- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2
Eclipse 4 migration notes
Starting from the July 2017 cycle, we are migrating IBEX from running on the Eclipse 3 platform to running on the Eclipse 4 platform. Initial investigation by Dominic Oram indicates that this is going to require significant time investment from the team.
The goal of the project is to run IBEX on an Eclipse 4.x platform. Notably the current stable release of CSS is 4.4.3, which runs on Eclipse Mars (4.5), hence we have used this as our target platform as well as our development environment
This is largely the same as setting up your E3 workspace. It's best to create a separate workspace for your E3 & E4 development.
Launching the E4 application is very similar to the launching the E3 application as detailed in the getting started guide.
- Create a new workspace
- Import all of the plugins from C:\Instrument\Dev\ibex_gui\base
- Change your run configuration to clear the workspace on launch. Unless you do this in E4 applications, changes to the code are not always propagated to the build
- Open the run configurations dialog
- With "ibex.product" selected under "Eclipse Application" in the left-hand nav bar, go to the "Main" tab
- Make sure the "Clear" box is ticked with the radio button set to "workspace"
- Under the "Configuration" tab, select "Clear the configuration area before launching"
- Click "Apply" then close the dialog
 
- Set the target platform. If it's covered in red, select each source followed by "Update" and "Reload". Once that's done, click "Set target platform"
- Go to the ...e4.client.productplugin.
- Open ibex.product
- Click Synchronize
- Click Launch Eclipse applicationor equivalent for debug
If you are still experiencing errors, you may still need to set up your new workspace for IBEX development. See this page for instructions.
As of 15th September 2017, the data source definitions are not contained in the GUI. The expectation is that we will fix that soon. Until then, you need the following files:
- C:\Users\[fedID]\.diirt\datasources\datasources.xml
<?xml version='1.0' encoding='UTF-8'?>
<dataSources version="1">
    <compositeDataSource defaultDataSource="ca" />
</dataSources>
- C:\Users\[fedID]\.diirt\datasources\ca\ca.xml
<?xml version='1.0' encoding='UTF-8'?>
<ca version="1">
    <jcaContext pureJava="true" addr_list="" auto_addr_list="true" connection_timeout="30.0"
                beacon_period="15.0" repeater_port="5065" server_port="5064"
                max_array_bytes="5000000" />
</ca>
If you don't have the datasources file, you won't be able to connect to any PVs. Without the ca file, you may still be able to connect to some PVs, but only certain ones. We've observed that the configuration dialogs won't load without it.
- Open the Application.e4xmi from uk.ac.stfc.isis.ibex.e4.client
- Go to Snippets
- Click Addto add a new perspective
- Set the perspective up using an existing migrated perspective as a template
- Set a sensible ID
- Give it a label
- Set the icon
- Add controls. This should be a hierarchy of part sash containers. You can see how it should be set up from the existing perspectives. Don't forget to set the container data where appropriate; it sets the relative size of sibling components.
 
- Add the perspective-specific parts
- In the alarms perspective, you'll see one part in the final part sash container called alarms. Do the same thing in your new perspective, but give it an appropriate name
- Change the ID of your new part to the ID of the view class you want the perspective to open
 
