]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.objmap2/src/org/simantics/objmap/graph/rules/range/FieldAccessor.java
Migrated source code from Simantics SVN
[simantics/platform.git] / bundles / org.simantics.objmap2 / src / org / simantics / objmap / graph / rules / range / FieldAccessor.java
1 /*******************************************************************************\r
2  * Copyright (c) 2007, 2013 Association for Decentralized Information Management\r
3  * in Industry THTH ry.\r
4  * All rights reserved. This program and the accompanying materials\r
5  * are made available under the terms of the Eclipse Public License v1.0\r
6  * which accompanies this distribution, and is available at\r
7  * http://www.eclipse.org/legal/epl-v10.html\r
8  *\r
9  * Contributors:\r
10  *     VTT Technical Research Centre of Finland - initial API and implementation\r
11  *******************************************************************************/\r
12 package org.simantics.objmap.graph.rules.range;\r
13 \r
14 import java.lang.reflect.Field;\r
15 \r
16 import org.apache.log4j.Logger;\r
17 import org.simantics.objmap.exceptions.MappingException;\r
18 \r
19 \r
20 /**\r
21  * Accesses the given field of the element.\r
22  * @author Hannu Niemistö\r
23  */\r
24 public class FieldAccessor<Range,T> implements IRangeAccessor<Range,T> {\r
25     \r
26     static Logger LOGGER = Logger.getLogger("org.simantics.objmap");\r
27     \r
28         Field field;\r
29 \r
30         public FieldAccessor(Field field) {\r
31                 this.field = field;\r
32         }\r
33 \r
34         @Override\r
35         public T get(Range element) throws MappingException {\r
36                 try {\r
37                     @SuppressWarnings("unchecked")\r
38                         T result = (T)field.get(element);\r
39                     \r
40                 if(LOGGER.isInfoEnabled())\r
41                     LOGGER.info("        FieldAccessor.get " +\r
42                             field.getName() + " -> " + result\r
43                     );\r
44                 \r
45                         return result;\r
46                 } catch (IllegalArgumentException e) {\r
47                         throw new MappingException(e);\r
48                 } catch (IllegalAccessException e) {\r
49                         throw new MappingException(e);\r
50                 }\r
51         }\r
52 \r
53         @Override\r
54         public boolean set(Range element, T value) throws MappingException {\r
55                 try {\r
56                         Object currentValue = field.get(element);\r
57                         \r
58             if(LOGGER.isInfoEnabled())\r
59                 LOGGER.info("        FieldAccessor.set " +\r
60                         field.getName() + " " + currentValue +  \r
61                         " -> " + value\r
62                 );\r
63                         \r
64                         if(value == null \r
65                                 ? (currentValue == null || field.getType().isPrimitive()) \r
66                                 : value.equals(currentValue))\r
67                                 return false;                   \r
68                         field.set(element, value);\r
69                         return true;\r
70                 } catch (IllegalArgumentException e) {\r
71                         throw new MappingException(e);\r
72                 } catch (IllegalAccessException e) {\r
73                         throw new MappingException(e);\r
74                 }\r
75         }       \r
76 }\r