experimental-agent 0.8.0-alpha.2 → 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.
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  agent
3
- } from "./chunk-EH4L2CPW.mjs";
3
+ } from "./chunk-HVZTAMAX.mjs";
4
4
  import "./chunk-C4VSUEY2.mjs";
5
5
  import "./chunk-CS2SEUAA.mjs";
6
6
  import "./chunk-MSWINCCM.mjs";
@@ -40,6 +40,9 @@ function mergeFrameworkOptions(base, overlay) {
40
40
  merged.skills = [...base.skills, ...overlay.skills];
41
41
  }
42
42
  }
43
+ if (overlay.tools !== void 0) {
44
+ merged.tools = { ...base.tools, ...overlay.tools };
45
+ }
43
46
  return merged;
44
47
  }
45
48
 
@@ -60,8 +63,33 @@ async function resolveFrameworkAgent(opts) {
60
63
  resolvedAgentCache.set(cacheKey, instance);
61
64
  return instance;
62
65
  }
66
+ async function resolveToolImports(loaders) {
67
+ const resolved = await Promise.all(
68
+ Object.entries(loaders).map(async ([toolName, load]) => {
69
+ const mod = await load();
70
+ if (!mod.default) {
71
+ throw new Error(
72
+ `Tool "${toolName}" module does not have a default export.
73
+
74
+ hint: tools/${toolName}.ts (or tools/${toolName}/index.ts) must export a default tool.
75
+
76
+ import { tool } from "ai";
77
+ export default tool({ ... });
78
+ `
79
+ );
80
+ }
81
+ return [toolName, mod.default];
82
+ })
83
+ );
84
+ return Object.fromEntries(resolved);
85
+ }
63
86
  async function resolveEntry(opts) {
64
87
  const { name, entry } = opts;
88
+ const config = { ...entry.config };
89
+ const toolLoaders = entry.imports?.tools;
90
+ if (toolLoaders && Object.keys(toolLoaders).length > 0) {
91
+ config.tools = await resolveToolImports(toolLoaders);
92
+ }
65
93
  if (typeof entry.import === "function") {
66
94
  const mod = await entry.import();
67
95
  if (!mod.default) {
@@ -76,14 +104,12 @@ hint: agents/${name}/agent.ts must export a default agent instance.
76
104
  );
77
105
  }
78
106
  const imported = mod.default;
79
- if (hasConfig(entry.config)) {
80
- return imported.extend(
81
- (base) => mergeFrameworkOptions(base, entry.config)
82
- );
107
+ if (hasConfig(config)) {
108
+ return agent(name, mergeFrameworkOptions(imported.options, config));
83
109
  }
84
110
  return imported;
85
111
  }
86
- return agent(name, entry.config);
112
+ return agent(name, config);
87
113
  }
