- होम
- Documentation
- रनटाइम टूल
- Resolve टूल रनटाइम इंटर्नल्स
Resolve टूल रनटाइम इंटर्नल्स
यह दस्तावेज़ बताता है कि coding-agent में preview/apply वर्कफ़्लो को कैसे मॉडल किया जाता है और कस्टम टूल pushPendingAction के माध्यम से कैसे भाग ले सकते हैं।
स्कोप और मुख्य फ़ाइलें
Section titled “स्कोप और मुख्य फ़ाइलें”src/tools/resolve.tssrc/tools/pending-action.tssrc/tools/ast-edit.tssrc/extensibility/custom-tools/types.tssrc/extensibility/custom-tools/loader.tssrc/sdk.ts
resolve क्या करता है
Section titled “resolve क्या करता है”resolve एक छिपा हुआ टूल है जो एक pending preview action को अंतिम रूप देता है।
action: "apply"pending action परapply(reason)को निष्पादित करता है और परिवर्तनों को सुरक्षित करता है।action: "discard"यदि प्रदान किया गया हो तोreject(reason)को आमंत्रित करता है; अन्यथा एक डिफ़ॉल्ट “Discarded” संदेश के साथ action को छोड़ देता है।
यदि कोई pending action मौजूद नहीं है, तो resolve निम्न त्रुटि के साथ विफल होता है:
No pending action to resolve. Nothing to apply or discard.
Pending actions एक स्टैक (LIFO) हैं
Section titled “Pending actions एक स्टैक (LIFO) हैं”Pending actions को PendingActionStore में push/pop स्टैक के रूप में संग्रहीत किया जाता है:
push(action)शीर्ष पर एक नया pending action जोड़ता है।peek()वर्तमान शीर्ष action का निरीक्षण करता है।pop()शीर्ष action को हटाता है और लौटाता है।hasPendingइंगित करता है कि स्टैक खाली नहीं है।
resolve हमेशा पहले सबसे ऊपर के pending action को उपभोग करता है (pop()), इसलिए एकाधिक preview-उत्पन्न करने वाले टूल पंजीकरण के विपरीत क्रम में resolve होते हैं।
अंतर्निहित producer उदाहरण (ast_edit)
Section titled “अंतर्निहित producer उदाहरण (ast_edit)”ast_edit पहले structural replacements का preview करता है। जब preview में replacements होते हैं और वह अभी तक apply नहीं हुआ है, तो यह एक pending action push करता है जिसमें शामिल हैं:
- label (मानव-पठनीय सारांश)
sourceToolName(ast_edit)apply(reason: string)callback जोdryRun: falseके साथ AST edit को पुनः चलाता है
resolve(action="apply", reason="...") इस callback में reason पास करता है।
कस्टम टूल: pushPendingAction
Section titled “कस्टम टूल: pushPendingAction”कस्टम टूल CustomToolAPI.pushPendingAction(...) के माध्यम से resolve-संगत pending actions पंजीकृत कर सकते हैं।
CustomToolPendingAction:
label: string(आवश्यक)apply(reason: string): Promise<AgentToolResult<unknown>>(आवश्यक) — apply पर आमंत्रित होता है;reasonवह string है जोresolveको पास की जाती हैreject?(reason: string): Promise<AgentToolResult<unknown> | undefined>(वैकल्पिक) — discard पर आमंत्रित होता है; यदि प्रदान किया गया हो तो return value डिफ़ॉल्ट “Discarded” संदेश को प्रतिस्थापित करती हैdetails?: unknown(वैकल्पिक)sourceToolName?: string(वैकल्पिक, डिफ़ॉल्ट"custom_tool")
न्यूनतम उपयोग उदाहरण
Section titled “न्यूनतम उपयोग उदाहरण”import type { CustomToolFactory } from "@f5-sales-demo/xcsh";
const factory: CustomToolFactory = pi => ({ name: "batch_rename_preview", label: "Batch Rename Preview", description: "Previews renames and defers commit to resolve", parameters: pi.typebox.Type.Object({ files: pi.typebox.Type.Array(pi.typebox.Type.String()), }),
async execute(_toolCallId, params) { const previewSummary = `Prepared rename plan for ${params.files.length} files`;
pi.pushPendingAction({ label: `Batch rename: ${params.files.length} files`, sourceToolName: "batch_rename_preview", apply: async (reason) => { // apply writes here return { content: [{ type: "text", text: `Applied batch rename. Reason: ${reason}` }], }; }, reject: async (reason) => { // optional: cleanup or notify on discard return { content: [{ type: "text", text: `Discarded batch rename. Reason: ${reason}` }], }; }, });
return { content: [{ type: "text", text: `${previewSummary}. Call resolve to apply or discard.` }], }; },});
export default factory;रनटाइम उपलब्धता और विफलताएं
Section titled “रनटाइम उपलब्धता और विफलताएं”pushPendingAction को कस्टम टूल लोडर द्वारा सक्रिय session PendingActionStore का उपयोग करके जोड़ा जाता है।
यदि रनटाइम में कोई pending-action store नहीं है, तो pushPendingAction निम्न त्रुटि फेंकता है:
Pending action store unavailable for custom tools in this runtime.
टूल-चॉइस व्यवहार
Section titled “टूल-चॉइस व्यवहार”जब PendingActionStore.hasPending true होता है, तो agent runtime टूल चॉइस को resolve की ओर प्राथमिकता देता है ताकि सामान्य टूल प्रवाह जारी रखने से पहले pending previews को स्पष्ट रूप से अंतिम रूप दिया जा सके।
डेवलपर मार्गदर्शन
Section titled “डेवलपर मार्गदर्शन”- Pending actions का उपयोग केवल विनाशकारी या उच्च-प्रभाव वाले ऑपरेशन के लिए करें जिन्हें स्पष्ट apply/discard का समर्थन करना चाहिए।
labelको संक्षिप्त और विशिष्ट रखें; यह resolve renderer आउटपुट में दिखाया जाता है।- सुनिश्चित करें कि
apply(reason)एकल निष्पादन के लिए पर्याप्त रूप से निर्धारणवादी और idempotent हो;reasonसूचनात्मक है और व्यवहार को नहीं बदलना चाहिए। reject(reason)तब लागू करें जब discard को cleanup की आवश्यकता हो (अस्थायी state, locks, notifications); उन stateless previews के लिए इसे छोड़ दें जहाँ डिफ़ॉल्ट संदेश पर्याप्त हो।- यदि आपका टूल एकाधिक previews स्टेज कर सकता है, तो LIFO semantics याद रखें: सबसे बाद में push किया गया action पहले resolve होता है।