This document describes how to get and build the sources. It also covers how to setup the Eclipse workspace to run JBoss Fuse Tooling from inside a vanilla Eclipse.
The easiest way to get started with the code is to create your own fork at github, and then clone your fork:
$ git clone [email protected]:<you>/fuseide.git
$ cd fuseide
$ git remote add upstream git://github.com/fusesource/fuseide.git
At any time, you can pull changes from the upstream and merge them onto your master:
$ git checkout master # switches to the 'master' branch
$ git pull upstream master # fetches all 'upstream' changes and merges 'upstream/master' onto your 'master' branch
$ git push origin # pushes all the updates to your fork, which should be in-sync with 'upstream'
The general idea is to keep your 'master' branch in-sync with the 'upstream/master'.
To build JBoss Fuse Tooling requires specific versions of Java (1.6+) and +Maven (3.0+).
This command will run the build:
$ mvn clean package
If you just want to check if things compiles/builds you can run:
$ mvn clean package -Dmaven.test.skip=true
At master branch we always try to use the latest Eclipse version. Please refer to the target platform plugin to see which versions of Eclipse are supported. The master branch was using Eclipse Luna when this document was created.
Now its time to open your Eclipse if you haven't done so.
Here's how to setup Eclipse...
- create a new workspace for working on JBoss Fuse Tooling
- import the project into Eclipse from directory "fuseide" (Import... -> General -> Existing Project)
- open the target platform module called "org.fusesource.ide.targetplatform"
- open jbtis_4.1_dev.target for Kepler OR open jbtis_4.2_dev.target for Luna
- wait until all is resolved (see progress in the bottom right) and then click the "Set as Target Platform" link in the top right
Now your Eclipse has set the target platform you need for running JBoss Fuse Tooling. A rebuild of all imported projects is done directly after setting the target platform. Make sure there are no more errors displayed in any of the projects.
To get rid of the access restriction warnings open menu
Eclipse -> Preferences -> Java -> Compiler / Errors/Warnings -> Deprecated and restricted API
then turn Forbidden reference (access rules) to "Warning" (it was "Error").
Before trying to run the Fuse Tooling you should have built the project, imported it successfully into Eclipse and also set the correct target platform (see the steps above).
To run open the Run Configurations dialog and select one of the following Eclipse Applications:
JBTIS Kepler Linux.launch # Eclipse Kepler based
JBTIS Luna Linux.launch # Eclipse Luna based
It may be possible that you have to adapt the launch configuration to fit your environment. If your OS doesn't have a launch configuration yet just create one by copying one of the Linux configurations and then inside the Plugins tab make sure to hit the Add required button. That should fix most of the problems.
Tycho downloads all needed plugins into the folder
<user.home>/.m2/repository/p2
If you kill a Tycho build you can sometimes end up with corrupted downloads leading to failed builds. The usual exception you will see then is something like this...
java.util.zip.ZipException: error in opening zip file
at java.util.zip.ZipFile.open(Native Method)
at java.util.zip.ZipFile.<init>(ZipFile.java:114)
at org.codehaus.tycho.osgitools.DefaultBundleReader.doLoadManifest(DefaultBundleReader.java:85)
at org.codehaus.tycho.osgitools.DefaultBundleReader.loadManifest(DefaultBundleReader.java:47)
at org.codehaus.tycho.osgitools.EquinoxResolver.loadManifest(EquinoxResolver.java:199)
at org.codehaus.tycho.osgitools.EquinoxResolver.addBundle(EquinoxResolver.java:175)
at org.codehaus.tycho.osgitools.EquinoxResolver.newState(EquinoxResolver.java:157)
at org.codehaus.tycho.osgitools.EquinoxResolver.newResolvedState(EquinoxResolver.java:52)
The quick fix is to trash your folder:
~/.m2/repository/p2
Be careful deleting that folder as with the next build it will download lots of plugins from the internet again.