88
114
  function hasConfig(config) {
89
115
  return Object.keys(config).length > 0;
@@ -104,4 +130,4 @@ var runtime = {
104
130
  export {
105
131
  runtime
106
132
  };
107
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/framework-runtime/merge-options.ts", "../src/framework-runtime/resolve.ts", "../src/framework-runtime/index.ts"],
  "sourcesContent": ["import type { AgentOptions } from \"../agent/client\";\nimport type { FsAgentConfig } from \"../framework-runtime/resolve\";\n\n/**\n * Merge fs-scanned config on top of the agent.ts base config.\n * Skills are appended. System prompts are concatenated (arrays).\n * The base options may contain Resolvable values (functions); when\n * the overlay has a static value we wrap the base resolvable so the\n * fs values get appended at resolve time.\n */\n\nexport function mergeFrameworkOptions(\n  base: AgentOptions,\n  overlay: FsAgentConfig\n): AgentOptions {\n  const merged: AgentOptions = { ...base };\n\n  if (overlay.system !== undefined) {\n    if (base.system === undefined) {\n      merged.system = overlay.system;\n    } else if (typeof base.system === \"function\") {\n      const baseFn = base.system;\n      merged.system = async (args) => {\n        const resolved = await baseFn(args);\n        if (resolved === undefined) {\n          return overlay.system;\n        }\n        const baseArr = Array.isArray(resolved) ? resolved : [resolved];\n        return [...baseArr, overlay.system!];\n      };\n    } else {\n      const baseArr = Array.isArray(base.system) ? base.system : [base.system];\n      merged.system = [...baseArr, overlay.system];\n    }\n  }\n\n  if (overlay.skills !== undefined) {\n    if (base.skills === undefined) {\n      merged.skills = overlay.skills;\n    } else if (typeof base.skills === \"function\") {\n      const baseFn = base.skills;\n      merged.skills = async (args) => {\n        const resolved = await baseFn(args);\n        return [...(resolved ?? []), ...overlay.skills!];\n      };\n    } else {\n      merged.skills = [...base.skills, ...overlay.skills];\n    }\n  }\n\n  return merged;\n}\n", "import { type AnyAgent, agent as createAgent } from \"../agent/client\";\nimport type { SkillInput } from \"../skills/types\";\nimport { mergeFrameworkOptions } from \"./merge-options\";\n\n/**\n * The subset of AgentOptions that can come from the filesystem scanner.\n * Always plain values \u2014 never Resolvable functions.\n */\nexport type FsAgentConfig = {\n  system?: string;\n  skills?: SkillInput[];\n};\n\n/**\n * A single entry in the generated agent registry.\n * Contains the filesystem-scanned config and an optional dynamic import\n * for agents that have an `agent.ts` module.\n */\nexport type AgentRegistryEntry = {\n  config: FsAgentConfig;\n  import?: () => Promise<{ default?: unknown }>;\n};\n\n/**\n * Map of agent name to registry entry, produced by the generated\n * `_registry.ts` file and consumed by {@link runtime.resolveAgent}\n * at request time.\n */\nexport type AgentRegistry = Record<string, AgentRegistryEntry>;\n\nconst resolvedAgentCache = new Map<string, AnyAgent>();\n\nexport async function resolveFrameworkAgent(opts: {\n  name: string;\n  agents: AgentRegistry;\n}): Promise<AnyAgent | null> {\n  const { name, agents } = opts;\n\n  if (!Object.hasOwn(agents, name)) {\n    return null;\n  }\n\n  const entry = agents[name];\n  const cacheKey = name + JSON.stringify(entry.config);\n  const cached = resolvedAgentCache.get(cacheKey);\n  if (cached) {\n    return cached;\n  }\n\n  const instance = await resolveEntry({ name, entry });\n  resolvedAgentCache.set(cacheKey, instance);\n  return instance;\n}\n\nasync function resolveEntry(opts: {\n  name: string;\n  entry: AgentRegistryEntry;\n}): Promise<AnyAgent> {\n  const { name, entry } = opts;\n\n  if (typeof entry.import === \"function\") {\n    const mod = await entry.import();\n    if (!mod.default) {\n      throw new Error(\n        `Agent \"${name}\" module does not have a default export.\\n\\n` +\n          `hint: agents/${name}/agent.ts must export a default agent instance.\\n\\n` +\n          `  import { agent } from \"experimental-agent\";\\n` +\n          `  export default agent(\"${name}\", { ... });\\n`\n      );\n    }\n\n    const imported = mod.default as AnyAgent;\n\n    if (hasConfig(entry.config)) {\n      return imported.extend((base) =>\n        mergeFrameworkOptions(base, entry.config)\n      );\n    }\n\n    return imported;\n  }\n\n  return createAgent(name, entry.config);\n}\n\nfunction hasConfig(config: FsAgentConfig): boolean {\n  return Object.keys(config).length > 0;\n}\n", "import { resolveFrameworkAgent } from \"./resolve\";\n\n/**\n * Request-time utilities for the framework router.\n *\n * Used inside generated route handlers to resolve an agent by name\n * from a registry produced at build time.\n *\n * @example\n * ```ts\n * import { runtime } from \"experimental-agent/framework-runtime\";\n *\n * const agent = await runtime.resolveAgent({ name, agents });\n * ```\n */\nexport const runtime = {\n  /**\n   * Look up an agent by name from a generated registry, merging any\n   * filesystem-scanned config (system prompts, skills) on top of the\n   * agent's own options. Results are cached for the lifetime of the\n   * process.\n   *\n   * Returns `null` when the name doesn't match any registry entry.\n   */\n  resolveAgent: resolveFrameworkAgent,\n};\n"],
  "mappings": ";;;;;;;;;AAWO,SAAS,sBACd,MACA,SACc;AACd,QAAM,SAAuB,EAAE,GAAG,KAAK;AAEvC,MAAI,QAAQ,WAAW,QAAW;AAChC,QAAI,KAAK,WAAW,QAAW;AAC7B,aAAO,SAAS,QAAQ;AAAA,IAC1B,WAAW,OAAO,KAAK,WAAW,YAAY;AAC5C,YAAM,SAAS,KAAK;AACpB,aAAO,SAAS,OAAO,SAAS;AAC9B,cAAM,WAAW,MAAM,OAAO,IAAI;AAClC,YAAI,aAAa,QAAW;AAC1B,iBAAO,QAAQ;AAAA,QACjB;AACA,cAAM,UAAU,MAAM,QAAQ,QAAQ,IAAI,WAAW,CAAC,QAAQ;AAC9D,eAAO,CAAC,GAAG,SAAS,QAAQ,MAAO;AAAA,MACrC;AAAA,IACF,OAAO;AACL,YAAM,UAAU,MAAM,QAAQ,KAAK,MAAM,IAAI,KAAK,SAAS,CAAC,KAAK,MAAM;AACvE,aAAO,SAAS,CAAC,GAAG,SAAS,QAAQ,MAAM;AAAA,IAC7C;AAAA,EACF;AAEA,MAAI,QAAQ,WAAW,QAAW;AAChC,QAAI,KAAK,WAAW,QAAW;AAC7B,aAAO,SAAS,QAAQ;AAAA,IAC1B,WAAW,OAAO,KAAK,WAAW,YAAY;AAC5C,YAAM,SAAS,KAAK;AACpB,aAAO,SAAS,OAAO,SAAS;AAC9B,cAAM,WAAW,MAAM,OAAO,IAAI;AAClC,eAAO,CAAC,GAAI,YAAY,CAAC,GAAI,GAAG,QAAQ,MAAO;AAAA,MACjD;AAAA,IACF,OAAO;AACL,aAAO,SAAS,CAAC,GAAG,KAAK,QAAQ,GAAG,QAAQ,MAAM;AAAA,IACpD;AAAA,EACF;AAEA,SAAO;AACT;;;ACrBA,IAAM,qBAAqB,oBAAI,IAAsB;AAErD,eAAsB,sBAAsB,MAGf;AAC3B,QAAM,EAAE,MAAM,OAAO,IAAI;AAEzB,MAAI,CAAC,OAAO,OAAO,QAAQ,IAAI,GAAG;AAChC,WAAO;AAAA,EACT;AAEA,QAAM,QAAQ,OAAO,IAAI;AACzB,QAAM,WAAW,OAAO,KAAK,UAAU,MAAM,MAAM;AACnD,QAAM,SAAS,mBAAmB,IAAI,QAAQ;AAC9C,MAAI,QAAQ;AACV,WAAO;AAAA,EACT;AAEA,QAAM,WAAW,MAAM,aAAa,EAAE,MAAM,MAAM,CAAC;AACnD,qBAAmB,IAAI,UAAU,QAAQ;AACzC,SAAO;AACT;AAEA,eAAe,aAAa,MAGN;AACpB,QAAM,EAAE,MAAM,MAAM,IAAI;AAExB,MAAI,OAAO,MAAM,WAAW,YAAY;AACtC,UAAM,MAAM,MAAM,MAAM,OAAO;AAC/B,QAAI,CAAC,IAAI,SAAS;AAChB,YAAM,IAAI;AAAA,QACR,UAAU,IAAI;AAAA;AAAA,eACI,IAAI;AAAA;AAAA;AAAA,0BAEO,IAAI;AAAA;AAAA,MACnC;AAAA,IACF;AAEA,UAAM,WAAW,IAAI;AAErB,QAAI,UAAU,MAAM,MAAM,GAAG;AAC3B,aAAO,SAAS;AAAA,QAAO,CAAC,SACtB,sBAAsB,MAAM,MAAM,MAAM;AAAA,MAC1C;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAEA,SAAO,MAAY,MAAM,MAAM,MAAM;AACvC;AAEA,SAAS,UAAU,QAAgC;AACjD,SAAO,OAAO,KAAK,MAAM,EAAE,SAAS;AACtC;;;ACxEO,IAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASrB,cAAc;AAChB;",
  "names": []
}

133
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/framework-runtime/merge-options.ts", "../src/framework-runtime/resolve.ts", "../src/framework-runtime/index.ts"],
  "sourcesContent": ["import type { AgentOptions } from \"../agent/client\";\nimport type { FsAgentConfig } from \"../framework-runtime/resolve\";\n\n/**\n * Merge fs-scanned config on top of the agent.ts base config.\n * Skills are appended. System prompts are concatenated (arrays).\n * The base options may contain Resolvable values (functions); when\n * the overlay has a static value we wrap the base resolvable so the\n * fs values get appended at resolve time.\n */\n\nexport function mergeFrameworkOptions(\n  base: AgentOptions,\n  overlay: FsAgentConfig\n): AgentOptions {\n  const merged: AgentOptions = { ...base };\n\n  if (overlay.system !== undefined) {\n    if (base.system === undefined) {\n      merged.system = overlay.system;\n    } else if (typeof base.system === \"function\") {\n      const baseFn = base.system;\n      merged.system = async (args) => {\n        const resolved = await baseFn(args);\n        if (resolved === undefined) {\n          return overlay.system;\n        }\n        const baseArr = Array.isArray(resolved) ? resolved : [resolved];\n        return [...baseArr, overlay.system!];\n      };\n    } else {\n      const baseArr = Array.isArray(base.system) ? base.system : [base.system];\n      merged.system = [...baseArr, overlay.system];\n    }\n  }\n\n  if (overlay.skills !== undefined) {\n    if (base.skills === undefined) {\n      merged.skills = overlay.skills;\n    } else if (typeof base.skills === \"function\") {\n      const baseFn = base.skills;\n      merged.skills = async (args) => {\n        const resolved = await baseFn(args);\n        return [...(resolved ?? []), ...overlay.skills!];\n      };\n    } else {\n      merged.skills = [...base.skills, ...overlay.skills];\n    }\n  }\n\n  if (overlay.tools !== undefined) {\n    merged.tools = { ...base.tools, ...overlay.tools };\n  }\n\n  return merged;\n}\n", "import type { ToolSet } from \"ai\";\nimport { type AnyAgent, agent as createAgent } from \"../agent/client\";\nimport type { SkillInput } from \"../skills/types\";\nimport { mergeFrameworkOptions } from \"./merge-options\";\n\n/**\n * The subset of AgentOptions that can come from the filesystem scanner.\n * Always plain values \u2014 never Resolvable functions.\n */\nexport type FsAgentConfig = {\n  system?: string;\n  skills?: SkillInput[];\n  tools?: ToolSet;\n};\n\ntype ModuleLoader = () => Promise<{ default?: unknown }>;\n\n/**\n * Dynamic import loaders for filesystem modules that can't be\n * serialized into `config`. Keyed by category, then by name.\n * Currently only `tools` is populated; `skills` and `system`\n * will follow the same pattern for `.ts` modules.\n */\nexport type RegistryImports = {\n  tools?: Record<string, ModuleLoader>;\n};\n\n/**\n * A single entry in the generated agent registry.\n * Contains the filesystem-scanned config and an optional dynamic import\n * for agents that have an `agent.ts` module.\n */\nexport type AgentRegistryEntry = {\n  config: FsAgentConfig;\n  import?: ModuleLoader;\n  imports?: RegistryImports;\n};\n\n/**\n * Map of agent name to registry entry, produced by the generated\n * `_registry.ts` file and consumed by {@link runtime.resolveAgent}\n * at request time.\n */\nexport type AgentRegistry = Record<string, AgentRegistryEntry>;\n\nconst resolvedAgentCache = new Map<string, AnyAgent>();\n\nexport async function resolveFrameworkAgent(opts: {\n  name: string;\n  agents: AgentRegistry;\n}): Promise<AnyAgent | null> {\n  const { name, agents } = opts;\n\n  if (!Object.hasOwn(agents, name)) {\n    return null;\n  }\n\n  const entry = agents[name];\n  const cacheKey = name + JSON.stringify(entry.config);\n  const cached = resolvedAgentCache.get(cacheKey);\n  if (cached) {\n    return cached;\n  }\n\n  const instance = await resolveEntry({ name, entry });\n  resolvedAgentCache.set(cacheKey, instance);\n  return instance;\n}\n\nasync function resolveToolImports(\n  loaders: Record<string, ModuleLoader>\n): Promise<ToolSet> {\n  const resolved = await Promise.all(\n    Object.entries(loaders).map(async ([toolName, load]) => {\n      const mod = await load();\n      if (!mod.default) {\n        throw new Error(\n          `Tool \"${toolName}\" module does not have a default export.\\n\\n` +\n            `hint: tools/${toolName}.ts (or tools/${toolName}/index.ts) must export a default tool.\\n\\n` +\n            `  import { tool } from \"ai\";\\n` +\n            \"  export default tool({ ... });\\n\"\n        );\n      }\n      return [toolName, mod.default] as const;\n    })\n  );\n  return Object.fromEntries(resolved) as ToolSet;\n}\n\nasync function resolveEntry(opts: {\n  name: string;\n  entry: AgentRegistryEntry;\n}): Promise<AnyAgent> {\n  const { name, entry } = opts;\n\n  const config = { ...entry.config };\n  const toolLoaders = entry.imports?.tools;\n  if (toolLoaders && Object.keys(toolLoaders).length > 0) {\n    config.tools = await resolveToolImports(toolLoaders);\n  }\n\n  if (typeof entry.import === \"function\") {\n    const mod = await entry.import();\n    if (!mod.default) {\n      throw new Error(\n        `Agent \"${name}\" module does not have a default export.\\n\\n` +\n          `hint: agents/${name}/agent.ts must export a default agent instance.\\n\\n` +\n          `  import { agent } from \"experimental-agent\";\\n` +\n          `  export default agent(\"${name}\", { ... });\\n`\n      );\n    }\n\n    const imported = mod.default as AnyAgent;\n\n    if (hasConfig(config)) {\n      return createAgent(name, mergeFrameworkOptions(imported.options, config));\n    }\n\n    return imported;\n  }\n\n  return createAgent(name, config);\n}\n\nfunction hasConfig(config: FsAgentConfig): boolean {\n  return Object.keys(config).length > 0;\n}\n", "import { resolveFrameworkAgent } from \"./resolve\";\n\n/**\n * Request-time utilities for the framework router.\n *\n * Used inside generated route handlers to resolve an agent by name\n * from a registry produced at build time.\n *\n * @example\n * ```ts\n * import { runtime } from \"experimental-agent/framework-runtime\";\n *\n * const agent = await runtime.resolveAgent({ name, agents });\n * ```\n */\nexport const runtime = {\n  /**\n   * Look up an agent by name from a generated registry, merging any\n   * filesystem-scanned config (system prompts, skills) on top of the\n   * agent's own options. Results are cached for the lifetime of the\n   * process.\n   *\n   * Returns `null` when the name doesn't match any registry entry.\n   */\n  resolveAgent: resolveFrameworkAgent,\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,11 +1,11 @@
1
- export { F as Framework } from './framework-c9fvEy0o.mjs';
2
- export { A as AgentRegistry, a as AgentRegistryEntry } from './resolve-Cma6YFgx.mjs';
1
+ export { F as Framework } from './framework-VPUsYNMf.mjs';
2
+ export { A as AgentRegistry, a as AgentRegistryEntry } from './resolve-YlI7Dugf.mjs';
3
3
  import './types-B3lbsOa7.mjs';
4
- import './client-PuttJd6O.mjs';
4
+ import 'ai';
5
+ import './client-BaItaOx5.mjs';
5
6
  import '@vercel/sandbox';
6
7
  import './steps-ChOeFWAq.mjs';
7
8
  import './adapter-CFq5IeYI.mjs';
8
9
  import '@workflow/serde';
9
- import 'ai';
10
10
  import './entry-CRBUC5DB.mjs';
11
11
  import 'zod';
@@ -1,11 +1,11 @@
1
- export { F as Framework } from './framework-DH4Z1NLV.js';
2
- export { A as AgentRegistry, a as AgentRegistryEntry } from './resolve-BZ26gcyj.js';
1
+ export { F as Framework } from './framework-DSe3sdP_.js';
2
+ export { A as AgentRegistry, a as AgentRegistryEntry } from './resolve-DCys_2es.js';
3
3
  import './types-B3lbsOa7.js';
4
- import './client-DIanpEQ_.js';
4
+ import 'ai';
5
+ import './client-BY6gceox.js';
5
6
  import '@vercel/sandbox';
6
7
  import './steps-DWTQiAPt.js';
7
8
  import './adapter-CFq5IeYI.js';
8
9
  import '@workflow/serde';
9
- import 'ai';
10
10
  import './entry-BUYBv4Cu.js';
11
11
  import 'zod';
package/dist/framework.js CHANGED
@@ -64,6 +64,20 @@ function inlineEntry(opts) {
64
64
  });
65
65
  parts.push(` import: () => import(${JSON.stringify(relativePath)})`);
66
66
  }
