mongo-query-normalizer 0.1.0 → 0.2.1

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 (242) hide show
  1. package/README.md +369 -39
  2. package/README.zh-CN.md +363 -44
  3. package/dist/ast/types.d.ts +4 -0
  4. package/dist/ast/types.d.ts.map +1 -1
  5. package/dist/index.d.ts +4 -1
  6. package/dist/index.d.ts.map +1 -1
  7. package/dist/normalize-context.d.ts +5 -1
  8. package/dist/normalize-context.d.ts.map +1 -1
  9. package/dist/normalize-context.js +3 -0
  10. package/dist/normalize-context.js.map +1 -1
  11. package/dist/normalize.d.ts +1 -1
  12. package/dist/normalize.d.ts.map +1 -1
  13. package/dist/normalize.js +105 -52
  14. package/dist/normalize.js.map +1 -1
  15. package/dist/options/constants.d.ts.map +1 -1
  16. package/dist/options/constants.js +7 -16
  17. package/dist/options/constants.js.map +1 -1
  18. package/dist/options/resolve.d.ts.map +1 -1
  19. package/dist/options/resolve.js +32 -1
  20. package/dist/options/resolve.js.map +1 -1
  21. package/dist/options/types.d.ts +1 -1
  22. package/dist/options/types.d.ts.map +1 -1
  23. package/dist/passes/normalize-predicate.d.ts.map +1 -1
  24. package/dist/passes/normalize-predicate.js +93 -14
  25. package/dist/passes/normalize-predicate.js.map +1 -1
  26. package/dist/predicate/analysis/detect-array-sensitive.d.ts +3 -0
  27. package/dist/predicate/analysis/detect-array-sensitive.d.ts.map +1 -0
  28. package/dist/predicate/analysis/detect-array-sensitive.js +33 -0
  29. package/dist/predicate/analysis/detect-array-sensitive.js.map +1 -0
  30. package/dist/predicate/analysis/detect-null-sensitive.d.ts +3 -0
  31. package/dist/predicate/analysis/detect-null-sensitive.d.ts.map +1 -0
  32. package/dist/predicate/analysis/detect-null-sensitive.js +24 -0
  33. package/dist/predicate/analysis/detect-null-sensitive.js.map +1 -0
  34. package/dist/predicate/analysis/detect-opaque-mix.d.ts +3 -0
  35. package/dist/predicate/analysis/detect-opaque-mix.d.ts.map +1 -0
  36. package/dist/predicate/analysis/detect-opaque-mix.js +9 -0
  37. package/dist/predicate/analysis/detect-opaque-mix.js.map +1 -0
  38. package/dist/predicate/analysis/detect-path-conflict-risk.d.ts +3 -0
  39. package/dist/predicate/analysis/detect-path-conflict-risk.d.ts.map +1 -0
  40. package/dist/predicate/analysis/detect-path-conflict-risk.js +14 -0
  41. package/dist/predicate/analysis/detect-path-conflict-risk.js.map +1 -0
  42. package/dist/predicate/analysis/merge-range-bounds.d.ts +27 -0
  43. package/dist/predicate/analysis/merge-range-bounds.d.ts.map +1 -0
  44. package/dist/predicate/analysis/merge-range-bounds.js +150 -0
  45. package/dist/predicate/analysis/merge-range-bounds.js.map +1 -0
  46. package/dist/predicate/capabilities/eq/eq-eq.d.ts +3 -0
  47. package/dist/predicate/capabilities/eq/eq-eq.d.ts.map +1 -0
  48. package/dist/predicate/capabilities/eq/eq-eq.js +53 -0
  49. package/dist/predicate/capabilities/eq/eq-eq.js.map +1 -0
  50. package/dist/predicate/capabilities/eq/eq-in.d.ts +3 -0
  51. package/dist/predicate/capabilities/eq/eq-in.d.ts.map +1 -0
  52. package/dist/predicate/capabilities/eq/eq-in.js +117 -0
  53. package/dist/predicate/capabilities/eq/eq-in.js.map +1 -0
  54. package/dist/predicate/capabilities/eq/eq-ne.d.ts +3 -0
  55. package/dist/predicate/capabilities/eq/eq-ne.d.ts.map +1 -0
  56. package/dist/predicate/capabilities/eq/eq-ne.js +37 -0
  57. package/dist/predicate/capabilities/eq/eq-ne.js.map +1 -0
  58. package/dist/predicate/capabilities/eq/eq-range.d.ts +3 -0
  59. package/dist/predicate/capabilities/eq/eq-range.d.ts.map +1 -0
  60. package/dist/predicate/capabilities/eq/eq-range.js +138 -0
  61. package/dist/predicate/capabilities/eq/eq-range.js.map +1 -0
  62. package/dist/predicate/capabilities/ne/ne-ne.d.ts +3 -0
  63. package/dist/predicate/capabilities/ne/ne-ne.d.ts.map +1 -0
  64. package/dist/predicate/capabilities/ne/ne-ne.js +44 -0
  65. package/dist/predicate/capabilities/ne/ne-ne.js.map +1 -0
  66. package/dist/predicate/capabilities/nin/nin-nin.d.ts +3 -0
  67. package/dist/predicate/capabilities/nin/nin-nin.d.ts.map +1 -0
  68. package/dist/predicate/capabilities/nin/nin-nin.js +45 -0
  69. package/dist/predicate/capabilities/nin/nin-nin.js.map +1 -0
  70. package/dist/predicate/capabilities/range/range-range.d.ts +3 -0
  71. package/dist/predicate/capabilities/range/range-range.d.ts.map +1 -0
  72. package/dist/predicate/capabilities/range/range-range.js +154 -0
  73. package/dist/predicate/capabilities/range/range-range.js.map +1 -0
  74. package/dist/predicate/capabilities/shared/capability-types.d.ts +11 -0
  75. package/dist/predicate/capabilities/shared/capability-types.d.ts.map +1 -0
  76. package/dist/predicate/capabilities/shared/capability-types.js +3 -0
  77. package/dist/predicate/capabilities/shared/capability-types.js.map +1 -0
  78. package/dist/predicate/capabilities/shared/relation-context.d.ts +13 -0
  79. package/dist/predicate/capabilities/shared/relation-context.d.ts.map +1 -0
  80. package/dist/predicate/capabilities/shared/relation-context.js +3 -0
  81. package/dist/predicate/capabilities/shared/relation-context.js.map +1 -0
  82. package/dist/predicate/capabilities/shared/relation-result.d.ts +12 -0
  83. package/dist/predicate/capabilities/shared/relation-result.d.ts.map +1 -0
  84. package/dist/predicate/capabilities/shared/relation-result.js +14 -0
  85. package/dist/predicate/capabilities/shared/relation-result.js.map +1 -0
  86. package/dist/predicate/index.d.ts +12 -0
  87. package/dist/predicate/index.d.ts.map +1 -0
  88. package/dist/predicate/index.js +22 -0
  89. package/dist/predicate/index.js.map +1 -0
  90. package/dist/predicate/ir/build-field-bundle.d.ts +7 -0
  91. package/dist/predicate/ir/build-field-bundle.d.ts.map +1 -0
  92. package/dist/predicate/ir/build-field-bundle.js +88 -0
  93. package/dist/predicate/ir/build-field-bundle.js.map +1 -0
  94. package/dist/predicate/ir/compile-field-bundle.d.ts +4 -0
  95. package/dist/predicate/ir/compile-field-bundle.d.ts.map +1 -0
  96. package/dist/predicate/ir/compile-field-bundle.js +57 -0
  97. package/dist/predicate/ir/compile-field-bundle.js.map +1 -0
  98. package/dist/predicate/ir/dedupe-atoms.d.ts +6 -0
  99. package/dist/predicate/ir/dedupe-atoms.d.ts.map +1 -0
  100. package/dist/predicate/ir/dedupe-atoms.js +42 -0
  101. package/dist/predicate/ir/dedupe-atoms.js.map +1 -0
  102. package/dist/predicate/ir/field-predicate-bundle.d.ts +16 -0
  103. package/dist/predicate/ir/field-predicate-bundle.d.ts.map +1 -0
  104. package/dist/predicate/ir/field-predicate-bundle.js +3 -0
  105. package/dist/predicate/ir/field-predicate-bundle.js.map +1 -0
  106. package/dist/predicate/ir/predicate-atom.d.ts +33 -0
  107. package/dist/predicate/ir/predicate-atom.d.ts.map +1 -0
  108. package/dist/predicate/ir/predicate-atom.js +3 -0
  109. package/dist/predicate/ir/predicate-atom.js.map +1 -0
  110. package/dist/predicate/local-normalize-result.d.ts +17 -0
  111. package/dist/predicate/local-normalize-result.d.ts.map +1 -0
  112. package/dist/predicate/local-normalize-result.js +3 -0
  113. package/dist/predicate/local-normalize-result.js.map +1 -0
  114. package/dist/predicate/meta/collect-predicate-meta.d.ts +16 -0
  115. package/dist/predicate/meta/collect-predicate-meta.d.ts.map +1 -0
  116. package/dist/predicate/meta/collect-predicate-meta.js +13 -0
  117. package/dist/predicate/meta/collect-predicate-meta.js.map +1 -0
  118. package/dist/predicate/normalize-field-predicate-bundle.d.ts +18 -0
  119. package/dist/predicate/normalize-field-predicate-bundle.d.ts.map +1 -0
  120. package/dist/predicate/normalize-field-predicate-bundle.js +126 -0
  121. package/dist/predicate/normalize-field-predicate-bundle.js.map +1 -0
  122. package/dist/predicate/normalize-predicate.d.ts +5 -0
  123. package/dist/predicate/normalize-predicate.d.ts.map +1 -0
  124. package/dist/predicate/normalize-predicate.js +10 -0
  125. package/dist/predicate/normalize-predicate.js.map +1 -0
  126. package/dist/predicate/planner/capability-selector.d.ts +8 -0
  127. package/dist/predicate/planner/capability-selector.d.ts.map +1 -0
  128. package/dist/predicate/planner/capability-selector.js +23 -0
  129. package/dist/predicate/planner/capability-selector.js.map +1 -0
  130. package/dist/predicate/planner/relation-plan.d.ts +10 -0
  131. package/dist/predicate/planner/relation-plan.d.ts.map +1 -0
  132. package/dist/predicate/planner/relation-plan.js +3 -0
  133. package/dist/predicate/planner/relation-plan.js.map +1 -0
  134. package/dist/predicate/planner/relation-planner.d.ts +5 -0
  135. package/dist/predicate/planner/relation-planner.d.ts.map +1 -0
  136. package/dist/predicate/planner/relation-planner.js +62 -0
  137. package/dist/predicate/planner/relation-planner.js.map +1 -0
  138. package/dist/predicate/registry/predicate-capability-registry.d.ts +3 -0
  139. package/dist/predicate/registry/predicate-capability-registry.d.ts.map +1 -0
  140. package/dist/predicate/registry/predicate-capability-registry.js +23 -0
  141. package/dist/predicate/registry/predicate-capability-registry.js.map +1 -0
  142. package/dist/predicate/safety/predicate-safety-policy.d.ts +9 -0
  143. package/dist/predicate/safety/predicate-safety-policy.d.ts.map +1 -0
  144. package/dist/predicate/safety/predicate-safety-policy.js +11 -0
  145. package/dist/predicate/safety/predicate-safety-policy.js.map +1 -0
  146. package/dist/predicate/utils/bson-compare.d.ts +2 -0
  147. package/dist/predicate/utils/bson-compare.d.ts.map +1 -0
  148. package/dist/predicate/utils/bson-compare.js +7 -0
  149. package/dist/predicate/utils/bson-compare.js.map +1 -0
  150. package/dist/predicate/utils/intersect-in-lists.d.ts +5 -0
  151. package/dist/predicate/utils/intersect-in-lists.d.ts.map +1 -0
  152. package/dist/predicate/utils/intersect-in-lists.js +15 -0
  153. package/dist/predicate/utils/intersect-in-lists.js.map +1 -0
  154. package/dist/predicate/utils/set-ops.d.ts +3 -0
  155. package/dist/predicate/utils/set-ops.d.ts.map +1 -0
  156. package/dist/predicate/utils/set-ops.js +18 -0
  157. package/dist/predicate/utils/set-ops.js.map +1 -0
  158. package/dist/predicate/utils/value-equality.d.ts +2 -0
  159. package/dist/predicate/utils/value-equality.d.ts.map +1 -0
  160. package/dist/predicate/utils/value-equality.js +8 -0
  161. package/dist/predicate/utils/value-equality.js.map +1 -0
  162. package/dist/rules/or-common-predicate/detect-common-predicates-in-or.d.ts +6 -0
  163. package/dist/rules/or-common-predicate/detect-common-predicates-in-or.d.ts.map +1 -0
  164. package/dist/rules/or-common-predicate/detect-common-predicates-in-or.js +83 -0
  165. package/dist/rules/or-common-predicate/detect-common-predicates-in-or.js.map +1 -0
  166. package/dist/rules/shape/collapse-single-child-logical.js +1 -1
  167. package/dist/rules/shape/collapse-single-child-logical.js.map +1 -1
  168. package/dist/rules/shape/dedupe-logical-children.js +1 -1
  169. package/dist/rules/shape/dedupe-logical-children.js.map +1 -1
  170. package/dist/rules/shape/flatten-logical.js +2 -2
  171. package/dist/rules/shape/flatten-logical.js.map +1 -1
  172. package/dist/rules/shape/remove-empty-logical.js +2 -2
  173. package/dist/rules/shape/remove-empty-logical.js.map +1 -1
  174. package/dist/scope/analysis/analyze-branch-coverage.d.ts +5 -0
  175. package/dist/scope/analysis/analyze-branch-coverage.d.ts.map +1 -0
  176. package/dist/scope/analysis/analyze-branch-coverage.js +8 -0
  177. package/dist/scope/analysis/analyze-branch-coverage.js.map +1 -0
  178. package/dist/scope/analysis/analyze-branch-satisfiability.d.ts +9 -0
  179. package/dist/scope/analysis/analyze-branch-satisfiability.d.ts.map +1 -0
  180. package/dist/scope/analysis/analyze-branch-satisfiability.js +33 -0
  181. package/dist/scope/analysis/analyze-branch-satisfiability.js.map +1 -0
  182. package/dist/scope/context/build-inherited-constraints.d.ts +6 -0
  183. package/dist/scope/context/build-inherited-constraints.d.ts.map +1 -0
  184. package/dist/scope/context/build-inherited-constraints.js +119 -0
  185. package/dist/scope/context/build-inherited-constraints.js.map +1 -0
  186. package/dist/scope/context/constraint-set.d.ts +19 -0
  187. package/dist/scope/context/constraint-set.d.ts.map +1 -0
  188. package/dist/scope/context/constraint-set.js +26 -0
  189. package/dist/scope/context/constraint-set.js.map +1 -0
  190. package/dist/scope/context/merge-constraint-sources.d.ts +4 -0
  191. package/dist/scope/context/merge-constraint-sources.d.ts.map +1 -0
  192. package/dist/scope/context/merge-constraint-sources.js +28 -0
  193. package/dist/scope/context/merge-constraint-sources.js.map +1 -0
  194. package/dist/scope/index.d.ts +8 -0
  195. package/dist/scope/index.d.ts.map +1 -0
  196. package/dist/scope/index.js +19 -0
  197. package/dist/scope/index.js.map +1 -0
  198. package/dist/scope/meta/collect-scope-meta.d.ts +5 -0
  199. package/dist/scope/meta/collect-scope-meta.d.ts.map +1 -0
  200. package/dist/scope/meta/collect-scope-meta.js +7 -0
  201. package/dist/scope/meta/collect-scope-meta.js.map +1 -0
  202. package/dist/scope/normalize-scope.d.ts +4 -0
  203. package/dist/scope/normalize-scope.d.ts.map +1 -0
  204. package/dist/scope/normalize-scope.js +149 -0
  205. package/dist/scope/normalize-scope.js.map +1 -0
  206. package/dist/scope/planner/scope-plan.d.ts +6 -0
  207. package/dist/scope/planner/scope-plan.d.ts.map +1 -0
  208. package/dist/scope/planner/scope-plan.js +9 -0
  209. package/dist/scope/planner/scope-plan.js.map +1 -0
  210. package/dist/scope/planner/scope-rewrite-planner.d.ts +4 -0
  211. package/dist/scope/planner/scope-rewrite-planner.d.ts.map +1 -0
  212. package/dist/scope/planner/scope-rewrite-planner.js +8 -0
  213. package/dist/scope/planner/scope-rewrite-planner.js.map +1 -0
  214. package/dist/scope/propagation/create-branch-local-bundle.d.ts +5 -0
  215. package/dist/scope/propagation/create-branch-local-bundle.d.ts.map +1 -0
  216. package/dist/scope/propagation/create-branch-local-bundle.js +16 -0
  217. package/dist/scope/propagation/create-branch-local-bundle.js.map +1 -0
  218. package/dist/scope/propagation/propagate-constraints-to-children.d.ts +6 -0
  219. package/dist/scope/propagation/propagate-constraints-to-children.d.ts.map +1 -0
  220. package/dist/scope/propagation/propagate-constraints-to-children.js +9 -0
  221. package/dist/scope/propagation/propagate-constraints-to-children.js.map +1 -0
  222. package/dist/scope/rewrite/collapse-single-branch.d.ts +5 -0
  223. package/dist/scope/rewrite/collapse-single-branch.d.ts.map +1 -0
  224. package/dist/scope/rewrite/collapse-single-branch.js +28 -0
  225. package/dist/scope/rewrite/collapse-single-branch.js.map +1 -0
  226. package/dist/scope/rewrite/prune-impossible-branches.d.ts +6 -0
  227. package/dist/scope/rewrite/prune-impossible-branches.d.ts.map +1 -0
  228. package/dist/scope/rewrite/prune-impossible-branches.js +32 -0
  229. package/dist/scope/rewrite/prune-impossible-branches.js.map +1 -0
  230. package/dist/scope/rewrite/remove-covered-local-constraints.d.ts +6 -0
  231. package/dist/scope/rewrite/remove-covered-local-constraints.d.ts.map +1 -0
  232. package/dist/scope/rewrite/remove-covered-local-constraints.js +76 -0
  233. package/dist/scope/rewrite/remove-covered-local-constraints.js.map +1 -0
  234. package/dist/scope/safety/scope-safety-policy.d.ts +10 -0
  235. package/dist/scope/safety/scope-safety-policy.d.ts.map +1 -0
  236. package/dist/scope/safety/scope-safety-policy.js +12 -0
  237. package/dist/scope/safety/scope-safety-policy.js.map +1 -0
  238. package/dist/types.d.ts +70 -2
  239. package/dist/types.d.ts.map +1 -1
  240. package/dist/types.js +2 -1
  241. package/dist/types.js.map +1 -1
  242. package/package.json +6 -4
