@cogitator-ai/neuro-symbolic 0.1.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.
Files changed (107) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +494 -0
  3. package/dist/constraints/dsl.d.ts +68 -0
  4. package/dist/constraints/dsl.d.ts.map +1 -0
  5. package/dist/constraints/dsl.js +419 -0
  6. package/dist/constraints/dsl.js.map +1 -0
  7. package/dist/constraints/index.d.ts +7 -0
  8. package/dist/constraints/index.d.ts.map +1 -0
  9. package/dist/constraints/index.js +18 -0
  10. package/dist/constraints/index.js.map +1 -0
  11. package/dist/constraints/prompts.d.ts +44 -0
  12. package/dist/constraints/prompts.d.ts.map +1 -0
  13. package/dist/constraints/prompts.js +175 -0
  14. package/dist/constraints/prompts.js.map +1 -0
  15. package/dist/constraints/simple-sat-solver.d.ts +21 -0
  16. package/dist/constraints/simple-sat-solver.d.ts.map +1 -0
  17. package/dist/constraints/simple-sat-solver.js +378 -0
  18. package/dist/constraints/simple-sat-solver.js.map +1 -0
  19. package/dist/constraints/z3-wasm-solver.d.ts +20 -0
  20. package/dist/constraints/z3-wasm-solver.d.ts.map +1 -0
  21. package/dist/constraints/z3-wasm-solver.js +286 -0
  22. package/dist/constraints/z3-wasm-solver.js.map +1 -0
  23. package/dist/index.d.ts +6 -0
  24. package/dist/index.d.ts.map +1 -0
  25. package/dist/index.js +6 -0
  26. package/dist/index.js.map +1 -0
  27. package/dist/knowledge-graph/index.d.ts +5 -0
  28. package/dist/knowledge-graph/index.d.ts.map +1 -0
  29. package/dist/knowledge-graph/index.js +5 -0
  30. package/dist/knowledge-graph/index.js.map +1 -0
  31. package/dist/knowledge-graph/natural-language-query.d.ts +42 -0
  32. package/dist/knowledge-graph/natural-language-query.d.ts.map +1 -0
  33. package/dist/knowledge-graph/natural-language-query.js +271 -0
  34. package/dist/knowledge-graph/natural-language-query.js.map +1 -0
  35. package/dist/knowledge-graph/prompts.d.ts +56 -0
  36. package/dist/knowledge-graph/prompts.d.ts.map +1 -0
  37. package/dist/knowledge-graph/prompts.js +198 -0
  38. package/dist/knowledge-graph/prompts.js.map +1 -0
  39. package/dist/knowledge-graph/query-language.d.ts +43 -0
  40. package/dist/knowledge-graph/query-language.d.ts.map +1 -0
  41. package/dist/knowledge-graph/query-language.js +569 -0
  42. package/dist/knowledge-graph/query-language.js.map +1 -0
  43. package/dist/knowledge-graph/reasoning-engine.d.ts +53 -0
  44. package/dist/knowledge-graph/reasoning-engine.d.ts.map +1 -0
  45. package/dist/knowledge-graph/reasoning-engine.js +337 -0
  46. package/dist/knowledge-graph/reasoning-engine.js.map +1 -0
  47. package/dist/logic/builtins.d.ts +10 -0
  48. package/dist/logic/builtins.d.ts.map +1 -0
  49. package/dist/logic/builtins.js +527 -0
  50. package/dist/logic/builtins.js.map +1 -0
  51. package/dist/logic/index.d.ts +8 -0
  52. package/dist/logic/index.d.ts.map +1 -0
  53. package/dist/logic/index.js +8 -0
  54. package/dist/logic/index.js.map +1 -0
  55. package/dist/logic/knowledge-base.d.ts +38 -0
  56. package/dist/logic/knowledge-base.d.ts.map +1 -0
  57. package/dist/logic/knowledge-base.js +205 -0
  58. package/dist/logic/knowledge-base.js.map +1 -0
  59. package/dist/logic/parser.d.ts +19 -0
  60. package/dist/logic/parser.d.ts.map +1 -0
  61. package/dist/logic/parser.js +466 -0
  62. package/dist/logic/parser.js.map +1 -0
  63. package/dist/logic/prompts.d.ts +55 -0
  64. package/dist/logic/prompts.d.ts.map +1 -0
  65. package/dist/logic/prompts.js +230 -0
  66. package/dist/logic/prompts.js.map +1 -0
  67. package/dist/logic/proof-tree.d.ts +30 -0
  68. package/dist/logic/proof-tree.d.ts.map +1 -0
  69. package/dist/logic/proof-tree.js +281 -0
  70. package/dist/logic/proof-tree.js.map +1 -0
  71. package/dist/logic/resolver.d.ts +16 -0
  72. package/dist/logic/resolver.d.ts.map +1 -0
  73. package/dist/logic/resolver.js +382 -0
  74. package/dist/logic/resolver.js.map +1 -0
  75. package/dist/logic/unification.d.ts +17 -0
  76. package/dist/logic/unification.d.ts.map +1 -0
  77. package/dist/logic/unification.js +257 -0
  78. package/dist/logic/unification.js.map +1 -0
  79. package/dist/orchestrator.d.ts +57 -0
  80. package/dist/orchestrator.d.ts.map +1 -0
  81. package/dist/orchestrator.js +293 -0
  82. package/dist/orchestrator.js.map +1 -0
  83. package/dist/planning/action-schema.d.ts +48 -0
  84. package/dist/planning/action-schema.d.ts.map +1 -0
  85. package/dist/planning/action-schema.js +358 -0
  86. package/dist/planning/action-schema.js.map +1 -0
  87. package/dist/planning/index.d.ts +6 -0
  88. package/dist/planning/index.d.ts.map +1 -0
  89. package/dist/planning/index.js +6 -0
  90. package/dist/planning/index.js.map +1 -0
  91. package/dist/planning/invariant-checker.d.ts +39 -0
  92. package/dist/planning/invariant-checker.d.ts.map +1 -0
  93. package/dist/planning/invariant-checker.js +293 -0
  94. package/dist/planning/invariant-checker.js.map +1 -0
  95. package/dist/planning/plan-repair.d.ts +38 -0
  96. package/dist/planning/plan-repair.d.ts.map +1 -0
  97. package/dist/planning/plan-repair.js +366 -0
  98. package/dist/planning/plan-repair.js.map +1 -0
  99. package/dist/planning/plan-validator.d.ts +31 -0
  100. package/dist/planning/plan-validator.d.ts.map +1 -0
  101. package/dist/planning/plan-validator.js +379 -0
  102. package/dist/planning/plan-validator.js.map +1 -0
  103. package/dist/planning/prompts.d.ts +50 -0
  104. package/dist/planning/prompts.d.ts.map +1 -0
  105. package/dist/planning/prompts.js +186 -0
  106. package/dist/planning/prompts.js.map +1 -0
  107. package/package.json +96 -0
