utils.cjs 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. "use strict";
  2. var __defProp = Object.defineProperty;
  3. var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
  4. var __getOwnPropNames = Object.getOwnPropertyNames;
  5. var __hasOwnProp = Object.prototype.hasOwnProperty;
  6. var __export = (target, all) => {
  7. for (var name in all)
  8. __defProp(target, name, { get: all[name], enumerable: true });
  9. };
  10. var __copyProps = (to, from, except, desc) => {
  11. if (from && typeof from === "object" || typeof from === "function") {
  12. for (let key of __getOwnPropNames(from))
  13. if (!__hasOwnProp.call(to, key) && key !== except)
  14. __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
  15. }
  16. return to;
  17. };
  18. var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
  19. var utils_exports = {};
  20. __export(utils_exports, {
  21. extractUsedTable: () => extractUsedTable,
  22. getTableConfig: () => getTableConfig,
  23. getViewConfig: () => getViewConfig
  24. });
  25. module.exports = __toCommonJS(utils_exports);
  26. var import_entity = require("../entity.cjs");
  27. var import_sql = require("../sql/sql.cjs");
  28. var import_subquery = require("../subquery.cjs");
  29. var import_table = require("../table.cjs");
  30. var import_view_common = require("../view-common.cjs");
  31. var import_checks = require("./checks.cjs");
  32. var import_foreign_keys = require("./foreign-keys.cjs");
  33. var import_indexes = require("./indexes.cjs");
  34. var import_primary_keys = require("./primary-keys.cjs");
  35. var import_table2 = require("./table.cjs");
  36. var import_unique_constraint = require("./unique-constraint.cjs");
  37. function getTableConfig(table) {
  38. const columns = Object.values(table[import_table2.SQLiteTable.Symbol.Columns]);
  39. const indexes = [];
  40. const checks = [];
  41. const primaryKeys = [];
  42. const uniqueConstraints = [];
  43. const foreignKeys = Object.values(table[import_table2.SQLiteTable.Symbol.InlineForeignKeys]);
  44. const name = table[import_table.Table.Symbol.Name];
  45. const extraConfigBuilder = table[import_table2.SQLiteTable.Symbol.ExtraConfigBuilder];
  46. if (extraConfigBuilder !== void 0) {
  47. const extraConfig = extraConfigBuilder(table[import_table2.SQLiteTable.Symbol.Columns]);
  48. const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);
  49. for (const builder of Object.values(extraValues)) {
  50. if ((0, import_entity.is)(builder, import_indexes.IndexBuilder)) {
  51. indexes.push(builder.build(table));
  52. } else if ((0, import_entity.is)(builder, import_checks.CheckBuilder)) {
  53. checks.push(builder.build(table));
  54. } else if ((0, import_entity.is)(builder, import_unique_constraint.UniqueConstraintBuilder)) {
  55. uniqueConstraints.push(builder.build(table));
  56. } else if ((0, import_entity.is)(builder, import_primary_keys.PrimaryKeyBuilder)) {
  57. primaryKeys.push(builder.build(table));
  58. } else if ((0, import_entity.is)(builder, import_foreign_keys.ForeignKeyBuilder)) {
  59. foreignKeys.push(builder.build(table));
  60. }
  61. }
  62. }
  63. return {
  64. columns,
  65. indexes,
  66. foreignKeys,
  67. checks,
  68. primaryKeys,
  69. uniqueConstraints,
  70. name
  71. };
  72. }
  73. function extractUsedTable(table) {
  74. if ((0, import_entity.is)(table, import_table2.SQLiteTable)) {
  75. return [`${table[import_table.Table.Symbol.BaseName]}`];
  76. }
  77. if ((0, import_entity.is)(table, import_subquery.Subquery)) {
  78. return table._.usedTables ?? [];
  79. }
  80. if ((0, import_entity.is)(table, import_sql.SQL)) {
  81. return table.usedTables ?? [];
  82. }
  83. return [];
  84. }
  85. function getViewConfig(view) {
  86. return {
  87. ...view[import_view_common.ViewBaseConfig]
  88. // ...view[SQLiteViewConfig],
  89. };
  90. }
  91. // Annotate the CommonJS export names for ESM import in node:
  92. 0 && (module.exports = {
  93. extractUsedTable,
  94. getTableConfig,
  95. getViewConfig
  96. });
  97. //# sourceMappingURL=utils.cjs.map