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,138 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.eqRangeCapability = void 0;
|
|
4
|
+
const merge_range_bounds_1 = require("../../analysis/merge-range-bounds");
|
|
5
|
+
const build_field_bundle_1 = require("../../ir/build-field-bundle");
|
|
6
|
+
const relation_result_1 = require("../shared/relation-result");
|
|
7
|
+
const intersect_in_lists_1 = require("../../utils/intersect-in-lists");
|
|
8
|
+
const set_ops_1 = require("../../utils/set-ops");
|
|
9
|
+
const value_equality_1 = require("../../utils/value-equality");
|
|
10
|
+
const bson_compare_1 = require("../../utils/bson-compare");
|
|
11
|
+
function rangeAtomFromLower(lower) {
|
|
12
|
+
if (lower.kind === "gt") {
|
|
13
|
+
return { kind: "gt", value: lower.value };
|
|
14
|
+
}
|
|
15
|
+
return { kind: "gte", value: lower.value };
|
|
16
|
+
}
|
|
17
|
+
function rangeAtomFromUpper(upper) {
|
|
18
|
+
if (upper.kind === "lt") {
|
|
19
|
+
return { kind: "lt", value: upper.value };
|
|
20
|
+
}
|
|
21
|
+
return { kind: "lte", value: upper.value };
|
|
22
|
+
}
|
|
23
|
+
function inValuesSameSet(a, b) {
|
|
24
|
+
const ua = (0, set_ops_1.uniqueUnknownArray)(a);
|
|
25
|
+
const ub = (0, set_ops_1.uniqueUnknownArray)(b);
|
|
26
|
+
if (ua.length !== ub.length) {
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
return ua.every((v) => ub.some((w) => (0, value_equality_1.valuesEqual)(v, w)));
|
|
30
|
+
}
|
|
31
|
+
exports.eqRangeCapability = {
|
|
32
|
+
id: "eq.range",
|
|
33
|
+
description: "Detect impossible $eq/$in vs range combinations; tighten or drop redundant bounds",
|
|
34
|
+
riskLevel: "safe",
|
|
35
|
+
supportedAtomKinds: ["eq", "in", "gt", "gte", "lt", "lte"],
|
|
36
|
+
isApplicable(ctx) {
|
|
37
|
+
if (!ctx.engine.mergeComparable && !ctx.engine.collapseContradictions) {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
const hasEq = ctx.bundle.predicates.some((a) => a.kind === "eq");
|
|
41
|
+
const hasIn = ctx.bundle.predicates.some((a) => a.kind === "in");
|
|
42
|
+
const hasRange = ctx.bundle.predicates.some(merge_range_bounds_1.isRangeAtom);
|
|
43
|
+
return (hasEq && hasRange) || (hasIn && hasRange);
|
|
44
|
+
},
|
|
45
|
+
apply(ctx) {
|
|
46
|
+
const base = (0, relation_result_1.emptyRelationResult)(ctx.bundle);
|
|
47
|
+
const predicates = ctx.bundle.predicates;
|
|
48
|
+
const rangeAtoms = predicates.filter(merge_range_bounds_1.isRangeAtom);
|
|
49
|
+
const inAtoms = predicates.filter((a) => a.kind === "in");
|
|
50
|
+
const otherAtoms = predicates.filter((a) => !(0, merge_range_bounds_1.isRangeAtom)(a) && a.kind !== "in");
|
|
51
|
+
if (rangeAtoms.length === 0) {
|
|
52
|
+
return base;
|
|
53
|
+
}
|
|
54
|
+
const merged = (0, merge_range_bounds_1.mergeRangeBoundsFromRangeAtoms)(rangeAtoms);
|
|
55
|
+
if ((0, merge_range_bounds_1.mergedBoundsContradict)(merged.lower, merged.upper)) {
|
|
56
|
+
return { ...base, contradiction: true, changed: true };
|
|
57
|
+
}
|
|
58
|
+
const eq = otherAtoms.find((a) => a.kind === "eq");
|
|
59
|
+
if (eq && eq.kind === "eq") {
|
|
60
|
+
if (!(0, bson_compare_1.isComparableScalar)(eq.value)) {
|
|
61
|
+
return {
|
|
62
|
+
...base,
|
|
63
|
+
skippedAtoms: [eq],
|
|
64
|
+
warnings: [`field ${ctx.bundle.fieldPath}: $eq is not comparable with range`],
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
if (ctx.engine.collapseContradictions && !(0, merge_range_bounds_1.valueSatisfiesMergedRange)(eq.value, merged.lower, merged.upper)) {
|
|
68
|
+
return { ...base, contradiction: true, changed: true };
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
let changed = false;
|
|
72
|
+
const coveredAtoms = [];
|
|
73
|
+
let nextInAtoms = inAtoms;
|
|
74
|
+
let shouldDropRanges = false;
|
|
75
|
+
let inTightened = false;
|
|
76
|
+
if (inAtoms.length > 0 &&
|
|
77
|
+
!merged.skippedNonComparableRange &&
|
|
78
|
+
(ctx.engine.mergeComparable || ctx.engine.collapseContradictions)) {
|
|
79
|
+
const intersected = inAtoms.length === 1 ? [...inAtoms[0].values] : (0, intersect_in_lists_1.intersectInAtomValues)(inAtoms);
|
|
80
|
+
const allComparable = intersected.length > 0 && intersected.every(bson_compare_1.isComparableScalar);
|
|
81
|
+
if (allComparable) {
|
|
82
|
+
const filtered = intersected.filter((v) => (0, merge_range_bounds_1.valueSatisfiesMergedRange)(v, merged.lower, merged.upper));
|
|
83
|
+
if (filtered.length === 0 && intersected.length > 0 && ctx.engine.collapseContradictions) {
|
|
84
|
+
return { ...base, contradiction: true, changed: true };
|
|
85
|
+
}
|
|
86
|
+
if (ctx.engine.mergeComparable && filtered.length > 0) {
|
|
87
|
+
const uniqFiltered = (0, set_ops_1.uniqueUnknownArray)(filtered);
|
|
88
|
+
inTightened =
|
|
89
|
+
inAtoms.length > 1 ||
|
|
90
|
+
(inAtoms.length === 1 && !inValuesSameSet(inAtoms[0].values, uniqFiltered));
|
|
91
|
+
if (inTightened) {
|
|
92
|
+
nextInAtoms = [{ kind: "in", values: uniqFiltered }];
|
|
93
|
+
coveredAtoms.push(...inAtoms);
|
|
94
|
+
}
|
|
95
|
+
shouldDropRanges = true;
|
|
96
|
+
changed = true;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (ctx.engine.mergeComparable &&
|
|
101
|
+
eq &&
|
|
102
|
+
eq.kind === "eq" &&
|
|
103
|
+
(0, bson_compare_1.isComparableScalar)(eq.value) &&
|
|
104
|
+
(0, merge_range_bounds_1.valueSatisfiesMergedRange)(eq.value, merged.lower, merged.upper)) {
|
|
105
|
+
shouldDropRanges = true;
|
|
106
|
+
changed = true;
|
|
107
|
+
}
|
|
108
|
+
if (!changed) {
|
|
109
|
+
return base;
|
|
110
|
+
}
|
|
111
|
+
if (shouldDropRanges) {
|
|
112
|
+
coveredAtoms.push(...rangeAtoms);
|
|
113
|
+
}
|
|
114
|
+
const rangeOut = [];
|
|
115
|
+
if (!shouldDropRanges) {
|
|
116
|
+
if (merged.lower) {
|
|
117
|
+
rangeOut.push(rangeAtomFromLower(merged.lower));
|
|
118
|
+
}
|
|
119
|
+
if (merged.upper) {
|
|
120
|
+
rangeOut.push(rangeAtomFromUpper(merged.upper));
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
const nextPredicates = [...otherAtoms, ...nextInAtoms, ...rangeOut];
|
|
124
|
+
const bundle = (0, build_field_bundle_1.refreshBundleMetadata)({
|
|
125
|
+
...ctx.bundle,
|
|
126
|
+
predicates: nextPredicates,
|
|
127
|
+
});
|
|
128
|
+
return {
|
|
129
|
+
bundle,
|
|
130
|
+
changed: true,
|
|
131
|
+
contradiction: false,
|
|
132
|
+
coveredAtoms,
|
|
133
|
+
skippedAtoms: [],
|
|
134
|
+
warnings: [],
|
|
135
|
+
};
|
|
136
|
+
},
|
|
137
|
+
};
|
|
138
|
+
//# sourceMappingURL=eq-range.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eq-range.js","sourceRoot":"","sources":["../../../../src/predicate/capabilities/eq/eq-range.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"range-range.d.ts","sourceRoot":"","sources":["../../../../src/predicate/capabilities/range/range-range.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAkFtE,eAAO,MAAM,oBAAoB,EAAE,mBA0FlC,CAAC"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.rangeRangeCapability = void 0;
|
|
4
|
+
const build_field_bundle_1 = require("../../ir/build-field-bundle");
|
|
5
|
+
const relation_result_1 = require("../shared/relation-result");
|
|
6
|
+
const bson_compare_1 = require("../../utils/bson-compare");
|
|
7
|
+
function toRangeLower(atom) {
|
|
8
|
+
if (atom.kind === "gt" || atom.kind === "gte") {
|
|
9
|
+
return { kind: atom.kind, value: atom.value };
|
|
10
|
+
}
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
function toRangeUpper(atom) {
|
|
14
|
+
if (atom.kind === "lt" || atom.kind === "lte") {
|
|
15
|
+
return { kind: atom.kind, value: atom.value };
|
|
16
|
+
}
|
|
17
|
+
return null;
|
|
18
|
+
}
|
|
19
|
+
function chooseStrongerLowerBound(lower, p) {
|
|
20
|
+
if (!lower) {
|
|
21
|
+
return p;
|
|
22
|
+
}
|
|
23
|
+
const cmp = (0, bson_compare_1.compareScalarValues)(p.value, lower.value);
|
|
24
|
+
if (cmp === null) {
|
|
25
|
+
return lower;
|
|
26
|
+
}
|
|
27
|
+
if (cmp > 0) {
|
|
28
|
+
return p;
|
|
29
|
+
}
|
|
30
|
+
if (cmp < 0) {
|
|
31
|
+
return lower;
|
|
32
|
+
}
|
|
33
|
+
if (p.kind === "gt" && lower.kind === "gte") {
|
|
34
|
+
return p;
|
|
35
|
+
}
|
|
36
|
+
if (p.kind === "gte" && lower.kind === "gt") {
|
|
37
|
+
return lower;
|
|
38
|
+
}
|
|
39
|
+
return lower;
|
|
40
|
+
}
|
|
41
|
+
function chooseStrongerUpperBound(upper, p) {
|
|
42
|
+
if (!upper) {
|
|
43
|
+
return p;
|
|
44
|
+
}
|
|
45
|
+
const cmp = (0, bson_compare_1.compareScalarValues)(p.value, upper.value);
|
|
46
|
+
if (cmp === null) {
|
|
47
|
+
return upper;
|
|
48
|
+
}
|
|
49
|
+
if (cmp < 0) {
|
|
50
|
+
return p;
|
|
51
|
+
}
|
|
52
|
+
if (cmp > 0) {
|
|
53
|
+
return upper;
|
|
54
|
+
}
|
|
55
|
+
if (p.kind === "lt" && upper.kind === "lte") {
|
|
56
|
+
return p;
|
|
57
|
+
}
|
|
58
|
+
if (p.kind === "lte" && upper.kind === "lt") {
|
|
59
|
+
return upper;
|
|
60
|
+
}
|
|
61
|
+
return upper;
|
|
62
|
+
}
|
|
63
|
+
function rangeAtomFromLower(lower) {
|
|
64
|
+
if (lower.kind === "gt") {
|
|
65
|
+
return { kind: "gt", value: lower.value };
|
|
66
|
+
}
|
|
67
|
+
return { kind: "gte", value: lower.value };
|
|
68
|
+
}
|
|
69
|
+
function rangeAtomFromUpper(upper) {
|
|
70
|
+
if (upper.kind === "lt") {
|
|
71
|
+
return { kind: "lt", value: upper.value };
|
|
72
|
+
}
|
|
73
|
+
return { kind: "lte", value: upper.value };
|
|
74
|
+
}
|
|
75
|
+
exports.rangeRangeCapability = {
|
|
76
|
+
id: "range.range",
|
|
77
|
+
description: "Merge multiple range bounds on the same field",
|
|
78
|
+
riskLevel: "safe",
|
|
79
|
+
supportedAtomKinds: ["gt", "gte", "lt", "lte"],
|
|
80
|
+
isApplicable(ctx) {
|
|
81
|
+
if (!ctx.engine.mergeComparable && !ctx.engine.collapseContradictions) {
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
const rangeCount = ctx.bundle.predicates.filter((a) => a.kind === "gt" || a.kind === "gte" || a.kind === "lt" || a.kind === "lte").length;
|
|
85
|
+
return rangeCount >= 2;
|
|
86
|
+
},
|
|
87
|
+
apply(ctx) {
|
|
88
|
+
const base = (0, relation_result_1.emptyRelationResult)(ctx.bundle);
|
|
89
|
+
let lower = null;
|
|
90
|
+
let upper = null;
|
|
91
|
+
const others = [];
|
|
92
|
+
for (const p of ctx.bundle.predicates) {
|
|
93
|
+
const asLower = toRangeLower(p);
|
|
94
|
+
if (asLower) {
|
|
95
|
+
if (!(0, bson_compare_1.isComparableScalar)(asLower.value)) {
|
|
96
|
+
return {
|
|
97
|
+
...base,
|
|
98
|
+
warnings: [`field ${ctx.bundle.fieldPath}: predicate ${asLower.kind} is not comparable`],
|
|
99
|
+
skippedAtoms: [p],
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
lower = chooseStrongerLowerBound(lower, asLower);
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
const asUpper = toRangeUpper(p);
|
|
106
|
+
if (asUpper) {
|
|
107
|
+
if (!(0, bson_compare_1.isComparableScalar)(asUpper.value)) {
|
|
108
|
+
return {
|
|
109
|
+
...base,
|
|
110
|
+
warnings: [`field ${ctx.bundle.fieldPath}: predicate ${asUpper.kind} is not comparable`],
|
|
111
|
+
skippedAtoms: [p],
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
upper = chooseStrongerUpperBound(upper, asUpper);
|
|
115
|
+
continue;
|
|
116
|
+
}
|
|
117
|
+
others.push(p);
|
|
118
|
+
}
|
|
119
|
+
if (lower && upper) {
|
|
120
|
+
const cmp = (0, bson_compare_1.compareScalarValues)(lower.value, upper.value);
|
|
121
|
+
if (cmp === 1) {
|
|
122
|
+
return { ...base, contradiction: true, changed: true };
|
|
123
|
+
}
|
|
124
|
+
if (cmp === 0 && (lower.kind === "gt" || upper.kind === "lt")) {
|
|
125
|
+
return { ...base, contradiction: true, changed: true };
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
const hadMultipleRange = ctx.bundle.predicates.filter((a) => a.kind === "gt" || a.kind === "gte" || a.kind === "lt" || a.kind === "lte").length >= 2;
|
|
129
|
+
if (!hadMultipleRange) {
|
|
130
|
+
return base;
|
|
131
|
+
}
|
|
132
|
+
const mergedRange = [];
|
|
133
|
+
if (lower) {
|
|
134
|
+
mergedRange.push(rangeAtomFromLower(lower));
|
|
135
|
+
}
|
|
136
|
+
if (upper) {
|
|
137
|
+
mergedRange.push(rangeAtomFromUpper(upper));
|
|
138
|
+
}
|
|
139
|
+
const nextPredicates = [...others, ...mergedRange];
|
|
140
|
+
const bundle = (0, build_field_bundle_1.refreshBundleMetadata)({
|
|
141
|
+
...ctx.bundle,
|
|
142
|
+
predicates: nextPredicates,
|
|
143
|
+
});
|
|
144
|
+
return {
|
|
145
|
+
bundle,
|
|
146
|
+
changed: true,
|
|
147
|
+
contradiction: false,
|
|
148
|
+
coveredAtoms: [],
|
|
149
|
+
skippedAtoms: [],
|
|
150
|
+
warnings: [],
|
|
151
|
+
};
|
|
152
|
+
},
|
|
153
|
+
};
|
|
154
|
+
//# sourceMappingURL=range-range.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"range-range.js","sourceRoot":"","sources":["../../../../src/predicate/capabilities/range/range-range.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { RelationContext } from "./relation-context";
|
|
2
|
+
import type { RelationResult } from "./relation-result";
|
|
3
|
+
export type PredicateCapability = {
|
|
4
|
+
id: string;
|
|
5
|
+
description: string;
|
|
6
|
+
riskLevel: "safe" | "guarded" | "provisional";
|
|
7
|
+
supportedAtomKinds: string[];
|
|
8
|
+
isApplicable: (ctx: RelationContext) => boolean;
|
|
9
|
+
apply: (ctx: RelationContext) => RelationResult;
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=capability-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"capability-types.d.ts","sourceRoot":"","sources":["../../../../src/predicate/capabilities/shared/capability-types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,MAAM,MAAM,mBAAmB,GAAG;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,aAAa,CAAC;IAC9C,kBAAkB,EAAE,MAAM,EAAE,CAAC;IAC7B,YAAY,EAAE,CAAC,GAAG,EAAE,eAAe,KAAK,OAAO,CAAC;IAChD,KAAK,EAAE,CAAC,GAAG,EAAE,eAAe,KAAK,cAAc,CAAC;CACnD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"capability-types.js","sourceRoot":"","sources":["../../../../src/predicate/capabilities/shared/capability-types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { FieldPredicateBundle } from "../../ir/field-predicate-bundle";
|
|
2
|
+
import type { PredicateSafetyPolicy } from "../../safety/predicate-safety-policy";
|
|
3
|
+
export type PredicateEngineFlags = {
|
|
4
|
+
dedupeAtoms: boolean;
|
|
5
|
+
mergeComparable: boolean;
|
|
6
|
+
collapseContradictions: boolean;
|
|
7
|
+
};
|
|
8
|
+
export type RelationContext = {
|
|
9
|
+
bundle: FieldPredicateBundle;
|
|
10
|
+
safety: PredicateSafetyPolicy;
|
|
11
|
+
engine: PredicateEngineFlags;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=relation-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation-context.d.ts","sourceRoot":"","sources":["../../../../src/predicate/capabilities/shared/relation-context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAElF,MAAM,MAAM,oBAAoB,GAAG;IAC/B,WAAW,EAAE,OAAO,CAAC;IACrB,eAAe,EAAE,OAAO,CAAC;IACzB,sBAAsB,EAAE,OAAO,CAAC;CACnC,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC1B,MAAM,EAAE,oBAAoB,CAAC;IAC7B,MAAM,EAAE,qBAAqB,CAAC;IAC9B,MAAM,EAAE,oBAAoB,CAAC;CAChC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation-context.js","sourceRoot":"","sources":["../../../../src/predicate/capabilities/shared/relation-context.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { FieldPredicateBundle } from "../../ir/field-predicate-bundle";
|
|
2
|
+
import type { PredicateAtom } from "../../ir/predicate-atom";
|
|
3
|
+
export type RelationResult = {
|
|
4
|
+
bundle: FieldPredicateBundle;
|
|
5
|
+
changed: boolean;
|
|
6
|
+
contradiction: boolean;
|
|
7
|
+
coveredAtoms: PredicateAtom[];
|
|
8
|
+
skippedAtoms: PredicateAtom[];
|
|
9
|
+
warnings: string[];
|
|
10
|
+
};
|
|
11
|
+
export declare function emptyRelationResult(bundle: FieldPredicateBundle): RelationResult;
|
|
12
|
+
//# sourceMappingURL=relation-result.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation-result.d.ts","sourceRoot":"","sources":["../../../../src/predicate/capabilities/shared/relation-result.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAC5E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAE7D,MAAM,MAAM,cAAc,GAAG;IACzB,MAAM,EAAE,oBAAoB,CAAC;IAC7B,OAAO,EAAE,OAAO,CAAC;IACjB,aAAa,EAAE,OAAO,CAAC;IACvB,YAAY,EAAE,aAAa,EAAE,CAAC;IAC9B,YAAY,EAAE,aAAa,EAAE,CAAC;IAC9B,QAAQ,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,oBAAoB,GAAG,cAAc,CAShF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.emptyRelationResult = emptyRelationResult;
|
|
4
|
+
function emptyRelationResult(bundle) {
|
|
5
|
+
return {
|
|
6
|
+
bundle,
|
|
7
|
+
changed: false,
|
|
8
|
+
contradiction: false,
|
|
9
|
+
coveredAtoms: [],
|
|
10
|
+
skippedAtoms: [],
|
|
11
|
+
warnings: [],
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=relation-result.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation-result.js","sourceRoot":"","sources":["../../../../src/predicate/capabilities/shared/relation-result.ts"],"names":[],"mappings":";;AAYA,kDASC;AATD,SAAgB,mBAAmB,CAAC,MAA4B;IAC5D,OAAO;QACH,MAAM;QACN,OAAO,EAAE,KAAK;QACd,aAAa,EAAE,KAAK;QACpB,YAAY,EAAE,EAAE;QAChB,YAAY,EAAE,EAAE;QAChB,QAAQ,EAAE,EAAE;KACf,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type { PredicateAtom } from "./ir/predicate-atom";
|
|
2
|
+
export type { FieldPredicateBundle, FieldPredicateBundleMetadata } from "./ir/field-predicate-bundle";
|
|
3
|
+
export { buildFieldPredicateBundleFromFieldNode, cloneBundle, refreshBundleMetadata } from "./ir/build-field-bundle";
|
|
4
|
+
export { compileFieldPredicateBundleToAst } from "./ir/compile-field-bundle";
|
|
5
|
+
export type { LocalNormalizeResult } from "./local-normalize-result";
|
|
6
|
+
export { normalizeFieldPredicateBundle, detectLocalContradiction, detectLocalCoverage, analyzeFieldPredicateBundle, compileLocalNormalizeResultToAst, type NormalizeFieldPredicateBundleOptions, } from "./normalize-field-predicate-bundle";
|
|
7
|
+
export { DEFAULT_PREDICATE_SAFETY_POLICY, type PredicateSafetyPolicy } from "./safety/predicate-safety-policy";
|
|
8
|
+
export { getDefaultPredicateCapabilities } from "./registry/predicate-capability-registry";
|
|
9
|
+
export type { PredicateCapability } from "./capabilities/shared/capability-types";
|
|
10
|
+
export type { RelationContext, PredicateEngineFlags } from "./capabilities/shared/relation-context";
|
|
11
|
+
export { planRelations } from "./planner/relation-planner";
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/predicate/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACzD,YAAY,EAAE,oBAAoB,EAAE,4BAA4B,EAAE,MAAM,6BAA6B,CAAC;AACtG,OAAO,EAAE,sCAAsC,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AACrH,OAAO,EAAE,gCAAgC,EAAE,MAAM,2BAA2B,CAAC;AAC7E,YAAY,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AACrE,OAAO,EACH,6BAA6B,EAC7B,wBAAwB,EACxB,mBAAmB,EACnB,2BAA2B,EAC3B,gCAAgC,EAChC,KAAK,oCAAoC,GAC5C,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,+BAA+B,EAAE,KAAK,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AAC/G,OAAO,EAAE,+BAA+B,EAAE,MAAM,0CAA0C,CAAC;AAC3F,YAAY,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAClF,YAAY,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AACpG,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.planRelations = exports.getDefaultPredicateCapabilities = exports.DEFAULT_PREDICATE_SAFETY_POLICY = exports.compileLocalNormalizeResultToAst = exports.analyzeFieldPredicateBundle = exports.detectLocalCoverage = exports.detectLocalContradiction = exports.normalizeFieldPredicateBundle = exports.compileFieldPredicateBundleToAst = exports.refreshBundleMetadata = exports.cloneBundle = exports.buildFieldPredicateBundleFromFieldNode = void 0;
|
|
4
|
+
var build_field_bundle_1 = require("./ir/build-field-bundle");
|
|
5
|
+
Object.defineProperty(exports, "buildFieldPredicateBundleFromFieldNode", { enumerable: true, get: function () { return build_field_bundle_1.buildFieldPredicateBundleFromFieldNode; } });
|
|
6
|
+
Object.defineProperty(exports, "cloneBundle", { enumerable: true, get: function () { return build_field_bundle_1.cloneBundle; } });
|
|
7
|
+
Object.defineProperty(exports, "refreshBundleMetadata", { enumerable: true, get: function () { return build_field_bundle_1.refreshBundleMetadata; } });
|
|
8
|
+
var compile_field_bundle_1 = require("./ir/compile-field-bundle");
|
|
9
|
+
Object.defineProperty(exports, "compileFieldPredicateBundleToAst", { enumerable: true, get: function () { return compile_field_bundle_1.compileFieldPredicateBundleToAst; } });
|
|
10
|
+
var normalize_field_predicate_bundle_1 = require("./normalize-field-predicate-bundle");
|
|
11
|
+
Object.defineProperty(exports, "normalizeFieldPredicateBundle", { enumerable: true, get: function () { return normalize_field_predicate_bundle_1.normalizeFieldPredicateBundle; } });
|
|
12
|
+
Object.defineProperty(exports, "detectLocalContradiction", { enumerable: true, get: function () { return normalize_field_predicate_bundle_1.detectLocalContradiction; } });
|
|
13
|
+
Object.defineProperty(exports, "detectLocalCoverage", { enumerable: true, get: function () { return normalize_field_predicate_bundle_1.detectLocalCoverage; } });
|
|
14
|
+
Object.defineProperty(exports, "analyzeFieldPredicateBundle", { enumerable: true, get: function () { return normalize_field_predicate_bundle_1.analyzeFieldPredicateBundle; } });
|
|
15
|
+
Object.defineProperty(exports, "compileLocalNormalizeResultToAst", { enumerable: true, get: function () { return normalize_field_predicate_bundle_1.compileLocalNormalizeResultToAst; } });
|
|
16
|
+
var predicate_safety_policy_1 = require("./safety/predicate-safety-policy");
|
|
17
|
+
Object.defineProperty(exports, "DEFAULT_PREDICATE_SAFETY_POLICY", { enumerable: true, get: function () { return predicate_safety_policy_1.DEFAULT_PREDICATE_SAFETY_POLICY; } });
|
|
18
|
+
var predicate_capability_registry_1 = require("./registry/predicate-capability-registry");
|
|
19
|
+
Object.defineProperty(exports, "getDefaultPredicateCapabilities", { enumerable: true, get: function () { return predicate_capability_registry_1.getDefaultPredicateCapabilities; } });
|
|
20
|
+
var relation_planner_1 = require("./planner/relation-planner");
|
|
21
|
+
Object.defineProperty(exports, "planRelations", { enumerable: true, get: function () { return relation_planner_1.planRelations; } });
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/predicate/index.ts"],"names":[],"mappings":";;;AAEA,8DAAqH;AAA5G,4IAAA,sCAAsC,OAAA;AAAE,iHAAA,WAAW,OAAA;AAAE,2HAAA,qBAAqB,OAAA;AACnF,kEAA6E;AAApE,wIAAA,gCAAgC,OAAA;AAEzC,uFAO4C;AANxC,iJAAA,6BAA6B,OAAA;AAC7B,4IAAA,wBAAwB,OAAA;AACxB,uIAAA,mBAAmB,OAAA;AACnB,+IAAA,2BAA2B,OAAA;AAC3B,oJAAA,gCAAgC,OAAA;AAGpC,4EAA+G;AAAtG,0IAAA,+BAA+B,OAAA;AACxC,0FAA2F;AAAlF,gJAAA,+BAA+B,OAAA;AAGxC,+DAA2D;AAAlD,iHAAA,aAAa,OAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { FieldNode } from "../../ast/types";
|
|
2
|
+
import type { FieldPredicateBundle } from "./field-predicate-bundle";
|
|
3
|
+
export declare function buildFieldPredicateBundleFromFieldNode(node: FieldNode): FieldPredicateBundle;
|
|
4
|
+
export declare function cloneBundle(bundle: FieldPredicateBundle): FieldPredicateBundle;
|
|
5
|
+
export declare function refreshBundleMetadata(bundle: FieldPredicateBundle): FieldPredicateBundle;
|
|
6
|
+
export declare function detectUnsupportedMix(bundle: FieldPredicateBundle): boolean;
|
|
7
|
+
//# sourceMappingURL=build-field-bundle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build-field-bundle.d.ts","sourceRoot":"","sources":["../../../src/predicate/ir/build-field-bundle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAkB,MAAM,iBAAiB,CAAC;AAKjE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAgDrE,wBAAgB,sCAAsC,CAAC,IAAI,EAAE,SAAS,GAAG,oBAAoB,CAgB5F;AAED,wBAAgB,WAAW,CAAC,MAAM,EAAE,oBAAoB,GAAG,oBAAoB,CAQ9E;AAED,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,oBAAoB,GAAG,oBAAoB,CAKxF;AAED,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAE1E"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildFieldPredicateBundleFromFieldNode = buildFieldPredicateBundleFromFieldNode;
|
|
4
|
+
exports.cloneBundle = cloneBundle;
|
|
5
|
+
exports.refreshBundleMetadata = refreshBundleMetadata;
|
|
6
|
+
exports.detectUnsupportedMix = detectUnsupportedMix;
|
|
7
|
+
const detect_array_sensitive_1 = require("../analysis/detect-array-sensitive");
|
|
8
|
+
const detect_path_conflict_risk_1 = require("../analysis/detect-path-conflict-risk");
|
|
9
|
+
const detect_null_sensitive_1 = require("../analysis/detect-null-sensitive");
|
|
10
|
+
const detect_opaque_mix_1 = require("../analysis/detect-opaque-mix");
|
|
11
|
+
function fieldPredicateToAtom(predicate) {
|
|
12
|
+
if (predicate.opaque || predicate.op === "raw") {
|
|
13
|
+
return { kind: "opaque", operator: predicate.op, raw: predicate.value };
|
|
14
|
+
}
|
|
15
|
+
switch (predicate.op) {
|
|
16
|
+
case "$eq":
|
|
17
|
+
return { kind: "eq", value: predicate.value };
|
|
18
|
+
case "$ne":
|
|
19
|
+
return { kind: "ne", value: predicate.value };
|
|
20
|
+
case "$in":
|
|
21
|
+
return {
|
|
22
|
+
kind: "in",
|
|
23
|
+
values: Array.isArray(predicate.value) ? [...predicate.value] : [predicate.value],
|
|
24
|
+
};
|
|
25
|
+
case "$nin":
|
|
26
|
+
return {
|
|
27
|
+
kind: "nin",
|
|
28
|
+
values: Array.isArray(predicate.value) ? [...predicate.value] : [predicate.value],
|
|
29
|
+
};
|
|
30
|
+
case "$gt":
|
|
31
|
+
return { kind: "gt", value: predicate.value };
|
|
32
|
+
case "$gte":
|
|
33
|
+
return { kind: "gte", value: predicate.value };
|
|
34
|
+
case "$lt":
|
|
35
|
+
return { kind: "lt", value: predicate.value };
|
|
36
|
+
case "$lte":
|
|
37
|
+
return { kind: "lte", value: predicate.value };
|
|
38
|
+
case "$exists":
|
|
39
|
+
return { kind: "exists", value: Boolean(predicate.value) };
|
|
40
|
+
default:
|
|
41
|
+
return { kind: "opaque", operator: predicate.op, raw: predicate.value };
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
function computeMetadata(bundle) {
|
|
45
|
+
const hasUnsupportedOperators = bundle.predicates.some((a) => a.kind === "opaque");
|
|
46
|
+
return {
|
|
47
|
+
hasArraySensitiveSemantics: (0, detect_array_sensitive_1.detectArraySensitiveSemantics)(bundle),
|
|
48
|
+
hasNullSemantics: (0, detect_null_sensitive_1.detectNullSensitiveSemantics)(bundle),
|
|
49
|
+
hasUnsupportedOperators,
|
|
50
|
+
hasDottedPathConflictRisk: (0, detect_path_conflict_risk_1.detectDottedPathConflictRisk)(bundle),
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
function buildFieldPredicateBundleFromFieldNode(node) {
|
|
54
|
+
const predicates = node.predicates.map(fieldPredicateToAtom);
|
|
55
|
+
const bundle = {
|
|
56
|
+
fieldPath: node.field,
|
|
57
|
+
sourceNodes: [node],
|
|
58
|
+
predicates,
|
|
59
|
+
opaqueNodes: [],
|
|
60
|
+
metadata: {
|
|
61
|
+
hasArraySensitiveSemantics: false,
|
|
62
|
+
hasNullSemantics: false,
|
|
63
|
+
hasUnsupportedOperators: false,
|
|
64
|
+
hasDottedPathConflictRisk: false,
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
bundle.metadata = computeMetadata(bundle);
|
|
68
|
+
return bundle;
|
|
69
|
+
}
|
|
70
|
+
function cloneBundle(bundle) {
|
|
71
|
+
return {
|
|
72
|
+
fieldPath: bundle.fieldPath,
|
|
73
|
+
sourceNodes: [...bundle.sourceNodes],
|
|
74
|
+
predicates: [...bundle.predicates],
|
|
75
|
+
opaqueNodes: [...bundle.opaqueNodes],
|
|
76
|
+
metadata: { ...bundle.metadata },
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
function refreshBundleMetadata(bundle) {
|
|
80
|
+
return {
|
|
81
|
+
...bundle,
|
|
82
|
+
metadata: computeMetadata(bundle),
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
function detectUnsupportedMix(bundle) {
|
|
86
|
+
return (0, detect_opaque_mix_1.detectOpaqueMix)(bundle);
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=build-field-bundle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build-field-bundle.js","sourceRoot":"","sources":["../../../src/predicate/ir/build-field-bundle.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { QueryNode } from "../../ast/types";
|
|
2
|
+
import type { FieldPredicateBundle } from "./field-predicate-bundle";
|
|
3
|
+
export declare function compileFieldPredicateBundleToAst(bundle: FieldPredicateBundle, contradiction: boolean): QueryNode;
|
|
4
|
+
//# sourceMappingURL=compile-field-bundle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compile-field-bundle.d.ts","sourceRoot":"","sources":["../../../src/predicate/ir/compile-field-bundle.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAkB,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAkDrE,wBAAgB,gCAAgC,CAAC,MAAM,EAAE,oBAAoB,EAAE,aAAa,EAAE,OAAO,GAAG,SAAS,CAQhH"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.compileFieldPredicateBundleToAst = compileFieldPredicateBundleToAst;
|
|
4
|
+
const builders_1 = require("../../ast/builders");
|
|
5
|
+
function atomToFieldPredicate(atom) {
|
|
6
|
+
switch (atom.kind) {
|
|
7
|
+
case "eq":
|
|
8
|
+
return { op: "$eq", value: atom.value };
|
|
9
|
+
case "ne":
|
|
10
|
+
return { op: "$ne", value: atom.value };
|
|
11
|
+
case "in":
|
|
12
|
+
return { op: "$in", value: atom.values };
|
|
13
|
+
case "nin":
|
|
14
|
+
return { op: "$nin", value: atom.values };
|
|
15
|
+
case "gt":
|
|
16
|
+
return { op: "$gt", value: atom.value };
|
|
17
|
+
case "gte":
|
|
18
|
+
return { op: "$gte", value: atom.value };
|
|
19
|
+
case "lt":
|
|
20
|
+
return { op: "$lt", value: atom.value };
|
|
21
|
+
case "lte":
|
|
22
|
+
return { op: "$lte", value: atom.value };
|
|
23
|
+
case "exists":
|
|
24
|
+
return { op: "$exists", value: atom.value };
|
|
25
|
+
case "opaque":
|
|
26
|
+
return { op: atom.operator === "raw" ? "raw" : atom.operator, value: atom.raw, opaque: true };
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
const KIND_ORDER = {
|
|
30
|
+
eq: 0,
|
|
31
|
+
ne: 1,
|
|
32
|
+
in: 2,
|
|
33
|
+
nin: 3,
|
|
34
|
+
gt: 4,
|
|
35
|
+
gte: 5,
|
|
36
|
+
lt: 6,
|
|
37
|
+
lte: 7,
|
|
38
|
+
exists: 8,
|
|
39
|
+
opaque: 9,
|
|
40
|
+
};
|
|
41
|
+
function compareAtomsForStableOrder(a, b) {
|
|
42
|
+
const ka = KIND_ORDER[a.kind];
|
|
43
|
+
const kb = KIND_ORDER[b.kind];
|
|
44
|
+
if (ka !== kb) {
|
|
45
|
+
return ka - kb;
|
|
46
|
+
}
|
|
47
|
+
return 0;
|
|
48
|
+
}
|
|
49
|
+
function compileFieldPredicateBundleToAst(bundle, contradiction) {
|
|
50
|
+
if (contradiction) {
|
|
51
|
+
return (0, builders_1.falseNode)();
|
|
52
|
+
}
|
|
53
|
+
const sorted = [...bundle.predicates].sort(compareAtomsForStableOrder);
|
|
54
|
+
const predicates = sorted.map(atomToFieldPredicate);
|
|
55
|
+
return (0, builders_1.fieldNode)(bundle.fieldPath, predicates);
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=compile-field-bundle.js.map
|