agent-afk 3.32.1 → 3.32.2
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/cli.mjs +2 -2
- package/package.json +1 -1
package/dist/cli.mjs
CHANGED
|
@@ -2121,14 +2121,14 @@ _ended: ${new Date().toISOString()}_
|
|
|
2121
2121
|
`),C()):F();return}if(M?.shift&&M?.name==="tab"||M?.sequence==="\x1B[Z"){e.onShiftTab?.();return}if(M?.name==="tab"){p.dropdownOpen&&D();return}let B=typeof V=="string"&&V.length===1&&V>=" "&&!M?.ctrl&&!M?.meta?V:typeof M?.sequence=="string"&&M.sequence.length===1&&M.sequence>=" "&&!M?.ctrl&&!M?.meta?M.sequence:null;B!==null&&(d=G.insert(d,B),e.history?.resetRecall(),g||(W?P():C()))},l=Je.subscribe(()=>{y=0,w=0,f=0,C()}),t.on("keypress",a)})}finally{e.statusLine?.setExtraRows(o),r.restore()}}async function bS(e){return!process.stdout.isTTY||!process.stdin.isTTY?gS(e):yS(e)}var vl=class{history;autocompleteState;rl;statusLine;compositor=null;armedStdout=null;backgroundHandler=null;pendingReadReject=null;slashRegistryView={has:t=>Ge().some(n=>n.name===`/${t}`)};constructor(t){this.rl=t.rl,this.history=t.history,this.statusLine=t.statusLine,this.autocompleteState=Sl()}async armCompositor(t){if(this.compositor)return;let n=t.stdout??process.stdout,r=t.stdin??process.stdin;if(!n.isTTY||!r.isTTY)return;let o=new Qr({stdout:n,stdin:r,promptText:t.promptFn,onCancel:t.onCancel,onBackground:()=>{this.backgroundHandler?.()},...t.onShiftTab?{onShiftTab:t.onShiftTab}:{},history:this.history,autocompleteState:this.autocompleteState,formatInputBuffer:s=>vn(s,this.slashRegistryView),...t.scrollRegion?{scrollRegion:t.scrollRegion}:{}});await o.arm(),o.setInputMode("idle"),this.compositor=o,this.armedStdout=n}async dispose(){if(this.compositor){if(this.pendingReadReject){this.compositor.setOnSubmit(null);let t=this.pendingReadReject;this.pendingReadReject=null,t(new Error("InputSurface disposed while readLine was in progress"))}try{this.compositor.disarm()}catch{}this.compositor=null,this.armedStdout=null,this.backgroundHandler=null}}getCompositor(){return this.compositor}setBackgroundHandler(t){this.backgroundHandler=t}async readLine(t){if(this.compositor&&this.compositor.isArmed()){let n=this.compositor;return new Promise((r,o)=>{this.pendingReadReject=o;let s=i=>{n.setOnSubmit(null),this.pendingReadReject=null;let a=this.armedStdout??process.stdout,l=Xn({buffer:vn(i.text,this.slashRegistryView),promptText:t.promptFn(),isTTY:!!a.isTTY,attachmentSummary:Xr([...i.attachments])});for(let c of l.split(`
|
|
2122
2122
|
`))n.commitAbove(c);r({text:i.text,attachments:[...i.attachments]})};n.setOnSubmit(s),n.setInputMode("idle")})}return bS({rl:this.rl,promptFn:t.promptFn,...t.onSigint?{onSigint:t.onSigint}:{},...t.onShiftTab?{onShiftTab:t.onShiftTab}:{},...t.compositor?{compositor:t.compositor}:{},history:this.history,autocompleteState:this.autocompleteState,...this.statusLine?{statusLine:this.statusLine}:{}})}toRunTurnRefs(t){return{history:this.history,autocompleteState:this.autocompleteState,promptText:t}}};function wS(e){if(!e)return null;let t=e.split(`
|
|
2123
2123
|
`),n=t.slice(Math.max(0,t.length-40)),r=-1,o=null;for(let l=n.length-1;l>=0;l--){let c=n[l]??"",u=LF(c);if(u){r=l,o=u;break}}if(o===null||r<0)return null;let s=n.slice(r+1).map(l=>l.trim());for(;s.length>0&&s[0]==="";)s.shift();for(;s.length>0&&s[s.length-1]==="";)s.pop();let i=FF(s),a=s.join(`
|
|
2124
|
-
`).trim();return{kind:o,rawBody:a,...NF(o,i)}}function LF(e){let t=e.trim().replace(/^#{1,6}\s+/,"").replace(/^[-•▶▸]\s+/,"").replace(/^\*\s+/,"").replace(/^\*\*(.+?)\*\*$/,"$1").replace(/^__(.+?)__$/,"$1").replace(/^\*(.+?)\*$/,"$1").replace(/^_(.+?)_$/,"$1").replace(/[.:!?\s]+$/,"").trim();if(t.length===0||t.length>24)return null;let n=t.toLowerCase();return n==="done"?"done":n==="blocked"?"blocked":n==="asking"?"asking":n==="interrupted"?"interrupted":null}function FF(e){let t=[];for(let n of e){let r=n.trim();if(r==="")continue;let o=/^(?:[-*•▶▸]|\d+[.)])\s+(.*)$/.exec(r),s=o?(o[1]??"").trim():r;if(!o&&t.length>0&&r.length>0){let a=t[t.length-1];a.value=`${a.value} ${r}`.trim();continue}let i=s.indexOf(":");if(i>0&&i<60){let a=s.slice(0,i).trim().replace(/^\*\*(.+?)\*\*$/,"$1").replace(/^__(.+?)__$/,"$1").toLowerCase(),l=s.slice(i+1).trim();t.push({label:a,value:l})}else t.push({label:"",value:s})}return t}function NF(e,t){let n=(...r)=>{for(let o of t)if(o.label!==""){for(let s of r)if(o.label.includes(s))return o.value}};switch(e){case"done":{let r={},o=n("what was done","what i did","completed","done");o!==void 0&&(r.whatWasDone=o);let s=n("evidence","what changed","change","artifact","output");s!==void 0&&(r.evidence=s);let i=n("pending","deferred","follow-up","followup","next");return i!==void 0&&(r.deferred=i),r}case"blocked":{let r={},o=n("what blocks","blocker","blocked by");o!==void 0&&(r.whatBlocks=o);let s=n("unblock","must change","to unblock","condition");s!==void 0&&(r.unblockCondition=s);let i=n("has already","been done","already done","what has been done","progress");return i!==void 0&&(r.alreadyDone=i),r}case"asking":{let r={},o=n("question","asking");o!==void 0&&(r.question=o);let s=n("assumption","resolves");s!==void 0&&(r.assumption=s);let i=n("once answered","follow-up","next","will do","after");return i!==void 0&&(r.followup=i),r}case"interrupted":{let r={},o=n("what you were doing","in progress","doing","task");o!==void 0&&(r.whatWasInProgress=o);let s=n("state was saved","state","saved","where");s!==void 0&&(r.stateLocation=s);let i=n("resumption","resume","requires");return i!==void 0&&(r.resumeRequires=i),r}}}var jF={done:{color:m.success,chip:"\u2713 Done",affordance:"Objective satisfied \u2014 review evidence and close."},blocked:{color:m.error,chip:"\u2298 Blocked",affordance:"External dependency \u2014 unblock above to resume."},asking:{color:m.warning,chip:"? Asking",affordance:"Waiting on you \u2014 answer above to continue."},interrupted:{color:m.meta,chip:"\u23F8 Interrupted",affordance:"Halted with state preserved \u2014 resume when ready."}};function kS(e){let t=jF[e.kind],n=Math.max(
|
|
2124
|
+
`).trim();return{kind:o,rawBody:a,...NF(o,i)}}function LF(e){let t=e.trim().replace(/^#{1,6}\s+/,"").replace(/^[-•▶▸]\s+/,"").replace(/^\*\s+/,"").replace(/^\*\*(.+?)\*\*$/,"$1").replace(/^__(.+?)__$/,"$1").replace(/^\*(.+?)\*$/,"$1").replace(/^_(.+?)_$/,"$1").replace(/[.:!?\s]+$/,"").trim();if(t.length===0||t.length>24)return null;let n=t.toLowerCase();return n==="done"?"done":n==="blocked"?"blocked":n==="asking"?"asking":n==="interrupted"?"interrupted":null}function FF(e){let t=[];for(let n of e){let r=n.trim();if(r==="")continue;let o=/^(?:[-*•▶▸]|\d+[.)])\s+(.*)$/.exec(r),s=o?(o[1]??"").trim():r;if(!o&&t.length>0&&r.length>0){let a=t[t.length-1];a.value=`${a.value} ${r}`.trim();continue}let i=s.indexOf(":");if(i>0&&i<60){let a=s.slice(0,i).trim().replace(/^\*\*(.+?)\*\*$/,"$1").replace(/^__(.+?)__$/,"$1").toLowerCase(),l=s.slice(i+1).trim();t.push({label:a,value:l})}else t.push({label:"",value:s})}return t}function NF(e,t){let n=(...r)=>{for(let o of t)if(o.label!==""){for(let s of r)if(o.label.includes(s))return o.value}};switch(e){case"done":{let r={},o=n("what was done","what i did","completed","done");o!==void 0&&(r.whatWasDone=o);let s=n("evidence","what changed","change","artifact","output");s!==void 0&&(r.evidence=s);let i=n("pending","deferred","follow-up","followup","next");return i!==void 0&&(r.deferred=i),r}case"blocked":{let r={},o=n("what blocks","blocker","blocked by");o!==void 0&&(r.whatBlocks=o);let s=n("unblock","must change","to unblock","condition");s!==void 0&&(r.unblockCondition=s);let i=n("has already","been done","already done","what has been done","progress");return i!==void 0&&(r.alreadyDone=i),r}case"asking":{let r={},o=n("question","asking");o!==void 0&&(r.question=o);let s=n("assumption","resolves");s!==void 0&&(r.assumption=s);let i=n("once answered","follow-up","next","will do","after");return i!==void 0&&(r.followup=i),r}case"interrupted":{let r={},o=n("what you were doing","in progress","doing","task");o!==void 0&&(r.whatWasInProgress=o);let s=n("state was saved","state","saved","where");s!==void 0&&(r.stateLocation=s);let i=n("resumption","resume","requires");return i!==void 0&&(r.resumeRequires=i),r}}}var jF={done:{color:m.success,chip:"\u2713 Done",affordance:"Objective satisfied \u2014 review evidence and close."},blocked:{color:m.error,chip:"\u2298 Blocked",affordance:"External dependency \u2014 unblock above to resume."},asking:{color:m.warning,chip:"? Asking",affordance:"Waiting on you \u2014 answer above to continue."},interrupted:{color:m.meta,chip:"\u23F8 Interrupted",affordance:"Halted with state preserved \u2014 resume when ready."}};function kS(e){let t=jF[e.kind],n=Math.max(34,Math.min(ne()-6,100)),r=n+4,o=t.color("\u256D\u2500")+t.color.call(null,` ${t.chip} `)+t.color("\u2500".repeat(Math.max(0,r-1-q(` ${t.chip} `)))+"\u256E"),s=t.color("\u2570"+"\u2500".repeat(r)+"\u256F"),i=t.color("\u2502"),a=i+" ".repeat(n+4)+i,l=UF(e),c=l.reduce((f,g)=>Math.max(f,q(g.label)),0),u=Math.max(8,n-c-2),d=[o,a];if(l.length===0){let f=e.rawBody.split(`
|
|
2125
2125
|
`).find(b=>b.trim().length>0)?.trim()??"",g=f.length>0?f:`${e.kind} (no structured fields)`,h=pe(en(g),n).split(`
|
|
2126
2126
|
`);for(let b of h)d.push(i+" "+Fe(b,n)+" "+i)}else for(let f of l){let g=m.dim(Fe(f.label,c)),h=pe(en(f.value),u).split(`
|
|
2127
2127
|
`),b=h[0]??"";d.push(i+" "+g+" "+Fe(b,u)+" "+i);for(let y of h.slice(1))d.push(i+" "+" ".repeat(c)+" "+Fe(y,u)+" "+i)}d.push(a);let p=m.dim(ce(t.affordance,n));return d.push(i+" "+Fe(p,n)+" "+i),d.push(s),d.join(`
|
|
2128
2128
|
`)}function UF(e){let t=[],n=(r,o)=>{o&&o.trim().length>0&&t.push({label:r,value:o.trim()})};switch(e.kind){case"done":n("done",e.whatWasDone),n("evidence",e.evidence),n("deferred",e.deferred);break;case"blocked":n("blocks",e.whatBlocks),n("unblock",e.unblockCondition),n("progress",e.alreadyDone);break;case"asking":n("question",e.question),n("resolves",e.assumption),n("after",e.followup);break;case"interrupted":n("was doing",e.whatWasInProgress),n("saved at",e.stateLocation),n("resume",e.resumeRequires);break}return t}function SS(e,t,n){let r=[];return n&&n.trim().length>0&&r.push({type:"text",text:n}),e&&r.push({type:"text",text:e}),qa(r,t),r}async function vS(e,t,n,r,o="summary",s,i,a){let l=cw(e.text,e.attachments);r.setInFlight(!0);let c="",u=!1,d=!1,p=!1,f=!1,g,h=!1,b=[],y=new Map,w=e.text.startsWith("/")?e.text.split(/[\s:]/)[0]?.slice(1):void 0,T=r.getCompositor?r.getCompositor():null,x=()=>new to({out:no(s),thinkingMode:o,...w?{activeSkillName:w}:{},onCancel:()=>{t.interrupt().catch(A=>{Ve()&&console.error(" "+m.error("session.interrupt() failed:"),A)})},...i?{onBackground:()=>{h=!0}}:{},...a?.history?{history:a.history}:{},...a?.autocompleteState?{autocompleteState:a.autocompleteState}:{},...a?.promptText!==void 0?{promptText:a.promptText}:{},...r.scrollRegion?{scrollRegion:r.scrollRegion}:{},...T?{compositor:T}:{}}),S=x(),v=async()=>{if(!p){p=!0;try{await S.dispose()}catch{}}},R=async()=>{await S.arm();let A=S.getCompositor();if(s&&A){let O=A;s.fn=C=>O.commitAbove(C)}r.setActiveCompositor?.(A),r.rearmStatus?.()};try{T?T.commitAbove(""):console.log(),await R(),i&&r.setBackgroundHandler&&r.setBackgroundHandler(()=>{h=!0});let A=e.attachments.length===0?e.text:SS(e.text,e.attachments),O=t.sendMessageStream(A);if(await Tr((I,P)=>{S.process(I,P)},async()=>{for await(let I of O){if(h&&i){let P=w??e.text.slice(0,40),D=i.register(P),F=ha(D,i);ya(O,c,l,D,i,F,n,r.onTurnComplete,t.abortSignal),await v(),(s??{fn:console.log}).fn(m.dim(` \u2192 backgrounded as ${D.id}: ${D.label}`)),r.setInFlight(!1),r.rearmStatus?.();return}if(I.type==="chunk"&&I.chunk.type==="content"?(c+=I.chunk.content,u=!0):I.type==="message"&&!u&&(c=I.message.content),I.type==="chunk"&&I.chunk.type==="tool_use_detail"){let P=I.chunk,D={toolName:P.toolName,toolUseId:P.toolUseId,input:P.toolInput};y.set(P.toolUseId,D),b.push(D)}else if(I.type==="chunk"&&I.chunk.type==="tool_result"){let P=I.chunk,D=y.get(P.toolUseId);D&&(D.result=P.content,D.isError=P.isError,y.delete(P.toolUseId))}if(I.type==="paused"){await v(),(s??{fn:console.log}).fn(Im({reason:I.reason,...I.resetsAt!==void 0?{resetsAt:I.resetsAt}:{},...I.accountId!==void 0?{accountId:I.accountId}:{},...I.autoResume!==void 0?{autoResume:I.autoResume}:{}}));continue}if(I.type==="resumed"){let P=I.hotSwapped&&I.accountId?`\u25B6 Resumed on ${I.accountId}`:"\u25B6 Resumed";c="",u=!1,b.length=0,y.clear(),f=!1,g=void 0,d=!1,h=!1,S=x(),p=!1,await R(),(s??{fn:console.log}).fn(m.success(P));continue}if(I.type==="error"){await v(),kr(wr(I.error)),d=!0;continue}S.process(I),I.type==="done"&&(f=!0,g=I.metadata)}}),await v(),f){Jn(n,l,c,g,b),r.onTurnComplete&&await r.onTurnComplete(l,c).catch(()=>{});let I=D=>{s?s.fn(D):console.log(D)};(u||b.length>0)&&I(`
|
|
2129
2129
|
`);let P=wS(c);if(P&&(I(kS(P)),I(""),r.onTerminalState))try{r.onTerminalState(P)}catch{}if(BF(g,n,I),r.onAfterTurn){let D=r.onAfterTurn();D instanceof Promise&&await D.catch(()=>{})}}}catch(A){await v(),d||kr(wr(A))}finally{await v(),s&&(s.fn=A=>console.log(A)),r.setActiveCompositor?.(null),r.setBackgroundHandler?.(null),r.setInFlight(!1),r.rearmStatus?.()}}function BF(e,t,n=console.log){if(!e)return;let r=[];e.durationMs&&r.push(ie(e.durationMs)),e.totalCostUsd!==void 0&&r.push(Ke(e.totalCostUsd));let o=Number(e.usage?.input_tokens??0),s=Number(e.usage?.output_tokens??0);o+s>0&&r.push(Z(o+s)+" tok"),r.length>0&&n(m.dim(" \u25E6 "+r.join(" \xB7 ")));let i=Nu(t),a=nt(t.model);if(i>=1){let l=Math.round((i-1)*a),c=Math.round(a/1e3);console.log(m.error(` context OVER ${c}k tok by ~${Z(l)} tok \u2014 model output may be silently truncated`))}else if(i>.5){let l=i>.8?m.error:m.warning;n(l(` context ${Math.round(i*100)}% used of ${Z(a)}`))}n("")}function TS(e={}){let t=e.load??ma,n=e.onResize??(i=>Je.subscribe(i)),r="",o,s=n(()=>{r=""});return{renderIfChanged(i){let a=i??"unbound",l=t(a),c=xb(l);return a===o&&c===r?[]:(o=a,r=c,c===""?[]:fa(l))},invalidate(){r=""},dispose(){try{s()}catch{}}}}var Kd={done:{glyph:"\u2713",color:m.success,label:"done"},blocked:{glyph:"\u2298",color:m.error,label:"blocked"},asking:{glyph:"?",color:m.warning,label:"asking"},interrupted:{glyph:"\u23F8",color:m.meta,label:"interrupted"}};function ES(e={}){let t=Math.max(2,e.capacity??8),n=[];return{push(r){n.push(r.kind),n.length>t&&(n=n.slice(n.length-t))},reset(){n=[]},entries(){return n},render(){if(n.length===0)return null;let r=m.dim(" ledger "),o=m.dim(" \xB7 "),s=n.map(u=>{let d=Kd[u];return d.color(`${d.glyph} ${d.label}`)}),i=m.dim(` (${n.length} turn${n.length===1?"":"s"})`),a=r+s.join(o)+i,l=Math.max(20,ne()-2);if(q(a)<=l)return a;let c=r+n.map(u=>Kd[u].color(Kd[u].glyph)).join(m.dim(" "))+i;return ce(c,l)}}}var Gd=["\u25D0","\u25D1","\u25D2","\u25D3"],Tl=class{stream;manager;registry;throttleMs;started=!1;lastRepaint=0;spinnerIndex=0;spinnerInterval=null;resizeUnsub=null;updateHandler=null;registryStartedHandler=null;registrySettledHandler=null;rowCount=0;onRowCountChange;constructor(t,n,r={}){this.manager=t,this.registry=n,this.stream=r.stream??process.stdout,this.throttleMs=r.throttleMs??200}setRowCountChangeHandler(t){this.onRowCountChange=t}start(){this.started||(this.started=!0,this.updateHandler=()=>this.scheduleRepaint(),this.manager.on("update",this.updateHandler),this.manager.on("complete",this.updateHandler),this.registry&&(this.registryStartedHandler=t=>{this.scheduleRepaint()},this.registrySettledHandler=t=>{this.scheduleRepaint()},this.registry.on("started",this.registryStartedHandler),this.registry.on("settled",this.registrySettledHandler)),this.resizeUnsub=Je.subscribe(()=>this.repaint()),this.spinnerInterval=setInterval(()=>{this.spinnerIndex=(this.spinnerIndex+1)%Gd.length,this.rowCount>0&&this.repaint()},Math.max(this.throttleMs,50)))}stop(){this.started&&(this.started=!1,this.updateHandler&&(this.manager.removeListener("update",this.updateHandler),this.manager.removeListener("complete",this.updateHandler),this.updateHandler=null),this.registry&&(this.registryStartedHandler&&(this.registry.off("started",this.registryStartedHandler),this.registryStartedHandler=null),this.registrySettledHandler&&(this.registry.off("settled",this.registrySettledHandler),this.registrySettledHandler=null)),this.resizeUnsub&&(this.resizeUnsub(),this.resizeUnsub=null),this.spinnerInterval&&(clearInterval(this.spinnerInterval),this.spinnerInterval=null),this.rowCount>0&&(this.clearRows(),this.rowCount=0,this.onRowCountChange?.(0)))}scheduleRepaint(){Date.now()-this.lastRepaint<this.throttleMs||this.repaint()}repaint(){if(!this.started||!this.stream.isTTY)return;this.lastRepaint=Date.now();let t=[...this.manager.running().map(s=>({kind:"turn",task:s})),...(this.registry?.list()??[]).filter(s=>s.status==="running").map(s=>({kind:"subagent",job:s}))],n=this.stream.rows??24,r=Math.max(0,Math.min(t.length,n-1));if(r!==this.rowCount&&(this.rowCount>0&&this.clearRows(),this.rowCount=r,this.onRowCountChange?.(r)),r===0)return;let o=Math.max(1,n-r);this.stream.write("\x1B[s");for(let s=0;s<r;s++){let i=t[s],a=o+s;this.stream.write(`\x1B[${a};1H`),this.stream.write("\x1B[2K"),this.stream.write(this.formatItemLine(i))}this.stream.write("\x1B[u")}clearRows(){if(!this.stream.isTTY)return;let t=this.stream.rows??24,n=Math.min(this.rowCount,t-1),r=Math.max(1,t-n);this.stream.write("\x1B[s");for(let o=0;o<n;o++)this.stream.write(`\x1B[${r+o};1H`),this.stream.write("\x1B[2K");this.stream.write("\x1B[u")}formatItemLine(t){return t.kind==="turn"?this.formatTaskLine(t.task):this.formatJobLine(t.job)}formatTaskLine(t){let n=Math.max(4,(this.stream.columns??80)-2),r=m.brand(Gd[this.spinnerIndex]),o=m.dim(t.id),s=m.bold(t.label),i=[r,o,s];t.progressDescription&&i.push(m.dim(t.progressDescription));let a=[];t.stats.toolUses>0&&a.push(`${t.stats.toolUses} tool${t.stats.toolUses===1?"":"s"}`),t.stats.tokens>0&&a.push(`${Z(t.stats.tokens)} tok`);let l=Date.now()-t.startedAt;return a.push(ie(l)),a.length>0&&i.push(m.dim(a.join(" \xB7 "))),ce(" "+i.join(" "),n)}formatJobLine(t){let n=Math.max(4,(this.stream.columns??80)-2),r=m.brand(Gd[this.spinnerIndex]),o=m.dim(t.jobId),s=m.bold(t.label||t.jobId),i=[r,o,s],a=Date.now()-t.startedAt;return i.push(m.dim(ie(a))),ce(" "+i.join(" "),n)}};function El(e,t){let n=m.brand("afk")+m.dim(` (${e})`),r=t?m.warning(" \u25CF plan"):"";return n+r+m.dim(" \u203A ")}async function xS(e,t,n,r){let o=null,s=[];e.session.current.waitForInitialization().then(async p=>{Ve()&&(o=ca(p)),await Va(e.session.current),Ve()&&(s=yk())}).catch(()=>{});let i=await fS(),a=new vl({rl:e.rl,history:i,statusLine:e.statusLine}),l,c,u,d;try{await a.armCompositor({promptFn:()=>El(e.stats.model,e.stats.planMode),onCancel:r,onShiftTab:()=>{let h=e.slashCtx;h.stats.planMode&&h.stats.pendingPlanExit?(h.stats.pendingPlanExit=!1,kt(h,!1,{closureSummarySkipped:!0}).catch(()=>{})):kt(h).catch(()=>{}),e.statusLine.rearm()},scrollRegion:e.statusLine}),e.replRenderer.setCompositor(a.getCompositor()),e.slashCtx.getCompositor=()=>a.getCompositor(),c=TS();let p=ES();e.clearVerdictLedger=()=>p.reset(),u=new ga,Lb(u),Wb(u),Gb(u),Hb(e.backgroundRegistry),d=new Tl(u,e.backgroundRegistry),d.setRowCountChangeHandler(h=>{e.statusLine.setExtraRows(h)}),d.start();let f=50,g=[];for(u.on("complete",h=>{g.length>=f&&g.shift(),g.push(h)});;){if(o&&(e.replRenderer.writeLine(o),e.replRenderer.writeLine(""),o=null),s.length>0){for(let v of s)e.replRenderer.writeLine(v);e.replRenderer.writeLine(""),s=[]}for(;g.length>0;){let v=g.shift(),R=v.status==="succeeded"?"\u2713":"\u2717",A=[];if(v.resultText){let C=v.resultText.trim().split(`
|
|
2130
2130
|
`)[0]?.slice(0,80)??"";C&&A.push(C)}v.error&&A.push(v.error.message);let O=[v.stats.toolUses>0?`${v.stats.toolUses} tools`:"",v.stats.tokens>0?`${Math.round(v.stats.tokens/1e3)}k tok`:"",v.stats.durationMs>0?`${Math.round(v.stats.durationMs/1e3)}s`:""].filter(Boolean).join(" \xB7 ");O&&A.push(O),e.replRenderer.writeLine(tn({kind:v.status==="succeeded"?"checkpoint":"diagnosis",title:`${R} ${v.id} ${v.label}`,body:A})),e.replRenderer.writeLine("")}let h=c.renderIfChanged(e.stats.sessionId);if(h.length>0){for(let v of h)e.replRenderer.writeLine(v);e.replRenderer.writeLine("")}let b=p.render();b&&e.replRenderer.writeLine(b);let y,w;if(l!==void 0){let v=l;l=void 0;let R=El(e.stats.model,e.stats.planMode),A=Xn({buffer:v.text,promptText:R,isTTY:!!process.stdout.isTTY,attachmentSummary:Xr([...v.attachments])});e.replRenderer.writeLine(A),y=v.text.trim(),w=v.attachments}else{let v=await a.readLine({promptFn:()=>El(e.stats.model,e.stats.planMode),onSigint:r,onShiftTab:()=>{let R=e.slashCtx;R.stats.planMode&&R.stats.pendingPlanExit?(R.stats.pendingPlanExit=!1,kt(R,!1,{closureSummarySkipped:!0}).catch(()=>{})):kt(R).catch(()=>{}),e.statusLine.rearm()}});y=v.text.trim(),w=v.attachments}if(!y&&w.length===0)continue;let T=!1;if(y.startsWith("/")){let v=await ob(y,e.slashCtx,w);if(v.handled){if(v.result==="exit"){e.rl.close();return}if((y==="/clear"||y.startsWith("/clear "))&&(await t.rotateOnClear(),e.replRenderer.writeLine(m.dim(` transcript: ${t.path()}`)),p.reset()),v.result!==null&&typeof v.result=="object"&&"kind"in v.result&&v.result.kind==="submit"){l={text:v.result.message,attachments:w??[]},e.statusLine.rearm();continue}e.statusLine.rearm();continue}T=!0}i.push(y);let x=y;if(T){let v=Fu(y);if(v){let R=v.name.replace(/^\//,"").split(":").pop()??"";if(R&&kd(R)){let A={skillName:R,rawArgs:v.args,source:"plugin",capabilities:{compose:!0,subagents:!0}},O=e.session.current.sessionId,C=ms(O),I=Date.now();H(`[afk trace] preflight.start commandName=${R}`);let P=!1,D=await ps(A,{cwd:e.stats.cwd??process.cwd(),artifactDir:C},F=>{Ve()&&e.replRenderer.writeLine(m.warning(`\u26A0 preflight(${R}) failed: `)+(F instanceof Error?F.message:String(F)))});P=D!==null,H(`[afk trace] preflight.end commandName=${R} durationMs=${Date.now()-I} success=${P}`),x=Td(D?.manifestBlock,y)}}}let S;if(e.firstTurnHook&&e.stats.totalTurns===0){let v=e.firstTurnHook;e.firstTurnHook=void 0,S=Promise.resolve().then(()=>v(y)).catch(R=>{e.completionWriter.fn(m.warning("\u26A0 ")+"first-turn hook failed: "+(R instanceof Error?R.message:String(R)))})}await vS({text:x,attachments:w},e.session.current,e.stats,{setInFlight(v){n.turnInFlight=v},async onTurnComplete(v,R){await t.appendTurn(v,R)},async onAfterTurn(){await e.contextSampler.onTurn(e.stats.totalTurns),await hb(e.slashCtx),e.statusLine.rearm()},rearmStatus:()=>e.statusLine.rearm(),onTerminalState:v=>p.push(v),setActiveCompositor:v=>{n.activeCompositor=v},scrollRegion:e.statusLine,getCompositor:()=>a.getCompositor(),setBackgroundHandler:v=>a.setBackgroundHandler(v)},e.options.thinkingUi,e.completionWriter,u,a.toRunTurnRefs(El(e.stats.model,e.stats.planMode))),S!==void 0&&await S}}finally{if(u!==void 0)for(let p of u.running())u.cancel(p.id);d?.stop(),c?.dispose(),await a.dispose()}}import{execFile as WF}from"node:child_process";import{dirname as HF,isAbsolute as KF,resolve as GF}from"node:path";import{promisify as qF}from"node:util";var AS=qF(WF),zF=3e3,JF=new Set(["empty","orphaned-dir","orphaned-registration","dead-owner"]);async function VF(){let t=(await AS("git",["rev-parse","--git-common-dir"])).stdout.trim();if(!t)throw new Error("Not in a git repository.");let n=KF(t)?t:GF(process.cwd(),t);return HF(n)}async function RS(e){if(e?.disabled)return{ran:!1,removedCount:0,skippedReason:"disabled"};let t;try{t=await VF()}catch{return{ran:!1,removedCount:0,skippedReason:"not-in-repo"}}let n,r=new Promise(o=>{n=setTimeout(()=>o("timeout"),zF)});try{let o=Ot({execFile:AS,repoRoot:t,dryRun:!1,scope:"interactive",bypassSoftLaunch:!0}),s=await Promise.race([o,r]);if(s==="timeout")return{ran:!1,removedCount:0,skippedReason:"timeout"};let i=s;return i.warnings.some(c=>c.toLowerCase().includes("contested"))?{ran:!1,removedCount:0,skippedReason:"lock-contested"}:{ran:!0,removedCount:i.candidates.filter(c=>JF.has(c.verdict)&&i.removed.includes(c.path)).length}}catch{return{ran:!1,removedCount:0,skippedReason:"error"}}finally{n&&clearTimeout(n)}}import{promises as YF}from"node:fs";import{dirname as XF,join as QF}from"node:path";import{randomBytes as ZF}from"node:crypto";var eN=["Generate a 2-4 word kebab-case slug describing this work request.","Rules:","- ASCII lowercase letters and digits only, separated by single hyphens","- 2 to 4 hyphen-separated words","- Maximum 30 characters total","- No prefix, no quotes, no punctuation other than hyphens","- Output ONLY the slug \u2014 no explanation, no preamble","Examples: fix-cleanup-race, add-telegram-allowlist, refactor-prompt-loader, debug-flaky-test"].join(`
|
|
2131
|
-
`),CS=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,qd=30,tN=1024,nN=8e3,rN="haiku";async function oN(e,t){let n=e.trim();if(n.length===0)return t.onSkip?.("empty-message"),null;if(n.startsWith("/"))return t.onSkip?.("slash-command"),null;let r=lN(n,tN),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??nN),i=t.signal?cN([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await pl({token:t.token,model:t.model??rN,system:eN,user:r,maxTokens:32,signal:i})}catch(d){let p=d instanceof Error?d.message:String(d);return t.onSkip?.("slug-generator-error",p.slice(0,200)),null}finally{clearTimeout(s)}let l=sN(a);if(l===null)return t.onSkip?.("invalid-slug-output",a.slice(0,60)),null;let c=XF(t.worktreePath);return await iN(l,c)}function sN(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(CS.test(t)&&t.length<=qd)return t;let n=t.replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"");if(n.length===0)return null;let r=n.split("-").filter(s=>s.length>0).slice(0,4);if(r.length<2)return null;let o=r[0];for(let s=1;s<r.length;s++){let i=`${o}-${r[s]}`;if(i.length>qd)break;o=i}return CS.test(o)?o:null}async function iN(e,t){if(!await aN(QF(t,e)))return e;let n=ZF(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,qd-5)}-${n}`}async function aN(e){try{return await YF.access(e),!0}catch{return!1}}function lN(e,t){let n=Buffer.from(e,"utf8");if(n.length<=t)return e;let r=t;for(;r>0&&n[r]!==void 0&&(n[r]&192)===128;)r--;return n.slice(0,r).toString("utf8")}function cN(e){let t=AbortSignal.any;if(typeof t=="function")return t.call(AbortSignal,e);let n=new AbortController;for(let r of e){if(r.aborted)return n.abort(r.reason),n.signal;r.addEventListener("abort",()=>n.abort(r.reason),{once:!0})}return n.signal}async function IS(e){let t,n,r=await oN(e.message,{token:e.token,...e.model!==void 0?{model:e.model}:{},...e.timeoutMs!==void 0?{timeoutMs:e.timeoutMs}:{},worktreePath:e.handle.path,...e.signal!==void 0?{signal:e.signal}:{},...e.slugGenerator!==void 0?{slugGenerator:e.slugGenerator}:{},onSkip:(i,a)=>{t=i,n=a}});if(r===null)return{status:"skipped",reason:t??"unknown",...n!==void 0?{detail:n}:{}};let s=await(e.renameFn??Xg)(e.handle,r,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return s.ok?(e.session&&e.session.setCwd(s.newPath),_S(s.newPath),{status:"renamed",oldPath:s.oldPath,newPath:s.newPath,oldBranch:s.oldBranch,newBranch:s.newBranch}):(s.partial==="branch"&&(e.session&&e.session.setCwd(e.handle.path),_S(e.handle.path)),{status:"failed",reason:s.reason,...s.partial!==void 0?{partial:s.partial}:{}})}function _S(e){try{process.chdir(e)}catch{}}N();import{spawn as PS}from"child_process";import{existsSync as fN,mkdirSync as gN,readFileSync as MS,unlinkSync as hN,writeFileSync as yN}from"fs";import{get as bN}from"https";import{join as $S}from"path";import{readFileSync as uN}from"fs";import{dirname as dN,join as pN}from"path";import{fileURLToPath as mN}from"url";function zt(){try{return"3.32.
|
|
2131
|
+
`),CS=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,qd=30,tN=1024,nN=8e3,rN="haiku";async function oN(e,t){let n=e.trim();if(n.length===0)return t.onSkip?.("empty-message"),null;if(n.startsWith("/"))return t.onSkip?.("slash-command"),null;let r=lN(n,tN),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??nN),i=t.signal?cN([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await pl({token:t.token,model:t.model??rN,system:eN,user:r,maxTokens:32,signal:i})}catch(d){let p=d instanceof Error?d.message:String(d);return t.onSkip?.("slug-generator-error",p.slice(0,200)),null}finally{clearTimeout(s)}let l=sN(a);if(l===null)return t.onSkip?.("invalid-slug-output",a.slice(0,60)),null;let c=XF(t.worktreePath);return await iN(l,c)}function sN(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(CS.test(t)&&t.length<=qd)return t;let n=t.replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"");if(n.length===0)return null;let r=n.split("-").filter(s=>s.length>0).slice(0,4);if(r.length<2)return null;let o=r[0];for(let s=1;s<r.length;s++){let i=`${o}-${r[s]}`;if(i.length>qd)break;o=i}return CS.test(o)?o:null}async function iN(e,t){if(!await aN(QF(t,e)))return e;let n=ZF(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,qd-5)}-${n}`}async function aN(e){try{return await YF.access(e),!0}catch{return!1}}function lN(e,t){let n=Buffer.from(e,"utf8");if(n.length<=t)return e;let r=t;for(;r>0&&n[r]!==void 0&&(n[r]&192)===128;)r--;return n.slice(0,r).toString("utf8")}function cN(e){let t=AbortSignal.any;if(typeof t=="function")return t.call(AbortSignal,e);let n=new AbortController;for(let r of e){if(r.aborted)return n.abort(r.reason),n.signal;r.addEventListener("abort",()=>n.abort(r.reason),{once:!0})}return n.signal}async function IS(e){let t,n,r=await oN(e.message,{token:e.token,...e.model!==void 0?{model:e.model}:{},...e.timeoutMs!==void 0?{timeoutMs:e.timeoutMs}:{},worktreePath:e.handle.path,...e.signal!==void 0?{signal:e.signal}:{},...e.slugGenerator!==void 0?{slugGenerator:e.slugGenerator}:{},onSkip:(i,a)=>{t=i,n=a}});if(r===null)return{status:"skipped",reason:t??"unknown",...n!==void 0?{detail:n}:{}};let s=await(e.renameFn??Xg)(e.handle,r,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return s.ok?(e.session&&e.session.setCwd(s.newPath),_S(s.newPath),{status:"renamed",oldPath:s.oldPath,newPath:s.newPath,oldBranch:s.oldBranch,newBranch:s.newBranch}):(s.partial==="branch"&&(e.session&&e.session.setCwd(e.handle.path),_S(e.handle.path)),{status:"failed",reason:s.reason,...s.partial!==void 0?{partial:s.partial}:{}})}function _S(e){try{process.chdir(e)}catch{}}N();import{spawn as PS}from"child_process";import{existsSync as fN,mkdirSync as gN,readFileSync as MS,unlinkSync as hN,writeFileSync as yN}from"fs";import{get as bN}from"https";import{join as $S}from"path";import{readFileSync as uN}from"fs";import{dirname as dN,join as pN}from"path";import{fileURLToPath as mN}from"url";function zt(){try{return"3.32.2"}catch{}try{let e=dN(mN(import.meta.url));for(let t of["../../package.json","../package.json"])try{let n=JSON.parse(uN(pN(e,t),"utf-8"));if(typeof n.version=="string")return n.version}catch{}}catch{}return"0.0.0-unknown"}K();var wN=64*1024,kN=1440*60*1e3,SN="update-check.json",vN="pending-update.json";function OS(){return $S(Bs(),SN)}function zd(){return $S(Bs(),vN)}function DS(){let e=Bs();fN(e)||gN(e,{recursive:!0})}function TN(e,t){let n=e.split(".").map(Number),r=t.split(".").map(Number),o=Math.max(n.length,r.length);for(let s=0;s<o;s++){let i=n[s]??0,a=r[s]??0;if(a>i)return!0;if(a<i)return!1}return!1}function EN(){try{let e=MS(OS(),"utf-8"),t=JSON.parse(e);if(typeof t.latestVersion=="string"&&typeof t.checkedAt=="number")return t}catch{}return null}function xN(){try{DS();let e=`
|
|
2132
2132
|
const https = require('https');
|
|
2133
2133
|
const fs = require('fs');
|
|
2134
2134
|
const url = 'https://registry.npmjs.org/agent-afk/latest';
|