source: java/main/src/main/java/com/framsticks/params/ReflectionAccess.java @ 101

Last change on this file since 101 was 101, checked in by psniegowski, 11 years ago

HIGHLIGHTS:

  • improve tree side notes
  • improve GUI layout
  • add foldable list of occured events to EventControl?
  • improve automatic type conversion in proxy listeners
  • implement several Access functionalities as algorithms independent of Access type
  • introduce draft base classes for distributed experiments
  • automatically register dependant Java classes to FramsClass? registry
  • add testing prime experiment and configuration
  • simplify and improve task dispatching

CHANGELOG:
Improve task dispatching in RemoteTree?.

GUI no longer hangs on connection problems.

Make all dispatchers joinables.

Refactorize Thread dispatcher.

Remove Task and PeriodicTask?.

Use Java utilities in those situations.

Reworking tasks dispatching.

Fix bug in EventControl? listener dispatching.

Minor improvements.

Add testing configuration for ExternalProcess? in GUI.

More improvement to prime.

Support for USERREADONLY in GUI.

Add that flag to various params in Java classes.

Remove redundant register clauses from several FramsClassAnnotations?.

Automatically gather and register dependant classes.

Add configuration for prime.

Improve Simulator class.

Add prime.xml configuration.

Introduce draft Experiment and Simulator classes.

Add prime experiment tests.

Enclose typical map with listeners into SimpleUniqueList?.

Needfile works in GUI.

Improve needfile handling in Browser.

More improvement with NeedFile?.

Implementing needfile.

Update test.

Rename ChangeEvent? to TestChangeEvent?.

Automatic argument type search in RemoteTree? listeners.

MultiParamLoader? uses AccessProvider?. By default old implementation
enclosed in AccessStash? or Registry.

Minor changes.

Rename SourceInterface? to Source.

Also improve toString of File and ListSource?.

Remove unused SimpleSource? class.

Add clearing in HistoryControl?.

Show entries in table at EventControl?.

Improve EventControl?.

Add listeners registration to EventControl?.

Add foldable table to HistoryControl?.

Add control row to Procedure and Event controls.

Improve layout of controls.

Another minor change to gui layout.

Minor improvement in the SliderControl?.

Minor changes.

Move ReflectionAccess?.Backend to separate file.

It was to cluttered.

Cleanup in ReflectionAccess?.

Move setMin, setMax, setDef to AccessOperations?.

Extract loading operation into AccessOperations?.

Append Framsticks to name of UnsupportedOperationException?.

The java.lang.UnsupportedOperationException? was shadowing this class.

Rename params.Util to params.ParamsUtil?.

Several improvements.

Minor changes.

Implement revert functionality.

Improve local changes management.

Minor improvement.

Remove methods rendered superfluous after SideNoteKey? improvement.

Improve SideNoteKey?.

It is now generic type, so explicit type specification at
call site is no more needed.

Introduce SideNoteKey? interface.

Only Objects implementing that key may be used as side note keys.

Minor improvements.

Use strings instead of ValueControls? in several gui mappings.

