@dxos/echo-query 0.8.4-main.c4373fc → 0.8.4-main.c85a9c8dae
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/dist/lib/{browser → neutral}/index.mjs +257 -68
- package/dist/lib/neutral/index.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/query-lite/index.d.ts +9890 -0
- package/dist/query-lite/index.d.ts.map +1 -0
- package/dist/query-lite/index.js +415 -0
- package/dist/query-lite/index.js.map +1 -0
- package/dist/types/src/index.d.ts +1 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/parser/gen/query.terms.d.ts +1 -1
- package/dist/types/src/parser/gen/query.terms.d.ts.map +1 -1
- package/dist/types/src/parser/query-builder.d.ts +12 -4
- package/dist/types/src/parser/query-builder.d.ts.map +1 -1
- package/dist/types/src/query-lite/index.d.ts +2 -0
- package/dist/types/src/query-lite/index.d.ts.map +1 -0
- package/dist/types/src/query-lite/query-lite.d.ts +8 -0
- package/dist/types/src/query-lite/query-lite.d.ts.map +1 -0
- package/dist/types/src/sandbox/index.d.ts +2 -0
- package/dist/types/src/sandbox/index.d.ts.map +1 -0
- package/dist/types/src/sandbox/quickjs.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +22 -17
- package/src/env.d.ts +1 -1
- package/src/index.ts +1 -0
- package/src/parser/gen/query.terms.ts +24 -23
- package/src/parser/gen/query.ts +8 -8
- package/src/parser/query-builder.ts +65 -12
- package/src/parser/query.grammar +8 -2
- package/src/parser/query.test.ts +75 -22
- package/src/query-lite/index.ts +5 -0
- package/src/{query-env/index.ts → query-lite/query-lite.ts} +145 -59
- package/src/sandbox/index.ts +5 -0
- package/src/sandbox/query-sandbox.test.ts +9 -8
- package/src/sandbox/query-sandbox.ts +3 -3
- package/src/sandbox/quickjs.ts +1 -2
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/node-esm/index.mjs +0 -530
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/query-env/index.js +0 -387
- package/dist/types/src/query-env/index.d.ts +0 -8
- package/dist/types/src/query-env/index.d.ts.map +0 -1
package/dist/query-env/index.js
DELETED
|
@@ -1,387 +0,0 @@
|
|
|
1
|
-
// ../../../common/invariant/dist/lib/browser/index.mjs
|
|
2
|
-
var assertArgument = (condition, argumentName, message) => {
|
|
3
|
-
if (!condition) {
|
|
4
|
-
const error = new TypeError(`Invalid argument \`${argumentName}\`` + (message ? `: ${message}` : ""));
|
|
5
|
-
Error.captureStackTrace(error, assertArgument);
|
|
6
|
-
throw error;
|
|
7
|
-
}
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
// src/query-env/index.ts
|
|
11
|
-
var OrderClass = class _OrderClass {
|
|
12
|
-
constructor(ast) {
|
|
13
|
-
this.ast = ast;
|
|
14
|
-
}
|
|
15
|
-
static variance = {};
|
|
16
|
-
static is(value) {
|
|
17
|
-
return typeof value === "object" && value !== null && "~Order" in value;
|
|
18
|
-
}
|
|
19
|
-
"~Order" = _OrderClass.variance;
|
|
20
|
-
};
|
|
21
|
-
var Order1;
|
|
22
|
-
((Order12) => {
|
|
23
|
-
Order12.natural = new OrderClass({ kind: "natural" });
|
|
24
|
-
Order12.property = (property2, direction) => new OrderClass({
|
|
25
|
-
kind: "property",
|
|
26
|
-
property: property2,
|
|
27
|
-
direction
|
|
28
|
-
});
|
|
29
|
-
})(Order1 || (Order1 = {}));
|
|
30
|
-
var Order2 = Order1;
|
|
31
|
-
var FilterClass = class _FilterClass {
|
|
32
|
-
constructor(ast) {
|
|
33
|
-
this.ast = ast;
|
|
34
|
-
}
|
|
35
|
-
static variance = {};
|
|
36
|
-
static is(value) {
|
|
37
|
-
return typeof value === "object" && value !== null && "~Filter" in value;
|
|
38
|
-
}
|
|
39
|
-
static fromAst(ast) {
|
|
40
|
-
return new _FilterClass(ast);
|
|
41
|
-
}
|
|
42
|
-
static everything() {
|
|
43
|
-
return new _FilterClass({
|
|
44
|
-
type: "object",
|
|
45
|
-
typename: null,
|
|
46
|
-
props: {}
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
static nothing() {
|
|
50
|
-
return new _FilterClass({
|
|
51
|
-
type: "not",
|
|
52
|
-
filter: {
|
|
53
|
-
type: "object",
|
|
54
|
-
typename: null,
|
|
55
|
-
props: {}
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
static relation() {
|
|
60
|
-
return new _FilterClass({
|
|
61
|
-
type: "object",
|
|
62
|
-
typename: null,
|
|
63
|
-
props: {}
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
static ids(...ids) {
|
|
67
|
-
if (ids.length === 0) {
|
|
68
|
-
return _FilterClass.nothing();
|
|
69
|
-
}
|
|
70
|
-
return new _FilterClass({
|
|
71
|
-
type: "object",
|
|
72
|
-
typename: null,
|
|
73
|
-
id: ids,
|
|
74
|
-
props: {}
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
static type(schema, props) {
|
|
78
|
-
if (typeof schema !== "string") {
|
|
79
|
-
throw new TypeError("expected typename as the first paramter");
|
|
80
|
-
}
|
|
81
|
-
return new _FilterClass({
|
|
82
|
-
type: "object",
|
|
83
|
-
typename: makeTypeDxn(schema),
|
|
84
|
-
...propsFilterToAst(props ?? {})
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
static typename(typename) {
|
|
88
|
-
return new _FilterClass({
|
|
89
|
-
type: "object",
|
|
90
|
-
typename: makeTypeDxn(typename),
|
|
91
|
-
props: {}
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
static typeDXN(dxn) {
|
|
95
|
-
return new _FilterClass({
|
|
96
|
-
type: "object",
|
|
97
|
-
typename: dxn.toString(),
|
|
98
|
-
props: {}
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
static tag(tag) {
|
|
102
|
-
return new _FilterClass({
|
|
103
|
-
type: "tag",
|
|
104
|
-
tag
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
static props(props) {
|
|
108
|
-
return new _FilterClass({
|
|
109
|
-
type: "object",
|
|
110
|
-
typename: null,
|
|
111
|
-
...propsFilterToAst(props)
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
static text(text, options) {
|
|
115
|
-
return new _FilterClass({
|
|
116
|
-
type: "text-search",
|
|
117
|
-
text,
|
|
118
|
-
searchKind: options?.type
|
|
119
|
-
});
|
|
120
|
-
}
|
|
121
|
-
static foreignKeys(schema, keys) {
|
|
122
|
-
assertArgument(typeof schema === "string", "schema");
|
|
123
|
-
assertArgument(!schema.startsWith("dxn:"), "schema");
|
|
124
|
-
return new _FilterClass({
|
|
125
|
-
type: "object",
|
|
126
|
-
typename: `dxn:type:${schema}`,
|
|
127
|
-
props: {},
|
|
128
|
-
foreignKeys: keys
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
static eq(value) {
|
|
132
|
-
if (!isRef(value) && typeof value === "object" && value !== null) {
|
|
133
|
-
throw new TypeError("Cannot use object as a value for eq filter");
|
|
134
|
-
}
|
|
135
|
-
return new _FilterClass({
|
|
136
|
-
type: "compare",
|
|
137
|
-
operator: "eq",
|
|
138
|
-
value: isRef(value) ? value.noInline().encode() : value
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
static neq(value) {
|
|
142
|
-
return new _FilterClass({
|
|
143
|
-
type: "compare",
|
|
144
|
-
operator: "neq",
|
|
145
|
-
value
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
static gt(value) {
|
|
149
|
-
return new _FilterClass({
|
|
150
|
-
type: "compare",
|
|
151
|
-
operator: "gt",
|
|
152
|
-
value
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
static gte(value) {
|
|
156
|
-
return new _FilterClass({
|
|
157
|
-
type: "compare",
|
|
158
|
-
operator: "gte",
|
|
159
|
-
value
|
|
160
|
-
});
|
|
161
|
-
}
|
|
162
|
-
static lt(value) {
|
|
163
|
-
return new _FilterClass({
|
|
164
|
-
type: "compare",
|
|
165
|
-
operator: "lt",
|
|
166
|
-
value
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
static lte(value) {
|
|
170
|
-
return new _FilterClass({
|
|
171
|
-
type: "compare",
|
|
172
|
-
operator: "lte",
|
|
173
|
-
value
|
|
174
|
-
});
|
|
175
|
-
}
|
|
176
|
-
static in(...values) {
|
|
177
|
-
return new _FilterClass({
|
|
178
|
-
type: "in",
|
|
179
|
-
values
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
static contains(value) {
|
|
183
|
-
return new _FilterClass({
|
|
184
|
-
type: "contains",
|
|
185
|
-
value
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
static between(from, to) {
|
|
189
|
-
return new _FilterClass({
|
|
190
|
-
type: "range",
|
|
191
|
-
from,
|
|
192
|
-
to
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
static not(filter) {
|
|
196
|
-
return new _FilterClass({
|
|
197
|
-
type: "not",
|
|
198
|
-
filter: filter.ast
|
|
199
|
-
});
|
|
200
|
-
}
|
|
201
|
-
static and(...filters) {
|
|
202
|
-
return new _FilterClass({
|
|
203
|
-
type: "and",
|
|
204
|
-
filters: filters.map((f) => f.ast)
|
|
205
|
-
});
|
|
206
|
-
}
|
|
207
|
-
static or(...filters) {
|
|
208
|
-
return new _FilterClass({
|
|
209
|
-
type: "or",
|
|
210
|
-
filters: filters.map((f) => f.ast)
|
|
211
|
-
});
|
|
212
|
-
}
|
|
213
|
-
"~Filter" = _FilterClass.variance;
|
|
214
|
-
};
|
|
215
|
-
var Filter1 = FilterClass;
|
|
216
|
-
var propsFilterToAst = (predicates) => {
|
|
217
|
-
let idFilter;
|
|
218
|
-
if ("id" in predicates) {
|
|
219
|
-
assertArgument(
|
|
220
|
-
typeof predicates.id === "string" || Array.isArray(predicates.id),
|
|
221
|
-
"predicates.id",
|
|
222
|
-
"invalid id filter"
|
|
223
|
-
);
|
|
224
|
-
idFilter = typeof predicates.id === "string" ? [predicates.id] : predicates.id;
|
|
225
|
-
}
|
|
226
|
-
return {
|
|
227
|
-
id: idFilter,
|
|
228
|
-
props: Object.fromEntries(
|
|
229
|
-
Object.entries(predicates).filter(([prop, _value]) => prop !== "id").map(([prop, predicate]) => [prop, processPredicate(predicate)])
|
|
230
|
-
)
|
|
231
|
-
};
|
|
232
|
-
};
|
|
233
|
-
var processPredicate = (predicate) => {
|
|
234
|
-
if (FilterClass.is(predicate)) {
|
|
235
|
-
return predicate.ast;
|
|
236
|
-
}
|
|
237
|
-
if (Array.isArray(predicate)) {
|
|
238
|
-
throw new Error("Array predicates are not yet supported.");
|
|
239
|
-
}
|
|
240
|
-
if (!isRef(predicate) && typeof predicate === "object" && predicate !== null) {
|
|
241
|
-
const nestedProps = Object.fromEntries(
|
|
242
|
-
Object.entries(predicate).map(([key, value]) => [key, processPredicate(value)])
|
|
243
|
-
);
|
|
244
|
-
return {
|
|
245
|
-
type: "object",
|
|
246
|
-
typename: null,
|
|
247
|
-
props: nestedProps
|
|
248
|
-
};
|
|
249
|
-
}
|
|
250
|
-
return FilterClass.eq(predicate).ast;
|
|
251
|
-
};
|
|
252
|
-
var QueryClass = class _QueryClass {
|
|
253
|
-
constructor(ast) {
|
|
254
|
-
this.ast = ast;
|
|
255
|
-
}
|
|
256
|
-
static variance = {};
|
|
257
|
-
static is(value) {
|
|
258
|
-
return typeof value === "object" && value !== null && "~Query" in value;
|
|
259
|
-
}
|
|
260
|
-
static fromAst(ast) {
|
|
261
|
-
return new _QueryClass(ast);
|
|
262
|
-
}
|
|
263
|
-
static select(filter) {
|
|
264
|
-
return new _QueryClass({
|
|
265
|
-
type: "select",
|
|
266
|
-
filter: filter.ast
|
|
267
|
-
});
|
|
268
|
-
}
|
|
269
|
-
static type(schema, predicates) {
|
|
270
|
-
return new _QueryClass({
|
|
271
|
-
type: "select",
|
|
272
|
-
filter: FilterClass.type(schema, predicates).ast
|
|
273
|
-
});
|
|
274
|
-
}
|
|
275
|
-
static all(...queries) {
|
|
276
|
-
if (queries.length === 0) {
|
|
277
|
-
throw new TypeError(
|
|
278
|
-
"Query.all combines results of multiple queries, to query all objects use Query.select(Filter.everything())"
|
|
279
|
-
);
|
|
280
|
-
}
|
|
281
|
-
return new _QueryClass({
|
|
282
|
-
type: "union",
|
|
283
|
-
queries: queries.map((q) => q.ast)
|
|
284
|
-
});
|
|
285
|
-
}
|
|
286
|
-
static without(source, exclude) {
|
|
287
|
-
return new _QueryClass({
|
|
288
|
-
type: "set-difference",
|
|
289
|
-
source: source.ast,
|
|
290
|
-
exclude: exclude.ast
|
|
291
|
-
});
|
|
292
|
-
}
|
|
293
|
-
"~Query" = _QueryClass.variance;
|
|
294
|
-
select(filter) {
|
|
295
|
-
if (FilterClass.is(filter)) {
|
|
296
|
-
return new _QueryClass({
|
|
297
|
-
type: "filter",
|
|
298
|
-
selection: this.ast,
|
|
299
|
-
filter: filter.ast
|
|
300
|
-
});
|
|
301
|
-
} else {
|
|
302
|
-
return new _QueryClass({
|
|
303
|
-
type: "filter",
|
|
304
|
-
selection: this.ast,
|
|
305
|
-
filter: FilterClass.props(filter).ast
|
|
306
|
-
});
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
reference(key) {
|
|
310
|
-
return new _QueryClass({
|
|
311
|
-
type: "reference-traversal",
|
|
312
|
-
anchor: this.ast,
|
|
313
|
-
property: key
|
|
314
|
-
});
|
|
315
|
-
}
|
|
316
|
-
referencedBy(target, key) {
|
|
317
|
-
assertArgument(typeof target === "string", "target");
|
|
318
|
-
assertArgument(!target.startsWith("dxn:"), "target");
|
|
319
|
-
return new _QueryClass({
|
|
320
|
-
type: "incoming-references",
|
|
321
|
-
anchor: this.ast,
|
|
322
|
-
property: key,
|
|
323
|
-
typename: target
|
|
324
|
-
});
|
|
325
|
-
}
|
|
326
|
-
sourceOf(relation, predicates) {
|
|
327
|
-
return new _QueryClass({
|
|
328
|
-
type: "relation",
|
|
329
|
-
anchor: this.ast,
|
|
330
|
-
direction: "outgoing",
|
|
331
|
-
filter: FilterClass.type(relation, predicates).ast
|
|
332
|
-
});
|
|
333
|
-
}
|
|
334
|
-
targetOf(relation, predicates) {
|
|
335
|
-
return new _QueryClass({
|
|
336
|
-
type: "relation",
|
|
337
|
-
anchor: this.ast,
|
|
338
|
-
direction: "incoming",
|
|
339
|
-
filter: FilterClass.type(relation, predicates).ast
|
|
340
|
-
});
|
|
341
|
-
}
|
|
342
|
-
source() {
|
|
343
|
-
return new _QueryClass({
|
|
344
|
-
type: "relation-traversal",
|
|
345
|
-
anchor: this.ast,
|
|
346
|
-
direction: "source"
|
|
347
|
-
});
|
|
348
|
-
}
|
|
349
|
-
target() {
|
|
350
|
-
return new _QueryClass({
|
|
351
|
-
type: "relation-traversal",
|
|
352
|
-
anchor: this.ast,
|
|
353
|
-
direction: "target"
|
|
354
|
-
});
|
|
355
|
-
}
|
|
356
|
-
orderBy(...order) {
|
|
357
|
-
return new _QueryClass({
|
|
358
|
-
type: "order",
|
|
359
|
-
query: this.ast,
|
|
360
|
-
order: order.map((o) => o.ast)
|
|
361
|
-
});
|
|
362
|
-
}
|
|
363
|
-
options(options) {
|
|
364
|
-
return new _QueryClass({
|
|
365
|
-
type: "options",
|
|
366
|
-
query: this.ast,
|
|
367
|
-
options
|
|
368
|
-
});
|
|
369
|
-
}
|
|
370
|
-
};
|
|
371
|
-
var Query1 = QueryClass;
|
|
372
|
-
var RefTypeId = Symbol("@dxos/echo-query/Ref");
|
|
373
|
-
var isRef = (obj) => {
|
|
374
|
-
return obj && typeof obj === "object" && RefTypeId in obj;
|
|
375
|
-
};
|
|
376
|
-
var makeTypeDxn = (typename) => {
|
|
377
|
-
assertArgument(typeof typename === "string", "typename");
|
|
378
|
-
assertArgument(!typename.startsWith("dxn:"), "typename");
|
|
379
|
-
return `dxn:type:${typename}`;
|
|
380
|
-
};
|
|
381
|
-
export {
|
|
382
|
-
Filter1 as Filter,
|
|
383
|
-
Filter1,
|
|
384
|
-
Order2 as Order,
|
|
385
|
-
Query1 as Query,
|
|
386
|
-
Query1
|
|
387
|
-
};
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import type * as Echo from '@dxos/echo';
|
|
2
|
-
declare const Order2: typeof Echo.Order;
|
|
3
|
-
export { Order2 as Order };
|
|
4
|
-
export declare const Filter1: typeof Echo.Filter;
|
|
5
|
-
export { Filter1 as Filter };
|
|
6
|
-
export declare const Query1: typeof Echo.Query;
|
|
7
|
-
export { Query1 as Query };
|
|
8
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/query-env/index.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,KAAK,IAAI,MAAM,YAAY,CAAC;AA0BxC,QAAA,MAAM,MAAM,EAAE,OAAO,IAAI,CAAC,KAAc,CAAC;AACzC,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,CAAC;AAkO3B,eAAO,MAAM,OAAO,EAAE,OAAO,IAAI,CAAC,MAAoB,CAAC;AACvD,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,CAAC;AA4L7B,eAAO,MAAM,MAAM,EAAE,OAAO,IAAI,CAAC,KAAkB,CAAC;AACpD,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,CAAC"}
|