experimental-ash 0.25.2 → 0.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/bin/ash.d.ts +4 -4
  3. package/bin/ash.js +12 -8
  4. package/dist/docs/public/channels/README.md +26 -2
  5. package/dist/docs/public/channels/discord.md +159 -0
  6. package/dist/docs/public/channels/slack.md +14 -2
  7. package/dist/src/chunks/{compile-agent-C4OrJW6C.js → compile-agent-DrIyb818.js} +1 -1
  8. package/dist/src/chunks/{dev-authored-source-watcher-PwAxalwl.js → dev-authored-source-watcher-C1WUVv9F.js} +1 -1
  9. package/dist/src/chunks/{host-F-DkwYJK.js → host-CwAcCrg7.js} +2 -2
  10. package/dist/src/chunks/paths-CWZN-XRX.js +85 -0
  11. package/dist/src/cli/commands/channels.d.ts +15 -0
  12. package/dist/src/cli/commands/channels.js +9 -0
  13. package/dist/src/cli/commands/info.js +1 -1
  14. package/dist/src/cli/run.js +1 -1
  15. package/dist/src/evals/cli/eval.js +1 -1
  16. package/dist/src/internal/application/package.js +1 -1
  17. package/dist/src/internal/process/pnpm.d.ts +28 -0
  18. package/dist/src/internal/process/pnpm.js +50 -0
  19. package/dist/src/public/channels/discord/api.d.ts +99 -0
  20. package/dist/src/public/channels/discord/api.js +167 -0
  21. package/dist/src/public/channels/discord/defaults.d.ts +9 -0
  22. package/dist/src/public/channels/discord/defaults.js +74 -0
  23. package/dist/src/public/channels/discord/discordChannel.d.ts +132 -0
  24. package/dist/src/public/channels/discord/discordChannel.js +402 -0
  25. package/dist/src/public/channels/discord/hitl.d.ts +34 -0
  26. package/dist/src/public/channels/discord/hitl.js +194 -0
  27. package/dist/src/public/channels/discord/inbound.d.ts +97 -0
  28. package/dist/src/public/channels/discord/inbound.js +238 -0
  29. package/dist/src/public/channels/discord/index.d.ts +7 -0
  30. package/dist/src/public/channels/discord/index.js +6 -0
  31. package/dist/src/public/channels/discord/responses.d.ts +11 -0
  32. package/dist/src/public/channels/discord/responses.js +40 -0
  33. package/dist/src/public/channels/discord/verify.d.ts +38 -0
  34. package/dist/src/public/channels/discord/verify.js +72 -0
  35. package/dist/src/public/channels/discord/verifyInbound.d.ts +6 -0
  36. package/dist/src/public/channels/discord/verifyInbound.js +19 -0
  37. package/dist/src/public/channels/slack/constants.d.ts +7 -0
  38. package/dist/src/public/channels/slack/constants.js +7 -0
  39. package/dist/src/public/channels/slack/slackChannel.js +2 -1
  40. package/package.json +9 -3
  41. package/dist/src/chunks/paths-DnlVBqHu.js +0 -85
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # experimental-ash
2
2
 
3
+ ## 0.26.0
4
+
5
+ ### Minor Changes
6
+
7
+ - 3553354: Add a native Discord channel for HTTP Interactions. The channel verifies Discord Ed25519 signatures, dispatches application commands, supports HITL buttons/selects/modals, sends deferred replies and followups, falls back to bot-token channel messages, supports proactive `receive(...)` sessions, and exposes a best-effort `ctx.discord.startTyping()` helper.
8
+
3
9
  ## 0.25.2
4
10
 
5
11
  ### Patch Changes
