@supabase/pg-delta 1.0.0-alpha.2 → 1.0.0-alpha.21

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.
Files changed (935) hide show
  1. package/README.md +48 -3
  2. package/dist/cli/app.js +26 -3
  3. package/dist/cli/bin/cli.js +5 -0
  4. package/dist/cli/commands/catalog-export.d.ts +5 -0
  5. package/dist/cli/commands/catalog-export.js +64 -0
  6. package/dist/cli/commands/declarative-apply.d.ts +6 -0
  7. package/dist/cli/commands/declarative-apply.js +288 -0
  8. package/dist/cli/commands/declarative-export.d.ts +5 -0
  9. package/dist/cli/commands/declarative-export.js +240 -0
  10. package/dist/cli/commands/plan.js +47 -16
  11. package/dist/cli/commands/sync.js +8 -12
  12. package/dist/cli/exit-code.d.ts +2 -0
  13. package/dist/cli/exit-code.js +7 -0
  14. package/dist/cli/formatters/tree/tree.js +3 -2
  15. package/dist/cli/utils/apply-display.d.ts +52 -0
  16. package/dist/cli/utils/apply-display.js +183 -0
  17. package/dist/cli/utils/export-display.d.ts +43 -0
  18. package/dist/cli/utils/export-display.js +202 -0
  19. package/dist/cli/utils/integrations.d.ts +30 -6
  20. package/dist/cli/utils/integrations.js +98 -6
  21. package/dist/cli/utils/resolve-input.d.ts +7 -0
  22. package/dist/cli/utils/resolve-input.js +13 -0
  23. package/dist/cli/utils.d.ts +2 -0
  24. package/dist/cli/utils.js +1 -1
  25. package/dist/core/catalog-export/index.d.ts +11 -0
  26. package/dist/core/catalog-export/index.js +10 -0
  27. package/dist/core/catalog.diff.d.ts +1 -0
  28. package/dist/core/catalog.diff.js +70 -49
  29. package/dist/core/catalog.model.d.ts +14 -1
  30. package/dist/core/catalog.model.js +103 -1
  31. package/dist/core/catalog.snapshot.d.ts +66 -0
  32. package/dist/core/catalog.snapshot.js +206 -0
  33. package/dist/core/change-utils.d.ts +9 -0
  34. package/dist/core/change-utils.js +71 -0
  35. package/dist/core/change.types.d.ts +22 -0
  36. package/dist/core/change.types.js +37 -1
  37. package/dist/core/connection-url.d.ts +32 -0
  38. package/dist/core/connection-url.js +77 -0
  39. package/dist/core/declarative-apply/discover-sql.d.ts +18 -0
  40. package/dist/core/declarative-apply/discover-sql.js +86 -0
  41. package/dist/core/declarative-apply/extract-catalog-providers.d.ts +23 -0
  42. package/dist/core/declarative-apply/extract-catalog-providers.js +159 -0
  43. package/dist/core/declarative-apply/index.d.ts +49 -0
  44. package/dist/core/declarative-apply/index.js +134 -0
  45. package/dist/core/declarative-apply/round-apply.d.ts +100 -0
  46. package/dist/core/declarative-apply/round-apply.js +378 -0
  47. package/dist/core/depend.js +25 -0
  48. package/dist/core/expand-replace-dependencies.d.ts +8 -2
  49. package/dist/core/expand-replace-dependencies.js +116 -10
  50. package/dist/core/export/file-mapper.d.ts +71 -0
  51. package/dist/core/export/file-mapper.js +474 -0
  52. package/dist/core/export/grouper.d.ts +13 -0
  53. package/dist/core/export/grouper.js +76 -0
  54. package/dist/core/export/index.d.ts +45 -0
  55. package/dist/core/export/index.js +66 -0
  56. package/dist/core/export/types.d.ts +84 -0
  57. package/dist/core/export/types.js +25 -0
  58. package/dist/core/fixtures/empty-catalogs/postgres-15-16-baseline.json +287 -0
  59. package/dist/core/integrations/filter/dsl.d.ts +82 -41
  60. package/dist/core/integrations/filter/dsl.js +127 -61
  61. package/dist/core/integrations/filter/flatten.d.ts +51 -0
  62. package/dist/core/integrations/filter/flatten.js +116 -0
  63. package/dist/core/integrations/integration-dsl.d.ts +27 -1
  64. package/dist/core/integrations/integration.types.d.ts +26 -1
  65. package/dist/core/integrations/integration.types.js +31 -1
  66. package/dist/core/integrations/merge.d.ts +20 -0
  67. package/dist/core/integrations/merge.js +60 -0
  68. package/dist/core/integrations/serialize/dsl.d.ts +8 -12
  69. package/dist/core/integrations/serialize/dsl.js +2 -2
  70. package/dist/core/integrations/serialize/serialize.types.d.ts +31 -0
  71. package/dist/core/integrations/supabase.d.ts +8 -0
  72. package/dist/core/integrations/supabase.js +69 -8
  73. package/dist/core/objects/aggregate/aggregate.diff.d.ts +2 -8
  74. package/dist/core/objects/aggregate/aggregate.diff.js +16 -70
  75. package/dist/core/objects/aggregate/aggregate.model.d.ts +8 -8
  76. package/dist/core/objects/aggregate/aggregate.model.js +1 -1
  77. package/dist/core/objects/aggregate/changes/aggregate.alter.d.ts +2 -1
  78. package/dist/core/objects/aggregate/changes/aggregate.alter.js +1 -1
  79. package/dist/core/objects/aggregate/changes/aggregate.comment.d.ts +3 -2
  80. package/dist/core/objects/aggregate/changes/aggregate.comment.js +2 -2
  81. package/dist/core/objects/aggregate/changes/aggregate.create.d.ts +2 -1
  82. package/dist/core/objects/aggregate/changes/aggregate.create.js +2 -2
  83. package/dist/core/objects/aggregate/changes/aggregate.drop.d.ts +2 -1
  84. package/dist/core/objects/aggregate/changes/aggregate.drop.js +2 -2
  85. package/dist/core/objects/aggregate/changes/aggregate.privilege.d.ts +4 -3
  86. package/dist/core/objects/aggregate/changes/aggregate.privilege.js +3 -3
  87. package/dist/core/objects/aggregate/changes/aggregate.types.d.ts +1 -0
  88. package/dist/core/objects/base.change.d.ts +12 -1
  89. package/dist/core/objects/base.change.js +10 -0
  90. package/dist/core/objects/base.model.d.ts +4 -1
  91. package/dist/core/objects/base.model.js +5 -2
  92. package/dist/core/objects/base.privilege-diff.d.ts +38 -13
  93. package/dist/core/objects/base.privilege-diff.js +104 -22
  94. package/dist/core/objects/base.privilege.d.ts +1 -0
  95. package/dist/core/objects/base.privilege.js +9 -2
  96. package/dist/core/objects/collation/changes/collation.alter.d.ts +3 -2
  97. package/dist/core/objects/collation/changes/collation.alter.js +2 -2
  98. package/dist/core/objects/collation/changes/collation.comment.d.ts +3 -2
  99. package/dist/core/objects/collation/changes/collation.comment.js +2 -2
  100. package/dist/core/objects/collation/changes/collation.create.d.ts +2 -1
  101. package/dist/core/objects/collation/changes/collation.create.js +1 -1
  102. package/dist/core/objects/collation/changes/collation.drop.d.ts +2 -1
  103. package/dist/core/objects/collation/changes/collation.drop.js +1 -1
  104. package/dist/core/objects/collation/changes/collation.types.d.ts +1 -0
  105. package/dist/core/objects/collation/collation.diff.d.ts +2 -3
  106. package/dist/core/objects/diff-context.d.ts +15 -0
  107. package/dist/core/objects/diff-context.js +1 -0
  108. package/dist/core/objects/domain/changes/domain.alter.d.ts +9 -8
  109. package/dist/core/objects/domain/changes/domain.alter.js +8 -8
  110. package/dist/core/objects/domain/changes/domain.comment.d.ts +3 -2
  111. package/dist/core/objects/domain/changes/domain.comment.js +2 -2
  112. package/dist/core/objects/domain/changes/domain.create.d.ts +3 -2
  113. package/dist/core/objects/domain/changes/domain.create.js +12 -4
  114. package/dist/core/objects/domain/changes/domain.drop.d.ts +2 -1
  115. package/dist/core/objects/domain/changes/domain.drop.js +1 -1
  116. package/dist/core/objects/domain/changes/domain.privilege.d.ts +4 -3
  117. package/dist/core/objects/domain/changes/domain.privilege.js +3 -3
  118. package/dist/core/objects/domain/changes/domain.types.d.ts +1 -0
  119. package/dist/core/objects/domain/domain.diff.d.ts +2 -8
  120. package/dist/core/objects/domain/domain.diff.js +16 -77
  121. package/dist/core/objects/domain/domain.model.js +1 -1
  122. package/dist/core/objects/event-trigger/changes/event-trigger.alter.d.ts +3 -2
  123. package/dist/core/objects/event-trigger/changes/event-trigger.alter.js +2 -2
  124. package/dist/core/objects/event-trigger/changes/event-trigger.comment.d.ts +3 -2
  125. package/dist/core/objects/event-trigger/changes/event-trigger.comment.js +2 -2
  126. package/dist/core/objects/event-trigger/changes/event-trigger.create.d.ts +2 -1
  127. package/dist/core/objects/event-trigger/changes/event-trigger.create.js +1 -1
  128. package/dist/core/objects/event-trigger/changes/event-trigger.drop.d.ts +2 -1
  129. package/dist/core/objects/event-trigger/changes/event-trigger.drop.js +1 -1
  130. package/dist/core/objects/event-trigger/changes/event-trigger.types.d.ts +1 -0
  131. package/dist/core/objects/event-trigger/event-trigger.diff.d.ts +2 -3
  132. package/dist/core/objects/extension/changes/extension.alter.d.ts +3 -2
  133. package/dist/core/objects/extension/changes/extension.alter.js +2 -2
  134. package/dist/core/objects/extension/changes/extension.comment.d.ts +3 -2
  135. package/dist/core/objects/extension/changes/extension.comment.js +2 -2
  136. package/dist/core/objects/extension/changes/extension.create.d.ts +2 -1
  137. package/dist/core/objects/extension/changes/extension.create.js +4 -2
  138. package/dist/core/objects/extension/changes/extension.drop.d.ts +2 -1
  139. package/dist/core/objects/extension/changes/extension.drop.js +1 -1
  140. package/dist/core/objects/extension/changes/extension.types.d.ts +1 -0
  141. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.alter.d.ts +3 -2
  142. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.alter.js +2 -2
  143. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.comment.d.ts +3 -2
  144. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.comment.js +2 -2
  145. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.create.d.ts +2 -1
  146. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.create.js +1 -1
  147. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.drop.d.ts +2 -1
  148. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.drop.js +1 -1
  149. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.privilege.d.ts +4 -3
  150. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.privilege.js +3 -3
  151. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.types.d.ts +1 -0
  152. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/foreign-data-wrapper.diff.d.ts +2 -8
  153. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/foreign-data-wrapper.diff.js +13 -77
  154. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper/foreign-data-wrapper.model.js +2 -2
  155. package/dist/core/objects/foreign-data-wrapper/foreign-data-wrapper.types.d.ts +1 -0
  156. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.alter.d.ts +10 -9
  157. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.alter.js +9 -9
  158. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.comment.d.ts +3 -2
  159. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.comment.js +2 -2
  160. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.create.d.ts +2 -1
  161. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.create.js +1 -1
  162. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.drop.d.ts +2 -1
  163. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.drop.js +1 -1
  164. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.privilege.d.ts +4 -3
  165. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.privilege.js +3 -3
  166. package/dist/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.types.d.ts +1 -0
  167. package/dist/core/objects/foreign-data-wrapper/foreign-table/foreign-table.diff.d.ts +2 -8
  168. package/dist/core/objects/foreign-data-wrapper/foreign-table/foreign-table.diff.js +16 -77
  169. package/dist/core/objects/foreign-data-wrapper/foreign-table/foreign-table.model.js +1 -1
  170. package/dist/core/objects/foreign-data-wrapper/server/changes/server.alter.d.ts +4 -3
  171. package/dist/core/objects/foreign-data-wrapper/server/changes/server.alter.js +3 -3
  172. package/dist/core/objects/foreign-data-wrapper/server/changes/server.comment.d.ts +3 -2
  173. package/dist/core/objects/foreign-data-wrapper/server/changes/server.comment.js +2 -2
  174. package/dist/core/objects/foreign-data-wrapper/server/changes/server.create.d.ts +2 -1
  175. package/dist/core/objects/foreign-data-wrapper/server/changes/server.create.js +1 -1
  176. package/dist/core/objects/foreign-data-wrapper/server/changes/server.drop.d.ts +2 -1
  177. package/dist/core/objects/foreign-data-wrapper/server/changes/server.drop.js +1 -1
  178. package/dist/core/objects/foreign-data-wrapper/server/changes/server.privilege.d.ts +4 -3
  179. package/dist/core/objects/foreign-data-wrapper/server/changes/server.privilege.js +3 -3
  180. package/dist/core/objects/foreign-data-wrapper/server/changes/server.types.d.ts +1 -0
  181. package/dist/core/objects/foreign-data-wrapper/server/server.diff.d.ts +2 -8
  182. package/dist/core/objects/foreign-data-wrapper/server/server.diff.js +13 -77
  183. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.alter.d.ts +2 -1
  184. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.alter.js +1 -1
  185. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.create.d.ts +2 -1
  186. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.create.js +1 -1
  187. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.drop.d.ts +2 -1
  188. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.drop.js +1 -1
  189. package/dist/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.types.d.ts +1 -0
  190. package/dist/core/objects/index/changes/index.alter.d.ts +4 -3
  191. package/dist/core/objects/index/changes/index.alter.js +3 -3
  192. package/dist/core/objects/index/changes/index.comment.d.ts +3 -2
  193. package/dist/core/objects/index/changes/index.comment.js +2 -2
  194. package/dist/core/objects/index/changes/index.create.d.ts +2 -1
  195. package/dist/core/objects/index/changes/index.create.js +1 -1
  196. package/dist/core/objects/index/changes/index.drop.d.ts +2 -1
  197. package/dist/core/objects/index/changes/index.drop.js +1 -1
  198. package/dist/core/objects/index/changes/index.types.d.ts +1 -0
  199. package/dist/core/objects/index/index.model.js +12 -2
  200. package/dist/core/objects/language/changes/language.alter.d.ts +2 -1
  201. package/dist/core/objects/language/changes/language.alter.js +1 -1
  202. package/dist/core/objects/language/changes/language.comment.d.ts +3 -2
  203. package/dist/core/objects/language/changes/language.comment.js +2 -2
  204. package/dist/core/objects/language/changes/language.create.d.ts +2 -1
  205. package/dist/core/objects/language/changes/language.create.js +1 -1
  206. package/dist/core/objects/language/changes/language.drop.d.ts +2 -1
  207. package/dist/core/objects/language/changes/language.drop.js +1 -1
  208. package/dist/core/objects/language/changes/language.privilege.d.ts +4 -3
  209. package/dist/core/objects/language/changes/language.privilege.js +3 -3
  210. package/dist/core/objects/language/changes/language.types.d.ts +1 -0
  211. package/dist/core/objects/language/language.diff.d.ts +2 -5
  212. package/dist/core/objects/language/language.diff.js +7 -39
  213. package/dist/core/objects/materialized-view/changes/materialized-view.alter.d.ts +3 -2
  214. package/dist/core/objects/materialized-view/changes/materialized-view.alter.js +2 -2
  215. package/dist/core/objects/materialized-view/changes/materialized-view.comment.d.ts +5 -4
  216. package/dist/core/objects/materialized-view/changes/materialized-view.comment.js +4 -4
  217. package/dist/core/objects/materialized-view/changes/materialized-view.create.d.ts +2 -1
  218. package/dist/core/objects/materialized-view/changes/materialized-view.create.js +1 -1
  219. package/dist/core/objects/materialized-view/changes/materialized-view.drop.d.ts +2 -1
  220. package/dist/core/objects/materialized-view/changes/materialized-view.drop.js +1 -1
  221. package/dist/core/objects/materialized-view/changes/materialized-view.privilege.d.ts +4 -3
  222. package/dist/core/objects/materialized-view/changes/materialized-view.privilege.js +3 -3
  223. package/dist/core/objects/materialized-view/changes/materialized-view.types.d.ts +1 -0
  224. package/dist/core/objects/materialized-view/materialized-view.diff.d.ts +2 -8
  225. package/dist/core/objects/materialized-view/materialized-view.diff.js +16 -158
  226. package/dist/core/objects/materialized-view/materialized-view.model.d.ts +3 -3
  227. package/dist/core/objects/materialized-view/materialized-view.model.js +1 -1
  228. package/dist/core/objects/procedure/changes/procedure.alter.d.ts +8 -7
  229. package/dist/core/objects/procedure/changes/procedure.alter.js +19 -19
  230. package/dist/core/objects/procedure/changes/procedure.comment.d.ts +3 -2
  231. package/dist/core/objects/procedure/changes/procedure.comment.js +2 -2
  232. package/dist/core/objects/procedure/changes/procedure.create.d.ts +2 -1
  233. package/dist/core/objects/procedure/changes/procedure.create.js +1 -1
  234. package/dist/core/objects/procedure/changes/procedure.drop.d.ts +2 -1
  235. package/dist/core/objects/procedure/changes/procedure.drop.js +1 -1
  236. package/dist/core/objects/procedure/changes/procedure.privilege.d.ts +4 -3
  237. package/dist/core/objects/procedure/changes/procedure.privilege.js +3 -3
  238. package/dist/core/objects/procedure/changes/procedure.types.d.ts +1 -0
  239. package/dist/core/objects/procedure/procedure.diff.d.ts +2 -8
  240. package/dist/core/objects/procedure/procedure.diff.js +57 -97
  241. package/dist/core/objects/procedure/procedure.model.d.ts +9 -9
  242. package/dist/core/objects/procedure/procedure.model.js +1 -1
  243. package/dist/core/objects/publication/changes/publication.alter.d.ts +10 -17
  244. package/dist/core/objects/publication/changes/publication.alter.js +12 -21
  245. package/dist/core/objects/publication/changes/publication.comment.d.ts +3 -2
  246. package/dist/core/objects/publication/changes/publication.comment.js +2 -2
  247. package/dist/core/objects/publication/changes/publication.create.d.ts +2 -1
  248. package/dist/core/objects/publication/changes/publication.create.js +1 -1
  249. package/dist/core/objects/publication/changes/publication.drop.d.ts +2 -1
  250. package/dist/core/objects/publication/changes/publication.drop.js +1 -1
  251. package/dist/core/objects/publication/changes/publication.types.d.ts +3 -2
  252. package/dist/core/objects/publication/publication.diff.d.ts +2 -3
  253. package/dist/core/objects/publication/publication.diff.js +8 -13
  254. package/dist/core/objects/rls-policy/changes/rls-policy.alter.d.ts +4 -3
  255. package/dist/core/objects/rls-policy/changes/rls-policy.alter.js +6 -6
  256. package/dist/core/objects/rls-policy/changes/rls-policy.comment.d.ts +3 -2
  257. package/dist/core/objects/rls-policy/changes/rls-policy.comment.js +2 -2
  258. package/dist/core/objects/rls-policy/changes/rls-policy.create.d.ts +2 -1
  259. package/dist/core/objects/rls-policy/changes/rls-policy.create.js +24 -1
  260. package/dist/core/objects/rls-policy/changes/rls-policy.drop.d.ts +2 -1
  261. package/dist/core/objects/rls-policy/changes/rls-policy.drop.js +1 -1
  262. package/dist/core/objects/rls-policy/changes/rls-policy.types.d.ts +1 -0
  263. package/dist/core/objects/rls-policy/rls-policy.model.d.ts +51 -2
  264. package/dist/core/objects/rls-policy/rls-policy.model.js +122 -1
  265. package/dist/core/objects/role/changes/role.alter.d.ts +3 -2
  266. package/dist/core/objects/role/changes/role.alter.js +2 -2
  267. package/dist/core/objects/role/changes/role.comment.d.ts +3 -2
  268. package/dist/core/objects/role/changes/role.comment.js +2 -2
  269. package/dist/core/objects/role/changes/role.create.d.ts +2 -1
  270. package/dist/core/objects/role/changes/role.create.js +1 -1
  271. package/dist/core/objects/role/changes/role.drop.d.ts +2 -1
  272. package/dist/core/objects/role/changes/role.drop.js +1 -1
  273. package/dist/core/objects/role/changes/role.privilege.d.ts +6 -5
  274. package/dist/core/objects/role/changes/role.privilege.js +5 -5
  275. package/dist/core/objects/role/changes/role.types.d.ts +1 -0
  276. package/dist/core/objects/role/role.diff.js +22 -1
  277. package/dist/core/objects/role/role.model.d.ts +4 -3
  278. package/dist/core/objects/role/role.model.js +118 -12
  279. package/dist/core/objects/rule/changes/rule.alter.d.ts +3 -2
  280. package/dist/core/objects/rule/changes/rule.alter.js +2 -2
  281. package/dist/core/objects/rule/changes/rule.comment.d.ts +3 -2
  282. package/dist/core/objects/rule/changes/rule.comment.js +2 -2
  283. package/dist/core/objects/rule/changes/rule.create.d.ts +2 -1
  284. package/dist/core/objects/rule/changes/rule.create.js +1 -1
  285. package/dist/core/objects/rule/changes/rule.drop.d.ts +2 -1
  286. package/dist/core/objects/rule/changes/rule.drop.js +1 -1
  287. package/dist/core/objects/rule/changes/rule.types.d.ts +1 -0
  288. package/dist/core/objects/rule/rule.model.d.ts +1 -1
  289. package/dist/core/objects/schema/changes/schema.alter.d.ts +2 -1
  290. package/dist/core/objects/schema/changes/schema.alter.js +1 -1
  291. package/dist/core/objects/schema/changes/schema.comment.d.ts +3 -2
  292. package/dist/core/objects/schema/changes/schema.comment.js +2 -2
  293. package/dist/core/objects/schema/changes/schema.create.d.ts +3 -5
  294. package/dist/core/objects/schema/changes/schema.drop.d.ts +2 -1
  295. package/dist/core/objects/schema/changes/schema.drop.js +1 -1
  296. package/dist/core/objects/schema/changes/schema.privilege.d.ts +4 -3
  297. package/dist/core/objects/schema/changes/schema.privilege.js +3 -3
  298. package/dist/core/objects/schema/changes/schema.types.d.ts +1 -0
  299. package/dist/core/objects/schema/schema.diff.d.ts +2 -8
  300. package/dist/core/objects/schema/schema.diff.js +16 -77
  301. package/dist/core/objects/schema/schema.model.js +1 -1
  302. package/dist/core/objects/sequence/changes/sequence.alter.d.ts +3 -2
  303. package/dist/core/objects/sequence/changes/sequence.alter.js +2 -2
  304. package/dist/core/objects/sequence/changes/sequence.comment.d.ts +3 -2
  305. package/dist/core/objects/sequence/changes/sequence.comment.js +2 -2
  306. package/dist/core/objects/sequence/changes/sequence.create.d.ts +2 -1
  307. package/dist/core/objects/sequence/changes/sequence.create.js +1 -1
  308. package/dist/core/objects/sequence/changes/sequence.drop.d.ts +2 -1
  309. package/dist/core/objects/sequence/changes/sequence.drop.js +11 -3
  310. package/dist/core/objects/sequence/changes/sequence.privilege.d.ts +4 -3
  311. package/dist/core/objects/sequence/changes/sequence.privilege.js +3 -3
  312. package/dist/core/objects/sequence/changes/sequence.types.d.ts +1 -0
  313. package/dist/core/objects/sequence/sequence.diff.d.ts +5 -8
  314. package/dist/core/objects/sequence/sequence.diff.js +55 -90
  315. package/dist/core/objects/sequence/sequence.model.js +1 -1
  316. package/dist/core/objects/subscription/changes/subscription.alter.d.ts +7 -6
  317. package/dist/core/objects/subscription/changes/subscription.alter.js +6 -6
  318. package/dist/core/objects/subscription/changes/subscription.comment.d.ts +3 -2
  319. package/dist/core/objects/subscription/changes/subscription.comment.js +2 -2
  320. package/dist/core/objects/subscription/changes/subscription.create.d.ts +2 -1
  321. package/dist/core/objects/subscription/changes/subscription.create.js +1 -1
  322. package/dist/core/objects/subscription/changes/subscription.drop.d.ts +2 -1
  323. package/dist/core/objects/subscription/changes/subscription.drop.js +1 -1
  324. package/dist/core/objects/subscription/changes/subscription.types.d.ts +1 -0
  325. package/dist/core/objects/subscription/subscription.diff.d.ts +2 -3
  326. package/dist/core/objects/table/changes/table.alter.d.ts +69 -22
  327. package/dist/core/objects/table/changes/table.alter.js +130 -27
  328. package/dist/core/objects/table/changes/table.comment.d.ts +7 -6
  329. package/dist/core/objects/table/changes/table.comment.js +6 -6
  330. package/dist/core/objects/table/changes/table.create.d.ts +2 -1
  331. package/dist/core/objects/table/changes/table.create.js +4 -1
  332. package/dist/core/objects/table/changes/table.drop.d.ts +16 -3
  333. package/dist/core/objects/table/changes/table.drop.js +24 -1
  334. package/dist/core/objects/table/changes/table.privilege.d.ts +4 -3
  335. package/dist/core/objects/table/changes/table.privilege.js +3 -3
  336. package/dist/core/objects/table/changes/table.types.d.ts +1 -0
  337. package/dist/core/objects/table/table.diff.d.ts +2 -8
  338. package/dist/core/objects/table/table.diff.js +101 -162
  339. package/dist/core/objects/table/table.model.d.ts +29 -22
  340. package/dist/core/objects/table/table.model.js +16 -8
  341. package/dist/core/objects/trigger/changes/trigger.alter.d.ts +2 -1
  342. package/dist/core/objects/trigger/changes/trigger.alter.js +24 -1
  343. package/dist/core/objects/trigger/changes/trigger.comment.d.ts +3 -2
  344. package/dist/core/objects/trigger/changes/trigger.comment.js +2 -2
  345. package/dist/core/objects/trigger/changes/trigger.create.d.ts +2 -1
  346. package/dist/core/objects/trigger/changes/trigger.create.js +5 -6
  347. package/dist/core/objects/trigger/changes/trigger.drop.d.ts +2 -1
  348. package/dist/core/objects/trigger/changes/trigger.drop.js +1 -1
  349. package/dist/core/objects/trigger/changes/trigger.types.d.ts +1 -0
  350. package/dist/core/objects/trigger/trigger.diff.js +7 -2
  351. package/dist/core/objects/trigger/trigger.model.d.ts +10 -1
  352. package/dist/core/objects/trigger/trigger.model.js +19 -1
  353. package/dist/core/objects/type/composite-type/changes/composite-type.alter.d.ts +5 -4
  354. package/dist/core/objects/type/composite-type/changes/composite-type.alter.js +4 -4
  355. package/dist/core/objects/type/composite-type/changes/composite-type.comment.d.ts +5 -4
  356. package/dist/core/objects/type/composite-type/changes/composite-type.comment.js +4 -4
  357. package/dist/core/objects/type/composite-type/changes/composite-type.create.d.ts +2 -1
  358. package/dist/core/objects/type/composite-type/changes/composite-type.create.js +1 -1
  359. package/dist/core/objects/type/composite-type/changes/composite-type.drop.d.ts +2 -1
  360. package/dist/core/objects/type/composite-type/changes/composite-type.drop.js +1 -1
  361. package/dist/core/objects/type/composite-type/changes/composite-type.privilege.d.ts +4 -3
  362. package/dist/core/objects/type/composite-type/changes/composite-type.privilege.js +3 -3
  363. package/dist/core/objects/type/composite-type/changes/composite-type.types.d.ts +1 -0
  364. package/dist/core/objects/type/composite-type/composite-type.diff.d.ts +2 -8
  365. package/dist/core/objects/type/composite-type/composite-type.diff.js +16 -77
  366. package/dist/core/objects/type/composite-type/composite-type.model.d.ts +3 -3
  367. package/dist/core/objects/type/composite-type/composite-type.model.js +2 -1
  368. package/dist/core/objects/type/enum/changes/enum.alter.d.ts +3 -2
  369. package/dist/core/objects/type/enum/changes/enum.alter.js +2 -2
  370. package/dist/core/objects/type/enum/changes/enum.comment.d.ts +3 -2
  371. package/dist/core/objects/type/enum/changes/enum.comment.js +2 -2
  372. package/dist/core/objects/type/enum/changes/enum.create.d.ts +2 -1
  373. package/dist/core/objects/type/enum/changes/enum.create.js +1 -1
  374. package/dist/core/objects/type/enum/changes/enum.drop.d.ts +2 -1
  375. package/dist/core/objects/type/enum/changes/enum.drop.js +1 -1
  376. package/dist/core/objects/type/enum/changes/enum.privilege.d.ts +4 -3
  377. package/dist/core/objects/type/enum/changes/enum.privilege.js +3 -3
  378. package/dist/core/objects/type/enum/changes/enum.types.d.ts +1 -0
  379. package/dist/core/objects/type/enum/enum.diff.d.ts +2 -8
  380. package/dist/core/objects/type/enum/enum.diff.js +25 -112
  381. package/dist/core/objects/type/enum/enum.model.js +1 -1
  382. package/dist/core/objects/type/range/changes/range.alter.d.ts +2 -1
  383. package/dist/core/objects/type/range/changes/range.alter.js +1 -1
  384. package/dist/core/objects/type/range/changes/range.comment.d.ts +3 -2
  385. package/dist/core/objects/type/range/changes/range.comment.js +2 -2
  386. package/dist/core/objects/type/range/changes/range.create.d.ts +2 -1
  387. package/dist/core/objects/type/range/changes/range.create.js +7 -4
  388. package/dist/core/objects/type/range/changes/range.drop.d.ts +2 -1
  389. package/dist/core/objects/type/range/changes/range.drop.js +1 -1
  390. package/dist/core/objects/type/range/changes/range.privilege.d.ts +4 -3
  391. package/dist/core/objects/type/range/changes/range.privilege.js +3 -3
  392. package/dist/core/objects/type/range/changes/range.types.d.ts +1 -0
  393. package/dist/core/objects/type/range/range.diff.d.ts +2 -8
  394. package/dist/core/objects/type/range/range.diff.js +16 -77
  395. package/dist/core/objects/type/range/range.model.js +1 -1
  396. package/dist/core/objects/type/type.types.d.ts +1 -0
  397. package/dist/core/objects/view/changes/view.alter.d.ts +4 -3
  398. package/dist/core/objects/view/changes/view.alter.js +3 -3
  399. package/dist/core/objects/view/changes/view.comment.d.ts +3 -2
  400. package/dist/core/objects/view/changes/view.comment.js +2 -2
  401. package/dist/core/objects/view/changes/view.create.d.ts +2 -1
  402. package/dist/core/objects/view/changes/view.create.js +1 -1
  403. package/dist/core/objects/view/changes/view.drop.d.ts +2 -1
  404. package/dist/core/objects/view/changes/view.drop.js +1 -1
  405. package/dist/core/objects/view/changes/view.privilege.d.ts +4 -3
  406. package/dist/core/objects/view/changes/view.privilege.js +3 -3
  407. package/dist/core/objects/view/changes/view.types.d.ts +1 -0
  408. package/dist/core/objects/view/view.diff.d.ts +2 -8
  409. package/dist/core/objects/view/view.diff.js +37 -168
  410. package/dist/core/objects/view/view.model.d.ts +18 -4
  411. package/dist/core/objects/view/view.model.js +3 -13
  412. package/dist/core/plan/apply.js +11 -28
  413. package/dist/core/plan/create.d.ts +19 -6
  414. package/dist/core/plan/create.js +154 -171
  415. package/dist/core/plan/serialize.js +16 -4
  416. package/dist/core/plan/sql-format/constants.d.ts +2 -0
  417. package/dist/core/plan/sql-format/constants.js +11 -0
  418. package/dist/core/plan/sql-format/fixtures.d.ts +2 -0
  419. package/dist/core/plan/sql-format/fixtures.js +2455 -0
  420. package/dist/core/plan/sql-format/format-utils.d.ts +37 -0
  421. package/dist/core/plan/sql-format/format-utils.js +274 -0
  422. package/dist/core/plan/sql-format/formatters.d.ts +20 -0
  423. package/dist/core/plan/sql-format/formatters.js +737 -0
  424. package/dist/core/plan/sql-format/index.d.ts +2 -0
  425. package/dist/core/plan/sql-format/index.js +98 -0
  426. package/dist/core/plan/sql-format/keyword-case.d.ts +2 -0
  427. package/dist/core/plan/sql-format/keyword-case.js +893 -0
  428. package/dist/core/plan/sql-format/protect.d.ts +3 -0
  429. package/dist/core/plan/sql-format/protect.js +269 -0
  430. package/dist/core/plan/sql-format/sql-scanner.d.ts +59 -0
  431. package/dist/core/plan/sql-format/sql-scanner.js +202 -0
  432. package/dist/core/plan/sql-format/tokenizer.d.ts +22 -0
  433. package/dist/core/plan/sql-format/tokenizer.js +118 -0
  434. package/dist/core/plan/sql-format/types.d.ts +28 -0
  435. package/dist/core/plan/sql-format/types.js +1 -0
  436. package/dist/core/plan/sql-format/wrap.d.ts +2 -0
  437. package/dist/core/plan/sql-format/wrap.js +165 -0
  438. package/dist/core/plan/sql-format.d.ts +2 -0
  439. package/dist/core/plan/sql-format.js +1 -0
  440. package/dist/core/plan/ssl-config.d.ts +32 -0
  441. package/dist/core/plan/ssl-config.js +115 -0
  442. package/dist/core/plan/statements.d.ts +2 -1
  443. package/dist/core/plan/statements.js +6 -2
  444. package/dist/core/plan/types.d.ts +9 -6
  445. package/dist/core/post-diff-cycle-breaking.d.ts +29 -0
  446. package/dist/core/post-diff-cycle-breaking.js +100 -0
  447. package/dist/core/postgres-config.d.ts +89 -3
  448. package/dist/core/postgres-config.js +273 -4
  449. package/dist/core/sort/custom-constraints.js +65 -1
  450. package/dist/core/sort/cycle-breakers.d.ts +15 -0
  451. package/dist/core/sort/cycle-breakers.js +269 -0
  452. package/dist/core/sort/graph-builder.js +10 -0
  453. package/dist/core/sort/logical-sort.js +34 -47
  454. package/dist/core/sort/sort-changes.js +97 -43
  455. package/dist/core/test-utils/assert-valid-sql.d.ts +10 -0
  456. package/dist/core/test-utils/assert-valid-sql.js +19 -0
  457. package/dist/index.d.ts +9 -0
  458. package/dist/index.js +9 -1
  459. package/package.json +59 -22
  460. package/src/cli/app.ts +52 -0
  461. package/src/cli/bin/cli.ts +15 -0
  462. package/src/cli/commands/apply.ts +101 -0
  463. package/src/cli/commands/catalog-export.ts +78 -0
  464. package/src/cli/commands/declarative-apply.diagnostics.test.ts +77 -0
  465. package/src/cli/commands/declarative-apply.ts +380 -0
  466. package/src/cli/commands/declarative-export.ts +322 -0
  467. package/src/cli/commands/plan.ts +210 -0
  468. package/src/cli/commands/sync.ts +178 -0
  469. package/src/cli/exit-code.test.ts +19 -0
  470. package/src/cli/exit-code.ts +7 -0
  471. package/src/cli/formatters/index.ts +5 -0
  472. package/src/cli/formatters/tree/tree-builder.ts +380 -0
  473. package/src/cli/formatters/tree/tree-renderer.ts +372 -0
  474. package/src/cli/formatters/tree/tree.ts +238 -0
  475. package/src/cli/utils/apply-display.test.ts +348 -0
  476. package/src/cli/utils/apply-display.ts +238 -0
  477. package/src/cli/utils/export-display.test.ts +103 -0
  478. package/src/cli/utils/export-display.ts +275 -0
  479. package/src/cli/utils/integrations.test.ts +251 -0
  480. package/src/cli/utils/integrations.ts +170 -0
  481. package/src/cli/utils/resolve-input.test.ts +38 -0
  482. package/src/cli/utils/resolve-input.ts +17 -0
  483. package/src/cli/utils.ts +231 -0
  484. package/src/core/catalog-export/index.ts +20 -0
  485. package/src/core/catalog.diff.ts +252 -0
  486. package/src/core/catalog.model.test.ts +122 -0
  487. package/src/core/catalog.model.ts +510 -0
  488. package/src/core/catalog.snapshot.test.ts +488 -0
  489. package/src/core/catalog.snapshot.ts +289 -0
  490. package/src/core/change-utils.test.ts +61 -0
  491. package/src/core/change-utils.ts +73 -0
  492. package/src/core/change.types.ts +94 -0
  493. package/src/core/connection-url.test.ts +142 -0
  494. package/src/core/connection-url.ts +82 -0
  495. package/src/core/context.ts +26 -0
  496. package/src/core/declarative-apply/discover-sql.test.ts +103 -0
  497. package/src/core/declarative-apply/discover-sql.ts +107 -0
  498. package/src/core/declarative-apply/extract-catalog-providers.ts +220 -0
  499. package/src/core/declarative-apply/index.test.ts +67 -0
  500. package/src/core/declarative-apply/index.ts +205 -0
  501. package/src/core/declarative-apply/round-apply.test.ts +504 -0
  502. package/src/core/declarative-apply/round-apply.ts +562 -0
  503. package/src/core/depend.ts +1895 -0
  504. package/src/core/expand-replace-dependencies.test.ts +555 -0
  505. package/src/core/expand-replace-dependencies.ts +536 -0
  506. package/src/core/export/file-mapper.test.ts +816 -0
  507. package/src/core/export/file-mapper.ts +579 -0
  508. package/src/core/export/grouper.ts +108 -0
  509. package/src/core/export/index.ts +138 -0
  510. package/src/core/export/types.ts +104 -0
  511. package/src/core/fingerprint.ts +204 -0
  512. package/src/core/fixtures/empty-catalogs/postgres-15-16-baseline.json +287 -0
  513. package/src/core/integrations/filter/dsl.test.ts +450 -0
  514. package/src/core/integrations/filter/dsl.ts +305 -0
  515. package/src/core/integrations/filter/filter.types.ts +3 -0
  516. package/src/core/integrations/filter/flatten.test.ts +282 -0
  517. package/src/core/integrations/filter/flatten.ts +150 -0
  518. package/src/core/integrations/integration-dsl.ts +50 -0
  519. package/src/core/integrations/integration.types.ts +65 -0
  520. package/src/core/integrations/merge.test.ts +128 -0
  521. package/src/core/integrations/merge.ts +72 -0
  522. package/src/core/integrations/serialize/dsl.test.ts +110 -0
  523. package/src/core/integrations/serialize/dsl.ts +71 -0
  524. package/src/core/integrations/serialize/serialize.types.ts +40 -0
  525. package/src/core/integrations/supabase.ts +180 -0
  526. package/src/core/objects/aggregate/aggregate.diff.test.ts +215 -0
  527. package/src/core/objects/aggregate/aggregate.diff.ts +222 -0
  528. package/src/core/objects/aggregate/aggregate.model.ts +317 -0
  529. package/src/core/objects/aggregate/changes/aggregate.alter.test.ts +66 -0
  530. package/src/core/objects/aggregate/changes/aggregate.alter.ts +33 -0
  531. package/src/core/objects/aggregate/changes/aggregate.base.ts +20 -0
  532. package/src/core/objects/aggregate/changes/aggregate.comment.test.ts +89 -0
  533. package/src/core/objects/aggregate/changes/aggregate.comment.ts +63 -0
  534. package/src/core/objects/aggregate/changes/aggregate.create.test.ts +104 -0
  535. package/src/core/objects/aggregate/changes/aggregate.create.ts +330 -0
  536. package/src/core/objects/aggregate/changes/aggregate.drop.test.ts +82 -0
  537. package/src/core/objects/aggregate/changes/aggregate.drop.ts +33 -0
  538. package/src/core/objects/aggregate/changes/aggregate.privilege.test.ts +136 -0
  539. package/src/core/objects/aggregate/changes/aggregate.privilege.ts +147 -0
  540. package/src/core/objects/aggregate/changes/aggregate.types.ts +13 -0
  541. package/src/core/objects/base.change.ts +74 -0
  542. package/src/core/objects/base.default-privileges.ts +204 -0
  543. package/src/core/objects/base.diff.ts +20 -0
  544. package/src/core/objects/base.model.test.ts +43 -0
  545. package/src/core/objects/base.model.ts +85 -0
  546. package/src/core/objects/base.privilege-diff.ts +447 -0
  547. package/src/core/objects/base.privilege.ts +191 -0
  548. package/src/core/objects/collation/changes/collation.alter.test.ts +68 -0
  549. package/src/core/objects/collation/changes/collation.alter.ts +80 -0
  550. package/src/core/objects/collation/changes/collation.base.ts +20 -0
  551. package/src/core/objects/collation/changes/collation.comment.ts +69 -0
  552. package/src/core/objects/collation/changes/collation.create.test.ts +56 -0
  553. package/src/core/objects/collation/changes/collation.create.ts +107 -0
  554. package/src/core/objects/collation/changes/collation.drop.test.ts +31 -0
  555. package/src/core/objects/collation/changes/collation.drop.ts +38 -0
  556. package/src/core/objects/collation/changes/collation.types.ts +11 -0
  557. package/src/core/objects/collation/collation.diff.test.ts +97 -0
  558. package/src/core/objects/collation/collation.diff.ts +127 -0
  559. package/src/core/objects/collation/collation.model.ts +224 -0
  560. package/src/core/objects/diff-context.ts +16 -0
  561. package/src/core/objects/domain/changes/domain.alter.test.ts +335 -0
  562. package/src/core/objects/domain/changes/domain.alter.ts +287 -0
  563. package/src/core/objects/domain/changes/domain.base.ts +20 -0
  564. package/src/core/objects/domain/changes/domain.comment.ts +60 -0
  565. package/src/core/objects/domain/changes/domain.create.test.ts +95 -0
  566. package/src/core/objects/domain/changes/domain.create.ts +141 -0
  567. package/src/core/objects/domain/changes/domain.drop.test.ts +33 -0
  568. package/src/core/objects/domain/changes/domain.drop.ts +35 -0
  569. package/src/core/objects/domain/changes/domain.privilege.ts +172 -0
  570. package/src/core/objects/domain/changes/domain.types.ts +13 -0
  571. package/src/core/objects/domain/domain.diff.test.ts +284 -0
  572. package/src/core/objects/domain/domain.diff.ts +295 -0
  573. package/src/core/objects/domain/domain.model.ts +190 -0
  574. package/src/core/objects/event-trigger/changes/event-trigger.alter.test.ts +57 -0
  575. package/src/core/objects/event-trigger/changes/event-trigger.alter.ts +83 -0
  576. package/src/core/objects/event-trigger/changes/event-trigger.base.ts +20 -0
  577. package/src/core/objects/event-trigger/changes/event-trigger.comment.ts +67 -0
  578. package/src/core/objects/event-trigger/changes/event-trigger.create.test.ts +27 -0
  579. package/src/core/objects/event-trigger/changes/event-trigger.create.ts +73 -0
  580. package/src/core/objects/event-trigger/changes/event-trigger.drop.test.ts +25 -0
  581. package/src/core/objects/event-trigger/changes/event-trigger.drop.ts +35 -0
  582. package/src/core/objects/event-trigger/changes/event-trigger.types.ts +11 -0
  583. package/src/core/objects/event-trigger/event-trigger.diff.test.ts +131 -0
  584. package/src/core/objects/event-trigger/event-trigger.diff.ts +127 -0
  585. package/src/core/objects/event-trigger/event-trigger.model.ts +106 -0
  586. package/src/core/objects/extension/changes/extension.alter.test.ts +63 -0
  587. package/src/core/objects/extension/changes/extension.alter.ts +79 -0
  588. package/src/core/objects/extension/changes/extension.base.ts +20 -0
  589. package/src/core/objects/extension/changes/extension.comment.ts +65 -0
  590. package/src/core/objects/extension/changes/extension.create.test.ts +50 -0
  591. package/src/core/objects/extension/changes/extension.create.ts +66 -0
  592. package/src/core/objects/extension/changes/extension.drop.test.ts +26 -0
  593. package/src/core/objects/extension/changes/extension.drop.ts +35 -0
  594. package/src/core/objects/extension/changes/extension.types.ts +11 -0
  595. package/src/core/objects/extension/extension.diff.test.ts +42 -0
  596. package/src/core/objects/extension/extension.diff.ts +90 -0
  597. package/src/core/objects/extension/extension.model.test.ts +98 -0
  598. package/src/core/objects/extension/extension.model.ts +280 -0
  599. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.alter.test.ts +136 -0
  600. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.alter.ts +102 -0
  601. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.base.ts +20 -0
  602. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.comment.ts +73 -0
  603. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.create.test.ts +160 -0
  604. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.create.ts +96 -0
  605. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.drop.test.ts +26 -0
  606. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.drop.ts +37 -0
  607. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.privilege.ts +173 -0
  608. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/changes/foreign-data-wrapper.types.ts +13 -0
  609. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/foreign-data-wrapper.diff.test.ts +286 -0
  610. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/foreign-data-wrapper.diff.ts +271 -0
  611. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper/foreign-data-wrapper.model.ts +149 -0
  612. package/src/core/objects/foreign-data-wrapper/foreign-data-wrapper.types.ts +11 -0
  613. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.alter.test.ts +340 -0
  614. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.alter.ts +342 -0
  615. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.base.ts +20 -0
  616. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.comment.ts +73 -0
  617. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.create.test.ts +210 -0
  618. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.create.ts +82 -0
  619. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.drop.test.ts +46 -0
  620. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.drop.ts +38 -0
  621. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.privilege.ts +182 -0
  622. package/src/core/objects/foreign-data-wrapper/foreign-table/changes/foreign-table.types.ts +13 -0
  623. package/src/core/objects/foreign-data-wrapper/foreign-table/foreign-table.diff.test.ts +813 -0
  624. package/src/core/objects/foreign-data-wrapper/foreign-table/foreign-table.diff.ts +343 -0
  625. package/src/core/objects/foreign-data-wrapper/foreign-table/foreign-table.model.ts +242 -0
  626. package/src/core/objects/foreign-data-wrapper/server/changes/server.alter.test.ts +183 -0
  627. package/src/core/objects/foreign-data-wrapper/server/changes/server.alter.ts +127 -0
  628. package/src/core/objects/foreign-data-wrapper/server/changes/server.base.ts +20 -0
  629. package/src/core/objects/foreign-data-wrapper/server/changes/server.comment.ts +61 -0
  630. package/src/core/objects/foreign-data-wrapper/server/changes/server.create.test.ts +144 -0
  631. package/src/core/objects/foreign-data-wrapper/server/changes/server.create.ts +82 -0
  632. package/src/core/objects/foreign-data-wrapper/server/changes/server.drop.test.ts +27 -0
  633. package/src/core/objects/foreign-data-wrapper/server/changes/server.drop.ts +35 -0
  634. package/src/core/objects/foreign-data-wrapper/server/changes/server.privilege.ts +165 -0
  635. package/src/core/objects/foreign-data-wrapper/server/changes/server.types.ts +13 -0
  636. package/src/core/objects/foreign-data-wrapper/server/server.diff.test.ts +262 -0
  637. package/src/core/objects/foreign-data-wrapper/server/server.diff.ts +247 -0
  638. package/src/core/objects/foreign-data-wrapper/server/server.model.ts +133 -0
  639. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.alter.test.ts +91 -0
  640. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.alter.ts +70 -0
  641. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.base.ts +20 -0
  642. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.create.test.ts +96 -0
  643. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.create.ts +67 -0
  644. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.drop.test.ts +60 -0
  645. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.drop.ts +41 -0
  646. package/src/core/objects/foreign-data-wrapper/user-mapping/changes/user-mapping.types.ts +9 -0
  647. package/src/core/objects/foreign-data-wrapper/user-mapping/user-mapping.diff.test.ts +77 -0
  648. package/src/core/objects/foreign-data-wrapper/user-mapping/user-mapping.diff.ts +107 -0
  649. package/src/core/objects/foreign-data-wrapper/user-mapping/user-mapping.model.ts +96 -0
  650. package/src/core/objects/index/changes/index.alter.test.ts +209 -0
  651. package/src/core/objects/index/changes/index.alter.ts +145 -0
  652. package/src/core/objects/index/changes/index.base.ts +20 -0
  653. package/src/core/objects/index/changes/index.comment.ts +64 -0
  654. package/src/core/objects/index/changes/index.create.test.ts +69 -0
  655. package/src/core/objects/index/changes/index.create.ts +69 -0
  656. package/src/core/objects/index/changes/index.drop.test.ts +47 -0
  657. package/src/core/objects/index/changes/index.drop.ts +35 -0
  658. package/src/core/objects/index/changes/index.types.ts +7 -0
  659. package/src/core/objects/index/changes/utils.ts +16 -0
  660. package/src/core/objects/index/index.diff.test.ts +153 -0
  661. package/src/core/objects/index/index.diff.ts +243 -0
  662. package/src/core/objects/index/index.model.test.ts +83 -0
  663. package/src/core/objects/index/index.model.ts +379 -0
  664. package/src/core/objects/language/changes/language.alter.test.ts +36 -0
  665. package/src/core/objects/language/changes/language.alter.ts +54 -0
  666. package/src/core/objects/language/changes/language.base.ts +20 -0
  667. package/src/core/objects/language/changes/language.comment.ts +59 -0
  668. package/src/core/objects/language/changes/language.create.test.ts +30 -0
  669. package/src/core/objects/language/changes/language.create.ts +105 -0
  670. package/src/core/objects/language/changes/language.drop.test.ts +28 -0
  671. package/src/core/objects/language/changes/language.drop.ts +40 -0
  672. package/src/core/objects/language/changes/language.privilege.ts +173 -0
  673. package/src/core/objects/language/changes/language.types.ts +13 -0
  674. package/src/core/objects/language/language.diff.test.ts +135 -0
  675. package/src/core/objects/language/language.diff.ts +144 -0
  676. package/src/core/objects/language/language.model.ts +150 -0
  677. package/src/core/objects/materialized-view/changes/materialized-view.alter.test.ts +130 -0
  678. package/src/core/objects/materialized-view/changes/materialized-view.alter.ts +114 -0
  679. package/src/core/objects/materialized-view/changes/materialized-view.base.ts +20 -0
  680. package/src/core/objects/materialized-view/changes/materialized-view.comment.ts +177 -0
  681. package/src/core/objects/materialized-view/changes/materialized-view.create.test.ts +69 -0
  682. package/src/core/objects/materialized-view/changes/materialized-view.create.ts +94 -0
  683. package/src/core/objects/materialized-view/changes/materialized-view.drop.test.ts +37 -0
  684. package/src/core/objects/materialized-view/changes/materialized-view.drop.ts +61 -0
  685. package/src/core/objects/materialized-view/changes/materialized-view.privilege.ts +213 -0
  686. package/src/core/objects/materialized-view/changes/materialized-view.types.ts +13 -0
  687. package/src/core/objects/materialized-view/materialized-view.diff.test.ts +264 -0
  688. package/src/core/objects/materialized-view/materialized-view.diff.ts +301 -0
  689. package/src/core/objects/materialized-view/materialized-view.model.ts +258 -0
  690. package/src/core/objects/procedure/changes/procedure.alter.test.ts +1077 -0
  691. package/src/core/objects/procedure/changes/procedure.alter.ts +291 -0
  692. package/src/core/objects/procedure/changes/procedure.base.ts +20 -0
  693. package/src/core/objects/procedure/changes/procedure.comment.ts +71 -0
  694. package/src/core/objects/procedure/changes/procedure.create.test.ts +51 -0
  695. package/src/core/objects/procedure/changes/procedure.create.ts +93 -0
  696. package/src/core/objects/procedure/changes/procedure.drop.test.ts +90 -0
  697. package/src/core/objects/procedure/changes/procedure.drop.ts +50 -0
  698. package/src/core/objects/procedure/changes/procedure.privilege.ts +189 -0
  699. package/src/core/objects/procedure/changes/procedure.types.ts +13 -0
  700. package/src/core/objects/procedure/procedure.diff.test.ts +284 -0
  701. package/src/core/objects/procedure/procedure.diff.ts +371 -0
  702. package/src/core/objects/procedure/procedure.model.ts +264 -0
  703. package/src/core/objects/procedure/utils.ts +58 -0
  704. package/src/core/objects/publication/changes/publication.alter.test.ts +221 -0
  705. package/src/core/objects/publication/changes/publication.alter.ts +232 -0
  706. package/src/core/objects/publication/changes/publication.base.ts +20 -0
  707. package/src/core/objects/publication/changes/publication.comment.test.ts +73 -0
  708. package/src/core/objects/publication/changes/publication.comment.ts +65 -0
  709. package/src/core/objects/publication/changes/publication.create.test.ts +90 -0
  710. package/src/core/objects/publication/changes/publication.create.ts +83 -0
  711. package/src/core/objects/publication/changes/publication.drop.test.ts +48 -0
  712. package/src/core/objects/publication/changes/publication.drop.ts +30 -0
  713. package/src/core/objects/publication/changes/publication.types.ts +25 -0
  714. package/src/core/objects/publication/publication.diff.test.ts +297 -0
  715. package/src/core/objects/publication/publication.diff.ts +247 -0
  716. package/src/core/objects/publication/publication.model.ts +206 -0
  717. package/src/core/objects/publication/utils.ts +55 -0
  718. package/src/core/objects/rls-policy/changes/rls-policy.alter.test.ts +283 -0
  719. package/src/core/objects/rls-policy/changes/rls-policy.alter.ts +129 -0
  720. package/src/core/objects/rls-policy/changes/rls-policy.base.ts +20 -0
  721. package/src/core/objects/rls-policy/changes/rls-policy.comment.ts +70 -0
  722. package/src/core/objects/rls-policy/changes/rls-policy.create.test.ts +209 -0
  723. package/src/core/objects/rls-policy/changes/rls-policy.create.ts +128 -0
  724. package/src/core/objects/rls-policy/changes/rls-policy.drop.test.ts +33 -0
  725. package/src/core/objects/rls-policy/changes/rls-policy.drop.ts +40 -0
  726. package/src/core/objects/rls-policy/changes/rls-policy.types.ts +11 -0
  727. package/src/core/objects/rls-policy/rls-policy.diff.test.ts +81 -0
  728. package/src/core/objects/rls-policy/rls-policy.diff.ts +121 -0
  729. package/src/core/objects/rls-policy/rls-policy.model.ts +273 -0
  730. package/src/core/objects/role/changes/role.alter.test.ts +362 -0
  731. package/src/core/objects/role/changes/role.alter.ts +111 -0
  732. package/src/core/objects/role/changes/role.base.ts +24 -0
  733. package/src/core/objects/role/changes/role.comment.ts +56 -0
  734. package/src/core/objects/role/changes/role.create.test.ts +56 -0
  735. package/src/core/objects/role/changes/role.create.ts +103 -0
  736. package/src/core/objects/role/changes/role.drop.test.ts +32 -0
  737. package/src/core/objects/role/changes/role.drop.ts +35 -0
  738. package/src/core/objects/role/changes/role.privilege.ts +377 -0
  739. package/src/core/objects/role/changes/role.types.ts +13 -0
  740. package/src/core/objects/role/role.diff.test.ts +279 -0
  741. package/src/core/objects/role/role.diff.ts +499 -0
  742. package/src/core/objects/role/role.model.ts +452 -0
  743. package/src/core/objects/rule/changes/rule.alter.test.ts +82 -0
  744. package/src/core/objects/rule/changes/rule.alter.ts +73 -0
  745. package/src/core/objects/rule/changes/rule.base.ts +20 -0
  746. package/src/core/objects/rule/changes/rule.comment.test.ts +58 -0
  747. package/src/core/objects/rule/changes/rule.comment.ts +63 -0
  748. package/src/core/objects/rule/changes/rule.create.test.ts +63 -0
  749. package/src/core/objects/rule/changes/rule.create.ts +43 -0
  750. package/src/core/objects/rule/changes/rule.drop.test.ts +40 -0
  751. package/src/core/objects/rule/changes/rule.drop.ts +30 -0
  752. package/src/core/objects/rule/changes/rule.types.ts +13 -0
  753. package/src/core/objects/rule/rule.diff.test.ts +132 -0
  754. package/src/core/objects/rule/rule.diff.ts +79 -0
  755. package/src/core/objects/rule/rule.model.ts +173 -0
  756. package/src/core/objects/schema/changes/schema.alter.test.ts +31 -0
  757. package/src/core/objects/schema/changes/schema.alter.ts +46 -0
  758. package/src/core/objects/schema/changes/schema.base.ts +20 -0
  759. package/src/core/objects/schema/changes/schema.comment.ts +57 -0
  760. package/src/core/objects/schema/changes/schema.create.test.ts +25 -0
  761. package/src/core/objects/schema/changes/schema.create.ts +47 -0
  762. package/src/core/objects/schema/changes/schema.drop.test.ts +23 -0
  763. package/src/core/objects/schema/changes/schema.drop.ts +35 -0
  764. package/src/core/objects/schema/changes/schema.privilege.ts +176 -0
  765. package/src/core/objects/schema/changes/schema.types.ts +13 -0
  766. package/src/core/objects/schema/schema.diff.test.ts +42 -0
  767. package/src/core/objects/schema/schema.diff.ts +146 -0
  768. package/src/core/objects/schema/schema.model.ts +107 -0
  769. package/src/core/objects/sequence/changes/sequence.alter.test.ts +157 -0
  770. package/src/core/objects/sequence/changes/sequence.alter.ts +116 -0
  771. package/src/core/objects/sequence/changes/sequence.base.ts +20 -0
  772. package/src/core/objects/sequence/changes/sequence.comment.ts +61 -0
  773. package/src/core/objects/sequence/changes/sequence.create.test.ts +89 -0
  774. package/src/core/objects/sequence/changes/sequence.create.ts +112 -0
  775. package/src/core/objects/sequence/changes/sequence.drop.test.ts +35 -0
  776. package/src/core/objects/sequence/changes/sequence.drop.ts +50 -0
  777. package/src/core/objects/sequence/changes/sequence.privilege.ts +180 -0
  778. package/src/core/objects/sequence/changes/sequence.types.ts +13 -0
  779. package/src/core/objects/sequence/sequence.diff.test.ts +434 -0
  780. package/src/core/objects/sequence/sequence.diff.ts +334 -0
  781. package/src/core/objects/sequence/sequence.model.ts +185 -0
  782. package/src/core/objects/subscription/changes/subscription.alter.test.ts +134 -0
  783. package/src/core/objects/subscription/changes/subscription.alter.ts +111 -0
  784. package/src/core/objects/subscription/changes/subscription.base.ts +20 -0
  785. package/src/core/objects/subscription/changes/subscription.comment.test.ts +70 -0
  786. package/src/core/objects/subscription/changes/subscription.comment.ts +65 -0
  787. package/src/core/objects/subscription/changes/subscription.create.test.ts +80 -0
  788. package/src/core/objects/subscription/changes/subscription.create.ts +70 -0
  789. package/src/core/objects/subscription/changes/subscription.drop.test.ts +48 -0
  790. package/src/core/objects/subscription/changes/subscription.drop.ts +21 -0
  791. package/src/core/objects/subscription/changes/subscription.types.ts +23 -0
  792. package/src/core/objects/subscription/subscription.diff.test.ts +237 -0
  793. package/src/core/objects/subscription/subscription.diff.ts +242 -0
  794. package/src/core/objects/subscription/subscription.model.ts +190 -0
  795. package/src/core/objects/subscription/utils.ts +156 -0
  796. package/src/core/objects/table/changes/table.alter.test.ts +910 -0
  797. package/src/core/objects/table/changes/table.alter.ts +939 -0
  798. package/src/core/objects/table/changes/table.base.ts +20 -0
  799. package/src/core/objects/table/changes/table.comment.ts +267 -0
  800. package/src/core/objects/table/changes/table.create.test.ts +188 -0
  801. package/src/core/objects/table/changes/table.create.ts +193 -0
  802. package/src/core/objects/table/changes/table.drop.test.ts +36 -0
  803. package/src/core/objects/table/changes/table.drop.ts +87 -0
  804. package/src/core/objects/table/changes/table.privilege.ts +201 -0
  805. package/src/core/objects/table/changes/table.types.ts +13 -0
  806. package/src/core/objects/table/table.diff.test.ts +1189 -0
  807. package/src/core/objects/table/table.diff.ts +913 -0
  808. package/src/core/objects/table/table.model.ts +465 -0
  809. package/src/core/objects/trigger/changes/trigger.alter.test.ts +50 -0
  810. package/src/core/objects/trigger/changes/trigger.alter.ts +77 -0
  811. package/src/core/objects/trigger/changes/trigger.base.ts +20 -0
  812. package/src/core/objects/trigger/changes/trigger.comment.ts +65 -0
  813. package/src/core/objects/trigger/changes/trigger.create.test.ts +47 -0
  814. package/src/core/objects/trigger/changes/trigger.create.ts +89 -0
  815. package/src/core/objects/trigger/changes/trigger.drop.test.ts +47 -0
  816. package/src/core/objects/trigger/changes/trigger.drop.ts +40 -0
  817. package/src/core/objects/trigger/changes/trigger.types.ts +11 -0
  818. package/src/core/objects/trigger/trigger.diff.test.ts +84 -0
  819. package/src/core/objects/trigger/trigger.diff.ts +121 -0
  820. package/src/core/objects/trigger/trigger.model.ts +268 -0
  821. package/src/core/objects/type/composite-type/changes/composite-type.alter.test.ts +208 -0
  822. package/src/core/objects/type/composite-type/changes/composite-type.alter.ts +175 -0
  823. package/src/core/objects/type/composite-type/changes/composite-type.base.ts +20 -0
  824. package/src/core/objects/type/composite-type/changes/composite-type.comment.ts +146 -0
  825. package/src/core/objects/type/composite-type/changes/composite-type.create.test.ts +106 -0
  826. package/src/core/objects/type/composite-type/changes/composite-type.create.ts +96 -0
  827. package/src/core/objects/type/composite-type/changes/composite-type.drop.test.ts +36 -0
  828. package/src/core/objects/type/composite-type/changes/composite-type.drop.ts +38 -0
  829. package/src/core/objects/type/composite-type/changes/composite-type.privilege.ts +176 -0
  830. package/src/core/objects/type/composite-type/changes/composite-type.types.ts +13 -0
  831. package/src/core/objects/type/composite-type/composite-type.diff.test.ts +269 -0
  832. package/src/core/objects/type/composite-type/composite-type.diff.ts +310 -0
  833. package/src/core/objects/type/composite-type/composite-type.model.ts +253 -0
  834. package/src/core/objects/type/enum/changes/enum.alter.test.ts +113 -0
  835. package/src/core/objects/type/enum/changes/enum.alter.ts +92 -0
  836. package/src/core/objects/type/enum/changes/enum.base.ts +20 -0
  837. package/src/core/objects/type/enum/changes/enum.comment.ts +65 -0
  838. package/src/core/objects/type/enum/changes/enum.create.test.ts +31 -0
  839. package/src/core/objects/type/enum/changes/enum.create.ts +57 -0
  840. package/src/core/objects/type/enum/changes/enum.drop.test.ts +28 -0
  841. package/src/core/objects/type/enum/changes/enum.drop.ts +35 -0
  842. package/src/core/objects/type/enum/changes/enum.privilege.ts +176 -0
  843. package/src/core/objects/type/enum/changes/enum.types.ts +13 -0
  844. package/src/core/objects/type/enum/enum.diff.test.ts +372 -0
  845. package/src/core/objects/type/enum/enum.diff.ts +308 -0
  846. package/src/core/objects/type/enum/enum.model.ts +194 -0
  847. package/src/core/objects/type/range/changes/range.alter.test.ts +29 -0
  848. package/src/core/objects/type/range/changes/range.alter.ts +52 -0
  849. package/src/core/objects/type/range/changes/range.base.ts +20 -0
  850. package/src/core/objects/type/range/changes/range.comment.ts +65 -0
  851. package/src/core/objects/type/range/changes/range.create.test.ts +54 -0
  852. package/src/core/objects/type/range/changes/range.create.ts +156 -0
  853. package/src/core/objects/type/range/changes/range.drop.test.ts +28 -0
  854. package/src/core/objects/type/range/changes/range.drop.ts +35 -0
  855. package/src/core/objects/type/range/changes/range.privilege.ts +176 -0
  856. package/src/core/objects/type/range/changes/range.types.ts +13 -0
  857. package/src/core/objects/type/range/range.diff.test.ts +147 -0
  858. package/src/core/objects/type/range/range.diff.ts +197 -0
  859. package/src/core/objects/type/range/range.model.ts +187 -0
  860. package/src/core/objects/type/type.types.ts +6 -0
  861. package/src/core/objects/utils.ts +171 -0
  862. package/src/core/objects/view/changes/view.alter.test.ts +115 -0
  863. package/src/core/objects/view/changes/view.alter.ts +113 -0
  864. package/src/core/objects/view/changes/view.base.ts +20 -0
  865. package/src/core/objects/view/changes/view.comment.ts +60 -0
  866. package/src/core/objects/view/changes/view.create.test.ts +70 -0
  867. package/src/core/objects/view/changes/view.create.ts +74 -0
  868. package/src/core/objects/view/changes/view.drop.test.ts +37 -0
  869. package/src/core/objects/view/changes/view.drop.ts +41 -0
  870. package/src/core/objects/view/changes/view.privilege.ts +201 -0
  871. package/src/core/objects/view/changes/view.types.ts +13 -0
  872. package/src/core/objects/view/view.diff.test.ts +269 -0
  873. package/src/core/objects/view/view.diff.ts +230 -0
  874. package/src/core/objects/view/view.model.ts +262 -0
  875. package/src/core/plan/apply.ts +172 -0
  876. package/src/core/plan/create.ts +368 -0
  877. package/src/core/plan/hierarchy.ts +574 -0
  878. package/src/core/plan/index.ts +29 -0
  879. package/src/core/plan/io.ts +20 -0
  880. package/src/core/plan/risk.ts +48 -0
  881. package/src/core/plan/serialize.test.ts +317 -0
  882. package/src/core/plan/serialize.ts +209 -0
  883. package/src/core/plan/sql-format/constants.ts +13 -0
  884. package/src/core/plan/sql-format/fixtures.ts +2811 -0
  885. package/src/core/plan/sql-format/format-comment-literals.test.ts +96 -0
  886. package/src/core/plan/sql-format/format-functions.test.ts +127 -0
  887. package/src/core/plan/sql-format/format-lowercase-coverage.test.ts +119 -0
  888. package/src/core/plan/sql-format/format-off.test.ts +806 -0
  889. package/src/core/plan/sql-format/format-pretty-lower-leading.test.ts +1061 -0
  890. package/src/core/plan/sql-format/format-pretty-narrow.test.ts +1279 -0
  891. package/src/core/plan/sql-format/format-pretty-preserve.test.ts +1057 -0
  892. package/src/core/plan/sql-format/format-pretty-upper.test.ts +1048 -0
  893. package/src/core/plan/sql-format/format-stress.test.ts +616 -0
  894. package/src/core/plan/sql-format/format-utils.test.ts +91 -0
  895. package/src/core/plan/sql-format/format-utils.ts +391 -0
  896. package/src/core/plan/sql-format/formatters.ts +921 -0
  897. package/src/core/plan/sql-format/index.ts +149 -0
  898. package/src/core/plan/sql-format/keyword-case.test.ts +118 -0
  899. package/src/core/plan/sql-format/keyword-case.ts +1120 -0
  900. package/src/core/plan/sql-format/protect.test.ts +127 -0
  901. package/src/core/plan/sql-format/protect.ts +337 -0
  902. package/src/core/plan/sql-format/sql-scanner.test.ts +240 -0
  903. package/src/core/plan/sql-format/sql-scanner.ts +252 -0
  904. package/src/core/plan/sql-format/tokenizer.test.ts +68 -0
  905. package/src/core/plan/sql-format/tokenizer.ts +152 -0
  906. package/src/core/plan/sql-format/types.ts +31 -0
  907. package/src/core/plan/sql-format/wrap.test.ts +119 -0
  908. package/src/core/plan/sql-format/wrap.ts +196 -0
  909. package/src/core/plan/sql-format.ts +2 -0
  910. package/src/core/plan/ssl-config.ts +172 -0
  911. package/src/core/plan/statements.ts +22 -0
  912. package/src/core/plan/types.ts +168 -0
  913. package/src/core/post-diff-cycle-breaking.test.ts +303 -0
  914. package/src/core/post-diff-cycle-breaking.ts +138 -0
  915. package/src/core/postgres-config.test.ts +336 -0
  916. package/src/core/postgres-config.ts +458 -0
  917. package/src/core/sort/custom-constraints.ts +235 -0
  918. package/src/core/sort/cycle-breakers.test.ts +476 -0
  919. package/src/core/sort/cycle-breakers.ts +311 -0
  920. package/src/core/sort/debug-visualization.ts +239 -0
  921. package/src/core/sort/dependency-filter.ts +224 -0
  922. package/src/core/sort/graph-builder.ts +235 -0
  923. package/src/core/sort/graph-utils.ts +51 -0
  924. package/src/core/sort/logical-sort.test.ts +371 -0
  925. package/src/core/sort/logical-sort.ts +573 -0
  926. package/src/core/sort/sort-changes.ts +319 -0
  927. package/src/core/sort/topological-sort.test.ts +275 -0
  928. package/src/core/sort/topological-sort.ts +184 -0
  929. package/src/core/sort/types.ts +112 -0
  930. package/src/core/sort/utils.ts +69 -0
  931. package/src/core/test-utils/assert-valid-sql.ts +20 -0
  932. package/src/index.ts +41 -0
  933. package/src/typedoc.ts +253 -0
  934. package/dist/core/integrations/filter/extractors.d.ts +0 -12
  935. package/dist/core/integrations/filter/extractors.js +0 -136
