]> gerrit.simantics Code Review - simantics/interop.git/blobdiff - org.simantics.xml.sax/src/org/simantics/xml/sax/ExporterGenerator.java
XML Elements are exported in the original order (if order is stored during import)
[simantics/interop.git] / org.simantics.xml.sax / src / org / simantics / xml / sax / ExporterGenerator.java
index 1d97259528bef8569311d85c27508f3e9b0f912a..c767311b66be7a42a951e00d28fff9d4fee0c7aa 100644 (file)
@@ -11,11 +11,11 @@ import java.util.Map;
 import javax.xml.namespace.QName;\r
 \r
 import org.simantics.utils.datastructures.BijectionMap;\r
+import org.simantics.xml.sax.SchemaConversionBase.RefType;\r
 import org.simantics.xml.sax.configuration.AttributeComposition;\r
 import org.simantics.xml.sax.configuration.Configuration;\r
 import org.simantics.xml.sax.configuration.IDProvider;\r
 import org.simantics.xml.sax.configuration.IDReference;\r
-import org.simantics.xml.sax.configuration.Rename;\r
 import org.simantics.xml.sax.configuration.UnrecognizedChildElement;\r
 import org.w3._2001.xmlschema.Annotated;\r
 import org.w3._2001.xmlschema.Attribute;\r