@@ -0,0 +1,337 @@
1
+ const DEFAULT_REASONING_CONFIG = {
2
+ maxHops: 3,
3
+ minConfidence: 0.5,
4
+ maxInferences: 100,
5
+ enableTransitivity: true,
6
+ enableInverse: true,
7
+ enableComposition: true,
8
+ };
9
+ const INVERSE_RELATIONS = {
10
+ works_at: 'custom',
11
+ part_of: 'custom',
12
+ belongs_to: 'custom',
13
+ created_by: 'custom',
14
+ knows: 'knows',
15
+ related_to: 'related_to',
16
+ associated_with: 'associated_with',
17
+ };
18
+ const TRANSITIVE_RELATIONS = [
19
+ 'part_of',
20
+ 'located_in',
21
+ 'related_to',
22
+ 'associated_with',
23
+ ];
24
+ export async function findPath(ctx, startNodeId, endNodeId) {
25
+ const result = {
26
+ paths: [],
27
+ inferences: [],
28
+ confidence: 0,
29
+ steps: [],
30
+ };
31
+ const pathResult = await ctx.adapter.findShortestPath(ctx.agentId, startNodeId, endNodeId, ctx.config.maxHops);
32
+ if (pathResult.success && pathResult.data) {
33
+ result.paths.push(pathResult.data);
34
+ result.confidence = calculatePathConfidence(pathResult.data);
35
+ for (let i = 0; i < pathResult.data.edges.length; i++) {
36
+ const edge = pathResult.data.edges[i];
37
+ const fromNode = pathResult.data.nodes[i];
38
+ const toNode = pathResult.data.nodes[i + 1];
39
+ result.steps.push({
40
+ type: 'traverse',
41
+ description: `${fromNode.name} --[${edge.label || edge.type}]--> ${toNode.name}`,
42
+ fromNode: fromNode.id,
43
+ toNode: toNode.id,
44
+ relation: edge.type,
45
+ confidence: edge.confidence,
46
+ });
47
+ }
48
+ }
49
+ return result;
50
+ }
51
+ function calculatePathConfidence(path) {
52
+ if (path.edges.length === 0)
53
+ return 1.0;
54
+ let confidence = 1.0;
55
+ for (const edge of path.edges) {
56
+ confidence *= edge.confidence * edge.weight;
57
+ }
58
+ return confidence;
59
+ }
60
+ export async function multiHopQuery(ctx, startNodeId, relationPath) {
61
+ const result = {
62
+ paths: [],
63
+ inferences: [],
64
+ confidence: 0,
65
+ steps: [],
66
+ };
67
+ let currentNodes = [];
68
+ const startResult = await ctx.adapter.getNode(startNodeId);
69
+ if (!startResult.success || !startResult.data) {
70
+ return result;
71
+ }
72
+ currentNodes.push(startResult.data);
73
+ const paths = [
74
+ {
75
+ nodes: [startResult.data],
76
+ edges: [],
77
+ totalWeight: 1,
78
+ length: 0,
79
+ },
80
+ ];
81
+ for (const relationType of relationPath) {
82
+ const nextNodes = [];
83
+ const nextPaths = [];
84
+ for (let i = 0; i < currentNodes.length; i++) {
85
+ const node = currentNodes[i];
86
+ const path = paths[i];
87
+ const edgesResult = await ctx.adapter.queryEdges({
88
+ agentId: ctx.agentId,
89
+ sourceNodeId: node.id,
90
+ types: [relationType],
91
+ });
92
+ if (!edgesResult.success || !edgesResult.data)
93
+ continue;
94
+ for (const edge of edgesResult.data) {
95
+ const targetResult = await ctx.adapter.getNode(edge.targetNodeId);
96
+ if (!targetResult.success || !targetResult.data)
97
+ continue;
98
+ const targetNode = targetResult.data;
99
+ nextNodes.push(targetNode);
100
+ nextPaths.push({
101
+ nodes: [...path.nodes, targetNode],
102
+ edges: [...path.edges, edge],
103
+ totalWeight: path.totalWeight * edge.weight,
104
+ length: path.length + 1,
105
+ });
106
+ result.steps.push({
107
+ type: 'traverse',
108
+ description: `${node.name} --[${relationType}]--> ${targetNode.name}`,
109
+ fromNode: node.id,
110
+ toNode: targetNode.id,
111
+ relation: relationType,
112
+ confidence: edge.confidence,
113
+ });
114
+ }
115
+ }
116
+ currentNodes = nextNodes;
117
+ paths.length = 0;
118
+ paths.push(...nextPaths);
119
+ }
120
+ result.paths = paths;
121
+ if (paths.length > 0) {
122
+ result.confidence = Math.max(...paths.map(calculatePathConfidence));
123
+ }
124
+ return result;
125
+ }
126
+ export async function inferTransitiveRelations(ctx) {
127
+ const inferred = [];
128
+ if (!ctx.config.enableTransitivity) {
129
+ return inferred;
130
+ }
131
+ for (const relationType of TRANSITIVE_RELATIONS) {
132
+ const edgesResult = await ctx.adapter.queryEdges({
133
+ agentId: ctx.agentId,
134
+ types: [relationType],
135
+ });
136
+ if (!edgesResult.success || !edgesResult.data)
137
+ continue;
138
+ const edges = edgesResult.data;
139
+ const edgesBySource = new Map();
140
+ for (const edge of edges) {
141
+ if (!edgesBySource.has(edge.sourceNodeId)) {
142
+ edgesBySource.set(edge.sourceNodeId, []);
143
+ }
144
+ edgesBySource.get(edge.sourceNodeId).push(edge);
145
+ }
146
+ for (const edge of edges) {
147
+ const transitiveEdges = edgesBySource.get(edge.targetNodeId) || [];
148
+ for (const transEdge of transitiveEdges) {
149
+ if (transEdge.targetNodeId === edge.sourceNodeId)
150
+ continue;
151
+ const existingResult = await ctx.adapter.getEdgesBetween(edge.sourceNodeId, transEdge.targetNodeId);
152
+ if (existingResult.success && existingResult.data && existingResult.data.length > 0) {
153
+ const hasType = existingResult.data.some((e) => e.type === relationType);
154
+ if (hasType)
155
+ continue;
156
+ }
157
+ const confidence = Math.min(edge.confidence, transEdge.confidence) * 0.9;
158
+ if (confidence < ctx.config.minConfidence)
159
+ continue;
160
+ inferred.push({
161
+ agentId: ctx.agentId,
162
+ sourceNodeId: edge.sourceNodeId,
163
+ targetNodeId: transEdge.targetNodeId,
164
+ type: relationType,
165
+ label: `Inferred: ${relationType} (transitive)`,
166
+ weight: Math.min(edge.weight, transEdge.weight),
167
+ bidirectional: false,
168
+ properties: {},
169
+ confidence,
170
+ source: 'inferred',
171
+ ruleId: 'transitive',
172
+ supportingPath: [edge.id, transEdge.id],
173
+ });
174
+ if (inferred.length >= ctx.config.maxInferences) {
175
+ return inferred;
176
+ }
177
+ }
178
+ }
179
+ }
180
+ return inferred;
181
+ }
182
+ export async function inferInverseRelations(ctx) {
183
+ const inferred = [];
184
+ if (!ctx.config.enableInverse) {
185
+ return inferred;
186
+ }
187
+ for (const [sourceRel, targetRel] of Object.entries(INVERSE_RELATIONS)) {
188
+ const edgesResult = await ctx.adapter.queryEdges({
189
+ agentId: ctx.agentId,
190
+ types: [sourceRel],
191
+ });
192
+ if (!edgesResult.success || !edgesResult.data)
193
+ continue;
194
+ for (const edge of edgesResult.data) {
195
+ if (edge.bidirectional)
196
+ continue;
197
+ const existingResult = await ctx.adapter.getEdgesBetween(edge.targetNodeId, edge.sourceNodeId);
198
+ if (existingResult.success && existingResult.data && existingResult.data.length > 0) {
199
+ continue;
200
+ }
201
+ const confidence = edge.confidence * 0.95;
202
+ if (confidence < ctx.config.minConfidence)
203
+ continue;
204
+ inferred.push({
205
+ agentId: ctx.agentId,
206
+ sourceNodeId: edge.targetNodeId,
207
+ targetNodeId: edge.sourceNodeId,
208
+ type: targetRel,
209
+ label: `Inferred: inverse of ${sourceRel}`,
210
+ weight: edge.weight,
211
+ bidirectional: false,
212
+ properties: {},
213
+ confidence,
214
+ source: 'inferred',
215
+ ruleId: 'inverse',
216
+ supportingPath: [edge.id],
217
+ });
218
+ if (inferred.length >= ctx.config.maxInferences) {
219
+ return inferred;
220
+ }
221
+ }
222
+ }
223
+ return inferred;
224
+ }
225
+ const COMPOSITION_RULES = [
226
+ { first: 'works_at', second: 'located_in', result: 'located_in', confidenceMultiplier: 0.8 },
227
+ { first: 'part_of', second: 'part_of', result: 'part_of', confidenceMultiplier: 0.9 },
228
+ { first: 'belongs_to', second: 'part_of', result: 'belongs_to', confidenceMultiplier: 0.85 },
229
+ { first: 'knows', second: 'knows', result: 'related_to', confidenceMultiplier: 0.5 },
230
+ ];
231
+ export async function inferComposedRelations(ctx) {
232
+ const inferred = [];
233
+ if (!ctx.config.enableComposition) {
234
+ return inferred;
235
+ }
236
+ for (const rule of COMPOSITION_RULES) {
237
+ const firstEdgesResult = await ctx.adapter.queryEdges({
238
+ agentId: ctx.agentId,
239
+ types: [rule.first],
240
+ });
241
+ if (!firstEdgesResult.success || !firstEdgesResult.data)
242
+ continue;
243
+ for (const firstEdge of firstEdgesResult.data) {
244
+ const secondEdgesResult = await ctx.adapter.queryEdges({
245
+ agentId: ctx.agentId,
246
+ sourceNodeId: firstEdge.targetNodeId,
247
+ types: [rule.second],
248
+ });
249
+ if (!secondEdgesResult.success || !secondEdgesResult.data)
250
+ continue;
251
+ for (const secondEdge of secondEdgesResult.data) {
252
+ if (secondEdge.targetNodeId === firstEdge.sourceNodeId)
253
+ continue;
254
+ const existingResult = await ctx.adapter.getEdgesBetween(firstEdge.sourceNodeId, secondEdge.targetNodeId);
255
+ if (existingResult.success && existingResult.data && existingResult.data.length > 0) {
256
+ const hasType = existingResult.data.some((e) => e.type === rule.result);
257
+ if (hasType)
258
+ continue;
259
+ }
260
+ const confidence = Math.min(firstEdge.confidence, secondEdge.confidence) * rule.confidenceMultiplier;
261
+ if (confidence < ctx.config.minConfidence)
262
+ continue;
263
+ inferred.push({
264
+ agentId: ctx.agentId,
265
+ sourceNodeId: firstEdge.sourceNodeId,
266
+ targetNodeId: secondEdge.targetNodeId,
267
+ type: rule.result,
268
+ label: `Inferred: ${rule.first} + ${rule.second} = ${rule.result}`,
269
+ weight: Math.min(firstEdge.weight, secondEdge.weight),
270
+ bidirectional: false,
271
+ properties: {
272
+ compositionRule: `${rule.first} + ${rule.second}`,
273
+ },
274
+ confidence,
275
+ source: 'inferred',
276
+ ruleId: 'composition',
277
+ supportingPath: [firstEdge.id, secondEdge.id],
278
+ });
279
+ if (inferred.length >= ctx.config.maxInferences) {
280
+ return inferred;
281
+ }
282
+ }
283
+ }
284
+ }
285
+ return inferred;
286
+ }
287
+ export async function runFullInference(ctx) {
288
+ const allInferred = [];
289
+ const transitive = await inferTransitiveRelations(ctx);
290
+ allInferred.push(...transitive);
291
+ if (allInferred.length >= ctx.config.maxInferences) {
292
+ return allInferred.slice(0, ctx.config.maxInferences);
293
+ }
294
+ const inverse = await inferInverseRelations(ctx);
295
+ allInferred.push(...inverse);
296
+ if (allInferred.length >= ctx.config.maxInferences) {
297
+ return allInferred.slice(0, ctx.config.maxInferences);
298
+ }
299
+ const composed = await inferComposedRelations(ctx);
300
+ allInferred.push(...composed);
301
+ return allInferred.slice(0, ctx.config.maxInferences);
302
+ }
303
+ export class ReasoningEngine {
304
+ ctx;
305
+ constructor(adapter, agentId, config = {}) {
306
+ this.ctx = {
307
+ adapter,
308
+ agentId,
309
+ config: { ...DEFAULT_REASONING_CONFIG, ...config },
310
+ };
311
+ }
312
+ async findPath(startNodeId, endNodeId) {
313
+ return findPath(this.ctx, startNodeId, endNodeId);
314
+ }
315
+ async multiHopQuery(startNodeId, relationPath) {
316
+ return multiHopQuery(this.ctx, startNodeId, relationPath);
317
+ }
318
+ async infer() {
319
+ return runFullInference(this.ctx);
320
+ }
321
+ async inferTransitive() {
322
+ return inferTransitiveRelations(this.ctx);
323
+ }
324
+ async inferInverse() {
325
+ return inferInverseRelations(this.ctx);
326
+ }
327
+ async inferComposed() {
328
+ return inferComposedRelations(this.ctx);
329
+ }
330
+ updateConfig(config) {
331
+ this.ctx.config = { ...this.ctx.config, ...config };
332
+ }
333
+ }
334
+ export function createReasoningEngine(adapter, agentId, config) {
335
+ return new ReasoningEngine(adapter, agentId, config);
336
+ }
337
+ //# sourceMappingURL=reasoning-engine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reasoning-engine.js","sourceRoot":"","sources":["../../src/knowledge-graph/reasoning-engine.ts"],"names":[],"mappings":"AAkBA,MAAM,wBAAwB,GAAoB;IAChD,OAAO,EAAE,CAAC;IACV,aAAa,EAAE,GAAG;IAClB,aAAa,EAAE,GAAG;IAClB,kBAAkB,EAAE,IAAI;IACxB,aAAa,EAAE,IAAI;IACnB,iBAAiB,EAAE,IAAI;CACxB,CAAC;AAwBF,MAAM,iBAAiB,GAAiC;IACtD,QAAQ,EAAE,QAAQ;IAClB,OAAO,EAAE,QAAQ;IACjB,UAAU,EAAE,QAAQ;IACpB,UAAU,EAAE,QAAQ;IACpB,KAAK,EAAE,OAAO;IACd,UAAU,EAAE,YAAY;IACxB,eAAe,EAAE,iBAAiB;CACnC,CAAC;AAEF,MAAM,oBAAoB,GAAmB;IAC3C,SAAS;IACT,YAAY;IACZ,YAAY;IACZ,iBAAiB;CAClB,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,GAAqB,EACrB,WAAmB,EACnB,SAAiB;IAEjB,MAAM,MAAM,GAAoB;QAC9B,KAAK,EAAE,EAAE;QACT,UAAU,EAAE,EAAE;QACd,UAAU,EAAE,CAAC;QACb,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,gBAAgB,CACnD,GAAG,CAAC,OAAO,EACX,WAAW,EACX,SAAS,EACT,GAAG,CAAC,MAAM,CAAC,OAAO,CACnB,CAAC;IAEF,IAAI,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,IAAI,EAAE,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACnC,MAAM,CAAC,UAAU,GAAG,uBAAuB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAE7D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtD,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACtC,MAAM,QAAQ,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC1C,MAAM,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAE5C,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC;gBAChB,IAAI,EAAE,UAAU;gBAChB,WAAW,EAAE,GAAG,QAAQ,CAAC,IAAI,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,QAAQ,MAAM,CAAC,IAAI,EAAE;gBAChF,QAAQ,EAAE,QAAQ,CAAC,EAAE;gBACrB,MAAM,EAAE,MAAM,CAAC,EAAE;gBACjB,QAAQ,EAAE,IAAI,CAAC,IAAI;gBACnB,UAAU,EAAE,IAAI,CAAC,UAAU;aAC5B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,uBAAuB,CAAC,IAAe;IAC9C,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,GAAG,CAAC;IAExC,IAAI,UAAU,GAAG,GAAG,CAAC;IACrB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QAC9B,UAAU,IAAI,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;IAC9C,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,GAAqB,EACrB,WAAmB,EACnB,YAA4B;IAE5B,MAAM,MAAM,GAAoB;QAC9B,KAAK,EAAE,EAAE;QACT,UAAU,EAAE,EAAE;QACd,UAAU,EAAE,CAAC;QACb,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,IAAI,YAAY,GAAgB,EAAE,CAAC;IAEnC,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAC3D,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;QAC9C,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACpC,MAAM,KAAK,GAAgB;QACzB;YACE,KAAK,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC;YACzB,KAAK,EAAE,EAAE;YACT,WAAW,EAAE,CAAC;YACd,MAAM,EAAE,CAAC;SACV;KACF,CAAC;IAEF,KAAK,MAAM,YAAY,IAAI,YAAY,EAAE,CAAC;QACxC,MAAM,SAAS,GAAgB,EAAE,CAAC;QAClC,MAAM,SAAS,GAAgB,EAAE,CAAC;QAElC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC7C,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAEtB,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;gBAC/C,OAAO,EAAE,GAAG,CAAC,OAAO;gBACpB,YAAY,EAAE,IAAI,CAAC,EAAE;gBACrB,KAAK,EAAE,CAAC,YAAY,CAAC;aACtB,CAAC,CAAC;YAEH,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI;gBAAE,SAAS;YAExD,KAAK,MAAM,IAAI,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;gBACpC,MAAM,YAAY,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAClE,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI;oBAAE,SAAS;gBAE1D,MAAM,UAAU,GAAG,YAAY,CAAC,IAAI,CAAC;gBACrC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAE3B,SAAS,CAAC,IAAI,CAAC;oBACb,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC;oBAClC,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC;oBAC5B,WAAW,EAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM;oBAC3C,MAAM,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC;iBACxB,CAAC,CAAC;gBAEH,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,UAAU;oBAChB,WAAW,EAAE,GAAG,IAAI,CAAC,IAAI,OAAO,YAAY,QAAQ,UAAU,CAAC,IAAI,EAAE;oBACrE,QAAQ,EAAE,IAAI,CAAC,EAAE;oBACjB,MAAM,EAAE,UAAU,CAAC,EAAE;oBACrB,QAAQ,EAAE,YAAY;oBACtB,UAAU,EAAE,IAAI,CAAC,UAAU;iBAC5B,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,YAAY,GAAG,SAAS,CAAC;QACzB,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACjB,KAAK,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;IAErB,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrB,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAC,CAAC;IACtE,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,wBAAwB,CAAC,GAAqB;IAClE,MAAM,QAAQ,GAAmB,EAAE,CAAC;IAEpC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC;QACnC,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,KAAK,MAAM,YAAY,IAAI,oBAAoB,EAAE,CAAC;QAChD,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;YAC/C,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,KAAK,EAAE,CAAC,YAAY,CAAC;SACtB,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI;YAAE,SAAS;QAExD,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC;QAC/B,MAAM,aAAa,GAAG,IAAI,GAAG,EAAuB,CAAC;QAErD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC;gBAC1C,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;YAC3C,CAAC;YACD,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,CAAC;QAED,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,eAAe,GAAG,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;YAEnE,KAAK,MAAM,SAAS,IAAI,eAAe,EAAE,CAAC;gBACxC,IAAI,SAAS,CAAC,YAAY,KAAK,IAAI,CAAC,YAAY;oBAAE,SAAS;gBAE3D,MAAM,cAAc,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,eAAe,CACtD,IAAI,CAAC,YAAY,EACjB,SAAS,CAAC,YAAY,CACvB,CAAC;gBAEF,IAAI,cAAc,CAAC,OAAO,IAAI,cAAc,CAAC,IAAI,IAAI,cAAc,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACpF,MAAM,OAAO,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;oBACzE,IAAI,OAAO;wBAAE,SAAS;gBACxB,CAAC;gBAED,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,SAAS,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC;gBAEzE,IAAI,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,aAAa;oBAAE,SAAS;gBAEpD,QAAQ,CAAC,IAAI,CAAC;oBACZ,OAAO,EAAE,GAAG,CAAC,OAAO;oBACpB,YAAY,EAAE,IAAI,CAAC,YAAY;oBAC/B,YAAY,EAAE,SAAS,CAAC,YAAY;oBACpC,IAAI,EAAE,YAAY;oBAClB,KAAK,EAAE,aAAa,YAAY,eAAe;oBAC/C,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC;oBAC/C,aAAa,EAAE,KAAK;oBACpB,UAAU,EAAE,EAAE;oBACd,UAAU;oBACV,MAAM,EAAE,UAAU;oBAClB,MAAM,EAAE,YAAY;oBACpB,cAAc,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC,EAAE,CAAC;iBACxC,CAAC,CAAC;gBAEH,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;oBAChD,OAAO,QAAQ,CAAC;gBAClB,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,GAAqB;IAC/D,MAAM,QAAQ,GAAmB,EAAE,CAAC;IAEpC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;QAC9B,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,KAAK,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE,CAAC;QACvE,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;YAC/C,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,KAAK,EAAE,CAAC,SAAyB,CAAC;SACnC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI;YAAE,SAAS;QAExD,KAAK,MAAM,IAAI,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;YACpC,IAAI,IAAI,CAAC,aAAa;gBAAE,SAAS;YAEjC,MAAM,cAAc,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,eAAe,CACtD,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,YAAY,CAClB,CAAC;YAEF,IAAI,cAAc,CAAC,OAAO,IAAI,cAAc,CAAC,IAAI,IAAI,cAAc,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACpF,SAAS;YACX,CAAC;YAED,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YAE1C,IAAI,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,aAAa;gBAAE,SAAS;YAEpD,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,GAAG,CAAC,OAAO;gBACpB,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,wBAAwB,SAAS,EAAE;gBAC1C,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,aAAa,EAAE,KAAK;gBACpB,UAAU,EAAE,EAAE;gBACd,UAAU;gBACV,MAAM,EAAE,UAAU;gBAClB,MAAM,EAAE,SAAS;gBACjB,cAAc,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;aAC1B,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;gBAChD,OAAO,QAAQ,CAAC;YAClB,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AASD,MAAM,iBAAiB,GAAsB;IAC3C,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,EAAE;IAC5F,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,oBAAoB,EAAE,GAAG,EAAE;IACrF,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,oBAAoB,EAAE,IAAI,EAAE;IAC5F,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,EAAE;CACrF,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,GAAqB;IAChE,MAAM,QAAQ,GAAmB,EAAE,CAAC;IAEpC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;QAClC,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,KAAK,MAAM,IAAI,IAAI,iBAAiB,EAAE,CAAC;QACrC,MAAM,gBAAgB,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;YACpD,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,KAAK,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC;SACpB,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,CAAC,OAAO,IAAI,CAAC,gBAAgB,CAAC,IAAI;YAAE,SAAS;QAElE,KAAK,MAAM,SAAS,IAAI,gBAAgB,CAAC,IAAI,EAAE,CAAC;YAC9C,MAAM,iBAAiB,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;gBACrD,OAAO,EAAE,GAAG,CAAC,OAAO;gBACpB,YAAY,EAAE,SAAS,CAAC,YAAY;gBACpC,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;aACrB,CAAC,CAAC;YAEH,IAAI,CAAC,iBAAiB,CAAC,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI;gBAAE,SAAS;YAEpE,KAAK,MAAM,UAAU,IAAI,iBAAiB,CAAC,IAAI,EAAE,CAAC;gBAChD,IAAI,UAAU,CAAC,YAAY,KAAK,SAAS,CAAC,YAAY;oBAAE,SAAS;gBAEjE,MAAM,cAAc,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,eAAe,CACtD,SAAS,CAAC,YAAY,EACtB,UAAU,CAAC,YAAY,CACxB,CAAC;gBAEF,IAAI,cAAc,CAAC,OAAO,IAAI,cAAc,CAAC,IAAI,IAAI,cAAc,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACpF,MAAM,OAAO,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,CAAC;oBACxE,IAAI,OAAO;wBAAE,SAAS;gBACxB,CAAC;gBAED,MAAM,UAAU,GACd,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBAEpF,IAAI,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,aAAa;oBAAE,SAAS;gBAEpD,QAAQ,CAAC,IAAI,CAAC;oBACZ,OAAO,EAAE,GAAG,CAAC,OAAO;oBACpB,YAAY,EAAE,SAAS,CAAC,YAAY;oBACpC,YAAY,EAAE,UAAU,CAAC,YAAY;oBACrC,IAAI,EAAE,IAAI,CAAC,MAAM;oBACjB,KAAK,EAAE,aAAa,IAAI,CAAC,KAAK,MAAM,IAAI,CAAC,MAAM,MAAM,IAAI,CAAC,MAAM,EAAE;oBAClE,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC;oBACrD,aAAa,EAAE,KAAK;oBACpB,UAAU,EAAE;wBACV,eAAe,EAAE,GAAG,IAAI,CAAC,KAAK,MAAM,IAAI,CAAC,MAAM,EAAE;qBAClD;oBACD,UAAU;oBACV,MAAM,EAAE,UAAU;oBAClB,MAAM,EAAE,aAAa;oBACrB,cAAc,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,CAAC;iBAC9C,CAAC,CAAC;gBAEH,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;oBAChD,OAAO,QAAQ,CAAC;gBAClB,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,GAAqB;IAC1D,MAAM,WAAW,GAAmB,EAAE,CAAC;IAEvC,MAAM,UAAU,GAAG,MAAM,wBAAwB,CAAC,GAAG,CAAC,CAAC;IACvD,WAAW,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC;IAEhC,IAAI,WAAW,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;QACnD,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IACxD,CAAC;IAED,MAAM,OAAO,GAAG,MAAM,qBAAqB,CAAC,GAAG,CAAC,CAAC;IACjD,WAAW,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;IAE7B,IAAI,WAAW,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;QACnD,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IACxD,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,sBAAsB,CAAC,GAAG,CAAC,CAAC;IACnD,WAAW,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;IAE9B,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,OAAO,eAAe;IAClB,GAAG,CAAmB;IAE9B,YAAY,OAAqB,EAAE,OAAe,EAAE,SAAmC,EAAE;QACvF,IAAI,CAAC,GAAG,GAAG;YACT,OAAO;YACP,OAAO;YACP,MAAM,EAAE,EAAE,GAAG,wBAAwB,EAAE,GAAG,MAAM,EAAE;SACnD,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,WAAmB,EAAE,SAAiB;QACnD,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,WAAmB,EAAE,YAA4B;QACnE,OAAO,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;IAC5D,CAAC;IAED,KAAK,CAAC,KAAK;QACT,OAAO,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,OAAO,wBAAwB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,OAAO,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,aAAa;QACjB,OAAO,sBAAsB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED,YAAY,CAAC,MAAgC;QAC3C,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,MAAM,EAAE,CAAC;IACtD,CAAC;CACF;AAED,MAAM,UAAU,qBAAqB,CACnC,OAAqB,EACrB,OAAe,EACf,MAAiC;IAEjC,OAAO,IAAI,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;AACvD,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { CompoundTerm, Substitution, BuiltinPredicate } from '@cogitator-ai/types';
2
+ export interface BuiltinResult {
3
+ success: boolean;
4
+ substitutions: Substitution[];
5
+ cut?: boolean;
6
+ }
7
+ export declare function isBuiltin(functor: string, arity: number): boolean;
8
+ export declare function executeBuiltin(goal: CompoundTerm, subst: Substitution): BuiltinResult;
9
+ export declare function getBuiltinList(): BuiltinPredicate[];
10
+ //# sourceMappingURL=builtins.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"builtins.d.ts","sourceRoot":"","sources":["../../src/logic/builtins.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAEjB,MAAM,qBAAqB,CAAC;AAY7B,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,OAAO,CAAC;IACjB,aAAa,EAAE,YAAY,EAAE,CAAC;IAC9B,GAAG,CAAC,EAAE,OAAO,CAAC;CACf;AAmkBD,wBAAgB,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAEjE;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,GAAG,aAAa,CASrF;AAED,wBAAgB,cAAc,IAAI,gBAAgB,EAAE,CA8BnD"}