package/bin/ash.d.ts CHANGED
@@ -5,14 +5,14 @@ export interface BootstrapOptions {
5
5
  cliEntrypointPath?: string;
6
6
 
7
7
  /**
8
- * Absolute path to the script that copies static assets after compilation.
8
+ * Absolute path to the ash package root.
9
9
  */
10
- copyAssetsScriptPath?: string;
10
+ packageRoot?: string;
11
11
 
12
12
  /**
13
- * Absolute path to the ash package root.
13
+ * Absolute paths to scripts that run after workspace bootstrap compilation.
14
14
  */
15
- packageRoot?: string;
15
+ postBuildScriptPaths?: readonly string[];
16
16
 
17
17
  /**
18
18
  * Absolute path to the tsgo CLI entrypoint used for bootstrap builds.
package/bin/ash.js CHANGED
@@ -16,9 +16,11 @@ function createBootstrapOptions(overrides = {}) {
16
16
  return {
17
17
  cliEntrypointPath:
18
18
  overrides.cliEntrypointPath ?? resolve(packageRoot, "dist", "src", "cli", "run.js"),
19
- copyAssetsScriptPath:
20
- overrides.copyAssetsScriptPath ?? resolve(packageRoot, "scripts", "copy-static-assets.mjs"),
21
19
  packageRoot,
20
+ postBuildScriptPaths: overrides.postBuildScriptPaths ?? [
21
+ resolve(packageRoot, "scripts", "copy-docs.mjs"),
22
+ resolve(packageRoot, "scripts", "stamp-version-tokens.mjs"),
23
+ ],
22
24
  tsgoCliPath: overrides.tsgoCliPath,
23
25
  };
24
26
  }
@@ -85,14 +87,14 @@ async function getLatestBuildInputMtimeMs({ packageRoot }) {
85
87
  return latestMtimeMs;
86
88
  }
87
89
 
88
- async function canBuildWorkspaceCli({ copyAssetsScriptPath, exists, packageRoot }) {
90
+ async function canBuildWorkspaceCli({ exists, packageRoot, postBuildScriptPaths }) {
89
91
  for (const requiredPath of [
90
92
  resolve(packageRoot, "bin"),
91
93
  inputTsconfigPath({
92
94
  packageRoot,
93
95
  }),
94
96
  resolve(packageRoot, "src"),
95
- copyAssetsScriptPath,
97
+ ...postBuildScriptPaths,
96
98
  ]) {
97
99
  if (!(await exists(requiredPath))) {
98
100
  return false;
@@ -175,9 +177,9 @@ export async function ensureBuiltCli(overrides = {}, dependencies = {}) {
175
177
  const getEntrypointMtimeMs = dependencies.getPathMtimeMs ?? getPathMtimeMs;
176
178
  const executeCommand = dependencies.runCommand ?? runCommand;
177
179
  const packageCanBuildCli = await canBuildWorkspaceCli({
178
- copyAssetsScriptPath: options.copyAssetsScriptPath,
179
180
  exists,
180
181
  packageRoot: options.packageRoot,
182
+ postBuildScriptPaths: options.postBuildScriptPaths,
181
183
  });
182
184
 
183
185
  if (await exists(options.cliEntrypointPath)) {
@@ -210,9 +212,11 @@ export async function ensureBuiltCli(overrides = {}, dependencies = {}) {
210
212
  cwd: options.packageRoot,
211
213
  },
212
214
  );
213
- await executeCommand(process.execPath, [options.copyAssetsScriptPath], {
214
- cwd: options.packageRoot,
215
- });
215
+ for (const scriptPath of options.postBuildScriptPaths) {
216
+ await executeCommand(process.execPath, [scriptPath], {
217
+ cwd: options.packageRoot,
218
+ });
219
+ }
216
220
 
217
221
  if (await exists(options.cliEntrypointPath)) {
218
222
  return options.cliEntrypointPath;
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  title: "Channels"
3
- description: "Deliver your agent over HTTP, Slack, and custom transports."
3
+ description: "Deliver your agent over HTTP, Slack, Discord, Twilio, and custom transports."
4
4
  url: /channels
5
5
  ---
6
6
 
@@ -23,7 +23,7 @@ Ash ships the public HTTP protocol as channels:
23
23
  - `ashChannel({ auth })` for the built-in Ash protocol channel
24
24
 
25
25
  Ash also supports authored channels under `agent/channels/` for platform-specific integrations such
26
- as Slack or custom webhooks.
26
+ as Slack, Discord, Twilio, or custom webhooks.
27
27
 
28
28
  ## Filesystem Shape
29
29
 
@@ -232,6 +232,30 @@ dispatch for app mentions, direct messages, and interactions.
232
232
  For a Slack app backed by Vercel Connect, see [Slack channel setup](./slack.md) to create the Connect client
233
233
  and channel file.
234
234
 
235
+ ## Discord Channels
236
+
237
+ Discord channels are authored with `discordChannel()`:
238
+
239
+ ```ts
240
+ import { discordChannel } from "experimental-ash/channels/discord";
241
+
242
+ export default discordChannel();
243
+ ```
244
+
245
+ The channel verifies Discord's Ed25519 interaction signature headers, accepts HTTP Interactions at
246
+ `/ash/v1/discord`, responds to `PING`, dispatches application commands, and resolves HITL button,
247
+ select, and modal submissions back into Ash input responses. The default command parser uses a
248
+ string option named `message` as the agent prompt and derives auth from the invoking Discord user.
249
+
250
+ Default delivery edits the original deferred interaction response for the first agent reply, sends
251
+ followups after that, and falls back to bot-token channel messages when the interaction token can no
252
+ longer be used. Proactive `receive(discord, { channelId })` sessions also use bot-token channel
253
+ messages. Default progress handlers trigger Discord's short-lived typing indicator when bot auth is
254
+ available.
255
+
256
+ See [Discord channel setup](./discord.md) for endpoint setup, environment variables, command
257
+ registration, and overrides.
258
+
235
259
  ## Twilio Channels
236
260
 
237
261
  Twilio channels are authored with `twilioChannel()`:
@@ -0,0 +1,159 @@
1
+ ---
2
+ title: "Discord channel setup"
3
+ description: "Create a Discord-backed Ash channel for HTTP Interactions."
4
+ ---
5
+
6
+ # Discord Channel Setup
7
+
8
+ The Discord channel accepts HTTP Interactions: slash/application commands, message components, and
9
+ modal submissions. It verifies Discord's Ed25519 signature headers before parsing the request,
10
+ acknowledges commands immediately, and continues Ash work in the background.
11
+
12
+ ## Add The Channel
13
+
14
+ Create `agent/channels/discord.ts`:
15
+
16
+ ```ts
17
+ import { discordChannel } from "experimental-ash/channels/discord";
18
+
19
+ export default discordChannel();
20
+ ```
21
+
22
+ Set the credentials Ash needs for inbound verification and outbound replies:
23
+
24
+ ```bash
25
+ DISCORD_PUBLIC_KEY=...
26
+ DISCORD_APPLICATION_ID=...
27
+ DISCORD_BOT_TOKEN=...
28
+ ```
29
+
30
+ - `DISCORD_PUBLIC_KEY` verifies `X-Signature-Ed25519` and `X-Signature-Timestamp`.
31
+ - `DISCORD_APPLICATION_ID` lets Ash edit the original deferred interaction response and send
32
+ followups.
33
+ - `DISCORD_BOT_TOKEN` lets Ash send proactive channel messages and fall back after an interaction
34
+ token expires. It also powers best-effort channel typing indicators.
35
+
36
+ You can also pass the same values in config:
37
+
38
+ ```ts
39
+ export default discordChannel({
40
+ credentials: {
41
+ applicationId: "123456789012345678",
42
+ botToken: process.env.DISCORD_BOT_TOKEN,
43
+ publicKey: process.env.DISCORD_PUBLIC_KEY,
44
+ },
45
+ });
46
+ ```
47
+
48
+ By default, the channel mounts `POST /ash/v1/discord`. Paste that public URL into your Discord
49
+ application's **Interactions Endpoint URL**.
50
+
51
+ ## Register A Command
52
+
53
+ The channel does not register commands for you. Create a command with Discord's application command
54
+ API or the Developer Portal. A simple command with a string option named `message` maps cleanly to
55
+ the default Ash prompt extraction:
56
+
57
+ ```bash
58
+ curl -X PUT \
59
+ "https://discord.com/api/v10/applications/$DISCORD_APPLICATION_ID/commands" \
60
+ -H "Authorization: Bot $DISCORD_BOT_TOKEN" \
61
+ -H "Content-Type: application/json" \
62
+ -d '[
63
+ {
64
+ "name": "ask",
65
+ "description": "Ask the Ash agent",
66
+ "type": 1,
67
+ "options": [
68
+ {
69
+ "name": "message",
70
+ "description": "What should the agent do?",
71
+ "type": 3,
72
+ "required": true
73
+ }
74
+ ]
75
+ }
76
+ ]'
77
+ ```
78
+
79
+ Discord may take time to propagate global command changes. Use guild commands during development if
80
+ you need faster iteration.
81
+
82
+ ## Hooks And Delivery
83
+
84
+ `onCommand(ctx, interaction)` decides whether to dispatch a command and what auth to use. Return
85
+ `{ auth }` to dispatch or `null` to acknowledge without running the agent. The default derives auth
86
+ from the invoking Discord user.
87
+
88
+ ```ts
89
+ import { discordChannel } from "experimental-ash/channels/discord";
90
+
91
+ export default discordChannel({
92
+ onCommand(ctx, interaction) {
93
+ return {
94
+ auth: {
95
+ principalId: interaction.user.id,
96
+ principalType: "user",
97
+ authenticator: "discord",
98
+ attributes: {
99
+ channel_id: interaction.channelId,
100
+ guild_id: interaction.guildId ?? "",
101
+ },
102
+ },
103
+ };
104
+ },
105
+ events: {
106
+ "message.completed"(event, ctx) {
107
+ if (event.finishReason === "tool-calls") return;
108
+ if (event.message) ctx.discord.post(event.message);
109
+ },
110
+ },
111
+ });
112
+ ```
113
+
114
+ The default `"message.completed"` handler edits the original deferred response for the first reply,
115
+ then sends followups. If Discord rejects the interaction-token write, Ash falls back to a
116
+ bot-authenticated channel message. Outbound text is split to Discord's 2000-character content limit,
117
+ and generated messages default to `allowed_mentions: { parse: [] }`.
118
+
119
+ The default `"turn.started"` and `"actions.requested"` handlers trigger Discord's short-lived
120
+ channel typing indicator when a bot token is available. You can call `ctx.discord.startTyping()` in
121
+ custom hooks or event handlers; failures are logged and swallowed because typing is only a UX hint.
122
+
123
+ ## Human Input
124
+
125
+ Pending Ash input requests render as Discord components:
126
+
127
+ - confirmation/options render as buttons;
128
+ - `display: "select"` renders as a string select;
129
+ - freeform questions render a button that opens a Discord modal.
130
+
131
+ Component and modal submissions resume the parked Ash session automatically.
132
+
133
+ ## Proactive Sessions
134
+
135
+ Use `receive(discord, args)` from schedules or another channel to start a Discord session:
136
+
137
+ ```ts
138
+ import { defineSchedule, receive } from "experimental-ash/schedules";
139
+ import discord from "../channels/discord.js";
140
+
141
+ export default defineSchedule({
142
+ cron: "0 9 * * 1-5",
143
+ markdown: "Post the daily summary.",
144
+ channel: receive(discord, {
145
+ channelId: "123456789012345678",
146
+ initialMessage: "Daily summary",
147
+ }),
148
+ });
149
+ ```
150
+
151
+ Proactive delivery requires `DISCORD_BOT_TOKEN` or `credentials.botToken`.
152
+
153
+ ## Discord References
154
+
155
+ - [Interactions overview](https://docs.discord.com/developers/interactions/overview)
156
+ - [Receiving and responding to interactions](https://docs.discord.com/developers/interactions/receiving-and-responding)
157
+ - [Application commands](https://docs.discord.com/developers/interactions/application-commands)
158
+ - [Create message](https://docs.discord.com/developers/resources/message#create-message)
159
+ - [Trigger typing indicator](https://docs.discord.com/developers/resources/channel#trigger-typing-indicator)
@@ -71,12 +71,24 @@ If you are using an AI coding agent, install the Connect skill first:
71
71
  npx skills add https://github.com/vercel/connect --skill vercel-connect
72
72
  ```
73
73
 
74
- Then create the Slack client from the project or agent folder that will use it:
74
+ Then create the Slack client from the project or agent folder that will use it, and attach this
75
+ project as the trigger destination so Slack events are forwarded to your deployment:
75
76
 
76
77
  ```bash
77
- vercel connect create slack
78
+ vercel connect create slack --triggers
79
+ vercel connect detach <uid> --yes
80
+ vercel connect attach <uid> --triggers --trigger-path /ash/v1/slack --yes
78
81
  ```
79
82
 
83
+ `--triggers` on `create` is what turns on Slack Event Subscriptions — without it the bot installs
84
+ but Slack never delivers `app_mention` or `message.im` events to the Connect webhook. The create
85
+ step also auto-attaches the linked project at Connect's default trigger path, so detach it before
86
+ attaching the Ash path. `attach --triggers` then registers the currently-linked Vercel project as
87
+ the destination Connect forwards verified webhooks to. The `--trigger-path /ash/v1/slack` value
88
+ must match Ash's Slack channel route; the default Connect trigger path is not served by Ash. These
89
+ commands target your project's production deployment, so make sure you have run
90
+ `vercel deploy --prod` before attaching.
91
+
80
92
  Run Connect commands from the directory containing the agent's `package.json` or `vercel.json`.
81
93
  Connect uses that project context to configure project access, webhooks, and triggers. The command
82
94
  may open a browser for Slack installation or OAuth consent; finish that flow before continuing.
@@ -1,4 +1,4 @@
1
- import{i as e}from"./chunk-DSjMdhoD.js";import{$ as t,B as n,F as r,G as i,H as a,I as o,J as s,K as c,L as l,N as u,P as d,Q as f,R as p,U as m,V as h,W as g,X as _,Y as v,Z as y,et as b,q as x,tt as ee,y as te,z as ne}from"./paths-DnlVBqHu.js";import{t as re}from"./gray-matter-D-9jHwOT.js";import{n as S}from"./guards-26p6sOw3.js";import{t as ie}from"./errors-HYWjHxV6.js";import{basename as ae,dirname as C,join as w,relative as T,resolve as E}from"node:path";import{readFile as oe,readdir as se,stat as ce}from"node:fs/promises";var le=e(re(),1);function ue(e){return e}function de(e){return e}function fe(e){return e}const pe=/^---\r?\n[\s\S]*?\r?\n---(?:\r?\n|$)/;function D(e){if(!le.default.test(e))return{hasFrontmatter:!1,frontmatter:{},markdown:e};let t;try{t=(0,le.default)(e)}catch(t){throw ge(e)&&!_e(e)?Error(`Markdown frontmatter is missing a closing delimiter.`):t}if(!S(t.data))throw Error(`Markdown frontmatter must parse to an object.`);return{hasFrontmatter:!0,frontmatter:t.data,markdown:ve(t.content)}}function me(e){return fe(ne({markdown:e},`Expected authored instructions markdown to match the public Ash shape.`))}function he(e){let t=D(e);if(!t.hasFrontmatter)throw Error(`Schedule markdown must start with YAML frontmatter declaring "cron".`);if(`run`in t.frontmatter)throw Error('Markdown-form schedules do not support the "run" frontmatter key. Use a TypeScript schedule (`<name>.ts`) to author a handler.');return ue(n({...t.frontmatter,markdown:t.markdown},`Expected authored schedule markdown to match the public Ash shape.`))}function O(e,t={}){let n=D(e),r=t.slug;if(r===void 0&&!n.hasFrontmatter)throw Error(`Skill markdown must start with YAML frontmatter.`);let i=xe(n.frontmatter),a=k(i.description,`description`),o=r===void 0?Se(i.description,`description`):a??t.description??we(n.markdown,r),s={...i,description:o,markdown:n.markdown};return ye(s,i),de(h(s,`Expected authored skill markdown to match the public Ash shape.`))}function ge(e){return e.startsWith(`---
1
+ import{i as e}from"./chunk-DSjMdhoD.js";import{$ as t,B as n,F as r,G as i,H as a,I as o,J as s,K as c,L as l,N as u,P as d,Q as f,R as p,U as m,V as h,W as g,X as _,Y as v,Z as y,et as b,q as x,tt as ee,y as te,z as ne}from"./paths-CWZN-XRX.js";import{t as re}from"./gray-matter-D-9jHwOT.js";import{n as S}from"./guards-26p6sOw3.js";import{t as ie}from"./errors-HYWjHxV6.js";import{basename as ae,dirname as C,join as w,relative as T,resolve as E}from"node:path";import{readFile as oe,readdir as se,stat as ce}from"node:fs/promises";var le=e(re(),1);function ue(e){return e}function de(e){return e}function fe(e){return e}const pe=/^---\r?\n[\s\S]*?\r?\n---(?:\r?\n|$)/;function D(e){if(!le.default.test(e))return{hasFrontmatter:!1,frontmatter:{},markdown:e};let t;try{t=(0,le.default)(e)}catch(t){throw ge(e)&&!_e(e)?Error(`Markdown frontmatter is missing a closing delimiter.`):t}if(!S(t.data))throw Error(`Markdown frontmatter must parse to an object.`);return{hasFrontmatter:!0,frontmatter:t.data,markdown:ve(t.content)}}function me(e){return fe(ne({markdown:e},`Expected authored instructions markdown to match the public Ash shape.`))}function he(e){let t=D(e);if(!t.hasFrontmatter)throw Error(`Schedule markdown must start with YAML frontmatter declaring "cron".`);if(`run`in t.frontmatter)throw Error('Markdown-form schedules do not support the "run" frontmatter key. Use a TypeScript schedule (`<name>.ts`) to author a handler.');return ue(n({...t.frontmatter,markdown:t.markdown},`Expected authored schedule markdown to match the public Ash shape.`))}function O(e,t={}){let n=D(e),r=t.slug;if(r===void 0&&!n.hasFrontmatter)throw Error(`Skill markdown must start with YAML frontmatter.`);let i=xe(n.frontmatter),a=k(i.description,`description`),o=r===void 0?Se(i.description,`description`):a??t.description??we(n.markdown,r),s={...i,description:o,markdown:n.markdown};return ye(s,i),de(h(s,`Expected authored skill markdown to match the public Ash shape.`))}function ge(e){return e.startsWith(`---
2
2
  `)||e.startsWith(`---\r
3
3
  `)}function _e(e){return pe.test(e)}function ve(e){return e.replace(/^\r?\n/u,``)}function ye(e,t){let n=k(t.license,`license`);n!==void 0&&(e.license=n);let r=Ce(t.metadata,`metadata`);r!==void 0&&(e.metadata=r)}const be=[`name`];function xe(e){let t={...e};for(let e of be)delete t[e];return t}function k(e,t){if(e!=null){if(typeof e!=`string`)throw Error(`Expected "${t}" frontmatter to be a string.`);return e}}function Se(e,t){let n=k(e,t);if(n===void 0)throw Error(`Missing required "${t}" frontmatter.`);return n}function Ce(e,t){if(e==null)return;if(!S(e))throw Error(`Expected "${t}" frontmatter to be an object.`);let n=Object.entries(e).map(([e,n])=>{if(typeof n!=`string`)throw Error(`Expected "${t}.${e}" frontmatter to be a string.`);return[e,n]});return Object.fromEntries(n)}function we(e,t){let n=e.split(/\r?\n/u).map(e=>e.trim()).find(e=>e!==``&&!e.startsWith("```"));return n===void 0?`Instructions for the ${t} skill.`:n.replace(/^[#>*\-\s]+/u,``).trim()||`Instructions for the ${t} skill.`}async function A(e){let t=v(e.logicalPath);return{definition:e.lower(await e.source.readTextFile(e.sourcePath),{name:_(t)}),sourceKind:`markdown`,logicalPath:t,sourceId:l(t)}}function j(e,t){let n={moduleFileNames:[]};for(let r of e)if(r.isFile()){if(t.markdownFileName!==void 0&&r.name===t.markdownFileName){n.markdownFileName=r.name;continue}t.moduleBaseName!==void 0&&x(r.name)===t.moduleBaseName&&n.moduleFileNames.push(r.name)}return n.moduleFileNames.sort((e,t)=>e.localeCompare(t)),n}function M(e,t){let n=new Map;for(let r of e){if(!r.isFile())continue;let e=t.allowMarkdown?Te(r.name):null,i=t.allowModules?x(r.name):null,a=e??i;if(a===null)continue;let o=n.get(a);if(o===void 0&&(o={moduleFileNames:[],slotName:a},n.set(a,o)),e!==null){o.markdownFileName=r.name;continue}i!==null&&o.moduleFileNames.push(r.name)}return[...n.values()].map(e=>(e.moduleFileNames.sort((e,t)=>e.localeCompare(t)),e)).sort((e,t)=>e.slotName.localeCompare(t.slotName))}function Te(e){return!e.endsWith(`.md`)||e.length<=3?null:e.slice(0,-3)}async function N(e){let t=w(e.rootPath,e.directoryName),n=e.rootEntries.find(t=>t.name===e.directoryName);if(n===void 0)return{diagnostics:[],sources:[]};if(!n.isDirectory())return{diagnostics:[f({code:e.invalidDirectoryCode,message:e.invalidDirectoryMessage,sourcePath:t})],sources:[]};let r=[],i=[];return await P({allowMarkdown:e.allowMarkdown===!0,diagnostics:r,markdownLowerer:e.allowMarkdown===!0?e.markdownLowerer:void 0,projectSource:e.source,recursive:e.recursive,relativeDirectory:e.directoryName,rootDirectoryPath:t,sources:i,subdirectoryRelative:``,unsupportedEntryCode:e.unsupportedEntryCode,unsupportedEntryMessage:e.unsupportedEntryMessage,unsupportedFileCode:e.unsupportedFileCode,unsupportedFileMessage:e.unsupportedFileMessage,validateSegment:e.validateSegment}),{diagnostics:r,sources:i}}async function P(e){let t=e.subdirectoryRelative===``?e.rootDirectoryPath:w(e.rootDirectoryPath,e.subdirectoryRelative),n=await R(e.projectSource,t);e.recursive&&await Ee(e,n,t),(e.unsupportedFileCode!==void 0||e.unsupportedEntryCode!==void 0)&&De(e,n,t),await Oe(e,n,t)}async function Ee(e,t,n){for(let r of t){if(!r.isDirectory())continue;let t=w(n,r.name);if(e.validateSegment!==void 0){let n=e.validateSegment(r.name,t);if(n!==null){e.diagnostics.push(n);continue}}await P({allowMarkdown:e.allowMarkdown,diagnostics:e.diagnostics,markdownLowerer:e.markdownLowerer,projectSource:e.projectSource,recursive:e.recursive,relativeDirectory:e.relativeDirectory,rootDirectoryPath:e.rootDirectoryPath,sources:e.sources,subdirectoryRelative:e.subdirectoryRelative===``?r.name:w(e.subdirectoryRelative,r.name),unsupportedEntryCode:e.unsupportedEntryCode,unsupportedEntryMessage:e.unsupportedEntryMessage,unsupportedFileCode:e.unsupportedFileCode,unsupportedFileMessage:e.unsupportedFileMessage,validateSegment:e.validateSegment})}}function De(e,t,n){for(let r of t){let t=c(r),i=w(n,r.name);if(t===`directory`)continue;if(t===`other`){e.unsupportedEntryCode!==void 0&&e.diagnostics.push(f({code:e.unsupportedEntryCode,message:e.unsupportedEntryMessage?.(i,e.relativeDirectory)??`Expected "${i}" to be a regular file or directory within "${e.relativeDirectory}/".`,sourcePath:i}));continue}if(e.unsupportedFileCode===void 0)continue;let a=x(r.name)!==null,o=e.allowMarkdown&&r.name.endsWith(`.md`);a||o||e.diagnostics.push(f({code:e.unsupportedFileCode,message:e.unsupportedFileMessage?.(i,e.relativeDirectory)??`Expected "${i}" to be a supported authored source within "${e.relativeDirectory}/".`,sourcePath:i}))}}async function Oe(e,t,n){for(let r of M(t,{allowMarkdown:e.allowMarkdown,allowModules:!0})){let t=e.subdirectoryRelative===``?r.slotName:w(e.subdirectoryRelative,r.slotName),i=v(w(e.relativeDirectory,t));if(e.validateSegment!==void 0){let t=r.markdownFileName??r.moduleFileNames[0]??r.slotName,i=e.validateSegment(r.slotName,w(n,t));if(i!==null){e.diagnostics.push(i);continue}}if(r.markdownFileName!==void 0&&r.moduleFileNames.length>0){e.diagnostics.push(K(n,i,[r.markdownFileName,...r.moduleFileNames]));continue}if(r.moduleFileNames.length>1){e.diagnostics.push(q(n,i,r.moduleFileNames));continue}if(r.markdownFileName!==void 0){let t=e.subdirectoryRelative===``?r.markdownFileName:w(e.subdirectoryRelative,r.markdownFileName),n=v(w(e.relativeDirectory,t));if(e.markdownLowerer===void 0)continue;let i=await A({logicalPath:n,lower:e.markdownLowerer,source:e.projectSource,sourcePath:w(e.rootDirectoryPath,t)});e.sources.push(i);continue}let[a]=r.moduleFileNames;if(a===void 0)continue;let s=e.subdirectoryRelative===``?a:w(e.subdirectoryRelative,a);e.sources.push(o({logicalPath:v(w(e.relativeDirectory,s))}))}}const F=`discover/module-slot-collision`,I=`discover/tools-directory-invalid`,L=`discover/hooks-directory-invalid`,ke=/^[a-zA-Z][a-zA-Z0-9_-]{0,63}$/,Ae=/^[a-z][a-z0-9-]{0,63}$/,je=/^(\.?[a-z][a-z0-9-]{0,63}|\[[a-zA-Z][a-zA-Z0-9_]{0,63}\])$/,Me=/^[a-zA-Z][a-zA-Z0-9_-]{0,63}$/;async function R(e,t){let n=[...await e.readDirectory(t)];return n.sort((e,t)=>e.name.localeCompare(t.name)),n}async function z(e){let n=await B({markdownFileName:`instructions.md`,moduleBaseName:`instructions`,rootEntries:e.rootEntries,rootPath:e.rootPath,slotLabel:`instructions`,source:e.source});if(n.diagnostics.length>0||n.source!==void 0)return{diagnostics:n.diagnostics,instructions:n.source};let r=await B({markdownFileName:`system.md`,moduleBaseName:`system`,rootEntries:e.rootEntries,rootPath:e.rootPath,slotLabel:`system`,source:e.source});if(r.source!==void 0){let n=r.source.sourceKind===`markdown`?`system.md`:r.source.logicalPath;return{diagnostics:[t({code:`discover/deprecated-system-slot`,message:`The "${n}" slot is deprecated. Rename it to "${n.replace(/^system/,`instructions`)}" — the runtime still loads the legacy slot for now, but support will be removed in a future release.`,sourcePath:w(e.rootPath,n)}),...r.diagnostics],instructions:r.source}}return r.diagnostics.length>0?{diagnostics:r.diagnostics}:e.required===!1?{diagnostics:[]}:{diagnostics:[f({code:`discover/required-instructions-missing`,message:`Expected one authored instructions prompt source at "instructions.md", "instructions.ts", "instructions.cts", "instructions.mts", "instructions.js", "instructions.cjs", or "instructions.mjs".`,sourcePath:e.rootPath})]}}async function B(e){let t=j(e.rootEntries,{markdownFileName:e.markdownFileName,moduleBaseName:e.moduleBaseName});if(t.markdownFileName!==void 0&&t.moduleFileNames.length>0)return{diagnostics:[K(e.rootPath,e.slotLabel,[t.markdownFileName,...t.moduleFileNames])]};if(t.moduleFileNames.length>1)return{diagnostics:[q(e.rootPath,e.slotLabel,t.moduleFileNames)]};if(t.markdownFileName!==void 0)return{diagnostics:[],source:await A({logicalPath:e.markdownFileName,lower:me,source:e.source,sourcePath:w(e.rootPath,t.markdownFileName)})};let[n]=t.moduleFileNames;return n===void 0?{diagnostics:[]}:{diagnostics:[],source:o({logicalPath:n})}}function V(e){let t=j(e.rootEntries,{moduleBaseName:e.slotName});if(t.moduleFileNames.length>1)return{diagnostics:[q(e.rootPath,e.slotName,t.moduleFileNames)]};let[n]=t.moduleFileNames;return n===void 0?e.missingDiagnostic===void 0?{diagnostics:[]}:{diagnostics:[f({code:e.missingDiagnostic.code,message:e.missingDiagnostic.message,sourcePath:e.rootPath})]}:{diagnostics:[],module:o({logicalPath:n})}}function H(e,t){return ke.test(e)?null:f({code:`discover/tool-name-invalid`,message:`Tool filename "${e}" is not a legal tool name. Expected ASCII letters, digits, underscores, and dashes only, starting with a letter, up to 64 characters.`,sourcePath:t})}function U(e,t){return Ae.test(e)?null:f({code:`discover/connection-name-invalid`,message:`Connection filename "${e}" is not a legal connection name. Expected lowercase ASCII letters, digits, and dashes only, starting with a letter, up to 64 characters.`,sourcePath:t})}function Ne(e,t){return je.test(e)?null:f({code:`discover/channel-name-invalid`,message:`Channel path segment "${e}" is not a legal channel name. Expected lowercase kebab-case (\`my-channel\`), optionally with a leading dot (\`.well-known\`), or a path parameter form (\`[sessionId]\`).`,sourcePath:t})}function W(e,t){return Me.test(e)?null:f({code:`discover/hook-name-invalid`,message:`Hook path segment "${e}" is not a legal hook name. Expected ASCII letters, digits, underscores, and dashes only, starting with a letter, up to 64 characters.`,sourcePath:t})}function G(e){return e.rootEntries.flatMap(n=>!n.isDirectory()||e.classifyEntry(n.name,c(n))!==`unknown`?[]:[t({code:`discover/unsupported-directory`,message:e.createUnsupportedDirectoryMessage(n.name),sourcePath:w(e.rootPath,n.name)})])}function K(e,t,n){return f({code:`discover/slot-collision`,message:`Found conflicting authored sources for "${t}": ${J(n)}.`,sourcePath:e})}function q(e,t,n){return f({code:F,message:`Found multiple authored module sources for "${t}": ${J(n)}.`,sourcePath:e})}function J(e){return e.map(e=>`"${e}"`).join(`, `)}async function Pe(e){let t=`connections`,n=w(e.rootPath,t),r=e.rootEntries.find(e=>e.name===t);if(r===void 0)return{connections:[],diagnostics:[]};if(!r.isDirectory())return{connections:[],diagnostics:[f({code:`discover/connections-directory-invalid`,message:`Expected "${n}" to be a directory of authored connections.`,sourcePath:n})]};let i=await R(e.source,n),a=[],o=[],s=new Set;for(let e of M(i,{allowMarkdown:!1,allowModules:!0})){let r=v(w(t,e.slotName));if(e.moduleFileNames.length>1){s.add(e.slotName),o.push(q(n,r,e.moduleFileNames));continue}let[i]=e.moduleFileNames;if(i===void 0)continue;s.add(e.slotName);let c=U(e.slotName,w(n,i));if(c!==null){o.push(c);continue}a.push(d({connectionName:e.slotName,logicalPath:w(t,i)}))}for(let r of i){if(!r.isDirectory())continue;let i=r.name,c=w(n,i);if(s.has(i)){o.push(f({code:`discover/connection-file-folder-collision`,message:`Connection "${i}" is defined twice. Found both file-form "connections/${i}.ts" and folder-form "connections/${i}/". Use one form, not both.`,sourcePath:c}));let e=a.findIndex(e=>e.connectionName===i);e!==-1&&a.splice(e,1);continue}let l=U(i,c);if(l!==null){o.push(l);continue}let u=Fe(await R(e.source,c));if(u.length>1){o.push(f({code:F,message:`Found multiple connection definition modules inside "${v(w(t,i))}": `+u.map(e=>`"${e}"`).join(`, `),sourcePath:c}));continue}let[p]=u;if(p===void 0){o.push(f({code:`discover/connection-folder-empty`,message:`Connection folder "connections/${i}/" contains no "connection.ts" definition. Add "connections/${i}/connection.ts" or use the file form "connections/${i}.ts".`,sourcePath:c}));continue}a.push(d({connectionName:i,logicalPath:w(t,i,p)}))}return{connections:a,diagnostics:o}}function Fe(e){let t=e.filter(e=>e.isFile()),n=[];for(let e of M(t,{allowMarkdown:!1,allowModules:!0}))e.slotName===`connection`&&n.push(...e.moduleFileNames);return n}const Ie=`discover/lib-entry-unsupported`;async function Le(e){let t=await N({directoryName:`lib`,invalidDirectoryCode:`discover/lib-directory-invalid`,invalidDirectoryMessage:`Expected "${e.agentRoot}/lib" to be a directory of authored helper modules.`,recursive:!0,rootEntries:e.rootEntries,rootPath:e.agentRoot,source:e.source,unsupportedEntryCode:Ie,unsupportedEntryMessage:e=>`Expected "${e}" to be a supported authored module within "lib/".`,unsupportedFileCode:Ie,unsupportedFileMessage:e=>`Expected "${e}" to be a supported authored module within "lib/".`});return{diagnostics:t.diagnostics,lib:t.sources}}function Y(){return{kind:`disk`,async readDirectory(e){return await se(e,{withFileTypes:!0})},async readTextFile(e){return await oe(e,`utf8`)},async stat(e){try{let t=await ce(e);return t.isDirectory()?`directory`:t.isFile()?`file`:`other`}catch{return`missing`}}}}const X=`sandbox`,Z=`workspace`,Re=`sandbox`;async function ze(e){let t=[],n=e.rootEntries.find(e=>e.name===X);if(n===void 0)return Be({diagnostics:t,rootEntries:e.rootEntries,rootPath:e.rootPath});let r=w(e.rootPath,X);if(!n.isDirectory())return t.push(f({code:`discover/sandbox-directory-invalid`,message:`Expected "${r}" to be the sandbox folder.`,sourcePath:r})),{diagnostics:t,sandbox:null,sandboxWorkspace:null};let i=await R(e.source,r),a=Ve(i),s=i.find(e=>e.name===Z&&e.isDirectory());if(a.length>1)return t.push(f({code:F,message:`Found multiple sandbox definition modules inside "${v(X)}": `+a.map(e=>`"${e}"`).join(`, `),sourcePath:r})),{diagnostics:t,sandbox:null,sandboxWorkspace:null};let[c]=a,u=c!==void 0,d=s!==void 0;if(!u&&!d)return t.push(f({code:`discover/sandbox-folder-empty`,message:`Sandbox folder "sandbox/" contains neither a "sandbox.<ext>" definition nor a "workspace/" subdirectory. Add one or the other, or remove the folder.`,sourcePath:r})),{diagnostics:t,sandbox:null,sandboxWorkspace:null};let p=null;u&&(p=o({logicalPath:w(X,c)}));let m=null;if(d){let n=w(r,Z),i=v(w(X,Z)),a=await Ue(e.source,n);a===null?m={logicalPath:i,rootEntries:await He(e.source,n),sourceId:l(i),sourcePath:n}:t.push(a)}return{diagnostics:t,sandbox:p,sandboxWorkspace:m}}function Be(e){let t=j(e.rootEntries,{moduleBaseName:Re});if(t.moduleFileNames.length>1)return e.diagnostics.push(f({code:F,message:`Found multiple top-level sandbox definition modules: `+t.moduleFileNames.map(e=>`"${e}"`).join(`, `),sourcePath:e.rootPath})),{diagnostics:e.diagnostics,sandbox:null,sandboxWorkspace:null};let[n]=t.moduleFileNames;return n===void 0?{diagnostics:e.diagnostics,sandbox:null,sandboxWorkspace:null}:{diagnostics:e.diagnostics,sandbox:o({logicalPath:n}),sandboxWorkspace:null}}function Ve(e){let t=e.filter(e=>e.isFile()),n=[];for(let e of M(t,{allowMarkdown:!1,allowModules:!0}))e.slotName===Re&&n.push(...e.moduleFileNames);return n}async function He(e,t){let n=await R(e,t),r=[];for(let e of n){if(e.isDirectory()){r.push(`${e.name}/`);continue}e.isFile()&&r.push(e.name)}return r}async function Ue(e,t){return(await R(e,t)).find(e=>e.name===`skills`)===void 0?null:f({code:`discover/sandbox-workspace-skills-reserved`,message:`"sandbox/workspace/skills/" is reserved for the framework skill discovery. Move skill files under "agent/skills/" instead, or rename the subtree.`,sourcePath:w(t,`skills`)})}const We=`discover/skill-frontmatter-invalid`;async function Ge(e){let t=e.source??Y(),n=E(e.agentRoot),r=E(e.skillsDirectoryPath??w(n,`skills`)),i=v(e.skillsLogicalPath??T(n,r)),a=await t.stat(r);if(a===`missing`)return{diagnostics:[],skills:[]};if(a!==`directory`)return{diagnostics:[f({code:`discover/skills-directory-invalid`,message:`Expected "${r}" to be a directory of authored skills.`,sourcePath:r})],skills:[]};let o=[],s=new Set,l=new Map,u=await R(t,r);for(let e of u){let n=await Ke({entryName:e.name,entryType:c(e),skillsDirectoryPath:r,skillsLogicalPath:i,source:t});if(o.push(...n.diagnostics),n.skill===null||n.skillId===null||s.has(n.skillId))continue;let a=l.get(n.skillId);if(a!==void 0){o.push(f({code:`discover/skill-collision`,message:`Found conflicting authored skill sources for "${n.skillId}": "${a.logicalPath}" and "${n.logicalPath}".`,sourcePath:w(r,n.skillId)})),s.add(n.skillId),l.delete(n.skillId);continue}l.set(n.skillId,{logicalPath:n.logicalPath,skill:n.skill})}return{diagnostics:o,skills:[...l.values()].map(e=>e.skill)}}async function Ke(e){let t=w(e.skillsDirectoryPath,e.entryName);switch(i(e.entryName,e.entryType)){case`skill-package-directory`:return qe({logicalSkillsPath:e.skillsLogicalPath,skillId:e.entryName,skillRootPath:t,source:e.source});case`flat-skill-markdown`:return Je({logicalSkillsPath:e.skillsLogicalPath,skillFileName:e.entryName,skillFilePath:t,source:e.source});case`flat-skill-module`:return Ye({logicalSkillsPath:e.skillsLogicalPath,skillFileName:e.entryName});default:return{diagnostics:[f({code:`discover/skill-entry-not-directory`,message:`Expected "${t}" to be a skill directory containing SKILL.md or a flat ".md", ".ts", ".cts", ".mts", ".js", ".cjs", or ".mjs" skill file.`,sourcePath:t})],logicalPath:v(w(e.skillsLogicalPath,e.entryName)),skill:null,skillId:null}}}async function qe(e){let t=w(e.skillRootPath,`SKILL.md`),n=v(w(e.logicalSkillsPath,e.skillId,`SKILL.md`));if(await e.source.stat(t)!==`file`)return{diagnostics:[f({code:`discover/skill-markdown-missing`,message:`Expected "${t}" to exist for the "${e.skillId}" skill.`,sourcePath:e.skillRootPath})],logicalPath:n,skill:null,skillId:null};let r;try{r=O(await e.source.readTextFile(t))}catch(e){return{diagnostics:[f({code:We,message:Ze(t,e),sourcePath:t})],logicalPath:n,skill:null,skillId:null}}let i=await Xe(e.source,e.skillRootPath),a={description:r.description,logicalPath:n,markdown:r.markdown,name:e.skillId,rootPath:e.skillRootPath,skillFilePath:t,skillId:e.skillId,sourceId:l(n)};return i.assetsPath!==void 0&&(a.assetsPath=i.assetsPath),r.license!==void 0&&(a.license=r.license),r.metadata!==void 0&&(a.metadata=r.metadata),i.referencesPath!==void 0&&(a.referencesPath=i.referencesPath),i.scriptsPath!==void 0&&(a.scriptsPath=i.scriptsPath),{diagnostics:[],logicalPath:n,skill:p(a),skillId:e.skillId}}async function Je(e){let t=Qe(e.skillFileName),n=v(w(e.logicalSkillsPath,e.skillFileName)),r;try{r=O(await e.source.readTextFile(e.skillFilePath),{slug:t})}catch(t){return{diagnostics:[f({code:We,message:Ze(e.skillFilePath,t),sourcePath:e.skillFilePath})],logicalPath:n,skill:null,skillId:null}}return{diagnostics:[],logicalPath:n,skill:{definition:r,sourceKind:`markdown`,logicalPath:n,sourceId:l(n)},skillId:t}}async function Ye(e){let t=x(e.skillFileName),n=v(w(e.logicalSkillsPath,e.skillFileName));return t===null?{diagnostics:[],logicalPath:n,skill:null,skillId:null}:{diagnostics:[],logicalPath:n,skill:o({logicalPath:n}),skillId:t}}async function Xe(e,t){let n=await e.readDirectory(t),r={};for(let e of n)if(e.isDirectory())switch(g(e.name,c(e))){case`skill-assets-directory`:r.assetsPath=w(t,e.name);break;case`skill-references-directory`:r.referencesPath=w(t,e.name);break;case`skill-scripts-directory`:r.scriptsPath=w(t,e.name);break;default:break}return r}function Ze(e,t){return`Invalid authored skill frontmatter in "${e}": ${ie(t)}`}function Qe(e){return e.endsWith(`.md`)?e.slice(0,-3):e}async function Q(e){let t=e.source??Y(),n=E(e.agentRoot),r=E(e.subagentsDirectoryPath??w(n,`subagents`)),i=v(e.subagentsLogicalPath??T(n,r)),a=await t.stat(r);if(a===`missing`)return{diagnostics:[],subagents:[]};if(a!==`directory`)return{diagnostics:[f({code:`discover/subagents-directory-invalid`,message:`Expected "${r}" to be a directory of authored subagents.`,sourcePath:r})],subagents:[]};let o=await R(t,r),s=[],c=[];for(let a of o){if(a.isFile()){let t=x(a.name);if(t===null)continue;c.push($e({agentRoot:n,appRoot:e.appRoot,subagentId:t,subagentLogicalPath:w(i,a.name),subagentPath:w(r,a.name)}));continue}if(!a.isDirectory())continue;let o=await et({appRoot:e.appRoot,source:t,subagentId:a.name,subagentLogicalPath:w(i,a.name),subagentRoot:w(r,a.name)});s.push(...o.diagnostics),c.push(o.subagent)}return{diagnostics:s,subagents:c}}function $e(e){let t=o({logicalPath:e.subagentLogicalPath}),n=u({agentId:e.subagentId,agentRoot:e.agentRoot,appRoot:e.appRoot,configModule:t});return r({entryPath:e.subagentPath,logicalPath:e.subagentLogicalPath,manifest:n,rootPath:e.agentRoot,subagentId:e.subagentId})}async function et(e){let t=[],n=await R(e.source,e.subagentRoot);t.push(...G({classifyEntry:m,createUnsupportedDirectoryMessage(e){return`Ignoring unsupported directory "${e}/" in the local subagent root.`},rootEntries:n,rootPath:e.subagentRoot}));let i=await z({required:!1,rootEntries:n,rootPath:e.subagentRoot,source:e.source});t.push(...i.diagnostics);let a=V({missingDiagnostic:{code:`discover/required-subagent-config-module-missing`,message:`Expected one authored subagent config module at "agent.ts", "agent.cts", "agent.mts", "agent.js", "agent.cjs", or "agent.mjs".`},rootEntries:n,rootPath:e.subagentRoot,slotName:`agent`});t.push(...a.diagnostics);let o=await Pe({rootEntries:n,rootPath:e.subagentRoot,source:e.source});t.push(...o.diagnostics);let s=await ze({rootEntries:n,rootPath:e.subagentRoot,source:e.source});t.push(...s.diagnostics);let c=await N({directoryName:`tools`,invalidDirectoryCode:I,invalidDirectoryMessage:`Expected "${w(e.subagentRoot,`tools`)}" to be a directory of authored tools.`,recursive:!0,rootEntries:n,rootPath:e.subagentRoot,source:e.source,validateSegment:H});t.push(...c.diagnostics);let l=await N({directoryName:`hooks`,invalidDirectoryCode:L,invalidDirectoryMessage:`Expected "${w(e.subagentRoot,`hooks`)}" to be a directory of authored hooks.`,recursive:!0,rootEntries:n,rootPath:e.subagentRoot,source:e.source,validateSegment:W});t.push(...l.diagnostics);let d=await Le({agentRoot:e.subagentRoot,rootEntries:n,source:e.source});t.push(...d.diagnostics),t.push(...tt(e.subagentRoot,n));let f=await Ge({agentRoot:e.subagentRoot,source:e.source});t.push(...f.diagnostics);let p=await Q({agentRoot:e.subagentRoot,appRoot:e.appRoot,source:e.source});t.push(...p.diagnostics);let h={agentRoot:e.subagentRoot,appRoot:e.appRoot,connections:o.connections,diagnostics:t,hooks:l.sources,lib:d.lib,instructions:i.instructions,sandbox:s.sandbox,sandboxWorkspaces:s.sandboxWorkspace===null?[]:[s.sandboxWorkspace],skills:f.skills,tools:c.sources,subagents:p.subagents};a.module!==void 0&&(h.configModule=a.module);let g=u(h);return{diagnostics:t,subagent:r({entryPath:e.subagentRoot,logicalPath:e.subagentLogicalPath,manifest:g,rootPath:e.subagentRoot,subagentId:e.subagentId})}}function tt(e,t){return t.flatMap(t=>m(t.name,c(t))===`invalid-schedules-directory`?[f({code:`discover/local-subagent-schedules-invalid`,message:`Local subagent packages cannot define schedules at "${w(e,t.name)}".`,sourcePath:w(e,t.name)})]:[])}async function nt(e){let t=await N({allowMarkdown:!0,directoryName:`schedules`,invalidDirectoryCode:`discover/schedules-directory-invalid`,invalidDirectoryMessage:`Expected "${w(e.agentRoot,`schedules`)}" to be a directory of authored schedules.`,markdownLowerer:e=>he(e),recursive:!0,rootEntries:e.rootEntries,rootPath:e.agentRoot,source:e.source,unsupportedFileCode:`discover/schedule-file-unsupported`,unsupportedFileMessage:e=>`Expected "${e}" to be a TypeScript or markdown schedule file within "schedules/".`});return{diagnostics:t.diagnostics,schedules:t.sources}}async function rt(e){let t=e.source??Y(),n=E(e.appRoot),r=E(e.agentRoot),i=[],o=await it(t,n),s=await R(t,r);i.push(...G({classifyEntry:a,createUnsupportedDirectoryMessage(e){return`Ignoring unsupported directory "${e}/" in the agent root.`},rootEntries:s,rootPath:r}));let c=await z({rootEntries:s,rootPath:r,source:t});i.push(...c.diagnostics);let l=V({rootEntries:s,rootPath:r,slotName:`agent`});i.push(...l.diagnostics);let d=await N({directoryName:`channels`,invalidDirectoryCode:`discover/channels-directory-invalid`,invalidDirectoryMessage:`Expected "${w(r,`channels`)}" to be a directory of authored channels.`,recursive:!0,rootEntries:s,rootPath:r,source:t,validateSegment:Ne});i.push(...d.diagnostics);let f=await Le({agentRoot:r,rootEntries:s,source:t});i.push(...f.diagnostics);let p=await nt({agentRoot:r,rootEntries:s,source:t});i.push(...p.diagnostics);let m=await Pe({rootEntries:s,rootPath:r,source:t});i.push(...m.diagnostics);let h=await ze({rootEntries:s,rootPath:r,source:t});i.push(...h.diagnostics);let g=await N({directoryName:`tools`,invalidDirectoryCode:I,invalidDirectoryMessage:`Expected "${w(r,`tools`)}" to be a directory of authored tools.`,recursive:!0,rootEntries:s,rootPath:r,source:t,validateSegment:H});i.push(...g.diagnostics);let _=await N({directoryName:`hooks`,invalidDirectoryCode:L,invalidDirectoryMessage:`Expected "${w(r,`hooks`)}" to be a directory of authored hooks.`,recursive:!0,rootEntries:s,rootPath:r,source:t,validateSegment:W});i.push(..._.diagnostics);let v=await Ge({agentRoot:r,source:t});i.push(...v.diagnostics);let y=await Q({agentRoot:r,appRoot:n,source:t});i.push(...y.diagnostics);let b={agentRoot:r,appRoot:n,channels:d.sources,connections:m.connections,packageName:o,diagnostics:i,hooks:_.sources,lib:f.lib,instructions:c.instructions,sandbox:h.sandbox,sandboxWorkspaces:h.sandboxWorkspace===null?[]:[h.sandboxWorkspace],schedules:p.schedules,skills:v.skills,tools:g.sources,subagents:y.subagents};return l.module!==void 0&&(b.configModule=l.module),{diagnostics:i,manifest:u(b)}}async function it(e,t){try{let n=w(t,`package.json`),r=JSON.parse(await e.readTextFile(n)).name;if(typeof r!=`string`||r.length===0)return;let i=r.lastIndexOf(`/`);return i===-1?r:r.slice(i+1)}catch{return}}var at=class extends Error{diagnostic;constructor(e){super(e.message),this.name=`DiscoveryProjectResolutionError`,this.diagnostic=e}};async function ot(e=process.cwd(),t={}){let n=t.source??Y(),r=await st(n,e),i=r;for(;;){let e=await ct(n,i);if(e!==null)return e;let t=await lt(n,i);if(t!==null)return t;if(await ut(n,i))return{agentRoot:i,appRoot:i,layout:`flat`};let r=C(i);if(r===i)break;i=r}throw new at(f({code:y,message:`Could not resolve an Ash agent root from "${r}".`,sourcePath:r}))}async function st(e,t){let n=E(t);return await e.stat(n)===`directory`?n:C(n)}async function ct(e,t){if(ae(t)!==`agent`)return null;let n=C(t);return await dt(e,n)?{agentRoot:t,appRoot:n,layout:`nested`}:null}async function lt(e,t){if(!await dt(e,t))return null;let n=w(t,`agent`);return await pt(e,n)?{agentRoot:n,appRoot:t,layout:`nested`}:null}async function ut(e,t){let n=await ft(e,t);return Array.from(n.entries()).some(([e,t])=>{let n=a(e,t);return n!==`unknown`&&n!==`lib-directory`})}async function dt(e,t){let n=await ft(e,t);return Array.from(n.entries()).some(([e,t])=>s(e,t))}async function ft(e,t){if(await e.stat(t)!==`directory`)return new Map;let n=await e.readDirectory(t);return new Map(n.map(e=>[e.name,c(e)]))}async function pt(e,t){return await e.stat(t)===`directory`}var $=class extends Error{result;constructor(e){super(gt({diagnostics:e.diagnostics,diagnosticsPath:e.paths.diagnosticsPath})),this.name=`CompileAgentError`,this.result=e}};async function mt(e={}){let t=e.source??Y(),n=await ot(e.startPath,{source:t}),r=await rt({...n,source:t}),i=await te({appRoot:n.appRoot,diagnostics:r.diagnostics,manifest:r.manifest}),a={diagnostics:r.diagnostics,manifest:i.compiledManifest,metadata:i.metadata,paths:i.paths,project:n};if(b(r.diagnostics))throw new $(a);return ht(r.diagnostics),a}function ht(e){let t=e.filter(e=>e.severity===`warning`);if(t.length!==0)for(let e of t)console.warn(`Warning [${e.code}]: ${e.message}\n source: ${e.sourcePath}`)}function gt(e){let t=ee(e.diagnostics),n=[`Discovery failed with ${t.errors} error(s) and ${t.warnings} warning(s).`];if(e.diagnosticsPath!==void 0&&n.push(`Diagnostics artifact: ${e.diagnosticsPath}`),e.diagnostics.length===0)return n.join(`
4
4
  `);n.push(`Discovery diagnostics:`);for(let t of e.diagnostics)n.push(`- ${_t(t.severity)}: ${t.message}`),n.push(` source: ${t.sourcePath}`);return n.join(`
@@ -1 +1 @@
1
- import{A as e,s as t}from"./paths-DnlVBqHu.js";import{t as n}from"./errors-HYWjHxV6.js";import{getDevelopmentEnvironmentFilePaths as r,loadDevelopmentEnvironmentFiles as i}from"../cli/dev/environment.js";import{a,c as o,i as s,o as c,r as l,s as u}from"./host-F-DkwYJK.js";import{createRequire as d}from"node:module";import*as f from"node:path";import{dirname as p,isAbsolute as m,join as h,relative as g,resolve as _,sep as v}from"node:path";import{lstat as y,open as b,readFile as x,readdir as S,realpath as C,stat as w}from"node:fs/promises";import{existsSync as ee,stat as te,unwatchFile as T,watch as ne,watchFile as re}from"node:fs";import{parse as ie}from"#compiled/jsonc-parser/index.js";import{EventEmitter as ae}from"node:events";import{Readable as oe}from"node:stream";import{type as se}from"node:os";const E={FILE_TYPE:`files`,DIR_TYPE:`directories`,FILE_DIR_TYPE:`files_directories`,EVERYTHING_TYPE:`all`},D={root:`.`,fileFilter:e=>!0,directoryFilter:e=>!0,type:E.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(D);const O=`READDIRP_RECURSIVE_ERROR`,ce=new Set([`ENOENT`,`EPERM`,`EACCES`,`ELOOP`,O]),k=[E.DIR_TYPE,E.EVERYTHING_TYPE,E.FILE_DIR_TYPE,E.FILE_TYPE],le=new Set([E.DIR_TYPE,E.EVERYTHING_TYPE,E.FILE_DIR_TYPE]),ue=new Set([E.EVERYTHING_TYPE,E.FILE_DIR_TYPE,E.FILE_TYPE]),de=e=>ce.has(e.code),fe=process.platform===`win32`,pe=e=>!0,A=e=>{if(e===void 0)return pe;if(typeof e==`function`)return e;if(typeof e==`string`){let t=e.trim();return e=>e.basename===t}if(Array.isArray(e)){let t=e.map(e=>e.trim());return e=>t.some(t=>e.basename===t)}return pe};var me=class extends oe{parents;reading;parent;_stat;_maxDepth;_wantsDir;_wantsFile;_wantsEverything;_root;_isDirent;_statsProp;_rdOptions;_fileFilter;_directoryFilter;constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark});let t={...D,...e},{root:n,type:r}=t;this._fileFilter=A(t.fileFilter),this._directoryFilter=A(t.directoryFilter);let i=t.lstat?y:w;fe?this._stat=e=>i(e,{bigint:!0}):this._stat=i,this._maxDepth=t.depth!=null&&Number.isSafeInteger(t.depth)?t.depth:D.depth,this._wantsDir=r?le.has(r):!1,this._wantsFile=r?ue.has(r):!1,this._wantsEverything=r===E.EVERYTHING_TYPE,this._root=_(n),this._isDirent=!t.alwaysStat,this._statsProp=this._isDirent?`dirent`:`stats`,this._rdOptions={encoding:`utf8`,withFileTypes:this._isDirent},this.parents=[this._exploreDir(n,1)],this.reading=!1,this.parent=void 0}async _read(e){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&e>0;){let t=this.parent,n=t&&t.files;if(n&&n.length>0){let{path:r,depth:i}=t,a=n.splice(0,e).map(e=>this._formatEntry(e,r)),o=await Promise.all(a);for(let t of o){if(!t)continue;if(this.destroyed)return;let n=await this._getEntryType(t);n===`directory`&&this._directoryFilter(t)?(i<=this._maxDepth&&this.parents.push(this._exploreDir(t.fullPath,i+1)),this._wantsDir&&(this.push(t),e--)):(n===`file`||this._includeAsFile(t))&&this._fileFilter(t)&&this._wantsFile&&(this.push(t),e--)}}else{let e=this.parents.pop();if(!e){this.push(null);break}if(this.parent=await e,this.destroyed)return}}}catch(e){this.destroy(e)}finally{this.reading=!1}}}async _exploreDir(e,t){let n;try{n=await S(e,this._rdOptions)}catch(e){this._onError(e)}return{files:n,depth:t,path:e}}async _formatEntry(e,t){let n,r=this._isDirent?e.name:e;try{let i=_(h(t,r));n={path:g(this._root,i),fullPath:i,basename:r},n[this._statsProp]=this._isDirent?e:await this._stat(i)}catch(e){this._onError(e);return}return n}_onError(e){de(e)&&!this.destroyed?this.emit(`warn`,e):this.destroy(e)}async _getEntryType(e){if(!e&&this._statsProp in e)return``;let t=e[this._statsProp];if(t.isFile())return`file`;if(t.isDirectory())return`directory`;if(t&&t.isSymbolicLink()){let t=e.fullPath;try{let e=await C(t),n=await y(e);if(n.isFile())return`file`;if(n.isDirectory()){let n=e.length;if(t.startsWith(e)&&t.substr(n,1)===v){let n=Error(`Circular symlink detected: "${t}" points to "${e}"`);return n.code=O,this._onError(n)}return`directory`}}catch(e){return this._onError(e),``}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}};function he(e,t={}){let n=t.entryType||t.type;if(n===`both`&&(n=E.FILE_DIR_TYPE),n&&(t.type=n),!e)throw Error(`readdirp: root argument is required. Usage: readdirp(root, options)`);if(typeof e!=`string`)throw TypeError(`readdirp: root argument must be a string. Usage: readdirp(root, options)`);if(n&&!k.includes(n))throw Error(`readdirp: Invalid type passed. Use one of ${k.join(`, `)}`);return t.root=e,new me(t)}const j=()=>{},M=process.platform,N=M===`win32`,ge=M===`darwin`,_e=M===`linux`,ve=M===`freebsd`,ye=se()===`OS400`,P={ALL:`all`,READY:`ready`,ADD:`add`,CHANGE:`change`,ADD_DIR:`addDir`,UNLINK:`unlink`,UNLINK_DIR:`unlinkDir`,RAW:`raw`,ERROR:`error`},F=P,be={lstat:y,stat:w},I=`listeners`,L=`errHandlers`,R=`rawEmitters`,xe=[I,L,R],Se=new Set(`3dm.3ds.3g2.3gp.7z.a.aac.adp.afdesign.afphoto.afpub.ai.aif.aiff.alz.ape.apk.appimage.ar.arj.asf.au.avi.bak.baml.bh.bin.bk.bmp.btif.bz2.bzip2.cab.caf.cgm.class.cmx.cpio.cr2.cur.dat.dcm.deb.dex.djvu.dll.dmg.dng.doc.docm.docx.dot.dotm.dra.DS_Store.dsk.dts.dtshd.dvb.dwg.dxf.ecelp4800.ecelp7470.ecelp9600.egg.eol.eot.epub.exe.f4v.fbs.fh.fla.flac.flatpak.fli.flv.fpx.fst.fvt.g3.gh.gif.graffle.gz.gzip.h261.h263.h264.icns.ico.ief.img.ipa.iso.jar.jpeg.jpg.jpgv.jpm.jxr.key.ktx.lha.lib.lvp.lz.lzh.lzma.lzo.m3u.m4a.m4v.mar.mdi.mht.mid.midi.mj2.mka.mkv.mmr.mng.mobi.mov.movie.mp3.mp4.mp4a.mpeg.mpg.mpga.mxu.nef.npx.numbers.nupkg.o.odp.ods.odt.oga.ogg.ogv.otf.ott.pages.pbm.pcx.pdb.pdf.pea.pgm.pic.png.pnm.pot.potm.potx.ppa.ppam.ppm.pps.ppsm.ppsx.ppt.pptm.pptx.psd.pya.pyc.pyo.pyv.qt.rar.ras.raw.resources.rgb.rip.rlc.rmf.rmvb.rpm.rtf.rz.s3m.s7z.scpt.sgi.shar.snap.sil.sketch.slk.smv.snk.so.stl.suo.sub.swf.tar.tbz.tbz2.tga.tgz.thmx.tif.tiff.tlz.ttc.ttf.txz.udf.uvh.uvi.uvm.uvp.uvs.uvu.viv.vob.war.wav.wax.wbmp.wdp.weba.webm.webp.whl.wim.wm.wma.wmv.wmx.woff.woff2.wrm.wvx.xbm.xif.xla.xlam.xls.xlsb.xlsm.xlsx.xlt.xltm.xltx.xm.xmind.xpi.xpm.xwd.xz.z.zip.zipx`.split(`.`)),Ce=e=>Se.has(f.extname(e).slice(1).toLowerCase()),z=(e,t)=>{e instanceof Set?e.forEach(t):t(e)},B=(e,t,n)=>{let r=e[t];r instanceof Set||(e[t]=r=new Set([r])),r.add(n)},we=e=>t=>{let n=e[t];n instanceof Set?n.clear():delete e[t]},V=(e,t,n)=>{let r=e[t];r instanceof Set?r.delete(n):r===n&&delete e[t]},H=e=>e instanceof Set?e.size===0:!e,U=new Map;function W(e,t,n,r,i){let a=(t,r)=>{n(e),i(t,r,{watchedPath:e}),r&&e!==r&&G(f.resolve(e,r),I,f.join(e,r))};try{return ne(e,{persistent:t.persistent},a)}catch(e){r(e);return}}const G=(e,t,n,r,i)=>{let a=U.get(e);a&&z(a[t],e=>{e(n,r,i)})},Te=(e,t,n,r)=>{let{listener:i,errHandler:a,rawEmitter:o}=r,s=U.get(t),c;if(!n.persistent)return c=W(e,n,i,a,o),c?c.close.bind(c):void 0;if(s)B(s,I,i),B(s,L,a),B(s,R,o);else{if(c=W(e,n,G.bind(null,t,I),a,G.bind(null,t,R)),!c)return;c.on(F.ERROR,async n=>{let r=G.bind(null,t,L);if(s&&(s.watcherUnusable=!0),N&&n.code===`EPERM`)try{await(await b(e,`r`)).close(),r(n)}catch{}else r(n)}),s={listeners:i,errHandlers:a,rawEmitters:o,watcher:c},U.set(t,s)}return()=>{V(s,I,i),V(s,L,a),V(s,R,o),H(s.listeners)&&(s.watcher.close(),U.delete(t),xe.forEach(we(s)),s.watcher=void 0,Object.freeze(s))}},K=new Map,Ee=(e,t,n,r)=>{let{listener:i,rawEmitter:a}=r,o=K.get(t),s=o&&o.options;return s&&(s.persistent<n.persistent||s.interval>n.interval)&&(T(t),o=void 0),o?(B(o,I,i),B(o,R,a)):(o={listeners:i,rawEmitters:a,options:n,watcher:re(t,n,(n,r)=>{z(o.rawEmitters,e=>{e(F.CHANGE,t,{curr:n,prev:r})});let i=n.mtimeMs;(n.size!==r.size||i>r.mtimeMs||i===0)&&z(o.listeners,t=>t(e,n))})},K.set(t,o)),()=>{V(o,I,i),V(o,R,a),H(o.listeners)&&(K.delete(t),T(t),o.options=o.watcher=void 0,Object.freeze(o))}};var De=class{fsw;_boundHandleError;constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let n=this.fsw.options,r=f.dirname(e),i=f.basename(e);this.fsw._getWatchedDir(r).add(i);let a=f.resolve(e),o={persistent:n.persistent};t||=j;let s;return n.usePolling?(o.interval=n.interval!==n.binaryInterval&&Ce(i)?n.binaryInterval:n.interval,s=Ee(e,a,o,{listener:t,rawEmitter:this.fsw._emitRaw})):s=Te(e,a,o,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),s}_handleFile(e,t,n){if(this.fsw.closed)return;let r=f.dirname(e),i=f.basename(e),a=this.fsw._getWatchedDir(r),o=t;if(a.has(i))return;let s=async(t,n)=>{if(this.fsw._throttle(`watch`,e,5)){if(!n||n.mtimeMs===0)try{let n=await w(e);if(this.fsw.closed)return;let r=n.atimeMs,i=n.mtimeMs;if((!r||r<=i||i!==o.mtimeMs)&&this.fsw._emit(F.CHANGE,e,n),(ge||_e||ve)&&o.ino!==n.ino){this.fsw._closeFile(t),o=n;let r=this._watchWithNodeFs(e,s);r&&this.fsw._addPathCloser(t,r)}else o=n}catch{this.fsw._remove(r,i)}else if(a.has(i)){let t=n.atimeMs,r=n.mtimeMs;(!t||t<=r||r!==o.mtimeMs)&&this.fsw._emit(F.CHANGE,e,n),o=n}}},c=this._watchWithNodeFs(e,s);if(!(n&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(F.ADD,e,0))return;this.fsw._emit(F.ADD,e,t)}return c}async _handleSymlink(e,t,n,r){if(this.fsw.closed)return;let i=e.fullPath,a=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let t;try{t=await C(n)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(r)?this.fsw._symlinkPaths.get(i)!==t&&(this.fsw._symlinkPaths.set(i,t),this.fsw._emit(F.CHANGE,n,e.stats)):(a.add(r),this.fsw._symlinkPaths.set(i,t),this.fsw._emit(F.ADD,n,e.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(e,t,n,r,i,a,o){e=f.join(e,``);let s=r?`${e}:${r}`:e;if(o=this.fsw._throttle(`readdir`,s,1e3),!o)return;let c=this.fsw._getWatchedDir(n.path),l=new Set,u=this.fsw._readdirp(e,{fileFilter:e=>n.filterPath(e),directoryFilter:e=>n.filterDir(e)});if(u)return u.on(`data`,async o=>{if(this.fsw.closed){u=void 0;return}let s=o.path,d=f.join(e,s);if(l.add(s),!(o.stats.isSymbolicLink()&&await this._handleSymlink(o,e,d,s))){if(this.fsw.closed){u=void 0;return}(s===r||!r&&!c.has(s))&&(this.fsw._incrReadyCount(),d=f.join(i,f.relative(i,d)),this._addToNodeFs(d,t,n,a+1))}}).on(F.ERROR,this._boundHandleError),new Promise((t,s)=>{if(!u)return s();u.once(`end`,()=>{if(this.fsw.closed){u=void 0;return}let s=o?o.clear():!1;t(void 0),c.getChildren().filter(t=>t!==e&&!l.has(t)).forEach(t=>{this.fsw._remove(e,t)}),u=void 0,s&&this._handleRead(e,!1,n,r,i,a,o)})})}async _handleDir(e,t,n,r,i,a,o){let s=this.fsw._getWatchedDir(f.dirname(e)),c=s.has(f.basename(e));!(n&&this.fsw.options.ignoreInitial)&&!i&&!c&&this.fsw._emit(F.ADD_DIR,e,t),s.add(f.basename(e)),this.fsw._getWatchedDir(e);let l,u=this.fsw.options.depth;if((u==null||r<=u)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(e,n,a,i,e,r,void 0),this.fsw.closed))return;l=this._watchWithNodeFs(e,(t,n)=>{n&&n.mtimeMs===0||this._handleRead(t,!1,a,i,e,r,void 0)})}return l}async _addToNodeFs(e,t,n,r,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(e)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(e);n&&(o.filterPath=e=>n.filterPath(e),o.filterDir=e=>n.filterDir(e));try{let n=await be[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,n))return a(),!1;let s=this.fsw.options.followSymlinks,c;if(n.isDirectory()){let a=f.resolve(e),l=s?await C(e):e;if(this.fsw.closed||(c=await this._handleDir(o.watchPath,n,t,r,i,o,l),this.fsw.closed))return;a!==l&&l!==void 0&&this.fsw._symlinkPaths.set(a,l)}else if(n.isSymbolicLink()){let i=s?await C(e):e;if(this.fsw.closed)return;let a=f.dirname(o.watchPath);if(this.fsw._getWatchedDir(a).add(o.watchPath),this.fsw._emit(F.ADD,o.watchPath,n),c=await this._handleDir(a,n,t,r,e,o,i),this.fsw.closed)return;i!==void 0&&this.fsw._symlinkPaths.set(f.resolve(e),i)}else c=this._handleFile(o.watchPath,n,t);return a(),c&&this.fsw._addPathCloser(e,c),!1}catch(t){if(this.fsw._handleError(t))return a(),e}}};const Oe=/\\/g,q=/\/\//g,ke=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,Ae=/^\.[/\\]/;function J(e){return Array.isArray(e)?e:[e]}const Y=e=>typeof e==`object`&&!!e&&!(e instanceof RegExp);function je(e){return typeof e==`function`?e:typeof e==`string`?t=>e===t:e instanceof RegExp?t=>e.test(t):typeof e==`object`&&e?t=>{if(e.path===t)return!0;if(e.recursive){let n=f.relative(e.path,t);return n?!n.startsWith(`..`)&&!f.isAbsolute(n):!1}return!1}:()=>!1}function Me(e){if(typeof e!=`string`)throw Error(`string expected`);e=f.normalize(e),e=e.replace(/\\/g,`/`);let t=!1;return e.startsWith(`//`)&&(t=!0),e=e.replace(q,`/`),t&&(e=`/`+e),e}function X(e,t,n){let r=Me(t);for(let t=0;t<e.length;t++){let i=e[t];if(i(r,n))return!0}return!1}function Ne(e,t){if(e==null)throw TypeError(`anymatch: specify first argument`);let n=J(e).map(e=>je(e));return t==null?(e,t)=>X(n,e,t):X(n,t)}const Z=e=>{let t=J(e).flat();if(!t.every(e=>typeof e==`string`))throw TypeError(`Non-string provided as watch path: ${t}`);return t.map(Pe)},Q=e=>{let t=e.replace(Oe,`/`),n=!1;return t.startsWith(`//`)&&(n=!0),t=t.replace(q,`/`),n&&(t=`/`+t),t},Pe=e=>Q(f.normalize(Q(e))),Fe=(e=``)=>t=>typeof t==`string`?Pe(f.isAbsolute(t)?t:f.join(e,t)):t,Ie=(e,t)=>f.isAbsolute(e)?e:f.join(t,e),Le=Object.freeze(new Set);var Re=class{path;_removeWatcher;items;constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==`.`&&e!==`..`&&t.add(e)}async remove(e){let{items:t}=this;if(!t||(t.delete(e),t.size>0))return;let n=this.path;try{await S(n)}catch{this._removeWatcher&&this._removeWatcher(f.dirname(n),f.basename(n))}}has(e){let{items:t}=this;if(t)return t.has(e)}getChildren(){let{items:e}=this;return e?[...e.values()]:[]}dispose(){this.items.clear(),this.path=``,this._removeWatcher=j,this.items=Le,Object.freeze(this)}},ze=class{fsw;path;watchPath;fullWatchPath;dirParts;followSymlinks;statMethod;constructor(e,t,n){this.fsw=n;let r=e;this.path=e=e.replace(Ae,``),this.watchPath=r,this.fullWatchPath=f.resolve(r),this.dirParts=[],this.dirParts.forEach(e=>{e.length>1&&e.pop()}),this.followSymlinks=t,this.statMethod=t?`stat`:`lstat`}entryPath(e){return f.join(this.watchPath,f.relative(this.watchPath,e.fullPath))}filterPath(e){let{stats:t}=e;if(t&&t.isSymbolicLink())return this.filterDir(e);let n=this.entryPath(e);return this.fsw._isntIgnored(n,t)&&this.fsw._hasReadPermissions(t)}filterDir(e){return this.fsw._isntIgnored(this.entryPath(e),e.stats)}},Be=class extends ae{closed;options;_closers;_ignoredPaths;_throttled;_streams;_symlinkPaths;_watched;_pendingWrites;_pendingUnlinks;_readyCount;_emitReady;_closePromise;_userIgnored;_readyEmitted;_emitRaw;_boundRemove;_nodeFsHandler;constructor(e={}){super(),this.closed=!1,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._streams=new Set,this._symlinkPaths=new Map,this._watched=new Map,this._pendingWrites=new Map,this._pendingUnlinks=new Map,this._readyCount=0,this._readyEmitted=!1;let t=e.awaitWriteFinish,n={stabilityThreshold:2e3,pollInterval:100},r={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...e,ignored:e.ignored?J(e.ignored):J([]),awaitWriteFinish:t===!0?n:typeof t==`object`?{...n,...t}:!1};ye&&(r.usePolling=!0),r.atomic===void 0&&(r.atomic=!r.usePolling);let i=process.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let e=i.toLowerCase();e===`false`||e===`0`?r.usePolling=!1:e===`true`||e===`1`?r.usePolling=!0:r.usePolling=!!e}let a=process.env.CHOKIDAR_INTERVAL;a&&(r.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=j,this._readyEmitted=!0,process.nextTick(()=>this.emit(P.READY)))},this._emitRaw=(...e)=>this.emit(P.RAW,...e),this._boundRemove=this._remove.bind(this),this.options=r,this._nodeFsHandler=new De(this),Object.freeze(r)}_addIgnoredPath(e){if(Y(e)){for(let t of this._ignoredPaths)if(Y(t)&&t.path===e.path&&t.recursive===e.recursive)return}this._ignoredPaths.add(e)}_removeIgnoredPath(e){if(this._ignoredPaths.delete(e),typeof e==`string`)for(let t of this._ignoredPaths)Y(t)&&t.path===e&&this._ignoredPaths.delete(t)}add(e,t,n){let{cwd:r}=this.options;this.closed=!1,this._closePromise=void 0;let i=Z(e);return r&&(i=i.map(e=>Ie(e,r))),i.forEach(e=>{this._removeIgnoredPath(e)}),this._userIgnored=void 0,this._readyCount||=0,this._readyCount+=i.length,Promise.all(i.map(async e=>{let r=await this._nodeFsHandler._addToNodeFs(e,!n,void 0,0,t);return r&&this._emitReady(),r})).then(e=>{this.closed||e.forEach(e=>{e&&this.add(f.dirname(e),f.basename(t||e))})}),this}unwatch(e){if(this.closed)return this;let t=Z(e),{cwd:n}=this.options;return t.forEach(e=>{!f.isAbsolute(e)&&!this._closers.has(e)&&(n&&(e=f.join(n,e)),e=f.resolve(e)),this._closePath(e),this._addIgnoredPath(e),this._watched.has(e)&&this._addIgnoredPath({path:e,recursive:!0}),this._userIgnored=void 0}),this}close(){if(this._closePromise)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(t=>{let n=t();n instanceof Promise&&e.push(n)})),this._streams.forEach(e=>e.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(e=>e.dispose()),this._closers.clear(),this._watched.clear(),this._streams.clear(),this._symlinkPaths.clear(),this._throttled.clear(),this._closePromise=e.length?Promise.all(e).then(()=>void 0):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,n)=>{let r=(this.options.cwd?f.relative(this.options.cwd,n):n)||`.`;e[r]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(e,...t),e!==P.ERROR&&this.emit(P.ALL,e,...t)}async _emit(e,t,n){if(this.closed)return;let r=this.options;N&&(t=f.normalize(t)),r.cwd&&(t=f.relative(r.cwd,t));let i=[t];n!=null&&i.push(n);let a=r.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(t)))return o.lastChange=new Date,this;if(r.atomic){if(e===P.UNLINK)return this._pendingUnlinks.set(t,[e,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((e,t)=>{this.emit(...e),this.emit(P.ALL,...e),this._pendingUnlinks.delete(t)})},typeof r.atomic==`number`?r.atomic:100),this;e===P.ADD&&this._pendingUnlinks.has(t)&&(e=P.CHANGE,this._pendingUnlinks.delete(t))}if(a&&(e===P.ADD||e===P.CHANGE)&&this._readyEmitted)return this._awaitWriteFinish(t,a.stabilityThreshold,e,(t,n)=>{t?(e=P.ERROR,i[0]=t,this.emitWithAll(e,i)):n&&(i.length>1?i[1]=n:i.push(n),this.emitWithAll(e,i))}),this;if(e===P.CHANGE&&!this._throttle(P.CHANGE,t,50))return this;if(r.alwaysStat&&n===void 0&&(e===P.ADD||e===P.ADD_DIR||e===P.CHANGE)){let e=r.cwd?f.join(r.cwd,t):t,n;try{n=await w(e)}catch{}if(!n||this.closed)return;i.push(n)}return this.emitWithAll(e,i),this}_handleError(e){let t=e&&e.code;return e&&t!==`ENOENT`&&t!==`ENOTDIR`&&(!this.options.ignorePermissionErrors||t!==`EPERM`&&t!==`EACCES`)&&this.emit(P.ERROR,e),e||this.closed}_throttle(e,t,n){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e);if(!r)throw Error(`invalid throttle`);let i=r.get(t);if(i)return i.count++,!1;let a,o=()=>{let e=r.get(t),n=e?e.count:0;return r.delete(t),clearTimeout(a),e&&clearTimeout(e.timeoutObject),n};a=setTimeout(o,n);let s={timeoutObject:a,clear:o,count:0};return r.set(t,s),s}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,n,r){let i=this.options.awaitWriteFinish;if(typeof i!=`object`)return;let a=i.pollInterval,o,s=e;this.options.cwd&&!f.isAbsolute(e)&&(s=f.join(this.options.cwd,e));let c=new Date,l=this._pendingWrites;function u(n){te(s,(i,s)=>{if(i||!l.has(e)){i&&i.code!==`ENOENT`&&r(i);return}let c=Number(new Date);n&&s.size!==n.size&&(l.get(e).lastChange=c),c-l.get(e).lastChange>=t?(l.delete(e),r(void 0,s)):o=setTimeout(u,a,s)})}l.has(e)||(l.set(e,{lastChange:c,cancelWait:()=>(l.delete(e),clearTimeout(o),n)}),o=setTimeout(u,a))}_isIgnored(e,t){if(this.options.atomic&&ke.test(e))return!0;if(!this._userIgnored){let{cwd:e}=this.options,t=(this.options.ignored||[]).map(Fe(e)),n=[...[...this._ignoredPaths].map(Fe(e)),...t];this._userIgnored=Ne(n,void 0)}return this._userIgnored(e,t)}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e){return new ze(e,this.options.followSymlinks,this)}_getWatchedDir(e){let t=f.resolve(e);return this._watched.has(t)||this._watched.set(t,new Re(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){return this.options.ignorePermissionErrors?!0:!!(Number(e.mode)&256)}_remove(e,t,n){let r=f.join(e,t),i=f.resolve(r);if(n??=this._watched.has(r)||this._watched.has(i),!this._throttle(`remove`,r,100))return;!n&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(e=>this._remove(r,e));let a=this._getWatchedDir(e),o=a.has(t);a.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let s=r;if(this.options.cwd&&(s=f.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(s)&&this._pendingWrites.get(s).cancelWait()===P.ADD)return;this._watched.delete(r),this._watched.delete(i);let c=n?P.UNLINK_DIR:P.UNLINK;o&&!this._isIgnored(r)&&this._emit(c,r),this._closePath(r)}_closePath(e){this._closeFile(e);let t=f.dirname(e);this._getWatchedDir(t).remove(f.basename(e))}_closeFile(e){let t=this._closers.get(e);t&&(t.forEach(e=>e()),this._closers.delete(e))}_addPathCloser(e,t){if(!t)return;let n=this._closers.get(e);n||(n=[],this._closers.set(e,n)),n.push(t)}_readdirp(e,t){if(this.closed)return;let n=he(e,{type:P.ALL,alwaysStat:!0,lstat:!0,...t,depth:0});return this._streams.add(n),n.once(`close`,()=>{n=void 0}),n.once(`end`,()=>{n&&=(this._streams.delete(n),void 0)}),n}};function Ve(e,t={}){let n=new Be(t);return n.add(e),n}const He=[`pnpm-lock.yaml`,`package-lock.json`,`yarn.lock`,`bun.lock`,`bun.lockb`],Ue=[`.git`,`pnpm-workspace.yaml`],We=[`**/.ash/**`,`**/.git/**`,`**/.output/**`,`**/.turbo/**`,`**/.vercel/**`,`**/.workflow-data/**`,`**/node_modules/**`];async function Ge(r){let d=r.schedulesEnabled!==!1,f=r.preparedHost,p=!1,m=Promise.resolve(),h,g=new Set,_=new Set,v=await qe(f),y=Je(v),b=Ve(v,{awaitWriteFinish:{pollInterval:50,stabilityThreshold:160},followSymlinks:!1,ignoreInitial:!0,ignored:We}),x=Ke(b),S=()=>{p||(m=m.then(async()=>{if(p)return;let m=g.size,h=[..._];g.clear(),_.clear();let v=f,x=Xe(v.appRoot,h);console.log(`[ash:dev] change detected (${m} event${m===1?``:`s`}), rebuilding authored artifacts...`);try{x&&i(v.appRoot);let n=await s(v.appRoot);await l({appRoot:n.appRoot,log:e=>console.log(e)});let p=o({appRoot:n.appRoot,dev:r.nitro.options.dev===!0}),m=u(r.nitro,{artifactsConfig:p,next:c(n),previous:c(v)}),h=a(r.nitro,{artifactsConfig:p,dispatchModulePath:e(`src/internal/nitro/routes/schedule-task.ts`),next:d?n.scheduleRegistrations:[],previous:d?v.scheduleRegistrations:[]});t(),f=n,m||h||x?(console.log(`[ash:dev] structural change detected, reloading Nitro worker...`),await r.nitro.hooks.callHook(`rollup:reload`)):console.log(`[ash:dev] authored artifacts updated.`),y=Ye({nextWatchPaths:await qe(n),previousWatchPathsByKey:y,watcher:b})}catch(e){console.error(`[ash:dev] rebuild failed: ${n(e)}`)}}).catch(e=>{console.error(`[ash:dev] rebuild queue error: ${n(e)}`)}))};return b.on(`all`,(e,t)=>{p||(g.add(`${e}:${t}`),_.add(t),h!==void 0&&clearTimeout(h),h=setTimeout(()=>{h=void 0,S()},120))}),await x,{async close(){p=!0,h!==void 0&&(clearTimeout(h),h=void 0),await b.close(),await m}}}async function Ke(e){await new Promise((t,n)=>{e.on(`ready`,()=>{t()}),e.on(`error`,e=>{n(e)})})}async function qe(e){let t=new Set([e.compileResult.project.agentRoot,h(e.appRoot,`package.json`),h(e.appRoot,`jsconfig.json`),h(e.appRoot,`tsconfig.json`),h(e.appRoot,`tsconfig.*.json`)]),n=await $e(e.appRoot);for(let n of r(e.appRoot))t.add(n);for(let e of n)t.add(e);for(let n of Ze(e.appRoot))for(let e of He)t.add(h(n,e));return[...t].sort((e,t)=>e.localeCompare(t))}function Je(e){let t=new Map;for(let n of e)t.set($(n),n);return t}function Ye(e){let t=Je(e.nextWatchPaths),n=[],r=[];for(let[r,i]of t)e.previousWatchPathsByKey.has(r)||n.push(i);for(let[n,i]of e.previousWatchPathsByKey)t.has(n)||r.push(i);return n.length>0&&e.watcher.add(n),r.length>0&&e.watcher.unwatch(r),t}function $(e){return e.replaceAll(`\\`,`/`)}function Xe(e,t){let n=new Set(r(e).map(e=>$(_(e))));return t.some(e=>n.has($(_(e))))}function Ze(e){let t=[],n=_(e);for(;t.push(n),!Qe(n);){let e=p(n);if(e===n)break;n=e}return t}function Qe(e){return Ue.some(t=>ee(h(e,t)))}async function $e(e){let t=await et(e),n=new Set,r=new Set;for(let e of t)await tt({configPath:e,resolvedConfigPaths:n,visitingConfigPaths:r});return[...n].sort((e,t)=>e.localeCompare(t))}async function et(e){let t=new Set([h(e,`tsconfig.json`),h(e,`jsconfig.json`)]);try{let n=await S(e,{withFileTypes:!0});for(let r of n)r.isFile()&&/^tsconfig\..+\.json$/i.test(r.name)&&t.add(h(e,r.name))}catch{}return[...t]}async function tt(e){let t=_(e.configPath);if(e.resolvedConfigPaths.has(t)||e.visitingConfigPaths.has(t))return;let n=await nt(t);if(n!==void 0){e.resolvedConfigPaths.add(t),e.visitingConfigPaths.add(t);try{let r=rt(n);for(let n of r)for(let r of it({configPath:t,extendsSpecifier:n}))await tt({configPath:r,resolvedConfigPaths:e.resolvedConfigPaths,visitingConfigPaths:e.visitingConfigPaths})}finally{e.visitingConfigPaths.delete(t)}}}async function nt(e){try{return await x(e,`utf8`)}catch{return}}function rt(e){let t=[],n=ie(e,t,{allowTrailingComma:!0});if(t.length>0||typeof n!=`object`||!n||Array.isArray(n))return[];let r=n.extends;return typeof r==`string`?r.length>0?[r]:[]:Array.isArray(r)?r.filter(e=>typeof e==`string`&&e.length>0):[]}function it(e){let t=new Set;if(st(e.extendsSpecifier))for(let n of at({configPath:e.configPath,extendsSpecifier:e.extendsSpecifier}))t.add(n);else for(let n of ot({configPath:e.configPath,extendsSpecifier:e.extendsSpecifier}))t.add(n);return[...t]}function at(e){let t=_(p(e.configPath),e.extendsSpecifier),n=new Set;return n.add(t),t.endsWith(`.json`)||(n.add(`${t}.json`),n.add(h(t,`tsconfig.json`))),[...n]}function ot(e){let t=new Set([e.extendsSpecifier]);e.extendsSpecifier.endsWith(`.json`)||(t.add(`${e.extendsSpecifier}.json`),t.add(`${e.extendsSpecifier}/tsconfig.json`));let n=new Set,r=d(e.configPath);for(let e of t)try{n.add(r.resolve(e))}catch{}return[...n]}function st(e){return e.startsWith(`.`)||m(e)?!0:/^[A-Za-z]:[\\/]/.test(e)}export{Ge as startAuthoredSourceWatcher};
1
+ import{A as e,s as t}from"./paths-CWZN-XRX.js";import{t as n}from"./errors-HYWjHxV6.js";import{getDevelopmentEnvironmentFilePaths as r,loadDevelopmentEnvironmentFiles as i}from"../cli/dev/environment.js";import{a,c as o,i as s,o as c,r as l,s as u}from"./host-CwAcCrg7.js";import{createRequire as d}from"node:module";import*as f from"node:path";import{dirname as p,isAbsolute as m,join as h,relative as g,resolve as _,sep as v}from"node:path";import{lstat as y,open as b,readFile as x,readdir as S,realpath as C,stat as w}from"node:fs/promises";import{existsSync as ee,stat as te,unwatchFile as T,watch as ne,watchFile as re}from"node:fs";import{parse as ie}from"#compiled/jsonc-parser/index.js";import{EventEmitter as ae}from"node:events";import{Readable as oe}from"node:stream";import{type as se}from"node:os";const E={FILE_TYPE:`files`,DIR_TYPE:`directories`,FILE_DIR_TYPE:`files_directories`,EVERYTHING_TYPE:`all`},D={root:`.`,fileFilter:e=>!0,directoryFilter:e=>!0,type:E.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(D);const O=`READDIRP_RECURSIVE_ERROR`,ce=new Set([`ENOENT`,`EPERM`,`EACCES`,`ELOOP`,O]),k=[E.DIR_TYPE,E.EVERYTHING_TYPE,E.FILE_DIR_TYPE,E.FILE_TYPE],le=new Set([E.DIR_TYPE,E.EVERYTHING_TYPE,E.FILE_DIR_TYPE]),ue=new Set([E.EVERYTHING_TYPE,E.FILE_DIR_TYPE,E.FILE_TYPE]),de=e=>ce.has(e.code),fe=process.platform===`win32`,pe=e=>!0,A=e=>{if(e===void 0)return pe;if(typeof e==`function`)return e;if(typeof e==`string`){let t=e.trim();return e=>e.basename===t}if(Array.isArray(e)){let t=e.map(e=>e.trim());return e=>t.some(t=>e.basename===t)}return pe};var me=class extends oe{parents;reading;parent;_stat;_maxDepth;_wantsDir;_wantsFile;_wantsEverything;_root;_isDirent;_statsProp;_rdOptions;_fileFilter;_directoryFilter;constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark});let t={...D,...e},{root:n,type:r}=t;this._fileFilter=A(t.fileFilter),this._directoryFilter=A(t.directoryFilter);let i=t.lstat?y:w;fe?this._stat=e=>i(e,{bigint:!0}):this._stat=i,this._maxDepth=t.depth!=null&&Number.isSafeInteger(t.depth)?t.depth:D.depth,this._wantsDir=r?le.has(r):!1,this._wantsFile=r?ue.has(r):!1,this._wantsEverything=r===E.EVERYTHING_TYPE,this._root=_(n),this._isDirent=!t.alwaysStat,this._statsProp=this._isDirent?`dirent`:`stats`,this._rdOptions={encoding:`utf8`,withFileTypes:this._isDirent},this.parents=[this._exploreDir(n,1)],this.reading=!1,this.parent=void 0}async _read(e){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&e>0;){let t=this.parent,n=t&&t.files;if(n&&n.length>0){let{path:r,depth:i}=t,a=n.splice(0,e).map(e=>this._formatEntry(e,r)),o=await Promise.all(a);for(let t of o){if(!t)continue;if(this.destroyed)return;let n=await this._getEntryType(t);n===`directory`&&this._directoryFilter(t)?(i<=this._maxDepth&&this.parents.push(this._exploreDir(t.fullPath,i+1)),this._wantsDir&&(this.push(t),e--)):(n===`file`||this._includeAsFile(t))&&this._fileFilter(t)&&this._wantsFile&&(this.push(t),e--)}}else{let e=this.parents.pop();if(!e){this.push(null);break}if(this.parent=await e,this.destroyed)return}}}catch(e){this.destroy(e)}finally{this.reading=!1}}}async _exploreDir(e,t){let n;try{n=await S(e,this._rdOptions)}catch(e){this._onError(e)}return{files:n,depth:t,path:e}}async _formatEntry(e,t){let n,r=this._isDirent?e.name:e;try{let i=_(h(t,r));n={path:g(this._root,i),fullPath:i,basename:r},n[this._statsProp]=this._isDirent?e:await this._stat(i)}catch(e){this._onError(e);return}return n}_onError(e){de(e)&&!this.destroyed?this.emit(`warn`,e):this.destroy(e)}async _getEntryType(e){if(!e&&this._statsProp in e)return``;let t=e[this._statsProp];if(t.isFile())return`file`;if(t.isDirectory())return`directory`;if(t&&t.isSymbolicLink()){let t=e.fullPath;try{let e=await C(t),n=await y(e);if(n.isFile())return`file`;if(n.isDirectory()){let n=e.length;if(t.startsWith(e)&&t.substr(n,1)===v){let n=Error(`Circular symlink detected: "${t}" points to "${e}"`);return n.code=O,this._onError(n)}return`directory`}}catch(e){return this._onError(e),``}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}};function he(e,t={}){let n=t.entryType||t.type;if(n===`both`&&(n=E.FILE_DIR_TYPE),n&&(t.type=n),!e)throw Error(`readdirp: root argument is required. Usage: readdirp(root, options)`);if(typeof e!=`string`)throw TypeError(`readdirp: root argument must be a string. Usage: readdirp(root, options)`);if(n&&!k.includes(n))throw Error(`readdirp: Invalid type passed. Use one of ${k.join(`, `)}`);return t.root=e,new me(t)}const j=()=>{},M=process.platform,N=M===`win32`,ge=M===`darwin`,_e=M===`linux`,ve=M===`freebsd`,ye=se()===`OS400`,P={ALL:`all`,READY:`ready`,ADD:`add`,CHANGE:`change`,ADD_DIR:`addDir`,UNLINK:`unlink`,UNLINK_DIR:`unlinkDir`,RAW:`raw`,ERROR:`error`},F=P,be={lstat:y,stat:w},I=`listeners`,L=`errHandlers`,R=`rawEmitters`,xe=[I,L,R],Se=new Set(`3dm.3ds.3g2.3gp.7z.a.aac.adp.afdesign.afphoto.afpub.ai.aif.aiff.alz.ape.apk.appimage.ar.arj.asf.au.avi.bak.baml.bh.bin.bk.bmp.btif.bz2.bzip2.cab.caf.cgm.class.cmx.cpio.cr2.cur.dat.dcm.deb.dex.djvu.dll.dmg.dng.doc.docm.docx.dot.dotm.dra.DS_Store.dsk.dts.dtshd.dvb.dwg.dxf.ecelp4800.ecelp7470.ecelp9600.egg.eol.eot.epub.exe.f4v.fbs.fh.fla.flac.flatpak.fli.flv.fpx.fst.fvt.g3.gh.gif.graffle.gz.gzip.h261.h263.h264.icns.ico.ief.img.ipa.iso.jar.jpeg.jpg.jpgv.jpm.jxr.key.ktx.lha.lib.lvp.lz.lzh.lzma.lzo.m3u.m4a.m4v.mar.mdi.mht.mid.midi.mj2.mka.mkv.mmr.mng.mobi.mov.movie.mp3.mp4.mp4a.mpeg.mpg.mpga.mxu.nef.npx.numbers.nupkg.o.odp.ods.odt.oga.ogg.ogv.otf.ott.pages.pbm.pcx.pdb.pdf.pea.pgm.pic.png.pnm.pot.potm.potx.ppa.ppam.ppm.pps.ppsm.ppsx.ppt.pptm.pptx.psd.pya.pyc.pyo.pyv.qt.rar.ras.raw.resources.rgb.rip.rlc.rmf.rmvb.rpm.rtf.rz.s3m.s7z.scpt.sgi.shar.snap.sil.sketch.slk.smv.snk.so.stl.suo.sub.swf.tar.tbz.tbz2.tga.tgz.thmx.tif.tiff.tlz.ttc.ttf.txz.udf.uvh.uvi.uvm.uvp.uvs.uvu.viv.vob.war.wav.wax.wbmp.wdp.weba.webm.webp.whl.wim.wm.wma.wmv.wmx.woff.woff2.wrm.wvx.xbm.xif.xla.xlam.xls.xlsb.xlsm.xlsx.xlt.xltm.xltx.xm.xmind.xpi.xpm.xwd.xz.z.zip.zipx`.split(`.`)),Ce=e=>Se.has(f.extname(e).slice(1).toLowerCase()),z=(e,t)=>{e instanceof Set?e.forEach(t):t(e)},B=(e,t,n)=>{let r=e[t];r instanceof Set||(e[t]=r=new Set([r])),r.add(n)},we=e=>t=>{let n=e[t];n instanceof Set?n.clear():delete e[t]},V=(e,t,n)=>{let r=e[t];r instanceof Set?r.delete(n):r===n&&delete e[t]},H=e=>e instanceof Set?e.size===0:!e,U=new Map;function W(e,t,n,r,i){let a=(t,r)=>{n(e),i(t,r,{watchedPath:e}),r&&e!==r&&G(f.resolve(e,r),I,f.join(e,r))};try{return ne(e,{persistent:t.persistent},a)}catch(e){r(e);return}}const G=(e,t,n,r,i)=>{let a=U.get(e);a&&z(a[t],e=>{e(n,r,i)})},Te=(e,t,n,r)=>{let{listener:i,errHandler:a,rawEmitter:o}=r,s=U.get(t),c;if(!n.persistent)return c=W(e,n,i,a,o),c?c.close.bind(c):void 0;if(s)B(s,I,i),B(s,L,a),B(s,R,o);else{if(c=W(e,n,G.bind(null,t,I),a,G.bind(null,t,R)),!c)return;c.on(F.ERROR,async n=>{let r=G.bind(null,t,L);if(s&&(s.watcherUnusable=!0),N&&n.code===`EPERM`)try{await(await b(e,`r`)).close(),r(n)}catch{}else r(n)}),s={listeners:i,errHandlers:a,rawEmitters:o,watcher:c},U.set(t,s)}return()=>{V(s,I,i),V(s,L,a),V(s,R,o),H(s.listeners)&&(s.watcher.close(),U.delete(t),xe.forEach(we(s)),s.watcher=void 0,Object.freeze(s))}},K=new Map,Ee=(e,t,n,r)=>{let{listener:i,rawEmitter:a}=r,o=K.get(t),s=o&&o.options;return s&&(s.persistent<n.persistent||s.interval>n.interval)&&(T(t),o=void 0),o?(B(o,I,i),B(o,R,a)):(o={listeners:i,rawEmitters:a,options:n,watcher:re(t,n,(n,r)=>{z(o.rawEmitters,e=>{e(F.CHANGE,t,{curr:n,prev:r})});let i=n.mtimeMs;(n.size!==r.size||i>r.mtimeMs||i===0)&&z(o.listeners,t=>t(e,n))})},K.set(t,o)),()=>{V(o,I,i),V(o,R,a),H(o.listeners)&&(K.delete(t),T(t),o.options=o.watcher=void 0,Object.freeze(o))}};var De=class{fsw;_boundHandleError;constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let n=this.fsw.options,r=f.dirname(e),i=f.basename(e);this.fsw._getWatchedDir(r).add(i);let a=f.resolve(e),o={persistent:n.persistent};t||=j;let s;return n.usePolling?(o.interval=n.interval!==n.binaryInterval&&Ce(i)?n.binaryInterval:n.interval,s=Ee(e,a,o,{listener:t,rawEmitter:this.fsw._emitRaw})):s=Te(e,a,o,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),s}_handleFile(e,t,n){if(this.fsw.closed)return;let r=f.dirname(e),i=f.basename(e),a=this.fsw._getWatchedDir(r),o=t;if(a.has(i))return;let s=async(t,n)=>{if(this.fsw._throttle(`watch`,e,5)){if(!n||n.mtimeMs===0)try{let n=await w(e);if(this.fsw.closed)return;let r=n.atimeMs,i=n.mtimeMs;if((!r||r<=i||i!==o.mtimeMs)&&this.fsw._emit(F.CHANGE,e,n),(ge||_e||ve)&&o.ino!==n.ino){this.fsw._closeFile(t),o=n;let r=this._watchWithNodeFs(e,s);r&&this.fsw._addPathCloser(t,r)}else o=n}catch{this.fsw._remove(r,i)}else if(a.has(i)){let t=n.atimeMs,r=n.mtimeMs;(!t||t<=r||r!==o.mtimeMs)&&this.fsw._emit(F.CHANGE,e,n),o=n}}},c=this._watchWithNodeFs(e,s);if(!(n&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(F.ADD,e,0))return;this.fsw._emit(F.ADD,e,t)}return c}async _handleSymlink(e,t,n,r){if(this.fsw.closed)return;let i=e.fullPath,a=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let t;try{t=await C(n)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(r)?this.fsw._symlinkPaths.get(i)!==t&&(this.fsw._symlinkPaths.set(i,t),this.fsw._emit(F.CHANGE,n,e.stats)):(a.add(r),this.fsw._symlinkPaths.set(i,t),this.fsw._emit(F.ADD,n,e.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(e,t,n,r,i,a,o){e=f.join(e,``);let s=r?`${e}:${r}`:e;if(o=this.fsw._throttle(`readdir`,s,1e3),!o)return;let c=this.fsw._getWatchedDir(n.path),l=new Set,u=this.fsw._readdirp(e,{fileFilter:e=>n.filterPath(e),directoryFilter:e=>n.filterDir(e)});if(u)return u.on(`data`,async o=>{if(this.fsw.closed){u=void 0;return}let s=o.path,d=f.join(e,s);if(l.add(s),!(o.stats.isSymbolicLink()&&await this._handleSymlink(o,e,d,s))){if(this.fsw.closed){u=void 0;return}(s===r||!r&&!c.has(s))&&(this.fsw._incrReadyCount(),d=f.join(i,f.relative(i,d)),this._addToNodeFs(d,t,n,a+1))}}).on(F.ERROR,this._boundHandleError),new Promise((t,s)=>{if(!u)return s();u.once(`end`,()=>{if(this.fsw.closed){u=void 0;return}let s=o?o.clear():!1;t(void 0),c.getChildren().filter(t=>t!==e&&!l.has(t)).forEach(t=>{this.fsw._remove(e,t)}),u=void 0,s&&this._handleRead(e,!1,n,r,i,a,o)})})}async _handleDir(e,t,n,r,i,a,o){let s=this.fsw._getWatchedDir(f.dirname(e)),c=s.has(f.basename(e));!(n&&this.fsw.options.ignoreInitial)&&!i&&!c&&this.fsw._emit(F.ADD_DIR,e,t),s.add(f.basename(e)),this.fsw._getWatchedDir(e);let l,u=this.fsw.options.depth;if((u==null||r<=u)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(e,n,a,i,e,r,void 0),this.fsw.closed))return;l=this._watchWithNodeFs(e,(t,n)=>{n&&n.mtimeMs===0||this._handleRead(t,!1,a,i,e,r,void 0)})}return l}async _addToNodeFs(e,t,n,r,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(e)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(e);n&&(o.filterPath=e=>n.filterPath(e),o.filterDir=e=>n.filterDir(e));try{let n=await be[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,n))return a(),!1;let s=this.fsw.options.followSymlinks,c;if(n.isDirectory()){let a=f.resolve(e),l=s?await C(e):e;if(this.fsw.closed||(c=await this._handleDir(o.watchPath,n,t,r,i,o,l),this.fsw.closed))return;a!==l&&l!==void 0&&this.fsw._symlinkPaths.set(a,l)}else if(n.isSymbolicLink()){let i=s?await C(e):e;if(this.fsw.closed)return;let a=f.dirname(o.watchPath);if(this.fsw._getWatchedDir(a).add(o.watchPath),this.fsw._emit(F.ADD,o.watchPath,n),c=await this._handleDir(a,n,t,r,e,o,i),this.fsw.closed)return;i!==void 0&&this.fsw._symlinkPaths.set(f.resolve(e),i)}else c=this._handleFile(o.watchPath,n,t);return a(),c&&this.fsw._addPathCloser(e,c),!1}catch(t){if(this.fsw._handleError(t))return a(),e}}};const Oe=/\\/g,q=/\/\//g,ke=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,Ae=/^\.[/\\]/;function J(e){return Array.isArray(e)?e:[e]}const Y=e=>typeof e==`object`&&!!e&&!(e instanceof RegExp);function je(e){return typeof e==`function`?e:typeof e==`string`?t=>e===t:e instanceof RegExp?t=>e.test(t):typeof e==`object`&&e?t=>{if(e.path===t)return!0;if(e.recursive){let n=f.relative(e.path,t);return n?!n.startsWith(`..`)&&!f.isAbsolute(n):!1}return!1}:()=>!1}function Me(e){if(typeof e!=`string`)throw Error(`string expected`);e=f.normalize(e),e=e.replace(/\\/g,`/`);let t=!1;return e.startsWith(`//`)&&(t=!0),e=e.replace(q,`/`),t&&(e=`/`+e),e}function X(e,t,n){let r=Me(t);for(let t=0;t<e.length;t++){let i=e[t];if(i(r,n))return!0}return!1}function Ne(e,t){if(e==null)throw TypeError(`anymatch: specify first argument`);let n=J(e).map(e=>je(e));return t==null?(e,t)=>X(n,e,t):X(n,t)}const Z=e=>{let t=J(e).flat();if(!t.every(e=>typeof e==`string`))throw TypeError(`Non-string provided as watch path: ${t}`);return t.map(Pe)},Q=e=>{let t=e.replace(Oe,`/`),n=!1;return t.startsWith(`//`)&&(n=!0),t=t.replace(q,`/`),n&&(t=`/`+t),t},Pe=e=>Q(f.normalize(Q(e))),Fe=(e=``)=>t=>typeof t==`string`?Pe(f.isAbsolute(t)?t:f.join(e,t)):t,Ie=(e,t)=>f.isAbsolute(e)?e:f.join(t,e),Le=Object.freeze(new Set);var Re=class{path;_removeWatcher;items;constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==`.`&&e!==`..`&&t.add(e)}async remove(e){let{items:t}=this;if(!t||(t.delete(e),t.size>0))return;let n=this.path;try{await S(n)}catch{this._removeWatcher&&this._removeWatcher(f.dirname(n),f.basename(n))}}has(e){let{items:t}=this;if(t)return t.has(e)}getChildren(){let{items:e}=this;return e?[...e.values()]:[]}dispose(){this.items.clear(),this.path=``,this._removeWatcher=j,this.items=Le,Object.freeze(this)}},ze=class{fsw;path;watchPath;fullWatchPath;dirParts;followSymlinks;statMethod;constructor(e,t,n){this.fsw=n;let r=e;this.path=e=e.replace(Ae,``),this.watchPath=r,this.fullWatchPath=f.resolve(r),this.dirParts=[],this.dirParts.forEach(e=>{e.length>1&&e.pop()}),this.followSymlinks=t,this.statMethod=t?`stat`:`lstat`}entryPath(e){return f.join(this.watchPath,f.relative(this.watchPath,e.fullPath))}filterPath(e){let{stats:t}=e;if(t&&t.isSymbolicLink())return this.filterDir(e);let n=this.entryPath(e);return this.fsw._isntIgnored(n,t)&&this.fsw._hasReadPermissions(t)}filterDir(e){return this.fsw._isntIgnored(this.entryPath(e),e.stats)}},Be=class extends ae{closed;options;_closers;_ignoredPaths;_throttled;_streams;_symlinkPaths;_watched;_pendingWrites;_pendingUnlinks;_readyCount;_emitReady;_closePromise;_userIgnored;_readyEmitted;_emitRaw;_boundRemove;_nodeFsHandler;constructor(e={}){super(),this.closed=!1,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._streams=new Set,this._symlinkPaths=new Map,this._watched=new Map,this._pendingWrites=new Map,this._pendingUnlinks=new Map,this._readyCount=0,this._readyEmitted=!1;let t=e.awaitWriteFinish,n={stabilityThreshold:2e3,pollInterval:100},r={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...e,ignored:e.ignored?J(e.ignored):J([]),awaitWriteFinish:t===!0?n:typeof t==`object`?{...n,...t}:!1};ye&&(r.usePolling=!0),r.atomic===void 0&&(r.atomic=!r.usePolling);let i=process.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let e=i.toLowerCase();e===`false`||e===`0`?r.usePolling=!1:e===`true`||e===`1`?r.usePolling=!0:r.usePolling=!!e}let a=process.env.CHOKIDAR_INTERVAL;a&&(r.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=j,this._readyEmitted=!0,process.nextTick(()=>this.emit(P.READY)))},this._emitRaw=(...e)=>this.emit(P.RAW,...e),this._boundRemove=this._remove.bind(this),this.options=r,this._nodeFsHandler=new De(this),Object.freeze(r)}_addIgnoredPath(e){if(Y(e)){for(let t of this._ignoredPaths)if(Y(t)&&t.path===e.path&&t.recursive===e.recursive)return}this._ignoredPaths.add(e)}_removeIgnoredPath(e){if(this._ignoredPaths.delete(e),typeof e==`string`)for(let t of this._ignoredPaths)Y(t)&&t.path===e&&this._ignoredPaths.delete(t)}add(e,t,n){let{cwd:r}=this.options;this.closed=!1,this._closePromise=void 0;let i=Z(e);return r&&(i=i.map(e=>Ie(e,r))),i.forEach(e=>{this._removeIgnoredPath(e)}),this._userIgnored=void 0,this._readyCount||=0,this._readyCount+=i.length,Promise.all(i.map(async e=>{let r=await this._nodeFsHandler._addToNodeFs(e,!n,void 0,0,t);return r&&this._emitReady(),r})).then(e=>{this.closed||e.forEach(e=>{e&&this.add(f.dirname(e),f.basename(t||e))})}),this}unwatch(e){if(this.closed)return this;let t=Z(e),{cwd:n}=this.options;return t.forEach(e=>{!f.isAbsolute(e)&&!this._closers.has(e)&&(n&&(e=f.join(n,e)),e=f.resolve(e)),this._closePath(e),this._addIgnoredPath(e),this._watched.has(e)&&this._addIgnoredPath({path:e,recursive:!0}),this._userIgnored=void 0}),this}close(){if(this._closePromise)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(t=>{let n=t();n instanceof Promise&&e.push(n)})),this._streams.forEach(e=>e.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(e=>e.dispose()),this._closers.clear(),this._watched.clear(),this._streams.clear(),this._symlinkPaths.clear(),this._throttled.clear(),this._closePromise=e.length?Promise.all(e).then(()=>void 0):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,n)=>{let r=(this.options.cwd?f.relative(this.options.cwd,n):n)||`.`;e[r]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(e,...t),e!==P.ERROR&&this.emit(P.ALL,e,...t)}async _emit(e,t,n){if(this.closed)return;let r=this.options;N&&(t=f.normalize(t)),r.cwd&&(t=f.relative(r.cwd,t));let i=[t];n!=null&&i.push(n);let a=r.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(t)))return o.lastChange=new Date,this;if(r.atomic){if(e===P.UNLINK)return this._pendingUnlinks.set(t,[e,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((e,t)=>{this.emit(...e),this.emit(P.ALL,...e),this._pendingUnlinks.delete(t)})},typeof r.atomic==`number`?r.atomic:100),this;e===P.ADD&&this._pendingUnlinks.has(t)&&(e=P.CHANGE,this._pendingUnlinks.delete(t))}if(a&&(e===P.ADD||e===P.CHANGE)&&this._readyEmitted)return this._awaitWriteFinish(t,a.stabilityThreshold,e,(t,n)=>{t?(e=P.ERROR,i[0]=t,this.emitWithAll(e,i)):n&&(i.length>1?i[1]=n:i.push(n),this.emitWithAll(e,i))}),this;if(e===P.CHANGE&&!this._throttle(P.CHANGE,t,50))return this;if(r.alwaysStat&&n===void 0&&(e===P.ADD||e===P.ADD_DIR||e===P.CHANGE)){let e=r.cwd?f.join(r.cwd,t):t,n;try{n=await w(e)}catch{}if(!n||this.closed)return;i.push(n)}return this.emitWithAll(e,i),this}_handleError(e){let t=e&&e.code;return e&&t!==`ENOENT`&&t!==`ENOTDIR`&&(!this.options.ignorePermissionErrors||t!==`EPERM`&&t!==`EACCES`)&&this.emit(P.ERROR,e),e||this.closed}_throttle(e,t,n){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e);if(!r)throw Error(`invalid throttle`);let i=r.get(t);if(i)return i.count++,!1;let a,o=()=>{let e=r.get(t),n=e?e.count:0;return r.delete(t),clearTimeout(a),e&&clearTimeout(e.timeoutObject),n};a=setTimeout(o,n);let s={timeoutObject:a,clear:o,count:0};return r.set(t,s),s}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,n,r){let i=this.options.awaitWriteFinish;if(typeof i!=`object`)return;let a=i.pollInterval,o,s=e;this.options.cwd&&!f.isAbsolute(e)&&(s=f.join(this.options.cwd,e));let c=new Date,l=this._pendingWrites;function u(n){te(s,(i,s)=>{if(i||!l.has(e)){i&&i.code!==`ENOENT`&&r(i);return}let c=Number(new Date);n&&s.size!==n.size&&(l.get(e).lastChange=c),c-l.get(e).lastChange>=t?(l.delete(e),r(void 0,s)):o=setTimeout(u,a,s)})}l.has(e)||(l.set(e,{lastChange:c,cancelWait:()=>(l.delete(e),clearTimeout(o),n)}),o=setTimeout(u,a))}_isIgnored(e,t){if(this.options.atomic&&ke.test(e))return!0;if(!this._userIgnored){let{cwd:e}=this.options,t=(this.options.ignored||[]).map(Fe(e)),n=[...[...this._ignoredPaths].map(Fe(e)),...t];this._userIgnored=Ne(n,void 0)}return this._userIgnored(e,t)}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e){return new ze(e,this.options.followSymlinks,this)}_getWatchedDir(e){let t=f.resolve(e);return this._watched.has(t)||this._watched.set(t,new Re(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){return this.options.ignorePermissionErrors?!0:!!(Number(e.mode)&256)}_remove(e,t,n){let r=f.join(e,t),i=f.resolve(r);if(n??=this._watched.has(r)||this._watched.has(i),!this._throttle(`remove`,r,100))return;!n&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(e=>this._remove(r,e));let a=this._getWatchedDir(e),o=a.has(t);a.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let s=r;if(this.options.cwd&&(s=f.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(s)&&this._pendingWrites.get(s).cancelWait()===P.ADD)return;this._watched.delete(r),this._watched.delete(i);let c=n?P.UNLINK_DIR:P.UNLINK;o&&!this._isIgnored(r)&&this._emit(c,r),this._closePath(r)}_closePath(e){this._closeFile(e);let t=f.dirname(e);this._getWatchedDir(t).remove(f.basename(e))}_closeFile(e){let t=this._closers.get(e);t&&(t.forEach(e=>e()),this._closers.delete(e))}_addPathCloser(e,t){if(!t)return;let n=this._closers.get(e);n||(n=[],this._closers.set(e,n)),n.push(t)}_readdirp(e,t){if(this.closed)return;let n=he(e,{type:P.ALL,alwaysStat:!0,lstat:!0,...t,depth:0});return this._streams.add(n),n.once(`close`,()=>{n=void 0}),n.once(`end`,()=>{n&&=(this._streams.delete(n),void 0)}),n}};function Ve(e,t={}){let n=new Be(t);return n.add(e),n}const He=[`pnpm-lock.yaml`,`package-lock.json`,`yarn.lock`,`bun.lock`,`bun.lockb`],Ue=[`.git`,`pnpm-workspace.yaml`],We=[`**/.ash/**`,`**/.git/**`,`**/.output/**`,`**/.turbo/**`,`**/.vercel/**`,`**/.workflow-data/**`,`**/node_modules/**`];async function Ge(r){let d=r.schedulesEnabled!==!1,f=r.preparedHost,p=!1,m=Promise.resolve(),h,g=new Set,_=new Set,v=await qe(f),y=Je(v),b=Ve(v,{awaitWriteFinish:{pollInterval:50,stabilityThreshold:160},followSymlinks:!1,ignoreInitial:!0,ignored:We}),x=Ke(b),S=()=>{p||(m=m.then(async()=>{if(p)return;let m=g.size,h=[..._];g.clear(),_.clear();let v=f,x=Xe(v.appRoot,h);console.log(`[ash:dev] change detected (${m} event${m===1?``:`s`}), rebuilding authored artifacts...`);try{x&&i(v.appRoot);let n=await s(v.appRoot);await l({appRoot:n.appRoot,log:e=>console.log(e)});let p=o({appRoot:n.appRoot,dev:r.nitro.options.dev===!0}),m=u(r.nitro,{artifactsConfig:p,next:c(n),previous:c(v)}),h=a(r.nitro,{artifactsConfig:p,dispatchModulePath:e(`src/internal/nitro/routes/schedule-task.ts`),next:d?n.scheduleRegistrations:[],previous:d?v.scheduleRegistrations:[]});t(),f=n,m||h||x?(console.log(`[ash:dev] structural change detected, reloading Nitro worker...`),await r.nitro.hooks.callHook(`rollup:reload`)):console.log(`[ash:dev] authored artifacts updated.`),y=Ye({nextWatchPaths:await qe(n),previousWatchPathsByKey:y,watcher:b})}catch(e){console.error(`[ash:dev] rebuild failed: ${n(e)}`)}}).catch(e=>{console.error(`[ash:dev] rebuild queue error: ${n(e)}`)}))};return b.on(`all`,(e,t)=>{p||(g.add(`${e}:${t}`),_.add(t),h!==void 0&&clearTimeout(h),h=setTimeout(()=>{h=void 0,S()},120))}),await x,{async close(){p=!0,h!==void 0&&(clearTimeout(h),h=void 0),await b.close(),await m}}}async function Ke(e){await new Promise((t,n)=>{e.on(`ready`,()=>{t()}),e.on(`error`,e=>{n(e)})})}async function qe(e){let t=new Set([e.compileResult.project.agentRoot,h(e.appRoot,`package.json`),h(e.appRoot,`jsconfig.json`),h(e.appRoot,`tsconfig.json`),h(e.appRoot,`tsconfig.*.json`)]),n=await $e(e.appRoot);for(let n of r(e.appRoot))t.add(n);for(let e of n)t.add(e);for(let n of Ze(e.appRoot))for(let e of He)t.add(h(n,e));return[...t].sort((e,t)=>e.localeCompare(t))}function Je(e){let t=new Map;for(let n of e)t.set($(n),n);return t}function Ye(e){let t=Je(e.nextWatchPaths),n=[],r=[];for(let[r,i]of t)e.previousWatchPathsByKey.has(r)||n.push(i);for(let[n,i]of e.previousWatchPathsByKey)t.has(n)||r.push(i);return n.length>0&&e.watcher.add(n),r.length>0&&e.watcher.unwatch(r),t}function $(e){return e.replaceAll(`\\`,`/`)}function Xe(e,t){let n=new Set(r(e).map(e=>$(_(e))));return t.some(e=>n.has($(_(e))))}function Ze(e){let t=[],n=_(e);for(;t.push(n),!Qe(n);){let e=p(n);if(e===n)break;n=e}return t}function Qe(e){return Ue.some(t=>ee(h(e,t)))}async function $e(e){let t=await et(e),n=new Set,r=new Set;for(let e of t)await tt({configPath:e,resolvedConfigPaths:n,visitingConfigPaths:r});return[...n].sort((e,t)=>e.localeCompare(t))}async function et(e){let t=new Set([h(e,`tsconfig.json`),h(e,`jsconfig.json`)]);try{let n=await S(e,{withFileTypes:!0});for(let r of n)r.isFile()&&/^tsconfig\..+\.json$/i.test(r.name)&&t.add(h(e,r.name))}catch{}return[...t]}async function tt(e){let t=_(e.configPath);if(e.resolvedConfigPaths.has(t)||e.visitingConfigPaths.has(t))return;let n=await nt(t);if(n!==void 0){e.resolvedConfigPaths.add(t),e.visitingConfigPaths.add(t);try{let r=rt(n);for(let n of r)for(let r of it({configPath:t,extendsSpecifier:n}))await tt({configPath:r,resolvedConfigPaths:e.resolvedConfigPaths,visitingConfigPaths:e.visitingConfigPaths})}finally{e.visitingConfigPaths.delete(t)}}}async function nt(e){try{return await x(e,`utf8`)}catch{return}}function rt(e){let t=[],n=ie(e,t,{allowTrailingComma:!0});if(t.length>0||typeof n!=`object`||!n||Array.isArray(n))return[];let r=n.extends;return typeof r==`string`?r.length>0?[r]:[]:Array.isArray(r)?r.filter(e=>typeof e==`string`&&e.length>0):[]}function it(e){let t=new Set;if(st(e.extendsSpecifier))for(let n of at({configPath:e.configPath,extendsSpecifier:e.extendsSpecifier}))t.add(n);else for(let n of ot({configPath:e.configPath,extendsSpecifier:e.extendsSpecifier}))t.add(n);return[...t]}function at(e){let t=_(p(e.configPath),e.extendsSpecifier),n=new Set;return n.add(t),t.endsWith(`.json`)||(n.add(`${t}.json`),n.add(h(t,`tsconfig.json`))),[...n]}function ot(e){let t=new Set([e.extendsSpecifier]);e.extendsSpecifier.endsWith(`.json`)||(t.add(`${e.extendsSpecifier}.json`),t.add(`${e.extendsSpecifier}/tsconfig.json`));let n=new Set,r=d(e.configPath);for(let e of t)try{n.add(r.resolve(e))}catch{}return[...n]}function st(e){return e.startsWith(`.`)||m(e)?!0:/^[A-Za-z]:[\\/]/.test(e)}export{Ge as startAuthoredSourceWatcher};