Updated Replace by Expression

git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-expression-widget@100026 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Giancarlo Panichi 2014-09-18 15:46:32 +00:00
parent 33cefe2f32
commit 0d1d8c0e78
1 changed files with 219 additions and 265 deletions

View File

@ -1,6 +1,5 @@
package org.gcube.portlets.user.td.expressionwidget.shared.model;
import java.util.ArrayList;
import java.util.List;
import org.gcube.portlets.user.td.expressionwidget.shared.model.composite.comparable.C_Equals;
@ -16,7 +15,6 @@ import org.gcube.portlets.user.td.expressionwidget.shared.model.composite.text.C
import org.gcube.portlets.user.td.expressionwidget.shared.model.composite.text.C_TextEndsWith;
import org.gcube.portlets.user.td.expressionwidget.shared.model.composite.text.C_TextMatchSQLRegexp;
import org.gcube.portlets.user.td.expressionwidget.shared.model.leaf.C_ColumnReferencePlaceholder;
import org.gcube.portlets.user.td.expressionwidget.shared.model.leaf.C_ConstantList;
import org.gcube.portlets.user.td.expressionwidget.shared.model.leaf.C_Range;
import org.gcube.portlets.user.td.expressionwidget.shared.model.leaf.C_TypedColumnReference;
import org.gcube.portlets.user.td.expressionwidget.shared.model.leaf.TD_Value;
@ -33,13 +31,11 @@ import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnTypeM
import com.allen_sauer.gwt.log.client.Log;
/**
* OperatorTypeMap creates a C_Expression usable client-side
*
* @author "Giancarlo Panichi"
* <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
* @author "Giancarlo Panichi" <a
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
*
*/
public class OperatorTypeMap {
@ -49,34 +45,36 @@ public class OperatorTypeMap {
}
public C_Expression map(ColumnData column,C_OperatorType operatorType, String firstArg, String secondArg){
public C_Expression map(ColumnData column, C_OperatorType operatorType,
String firstArg, String secondArg) {
Log.debug("OperatorTypeMap Map");
C_Expression exp = null;
readableExpression = new String();
if (column.getTrId() == null) {
exp = mapPlaceHolder(column, operatorType, firstArg, secondArg);
} else {
exp=mapTypedColumnReference(column,operatorType,firstArg,secondArg);
exp = mapTypedColumnReference(column, operatorType, firstArg,
secondArg);
}
return exp;
}
public C_Expression mapPlaceHolder(ColumnData column,C_OperatorType operatorType, String firstArg, String secondArg){
public C_Expression mapPlaceHolder(ColumnData column,
C_OperatorType operatorType, String firstArg, String secondArg) {
Log.debug("OperatorTypeMap Map Place Holder");
C_Expression exp = null;
Log.debug("Column Data Type Name:" + column.getDataTypeName());
ColumnDataType dataType=ColumnTypeMap.getColumnDataType(column.getDataTypeName());
ColumnDataType dataType = ColumnTypeMap.getColumnDataType(column
.getDataTypeName());
Log.debug("Data Type:" + dataType);
C_ColumnReferencePlaceholder placeHolder=new C_ColumnReferencePlaceholder(dataType
, column.getColumnId());
C_ColumnReferencePlaceholder placeHolder = new C_ColumnReferencePlaceholder(
dataType, column.getColumnId());
Log.debug("placeHolder:" + placeHolder);
String readablePlaceHolder = column.getColumnId();
List<TD_Value> arguments=new ArrayList<TD_Value>();
TD_Value fArg;
TD_Value sArg;
C_Range range;
int separator;
switch (operatorType) {
case ADDITION:
@ -88,66 +86,52 @@ public class OperatorTypeMap {
case ANY:
break;
case BEGINS_WITH:
exp=new C_TextBeginsWith(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="Begins("+readablePlaceHolder+", "+firstArg+")";
exp = new C_TextBeginsWith(placeHolder, new TD_Value(dataType,
firstArg));
readableExpression = "Begins(" + readablePlaceHolder + ", "
+ firstArg + ")";
break;
case BETWEEN:
fArg = new TD_Value(dataType, firstArg);
sArg = new TD_Value(dataType, secondArg);
range = new C_Range(fArg, sArg);
exp = new C_Between(placeHolder, range);
readableExpression="Between("+readablePlaceHolder+", Range("+firstArg+", "+secondArg+"))";
readableExpression = "Between(" + readablePlaceHolder + ", Range("
+ firstArg + ", " + secondArg + "))";
break;
case CONTAINS:
separator=firstArg.indexOf(",");
if(separator==-1|| firstArg.length()==1){
arguments.add(new TD_Value(dataType,firstArg));
} else {
String arg;
boolean end=false;
while(!end){
arg=firstArg.substring(0, separator);
arguments.add(new TD_Value(dataType,arg));
separator++;
if(separator<firstArg.length()){
firstArg=firstArg.substring(separator,firstArg.length());
separator=firstArg.indexOf(",");
if(separator==-1){
arguments.add(new TD_Value(dataType,firstArg));
end=true;
}
} else {
end=true;
}
}
}
exp=new C_TextContains(placeHolder,new C_ConstantList(arguments));
readableExpression="Contains("+readablePlaceHolder;
for(TD_Value v:arguments){
readableExpression+=", "+v.getValue();
}
readableExpression+=")";
fArg = new TD_Value(dataType, firstArg);
exp = new C_TextContains(placeHolder, fArg);
readableExpression = "Contains(" + readablePlaceHolder + ", "
+ firstArg + ")";
break;
case DIVISION:
break;
case ENDS_WITH:
exp=new C_TextEndsWith(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="TextEndsWith("+readablePlaceHolder+","+firstArg+")";
exp = new C_TextEndsWith(placeHolder, new TD_Value(dataType,
firstArg));
readableExpression = "TextEndsWith(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case EQUALS:
exp = new C_Equals(placeHolder, new TD_Value(dataType, firstArg));
readableExpression="Equals("+readablePlaceHolder+","+firstArg+")";
readableExpression = "Equals(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case EXISTS:
// exp=new C_Exi(placeHolder,new C_ConstantList(arguments));
break;
case GREATER:
exp=new C_GreaterThan(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="GreaterThan("+readablePlaceHolder+","+firstArg+")";
exp = new C_GreaterThan(placeHolder, new TD_Value(dataType,
firstArg));
readableExpression = "GreaterThan(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case GREATER_OR_EQUALS:
exp=new C_GreaterOrEquals(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="GreaterOrEquals("+readablePlaceHolder+","+firstArg+")";
exp = new C_GreaterOrEquals(placeHolder, new TD_Value(dataType,
firstArg));
readableExpression = "GreaterOrEquals(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case IN:
break;
@ -161,17 +145,22 @@ public class OperatorTypeMap {
break;
case LESSER:
exp = new C_LessThan(placeHolder, new TD_Value(dataType, firstArg));
readableExpression="LessThan("+readablePlaceHolder+","+firstArg+")";
readableExpression = "LessThan(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case LESSER_OR_EQUALS:
exp=new C_LessOrEquals(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="LessOrEquals("+readablePlaceHolder+","+firstArg+")";
exp = new C_LessOrEquals(placeHolder, new TD_Value(dataType,
firstArg));
readableExpression = "LessOrEquals(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case LIKE:
break;
case MATCH_REGEX:
exp=new C_TextMatchSQLRegexp(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="TextMatchSQLRegexp("+readablePlaceHolder+","+firstArg+")";
exp = new C_TextMatchSQLRegexp(placeHolder, new TD_Value(dataType,
firstArg));
readableExpression = "TextMatchSQLRegexp(" + readablePlaceHolder
+ "," + firstArg + ")";
break;
case MODULUS:
break;
@ -180,9 +169,11 @@ public class OperatorTypeMap {
case NOT:
break;
case NOT_BEGINS_WITH:
exp=new C_TextBeginsWith(placeHolder, new TD_Value(dataType,firstArg));
exp = new C_TextBeginsWith(placeHolder, new TD_Value(dataType,
firstArg));
exp = new C_Not(exp);
readableExpression="Not(TextBeginsWith("+readablePlaceHolder+","+firstArg+"))";
readableExpression = "Not(TextBeginsWith(" + readablePlaceHolder
+ "," + firstArg + "))";
break;
case NOT_BETWEEN:
fArg = new TD_Value(dataType, firstArg);
@ -190,64 +181,49 @@ public class OperatorTypeMap {
range = new C_Range(fArg, sArg);
exp = new C_Between(placeHolder, range);
exp = new C_Not(exp);
readableExpression="Not(Between("+readablePlaceHolder+", Range("+firstArg+", "+secondArg+")))";
readableExpression = "Not(Between(" + readablePlaceHolder
+ ", Range(" + firstArg + ", " + secondArg + ")))";
break;
case NOT_CONTAINS:
separator=firstArg.indexOf(",");
if(separator==-1|| firstArg.length()==1){
arguments.add(new TD_Value(dataType,firstArg));
} else {
String arg;
boolean end=false;
while(!end){
arg=firstArg.substring(0, separator);
arguments.add(new TD_Value(dataType,arg));
separator++;
if(separator<firstArg.length()){
firstArg=firstArg.substring(separator,firstArg.length());
separator=firstArg.indexOf(",");
if(separator==-1){
arguments.add(new TD_Value(dataType,firstArg));
end=true;
}
} else {
end=true;
}
}
}
exp=new C_TextContains(placeHolder,new C_ConstantList(arguments));
fArg = new TD_Value(dataType, firstArg);
exp = new C_TextContains(placeHolder, fArg);
exp = new C_Not(exp);
readableExpression="Not(Contains("+readablePlaceHolder;
for(TD_Value v:arguments){
readableExpression+=", "+v.getValue();
}
readableExpression+="))";
readableExpression = "Not(Contains(" + readablePlaceHolder + ", "
+ firstArg + "))";
break;
case NOT_ENDS_WITH:
exp=new C_TextEndsWith(placeHolder,new TD_Value(dataType,firstArg));
exp = new C_TextEndsWith(placeHolder, new TD_Value(dataType,
firstArg));
exp = new C_Not(exp);
readableExpression="Not(TextEndsWith("+readablePlaceHolder+","+firstArg+"))";
readableExpression = "Not(TextEndsWith(" + readablePlaceHolder
+ "," + firstArg + "))";
break;
case NOT_EQUALS:
exp = new C_NotEquals(placeHolder, new TD_Value(dataType, firstArg));
readableExpression="NotEquals("+readablePlaceHolder+","+firstArg+")";
readableExpression = "NotEquals(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case NOT_GREATER:
exp=new C_NotGreater(placeHolder,new TD_Value(dataType,firstArg));
readableExpression="NotGreater("+readablePlaceHolder+","+firstArg+")";
exp = new C_NotGreater(placeHolder,
new TD_Value(dataType, firstArg));
readableExpression = "NotGreater(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case NOT_IN:
break;
case NOT_LESSER:
exp = new C_NotLess(placeHolder, new TD_Value(dataType, firstArg));
readableExpression="NotLess("+readablePlaceHolder+","+firstArg+")";
readableExpression = "NotLess(" + readablePlaceHolder + ","
+ firstArg + ")";
break;
case NOT_LIKE:
break;
case NOT_MATCH_REGEX:
exp=new C_TextMatchSQLRegexp(placeHolder,new TD_Value(dataType,firstArg));
exp = new C_TextMatchSQLRegexp(placeHolder, new TD_Value(dataType,
firstArg));
exp = new C_Not(exp);
readableExpression="Not(TextMatchSQLRegexp("+readablePlaceHolder+","+firstArg+"))";
readableExpression = "Not(TextMatchSQLRegexp("
+ readablePlaceHolder + "," + firstArg + "))";
break;
case OR:
break;
@ -264,26 +240,23 @@ public class OperatorTypeMap {
return exp;
}
public C_Expression mapTypedColumnReference(ColumnData column,C_OperatorType operatorType, String firstArg, String secondArg){
public C_Expression mapTypedColumnReference(ColumnData column,
C_OperatorType operatorType, String firstArg, String secondArg) {
Log.debug("OperatorTypeMap Map Typed Column Reference");
C_Expression exp = null;
Log.debug("Column Data Type Name:" + column.getDataTypeName());
ColumnDataType dataType=ColumnTypeMap.getColumnDataType(column.getDataTypeName());
ColumnDataType dataType = ColumnTypeMap.getColumnDataType(column
.getDataTypeName());
Log.debug("Data Type:" + dataType);
C_TypedColumnReference columnReference=new C_TypedColumnReference(column.getTrId(), dataType
, column.getColumnId());
C_TypedColumnReference columnReference = new C_TypedColumnReference(
column.getTrId(), dataType, column.getColumnId());
Log.debug("Typed Column Reference:" + columnReference);
String readableColumnReference = column.getLabel();
List<TD_Value> arguments=new ArrayList<TD_Value>();
TD_Value fArg;
TD_Value sArg;
C_Range range;
int separator;
switch (operatorType) {
case ADDITION:
@ -295,66 +268,53 @@ public class OperatorTypeMap {
case ANY:
break;
case BEGINS_WITH:
exp=new C_TextBeginsWith(columnReference,new TD_Value(dataType,firstArg));
readableExpression="TextBeginsWith("+readableColumnReference+","+firstArg+")";
exp = new C_TextBeginsWith(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "TextBeginsWith(" + readableColumnReference
+ "," + firstArg + ")";
break;
case BETWEEN:
fArg = new TD_Value(dataType, firstArg);
sArg = new TD_Value(dataType, secondArg);
range = new C_Range(fArg, sArg);
exp = new C_Between(columnReference, range);
readableExpression="Between("+readableColumnReference+", Range("+firstArg+", "+secondArg+"))";
readableExpression = "Between(" + readableColumnReference
+ ", Range(" + firstArg + ", " + secondArg + "))";
break;
case CONTAINS:
separator=firstArg.indexOf(",");
if(separator==-1|| firstArg.length()==1){
arguments.add(new TD_Value(dataType,firstArg));
} else {
String arg;
boolean end=false;
while(!end){
arg=firstArg.substring(0, separator);
arguments.add(new TD_Value(dataType,arg));
separator++;
if(separator<firstArg.length()){
firstArg=firstArg.substring(separator,firstArg.length());
separator=firstArg.indexOf(",");
if(separator==-1){
arguments.add(new TD_Value(dataType,firstArg));
end=true;
}
} else {
end=true;
}
}
}
exp=new C_TextContains(columnReference,new C_ConstantList(arguments));
readableExpression="Contains("+readableColumnReference;
for(TD_Value v:arguments){
readableExpression+=", "+v.getValue();
}
readableExpression+=")";
fArg = new TD_Value(dataType, firstArg);
exp = new C_TextContains(columnReference, fArg);
readableExpression = "Contains(" + columnReference + ", "
+ firstArg + ")";
break;
case DIVISION:
break;
case ENDS_WITH:
exp=new C_TextEndsWith(columnReference,new TD_Value(dataType,firstArg));
readableExpression="TextEndsWith("+readableColumnReference+", "+firstArg+")";
exp = new C_TextEndsWith(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "TextEndsWith(" + readableColumnReference
+ ", " + firstArg + ")";
break;
case EQUALS:
exp=new C_Equals(columnReference,new TD_Value(dataType,firstArg));
readableExpression="Equals("+readableColumnReference+", "+firstArg+")";
exp = new C_Equals(columnReference,
new TD_Value(dataType, firstArg));
readableExpression = "Equals(" + readableColumnReference + ", "
+ firstArg + ")";
break;
case EXISTS:
// exp=new C_Exi(placeHolder,new C_ConstantList(arguments));
break;
case GREATER:
exp=new C_GreaterThan(columnReference,new TD_Value(dataType,firstArg));
readableExpression="GreaterThan("+readableColumnReference+", "+firstArg+")";
exp = new C_GreaterThan(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "GreaterThan(" + readableColumnReference
+ ", " + firstArg + ")";
break;
case GREATER_OR_EQUALS:
exp=new C_GreaterOrEquals(columnReference,new TD_Value(dataType,firstArg));
readableExpression="GreaterOrEquals("+readableColumnReference+", "+firstArg+")";
exp = new C_GreaterOrEquals(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "GreaterOrEquals(" + readableColumnReference
+ ", " + firstArg + ")";
break;
case IN:
break;
@ -367,18 +327,24 @@ public class OperatorTypeMap {
readableExpression = "IsNull(" + readableColumnReference + ")";
break;
case LESSER:
exp=new C_LessThan(columnReference,new TD_Value(dataType,firstArg));
readableExpression="LessThan("+readableColumnReference+", "+firstArg+")";
exp = new C_LessThan(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "LessThan(" + readableColumnReference + ", "
+ firstArg + ")";
break;
case LESSER_OR_EQUALS:
exp=new C_LessOrEquals(columnReference,new TD_Value(dataType,firstArg));
readableExpression="LessOrEquals("+readableColumnReference+", "+firstArg+")";
exp = new C_LessOrEquals(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "LessOrEquals(" + readableColumnReference
+ ", " + firstArg + ")";
break;
case LIKE:
break;
case MATCH_REGEX:
exp=new C_TextMatchSQLRegexp(columnReference,new TD_Value(dataType,firstArg));
readableExpression="TextMatchSQLRegexp("+readableColumnReference+", "+firstArg+")";
exp = new C_TextMatchSQLRegexp(columnReference, new TD_Value(
dataType, firstArg));
readableExpression = "TextMatchSQLRegexp("
+ readableColumnReference + ", " + firstArg + ")";
break;
case MODULUS:
break;
@ -387,9 +353,11 @@ public class OperatorTypeMap {
case NOT:
break;
case NOT_BEGINS_WITH:
exp=new C_TextBeginsWith(columnReference,new TD_Value(dataType,firstArg));
exp = new C_TextBeginsWith(columnReference, new TD_Value(dataType,
firstArg));
exp = new C_Not(exp);
readableExpression="Not(TextBeginsWith("+readableColumnReference+", "+firstArg+"))";
readableExpression = "Not(TextBeginsWith("
+ readableColumnReference + ", " + firstArg + "))";
break;
case NOT_BETWEEN:
fArg = new TD_Value(dataType, firstArg);
@ -397,64 +365,51 @@ public class OperatorTypeMap {
range = new C_Range(fArg, sArg);
exp = new C_Between(columnReference, range);
exp = new C_Not(exp);
readableExpression="Not(Between("+readableColumnReference+", Range("+firstArg+", "+secondArg+")))";
readableExpression = "Not(Between(" + readableColumnReference
+ ", Range(" + firstArg + ", " + secondArg + ")))";
break;
case NOT_CONTAINS:
separator=firstArg.indexOf(",");
if(separator==-1|| firstArg.length()==1){
arguments.add(new TD_Value(dataType,firstArg));
} else {
String arg;
boolean end=false;
while(!end){
arg=firstArg.substring(0, separator);
arguments.add(new TD_Value(dataType,arg));
separator++;
if(separator<firstArg.length()){
firstArg=firstArg.substring(separator,firstArg.length());
separator=firstArg.indexOf(",");
if(separator==-1){
arguments.add(new TD_Value(dataType,firstArg));
end=true;
}
} else {
end=true;
}
}
}
exp=new C_TextContains(columnReference,new C_ConstantList(arguments));
fArg = new TD_Value(dataType, firstArg);
exp = new C_TextContains(columnReference, fArg);
exp = new C_Not(exp);
readableExpression="Not(Contains("+readableColumnReference;
for(TD_Value v:arguments){
readableExpression+=", "+v.getValue();
}
readableExpression+="))";
readableExpression = "Not(Contains(" + columnReference + ", "
+ firstArg + "))";
break;
case NOT_ENDS_WITH:
exp=new C_TextEndsWith(columnReference,new TD_Value(dataType,firstArg));
exp = new C_TextEndsWith(columnReference, new TD_Value(dataType,
firstArg));
exp = new C_Not(exp);
readableExpression="Not(TextEndsWith("+readableColumnReference+","+firstArg+"))";
readableExpression = "Not(TextEndsWith(" + readableColumnReference
+ "," + firstArg + "))";
break;
case NOT_EQUALS:
exp=new C_NotEquals(columnReference,new TD_Value(dataType,firstArg));
readableExpression="NotEquals("+readableColumnReference+","+firstArg+")";
exp = new C_NotEquals(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "NotEquals(" + readableColumnReference + ","
+ firstArg + ")";
break;
case NOT_GREATER:
exp=new C_NotGreater(columnReference,new TD_Value(dataType,firstArg));
readableExpression="NotGreater("+readableColumnReference+","+firstArg+")";
exp = new C_NotGreater(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "NotGreater(" + readableColumnReference + ","
+ firstArg + ")";
break;
case NOT_IN:
break;
case NOT_LESSER:
exp=new C_NotLess(columnReference,new TD_Value(dataType,firstArg));
readableExpression="NotLess("+readableColumnReference+","+firstArg+")";
exp = new C_NotLess(columnReference, new TD_Value(dataType,
firstArg));
readableExpression = "NotLess(" + readableColumnReference + ","
+ firstArg + ")";
break;
case NOT_LIKE:
break;
case NOT_MATCH_REGEX:
exp=new C_TextMatchSQLRegexp(columnReference,new TD_Value(dataType,firstArg));
exp = new C_TextMatchSQLRegexp(columnReference, new TD_Value(
dataType, firstArg));
exp = new C_Not(exp);
readableExpression="Not(TextMatchSQLRegexp("+readableColumnReference+","+firstArg+"))";
readableExpression = "Not(TextMatchSQLRegexp("
+ readableColumnReference + "," + firstArg + "))";
break;
case OR:
break;
@ -485,5 +440,4 @@ public class OperatorTypeMap {
return readableExpression;
}
}