rawsql-ts 0.12.0 → 0.13.0
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.
- package/LICENSE +21 -0
- package/dist/esm/index.js +11 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/index.min.js +16 -16
- package/dist/esm/index.min.js.map +3 -3
- package/dist/esm/src/index.d.ts +12 -0
- package/dist/esm/src/index.js +11 -0
- package/dist/esm/src/index.js.map +1 -1
- package/dist/esm/src/models/Clause.d.ts +7 -3
- package/dist/esm/src/models/Clause.js +17 -4
- package/dist/esm/src/models/Clause.js.map +1 -1
- package/dist/esm/src/models/DDLStatements.d.ts +14 -2
- package/dist/esm/src/models/DDLStatements.js +12 -0
- package/dist/esm/src/models/DDLStatements.js.map +1 -1
- package/dist/esm/src/models/InsertQuery.d.ts +1 -4
- package/dist/esm/src/models/InsertQuery.js +3 -5
- package/dist/esm/src/models/InsertQuery.js.map +1 -1
- package/dist/esm/src/models/SqlPrintToken.d.ts +1 -0
- package/dist/esm/src/models/SqlPrintToken.js +1 -0
- package/dist/esm/src/models/SqlPrintToken.js.map +1 -1
- package/dist/esm/src/models/TableDefinitionModel.d.ts +39 -0
- package/dist/esm/src/models/TableDefinitionModel.js +77 -0
- package/dist/esm/src/models/TableDefinitionModel.js.map +1 -0
- package/dist/esm/src/models/ValuesQuery.d.ts +2 -0
- package/dist/esm/src/models/ValuesQuery.js +1 -0
- package/dist/esm/src/models/ValuesQuery.js.map +1 -1
- package/dist/esm/src/parsers/AlterTableParser.js +1 -1
- package/dist/esm/src/parsers/AlterTableParser.js.map +1 -1
- package/dist/esm/src/parsers/InsertQueryParser.js +4 -1
- package/dist/esm/src/parsers/InsertQueryParser.js.map +1 -1
- package/dist/esm/src/parsers/ReturningClauseParser.js +33 -47
- package/dist/esm/src/parsers/ReturningClauseParser.js.map +1 -1
- package/dist/esm/src/parsers/SqlParser.d.ts +0 -1
- package/dist/esm/src/parsers/SqlParser.js +44 -58
- package/dist/esm/src/parsers/SqlParser.js.map +1 -1
- package/dist/esm/src/parsers/SqlPrintTokenParser.d.ts +1 -0
- package/dist/esm/src/parsers/SqlPrintTokenParser.js +23 -5
- package/dist/esm/src/parsers/SqlPrintTokenParser.js.map +1 -1
- package/dist/esm/src/tokenReaders/LiteralTokenReader.js +7 -0
- package/dist/esm/src/tokenReaders/LiteralTokenReader.js.map +1 -1
- package/dist/esm/src/transformers/DDLDiffGenerator.d.ts +14 -0
- package/dist/esm/src/transformers/DDLDiffGenerator.js +197 -0
- package/dist/esm/src/transformers/DDLDiffGenerator.js.map +1 -0
- package/dist/esm/src/transformers/DDLGeneralizer.d.ts +13 -0
- package/dist/esm/src/transformers/DDLGeneralizer.js +98 -0
- package/dist/esm/src/transformers/DDLGeneralizer.js.map +1 -0
- package/dist/esm/src/transformers/DDLToFixtureConverter.d.ts +19 -0
- package/dist/esm/src/transformers/DDLToFixtureConverter.js +202 -0
- package/dist/esm/src/transformers/DDLToFixtureConverter.js.map +1 -0
- package/dist/esm/src/transformers/DeleteResultSelectConverter.d.ts +53 -0
- package/dist/esm/src/transformers/DeleteResultSelectConverter.js +394 -0
- package/dist/esm/src/transformers/DeleteResultSelectConverter.js.map +1 -0
- package/dist/esm/src/transformers/FixtureCteBuilder.d.ts +60 -0
- package/dist/esm/src/transformers/FixtureCteBuilder.js +147 -0
- package/dist/esm/src/transformers/FixtureCteBuilder.js.map +1 -0
- package/dist/esm/src/transformers/InsertQuerySelectValuesConverter.js +5 -2
- package/dist/esm/src/transformers/InsertQuerySelectValuesConverter.js.map +1 -1
- package/dist/esm/src/transformers/InsertResultSelectConverter.d.ts +64 -0
- package/dist/esm/src/transformers/InsertResultSelectConverter.js +495 -0
- package/dist/esm/src/transformers/InsertResultSelectConverter.js.map +1 -0
- package/dist/esm/src/transformers/MergeResultSelectConverter.d.ts +38 -0
- package/dist/esm/src/transformers/MergeResultSelectConverter.js +306 -0
- package/dist/esm/src/transformers/MergeResultSelectConverter.js.map +1 -0
- package/dist/esm/src/transformers/QueryBuilder.d.ts +11 -0
- package/dist/esm/src/transformers/QueryBuilder.js +19 -3
- package/dist/esm/src/transformers/QueryBuilder.js.map +1 -1
- package/dist/esm/src/transformers/SelectResultSelectConverter.d.ts +10 -0
- package/dist/esm/src/transformers/SelectResultSelectConverter.js +32 -0
- package/dist/esm/src/transformers/SelectResultSelectConverter.js.map +1 -0
- package/dist/esm/src/transformers/SimulatedSelectConverter.d.ts +23 -0
- package/dist/esm/src/transformers/SimulatedSelectConverter.js +61 -0
- package/dist/esm/src/transformers/SimulatedSelectConverter.js.map +1 -0
- package/dist/esm/src/transformers/UpdateResultSelectConverter.d.ts +51 -0
- package/dist/esm/src/transformers/UpdateResultSelectConverter.js +340 -0
- package/dist/esm/src/transformers/UpdateResultSelectConverter.js.map +1 -0
- package/dist/esm/src/utils/SelectQueryWithClauseHelper.d.ts +12 -0
- package/dist/esm/src/utils/SelectQueryWithClauseHelper.js +43 -0
- package/dist/esm/src/utils/SelectQueryWithClauseHelper.js.map +1 -0
- package/dist/esm/src/utils/ValueComponentRewriter.d.ts +3 -0
- package/dist/esm/src/utils/ValueComponentRewriter.js +180 -0
- package/dist/esm/src/utils/ValueComponentRewriter.js.map +1 -0
- package/dist/esm/tsconfig.browser.tsbuildinfo +1 -1
- package/dist/formatters/OriginalFormatRestorer.js +139 -0
- package/dist/formatters/OriginalFormatRestorer.js.map +1 -0
- package/dist/index.js +144 -0
- package/dist/index.js.map +1 -0
- package/dist/index.min.js +17 -17
- package/dist/index.min.js.map +3 -3
- package/dist/models/BinarySelectQuery.js +198 -0
- package/dist/models/BinarySelectQuery.js.map +1 -0
- package/dist/models/CTEError.js +37 -0
- package/dist/models/CTEError.js.map +1 -0
- package/dist/models/Clause.js +535 -0
- package/dist/models/Clause.js.map +1 -0
- package/dist/models/CreateTableQuery.js +135 -0
- package/dist/models/CreateTableQuery.js.map +1 -0
- package/dist/models/DDLStatements.js +275 -0
- package/dist/models/DDLStatements.js.map +1 -0
- package/dist/models/DeleteQuery.js +20 -0
- package/dist/models/DeleteQuery.js.map +1 -0
- package/dist/models/FormattingLexeme.js +3 -0
- package/dist/models/FormattingLexeme.js.map +1 -0
- package/dist/models/HintClause.js +41 -0
- package/dist/models/HintClause.js.map +1 -0
- package/dist/models/InsertQuery.js +23 -0
- package/dist/models/InsertQuery.js.map +1 -0
- package/dist/models/KeywordTrie.js +54 -0
- package/dist/models/KeywordTrie.js.map +1 -0
- package/dist/models/Lexeme.js +22 -0
- package/dist/models/Lexeme.js.map +1 -0
- package/dist/models/MergeQuery.js +104 -0
- package/dist/models/MergeQuery.js.map +1 -0
- package/dist/models/SelectQuery.js +22 -0
- package/dist/models/SelectQuery.js.map +1 -0
- package/dist/models/SimpleSelectQuery.js +648 -0
- package/dist/models/SimpleSelectQuery.js.map +1 -0
- package/dist/models/SqlComponent.js +73 -0
- package/dist/models/SqlComponent.js.map +1 -0
- package/dist/models/SqlPrintToken.js +143 -0
- package/dist/models/SqlPrintToken.js.map +1 -0
- package/dist/models/TableDefinitionModel.js +86 -0
- package/dist/models/TableDefinitionModel.js.map +1 -0
- package/dist/models/UpdateQuery.js +29 -0
- package/dist/models/UpdateQuery.js.map +1 -0
- package/dist/models/ValueComponent.js +380 -0
- package/dist/models/ValueComponent.js.map +1 -0
- package/dist/models/ValuesQuery.js +62 -0
- package/dist/models/ValuesQuery.js.map +1 -0
- package/dist/parsers/AlterTableParser.js +490 -0
- package/dist/parsers/AlterTableParser.js.map +1 -0
- package/dist/parsers/AnalyzeStatementParser.js +94 -0
- package/dist/parsers/AnalyzeStatementParser.js.map +1 -0
- package/dist/parsers/CommandExpressionParser.js +213 -0
- package/dist/parsers/CommandExpressionParser.js.map +1 -0
- package/dist/parsers/CommonTableParser.js +177 -0
- package/dist/parsers/CommonTableParser.js.map +1 -0
- package/dist/parsers/CreateIndexParser.js +241 -0
- package/dist/parsers/CreateIndexParser.js.map +1 -0
- package/dist/parsers/CreateTableParser.js +738 -0
- package/dist/parsers/CreateTableParser.js.map +1 -0
- package/dist/parsers/DeleteClauseParser.js +37 -0
- package/dist/parsers/DeleteClauseParser.js.map +1 -0
- package/dist/parsers/DeleteQueryParser.js +77 -0
- package/dist/parsers/DeleteQueryParser.js.map +1 -0
- package/dist/parsers/DropConstraintParser.js +51 -0
- package/dist/parsers/DropConstraintParser.js.map +1 -0
- package/dist/parsers/DropIndexParser.js +73 -0
- package/dist/parsers/DropIndexParser.js.map +1 -0
- package/dist/parsers/DropTableParser.js +63 -0
- package/dist/parsers/DropTableParser.js.map +1 -0
- package/dist/parsers/ExplainStatementParser.js +189 -0
- package/dist/parsers/ExplainStatementParser.js.map +1 -0
- package/dist/parsers/FetchClauseParser.js +89 -0
- package/dist/parsers/FetchClauseParser.js.map +1 -0
- package/dist/parsers/ForClauseParser.js +58 -0
- package/dist/parsers/ForClauseParser.js.map +1 -0
- package/dist/parsers/FromClauseParser.js +54 -0
- package/dist/parsers/FromClauseParser.js.map +1 -0
- package/dist/parsers/FullNameParser.js +110 -0
- package/dist/parsers/FullNameParser.js.map +1 -0
- package/dist/parsers/FunctionExpressionParser.js +524 -0
- package/dist/parsers/FunctionExpressionParser.js.map +1 -0
- package/dist/parsers/GroupByParser.js +58 -0
- package/dist/parsers/GroupByParser.js.map +1 -0
- package/dist/parsers/HavingParser.js +36 -0
- package/dist/parsers/HavingParser.js.map +1 -0
- package/dist/parsers/IdentifierDecorator.js +17 -0
- package/dist/parsers/IdentifierDecorator.js.map +1 -0
- package/dist/parsers/IdentifierParser.js +15 -0
- package/dist/parsers/IdentifierParser.js.map +1 -0
- package/dist/parsers/InsertQueryParser.js +162 -0
- package/dist/parsers/InsertQueryParser.js.map +1 -0
- package/dist/parsers/JoinClauseParser.js +117 -0
- package/dist/parsers/JoinClauseParser.js.map +1 -0
- package/dist/parsers/JoinOnClauseParser.js +21 -0
- package/dist/parsers/JoinOnClauseParser.js.map +1 -0
- package/dist/parsers/JoinUsingClauseParser.js +23 -0
- package/dist/parsers/JoinUsingClauseParser.js.map +1 -0
- package/dist/parsers/KeywordParser.js +99 -0
- package/dist/parsers/KeywordParser.js.map +1 -0
- package/dist/parsers/LimitClauseParser.js +38 -0
- package/dist/parsers/LimitClauseParser.js.map +1 -0
- package/dist/parsers/LiteralParser.js +48 -0
- package/dist/parsers/LiteralParser.js.map +1 -0
- package/dist/parsers/MergeQueryParser.js +483 -0
- package/dist/parsers/MergeQueryParser.js.map +1 -0
- package/dist/parsers/OffsetClauseParser.js +42 -0
- package/dist/parsers/OffsetClauseParser.js.map +1 -0
- package/dist/parsers/OrderByClauseParser.js +108 -0
- package/dist/parsers/OrderByClauseParser.js.map +1 -0
- package/dist/parsers/OverExpressionParser.js +44 -0
- package/dist/parsers/OverExpressionParser.js.map +1 -0
- package/dist/parsers/ParameterDecorator.js +40 -0
- package/dist/parsers/ParameterDecorator.js.map +1 -0
- package/dist/parsers/ParameterExpressionParser.js +24 -0
- package/dist/parsers/ParameterExpressionParser.js.map +1 -0
- package/dist/parsers/ParenExpressionParser.js +109 -0
- package/dist/parsers/ParenExpressionParser.js.map +1 -0
- package/dist/parsers/ParseError.js +25 -0
- package/dist/parsers/ParseError.js.map +1 -0
- package/dist/parsers/PartitionByParser.js +53 -0
- package/dist/parsers/PartitionByParser.js.map +1 -0
- package/dist/parsers/ReturningClauseParser.js +64 -0
- package/dist/parsers/ReturningClauseParser.js.map +1 -0
- package/dist/parsers/SelectClauseParser.js +244 -0
- package/dist/parsers/SelectClauseParser.js.map +1 -0
- package/dist/parsers/SelectQueryParser.js +564 -0
- package/dist/parsers/SelectQueryParser.js.map +1 -0
- package/dist/parsers/SequenceParser.js +245 -0
- package/dist/parsers/SequenceParser.js.map +1 -0
- package/dist/parsers/SetClauseParser.js +125 -0
- package/dist/parsers/SetClauseParser.js.map +1 -0
- package/dist/parsers/SourceAliasExpressionParser.js +60 -0
- package/dist/parsers/SourceAliasExpressionParser.js.map +1 -0
- package/dist/parsers/SourceExpressionParser.js +69 -0
- package/dist/parsers/SourceExpressionParser.js.map +1 -0
- package/dist/parsers/SourceParser.js +144 -0
- package/dist/parsers/SourceParser.js.map +1 -0
- package/dist/parsers/SqlParser.js +431 -0
- package/dist/parsers/SqlParser.js.map +1 -0
- package/dist/parsers/SqlPrintTokenParser.js +3289 -0
- package/dist/parsers/SqlPrintTokenParser.js.map +1 -0
- package/dist/parsers/SqlTokenizer.js +553 -0
- package/dist/parsers/SqlTokenizer.js.map +1 -0
- package/dist/parsers/StringSpecifierExpressionParser.js +22 -0
- package/dist/parsers/StringSpecifierExpressionParser.js.map +1 -0
- package/dist/parsers/UnaryExpressionParser.js +39 -0
- package/dist/parsers/UnaryExpressionParser.js.map +1 -0
- package/dist/parsers/UpdateClauseParser.js +21 -0
- package/dist/parsers/UpdateClauseParser.js.map +1 -0
- package/dist/parsers/UpdateQueryParser.js +98 -0
- package/dist/parsers/UpdateQueryParser.js.map +1 -0
- package/dist/parsers/UsingClauseParser.js +33 -0
- package/dist/parsers/UsingClauseParser.js.map +1 -0
- package/dist/parsers/ValueParser.js +562 -0
- package/dist/parsers/ValueParser.js.map +1 -0
- package/dist/parsers/ValuesQueryParser.js +112 -0
- package/dist/parsers/ValuesQueryParser.js.map +1 -0
- package/dist/parsers/WhereClauseParser.js +51 -0
- package/dist/parsers/WhereClauseParser.js.map +1 -0
- package/dist/parsers/WindowClauseParser.js +57 -0
- package/dist/parsers/WindowClauseParser.js.map +1 -0
- package/dist/parsers/WindowExpressionParser.js +163 -0
- package/dist/parsers/WindowExpressionParser.js.map +1 -0
- package/dist/parsers/WithClauseParser.js +165 -0
- package/dist/parsers/WithClauseParser.js.map +1 -0
- package/dist/parsers/utils/LexemeCommentUtils.js +29 -0
- package/dist/parsers/utils/LexemeCommentUtils.js.map +1 -0
- package/dist/reporting/models/DataFlowEdge.js +58 -0
- package/dist/reporting/models/DataFlowEdge.js.map +1 -0
- package/dist/reporting/models/DataFlowGraph.js +138 -0
- package/dist/reporting/models/DataFlowGraph.js.map +1 -0
- package/dist/reporting/models/DataFlowNode.js +148 -0
- package/dist/reporting/models/DataFlowNode.js.map +1 -0
- package/dist/reporting/services/CTEHandler.js +58 -0
- package/dist/reporting/services/CTEHandler.js.map +1 -0
- package/dist/reporting/services/DataSourceHandler.js +95 -0
- package/dist/reporting/services/DataSourceHandler.js.map +1 -0
- package/dist/reporting/services/JoinHandler.js +84 -0
- package/dist/reporting/services/JoinHandler.js.map +1 -0
- package/dist/reporting/services/ProcessHandler.js +26 -0
- package/dist/reporting/services/ProcessHandler.js.map +1 -0
- package/dist/src/index.d.ts +15 -0
- package/dist/src/index.js +13 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/models/Clause.d.ts +7 -3
- package/dist/src/models/Clause.js +16 -3
- package/dist/src/models/Clause.js.map +1 -1
- package/dist/src/models/DDLStatements.d.ts +97 -2
- package/dist/src/models/DDLStatements.js +14 -1
- package/dist/src/models/DDLStatements.js.map +1 -1
- package/dist/src/models/InsertQuery.d.ts +1 -4
- package/dist/src/models/InsertQuery.js +3 -5
- package/dist/src/models/InsertQuery.js.map +1 -1
- package/dist/src/models/SqlPrintToken.d.ts +6 -0
- package/dist/src/models/SqlPrintToken.js +1 -0
- package/dist/src/models/SqlPrintToken.js.map +1 -1
- package/dist/src/models/TableDefinitionModel.d.ts +41 -0
- package/dist/src/models/TableDefinitionModel.js +85 -0
- package/dist/src/models/TableDefinitionModel.js.map +1 -0
- package/dist/src/models/ValueComponent.d.ts +2 -1
- package/dist/src/models/ValuesQuery.d.ts +2 -0
- package/dist/src/models/ValuesQuery.js +1 -0
- package/dist/src/models/ValuesQuery.js.map +1 -1
- package/dist/src/parsers/AlterTableParser.d.ts +1 -0
- package/dist/src/parsers/AlterTableParser.js +26 -5
- package/dist/src/parsers/AlterTableParser.js.map +1 -1
- package/dist/src/parsers/FunctionExpressionParser.d.ts +1 -0
- package/dist/src/parsers/InsertQueryParser.js +4 -1
- package/dist/src/parsers/InsertQueryParser.js.map +1 -1
- package/dist/src/parsers/ReturningClauseParser.js +33 -47
- package/dist/src/parsers/ReturningClauseParser.js.map +1 -1
- package/dist/src/parsers/SequenceParser.d.ts +16 -0
- package/dist/src/parsers/SqlParser.d.ts +4 -3
- package/dist/src/parsers/SqlParser.js +44 -63
- package/dist/src/parsers/SqlParser.js.map +1 -1
- package/dist/src/parsers/SqlPrintTokenParser.d.ts +9 -0
- package/dist/src/parsers/SqlPrintTokenParser.js +22 -4
- package/dist/src/parsers/SqlPrintTokenParser.js.map +1 -1
- package/dist/src/parsers/SqlTokenizer.d.ts +1 -0
- package/dist/src/tokenReaders/LiteralTokenReader.js +7 -0
- package/dist/src/tokenReaders/LiteralTokenReader.js.map +1 -1
- package/dist/src/transformers/DDLDiffGenerator.d.ts +18 -0
- package/dist/src/transformers/DDLDiffGenerator.js +313 -0
- package/dist/src/transformers/DDLDiffGenerator.js.map +1 -0
- package/dist/src/transformers/DDLGeneralizer.d.ts +13 -0
- package/dist/src/transformers/DDLGeneralizer.js +119 -0
- package/dist/src/transformers/DDLGeneralizer.js.map +1 -0
- package/dist/src/transformers/DDLToFixtureConverter.d.ts +19 -0
- package/dist/src/transformers/DDLToFixtureConverter.js +206 -0
- package/dist/src/transformers/DDLToFixtureConverter.js.map +1 -0
- package/dist/src/transformers/DeleteResultSelectConverter.d.ts +53 -0
- package/dist/src/transformers/DeleteResultSelectConverter.js +398 -0
- package/dist/src/transformers/DeleteResultSelectConverter.js.map +1 -0
- package/dist/src/transformers/FixtureCteBuilder.d.ts +60 -0
- package/dist/src/transformers/FixtureCteBuilder.js +151 -0
- package/dist/src/transformers/FixtureCteBuilder.js.map +1 -0
- package/dist/src/transformers/InsertQuerySelectValuesConverter.js +5 -2
- package/dist/src/transformers/InsertQuerySelectValuesConverter.js.map +1 -1
- package/dist/src/transformers/InsertResultSelectConverter.d.ts +67 -0
- package/dist/src/transformers/InsertResultSelectConverter.js +499 -0
- package/dist/src/transformers/InsertResultSelectConverter.js.map +1 -0
- package/dist/src/transformers/MergeResultSelectConverter.d.ts +38 -0
- package/dist/src/transformers/MergeResultSelectConverter.js +310 -0
- package/dist/src/transformers/MergeResultSelectConverter.js.map +1 -0
- package/dist/src/transformers/QueryBuilder.d.ts +11 -0
- package/dist/src/transformers/QueryBuilder.js +19 -3
- package/dist/src/transformers/QueryBuilder.js.map +1 -1
- package/dist/src/transformers/SelectResultSelectConverter.d.ts +10 -0
- package/dist/src/transformers/SelectResultSelectConverter.js +36 -0
- package/dist/src/transformers/SelectResultSelectConverter.js.map +1 -0
- package/dist/src/transformers/SimulatedSelectConverter.d.ts +23 -0
- package/dist/src/transformers/SimulatedSelectConverter.js +65 -0
- package/dist/src/transformers/SimulatedSelectConverter.js.map +1 -0
- package/dist/src/transformers/UpdateResultSelectConverter.d.ts +51 -0
- package/dist/src/transformers/UpdateResultSelectConverter.js +344 -0
- package/dist/src/transformers/UpdateResultSelectConverter.js.map +1 -0
- package/dist/src/types/GenericFixture.d.ts +17 -0
- package/dist/src/utils/SelectQueryWithClauseHelper.d.ts +12 -0
- package/dist/src/utils/SelectQueryWithClauseHelper.js +47 -0
- package/dist/src/utils/SelectQueryWithClauseHelper.js.map +1 -0
- package/dist/src/utils/TableNameUtils.d.ts +10 -0
- package/dist/src/utils/ValueComponentRewriter.d.ts +3 -0
- package/dist/src/utils/ValueComponentRewriter.js +183 -0
- package/dist/src/utils/ValueComponentRewriter.js.map +1 -0
- package/dist/tokenReaders/BaseTokenReader.js +86 -0
- package/dist/tokenReaders/BaseTokenReader.js.map +1 -0
- package/dist/tokenReaders/CommandTokenReader.js +221 -0
- package/dist/tokenReaders/CommandTokenReader.js.map +1 -0
- package/dist/tokenReaders/EscapedIdentifierTokenReader.js +99 -0
- package/dist/tokenReaders/EscapedIdentifierTokenReader.js.map +1 -0
- package/dist/tokenReaders/FunctionTokenReader.js +47 -0
- package/dist/tokenReaders/FunctionTokenReader.js.map +1 -0
- package/dist/tokenReaders/IdentifierTokenReader.js +34 -0
- package/dist/tokenReaders/IdentifierTokenReader.js.map +1 -0
- package/dist/tokenReaders/LiteralTokenReader.js +329 -0
- package/dist/tokenReaders/LiteralTokenReader.js.map +1 -0
- package/dist/tokenReaders/OperatorTokenReader.js +152 -0
- package/dist/tokenReaders/OperatorTokenReader.js.map +1 -0
- package/dist/tokenReaders/ParameterTokenReader.js +190 -0
- package/dist/tokenReaders/ParameterTokenReader.js.map +1 -0
- package/dist/tokenReaders/StringSpecifierTokenReader.js +31 -0
- package/dist/tokenReaders/StringSpecifierTokenReader.js.map +1 -0
- package/dist/tokenReaders/SymbolTokenReader.js +35 -0
- package/dist/tokenReaders/SymbolTokenReader.js.map +1 -0
- package/dist/tokenReaders/TokenReaderManager.js +110 -0
- package/dist/tokenReaders/TokenReaderManager.js.map +1 -0
- package/dist/tokenReaders/TypeTokenReader.js +69 -0
- package/dist/tokenReaders/TypeTokenReader.js.map +1 -0
- package/dist/transformers/AliasRenamer.js +600 -0
- package/dist/transformers/AliasRenamer.js.map +1 -0
- package/dist/transformers/CTEBuilder.js +188 -0
- package/dist/transformers/CTEBuilder.js.map +1 -0
- package/dist/transformers/CTECollector.js +409 -0
- package/dist/transformers/CTECollector.js.map +1 -0
- package/dist/transformers/CTEComposer.js +302 -0
- package/dist/transformers/CTEComposer.js.map +1 -0
- package/dist/transformers/CTEDependencyAnalyzer.js +285 -0
- package/dist/transformers/CTEDependencyAnalyzer.js.map +1 -0
- package/dist/transformers/CTEDependencyTracer.js +253 -0
- package/dist/transformers/CTEDependencyTracer.js.map +1 -0
- package/dist/transformers/CTEDisabler.js +355 -0
- package/dist/transformers/CTEDisabler.js.map +1 -0
- package/dist/transformers/CTEInjector.js +83 -0
- package/dist/transformers/CTEInjector.js.map +1 -0
- package/dist/transformers/CTENormalizer.js +46 -0
- package/dist/transformers/CTENormalizer.js.map +1 -0
- package/dist/transformers/CTEQueryDecomposer.js +589 -0
- package/dist/transformers/CTEQueryDecomposer.js.map +1 -0
- package/dist/transformers/CTERenamer.js +486 -0
- package/dist/transformers/CTERenamer.js.map +1 -0
- package/dist/transformers/CTETableReferenceCollector.js +358 -0
- package/dist/transformers/CTETableReferenceCollector.js.map +1 -0
- package/dist/transformers/ColumnReferenceCollector.js +478 -0
- package/dist/transformers/ColumnReferenceCollector.js.map +1 -0
- package/dist/transformers/DDLDiffGenerator.js +313 -0
- package/dist/transformers/DDLDiffGenerator.js.map +1 -0
- package/dist/transformers/DDLGeneralizer.js +119 -0
- package/dist/transformers/DDLGeneralizer.js.map +1 -0
- package/dist/transformers/DDLToFixtureConverter.js +206 -0
- package/dist/transformers/DDLToFixtureConverter.js.map +1 -0
- package/dist/transformers/DeleteResultSelectConverter.js +414 -0
- package/dist/transformers/DeleteResultSelectConverter.js.map +1 -0
- package/dist/transformers/DynamicQueryBuilder.js +164 -0
- package/dist/transformers/DynamicQueryBuilder.js.map +1 -0
- package/dist/transformers/EnhancedJsonMapping.js +223 -0
- package/dist/transformers/EnhancedJsonMapping.js.map +1 -0
- package/dist/transformers/FilterableItemCollector.js +259 -0
- package/dist/transformers/FilterableItemCollector.js.map +1 -0
- package/dist/transformers/FixtureCteBuilder.js +151 -0
- package/dist/transformers/FixtureCteBuilder.js.map +1 -0
- package/dist/transformers/FormatOptionResolver.js +67 -0
- package/dist/transformers/FormatOptionResolver.js.map +1 -0
- package/dist/transformers/Formatter.js +38 -0
- package/dist/transformers/Formatter.js.map +1 -0
- package/dist/transformers/InsertQuerySelectValuesConverter.js +125 -0
- package/dist/transformers/InsertQuerySelectValuesConverter.js.map +1 -0
- package/dist/transformers/InsertResultSelectConverter.js +589 -0
- package/dist/transformers/InsertResultSelectConverter.js.map +1 -0
- package/dist/transformers/JoinAggregationDecomposer.js +497 -0
- package/dist/transformers/JoinAggregationDecomposer.js.map +1 -0
- package/dist/transformers/JsonMappingConverter.js +392 -0
- package/dist/transformers/JsonMappingConverter.js.map +1 -0
- package/dist/transformers/JsonMappingUnifier.js +216 -0
- package/dist/transformers/JsonMappingUnifier.js.map +1 -0
- package/dist/transformers/LinePrinter.js +148 -0
- package/dist/transformers/LinePrinter.js.map +1 -0
- package/dist/transformers/MergeResultSelectConverter.js +310 -0
- package/dist/transformers/MergeResultSelectConverter.js.map +1 -0
- package/dist/transformers/ModelDrivenJsonMapping.js +122 -0
- package/dist/transformers/ModelDrivenJsonMapping.js.map +1 -0
- package/dist/transformers/OnelineFormattingHelper.js +99 -0
- package/dist/transformers/OnelineFormattingHelper.js.map +1 -0
- package/dist/transformers/ParameterCollector.js +37 -0
- package/dist/transformers/ParameterCollector.js.map +1 -0
- package/dist/transformers/PostgresArrayEntityCteBuilder.js +458 -0
- package/dist/transformers/PostgresArrayEntityCteBuilder.js.map +1 -0
- package/dist/transformers/PostgresJsonQueryBuilder.js +245 -0
- package/dist/transformers/PostgresJsonQueryBuilder.js.map +1 -0
- package/dist/transformers/PostgresObjectEntityCteBuilder.js +347 -0
- package/dist/transformers/PostgresObjectEntityCteBuilder.js.map +1 -0
- package/dist/transformers/QueryBuilder.js +649 -0
- package/dist/transformers/QueryBuilder.js.map +1 -0
- package/dist/transformers/QueryFlowDiagramGenerator.js +157 -0
- package/dist/transformers/QueryFlowDiagramGenerator.js.map +1 -0
- package/dist/transformers/SchemaCollector.js +523 -0
- package/dist/transformers/SchemaCollector.js.map +1 -0
- package/dist/transformers/SelectResultSelectConverter.js +36 -0
- package/dist/transformers/SelectResultSelectConverter.js.map +1 -0
- package/dist/transformers/SelectValueCollector.js +244 -0
- package/dist/transformers/SelectValueCollector.js.map +1 -0
- package/dist/transformers/SelectableColumnCollector.js +674 -0
- package/dist/transformers/SelectableColumnCollector.js.map +1 -0
- package/dist/transformers/SimulatedSelectConverter.js +65 -0
- package/dist/transformers/SimulatedSelectConverter.js.map +1 -0
- package/dist/transformers/SmartRenamer.js +422 -0
- package/dist/transformers/SmartRenamer.js.map +1 -0
- package/dist/transformers/SqlFormatter.js +77 -0
- package/dist/transformers/SqlFormatter.js.map +1 -0
- package/dist/transformers/SqlIdentifierRenamer.js +504 -0
- package/dist/transformers/SqlIdentifierRenamer.js.map +1 -0
- package/dist/transformers/SqlOutputToken.js +13 -0
- package/dist/transformers/SqlOutputToken.js.map +1 -0
- package/dist/transformers/SqlPaginationInjector.js +108 -0
- package/dist/transformers/SqlPaginationInjector.js.map +1 -0
- package/dist/transformers/SqlParamInjector.js +802 -0
- package/dist/transformers/SqlParamInjector.js.map +1 -0
- package/dist/transformers/SqlParameterBinder.js +70 -0
- package/dist/transformers/SqlParameterBinder.js.map +1 -0
- package/dist/transformers/SqlPrinter.js +1478 -0
- package/dist/transformers/SqlPrinter.js.map +1 -0
- package/dist/transformers/SqlSortInjector.js +153 -0
- package/dist/transformers/SqlSortInjector.js.map +1 -0
- package/dist/transformers/TableColumnResolver.js +3 -0
- package/dist/transformers/TableColumnResolver.js.map +1 -0
- package/dist/transformers/TableSourceCollector.js +439 -0
- package/dist/transformers/TableSourceCollector.js.map +1 -0
- package/dist/transformers/TypeTransformationPostProcessor.js +363 -0
- package/dist/transformers/TypeTransformationPostProcessor.js.map +1 -0
- package/dist/transformers/UpdateResultSelectConverter.js +359 -0
- package/dist/transformers/UpdateResultSelectConverter.js.map +1 -0
- package/dist/transformers/UpstreamSelectQueryFinder.js +184 -0
- package/dist/transformers/UpstreamSelectQueryFinder.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/types/Formatting.js +3 -0
- package/dist/types/Formatting.js.map +1 -0
- package/dist/types/GenericFixture.js +3 -0
- package/dist/types/GenericFixture.js.map +1 -0
- package/dist/utils/CTERegionDetector.js +464 -0
- package/dist/utils/CTERegionDetector.js.map +1 -0
- package/dist/utils/CommentEditor.js +345 -0
- package/dist/utils/CommentEditor.js.map +1 -0
- package/dist/utils/CommentUtils.js +69 -0
- package/dist/utils/CommentUtils.js.map +1 -0
- package/dist/utils/CursorContextAnalyzer.js +338 -0
- package/dist/utils/CursorContextAnalyzer.js.map +1 -0
- package/dist/utils/IntelliSenseApi.js +292 -0
- package/dist/utils/IntelliSenseApi.js.map +1 -0
- package/dist/utils/JsonSchemaValidator.js +215 -0
- package/dist/utils/JsonSchemaValidator.js.map +1 -0
- package/dist/utils/KeywordCache.js +206 -0
- package/dist/utils/KeywordCache.js.map +1 -0
- package/dist/utils/LexemeCursor.js +314 -0
- package/dist/utils/LexemeCursor.js.map +1 -0
- package/dist/utils/MultiQuerySplitter.js +292 -0
- package/dist/utils/MultiQuerySplitter.js.map +1 -0
- package/dist/utils/OperatorPrecedence.js +107 -0
- package/dist/utils/OperatorPrecedence.js.map +1 -0
- package/dist/utils/ParameterDetector.js +53 -0
- package/dist/utils/ParameterDetector.js.map +1 -0
- package/dist/utils/ParameterHelper.js +31 -0
- package/dist/utils/ParameterHelper.js.map +1 -0
- package/dist/utils/ParameterRemover.js +783 -0
- package/dist/utils/ParameterRemover.js.map +1 -0
- package/dist/utils/ParserStringUtils.js +31 -0
- package/dist/utils/ParserStringUtils.js.map +1 -0
- package/dist/utils/PositionAwareParser.js +363 -0
- package/dist/utils/PositionAwareParser.js.map +1 -0
- package/dist/utils/SchemaManager.js +217 -0
- package/dist/utils/SchemaManager.js.map +1 -0
- package/dist/utils/ScopeResolver.js +272 -0
- package/dist/utils/ScopeResolver.js.map +1 -0
- package/dist/utils/SelectQueryWithClauseHelper.js +47 -0
- package/dist/utils/SelectQueryWithClauseHelper.js.map +1 -0
- package/dist/utils/SqlSchemaValidator.js +55 -0
- package/dist/utils/SqlSchemaValidator.js.map +1 -0
- package/dist/utils/TableNameUtils.js +35 -0
- package/dist/utils/TableNameUtils.js.map +1 -0
- package/dist/utils/TextPositionUtils.js +128 -0
- package/dist/utils/TextPositionUtils.js.map +1 -0
- package/dist/utils/ValueComponentRewriter.js +187 -0
- package/dist/utils/ValueComponentRewriter.js.map +1 -0
- package/dist/utils/charLookupTable.js +73 -0
- package/dist/utils/charLookupTable.js.map +1 -0
- package/dist/utils/stringUtils.js +230 -0
- package/dist/utils/stringUtils.js.map +1 -0
- package/package.json +62 -62
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AlterSequenceParser = exports.CreateSequenceParser = void 0;
|
|
4
|
+
const DDLStatements_1 = require("../models/DDLStatements");
|
|
5
|
+
const FullNameParser_1 = require("./FullNameParser");
|
|
6
|
+
const ValueComponent_1 = require("../models/ValueComponent");
|
|
7
|
+
const SqlTokenizer_1 = require("./SqlTokenizer");
|
|
8
|
+
const ValueParser_1 = require("./ValueParser");
|
|
9
|
+
const CREATE_SEQUENCE_COMMANDS = new Set([
|
|
10
|
+
"create sequence",
|
|
11
|
+
"create temporary sequence",
|
|
12
|
+
"create temp sequence"
|
|
13
|
+
]);
|
|
14
|
+
const SEQUENCE_CLAUSE_STARTERS = new Set([
|
|
15
|
+
"increment",
|
|
16
|
+
"start",
|
|
17
|
+
"minvalue",
|
|
18
|
+
"maxvalue",
|
|
19
|
+
"cache",
|
|
20
|
+
"cycle",
|
|
21
|
+
"owned",
|
|
22
|
+
"no"
|
|
23
|
+
]);
|
|
24
|
+
class CreateSequenceParser {
|
|
25
|
+
static parse(sql) {
|
|
26
|
+
var _a, _b;
|
|
27
|
+
const tokenizer = new SqlTokenizer_1.SqlTokenizer(sql);
|
|
28
|
+
const lexemes = tokenizer.readLexemes();
|
|
29
|
+
const result = this.parseFromLexeme(lexemes, 0);
|
|
30
|
+
// Ensure the statement was fully consumed and no extra tokens remain.
|
|
31
|
+
if (result.newIndex < lexemes.length) {
|
|
32
|
+
const unexpected = lexemes[result.newIndex];
|
|
33
|
+
const position = (_b = (_a = unexpected.position) === null || _a === void 0 ? void 0 : _a.startPosition) !== null && _b !== void 0 ? _b : 0;
|
|
34
|
+
throw new Error(`[CreateSequenceParser] Unexpected token "${unexpected.value}" at position ${position}.`);
|
|
35
|
+
}
|
|
36
|
+
return result.value;
|
|
37
|
+
}
|
|
38
|
+
static parseFromLexeme(lexemes, index) {
|
|
39
|
+
var _a, _b;
|
|
40
|
+
let idx = index;
|
|
41
|
+
// The cursor should start on a CREATE SEQUENCE command (possibly with TEMP/TEMPORARY).
|
|
42
|
+
const command = (_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase();
|
|
43
|
+
if (!command || !CREATE_SEQUENCE_COMMANDS.has(command)) {
|
|
44
|
+
throw new Error(`[CreateSequenceParser] Expected CREATE SEQUENCE at index ${idx}.`);
|
|
45
|
+
}
|
|
46
|
+
idx++;
|
|
47
|
+
let ifNotExists = false;
|
|
48
|
+
// Accept an optional IF NOT EXISTS clause.
|
|
49
|
+
if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase()) === "if not exists") {
|
|
50
|
+
ifNotExists = true;
|
|
51
|
+
idx++;
|
|
52
|
+
}
|
|
53
|
+
// Parse the qualified name of the target sequence.
|
|
54
|
+
const nameResult = FullNameParser_1.FullNameParser.parseFromLexeme(lexemes, idx);
|
|
55
|
+
const sequenceName = new ValueComponent_1.QualifiedName(nameResult.namespaces, nameResult.name);
|
|
56
|
+
idx = nameResult.newIndex;
|
|
57
|
+
// Gather sequence option clauses that follow the target identifier.
|
|
58
|
+
const optionsResult = parseSequenceClauses(lexemes, idx);
|
|
59
|
+
idx = optionsResult.newIndex;
|
|
60
|
+
return {
|
|
61
|
+
value: new DDLStatements_1.CreateSequenceStatement({
|
|
62
|
+
sequenceName,
|
|
63
|
+
ifNotExists,
|
|
64
|
+
clauses: optionsResult.clauses
|
|
65
|
+
}),
|
|
66
|
+
newIndex: idx
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
exports.CreateSequenceParser = CreateSequenceParser;
|
|
71
|
+
class AlterSequenceParser {
|
|
72
|
+
static parse(sql) {
|
|
73
|
+
var _a, _b;
|
|
74
|
+
const tokenizer = new SqlTokenizer_1.SqlTokenizer(sql);
|
|
75
|
+
const lexemes = tokenizer.readLexemes();
|
|
76
|
+
const result = this.parseFromLexeme(lexemes, 0);
|
|
77
|
+
// Guard against unexpected trailing tokens after a valid ALTER SEQUENCE statement.
|
|
78
|
+
if (result.newIndex < lexemes.length) {
|
|
79
|
+
const unexpected = lexemes[result.newIndex];
|
|
80
|
+
const position = (_b = (_a = unexpected.position) === null || _a === void 0 ? void 0 : _a.startPosition) !== null && _b !== void 0 ? _b : 0;
|
|
81
|
+
throw new Error(`[AlterSequenceParser] Unexpected token "${unexpected.value}" at position ${position}.`);
|
|
82
|
+
}
|
|
83
|
+
return result.value;
|
|
84
|
+
}
|
|
85
|
+
static parseFromLexeme(lexemes, index) {
|
|
86
|
+
var _a, _b;
|
|
87
|
+
let idx = index;
|
|
88
|
+
// Expect ALTER SEQUENCE as the leading keywords.
|
|
89
|
+
if (((_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase()) !== "alter sequence") {
|
|
90
|
+
throw new Error(`[AlterSequenceParser] Expected ALTER SEQUENCE at index ${idx}.`);
|
|
91
|
+
}
|
|
92
|
+
idx++;
|
|
93
|
+
let ifExists = false;
|
|
94
|
+
// Consume the optional IF EXISTS qualifier.
|
|
95
|
+
if (((_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase()) === "if exists") {
|
|
96
|
+
ifExists = true;
|
|
97
|
+
idx++;
|
|
98
|
+
}
|
|
99
|
+
// Parse the fully qualified sequence identifier.
|
|
100
|
+
const nameResult = FullNameParser_1.FullNameParser.parseFromLexeme(lexemes, idx);
|
|
101
|
+
const sequenceName = new ValueComponent_1.QualifiedName(nameResult.namespaces, nameResult.name);
|
|
102
|
+
idx = nameResult.newIndex;
|
|
103
|
+
// Capture any option clauses that follow.
|
|
104
|
+
const optionsResult = parseSequenceClauses(lexemes, idx);
|
|
105
|
+
idx = optionsResult.newIndex;
|
|
106
|
+
return {
|
|
107
|
+
value: new DDLStatements_1.AlterSequenceStatement({
|
|
108
|
+
sequenceName,
|
|
109
|
+
ifExists,
|
|
110
|
+
clauses: optionsResult.clauses
|
|
111
|
+
}),
|
|
112
|
+
newIndex: idx
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
exports.AlterSequenceParser = AlterSequenceParser;
|
|
117
|
+
function parseSequenceClauses(lexemes, index) {
|
|
118
|
+
var _a, _b, _c, _d, _e;
|
|
119
|
+
let idx = index;
|
|
120
|
+
// Continue parsing clause-by-clause until a non-clause token stops the loop.
|
|
121
|
+
const clauses = [];
|
|
122
|
+
while (idx < lexemes.length) {
|
|
123
|
+
const token = (_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase();
|
|
124
|
+
// Terminate when there are no more tokens left to consume.
|
|
125
|
+
if (!token) {
|
|
126
|
+
break;
|
|
127
|
+
}
|
|
128
|
+
// Recognize INCREMENT BY <value> while tolerating the optional BY keyword.
|
|
129
|
+
if (token === "increment") {
|
|
130
|
+
idx++;
|
|
131
|
+
idx = consumeOptionalKeyword(lexemes, idx, "by");
|
|
132
|
+
const valueResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
133
|
+
clauses.push({ kind: "increment", value: valueResult.value });
|
|
134
|
+
idx = valueResult.newIndex;
|
|
135
|
+
continue;
|
|
136
|
+
}
|
|
137
|
+
// START WITH <value> clause prefers a WITH keyword but does not require it.
|
|
138
|
+
if (token === "start") {
|
|
139
|
+
idx++;
|
|
140
|
+
idx = consumeOptionalKeyword(lexemes, idx, "with");
|
|
141
|
+
const valueResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
142
|
+
clauses.push({ kind: "start", value: valueResult.value });
|
|
143
|
+
idx = valueResult.newIndex;
|
|
144
|
+
continue;
|
|
145
|
+
}
|
|
146
|
+
// MINVALUE <value> clause captures the lower bound directly.
|
|
147
|
+
if (token === "minvalue") {
|
|
148
|
+
idx++;
|
|
149
|
+
const valueResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
150
|
+
clauses.push({ kind: "minValue", value: valueResult.value });
|
|
151
|
+
idx = valueResult.newIndex;
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
// MAXVALUE <value> clause captures the upper bound directly.
|
|
155
|
+
if (token === "maxvalue") {
|
|
156
|
+
idx++;
|
|
157
|
+
const valueResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
158
|
+
clauses.push({ kind: "maxValue", value: valueResult.value });
|
|
159
|
+
idx = valueResult.newIndex;
|
|
160
|
+
continue;
|
|
161
|
+
}
|
|
162
|
+
// CACHE <value> clause records the in-memory cache size.
|
|
163
|
+
if (token === "cache") {
|
|
164
|
+
idx++;
|
|
165
|
+
const valueResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
166
|
+
clauses.push({ kind: "cache", value: valueResult.value });
|
|
167
|
+
idx = valueResult.newIndex;
|
|
168
|
+
continue;
|
|
169
|
+
}
|
|
170
|
+
// CYCLE enables wrapping behavior.
|
|
171
|
+
if (token === "cycle") {
|
|
172
|
+
clauses.push({ kind: "cycle", enabled: true });
|
|
173
|
+
idx++;
|
|
174
|
+
continue;
|
|
175
|
+
}
|
|
176
|
+
// RESTART may be followed by an optional WITH keyword and/or a value before the next clause starts.
|
|
177
|
+
if (token === "restart") {
|
|
178
|
+
idx++;
|
|
179
|
+
idx = consumeOptionalKeyword(lexemes, idx, "with");
|
|
180
|
+
let restartValue;
|
|
181
|
+
const nextToken = (_b = lexemes[idx]) === null || _b === void 0 ? void 0 : _b.value.toLowerCase();
|
|
182
|
+
if (nextToken && !SEQUENCE_CLAUSE_STARTERS.has(nextToken)) {
|
|
183
|
+
const restartResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
184
|
+
restartValue = restartResult.value;
|
|
185
|
+
idx = restartResult.newIndex;
|
|
186
|
+
}
|
|
187
|
+
clauses.push({ kind: "restart", value: restartValue });
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
// OWNED BY clause can point to a target column or NONE.
|
|
191
|
+
if (token === "owned") {
|
|
192
|
+
idx++;
|
|
193
|
+
if (((_c = lexemes[idx]) === null || _c === void 0 ? void 0 : _c.value.toLowerCase()) !== "by") {
|
|
194
|
+
throw new Error(`[SequenceParser] Expected BY after OWNED at index ${idx}.`);
|
|
195
|
+
}
|
|
196
|
+
idx++;
|
|
197
|
+
const nextToken = (_d = lexemes[idx]) === null || _d === void 0 ? void 0 : _d.value.toLowerCase();
|
|
198
|
+
if (nextToken === "none") {
|
|
199
|
+
clauses.push({ kind: "ownedBy", none: true });
|
|
200
|
+
idx++;
|
|
201
|
+
continue;
|
|
202
|
+
}
|
|
203
|
+
const ownerResult = FullNameParser_1.FullNameParser.parseFromLexeme(lexemes, idx);
|
|
204
|
+
const ownerName = new ValueComponent_1.QualifiedName(ownerResult.namespaces, ownerResult.name);
|
|
205
|
+
clauses.push({ kind: "ownedBy", target: ownerName });
|
|
206
|
+
idx = ownerResult.newIndex;
|
|
207
|
+
continue;
|
|
208
|
+
}
|
|
209
|
+
// NO {MINVALUE|MAXVALUE|CACHE|CYCLE} disables the respective default clauses.
|
|
210
|
+
if (token === "no") {
|
|
211
|
+
const nextToken = (_e = lexemes[idx + 1]) === null || _e === void 0 ? void 0 : _e.value.toLowerCase();
|
|
212
|
+
if (nextToken === "minvalue") {
|
|
213
|
+
clauses.push({ kind: "minValue", noValue: true });
|
|
214
|
+
idx += 2;
|
|
215
|
+
continue;
|
|
216
|
+
}
|
|
217
|
+
if (nextToken === "maxvalue") {
|
|
218
|
+
clauses.push({ kind: "maxValue", noValue: true });
|
|
219
|
+
idx += 2;
|
|
220
|
+
continue;
|
|
221
|
+
}
|
|
222
|
+
if (nextToken === "cache") {
|
|
223
|
+
clauses.push({ kind: "cache", noValue: true });
|
|
224
|
+
idx += 2;
|
|
225
|
+
continue;
|
|
226
|
+
}
|
|
227
|
+
if (nextToken === "cycle") {
|
|
228
|
+
clauses.push({ kind: "cycle", enabled: false });
|
|
229
|
+
idx += 2;
|
|
230
|
+
continue;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
break;
|
|
234
|
+
}
|
|
235
|
+
return { clauses, newIndex: idx };
|
|
236
|
+
}
|
|
237
|
+
function consumeOptionalKeyword(lexemes, index, keyword) {
|
|
238
|
+
var _a;
|
|
239
|
+
// Skip an optional keyword that may appear before a value (e.g., BY or WITH).
|
|
240
|
+
if (((_a = lexemes[index]) === null || _a === void 0 ? void 0 : _a.value.toLowerCase()) === keyword) {
|
|
241
|
+
return index + 1;
|
|
242
|
+
}
|
|
243
|
+
return index;
|
|
244
|
+
}
|
|
245
|
+
//# sourceMappingURL=SequenceParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequenceParser.js","sourceRoot":"","sources":["../../src/parsers/SequenceParser.ts"],"names":[],"mappings":";;;AACA,2DAAgH;AAChH,qDAAkD;AAClD,6DAAyD;AACzD,iDAA8C;AAC9C,+CAA4C;AAE5C,MAAM,wBAAwB,GAAG,IAAI,GAAG,CAAC;IACrC,iBAAiB;IACjB,2BAA2B;IAC3B,sBAAsB;CACzB,CAAC,CAAC;AACH,MAAM,wBAAwB,GAAG,IAAI,GAAG,CAAC;IACrC,WAAW;IACX,OAAO;IACP,UAAU;IACV,UAAU;IACV,OAAO;IACP,OAAO;IACP,OAAO;IACP,IAAI;CACP,CAAC,CAAC;AAEH,MAAa,oBAAoB;IACtB,MAAM,CAAC,KAAK,CAAC,GAAW;;QAC3B,MAAM,SAAS,GAAG,IAAI,2BAAY,CAAC,GAAG,CAAC,CAAC;QACxC,MAAM,OAAO,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAChD,sEAAsE;QACtE,IAAI,MAAM,CAAC,QAAQ,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,MAAM,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC5C,MAAM,QAAQ,GAAG,MAAA,MAAA,UAAU,CAAC,QAAQ,0CAAE,aAAa,mCAAI,CAAC,CAAC;YACzD,MAAM,IAAI,KAAK,CACX,4CAA4C,UAAU,CAAC,KAAK,iBAAiB,QAAQ,GAAG,CAC3F,CAAC;QACN,CAAC;QACD,OAAO,MAAM,CAAC,KAAK,CAAC;IACxB,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,OAAiB,EAAE,KAAa;;QAC1D,IAAI,GAAG,GAAG,KAAK,CAAC;QAChB,uFAAuF;QACvF,MAAM,OAAO,GAAG,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,CAAC;QAClD,IAAI,CAAC,OAAO,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;YACrD,MAAM,IAAI,KAAK,CAAC,4DAA4D,GAAG,GAAG,CAAC,CAAC;QACxF,CAAC;QACD,GAAG,EAAE,CAAC;QAEN,IAAI,WAAW,GAAG,KAAK,CAAC;QACxB,2CAA2C;QAC3C,IAAI,CAAA,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,MAAK,eAAe,EAAE,CAAC;YACxD,WAAW,GAAG,IAAI,CAAC;YACnB,GAAG,EAAE,CAAC;QACV,CAAC;QAED,mDAAmD;QACnD,MAAM,UAAU,GAAG,+BAAc,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAChE,MAAM,YAAY,GAAG,IAAI,8BAAa,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAC/E,GAAG,GAAG,UAAU,CAAC,QAAQ,CAAC;QAE1B,oEAAoE;QACpE,MAAM,aAAa,GAAG,oBAAoB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACzD,GAAG,GAAG,aAAa,CAAC,QAAQ,CAAC;QAE7B,OAAO;YACH,KAAK,EAAE,IAAI,uCAAuB,CAAC;gBAC/B,YAAY;gBACZ,WAAW;gBACX,OAAO,EAAE,aAAa,CAAC,OAAO;aACjC,CAAC;YACF,QAAQ,EAAE,GAAG;SAChB,CAAC;IACN,CAAC;CACJ;AAlDD,oDAkDC;AAED,MAAa,mBAAmB;IACrB,MAAM,CAAC,KAAK,CAAC,GAAW;;QAC3B,MAAM,SAAS,GAAG,IAAI,2BAAY,CAAC,GAAG,CAAC,CAAC;QACxC,MAAM,OAAO,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QACxC,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAChD,mFAAmF;QACnF,IAAI,MAAM,CAAC,QAAQ,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACnC,MAAM,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC5C,MAAM,QAAQ,GAAG,MAAA,MAAA,UAAU,CAAC,QAAQ,0CAAE,aAAa,mCAAI,CAAC,CAAC;YACzD,MAAM,IAAI,KAAK,CACX,2CAA2C,UAAU,CAAC,KAAK,iBAAiB,QAAQ,GAAG,CAC1F,CAAC;QACN,CAAC;QACD,OAAO,MAAM,CAAC,KAAK,CAAC;IACxB,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,OAAiB,EAAE,KAAa;;QAC1D,IAAI,GAAG,GAAG,KAAK,CAAC;QAChB,iDAAiD;QACjD,IAAI,CAAA,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,MAAK,gBAAgB,EAAE,CAAC;YACzD,MAAM,IAAI,KAAK,CAAC,0DAA0D,GAAG,GAAG,CAAC,CAAC;QACtF,CAAC;QACD,GAAG,EAAE,CAAC;QAEN,IAAI,QAAQ,GAAG,KAAK,CAAC;QACrB,4CAA4C;QAC5C,IAAI,CAAA,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,MAAK,WAAW,EAAE,CAAC;YACpD,QAAQ,GAAG,IAAI,CAAC;YAChB,GAAG,EAAE,CAAC;QACV,CAAC;QAED,iDAAiD;QACjD,MAAM,UAAU,GAAG,+BAAc,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAChE,MAAM,YAAY,GAAG,IAAI,8BAAa,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAC/E,GAAG,GAAG,UAAU,CAAC,QAAQ,CAAC;QAE1B,0CAA0C;QAC1C,MAAM,aAAa,GAAG,oBAAoB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QACzD,GAAG,GAAG,aAAa,CAAC,QAAQ,CAAC;QAE7B,OAAO;YACH,KAAK,EAAE,IAAI,sCAAsB,CAAC;gBAC9B,YAAY;gBACZ,QAAQ;gBACR,OAAO,EAAE,aAAa,CAAC,OAAO;aACjC,CAAC;YACF,QAAQ,EAAE,GAAG;SAChB,CAAC;IACN,CAAC;CACJ;AAjDD,kDAiDC;AAED,SAAS,oBAAoB,CAAC,OAAiB,EAAE,KAAa;;IAC1D,IAAI,GAAG,GAAG,KAAK,CAAC;IAChB,6EAA6E;IAC7E,MAAM,OAAO,GAA2B,EAAE,CAAC;IAE3C,OAAO,GAAG,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAC1B,MAAM,KAAK,GAAG,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,CAAC;QAChD,2DAA2D;QAC3D,IAAI,CAAC,KAAK,EAAE,CAAC;YACT,MAAM;QACV,CAAC;QAED,2EAA2E;QAC3E,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;YACxB,GAAG,EAAE,CAAC;YACN,GAAG,GAAG,sBAAsB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;YACjD,MAAM,WAAW,GAAG,yBAAW,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAC9D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;YAC9D,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3B,SAAS;QACb,CAAC;QAED,4EAA4E;QAC5E,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;YACpB,GAAG,EAAE,CAAC;YACN,GAAG,GAAG,sBAAsB,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;YACnD,MAAM,WAAW,GAAG,yBAAW,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAC9D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;YAC1D,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3B,SAAS;QACb,CAAC;QAED,6DAA6D;QAC7D,IAAI,KAAK,KAAK,UAAU,EAAE,CAAC;YACvB,GAAG,EAAE,CAAC;YACN,MAAM,WAAW,GAAG,yBAAW,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAC9D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;YAC7D,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3B,SAAS;QACb,CAAC;QAED,6DAA6D;QAC7D,IAAI,KAAK,KAAK,UAAU,EAAE,CAAC;YACvB,GAAG,EAAE,CAAC;YACN,MAAM,WAAW,GAAG,yBAAW,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAC9D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;YAC7D,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3B,SAAS;QACb,CAAC;QAED,yDAAyD;QACzD,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;YACpB,GAAG,EAAE,CAAC;YACN,MAAM,WAAW,GAAG,yBAAW,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAC9D,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;YAC1D,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3B,SAAS;QACb,CAAC;QAED,mCAAmC;QACnC,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;YAC/C,GAAG,EAAE,CAAC;YACN,SAAS;QACb,CAAC;QAED,oGAAoG;QACpG,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACtB,GAAG,EAAE,CAAC;YACN,GAAG,GAAG,sBAAsB,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;YACnD,IAAI,YAAY,CAAC;YACjB,MAAM,SAAS,GAAG,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,CAAC;YACpD,IAAI,SAAS,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;gBACxD,MAAM,aAAa,GAAG,yBAAW,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;gBAChE,YAAY,GAAG,aAAa,CAAC,KAAK,CAAC;gBACnC,GAAG,GAAG,aAAa,CAAC,QAAQ,CAAC;YACjC,CAAC;YACD,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC;YACvD,SAAS;QACb,CAAC;QAED,wDAAwD;QACxD,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;YACpB,GAAG,EAAE,CAAC;YACN,IAAI,CAAA,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,MAAK,IAAI,EAAE,CAAC;gBAC7C,MAAM,IAAI,KAAK,CAAC,qDAAqD,GAAG,GAAG,CAAC,CAAC;YACjF,CAAC;YACD,GAAG,EAAE,CAAC;YACN,MAAM,SAAS,GAAG,MAAA,OAAO,CAAC,GAAG,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,CAAC;YACpD,IAAI,SAAS,KAAK,MAAM,EAAE,CAAC;gBACvB,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC9C,GAAG,EAAE,CAAC;gBACN,SAAS;YACb,CAAC;YACD,MAAM,WAAW,GAAG,+BAAc,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YACjE,MAAM,SAAS,GAAG,IAAI,8BAAa,CAAC,WAAW,CAAC,UAAU,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;YAC9E,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC;YACrD,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3B,SAAS;QACb,CAAC;QAED,8EAA8E;QAC9E,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACjB,MAAM,SAAS,GAAG,MAAA,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,CAAC;YACxD,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;gBAC3B,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBAClD,GAAG,IAAI,CAAC,CAAC;gBACT,SAAS;YACb,CAAC;YACD,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;gBAC3B,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBAClD,GAAG,IAAI,CAAC,CAAC;gBACT,SAAS;YACb,CAAC;YACD,IAAI,SAAS,KAAK,OAAO,EAAE,CAAC;gBACxB,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC/C,GAAG,IAAI,CAAC,CAAC;gBACT,SAAS;YACb,CAAC;YACD,IAAI,SAAS,KAAK,OAAO,EAAE,CAAC;gBACxB,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;gBAChD,GAAG,IAAI,CAAC,CAAC;gBACT,SAAS;YACb,CAAC;QACL,CAAC;QAED,MAAM;IACV,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC;AACtC,CAAC;AAED,SAAS,sBAAsB,CAAC,OAAiB,EAAE,KAAa,EAAE,OAAe;;IAC7E,8EAA8E;IAC9E,IAAI,CAAA,MAAA,OAAO,CAAC,KAAK,CAAC,0CAAE,KAAK,CAAC,WAAW,EAAE,MAAK,OAAO,EAAE,CAAC;QAClD,OAAO,KAAK,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,OAAO,KAAK,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SetClauseParser = void 0;
|
|
4
|
+
// Provides parsing for SET clauses in UPDATE queries.
|
|
5
|
+
const Lexeme_1 = require("../models/Lexeme");
|
|
6
|
+
const Clause_1 = require("../models/Clause");
|
|
7
|
+
const ValueParser_1 = require("./ValueParser");
|
|
8
|
+
const FullNameParser_1 = require("./FullNameParser");
|
|
9
|
+
const LexemeCommentUtils_1 = require("./utils/LexemeCommentUtils");
|
|
10
|
+
/**
|
|
11
|
+
* Parse SET clause from lexemes (including 'SET' keyword check).
|
|
12
|
+
*/
|
|
13
|
+
class SetClauseParser {
|
|
14
|
+
static parseFromLexeme(lexemes, idx) {
|
|
15
|
+
var _a;
|
|
16
|
+
if (lexemes[idx].value !== "set") {
|
|
17
|
+
throw new Error(`Syntax error at position ${idx}: Expected 'SET' but found '${lexemes[idx].value}'.`);
|
|
18
|
+
}
|
|
19
|
+
const setLexeme = lexemes[idx];
|
|
20
|
+
const setKeywordComments = (0, LexemeCommentUtils_1.extractLexemeComments)(setLexeme);
|
|
21
|
+
idx++;
|
|
22
|
+
const items = [];
|
|
23
|
+
let pendingBeforeForNext = [...setKeywordComments.after];
|
|
24
|
+
const mergeUnique = (target, source) => {
|
|
25
|
+
for (const comment of source) {
|
|
26
|
+
if (!target.includes(comment)) {
|
|
27
|
+
target.push(comment);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
const addUniquePositionedComments = (component, position, comments) => {
|
|
32
|
+
if (comments.length === 0) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
const existing = component.getPositionedComments(position);
|
|
36
|
+
const newOnes = comments.filter(comment => !existing.includes(comment));
|
|
37
|
+
if (newOnes.length > 0) {
|
|
38
|
+
component.addPositionedComments(position, newOnes);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
while (idx < lexemes.length) {
|
|
42
|
+
const currentLexeme = lexemes[idx];
|
|
43
|
+
if (!currentLexeme) {
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
// Break once we reach the start of the next clause (e.g. WHERE, FROM, RETURNING)
|
|
47
|
+
if (currentLexeme.value === "where" || currentLexeme.value === "from" || currentLexeme.value === "returning") {
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
if (!(currentLexeme.type & (Lexeme_1.TokenType.Identifier | Lexeme_1.TokenType.Function | Lexeme_1.TokenType.Type | Lexeme_1.TokenType.OpenBracket))) {
|
|
51
|
+
break;
|
|
52
|
+
}
|
|
53
|
+
const columnStartComments = (0, LexemeCommentUtils_1.extractLexemeComments)(currentLexeme);
|
|
54
|
+
const columnParseResult = FullNameParser_1.FullNameParser.parseFromLexeme(lexemes, idx);
|
|
55
|
+
idx = columnParseResult.newIndex;
|
|
56
|
+
const equalsLexeme = lexemes[idx];
|
|
57
|
+
if (!equalsLexeme || !(equalsLexeme.type & Lexeme_1.TokenType.Operator) || equalsLexeme.value !== "=") {
|
|
58
|
+
throw new Error(`Syntax error at position ${idx}: Expected '=' after column name in SET clause.`);
|
|
59
|
+
}
|
|
60
|
+
const equalsComments = (0, LexemeCommentUtils_1.extractLexemeComments)(equalsLexeme);
|
|
61
|
+
idx++;
|
|
62
|
+
// Parse value expression for the assignment.
|
|
63
|
+
const valueParseResult = ValueParser_1.ValueParser.parseFromLexeme(lexemes, idx);
|
|
64
|
+
idx = valueParseResult.newIndex;
|
|
65
|
+
const setItem = new Clause_1.SetClauseItem({ namespaces: columnParseResult.namespaces, column: columnParseResult.name }, valueParseResult.value);
|
|
66
|
+
// Attach comments that should appear before the assignment.
|
|
67
|
+
const beforeComments = [];
|
|
68
|
+
mergeUnique(beforeComments, pendingBeforeForNext);
|
|
69
|
+
mergeUnique(beforeComments, columnStartComments.before);
|
|
70
|
+
if (beforeComments.length > 0) {
|
|
71
|
+
addUniquePositionedComments(columnParseResult.name, "before", beforeComments);
|
|
72
|
+
}
|
|
73
|
+
pendingBeforeForNext = [];
|
|
74
|
+
// Preserve comments that trail the column identifier itself.
|
|
75
|
+
if (columnStartComments.after.length > 0) {
|
|
76
|
+
const afterComments = [];
|
|
77
|
+
mergeUnique(afterComments, columnStartComments.after);
|
|
78
|
+
addUniquePositionedComments(columnParseResult.name, "after", afterComments);
|
|
79
|
+
}
|
|
80
|
+
// Comments immediately before '=' belong to the assignment item.
|
|
81
|
+
if (equalsComments.before.length > 0) {
|
|
82
|
+
const equalsBefore = [];
|
|
83
|
+
mergeUnique(equalsBefore, equalsComments.before);
|
|
84
|
+
addUniquePositionedComments(columnParseResult.name, "after", equalsBefore);
|
|
85
|
+
}
|
|
86
|
+
// Comments captured after '=' should precede the value expression.
|
|
87
|
+
if (equalsComments.after.length > 0) {
|
|
88
|
+
const equalsAfter = [];
|
|
89
|
+
mergeUnique(equalsAfter, equalsComments.after);
|
|
90
|
+
addUniquePositionedComments(valueParseResult.value, "before", equalsAfter);
|
|
91
|
+
}
|
|
92
|
+
items.push(setItem);
|
|
93
|
+
if (((_a = lexemes[idx]) === null || _a === void 0 ? void 0 : _a.type) === Lexeme_1.TokenType.Comma) {
|
|
94
|
+
const commaLexeme = lexemes[idx];
|
|
95
|
+
const commaComments = (0, LexemeCommentUtils_1.extractLexemeComments)(commaLexeme);
|
|
96
|
+
idx++;
|
|
97
|
+
// Comments that appear before the comma belong to the current item.
|
|
98
|
+
if (commaComments.before.length > 0) {
|
|
99
|
+
const commaBefore = [];
|
|
100
|
+
mergeUnique(commaBefore, commaComments.before);
|
|
101
|
+
addUniquePositionedComments(setItem, "after", commaBefore);
|
|
102
|
+
}
|
|
103
|
+
const nextBefore = [];
|
|
104
|
+
mergeUnique(nextBefore, commaComments.after);
|
|
105
|
+
pendingBeforeForNext = nextBefore;
|
|
106
|
+
continue;
|
|
107
|
+
}
|
|
108
|
+
break;
|
|
109
|
+
}
|
|
110
|
+
if (pendingBeforeForNext.length > 0 && items.length > 0) {
|
|
111
|
+
const trailingComments = [];
|
|
112
|
+
mergeUnique(trailingComments, pendingBeforeForNext);
|
|
113
|
+
if (trailingComments.length > 0) {
|
|
114
|
+
addUniquePositionedComments(items[items.length - 1], "after", trailingComments);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
const setClause = new Clause_1.SetClause(items);
|
|
118
|
+
if (setKeywordComments.before.length > 0) {
|
|
119
|
+
setClause.addPositionedComments("before", setKeywordComments.before);
|
|
120
|
+
}
|
|
121
|
+
return { setClause, newIndex: idx };
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
exports.SetClauseParser = SetClauseParser;
|
|
125
|
+
//# sourceMappingURL=SetClauseParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SetClauseParser.js","sourceRoot":"","sources":["../../src/parsers/SetClauseParser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SourceAliasExpressionParser = void 0;
|
|
4
|
+
const Clause_1 = require("../models/Clause");
|
|
5
|
+
const Lexeme_1 = require("../models/Lexeme");
|
|
6
|
+
class SourceAliasExpressionParser {
|
|
7
|
+
// Parse from lexeme array (was: parse)
|
|
8
|
+
static parseFromLexeme(lexemes, index) {
|
|
9
|
+
var _a;
|
|
10
|
+
let idx = index;
|
|
11
|
+
// If there is a column alias, it may be detected as a function, so functions are also processed.
|
|
12
|
+
if (idx < lexemes.length && ((lexemes[idx].type & Lexeme_1.TokenType.Identifier) || (lexemes[idx].type & Lexeme_1.TokenType.Function))) {
|
|
13
|
+
// Check for alias and capture comments from the alias token
|
|
14
|
+
const aliasToken = lexemes[idx];
|
|
15
|
+
const table = aliasToken.value;
|
|
16
|
+
idx++;
|
|
17
|
+
if (idx < lexemes.length && (lexemes[idx].type & Lexeme_1.TokenType.OpenParen)) {
|
|
18
|
+
// Check for column alias
|
|
19
|
+
const columns = [];
|
|
20
|
+
// Skip the open parenthesis
|
|
21
|
+
idx++;
|
|
22
|
+
while (idx < lexemes.length && (lexemes[idx].type & Lexeme_1.TokenType.Identifier)) {
|
|
23
|
+
columns.push(lexemes[idx].value);
|
|
24
|
+
idx++;
|
|
25
|
+
if (idx < lexemes.length && (lexemes[idx].type & Lexeme_1.TokenType.Comma)) {
|
|
26
|
+
idx++;
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
break; // Exit loop if not a comma
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (lexemes[idx].type & Lexeme_1.TokenType.CloseParen) {
|
|
33
|
+
// Skip the closing parenthesis
|
|
34
|
+
idx++;
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
throw new Error(`Syntax error at position ${idx}: Missing closing parenthesis ')' for column alias list. Each opening parenthesis must have a matching closing parenthesis.`);
|
|
38
|
+
}
|
|
39
|
+
if (columns.length === 0) {
|
|
40
|
+
throw new Error(`Syntax error at position ${index}: No column aliases found. Column alias declarations must contain at least one column name.`);
|
|
41
|
+
}
|
|
42
|
+
const sourceAlias = new Clause_1.SourceAliasExpression(table, columns);
|
|
43
|
+
// Transfer positioned comments from the alias token
|
|
44
|
+
if (aliasToken.positionedComments && aliasToken.positionedComments.length > 0) {
|
|
45
|
+
sourceAlias.positionedComments = aliasToken.positionedComments;
|
|
46
|
+
}
|
|
47
|
+
return { value: sourceAlias, newIndex: idx };
|
|
48
|
+
}
|
|
49
|
+
const sourceAlias = new Clause_1.SourceAliasExpression(table, null);
|
|
50
|
+
// Transfer positioned comments from the alias token
|
|
51
|
+
if (aliasToken.positionedComments && aliasToken.positionedComments.length > 0) {
|
|
52
|
+
sourceAlias.positionedComments = aliasToken.positionedComments;
|
|
53
|
+
}
|
|
54
|
+
return { value: sourceAlias, newIndex: idx };
|
|
55
|
+
}
|
|
56
|
+
throw new Error(`Syntax error at position ${index}: Expected an identifier for table alias but found "${((_a = lexemes[index]) === null || _a === void 0 ? void 0 : _a.value) || 'end of input'}".`);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.SourceAliasExpressionParser = SourceAliasExpressionParser;
|
|
60
|
+
//# sourceMappingURL=SourceAliasExpressionParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SourceAliasExpressionParser.js","sourceRoot":"","sources":["../../src/parsers/SourceAliasExpressionParser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SourceExpressionParser = void 0;
|
|
4
|
+
const Clause_1 = require("../models/Clause");
|
|
5
|
+
const SqlTokenizer_1 = require("./SqlTokenizer");
|
|
6
|
+
const Lexeme_1 = require("../models/Lexeme");
|
|
7
|
+
const SourceParser_1 = require("./SourceParser");
|
|
8
|
+
const SourceAliasExpressionParser_1 = require("./SourceAliasExpressionParser");
|
|
9
|
+
class SourceExpressionParser {
|
|
10
|
+
/**
|
|
11
|
+
* Parse SQL string to SourceExpression (e.g. "table", "table as t", "schema.table t")
|
|
12
|
+
*/
|
|
13
|
+
static parse(query) {
|
|
14
|
+
const tokenizer = new SqlTokenizer_1.SqlTokenizer(query);
|
|
15
|
+
const lexemes = tokenizer.readLexmes();
|
|
16
|
+
const result = this.parseFromLexeme(lexemes, 0);
|
|
17
|
+
if (result.newIndex < lexemes.length) {
|
|
18
|
+
throw new Error(`Syntax error: Unexpected token "${lexemes[result.newIndex].value}" at position ${result.newIndex}. The source expression is complete but there are additional tokens.`);
|
|
19
|
+
}
|
|
20
|
+
return result.value;
|
|
21
|
+
}
|
|
22
|
+
static parseTableSourceFromLexemes(lexemes, index) {
|
|
23
|
+
const result = SourceParser_1.SourceParser.parseTableSourceFromLexemes(lexemes, index);
|
|
24
|
+
// No alias for table source
|
|
25
|
+
const sourceExpr = new Clause_1.SourceExpression(result.value, null);
|
|
26
|
+
return { value: sourceExpr, newIndex: result.newIndex };
|
|
27
|
+
}
|
|
28
|
+
// Parse from lexeme array (was: parse)
|
|
29
|
+
static parseFromLexeme(lexemes, index) {
|
|
30
|
+
let idx = index;
|
|
31
|
+
const sourceResult = SourceParser_1.SourceParser.parseFromLexeme(lexemes, idx);
|
|
32
|
+
idx = sourceResult.newIndex;
|
|
33
|
+
if (idx < lexemes.length) {
|
|
34
|
+
if (lexemes[idx].value === "as") {
|
|
35
|
+
idx++;
|
|
36
|
+
const aliasResult = SourceAliasExpressionParser_1.SourceAliasExpressionParser.parseFromLexeme(lexemes, idx);
|
|
37
|
+
idx = aliasResult.newIndex;
|
|
38
|
+
const sourceExpr = new Clause_1.SourceExpression(sourceResult.value, aliasResult.value);
|
|
39
|
+
return { value: sourceExpr, newIndex: idx };
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Explanation:
|
|
43
|
+
* Source aliases are typically identified as TokenType.Identifier.
|
|
44
|
+
* However, when the 'AS' keyword is omitted and column alias names are specified,
|
|
45
|
+
* they may sometimes be classified as TokenType.Function.
|
|
46
|
+
* Since the TokenReader's responsibility is to perform coarse-grained classification,
|
|
47
|
+
* the parser must interpret subsequent 'Function' tokens as source alias expressions
|
|
48
|
+
* when they follow a source definition.
|
|
49
|
+
* Example:
|
|
50
|
+
* SQL: select t.* from (values(1)) t(id)
|
|
51
|
+
* Explanation: The alias 't' and its column alias 'id' are parsed as a source alias expression.
|
|
52
|
+
*/
|
|
53
|
+
if (idx < lexemes.length && this.isTokenTypeAliasCandidate(lexemes[idx].type)) {
|
|
54
|
+
const aliasResult = SourceAliasExpressionParser_1.SourceAliasExpressionParser.parseFromLexeme(lexemes, idx);
|
|
55
|
+
idx = aliasResult.newIndex;
|
|
56
|
+
const sourceExpr = new Clause_1.SourceExpression(sourceResult.value, aliasResult.value);
|
|
57
|
+
return { value: sourceExpr, newIndex: idx };
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
// no alias
|
|
61
|
+
const expr = new Clause_1.SourceExpression(sourceResult.value, null);
|
|
62
|
+
return { value: expr, newIndex: idx };
|
|
63
|
+
}
|
|
64
|
+
static isTokenTypeAliasCandidate(type) {
|
|
65
|
+
return (type & Lexeme_1.TokenType.Identifier) !== 0 || (type & Lexeme_1.TokenType.Function) !== 0;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.SourceExpressionParser = SourceExpressionParser;
|
|
69
|
+
//# sourceMappingURL=SourceExpressionParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SourceExpressionParser.js","sourceRoot":"","sources":["../../src/parsers/SourceExpressionParser.ts"],"names":[],"mappings":"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"}
|