mongo-query-normalizer 0.1.0 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +369 -39
- package/README.zh-CN.md +363 -44
- package/dist/ast/types.d.ts +4 -0
- package/dist/ast/types.d.ts.map +1 -1
- package/dist/index.d.ts +4 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/normalize-context.d.ts +5 -1
- package/dist/normalize-context.d.ts.map +1 -1
- package/dist/normalize-context.js +3 -0
- package/dist/normalize-context.js.map +1 -1
- package/dist/normalize.d.ts +1 -1
- package/dist/normalize.d.ts.map +1 -1
- package/dist/normalize.js +105 -52
- package/dist/normalize.js.map +1 -1
- package/dist/options/constants.d.ts.map +1 -1
- package/dist/options/constants.js +7 -16
- package/dist/options/constants.js.map +1 -1
- package/dist/options/resolve.d.ts.map +1 -1
- package/dist/options/resolve.js +32 -1
- package/dist/options/resolve.js.map +1 -1
- package/dist/options/types.d.ts +1 -1
- package/dist/options/types.d.ts.map +1 -1
- package/dist/passes/normalize-predicate.d.ts.map +1 -1
- package/dist/passes/normalize-predicate.js +93 -14
- package/dist/passes/normalize-predicate.js.map +1 -1
- package/dist/predicate/analysis/detect-array-sensitive.d.ts +3 -0
- package/dist/predicate/analysis/detect-array-sensitive.d.ts.map +1 -0
- package/dist/predicate/analysis/detect-array-sensitive.js +33 -0
- package/dist/predicate/analysis/detect-array-sensitive.js.map +1 -0
- package/dist/predicate/analysis/detect-null-sensitive.d.ts +3 -0
- package/dist/predicate/analysis/detect-null-sensitive.d.ts.map +1 -0
- package/dist/predicate/analysis/detect-null-sensitive.js +24 -0
- package/dist/predicate/analysis/detect-null-sensitive.js.map +1 -0
- package/dist/predicate/analysis/detect-opaque-mix.d.ts +3 -0
- package/dist/predicate/analysis/detect-opaque-mix.d.ts.map +1 -0
- package/dist/predicate/analysis/detect-opaque-mix.js +9 -0
- package/dist/predicate/analysis/detect-opaque-mix.js.map +1 -0
- package/dist/predicate/analysis/detect-path-conflict-risk.d.ts +3 -0
- package/dist/predicate/analysis/detect-path-conflict-risk.d.ts.map +1 -0
- package/dist/predicate/analysis/detect-path-conflict-risk.js +14 -0
- package/dist/predicate/analysis/detect-path-conflict-risk.js.map +1 -0
- package/dist/predicate/analysis/merge-range-bounds.d.ts +27 -0
- package/dist/predicate/analysis/merge-range-bounds.d.ts.map +1 -0
- package/dist/predicate/analysis/merge-range-bounds.js +150 -0
- package/dist/predicate/analysis/merge-range-bounds.js.map +1 -0
- package/dist/predicate/capabilities/eq/eq-eq.d.ts +3 -0
- package/dist/predicate/capabilities/eq/eq-eq.d.ts.map +1 -0
- package/dist/predicate/capabilities/eq/eq-eq.js +53 -0
- package/dist/predicate/capabilities/eq/eq-eq.js.map +1 -0
- package/dist/predicate/capabilities/eq/eq-in.d.ts +3 -0
- package/dist/predicate/capabilities/eq/eq-in.d.ts.map +1 -0
- package/dist/predicate/capabilities/eq/eq-in.js +117 -0
- package/dist/predicate/capabilities/eq/eq-in.js.map +1 -0
- package/dist/predicate/capabilities/eq/eq-ne.d.ts +3 -0
- package/dist/predicate/capabilities/eq/eq-ne.d.ts.map +1 -0
- package/dist/predicate/capabilities/eq/eq-ne.js +37 -0
- package/dist/predicate/capabilities/eq/eq-ne.js.map +1 -0
- package/dist/predicate/capabilities/eq/eq-range.d.ts +3 -0
- package/dist/predicate/capabilities/eq/eq-range.d.ts.map +1 -0
- package/dist/predicate/capabilities/eq/eq-range.js +138 -0
- package/dist/predicate/capabilities/eq/eq-range.js.map +1 -0
- package/dist/predicate/capabilities/range/range-range.d.ts +3 -0
- package/dist/predicate/capabilities/range/range-range.d.ts.map +1 -0
- package/dist/predicate/capabilities/range/range-range.js +154 -0
- package/dist/predicate/capabilities/range/range-range.js.map +1 -0
- package/dist/predicate/capabilities/shared/capability-types.d.ts +11 -0
- package/dist/predicate/capabilities/shared/capability-types.d.ts.map +1 -0
- package/dist/predicate/capabilities/shared/capability-types.js +3 -0
- package/dist/predicate/capabilities/shared/capability-types.js.map +1 -0
- package/dist/predicate/capabilities/shared/relation-context.d.ts +13 -0
- package/dist/predicate/capabilities/shared/relation-context.d.ts.map +1 -0
- package/dist/predicate/capabilities/shared/relation-context.js +3 -0
- package/dist/predicate/capabilities/shared/relation-context.js.map +1 -0
- package/dist/predicate/capabilities/shared/relation-result.d.ts +12 -0
- package/dist/predicate/capabilities/shared/relation-result.d.ts.map +1 -0
- package/dist/predicate/capabilities/shared/relation-result.js +14 -0
- package/dist/predicate/capabilities/shared/relation-result.js.map +1 -0
- package/dist/predicate/index.d.ts +12 -0
- package/dist/predicate/index.d.ts.map +1 -0
- package/dist/predicate/index.js +22 -0
- package/dist/predicate/index.js.map +1 -0
- package/dist/predicate/ir/build-field-bundle.d.ts +7 -0
- package/dist/predicate/ir/build-field-bundle.d.ts.map +1 -0
- package/dist/predicate/ir/build-field-bundle.js +88 -0
- package/dist/predicate/ir/build-field-bundle.js.map +1 -0
- package/dist/predicate/ir/compile-field-bundle.d.ts +4 -0
- package/dist/predicate/ir/compile-field-bundle.d.ts.map +1 -0
- package/dist/predicate/ir/compile-field-bundle.js +57 -0
- package/dist/predicate/ir/compile-field-bundle.js.map +1 -0
- package/dist/predicate/ir/dedupe-atoms.d.ts +6 -0
- package/dist/predicate/ir/dedupe-atoms.d.ts.map +1 -0
- package/dist/predicate/ir/dedupe-atoms.js +42 -0
- package/dist/predicate/ir/dedupe-atoms.js.map +1 -0
- package/dist/predicate/ir/field-predicate-bundle.d.ts +16 -0
- package/dist/predicate/ir/field-predicate-bundle.d.ts.map +1 -0
- package/dist/predicate/ir/field-predicate-bundle.js +3 -0
- package/dist/predicate/ir/field-predicate-bundle.js.map +1 -0
- package/dist/predicate/ir/predicate-atom.d.ts +33 -0
- package/dist/predicate/ir/predicate-atom.d.ts.map +1 -0
- package/dist/predicate/ir/predicate-atom.js +3 -0
- package/dist/predicate/ir/predicate-atom.js.map +1 -0
- package/dist/predicate/local-normalize-result.d.ts +17 -0
- package/dist/predicate/local-normalize-result.d.ts.map +1 -0
- package/dist/predicate/local-normalize-result.js +3 -0
- package/dist/predicate/local-normalize-result.js.map +1 -0
- package/dist/predicate/meta/collect-predicate-meta.d.ts +16 -0
- package/dist/predicate/meta/collect-predicate-meta.d.ts.map +1 -0
- package/dist/predicate/meta/collect-predicate-meta.js +13 -0
- package/dist/predicate/meta/collect-predicate-meta.js.map +1 -0
- package/dist/predicate/normalize-field-predicate-bundle.d.ts +18 -0
- package/dist/predicate/normalize-field-predicate-bundle.d.ts.map +1 -0
- package/dist/predicate/normalize-field-predicate-bundle.js +126 -0
- package/dist/predicate/normalize-field-predicate-bundle.js.map +1 -0
- package/dist/predicate/normalize-predicate.d.ts +5 -0
- package/dist/predicate/normalize-predicate.d.ts.map +1 -0
- package/dist/predicate/normalize-predicate.js +10 -0
- package/dist/predicate/normalize-predicate.js.map +1 -0
- package/dist/predicate/planner/capability-selector.d.ts +8 -0
- package/dist/predicate/planner/capability-selector.d.ts.map +1 -0
- package/dist/predicate/planner/capability-selector.js +23 -0
- package/dist/predicate/planner/capability-selector.js.map +1 -0
- package/dist/predicate/planner/relation-plan.d.ts +10 -0
- package/dist/predicate/planner/relation-plan.d.ts.map +1 -0
- package/dist/predicate/planner/relation-plan.js +3 -0
- package/dist/predicate/planner/relation-plan.js.map +1 -0
- package/dist/predicate/planner/relation-planner.d.ts +5 -0
- package/dist/predicate/planner/relation-planner.d.ts.map +1 -0
- package/dist/predicate/planner/relation-planner.js +62 -0
- package/dist/predicate/planner/relation-planner.js.map +1 -0
- package/dist/predicate/registry/predicate-capability-registry.d.ts +3 -0
- package/dist/predicate/registry/predicate-capability-registry.d.ts.map +1 -0
- package/dist/predicate/registry/predicate-capability-registry.js +19 -0
- package/dist/predicate/registry/predicate-capability-registry.js.map +1 -0
- package/dist/predicate/safety/predicate-safety-policy.d.ts +9 -0
- package/dist/predicate/safety/predicate-safety-policy.d.ts.map +1 -0
- package/dist/predicate/safety/predicate-safety-policy.js +11 -0
- package/dist/predicate/safety/predicate-safety-policy.js.map +1 -0
- package/dist/predicate/utils/bson-compare.d.ts +2 -0
- package/dist/predicate/utils/bson-compare.d.ts.map +1 -0
- package/dist/predicate/utils/bson-compare.js +7 -0
- package/dist/predicate/utils/bson-compare.js.map +1 -0
- package/dist/predicate/utils/intersect-in-lists.d.ts +5 -0
- package/dist/predicate/utils/intersect-in-lists.d.ts.map +1 -0
- package/dist/predicate/utils/intersect-in-lists.js +15 -0
- package/dist/predicate/utils/intersect-in-lists.js.map +1 -0
- package/dist/predicate/utils/set-ops.d.ts +3 -0
- package/dist/predicate/utils/set-ops.d.ts.map +1 -0
- package/dist/predicate/utils/set-ops.js +18 -0
- package/dist/predicate/utils/set-ops.js.map +1 -0
- package/dist/predicate/utils/value-equality.d.ts +2 -0
- package/dist/predicate/utils/value-equality.d.ts.map +1 -0
- package/dist/predicate/utils/value-equality.js +8 -0
- package/dist/predicate/utils/value-equality.js.map +1 -0
- package/dist/rules/or-common-predicate/detect-common-predicates-in-or.d.ts +6 -0
- package/dist/rules/or-common-predicate/detect-common-predicates-in-or.d.ts.map +1 -0
- package/dist/rules/or-common-predicate/detect-common-predicates-in-or.js +83 -0
- package/dist/rules/or-common-predicate/detect-common-predicates-in-or.js.map +1 -0
- package/dist/rules/shape/collapse-single-child-logical.js +1 -1
- package/dist/rules/shape/collapse-single-child-logical.js.map +1 -1
- package/dist/rules/shape/dedupe-logical-children.js +1 -1
- package/dist/rules/shape/dedupe-logical-children.js.map +1 -1
- package/dist/rules/shape/flatten-logical.js +2 -2
- package/dist/rules/shape/flatten-logical.js.map +1 -1
- package/dist/rules/shape/remove-empty-logical.js +2 -2
- package/dist/rules/shape/remove-empty-logical.js.map +1 -1
- package/dist/scope/analysis/analyze-branch-coverage.d.ts +5 -0
- package/dist/scope/analysis/analyze-branch-coverage.d.ts.map +1 -0
- package/dist/scope/analysis/analyze-branch-coverage.js +8 -0
- package/dist/scope/analysis/analyze-branch-coverage.js.map +1 -0
- package/dist/scope/analysis/analyze-branch-satisfiability.d.ts +9 -0
- package/dist/scope/analysis/analyze-branch-satisfiability.d.ts.map +1 -0
- package/dist/scope/analysis/analyze-branch-satisfiability.js +33 -0
- package/dist/scope/analysis/analyze-branch-satisfiability.js.map +1 -0
- package/dist/scope/context/build-inherited-constraints.d.ts +6 -0
- package/dist/scope/context/build-inherited-constraints.d.ts.map +1 -0
- package/dist/scope/context/build-inherited-constraints.js +119 -0
- package/dist/scope/context/build-inherited-constraints.js.map +1 -0
- package/dist/scope/context/constraint-set.d.ts +19 -0
- package/dist/scope/context/constraint-set.d.ts.map +1 -0
- package/dist/scope/context/constraint-set.js +26 -0
- package/dist/scope/context/constraint-set.js.map +1 -0
- package/dist/scope/context/merge-constraint-sources.d.ts +4 -0
- package/dist/scope/context/merge-constraint-sources.d.ts.map +1 -0
- package/dist/scope/context/merge-constraint-sources.js +28 -0
- package/dist/scope/context/merge-constraint-sources.js.map +1 -0
- package/dist/scope/index.d.ts +8 -0
- package/dist/scope/index.d.ts.map +1 -0
- package/dist/scope/index.js +19 -0
- package/dist/scope/index.js.map +1 -0
- package/dist/scope/meta/collect-scope-meta.d.ts +5 -0
- package/dist/scope/meta/collect-scope-meta.d.ts.map +1 -0
- package/dist/scope/meta/collect-scope-meta.js +7 -0
- package/dist/scope/meta/collect-scope-meta.js.map +1 -0
- package/dist/scope/normalize-scope.d.ts +4 -0
- package/dist/scope/normalize-scope.d.ts.map +1 -0
- package/dist/scope/normalize-scope.js +149 -0
- package/dist/scope/normalize-scope.js.map +1 -0
- package/dist/scope/planner/scope-plan.d.ts +6 -0
- package/dist/scope/planner/scope-plan.d.ts.map +1 -0
- package/dist/scope/planner/scope-plan.js +9 -0
- package/dist/scope/planner/scope-plan.js.map +1 -0
- package/dist/scope/planner/scope-rewrite-planner.d.ts +4 -0
- package/dist/scope/planner/scope-rewrite-planner.d.ts.map +1 -0
- package/dist/scope/planner/scope-rewrite-planner.js +8 -0
- package/dist/scope/planner/scope-rewrite-planner.js.map +1 -0
- package/dist/scope/propagation/create-branch-local-bundle.d.ts +5 -0
- package/dist/scope/propagation/create-branch-local-bundle.d.ts.map +1 -0
- package/dist/scope/propagation/create-branch-local-bundle.js +16 -0
- package/dist/scope/propagation/create-branch-local-bundle.js.map +1 -0
- package/dist/scope/propagation/propagate-constraints-to-children.d.ts +6 -0
- package/dist/scope/propagation/propagate-constraints-to-children.d.ts.map +1 -0
- package/dist/scope/propagation/propagate-constraints-to-children.js +9 -0
- package/dist/scope/propagation/propagate-constraints-to-children.js.map +1 -0
- package/dist/scope/rewrite/collapse-single-branch.d.ts +5 -0
- package/dist/scope/rewrite/collapse-single-branch.d.ts.map +1 -0
- package/dist/scope/rewrite/collapse-single-branch.js +28 -0
- package/dist/scope/rewrite/collapse-single-branch.js.map +1 -0
- package/dist/scope/rewrite/prune-impossible-branches.d.ts +6 -0
- package/dist/scope/rewrite/prune-impossible-branches.d.ts.map +1 -0
- package/dist/scope/rewrite/prune-impossible-branches.js +32 -0
- package/dist/scope/rewrite/prune-impossible-branches.js.map +1 -0
- package/dist/scope/rewrite/remove-covered-local-constraints.d.ts +6 -0
- package/dist/scope/rewrite/remove-covered-local-constraints.d.ts.map +1 -0
- package/dist/scope/rewrite/remove-covered-local-constraints.js +76 -0
- package/dist/scope/rewrite/remove-covered-local-constraints.js.map +1 -0
- package/dist/scope/safety/scope-safety-policy.d.ts +10 -0
- package/dist/scope/safety/scope-safety-policy.d.ts.map +1 -0
- package/dist/scope/safety/scope-safety-policy.js +12 -0
- package/dist/scope/safety/scope-safety-policy.js.map +1 -0
- package/dist/types.d.ts +70 -2
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +2 -1
- package/dist/types.js.map +1 -1
- package/package.json +6 -4
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { normalizeScope } from "./normalize-scope";
|
|
2
|
+
export type { ConstraintSet } from "./context/constraint-set";
|
|
3
|
+
export { emptyConstraintSet, cloneConstraintSet } from "./context/constraint-set";
|
|
4
|
+
export { mergeConstraintSources, mergeManyConstraintSources } from "./context/merge-constraint-sources";
|
|
5
|
+
export { constraintSetFromQueryNode, constraintSetFromFieldNode } from "./context/build-inherited-constraints";
|
|
6
|
+
export { createBranchLocalBundle } from "./propagation/create-branch-local-bundle";
|
|
7
|
+
export { DEFAULT_SCOPE_SAFETY_POLICY, type ScopeSafetyPolicy } from "./safety/scope-safety-policy";
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/scope/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,YAAY,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAClF,OAAO,EAAE,sBAAsB,EAAE,0BAA0B,EAAE,MAAM,oCAAoC,CAAC;AACxG,OAAO,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,MAAM,uCAAuC,CAAC;AAC/G,OAAO,EAAE,uBAAuB,EAAE,MAAM,0CAA0C,CAAC;AACnF,OAAO,EAAE,2BAA2B,EAAE,KAAK,iBAAiB,EAAE,MAAM,8BAA8B,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_SCOPE_SAFETY_POLICY = exports.createBranchLocalBundle = exports.constraintSetFromFieldNode = exports.constraintSetFromQueryNode = exports.mergeManyConstraintSources = exports.mergeConstraintSources = exports.cloneConstraintSet = exports.emptyConstraintSet = exports.normalizeScope = void 0;
|
|
4
|
+
var normalize_scope_1 = require("./normalize-scope");
|
|
5
|
+
Object.defineProperty(exports, "normalizeScope", { enumerable: true, get: function () { return normalize_scope_1.normalizeScope; } });
|
|
6
|
+
var constraint_set_1 = require("./context/constraint-set");
|
|
7
|
+
Object.defineProperty(exports, "emptyConstraintSet", { enumerable: true, get: function () { return constraint_set_1.emptyConstraintSet; } });
|
|
8
|
+
Object.defineProperty(exports, "cloneConstraintSet", { enumerable: true, get: function () { return constraint_set_1.cloneConstraintSet; } });
|
|
9
|
+
var merge_constraint_sources_1 = require("./context/merge-constraint-sources");
|
|
10
|
+
Object.defineProperty(exports, "mergeConstraintSources", { enumerable: true, get: function () { return merge_constraint_sources_1.mergeConstraintSources; } });
|
|
11
|
+
Object.defineProperty(exports, "mergeManyConstraintSources", { enumerable: true, get: function () { return merge_constraint_sources_1.mergeManyConstraintSources; } });
|
|
12
|
+
var build_inherited_constraints_1 = require("./context/build-inherited-constraints");
|
|
13
|
+
Object.defineProperty(exports, "constraintSetFromQueryNode", { enumerable: true, get: function () { return build_inherited_constraints_1.constraintSetFromQueryNode; } });
|
|
14
|
+
Object.defineProperty(exports, "constraintSetFromFieldNode", { enumerable: true, get: function () { return build_inherited_constraints_1.constraintSetFromFieldNode; } });
|
|
15
|
+
var create_branch_local_bundle_1 = require("./propagation/create-branch-local-bundle");
|
|
16
|
+
Object.defineProperty(exports, "createBranchLocalBundle", { enumerable: true, get: function () { return create_branch_local_bundle_1.createBranchLocalBundle; } });
|
|
17
|
+
var scope_safety_policy_1 = require("./safety/scope-safety-policy");
|
|
18
|
+
Object.defineProperty(exports, "DEFAULT_SCOPE_SAFETY_POLICY", { enumerable: true, get: function () { return scope_safety_policy_1.DEFAULT_SCOPE_SAFETY_POLICY; } });
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/scope/index.ts"],"names":[],"mappings":";;;AAAA,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AAEvB,2DAAkF;AAAzE,oHAAA,kBAAkB,OAAA;AAAE,oHAAA,kBAAkB,OAAA;AAC/C,+EAAwG;AAA/F,kIAAA,sBAAsB,OAAA;AAAE,sIAAA,0BAA0B,OAAA;AAC3D,qFAA+G;AAAtG,yIAAA,0BAA0B,OAAA;AAAE,yIAAA,0BAA0B,OAAA;AAC/D,uFAAmF;AAA1E,qIAAA,uBAAuB,OAAA;AAChC,oEAAmG;AAA1F,kIAAA,2BAA2B,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collect-scope-meta.d.ts","sourceRoot":"","sources":["../../../src/scope/meta/collect-scope-meta.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG;IAC7B,YAAY,EAAE,OAAO,CAAC;CACzB,CAAC;AAEF,wBAAgB,cAAc,IAAI,kBAAkB,CAEnD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collect-scope-meta.js","sourceRoot":"","sources":["../../../src/scope/meta/collect-scope-meta.ts"],"names":[],"mappings":";;AAIA,wCAEC;AAFD,SAAgB,cAAc;IAC1B,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;AACnC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize-scope.d.ts","sourceRoot":"","sources":["../../src/scope/normalize-scope.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAe,SAAS,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AA2N7D,wBAAgB,cAAc,CAAC,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,gBAAgB,GAAG,SAAS,CAY7F"}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.normalizeScope = normalizeScope;
|
|
4
|
+
const builders_1 = require("../ast/builders");
|
|
5
|
+
const guards_1 = require("../ast/guards");
|
|
6
|
+
const build_inherited_constraints_1 = require("./context/build-inherited-constraints");
|
|
7
|
+
const constraint_set_1 = require("./context/constraint-set");
|
|
8
|
+
const merge_constraint_sources_1 = require("./context/merge-constraint-sources");
|
|
9
|
+
const collapse_single_branch_1 = require("./rewrite/collapse-single-branch");
|
|
10
|
+
const prune_impossible_branches_1 = require("./rewrite/prune-impossible-branches");
|
|
11
|
+
const remove_covered_local_constraints_1 = require("./rewrite/remove-covered-local-constraints");
|
|
12
|
+
/** Extract positive field constraints from one $and sibling subtree (constraint-set build only; no context I/O). */
|
|
13
|
+
function positiveFieldConstraintsFromSibling(child) {
|
|
14
|
+
if ((0, guards_1.isFieldNode)(child)) {
|
|
15
|
+
return (0, build_inherited_constraints_1.constraintSetFromQueryNode)(child);
|
|
16
|
+
}
|
|
17
|
+
if ((0, guards_1.isLogicalNode)(child) && child.op === "$and") {
|
|
18
|
+
const parts = child.children.map((c) => positiveFieldConstraintsFromSibling(c));
|
|
19
|
+
return (0, merge_constraint_sources_1.mergeManyConstraintSources)(parts);
|
|
20
|
+
}
|
|
21
|
+
return (0, constraint_set_1.emptyConstraintSet)();
|
|
22
|
+
}
|
|
23
|
+
/** Orchestrator-only: append inherited-phase extraction rejections to observe metadata (same guard as legacy per-sibling record). */
|
|
24
|
+
function commitInheritedConstraintRejections(normalizeContext, rejections) {
|
|
25
|
+
if (!normalizeContext.options.observe.collectScopeTraces || rejections.length === 0) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
if (!normalizeContext.scopeConstraintRejections) {
|
|
29
|
+
normalizeContext.scopeConstraintRejections = [];
|
|
30
|
+
}
|
|
31
|
+
normalizeContext.scopeConstraintRejections.push(...rejections);
|
|
32
|
+
}
|
|
33
|
+
/** Pure build: merge sibling constraints into inherited; rejections are reported separately for orchestrator commit. */
|
|
34
|
+
function buildInheritedConstraintsForAndChild(andLogical, childIndex, inherited) {
|
|
35
|
+
let siblingInherited = (0, constraint_set_1.cloneConstraintSet)(inherited);
|
|
36
|
+
const rejections = [];
|
|
37
|
+
for (let j = 0; j < andLogical.children.length; j += 1) {
|
|
38
|
+
if (j === childIndex) {
|
|
39
|
+
continue;
|
|
40
|
+
}
|
|
41
|
+
const siblingPart = positiveFieldConstraintsFromSibling(andLogical.children[j]);
|
|
42
|
+
rejections.push(...siblingPart.metadata.extractionRejections);
|
|
43
|
+
siblingInherited = (0, merge_constraint_sources_1.mergeConstraintSources)(siblingInherited, siblingPart);
|
|
44
|
+
}
|
|
45
|
+
return { inheritedConstraints: siblingInherited, rejections };
|
|
46
|
+
}
|
|
47
|
+
/** Coverage elimination phase: delegate to rewriter; trace via emitTrace only. */
|
|
48
|
+
function applyCoverageElimination(branch, inherited, policy, emitTrace) {
|
|
49
|
+
return (0, remove_covered_local_constraints_1.removeCoveredLocalConstraints)(branch, inherited, policy, emitTrace);
|
|
50
|
+
}
|
|
51
|
+
/** Impossible-branch prune phase: delegate to rewriter; trace via emitTrace only. */
|
|
52
|
+
function applyImpossibleBranchPrune(branch, inherited, policy, emitTrace) {
|
|
53
|
+
return (0, prune_impossible_branches_1.pruneImpossibleOrBranch)(branch, inherited, policy, emitTrace);
|
|
54
|
+
}
|
|
55
|
+
/** $and child pass: recurse with sibling-merged inherited, then optional coverage pass. */
|
|
56
|
+
function normalizeAndChildWithInherited(child, siblingInherited, policy, normalizeContext, emitTrace) {
|
|
57
|
+
let processed = normalizeScopeRecursive(child, siblingInherited, policy, normalizeContext, emitTrace);
|
|
58
|
+
if (!siblingInherited.metadata.hasUnsupportedSemantics) {
|
|
59
|
+
processed = applyCoverageElimination(processed, siblingInherited, policy, emitTrace);
|
|
60
|
+
}
|
|
61
|
+
return processed;
|
|
62
|
+
}
|
|
63
|
+
/** $or branch pass: recurse, coverage elimination, then impossible-branch prune. */
|
|
64
|
+
function normalizeOrBranchWithInherited(child, inherited, policy, normalizeContext, emitTrace) {
|
|
65
|
+
let branch = normalizeScopeRecursive(child, inherited, policy, normalizeContext, emitTrace);
|
|
66
|
+
branch = applyCoverageElimination(branch, inherited, policy, emitTrace);
|
|
67
|
+
const prunedReplacement = applyImpossibleBranchPrune(branch, inherited, policy, emitTrace);
|
|
68
|
+
if (prunedReplacement !== null) {
|
|
69
|
+
return prunedReplacement;
|
|
70
|
+
}
|
|
71
|
+
return branch;
|
|
72
|
+
}
|
|
73
|
+
/** Post-$or children: structural collapse; collapse-or trace goes through emitTrace (already gated). */
|
|
74
|
+
function finalizeOrNode(newChildren, policy, emitTrace) {
|
|
75
|
+
const childCountBeforeCollapse = newChildren.length;
|
|
76
|
+
const out = (0, collapse_single_branch_1.collapseOrNodeChildren)(newChildren, policy);
|
|
77
|
+
if (policy.allowSingleBranchCollapse && childCountBeforeCollapse === 1) {
|
|
78
|
+
emitTrace({
|
|
79
|
+
type: "collapse-or",
|
|
80
|
+
outcome: "collapsed-single-child",
|
|
81
|
+
detail: "single $or branch collapsed",
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
return out;
|
|
85
|
+
}
|
|
86
|
+
function normalizeScopeRecursive(node, inherited, policy, normalizeContext, emitTrace) {
|
|
87
|
+
if ((0, guards_1.isFieldNode)(node)) {
|
|
88
|
+
return node;
|
|
89
|
+
}
|
|
90
|
+
if (!(0, guards_1.isLogicalNode)(node)) {
|
|
91
|
+
return node;
|
|
92
|
+
}
|
|
93
|
+
if (node.op === "$and") {
|
|
94
|
+
if (!policy.allowAndPropagation) {
|
|
95
|
+
emitTrace({
|
|
96
|
+
type: "and-propagation",
|
|
97
|
+
outcome: "skipped-by-policy",
|
|
98
|
+
detail: "$and sibling constraint propagation disabled by scope safety policy",
|
|
99
|
+
});
|
|
100
|
+
return (0, builders_1.andNode)(node.children.map((c) => normalizeScopeRecursive(c, inherited, policy, normalizeContext, emitTrace)));
|
|
101
|
+
}
|
|
102
|
+
emitTrace({
|
|
103
|
+
type: "and-propagation",
|
|
104
|
+
outcome: "applied",
|
|
105
|
+
detail: "merging sibling field constraints for $and children",
|
|
106
|
+
});
|
|
107
|
+
const newChildren = [];
|
|
108
|
+
const andNodeTyped = node;
|
|
109
|
+
for (let i = 0; i < andNodeTyped.children.length; i += 1) {
|
|
110
|
+
const { inheritedConstraints, rejections } = buildInheritedConstraintsForAndChild(andNodeTyped, i, inherited);
|
|
111
|
+
commitInheritedConstraintRejections(normalizeContext, rejections);
|
|
112
|
+
const processed = normalizeAndChildWithInherited(andNodeTyped.children[i], inheritedConstraints, policy, normalizeContext, emitTrace);
|
|
113
|
+
newChildren.push(processed);
|
|
114
|
+
}
|
|
115
|
+
return (0, builders_1.andNode)(newChildren);
|
|
116
|
+
}
|
|
117
|
+
if (node.op === "$or") {
|
|
118
|
+
if (!policy.allowOrPropagation) {
|
|
119
|
+
emitTrace({
|
|
120
|
+
type: "or-branch-inherited",
|
|
121
|
+
satisfiabilityCheck: "skipped",
|
|
122
|
+
detail: "$or propagation disabled; inherited constraints not applied for branch analysis",
|
|
123
|
+
});
|
|
124
|
+
const lifted = node.children.map((c) => normalizeScopeRecursive(c, inherited, policy, normalizeContext, emitTrace));
|
|
125
|
+
return finalizeOrNode(lifted, policy, emitTrace);
|
|
126
|
+
}
|
|
127
|
+
const newChildren = [];
|
|
128
|
+
for (const child of node.children) {
|
|
129
|
+
const branch = normalizeOrBranchWithInherited(child, inherited, policy, normalizeContext, emitTrace);
|
|
130
|
+
newChildren.push(branch);
|
|
131
|
+
}
|
|
132
|
+
return finalizeOrNode(newChildren, policy, emitTrace);
|
|
133
|
+
}
|
|
134
|
+
return node;
|
|
135
|
+
}
|
|
136
|
+
function normalizeScope(node, normalizeContext) {
|
|
137
|
+
const policy = normalizeContext.options.scope.safetyPolicy;
|
|
138
|
+
const emitTrace = (event) => {
|
|
139
|
+
if (!normalizeContext.options.observe.collectScopeTraces) {
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
if (!normalizeContext.scopeTraceEvents) {
|
|
143
|
+
normalizeContext.scopeTraceEvents = [];
|
|
144
|
+
}
|
|
145
|
+
normalizeContext.scopeTraceEvents.push(event);
|
|
146
|
+
};
|
|
147
|
+
return normalizeScopeRecursive(node, (0, constraint_set_1.emptyConstraintSet)(), policy, normalizeContext, emitTrace);
|
|
148
|
+
}
|
|
149
|
+
//# sourceMappingURL=normalize-scope.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize-scope.js","sourceRoot":"","sources":["../../src/scope/normalize-scope.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-plan.d.ts","sourceRoot":"","sources":["../../../src/scope/planner/scope-plan.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG,WAAW,GAAG,OAAO,GAAG,UAAU,GAAG,UAAU,CAAC;AAE7E,MAAM,MAAM,SAAS,GAAG;IACpB,MAAM,EAAE,cAAc,EAAE,CAAC;CAC5B,CAAC;AAEF,wBAAgB,gBAAgB,IAAI,SAAS,CAI5C"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.defaultScopePlan = defaultScopePlan;
|
|
4
|
+
function defaultScopePlan() {
|
|
5
|
+
return {
|
|
6
|
+
phases: ["propagate", "coverage", "prune", "collapse"],
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=scope-plan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-plan.js","sourceRoot":"","sources":["../../../src/scope/planner/scope-plan.ts"],"names":[],"mappings":";;AAMA,4CAIC;AAJD,SAAgB,gBAAgB;IAC5B,OAAO;QACH,MAAM,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,CAAC;KACzD,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-rewrite-planner.d.ts","sourceRoot":"","sources":["../../../src/scope/planner/scope-rewrite-planner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAChE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAEvE,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,iBAAiB,GAAG,SAAS,CAEtE"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.planScopeRewrite = planScopeRewrite;
|
|
4
|
+
const scope_plan_1 = require("./scope-plan");
|
|
5
|
+
function planScopeRewrite(_policy) {
|
|
6
|
+
return (0, scope_plan_1.defaultScopePlan)();
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=scope-rewrite-planner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-rewrite-planner.js","sourceRoot":"","sources":["../../../src/scope/planner/scope-rewrite-planner.ts"],"names":[],"mappings":";;AAGA,4CAEC;AALD,6CAAgE;AAGhE,SAAgB,gBAAgB,CAAC,OAA0B;IACvD,OAAO,IAAA,6BAAgB,GAAE,CAAC;AAC9B,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { FieldNode } from "../../ast/types";
|
|
2
|
+
import type { FieldPredicateBundle } from "../../predicate/ir/field-predicate-bundle";
|
|
3
|
+
import type { ConstraintSet } from "../context/constraint-set";
|
|
4
|
+
export declare function createBranchLocalBundle(fieldNode: FieldNode, inherited: ConstraintSet): FieldPredicateBundle;
|
|
5
|
+
//# sourceMappingURL=create-branch-local-bundle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-branch-local-bundle.d.ts","sourceRoot":"","sources":["../../../src/scope/propagation/create-branch-local-bundle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACtF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE/D,wBAAgB,uBAAuB,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,GAAG,oBAAoB,CAU5G"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createBranchLocalBundle = createBranchLocalBundle;
|
|
4
|
+
const build_field_bundle_1 = require("../../predicate/ir/build-field-bundle");
|
|
5
|
+
function createBranchLocalBundle(fieldNode, inherited) {
|
|
6
|
+
const local = (0, build_field_bundle_1.buildFieldPredicateBundleFromFieldNode)(fieldNode);
|
|
7
|
+
const inheritedAtoms = inherited.byField.get(fieldNode.field) ?? [];
|
|
8
|
+
const mergedPredicates = [...inheritedAtoms, ...local.predicates];
|
|
9
|
+
const bundle = {
|
|
10
|
+
...local,
|
|
11
|
+
predicates: mergedPredicates,
|
|
12
|
+
metadata: local.metadata,
|
|
13
|
+
};
|
|
14
|
+
return (0, build_field_bundle_1.refreshBundleMetadata)(bundle);
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=create-branch-local-bundle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-branch-local-bundle.js","sourceRoot":"","sources":["../../../src/scope/propagation/create-branch-local-bundle.ts"],"names":[],"mappings":";;AAKA,0DAUC;AAdD,8EAAsH;AAItH,SAAgB,uBAAuB,CAAC,SAAoB,EAAE,SAAwB;IAClF,MAAM,KAAK,GAAG,IAAA,2DAAsC,EAAC,SAAS,CAAC,CAAC;IAChE,MAAM,cAAc,GAAG,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpE,MAAM,gBAAgB,GAAG,CAAC,GAAG,cAAc,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC;IAClE,MAAM,MAAM,GAAyB;QACjC,GAAG,KAAK;QACR,UAAU,EAAE,gBAAgB;QAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ;KAC3B,CAAC;IACF,OAAO,IAAA,0CAAqB,EAAC,MAAM,CAAC,CAAC;AACzC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 约束传播逻辑内联在 `normalize-scope.ts` 的 `$and` / `$or` 遍历中;
|
|
3
|
+
* 本模块占位,便于后续把传播策略从 normalize 主流程中抽出。
|
|
4
|
+
*/
|
|
5
|
+
export declare const PROPAGATION_NOTES = "see normalizeScopeRecursive for AND/OR inherited accumulation";
|
|
6
|
+
//# sourceMappingURL=propagate-constraints-to-children.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"propagate-constraints-to-children.d.ts","sourceRoot":"","sources":["../../../src/scope/propagation/propagate-constraints-to-children.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,eAAO,MAAM,iBAAiB,kEAAkE,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* 约束传播逻辑内联在 `normalize-scope.ts` 的 `$and` / `$or` 遍历中;
|
|
4
|
+
* 本模块占位,便于后续把传播策略从 normalize 主流程中抽出。
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.PROPAGATION_NOTES = void 0;
|
|
8
|
+
exports.PROPAGATION_NOTES = "see normalizeScopeRecursive for AND/OR inherited accumulation";
|
|
9
|
+
//# sourceMappingURL=propagate-constraints-to-children.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"propagate-constraints-to-children.js","sourceRoot":"","sources":["../../../src/scope/propagation/propagate-constraints-to-children.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEU,QAAA,iBAAiB,GAAG,+DAA+D,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { QueryNode } from "../../ast/types";
|
|
2
|
+
import type { ScopeSafetyPolicy } from "../safety/scope-safety-policy";
|
|
3
|
+
export declare function collapseSingleOrBranch(node: QueryNode, policy: ScopeSafetyPolicy): QueryNode;
|
|
4
|
+
export declare function collapseOrNodeChildren(children: QueryNode[], policy: ScopeSafetyPolicy): QueryNode;
|
|
5
|
+
//# sourceMappingURL=collapse-single-branch.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collapse-single-branch.d.ts","sourceRoot":"","sources":["../../../src/scope/rewrite/collapse-single-branch.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAEvE,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,iBAAiB,GAAG,SAAS,CAW5F;AAED,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,iBAAiB,GAAG,SAAS,CAQlG"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.collapseSingleOrBranch = collapseSingleOrBranch;
|
|
4
|
+
exports.collapseOrNodeChildren = collapseOrNodeChildren;
|
|
5
|
+
const builders_1 = require("../../ast/builders");
|
|
6
|
+
const guards_1 = require("../../ast/guards");
|
|
7
|
+
function collapseSingleOrBranch(node, policy) {
|
|
8
|
+
if (!policy.allowSingleBranchCollapse) {
|
|
9
|
+
return node;
|
|
10
|
+
}
|
|
11
|
+
if (!(0, guards_1.isLogicalNode)(node) || node.op !== "$or") {
|
|
12
|
+
return node;
|
|
13
|
+
}
|
|
14
|
+
if (node.children.length !== 1) {
|
|
15
|
+
return node;
|
|
16
|
+
}
|
|
17
|
+
return node.children[0];
|
|
18
|
+
}
|
|
19
|
+
function collapseOrNodeChildren(children, policy) {
|
|
20
|
+
if (!policy.allowSingleBranchCollapse) {
|
|
21
|
+
return (0, builders_1.orNode)(children);
|
|
22
|
+
}
|
|
23
|
+
if (children.length === 1) {
|
|
24
|
+
return children[0];
|
|
25
|
+
}
|
|
26
|
+
return (0, builders_1.orNode)(children);
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=collapse-single-branch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collapse-single-branch.js","sourceRoot":"","sources":["../../../src/scope/rewrite/collapse-single-branch.ts"],"names":[],"mappings":";;AAKA,wDAWC;AAED,wDAQC;AA1BD,iDAA4C;AAC5C,6CAAiD;AAIjD,SAAgB,sBAAsB,CAAC,IAAe,EAAE,MAAyB;IAC7E,IAAI,CAAC,MAAM,CAAC,yBAAyB,EAAE,CAAC;QACpC,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,IAAI,CAAC,IAAA,sBAAa,EAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,KAAK,KAAK,EAAE,CAAC;QAC5C,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC5B,CAAC;AAED,SAAgB,sBAAsB,CAAC,QAAqB,EAAE,MAAyB;IACnF,IAAI,CAAC,MAAM,CAAC,yBAAyB,EAAE,CAAC;QACpC,OAAO,IAAA,iBAAM,EAAC,QAAQ,CAAC,CAAC;IAC5B,CAAC;IACD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC;IACD,OAAO,IAAA,iBAAM,EAAC,QAAQ,CAAC,CAAC;AAC5B,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { QueryNode } from "../../ast/types";
|
|
2
|
+
import type { ScopeTraceEvent } from "../../types";
|
|
3
|
+
import type { ConstraintSet } from "../context/constraint-set";
|
|
4
|
+
import type { ScopeSafetyPolicy } from "../safety/scope-safety-policy";
|
|
5
|
+
export declare function pruneImpossibleOrBranch(branch: QueryNode, inherited: ConstraintSet, policy: ScopeSafetyPolicy, onTrace?: (event: ScopeTraceEvent) => void): QueryNode | null;
|
|
6
|
+
//# sourceMappingURL=prune-impossible-branches.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prune-impossible-branches.d.ts","sourceRoot":"","sources":["../../../src/scope/rewrite/prune-impossible-branches.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAGvE,wBAAgB,uBAAuB,CACnC,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,aAAa,EACxB,MAAM,EAAE,iBAAiB,EACzB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,eAAe,KAAK,IAAI,GAC3C,SAAS,GAAG,IAAI,CAyBlB"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.pruneImpossibleOrBranch = pruneImpossibleOrBranch;
|
|
4
|
+
const builders_1 = require("../../ast/builders");
|
|
5
|
+
const analyze_branch_satisfiability_1 = require("../analysis/analyze-branch-satisfiability");
|
|
6
|
+
function pruneImpossibleOrBranch(branch, inherited, policy, onTrace) {
|
|
7
|
+
if (!policy.allowBranchPruning || !policy.allowOrPropagation) {
|
|
8
|
+
onTrace?.({
|
|
9
|
+
type: "prune-branch",
|
|
10
|
+
outcome: "skipped-by-policy",
|
|
11
|
+
detail: "branch pruning or $or propagation disabled by scope safety policy",
|
|
12
|
+
});
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
const explained = (0, analyze_branch_satisfiability_1.explainBranchSatisfiability)(branch, inherited, policy);
|
|
16
|
+
onTrace?.({
|
|
17
|
+
type: "or-branch-inherited",
|
|
18
|
+
satisfiabilityCheck: "ran",
|
|
19
|
+
satisfiable: explained.satisfiable,
|
|
20
|
+
detail: explained.reason,
|
|
21
|
+
});
|
|
22
|
+
if (!explained.satisfiable) {
|
|
23
|
+
onTrace?.({
|
|
24
|
+
type: "prune-branch",
|
|
25
|
+
outcome: "pruned-to-false",
|
|
26
|
+
detail: explained.reason,
|
|
27
|
+
});
|
|
28
|
+
return (0, builders_1.falseNode)();
|
|
29
|
+
}
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=prune-impossible-branches.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prune-impossible-branches.js","sourceRoot":"","sources":["../../../src/scope/rewrite/prune-impossible-branches.ts"],"names":[],"mappings":";;AAOA,0DA8BC;AArCD,iDAA+C;AAK/C,6FAAwF;AAExF,SAAgB,uBAAuB,CACnC,MAAiB,EACjB,SAAwB,EACxB,MAAyB,EACzB,OAA0C;IAE1C,IAAI,CAAC,MAAM,CAAC,kBAAkB,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC;QAC3D,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,cAAc;YACpB,OAAO,EAAE,mBAAmB;YAC5B,MAAM,EAAE,mEAAmE;SAC9E,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,MAAM,SAAS,GAAG,IAAA,2DAA2B,EAAC,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;IACzE,OAAO,EAAE,CAAC;QACN,IAAI,EAAE,qBAAqB;QAC3B,mBAAmB,EAAE,KAAK;QAC1B,WAAW,EAAE,SAAS,CAAC,WAAW;QAClC,MAAM,EAAE,SAAS,CAAC,MAAM;KAC3B,CAAC,CAAC;IACH,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QACzB,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,cAAc;YACpB,OAAO,EAAE,iBAAiB;YAC1B,MAAM,EAAE,SAAS,CAAC,MAAM;SAC3B,CAAC,CAAC;QACH,OAAO,IAAA,oBAAS,GAAE,CAAC;IACvB,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { QueryNode } from "../../ast/types";
|
|
2
|
+
import type { ScopeTraceEvent } from "../../types";
|
|
3
|
+
import type { ConstraintSet } from "../context/constraint-set";
|
|
4
|
+
import type { ScopeSafetyPolicy } from "../safety/scope-safety-policy";
|
|
5
|
+
export declare function removeCoveredLocalConstraints(branch: QueryNode, inherited: ConstraintSet, policy: ScopeSafetyPolicy, onTrace?: (event: ScopeTraceEvent) => void): QueryNode;
|
|
6
|
+
//# sourceMappingURL=remove-covered-local-constraints.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-covered-local-constraints.d.ts","sourceRoot":"","sources":["../../../src/scope/rewrite/remove-covered-local-constraints.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAa,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAavE,wBAAgB,6BAA6B,CACzC,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,aAAa,EACxB,MAAM,EAAE,iBAAiB,EACzB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,eAAe,KAAK,IAAI,GAC3C,SAAS,CA8DX"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.removeCoveredLocalConstraints = removeCoveredLocalConstraints;
|
|
4
|
+
const builders_1 = require("../../ast/builders");
|
|
5
|
+
const guards_1 = require("../../ast/guards");
|
|
6
|
+
const value_equality_1 = require("../../predicate/utils/value-equality");
|
|
7
|
+
function isSingleEqField(node) {
|
|
8
|
+
if (node.predicates.length !== 1) {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
const p = node.predicates[0];
|
|
12
|
+
if (p.op === "$eq" || (!p.opaque && p.op === "$eq")) {
|
|
13
|
+
return { value: p.value };
|
|
14
|
+
}
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
function removeCoveredLocalConstraints(branch, inherited, policy, onTrace) {
|
|
18
|
+
if (!policy.allowConstraintCoverageElimination) {
|
|
19
|
+
onTrace?.({
|
|
20
|
+
type: "coverage-removal",
|
|
21
|
+
outcome: "unchanged",
|
|
22
|
+
detail: "coverage elimination disabled by scope safety policy",
|
|
23
|
+
});
|
|
24
|
+
return branch;
|
|
25
|
+
}
|
|
26
|
+
if (policy.bailoutOnUnsupportedScopeMix && inherited.metadata.hasUnsupportedSemantics) {
|
|
27
|
+
onTrace?.({
|
|
28
|
+
type: "coverage-removal",
|
|
29
|
+
outcome: "unchanged",
|
|
30
|
+
detail: "preserve: inherited constraints flagged unsupported for scope mix bailout",
|
|
31
|
+
});
|
|
32
|
+
return branch;
|
|
33
|
+
}
|
|
34
|
+
if (!(0, guards_1.isFieldNode)(branch)) {
|
|
35
|
+
onTrace?.({
|
|
36
|
+
type: "coverage-removal",
|
|
37
|
+
outcome: "unchanged",
|
|
38
|
+
detail: "not a field leaf; no single-field coverage strip",
|
|
39
|
+
});
|
|
40
|
+
return branch;
|
|
41
|
+
}
|
|
42
|
+
const inheritedAtoms = inherited.byField.get(branch.field) ?? [];
|
|
43
|
+
const eqInherited = inheritedAtoms.find((a) => a.kind === "eq");
|
|
44
|
+
if (!eqInherited || eqInherited.kind !== "eq") {
|
|
45
|
+
onTrace?.({
|
|
46
|
+
type: "coverage-removal",
|
|
47
|
+
outcome: "unchanged",
|
|
48
|
+
detail: "no inherited eq constraint on this field",
|
|
49
|
+
});
|
|
50
|
+
return branch;
|
|
51
|
+
}
|
|
52
|
+
const localEq = isSingleEqField(branch);
|
|
53
|
+
if (!localEq) {
|
|
54
|
+
onTrace?.({
|
|
55
|
+
type: "coverage-removal",
|
|
56
|
+
outcome: "unchanged",
|
|
57
|
+
detail: "local field is not a single $eq; conservative preserve",
|
|
58
|
+
});
|
|
59
|
+
return branch;
|
|
60
|
+
}
|
|
61
|
+
if (!(0, value_equality_1.valuesEqual)(eqInherited.value, localEq.value)) {
|
|
62
|
+
onTrace?.({
|
|
63
|
+
type: "coverage-removal",
|
|
64
|
+
outcome: "unchanged",
|
|
65
|
+
detail: "local $eq differs from inherited $eq",
|
|
66
|
+
});
|
|
67
|
+
return branch;
|
|
68
|
+
}
|
|
69
|
+
onTrace?.({
|
|
70
|
+
type: "coverage-removal",
|
|
71
|
+
outcome: "replaced-with-true",
|
|
72
|
+
detail: "local $eq redundant with inherited $eq on same field",
|
|
73
|
+
});
|
|
74
|
+
return (0, builders_1.trueNode)();
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=remove-covered-local-constraints.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-covered-local-constraints.js","sourceRoot":"","sources":["../../../src/scope/rewrite/remove-covered-local-constraints.ts"],"names":[],"mappings":";;AAmBA,sEAmEC;AAtFD,iDAA8C;AAC9C,6CAA+C;AAG/C,yEAAmE;AAInE,SAAS,eAAe,CAAC,IAAe;IACpC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,MAAM,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAC7B,IAAI,CAAC,CAAC,EAAE,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,CAAC;QAClD,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC;AAED,SAAgB,6BAA6B,CACzC,MAAiB,EACjB,SAAwB,EACxB,MAAyB,EACzB,OAA0C;IAE1C,IAAI,CAAC,MAAM,CAAC,kCAAkC,EAAE,CAAC;QAC7C,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,sDAAsD;SACjE,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IACD,IAAI,MAAM,CAAC,4BAA4B,IAAI,SAAS,CAAC,QAAQ,CAAC,uBAAuB,EAAE,CAAC;QACpF,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,2EAA2E;SACtF,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IACD,IAAI,CAAC,IAAA,oBAAW,EAAC,MAAM,CAAC,EAAE,CAAC;QACvB,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,kDAAkD;SAC7D,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,MAAM,cAAc,GAAG,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACjE,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;IAChE,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;QAC5C,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,0CAA0C;SACrD,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,MAAM,OAAO,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;IACxC,IAAI,CAAC,OAAO,EAAE,CAAC;QACX,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,wDAAwD;SACnE,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,IAAI,CAAC,IAAA,4BAAW,EAAC,WAAW,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACjD,OAAO,EAAE,CAAC;YACN,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,sCAAsC;SACjD,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,OAAO,EAAE,CAAC;QACN,IAAI,EAAE,kBAAkB;QACxB,OAAO,EAAE,oBAAoB;QAC7B,MAAM,EAAE,sDAAsD;KACjE,CAAC,CAAC;IACH,OAAO,IAAA,mBAAQ,GAAE,CAAC;AACtB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type ScopeSafetyPolicy = {
|
|
2
|
+
allowBranchPruning: boolean;
|
|
3
|
+
allowConstraintCoverageElimination: boolean;
|
|
4
|
+
allowSingleBranchCollapse: boolean;
|
|
5
|
+
allowOrPropagation: boolean;
|
|
6
|
+
allowAndPropagation: boolean;
|
|
7
|
+
bailoutOnUnsupportedScopeMix: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare const DEFAULT_SCOPE_SAFETY_POLICY: ScopeSafetyPolicy;
|
|
10
|
+
//# sourceMappingURL=scope-safety-policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-safety-policy.d.ts","sourceRoot":"","sources":["../../../src/scope/safety/scope-safety-policy.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,iBAAiB,GAAG;IAC5B,kBAAkB,EAAE,OAAO,CAAC;IAC5B,kCAAkC,EAAE,OAAO,CAAC;IAC5C,yBAAyB,EAAE,OAAO,CAAC;IACnC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,mBAAmB,EAAE,OAAO,CAAC;IAC7B,4BAA4B,EAAE,OAAO,CAAC;CACzC,CAAC;AAEF,eAAO,MAAM,2BAA2B,EAAE,iBAOzC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_SCOPE_SAFETY_POLICY = void 0;
|
|
4
|
+
exports.DEFAULT_SCOPE_SAFETY_POLICY = {
|
|
5
|
+
allowBranchPruning: true,
|
|
6
|
+
allowConstraintCoverageElimination: true,
|
|
7
|
+
allowSingleBranchCollapse: true,
|
|
8
|
+
allowOrPropagation: true,
|
|
9
|
+
allowAndPropagation: true,
|
|
10
|
+
bailoutOnUnsupportedScopeMix: true,
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=scope-safety-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-safety-policy.js","sourceRoot":"","sources":["../../../src/scope/safety/scope-safety-policy.ts"],"names":[],"mappings":";;;AASa,QAAA,2BAA2B,GAAsB;IAC1D,kBAAkB,EAAE,IAAI;IACxB,kCAAkC,EAAE,IAAI;IACxC,yBAAyB,EAAE,IAAI;IAC/B,kBAAkB,EAAE,IAAI;IACxB,mBAAmB,EAAE,IAAI;IACzB,4BAA4B,EAAE,IAAI;CACrC,CAAC"}
|