]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.structural2/src/org/simantics/structural2/StructuralVariables.java
Migrated source code from Simantics SVN
[simantics/platform.git] / bundles / org.simantics.structural2 / src / org / simantics / structural2 / StructuralVariables.java
diff --git a/bundles/org.simantics.structural2/src/org/simantics/structural2/StructuralVariables.java b/bundles/org.simantics.structural2/src/org/simantics/structural2/StructuralVariables.java
new file mode 100644 (file)
index 0000000..0e81e10
--- /dev/null
@@ -0,0 +1,185 @@
+package org.simantics.structural2;\r
+\r
+import java.util.ArrayList;\r
+\r
+import org.simantics.databoard.Bindings;\r
+import org.simantics.databoard.util.URIStringUtils;\r
+import org.simantics.db.ReadGraph;\r
+import org.simantics.db.Resource;\r
+import org.simantics.db.Session;\r
+import org.simantics.db.common.ResourceArray;\r
+import org.simantics.db.common.primitiverequest.PossibleObject;\r
+import org.simantics.db.common.request.PossibleTypedParent;\r
+import org.simantics.db.common.request.Queries;\r
+import org.simantics.db.common.utils.NameUtils;\r
+import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.db.layer0.variable.Variable;\r
+import org.simantics.db.layer0.variable.VariableInterface;\r
+import org.simantics.layer0.Layer0;\r
+import org.simantics.operation.Layer0X;\r
+import org.simantics.simulation.ontology.SimulationResource;\r
+import org.simantics.structural.stubs.StructuralResource2;\r
+\r
+/**\r
+ * @deprecated Don't use this class anymore. It contains nothing worth using.\r
+ */\r
+@Deprecated\r
+final public class StructuralVariables {\r
+\r
+       private static final boolean DEBUG = false;\r
+\r
+       \r
+       public static Resource getCompositeParent(Session session, Resource component) throws DatabaseException {\r
+\r
+               Layer0 L0 = Layer0.getInstance(session);\r
+               StructuralResource2 sr = StructuralResource2.getInstance(session);\r
+               Resource parent = session.syncRequest( new PossibleObject(component, L0.PartOf) );\r
+               if(parent == null) return null;\r
+               if ( session.syncRequest( Queries.isInstanceOf(parent, sr.Component) )) return parent;\r
+               return null;\r
+               \r
+       }\r
+       \r
+       public static Resource getCompositeParent(ReadGraph graph, Resource component) throws DatabaseException {\r
+\r
+               Layer0 L0 = Layer0.getInstance(graph);\r
+               StructuralResource2 sr = StructuralResource2.getInstance(graph);\r
+               Resource parent = graph.getPossibleObject(component, L0.PartOf);\r
+               if(parent == null) return null;\r
+               if(graph.isInstanceOf(parent, sr.Composite)) return parent;\r
+               return null;\r
+               \r
+       }\r
+\r
+       public static ResourceArray getCompositeArray(Session session, Resource composite) throws DatabaseException {\r
+               \r
+               ArrayList<Resource> path = new ArrayList<Resource>();\r
+               while(composite != null) {\r
+                       path.add(composite);\r
+                       composite = getCompositeParent(session, composite);\r
+               }\r
+               return new ResourceArray(path).reversed();\r
+               \r
+       }\r
+       \r
+       public static ResourceArray getCompositeArray(ReadGraph graph, Resource composite) throws DatabaseException {\r
+               \r
+               ArrayList<Resource> path = new ArrayList<Resource>();\r
+               while(composite != null) {\r
+                       path.add(composite);\r
+                       composite = getCompositeParent(graph, composite);\r
+               }\r
+               return new ResourceArray(path).reversed();\r
+               \r
+       }\r
+       \r
+       public static ResourceArray getComponentArray(ReadGraph graph, Resource component) throws DatabaseException {\r
+               \r
+               Resource composite = getCompositeParent(graph, component);\r
+               return getCompositeArray(graph, composite).appended(component);\r
+               \r
+//             ArrayList<Resource> path = new ArrayList<Resource>();\r
+//             path.add(component);\r
+//             component = getCompositeParent(graph, component);\r
+//             while(component != null) {\r
+//                     path.add(component);\r
+//                     component = getCompositeParent(graph, component);\r
+//             }\r
+//             return new ResourceArray(path).reversed();\r
+               \r
+       }\r
+\r
+       public static ResourceArray getComponentArray(ReadGraph graph, ResourceArray prefix, Resource component) throws DatabaseException {\r
+               \r
+               return prefix.appended(getComponentArray(graph, component));\r
+               \r
+       }\r
+\r
+       static Resource getModel(ReadGraph graph, ResourceArray path) throws DatabaseException {\r
+               \r
+               // The first element is the configuration composite\r
+               return graph.getPossibleObject(path.resources[0], SimulationResource.getInstance(graph).IsConfigurationOf);\r
+               \r
+       }\r
+       \r
+       public static Resource getRootComposite(ReadGraph graph, Resource component) throws DatabaseException {\r
+\r
+               ResourceArray fullPath = getComponentArray(graph, ResourceArray.EMPTY, component);\r
+               return fullPath.head();\r
+               \r
+       }\r
+       \r
+       public static Variable getVariable(ReadGraph graph, ResourceArray path, Resource component) throws DatabaseException {\r
+               \r
+               ResourceArray fullPath = getComponentArray(graph, path, component);\r
+               Resource model = getModel(graph, fullPath);\r
+               if(model == null) return null;\r
+               VariableInterface variables = graph.adapt(model, VariableInterface.class);\r
+               return variables.getVariable(graph, fullPath.removeFromBeginning(1));\r
+               \r
+       }\r
+\r
+    /**\r
+     * @param graph\r
+     * @param array\r
+     * @return RVI, never <code>null</code>\r
+     * @throws DatabaseException\r
+     */\r
+    public static String getRVI(ReadGraph graph, ResourceArray array) throws DatabaseException {\r
+        Layer0 L0 = Layer0.getInstance(graph);\r
+        String result = "";\r
+        for(Resource r : array) {\r
+            if(DEBUG) System.out.println("Variables.getRVI " + NameUtils.getSafeName(graph, r) );\r
+            String name = graph.getRelatedValue(r, L0.HasName, Bindings.STRING);\r
+            String segment = URIStringUtils.escape(name);\r
+            result += "/" + segment;\r
+        }\r
+        return result;\r
+    }\r
+    \r
+    public static String getRVI(Session session, ResourceArray array) throws DatabaseException {\r
+        Layer0 L0 = Layer0.getInstance(session);\r
+        String result = "";\r
+        for(Resource r : array) {\r
+               String safeName = session.syncRequest( Queries.safeName(r) );\r
+            if(DEBUG) System.out.println("Variables.getRVI " + safeName );            \r
+            String name = (String) session.syncRequest( Queries.getRelatedValue(r, L0.HasName, Bindings.STRING) );\r
+            String segment = URIStringUtils.escape(name);\r
+            result += "/" + segment;\r
+        }\r
+        return result;\r
+    }\r
+    \r
+\r
+    /**\r
+     * @param graph\r
+     * @param array\r
+     * @return RVI or <code>null</code> if it can't be resolved\r
+     * @throws DatabaseException\r
+     */\r
+    public static String getPossibleRVI(ReadGraph graph, ResourceArray array) throws DatabaseException {\r
+        Layer0 L0 = Layer0.getInstance(graph);\r
+        String result = "";\r
+        for(Resource r : array) {\r
+            if(DEBUG) System.out.println("Variables.getRVI " + NameUtils.getSafeName(graph, r) );\r
+            String name = graph.getPossibleRelatedValue(r, L0.HasName, Bindings.STRING);\r
+            if (name == null)\r
+                return null;\r
+            String segment = URIStringUtils.escape(name);\r
+            result += "/" + segment;\r
+        }\r
+        return result;\r
+    }\r
+\r
+       public static Resource getModel(ReadGraph graph, Resource composite) throws DatabaseException {\r
+               return graph.syncRequest(new PossibleTypedParent(composite, SimulationResource.getInstance(graph).Model));\r
+       }\r
+\r
+       public static Resource getBaseRealization(ReadGraph graph, Resource composite) throws DatabaseException {\r
+               Layer0X L0X = Layer0X.getInstance(graph);\r
+               Resource model = getModel(graph, composite);\r
+               if(model == null) return null;\r
+               return graph.getPossibleObject(model, L0X.HasBaseRealization);\r
+       }\r
+       \r
+}\r