Skip to content
/ IDE Public

Provides editor support for various network programming and other specifications languages used in the development lifecycle.

License

Notifications You must be signed in to change notification settings

fp7-netide/IDE

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NetIDE Eclipse Plug-Ins

This Repository contains the plug-ins needed for a graphical network editing and the generation of platform-specific code.

Requirements

In order to use NetIDE to its full extend, you need to install VirtualBox and Vagrant. NetIDE deploys your network apps on virtual machines which are set up and managed with vagrant.

In order to execute commands on your VM through the IDE, you also need an installation of SSH. If you are running Windows, make sure that your ssh executable is referenced in the PATH variable.

You'll also need at least Java 8.

Installation

...using the Eclipse Marketplace

  1. Open your Eclipse installation and navigate to Help->Eclipse Marketplace... in the Menubar.
  2. Search for NetIDE, click Install and follow the instructions. After restarting Eclipse, NetIDE is ready to run.

Alternatively, you can drag the button below into your running Eclipse window.

Drag to your running Eclipse workspace to install NetIDE

...using the Update Site

  1. Open your Eclipse installation and navigate to Help->Install New Software....
  2. Enter http://updatesite.netide.eu/stable for a stable installation or http://updatesite.netide.eu/nightly for nightly builds.
  3. Select NetIDE click Next and follow the instructions. After restarting Eclipse, NetIDE is ready to run.

...by building from source

Check out the master branch.

Navigate to the folder releng/eu.netide.dependencies and type mvn p2:site. This will build an Eclipse repository for external dependencies at releng/eu.netide/dependencies/target/repository.

Navigate to the folder releng/eu.netide.parent and type MAVEN_OPTS="-Xmx1024M" mvn package. The build process can take some time.

Once it has finished, you'll find the contents of an eclipse update site as a zip file in releng/eu.netide.product/target.

Open your Eclipse installation.

Go to Help->Install New Software->Add->Local and specify the location of the dependency repository. Go to Help->Install New Software->Add->Archive and specify the location of the zip file.

Select NetIDE from the list and follow the instructions. After restarting Eclipse, NetIDE is ready to run.

Set up Eclipse

  1. Download Eclipse Neon Modeling Tools here.
  2. From the window menu, select Help -> Install Modeling Components. Select and install Sirius and Xtext.
  3. Go to Help -> Eclipse Marketplace..., search for and install TM Terminal.
  4. Go to Help -> Install New Software, enter http://updatesite.netide.eu/dependencies, and install the packages provided by this repository.
  5. Use the same UI to install the BIRT SDK.
  6. Start Eclipse and open the Git Perspective.
  7. Clone or add this git repository and import all projects from the "plugins"-folder into your workspace. To do so, enter to the folder "Working Directory", right-click on the folder "plugins" and select "Import Projects". Follow the steps in the wizard.
  8. Open the Plug-In Development perspective and open eu.netide.configuration/model/Topology.genmodel. Right-click the root element in the tree view and select Generate All
  9. Open the Plug-In Development perspective and open eu.netide.runtime.topology/model/RuntimeTopology.genmodel. Right-click the root element in the tree view and select Generate All
  10. For both projects "eu.netide.parameters.language" and "eu.netide.sysreq", do the following:
    1. Find the *.mwe2 file in the source folder.
    2. Right-click on the mwe2 file and select "Run As -> MWE2 Workflow". A dialog box should pop up informing you about errors in the project. Click "Proceed".
    3. A console view in the bottom region will appear and ask you to install the Antlr parser. Type "y" into the console and hit Return.
  11. Right-click the project eu.netide.configuration and select Run As -> Eclipse Application
  12. If you want to develop your Python-based controllers in Eclipse as well, you can install the PyDev plug-in for Eclipse from the Eclipse Marketplace.

Usage

Consult the wiki pages for a detailed usage manual.

Examples

For examples, have a look at the examples folder. You can import the examples into your runtime workspace from there.

Troubleshooting

Vagrant does not start when running a launch configuration

If Vagrant displays the error message The box 'ubuntu/trusty64' could not be found, make sure you have installed a recent version of vagrant. For example, the version in the repositories for Ubuntu 14.04 LTS (1.4.3-1) is too old. After upgrading Vagrant, it may be necessary to remove the directory ~/.vagrant.d.

If your vagrant executable is not in a standard location (/usr/bin/vagrant or C:\Hashicorp\Vagrant\bin\vagrant.exe) you have to enter your custom location under "Window -> Preferences -> NetIDE".

Generating mininet configurations fails with "The chosen operation is not currently available"

This error occurs if the projects in the plugins-folder have not been imported properly. They have to be imported as Projects, or, in the case of eu.netide.configuration, as General Projects. The simplest way to do this is to right-click the plugins-folder in the Git perspective and choosing "Import Projects..." from the menu.

Compiler errors after pulling

The code you just pulled may use a more recent version of the Topology meta-model. If you run into compiler errors, just repeat step 7 and 8 from the Installation guide. This generates new model code from the newest version of the meta-model.

Large amounts of disk space used

NetIDE creates a VM for each topology modeling project to set up a clean simulation environment. Delete the gen folder in your project and open the Virtualbox GUI to delete the VM completely, once you do not need it anymore.

About

Provides editor support for various network programming and other specifications languages used in the development lifecycle.

Resources

License

Stars

Watchers

Forks

Packages

No packages published