svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.compat.cdc / org.gvsig.fmap.dal / org.gvsig.fmap.dal.impl / src / main / java / org / gvsig / fmap / dal / impl / expressionevaluator / DefaultFeatureAttributeEmulatorExpression.java @ 44149
History | View | Annotate | Download (7.65 KB)
1 |
package org.gvsig.fmap.dal.impl.expressionevaluator; |
---|---|
2 |
|
3 |
import java.util.ArrayList; |
4 |
import java.util.List; |
5 |
import org.apache.commons.lang3.StringUtils; |
6 |
import org.gvsig.expressionevaluator.Code; |
7 |
import org.gvsig.expressionevaluator.Code.Identifier; |
8 |
import org.gvsig.expressionevaluator.Expression; |
9 |
import org.gvsig.fmap.dal.feature.EditableFeature; |
10 |
import org.gvsig.fmap.dal.feature.Feature; |
11 |
import org.gvsig.expressionevaluator.ExpressionEvaluatorLocator; |
12 |
import org.gvsig.expressionevaluator.ExpressionEvaluatorManager; |
13 |
import org.gvsig.expressionevaluator.SymbolTable; |
14 |
import org.gvsig.fmap.dal.DataManager; |
15 |
import org.gvsig.fmap.dal.expressionevaluator.FeatureSymbolTable; |
16 |
import org.gvsig.fmap.dal.feature.FeatureType; |
17 |
import org.gvsig.tools.ToolsLocator; |
18 |
import org.gvsig.tools.dynobject.DynStruct; |
19 |
import org.gvsig.tools.exception.BaseException; |
20 |
import org.gvsig.tools.persistence.PersistenceManager; |
21 |
import org.gvsig.tools.persistence.PersistentState; |
22 |
import org.gvsig.tools.persistence.exception.PersistenceException; |
23 |
import org.gvsig.tools.visitor.VisitCanceledException; |
24 |
import org.gvsig.tools.visitor.Visitor; |
25 |
import org.gvsig.fmap.dal.expressionevaluator.FeatureAttributeEmulatorExpression; |
26 |
import org.gvsig.tools.logger.FilteredLogger; |
27 |
import org.slf4j.Logger; |
28 |
import org.slf4j.LoggerFactory; |
29 |
|
30 |
/**
|
31 |
*
|
32 |
* @author osc
|
33 |
*/
|
34 |
@SuppressWarnings("UseSpecificCatch") |
35 |
public class DefaultFeatureAttributeEmulatorExpression implements FeatureAttributeEmulatorExpression { |
36 |
|
37 |
private static final Logger LOGGER = LoggerFactory.getLogger(DefaultFeatureAttributeEmulatorExpression.class); |
38 |
|
39 |
private static final String EMULEFIELDEXP_PERSISTENCE_DEFINITION_NAME = "EmulatedFieldExpression"; |
40 |
|
41 |
private String[] requiredFields = null; |
42 |
private Expression expression = null; |
43 |
private SymbolTable symbolTable = null; |
44 |
private FeatureSymbolTable featureSymbolTable = null; |
45 |
|
46 |
private boolean valid; |
47 |
private String errorMessage; |
48 |
|
49 |
private FilteredLogger logger;
|
50 |
|
51 |
public DefaultFeatureAttributeEmulatorExpression() {
|
52 |
} |
53 |
|
54 |
public DefaultFeatureAttributeEmulatorExpression(FeatureType featureType, Expression expression) { |
55 |
this.expression = expression;
|
56 |
this.checkVars(featureType);
|
57 |
} |
58 |
|
59 |
private FilteredLogger getLogger() {
|
60 |
if( this.logger == null ) { |
61 |
this.logger = new FilteredLogger(LOGGER, "FeatureAttributeEmulatorExpression", 10); |
62 |
} |
63 |
return this.logger; |
64 |
} |
65 |
|
66 |
private void checkVars(final FeatureType featureType) { |
67 |
this.valid = true; |
68 |
final List<String> theUsedFields = new ArrayList<>(); |
69 |
final List<String> undefinedFields = new ArrayList<>(); |
70 |
|
71 |
try {
|
72 |
Code code = this.expression.getCode();
|
73 |
code.accept(new Visitor() {
|
74 |
@Override
|
75 |
public void visit(Object obj) throws VisitCanceledException, BaseException { |
76 |
Code code = (Code) obj; |
77 |
if (code instanceof Identifier) { |
78 |
String name = ((Identifier) code).name();
|
79 |
if (featureType.get(name) == null) { |
80 |
undefinedFields.add(name); |
81 |
valid = false;
|
82 |
} else {
|
83 |
theUsedFields.add(name); |
84 |
} |
85 |
} |
86 |
} |
87 |
}); |
88 |
if(!undefinedFields.isEmpty()){
|
89 |
this.errorMessage = "undefined fields " + StringUtils.join(undefinedFields,", "); |
90 |
} |
91 |
} catch (Exception ex) { |
92 |
valid = false;
|
93 |
this.errorMessage = ex.getMessage();
|
94 |
} |
95 |
this.requiredFields = theUsedFields.toArray(new String[theUsedFields.size()]); |
96 |
} |
97 |
|
98 |
@Override
|
99 |
public SymbolTable getSymbolTable() {
|
100 |
if (this.symbolTable == null) { |
101 |
ExpressionEvaluatorManager expressionManager = ExpressionEvaluatorLocator.getManager(); |
102 |
this.featureSymbolTable = (FeatureSymbolTable) expressionManager.getSymbolTable(
|
103 |
DataManager.FEATURE_SYMBOL_TABLE |
104 |
); |
105 |
this.symbolTable = expressionManager.createSymbolTable();
|
106 |
this.symbolTable.addSymbolTable(this.featureSymbolTable); |
107 |
} |
108 |
return this.symbolTable; |
109 |
} |
110 |
|
111 |
private FeatureSymbolTable getFeatureSymbolTable() {
|
112 |
if (this.featureSymbolTable == null) { |
113 |
this.getSymbolTable();
|
114 |
} |
115 |
return this.featureSymbolTable; |
116 |
} |
117 |
|
118 |
@Override
|
119 |
public boolean isValid() { |
120 |
return this.valid; |
121 |
} |
122 |
|
123 |
@Override
|
124 |
public Object get(Feature feature) { |
125 |
if (!this.valid) { |
126 |
return null; |
127 |
} |
128 |
this.getFeatureSymbolTable().setFeature(feature);
|
129 |
try {
|
130 |
Object result = this.expression.execute(this.getSymbolTable()); |
131 |
return result;
|
132 |
} catch(Exception ex) { |
133 |
this.getLogger().warn("Problems evaluating expression '"+this.expression.getPhrase()+"' with feature '"+feature.getReference().toString()+"'.", ex); |
134 |
return null; |
135 |
} |
136 |
} |
137 |
|
138 |
@Override
|
139 |
public void set(EditableFeature feature, Object value) { |
140 |
// Do nothing
|
141 |
} |
142 |
|
143 |
@Override
|
144 |
public boolean allowSetting() { |
145 |
return false; |
146 |
} |
147 |
|
148 |
@Override
|
149 |
public String[] getRequiredFieldNames() { |
150 |
return this.requiredFields; |
151 |
} |
152 |
|
153 |
@Override
|
154 |
public Expression getExpression() { |
155 |
return this.expression; |
156 |
} |
157 |
|
158 |
@Override
|
159 |
public String getErrorMessage() { |
160 |
return this.errorMessage; |
161 |
} |
162 |
|
163 |
@Override
|
164 |
public void saveToState(PersistentState state) throws PersistenceException { |
165 |
state.set("fields", this.requiredFields); |
166 |
state.set("expression", this.expression); |
167 |
state.set("valid", this.valid); |
168 |
|
169 |
} |
170 |
|
171 |
@Override
|
172 |
public void loadFromState(PersistentState state) throws PersistenceException { |
173 |
this.valid = state.getBoolean("valid"); |
174 |
this.expression = (Expression) state.get("expression"); |
175 |
this.requiredFields = state.getStringArray("fields"); |
176 |
} |
177 |
|
178 |
@Override
|
179 |
public String toString() { |
180 |
StringBuilder builder = new StringBuilder(); |
181 |
builder.append("{ (").append(StringUtils.right(super.toString(),9)).append(")\n"); |
182 |
builder.append("isValid: ").append(this.isValid()).append(",\n"); |
183 |
builder.append("requiredFields: ").append(StringUtils.join(this.requiredFields)).append(",\n"); |
184 |
builder.append("errorMessage: \"").append(this.errorMessage).append("\",\n"); |
185 |
builder.append("expression: ").append(this.expression).append("\n"); |
186 |
builder.append("}");
|
187 |
return builder.toString();
|
188 |
} |
189 |
|
190 |
public static void registerPersistenceDefinition() { |
191 |
PersistenceManager manager = ToolsLocator.getPersistenceManager(); |
192 |
|
193 |
if (manager.getDefinition(EMULEFIELDEXP_PERSISTENCE_DEFINITION_NAME)
|
194 |
== null) {
|
195 |
DynStruct definition = manager.addDefinition(DefaultFeatureAttributeEmulatorExpression.class, |
196 |
EMULEFIELDEXP_PERSISTENCE_DEFINITION_NAME, |
197 |
EMULEFIELDEXP_PERSISTENCE_DEFINITION_NAME |
198 |
+ " Persistent definition",
|
199 |
null,
|
200 |
null
|
201 |
); |
202 |
definition.addDynFieldObject("expression")
|
203 |
.setMandatory(true)
|
204 |
.setPersistent(true)
|
205 |
.setClassOfValue(Expression.class);
|
206 |
definition.addDynFieldArray("fields")
|
207 |
.setClassOfItems(String.class)
|
208 |
.setMandatory(true)
|
209 |
.setPersistent(true);
|
210 |
definition.addDynFieldBoolean("valid")
|
211 |
.setMandatory(true)
|
212 |
.setPersistent(true);
|
213 |
} |
214 |
} |
215 |
|
216 |
} |