]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.modeling/src/org/simantics/modeling/SCLAction.java
Add utility class org.simantics.modeling.help.HelpContexts
[simantics/platform.git] / bundles / org.simantics.modeling / src / org / simantics / modeling / SCLAction.java
index a236c0aadb5616b5f49bd33bf076096cec9f3d02..ba7e7117fea1dc28202803be58e7961f6a34266d 100644 (file)
@@ -1,66 +1,69 @@
-package org.simantics.modeling;\r
-\r
-import org.simantics.Simantics;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.common.request.ResourceRead;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.db.layer0.adapter.ActionFactory;\r
-import org.simantics.db.layer0.variable.Variable;\r
-import org.simantics.db.layer0.variable.Variables;\r
-import org.simantics.diagram.Logger;\r
-import org.simantics.scl.runtime.function.Function1;\r
-\r
-public class SCLAction implements ActionFactory {\r
-\r
-       final private Resource rule;\r
-    \r
-    public SCLAction(ReadGraph graph, Resource rule) throws DatabaseException {\r
-       this.rule = rule;\r
-    }\r
-    \r
-    static class RuleFunctionRequest extends ResourceRead<Function1<Resource,Object>> {\r
-\r
-               protected RuleFunctionRequest(Resource rule) {\r
-                       super(rule);\r
-               }\r
-\r
-               @Override\r
-               public Function1<Resource, Object> perform(ReadGraph graph) throws DatabaseException {\r
-               Variable ruleVariable = Variables.getVariable(graph, resource);\r
-               ModelingResources MOD = ModelingResources.getInstance(graph);\r
-               return ruleVariable.getPossiblePropertyValue(graph, MOD.SCLAction_action);\r
-               }\r
-       \r
-    }\r
-    \r
-    public static class SCLActionRunnable implements Runnable {\r
-       \r
-       public Resource rule;\r
-       public Resource target;\r
-       \r
-       public SCLActionRunnable(Resource rule, Resource target) {\r
-               this.rule = rule;\r
-               this.target = target;\r
-       }\r
-       \r
-               @Override\r
-               public void run() {\r
-                       Resource resource = (Resource)target;\r
-                       Simantics.getSession().markUndoPoint();\r
-                       try {\r
-                               Function1<Resource, Object> function = Simantics.getSession().syncRequest(new RuleFunctionRequest(rule));\r
-                               function.apply(resource);\r
-                       } catch (DatabaseException e) {\r
-                               Logger.defaultLogError(e);\r
-                       }\r
-               }\r
-       \r
-    }\r
-\r
-       @Override\r
-       public Runnable create(final Object target) {\r
-               return new SCLActionRunnable(rule, (Resource)target);\r
-       }\r
-\r
-}\r
+package org.simantics.modeling;
+
+import org.simantics.Simantics;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.common.request.ResourceRead;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.adapter.ActionFactory;
+import org.simantics.db.layer0.variable.Variable;
+import org.simantics.db.layer0.variable.Variables;
+import org.simantics.scl.runtime.function.Function1;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class SCLAction implements ActionFactory {
+
+       private static final Logger LOGGER = LoggerFactory.getLogger(SCLAction.class);
+
+       final private Resource rule;
+    
+    public SCLAction(ReadGraph graph, Resource rule) throws DatabaseException {
+       this.rule = rule;
+    }
+    
+    static class RuleFunctionRequest extends ResourceRead<Function1<Resource,Object>> {
+
+               protected RuleFunctionRequest(Resource rule) {
+                       super(rule);
+               }
+
+               @Override
+               public Function1<Resource, Object> perform(ReadGraph graph) throws DatabaseException {
+               Variable ruleVariable = Variables.getVariable(graph, resource);
+               ModelingResources MOD = ModelingResources.getInstance(graph);
+               return ruleVariable.getPossiblePropertyValue(graph, MOD.SCLAction_action);
+               }
+       
+    }
+    
+    public static class SCLActionRunnable implements Runnable {
+       
+       public Resource rule;
+       public Resource target;
+       
+       public SCLActionRunnable(Resource rule, Resource target) {
+               this.rule = rule;
+               this.target = target;
+       }
+       
+               @Override
+               public void run() {
+                       Resource resource = (Resource)target;
+                       Simantics.getSession().markUndoPoint();
+                       try {
+                               Function1<Resource, Object> function = Simantics.getSession().syncRequest(new RuleFunctionRequest(rule));
+                               function.apply(resource);
+                       } catch (DatabaseException e) {
+                               LOGGER.error("SCLActionRunnable failed to request/apply RuleFunction {}", rule, e);
+                       }
+               }
+       
+    }
+
+       @Override
+       public Runnable create(final Object target) {
+               return new SCLActionRunnable(rule, (Resource)target);
+       }
+
+}