X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=org.simantics.plant3d%2Fsrc%2Forg%2Fsimantics%2Fplant3d%2Fscl%2FSCLUtil.java;h=cdbf6626b197548c624f65e57b6f2d7b58cbdff1;hb=f3f97890617bc359b043b903f5d9e75c6bdc71bd;hp=a27e76f2c83342dc2edba05f562d0047264b90e3;hpb=b7de6cac8cc67d2e9355f700ea813c7ed0d75bd4;p=simantics%2F3d.git diff --git a/org.simantics.plant3d/src/org/simantics/plant3d/scl/SCLUtil.java b/org.simantics.plant3d/src/org/simantics/plant3d/scl/SCLUtil.java index a27e76f2..cdbf6626 100644 --- a/org.simantics.plant3d/src/org/simantics/plant3d/scl/SCLUtil.java +++ b/org.simantics.plant3d/src/org/simantics/plant3d/scl/SCLUtil.java @@ -1,6 +1,5 @@ package org.simantics.plant3d.scl; - import org.simantics.Simantics; import org.simantics.db.ReadGraph; import org.simantics.db.Resource; @@ -9,6 +8,7 @@ import org.simantics.db.request.Read; import org.simantics.objmap.graph.IMapping; import org.simantics.objmap.graph.Mappings; import org.simantics.objmap.graph.schema.IMappingSchema; +import org.simantics.plant3d.ontology.Plant3D; import org.simantics.plant3d.scenegraph.P3DRootNode; import org.simantics.plant3d.scenegraph.SchemaBuilder; import org.simantics.plant3d.scenegraph.controlpoint.ControlPointFactory; @@ -17,21 +17,47 @@ import org.simantics.plant3d.utils.ComponentUtils; import org.simantics.plant3d.utils.P3DUtil; public class SCLUtil { + + public static interface SchemaProvider { + IMappingSchema get(ReadGraph graph) throws DatabaseException; + } + + public static interface NodeMapProvider { + P3DScriptNodeMap get(IMapping mapping, P3DRootNode rootNode); + } public static P3DScriptNodeMap load(final Resource root) throws DatabaseException { + preload(Plant3D.URIs.Builtin); + + SchemaProvider schemaProvider = g -> SchemaBuilder.getSchema(g); + NodeMapProvider mapProvider = (mapping, rootNode) -> new P3DScriptNodeMap(Simantics.getSession(), mapping, rootNode); + return load(root, schemaProvider, mapProvider); + } + + public static P3DRootNode loadReadOnly(final Resource root) throws DatabaseException { + preload(Plant3D.URIs.Builtin); + + SchemaProvider schemaProvider = g -> SchemaBuilder.getSchema(g); + return loadReadOnly(root, schemaProvider); + } + + public static void preload(String symbolSet) throws DatabaseException { try { - ControlPointFactory.preloadCache(); + ControlPointFactory.preloadCache(symbolSet); ComponentUtils.preloadCache(); } catch (Exception e) { throw new DatabaseException(e); } - return Simantics.getSession().syncRequest(new Read() { + } + + public static NodeMap load(final Resource root, SchemaProvider schemaProvider, NodeMapProvider mapProvider) throws DatabaseException { + return Simantics.getSession().syncRequest(new Read() { @Override - public P3DScriptNodeMap perform(ReadGraph graph) throws DatabaseException { + public NodeMap perform(ReadGraph graph) throws DatabaseException { PipingRules.setEnabled(false); - IMappingSchema schema = SchemaBuilder.getSchema(graph); + IMappingSchema schema = schemaProvider.get(graph); IMapping mapping = Mappings.createWithListening(schema); - P3DRootNode rootNode = (P3DRootNode)mapping.map(graph, root); + P3DRootNode rootNode = (P3DRootNode) mapping.map(graph, root); try { P3DUtil.finalizeDBLoad(rootNode); // FIXME: Something needs to be done here... @@ -39,28 +65,24 @@ public class SCLUtil { } catch (Exception e) { throw new DatabaseException(e); } - P3DScriptNodeMap nodeMap = new P3DScriptNodeMap(Simantics.getSession(), mapping, rootNode); - return nodeMap; + @SuppressWarnings("unchecked") + NodeMap nodeMap = (NodeMap) mapProvider.get(mapping, rootNode); + return nodeMap; } }); - } - - public static P3DRootNode loadReadOnly(final Resource root) throws DatabaseException { - try { - ControlPointFactory.preloadCache(); - ComponentUtils.preloadCache(); - } catch (Exception e) { - throw new DatabaseException(e); - } - return Simantics.getSession().syncRequest(new Read() { + + public static Root loadReadOnly(final Resource root, SchemaProvider schemaProvider) + throws DatabaseException { + return Simantics.getSession().syncRequest(new Read() { @Override - public P3DRootNode perform(ReadGraph graph) throws DatabaseException { + public Root perform(ReadGraph graph) throws DatabaseException { PipingRules.setEnabled(false); - IMappingSchema schema = SchemaBuilder.getSchema(graph); + IMappingSchema schema = schemaProvider.get(graph); IMapping mapping = Mappings.createWithoutListening(schema); - P3DRootNode rootNode = (P3DRootNode)mapping.map(graph, root); + @SuppressWarnings("unchecked") + Root rootNode = (Root) mapping.map(graph, root); try { P3DUtil.finalizeDBLoad(rootNode); P3DUtil.finalizeDBLoad2(rootNode); @@ -68,7 +90,6 @@ public class SCLUtil { throw new DatabaseException(e); } return rootNode; - } }); }