-package org.simantics.help.ui;\r
-\r
-import org.eclipse.ui.PartInitException;\r
-import org.eclipse.ui.PlatformUI;\r
-import org.simantics.Logger;\r
-import org.simantics.Simantics;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.common.request.PossibleIndexRoot;\r
-import org.simantics.db.common.request.ReadRequest;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.db.layer0.variable.RVI;\r
-import org.simantics.db.layer0.variable.Variable;\r
-import org.simantics.db.layer0.variable.Variables;\r
-import org.simantics.help.HelpResources;\r
-import org.simantics.ui.workbench.ResourceEditorInput2;\r
-import org.simantics.ui.workbench.editor.AbstractResourceEditorAdapter;\r
-import org.simantics.utils.ui.workbench.WorkbenchUtils;\r
-\r
-public class OpenHelpFileAdapter extends AbstractResourceEditorAdapter {\r
-\r
- public OpenHelpFileAdapter() {\r
- super("Help File Editor");\r
- }\r
-\r
- protected String getEditorId() {\r
- return HelpFileEditor.getEditorId();\r
- }\r
- \r
- @Override\r
- protected boolean canHandle(ReadGraph g, Resource input) throws DatabaseException {\r
- return g.isInstanceOf(input, HelpResources.getInstance(g).HelpFile);\r
- }\r
- \r
- @Override\r
- protected void openEditor(Resource input) throws Exception {\r
- Simantics.getSession().asyncRequest(new ReadRequest() {\r
- @Override\r
- public void run(ReadGraph g) throws DatabaseException {\r
-\r
- Variable variable = Variables.getVariable(g, input);\r
- final Resource model = g.syncRequest(new PossibleIndexRoot(input));\r
- final RVI rvi = variable.getPossibleRVI(g);\r
- \r
- PlatformUI.getWorkbench().getDisplay().asyncExec(new Runnable() {\r
- @Override\r
- public void run() {\r
- try {\r
- String editorId = getEditorId();\r
- WorkbenchUtils.openEditor(editorId, new ResourceEditorInput2(editorId, input, model, rvi));\r
- } catch (PartInitException e) {\r
- Logger.defaultLogError(e);\r
- }\r
- }\r
- });\r
- }\r
- });\r
- }\r
-\r
-}\r
+package org.simantics.help.ui;
+
+import org.eclipse.ui.PartInitException;
+import org.eclipse.ui.PlatformUI;
+import org.simantics.Simantics;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.common.request.PossibleIndexRoot;
+import org.simantics.db.common.request.ReadRequest;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.variable.RVI;
+import org.simantics.db.layer0.variable.Variable;
+import org.simantics.db.layer0.variable.Variables;
+import org.simantics.help.HelpResources;
+import org.simantics.ui.workbench.ResourceEditorInput2;
+import org.simantics.ui.workbench.editor.AbstractResourceEditorAdapter;
+import org.simantics.utils.ui.workbench.WorkbenchUtils;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class OpenHelpFileAdapter extends AbstractResourceEditorAdapter {
+ private static final Logger LOGGER = LoggerFactory.getLogger(OpenHelpFileAdapter.class);
+
+ public OpenHelpFileAdapter() {
+ super(Messages.OpenHelpFileAdapter_HelpFileEditor);
+ }
+
+ protected String getEditorId() {
+ return HelpFileEditor.getEditorId();
+ }
+
+ @Override
+ protected boolean canHandle(ReadGraph g, Resource input) throws DatabaseException {
+ return g.isInstanceOf(input, HelpResources.getInstance(g).HelpFile);
+ }
+
+ @Override
+ protected void openEditor(Resource input) throws Exception {
+ Simantics.getSession().asyncRequest(new ReadRequest() {
+ @Override
+ public void run(ReadGraph g) throws DatabaseException {
+
+ Variable variable = Variables.getVariable(g, input);
+ final Resource model = g.syncRequest(new PossibleIndexRoot(input));
+ final RVI rvi = variable.getPossibleRVI(g);
+
+ PlatformUI.getWorkbench().getDisplay().asyncExec(new Runnable() {
+ @Override
+ public void run() {
+ try {
+ String editorId = getEditorId();
+ WorkbenchUtils.openEditor(editorId, new ResourceEditorInput2(editorId, input, model, rvi));
+ } catch (PartInitException e) {
+ LOGGER.error("Failed to open an editor for help file.", e); //$NON-NLS-1$
+ }
+ }
+ });
+ }
+ });
+ }
+
+}