]> gerrit.simantics Code Review - simantics/interop.git/blobdiff - org.simantics.xml.sax/src/org/simantics/xml/sax/ImporterGenerator.java
Export XML Namespaces
[simantics/interop.git] / org.simantics.xml.sax / src / org / simantics / xml / sax / ImporterGenerator.java
index f55f9cfeb0ad7a5816cc584f84cf5cba32216ff8..80359ba895c6ea25269785a1907c6f96996141bd 100644 (file)
@@ -11,6 +11,9 @@ import java.util.Map;
 import javax.xml.namespace.QName;\r
 \r
 import org.simantics.utils.datastructures.BijectionMap;\r
+import org.simantics.xml.sax.SchemaConversionBase.InheritanceType;\r
+import org.simantics.xml.sax.SchemaConversionBase.RefType;\r
+import org.simantics.xml.sax.SchemaObject.ObjectType;\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
@@ -114,7 +117,9 @@ public class ImporterGenerator extends JavaGenerator{
                \r
                String name = getName(complexTypeObj);\r
                \r
-//             if (topLevelComplexType.getName().equals("Reference"))\r
+               //if (topLevelComplexType.getName().equals("LocalizedText"))\r
+               //if (topLevelComplexType.getName().equals("Reference"))\r
+//             if (topLevelComplexType.getName().equals("NodeIdAlias"))\r
 //                     System.out.println();\r
                \r
                String className = name;//"_"+name;\r
@@ -126,19 +131,8 @@ public class ImporterGenerator extends JavaGenerator{
                        throw new RuntimeException(e);\r
                }\r
                writers.put(complexTypeObj, fw);\r
-\r
-               String baseClass = getBaseClass();\r
-               \r
-               boolean inherited = false;\r
                \r
-               QName type = getComplexTypeBase(topLevelComplexType);\r
-               if (type != null && !type.getNamespaceURI().equals("http://www.w3.org/2001/XMLSchema")) {\r
-                       SchemaObject obj = complexTypeName.get(type.getLocalPart());\r
-                       if (obj != null) {\r
-                               baseClass = getName(obj);\r
-                               inherited = true;\r
-                       }\r
-               }\r
+               Inheritance inheritance = getInheritance(complexTypeObj);\r
                \r
                provider = getIDProvider(topLevelComplexType);\r
                List<IDReference> references = getIDReferences(topLevelComplexType);\r
@@ -151,7 +145,7 @@ public class ImporterGenerator extends JavaGenerator{
                        intrerfaces.add("org.simantics.xml.sax.base.UnrecognizedElementParser");\r
                \r
                createClassHeader(fw.writer, false);\r
-               writeClass(fw.writer,false, null, className, baseClass, intrerfaces);\r
+               writeClass(fw.writer,false, null, className, inheritance.baseClass, intrerfaces);\r
                        \r
                writeIDProvider(fw.writer);\r
        \r
@@ -192,9 +186,11 @@ public class ImporterGenerator extends JavaGenerator{
                if (stringWriter.getBuffer().length() > 0) {\r
                        fw.writer.write(stringWriter.toString());\r
                }\r
-               \r
-               \r
+               if (inheritance.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
                \r
@@ -211,7 +207,7 @@ public class ImporterGenerator extends JavaGenerator{
                \r
                fw.writer.println("   @Override");\r
                fw.writer.println("   public void configure(WriteGraph graph, Deque<ParserElement> parents, ParserElement element) throws DatabaseException {");\r
-               if (inherited) {\r
+               if (inheritance.type == InheritanceType.ComplexType) {\r
                fw.writer.println("             super.configure(graph,parents,element);");\r
                }\r
                fw.writer.println("        "+getOntologyImport());\r
@@ -221,6 +217,14 @@ public class ImporterGenerator extends JavaGenerator{
                \r
                fw.writer.println("   }");\r
                \r
+               if (inheritance.type == InheritanceType.AtomicType) {\r
+               fw.writer.println();\r
+               fw.writer.println("   @Override");\r
+               fw.writer.println("   public void configure(WriteGraph graph, ParserElement element, java.lang.String string) throws DatabaseException {");\r
+               fw.writer.println("      graph.claimValue(element.getData(), "+getValueGetter(inheritance.atomicType,"string")+", "+inheritance.atomicType.binding+");");\r
+               fw.writer.println("   }");\r
+               }\r
+               \r
                writeIDReferences(fw.writer,name, references);\r
                writeUnknownChild(fw.writer,name,unknownChildElement);\r
                \r
@@ -234,133 +238,104 @@ public class ImporterGenerator 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, String refName, RefType referenceType) {\r
+       protected void createReferenceIndicator(SchemaObject parent, RefType referenceType, String refName, String objectName, String primaryClassName, String secondaryClassName, boolean useElementList, boolean useOriginalList) {\r
                FileWriter fw = getWriter(parent);\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
-                       String binding = getBindingFromPrimitiveType(refType);\r
-                       if (binding == null) {\r
-                               SchemaObject refElement = elementName.get(refType.getLocalPart());\r
-                               SchemaObject refComplexType = complexTypeName.get(refType.getLocalPart());\r
+               if (referenceType == RefType.Type) {\r
+               // create internal class for handling the element and child attachment\r
+               secondaryClassName = getName(parent) +"_" +objectName;\r
+               fw.writer.println("        addParser(\""+ objectName +"\", "+secondaryClassName+".class);");\r
+               fw.delayedWriter2.println("   public static class " + secondaryClassName +" extends " + primaryClassName +"{");\r
+               fw.delayedWriter2.println("      public "+ secondaryClassName +"(){");\r
+               fw.delayedWriter2.println("      }");\r
+               fw.delayedWriter2.println("   }");\r
+               } else { // referenceType == RefType.Reference\r
+               fw.writer.println("        addParser("+primaryClassName+".class);");\r
+               if (!primaryClassName.equals(secondaryClassName))\r
+               fw.writer.println("        addParser("+secondaryClassName+".class);");\r
+               }\r
+               \r
+               fw.delayedWriter.println("         if (child.getElementParser() instanceof "+secondaryClassName+"){");\r
+               fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+refName + ", child.getData());");\r
+               if (useElementList) {\r
+\r
+               // element type specific list\r
+               fw.delayedWriter.println("            {");\r
+               fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(),"+ontShort+getName(parent)+"_has"+refName + "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"+refName + "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) {\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
-                               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("        addParser(\""+ refName +"\", "+className+".class);");\r
-                               else\r
-                               fw.writer.println("        addParser("+className+".class);");\r
-                               if (!className.equals(refClassName))\r
-                               fw.writer.println("        addParser("+refClassName+".class);");\r
-                               \r
-                               fw.delayedWriter.println("         if (child.getElementParser() instanceof "+refClassName+"){");\r
-                               fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+refName + ", 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("               Resource list = graph.getPossibleObject(element.getData(),"+ontShort+getName(parent)+"_has"+refName + "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"+refName + "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, referenceType == RefType.Reference, refName, 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
-                               //writer.println(commentTag+ontShort+"."+parent+".has"+ref + " <R " +  ontShort+".hasElement");\r
-                               fw.writer.println("        addParser(\""+ refName +"\", "+getName(parent) +"_" +refName+".class);");\r
-                               \r
-                               fw.delayedWriter2.println("   public static class " + getName(parent) +"_" +refName+" extends org.simantics.xml.sax.base.ValueElementParser {");\r
-                               fw.delayedWriter2.println("      public "+ getName(parent) +"_" +refName +"(){");\r
-                               fw.delayedWriter2.println("           super(\""+refName+"\"," +this.ontologyClassName+".URIs."+getName(parent) + "_has"+refName+", "+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
-                       String className = getName(obj);\r
-                       if (refName == null)\r
-                               refName = attrs.getName();\r
-                       \r
-                       \r
-                       //if (!reference)\r
-                       fw.writer.println("        addParser(\""+ refName +"\", "+className+".class);");\r
-//                     else\r
-//                     fw.writer.println("        addParser("+className+".class);");\r
-                       \r
-                       fw.delayedWriter.println("         if (child.getElementParser() instanceof "+className+"){");\r
-                       fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+refName + ", child.getData());");\r
-                       if (useElementList(parent, indicator,element, false, refName, new QName(obj.getName()))) {\r
+       protected void createPrimitiveIndicator(SchemaObject parent, String refName, String binding) {\r
+               FileWriter fw = getWriter(parent);\r
+               fw.writer.println("        addParser(\""+ refName +"\", "+getName(parent) +"_" +refName+".class);");\r
+               \r
+               fw.delayedWriter2.println("   public static class " + getName(parent) +"_" +refName+" extends org.simantics.xml.sax.base.ValueElementParser {");\r
+               fw.delayedWriter2.println("      public "+ getName(parent) +"_" +refName +"(){");\r
+               fw.delayedWriter2.println("           super(\""+refName+"\"," +this.ontologyClassName+".URIs."+getName(parent) + "_has"+refName+", "+binding+");");\r
+               fw.delayedWriter2.println("       }");\r
+               fw.delayedWriter2.println("   }");\r
+       }\r
+       \r
+       protected void createElementIndicator(SchemaObject parent, boolean useElementList, String refName, String className, boolean useOriginalList) {\r
+               FileWriter fw = getWriter(parent);\r
+               //if (!reference)\r
+               fw.writer.println("        addParser(\""+ refName +"\", "+className+".class);");\r
+//             else\r
+//             fw.writer.println("        addParser("+className+".class);");\r
+               \r
+               fw.delayedWriter.println("         if (child.getElementParser() instanceof "+className+"){");\r
+               fw.delayedWriter.println("            graph.claim(element.getData(), "+ontShort+getName(parent)+"_has"+refName + ", child.getData());");\r
+               if (useElementList) {\r
 \r
-                       // element type specific list\r
-                       fw.delayedWriter.println("            {");\r
-                       fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(),"+ontShort+getName(parent)+"_has"+refName + "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"+refName + "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, false, refName, 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
+               // element type specific list\r
+               fw.delayedWriter.println("            {");\r
+               fw.delayedWriter.println("               Resource list = graph.getPossibleObject(element.getData(),"+ontShort+getName(parent)+"_has"+refName + "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"+refName + "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) {\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
        @Override\r
@@ -584,7 +559,7 @@ public class ImporterGenerator extends JavaGenerator{
                writers.put(elementObj, fw);\r
                boolean isList = false;\r
                \r
-               Inheritance inhertiance = getElementInheritance(elementObj);    \r
+               Inheritance inheritance = getInheritance(elementObj);   \r
                \r
                provider = getIDProvider(element);\r
                List<IDReference> references = getIDReferences(element);\r
@@ -597,7 +572,7 @@ public class ImporterGenerator extends JavaGenerator{
                        intrerfaces.add("org.simantics.xml.sax.base.UnrecognizedElementParser");\r
 \r
                createClassHeader(fw.writer, isList);\r
-               writeClass(fw.writer,false, element.getName(), className, inhertiance.baseClass, intrerfaces);\r
+               writeClass(fw.writer,false, element.getName(), className, inheritance.baseClass, intrerfaces);\r
                writeIDProvider(fw.writer);\r
                fw.writer.println("   @Override");\r
                fw.writer.println("   public Resource create(WriteGraph graph, ParserElement element) throws DatabaseException{");\r
@@ -623,7 +598,7 @@ public class ImporterGenerator extends JavaGenerator{
                \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
+               if (inheritance.type == InheritanceType.ComplexType) {\r
                fw.writer.println("             super.configure(graph,parents,element);");\r
                }\r
                fw.writer.println("        "+getOntologyImport());\r
@@ -637,11 +612,11 @@ public class ImporterGenerator extends JavaGenerator{
                } \r
                fw.writer.println("   }");\r
                \r
-               if (inhertiance.type == InheritanceType.AtomicType) {\r
+               if (inheritance.type == InheritanceType.AtomicType) {\r
                fw.writer.println();\r
                fw.writer.println("   @Override");\r
                fw.writer.println("   public void configure(WriteGraph graph, ParserElement element, java.lang.String string) throws DatabaseException {");\r
-               fw.writer.println("      graph.claimValue(element.getData(), "+getValueGetter(inhertiance.atomicType,"string")+", "+inhertiance.atomicType.binding+");");\r
+               fw.writer.println("      graph.claimValue(element.getData(), "+getValueGetter(inheritance.atomicType,"string")+", "+inheritance.atomicType.binding+");");\r
                fw.writer.println("   }");\r
                }\r
 //             if (simpleType != null) {\r
@@ -674,7 +649,7 @@ public class ImporterGenerator extends JavaGenerator{
                if (stringWriter.getBuffer().length() > 0) {\r
                        fw.writer.write(stringWriter.toString());\r
                }\r
-               if (inhertiance.type == InheritanceType.ComplexType) {\r
+               if (inheritance.type == InheritanceType.ComplexType) {\r
                fw.writer.println("      return super.connectChild(graph,element,child);");     \r
                } else {\r
                fw.writer.println("      return false;");\r
@@ -767,7 +742,7 @@ public class ImporterGenerator extends JavaGenerator{
        }\r
        \r
        @Override\r
-       protected String getBaseClass() {\r
+       protected String getBaseClass(ObjectType type) {\r
                return "org.simantics.xml.sax.base.XMLElementNamedChildParserBase";\r
        }\r
        \r