svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.compat.cdc / org.gvsig.fmap.dal / org.gvsig.fmap.dal.db / org.gvsig.fmap.dal.db.h2 / src / main / java / org / gvsig / fmap / dal / store / h2 / expressionbuilderformatter / IsNotNull.java @ 44748
History | View | Annotate | Download (2.32 KB)
1 |
package org.gvsig.fmap.dal.store.h2.expressionbuilderformatter; |
---|---|
2 |
|
3 |
import java.text.MessageFormat; |
4 |
import java.util.List; |
5 |
import org.apache.commons.lang3.StringUtils; |
6 |
import org.apache.commons.lang3.tuple.Pair; |
7 |
import org.gvsig.expressionevaluator.Code.Constant; |
8 |
import org.gvsig.expressionevaluator.ExpressionBuilder.Function; |
9 |
import static org.gvsig.expressionevaluator.ExpressionBuilder.OPERATOR_IS; |
10 |
import static org.gvsig.expressionevaluator.ExpressionBuilder.OPERATOR_NOT; |
11 |
import org.gvsig.expressionevaluator.ExpressionBuilder.Value; |
12 |
import org.gvsig.expressionevaluator.Formatter; |
13 |
import org.gvsig.fmap.dal.SQLBuilder; |
14 |
|
15 |
/**
|
16 |
*
|
17 |
* @author jjdelcerro
|
18 |
*/
|
19 |
class IsNotNull implements Formatter<Value> { |
20 |
|
21 |
private final Formatter<Value> formatter; |
22 |
private final SQLBuilder builder; |
23 |
|
24 |
public IsNotNull(SQLBuilder builder, Formatter<Value> formatter) { |
25 |
this.builder = builder;
|
26 |
this.formatter = formatter;
|
27 |
} |
28 |
|
29 |
@Override
|
30 |
public boolean canApply(Value value_not) { |
31 |
if (value_not instanceof Function) { |
32 |
// NOT( IS( p1, NULL) )
|
33 |
if( StringUtils.equalsIgnoreCase(OPERATOR_NOT, ((Function) value_not).name()) ) {
|
34 |
List<Pair<String,Value>> parameters = ((Function) value_not).parameters(); |
35 |
Value value_is = parameters.get(0).getValue();
|
36 |
if( value_is instanceof Function && StringUtils.equalsIgnoreCase(OPERATOR_IS, ((Function)value_is).name()) ) { |
37 |
List<Pair<String,Value>> parameters_is = ((Function) value_is).parameters(); |
38 |
Value is_p2 = parameters_is.get(1).getValue();
|
39 |
if( is_p2 instanceof Constant && ((Constant)is_p2).value()==null ) { |
40 |
return true; |
41 |
} |
42 |
} |
43 |
} |
44 |
} |
45 |
return false; |
46 |
} |
47 |
|
48 |
@Override
|
49 |
public String format(Value value_not) { |
50 |
// NOT( IS( p1, NULL) )
|
51 |
|
52 |
List<Pair<String,Value>> parameters = ((Function) value_not).parameters(); |
53 |
Value value_is = parameters.get(0).getValue();
|
54 |
List<Pair<String,Value>> parameters_is = ((Function)value_is).parameters(); |
55 |
Value is_p1 = parameters_is.get(0).getValue();
|
56 |
String r = MessageFormat.format( |
57 |
"( ({0}) IS NOT NULL )",
|
58 |
is_p1.toString(formatter) |
59 |
); |
60 |
return r;
|
61 |
} |
62 |
|
63 |
} |