- Add the dependency of the view you've added to the plugin.xmlin the...e4.clientplugin
- Add the new dependency to ...feature.base
- Open IBEX
- Check the new perspective scales appropriately and change the layout accordingly if needed
Eclipse 4 supports running Eclipse 3.x applications using the "compatibility" layer. In Eclipse 4.5, this is built into the tooling and so doesn't require any code changes to activate. The required plugins just need to be activated as part of the run configuration. Eclipse does an OK job at handling this automatically but has a tendency to either pull in too much if optional dependencies are included, or too little if they are not.
As part of the branch Ticket2376_E4_Compatibility, the code will build on the Eclipse 4 platform. However, I have not had much luck successfully launching IBEX in it's current form:
- Including all plugins in a workspace along with required plugins (and optional) results in an application that will not launch
- Including *.ui.dashboardand everything it needs (40 other IBEX plugins) results in an application that does make it to launch eventually (it struggles) but all of the plugins fail to initialise and there are many visual issues. Notably in this format, the current views do not have fixed size.
Owing to this investigation, and discussions with John and Kevin, I have chosen to create a brand new application based on the Eclipse 4 application model using the existing code as a base.
As part of the first stage of the application migration, I have created a branch Ticket2376_E4_prototype_migrated. To run it, set up a new E4 workspace as per these instructions.
Many of the application's views have been mocked using screenshots of the current system. These are 'cartoonified' to make them look less realistic to avoid confusion. The views that have been converted so far are the dashboard and the beam status view.
There are a few technical aspects that are worth noting that will affect future migration steps.
I discovered this while importing the minimal plugins for the dashboard. There is an architectural error in having it rely on the script generator. The dependency comes from ...ibex.ui.widgets. This dependency should ideally be resolved.
At the moment, the plugins required for the build are defined in the feature plugins. We don't have to change these very often on master because we don't often add new plugins. However, we will do it very frequently on this branch. So that the run configuration is valid, when you add a new plugin, make sure to add it and any dependencies to the feautre.xml file. You shouldn't ever need to edit the included plugins via the Run configurations menu.
There's a CSStudio plugin called jre6.fragment. Despite appearances, it is an RAP, not and RCP plugin. If you include it, many of the views won't load properly. In some cases, I've had to add new imports into the target platform to get around this limitation. If you ask the "Run configurations" menu to add required plugins though, it will add it and your application will no longer run properly. You have been warned!
I've gotten into the habit of using TODOs in Eclipse to identify bits of work that I haven't yet gotten around to or rely on later stages of migration. They can be listed by opening up the Eclipse "Tasks" window. The current TODOs are:
- 
BeamStatusView.java: The PVs haven't been connected to the beam status view because the archiver doesn't connect properly yet
- 'BeamStatusView.java: Using theshowToolbar(false)` command doesn't actually hide the toolbar in the beam status view. I've tried working around this but ran out of time. We should sort it out eventually but I've left it for the time being. We may want to change that entire part eventually to just be two databrowsers in different tabs rather than embedding the graph in a separate view. That relies on a later bit of work though.
- Perspective switching: I've written a basic perspective switcher uk.ac.stfc.isis.ibex.e4.ui.perspectiveswitcher. It does what we need it to for now but later on we should switch to using snippets rather than shared elements to build our perspectives. The reason is that shared elements retain changes to their size between perspectives which sounds nice but can lead to very weird behaviour. I think it's best avoided. Similarly, snippets will be necessary to do things like restoring default views of a perspective. In all, we shouldn't have to hard code our perspectives, so it would be better managed via an extension point.
- Right click on block menu is in something I touched but is probably best done as part of the blocks migration
- Reenable detecor diagnostics on tab changes PV is DAE:DIAG:ENABLE:FOR
Nick Battam at Diamond has been very helpful. He has also recommended we speak to Will Rogers, as he's done a lot of Eclipse 4 work in CSStudio.
The Application model in uk.ac.stfc.isis.ibex.e4.client defines the structure of the application. In a pure E4 application, when parts are created we use annotations and dependency injection to define when and how the views are constructed. That's different from Eclipse 3.x which used parts derived from ViewPart that call createPartControl instead of using the annotation @PartConstruct. Further, even if we do manage to build the view with some clever function calls, the RCP model is unavailable to us and we get lots of exceptions (e.g. getSite() returns null).
To use a CSS view, or something derived from it, in Eclipse 4, create a shared part element in the application model. Give it the ID of the view you want to use (e.g. uk.ac.stfc.isis.ibex.ui.alarm.AlarmView) and in Class URI use bundleclass://org.eclipse.ui.workbench/org.eclipse.ui.internal.e4.compatibility.CompatibilityView. When you use that shared element in your perspective, it will build and run as if it were in Eclipse 3.x.
The way Eclipse RCP works, if you include certain plugins (often denoted with the suffix ui) in your application, it will add certain elements to the UI, whether you want it to or not! Sometimes you can't avoid adding these plugins because they're required for something else you want to use. To get rid of them, hide them from the application model:
- Make sure model spy is active. The feature uk.ac.stfc.isis.ibex.feature.spiesshould be included inuk.ac.stfc.isis.ibex.feature.base.
- Open ibex.productinuk.ac.stfc.isis.ibex.e4.client.productand clickSynchronizeto make sure all relevant plugins have been activated in the run configuration
- Launch the application
- Press Ctrl+Shift+F9to access the application spies
- Find the model spy and navigate to the element you want to hide
- Add the element to Application.e4xmiinuk.ac.stfc.isis.ibex.e4.clientand untick theTo Be RenderedandVisiblecheckboxes
To create a menu item:
- Create a command in Commandsin application
- Create a menu item in the application model "windows and dialogue" > "Main menu" and use the command you have just created
- Add the command to a command category if applicable (I am not sure why but it might be useful later)
- Add a handler in which handles the command just created which is the same one used before the migration:
- Change the handler to not inherit from AbstractHandler
- Replace @overrideon the execute method with a@Executeyou will probably also want the shell injected to display stuff e.g.@Execute public void execute(Shell shell)
- Add an method and label @CanExecute this should return true if the command can be executed
 
- Remove the menu item from the extension to avoid the errors like "[main] ERROR org.eclipse.ui.workbench - uk.ac.stfc.isis.ibex.ui.mainmenu.managermode.ManagerModeHandler cannot be cast to org.eclipse.core.commands.IHandler"