@guojc1/sql-formatter-compact 1.0.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/AUTHORS +75 -0
- package/LICENSE +23 -0
- package/README.md +318 -0
- package/bin/sql-formatter-cli.cjs +182 -0
- package/dist/cjs/FormatOptions.d.ts +27 -0
- package/dist/cjs/FormatOptions.js +3 -0
- package/dist/cjs/FormatOptions.js.map +1 -0
- package/dist/cjs/allDialects.d.ts +20 -0
- package/dist/cjs/allDialects.js +44 -0
- package/dist/cjs/allDialects.js.map +1 -0
- package/dist/cjs/dialect.d.ts +18 -0
- package/dist/cjs/dialect.js +35 -0
- package/dist/cjs/dialect.js.map +1 -0
- package/dist/cjs/expandPhrases.d.ts +29 -0
- package/dist/cjs/expandPhrases.js +132 -0
- package/dist/cjs/expandPhrases.js.map +1 -0
- package/dist/cjs/formatter/ExpressionFormatter.d.ts +78 -0
- package/dist/cjs/formatter/ExpressionFormatter.js +546 -0
- package/dist/cjs/formatter/ExpressionFormatter.js.map +1 -0
- package/dist/cjs/formatter/Formatter.d.ts +18 -0
- package/dist/cjs/formatter/Formatter.js +80 -0
- package/dist/cjs/formatter/Formatter.js.map +1 -0
- package/dist/cjs/formatter/Indentation.d.ts +43 -0
- package/dist/cjs/formatter/Indentation.js +70 -0
- package/dist/cjs/formatter/Indentation.js.map +1 -0
- package/dist/cjs/formatter/InlineLayout.d.ts +21 -0
- package/dist/cjs/formatter/InlineLayout.js +88 -0
- package/dist/cjs/formatter/InlineLayout.js.map +1 -0
- package/dist/cjs/formatter/Layout.d.ts +41 -0
- package/dist/cjs/formatter/Layout.js +122 -0
- package/dist/cjs/formatter/Layout.js.map +1 -0
- package/dist/cjs/formatter/Params.d.ts +26 -0
- package/dist/cjs/formatter/Params.js +37 -0
- package/dist/cjs/formatter/Params.js.map +1 -0
- package/dist/cjs/formatter/config.d.ts +9 -0
- package/dist/cjs/formatter/config.js +25 -0
- package/dist/cjs/formatter/config.js.map +1 -0
- package/dist/cjs/formatter/tabularStyle.d.ts +11 -0
- package/dist/cjs/formatter/tabularStyle.js +39 -0
- package/dist/cjs/formatter/tabularStyle.js.map +1 -0
- package/dist/cjs/index.d.ts +28 -0
- package/dist/cjs/index.js +53 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/languages/bigquery/bigquery.formatter.d.ts +2 -0
- package/dist/cjs/languages/bigquery/bigquery.formatter.js +259 -0
- package/dist/cjs/languages/bigquery/bigquery.formatter.js.map +1 -0
- package/dist/cjs/languages/bigquery/bigquery.functions.d.ts +1 -0
- package/dist/cjs/languages/bigquery/bigquery.functions.js +549 -0
- package/dist/cjs/languages/bigquery/bigquery.functions.js.map +1 -0
- package/dist/cjs/languages/bigquery/bigquery.keywords.d.ts +2 -0
- package/dist/cjs/languages/bigquery/bigquery.keywords.js +139 -0
- package/dist/cjs/languages/bigquery/bigquery.keywords.js.map +1 -0
- package/dist/cjs/languages/clickhouse/clickhouse.formatter.d.ts +2 -0
- package/dist/cjs/languages/clickhouse/clickhouse.formatter.js +323 -0
- package/dist/cjs/languages/clickhouse/clickhouse.formatter.js.map +1 -0
- package/dist/cjs/languages/clickhouse/clickhouse.functions.d.ts +1 -0
- package/dist/cjs/languages/clickhouse/clickhouse.functions.js +1756 -0
- package/dist/cjs/languages/clickhouse/clickhouse.functions.js.map +1 -0
- package/dist/cjs/languages/clickhouse/clickhouse.keywords.d.ts +2 -0
- package/dist/cjs/languages/clickhouse/clickhouse.keywords.js +550 -0
- package/dist/cjs/languages/clickhouse/clickhouse.keywords.js.map +1 -0
- package/dist/cjs/languages/db2/db2.formatter.d.ts +2 -0
- package/dist/cjs/languages/db2/db2.formatter.js +304 -0
- package/dist/cjs/languages/db2/db2.formatter.js.map +1 -0
- package/dist/cjs/languages/db2/db2.functions.d.ts +1 -0
- package/dist/cjs/languages/db2/db2.functions.js +325 -0
- package/dist/cjs/languages/db2/db2.functions.js.map +1 -0
- package/dist/cjs/languages/db2/db2.keywords.d.ts +2 -0
- package/dist/cjs/languages/db2/db2.keywords.js +449 -0
- package/dist/cjs/languages/db2/db2.keywords.js.map +1 -0
- package/dist/cjs/languages/db2i/db2i.formatter.d.ts +2 -0
- package/dist/cjs/languages/db2i/db2i.formatter.js +181 -0
- package/dist/cjs/languages/db2i/db2i.formatter.js.map +1 -0
- package/dist/cjs/languages/db2i/db2i.functions.d.ts +1 -0
- package/dist/cjs/languages/db2i/db2i.functions.js +339 -0
- package/dist/cjs/languages/db2i/db2i.functions.js.map +1 -0
- package/dist/cjs/languages/db2i/db2i.keywords.d.ts +2 -0
- package/dist/cjs/languages/db2i/db2i.keywords.js +538 -0
- package/dist/cjs/languages/db2i/db2i.keywords.js.map +1 -0
- package/dist/cjs/languages/duckdb/duckdb.formatter.d.ts +2 -0
- package/dist/cjs/languages/duckdb/duckdb.formatter.js +213 -0
- package/dist/cjs/languages/duckdb/duckdb.formatter.js.map +1 -0
- package/dist/cjs/languages/duckdb/duckdb.functions.d.ts +1 -0
- package/dist/cjs/languages/duckdb/duckdb.functions.js +668 -0
- package/dist/cjs/languages/duckdb/duckdb.functions.js.map +1 -0
- package/dist/cjs/languages/duckdb/duckdb.keywords.d.ts +2 -0
- package/dist/cjs/languages/duckdb/duckdb.keywords.js +168 -0
- package/dist/cjs/languages/duckdb/duckdb.keywords.js.map +1 -0
- package/dist/cjs/languages/hive/hive.formatter.d.ts +2 -0
- package/dist/cjs/languages/hive/hive.formatter.js +106 -0
- package/dist/cjs/languages/hive/hive.formatter.js.map +1 -0
- package/dist/cjs/languages/hive/hive.functions.d.ts +1 -0
- package/dist/cjs/languages/hive/hive.functions.js +213 -0
- package/dist/cjs/languages/hive/hive.functions.js.map +1 -0
- package/dist/cjs/languages/hive/hive.keywords.d.ts +2 -0
- package/dist/cjs/languages/hive/hive.keywords.js +342 -0
- package/dist/cjs/languages/hive/hive.keywords.js.map +1 -0
- package/dist/cjs/languages/mariadb/likeMariaDb.d.ts +2 -0
- package/dist/cjs/languages/mariadb/likeMariaDb.js +22 -0
- package/dist/cjs/languages/mariadb/likeMariaDb.js.map +1 -0
- package/dist/cjs/languages/mariadb/mariadb.formatter.d.ts +2 -0
- package/dist/cjs/languages/mariadb/mariadb.formatter.js +317 -0
- package/dist/cjs/languages/mariadb/mariadb.formatter.js.map +1 -0
- package/dist/cjs/languages/mariadb/mariadb.functions.d.ts +1 -0
- package/dist/cjs/languages/mariadb/mariadb.functions.js +243 -0
- package/dist/cjs/languages/mariadb/mariadb.functions.js.map +1 -0
- package/dist/cjs/languages/mariadb/mariadb.keywords.d.ts +2 -0
- package/dist/cjs/languages/mariadb/mariadb.keywords.js +274 -0
- package/dist/cjs/languages/mariadb/mariadb.keywords.js.map +1 -0
- package/dist/cjs/languages/mysql/mysql.formatter.d.ts +2 -0
- package/dist/cjs/languages/mysql/mysql.formatter.js +284 -0
- package/dist/cjs/languages/mysql/mysql.formatter.js.map +1 -0
- package/dist/cjs/languages/mysql/mysql.functions.d.ts +1 -0
- package/dist/cjs/languages/mysql/mysql.functions.js +428 -0
- package/dist/cjs/languages/mysql/mysql.functions.js.map +1 -0
- package/dist/cjs/languages/mysql/mysql.keywords.d.ts +2 -0
- package/dist/cjs/languages/mysql/mysql.keywords.js +288 -0
- package/dist/cjs/languages/mysql/mysql.keywords.js.map +1 -0
- package/dist/cjs/languages/n1ql/n1ql.formatter.d.ts +2 -0
- package/dist/cjs/languages/n1ql/n1ql.formatter.js +109 -0
- package/dist/cjs/languages/n1ql/n1ql.formatter.js.map +1 -0
- package/dist/cjs/languages/n1ql/n1ql.functions.d.ts +1 -0
- package/dist/cjs/languages/n1ql/n1ql.functions.js +235 -0
- package/dist/cjs/languages/n1ql/n1ql.functions.js.map +1 -0
- package/dist/cjs/languages/n1ql/n1ql.keywords.d.ts +2 -0
- package/dist/cjs/languages/n1ql/n1ql.keywords.js +221 -0
- package/dist/cjs/languages/n1ql/n1ql.keywords.js.map +1 -0
- package/dist/cjs/languages/plsql/plsql.formatter.d.ts +2 -0
- package/dist/cjs/languages/plsql/plsql.formatter.js +140 -0
- package/dist/cjs/languages/plsql/plsql.formatter.js.map +1 -0
- package/dist/cjs/languages/plsql/plsql.functions.d.ts +1 -0
- package/dist/cjs/languages/plsql/plsql.functions.js +270 -0
- package/dist/cjs/languages/plsql/plsql.functions.js.map +1 -0
- package/dist/cjs/languages/plsql/plsql.keywords.d.ts +2 -0
- package/dist/cjs/languages/plsql/plsql.keywords.js +349 -0
- package/dist/cjs/languages/plsql/plsql.keywords.js.map +1 -0
- package/dist/cjs/languages/postgresql/postgresql.formatter.d.ts +2 -0
- package/dist/cjs/languages/postgresql/postgresql.formatter.js +391 -0
- package/dist/cjs/languages/postgresql/postgresql.formatter.js.map +1 -0
- package/dist/cjs/languages/postgresql/postgresql.functions.d.ts +1 -0
- package/dist/cjs/languages/postgresql/postgresql.functions.js +693 -0
- package/dist/cjs/languages/postgresql/postgresql.functions.js.map +1 -0
- package/dist/cjs/languages/postgresql/postgresql.keywords.d.ts +2 -0
- package/dist/cjs/languages/postgresql/postgresql.keywords.js +158 -0
- package/dist/cjs/languages/postgresql/postgresql.keywords.js.map +1 -0
- package/dist/cjs/languages/redshift/redshift.formatter.d.ts +2 -0
- package/dist/cjs/languages/redshift/redshift.formatter.js +180 -0
- package/dist/cjs/languages/redshift/redshift.formatter.js.map +1 -0
- package/dist/cjs/languages/redshift/redshift.functions.d.ts +1 -0
- package/dist/cjs/languages/redshift/redshift.functions.js +351 -0
- package/dist/cjs/languages/redshift/redshift.functions.js.map +1 -0
- package/dist/cjs/languages/redshift/redshift.keywords.d.ts +2 -0
- package/dist/cjs/languages/redshift/redshift.keywords.js +216 -0
- package/dist/cjs/languages/redshift/redshift.keywords.js.map +1 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.formatter.d.ts +2 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.formatter.js +286 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.formatter.js.map +1 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.functions.d.ts +1 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.functions.js +285 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.functions.js.map +1 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.keywords.d.ts +2 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.keywords.js +268 -0
- package/dist/cjs/languages/singlestoredb/singlestoredb.keywords.js.map +1 -0
- package/dist/cjs/languages/snowflake/snowflake.formatter.d.ts +2 -0
- package/dist/cjs/languages/snowflake/snowflake.formatter.js +339 -0
- package/dist/cjs/languages/snowflake/snowflake.formatter.js.map +1 -0
- package/dist/cjs/languages/snowflake/snowflake.functions.d.ts +1 -0
- package/dist/cjs/languages/snowflake/snowflake.functions.js +613 -0
- package/dist/cjs/languages/snowflake/snowflake.functions.js.map +1 -0
- package/dist/cjs/languages/snowflake/snowflake.keywords.d.ts +2 -0
- package/dist/cjs/languages/snowflake/snowflake.keywords.js +140 -0
- package/dist/cjs/languages/snowflake/snowflake.keywords.js.map +1 -0
- package/dist/cjs/languages/spark/spark.formatter.d.ts +2 -0
- package/dist/cjs/languages/spark/spark.formatter.js +167 -0
- package/dist/cjs/languages/spark/spark.formatter.js.map +1 -0
- package/dist/cjs/languages/spark/spark.functions.d.ts +1 -0
- package/dist/cjs/languages/spark/spark.functions.js +326 -0
- package/dist/cjs/languages/spark/spark.functions.js.map +1 -0
- package/dist/cjs/languages/spark/spark.keywords.d.ts +2 -0
- package/dist/cjs/languages/spark/spark.keywords.js +302 -0
- package/dist/cjs/languages/spark/spark.keywords.js.map +1 -0
- package/dist/cjs/languages/sql/sql.formatter.d.ts +2 -0
- package/dist/cjs/languages/sql/sql.formatter.js +97 -0
- package/dist/cjs/languages/sql/sql.formatter.js.map +1 -0
- package/dist/cjs/languages/sql/sql.functions.d.ts +1 -0
- package/dist/cjs/languages/sql/sql.functions.js +102 -0
- package/dist/cjs/languages/sql/sql.functions.js.map +1 -0
- package/dist/cjs/languages/sql/sql.keywords.d.ts +2 -0
- package/dist/cjs/languages/sql/sql.keywords.js +244 -0
- package/dist/cjs/languages/sql/sql.keywords.js.map +1 -0
- package/dist/cjs/languages/sqlite/sqlite.formatter.d.ts +2 -0
- package/dist/cjs/languages/sqlite/sqlite.formatter.js +94 -0
- package/dist/cjs/languages/sqlite/sqlite.formatter.js.map +1 -0
- package/dist/cjs/languages/sqlite/sqlite.functions.d.ts +1 -0
- package/dist/cjs/languages/sqlite/sqlite.functions.js +129 -0
- package/dist/cjs/languages/sqlite/sqlite.functions.js.map +1 -0
- package/dist/cjs/languages/sqlite/sqlite.keywords.d.ts +2 -0
- package/dist/cjs/languages/sqlite/sqlite.keywords.js +180 -0
- package/dist/cjs/languages/sqlite/sqlite.keywords.js.map +1 -0
- package/dist/cjs/languages/tidb/tidb.formatter.d.ts +2 -0
- package/dist/cjs/languages/tidb/tidb.formatter.js +218 -0
- package/dist/cjs/languages/tidb/tidb.formatter.js.map +1 -0
- package/dist/cjs/languages/tidb/tidb.functions.d.ts +1 -0
- package/dist/cjs/languages/tidb/tidb.functions.js +331 -0
- package/dist/cjs/languages/tidb/tidb.functions.js.map +1 -0
- package/dist/cjs/languages/tidb/tidb.keywords.d.ts +2 -0
- package/dist/cjs/languages/tidb/tidb.keywords.js +244 -0
- package/dist/cjs/languages/tidb/tidb.keywords.js.map +1 -0
- package/dist/cjs/languages/transactsql/transactsql.formatter.d.ts +2 -0
- package/dist/cjs/languages/transactsql/transactsql.formatter.js +275 -0
- package/dist/cjs/languages/transactsql/transactsql.formatter.js.map +1 -0
- package/dist/cjs/languages/transactsql/transactsql.functions.d.ts +1 -0
- package/dist/cjs/languages/transactsql/transactsql.functions.js +310 -0
- package/dist/cjs/languages/transactsql/transactsql.functions.js.map +1 -0
- package/dist/cjs/languages/transactsql/transactsql.keywords.d.ts +2 -0
- package/dist/cjs/languages/transactsql/transactsql.keywords.js +214 -0
- package/dist/cjs/languages/transactsql/transactsql.keywords.js.map +1 -0
- package/dist/cjs/languages/trino/trino.formatter.d.ts +2 -0
- package/dist/cjs/languages/trino/trino.formatter.js +163 -0
- package/dist/cjs/languages/trino/trino.formatter.js.map +1 -0
- package/dist/cjs/languages/trino/trino.functions.d.ts +1 -0
- package/dist/cjs/languages/trino/trino.functions.js +439 -0
- package/dist/cjs/languages/trino/trino.functions.js.map +1 -0
- package/dist/cjs/languages/trino/trino.keywords.d.ts +2 -0
- package/dist/cjs/languages/trino/trino.keywords.js +282 -0
- package/dist/cjs/languages/trino/trino.keywords.js.map +1 -0
- package/dist/cjs/lexer/NestedComment.d.ts +10 -0
- package/dist/cjs/lexer/NestedComment.js +54 -0
- package/dist/cjs/lexer/NestedComment.js.map +1 -0
- package/dist/cjs/lexer/Tokenizer.d.ts +14 -0
- package/dist/cjs/lexer/Tokenizer.js +293 -0
- package/dist/cjs/lexer/Tokenizer.js.map +1 -0
- package/dist/cjs/lexer/TokenizerEngine.d.ts +31 -0
- package/dist/cjs/lexer/TokenizerEngine.js +95 -0
- package/dist/cjs/lexer/TokenizerEngine.js.map +1 -0
- package/dist/cjs/lexer/TokenizerOptions.d.ts +56 -0
- package/dist/cjs/lexer/TokenizerOptions.js +3 -0
- package/dist/cjs/lexer/TokenizerOptions.js.map +1 -0
- package/dist/cjs/lexer/disambiguateTokens.d.ts +18 -0
- package/dist/cjs/lexer/disambiguateTokens.js +90 -0
- package/dist/cjs/lexer/disambiguateTokens.js.map +1 -0
- package/dist/cjs/lexer/lineColFromIndex.d.ts +8 -0
- package/dist/cjs/lexer/lineColFromIndex.js +12 -0
- package/dist/cjs/lexer/lineColFromIndex.js.map +1 -0
- package/dist/cjs/lexer/regexFactory.d.ts +55 -0
- package/dist/cjs/lexer/regexFactory.js +153 -0
- package/dist/cjs/lexer/regexFactory.js.map +1 -0
- package/dist/cjs/lexer/regexUtil.d.ts +7 -0
- package/dist/cjs/lexer/regexUtil.js +21 -0
- package/dist/cjs/lexer/regexUtil.js.map +1 -0
- package/dist/cjs/lexer/token.d.ts +89 -0
- package/dist/cjs/lexer/token.js +101 -0
- package/dist/cjs/lexer/token.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/parser/LexerAdapter.d.ts +17 -0
- package/dist/cjs/parser/LexerAdapter.js +30 -0
- package/dist/cjs/parser/LexerAdapter.js.map +1 -0
- package/dist/cjs/parser/ast.d.ts +158 -0
- package/dist/cjs/parser/ast.js +31 -0
- package/dist/cjs/parser/ast.js.map +1 -0
- package/dist/cjs/parser/createParser.d.ts +10 -0
- package/dist/cjs/parser/createParser.js +43 -0
- package/dist/cjs/parser/createParser.js.map +1 -0
- package/dist/cjs/parser/grammar.d.ts +28 -0
- package/dist/cjs/parser/grammar.js +371 -0
- package/dist/cjs/parser/grammar.js.map +1 -0
- package/dist/cjs/sqlFormatter.d.ts +31 -0
- package/dist/cjs/sqlFormatter.js +117 -0
- package/dist/cjs/sqlFormatter.js.map +1 -0
- package/dist/cjs/utils.d.ts +8 -0
- package/dist/cjs/utils.js +22 -0
- package/dist/cjs/utils.js.map +1 -0
- package/dist/cjs/validateConfig.d.ts +4 -0
- package/dist/cjs/validateConfig.js +43 -0
- package/dist/cjs/validateConfig.js.map +1 -0
- package/dist/esm/FormatOptions.d.ts +27 -0
- package/dist/esm/FormatOptions.js +2 -0
- package/dist/esm/FormatOptions.js.map +1 -0
- package/dist/esm/allDialects.d.ts +20 -0
- package/dist/esm/allDialects.js +21 -0
- package/dist/esm/allDialects.js.map +1 -0
- package/dist/esm/dialect.d.ts +18 -0
- package/dist/esm/dialect.js +28 -0
- package/dist/esm/dialect.js.map +1 -0
- package/dist/esm/expandPhrases.d.ts +29 -0
- package/dist/esm/expandPhrases.js +127 -0
- package/dist/esm/expandPhrases.js.map +1 -0
- package/dist/esm/formatter/ExpressionFormatter.d.ts +78 -0
- package/dist/esm/formatter/ExpressionFormatter.js +520 -0
- package/dist/esm/formatter/ExpressionFormatter.js.map +1 -0
- package/dist/esm/formatter/Formatter.d.ts +18 -0
- package/dist/esm/formatter/Formatter.js +51 -0
- package/dist/esm/formatter/Formatter.js.map +1 -0
- package/dist/esm/formatter/Indentation.d.ts +43 -0
- package/dist/esm/formatter/Indentation.js +67 -0
- package/dist/esm/formatter/Indentation.js.map +1 -0
- package/dist/esm/formatter/InlineLayout.d.ts +21 -0
- package/dist/esm/formatter/InlineLayout.js +57 -0
- package/dist/esm/formatter/InlineLayout.js.map +1 -0
- package/dist/esm/formatter/Layout.d.ts +41 -0
- package/dist/esm/formatter/Layout.js +118 -0
- package/dist/esm/formatter/Layout.js.map +1 -0
- package/dist/esm/formatter/Params.d.ts +26 -0
- package/dist/esm/formatter/Params.js +34 -0
- package/dist/esm/formatter/Params.js.map +1 -0
- package/dist/esm/formatter/config.d.ts +9 -0
- package/dist/esm/formatter/config.js +20 -0
- package/dist/esm/formatter/config.js.map +1 -0
- package/dist/esm/formatter/tabularStyle.d.ts +11 -0
- package/dist/esm/formatter/tabularStyle.js +34 -0
- package/dist/esm/formatter/tabularStyle.js.map +1 -0
- package/dist/esm/index.d.ts +28 -0
- package/dist/esm/index.js +25 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/languages/bigquery/bigquery.formatter.d.ts +2 -0
- package/dist/esm/languages/bigquery/bigquery.formatter.js +256 -0
- package/dist/esm/languages/bigquery/bigquery.formatter.js.map +1 -0
- package/dist/esm/languages/bigquery/bigquery.functions.d.ts +1 -0
- package/dist/esm/languages/bigquery/bigquery.functions.js +546 -0
- package/dist/esm/languages/bigquery/bigquery.functions.js.map +1 -0
- package/dist/esm/languages/bigquery/bigquery.keywords.d.ts +2 -0
- package/dist/esm/languages/bigquery/bigquery.keywords.js +136 -0
- package/dist/esm/languages/bigquery/bigquery.keywords.js.map +1 -0
- package/dist/esm/languages/clickhouse/clickhouse.formatter.d.ts +2 -0
- package/dist/esm/languages/clickhouse/clickhouse.formatter.js +320 -0
- package/dist/esm/languages/clickhouse/clickhouse.formatter.js.map +1 -0
- package/dist/esm/languages/clickhouse/clickhouse.functions.d.ts +1 -0
- package/dist/esm/languages/clickhouse/clickhouse.functions.js +1753 -0
- package/dist/esm/languages/clickhouse/clickhouse.functions.js.map +1 -0
- package/dist/esm/languages/clickhouse/clickhouse.keywords.d.ts +2 -0
- package/dist/esm/languages/clickhouse/clickhouse.keywords.js +547 -0
- package/dist/esm/languages/clickhouse/clickhouse.keywords.js.map +1 -0
- package/dist/esm/languages/db2/db2.formatter.d.ts +2 -0
- package/dist/esm/languages/db2/db2.formatter.js +301 -0
- package/dist/esm/languages/db2/db2.formatter.js.map +1 -0
- package/dist/esm/languages/db2/db2.functions.d.ts +1 -0
- package/dist/esm/languages/db2/db2.functions.js +322 -0
- package/dist/esm/languages/db2/db2.functions.js.map +1 -0
- package/dist/esm/languages/db2/db2.keywords.d.ts +2 -0
- package/dist/esm/languages/db2/db2.keywords.js +446 -0
- package/dist/esm/languages/db2/db2.keywords.js.map +1 -0
- package/dist/esm/languages/db2i/db2i.formatter.d.ts +2 -0
- package/dist/esm/languages/db2i/db2i.formatter.js +178 -0
- package/dist/esm/languages/db2i/db2i.formatter.js.map +1 -0
- package/dist/esm/languages/db2i/db2i.functions.d.ts +1 -0
- package/dist/esm/languages/db2i/db2i.functions.js +336 -0
- package/dist/esm/languages/db2i/db2i.functions.js.map +1 -0
- package/dist/esm/languages/db2i/db2i.keywords.d.ts +2 -0
- package/dist/esm/languages/db2i/db2i.keywords.js +535 -0
- package/dist/esm/languages/db2i/db2i.keywords.js.map +1 -0
- package/dist/esm/languages/duckdb/duckdb.formatter.d.ts +2 -0
- package/dist/esm/languages/duckdb/duckdb.formatter.js +210 -0
- package/dist/esm/languages/duckdb/duckdb.formatter.js.map +1 -0
- package/dist/esm/languages/duckdb/duckdb.functions.d.ts +1 -0
- package/dist/esm/languages/duckdb/duckdb.functions.js +665 -0
- package/dist/esm/languages/duckdb/duckdb.functions.js.map +1 -0
- package/dist/esm/languages/duckdb/duckdb.keywords.d.ts +2 -0
- package/dist/esm/languages/duckdb/duckdb.keywords.js +165 -0
- package/dist/esm/languages/duckdb/duckdb.keywords.js.map +1 -0
- package/dist/esm/languages/hive/hive.formatter.d.ts +2 -0
- package/dist/esm/languages/hive/hive.formatter.js +103 -0
- package/dist/esm/languages/hive/hive.formatter.js.map +1 -0
- package/dist/esm/languages/hive/hive.functions.d.ts +1 -0
- package/dist/esm/languages/hive/hive.functions.js +210 -0
- package/dist/esm/languages/hive/hive.functions.js.map +1 -0
- package/dist/esm/languages/hive/hive.keywords.d.ts +2 -0
- package/dist/esm/languages/hive/hive.keywords.js +339 -0
- package/dist/esm/languages/hive/hive.keywords.js.map +1 -0
- package/dist/esm/languages/mariadb/likeMariaDb.d.ts +2 -0
- package/dist/esm/languages/mariadb/likeMariaDb.js +18 -0
- package/dist/esm/languages/mariadb/likeMariaDb.js.map +1 -0
- package/dist/esm/languages/mariadb/mariadb.formatter.d.ts +2 -0
- package/dist/esm/languages/mariadb/mariadb.formatter.js +314 -0
- package/dist/esm/languages/mariadb/mariadb.formatter.js.map +1 -0
- package/dist/esm/languages/mariadb/mariadb.functions.d.ts +1 -0
- package/dist/esm/languages/mariadb/mariadb.functions.js +240 -0
- package/dist/esm/languages/mariadb/mariadb.functions.js.map +1 -0
- package/dist/esm/languages/mariadb/mariadb.keywords.d.ts +2 -0
- package/dist/esm/languages/mariadb/mariadb.keywords.js +271 -0
- package/dist/esm/languages/mariadb/mariadb.keywords.js.map +1 -0
- package/dist/esm/languages/mysql/mysql.formatter.d.ts +2 -0
- package/dist/esm/languages/mysql/mysql.formatter.js +281 -0
- package/dist/esm/languages/mysql/mysql.formatter.js.map +1 -0
- package/dist/esm/languages/mysql/mysql.functions.d.ts +1 -0
- package/dist/esm/languages/mysql/mysql.functions.js +425 -0
- package/dist/esm/languages/mysql/mysql.functions.js.map +1 -0
- package/dist/esm/languages/mysql/mysql.keywords.d.ts +2 -0
- package/dist/esm/languages/mysql/mysql.keywords.js +285 -0
- package/dist/esm/languages/mysql/mysql.keywords.js.map +1 -0
- package/dist/esm/languages/n1ql/n1ql.formatter.d.ts +2 -0
- package/dist/esm/languages/n1ql/n1ql.formatter.js +106 -0
- package/dist/esm/languages/n1ql/n1ql.formatter.js.map +1 -0
- package/dist/esm/languages/n1ql/n1ql.functions.d.ts +1 -0
- package/dist/esm/languages/n1ql/n1ql.functions.js +232 -0
- package/dist/esm/languages/n1ql/n1ql.functions.js.map +1 -0
- package/dist/esm/languages/n1ql/n1ql.keywords.d.ts +2 -0
- package/dist/esm/languages/n1ql/n1ql.keywords.js +218 -0
- package/dist/esm/languages/n1ql/n1ql.keywords.js.map +1 -0
- package/dist/esm/languages/plsql/plsql.formatter.d.ts +2 -0
- package/dist/esm/languages/plsql/plsql.formatter.js +137 -0
- package/dist/esm/languages/plsql/plsql.formatter.js.map +1 -0
- package/dist/esm/languages/plsql/plsql.functions.d.ts +1 -0
- package/dist/esm/languages/plsql/plsql.functions.js +267 -0
- package/dist/esm/languages/plsql/plsql.functions.js.map +1 -0
- package/dist/esm/languages/plsql/plsql.keywords.d.ts +2 -0
- package/dist/esm/languages/plsql/plsql.keywords.js +346 -0
- package/dist/esm/languages/plsql/plsql.keywords.js.map +1 -0
- package/dist/esm/languages/postgresql/postgresql.formatter.d.ts +2 -0
- package/dist/esm/languages/postgresql/postgresql.formatter.js +388 -0
- package/dist/esm/languages/postgresql/postgresql.formatter.js.map +1 -0
- package/dist/esm/languages/postgresql/postgresql.functions.d.ts +1 -0
- package/dist/esm/languages/postgresql/postgresql.functions.js +690 -0
- package/dist/esm/languages/postgresql/postgresql.functions.js.map +1 -0
- package/dist/esm/languages/postgresql/postgresql.keywords.d.ts +2 -0
- package/dist/esm/languages/postgresql/postgresql.keywords.js +155 -0
- package/dist/esm/languages/postgresql/postgresql.keywords.js.map +1 -0
- package/dist/esm/languages/redshift/redshift.formatter.d.ts +2 -0
- package/dist/esm/languages/redshift/redshift.formatter.js +177 -0
- package/dist/esm/languages/redshift/redshift.formatter.js.map +1 -0
- package/dist/esm/languages/redshift/redshift.functions.d.ts +1 -0
- package/dist/esm/languages/redshift/redshift.functions.js +348 -0
- package/dist/esm/languages/redshift/redshift.functions.js.map +1 -0
- package/dist/esm/languages/redshift/redshift.keywords.d.ts +2 -0
- package/dist/esm/languages/redshift/redshift.keywords.js +213 -0
- package/dist/esm/languages/redshift/redshift.keywords.js.map +1 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.formatter.d.ts +2 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.formatter.js +283 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.formatter.js.map +1 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.functions.d.ts +1 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.functions.js +282 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.functions.js.map +1 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.keywords.d.ts +2 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.keywords.js +265 -0
- package/dist/esm/languages/singlestoredb/singlestoredb.keywords.js.map +1 -0
- package/dist/esm/languages/snowflake/snowflake.formatter.d.ts +2 -0
- package/dist/esm/languages/snowflake/snowflake.formatter.js +336 -0
- package/dist/esm/languages/snowflake/snowflake.formatter.js.map +1 -0
- package/dist/esm/languages/snowflake/snowflake.functions.d.ts +1 -0
- package/dist/esm/languages/snowflake/snowflake.functions.js +610 -0
- package/dist/esm/languages/snowflake/snowflake.functions.js.map +1 -0
- package/dist/esm/languages/snowflake/snowflake.keywords.d.ts +2 -0
- package/dist/esm/languages/snowflake/snowflake.keywords.js +137 -0
- package/dist/esm/languages/snowflake/snowflake.keywords.js.map +1 -0
- package/dist/esm/languages/spark/spark.formatter.d.ts +2 -0
- package/dist/esm/languages/spark/spark.formatter.js +164 -0
- package/dist/esm/languages/spark/spark.formatter.js.map +1 -0
- package/dist/esm/languages/spark/spark.functions.d.ts +1 -0
- package/dist/esm/languages/spark/spark.functions.js +323 -0
- package/dist/esm/languages/spark/spark.functions.js.map +1 -0
- package/dist/esm/languages/spark/spark.keywords.d.ts +2 -0
- package/dist/esm/languages/spark/spark.keywords.js +299 -0
- package/dist/esm/languages/spark/spark.keywords.js.map +1 -0
- package/dist/esm/languages/sql/sql.formatter.d.ts +2 -0
- package/dist/esm/languages/sql/sql.formatter.js +94 -0
- package/dist/esm/languages/sql/sql.formatter.js.map +1 -0
- package/dist/esm/languages/sql/sql.functions.d.ts +1 -0
- package/dist/esm/languages/sql/sql.functions.js +99 -0
- package/dist/esm/languages/sql/sql.functions.js.map +1 -0
- package/dist/esm/languages/sql/sql.keywords.d.ts +2 -0
- package/dist/esm/languages/sql/sql.keywords.js +241 -0
- package/dist/esm/languages/sql/sql.keywords.js.map +1 -0
- package/dist/esm/languages/sqlite/sqlite.formatter.d.ts +2 -0
- package/dist/esm/languages/sqlite/sqlite.formatter.js +91 -0
- package/dist/esm/languages/sqlite/sqlite.formatter.js.map +1 -0
- package/dist/esm/languages/sqlite/sqlite.functions.d.ts +1 -0
- package/dist/esm/languages/sqlite/sqlite.functions.js +126 -0
- package/dist/esm/languages/sqlite/sqlite.functions.js.map +1 -0
- package/dist/esm/languages/sqlite/sqlite.keywords.d.ts +2 -0
- package/dist/esm/languages/sqlite/sqlite.keywords.js +177 -0
- package/dist/esm/languages/sqlite/sqlite.keywords.js.map +1 -0
- package/dist/esm/languages/tidb/tidb.formatter.d.ts +2 -0
- package/dist/esm/languages/tidb/tidb.formatter.js +215 -0
- package/dist/esm/languages/tidb/tidb.formatter.js.map +1 -0
- package/dist/esm/languages/tidb/tidb.functions.d.ts +1 -0
- package/dist/esm/languages/tidb/tidb.functions.js +328 -0
- package/dist/esm/languages/tidb/tidb.functions.js.map +1 -0
- package/dist/esm/languages/tidb/tidb.keywords.d.ts +2 -0
- package/dist/esm/languages/tidb/tidb.keywords.js +241 -0
- package/dist/esm/languages/tidb/tidb.keywords.js.map +1 -0
- package/dist/esm/languages/transactsql/transactsql.formatter.d.ts +2 -0
- package/dist/esm/languages/transactsql/transactsql.formatter.js +272 -0
- package/dist/esm/languages/transactsql/transactsql.formatter.js.map +1 -0
- package/dist/esm/languages/transactsql/transactsql.functions.d.ts +1 -0
- package/dist/esm/languages/transactsql/transactsql.functions.js +307 -0
- package/dist/esm/languages/transactsql/transactsql.functions.js.map +1 -0
- package/dist/esm/languages/transactsql/transactsql.keywords.d.ts +2 -0
- package/dist/esm/languages/transactsql/transactsql.keywords.js +211 -0
- package/dist/esm/languages/transactsql/transactsql.keywords.js.map +1 -0
- package/dist/esm/languages/trino/trino.formatter.d.ts +2 -0
- package/dist/esm/languages/trino/trino.formatter.js +160 -0
- package/dist/esm/languages/trino/trino.formatter.js.map +1 -0
- package/dist/esm/languages/trino/trino.functions.d.ts +1 -0
- package/dist/esm/languages/trino/trino.functions.js +436 -0
- package/dist/esm/languages/trino/trino.functions.js.map +1 -0
- package/dist/esm/languages/trino/trino.keywords.d.ts +2 -0
- package/dist/esm/languages/trino/trino.keywords.js +279 -0
- package/dist/esm/languages/trino/trino.keywords.js.map +1 -0
- package/dist/esm/lexer/NestedComment.d.ts +10 -0
- package/dist/esm/lexer/NestedComment.js +50 -0
- package/dist/esm/lexer/NestedComment.js.map +1 -0
- package/dist/esm/lexer/Tokenizer.d.ts +14 -0
- package/dist/esm/lexer/Tokenizer.js +264 -0
- package/dist/esm/lexer/Tokenizer.js.map +1 -0
- package/dist/esm/lexer/TokenizerEngine.d.ts +31 -0
- package/dist/esm/lexer/TokenizerEngine.js +92 -0
- package/dist/esm/lexer/TokenizerEngine.js.map +1 -0
- package/dist/esm/lexer/TokenizerOptions.d.ts +56 -0
- package/dist/esm/lexer/TokenizerOptions.js +2 -0
- package/dist/esm/lexer/TokenizerOptions.js.map +1 -0
- package/dist/esm/lexer/disambiguateTokens.d.ts +18 -0
- package/dist/esm/lexer/disambiguateTokens.js +86 -0
- package/dist/esm/lexer/disambiguateTokens.js.map +1 -0
- package/dist/esm/lexer/lineColFromIndex.d.ts +8 -0
- package/dist/esm/lexer/lineColFromIndex.js +8 -0
- package/dist/esm/lexer/lineColFromIndex.js.map +1 -0
- package/dist/esm/lexer/regexFactory.d.ts +55 -0
- package/dist/esm/lexer/regexFactory.js +140 -0
- package/dist/esm/lexer/regexFactory.js.map +1 -0
- package/dist/esm/lexer/regexUtil.d.ts +7 -0
- package/dist/esm/lexer/regexUtil.js +13 -0
- package/dist/esm/lexer/regexUtil.js.map +1 -0
- package/dist/esm/lexer/token.d.ts +89 -0
- package/dist/esm/lexer/token.js +94 -0
- package/dist/esm/lexer/token.js.map +1 -0
- package/dist/esm/parser/LexerAdapter.d.ts +17 -0
- package/dist/esm/parser/LexerAdapter.js +27 -0
- package/dist/esm/parser/LexerAdapter.js.map +1 -0
- package/dist/esm/parser/ast.d.ts +158 -0
- package/dist/esm/parser/ast.js +28 -0
- package/dist/esm/parser/ast.js.map +1 -0
- package/dist/esm/parser/createParser.d.ts +10 -0
- package/dist/esm/parser/createParser.js +36 -0
- package/dist/esm/parser/createParser.js.map +1 -0
- package/dist/esm/parser/grammar.d.ts +28 -0
- package/dist/esm/parser/grammar.js +366 -0
- package/dist/esm/parser/grammar.js.map +1 -0
- package/dist/esm/sqlFormatter.d.ts +31 -0
- package/dist/esm/sqlFormatter.js +86 -0
- package/dist/esm/sqlFormatter.js.map +1 -0
- package/dist/esm/utils.d.ts +8 -0
- package/dist/esm/utils.js +13 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/esm/validateConfig.d.ts +4 -0
- package/dist/esm/validateConfig.js +38 -0
- package/dist/esm/validateConfig.js.map +1 -0
- package/dist/sql-formatter.min.cjs +2 -0
- package/dist/sql-formatter.min.cjs.map +1 -0
- package/dist/sql-formatter.min.js +2 -0
- package/package.json +135 -0
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
/** Token type enum for all possible Token categories */
|
|
2
|
+
export declare enum TokenType {
|
|
3
|
+
QUOTED_IDENTIFIER = "QUOTED_IDENTIFIER",
|
|
4
|
+
IDENTIFIER = "IDENTIFIER",
|
|
5
|
+
STRING = "STRING",
|
|
6
|
+
VARIABLE = "VARIABLE",
|
|
7
|
+
RESERVED_DATA_TYPE = "RESERVED_DATA_TYPE",
|
|
8
|
+
RESERVED_PARAMETERIZED_DATA_TYPE = "RESERVED_PARAMETERIZED_DATA_TYPE",
|
|
9
|
+
RESERVED_KEYWORD = "RESERVED_KEYWORD",
|
|
10
|
+
RESERVED_FUNCTION_NAME = "RESERVED_FUNCTION_NAME",
|
|
11
|
+
RESERVED_KEYWORD_PHRASE = "RESERVED_KEYWORD_PHRASE",
|
|
12
|
+
RESERVED_DATA_TYPE_PHRASE = "RESERVED_DATA_TYPE_PHRASE",
|
|
13
|
+
RESERVED_SET_OPERATION = "RESERVED_SET_OPERATION",
|
|
14
|
+
RESERVED_CLAUSE = "RESERVED_CLAUSE",
|
|
15
|
+
RESERVED_SELECT = "RESERVED_SELECT",
|
|
16
|
+
RESERVED_JOIN = "RESERVED_JOIN",
|
|
17
|
+
ARRAY_IDENTIFIER = "ARRAY_IDENTIFIER",
|
|
18
|
+
ARRAY_KEYWORD = "ARRAY_KEYWORD",
|
|
19
|
+
CASE = "CASE",
|
|
20
|
+
END = "END",
|
|
21
|
+
WHEN = "WHEN",
|
|
22
|
+
ELSE = "ELSE",
|
|
23
|
+
THEN = "THEN",
|
|
24
|
+
LIMIT = "LIMIT",
|
|
25
|
+
BETWEEN = "BETWEEN",
|
|
26
|
+
AND = "AND",
|
|
27
|
+
OR = "OR",
|
|
28
|
+
XOR = "XOR",
|
|
29
|
+
OPERATOR = "OPERATOR",
|
|
30
|
+
COMMA = "COMMA",
|
|
31
|
+
ASTERISK = "ASTERISK",
|
|
32
|
+
PROPERTY_ACCESS_OPERATOR = "PROPERTY_ACCESS_OPERATOR",
|
|
33
|
+
OPEN_PAREN = "OPEN_PAREN",
|
|
34
|
+
CLOSE_PAREN = "CLOSE_PAREN",
|
|
35
|
+
LINE_COMMENT = "LINE_COMMENT",
|
|
36
|
+
BLOCK_COMMENT = "BLOCK_COMMENT",
|
|
37
|
+
DISABLE_COMMENT = "DISABLE_COMMENT",
|
|
38
|
+
NUMBER = "NUMBER",
|
|
39
|
+
NAMED_PARAMETER = "NAMED_PARAMETER",
|
|
40
|
+
QUOTED_PARAMETER = "QUOTED_PARAMETER",
|
|
41
|
+
NUMBERED_PARAMETER = "NUMBERED_PARAMETER",
|
|
42
|
+
POSITIONAL_PARAMETER = "POSITIONAL_PARAMETER",
|
|
43
|
+
CUSTOM_PARAMETER = "CUSTOM_PARAMETER",
|
|
44
|
+
DELIMITER = "DELIMITER",
|
|
45
|
+
EOF = "EOF"
|
|
46
|
+
}
|
|
47
|
+
/** Struct to store the most basic cohesive unit of language grammar */
|
|
48
|
+
export interface Token {
|
|
49
|
+
type: TokenType;
|
|
50
|
+
raw: string;
|
|
51
|
+
text: string;
|
|
52
|
+
key?: string;
|
|
53
|
+
start: number;
|
|
54
|
+
precedingWhitespace?: string;
|
|
55
|
+
}
|
|
56
|
+
/** Creates EOF token positioned at given location */
|
|
57
|
+
export declare const createEofToken: (index: number) => {
|
|
58
|
+
type: TokenType;
|
|
59
|
+
raw: string;
|
|
60
|
+
text: string;
|
|
61
|
+
start: number;
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* For use as a "missing token"
|
|
65
|
+
* e.g. in lookAhead and lookBehind to avoid dealing with null values
|
|
66
|
+
*/
|
|
67
|
+
export declare const EOF_TOKEN: {
|
|
68
|
+
type: TokenType;
|
|
69
|
+
raw: string;
|
|
70
|
+
text: string;
|
|
71
|
+
start: number;
|
|
72
|
+
};
|
|
73
|
+
/** Checks if two tokens are equivalent */
|
|
74
|
+
export declare const testToken: (compareToken: {
|
|
75
|
+
type: TokenType;
|
|
76
|
+
text: string;
|
|
77
|
+
}) => (token: Token) => boolean;
|
|
78
|
+
/** Util object that allows for easy checking of Reserved Keywords */
|
|
79
|
+
export declare const isToken: {
|
|
80
|
+
ARRAY: (token: Token) => boolean;
|
|
81
|
+
BY: (token: Token) => boolean;
|
|
82
|
+
SET: (token: Token) => boolean;
|
|
83
|
+
STRUCT: (token: Token) => boolean;
|
|
84
|
+
WINDOW: (token: Token) => boolean;
|
|
85
|
+
VALUES: (token: Token) => boolean;
|
|
86
|
+
};
|
|
87
|
+
/** Checks if token is any Reserved Keyword or Clause */
|
|
88
|
+
export declare const isReserved: (type: TokenType) => boolean;
|
|
89
|
+
export declare const isLogicalOperator: (type: TokenType) => boolean;
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isLogicalOperator = exports.isReserved = exports.isToken = exports.testToken = exports.EOF_TOKEN = exports.createEofToken = exports.TokenType = void 0;
|
|
4
|
+
/** Token type enum for all possible Token categories */
|
|
5
|
+
var TokenType;
|
|
6
|
+
(function (TokenType) {
|
|
7
|
+
TokenType["QUOTED_IDENTIFIER"] = "QUOTED_IDENTIFIER";
|
|
8
|
+
TokenType["IDENTIFIER"] = "IDENTIFIER";
|
|
9
|
+
TokenType["STRING"] = "STRING";
|
|
10
|
+
TokenType["VARIABLE"] = "VARIABLE";
|
|
11
|
+
TokenType["RESERVED_DATA_TYPE"] = "RESERVED_DATA_TYPE";
|
|
12
|
+
TokenType["RESERVED_PARAMETERIZED_DATA_TYPE"] = "RESERVED_PARAMETERIZED_DATA_TYPE";
|
|
13
|
+
TokenType["RESERVED_KEYWORD"] = "RESERVED_KEYWORD";
|
|
14
|
+
TokenType["RESERVED_FUNCTION_NAME"] = "RESERVED_FUNCTION_NAME";
|
|
15
|
+
TokenType["RESERVED_KEYWORD_PHRASE"] = "RESERVED_KEYWORD_PHRASE";
|
|
16
|
+
TokenType["RESERVED_DATA_TYPE_PHRASE"] = "RESERVED_DATA_TYPE_PHRASE";
|
|
17
|
+
TokenType["RESERVED_SET_OPERATION"] = "RESERVED_SET_OPERATION";
|
|
18
|
+
TokenType["RESERVED_CLAUSE"] = "RESERVED_CLAUSE";
|
|
19
|
+
TokenType["RESERVED_SELECT"] = "RESERVED_SELECT";
|
|
20
|
+
TokenType["RESERVED_JOIN"] = "RESERVED_JOIN";
|
|
21
|
+
TokenType["ARRAY_IDENTIFIER"] = "ARRAY_IDENTIFIER";
|
|
22
|
+
TokenType["ARRAY_KEYWORD"] = "ARRAY_KEYWORD";
|
|
23
|
+
TokenType["CASE"] = "CASE";
|
|
24
|
+
TokenType["END"] = "END";
|
|
25
|
+
TokenType["WHEN"] = "WHEN";
|
|
26
|
+
TokenType["ELSE"] = "ELSE";
|
|
27
|
+
TokenType["THEN"] = "THEN";
|
|
28
|
+
TokenType["LIMIT"] = "LIMIT";
|
|
29
|
+
TokenType["BETWEEN"] = "BETWEEN";
|
|
30
|
+
TokenType["AND"] = "AND";
|
|
31
|
+
TokenType["OR"] = "OR";
|
|
32
|
+
TokenType["XOR"] = "XOR";
|
|
33
|
+
TokenType["OPERATOR"] = "OPERATOR";
|
|
34
|
+
TokenType["COMMA"] = "COMMA";
|
|
35
|
+
TokenType["ASTERISK"] = "ASTERISK";
|
|
36
|
+
TokenType["PROPERTY_ACCESS_OPERATOR"] = "PROPERTY_ACCESS_OPERATOR";
|
|
37
|
+
TokenType["OPEN_PAREN"] = "OPEN_PAREN";
|
|
38
|
+
TokenType["CLOSE_PAREN"] = "CLOSE_PAREN";
|
|
39
|
+
TokenType["LINE_COMMENT"] = "LINE_COMMENT";
|
|
40
|
+
TokenType["BLOCK_COMMENT"] = "BLOCK_COMMENT";
|
|
41
|
+
// Text between /* sql-formatter-disable */ and /* sql-formatter-enable */
|
|
42
|
+
TokenType["DISABLE_COMMENT"] = "DISABLE_COMMENT";
|
|
43
|
+
TokenType["NUMBER"] = "NUMBER";
|
|
44
|
+
TokenType["NAMED_PARAMETER"] = "NAMED_PARAMETER";
|
|
45
|
+
TokenType["QUOTED_PARAMETER"] = "QUOTED_PARAMETER";
|
|
46
|
+
TokenType["NUMBERED_PARAMETER"] = "NUMBERED_PARAMETER";
|
|
47
|
+
TokenType["POSITIONAL_PARAMETER"] = "POSITIONAL_PARAMETER";
|
|
48
|
+
TokenType["CUSTOM_PARAMETER"] = "CUSTOM_PARAMETER";
|
|
49
|
+
TokenType["DELIMITER"] = "DELIMITER";
|
|
50
|
+
TokenType["EOF"] = "EOF";
|
|
51
|
+
})(TokenType = exports.TokenType || (exports.TokenType = {}));
|
|
52
|
+
/** Creates EOF token positioned at given location */
|
|
53
|
+
const createEofToken = (index) => ({
|
|
54
|
+
type: TokenType.EOF,
|
|
55
|
+
raw: '«EOF»',
|
|
56
|
+
text: '«EOF»',
|
|
57
|
+
start: index,
|
|
58
|
+
});
|
|
59
|
+
exports.createEofToken = createEofToken;
|
|
60
|
+
/**
|
|
61
|
+
* For use as a "missing token"
|
|
62
|
+
* e.g. in lookAhead and lookBehind to avoid dealing with null values
|
|
63
|
+
*/
|
|
64
|
+
exports.EOF_TOKEN = (0, exports.createEofToken)(Infinity);
|
|
65
|
+
/** Checks if two tokens are equivalent */
|
|
66
|
+
const testToken = (compareToken) => (token) => token.type === compareToken.type && token.text === compareToken.text;
|
|
67
|
+
exports.testToken = testToken;
|
|
68
|
+
/** Util object that allows for easy checking of Reserved Keywords */
|
|
69
|
+
exports.isToken = {
|
|
70
|
+
ARRAY: (0, exports.testToken)({ text: 'ARRAY', type: TokenType.RESERVED_DATA_TYPE }),
|
|
71
|
+
BY: (0, exports.testToken)({ text: 'BY', type: TokenType.RESERVED_KEYWORD }),
|
|
72
|
+
SET: (0, exports.testToken)({ text: 'SET', type: TokenType.RESERVED_CLAUSE }),
|
|
73
|
+
STRUCT: (0, exports.testToken)({ text: 'STRUCT', type: TokenType.RESERVED_DATA_TYPE }),
|
|
74
|
+
WINDOW: (0, exports.testToken)({ text: 'WINDOW', type: TokenType.RESERVED_CLAUSE }),
|
|
75
|
+
VALUES: (0, exports.testToken)({ text: 'VALUES', type: TokenType.RESERVED_CLAUSE }),
|
|
76
|
+
};
|
|
77
|
+
/** Checks if token is any Reserved Keyword or Clause */
|
|
78
|
+
const isReserved = (type) => type === TokenType.RESERVED_DATA_TYPE ||
|
|
79
|
+
type === TokenType.RESERVED_KEYWORD ||
|
|
80
|
+
type === TokenType.RESERVED_FUNCTION_NAME ||
|
|
81
|
+
type === TokenType.RESERVED_KEYWORD_PHRASE ||
|
|
82
|
+
type === TokenType.RESERVED_DATA_TYPE_PHRASE ||
|
|
83
|
+
type === TokenType.RESERVED_CLAUSE ||
|
|
84
|
+
type === TokenType.RESERVED_SELECT ||
|
|
85
|
+
type === TokenType.RESERVED_SET_OPERATION ||
|
|
86
|
+
type === TokenType.RESERVED_JOIN ||
|
|
87
|
+
type === TokenType.ARRAY_KEYWORD ||
|
|
88
|
+
type === TokenType.CASE ||
|
|
89
|
+
type === TokenType.END ||
|
|
90
|
+
type === TokenType.WHEN ||
|
|
91
|
+
type === TokenType.ELSE ||
|
|
92
|
+
type === TokenType.THEN ||
|
|
93
|
+
type === TokenType.LIMIT ||
|
|
94
|
+
type === TokenType.BETWEEN ||
|
|
95
|
+
type === TokenType.AND ||
|
|
96
|
+
type === TokenType.OR ||
|
|
97
|
+
type === TokenType.XOR;
|
|
98
|
+
exports.isReserved = isReserved;
|
|
99
|
+
const isLogicalOperator = (type) => type === TokenType.AND || type === TokenType.OR || type === TokenType.XOR;
|
|
100
|
+
exports.isLogicalOperator = isLogicalOperator;
|
|
101
|
+
//# sourceMappingURL=token.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.js","sourceRoot":"","sources":["../../../src/lexer/token.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
'{"type": "commonjs"}'
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Token } from '../lexer/token.js';
|
|
2
|
+
type NearleyToken = Token & {
|
|
3
|
+
value: string;
|
|
4
|
+
};
|
|
5
|
+
export default class LexerAdapter {
|
|
6
|
+
private tokenize;
|
|
7
|
+
private index;
|
|
8
|
+
private tokens;
|
|
9
|
+
private input;
|
|
10
|
+
constructor(tokenize: (chunk: string) => Token[]);
|
|
11
|
+
reset(chunk: string, _info: any): void;
|
|
12
|
+
next(): NearleyToken | undefined;
|
|
13
|
+
save(): any;
|
|
14
|
+
formatError(token: NearleyToken): string;
|
|
15
|
+
has(name: string): boolean;
|
|
16
|
+
}
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const lineColFromIndex_js_1 = require("../lexer/lineColFromIndex.js");
|
|
4
|
+
const token_js_1 = require("../lexer/token.js");
|
|
5
|
+
class LexerAdapter {
|
|
6
|
+
constructor(tokenize) {
|
|
7
|
+
this.tokenize = tokenize;
|
|
8
|
+
this.index = 0;
|
|
9
|
+
this.tokens = [];
|
|
10
|
+
this.input = '';
|
|
11
|
+
}
|
|
12
|
+
reset(chunk, _info) {
|
|
13
|
+
this.input = chunk;
|
|
14
|
+
this.index = 0;
|
|
15
|
+
this.tokens = this.tokenize(chunk);
|
|
16
|
+
}
|
|
17
|
+
next() {
|
|
18
|
+
return this.tokens[this.index++];
|
|
19
|
+
}
|
|
20
|
+
save() { }
|
|
21
|
+
formatError(token) {
|
|
22
|
+
const { line, col } = (0, lineColFromIndex_js_1.lineColFromIndex)(this.input, token.start);
|
|
23
|
+
return `Parse error at token: ${token.text} at line ${line} column ${col}`;
|
|
24
|
+
}
|
|
25
|
+
has(name) {
|
|
26
|
+
return name in token_js_1.TokenType;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
exports.default = LexerAdapter;
|
|
30
|
+
//# sourceMappingURL=LexerAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LexerAdapter.js","sourceRoot":"","sources":["../../../src/parser/LexerAdapter.ts"],"names":[],"mappings":";;AAAA,sEAAgE;AAChE,gDAAqD;AAMrD,MAAqB,YAAY;IAK/B,YAAoB,QAAoC;QAApC,aAAQ,GAAR,QAAQ,CAA4B;QAJhD,UAAK,GAAG,CAAC,CAAC;QACV,WAAM,GAAY,EAAE,CAAC;QACrB,UAAK,GAAG,EAAE,CAAC;IAEwC,CAAC;IAE5D,KAAK,CAAC,KAAa,EAAE,KAAU;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED,IAAI;QACF,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAA6B,CAAC;IAC/D,CAAC;IAED,IAAI,KAAS,CAAC;IAEd,WAAW,CAAC,KAAmB;QAC7B,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,IAAA,sCAAgB,EAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QAChE,OAAO,yBAAyB,KAAK,CAAC,IAAI,YAAY,IAAI,WAAW,GAAG,EAAE,CAAC;IAC7E,CAAC;IAED,GAAG,CAAC,IAAY;QACd,OAAO,IAAI,IAAI,oBAAS,CAAC;IAC3B,CAAC;CACF;AA3BD,+BA2BC"}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { TokenType } from '../lexer/token.js';
|
|
2
|
+
export declare enum NodeType {
|
|
3
|
+
statement = "statement",
|
|
4
|
+
clause = "clause",
|
|
5
|
+
set_operation = "set_operation",
|
|
6
|
+
function_call = "function_call",
|
|
7
|
+
parameterized_data_type = "parameterized_data_type",
|
|
8
|
+
array_subscript = "array_subscript",
|
|
9
|
+
property_access = "property_access",
|
|
10
|
+
parenthesis = "parenthesis",
|
|
11
|
+
between_predicate = "between_predicate",
|
|
12
|
+
case_expression = "case_expression",
|
|
13
|
+
case_when = "case_when",
|
|
14
|
+
case_else = "case_else",
|
|
15
|
+
limit_clause = "limit_clause",
|
|
16
|
+
all_columns_asterisk = "all_columns_asterisk",
|
|
17
|
+
literal = "literal",
|
|
18
|
+
identifier = "identifier",
|
|
19
|
+
keyword = "keyword",
|
|
20
|
+
data_type = "data_type",
|
|
21
|
+
parameter = "parameter",
|
|
22
|
+
operator = "operator",
|
|
23
|
+
comma = "comma",
|
|
24
|
+
line_comment = "line_comment",
|
|
25
|
+
block_comment = "block_comment",
|
|
26
|
+
disable_comment = "disable_comment"
|
|
27
|
+
}
|
|
28
|
+
interface BaseNode {
|
|
29
|
+
leadingComments?: CommentNode[];
|
|
30
|
+
trailingComments?: CommentNode[];
|
|
31
|
+
}
|
|
32
|
+
export interface StatementNode extends BaseNode {
|
|
33
|
+
type: NodeType.statement;
|
|
34
|
+
children: AstNode[];
|
|
35
|
+
hasSemicolon: boolean;
|
|
36
|
+
}
|
|
37
|
+
export interface ClauseNode extends BaseNode {
|
|
38
|
+
type: NodeType.clause;
|
|
39
|
+
nameKw: KeywordNode;
|
|
40
|
+
children: AstNode[];
|
|
41
|
+
}
|
|
42
|
+
export interface SetOperationNode extends BaseNode {
|
|
43
|
+
type: NodeType.set_operation;
|
|
44
|
+
nameKw: KeywordNode;
|
|
45
|
+
children: AstNode[];
|
|
46
|
+
}
|
|
47
|
+
export interface FunctionCallNode extends BaseNode {
|
|
48
|
+
type: NodeType.function_call;
|
|
49
|
+
nameKw: KeywordNode;
|
|
50
|
+
parenthesis: ParenthesisNode;
|
|
51
|
+
}
|
|
52
|
+
export interface ParameterizedDataTypeNode extends BaseNode {
|
|
53
|
+
type: NodeType.parameterized_data_type;
|
|
54
|
+
dataType: DataTypeNode;
|
|
55
|
+
parenthesis: ParenthesisNode;
|
|
56
|
+
}
|
|
57
|
+
export interface ArraySubscriptNode extends BaseNode {
|
|
58
|
+
type: NodeType.array_subscript;
|
|
59
|
+
array: IdentifierNode | KeywordNode | DataTypeNode;
|
|
60
|
+
parenthesis: ParenthesisNode;
|
|
61
|
+
}
|
|
62
|
+
export interface ParenthesisNode extends BaseNode {
|
|
63
|
+
type: NodeType.parenthesis;
|
|
64
|
+
children: AstNode[];
|
|
65
|
+
openParen: string;
|
|
66
|
+
closeParen: string;
|
|
67
|
+
}
|
|
68
|
+
export interface BetweenPredicateNode extends BaseNode {
|
|
69
|
+
type: NodeType.between_predicate;
|
|
70
|
+
betweenKw: KeywordNode;
|
|
71
|
+
expr1: AstNode[];
|
|
72
|
+
andKw: KeywordNode;
|
|
73
|
+
expr2: AstNode[];
|
|
74
|
+
}
|
|
75
|
+
export interface CaseExpressionNode extends BaseNode {
|
|
76
|
+
type: NodeType.case_expression;
|
|
77
|
+
caseKw: KeywordNode;
|
|
78
|
+
endKw: KeywordNode;
|
|
79
|
+
expr: AstNode[];
|
|
80
|
+
clauses: (CaseWhenNode | CaseElseNode)[];
|
|
81
|
+
}
|
|
82
|
+
export interface CaseWhenNode extends BaseNode {
|
|
83
|
+
type: NodeType.case_when;
|
|
84
|
+
whenKw: KeywordNode;
|
|
85
|
+
thenKw: KeywordNode;
|
|
86
|
+
condition: AstNode[];
|
|
87
|
+
result: AstNode[];
|
|
88
|
+
}
|
|
89
|
+
export interface CaseElseNode extends BaseNode {
|
|
90
|
+
type: NodeType.case_else;
|
|
91
|
+
elseKw: KeywordNode;
|
|
92
|
+
result: AstNode[];
|
|
93
|
+
}
|
|
94
|
+
export interface LimitClauseNode extends BaseNode {
|
|
95
|
+
type: NodeType.limit_clause;
|
|
96
|
+
limitKw: KeywordNode;
|
|
97
|
+
count: AstNode[];
|
|
98
|
+
offset?: AstNode[];
|
|
99
|
+
}
|
|
100
|
+
export interface AllColumnsAsteriskNode extends BaseNode {
|
|
101
|
+
type: NodeType.all_columns_asterisk;
|
|
102
|
+
}
|
|
103
|
+
export interface LiteralNode extends BaseNode {
|
|
104
|
+
type: NodeType.literal;
|
|
105
|
+
text: string;
|
|
106
|
+
}
|
|
107
|
+
export interface PropertyAccessNode extends BaseNode {
|
|
108
|
+
type: NodeType.property_access;
|
|
109
|
+
object: AstNode;
|
|
110
|
+
operator: string;
|
|
111
|
+
property: IdentifierNode | ArraySubscriptNode | AllColumnsAsteriskNode;
|
|
112
|
+
}
|
|
113
|
+
export interface IdentifierNode extends BaseNode {
|
|
114
|
+
type: NodeType.identifier;
|
|
115
|
+
quoted: boolean;
|
|
116
|
+
text: string;
|
|
117
|
+
}
|
|
118
|
+
export interface DataTypeNode extends BaseNode {
|
|
119
|
+
type: NodeType.data_type;
|
|
120
|
+
text: string;
|
|
121
|
+
raw: string;
|
|
122
|
+
}
|
|
123
|
+
export interface KeywordNode extends BaseNode {
|
|
124
|
+
type: NodeType.keyword;
|
|
125
|
+
tokenType: TokenType;
|
|
126
|
+
text: string;
|
|
127
|
+
raw: string;
|
|
128
|
+
}
|
|
129
|
+
export interface ParameterNode extends BaseNode {
|
|
130
|
+
type: NodeType.parameter;
|
|
131
|
+
key?: string;
|
|
132
|
+
text: string;
|
|
133
|
+
}
|
|
134
|
+
export interface OperatorNode extends BaseNode {
|
|
135
|
+
type: NodeType.operator;
|
|
136
|
+
text: string;
|
|
137
|
+
}
|
|
138
|
+
export interface CommaNode extends BaseNode {
|
|
139
|
+
type: NodeType.comma;
|
|
140
|
+
}
|
|
141
|
+
export interface LineCommentNode extends BaseNode {
|
|
142
|
+
type: NodeType.line_comment;
|
|
143
|
+
text: string;
|
|
144
|
+
precedingWhitespace: string;
|
|
145
|
+
}
|
|
146
|
+
export interface BlockCommentNode extends BaseNode {
|
|
147
|
+
type: NodeType.block_comment;
|
|
148
|
+
text: string;
|
|
149
|
+
precedingWhitespace: string;
|
|
150
|
+
}
|
|
151
|
+
export interface DisableCommentNode extends BaseNode {
|
|
152
|
+
type: NodeType.disable_comment;
|
|
153
|
+
text: string;
|
|
154
|
+
precedingWhitespace: string;
|
|
155
|
+
}
|
|
156
|
+
export type CommentNode = LineCommentNode | BlockCommentNode | DisableCommentNode;
|
|
157
|
+
export type AstNode = ClauseNode | SetOperationNode | FunctionCallNode | ParameterizedDataTypeNode | ArraySubscriptNode | PropertyAccessNode | ParenthesisNode | BetweenPredicateNode | CaseExpressionNode | CaseWhenNode | CaseElseNode | LimitClauseNode | AllColumnsAsteriskNode | LiteralNode | IdentifierNode | DataTypeNode | KeywordNode | ParameterNode | OperatorNode | CommaNode | LineCommentNode | BlockCommentNode | DisableCommentNode;
|
|
158
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NodeType = void 0;
|
|
4
|
+
var NodeType;
|
|
5
|
+
(function (NodeType) {
|
|
6
|
+
NodeType["statement"] = "statement";
|
|
7
|
+
NodeType["clause"] = "clause";
|
|
8
|
+
NodeType["set_operation"] = "set_operation";
|
|
9
|
+
NodeType["function_call"] = "function_call";
|
|
10
|
+
NodeType["parameterized_data_type"] = "parameterized_data_type";
|
|
11
|
+
NodeType["array_subscript"] = "array_subscript";
|
|
12
|
+
NodeType["property_access"] = "property_access";
|
|
13
|
+
NodeType["parenthesis"] = "parenthesis";
|
|
14
|
+
NodeType["between_predicate"] = "between_predicate";
|
|
15
|
+
NodeType["case_expression"] = "case_expression";
|
|
16
|
+
NodeType["case_when"] = "case_when";
|
|
17
|
+
NodeType["case_else"] = "case_else";
|
|
18
|
+
NodeType["limit_clause"] = "limit_clause";
|
|
19
|
+
NodeType["all_columns_asterisk"] = "all_columns_asterisk";
|
|
20
|
+
NodeType["literal"] = "literal";
|
|
21
|
+
NodeType["identifier"] = "identifier";
|
|
22
|
+
NodeType["keyword"] = "keyword";
|
|
23
|
+
NodeType["data_type"] = "data_type";
|
|
24
|
+
NodeType["parameter"] = "parameter";
|
|
25
|
+
NodeType["operator"] = "operator";
|
|
26
|
+
NodeType["comma"] = "comma";
|
|
27
|
+
NodeType["line_comment"] = "line_comment";
|
|
28
|
+
NodeType["block_comment"] = "block_comment";
|
|
29
|
+
NodeType["disable_comment"] = "disable_comment";
|
|
30
|
+
})(NodeType = exports.NodeType || (exports.NodeType = {}));
|
|
31
|
+
//# sourceMappingURL=ast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ast.js","sourceRoot":"","sources":["../../../src/parser/ast.ts"],"names":[],"mappings":";;;AAEA,IAAY,QAyBX;AAzBD,WAAY,QAAQ;IAClB,mCAAuB,CAAA;IACvB,6BAAiB,CAAA;IACjB,2CAA+B,CAAA;IAC/B,2CAA+B,CAAA;IAC/B,+DAAmD,CAAA;IACnD,+CAAmC,CAAA;IACnC,+CAAmC,CAAA;IACnC,uCAA2B,CAAA;IAC3B,mDAAuC,CAAA;IACvC,+CAAmC,CAAA;IACnC,mCAAuB,CAAA;IACvB,mCAAuB,CAAA;IACvB,yCAA6B,CAAA;IAC7B,yDAA6C,CAAA;IAC7C,+BAAmB,CAAA;IACnB,qCAAyB,CAAA;IACzB,+BAAmB,CAAA;IACnB,mCAAuB,CAAA;IACvB,mCAAuB,CAAA;IACvB,iCAAqB,CAAA;IACrB,2BAAe,CAAA;IACf,yCAA6B,CAAA;IAC7B,2CAA+B,CAAA;IAC/B,+CAAmC,CAAA;AACrC,CAAC,EAzBW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAyBnB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import Tokenizer from '../lexer/Tokenizer.js';
|
|
2
|
+
import { ParamTypes } from '../lexer/TokenizerOptions.js';
|
|
3
|
+
import { StatementNode } from './ast.js';
|
|
4
|
+
export interface Parser {
|
|
5
|
+
parse(sql: string, paramTypesOverrides: ParamTypes): StatementNode[];
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Creates a parser object which wraps the setup of Nearley parser
|
|
9
|
+
*/
|
|
10
|
+
export declare function createParser(tokenizer: Tokenizer): Parser;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createParser = void 0;
|
|
7
|
+
const nearley_1 = __importDefault(require("nearley"));
|
|
8
|
+
const disambiguateTokens_js_1 = require("../lexer/disambiguateTokens.js");
|
|
9
|
+
const grammar_js_1 = __importDefault(require("./grammar.js"));
|
|
10
|
+
const LexerAdapter_js_1 = __importDefault(require("./LexerAdapter.js"));
|
|
11
|
+
const token_js_1 = require("../lexer/token.js");
|
|
12
|
+
const { Parser: NearleyParser, Grammar } = nearley_1.default;
|
|
13
|
+
/**
|
|
14
|
+
* Creates a parser object which wraps the setup of Nearley parser
|
|
15
|
+
*/
|
|
16
|
+
function createParser(tokenizer) {
|
|
17
|
+
let paramTypesOverrides = {};
|
|
18
|
+
const lexer = new LexerAdapter_js_1.default(chunk => [
|
|
19
|
+
...(0, disambiguateTokens_js_1.disambiguateTokens)(tokenizer.tokenize(chunk, paramTypesOverrides)),
|
|
20
|
+
(0, token_js_1.createEofToken)(chunk.length),
|
|
21
|
+
]);
|
|
22
|
+
const parser = new NearleyParser(Grammar.fromCompiled(grammar_js_1.default), { lexer });
|
|
23
|
+
return {
|
|
24
|
+
parse: (sql, paramTypes) => {
|
|
25
|
+
// share paramTypesOverrides with Tokenizer
|
|
26
|
+
paramTypesOverrides = paramTypes;
|
|
27
|
+
const { results } = parser.feed(sql);
|
|
28
|
+
if (results.length === 1) {
|
|
29
|
+
return results[0];
|
|
30
|
+
}
|
|
31
|
+
else if (results.length === 0) {
|
|
32
|
+
// Ideally we would report a line number where the parser failed,
|
|
33
|
+
// but I haven't found a way to get this info from Nearley :(
|
|
34
|
+
throw new Error('Parse error: Invalid SQL');
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
throw new Error(`Parse error: Ambiguous grammar\n${JSON.stringify(results, undefined, 2)}`);
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
exports.createParser = createParser;
|
|
43
|
+
//# sourceMappingURL=createParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createParser.js","sourceRoot":"","sources":["../../../src/parser/createParser.ts"],"names":[],"mappings":";;;;;;AAAA,sDAA8B;AAG9B,0EAAoE;AAGpE,8DAAmC;AACnC,wEAA6C;AAC7C,gDAAmD;AAEnD,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,iBAAO,CAAC;AAMnD;;GAEG;AACH,SAAgB,YAAY,CAAC,SAAoB;IAC/C,IAAI,mBAAmB,GAAe,EAAE,CAAC;IACzC,MAAM,KAAK,GAAG,IAAI,yBAAY,CAAC,KAAK,CAAC,EAAE,CAAC;QACtC,GAAG,IAAA,0CAAkB,EAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAC;QACrE,IAAA,yBAAc,EAAC,KAAK,CAAC,MAAM,CAAC;KAC7B,CAAC,CAAC;IACH,MAAM,MAAM,GAAG,IAAI,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,oBAAO,CAAC,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAE3E,OAAO;QACL,KAAK,EAAE,CAAC,GAAW,EAAE,UAAsB,EAAE,EAAE;YAC7C,2CAA2C;YAC3C,mBAAmB,GAAG,UAAU,CAAC;YAEjC,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAErC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;gBACxB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;aACnB;iBAAM,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC/B,iEAAiE;gBACjE,6DAA6D;gBAC7D,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;aAC7C;iBAAM;gBACL,MAAM,IAAI,KAAK,CAAC,mCAAmC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aAC7F;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AA1BD,oCA0BC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
interface NearleyToken {
|
|
2
|
+
value: any;
|
|
3
|
+
[key: string]: any;
|
|
4
|
+
}
|
|
5
|
+
interface NearleyLexer {
|
|
6
|
+
reset: (chunk: string, info: any) => void;
|
|
7
|
+
next: () => NearleyToken | undefined;
|
|
8
|
+
save: () => any;
|
|
9
|
+
formatError: (token: never) => string;
|
|
10
|
+
has: (tokenType: string) => boolean;
|
|
11
|
+
}
|
|
12
|
+
interface NearleyRule {
|
|
13
|
+
name: string;
|
|
14
|
+
symbols: NearleySymbol[];
|
|
15
|
+
postprocess?: (d: any[], loc?: number, reject?: {}) => any;
|
|
16
|
+
}
|
|
17
|
+
type NearleySymbol = string | {
|
|
18
|
+
literal: any;
|
|
19
|
+
} | {
|
|
20
|
+
test: (token: any) => boolean;
|
|
21
|
+
};
|
|
22
|
+
interface Grammar {
|
|
23
|
+
Lexer: NearleyLexer | undefined;
|
|
24
|
+
ParserRules: NearleyRule[];
|
|
25
|
+
ParserStart: string;
|
|
26
|
+
}
|
|
27
|
+
declare const grammar: Grammar;
|
|
28
|
+
export default grammar;
|