@kodax-ai/kodax 0.7.49 → 0.7.50
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/CHANGELOG.md +35 -3
- package/README.md +11 -8
- package/README_CN.md +10 -8
- package/dist/chunks/argument-completer-3WX5B42G.js +2 -0
- package/dist/chunks/chunk-5UJQ2GKJ.js +574 -0
- package/dist/chunks/{chunk-TYZAH3YP.js → chunk-HR64F32V.js} +1 -1
- package/dist/chunks/{chunk-67SWUEEN.js → chunk-MFOMFMSK.js} +318 -297
- package/dist/chunks/{chunk-YW4RQV7U.js → chunk-SK4HOYT2.js} +1 -1
- package/dist/chunks/chunk-UB5IAZHF.js +476 -0
- package/dist/chunks/chunk-XZY4CIDV.js +31 -0
- package/dist/chunks/chunk-YJLRBIEW.js +301 -0
- package/dist/chunks/{compaction-config-BQBYOWX2.js → compaction-config-DDJSQ4OT.js} +1 -1
- package/dist/chunks/{construction-bootstrap-5TFGMSWQ.js → construction-bootstrap-4QNM2BVM.js} +1 -1
- package/dist/chunks/{dist-BL7IBQHD.js → dist-OJSNNI7P.js} +1 -1
- package/dist/chunks/dist-T256OSDI.js +2 -0
- package/dist/chunks/{utils-XWDT3W5X.js → utils-JHIEOX6Z.js} +1 -1
- package/dist/index.d.ts +6 -6
- package/dist/index.js +2 -2
- package/dist/kodax_cli.js +967 -886
- package/dist/sdk-agent.d.ts +14 -6
- package/dist/sdk-agent.js +1 -1
- package/dist/sdk-coding.d.ts +138 -28
- package/dist/sdk-coding.js +1 -1
- package/dist/sdk-llm.d.ts +1 -1
- package/dist/sdk-llm.js +1 -1
- package/dist/sdk-mcp.js +1 -1
- package/dist/sdk-repl.d.ts +29 -7
- package/dist/sdk-repl.js +2 -2
- package/dist/sdk-session.d.ts +27 -3
- package/dist/sdk-session.js +1 -1
- package/dist/sdk-skills.js +1 -1
- package/dist/types-chunks/{bash-prefix-extractor.d-CI_xcPhn.d.ts → bash-prefix-extractor.d-B0CIb0N3.d.ts} +72 -19
- package/dist/types-chunks/{capsule.d-DaPuhyyK.d.ts → capsule.d-CwBEm6M-.d.ts} +4 -1
- package/dist/types-chunks/{types.d-BR9oNWup.d.ts → process.d-BbiXD24v.d.ts} +142 -3
- package/dist/types-chunks/{resolver.d-B_wm409c.d.ts → resolver.d-CQfaJbht.d.ts} +22 -4
- package/dist/types-chunks/{utils.d-BJ_-y8gC.d.ts → utils.d-D_-jrRku.d.ts} +3 -1
- package/package.json +1 -1
- package/dist/chunks/argument-completer-GDG5OHN7.js +0 -2
- package/dist/chunks/chunk-C5PKZX5Z.js +0 -291
- package/dist/chunks/chunk-ISGHUKRY.js +0 -428
- package/dist/chunks/chunk-JTHMWRXM.js +0 -566
- package/dist/chunks/chunk-YACQ4OST.js +0 -31
- package/dist/chunks/dist-D7HOETCE.js +0 -2
|
@@ -0,0 +1,476 @@
|
|
|
1
|
+
// @kodax-ai/kodax — bundled distribution. See docs/ADR.md ADR-022 + ADR-024.
|
|
2
|
+
import{A as sr,B as ir,C as ar,j as er,l as Re,m as an,n as or,o as nr,p as tr,q as ln,s as cn,t as dn,u as rr,w as po,y as de}from"./chunk-HR64F32V.js";import{a as lr}from"./chunk-SK4HOYT2.js";import{Ab as V,Ae as Vt,Be as sn,Ce as Jt,De as je,Ec as qt,Fc as Kt,Fe as Ae,He as Yt,Ia as Ut,Ka as Ft,Kb as Ht,La as jt,Mb as Bt,Oa as rn,Pe as go,Qe as Zt,R as Ot,U as Ue,V as Dt,We as Qt,Xe as He,ne as zt,qe as ce,t as Nt,ue as xe,we as Fe,xe as mo,ye as Gt,ze as Xt}from"./chunk-MFOMFMSK.js";import{j as en,sa as Rt,ta as $e,ua as Se}from"./chunk-XZY4CIDV.js";import{Zc as be,_c as _t,cc as Tt,dc as Pt,ec as Mt,k as on,nd as Lt,rc as nn,sb as It,sc as tn,tb as Ct,va as uo,wa as _,xb as Et,xc as Wt,xd as fo}from"./chunk-5UJQ2GKJ.js";import{a,b as Qo,c as ri}from"./chunk-V4WSBIXB.js";var wr=Qo((Yc,pr)=>{"use strict";pr.exports=a(function(o){return o.map(function(n){return n===""?"''":n&&typeof n=="object"?n.op.replace(/(.)/g,"\\$1"):/["\s\\]/.test(n)&&!/'/.test(n)?"'"+n.replace(/(['])/g,"\\$1")+"'":/["'\s]/.test(n)?'"'+n.replace(/(["\\$`!])/g,"\\$1")+'"':String(n).replace(/([A-Za-z]:)?([#!"$&'()*,:;<=>?@[\\\]^`{|}])/g,"$1\\$2")}).join(" ")},"quote")});var br=Qo((Qc,Sr)=>{"use strict";var $r="(?:"+["\\|\\|","\\&\\&",";;","\\|\\&","\\<\\(","\\<\\<\\<",">>",">\\&","<\\&","[&;()|<>]"].join("|")+")",hr=new RegExp("^"+$r+"$"),yr="|&;()<> \\t",ai='"((\\\\"|[^"])*?)"',li="'((\\\\'|[^'])*?)'",ci=/^#$/,kr="'",vr='"',un="$",ue="",di=4294967296;for(fn=0;fn<4;fn++)ue+=(di*Math.random()).toString(16);var fn,ui=new RegExp("^"+ue);function fi(e,o){for(var n=o.lastIndex,t=[],r;r=o.exec(e);)t.push(r),o.lastIndex===r.index&&(o.lastIndex+=1);return o.lastIndex=n,t}a(fi,"matchAll");function mi(e,o,n){var t=typeof e=="function"?e(n):e[n];return typeof t>"u"&&n!=""?t="":typeof t>"u"&&(t="$"),typeof t=="object"?o+ue+JSON.stringify(t)+ue:o+t}a(mi,"getVar");function gi(e,o,n){n||(n={});var t=n.escape||"\\",r="(\\"+t+`['"`+yr+`]|[^\\s'"`+yr+"])+",i=new RegExp(["("+$r+")","("+r+"|"+ai+"|"+li+")+"].join("|"),"g"),l=fi(e,i);if(l.length===0)return[];o||(o={});var c=!1;return l.map(function(d){var u=d[0];if(!u||c)return;if(hr.test(u))return{op:u};var m=!1,f=!1,h="",k=!1,y;function v(){y+=1;var x,D,F=u.charAt(y);if(F==="{"){if(y+=1,u.charAt(y)==="}")throw new Error("Bad substitution: "+u.slice(y-2,y+1));if(x=u.indexOf("}",y),x<0)throw new Error("Bad substitution: "+u.slice(y));D=u.slice(y,x),y=x}else if(/[*@#?$!_-]/.test(F))D=F,y+=1;else{var B=u.slice(y);x=B.match(/[^\w\d_]/),x?(D=B.slice(0,x.index),y+=x.index-1):(D=B,y=u.length)}return mi(o,"",D)}for(a(v,"parseEnvVar"),y=0;y<u.length;y++){var g=u.charAt(y);if(k=k||!m&&(g==="*"||g==="?"),f)h+=g,f=!1;else if(m)g===m?m=!1:m==kr?h+=g:g===t?(y+=1,g=u.charAt(y),g===vr||g===t||g===un?h+=g:h+=t+g):g===un?h+=v():h+=g;else if(g===vr||g===kr)m=g;else{if(hr.test(g))return{op:u};if(ci.test(g)){c=!0;var I={comment:e.slice(d.index+y+1)};return h.length?[h,I]:[I]}else g===t?f=!0:g===un?h+=v():h+=g}}return k?{op:"glob",pattern:h}:h}).reduce(function(d,u){return typeof u>"u"?d:d.concat(u)},[])}a(gi,"parseInternal");Sr.exports=a(function(o,n,t){var r=gi(o,n,t);return typeof n!="function"?r:r.reduce(function(i,l){if(typeof l=="object")return i.concat(l);var c=l.split(RegExp("("+ue+".*?"+ue+")","g"));return c.length===1?i.concat(c[0]):i.concat(c.filter(Boolean).map(function(d){return ui.test(d)?JSON.parse(d.split(ue)[1]):d}))},[])},"parse")});var xr=Qo(mn=>{"use strict";mn.quote=wr();mn.parse=br()});import*as zo from"fs";import*as ao from"path";import s from"chalk";var wo=["plan","accept-edits","auto","auto-in-project"];function Gc(e){return e==="auto"||e==="auto-in-project"}a(Gc,"isAutoMode");function si(e){switch(e){case"plan":return"Plan";case"accept-edits":return"Edits";case"auto":case"auto-in-project":return"Auto"}}a(si,"permissionModeDisplayName");var ii='[deprecated] permissionMode "auto-in-project" is now an alias for "auto" (FEATURE_092, v0.7.33). The alias will be removed in v0.7.38 \u2014 please update ~/.kodax/config.json to use "auto".';function Xc(e=console.warn){let o=!1;return()=>{o||(o=!0,e(ii))}}a(Xc,"createAutoInProjectDeprecationEmitter");var cr=Ht(),Be=new Set(cr.filter(e=>e.sideEffect==="mutates-fs"&&e.requiredParams.includes("path")).map(e=>e.name)),dr=new Set(cr.filter(e=>e.sideEffect!=="readonly").map(e=>e.name)),ur=new Set(["npm install","npm i","npm uninstall","npm remove","npm update","npm ci","yarn add","yarn remove","yarn upgrade","pnpm add","pnpm remove","pnpm update","git clean","git reset","git checkout","git switch","git merge","git rebase","git cherry-pick","git revert","git commit","git push","git pull","rm","mv","cp","mkdir","rmdir","touch","chmod","chown","del","erase","rd","copy","move","ren","curl","wget","dd","tar","kill","pkill","killall"]),fr=new Set(["ls","cat","pwd","echo","whoami","date","which","whereis","tree","dir","type","get-childitem","get-content","select-string","get-location","where","grep","find","awk","sed","head","tail","less","more","wc","findstr","fc","git status","git diff","git log","git show","git branch","git remote","git ls-files","git rev-parse","git grep","git tag","git stash list","git describe","git config --get","node","npm","yarn","pnpm","tsc","python","pip","go","cargo","rustc"]);function mr(e){switch(e){case"plan":return new Set(["bash","write","edit","undo"]);case"accept-edits":return new Set(["bash"]);case"auto":case"auto-in-project":return new Set}}a(mr,"computeConfirmTools");function gr(e){return e!==void 0&&wo.includes(e)}a(gr,"isPermissionMode");function qe(e,o){return gr(e)?e:o}a(qe,"normalizePermissionMode");import So from"fs";import Dr from"path";import ho from"fs";import M from"path";import ze from"os";var Ir=ri(xr(),1);var Ar=new Set(["/dev/null","nul","NUL"]);function gn(e){return Ar.has(e)||Ar.has(e.toLowerCase())}a(gn,"isNullDevice");function Ke(e){let o=e.trim();if(!o)return{statements:[],unparseable:!1};if(o.includes("`"))return{statements:[],unparseable:!0};let n;try{n=(0,Ir.parse)(o)}catch{return{statements:[],unparseable:!0}}let t=[],r=[],i=[],l=[],c=null,d=!1,u=a(()=>{(i.length>0||l.length>0)&&(r.push({argv:i,redirections:l}),i=[],l=[])},"flushStage"),m=a(f=>{u(),r.length>0&&(t.push({precedingOp:c,stages:r}),r=[]),c=f},"flushStatement");for(let f=0;f<n.length;f+=1){let h=n[f];if(typeof h=="string"){i.push(h);continue}if("op"in h){let k=h.op;if(k==="&&"||k==="||"||k===";"){m(k);continue}if(k==="|"){u();continue}if(k==="&"){let y=n[f+1];if(y!==void 0&&typeof y!="string"&&"op"in y&&(y.op===">"||y.op===">>")){let v=n[f+2];if(typeof v!="string"){d=!0,f+=1;continue}l.push(Rr(`&${y.op}`,v)),f+=2;continue}d=!0;continue}if(wi(k)){let y=null,v=i[i.length-1];v!==void 0&&/^[0-9]+$/.test(v)&&(y=v,i.pop());let g=n[f+1];if(typeof g!="string"){d=!0;continue}l.push(Rr(y?`${y}${k}`:k,g)),f+=1;continue}if(k==="glob"){let y=h.pattern;typeof y=="string"?i.push(y):d=!0;continue}d=!0;continue}if("comment"in h)break;d=!0}return m(null),{statements:t,unparseable:d}}a(Ke,"parseBashCommand");var pi=new Set([">",">>","<","<<","<<<","&>","&>>"]),Cr=/^([0-9]+|&)(>>?|<<?)$/;function wi(e){return pi.has(e)||Cr.test(e)}a(wi,"isRedirectionOp");function Rr(e,o){let n=null,t=e,r=Cr.exec(e);return r&&(n=r[1],t=r[2]),{op:e,fd:n,append:t===">>"||e==="&>>",input:t==="<"||t==="<<"||e==="<<<",target:o}}a(Rr,"parseRedirection");var hi=M.join(".agent","plan_mode_doc.md"),yo=new Map,ko=null;function yi(e){if(!e||!e.trim())return!1;let o=e.trim().replace(/\s+/g," ").toLowerCase();for(let n of fr)if(o===n||o.startsWith(n+" ")){if(n==="sed"&&o.split(/\s+/).some(i=>i.startsWith("-i")||i==="--in-place"))return!1;if(n==="awk"){let r=o.split(/\s+/);if(r.includes("-f")||r.includes("--file"))return!1}if(["node","npm","yarn","pnpm","tsc","python","pip","go","cargo","rustc","ruby","perl"].includes(n)){let r=o.split(/\s+/).slice(1);if(r.length>0&&!r.every(i=>/^(-v|--version|-h|--help)$/.test(i)))return!1}return!0}return!1}a(yi,"isSingleBashReadCommand");var ki=/^[a-zA-Z0-9]+$/;function vi(e){let o=e.trim();if(!o.endsWith("--help")||o.includes('"')||o.includes("'"))return!1;let n=!1;for(let t of o.split(/\s+/))if(t.startsWith("-"))if(t==="--help")n=!0;else return!1;else if(!ki.test(t))return!1;return n}a(vi,"isHelpCommand");function wn(e){if(!e||!e.trim())return!1;if(vi(e))return!0;let o=e.trim().replace(/\\\r?\n/g," "),n=Ke(o);if(n.unparseable||n.statements.length===0)return!1;let t=n.statements.length>1||(n.statements[0]?.stages.length??0)>1;for(let r of n.statements){if(r.precedingOp!==null&&r.precedingOp!=="&&")return!1;for(let i of r.stages){for(let c of i.redirections)if(c.input||!gn(c.target))return!1;let l=i.argv.join(" ");if(l&&!(t&&i.argv[0]?.toLowerCase()==="cd"&&i.argv.length>=2)&&!yi(l))return!1}}return!0}a(wn,"isBashReadCommand");function $i(e){let o=e.trim();return o?wn(o)?null:"[Blocked] Direct !command execution only supports safe read-only commands. Use the bash tool for commands that write files, invoke shells, or require confirmation.":"[Shell: No command provided]"}a($i,"getDirectShellBypassBlockReason");var Tr=new Set(["remove-item","set-content","add-content","out-file","new-item","copy-item","move-item","rename-item","ni"]);function hn(e){if(!e||!e.trim())return!1;let o=Ke(e);if(o.unparseable)return!1;for(let n of o.statements)for(let t of n.stages){let r=t.argv.map(i=>i.toLowerCase());if(r.length>0){let i=r[0],l=r.length>=2?`${r[0]} ${r[1]}`:null;for(let c of ur)if(c===i||l!==null&&c===l)return!0}for(let i of r)if(Tr.has(i))return!0;for(let i of t.redirections)if(!i.input&&!gn(i.target))return!0}return!1}a(hn,"isBashWriteCommand");function yn(e){let o=e.match(/^([a-zA-Z_][a-zA-Z0-9_]*)\((.+)\)$/);return o?{tool:o[1].toLowerCase(),pattern:o[2]}:{tool:e.toLowerCase(),pattern:null}}a(yn,"parseAllowedToolPattern");function Si(e,o){if(o==="*")return!1;if(o.endsWith(":*")){let n=o.slice(0,-2);return e.startsWith(n)}return e===o}a(Si,"matchesBashPatternLegacy");function bi(e,o){if(o==="*")return!1;if(o.endsWith(":*")){let n=o.slice(0,-2);return e===n}return e===o}a(bi,"matchesBashPatternByExtractedPrefix");async function kn(e,o,n,t,r){if(e.toLowerCase()!=="bash")return!1;let i=o.command??"",l=[];for(let c of n){let d=yn(c);if(d.tool==="bash"){if(d.pattern===null)return!0;l.push({pattern:d.pattern})}}if(l.length===0)return!1;if(t){let c;try{c=await t.extract(i,r)}catch{return!1}if(c.kind!=="prefix")return!1;for(let{pattern:d}of l)if(d&&bi(c.value,d))return!0;return!1}for(let{pattern:c}of l)if(c&&Si(i,c))return!0;return!1}a(kn,"isToolCallAllowed");function vn(e,o,n){if(e.toLowerCase()!=="bash")return"";let t=o.command??"",r=t.split(" ");return r.length>1?`Bash(${r.slice(0,2).join(" ")}:*)`:`Bash(${t})`}a(vn,"generateSavePattern");function Ge(e,o){try{let n=M.resolve(e),t=M.resolve(o),r=uo(),i=M.join(t,".kodax");return Ie(n,i)||Ie(n,r)?!0:!(Ie(n,t)||Wr().some(c=>Ie(n,c)))}catch{return!1}}a(Ge,"isAlwaysConfirmPath");function Er(e){return!e||e.startsWith("-")?!1:/^\.\.?[/\\]/.test(e)||e.startsWith("~/")||e.startsWith("~\\")||/^[a-zA-Z]:[/\\]/.test(e)?!0:e.startsWith("/")&&e.length>1?!(process.platform==="win32"&&xi.test(e)):!!(e.startsWith(".")&&/[/\\]/.test(e))}a(Er,"looksLikePath");var xi=/^\/[A-Za-z][A-Za-z0-9]*(?::[A-Za-z0-9]+)?$/;function Ai(e){let o=[],n=/["']([^"']+)["']/g,t;for(;(t=n.exec(e))!==null;)o.push(t[1]);let r=/(?:^|\s)(\.\.?\/[^\s]+|\.\.?\\[^\s]+|[a-zA-Z]:\\[^\s]+|~\/[^\s]+|\.[^\s]*[/\\][^\s]*)/g;for(;(t=r.exec(e))!==null;)o.push(t[1]);return o}a(Ai,"legacyRegexPathScan");function $o(e){let o=new Set,n=Ke(e);if(!n.unparseable)for(let t of n.statements)for(let r of t.stages){for(let i of r.argv)Er(i)&&o.add(i);for(let i of r.redirections)Er(i.target)&&o.add(i.target)}for(let t of Ai(e))o.add(t);return Array.from(o)}a($o,"extractPathsFromCommand");function Ri(e,o){let n=$o(e);for(let t of n)if(Ge(t,o))return!0;return!1}a(Ri,"isCommandOnProtectedPath");function vo(e){let o=M.normalize(e);return process.platform==="win32"?o.toLowerCase():o}a(vo,"normalizePathForComparison");function Ii(e,o){return vo(e)===vo(o)}a(Ii,"pathsEqual");function Ie(e,o){let n=vo(e),t=vo(o);return n===t||n.startsWith(t+M.sep)}a(Ie,"isPathInsideDirectory");function $n(e,o){try{let n=M.resolve(o),t=M.resolve(n,Mr(Pr(e)));return Ie(t,n)}catch{return!1}}a($n,"isPathInsideProject");function Ci(e){let o=e.match(/[A-Za-z]:[\\/][^\s;|&<>(){}'"]+|\/[^\s;|&<>(){}'"]+/g);return o?o.filter(n=>!/^(?:\/dev\/|\/proc\/)/i.test(n)):[]}a(Ci,"collectAbsolutePathCandidates");function Sn(e){let o=M.resolve(e),n=yo.get(o);if(n)return n;if(ho.existsSync(o)){let c=ho.realpathSync.native(o);return yo.set(o,c),c}let t=[],r=o;for(;!ho.existsSync(r);){let c=M.dirname(r);if(c===r)return yo.set(o,o),o;t.unshift(M.basename(r)),r=c}let i=ho.realpathSync.native(r),l=M.join(i,...t);return yo.set(o,l),l}a(Sn,"resolveExistingPathPrefix");function Pr(e){return e==="~"?ze.homedir():e.startsWith(`~${M.sep}`)||e.startsWith("~/")||e.startsWith("~\\")?M.join(ze.homedir(),e.slice(2)):e}a(Pr,"expandHomeDirectory");function Mr(e){let o=ze.tmpdir(),n=[[/^%temp%/i,o],[/^%tmp%/i,o],[/^\$env:temp\b/i,o],[/^\$env:tmp\b/i,o],[/^\$tmpdir\b/i,o],[/^\$temp\b/i,o],[/^\$tmp\b/i,o]];for(let[t,r]of n)if(t.test(e))return e.replace(t,r);return e}a(Mr,"expandSystemTempAlias");function Ei(e,o){let n=M.resolve(o??process.cwd()),t=Mr(Pr(e)),r=M.isAbsolute(t)?M.resolve(t):M.resolve(n,t);return Sn(r)}a(Ei,"resolvePermissionPath");function Wr(){if(ko)return ko;let e=new Set,o=[ze.tmpdir(),process.env.TEMP,process.env.TMP,process.env.TMPDIR].filter(n=>typeof n=="string"&&n.trim().length>0);for(let n of o)try{e.add(Sn(n))}catch{}return ko=Array.from(e),ko}a(Wr,"getSystemTempDirectories");function bn(e){let o=Sn(e??process.cwd());return{projectPlanDoc:M.join(o,hi),systemTempDirs:Wr()}}a(bn,"getPlanModeAllowedWritablePaths");function pn(e,o){let n=Ei(e,o),{projectPlanDoc:t,systemTempDirs:r}=bn(o);return Ii(n,t)?!0:r.some(i=>Ie(n,i))}a(pn,"isPlanModeAllowedPath");function Ti(e){let{projectPlanDoc:o,systemTempDirs:n}=bn(e),t=n[0]??ze.tmpdir();return`${o} or the system temp directory (${t})`}a(Ti,"formatPlanModeAllowedLocations");var Pi=new Set(["-a","--append","-i","--ignore-interrupts"]);function Mi(e){let o=[];for(let n=1;n<e.argv.length;n+=1){let t=e.argv[n];Pi.has(t)||t.startsWith("-")||o.push(t)}return o}a(Mi,"collectTeeTargets");function Wi(e){let o=[],n=1,t=!1;for(;n<e.argv.length;){let r=e.argv[n],i=r.toLowerCase();if(i==="-path"||i==="-literalpath"||i==="-destination"){let l=e.argv[n+1];if(l!==void 0&&!l.startsWith("-")){o.push(l),n+=2;continue}}!r.startsWith("-")&&!t&&(o.push(r),t=!0),n+=1}return o}a(Wi,"collectPowerShellWriteTargets");function Ce(e){let o=new Set,n=a(r=>{let i=r?.trim();i&&o.add(i)},"pushTarget");for(let r of $o(e))n(r);let t=Ke(e);if(t.unparseable)return Array.from(o);for(let r of t.statements)for(let i of r.stages){for(let c of i.redirections)c.input||n(c.target);let l=i.argv[0]?.toLowerCase();if(l){if(l==="tee")for(let c of Mi(i))n(c);else if(Tr.has(l))for(let c of Wi(i))n(c)}}return Array.from(o)}a(Ce,"collectBashWriteTargets");function _r(e,o){if(!hn(e))return{dangerous:!1};let n=new Set([...Ce(e),...Ci(e)]);for(let t of n)if(!$n(t,o))return{dangerous:!0,reason:`Command may modify file outside project: ${t}`};return{dangerous:!1}}a(_r,"getBashOutsideProjectWriteRisk");function Lr(e,o,n){let t=Ti(n);if(Bt(e))return null;if(Be.has(e)){let r=typeof o.path=="string"?o.path:"";return r?pn(r,n)?null:`[Blocked] Plan mode only allows file modifications in ${t}. Requested path: ${r}`:`[Blocked] Tool '${e}' is not allowed in plan mode unless it targets ${t}.`}if(e==="bash"){let r=o.command??"";if(!hn(r))return null;let i=Ce(r);if(i.length===0)return`[Blocked] Plan mode only allows bash write operations when every target is either ${t}. Could not determine a safe target from: ${r.slice(0,80)}${r.length>80?"...":""}`;let l=i.find(c=>!pn(c,n));return l?`[Blocked] Plan mode only allows bash write operations in ${t}. Blocked target: ${l}`:null}return`[Blocked] Tool '${e}' has side effects and is not permitted in plan mode. Switch to accept-edits or auto mode to use it, or work within ${t}.`}a(Lr,"getPlanModeBlockReason");import oe from"node:path";import _i from"node:os";function Ee(e,o){try{let n=oe.resolve(e),t=oe.resolve(o);return n===t?!0:n.startsWith(t+oe.sep)}catch{return!1}}a(Ee,"isPathUnder");function Li(){try{return uo()}catch{return}}a(Li,"safeGetAgentConfigHome");function Nr(e,o){let n=Li();if(n&&Ee(e,n))return"user-kodax";let t=oe.join(oe.resolve(o),".kodax");if(Ee(e,t))return"project-kodax"}a(Nr,"resolveProtectedZone");function Ni(){let e=new Set;try{e.add(_i.tmpdir())}catch{}for(let o of["TEMP","TMP","TMPDIR"]){let n=process.env[o];n&&n.length>0&&e.add(n)}return Array.from(e)}a(Ni,"getSystemTempDirs");var Oi=new Set(["bash"]),Di={toolNames:Oi,collect(e,o){let n=typeof e.input.command=="string"?e.input.command:"";if(!n||!o)return[];let t=[],r=new Set,i=new Set,l=Ni(),c=oe.resolve(o);for(let d of $o(n)){let u;try{u=oe.resolve(o,d)}catch{continue}let m=Nr(u,o);if(m){r.has(u)||(r.add(u),t.push({kind:"protected_path",path:d,zone:m}));continue}if(Ge(d,o)){let f=l.some(k=>Ee(u,k)),h=Ee(u,c);!f&&!h&&!i.has(u)&&(i.add(u),t.push({kind:"outside_project",path:d}))}}for(let d of Ce(n)){let u;try{u=oe.resolve(o,d)}catch{continue}Nr(u,o)||Ee(u,c)||l.some(h=>Ee(u,h))||t.push({kind:"shell_redirect_outside",target:d})}return t}};var bo=_("config.json");function Ur(){return Dr.join(process.cwd(),".kodax","config.local.json")}a(Ur,"getProjectConfigFile");function Dd(e=process.env){let n=Xe(bo).autoMode??{},t=e.KODAX_AUTO_MODE_ENGINE?.trim(),r=t==="llm"||t==="rules"?t:void 0,i=n.engine==="llm"||n.engine==="rules"?n.engine:void 0,l=r??i??"llm",c=Or(n.classifierModel),d=Or(e.KODAX_AUTO_MODE_CLASSIFIER_MODEL),u=e.KODAX_AUTO_MODE_TIMEOUT_MS?.trim(),m=u!==void 0?Number(u):NaN,f=Number.isFinite(m)&&m>0?Math.floor(m):void 0,h=typeof n.timeoutMs=="number"&&n.timeoutMs>0?Math.floor(n.timeoutMs):void 0;return{engine:l,classifierModel:c,classifierModelEnv:d,timeoutMs:f??h}}a(Dd,"loadAutoModeSettings");function Or(e){if(typeof e!="string")return;let o=e.trim();return o.length===0?void 0:o}a(Or,"nonEmptyString");function Xe(e){try{if(So.existsSync(e))return JSON.parse(So.readFileSync(e,"utf-8"))}catch{}return{}}a(Xe,"readJsonFile");function Fr(e,o){So.mkdirSync(Dr.dirname(e),{recursive:!0}),So.writeFileSync(e,JSON.stringify(o,null,2))}a(Fr,"writeJsonFile");function xn(e){let o=Xe(bo);Fr(bo,{...o,permissionMode:e})}a(xn,"savePermissionModeUser");function Ud(){let e=Xe(bo),o=Xe(Ur()),n=e.alwaysAllowTools??[],t=o.alwaysAllowTools??[];return[...new Set([...n,...t])]}a(Ud,"loadAlwaysAllowTools");function Fd(e,o,n=!1){let t=vn(e,o,n);if(!t)return;let r=Ur(),i=Xe(r),l=i.alwaysAllowTools??[];l.includes(t)||Fr(r,{...i,alwaysAllowTools:[...l,t]})}a(Fd,"saveAlwaysAllowToolPattern");var An=["ama","amaw","sa"];function jr(e){let o=An.indexOf(e);return An[(o+1)%An.length]??"ama"}a(jr,"nextAgentMode");var Te=class{static{a(this,"CommandRegistry")}commands=new Map;aliases=new Map;register(o){let n=o.name.toLowerCase();if(this.commands.has(n))throw new Error(`Command "${o.name}" is already registered`);if(this.aliases.has(n)){let r=this.aliases.get(n);throw new Error(`Command "${o.name}" conflicts with existing alias for "${r}"`)}let t=new Set;for(let r of o.aliases??[]){let i=r.toLowerCase();if(i!==n){if(t.has(i))throw new Error(`Alias "${r}" is duplicated within command "${o.name}"`);if(this.commands.has(i))throw new Error(`Alias "${r}" conflicts with existing command "${i}"`);if(this.aliases.has(i)){let l=this.aliases.get(i);throw new Error(`Alias "${r}" is already registered for "${l}"`)}t.add(i)}}if(this.commands.set(n,{...o,source:o.source??"builtin"}),o.aliases)for(let r of o.aliases){let i=r.toLowerCase();i!==n&&this.aliases.set(i,n)}}unregister(o){let n=o.toLowerCase(),t=this.aliases.get(n)??n;if(!this.commands.has(t))return!1;let r=this.commands.get(t);if(r?.aliases)for(let i of r.aliases)this.aliases.delete(i.toLowerCase());return this.commands.delete(t),!0}get(o){let n=o.toLowerCase(),t=this.aliases.get(n)??n;return this.commands.get(t)}has(o){let n=o.toLowerCase(),t=this.aliases.get(n)??n;return this.commands.has(t)}getAll(o){let n=new Map;for(let[t,r]of this.commands)o&&r.source!==o||n.has(t)||n.set(t,{name:r.name,aliases:r.aliases,description:r.description,source:r.source??"builtin",usage:r.usage,priority:r.priority,location:r.location,path:r.path,userInvocable:r.userInvocable,disableModelInvocation:r.disableModelInvocation,allowedTools:r.allowedTools,context:r.context,agent:r.agent,argumentHint:r.argumentHint,model:r.model});return Array.from(n.values()).sort((t,r)=>t.name.localeCompare(r.name))}getBySource(o){return this.getAll(o)}getNames(){return Array.from(this.commands.keys()).sort()}clear(){this.commands.clear(),this.aliases.clear()}get size(){return this.commands.size}get aliasCount(){return this.aliases.size}},Ui=new Te;import j from"chalk";import{Buffer as Kr}from"node:buffer";import{spawn as Fi}from"node:child_process";import Hr from"node:process";var fe="\x1B",ji="\x07",Rn=`${fe}\\`;function Br(e,o){return e.SSH_CONNECTION?!1:o==="win32"||o==="darwin"||o==="linux"}a(Br,"shouldPreferNativeClipboard");function Hi(e,o){let n=Kr.from(e,"utf8").toString("base64"),t=o.TERM==="xterm-kitty"?Rn:ji,r=`${fe}]52;c;${n}${t}`;return o.TMUX?`${fe}Ptmux;${r.replaceAll(fe,`${fe}${fe}`)}${Rn}`:o.STY?`${fe}P${r}${Rn}`:r}a(Hi,"buildOscSequence");async function xo(e,o,n){return new Promise((t,r)=>{let i=Fi(e,o,{stdio:["pipe","ignore","pipe"],windowsHide:!0}),l="";i.on("error",r),i.stderr?.on("data",c=>{l+=c.toString()}),i.on("close",c=>{if(c===0){t(!0);return}r(new Error(l.trim()||`${e} exited with code ${c??"unknown"}`))}),i.stdin?.write(n),i.stdin?.end()})}a(xo,"execClipboardCommand");function Bi(e){let o="$stream = [Console]::OpenStandardInput(); $buffer = New-Object byte[] 8192; $memory = New-Object System.IO.MemoryStream; while (($read = $stream.Read($buffer, 0, $buffer.Length)) -gt 0) { $memory.Write($buffer, 0, $read) }; $text = [System.Text.Encoding]::UTF8.GetString($memory.ToArray()); Set-Clipboard -Value $text",n=Kr.from(e,"utf8");return[["powershell",["-NoProfile","-NonInteractive","-Command",o],n],["pwsh",["-NoProfile","-NonInteractive","-Command",o],n],["cmd",["/c","chcp 65001 >nul & clip"],n]]}a(Bi,"buildWindowsClipboardCandidates");async function qr(e,o,n){if(o.SSH_CONNECTION)return!1;switch(n){case"win32":{let t=Bi(e);for(let[r,i,l]of t)try{if(await xo(r,i,l))return!0}catch{}return!1}case"darwin":return xo("pbcopy",[],e);case"linux":{let t=[["wl-copy",[]],["xclip",["-selection","clipboard"]],["xsel",["--clipboard","--input"]]];for(let[r,i]of t)try{if(await xo(r,i,e))return!0}catch{}return!1}default:return!1}}a(qr,"tryNativeClipboard");async function qi(e,o){if(!o.TMUX)return!1;let n=o.LC_TERMINAL==="iTerm2"?["load-buffer","-"]:["load-buffer","-w","-"];try{return await xo("tmux",n,e)}catch{return!1}}a(qi,"tryTmuxClipboard");async function zr(e,o={}){let n=o.env??Hr.env,t=o.platform??Hr.platform,r=e.trimEnd(),i=Hi(r,n);if(!r)throw new Error("Nothing to copy.");if(Br(n,t))try{if(await qr(r,n,t))return{path:"native"}}catch{}if(await qi(r,n))return{path:"tmux-buffer"};if(o.terminalWrite?.(i))return{path:"osc52"};if(!Br(n,t))try{if(await qr(r,n,t))return{path:"native"}}catch{}throw new Error("Unable to access any clipboard path.")}a(zr,"copyTextToClipboard");function Zd(e){return e.type==="tool_summary"?{type:"event",text:e.text,icon:"tool"}:e}a(Zd,"seedToHistoryItem");var Ki="[Thinking]",zi="[/Thinking]",Gi="Untitled Session",Gr=50,Xi=60,Vr="...",Jr=["[Managed Task]","[Managed Task Protocol Retry]","Assigned native agent identity:","Tool policy:","Blocked tools:","Allowed shell patterns:","Dependency handoff artifacts:","Dependency summary preview:","Preferred agent:","Read structured bundle first:","Read human summary next:"],Yr=[/(?:^|\n)You are the [^\n]+ role for a managed KodaX task\./,/(?:^|\n)Primary task:/,/(?:^|\n)Work intent:/,/(?:^|\n)Complexity:/,/(?:^|\n)Risk:/,/(?:^|\n)Harness:/,/(?:^|\n)Brainstorm required:/],Vi=/(^|\r?\n)\[Thinking\]\r?\n([\s\S]*?)\r?\n\[\/Thinking\](?=\r?\n|$)/g;function Ji(e){let o=-1;for(let n of Jr){let t=e.indexOf(n);t>=0&&(o===-1||t<o)&&(o=t)}for(let n of Yr){let t=n.exec(e);t&&t.index>=0&&(o===-1||t.index<o)&&(o=t.index)}return o}a(Ji,"findControlPlaneCutIndex");function Yi(e){return Jr.some(o=>e.includes(o))||Yr.some(o=>o.test(e))}a(Yi,"hasControlPlaneSignal");function Zr(e){let o=[];for(let n of e)n&&typeof n=="object"&&"type"in n&&n.type==="text"&&"text"in n&&o.push(String(n.text));return o}a(Zr,"collectTextBlocks");function Zi(e){return typeof e=="string"?e:Array.isArray(e)?Zr(e).join(`
|
|
3
|
+
`):""}a(Zi,"extractAssistantTextOnly");function Je(e,o,n){n.trim().length!==0&&e.push({type:o,text:n})}a(Je,"pushSeed");function Xr(e){return e.replace(/^\n+/,"").replace(/\n+$/,"")}a(Xr,"stripLegacyTagBoundaryNewlines");function Qi(e){let o=e.name,n=e.input;if(!n)return`\u26A1 ${o}`;let t=o==="bash"?Ve(String(n.command??"")):o==="read"||o==="write"||o==="edit"?Ve(String(n.file_path??n.path??"")):o==="grep"||o==="glob"?Ve(String(n.pattern??"")):o==="web_search"||o==="web_fetch"?Ve(String(n.query??n.url??"")):void 0;return t?`\u26A1 ${o}(${t})`:`\u26A1 ${o}`}a(Qi,"formatToolUseSummary");function Ve(e,o=60){let n=e.replace(/\s+/g," ").trim();return n.length>o?`${n.slice(0,o)}...`:n}a(Ve,"truncateToolHint");function ea(e){if(!e.includes(Ki)||!e.includes(zi))return e.trim().length>0?[{type:"assistant",text:e}]:[];let o=[],n=0;for(let t of e.matchAll(Vi)){let r=t.index??-1,i=t[1]??"",l=t[2]??"";if(r<0)continue;let c=r+i.length;Je(o,"assistant",Xr(e.slice(n,c))),Je(o,"thinking",l),n=r+t[0].length}return Je(o,"assistant",Xr(e.slice(n))),o.length===0?e.trim().length>0?[{type:"assistant",text:e}]:[]:o}a(ea,"parseLegacyAssistantContent");function oa(e){if(typeof e=="string")return ea(e);if(!Array.isArray(e))return[];let o=[],n=[],t=a(()=>{n.length!==0&&(Je(o,"assistant",n.join(`
|
|
4
|
+
`)),n.length=0)},"flushAssistantBuffer");for(let r of e)if(!(!r||typeof r!="object"||!("type"in r)))switch(r.type){case"text":"text"in r&&n.push(String(r.text));break;case"thinking":t(),"thinking"in r&&Je(o,"thinking",String(r.thinking));break;case"tool_use":if(t(),"name"in r){let i=Qi(r);i&&o.push({type:"tool_summary",text:i})}break;case"tool_result":case"redacted_thinking":break;default:break}return t(),o}a(oa,"extractAssistantHistorySeeds");var na=["You are the Scout role","You are the Generator role","You are the Planner role","You are the Evaluator role"],ta=/\r?\n?\`\`\`kodax[\w-]*[\s\S]*?\`\`\`\s*/g;function ra(e){return na.some(o=>e.includes(o))}a(ra,"isManagedWorkerPrompt");function sa(e){return e.replace(ta,"").trim()}a(sa,"stripManagedProtocolBlocks");function Qd(e){switch(e.role){case"assistant":return oa(e.content).map(n=>({...n,text:sa(n.text)})).filter(n=>n.text.length>0);case"user":{if(e._synthetic)return[];let o=Qr(e.content);return o.trim().length===0||ra(o)?[]:[{type:"user",text:o}]}case"system":return[];default:return[]}}a(Qd,"extractHistorySeedsFromMessage");function Qr(e){return typeof e=="string"?e:Array.isArray(e)?Zr(e).join(`
|
|
5
|
+
`):""}a(Qr,"extractTextContent");function ia(e){let o=e.replace(/\s+/g," ").trim();return o?o.length>Gr?`${o.slice(0,Gr)}${Vr}`:o:Gi}a(ia,"formatSessionTitle");function In(e){for(let o=e.length-1;o>=0;o--){let n=e[o];if(n?.role!=="assistant")continue;let t=Zi(n.content);if(t)return t}return""}a(In,"extractLastAssistantText");function eu(e,o,n,t){let r=[In(e),o.trim(),n?.trim()??"",t?.trim()??""];for(let i of r){let l=es(i);if(l)return l}return""}a(eu,"resolveCompletedAssistantText");function es(e){let o=e.trim();if(!o)return"";let n=Ji(o);return n===0?"":(n>0?o.slice(0,n):o).trim()}a(es,"sanitizeUserFacingAssistantText");function ou(e){let o=e.trim();return o.length>0&&es(o).length===0&&Yi(o)}a(ou,"isControlPlaneOnlyAssistantText");function nu(e){let o=e.find(t=>t.role==="user"),n=o?Qr(o.content):"";return ia(n)}a(nu,"extractTitle");function tu(e,o=Xi){let n=e.replace(/\n/g," "),t=n.length>o?Vr:"";return n.slice(0,o)+t}a(tu,"formatMessagePreview");var Cn={name:"copy",description:"Copy last assistant message to clipboard",usage:"/copy",handler:a(async(e,o)=>{let n=In(o.messages);if(!n){console.log(j.yellow(`
|
|
6
|
+
No assistant message found to copy.`)),console.log(j.dim("The assistant needs to respond first before you can copy its message."));return}try{await zr(n);let t=n.length>50?n.slice(0,50)+"...":n;console.log(j.green(`
|
|
7
|
+
Copied to clipboard!`)),console.log(j.dim(`Preview: ${t}`))}catch(t){let r=t instanceof Error?t.message:String(t);console.log(j.red(`
|
|
8
|
+
Failed to copy to clipboard: ${r}`)),console.log(j.dim("You may need to check clipboard permissions or manually copy the message."))}},"handler"),detailedHelp:a(()=>{console.log(j.bold(`
|
|
9
|
+
/copy - Copy Last Assistant Message
|
|
10
|
+
`)),console.log("Usage:"),console.log(j.cyan(" /copy")+` - Copy the last assistant message to clipboard
|
|
11
|
+
`),console.log("Description:"),console.log(" This command copies the most recent assistant response to your system clipboard."),console.log(` Useful for quickly sharing or saving AI responses.
|
|
12
|
+
`),console.log("Examples:"),console.log(j.dim(" User: Explain how async/await works")),console.log(j.dim(" AI: [responds with explanation]")),console.log(j.cyan(" /copy")+j.dim(` - Copies the explanation to clipboard
|
|
13
|
+
`)),console.log("Notes:"),console.log(" - Only copies assistant messages, not user messages"),console.log(" - Works with both plain text and formatted responses"),console.log(" - Requires clipboard permissions on some systems")},"detailedHelp")};import*as z from"node:fs";import*as Ao from"node:path";import S from"chalk";function aa(e){return e.runtimeInfo?.workspaceRoot??e.runtimeInfo?.executionCwd??process.cwd()}a(aa,"resolveCwd");function ns(e){let o;try{o=z.readdirSync(e,{withFileTypes:!0})}catch(t){return t.code!=="ENOENT"&&console.error(`[memory] failed to read memory directory ${e}:`,t),[]}let n=[];for(let t of o){if(!t.isFile()||!t.name.endsWith(".md")||t.name==="MEMORY.md")continue;let r=Ao.join(e,t.name),i="",l=0;try{i=z.readFileSync(r,"utf-8"),l=z.statSync(r).mtimeMs}catch(f){console.error(`[memory] failed to read ${r}:`,f);continue}let d=Et(i).frontmatter,u=d.name!==void 0||d.description!==void 0||d.type!==void 0,m=Ao.basename(t.name,".md");n.push({filename:t.name,absPath:r,mtimeMs:l,title:d.name?.trim()||m,description:d.description?.trim()||m,type:d.type,parseOk:u})}return n}a(ns,"readTopicFiles");function la(e){return e.map(o=>`- [${o.title}](${o.filename}) \u2014 ${o.description}`)}a(la,"buildIndexLines");async function ca(e,o){console.log(S.cyan(`
|
|
14
|
+
[memory] per-project memory directory`)),console.log(S.dim(` ${e}`));let n=ns(e),t=n.filter(l=>!l.parseOk);console.log(S.dim(` ${n.length} topic file${n.length===1?"":"s"}`+(t.length>0?`, ${t.length} without parsable frontmatter`:"")));let r=!1,i="";try{i=z.readFileSync(o,"utf-8"),r=!0}catch{r=!1}if(!r){console.log(S.yellow(`
|
|
15
|
+
MEMORY.md does not exist yet.`)),n.length>0?console.log(S.dim(" Run `/memory rebuild` to seed it from existing topic files.")):console.log(S.dim(" The LLM will create it on first save \u2014 no action needed.")),console.log();return}console.log(S.cyan(`
|
|
16
|
+
--- MEMORY.md ---`)),i.trim().length===0?console.log(S.dim(" (empty)")):console.log(i.trimEnd()),console.log(S.cyan(`--- end ---
|
|
17
|
+
`))}a(ca,"listMemory");async function da(e,o){let n=!1;try{n=z.statSync(e).isDirectory()}catch{n=!1}if(!n){console.log(S.yellow(`
|
|
18
|
+
[memory] memory directory does not exist yet \u2014 nothing to rebuild.`)),console.log(S.dim(` ${e}`)),console.log(S.dim(` The LLM will create both the directory and MEMORY.md on first save.
|
|
19
|
+
`));return}let t=ns(e);if(t.length===0){console.log(S.yellow(`
|
|
20
|
+
[memory] no topic files found \u2014 nothing to rebuild.`)),console.log(S.dim(` ${e}
|
|
21
|
+
`));return}let r=[...t].sort((d,u)=>u.mtimeMs-d.mtimeMs),l=la(r).join(`
|
|
22
|
+
`)+`
|
|
23
|
+
`;z.writeFileSync(o,l,"utf-8"),console.log(S.green(`
|
|
24
|
+
[memory] rebuilt MEMORY.md with ${r.length} entries (newest first).`)),console.log(S.dim(` ${o}`));let c=r.filter(d=>!d.parseOk);if(c.length>0){console.log(S.yellow(` ${c.length} file(s) had no parsable frontmatter \u2014 used filename as fallback:`));for(let d of c)console.log(S.dim(` - ${d.filename}`));console.log(S.dim(" Tip: add `---\\nname: ...\\ndescription: ...\\ntype: ...\\n---` at the top of those files."))}console.log()}a(da,"rebuildMemory");function ua(e,o){console.log(S.cyan(`
|
|
25
|
+
[memory] open these paths in your editor:`)),console.log(S.dim(" index :"),o),console.log(S.dim(" dir :"),e),console.log(S.dim(`
|
|
26
|
+
(No in-REPL editor is provided \u2014 open the file in your usual editor.
|
|
27
|
+
Use \`/memory rebuild\` after manual edits if you renamed any topic file.)
|
|
28
|
+
`))}a(ua,"openMemory");function os(){console.log(S.cyan(`
|
|
29
|
+
/memory - Inspect or rebuild per-project memory`)),console.log(S.dim(" /memory List MEMORY.md + memory directory")),console.log(S.dim(" /memory list Same as `/memory`")),console.log(S.dim(" /memory rebuild Regenerate MEMORY.md from topic frontmatter")),console.log(S.dim(" /memory open Print paths so you can open them in your editor")),console.log(S.dim(" /memory help Show this help")),console.log()}a(os,"printHelp");function fa(){console.log(S.bold(`
|
|
30
|
+
/memory - Inspect or rebuild project memory
|
|
31
|
+
`)),console.log("Usage:"),console.log(S.cyan(" /memory ")+S.dim("Show MEMORY.md + topic file count")),console.log(S.cyan(" /memory list ")+S.dim("Alias for `/memory`")),console.log(S.cyan(" /memory rebuild ")+S.dim("Regenerate MEMORY.md (newest first by mtime)")),console.log(S.cyan(" /memory open ")+S.dim("Print the index + dir paths for editor use")),console.log(S.cyan(" /memory help ")+S.dim(`Show this help
|
|
32
|
+
`)),console.log("Description:"),console.log(S.dim(` Each project gets its own memory directory under your KodaX agent
|
|
33
|
+
home \u2014 \`<agentConfigHome>/projects/<project-key>/memory/\`. The LLM
|
|
34
|
+
owns reads/writes; this command is your escape hatch when the
|
|
35
|
+
MEMORY.md index drifts from the topic files on disk.
|
|
36
|
+
`)),console.log("Notes:"),console.log(S.dim(" \u2022 Rebuild ONLY rewrites MEMORY.md. Topic files are never touched.")),console.log(S.dim(" \u2022 Rebuild sorts entries by file mtime descending \u2014 the same")),console.log(S.dim(" natural-LRU order the LLM produces by prepending new entries.")),console.log(S.dim(" \u2022 Files missing or with malformed frontmatter still appear in")),console.log(S.dim(" the rebuilt index using their filename as fallback; the command")),console.log(S.dim(` prints a warning so you can fix the frontmatter.
|
|
37
|
+
`))}a(fa,"printDetailedHelp");var En={name:"memory",description:"Inspect or rebuild per-project memory (FEATURE_124)",usage:"/memory [list|rebuild|open|help]",argumentHint:"list | rebuild | open | help",handler:a(async(e,o)=>{let n=aa(o),t=It(n),r=Ct(n),i=(e[0]??"list").toLowerCase();if(i==="help"||i==="--help"||i==="-h"){os();return}if(i==="list"){await ca(t,r);return}if(i==="rebuild"){await da(t,r);return}if(i==="open"){ua(t,r);return}console.log(S.yellow(`
|
|
38
|
+
[memory] unknown subcommand: ${i}`)),os()},"handler"),detailedHelp:fa};import R from"chalk";function ts(){console.log(`
|
|
39
|
+
${R.bold("/goal")} \u2014 persistent session goal
|
|
40
|
+
|
|
41
|
+
${R.bold("Subcommands:")}
|
|
42
|
+
${R.cyan("/goal <objective> [--tokens N]")} Create a new persistent goal.
|
|
43
|
+
${R.cyan("/goal status")} Show current goal (default).
|
|
44
|
+
${R.cyan("/goal pause")} Pause an active goal.
|
|
45
|
+
${R.cyan("/goal resume")} Resume a paused goal.
|
|
46
|
+
${R.cyan("/goal clear")} Clear the current goal.
|
|
47
|
+
${R.cyan("/goal help")} Show this help.
|
|
48
|
+
|
|
49
|
+
${R.bold("Notes:")}
|
|
50
|
+
- The agent auto-continues toward an active goal on every Worker turn end.
|
|
51
|
+
- Token budget is optional; set it only when you want a hard ceiling.
|
|
52
|
+
- update_goal({complete}) is verifier-gated; the agent cannot
|
|
53
|
+
self-declare done without runtime confirmation.
|
|
54
|
+
`.trim())}a(ts,"printHelp");function ma(e){let o=null,n=[];for(let r=0;r<e.length;r++){let i=e[r];if(i==="--tokens"){let l=e[r+1];if(!l)return{error:"--tokens requires a value (e.g. `--tokens 50000`)"};let c=Number(l);if(!rn(c))return{error:"--tokens value must be a positive integer"};o=c,r++;continue}if(i.startsWith("--tokens=")){let l=i.slice(9),c=Number(l);if(!rn(c))return{error:"--tokens value must be a positive integer"};o=c;continue}if(i.startsWith("--"))return{error:`unknown flag: ${i}`};n.push(i)}let t=n.join(" ").trim();return t?{objective:t,tokenBudget:o}:{error:"objective is required"}}a(ma,"parseCreateArgs");function ga(e){if(!e)return R.dim("No goal set. Use `/goal <objective>` to create one.");let o=[`${R.bold("Goal:")} ${e.objective}`,`${R.bold("Status:")} ${e.status}`,`${R.bold("Tokens used:")} ${e.tokensUsed}`];if(e.tokenBudget!==null){let n=Math.max(0,e.tokenBudget-e.tokensUsed);o.push(`${R.bold("Token budget:")} ${e.tokenBudget} (remaining ${n})`)}else o.push(`${R.bold("Token budget:")} ${R.dim("none")}`);return o.push(`${R.bold("Elapsed:")} ${e.timeUsedSeconds}s`),e.status==="blocked"&&e.lastBlockerKind&&o.push(`${R.bold("Blocker:")} ${e.lastBlockerKind}`),o.join(`
|
|
55
|
+
`)}a(ga,"renderStatus");async function Ye(e,o,n,t){if(!e.lineage)throw new Error("session lineage unavailable \u2014 open or start a new session before using /goal");e.lineage=_t(e.lineage,n,t),await o.saveSession()}a(Ye,"persist");async function pa(e,o,n){if(!o.lineage){console.log(R.red("[/goal] no active session lineage"));return}let t=be(o.lineage);if(t&&t.status!=="complete"){console.log(R.yellow(`[/goal] a goal is already active (status: ${t.status}). Clear it first with \`/goal clear\` before creating a new one.`));return}let r=ma(e);if("error"in r){console.log(R.red(`[/goal] ${r.error}`));return}try{t&&t.status==="complete"&&await Ye(o,n,null,"cleared");let i=Ut(r.objective,r.tokenBudget);await Ye(o,n,i,"created"),console.log(R.green(`[/goal] created: "${i.objective}"`)),i.tokenBudget!==null&&console.log(R.dim(` budget: ${i.tokenBudget} tokens`))}catch(i){let l=i instanceof Error?i.message:String(i);console.log(R.red(`[/goal] ${l}`))}}a(pa,"doCreate");async function wa(e){if(!e.lineage){console.log(R.red("[/goal] no active session lineage"));return}let o=be(e.lineage);console.log(ga(o))}a(wa,"doStatus");async function ha(e,o){if(!e.lineage){console.log(R.red("[/goal] no active session lineage"));return}let n=be(e.lineage);if(!n){console.log(R.yellow("[/goal] no goal to pause"));return}if(n.status!=="active"){console.log(R.yellow(`[/goal] cannot pause from status '${n.status}' (only 'active' is pausable)`));return}let t=Ft(n);await Ye(e,o,t,"paused"),console.log(R.green("[/goal] paused"))}a(ha,"doPause");async function ya(e,o){if(!e.lineage){console.log(R.red("[/goal] no active session lineage"));return}let n=be(e.lineage);if(!n){console.log(R.yellow("[/goal] no goal to resume"));return}if(n.status!=="paused"){console.log(R.yellow(`[/goal] cannot resume from status '${n.status}' (only 'paused' is resumable)`));return}let t=jt(n);await Ye(e,o,t,"resumed"),console.log(R.green("[/goal] resumed"))}a(ya,"doResume");async function ka(e,o){if(!e.lineage){console.log(R.red("[/goal] no active session lineage"));return}if(!be(e.lineage)){console.log(R.yellow("[/goal] no goal to clear"));return}await Ye(e,o,null,"cleared"),console.log(R.green("[/goal] cleared"))}a(ka,"doClear");var rs={name:"goal",description:"Manage a persistent session goal (FEATURE_192)",usage:"/goal [<objective> [--tokens N] | status | pause | resume | clear | help]",argumentHint:"<objective> | status | pause | resume | clear | help",handler:a(async(e,o,n)=>{let t=(e[0]??"status").toLowerCase();if(t==="help"||t==="--help"||t==="-h"){ts();return}if(t==="status"){await wa(o);return}if(t==="pause"){await ha(o,n);return}if(t==="resume"){await ya(o,n);return}if(t==="clear"){await ka(o,n);return}await pa(e,o,n)},"handler"),detailedHelp:ts};import{existsSync as Ps}from"node:fs";import{join as X}from"node:path";import w from"chalk";import Mn from"path";import{createHash as Aa}from"crypto";import{execFile as va}from"child_process";import $a from"fs";import Tn from"path";import{promisify as Sa}from"util";var ba=Sa(va);function ne(e){if(!(!e||!e.trim()))return Tn.resolve(e).replace(/\\/g,"/")}a(ne,"normalizePath");async function Ze(e,o){try{let{stdout:n}=await ba("git",o,{cwd:e,windowsHide:!0,maxBuffer:1048576}),t=n.trim();return t||void 0}catch{return}}a(Ze,"gitStdout");function xa(e){let o=ne(e);if(o)return Tn.posix.basename(o)===".git"?Tn.posix.dirname(o):o}a(xa,"deriveCanonicalRepoRoot");async function xu(e={}){let o=ne(e.cwd??process.cwd())??process.cwd().replace(/\\/g,"/"),n=ne(await Ze(o,["rev-parse","--show-toplevel"])),t=await Ze(n??o,["rev-parse","--path-format=absolute","--git-common-dir"])??await Ze(n??o,["rev-parse","--git-common-dir"]),r=await Ze(n??o,["branch","--show-current"])??await Ze(n??o,["rev-parse","--abbrev-ref","HEAD"]);return{canonicalRepoRoot:xa(t)??n,workspaceRoot:n,executionCwd:o,branch:r&&r!=="HEAD"?r:void 0,workspaceKind:e.workspaceKind??"detected"}}a(xu,"inspectWorkspaceRuntime");function Au(e,o){return!e?.canonicalRepoRoot||!o?.canonicalRepoRoot?!1:ne(e.canonicalRepoRoot)===ne(o.canonicalRepoRoot)}a(Au,"isSameCanonicalRepo");function Ru(e){return!!(e?.workspaceRoot&&$a.existsSync(e.workspaceRoot))}a(Ru,"workspaceExists");function ss(e){let o=ne(e.runtimeInfo?.workspaceRoot??e.gitRoot),n=ne(e.runtimeInfo?.executionCwd??o),t=ne(e.runtimeInfo?.canonicalRepoRoot??o);if(!(!o&&!n&&!t))return{canonicalRepoRoot:t,workspaceRoot:o,executionCwd:n,branch:e.runtimeInfo?.branch,workspaceKind:e.runtimeInfo?.workspaceKind??"detected"}}a(ss,"resolveSessionRuntimeInfo");function Pn(e){if(!e?.workspaceRoot)return"No git workspace detected";let o=e.branch?` @ ${e.branch}`:"",n=e.workspaceKind??"detected";return`${e.workspaceRoot}${o} [${n}]`}a(Pn,"formatWorkspaceTruth");var is="_unknown",as=80;function Ra(e){return process.platform==="win32"||process.platform==="darwin"?e.toLowerCase():e}a(Ra,"caseFold");function Ia(e){return Ra(Mn.resolve(e).replace(/\\/g,"/"))}a(Ia,"normalizeRoot");function ls(e){return Aa("sha256").update(e).digest("hex").slice(0,10)}a(ls,"shortHash");function Ca(e){let o=e.replace(/[^a-z0-9]+/gi,"-").replace(/^-+|-+$/g,"");return o.length>as?o.slice(o.length-as):o}a(Ca,"slugify");function me(e){if(!e||!e.trim())return{key:is,canonicalRoot:null,displayName:is};let o=Ia(e),n=Ca(o),t=n?`${n}-${ls(o)}`:ls(o),r=Mn.basename(Mn.resolve(e).replace(/\\/g,"/"))||e;return{key:t,canonicalRoot:o,displayName:r}}a(me,"deriveProjectKeyFromRoot");function Mu(e){let o=ss({gitRoot:e.gitRoot??"",runtimeInfo:e.runtimeInfo}),n=o?.canonicalRepoRoot??o?.executionCwd??(e.gitRoot&&e.gitRoot.trim()?e.gitRoot:void 0);return me(n)}a(Mu,"deriveProjectKeyFromData");import{join as ml}from"node:path";import Uo from"chalk";import{existsSync as J,readdirSync as ja,readFileSync as Po,writeFileSync as Hu}from"node:fs";import{dirname as Ha,join as G}from"node:path";import A from"chalk";import{existsSync as Ea,readFileSync as Ta}from"node:fs";var cs=4,ds=180,us=6e3,fs=360,Wn="[truncated]";function pe(e){return/[\u3400-\u9fff]/u.test(e)?"zh":"en"}a(pe,"detectWorkflowLocale");function Qe(...e){return pe(e.filter(o=>typeof o=="string").join(`
|
|
56
|
+
`))}a(Qe,"inferWorkflowLocaleFromParts");function ge(e,o={}){let n=e.trim();return o.full===!0||n.length<=us?n:`${n.slice(0,us).trimEnd()}
|
|
57
|
+
|
|
58
|
+
${Wn}`}a(ge,"trimResultPreview");function _n(e){return e.includes(Wn)}a(_n,"isWorkflowResultPreviewTruncated");function Pa(e,o){return o==="zh"?`[\u7ED3\u679C\u9884\u89C8\u5DF2\u622A\u65AD\u3002\u5B8C\u6574\u7ED3\u679C\u8BF7\u7528 /workflow show --full ${e} \u67E5\u770B\uFF1Bartifact \u6587\u4EF6\u4E5F\u4FDD\u5B58\u5728\u672C\u6B21 run \u76EE\u5F55\u3002]`:`[Result preview truncated. Use /workflow show --full ${e} for the complete result; artifacts are also saved in the run directory.]`}a(Pa,"formatWorkflowResultTruncationHint");function Ro(e,o,n){let t=e.lastIndexOf(Wn);return t<0?e:`${e.slice(0,t).trimEnd()}
|
|
59
|
+
|
|
60
|
+
${Pa(o,n)}`}a(Ro,"replaceWorkflowResultTruncationMarker");function Ma(e){let o=e.replace(/\s+/g," ").trim();return o.length<=fs?o:`${o.slice(0,fs).trimEnd()}...`}a(Ma,"trimWorkflowLaunchSummary");function re(e,o={}){if(typeof e=="string"&&e.trim().length>0)return ge(e,o);if(e&&typeof e=="object"&&"synthesis"in e){let n=e.synthesis;if(typeof n=="string"&&n.trim().length>0)return ge(n,o);if(n&&typeof n=="object"&&"text"in n){let t=n.text;if(typeof t=="string"&&t.trim().length>0)return ge(t,o)}}if(e&&typeof e=="object")for(let n of["summary","report","text","result"]){let t=e[n];if(typeof t=="string"&&t.trim().length>0)return ge(t,o)}if(e!=null)try{let n=JSON.stringify(e,null,2);if(typeof n=="string"){let t=n.trim();if(t.length>0&&t!=="{}"&&t!=="[]"&&t!=='""')return ge(n,o)}}catch{}}a(re,"formatResult");function Io(e,o={}){let n=[...e].reverse().filter(l=>l.type==="agent_completed"&&te(l,"status")==="completed"),r=n.find(l=>te(l,"name")==="synthesize")??n[0],i=r?te(r,"summary"):void 0;return i?ge(i,o):void 0}a(Io,"formatFinalEventSummary");function Wa(e,o={}){if(!(!e.path||!Ea(e.path)))try{let n=JSON.parse(Ta(e.path,"utf8")),t=re(n,o);if(t)return t;let r=JSON.stringify(n,null,2);return typeof r=="string"&&r.trim().length>0?ge(r,o):void 0}catch(n){return`artifact preview unavailable: ${n instanceof Error?n.message:String(n)}`}}a(Wa,"formatArtifactPreview");function eo(e,o,n={}){for(let r=e.length-1;r>=0;r-=1){let i=e[r];if(!i)continue;let l=Wa(i,n);if(l)return o==="zh"?`\u4EA7\u7269 ${i.name}:
|
|
61
|
+
${l}`:`Artifact ${i.name}:
|
|
62
|
+
${l}`}if(e.length===0)return;let t=e.map(r=>r.name).join(", ");return o==="zh"?`\u5DF2\u751F\u6210\u4EA7\u7269: ${t}`:`Artifacts created: ${t}`}a(eo,"formatArtifactResult");function Ln(e){let o=e.resultText?Ro(e.resultText,e.runId,e.locale):void 0;if(e.locale==="zh"){let t=e.resultText&&e.isFallbackPreview!==!0?`Workflow \u5DF2\u5B8C\u6210\uFF08${e.totalSpawned} \u4E2A\u667A\u80FD\u4F53\uFF0Crun ${e.runId}\uFF09\u3002`:`Workflow \u8FD0\u884C\u7ED3\u675F\uFF0C\u4F46\u7ED3\u679C\u5951\u7EA6\u5931\u8D25\uFF08${e.totalSpawned} \u4E2A\u667A\u80FD\u4F53\uFF0Crun ${e.runId}\uFF09\u3002`;if(o){let r=e.isFallbackPreview===!0?"\u7ED3\u679C\u5951\u7EA6\u5F02\u5E38\uFF1Aworkflow \u8FD0\u884C\u7ED3\u675F\uFF0C\u4F46\u6CA1\u6709\u8FD4\u56DE\u5B8C\u6574\u6700\u7EC8\u7ED3\u679C\u3002\u4EE5\u4E0B\u662F\u6700\u540E\u7EFC\u5408\u8F93\u51FA\uFF1A":"\u6700\u7EC8\u7ED3\u679C\uFF1A";return`${t}
|
|
63
|
+
|
|
64
|
+
${r}
|
|
65
|
+
|
|
66
|
+
${o}`}return[t,"","\u8FD9\u6B21 workflow \u8FD0\u884C\u7ED3\u675F\uFF0C\u4F46\u751F\u6210\u811A\u672C\u8FDD\u53CD\u7ED3\u679C\u5951\u7EA6\uFF1A\u6CA1\u6709\u8FD4\u56DE\u53EF\u76F4\u63A5\u5C55\u793A\u7684\u6700\u7EC8\u7ED3\u679C\u6216\u53EF\u9884\u89C8\u4EA7\u7269\u3002\u8FD9\u4E0D\u662F\u6B63\u5E38\u5B8C\u6210\u72B6\u6001\uFF0C\u9700\u8981\u4FEE\u590D\u751F\u6210\u811A\u672C\u540E\u91CD\u65B0\u8FD0\u884C\u3002"].join(`
|
|
67
|
+
`)}let n=e.resultText&&e.isFallbackPreview!==!0?`Workflow completed (${e.totalSpawned} agents, run ${e.runId}).`:`Workflow ended with a result contract failure (${e.totalSpawned} agents, run ${e.runId}).`;if(o){let t=e.isFallbackPreview===!0?"Result contract violation: the workflow ended without returning a complete final result. Last synthesis output:":"Final result:";return`${n}
|
|
68
|
+
|
|
69
|
+
${t}
|
|
70
|
+
|
|
71
|
+
${o}`}return[n,"","The workflow ended, but the generated script violated the result contract: it did not return displayable final text or a previewable artifact. This is not a normal completion state; fix the generated script and rerun it."].join(`
|
|
72
|
+
`)}a(Ln,"formatWorkflowCompletionAnswer");function Nn(e){let o=e.summary.phases.length>0?e.summary.phases.join(" -> "):"dynamic",n=e.summary.maxAgents===null?"unbounded":String(e.summary.maxAgents),t=e.summary.plannedAgents===void 0?e.locale==="zh"?`\u6700\u591A ${n} \u4E2A\u667A\u80FD\u4F53`:`up to ${n} agents`:e.locale==="zh"?`\u8BA1\u5212\u7EA6 ${e.summary.plannedAgents} \u4E2A\u667A\u80FD\u4F53\uFF0C\u5B89\u5168\u4E0A\u9650 ${n}`:`about ${e.summary.plannedAgents} planned agents, safety cap ${n}`,r=e.summary.maxConcurrency===null?"unbounded":String(e.summary.maxConcurrency),i=Ma(e.approvalSummary);if(e.locale==="zh"){let c=e.summary.writesFiles?"\u5982\u9700\u5199\u6587\u4EF6\uFF0C\u4ECD\u4F1A\u7ECF\u8FC7\u6B63\u5E38\u6743\u9650\u786E\u8BA4\u3002":"\u8FD9\u662F\u53EA\u8BFB\u63A2\u67E5\uFF0C\u4E0D\u4F1A\u4E3B\u52A8\u4FEE\u6539\u6587\u4EF6\u3002";return[`\u6211\u4F1A\u7528 workflow \u505A\u8FD9\u6B21\u4EFB\u52A1\uFF0C\u5DF2\u542F\u52A8 ${e.summary.name}\uFF08${e.runId}\uFF09\u3002`,`\u8BA1\u5212\uFF1A${i}`,`\u9636\u6BB5\uFF1A${o}\uFF1B\u89C4\u6A21\uFF1A${t}\uFF0C\u5E76\u53D1 ${r}\u3002${c}`,"\u8FD0\u884C\u8FC7\u7A0B\u4F1A\u5728\u4E0B\u65B9\u52A8\u6001\u66F4\u65B0\uFF0C\u5B8C\u6210\u540E\u6211\u4F1A\u76F4\u63A5\u6C47\u603B\u7ED3\u8BBA\u3002"].join(`
|
|
73
|
+
`)}let l=e.summary.writesFiles?"File-writing work still goes through normal permission gates.":"This is read-only and will not modify files.";return[`I will use a workflow for this task: ${e.summary.name} (${e.runId}).`,`Plan: ${i}`,`Phases: ${o}; scale: ${t}, ${r} concurrent. ${l}`,"Progress will update below, and I will summarize the result when it finishes."].join(`
|
|
74
|
+
`)}a(Nn,"formatWorkflowLaunchAnswer");function te(e,o){let n=e.data?.[o];return typeof n=="string"&&n.trim().length>0?n.trim():void 0}a(te,"readEventString");function On(e,o="en",n){if(e.type!=="agent_completed"&&e.type!=="agent_summary_updated"||e.type==="agent_completed"&&te(e,"status")!=="completed")return;let t=te(e,"summary");if(!t)return;let r=te(e,"summaryKind");if(r==="pending")return;let i=r==="digest"?"digest":r==="digest-failed"?"digest-failed":"excerpt",l=te(e,"name")??te(e,"taskId")??"agent";return Fa(l,t,o,n,i)}a(On,"formatWorkflowAgentDigest");function _a(e){let o=e.replace(/\s+/g," ").trim();return o.length<=ds?o:`${o.slice(0,ds).trimEnd()}...`}a(_a,"trimWorkflowAgentDigestExcerpt");function La(e){return/^(?:conclusion|finding|confirmed issue|issue|evidence|risk|next|unresolved|decision|result|summary|结论|发现|问题|证据|风险|下一步|未决|判断|决定|结果|摘要)[::]/i.test(e)||/^(?:[A-Z]{1,3}-?\d+|[HMSLP]\d+)[.)::\s-]/i.test(e)?!0:/(?:critical|high|medium|low)\s+severity|(?:严重|高危|中危|低危)/i.test(e)}a(La,"isHighSignalWorkflowAgentDigestLine");function Na(e){let o=e.toLowerCase();return!!(/\[\/?workflow handoff\]/i.test(e)||/^\|.*\|$/.test(e)||/^\|?\s*:?-{3,}:?\s*(?:\|\s*:?-{3,}:?\s*)+\|?$/.test(e)||/^(?:i now have|i have|i now understand|here is|let me|i will|this report|the report)\b/.test(o)||/^(?:scope|review scope|范围|审查范围)[::]/i.test(e)||/^feature[_\s-]*\d+.*(?:report|review|audit|map|审查|报告|地图|变更地图)/i.test(e)||/^feature[_\s-]*\d+.*改动分布.*feature/i.test(e)||/(?:review report|audit|审查报告|综合报告|分析报告|变更地图)$/i.test(e)&&e.length<140)}a(Na,"isLowInformationWorkflowAgentDigestLine");function Oa(e){return e.replace(/\s+/g," ").trim()}a(Oa,"compactWorkflowAgentDigestLine");function Da(e,o={}){let n=e.replace(/^#{1,6}\s+/,"").replace(/^[-*]\s+/,"").replace(/^\d+[.)]\s+/,"").replace(/^`{3,}.*$/,"").replace(/^[`"'“”‘’)\]},,、。;;::.\s]+/,"").trim(),t=Oa(n);if(!(t.length<12)&&!/^[-*_`#\s]+$/.test(t)&&!Na(t))return o.truncateLines===!1?t:_a(t)}a(Da,"normalizeWorkflowAgentDigestLine");function Ua(e,o={}){let n=[],t=[];for(let r of e.split(/\r?\n+/)){let i=Da(r,o);if(!i)continue;let l=La(i)?n:t;n.includes(i)||t.includes(i)||l.push(i)}return n.length>0?n.slice(0,cs):t.length>0?t.slice(0,cs):[]}a(Ua,"extractWorkflowAgentDigestExcerpts");function Fa(e,o,n,t,r="excerpt"){let i=r==="digest",c=Ua(o,{truncateLines:!i}).map(m=>`- ${m}`),d=t?n==="zh"?`\u8FD9\u662F\u5B50 Agent \u7684\u6709\u754C\u6458\u8981\uFF1B/workflow show ${t} \u53EF\u67E5\u770B\u8FD0\u884C\u4E8B\u4EF6\u65F6\u95F4\u7EBF\u3002`:`This is a child-agent digest; use /workflow show ${t} for the event timeline.`:n==="zh"?"\u8FD9\u662F\u5B50 Agent \u7684\u6709\u754C\u6458\u8981\uFF1B/workflow show \u53EF\u67E5\u770B\u8FD0\u884C\u4E8B\u4EF6\u65F6\u95F4\u7EBF\u3002":"This is a child-agent digest; use /workflow show for the event timeline.",u=n==="zh"?i?`\u5B50 Agent ${e} \u5DF2\u5B8C\u6210\u3002\u6458\u8981\uFF1A`:r==="digest-failed"?`\u5B50 Agent ${e} \u5DF2\u5B8C\u6210\uFF08\u667A\u80FD\u6458\u8981\u4E0D\u53EF\u7528\uFF0C\u4EE5\u4E0B\u4E3A\u672C\u5730\u6458\u5F55\uFF09\uFF1A`:`\u5B50 Agent ${e} \u5DF2\u5B8C\u6210\u3002\u6458\u5F55\u6458\u8981\uFF1A`:i?`Agent ${e} completed. Summary:`:r==="digest-failed"?`Agent ${e} completed (smart summary unavailable; local excerpt):`:`Agent ${e} completed. Extracted summary:`;return c.length===0?[n==="zh"?`\u5B50 Agent ${e} \u5DF2\u5B8C\u6210\uFF0C\u4F46\u672A\u80FD\u63D0\u53D6\u5230\u6709\u6548\u6458\u8981\u3002`:`Agent ${e} completed. No useful summary could be extracted.`,d].join(`
|
|
75
|
+
`):[u,...c,d].join(`
|
|
76
|
+
`)}a(Fa,"formatWorkflowAgentLongDigest");function Co(e){return(o,n="en")=>On(o,n,e)}a(Co,"createWorkflowAgentDigestLimiter");import C from"chalk";function Dn(){return[`${C.bold("/workflow")} - dynamic multi-agent workflow harness`,"",`${C.bold("Subcommands:")}`,` ${C.cyan("/workflow list")} List built-in, pattern, and saved workflows. Alias: /workflow`,` ${C.cyan("/workflow create <request>")} Generate a restricted workflow from a complex request.`,` ${C.cyan("/workflow <name> [args]")} Run a built-in or saved workflow. Args may be JSON or bare text.`,` ${C.cyan("/workflow runs [--all|--limit N]")} List active and recent workflow runs for this project.`,` ${C.cyan("/workflow show [--full] [runId]")} Show the latest run; use --full for complete result artifacts.`,` ${C.cyan("/workflow pause <runId>")} Pause future child launches for an active run.`,` ${C.cyan("/workflow resume <runId>")} Resume a paused run.`,` ${C.cyan("/workflow stop [runId]")} Stop an active run through abort propagation. Defaults to the active run.`,` ${C.cyan("/workflow delete [--force] <runId>")} Delete one persisted run record; --force removes stale non-terminal records.`,` ${C.cyan("/workflow prune --dry-run|--keep N|--older-than Nd")}`," Preview or delete old terminal run records.",` ${C.cyan("/workflow rerun <runId|savedName> [args]")} Rerun a historical generated run, or run the current saved workflow by name.`,` ${C.cyan("/workflow save <runId> <name>")} Save a generated run as a workflow capsule.`,` ${C.cyan("/workflow rename <runId|alias|savedName> <newName>")} Rename a run display name or generated saved capsule.`,` ${C.cyan("/workflow revise [--replace] <runId|alias|savedName> <change>")} Generate and save a capsule revision.`,` ${C.cyan("/workflow help")} Show this help. Also available as /help workflow.`,"",`${C.bold("Examples:")}`,` ${C.dim("/workflow create Compare three flaky-test hypotheses and verify each one")}`,` ${C.dim('/workflow parallel-investigation {"question":"\u8BF7\u68C0\u67E5\u8FD9\u4E2A\u7ADE\u6001\u5728\u54EA\u91CC","targets":["packages/agent"]}')}`,` ${C.dim('/workflow rerun run-lx3 {"request":"\u8BF7\u7528\u540C\u6837\u6D41\u7A0B\u590D\u67E5 packages/repl"}')}`,` ${C.dim('/workflow rerun generated-audit {"request":"reuse the saved workflow for packages/repl"}')}`,` ${C.dim("/workflow prune --dry-run")}`,` ${C.dim("/workflow save run-lx3 generated-audit")}`,"",`${C.bold("Safety:")}`," - Generated and workflow capsule (.workflow.json) workflows run in the capability WorkflowApi runner."," - For rerun, a run id reruns its saved snapshot; a saved name runs the current saved capsule version."," - For revise --replace, only a saved generated capsule name can move; the previous capsule is archived."," - Local .ts/.mjs/.js workflows are trusted-local and require explicit confirmation."," - File, shell, MCP, and web effects still go through child agents and existing permission gates."].join(`
|
|
77
|
+
`)}a(Dn,"renderWorkflowHelp");function Eo(){console.log(`
|
|
78
|
+
${Dn()}
|
|
79
|
+
`)}a(Eo,"printWorkflowHelp");var Ba=new Set(["completed","failed","stopped","denied","cancelled"]);function Mo(e){return e.length===0?" (no built-in workflows)":e.map(o=>` ${A.cyan(o.name)} \u2014 ${o.description}`).join(`
|
|
80
|
+
`)}a(Mo,"formatWorkflowList");var qa=6,Ka=900;function za(e){let o=e.replace(/\r\n/g,`
|
|
81
|
+
`).replace(/\r/g,`
|
|
82
|
+
`).split(`
|
|
83
|
+
`),n=[],t=0,r=!1;for(let l of o){if(n.length>=qa)break;let c=` ${l}`,d=Ka-t;if(d<=0){r=!0;break}if(c.length>d){d>16&&n.push(`${c.slice(0,d-4)} ...`),r=!0;break}n.push(c),t+=c.length+1}let i=Math.max(0,o.length-n.length);if(i>0||r){let l=i>0?`${i} more line(s)`:"source truncated";n.push(` ... (${l}; full source omitted from prompt)`)}return n}a(za,"renderApprovalScriptPreview");function Y(e,o){let n=a(i=>i===null?"\u221E":String(i),"cap"),t=e.plannedAgents===void 0?void 0:String(e.plannedAgents),r=t===void 0?`agent total cap: ${n(e.maxAgents)}`:`planned agents: ${t} \xB7 agent safety cap: ${n(e.maxAgents)}`;return[`Run workflow ${A.cyan(e.name)}?`,` ${e.description}`,` phases: ${e.phases.length>0?e.phases.join(" \u2192 "):"(dynamic)"}`,` ${r} \xB7 max concurrency: ${n(e.maxConcurrency)} \xB7 token budget: ${n(e.tokenBudget)}`,` writes files: ${e.writesFiles?A.yellow("yes"):"no (read-only)"}`,...o?[` source: ${o.source}`,` sandbox/trust: ${o.sandbox}`,` worktree isolation: ${o.mayUseWorktree?"may request worktree":"shared cwd / per-child default"}`,...o.rawScriptPath?[` raw script: ${o.rawScriptPath}`]:o.rawScript?[" raw script: preview below"]:[],...o.rawScript&&!o.rawScriptPath?[" raw script preview:",...za(o.rawScript)]:[]]:[]].join(`
|
|
84
|
+
`)}a(Y,"renderApprovalPrompt");function no(e){if(!J(e))return[];let o=[];for(let n of ja(e)){let t=G(e,n,"run.json");if(J(t))try{let r=JSON.parse(Po(t,"utf8"));o.push({runId:n,workflow:typeof r.workflow=="string"?r.workflow:"?",status:typeof r.status=="string"?r.status:"?",totalSpawned:typeof r.totalSpawned=="number"?r.totalSpawned:0,endedAt:typeof r.endedAt=="number"?r.endedAt:0})}catch{}}return o.sort((n,t)=>t.endedAt-n.endedAt)}a(no,"readWorkflowRuns");function Ga(e){let o=G(e,"events.jsonl");if(!J(o))return[];let n=Po(o,"utf8").split(/\r?\n/).filter(r=>r.trim().length>0),t=[];for(let r of n)try{let i=JSON.parse(r);if(typeof i!="object"||i===null)continue;let l=i;if(typeof l.seq!="number"||typeof l.type!="string")continue;let c=l.data;t.push({seq:l.seq,type:l.type,...typeof c=="object"&&c!==null?{data:c}:{}})}catch{}return t}a(Ga,"readWorkflowEvents");function Xa(e){return Array.isArray(e)?e.filter(o=>typeof o=="string"):[]}a(Xa,"readStringArray");function To(e){return typeof e=="string"&&e.trim().length>0?e:void 0}a(To,"readNonEmptyString");function ms(e,o){let n=o?To(o.scriptSnapshotPath):G(e,"script.js"),t=o?To(o.manifestSnapshotPath):G(e,"manifest.json");return!n||!t?!1:J(n)&&J(t)}a(ms,"hasGeneratedWorkflowSnapshot");function ps(e,o){if(o)return ms(e,o);let n=G(e,"run.json");if(!J(n))return!1;try{let t=JSON.parse(Po(n,"utf8"));return typeof t=="object"&&t!==null?ms(e,t):!1}catch{return!1}}a(ps,"hasRerunnableGeneratedWorkflowRun");function Va(e){for(let o of[...e].reverse()){if(o.type!=="workflow_failed")continue;let n=o.data?.error;if(typeof n=="string"&&n.trim().length>0)return n}}a(Va,"readWorkflowFailure");function to(e,o){let n=G(e,o),t=G(n,"run.json"),r=Ga(n),i=Va(r);if(!(!J(t)&&r.length===0)){if(!J(t))return{runId:o,workflow:"?",status:i?"failed":"running",totalSpawned:r.filter(l=>l.type==="agent_spawned").length,eventCount:r.length,runDir:n,canRerun:!1,artifacts:[],events:r,...i?{error:i}:{}};try{let l=JSON.parse(Po(t,"utf8")),c=To(l.scriptSnapshotPath),d=To(l.manifestSnapshotPath);return{runId:o,workflow:typeof l.workflow=="string"?l.workflow:"?",status:typeof l.status=="string"?l.status:"?",totalSpawned:typeof l.totalSpawned=="number"?l.totalSpawned:0,eventCount:r.length,runDir:n,canRerun:ps(n,l),...c?{scriptSnapshotPath:c}:{},...d?{manifestSnapshotPath:d}:{},...typeof l.startedAt=="number"?{startedAt:l.startedAt}:{},...typeof l.endedAt=="number"?{endedAt:l.endedAt}:{},...i?{error:i}:{},artifacts:Xa(l.artifacts),events:r}}catch{return{runId:o,workflow:"?",status:i?"failed":"unknown",totalSpawned:r.filter(l=>l.type==="agent_spawned").length,eventCount:r.length,runDir:n,canRerun:!1,artifacts:[],events:r,...i?{error:i}:{}}}}}a(to,"readWorkflowRunDetail");function oo(e){return e==="completed"?A.green("ok"):e==="failed"?A.red("x"):e==="running"?A.cyan("run"):e==="paused"?A.yellow("pause"):e==="stopped"?A.dim("stop"):e==="denied"?A.dim("deny"):e==="cancelled"?A.dim("cancel"):A.dim("-")}a(oo,"statusIcon");function Un(e){return Ba.has(e)}a(Un,"isTerminalWorkflowStatus");function ws(e){if(!e)return;let o=[];return e.displayName&&e.displayName!==e.workflowName&&o.push(`display: ${e.displayName}`),e.source&&o.push(`source: ${e.source}`),e.savedWorkflowName&&o.push(`saved: ${e.savedWorkflowName}`),e.revisionOf&&o.push(`revision of: ${e.revisionOf}`),o.length>0?o.join(", "):void 0}a(ws,"formatProcessListMeta");function Fn(e,o={}){if(e.length===0)return" (no workflow runs yet)";let n=o.limit===void 0?void 0:Math.max(1,Math.floor(o.limit)),t=n===void 0?e:e.slice(0,n);if(o.processSnapshots){let i=t.map(l=>{let c=ws(o.processSnapshots?.get(l.runId));return` ${oo(l.status)} ${A.cyan(l.workflow)} ${A.dim(l.runId)} - ${l.status} (${l.totalSpawned} agents)${c?A.dim(` [${c}]`):""}`});return o.showLimitHint===!0&&n!==void 0&&e.length>t.length&&i.push(A.dim(` Showing ${t.length} of ${e.length} persisted runs. Use /workflow runs --all to show all.`)),i.join(`
|
|
85
|
+
`)}let r=t.map(i=>` ${oo(i.status)} ${A.cyan(i.workflow)} ${A.dim(i.runId)} \u2014 ${i.status} (${i.totalSpawned} agents)`);return o.showLimitHint===!0&&n!==void 0&&e.length>t.length&&r.push(A.dim(` Showing ${t.length} of ${e.length} persisted runs. Use /workflow runs --all to show all.`)),r.join(`
|
|
86
|
+
`)}a(Fn,"formatRunsList");function jn(e,o={}){return e.length===0?" (no active workflow runs)":o.processSnapshots?e.map(n=>{let t=ws(o.processSnapshots?.get(n.runId));return` ${oo(n.status)} ${A.cyan(n.workflow)} ${A.dim(n.runId)} - ${n.status} (${n.totalSpawned} agents, ${n.eventCount} events)${t?A.dim(` [${t}]`):""}`}).join(`
|
|
87
|
+
`):e.map(n=>` ${oo(n.status)} ${A.cyan(n.workflow)} ${A.dim(n.runId)} - ${n.status} (${n.totalSpawned} agents, ${n.eventCount} events)`).join(`
|
|
88
|
+
`)}a(jn,"formatManagedRunsList");function Pe(e){return e.status==="running"||e.status==="paused"}a(Pe,"isActiveManagedWorkflowRun");function Hn(e){return e.length===0?" (no workflow runs match the cleanup rule)":e.map(o=>` ${oo(o.status)} ${A.cyan(o.workflow)} ${A.dim(o.runId)} - ${o.status}`).join(`
|
|
89
|
+
`)}a(Hn,"formatWorkflowPruneCandidates");function Bn(e,o){return e.filter(Pe)[0]?.runId??e[0]?.runId??o[0]?.runId}a(Bn,"selectDefaultWorkflowRunId");function qn(e){return e.find(Pe)?.runId}a(qn,"selectDefaultActiveWorkflowRunId");function gs(e){if(e!==void 0)return typeof e=="number"?new Date(e).toLocaleString():e}a(gs,"formatTime");function Ja(e,o=10){let n=e.map(No).filter(t=>t!==void 0);return n.slice(Math.max(0,n.length-o))}a(Ja,"formatRecentWorkflowEvents");function Kn(e,o){return o?.canRerun??(e?.runDir?ps(e.runDir):!1)}a(Kn,"canRerunWorkflowRun");function Ya(e){return e?e.artifacts.map(o=>({name:o,path:G(e.runDir,"artifacts",`${zt(o)}.json`)})):[]}a(Ya,"workflowArtifactRefs");function zn(e,o){return o?`/workflow show ${e} | /workflow rerun ${e}`:`/workflow show ${e}`}a(zn,"formatWorkflowNextActions");function hs(e,o){return o?`Use /workflow show ${e} for events. /workflow rerun ${e} repeats the saved workflow script.`:`Use /workflow show ${e} for events.`}a(hs,"formatWorkflowFailureAction");function Gn(e,o,n={}){let t=n.processSnapshot;if(!e&&!o&&!t)return" (unknown workflow run)";let r=t?.workflowName??e?.workflow??o?.workflow??"?",i=t?.runId??e?.runId??o?.runId??"?",l=t?.status??e?.status??o?.status??"?",c=t?.progress.spawnedAgents??e?.totalSpawned??o?.totalSpawned??0,d=e?.eventCount??o?.eventCount??0,u=e?.runDir??o?.runDir??"",m=gs(e?.startedAt??o?.startedAt??t?.startedAt),f=t&&t.status!=="running"&&t.status!=="paused"?t.updatedAt:void 0,h=gs(e?.endedAt??o?.endedAt??f),k=t?.error??e?.error??o?.error,y=o?.artifacts??t?.artifacts?.map(ae=>ae.name)??[],v=Ya(o),g=e?.resultText,I=n.full===!0||g===void 0?eo(v,pe(r),{full:n.full===!0}):void 0,x=n.full===!0?I??g??t?.resultSummary:g!==void 0?re(g):t?.resultSummary!==void 0?re(t.resultSummary):I,D=x?Ro(x,i,pe(x)):void 0,F=n.full===!0||!x||!_n(x)?"result:":"result preview:",B=o?Ja(o.events):[],lo=Kn(e,o);return[` ${A.cyan(r)} ${A.dim(i)}`,...t?.displayName&&t.displayName!==r?[` display name: ${t.displayName}`]:[],` status: ${l}`,...t?.source?[` source: ${t.source}`]:[],...t?.savedWorkflowName?[` saved workflow: ${t.savedWorkflowName}`]:[],...t?.sourceRunId?[` source run: ${t.sourceRunId}`]:[],...t?.sourceWorkflowName?[` source workflow: ${t.sourceWorkflowName}`]:[],...t?.revisionOf?[` revision of: ${t.revisionOf}`]:[],` agents: ${c}`,` events: ${d}`,...m?[` started: ${m}`]:[],...h?[` ended: ${h}`]:[],...u?[` run dir: ${u}`]:[],...y.length>0?[` artifacts: ${y.join(", ")}`]:[],...k?[` error: ${k}`]:[],...D?["",` ${F}`,...D.split(`
|
|
90
|
+
`).map(ae=>` ${ae}`)]:[],...B.length>0?[""," recent events:",...B.map(ae=>` ${ae.trimEnd()}`)]:[],"",` next: ${zn(i,lo)}`].join(`
|
|
91
|
+
`)}a(Gn,"formatWorkflowRunSnapshot");function Xn(e){return{project:G(e,".kodax","workflows"),personal:_("workflows")}}a(Xn,"savedWorkflowDirs");async function ys(e,o){return new Set((await xe(e)).map(t=>t.name)).has(o)?`${o}-revision-${Date.now().toString(36)}`:o}a(ys,"nextRevisionWorkflowName");function ks(e){let o=e.resolution.kind==="run"?e.resolution.runId:e.capsule.provenance?.fromRunId,n=e.resolution.kind==="saved"?e.resolution.savedWorkflow.name:e.capsule.provenance?.fromWorkflowName,t=e.resolution.kind==="run"?e.resolution.runId:e.resolution.kind==="saved"?e.resolution.savedWorkflow.name:void 0;return{...o!==void 0?{fromRunId:o}:{},...n!==void 0?{fromWorkflowName:n}:{},...t!==void 0?{revisionOf:t}:{},...e.replacesWorkflowName!==void 0?{replacesWorkflowName:e.replacesWorkflowName}:{},createdAt:new Date().toISOString(),kodaxVersion:er}}a(ks,"buildWorkflowRevisionProvenance");function Vn(e){return e.length===0?" (no saved workflows)":e.map(o=>` ${A.cyan(o.name)} ${A.dim(`(${o.source}, ${o.execution}: ${o.path})`)}`).join(`
|
|
92
|
+
`)}a(Vn,"formatSavedList");function vs(e){return/^[a-zA-Z0-9._-]{1,120}$/.test(e)&&!e.startsWith(".")&&!e.includes("..")}a(vs,"isSafeWorkflowRunId");function we(e){if(e.confirm)return e.confirm;let o=e.readline;if(o)return n=>new Promise(t=>{o.question(`${n} (y/N) `,r=>t(/^y(es)?$/i.test(r.trim())))})}a(we,"resolveConfirm");function Za(e){console.log(A.red(`
|
|
93
|
+
[workflow] invalid run id: ${e||"<empty>"}
|
|
94
|
+
`))}a(Za,"printInvalidRunId");function se(e){return vs(e)?!0:(Za(e),!1)}a(se,"ensureSafeRunId");function Wo(){let e=Qa(process.cwd());return{isGitRepo:e,worktreeCapable:e}}a(Wo,"currentWorkflowPreflightEnv");function Qa(e){let o=e;for(;;){if(J(G(o,".git")))return!0;let n=Ha(o);if(n===o)return!1;o=n}}a(Qa,"hasGitMarker");function _o(e){console.log(A.red(`
|
|
95
|
+
[workflow] capsule preflight failed:`));for(let o of e.issues)console.log(A.red(` - ${o.requirement}: ${o.message}`));console.log()}a(_o,"printPreflightFailure");function Lo(e){let o=e.issues.filter(n=>n.severity==="warning");if(o.length!==0){console.log(A.yellow(`
|
|
96
|
+
[workflow] capsule preflight warnings:`));for(let n of o)console.log(A.yellow(` - ${n.requirement}: ${n.message}`));console.log()}}a(Lo,"printPreflightWarnings");async function $s(e,o){if(e.execution==="trusted-local"&&!await o(`Run local workflow file? This EXECUTES local code:
|
|
97
|
+
${e.path}`)){console.log(A.dim(`Workflow cancelled.
|
|
98
|
+
`));return}try{let n={source:`saved:${e.source}`,sandbox:e.execution,mayUseWorktree:!1},t,r;if(e.execution==="capability-generated"){let l=await Fe(e.path),c=je(l,Wo());if(!c.ok){_o(c);return}Lo(c),n={source:`saved:${e.source}`,sandbox:e.execution,mayUseWorktree:l.manifest.mayUseWorktree===!0,rawScriptPath:e.path,rawScript:l.source},t={manifest:l.manifest,source:l.source},r=l.provenance}return{module:await mo(e.path),approvalContext:n,...t!==void 0?{scriptSnapshot:t}:{},...r!==void 0?{provenance:r}:{}}}catch(n){let t=n instanceof Error?n.message:String(n);console.log(A.red(`
|
|
99
|
+
[workflow] failed to load ${e.path}: ${t}
|
|
100
|
+
`));return}}a($s,"prepareSavedWorkflow");function Jn(e){let o=e.data?.status;return typeof o=="string"?o:void 0}a(Jn,"workflowEventStatus");function No(e){let o=e.data?.name??e.data?.taskId??"",n=Jn(e);switch(e.type){case"phase_started":return` > phase: ${e.data?.name??""}`;case"phase_finished":return` done phase: ${e.data?.name??""}`;case"agent_spawned":return` + ${o}`;case"agent_completed":return n==="failed"?` failed ${o}`:` done ${o}`;case"agent_stopped":return` stopped ${o}`;case"workflow_log":return` log ${e.data?.message??""}`;case"artifact_written":return` artifact ${e.data?.name??""}`;case"synthesis_completed":return" synthesis complete";case"workflow_completed":return" workflow completed";case"workflow_stopped":return" workflow stopped";case"workflow_failed":return` workflow failed: ${e.data?.error??"unknown error"}`;default:return}}a(No,"formatWorkflowEvent");function Ss(e){let o=No(e);o&&console.log(A.dim(o))}a(Ss,"renderWorkflowEvent");import Do from"chalk";import el from"string-width";var ol=9;function nl(e,o=ol){let n=el(e);return n>=o?e:`${e}${" ".repeat(o-n)}`}a(nl,"padWorkflowLiveSymbol");function Rs(e,o={}){let n=e.items.filter(f=>f.kind==="agent"),t=n.filter(f=>f.status==="running").map(f=>f.title),r=n.filter(f=>f.status==="completed").length,i=n.filter(f=>f.status==="failed").length,l=n.filter(f=>f.status==="cancelled").length,c=e.status==="completed"?"completed":e.status==="failed"?"failed":e.status==="cancelled"?"stopped":"running",d=e.activePhaseId===void 0?void 0:e.items.find(f=>f.id===e.activePhaseId)?.title,u=Date.parse(e.startedAt),m=o.message??e.latestMessage;return{runId:e.runId,workflow:e.displayName??e.workflowName,status:c,...d!==void 0?{phase:d}:{},...e.activePhaseIndex!==void 0?{phaseIndex:e.activePhaseIndex}:{},...e.phaseCount!==void 0?{phaseTotal:e.phaseCount}:{},...Number.isFinite(u)?{startedAt:u}:{},elapsedMs:e.elapsedMs,activeAgents:t,totalSpawned:e.progress.spawnedAgents,...e.progress.plannedItems!==void 0?{plannedAgents:e.progress.plannedItems}:{},...e.progress.agentCap!==void 0?{agentCap:e.progress.agentCap}:{},...e.tokens!==void 0?{tokenBudgetSpent:e.tokens.spent}:{},...e.tokens?.total!==void 0?{tokenBudgetTotal:e.tokens.total}:{},completedAgents:r,failedAgents:i,stoppedAgents:l,...m!==void 0?{message:m}:{},...o.locale!==void 0?{locale:o.locale}:{}}}a(Rs,"workflowLiveSnapshotFromProcess");function ef(e){return!e.shouldRender||e.rows.length===0?[]:e.rows.map(o=>`${nl(o.symbol)}${o.text}`)}a(ef,"formatWorkflowLiveViewModelForTranscript");var tl=6,bs=2,xs={en:{workflow:"workflow",phase:"phase",agent:"agent",more:"more",progress:"progress",waiting:"waiting",hint:"hint",finished:"finished",failed:"failed",stopped:"stopped",started:"started",cap:"cap",budget:"budget",spent:"spent",waitingForFirstAgent:"waiting for first agent",showStopHint:a(e=>`show: /workflow show ${e} | stop: /workflow stop ${e}`,"showStopHint"),activeAgents:a(e=>`${e} active agent${e===1?"":"s"}`,"activeAgents"),moreActive:a(e=>`${e} more active agent${e===1?"":"s"}`,"moreActive")},zh:{workflow:"\u5DE5\u4F5C\u6D41",phase:"\u9636\u6BB5",agent:"\u667A\u80FD\u4F53",more:"\u66F4\u591A",progress:"\u8FDB\u5EA6",waiting:"\u7B49\u5F85",hint:"\u63D0\u793A",finished:"\u5B8C\u6210",failed:"\u5931\u8D25",stopped:"\u505C\u6B62",started:"\u5DF2\u542F\u52A8",cap:"\u4E0A\u9650",budget:"\u9884\u7B97",spent:"\u5DF2\u7528",waitingForFirstAgent:"\u7B49\u5F85\u7B2C\u4E00\u4E2A\u667A\u80FD\u4F53\u542F\u52A8",showStopHint:a(e=>`\u67E5\u770B: /workflow show ${e} | \u505C\u6B62: /workflow stop ${e}`,"showStopHint"),activeAgents:a(e=>`${e} \u4E2A\u667A\u80FD\u4F53\u8FD0\u884C\u4E2D`,"activeAgents"),moreActive:a(e=>`\u53E6\u6709 ${e} \u4E2A\u8FD0\u884C\u4E2D`,"moreActive")}},rl={shouldRender:!1,workflow:"",runId:"",activeCount:0,totalSpawned:0,completedAgents:0,failedAgents:0,stoppedAgents:0,rows:[]};function sl(e){return e.length>14?`${e.slice(0,14)}...`:e}a(sl,"shortRunId");function Oo(e){return e==="zh"?xs.zh:xs.en}a(Oo,"workflowLiveLabels");function il(e,o){let n=Math.max(0,Math.floor(e)),t=Math.floor(n/1e3),r=t%60,i=Math.floor(t/60),l=i%60,c=Math.floor(i/60);return o==="zh"?c>0?`${c}\u5C0F\u65F6${String(l).padStart(2,"0")}\u5206`:l>0?`${l}\u5206${String(r).padStart(2,"0")}\u79D2`:`${r}\u79D2`:c>0?`${c}h${l}m${r}s`:l>0?`${l}m${r}s`:`${r}s`}a(il,"formatElapsedMs");function As(e){let o=Math.max(0,Math.floor(e));return o>=1e6?`${(o/1e6).toFixed(1).replace(/\.0$/,"")}M`:o>=1e3?`${(o/1e3).toFixed(1).replace(/\.0$/,"")}k`:String(o)}a(As,"formatTokenCount");function al(e){if(e.tokenBudgetSpent===void 0)return;let o=Oo(e.locale),n=As(e.tokenBudgetSpent);if(e.tokenBudgetTotal!==void 0&&Number.isFinite(e.tokenBudgetTotal)){let t=As(e.tokenBudgetTotal);return e.tokenBudgetSpent<=0?`${o.budget} ${t} tokens`:`${o.spent} ${n}/${t} tokens`}if(!(e.tokenBudgetSpent<=0))return`${o.spent} ${n} tokens`}a(al,"formatWorkflowTokenUsage");function ll(e,o){let n=[],t=e.startedAt===void 0?e.elapsedMs:o-e.startedAt;t!==void 0&&n.push(il(t,e.locale));let r=al(e);return r!==void 0&&n.push(r),n}a(ll,"formatWorkflowHeaderMetrics");function cl(e){let o=Oo(e.locale),n=e.completedAgents+e.failedAgents+e.stoppedAgents;if(e.totalSpawned===0&&n===0)return;let t=Is(e,n),r=[];e.activeAgents.length>0&&r.push(o.activeAgents(e.activeAgents.length)),e.plannedAgents!==void 0&&r.push(`${o.started} ${e.totalSpawned}`),e.failedAgents>0&&r.push(`${e.failedAgents} ${o.failed}`),e.stoppedAgents>0&&r.push(`${e.stoppedAgents} ${o.stopped}`),e.agentCap!==void 0&&r.push(`${o.cap} ${e.agentCap}`);let i=r.length===0?"":e.locale==="zh"?`\uFF08${r.join("\uFF0C")}\uFF09`:` (${r.join(", ")})`;return`${n}/${t} ${o.finished}${i}`}a(cl,"formatWorkflowProgress");function dl(e){let o=Oo(e.locale);if(e.totalSpawned===0)return o.waiting;let n=e.activeAgents.length,t=Is(e),r=e.locale==="zh"?`${n}/${t} \u4E2A\u667A\u80FD\u4F53\u8FD0\u884C\u4E2D`:`${n}/${t} active agent${n===1?"":"s"}`,i=[];return e.failedAgents>0&&i.push(`${e.failedAgents} ${o.failed}`),e.stoppedAgents>0&&i.push(`${e.stoppedAgents} ${o.stopped}`),i.length===0?r:e.locale==="zh"?`${r}\uFF0C${i.join("\uFF0C")}`:`${r}, ${i.join(", ")}`}a(dl,"formatWorkflowCounter");function Is(e,o){let n=o??e.completedAgents+e.failedAgents+e.stoppedAgents;return Math.max(e.plannedAgents??0,e.totalSpawned,n)}a(Is,"workflowProgressDenominator");function ul(e){if(e.phase)return e.phaseIndex!==void 0&&e.phaseTotal!==void 0&&e.phaseIndex>0&&e.phaseTotal>0?`${e.phaseIndex}/${e.phaseTotal} ${e.phase}`:e.phase}a(ul,"formatWorkflowPhase");function of(e,o=Date.now()){if(!e||e.status!=="running")return rl;let n=[],t=Oo(e.locale),r=ll(e,o),i=r.length===0?"":` \xB7 ${r.join(" \xB7 ")}`;n.push({kind:"header",id:"header",symbol:t.workflow,symbolColor:e.failedAgents>0?"red":"cyan",text:`${e.workflow} (${sl(e.runId)}) - ${t.activeAgents(e.activeAgents.length)}${i}`,isActive:!0});let l=ul(e);l&&n.push({kind:"phase",id:"phase",symbol:t.phase,symbolColor:"cyan",text:l,isActive:!0});let c=e.activeAgents.length>bs?1:bs,d=e.activeAgents.slice(0,c);for(let[h,k]of d.entries())n.push({kind:"agent",id:`active-${h}-${k}`,symbol:t.agent,symbolColor:"cyan",text:k,isActive:!0});let u=e.activeAgents.length-d.length;u>0&&n.push({kind:"summary",id:"more-active",symbol:t.more,symbolColor:"dim",text:t.moreActive(u),isActive:!1});let m=cl(e);m&&n.push({kind:"summary",id:"progress",symbol:t.progress,symbolColor:e.failedAgents>0?"red":"green",text:m,isActive:!1}),e.totalSpawned===0&&e.activeAgents.length===0&&n.push({kind:"summary",id:"waiting",symbol:t.waiting,symbolColor:"dim",text:t.waitingForFirstAgent,isActive:!1}),n.push({kind:"hint",id:"controls",symbol:t.hint,symbolColor:"dim",text:e.message??t.showStopHint(e.runId),isActive:!1});let f=n.slice(0,tl);return{shouldRender:!0,workflow:e.workflow,runId:e.runId,...e.phase!==void 0?{phase:e.phase}:{},...e.phaseIndex!==void 0?{phaseIndex:e.phaseIndex}:{},...e.phaseTotal!==void 0?{phaseTotal:e.phaseTotal}:{},activeCount:e.activeAgents.length,totalSpawned:e.totalSpawned,...e.plannedAgents!==void 0?{plannedAgents:e.plannedAgents}:{},completedAgents:e.completedAgents,failedAgents:e.failedAgents,stoppedAgents:e.stoppedAgents,counterText:dl(e),rows:f}}a(of,"buildWorkflowLiveViewModel");function fl(e,o){return o!==0?!1:e.name==="WorkflowScriptExecutionError"||/restricted workflow script|workflow generation source|workflow command .* must|unsupported workflow command/i.test(e.message)}a(fl,"isWorkflowHarnessFailure");function Cs(e){let o=hs(e.runId,e.canRerun);return fl(e.error,e.totalSpawned)?[`Workflow harness failed before launching child agents (${e.runId}): ${e.error.message}`,"This points to an invalid generated workflow script or saved capsule, not a failed child-agent task.",o].join(`
|
|
101
|
+
`):[`Workflow failed (${e.runId}): ${e.error.message}`,o].join(`
|
|
102
|
+
`)}a(Cs,"formatWorkflowFailedMessage");function Es(e){let o=e?.usage;if(typeof o!="object"||o===null)return 0;let n=o,t=n.totalTokens;if(typeof t=="number"&&Number.isFinite(t)&&t>0)return t;let r=n.inputTokens,i=n.outputTokens,l=typeof r=="number"&&Number.isFinite(r)&&r>0?r:0,c=typeof i=="number"&&Number.isFinite(i)&&i>0?i:0;return l+c}a(Es,"readWorkflowEventUsageTokens");function L(e,o){if(e.onWorkflowRunMessage){e.onWorkflowRunMessage(o);return}if(o.type==="error"){console.log(Do.red(`
|
|
103
|
+
${o.text}
|
|
104
|
+
`));return}if(o.type==="success"){console.log(Do.green(`
|
|
105
|
+
${o.text}
|
|
106
|
+
`));return}if(o.type==="event"){console.log(Do.dim(o.text));return}if(o.type==="assistant"){console.log(`
|
|
107
|
+
${o.text}
|
|
108
|
+
`);return}console.log(Do.dim(`
|
|
109
|
+
${o.text}
|
|
110
|
+
`))}a(L,"emitWorkflowRunMessage");function Me(e,o,n={}){let t=n.presentation==="agentic"?Co(n.runId??"current"):void 0,r=!1;return i=>{if(r&&(i.type==="agent_completed"||i.type==="agent_summary_updated"))return;o?.onEvent(i);let l=No(i);if(e.onWorkflowRunMessage){if(l&&L(e,{type:"event",text:l}),t){let c=t(i,n.locale??"en");c&&L(e,{type:"assistant",text:c,final:!1})}(i.type==="workflow_completed"||i.type==="workflow_failed"||i.type==="workflow_stopped")&&(r=!0);return}(i.type==="workflow_completed"||i.type==="workflow_failed"||i.type==="workflow_stopped")&&(r=!0),l&&Ss(i)}}a(Me,"workflowEventSink");function We(e,o,n){return e.subscribeWorkflowProcess(t=>{t.snapshot.runId===n&&o.onProcessEvent(t)})}a(We,"subscribeWorkflowLiveProcess");function he(e,o,n,t="en"){let r=Date.now(),i=new Map,l,c=0,d=0,u=0,m=0,f=0,h=!1,k=n.phases??[],y=n.tokenBudget!==void 0&&Number.isFinite(n.tokenBudget)?n.tokenBudget:void 0,v=a((g,I)=>{let x=l===void 0?-1:k.indexOf(l),D=x>=0?x+1:void 0,F=k.length>0?k.length:void 0;e.onWorkflowRunUpdate?.({runId:o,workflow:n.name,status:g,...l!==void 0?{phase:l}:{},...D!==void 0?{phaseIndex:D}:{},...F!==void 0?{phaseTotal:F}:{},startedAt:r,elapsedMs:Math.max(0,Date.now()-r),activeAgents:[...i.values()],totalSpawned:c,...n.plannedAgents!==void 0?{plannedAgents:n.plannedAgents}:{},...n.maxAgents!==void 0?{agentCap:n.maxAgents}:{},tokenBudgetSpent:f,...y!==void 0?{tokenBudgetTotal:y}:{},completedAgents:d,failedAgents:u,stoppedAgents:m,...I!==void 0?{message:I}:{},locale:t})},"emit");return{running:a(g=>{h||v("running",g)},"running"),onProcessEvent:a(g=>{if(h&&g.type!=="workflow_finished")return;let I=g.snapshot.status;(g.type==="workflow_finished"||I==="completed"||I==="failed"||I==="cancelled")&&(h=!0);let x=g.type==="workflow_updated"?g.message:void 0;e.onWorkflowRunUpdate?.(Rs(g.snapshot,x===void 0?{locale:t}:{locale:t,message:x}))},"onProcessEvent"),onEvent:a(g=>{if(!h)switch(g.type){case"phase_started":{let I=g.data?.name;l=typeof I=="string"?I:l,v("running");break}case"agent_spawned":{let I=typeof g.data?.taskId=="string"?g.data.taskId:`task-${c+1}`,x=typeof g.data?.name=="string"?g.data.name:I;i.set(I,x),c+=1,v("running");break}case"agent_completed":{let I=typeof g.data?.taskId=="string"?g.data.taskId:void 0;I&&i.delete(I),f+=Es(g.data),Jn(g)==="failed"?u+=1:d+=1,v("running");break}case"agent_stopped":{let I=typeof g.data?.taskId=="string"?g.data.taskId:void 0;I&&i.delete(I),f+=Es(g.data),m+=1,v("running");break}case"synthesis_completed":{v("running","synthesis complete");break}default:break}},"onEvent"),complete:a((g,I)=>{h||(h=!0,v(g,I))},"complete")}}a(he,"createWorkflowLiveUpdateEmitter");function ye(e,o,n,t,r={}){e.done.then(i=>{if(i.kind==="failed"){if(e.getSnapshot?.()?.status==="stopped"){t?.complete("stopped","Workflow stopped by user.");return}t?.complete("failed",i.error.message),L(o,{type:"error",text:Cs({runId:n,error:i.error,canRerun:r.canRerun===!0,totalSpawned:i.state.totalSpawned})});return}if(i.kind==="completed"){let l=r.locale??"en",c={full:r.presentation==="agentic"},d=re(i.result,c)??eo(i.state.artifacts,l,c),u=d===void 0?Io(i.state.events,c):void 0,m=d??u;if(t?.complete("completed",m?"completed with result":"completed"),r.presentation==="agentic"){L(o,{type:"assistant",text:Ln({runId:n,totalSpawned:i.state.totalSpawned,...m!==void 0?{resultText:m}:{},...d===void 0&&u!==void 0?{isFallbackPreview:!0}:{},locale:l}),final:!0});return}L(o,{type:"success",text:[`Workflow completed (${i.state.totalSpawned} agents, run ${n}).`,`Use /workflow show ${n} for the event timeline.`].join(`
|
|
111
|
+
`)}),m&&L(o,{type:"info",text:`Workflow result:
|
|
112
|
+
${m}`})}}).catch(i=>{let l=i instanceof Error?i.message:String(i);if(e.getSnapshot?.()?.status==="stopped"){t?.complete("stopped","Workflow stopped by user.");return}t?.complete("failed",l),L(o,{type:"error",text:Cs({runId:n,error:i instanceof Error?i:new Error(l),canRerun:r.canRerun===!0})})})}a(ye,"observeManagedWorkflowDone");function ie(e,o){if(e.onBuilderEvent?.(o),o.stage==="failed"){L(e.callbacks,{type:"error",text:`Workflow builder failed: ${o.message}`});return}!e.onBuilderEvent&&(o.stage==="started"||o.stage==="generating"||o.stage==="validating"||o.stage==="ready")&&console.log(Uo.dim(`
|
|
113
|
+
[workflow] ${o.message}
|
|
114
|
+
`))}a(ie,"emitWorkflowBuilderEvent");function ro(e){return{source:e.source,displayName:e.displayName,...e.goal!==void 0?{goal:e.goal}:{},...e.savedWorkflowName!==void 0?{savedWorkflowName:e.savedWorkflowName}:{},...e.sourceRunId!==void 0?{sourceRunId:e.sourceRunId}:{},...e.sourceWorkflowName!==void 0?{sourceWorkflowName:e.sourceWorkflowName}:{},...e.revisionOf!==void 0?{revisionOf:e.revisionOf}:{}}}a(ro,"buildWorkflowProcessMetadata");async function Yn(e){let o=e.approval==="required"?we(e.callbacks):void 0;if(e.approval==="required"&&!o)return console.log(Uo.red(`
|
|
115
|
+
[workflow] refusing to generate a workflow without an interactive approval channel.
|
|
116
|
+
`)),"failed";let n=e.callbacks.createKodaXOptions;if(!n)return console.log(Uo.red(`
|
|
117
|
+
[workflow] cannot generate - REPL options unavailable in this context.
|
|
118
|
+
`)),"failed";let t=pe(e.request),r,i;try{ie(e,{stage:"started",message:"Workflow builder started"}),ie(e,{stage:"generating",message:"Workflow - generating harness"}),r=n(),i=await(e.generateWorkflow??go)({request:e.request,options:r}),ie(e,{stage:"validating",message:"Workflow - validating harness"})}catch(g){let I=g instanceof Error?g.message:String(g);return ie(e,{stage:"failed",message:I}),"failed"}if(i.kind==="declined")return ie(e,{stage:"declined",message:i.reason}),console.log(Uo.dim(`
|
|
119
|
+
Workflow not created: ${i.reason}
|
|
120
|
+
`)),"declined";ie(e,{stage:"ready",message:"Workflow - harness ready"});let l=e.presentation??"command",c=ce(i.module);l!=="agentic"&&L(e.callbacks,{type:"info",text:`Generated workflow: ${i.approvalSummary}`});let d=me(process.cwd()).key,u=e.runBaseDir??_("workflow-runs",d),m=e.runManager??Ae(),f=`run-${Date.now().toString(36)}`,h=ml(u,f);if(o){if(!await o(Y(c,{source:e.sourceLabel??"generated",sandbox:"capability-generated",mayUseWorktree:i.manifest.mayUseWorktree===!0,rawScript:i.scriptSnapshot.source})))return ie(e,{stage:"cancelled",message:"Workflow cancelled"}),L(e.callbacks,{type:"info",text:"Workflow cancelled."}),"cancelled"}else l!=="agentic"&&(L(e.callbacks,{type:"info",text:Y(c,{source:e.sourceLabel??"generated",sandbox:"capability-generated",mayUseWorktree:i.manifest.mayUseWorktree===!0})}),L(e.callbacks,{type:"info",text:"AMAW auto-start: capability-isolated generated workflow; normal permission gates still apply."}));l==="agentic"?L(e.callbacks,{type:"assistant",text:Nn({runId:f,summary:c,approvalSummary:i.approvalSummary,locale:t}),final:!1}):L(e.callbacks,{type:"info",text:`Started workflow ${i.module.meta.name} (${f}). Use /workflow show ${f} for status.`});let k=he(e.callbacks,f,i.module.meta,t);k.running(`Use /workflow show ${f} for status or /workflow stop ${f} to stop.`);let y=We(m,k,f),v=m.startFromOptions({module:i.module,args:{request:e.request},options:r,runId:f,runDir:h,scriptSnapshot:i.scriptSnapshot,processMetadata:ro({source:e.processSource??"command",displayName:i.module.meta.name,goal:e.request}),onEvent:Me(e.callbacks,void 0,{presentation:e.presentation??"command",locale:t,runId:f})});return v.done.finally(y),ie(e,{stage:"launched",message:`Workflow ${i.module.meta.name} started`}),ye(v,e.callbacks,f,k,{canRerun:!0,presentation:l,locale:t}),"started"}a(Yn,"startGeneratedWorkflowFromRequest");function Zn(e){let o=e[0]?.toLowerCase();if(o==="help"||o==="--help"||o==="-h")return{kind:"help"};if(!o||o==="list")return{kind:"list"};if(o==="runs")return{kind:"runs",rawArgs:e.slice(1)};if(o==="show"){let n=e.slice(1),t=n.includes("--full"),r=n.find(i=>i!=="--full")??"";return t?{kind:"show",runId:r,full:!0}:{kind:"show",runId:r}}if(o==="pause")return{kind:"pause",runId:e[1]??""};if(o==="resume")return{kind:"resume",runId:e[1]??""};if(o==="stop")return{kind:"stop",runId:e[1]??""};if(o==="delete"){let n=e.slice(1),t=n.includes("--force"),r=n.find(i=>i!=="--force")??"";return t?{kind:"delete",runId:r,force:!0}:{kind:"delete",runId:r}}if(o==="prune")return{kind:"prune",rawArgs:e.slice(1)};if(o==="save")return{kind:"save",runId:e[1]??"",name:e[2]??""};if(o==="rename")return{kind:"rename",target:e[1]??"",newName:e.slice(2).join(" ").trim()};if(o==="revise"){let n=e.slice(1),t=n.includes("--replace"),r=n.filter(i=>i!=="--replace");return{kind:"revise",target:r[0]??"",request:r.slice(1).join(" ").trim(),...t?{replace:!0}:{}}}return o==="rerun"?{kind:"rerun",runId:e[1]??"",rawArgs:e.slice(2).join(" ").trim()}:o==="create"?{kind:"create",request:e.slice(1).join(" ").trim()}:{kind:"start",name:e[0],rawArgs:e.slice(1).join(" ").trim()}}a(Zn,"parseWorkflowInvocation");function so(e){let o=e.trim();if(!o)return{};if(o.startsWith("{"))try{return JSON.parse(o)}catch{return{question:o}}return{question:o}}a(so,"parseWorkflowArgs");function Qn(e){return["Revise this existing KodaX dynamic workflow capsule.","Return a complete revised workflow, not a patch.","Preserve the reusable workflow intent, safety requirements, and compatible args shape unless the requested change explicitly requires otherwise.","",`Target: ${e.target}`,"","Original manifest:",JSON.stringify(e.capsule.manifest,null,2),"","Original source:","```js",e.capsule.source,"```","",`Change request: ${e.changeRequest}`].join(`
|
|
121
|
+
`)}a(Qn,"buildWorkflowRevisionRequest");function Ts(e){if(!e)return;let o=Number(e);return Number.isInteger(o)&&o>=0?o:void 0}a(Ts,"parseNonNegativeInteger");function et(e){let o=!1,n=20;for(let t=0;t<e.length;t+=1){let r=e[t];if(r==="--all"){o=!0;continue}if(r==="--limit"){let i=Ts(e[t+1]);if(i===void 0||i<1)return{all:o,limit:n,error:"--limit expects a positive integer"};n=Math.min(i,200),t+=1;continue}return{all:o,limit:n,error:`unknown option: ${r??""}`}}return{all:o,limit:n}}a(et,"parseWorkflowRunsOptions");function gl(e){if(!e)return;let o=/^(\d+)([dh]?)$/i.exec(e.trim());if(!o)return;let n=Number(o[1]);return!Number.isInteger(n)||n<=0?void 0:(o[2]?.toLowerCase()||"d")==="h"?n*60*60*1e3:n*24*60*60*1e3}a(gl,"parseOlderThanMs");function ot(e){let o=!1,n,t;for(let r=0;r<e.length;r+=1){let i=e[r];if(i==="--dry-run"){o=!0;continue}if(i==="--keep"){let l=Ts(e[r+1]);if(l===void 0)return{dryRun:o,error:"--keep expects a non-negative integer"};n=l,r+=1;continue}if(i==="--older-than"){let l=gl(e[r+1]);if(l===void 0)return{dryRun:o,error:"--older-than expects a value like 7d or 24h"};t=l,r+=1;continue}return{dryRun:o,error:`unknown option: ${i??""}`}}return o&&n===void 0&&t===void 0?{dryRun:o,keep:50}:{dryRun:o,...n!==void 0?{keep:n}:{},...t!==void 0?{olderThanMs:t}:{}}}a(ot,"parseWorkflowPruneOptions");var pl=1440*60*1e3;function wl(e){return new Map(e.map(o=>[o.runId,o]))}a(wl,"processSnapshotsByRunId");function hl(e){return{dryRun:e.dryRun,...e.keep!==void 0?{keep:e.keep}:{},...e.olderThanMs!==void 0?{olderThanDays:e.olderThanMs/pl}:{}}}a(hl,"workflowPruneRetentionOptions");function yl(e,o){let n=new Map(e.map(t=>[t.runId,t]));return o.map(t=>{let r=n.get(t);return{runId:t,workflow:r?.workflow??"?",status:r?.status??"?",endedAt:r?.endedAt??0}})}a(yl,"workflowPruneCandidateSummaries");function Ms(e){return ro({source:"capsule",displayName:e.displayName,savedWorkflowName:e.savedWorkflowName,sourceRunId:e.provenance?.fromRunId,sourceWorkflowName:e.provenance?.fromWorkflowName??e.savedWorkflowName,revisionOf:e.provenance?.revisionOf})}a(Ms,"buildSavedWorkflowProcessMetadata");var Ws={name:"workflow",description:"Run a dynamic multi-agent workflow (FEATURE_217)",usage:"/workflow [help | list | runs | show | pause | resume | stop | delete | prune | rerun | save | rename | revise | create | <name> [args]]",argumentHint:"help | list | runs [--all|--limit N] | show [runId] | pause <runId> | resume <runId> | stop [runId] | delete [--force] <runId> | prune --dry-run|--keep N|--older-than Nd | rerun <runId|savedName> [args] | save <runId> <name> | rename <runId|alias|savedName> <newName> | revise [--replace] <runId|alias|savedName> <change> | create <request> | <name> [args]",detailedHelp:Eo,handler:a(async(e,o,n,t)=>{let r=Zn(e),i=me(process.cwd()).key,l=_("workflow-runs",i),c=Ae(),d=Xn(process.cwd()),u=Yt({runManager:c,runBaseDir:l,savedWorkflowDirs:d});if(r.kind==="help"){Eo();return}if(r.kind==="list"){console.log(w.bold(`
|
|
122
|
+
Built-in workflows:`)),console.log(Mo(He())),console.log(w.bold(`
|
|
123
|
+
Pattern templates:`));for(let $ of Zt())console.log(` ${w.cyan($.name)} ${w.dim(`(${$.pattern})`)} - ${$.description}`);let p=await xe(d);p.length>0&&(console.log(w.bold(`
|
|
124
|
+
Saved workflows:`)),console.log(Vn(p))),console.log(w.dim(`
|
|
125
|
+
Run one with: /workflow <name> <question or JSON args>`)),console.log(w.dim(` Show usage with: /workflow help
|
|
126
|
+
`));return}if(r.kind==="runs"){let p=et(r.rawArgs);if(p.error){console.log(w.yellow(`
|
|
127
|
+
Usage: /workflow runs [--all] [--limit N]
|
|
128
|
+
${p.error}
|
|
129
|
+
`));return}let $=wl(u.listWorkflowProcessSnapshots({activeOnly:!1})),b=c.list().filter(Pe);b.length>0&&(console.log(w.bold(`
|
|
130
|
+
Active workflow runs:`)),console.log(jn(b,{processSnapshots:$}))),console.log(w.bold(`
|
|
131
|
+
Workflow runs:`)),console.log(Fn(no(l),{limit:p.all?void 0:p.limit,showLimitHint:!p.all,processSnapshots:$})),console.log();return}if(r.kind==="show"){let p=no(l),$=r.runId||Bn(c.list(),p);if(!$){console.log(w.yellow(`
|
|
132
|
+
No workflow runs yet. Start one with /workflow create <request>.
|
|
133
|
+
`));return}if(!se($))return;let b=c.get($),P=to(l,$),E=u.getWorkflowProcessSnapshot($);console.log(w.bold(`
|
|
134
|
+
Workflow run:`)),console.log(Gn(b,P,{full:r.full===!0,...E?{processSnapshot:E}:{}})),console.log();return}if(r.kind==="pause"){if(!se(r.runId))return;let p=c.pause(r.runId);console.log(p?w.dim(`Paused workflow ${r.runId}.
|
|
135
|
+
`):w.yellow(`No running workflow ${r.runId}.
|
|
136
|
+
`));return}if(r.kind==="resume"){if(!se(r.runId))return;let p=c.resume(r.runId);console.log(p?w.dim(`Resumed workflow ${r.runId}.
|
|
137
|
+
`):w.yellow(`No paused workflow ${r.runId}.
|
|
138
|
+
`));return}if(r.kind==="stop"){let p=r.runId||qn(c.list());if(!p){console.log(w.yellow(`
|
|
139
|
+
No active workflow to stop.
|
|
140
|
+
`));return}if(!se(p))return;let $=await u.stopWorkflow(p,"stopped by user"),b=c.get(p),P=to(l,p),E=u.getWorkflowProcessSnapshot(p),O=b?.status??P?.status??E?.status,le=b?!Pe(b):P?Un(P.status):E!==void 0&&fo(E.status),H=zn(p,Kn(b,P));console.log($?w.dim(`Stopped workflow ${p}.
|
|
141
|
+
`):O&&le?w.yellow(`Workflow ${p} is already ${O}. Next: ${H}.
|
|
142
|
+
`):w.yellow(`No active workflow ${p}.
|
|
143
|
+
`));return}if(r.kind==="delete"){if(!se(r.runId))return;if(await u.deleteWorkflowRun(r.runId,{force:r.force})){console.log(w.dim(`
|
|
144
|
+
Deleted workflow run ${r.runId}${r.force?" with --force":""}.
|
|
145
|
+
`));return}let $=c.getWorkflowProcessSnapshot(r.runId),b=u.getWorkflowProcessSnapshot(r.runId);if(!b&&!Ps(X(l,r.runId,"run.json"))){console.log(w.yellow(`
|
|
146
|
+
No persisted workflow run ${r.runId}.
|
|
147
|
+
`));return}if($&&!fo($.status)){console.log(w.yellow(`
|
|
148
|
+
Workflow ${r.runId} is ${$.status}. Stop it before deleting the run record.
|
|
149
|
+
`));return}if(b&&!fo(b.status)){console.log(w.yellow(`
|
|
150
|
+
Workflow ${r.runId} is a non-terminal persisted ${b.status} record. If it is stale, run /workflow delete --force ${r.runId}.
|
|
151
|
+
`));return}console.log(w.yellow(`
|
|
152
|
+
Workflow ${r.runId} is not a deletable terminal run.
|
|
153
|
+
`));return}if(r.kind==="prune"){let p=ot(r.rawArgs);if(p.error){console.log(w.yellow(`
|
|
154
|
+
Usage: /workflow prune --dry-run | --keep N | --older-than Nd
|
|
155
|
+
${p.error}
|
|
156
|
+
`));return}if(!p.dryRun&&p.keep===void 0&&p.olderThanMs===void 0){console.log(w.yellow(`
|
|
157
|
+
Usage: /workflow prune --dry-run | --keep N | --older-than Nd
|
|
158
|
+
No cleanup rule was provided.
|
|
159
|
+
`));return}let $=no(l),b=await u.pruneWorkflowRuns(hl(p)),P=yl($,b.candidates);console.log(w.bold(p.dryRun?`
|
|
160
|
+
Workflow prune preview:`:`
|
|
161
|
+
Workflow prune:`)),console.log(Hn(P)),b.protectedRuns>0&&console.log(w.dim(`
|
|
162
|
+
Protected ${b.protectedRuns} active workflow run${b.protectedRuns===1?"":"s"} from pruning.`)),p.dryRun?console.log(w.dim(`
|
|
163
|
+
Dry run only. Add --keep N or --older-than Nd without --dry-run to delete.
|
|
164
|
+
`)):console.log(w.dim(`
|
|
165
|
+
Deleted ${b.deleted} workflow run${b.deleted===1?"":"s"}.
|
|
166
|
+
`));return}if(r.kind==="save"){if(!r.runId||!r.name){console.log(w.yellow(`
|
|
167
|
+
Usage: /workflow save <runId> <name>
|
|
168
|
+
`));return}if(!se(r.runId))return;try{let p=await Jt({runDir:X(l,r.runId),targetDir:d.project??X(process.cwd(),".kodax","workflows"),name:r.name});console.log(w.green(`
|
|
169
|
+
Saved workflow ${p.name} to ${p.path}
|
|
170
|
+
`))}catch(p){let $=p instanceof Error?p.message:String(p);console.log(w.red(`
|
|
171
|
+
[workflow] save failed: ${$}
|
|
172
|
+
`))}return}if(r.kind==="rename"){if(!r.target||!r.newName){console.log(w.yellow(`
|
|
173
|
+
Usage: /workflow rename <runId|alias|savedName> <newName>
|
|
174
|
+
`));return}let p=await u.resolveWorkflowIdentity(r.target);if(p.kind==="ambiguous"){console.log(w.red(`
|
|
175
|
+
[workflow] ambiguous rename target: ${r.target} matches both a workflow run id and a saved workflow name.
|
|
176
|
+
`));return}if(p.kind==="missing"){console.log(w.red(`
|
|
177
|
+
[workflow] rename target not found: ${r.target}
|
|
178
|
+
`));return}if(p.kind==="run"){if(!await u.renameWorkflowRun(p.runId,r.newName)){console.log(w.red(`
|
|
179
|
+
[workflow] rename failed: ${p.runId}
|
|
180
|
+
`));return}console.log(w.green(`
|
|
181
|
+
Renamed workflow run ${p.runId} to ${r.newName.trim()}.
|
|
182
|
+
`));return}try{let $=await Xt({dirs:d,name:p.savedWorkflow.name,newName:r.newName,source:p.savedWorkflow.source});console.log(w.green(`
|
|
183
|
+
Renamed saved workflow ${r.target} to ${$.name}.
|
|
184
|
+
`))}catch($){let b=$ instanceof Error?$.message:String($);console.log(w.red(`
|
|
185
|
+
[workflow] rename failed: ${b}
|
|
186
|
+
`))}return}if(r.kind==="revise"){if(!r.target||!r.request){console.log(w.yellow(`
|
|
187
|
+
Usage: /workflow revise [--replace] <runId|alias|savedName> <change request>
|
|
188
|
+
`));return}let p=we(n);if(!p){console.log(w.red(`
|
|
189
|
+
[workflow] refusing to revise a workflow without an interactive approval channel.
|
|
190
|
+
`));return}let $=n.createKodaXOptions;if(!$){console.log(w.red(`
|
|
191
|
+
[workflow] cannot revise - REPL options unavailable in this context.
|
|
192
|
+
`));return}let b=await u.resolveWorkflowIdentity(r.target);if(b.kind==="ambiguous"){console.log(w.red(`
|
|
193
|
+
[workflow] ambiguous revise target: ${r.target} matches both a workflow run id and a saved workflow name.
|
|
194
|
+
`));return}if(b.kind==="missing"){console.log(w.red(`
|
|
195
|
+
[workflow] revise target not found: ${r.target}
|
|
196
|
+
`));return}if(r.replace===!0&&b.kind!=="saved"){console.log(w.red(`
|
|
197
|
+
[workflow] revise --replace requires a saved workflow name target.
|
|
198
|
+
`));return}let P;try{if(b.kind==="run")P=(await sn({runDir:b.runDir})).capsule;else{if(b.savedWorkflow.execution!=="capability-generated"){console.log(w.red(`
|
|
199
|
+
[workflow] only generated workflow capsules can be revised.
|
|
200
|
+
`));return}P=await Fe(b.savedWorkflow.path)}}catch(W){let Oe=W instanceof Error?W.message:String(W);console.log(w.red(`
|
|
201
|
+
[workflow] revise failed: ${Oe}
|
|
202
|
+
`));return}let E=Qn({target:r.target,capsule:P,changeRequest:r.request}),O;try{O=await go({request:E,options:$()})}catch(W){let Oe=W instanceof Error?W.message:String(W);console.log(w.red(`
|
|
203
|
+
[workflow] revise generation failed: ${Oe}
|
|
204
|
+
`));return}if(O.kind==="declined"){console.log(w.dim(`
|
|
205
|
+
Workflow revision not created: ${O.reason}
|
|
206
|
+
`));return}let le=r.replace===!0&&b.kind==="saved"?b:void 0,H=le?.savedWorkflow.name,ve=H??await ys(d,O.manifest.name),q=ve===O.manifest.name?O.manifest:{...O.manifest,name:ve};if(!await p(Y(ce({meta:q,run:O.module.run}),{source:H?`revision-replace:${H}`:`revision:${r.target}`,sandbox:"capability-generated",mayUseWorktree:q.mayUseWorktree===!0,rawScript:O.source}))){console.log(w.dim(`Workflow revision cancelled.
|
|
207
|
+
`));return}let U={name:ve,manifest:q,source:O.source,intent:{taskClass:q.patterns[0]??q.name,originalRequest:r.request,reusableFor:[q.description]},...P.inputs!==void 0?{inputs:P.inputs}:{},...P.requires!==void 0?{requires:P.requires}:{},provenance:ks({capsule:P,resolution:b,...H!==void 0?{replacesWorkflowName:H}:{}})};if(le){let W=await Vt({...U,dirs:d,savedSource:le.savedWorkflow.source});console.log(w.green(`
|
|
208
|
+
Replaced saved workflow ${W.name} with revised capsule at ${W.path}
|
|
209
|
+
`)),console.log(w.dim(`Previous capsule archived at ${W.previousPath}
|
|
210
|
+
`));return}let co=await Gt({...U,dir:d.project??X(process.cwd(),".kodax","workflows")});console.log(w.green(`
|
|
211
|
+
Saved workflow revision ${co.name} to ${co.path}
|
|
212
|
+
`));return}if(r.kind==="rerun"){if(!r.runId){console.log(w.yellow(`
|
|
213
|
+
Usage: /workflow rerun <runId|savedName> [args]
|
|
214
|
+
`));return}if(!se(r.runId))return;let p=we(n);if(!p){console.log(w.red(`
|
|
215
|
+
[workflow] refusing to rerun a workflow without an interactive approval channel.
|
|
216
|
+
`));return}let $=n.createKodaXOptions;if(!$){console.log(w.red(`
|
|
217
|
+
[workflow] cannot start \u2014 REPL options unavailable in this context.
|
|
218
|
+
`));return}let b=(await xe(d)).find(T=>T.name===r.runId),P=c.list().some(T=>T.runId===r.runId)||Ps(X(l,r.runId,"run.json"));if(b&&P){console.log(w.red(`
|
|
219
|
+
[workflow] ambiguous rerun target: ${r.runId} matches both a workflow run id and a saved workflow name.
|
|
220
|
+
`)),console.log(w.yellow(`Use /workflow ${r.runId} to run the saved workflow, or rerun a unique run id/name.
|
|
221
|
+
`));return}if(b&&!P){let T=await $s(b,p);if(!T)return;let De=Qe(r.rawArgs,T.module.meta.name,T.module.meta.description,T.scriptSnapshot?.source),xt="agentic";if(!await p(Y(ce(T.module),T.approvalContext))){console.log(w.dim(`Workflow cancelled.
|
|
222
|
+
`));return}let K=`run-${Date.now().toString(36)}`,ni=X(l,K);console.log(w.dim(`
|
|
223
|
+
Started workflow ${T.module.meta.name} (${K}). Use /workflow show ${K} for status.
|
|
224
|
+
`));let Zo=he(n,K,T.module.meta,De);Zo.running(`Use /workflow show ${K} for status or /workflow stop ${K} to stop.`);let ti=We(c,Zo,K),At=c.startFromOptions({module:T.module,args:so(r.rawArgs),options:$(),runId:K,runDir:ni,...T.scriptSnapshot?{scriptSnapshot:T.scriptSnapshot}:{},processMetadata:Ms({displayName:T.module.meta.name,savedWorkflowName:b.name,provenance:T.provenance}),onEvent:Me(n,void 0,{presentation:xt,locale:De,runId:K})});At.done.finally(ti),ye(At,n,K,Zo,{canRerun:T.scriptSnapshot!==void 0,presentation:xt,locale:De});return}let E;try{E=await sn({runDir:X(l,r.runId)})}catch(T){let De=T instanceof Error?T.message:String(T);console.log(w.red(`
|
|
225
|
+
[workflow] rerun failed: ${De}
|
|
226
|
+
`));return}let le=to(l,r.runId)?.scriptSnapshotPath??X(l,r.runId,"script.js"),H=Qe(r.rawArgs,E.capsule.manifest.name,E.capsule.manifest.description,E.capsule.source),ve="agentic",q=je(E.capsule,Wo());if(!q.ok){_o(q);return}if(Lo(q),!await p(Y(ce(E.module),{source:`run:${r.runId}`,sandbox:"capability-generated",mayUseWorktree:E.capsule.manifest.mayUseWorktree===!0,rawScriptPath:le,rawScript:E.capsule.source}))){console.log(w.dim(`Workflow cancelled.
|
|
227
|
+
`));return}let U=`run-${Date.now().toString(36)}`,co=X(l,U);console.log(w.dim(`
|
|
228
|
+
Started workflow ${E.module.meta.name} (${U}). Use /workflow show ${U} for status.
|
|
229
|
+
`));let W=he(n,U,E.module.meta,H);W.running(`Use /workflow show ${U} for status or /workflow stop ${U} to stop.`);let Oe=We(c,W,U),bt=c.startFromOptions({module:E.module,args:so(r.rawArgs),options:$(),runId:U,runDir:co,scriptSnapshot:{manifest:E.capsule.manifest,source:E.capsule.source},processMetadata:ro({source:"command",displayName:E.module.meta.name,sourceRunId:r.runId}),onEvent:Me(n,void 0,{presentation:ve,locale:H,runId:U})});bt.done.finally(Oe),ye(bt,n,U,W,{canRerun:!0,presentation:ve,locale:H});return}if(r.kind==="create"){if(!r.request){console.log(w.yellow(`
|
|
230
|
+
Usage: /workflow create <request>
|
|
231
|
+
`));return}await Yn({request:r.request,callbacks:n,approval:t.permissionMode==="plan"?"required":"silent",presentation:"agentic",sourceLabel:"generated",processSource:"command",onBuilderEvent:n.onWorkflowBuilderEvent});return}let m=we(n);if(!m){console.log(w.red(`
|
|
232
|
+
[workflow] refusing to start a workflow without an interactive approval channel.
|
|
233
|
+
`));return}let f={source:"built-in",sandbox:"trusted package",mayUseWorktree:!1},h,k=Qt(r.name),y,v;if(!k){let p=(await xe(d)).find($=>$.name===r.name);if(!p){console.log(w.yellow(`
|
|
234
|
+
Unknown workflow: ${r.name}`)),console.log(Mo(He())),console.log();return}if(y=p,p.execution==="trusted-local"&&!await m(`Run local workflow file? This EXECUTES local code:
|
|
235
|
+
${p.path}`)){console.log(w.dim(`Workflow cancelled.
|
|
236
|
+
`));return}try{if(p.execution==="capability-generated"){let $=await Fe(p.path),b=je($,Wo());if(!b.ok){_o(b);return}Lo(b),f={source:`saved:${p.source}`,sandbox:p.execution,mayUseWorktree:$.manifest.mayUseWorktree===!0,rawScriptPath:p.path,rawScript:$.source},h={manifest:$.manifest,source:$.source},v=$.provenance}k=await mo(p.path),p.execution==="trusted-local"&&(f={source:`saved:${p.source}`,sandbox:p.execution,mayUseWorktree:!1})}catch($){let b=$ instanceof Error?$.message:String($);console.log(w.red(`
|
|
237
|
+
[workflow] failed to load ${p.path}: ${b}
|
|
238
|
+
`));return}}let g=n.createKodaXOptions;if(!g){console.log(w.red(`
|
|
239
|
+
[workflow] cannot start \u2014 REPL options unavailable in this context.
|
|
240
|
+
`));return}if(!await m(Y(ce(k),f))){console.log(w.dim(`Workflow cancelled.
|
|
241
|
+
`));return}let x=`run-${Date.now().toString(36)}`,D=X(l,x);console.log(w.dim(`
|
|
242
|
+
Started workflow ${k.meta.name} (${x}). Use /workflow show ${x} for status.
|
|
243
|
+
`));let F=Qe(r.rawArgs,k.meta.name,k.meta.description,h?.source),B=he(n,x,k.meta,F);B.running(`Use /workflow show ${x} for status or /workflow stop ${x} to stop.`);let lo="agentic",ae=We(c,B,x),St=c.startFromOptions({module:k,args:so(r.rawArgs),options:g(),runId:x,runDir:D,...h?{scriptSnapshot:h}:{},processMetadata:y?Ms({displayName:k.meta.name,savedWorkflowName:y.name,provenance:v}):ro({source:"command",displayName:k.meta.name}),onEvent:Me(n,void 0,{presentation:lo,locale:F,runId:x})});St.done.finally(ae),ye(St,n,x,B,{canRerun:h!==void 0,presentation:lo,locale:F})},"handler")};import N from"chalk";var nt={name:"new",description:"Start a new conversation session",usage:"/new",handler:a(async(e,o,n)=>{if(o.messages.length===0){console.log(N.yellow(`
|
|
244
|
+
Current session is already empty.`)),console.log(N.dim("You can start a new conversation directly."));return}if(n.confirm&&!await n.confirm("Start a new session? This will clear the current conversation history.")){console.log(N.dim(`
|
|
245
|
+
Cancelled. Current session preserved.`));return}try{await n.saveSession(),console.log(N.dim(`
|
|
246
|
+
[Previous session saved]`))}catch{console.log(N.yellow(`
|
|
247
|
+
[Warning: Failed to save previous session]`))}n.startNewSession?.(),o.messages=[],n.clearHistory(),console.log(N.green(`
|
|
248
|
+
\u2713 Started new session`)),console.log(N.dim("Conversation history cleared. Ready for a fresh start!"))},"handler"),detailedHelp:a(()=>{console.log(N.bold(`
|
|
249
|
+
/new - Start New Session
|
|
250
|
+
`)),console.log("Usage:"),console.log(N.cyan(" /new")+` - Clear current session and start fresh
|
|
251
|
+
`),console.log("Description:"),console.log(" This command clears the current conversation history and starts a new session."),console.log(" It automatically saves the previous session before clearing."),console.log(` Useful for switching contexts or starting a new topic.
|
|
252
|
+
`),console.log("Examples:"),console.log(N.dim(" User: Help me refactor the authentication module")),console.log(N.dim(" AI: [provides refactoring help]")),console.log(N.cyan(" /new")),console.log(N.dim(" \u2713 Started new session")),console.log(N.dim(" User: Now I need help with database optimization")),console.log(N.dim(` AI: [provides database help]
|
|
253
|
+
`)),console.log("Notes:"),console.log(" \u2022 Automatically saves previous session before clearing"),console.log(" \u2022 Prompts for confirmation if there are messages in the current session"),console.log(" \u2022 Use /load to resume a previous session"),console.log(" \u2022 Use /sessions to see all saved sessions")},"detailedHelp")};import{execFile as kl}from"node:child_process";import{promisify as vl}from"node:util";var $l=vl(kl),tt=1e5;async function Fo(e,o){let{stdout:n}=await $l("git",e,{cwd:o,maxBuffer:67108864});return n}a(Fo,"git");async function Sl(e){for(let o of["main","master","develop"])try{return await Fo(["rev-parse","--verify",o],e),o}catch{}return"HEAD"}a(Sl,"detectBaseBranch");async function bl(e,o){let n=e[0];if(n==="base"){let t=await Sl(o);return{diff:await Fo(["diff",`${t}...HEAD`],o),label:`changes against ${t}`}}return n==="sha"&&e[1]?{diff:await Fo(["show",e[1]],o),label:`commit ${e[1]}`}:{diff:await Fo(["diff","HEAD"],o),label:"uncommitted changes"}}a(bl,"getDiff");function xl(e){return{workflow:e.some(o=>o==="--workflow"||o==="workflow"),diffArgs:e.filter(o=>o!=="--workflow"&&o!=="workflow")}}a(xl,"parseReviewInvocation");function Al(e){return[`Review ${e} with a dynamic workflow.`,"Create independent reviewers for correctness, security, performance, and design.","Have each reviewer inspect the relevant git diff evidence independently, then synthesize findings.","Final output must lead with verified findings, cite files or diff hunks, and state when no issues are found."].join(`
|
|
254
|
+
`)}a(Al,"buildReviewWorkflowRequest");var _s={name:"review",description:"Review code changes (git diff) for bugs, security, performance, and design",usage:"/review [--workflow] [base | sha <hash>] (default: uncommitted changes)",handler:a(async(e,o)=>{let n=o.gitRoot??process.cwd(),t=xl(e),r,i;try{({diff:r,label:i}=await bl(t.diffArgs,n))}catch(d){return{success:!1,message:`/review: git failed \u2014 ${d instanceof Error?d.message:String(d)}`}}if(!r.trim())return{success:!0,message:"No changes to review."};if(t.workflow)return{success:!0,workflow:{request:Al(i),source:"command",displayName:"/review --workflow",processSource:"review"}};let l=r;return l.length>tt&&(l=`${l.slice(0,tt)}
|
|
255
|
+
|
|
256
|
+
[diff truncated to ${tt} chars \u2014 review the rest with a narrower scope]`),{success:!0,invocation:{prompt:[`Review the following ${i} as a third-party reviewer (not the author).`,"Look for bugs (logic errors, null/undefined handling, off-by-one, races),","security (injection, secret exposure, auth bypass), performance hotpaths,","and design (over-engineering vs missing abstraction).","Cite specific diff lines. For each finding, note whether it is verifiable by","tsc / lint / test / build. If the diff is small or risk-free, say so briefly.","","```diff",l,"```"].join(`
|
|
257
|
+
`),source:"prompt",displayName:"/review"}}},"handler")};function Ho(e){let o=e.match(/\r\n|\r|\n/g);return o?o.length:0}a(Ho,"getPastedTextRefNumLines");function Rl(e,o){return o===0?`[Pasted text #${e}]`:`[Pasted text #${e} +${o} lines]`}a(Rl,"formatPastedTextRef");function Il(e,o){return`[...Truncated text #${e} +${o} lines...]`}a(Il,"formatTruncatedTextRef");var Cl=/\[(Pasted text|Image|\.\.\.Truncated text) #(\d+)(?: \+\d+ lines)?(\.*)\]/g;function El(e){let o=[],n=new RegExp(Cl.source,"g");for(let t of e.matchAll(n)){let r=Number.parseInt(t[2]??"0",10);!Number.isFinite(r)||r<=0||o.push({id:r,kind:t[1],match:t[0],index:t.index??0})}return o}a(El,"parseReferences");function Tl(e,o){let n=El(e);if(n.length===0)return e;let t=a(i=>o instanceof Map?o.get(i):o[i],"getContent"),r=e;for(let i=n.length-1;i>=0;i--){let l=n[i];if(l.kind==="Image")continue;let c=t(l.id);!c||c.type!=="text"||(r=r.slice(0,l.index)+c.content+r.slice(l.index+l.match.length))}return r}a(Tl,"expandPastedTextRefs");var Pl=/\[(Pasted text|Image|\.\.\.Truncated text) #(\d+)(?: \+\d+ lines)?(\.*)\]$/,Ml=/^\[(Pasted text|Image|\.\.\.Truncated text) #(\d+)(?: \+\d+ lines)?(\.*)\]/;function Wl(e,o){if(o>=e.length)return!0;let n=e[o];return!n||/\s/.test(n)}a(Wl,"isAtWordBoundaryAfter");function _l(e,o){if(o===0)return!0;let n=e[o-1];return!n||/\s/.test(n)}a(_l,"isAtWordBoundaryBefore");function Gf(e,o){if(o<=0||!Wl(e,o))return null;let t=e.slice(0,o).match(Pl);if(!t)return null;let r=o-t[0].length,i=Number.parseInt(t[2]??"0",10);return!Number.isFinite(i)||i<=0?null:{start:r,end:o,id:i,kind:t[1]}}a(Gf,"findPlaceholderBeforeCursor");function Xf(e,o){if(o>=e.length||!_l(e,o))return null;let t=e.slice(o).match(Ml);if(!t)return null;let r=Number.parseInt(t[2]??"0",10);return!Number.isFinite(r)||r<=0?null:{start:o,end:o+t[0].length,id:r,kind:t[1]}}a(Xf,"findPlaceholderAfterCursor");function Vf(e){return e.length>800||Ho(e)>2}a(Vf,"shouldReplacePasteWithPlaceholder");function Jf(e,o){if(e.length<=1e4)return{truncatedText:e,placeholderContent:""};let n=Math.floor(1e3/2),t=Math.floor(1e3/2),r=e.slice(0,n),i=e.slice(-t),l=e.slice(n,-t),c=Ho(l),d=Il(o,c);return{truncatedText:r+d+i,placeholderContent:l}}a(Jf,"maybeTruncateLongInput");var rt=class{static{a(this,"PasteStore")}contents=new Map;nextId=1;registerText(o){let n=this.nextId++,t=Ho(o);return this.contents.set(n,{id:n,type:"text",content:o}),{id:n,placeholder:Rl(n,t),numLines:t}}registerTruncatedText(o){let n=this.nextId++,t=Ho(o);return this.contents.set(n,{id:n,type:"text",content:o}),{id:n,numLines:t}}adopt(o){this.contents.set(o.id,o),o.id>=this.nextId&&(this.nextId=o.id+1)}peekNextId(){return this.nextId}get(o){return this.contents.get(o)}expand(o){return Tl(o,this.contents)}snapshot(){return new Map(this.contents)}restore(o){this.contents.clear();for(let[n,t]of o)this.contents.set(n,t);for(let n of o.keys())n>=this.nextId&&(this.nextId=n+1)}reset(){this.contents.clear(),this.nextId=1}size(){return this.contents.size}export(){return Array.from(this.contents.values())}},jo=null;function Yf(){return jo===null&&(jo=new rt),jo}a(Yf,"getOrCreateModulePasteStore");function Ls(){return jo??void 0}a(Ls,"getActivePasteStore");import{createHash as Ll}from"node:crypto";import{mkdir as Nl,readdir as Ol,readFile as Dl,stat as Ul,unlink as Fl,writeFile as jl}from"node:fs/promises";import*as st from"node:path";var Hl="paste-cache",Bl=720*60*60*1e3;function it(){return _(Hl)}a(it,"getPasteCacheDir");function Ns(e){return st.join(it(),`${e}.txt`)}a(Ns,"getPastePath");function tm(e){return Ll("sha256").update(e).digest("hex").slice(0,16)}a(tm,"hashPastedText");async function rm(e,o){try{let n=it();return await Nl(n,{recursive:!0}),await jl(Ns(e),o,{encoding:"utf8",mode:384}),!0}catch{return!1}}a(rm,"storePastedText");async function Os(e){try{return await Dl(Ns(e),{encoding:"utf8"})}catch{return null}}a(Os,"retrievePastedText");async function sm(e=Bl){let o=it(),n=Date.now()-e,t=0,r=0,i;try{i=await Ol(o)}catch{return{scanned:t,removed:r}}for(let l of i){if(!l.endsWith(".txt"))continue;t+=1;let c=st.join(o,l);try{(await Ul(c)).mtimeMs<n&&(await Fl(c),r+=1)}catch{}}return{scanned:t,removed:r}}a(sm,"cleanupOldPastes");import*as ut from"path";import*as Us from"os";function ql(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}a(ql,"escapeRegExp");function Kl(e,o){if(!e)return;let n=e.trim();if(!n.startsWith("/"))return;let t=new RegExp(`^/${ql(o)}(?:\\s+)?`,"i"),r=n.replace(t,"").trim();return r.length>0?r:void 0}a(Kl,"deriveArgumentHintFromUsage");function at(e,o="builtin"){return{...e,source:e.source??o,userInvocable:e.userInvocable??!0,disableModelInvocation:e.disableModelInvocation??!1,argumentHint:e.argumentHint??Kl(e.usage,e.name)}}a(at,"toCommandDefinition");function lt(e){for(let o of Ds)try{let n=at(o,"builtin");e.register(n)}catch(n){console.error(`Failed to register command "${o.name}":`,n)}}a(lt,"registerBuiltinCommands");import*as Z from"fs";import*as ke from"path";function zl(e){if(Array.isArray(e))return e.map(o=>String(o).trim()).filter(o=>o.length>0);if(typeof e=="string")return e.split(",").map(o=>o.trim()).filter(o=>o.length>0)}a(zl,"normalizeAliases");function Gl(e){if(e==="critical"||e==="high"||e==="medium"||e==="low")return e}a(Gl,"normalizePriority");function Xl(e){return{disableModelInvocation:e["disable-model-invocation"]===!0,userInvocable:e["user-invocable"]!==!1,allowedTools:Pt(e["allowed-tools"]),context:e.context==="fork"?"fork":void 0,agent:typeof e.agent=="string"?e.agent:void 0,argumentHint:typeof e["argument-hint"]=="string"?e["argument-hint"]:void 0,model:typeof e.model=="string"?e.model:void 0,hooks:Mt(e.hooks),frontmatter:e}}a(Xl,"buildExecutionMetadata");function Vl(e,o){try{let n=Z.readFileSync(e,"utf-8"),[t,r]=Tt(n),i=t??{},l=ke.basename(e,".md"),c=typeof i.name=="string"&&i.name.trim()?i.name.trim():l;if(!c||r.trim().length===0)return;let d=typeof i.description=="string"&&i.description.trim()?i.description.trim():`Custom command from ${o} level`;return{name:c,description:d,aliases:zl(i.aliases),priority:Gl(i.priority),content:r.trim(),location:o,path:e,frontmatter:i,execution:Xl(i)}}catch(n){console.error(`Error parsing command file ${e}:`,n);return}}a(Vl,"parseCommandFile");function ct(e){let o=[],n=new Set;for(let t=0;t<e.length;t++){let r=e[t],i=typeof r=="string"?r:r.path,l=typeof r=="string"?t===0?"user":"project":r.location;if(!Z.existsSync(i))continue;let c=ke.resolve(i);try{c=Z.realpathSync.native?.(i)??Z.realpathSync(i)}catch{c=ke.resolve(i)}if(!n.has(c)){n.add(c);try{let d=Z.readdirSync(i);for(let u of d){if(!u.endsWith(".md"))continue;let m=ke.join(i,u),f=Vl(m,l);f&&o.push(f)}}catch(d){console.error(`Error scanning directory ${i}:`,d)}}}return o}a(ct,"discoverCommands");function dt(e,o){for(let n of e)try{o.register({name:n.name,aliases:n.aliases,description:n.description,source:"extension",priority:n.priority,location:n.location,path:n.path,userInvocable:n.execution.userInvocable,disableModelInvocation:n.execution.disableModelInvocation,allowedTools:n.execution.allowedTools,context:n.execution.context,agent:n.execution.agent,argumentHint:n.execution.argumentHint,model:n.execution.model,hooks:n.execution.hooks,frontmatter:n.frontmatter,handler:a(async()=>({success:!0,invocation:{...n.execution,prompt:n.content,source:"prompt",displayName:n.name,path:n.path}}),"handler")})}catch(t){console.error(`Error registering command ${n.name}:`,t)}}a(dt,"registerDiscoveredCommands");function Fs(e,o){lt(e);try{let n=Us.homedir(),t=o??process.cwd(),r=ct([{path:ut.join(t,".kodax","commands"),location:"project"},{path:_("commands"),location:"user"},{path:ut.join(n,".agents","commands"),location:"user"}]);dt(r,e)}catch(n){console.error("Failed to discover commands:",n)}}a(Fs,"registerAllCommands");function Jl(e){return{global:e.filter(o=>o.scope==="global").length,directory:e.filter(o=>o.scope==="directory").length,project:e.filter(o=>o.scope==="project").length}}a(Jl,"summarizeAgentsFiles");function Yl(e,o,n){if(!Number.isFinite(o)||o<=0||n<=0)return{...e,enabled:!0};let t=o/n*100,r=Math.max(1,Math.ceil(t)-1);return{...e,enabled:!0,triggerPercent:Math.min(e.triggerPercent,r)}}a(Yl,"createManualCompactionConfig");function ft(e){e.runtimeInfo?.workspaceRoot?console.log(s.dim(` Workspace unchanged: ${Pn(e.runtimeInfo)}`)):console.log(s.dim(" Workspace unchanged."))}a(ft,"printWorkspaceUnchangedNote");var Ds=[{name:"help",aliases:["h","?"],description:"Show all available commands",usage:"/help [command]",handler:a(async e=>{if(e.length>0){let o=e[0];ee.size===0&&qo(),ee.has(o.toLowerCase())||!!gt(o)?mt(o):lc(o)}else ac()},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
258
|
+
/help - Show Command Help
|
|
259
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /help ")+"Show all available commands"),console.log(s.dim(" /help <command> ")+"Show detailed help for a specific command"),console.log(s.dim(" /<command> help ")+"Shortcut for command-specific help"),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /help ")+"# List all commands"),console.log(s.dim(" /help mode ")+"# Detailed help for /mode"),console.log(s.dim(" /mode help ")+"# Same detailed help shortcut"),console.log()},"detailedHelp")},{name:"exit",aliases:["quit","q","bye"],description:"Exit interactive mode",handler:a(async(e,o,n)=>{await n.saveSession(),console.log(s.green(`
|
|
260
|
+
Session saved. Goodbye!`)),await n.exit()},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
261
|
+
/exit - Exit Interactive Mode
|
|
262
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /exit ")+"Save session and exit"),console.log(s.dim(" /quit, /q, /bye ")+"Aliases for /exit"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Saves the current conversation session and exits interactive mode.")),console.log(s.dim(" Sessions can be resumed later with /load or CLI -c option.")),console.log(s.dim(" Exiting never removes or mutates the current workspace.")),console.log()},"detailedHelp")},{name:"clear",description:"Clear conversation history",handler:a(async(e,o,n)=>{o.messages=[],o.contextTokenSnapshot=void 0,n.clearHistory(),console.log(s.yellow(`
|
|
263
|
+
[Conversation cleared]`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
264
|
+
/clear - Clear Conversation History
|
|
265
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /clear ")+"Clear all messages in current session"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Removes all messages from the current conversation context.")),console.log(s.dim(" Useful for starting fresh while keeping the session.")),console.log(),console.log(s.yellow(" Warning: This action cannot be undone!")),console.log()},"detailedHelp")},{name:"cost",description:"Show session cost report",usage:"/cost",handler:a(async(e,o,n)=>{let t=n.getCostReport?.();if(!t){console.log(s.dim(`
|
|
266
|
+
[No cost data available yet]`));return}console.log(s.cyan(`
|
|
267
|
+
`+t))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
268
|
+
/cost - Session Cost Report
|
|
269
|
+
`)),console.log(s.bold("Description:")),console.log(s.dim(" Shows token usage and estimated cost for the current session,")),console.log(s.dim(" broken down by provider and AMA role.")),console.log()},"detailedHelp")},{name:"paste",description:"Inspect pasted text stored in the input buffer",usage:"/paste show <id> | /paste list",argumentHint:"show <id> | list",handler:a(async e=>{let o=e[0]?.toLowerCase();if(!o||o==="help"){console.log(s.cyan(`
|
|
270
|
+
/paste - Inspect stored paste contents`)),console.log(s.dim(" /paste list - Show all pasted text ids in this session")),console.log(s.dim(" /paste show <id> - Print the full content of paste #<id>")),console.log();return}let n=Ls();if(!n){console.log(s.yellow(`
|
|
271
|
+
[No paste registry active]`)),console.log(s.dim(" The REPL composer is not mounted, or no paste has been captured yet."));return}if(o==="list"){let t=n.export();if(t.length===0){console.log(s.dim(`
|
|
272
|
+
[No pasted content in this session yet]`));return}console.log(s.bold(`
|
|
273
|
+
Pasted content in this session:
|
|
274
|
+
`));for(let r of t){let i=r.content?.length??0,l=r.contentHash?` (hash ${r.contentHash.slice(0,8)})`:"";console.log(` ${s.cyan(`#${r.id}`)} ${r.type} ${i} chars${l}`)}console.log();return}if(o==="show"){let t=e[1],r=t?Number.parseInt(t,10):NaN;if(!Number.isFinite(r)||r<=0){console.log(s.yellow(`
|
|
275
|
+
Usage: /paste show <id>`));return}let i=n.get(r);if(!i){console.log(s.dim(`
|
|
276
|
+
[No paste registered with id #${r}]`));return}let l=i.content??"";if(!l&&i.contentHash){let c=await Os(i.contentHash);c&&(l=c)}if(!l){console.log(s.yellow(`
|
|
277
|
+
[Paste #${r} has no stored content (hash ${i.contentHash??"n/a"})]`));return}console.log(s.bold(`
|
|
278
|
+
Pasted text #${r} (${l.length} chars):
|
|
279
|
+
`)),console.log(l),console.log();return}console.log(s.yellow(`
|
|
280
|
+
[Unknown /paste subcommand: ${o}]`)),console.log(s.dim(" Try /paste show <id> or /paste list"))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
281
|
+
/paste - Inspect stored paste contents
|
|
282
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /paste list - Show all pasted text ids in this session")),console.log(s.dim(" /paste show <id> - Print the full content of paste #<id>")),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" When you paste more than ~800 chars into the input bar, KodaX")),console.log(s.dim(" replaces the pasted text with a `[Pasted text #N +K lines]` anchor")),console.log(s.dim(" to keep the UI responsive. The full content is preserved and sent")),console.log(s.dim(" to the LLM on submit. Use this command to see what was captured.")),console.log()},"detailedHelp")},{name:"compact",description:"Manually trigger context compaction",usage:"/compact [instructions]",handler:a(async(e,o,n,t)=>{try{let r=await lr(o.gitRoot),i=t.provider,l=Rt(i);if(!l){console.log(s.red(`
|
|
283
|
+
[Provider not found: ${i}]`));return}let c=e.length>0?e.join(" "):void 0,d=r.contextWindow??l.getEffectiveContextWindow?.(t.model)??l.getContextWindow?.()??2e5,u=o.contextTokenSnapshot?.currentTokens??on(o.messages),m=Yl(r,u,d);console.log(s.dim(`
|
|
284
|
+
[Compacting conversation...]`)),n.startCompacting?.();try{let f=await Lt(o.messages,m,l,d,c,void 0,u,qt,Kt);if(!f.compacted){console.log(s.green(`
|
|
285
|
+
[No compaction needed]`)),console.log(s.dim(`Current token usage: ${f.tokensBefore.toLocaleString()}
|
|
286
|
+
`));return}o.messages=f.messages,o.contextTokenSnapshot={currentTokens:f.tokensAfter,baselineEstimatedTokens:f.tokensAfter,source:"estimate"},n.onCompactStats?.({tokensBefore:f.tokensBefore,tokensAfter:f.tokensAfter}),n.clearHistory?.(),await n.saveSession(),console.log(s.green(`
|
|
287
|
+
[Compaction complete: ${Math.round(f.tokensBefore/1e3)}k -> ${Math.round(f.tokensAfter/1e3)}k tokens, ${Math.round((1-f.tokensAfter/f.tokensBefore)*100)}% reduced]`)),console.log()}finally{n.stopCompacting?.()}}catch(r){let i=r instanceof Error?r.message:String(r);console.log(s.red(`
|
|
288
|
+
[Compaction failed: ${i}]
|
|
289
|
+
`))}},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
290
|
+
/compact - Manual Context Compaction
|
|
291
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /compact ")+"Compact conversation with default instructions"),console.log(s.dim(" /compact <text> ")+"Compact with custom instructions for the summary"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Manually triggers context compaction using LLM-generated summaries.")),console.log(s.dim(" Older messages are replaced with a structured summary, keeping recent context.")),console.log(s.dim(" /compact still works even if auto-compaction is disabled or the auto threshold is not reached.")),console.log(),console.log(s.bold("What it does:")),console.log(s.dim(" 1. Protects a recent slice of context from pruning/summary")),console.log(s.dim(" 2. Generates structured summary of older messages using LLM")),console.log(s.dim(" 3. Tracks files that were read/modified in the conversation")),console.log(s.dim(" 4. Replaces old messages with summary to save tokens")),console.log(),console.log(s.bold("Configuration:")),console.log(s.dim(" Config file: ~/.kodax/config.json")),console.log(s.dim(" Settings:")),console.log(s.dim(" - compaction.triggerPercent: Usage percentage that triggers compaction")),console.log(s.dim(" - compaction.enabled: Controls auto-compaction only; /compact always remains available")),console.log(s.dim(" - compaction.contextWindow: Optional token-window override")),console.log(s.dim(" - compaction.protectionPercent / rollingSummaryPercent / pruningThresholdTokens: Advanced tuning")),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /compact ")+"# Compact with default instructions"),console.log(s.dim(" /compact focus on auth logic ")+"# Emphasize authentication in summary"),console.log(),console.log(s.dim(" See also: /help status (shows token usage)")),console.log()},"detailedHelp")},{name:"reload",description:"Reload project rules and active extensions",handler:a(async(e,o,n,t)=>{console.log(s.cyan(`
|
|
292
|
+
Reloading project rule files and runtime extensions...
|
|
293
|
+
`));try{let r=await n.reloadAgentsFiles?.()??[],i=Jl(r),l=V(),c=l?_e(l).loadedExtensions.length:0,d=l?_e(l).failures.length:0,u=0,m=0;if(l){await l.reloadExtensions({continueOnError:!0});let f=_e(l);u=c||f.loadedExtensions.length,m=Math.max(0,f.failures.length-d)}if(r.length===0&&u===0){console.log(s.yellow(`No project rule files or active extensions found.
|
|
294
|
+
`)),console.log(s.dim(" Create AGENTS.md or CLAUDE.md in your project, or load extensions with --extension.")),console.log();return}console.log(s.green(`Rules reloaded successfully:
|
|
295
|
+
`)),i.global>0&&console.log(s.dim(` - Global: ${i.global} file(s)`)),i.directory>0&&console.log(s.dim(` - Directory: ${i.directory} file(s)`)),i.project>0&&console.log(s.dim(` - Project: ${i.project} file(s)`)),u>0&&console.log(s.dim(` - Extensions: ${u} module(s)`)),m>0&&console.log(s.yellow(` - Failures: ${m} recorded (run /extensions for details)`)),console.log(s.dim(" Updated rules will apply to subsequent requests in this session.")),console.log();return}catch(r){console.log(s.red(`Failed to reload rules.
|
|
296
|
+
`)),console.log(s.dim(` Error: ${r instanceof Error?r.message:String(r)}`)),console.log()}},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
297
|
+
/reload - Reload Project Rules
|
|
298
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /reload ")+"Reload project rule files and active extensions"),console.log(),console.log(s.bold("Description:")),console.log(" Reloads project-level context rules from AGENTS.md, CLAUDE.md, and .kodax/AGENTS.md files."),console.log(" If a runtime extension host is active, it also hot-reloads loaded extensions."),console.log(),console.log(s.bold("Rule Priority:")),console.log(s.dim(" 1. Global: ")+"~/.kodax/AGENTS.md"),console.log(s.dim(" 2. Directory: ")+"AGENTS.md or CLAUDE.md from project root to current directory"),console.log(s.dim(" 3. Project: ")+".kodax/AGENTS.md at the project root"),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /reload ")+"# Reload and show loaded rules"),console.log()},"detailedHelp")},{name:"extensions",aliases:["ext"],description:"Show active extension runtime diagnostics",usage:"/extensions",handler:a(async()=>{let e=V();if(!e){console.log(s.yellow(`
|
|
299
|
+
[No active extension runtime]
|
|
300
|
+
`));return}let o=_e(e),n=o.tools.filter(t=>t.source.kind==="extension");if(console.log(s.bold(`
|
|
301
|
+
Extension Runtime:
|
|
302
|
+
`)),console.log(s.dim(` Loaded: ${o.loadedExtensions.length}`)),console.log(s.dim(` Capabilities: ${o.capabilityProviders.length}`)),console.log(s.dim(` Commands: ${o.commands.length}`)),console.log(s.dim(` Hooks: ${o.hooks.length}`)),console.log(s.dim(` Failures: ${o.failures.length}`)),console.log(s.dim(` Extension Tools: ${n.length}`)),o.defaults.activeTools!==void 0&&console.log(s.dim(` Active Tools: ${o.defaults.activeTools.join(", ")||"(none)"}`)),(o.defaults.modelSelection.provider||o.defaults.modelSelection.model)&&console.log(s.dim(` Model Override: ${o.defaults.modelSelection.provider??"(inherit)"} / ${o.defaults.modelSelection.model??"(inherit)"}`)),o.defaults.thinkingLevel&&console.log(s.dim(` Thinking: ${o.defaults.thinkingLevel}`)),console.log(),o.loadedExtensions.length>0){console.log(s.bold("Loaded Extensions:"));for(let t of o.loadedExtensions)console.log(s.dim(` - ${t.label} [${t.loadSource}] (${t.path})`));console.log()}if(o.commands.length>0){console.log(s.bold("Extension Commands:"));for(let t of o.commands){let r=t.aliases?.length?` [${t.aliases.join(", ")}]`:"";console.log(s.dim(` - /${t.name}${r} ${t.description}`))}console.log()}if(o.capabilityProviders.length>0){console.log(s.bold("Capability Providers:"));for(let t of o.capabilityProviders){let r=gc(t.metadata);console.log(s.dim(` - ${t.id} [${t.kinds.join(", ")}]${r?` ${r}`:""}`))}console.log()}if(n.length>0){console.log(s.bold("Extension Tools:"));for(let t of n){let r=t.shadowedSources.length>0?` overrides: ${t.shadowedSources.map(i=>i.label??i.id??i.kind).join(", ")}`:"";console.log(s.dim(` - ${t.name}${r}`))}console.log()}if(o.hooks.length>0){console.log(s.bold("Hook Participation:"));for(let t of o.hooks)console.log(s.dim(` - ${t.hook} [#${t.order}] ${t.source.label}`));console.log()}if(o.failures.length>0){console.log(s.bold("Recent Failures:"));for(let t of o.failures.slice(-10))console.log(s.dim(` - [${t.stage}] ${t.source.label}: ${t.target} -> ${t.message}`));console.log()}},"handler")},{name:"status",aliases:["info","ctx"],description:"Show current session status",handler:a(async(e,o,n,t)=>{await cc(o,t,e)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
303
|
+
/status - Show Session Status
|
|
304
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /status ")+"Display current session information"),console.log(s.dim(" /status workspace ")+"Show deeper workspace/runtime details"),console.log(s.dim(" /info, /ctx ")+"Aliases for /status"),console.log(),console.log(s.bold("Displays:")),console.log(s.dim(" - Current mode (code/ask)")),console.log(s.dim(" - Session ID")),console.log(s.dim(" - Message count")),console.log(s.dim(" - Estimated token usage")),console.log(s.dim(" - Current workspace truth")),console.log(s.dim(" - Session timestamps")),console.log(s.dim(" - Repo-intelligence mode and active runtime summary")),console.log()},"detailedHelp")},{name:"mcp",description:"Show MCP server status or refresh catalogs",usage:"/mcp [status|refresh]",handler:a(async e=>{let o=V();if(!o){console.log(s.yellow(`
|
|
305
|
+
[No extension runtime active \u2014 MCP is not available]`));return}let t=_e(o).capabilityProviders.find(c=>c.id==="mcp");if((e[0]?.toLowerCase()??"status")==="refresh"){console.log(s.dim(`
|
|
306
|
+
Refreshing MCP catalogs...`));try{await o.refreshCapabilityProviders("mcp"),console.log(s.green("MCP catalogs refreshed."))}catch(c){console.log(s.red(`Refresh failed: ${c instanceof Error?c.message:String(c)}`))}return}if(console.log(s.cyan(`
|
|
307
|
+
MCP Status
|
|
308
|
+
`)),!t){console.log(s.yellow(" No MCP provider registered.")),console.log(s.dim(` Add mcpServers to ~/.kodax/config.json to enable MCP.
|
|
309
|
+
`));return}let l=t.metadata?.servers??[];console.log(s.dim(` Servers: ${l.length}`)),console.log();for(let c of l){let d=c.status==="ready"?s.green:c.status==="error"?s.red:s.yellow;console.log(` ${s.bold(c.serverId)} ${d(c.status)} connect=${s.dim(c.connect)}`),c.cachedAt&&console.log(s.dim(` tools=${c.tools} resources=${c.resources} prompts=${c.prompts}`)),c.lastError&&console.log(s.red(` error: ${c.lastError}`))}console.log()},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
310
|
+
/mcp - MCP Server Management
|
|
311
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /mcp ")+"Show MCP server status"),console.log(s.dim(" /mcp status ")+"Same as /mcp"),console.log(s.dim(" /mcp refresh ")+"Force-refresh all MCP server catalogs"),console.log()},"detailedHelp")},{name:"repointel",aliases:["ri"],description:"Inspect or control the repo-intelligence premium runtime",usage:"/repointel [status|mode|trace|warm|endpoint|bin]",handler:a(async(e,o,n,t)=>{let r=e[0]?.toLowerCase()??"status";if(r==="status"){let i=await Ue({mode:t.repoIntelligenceMode,trace:t.repoIntelligenceTrace,probePremium:!0});zs(i);return}if(r==="warm"){let i=await Dt({mode:t.repoIntelligenceMode,trace:t.repoIntelligenceTrace});ic(i);return}if(r==="mode"){if(e.length===1){console.log(s.dim(`
|
|
312
|
+
Current repo-intelligence mode: ${s.cyan(t.repoIntelligenceMode??"auto")}`)),console.log(s.dim(`Usage: /repointel mode [auto|off|oss|premium-shared|premium-native]
|
|
313
|
+
`));return}let i=nc(e[1]);if(!i){console.log(s.red(`
|
|
314
|
+
[Invalid repo-intelligence mode: ${e[1]}]`)),console.log(s.dim(`Usage: /repointel mode [auto|off|oss|premium-shared|premium-native]
|
|
315
|
+
`));return}let l=Bo({mode:i},{repoIntelligenceMode:i},n,t);Q(`Repo intelligence mode: ${i}`,l);return}if(r==="trace"){let i=e[1]?.toLowerCase();if(!i){console.log(s.dim(`
|
|
316
|
+
Current repo-intelligence trace: ${s.cyan(t.repoIntelligenceTrace?"on":"off")}`)),console.log(s.dim(`Usage: /repointel trace [on|off|toggle]
|
|
317
|
+
`));return}let l=tc(i,t.repoIntelligenceTrace??!1);if(l===null){console.log(s.red(`
|
|
318
|
+
[Invalid trace value: ${e[1]}]`)),console.log(s.dim(`Usage: /repointel trace [on|off|toggle]
|
|
319
|
+
`));return}let c=Bo({trace:l},{repoIntelligenceTrace:l},n,t);Q(`Repo intelligence trace: ${l?"on":"off"}`,c);return}if(r==="endpoint"){if(e.length===1){let c=await Ue({mode:t.repoIntelligenceMode,trace:t.repoIntelligenceTrace});console.log(s.dim(`
|
|
320
|
+
Current repointel endpoint: ${s.cyan(c.endpoint)}`)),console.log(s.dim(`Usage: /repointel endpoint [http://host:port|default]
|
|
321
|
+
`));return}let i=js(e[1]),l=Bo({endpoint:i},{repointelEndpoint:i??void 0},n,t);Q(`Repointel endpoint: ${i??"default"}`,l);return}if(r==="bin"){if(e.length===1){let c=await Ue({mode:t.repoIntelligenceMode,trace:t.repoIntelligenceTrace});console.log(s.dim(`
|
|
322
|
+
Current repointel bin: ${s.cyan(c.bin)}`)),console.log(s.dim(`Usage: /repointel bin [<path-or-command>|default]
|
|
323
|
+
`));return}let i=js(e.slice(1).join(" ")),l=Bo({bin:i},{repointelBin:i??void 0},n,t);Q(`Repointel bin: ${i??"default"}`,l);return}console.log(s.red(`
|
|
324
|
+
[Unknown /repointel subcommand: ${e[0]}]`)),console.log(s.dim(`Usage: /repointel [status|mode|trace|warm|endpoint|bin]
|
|
325
|
+
`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
326
|
+
/repointel - Repo-Intelligence Runtime Control
|
|
327
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /repointel ")+"Show current repo-intelligence and premium runtime status"),console.log(s.dim(" /repointel status ")+"Probe the local premium frontdoor and print detailed status"),console.log(s.dim(" /repointel mode auto ")+"Prefer premium-native when available, otherwise fall back to OSS"),console.log(s.dim(" /repointel mode off ")+"Strictly disable repo-intelligence working tools and auto lane for this session"),console.log(s.dim(" /repointel mode oss ")+"Force the OSS baseline only"),console.log(s.dim(" /repointel mode premium-shared ")+"Use premium without KodaX native auto lane"),console.log(s.dim(" /repointel mode premium-native ")+"Use the KodaX flagship premium path"),console.log(s.dim(" /repointel trace on|off|toggle ")+"Toggle repo-intelligence trace output"),console.log(s.dim(" /repointel endpoint http://127.0.0.1:47891")+"Override the local premium daemon endpoint"),console.log(s.dim(" /repointel endpoint default ")+"Clear the endpoint override and use the default"),console.log(s.dim(" /repointel bin repointel ")+"Use a PATH-visible repointel command"),console.log(s.dim(" /repointel bin <path> ")+"Use an explicit repointel launcher path"),console.log(s.dim(" /repointel bin default ")+"Clear the bin override and use the default command"),console.log(s.dim(" /repointel warm ")+"Try to start or warm the local premium daemon"),console.log(),console.log(s.bold("Notes:")),console.log(s.dim(" - /status now includes a compact repo-intelligence summary.")),console.log(s.dim(" - /repointel warm is operational: it can warm the premium runtime even when your current mode is oss/off.")),console.log(s.dim(" - If the local service cannot be started, KodaX will continue with the OSS baseline and this command will explain why.")),console.log()},"detailedHelp")},{name:"fallback",description:"Configure the cross-provider fallback chain for child tasks",usage:"/fallback [status | <p1,p2,...> | off]",handler:a(async(e,o,n,t)=>{let r=(process.env.KODAX_FALLBACK_PROVIDERS??"").split(",").map(c=>c.trim()).filter(Boolean),i=e[0]?.toLowerCase();if(!i||i==="status"){r.length===0?console.log(s.dim(`
|
|
328
|
+
Child-task provider fallback: `)+s.yellow("off")+s.dim(" (no chain configured)")):(console.log(s.dim(`
|
|
329
|
+
Child-task provider fallback: `)+s.green("on")),console.log(s.dim(" Order: ")+s.cyan(r.join(" \u2192 ")))),console.log(s.dim(`
|
|
330
|
+
When a child's primary provider is exhausted/down, KodaX re-runs it`)),console.log(s.dim(` on the next provider in this list. Set: /fallback ark-coding,kimi-code
|
|
331
|
+
`));return}if(i==="off"||i==="clear"||i==="none"){de({fallbackProviders:void 0}),delete process.env.KODAX_FALLBACK_PROVIDERS,console.log(s.green(`
|
|
332
|
+
\u2713 `)+s.dim(`Child-task provider fallback disabled.
|
|
333
|
+
`));return}let l=e.join(",").split(",").map(c=>c.trim()).filter(Boolean);if(l.length===0){console.log(s.red(`
|
|
334
|
+
[/fallback: no provider ids given]`)),console.log(s.dim(`Usage: /fallback ark-coding,kimi-code (or /fallback off)
|
|
335
|
+
`));return}de({fallbackProviders:l}),process.env.KODAX_FALLBACK_PROVIDERS=l.join(","),console.log(s.green(`
|
|
336
|
+
\u2713 `)+s.dim("Child-task fallback order: ")+s.cyan(l.join(" \u2192 "))),console.log(s.dim(` Provider ids must match your configured providers (see /status or kodax doctor).
|
|
337
|
+
`))},"handler")},{name:"mode",description:"Show or switch permission mode (plan/accept-edits/auto)",usage:"/mode [plan|accept-edits|auto]",handler:a(async(e,o,n,t)=>{if(e.length===0){let i=qe(t.permissionMode,"accept-edits")??"accept-edits";console.log(s.dim(`
|
|
338
|
+
Current mode: ${s.cyan(i)}`)),console.log(s.dim("Usage: /mode [plan|accept-edits|auto]"));return}let r=e[0];wo.includes(r)?(t.permissionMode=r,n.setPermissionMode?.(r),xn(r),console.log(s.cyan(`
|
|
339
|
+
[Switched to ${r} mode] (saved)`))):console.log(s.red(`
|
|
340
|
+
[Unknown mode: ${e[0]}. Use: plan | accept-edits | auto]`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
341
|
+
/mode - Switch Permission Mode
|
|
342
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /mode ")+"Show current permission mode"),console.log(s.dim(" /mode plan ")+"Read-only: blocks all modifications"),console.log(s.dim(" /mode accept-edits ")+"File edits auto, bash requires confirmation"),console.log(s.dim(" /mode auto ")+"LLM classifier reviews each tool call (FEATURE_092)"),console.log(s.dim(" /mode auto-in-project ")+s.gray("(deprecated alias for auto; will be removed in v0.7.38)")),console.log(),console.log(s.bold("Permission Levels:")),console.log(s.yellow(" plan ")+s.dim("- Read-only planning, no file/command modifications")),console.log(s.green(" accept-edits ")+s.dim("- File edits auto-approved, bash still requires confirmation")),console.log(s.green(" auto ")+s.dim("- LLM classifier (engine=llm, default) or rules engine reviews each call")),console.log(),console.log(s.bold("Notes:")),console.log(s.dim(" - .kodax/ directory and project-external paths always require confirmation")),console.log(s.dim(" - Mode is saved to ~/.kodax/config.json (user-level)")),console.log()},"detailedHelp")},{name:"auto-engine",description:"Show or set auto-mode classifier engine (llm | rules)",usage:"/auto-engine [llm|rules]",handler:a(async(e,o,n)=>{let t=n.getAutoModeStats?.();if(!t){console.log(s.yellow(`
|
|
343
|
+
[auto-engine] not in auto mode \u2014 switch via /mode auto first`));return}if(e.length===0){console.log(s.dim(`
|
|
344
|
+
Classifier engine: ${s.cyan(t.engine)}`)),console.log(s.dim(` consecutive denials: ${t.denials.consecutive}`)),console.log(s.dim(` cumulative denials: ${t.denials.cumulative}`)),console.log(s.dim(` breaker errors: ${t.breaker.timestamps.filter(i=>i>=Date.now()-600*1e3).length}`)),console.log(s.dim("Usage: /auto-engine [llm|rules]"));return}let r=e[0];if(r!=="llm"&&r!=="rules"){console.log(s.red(`
|
|
345
|
+
[auto-engine] unknown engine "${e[0]}" \u2014 use llm or rules`));return}n.setAutoModeEngine?.(r),console.log(s.cyan(`
|
|
346
|
+
[auto-engine] switched to ${r}`)),console.log(r==="rules"?s.dim(" every non-Tier-1 tool call now escalates to user confirmation"):s.dim(" classifier consultation resumed; threshold downgrades still apply"))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
347
|
+
/auto-engine - Auto-Mode Classifier Engine Toggle
|
|
348
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /auto-engine ")+"Show current engine + denial/breaker counts"),console.log(s.dim(" /auto-engine llm ")+"Resume classifier consultation (default)"),console.log(s.dim(" /auto-engine rules ")+"Skip classifier; every non-Tier-1 call asks user"),console.log(),console.log(s.bold("Notes:")),console.log(s.dim(" - Only meaningful in auto mode (/mode auto).")),console.log(s.dim(" - The classifier may auto-downgrade to rules after 3 consecutive blocks,")),console.log(s.dim(" 20 cumulative blocks, or 5 errors in a 10-minute window. /auto-engine llm")),console.log(s.dim(" manually flips back to llm.")),console.log(s.dim(" - Override via env: KODAX_AUTO_MODE_ENGINE=rules.")),console.log()},"detailedHelp")},{name:"auto-denials",description:"Show auto-mode classifier denial tracker + circuit breaker stats",usage:"/auto-denials",handler:a(async(e,o,n)=>{let t=n.getAutoModeStats?.();if(!t){console.log(s.yellow(`
|
|
349
|
+
[auto-denials] not in auto mode \u2014 switch via /mode auto first`));return}console.log(s.cyan(`
|
|
350
|
+
[auto-mode classifier stats]`)),console.log(s.dim(` engine: ${s.cyan(t.engine)}`)),console.log(s.dim(" Denial tracker:")),console.log(s.dim(` consecutive blocks: ${t.denials.consecutive} / 3`)),console.log(s.dim(` cumulative blocks: ${t.denials.cumulative} / 20`)),console.log(s.dim(" Circuit breaker:")),console.log(s.dim(` errors in window: ${t.breaker.timestamps.filter(r=>r>=Date.now()-600*1e3).length} / 5 (10 min)`)),console.log(),t.engine==="rules"&&console.log(s.yellow(" \u21AA engine has downgraded to rules. /auto-engine llm to flip back.")),console.log()},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
351
|
+
/auto-denials - Auto-Mode Classifier Diagnostic Dump
|
|
352
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /auto-denials ")+"Print engine + tracker + breaker counters"),console.log(),console.log(s.bold("Thresholds (FEATURE_092):")),console.log(s.dim(" - 3 consecutive blocks \u2192 engine downgrade to rules")),console.log(s.dim(" - 20 cumulative blocks \u2192 engine downgrade to rules")),console.log(s.dim(" - 5 errors in 10-min \u2192 circuit breaker trips \u2192 engine downgrade")),console.log()},"detailedHelp")},{name:"save",description:"Save current session",handler:a(async(e,o,n)=>{await n.saveSession(),console.log(s.green(`
|
|
353
|
+
[Session saved]`)),ft(o)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
354
|
+
/save - Save Current Session
|
|
355
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /save ")+"Save current conversation to session storage"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Manually saves the current conversation session.")),console.log(s.dim(" Sessions are auto-saved after each message, but you can")),console.log(s.dim(" use this to ensure the session is persisted.")),console.log(s.dim(" Saving updates session storage only; the current workspace stays untouched.")),console.log(),console.log(s.dim(" See also: /help load, /help sessions")),console.log()},"detailedHelp")},{name:"load",aliases:["resume"],description:"Load a session",usage:"/load <session-id>",handler:a(async(e,o,n)=>{if(e.length===0){console.log(s.red(`
|
|
356
|
+
[Usage: /load <session-id>]`)),await n.listSessions();return}await n.loadSession(e[0])==="missing"&&console.log(s.red(`
|
|
357
|
+
[Session not found: ${e[0]}]`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
358
|
+
/load - Load a Saved Session
|
|
359
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /load ")+"List available sessions"),console.log(s.dim(" /load <session-id> ")+"Load a specific session"),console.log(s.dim(" /resume <id> ")+"Alias for /load"),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /load ")+"# See all sessions"),console.log(s.dim(" /load 20260219_143052")+"# Load session by ID"),console.log(),console.log(s.bold("Workspace behavior:")),console.log(s.dim(" /load can resume sessions from sibling workspaces in the same canonical repo.")),console.log(s.dim(" If a saved workspace is unavailable, KodaX explains the fallback before loading.")),console.log(),console.log(s.dim(" See also: /help sessions, /help save")),console.log()},"detailedHelp")},{name:"tree",description:"Inspect or switch the current session tree",usage:"/tree [entry-id|label] | /tree label <entry-id|label> <name> | /tree unlabel <entry-id|label>",handler:a(async(e,o,n)=>{if(e.length===0){await n.printSessionTree?.();return}let t=e[0]?.trim().toLowerCase();if(t==="label"){if(e.length<3){console.log(s.red(`
|
|
360
|
+
[Usage: /tree label <entry-id|label> <name>]`));return}await n.labelSessionBranch?.(e[1],e.slice(2).join(" "))||console.log(s.red(`
|
|
361
|
+
[Tree entry not found: ${e[1]}]`));return}if(t==="unlabel"){if(e.length<2){console.log(s.red(`
|
|
362
|
+
[Usage: /tree unlabel <entry-id|label>]`));return}await n.labelSessionBranch?.(e[1],void 0)||console.log(s.red(`
|
|
363
|
+
[Tree entry not found: ${e[1]}]`));return}await n.switchSessionBranch?.(e[0])==="missing"&&console.log(s.red(`
|
|
364
|
+
[Tree entry not found: ${e[0]}]`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
365
|
+
/tree - Inspect Session Lineage
|
|
366
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /tree ")+"Show the current session tree"),console.log(s.dim(" /tree <entry-id|label> ")+"Jump to a previous branch point"),console.log(s.dim(" /tree label <entry-id|label> <name>")+"Attach a lightweight checkpoint label"),console.log(s.dim(" /tree unlabel <entry-id|label> ")+"Clear an existing checkpoint label"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Session history is stored as a branchable tree. Use /tree to")),console.log(s.dim(" inspect the lineage, revisit an earlier branch safely, and add")),console.log(s.dim(" bookmark-style checkpoint labels without changing git state.")),console.log()},"detailedHelp")},{name:"fork",description:"Fork the current branch into a new session",usage:"/fork [entry-id|label]",handler:a(async(e,o,n)=>{await n.forkSession?.(e[0])==="failed"&&console.log(s.red(`
|
|
367
|
+
[Unable to fork session${e[0]?` from ${e[0]}`:""}]`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
368
|
+
/fork - Export a Branch to a New Session
|
|
369
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /fork ")+"Fork from the active branch"),console.log(s.dim(" /fork <entry-id|label>")+"Fork from a selected tree node"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Creates a new session file from the selected branch so you can")),console.log(s.dim(" continue there without mutating the current session lineage.")),console.log()},"detailedHelp")},{name:"rewind",description:"Rewind the current session to a previous point",usage:"/rewind [entry-id|label]",handler:a(async(e,o,n)=>{await n.rewindSession?.(e[0])==="failed"&&console.log(s.red(`
|
|
370
|
+
[Unable to rewind${e[0]?` to ${e[0]}`:" \u2014 no previous turn found"}]`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
371
|
+
/rewind - Rewind Session to a Previous Point
|
|
372
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /rewind ")+"Rewind to the previous user input"),console.log(s.dim(" /rewind <entry-id|label>")+"Rewind to a specific tree node"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Truncates the session after the target entry. Unlike /fork,")),console.log(s.dim(" this modifies the current session in place. The rewind event")),console.log(s.dim(" is recorded in the lineage for auditability.")),console.log(),console.log(s.yellow(" \u26A0 This is irreversible. Use /fork first to preserve a copy.")),console.log()},"detailedHelp")},{name:"sessions",aliases:["ls","list"],description:"List recent sessions",handler:a(async(e,o,n)=>{await n.listSessions()},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
373
|
+
/sessions - List Saved Sessions
|
|
374
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /sessions ")+"List all saved sessions"),console.log(s.dim(" /ls, /list ")+"Aliases for /sessions"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Shows recent conversation sessions with their IDs,")),console.log(s.dim(" message counts, titles, and workspace truth. Use /load <id> to resume.")),console.log(s.dim(" This keeps sibling worktree sessions inspectable without a persistent cockpit.")),console.log(),console.log(s.dim(" See also: /help load, /help delete")),console.log()},"detailedHelp")},{name:"history",aliases:["hist"],description:"Show conversation history",handler:a(async(e,o,n)=>{n.printHistory()},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
375
|
+
/history - Show Conversation History
|
|
376
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /history ")+"Display recent messages in current session"),console.log(s.dim(" /hist ")+"Alias for /history"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Shows the last 20 messages in the current conversation.")),console.log(s.dim(" Useful for reviewing what has been discussed.")),console.log()},"detailedHelp")},{name:"delete",aliases:["rm","del"],description:"Delete a session",usage:"/delete <session-id> or /delete all",handler:a(async(e,o,n)=>{if(e.length===0){console.log(s.red(`
|
|
377
|
+
[Usage: /delete <session-id> or /delete all]`)),await n.listSessions?.();return}e[0]==="all"?(await n.deleteAllSessions?.(),console.log(s.green(`
|
|
378
|
+
[All sessions deleted]`)),ft(o)):(await n.deleteSession?.(e[0]),console.log(s.green(`
|
|
379
|
+
[Session deleted: ${e[0]}]`)),ft(o))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
380
|
+
/delete - Delete Saved Sessions
|
|
381
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /delete ")+"Show usage (lists sessions)"),console.log(s.dim(" /delete <id> ")+"Delete a specific session"),console.log(s.dim(" /delete all ")+"Delete ALL sessions"),console.log(s.dim(" /rm, /del ")+"Aliases for /delete"),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /delete 20260219_143052")+" # Delete specific session"),console.log(s.dim(" /delete all ")+"# Delete all sessions"),console.log(),console.log(s.bold("Workspace behavior:")),console.log(s.dim(" Deletes saved session records only.")),console.log(s.dim(" Current workspaces and checkouts remain untouched.")),console.log(),console.log(s.yellow(" Warning: /delete all cannot be undone!")),console.log()},"detailedHelp")},{name:"model",aliases:["m"],description:"Show or switch provider/model",usage:"/model [<provider>[/<model>] | /<model>]",handler:a(async(e,o,n,t)=>{let r=po().providerModels;if(e.length===0){console.log(s.bold(`
|
|
382
|
+
Available Providers:
|
|
383
|
+
`));let c=rr(r);for(let d of c){let u=d.configured?s.green("[configured]"):s.red("[not configured]"),m=d.custom?s.yellow(" [custom]"):"",f=d.name===t.provider,h=f?s.cyan(" *"):"";console.log(` ${s.bold(d.name)}${h} ${u}${m}`),d.capabilityProfile.transport==="cli-bridge"&&console.log(s.yellow(` ! ${ln(d.capabilityProfile)}`));let k=Re(d.name,r),y=f?t.model:null;for(let v of k){let I=f&&(y===v||!y&&v===d.model)?s.cyan(">"):" ";console.log(` ${I} ${v}`)}console.log()}console.log(s.dim(`Current: provider=${t.provider}${t.model?`, model=${t.model}`:""}`)),console.log(s.dim("Usage:")),console.log(s.dim(" /model <provider> Switch provider")),console.log(s.dim(" /model <provider>/<model> Switch to specific model")),console.log(s.dim(` /model /<model> Switch model within current provider
|
|
384
|
+
`));return}let i=(e[0]??"").trim();if(!i)return;if(i.startsWith("/")){let c=i.slice(1);if(!c){console.log(s.red(`
|
|
385
|
+
[Missing model name after /]`));return}let d=Re(t.provider,r);if(!d.includes(c)){console.log(s.red(`
|
|
386
|
+
[Unknown model: ${c}]`)),console.log(s.dim(`Available models for ${t.provider}: ${d.join(", ")}
|
|
387
|
+
`));return}de({model:c}),n.switchProvider?.(t.provider,c),console.log(s.cyan(`
|
|
388
|
+
[Switched to ${c}] (saved)`));return}if(i.includes("/")){let c=i.indexOf("/"),d=i.slice(0,c),u=i.slice(c+1);if(!u||!d){console.log(s.red(`
|
|
389
|
+
[Invalid format. Use: /model <provider>/<model>]`));return}if(!$e(d)){console.log(s.red(`
|
|
390
|
+
[Unknown provider: ${d}]`)),console.log(s.dim(`Available: ${Se().join(", ")}
|
|
391
|
+
`));return}let m=Re(d,r);if(!m.includes(u)){console.log(s.red(`
|
|
392
|
+
[Unknown model: ${u}]`)),console.log(s.dim(`Available models for ${d}: ${m.join(", ")}
|
|
393
|
+
`));return}de({provider:d,model:u}),n.switchProvider?.(d,u),console.log(s.cyan(`
|
|
394
|
+
[Switched to ${d}/${u}] (saved)`));return}let l=i;$e(l)?(de({provider:l,model:void 0}),n.switchProvider?.(l),console.log(s.cyan(`
|
|
395
|
+
[Switched to ${l}] (saved)`))):(console.log(s.red(`
|
|
396
|
+
[Unknown provider: ${l}]`)),console.log(s.dim(`Available: ${Se().join(", ")}
|
|
397
|
+
`)))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
398
|
+
/model - Switch LLM Provider/Model
|
|
399
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /model ")+"List all providers with models"),console.log(s.dim(" /model <provider> ")+"Switch to a provider (default model)"),console.log(s.dim(" /model <provider>/<model> ")+"Switch to a specific model"),console.log(s.dim(" /model /<model> ")+"Switch model within current provider"),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /model ")+"# See available providers & models"),console.log(s.dim(" /model anthropic ")+"# Switch to Anthropic (default model)"),console.log(s.dim(" /model openai/gpt-5.4 ")+"# Switch to OpenAI GPT-5.4"),console.log(s.dim(" /model /claude-opus-4-6 ")+"# Switch to Opus within current provider"),console.log()},"detailedHelp")},{name:"provider",description:"Inspect provider semantics and policy constraints",usage:"/provider [<provider>[/<model>]]",handler:a(async(e,o,n,t)=>{let r=(e[0]??"").trim(),i=t.provider,l=t.model;if(r)if(r.includes("/")){let u=r.indexOf("/");i=r.slice(0,u).trim(),l=r.slice(u+1).trim()||void 0}else i=r,l=void 0;if(!$e(i)){console.log(s.red(`
|
|
400
|
+
[Unknown provider: ${i}]`)),console.log(s.dim(`Available: ${Se().join(", ")}
|
|
401
|
+
`));return}let c=nr(i,l);if(!c){console.log(s.red(`
|
|
402
|
+
[Provider details unavailable: ${i}]`)),console.log();return}let d=ar(i,l,t.reasoningMode);console.log(s.bold(`
|
|
403
|
+
Provider Details:
|
|
404
|
+
`)),console.log(s.dim(` Provider: ${s.cyan(c.provider)}${c.model?` / ${s.cyan(c.model)}`:""}`)),console.log(s.dim(` Source: ${sr(c.sourceKind)}`)),console.log(),console.log(s.bold("Capability Matrix:"));for(let u of ir(c))console.log(s.dim(` - ${u}`));if(console.log(),d.length>0){console.log(s.bold("Common Scenarios:"));for(let u of d){let m=u.decision.status==="block"?s.red:u.decision.status==="warn"?s.yellow:s.green;console.log(m(` - ${u.label}: ${u.decision.status.toUpperCase()}`)),console.log(s.dim(` ${u.decision.summary}`))}console.log()}},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
405
|
+
/provider - Inspect Provider Semantics
|
|
406
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /provider ")+"Inspect the current provider/model"),console.log(s.dim(" /provider <provider> ")+"Inspect a provider using its default model"),console.log(s.dim(" /provider <provider>/<model> ")+"Inspect a specific provider/model pair"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Shows the provider capability matrix and common 029 policy outcomes.")),console.log(s.dim(" Use this to understand why long-running, harness, or evidence-heavy flows may warn or block.")),console.log()},"detailedHelp")},{name:"thinking",aliases:["think","t"],description:"Show or change reasoning mode (compat alias)",usage:"/thinking [on|off|auto|quick|balanced|deep]",handler:a(async(e,o,n,t)=>{if(e.length===0){let i=an(t.provider,t.model),l=t.thinking?s.green("ON"):s.dim("OFF");console.log(s.dim(`
|
|
407
|
+
Thinking: ${l}`)),console.log(s.dim(`Reasoning mode: ${s.cyan(t.reasoningMode)}`)),console.log(s.dim(`Effective control: ${s.cyan(cn(i))}`)),console.log(s.dim(`Actual execution: ${dn(t.reasoningMode,i)}`)),console.log(s.dim(`Usage: /thinking on|off|auto|quick|balanced|deep
|
|
408
|
+
`));return}let r=e[0].toLowerCase();if(r==="on"||r==="off"||en.includes(r)){let i=r==="on"?"auto":r==="off"?"off":r,l=Hs(i,n,t);Q(`Reasoning mode: ${i}`,l);return}console.log(s.red(`
|
|
409
|
+
[Invalid value: ${e[0]}]`)),console.log(s.dim(`Usage: /thinking on|off|auto|quick|balanced|deep
|
|
410
|
+
`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
411
|
+
/thinking - Legacy Alias for Reasoning Mode
|
|
412
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /thinking ")+"Show current reasoning status"),console.log(s.dim(" /thinking on ")+"Map to /reasoning auto"),console.log(s.dim(" /thinking off ")+"Map to /reasoning off"),console.log(s.dim(" /thinking auto ")+"Set reasoning mode to auto"),console.log(s.dim(" /thinking quick ")+"Set reasoning mode to quick"),console.log(s.dim(" /thinking balanced ")+"Set reasoning mode to balanced"),console.log(s.dim(" /thinking deep ")+"Set reasoning mode to deep"),console.log(s.dim(" /t ")+"Alias for /thinking"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Compatibility command for the new unified reasoning modes.")),console.log(s.dim(" Use /reasoning for the primary interface.")),console.log()},"detailedHelp")},{name:"reasoning",aliases:["reason"],description:"Show or set reasoning mode",usage:"/reasoning [off|auto|quick|balanced|deep]",handler:a(async(e,o,n,t)=>{if(e.length===0){let l=an(t.provider,t.model);console.log(s.dim(`
|
|
413
|
+
Reasoning mode: ${s.cyan(t.reasoningMode)}`)),console.log(s.dim(`Thinking compatibility: ${t.thinking?s.green("ON"):s.dim("OFF")}`)),console.log(s.dim(`Effective control: ${s.cyan(cn(l))}`)),console.log(s.dim(`Actual execution: ${dn(t.reasoningMode,l)}`)),console.log(s.dim(`Usage: /reasoning off|auto|quick|balanced|deep
|
|
414
|
+
`));return}let r=e[0].toLowerCase();if(!en.includes(r)){console.log(s.red(`
|
|
415
|
+
[Invalid reasoning mode: ${e[0]}]`)),console.log(s.dim(`Usage: /reasoning off|auto|quick|balanced|deep
|
|
416
|
+
`));return}let i=Hs(r,n,t);Q(`Reasoning mode: ${r}`,i)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
417
|
+
/reasoning - Set Reasoning Mode
|
|
418
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /reasoning ")+"Show current reasoning mode"),console.log(s.dim(" /reasoning off ")+"Disable reasoning"),console.log(s.dim(" /reasoning auto ")+"Use semantic routing + adaptive depth"),console.log(s.dim(" /reasoning quick ")+"Low-depth reasoning"),console.log(s.dim(" /reasoning balanced ")+"Medium-depth reasoning"),console.log(s.dim(" /reasoning deep ")+"High-depth reasoning"),console.log(s.dim(" /reasoning:auto ")+"Inline form, equivalent to /reasoning auto"),console.log(s.dim(" /reason ")+"Alias for /reasoning"),console.log()},"detailedHelp")},{name:"agent-mode",aliases:["am"],description:"Show or set agent mode",usage:"/agent-mode [ama|amaw|ama-workflow|sa|toggle]",handler:a(async(e,o,n,t)=>{if(e.length===0){console.log(s.dim(`
|
|
419
|
+
Agent mode: ${s.cyan(t.agentMode.toUpperCase())}`)),console.log(s.dim(`Usage: /agent-mode [ama|amaw|ama-workflow|sa|toggle]
|
|
420
|
+
`));return}let r=e[0]?.toLowerCase(),i=r==="toggle"?jr(t.agentMode):r==="ama"||r==="sa"||r==="amaw"?r:r==="ama-workflow"?"amaw":void 0;if(!i){console.log(s.red(`
|
|
421
|
+
[Invalid agent mode: ${e[0]}]`)),console.log(s.dim(`Usage: /agent-mode [ama|amaw|ama-workflow|sa|toggle]
|
|
422
|
+
`));return}let l=rc(i,n,t);Q(`Agent mode: ${i.toUpperCase()}`,l)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
423
|
+
/agent-mode - Adaptive Multi-Agent Mode Control
|
|
424
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /agent-mode ")+"Show current agent mode"),console.log(s.dim(" /agent-mode ama ")+"Enable adaptive multi-agent mode"),console.log(s.dim(" /agent-mode amaw ")+"Enable AMA Workflow mode; generated workflows may start automatically"),console.log(s.dim(" /agent-mode ama-workflow")+"Alias for /agent-mode amaw"),console.log(s.dim(" /agent-mode sa ")+"Force single-agent execution"),console.log(s.dim(" /agent-mode toggle ")+"Cycle AMA -> AMAW -> SA"),console.log(s.dim(" /am ")+"Alias for /agent-mode"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" AMA keeps adaptive multi-agent harness selection enabled and supports explicit /workflow.")),console.log(s.dim(" AMAW keeps AMA behavior and may silently start restricted generated workflows.")),console.log(s.dim(" SA keeps routing and task artifacts, but forces single-agent execution to save tokens.")),console.log()},"detailedHelp")},{name:"auto",aliases:["a"],description:"Quick switch to auto mode",handler:a(async(e,o,n,t)=>{t.permissionMode="auto",n.setPermissionMode?.("auto"),xn("auto"),console.log(s.cyan(`
|
|
425
|
+
[Switched to auto mode] (saved)`))},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
426
|
+
/auto - Quick Switch to Auto Mode
|
|
427
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /auto ")+"Switch to auto mode"),console.log(s.dim(" /a ")+"Alias for /auto"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" Equivalent to /mode auto.")),console.log(s.dim(" Auto-mode classifier evaluates each non-Tier-1 tool call;")),console.log(s.dim(" benign actions auto-approve, risky ones escalate to user confirm.")),console.log(),console.log(s.dim(" See also: /help mode, /auto-engine, /auto-denials")),console.log()},"detailedHelp")},{name:"skills",description:"(Deprecated) Use /skill instead",usage:"/skill",handler:a(async(e,o)=>{console.log(s.dim(`
|
|
428
|
+
[/skills is deprecated. Use /skill instead]`)),await qs(e,o)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
429
|
+
/skills - Deprecated
|
|
430
|
+
`)),console.log(s.yellow("This command is deprecated. Use /skill instead.")),console.log(),console.log(s.dim(" /skill ")+"List all available skills"),console.log(s.dim(" /skill:<name> ")+"Invoke a skill"),console.log()},"detailedHelp")},{name:"skill",description:"Skill namespace - invoke skills with /skill:name",usage:"/skill[:name] [args]",handler:a(async(e,o,n,t)=>{await qs(e,o)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
431
|
+
/skill - Skill Namespace
|
|
432
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /skill ")+"List all available skills"),console.log(s.dim(" /skill:<name> [args] ")+"Invoke a skill by name"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" This is the pi-mono style skill invocation format.")),console.log(s.dim(" Skills can also be triggered by natural language - just ask!")),console.log(),console.log(s.bold("Examples:")),console.log(s.dim(" /skill ")+"# List all skills"),console.log(s.dim(" /skill:code-review src/ ")+"# Invoke code-review skill"),console.log(s.dim(" /skill:tdd auth ")+"# Invoke TDD skill"),console.log()},"detailedHelp")},{name:"verifier-log",description:"Toggle Sidecar Verifier log line (off by default)",usage:"/verifier-log [on|off]",argumentHint:"on | off",handler:a(async e=>{let o=e[0]?.toLowerCase(),n=process.env.KODAX_VERIFIER_LOG==="1";if(!o){let i=po().verifierLog===!0,l=n?"on":"off",c=i===n?"":` (env=${n?"on":"off"}, config=${i?"on":"off"})`;console.log(s.dim(`
|
|
433
|
+
Sidecar Verifier log: ${s.cyan(l)}${c}`)),console.log(s.dim(" When on, a one-line summary persists per verifier call:\n `[Sidecar Verifier] {verdict} \xB7 {provider}/{model} \xB7 {ms}ms \xB7 {trace}`")),console.log(s.dim(`Usage: /verifier-log [on|off]
|
|
434
|
+
`));return}let t;if(o==="on"||o==="true"||o==="1")t=!0;else if(o==="off"||o==="false"||o==="0")t=!1;else{console.log(s.red(`
|
|
435
|
+
[Invalid value: ${e[0]}]`)),console.log(s.dim(`Usage: /verifier-log [on|off]
|
|
436
|
+
`));return}t?process.env.KODAX_VERIFIER_LOG="1":delete process.env.KODAX_VERIFIER_LOG;let r=io({verifierLog:t});Q(`Sidecar Verifier log: ${t?"on":"off"}`,r)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
437
|
+
/verifier-log - Sidecar Verifier Log Toggle
|
|
438
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /verifier-log ")+"Show current state"),console.log(s.dim(" /verifier-log on ")+"Enable + persist to config"),console.log(s.dim(" /verifier-log off ")+"Disable + persist to config"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" The Sidecar Verifier is the second-pass LLM judgment that fires")),console.log(s.dim(" after a Worker terminates text-only. Off by default (silent happy")),console.log(s.dim(" path). When on, every verifier call emits a one-line summary:")),console.log(s.dim(" [Sidecar Verifier] accept \xB7 anthropic/claude-sonnet-4-6 \xB7 3214ms \xB7 verifier_ok")),console.log(),console.log(s.bold("Equivalent env var:")),console.log(s.dim(" KODAX_VERIFIER_LOG=1 ")+"Same effect, env wins over config"),console.log()},"detailedHelp")},{name:"stall-log",description:"Toggle Stall Sidecar log line (off by default)",usage:"/stall-log [on|off]",argumentHint:"on | off",handler:a(async e=>{let o=e[0]?.toLowerCase(),n=process.env.KODAX_STALL_LOG==="1";if(!o){let i=po().stallLog===!0,l=n?"on":"off",c=i===n?"":` (env=${n?"on":"off"}, config=${i?"on":"off"})`;console.log(s.dim(`
|
|
439
|
+
Stall Sidecar log: ${s.cyan(l)}${c}`)),console.log(s.dim(" When on, a one-line summary persists per L2 stall verdict:\n `[Stall Sidecar] isStuck={true|false} \xB7 {provider}/{model} \xB7 {ms}ms \xB7 {trace}`")),console.log(s.dim(`Usage: /stall-log [on|off]
|
|
440
|
+
`));return}let t;if(o==="on"||o==="true"||o==="1")t=!0;else if(o==="off"||o==="false"||o==="0")t=!1;else{console.log(s.red(`
|
|
441
|
+
[Invalid value: ${e[0]}]`)),console.log(s.dim(`Usage: /stall-log [on|off]
|
|
442
|
+
`));return}t?process.env.KODAX_STALL_LOG="1":delete process.env.KODAX_STALL_LOG;let r=io({stallLog:t});Q(`Stall Sidecar log: ${t?"on":"off"}`,r)},"handler"),detailedHelp:a(()=>{console.log(s.cyan(`
|
|
443
|
+
/stall-log - Stall Sidecar Log Toggle
|
|
444
|
+
`)),console.log(s.bold("Usage:")),console.log(s.dim(" /stall-log ")+"Show current state"),console.log(s.dim(" /stall-log on ")+"Enable + persist to config"),console.log(s.dim(" /stall-log off ")+"Disable + persist to config"),console.log(),console.log(s.bold("Description:")),console.log(s.dim(" The Stall Sidecar (FEATURE_178) is the L2 anti-loop LLM judge that")),console.log(s.dim(" fires when the L1 rule-based detector spots a repeat-tool pattern.")),console.log(s.dim(" Off by default (silent happy path). When on, every L2 verdict emits")),console.log(s.dim(" a one-line summary:")),console.log(s.dim(" [Stall Sidecar] isStuck=true \xB7 zhipu/glm-5.1 (inherit) \xB7 1842ms \xB7 sidecar_ok")),console.log(),console.log(s.bold("Equivalent env var:")),console.log(s.dim(" KODAX_STALL_LOG=1 ")+"Same effect, env wins over config"),console.log()},"detailedHelp")},Cn,En,rs,Ws,nt,_s],Zl={General:["help","copy","exit","clear","compact","reload","extensions","status"],Permission:["mode","auto"],Session:["new","save","load","sessions","history","delete"],Settings:["model","provider","thinking","reasoning","agent-mode","plan","repointel"],Skills:["skill"]};function Ql(e){let o=Ko();return e.map(n=>o.get(n)).filter(n=>n!==void 0).filter(n=>n.userInvocable!==!1)}a(Ql,"getCommandsForCategory");function ec(e){return e!=="off"}a(ec,"reasoningModeToLegacyThinking");var oc=["auto","off","oss","premium-shared","premium-native"];function nc(e){return e&&oc.includes(e)?e:null}a(nc,"normalizeRepoIntelligenceMode");function js(e){let o=e?.trim();return!o||o==="default"||o==="reset"||o==="clear"?null:o}a(js,"normalizeRuntimeOverride");function tc(e,o){return e?e==="toggle"?!o:e==="on"||e==="true"||e==="1"?!0:e==="off"||e==="false"||e==="0"?!1:null:null}a(tc,"resolveToggleFlag");function io(e){try{return de(e),{saved:!0}}catch(o){return{saved:!1,error:o instanceof Error?o:new Error(String(o))}}}a(io,"persistUserConfig");function Q(e,o){if(o.saved){console.log(s.cyan(`
|
|
445
|
+
[${e}] (saved)`));return}console.log(s.yellow(`
|
|
446
|
+
[${e}]`)),console.log(s.red(`[Config save failed: ${o.error.message}]`))}a(Q,"printPersistedCommandStatus");function Hs(e,o,n){let t=ec(e),r=io({reasoningMode:e,thinking:t});return o.setReasoningMode?o.setReasoningMode(e):(n.reasoningMode=e,n.thinking=t),r}a(Hs,"applyReasoningMode");function rc(e,o,n){let t=io({agentMode:e});return o.setAgentMode?o.setAgentMode(e):n.agentMode=e,t}a(rc,"applyAgentMode");function Bo(e,o,n,t){let r=io(o);return n.setRepoIntelligenceRuntime?n.setRepoIntelligenceRuntime(e):(e.mode!==void 0&&(t.repoIntelligenceMode=e.mode),e.endpoint!==void 0&&(t.repointelEndpoint=e.endpoint??void 0),e.bin!==void 0&&(t.repointelBin=e.bin??void 0),e.trace!==void 0&&(t.repoIntelligenceTrace=e.trace)),r}a(Bo,"applyRepoIntelligenceRuntimeConfig");function sc(e){let o=e.configuredMode===e.requestedMode?e.configuredMode:`${e.configuredMode} -> ${e.requestedMode}`,n=`${e.effectiveEngine}/${e.effectiveBridge}`,t=e.transport?`, ${e.transport}`:"",r=e.fallbackToOss?", fallback=oss":"";return`${o} => ${n} (${e.status}${t}${r})`}a(sc,"formatRepoIntelligenceSummary");function zs(e){console.log(s.bold(`
|
|
447
|
+
Repo Intelligence:
|
|
448
|
+
`)),console.log(s.dim(` Configured: ${s.cyan(e.configuredMode)}`)),console.log(s.dim(` Requested: ${s.cyan(e.requestedMode)}`)),console.log(s.dim(` Active: ${s.cyan(`${e.effectiveEngine}/${e.effectiveBridge}`)}`)),console.log(s.dim(` Status: ${s.cyan(e.status)}${e.transport?s.dim(` (${e.transport})`):""}`)),console.log(s.dim(` Trace: ${s.cyan(e.traceEnabled?"on":"off")}`)),console.log(s.dim(` Endpoint: ${e.endpoint}`)),console.log(s.dim(` Bin: ${e.bin}`)),e.clientBuildId&&console.log(s.dim(` Client ID: ${e.clientBuildId}`)),e.daemonBuildId&&console.log(s.dim(` Daemon ID: ${e.daemonBuildId}`)),e.daemonPid!==void 0&&console.log(s.dim(` Daemon PID: ${e.daemonPid}`)),e.daemonStartedAt&&console.log(s.dim(` Daemon Up: ${e.daemonStartedAt}`)),e.fallbackToOss&&console.log(s.yellow(" Fallback: OSS baseline is currently active")),e.error&&console.log(s.red(` Error: ${e.error}`));for(let o of e.warnings)console.log(s.yellow(` Warning: ${o}`));console.log()}a(zs,"printRepoIntelligenceInspection");function ic(e){e.warmed?console.log(s.green(`
|
|
449
|
+
[repointel warmed successfully]`)):console.log(s.yellow(`
|
|
450
|
+
[repointel warm did not reach a ready daemon state]`)),e.warmLatencyMs!==void 0&&console.log(s.dim(` Warm latency: ${e.warmLatencyMs} ms`)),zs(e)}a(ic,"printRepoIntelligenceWarmResult");function Bs(e,o){if(o.length!==0){console.log(s.dim(`${e}:`));for(let n of o){let t=n.aliases?.length?` (${n.aliases.join(", ")})`:"";console.log(` ${s.cyan(`/${n.name}`)}${s.dim(t)} ${n.description}`)}console.log()}}a(Bs,"printCommandSection");function ac(){console.log(s.bold(`
|
|
451
|
+
Available Commands:
|
|
452
|
+
`));let e=Ko(),o=new Set;for(let[t,r]of Object.entries(Zl)){let i=Ql(r);if(i.length!==0){for(let l of i)o.add(l.name.toLowerCase());Bs(t,i)}}let n=new Map;for(let t of e.getAll()){if(t.userInvocable===!1||o.has(t.name.toLowerCase()))continue;let r=t.source==="extension"?"Extensions":t.source==="skill"?"Skill Commands":t.source==="prompt"?"Prompt Commands":"Other Commands",i=n.get(r)??[];i.push(t),n.set(r,i)}for(let t of uc()){if(o.has(t.name.toLowerCase()))continue;let r=n.get("Extensions")??[];r.push({name:t.name,aliases:t.aliases,description:t.description}),n.set("Extensions",r)}for(let t of["Extensions","Skill Commands","Prompt Commands","Other Commands"])Bs(t,n.get(t)??[]);console.log(s.dim("Special syntax:")),console.log(` ${s.cyan("@path")} Attach image to context`),console.log(` ${s.cyan("!command")} Execute shell command`),console.log(),console.log(s.dim("Skills:")),console.log(` ${s.cyan("/skill")} List all available skills`),console.log(` ${s.cyan("/skill:<name>")} Invoke a skill (e.g., /skill:code-review)`),console.log(),console.log(s.dim(`Tip: ${s.cyan("/<command> help")} shows command-specific help.`)),console.log()}a(ac,"printHelp");function lc(e){let o=Nt({topic:e});console.log(`
|
|
453
|
+
${s.cyan(o.title)}`),console.log(o.content),o.nextTopics.length>0&&console.log(s.dim(`
|
|
454
|
+
Related topics: ${o.nextTopics.join(", ")}`)),console.log()}a(lc,"printManualTopic");function mt(e){ee.size===0&&qo();let o=ee.get(e.toLowerCase());if(!o){let n=gt(e);if(!n){console.log(s.yellow(`
|
|
455
|
+
[Unknown command: /${e}. Type /help for available commands]`));return}console.log(s.cyan(`
|
|
456
|
+
/${n.name}`)),n.aliases?.length&&console.log(s.dim(`Aliases: ${n.aliases.join(", ")}`)),console.log(s.dim(`
|
|
457
|
+
${n.description}`)),console.log(s.dim(`
|
|
458
|
+
Usage: ${fc(n)}`)),console.log();return}o.detailedHelp?o.detailedHelp():(console.log(s.cyan(`
|
|
459
|
+
/${o.name}`)),o.aliases?.length&&console.log(s.dim(`Aliases: ${o.aliases.join(", ")}`)),console.log(s.dim(`
|
|
460
|
+
${o.description}`)),o.usage&&console.log(s.dim(`
|
|
461
|
+
Usage: ${o.usage}`)),console.log())}a(mt,"printDetailedHelp");async function cc(e,o,n=[]){let t=n[0]?.toLowerCase(),r=e.contextTokenSnapshot?.currentTokens??on(e.messages),i=e.contextTokenSnapshot?.source??"estimate",l=or(o.provider),c=tr(o.provider,o.model,o.reasoningMode);if(console.log(s.bold(`
|
|
462
|
+
Session Status:
|
|
463
|
+
`)),console.log(s.dim(` Provider: ${s.cyan(o.provider)}${o.model?` / ${s.cyan(o.model)}`:""}`)),console.log(s.dim(` Permission: ${s.cyan(o.permissionMode)}`)),console.log(s.dim(` Reasoning: ${s.cyan(o.reasoningMode)}`)),console.log(s.dim(` Agent Mode: ${s.cyan(o.agentMode.toUpperCase())}`)),l){let u=ln(l),m=l.transport==="cli-bridge"?s.yellow(u):s.cyan(u);console.log(s.dim(` Provider Cap: ${m}`))}if(c&&c.status!=="allow"){let u=c.status==="block"?s.red:s.yellow;console.log(s.dim(` Provider Policy: ${u(c.summary)}`))}console.log(s.dim(` Session ID: ${e.sessionId}`)),console.log(s.dim(` Messages: ${e.messages.length}`)),console.log(s.dim(` Tokens: ~${r} (${i})`));let d=await Ue({mode:o.repoIntelligenceMode,trace:o.repoIntelligenceTrace});console.log(s.dim(` Repo Intel: ${s.cyan(sc(d))}`)),e.runtimeInfo?.workspaceRoot?console.log(s.dim(` Workspace: ${s.cyan(Pn(e.runtimeInfo))}`)):e.gitRoot&&console.log(s.dim(` Workspace: ${s.cyan(e.gitRoot)}`)),(t==="workspace"||t==="worktree"||t==="runtime")&&(e.runtimeInfo?.canonicalRepoRoot&&console.log(s.dim(` Canonical: ${e.runtimeInfo.canonicalRepoRoot}`)),e.runtimeInfo?.executionCwd&&console.log(s.dim(` Exec CWD: ${e.runtimeInfo.executionCwd}`)),e.runtimeInfo?.workspaceKind&&console.log(s.dim(` Kind: ${e.runtimeInfo.workspaceKind}`))),console.log(s.dim(` Created: ${e.createdAt}`)),console.log(s.dim(` Last Active: ${e.lastAccessed}`)),console.log()}a(cc,"printStatus");async function qs(e,o){let n=nn(o.gitRoot);n.size===0&&await tn(o.gitRoot),dc(n.listUserInvocable())}a(qs,"handleSkillNamespaceCommand");function dc(e){if(console.log(s.bold(`
|
|
464
|
+
Available Skills:
|
|
465
|
+
`)),e.length===0){console.log(s.dim(" No skills found.")),console.log(s.dim(`
|
|
466
|
+
Skills can be placed in:`)),console.log(s.dim(" - .kodax/skills/")),console.log(s.dim(" - ~/.kodax/skills/"));return}let o=Math.max(...e.map(n=>n.name.length));for(let n of e){let t=n.name.padEnd(o),r=n.argumentHint?` ${n.argumentHint}`:"",i=n.source==="builtin"?" [builtin]":n.source==="user"?" [user]":n.source==="plugin"?" [plugin]":"",l=n.description.length>50?n.description.slice(0,50)+"...":n.description;console.log(` ${s.cyan(`/skill:${t}`)}${s.dim(r)}${s.dim(i)} ${s.dim(l)}`)}console.log(),console.log(s.dim(`Total: ${e.length} skills`)),console.log(s.dim("Usage: /skill:<name> [args] or ask naturally")),console.log()}a(dc,"printSkillsListPiMonoStyle");var ee=new Te;function qo(e){ee.size>0||Fs(ee,e)}a(qo,"initCommandRegistry");function Ko(e){return qo(e),ee}a(Ko,"getCommandRegistry");function uc(){return V()?.listCommands().filter(o=>o.metadata?.userInvocable!==!1)??[]}a(uc,"getActiveExtensionCommands");function gt(e){let o=V(),n=e.trim().toLowerCase();if(!n)return;let t=o?.listCommands().find(r=>r.name.trim().toLowerCase()===n||(r.aliases??[]).some(i=>i.trim().toLowerCase()===n));if(t)return t.metadata?.userInvocable===!1?void 0:t}a(gt,"getActiveExtensionCommand");function fc(e){return e.usage??`/${e.name}`}a(fc,"formatExtensionCommandUsage");function mc(e){return Array.isArray(e)?e.map(o=>String(o)).join(", "):e&&typeof e=="object"?JSON.stringify(e):String(e)}a(mc,"formatExtensionDiagnosticValue");function gc(e){if(!e)return;let o=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>`${n}=${mc(t)}`);return o.length>0?o.join(" | "):void 0}a(gc,"formatExtensionDiagnosticMetadata");function _e(e){let o=e.getDiagnostics;if(typeof o=="function")return o.call(e);let n=e.getDefaults,t=typeof n=="function"?n.call(e):void 0;return{loadedExtensions:[],capabilityProviders:e.listCapabilityProviders().map(r=>({id:r.id,kinds:[...r.kinds],source:{kind:"extension",id:`extension:${r.id}`,label:r.id,path:"(runtime)"}})),commands:e.listCommands().map(r=>({name:r.name,aliases:r.aliases,description:r.description,usage:r.usage,metadata:r.metadata,source:{kind:"extension",id:`extension-command:${r.name}`,label:r.name,path:"(runtime)"}})),tools:[],hooks:[],failures:[],defaults:{activeTools:t?.activeTools,modelSelection:t?.modelSelection??{},thinkingLevel:t?.thinkingLevel}}}a(_e,"getExtensionRuntimeDiagnostics");function pc(e,o){if(o.invocation)return{prompt:o.invocation.prompt,source:"extension",displayName:o.invocation.displayName??`/${e.name}`,disableModelInvocation:o.invocation.disableModelInvocation,allowedTools:o.invocation.allowedTools,context:o.invocation.context,model:o.invocation.model}}a(pc,"toExtensionInvocationRequest");async function wc(e,o,n){let t=V();if(!t)return console.log(s.yellow(`
|
|
467
|
+
[Extension runtime is not active for /${e.name}]`)),!1;let r=await e.handler(o,{sessionId:n.sessionId,gitRoot:n.gitRoot,workingDirectory:n.runtimeInfo?.executionCwd??n.gitRoot??process.cwd(),reloadExtensions:a(()=>t.reloadExtensions(),"reloadExtensions"),getDiagnostics:a(()=>_e(t),"getDiagnostics"),logger:{debug:a((...l)=>console.debug(`[kodax:extension-command:${e.name}]`,...l),"debug"),info:a((...l)=>console.info(`[kodax:extension-command:${e.name}]`,...l),"info"),warn:a((...l)=>console.warn(`[kodax:extension-command:${e.name}]`,...l),"warn"),error:a((...l)=>console.error(`[kodax:extension-command:${e.name}]`,...l),"error")}});if(!r)return!0;r.message&&console.log(r.message);let i=pc(e,r);return i?{invocation:i}:!0}a(wc,"executeExtensionCommand");function Jm(e){let o=e.trim();if(!o.startsWith("/"))return null;let n=o.slice(1).split(/\s+/),r=n[0]?.toLowerCase(),i=n.slice(1).filter(Boolean);if(!r)return null;if(r.startsWith("skill:")){let c=r.slice(6);return c?{command:"skill",args:i,skillInvocation:{name:c}}:{command:"skill",args:i}}let l=r.indexOf(":");if(l>0){let c=r.slice(l+1).trim();r=r.slice(0,l),i=c?[c,...i]:i}return{command:r,args:i}}a(Jm,"parseCommand");function Ks(e){let o=e[0]?.trim().toLowerCase();return o==="help"||o==="--help"||o==="-h"}a(Ks,"isCommandHelpRequest");async function Ym(e,o,n,t){if(ee.size===0&&qo(o.gitRoot),e.skillInvocation)return await hc({command:e.skillInvocation.name,args:e.args},o);let r=ee.get(e.command);if(r){if(r.userInvocable===!1)return console.log(s.yellow(`
|
|
468
|
+
[Command /${r.name} is not user-invocable]`)),!1;if(Ks(e.args))return mt(e.command),!0;try{let l=await r.handler(e.args,o,n,t);return l&&typeof l=="object"?l:!0}catch(l){return console.log(s.red(`
|
|
469
|
+
[Command failed: ${l instanceof Error?l.message:String(l)}]`)),!1}}let i=gt(e.command);if(i){if(Ks(e.args))return mt(e.command),!0;try{return await wc(i,e.args,o)}catch(l){return console.log(s.red(`
|
|
470
|
+
[Extension command failed: ${l instanceof Error?l.message:String(l)}]`)),!1}}return console.log(s.yellow(`
|
|
471
|
+
[Unknown command: /${e.command}. Type /help for available commands]`)),!1}a(Ym,"executeCommand");async function hc(e,o){let n=nn(o.gitRoot),t=e.command,r=e.args.join(" ");n.size===0&&await tn(o.gitRoot);try{let i=n.get(t);if(!i)return console.log(s.red(`
|
|
472
|
+
[Skill not found: ${t}]`)),!1;if(!i.userInvocable)return console.log(s.yellow(`
|
|
473
|
+
[Skill "${t}" is not user-invocable]`)),!1;console.log(s.cyan(`
|
|
474
|
+
[Invoking skill: ${t}]`)),i.argumentHint&&console.log(s.dim(`Arguments: ${r||"(none)"}`)),console.log();let l=await n.loadFull(t),c={workingDirectory:process.cwd(),projectRoot:o.gitRoot??void 0,sessionId:o.sessionId,environment:{}},d=await Wt(l,r,c);return console.log(s.green(`Skill activated: ${t}`)),console.log(s.dim("The skill context has been prepared for the AI.")),console.log(),{invocation:{prompt:d.content,source:"skill",displayName:t,path:l.skillFilePath,disableModelInvocation:d.disableModelInvocation,userInvocable:l.userInvocable,allowedTools:l.allowedTools,context:l.context,agent:l.agent,argumentHint:l.argumentHint,model:l.model,hooks:l.hooks,skillInvocation:{name:t,path:l.skillFilePath,description:l.description,arguments:r||void 0,allowedTools:l.allowedTools,context:l.context,agent:l.agent,argumentHint:l.argumentHint,model:l.model,hookEvents:l.hooks?Object.entries(l.hooks).filter(([,u])=>Array.isArray(u)&&u.length>0).map(([u])=>u):void 0,expandedContent:d.content}}}}catch(i){return console.log(s.red(`
|
|
475
|
+
[Error invoking skill: ${i instanceof Error?i.message:String(i)}]`)),!1}}a(hc,"executeSkillCommand");import{exec as yc}from"node:child_process";import*as Le from"node:path";import{promisify as kc}from"node:util";var Gs=kc(yc);function vc(e){let o=e.slice(3);if(!o)return;let n=o.indexOf(" -> ");return(n===-1?o:o.slice(n+4)).replace(/^"(.*)"$/,"$1").trim()||void 0}a(vc,"pathFromPorcelainLine");async function Xs(e,o=10){try{let[{stdout:n},{stdout:t}]=await Promise.all([Gs("git rev-parse --show-toplevel",{cwd:e}),Gs("git status --porcelain=v1 -uall",{cwd:e})]),r=n.trim(),i=[],l=new Set;for(let c of t.split(`
|
|
476
|
+
`)){if(!c.trim())continue;let d=vc(c);if(!d)continue;let u=Le.resolve(r,d),m=Le.relative(e,u).split(Le.sep).join("/");if(!(!m||m.startsWith("..")||l.has(m))&&(l.add(m),i.push(m),i.length>=o))break}return i}catch{return[]}}a(Xs,"getRecentWorkingSetFiles");function Ne(e){let o=e.lastIndexOf("/");if(o===-1)return-1;for(;o>0&&!/\s/.test(e[o-1]??"");)if(o=e.lastIndexOf("/",o-1),o===-1)return-1;return o}a(Ne,"findCommandSlashIndex");var pt=class{static{a(this,"FileCompleter")}cwdSource;cache=new Map;cacheTimeout=5e3;recentCache=new Map;recentFilesProvider;constructor(o,n=Xs){this.cwdSource=o,this.recentFilesProvider=n}canComplete(o,n){let t=o.slice(0,n),r=t.lastIndexOf("@");return!(r===-1||r>0&&!/\s/.test(t[r-1]??"")||t.slice(r+1).includes(" "))}async getCompletions(o,n){let t=o.slice(0,n),r=t.lastIndexOf("@");if(r===-1)return[];let i=t.slice(r+1),l=[],c=this.resolveCwd(),d=i.lastIndexOf("/"),u=d===-1?c:ao.join(c,i.slice(0,d)),m=d===-1?i:i.slice(d+1);try{let h=(await this.readdir(u)).filter(k=>k.toLowerCase().startsWith(m.toLowerCase()));for(let k of h){let y=ao.join(u,k),v=await this.isDirectory(y),g=d===-1?k:i.slice(0,d+1)+k;l.push({text:"@"+g+(v?"/":""),display:k+(v?"/":""),description:v?"directory":"file",type:"file"})}}catch{}if(d===-1){let f=await this.getRecentFiles(c),h=new Set(l.map(v=>v.text)),k=m.toLowerCase(),y=[];for(let v of f){if(m&&!ao.basename(v).toLowerCase().startsWith(k))continue;let g="@"+v;h.has(g)||(h.add(g),y.push({text:g,display:v,description:"recent",type:"file"}))}l.unshift(...y)}return l}async getRecentFiles(o){let n=Date.now(),t=this.recentCache.get(o);if(t&&t.expiresAt>n)return t.files;let r=await this.recentFilesProvider(o);return this.recentCache.set(o,{files:r,expiresAt:Date.now()+this.cacheTimeout}),r}resolveCwd(){return typeof this.cwdSource=="function"?this.cwdSource():this.cwdSource??process.cwd()}async readdir(o){let n=Date.now(),t=this.cache.get(o);return t&&t.expiresAt>n?t.entries:(t&&this.cache.delete(o),new Promise(r=>{zo.readdir(o,(i,l)=>{i?r([]):(this.cache.set(o,{entries:l,expiresAt:Date.now()+this.cacheTimeout}),r(l))})}))}async isDirectory(o){return new Promise(n=>{zo.stat(o,(t,r)=>{n(!t&&r.isDirectory())})})}},wt=class{static{a(this,"CommandCompleter")}commands;constructor(){this.commands=new Map,this.loadCommands()}loadCommands(){for(let n of Ko().getAll())n.userInvocable!==!1&&this.commands.set(n.name,{description:n.description,aliases:n.aliases??[]});let o=V();for(let n of o?.listCommands()??[])n.metadata?.userInvocable!==!1&&this.commands.set(n.name,{description:n.description,aliases:n.aliases??[]})}canComplete(o,n){let t=o.slice(0,n),r=Ne(t);return r===-1?!1:!t.slice(r).includes(" ")}async getCompletions(o,n){let t=o.slice(0,n),r=Ne(t);if(r===-1)return[];this.commands.clear(),this.loadCommands();let i=t.slice(r+1).toLowerCase(),l=[];for(let[c,d]of this.commands){this.fuzzyMatch(i,c)&&l.push({text:"/"+c,display:"/"+c,description:d.description,type:"command"});for(let u of d.aliases)u!==c&&this.fuzzyMatch(i,u)&&l.push({text:"/"+u,display:"/"+u,description:`Alias for /${c}: ${d.description}`,type:"command"})}return l}fuzzyMatch(o,n){if(!o)return!0;let t=o.toLowerCase(),r=n.toLowerCase(),i=0;for(let l=0;l<r.length&&i<t.length;l++)r[l]===t[i]&&i++;return i===t.length}};function ag(e){let o=new pt(e),n=new wt;return async t=>{let r=t.includes("@"),i=t.includes("/");if(!r&&!i)return[[],t];let l=[];if(i){let d=await $c(t,t.length);l.push(...d)}if(i&&n.canComplete(t,t.length)){let d=await n.getCompletions(t,t.length);l.push(...d)}if(r&&o.canComplete(t,t.length)){let d=await o.getCompletions(t,t.length);l.push(...d)}return[l.map(d=>Sc(t,d)),t]}}a(ag,"createCompleter");async function $c(e,o){let{ArgumentCompleter:n}=await import("./argument-completer-3WX5B42G.js"),t=new n;return t.canComplete(e,o)?t.getCompletions(e,o):[]}a($c,"getArgumentCompletions");function Sc(e,o){if(o.type!=="argument")return o.display;let n=Ne(e);if(n!==-1&&!/\s/.test(e.slice(n)))return`${e} ${o.text}`;let r=e.match(/\S+$/)?.[0]??"";return`${r?e.slice(0,e.length-r.length):e}${o.text}`}a(Sc,"formatReadlineCompletion");import{existsSync as Xo,readdirSync as Qs,readFileSync as ei}from"node:fs";import{join as Vo}from"node:path";var bc=[{name:"plan",description:"Read-only planning mode - blocks all modifications",type:"enum"},{name:"accept-edits",description:"File edits auto-approved, bash requires confirmation",type:"enum"},{name:"auto-in-project",description:"All tools auto within project directory",type:"enum"}],Go=[{name:"on",description:"Map to reasoning auto",type:"enum"},{name:"off",description:"Disable reasoning",type:"enum"},{name:"auto",description:"Use semantic routing with adaptive depth",type:"enum"},{name:"quick",description:"Low-depth reasoning mode",type:"enum"},{name:"balanced",description:"Medium-depth reasoning mode",type:"enum"},{name:"deep",description:"High-depth reasoning mode",type:"enum"}],Vs=Go.slice(2).concat([{name:"off",description:"Disable reasoning",type:"enum"}]);function xc(e){if(e&&e.includes("/")){let o=e.indexOf("/"),n=e.slice(0,o),t=e.slice(o+1);if($e(n))try{return Re(n).filter(i=>!t||i.toLowerCase().includes(t.toLowerCase())).map(i=>({name:`${n}/${i}`,description:i,type:"enum"}))}catch{}return[]}return Se().map(o=>({name:o,description:`Switch to ${o} provider`,type:"enum"}))}a(xc,"getModelArgs");var Js=[{name:"on",description:"Enable plan mode for all requests",type:"enum"},{name:"off",description:"Disable plan mode",type:"enum"},{name:"once",description:"Run plan mode for a single request (followed by task)",type:"enum"},{name:"list",description:"List all saved plans",type:"enum"},{name:"resume",description:"Resume a saved plan (followed by plan ID)",type:"enum"},{name:"clear",description:"Clear completed plans",type:"enum"}],ht=[{name:"workspace",description:"Inspect current workspace/runtime truth in more detail",type:"enum"},{name:"runtime",description:"Alias for workspace runtime inspection",type:"enum"},{name:"worktree",description:"Alias for workspace runtime inspection",type:"enum"}],yt=[{name:"all",description:"Delete ALL sessions",type:"enum"}],Ac=[{name:"status",description:"Inspect the current repo-intelligence runtime state",type:"enum"},{name:"warm",description:"Warm or start the local premium runtime if available",type:"enum"},{name:"mode",description:"Switch repo-intelligence runtime mode",type:"enum"},{name:"trace",description:"Toggle repo-intelligence trace output",type:"enum"},{name:"endpoint",description:"Inspect or override the local repointel daemon endpoint",type:"enum"},{name:"bin",description:"Inspect or override the local repointel command or path",type:"enum"}],Rc=[{name:"auto",description:"Resolve to premium-native when available, otherwise fall back to oss",type:"enum"},{name:"off",description:"Disable repo-intelligence injection",type:"enum"},{name:"oss",description:"Use only the public OSS repo-intelligence baseline",type:"enum"},{name:"premium-shared",description:"Use premium without the native KodaX auto lane",type:"enum"},{name:"premium-native",description:"Use premium through the native KodaX bridge",type:"enum"}],Ic=[{name:"on",description:"Enable repo-intelligence trace output",type:"enum"},{name:"off",description:"Disable repo-intelligence trace output",type:"enum"},{name:"toggle",description:"Toggle repo-intelligence trace output",type:"enum"}],Ys=[{name:"default",description:"Clear the override and use the default value again",type:"enum"}],Cc=[{name:"list",description:"List built-in and saved workflows",type:"enum"},{name:"create",description:"Generate and run a workflow from a request",type:"enum"},{name:"runs",description:"List active and recent workflow runs",type:"enum"},{name:"show",description:"Show latest run or a specific workflow run",type:"enum"},{name:"pause",description:"Pause future child launches for a run",type:"enum"},{name:"resume",description:"Resume a paused run",type:"enum"},{name:"stop",description:"Stop an active workflow run",type:"enum"},{name:"delete",description:"Delete one persisted workflow run",type:"enum"},{name:"prune",description:"Preview or delete old terminal workflow runs",type:"enum"},{name:"rerun",description:"Rerun a run id or saved workflow name",type:"enum"},{name:"save",description:"Save a generated run as a workflow capsule",type:"enum"},{name:"rename",description:"Rename a run display name or saved workflow capsule",type:"enum"},{name:"revise",description:"Generate a revised workflow capsule",type:"enum"},{name:"help",description:"Show workflow help",type:"enum"}],Ec=new Set(["show","pause","resume","stop","delete","rerun","save","rename","revise"]),Tc=new Set(["show","delete","rerun","save","rename","revise"]),Pc=[{name:"--all",description:"Show all persisted workflow runs",type:"enum"},{name:"--limit",description:"Show at most N persisted workflow runs",type:"enum"}],Mc=[{name:"--dry-run",description:"Preview cleanup without deleting runs",type:"enum"},{name:"--keep",description:"Keep the newest N terminal runs",type:"enum"},{name:"--older-than",description:"Delete terminal runs older than Nd or Nh",type:"enum"}],Wc=[".workflow.json",".ts",".mjs",".js"];function _c(e,o){switch(e){case"pause":return o==="running";case"resume":return o==="paused";case"stop":return o==="running"||o==="paused";case"delete":return o!=="running"&&o!=="paused";default:return!0}}a(_c,"workflowRunMatchesSubcommand");function Jo(e){return/^[a-zA-Z0-9._-]{1,120}$/.test(e)&&!e.startsWith(".")&&!e.includes("..")}a(Jo,"isWorkflowRunEntryName");function Lc(e,o){let n=Vo(e,"workflow-metadata.json");if(Xo(n))try{let r=JSON.parse(ei(n,"utf8"));if(typeof r=="object"&&r!==null){let i=r.displayName;if(typeof i=="string"&&Jo(i.trim()))return i.trim()}}catch{}let t=o.displayName;return typeof t=="string"&&Jo(t.trim())?t.trim():void 0}a(Lc,"readWorkflowRunDisplayName");function Nc(){let e=me(process.cwd()).key,o=_("workflow-runs",e);if(!Xo(o))return[];let n=[];for(let t of Qs(o)){if(!Jo(t))continue;let r=Vo(o,t,"run.json");if(Xo(r))try{let i=JSON.parse(ei(r,"utf8")),l=typeof i.workflow=="string"?i.workflow:"?",c=typeof i.status=="string"?i.status:"?",d=typeof i.endedAt=="number"?i.endedAt:0;n.push({arg:{name:t,description:`${l} - ${c}`,type:"string"},endedAt:d});let u=Lc(Vo(o,t),i);u&&u!==t&&n.push({arg:{name:u,description:`${l} alias for ${t} - ${c}`,type:"string"},endedAt:d})}catch{}}return n.sort((t,r)=>r.endedAt-t.endedAt).map(t=>t.arg)}a(Nc,"getPersistedWorkflowRunIdArgs");function kt(e){let o=Ae().list().filter(r=>_c(e,r.status)).map(r=>({name:r.runId,description:`${r.workflow} - ${r.status}`,type:"string"})),n=Tc.has(e)?Nc():[],t=new Set;return[...o,...n].filter(r=>t.has(r.name)?!1:(t.add(r.name),!0))}a(kt,"getWorkflowRunIdArgs");function Oc(e){for(let o of Wc)if(e.endsWith(o)){let n=e.slice(0,-o.length);return Jo(n)?n:void 0}}a(Oc,"savedWorkflowNameFromFile");function Yo(){let e=[{path:_("workflows"),source:"personal"},{path:Vo(process.cwd(),".kodax","workflows"),source:"project"}],o=new Map;for(let n of e)if(Xo(n.path))try{for(let t of Qs(n.path)){let r=Oc(t);r&&o.set(r,{name:r,description:`${n.source} saved workflow`,type:"enum"})}}catch{}return[...o.values()].sort((n,t)=>n.name.localeCompare(t.name))}a(Yo,"getSavedWorkflowNameArgs");function Dc(){let e=new Map;for(let o of kt("rerun"))e.set(o.name,{...o,description:`recent run: ${o.description}`,type:"string"});for(let o of Yo()){let n=e.get(o.name);if(n){e.set(o.name,{...n,description:`${n.description}; also ${o.description}`});continue}e.set(o.name,{...o,description:o.description,type:"string"})}return[...e.values()]}a(Dc,"getWorkflowRerunArgs");function Zs(e){let o=new Map;for(let n of kt(e))o.set(n.name,{...n,description:`workflow run: ${n.description}`,type:"string"});for(let n of Yo()){let t=o.get(n.name);if(t){o.set(n.name,{...t,description:`${t.description}; also ${n.description}`});continue}o.set(n.name,{...n,description:n.description,type:"string"})}return[...o.values()]}a(Zs,"getWorkflowRunOrSavedNameArgs");function Uc(e){let[o=""]=e,n=o.toLowerCase(),t=e.length===1&&e[0]===""?0:e.length;if(t<=1)return[...Cc,...He().map(r=>({name:r.name,description:r.description,type:"enum"})),...Yo()];if(n==="rerun"&&t<=2)return Dc();if(n==="rename"&&t<=2)return Zs("rename");if(n==="revise"){if(t<=2)return[{name:"--replace",description:"Replace a saved workflow after confirmation",type:"enum"},...Zs("revise")];if(e[1]==="--replace"&&t<=3)return Yo()}return Ec.has(n)&&t<=2?kt(n):n==="runs"&&t<=2?Pc:n==="prune"&&t<=2?Mc:[]}a(Uc,"getWorkflowArgs");function Fc(e){let[o=""]=e,n=o.toLowerCase(),t=e.length===1&&e[0]===""?0:e.length;return t<=1?Ac:t>2?[]:n==="mode"?Rc:n==="trace"?Ic:n==="endpoint"?[...Ys,{name:Ot,description:"Default local repointel daemon endpoint",type:"string"}]:n==="bin"?Ys:[]}a(Fc,"getRepointelArgs");var jc=new Map([["mode",bc],["thinking",Go],["think",Go],["t",Go],["reasoning",Vs],["reason",Vs],["plan",Js],["p",Js],["status",ht],["info",ht],["ctx",ht],["delete",yt],["rm",yt],["del",yt]]),Hc=new Set(["model","m"]),Bc=new Set(["repointel","ri"]),qc=new Set(["workflow"]);function vt(e,o,n=[]){let t=e.toLowerCase();return Hc.has(t)?xc(o):Bc.has(t)?Fc(n):qc.has(t)?Uc(n):jc.get(t)??[]}a(vt,"getCommandArguments");var $t=class{static{a(this,"ArgumentCompleter")}canComplete(o,n){let t=o.slice(0,n),r=Ne(t);if(r===-1)return!1;let i=t.slice(r),l=i.split(/\s+/);if(l.length>=2&&l[0]!=="")return!0;let c=i.slice(1).toLowerCase();return vt(c).length>0}async getCompletions(o,n){let t=o.slice(0,n),r=Ne(t);if(r===-1)return[];let i=t.slice(r),l=i.indexOf(" "),c=(l===-1?i.slice(1):i.slice(1,l)).toLowerCase(),d=l===-1?"":i.slice(l+1),u=d?d.split(/\s+/):[""],m=u.length-1,f=(u[m]??"").toLowerCase(),h=vt(c,f,u);if(!h||h.length===0)return[];let k=new Set(u.slice(0,-1).map(v=>v.toLowerCase()));return h.filter(v=>!k.has(v.name.toLowerCase())).filter(v=>!f||v.name.includes("/")?!0:v.name.toLowerCase().includes(f)).map(v=>({text:v.name,display:v.name,description:v.description,type:"argument"})).sort((v,g)=>{let I=v.display.toLowerCase().startsWith(f),x=g.display.toLowerCase().startsWith(f);return I&&!x?-1:!I&&x?1:v.display.length-g.display.length})}};function vg(){return new $t}a(vg,"createArgumentCompleter");export{wo as a,Gc as b,si as c,Xc as d,Be as e,mr as f,gr as g,qe as h,wn as i,$i as j,hn as k,kn as l,vn as m,Ge as n,Ri as o,$n as p,Ce as q,_r as r,Lr as s,Di as t,Dd as u,xn as v,Ud as w,Fd as x,jr as y,zr as z,Zd as A,Qd as B,Qr as C,In as D,eu as E,es as F,ou as G,nu as H,tu as I,xu as J,Au as K,Ru as L,ss as M,Pn as N,is as O,me as P,Mu as Q,we as R,ol as S,nl as T,ef as U,of as V,Yn as W,Gf as X,Xf as Y,Vf as Z,Jf as _,Yf as $,Ls as aa,tm as ba,rm as ca,Os as da,sm as ea,Ds as fa,Jm as ga,Ym as ha,$t as ia,vg as ja,Ne as ka,pt as la,wt as ma,ag as na};
|