]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.modeling/src/org/simantics/modeling/mapping/NamingCreationInstruction.java
Layer0Utils.addL0Identifier to prevent possible differentiation of code
[simantics/platform.git] / bundles / org.simantics.modeling / src / org / simantics / modeling / mapping / NamingCreationInstruction.java
index fd2dda7f403ae17595c64daee8e19e4759b8f502..3330587b934f5e9c233b997e6b96745aff8e9168 100644 (file)
@@ -1,79 +1,80 @@
-/*******************************************************************************\r
- * Copyright (c) 2007, 2010 Association for Decentralized Information Management\r
- * in Industry THTH ry.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- *     VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.modeling.mapping;\r
-\r
-import gnu.trove.map.hash.TIntIntHashMap;\r
-import gnu.trove.set.hash.TIntHashSet;\r
-\r
-import org.simantics.datatypes.literal.GUID;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.WriteGraph;\r
-import org.simantics.db.common.utils.CommonDBUtils;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.layer0.Layer0;\r
-import org.simantics.layer0.utils.direct.GraphUtils;\r
-import org.simantics.mapping.constraint.instructions.TypedBracketInstruction.CreationInstruction;\r
-import org.simantics.modeling.services.ComponentNamingUtil;\r
-import org.simantics.modeling.services.NamingException;\r
-import org.simantics.project.IProject;\r
-\r
-public class NamingCreationInstruction extends CreationInstruction {\r
-\r
-    IProject project;\r
-    int configurationRoot;\r
-    int lComponentType;\r
-    int lConfiguration;\r
-\r
-    public NamingCreationInstruction(IProject project, int configurationRoot, int variableId, int componentType,\r
-            int configuration) {\r
-        super(variableId);\r
-        this.project = project;\r
-        this.configurationRoot = configurationRoot;\r
-        lComponentType = componentType;\r
-        lConfiguration = configuration;\r
-    }\r
-\r
-    @Override\r
-    public Resource create(WriteGraph g, Object[] bindings) throws DatabaseException {\r
-        Resource componentType = (Resource) bindings[lComponentType];\r
-        Resource configuration = (Resource) bindings[lConfiguration];\r
-\r
-        try {\r
-               CommonDBUtils.selectClusterSet(g, configuration);\r
-            String proposition = ComponentNamingUtil.findFreshInstanceName(g, project, (Resource)bindings[configurationRoot], configuration, componentType);\r
-               Layer0 b = Layer0.getInstance(g);\r
-            Resource result = GraphUtils.create(g,\r
-                    b.HasName, proposition\r
-            );\r
-            g.addLiteral(result, b.identifier, b.identifier_Inverse, b.GUID, GUID.random(), GUID.BINDING);\r
-            return result;\r
-        } catch (NamingException e1) {\r
-            throw new DatabaseException(e1);\r
-        }\r
-    }\r
-\r
-    @Override\r
-    public void mapVariables(TIntIntHashMap map) {\r
-        super.mapVariables(map);\r
-        lComponentType = map.get(lComponentType);\r
-        lConfiguration = map.get(lConfiguration);\r
-        configurationRoot = map.get(configurationRoot);\r
-    }\r
-    \r
-    @Override\r
-    public void collectVariables(TIntHashSet reads, TIntHashSet writes) {\r
-       reads.add(lComponentType);\r
-       reads.add(lConfiguration);\r
-       reads.add(configurationRoot);\r
-    }\r
-\r
-}\r
+/*******************************************************************************
+ * Copyright (c) 2007, 2010 Association for Decentralized Information Management
+ * in Industry THTH ry.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     VTT Technical Research Centre of Finland - initial API and implementation
+ *******************************************************************************/
+package org.simantics.modeling.mapping;
+
+import gnu.trove.map.hash.TIntIntHashMap;
+import gnu.trove.set.hash.TIntHashSet;
+
+import org.simantics.datatypes.literal.GUID;
+import org.simantics.db.Resource;
+import org.simantics.db.WriteGraph;
+import org.simantics.db.common.utils.CommonDBUtils;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.util.Layer0Utils;
+import org.simantics.layer0.Layer0;
+import org.simantics.layer0.utils.direct.GraphUtils;
+import org.simantics.mapping.constraint.instructions.TypedBracketInstruction.CreationInstruction;
+import org.simantics.modeling.services.ComponentNamingUtil;
+import org.simantics.modeling.services.NamingException;
+import org.simantics.project.IProject;
+
+public class NamingCreationInstruction extends CreationInstruction {
+
+    IProject project;
+    int configurationRoot;
+    int lComponentType;
+    int lConfiguration;
+
+    public NamingCreationInstruction(IProject project, int configurationRoot, int variableId, int componentType,
+            int configuration) {
+        super(variableId);
+        this.project = project;
+        this.configurationRoot = configurationRoot;
+        lComponentType = componentType;
+        lConfiguration = configuration;
+    }
+
+    @Override
+    public Resource create(WriteGraph g, Object[] bindings) throws DatabaseException {
+        Resource componentType = (Resource) bindings[lComponentType];
+        Resource configuration = (Resource) bindings[lConfiguration];
+
+        try {
+               CommonDBUtils.selectClusterSet(g, configuration);
+            String proposition = ComponentNamingUtil.findFreshInstanceName(g, project, (Resource)bindings[configurationRoot], configuration, componentType);
+               Layer0 b = Layer0.getInstance(g);
+            Resource result = GraphUtils.create(g,
+                    b.HasName, proposition
+            );
+            Layer0Utils.addL0Identifier(g, result);
+            return result;
+        } catch (NamingException e1) {
+            throw new DatabaseException(e1);
+        }
+    }
+
+    @Override
+    public void mapVariables(TIntIntHashMap map) {
+        super.mapVariables(map);
+        lComponentType = map.get(lComponentType);
+        lConfiguration = map.get(lConfiguration);
+        configurationRoot = map.get(configurationRoot);
+    }
+    
+    @Override
+    public void collectVariables(TIntHashSet reads, TIntHashSet writes) {
+       reads.add(lComponentType);
+       reads.add(lConfiguration);
+       reads.add(configurationRoot);
+    }
+
+}