]> gerrit.simantics Code Review - simantics/interop.git/blobdiff - org.simantics.interop.xmlio/src/org/simantics/interop/xmlio/LoadXML.java
refs #3842
[simantics/interop.git] / org.simantics.interop.xmlio / src / org / simantics / interop / xmlio / LoadXML.java
index 3a6606b98d8e48a386262727bf003a09d4acee49..c79ace686e8e39bb5ee2a639e52e16f451d6478a 100644 (file)
@@ -6,14 +6,13 @@ import java.io.FileReader;
 import java.io.Reader;\r
 import java.io.Serializable;\r
 import java.util.ArrayList;\r
-import java.util.HashMap;\r
 import java.util.List;\r
-import java.util.Map;\r
 import java.util.Stack;\r
 \r
 import javax.xml.parsers.SAXParser;\r
 import javax.xml.parsers.SAXParserFactory;\r
 \r
+import org.cojen.util.IntHashMap;\r
 import org.simantics.db.ReadGraph;\r
 import org.simantics.db.Resource;\r
 import org.simantics.db.Session;\r
@@ -21,6 +20,7 @@ import org.simantics.db.WriteGraph;
 import org.simantics.db.common.request.DelayedWriteRequest;\r
 import org.simantics.db.common.request.WriteRequest;\r
 import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.db.layer0.util.Layer0Utils;\r
 import org.simantics.db.layer0.util.SessionGarbageCollection;\r
 import org.simantics.layer0.Layer0;\r
 import org.xml.sax.Attributes;\r
@@ -38,7 +38,9 @@ public class LoadXML {
        \r
        private File file;\r
        \r
-       private Map<Integer,Resource> idMap = new HashMap<Integer, Resource>();\r
+       \r
+       //private Map<Integer,Resource> idMap = new HashMap<Integer, Resource>();\r
+       private IntHashMap<Resource> idMap = new IntHashMap<Resource>();\r
        \r
        //private Map<String,Resource> uriMap = new HashMap<String, Resource>();\r
        \r
@@ -49,6 +51,8 @@ public class LoadXML {
        private int resources;\r
        private int statements;\r
        \r
+       private static final boolean USE_DELAYED = true;\r
+       \r
        public LoadXML(Session session, File file) {\r
                this.session = session;\r
                this.file = file;\r
@@ -59,33 +63,68 @@ public class LoadXML {
                this.rule = rule;\r
        }\r
        \r
-       public void load(final Resource subj, final Resource pred) throws Exception {\r
+       public void load(Resource subj, Resource pred) throws Exception {\r
                resources = 0;\r
                statements = 0;\r
-               // TODO : switch to Delayed if possible\r
-               //        Delayed Write  Graph in 1.6 does not seem to support converting virtual Resources to real Resources!\r
                \r
-               session.syncRequest(new DelayedWriteRequest() {\r
-               //session.syncRequest(new WriteRequest() {\r
-                       \r
-                       @Override\r
-                       public void perform(WriteGraph graph) throws DatabaseException {\r
-                               LoadXML.this.graph = graph;\r
-                               l0 = Layer0.getInstance(graph);\r
-                               try {\r
-                                       XMLParser parser = new XMLParser();\r
-                                       parser.parse(file.getAbsolutePath());\r
-                               } catch (Exception e) {\r
-                                       throw new DatabaseException(e);\r
-                               } finally {\r
-                                       resultRoot = idMap.get(0);\r
-                                       graph.claim(subj, pred, resultRoot);\r
-                                       idMap.clear();\r
-                               }\r
-                       }\r
-               });\r
+               if (USE_DELAYED) {\r
+                       session.syncRequest(new ImportDelayedRequest(subj,pred));       \r
+               } else {\r
+                       session.syncRequest(new ImportRequest(subj,pred));      \r
+               }\r
+               //session.syncRequest(new DelayedWriteRequest() {\r
+               \r
+               \r
+               System.out.println("Import done.");\r
+       }\r
+       \r
+       private class ImportRequest extends WriteRequest {\r
+               Resource subj;Resource pred;\r
+               \r
+               \r
+               public ImportRequest(Resource subj, Resource pred) {\r
+                       super();\r
+                       this.subj = subj;\r
+                       this.pred = pred;\r
+               }\r
+\r
+               @Override\r
+               public void perform(WriteGraph graph) throws DatabaseException {\r
+                       doImport(graph, subj, pred);\r
+               }\r
+       }\r
+       \r
+       private class ImportDelayedRequest extends DelayedWriteRequest {\r
+               Resource subj;Resource pred;\r
                \r
-               System.out.println("Imported " + statements + " Statements, " + resources + " Resources.");\r
+               \r
+               public ImportDelayedRequest(Resource subj, Resource pred) {\r
+                       super();\r
+                       this.subj = subj;\r
+                       this.pred = pred;\r
+               }\r
+\r
+               @Override\r
+               public void perform(WriteGraph graph) throws DatabaseException {\r
+                       doImport(graph, subj, pred);\r
+               }\r
+       }\r
+       \r
+       private void doImport(WriteGraph graph, Resource subj, Resource pred) throws DatabaseException {\r
+               LoadXML.this.graph = graph;\r
+               l0 = Layer0.getInstance(graph);\r
+               Layer0Utils.setDependenciesIndexingDisabled(graph, true);\r
+               try {\r
+                       XMLParser parser = new XMLParser();\r
+                       parser.parse(file.getAbsolutePath());\r
+                       System.out.println("Imported " + statements + " Statements, " + resources + " Resources.");\r
+               } catch (Exception e) {\r
+                       throw new DatabaseException(e);\r
+               } finally {\r
+                       resultRoot = idMap.get(0);\r
+                       graph.claim(subj, pred, resultRoot);\r
+                       idMap.clear();\r
+               }\r
        }\r
        \r
        \r
@@ -242,6 +281,11 @@ public class LoadXML {
                                        System.out.println("Imported " + statements + " Statements, " + resources + " Resources..");\r
                                        //SessionGarbageCollection.gc(graph, 0, -1);\r
                                }\r
+                               if (!USE_DELAYED && statements % 100000 == 0) {\r
+                                       SessionGarbageCollection.gc(graph, 0, -1);\r
+                                       System.gc();\r
+                               }\r
+                               \r
                                return;\r
                        }\r
                        \r