experimental-agent 0.8.0-alpha.1 → 0.8.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/dist/{adapter-txsF6hou.d.mts → adapter-CFq5IeYI.d.mts} +2 -1
- package/dist/{adapter-txsF6hou.d.ts → adapter-CFq5IeYI.d.ts} +2 -1
- package/dist/chunk-5N2UOGXY.mjs +123 -0
- package/dist/chunk-HPBAZJLN.mjs +242 -0
- package/dist/chunk-HVZTAMAX.mjs +3771 -0
- package/dist/{client-BbQZtxca.d.ts → client-BY6gceox.d.ts} +5 -56
- package/dist/{client-B2ohNvwc.d.mts → client-BaItaOx5.d.mts} +5 -56
- package/dist/{entry-ok9EBUS3.d.ts → entry-BUYBv4Cu.d.ts} +1 -1
- package/dist/{entry-BUiucCNp.d.mts → entry-CRBUC5DB.d.mts} +1 -1
- package/dist/framework-DSe3sdP_.d.ts +66 -0
- package/dist/framework-VPUsYNMf.d.mts +66 -0
- package/dist/framework-runtime.d.mts +37 -0
- package/dist/framework-runtime.d.ts +37 -0
- package/dist/framework-runtime.js +5449 -0
- package/dist/framework-runtime.mjs +133 -0
- package/dist/framework.d.mts +11 -0
- package/dist/framework.d.ts +11 -0
- package/dist/framework.js +278 -0
- package/dist/framework.mjs +8 -0
- package/dist/index.d.mts +33 -10
- package/dist/index.d.ts +33 -10
- package/dist/index.js +45 -4
- package/dist/index.mjs +159 -3860
- package/dist/lifecycle-workflow-steps.d.mts +2 -2
- package/dist/lifecycle-workflow-steps.d.ts +2 -2
- package/dist/lifecycle-workflow.d.mts +2 -2
- package/dist/lifecycle-workflow.d.ts +2 -2
- package/dist/next/agents.d.mts +43 -0
- package/dist/next/agents.d.ts +43 -0
- package/dist/next/agents.js +407 -0
- package/dist/next/agents.mjs +137 -0
- package/dist/next/loader.js +19 -3
- package/dist/next/loader.mjs +1 -1
- package/dist/next.js +22 -4
- package/dist/next.mjs +5 -3
- package/dist/react.d.mts +5 -4
- package/dist/react.d.ts +5 -4
- package/dist/resolve-DCys_2es.d.ts +47 -0
- package/dist/resolve-YlI7Dugf.d.mts +47 -0
- package/dist/sandbox.d.mts +3 -3
- package/dist/sandbox.d.ts +3 -3
- package/dist/sandbox.mjs +2 -2
- package/dist/{steps-Mi3sjYbD.d.mts → steps-ChOeFWAq.d.mts} +1 -1
- package/dist/{steps-BOKeU8X3.d.ts → steps-DWTQiAPt.d.ts} +1 -1
- package/dist/storage.d.mts +2 -2
- package/dist/storage.d.ts +2 -2
- package/dist/types-B3lbsOa7.d.mts +53 -0
- package/dist/types-B3lbsOa7.d.ts +53 -0
- package/package.json +13 -13
- package/dist/chunk-CCWLV27N.mjs +0 -107
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { WORKFLOW_SERIALIZE, WORKFLOW_DESERIALIZE } from '@workflow/serde';
|
|
2
2
|
import { NetworkPolicy } from '@vercel/sandbox';
|
|
3
|
-
import { UIMessage } from 'ai';
|
|
3
|
+
import { UIMessage, JSONValue } from 'ai';
|
|
4
4
|
|
|
5
5
|
type GenerationOptions = {
|
|
6
6
|
maxSteps?: number;
|
|
@@ -11,6 +11,7 @@ type GenerationOptions = {
|
|
|
11
11
|
presencePenalty?: number;
|
|
12
12
|
maxOutputTokens?: number;
|
|
13
13
|
headers?: Record<string, string>;
|
|
14
|
+
providerOptions?: Record<string, Record<string, JSONValue>>;
|
|
14
15
|
};
|
|
15
16
|
type Session = {
|
|
16
17
|
id: string;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { WORKFLOW_SERIALIZE, WORKFLOW_DESERIALIZE } from '@workflow/serde';
|
|
2
2
|
import { NetworkPolicy } from '@vercel/sandbox';
|
|
3
|
-
import { UIMessage } from 'ai';
|
|
3
|
+
import { UIMessage, JSONValue } from 'ai';
|
|
4
4
|
|
|
5
5
|
type GenerationOptions = {
|
|
6
6
|
maxSteps?: number;
|
|
@@ -11,6 +11,7 @@ type GenerationOptions = {
|
|
|
11
11
|
presencePenalty?: number;
|
|
12
12
|
maxOutputTokens?: number;
|
|
13
13
|
headers?: Record<string, string>;
|
|
14
|
+
providerOptions?: Record<string, Record<string, JSONValue>>;
|
|
14
15
|
};
|
|
15
16
|
type Session = {
|
|
16
17
|
id: string;
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
// package.json
|
|
2
|
+
var package_default = {
|
|
3
|
+
name: "experimental-agent",
|
|
4
|
+
version: "0.8.0",
|
|
5
|
+
main: "./dist/index.js",
|
|
6
|
+
module: "./dist/index.mjs",
|
|
7
|
+
types: "./dist/index.d.ts",
|
|
8
|
+
sideEffects: true,
|
|
9
|
+
license: "MIT",
|
|
10
|
+
files: [
|
|
11
|
+
"dist/**"
|
|
12
|
+
],
|
|
13
|
+
exports: {
|
|
14
|
+
".": {
|
|
15
|
+
types: "./dist/index.d.ts",
|
|
16
|
+
import: "./dist/index.mjs",
|
|
17
|
+
require: "./dist/index.js"
|
|
18
|
+
},
|
|
19
|
+
"./storage": {
|
|
20
|
+
types: "./dist/storage.d.ts",
|
|
21
|
+
import: "./dist/storage.mjs",
|
|
22
|
+
require: "./dist/storage.js"
|
|
23
|
+
},
|
|
24
|
+
"./sandbox": {
|
|
25
|
+
types: "./dist/sandbox.d.ts",
|
|
26
|
+
import: "./dist/sandbox.mjs",
|
|
27
|
+
require: "./dist/sandbox.js"
|
|
28
|
+
},
|
|
29
|
+
"./next": {
|
|
30
|
+
types: "./dist/next.d.ts",
|
|
31
|
+
import: "./dist/next.mjs",
|
|
32
|
+
require: "./dist/next.js"
|
|
33
|
+
},
|
|
34
|
+
"./next/loader": {
|
|
35
|
+
types: "./dist/next/loader.d.ts",
|
|
36
|
+
import: "./dist/next/loader.mjs",
|
|
37
|
+
require: "./dist/next/loader.js"
|
|
38
|
+
},
|
|
39
|
+
"./next/agents": {
|
|
40
|
+
types: "./dist/next/agents.d.ts",
|
|
41
|
+
import: "./dist/next/agents.mjs",
|
|
42
|
+
require: "./dist/next/agents.js"
|
|
43
|
+
},
|
|
44
|
+
"./framework": {
|
|
45
|
+
types: "./dist/framework.d.ts",
|
|
46
|
+
import: "./dist/framework.mjs",
|
|
47
|
+
require: "./dist/framework.js"
|
|
48
|
+
},
|
|
49
|
+
"./framework-runtime": {
|
|
50
|
+
types: "./dist/framework-runtime.d.ts",
|
|
51
|
+
import: "./dist/framework-runtime.mjs",
|
|
52
|
+
require: "./dist/framework-runtime.js"
|
|
53
|
+
},
|
|
54
|
+
"./client": {
|
|
55
|
+
types: "./dist/client.d.ts",
|
|
56
|
+
import: "./dist/client.mjs",
|
|
57
|
+
require: "./dist/client.js"
|
|
58
|
+
},
|
|
59
|
+
"./lifecycle-workflow": {
|
|
60
|
+
types: "./dist/lifecycle-workflow.d.ts",
|
|
61
|
+
import: "./dist/lifecycle-workflow.mjs",
|
|
62
|
+
require: "./dist/lifecycle-workflow.js"
|
|
63
|
+
},
|
|
64
|
+
"./lifecycle-workflow-steps": {
|
|
65
|
+
types: "./dist/lifecycle-workflow-steps.d.ts",
|
|
66
|
+
import: "./dist/lifecycle-workflow-steps.mjs",
|
|
67
|
+
require: "./dist/lifecycle-workflow-steps.js"
|
|
68
|
+
},
|
|
69
|
+
"./react": {
|
|
70
|
+
types: "./dist/react.d.ts",
|
|
71
|
+
import: "./dist/react.mjs",
|
|
72
|
+
require: "./dist/react.js"
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
scripts: {
|
|
76
|
+
build: "tsup",
|
|
77
|
+
dev: "tsup --watch",
|
|
78
|
+
clean: "rm -rf .turbo && rm -rf node_modules && rm -rf dist",
|
|
79
|
+
release: "pnpm build && npm publish",
|
|
80
|
+
typecheck: "tsc --noEmit",
|
|
81
|
+
test: "vitest run",
|
|
82
|
+
"test:watch": "vitest"
|
|
83
|
+
},
|
|
84
|
+
dependencies: {
|
|
85
|
+
"@elysiajs/openapi": "^1.4.14",
|
|
86
|
+
"@swc/core": "^1.10.0",
|
|
87
|
+
"@tanstack/react-query": "^5.90.21",
|
|
88
|
+
"@vercel/kv2": "^0.0.18",
|
|
89
|
+
"@vercel/oidc": "^3.1.0",
|
|
90
|
+
"@vercel/sandbox": "1.7.1",
|
|
91
|
+
"@workflow/serde": "4.1.0-beta.2",
|
|
92
|
+
"better-all": "^0.0.5",
|
|
93
|
+
elysia: "^1.4.25",
|
|
94
|
+
errore: "^0.14.0",
|
|
95
|
+
"fast-deep-equal": "^3.1.3",
|
|
96
|
+
ulid: "^3.0.2",
|
|
97
|
+
zod: "^4.3.6"
|
|
98
|
+
},
|
|
99
|
+
devDependencies: {
|
|
100
|
+
"@agent/tsconfig": "workspace:*",
|
|
101
|
+
"@ai-sdk/react": "^3.0.88",
|
|
102
|
+
"@types/node": "^20.11.24",
|
|
103
|
+
"@types/react": "^19.2.14",
|
|
104
|
+
dotenv: "^17.2.3",
|
|
105
|
+
next: "^16.0.0",
|
|
106
|
+
react: "^19.2.4",
|
|
107
|
+
tsup: "^8.0.2",
|
|
108
|
+
typescript: "5.5.4",
|
|
109
|
+
vitest: "^3.0.0",
|
|
110
|
+
workflow: "4.2.0-beta.70"
|
|
111
|
+
},
|
|
112
|
+
peerDependencies: {
|
|
113
|
+
ai: "^6.0.0"
|
|
114
|
+
},
|
|
115
|
+
publishConfig: {
|
|
116
|
+
access: "public"
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
export {
|
|
121
|
+
package_default
|
|
122
|
+
};
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vcGFja2FnZS5qc29uIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ7XG4gIFwibmFtZVwiOiBcImV4cGVyaW1lbnRhbC1hZ2VudFwiLFxuICBcInZlcnNpb25cIjogXCIwLjguMFwiLFxuICBcIm1haW5cIjogXCIuL2Rpc3QvaW5kZXguanNcIixcbiAgXCJtb2R1bGVcIjogXCIuL2Rpc3QvaW5kZXgubWpzXCIsXG4gIFwidHlwZXNcIjogXCIuL2Rpc3QvaW5kZXguZC50c1wiLFxuICBcInNpZGVFZmZlY3RzXCI6IHRydWUsXG4gIFwibGljZW5zZVwiOiBcIk1JVFwiLFxuICBcImZpbGVzXCI6IFtcbiAgICBcImRpc3QvKipcIlxuICBdLFxuICBcImV4cG9ydHNcIjoge1xuICAgIFwiLlwiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L2luZGV4LmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L2luZGV4Lm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L2luZGV4LmpzXCJcbiAgICB9LFxuICAgIFwiLi9zdG9yYWdlXCI6IHtcbiAgICAgIFwidHlwZXNcIjogXCIuL2Rpc3Qvc3RvcmFnZS5kLnRzXCIsXG4gICAgICBcImltcG9ydFwiOiBcIi4vZGlzdC9zdG9yYWdlLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L3N0b3JhZ2UuanNcIlxuICAgIH0sXG4gICAgXCIuL3NhbmRib3hcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9zYW5kYm94LmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L3NhbmRib3gubWpzXCIsXG4gICAgICBcInJlcXVpcmVcIjogXCIuL2Rpc3Qvc2FuZGJveC5qc1wiXG4gICAgfSxcbiAgICBcIi4vbmV4dFwiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L25leHQuZC50c1wiLFxuICAgICAgXCJpbXBvcnRcIjogXCIuL2Rpc3QvbmV4dC5tanNcIixcbiAgICAgIFwicmVxdWlyZVwiOiBcIi4vZGlzdC9uZXh0LmpzXCJcbiAgICB9LFxuICAgIFwiLi9uZXh0L2xvYWRlclwiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L25leHQvbG9hZGVyLmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L25leHQvbG9hZGVyLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L25leHQvbG9hZGVyLmpzXCJcbiAgICB9LFxuICAgIFwiLi9uZXh0L2FnZW50c1wiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L25leHQvYWdlbnRzLmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L25leHQvYWdlbnRzLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L25leHQvYWdlbnRzLmpzXCJcbiAgICB9LFxuICAgIFwiLi9mcmFtZXdvcmtcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9mcmFtZXdvcmsuZC50c1wiLFxuICAgICAgXCJpbXBvcnRcIjogXCIuL2Rpc3QvZnJhbWV3b3JrLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L2ZyYW1ld29yay5qc1wiXG4gICAgfSxcbiAgICBcIi4vZnJhbWV3b3JrLXJ1bnRpbWVcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9mcmFtZXdvcmstcnVudGltZS5kLnRzXCIsXG4gICAgICBcImltcG9ydFwiOiBcIi4vZGlzdC9mcmFtZXdvcmstcnVudGltZS5tanNcIixcbiAgICAgIFwicmVxdWlyZVwiOiBcIi4vZGlzdC9mcmFtZXdvcmstcnVudGltZS5qc1wiXG4gICAgfSxcbiAgICBcIi4vY2xpZW50XCI6IHtcbiAgICAgIFwidHlwZXNcIjogXCIuL2Rpc3QvY2xpZW50LmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L2NsaWVudC5tanNcIixcbiAgICAgIFwicmVxdWlyZVwiOiBcIi4vZGlzdC9jbGllbnQuanNcIlxuICAgIH0sXG4gICAgXCIuL2xpZmVjeWNsZS13b3JrZmxvd1wiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L2xpZmVjeWNsZS13b3JrZmxvdy5kLnRzXCIsXG4gICAgICBcImltcG9ydFwiOiBcIi4vZGlzdC9saWZlY3ljbGUtd29ya2Zsb3cubWpzXCIsXG4gICAgICBcInJlcXVpcmVcIjogXCIuL2Rpc3QvbGlmZWN5Y2xlLXdvcmtmbG93LmpzXCJcbiAgICB9LFxuICAgIFwiLi9saWZlY3ljbGUtd29ya2Zsb3ctc3RlcHNcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9saWZlY3ljbGUtd29ya2Zsb3ctc3RlcHMuZC50c1wiLFxuICAgICAgXCJpbXBvcnRcIjogXCIuL2Rpc3QvbGlmZWN5Y2xlLXdvcmtmbG93LXN0ZXBzLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L2xpZmVjeWNsZS13b3JrZmxvdy1zdGVwcy5qc1wiXG4gICAgfSxcbiAgICBcIi4vcmVhY3RcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9yZWFjdC5kLnRzXCIsXG4gICAgICBcImltcG9ydFwiOiBcIi4vZGlzdC9yZWFjdC5tanNcIixcbiAgICAgIFwicmVxdWlyZVwiOiBcIi4vZGlzdC9yZWFjdC5qc1wiXG4gICAgfVxuICB9LFxuICBcInNjcmlwdHNcIjoge1xuICAgIFwiYnVpbGRcIjogXCJ0c3VwXCIsXG4gICAgXCJkZXZcIjogXCJ0c3VwIC0td2F0Y2hcIixcbiAgICBcImNsZWFuXCI6IFwicm0gLXJmIC50dXJibyAmJiBybSAtcmYgbm9kZV9tb2R1bGVzICYmIHJtIC1yZiBkaXN0XCIsXG4gICAgXCJyZWxlYXNlXCI6IFwicG5wbSBidWlsZCAmJiBucG0gcHVibGlzaFwiLFxuICAgIFwidHlwZWNoZWNrXCI6IFwidHNjIC0tbm9FbWl0XCIsXG4gICAgXCJ0ZXN0XCI6IFwidml0ZXN0IHJ1blwiLFxuICAgIFwidGVzdDp3YXRjaFwiOiBcInZpdGVzdFwiXG4gIH0sXG4gIFwiZGVwZW5kZW5jaWVzXCI6IHtcbiAgICBcIkBlbHlzaWFqcy9vcGVuYXBpXCI6IFwiXjEuNC4xNFwiLFxuICAgIFwiQHN3Yy9jb3JlXCI6IFwiXjEuMTAuMFwiLFxuICAgIFwiQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5XCI6IFwiXjUuOTAuMjFcIixcbiAgICBcIkB2ZXJjZWwva3YyXCI6IFwiXjAuMC4xOFwiLFxuICAgIFwiQHZlcmNlbC9vaWRjXCI6IFwiXjMuMS4wXCIsXG4gICAgXCJAdmVyY2VsL3NhbmRib3hcIjogXCIxLjcuMVwiLFxuICAgIFwiQHdvcmtmbG93L3NlcmRlXCI6IFwiNC4xLjAtYmV0YS4yXCIsXG4gICAgXCJiZXR0ZXItYWxsXCI6IFwiXjAuMC41XCIsXG4gICAgXCJlbHlzaWFcIjogXCJeMS40LjI1XCIsXG4gICAgXCJlcnJvcmVcIjogXCJeMC4xNC4wXCIsXG4gICAgXCJmYXN0LWRlZXAtZXF1YWxcIjogXCJeMy4xLjNcIixcbiAgICBcInVsaWRcIjogXCJeMy4wLjJcIixcbiAgICBcInpvZFwiOiBcIl40LjMuNlwiXG4gIH0sXG4gIFwiZGV2RGVwZW5kZW5jaWVzXCI6IHtcbiAgICBcIkBhZ2VudC90c2NvbmZpZ1wiOiBcIndvcmtzcGFjZToqXCIsXG4gICAgXCJAYWktc2RrL3JlYWN0XCI6IFwiXjMuMC44OFwiLFxuICAgIFwiQHR5cGVzL25vZGVcIjogXCJeMjAuMTEuMjRcIixcbiAgICBcIkB0eXBlcy9yZWFjdFwiOiBcIl4xOS4yLjE0XCIsXG4gICAgXCJkb3RlbnZcIjogXCJeMTcuMi4zXCIsXG4gICAgXCJuZXh0XCI6IFwiXjE2LjAuMFwiLFxuICAgIFwicmVhY3RcIjogXCJeMTkuMi40XCIsXG4gICAgXCJ0c3VwXCI6IFwiXjguMC4yXCIsXG4gICAgXCJ0eXBlc2NyaXB0XCI6IFwiNS41LjRcIixcbiAgICBcInZpdGVzdFwiOiBcIl4zLjAuMFwiLFxuICAgIFwid29ya2Zsb3dcIjogXCI0LjIuMC1iZXRhLjcwXCJcbiAgfSxcbiAgXCJwZWVyRGVwZW5kZW5jaWVzXCI6IHtcbiAgICBcImFpXCI6IFwiXjYuMC4wXCJcbiAgfSxcbiAgXCJwdWJsaXNoQ29uZmlnXCI6IHtcbiAgICBcImFjY2Vzc1wiOiBcInB1YmxpY1wiXG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7QUFBQTtBQUFBLEVBQ0UsTUFBUTtBQUFBLEVBQ1IsU0FBVztBQUFBLEVBQ1gsTUFBUTtBQUFBLEVBQ1IsUUFBVTtBQUFBLEVBQ1YsT0FBUztBQUFBLEVBQ1QsYUFBZTtBQUFBLEVBQ2YsU0FBVztBQUFBLEVBQ1gsT0FBUztBQUFBLElBQ1A7QUFBQSxFQUNGO0FBQUEsRUFDQSxTQUFXO0FBQUEsSUFDVCxLQUFLO0FBQUEsTUFDSCxPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0EsYUFBYTtBQUFBLE1BQ1gsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxJQUNBLGFBQWE7QUFBQSxNQUNYLE9BQVM7QUFBQSxNQUNULFFBQVU7QUFBQSxNQUNWLFNBQVc7QUFBQSxJQUNiO0FBQUEsSUFDQSxVQUFVO0FBQUEsTUFDUixPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0EsaUJBQWlCO0FBQUEsTUFDZixPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0EsaUJBQWlCO0FBQUEsTUFDZixPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0EsZUFBZTtBQUFBLE1BQ2IsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxJQUNBLHVCQUF1QjtBQUFBLE1BQ3JCLE9BQVM7QUFBQSxNQUNULFFBQVU7QUFBQSxNQUNWLFNBQVc7QUFBQSxJQUNiO0FBQUEsSUFDQSxZQUFZO0FBQUEsTUFDVixPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0Esd0JBQXdCO0FBQUEsTUFDdEIsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxJQUNBLDhCQUE4QjtBQUFBLE1BQzVCLE9BQVM7QUFBQSxNQUNULFFBQVU7QUFBQSxNQUNWLFNBQVc7QUFBQSxJQUNiO0FBQUEsSUFDQSxXQUFXO0FBQUEsTUFDVCxPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLEVBQ0Y7QUFBQSxFQUNBLFNBQVc7QUFBQSxJQUNULE9BQVM7QUFBQSxJQUNULEtBQU87QUFBQSxJQUNQLE9BQVM7QUFBQSxJQUNULFNBQVc7QUFBQSxJQUNYLFdBQWE7QUFBQSxJQUNiLE1BQVE7QUFBQSxJQUNSLGNBQWM7QUFBQSxFQUNoQjtBQUFBLEVBQ0EsY0FBZ0I7QUFBQSxJQUNkLHFCQUFxQjtBQUFBLElBQ3JCLGFBQWE7QUFBQSxJQUNiLHlCQUF5QjtBQUFBLElBQ3pCLGVBQWU7QUFBQSxJQUNmLGdCQUFnQjtBQUFBLElBQ2hCLG1CQUFtQjtBQUFBLElBQ25CLG1CQUFtQjtBQUFBLElBQ25CLGNBQWM7QUFBQSxJQUNkLFFBQVU7QUFBQSxJQUNWLFFBQVU7QUFBQSxJQUNWLG1CQUFtQjtBQUFBLElBQ25CLE1BQVE7QUFBQSxJQUNSLEtBQU87QUFBQSxFQUNUO0FBQUEsRUFDQSxpQkFBbUI7QUFBQSxJQUNqQixtQkFBbUI7QUFBQSxJQUNuQixpQkFBaUI7QUFBQSxJQUNqQixlQUFlO0FBQUEsSUFDZixnQkFBZ0I7QUFBQSxJQUNoQixRQUFVO0FBQUEsSUFDVixNQUFRO0FBQUEsSUFDUixPQUFTO0FBQUEsSUFDVCxNQUFRO0FBQUEsSUFDUixZQUFjO0FBQUEsSUFDZCxRQUFVO0FBQUEsSUFDVixVQUFZO0FBQUEsRUFDZDtBQUFBLEVBQ0Esa0JBQW9CO0FBQUEsSUFDbEIsSUFBTTtBQUFBLEVBQ1I7QUFBQSxFQUNBLGVBQWlCO0FBQUEsSUFDZixRQUFVO0FBQUEsRUFDWjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
// src/framework/generate.ts
|
|
2
|
+
import * as fs from "fs";
|
|
3
|
+
import * as path from "path";
|
|
4
|
+
var TS_IMPORT_EXT = /\.(ts|mts)$/;
|
|
5
|
+
function generateRegistry(opts) {
|
|
6
|
+
const entries = opts.agents.map(
|
|
7
|
+
(agent) => inlineEntry({ agent, outputDir: opts.outputDir })
|
|
8
|
+
);
|
|
9
|
+
return [
|
|
10
|
+
"// Auto-generated by withAgents - do not edit",
|
|
11
|
+
'import type { AgentRegistry } from "experimental-agent/framework";',
|
|
12
|
+
"",
|
|
13
|
+
"export const agents = {",
|
|
14
|
+
...entries,
|
|
15
|
+
"} satisfies AgentRegistry;",
|
|
16
|
+
""
|
|
17
|
+
].join("\n");
|
|
18
|
+
}
|
|
19
|
+
function inlineEntry(opts) {
|
|
20
|
+
const config = buildConfig(opts.agent);
|
|
21
|
+
const configStr = JSON.stringify(config, null, 2).split("\n").map((line, i) => i === 0 ? line : ` ${line}`).join("\n");
|
|
22
|
+
const parts = [` config: ${configStr}`];
|
|
23
|
+
if (opts.agent.hasAgentConfig) {
|
|
24
|
+
const configPath = findAgentConfigPath(opts.agent.absolutePath);
|
|
25
|
+
const relativePath = relativeImportPath({
|
|
26
|
+
from: opts.outputDir,
|
|
27
|
+
to: configPath
|
|
28
|
+
});
|
|
29
|
+
parts.push(` import: () => import(${JSON.stringify(relativePath)})`);
|
|
30
|
+
}
|
|
31
|
+
if (opts.agent.tools.length > 0) {
|
|
32
|
+
const toolLines = opts.agent.tools.map((tool) => {
|
|
33
|
+
const rel = relativeImportPath({
|
|
34
|
+
from: opts.outputDir,
|
|
35
|
+
to: tool.importPath
|
|
36
|
+
});
|
|
37
|
+
return ` ${JSON.stringify(tool.name)}: () => import(${JSON.stringify(rel)})`;
|
|
38
|
+
});
|
|
39
|
+
parts.push(` imports: {
|
|
40
|
+
tools: {
|
|
41
|
+
${toolLines.join(",\n")}
|
|
42
|
+
}
|
|
43
|
+
}`);
|
|
44
|
+
}
|
|
45
|
+
return ` ${JSON.stringify(opts.agent.name)}: {
|
|
46
|
+
${parts.join(",\n")}
|
|
47
|
+
},`;
|
|
48
|
+
}
|
|
49
|
+
function buildConfig(agent) {
|
|
50
|
+
const config = {};
|
|
51
|
+
if (agent.systemPrompt) {
|
|
52
|
+
config.system = agent.systemPrompt;
|
|
53
|
+
}
|
|
54
|
+
if (agent.skills.length > 0) {
|
|
55
|
+
config.skills = agent.skills;
|
|
56
|
+
}
|
|
57
|
+
return config;
|
|
58
|
+
}
|
|
59
|
+
function findAgentConfigPath(agentDir) {
|
|
60
|
+
const extensions = [".ts", ".js", ".mts", ".mjs"];
|
|
61
|
+
for (const ext of extensions) {
|
|
62
|
+
const candidate = path.join(agentDir, `agent${ext}`);
|
|
63
|
+
if (fs.existsSync(candidate)) {
|
|
64
|
+
return candidate;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return path.join(agentDir, "agent");
|
|
68
|
+
}
|
|
69
|
+
function relativeImportPath(opts) {
|
|
70
|
+
let rel = path.relative(opts.from, opts.to).replace(/\\/g, "/");
|
|
71
|
+
rel = rel.replace(TS_IMPORT_EXT, "");
|
|
72
|
+
if (!rel.startsWith(".")) {
|
|
73
|
+
rel = `./${rel}`;
|
|
74
|
+
}
|
|
75
|
+
return rel;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// src/framework/scan.ts
|
|
79
|
+
import * as fs2 from "fs";
|
|
80
|
+
import * as path2 from "path";
|
|
81
|
+
var AGENT_CONFIG_FILES = ["agent.ts", "agent.js", "agent.mts", "agent.mjs"];
|
|
82
|
+
var MD_EXT = /\.md$/;
|
|
83
|
+
var TS_EXT = /\.(ts|js|mts|mjs)$/;
|
|
84
|
+
function listDir(dir) {
|
|
85
|
+
if (!fs2.existsSync(dir)) {
|
|
86
|
+
return [];
|
|
87
|
+
}
|
|
88
|
+
return fs2.readdirSync(dir);
|
|
89
|
+
}
|
|
90
|
+
function readFile(filePath) {
|
|
91
|
+
return fs2.readFileSync(filePath, "utf-8");
|
|
92
|
+
}
|
|
93
|
+
function fileExists(filePath) {
|
|
94
|
+
return fs2.existsSync(filePath);
|
|
95
|
+
}
|
|
96
|
+
function isDirectory(filePath) {
|
|
97
|
+
return fs2.existsSync(filePath) && fs2.statSync(filePath).isDirectory();
|
|
98
|
+
}
|
|
99
|
+
function discoverAgentDirs(agentsRoot) {
|
|
100
|
+
const entries = listDir(agentsRoot);
|
|
101
|
+
const dirs = [];
|
|
102
|
+
for (const entry of entries) {
|
|
103
|
+
const absolutePath = path2.join(agentsRoot, entry);
|
|
104
|
+
if (!isDirectory(absolutePath)) {
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
if (entry.startsWith(".")) {
|
|
108
|
+
continue;
|
|
109
|
+
}
|
|
110
|
+
dirs.push({
|
|
111
|
+
name: entry,
|
|
112
|
+
absolutePath,
|
|
113
|
+
hasAgentConfig: hasAgentConfig(absolutePath)
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
return dirs;
|
|
117
|
+
}
|
|
118
|
+
function hasAgentConfig(agentDir) {
|
|
119
|
+
return AGENT_CONFIG_FILES.some((f) => fileExists(path2.join(agentDir, f)));
|
|
120
|
+
}
|
|
121
|
+
function getSkills(agentDir) {
|
|
122
|
+
const skillsDir = path2.join(agentDir, "skills");
|
|
123
|
+
const entries = listDir(skillsDir);
|
|
124
|
+
const skills = [];
|
|
125
|
+
const tsSkillImportPaths = [];
|
|
126
|
+
for (const entry of entries.sort()) {
|
|
127
|
+
const absolutePath = path2.join(skillsDir, entry);
|
|
128
|
+
if (MD_EXT.test(entry)) {
|
|
129
|
+
skills.push({
|
|
130
|
+
type: "host",
|
|
131
|
+
path: absolutePath
|
|
132
|
+
});
|
|
133
|
+
} else if (TS_EXT.test(entry)) {
|
|
134
|
+
tsSkillImportPaths.push(absolutePath);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
return { skills, tsSkillImportPaths };
|
|
138
|
+
}
|
|
139
|
+
function getSystemPrompt(agentDir) {
|
|
140
|
+
const systemDir = path2.join(agentDir, "system");
|
|
141
|
+
const entries = listDir(systemDir);
|
|
142
|
+
const mdFiles = entries.filter((e) => MD_EXT.test(e)).sort();
|
|
143
|
+
if (mdFiles.length === 0) {
|
|
144
|
+
return void 0;
|
|
145
|
+
}
|
|
146
|
+
const parts = [];
|
|
147
|
+
for (const file of mdFiles) {
|
|
148
|
+
const content = readFile(path2.join(systemDir, file)).trim();
|
|
149
|
+
if (content) {
|
|
150
|
+
parts.push(content);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
return parts.length > 0 ? parts.join("\n\n") : void 0;
|
|
154
|
+
}
|
|
155
|
+
function getTools(agentDir) {
|
|
156
|
+
const toolsDir = path2.join(agentDir, "tools");
|
|
157
|
+
const entries = listDir(toolsDir);
|
|
158
|
+
const tools = [];
|
|
159
|
+
for (const entry of entries.sort()) {
|
|
160
|
+
const absolutePath = path2.join(toolsDir, entry);
|
|
161
|
+
if (isDirectory(absolutePath)) {
|
|
162
|
+
const indexFile = findIndexFile(absolutePath);
|
|
163
|
+
if (indexFile) {
|
|
164
|
+
tools.push({ name: entry, importPath: indexFile });
|
|
165
|
+
}
|
|
166
|
+
} else if (TS_EXT.test(entry)) {
|
|
167
|
+
const name = entry.replace(TS_EXT, "");
|
|
168
|
+
tools.push({ name, importPath: absolutePath });
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
return tools;
|
|
172
|
+
}
|
|
173
|
+
function findIndexFile(dir) {
|
|
174
|
+
const extensions = [".ts", ".js", ".mts", ".mjs"];
|
|
175
|
+
for (const ext of extensions) {
|
|
176
|
+
const candidate = path2.join(dir, `index${ext}`);
|
|
177
|
+
if (fileExists(candidate)) {
|
|
178
|
+
return candidate;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
return null;
|
|
182
|
+
}
|
|
183
|
+
function scanAgent(agentDir) {
|
|
184
|
+
const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);
|
|
185
|
+
const systemPrompt = getSystemPrompt(agentDir.absolutePath);
|
|
186
|
+
const tools = getTools(agentDir.absolutePath);
|
|
187
|
+
return { ...agentDir, skills, systemPrompt, tsSkillImportPaths, tools };
|
|
188
|
+
}
|
|
189
|
+
function findAgentsRoot(cwd, userDefinedAgentsDir) {
|
|
190
|
+
if (userDefinedAgentsDir) {
|
|
191
|
+
return path2.resolve(cwd, userDefinedAgentsDir);
|
|
192
|
+
}
|
|
193
|
+
const candidates = [
|
|
194
|
+
path2.join(cwd, "src", "agents"),
|
|
195
|
+
path2.join(cwd, "agents")
|
|
196
|
+
];
|
|
197
|
+
for (const candidate of candidates) {
|
|
198
|
+
if (isDirectory(candidate)) {
|
|
199
|
+
return candidate;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
return null;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
// src/framework/framework.ts
|
|
206
|
+
var Framework = class {
|
|
207
|
+
cwd;
|
|
208
|
+
agentsDir;
|
|
209
|
+
log;
|
|
210
|
+
constructor(opts) {
|
|
211
|
+
this.cwd = opts.cwd ?? process.cwd();
|
|
212
|
+
this.agentsDir = opts.agentsDir;
|
|
213
|
+
this.log = opts.debug ? console.log.bind(console, "[Framework]") : () => void 0;
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Scan the agents directory and return metadata for every agent found.
|
|
217
|
+
* Each subfolder inside the agents directory becomes one agent.
|
|
218
|
+
* Returns an empty array when no agents directory exists.
|
|
219
|
+
*/
|
|
220
|
+
discoverAgents() {
|
|
221
|
+
const root = findAgentsRoot(this.cwd, this.agentsDir);
|
|
222
|
+
if (!root) {
|
|
223
|
+
return [];
|
|
224
|
+
}
|
|
225
|
+
const dirs = discoverAgentDirs(root);
|
|
226
|
+
return dirs.map(scanAgent);
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Generate the TypeScript source for an agent registry module.
|
|
230
|
+
*
|
|
231
|
+
* @param opts.agents - Scanned agents to include in the registry.
|
|
232
|
+
* @param opts.outputDir - Directory where the registry file will be written
|
|
233
|
+
* (used to compute relative import paths to each agent's config module).
|
|
234
|
+
* @returns The full source text of the generated `_registry.ts` file.
|
|
235
|
+
*/
|
|
236
|
+
generateRegistrySource = generateRegistry;
|
|
237
|
+
};
|
|
238
|
+
|
|
239
|
+
export {
|
|
240
|
+
Framework
|
|
241
|
+
};
|
|
242
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/framework/generate.ts", "../src/framework/scan.ts", "../src/framework/framework.ts"],
  "sourcesContent": ["import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { ScannedAgent } from \"./scan\";\n\nconst TS_IMPORT_EXT = /\\.(ts|mts)$/;\nexport function generateRegistry(opts: {\n  agents: ScannedAgent[];\n  outputDir: string;\n}): string {\n  const entries = opts.agents.map((agent) =>\n    inlineEntry({ agent, outputDir: opts.outputDir })\n  );\n\n  return [\n    \"// Auto-generated by withAgents - do not edit\",\n    'import type { AgentRegistry } from \"experimental-agent/framework\";',\n    \"\",\n    \"export const agents = {\",\n    ...entries,\n    \"} satisfies AgentRegistry;\",\n    \"\",\n  ].join(\"\\n\");\n}\n\nfunction inlineEntry(opts: {\n  agent: ScannedAgent;\n  outputDir: string;\n}): string {\n  const config = buildConfig(opts.agent);\n  const configStr = JSON.stringify(config, null, 2)\n    .split(\"\\n\")\n    .map((line, i) => (i === 0 ? line : `      ${line}`))\n    .join(\"\\n\");\n\n  const parts = [`    config: ${configStr}`];\n\n  if (opts.agent.hasAgentConfig) {\n    const configPath = findAgentConfigPath(opts.agent.absolutePath);\n    const relativePath = relativeImportPath({\n      from: opts.outputDir,\n      to: configPath,\n    });\n    parts.push(`    import: () => import(${JSON.stringify(relativePath)})`);\n  }\n\n  if (opts.agent.tools.length > 0) {\n    const toolLines = opts.agent.tools.map((tool) => {\n      const rel = relativeImportPath({\n        from: opts.outputDir,\n        to: tool.importPath,\n      });\n      return `        ${JSON.stringify(tool.name)}: () => import(${JSON.stringify(rel)})`;\n    });\n    parts.push(`    imports: {\\n      tools: {\\n${toolLines.join(\",\\n\")}\\n      }\\n    }`);\n  }\n\n  return `  ${JSON.stringify(opts.agent.name)}: {\\n${parts.join(\",\\n\")}\\n  },`;\n}\n\nfunction buildConfig(agent: ScannedAgent): Record<string, unknown> {\n  const config: Record<string, unknown> = {};\n\n  if (agent.systemPrompt) {\n    config.system = agent.systemPrompt;\n  }\n\n  if (agent.skills.length > 0) {\n    config.skills = agent.skills;\n  }\n\n  return config;\n}\n\nfunction findAgentConfigPath(agentDir: string): string {\n  const extensions = [\".ts\", \".js\", \".mts\", \".mjs\"];\n  for (const ext of extensions) {\n    const candidate = path.join(agentDir, `agent${ext}`);\n    if (fs.existsSync(candidate)) {\n      return candidate;\n    }\n  }\n  return path.join(agentDir, \"agent\");\n}\n\nfunction relativeImportPath(opts: { from: string; to: string }): string {\n  let rel = path.relative(opts.from, opts.to).replace(/\\\\/g, \"/\");\n  rel = rel.replace(TS_IMPORT_EXT, \"\");\n  if (!rel.startsWith(\".\")) {\n    rel = `./${rel}`;\n  }\n  return rel;\n}\n\n", "import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport type { HostSkillInput, SkillInput } from \"../skills/types\";\n\nexport type AgentDir = {\n  name: string;\n  absolutePath: string;\n  hasAgentConfig: boolean;\n};\n\nexport type ScannedTool = {\n  name: string;\n  importPath: string;\n};\n\nexport type ScannedAgent = AgentDir & {\n  skills: SkillInput[];\n  systemPrompt: string | undefined;\n  tsSkillImportPaths: string[];\n  tools: ScannedTool[];\n};\n\nconst AGENT_CONFIG_FILES = [\"agent.ts\", \"agent.js\", \"agent.mts\", \"agent.mjs\"];\nconst MD_EXT = /\\.md$/;\nconst TS_EXT = /\\.(ts|js|mts|mjs)$/;\n\nexport function listDir(dir: string): string[] {\n  if (!fs.existsSync(dir)) {\n    return [];\n  }\n  return fs.readdirSync(dir);\n}\n\nexport function readFile(filePath: string): string {\n  return fs.readFileSync(filePath, \"utf-8\");\n}\n\nexport function fileExists(filePath: string): boolean {\n  return fs.existsSync(filePath);\n}\n\nexport function isDirectory(filePath: string): boolean {\n  return fs.existsSync(filePath) && fs.statSync(filePath).isDirectory();\n}\n\nexport function discoverAgentDirs(agentsRoot: string): AgentDir[] {\n  const entries = listDir(agentsRoot);\n  const dirs: AgentDir[] = [];\n\n  for (const entry of entries) {\n    const absolutePath = path.join(agentsRoot, entry);\n    if (!isDirectory(absolutePath)) {\n      continue;\n    }\n    if (entry.startsWith(\".\")) {\n      continue;\n    }\n\n    dirs.push({\n      name: entry,\n      absolutePath,\n      hasAgentConfig: hasAgentConfig(absolutePath),\n    });\n  }\n\n  return dirs;\n}\n\nexport function hasAgentConfig(agentDir: string): boolean {\n  return AGENT_CONFIG_FILES.some((f) => fileExists(path.join(agentDir, f)));\n}\n\nexport function getSkills(agentDir: string): {\n  skills: SkillInput[];\n  tsSkillImportPaths: string[];\n} {\n  const skillsDir = path.join(agentDir, \"skills\");\n  const entries = listDir(skillsDir);\n  const skills: SkillInput[] = [];\n  const tsSkillImportPaths: string[] = [];\n\n  for (const entry of entries.sort()) {\n    const absolutePath = path.join(skillsDir, entry);\n\n    if (MD_EXT.test(entry)) {\n      skills.push({\n        type: \"host\",\n        path: absolutePath,\n      } satisfies HostSkillInput);\n    } else if (TS_EXT.test(entry)) {\n      tsSkillImportPaths.push(absolutePath);\n    }\n  }\n\n  return { skills, tsSkillImportPaths };\n}\n\nexport function getSystemPrompt(agentDir: string): string | undefined {\n  const systemDir = path.join(agentDir, \"system\");\n  const entries = listDir(systemDir);\n  const mdFiles = entries.filter((e) => MD_EXT.test(e)).sort();\n\n  if (mdFiles.length === 0) {\n    return undefined;\n  }\n\n  const parts: string[] = [];\n  for (const file of mdFiles) {\n    const content = readFile(path.join(systemDir, file)).trim();\n    if (content) {\n      parts.push(content);\n    }\n  }\n\n  return parts.length > 0 ? parts.join(\"\\n\\n\") : undefined;\n}\n\nexport function getTools(agentDir: string): ScannedTool[] {\n  const toolsDir = path.join(agentDir, \"tools\");\n  const entries = listDir(toolsDir);\n  const tools: ScannedTool[] = [];\n\n  for (const entry of entries.sort()) {\n    const absolutePath = path.join(toolsDir, entry);\n\n    if (isDirectory(absolutePath)) {\n      const indexFile = findIndexFile(absolutePath);\n      if (indexFile) {\n        tools.push({ name: entry, importPath: indexFile });\n      }\n    } else if (TS_EXT.test(entry)) {\n      const name = entry.replace(TS_EXT, \"\");\n      tools.push({ name, importPath: absolutePath });\n    }\n  }\n\n  return tools;\n}\n\nfunction findIndexFile(dir: string): string | null {\n  const extensions = [\".ts\", \".js\", \".mts\", \".mjs\"];\n  for (const ext of extensions) {\n    const candidate = path.join(dir, `index${ext}`);\n    if (fileExists(candidate)) {\n      return candidate;\n    }\n  }\n  return null;\n}\n\nexport function scanAgent(agentDir: AgentDir): ScannedAgent {\n  const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);\n  const systemPrompt = getSystemPrompt(agentDir.absolutePath);\n  const tools = getTools(agentDir.absolutePath);\n\n  return { ...agentDir, skills, systemPrompt, tsSkillImportPaths, tools };\n}\n\nexport function findAgentsRoot(\n  cwd: string,\n  userDefinedAgentsDir: string | undefined\n): string | null {\n  if (userDefinedAgentsDir) {\n    return path.resolve(cwd, userDefinedAgentsDir);\n  }\n  const candidates = [\n    path.join(cwd, \"src\", \"agents\"),\n    path.join(cwd, \"agents\"),\n  ];\n\n  for (const candidate of candidates) {\n    if (isDirectory(candidate)) {\n      return candidate;\n    }\n  }\n\n  return null;\n}\n", "import { generateRegistry } from \"./generate\";\nimport type { ScannedAgent } from \"./scan\";\nimport { discoverAgentDirs, findAgentsRoot, scanAgent } from \"./scan\";\n\n/**\n * Framework-agnostic core for filesystem-based agent discovery and\n * registry code generation. Adapters like {@link Next} receive a\n * `Framework` instance and use it to scan agents and produce registry\n * source code.\n */\nexport class Framework {\n  readonly cwd: string;\n  readonly agentsDir: string | undefined;\n  readonly log: (...args: unknown[]) => void;\n\n  constructor(opts: {\n    /**\n     * Project root directory.\n     * @defaultValue `process.cwd()`\n     */\n    cwd?: string;\n    /**\n     * Path to the agents directory, relative to `cwd`.\n     * When omitted, auto-detected as the first existing directory\n     * among `src/agents` and `agents`.\n     */\n    agentsDir?: string;\n    /** Enable verbose logging to stdout. */\n    debug?: boolean;\n  }) {\n    this.cwd = opts.cwd ?? process.cwd();\n    this.agentsDir = opts.agentsDir;\n    this.log = opts.debug\n      ? console.log.bind(console, \"[Framework]\")\n      : () => undefined;\n  }\n\n  /**\n   * Scan the agents directory and return metadata for every agent found.\n   * Each subfolder inside the agents directory becomes one agent.\n   * Returns an empty array when no agents directory exists.\n   */\n  discoverAgents(): ScannedAgent[] {\n    const root = findAgentsRoot(this.cwd, this.agentsDir);\n    if (!root) {\n      return [];\n    }\n    const dirs = discoverAgentDirs(root);\n    return dirs.map(scanAgent);\n  }\n\n  /**\n   * Generate the TypeScript source for an agent registry module.\n   *\n   * @param opts.agents - Scanned agents to include in the registry.\n   * @param opts.outputDir - Directory where the registry file will be written\n   *   (used to compute relative import paths to each agent's config module).\n   * @returns The full source text of the generated `_registry.ts` file.\n   */\n  generateRegistrySource = generateRegistry;\n}\n"],
  "mappings": ";AAAA,YAAY,QAAQ;AACpB,YAAY,UAAU;AAGtB,IAAM,gBAAgB;AACf,SAAS,iBAAiB,MAGtB;AACT,QAAM,UAAU,KAAK,OAAO;AAAA,IAAI,CAAC,UAC/B,YAAY,EAAE,OAAO,WAAW,KAAK,UAAU,CAAC;AAAA,EAClD;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,IACH;AAAA,IACA;AAAA,EACF,EAAE,KAAK,IAAI;AACb;AAEA,SAAS,YAAY,MAGV;AACT,QAAM,SAAS,YAAY,KAAK,KAAK;AACrC,QAAM,YAAY,KAAK,UAAU,QAAQ,MAAM,CAAC,EAC7C,MAAM,IAAI,EACV,IAAI,CAAC,MAAM,MAAO,MAAM,IAAI,OAAO,SAAS,IAAI,EAAG,EACnD,KAAK,IAAI;AAEZ,QAAM,QAAQ,CAAC,eAAe,SAAS,EAAE;AAEzC,MAAI,KAAK,MAAM,gBAAgB;AAC7B,UAAM,aAAa,oBAAoB,KAAK,MAAM,YAAY;AAC9D,UAAM,eAAe,mBAAmB;AAAA,MACtC,MAAM,KAAK;AAAA,MACX,IAAI;AAAA,IACN,CAAC;AACD,UAAM,KAAK,4BAA4B,KAAK,UAAU,YAAY,CAAC,GAAG;AAAA,EACxE;AAEA,MAAI,KAAK,MAAM,MAAM,SAAS,GAAG;AAC/B,UAAM,YAAY,KAAK,MAAM,MAAM,IAAI,CAAC,SAAS;AAC/C,YAAM,MAAM,mBAAmB;AAAA,QAC7B,MAAM,KAAK;AAAA,QACX,IAAI,KAAK;AAAA,MACX,CAAC;AACD,aAAO,WAAW,KAAK,UAAU,KAAK,IAAI,CAAC,kBAAkB,KAAK,UAAU,GAAG,CAAC;AAAA,IAClF,CAAC;AACD,UAAM,KAAK;AAAA;AAAA,EAAmC,UAAU,KAAK,KAAK,CAAC;AAAA;AAAA,MAAkB;AAAA,EACvF;AAEA,SAAO,KAAK,KAAK,UAAU,KAAK,MAAM,IAAI,CAAC;AAAA,EAAQ,MAAM,KAAK,KAAK,CAAC;AAAA;AACtE;AAEA,SAAS,YAAY,OAA8C;AACjE,QAAM,SAAkC,CAAC;AAEzC,MAAI,MAAM,cAAc;AACtB,WAAO,SAAS,MAAM;AAAA,EACxB;AAEA,MAAI,MAAM,OAAO,SAAS,GAAG;AAC3B,WAAO,SAAS,MAAM;AAAA,EACxB;AAEA,SAAO;AACT;AAEA,SAAS,oBAAoB,UAA0B;AACrD,QAAM,aAAa,CAAC,OAAO,OAAO,QAAQ,MAAM;AAChD,aAAW,OAAO,YAAY;AAC5B,UAAM,YAAiB,UAAK,UAAU,QAAQ,GAAG,EAAE;AACnD,QAAO,cAAW,SAAS,GAAG;AAC5B,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAY,UAAK,UAAU,OAAO;AACpC;AAEA,SAAS,mBAAmB,MAA4C;AACtE,MAAI,MAAW,cAAS,KAAK,MAAM,KAAK,EAAE,EAAE,QAAQ,OAAO,GAAG;AAC9D,QAAM,IAAI,QAAQ,eAAe,EAAE;AACnC,MAAI,CAAC,IAAI,WAAW,GAAG,GAAG;AACxB,UAAM,KAAK,GAAG;AAAA,EAChB;AACA,SAAO;AACT;;;AC3FA,YAAYA,SAAQ;AACpB,YAAYC,WAAU;AAqBtB,IAAM,qBAAqB,CAAC,YAAY,YAAY,aAAa,WAAW;AAC5E,IAAM,SAAS;AACf,IAAM,SAAS;AAER,SAAS,QAAQ,KAAuB;AAC7C,MAAI,CAAI,eAAW,GAAG,GAAG;AACvB,WAAO,CAAC;AAAA,EACV;AACA,SAAU,gBAAY,GAAG;AAC3B;AAEO,SAAS,SAAS,UAA0B;AACjD,SAAU,iBAAa,UAAU,OAAO;AAC1C;AAEO,SAAS,WAAW,UAA2B;AACpD,SAAU,eAAW,QAAQ;AAC/B;AAEO,SAAS,YAAY,UAA2B;AACrD,SAAU,eAAW,QAAQ,KAAQ,aAAS,QAAQ,EAAE,YAAY;AACtE;AAEO,SAAS,kBAAkB,YAAgC;AAChE,QAAM,UAAU,QAAQ,UAAU;AAClC,QAAM,OAAmB,CAAC;AAE1B,aAAW,SAAS,SAAS;AAC3B,UAAM,eAAoB,WAAK,YAAY,KAAK;AAChD,QAAI,CAAC,YAAY,YAAY,GAAG;AAC9B;AAAA,IACF;AACA,QAAI,MAAM,WAAW,GAAG,GAAG;AACzB;AAAA,IACF;AAEA,SAAK,KAAK;AAAA,MACR,MAAM;AAAA,MACN;AAAA,MACA,gBAAgB,eAAe,YAAY;AAAA,IAC7C,CAAC;AAAA,EACH;AAEA,SAAO;AACT;AAEO,SAAS,eAAe,UAA2B;AACxD,SAAO,mBAAmB,KAAK,CAAC,MAAM,WAAgB,WAAK,UAAU,CAAC,CAAC,CAAC;AAC1E;AAEO,SAAS,UAAU,UAGxB;AACA,QAAM,YAAiB,WAAK,UAAU,QAAQ;AAC9C,QAAM,UAAU,QAAQ,SAAS;AACjC,QAAM,SAAuB,CAAC;AAC9B,QAAM,qBAA+B,CAAC;AAEtC,aAAW,SAAS,QAAQ,KAAK,GAAG;AAClC,UAAM,eAAoB,WAAK,WAAW,KAAK;AAE/C,QAAI,OAAO,KAAK,KAAK,GAAG;AACtB,aAAO,KAAK;AAAA,QACV,MAAM;AAAA,QACN,MAAM;AAAA,MACR,CAA0B;AAAA,IAC5B,WAAW,OAAO,KAAK,KAAK,GAAG;AAC7B,yBAAmB,KAAK,YAAY;AAAA,IACtC;AAAA,EACF;AAEA,SAAO,EAAE,QAAQ,mBAAmB;AACtC;AAEO,SAAS,gBAAgB,UAAsC;AACpE,QAAM,YAAiB,WAAK,UAAU,QAAQ;AAC9C,QAAM,UAAU,QAAQ,SAAS;AACjC,QAAM,UAAU,QAAQ,OAAO,CAAC,MAAM,OAAO,KAAK,CAAC,CAAC,EAAE,KAAK;AAE3D,MAAI,QAAQ,WAAW,GAAG;AACxB,WAAO;AAAA,EACT;AAEA,QAAM,QAAkB,CAAC;AACzB,aAAW,QAAQ,SAAS;AAC1B,UAAM,UAAU,SAAc,WAAK,WAAW,IAAI,CAAC,EAAE,KAAK;AAC1D,QAAI,SAAS;AACX,YAAM,KAAK,OAAO;AAAA,IACpB;AAAA,EACF;AAEA,SAAO,MAAM,SAAS,IAAI,MAAM,KAAK,MAAM,IAAI;AACjD;AAEO,SAAS,SAAS,UAAiC;AACxD,QAAM,WAAgB,WAAK,UAAU,OAAO;AAC5C,QAAM,UAAU,QAAQ,QAAQ;AAChC,QAAM,QAAuB,CAAC;AAE9B,aAAW,SAAS,QAAQ,KAAK,GAAG;AAClC,UAAM,eAAoB,WAAK,UAAU,KAAK;AAE9C,QAAI,YAAY,YAAY,GAAG;AAC7B,YAAM,YAAY,cAAc,YAAY;AAC5C,UAAI,WAAW;AACb,cAAM,KAAK,EAAE,MAAM,OAAO,YAAY,UAAU,CAAC;AAAA,MACnD;AAAA,IACF,WAAW,OAAO,KAAK,KAAK,GAAG;AAC7B,YAAM,OAAO,MAAM,QAAQ,QAAQ,EAAE;AACrC,YAAM,KAAK,EAAE,MAAM,YAAY,aAAa,CAAC;AAAA,IAC/C;AAAA,EACF;AAEA,SAAO;AACT;AAEA,SAAS,cAAc,KAA4B;AACjD,QAAM,aAAa,CAAC,OAAO,OAAO,QAAQ,MAAM;AAChD,aAAW,OAAO,YAAY;AAC5B,UAAM,YAAiB,WAAK,KAAK,QAAQ,GAAG,EAAE;AAC9C,QAAI,WAAW,SAAS,GAAG;AACzB,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;AAEO,SAAS,UAAU,UAAkC;AAC1D,QAAM,EAAE,QAAQ,mBAAmB,IAAI,UAAU,SAAS,YAAY;AACtE,QAAM,eAAe,gBAAgB,SAAS,YAAY;AAC1D,QAAM,QAAQ,SAAS,SAAS,YAAY;AAE5C,SAAO,EAAE,GAAG,UAAU,QAAQ,cAAc,oBAAoB,MAAM;AACxE;AAEO,SAAS,eACd,KACA,sBACe;AACf,MAAI,sBAAsB;AACxB,WAAY,cAAQ,KAAK,oBAAoB;AAAA,EAC/C;AACA,QAAM,aAAa;AAAA,IACZ,WAAK,KAAK,OAAO,QAAQ;AAAA,IACzB,WAAK,KAAK,QAAQ;AAAA,EACzB;AAEA,aAAW,aAAa,YAAY;AAClC,QAAI,YAAY,SAAS,GAAG;AAC1B,aAAO;AAAA,IACT;AAAA,EACF;AAEA,SAAO;AACT;;;ACvKO,IAAM,YAAN,MAAgB;AAAA,EACZ;AAAA,EACA;AAAA,EACA;AAAA,EAET,YAAY,MAcT;AACD,SAAK,MAAM,KAAK,OAAO,QAAQ,IAAI;AACnC,SAAK,YAAY,KAAK;AACtB,SAAK,MAAM,KAAK,QACZ,QAAQ,IAAI,KAAK,SAAS,aAAa,IACvC,MAAM;AAAA,EACZ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,iBAAiC;AAC/B,UAAM,OAAO,eAAe,KAAK,KAAK,KAAK,SAAS;AACpD,QAAI,CAAC,MAAM;AACT,aAAO,CAAC;AAAA,IACV;AACA,UAAM,OAAO,kBAAkB,IAAI;AACnC,WAAO,KAAK,IAAI,SAAS;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,yBAAyB;AAC3B;",
  "names": ["fs", "path"]
}

|