-/*******************************************************************************\r
- * Copyright (c) 2007, 2013 Association for Decentralized Information Management\r
- * in 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.apache.log4j.Logger;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.WriteGraph;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.objmap.backward.IBackwardMapping;\r
-import org.simantics.objmap.bidirectional.IBidirectionalMappingRule;\r
-import org.simantics.objmap.exceptions.MappingException;\r
-import org.simantics.objmap.forward.IForwardMapping;\r
-import org.simantics.objmap.graph.rules.factory.IMethodRuleFactory;\r
-\r
-public class UpdateMethodFactory<Domain, Range> implements IMethodRuleFactory<Domain, Range> {\r
-\r
- static Logger LOGGER = Logger.getLogger("org.simantics.objmap");\r
- \r
- @Override\r
- public IBidirectionalMappingRule<Domain, Range> create(ReadGraph g, \r
- Annotation annotation, \r
- final Method method)\r
- throws DatabaseException {\r
- method.setAccessible(true);\r
- return new IBidirectionalMappingRule<Domain,Range>() {\r
- \r
- @Override\r
- public boolean updateRange(ReadGraph g, IForwardMapping<Domain, Range> map,\r
- Domain domainElement, Range rangeElement)\r
- throws MappingException {\r
- LOGGER.info(" UpdateMethodFactory.updateRange"); \r
- try {\r
- return (Boolean)method.invoke(rangeElement, g, domainElement);\r
- } catch (Exception e) {\r
- // TODO Auto-generated catch block\r
- e.printStackTrace();\r
- }\r
- return false;\r
- }\r
- \r
- @Override\r
- public boolean updateDomain(WriteGraph g, IBackwardMapping<Domain,Range> map,\r
- Domain domainElement, Range rangeElement)\r
- throws MappingException {\r
- return false;\r
- }\r
- \r
- public void createDomain(WriteGraph g, IBackwardMapping<Domain,Range> map, Domain domainElement, Range rangeElement) throws MappingException {\r
- updateDomain(g, map, domainElement, rangeElement);\r
- };\r
- \r
- public void createRange(ReadGraph g, IForwardMapping<Domain,Range> map, Domain domainElement, Range rangeElement) throws MappingException {\r
- updateRange(g, map, domainElement, rangeElement);\r
- };\r
- };\r
- }\r
-\r
-}\r
+/*******************************************************************************
+ * Copyright (c) 2007, 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.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.WriteGraph;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.objmap.backward.IBackwardMapping;
+import org.simantics.objmap.bidirectional.IBidirectionalMappingRule;
+import org.simantics.objmap.exceptions.MappingException;
+import org.simantics.objmap.forward.IForwardMapping;
+import org.simantics.objmap.graph.rules.factory.IMethodRuleFactory;
+
+public class UpdateMethodFactory<Domain, Range> implements IMethodRuleFactory<Domain, Range> {
+
+ static Logger LOGGER = LoggerFactory.getLogger(UpdateMethodFactory.class);
+
+ @Override
+ public IBidirectionalMappingRule<Domain, Range> create(ReadGraph g,
+ Annotation annotation,
+ final Method method)
+ throws DatabaseException {
+ method.setAccessible(true);
+ return new IBidirectionalMappingRule<Domain,Range>() {
+
+ @Override
+ public boolean updateRange(ReadGraph g, IForwardMapping<Domain, Range> map,
+ Domain domainElement, Range rangeElement)
+ throws MappingException {
+ LOGGER.trace(" UpdateMethodFactory.updateRange");
+ try {
+ return (Boolean)method.invoke(rangeElement, g, domainElement);
+ } catch (Exception e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
+ return false;
+ }
+
+ @Override
+ public boolean updateDomain(WriteGraph g, IBackwardMapping<Domain,Range> map,
+ Domain domainElement, Range rangeElement)
+ throws MappingException {
+ return false;
+ }
+
+ @Override
+ public boolean checkChanges(ReadGraph g, IForwardMapping<Domain, Range> map, Domain domainElement,
+ Range rangeElement) throws MappingException {
+ return false;
+ }
+
+ public void createDomain(WriteGraph g, IBackwardMapping<Domain,Range> map, Domain domainElement, Range rangeElement) throws MappingException {
+ updateDomain(g, map, domainElement, rangeElement);
+ };
+
+ public void createRange(ReadGraph g, IForwardMapping<Domain,Range> map, Domain domainElement, Range rangeElement) throws MappingException {
+ updateRange(g, map, domainElement, rangeElement);
+ };
+ };
+ }
+
+}