agent-afk 3.17.1 → 3.17.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
|
@@ -1930,7 +1930,7 @@ ${u}`}function Zc(e,t){let n=vy[t.status];e.out.line(` ${n} ${m.bold(t.jobId)}
|
|
|
1930
1930
|
`):[],r=this.spinner?m.meta(`${Vy[this.spinner.frameIndex]} ${this.spinner.verb}...`)+aM(this.spinner.startedAt):null,o=this.spinner?.currentTip?lM(this.spinner.currentTip.text,this.stdout.columns??80):null,s=null;this.attachments.length>0?s=ia(this.attachments):this.clipboardFailureMsg!==null&&(s=m.dim(this.clipboardFailureMsg),this.clipboardFailureMsg=null);let i=this.renderDropdownRows(),a=Math.max(1,(this.stdout.rows??24)-1),l=(r?1:0)+(o?1:0)+(s?1:0)+1+i.length,c=Math.max(0,a-l),u=n.length>c?n.slice(-c):n,d=[];d.push(...u),r&&d.push(r),o&&d.push(o),s&&d.push(s),d.push(t),d.push(...i),this.logUpdate(d.join(`
|
|
1931
1931
|
`))}resetState(){this.overlay="",this.input=q.seed(""),this.queued=!1,this.canceled=!1,this.backgrounded=!1,this.attachments=[],this.pasting=!1,this.pasteStartBufferLen=0,this.clipboardFailureMsg=null,this.autocompleteState?.reset(),this.resizeUnsub&&(this.resizeUnsub(),this.resizeUnsub=null)}applyEdit(t){return t===this.input?!1:(this.input=t,this.queued=!1,this.updateAutocomplete(),this.pasting||this.repaint(),!0)}applyDropdownSelection(){let t=this.autocompleteState;if(!t?.dropdownOpen||t.candidates.length===0)return!1;let n=t.candidates[t.selectedIndex];if(!n)return!1;let r=this.input.buffer.slice(0,this.input.cursor),o=this.input.buffer.slice(this.input.cursor),s,i;if(t.trigger?.kind==="slash"){let l=/\/[A-Za-z_-]*$/.exec(r);s=l?r.length-l[0].length:this.input.cursor,i=n.value+(o.startsWith(" ")?"":" ")}else if(t.trigger?.kind==="flag"){let l=/--[a-z0-9-]*$/.exec(r);s=l?r.length-l[0].length:this.input.cursor,i=n.value+(o.startsWith(" ")?"":" ")}else{let l=r.search(/[^\s]*$/);s=l>=0?l:this.input.cursor,i=n.value}let a=q.replaceRange(this.input,{start:s,end:this.input.cursor},i);return a===this.input?!1:(this.input=a,t.dropdownOpen=!1,t.candidates=[],t.viewportStart=0,t.selectedIndex=0,this.queued=!1,this.updateAutocomplete(),this.repaint(),!0)}dispatchKey(t,n){if(!this.armed)return;let r=this.autocompleteState,o=n?.sequence??"";if(o==="\x1B[200~"){this.pasting=!0,this.pasteStartBufferLen=this.input.buffer.length;return}if(o==="\x1B[201~"){this.pasting=!1;let a=l=>{this.clipboardInFlight||(this.clipboardInFlight=!0,Gn().then(c=>{c?(this.clipboardFailureMsg=null,this.attachments.push(c),this.repaint()):l==="flag-missing"&&(this.clipboardFailureMsg="[clipboard: no image found]",this.repaint())}).catch(()=>{}).finally(()=>{this.clipboardInFlight=!1}))};this.input.buffer.length===this.pasteStartBufferLen?a("flag-missing"):(this.repaint(),a("silent"));return}if(n?.name==="escape"){if(r?.dropdownOpen){r.suppressedSignature=`${this.input.cursor}:${this.input.buffer}`,r.dropdownOpen=!1,r.candidates=[],this.repaint();return}if(this.inputMode==="idle"||this.canceled)return;this.canceled=!0,this.input.buffer.length>0&&!this.queued&&(this.queued=!0,this.repaint()),this.onCancel&&this.onCancel();return}if(n?.ctrl&&n?.name==="c"){if(this.inputMode==="idle"){this.onCancel&&this.onCancel();return}if(this.canceled)return;this.canceled=!0,this.input.buffer.length>0&&!this.queued&&(this.queued=!0,this.repaint()),this.onCancel&&this.onCancel();return}if(n?.ctrl&&n?.name==="v"){this.clipboardInFlight||(this.clipboardInFlight=!0,Gn().then(a=>{a?(this.clipboardFailureMsg=null,this.attachments.push(a)):this.clipboardFailureMsg="[clipboard: no image found]",this.repaint()}).catch(()=>{}).finally(()=>{this.clipboardInFlight=!1}));return}if(n?.ctrl&&n?.name==="p"||n?.name==="up"){if(r?.dropdownOpen){r.selectedIndex>0&&(r.selectedIndex--,r.selectedIndex<r.viewportStart&&(r.viewportStart=r.selectedIndex),this.repaint());return}if(this.history){let a=this.history.back(this.input.buffer);a!==null&&this.applyEdit(q.seed(a))}return}if(n?.ctrl&&n?.name==="n"||n?.name==="down"){if(r?.dropdownOpen){r.selectedIndex<r.candidates.length-1&&(r.selectedIndex++,r.selectedIndex>=r.viewportStart+e.MAX_DROPDOWN_ROWS&&(r.viewportStart=r.selectedIndex-e.MAX_DROPDOWN_ROWS+1),this.repaint());return}if(this.history){let a=this.history.forward();a!==null&&this.applyEdit(q.seed(a))}return}if(n?.name==="return"){if(this.input.buffer.length===0&&this.attachments.length===0)return;if(this.inputMode==="idle"&&this.onSubmit){let a=this.input.buffer,l=[...this.attachments],c=this.onSubmit;this.queued=!1,this.input=q.seed(""),this.attachments=[],this.autocompleteState?.reset(),this.repaint(),c({text:a,attachments:l});return}this.queued||(this.queued=!0,this.repaint());return}if(n?.name==="backspace"){let a=q.backspace(this.input);a!==this.input?(this.history?.resetRecall(),this.applyEdit(a)):this.queued?(this.queued=!1,this.repaint()):this.attachments.length>0&&(this.attachments.pop(),this.repaint());return}if(n?.name==="left"){this.applyEdit(q.moveLeft(this.input));return}if(n?.name==="right"){this.applyEdit(q.moveRight(this.input));return}if(n?.name==="home"){this.applyEdit(q.moveHome(this.input));return}if(n?.name==="end"){this.applyEdit(q.moveEnd(this.input));return}if(n?.name==="delete"){this.history?.resetRecall(),this.applyEdit(q.deleteForward(this.input));return}if(n?.ctrl&&n?.name==="b"){if(this.inputMode==="idle"||this.backgrounded)return;this.backgrounded=!0,this.onBackground&&this.onBackground();return}if(n?.name==="tab"&&n?.shift){this.onShiftTab&&this.onShiftTab();return}if(n?.name==="tab"){this.applyDropdownSelection();return}let s=["tab","pageup","pagedown"];if(n?.name&&s.includes(n.name)||n?.ctrl||n?.meta)return;let i=typeof t=="string"&&t.length===1&&t>=" "?t:typeof n?.sequence=="string"&&n.sequence.length===1&&n.sequence>=" "?n.sequence:null;i!==null&&(this.history?.resetRecall(),this.applyEdit(q.insert(this.input,i)))}};import cM from"chalk";var uM=/(?<=\s|^)(\/[A-Za-z][\w:-]*)(?=\s|$)/g,dM=/(?<=\s|^)(@[\w./-]*)(?=\s|$)/g;function qn(e,t){return cM.level===0?e:e.replace(uM,r=>{let o=r.slice(1);return t.has(o)?m.brand(r):m.meta(r)}).replace(dM,r=>m.fileRef(r))}H();var pM=m.success("\u2713"),mM=m.error("\u2717");function Fr(e){return e?mM:pM}var aa=3,Xy=2,Qy=3;function Zy(e){switch(Nn(e)){case"read":return"Reading\u2026";case"write":return"Writing\u2026";case"web":return"Fetching\u2026";case"shell":return"Running\u2026";default:return"Running\u2026"}}function du(e){return e.replace(/\/(?:[^/\s,)]+\/){2,}([^/\s,)]+)/g,"$1")}function fM(e){let t=/^(\s*[("]?\s*)cd\s+\S+\s+&&\s+(?!cd\s)(.+)$/.exec(e);return t?(t[1]??"")+(t[2]??""):e}function gM(e,t){if(e==="bash"||e==="Bash")return fM(t);if(e==="compose"||e==="Compose"){let n=t.trim().replace(/^\((.*)\)$/s,"$1");try{let r=JSON.parse(n);if(r&&typeof r=="object"){let o=Array.isArray(r.nodes)?r.nodes.length:void 0,s=Array.isArray(r.edges)?r.edges.length:0;if(o!==void 0){let i=`${o} node${o===1?"":"s"}`,a=s>0?`, ${s} edge${s===1?"":"s"}`:"";return`(${i}${a})`}}}catch{}}return t}function eb(e){return e.replace(/[\r\n]+/g," ")}var hM={"(":")","{":"}","[":"]"};function yM(e,t,n="\u2026"){let r=e.charAt(0),o=hM[r];return!(o&&e.endsWith(o)&&e.length>=2)||K(e)<=t?ce(e,t,n):t<3?t>=2?r+o:ce(e,t,n):ce(e,t-1,n)+o}function yn(e,t){let n=/^([A-Za-z_][A-Za-z0-9_]*)(.*)$/s.exec(e);if(n){let r=n[1],o=du(gM(r,n[2]??"")),s=Nn(r),{color:i,glyph:a}=xr(r),l=$c(s),c=l?` [${l}]`:"";if(t!==void 0){let d=(a+" ").length+r.length+c.length,p=Math.max(1,t-d);o=yM(o,p)}o=eb(o);let u=i(a+" ")+i.bold(r)+m.toolArg(o);return l?u+m.dim(c):u}return m.chrome("\u25CF ")+m.toolArg(e)}function bM(e,t){return e?e==="grep"||e==="Grep"?t===1?"match":"matches":e==="glob"||e==="Glob"?t===1?"path":"paths":t===1?"line":"lines":t===1?"line":"lines"}function zn(e,t,n=60,r){let o=e.isError?m.error:m.dim,s=t??E.HOME??"___NOHOME___";if(e.display!==void 0&&!e.isError)return o(e.display);if(e.persistedPath){let a=e.persistedPath.startsWith(s)?"~"+e.persistedPath.slice(s.length):e.persistedPath;return o(`saved \u2192 ${a}`)}if(e.lineCount!==void 0&&e.lineCount>1)return o(`${e.lineCount} ${bM(r,e.lineCount)}`);let i=e.content.length>n?e.content.slice(0,n-3)+"\u2026":e.content;return o(eb(i))}var cu=8;function wM(){let e=E.AFK_SHOW_DIFFS;if(e===void 0)return!1;let t=e.trim().toLowerCase();return t==="0"||t==="false"||t==="no"||t==="off"}var kM=/[\x00-\x08\x0B-\x1F\x7F]/g;function SM(e){let t=Ve(e.text).replace(kM,"");return e.kind==="+"?m.diffAdd("+ "+t):e.kind==="-"?m.diffRemove("- "+t):m.dim(" "+t)}var uu=new WeakMap;function Jn(e,t,n){if(wM())return[];let r=t+"|"+n,o=uu.get(e);if(o!==void 0){let a=o.get(r);if(a!==void 0)return a}let s=[],i=[];for(let a of e.hunks){let l=`@@ -${a.oldStart},${a.oldLines} +${a.newStart},${a.newLines} @@`;i.push({kind:"header",text:m.diffHunk(l)});for(let c of a.lines)i.push({kind:"body",text:SM(c)})}if(t==="overlay"){let a=i.filter(l=>l.kind!=="header");if(a.length>cu){let l=0,c=[];for(let d of i)d.kind==="header"?c.push(d):l<cu&&(c.push(d),l++);let u=a.length-cu;for(let d of c)s.push(n+d.text);return s.push(n+m.dim(`\u2026 +${u} more diff line${u===1?"":"s"}`)),Yy(e,r,s),s}}for(let a of i)s.push(n+a.text);return Yy(e,r,s),s}function Yy(e,t,n){let r=uu.get(e);r===void 0&&(r=new Map,uu.set(e,r)),r.set(t,n)}H();function Me(e,t){return ce(e,t)}var pu=Object.freeze({spine:"\u2502 ",spineClosed:" ",lead:" ",turnRoot:"\u25C9 ",midConnector:"\u251C\u2500 ",lastConnector:"\u2570\u2500 ",textPrefix:"\u2502 "}),vM=Object.freeze({spine:"| ",spineClosed:" ",lead:" ",turnRoot:"o ",midConnector:"+- ",lastConnector:"\\- ",textPrefix:"| "});function bn(){let e=E.AGENT_AFK_ASCII;return e&&/^(1|true|yes)$/i.test(e)?vM:pu}function rb(e,t){let n="";for(let r of e)n+=r?t.spineClosed:t.spine;return n+=t.spine,n}function mu(e,t){let n="";for(let r=0;r<e.length;r+=2){let o=e.slice(r,r+2);n+=o===t.spine?m.dim(o):o}return n}function ob(e,t,n){if(!e||!e.trim())return[];let r=m.dim(n.textPrefix),o=Math.max(1,te()-t.length-2-2),s=mu(t,n),i=[];for(let a of e.split(`
|
|
1932
1932
|
`)){let l=ue(a,o);for(let c of l.split(`
|
|
1933
|
-
`))i.push(s+r+c)}return i}function tb(e){return Ze.has(e.toolName)?e.toolName+"::"+e.toolInput:e.toolName}function TM(e){return Ze.has(e)?Xy:Qy}var v3=pu.midConnector,T3=pu.lastConnector;function sb(e,t=bn()){return e.map((n,r)=>({sibling:n,connector:r===e.length-1?t.lastConnector:t.midConnector}))}function ib(e,t){if(e.length<=t)return e;let n=e.slice(0,t),r=e.slice(t),o=_M(r);return[...n,{kind:"overflow",count:r.length,text:o}]}function EM(e,t){return t?[...e,{kind:"resultSummary",summary:t}]:e}function ab(e){if(e.length===0)return[];let t=new Map;for(let o of e){let s=tb(o),i=t.get(s);i||(i=[],t.set(s,i)),i.push(o)}let n=[],r=new Set;for(let o of e){let s=tb(o),i=t.get(s);i.length>=TM(o.toolName)?r.has(s)||(n.push({kind:"group",toolName:o.toolName,label:Ze.has(o.toolName)?o.toolInput:"",entries:i}),r.add(s)):n.push(o)}return n}function lb(e){let t=e.entries.length,n=e.entries.filter(a=>a.result),r=n.filter(a=>a.result.isError),o=n.length,s;if(r.length>0){let a=o-r.length,l=[];a>0&&l.push(`${a} ok`),l.push(`${r.length} error${r.length===1?"":"s"}`),s=l.join(", ")}else o===t?s=`${t} done`:o===0?s=`${t} running`:s=`${o}/${t} done`;return yn(e.toolName+e.label)+m.dim(` \xD7${t} \u2014 ${s}`)}function xM(e,t){return t<=1||e.endsWith("s")||/(sh|ch|x|z)$/i.test(e)?e:e+"s"}var AM=5,nb=60;function RM(e){return e.replace(/[\r\n\x1b]+/g," ").replace(/ {2,}/g," ").trim()}function _M(e){let t=new Map,n=0;for(let s of e)s.kind==="group"?(t.set(s.toolName,(t.get(s.toolName)??0)+s.entries.length),n+=s.entries.length):(t.set(s.toolName,(t.get(s.toolName)??0)+1),n+=1);if(n===0)return"";if(e.length>0&&e.every(s=>Ze.has(s.toolName))&&new Set(e.map(s=>s.toolName)).size===1){let s=[],i=!1;for(let a of e){let c=(a.kind==="group"?a.label:a.toolInput).trim();if(!c.startsWith("(")||!c.endsWith(")")){i=!0;break}let u=c.slice(1,-1),d=RM(u);if(!d){i=!0;break}let p=d.length>nb?d.slice(0,nb-1)+"\u2026":d,f=a.kind==="group"?a.entries.length:1;s.push({display:p,entries:f})}if(!i&&s.length>0){let a=s.slice(0,AM),l=a.map(({display:p,entries:f})=>f>1?`${p} \xD7${f}`:p),c=a.reduce((p,f)=>p+f.entries,0),u=n-c,d=l.join(", ")+(u>0?` (+${u})`:"");return`\u2026 +${n} more: ${d}`}}let o=[];for(let[s,i]of t)o.push(`${i} ${xM(s,i)}`);return`\u2026 +${n} (${o.join(", ")})`}function fu(e,t,n,r=te(),o=[],s=bn()){let i=rb(o,s),a=mu(i,s),l=e.filter(f=>f.kind==="text"),c=e.filter(f=>f.kind==="tool"),u=ab(c),d=ib(u,aa),p=sb(d,s);for(let{sibling:f,connector:g}of p){let h=m.dim(g),b=g===s.lastConnector;if(f.kind==="overflow")n.push(Me(a+h+m.dim(f.text),r));else if(f.kind==="group")n.push(Me(a+h+lb(f),r));else if(f.kind==="resultSummary")n.push(Me(a+h+m.dim(f.summary),r));else{let y=f,S=t.get(y.toolUseId);if(Ze.has(y.toolName)&&S&&S.length>0){if(y.headerEmitted){let T=y.toolInput?`${y.toolName} ${y.toolInput}`:y.toolName;n.push(Me(
|
|
1933
|
+
`))i.push(s+r+c)}return i}function tb(e){return Ze.has(e.toolName)?e.toolName+"::"+e.toolInput:e.toolName}function TM(e){return Ze.has(e)?Xy:Qy}var v3=pu.midConnector,T3=pu.lastConnector;function sb(e,t=bn()){return e.map((n,r)=>({sibling:n,connector:r===e.length-1?t.lastConnector:t.midConnector}))}function ib(e,t){if(e.length<=t)return e;let n=e.slice(0,t),r=e.slice(t),o=_M(r);return[...n,{kind:"overflow",count:r.length,text:o}]}function EM(e,t){return t?[...e,{kind:"resultSummary",summary:t}]:e}function ab(e){if(e.length===0)return[];let t=new Map;for(let o of e){let s=tb(o),i=t.get(s);i||(i=[],t.set(s,i)),i.push(o)}let n=[],r=new Set;for(let o of e){let s=tb(o),i=t.get(s);i.length>=TM(o.toolName)?r.has(s)||(n.push({kind:"group",toolName:o.toolName,label:Ze.has(o.toolName)?o.toolInput:"",entries:i}),r.add(s)):n.push(o)}return n}function lb(e){let t=e.entries.length,n=e.entries.filter(a=>a.result),r=n.filter(a=>a.result.isError),o=n.length,s;if(r.length>0){let a=o-r.length,l=[];a>0&&l.push(`${a} ok`),l.push(`${r.length} error${r.length===1?"":"s"}`),s=l.join(", ")}else o===t?s=`${t} done`:o===0?s=`${t} running`:s=`${o}/${t} done`;return yn(e.toolName+e.label)+m.dim(` \xD7${t} \u2014 ${s}`)}function xM(e,t){return t<=1||e.endsWith("s")||/(sh|ch|x|z)$/i.test(e)?e:e+"s"}var AM=5,nb=60;function RM(e){return e.replace(/[\r\n\x1b]+/g," ").replace(/ {2,}/g," ").trim()}function _M(e){let t=new Map,n=0;for(let s of e)s.kind==="group"?(t.set(s.toolName,(t.get(s.toolName)??0)+s.entries.length),n+=s.entries.length):(t.set(s.toolName,(t.get(s.toolName)??0)+1),n+=1);if(n===0)return"";if(e.length>0&&e.every(s=>Ze.has(s.toolName))&&new Set(e.map(s=>s.toolName)).size===1){let s=[],i=!1;for(let a of e){let c=(a.kind==="group"?a.label:a.toolInput).trim();if(!c.startsWith("(")||!c.endsWith(")")){i=!0;break}let u=c.slice(1,-1),d=RM(u);if(!d){i=!0;break}let p=d.length>nb?d.slice(0,nb-1)+"\u2026":d,f=a.kind==="group"?a.entries.length:1;s.push({display:p,entries:f})}if(!i&&s.length>0){let a=s.slice(0,AM),l=a.map(({display:p,entries:f})=>f>1?`${p} \xD7${f}`:p),c=a.reduce((p,f)=>p+f.entries,0),u=n-c,d=l.join(", ")+(u>0?` (+${u})`:"");return`\u2026 +${n} more: ${d}`}}let o=[];for(let[s,i]of t)o.push(`${i} ${xM(s,i)}`);return`\u2026 +${n} (${o.join(", ")})`}function fu(e,t,n,r=te(),o=[],s=bn()){let i=rb(o,s),a=mu(i,s),l=e.filter(f=>f.kind==="text"),c=e.filter(f=>f.kind==="tool"),u=ab(c),d=ib(u,aa),p=sb(d,s);for(let{sibling:f,connector:g}of p){let h=m.dim(g),b=g===s.lastConnector;if(f.kind==="overflow")n.push(Me(a+h+m.dim(f.text),r));else if(f.kind==="group")n.push(Me(a+h+lb(f),r));else if(f.kind==="resultSummary")n.push(Me(a+h+m.dim(f.summary),r));else{let y=f,S=t.get(y.toolUseId);if(Ze.has(y.toolName)&&S&&S.length>0){if(y.headerEmitted){let T=y.toolInput?`${y.toolName} ${y.toolInput}`:y.toolName;n.push(Me(a+h+m.dim("\u21B3 "+T),r))}else n.push(Me(a+h+y.prefix,r));fu(S,t,n,r,[...o,b],s),y.thinkingTail&&n.push(Me(a+s.spineClosed+m.thinking("\u2307 "+y.thinkingTail),r))}else if(y.result){if(n.push(Me(a+h+y.prefix+m.dim(" \u2014 ")+Fr(y.result.isError)+" "+zn(y.result,void 0,60,y.toolName),r)),y.diff&&!y.result.isError){let T=a+(b?s.spineClosed:m.dim(s.spine))+" ";for(let x of Jn(y.diff,"overlay",T))n.push(x)}}else{n.push(Me(a+h+y.prefix,r));let T=a+(b?s.spineClosed:m.dim(s.spine))+" ";y.thinkingTail?n.push(Me(T+m.thinking("\u2307 "+y.thinkingTail),r)):n.push(Me(T+m.dim(Zy(y.toolName)),r))}}}for(let f of l)n.push(...ob(f.text,i,s))}function gu(e,t,n,r,o=te(),s=[],i=bn()){let a=rb(s,i),l=mu(a,i),c=[],u=e.filter(b=>b.kind==="text"),d=e.filter(b=>b.kind==="tool"),p=ab(d),f=ib(p,aa),g=EM(f,r),h=sb(g,i);for(let{sibling:b,connector:y}of h){let S=m.dim(y),T=y===i.lastConnector;if(b.kind==="overflow")c.push(Me(l+S+m.dim(b.text),o));else if(b.kind==="resultSummary")c.push(Me(l+S+m.dim(b.summary),o));else if(b.kind==="group")c.push(Me(l+S+lb(b),o));else{let x=b,k=t.get(x.toolUseId);if(Ze.has(x.toolName)&&k&&k.length>0)c.push(Me(l+S+x.prefix,o)),c.push(...gu(k,t,n,void 0,o,[...s,T],i));else if(x.result){if(c.push(Me(l+S+x.prefix+m.dim(" \u2014 ")+Fr(x.result.isError)+" "+zn(x.result,n,60,x.toolName),o)),x.diff&&!x.result.isError){let v=l+(T?i.spineClosed:m.dim(i.spine))+" ";for(let R of Jn(x.diff,"flush",v))c.push(R)}}else c.push(Me(l+S+x.prefix,o))}}for(let b of u)c.push(...ob(b.text,a,i));return c}function la(e,t,n,r,o=0){let s=bn(),i=t.filter(h=>h.kind==="tool"),l=i.filter(h=>h.result).reduce((h,b)=>h+(b.result.lineCount??0),0),c=[];i.length>aa&&(c.push(`${i.length} tools`),l>0&&c.push(`${l} lines`));let u=m.dim(s.spine.repeat(o)),d=Array.from({length:o},()=>!1),p=m.dim(s.turnRoot),f=c.length>0?u+p+e.prefix+m.dim(" \u2014 "+c.join(" \xB7 ")):u+p+e.prefix,g=gu(t,n,r,e.agentResultSummary,te(),d,s);return[f,...g].join(`
|
|
1934
1934
|
`)}function cb(e,t=0){let n=bn(),r=m.dim(n.spine.repeat(t)),o=m.dim(n.turnRoot);return r+o+e.prefix}function ca(e,t,n,r,o=0){let s=bn(),i=Array.from({length:o},()=>!1);return gu(t,n,r,e.agentResultSummary,te(),i,s)}function Vo(e,t,n){let r=[];for(let o of t){let s=e.get(o);if(s.length===1){let i=s[0];if(i.result){if(r.push(" "+i.prefix+m.dim(" \u2014 ")+Fr(i.result.isError)+" "+zn(i.result,n,60,i.toolName)),i.diff&&!i.result.isError)for(let a of Jn(i.diff,"flush"," "))r.push(a)}else r.push(" "+i.prefix)}else{r.push(CM(o,s,n));for(let i of s)if(i.diff&&i.result&&!i.result.isError)for(let a of Jn(i.diff,"flush"," "))r.push(a)}}return r}function CM(e,t,n){let{color:r,glyph:o}=xr(e),s=t.map(u=>du(u.toolInput).trim()),i=r(o+" ")+r.bold(e)+m.dim(` \xD7${t.length}`)+" "+m.toolArg(s.join(", ")),a=t.filter(u=>u.result),l=a.filter(u=>u.result.isError);if(l.length>0){let u=a.length-l.length,p=a.filter(g=>!g.result.isError).map(g=>g.result.lineCount).filter(g=>g!==void 0).reduce((g,h)=>g+h,0),f=[];return p>0&&f.push(`${p} lines`),u>0&&f.push(`${u} ok`),f.push(m.error(`${l.length} error${l.length>1?"s":""}`))," "+i+m.dim(" \u2014 ")+f.join(m.dim(", "))}let c=a.map(u=>u.result?.lineCount).filter(u=>u!==void 0);if(c.length===a.length&&c.length>0){if(c.every(p=>p===c[0]))return" "+i+m.dim(` \u2014 ${c[0]} lines each`);let d=c.reduce((p,f)=>p+f,0);return" "+i+m.dim(` \u2014 ${d} lines total`)}if(a.length>0){let u=a.map(d=>zn(d.result,n,60,d.toolName));return" "+i+m.dim(" \u2014 ")+u.join(m.dim(", "))}return" "+i}var ub=6,Yo=class{entries=new Map;order=[];agentIdStack=[];addStart(t,n,r){let o=yn(n+r),s=this.agentIdStack.at(-1)??void 0,i={kind:"tool",toolUseId:t,toolName:n,toolInput:r,prefix:o,...s!==void 0?{agentContext:s}:{}};this.entries.set(t,i),this.order.push(t),vr.has(n)&&this.agentIdStack.push(t)}addStartWithAgentContext(t,n,r,o,s){let i=this.entries.get(t);if(i?.kind==="tool"){i.toolInput=r,i.prefix=yn(n+r,s),o!==void 0&&(i.agentContext=o);return}let a=yn(n+r,s),l={kind:"tool",toolUseId:t,toolName:n,toolInput:r,prefix:a,...o!==void 0?{agentContext:o}:{}};this.entries.set(t,l),this.order.push(t)}mergeAgentLabel(t,n,r){let o=this.entries.get(t);if(o?.kind!=="tool"||!vr.has(o.toolName)||o.toolName==="Agent")return!1;let s=`(${n})`;return o.toolName="Agent",o.toolInput=s,o.prefix=yn("Agent"+s,r),!0}setAgentContext(t,n){let r=this.entries.get(t);r?.kind==="tool"&&(n===void 0?delete r.agentContext:r.agentContext=n)}setAgentResultSummary(t,n){let r=this.entries.get(t);r?.kind==="tool"&&(r.agentResultSummary=n)}setThinkingTail(t,n){let r=this.entries.get(t);r?.kind==="tool"&&(n===void 0?delete r.thinkingTail:r.thinkingTail=n)}addResult(t,n){let r=this.entries.get(t);r?.kind==="tool"&&(r.result=n),this.agentIdStack.at(-1)===t&&this.agentIdStack.pop()}addDiff(t,n){let r=this.entries.get(t);r?.kind==="tool"&&(r.diff=n)}upsertTextChild(t,n,r){let o=this.entries.get(t);if(o?.kind==="text"){o.text=r,o.agentContext=n;return}let s={kind:"text",toolUseId:t,text:r,agentContext:n};this.entries.set(t,s),this.order.push(t)}removeTextChildrenUnder(t){let n=[];for(let[r,o]of this.entries)o.kind==="text"&&o.agentContext===t&&n.push(r);for(let r of n)this.entries.delete(r);if(n.length>0){let r=new Set(n);this.order=this.order.filter(o=>!r.has(o))}}hasPending(){return this.entries.size>0}hasEntry(t){return this.entries.get(t)?.kind==="tool"}getOverlay(){let t=this.buildChildMap(),n=[],r=bn(),o=te(),s=c=>ce(c,o),i=[];for(let c of this.order){let u=this.entries.get(c);!u||u.kind!=="tool"||u.agentContext||i.push(u)}let a=i,l=0;if(i.length>ub){let c=i.filter(f=>!f.result),u=i.filter(f=>f.result),d=Math.max(0,ub-c.length),p=new Set(u.slice(-d));l=u.length-p.size,a=i.filter(f=>!f.result||p.has(f))}for(let c of a){let u=t.get(c.toolUseId);if(Ze.has(c.toolName)&&u&&u.length>0){if(c.headerEmitted){let d=c.toolInput?`${c.toolName} ${c.toolInput}`:c.toolName;n.push(s(" "+m.dim("\u21B3 "+d)))}else n.push(s(m.dim(r.turnRoot)+c.prefix));fu(u,t,n,void 0,void 0,r),c.thinkingTail&&n.push(s(" "+m.thinking("\u2307 "+c.thinkingTail)))}else if(!(Ze.has(c.toolName)&&c.headerEmitted))if(c.result){if(n.push(s(" "+c.prefix+m.dim(" \u2014 ")+Fr(c.result.isError)+" "+zn(c.result,void 0,60,c.toolName))),c.diff&&!c.result.isError)for(let d of Jn(c.diff,"overlay"," "))n.push(s(d))}else n.push(s(" "+c.prefix+m.dim(" \u2026"))),c.thinkingTail&&n.push(s(" "+m.thinking("\u2307 "+c.thinkingTail)))}return l>0&&n.push(s(" "+m.dim(`\u2026 +${l} done`))),n.join(`
|
|
1935
1935
|
`)}ancestorDepthOf(t){let n=new Set([t]),r=0,o=t,s=32;for(;o!==void 0&&r<s;){let i=this.entries.get(o);if(!i||i.kind!=="tool")break;let a=i.agentContext;if(a===void 0||n.has(a))break;n.add(a);let l=this.entries.get(a);if(!l||l.kind!=="tool")break;r+=1,o=a}return r}flushSource(t,n){let r=this.entries.get(t);if(!r||r.kind!=="tool")return[];let o=this.ancestorDepthOf(t),s=[];{let p=[],f=new Set([t]),g=r.agentContext;for(;g!==void 0&&!f.has(g);){f.add(g);let h=this.entries.get(g);if(!h||h.kind!=="tool")break;p.push({entry:h,depth:this.ancestorDepthOf(h.toolUseId)}),g=h.agentContext}p.reverse();for(let{entry:h,depth:b}of p)h.headerEmitted||(s.push(cb(h,b)),h.headerEmitted=!0)}let i=new Set([t]),a=[t];for(;a.length>0;){let p=a.shift();for(let[f,g]of this.entries){if(i.has(f))continue;(g.kind==="tool",g.agentContext)===p&&(i.add(f),g.kind==="tool"&&a.push(f))}}let l=new Map;for(let p of this.order){if(!i.has(p))continue;let f=this.entries.get(p);if(!f)continue;let g=(f.kind==="tool",f.agentContext);if(!g)continue;let h=l.get(g);h||(h=[],l.set(g,h)),h.push(f)}let c=l.get(r.toolUseId)??[],u=r.headerEmitted?ca(r,c,l,n,o).join(`
|
|
1936
1936
|
`):la(r,c,l,n,o);for(let p of i)this.entries.delete(p);this.order=this.order.filter(p=>!i.has(p));let d=u===""?[]:[u];return[...s,...d]}flushCompletedRoots(t){if(this.entries.size===0)return[];let n=this.buildChildMap(),r=[];for(let c of this.order){let u=this.entries.get(c);!u||u.kind!=="tool"||u.agentContext||u.result!==void 0&&r.push(c)}if(r.length===0)return[];let o=[],s=new Map,i=[];for(let c of r){let u=this.entries.get(c);if(!u||u.kind!=="tool")continue;let d=n.get(u.toolUseId);if(Ze.has(u.toolName))if(o.push(...Vo(s,i,t)),s.clear(),i.length=0,u.headerEmitted){let p=ca(u,d??[],n,t,0);o.push(...p)}else o.push(la(u,d??[],n,t));else s.has(u.toolName)||(s.set(u.toolName,[]),i.push(u.toolName)),s.get(u.toolName).push(u)}o.push(...Vo(s,i,t));let a=new Set(r),l=[...r];for(;l.length>0;){let c=l.shift();for(let[u,d]of this.entries){if(a.has(u))continue;(d.kind==="tool",d.agentContext)===c&&(a.add(u),d.kind==="tool"&&l.push(u))}}for(let c of a)this.entries.delete(c);return this.order=this.order.filter(c=>!a.has(c)),o}flush(t){if(this.entries.size===0)return[];let n=this.buildChildMap(),r=[];for(let a of this.order){let l=this.entries.get(a);!l||l.kind!=="tool"||l.agentContext||r.push(a)}let o=[],s=new Map,i=[];for(let a of r){let l=this.entries.get(a);if(!l||l.kind!=="tool")continue;let c=n.get(l.toolUseId);if(Ze.has(l.toolName))if(o.push(...Vo(s,i,t)),s.clear(),i.length=0,l.headerEmitted){let u=ca(l,c??[],n,t,0);o.push(...u)}else o.push(la(l,c??[],n,t));else s.has(l.toolName)||(s.set(l.toolName,[]),i.push(l.toolName)),s.get(l.toolName).push(l)}return o.push(...Vo(s,i,t)),this.entries.clear(),this.order=[],this.agentIdStack=[],o}buildChildMap(){let t=new Map;for(let n of this.order){let r=this.entries.get(n);if(!r)continue;let o=(r.kind==="tool",r.agentContext);if(!o)continue;let s=t.get(o);s||(s=[],t.set(o,s)),s.push(r)}return t}};var Nr=class{buffer="";startedAt=null;hasEmitted=!1;push(t){this.hasEmitted||(this.buffer+=t,this.startedAt||(this.startedAt=Date.now()))}isActive(){return!this.hasEmitted}hasBufferedContent(){return this.buffer.trim().length>0}peek(){return this.buffer}consume(){return this.hasEmitted=!0,this.buffer}collapse(){if(this.hasEmitted||!this.startedAt)return!this.startedAt&&!this.hasEmitted&&We()&&console.error("[afk:thinking] collapse() short-circuited: no thinking chunks received this turn. Model may not support extended thinking, or API ignored the thinking parameter."),null;this.hasEmitted=!0;let t=Date.now()-this.startedAt,n=t<1e3?`${t}ms`:`${(t/1e3).toFixed(1)}s`,r=Math.ceil(this.buffer.length/4);return` ${m.thinking("\u25C6 thought for "+n+" \xB7 "+r+" tok")}`}inlineSummary(){if(!this.startedAt||!this.hasBufferedContent())return null;let t=Date.now()-this.startedAt,n=t<1e3?`${t}ms`:`${(t/1e3).toFixed(1)}s`,r=Math.ceil(this.buffer.length/4);return`thought ${n} \xB7 ${r} tok`}};var hu="__main__";function pb(e){let t={startedAt:Date.now(),lastEventAt:Date.now(),stats:{tokens:0,toolUses:0},contentBuffer:"",done:!1,errored:!1,stalledTicks:0};return e!==void 0&&(t.agentType=e),t}function Xo(e,t){return{type:"tool_result",toolUseId:"synthetic",content:e,isError:t}}function mb(e){let t=["Done"],n=[];e.stats.toolUses&&n.push(`${e.stats.toolUses} tool${e.stats.toolUses===1?"":"s"}`),e.stats.tokens&&n.push(`${Q(e.stats.tokens)} tok`);let r=e.responseMetadata?.durationMs,o=Date.now()-e.startedAt;typeof r=="number"&&(n.push(se(r)),o>r*1.5&&o-r>=1e3&&n.push(`${se(o)} wall`)),n.length===0&&o>0&&n.push(se(o));let s=e.thinkingLane?.inlineSummary();return s&&n.push(s),n.length>0&&t.push(`(${n.join(" \xB7 ")})`),t.join(" ")}var ua=class{out;throttleMs;indent;buffer="";committed="";throttleTimer=null;logUpdate=null;isTTY;flushing=!1;compositor;resizeUnsub=null;constructor(t){this.out=t?.out??process.stdout,this.throttleMs=t?.throttleMs??33,this.indent=t?.indent??" ",this.isTTY=this.out.isTTY??!1,this.compositor=t?.compositor??null,this.logUpdate=null,this.isTTY&&(this.resizeUnsub=ot.subscribe(()=>this.scheduleRepaint()))}async initLogUpdate(){if(!(!this.isTTY||this.logUpdate!==null))try{let n=(await import("log-update")).default,r=(o=>{n(o)});r.clear=()=>n.clear(),this.logUpdate=r}catch{this.logUpdate=null}}hasMarkdownContent(t){return/[#*_\-\`>\[\|~]|\d+\.\s/.test(t)}findBlockBoundary(t){let n=t.indexOf(`
|
|
@@ -2042,7 +2042,7 @@ _ended: ${new Date().toISOString()}_
|
|
|
2042
2042
|
`)}function sD(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 Zw(e,t,n){let r=[];n&&n.trim().length>0&&r.push({type:"text",text:n}),e&&r.push({type:"text",text:e});for(let o of t)r.push({type:"image",source:{type:"base64",media_type:o.mediaType,data:o.bytes.toString("base64")}});return r}async function ek(e,t,n,r,o="summary",s,i,a){let l=Ky(e.text,e.attachments);r.setInFlight(!0);let c="",u=!1,d=!1,p=!1,f=!1,g,h=!1,b=[],y=new Map,S=e.text.startsWith("/")?e.text.split(/[\s:]/)[0]?.slice(1):void 0,T=r.getCompositor?r.getCompositor():null,x=new Ur({out:Br(s),thinkingMode:o,...S?{activeSkillName:S}:{},onCancel:()=>{t.interrupt().catch(v=>{We()&&console.error(" "+m.error("session.interrupt() failed:"),v)})},...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}:{}}),k=async()=>{if(!p){p=!0;try{await x.dispose()}catch{}}};try{T?T.commitAbove(""):console.log(),await x.arm();let v=x.getCompositor();if(s&&v){let C=v;s.fn=A=>C.commitAbove(A)}r.setActiveCompositor?.(v),i&&r.setBackgroundHandler&&r.setBackgroundHandler(()=>{h=!0}),r.rearmStatus?.();let R=e.attachments.length===0?e.text:Zw(e.text,e.attachments),_=t.sendMessageStream(R);if(await Zt(x.sink,async()=>{for await(let C of _){if(h&&i){let A=S??e.text.slice(0,40),O=i.register(A),M=zi(O,i);Ji(_,c,l,O,i,M,n,r.onTurnComplete,t.abortSignal),await k(),(s??{fn:console.log}).fn(m.dim(` \u2192 backgrounded as ${O.id}: ${O.label}`)),r.setInFlight(!1),r.rearmStatus?.();return}if(C.type==="chunk"&&C.chunk.type==="content"?(c+=C.chunk.content,u=!0):C.type==="message"&&!u&&(c=C.message.content),C.type==="chunk"&&C.chunk.type==="tool_use_detail"){let A=C.chunk,O={toolName:A.toolName,toolUseId:A.toolUseId,input:A.toolInput};y.set(A.toolUseId,O),b.push(O)}else if(C.type==="chunk"&&C.chunk.type==="tool_result"){let A=C.chunk,O=y.get(A.toolUseId);O&&(O.result=A.content,O.isError=A.isError,y.delete(A.toolUseId))}if(C.type==="paused"){await k(),(s??{fn:console.log}).fn(Sp({reason:C.reason,...C.resetsAt!==void 0?{resetsAt:C.resetsAt}:{},...C.accountId!==void 0?{accountId:C.accountId}:{}}));continue}if(C.type==="resumed"){let A=C.hotSwapped&&C.accountId?`\u25B6 Resumed on ${C.accountId}`:"\u25B6 Resumed";(s??{fn:console.log}).fn(m.success(A));continue}if(C.type==="error"){await k(),ir(sr(C.error)),d=!0;continue}x.process(C),C.type==="done"&&(f=!0,g=C.metadata)}}),await k(),f){Un(n,l,c,g,b),r.onTurnComplete&&await r.onTurnComplete(l,c).catch(()=>{});let C=O=>{s?s.fn(O):console.log(O)};u&&C(`
|
|
2043
2043
|
`);let A=Xw(c);if(A&&(C(Qw(A)),C(""),r.onTerminalState))try{r.onTerminalState(A)}catch{}if(iD(g,n,C),r.onAfterTurn){let O=r.onAfterTurn();O instanceof Promise&&await O.catch(()=>{})}}}catch(v){await k(),d||ir(sr(v))}finally{await k(),s&&(s.fn=v=>console.log(v)),r.setActiveCompositor?.(null),r.setBackgroundHandler?.(null),r.setInFlight(!1),r.rearmStatus?.()}}function iD(e,t,n=console.log){if(!e)return;let r=[];e.durationMs&&r.push(se(e.durationMs)),e.totalCostUsd!==void 0&&r.push(Ne(e.totalCostUsd));let o=Number(e.usage?.input_tokens??0),s=Number(e.usage?.output_tokens??0);o+s>0&&r.push(Q(o+s)+" tok"),r.length>0&&n(m.dim(" \u25E6 "+r.join(" \xB7 ")));let i=Hc(t),a=Qe(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 ~${Q(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 ${Q(a)}`))}n("")}function tk(e={}){let t=e.load??Ki,n=e.onResize??(i=>ot.subscribe(i)),r="",o,s=n(()=>{r=""});return{renderIfChanged(i){let a=i??"unbound",l=t(a),c=ay(l);return a===o&&c===r?[]:(o=a,r=c,c===""?[]:Gi(l))},invalidate(){r=""},dispose(){try{s()}catch{}}}}var Ju={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 nk(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=Ju[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,te()-2);if(K(a)<=l)return a;let c=r+n.map(u=>Ju[u].color(Ju[u].glyph)).join(m.dim(" "))+i;return ce(c,l)}}}var Vu=["\u25D0","\u25D1","\u25D2","\u25D3"],Ja=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=ot.subscribe(()=>this.repaint()),this.spinnerInterval=setInterval(()=>{this.spinnerIndex=(this.spinnerIndex+1)%Vu.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(Vu[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(`${Q(t.stats.tokens)} tok`);let l=Date.now()-t.startedAt;return a.push(se(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(Vu[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(se(a))),ce(" "+i.join(" "),n)}};function Va(e,t){let n=m.brand("afk")+m.dim(` (${e})`),r=t?m.warning(" \u25CF plan"):"";return n+r+m.dim(" \u203A ")}async function rk(e,t,n,r){let o=null,s=[];e.session.current.waitForInitialization().then(async p=>{We()&&(o=ji(p)),await ka(e.session.current),We()&&(s=Vb())}).catch(()=>{});let i=await qw(),a=new za({rl:e.rl,history:i,statusLine:e.statusLine}),l,c,u,d;try{await a.armCompositor({promptFn:()=>Va(e.stats.model,e.stats.planMode),onCancel:r,onShiftTab:()=>{let h=e.slashCtx;h.stats.planMode&&h.stats.pendingPlanExit?(h.stats.pendingPlanExit=!1,gt(h,!1,{closureSummarySkipped:!0}).catch(()=>{})):gt(h).catch(()=>{}),e.statusLine.rearm()},scrollRegion:e.statusLine}),e.replRenderer.setCompositor(a.getCompositor()),e.slashCtx.getCompositor=()=>a.getCompositor(),c=tk();let p=nk();e.clearVerdictLedger=()=>p.reset(),u=new qi,by(u),Ey(u),Ry(u),xy(e.backgroundRegistry),d=new Ja(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",_=[];if(v.resultText){let A=v.resultText.trim().split(`
|
|
2044
2044
|
`)[0]?.slice(0,80)??"";A&&_.push(A)}v.error&&_.push(v.error.message);let C=[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 ");C&&_.push(C),e.replRenderer.writeLine(Vt({kind:v.status==="succeeded"?"checkpoint":"diagnosis",title:`${R} ${v.id} ${v.label}`,body:_})),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,S;if(l!==void 0){let v=l;l=void 0;let R=Va(e.stats.model,e.stats.planMode),_=Bn({buffer:v.text,promptText:R,isTTY:!!process.stdout.isTTY,attachmentSummary:Dr([...v.attachments])});e.replRenderer.writeLine(_),y=v.text.trim(),S=v.attachments}else{let v=await a.readLine({promptFn:()=>Va(e.stats.model,e.stats.planMode),onSigint:r,onShiftTab:()=>{let R=e.slashCtx;R.stats.planMode&&R.stats.pendingPlanExit?(R.stats.pendingPlanExit=!1,gt(R,!1,{closureSummarySkipped:!0}).catch(()=>{})):gt(R).catch(()=>{}),e.statusLine.rearm()}});y=v.text.trim(),S=v.attachments}if(!y&&S.length===0)continue;let T=!1;if(y.startsWith("/")){let v=await jh(y,e.slashCtx,S);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:S??[]},e.statusLine.rearm();continue}e.statusLine.rearm();continue}T=!0}i.push(y);let x=y;if(T){let v=Wc(y);if(v){let R=v.name.replace(/^\//,"").split(":").pop()??"";if(R&&Eu(R)){let _={skillName:R,rawArgs:v.args,source:"plugin",capabilities:{compose:!0,subagents:!0}},C=e.session.current.sessionId,A=Zo(C),O=Date.now();W(`[afk trace] preflight.start commandName=${R}`);let M=!1,$=await Qo(_,{cwd:e.stats.cwd??process.cwd(),artifactDir:A},N=>{We()&&e.replRenderer.writeLine(m.warning(`\u26A0 preflight(${R}) failed: `)+(N instanceof Error?N.message:String(N)))});M=$!==null,W(`[afk trace] preflight.end commandName=${R} durationMs=${Date.now()-O} success=${M}`),x=Ru($?.manifestBlock,y)}}}let k;if(e.firstTurnHook&&e.stats.totalTurns===0){let v=e.firstTurnHook;e.firstTurnHook=void 0,k=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 ek({text:x,attachments:S},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 Qh(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(Va(e.stats.model,e.stats.planMode))),k!==void 0&&await k}}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 aD}from"node:child_process";import{dirname as lD,isAbsolute as cD,resolve as uD}from"node:path";import{promisify as dD}from"node:util";var ok=dD(aD),pD=3e3,mD=new Set(["empty","orphaned-dir","orphaned-registration","dead-owner"]);async function fD(){let t=(await ok("git",["rev-parse","--git-common-dir"])).stdout.trim();if(!t)throw new Error("Not in a git repository.");let n=cD(t)?t:uD(process.cwd(),t);return lD(n)}async function sk(e){if(e?.disabled)return{ran:!1,removedCount:0,skippedReason:"disabled"};let t;try{t=await fD()}catch{return{ran:!1,removedCount:0,skippedReason:"not-in-repo"}}let n,r=new Promise(o=>{n=setTimeout(()=>o("timeout"),pD)});try{let o=_t({execFile:ok,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=>mD.has(c.verdict)&&i.removed.includes(c.path)).length}}catch{return{ran:!1,removedCount:0,skippedReason:"error"}}finally{n&&clearTimeout(n)}}import{promises as gD}from"node:fs";import{dirname as hD,join as yD}from"node:path";import{randomBytes as bD}from"node:crypto";var wD=["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(`
|
|
2045
|
-
`),ik=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,Yu=30,kD=1024,SD=8e3,vD="haiku";async function TD(e,t){let n=e.trim();if(n.length===0||n.startsWith("/"))return null;let r=RD(n,kD),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??SD),i=t.signal?_D([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await Fa({token:t.token,model:t.model??vD,system:wD,user:r,maxTokens:32,signal:i})}catch{return null}finally{clearTimeout(s)}let l=ED(a);if(l===null)return null;let c=hD(t.worktreePath);return await xD(l,c)}function ED(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(ik.test(t)&&t.length<=Yu)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>Yu)break;o=i}return ik.test(o)?o:null}async function xD(e,t){if(!await AD(yD(t,e)))return e;let n=bD(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,Yu-5)}-${n}`}async function AD(e){try{return await gD.access(e),!0}catch{return!1}}function RD(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 _D(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 ak(e){let t=await TD(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}:{}});if(t===null)return{status:"skipped",reason:"slug generation returned null"};let r=await(e.renameFn??Df)(e.handle,t,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return r.ok?(e.session&&e.session.setCwd(r.newPath),{status:"renamed",oldPath:r.oldPath,newPath:r.newPath,oldBranch:r.oldBranch,newBranch:r.newBranch}):(r.partial==="branch"&&e.session&&e.session.setCwd(e.handle.path),{status:"failed",reason:r.reason,...r.partial!==void 0?{partial:r.partial}:{}})}F();import{spawn as lk}from"child_process";import{existsSync as OD,mkdirSync as $D,readFileSync as ck,unlinkSync as DD,writeFileSync as LD}from"fs";import{get as FD}from"https";import{join as uk}from"path";import{readFileSync as CD}from"fs";import{dirname as ID,join as PD}from"path";import{fileURLToPath as MD}from"url";function Bt(){try{return"3.17.
|
|
2045
|
+
`),ik=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,Yu=30,kD=1024,SD=8e3,vD="haiku";async function TD(e,t){let n=e.trim();if(n.length===0||n.startsWith("/"))return null;let r=RD(n,kD),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??SD),i=t.signal?_D([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await Fa({token:t.token,model:t.model??vD,system:wD,user:r,maxTokens:32,signal:i})}catch{return null}finally{clearTimeout(s)}let l=ED(a);if(l===null)return null;let c=hD(t.worktreePath);return await xD(l,c)}function ED(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(ik.test(t)&&t.length<=Yu)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>Yu)break;o=i}return ik.test(o)?o:null}async function xD(e,t){if(!await AD(yD(t,e)))return e;let n=bD(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,Yu-5)}-${n}`}async function AD(e){try{return await gD.access(e),!0}catch{return!1}}function RD(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 _D(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 ak(e){let t=await TD(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}:{}});if(t===null)return{status:"skipped",reason:"slug generation returned null"};let r=await(e.renameFn??Df)(e.handle,t,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return r.ok?(e.session&&e.session.setCwd(r.newPath),{status:"renamed",oldPath:r.oldPath,newPath:r.newPath,oldBranch:r.oldBranch,newBranch:r.newBranch}):(r.partial==="branch"&&e.session&&e.session.setCwd(e.handle.path),{status:"failed",reason:r.reason,...r.partial!==void 0?{partial:r.partial}:{}})}F();import{spawn as lk}from"child_process";import{existsSync as OD,mkdirSync as $D,readFileSync as ck,unlinkSync as DD,writeFileSync as LD}from"fs";import{get as FD}from"https";import{join as uk}from"path";import{readFileSync as CD}from"fs";import{dirname as ID,join as PD}from"path";import{fileURLToPath as MD}from"url";function Bt(){try{return"3.17.2"}catch{}try{let e=ID(MD(import.meta.url));for(let t of["../../package.json","../package.json"])try{let n=JSON.parse(CD(PD(e,t),"utf-8"));if(typeof n.version=="string")return n.version}catch{}}catch{}return"0.0.0-unknown"}H();var ND=64*1024,UD=1440*60*1e3,jD="update-check.json",BD="pending-update.json";function dk(){return uk(vs(),jD)}function Xu(){return uk(vs(),BD)}function pk(){let e=vs();OD(e)||$D(e,{recursive:!0})}function WD(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 HD(){try{let e=ck(dk(),"utf-8"),t=JSON.parse(e);if(typeof t.latestVersion=="string"&&typeof t.checkedAt=="number")return t}catch{}return null}function KD(){try{pk();let e=`
|
|
2046
2046
|
const https = require('https');
|
|
2047
2047
|
const fs = require('fs');
|
|
2048
2048
|
const url = 'https://registry.npmjs.org/agent-afk/latest';
|