67
+ if (opts.agent.tools.length > 0) {
68
+ const toolLines = opts.agent.tools.map((tool) => {
69
+ const rel = relativeImportPath({
70
+ from: opts.outputDir,
71
+ to: tool.importPath
72
+ });
73
+ return ` ${JSON.stringify(tool.name)}: () => import(${JSON.stringify(rel)})`;
74
+ });
75
+ parts.push(` imports: {
76
+ tools: {
77
+ ${toolLines.join(",\n")}
78
+ }
79
+ }`);
80
+ }
67
81
  return ` ${JSON.stringify(opts.agent.name)}: {
68
82
  ${parts.join(",\n")}
69
83
  },`;
@@ -174,10 +188,39 @@ function getSystemPrompt(agentDir) {
174
188
  }
175
189
  return parts.length > 0 ? parts.join("\n\n") : void 0;
176
190
  }
191
+ function getTools(agentDir) {
192
+ const toolsDir = path2.join(agentDir, "tools");
193
+ const entries = listDir(toolsDir);
194
+ const tools = [];
195
+ for (const entry of entries.sort()) {
196
+ const absolutePath = path2.join(toolsDir, entry);
197
+ if (isDirectory(absolutePath)) {
198
+ const indexFile = findIndexFile(absolutePath);
199
+ if (indexFile) {
200
+ tools.push({ name: entry, importPath: indexFile });
201
+ }
202
+ } else if (TS_EXT.test(entry)) {
203
+ const name = entry.replace(TS_EXT, "");
204
+ tools.push({ name, importPath: absolutePath });
205
+ }
206
+ }
207
+ return tools;
208
+ }
209
+ function findIndexFile(dir) {
210
+ const extensions = [".ts", ".js", ".mts", ".mjs"];
211
+ for (const ext of extensions) {
212
+ const candidate = path2.join(dir, `index${ext}`);
213
+ if (fileExists(candidate)) {
214
+ return candidate;
215
+ }
216
+ }
217
+ return null;
218
+ }
177
219
  function scanAgent(agentDir) {
178
220
  const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);
