@dbml/core 2.5.2 → 2.5.4
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/README.md +1 -1
- package/lib/export/DbmlExporter.js +9 -64
- package/lib/export/JsonExporter.js +5 -11
- package/lib/export/ModelExporter.js +5 -22
- package/lib/export/MysqlExporter.js +8 -70
- package/lib/export/PostgresExporter.js +11 -80
- package/lib/export/SqlServerExporter.js +10 -71
- package/lib/export/index.js +0 -6
- package/lib/export/utils.js +2 -12
- package/lib/import/index.js +0 -7
- package/lib/index.js +4 -9
- package/lib/model_structure/config.js +1 -1
- package/lib/model_structure/database.js +32 -83
- package/lib/model_structure/dbState.js +5 -10
- package/lib/model_structure/element.js +13 -38
- package/lib/model_structure/endpoint.js +22 -68
- package/lib/model_structure/enum.js +18 -49
- package/lib/model_structure/enumValue.js +17 -44
- package/lib/model_structure/field.js +26 -62
- package/lib/model_structure/indexColumn.js +15 -40
- package/lib/model_structure/indexes.js +22 -50
- package/lib/model_structure/ref.js +24 -56
- package/lib/model_structure/schema.js +27 -65
- package/lib/model_structure/table.js +24 -59
- package/lib/model_structure/tableGroup.js +18 -49
- package/lib/model_structure/utils.js +0 -3
- package/lib/parse/Parser.js +5 -27
- package/lib/parse/buildParser.js +11 -23
- package/lib/parse/dbmlParser.js +863 -2131
- package/lib/parse/mssql/base_parsers.js +2 -11
- package/lib/parse/mssql/column_definition/actions.js +0 -3
- package/lib/parse/mssql/column_definition/index.js +9 -17
- package/lib/parse/mssql/constraint_definition/actions.js +6 -12
- package/lib/parse/mssql/constraint_definition/index.js +13 -21
- package/lib/parse/mssql/expression.js +6 -16
- package/lib/parse/mssql/fk_definition/actions.js +1 -12
- package/lib/parse/mssql/fk_definition/index.js +5 -10
- package/lib/parse/mssql/index.js +2 -4
- package/lib/parse/mssql/index_definition/actions.js +0 -6
- package/lib/parse/mssql/index_definition/index.js +8 -13
- package/lib/parse/mssql/keyword_parsers.js +2 -3
- package/lib/parse/mssql/keyword_utils.js +0 -4
- package/lib/parse/mssql/statements/actions.js +0 -24
- package/lib/parse/mssql/statements/index.js +1 -7
- package/lib/parse/mssql/statements/statement_types/alter_table/actions.js +3 -10
- package/lib/parse/mssql/statements/statement_types/alter_table/add/actions.js +2 -6
- package/lib/parse/mssql/statements/statement_types/alter_table/add/index.js +9 -18
- package/lib/parse/mssql/statements/statement_types/alter_table/index.js +2 -7
- package/lib/parse/mssql/statements/statement_types/comments/actions.js +3 -11
- package/lib/parse/mssql/statements/statement_types/comments/index.js +3 -13
- package/lib/parse/mssql/statements/statement_types/create_index/actions.js +1 -3
- package/lib/parse/mssql/statements/statement_types/create_index/index.js +9 -15
- package/lib/parse/mssql/statements/statement_types/create_table/actions.js +7 -18
- package/lib/parse/mssql/statements/statement_types/create_table/index.js +8 -16
- package/lib/parse/mssql/statements/statement_types/index.js +0 -4
- package/lib/parse/mssql/utils.js +4 -14
- package/lib/parse/mssql/whitespaces.js +0 -1
- package/lib/parse/mssqlParser.js +0 -3
- package/lib/parse/mysqlParser.js +822 -2395
- package/lib/parse/postgresParser.js +3 -3
- package/lib/parse/postgresql/get_parser.js +6 -9
- package/lib/parse/schemarbParser.js +219 -714
- package/package.json +11 -12
- package/types/.DS_Store +0 -0
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _ = require('lodash');
|
|
4
|
-
|
|
5
4
|
var _require = require('../../../utils'),
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
getFullTableName = _require.getFullTableName;
|
|
8
6
|
function handleRef(tableName, result) {
|
|
9
7
|
var endpointWithNoTableName = result.value.endpoints.find(function (ele) {
|
|
10
8
|
return !ele.tableName;
|
|
@@ -12,29 +10,25 @@ function handleRef(tableName, result) {
|
|
|
12
10
|
endpointWithNoTableName.tableName = tableName.name;
|
|
13
11
|
endpointWithNoTableName.schemaName = tableName.schemaName;
|
|
14
12
|
}
|
|
15
|
-
|
|
16
13
|
function addTableName(tableName, result) {
|
|
17
14
|
result.value.tableName = tableName.name;
|
|
18
15
|
result.value.schemaName = tableName.schemaName;
|
|
19
16
|
}
|
|
20
|
-
|
|
21
17
|
function handleAlterTableResult(_keyword, tableName, results) {
|
|
22
18
|
if (!results) return null;
|
|
23
|
-
var fullName = getFullTableName(tableName);
|
|
24
|
-
|
|
19
|
+
var fullName = getFullTableName(tableName);
|
|
20
|
+
// eslint-disable-next-line consistent-return
|
|
25
21
|
results.forEach(function (result) {
|
|
26
22
|
if (result) {
|
|
27
23
|
switch (result.type) {
|
|
28
24
|
case 'refs':
|
|
29
25
|
handleRef(fullName, result);
|
|
30
26
|
break;
|
|
31
|
-
|
|
32
27
|
case 'indexes':
|
|
33
28
|
case 'dbdefault':
|
|
34
29
|
case 'enums':
|
|
35
30
|
addTableName(fullName, result);
|
|
36
31
|
break;
|
|
37
|
-
|
|
38
32
|
default:
|
|
39
33
|
break;
|
|
40
34
|
}
|
|
@@ -42,7 +36,6 @@ function handleAlterTableResult(_keyword, tableName, results) {
|
|
|
42
36
|
});
|
|
43
37
|
return results;
|
|
44
38
|
}
|
|
45
|
-
|
|
46
39
|
module.exports = {
|
|
47
40
|
handleAlterTableResult: handleAlterTableResult
|
|
48
41
|
};
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _require = require('../../../../constraint_definition'),
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
makeTableConstraint = _require.makeTableConstraint;
|
|
6
5
|
|
|
6
|
+
// eslint-disable-next-line no-unused-vars
|
|
7
7
|
function makeDefault(_keyword, constExpression, _for, fieldName, _withValues) {
|
|
8
8
|
var value = {};
|
|
9
|
-
|
|
10
9
|
if (constExpression.type) {
|
|
11
10
|
switch (constExpression.type) {
|
|
12
11
|
case 'string':
|
|
@@ -14,7 +13,6 @@ function makeDefault(_keyword, constExpression, _for, fieldName, _withValues) {
|
|
|
14
13
|
case 'boolean':
|
|
15
14
|
value.type = constExpression.type;
|
|
16
15
|
break;
|
|
17
|
-
|
|
18
16
|
default:
|
|
19
17
|
value.type = 'expression';
|
|
20
18
|
break;
|
|
@@ -22,7 +20,6 @@ function makeDefault(_keyword, constExpression, _for, fieldName, _withValues) {
|
|
|
22
20
|
} else {
|
|
23
21
|
value.type = 'expression';
|
|
24
22
|
}
|
|
25
|
-
|
|
26
23
|
value.value = constExpression.value;
|
|
27
24
|
value.fieldName = fieldName;
|
|
28
25
|
return {
|
|
@@ -30,7 +27,6 @@ function makeDefault(_keyword, constExpression, _for, fieldName, _withValues) {
|
|
|
30
27
|
value: value
|
|
31
28
|
};
|
|
32
29
|
}
|
|
33
|
-
|
|
34
30
|
module.exports = {
|
|
35
31
|
makeTableConstraint: makeTableConstraint,
|
|
36
32
|
makeDefault: makeDefault
|
|
@@ -1,32 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var P = require('parsimmon');
|
|
4
|
-
|
|
5
4
|
var KP = require('../../../../keyword_parsers');
|
|
6
|
-
|
|
7
5
|
var _require = require('../../../../base_parsers'),
|
|
8
|
-
|
|
9
|
-
|
|
6
|
+
pIdentifier = _require.pIdentifier;
|
|
10
7
|
var _require2 = require('../../../../utils'),
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
8
|
+
makeNode = _require2.makeNode,
|
|
9
|
+
makeList = _require2.makeList;
|
|
14
10
|
var A = require('./actions');
|
|
15
|
-
|
|
16
11
|
var _require3 = require('../../../../fk_definition'),
|
|
17
|
-
|
|
18
|
-
|
|
12
|
+
pTableConstraintFK = _require3.pTableConstraintFK;
|
|
19
13
|
var _require4 = require('../../../../index_definition'),
|
|
20
|
-
|
|
21
|
-
|
|
14
|
+
pTableConstraintIndex = _require4.pTableConstraintIndex;
|
|
22
15
|
var _require5 = require('../../../../constraint_definition'),
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
16
|
+
pConstraintCheck = _require5.pConstraintCheck,
|
|
17
|
+
pConstExpr = _require5.pConstExpr,
|
|
18
|
+
pConstraintName = _require5.pConstraintName;
|
|
27
19
|
var _require6 = require('../../../../column_definition'),
|
|
28
|
-
|
|
29
|
-
|
|
20
|
+
pColumnsDefinition = _require6.pColumnsDefinition;
|
|
30
21
|
var Lang = P.createLanguage({
|
|
31
22
|
AddAction: function AddAction(r) {
|
|
32
23
|
return P.seq(KP.KeywordAdd, r.AddOption.sepBy1(KP.Comma)).map(function (value) {
|
|
@@ -1,17 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var P = require('parsimmon');
|
|
4
|
-
|
|
5
4
|
var KP = require('../../../keyword_parsers');
|
|
6
|
-
|
|
7
5
|
var _require = require('../../../base_parsers'),
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
6
|
+
pDotDelimitedName = _require.pDotDelimitedName,
|
|
7
|
+
pIgnore = _require.pIgnore;
|
|
11
8
|
var A = require('./actions');
|
|
12
|
-
|
|
13
9
|
var pAddAction = require('./add');
|
|
14
|
-
|
|
15
10
|
var Lang = P.createLanguage({
|
|
16
11
|
AlterTable: function AlterTable(r) {
|
|
17
12
|
return P.seqMap(r.AlterTableKeywords, pDotDelimitedName, r.AlterTableActions, A.handleAlterTableResult);
|
|
@@ -3,35 +3,29 @@
|
|
|
3
3
|
var isSchema = function isSchema(type) {
|
|
4
4
|
return type.toLowerCase() === 'schema';
|
|
5
5
|
};
|
|
6
|
-
|
|
7
6
|
var isTable = function isTable(type) {
|
|
8
7
|
return type.toLowerCase() === 'table';
|
|
9
8
|
};
|
|
10
|
-
|
|
11
9
|
var isColumn = function isColumn(type) {
|
|
12
10
|
return type.toLowerCase() === 'column';
|
|
13
11
|
};
|
|
14
|
-
|
|
15
12
|
var isValidTableNote = function isValidTableNote(level) {
|
|
16
13
|
return level.length === 2 && isSchema(level[0].type) && isTable(level[1].type);
|
|
17
14
|
};
|
|
18
|
-
|
|
19
15
|
var isValidColumnNote = function isValidColumnNote(level) {
|
|
20
16
|
return level.length === 3 && isSchema(level[0].type) && isTable(level[1].type) && isColumn(level[2].type);
|
|
21
17
|
};
|
|
22
|
-
|
|
23
18
|
function handleComment(_ref) {
|
|
24
19
|
var note = _ref.note,
|
|
25
|
-
|
|
20
|
+
level = _ref.level;
|
|
26
21
|
var type = 'unsupported';
|
|
27
22
|
var schemaName = null;
|
|
28
23
|
var tableName = null;
|
|
29
24
|
var columnName = null;
|
|
30
|
-
|
|
31
25
|
if (isValidTableNote(level)) {
|
|
32
26
|
schemaName = level[0].name;
|
|
33
|
-
tableName = level[1].name;
|
|
34
|
-
|
|
27
|
+
tableName = level[1].name;
|
|
28
|
+
// Table Comment
|
|
35
29
|
type = 'table';
|
|
36
30
|
} else if (isValidColumnNote(level)) {
|
|
37
31
|
schemaName = level[0].name;
|
|
@@ -39,7 +33,6 @@ function handleComment(_ref) {
|
|
|
39
33
|
columnName = level[2].name;
|
|
40
34
|
type = 'column';
|
|
41
35
|
}
|
|
42
|
-
|
|
43
36
|
return {
|
|
44
37
|
type: 'comment',
|
|
45
38
|
value: {
|
|
@@ -51,7 +44,6 @@ function handleComment(_ref) {
|
|
|
51
44
|
}
|
|
52
45
|
};
|
|
53
46
|
}
|
|
54
|
-
|
|
55
47
|
module.exports = {
|
|
56
48
|
handleComment: handleComment
|
|
57
49
|
};
|
|
@@ -1,26 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
4
|
-
|
|
5
4
|
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
6
|
-
|
|
7
5
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
8
|
-
|
|
9
|
-
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
|
|
10
|
-
|
|
6
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
11
7
|
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
12
|
-
|
|
13
|
-
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
14
|
-
|
|
8
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
15
9
|
var P = require('parsimmon');
|
|
16
|
-
|
|
17
10
|
var KP = require('../../../keyword_parsers');
|
|
18
|
-
|
|
19
11
|
var A = require('./actions');
|
|
20
|
-
|
|
21
12
|
var _require = require('../../../utils'),
|
|
22
|
-
|
|
23
|
-
|
|
13
|
+
makeNode = _require.makeNode;
|
|
24
14
|
var Lang = P.createLanguage({
|
|
25
15
|
StartComment: function StartComment() {
|
|
26
16
|
return P.seq(KP.KeywordExec, KP.KeywordSP_ADDEXTENDEDPROPERTY);
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _require = require('../../../utils'),
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
getFullTableName = _require.getFullTableName;
|
|
6
5
|
function makeIndex(_create, isUnique, _clustered, _index, indexName, _on, tableName, columnNames) {
|
|
7
6
|
var fullTableName = getFullTableName(tableName);
|
|
8
7
|
var columns = [];
|
|
@@ -23,7 +22,6 @@ function makeIndex(_create, isUnique, _clustered, _index, indexName, _on, tableN
|
|
|
23
22
|
}
|
|
24
23
|
};
|
|
25
24
|
}
|
|
26
|
-
|
|
27
25
|
module.exports = {
|
|
28
26
|
makeIndex: makeIndex
|
|
29
27
|
};
|
|
@@ -1,26 +1,20 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var P = require('parsimmon');
|
|
4
|
-
|
|
5
4
|
var KP = require('../../../keyword_parsers');
|
|
6
|
-
|
|
7
5
|
var _require = require('../../../base_parsers'),
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
6
|
+
pIdentifier = _require.pIdentifier,
|
|
7
|
+
pKeywordClusteredOrNon = _require.pKeywordClusteredOrNon,
|
|
8
|
+
pConst = _require.pConst,
|
|
9
|
+
pColumnNames = _require.pColumnNames,
|
|
10
|
+
pDotDelimitedName = _require.pDotDelimitedName,
|
|
11
|
+
pComparsionOp = _require.pComparsionOp;
|
|
15
12
|
var _require2 = require('../../../utils'),
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
13
|
+
makeNode = _require2.makeNode,
|
|
14
|
+
makeList = _require2.makeList;
|
|
19
15
|
var A = require('./actions');
|
|
20
|
-
|
|
21
16
|
var _require3 = require('../../../index_definition'),
|
|
22
|
-
|
|
23
|
-
|
|
17
|
+
pIgnoredIndexOption = _require3.pIgnoredIndexOption;
|
|
24
18
|
var Lang = P.createLanguage({
|
|
25
19
|
CreateIndex: function CreateIndex(r) {
|
|
26
20
|
return P.seqMap(KP.KeywordCreate, KP.KeywordUnique.fallback(null), pKeywordClusteredOrNon.fallback(null), KP.KeywordIndex, pIdentifier, KP.KeywordOn, pDotDelimitedName, pColumnNames, A.makeIndex).thru(makeNode()).skip(r.IgnoredCreateIndexOptions);
|
|
@@ -1,16 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
function
|
|
4
|
-
|
|
5
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]
|
|
6
|
-
|
|
7
|
-
function
|
|
8
|
-
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
5
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
6
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
7
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
8
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
9
9
|
var _ = require('lodash');
|
|
10
|
-
|
|
11
10
|
var _require = require('../../../utils'),
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
getFullTableName = _require.getFullTableName;
|
|
14
12
|
function createRefFromInlineRef(linesRefs, inlineRefs, fieldName, tableName) {
|
|
15
13
|
if (!inlineRefs || inlineRefs.length === 0) return;
|
|
16
14
|
var newRef = {};
|
|
@@ -24,15 +22,12 @@ function createRefFromInlineRef(linesRefs, inlineRefs, fieldName, tableName) {
|
|
|
24
22
|
fieldNames: [fieldName],
|
|
25
23
|
relation: '*'
|
|
26
24
|
});
|
|
27
|
-
|
|
28
25
|
if (!inlineRef.endpoint.fieldNames) {
|
|
29
26
|
inlineRef.endpoint.fieldNames = newRef.endpoints[0].fieldNames;
|
|
30
27
|
}
|
|
31
|
-
|
|
32
28
|
newRef.endpoints.push(inlineRef.endpoint);
|
|
33
29
|
linesRefs.push(newRef);
|
|
34
30
|
}
|
|
35
|
-
|
|
36
31
|
function pushOutEnum(linesEnums, fieldValue, tableName) {
|
|
37
32
|
if (fieldValue.enums) {
|
|
38
33
|
var _enum = fieldValue.enums;
|
|
@@ -46,7 +41,6 @@ function pushOutEnum(linesEnums, fieldValue, tableName) {
|
|
|
46
41
|
fieldValue.enums = null;
|
|
47
42
|
}
|
|
48
43
|
}
|
|
49
|
-
|
|
50
44
|
function pushOutIndex(linesIndexes, fieldValue) {
|
|
51
45
|
if (fieldValue.indexes) {
|
|
52
46
|
fieldValue.indexes.columns.push({
|
|
@@ -57,7 +51,6 @@ function pushOutIndex(linesIndexes, fieldValue) {
|
|
|
57
51
|
fieldValue.indexes = null;
|
|
58
52
|
}
|
|
59
53
|
}
|
|
60
|
-
|
|
61
54
|
function getLinesValue(lines, tableName) {
|
|
62
55
|
var value = {
|
|
63
56
|
fields: [],
|
|
@@ -72,13 +65,11 @@ function getLinesValue(lines, tableName) {
|
|
|
72
65
|
pushOutIndex(value.indexes, line.value);
|
|
73
66
|
createRefFromInlineRef(value.refs, line.value.inline_refs, line.value.name, tableName);
|
|
74
67
|
}
|
|
75
|
-
|
|
76
68
|
if (line.type === 'refs') {
|
|
77
69
|
var ref = line.value;
|
|
78
70
|
ref.endpoints[0].tableName = tableName.name;
|
|
79
71
|
ref.endpoints[0].schemaName = tableName.schemaName;
|
|
80
72
|
}
|
|
81
|
-
|
|
82
73
|
value[line.type].push(line.value);
|
|
83
74
|
}
|
|
84
75
|
});
|
|
@@ -87,7 +78,6 @@ function getLinesValue(lines, tableName) {
|
|
|
87
78
|
value: value
|
|
88
79
|
};
|
|
89
80
|
}
|
|
90
|
-
|
|
91
81
|
function makeTable(_keyword, tableName, _keyword2, lines) {
|
|
92
82
|
var fullName = getFullTableName(tableName);
|
|
93
83
|
var linesValue = getLinesValue(lines, fullName);
|
|
@@ -96,7 +86,6 @@ function makeTable(_keyword, tableName, _keyword2, lines) {
|
|
|
96
86
|
value: _objectSpread(_objectSpread({}, fullName), linesValue.value)
|
|
97
87
|
};
|
|
98
88
|
}
|
|
99
|
-
|
|
100
89
|
module.exports = {
|
|
101
90
|
makeTable: makeTable
|
|
102
91
|
};
|
|
@@ -1,29 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var P = require('parsimmon');
|
|
4
|
-
|
|
5
4
|
var KP = require('../../../keyword_parsers');
|
|
6
|
-
|
|
7
5
|
var _require = require('../../../base_parsers'),
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
6
|
+
pIdentifier = _require.pIdentifier,
|
|
7
|
+
pDotDelimitedName = _require.pDotDelimitedName;
|
|
11
8
|
var _require2 = require('../../../utils'),
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
9
|
+
makeNode = _require2.makeNode,
|
|
10
|
+
makeList = _require2.makeList;
|
|
15
11
|
var _require3 = require('../../../constraint_definition'),
|
|
16
|
-
|
|
17
|
-
|
|
12
|
+
pTableConstraint = _require3.pTableConstraint;
|
|
18
13
|
var _require4 = require('../../../index_definition'),
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
14
|
+
pTableIndex = _require4.pTableIndex,
|
|
15
|
+
pIgnoredIndexOption = _require4.pIgnoredIndexOption;
|
|
22
16
|
var _require5 = require('../../../column_definition'),
|
|
23
|
-
|
|
24
|
-
|
|
17
|
+
pColumnsDefinition = _require5.pColumnsDefinition;
|
|
25
18
|
var A = require('./actions');
|
|
26
|
-
|
|
27
19
|
var Lang = P.createLanguage({
|
|
28
20
|
CreateTable: function CreateTable(r) {
|
|
29
21
|
return P.seqMap(r.CreateTableKeywords, pDotDelimitedName, r.AsFileTableKeywords.fallback(null), makeList(r.Line), A.makeTable).thru(makeNode()).skip(r.IgnoredTableOptions);
|
|
@@ -1,13 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var pAlterTable = require('./alter_table');
|
|
4
|
-
|
|
5
4
|
var pCreateIndex = require('./create_index/index');
|
|
6
|
-
|
|
7
5
|
var pCreateTable = require('./create_table');
|
|
8
|
-
|
|
9
6
|
var pCommentSyntax = require('./comments');
|
|
10
|
-
|
|
11
7
|
module.exports = {
|
|
12
8
|
pAlterTable: pAlterTable,
|
|
13
9
|
pCreateIndex: pCreateIndex,
|
package/lib/parse/mssql/utils.js
CHANGED
|
@@ -1,18 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
function _typeof(obj) { "@babel/helpers - typeof";
|
|
4
|
-
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
5
4
|
var P = require('parsimmon');
|
|
6
|
-
|
|
7
5
|
var _ = require('lodash');
|
|
8
|
-
|
|
9
6
|
var _require = require('./keyword_parsers'),
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
LParen = _require.LParen,
|
|
8
|
+
RParen = _require.RParen,
|
|
9
|
+
Comma = _require.Comma;
|
|
14
10
|
var wss = require('./whitespaces');
|
|
15
|
-
|
|
16
11
|
exports.makeNode = function () {
|
|
17
12
|
return function (parser) {
|
|
18
13
|
return P.seqMap(P.index, parser, P.index, function (start, value, end) {
|
|
@@ -28,7 +23,6 @@ exports.makeNode = function () {
|
|
|
28
23
|
}).skip(wss);
|
|
29
24
|
};
|
|
30
25
|
};
|
|
31
|
-
|
|
32
26
|
exports.makeList = function (parser) {
|
|
33
27
|
var isZero = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
34
28
|
var seperator = parser.sepBy1(Comma);
|
|
@@ -37,7 +31,6 @@ exports.makeList = function (parser) {
|
|
|
37
31
|
return value[1];
|
|
38
32
|
});
|
|
39
33
|
};
|
|
40
|
-
|
|
41
34
|
exports.streamline = function (type) {
|
|
42
35
|
return function (parser) {
|
|
43
36
|
return parser.skip(wss).map(function (value) {
|
|
@@ -50,14 +43,11 @@ exports.streamline = function (type) {
|
|
|
50
43
|
});
|
|
51
44
|
};
|
|
52
45
|
};
|
|
53
|
-
|
|
54
46
|
exports.getFullTableName = function (nameList) {
|
|
55
47
|
var schemaName = null;
|
|
56
|
-
|
|
57
48
|
if (nameList.length > 1) {
|
|
58
49
|
schemaName = nameList[nameList.length - 2];
|
|
59
50
|
}
|
|
60
|
-
|
|
61
51
|
return {
|
|
62
52
|
name: _.last(nameList),
|
|
63
53
|
schemaName: schemaName
|
package/lib/parse/mssqlParser.js
CHANGED
|
@@ -4,10 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports["default"] = void 0;
|
|
7
|
-
|
|
8
7
|
var _mssql = _interopRequireDefault(require("./mssql"));
|
|
9
|
-
|
|
10
8
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
-
|
|
12
9
|
var _default = _mssql["default"];
|
|
13
10
|
exports["default"] = _default;
|