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,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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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
|
|
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,
|
|
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
|
|
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,
|
|
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
|
|
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
|
|
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,
|
|
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
|
|
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, "
|
|
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,
|
|
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"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.constraintSetFromFieldNode = constraintSetFromFieldNode;
|
|
4
|
+
exports.constraintSetFromQueryNode = constraintSetFromQueryNode;
|
|
5
|
+
exports.mergeConstraintRejectionLists = mergeConstraintRejectionLists;
|
|
6
|
+
const guards_1 = require("../../ast/guards");
|
|
7
|
+
const build_field_bundle_1 = require("../../predicate/ir/build-field-bundle");
|
|
8
|
+
const constraint_set_1 = require("./constraint-set");
|
|
9
|
+
const merge_constraint_sources_1 = require("./merge-constraint-sources");
|
|
10
|
+
/**
|
|
11
|
+
* Phase-1 inherited constraints: only plain equality, guarded $in, and simple range atoms.
|
|
12
|
+
* Excludes exists / nin / ne / opaque / array-null-sensitive bundles / path-conflict-risk fields.
|
|
13
|
+
*/
|
|
14
|
+
const ALLOWED_INHERITED_ATOM_KINDS = new Set(["eq", "gt", "gte", "lt", "lte", "in"]);
|
|
15
|
+
function pushRejection(set, fieldPath, atomKind, reason) {
|
|
16
|
+
set.metadata.extractionRejections.push({ fieldPath, atomKind, reason });
|
|
17
|
+
}
|
|
18
|
+
function atomAllowedForInherited(atom, fieldPath, set) {
|
|
19
|
+
if (atom.kind === "opaque") {
|
|
20
|
+
pushRejection(set, fieldPath, "opaque", "opaque operators are not inherited");
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
if (atom.kind === "exists") {
|
|
24
|
+
pushRejection(set, fieldPath, "exists", "exists semantics are not inherited in phase 1");
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
if (atom.kind === "nin") {
|
|
28
|
+
pushRejection(set, fieldPath, "nin", "nin is not inherited");
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
if (atom.kind === "ne") {
|
|
32
|
+
pushRejection(set, fieldPath, "ne", "ne is omitted from inherited constraints (conservative)");
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
if (!ALLOWED_INHERITED_ATOM_KINDS.has(atom.kind)) {
|
|
36
|
+
pushRejection(set, fieldPath, atom.kind, "atom kind not in inherited constraint allowlist");
|
|
37
|
+
return false;
|
|
38
|
+
}
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
function rejectWholeField(set, fieldPath, atomKind, reason, markUnsupported) {
|
|
42
|
+
pushRejection(set, fieldPath, atomKind, reason);
|
|
43
|
+
if (markUnsupported) {
|
|
44
|
+
set.metadata.hasUnsupportedSemantics = true;
|
|
45
|
+
}
|
|
46
|
+
return set;
|
|
47
|
+
}
|
|
48
|
+
function fieldBundleDisallowedForInherited(bundle, set, fieldPath) {
|
|
49
|
+
if (bundle.metadata.hasUnsupportedOperators) {
|
|
50
|
+
rejectWholeField(set, fieldPath, "*", "bundle contains opaque or unsupported operators", true);
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
if (bundle.metadata.hasArraySensitiveSemantics) {
|
|
54
|
+
rejectWholeField(set, fieldPath, "*", "array-sensitive field bundle is not inherited", true);
|
|
55
|
+
return true;
|
|
56
|
+
}
|
|
57
|
+
if (bundle.metadata.hasNullSemantics) {
|
|
58
|
+
rejectWholeField(set, fieldPath, "*", "null-sensitive field bundle is not inherited", true);
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
if (bundle.metadata.hasDottedPathConflictRisk) {
|
|
62
|
+
rejectWholeField(set, fieldPath, "*", "path conflict risk: field excluded from inherited constraints", true);
|
|
63
|
+
return true;
|
|
64
|
+
}
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
function fieldNodeToConstraintSet(node) {
|
|
68
|
+
const bundle = (0, build_field_bundle_1.buildFieldPredicateBundleFromFieldNode)(node);
|
|
69
|
+
const set = (0, constraint_set_1.emptyConstraintSet)();
|
|
70
|
+
if (fieldBundleDisallowedForInherited(bundle, set, node.field)) {
|
|
71
|
+
return set;
|
|
72
|
+
}
|
|
73
|
+
const allowed = [];
|
|
74
|
+
for (const atom of bundle.predicates) {
|
|
75
|
+
if (atomAllowedForInherited(atom, node.field, set)) {
|
|
76
|
+
allowed.push(atom);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
if (allowed.length > 0) {
|
|
80
|
+
set.byField.set(node.field, allowed);
|
|
81
|
+
}
|
|
82
|
+
return set;
|
|
83
|
+
}
|
|
84
|
+
function constraintSetFromFieldNode(node) {
|
|
85
|
+
return fieldNodeToConstraintSet(node);
|
|
86
|
+
}
|
|
87
|
+
function constraintSetFromQueryNode(node) {
|
|
88
|
+
if ((0, guards_1.isTrueNode)(node)) {
|
|
89
|
+
return (0, constraint_set_1.emptyConstraintSet)();
|
|
90
|
+
}
|
|
91
|
+
if ((0, guards_1.isFalseNode)(node)) {
|
|
92
|
+
const set = (0, constraint_set_1.emptyConstraintSet)();
|
|
93
|
+
set.metadata.hasUnsupportedSemantics = true;
|
|
94
|
+
pushRejection(set, "?", "*", "false node has no safe inherited constraints");
|
|
95
|
+
return set;
|
|
96
|
+
}
|
|
97
|
+
if ((0, guards_1.isFieldNode)(node)) {
|
|
98
|
+
return fieldNodeToConstraintSet(node);
|
|
99
|
+
}
|
|
100
|
+
if ((0, guards_1.isOpaqueNode)(node)) {
|
|
101
|
+
const set = (0, constraint_set_1.emptyConstraintSet)();
|
|
102
|
+
set.opaqueConstraints.push(node);
|
|
103
|
+
set.metadata.hasUnsupportedSemantics = true;
|
|
104
|
+
pushRejection(set, "?", "opaque", "opaque query node is not converted to inherited constraints");
|
|
105
|
+
return set;
|
|
106
|
+
}
|
|
107
|
+
if ((0, guards_1.isLogicalNode)(node) && node.op === "$and") {
|
|
108
|
+
const parts = node.children.map((c) => constraintSetFromQueryNode(c));
|
|
109
|
+
return (0, merge_constraint_sources_1.mergeManyConstraintSources)(parts);
|
|
110
|
+
}
|
|
111
|
+
const set = (0, constraint_set_1.emptyConstraintSet)();
|
|
112
|
+
set.metadata.hasUnsupportedSemantics = true;
|
|
113
|
+
pushRejection(set, "?", "*", "non-$and compound shape is not a constraint source for phase 1");
|
|
114
|
+
return set;
|
|
115
|
+
}
|
|
116
|
+
function mergeConstraintRejectionLists(target, more) {
|
|
117
|
+
target.push(...more);
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=build-inherited-constraints.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build-inherited-constraints.js","sourceRoot":"","sources":["../../../src/scope/context/build-inherited-constraints.ts"],"names":[],"mappings":";;AA8GA,gEAEC;AAED,gEA4BC;AAED,sEAKC;AArJD,6CAAqG;AAErG,8EAA+F;AAI/F,qDAAsD;AACtD,yEAAwE;AAExE;;;GAGG;AACH,MAAM,4BAA4B,GAAG,IAAI,GAAG,CAAwB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;AAE5G,SAAS,aAAa,CAClB,GAAkB,EAClB,SAAiB,EACjB,QAAgB,EAChB,MAAc;IAEd,GAAG,CAAC,QAAQ,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;AAC5E,CAAC;AAED,SAAS,uBAAuB,CAC5B,IAAmB,EACnB,SAAiB,EACjB,GAAkB;IAElB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QACzB,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE,oCAAoC,CAAC,CAAC;QAC9E,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QACzB,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE,+CAA+C,CAAC,CAAC;QACzF,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;QACtB,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,KAAK,EAAE,sBAAsB,CAAC,CAAC;QAC7D,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;QACrB,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,yDAAyD,CAAC,CAAC;QAC/F,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,CAAC,4BAA4B,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC/C,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,CAAC,IAAI,EAAE,iDAAiD,CAAC,CAAC;QAC5F,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC;AAED,SAAS,gBAAgB,CACrB,GAAkB,EAClB,SAAiB,EACjB,QAAgB,EAChB,MAAc,EACd,eAAwB;IAExB,aAAa,CAAC,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IAChD,IAAI,eAAe,EAAE,CAAC;QAClB,GAAG,CAAC,QAAQ,CAAC,uBAAuB,GAAG,IAAI,CAAC;IAChD,CAAC;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAED,SAAS,iCAAiC,CACtC,MAA4B,EAC5B,GAAkB,EAClB,SAAiB;IAEjB,IAAI,MAAM,CAAC,QAAQ,CAAC,uBAAuB,EAAE,CAAC;QAC1C,gBAAgB,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,iDAAiD,EAAE,IAAI,CAAC,CAAC;QAC/F,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,IAAI,MAAM,CAAC,QAAQ,CAAC,0BAA0B,EAAE,CAAC;QAC7C,gBAAgB,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,+CAA+C,EAAE,IAAI,CAAC,CAAC;QAC7F,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,IAAI,MAAM,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;QACnC,gBAAgB,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,8CAA8C,EAAE,IAAI,CAAC,CAAC;QAC5F,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,IAAI,MAAM,CAAC,QAAQ,CAAC,yBAAyB,EAAE,CAAC;QAC5C,gBAAgB,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,+DAA+D,EAAE,IAAI,CAAC,CAAC;QAC7G,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,SAAS,wBAAwB,CAAC,IAAe;IAC7C,MAAM,MAAM,GAAG,IAAA,2DAAsC,EAAC,IAAI,CAAC,CAAC;IAC5D,MAAM,GAAG,GAAG,IAAA,mCAAkB,GAAE,CAAC;IAEjC,IAAI,iCAAiC,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAC7D,OAAO,GAAG,CAAC;IACf,CAAC;IAED,MAAM,OAAO,GAAoB,EAAE,CAAC;IACpC,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;QACnC,IAAI,uBAAuB,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,CAAC;YACjD,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;IACL,CAAC;IACD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrB,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACzC,CAAC;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAED,SAAgB,0BAA0B,CAAC,IAAe;IACtD,OAAO,wBAAwB,CAAC,IAAI,CAAC,CAAC;AAC1C,CAAC;AAED,SAAgB,0BAA0B,CAAC,IAAe;IACtD,IAAI,IAAA,mBAAU,EAAC,IAAI,CAAC,EAAE,CAAC;QACnB,OAAO,IAAA,mCAAkB,GAAE,CAAC;IAChC,CAAC;IACD,IAAI,IAAA,oBAAW,EAAC,IAAI,CAAC,EAAE,CAAC;QACpB,MAAM,GAAG,GAAG,IAAA,mCAAkB,GAAE,CAAC;QACjC,GAAG,CAAC,QAAQ,CAAC,uBAAuB,GAAG,IAAI,CAAC;QAC5C,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,8CAA8C,CAAC,CAAC;QAC7E,OAAO,GAAG,CAAC;IACf,CAAC;IACD,IAAI,IAAA,oBAAW,EAAC,IAAI,CAAC,EAAE,CAAC;QACpB,OAAO,wBAAwB,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,IAAA,qBAAY,EAAC,IAAI,CAAC,EAAE,CAAC;QACrB,MAAM,GAAG,GAAG,IAAA,mCAAkB,GAAE,CAAC;QACjC,GAAG,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,GAAG,CAAC,QAAQ,CAAC,uBAAuB,GAAG,IAAI,CAAC;QAC5C,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,QAAQ,EAAE,6DAA6D,CAAC,CAAC;QACjG,OAAO,GAAG,CAAC;IACf,CAAC;IACD,IAAI,IAAA,sBAAa,EAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,KAAK,MAAM,EAAE,CAAC;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC;QACtE,OAAO,IAAA,qDAA0B,EAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IACD,MAAM,GAAG,GAAG,IAAA,mCAAkB,GAAE,CAAC;IACjC,GAAG,CAAC,QAAQ,CAAC,uBAAuB,GAAG,IAAI,CAAC;IAC5C,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,gEAAgE,CAAC,CAAC;IAC/F,OAAO,GAAG,CAAC;AACf,CAAC;AAED,SAAgB,6BAA6B,CACzC,MAAuC,EACvC,IAAqC;IAErC,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;AACzB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { QueryNode } from "../../ast/types";
|
|
2
|
+
import type { PredicateAtom } from "../../predicate/ir/predicate-atom";
|
|
3
|
+
/** Record when an atom or field is not promoted into inherited constraints (phase-1 allowlist). */
|
|
4
|
+
export type ConstraintExtractionRejection = {
|
|
5
|
+
fieldPath: string;
|
|
6
|
+
atomKind: string;
|
|
7
|
+
reason: string;
|
|
8
|
+
};
|
|
9
|
+
export type ConstraintSet = {
|
|
10
|
+
byField: Map<string, PredicateAtom[]>;
|
|
11
|
+
opaqueConstraints: QueryNode[];
|
|
12
|
+
metadata: {
|
|
13
|
+
hasUnsupportedSemantics: boolean;
|
|
14
|
+
extractionRejections: ConstraintExtractionRejection[];
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
export declare function emptyConstraintSet(): ConstraintSet;
|
|
18
|
+
export declare function cloneConstraintSet(set: ConstraintSet): ConstraintSet;
|
|
19
|
+
//# sourceMappingURL=constraint-set.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constraint-set.d.ts","sourceRoot":"","sources":["../../../src/scope/context/constraint-set.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,mGAAmG;AACnG,MAAM,MAAM,6BAA6B,GAAG;IACxC,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IACxB,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;IACtC,iBAAiB,EAAE,SAAS,EAAE,CAAC;IAC/B,QAAQ,EAAE;QACN,uBAAuB,EAAE,OAAO,CAAC;QACjC,oBAAoB,EAAE,6BAA6B,EAAE,CAAC;KACzD,CAAC;CACL,CAAC;AAEF,wBAAgB,kBAAkB,IAAI,aAAa,CAMlD;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,aAAa,GAAG,aAAa,CAapE"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.emptyConstraintSet = emptyConstraintSet;
|
|
4
|
+
exports.cloneConstraintSet = cloneConstraintSet;
|
|
5
|
+
function emptyConstraintSet() {
|
|
6
|
+
return {
|
|
7
|
+
byField: new Map(),
|
|
8
|
+
opaqueConstraints: [],
|
|
9
|
+
metadata: { hasUnsupportedSemantics: false, extractionRejections: [] },
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
function cloneConstraintSet(set) {
|
|
13
|
+
const byField = new Map();
|
|
14
|
+
for (const [k, v] of set.byField) {
|
|
15
|
+
byField.set(k, [...v]);
|
|
16
|
+
}
|
|
17
|
+
return {
|
|
18
|
+
byField,
|
|
19
|
+
opaqueConstraints: [...set.opaqueConstraints],
|
|
20
|
+
metadata: {
|
|
21
|
+
hasUnsupportedSemantics: set.metadata.hasUnsupportedSemantics,
|
|
22
|
+
extractionRejections: [...set.metadata.extractionRejections],
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=constraint-set.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constraint-set.js","sourceRoot":"","sources":["../../../src/scope/context/constraint-set.ts"],"names":[],"mappings":";;AAmBA,gDAMC;AAED,gDAaC;AArBD,SAAgB,kBAAkB;IAC9B,OAAO;QACH,OAAO,EAAE,IAAI,GAAG,EAAE;QAClB,iBAAiB,EAAE,EAAE;QACrB,QAAQ,EAAE,EAAE,uBAAuB,EAAE,KAAK,EAAE,oBAAoB,EAAE,EAAE,EAAE;KACzE,CAAC;AACN,CAAC;AAED,SAAgB,kBAAkB,CAAC,GAAkB;IACjD,MAAM,OAAO,GAAG,IAAI,GAAG,EAA2B,CAAC;IACnD,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;QAC/B,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IACD,OAAO;QACH,OAAO;QACP,iBAAiB,EAAE,CAAC,GAAG,GAAG,CAAC,iBAAiB,CAAC;QAC7C,QAAQ,EAAE;YACN,uBAAuB,EAAE,GAAG,CAAC,QAAQ,CAAC,uBAAuB;YAC7D,oBAAoB,EAAE,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,oBAAoB,CAAC;SAC/D;KACJ,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ConstraintSet } from "./constraint-set";
|
|
2
|
+
export declare function mergeConstraintSources(a: ConstraintSet, b: ConstraintSet): ConstraintSet;
|
|
3
|
+
export declare function mergeManyConstraintSources(sets: ConstraintSet[]): ConstraintSet;
|
|
4
|
+
//# sourceMappingURL=merge-constraint-sources.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge-constraint-sources.d.ts","sourceRoot":"","sources":["../../../src/scope/context/merge-constraint-sources.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAGtD,wBAAgB,sBAAsB,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC,EAAE,aAAa,GAAG,aAAa,CAYxF;AAED,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,aAAa,EAAE,GAAG,aAAa,CAS/E"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mergeConstraintSources = mergeConstraintSources;
|
|
4
|
+
exports.mergeManyConstraintSources = mergeManyConstraintSources;
|
|
5
|
+
const constraint_set_1 = require("./constraint-set");
|
|
6
|
+
function mergeConstraintSources(a, b) {
|
|
7
|
+
const out = (0, constraint_set_1.cloneConstraintSet)(a);
|
|
8
|
+
out.metadata.hasUnsupportedSemantics =
|
|
9
|
+
out.metadata.hasUnsupportedSemantics || b.metadata.hasUnsupportedSemantics;
|
|
10
|
+
out.metadata.extractionRejections.push(...b.metadata.extractionRejections);
|
|
11
|
+
for (const [field, atoms] of b.byField) {
|
|
12
|
+
const cur = out.byField.get(field) ?? [];
|
|
13
|
+
out.byField.set(field, [...cur, ...atoms]);
|
|
14
|
+
}
|
|
15
|
+
out.opaqueConstraints.push(...b.opaqueConstraints);
|
|
16
|
+
return out;
|
|
17
|
+
}
|
|
18
|
+
function mergeManyConstraintSources(sets) {
|
|
19
|
+
if (sets.length === 0) {
|
|
20
|
+
return (0, constraint_set_1.emptyConstraintSet)();
|
|
21
|
+
}
|
|
22
|
+
let acc = (0, constraint_set_1.cloneConstraintSet)(sets[0]);
|
|
23
|
+
for (let i = 1; i < sets.length; i += 1) {
|
|
24
|
+
acc = mergeConstraintSources(acc, sets[i]);
|
|
25
|
+
}
|
|
26
|
+
return acc;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=merge-constraint-sources.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge-constraint-sources.js","sourceRoot":"","sources":["../../../src/scope/context/merge-constraint-sources.ts"],"names":[],"mappings":";;AAGA,wDAYC;AAED,gEASC;AAzBD,qDAA0E;AAE1E,SAAgB,sBAAsB,CAAC,CAAgB,EAAE,CAAgB;IACrE,MAAM,GAAG,GAAG,IAAA,mCAAkB,EAAC,CAAC,CAAC,CAAC;IAClC,GAAG,CAAC,QAAQ,CAAC,uBAAuB;QAChC,GAAG,CAAC,QAAQ,CAAC,uBAAuB,IAAI,CAAC,CAAC,QAAQ,CAAC,uBAAuB,CAAC;IAC/E,GAAG,CAAC,QAAQ,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC;IAE3E,KAAK,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC;QACrC,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACzC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,GAAG,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;IAC/C,CAAC;IACD,GAAG,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,iBAAiB,CAAC,CAAC;IACnD,OAAO,GAAG,CAAC;AACf,CAAC;AAED,SAAgB,0BAA0B,CAAC,IAAqB;IAC5D,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpB,OAAO,IAAA,mCAAkB,GAAE,CAAC;IAChC,CAAC;IACD,IAAI,GAAG,GAAG,IAAA,mCAAkB,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;QACtC,GAAG,GAAG,sBAAsB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IACD,OAAO,GAAG,CAAC;AACf,CAAC"}
|