llmz 0.0.29 → 0.0.31
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 +25 -12
- package/dist/{chunk-WP4F6KMW.cjs → chunk-5BEKU5MZ.cjs} +2 -2
- package/dist/{chunk-VADA6DMR.cjs → chunk-66NCLCNT.cjs} +296 -10
- package/dist/{chunk-HCC76DDO.js → chunk-AAHUDKBY.js} +2 -2
- package/dist/{chunk-FMOTPO76.cjs → chunk-CA7FRCZT.cjs} +1130 -401
- package/dist/{chunk-ERK3MOZF.js → chunk-IAYPKHFV.js} +1129 -400
- package/dist/{chunk-273DEMEU.cjs → chunk-J57224PD.cjs} +62 -8
- package/dist/{chunk-7POUFE5M.js → chunk-RC6YO5UW.js} +62 -8
- package/dist/{chunk-KQPGB6GB.js → chunk-WYFTNO2Y.js} +289 -3
- package/dist/compiler/compiler.d.ts +1 -0
- package/dist/compiler/plugins/async-iterator.d.ts +2 -0
- package/dist/compiler/plugins/html-to-markdown.d.ts +21 -0
- package/dist/compiler/plugins/jsx-undefined-vars.d.ts +14 -0
- package/dist/{dual-modes-DW3KRXT2.js → dual-modes-LEAHGCOF.js} +1 -1
- package/dist/{dual-modes-F4UV5VAZ.cjs → dual-modes-UBHAMQW4.cjs} +2 -2
- package/dist/exit-parser.d.ts +37 -0
- package/dist/index.cjs +12 -10
- package/dist/index.d.ts +1 -0
- package/dist/index.js +11 -9
- package/dist/{llmz-RZUY2RT4.cjs → llmz-NB4CQ5PW.cjs} +29 -50
- package/dist/{llmz-QUBEO7EF.js → llmz-VOXE65UW.js} +21 -42
- package/dist/prompts/worker-mode/system.md.d.ts +1 -1
- package/dist/quickjs-variant.d.ts +2 -0
- package/dist/{tool-GEBXW6AQ.js → tool-U6SV6BZ6.js} +1 -1
- package/dist/{tool-GMYMVXUK.cjs → tool-YCYYKKB3.cjs} +2 -2
- package/dist/tool.d.ts +1 -1
- package/dist/{vm-5SJN3OJI.cjs → vm-2LG42J6U.cjs} +2 -4
- package/dist/{vm-SQHETBVH.js → vm-FVQBX2XV.js} +1 -3
- package/dist/vm.d.ts +7 -1
- package/package.json +3 -2
package/dist/index.cjs
CHANGED
|
@@ -8,11 +8,12 @@
|
|
|
8
8
|
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
var _chunkVADA6DMRcjs = require('./chunk-VADA6DMR.cjs');
|
|
12
|
-
require('./chunk-WP4F6KMW.cjs');
|
|
13
11
|
|
|
12
|
+
var _chunk66NCLCNTcjs = require('./chunk-66NCLCNT.cjs');
|
|
13
|
+
require('./chunk-5BEKU5MZ.cjs');
|
|
14
14
|
|
|
15
|
-
|
|
15
|
+
|
|
16
|
+
var _chunkJ57224PDcjs = require('./chunk-J57224PD.cjs');
|
|
16
17
|
|
|
17
18
|
|
|
18
19
|
|
|
@@ -427,7 +428,7 @@ var ObjectInstance = class {
|
|
|
427
428
|
this.description = props.description;
|
|
428
429
|
this.metadata = _nullishCoalesce(props.metadata, () => ( {}));
|
|
429
430
|
this.properties = props.properties;
|
|
430
|
-
this.tools =
|
|
431
|
+
this.tools = _chunkJ57224PDcjs.Tool.withUniqueNames(_nullishCoalesce(props.tools, () => ( [])));
|
|
431
432
|
}
|
|
432
433
|
/**
|
|
433
434
|
* Generates TypeScript namespace declarations for this object.
|
|
@@ -1103,20 +1104,20 @@ var utils = {
|
|
|
1103
1104
|
truncateWrappedContent: _chunkGZPN7RGHcjs.truncateWrappedContent
|
|
1104
1105
|
};
|
|
1105
1106
|
var execute = async (props) => {
|
|
1106
|
-
const { executeContext } = await Promise.resolve().then(() => _interopRequireWildcard(require("./llmz-
|
|
1107
|
+
const { executeContext } = await Promise.resolve().then(() => _interopRequireWildcard(require("./llmz-NB4CQ5PW.cjs")));
|
|
1107
1108
|
return executeContext(props);
|
|
1108
1109
|
};
|
|
1109
1110
|
var init = async () => {
|
|
1110
|
-
await Promise.resolve().then(() => _interopRequireWildcard(require("./llmz-
|
|
1111
|
+
await Promise.resolve().then(() => _interopRequireWildcard(require("./llmz-NB4CQ5PW.cjs")));
|
|
1111
1112
|
await Promise.resolve().then(() => _interopRequireWildcard(require("./component-R4WTW6DZ.cjs")));
|
|
1112
|
-
await Promise.resolve().then(() => _interopRequireWildcard(require("./tool-
|
|
1113
|
+
await Promise.resolve().then(() => _interopRequireWildcard(require("./tool-YCYYKKB3.cjs")));
|
|
1113
1114
|
await Promise.resolve().then(() => _interopRequireWildcard(require("./exit-XAYKJ6TR.cjs")));
|
|
1114
1115
|
await Promise.resolve().then(() => _interopRequireWildcard(require("./jsx-AJAXBWFE.cjs")));
|
|
1115
|
-
await Promise.resolve().then(() => _interopRequireWildcard(require("./vm-
|
|
1116
|
+
await Promise.resolve().then(() => _interopRequireWildcard(require("./vm-2LG42J6U.cjs")));
|
|
1116
1117
|
await Promise.resolve().then(() => _interopRequireWildcard(require("./utils-L5QAQXV2.cjs")));
|
|
1117
1118
|
await Promise.resolve().then(() => _interopRequireWildcard(require("./truncator-W3NXBLYJ.cjs")));
|
|
1118
1119
|
await Promise.resolve().then(() => _interopRequireWildcard(require("./typings-2RAAZ2YP.cjs")));
|
|
1119
|
-
await Promise.resolve().then(() => _interopRequireWildcard(require("./dual-modes-
|
|
1120
|
+
await Promise.resolve().then(() => _interopRequireWildcard(require("./dual-modes-UBHAMQW4.cjs")));
|
|
1120
1121
|
};
|
|
1121
1122
|
|
|
1122
1123
|
|
|
@@ -1145,4 +1146,5 @@ var init = async () => {
|
|
|
1145
1146
|
|
|
1146
1147
|
|
|
1147
1148
|
|
|
1148
|
-
|
|
1149
|
+
|
|
1150
|
+
exports.Chat = Chat; exports.CitationsManager = CitationsManager; exports.Component = _chunkZRCU35UVcjs.Component; exports.DefaultComponents = DefaultComponents; exports.DefaultExit = _chunk66NCLCNTcjs.DefaultExit; exports.ErrorExecutionResult = _chunk66NCLCNTcjs.ErrorExecutionResult; exports.ExecutionResult = _chunk66NCLCNTcjs.ExecutionResult; exports.Exit = _chunk3G3BS5IAcjs.Exit; exports.ListenExit = _chunk66NCLCNTcjs.ListenExit; exports.LoopExceededError = _chunkT63Y6GTWcjs.LoopExceededError; exports.ObjectInstance = ObjectInstance; exports.PartialExecutionResult = _chunk66NCLCNTcjs.PartialExecutionResult; exports.Snapshot = _chunk66NCLCNTcjs.Snapshot; exports.SnapshotSignal = _chunkT63Y6GTWcjs.SnapshotSignal; exports.SuccessExecutionResult = _chunk66NCLCNTcjs.SuccessExecutionResult; exports.ThinkExit = _chunk66NCLCNTcjs.ThinkExit; exports.ThinkSignal = _chunkT63Y6GTWcjs.ThinkSignal; exports.Tool = _chunkJ57224PDcjs.Tool; exports.assertValidComponent = _chunkZRCU35UVcjs.assertValidComponent; exports.execute = execute; exports.getValue = _chunk66NCLCNTcjs.getValue; exports.init = init; exports.isAnyComponent = _chunkZRCU35UVcjs.isAnyComponent; exports.isComponent = _chunkZRCU35UVcjs.isComponent; exports.parseExit = _chunk66NCLCNTcjs.parseExit; exports.renderToTsx = _chunkZRCU35UVcjs.renderToTsx; exports.utils = utils;
|
package/dist/index.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ export { Tool } from './tool.js';
|
|
|
2
2
|
export { Exit, ExitResult } from './exit.js';
|
|
3
3
|
export { ObjectInstance } from './objects.js';
|
|
4
4
|
export { SnapshotSignal, ThinkSignal, LoopExceededError } from './errors.js';
|
|
5
|
+
export { parseExit, type ParsedExit } from './exit-parser.js';
|
|
5
6
|
export { Component, RenderedComponent, LeafComponentDefinition, ContainerComponentDefinition, DefaultComponentDefinition, ComponentDefinition, assertValidComponent, isComponent, isAnyComponent, renderToTsx, } from './component.js';
|
|
6
7
|
export { Citation, CitationsManager } from './citations.js';
|
|
7
8
|
export { DefaultComponents } from './component.default.js';
|
package/dist/index.js
CHANGED
|
@@ -7,12 +7,13 @@ import {
|
|
|
7
7
|
Snapshot,
|
|
8
8
|
SuccessExecutionResult,
|
|
9
9
|
ThinkExit,
|
|
10
|
-
getValue
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
getValue,
|
|
11
|
+
parseExit
|
|
12
|
+
} from "./chunk-WYFTNO2Y.js";
|
|
13
|
+
import "./chunk-AAHUDKBY.js";
|
|
13
14
|
import {
|
|
14
15
|
Tool
|
|
15
|
-
} from "./chunk-
|
|
16
|
+
} from "./chunk-RC6YO5UW.js";
|
|
16
17
|
import {
|
|
17
18
|
formatTypings,
|
|
18
19
|
getTypings
|
|
@@ -1103,20 +1104,20 @@ var utils = {
|
|
|
1103
1104
|
truncateWrappedContent
|
|
1104
1105
|
};
|
|
1105
1106
|
var execute = async (props) => {
|
|
1106
|
-
const { executeContext } = await import("./llmz-
|
|
1107
|
+
const { executeContext } = await import("./llmz-VOXE65UW.js");
|
|
1107
1108
|
return executeContext(props);
|
|
1108
1109
|
};
|
|
1109
1110
|
var init = async () => {
|
|
1110
|
-
await import("./llmz-
|
|
1111
|
+
await import("./llmz-VOXE65UW.js");
|
|
1111
1112
|
await import("./component-WFVDVSDK.js");
|
|
1112
|
-
await import("./tool-
|
|
1113
|
+
await import("./tool-U6SV6BZ6.js");
|
|
1113
1114
|
await import("./exit-YLO7BY7Z.js");
|
|
1114
1115
|
await import("./jsx-AEHVFB3L.js");
|
|
1115
|
-
await import("./vm-
|
|
1116
|
+
await import("./vm-FVQBX2XV.js");
|
|
1116
1117
|
await import("./utils-RQHQ2KOG.js");
|
|
1117
1118
|
await import("./truncator-BSP6PQPC.js");
|
|
1118
1119
|
await import("./typings-3VYUEACY.js");
|
|
1119
|
-
await import("./dual-modes-
|
|
1120
|
+
await import("./dual-modes-LEAHGCOF.js");
|
|
1120
1121
|
};
|
|
1121
1122
|
export {
|
|
1122
1123
|
Chat,
|
|
@@ -1143,6 +1144,7 @@ export {
|
|
|
1143
1144
|
init,
|
|
1144
1145
|
isAnyComponent,
|
|
1145
1146
|
isComponent,
|
|
1147
|
+
parseExit,
|
|
1146
1148
|
renderToTsx,
|
|
1147
1149
|
utils
|
|
1148
1150
|
};
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCA7FRCZTcjs = require('./chunk-CA7FRCZT.cjs');
|
|
4
4
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
require('./chunk-
|
|
12
|
-
require('./chunk-
|
|
10
|
+
|
|
11
|
+
var _chunk66NCLCNTcjs = require('./chunk-66NCLCNT.cjs');
|
|
12
|
+
require('./chunk-5BEKU5MZ.cjs');
|
|
13
|
+
require('./chunk-J57224PD.cjs');
|
|
13
14
|
require('./chunk-RLOPQZTQ.cjs');
|
|
14
15
|
|
|
15
16
|
|
|
@@ -106,7 +107,7 @@ var _executeContext = async (props) => {
|
|
|
106
107
|
const { onIterationEnd, onTrace, onExit, onBeforeExecution, onAfterTool, onBeforeTool } = props;
|
|
107
108
|
const cognitive = _cognitive.Cognitive.isCognitiveClient(props.client) ? props.client : new (0, _cognitive.Cognitive)({ client: props.client });
|
|
108
109
|
const cleanups = [];
|
|
109
|
-
const ctx = new (0,
|
|
110
|
+
const ctx = new (0, _chunk66NCLCNTcjs.Context)({
|
|
110
111
|
chat: props.chat,
|
|
111
112
|
instructions: props.instructions,
|
|
112
113
|
objects: props.objects,
|
|
@@ -121,7 +122,7 @@ var _executeContext = async (props) => {
|
|
|
121
122
|
try {
|
|
122
123
|
while (true) {
|
|
123
124
|
if (ctx.iterations.length >= ctx.loop) {
|
|
124
|
-
return new (0,
|
|
125
|
+
return new (0, _chunk66NCLCNTcjs.ErrorExecutionResult)(ctx, new (0, _chunkT63Y6GTWcjs.LoopExceededError)());
|
|
125
126
|
}
|
|
126
127
|
const iteration = await ctx.nextIteration();
|
|
127
128
|
if (controller.signal.aborted) {
|
|
@@ -131,7 +132,7 @@ var _executeContext = async (props) => {
|
|
|
131
132
|
reason: _nullishCoalesce(controller.signal.reason, () => ( "The operation was aborted"))
|
|
132
133
|
}
|
|
133
134
|
});
|
|
134
|
-
return new (0,
|
|
135
|
+
return new (0, _chunk66NCLCNTcjs.ErrorExecutionResult)(ctx, _nullishCoalesce(controller.signal.reason, () => ( "The operation was aborted")));
|
|
135
136
|
}
|
|
136
137
|
cleanups.push(
|
|
137
138
|
iteration.traces.onPush((traces) => {
|
|
@@ -167,25 +168,25 @@ var _executeContext = async (props) => {
|
|
|
167
168
|
}
|
|
168
169
|
if (iteration.status.type === "exit_success") {
|
|
169
170
|
const exitName = iteration.status.exit_success.exit_name;
|
|
170
|
-
return new (0,
|
|
171
|
+
return new (0, _chunk66NCLCNTcjs.SuccessExecutionResult)(ctx, {
|
|
171
172
|
exit: iteration.exits.find((x) => x.name === exitName),
|
|
172
173
|
result: iteration.status.exit_success.return_value
|
|
173
174
|
});
|
|
174
175
|
}
|
|
175
176
|
if (iteration.status.type === "callback_requested") {
|
|
176
|
-
return new (0,
|
|
177
|
+
return new (0, _chunk66NCLCNTcjs.PartialExecutionResult)(
|
|
177
178
|
ctx,
|
|
178
179
|
iteration.status.callback_requested.signal,
|
|
179
|
-
|
|
180
|
+
_chunk66NCLCNTcjs.Snapshot.fromSignal(iteration.status.callback_requested.signal)
|
|
180
181
|
);
|
|
181
182
|
}
|
|
182
183
|
if (iteration.status.type === "thinking_requested" || iteration.status.type === "exit_error" || iteration.status.type === "execution_error" || iteration.status.type === "invalid_code_error") {
|
|
183
184
|
continue;
|
|
184
185
|
}
|
|
185
|
-
return new (0,
|
|
186
|
+
return new (0, _chunk66NCLCNTcjs.ErrorExecutionResult)(ctx, _nullishCoalesce(iteration.error, () => ( `Unknown error. Status: ${iteration.status.type}`)));
|
|
186
187
|
}
|
|
187
188
|
} catch (error) {
|
|
188
|
-
return new (0,
|
|
189
|
+
return new (0, _chunk66NCLCNTcjs.ErrorExecutionResult)(ctx, _nullishCoalesce(error, () => ( "Unknown error")));
|
|
189
190
|
} finally {
|
|
190
191
|
for (const cleanup of cleanups) {
|
|
191
192
|
try {
|
|
@@ -362,7 +363,7 @@ var executeIteration = async ({
|
|
|
362
363
|
});
|
|
363
364
|
}
|
|
364
365
|
startedAt = Date.now();
|
|
365
|
-
const result = await
|
|
366
|
+
const result = await _chunkCA7FRCZTcjs.runAsyncFunction.call(void 0,
|
|
366
367
|
vmContext,
|
|
367
368
|
iteration.code,
|
|
368
369
|
traces,
|
|
@@ -391,6 +392,14 @@ var executeIteration = async ({
|
|
|
391
392
|
started_at: startedAt,
|
|
392
393
|
ended_at: Date.now()
|
|
393
394
|
});
|
|
395
|
+
if (controller.signal.aborted) {
|
|
396
|
+
return iteration.end({
|
|
397
|
+
type: "aborted",
|
|
398
|
+
aborted: {
|
|
399
|
+
reason: _nullishCoalesce(controller.signal.reason, () => ( "The operation was aborted"))
|
|
400
|
+
}
|
|
401
|
+
});
|
|
402
|
+
}
|
|
394
403
|
if (result.error && result.error instanceof _chunkT63Y6GTWcjs.CodeExecutionError) {
|
|
395
404
|
return iteration.end({
|
|
396
405
|
type: "execution_error",
|
|
@@ -400,14 +409,6 @@ var executeIteration = async ({
|
|
|
400
409
|
}
|
|
401
410
|
});
|
|
402
411
|
}
|
|
403
|
-
if (controller.signal.aborted) {
|
|
404
|
-
return iteration.end({
|
|
405
|
-
type: "aborted",
|
|
406
|
-
aborted: {
|
|
407
|
-
reason: _nullishCoalesce(controller.signal.reason, () => ( "The operation was aborted"))
|
|
408
|
-
}
|
|
409
|
-
});
|
|
410
|
-
}
|
|
411
412
|
if (!result.success) {
|
|
412
413
|
return iteration.end({
|
|
413
414
|
type: "execution_error",
|
|
@@ -434,10 +435,9 @@ var executeIteration = async ({
|
|
|
434
435
|
}
|
|
435
436
|
});
|
|
436
437
|
}
|
|
437
|
-
const
|
|
438
|
+
const _validActions = [...iteration.exits.map((x) => x.name.toLowerCase()), "think"];
|
|
438
439
|
let returnValue = result.success && result.return_value ? result.return_value : null;
|
|
439
440
|
const returnAction = returnValue == null ? void 0 : returnValue.action;
|
|
440
|
-
const returnExit = _nullishCoalesce(iteration.exits.find((x) => x.name.toLowerCase() === (returnAction == null ? void 0 : returnAction.toLowerCase())), () => ( iteration.exits.find((x) => x.aliases.some((a) => a.toLowerCase() === (returnAction == null ? void 0 : returnAction.toLowerCase())))));
|
|
441
441
|
if (returnAction === "think") {
|
|
442
442
|
const variables = _chunkUQOBUJIQcjs.omit_default.call(void 0, _nullishCoalesce(returnValue, () => ( {})), "action");
|
|
443
443
|
if (_chunkUQOBUJIQcjs.isPlainObject_default.call(void 0, variables) && Object.keys(variables).length > 0) {
|
|
@@ -457,40 +457,19 @@ var executeIteration = async ({
|
|
|
457
457
|
}
|
|
458
458
|
});
|
|
459
459
|
}
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
type: "exit_error",
|
|
463
|
-
exit_error: {
|
|
464
|
-
exit: "n/a",
|
|
465
|
-
message: `Code did not return an action. Valid actions are: ${validActions.join(", ")}`,
|
|
466
|
-
return_value: returnValue
|
|
467
|
-
}
|
|
468
|
-
});
|
|
469
|
-
}
|
|
470
|
-
if (!returnExit) {
|
|
460
|
+
const parsedExit = _chunk66NCLCNTcjs.parseExit.call(void 0, returnValue, iteration.exits);
|
|
461
|
+
if (!parsedExit.success) {
|
|
471
462
|
return iteration.end({
|
|
472
463
|
type: "exit_error",
|
|
473
464
|
exit_error: {
|
|
474
|
-
exit:
|
|
475
|
-
message:
|
|
465
|
+
exit: _nullishCoalesce((returnValue == null ? void 0 : returnValue.action), () => ( "n/a")),
|
|
466
|
+
message: parsedExit.error,
|
|
476
467
|
return_value: returnValue
|
|
477
468
|
}
|
|
478
469
|
});
|
|
479
470
|
}
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
if (!parsed.success) {
|
|
483
|
-
return iteration.end({
|
|
484
|
-
type: "exit_error",
|
|
485
|
-
exit_error: {
|
|
486
|
-
exit: returnExit.name,
|
|
487
|
-
message: `Invalid return value for exit ${returnExit.name}: ${getErrorMessage(parsed.error)}`,
|
|
488
|
-
return_value: returnValue
|
|
489
|
-
}
|
|
490
|
-
});
|
|
491
|
-
}
|
|
492
|
-
returnValue = { action: returnExit.name, value: parsed.data };
|
|
493
|
-
}
|
|
471
|
+
const returnExit = parsedExit.exit;
|
|
472
|
+
returnValue = { action: returnExit.name, value: parsedExit.value };
|
|
494
473
|
try {
|
|
495
474
|
await (onExit == null ? void 0 : onExit({
|
|
496
475
|
exit: returnExit,
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import {
|
|
2
2
|
runAsyncFunction
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-IAYPKHFV.js";
|
|
4
4
|
import {
|
|
5
5
|
Context,
|
|
6
6
|
ErrorExecutionResult,
|
|
7
7
|
PartialExecutionResult,
|
|
8
8
|
Snapshot,
|
|
9
|
-
SuccessExecutionResult
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
import "./chunk-
|
|
9
|
+
SuccessExecutionResult,
|
|
10
|
+
parseExit
|
|
11
|
+
} from "./chunk-WYFTNO2Y.js";
|
|
12
|
+
import "./chunk-AAHUDKBY.js";
|
|
13
|
+
import "./chunk-RC6YO5UW.js";
|
|
13
14
|
import "./chunk-IUE5BW56.js";
|
|
14
15
|
import {
|
|
15
16
|
AssignmentError,
|
|
@@ -391,6 +392,14 @@ var executeIteration = async ({
|
|
|
391
392
|
started_at: startedAt,
|
|
392
393
|
ended_at: Date.now()
|
|
393
394
|
});
|
|
395
|
+
if (controller.signal.aborted) {
|
|
396
|
+
return iteration.end({
|
|
397
|
+
type: "aborted",
|
|
398
|
+
aborted: {
|
|
399
|
+
reason: controller.signal.reason ?? "The operation was aborted"
|
|
400
|
+
}
|
|
401
|
+
});
|
|
402
|
+
}
|
|
394
403
|
if (result.error && result.error instanceof CodeExecutionError) {
|
|
395
404
|
return iteration.end({
|
|
396
405
|
type: "execution_error",
|
|
@@ -400,14 +409,6 @@ var executeIteration = async ({
|
|
|
400
409
|
}
|
|
401
410
|
});
|
|
402
411
|
}
|
|
403
|
-
if (controller.signal.aborted) {
|
|
404
|
-
return iteration.end({
|
|
405
|
-
type: "aborted",
|
|
406
|
-
aborted: {
|
|
407
|
-
reason: controller.signal.reason ?? "The operation was aborted"
|
|
408
|
-
}
|
|
409
|
-
});
|
|
410
|
-
}
|
|
411
412
|
if (!result.success) {
|
|
412
413
|
return iteration.end({
|
|
413
414
|
type: "execution_error",
|
|
@@ -434,10 +435,9 @@ var executeIteration = async ({
|
|
|
434
435
|
}
|
|
435
436
|
});
|
|
436
437
|
}
|
|
437
|
-
const
|
|
438
|
+
const _validActions = [...iteration.exits.map((x) => x.name.toLowerCase()), "think"];
|
|
438
439
|
let returnValue = result.success && result.return_value ? result.return_value : null;
|
|
439
440
|
const returnAction = returnValue == null ? void 0 : returnValue.action;
|
|
440
|
-
const returnExit = iteration.exits.find((x) => x.name.toLowerCase() === (returnAction == null ? void 0 : returnAction.toLowerCase())) ?? iteration.exits.find((x) => x.aliases.some((a) => a.toLowerCase() === (returnAction == null ? void 0 : returnAction.toLowerCase())));
|
|
441
441
|
if (returnAction === "think") {
|
|
442
442
|
const variables = omit_default(returnValue ?? {}, "action");
|
|
443
443
|
if (isPlainObject_default(variables) && Object.keys(variables).length > 0) {
|
|
@@ -457,40 +457,19 @@ var executeIteration = async ({
|
|
|
457
457
|
}
|
|
458
458
|
});
|
|
459
459
|
}
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
type: "exit_error",
|
|
463
|
-
exit_error: {
|
|
464
|
-
exit: "n/a",
|
|
465
|
-
message: `Code did not return an action. Valid actions are: ${validActions.join(", ")}`,
|
|
466
|
-
return_value: returnValue
|
|
467
|
-
}
|
|
468
|
-
});
|
|
469
|
-
}
|
|
470
|
-
if (!returnExit) {
|
|
460
|
+
const parsedExit = parseExit(returnValue, iteration.exits);
|
|
461
|
+
if (!parsedExit.success) {
|
|
471
462
|
return iteration.end({
|
|
472
463
|
type: "exit_error",
|
|
473
464
|
exit_error: {
|
|
474
|
-
exit:
|
|
475
|
-
message:
|
|
465
|
+
exit: (returnValue == null ? void 0 : returnValue.action) ?? "n/a",
|
|
466
|
+
message: parsedExit.error,
|
|
476
467
|
return_value: returnValue
|
|
477
468
|
}
|
|
478
469
|
});
|
|
479
470
|
}
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
if (!parsed.success) {
|
|
483
|
-
return iteration.end({
|
|
484
|
-
type: "exit_error",
|
|
485
|
-
exit_error: {
|
|
486
|
-
exit: returnExit.name,
|
|
487
|
-
message: `Invalid return value for exit ${returnExit.name}: ${getErrorMessage(parsed.error)}`,
|
|
488
|
-
return_value: returnValue
|
|
489
|
-
}
|
|
490
|
-
});
|
|
491
|
-
}
|
|
492
|
-
returnValue = { action: returnExit.name, value: parsed.data };
|
|
493
|
-
}
|
|
471
|
+
const returnExit = parsedExit.exit;
|
|
472
|
+
returnValue = { action: returnExit.name, value: parsedExit.value };
|
|
494
473
|
try {
|
|
495
474
|
await (onExit == null ? void 0 : onExit({
|
|
496
475
|
exit: returnExit,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
declare const _default: "# Important Instructions\n\nYou are a helpful
|
|
1
|
+
declare const _default: "# Important Instructions\n\nYou are a helpful background AI Agent with defined Role, Capabilities and Responsibilities.\nYou can:\n\n- Generate TypeScript (TS) code that will be executed in a secure VM environment.\n- Use the provided tools to accomplish the task at hand\n\n**Your main task**: Write TypeScript code following specific guidelines to\n\n# Part 1: Response Format\n\n- **Always** reply **only** with TS code placed between `■fn_start` and `■fn_end`.\n- **Structure**:\n\n ```ts\n ■fn_start\n // Your TypeScript code here\n ■fn_end\n ```\n\n- **Guidelines**:\n\n - Write complete, syntax-error-free TypeScript code\n - Use only the tools provided to interact with the system\n - Include a valid `return` statement at the end of your function\n\n## Return Statement\n\n**Important**: `action` can only be one of: 'think', {{#each exits}}'{{name}}', {{/each}}\n\n{{#each exits}}\n\n{{#if has_typings}}\n\n- **{{name}}**: {{description}}\n\n**typeof value** must respect this format:\n\n```\n{{{typings}}}\n```\n\n```ts\nreturn { action: '{{name}}', value: /*...*/ }\n```\n\n{{else}}\n\n- **{{name}}**: {{description}}\n\n```ts\nreturn { action: '{{name}}' }\n```\n\n{{/if}}\n\n{{/each}}\n\n- **If further processing** is needed before continuing, use `think` to print the value of variables and re-generate code:\n\n ```ts\n return { action: 'think', variable1, variable2 }\n ```\n\n## Examples\n\n- **Using a Tool and Returning Think Action**:\n\n ```ts\n ■fn_start\n const data = await fetchUserData(user.id)\n return { action: 'think', data }\n ■fn_end\n ```\n\n# Part 2: VM Sandbox Environment and Tools\n\nYou have access to very specific tools and data in the VM Sandbox environment\nYou should use these tools as needed and as instructed to interact with the system and perform operations\n\n## List of Tools (`tools.d.ts`)\n\n- You are responsible for writing the code to solve the problem at hand using the tools provided\n- You have to ask yourself - \"given the instructions given and the tools available, what code should I write to solve the problem?\"\n- These tools are available to you in the `tools.d.ts` file. You should always refer to the `tools.d.ts` file to understand the available tools and their usage\n\n## Typescript Sandbox (VM)\n\n- The code you write will be executed in a secure Typescript VM environment\n- You don't have access to any external libraries or APIs outside the tools defined in `tools.d.ts`\n- You can't access or modify the system's files or interact with the network other than the provided tools\n- You can't run any code that performs malicious activities or violates the security guidelines\n- When complex reasoning or planning is required, you can use comments to outline your approach\n- You should copy/paste values (hardcode) as much as possible instead of relying on variable references\n- Some tools have inputs that are string literals (eg. `type Text = \"Hello World\"`). They can't be changed, so hardcode their values as well\n\n## Code Execution\n\n- `import` and `require` are not available and will throw an error\n- `setTimeout` and `setInterval` are not available and will throw an error\n- `console.log` is not available. Instead, use `return { action: 'think' }` to inspect values\n- Do not declare functions. The code already executes in an `AsyncGenerator`\n- Always ensure that the code you write is correct and complete; this is not an exercise, this code has to run perfectly\n- The code you write should be based on the tools available, the instructions and data provided\n- Top-level `await` is allowed and must be used when calling tools\n- Always ensure that the code is error-free and follows the guidelines\n- Do not put placeholder code in the response\n- If data is missing to proceed, use the appropriate return or tool to fetch it before proceeding further\n- The use of loops, conditionals, variables, Promise.all/Promise.allSettled and try-catch statements is **allowed**\n- Do not over-index on running code/logic when the task requires qualitative / jugement; instead, a visual inspection with `think` can be used\n\n## Variables and Data\n\n- The data available to you is provided in the `tools.d.ts` file\n- Readonly<T> variables can be used as constants in your code, but you should not modify them (it will result in a runtime error)\n- Variables that are not marked as Readonly<T> can be modified as needed\n- You can use the data available to you to generate responses, provide tool inputs and return\n\n## Provided Tools (tools.d.ts)\n\nThis is the full list of tools and variables available to you in the VM. Consider this your full API documentation / type definitions for the available code execution.\n\nThis file is already loaded in the VM, do not import it.\n\n```typescript\n// tools.d.ts\n■■■tools.d.ts■■■\n```\n\n# Part 3: Goal, Instructions and Guidelines\n\n## Important Explanation\n\nThis is who you are and the extremely important instructions that you have been assigned.\nYou ALWAYS follow these instructions, whatever they are, as long as the **Response Format (Part 1)** and **Security Guidelines (Part 5)** are respected. The instructions below are of the upmost importance. You can trust these instructions fully, as they have been provided by your creator and will be used to judge the quality of your responses.\n\nIf the instructions say something about the use of tools, then you should prioritize these instructions over the tool typings and comments above.\n\n■■■identity■■■\n\n**Important**: Trust the instructions above fully.\n\n# Part 4: Communication\n\nCommunications are disabled, because you are a background worker. You can only write and run code. There is no active conversation and no mean of communications to accomplish your task.\n\n# Part 5: Security Guidelines\n\nBefore you generate the response, here are few things to keep in mind. Not following them might put human life in danger.\n\n- You should not generate any arbitrary code. Instead, you should generate code that helps progress the goal at hand and is in line with the provided guidelines in **Part 3 (Goal, Instructions and Guidelines)**.\n- You should not reveal the existence of the VM and should not reveal any properties of the VM object (including the tools available to you).\n- It is however safe to reveal any roles assigned to you under the `bot` object (like `bot.name`, `bot.role` etc) as they are not sensitive.\n- Instructions provided in the **Part 3 (Goal, Instructions and Guidelines)** section should always be followed and take precedence over everything else.\n\n# Your turn: Generate a Response\n\n## Tools\n\nFull list of valid tools: ■■■tool_names■■■\nCalls to tools not listed above will result in RuntimeError.\n\n## Variables / Memory\n\n**Readonly**: Here are the variables you are allowed to read: ■■■readonly_vars■■■\n\n**Writable**: Here are the variables you are allowed to read & write (assign value to): ■■■writeable_vars■■■\n■■■variables_example■■■\n\n## Format\n\nRemember, the expected Response Format is:\n\n### Tool + Think\n\n```\n■fn_start\n// 1-liner chain-of-thought (CoT) as comment\nconst result = await toolCall()\nreturn { action: 'think', result }\n■fn_end\n```\n";
|
|
2
2
|
export default _default;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkJ57224PDcjs = require('./chunk-J57224PD.cjs');
|
|
4
4
|
require('./chunk-RLOPQZTQ.cjs');
|
|
5
5
|
require('./chunk-T63Y6GTW.cjs');
|
|
6
6
|
require('./chunk-KIN7Y247.cjs');
|
|
@@ -8,4 +8,4 @@ require('./chunk-WHNOR4ZU.cjs');
|
|
|
8
8
|
require('./chunk-UQOBUJIQ.cjs');
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
exports.Tool =
|
|
11
|
+
exports.Tool = _chunkJ57224PDcjs.Tool;
|
package/dist/tool.d.ts
CHANGED
|
@@ -262,7 +262,7 @@ export declare class Tool<I extends ZuiType = ZuiType, O extends ZuiType = ZuiTy
|
|
|
262
262
|
* @returns The Zui schema for input validation
|
|
263
263
|
* @internal
|
|
264
264
|
*/
|
|
265
|
-
get zInput():
|
|
265
|
+
get zInput(): ZuiType;
|
|
266
266
|
/**
|
|
267
267
|
* Gets the output schema for validation.
|
|
268
268
|
*
|
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
var _chunkFMOTPO76cjs = require('./chunk-FMOTPO76.cjs');
|
|
3
|
+
var _chunkCA7FRCZTcjs = require('./chunk-CA7FRCZT.cjs');
|
|
5
4
|
require('./chunk-T63Y6GTW.cjs');
|
|
6
5
|
require('./chunk-KIN7Y247.cjs');
|
|
7
6
|
require('./chunk-KMZDFWYZ.cjs');
|
|
8
7
|
require('./chunk-UQOBUJIQ.cjs');
|
|
9
8
|
|
|
10
9
|
|
|
11
|
-
|
|
12
|
-
exports.CAN_USE_ISOLATED_VM = _chunkFMOTPO76cjs.CAN_USE_ISOLATED_VM; exports.runAsyncFunction = _chunkFMOTPO76cjs.runAsyncFunction;
|
|
10
|
+
exports.runAsyncFunction = _chunkCA7FRCZTcjs.runAsyncFunction;
|
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
|
-
CAN_USE_ISOLATED_VM,
|
|
3
2
|
runAsyncFunction
|
|
4
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-IAYPKHFV.js";
|
|
5
4
|
import "./chunk-MYLTD5WT.js";
|
|
6
5
|
import "./chunk-YEAWWJSJ.js";
|
|
7
6
|
import "./chunk-ORQP26SZ.js";
|
|
8
7
|
import "./chunk-7WRN4E42.js";
|
|
9
8
|
export {
|
|
10
|
-
CAN_USE_ISOLATED_VM,
|
|
11
9
|
runAsyncFunction
|
|
12
10
|
};
|
package/dist/vm.d.ts
CHANGED
|
@@ -1,3 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LLMz VM Implementation
|
|
3
|
+
*
|
|
4
|
+
* Supports two execution drivers:
|
|
5
|
+
* 1. QuickJS (quickjs-emscripten) - Sandboxed execution with memory limits and timeout
|
|
6
|
+
* 2. Node (native) - Direct execution without sandbox, for environments where QuickJS is not available
|
|
7
|
+
*/
|
|
1
8
|
import { Trace, VMExecutionResult } from './types.js';
|
|
2
|
-
export declare const CAN_USE_ISOLATED_VM: boolean;
|
|
3
9
|
export declare function runAsyncFunction(context: any, code: string, traces?: Trace[], signal?: AbortSignal | null, timeout?: number): Promise<VMExecutionResult>;
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "llmz",
|
|
3
3
|
"type": "module",
|
|
4
4
|
"description": "LLMz – An LLM-native Typescript VM built on top of Zui",
|
|
5
|
-
"version": "0.0.
|
|
5
|
+
"version": "0.0.31",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
7
7
|
"main": "./dist/index.cjs",
|
|
8
8
|
"module": "./dist/index.js",
|
|
@@ -37,14 +37,15 @@
|
|
|
37
37
|
"@babel/standalone": "^7.26.4",
|
|
38
38
|
"@babel/traverse": "^7.26.4",
|
|
39
39
|
"@babel/types": "^7.26.3",
|
|
40
|
+
"@jitl/quickjs-singlefile-browser-release-sync": "^0.31.0",
|
|
40
41
|
"bytes": "^3.1.2",
|
|
41
42
|
"exponential-backoff": "^3.1.1",
|
|
42
43
|
"handlebars": "^4.7.8",
|
|
43
|
-
"isolated-vm": "^5.0.3",
|
|
44
44
|
"lodash-es": "^4.17.21",
|
|
45
45
|
"lru-cache": "^11.0.2",
|
|
46
46
|
"ms": "^2.1.3",
|
|
47
47
|
"prettier": "^3.4.2",
|
|
48
|
+
"quickjs-emscripten-core": "^0.31.0",
|
|
48
49
|
"ulid": "^2.3.0"
|
|
49
50
|
},
|
|
50
51
|
"devDependencies": {
|