]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.objmap2/src/org/simantics/objmap/graph/annotations/factories/CompoundRelatedGetSetValueRuleFactory.java
Fix binding instance for CompoundRelatedGetValue method.
[simantics/platform.git] / bundles / org.simantics.objmap2 / src / org / simantics / objmap / graph / annotations / factories / CompoundRelatedGetSetValueRuleFactory.java
index 2120b50fe8fe1f3f0831f28867db7a2d9076e93c..b98961154ca4cddec50b5a2ddd8efbcc62a1f17a 100644 (file)
-/*******************************************************************************\r
- * Copyright (c) 2012, 2013 Association for Decentralized Information Management in\r
- * Industry THTH ry.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- *     VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.objmap.graph.annotations.factories;\r
-\r
-import java.lang.annotation.Annotation;\r
-import java.lang.reflect.Method;\r
-\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.layer0.Layer0;\r
-import org.simantics.objmap.bidirectional.IBidirectionalMappingRule;\r
-import org.simantics.objmap.graph.annotations.CompoundRelatedGetValue;\r
-import org.simantics.objmap.graph.annotations.CompoundRelatedSetValue;\r
-import org.simantics.objmap.graph.rules.ValueRule;\r
-import org.simantics.objmap.graph.rules.domain.CompoundValueAccessor;\r
-import org.simantics.objmap.graph.rules.factory.IGetSetRuleFactory;\r
-import org.simantics.objmap.graph.rules.range.CompoundGetSetValueAccessor;\r
-import org.simantics.objmap.graph.rules.range.IRangeAccessor;\r
-\r
-/**\r
- * Rule factory for mapped value using Getter/Setter-methods.\r
- * \r
- * @author Marko Luukkainen <marko.luukkainen@vtt.fi>\r
- *\r
- */\r
-public class CompoundRelatedGetSetValueRuleFactory<Range> implements IGetSetRuleFactory<Resource,Range> {\r
-       \r
-       @Override\r
-       public IBidirectionalMappingRule<Resource, Range> create(ReadGraph g, Annotation annotation,\r
-                       Method getter, Method setter)\r
-                       throws DatabaseException {\r
-               CompoundRelatedGetValue getterAnn = (CompoundRelatedGetValue)annotation;\r
-               \r
-//             Class<? extends ValueAdapter> adapterClass = getterAnn.adapter();\r
-               IRangeAccessor<Range,Object> rangeAccessor = new CompoundGetSetValueAccessor<Range,Object>(getter, setter);\r
-//        Resource valueType;\r
-//        if (adapterClass == IdentityAdapter.class) {\r
-//            valueType = dataTypeOfClass(g, getter.getReturnType());\r
-//        } else {\r
-//             try{\r
-//                      ValueAdapter adapter = adapterClass.newInstance();\r
-//                 rangeAccessor = new AdaptedRangeAccessor<Range>(rangeAccessor, adapter);\r
-//                 valueType = adapter.rangeTypeToDomainType(g, getter.getReturnType());\r
-//             } catch (InstantiationException e) {\r
-//                 throw new RuntimeException(e);\r
-//             } catch (IllegalAccessException e) {\r
-//                 throw new RuntimeException(e);\r
-//             }\r
-//        }\r
-               return new ValueRule<Resource,Range>(new CompoundValueAccessor(g.getResource(getterAnn.objRelation()),\r
-                                                                                                                                          g.getResource(getterAnn.objType()),\r
-                                                                                                                                          g.getResource(getterAnn.valRelation())),\r
-                                       rangeAccessor);\r
-       }\r
-       \r
-       @Override\r
-       public boolean isSetter(Annotation getterAnnotation, Annotation annotation) {\r
-               CompoundRelatedGetValue getterAnn = (CompoundRelatedGetValue)getterAnnotation;\r
-               CompoundRelatedSetValue setterAnn = (CompoundRelatedSetValue)annotation;\r
-               return getterAnn.objRelation().equals(setterAnn.value());\r
-       }\r
-       \r
-       public static Resource dataTypeOfClass(ReadGraph g, Class<?> clazz) {\r
-        Layer0 b = Layer0.getInstance(g);\r
-        if(clazz.equals(Double.class) || clazz.equals(double.class))\r
-            return b.Double;\r
-        else if(clazz.equals(String.class))\r
-            return b.String;\r
-        else if(clazz.equals(Integer.class) || clazz.equals(int.class))\r
-            return b.Integer;\r
-        else if(clazz.equals(Float.class) || clazz.equals(float.class))\r
-            return b.Float;\r
-        else if(clazz.equals(Boolean.class) || clazz.equals(boolean.class))\r
-            return b.Boolean;\r
-        else if(clazz.equals(Long.class) || clazz.equals(long.class))\r
-            return b.Long;\r
-        else if(clazz.equals(Byte.class) || clazz.equals(byte.class))\r
-            return b.Byte;\r
-        \r
-        else if(clazz.equals(double[].class))\r
-            return b.DoubleArray;\r
-        else if(clazz.equals(int[].class))\r
-            return b.IntegerArray;\r
-        else if(clazz.equals(byte[].class))\r
-            return b.ByteArray;\r
-        else if(clazz.equals(float[].class))\r
-            return b.FloatArray;\r
-        else if(clazz.equals(boolean[].class))\r
-            return b.BooleanArray;\r
-        else if(clazz.equals(String[].class))\r
-            return b.StringArray;\r
-        else if(clazz.equals(long[].class))\r
-            return b.LongArray;\r
-        else {\r
-               System.out.println("Couldn't find a data type for " + clazz);\r
-            return null;\r
-        }\r
-    }\r
-\r
-}\r
+/*******************************************************************************
+ * Copyright (c) 2012, 2013 Association for Decentralized Information Management in
+ * Industry THTH ry.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     VTT Technical Research Centre of Finland - initial API and implementation
+ *******************************************************************************/
+package org.simantics.objmap.graph.annotations.factories;
+
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Method;
+
+import org.simantics.databoard.binding.Binding;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.request.PropertyInfo;
+import org.simantics.db.layer0.request.PropertyInfoRequest;
+import org.simantics.objmap.bidirectional.IBidirectionalMappingRule;
+import org.simantics.objmap.graph.annotations.CompoundRelatedGetValue;
+import org.simantics.objmap.graph.annotations.CompoundRelatedSetValue;
+import org.simantics.objmap.graph.rules.ValueRule;
+import org.simantics.objmap.graph.rules.domain.CompoundValueAccessor;
+import org.simantics.objmap.graph.rules.factory.IGetSetRuleFactory;
+import org.simantics.objmap.graph.rules.range.CompoundGetSetValueAccessor;
+import org.simantics.objmap.graph.rules.range.IRangeAccessor;
+
+/**
+ * Rule factory for mapped value using Getter/Setter-methods.
+ * 
+ * @author Marko Luukkainen <marko.luukkainen@vtt.fi>
+ *
+ */
+public class CompoundRelatedGetSetValueRuleFactory<Range> implements IGetSetRuleFactory<Resource,Range> {
+       
+       @Override
+       public IBidirectionalMappingRule<Resource, Range> create(ReadGraph g, Annotation annotation,
+                       Method getter, Method setter)
+                       throws DatabaseException {
+               CompoundRelatedGetValue getterAnn = (CompoundRelatedGetValue)annotation;
+               
+//             Class<? extends ValueAdapter> adapterClass = getterAnn.adapter();
+               IRangeAccessor<Range,Object> rangeAccessor = new CompoundGetSetValueAccessor<Range,Object>(getter, setter);
+               PropertyInfo propInfo = g.syncRequest(new PropertyInfoRequest(g.getResource(getterAnn.valRelation())));
+               Binding valueBinding = propInfo.defaultBinding;
+//        Resource valueType;
+//        if (adapterClass == IdentityAdapter.class) {
+//            valueType = dataTypeOfClass(g, getter.getReturnType());
+//        } else {
+//             try{
+//                      ValueAdapter adapter = adapterClass.newInstance();
+//                 rangeAccessor = new AdaptedRangeAccessor<Range>(rangeAccessor, adapter);
+//                 valueType = adapter.rangeTypeToDomainType(g, getter.getReturnType());
+//             } catch (InstantiationException e) {
+//                 throw new RuntimeException(e);
+//             } catch (IllegalAccessException e) {
+//                 throw new RuntimeException(e);
+//             }
+//        }
+               return new ValueRule<Resource,Range>(new CompoundValueAccessor(g.getResource(getterAnn.objRelation()),
+                                                                                                                                          g.getResource(getterAnn.objType()),
+                                                                                                                                          g.getResource(getterAnn.valRelation()),
+                                                                                                                                          valueBinding),
+                                       rangeAccessor);
+       }
+       
+       @Override
+       public boolean isSetter(Annotation getterAnnotation, Annotation annotation) {
+               CompoundRelatedGetValue getterAnn = (CompoundRelatedGetValue)getterAnnotation;
+               CompoundRelatedSetValue setterAnn = (CompoundRelatedSetValue)annotation;
+               return getterAnn.objRelation().equals(setterAnn.value());
+       }
+
+}