sparkecoder 0.1.54 → 0.1.56
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent/index.d.ts +2 -2
- package/dist/agent/index.js +50 -22
- package/dist/agent/index.js.map +1 -1
- package/dist/cli.js +50 -22
- package/dist/cli.js.map +1 -1
- package/dist/{index-BYOHniN4.d.ts → index-CqKMYoJv.d.ts} +5 -5
- package/dist/index.d.ts +3 -3
- package/dist/index.js +50 -22
- package/dist/index.js.map +1 -1
- package/dist/{search-DALwmPRX.d.ts → search-CZsTAZ90.d.ts} +6 -6
- package/dist/server/index.js +50 -22
- package/dist/server/index.js.map +1 -1
- package/dist/tools/index.d.ts +2 -2
- package/dist/tools/index.js +36 -21
- package/dist/tools/index.js.map +1 -1
- package/package.json +1 -1
- package/web/.next/BUILD_ID +1 -1
- package/web/.next/standalone/web/.next/BUILD_ID +1 -1
- package/web/.next/standalone/web/.next/build-manifest.json +2 -2
- package/web/.next/standalone/web/.next/prerender-manifest.json +3 -3
- package/web/.next/standalone/web/.next/server/app/(main)/session/[id]/page.js.nft.json +1 -1
- package/web/.next/standalone/web/.next/server/app/(main)/session/[id]/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.html +2 -2
- package/web/.next/standalone/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.html +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/installation.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs/installation/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs/installation.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/installation.segments/docs.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/skills.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs/skills/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs/skills.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/skills.segments/docs.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs/tools.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs/tools/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs/tools.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs/tools.segments/docs.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.html +2 -2
- package/web/.next/standalone/web/.next/server/app/docs.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/docs/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/docs.segments/docs.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/embed/[id]/page.js.nft.json +1 -1
- package/web/.next/standalone/web/.next/server/app/embed/[id]/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/app/index.html +1 -1
- package/web/.next/standalone/web/.next/server/app/index.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/!KG1haW4p/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/!KG1haW4p.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_c9e3cd7b._.js → 2374f_05c00b91._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_de035f79._.js → 2374f_1fa4a79a._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_273991ba._.js → 2374f_39f76acc._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_8d018190._.js → 2374f_562d2f4f._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_7b421f78._.js → 2374f_6ced4caf._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_ec997752._.js → 2374f_800db4e3._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_2572135b._.js → 2374f_934cb548._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_5ee28d4c._.js → 2374f_aade2a6d._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_460c0d78._.js → 2374f_ac284eb3._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_a7457131._.js → 2374f_c272cbb4._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_06a5ea48._.js → 2374f_d118a207._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_df3c414e._.js → 2374f_e35df3d7._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_88cbeb7b._.js → 2374f_ef435bac._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{2374f_65b86b54._.js → 2374f_f661d73d._.js} +1 -1
- package/web/.next/standalone/web/.next/server/chunks/ssr/{[root-of-the-server]__a87e1c27._.js → [root-of-the-server]__8cdc7b0b._.js} +2 -2
- package/web/.next/standalone/web/.next/server/chunks/ssr/{[root-of-the-server]__c94aac98._.js → [root-of-the-server]__f44222d9._.js} +2 -2
- package/web/.next/standalone/web/.next/server/chunks/ssr/{web_b85931da._.js → web_0a13adb9._.js} +2 -2
- package/web/.next/standalone/web/.next/server/pages/404.html +1 -1
- package/web/.next/standalone/web/.next/server/pages/500.html +2 -2
- package/web/.next/standalone/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/standalone/web/.next/server/server-reference-manifest.json +1 -1
- package/web/.next/standalone/web/.next/static/chunks/{9b4c4424a720586b.js → ca717ddd7c8f37e8.js} +2 -2
- package/web/.next/standalone/web/.next/static/static/chunks/{9b4c4424a720586b.js → ca717ddd7c8f37e8.js} +2 -2
- package/web/.next/standalone/web/src/components/ai-elements/search-tool.tsx +7 -9
- package/web/.next/static/chunks/{9b4c4424a720586b.js → ca717ddd7c8f37e8.js} +2 -2
- /package/web/.next/standalone/web/.next/static/{7rKMR1VNC_1_vH6S9H5aS → static/yfBGAcI8gI55lwQllPu-z}/_buildManifest.js +0 -0
- /package/web/.next/standalone/web/.next/static/{7rKMR1VNC_1_vH6S9H5aS → static/yfBGAcI8gI55lwQllPu-z}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/standalone/web/.next/static/{7rKMR1VNC_1_vH6S9H5aS → static/yfBGAcI8gI55lwQllPu-z}/_ssgManifest.js +0 -0
- /package/web/.next/standalone/web/.next/static/{static/7rKMR1VNC_1_vH6S9H5aS → yfBGAcI8gI55lwQllPu-z}/_buildManifest.js +0 -0
- /package/web/.next/standalone/web/.next/static/{static/7rKMR1VNC_1_vH6S9H5aS → yfBGAcI8gI55lwQllPu-z}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/standalone/web/.next/static/{static/7rKMR1VNC_1_vH6S9H5aS → yfBGAcI8gI55lwQllPu-z}/_ssgManifest.js +0 -0
- /package/web/.next/static/{7rKMR1VNC_1_vH6S9H5aS → yfBGAcI8gI55lwQllPu-z}/_buildManifest.js +0 -0
- /package/web/.next/static/{7rKMR1VNC_1_vH6S9H5aS → yfBGAcI8gI55lwQllPu-z}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/static/{7rKMR1VNC_1_vH6S9H5aS → yfBGAcI8gI55lwQllPu-z}/_ssgManifest.js +0 -0
package/dist/cli.js
CHANGED
|
@@ -4643,41 +4643,60 @@ var SearchSubagent = class extends Subagent {
|
|
|
4643
4643
|
this.maxSteps = 10;
|
|
4644
4644
|
}
|
|
4645
4645
|
getSystemPrompt(options) {
|
|
4646
|
-
|
|
4646
|
+
const contextBlock = options.additionalContext ? `
|
|
4647
|
+
## Active Context (from devtools)
|
|
4648
|
+
${options.additionalContext}
|
|
4647
4649
|
|
|
4648
|
-
|
|
4650
|
+
Use this context to understand what the user is currently looking at. If they reference "this page", "this component", "this screen", etc., this context tells you which page/route they mean. Search for files related to this page/route first.
|
|
4651
|
+
` : "";
|
|
4652
|
+
return `You are an Explore agent - a READ-ONLY file search and code analysis specialist. Your job is to find relevant files, understand code structure, and return clear findings to the main agent. You MUST NOT create, modify, or delete any files.
|
|
4649
4653
|
|
|
4650
|
-
|
|
4651
|
-
|
|
4652
|
-
|
|
4653
|
-
-
|
|
4654
|
-
-
|
|
4655
|
-
-
|
|
4654
|
+
Working Directory: ${options.workingDirectory}
|
|
4655
|
+
${contextBlock}
|
|
4656
|
+
## Available Tools
|
|
4657
|
+
- **semantic_search**: Search the codebase by meaning (finds code related to a concept). Use this FIRST when available - it's the fastest way to explore.
|
|
4658
|
+
- **grep**: Search for exact patterns in files using ripgrep. Best for exact symbol/string matches.
|
|
4659
|
+
- **glob**: Find files matching a name pattern. Best for file discovery.
|
|
4660
|
+
- **read_file**: Read contents of a specific file. Use to examine code found in searches.
|
|
4661
|
+
- **list_dir**: List directory contents. Use to understand project structure.
|
|
4656
4662
|
|
|
4657
|
-
## Strategy
|
|
4663
|
+
## Search Strategy
|
|
4658
4664
|
|
|
4659
4665
|
1. **Start with semantic_search** if available - it finds code by meaning, which is the fastest way to explore
|
|
4660
|
-
2. Use grep for exact
|
|
4661
|
-
3.
|
|
4662
|
-
4.
|
|
4666
|
+
2. **Use grep** for exact symbol/string matches (function names, class names, imports)
|
|
4667
|
+
3. **Use glob** for file discovery by name patterns
|
|
4668
|
+
4. **Read key files** to get actual code content and understand context
|
|
4669
|
+
5. **Run searches in PARALLEL** - make multiple tool calls at once to cover different angles simultaneously. This is critical for speed.
|
|
4670
|
+
|
|
4671
|
+
### Tool Selection Guide
|
|
4672
|
+
- Know the exact name? Use **grep** (e.g. \`getUserById\`, \`class AuthService\`)
|
|
4673
|
+
- Exploring a concept? Use **semantic_search** (e.g. "how does authentication work")
|
|
4674
|
+
- Looking for files? Use **glob** (e.g. \`**/*.config.ts\`, \`**/auth/**\`)
|
|
4675
|
+
- Need file content? Use **read_file** with optional line ranges for large files
|
|
4663
4676
|
|
|
4664
4677
|
## CRITICAL: Your text output IS the result
|
|
4665
4678
|
|
|
4666
|
-
The text you write in your responses is what gets sent back to the main agent as the summary. You MUST include:
|
|
4679
|
+
The text you write in your responses is what gets sent back to the main agent as the summary. The main agent has NO other context about what you found. You MUST include:
|
|
4667
4680
|
- **Exact file paths** (relative to working directory)
|
|
4668
4681
|
- **Line numbers** where relevant code is found
|
|
4669
4682
|
- **Key code snippets** showing the important parts
|
|
4670
|
-
- **How pieces connect together**
|
|
4683
|
+
- **How pieces connect together** - explain relationships between files
|
|
4671
4684
|
- **What you actually found**, not just metadata
|
|
4672
4685
|
|
|
4673
4686
|
ALWAYS end with a comprehensive summary of your findings. This summary IS the data that the main agent receives.
|
|
4674
4687
|
|
|
4688
|
+
## Constraints
|
|
4689
|
+
- You are READ-ONLY. Do NOT attempt to create, write, edit, or delete files.
|
|
4690
|
+
- Be fast. Return results quickly. Don't over-explore when you've found what's needed.
|
|
4691
|
+
- Be thorough but efficient. If you find the answer in 2 searches, stop there.
|
|
4692
|
+
- No emojis in output.
|
|
4693
|
+
|
|
4675
4694
|
## Example good output:
|
|
4676
4695
|
"Found the authentication system in src/auth/:
|
|
4677
4696
|
- \`src/auth/provider.ts\` (lines 15-45): AuthProvider class handles JWT token validation
|
|
4678
4697
|
- \`src/auth/middleware.ts\` (lines 8-20): Express middleware that checks auth headers
|
|
4679
4698
|
- \`src/auth/hooks.ts\`: useAuth() hook used by React components
|
|
4680
|
-
The auth flow: middleware validates JWT
|
|
4699
|
+
The auth flow: middleware validates JWT -> provider decodes token -> user context set"
|
|
4681
4700
|
|
|
4682
4701
|
## Example bad output:
|
|
4683
4702
|
"I searched for auth and found some files." (too vague, no paths, no details)
|
|
@@ -4993,14 +5012,10 @@ The Explore agent will explore the codebase and return a summary of findings.
|
|
|
4993
5012
|
This is more thorough than a simple grep because it can follow references and understand context.
|
|
4994
5013
|
It also has access to semantic search to find code by meaning, not just text.
|
|
4995
5014
|
|
|
4996
|
-
|
|
4997
|
-
- "Find all React components that use the useState hook"
|
|
4998
|
-
- "Where is the authentication logic implemented?"
|
|
4999
|
-
- "Find all API routes and their handlers"
|
|
5000
|
-
- "Search for usages of the UserService class"`,
|
|
5015
|
+
CRITICAL: The explore agent has ZERO context. It cannot see the conversation, the user's message, devtools data, or any prior context. You MUST pass ALL relevant context via the "context" parameter. If the user selected a component (component name, file path, HTML, component stack) or there is a <devtools-context> block, you MUST copy that information into the "context" field verbatim. Without it the explore agent is searching blind.`,
|
|
5001
5016
|
inputSchema: z10.object({
|
|
5002
5017
|
query: z10.string().describe("What to search for. Be specific about what you're looking for."),
|
|
5003
|
-
context: z10.string().
|
|
5018
|
+
context: z10.string().describe("ALL context the explore agent needs. It has ZERO context on its own - no conversation history, no devtools data, nothing. You MUST include: any selected component info (name, file path, HTML, component stack), any <devtools-context> block (page URL, path, viewport), and any other relevant details from the user message. The explore agent literally only sees the query and this context field.")
|
|
5004
5019
|
}),
|
|
5005
5020
|
execute: async ({ query, context }, toolOptions) => {
|
|
5006
5021
|
const toolCallId = toolOptions.toolCallId || `explore_agent_${Date.now()}`;
|
|
@@ -5328,6 +5343,11 @@ Use this proactively after making code changes to catch errors early.
|
|
|
5328
5343
|
|
|
5329
5344
|
**Choose the right search approach:**
|
|
5330
5345
|
|
|
5346
|
+
0. **Use paths to your advantage \u2014 skip searching if you already have what you need.**
|
|
5347
|
+
- If the user selected a component via devtools and you can see the component name, file path, and/or line number, you ALREADY know where the code is. Just use \`read_file\` to read that file directly \u2014 do NOT call \`explore_agent\` to "find" something you already have the location of.
|
|
5348
|
+
- If you received a **page path** (e.g. \`/dashboard\`, \`/settings/profile\`), map it to the corresponding file in the project structure. In Next.js this means \`app/dashboard/page.tsx\`, \`app/settings/profile/page.tsx\`, etc. In other frameworks, check the routing convention (e.g. \`pages/\`, \`src/routes/\`). Use \`read_file\` on the mapped path directly.
|
|
5349
|
+
- If the file path doesn't exist or \`read_file\` fails, fall back to grep to locate it (e.g. \`rg "ComponentName" --type ts -l\`) since devtools paths can sometimes be slightly off or truncated.
|
|
5350
|
+
- Read up and down component trees when you have the file path or page path to find what you're looking for.
|
|
5331
5351
|
1. **Use the \`explore_agent\` tool (Explore agent)** for:
|
|
5332
5352
|
- Semantic/exploratory questions: "How does authentication work?", "Where is user data processed?"
|
|
5333
5353
|
- Finding code by meaning or concept, not exact text
|
|
@@ -5337,6 +5357,13 @@ Use this proactively after making code changes to catch errors early.
|
|
|
5337
5357
|
|
|
5338
5358
|
The Explore agent is a mini-agent that intelligently explores the codebase, reads relevant files, and returns a summary of what it found. It's best for understanding and discovery.
|
|
5339
5359
|
|
|
5360
|
+
**MANDATORY \u2014 The Explore agent has ZERO context.** It cannot see the conversation, the user's messages, devtools data, or anything else. The \`query\` and \`context\` fields are the ONLY information it receives. Every time you call \`explore_agent\`, you MUST populate the \`context\` field with ALL relevant information:
|
|
5361
|
+
- Copy the ENTIRE \`<devtools-context>\` block (page URL, path, viewport) if one exists in the user's message.
|
|
5362
|
+
- Copy ALL selected component info (component name, file path, line number, HTML snippet, component stack) if the user selected something via devtools.
|
|
5363
|
+
- Include any file paths, component names, or page names the user mentioned.
|
|
5364
|
+
- If you skip the \`context\` field, the explore agent is searching completely blind and will waste time guessing.
|
|
5365
|
+
- NEVER call \`explore_agent\` with only a \`query\` and no \`context\` when the user's message contains devtools or component information.
|
|
5366
|
+
|
|
5340
5367
|
2. **Use direct commands (grep/rg, find)** for:
|
|
5341
5368
|
- Exact string matches: \`rg "functionName"\`, \`rg "class MyClass"\`
|
|
5342
5369
|
- Finding files by name: \`find . -name "*.config.ts"\`
|
|
@@ -5344,7 +5371,8 @@ Use this proactively after making code changes to catch errors early.
|
|
|
5344
5371
|
- Counting occurrences or listing all matches
|
|
5345
5372
|
|
|
5346
5373
|
**Examples:**
|
|
5347
|
-
-
|
|
5374
|
+
- User selected \`<LandingButton>\` at \`src/components/LandingButton.tsx:12\` \u2192 Just \`read_file("src/components/LandingButton.tsx")\`. Do NOT call explore_agent.
|
|
5375
|
+
- "Where is the API authentication handled?" (no file path given) \u2192 Use \`explore_agent\` tool
|
|
5348
5376
|
- "Find all usages of getUserById" \u2192 Use \`rg "getUserById"\`
|
|
5349
5377
|
- "How does the payment flow work?" \u2192 Use \`explore_agent\` tool
|
|
5350
5378
|
- "Find files named config" \u2192 Use \`find . -name "*config*"\`
|