\r
import java.util.ArrayDeque;\r
import java.util.ArrayList;\r
+import java.util.Base64;\r
import java.util.Deque;\r
import java.util.HashMap;\r
import java.util.HashSet;\r
Map<String,TypeEntry> l0Types = new HashMap<String, SchemaConversionBase.TypeEntry>();\r
typeMap.put(CONVERSION_NS, l0Types);\r
\r
- schemaTypes.put("string", new TypeEntry("L0.String", "STRING", "String", ""));\r
- schemaTypes.put("NMTOKEN", new TypeEntry("L0.String", "STRING", "String", ""));\r
- schemaTypes.put("token", new TypeEntry("L0.String", "STRING", "String", ""));\r
- schemaTypes.put("ID", new TypeEntry("L0.String", "STRING", "String", "",true));\r
- schemaTypes.put("IDREF", new TypeEntry("L0.String", "STRING", "String", ""));\r
- schemaTypes.put("date", new TypeEntry("L0.String", "STRING", "String", ""));\r
- schemaTypes.put("time", new TypeEntry("L0.String", "STRING", "String", ""));\r
- schemaTypes.put("anyURI", new TypeEntry("L0.URI", "STRING", "String", ""));\r
- schemaTypes.put("double", new TypeEntry("L0.Double", "DOUBLE", "double", "Double.NaN"));\r
- schemaTypes.put("float", new TypeEntry("L0.Float", "FLOAT", "float", "Float.NaN"));\r
- schemaTypes.put("decimal", new TypeEntry("L0.Double", "DOUBLE", "double", "Double.NaN"));\r
- schemaTypes.put("boolean", new TypeEntry("L0.Boolean", "BOOLEAN", "boolean", "false"));\r
- schemaTypes.put("integer", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("positiveInteger", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("nonPositiveInteger", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("nonNegativeInteger", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("negativeInteger", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("unsignedInt", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("int", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("short", new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("unsignedShort",new TypeEntry("L0.Integer", "INTEGER", "int", "0"));\r
- schemaTypes.put("byte", new TypeEntry("L0.Byte", "BYTE", "byte", "0"));\r
- schemaTypes.put("unsignedByte", new TypeEntry("L0.Byte", "BYTE", "byte", "0"));\r
- schemaTypes.put("long", new TypeEntry("L0.Long", "LONG", "long", "0"));\r
- schemaTypes.put("unsignedLong", new TypeEntry("L0.Long", "LONG", "long", "0"));\r
+ schemaTypes.put("string", new TypeEntry("L0.String", "Bindings.STRING", "java.lang.String", "","",""));\r
+ schemaTypes.put("NMTOKEN", new TypeEntry("L0.String", "Bindings.STRING", "java.lang.String", "","",""));\r
+ schemaTypes.put("token", new TypeEntry("L0.String", "Bindings.STRING", "java.lang.String", "","",""));\r
+ schemaTypes.put("ID", new TypeEntry("L0.String", "Bindings.STRING", "java.lang.String", "","","",true));\r
+ schemaTypes.put("IDREF", new TypeEntry("L0.String", "Bindings.STRING", "java.lang.String", "","",""));\r
+ schemaTypes.put("date", new TypeEntry("XML.Date", "org.simantics.xml.sax.base.datatypes.literal.Date.BINDING", "org.simantics.xml.sax.base.datatypes.literal.Date", "","org.simantics.xml.sax.base.datatypes.literal.Date.parseDate(",")"));\r
+ schemaTypes.put("time", new TypeEntry("XML.Time", "org.simantics.xml.sax.base.datatypes.literal.Time.BINDING", "org.simantics.xml.sax.base.datatypes.literal.Time", "","org.simantics.xml.sax.base.datatypes.literal.Time.parseTime(",")"));\r
+ schemaTypes.put("dateTime", new TypeEntry("XML.DateTime", "org.simantics.xml.sax.base.datatypes.literal.DateTime.BINDING", "org.simantics.xml.sax.base.datatypes.literal.DateTime", "","org.simantics.xml.sax.base.datatypes.literal.DateTime.parseDateTime(",")"));\r
+ schemaTypes.put("anyURI", new TypeEntry("L0.URI", "Bindings.STRING", "java.lang.String", "","",""));\r
+ schemaTypes.put("double", new TypeEntry("L0.Double", "Bindings.DOUBLE", "double", "java.lang.Double.NaN","java.lang.Double.parseDouble(",")"));\r
+ schemaTypes.put("float", new TypeEntry("L0.Float", "Bindings.FLOAT", "float", "java.lang.Float.NaN","java.lang.Float.parseFloat(",")"));\r
+ schemaTypes.put("decimal", new TypeEntry("L0.Double", "Bindings.DOUBLE", "double", "java.lang.Double.NaN","java.lang.Double.parseDouble(",")"));\r
+ schemaTypes.put("boolean", new TypeEntry("L0.Boolean", "Bindings.BOOLEAN", "boolean", "false","java.lang.Boolean.parseBoolean(",")"));\r
+ schemaTypes.put("integer", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("positiveInteger", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("nonPositiveInteger", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("nonNegativeInteger", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("negativeInteger", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("unsignedInt", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("int", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("short", new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("unsignedShort",new TypeEntry("L0.Integer", "Bindings.INTEGER", "int", "0","java.lang.Integer.parseInt(",")"));\r
+ schemaTypes.put("byte", new TypeEntry("L0.Byte", "Bindings.BYTE", "byte", "0","java.lang.Byte.parseByte(",")"));\r
+ schemaTypes.put("unsignedByte", new TypeEntry("L0.Byte", "Bindings.BYTE", "byte", "0","java.lang.Byte.parseByte(",")"));\r
+ schemaTypes.put("long", new TypeEntry("L0.Long", "Bindings.LONG", "long", "0","java.lang.Long.parseLong(",")"));\r
+ schemaTypes.put("unsignedLong", new TypeEntry("L0.Long", "Bindings.LONG", "long", "0","java.lang.Long.parseLong(",")"));\r
+ schemaTypes.put("base64Binary", new TypeEntry("L0.ByteArray", "Bindings.BYTE_ARRAY", "byte[]", "new byte[0]","",".getBytes(org.simantics.databoard.util.binary.UTF8.CHARSET)"));\r
\r
\r
\r
- l0Types.put("doubleArray", new TypeEntry("L0.DoubleArray", "DOUBLE_ARRAY", "double[]", null));\r
- l0Types.put("stringArray", new TypeEntry("L0.StringArray", "STRING_ARRAY", "string[]", null));\r
+ l0Types.put("doubleArray", new TypeEntry("L0.DoubleArray", "Bindings.DOUBLE_ARRAY", "double[]", null,null,null));\r
+ l0Types.put("stringArray", new TypeEntry("L0.StringArray", "Bindings.STRING_ARRAY", "string[]", null,null,null));\r
}\r
\r
\r
return null;\r
TypeEntry entry = types.get(type.getLocalPart());\r
return entry;\r
- \r
+ }\r
+ protected TypeEntry getTypeEntry(String type) {\r
+ for (Map<String,TypeEntry> types : typeMap.values()) {\r
+ TypeEntry entry = types.get(type);\r
+ if (entry != null)\r
+ return entry;\r
+ }\r
+ return null;\r
}\r
\r
protected String getL0TypeFromPrimitiveType(QName primitiveType) {\r
return null;\r
}\r
\r
+ protected QName getPrimitiveType(Attribute attribute) {\r
+ QName type = getBaseType(attribute);\r
+ String b = getBindingFromPrimitiveType(type);\r
+ while (b==null && type != null) {\r
+ SchemaObject baseType = simpleTypeName.get(type.getLocalPart());\r
+ if (baseType != null) {\r
+ Restriction restriction = baseType.getSimpleType().getRestriction();\r
+ if (restriction != null)\r
+ if (restriction.getBase() != null) {\r
+ type = restriction.getBase();\r
+ b = getBindingFromPrimitiveType(type);\r
+ }\r
+ }\r
+ }\r
+ return type;\r
+ }\r
+ \r
protected Attribute getRefAttribute(QName ref) {\r
for (OpenAttrs attrs : schema.getSimpleTypeOrComplexTypeOrGroup()) {\r
if (attrs instanceof TopLevelAttribute) {\r
String javaType;\r
String defaultValue;\r
boolean id;\r
- public TypeEntry(String l0Type, String binding, String javaType, String defaultValue) {\r
+ String getterPrefix;\r
+ String getterPostfix;\r
+ public TypeEntry(String l0Type, String binding, String javaType, String defaultValue, String getterPrefix, String getterPostfix) {\r
super();\r
this.l0Type = l0Type;\r
this.binding = binding;\r
this.javaType = javaType;\r
this.defaultValue = defaultValue;\r
this.id = false;\r
+ this.getterPrefix = getterPrefix;\r
+ this.getterPostfix = getterPostfix;\r
+ \r
}\r
\r
- public TypeEntry(String l0Type, String binding, String javaType, String defaultValue, boolean id) {\r
+ public TypeEntry(String l0Type, String binding, String javaType, String defaultValue, String getterPrefix, String getterPostfix, boolean id) {\r
super();\r
this.l0Type = l0Type;\r
this.binding = binding;\r
this.javaType = javaType;\r
this.defaultValue = defaultValue;\r
this.id = id;\r
+ this.getterPrefix = getterPrefix;\r
+ this.getterPostfix = getterPostfix;\r
+ }\r
+ \r
+ public String getValueGetterMethod(String name) {\r
+ return getterPrefix + name + ".getValue()"+getterPostfix;\r
+ }\r
+ public String getValueGetter(String name) {\r
+ return getterPrefix + name+getterPostfix;\r
+ }\r
+ public String getValueGetter()\r
+ {\r
+ return getValueGetter("value");\r
}\r
\r
}\r