@@ -1,6 +1,6 @@
1
1
  import { sql } from "@ts-safeql/sql-tag";
2
2
  import z from "zod";
3
- import { BasePgModel, columnPropsSchema, } from "../base.model.js";
3
+ import { BasePgModel, columnPropsSchema, normalizeColumns, } from "../base.model.js";
4
4
  import { privilegePropsSchema, } from "../base.privilege-diff.js";
5
5
  import { ReplicaIdentitySchema } from "../table/table.model.js";
6
6
  const viewPropsSchema = z.object({
@@ -95,21 +95,11 @@ export class View extends BasePgModel {
95
95
  };
96
96
  }
97
97
  stableSnapshot() {
98
- const normalizeColumns = () => [...this.columns]
99
- .map((col) => {
100
- const { position: _pos, ...rest } = col;
101
- return rest;
102
- })
103
- .sort((a, b) => {
104
- const nameA = a.name ?? "";
105
- const nameB = b.name ?? "";
106
- return nameA.localeCompare(nameB);
107
- });
108
98
  return {
109
99
  identity: this.identityFields,
110
100
  data: {
111
101
  ...this.dataFields,
112
- columns: normalizeColumns(),
102
+ columns: normalizeColumns(this.columns),
113
103
  },
114
104
  };
115
105
  }
@@ -218,7 +208,7 @@ select
218
208
  from (
219
209
  -- one row for object ACL + one row per column ACL
220
210
  select null::name as attname, v.oid as relacl_oid, (
221
- select c_rel.relacl from pg_class c_rel where c_rel.oid = v.oid
211
+ select COALESCE(c_rel.relacl, acldefault('r', c_rel.relowner)) from pg_class c_rel where c_rel.oid = v.oid
222
212
  ) as acl
223
213
  union all
224
214
  select a2.attname, v.oid as relacl_oid, a2.attacl
@@ -1,12 +1,11 @@
1
1
  /**
2
2
  * Plan application - execute migration plans against target databases.
3
3
  */
4
- import { escapeIdentifier } from "pg";
5
4
  import { diffCatalogs } from "../catalog.diff.js";
6
5
  import { extractCatalog } from "../catalog.model.js";
7
6
  import { buildPlanScopeFingerprint, hashStableIds } from "../fingerprint.js";
8
7
  import { compileFilterDSL } from "../integrations/filter/dsl.js";
9
- import { createPool } from "../postgres-config.js";
8
+ import { createManagedPool, endPool } from "../postgres-config.js";
10
9
  import { sortChanges } from "../sort/sort-changes.js";
11
10
  /**
12
11
  * Check if a statement is a session configuration statement (standalone SET statements).
@@ -30,39 +29,23 @@ export async function applyPlan(plan, source, target, options = {}) {
30
29
  let desiredPool;
31
30
  let shouldCloseCurrent = false;
32
31
  let shouldCloseDesired = false;
33
- // Suppress expected shutdown errors from idle pool connections (57P01 = admin_shutdown)
34
- const onError = (err) => {
35
- if (err.code !== "57P01") {
36
- console.error("Pool error:", err);
37
- }
38
- };
39
32
  if (typeof source === "string") {
40
- currentPool = createPool(source, {
41
- onError,
42
- onConnect: async (client) => {
43
- // Force fully qualified names in catalog queries for fingerprint verification
44
- await client.query("SET search_path = ''");
45
- if (plan.role) {
46
- await client.query(`SET ROLE ${escapeIdentifier(plan.role)}`);
47
- }
48
- },
33
+ const managed = await createManagedPool(source, {
34
+ role: plan.role,
35
+ label: "source",
49
36
  });
37
+ currentPool = managed.pool;
50
38
  shouldCloseCurrent = true;
51
39
  }
52
40
  else {
53
41
  currentPool = source;
54
42
  }
55
43
  if (typeof target === "string") {
56
- desiredPool = createPool(target, {
57
- onError,
58
- onConnect: async (client) => {
59
- // Force fully qualified names in catalog queries for fingerprint verification
60
- await client.query("SET search_path = ''");
61
- if (plan.role) {
62
- await client.query(`SET ROLE ${escapeIdentifier(plan.role)}`);
63
- }
64
- },
44
+ const managed = await createManagedPool(target, {
45
+ role: plan.role,
46
+ label: "target",
65
47
  });
48
+ desiredPool = managed.pool;
66
49
  shouldCloseDesired = true;
67
50
  }
68
51
  else {
@@ -136,9 +119,9 @@ export async function applyPlan(plan, source, target, options = {}) {
136
119
  finally {
137
120
  const closers = [];
138
121
  if (shouldCloseCurrent)
139
- closers.push(currentPool.end());
122
+ closers.push(endPool(currentPool));
140
123
  if (shouldCloseDesired)
141
- closers.push(desiredPool.end());
124
+ closers.push(endPool(desiredPool));
142
125
  if (closers.length) {
143
126
  await Promise.all(closers);
144
127
  }
@@ -2,21 +2,34 @@
2
2
  * Plan creation - the main entry point for creating migration plans.
3
3
  */
4
4
  import type { Pool } from "pg";
5
+ import type { Catalog } from "../catalog.model.ts";
5
6
  import type { Change } from "../change.types.ts";
6
7
  import type { DiffContext } from "../context.ts";
7
8
  import type { CreatePlanOptions, Plan } from "./types.ts";
8
9
  /**
9
- * Create a migration plan by comparing two databases.
10
+ * Input for source/target: a postgres connection URL, an existing Pool, or
11
+ * an already-resolved Catalog (e.g. deserialized from a snapshot file).
12
+ */
13
+ export type CatalogInput = string | Pool | Catalog;
14
+ /**
15
+ * Create a migration plan by comparing two catalog states.
16
+ *
17
+ * Each input can be:
18
+ * - A postgres connection URL (string) -- a pool is created and catalog extracted
19
+ * - An existing pg Pool -- catalog is extracted directly
20
+ * - A Catalog instance -- used as-is (e.g. from a deserialized snapshot)
21
+ *
22
+ * When `source` is `null`, a minimal empty catalog (`createEmptyCatalog`) is
23
+ * used as the baseline. For a more accurate baseline, pass a Catalog
24
+ * deserialized from a snapshot of `template1` or another reference database.
10
25
  *
11
- * @param fromUrl - Source database connection URL (current state)
12
- * @param toUrl - Target database connection URL (desired state)
26
+ * @param source - Source catalog input (current state), or null for empty baseline
27
+ * @param target - Target catalog input (desired state)
13
28
  * @param options - Optional configuration
14
29
  * @returns A Plan if there are changes, null if databases are identical
15
30
  */
16
- type ConnectionInput = string | Pool;
17
- export declare function createPlan(source: ConnectionInput, target: ConnectionInput, options?: CreatePlanOptions): Promise<{
31
+ export declare function createPlan(source: CatalogInput | null, target: CatalogInput, options?: CreatePlanOptions): Promise<{
18
32
  plan: Plan;
19
33
  sortedChanges: Change[];
20
34
  ctx: DiffContext;
21
35
  } | null>;
22
- export {};
@@ -1,177 +1,83 @@
1
1
  /**
2
2
  * Plan creation - the main entry point for creating migration plans.
3
3
  */
4
- import { readFile } from "node:fs/promises";
5
4
  import { escapeIdentifier } from "pg";
6
5
  import { diffCatalogs } from "../catalog.diff.js";
7
- import { extractCatalog } from "../catalog.model.js";
6
+ import { createEmptyCatalog, extractCatalog } from "../catalog.model.js";
8
7
  import { buildPlanScopeFingerprint, hashStableIds } from "../fingerprint.js";
9
- import { compileFilterDSL, } from "../integrations/filter/dsl.js";
10
- import { compileSerializeDSL, } from "../integrations/serialize/dsl.js";
11
- import { createPool } from "../postgres-config.js";
8
+ import { resolveIntegration, } from "../integrations/integration.types.js";
9
+ import { createManagedPool, endPool } from "../postgres-config.js";
12
10
  import { sortChanges } from "../sort/sort-changes.js";
13
11
  import { classifyChangesRisk } from "./risk.js";
14
12
  /**
15
- * Parse SSL configuration from a PostgreSQL connection URL.
16
- * Supports sslmode (require, verify-ca, verify-full, prefer, disable).
17
- * Certificates can be provided via:
18
- * - Query string parameters (file paths): sslrootcert, sslcert, sslkey (preferred)
19
- * - Environment variables (content): PGDELTA_SOURCE_SSLROOTCERT/SSLCERT/SSLKEY or PGDELTA_TARGET_SSLROOTCERT/SSLCERT/SSLKEY
20
- * Returns SSL options for the postgres.js library and a cleaned URL without SSL-related query parameters.
13
+ * Bundle-safe catalog detection: treat input as a resolved Catalog when it has
14
+ * the catalog shape and is not a pg Pool. Deserialized or cross-bundle Catalog
15
+ * instances may fail `instanceof Catalog` but pass this guard.
21
16
  */
22
- async function parseSslConfig(url, connectionType) {
23
- const urlObj = new URL(url);
24
- const sslmode = urlObj.searchParams.get("sslmode");
25
- const sslrootcert = urlObj.searchParams.get("sslrootcert");
26
- const sslcert = urlObj.searchParams.get("sslcert");
27
- const sslkey = urlObj.searchParams.get("sslkey");
28
- // Remove SSL-related query parameters since we parse them ourselves
29
- urlObj.searchParams.delete("sslmode");
30
- urlObj.searchParams.delete("sslrootcert");
31
- urlObj.searchParams.delete("sslcert");
32
- urlObj.searchParams.delete("sslkey");
33
- const cleanedUrl = urlObj.toString();
34
- // Handle different SSL modes
35
- if (sslmode === "disable") {
36
- return { cleanedUrl };
37
- }
38
- if (sslmode === "require" ||
39
- sslmode === "prefer" ||
40
- sslmode === "verify-ca" ||
41
- sslmode === "verify-full") {
42
- // Helper function to get certificate value: query param (file path) takes precedence over env var (content)
43
- const getCertValue = async (queryParam, envVarName) => {
44
- // Prefer query parameter (file path)
45
- if (queryParam) {
46
- try {
47
- return await readFile(queryParam, "utf-8");
48
- }
49
- catch (error) {
50
- throw new Error(`Failed to read certificate file '${queryParam}': ${error instanceof Error ? error.message : String(error)}`);
51
- }
52
- }
53
- // Fallback to environment variable (content)
54
- const envValue = process.env[envVarName];
55
- return envValue || undefined;
56
- };
57
- // Get CA certificate value (needed for verify-ca, verify-full, and libpq compatibility with require/prefer)
58
- const caEnvVar = connectionType === "source"
59
- ? "PGDELTA_SOURCE_SSLROOTCERT"
60
- : "PGDELTA_TARGET_SSLROOTCERT";
61
- const caValue = await getCertValue(sslrootcert, caEnvVar);
62
- // Determine if we should verify the CA chain
63
- // - verify-ca and verify-full: always verify CA
64
- // - require/prefer with CA cert provided: verify CA (libpq backward compatibility)
65
- // From PostgreSQL docs: "if a root CA file exists, the behavior of sslmode=require
66
- // will be the same as that of verify-ca"
67
- const hasExplicitVerification = sslmode === "verify-ca" || sslmode === "verify-full";
68
- const hasLibpqCompatibility = (sslmode === "require" || sslmode === "prefer") && caValue !== undefined;
69
- const shouldVerifyCa = hasExplicitVerification || hasLibpqCompatibility;
70
- // Determine if we should verify hostname
71
- // - verify-full: verify both CA and hostname
72
- // - verify-ca: verify CA only (skip hostname)
73
- // - require/prefer with CA (libpq compat): behaves like verify-ca (skip hostname)
74
- const shouldVerifyHostname = sslmode === "verify-full";
75
- const ssl = {
76
- rejectUnauthorized: shouldVerifyCa,
77
- };
78
- // Add CA certificate if verifying
79
- if (shouldVerifyCa && caValue) {
80
- ssl.ca = caValue;
81
- }
82
- // For verify-ca and libpq compatibility mode: skip hostname verification
83
- // This matches PostgreSQL semantics where verify-ca only checks the CA chain
84
- if (shouldVerifyCa && !shouldVerifyHostname) {
85
- ssl.checkServerIdentity = () => undefined;
86
- }
87
- // Get client certificate (optional, for mutual TLS)
88
- const certEnvVar = connectionType === "source"
89
- ? "PGDELTA_SOURCE_SSLCERT"
90
- : "PGDELTA_TARGET_SSLCERT";
91
- const certValue = await getCertValue(sslcert, certEnvVar);
92
- if (certValue) {
93
- ssl.cert = certValue;
94
- }
95
- // Get client key (optional, for mutual TLS, required if cert is provided)
96
- const keyEnvVar = connectionType === "source"
97
- ? "PGDELTA_SOURCE_SSLKEY"
98
- : "PGDELTA_TARGET_SSLKEY";
99
- const keyValue = await getCertValue(sslkey, keyEnvVar);
100
- if (keyValue) {
101
- ssl.key = keyValue;
102
- }
103
- // Warn if cert is provided without key (or vice versa)
104
- if ((ssl.cert && !ssl.key) || (!ssl.cert && ssl.key)) {
105
- throw new Error("Both client certificate and key must be provided together for mutual TLS");
106
- }
107
- return { ssl, cleanedUrl };
108
- }
109
- // No sslmode specified or invalid value - no SSL configuration
110
- return { cleanedUrl };
17
+ function isResolvedCatalog(input) {
18
+ return (typeof input === "object" &&
19
+ input !== null &&
20
+ typeof input.query !== "function" &&
21
+ "version" in input &&
22
+ "currentUser" in input &&
23
+ "depends" in input &&
24
+ "schemas" in input &&
25
+ "tables" in input &&
26
+ "views" in input);
111
27
  }
28
+ /**
29
+ * Create a migration plan by comparing two catalog states.
30
+ *
31
+ * Each input can be:
32
+ * - A postgres connection URL (string) -- a pool is created and catalog extracted
33
+ * - An existing pg Pool -- catalog is extracted directly
34
+ * - A Catalog instance -- used as-is (e.g. from a deserialized snapshot)
35
+ *
36
+ * When `source` is `null`, a minimal empty catalog (`createEmptyCatalog`) is
37
+ * used as the baseline. For a more accurate baseline, pass a Catalog
38
+ * deserialized from a snapshot of `template1` or another reference database.
39
+ *
40
+ * @param source - Source catalog input (current state), or null for empty baseline
41
+ * @param target - Target catalog input (desired state)
42
+ * @param options - Optional configuration
43
+ * @returns A Plan if there are changes, null if databases are identical
44
+ */
112
45
  export async function createPlan(source, target, options = {}) {
113
- let sourcePool;
114
- let targetPool;
115
- let shouldCloseSource = false;
116
- let shouldCloseTarget = false;
117
- // Suppress expected shutdown errors from idle pool connections (57P01 = admin_shutdown)
118
- const onError = (err) => {
119
- if (err.code !== "57P01") {
120
- console.error("Pool error:", err);
46
+ const resolvePool = async (input, label) => {
47
+ if (typeof input === "string") {
48
+ const managed = await createManagedPool(input, {
49
+ role: options.role,
50
+ label,
51
+ });
52
+ return { pool: managed.pool, shouldClose: true };
121
53
  }
54
+ return { pool: input, shouldClose: false };
122
55
  };
123
- if (typeof source === "string") {
124
- const sslConfig = await parseSslConfig(source, "source");
125
- sourcePool = createPool(sslConfig.cleanedUrl, {
126
- ...(sslConfig.ssl ? { ssl: sslConfig.ssl } : {}),
127
- onError,
128
- onConnect: async (client) => {
129
- // Force fully qualified names in catalog queries
130
- await client.query("SET search_path = ''");
131
- if (options.role) {
132
- await client.query(`SET ROLE ${escapeIdentifier(options.role)}`);
133
- }
134
- },
135
- });
136
- shouldCloseSource = true;
137
- }
138
- else {
139
- sourcePool = source;
140
- }
141
- if (typeof target === "string") {
142
- const sslConfig = await parseSslConfig(target, "target");
143
- targetPool = createPool(sslConfig.cleanedUrl, {
144
- ...(sslConfig.ssl ? { ssl: sslConfig.ssl } : {}),
145
- onError,
146
- onConnect: async (client) => {
147
- // Force fully qualified names in catalog queries
148
- await client.query("SET search_path = ''");
149
- if (options.role) {
150
- await client.query(`SET ROLE ${escapeIdentifier(options.role)}`);
151
- }
152
- },
153
- });
154
- shouldCloseTarget = true;
155
- }
156
- else {
157
- targetPool = target;
158
- }
56
+ /**
57
+ * Resolve a CatalogInput to a Catalog, tracking pools that need cleanup.
58
+ */
59
+ const resolveCatalog = async (input, label, pools) => {
60
+ if (isResolvedCatalog(input)) {
61
+ return input;
62
+ }
63
+ const resolved = await resolvePool(input, label);
64
+ pools.push(resolved);
65
+ return extractCatalog(resolved.pool);
66
+ };
67
+ const pools = [];
159
68
  try {
160
- const [fromCatalog, toCatalog] = await Promise.all([
161
- extractCatalog(sourcePool),
162
- extractCatalog(targetPool),
163
- ]);
69
+ const toCatalog = await resolveCatalog(target, "target", pools);
70
+ const fromCatalog = source !== null
71
+ ? await resolveCatalog(source, "source", pools)
72
+ : await createEmptyCatalog(toCatalog.version, toCatalog.currentUser);
164
73
  return buildPlanForCatalogs(fromCatalog, toCatalog, options);
165
74
  }
166
75
  finally {
167
- const closers = [];
168
- if (shouldCloseSource)
169
- closers.push(sourcePool.end());
170
- if (shouldCloseTarget)
171
- closers.push(targetPool.end());
172
- if (closers.length) {
76
+ const closers = pools
77
+ .filter((p) => p.shouldClose)
78
+ .map((p) => endPool(p.pool));
79
+ if (closers.length)
173
80
  await Promise.all(closers);
174
- }
175
81
  }
176
82
  }
177
83
  /**
@@ -180,6 +86,7 @@ export async function createPlan(source, target, options = {}) {
180
86
  function buildPlanForCatalogs(fromCatalog, toCatalog, options = {}) {
181
87
  const changes = diffCatalogs(fromCatalog, toCatalog, {
182
88
  role: options.role,
89
+ skipDefaultPrivilegeSubtraction: options.skipDefaultPrivilegeSubtraction,
183
90
  });
184
91
  const filterOption = options.filter;
185
92
  const serializeOption = options.serialize;
@@ -195,26 +102,24 @@ function buildPlanForCatalogs(fromCatalog, toCatalog, options = {}) {
195
102
  ? serializeOption
196
103
  : undefined;
197
104
  // Build final integration: compile DSL if needed, use functions directly otherwise
198
- let finalIntegration;
199
- if (filterOption || serializeOption) {
200
- finalIntegration = {
201
- filter: typeof filterOption === "function"
202
- ? filterOption
203
- : filterDSL
204
- ? compileFilterDSL(filterDSL)
205
- : undefined,
206
- serialize: typeof serializeOption === "function"
207
- ? serializeOption
208
- : serializeDSL
209
- ? compileSerializeDSL(serializeDSL)
210
- : undefined,
211
- };
212
- }
105
+ const finalIntegration = resolveIntegration({
106
+ filter: filterOption,
107
+ serialize: serializeOption,
108
+ });
213
109
  // Use filter from final integration
214
110
  const filterFn = finalIntegration?.filter;
215
- const filteredChanges = filterFn
111
+ let filteredChanges = filterFn
216
112
  ? changes.filter((change) => filterFn(change))
217
113
  : changes;
114
+ // Cascade dependency exclusions: when a change is excluded by the filter,
115
+ // also exclude changes that depend on it (via requires or pg_depend).
116
+ // DSL filters: cascade only if explicitly opted in (cascade: true). Function filters: cascade by default.
117
+ const shouldCascade = isFilterDSL
118
+ ? filterDSL?.cascade === true
119
+ : true;
120
+ if (filterFn && filteredChanges.length < changes.length && shouldCascade) {
121
+ filteredChanges = cascadeExclusions(filteredChanges, changes, toCatalog.depends);
122
+ }
218
123
  if (filteredChanges.length === 0) {
219
124
  return null;
220
125
  }
@@ -223,6 +128,84 @@ function buildPlanForCatalogs(fromCatalog, toCatalog, options = {}) {
223
128
  return { plan, sortedChanges, ctx };
224
129
  }
225
130
  // ============================================================================
131
+ // Dependency Cascading
132
+ // ============================================================================
133
+ /**
134
+ * Cascade exclusions through dependency relationships.
135
+ *
136
+ * When a change is excluded by the filter, any change that depends on it
137
+ * (via explicit `requires` or via catalog `pg_depend`) should also be excluded.
138
+ * This runs as a fixpoint loop, bounded by the total number of changes to
139
+ * guarantee deterministic termination.
140
+ *
141
+ * @param filteredChanges - Changes that passed the initial filter
142
+ * @param allChanges - All changes before filtering
143
+ * @param catalogDepends - Dependency rows from the target catalog (pg_depend)
144
+ * @returns The filtered changes with cascading exclusions applied
145
+ */
146
+ function cascadeExclusions(filteredChanges, allChanges, catalogDepends) {
147
+ // Collect stableIds created by initially-excluded changes
148
+ const filteredSet = new Set(filteredChanges);
149
+ const excludedIds = new Set();
150
+ for (const change of allChanges) {
151
+ if (!filteredSet.has(change)) {
152
+ for (const id of change.creates ?? []) {
153
+ excludedIds.add(id);
154
+ }
155
+ }
156
+ }
157
+ if (excludedIds.size === 0) {
158
+ return filteredChanges;
159
+ }
160
+ // Build reverse dependency map: referenced_stable_id -> Set(dependent_stable_ids)
161
+ const catalogDependents = new Map();
162
+ for (const dep of catalogDepends) {
163
+ const existing = catalogDependents.get(dep.referenced_stable_id);
164
+ if (existing) {
165
+ existing.add(dep.dependent_stable_id);
166
+ }
167
+ else {
168
+ catalogDependents.set(dep.referenced_stable_id, new Set([dep.dependent_stable_id]));
169
+ }
170
+ }
171
+ // Fixpoint loop: bounded by total changes to guarantee termination.
172
+ // Each iteration must remove at least one change, otherwise we break.
173
+ let result = filteredChanges;
174
+ for (let i = 0; i < allChanges.length; i++) {
175
+ const beforeLength = result.length;
176
+ result = result.filter((change) => {
177
+ // Check explicit requirements: does this change require an excluded id?
178
+ const requires = change.requires ?? [];
179
+ if (requires.some((dep) => excludedIds.has(dep))) {
180
+ for (const id of change.creates ?? []) {
181
+ excludedIds.add(id);
182
+ }
183
+ return false;
184
+ }
185
+ // Check catalog dependencies: does anything this change creates
186
+ // depend on an excluded id via pg_depend?
187
+ const creates = change.creates ?? [];
188
+ for (const createdId of creates) {
189
+ for (const excludedId of excludedIds) {
190
+ const dependents = catalogDependents.get(excludedId);
191
+ if (dependents?.has(createdId)) {
192
+ for (const id of creates) {
193
+ excludedIds.add(id);
194
+ }
195
+ return false;
196
+ }
197
+ }
198
+ }
199
+ return true;
200
+ });
201
+ // No changes removed this iteration — fixpoint reached
202
+ if (result.length === beforeLength) {
203
+ break;
204
+ }
205
+ }
206
+ return result;
207
+ }
208
+ // ============================================================================
226
209
  // Plan Building
227
210
  // ============================================================================
228
211
  /**
@@ -139,10 +139,22 @@ export function getParentInfo(change) {
139
139
  const parentType = change.index.table_relkind === "m" ? "materialized_view" : "table";
140
140
  return { type: parentType, name: change.index.table_name };
141
141
  }
142
- case "trigger":
143
- return { type: "table", name: change.trigger.table_name };
144
- case "rule":
145
- return { type: "table", name: change.rule.table_name };
142
+ case "trigger": {
143
+ const parentType = change.trigger.table_relkind === "v"
144
+ ? "view"
145
+ : change.trigger.table_relkind === "m"
146
+ ? "materialized_view"
147
+ : "table";
148
+ return { type: parentType, name: change.trigger.table_name };
149
+ }
150
+ case "rule": {
151
+ const parentType = change.rule.relation_kind === "v"
152
+ ? "view"
153
+ : change.rule.relation_kind === "m"
154
+ ? "materialized_view"
155
+ : "table";
156
+ return { type: parentType, name: change.rule.table_name };
157
+ }
146
158
  case "rls_policy":
147
159
  return { type: "table", name: change.policy.table_name };
148
160
  case "aggregate":
@@ -0,0 +1,2 @@
1
+ import type { NormalizedOptions } from "./types.ts";
2
+ export declare const DEFAULT_OPTIONS: NormalizedOptions;
@@ -0,0 +1,11 @@
1
+ export const DEFAULT_OPTIONS = {
2
+ keywordCase: "preserve",
3
+ indent: 2,
4
+ maxWidth: 100,
5
+ commaStyle: "trailing",
6
+ alignColumns: true,
7
+ alignKeyValues: true,
8
+ preserveRoutineBodies: true,
9
+ preserveViewBodies: true,
10
+ preserveRuleBodies: true,
11
+ };
@@ -0,0 +1,2 @@
1
+ import type { SqlFormatOptions } from "../sql-format.ts";
2
+ export declare function renderScript(options?: SqlFormatOptions): string;