-package org.simantics.scl.ui.editor2;\r
-\r
-import org.eclipse.core.commands.AbstractHandler;\r
-import org.eclipse.core.commands.ExecutionEvent;\r
-import org.eclipse.core.commands.ExecutionException;\r
-import org.eclipse.ui.IWorkbenchPage;\r
-import org.eclipse.ui.PartInitException;\r
-import org.eclipse.ui.PlatformUI;\r
-import org.simantics.scl.compiler.elaboration.modules.SCLValue;\r
-import org.simantics.scl.compiler.errors.Locations;\r
-import org.simantics.scl.ui.browser.SCLDefinitionSelectionDialog;\r
-\r
-public class OpenSCLDefinition extends AbstractHandler {\r
-\r
- @Override\r
- public Object execute(ExecutionEvent event) throws ExecutionException {\r
- SCLDefinitionSelectionDialog dialog = new SCLDefinitionSelectionDialog(\r
- PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell());\r
- if(dialog.open() == SCLDefinitionSelectionDialog.OK) {\r
- SCLValue value = (SCLValue)dialog.getFirstResult();\r
- if(value != null)\r
- openDefinition(value);\r
- }\r
- return null;\r
- }\r
- \r
- public static void openDefinition(SCLValue value) {\r
- openDefinition(value.getName().module, value.definitionLocation);\r
- }\r
- \r
- public static void openDefinition(String moduleName, long location) {\r
- IWorkbenchPage page = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getActivePage();\r
- if(page == null)\r
- return;\r
- SCLModuleEditorInput input = new StandardSCLModuleEditorInput(moduleName);\r
- try {\r
- SCLModuleEditor2 editor = (SCLModuleEditor2)page.openEditor(input, "org.simantics.scl.ui.editor2");\r
- if(location != Locations.NO_LOCATION) {\r
- int begin = Locations.beginOf(location);\r
- int end = Locations.endOf(location);\r
- editor.selectAndReveal(begin, end-begin);\r
- }\r
- } catch (PartInitException e) {\r
- e.printStackTrace();\r
- }\r
- }\r
-\r
-}\r
+package org.simantics.scl.ui.editor2;
+
+import org.eclipse.core.commands.AbstractHandler;
+import org.eclipse.core.commands.ExecutionEvent;
+import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.swt.widgets.Display;
+import org.eclipse.ui.IWorkbenchPage;
+import org.eclipse.ui.PartInitException;
+import org.eclipse.ui.PlatformUI;
+import org.simantics.scl.compiler.elaboration.modules.SCLValue;
+import org.simantics.scl.compiler.errors.Locations;
+import org.simantics.scl.ui.browser.SCLDefinitionSelectionDialog;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class OpenSCLDefinition extends AbstractHandler {
+
+ private static final Logger LOGGER = LoggerFactory.getLogger(OpenSCLDefinition.class);
+
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
+ SCLDefinitionSelectionDialog dialog = new SCLDefinitionSelectionDialog(
+ PlatformUI.getWorkbench().getActiveWorkbenchWindow().getShell());
+ if(dialog.open() == SCLDefinitionSelectionDialog.OK) {
+ SCLValue value = (SCLValue)dialog.getFirstResult();
+ if(value != null)
+ scheduleOpenDefinition(value.getName().module, value.definitionLocation);
+ }
+ return null;
+ }
+
+ public static void openDefinition(SCLValue value) {
+ openDefinition(value.getName().module, value.definitionLocation);
+ }
+
+ public static Runnable openDefinition(String moduleName, long location) {
+ return () -> {
+ IWorkbenchPage page = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getActivePage();
+ if(page == null)
+ return;
+ SCLModuleEditorInput input = new StandardSCLModuleEditorInput(moduleName);
+ try {
+ SCLModuleEditor2 editor = (SCLModuleEditor2)page.openEditor(input, "org.simantics.scl.ui.editor2"); //$NON-NLS-1$
+ if(location != Locations.NO_LOCATION) {
+ int begin = Locations.beginOf(location);
+ int end = Locations.endOf(location);
+ editor.selectAndReveal(begin, end-begin);
+ }
+ } catch (PartInitException e) {
+ LOGGER.error("", e); //$NON-NLS-1$
+ }
+ };
+ }
+
+ public static void scheduleOpenDefinition(String moduleName, long location) {
+ Display.getCurrent().asyncExec(openDefinition(moduleName, location));
+ }
+
+}