typesql-cli 0.7.4 → 0.8.0-alpha.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (46) hide show
  1. package/cli.js +20 -16
  2. package/cli.js.map +1 -1
  3. package/code-generator.d.ts +6 -4
  4. package/code-generator.d.ts.map +1 -1
  5. package/code-generator.js +27 -7
  6. package/code-generator.js.map +1 -1
  7. package/describe-query.d.ts +2 -2
  8. package/describe-query.d.ts.map +1 -1
  9. package/mysql-mapping.d.ts +3 -1
  10. package/mysql-mapping.d.ts.map +1 -1
  11. package/mysql-mapping.js.map +1 -1
  12. package/mysql-query-analyzer/select-columns.d.ts +2 -1
  13. package/mysql-query-analyzer/select-columns.d.ts.map +1 -1
  14. package/mysql-query-analyzer/select-columns.js +9 -4
  15. package/mysql-query-analyzer/select-columns.js.map +1 -1
  16. package/mysql-query-analyzer/traverse.d.ts +1 -2
  17. package/mysql-query-analyzer/traverse.d.ts.map +1 -1
  18. package/mysql-query-analyzer/traverse.js +24 -22
  19. package/mysql-query-analyzer/traverse.js.map +1 -1
  20. package/mysql-query-analyzer/types.d.ts +16 -5
  21. package/mysql-query-analyzer/types.d.ts.map +1 -1
  22. package/package.json +5 -3
  23. package/sqlite-query-analyzer/code-generator.d.ts +3 -0
  24. package/sqlite-query-analyzer/code-generator.d.ts.map +1 -0
  25. package/sqlite-query-analyzer/code-generator.js +118 -0
  26. package/sqlite-query-analyzer/code-generator.js.map +1 -0
  27. package/sqlite-query-analyzer/parser.d.ts +5 -0
  28. package/sqlite-query-analyzer/parser.d.ts.map +1 -0
  29. package/sqlite-query-analyzer/parser.js +71 -0
  30. package/sqlite-query-analyzer/parser.js.map +1 -0
  31. package/sqlite-query-analyzer/query-executor.d.ts +5 -0
  32. package/sqlite-query-analyzer/query-executor.d.ts.map +1 -0
  33. package/sqlite-query-analyzer/query-executor.js +29 -0
  34. package/sqlite-query-analyzer/query-executor.js.map +1 -0
  35. package/sqlite-query-analyzer/traverse.d.ts +5 -0
  36. package/sqlite-query-analyzer/traverse.d.ts.map +1 -0
  37. package/sqlite-query-analyzer/traverse.js +254 -0
  38. package/sqlite-query-analyzer/traverse.js.map +1 -0
  39. package/sqlite-query-analyzer/types.d.ts +2 -0
  40. package/sqlite-query-analyzer/types.d.ts.map +1 -0
  41. package/sqlite-query-analyzer/types.js +3 -0
  42. package/sqlite-query-analyzer/types.js.map +1 -0
  43. package/ts-nested-descriptor.d.ts.map +1 -1
  44. package/ts-nested-descriptor.js.map +1 -1
  45. package/types.d.ts +4 -1
  46. package/types.d.ts.map +1 -1