179
221
  const systemPrompt = getSystemPrompt(agentDir.absolutePath);
180
- return { ...agentDir, skills, systemPrompt, tsSkillImportPaths };
222
+ const tools = getTools(agentDir.absolutePath);
223
+ return { ...agentDir, skills, systemPrompt, tsSkillImportPaths, tools };
181
224
  }
182
225
  function findAgentsRoot(cwd, userDefinedAgentsDir) {
183
226
  if (userDefinedAgentsDir) {
@@ -232,4 +275,4 @@ var Framework = class {
232
275
  0 && (module.exports = {
233
276
  Framework
234
277
  });
235
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/framework/index.ts", "../src/framework/generate.ts", "../src/framework/scan.ts", "../src/framework/framework.ts"],
  "sourcesContent": ["export { Framework } from \"./framework\";\nexport type {\n  AgentRegistry,\n  AgentRegistryEntry,\n} from \"../framework-runtime/resolve\";\n", "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  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 ScannedAgent = AgentDir & {\n  skills: SkillInput[];\n  systemPrompt: string | undefined;\n  tsSkillImportPaths: string[];\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 scanAgent(agentDir: AgentDir): ScannedAgent {\n  const { skills, tsSkillImportPaths } = getSkills(agentDir.absolutePath);\n  const systemPrompt = getSystemPrompt(agentDir.absolutePath);\n\n  return { ...agentDir, skills, systemPrompt, tsSkillImportPaths };\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": "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",
  "names": ["fs", "path"]
}

278
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/framework/index.ts", "../src/framework/generate.ts", "../src/framework/scan.ts", "../src/framework/framework.ts"],
  "sourcesContent": ["export { Framework } from \"./framework\";\nexport type {\n  AgentRegistry,\n  AgentRegistryEntry,\n} from \"../framework-runtime/resolve\";\n", "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": "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",
  "names": ["fs", "path"]
}

@@ -1,6 +1,6 @@
1
1
  import {
2
2
  Framework
3
- } from "./chunk-DO4HKPHR.mjs";
3
+ } from "./chunk-HPBAZJLN.mjs";
4
4
  import "./chunk-BJTO5JO5.mjs";
5
5
  export {
6
6
  Framework
package/dist/index.d.mts CHANGED
@@ -1,5 +1,5 @@
1
- import { T as ToolContext, A as AnyAgent, S as SessionSendArgs, b as SendResult } from './client-PuttJd6O.mjs';
2
- export { c as AgentDataTypes, d as AgentHooks, e as AgentOptions, a as AgentStatus, f as ApprovalData, B as BuiltInToolName, I as InferSession, g as InferUIMessage, N as NeedsApprovalMap, R as Resolvable, h as ResolvableArgs, i as SendInput, j as SessionDefaults, k as StepUsage, U as UsageSummary, W as WorkflowRunLike, l as agent, m as builtinToolNames } from './client-PuttJd6O.mjs';
1
+ import { T as ToolContext, A as AnyAgent, S as SessionSendArgs, b as SendResult } from './client-BaItaOx5.mjs';
2
+ export { c as AgentDataTypes, d as AgentHooks, e as AgentOptions, a as AgentStatus, f as ApprovalData, B as BuiltInToolName, I as InferSession, g as InferUIMessage, N as NeedsApprovalMap, R as Resolvable, h as ResolvableArgs, i as SendInput, j as SessionDefaults, k as StepUsage, U as UsageSummary, W as WorkflowRunLike, l as agent, m as builtinToolNames } from './client-BaItaOx5.mjs';
3
3
  import * as errore from 'errore';
4
4
  import * as ai from 'ai';
5
5
  import { Tool } from 'ai';
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- import { T as ToolContext, A as AnyAgent, S as SessionSendArgs, b as SendResult } from './client-DIanpEQ_.js';
2
- export { c as AgentDataTypes, d as AgentHooks, e as AgentOptions, a as AgentStatus, f as ApprovalData, B as BuiltInToolName, I as InferSession, g as InferUIMessage, N as NeedsApprovalMap, R as Resolvable, h as ResolvableArgs, i as SendInput, j as SessionDefaults, k as StepUsage, U as UsageSummary, W as WorkflowRunLike, l as agent, m as builtinToolNames } from './client-DIanpEQ_.js';
1
+ import { T as ToolContext, A as AnyAgent, S as SessionSendArgs, b as SendResult } from './client-BY6gceox.js';
2
+ export { c as AgentDataTypes, d as AgentHooks, e as AgentOptions, a as AgentStatus, f as ApprovalData, B as BuiltInToolName, I as InferSession, g as InferUIMessage, N as NeedsApprovalMap, R as Resolvable, h as ResolvableArgs, i as SendInput, j as SessionDefaults, k as StepUsage, U as UsageSummary, W as WorkflowRunLike, l as agent, m as builtinToolNames } from './client-BY6gceox.js';
3
3
  import * as errore from 'errore';
4
4
  import * as ai from 'ai';
5
5
  import { Tool } from 'ai';