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.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
}\r
\r
@Override\r
- protected String getBaseClass() {\r
+ protected String getBaseClass(ObjectType type) {\r
return "org.simantics.xml.sax.base.XMLElementNamedChildWriterBase";\r
}\r
\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
-// obj = simpleTypeName.get(type.getLocalPart());\r
- if (obj != null) {\r
- baseClass = getName(obj);\r
- inherited = true;\r
- }\r
- }\r
+// String baseClass = getBaseClass(ObjectType.COMPLEX_TYPE);\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
+//// obj = simpleTypeName.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
// intrerfaces.add("org.simantics.xml.sax.base.UnrecognizedElementParser");\r
\r
createClassHeader(fw.writer);\r
- writeClass(fw.writer,false, topLevelComplexType.getName(), className, baseClass, Collections.EMPTY_LIST);\r
+ writeClass(fw.writer,false, topLevelComplexType.getName(), className, inheritance.baseClass, Collections.EMPTY_LIST);\r
\r
// writeIDProvider(fw.writer);\r
\r
if (stringWriter.getBuffer().length() > 0) {\r
fw.writer.write(stringWriter.toString());\r
}\r
- \r
+ if (inheritance.type == InheritanceType.ComplexType)\r
+ fw.writer.println(" super.children(graph,instance,result);");\r
fw.writer.println(" }");\r
fw.writer.println();\r
\r
\r
fw.writer.println(" @Override");\r
fw.writer.println(" public void attributes(ReadGraph graph, WriterElement instance, Collection<Statement> attributes, XMLStreamWriter writer) throws XMLStreamException, DatabaseException{");\r
- if (inherited) {\r
+ if (inheritance.type == InheritanceType.ComplexType) {\r
fw.writer.println(" super.attributes(graph,instance,attributes,writer);");\r
}\r
fw.writer.println(" "+getOntologyImport());\r
fw.writer.println(" }");\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 characters(ReadGraph graph, WriterElement instance, XMLStreamWriter writer) throws XMLStreamException, DatabaseException {");\r
+ fw.writer.println(" writer.writeCharacters("+inheritance.atomicType.getToString("graph.getValue(instance.getResource(),"+inheritance.atomicType.binding+")")+");");\r
+ fw.writer.println(" }");\r
+ }\r
+ \r
// writeIDReferences(fw.writer,name, references);\r
// writeUnknownChild(fw.writer,name,unknownChildElement);\r
\r
\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
FileWriter fw = getWriter(parent);\r
+ String objectName;\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
+ objectName = element.getElement().getName();\r
} else {\r
refType = element.getElement().getRef();\r
if (refName == null)\r
refName = refType.getLocalPart();\r
+ objectName = refType.getLocalPart();\r
}\r
\r
String binding = getBindingFromPrimitiveType(refType);\r
SchemaObject refElement = elementName.get(refType.getLocalPart());\r
SchemaObject refComplexType = complexTypeName.get(refType.getLocalPart());\r
\r
- String className = null;\r
- String refClassName = null;\r
+ // prefer element reference over complex type reference\r
+ String primaryClassName = null;\r
+ String secondaryClassName = null;\r
if (refElement != null)\r
- className = getName(refElement);\r
+ primaryClassName = getName(refElement);\r
else\r
- className = getName(refComplexType);\r
+ primaryClassName = getName(refComplexType);\r
\r
if (refComplexType != null) {\r
- refClassName = getName(refComplexType);\r
+ secondaryClassName = getName(refComplexType);\r
} else {\r
- refClassName = getName(refElement);\r
+ secondaryClassName = 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
+ 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
+ fw.delayedWriter2.println(" public static class " + secondaryClassName +" extends " + primaryClassName +"{");\r
+ fw.delayedWriter2.println(" public "+ secondaryClassName +"(ReadGraph graph){");\r
+ fw.delayedWriter2.println(" super(graph);");\r
+ fw.delayedWriter2.println(" }");\r
+ fw.delayedWriter2.println(" ");\r
+ fw.delayedWriter2.println(" @Override");\r
+ fw.delayedWriter2.println(" public java.lang.String getElementId() {");\r
+ fw.delayedWriter2.println(" return \"" + refName +"\";");\r
+ fw.delayedWriter2.println(" }");\r
+ fw.delayedWriter2.println(" }");\r
+ } else { //referenceType == RefType.Reference\r
+ fw.writer.println(" addWriter("+primaryClassName+".class);");\r
+ if (!primaryClassName.equals(secondaryClassName))\r
+ fw.writer.println(" addWriter("+secondaryClassName+".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
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
// intrerfaces.add("org.simantics.xml.sax.base.UnrecognizedElementParser");\r
\r
createClassHeader(fw.writer);\r
- writeClass(fw.writer,false, element.getName(), className, inhertiance.baseClass, Collections.EMPTY_LIST);\r
+ writeClass(fw.writer,false, element.getName(), className, inheritance.baseClass, Collections.EMPTY_LIST);\r
// writeIDProvider(fw.writer);\r
fw.writer.println(" @Override");\r
fw.writer.println(" public Resource getType(ReadGraph graph) throws DatabaseException {");\r
\r
fw.writer.println(" @Override");\r
fw.writer.println(" public void attributes(ReadGraph graph, WriterElement instance, Collection<Statement> attributes, XMLStreamWriter writer) throws XMLStreamException, DatabaseException{");\r
- if (inhertiance.type == InheritanceType.ComplexType) {\r
+ if (inheritance.type == InheritanceType.ComplexType) {\r
fw.writer.println(" super.attributes(graph,instance,attributes,writer);");\r
}\r
fw.writer.println(" "+getOntologyImport());\r
// } \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(" }");\r
fw.writer.println(" @Override");\r
fw.writer.println(" public void characters(ReadGraph graph, WriterElement instance, XMLStreamWriter writer) throws XMLStreamException, DatabaseException {");\r
- fw.writer.println(" writer.writeCharacters("+inhertiance.atomicType.getToString("graph.getValue(instance.getResource(),"+inhertiance.atomicType.binding+")")+");");\r
+ fw.writer.println(" writer.writeCharacters("+inheritance.atomicType.getToString("graph.getValue(instance.getResource(),"+inheritance.atomicType.binding+")")+");");\r
// fw.writer.println(" graph.claimValue(element.getData(),"+getValueGetter(binding)+", "+binding.binding +");");\r
fw.writer.println(" }");\r
}\r
fw.writer.write(stringWriter.toString());\r
}\r
\r
- if (inhertiance.type == InheritanceType.ComplexType) {\r
+ if (inheritance.type == InheritanceType.ComplexType) {\r
fw.writer.println(" super.children(graph,instance,result);");\r
}\r
\r