rawsql-ts 0.11.42-beta → 0.11.44-beta

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (278) hide show
  1. package/README.md +12 -13
  2. package/dist/esm/index.js +18 -0
  3. package/dist/esm/index.js.map +1 -1
  4. package/dist/esm/index.min.js +23 -18
  5. package/dist/esm/index.min.js.map +4 -4
  6. package/dist/esm/src/index.d.ts +18 -0
  7. package/dist/esm/src/index.js +18 -0
  8. package/dist/esm/src/index.js.map +1 -1
  9. package/dist/esm/src/models/BinarySelectQuery.d.ts +25 -1
  10. package/dist/esm/src/models/BinarySelectQuery.js +28 -0
  11. package/dist/esm/src/models/BinarySelectQuery.js.map +1 -1
  12. package/dist/esm/src/models/Clause.d.ts +14 -2
  13. package/dist/esm/src/models/Clause.js +26 -1
  14. package/dist/esm/src/models/Clause.js.map +1 -1
  15. package/dist/esm/src/models/CreateTableQuery.d.ts +99 -5
  16. package/dist/esm/src/models/CreateTableQuery.js +85 -10
  17. package/dist/esm/src/models/CreateTableQuery.js.map +1 -1
  18. package/dist/esm/src/models/DDLStatements.d.ts +157 -0
  19. package/dist/esm/src/models/DDLStatements.js +141 -0
  20. package/dist/esm/src/models/DDLStatements.js.map +1 -0
  21. package/dist/esm/src/models/DeleteQuery.d.ts +17 -0
  22. package/dist/esm/src/models/DeleteQuery.js +16 -0
  23. package/dist/esm/src/models/DeleteQuery.js.map +1 -0
  24. package/dist/esm/src/models/InsertQuery.d.ts +7 -1
  25. package/dist/esm/src/models/InsertQuery.js +6 -2
  26. package/dist/esm/src/models/InsertQuery.js.map +1 -1
  27. package/dist/esm/src/models/MergeQuery.d.ts +63 -0
  28. package/dist/esm/src/models/MergeQuery.js +94 -0
  29. package/dist/esm/src/models/MergeQuery.js.map +1 -0
  30. package/dist/esm/src/models/SelectQuery.d.ts +37 -1
  31. package/dist/esm/src/models/SelectQuery.js +4 -1
  32. package/dist/esm/src/models/SelectQuery.js.map +1 -1
  33. package/dist/esm/src/models/SimpleSelectQuery.d.ts +29 -1
  34. package/dist/esm/src/models/SimpleSelectQuery.js +32 -0
  35. package/dist/esm/src/models/SimpleSelectQuery.js.map +1 -1
  36. package/dist/esm/src/models/SqlComponent.d.ts +2 -1
  37. package/dist/esm/src/models/SqlComponent.js +1 -1
  38. package/dist/esm/src/models/SqlComponent.js.map +1 -1
  39. package/dist/esm/src/models/SqlPrintToken.d.ts +33 -0
  40. package/dist/esm/src/models/SqlPrintToken.js +32 -0
  41. package/dist/esm/src/models/SqlPrintToken.js.map +1 -1
  42. package/dist/esm/src/models/ValuesQuery.d.ts +25 -1
  43. package/dist/esm/src/models/ValuesQuery.js +28 -0
  44. package/dist/esm/src/models/ValuesQuery.js.map +1 -1
  45. package/dist/esm/src/parsers/AlterTableParser.d.ts +25 -0
  46. package/dist/esm/src/parsers/AlterTableParser.js +428 -0
  47. package/dist/esm/src/parsers/AlterTableParser.js.map +1 -0
  48. package/dist/esm/src/parsers/CreateIndexParser.d.ts +16 -0
  49. package/dist/esm/src/parsers/CreateIndexParser.js +237 -0
  50. package/dist/esm/src/parsers/CreateIndexParser.js.map +1 -0
  51. package/dist/esm/src/parsers/CreateTableParser.d.ts +41 -0
  52. package/dist/esm/src/parsers/CreateTableParser.js +734 -0
  53. package/dist/esm/src/parsers/CreateTableParser.js.map +1 -0
  54. package/dist/esm/src/parsers/DeleteClauseParser.d.ts +11 -0
  55. package/dist/esm/src/parsers/DeleteClauseParser.js +33 -0
  56. package/dist/esm/src/parsers/DeleteClauseParser.js.map +1 -0
  57. package/dist/esm/src/parsers/DeleteQueryParser.d.ts +16 -0
  58. package/dist/esm/src/parsers/DeleteQueryParser.js +73 -0
  59. package/dist/esm/src/parsers/DeleteQueryParser.js.map +1 -0
  60. package/dist/esm/src/parsers/DropConstraintParser.d.ts +12 -0
  61. package/dist/esm/src/parsers/DropConstraintParser.js +47 -0
  62. package/dist/esm/src/parsers/DropConstraintParser.js.map +1 -0
  63. package/dist/esm/src/parsers/DropIndexParser.d.ts +12 -0
  64. package/dist/esm/src/parsers/DropIndexParser.js +69 -0
  65. package/dist/esm/src/parsers/DropIndexParser.js.map +1 -0
  66. package/dist/esm/src/parsers/DropTableParser.d.ts +12 -0
  67. package/dist/esm/src/parsers/DropTableParser.js +59 -0
  68. package/dist/esm/src/parsers/DropTableParser.js.map +1 -0
  69. package/dist/esm/src/parsers/FunctionExpressionParser.d.ts +4 -0
  70. package/dist/esm/src/parsers/FunctionExpressionParser.js +25 -8
  71. package/dist/esm/src/parsers/FunctionExpressionParser.js.map +1 -1
  72. package/dist/esm/src/parsers/InsertQueryParser.js +103 -31
  73. package/dist/esm/src/parsers/InsertQueryParser.js.map +1 -1
  74. package/dist/esm/src/parsers/MergeQueryParser.d.ts +26 -0
  75. package/dist/esm/src/parsers/MergeQueryParser.js +479 -0
  76. package/dist/esm/src/parsers/MergeQueryParser.js.map +1 -0
  77. package/dist/esm/src/parsers/ReturningClauseParser.js +50 -7
  78. package/dist/esm/src/parsers/ReturningClauseParser.js.map +1 -1
  79. package/dist/esm/src/parsers/SelectClauseParser.js +3 -3
  80. package/dist/esm/src/parsers/SelectClauseParser.js.map +1 -1
  81. package/dist/esm/src/parsers/SelectQueryParser.d.ts +4 -0
  82. package/dist/esm/src/parsers/SelectQueryParser.js +4 -0
  83. package/dist/esm/src/parsers/SelectQueryParser.js.map +1 -1
  84. package/dist/esm/src/parsers/SetClauseParser.js +97 -15
  85. package/dist/esm/src/parsers/SetClauseParser.js.map +1 -1
  86. package/dist/esm/src/parsers/SqlParser.d.ts +38 -0
  87. package/dist/esm/src/parsers/SqlParser.js +344 -0
  88. package/dist/esm/src/parsers/SqlParser.js.map +1 -0
  89. package/dist/esm/src/parsers/SqlPrintTokenParser.d.ts +68 -21
  90. package/dist/esm/src/parsers/SqlPrintTokenParser.js +1145 -254
  91. package/dist/esm/src/parsers/SqlPrintTokenParser.js.map +1 -1
  92. package/dist/esm/src/parsers/SqlTokenizer.d.ts +24 -2
  93. package/dist/esm/src/parsers/SqlTokenizer.js +135 -74
  94. package/dist/esm/src/parsers/SqlTokenizer.js.map +1 -1
  95. package/dist/esm/src/parsers/UpdateQueryParser.js +11 -1
  96. package/dist/esm/src/parsers/UpdateQueryParser.js.map +1 -1
  97. package/dist/esm/src/parsers/UsingClauseParser.d.ts +11 -0
  98. package/dist/esm/src/parsers/UsingClauseParser.js +29 -0
  99. package/dist/esm/src/parsers/UsingClauseParser.js.map +1 -0
  100. package/dist/esm/src/parsers/ValueParser.js +5 -1
  101. package/dist/esm/src/parsers/ValueParser.js.map +1 -1
  102. package/dist/esm/src/parsers/ValuesQueryParser.d.ts +0 -2
  103. package/dist/esm/src/parsers/ValuesQueryParser.js +5 -45
  104. package/dist/esm/src/parsers/ValuesQueryParser.js.map +1 -1
  105. package/dist/esm/src/parsers/utils/LexemeCommentUtils.d.ts +6 -0
  106. package/dist/esm/src/parsers/utils/LexemeCommentUtils.js +26 -0
  107. package/dist/esm/src/parsers/utils/LexemeCommentUtils.js.map +1 -0
  108. package/dist/esm/src/tokenReaders/CommandTokenReader.js +49 -2
  109. package/dist/esm/src/tokenReaders/CommandTokenReader.js.map +1 -1
  110. package/dist/esm/src/tokenReaders/LiteralTokenReader.js +8 -5
  111. package/dist/esm/src/tokenReaders/LiteralTokenReader.js.map +1 -1
  112. package/dist/esm/src/tokenReaders/OperatorTokenReader.js +10 -1
  113. package/dist/esm/src/tokenReaders/OperatorTokenReader.js.map +1 -1
  114. package/dist/esm/src/tokenReaders/TypeTokenReader.js +11 -1
  115. package/dist/esm/src/tokenReaders/TypeTokenReader.js.map +1 -1
  116. package/dist/esm/src/transformers/InsertQuerySelectValuesConverter.d.ts +18 -0
  117. package/dist/esm/src/transformers/InsertQuerySelectValuesConverter.js +118 -0
  118. package/dist/esm/src/transformers/InsertQuerySelectValuesConverter.js.map +1 -0
  119. package/dist/esm/src/transformers/LinePrinter.d.ts +2 -0
  120. package/dist/esm/src/transformers/LinePrinter.js +34 -1
  121. package/dist/esm/src/transformers/LinePrinter.js.map +1 -1
  122. package/dist/esm/src/transformers/OnelineFormattingHelper.d.ts +29 -0
  123. package/dist/esm/src/transformers/OnelineFormattingHelper.js +88 -0
  124. package/dist/esm/src/transformers/OnelineFormattingHelper.js.map +1 -0
  125. package/dist/esm/src/transformers/QueryBuilder.d.ts +47 -13
  126. package/dist/esm/src/transformers/QueryBuilder.js +424 -62
  127. package/dist/esm/src/transformers/QueryBuilder.js.map +1 -1
  128. package/dist/esm/src/transformers/SqlFormatter.d.ts +13 -3
  129. package/dist/esm/src/transformers/SqlFormatter.js +13 -4
  130. package/dist/esm/src/transformers/SqlFormatter.js.map +1 -1
  131. package/dist/esm/src/transformers/SqlPrinter.d.ts +63 -10
  132. package/dist/esm/src/transformers/SqlPrinter.js +954 -64
  133. package/dist/esm/src/transformers/SqlPrinter.js.map +1 -1
  134. package/dist/esm/src/types/Formatting.d.ts +8 -0
  135. package/dist/esm/src/types/Formatting.js +2 -0
  136. package/dist/esm/src/types/Formatting.js.map +1 -0
  137. package/dist/esm/src/utils/ParserStringUtils.d.ts +6 -0
  138. package/dist/esm/src/utils/ParserStringUtils.js +28 -0
  139. package/dist/esm/src/utils/ParserStringUtils.js.map +1 -0
  140. package/dist/esm/tsconfig.browser.tsbuildinfo +1 -1
  141. package/dist/index.min.js +22 -17
  142. package/dist/index.min.js.map +4 -4
  143. package/dist/src/index.d.ts +18 -0
  144. package/dist/src/index.js +18 -0
  145. package/dist/src/index.js.map +1 -1
  146. package/dist/src/models/BinarySelectQuery.d.ts +25 -1
  147. package/dist/src/models/BinarySelectQuery.js +28 -0
  148. package/dist/src/models/BinarySelectQuery.js.map +1 -1
  149. package/dist/src/models/Clause.d.ts +14 -2
  150. package/dist/src/models/Clause.js +29 -2
  151. package/dist/src/models/Clause.js.map +1 -1
  152. package/dist/src/models/CreateTableQuery.d.ts +99 -5
  153. package/dist/src/models/CreateTableQuery.js +90 -11
  154. package/dist/src/models/CreateTableQuery.js.map +1 -1
  155. package/dist/src/models/DDLStatements.d.ts +157 -0
  156. package/dist/src/models/DDLStatements.js +153 -0
  157. package/dist/src/models/DDLStatements.js.map +1 -0
  158. package/dist/src/models/DeleteQuery.d.ts +17 -0
  159. package/dist/src/models/DeleteQuery.js +20 -0
  160. package/dist/src/models/DeleteQuery.js.map +1 -0
  161. package/dist/src/models/InsertQuery.d.ts +7 -1
  162. package/dist/src/models/InsertQuery.js +6 -2
  163. package/dist/src/models/InsertQuery.js.map +1 -1
  164. package/dist/src/models/MergeQuery.d.ts +63 -0
  165. package/dist/src/models/MergeQuery.js +104 -0
  166. package/dist/src/models/MergeQuery.js.map +1 -0
  167. package/dist/src/models/SelectQuery.d.ts +37 -1
  168. package/dist/src/models/SelectQuery.js +7 -1
  169. package/dist/src/models/SelectQuery.js.map +1 -1
  170. package/dist/src/models/SimpleSelectQuery.d.ts +29 -1
  171. package/dist/src/models/SimpleSelectQuery.js +32 -0
  172. package/dist/src/models/SimpleSelectQuery.js.map +1 -1
  173. package/dist/src/models/SqlComponent.d.ts +2 -1
  174. package/dist/src/models/SqlComponent.js +1 -1
  175. package/dist/src/models/SqlComponent.js.map +1 -1
  176. package/dist/src/models/SqlPrintToken.d.ts +33 -0
  177. package/dist/src/models/SqlPrintToken.js +32 -0
  178. package/dist/src/models/SqlPrintToken.js.map +1 -1
  179. package/dist/src/models/ValuesQuery.d.ts +25 -1
  180. package/dist/src/models/ValuesQuery.js +28 -0
  181. package/dist/src/models/ValuesQuery.js.map +1 -1
  182. package/dist/src/parsers/AlterTableParser.d.ts +25 -0
  183. package/dist/src/parsers/AlterTableParser.js +432 -0
  184. package/dist/src/parsers/AlterTableParser.js.map +1 -0
  185. package/dist/src/parsers/CreateIndexParser.d.ts +16 -0
  186. package/dist/src/parsers/CreateIndexParser.js +241 -0
  187. package/dist/src/parsers/CreateIndexParser.js.map +1 -0
  188. package/dist/src/parsers/CreateTableParser.d.ts +41 -0
  189. package/dist/src/parsers/CreateTableParser.js +738 -0
  190. package/dist/src/parsers/CreateTableParser.js.map +1 -0
  191. package/dist/src/parsers/DeleteClauseParser.d.ts +11 -0
  192. package/dist/src/parsers/DeleteClauseParser.js +37 -0
  193. package/dist/src/parsers/DeleteClauseParser.js.map +1 -0
  194. package/dist/src/parsers/DeleteQueryParser.d.ts +16 -0
  195. package/dist/src/parsers/DeleteQueryParser.js +77 -0
  196. package/dist/src/parsers/DeleteQueryParser.js.map +1 -0
  197. package/dist/src/parsers/DropConstraintParser.d.ts +12 -0
  198. package/dist/src/parsers/DropConstraintParser.js +51 -0
  199. package/dist/src/parsers/DropConstraintParser.js.map +1 -0
  200. package/dist/src/parsers/DropIndexParser.d.ts +12 -0
  201. package/dist/src/parsers/DropIndexParser.js +73 -0
  202. package/dist/src/parsers/DropIndexParser.js.map +1 -0
  203. package/dist/src/parsers/DropTableParser.d.ts +12 -0
  204. package/dist/src/parsers/DropTableParser.js +63 -0
  205. package/dist/src/parsers/DropTableParser.js.map +1 -0
  206. package/dist/src/parsers/FunctionExpressionParser.d.ts +4 -0
  207. package/dist/src/parsers/FunctionExpressionParser.js +25 -8
  208. package/dist/src/parsers/FunctionExpressionParser.js.map +1 -1
  209. package/dist/src/parsers/InsertQueryParser.js +103 -31
  210. package/dist/src/parsers/InsertQueryParser.js.map +1 -1
  211. package/dist/src/parsers/MergeQueryParser.d.ts +26 -0
  212. package/dist/src/parsers/MergeQueryParser.js +483 -0
  213. package/dist/src/parsers/MergeQueryParser.js.map +1 -0
  214. package/dist/src/parsers/ReturningClauseParser.js +50 -7
  215. package/dist/src/parsers/ReturningClauseParser.js.map +1 -1
  216. package/dist/src/parsers/SelectClauseParser.js +2 -2
  217. package/dist/src/parsers/SelectClauseParser.js.map +1 -1
  218. package/dist/src/parsers/SelectQueryParser.d.ts +4 -0
  219. package/dist/src/parsers/SelectQueryParser.js +4 -0
  220. package/dist/src/parsers/SelectQueryParser.js.map +1 -1
  221. package/dist/src/parsers/SetClauseParser.js +97 -15
  222. package/dist/src/parsers/SetClauseParser.js.map +1 -1
  223. package/dist/src/parsers/SqlParser.d.ts +38 -0
  224. package/dist/src/parsers/SqlParser.js +353 -0
  225. package/dist/src/parsers/SqlParser.js.map +1 -0
  226. package/dist/src/parsers/SqlPrintTokenParser.d.ts +68 -21
  227. package/dist/src/parsers/SqlPrintTokenParser.js +1143 -252
  228. package/dist/src/parsers/SqlPrintTokenParser.js.map +1 -1
  229. package/dist/src/parsers/SqlTokenizer.d.ts +24 -2
  230. package/dist/src/parsers/SqlTokenizer.js +139 -74
  231. package/dist/src/parsers/SqlTokenizer.js.map +1 -1
  232. package/dist/src/parsers/UpdateQueryParser.js +11 -1
  233. package/dist/src/parsers/UpdateQueryParser.js.map +1 -1
  234. package/dist/src/parsers/UsingClauseParser.d.ts +11 -0
  235. package/dist/src/parsers/UsingClauseParser.js +33 -0
  236. package/dist/src/parsers/UsingClauseParser.js.map +1 -0
  237. package/dist/src/parsers/ValueParser.js +5 -1
  238. package/dist/src/parsers/ValueParser.js.map +1 -1
  239. package/dist/src/parsers/ValuesQueryParser.d.ts +0 -2
  240. package/dist/src/parsers/ValuesQueryParser.js +5 -45
  241. package/dist/src/parsers/ValuesQueryParser.js.map +1 -1
  242. package/dist/src/parsers/utils/LexemeCommentUtils.d.ts +6 -0
  243. package/dist/src/parsers/utils/LexemeCommentUtils.js +29 -0
  244. package/dist/src/parsers/utils/LexemeCommentUtils.js.map +1 -0
  245. package/dist/src/tokenReaders/CommandTokenReader.js +49 -2
  246. package/dist/src/tokenReaders/CommandTokenReader.js.map +1 -1
  247. package/dist/src/tokenReaders/LiteralTokenReader.js +8 -5
  248. package/dist/src/tokenReaders/LiteralTokenReader.js.map +1 -1
  249. package/dist/src/tokenReaders/OperatorTokenReader.js +10 -1
  250. package/dist/src/tokenReaders/OperatorTokenReader.js.map +1 -1
  251. package/dist/src/tokenReaders/TypeTokenReader.js +11 -1
  252. package/dist/src/tokenReaders/TypeTokenReader.js.map +1 -1
  253. package/dist/src/transformers/InsertQuerySelectValuesConverter.d.ts +18 -0
  254. package/dist/src/transformers/InsertQuerySelectValuesConverter.js +122 -0
  255. package/dist/src/transformers/InsertQuerySelectValuesConverter.js.map +1 -0
  256. package/dist/src/transformers/LinePrinter.d.ts +2 -0
  257. package/dist/src/transformers/LinePrinter.js +34 -1
  258. package/dist/src/transformers/LinePrinter.js.map +1 -1
  259. package/dist/src/transformers/OnelineFormattingHelper.d.ts +29 -0
  260. package/dist/src/transformers/OnelineFormattingHelper.js +92 -0
  261. package/dist/src/transformers/OnelineFormattingHelper.js.map +1 -0
  262. package/dist/src/transformers/QueryBuilder.d.ts +47 -13
  263. package/dist/src/transformers/QueryBuilder.js +433 -60
  264. package/dist/src/transformers/QueryBuilder.js.map +1 -1
  265. package/dist/src/transformers/SqlFormatter.d.ts +13 -3
  266. package/dist/src/transformers/SqlFormatter.js +20 -6
  267. package/dist/src/transformers/SqlFormatter.js.map +1 -1
  268. package/dist/src/transformers/SqlPrinter.d.ts +63 -10
  269. package/dist/src/transformers/SqlPrinter.js +954 -64
  270. package/dist/src/transformers/SqlPrinter.js.map +1 -1
  271. package/dist/src/types/Formatting.d.ts +8 -0
  272. package/dist/src/types/Formatting.js +3 -0
  273. package/dist/src/types/Formatting.js.map +1 -0
  274. package/dist/src/utils/ParserStringUtils.d.ts +6 -0
  275. package/dist/src/utils/ParserStringUtils.js +31 -0
  276. package/dist/src/utils/ParserStringUtils.js.map +1 -0
  277. package/dist/tsconfig.tsbuildinfo +1 -1
  278. package/package.json +1 -1