@@ -0,0 +1,5 @@
1
+ import type { PredicateCapability } from "../capabilities/shared/capability-types";
2
+ import type { RelationContext } from "../capabilities/shared/relation-context";
3
+ import type { RelationPlan } from "./relation-plan";
4
+ export declare function planRelations(orderedCapabilities: PredicateCapability[], ctx: RelationContext): RelationPlan;
5
+ //# sourceMappingURL=relation-planner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"relation-planner.d.ts","sourceRoot":"","sources":["../../../src/predicate/planner/relation-planner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AACnF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAC;AAE/E,OAAO,KAAK,EAAE,YAAY,EAAqB,MAAM,iBAAiB,CAAC;AAsBvE,wBAAgB,aAAa,CAAC,mBAAmB,EAAE,mBAAmB,EAAE,EAAE,GAAG,EAAE,eAAe,GAAG,YAAY,CA6C5G"}
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.planRelations = planRelations;
4
+ const build_field_bundle_1 = require("../ir/build-field-bundle");
5
+ const capability_selector_1 = require("./capability-selector");
6
+ const DEFAULT_CAPABILITY_ORDER = ["eq.eq", "eq.ne", "ne.ne", "nin.nin", "eq.in", "range.range", "eq.range"];
7
+ function orderCapabilities(caps) {
8
+ const byId = new Map(caps.map((c) => [c.id, c]));
9
+ const ordered = [];
10
+ for (const id of DEFAULT_CAPABILITY_ORDER) {
11
+ const cap = byId.get(id);
12
+ if (cap) {
13
+ ordered.push(cap);
14
+ }
15
+ }
16
+ for (const cap of caps) {
17
+ if (!DEFAULT_CAPABILITY_ORDER.includes(cap.id)) {
18
+ ordered.push(cap);
19
+ }
20
+ }
21
+ return ordered;
22
+ }
23
+ function planRelations(orderedCapabilities, ctx) {
24
+ const skippedCapabilities = [];
25
+ if (ctx.safety.bailoutOnUnsupportedMix && (0, build_field_bundle_1.detectUnsupportedMix)(ctx.bundle)) {
26
+ for (const cap of orderedCapabilities) {
27
+ skippedCapabilities.push({
28
+ id: cap.id,
29
+ reason: "unsupported opaque mix in bundle",
30
+ });
31
+ }
32
+ return { capabilities: [], skippedCapabilities };
33
+ }
34
+ const ordered = orderCapabilities(orderedCapabilities);
35
+ const selected = [];
36
+ for (const cap of ordered) {
37
+ if (!(0, capability_selector_1.isCapabilityCandidate)(cap, ctx)) {
38
+ skippedCapabilities.push({
39
+ id: cap.id,
40
+ reason: "no supporting atom kinds in bundle",
41
+ });
42
+ continue;
43
+ }
44
+ if (cap.id === "eq.in" && ctx.bundle.metadata.hasArraySensitiveSemantics && !ctx.safety.allowArraySensitiveRewrite) {
45
+ skippedCapabilities.push({
46
+ id: cap.id,
47
+ reason: "array-sensitive rewrite disabled",
48
+ });
49
+ continue;
50
+ }
51
+ if (cap.id === "eq.in" && ctx.bundle.metadata.hasNullSemantics && !ctx.safety.allowNullSemanticRewrite) {
52
+ skippedCapabilities.push({
53
+ id: cap.id,
54
+ reason: "null semantic rewrite disabled",
55
+ });
56
+ continue;
57
+ }
58
+ selected.push(cap);
59
+ }
60
+ return { capabilities: selected, skippedCapabilities };
61
+ }
62
+ //# sourceMappingURL=relation-planner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"relation-planner.js","sourceRoot":"","sources":["../../../src/predicate/planner/relation-planner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { PredicateCapability } from "../capabilities/shared/capability-types";
2
+ export declare function getDefaultPredicateCapabilities(): PredicateCapability[];
3
+ //# sourceMappingURL=predicate-capability-registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"predicate-capability-registry.d.ts","sourceRoot":"","sources":["../../../src/predicate/registry/predicate-capability-registry.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AAYnF,wBAAgB,+BAA+B,IAAI,mBAAmB,EAAE,CAEvE"}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getDefaultPredicateCapabilities = getDefaultPredicateCapabilities;
4
+ const eq_eq_1 = require("../capabilities/eq/eq-eq");
5
+ const eq_in_1 = require("../capabilities/eq/eq-in");
6
+ const eq_ne_1 = require("../capabilities/eq/eq-ne");
7
+ const eq_range_1 = require("../capabilities/eq/eq-range");
8
+ const range_range_1 = require("../capabilities/range/range-range");
9
+ const ne_ne_1 = require("../capabilities/ne/ne-ne");
10
+ const nin_nin_1 = require("../capabilities/nin/nin-nin");
11
+ const DEFAULT_CAPABILITIES = [
12
+ eq_eq_1.eqEqCapability,
13
+ eq_ne_1.eqNeCapability,
14
+ ne_ne_1.neNeCapability,
15
+ nin_nin_1.ninNinCapability,
16
+ eq_in_1.eqInCapability,
17
+ eq_range_1.eqRangeCapability,
18
+ range_range_1.rangeRangeCapability,
19
+ ];
20
+ function getDefaultPredicateCapabilities() {
21
+ return [...DEFAULT_CAPABILITIES];
22
+ }
23
+ //# sourceMappingURL=predicate-capability-registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"predicate-capability-registry.js","sourceRoot":"","sources":["../../../src/predicate/registry/predicate-capability-registry.ts"],"names":[],"mappings":";;AAmBA,0EAEC;AArBD,oDAA0D;AAC1D,oDAA0D;AAC1D,oDAA0D;AAC1D,0DAAgE;AAChE,mEAAyE;AACzE,oDAA0D;AAC1D,yDAA+D;AAG/D,MAAM,oBAAoB,GAA0B;IAChD,sBAAc;IACd,sBAAc;IACd,sBAAc;IACd,0BAAgB;IAChB,sBAAc;IACd,4BAAiB;IACjB,kCAAoB;CACvB,CAAC;AAEF,SAAgB,+BAA+B;IAC3C,OAAO,CAAC,GAAG,oBAAoB,CAAC,CAAC;AACrC,CAAC"}
@@ -0,0 +1,9 @@
1
+ export type PredicateSafetyPolicy = {
2
+ allowArraySensitiveRewrite: boolean;
3
+ allowNullSemanticRewrite: boolean;
4
+ allowExistsSemanticRewrite: boolean;
5
+ allowPathConflictRewrite: boolean;
6
+ bailoutOnUnsupportedMix: boolean;
7
+ };
8
+ export declare const DEFAULT_PREDICATE_SAFETY_POLICY: PredicateSafetyPolicy;
9
+ //# sourceMappingURL=predicate-safety-policy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"predicate-safety-policy.d.ts","sourceRoot":"","sources":["../../../src/predicate/safety/predicate-safety-policy.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,qBAAqB,GAAG;IAChC,0BAA0B,EAAE,OAAO,CAAC;IACpC,wBAAwB,EAAE,OAAO,CAAC;IAClC,0BAA0B,EAAE,OAAO,CAAC;IACpC,wBAAwB,EAAE,OAAO,CAAC;IAClC,uBAAuB,EAAE,OAAO,CAAC;CACpC,CAAC;AAEF,eAAO,MAAM,+BAA+B,EAAE,qBAM7C,CAAC"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DEFAULT_PREDICATE_SAFETY_POLICY = void 0;
4
+ exports.DEFAULT_PREDICATE_SAFETY_POLICY = {
5
+ allowArraySensitiveRewrite: false,
6
+ allowNullSemanticRewrite: false,
7
+ allowExistsSemanticRewrite: false,
8
+ allowPathConflictRewrite: false,
9
+ bailoutOnUnsupportedMix: true,
10
+ };
11
+ //# sourceMappingURL=predicate-safety-policy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"predicate-safety-policy.js","sourceRoot":"","sources":["../../../src/predicate/safety/predicate-safety-policy.ts"],"names":[],"mappings":";;;AAQa,QAAA,+BAA+B,GAA0B;IAClE,0BAA0B,EAAE,KAAK;IACjC,wBAAwB,EAAE,KAAK;IAC/B,0BAA0B,EAAE,KAAK;IACjC,wBAAwB,EAAE,KAAK;IAC/B,uBAAuB,EAAE,IAAI;CAChC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { compareScalarValues, isComparableScalar } from "../../utils/compare-values";
2
+ //# sourceMappingURL=bson-compare.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bson-compare.d.ts","sourceRoot":"","sources":["../../../src/predicate/utils/bson-compare.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC"}
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isComparableScalar = exports.compareScalarValues = void 0;
4
+ var compare_values_1 = require("../../utils/compare-values");
5
+ Object.defineProperty(exports, "compareScalarValues", { enumerable: true, get: function () { return compare_values_1.compareScalarValues; } });
6
+ Object.defineProperty(exports, "isComparableScalar", { enumerable: true, get: function () { return compare_values_1.isComparableScalar; } });
7
+ //# sourceMappingURL=bson-compare.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bson-compare.js","sourceRoot":"","sources":["../../../src/predicate/utils/bson-compare.ts"],"names":[],"mappings":";;;AAAA,6DAAqF;AAA5E,qHAAA,mBAAmB,OAAA;AAAE,oHAAA,kBAAkB,OAAA"}
@@ -0,0 +1,5 @@
1
+ import type { PredicateAtom } from "../ir/predicate-atom";
2
+ export declare function intersectInAtomValues(ins: Extract<PredicateAtom, {
3
+ kind: "in";
4
+ }>[]): unknown[];
5
+ //# sourceMappingURL=intersect-in-lists.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"intersect-in-lists.d.ts","sourceRoot":"","sources":["../../../src/predicate/utils/intersect-in-lists.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG1D,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,OAAO,CAAC,aAAa,EAAE;IAAE,IAAI,EAAE,IAAI,CAAA;CAAE,CAAC,EAAE,GAAG,OAAO,EAAE,CAS9F"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.intersectInAtomValues = intersectInAtomValues;
4
+ const value_equality_1 = require("./value-equality");
5
+ function intersectInAtomValues(ins) {
6
+ if (ins.length === 0) {
7
+ return [];
8
+ }
9
+ let acc = [...ins[0].values];
10
+ for (let i = 1; i < ins.length; i++) {
11
+ acc = acc.filter((x) => ins[i].values.some((y) => (0, value_equality_1.valuesEqual)(x, y)));
12
+ }
13
+ return acc;
14
+ }
15
+ //# sourceMappingURL=intersect-in-lists.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"intersect-in-lists.js","sourceRoot":"","sources":["../../../src/predicate/utils/intersect-in-lists.ts"],"names":[],"mappings":";;AAGA,sDASC;AAXD,qDAA+C;AAE/C,SAAgB,qBAAqB,CAAC,GAA6C;IAC/E,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnB,OAAO,EAAE,CAAC;IACd,CAAC;IACD,IAAI,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAClC,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,4BAAW,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1E,CAAC;IACD,OAAO,GAAG,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function uniqueUnknownArray(values: unknown[]): unknown[];
2
+ export declare function intersectUnknownArrays(a: unknown[], b: unknown[]): unknown[];
3
+ //# sourceMappingURL=set-ops.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"set-ops.d.ts","sourceRoot":"","sources":["../../../src/predicate/utils/set-ops.ts"],"names":[],"mappings":"AAEA,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAQ/D;AAED,wBAAgB,sBAAsB,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAE5E"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.uniqueUnknownArray = uniqueUnknownArray;
4
+ exports.intersectUnknownArrays = intersectUnknownArrays;
5
+ const value_equality_1 = require("./value-equality");
6
+ function uniqueUnknownArray(values) {
7
+ const result = [];
8
+ for (const v of values) {
9
+ if (!result.some((x) => (0, value_equality_1.valuesEqual)(x, v))) {
10
+ result.push(v);
11
+ }
12
+ }
13
+ return result;
14
+ }
15
+ function intersectUnknownArrays(a, b) {
16
+ return a.filter((x) => b.some((y) => (0, value_equality_1.valuesEqual)(x, y)));
17
+ }
18
+ //# sourceMappingURL=set-ops.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"set-ops.js","sourceRoot":"","sources":["../../../src/predicate/utils/set-ops.ts"],"names":[],"mappings":";;AAEA,gDAQC;AAED,wDAEC;AAdD,qDAA+C;AAE/C,SAAgB,kBAAkB,CAAC,MAAiB;IAChD,MAAM,MAAM,GAAc,EAAE,CAAC;IAC7B,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,4BAAW,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACzC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACnB,CAAC;IACL,CAAC;IACD,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,SAAgB,sBAAsB,CAAC,CAAY,EAAE,CAAY;IAC7D,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,4BAAW,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;AAC7D,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function valuesEqual(a: unknown, b: unknown): boolean;
2
+ //# sourceMappingURL=value-equality.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"value-equality.d.ts","sourceRoot":"","sources":["../../../src/predicate/utils/value-equality.ts"],"names":[],"mappings":"AAEA,wBAAgB,WAAW,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,GAAG,OAAO,CAE3D"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.valuesEqual = valuesEqual;
4
+ const deep_equal_1 = require("../../utils/deep-equal");
5
+ function valuesEqual(a, b) {
6
+ return (0, deep_equal_1.deepEqual)(a, b);
7
+ }
8
+ //# sourceMappingURL=value-equality.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"value-equality.js","sourceRoot":"","sources":["../../../src/predicate/utils/value-equality.ts"],"names":[],"mappings":";;AAEA,kCAEC;AAJD,uDAAmD;AAEnD,SAAgB,WAAW,CAAC,CAAU,EAAE,CAAU;IAC9C,OAAO,IAAA,sBAAS,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAC3B,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { QueryNode } from "../../ast/types";
2
+ import type { NormalizeContext } from "../../normalize-context";
3
+ /** $or 分支间公共 field 谓词检测(`scope` 层可选规则,由 `rules.detectCommonPredicatesInOr` 控制;仅告警,不改写结构)。 */
4
+ export declare const RULE_ID = "orCommonPredicate.detectCommonPredicatesInOr";
5
+ export declare function detectCommonPredicatesInOr(node: QueryNode, normalizeContext: NormalizeContext): QueryNode;
6
+ //# sourceMappingURL=detect-common-predicates-in-or.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"detect-common-predicates-in-or.d.ts","sourceRoot":"","sources":["../../../src/rules/or-common-predicate/detect-common-predicates-in-or.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAe,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAGhE,6FAA6F;AAC7F,eAAO,MAAM,OAAO,iDAAiD,CAAC;AAEtE,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,gBAAgB,GAAG,SAAS,CAYzG"}
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RULE_ID = void 0;
4
+ exports.detectCommonPredicatesInOr = detectCommonPredicatesInOr;
5
+ const builders_1 = require("../../ast/builders");
6
+ const hash_1 = require("../../ast/hash");
7
+ const guards_1 = require("../../ast/guards");
8
+ const warnings_1 = require("../../observe/warnings");
9
+ /** $or 分支间公共 field 谓词检测(`scope` 层可选规则,由 `rules.detectCommonPredicatesInOr` 控制;仅告警,不改写结构)。 */
10
+ exports.RULE_ID = "orCommonPredicate.detectCommonPredicatesInOr";
11
+ function detectCommonPredicatesInOr(node, normalizeContext) {
12
+ if (!(0, guards_1.isLogicalNode)(node)) {
13
+ return node;
14
+ }
15
+ if (node.op === "$or") {
16
+ detectCommonPredicates(node, normalizeContext);
17
+ }
18
+ const nextChildren = node.children.map((child) => detectCommonPredicatesInOr(child, normalizeContext));
19
+ return node.op === "$and" ? (0, builders_1.andNode)(nextChildren) : (0, builders_1.orNode)(nextChildren);
20
+ }
21
+ function detectCommonPredicates(node, normalizeContext) {
22
+ const maps = node.children.map((branch) => extractComparableFieldPredicates(branch));
23
+ const common = intersectPredicateMaps(maps);
24
+ if (common.size === 0) {
25
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "no common predicates found in $or");
26
+ return;
27
+ }
28
+ (0, warnings_1.markRuleApplied)(normalizeContext, exports.RULE_ID);
29
+ (0, warnings_1.addWarning)(normalizeContext, `common predicates detected in $or: ${formatPredicateMap(common)}`);
30
+ }
31
+ function extractComparableFieldPredicates(node) {
32
+ const map = new Map();
33
+ if ((0, guards_1.isFieldNode)(node)) {
34
+ const safe = node.predicates
35
+ .filter((p) => !p.opaque && p.op !== "raw")
36
+ .map((p) => (0, hash_1.hashPredicate)(p));
37
+ if (safe.length > 0) {
38
+ map.set(node.field, safe);
39
+ }
40
+ return map;
41
+ }
42
+ if ((0, guards_1.isLogicalNode)(node) && node.op === "$and") {
43
+ for (const child of node.children) {
44
+ if (!(0, guards_1.isFieldNode)(child)) {
45
+ continue;
46
+ }
47
+ const safe = child.predicates
48
+ .filter((p) => !p.opaque && p.op !== "raw")
49
+ .map((p) => (0, hash_1.hashPredicate)(p));
50
+ if (safe.length > 0) {
51
+ map.set(child.field, safe);
52
+ }
53
+ }
54
+ }
55
+ return map;
56
+ }
57
+ function intersectPredicateMaps(maps) {
58
+ if (maps.length === 0) {
59
+ return new Map();
60
+ }
61
+ const result = new Map(maps[0]);
62
+ for (let i = 1; i < maps.length; i += 1) {
63
+ for (const [field, predicates] of [...result.entries()]) {
64
+ const other = maps[i].get(field);
65
+ if (!other) {
66
+ result.delete(field);
67
+ continue;
68
+ }
69
+ const intersection = predicates.filter((p) => other.includes(p));
70
+ if (intersection.length === 0) {
71
+ result.delete(field);
72
+ }
73
+ else {
74
+ result.set(field, intersection);
75
+ }
76
+ }
77
+ }
78
+ return result;
79
+ }
80
+ function formatPredicateMap(common) {
81
+ return JSON.stringify([...common.entries()]);
82
+ }
83
+ //# sourceMappingURL=detect-common-predicates-in-or.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"detect-common-predicates-in-or.js","sourceRoot":"","sources":["../../../src/rules/or-common-predicate/detect-common-predicates-in-or.ts"],"names":[],"mappings":"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"}
@@ -7,7 +7,7 @@ const warnings_1 = require("../../observe/warnings");
7
7
  exports.RULE_ID = "shape.collapseSingleChildLogical";
