Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.library / org.gvsig.expressionevaluator / org.gvsig.expressionevaluator.lib / org.gvsig.expressionevaluator.lib.api / src / main / java / org / gvsig / expressionevaluator / ExpressionBuilder.java @ 44568

History | View | Annotate | Download (19.7 KB)

1
package org.gvsig.expressionevaluator;
2

    
3
import java.util.List;
4
import java.util.Map;
5
import org.cresques.cts.IProjection;
6
import org.gvsig.fmap.geom.Geometry;
7
import org.gvsig.fmap.geom.primitive.Envelope;
8
import org.gvsig.tools.util.PropertiesSupport;
9
import org.gvsig.tools.util.PropertiesSupportHelper;
10

    
11
public interface ExpressionBuilder {
12

    
13
    public static final String OPERATOR_NOT = "NOT";
14
    public static final String OPERATOR_NEGATE = "NEGATE";
15
    public static final String OPERATOR_IS = "IS";
16
    public static final String OPERATOR_AND = "AND";
17
    public static final String OPERATOR_OR = "OR";
18
    public static final String OPERATOR_EQ = "=";
19
    public static final String OPERATOR_NE = "<>";
20
    public static final String OPERATOR_GT = ">";
21
    public static final String OPERATOR_GE = ">=";
22
    public static final String OPERATOR_LT = "<";
23
    public static final String OPERATOR_LE = "<=";
24
    public static final String OPERATOR_LIKE = "LIKE";
25
    public static final String OPERATOR_ILIKE = "ILIKE";
26
    public static final String OPERATOR_ADD = "+";
27
    public static final String OPERATOR_SUBST = "-";
28
    public static final String OPERATOR_MULT = "*";
29
    public static final String OPERATOR_DIV = "/";
30
    public static final String OPERATOR_MOD = "%";
31
    public static final String OPERATOR_CONCAT = "||";
32
    public static final String OPERATOR_REGEXP = "~";
33
    public static final String OPERATOR_AND2 = "&&";
34
    
35
    public static final String FUNCTION_ST_SRID = "ST_SRID";
36
    public static final String FUNCTION_ST_ASTEXT = "ST_AsText";
37
    public static final String FUNCTION_ST_ASBINARY = "ST_AsBinary";
38
    public static final String FUNCTION_ST_ASEWKB = "ST_AsEWKB";
39
    public static final String FUNCTION_ST_ENVELOPE = "ST_Envelope";
40
    public static final String FUNCTION_ST_GEOMFROMTEXT = "ST_GeomFromText";
41
    public static final String FUNCTION_ST_GEOMFROMWKB = "ST_GeomFromWKB";
42
    public static final String FUNCTION_ST_GEOMFROMEWKB = "ST_GeomFromEWKB";
43
    public static final String FUNCTION_ST_SIMPLIFY = "ST_Simplify";
44
    public static final String FUNCTION_ST_EQUALS = "ST_Equals";
45
    public static final String FUNCTION_ST_INTERSECTS = "ST_Intersects";
46
    public static final String FUNCTION_ST_CONTAINS = "ST_Contains";
47
    public static final String FUNCTION_ST_DISJOINT = "ST_Disjoint";
48
    public static final String FUNCTION_ST_CROSSES = "ST_Crosses";
49
    public static final String FUNCTION_ST_ISCLOSED = "ST_IsClosed";
50
    public static final String FUNCTION_ST_OVERLAPS = "ST_Overlaps";
51
    public static final String FUNCTION_ST_TOUCHES = "ST_Touches";
52
    public static final String FUNCTION_ST_WITHIN = "ST_Within";
53
    public static final String FUNCTION_ST_SETSRID = "ST_SetSRID";
54
    public static final String FUNCTION_ST_POINT = "ST_Point";
55
    public static final String FUNCTION_ST_MAKEPOINT = "ST_MakePoint";
56
    public static final String FUNCTION_ST_UNIONAGGREGATE = "ST_UnionAggregate";
57
    public static final String FUNCTION_ST_EXTENTAGGREGATE = "ST_ExtentAggregate";
58

    
59
    public static final String FUNCTION_IIF = "IIF";
60
    public static final String FUNCTION_IFNULL = "IFNULL";
61
    
62
    public static final String FUNCTION_LEFT = "LEFT";
63
    public static final String FUNCTION_RIGHT = "RIGHT";
64
    public static final String FUNCTION_LOCATE = "LOCATE";
65
    public static final String FUNCTION_POSITION = "POSITION";
66
    public static final String FUNCTION_LPAD = "LPAD";
67
    public static final String FUNCTION_RPAD = "RPAD";
68
    public static final String FUNCTION_LTRIM = "LTRIM";
69
    public static final String FUNCTION_RTRIM = "RTRIM";
70
    public static final String FUNCTION_TRIM = "TRIM";
71
    public static final String FUNCTION_REPEAT = "REPEAT";
72
    public static final String FUNCTION_REPLACE = "REPLACE";
73
    public static final String FUNCTION_ASCII = "ASCII";
74
    public static final String FUNCTION_LENGHT = "LENGHT";
75
    public static final String FUNCTION_INSTR = "INSTR";
76
    public static final String FUNCTION_LOWER = "LOWER";
77
    public static final String FUNCTION_UPPER = "UPPER";
78
    public static final String FUNCTION_SPACE = "SPACE";
79
    public static final String FUNCTION_SUBSTRING = "SUBSTRING";
80
    public static final String FUNCTION_ACOS = "ACOS";
81
    public static final String FUNCTION_ASIN = "ASIN";
82
    public static final String FUNCTION_ATAN = "ATAN";
83
    public static final String FUNCTION_COS = "COS";
84
    public static final String FUNCTION_COSH = "COSH";
85
    public static final String FUNCTION_COT = "COT";
86
    public static final String FUNCTION_BITAND = "BITAND";
87
    public static final String FUNCTION_BITOR = "BITOR";
88
    public static final String FUNCTION_BITXOR = "BITXOR";
89
    public static final String FUNCTION_CEIL = "CEIL";
90
    public static final String FUNCTION_DEGREES = "DEGREES";
91
    public static final String FUNCTION_EXP = "EXP";
92
    public static final String FUNCTION_FLOOR = "FLOOR";
93
    public static final String FUNCTION_LOG = "LOG";
94
    public static final String FUNCTION_LOG10 = "LOG10";
95
    public static final String FUNCTION_PI = "PI";
96
    public static final String FUNCTION_POWER = "POWER";
97
    public static final String FUNCTION_RADIANS = "RADIANS";
98
    public static final String FUNCTION_RAND = "RAND";
99
    public static final String FUNCTION_ROUND = "ROUND";
100
    public static final String FUNCTION_SQRT = "SQRT";
101
    public static final String FUNCTION_SIGN = "SIGN";
102
    public static final String FUNCTION_SIN = "SIN";
103
    public static final String FUNCTION_SINH = "SINH";
104
    public static final String FUNCTION_TAN = "TAN";
105
    public static final String FUNCTION_TANH = "TANH";
106
    public static final String FUNCTION_ZERO = "ZERO";
107
    public static final String FUNCTION_CHR = "CHR";
108
    public static final String FUNCTION_DATE = "DATE";
109
    public static final String FUNCTION_DATEDIFF = "DATEDIFF";
110
    public static final String FUNCTION_DATEADD = "DATEADD";
111
    public static final String FUNCTION_NOW = "NOW";
112
    public static final String FUNCTION_TIME = "TIME";
113
    public static final String FUNCTION_TIMESTAMP = "TIMESTAMP";
114

    
115
    public static final String FUNCTION_CAST = "CAST";
116
    public static final String FUNCTION_DECODE = "DECODE";
117
    public static final String FUNCTION_TODOUBLE = "TODOUBLE";
118
    public static final String FUNCTION_TOFLOAT = "TOFLOAT";
119
    public static final String FUNCTION_TOINTEGER = "TOINTEGER";
120
    public static final String FUNCTION_TOLONG = "TOLONG";
121
    public static final String FUNCTION_TOSTR = "TOSTR";
122
    
123
    public static final String FUNCTION_INCR = "INCR";
124
    public static final String FUNCTION_DECR = "DECR";
125
    
126
    public static final String FUNCTION_RANGE = "RANGE";
127
    public static final String FUNCTION_EVAL = "EVAL";
128
    public static final String FUNCTION_LIST = "LIST";
129
    public static final String FUNCTION_TUPLE = "TUPLE";
130
    
131
    public enum GeometrySupportType {
132
        WKT,
133
        WKB,
134
        EWKB,
135
        NATIVE
136
    }
137

    
138
    public enum ParameterType {
139
        Variable,
140
        Constant,
141
        Geometry
142
    }
143
    
144
    public interface VisitorFilter {
145
        boolean accept(Visitable visitable);
146
    }
147

    
148
     public interface Visitor {
149
        public void visit(Visitable value);
150
    }
151

    
152
    public interface Visitable {
153
        public void accept(Visitor visitor, VisitorFilter filter);
154
    }
155
        
156
    public interface Value extends Visitable, PropertiesSupport {
157
        public String toString(Formatter<Value> formatter);
158
        public void replace(Value target, Value replacement);
159
    }
160

    
161
    public interface Group extends Value {
162
        public Value value();
163
    }
164

    
165
    public interface Constant extends Value {
166
        public Object value();
167
    }
168

    
169
    public interface Custom extends Value {
170
        public Object value();
171
        public Custom add(Variable variable);
172
        public Custom add(Parameter parameter);
173
    }
174

    
175
    public interface Variable extends Value, Comparable<Variable> {
176
        public String name();
177
    }
178

    
179
    public interface Parameter extends Value {
180
        public Parameter as_constant();
181
        public Parameter as_variable();        
182
        public Parameter as_geometry_variable();
183
        public Parameter srs(Value srs);
184
        public Parameter srs(IProjection srs);
185
        public Parameter value(Object value);
186
        public Parameter name(String value);
187
        public String name();
188
        public Object value();
189
        public ParameterType type();
190
        public Value srs();
191
        public boolean is_constant();
192
        public boolean is_variable();
193
        public boolean is_geometry_variable();        
194
    }
195
    
196
    public interface Function extends Value {
197
        public String name();
198
        public List<Value> parameters();
199
        public Function parameter(Value parameter);
200
    }
201

    
202
    public interface Method extends Value {
203
        public String name();
204
        public Value instance();
205
        public List<Value> parameters();
206
        public Function parameter(Value parameter);
207
    }
208

    
209
    public interface BinaryOperator extends Value {
210
        public String name();
211
        public Value left();
212
        public Value right();
213
        public BinaryOperator left(Value operand);
214
        public BinaryOperator right(Value operand);
215
    }
216

    
217
    public abstract class AbstractValue implements Value {
218

    
219
        private PropertiesSupport properties;
220
        
221
        protected AbstractValue() {
222
            this.properties = new PropertiesSupportHelper();
223
        }
224
        
225
        @Override
226
        public void accept(Visitor visitor, VisitorFilter filter) {
227
            if (filter == null || filter.accept(this)) {
228
                visitor.visit(this);
229
            }
230
        }
231

    
232
        @Override
233
        public Map<String, Object> getProperties() {
234
            return this.properties.getProperties();
235
        }
236

    
237
        @Override
238
        public Object getProperty(String name) {
239
            return this.properties.getProperty(name);
240
        }
241

    
242
        @Override
243
        public void setProperty(String name, Object value) {
244
            this.properties.setProperty(name, value);
245
        }
246

    
247
        @Override
248
        public void replace(Value target, Value replacement) {
249
            // Do nothing
250
        }
251
    }
252

    
253
    public class ClassVisitorFilter implements VisitorFilter {
254

    
255
        private final Class classFilter;
256

    
257
        public ClassVisitorFilter(Class classFilter) {
258
            this.classFilter = classFilter;
259
        }
260

    
261
        @Override
262
        public boolean accept(Visitable visitable) {
263
            if( classFilter==null ) {
264
                return true;
265
            }
266
            return classFilter.isInstance(visitable);
267
        }
268

    
269
    }
270

    
271
    public static final Formatter<Value> EMPTY_FORMATTER = new Formatter<Value>() {
272
        @Override
273
        public boolean canApply(Value value) {
274
            return false;
275
        }
276

    
277
        @Override
278
        public String format(Value value) {
279
            return "";
280
        }
281
    };
282
            
283
    public String quote_for_identifiers();
284
    
285
    public String quote_for_strings();
286
    
287
    public void accept(Visitor visitor, VisitorFilter filter);
288

    
289
    public List<Variable> variables();
290
    
291
    public List<String> variables_names();
292
    
293
    public List<Parameter> parameters();
294
    
295
    public List<String> parameters_names();
296
    
297
    public GeometrySupportType geometry_support_type();
298
    
299
    public ExpressionBuilder geometry_support_type(GeometrySupportType geometrySupportType);
300

    
301
    public String identifier(String name);
302

    
303
    public String bytearray_hex(byte[] data);
304

    
305
    public String bytearray_0x(byte[] data);
306

    
307
    public String bytearray_x(byte[] data);
308

    
309
    public String string(String s);
310
   
311
    public Object srs_id(IProjection projection);
312
    
313
    public Value value();
314
    
315
    public ExpressionBuilder value(Value value);
316

    
317
    public Group group(Value group);
318
    
319
    public Constant bytearray(byte[] data);
320
    
321
    public Variable variable(String name);
322
    
323
    public Variable column(String name); // Alias for variable(name)
324

    
325
    public Parameter parameter(String name);
326

    
327
    public Parameter parameter();
328

    
329
    public Constant constant(Object value);
330
    
331
    public Constant geometry(Geometry geom, IProjection projection);
332

    
333
    public Constant geometry(Geometry geom);
334

    
335
    public Constant envelope(Envelope envelope, IProjection projection);
336

    
337
    public Constant envelope(Envelope envelope);
338

    
339
    public Constant srs(IProjection projection);
340

    
341
    public Custom custom(Object value);
342
    
343
    public Function as_geometry(Value value);
344

    
345
    public Method method(Value instance, String name, Value... values);
346

    
347
    public Function function(String name, Value... values);
348
    
349
    public BinaryOperator binaryOperator(String name, Value leftOperand, Value rightOperand);
350

    
351
    public Value toValue(String expression);
352
    
353
    public String toString(Formatter<Value> formatter);
354
    
355
    public Function not(Value value);
356

    
357
    public Function not_is_null(Value value);
358
    
359
    public Function is_null(Value value);
360

    
361
    
362
    public Function ST_Area(Value geom);
363

    
364
    public Function ST_AsBinary(Value geom);
365

    
366
    public Function ST_AsEWKB(Value geom);
367

    
368
    public Function ST_AsText(Value geom);
369

    
370
    public Function ST_Buffer(Value geom);
371

    
372
    public Function ST_Buffer(Value geom, Value dist);
373

    
374
    public Function ST_Centroid(Value geom);
375

    
376
    public Function ST_Contains(Value geom1, Value geom2);
377

    
378
    public Function ST_CoveredBy(Value geom1, Value geom2);
379

    
380
    public Function ST_Covers(Value geom1, Value geom2);
381

    
382
    public Function ST_Crosses(Value geom1, Value geom2);
383

    
384
    public Function ST_Diference(Value geom1, Value geom2);
385

    
386
    public Function ST_Dimension(Value geom1);
387

    
388
    public Function ST_Disjoint(Value geom1, Value geom2);
389

    
390
    public Function ST_Distance(Value geom1, Value geom2);
391

    
392
    public Function ST_EndPoint(Value geom1);
393

    
394
    public Function ST_Envelope(Value geom);
395

    
396
    public Function ST_Equals(Value geom1, Value geom2);
397

    
398
    public Function ST_GeomFromText(Value geom, Value crs);
399
    
400
    public Function ST_GeomFromWKB(Value geom, Value crs);
401
            
402
    public Function ST_GeomFromEWKB(Value geom, Value crs);
403

    
404
    public Function ST_Intersection(Value geom1, Value geom2);
405

    
406
    public Function ST_Intersects(Value geom1, Value geom2);
407

    
408
    public Function ST_IsClosed(Value geom);
409

    
410
    public Function ST_IsSimple(Value geom);
411

    
412
    public Function ST_IsValid(Value geom);
413

    
414
    public Function ST_NumGeometries(Value geom);
415
    
416
    public Function ST_NumPoints(Value geom);
417

    
418
    public Function ST_Overlaps(Value geom1, Value geom2);
419

    
420
    public Function ST_Perimeter(Value geom);
421

    
422
    public Function ST_Point(Value x, Value y);
423

    
424
    public Function ST_MakePoint(Value x, Value y);
425

    
426
    public Function ST_MakePoint(Value x, Value y, Value z);
427

    
428
    public Function ST_MakePoint(Value x, Value y, Value z, Value m);
429

    
430
    public Function ST_PointN(Value geom, Value n);
431

    
432
    public Function ST_SRID(Value geom);
433

    
434
    public Function ST_SetSRID(Value geom, Value srid);
435
    
436
    public Function ST_StartPoint(Value geom);
437

    
438
    public Function ST_Simplify(Value geom, Value tolerance);
439

    
440
    public Function ST_Touches(Value geom1, Value geom2);
441

    
442
    public Function ST_Union(Value geom1, Value geom2);
443

    
444
    public Function ST_Within(Value geom1, Value geom2);
445

    
446
    public Function ST_X(Value geom);
447

    
448
    public Function ST_Y(Value geom);
449

    
450
    public Function ST_Z(Value geom);
451

    
452
    
453
    public Function ST_UnionAggregate(Value geom);
454
    
455
    public Function ST_ExtentAggregate(Value geom);
456

    
457

    
458
    
459
    public BinaryOperator and(Value op1, Value op2);
460

    
461
    public BinaryOperator and(Expression op1, Expression op2);
462

    
463
    public BinaryOperator and(Expression op1, Value op2);
464

    
465
    public BinaryOperator or(Value op1, Value op2);
466

    
467
    public BinaryOperator eq(Value op1, Value op2);
468
    
469
    public BinaryOperator ne(Value op1, Value op2);
470
    
471
    public BinaryOperator gt(Value op1, Value op2);
472
    
473
    public BinaryOperator ge(Value op1, Value op2);
474

    
475
    public BinaryOperator lt(Value op1, Value op2);
476
    
477
    public BinaryOperator le(Value op1, Value op2);
478

    
479
    public BinaryOperator like(Value op1, Value op2);
480

    
481
    public BinaryOperator ilike(Value op1, Value op2);
482

    
483
    public BinaryOperator add(Value op1, Value op2);
484

    
485
    public BinaryOperator subst(Value op1, Value op2);
486

    
487
    public BinaryOperator mult(Value op1, Value op2);
488

    
489
    public BinaryOperator div(Value op1, Value op2);
490

    
491
    public BinaryOperator concat(Value op1, Value op2);
492

    
493
    public ExpressionBuilder set(Value value);
494
    
495
    public ExpressionBuilder and(Value value);
496

    
497
    public ExpressionBuilder or(Value value);
498

    
499
    public Function iif(Value condition, Value iftrue, Value iffalse);
500
    
501
    public Function ifnull(Value value, Value iftrue, Value iffalse);
502

    
503
    public ExpressionBuilder createExpressionBuilder();
504
   
505
    public Function left(Value str, Value size);
506
    
507
    public Function right(Value str, Value len);
508
    
509
    public Function locate(Value search, Value str, Value start) ;
510
    
511
    public Function position(Value search, Value str);
512
    
513
    public Function lpad(Value str, Value len, Value padstr) ;
514
    
515
    public Function rpad(Value str, Value len, Value padstr);
516
    
517
    public Function ltrim(Value str);
518
    
519
    public Function rtrim(Value str);
520
    
521
    public Function trim(Value str);
522
    
523
    public Function repeat(Value str, Value size);
524
    
525
    public Function replace(Value str, Value search, Value replstr);
526
    
527
    public Function ascii(Value str);
528
    
529
    public Function lenght(Value str);
530

    
531
    public Function instr(Value str, Value search, Value start);
532
    
533
    public Function lower(Value str);
534
    
535
    public Function upper(Value str);
536
    
537
    public Function space(Value size);
538
    
539
    public Function substring(Value str, Value start, Value len);
540
    
541
    public Function acos(Value num);
542
    
543
    public Function asin(Value num);
544
    
545
    public Function atan(Value num);
546
    
547
    public Function cos(Value num);
548
    
549
    public Function cosh(Value num);
550
    
551
    public Function cot(Value num);
552
    
553
    public Function bitand(Value num1, Value num2);
554
    
555
    public Function bitor(Value num1, Value num2);
556
    
557
    public Function bitxor(Value num1, Value num2);
558
    
559
    public Function ceil(Value num);
560
    
561
    public Function degrees(Value num);
562
    
563
    public Function exp(Value num);
564
    
565
    public Function floor(Value num);
566
    
567
    public Function log(Value num);
568
    
569
    public Function log10(Value num);
570
    
571
    public Function pi(Value num);
572
    
573
    public Function power(Value num);
574
    
575
    public Function radians(Value num);
576
    
577
    public Function rand(Value num);
578
    
579
    public Function round(Value num);
580
    
581
    public Function sqrt(Value num);
582
    
583
    public Function sign(Value num);
584
    
585
    public Function sin(Value num);
586
    
587
    public Function sinh(Value num);
588
    
589
    public Function tan(Value num);
590
    
591
    public Function tanh(Value num);
592
    
593
    public Function zero();
594
    
595
    public Function chr(Value num);
596

    
597
    public Function decode(Value value, Value format);
598

    
599
    public Function cast(Value object, Value typeName);
600

    
601
    public Function toDouble(Value object);
602

    
603
    public Function toFloat(Value object);
604

    
605
    public Function toLong(Value object);
606

    
607
    public Function toInteger(Value object);
608

    
609
    public Function toStr(Value object);
610

    
611
    public Function list();
612
    
613
    public Function tuple();
614
    
615
    public Function tuple(Constant... values);
616
    
617
    public boolean isEmpty();
618
}