@@ -213,18 +213,16 @@ public class ExporterGenerator extends JavaGenerator{
                \r
                fw.writer.println("   }");\r
                \r
-//             fw.writer.println("   @Override");\r
-//             fw.writer.println("   public boolean connectChild(WriteGraph graph, ParserElement element, ParserElement child) throws DatabaseException{");\r
-//             fw.writer.println("      "+getOntologyImport());\r
-//             \r
-//             if (stringWriter.getBuffer().length() > 0) {\r
-//                     fw.writer.write(stringWriter.toString());\r
-//             }\r
-//             \r
-//             \r
-//             fw.writer.println("      return false;");\r
-//             fw.writer.println("   }");\r
-//             fw.writer.println();\r
+               fw.writer.println("   @Override");\r
+               fw.writer.println("   public void children(ReadGraph graph, WriterElement instance, java.util.Set<org.simantics.db.Resource> result) throws XMLStreamException, DatabaseException {");\r
+               fw.writer.println("      "+getOntologyImport());\r
+               \r
+               if (stringWriter.getBuffer().length() > 0) {\r
+                       fw.writer.write(stringWriter.toString());\r
+               }\r
+               \r
+               fw.writer.println("   }");\r
+               fw.writer.println();\r
                \r
                if (stringWriter2.getBuffer().length() > 0) {\r
                        fw.writer.write(stringWriter2.toString());\r
@@ -264,37 +262,122 @@ public class ExporterGenerator extends JavaGenerator{
        \r
        \r
        @Override\r
-       protected void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement element,  boolean reference, String ref, QName refType) {\r
+       //protected void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement element,  boolean reference, String ref, QName refType) {\r
+       protected void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement element, String refName, RefType referenceType) {\r
                FileWriter fw = getWriter(parent);\r
-               String binding = getBindingFromPrimitiveType(refType);\r
-               if (binding == null) {\r
-                       SchemaObject refElement = elementName.get(refType.getLocalPart());\r
-                       SchemaObject refComplexType = complexTypeName.get(refType.getLocalPart());\r
-\r
-                       String className = null;\r
-                       String refClassName = null;\r
-                       if (refElement != null)\r
-                               className = getName(refElement);\r
-                       else\r
-                               className = getName(refComplexType);\r
+               if (referenceType != RefType.Element) {\r
+                       QName refType;\r
+                       if (referenceType == RefType.Type) {\r
+                               refType = element.getElement().getType();\r
+                               if (refName == null)\r
+                                       refName = element.getElement().getName();\r
+                       } else {\r
+                               refType = element.getElement().getRef();\r
+                               if (refName == null)\r
+                                       refName = refType.getLocalPart();\r
+                       }\r
                        \r
-                       if (refComplexType != null) {\r
-                               refClassName = getName(refComplexType);\r
+                       String binding = getBindingFromPrimitiveType(refType);\r
+                       if (binding == null) {\r
+                               SchemaObject refElement = elementName.get(refType.getLocalPart());\r
+                               SchemaObject refComplexType = complexTypeName.get(refType.getLocalPart());\r
+       \r
+                               String className = null;\r
+                               String refClassName = null;\r
+                               if (refElement != null)\r
+                                       className = getName(refElement);\r
+                               else\r
+                                       className = getName(refComplexType);\r
+                               \r
+                               if (refComplexType != null) {\r
+                                       refClassName = getName(refComplexType);\r
+                               } else {\r
+                                       refClassName = getName(refElement);\r
+                               }\r
+                               \r
+                               if (referenceType != RefType.Reference)\r
+                               fw.writer.println("        addTypeWriter("+ontShort+ className +", "+className+".class);");\r
+                               else\r
+                               fw.writer.println("        addWriter("+className+".class);");\r
+                               if (!className.equals(refClassName))\r
+                               fw.writer.println("        addWriter("+refClassName+".class);");\r
+                               \r
+       //                      fw.delayedWriter.println("         if (child.getElementParser() instanceof "+refClassName+"){");\r
+       //                      fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+ref + ", child.getData());");\r
+                               if (useElementList(parent, indicator,element, referenceType == RefType.Reference, refName, refType)) {\r
+               \r
+                               // element type specific list\r
+                               fw.delayedWriter.println("            {");\r
+                               fw.delayedWriter.println("               org.simantics.db.Resource list = graph.getPossibleObject(instance.getResource(),"+ontShort+getName(parent)+"_has"+refName + "List);");\r
+                               fw.delayedWriter.println("               if (list != null) {");\r
+                               fw.delayedWriter.println("                  java.util.List<org.simantics.db.Resource> l = org.simantics.db.common.utils.ListUtils.toList(graph, list);");\r
+                               fw.delayedWriter.println("                  result.addAll(l);");\r
+                               fw.delayedWriter.println("               } else {");\r
+                               fw.delayedWriter.println("                  result.addAll(graph.getObjects(instance.getResource(), "+ontShort+getName(parent)+"_has"+refName + "));");\r
+                               fw.delayedWriter.println("               }");\r
+                               fw.delayedWriter.println("            }");\r
+                               } else {\r
+                               fw.delayedWriter.println("         result.addAll(graph.getObjects(instance.getResource(), "+ontShort+getName(parent)+"_has"+refName + "));");\r
+                               }\r
+       //                      if (useOriginalList(parent, indicator,element, reference, ref, refType)) {\r
+       //                      // generic list\r
+       //                      fw.delayedWriter.println("            {");\r
+       //                      fw.delayedWriter.println("               XMLResource XML = XMLResource.getInstance(graph);");\r
+       //                      fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(), XML.hasOriginalElementList);");\r
+       //                      fw.delayedWriter.println("               if (list == null) {");\r
+       //                      fw.delayedWriter.println("                  list = org.simantics.db.common.utils.ListUtils.create(graph, java.util.Collections.singletonList(child.getData()));");\r
+       //                      fw.delayedWriter.println("                  graph.claim(element.getData(), XML.hasOriginalElementList,list);");\r
+       //                      fw.delayedWriter.println("               } else {");\r
+       //                      fw.delayedWriter.println("                  org.simantics.db.common.utils.ListUtils.insertBack(graph, list, java.util.Collections.singletonList(child.getData()));");\r
+       //                      fw.delayedWriter.println("               }");\r
+       //                      fw.delayedWriter.println("            }");\r
+       //                      }\r
+                               \r
+       //                      fw.delayedWriter.println("            return true;");\r
+       //                      fw.delayedWriter.println("         }");\r
                        } else {\r
-                               refClassName = getName(refElement);\r
+                               SchemaObject refElement = elementName.get(refType.getLocalPart());\r
+                               //writer.println(commentTag+ontShort+"."+parent+".has"+ref + " <R " +  ontShort+".hasElement");\r
+                               fw.writer.println("        addRelationWriter("+ ontShort +getName(parent) + "_has"+refName+", "+getName(parent) +"_" +refName+".class);");\r
+                               \r
+                               fw.delayedWriter2.println("   public static class " + getName(parent) +"_" +refName+" extends org.simantics.xml.sax.base.ValueElementWriter {");\r
+                               fw.delayedWriter2.println("      public "+ getName(parent) +"_" +refName +"(){");\r
+                               //fw.delayedWriter2.println("           super(\""+ref+"\"," +this.ontologyClassName+".URIs."+getName(parent) + "_has"+ref+", "+binding+");");\r
+                               fw.delayedWriter2.println("           super(\""+refName+"\",null, "+binding+");");\r
+                               fw.delayedWriter2.println("       }");\r
+                               fw.delayedWriter2.println("   }");\r
                        }\r
+               } else {\r
+                       Element attrs= element.getElement();\r
+                       SchemaObject obj = getWithObj(parent, attrs);\r
                        \r
-                       if (!reference)\r
-                       fw.writer.println("        addTypeWriter("+ontShort+ className +", "+className+".class);");\r
-                       else\r
-                       fw.writer.println("        addWriter("+className+".class);");\r
-                       if (!className.equals(refClassName))\r
-                       fw.writer.println("        addWriter("+refClassName+".class);");\r
+                       String className = getName(obj);\r
+                       if (refName == null) {\r
+                               refName = obj.getName();//attrs.getName();\r
+                       }\r
+\r
+                       //if (!reference)\r
+                       fw.writer.println("        addTypeWriter("+ ontShort+getName(obj) +", "+className+".class);");\r
+//                     else\r
+//                     fw.writer.println("        addWriter("+className+".class);");\r
                        \r
-//                     fw.delayedWriter.println("         if (child.getElementParser() instanceof "+refClassName+"){");\r
+//                     fw.delayedWriter.println("         if (child.getElementParser() instanceof "+className+"){");\r
 //                     fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+ref + ", child.getData());");\r
-//                     if (useElementList(parent, indicator,element, reference, ref, refType)) {\r
-//     \r
+                       if (useElementList(parent, indicator,element, false, refName, new QName(obj.getName()))) {\r
+                               \r
+                       // element type specific list\r
+                       fw.delayedWriter.println("            {");\r
+                       fw.delayedWriter.println("               org.simantics.db.Resource list = graph.getPossibleObject(instance.getResource(),"+ontShort+getName(parent)+"_has"+refName + "List);");\r
+                       fw.delayedWriter.println("               if (list != null) {");\r
+                       fw.delayedWriter.println("                  java.util.List<org.simantics.db.Resource> l = org.simantics.db.common.utils.ListUtils.toList(graph, list);");\r
+                       fw.delayedWriter.println("                  result.addAll(l);");\r
+                       fw.delayedWriter.println("               } else {");\r
+                       fw.delayedWriter.println("                  result.addAll(graph.getObjects(instance.getResource(), "+ontShort+getName(parent)+"_has"+refName + "));");\r
+                       fw.delayedWriter.println("               }");\r
+                       fw.delayedWriter.println("            }");\r
+                       } else {\r
+                       fw.delayedWriter.println("         result.addAll(graph.getObjects(instance.getResource(), "+ontShort+getName(parent)+"_has"+refName + "));");\r
+                       }\r
 //                     // element type specific list\r
 //                     fw.delayedWriter.println("            {");\r
 //                     fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(),"+ontShort+getName(parent)+"_has"+ref + "List);");\r
@@ -306,7 +389,7 @@ public class ExporterGenerator extends JavaGenerator{
 //                     fw.delayedWriter.println("               }");\r
 //                     fw.delayedWriter.println("            }");\r
 //                     }\r
-//                     if (useOriginalList(parent, indicator,element, reference, ref, refType)) {\r
+//                     if (useOriginalList(parent, indicator,element, reference, ref, new QName(obj.getName()))) {\r
 //                     // generic list\r
 //                     fw.delayedWriter.println("            {");\r
 //                     fw.delayedWriter.println("               XMLResource XML = XMLResource.getInstance(graph);");\r
@@ -322,65 +405,10 @@ public class ExporterGenerator extends JavaGenerator{
 //                     \r
 //                     fw.delayedWriter.println("            return true;");\r
 //                     fw.delayedWriter.println("         }");\r
-               } else {\r
-                       SchemaObject refElement = elementName.get(refType.getLocalPart());\r
-                       //writer.println(commentTag+ontShort+"."+parent+".has"+ref + " <R " +  ontShort+".hasElement");\r
-                       fw.writer.println("        addRelationWriter("+ ontShort +getName(parent) + "_has"+ref+", "+getName(parent) +"_" +ref+".class);");\r
-                       \r
-                       fw.delayedWriter2.println("   public static class " + getName(parent) +"_" +ref+" extends org.simantics.xml.sax.base.ValueElementWriter {");\r
-                       fw.delayedWriter2.println("      public "+ getName(parent) +"_" +ref +"(){");\r
-                       //fw.delayedWriter2.println("           super(\""+ref+"\"," +this.ontologyClassName+".URIs."+getName(parent) + "_has"+ref+", "+binding+");");\r
-                       fw.delayedWriter2.println("           super(\""+ref+"\",null, "+binding+");");\r
-                       fw.delayedWriter2.println("       }");\r
-                       fw.delayedWriter2.println("   }");\r
                }\r
        }\r
        \r
-       @Override\r
-       protected void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement element,  boolean reference, String ref, OpenAttrs attrs) {\r
-               FileWriter fw = getWriter(parent);\r
-               SchemaObject obj = getWithObj(parent, attrs);\r
        \r
-               String className = getName(obj);\r
-\r
-               if (!reference)\r
-               fw.writer.println("        addTypeWriter("+ ontShort+getName(obj) +", "+className+".class);");\r
-               else\r
-               fw.writer.println("        addWriter("+className+".class);");\r
-               \r
-               fw.delayedWriter.println("         if (child.getElementParser() instanceof "+className+"){");\r
-               fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+ref + ", child.getData());");\r
-//             if (useElementList(parent, indicator,element, reference, ref, new QName(obj.getName()))) {\r
-//\r
-//             // element type specific list\r
-//             fw.delayedWriter.println("            {");\r
-//             fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(),"+ontShort+getName(parent)+"_has"+ref + "List);");\r
-//             fw.delayedWriter.println("               if (list == null) {");\r
-//             fw.delayedWriter.println("                  list = org.simantics.db.common.utils.ListUtils.create(graph, java.util.Collections.singletonList(child.getData()));");\r
-//             fw.delayedWriter.println("                  graph.claim(element.getData(),"+ontShort+getName(parent)+"_has"+ref + "List,list);");\r
-//             fw.delayedWriter.println("               } else {");\r
-//             fw.delayedWriter.println("                  org.simantics.db.common.utils.ListUtils.insertBack(graph, list, java.util.Collections.singletonList(child.getData()));");\r
-//             fw.delayedWriter.println("               }");\r
-//             fw.delayedWriter.println("            }");\r
-//             }\r
-//             if (useOriginalList(parent, indicator,element, reference, ref, new QName(obj.getName()))) {\r
-//             // generic list\r
-//             fw.delayedWriter.println("            {");\r
-//             fw.delayedWriter.println("               XMLResource XML = XMLResource.getInstance(graph);");\r
-//             fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(), XML.hasOriginalElementList);");\r
-//             fw.delayedWriter.println("               if (list == null) {");\r
-//             fw.delayedWriter.println("                  list = org.simantics.db.common.utils.ListUtils.create(graph, java.util.Collections.singletonList(child.getData()));");\r
-//             fw.delayedWriter.println("                  graph.claim(element.getData(), XML.hasOriginalElementList,list);");\r
-//             fw.delayedWriter.println("               } else {");\r
-//             fw.delayedWriter.println("                  org.simantics.db.common.utils.ListUtils.insertBack(graph, list, java.util.Collections.singletonList(child.getData()));");\r
-//             fw.delayedWriter.println("               }");\r
-//             fw.delayedWriter.println("            }");\r
-//             }\r
-//             \r
-//             fw.delayedWriter.println("            return true;");\r
-//             fw.delayedWriter.println("         }");\r
-               \r
-       }\r
        \r
        @Override\r
        protected void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement any) {               \r
@@ -396,10 +424,7 @@ public class ExporterGenerator extends JavaGenerator{
                fw.delayedWriter2.println("      return null;");\r
                fw.delayedWriter2.println("   }");\r
        }\r
-       \r
-       \r
-       \r
-       \r
+\r
        @Override       \r
        protected void handle(SchemaObject parent, Attribute attribute) {\r
                String name = attribute.getName();\r
@@ -669,6 +694,7 @@ public class ExporterGenerator extends JavaGenerator{
                fw.writer.println("        }");\r
                fw.writer.println("   }");\r
                \r
+               \r
 //             fw.writer.println("   @Override");\r
 //             fw.writer.println("   public void configure(WriteGraph graph, Deque<ParserElement> parents, ParserElement element) throws DatabaseException {");\r
 //             if (inhertiance.type == InheritanceType.ComplexType) {\r
@@ -720,21 +746,21 @@ public class ExporterGenerator extends JavaGenerator{
                \r
                fw.writer.println("   }");\r
                \r
-//             fw.writer.println("   @Override");\r
-//             fw.writer.println("   public boolean connectChild(WriteGraph graph, ParserElement element, ParserElement child) throws DatabaseException{");\r
-//             fw.writer.println("      "+getOntologyImport());\r
-//             \r
-//             if (stringWriter.getBuffer().length() > 0) {\r
-//                     fw.writer.write(stringWriter.toString());\r
-//             }\r
-//             if (inhertiance.type == InheritanceType.ComplexType) {\r
-//             fw.writer.println("      return super.connectChild(graph,element,child);");     \r
-//             } else {\r
-//             fw.writer.println("      return false;");\r
-//             }\r
-//             fw.writer.println("   }");\r
-//             fw.writer.println();\r
+               fw.writer.println("   @Override");\r
+               fw.writer.println("   public void children(ReadGraph graph, WriterElement instance, java.util.Set<org.simantics.db.Resource> result) throws XMLStreamException, DatabaseException {");\r
+               fw.writer.println("      "+getOntologyImport());\r
                \r
+               if (stringWriter.getBuffer().length() > 0) {\r
+                       fw.writer.write(stringWriter.toString());\r
+               }\r
+               \r
+               if (inhertiance.type == InheritanceType.ComplexType) {\r
+               fw.writer.println("      super.children(graph,instance,result);");\r
+               }\r
+               \r
+               fw.writer.println("   }");\r
+               fw.writer.println();\r
+                               \r
                if (stringWriter2.getBuffer().length() > 0) {\r
                        fw.writer.write(stringWriter2.toString());\r
                }\r