8
8
  function collapseSingleChildLogical(node, normalizeContext) {
9
9
  if (!(0, guards_1.isLogicalNode)(node)) {
10
- (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not logical");
10
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not a compound ($and/$or) node");
11
11
  return node;
12
12
  }
13
13
  if (node.children.length !== 1) {
@@ -1 +1 @@
1
- {"version":3,"file":"collapse-single-child-logical.js","sourceRoot":"","sources":["../../../src/rules/shape/collapse-single-child-logical.ts"],"names":[],"mappings":";;;AAOA,gEAaC;AApBD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,kCAAkC,CAAC;AAE1D,SAAgB,0BAA0B,CAAC,IAAe,EAAE,gBAAkC;IAC1F,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,qBAAqB,CAAC,CAAC;QAClE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,sBAAsB,CAAC,CAAC;QACnE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC5B,CAAC"}
1
+ {"version":3,"file":"collapse-single-child-logical.js","sourceRoot":"","sources":["../../../src/rules/shape/collapse-single-child-logical.ts"],"names":[],"mappings":";;;AAOA,gEAaC;AApBD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,kCAAkC,CAAC;AAE1D,SAAgB,0BAA0B,CAAC,IAAe,EAAE,gBAAkC;IAC1F,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,wCAAwC,CAAC,CAAC;QACrF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,sBAAsB,CAAC,CAAC;QACnE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC5B,CAAC"}
@@ -23,7 +23,7 @@ function uniqueChildrenByHash(children) {
23
23
  }
24
24
  function dedupeLogicalChildren(node, normalizeContext) {
25
25
  if (!(0, guards_1.isLogicalNode)(node)) {
26
- (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not logical");
26
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not a compound ($and/$or) node");
27
27
  return node;
28
28
  }
29
29
  const deduped = uniqueChildrenByHash(node.children);
@@ -1 +1 @@
1
- {"version":3,"file":"dedupe-logical-children.js","sourceRoot":"","sources":["../../../src/rules/shape/dedupe-logical-children.ts"],"names":[],"mappings":";;;AASA,oDAcC;AAED,sDAeC;AAxCD,yCAA0C;AAC1C,iDAAqD;AACrD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,6BAA6B,CAAC;AAErD,SAAgB,oBAAoB,CAAC,QAAqB;IACtD,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAC/B,MAAM,MAAM,GAAgB,EAAE,CAAC;IAE/B,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAA,eAAQ,EAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAChB,SAAS;QACb,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACd,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,SAAgB,qBAAqB,CAAC,IAAe,EAAE,gBAAkC;IACrF,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,qBAAqB,CAAC,CAAC;QAClE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,OAAO,GAAG,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAEpD,IAAI,OAAO,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC1C,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,uBAAuB,CAAC,CAAC;QACpE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAA,kBAAO,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAA,iBAAM,EAAC,OAAO,CAAC,CAAC;AACnE,CAAC"}
1
+ {"version":3,"file":"dedupe-logical-children.js","sourceRoot":"","sources":["../../../src/rules/shape/dedupe-logical-children.ts"],"names":[],"mappings":";;;AASA,oDAcC;AAED,sDAeC;AAxCD,yCAA0C;AAC1C,iDAAqD;AACrD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,6BAA6B,CAAC;AAErD,SAAgB,oBAAoB,CAAC,QAAqB;IACtD,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAC/B,MAAM,MAAM,GAAgB,EAAE,CAAC;IAE/B,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAA,eAAQ,EAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAChB,SAAS;QACb,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACd,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,SAAgB,qBAAqB,CAAC,IAAe,EAAE,gBAAkC;IACrF,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,wCAAwC,CAAC,CAAC;QACrF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,OAAO,GAAG,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAEpD,IAAI,OAAO,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC1C,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,uBAAuB,CAAC,CAAC;QACpE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAA,kBAAO,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAA,iBAAM,EAAC,OAAO,CAAC,CAAC;AACnE,CAAC"}
@@ -21,7 +21,7 @@ function flattenLogicalChildren(node) {
21
21
  }
22
22
  function flattenLogical(node, normalizeContext) {
23
23
  if (!(0, guards_1.isLogicalNode)(node)) {
24
- (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not logical");
24
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not a compound ($and/$or) node");
25
25
  return node;
26
26
  }
27
27
  const nextChildren = flattenLogicalChildren(node);
@@ -31,7 +31,7 @@ function flattenLogical(node, normalizeContext) {
31
31
  (0, warnings_1.markRuleApplied)(normalizeContext, exports.RULE_ID);
32
32
  return node.op === "$and" ? (0, builders_1.andNode)(nextChildren) : (0, builders_1.orNode)(nextChildren);
33
33
  }
34
- (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "no nested same-op logical nodes");
34
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "no nested same-op compound nodes");
35
35
  return node;
36
36
  }
37
37
  //# sourceMappingURL=flatten-logical.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"flatten-logical.js","sourceRoot":"","sources":["../../../src/rules/shape/flatten-logical.ts"],"names":[],"mappings":";;;AAQA,wDAYC;AAED,wCAmBC;AAzCD,iDAAqD;AACrD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,sBAAsB,CAAC;AAE9C,SAAgB,sBAAsB,CAAC,IAAiB;IACpD,MAAM,MAAM,GAAgB,EAAE,CAAC;IAE/B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChC,IAAI,IAAA,sBAAa,EAAC,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;YAC/C,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACJ,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACL,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,SAAgB,cAAc,CAAC,IAAe,EAAE,gBAAkC;IAC9E,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,qBAAqB,CAAC,CAAC;QAClE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,YAAY,GAAG,sBAAsB,CAAC,IAAI,CAAC,CAAC;IAElD,MAAM,OAAO,GACT,YAAY,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM;QAC5C,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IAExD,IAAI,OAAO,EAAE,CAAC;QACV,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAA,kBAAO,EAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAA,iBAAM,EAAC,YAAY,CAAC,CAAC;IAC7E,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,iCAAiC,CAAC,CAAC;IAC9E,OAAO,IAAI,CAAC;AAChB,CAAC"}
1
+ {"version":3,"file":"flatten-logical.js","sourceRoot":"","sources":["../../../src/rules/shape/flatten-logical.ts"],"names":[],"mappings":";;;AAQA,wDAYC;AAED,wCAmBC;AAzCD,iDAAqD;AACrD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,sBAAsB,CAAC;AAE9C,SAAgB,sBAAsB,CAAC,IAAiB;IACpD,MAAM,MAAM,GAAgB,EAAE,CAAC;IAE/B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChC,IAAI,IAAA,sBAAa,EAAC,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;YAC/C,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACJ,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACL,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,SAAgB,cAAc,CAAC,IAAe,EAAE,gBAAkC;IAC9E,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,wCAAwC,CAAC,CAAC;QACrF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,YAAY,GAAG,sBAAsB,CAAC,IAAI,CAAC,CAAC;IAElD,MAAM,OAAO,GACT,YAAY,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM;QAC5C,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IAExD,IAAI,OAAO,EAAE,CAAC;QACV,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAA,kBAAO,EAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAA,iBAAM,EAAC,YAAY,CAAC,CAAC;IAC7E,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,kCAAkC,CAAC,CAAC;IAC/E,OAAO,IAAI,CAAC;AAChB,CAAC"}
@@ -8,11 +8,11 @@ const warnings_1 = require("../../observe/warnings");
8
8
  exports.RULE_ID = "shape.removeEmptyLogical";
9
9
  function removeEmptyLogical(node, normalizeContext) {
10
10
  if (!(0, guards_1.isLogicalNode)(node)) {
11
- (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not logical");
11
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "node is not a compound ($and/$or) node");
12
12
  return node;
13
13
  }
14
14
  if (node.children.length > 0) {
15
- (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "logical node is not empty");
15
+ (0, warnings_1.markRuleSkipped)(normalizeContext, exports.RULE_ID, "compound node is not empty");
16
16
  return node;
17
17
  }
18
18
  (0, warnings_1.markRuleApplied)(normalizeContext, exports.RULE_ID);
@@ -1 +1 @@
1
- {"version":3,"file":"remove-empty-logical.js","sourceRoot":"","sources":["../../../src/rules/shape/remove-empty-logical.ts"],"names":[],"mappings":";;;AAQA,gDAaC;AArBD,iDAAyD;AACzD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,0BAA0B,CAAC;AAElD,SAAgB,kBAAkB,CAAC,IAAe,EAAE,gBAAkC;IAClF,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,qBAAqB,CAAC,CAAC;QAClE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,2BAA2B,CAAC,CAAC;QACxE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAA,mBAAQ,GAAE,CAAC,CAAC,CAAC,IAAA,oBAAS,GAAE,CAAC;AACzD,CAAC"}
1
+ {"version":3,"file":"remove-empty-logical.js","sourceRoot":"","sources":["../../../src/rules/shape/remove-empty-logical.ts"],"names":[],"mappings":";;;AAQA,gDAaC;AArBD,iDAAyD;AACzD,6CAAiD;AAGjD,qDAA0E;AAE7D,QAAA,OAAO,GAAG,0BAA0B,CAAC;AAElD,SAAgB,kBAAkB,CAAC,IAAe,EAAE,gBAAkC;IAClF,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,EAAE,CAAC;QACvB,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,wCAAwC,CAAC,CAAC;QACrF,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,EAAE,4BAA4B,CAAC,CAAC;QACzE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAA,0BAAe,EAAC,gBAAgB,EAAE,eAAO,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,IAAA,mBAAQ,GAAE,CAAC,CAAC,CAAC,IAAA,oBAAS,GAAE,CAAC;AACzD,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { QueryNode } from "../../ast/types";
2
+ import type { ConstraintSet } from "../context/constraint-set";
3
+ import type { ScopeSafetyPolicy } from "../safety/scope-safety-policy";
4
+ export declare function analyzeBranchCoverage(branch: QueryNode, inherited: ConstraintSet, policy: ScopeSafetyPolicy): QueryNode;
5
+ //# sourceMappingURL=analyze-branch-coverage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyze-branch-coverage.d.ts","sourceRoot":"","sources":["../../../src/scope/analysis/analyze-branch-coverage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE/D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAEvE,wBAAgB,qBAAqB,CACjC,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,aAAa,EACxB,MAAM,EAAE,iBAAiB,GAC1B,SAAS,CAEX"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.analyzeBranchCoverage = analyzeBranchCoverage;
4
+ const remove_covered_local_constraints_1 = require("../rewrite/remove-covered-local-constraints");
5
+ function analyzeBranchCoverage(branch, inherited, policy) {
6
+ return (0, remove_covered_local_constraints_1.removeCoveredLocalConstraints)(branch, inherited, policy);
7
+ }
8
+ //# sourceMappingURL=analyze-branch-coverage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyze-branch-coverage.js","sourceRoot":"","sources":["../../../src/scope/analysis/analyze-branch-coverage.ts"],"names":[],"mappings":";;AAKA,sDAMC;AATD,kGAA4F;AAG5F,SAAgB,qBAAqB,CACjC,MAAiB,EACjB,SAAwB,EACxB,MAAyB;IAEzB,OAAO,IAAA,gEAA6B,EAAC,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;AACpE,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { QueryNode } from "../../ast/types";
2
+ import type { ConstraintSet } from "../context/constraint-set";
3
+ import type { ScopeSafetyPolicy } from "../safety/scope-safety-policy";
4
+ export type BranchSatisfiabilityExplanation = {
5
+ satisfiable: boolean;
6
+ reason: string;
7
+ };
8
+ export declare function explainBranchSatisfiability(branch: QueryNode, inherited: ConstraintSet, policy: ScopeSafetyPolicy): BranchSatisfiabilityExplanation;
9
+ //# sourceMappingURL=analyze-branch-satisfiability.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyze-branch-satisfiability.d.ts","sourceRoot":"","sources":["../../../src/scope/analysis/analyze-branch-satisfiability.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAGvE,MAAM,MAAM,+BAA+B,GAAG;IAC1C,WAAW,EAAE,OAAO,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,wBAAgB,2BAA2B,CACvC,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,aAAa,EACxB,MAAM,EAAE,iBAAiB,GAC1B,+BAA+B,CAyBjC"}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.explainBranchSatisfiability = explainBranchSatisfiability;
4
+ const guards_1 = require("../../ast/guards");
5
+ const normalize_field_predicate_bundle_1 = require("../../predicate/normalize-field-predicate-bundle");
6
+ const create_branch_local_bundle_1 = require("../propagation/create-branch-local-bundle");
7
+ function explainBranchSatisfiability(branch, inherited, policy) {
8
+ if (policy.bailoutOnUnsupportedScopeMix && inherited.metadata.hasUnsupportedSemantics) {
9
+ return {
10
+ satisfiable: true,
11
+ reason: "preserve branch: inherited constraints marked unsupported/bailout",
12
+ };
13
+ }
14
+ if (!(0, guards_1.isFieldNode)(branch)) {
15
+ return {
16
+ satisfiable: true,
17
+ reason: "non-field branch: no local+inherited contradiction check",
18
+ };
19
+ }
20
+ const bundle = (0, create_branch_local_bundle_1.createBranchLocalBundle)(branch, inherited);
21
+ const local = (0, normalize_field_predicate_bundle_1.normalizeFieldPredicateBundle)(bundle, {});
22
+ if (local.contradiction) {
23
+ return {
24
+ satisfiable: false,
25
+ reason: `local analysis reports contradiction (capability ${local.contradictionCapabilityId ?? "unknown"})`,
26
+ };
27
+ }
28
+ return {
29
+ satisfiable: true,
30
+ reason: "no contradiction between inherited constraints and branch field",
31
+ };
32
+ }
33
+ //# sourceMappingURL=analyze-branch-satisfiability.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyze-branch-satisfiability.js","sourceRoot":"","sources":["../../../src/scope/analysis/analyze-branch-satisfiability.ts"],"names":[],"mappings":";;AAYA,kEA6BC;AAzCD,6CAA+C;AAE/C,uGAAiG;AAGjG,0FAAoF;AAOpF,SAAgB,2BAA2B,CACvC,MAAiB,EACjB,SAAwB,EACxB,MAAyB;IAEzB,IAAI,MAAM,CAAC,4BAA4B,IAAI,SAAS,CAAC,QAAQ,CAAC,uBAAuB,EAAE,CAAC;QACpF,OAAO;YACH,WAAW,EAAE,IAAI;YACjB,MAAM,EAAE,mEAAmE;SAC9E,CAAC;IACN,CAAC;IACD,IAAI,CAAC,IAAA,oBAAW,EAAC,MAAM,CAAC,EAAE,CAAC;QACvB,OAAO;YACH,WAAW,EAAE,IAAI;YACjB,MAAM,EAAE,0DAA0D;SACrE,CAAC;IACN,CAAC;IACD,MAAM,MAAM,GAAG,IAAA,oDAAuB,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAC1D,MAAM,KAAK,GAAG,IAAA,gEAA6B,EAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACxD,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;QACtB,OAAO;YACH,WAAW,EAAE,KAAK;YAClB,MAAM,EAAE,oDAAoD,KAAK,CAAC,yBAAyB,IAAI,SAAS,GAAG;SAC9G,CAAC;IACN,CAAC;IACD,OAAO;QACH,WAAW,EAAE,IAAI;QACjB,MAAM,EAAE,iEAAiE;KAC5E,CAAC;AACN,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { FieldNode, QueryNode } from "../../ast/types";
2
+ import type { ConstraintExtractionRejection, ConstraintSet } from "./constraint-set";
3
+ export declare function constraintSetFromFieldNode(node: FieldNode): ConstraintSet;
4
+ export declare function constraintSetFromQueryNode(node: QueryNode): ConstraintSet;
5
+ export declare function mergeConstraintRejectionLists(target: ConstraintExtractionRejection[], more: ConstraintExtractionRejection[]): void;
6
+ //# sourceMappingURL=build-inherited-constraints.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build-inherited-constraints.d.ts","sourceRoot":"","sources":["../../../src/scope/context/build-inherited-constraints.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAI5D,OAAO,KAAK,EAAE,6BAA6B,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAyGrF,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,SAAS,GAAG,aAAa,CAEzE;AAED,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,SAAS,GAAG,aAAa,CA4BzE;AAED,wBAAgB,6BAA6B,CACzC,MAAM,EAAE,6BAA6B,EAAE,EACvC,IAAI,EAAE,6BAA6B,EAAE,GACtC,IAAI,CAEN"}