|
12 | 12 | * limitations under the License. |
13 | 13 | */ |
14 | 14 |
|
15 | | -Start = initial:_? thing:(SqlQueryWithPossibleContext / SqlAlias) final:_sc? |
| 15 | +Start = initial:_ thing:(SqlQueryWithPossibleContext / SqlAlias) final:_sc |
16 | 16 | { |
17 | 17 | if (initial) thing = thing.changeSpace('initial', initial); |
18 | 18 | if (final) thing = thing.changeSpace('final', final); |
19 | 19 | return thing; |
20 | 20 | } |
21 | 21 |
|
| 22 | +StartSetStatementsOnly = spaceBefore:_ statements:(SqlSetStatement _sc)* rest:$(.*) |
| 23 | +{ |
| 24 | + let ret = { |
| 25 | + spaceBefore: spaceBefore, |
| 26 | + rest: rest |
| 27 | + } |
| 28 | + |
| 29 | + if (statements.length) { |
| 30 | + ret.contextStatements = new S.SeparatedArray( |
| 31 | + statements.map(function(x) { return x[0] }), |
| 32 | + statements.map(function(x) { return x[1] }).slice(0, statements.length - 1) |
| 33 | + ); |
| 34 | + ret.spaceAfter = statements[statements.length - 1][1]; |
| 35 | + } |
| 36 | + |
| 37 | + return ret; |
| 38 | +} |
| 39 | + |
22 | 40 | // ------------------------------ |
23 | 41 |
|
24 | 42 | SqlAlias = expression:Expression alias:((_ AsToken)? _ RefNameAlias)? columns:(_ SqlColumnList)? |
@@ -62,6 +80,38 @@ SqlLabeledExpression = label:RefNameAlias preArrow:_ "=>" postArrow:_ expression |
62 | 80 | }); |
63 | 81 | } |
64 | 82 |
|
| 83 | +SqlKeyValue = LongKeyValueForm / ShortKeyValueForm |
| 84 | + |
| 85 | +LongKeyValueForm = keyToken:KeyToken postKey:_ key:Expression postKeyExpression:_ valueToken:ValueToken preValueExpression:_ value:Expression |
| 86 | +{ |
| 87 | + return new S.SqlKeyValue({ |
| 88 | + key: key, |
| 89 | + value: value, |
| 90 | + spacing: { |
| 91 | + postKey: postKey, |
| 92 | + postKeyExpression: postKeyExpression, |
| 93 | + preValueExpression: preValueExpression |
| 94 | + }, |
| 95 | + keywords: { |
| 96 | + key: keyToken, |
| 97 | + value: valueToken |
| 98 | + } |
| 99 | + }); |
| 100 | +} |
| 101 | + |
| 102 | +ShortKeyValueForm = key:Expression postKeyExpression:_ ":" preValueExpression:_ value:Expression |
| 103 | +{ |
| 104 | + return new S.SqlKeyValue({ |
| 105 | + key: key, |
| 106 | + value: value, |
| 107 | + short: true, |
| 108 | + spacing: { |
| 109 | + postKeyExpression: postKeyExpression, |
| 110 | + preValueExpression: preValueExpression |
| 111 | + } |
| 112 | + }); |
| 113 | +} |
| 114 | + |
65 | 115 | SqlExtendClause = |
66 | 116 | extend:(ExtendToken _)? |
67 | 117 | OpenParen |
@@ -1010,6 +1060,7 @@ Function = |
1010 | 1060 | / TimestampAddDiffFunction |
1011 | 1061 | / PositionFunction |
1012 | 1062 | / JsonValueReturningFunction |
| 1063 | +/ JsonObjectFunction |
1013 | 1064 | / ArrayFunction |
1014 | 1065 | / NakedFunction |
1015 | 1066 |
|
@@ -1171,6 +1222,32 @@ JsonValueReturningFunction = |
1171 | 1222 | }); |
1172 | 1223 | } |
1173 | 1224 |
|
| 1225 | +JsonObjectFunction = |
| 1226 | + functionName:JsonObjectToken |
| 1227 | + preLeftParen:_ |
| 1228 | + OpenParen |
| 1229 | + postLeftParen:_ |
| 1230 | + head:SqlKeyValue? |
| 1231 | + tail:(CommaSeparator SqlKeyValue)* |
| 1232 | + postArguments:_ |
| 1233 | + CloseParen |
| 1234 | +{ |
| 1235 | + var value = { |
| 1236 | + functionName: makeFunctionName(functionName) |
| 1237 | + }; |
| 1238 | + var spacing = value.spacing = { |
| 1239 | + preLeftParen: preLeftParen, |
| 1240 | + postLeftParen: postLeftParen |
| 1241 | + }; |
| 1242 | + |
| 1243 | + if (head) { |
| 1244 | + value.args = makeSeparatedArray(head, tail); |
| 1245 | + spacing.postArguments = postArguments; |
| 1246 | + } |
| 1247 | + |
| 1248 | + return new S.SqlFunction(value); |
| 1249 | +} |
| 1250 | + |
1174 | 1251 | ExtractFunction = |
1175 | 1252 | functionName:(ExtractToken / ('"' ExtractToken '"')) |
1176 | 1253 | preLeftParen:_ |
@@ -1881,6 +1958,9 @@ IntoToken = $("INTO"i !IdentifierPart) |
1881 | 1958 | IsToken = $("IS"i !IdentifierPart) |
1882 | 1959 | JoinToken = $("JOIN"i !IdentifierPart) |
1883 | 1960 | JsonValueToken = $("JSON_VALUE"i !IdentifierPart) |
| 1961 | +JsonObjectToken = $("JSON_OBJECT"i !IdentifierPart) |
| 1962 | +KeyToken = $("KEY"i !IdentifierPart) |
| 1963 | +ValueToken = $("VALUE"i !IdentifierPart) |
1884 | 1964 | LeadingToken = $("LEADING"i !IdentifierPart) |
1885 | 1965 | LikeToken = $("LIKE"i !IdentifierPart) |
1886 | 1966 | LimitToken = $("LIMIT"i !IdentifierPart) |
|
0 commit comments