]> gerrit.simantics Code Review - simantics/interop.git/blobdiff - org.simantics.xml.sax/src/org/simantics/xml/sax/ExporterGenerator.java
Refactoring and preparing the conversion code to handle references between XML schemas.
[simantics/interop.git] / org.simantics.xml.sax / src / org / simantics / xml / sax / ExporterGenerator.java
index 74538ea1c7716cc9fca8d2f94aa94d9159b628f3..d1f67a426c7ff73a138c02dd25517f91f9407574 100644 (file)
@@ -11,10 +11,12 @@ import java.util.Map;
 import javax.xml.namespace.QName;\r
 \r
 import org.simantics.utils.datastructures.BijectionMap;\r
+import org.simantics.xml.sax.SchemaConversionBase.Inheritance;\r
+import org.simantics.xml.sax.SchemaConversionBase.InheritanceType;\r
 import org.simantics.xml.sax.SchemaConversionBase.RefType;\r
+import org.simantics.xml.sax.SchemaConversionBase.TypeEntry;\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
 import org.simantics.xml.sax.configuration.IDReference;\r
 import org.simantics.xml.sax.configuration.UnrecognizedChildElement;\r
@@ -26,31 +28,18 @@ import org.w3._2001.xmlschema.Element;
 import org.w3._2001.xmlschema.LocalComplexType;\r
 import org.w3._2001.xmlschema.LocalSimpleType;\r
 import org.w3._2001.xmlschema.NamedAttributeGroup;\r
+import org.w3._2001.xmlschema.NamedGroup;\r
 import org.w3._2001.xmlschema.Restriction;\r
-import org.w3._2001.xmlschema.Schema;\r
 import org.w3._2001.xmlschema.SimpleType;\r