@@ -0,0 +1,428 @@
1
+ import { SqlTokenizer } from "./SqlTokenizer";
2
+ import { AlterTableStatement, AlterTableAddConstraint, AlterTableDropConstraint, AlterTableDropColumn } from "../models/DDLStatements";
3
+ import { TableConstraintDefinition, ReferenceDefinition } from "../models/CreateTableQuery";
4
+ import { TokenType } from "../models/Lexeme";
5
+ import { FullNameParser } from "./FullNameParser";
6
+ import { QualifiedName, RawString } from "../models/ValueComponent";
7
+ import { ValueParser } from "./ValueParser";
8
+ import { joinLexemeValues } from "../utils/ParserStringUtils";
9
+ /**
10
+ * Parses ALTER TABLE statements focused on constraint operations.
11
+ */
12
+ export class AlterTableParser {
13
+ static parse(sql) {
14
+ const tokenizer = new SqlTokenizer(sql);
15
+ const lexemes = tokenizer.readLexemes();
16
+ const result = this.parseFromLexeme(lexemes, 0);
17
+ if (result.newIndex < lexemes.length) {
18
+ throw new Error(`[AlterTableParser] Unexpected token "${lexemes[result.newIndex].value}" after ALTER TABLE statement.`);
19
+ }
20
+ return result.value;
21
+ }
22
+ static parseFromLexeme(lexemes, index) {
23
+ var _a, _b, _c, _d;
24
+ let idx = index;
25
+ if (((_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase()) !== "alter table") {
26
+ throw new Error(`[AlterTableParser] Expected ALTER TABLE at index ${idx}.`);
27
+ }
28
+ idx++;
29
+ let ifExists = false;
30
+ if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase()) === "if exists") {
31
+ ifExists = true;
32
+ idx++;
33
+ }
34
+ let only = false;
35
+ if (((_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.value.toLowerCase()) === "only") {
36
+ only = true;
37
+ idx++;
38
+ }
39
+ const tableResult = FullNameParser.parseFromLexeme(lexemes, idx);
40
+ const tableName = new QualifiedName(tableResult.namespaces, tableResult.name);
41
+ idx = tableResult.newIndex;
42
+ const actions = [];
43
+ while (idx < lexemes.length) {
44
+ const value = lexemes[idx].value.toLowerCase();
45
+ if (value === "add constraint") {
46
+ const result = this.parseAddConstraintAction(lexemes, idx);
47
+ actions.push(result.value);
48
+ idx = result.newIndex;
49
+ }
50
+ else if (value === "drop constraint") {
51
+ const result = this.parseDropConstraintAction(lexemes, idx);
52
+ actions.push(result.value);
53
+ idx = result.newIndex;
54
+ }
55
+ else if (value === "drop column" || value === "drop") {
56
+ const result = this.parseDropColumnAction(lexemes, idx);
57
+ actions.push(result.value);
58
+ idx = result.newIndex;
59
+ }
60
+ else {
61
+ throw new Error(`[AlterTableParser] Unsupported ALTER TABLE action '${lexemes[idx].value}' at index ${idx}.`);
62
+ }
63
+ if (((_d = lexemes[idx]) === null || _d === void 0 ? void 0 : _d.type) === TokenType.Comma) {
64
+ idx++;
65
+ continue;
66
+ }
67
+ break;
68
+ }
69
+ if (actions.length === 0) {
70
+ throw new Error("[AlterTableParser] ALTER TABLE requires at least one action.");
71
+ }
72
+ return {
73
+ value: new AlterTableStatement({ table: tableName, only, ifExists, actions }),
74
+ newIndex: idx
75
+ };
76
+ }
77
+ static parseAddConstraintAction(lexemes, index) {
78
+ var _a, _b, _c, _d, _e;
79
+ let idx = index;
80
+ const initialToken = (_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase();
81
+ if (initialToken !== "add" && initialToken !== "add constraint") {
82
+ throw new Error(`[AlterTableParser] Expected ADD or ADD CONSTRAINT at index ${idx}.`);
83
+ }
84
+ idx++;
85
+ // If the token was plain ADD, consume optional CONSTRAINT keyword.
86
+ if (initialToken === "add" && ((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase()) === "constraint") {
87
+ idx++;
88
+ }
89
+ let ifNotExists = false;
90
+ if (((_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.value.toLowerCase()) === "if not exists") {
91
+ ifNotExists = true;
92
+ idx++;
93
+ }
94
+ let constraintName;
95
+ const nextValue = (_d = lexemes[idx]) === null || _d === void 0 ? void 0 : _d.value.toLowerCase();
96
+ if (nextValue && !this.CONSTRAINT_TYPE_TOKENS.has(nextValue)) {
97
+ const nameResult = FullNameParser.parseFromLexeme(lexemes, idx);
98
+ constraintName = nameResult.name;
99
+ idx = nameResult.newIndex;
100
+ }
101
+ const constraintResult = this.parseTableConstraintDefinition(lexemes, idx, constraintName);
102
+ idx = constraintResult.newIndex;
103
+ let notValid = false;
104
+ if (((_e = lexemes[idx]) === null || _e === void 0 ? void 0 : _e.value.toLowerCase()) === "not valid") {
105
+ notValid = true;
106
+ idx++;
107
+ }
108
+ return {
109
+ value: new AlterTableAddConstraint({
110
+ constraint: constraintResult.constraint,
111
+ ifNotExists,
112
+ notValid
113
+ }),
114
+ newIndex: idx
115
+ };
116
+ }
117
+ static parseDropConstraintAction(lexemes, index) {
118
+ var _a, _b, _c, _d;
119
+ let idx = index;
120
+ const initialValue = (_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase();
121
+ if (initialValue === "drop constraint") {
122
+ idx++;
123
+ }
124
+ else if (initialValue === "drop") {
125
+ idx++;
126
+ if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase()) !== "constraint") {
127
+ throw new Error(`[AlterTableParser] Expected CONSTRAINT keyword after DROP at index ${idx}.`);
128
+ }
129
+ idx++;
130
+ }
131
+ else {
132
+ throw new Error(`[AlterTableParser] Expected DROP CONSTRAINT at index ${idx}.`);
133
+ }
134
+ let ifExists = false;
135
+ if (((_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.value.toLowerCase()) === "if exists") {
136
+ ifExists = true;
137
+ idx++;
138
+ }
139
+ const nameResult = FullNameParser.parseFromLexeme(lexemes, idx);
140
+ idx = nameResult.newIndex;
141
+ let behavior = null;
142
+ const nextValue = (_d = lexemes[idx]) === null || _d === void 0 ? void 0 : _d.value.toLowerCase();
143
+ if (nextValue === "cascade" || nextValue === "restrict") {
144
+ behavior = nextValue;
145
+ idx++;
146
+ }
147
+ return {
148
+ value: new AlterTableDropConstraint({
149
+ constraintName: nameResult.name,
150
+ ifExists,
151
+ behavior
152
+ }),
153
+ newIndex: idx
154
+ };
155
+ }
156
+ static parseDropColumnAction(lexemes, index) {
157
+ var _a, _b, _c, _d;
158
+ let idx = index;
159
+ const initialValue = (_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase();
160
+ if (initialValue === "drop column") {
161
+ idx++;
162
+ }
163
+ else if (initialValue === "drop") {
164
+ idx++;
165
+ if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase()) !== "column") {
166
+ throw new Error(`[AlterTableParser] Expected COLUMN keyword after DROP at index ${idx}.`);
167
+ }
168
+ idx++;
169
+ }
170
+ else {
171
+ throw new Error(`[AlterTableParser] Expected DROP COLUMN at index ${idx}.`);
172
+ }
173
+ let ifExists = false;
174
+ if (((_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.value.toLowerCase()) === "if exists") {
175
+ // Accept optional IF EXISTS modifier for defensive migrations.
176
+ ifExists = true;
177
+ idx++;
178
+ }
179
+ // Parse the column identifier, propagating any attached comments.
180
+ const nameResult = FullNameParser.parseFromLexeme(lexemes, idx);
181
+ const columnName = nameResult.name;
182
+ idx = nameResult.newIndex;
183
+ let behavior = null;
184
+ const nextValue = (_d = lexemes[idx]) === null || _d === void 0 ? void 0 : _d.value.toLowerCase();
185
+ if (nextValue === "cascade" || nextValue === "restrict") {
186
+ // Capture optional drop behavior to mirror PostgreSQL semantics.
187
+ behavior = nextValue;
188
+ idx++;
189
+ }
190
+ return {
191
+ value: new AlterTableDropColumn({
192
+ columnName,
193
+ ifExists,
194
+ behavior
195
+ }),
196
+ newIndex: idx
197
+ };
198
+ }
199
+ static parseTableConstraintDefinition(lexemes, index, constraintName) {
200
+ let idx = index;
201
+ const token = lexemes[idx];
202
+ if (!token) {
203
+ throw new Error(`[AlterTableParser] Missing constraint definition at index ${idx}.`);
204
+ }
205
+ const value = token.value.toLowerCase();
206
+ if (value === "primary key") {
207
+ idx++;
208
+ const listResult = this.parseIdentifierList(lexemes, idx);
209
+ idx = listResult.newIndex;
210
+ return {
211
+ constraint: new TableConstraintDefinition({
212
+ kind: "primary-key",
213
+ constraintName,
214
+ columns: listResult.identifiers
215
+ }),
216
+ newIndex: idx
217
+ };
218
+ }
219
+ if (value === "unique" || value === "unique key") {
220
+ idx++;
221
+ const listResult = this.parseIdentifierList(lexemes, idx);
222
+ idx = listResult.newIndex;
223
+ return {
224
+ constraint: new TableConstraintDefinition({
225
+ kind: "unique",
226
+ constraintName,
227
+ columns: listResult.identifiers
228
+ }),
229
+ newIndex: idx
230
+ };
231
+ }
232
+ if (value === "foreign key") {
233
+ idx++;
234
+ const listResult = this.parseIdentifierList(lexemes, idx);
235
+ idx = listResult.newIndex;
236
+ const referenceResult = this.parseReferenceDefinition(lexemes, idx);
237
+ idx = referenceResult.newIndex;
238
+ return {
239
+ constraint: new TableConstraintDefinition({
240
+ kind: "foreign-key",
241
+ constraintName,
242
+ columns: listResult.identifiers,
243
+ reference: referenceResult.reference,
244
+ deferrable: referenceResult.reference.deferrable,
245
+ initially: referenceResult.reference.initially
246
+ }),
247
+ newIndex: idx
248
+ };
249
+ }
250
+ if (value === "check") {
251
+ idx++;
252
+ const checkExpression = this.parseParenExpression(lexemes, idx);
253
+ idx = checkExpression.newIndex;
254
+ return {
255
+ constraint: new TableConstraintDefinition({
256
+ kind: "check",
257
+ constraintName,
258
+ checkExpression: checkExpression.value
259
+ }),
260
+ newIndex: idx
261
+ };
262
+ }
263
+ const rawEnd = this.findConstraintClauseEnd(lexemes, idx + 1);
264
+ const rawText = joinLexemeValues(lexemes, idx, rawEnd);
265
+ return {
266
+ constraint: new TableConstraintDefinition({
267
+ kind: "raw",
268
+ constraintName,
269
+ rawClause: new RawString(rawText)
270
+ }),
271
+ newIndex: rawEnd
272
+ };
273
+ }
274
+ static parseIdentifierList(lexemes, index) {
275
+ var _a, _b, _c;
276
+ let idx = index;
277
+ const identifiers = [];
278
+ if (((_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.type) !== TokenType.OpenParen) {
279
+ throw new Error(`[AlterTableParser] Expected '(' to start identifier list at index ${idx}.`);
280
+ }
281
+ idx++;
282
+ while (idx < lexemes.length) {
283
+ const nameResult = FullNameParser.parseFromLexeme(lexemes, idx);
284
+ identifiers.push(nameResult.name);
285
+ idx = nameResult.newIndex;
286
+ if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.type) === TokenType.Comma) {
287
+ idx++;
288
+ continue;
289
+ }
290
+ if (((_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.type) === TokenType.CloseParen) {
291
+ idx++;
292
+ break;
293
+ }
294
+ }
295
+ return { identifiers, newIndex: idx };
296
+ }
297
+ static parseReferenceDefinition(lexemes, index) {
298
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
299
+ let idx = index;
300
+ if (((_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase()) !== "references") {
301
+ throw new Error(`[AlterTableParser] Expected REFERENCES clause at index ${idx}.`);
302
+ }
303
+ idx++;
304
+ const tableResult = FullNameParser.parseFromLexeme(lexemes, idx);
305
+ const targetTable = new QualifiedName(tableResult.namespaces, tableResult.name);
306
+ idx = tableResult.newIndex;
307
+ let columns = null;
308
+ if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.type) === TokenType.OpenParen) {
309
+ const listResult = this.parseIdentifierList(lexemes, idx);
310
+ columns = listResult.identifiers;
311
+ idx = listResult.newIndex;
312
+ }
313
+ let matchType = null;
314
+ let onDelete = null;
315
+ let onUpdate = null;
316
+ let deferrable = null;
317
+ let initially = null;
318
+ while (idx < lexemes.length) {
319
+ const current = lexemes[idx].value.toLowerCase();
320
+ if (this.MATCH_KEYWORDS.has(current)) {
321
+ matchType = this.MATCH_KEYWORDS.get(current);
322
+ idx++;
323
+ continue;
324
+ }
325
+ if (current === "match") {
326
+ idx++;
327
+ const descriptor = (_d = (_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.value.toLowerCase()) !== null && _d !== void 0 ? _d : "";
328
+ matchType = descriptor;
329
+ idx++;
330
+ continue;
331
+ }
332
+ if (current === "on delete") {
333
+ idx++;
334
+ const action = (_f = (_e = lexemes[idx]) === null || _e === void 0 ? void 0 : _e.value.toLowerCase()) !== null && _f !== void 0 ? _f : "";
335
+ onDelete = (_g = this.REFERENTIAL_ACTIONS.get(action)) !== null && _g !== void 0 ? _g : null;
336
+ idx++;
337
+ continue;
338
+ }
339
+ if (current === "on update") {
340
+ idx++;
341
+ const action = (_j = (_h = lexemes[idx]) === null || _h === void 0 ? void 0 : _h.value.toLowerCase()) !== null && _j !== void 0 ? _j : "";
342
+ onUpdate = (_k = this.REFERENTIAL_ACTIONS.get(action)) !== null && _k !== void 0 ? _k : null;
343
+ idx++;
344
+ continue;
345
+ }
346
+ if (this.DEFERRABILITY_KEYWORDS.has(current)) {
347
+ deferrable = this.DEFERRABILITY_KEYWORDS.get(current);
348
+ idx++;
349
+ continue;
350
+ }
351
+ if (this.INITIALLY_KEYWORDS.has(current)) {
352
+ initially = this.INITIALLY_KEYWORDS.get(current);
353
+ idx++;
354
+ continue;
355
+ }
356
+ break;
357
+ }
358
+ return {
359
+ reference: new ReferenceDefinition({
360
+ targetTable,
361
+ columns,
362
+ matchType,
363
+ onDelete,
364
+ onUpdate,
365
+ deferrable,
366
+ initially
367
+ }),
368
+ newIndex: idx
369
+ };
370
+ }
371
+ static parseParenExpression(lexemes, index) {
372
+ var _a, _b;
373
+ let idx = index;
374
+ if (((_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.type) !== TokenType.OpenParen) {
375
+ throw new Error(`[AlterTableParser] Expected '(' starting CHECK expression at index ${idx}.`);
376
+ }
377
+ idx++;
378
+ const result = ValueParser.parseFromLexeme(lexemes, idx);
379
+ idx = result.newIndex;
380
+ if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.type) !== TokenType.CloseParen) {
381
+ throw new Error(`[AlterTableParser] Expected ')' closing CHECK expression at index ${idx}.`);
382
+ }
383
+ idx++;
384
+ return { value: result.value, newIndex: idx };
385
+ }
386
+ static findConstraintClauseEnd(lexemes, index) {
387
+ let idx = index;
388
+ while (idx < lexemes.length) {
389
+ const token = lexemes[idx];
390
+ if (token.type & (TokenType.Comma | TokenType.CloseParen)) {
391
+ break;
392
+ }
393
+ if (token.value.toLowerCase() === "not valid") {
394
+ break;
395
+ }
396
+ idx++;
397
+ }
398
+ return idx;
399
+ }
400
+ }
401
+ AlterTableParser.CONSTRAINT_TYPE_TOKENS = new Set([
402
+ "primary key",
403
+ "unique",
404
+ "unique key",
405
+ "foreign key",
406
+ "check"
407
+ ]);
408
+ AlterTableParser.MATCH_KEYWORDS = new Map([
409
+ ["match full", "full"],
410
+ ["match partial", "partial"],
411
+ ["match simple", "simple"]
412
+ ]);
413
+ AlterTableParser.REFERENTIAL_ACTIONS = new Map([
414
+ ["cascade", "cascade"],
415
+ ["restrict", "restrict"],
416
+ ["no action", "no action"],
417
+ ["set null", "set null"],
418
+ ["set default", "set default"]
419
+ ]);
420
+ AlterTableParser.DEFERRABILITY_KEYWORDS = new Map([
421
+ ["deferrable", "deferrable"],
422
+ ["not deferrable", "not deferrable"]
423
+ ]);
424
+ AlterTableParser.INITIALLY_KEYWORDS = new Map([
425
+ ["initially immediate", "immediate"],
426
+ ["initially deferred", "deferred"]
427
+ ]);
428
+ //# sourceMappingURL=AlterTableParser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AlterTableParser.js","sourceRoot":"","sources":["../../../../src/parsers/AlterTableParser.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { CreateIndexStatement } from "../models/DDLStatements";
2
+ import { Lexeme } from "../models/Lexeme";
3
+ /**
4
+ * Parses CREATE INDEX statements.
5
+ */
6
+ export declare class CreateIndexParser {
7
+ static parse(sql: string): CreateIndexStatement;
8
+ static parseFromLexeme(lexemes: Lexeme[], index: number): {
9
+ value: CreateIndexStatement;
10
+ newIndex: number;
11
+ };
12
+ private static parseIndexColumnList;
13
+ private static parseIdentifierList;
14
+ private static parseWithOptions;
15
+ private static isClauseTerminator;
16
+ }