File size: 6.6 KB
Line 
1package com.framsticks.params;
2
3import java.lang.reflect.InvocationTargetException;
4import java.lang.reflect.Method;
5
6
7import org.apache.logging.log4j.Logger;
8import org.apache.logging.log4j.LogManager;
9
10import com.framsticks.params.types.EventParam;
11import com.framsticks.params.types.ProcedureParam;
12import com.framsticks.util.FramsticksException;
13
14import static com.framsticks.util.lang.Containers.*;
15
16/**
17 * The Class ReflectionAccess. Stores data in provided object using reflection.
18 *
19 * @author Mateusz Jarus <name.surname@gmail.com> (please replace name and
20 *         surname with my personal data)
21 *
22 * @author Piotr Sniegowski
23 */
24public class ReflectionAccess extends SimpleAbstractAccess {
25        private final static Logger log = LogManager.getLogger(ReflectionAccess.class.getName());
26
27        protected final Class<?> javaClass;
28        protected final ReflectionAccessBackend backend;
29
30        private Object object;
31
32        public ReflectionAccess(Class<?> javaClass) throws ConstructionException {
33                this(javaClass, FramsClass.build().forClass(javaClass));
34        }
35
36
37        public ReflectionAccess(Class<?> javaClass, FramsClass framsClass) throws ConstructionException {
38                this(javaClass, framsClass, ReflectionAccessBackend.getOrCreateFor(javaClass, framsClass));
39        }
40
41        protected ReflectionAccess(Class<?> javaClass, FramsClass framsClass, ReflectionAccessBackend backend) throws ConstructionException {
42                super(framsClass);
43                this.javaClass = javaClass;
44                this.backend = backend;
45        }
46
47        @Override
48        public ReflectionAccess cloneAccess() {
49                return new ReflectionAccess(javaClass, framsClass, backend);
50        }
51
52        @Override
53        public <T> T get(ValueParam param, Class<T> type) {
54                try {
55                        try {
56                                if (object == null) {
57                                        throw new FramsticksException().msg("no object set");
58                                }
59
60                                return backend.getters.get(param.getId()).get(object, type);
61                        } catch (IllegalAccessException | IllegalArgumentException | InvocationTargetException e) {
62                                throw new FramsticksException().msg("failed to get").cause(e);
63                        }
64                } catch (FramsticksException e) {
65                        throw e.arg("param", param).arg("type", type).arg("access", this);
66                }
67        }
68
69        @Override
70        protected <T> void internalSet(ValueParam param, T value) {
71                setValue(param, value);
72        }
73
74        private <T> void setValue(ValueParam param, T value) {
75                try {
76                        try {
77                                if (object == null) {
78                                        throw new FramsticksException().msg("no object set");
79                                }
80                                ReflectionAccessBackend.ReflectedSetter s = backend.setters.get(param.getId());
81                                if (s == null) {
82                                        throw new FramsticksException().msg("trying to set unsettable");
83                                        // return;
84                                        // if (value != backend.getters.get(param).get(object, Object.class)) {
85                                        // }
86                                }
87                                s.set(object, value);
88                        } catch (IllegalArgumentException | IllegalAccessException | InvocationTargetException e) {
89                                throw new FramsticksException().msg("failed to set").cause(e);
90                        }
91                } catch (FramsticksException e) {
92                        throw e.arg("param", param).arg("value", value).arg("access", this);
93                }
94        }
95
96        @Override
97        public void reg(EventParam param, EventListener<?> listener) {
98                try {
99                        try {
100                                if (object == null) {
101                                        throw new FramsticksException().msg("no object set");
102                                }
103
104                                backend.adders.get(param.getId()).reg(object, listener);
105                                return;
106                        } catch (IllegalAccessException | IllegalArgumentException | InvocationTargetException e) {
107                                throw new FramsticksException().msg("failed to add listener").cause(e);
108                        }
109                } catch (FramsticksException e) {
110                        throw e.arg("param", param).arg("access", this);
111                }
112        }
113
114        @Override
115        public void regRemove(EventParam param, EventListener<?> listener) {
116                try {
117                        try {
118                                if (object == null) {
119                                        throw new FramsticksException().msg("no object set");
120                                }
121
122                                backend.removers.get(param.getId()).regRemove(object, listener);
123                                return;
124                        } catch (IllegalAccessException | IllegalArgumentException | InvocationTargetException e) {
125                                throw new FramsticksException().msg("failed to remove listener").cause(e);
126                        }
127                } catch (FramsticksException e) {
128                        throw e.arg("param", param).arg("access", this);
129                }
130        }
131
132        @Override
133        public Object call(String id, Object[] arguments) {
134                try {
135                        try {
136                                if (object == null) {
137                                        throw new FramsticksException().msg("no object set");
138                                }
139                                ReflectionAccessBackend.ReflectedCaller c = backend.callers.get(id);
140                                if (c == null) {
141                                        throw new FramsticksException().msg("method is not bound");
142                                }
143                                return c.call(object, arguments);
144                        } catch (IllegalArgumentException | IllegalAccessException | InvocationTargetException e) {
145                                throw new FramsticksException().msg("failed to call").cause(e);
146                        }
147                } catch (FramsticksException e) {
148                        throw e.arg("param", framsClass.getParam(id)).arg("access", this);
149                }
150        }
151
152        @Override
153        public Object call(ProcedureParam param, Object[] arguments) {
154                return call(param.getId(), arguments);
155        }
156
157        @Override
158        public void clearValues() {
159                if (object == null) {
160                        return;
161                }
162
163                try {
164                        for (ValueParam p : filterInstanceof(framsClass.getParamEntries(), ValueParam.class)) {
165                                setValue(p, p.getDef(Object.class));
166                        }
167                } catch (IllegalArgumentException ex) {
168                        ex.printStackTrace();
169                }
170        }
171
172        /**
173         * Sets the new object to operate on.
174         *
175         * @param object
176         *            new object to operate on
177         */
178        @Override
179        public ReflectionAccess select(Object object) {
180                this.object = ParamsUtil.selectObjectForAccess(this, object, javaClass);
181                return this;
182        }
183
184        @Override
185        public Object getSelected() {
186                return object;
187        }
188
189        @Override
190        public Object createAccessee() {
191                try {
192                        return javaClass.newInstance();
193                } catch (InstantiationException | IllegalAccessException e) {
194                        throw new FramsticksException().msg("failed to create reflected object").arg("java class", javaClass).arg("frams class", framsClass).cause(e);
195                }
196        }
197
198        @Override
199        public void tryAutoAppend(Object value) {
200                assert object != null;
201                try {
202                        for (Method m : backend.autoAppendMethods) {
203                                if (m.getParameterTypes()[0].isAssignableFrom(value.getClass())) {
204                                        try {
205                                                log.trace("auto appending with value {} with method {}", value, m);
206                                                m.invoke(object, value);
207                                                return;
208                                        } catch (IllegalAccessException | IllegalArgumentException | InvocationTargetException | FramsticksException e) {
209                                                throw new FramsticksException().msg("failed to auto append").cause(e).arg("with method", m);
210                                        }
211                                }
212                        }
213                        throw new FramsticksException().msg("no method found to append");
214                } catch (FramsticksException e) {
215                        throw e.arg("value", value).arg("into object", object);
216                }
217
218        }
219
220        @Override
221        public String toString() {
222                StringBuilder b = new StringBuilder();
223                b.append(framsClass);
224                if (getSelected() != null) {
225                        b.append("(").append(getSelected()).append(")");
226                }
227                return b.toString();
228        }
229}
230
Note: See TracBrowser for help on using the repository browser.