-import org.w3._2001.xmlschema.TopLevelAttribute;\r
 \r
 public class ExporterGenerator extends JavaGenerator{\r
        \r
-       public ExporterGenerator(Configuration configuration) {\r
-               super(configuration);\r
+       public ExporterGenerator(SchemaConverter converter, SchemaConversionBase base) {\r
+               super(converter, base);\r
        }\r
 \r
-       \r
-       \r
-       public void createParser(Schema schema,String ontologyUri, String className, SchemaConverter converter) throws IOException {\r
-               this.schema = schema;\r
-               this.ontologyClassName = className;\r
-               this.converter = converter;\r
-               \r
-               \r
-               String packageParts[] = className.split("\\.");\r
-               String name = packageParts[packageParts.length-1];\r
-       \r
+       public void createParser() throws IOException {\r
                \r
-               ontShort = name.substring(0, 3).toUpperCase();\r
-               ontShort +=".";\r
                String parserPackagePostfix = "_exp";\r
                String importerClassPostfix = "Exporter";\r
                String parserClassPostfix = "Writer";\r
@@ -60,7 +49,7 @@ public class ExporterGenerator extends JavaGenerator{
                if (!importParserDir.exists())\r
                        importParserDir.mkdirs();\r
                \r
-               handle(schema);\r
+               base.handle(this);\r
                // Create Importer class\r
                File importerFile = new File(converter.getParserDir().getAbsolutePath()+"/"+name+importerClassPostfix+".java");\r
                PrintWriter mainWriter = createFile(importerFile);\r
@@ -119,21 +108,28 @@ public class ExporterGenerator extends JavaGenerator{
                mainWriter.close();\r
        }\r
        \r
-       protected void handle(TopLevelAttribute topLevelAttribute) {\r
-\r
-       }\r
+//     @Override\r
+//     protected void handle(TopLevelAttribute topLevelAttribute) {\r
+//\r
+//     }\r
        \r
        @Override\r
-       protected String getBaseClass(ObjectType type) {\r
+       public String getBaseClass(ObjectType type) {\r
                return "org.simantics.xml.sax.base.XMLElementNamedChildWriterBase";\r
        }\r
        \r
        @Override\r
-       protected void handleSimpleType(SchemaObject parent, SchemaObject simpleTypeObj) {\r
+       public void handleSimpleType(SchemaObject parent, SchemaObject simpleTypeObj) {\r
+       }\r
+       \r
+       @Override\r
+       public void handle(SchemaObject parent, NamedGroup attribute) {\r
+               // TODO Auto-generated method stub\r
+               \r
        }\r
 \r
        @Override\r
-       protected void handleComplexType(SchemaObject complexTypeObj) {\r
+       public void handleComplexType(SchemaObject complexTypeObj) {\r
                ComplexType topLevelComplexType = complexTypeObj.getComplexType();\r
                \r
                String name = getName(complexTypeObj);\r
@@ -162,9 +158,9 @@ public class ExporterGenerator extends JavaGenerator{
 //                             inherited = true;\r
 //                     }\r
 //             }\r
-               Inheritance inheritance = getInheritance(complexTypeObj);\r
+               Inheritance inheritance = base.getInheritance(complexTypeObj);\r
                \r
-               provider = getIDProvider(topLevelComplexType);\r
+               provider = base.getIDProvider(topLevelComplexType);\r
 //             List<IDReference> references = getIDReferences(topLevelComplexType);\r
 //             UnrecognizedChildElement unknownChildElement = getUnknown(topLevelComplexType);\r
 \r
@@ -217,7 +213,7 @@ public class ExporterGenerator extends JavaGenerator{
                fw.writer.println("      super(graph);");\r
                fw.writer.println("      "+getOntologyImport());\r
                \r
-               handleComplexTypeExtension(complexTypeObj);\r
+               base.handleComplexTypeExtension(complexTypeObj);\r
                \r
                fw.writer.println("   }");\r
                \r
@@ -251,8 +247,8 @@ public class ExporterGenerator extends JavaGenerator{
                }\r
                fw.writer.println("        "+getOntologyImport());\r
                fw.writer.println("        for (Statement attribute : attributes) {");\r
-               handleComplexTypeAttributes(complexTypeObj);\r
-               handleExtensionAttributes(complexTypeObj);\r
+               base.handleComplexTypeAttributes(complexTypeObj);\r
+               base.handleExtensionAttributes(complexTypeObj);\r
                fw.writer.println("        }");\r
                fw.writer.println("   }");\r
                \r
@@ -280,10 +276,15 @@ public class ExporterGenerator extends JavaGenerator{
        protected void createReferenceIndicator(SchemaObject parent, RefType referenceType, String refName, String objectName,\r
                        String primaryClassName, String secondaryClassName, boolean useElementList, boolean useOriginalList) {\r
                FileWriter fw = getWriter(parent);\r
+               if ("TextOrField".equals(refName))\r
+                       System.out.println();\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("        addRelationWriter("+ontShort+ getName(parent)+"_has"+refName +", "+secondaryClassName+".class);");\r
+               if (objectName.equals(refName))\r
+               fw.writer.println("      addRelationWriter("+ontShort+ getName(parent)+"_has"+refName +", "+secondaryClassName+".class);");\r
+               else // FIXME : type name may not be correct\r
+               fw.writer.println("      addRelationTypeWriter("+ontShort+ getName(parent)+"_has"+refName +", " +ontShort+primaryClassName +", "+secondaryClassName+".class);");\r
                fw.delayedWriter2.println("   public static class " + secondaryClassName +" extends " + primaryClassName +"{");\r
                fw.delayedWriter2.println("      public "+ secondaryClassName +"(ReadGraph graph){");\r
                fw.delayedWriter2.println("         super(graph);");\r
@@ -304,17 +305,17 @@ public class ExporterGenerator extends JavaGenerator{
                if (useElementList) {\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
+               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
+               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
@@ -376,17 +377,6 @@ public class ExporterGenerator extends JavaGenerator{
                } 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
-//             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
@@ -407,7 +397,7 @@ public class ExporterGenerator extends JavaGenerator{
        }\r
        \r
        @Override\r
-       protected void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement any) {               \r
+       public void handleIndicator(SchemaObject parent, SchemaElement indicator, SchemaElement any) {          \r
                // generates overriding method that allows writing any element\r
                FileWriter fw = getWriter(parent);\r
                fw.delayedWriter2.println("   @Override");\r
@@ -422,7 +412,9 @@ public class ExporterGenerator extends JavaGenerator{
        }\r
 \r
        @Override       \r
-       protected void handle(SchemaObject parent, Attribute attribute) {\r
+       public void handle(SchemaObject parent, Attribute attribute) {\r
+               if (parent == null)\r
+                       return;\r
                String name = attribute.getName();\r
                QName primitiveType = attribute.getType();\r
                SimpleType simpleType = attribute.getSimpleType();\r
@@ -440,7 +432,7 @@ public class ExporterGenerator extends JavaGenerator{
                        attrName = ref.getLocalPart();\r
                        relationName = ontShort+getName(parent)+"_has"+ref.getLocalPart();\r
                        \r
-                       Attribute referred = getRefAttribute(ref);\r
+                       Attribute referred = base.getRefAttribute(ref);\r
                        if (referred != null) {\r
                                primitiveType = referred.getType();\r
                                simpleType = referred.getSimpleType();\r
@@ -457,14 +449,14 @@ public class ExporterGenerator extends JavaGenerator{
                if (primitiveType != null) {\r
                        \r
                        //String binding = getBindingFromPrimitiveType(primitiveType);\r
-                       TypeEntry binding = getTypeEntry(primitiveType);\r
+                       TypeEntry binding = base.getTypeEntry(primitiveType);\r
                        \r
                        if (binding != null) {\r
                                writeAttribute(fw, attrName, relationName, binding, isReference);\r
                                return;\r
                    } else {\r
                        if (simpleType == null) {\r
-                               SchemaObject simpleTypeObj = simpleTypeName.get(primitiveType.getLocalPart());\r
+                               SchemaObject simpleTypeObj = base.simpleTypeName.get(primitiveType.getLocalPart());\r
                                if (simpleTypeObj != null)\r
                                        simpleType = simpleTypeObj.getSimpleType();\r
                        }       \r
@@ -473,7 +465,7 @@ public class ExporterGenerator extends JavaGenerator{
                if (simpleType != null) {\r
                        org.w3._2001.xmlschema.List list = simpleType.getList();\r
                        if (list != null) {\r
-                               TypeEntry binding = getTypeEntry(new QName(SCHEMA_NS, "string"));\r
+                               TypeEntry binding = base.getTypeEntry(new QName(SchemaConversionBase.SCHEMA_NS, "string"));\r
                                writeAttribute(fw, attrName, relationName, binding, isReference);\r
                        } else {\r
                                Restriction restriction = simpleType.getRestriction();\r
@@ -483,7 +475,7 @@ public class ExporterGenerator extends JavaGenerator{
                                \r
                                \r
                                //String binding = getBindingFromPrimitiveType(base);\r
-                               TypeEntry binding = getTypeEntry(base);\r
+                               TypeEntry binding = this.base.getTypeEntry(base);\r
                                writeAttribute(fw, attrName, relationName, binding, isReference);\r
                        }\r
                } else {\r
@@ -491,11 +483,10 @@ public class ExporterGenerator extends JavaGenerator{
                        //throw new RuntimeException("Cannot resolve type for Attribute " + attrName + " -> " + primitiveType.getLocalPart());\r
                        fw.writer.println("    //FIXME: Cannot resolve type for Attribute " + attrName + " Using default type String");\r
                        //writeAttribute(fw, attrName, relationName, "STRING", isReference);\r
-                       writeAttribute(fw, attrName, relationName, getTypeEntry("string"), isReference);\r
+                       writeAttribute(fw, attrName, relationName, base.getTypeEntry("string"), isReference);\r
                }\r
        }\r
        \r
-       //private void writeAttribute(FileWriter fw, String attrName, String relationName, String binding, boolean isReference) {\r
        private void writeAttribute(FileWriter fw, String attrName, String relationName, TypeEntry binding, boolean isReference) {\r
                fw.writer.println("      {");\r
                fw.writer.println("         if (attribute.getPredicate().equals("+relationName+")) {"); \r
@@ -508,7 +499,7 @@ public class ExporterGenerator extends JavaGenerator{
        }\r
        \r
        @Override\r
-       protected void handleAttributes(SchemaObject simpleTypeObj) {\r
+       public void handleAttributes(SchemaObject simpleTypeObj) {\r
                SchemaObject parent = simpleTypeObj.getParent();\r
                FileWriter fw = getWriter(parent);\r
                \r
@@ -520,7 +511,7 @@ public class ExporterGenerator extends JavaGenerator{
                \r
                \r
                //String binding = getBindingFromPrimitiveType(base);\r
-               TypeEntry binding = getTypeEntry(base);\r
+               TypeEntry binding = this.base.getTypeEntry(base);\r
                \r
                fw.writer.println("   @Override");\r
                fw.writer.println("   public void characters(ReadGraph graph, WriterElement instance, XMLStreamWriter writer) throws XMLStreamException, DatabaseException {");\r
@@ -530,10 +521,10 @@ public class ExporterGenerator extends JavaGenerator{
        }\r
        \r
        @Override\r
-       protected void handle(SchemaObject parent, AttributeGroup attribute) {\r
+       public void handle(SchemaObject parent, AttributeGroup attribute) {\r
                if (parent != null) {\r
                        FileWriter fw = getWriter(parent);\r
-                       NamedAttributeGroup group = getAttributeGroup(attribute.getRef().getLocalPart());\r
+                       NamedAttributeGroup group = this.base.getAttributeGroup(attribute.getRef().getLocalPart());\r
                        fw.writer.println(commentTag+"    AttributeGroup " + group.getName());\r
                        SchemaObject obj = new SchemaObject(parent,attribute);\r
                        for (Annotated annotated : group.getAttributeOrAttributeGroup()) {\r
@@ -551,10 +542,10 @@ public class ExporterGenerator extends JavaGenerator{
        }\r
        \r
        @Override\r
-       protected void handleAttributeComposition(SchemaObject parent, AttributeComposition composition, BijectionMap<org.simantics.xml.sax.configuration.Attribute, Annotated> attributes) {\r
+       public void handleAttributeComposition(SchemaObject parent, AttributeComposition composition, BijectionMap<org.simantics.xml.sax.configuration.Attribute, Annotated> attributes) {\r
                FileWriter fw = getWriter(parent);\r
-               QName type = new QName(CONVERSION_NS, composition.getType());\r
-               TypeEntry typeEntry = getTypeEntry(type);\r
+               QName type = new QName(SchemaConversionBase.CONVERSION_NS, composition.getType());\r
+               TypeEntry typeEntry = this.base.getTypeEntry(type);\r
                String arrayBinding = typeEntry.binding;//getBindingFromPrimitiveType(type);\r
                String javaType = typeEntry.javaType;//getJavaTypeFromPrimitiveType(type);\r
                String name = composition.getName();\r
@@ -603,7 +594,7 @@ public class ExporterGenerator extends JavaGenerator{
        }\r
        \r
        protected String getDefaultValue(QName atype) {\r
-               Map<String,TypeEntry> types = typeMap.get(atype.getNamespaceURI());\r
+               Map<String,TypeEntry> types = this.base.typeMap.get(atype.getNamespaceURI());\r
                if (types == null)\r
                        return null;\r
                TypeEntry entry =  types.get(atype.getLocalPart());\r
@@ -612,14 +603,9 @@ public class ExporterGenerator extends JavaGenerator{
                return entry.defaultValue;\r
        }\r
        \r
-       \r
-       \r
-       \r
-       \r
-       \r
        IDProvider provider;\r
        @Override\r
-       protected void handleElement(SchemaObject elementObj)  {\r
+       public void handleElement(SchemaObject elementObj)  {\r
                Element element = elementObj.getElement();\r
                \r
                String name = getName(elementObj);//topLevelElement.getName();\r
@@ -634,11 +620,11 @@ public class ExporterGenerator extends JavaGenerator{
                writers.put(elementObj, fw);\r
                boolean isList = false;\r
                \r
-               Inheritance inheritance = getInheritance(elementObj);   \r
+               Inheritance inheritance = this.base.getInheritance(elementObj); \r
                \r
-               provider = getIDProvider(element);\r
-               List<IDReference> references = getIDReferences(element);\r
-               UnrecognizedChildElement unknownChildElement = getUnknown(element);\r
+               provider = this.base.getIDProvider(element);\r
+               List<IDReference> references = this.base.getIDReferences(element);\r
+               UnrecognizedChildElement unknownChildElement = this.base.getUnknown(element);\r
 \r
 //             List<String> intrerfaces = new ArrayList<String>();\r
 //             if (references.size() > 0)\r
@@ -681,8 +667,8 @@ public class ExporterGenerator extends JavaGenerator{
                fw.writer.println("        "+getOntologyImport());\r
                fw.writer.println("        for (Statement attribute : attributes) {");\r
                if (complexType != null) {\r
-                       SchemaObject obj = complexTypes.get(complexType);\r
-                       handleElementComplexTypeAttributes(obj);\r
+                       SchemaObject obj = this.base.complexTypes.get(complexType);\r
+                       this.base.handleElementComplexTypeAttributes(obj);\r
                } \r
                fw.writer.println("        }");\r
                fw.writer.println("   }");\r
@@ -731,8 +717,8 @@ public class ExporterGenerator extends JavaGenerator{
                fw.writer.println("      super(graph);");\r
                fw.writer.println("      "+getOntologyImport());\r
                if (complexType != null) {\r
-                       SchemaObject obj = complexTypes.get(complexType);\r
-                       handleComplexTypeExtension(obj);\r
+                       SchemaObject obj = this.base.complexTypes.get(complexType);\r
+                       this.base.handleComplexTypeExtension(obj);\r
                } else if (simpleType != null) {\r
                        \r
                }\r