Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Switch perspective in a RCP application since Eclipse Juno?

In my RCP application I use this code to switch perspective :

IWorkbenchWindow window = getViewSite().getWorkbenchWindow();
window.getWorkbench().showPerspective(PRODUCT_PERSPECTIVE_ID, window);

I didn't change my code but I changed my developement environnement from

java 6 64bits + windows + Eclipse Indigo

to

java 7 32bits + windows + Eclipse Juno

And now the perspective doesn't switch any more, with no exception and nothing suspect visible in debug.

I didn't find any bug report.

Is there an explanation ? A workaround ?

like image 205
Denys Séguret Avatar asked Jul 17 '12 13:07

Denys Séguret


3 Answers

I have run into this problem as well. As far as I can tell, it is a regression in Juno (4.2.0). I used the debugger to step through the call to showPerspective(). At no point was any explicit attempt made to actually change the perspective. Perhaps there is an internal event listener missing, or perhaps the port of showPerspective() to the new framework is incomplete.

As a work-around, the following code successfully changed perspectives for me:

IWorkbenchWindow window = getViewSite().getWorkbenchWindow();
IPerspectiveRegistry registry = workbench.getPerspectiveRegistry();
IWorkbenchPage page = window.getActivePage();
page.setPerspective(registry.findPerspectiveWithId(PRODUCT_PERSPECTIVE_ID));

Depending upon the context in which these calls are made, you might want to null-guard some of these calls, or check Workbench.isClosing() to be safe.

like image 171
WReach Avatar answered Nov 11 '22 22:11

WReach


This is bug https://bugs.eclipse.org/bugs/show_bug.cgi?id=395084 and fixed for Eclipse Luna which is scheduled to be released in June.

like image 27
Henno Vermeulen Avatar answered Nov 11 '22 22:11

Henno Vermeulen


Here's an answer that aims at clarifying and solving my problem :

Using the Eclipse 4 IDE, build a RCP application developped before Eclipse 4, integrating Java 7 features and compatible with Windows 32 bits. And of course be able to switch perspective.

This answer doesn't solve the problem of those who'd want to switch perspective in a RCP application AND use the features or look of the new Eclipse 4 Platform (not to be confused with the Eclipse 4 IDE). But I wouldn't recommend it, at least for an old application (that is developped on Eclipse 3), given that :

  • that's so slow it renders the application barely usable
  • there are numerous graphical glitches
  • there are bugs, among them the one related to perspective switch

For these 3 points, I can't say if it's due to the Eclipse 4 platform or the Eclipse 3 compatibility layer. I hope new applications developed specifically for the new Eclipse 4 platform would correctly run.

So my solution was to define an Eclipse 3 target and use it for the build.

Here's the complete procedure :

  1. Have the JDK 7 installed (32bits version)
  2. Install Eclipse 3.7 (32bits version)
  3. Install Eclipse 4 (32bits version)
  4. Launch Eclipse 4 and import the needed projects
  5. Go to Window/Preferences/Plug-in Development/Target Platform
  6. Click "Add" then "Nothing"
  7. Click "Add" then "Installation" and choose your Eclipse 3.7 directory
  8. Once your target created, select it (still in Window/Preferences/Plug-in Development/Target Platform)

Now, in your .product, the "Eclipse Product Export Wizard" will build an Eclipse 3 executable.

Practical notes :

  • "clean all" wasn't enough and I had to stop/restart Eclipse to get it working after target selection
  • the installation process erased some on my .product fields. I had to reset the ID and to check "The product includes native laucher artifacts"
like image 1
Denys Séguret Avatar answered Nov 11 '22 21:11

Denys Séguret