@@ -0,0 +1,118 @@
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.generateTsCode = void 0;
7
+ const Either_1 = require("fp-ts/lib/Either");
8
+ const parser_1 = require("./parser");
9
+ const code_generator_1 = require("../code-generator");
10
+ const code_block_writer_1 = __importDefault(require("code-block-writer"));
11
+ function generateTsCode(sql, queryName, sqliteDbSchema) {
12
+ const queryInfo = (0, parser_1.parseSql)(sql, sqliteDbSchema);
13
+ if ((0, Either_1.isLeft)(queryInfo)) {
14
+ return 'invalid';
15
+ }
16
+ const tsDescriptor = createTsDescriptor(queryInfo.right);
17
+ const code = generateCodeFromTsDescriptor(queryName, tsDescriptor);
18
+ return code;
19
+ }
20
+ exports.generateTsCode = generateTsCode;
21
+ function createTsDescriptor(queryInfo) {
22
+ const tsDescriptor = {
23
+ sql: queryInfo.sql,
24
+ queryType: "Select",
25
+ multipleRowsResult: false,
26
+ columns: queryInfo.columns.map(col => mapColumnToTsFieldDescriptor(col)),
27
+ parameterNames: [],
28
+ parameters: queryInfo.parameters.map(param => mapParameterToTsFieldDescriptor(param))
29
+ };
30
+ return tsDescriptor;
31
+ }
32
+ function mapParameterToTsFieldDescriptor(col) {
33
+ const tsDesc = {
34
+ name: col.name,
35
+ tsType: mapColumnType(col.columnType),
36
+ notNull: col.notNull ? col.notNull : false
37
+ };
38
+ return tsDesc;
39
+ }
40
+ function mapColumnToTsFieldDescriptor(col) {
41
+ const tsDesc = {
42
+ name: col.columnName,
43
+ tsType: mapColumnType(col.type),
44
+ notNull: col.notNull ? col.notNull : false
45
+ };
46
+ return tsDesc;
47
+ }
48
+ function mapColumnType(sqliteType) {
49
+ switch (sqliteType) {
50
+ case 'INTEGER':
51
+ return 'number';
52
+ case 'TEXT':
53
+ return 'string';
54
+ case 'NUMERIC':
55
+ return 'number';
56
+ }
57
+ }
58
+ function generateCodeFromTsDescriptor(queryName, tsDescriptor) {
59
+ const writer = new code_block_writer_1.default({
60
+ useTabs: true
61
+ });
62
+ const camelCaseName = (0, code_generator_1.convertToCamelCaseName)(queryName);
63
+ const capitalizedName = (0, code_generator_1.capitalize)(camelCaseName);
64
+ const sql = tsDescriptor.sql;
65
+ const dataTypeName = capitalizedName + 'Data';
66
+ const paramsTypeName = capitalizedName + 'Params';
67
+ const resultTypeName = capitalizedName + 'Result';
68
+ const dynamicParamsTypeName = capitalizedName + 'DynamicParams';
69
+ const selectColumnsTypeName = capitalizedName + 'Select';
70
+ const whereTypeName = capitalizedName + 'Where';
71
+ const orderByTypeName = capitalizedName + 'OrderBy';
72
+ const generateOrderBy = tsDescriptor.orderByColumns != null && tsDescriptor.orderByColumns.length > 0;
73
+ const uniqueParams = (0, code_generator_1.removeDuplicatedParameters2)(tsDescriptor.parameters);
74
+ writer.writeLine(`import { Database } from 'better-sqlite3';`);
75
+ if (uniqueParams.length > 0) {
76
+ writer.blankLine();
77
+ writer.write(`export type ${paramsTypeName} =`).block(() => {
78
+ uniqueParams.forEach((field) => {
79
+ writer.writeLine(`${field.name}: ${field.tsType};`);
80
+ });
81
+ });
82
+ }
83
+ writer.blankLine();
84
+ writer.write(`export type ${resultTypeName} =`).block(() => {
85
+ tsDescriptor.columns.forEach((field, index) => {
86
+ const optionalOp = field.notNull ? '' : '?';
87
+ writer.writeLine(`${field.name}${optionalOp}: ${field.tsType};`);
88
+ });
89
+ });
90
+ writer.blankLine();
91
+ let functionArguments = `db: Database`;
92
+ functionArguments += tsDescriptor.parameters.length > 0 || generateOrderBy ? ', params: ' + paramsTypeName : '';
93
+ const queryParams = tsDescriptor.parameters.length > 0 ? '[' + tsDescriptor.parameters.map(param => 'params.' + param.name).join(', ') + ']' : '';
94
+ writer.write(`export function ${camelCaseName}(${functionArguments}): ${resultTypeName}[]`).block(() => {
95
+ const sqlSplit = sql.split('\n');
96
+ writer.write('const sql = `').newLine();
97
+ sqlSplit.forEach(sqlLine => {
98
+ writer.indent().write(sqlLine).newLine();
99
+ });
100
+ writer.indent().write('`').newLine();
101
+ writer.write('return db.prepare(sql)').newLine();
102
+ writer.indent().write('.raw(true)').newLine();
103
+ writer.indent().write(`.all(${queryParams})`).newLine();
104
+ writer.indent().write(`.map(data => mapArrayTo${resultTypeName}(data));`);
105
+ });
106
+ writer.blankLine();
107
+ writer.write(`function mapArrayTo${resultTypeName}(data: any) `).block(() => {
108
+ writer.write(`const result: ${resultTypeName} = `).block(() => {
109
+ tsDescriptor.columns.forEach((col, index) => {
110
+ const separator = index < tsDescriptor.columns.length - 1 ? ',' : '';
111
+ writer.writeLine(`${col.name}: data[${index}]${separator}`);
112
+ });
113
+ });
114
+ writer.writeLine('return result;');
115
+ });
116
+ return writer.toString();
117
+ }
118
+ //# sourceMappingURL=code-generator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-generator.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/code-generator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { Either } from "fp-ts/lib/Either";
2
+ import { SchemaDef, TypeSqlError } from "../types";
3
+ import { ColumnSchema } from "../mysql-query-analyzer/types";
4
+ export declare function parseSql(sql: string, dbSchema: ColumnSchema[]): Either<TypeSqlError, SchemaDef>;
5
+ //# sourceMappingURL=parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parser.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/parser.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAS,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAgB,SAAS,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAIjE,OAAO,EAAc,YAAY,EAAqC,MAAM,+BAA+B,CAAC;AAK5G,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,SAAS,CAAC,CAW/F"}
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseSql = void 0;
4
+ const sqlite_1 = require("@wsporto/ts-mysql-parser/dist/sqlite");
5
+ const Either_1 = require("fp-ts/lib/Either");
6
+ const sqlite_2 = require("@wsporto/ts-mysql-parser/dist/sqlite");
7
+ const antlr4ts_1 = require("antlr4ts");
8
+ const traverse_1 = require("./traverse");
9
+ const collect_constraints_1 = require("../mysql-query-analyzer/collect-constraints");
10
+ const unify_1 = require("../mysql-query-analyzer/unify");
11
+ const describe_query_1 = require("../describe-query");
12
+ function parseSql(sql, dbSchema) {
13
+ const { sql: processedSql, namedParameters } = (0, describe_query_1.preprocessSql)(sql);
14
+ const input = antlr4ts_1.CharStreams.fromString(sql.toUpperCase());
15
+ const lexer = new sqlite_1.SQLiteLexer(input);
16
+ const parser = new sqlite_2.SQLiteParser(new antlr4ts_1.CommonTokenStream(lexer));
17
+ const sql_stmt = parser.sql_stmt();
18
+ return describeSQL(processedSql, sql_stmt, dbSchema, namedParameters);
19
+ }
20
+ exports.parseSql = parseSql;
21
+ function describeSQL(sql, sql_stmtContext, dbSchema, namedParameters) {
22
+ const traverseContext = {
23
+ dbSchema,
24
+ withSchema: [],
25
+ constraints: [],
26
+ parameters: [],
27
+ fromColumns: [],
28
+ subQueryColumns: [],
29
+ subQuery: false,
30
+ where: false,
31
+ dynamicSqlInfo: {
32
+ with: [],
33
+ select: [],
34
+ from: [],
35
+ where: []
36
+ }
37
+ };
38
+ const queryResult = (0, traverse_1.traverse_Sql_stmtContext)(sql_stmtContext, traverseContext);
39
+ const substitutions = {}; //TODO - DUPLICADO
40
+ (0, unify_1.unify)(traverseContext.constraints, substitutions);
41
+ const columnResult = queryResult.columns.map((col) => {
42
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, col.type);
43
+ const columnNotNull = col.notNull;
44
+ const colInfo = {
45
+ columnName: col.name,
46
+ type: (0, describe_query_1.verifyNotInferred)(columnType),
47
+ notNull: columnNotNull,
48
+ table: col.table
49
+ };
50
+ return colInfo;
51
+ });
52
+ const paramsResult = traverseContext.parameters.map((param, index) => {
53
+ const columnType = (0, collect_constraints_1.getVarType)(substitutions, param);
54
+ const columnNotNull = true; // param.notNull;
55
+ const colInfo = {
56
+ name: namedParameters && namedParameters[index] ? namedParameters[index] : 'param' + (index + 1),
57
+ columnType: (0, describe_query_1.verifyNotInferred)(columnType),
58
+ notNull: columnNotNull
59
+ };
60
+ return colInfo;
61
+ });
62
+ const schemaDef = {
63
+ sql,
64
+ queryType: "Select",
65
+ multipleRowsResult: true,
66
+ columns: columnResult,
67
+ parameters: paramsResult
68
+ };
69
+ return (0, Either_1.right)(schemaDef);
70
+ }
71
+ //# sourceMappingURL=parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/parser.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { Either } from "fp-ts/lib/Either";
2
+ import { TypeSqlError } from "../types";
3
+ import { ColumnSchema } from "../mysql-query-analyzer/types";
4
+ export declare function loadDbSchema(databaseUri: string): Either<TypeSqlError, ColumnSchema[]>;
5
+ //# sourceMappingURL=query-executor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-executor.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/query-executor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAS,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAG7D,wBAAgB,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAAC,YAAY,EAAE,YAAY,EAAE,CAAC,CAoBtF"}
@@ -0,0 +1,29 @@
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.loadDbSchema = void 0;
7
+ const Either_1 = require("fp-ts/lib/Either");
8
+ const better_sqlite3_1 = __importDefault(require("better-sqlite3"));
9
+ function loadDbSchema(databaseUri) {
10
+ const db = new better_sqlite3_1.default(databaseUri);
11
+ const sql = `
12
+ WITH all_tables AS (
13
+ SELECT name FROM sqlite_schema WHERE type = 'table'
14
+ )
15
+ SELECT
16
+ '' AS schema,
17
+ t.name as 'table',
18
+ ti.name as 'column',
19
+ ti.type as column_type,
20
+ ti.'notnull' or ti.pk = 1 as 'notNull',
21
+ IIF(ti.pk = 1, 'PRI', '') as columnKey
22
+ FROM all_tables t INNER JOIN pragma_table_info(t.name) ti
23
+ `;
24
+ const result = db.prepare(sql)
25
+ .all();
26
+ return (0, Either_1.right)(result);
27
+ }
28
+ exports.loadDbSchema = loadDbSchema;
29
+ //# sourceMappingURL=query-executor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-executor.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/query-executor.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAiD;AAGjD,oEAAsC;AAEtC,SAAgB,YAAY,CAAC,WAAmB;IAE/C,MAAM,EAAE,GAAG,IAAI,wBAAQ,CAAC,WAAW,CAAC,CAAC;IACrC,MAAM,GAAG,GAAG;;;;;;;;;;;;GAYV,CAAA;IAEF,MAAM,MAAM,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC;SAC5B,GAAG,EAAoB,CAAC;IAC1B,OAAO,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC;AACtB,CAAC;AApBD,oCAoBC"}
@@ -0,0 +1,5 @@
1
+ import { Sql_stmtContext } from "@wsporto/ts-mysql-parser/dist/sqlite";
2
+ import { TraverseContext } from "../mysql-query-analyzer/types";
3
+ import { QuerySpecificationResult } from "../mysql-query-analyzer/traverse";
4
+ export declare function traverse_Sql_stmtContext(sql_stmt: Sql_stmtContext, traverseContext: TraverseContext): QuerySpecificationResult;
5
+ //# sourceMappingURL=traverse.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traverse.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/traverse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,eAAe,EAAyC,MAAM,sCAAsC,CAAC;AAClI,OAAO,EAAa,eAAe,EAAmC,MAAM,+BAA+B,CAAC;AAG5G,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAE5E,wBAAgB,wBAAwB,CAAC,QAAQ,EAAE,eAAe,EAAE,eAAe,EAAE,eAAe,GAAG,wBAAwB,CAQ9H"}
@@ -0,0 +1,254 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.traverse_Sql_stmtContext = void 0;
4
+ const sqlite_1 = require("@wsporto/ts-mysql-parser/dist/sqlite");
5
+ const select_columns_1 = require("../mysql-query-analyzer/select-columns");
6
+ const collect_constraints_1 = require("../mysql-query-analyzer/collect-constraints");
7
+ function traverse_Sql_stmtContext(sql_stmt, traverseContext) {
8
+ const select_stmt = sql_stmt.select_stmt();
9
+ if (select_stmt) {
10
+ const queryResult = traverse_select_stmt(select_stmt, traverseContext);
11
+ return queryResult;
12
+ }
13
+ throw Error("traverse_Sql_stmtContext");
14
+ }
15
+ exports.traverse_Sql_stmtContext = traverse_Sql_stmtContext;
16
+ function traverse_select_stmt(select_stmt, traverseContext) {
17
+ const common_table_stmt = select_stmt.common_table_stmt();
18
+ const select_coreList = select_stmt.select_core();
19
+ const columnsResult = [];
20
+ const listType = [];
21
+ const columnNullability = [];
22
+ const querySpecResult = select_coreList.map(select_core => {
23
+ const table_or_subquery = select_core.table_or_subquery();
24
+ if (table_or_subquery) {
25
+ const fields = traverse_table_or_subquery(table_or_subquery, traverseContext);
26
+ columnsResult.push(...fields);
27
+ }
28
+ const join_clause = select_core.join_clause();
29
+ if (join_clause) {
30
+ const join_table_or_subquery = join_clause.table_or_subquery();
31
+ const fields = traverse_table_or_subquery(join_table_or_subquery, traverseContext);
32
+ columnsResult.push(...fields);
33
+ }
34
+ const result_column = select_core.result_column();
35
+ result_column.forEach(result_column => {
36
+ var _a, _b;
37
+ if (result_column.STAR()) {
38
+ const tableName = (_a = result_column.table_name()) === null || _a === void 0 ? void 0 : _a.text;
39
+ columnsResult.forEach(col => {
40
+ if (!tableName || (0, select_columns_1.includeColumn)(col, tableName)) {
41
+ const columnType = (0, collect_constraints_1.createColumnType)(col);
42
+ listType.push(columnType);
43
+ columnNullability.push(col.notNull);
44
+ }
45
+ });
46
+ }
47
+ const expr = result_column.expr();
48
+ const alias = (_b = result_column.column_alias()) === null || _b === void 0 ? void 0 : _b.text;
49
+ if (expr) {
50
+ const exprType = traverse_expr(expr, Object.assign(Object.assign({}, traverseContext), { fromColumns: columnsResult }));
51
+ if (exprType.kind == 'TypeVar') {
52
+ if (alias) {
53
+ exprType.name = alias;
54
+ }
55
+ listType.push(exprType);
56
+ columnNullability.push(inferNotNull_expr(expr, columnsResult));
57
+ }
58
+ }
59
+ });
60
+ const whereList = select_core.expr();
61
+ whereList.forEach(where => {
62
+ traverse_expr(where, Object.assign(Object.assign({}, traverseContext), { fromColumns: columnsResult }));
63
+ });
64
+ const columns = listType.map((t, index) => {
65
+ const resultType = {
66
+ name: t.name,
67
+ type: t,
68
+ notNull: columnNullability[index],
69
+ table: t.table || ''
70
+ };
71
+ return resultType;
72
+ });
73
+ const querySpecification = {
74
+ columns,
75
+ fromColumns: []
76
+ };
77
+ return querySpecification;
78
+ });
79
+ return querySpecResult[0];
80
+ }
81
+ function traverse_table_or_subquery(table_or_subquery, traverseContext) {
82
+ const allFields = [];
83
+ table_or_subquery.forEach(table_or_subquery => {
84
+ var _a, _b;
85
+ const table_name = table_or_subquery.table_name();
86
+ const table_alias = (_a = table_or_subquery.table_alias()) === null || _a === void 0 ? void 0 : _a.text;
87
+ if (table_name) {
88
+ const tableName = (0, select_columns_1.splitName)(table_name.any_name().text);
89
+ const fields = (0, select_columns_1.filterColumns)(traverseContext.dbSchema, [], table_alias, tableName);
90
+ allFields.push(...fields);
91
+ }
92
+ const select_stmt = table_or_subquery.select_stmt();
93
+ if (select_stmt) {
94
+ const subQueryResult = traverse_select_stmt(select_stmt, traverseContext);
95
+ const tableAlias = (_b = table_or_subquery.table_alias()) === null || _b === void 0 ? void 0 : _b.text;
96
+ subQueryResult.columns.forEach(t => {
97
+ const colDef = {
98
+ table: t.table ? tableAlias || '' : '',
99
+ columnName: t.name,
100
+ columnType: t.type,
101
+ columnKey: "",
102
+ notNull: t.notNull,
103
+ tableAlias: tableAlias
104
+ };
105
+ allFields.push(colDef);
106
+ });
107
+ }
108
+ });
109
+ return allFields;
110
+ }
111
+ function traverse_expr(expr, traverseContext) {
112
+ var _a, _b;
113
+ const function_name = (_a = expr.function_name()) === null || _a === void 0 ? void 0 : _a.text.toLowerCase();
114
+ if (function_name == 'sum') {
115
+ const functionType = (0, collect_constraints_1.freshVar)(expr.text, 'NUMERIC');
116
+ const sumParamExpr = expr.expr()[0];
117
+ const paramType = traverse_expr(sumParamExpr, traverseContext);
118
+ if (paramType.kind == 'TypeVar') {
119
+ functionType.table = paramType.table;
120
+ }
121
+ return functionType;
122
+ }
123
+ if (function_name == 'count') {
124
+ const functionType = (0, collect_constraints_1.freshVar)(expr.text, 'INTEGER');
125
+ if (expr.expr().length == 1) {
126
+ const sumParamExpr = expr.expr()[0];
127
+ const paramType = traverse_expr(sumParamExpr, traverseContext);
128
+ if (paramType.kind == 'TypeVar') {
129
+ functionType.table = paramType.table;
130
+ }
131
+ }
132
+ return functionType;
133
+ }
134
+ const column_name = expr.column_name();
135
+ if (column_name) {
136
+ const fieldName = (0, select_columns_1.splitName)(column_name.text);
137
+ const column = (0, select_columns_1.findColumn)(fieldName, traverseContext.fromColumns);
138
+ const typeVar = (0, collect_constraints_1.freshVar)(column.columnName, column.columnType.type, column.tableAlias || column.table);
139
+ return typeVar;
140
+ }
141
+ const literal = expr.literal_value();
142
+ if (literal) {
143
+ if (literal.STRING_LITERAL()) {
144
+ return (0, collect_constraints_1.freshVar)(literal.text, 'TEXT');
145
+ }
146
+ if (literal.NUMERIC_LITERAL()) {
147
+ return (0, collect_constraints_1.freshVar)(literal.text, 'INTEGER');
148
+ }
149
+ return (0, collect_constraints_1.freshVar)(literal.text, '?');
150
+ }
151
+ const parameter = expr.BIND_PARAMETER();
152
+ if (parameter) {
153
+ const param = (0, collect_constraints_1.freshVar)('?', '?');
154
+ traverseContext.parameters.push(param);
155
+ return param;
156
+ }
157
+ if (expr.STAR() || expr.DIV() || expr.MOD()) {
158
+ const exprLeft = expr.expr()[0];
159
+ const exprRight = expr.expr()[1];
160
+ const typeLeft = traverse_expr(exprLeft, traverseContext);
161
+ return (0, collect_constraints_1.freshVar)(expr.text, 'tinyint');
162
+ }
163
+ if (expr.LT2() || expr.GT2() || expr.AMP() || expr.PIPE() || expr.LT() || expr.LT_EQ() || expr.GT() || expr.GT_EQ()) {
164
+ const exprLeft = expr.expr()[0];
165
+ const exprRight = expr.expr()[1];
166
+ const typeLeft = traverse_expr(exprLeft, traverseContext);
167
+ const typeRight = traverse_expr(exprRight, traverseContext);
168
+ traverseContext.constraints.push({
169
+ expression: expr.text,
170
+ type1: typeLeft,
171
+ type2: typeRight
172
+ });
173
+ return (0, collect_constraints_1.freshVar)(expr.text, 'tinyint');
174
+ }
175
+ if (expr.ASSIGN()) { //=
176
+ const exprLeft = expr.expr()[0];
177
+ const exprRight = expr.expr()[1];
178
+ const typeLeft = traverse_expr(exprLeft, traverseContext);
179
+ const typeRight = traverse_expr(exprRight, traverseContext);
180
+ traverseContext.constraints.push({
181
+ expression: expr.text,
182
+ type1: typeLeft,
183
+ type2: typeRight
184
+ });
185
+ return (0, collect_constraints_1.freshVar)(expr.text, 'tinyint');
186
+ }
187
+ if (expr.IN_()) {
188
+ const inExprLeft = expr.expr()[0];
189
+ const inExprRight = expr.expr()[1];
190
+ const typeLeft = traverse_expr(inExprLeft, traverseContext);
191
+ (_b = inExprRight.children) === null || _b === void 0 ? void 0 : _b.forEach(exprRight => {
192
+ if (exprRight instanceof sqlite_1.ExprContext) {
193
+ const typeRight = traverse_expr(exprRight, traverseContext);
194
+ traverseContext.constraints.push({
195
+ expression: expr.text,
196
+ type1: typeLeft,
197
+ type2: typeRight
198
+ });
199
+ }
200
+ });
201
+ return (0, collect_constraints_1.freshVar)(expr.text, 'tinyint');
202
+ }
203
+ if (expr.OR_() || expr.AND_()) {
204
+ const expr1 = expr.expr()[0];
205
+ const expr2 = expr.expr()[1];
206
+ traverse_expr(expr1, traverseContext);
207
+ traverse_expr(expr2, traverseContext);
208
+ return (0, collect_constraints_1.freshVar)(expr.text, 'tinyint');
209
+ }
210
+ if (expr.CASE_()) {
211
+ const resultTypes = []; //then and else
212
+ const whenTypes = [];
213
+ expr.expr().forEach((expr_, index) => {
214
+ const type = traverse_expr(expr_, traverseContext);
215
+ if (expr_.WHEN_() || expr_.THEN_()) {
216
+ if (index % 2 == 0) {
217
+ whenTypes.push(type);
218
+ }
219
+ else {
220
+ resultTypes.push(type);
221
+ }
222
+ }
223
+ if (expr_.ELSE_()) {
224
+ resultTypes.push(type);
225
+ }
226
+ });
227
+ resultTypes.forEach((resultType, index) => {
228
+ if (index > 0) {
229
+ traverseContext.constraints.push({
230
+ expression: expr.text,
231
+ type1: resultTypes[0],
232
+ type2: resultType
233
+ });
234
+ }
235
+ });
236
+ return resultTypes[0];
237
+ }
238
+ throw Error('traverse_expr not supported:' + expr.text);
239
+ }
240
+ function inferNotNull_expr(expr, fromColumns) {
241
+ var _a;
242
+ const column_name = expr.column_name();
243
+ if (column_name) {
244
+ const fieldName = (0, select_columns_1.splitName)(column_name.text);
245
+ const column = (0, select_columns_1.findColumn)(fieldName, fromColumns);
246
+ return column.notNull;
247
+ }
248
+ const function_name = (_a = expr.function_name()) === null || _a === void 0 ? void 0 : _a.text.toLowerCase();
249
+ if (function_name == 'count') {
250
+ return true;
251
+ }
252
+ return false;
253
+ }
254
+ //# sourceMappingURL=traverse.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traverse.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/traverse.ts"],"names":[],"mappings":";;;AAAA,iEAAkI;AAElI,2EAA6G;AAC7G,qFAAyF;AAGzF,SAAgB,wBAAwB,CAAC,QAAyB,EAAE,eAAgC;IAEhG,MAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC3C,IAAI,WAAW,EAAE,CAAC;QACd,MAAM,WAAW,GAAG,oBAAoB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACvE,OAAO,WAAW,CAAC;IACvB,CAAC;IACD,MAAM,KAAK,CAAC,0BAA0B,CAAC,CAAC;AAC5C,CAAC;AARD,4DAQC;AAED,SAAS,oBAAoB,CAAC,WAA+B,EAAE,eAAgC;IAC3F,MAAM,iBAAiB,GAAG,WAAW,CAAC,iBAAiB,EAAE,CAAC;IAE1D,MAAM,eAAe,GAAG,WAAW,CAAC,WAAW,EAAE,CAAC;IAElD,MAAM,aAAa,GAAgB,EAAE,CAAC;IACtC,MAAM,QAAQ,GAAc,EAAE,CAAC;IAC/B,MAAM,iBAAiB,GAAc,EAAE,CAAC;IAExC,MAAM,eAAe,GAAG,eAAe,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;QACtD,MAAM,iBAAiB,GAAG,WAAW,CAAC,iBAAiB,EAAE,CAAC;QAC1D,IAAI,iBAAiB,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,0BAA0B,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;YAC9E,aAAa,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC;QAClC,CAAC;QACD,MAAM,WAAW,GAAG,WAAW,CAAC,WAAW,EAAE,CAAC;QAC9C,IAAI,WAAW,EAAE,CAAC;YACd,MAAM,sBAAsB,GAAG,WAAW,CAAC,iBAAiB,EAAE,CAAC;YAC/D,MAAM,MAAM,GAAG,0BAA0B,CAAC,sBAAsB,EAAE,eAAe,CAAC,CAAC;YACnF,aAAa,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC;QAClC,CAAC;QAED,MAAM,aAAa,GAAG,WAAW,CAAC,aAAa,EAAE,CAAC;QAElD,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE;;YAClC,IAAI,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC;gBACvB,MAAM,SAAS,GAAG,MAAA,aAAa,CAAC,UAAU,EAAE,0CAAE,IAAI,CAAC;gBACnD,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;oBACxB,IAAI,CAAC,SAAS,IAAI,IAAA,8BAAa,EAAC,GAAG,EAAE,SAAS,CAAC,EAAE,CAAC;wBAC9C,MAAM,UAAU,GAAG,IAAA,sCAAgB,EAAC,GAAG,CAAC,CAAC;wBACzC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;wBAC1B,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACxC,CAAC;gBAEL,CAAC,CAAC,CAAA;YACN,CAAC;YAED,MAAM,IAAI,GAAG,aAAa,CAAC,IAAI,EAAE,CAAC;YAClC,MAAM,KAAK,GAAG,MAAA,aAAa,CAAC,YAAY,EAAE,0CAAE,IAAI,CAAC;YACjD,IAAI,IAAI,EAAE,CAAC;gBACP,MAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,kCAAO,eAAe,KAAE,WAAW,EAAE,aAAa,IAAG,CAAC;gBACzF,IAAI,QAAQ,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;oBAC7B,IAAI,KAAK,EAAE,CAAC;wBACR,QAAQ,CAAC,IAAI,GAAG,KAAK,CAAC;oBAC1B,CAAC;oBACD,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACxB,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC;gBACnE,CAAC;YACL,CAAC;QACL,CAAC,CAAC,CAAA;QAEF,MAAM,SAAS,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC;QACrC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACtB,aAAa,CAAC,KAAK,kCAAO,eAAe,KAAE,WAAW,EAAE,aAAa,IAAG,CAAC;QAC7E,CAAC,CAAC,CAAA;QAEF,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;YACtC,MAAM,UAAU,GAAqB;gBACjC,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC;gBACP,OAAO,EAAE,iBAAiB,CAAC,KAAK,CAAC;gBACjC,KAAK,EAAE,CAAC,CAAC,KAAK,IAAI,EAAE;aACvB,CAAA;YACD,OAAO,UAAU,CAAC;QACtB,CAAC,CAAC,CAAA;QACF,MAAM,kBAAkB,GAA6B;YACjD,OAAO;YACP,WAAW,EAAE,EAAE;SAClB,CAAA;QACD,OAAO,kBAAkB,CAAC;IAC9B,CAAC,CAAC,CAAA;IAEF,OAAO,eAAe,CAAC,CAAC,CAAC,CAAC;AAC9B,CAAC;AAED,SAAS,0BAA0B,CAAC,iBAA6C,EAAE,eAAgC;IAC/G,MAAM,SAAS,GAAgB,EAAE,CAAC;IAClC,iBAAiB,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE;;QAC1C,MAAM,UAAU,GAAG,iBAAiB,CAAC,UAAU,EAAE,CAAC;QAClD,MAAM,WAAW,GAAG,MAAA,iBAAiB,CAAC,WAAW,EAAE,0CAAE,IAAI,CAAC;QAC1D,IAAI,UAAU,EAAE,CAAC;YACb,MAAM,SAAS,GAAG,IAAA,0BAAS,EAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,CAAC;YACxD,MAAM,MAAM,GAAG,IAAA,8BAAa,EAAC,eAAe,CAAC,QAAQ,EAAE,EAAE,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;YACnF,SAAS,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC;QAC9B,CAAC;QACD,MAAM,WAAW,GAAG,iBAAiB,CAAC,WAAW,EAAE,CAAC;QACpD,IAAI,WAAW,EAAE,CAAC;YACd,MAAM,cAAc,GAAG,oBAAoB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;YAC1E,MAAM,UAAU,GAAG,MAAA,iBAAiB,CAAC,WAAW,EAAE,0CAAE,IAAI,CAAC;YACzD,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBAC/B,MAAM,MAAM,GAAc;oBACtB,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE;oBACtC,UAAU,EAAE,CAAC,CAAC,IAAI;oBAClB,UAAU,EAAE,CAAC,CAAC,IAAI;oBAClB,SAAS,EAAE,EAAE;oBACb,OAAO,EAAE,CAAC,CAAC,OAAO;oBAClB,UAAU,EAAE,UAAU;iBACzB,CAAA;gBACD,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC,CAAC,CAAA;QACN,CAAC;IACL,CAAC,CAAC,CAAA;IACF,OAAO,SAAS,CAAC;AACrB,CAAC;AAED,SAAS,aAAa,CAAC,IAAiB,EAAE,eAAgC;;IACtE,MAAM,aAAa,GAAG,MAAA,IAAI,CAAC,aAAa,EAAE,0CAAE,IAAI,CAAC,WAAW,EAAE,CAAC;IAC/D,IAAI,aAAa,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,YAAY,GAAG,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACpD,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACpC,MAAM,SAAS,GAAG,aAAa,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;QAC/D,IAAI,SAAS,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;YAC9B,YAAY,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,CAAA;QACxC,CAAC;QACD,OAAO,YAAY,CAAC;IACxB,CAAC;IACD,IAAI,aAAa,IAAI,OAAO,EAAE,CAAC;QAC3B,MAAM,YAAY,GAAG,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC1B,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YACpC,MAAM,SAAS,GAAG,aAAa,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;YAC/D,IAAI,SAAS,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;gBAC9B,YAAY,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,CAAA;YACxC,CAAC;QACL,CAAC;QAED,OAAO,YAAY,CAAC;IACxB,CAAC;IAED,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IACvC,IAAI,WAAW,EAAE,CAAC;QACd,MAAM,SAAS,GAAG,IAAA,0BAAS,EAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,IAAA,2BAAU,EAAC,SAAS,EAAE,eAAe,CAAC,WAAW,CAAC,CAAC;QAClE,MAAM,OAAO,GAAG,IAAA,8BAAQ,EAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC;QACvG,OAAO,OAAO,CAAC;IACnB,CAAC;IACD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;IACrC,IAAI,OAAO,EAAE,CAAC;QACV,IAAI,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC;YAC3B,OAAO,IAAA,8BAAQ,EAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;QACzC,CAAC;QACD,IAAI,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC;YAC5B,OAAO,IAAA,8BAAQ,EAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QAC7C,CAAC;QACD,OAAO,IAAA,8BAAQ,EAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACvC,CAAC;IACD,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;IACxC,IAAI,SAAS,EAAE,CAAC;QACZ,MAAM,KAAK,GAAG,IAAA,8BAAQ,EAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACjC,eAAe,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,IAAI,CAAC,IAAI,EAAE,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;QAC1D,OAAO,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,IAAI,IAAI,CAAC,EAAE,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,EAAE,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QAClH,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;QAC1D,MAAM,SAAS,GAAG,aAAa,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;QAC5D,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC;YAC7B,UAAU,EAAE,IAAI,CAAC,IAAI;YACrB,KAAK,EAAE,QAAQ;YACf,KAAK,EAAE,SAAS;SACnB,CAAC,CAAA;QACF,OAAO,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,GAAG;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;QAC1D,MAAM,SAAS,GAAG,aAAa,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;QAC5D,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC;YAC7B,UAAU,EAAE,IAAI,CAAC,IAAI;YACrB,KAAK,EAAE,QAAQ;YACf,KAAK,EAAE,SAAS;SACnB,CAAC,CAAA;QACF,OAAO,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QACb,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAG,aAAa,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;QAC5D,MAAA,WAAW,CAAC,QAAQ,0CAAE,OAAO,CAAC,SAAS,CAAC,EAAE;YACtC,IAAI,SAAS,YAAY,oBAAW,EAAE,CAAC;gBACnC,MAAM,SAAS,GAAG,aAAa,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;gBAC5D,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC;oBAC7B,UAAU,EAAE,IAAI,CAAC,IAAI;oBACrB,KAAK,EAAE,QAAQ;oBACf,KAAK,EAAE,SAAS;iBACnB,CAAC,CAAA;YACN,CAAC;QACL,CAAC,CAAC,CAAA;QACF,OAAO,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;QAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7B,aAAa,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;QACtC,aAAa,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;QACtC,OAAO,IAAA,8BAAQ,EAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QACf,MAAM,WAAW,GAAW,EAAE,CAAC,CAAC,eAAe;QAC/C,MAAM,SAAS,GAAW,EAAE,CAAC;QAC7B,IAAI,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YACjC,MAAM,IAAI,GAAG,aAAa,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;YACnD,IAAI,KAAK,CAAC,KAAK,EAAE,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC;gBACjC,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;oBACjB,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACzB,CAAC;qBACI,CAAC;oBACF,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC3B,CAAC;YACL,CAAC;YACD,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC;gBAChB,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3B,CAAC;QACL,CAAC,CAAC,CAAC;QACH,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,KAAK,EAAE,EAAE;YACtC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;gBACZ,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC;oBAC7B,UAAU,EAAE,IAAI,CAAC,IAAI;oBACrB,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC;oBACrB,KAAK,EAAE,UAAU;iBACpB,CAAC,CAAA;YACN,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,WAAW,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IACD,MAAM,KAAK,CAAC,8BAA8B,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;AAC5D,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAiB,EAAE,WAAwB;;IAClE,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IACvC,IAAI,WAAW,EAAE,CAAC;QACd,MAAM,SAAS,GAAG,IAAA,0BAAS,EAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,IAAA,2BAAU,EAAC,SAAS,EAAE,WAAW,CAAC,CAAC;QAClD,OAAO,MAAM,CAAC,OAAO,CAAC;IAC1B,CAAC;IACD,MAAM,aAAa,GAAG,MAAA,IAAI,CAAC,aAAa,EAAE,0CAAE,IAAI,CAAC,WAAW,EAAE,CAAC;IAC/D,IAAI,aAAa,IAAI,OAAO,EAAE,CAAC;QAC3B,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,OAAO,KAAK,CAAC;AACjB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export type SQLiteType = 'INTEGER' | 'TEXT' | 'NUMERIC';
2
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GACnB,SAAS,GACT,MAAM,GACN,SAAS,CAAC"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/sqlite-query-analyzer/types.ts"],"names":[],"mappings":""}
@@ -1 +1 @@
1
- {"version":3,"file":"ts-nested-descriptor.d.ts","sourceRoot":"","sources":["../../src/ts-nested-descriptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,gBAAgB,EAAiB,MAAM,yBAAyB,CAAC;AAC/F,OAAO,EAAE,MAAM,EAAkB,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,MAAM,MAAM,OAAO,GAAG;IAClB,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;CACpB,CAAA;AAED,MAAM,MAAM,eAAe,GAAG;IAC1B,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;CACpB,CAAA;AAED,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,eAAe,CAAC;AAElD,MAAM,MAAM,YAAY,GAAG;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,SAAS,EAAE,CAAC;CACvB,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC7B,SAAS,EAAE,YAAY,EAAE,CAAC;CAC7B,CAAA;AAED,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,UAAU,EAAE,EAAE,gBAAgB,EAAE,gBAAgB,GAAG,kBAAkB,CAKtH"}
1
+ {"version":3,"file":"ts-nested-descriptor.d.ts","sourceRoot":"","sources":["../../src/ts-nested-descriptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,gBAAgB,EAAiB,MAAM,yBAAyB,CAAC;AAC/F,OAAO,EAAa,MAAM,EAAkB,MAAM,iBAAiB,CAAC;AACpE,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,MAAM,MAAM,OAAO,GAAG;IAClB,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;CACpB,CAAA;AAED,MAAM,MAAM,eAAe,GAAG;IAC1B,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;CACpB,CAAA;AAED,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,eAAe,CAAC;AAElD,MAAM,MAAM,YAAY,GAAG;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,SAAS,EAAE,CAAC;CACvB,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC7B,SAAS,EAAE,YAAY,EAAE,CAAC;CAC7B,CAAA;AAED,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,UAAU,EAAE,EAAE,gBAAgB,EAAE,gBAAgB,GAAG,kBAAkB,CAKtH"}
@@ -1 +1 @@
1
- {"version":3,"file":"ts-nested-descriptor.js","sourceRoot":"","sources":["../../src/ts-nested-descriptor.ts"],"names":[],"mappings":";;;AACA,mDAAyD;AA+BzD,SAAgB,wBAAwB,CAAC,OAAqB,EAAE,gBAAkC;IAC9F,MAAM,MAAM,GAAuB;QAC/B,SAAS,EAAE,gBAAgB,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,sBAAsB,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;KACrF,CAAA;IACD,OAAO,MAAM,CAAC;AAClB,CAAC;AALD,4DAKC;AAED,SAAS,sBAAsB,CAAC,OAAqB,EAAE,WAAyB;IAE5E,MAAM,QAAQ,GAAiB;QAC3B,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,aAAa,EAAE,WAAW,CAAC,aAAa;QACxC,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;KAC/D,CAAA;IACD,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED,SAAS,UAAU,CAAC,OAAqB,EAAE,KAA4B;IACnE,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC;IAC7B,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;QACvB,OAAO,uBAAuB,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IACnD,CAAC;IACD,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;QAC1B,OAAO,0BAA0B,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IACD,OAAO,SAAyB,CAAA;AACpC,CAAC;AAED,SAAS,uBAAuB,CAAC,OAAqB,EAAE,WAAkB;IACtE,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,IAAI,WAAW,CAAC,IAAI,CAAE,CAAC;IACxE,MAAM,MAAM,GAAG,IAAA,8BAAc,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAE3C,MAAM,KAAK,GAAY;QACnB,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,KAAK,EAAE,WAAW,CAAC,KAAK;QACxB,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM,CAAC,OAAO;KAC1B,CAAA;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,SAAS,0BAA0B,CAAC,WAA0B;IAE1D,MAAM,KAAK,GAAoB;QAC3B,IAAI,EAAE,UAAU;QAChB,IAAI,EAAE,WAAW,CAAC,WAAW,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;QACtD,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,MAAM,EAAE,WAAW,CAAC,IAAI,GAAG,CAAC,WAAW,CAAC,WAAW,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1E,OAAO,EAAE,WAAW,CAAC,OAAO;KAC/B,CAAA;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AACD,kGAAkG;AAClG,sDAAsD;AAEtD,8EAA8E;AAC9E,uCAAuC;AACvC,mCAAmC;AACnC,qDAAqD;AACrD,+FAA+F;AAC/F,iEAAiE;AACjE,iBAAiB;AACjB,YAAY;AACZ,uBAAuB;AACvB,UAAU;AACV,IAAI;AAEJ,yCAAyC;AACzC,yEAAyE;AACzE,sCAAsC;AACtC,2CAA2C;AAC3C,qDAAqD;AACrD,gCAAgC;AAChC,YAAY;AACZ,QAAQ;AACR,kBAAkB;AAClB,IAAI"}
1
+ {"version":3,"file":"ts-nested-descriptor.js","sourceRoot":"","sources":["../../src/ts-nested-descriptor.ts"],"names":[],"mappings":";;;AACA,mDAAoE;AA+BpE,SAAgB,wBAAwB,CAAC,OAAqB,EAAE,gBAAkC;IAC9F,MAAM,MAAM,GAAuB;QAC/B,SAAS,EAAE,gBAAgB,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,sBAAsB,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;KACrF,CAAA;IACD,OAAO,MAAM,CAAC;AAClB,CAAC;AALD,4DAKC;AAED,SAAS,sBAAsB,CAAC,OAAqB,EAAE,WAAyB;IAE5E,MAAM,QAAQ,GAAiB;QAC3B,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,aAAa,EAAE,WAAW,CAAC,aAAa;QACxC,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;KAC/D,CAAA;IACD,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED,SAAS,UAAU,CAAC,OAAqB,EAAE,KAA4B;IACnE,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC;IAC7B,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;QACvB,OAAO,uBAAuB,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IACnD,CAAC;IACD,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;QAC1B,OAAO,0BAA0B,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IACD,OAAO,SAAyB,CAAA;AACpC,CAAC;AAED,SAAS,uBAAuB,CAAC,OAAqB,EAAE,WAAkB;IACtE,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,IAAI,WAAW,CAAC,IAAI,CAAE,CAAC;IACxE,MAAM,MAAM,GAAG,IAAA,8BAAc,EAAC,MAAM,CAAC,IAAiB,CAAC,CAAC;IAExD,MAAM,KAAK,GAAY;QACnB,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,KAAK,EAAE,WAAW,CAAC,KAAK;QACxB,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,MAAM,CAAC,OAAO;KAC1B,CAAA;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,SAAS,0BAA0B,CAAC,WAA0B;IAE1D,MAAM,KAAK,GAAoB;QAC3B,IAAI,EAAE,UAAU;QAChB,IAAI,EAAE,WAAW,CAAC,WAAW,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;QACtD,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,MAAM,EAAE,WAAW,CAAC,IAAI,GAAG,CAAC,WAAW,CAAC,WAAW,IAAI,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1E,OAAO,EAAE,WAAW,CAAC,OAAO;KAC/B,CAAA;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AACD,kGAAkG;AAClG,sDAAsD;AAEtD,8EAA8E;AAC9E,uCAAuC;AACvC,mCAAmC;AACnC,qDAAqD;AACrD,+FAA+F;AAC/F,iEAAiE;AACjE,iBAAiB;AACjB,YAAY;AACZ,uBAAuB;AACvB,UAAU;AACV,IAAI;AAEJ,yCAAyC;AACzC,yEAAyE;AACzE,sCAAsC;AACtC,2CAA2C;AAC3C,qDAAqD;AACrD,gCAAgC;AAChC,YAAY;AACZ,QAAQ;AACR,kBAAkB;AAClB,IAAI"}
package/types.d.ts CHANGED
@@ -3,6 +3,7 @@ import { Brand } from "./utility-types";
3
3
  import { ColumnInfo, ColumnSchema, DynamicSqlInfoResult } from "./mysql-query-analyzer/types";
4
4
  import { QueryContext } from '@wsporto/ts-mysql-parser';
5
5
  import { NestedResultInfo } from "./describe-nested-query";
6
+ import { SQLiteType } from "./sqlite-query-analyzer/types";
6
7
  export type DBSchema = {
7
8
  columns: ColumnSchema[];
8
9
  };
@@ -36,7 +37,7 @@ export type ColumnDef2 = {
36
37
  };
37
38
  export type ParameterDef = {
38
39
  name: string;
39
- columnType: MySqlType | 'any';
40
+ columnType: MySqlType | SQLiteType | 'any';
40
41
  notNull: boolean;
41
42
  list?: boolean;
42
43
  };
@@ -86,10 +87,12 @@ export type PreprocessedSql = {
86
87
  namedParameters: string[];
87
88
  };
88
89
  export type CamelCaseName = Brand<string, 'CamelCase'>;
90
+ export type TypeSqlDialect = 'mysql' | 'sqlite';
89
91
  export type TypeSqlConfig = {
90
92
  databaseUri: string;
91
93
  sqlDir: string;
92
94
  target: 'node' | 'deno';
95
+ client: TypeSqlDialect;
93
96
  includeCrudTables: string[];
94
97
  };
95
98
  export type SqlGenOption = 'select' | 's' | 'insert' | 'i' | 'update' | 'u' | 'delete' | 'd';
package/types.d.ts.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}