[OLINGO-63] Improve-Lexer-Modes
This commit is contained in:
parent
5e10653b1f
commit
2e622040d1
|
@ -57,6 +57,5 @@ public interface EdmEntityContainer extends EdmNamed {
|
||||||
* @return {@link EdmFunctionImport}
|
* @return {@link EdmFunctionImport}
|
||||||
*/
|
*/
|
||||||
EdmFunctionImport getFunctionImport(String name);
|
EdmFunctionImport getFunctionImport(String name);
|
||||||
|
|
||||||
EdmNamed getElement(String odataIdentifier);
|
|
||||||
}
|
}
|
|
@ -126,9 +126,4 @@ public class EdmEntityContainerImpl extends EdmNamedImpl implements EdmEntityCon
|
||||||
return functionImport;
|
return functionImport;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public EdmNamed getElement(final String odataIdentifier) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,26 +18,32 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
lexer grammar UriLexer;
|
lexer grammar UriLexer;
|
||||||
|
|
||||||
|
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
// Mode "DEFAULT_MODE": Processes everything bevor the first '?' char
|
// Mode "DEFAULT_MODE": Processes everything bevor the first '?' char
|
||||||
// On '?' the next mode "MODE_QUERY" is used
|
// On '?' the next mode "MODE_QUERY" is used
|
||||||
// The percent encoding rules a defined in RFC3986 ABNF rule "path-rootless" apply
|
// The percent encoding rules a defined in RFC3986 ABNF rule "path-rootless" apply
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
QM : '?' -> pushMode(MODE_QUERY);
|
QM : '?' -> pushMode(MODE_QUERY); //first query parameter
|
||||||
|
AMP : '&' -> pushMode(MODE_QUERY); //more query parameters
|
||||||
STRING : '\'' -> more, pushMode(MODE_ODATA_STRING);
|
STRING : '\'' -> more, pushMode(MODE_ODATA_STRING);
|
||||||
|
|
||||||
|
GEOGRAPHY : G E O G R A P H Y SQUOTE -> pushMode(MODE_ODATA_GEO); //TODO make case insensitive
|
||||||
|
GEOMETRY : G E O M E T R Y SQUOTE -> pushMode(MODE_ODATA_GEO);
|
||||||
|
|
||||||
|
//Letters for case insensitivity
|
||||||
fragment A : 'A'|'a';
|
fragment A : 'A'|'a';
|
||||||
fragment B : 'B'|'b';
|
fragment B : 'B'|'b';
|
||||||
fragment D : 'D'|'d';
|
fragment D : 'D'|'d';
|
||||||
fragment E : 'E'|'e';
|
fragment E : 'E'|'e';
|
||||||
fragment F : 'F'|'f';
|
fragment F : 'F'|'f';
|
||||||
fragment G : 'G'|'g';
|
fragment G : 'G'|'g';
|
||||||
|
fragment H : 'H'|'h';
|
||||||
fragment I : 'I'|'i';
|
fragment I : 'I'|'i';
|
||||||
fragment L : 'L'|'l';
|
fragment L : 'L'|'l';
|
||||||
fragment M : 'M'|'m';
|
fragment M : 'M'|'m';
|
||||||
fragment N : 'N'|'n';
|
fragment N : 'N'|'n';
|
||||||
fragment O : 'O'|'o';
|
fragment O : 'O'|'o';
|
||||||
|
fragment P : 'P'|'p';
|
||||||
fragment R : 'R'|'r';
|
fragment R : 'R'|'r';
|
||||||
fragment S : 'S'|'s';
|
fragment S : 'S'|'s';
|
||||||
fragment T : 'T'|'t';
|
fragment T : 'T'|'t';
|
||||||
|
@ -45,6 +51,24 @@ fragment U : 'U'|'u';
|
||||||
fragment Y : 'Y'|'y';
|
fragment Y : 'Y'|'y';
|
||||||
fragment Z : 'Z'|'z';
|
fragment Z : 'Z'|'z';
|
||||||
|
|
||||||
|
//special chars
|
||||||
|
OPEN : '(' | '%28';
|
||||||
|
CLOSE : ')' | '%29';
|
||||||
|
COMMA : ',' | '%2C';
|
||||||
|
SLASH : '/';
|
||||||
|
POINT : '.';
|
||||||
|
AT : '@';
|
||||||
|
EQ : '=' ;
|
||||||
|
STAR : '*';
|
||||||
|
SEMI : ';';
|
||||||
|
FRAGMENT : '#';
|
||||||
|
|
||||||
|
EQ_sq : '=' -> type(EQ);
|
||||||
|
AMP_sq : '&' -> type(AMP), popMode;
|
||||||
|
fragment WS : ( ' ' | '%09' | '%20' | '%09' );
|
||||||
|
WSP : WS+;
|
||||||
|
|
||||||
|
//alpha stuff
|
||||||
fragment ALPHA : 'a'..'z' | 'A'..'Z';
|
fragment ALPHA : 'a'..'z' | 'A'..'Z';
|
||||||
fragment ALPHA_A_TO_F : 'a'..'f' | 'A'..'F';
|
fragment ALPHA_A_TO_F : 'a'..'f' | 'A'..'F';
|
||||||
fragment DIGIT : '0'..'9';
|
fragment DIGIT : '0'..'9';
|
||||||
|
@ -53,7 +77,18 @@ fragment HEXDIG : DIGIT | ALPHA_A_TO_F;
|
||||||
fragment ODI_LEADINGCHARACTER : ALPHA | '_'; //TODO; add Unicode characters from the categories L or Nl
|
fragment ODI_LEADINGCHARACTER : ALPHA | '_'; //TODO; add Unicode characters from the categories L or Nl
|
||||||
fragment ODI_CHARACTER : ALPHA | '_' | DIGIT; //TODO; add Unicode characters from the categories L, Nl, Nd, Mn, Mc, Pc, or Cf
|
fragment ODI_CHARACTER : ALPHA | '_' | DIGIT; //TODO; add Unicode characters from the categories L, Nl, Nd, Mn, Mc, Pc, or Cf
|
||||||
|
|
||||||
|
//helper for date/time values
|
||||||
|
fragment ONE_TO_NINE : '1'..'9';
|
||||||
|
fragment ZERO_TO_FIFTYNINE : ('0'..'5') DIGIT;
|
||||||
|
fragment FRACTIONALSECONDS : DIGIT+;
|
||||||
|
fragment SECOND : ZERO_TO_FIFTYNINE;
|
||||||
|
fragment MINUTE : ZERO_TO_FIFTYNINE;
|
||||||
|
fragment HOUR : ('0' | '1') DIGIT | '2' ( '0'..'3');
|
||||||
|
fragment DAY : '0' '1'..'9' | ('1'|'2') DIGIT | '3' ('0'|'1');
|
||||||
|
fragment MONTH : '0' ONE_TO_NINE | '1' ( '0' | '1' | '2' );
|
||||||
|
fragment YEAR : ('-')? ( '0' DIGIT DIGIT DIGIT | ONE_TO_NINE DIGIT DIGIT DIGIT );
|
||||||
|
|
||||||
|
//tag start with $
|
||||||
BATCH : '$batch';
|
BATCH : '$batch';
|
||||||
ENTITY : '$entity';
|
ENTITY : '$entity';
|
||||||
METADATA : '$metadata';
|
METADATA : '$metadata';
|
||||||
|
@ -65,37 +100,29 @@ VALUE : '$value';
|
||||||
REF : '$ref';
|
REF : '$ref';
|
||||||
COUNT : '$count';
|
COUNT : '$count';
|
||||||
|
|
||||||
|
//inlined query parameters ( e.g. $skip)
|
||||||
|
SKIP_INLINE : '$skip';
|
||||||
|
FILTER_INLINE : '$filter';
|
||||||
|
ORDERBY_INLINE: '$orderby';
|
||||||
|
SEARCH_INLINE : '$search'-> pushMode(MODE_SYSTEM_QUERY_SEARCH);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//rest
|
||||||
NULLVALUE : 'null';
|
NULLVALUE : 'null';
|
||||||
|
|
||||||
OPEN : '(' | '%28';
|
TRUE : 'true';
|
||||||
CLOSE : ')' | '%29';
|
FALSE : 'false';
|
||||||
COMMA : ',' | '%2 SLASH_sqpC';
|
|
||||||
SLASH : '/';
|
|
||||||
POINT : '.';
|
|
||||||
AT : '@';
|
|
||||||
EQ : '=' ;
|
|
||||||
|
|
||||||
BOOLEAN : T R U E | F A L S E;
|
BOOLEAN : T R U E | F A L S E;
|
||||||
SIGN : '+' | '%2B' |'-';
|
PLUS : '+';
|
||||||
|
SIGN : PLUS | '%2B' |'-';
|
||||||
INT : SIGN? DIGITS;
|
INT : SIGN? DIGITS;
|
||||||
DECIMAL : INT '.' DIGITS ('e' SIGN? DIGITS)?;
|
DECIMAL : INT '.' DIGITS ('e' SIGN? DIGITS)?;
|
||||||
|
|
||||||
//primary types
|
//primary types
|
||||||
BINARY : ('X'| B I N A R Y) SQUOTE (HEXDIG HEXDIG)* SQUOTE; //TODO remove 'x' here and in unit tests
|
BINARY : B I N A R Y SQUOTE (HEXDIG HEXDIG)* SQUOTE;
|
||||||
|
|
||||||
fragment ONE_TO_NINE : '1'..'9';
|
|
||||||
fragment ZERO_TO_FIFTYNINE : ('0'..'5') DIGIT;
|
|
||||||
fragment FRACTIONALSECONDS : DIGIT+;
|
|
||||||
fragment SECOND : ZERO_TO_FIFTYNINE;
|
|
||||||
fragment MINUTE : ZERO_TO_FIFTYNINE;
|
|
||||||
fragment HOUR : ('0' | '1') DIGIT | '2' ( '0'..'3');
|
|
||||||
fragment DAY : '0' '1'..'9' | ('1'|'2') DIGIT | '3' ('0'|'1');
|
|
||||||
fragment MONTH : '0' ONE_TO_NINE | '1' ( '0' | '1' | '2' );
|
|
||||||
fragment YEAR : ('-')? ( '0' DIGIT DIGIT DIGIT | ONE_TO_NINE DIGIT DIGIT DIGIT );
|
|
||||||
|
|
||||||
DATE : D A T E SQUOTE YEAR '-' MONTH '-' DAY SQUOTE;
|
DATE : D A T E SQUOTE YEAR '-' MONTH '-' DAY SQUOTE;
|
||||||
DATETIMEOFFSET : D A T E T I M E O F F S E T SQUOTE YEAR '-' MONTH '-' DAY T HOUR ':' MINUTE ( ':' SECOND ( '.' FRACTIONALSECONDS )? )? ( Z | SIGN HOUR ':' MINUTE ) SQUOTE;
|
DATETIMEOFFSET : D A T E T I M E O F F S E T SQUOTE YEAR '-' MONTH '-' DAY T HOUR ':' MINUTE ( ':' SECOND ( '.' FRACTIONALSECONDS )? )? ( Z | SIGN HOUR ':' MINUTE ) SQUOTE;
|
||||||
|
|
||||||
fragment DUSECONDFRAG : DIGITS ('.' DIGITS)? 'S';
|
fragment DUSECONDFRAG : DIGITS ('.' DIGITS)? 'S';
|
||||||
fragment DUTIMEFRAG : 'T' (
|
fragment DUTIMEFRAG : 'T' (
|
||||||
( DIGITS 'H' (DIGITS 'M')? DUSECONDFRAG?)
|
( DIGITS 'H' (DIGITS 'M')? DUSECONDFRAG?)
|
||||||
|
@ -105,7 +132,6 @@ fragment DUTIMEFRAG : 'T' (
|
||||||
fragment DUDAYTIMEFRAG : DIGITS 'D' DUTIMEFRAG? | DUTIMEFRAG;
|
fragment DUDAYTIMEFRAG : DIGITS 'D' DUTIMEFRAG? | DUTIMEFRAG;
|
||||||
DURATION : D U R A T I O N SQUOTE '-'? 'P' DUDAYTIMEFRAG SQUOTE;
|
DURATION : D U R A T I O N SQUOTE '-'? 'P' DUDAYTIMEFRAG SQUOTE;
|
||||||
TIMEOFDAY : T I M E O F D A Y SQUOTE HOUR ':' MINUTE ( ':' SECOND ( '.' FRACTIONALSECONDS )? )? SQUOTE;
|
TIMEOFDAY : T I M E O F D A Y SQUOTE HOUR ':' MINUTE ( ':' SECOND ( '.' FRACTIONALSECONDS )? )? SQUOTE;
|
||||||
|
|
||||||
fragment GUIDVALUE : HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG'-'
|
fragment GUIDVALUE : HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG'-'
|
||||||
HEXDIG HEXDIG HEXDIG HEXDIG '-'
|
HEXDIG HEXDIG HEXDIG HEXDIG '-'
|
||||||
HEXDIG HEXDIG HEXDIG HEXDIG '-'
|
HEXDIG HEXDIG HEXDIG HEXDIG '-'
|
||||||
|
@ -113,8 +139,85 @@ fragment GUIDVALUE : HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG H
|
||||||
HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG;
|
HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG HEXDIG;
|
||||||
GUID : G U I D SQUOTE GUIDVALUE SQUOTE;
|
GUID : G U I D SQUOTE GUIDVALUE SQUOTE;
|
||||||
|
|
||||||
ODATAIDENTIFIER : ODI_LEADINGCHARACTER (ODI_CHARACTER)*;
|
//expression tokens
|
||||||
|
ASC : 'asc';
|
||||||
|
DESC : 'desc';
|
||||||
|
MUL : 'mul';
|
||||||
|
DIV : 'div';
|
||||||
|
MOD : 'mod';
|
||||||
|
ADD : 'add';
|
||||||
|
SUB : 'sub';
|
||||||
|
GT : 'gt';
|
||||||
|
GE : 'ge';
|
||||||
|
LT : 'lt';
|
||||||
|
LE : 'le';
|
||||||
|
EQ_ALPHA : 'eq';
|
||||||
|
NE : 'ne';
|
||||||
|
AND : 'and';
|
||||||
|
OR : 'or';
|
||||||
|
ISOF : 'isof';
|
||||||
|
NOT : 'not';
|
||||||
|
MINUS :'-';
|
||||||
|
ROOT : '$root/';
|
||||||
|
NANINFINITY : 'NaN' | '-INF' | 'INF';
|
||||||
|
|
||||||
|
IMPLICIT_VARIABLE_EXPR : '$it';
|
||||||
|
LEVELS : '$levels';
|
||||||
|
|
||||||
|
CONTAINS_WORD : 'contains(';
|
||||||
|
STARTSWITH_WORD : 'startswith(';
|
||||||
|
ENDSWITH_WORD : 'endswith(';
|
||||||
|
LENGTH_WORD : 'length(';
|
||||||
|
INDEXOF_WORD : 'indexof(';
|
||||||
|
SUBSTRING_WORD : 'substring(';
|
||||||
|
TOLOWER_WORD : 'tolower(';
|
||||||
|
TOUPPER_WORD : 'toupper(';
|
||||||
|
TRIM_WORD : 'trim(';
|
||||||
|
CONCAT_WORD : 'concat(';
|
||||||
|
YEAR_WORD : 'year(';
|
||||||
|
MONTH_WORD : 'month(';
|
||||||
|
DAY_WORD : 'day(';
|
||||||
|
HOUR_WORD : 'hour(';
|
||||||
|
MINUTE_WORD : 'minute(';
|
||||||
|
SECOND_WORD : 'second(';
|
||||||
|
FRACTIONALSECONDS_WORD : 'fractionalseconds(';
|
||||||
|
TOTALSECONDS_WORD : 'totalseconds(';
|
||||||
|
DATE_WORD : 'date(';
|
||||||
|
TIME_WORD : 'time(';
|
||||||
|
TOTALOFFSETMINUTES_WORD : 'totaloffsetminutes(';
|
||||||
|
|
||||||
|
MINDATETIME_WORD : 'mindatetime(';
|
||||||
|
MAXDATETIME_WORD : 'maxdatetime(';
|
||||||
|
NOW_WORD : 'now(';
|
||||||
|
|
||||||
|
ROUND_WORD : 'round(';
|
||||||
|
FLOOR_WORD : 'floor(';
|
||||||
|
CEILING_WORD : 'ceiling(';
|
||||||
|
|
||||||
|
GEO_DISTANCE_WORD : 'geo.distance(';
|
||||||
|
GEO_LENGTH_WORD : 'geo.length(';
|
||||||
|
GEO_INTERSECTS_WORD : 'geo.intersects(';
|
||||||
|
ISOF_WORD : 'isof(';
|
||||||
|
CAST_WORD : 'cast(';
|
||||||
|
|
||||||
|
COLLECTION_REF : 'Collection($ref)';
|
||||||
|
COLLECTION_ENTITY_TYPE : 'Collection(Edm.EntityType)';
|
||||||
|
COLLECTION_COMPLEX_TYPE : 'Collection(Edm.ComplexType)';
|
||||||
|
COLLECTION : 'Collection(' -> type(COLLECTION);
|
||||||
|
|
||||||
|
//used in fragment only
|
||||||
|
DELETED_ENTITY : '$deletedEntity';
|
||||||
|
LINK : '$link';
|
||||||
|
DELETED_LINK : '$deletedLink';
|
||||||
|
DELTA : '$delta';
|
||||||
|
//ENTITY_IN_FRAGMENT : '/$entity';
|
||||||
|
|
||||||
|
|
||||||
|
LEVELSMAX : '$levels=max';
|
||||||
|
|
||||||
|
|
||||||
|
//ODI
|
||||||
|
ODATAIDENTIFIER : ODI_LEADINGCHARACTER (ODI_CHARACTER)*;
|
||||||
|
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
// Mode "QUERY": Processes everything between the first '?' and the '#' char
|
// Mode "QUERY": Processes everything between the first '?' and the '#' char
|
||||||
|
@ -123,56 +226,31 @@ ODATAIDENTIFIER : ODI_LEADINGCHARACTER (ODI_CHARACTER)*;
|
||||||
mode MODE_QUERY;
|
mode MODE_QUERY;
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
|
|
||||||
FRAGMENT : '#' -> pushMode(MODE_FRAGMENT);
|
FRAGMENT_q : '#' -> type(FRAGMENT);
|
||||||
FILTER : '$filter' -> pushMode(MODE_SYSTEM_QUERY);
|
FILTER : '$filter' -> pushMode(DEFAULT_MODE);
|
||||||
ORDERBY : '$orderby' -> pushMode(MODE_SYSTEM_QUERY);
|
ORDERBY : '$orderby' -> pushMode(DEFAULT_MODE);
|
||||||
EXPAND : '$expand' -> pushMode(MODE_SYSTEM_QUERY);
|
EXPAND : '$expand' -> pushMode(DEFAULT_MODE);
|
||||||
SELECT : '$select' -> pushMode(MODE_SYSTEM_QUERY);
|
SELECT : '$select' -> pushMode(DEFAULT_MODE);
|
||||||
SKIP : '$skip' -> pushMode(MODE_SYSTEM_QUERY);
|
SKIP : '$skip' -> pushMode(DEFAULT_MODE);
|
||||||
TOP : '$top' -> pushMode(MODE_SYSTEM_QUERY);
|
SKIPTOKEN : '$skiptoken' -> pushMode(MODE_SYSTEM_QUERY_REST_QCHAR_NO_AMP);
|
||||||
LEVELS : '$levels' -> pushMode(MODE_SYSTEM_QUERY);
|
|
||||||
|
TOP : '$top' -> pushMode(DEFAULT_MODE);
|
||||||
|
LEVELS_q : '$levels' -> type(LEVELS), pushMode(DEFAULT_MODE);
|
||||||
FORMAT : '$format' -> pushMode(MODE_SYSTEM_QUERY_PCHAR);
|
FORMAT : '$format' -> pushMode(MODE_SYSTEM_QUERY_PCHAR);
|
||||||
COUNT_q : '$count' -> type(COUNT), pushMode(MODE_SYSTEM_QUERY);
|
COUNT_q : '$count' -> type(COUNT), pushMode(DEFAULT_MODE);
|
||||||
REF_q : '$ref' -> type(REF);
|
REF_q : '$ref' -> type(REF);
|
||||||
VALUE_q : '$value' -> type(VALUE);
|
VALUE_q : '$value' -> type(VALUE);
|
||||||
|
|
||||||
ID : '$id'-> pushMode(MODE_SYSTEM_QUERY_REST_QCHAR_NO_AMP);
|
ID : '$id'-> pushMode(MODE_SYSTEM_QUERY_REST_QCHAR_NO_AMP);
|
||||||
SKIPTOKEN : '$skiptoken' -> pushMode(MODE_SYSTEM_QUERY_REST_QCHAR_NO_AMP);
|
|
||||||
SEARCH : '$search'-> pushMode(MODE_SYSTEM_QUERY_SEARCH);
|
SEARCH : '$search'-> pushMode(MODE_SYSTEM_QUERY_SEARCH);
|
||||||
|
|
||||||
GEOGRAPHY : G_q E_q O_q G_q R_q A_q P_q H_q Y_q -> pushMode(MODE_ODATA_GEO);//TODO make case insensitive
|
|
||||||
GEOMETRY : G_q E_q O_q M_q E_q T_q R_q Y_q -> pushMode(MODE_ODATA_GEO);
|
|
||||||
|
|
||||||
fragment A_q : 'A'|'a';
|
|
||||||
fragment E_q : 'E'|'e';
|
|
||||||
fragment G_q : 'G'|'g';
|
|
||||||
fragment H_q : 'H'|'h';
|
|
||||||
fragment M_q : 'M'|'m';
|
|
||||||
fragment O_q : 'O'|'o';
|
|
||||||
fragment P_q : 'P'|'p';
|
|
||||||
fragment R_q : 'R'|'r';
|
|
||||||
fragment S_q : 'S'|'s';
|
|
||||||
fragment T_q : 'T'|'t';
|
|
||||||
fragment Y_q : 'Y'|'y';
|
|
||||||
|
|
||||||
fragment ALPHA_q : 'a'..'z'|'A'..'Z';
|
|
||||||
fragment A_TO_F_q : 'a'..'f'|'A'..'F';
|
|
||||||
fragment DIGIT_q : '0'..'9';
|
|
||||||
fragment HEXDIG_q : DIGIT_q | A_TO_F_q;
|
|
||||||
|
|
||||||
fragment PCT_ENCODED_q : '%' HEXDIG_q HEXDIG_q;
|
|
||||||
fragment UNRESERVED_q : ALPHA_q | DIGIT_q | '-' |'.' | '_' | '~';
|
|
||||||
fragment OTHER_DELIMS_q : '!' | '(' | ')' | '*' | '+' | ',' | ';';
|
|
||||||
fragment QCHAR_NO_AMP_q : UNRESERVED_q | PCT_ENCODED_q | OTHER_DELIMS_q | ':' | '@' | '/' | '?' | '$' | '\'' | '=';
|
|
||||||
fragment QCHAR_NO_AMP_EQ_q : UNRESERVED_q | PCT_ENCODED_q | OTHER_DELIMS_q | ':' | '@' | '/' | '?' | '$' | '\'';
|
|
||||||
fragment QCHAR_NO_AMP_EQ_AT_DOLLAR_q : UNRESERVED_q | PCT_ENCODED_q | OTHER_DELIMS_q | ':' | '/' | '?' | '\'';
|
|
||||||
|
|
||||||
EQ_q : '=' -> type(EQ);
|
EQ_q : '=' -> type(EQ);
|
||||||
|
|
||||||
AMP : '&';
|
AMP_q : '&' -> type(AMP);
|
||||||
|
|
||||||
CUSTOMNAME : QCHAR_NO_AMP_EQ_AT_DOLLAR_q QCHAR_NO_AMP_EQ_q*;
|
CUSTOMNAME : ~[&=@$] ~[&=]*;
|
||||||
CUSTOMVALUE : QCHAR_NO_AMP_EQ_q+;
|
CUSTOMVALUE : ~[&=]+;
|
||||||
|
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
mode MODE_SYSTEM_QUERY_PCHAR;
|
mode MODE_SYSTEM_QUERY_PCHAR;
|
||||||
|
@ -206,6 +284,9 @@ EQ_sqp : '=' -> type(EQ);
|
||||||
mode MODE_SYSTEM_QUERY_REST_QCHAR_NO_AMP;
|
mode MODE_SYSTEM_QUERY_REST_QCHAR_NO_AMP;
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
|
|
||||||
|
AMP_sqr : '&' -> type(AMP), popMode;
|
||||||
|
FRAGMENT_sqr : '#' -> popMode;
|
||||||
|
/*
|
||||||
fragment ALPHA_sqr : 'a'..'z'|'A'..'Z';
|
fragment ALPHA_sqr : 'a'..'z'|'A'..'Z';
|
||||||
fragment A_TO_F_sqr : 'a'..'f'|'A'..'F';
|
fragment A_TO_F_sqr : 'a'..'f'|'A'..'F';
|
||||||
fragment DIGIT_sqr : '0'..'9';
|
fragment DIGIT_sqr : '0'..'9';
|
||||||
|
@ -215,13 +296,11 @@ fragment UNRESERVED_sqr : ALPHA_sqr | DIGIT_sqr | '-' |'.' | '_' | '~';
|
||||||
fragment OTHER_DELIMS_sqr : '!' | '(' | ')' | '*' | '+' | ',' | ';';
|
fragment OTHER_DELIMS_sqr : '!' | '(' | ')' | '*' | '+' | ',' | ';';
|
||||||
fragment QCHAR_NO_AMP_sqr : UNRESERVED_sqr | PCT_ENCODED_sqr | OTHER_DELIMS_sqr | ':' | '@' | '/' | '?' | '$' | '\'' | '=';
|
fragment QCHAR_NO_AMP_sqr : UNRESERVED_sqr | PCT_ENCODED_sqr | OTHER_DELIMS_sqr | ':' | '@' | '/' | '?' | '$' | '\'' | '=';
|
||||||
fragment QCHAR_NO_AMP_EQ_sqr : UNRESERVED_sqr | PCT_ENCODED_sqr | OTHER_DELIMS_sqr | ':' | '@' | '/' | '?' | '$' | '\'' ;
|
fragment QCHAR_NO_AMP_EQ_sqr : UNRESERVED_sqr | PCT_ENCODED_sqr | OTHER_DELIMS_sqr | ':' | '@' | '/' | '?' | '$' | '\'' ;
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
//REST : ~[&#]*;
|
|
||||||
AMP_sqr : '&' -> type(AMP), popMode;
|
|
||||||
EQ_sqr : '=' -> type(EQ);
|
EQ_sqr : '=' -> type(EQ);
|
||||||
FRAGMENT_sqr : '#' -> popMode;
|
REST : ~[&#=] ~[&#]*;
|
||||||
REST : QCHAR_NO_AMP_EQ_sqr QCHAR_NO_AMP_sqr*;
|
|
||||||
|
|
||||||
|
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
|
@ -248,207 +327,15 @@ SEARCHPHRASE : QUOTATION_MARK /*QCHAR_NO_AMP_DQUOTE+*/ ~[&"]* QUOTATION_M
|
||||||
|
|
||||||
|
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
mode MODE_SYSTEM_QUERY;
|
mode MODE_ODATA_STRING;
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
|
|
||||||
fragment SQUOTE_sq : '\'' -> type(SQUOTE);
|
|
||||||
|
|
||||||
STRING_sq : SQUOTE_sq -> more, pushMode(MODE_ODATA_STRING);
|
|
||||||
GEOGRAPHY_sq : G_sq E_sq O_sq G_sq R_sq A_sq P_sq H_sq Y SQUOTE_sq -> type(GEOGRAPHY), pushMode(MODE_ODATA_GEO); //TODO make case insensitive
|
|
||||||
GEOMETRY_sq : G_sq E_sq O_sq M_sq E_sq T_sq R_sq Y_sq SQUOTE_sq -> type(GEOMETRY),pushMode(MODE_ODATA_GEO);
|
|
||||||
|
|
||||||
fragment A_sq : 'A'|'a';
|
|
||||||
fragment B_sq : 'B'|'b';
|
|
||||||
fragment D_sq : 'D'|'d';
|
|
||||||
fragment E_sq : 'E'|'e';
|
|
||||||
fragment F_sq : 'F'|'f';
|
|
||||||
fragment G_sq : 'G'|'g';
|
|
||||||
fragment H_sq : 'H'|'h';
|
|
||||||
fragment I_sq : 'I'|'i';
|
|
||||||
fragment L_sq : 'L'|'l';
|
|
||||||
fragment M_sq : 'M'|'m';
|
|
||||||
fragment N_sq : 'N'|'n';
|
|
||||||
fragment O_sq : 'O'|'o';
|
|
||||||
fragment P_sq : 'P'|'p';
|
|
||||||
fragment R_sq : 'R'|'r';
|
|
||||||
fragment S_sq : 'S'|'s';
|
|
||||||
fragment T_sq : 'T'|'t';
|
|
||||||
fragment U_sq : 'U'|'u';
|
|
||||||
fragment Y_sq : 'Y'|'y';
|
|
||||||
fragment Z_sq : 'Z'|'z';
|
|
||||||
|
|
||||||
fragment ALPHA_sq : 'a'..'z'|'A'..'Z';
|
|
||||||
fragment ALPHA_A_TO_F_sq : 'a'..'f'|'A'..'F';
|
|
||||||
fragment DIGIT_sq : '0'..'9';
|
|
||||||
fragment DIGITS_sq : DIGIT_sq+;
|
|
||||||
fragment HEXDIG_sq : DIGIT_sq | ALPHA_A_TO_F_sq;
|
|
||||||
fragment ODI_LEADINGCHARACTER_sq : ALPHA_sq | '_'; //TODO; plus Unicode characters from the categories L or Nl
|
|
||||||
fragment ODI_CHARACTER_sq : ALPHA_sq | '_' | DIGIT_sq; //TODO; plus Unicode characters from the categories L, Nl, Nd, Mn, Mc, Pc, or Cf
|
|
||||||
fragment WS_sqr : ( SP_g | HTAB_g | '%20' | '%09' );
|
|
||||||
|
|
||||||
OPEN_sq : ('(' | '%28') -> type(OPEN);
|
|
||||||
CLOSE_sq : (')' | '%29') -> type(CLOSE);
|
|
||||||
COMMA_sq : (',' | '%2C') -> type(COMMA);
|
|
||||||
SLASH_sq : '/' -> type(SLASH);
|
|
||||||
POINT_sq : '.' -> type(POINT);
|
|
||||||
AT_sq : '@' -> type(AT);
|
|
||||||
STAR : '*';
|
|
||||||
SEMI_sq : ';' -> type(SEMI);
|
|
||||||
EQ_sq : '=' -> type(EQ);
|
|
||||||
AMP_sq : '&' -> type(AMP), popMode;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
WSP_sqr : WS_sqr+ -> type(WSP);
|
|
||||||
|
|
||||||
NULLVALUE_sq : 'null' -> type(NULLVALUE);
|
|
||||||
TRUE : 'true';
|
|
||||||
FALSE : 'false';
|
|
||||||
BOOLEAN_sq : (T_sq R_sq U_sq E_sq | F_sq A_sq L_sq S_sq E_sq) -> type(BOOLEAN);
|
|
||||||
SIGN_sq : ('+' | '%2B' |'-') -> type(SIGN);
|
|
||||||
INT_sq : SIGN_sq? DIGITS_sq -> type(INT);
|
|
||||||
DECIMAL_sq : INT_sq '.' DIGITS_sq ('e' SIGN_sq? DIGITS_sq)? -> type(DECIMAL);
|
|
||||||
BINARY_sq : ('X'| B_sq I_sq N_sq A_sq R_sq Y_sq) SQUOTE_sq (HEXDIG_sq HEXDIG_sq)* SQUOTE_sq -> type(BINARY);
|
|
||||||
|
|
||||||
ASC : 'asc';
|
|
||||||
DESC : 'desc';
|
|
||||||
MUL : 'mul';
|
|
||||||
DIV : 'div';
|
|
||||||
MOD : 'mod';
|
|
||||||
ADD : 'add';
|
|
||||||
SUB : 'sub';
|
|
||||||
GT : 'gt';
|
|
||||||
GE : 'ge';
|
|
||||||
LT : 'lt';
|
|
||||||
LE : 'le';
|
|
||||||
EQ_ALPHA : 'eq';
|
|
||||||
NE : 'ne';
|
|
||||||
AND : 'and';
|
|
||||||
OR : 'or';
|
|
||||||
ISOF : 'isof';
|
|
||||||
NOT : 'not';
|
|
||||||
MINUS :'-';
|
|
||||||
ROOT : '$root/';
|
|
||||||
NANINFINITY : 'NaN' | '-INF' | 'INF';
|
|
||||||
|
|
||||||
fragment ONE_TO_NINE_sq : '1'..'9';
|
|
||||||
fragment ZERO_TO_FIFTYNINE_sq : ('0'..'5') DIGIT_sq;
|
|
||||||
fragment FRACTIONALSECONDS_sq : DIGIT_sq+;
|
|
||||||
fragment SECOND_sq : ZERO_TO_FIFTYNINE_sq;
|
|
||||||
fragment MINUTE_sq : ZERO_TO_FIFTYNINE_sq;
|
|
||||||
fragment HOUR_sq : ('0' | '1') DIGIT_sq | '2' ( '0'..'3');
|
|
||||||
fragment DAY_sq : '0' '1'..'9' | ('1'|'2') DIGIT_sq | '3' ('0'|'1');
|
|
||||||
fragment MONTH_sq : '0' ONE_TO_NINE_sq | '1' ( '0' | '1' | '2' );
|
|
||||||
fragment YEAR_sq : ('-')? ( '0' DIGIT_sq DIGIT_sq DIGIT_sq | ONE_TO_NINE DIGIT_sq DIGIT_sq DIGIT_sq );
|
|
||||||
|
|
||||||
DATE_sq : D_sq A_sq T_sq E_sq SQUOTE_sq YEAR_sq '-' MONTH_sq '-' DAY_sq SQUOTE_sq -> type(DATE);
|
|
||||||
DATETIMEOFFSET_sq : D_sq A_sq T_sq E_sq T_sq I_sq M_sq E_sq O_sq F_sq F_sq S_sq E_sq T_sq SQUOTE_sq YEAR_sq '-' MONTH_sq '-' DAY_sq T_sq HOUR_sq ':' MINUTE_sq ( ':' SECOND_sq ( '.' FRACTIONALSECONDS_sq )? )? ( Z_sq | SIGN_sq HOUR_sq ':' MINUTE_sq ) SQUOTE_sq -> type(DATETIMEOFFSET);
|
|
||||||
|
|
||||||
fragment DUSECONDFRAG_sq : DIGITS_sq ('.' DIGITS_sq)? 'S';
|
|
||||||
fragment DUTIMEFRAG_sq : 'T' (
|
|
||||||
( DIGITS_sq 'H' (DIGITS_sq 'M')? DUSECONDFRAG_sq?)
|
|
||||||
| (DIGITS_sq 'M' DUSECONDFRAG_sq?)
|
|
||||||
| DUSECONDFRAG_sq
|
|
||||||
);
|
|
||||||
fragment DUDAYTIMEFRAG_sq : DIGITS 'D' DUTIMEFRAG? | DUTIMEFRAG;
|
|
||||||
|
|
||||||
DURATION_sq : D_sq U_sq R_sq A_sq T_sq I_sq O_sq N_sq SQUOTE_sq '-'? 'P' DUDAYTIMEFRAG_sq SQUOTE_sq -> type(DURATION);
|
|
||||||
TIMEOFDAY_sq : T_sq I_sq M_sq E_sq O_sq F_sq D_sq A_sq Y_sq SQUOTE_sq HOUR_sq ':' MINUTE_sq ( ':' SECOND_sq ( '.' FRACTIONALSECONDS_sq )? )? SQUOTE_sq -> type(TIMEOFDAY);
|
|
||||||
|
|
||||||
GUID_sq : G_sq U_sq I_sq D_sq SQUOTE_sq GUIDVALUE_sq SQUOTE_sq -> type(GUID);
|
|
||||||
fragment GUIDVALUE_sq : HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq'-'
|
|
||||||
HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq '-'
|
|
||||||
HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq '-'
|
|
||||||
HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq '-'
|
|
||||||
HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq HEXDIG_sq;
|
|
||||||
|
|
||||||
fragment PCT_ENCODED_sq : '%' HEXDIG_sq HEXDIG_sq;
|
|
||||||
fragment UNRESERVED_sq : ALPHA_sq | DIGIT_sq | '-' |'.' | '_' | '~';
|
|
||||||
fragment OTHER_DELIMS_sq : '!' | '(' | ')' | '*' | '+' | ',' | ';';
|
|
||||||
fragment QCHAR_NO_AMP_sq : UNRESERVED_sq | PCT_ENCODED_sq | OTHER_DELIMS_sq | ':' | '@' | '/' | '?' | '$' | '\'' | '=';
|
|
||||||
|
|
||||||
|
|
||||||
IMPLICIT_VARIABLE_EXPR : '$it';
|
|
||||||
REF_sq : '$ref' -> type(REF);
|
|
||||||
LEVELS_sq : '$levels' -> type(LEVELS);
|
|
||||||
|
|
||||||
|
|
||||||
CONTAINS_WORD : 'contains(';
|
|
||||||
STARTSWITH_WORD : 'startswith(';
|
|
||||||
ENDSWITH_WORD : 'endswith(';
|
|
||||||
LENGTH_WORD : 'length(';
|
|
||||||
INDEXOF_WORD : 'indexof(';
|
|
||||||
SUBSTRING_WORD : 'substring(';
|
|
||||||
TOLOWER_WORD : 'tolower(';
|
|
||||||
TOUPPER_WORD : 'toupper(';
|
|
||||||
TRIM_WORD : 'trim(';
|
|
||||||
CONCAT_WORD : 'concat(';
|
|
||||||
YEAR_WORD : 'year(';
|
|
||||||
MONTH_WORD : 'month(';
|
|
||||||
DAY_WORD : 'day(';
|
|
||||||
HOUR_WORD : 'hour(';
|
|
||||||
MINUTE_WORD : 'minute(';
|
|
||||||
SECOND_WORD : 'second(';
|
|
||||||
FRACTIONALSECONDS_WORD : 'fractionalseconds(';
|
|
||||||
TOTALSECONDS_WORD : 'totalseconds(';
|
|
||||||
DATE_WORD : 'date(';
|
|
||||||
TIME_WORD : 'time(';
|
|
||||||
TOTALOFFSETMINUTES_WORD : 'totaloffsetminutes(';
|
|
||||||
|
|
||||||
MINDATETIME_WORD : 'mindatetime(';
|
|
||||||
MAXDATETIME_WORD : 'maxdatetime(';
|
|
||||||
NOW_WORD : 'now(';
|
|
||||||
|
|
||||||
ROUND_WORD : 'round(';
|
|
||||||
FLOOR_WORD : 'floor(';
|
|
||||||
CEILING_WORD : 'ceiling(';
|
|
||||||
|
|
||||||
GEO_DISTANCE_WORD : 'geo.distance(';
|
|
||||||
GEO_LENGTH_WORD : 'geo.length(';
|
|
||||||
GEO_INTERSECTS_WORD : 'geo.intersects(';
|
|
||||||
ISOF_WORD : 'isof(';
|
|
||||||
CAST_WORD : 'cast(';
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
LEVELSMAX : '$levels=max';
|
|
||||||
SKIP_sq : '$skip' -> type(SKIP);
|
|
||||||
COUNT_sq : '$count' -> type(COUNT);
|
|
||||||
FILTER_sq : '$filter' -> type(FILTER);
|
|
||||||
SEARCH_sq : '$search' -> type(SEARCH), pushMode(MODE_SYSTEM_QUERY_SEARCH);
|
|
||||||
//IRI_IN_QUERY : /*EQ*/ QCHAR_NO_AMP_sq*;
|
|
||||||
ODATAIDENTIFIER_sq : ODI_LEADINGCHARACTER_sq (ODI_CHARACTER_sq)* ->type(ODATAIDENTIFIER);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//;==============================================================================
|
|
||||||
// Mode "QUERY": Processes everything after the '#' char
|
|
||||||
// The percent encoding rules a defined in RFC3986 ABNF rule "fragment" apply
|
|
||||||
//;==============================================================================
|
|
||||||
mode MODE_FRAGMENT;
|
|
||||||
|
|
||||||
TMP_FRAGMENT : 'TMP_FRAGMENT';
|
|
||||||
|
|
||||||
//;==============================================================================
|
|
||||||
//;==============================================================================
|
|
||||||
mode MODE_ODATA_STRING;//2
|
|
||||||
|
|
||||||
|
|
||||||
fragment COMMA_s : ',' | '%2C';
|
|
||||||
fragment ALPHA_s : 'a'..'z'|'A'..'Z';
|
|
||||||
fragment ALPHA_A_TO_F_s : 'a'..'f'|'A'..'F';
|
|
||||||
fragment DIGIT_s : '0'..'9';
|
|
||||||
fragment HEXDIG_s : DIGIT_s | ALPHA_A_TO_F_s;
|
|
||||||
fragment UNRESERVED_s : ALPHA_s | DIGIT_s | '-' |'.' | '_' | '~';
|
|
||||||
fragment OTHER_DELIMS_s : '!' | '(' | ')' | '*' | '+' | COMMA_s | ';';
|
|
||||||
fragment PCTENCODEDnoSQUOTE_s : '%' ( '0'|'1'|'3'..'9' | ALPHA_A_TO_F_s ) HEXDIG_s | '%' '2' ( '0'..'6'|'8'|'9' | ALPHA_A_TO_F_s );
|
|
||||||
fragment PCHARnoSQUOTE_s : UNRESERVED_s| PCTENCODEDnoSQUOTE_s | OTHER_DELIMS_s | '$' | '&' | '=' | ':' | '@';
|
|
||||||
fragment SQUOTE_s : '\'';
|
fragment SQUOTE_s : '\'';
|
||||||
STRING_s : ('\'\'' | PCHARnoSQUOTE_s )* SQUOTE_s -> type(STRING), popMode;
|
STRING_s : ('\'\'' | ~[\u0027] )* SQUOTE_s -> type(STRING), popMode;
|
||||||
|
|
||||||
//;==============================================================================
|
|
||||||
//;==============================================================================
|
//;==============================================================================
|
||||||
mode MODE_ODATA_GEO;
|
mode MODE_ODATA_GEO;
|
||||||
|
//;==============================================================================
|
||||||
|
|
||||||
fragment C_g : 'c'|'C';
|
fragment C_g : 'c'|'C';
|
||||||
fragment D_g : 'd'|'D';
|
fragment D_g : 'd'|'D';
|
||||||
|
@ -469,15 +356,15 @@ fragment Y_g : 'y'|'Y';
|
||||||
|
|
||||||
fragment SP_g : ' ';//'\u0020'; // a simple space
|
fragment SP_g : ' ';//'\u0020'; // a simple space
|
||||||
fragment HTAB_g : '%09';
|
fragment HTAB_g : '%09';
|
||||||
fragment WS_g : ( SP_g | HTAB_g | '%20' | '%09' );
|
fragment WS_g : ( ' ' | HTAB_g | '%20' | '%09' );
|
||||||
|
|
||||||
OPEN_g : ('(' | '%28') -> type(OPEN);
|
OPEN_g : ('(' | '%28') -> type(OPEN);
|
||||||
CLOSE_g : (')' | '%29') -> type(CLOSE);
|
CLOSE_g : (')' | '%29') -> type(CLOSE);
|
||||||
COMMA_g : (',' | '%2C') -> type(COMMA);
|
COMMA_g : (',' | '%2C') -> type(COMMA);
|
||||||
WSP : WS_g+;
|
WSP_g : WS_g+ -> type(WSP);
|
||||||
POINT_g : '.' -> type(POINT);
|
POINT_g : '.' -> type(POINT);
|
||||||
AT_g : '@' -> type(AT);
|
AT_g : '@' -> type(AT);
|
||||||
SEMI : (';' | '%3B');
|
SEMI_g : (';' | '%3B') -> type(SEMI);
|
||||||
EQ_g : '=' -> type(EQ);
|
EQ_g : '=' -> type(EQ);
|
||||||
|
|
||||||
fragment DIGIT_g : '0'..'9';
|
fragment DIGIT_g : '0'..'9';
|
||||||
|
@ -485,7 +372,7 @@ fragment DIGITS_g : DIGIT_g+;
|
||||||
SIGN_g : ('+' | '%2B' |'-') -> type(SIGN);
|
SIGN_g : ('+' | '%2B' |'-') -> type(SIGN);
|
||||||
INT_g : SIGN_g? DIGITS_g -> type(INT);
|
INT_g : SIGN_g? DIGITS_g -> type(INT);
|
||||||
DECIMAL_g : INT_g '.' DIGITS_g ('e' SIGN_g? DIGITS_g)? -> type(DECIMAL);
|
DECIMAL_g : INT_g '.' DIGITS_g ('e' SIGN_g? DIGITS_g)? -> type(DECIMAL);
|
||||||
COLLECTION : C_g O_g L_g L_g E_g C_g T_g I_g O_g N_g ;
|
COLLECTION_g : C_g O_g L_g L_g E_g C_g T_g I_g O_g N_g -> type(COLLECTION);
|
||||||
LINESTRING : L_g I_g N_g E_g S_g T_g R_g I_g N_g G_g ;
|
LINESTRING : L_g I_g N_g E_g S_g T_g R_g I_g N_g G_g ;
|
||||||
MULTILINESTRING : M_g U_g L_g T_g I_g L_g I_g N_g E_g S_g T_g R_g I_g N_g G_g;
|
MULTILINESTRING : M_g U_g L_g T_g I_g L_g I_g N_g E_g S_g T_g R_g I_g N_g G_g;
|
||||||
MULTIPOINT : M_g U_g L_g T_g I_g P_g O_g I_g N_g T_g ;
|
MULTIPOINT : M_g U_g L_g T_g I_g P_g O_g I_g N_g T_g ;
|
||||||
|
|
|
@ -163,12 +163,12 @@ expandPathExtension : SLASH ref ( OPEN expandRefOption ( SEMI expandRefOptio
|
||||||
| SLASH count ( OPEN expandCountOption ( SEMI expandCountOption )* CLOSE )?
|
| SLASH count ( OPEN expandCountOption ( SEMI expandCountOption )* CLOSE )?
|
||||||
| OPEN expandOption ( SEMI expandOption )* CLOSE
|
| OPEN expandOption ( SEMI expandOption )* CLOSE
|
||||||
;
|
;
|
||||||
expandCountOption : filter
|
expandCountOption : filterInline
|
||||||
| search
|
| searchInline
|
||||||
;
|
;
|
||||||
expandRefOption : expandCountOption
|
expandRefOption : expandCountOption
|
||||||
| orderby
|
| orderbyInline
|
||||||
| skip
|
| skipInline
|
||||||
| top
|
| top
|
||||||
| inlinecount
|
| inlinecount
|
||||||
;
|
;
|
||||||
|
@ -178,18 +178,24 @@ expandOption : expandRefOption
|
||||||
| LEVELS;
|
| LEVELS;
|
||||||
|
|
||||||
filter : FILTER EQ commonExpr;
|
filter : FILTER EQ commonExpr;
|
||||||
|
filterInline : FILTER_INLINE EQ commonExpr;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
orderby : ORDERBY EQ orderbyItem ( COMMA orderbyItem )*;
|
orderby : ORDERBY EQ orderbyItem ( COMMA orderbyItem )*;
|
||||||
|
orderbyInline : ORDERBY_INLINE EQ orderbyItem ( COMMA orderbyItem )*;
|
||||||
orderbyItem : commonExpr ( WSP ( ASC | DESC ) )?;
|
orderbyItem : commonExpr ( WSP ( ASC | DESC ) )?;
|
||||||
|
|
||||||
//this is completly done in lexer grammer to avoid ambiguities with odataIdentifier and STRING
|
//this is completly done in lexer grammer to avoid ambiguities with odataIdentifier and STRING
|
||||||
skip : SKIP EQ INT;
|
skip : SKIP EQ INT;
|
||||||
|
skipInline : SKIP_INLINE EQ INT;
|
||||||
top : TOP EQ INT;
|
top : TOP EQ INT;
|
||||||
format : FORMAT EQ ( ATOM | JSON | XML | PCHARS ( SLASH PCHARS)?);
|
format : FORMAT EQ ( ATOM | JSON | XML | PCHARS ( SLASH PCHARS)?);
|
||||||
|
|
||||||
inlinecount : COUNT EQ booleanNonCase;
|
inlinecount : COUNT EQ booleanNonCase;
|
||||||
|
|
||||||
search : SEARCH searchSpecialToken;
|
search : SEARCH searchSpecialToken;
|
||||||
|
searchInline : SEARCH_INLINE searchSpecialToken;
|
||||||
|
|
||||||
searchSpecialToken : EQ WSP? searchExpr;
|
searchSpecialToken : EQ WSP? searchExpr;
|
||||||
|
|
||||||
|
@ -230,18 +236,14 @@ customValue : CUSTOMVALUE;
|
||||||
//ps+=pathSegment (SLASH ps+=pathSegment)*
|
//ps+=pathSegment (SLASH ps+=pathSegment)*
|
||||||
//PRIMITIVETYPENAME
|
//PRIMITIVETYPENAME
|
||||||
contextFragment : REF
|
contextFragment : REF
|
||||||
| PRIMITIVETYPENAME
|
/*| PRIMITIVETYPENAME*/
|
||||||
| 'Collection($ref)'
|
| COLLECTION_REF
|
||||||
| 'Collection(Edm.EntityType)'
|
| COLLECTION_ENTITY_TYPE
|
||||||
| 'Collection(Edm.ComplexType)'
|
| COLLECTION_COMPLEX_TYPE
|
||||||
|
| COLLECTION ( /*PRIMITIVETYPENAME |*/ namespace? odataIdentifier ) CLOSE
|
||||||
| COLLECTION_FIX OPEN ( PRIMITIVETYPENAME | namespace odataIdentifier ) CLOSE
|
|
||||||
|
|
||||||
| namespace? odataIdentifier
|
| namespace? odataIdentifier
|
||||||
( '/$deletedEntity'
|
( SLASH ( DELETED_ENTITY | LINK | DELETED_LINK )
|
||||||
| '/$link'
|
| nameValueOptList? ( SLASH namespace? odataIdentifier)* ( propertyList )? ( SLASH DELTA) ? (SLASH ENTITY) ?
|
||||||
| '/$deletedLink'
|
|
||||||
| nameValueOptList? ( SLASH namespace? odataIdentifier)* ( propertyList )? ( '/$delta' )? ( entity )?
|
|
||||||
)
|
)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
@ -249,10 +251,10 @@ propertyList : OPEN propertyListItem ( COMMA propertyListItem )* CLOSE;
|
||||||
propertyListItem : STAR //; all structural properties
|
propertyListItem : STAR //; all structural properties
|
||||||
| propertyListProperty
|
| propertyListProperty
|
||||||
;
|
;
|
||||||
propertyListProperty : namespace? odataIdentifier ( SLASH namespace? odataIdentifier)* ( '+' )? ( propertyList)?
|
propertyListProperty : namespace? odataIdentifier ( SLASH namespace? odataIdentifier)* ( PLUS )? ( propertyList)?
|
||||||
;
|
;
|
||||||
|
|
||||||
entity : '/$entity';
|
|
||||||
//;------------------------------------------------------------------------------
|
//;------------------------------------------------------------------------------
|
||||||
//; 4. Expressions
|
//; 4. Expressions
|
||||||
//;------------------------------------------------------------------------------
|
//;------------------------------------------------------------------------------
|
||||||
|
@ -287,8 +289,8 @@ rootExpr : ROOT pathSegments;
|
||||||
|
|
||||||
memberExpr : '$it' | '$it/'? pathSegments;
|
memberExpr : '$it' | '$it/'? pathSegments;
|
||||||
|
|
||||||
anyExpr : 'any' OPEN WS* /* [ lambdaVariableExpr BWS COLON BWS lambdaPredicateExpr ] WS* */ CLOSE;
|
anyExpr : 'any' OPEN WSP /* [ lambdaVariableExpr BWS COLON BWS lambdaPredicateExpr ] WS* */ CLOSE;
|
||||||
allExpr : 'all' OPEN WS* /* lambdaVariableExpr BWS COLON BWS lambdaPredicateExpr WS* */ CLOSE;
|
allExpr : 'all' OPEN WSP /* lambdaVariableExpr BWS COLON BWS lambdaPredicateExpr WS* */ CLOSE;
|
||||||
|
|
||||||
methodCallExpr : indexOfMethodCallExpr
|
methodCallExpr : indexOfMethodCallExpr
|
||||||
| toLowerMethodCallExpr
|
| toLowerMethodCallExpr
|
||||||
|
@ -326,43 +328,43 @@ methodCallExpr : indexOfMethodCallExpr
|
||||||
;
|
;
|
||||||
|
|
||||||
|
|
||||||
containsMethodCallExpr : CONTAINS_WORD WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
containsMethodCallExpr : CONTAINS_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
startsWithMethodCallExpr : STARTSWITH_WORD WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
startsWithMethodCallExpr : STARTSWITH_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
endsWithMethodCallExpr : ENDSWITH_WORD WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
endsWithMethodCallExpr : ENDSWITH_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
lengthMethodCallExpr : LENGTH_WORD WS* commonExpr WS* CLOSE;
|
lengthMethodCallExpr : LENGTH_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
indexOfMethodCallExpr : INDEXOF_WORD WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
indexOfMethodCallExpr : INDEXOF_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
substringMethodCallExpr : SUBSTRING_WORD WS* commonExpr WS* COMMA WS* commonExpr WS* ( COMMA WS* commonExpr WS* )? CLOSE;
|
substringMethodCallExpr : SUBSTRING_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? ( COMMA WSP? commonExpr WSP? )? CLOSE;
|
||||||
toLowerMethodCallExpr : TOLOWER_WORD WS* commonExpr WS* CLOSE;
|
toLowerMethodCallExpr : TOLOWER_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
toUpperMethodCallExpr : TOUPPER_WORD WS* commonExpr WS* CLOSE;
|
toUpperMethodCallExpr : TOUPPER_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
trimMethodCallExpr : TRIM_WORD WS* commonExpr WS* CLOSE;
|
trimMethodCallExpr : TRIM_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
concatMethodCallExpr : CONCAT_WORD WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
concatMethodCallExpr : CONCAT_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
|
|
||||||
yearMethodCallExpr : YEAR_WORD WS* commonExpr WS* CLOSE;
|
yearMethodCallExpr : YEAR_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
monthMethodCallExpr : MONTH_WORD WS* commonExpr WS* CLOSE;
|
monthMethodCallExpr : MONTH_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
dayMethodCallExpr : DAY_WORD WS* commonExpr WS* CLOSE;
|
dayMethodCallExpr : DAY_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
hourMethodCallExpr : HOUR_WORD WS* commonExpr WS* CLOSE;
|
hourMethodCallExpr : HOUR_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
minuteMethodCallExpr : MINUTE_WORD WS* commonExpr WS* CLOSE;
|
minuteMethodCallExpr : MINUTE_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
secondMethodCallExpr : SECOND_WORD WS* commonExpr WS* CLOSE;
|
secondMethodCallExpr : SECOND_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
fractionalsecondsMethodCallExpr : FRACTIONALSECONDS_WORD WS* commonExpr WS* CLOSE;
|
fractionalsecondsMethodCallExpr : FRACTIONALSECONDS_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
totalsecondsMethodCallExpr : TOTALSECONDS_WORD WS* commonExpr WS* CLOSE;
|
totalsecondsMethodCallExpr : TOTALSECONDS_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
dateMethodCallExpr : DATE_WORD WS* commonExpr WS* CLOSE;
|
dateMethodCallExpr : DATE_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
timeMethodCallExpr : TIME_WORD WS* commonExpr WS* CLOSE;
|
timeMethodCallExpr : TIME_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
totalOffsetMinutesMethodCallExpr : TOTALOFFSETMINUTES_WORD WS* commonExpr WS* CLOSE;
|
totalOffsetMinutesMethodCallExpr : TOTALOFFSETMINUTES_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
|
|
||||||
minDateTimeMethodCallExpr : MINDATETIME_WORD WS* CLOSE;
|
minDateTimeMethodCallExpr : MINDATETIME_WORD WSP? CLOSE;
|
||||||
maxDateTimeMethodCallExpr : MAXDATETIME_WORD WS* CLOSE;
|
maxDateTimeMethodCallExpr : MAXDATETIME_WORD WSP? CLOSE;
|
||||||
nowMethodCallExpr : NOW_WORD WS* CLOSE;
|
nowMethodCallExpr : NOW_WORD WSP? CLOSE;
|
||||||
|
|
||||||
roundMethodCallExpr : ROUND_WORD WS* commonExpr WS* CLOSE;
|
roundMethodCallExpr : ROUND_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
floorMethodCallExpr : FLOOR_WORD WS* commonExpr WS* CLOSE;
|
floorMethodCallExpr : FLOOR_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
ceilingMethodCallExpr : CEILING_WORD WS* commonExpr WS* CLOSE;
|
ceilingMethodCallExpr : CEILING_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
|
|
||||||
distanceMethodCallExpr : GEO_DISTANCE_WORD OPEN WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
distanceMethodCallExpr : GEO_DISTANCE_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
geoLengthMethodCallExpr : GEO_LENGTH_WORD OPEN WS* commonExpr WS* CLOSE;
|
geoLengthMethodCallExpr : GEO_LENGTH_WORD WSP? commonExpr WSP? CLOSE;
|
||||||
intersectsMethodCallExpr : GEO_INTERSECTS_WORD OPEN WS* commonExpr WS* COMMA WS* commonExpr WS* CLOSE;
|
intersectsMethodCallExpr : GEO_INTERSECTS_WORD WSP? commonExpr WSP? COMMA WSP? commonExpr WSP? CLOSE;
|
||||||
|
|
||||||
isofExpr : ISOF_WORD WS* ( commonExpr WS* COMMA WS* )? qualifiedtypename WS* CLOSE;
|
isofExpr : ISOF_WORD WSP? ( commonExpr WSP? COMMA WSP? )? qualifiedtypename WSP? CLOSE;
|
||||||
castExpr : CAST_WORD WS* ( commonExpr WS* COMMA WS* )? qualifiedtypename WS* CLOSE;
|
castExpr : CAST_WORD WSP? ( commonExpr WSP? COMMA WSP? )? qualifiedtypename WSP? CLOSE;
|
||||||
|
|
||||||
//;------------------------------------------------------------------------------
|
//;------------------------------------------------------------------------------
|
||||||
//; 5. JSON format for function parameters
|
//; 5. JSON format for function parameters
|
||||||
|
@ -434,9 +436,8 @@ number_in_json : INT | DECIMAL;
|
||||||
//; 6. Names and identifiers
|
//; 6. Names and identifiers
|
||||||
//;------------------------------------------------------------------------------
|
//;------------------------------------------------------------------------------
|
||||||
|
|
||||||
qualifiedtypename : PRIMITIVETYPENAME
|
qualifiedtypename : namespace odataIdentifier
|
||||||
| namespace odataIdentifier
|
| 'collection' OPEN ( namespace odataIdentifier ) CLOSE
|
||||||
| 'collection' OPEN ( PRIMITIVETYPENAME | namespace odataIdentifier ) CLOSE
|
|
||||||
;
|
;
|
||||||
|
|
||||||
namespace : (odataIdentifier POINT)+;
|
namespace : (odataIdentifier POINT)+;
|
||||||
|
@ -491,7 +492,7 @@ singleEnumValue : odataIdentifier / INT;
|
||||||
geographyCollection : GEOGRAPHY fullCollectionLiteral SQUOTE;
|
geographyCollection : GEOGRAPHY fullCollectionLiteral SQUOTE;
|
||||||
fullCollectionLiteral : sridLiteral collectionLiteral;
|
fullCollectionLiteral : sridLiteral collectionLiteral;
|
||||||
|
|
||||||
collectionLiteral : (COLLECTION | COLLECTION_FIX) OPEN geoLiteral ( COMMA geoLiteral )* CLOSE;
|
collectionLiteral : (COLLECTION ) OPEN geoLiteral ( COMMA geoLiteral )* CLOSE;
|
||||||
|
|
||||||
geoLiteral : collectionLiteral
|
geoLiteral : collectionLiteral
|
||||||
| lineStringLiteral
|
| lineStringLiteral
|
||||||
|
|
|
@ -125,7 +125,7 @@ public class UriParserImpl {
|
||||||
String odataIdentifier = ""; //TODO ctx.odi.getText();
|
String odataIdentifier = ""; //TODO ctx.odi.getText();
|
||||||
|
|
||||||
// get element "odataIdentifier" from EDM
|
// get element "odataIdentifier" from EDM
|
||||||
EdmNamed edmObject = entityContainer.getElement(odataIdentifier);
|
EdmNamed edmObject = null;// entityContainer.getElement(odataIdentifier);
|
||||||
|
|
||||||
if (edmObject instanceof EdmEntitySet) {
|
if (edmObject instanceof EdmEntitySet) {
|
||||||
|
|
||||||
|
|
|
@ -346,12 +346,13 @@ public class EdmMock implements Edm {
|
||||||
when(container1.getFunctionImport(FUNCTION_IMPORT_ALL_LOCATIONS_NAME.getName())).thenReturn(
|
when(container1.getFunctionImport(FUNCTION_IMPORT_ALL_LOCATIONS_NAME.getName())).thenReturn(
|
||||||
allLocationsFunctionImport);
|
allLocationsFunctionImport);
|
||||||
|
|
||||||
when(container1.getElement(EMPLOYEES_SET_NAME.getName())).thenReturn(employeesSet);
|
/*
|
||||||
when(container1.getElement(TEAMS_SET_NAME.getName())).thenReturn(teamsSet);
|
* when(container1.getElement(EMPLOYEES_SET_NAME.getName())).thenReturn(employeesSet);
|
||||||
when(container1.getElement(COMPANY_SINGLETON_NAME.getName())).thenReturn(company);
|
* when(container1.getElement(TEAMS_SET_NAME.getName())).thenReturn(teamsSet);
|
||||||
when(container1.getElement(ACTION_IMPORT1_NAME.getName())).thenReturn(actionImport1);
|
* when(container1.getElement(COMPANY_SINGLETON_NAME.getName())).thenReturn(company);
|
||||||
when(container1.getElement(FUNCTION_IMPORT_MAXIMAL_AGE_NAME.getName())).thenReturn(maximalAgeFunctionImport);
|
* when(container1.getElement(ACTION_IMPORT1_NAME.getName())).thenReturn(actionImport1);
|
||||||
|
* when(container1.getElement(FUNCTION_IMPORT_MAXIMAL_AGE_NAME.getName())).thenReturn(maximalAgeFunctionImport);
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
private void enhanceActionImport1() {
|
private void enhanceActionImport1() {
|
||||||
|
|
|
@ -35,6 +35,7 @@ import org.antlr.v4.runtime.Parser;
|
||||||
import org.antlr.v4.runtime.ParserRuleContext;
|
import org.antlr.v4.runtime.ParserRuleContext;
|
||||||
import org.antlr.v4.runtime.RecognitionException;
|
import org.antlr.v4.runtime.RecognitionException;
|
||||||
import org.antlr.v4.runtime.Recognizer;
|
import org.antlr.v4.runtime.Recognizer;
|
||||||
|
import org.antlr.v4.runtime.Token;
|
||||||
import org.antlr.v4.runtime.atn.ATNConfigSet;
|
import org.antlr.v4.runtime.atn.ATNConfigSet;
|
||||||
import org.antlr.v4.runtime.atn.PredictionMode;
|
import org.antlr.v4.runtime.atn.PredictionMode;
|
||||||
import org.antlr.v4.runtime.dfa.DFA;
|
import org.antlr.v4.runtime.dfa.DFA;
|
||||||
|
@ -42,71 +43,106 @@ import org.antlr.v4.runtime.misc.Interval;
|
||||||
import org.apache.olingo.producer.core.uri.antlr.UriLexer;
|
import org.apache.olingo.producer.core.uri.antlr.UriLexer;
|
||||||
import org.apache.olingo.producer.core.uri.antlr.UriParserParser;
|
import org.apache.olingo.producer.core.uri.antlr.UriParserParser;
|
||||||
import org.apache.olingo.producer.core.uri.antlr.UriParserParser.OdataRelativeUriEOFContext;
|
import org.apache.olingo.producer.core.uri.antlr.UriParserParser.OdataRelativeUriEOFContext;
|
||||||
import org.apache.olingo.producer.core.uri.antlr.UriParserParser.TestContext;
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author d039346
|
||||||
|
*
|
||||||
|
*/
|
||||||
public class ParserValidator {
|
public class ParserValidator {
|
||||||
|
public class UriLexerTrace extends UriLexer {
|
||||||
|
ParserValidator parserValidator = null;
|
||||||
|
|
||||||
|
public UriLexerTrace(ParserValidator parserValidator, ANTLRInputStream antlrInputStream) {
|
||||||
|
super(antlrInputStream);
|
||||||
|
this.parserValidator = parserValidator;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Token emit() {
|
||||||
|
Token t =
|
||||||
|
_factory.create(_tokenFactorySourcePair, _type, _text, _channel, _tokenStartCharIndex, getCharIndex() - 1,
|
||||||
|
_tokenStartLine, _tokenStartCharPositionInLine);
|
||||||
|
|
||||||
|
if (parserValidator.logLevel > 1) {
|
||||||
|
String out = String.format("%1$-" + 20 + "s", t.getText());
|
||||||
|
;
|
||||||
|
int tokenType = t.getType();
|
||||||
|
if (tokenType == -1) {
|
||||||
|
out += "-1/EOF";
|
||||||
|
} else {
|
||||||
|
out += UriLexer.tokenNames[tokenType];
|
||||||
|
}
|
||||||
|
System.out.println(out);
|
||||||
|
}
|
||||||
|
emit(t);
|
||||||
|
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void pushMode(int m) {
|
||||||
|
String out = UriLexer.modeNames[this._mode] + "-->";
|
||||||
|
super.pushMode(m);
|
||||||
|
out += UriLexer.modeNames[this._mode];
|
||||||
|
if (parserValidator.logLevel > 1) {
|
||||||
|
System.out.print(out + " ");
|
||||||
|
}
|
||||||
|
;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int popMode() {
|
||||||
|
String out = UriLexer.modeNames[this._mode] + "-->";
|
||||||
|
int m = super.popMode();
|
||||||
|
out += UriLexer.modeNames[this._mode];
|
||||||
|
|
||||||
|
if (parserValidator.logLevel > 1) {
|
||||||
|
System.out.print(out + " ");
|
||||||
|
}
|
||||||
|
|
||||||
|
return m;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private List<Exception> exceptions = new ArrayList<Exception>();
|
private List<Exception> exceptions = new ArrayList<Exception>();
|
||||||
private ParserRuleContext root;
|
private ParserRuleContext root;
|
||||||
|
|
||||||
private String input = null;
|
private String input = null;
|
||||||
//private int exceptionOnStage = -1;
|
// private int exceptionOnStage = -1;
|
||||||
private Exception curException = null;
|
private Exception curException = null;
|
||||||
//private Exception curWeakException = null;
|
// private Exception curWeakException = null;
|
||||||
private boolean allowFullContext;
|
private boolean allowFullContext;
|
||||||
private boolean allowContextSensitifity;
|
private boolean allowContextSensitifity;
|
||||||
private boolean allowAmbiguity;
|
private boolean allowAmbiguity;
|
||||||
private int logLevel = 0;
|
private int logLevel = 0;
|
||||||
private int lexerLog;
|
private int lexerLogLevel = 0;
|
||||||
|
|
||||||
|
// private int lexerLogLevel = 0;
|
||||||
|
|
||||||
public ParserValidator run(String uri) {
|
public ParserValidator run(String uri) {
|
||||||
return run(uri, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
public ParserValidator runTest(String uri) {
|
|
||||||
return runTest(uri, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
public ParserValidator run(String uri, boolean searchMode) {
|
|
||||||
input = uri;
|
input = uri;
|
||||||
if (lexerLog> 0) {
|
if (lexerLogLevel > 0) {
|
||||||
(new TokenValidator()).log(lexerLog).run(input);
|
(new TokenValidator()).log(lexerLogLevel).run(input);
|
||||||
|
|
||||||
}
|
}
|
||||||
root = parseInput(uri, searchMode);
|
root = parseInput(uri);
|
||||||
|
// LOG > 0 - Write serialized tree
|
||||||
|
|
||||||
|
|
||||||
if (logLevel > 0) {
|
if (logLevel > 0) {
|
||||||
|
if (root != null) {
|
||||||
System.out.println(ParseTreeSerializer.getTreeAsText(root, new UriParserParser(null).getRuleNames()));
|
System.out.println(ParseTreeSerializer.getTreeAsText(root, new UriParserParser(null).getRuleNames()));
|
||||||
|
} else {
|
||||||
|
System.out.println("root == null");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// reset for nest test
|
// reset for next test
|
||||||
allowFullContext = false;
|
allowFullContext = false;
|
||||||
allowContextSensitifity = false;
|
allowContextSensitifity = false;
|
||||||
allowAmbiguity = false;
|
allowAmbiguity = false;
|
||||||
|
logLevel = 0;
|
||||||
|
|
||||||
exFirst();
|
// exFirst();
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ParserValidator runTest(String uri, boolean searchMode) {
|
|
||||||
input = uri;
|
|
||||||
root = parseInputTest(uri, searchMode);
|
|
||||||
|
|
||||||
if (logLevel > 0) {
|
|
||||||
|
|
||||||
System.out.println(ParseTreeSerializer.getTreeAsText(root, new UriParserParser(null).getRuleNames()));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// reset for nest test
|
|
||||||
allowFullContext = false;
|
|
||||||
allowContextSensitifity = false;
|
|
||||||
allowAmbiguity = false;
|
|
||||||
|
|
||||||
exFirst();
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,22 +151,40 @@ public class ParserValidator {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used in fast LL Parsing:
|
||||||
|
* Don't stops the parsing process when the slower full context parsing (with prediction mode SLL) is
|
||||||
|
* required
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public ParserValidator aFC() {
|
public ParserValidator aFC() {
|
||||||
allowFullContext = true;
|
allowFullContext = true;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used in fast LL Parsing:
|
||||||
|
* Allows ContextSensitifity Errors which occur often when using the slower full context parsing
|
||||||
|
* and indicate that there is a context sensitivity ( which may not be an error).
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public ParserValidator aCS() {
|
public ParserValidator aCS() {
|
||||||
allowContextSensitifity = true;
|
allowContextSensitifity = true;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used in fast LL Parsing:
|
||||||
|
* Allows ambiguities
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public ParserValidator aAM() {
|
public ParserValidator aAM() {
|
||||||
allowAmbiguity = true;
|
allowAmbiguity = true;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ParserValidator isText(String expected) {
|
public ParserValidator isText(String expected) {
|
||||||
|
// make sure that there are no exceptions
|
||||||
assertEquals(null, curException);
|
assertEquals(null, curException);
|
||||||
assertEquals(0, exceptions.size());
|
assertEquals(0, exceptions.size());
|
||||||
|
|
||||||
|
@ -144,8 +198,9 @@ public class ParserValidator {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
private OdataRelativeUriEOFContext parseInput(final String input, boolean searchMode) {
|
private OdataRelativeUriEOFContext parseInput(final String input) {
|
||||||
UriParserParser parser = null;
|
UriParserParser parser = null;
|
||||||
|
UriLexer lexer = null;
|
||||||
OdataRelativeUriEOFContext ret = null;
|
OdataRelativeUriEOFContext ret = null;
|
||||||
|
|
||||||
// Use 2 stage approach to improve performance
|
// Use 2 stage approach to improve performance
|
||||||
|
@ -156,86 +211,71 @@ public class ParserValidator {
|
||||||
try {
|
try {
|
||||||
curException = null;
|
curException = null;
|
||||||
exceptions.clear();
|
exceptions.clear();
|
||||||
parser = getNewParser(input, searchMode);
|
// create parser
|
||||||
|
lexer = new UriLexerTrace(this, new ANTLRInputStream(input));
|
||||||
|
parser = new UriParserParser(new CommonTokenStream(lexer));
|
||||||
|
|
||||||
|
// write single tokens to System.out
|
||||||
|
if (logLevel > 1) {
|
||||||
|
// can not be used because the listener is called bevore the mode changes
|
||||||
|
parser.addParseListener(new TokenWriter());
|
||||||
|
}
|
||||||
|
// write always a error message in case of syntax errors
|
||||||
|
parser.addErrorListener(new TraceErrorHandler<Object>());
|
||||||
|
// check error message if whether they are allowed or not
|
||||||
|
parser.addErrorListener(new ErrorCollector(this));
|
||||||
|
|
||||||
|
// Bail out of parser at first syntax error. --> procceds in catch block with step 2
|
||||||
parser.setErrorHandler(new BailErrorStrategy());
|
parser.setErrorHandler(new BailErrorStrategy());
|
||||||
|
|
||||||
|
// User the faster LL parsing
|
||||||
parser.getInterpreter().setPredictionMode(PredictionMode.LL);
|
parser.getInterpreter().setPredictionMode(PredictionMode.LL);
|
||||||
|
if (logLevel > 1) {
|
||||||
|
System.out.println("Step 1 (LL)");
|
||||||
|
}
|
||||||
ret = parser.odataRelativeUriEOF();
|
ret = parser.odataRelativeUriEOF();
|
||||||
|
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
curException = ex;
|
curException = ex;
|
||||||
//exceptionOnStage = 1;
|
|
||||||
// stage= 2
|
|
||||||
try {
|
try {
|
||||||
|
// clear status
|
||||||
curException = null;
|
curException = null;
|
||||||
exceptions.clear();
|
exceptions.clear();
|
||||||
parser = getNewParser(input, searchMode);
|
|
||||||
|
// create parser
|
||||||
|
lexer = new UriLexerTrace(this, new ANTLRInputStream(input));
|
||||||
|
parser = new UriParserParser(new CommonTokenStream(lexer));
|
||||||
|
|
||||||
|
// write single tokens to System.out
|
||||||
|
if (logLevel > 1) {
|
||||||
|
parser.addParseListener(new TokenWriter());
|
||||||
|
}
|
||||||
|
|
||||||
|
// write always a error message in case of syntax errors
|
||||||
|
parser.addErrorListener(new TraceErrorHandler<Object>());
|
||||||
|
// check error message if whether they are allowed or not
|
||||||
|
parser.addErrorListener(new ErrorCollector(this));
|
||||||
|
|
||||||
|
// Used default error strategy
|
||||||
parser.setErrorHandler(new DefaultErrorStrategy());
|
parser.setErrorHandler(new DefaultErrorStrategy());
|
||||||
|
|
||||||
|
// User the slower SLL parsing
|
||||||
parser.getInterpreter().setPredictionMode(PredictionMode.SLL);
|
parser.getInterpreter().setPredictionMode(PredictionMode.SLL);
|
||||||
|
|
||||||
|
if (logLevel > 1) {
|
||||||
|
System.out.println("Step 2 (SLL)");
|
||||||
|
}
|
||||||
ret = parser.odataRelativeUriEOF();
|
ret = parser.odataRelativeUriEOF();
|
||||||
|
|
||||||
} catch (Exception ex1) {
|
} catch (Exception ex1) {
|
||||||
curException = ex1;
|
curException = ex1;
|
||||||
//exceptionOnStage = 2;
|
// exceptionOnStage = 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
private TestContext parseInputTest(final String input, boolean searchMode) {
|
|
||||||
UriParserParser parser = null;
|
|
||||||
TestContext ret = null;
|
|
||||||
|
|
||||||
// Use 2 stage approach to improve performance
|
|
||||||
// see https://github.com/antlr/antlr4/issues/192
|
|
||||||
// TODO verify this
|
|
||||||
|
|
||||||
// stage= 1
|
|
||||||
try {
|
|
||||||
curException = null;
|
|
||||||
exceptions.clear();
|
|
||||||
parser = getNewParser(input, searchMode);
|
|
||||||
parser.setErrorHandler(new BailErrorStrategy());
|
|
||||||
parser.getInterpreter().setPredictionMode(PredictionMode.LL);
|
|
||||||
ret = parser.test();
|
|
||||||
} catch (Exception ex) {
|
|
||||||
curException = ex;
|
|
||||||
//exceptionOnStage = 1;
|
|
||||||
// stage= 2
|
|
||||||
try {
|
|
||||||
curException = null;
|
|
||||||
exceptions.clear();
|
|
||||||
parser = getNewParser(input, searchMode);
|
|
||||||
parser.setErrorHandler(new DefaultErrorStrategy());
|
|
||||||
parser.getInterpreter().setPredictionMode(PredictionMode.SLL);
|
|
||||||
ret = parser.test();
|
|
||||||
} catch (Exception ex1) {
|
|
||||||
curException = ex1;
|
|
||||||
//exceptionOnStage = 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
private UriParserParser getNewParser(final String input, boolean searchMode) {
|
|
||||||
ANTLRInputStream inputStream = new ANTLRInputStream(input);
|
|
||||||
|
|
||||||
// UriLexer lexer = new UriLexer(inputStream);
|
|
||||||
UriLexer lexer = new UriLexer(inputStream);
|
|
||||||
//lexer.setInSearch(searchMode);
|
|
||||||
// lexer.removeErrorListeners();
|
|
||||||
lexer.addErrorListener(new ErrorCollector(this));
|
|
||||||
CommonTokenStream tokens = new CommonTokenStream(lexer);
|
|
||||||
|
|
||||||
UriParserParser parser = new UriParserParser(tokens);
|
|
||||||
if ((lexerLog >0 ) || (logLevel > 0)) {
|
|
||||||
parser.addParseListener(new TokenWriter());
|
|
||||||
}
|
|
||||||
parser.addErrorListener(new TraceErrorHandler<Object>());
|
|
||||||
parser.addErrorListener(new ErrorCollector(this));
|
|
||||||
|
|
||||||
return parser;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static class ErrorCollector implements ANTLRErrorListener {
|
private static class ErrorCollector implements ANTLRErrorListener {
|
||||||
ParserValidator tokenValidator;
|
ParserValidator tokenValidator;
|
||||||
|
|
||||||
|
@ -250,21 +290,20 @@ public class ParserValidator {
|
||||||
tokenValidator.exceptions.add(e);
|
tokenValidator.exceptions.add(e);
|
||||||
trace(recognizer, offendingSymbol, line, charPositionInLine, msg, e);
|
trace(recognizer, offendingSymbol, line, charPositionInLine, msg, e);
|
||||||
|
|
||||||
fail("syntaxError"); // don't fail here we want to the error message at the caller
|
fail("syntaxError");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void reportAmbiguity(Parser recognizer, DFA dfa, int startIndex, int stopIndex, boolean exact,
|
public void reportAmbiguity(Parser recognizer, DFA dfa, int startIndex, int stopIndex, boolean exact,
|
||||||
BitSet ambigAlts, ATNConfigSet configs) {
|
BitSet ambigAlts, ATNConfigSet configs) {
|
||||||
|
|
||||||
|
|
||||||
if (!tokenValidator.allowAmbiguity) {
|
if (!tokenValidator.allowAmbiguity) {
|
||||||
System.out.println("reportAmbiguity " +
|
System.out.println("reportAmbiguity " +
|
||||||
ambigAlts + ":" + configs +
|
ambigAlts + ":" + configs +
|
||||||
", input=" + recognizer.getTokenStream().getText(Interval.of(startIndex, stopIndex)));
|
", input=" + recognizer.getTokenStream().getText(Interval.of(startIndex, stopIndex)));
|
||||||
printStack(recognizer);
|
printStack(recognizer);
|
||||||
fail("reportAmbiguity");
|
fail("reportAmbiguity");
|
||||||
} else {
|
} else if (tokenValidator.logLevel > 0) {
|
||||||
System.out.println("allowed Ambiguity " +
|
System.out.println("allowed Ambiguity " +
|
||||||
ambigAlts + ":" + configs +
|
ambigAlts + ":" + configs +
|
||||||
", input=" + recognizer.getTokenStream().getText(Interval.of(startIndex, stopIndex)));
|
", input=" + recognizer.getTokenStream().getText(Interval.of(startIndex, stopIndex)));
|
||||||
|
@ -280,7 +319,7 @@ public class ParserValidator {
|
||||||
if (!tokenValidator.allowFullContext) {
|
if (!tokenValidator.allowFullContext) {
|
||||||
printStack(recognizer);
|
printStack(recognizer);
|
||||||
fail("reportAttemptingFullContext");
|
fail("reportAttemptingFullContext");
|
||||||
} else {
|
} else if (tokenValidator.logLevel > 0) {
|
||||||
System.out.println("allowed AttemptingFullContext");
|
System.out.println("allowed AttemptingFullContext");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -291,9 +330,8 @@ public class ParserValidator {
|
||||||
if (!tokenValidator.allowContextSensitifity) {
|
if (!tokenValidator.allowContextSensitifity) {
|
||||||
printStack(recognizer);
|
printStack(recognizer);
|
||||||
fail("reportContextSensitivity");
|
fail("reportContextSensitivity");
|
||||||
} else {
|
} else if (tokenValidator.logLevel > 0) {
|
||||||
System.out.println("allowed ContextSensitivity");
|
System.out.println("allowed ContextSensitivity");
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -331,32 +369,31 @@ public class ParserValidator {
|
||||||
|
|
||||||
public ParserValidator exFirst() {
|
public ParserValidator exFirst() {
|
||||||
try {
|
try {
|
||||||
//curWeakException = exceptions.get(0);
|
// curWeakException = exceptions.get(0);
|
||||||
} catch (IndexOutOfBoundsException ex) {
|
} catch (IndexOutOfBoundsException ex) {
|
||||||
//curWeakException = null;
|
// curWeakException = null;
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public ParserValidator exLast() {
|
public ParserValidator exLast() {
|
||||||
//curWeakException = exceptions.get(exceptions.size() - 1);
|
// curWeakException = exceptions.get(exceptions.size() - 1);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ParserValidator exAt(int index) {
|
public ParserValidator exAt(int index) {
|
||||||
try {
|
try {
|
||||||
//curWeakException = exceptions.get(index);
|
// curWeakException = exceptions.get(index);
|
||||||
} catch (IndexOutOfBoundsException ex) {
|
} catch (IndexOutOfBoundsException ex) {
|
||||||
//curWeakException = null;
|
// curWeakException = null;
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ParserValidator lexerlog(int i) {
|
public ParserValidator lexerLog(int i) {
|
||||||
this.lexerLog = i;
|
lexerLogLevel = i;
|
||||||
return this;
|
return this;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one
|
* L icensed to the Apache Software Foundation (ASF) under one
|
||||||
* or more contributor license agreements. See the NOTICE file
|
* or more contributor license agreements. See the NOTICE file
|
||||||
* distributed with this work for additional information
|
* distributed with this work for additional information
|
||||||
* regarding copyright ownership. The ASF licenses this file
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
@ -22,15 +22,19 @@ import org.antlr.v4.runtime.ParserRuleContext;
|
||||||
import org.antlr.v4.runtime.tree.ErrorNode;
|
import org.antlr.v4.runtime.tree.ErrorNode;
|
||||||
import org.antlr.v4.runtime.tree.ParseTreeListener;
|
import org.antlr.v4.runtime.tree.ParseTreeListener;
|
||||||
import org.antlr.v4.runtime.tree.TerminalNode;
|
import org.antlr.v4.runtime.tree.TerminalNode;
|
||||||
import org.apache.olingo.producer.core.uri.antlr.UriLexer;
|
|
||||||
|
|
||||||
public class TokenWriter implements ParseTreeListener {
|
public class TokenWriter implements ParseTreeListener {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void visitTerminal(TerminalNode node) {
|
public void visitTerminal(TerminalNode node) {
|
||||||
String out = String.format("%1$-" + 20 + "s", node.getText()); ;
|
/*String out = String.format("%1$-" + 20 + "s", node.getText()); ;
|
||||||
out += UriLexer.tokenNames[node.getSymbol().getType()];
|
int tokenType = node.getSymbol().getType();
|
||||||
System.out.println(out);
|
if (tokenType == -1 ) {
|
||||||
|
out += "-1/EOF";
|
||||||
|
} else {
|
||||||
|
out += UriLexer.tokenNames[tokenType];
|
||||||
|
}
|
||||||
|
System.out.println(out); */
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -55,9 +55,10 @@ public class TestLexer {
|
||||||
test = new TokenValidator();
|
test = new TokenValidator();
|
||||||
}
|
}
|
||||||
|
|
||||||
// @Test
|
@Test
|
||||||
public void test() {
|
public void test() {
|
||||||
test.globalMode(UriLexer.MODE_QUERY);
|
test.globalMode(UriLexer.DEFAULT_MODE);
|
||||||
|
test.run("ODI?$filter=geo.distance(geometry'SRID=0;Point(142.1 64.1)',geometry'SRID=0;Point(142.1 64.1)')");
|
||||||
// test.log(1).run("$filter='ABC'").isText("ABC").isType(UriLexer.STRING);
|
// test.log(1).run("$filter='ABC'").isText("ABC").isType(UriLexer.STRING);
|
||||||
// test.log(1).run("ODI?$filter=1 add 2 mul 3");
|
// test.log(1).run("ODI?$filter=1 add 2 mul 3");
|
||||||
// test.log(1).run("1 + 2 + 3");
|
// test.log(1).run("1 + 2 + 3");
|
||||||
|
@ -137,7 +138,7 @@ public class TestLexer {
|
||||||
// ;------------------------------------------------------------------------------
|
// ;------------------------------------------------------------------------------
|
||||||
@Test
|
@Test
|
||||||
public void testQueryExpressions() {
|
public void testQueryExpressions() {
|
||||||
test.globalMode(UriLexer.MODE_SYSTEM_QUERY);
|
test.globalMode(UriLexer.DEFAULT_MODE);
|
||||||
// assertEquals("expected","actual");
|
// assertEquals("expected","actual");
|
||||||
|
|
||||||
test.run("$it").isText("$it").isType(UriLexer.IMPLICIT_VARIABLE_EXPR);
|
test.run("$it").isText("$it").isType(UriLexer.IMPLICIT_VARIABLE_EXPR);
|
||||||
|
@ -265,20 +266,15 @@ public class TestLexer {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testLiteralDataValues() {
|
public void testLiteralDataValues() {
|
||||||
test.globalMode(UriLexer.MODE_SYSTEM_QUERY);
|
test.globalMode(UriLexer.DEFAULT_MODE);
|
||||||
// null
|
// null
|
||||||
test.run("null").isInput().isType(UriLexer.NULLVALUE);
|
test.run("null").isInput().isType(UriLexer.NULLVALUE);
|
||||||
|
|
||||||
// binary
|
// binary
|
||||||
test.run("X'ABCD'").isInput().isType(UriLexer.BINARY);
|
|
||||||
test.run("X'ABCD'").isInput().isType(UriLexer.BINARY);
|
|
||||||
test.run("binary'ABCD'").isInput().isType(UriLexer.BINARY);
|
test.run("binary'ABCD'").isInput().isType(UriLexer.BINARY);
|
||||||
test.run("BiNaRy'ABCD'").isInput().isType(UriLexer.BINARY);
|
test.run("BiNaRy'ABCD'").isInput().isType(UriLexer.BINARY);
|
||||||
|
|
||||||
// not a binary TODO add error handling
|
// not a binary TODO add error handling
|
||||||
test.run("x'ABCDA'")
|
|
||||||
.at(0).isText("x").isType(UriLexer.ODATAIDENTIFIER)
|
|
||||||
.at(1).isText("'ABCDA'").isType(UriLexer.STRING);
|
|
||||||
test.run("BiNaRy'ABCDA'")
|
test.run("BiNaRy'ABCDA'")
|
||||||
.at(0).isText("BiNaRy").isType(UriLexer.ODATAIDENTIFIER)
|
.at(0).isText("BiNaRy").isType(UriLexer.ODATAIDENTIFIER)
|
||||||
.at(1).isText("'ABCDA'").isType(UriLexer.STRING);
|
.at(1).isText("'ABCDA'").isType(UriLexer.STRING);
|
||||||
|
|
|
@ -41,16 +41,22 @@ public class TestParser {
|
||||||
test = new ParserValidator();
|
test = new ParserValidator();
|
||||||
}
|
}
|
||||||
|
|
||||||
//@Test
|
@Test
|
||||||
public void test() {
|
public void test() {
|
||||||
String text = "ODI?$expand=*";
|
/*
|
||||||
text = "aa";
|
* test.log(2).run("ODI?$filter=geo.distance("+
|
||||||
|
* "geometry'SRID=0;Point(142.1 64.1)',geometry'SRID=0;Point(142.1 64.1)')")
|
||||||
(new TokenValidator()).log(1).run(text);
|
* .isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
// test.log(1).run(text);
|
* + "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
||||||
|
* + "queryOption(systemQueryOption("
|
||||||
//
|
* + "filter($filter = commonExpr(methodCallExpr("
|
||||||
|
* + "distanceMethodCallExpr("
|
||||||
|
* + "geo.distance( "
|
||||||
|
* + "commonExpr(primitiveLiteral(geometryPoint(geometry' fullpointLiteral(sridLiteral(SRID = 0 ;) "
|
||||||
|
* + "pointLiteral(Point pointData(( positionLiteral(142.1 64.1) )))) '))) , "
|
||||||
|
* + "commonExpr(primitiveLiteral(geometryPoint(geometry' fullpointLiteral(sridLiteral(SRID = 0 ;) "
|
||||||
|
* + "pointLiteral(Point pointData(( positionLiteral(142.1 64.1) )))) '))) ))))))))) <EOF>)");
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// ;------------------------------------------------------------------------------
|
// ;------------------------------------------------------------------------------
|
||||||
|
@ -277,7 +283,7 @@ public class TestParser {
|
||||||
+ "odataIdentifier(ODI)))) ? queryOptions(queryOption(systemQueryOption("
|
+ "odataIdentifier(ODI)))) ? queryOptions(queryOption(systemQueryOption("
|
||||||
+ "expand($expand = expandItemList("
|
+ "expand($expand = expandItemList("
|
||||||
+ "expandItem(expandPath(odataIdentifier(ODI)) "
|
+ "expandItem(expandPath(odataIdentifier(ODI)) "
|
||||||
+ "expandPathExtension(/ ref($ref) ( expandRefOption(skip($skip = 1)) ))))))))) <EOF>)");
|
+ "expandPathExtension(/ ref($ref) ( expandRefOption(skipInline($skip = 1)) ))))))))) <EOF>)");
|
||||||
|
|
||||||
test.run("ODI?$expand=ODI/$count").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("ODI?$expand=ODI/$count").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "resourcePath(pathSegments(pathSegment("
|
+ "resourcePath(pathSegments(pathSegment("
|
||||||
|
@ -292,7 +298,7 @@ public class TestParser {
|
||||||
+ "expand($expand = expandItemList("
|
+ "expand($expand = expandItemList("
|
||||||
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(/ count($count) ( "
|
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(/ count($count) ( "
|
||||||
+ "expandCountOption("
|
+ "expandCountOption("
|
||||||
+ "filter($filter = commonExpr(primitiveLiteral(1)))) ))))))))) <EOF>)");
|
+ "filterInline($filter = commonExpr(primitiveLiteral(1)))) ))))))))) <EOF>)");
|
||||||
|
|
||||||
test.run("ODI?$expand=ODI/$count($search=\"abc\")").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("ODI?$expand=ODI/$count($search=\"abc\")").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "resourcePath(pathSegments(pathSegment("
|
+ "resourcePath(pathSegments(pathSegment("
|
||||||
|
@ -300,25 +306,25 @@ public class TestParser {
|
||||||
+ "expand($expand = expandItemList("
|
+ "expand($expand = expandItemList("
|
||||||
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(/ count($count) ( "
|
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(/ count($count) ( "
|
||||||
+ "expandCountOption("
|
+ "expandCountOption("
|
||||||
+ "search($search searchSpecialToken(= searchExpr(searchPhrase(\"abc\"))))) ))))))))) <EOF>)");
|
+ "searchInline($search searchSpecialToken(= searchExpr(searchPhrase(\"abc\"))))) ))))))))) <EOF>)");
|
||||||
|
|
||||||
test.run("ODI?$expand=ODI/$ref($skip=1;$filter=true)").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("ODI?$expand=ODI/$ref($skip=1;$filter=true)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "resourcePath(pathSegments(pathSegment("
|
+ "resourcePath(pathSegments(pathSegment("
|
||||||
+ "odataIdentifier(ODI)))) ? queryOptions(queryOption(systemQueryOption("
|
+ "odataIdentifier(ODI)))) ? queryOptions(queryOption(systemQueryOption("
|
||||||
+ "expand($expand = expandItemList("
|
+ "expand($expand = expandItemList("
|
||||||
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(/ ref($ref) ( "
|
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(/ ref($ref) ( "
|
||||||
+ "expandRefOption(skip($skip = 1)) ; "
|
+ "expandRefOption(skipInline($skip = 1)) ; "
|
||||||
+ "expandRefOption(expandCountOption("
|
+ "expandRefOption(expandCountOption("
|
||||||
+ "filter($filter = commonExpr(primitiveLiteral(booleanNonCase(true)))))) ))))))))) <EOF>)");
|
+ "filterInline($filter = commonExpr(primitiveLiteral(booleanNonCase(true)))))) ))))))))) <EOF>)");
|
||||||
|
|
||||||
test.run("ODI?$expand=ODI($skip=1;$filter=true)").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("ODI?$expand=ODI($skip=1;$filter=true)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "resourcePath(pathSegments(pathSegment("
|
+ "resourcePath(pathSegments(pathSegment("
|
||||||
+ "odataIdentifier(ODI)))) ? queryOptions(queryOption(systemQueryOption("
|
+ "odataIdentifier(ODI)))) ? queryOptions(queryOption(systemQueryOption("
|
||||||
+ "expand($expand = expandItemList("
|
+ "expand($expand = expandItemList("
|
||||||
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(( "
|
+ "expandItem(expandPath(odataIdentifier(ODI)) expandPathExtension(( "
|
||||||
+ "expandOption(expandRefOption(skip($skip = 1))) ; "
|
+ "expandOption(expandRefOption(skipInline($skip = 1))) ; "
|
||||||
+ "expandOption(expandRefOption(expandCountOption("
|
+ "expandOption(expandRefOption(expandCountOption("
|
||||||
+ "filter($filter = commonExpr(primitiveLiteral(booleanNonCase(true))))))) ))))))))) <EOF>)");
|
+ "filterInline($filter = commonExpr(primitiveLiteral(booleanNonCase(true))))))) ))))))))) <EOF>)");
|
||||||
|
|
||||||
// Test parser rule filter ( more filter test in method testExpressions)
|
// Test parser rule filter ( more filter test in method testExpressions)
|
||||||
test.run("ODI?$filter=true")
|
test.run("ODI?$filter=true")
|
||||||
|
@ -347,11 +353,12 @@ public class TestParser {
|
||||||
+ "queryOption(systemQueryOption(id($id = abc))))) <EOF>)");
|
+ "queryOption(systemQueryOption(id($id = abc))))) <EOF>)");
|
||||||
|
|
||||||
// Test parser rule count
|
// Test parser rule count
|
||||||
/* TODO add count to new mode based lexer
|
/*
|
||||||
test.lexerlog(1).run("ODI?$count=true").isText("odataRelativeUriEOF(odataRelativeUri("
|
* TODO add count to new mode based lexer
|
||||||
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions(queryOption("
|
* test.lexerlog(1).run("ODI?$count=true").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "systemQueryOption("
|
* + "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions(queryOption("
|
||||||
+ "inlinecount($count = booleanNonCase(true)))))) <EOF>)");
|
* + "systemQueryOption("
|
||||||
|
* + "inlinecount($count = booleanNonCase(true)))))) <EOF>)");
|
||||||
*/
|
*/
|
||||||
test.run("ODI?$count=false").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("ODI?$count=false").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions(queryOption("
|
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions(queryOption("
|
||||||
|
@ -562,11 +569,6 @@ public class TestParser {
|
||||||
+ "queryOption(systemQueryOption(filter($filter = commonExpr("
|
+ "queryOption(systemQueryOption(filter($filter = commonExpr("
|
||||||
+ "primitiveLiteral(-1.2e-3))))))) <EOF>)");
|
+ "primitiveLiteral(-1.2e-3))))))) <EOF>)");
|
||||||
|
|
||||||
test.run("ODI?$filter=X'12AB'").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
|
||||||
+ "queryOption(systemQueryOption(filter($filter = commonExpr("
|
|
||||||
+ "primitiveLiteral(X'12AB'))))))) <EOF>)");
|
|
||||||
|
|
||||||
test.run("ODI?$filter=binary'12AB'").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("ODI?$filter=binary'12AB'").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
||||||
+ "queryOption(systemQueryOption(filter($filter = commonExpr("
|
+ "queryOption(systemQueryOption(filter($filter = commonExpr("
|
||||||
|
@ -957,23 +959,22 @@ public class TestParser {
|
||||||
+ "filter($filter = commonExpr(methodCallExpr("
|
+ "filter($filter = commonExpr(methodCallExpr("
|
||||||
+ "ceilingMethodCallExpr(ceiling( commonExpr(primitiveLiteral(12.34)) ))))))))) <EOF>)");
|
+ "ceilingMethodCallExpr(ceiling( commonExpr(primitiveLiteral(12.34)) ))))))))) <EOF>)");
|
||||||
|
|
||||||
/* TODO reenable GEOMETRY
|
test.run("ODI?$filter=geo.distance(geometry'SRID=0;Point(142.1 64.1)',geometry'SRID=0;Point(142.1 64.1)')")
|
||||||
test.run("ODI?$filter=geo.distance(geometry'SRID=0;Point(142.1 64.1)',geometry'SRID=0;Point(142.1 64.1)')")
|
.isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
.isText("odataRelativeUriEOF(odataRelativeUri("
|
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
||||||
+ "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
+ "queryOption(systemQueryOption("
|
||||||
+ "queryOption(systemQueryOption("
|
+ "filter($filter = commonExpr(methodCallExpr("
|
||||||
+ "filter($filter = commonExpr(methodCallExpr("
|
+ "distanceMethodCallExpr("
|
||||||
+ "distanceMethodCallExpr("
|
+ "geo.distance( "
|
||||||
+ "geo.distance( "
|
+ "commonExpr(primitiveLiteral(geometryPoint(geometry' fullpointLiteral(sridLiteral(SRID = 0 ;) "
|
||||||
+ "commonExpr(primitiveLiteral(geometryPoint(geometry' fullpointLiteral(sridLiteral(SRID = 0 ;) "
|
+ "pointLiteral(Point pointData(( positionLiteral(142.1 64.1) )))) '))) , "
|
||||||
+ "pointLiteral(Point pointData(( positionLiteral(142.1 64.1) )))) '))) , "
|
+ "commonExpr(primitiveLiteral(geometryPoint(geometry' fullpointLiteral(sridLiteral(SRID = 0 ;) "
|
||||||
+ "commonExpr(primitiveLiteral(geometryPoint(geometry' fullpointLiteral(sridLiteral(SRID = 0 ;) "
|
+ "pointLiteral(Point pointData(( positionLiteral(142.1 64.1) )))) '))) ))))))))) <EOF>)");
|
||||||
+ "pointLiteral(Point pointData(( positionLiteral(142.1 64.1) )))) '))) ))))))))) <EOF>)");
|
|
||||||
*/
|
// TODO check this
|
||||||
// TODO check this
|
/*
|
||||||
/*
|
* test.run("ODI?$filter=geo.length(geometry'SRID=0;LineString(142.1 64.1,3.14 2.78)')")
|
||||||
test.run("ODI?$filter=geo.length(geometry'SRID=0;LineString(142.1 64.1,3.14 2.78)')")
|
* .isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
.isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
* + "resourcePath(pathSegments(pathSegment(odataIdentifier(ODI)))) ? queryOptions("
|
||||||
* + "queryOption(systemQueryOption(filter($filter = commonExpr(methodCallExpr("
|
* + "queryOption(systemQueryOption(filter($filter = commonExpr(methodCallExpr("
|
||||||
* + "geoLengthMethodCallExpr(geo.length ( commonExpr(primitiveLiteral("
|
* + "geoLengthMethodCallExpr(geo.length ( commonExpr(primitiveLiteral("
|
||||||
|
@ -1184,132 +1185,133 @@ public class TestParser {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFragment() {
|
public void testFragment() {
|
||||||
/*
|
|
||||||
* test.run("$metadata#Collection($ref)").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("$metadata#Collection($ref)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "$metadata # contextFragment(Collection($ref))) <EOF>)");
|
+ "$metadata # contextFragment(Collection($ref))) <EOF>)");
|
||||||
*
|
|
||||||
* test.run("$metadata#Collection(Edm.EntityType)").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("$metadata#Collection(Edm.EntityType)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "$metadata # contextFragment(Collection(Edm.EntityType))) <EOF>)");
|
+ "$metadata # contextFragment(Collection(Edm.EntityType))) <EOF>)");
|
||||||
*
|
|
||||||
* test.run("$metadata#Collection(Edm.ComplexType)").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("$metadata#Collection(Edm.ComplexType)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "$metadata # contextFragment(Collection(Edm.ComplexType))) <EOF>)");
|
+ "$metadata # contextFragment(Collection(Edm.ComplexType))) <EOF>)");
|
||||||
*
|
|
||||||
* test.run("$metadata#singletonEntity").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("$metadata#singletonEntity").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "$metadata # contextFragment(odataIdentifier(singletonEntity))) <EOF>)");
|
+ "$metadata # contextFragment(odataIdentifier(singletonEntity))) <EOF>)");
|
||||||
*
|
|
||||||
* test.run("$metadata#NS.ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("$metadata#NS.ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "$metadata # contextFragment(namespace(odataIdentifier(NS) .) odataIdentifier(ODI))) <EOF>)");
|
+ "$metadata # contextFragment(namespace(odataIdentifier(NS) .) odataIdentifier(ODI))) <EOF>)");
|
||||||
*
|
|
||||||
* test.run("$metadata#Edm.Boolean").isText("odataRelativeUriEOF(odataRelativeUri("
|
test.run("$metadata#Edm.Boolean").isText("odataRelativeUriEOF("
|
||||||
* + "$metadata # contextFragment(Edm.Boolean)) <EOF>)");
|
+ "odataRelativeUri($metadata # "
|
||||||
*
|
+ "contextFragment(namespace(odataIdentifier(Edm) .) odataIdentifier(Boolean))) <EOF>)");
|
||||||
* test.run("$metadata#ODI/$deletedEntity").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) /$deletedEntity)) <EOF>)");
|
test.run("$metadata#ODI/$deletedEntity").isText("odataRelativeUriEOF("
|
||||||
*
|
+ "odataRelativeUri($metadata # contextFragment(odataIdentifier(ODI) / $deletedEntity)) <EOF>)");
|
||||||
* test.run("$metadata#ODI/$link").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) /$link)) <EOF>)");
|
test.run("$metadata#ODI/$link").isText("odataRelativeUriEOF("
|
||||||
*
|
+ "odataRelativeUri($metadata # contextFragment(odataIdentifier(ODI) / $link)) <EOF>)");
|
||||||
* test.run("$metadata#ODI/$deletedLink").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) /$deletedLink)) <EOF>)");
|
test.run("$metadata#ODI/$deletedLink").isText("odataRelativeUriEOF("
|
||||||
*
|
+ "odataRelativeUri($metadata # contextFragment(odataIdentifier(ODI) / $deletedLink)) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
test.run("$metadata#ODI(1)/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "/ odataIdentifier(ODI))) <EOF>)");
|
+ "$metadata # contextFragment(odataIdentifier(ODI) nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
*
|
+ "/ odataIdentifier(ODI))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)/NS.ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
test.run("$metadata#ODI(1)/NS.ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI))) <EOF>)");
|
+ "$metadata # contextFragment(odataIdentifier(ODI) nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
*
|
+ "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)/NS.ODI/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)/NS.ODI/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI) "
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* + "/ odataIdentifier(ODI))) <EOF>)");
|
+ "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI) "
|
||||||
*
|
+ "/ odataIdentifier(ODI))) <EOF>)");
|
||||||
* test.run("$metadata#NS.ODI(*)").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(namespace(odataIdentifier(NS) .) odataIdentifier(ODI) "
|
test.run("$metadata#NS.ODI(*)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "propertyList(( propertyListItem(*) )))) <EOF>)");
|
+ "$metadata # contextFragment(namespace(odataIdentifier(NS) .) odataIdentifier(ODI) "
|
||||||
*
|
+ "propertyList(( propertyListItem(*) )))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))))) <EOF>)");
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
*
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "/ odataIdentifier(ODI))) <EOF>)");
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
*
|
+ "/ odataIdentifier(ODI))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)/NS.ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)/NS.ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI))) <EOF>)");
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
*
|
+ "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)/NS.ODI/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)/NS.ODI/ODI").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI) / odataIdentifier(ODI))) <EOF>)");
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
*
|
+ "/ namespace(odataIdentifier(NS) .) odataIdentifier(ODI) / odataIdentifier(ODI))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)(*)").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(*)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) propertyList(( propertyListItem(*) )))) <EOF>)");
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
*
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) propertyList(( propertyListItem(*) )))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)(PROP)").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(PROP)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( propertyListItem(propertyListProperty(odataIdentifier(PROP))) )))) <EOF>)");
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* test.run("$metadata#ODI(1)(NAVPROP+)").isText("odataRelativeUriEOF(odataRelativeUri("
|
+ "propertyList(( propertyListItem(propertyListProperty(odataIdentifier(PROP))) )))) <EOF>)");
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(NAVPROP+)").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) +)) )))) <EOF>)");
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* test.run("$metadata#ODI(1)(NAVPROP+(*))").isText("odataRelativeUriEOF(odataRelativeUri("
|
+ "propertyList(( propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) +)) )))) <EOF>)");
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(NAVPROP+(*))").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( "
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
+ "propertyList(( "
|
||||||
* + "propertyList(( "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
||||||
* + "propertyListItem(*) )))) )))) <EOF>)");
|
+ "propertyList(( "
|
||||||
* test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))").isText("odataRelativeUriEOF(odataRelativeUri("
|
+ "propertyListItem(*) )))) )))) <EOF>)");
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( "
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
+ "propertyList(( "
|
||||||
* + "propertyList(( "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
+ "propertyList(( "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )))) <EOF>)");
|
+ "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
||||||
*
|
+ "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )))) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))/$delta").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))/$delta").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( "
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
+ "propertyList(( "
|
||||||
* + "propertyList(( "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
+ "propertyList(( "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )) "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
||||||
* + "/$delta)) <EOF>)");
|
+ "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )) "
|
||||||
*
|
+ "/ $delta)) <EOF>)");
|
||||||
* test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))/$entity").isText("odataRelativeUriEOF(odataRelativeUri("
|
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))/$entity").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( "
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
+ "propertyList(( "
|
||||||
* + "propertyList(( "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
+ "propertyList(( "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )) "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
||||||
* + "entity(/$entity))) <EOF>)");
|
+ "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )) "
|
||||||
* test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))/$delta/$entity").isText("odataRelativeUriEOF(odataRelativeUri("
|
+ "/ $entity)) <EOF>)");
|
||||||
* + "$metadata # contextFragment(odataIdentifier(ODI) "
|
test.run("$metadata#ODI(1)(NAVPROP+(A,B,C))/$delta/$entity").isText("odataRelativeUriEOF(odataRelativeUri("
|
||||||
* + "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
+ "$metadata # contextFragment(odataIdentifier(ODI) "
|
||||||
* + "propertyList(( "
|
+ "nameValueOptList(valueOnly(( primitiveLiteral(1) ))) "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
+ "propertyList(( "
|
||||||
* + "propertyList(( "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(NAVPROP) + "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
+ "propertyList(( "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(A))) , "
|
||||||
* + "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )) "
|
+ "propertyListItem(propertyListProperty(odataIdentifier(B))) , "
|
||||||
* + "/$delta entity(/$entity))) <EOF>)");
|
+ "propertyListItem(propertyListProperty(odataIdentifier(C))) )))) )) "
|
||||||
*/
|
+ "/ $delta / $entity)) <EOF>)");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
Loading…
Reference in New Issue