prjct-cli 2.2.3 → 2.2.4
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 +7 -0
- package/dist/bin/prjct-core.mjs +26 -21
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
package/dist/bin/prjct-core.mjs
CHANGED
|
@@ -6,10 +6,10 @@ var __filename = __fileURLToPath(import.meta.url);
|
|
|
6
6
|
var __dirname = __pathDirname(__filename);
|
|
7
7
|
var zf=Object.create;var or=Object.defineProperty;var Xf=Object.getOwnPropertyDescriptor;var Kf=Object.getOwnPropertyNames;var Yf=Object.getPrototypeOf,Qf=Object.prototype.hasOwnProperty;var c=(n,e)=>or(n,"name",{value:e,configurable:!0}),Ke=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var h=(n,e)=>()=>(n&&(e=n(n=0)),e);var Zf=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),G=(n,e)=>{for(var t in e)or(n,t,{get:e[t],enumerable:!0})},Ll=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Kf(e))!Qf.call(n,r)&&r!==t&&or(n,r,{get:()=>e[r],enumerable:!(s=Xf(e,r))||s.enumerable});return n};var eh=(n,e,t)=>(t=n!=null?zf(Yf(n)):{},Ll(e||!n||!n.__esModule?or(t,"default",{value:n,enumerable:!0}):t,n)),yt=n=>Ll(or({},"__esModule",{value:!0}),n);var Ul={};G(Ul,{REGISTERED_VERBS:()=>Fl,REGISTERED_VERBS_SET:()=>th});var Fl,th,Hl=h(()=>{"use strict";Fl=["task","ship","tag","remember","status","workflow","init","analyze","analysis-save-llm","sync","regen","context","login","logout","auth","seed","install","capture"],th=new Set(Fl)});var Wl={};G(Wl,{DAEMON_PATHS:()=>xe,IDLE_TIMEOUT_MS:()=>xi,MAX_BUFFER_SIZE:()=>Ri,decodeMessage:()=>sh,encodeMessage:()=>Ds});function Ds(n){return Buffer.from(`${JSON.stringify(n)}
|
|
8
8
|
`)}function sh(n){return JSON.parse(n.trim())}var xe,xi,Ri,qr=h(()=>{"use strict";xe={runDir:c(()=>`${process.env.HOME||Ke("node:os").homedir()}/.prjct-cli/run`,"runDir"),socket:c(()=>`${xe.runDir()}/daemon.sock`,"socket"),pid:c(()=>`${xe.runDir()}/daemon.pid`,"pid"),log:c(()=>`${xe.runDir()}/daemon.log`,"log")},xi=30*60*1e3,Ri=1024*1024;c(Ds,"encodeMessage");c(sh,"decodeMessage")});function Gl(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function Ms(){return Gl()==="bun"}function Ai(){if(Gl()==="bun")return!0;try{let{execSync:n}=Ke("node:child_process");return n("bun --version",{stdio:"ignore"}),!0}catch{return!1}}var ir=h(()=>{"use strict";c(Gl,"detectRuntime");c(Ms,"isBun");c(Ai,"isBunAvailable")});var zt={};G(zt,{executeViaDaemon:()=>oh,forceKillDaemon:()=>ah,getDaemonStatus:()=>rh,isDaemonRunning:()=>Vl,sendRequest:()=>ar,spawnDaemon:()=>ql,stopDaemon:()=>ih});import Br from"node:crypto";import Ue from"node:fs";import{connect as nh}from"node:net";async function Vl(){let n=xe.socket();if(!Ue.existsSync(n))return!1;try{return(await ar({id:Br.randomUUID(),command:"__ping",args:[],options:{},cwd:process.cwd()})).success}catch{try{Ue.unlinkSync(n)}catch{}return!1}}async function rh(){let n=xe.socket(),e=xe.pid();if(!Ue.existsSync(n))return{running:!1};try{let t=await ar({id:Br.randomUUID(),command:"daemon",args:["status"],options:{},cwd:process.cwd()});if(t.success&&t.result)return t.result}catch{}return Ue.existsSync(e)?{running:!1,pid:parseInt(Ue.readFileSync(e,"utf-8").trim(),10),socketPath:n}:{running:!1}}function ar(n){return new Promise((e,t)=>{let s=xe.socket(),r=nh(s),o="",i=!1,a=setTimeout(()=>{i||(i=!0,r.destroy(),t(new Error("Daemon request timed out")))},3e4);r.on("connect",()=>{r.write(Ds(n))}),r.on("data",l=>{o+=l.toString();let u=o.indexOf(`
|
|
9
|
-
`);if(u!==-1){let d=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(d);i=!0,clearTimeout(a),r.end(),e(m)}catch(m){i=!0,clearTimeout(a),r.end(),t(new Error(`Invalid daemon response: ${m.message}`))}}}),r.on("error",l=>{i||(i=!0,clearTimeout(a),t(l))}),r.on("close",()=>{i||(i=!0,clearTimeout(a),t(new Error("Connection closed before response")))})})}async function oh(n,e,t,s,r,o=!0){let i=xe.socket();if(!Ue.existsSync(i))return o&&ql().catch(()=>{}),null;try{return await ar({id:Br.randomUUID(),command:n,args:e,options:t,cwd:s,perfStartNs:r})}catch{return null}}async function ih(){try{return(await ar({id:Br.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function ah(){let n=xe.pid(),e=xe.socket(),t=!1;if(Ue.existsSync(n)){let s=parseInt(Ue.readFileSync(n,"utf-8").trim(),10);if(!Number.isNaN(s))try{process.kill(s,"SIGKILL"),t=!0}catch{}}try{Ue.existsSync(n)&&Ue.unlinkSync(n)}catch{}try{Ue.existsSync(e)&&Ue.unlinkSync(e)}catch{}return t}async function ql(){let{spawn:n}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),s=e.join(__dirname,"..","daemon","entry.mjs"),r=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Ue.existsSync(t))o=t,i="bun";else if(Ue.existsSync(s))o=s,i=Ai()?"bun":"node";else if(Ue.existsSync(r))o=r,i=Ai()?"bun":"node";else return!1;let a=xe.runDir();Ue.mkdirSync(a,{recursive:!0});let l=xe.log(),u=Ue.openSync(l,"a");n(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Ue.closeSync(u);let m=Date.now()+3e3;for(;Date.now()<m;)if(await new Promise(p=>setTimeout(p,300)),await Vl())return!0;return!1}var Xt=h(()=>{"use strict";ir();qr();c(Vl,"isDaemonRunning");c(rh,"getDaemonStatus");c(ar,"sendRequest");c(oh,"executeViaDaemon");c(ih,"stopDaemon");c(ah,"forceKillDaemon");c(ql,"spawnDaemon")});var Jr=h(()=>{"use strict"});import{z as Ot}from"zod";function Bl(n,e){let t=n.split(".").map(Number),s=e.split(".").map(Number);for(let r=0;r<3;r++){let o=t[r]??0,i=s[r]??0;if(o<i)return-1;if(o>i)return 1}return 0}var
|
|
9
|
+
`);if(u!==-1){let d=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(d);i=!0,clearTimeout(a),r.end(),e(m)}catch(m){i=!0,clearTimeout(a),r.end(),t(new Error(`Invalid daemon response: ${m.message}`))}}}),r.on("error",l=>{i||(i=!0,clearTimeout(a),t(l))}),r.on("close",()=>{i||(i=!0,clearTimeout(a),t(new Error("Connection closed before response")))})})}async function oh(n,e,t,s,r,o=!0){let i=xe.socket();if(!Ue.existsSync(i))return o&&ql().catch(()=>{}),null;try{return await ar({id:Br.randomUUID(),command:n,args:e,options:t,cwd:s,perfStartNs:r})}catch{return null}}async function ih(){try{return(await ar({id:Br.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function ah(){let n=xe.pid(),e=xe.socket(),t=!1;if(Ue.existsSync(n)){let s=parseInt(Ue.readFileSync(n,"utf-8").trim(),10);if(!Number.isNaN(s))try{process.kill(s,"SIGKILL"),t=!0}catch{}}try{Ue.existsSync(n)&&Ue.unlinkSync(n)}catch{}try{Ue.existsSync(e)&&Ue.unlinkSync(e)}catch{}return t}async function ql(){let{spawn:n}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),s=e.join(__dirname,"..","daemon","entry.mjs"),r=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Ue.existsSync(t))o=t,i="bun";else if(Ue.existsSync(s))o=s,i=Ai()?"bun":"node";else if(Ue.existsSync(r))o=r,i=Ai()?"bun":"node";else return!1;let a=xe.runDir();Ue.mkdirSync(a,{recursive:!0});let l=xe.log(),u=Ue.openSync(l,"a");n(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Ue.closeSync(u);let m=Date.now()+3e3;for(;Date.now()<m;)if(await new Promise(p=>setTimeout(p,300)),await Vl())return!0;return!1}var Xt=h(()=>{"use strict";ir();qr();c(Vl,"isDaemonRunning");c(rh,"getDaemonStatus");c(ar,"sendRequest");c(oh,"executeViaDaemon");c(ih,"stopDaemon");c(ah,"forceKillDaemon");c(ql,"spawnDaemon")});var Jr=h(()=>{"use strict"});import{z as Ot}from"zod";function Bl(n,e){let t=n.split(".").map(Number),s=e.split(".").map(Number);for(let r=0;r<3;r++){let o=t[r]??0,i=s[r]??0;if(o<i)return-1;if(o>i)return 1}return 0}var NE,OE,_E,on,LE,zr=h(()=>{"use strict";NE=Ot.enum(["opus","sonnet","haiku"]),OE=Ot.enum(["2.5-pro","2.5-flash","2.0-flash"]),_E=Ot.string().min(1),on=Ot.object({provider:Ot.string(),model:Ot.string(),cliVersion:Ot.string().optional(),recordedAt:Ot.string()}),LE=Ot.object({preferredModel:Ot.string().optional(),lastAnalysisModel:on.optional()});c(Bl,"compareSemver")});var Ii={};G(Ii,{execAsync:()=>_,execFileAsync:()=>Kt});import{exec as ch,execFile as lh}from"node:child_process";import{promisify as Jl}from"node:util";var _,Kt,st=h(()=>{"use strict";_=Jl(ch),Kt=Jl(lh)});var zl,Xl,Kl,$i=h(()=>{"use strict";zl=new Set(["node_modules",".git","dist","build","out",".next",".nuxt","coverage",".cache",".turbo",".vercel",".parcel-cache","__pycache__",".pytest_cache","target","vendor",".venv","venv","eggs","*.egg-info",".prjct",".worktrees"]),Xl=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],Kl=/(?:import|from)\s+['"]([^'"]+)['"]/g});function uh(n){return n instanceof Error&&"code"in n}function D(n){return uh(n)&&n.code==="ENOENT"}function k(n){return n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}function Di(n){if(n instanceof Error)return n.stack}var q=h(()=>{"use strict";c(uh,"isNodeError");c(D,"isNotFoundError");c(k,"getErrorMessage");c(Di,"getErrorStack")});import Zl from"node:fs/promises";async function eu(n,e){let t;try{t=await Zl.readFile(n,"utf-8")}catch(o){if(D(o))return null;throw o}let s;try{s=JSON.parse(t)}catch{return await Yl(n,t),Ql(n,"Malformed JSON"),null}let r=e.safeParse(s);return r.success?s:(await Yl(n,t),Ql(n,dh(r.error)),null)}async function Yl(n,e){let t=`${n}.backup`;try{await Zl.writeFile(t,e,"utf-8")}catch{}}function Ql(n,e){console.error(`[prjct] Warning: Corrupted storage file: ${n}`),console.error(`[prjct] Reason: ${e}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function dh(n){return n.issues.slice(0,3).map(e=>`${e.path.join(".")}: ${e.message}`).join("; ")}var tu=h(()=>{"use strict";q();c(eu,"safeRead");c(Yl,"createBackup");c(Ql,"logCorruption");c(dh,"formatZodError")});var es={};G(es,{appendLine:()=>gh,appendToFile:()=>mh,atomicWrite:()=>ph,batchProcess:()=>Os,copyFile:()=>Sh,deleteDir:()=>yh,deleteFile:()=>hh,dirExists:()=>Qt,ensureDir:()=>jt,fileExists:()=>v,getFileExtension:()=>Eh,getFileModifiedTime:()=>kh,getFileNameWithoutExtension:()=>Ch,getFileSize:()=>wh,listFiles:()=>Zt,moveFile:()=>vh,prependToFile:()=>fh,readFile:()=>ct,readJson:()=>Ee,readLines:()=>bh,walkDir:()=>Ns,writeFile:()=>_t,writeJson:()=>ae,writeLines:()=>Th});import fe from"node:fs/promises";import Yt from"node:path";async function Ns(n,e={}){let t=[],s=e.maxFiles??1/0,r=e.dotfileAllowlist?new Set(e.dotfileAllowlist):null;async function o(i){if(t.length>=s)return;let a=await fe.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let l of a){if(t.length>=s)break;let u=String(l.name);if(zl.has(u)||e.skipDotfiles&&u.startsWith(".")&&(!r||!r.has(u)))continue;let d=Yt.join(i,u);l.isDirectory()?await o(d):l.isFile()&&t.push(Yt.relative(n,d))}}return c(o,"walk"),await o(n),t}async function Os(n,e,t){let s=[];for(let r=0;r<n.length;r+=e){let o=await Promise.all(n.slice(r,r+e).map(t));for(let i of o)i!==null&&s.push(i)}return s}async function Ee(n,e=null,t){if(t)return await eu(n,t)??e;try{let s=await fe.readFile(n,"utf-8");return JSON.parse(s)}catch(s){if(D(s))return e;throw s}}async function ae(n,e,t=2){let s=Yt.dirname(n);await fe.mkdir(s,{recursive:!0});let r=JSON.stringify(e,null,t);await fe.writeFile(n,r,"utf-8")}async function ct(n,e=""){try{return await fe.readFile(n,"utf-8")}catch(t){if(D(t))return e;throw t}}async function _t(n,e){let t=Yt.dirname(n);await fe.mkdir(t,{recursive:!0}),await fe.writeFile(n,e,"utf-8")}async function ph(n,e){let t=Yt.dirname(n);await fe.mkdir(t,{recursive:!0});let s=`${n}.${Date.now()}.tmp`;await fe.writeFile(s,e,"utf-8"),await fe.rename(s,n)}async function mh(n,e){await fe.appendFile(n,e,"utf-8")}async function gh(n,e){let t=Yt.dirname(n);await fe.mkdir(t,{recursive:!0}),await fe.appendFile(n,`${e}
|
|
10
10
|
`,"utf-8")}async function fh(n,e){try{let t=await fe.readFile(n,"utf-8");await fe.writeFile(n,e+t,"utf-8")}catch(t){if(D(t))await fe.writeFile(n,e,"utf-8");else throw t}}async function v(n){try{return await fe.access(n),!0}catch(e){if(D(e))return!1;throw e}}async function Qt(n){try{return(await fe.stat(n)).isDirectory()}catch(e){if(D(e))return!1;throw e}}async function jt(n){await fe.mkdir(n,{recursive:!0})}async function hh(n){try{return await fe.unlink(n),!0}catch(e){if(D(e))return!1;throw e}}async function yh(n){try{return await fe.rm(n,{recursive:!0,force:!0}),!0}catch(e){if(D(e))return!1;throw e}}async function Zt(n,e={}){try{let s=await fe.readdir(n,{withFileTypes:!0});return e.filesOnly&&(s=s.filter(r=>r.isFile())),e.dirsOnly&&(s=s.filter(r=>r.isDirectory())),e.extension&&(s=s.filter(r=>r.name.endsWith(e.extension))),s.map(r=>r.name)}catch(t){if(D(t))return[];throw t}}async function wh(n){return(await fe.stat(n)).size}async function kh(n){return(await fe.stat(n)).mtime}async function Sh(n,e){await fe.copyFile(n,e)}async function vh(n,e){await fe.rename(n,e)}async function bh(n){return(await ct(n,"")).split(`
|
|
11
11
|
`)}async function Th(n,e){let t=e.join(`
|
|
12
|
-
`);await _t(n,t)}function Eh(n){return Yt.extname(n)}function Ch(n){return Yt.basename(n,Yt.extname(n))}var z=h(()=>{"use strict";$i();tu();q();c(Ns,"walkDir");c(Os,"batchProcess");c(Ee,"readJson");c(ae,"writeJson");c(ct,"readFile");c(_t,"writeFile");c(ph,"atomicWrite");c(mh,"appendToFile");c(gh,"appendLine");c(fh,"prependToFile");c(v,"fileExists");c(Qt,"dirExists");c(jt,"ensureDir");c(hh,"deleteFile");c(yh,"deleteDir");c(Zt,"listFiles");c(wh,"getFileSize");c(kh,"getFileModifiedTime");c(Sh,"copyFile");c(vh,"moveFile");c(bh,"readLines");c(Th,"writeLines");c(Eh,"getFileExtension");c(Ch,"getFileNameWithoutExtension")});function an(n,e){let t=typeof n=="string"?new Date(n).getTime():n;return Date.now()-t>e}var Xr,cr=h(()=>{"use strict";c(an,"isExpired");Xr=class{static{c(this,"TTLCache")}cache=new Map;ttl;maxSize;constructor(e={}){this.ttl=e.ttl??5e3,this.maxSize=e.maxSize??50}isValid(e){let t=this.cache.get(e);return t?Date.now()-t.timestamp<this.ttl:!1}get(e){let t=this.cache.get(e);return t?this.isValid(e)?t.data:(this.cache.delete(e),null):null}set(e,t){this.cache.set(e,{data:t,timestamp:Date.now()}),this.evictOldEntries()}delete(e){this.cache.delete(e)}clear(){this.cache.clear()}has(e){return this.cache.has(e)}get size(){return this.cache.size}evictOldEntries(){if(this.cache.size<=this.maxSize)return;let t=Array.from(this.cache.entries()).sort((s,r)=>s[1].timestamp-r[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[s]of t)this.cache.delete(s)}stats(){return{size:this.cache.size,maxSize:this.maxSize,ttl:this.ttl}}prune(){let e=0;for(let t of this.cache.keys())this.isValid(t)||(this.cache.delete(t),e++);return e}}});var ru={};G(ru,{invalidateProviderCache:()=>Rh,readProviderCache:()=>Ni,writeProviderCache:()=>Oi});import su from"node:fs/promises";import Ph from"node:os";import nu from"node:path";async function Ni(){try{let n=await su.readFile(Mi,"utf-8"),e=JSON.parse(n);return!e.timestamp||!e.detection||!e.detection.claude||!e.detection.gemini||!e.detection.codex||an(e.timestamp,xh)?null:e.detection}catch{return null}}async function Oi(n){let e={timestamp:new Date().toISOString(),detection:n};await ae(Mi,e)}async function Rh(){try{await su.unlink(Mi)}catch{}}var jh,Mi,xh,_i=h(()=>{"use strict";cr();z();jh=nu.join(Ph.homedir(),".prjct-cli","cache"),Mi=nu.join(jh,"providers.json"),xh=10*60*1e3;c(Ni,"readProviderCache");c(Oi,"writeProviderCache");c(Rh,"invalidateProviderCache")});var wt={};G(wt,{AntigravityProvider:()=>Fi,ClaudeProvider:()=>Kr,CodexProvider:()=>Ui,CursorProvider:()=>iu,GeminiProvider:()=>Li,Providers:()=>$e,WindsurfProvider:()=>au,detectAllProviders:()=>ts,detectAntigravity:()=>cn,detectCodex:()=>_s,detectCursorProject:()=>uu,detectProvider:()=>Yr,detectWindsurfProject:()=>du,getActiveProvider:()=>Dh,getCapabilities:()=>Ih,getCommandsDir:()=>Uh,getGlobalContextPath:()=>_h,getGlobalSettingsPath:()=>Lh,getProjectCommandsPath:()=>Hh,getProviderBranding:()=>Qr,getSkillsPath:()=>Fh,hasProviderConfig:()=>Mh,needsCursorRouterRegeneration:()=>Nh,needsWindsurfRouterRegeneration:()=>Oh,selectProvider:()=>Hi,validateCliVersion:()=>lu});import ms from"node:os";import _e from"node:path";function Ih(n,e){return{...Ah[n],...e}}async function cu(n){try{let{stdout:e}=await _(`which ${n}`,{timeout:2e3});return e.trim()}catch{return null}}async function $h(n){try{let{stdout:e}=await _(`${n} --version`,{timeout:2e3}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function Yr(n){let e=$e[n];if(!e.cliCommand)return{installed:!1};let t=await cu(e.cliCommand);if(!t)return{installed:!1};let s=await $h(e.cliCommand),r=lu(n,s||void 0);return{installed:!0,version:s||void 0,path:t,versionWarning:r||void 0}}function lu(n,e){let t=$e[n];return!t.minCliVersion||!e?null:Bl(e,t.minCliVersion)<0?`\u26A0\uFE0F ${t.displayName} v${e} is below minimum v${t.minCliVersion}. Some features may not work correctly.`:null}async function ts(n=!1){if(!n){let i=await Ni();if(i)return i}let[e,t,s]=await Promise.all([Yr("claude"),Yr("gemini"),_s()]),r={installed:s.installed},o={claude:e,gemini:t,codex:r};return await Oi(o).catch(()=>{}),o}async function Dh(n){if(n&&$e[n])return $e[n];let e=await ts();return e.claude.installed&&!e.gemini.installed?Kr:e.gemini.installed&&!e.claude.installed?Li:Kr}async function Mh(n){let e=$e[n];return e.configDir?v(e.configDir):!1}function Qr(n){return{commitFooter:"Generated with [p/](https://www.prjct.app/)",signature:{claude:"\u26A1 prjct + Claude",gemini:"\u26A1 prjct + Gemini",cursor:"\u26A1 prjct + Cursor",antigravity:"\u26A1 prjct + Antigravity",windsurf:"\u26A1 prjct + Windsurf",codex:"\u26A1 prjct + Codex"}[n]||"\u26A1 prjct"}}async function uu(n){let e=_e.join(n,".cursor"),t=_e.join(e,"rules"),s=_e.join(t,"prjct.mdc"),[r,o]=await Promise.all([v(e),v(s)]);return{detected:r,routerInstalled:o,projectRoot:r?n:void 0}}async function Nh(n){let e=await uu(n);return e.detected&&!e.routerInstalled}async function du(n){let e=_e.join(n,".windsurf"),t=_e.join(e,"rules"),s=_e.join(t,"prjct.md"),[r,o]=await Promise.all([v(e),v(s)]);return{detected:r,routerInstalled:o,projectRoot:r?n:void 0}}async function Oh(n){let e=await du(n);return e.detected&&!e.routerInstalled}async function cn(){let n=Fi.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=_e.join(n,"skills","prjct","SKILL.md"),[t,s]=await Promise.all([v(n),v(e)]);return{installed:t,skillInstalled:s,configPath:t?n:void 0}}async function _s(){let n=Ui.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=await cu("codex"),t=_e.join(n,"skills","prjct","SKILL.md"),s=await v(t),r=!!e;return{installed:r,skillInstalled:s,configPath:r?n:void 0}}function _h(n){let e=$e[n];return e.configDir?_e.join(e.configDir,e.contextFile):null}function Lh(n){let e=$e[n];return!e.configDir||!e.settingsFile?null:_e.join(e.configDir,e.settingsFile)}function Fh(n){return $e[n].skillsDir}function Uh(n){return $e[n].commandsDir}function Hh(n,e){let t=$e[n];return _e.join(e,t.commandsDir)}async function Hi(){let n=await ts(),e=n.claude.installed,t=n.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:n}:e&&!t?{provider:"claude",userSelected:!1,detection:n}:t&&!e?{provider:"gemini",userSelected:!1,detection:n}:{provider:"claude",userSelected:!0,detection:n}}var Ah,Kr,Li,Fi,iu,au,Ui,$e,Ve=h(()=>{"use strict";Jr();zr();st();z();_i();Ah={full:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!0,webFetch:!0,todoTracking:!0},standard:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!1,webFetch:!1,todoTracking:!1},basic:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!1,subagents:!1,webFetch:!1,todoTracking:!1}};c(Ih,"getCapabilities");Kr={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:_e.join(ms.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:_e.join(ms.homedir(),".claude","skills"),commandsDir:".claude/commands",commandFormat:"md",settingsFile:"settings.json",projectSettingsFile:"settings.local.json",ignoreFile:".claudeignore",websiteUrl:"https://www.anthropic.com/claude",docsUrl:"https://docs.anthropic.com/claude-code",defaultModel:"sonnet",supportedModels:["opus","sonnet","haiku"],minCliVersion:"1.0.0",capabilityTier:"full"},Li={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:_e.join(ms.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:_e.join(ms.homedir(),".gemini","skills"),commandsDir:".gemini/commands",commandFormat:"toml",settingsFile:"settings.json",projectSettingsFile:"settings.json",ignoreFile:".geminiignore",websiteUrl:"https://geminicli.com",docsUrl:"https://geminicli.com/docs",defaultModel:"2.5-flash",supportedModels:["2.5-pro","2.5-flash","2.0-flash"],minCliVersion:"1.0.0",capabilityTier:"standard"},Fi={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:_e.join(ms.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:_e.join(ms.homedir(),".gemini","antigravity","global_skills"),commandsDir:".agent/skills",commandFormat:"md",settingsFile:"mcp_config.json",projectSettingsFile:null,ignoreFile:".agentignore",websiteUrl:"https://gemini.google.com/app/antigravity",docsUrl:"https://gemini.google.com/app/antigravity",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},iu={name:"cursor",displayName:"Cursor IDE",cliCommand:null,configDir:null,contextFile:"prjct.mdc",skillsDir:null,commandsDir:".cursor/commands",rulesDir:".cursor/rules",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".cursorignore",isProjectLevel:!0,websiteUrl:"https://cursor.com",docsUrl:"https://cursor.com/docs",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},au={name:"windsurf",displayName:"Windsurf IDE",cliCommand:null,configDir:null,contextFile:"prjct.md",skillsDir:null,commandsDir:".windsurf/workflows",rulesDir:".windsurf/rules",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".windsurfignore",isProjectLevel:!0,websiteUrl:"https://windsurf.com",docsUrl:"https://docs.windsurf.com",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},Ui={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:_e.join(ms.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:_e.join(ms.homedir(),".codex","skills"),commandsDir:".agents/skills",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".codexignore",websiteUrl:"https://openai.com/codex",docsUrl:"https://github.com/openai/codex",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},$e={claude:Kr,gemini:Li,cursor:iu,antigravity:Fi,windsurf:au,codex:Ui};c(cu,"whichCommand");c($h,"getCliVersion");c(Yr,"detectProvider");c(lu,"validateCliVersion");c(ts,"detectAllProviders");c(Dh,"getActiveProvider");c(Mh,"hasProviderConfig");c(Qr,"getProviderBranding");c(uu,"detectCursorProject");c(Nh,"needsCursorRouterRegeneration");c(du,"detectWindsurfProject");c(Oh,"needsWindsurfRouterRegeneration");c(cn,"detectAntigravity");c(_s,"detectCodex");c(_h,"getGlobalContextPath");c(Lh,"getGlobalSettingsPath");c(Fh,"getSkillsPath");c(Uh,"getCommandsDir");c(Hh,"getProjectCommandsPath");c(Hi,"selectProvider")});import{z as Se}from"zod";function Wh(n){return n instanceof ln}function ge(n){return Wh(n)||n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}var un,wC,kC,SC,vC,bC,TC,ln,Zr,eo,lr,gs=h(()=>{"use strict";un={create(n,e){class t extends Error{static{c(this,"TypedError")}errorName;data;isOperational=!0;constructor(r){let o=e.parse(r);super(`${n}: ${JSON.stringify(o)}`),this.name=n,this.errorName=n,this.data=o,Error.captureStackTrace?.(this,this.constructor)}static throw(r){throw new t(r)}static is(r){return r instanceof t&&r.errorName===n}static create(r){return new t(r)}}return t}},wC=un.create("FileError",Se.object({path:Se.string(),operation:Se.enum(["read","write","delete","create","copy"]),reason:Se.string().optional()})),kC=un.create("ValidationError",Se.object({field:Se.string(),expected:Se.string(),received:Se.string().optional(),message:Se.string().optional()})),SC=un.create("PermissionError",Se.object({action:Se.string(),resource:Se.string(),reason:Se.string().optional()})),vC=un.create("TaskError",Se.object({taskId:Se.string().optional(),operation:Se.enum(["create","update","complete","pause","resume","delete"]),reason:Se.string()})),bC=un.create("SessionError",Se.object({sessionId:Se.string().optional(),reason:Se.string()})),TC=un.create("SyncError",Se.object({projectId:Se.string().optional(),operation:Se.enum(["push","pull","auth","connect"]),reason:Se.string()})),ln=class extends Error{static{c(this,"PrjctError")}code;isOperational;constructor(e,t="PRJCT_ERROR"){super(e),this.name="PrjctError",this.code=t,this.isOperational=!0,Error.captureStackTrace?.(this,this.constructor)}},Zr=class n extends ln{static{c(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new n("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new n(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new n(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},eo=class n extends ln{static{c(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new n(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new n(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},lr=class n extends ln{static{c(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new n(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new n(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};c(Wh,"isPrjctError");c(ge,"getErrorMessage")});import{formatDistanceToNowStrict as jC}from"date-fns";function pu(n){let e=n.getFullYear(),t=(n.getMonth()+1).toString().padStart(2,"0"),s=n.getDate().toString().padStart(2,"0");return`${e}-${t}-${s}`}function mu(n){return{year:n.getFullYear().toString(),month:(n.getMonth()+1).toString().padStart(2,"0"),day:n.getDate().toString().padStart(2,"0")}}function x(){return new Date().toISOString()}function dn(n){let e=new Date;return e.setDate(e.getDate()-n),e}function ur(n){let e=Math.floor(n/1e3),t=Math.floor(e/60),s=Math.floor(t/60),r=Math.floor(s/24);return r>0?`${r}d ${s%24}h`:s>0?`${s}h ${t%60}m`:t>0?`${t}m`:`${e}s`}var Ce=h(()=>{"use strict";c(pu,"formatDate");c(mu,"getYearMonthDay");c(x,"getTimestamp");c(dn,"getDaysAgo");c(ur,"formatDuration")});var mn={};G(mn,{PACKAGE_ROOT:()=>kt,VERSION:()=>ce,compareVersions:()=>gu,getPackageInfo:()=>Gh,getPackageRoot:()=>Gi,getVersion:()=>Ls,isCompatible:()=>Vh,needsMigration:()=>qh,resetPackageRoot:()=>Vi});import Wi from"node:fs";import to from"node:path";function Gi(){if(pn)return pn;let n=__dirname;for(let e=0;e<5;e++){let t=to.join(n,"package.json");if(Wi.existsSync(t))try{if(JSON.parse(Wi.readFileSync(t,"utf-8")).name==="prjct-cli")return pn=n,n}catch{}n=to.dirname(n)}return pn=to.join(__dirname,"..","..",".."),pn}function Ls(){if(dr)return dr;try{let n=to.join(Gi(),"package.json"),e=JSON.parse(Wi.readFileSync(n,"utf-8"));return dr=e.version,so=e,dr}catch(n){return console.error("Failed to read version from package.json:",k(n)),"0.0.0"}}function Gh(){return so||Ls(),so}function gu(n,e){let t=n.split(".").map(Number),s=e.split(".").map(Number);for(let r=0;r<Math.max(t.length,s.length);r++){let o=t[r]||0,i=s[r]||0;if(o>i)return 1;if(o<i)return-1}return 0}function Vh(n){let e=Ls(),[t,s]=e.split(".").map(Number),[r,o]=n.split(".").map(Number);return t===r&&s===o}function qh(n,e=null){let t=e||Ls();return gu(n,t)<0}function Vi(n){pn=n,dr=null,so=null}var dr,so,pn,ce,kt,qe=h(()=>{"use strict";q();dr=null,so=null,pn=null;c(Gi,"getPackageRoot");c(Ls,"getVersion");c(Gh,"getPackageInfo");c(gu,"compareVersions");c(Vh,"isCompatible");c(qh,"needsMigration");c(Vi,"resetPackageRoot");ce=Ls(),kt=Gi()});async function no(n){try{let{stdout:e}=await _(n,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function Bh(){let n=await no("gh api user --jq .login");return n.success&&n.output||(n=await no("git config --global github.user"),n.success&&n.output)?n.output:null}async function Jh(){let n=await no("git config user.name");return n.success&&n.output?n.output:null}async function zh(){let n=await no("git config user.email");return n.success&&n.output?n.output:null}async function gn(){let[n,e,t]=await Promise.all([Bh(),Jh(),zh()]);return{github:n,email:t,name:e||n||"Unknown"}}var ro=h(()=>{"use strict";st();c(no,"execCommand");c(Bh,"detectGitHubUsername");c(Jh,"detectGitName");c(zh,"detectGitEmail");c(gn,"detect")});var fu={};G(fu,{default:()=>$});import Xh from"node:crypto";import Lt from"node:fs/promises";import fn from"node:os";import O from"node:path";import{globSync as Kh}from"glob";var Bi,Yh,$,Pe=h(()=>{"use strict";Ce();z();Bi=class{static{c(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?O.resolve(e):O.join(fn.homedir(),".prjct-cli"),this.globalProjectsDir=O.join(this.globalBaseDir,"projects"),this.globalConfigDir=O.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=O.resolve(e),this.globalProjectsDir=O.join(this.globalBaseDir,"projects"),this.globalConfigDir=O.join(this.globalBaseDir,"config")}generateProjectId(e){return Xh.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return O.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return O.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return O.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return O.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await Qt(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await v(t)}async ensureGlobalStructure(){await jt(this.globalBaseDir),await jt(this.globalProjectsDir),await jt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),s=["core","progress","planning","analysis","memory"];for(let r of s)await jt(O.join(t,r));return await jt(O.join(t,"planning","tasks")),await jt(O.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:s,month:r,day:o}=mu(t);return O.join(this.getGlobalProjectPath(e),"sessions",s,r,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let s=this.getSessionPath(e,t);return await jt(s),s}async listSessions(e,t=null,s=null){let r=O.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Lt.readdir(r,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let l=O.join(r,a.name),u=await Lt.readdir(l,{withFileTypes:!0});for(let d of u){if(!d.isDirectory()||s&&d.name!==s.toString().padStart(2,"0"))continue;let m=O.join(l,d.name),p=await Lt.readdir(m,{withFileTypes:!0});for(let g of p)g.isDirectory()&&o.push({year:a.name,month:d.name,day:g.name,path:O.join(m,g.name),date:new Date(`${a.name}-${d.name}-${g.name}`)})}}return o.sort((a,l)=>l.date.getTime()-a.date.getTime()),o}catch{return[]}}async getSessionsInRange(e,t,s=new Date){return(await this.listSessions(e)).filter(o=>o.date>=t&&o.date<=s)}getFilePath(e,t,s){return O.join(this.getGlobalProjectPath(e),t,s)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Lt.readdir(this.globalProjectsDir,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}async projectExists(e){let t=this.getGlobalProjectPath(e);return await Qt(t)}getDisplayPath(e){let t=fn.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return O.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return O.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return O.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return O.join(this.globalBaseDir,".running")}getDocsPath(){return O.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(Ve(),yt(wt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(Ve(),yt(wt)).getActiveProvider();return(Ve(),yt(wt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return O.join(fn.homedir(),".claude")}getClaudeSettingsPath(){return O.join(this.getClaudeDir(),"settings.json")}getStoragePath(e,t){return O.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return O.join(this.getGlobalProjectPath(e),"context")}getWikiPath(e,t){if(t&&t.trim().length>0)return this.resolveVaultOverride(e,t);let r=O.basename(O.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project";return O.join(fn.homedir(),"Documents","prjct",r)}getWikiPathWithProjectHash(e,t){let r=O.basename(O.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project",o=t.replace(/-/g,"").slice(0,8);return O.join(fn.homedir(),"Documents","prjct",`${r}-${o}`)}getLegacyWikiPath(e){return O.join(e,".prjct","wiki")}resolveVaultOverride(e,t){let s=t.trim();return(s.startsWith("~/")||s==="~")&&(s=O.join(fn.homedir(),s.slice(1))),O.isAbsolute(s)||(s=O.resolve(e,s)),s}async detectMonorepo(e){let t={isMonorepo:!1,type:null,rootPath:e,packages:[]},s=[{file:"pnpm-workspace.yaml",type:"pnpm"},{file:"lerna.json",type:"lerna"},{file:"nx.json",type:"nx"},{file:"rush.json",type:"rush"},{file:"turbo.json",type:"turborepo"}];for(let r of s){let o=O.join(e,r.file);if(await v(o)){t.isMonorepo=!0,t.type=r.type;break}}if(!t.isMonorepo){let r=O.join(e,"package.json");if(await v(r))try{let o=await Lt.readFile(r,"utf-8");JSON.parse(o).workspaces&&(t.isMonorepo=!0,t.type="npm")}catch{}}return t.isMonorepo&&(t.packages=await this.discoverMonorepoPackages(e,t.type)),t}async discoverMonorepoPackages(e,t){let s=[],r=[];try{if(t==="pnpm"){let i=(await Lt.readFile(O.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(r=i[1].split(`
|
|
12
|
+
`);await _t(n,t)}function Eh(n){return Yt.extname(n)}function Ch(n){return Yt.basename(n,Yt.extname(n))}var z=h(()=>{"use strict";$i();tu();q();c(Ns,"walkDir");c(Os,"batchProcess");c(Ee,"readJson");c(ae,"writeJson");c(ct,"readFile");c(_t,"writeFile");c(ph,"atomicWrite");c(mh,"appendToFile");c(gh,"appendLine");c(fh,"prependToFile");c(v,"fileExists");c(Qt,"dirExists");c(jt,"ensureDir");c(hh,"deleteFile");c(yh,"deleteDir");c(Zt,"listFiles");c(wh,"getFileSize");c(kh,"getFileModifiedTime");c(Sh,"copyFile");c(vh,"moveFile");c(bh,"readLines");c(Th,"writeLines");c(Eh,"getFileExtension");c(Ch,"getFileNameWithoutExtension")});function an(n,e){let t=typeof n=="string"?new Date(n).getTime():n;return Date.now()-t>e}var Xr,cr=h(()=>{"use strict";c(an,"isExpired");Xr=class{static{c(this,"TTLCache")}cache=new Map;ttl;maxSize;constructor(e={}){this.ttl=e.ttl??5e3,this.maxSize=e.maxSize??50}isValid(e){let t=this.cache.get(e);return t?Date.now()-t.timestamp<this.ttl:!1}get(e){let t=this.cache.get(e);return t?this.isValid(e)?t.data:(this.cache.delete(e),null):null}set(e,t){this.cache.set(e,{data:t,timestamp:Date.now()}),this.evictOldEntries()}delete(e){this.cache.delete(e)}clear(){this.cache.clear()}has(e){return this.cache.has(e)}get size(){return this.cache.size}evictOldEntries(){if(this.cache.size<=this.maxSize)return;let t=Array.from(this.cache.entries()).sort((s,r)=>s[1].timestamp-r[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[s]of t)this.cache.delete(s)}stats(){return{size:this.cache.size,maxSize:this.maxSize,ttl:this.ttl}}prune(){let e=0;for(let t of this.cache.keys())this.isValid(t)||(this.cache.delete(t),e++);return e}}});var ru={};G(ru,{invalidateProviderCache:()=>Rh,readProviderCache:()=>Ni,writeProviderCache:()=>Oi});import su from"node:fs/promises";import Ph from"node:os";import nu from"node:path";async function Ni(){try{let n=await su.readFile(Mi,"utf-8"),e=JSON.parse(n);return!e.timestamp||!e.detection||!e.detection.claude||!e.detection.gemini||!e.detection.codex||an(e.timestamp,xh)?null:e.detection}catch{return null}}async function Oi(n){let e={timestamp:new Date().toISOString(),detection:n};await ae(Mi,e)}async function Rh(){try{await su.unlink(Mi)}catch{}}var jh,Mi,xh,_i=h(()=>{"use strict";cr();z();jh=nu.join(Ph.homedir(),".prjct-cli","cache"),Mi=nu.join(jh,"providers.json"),xh=10*60*1e3;c(Ni,"readProviderCache");c(Oi,"writeProviderCache");c(Rh,"invalidateProviderCache")});var wt={};G(wt,{AntigravityProvider:()=>Fi,ClaudeProvider:()=>Kr,CodexProvider:()=>Ui,CursorProvider:()=>iu,GeminiProvider:()=>Li,Providers:()=>$e,WindsurfProvider:()=>au,detectAllProviders:()=>ts,detectAntigravity:()=>cn,detectCodex:()=>_s,detectCursorProject:()=>uu,detectProvider:()=>Yr,detectWindsurfProject:()=>du,getActiveProvider:()=>Dh,getCapabilities:()=>Ih,getCommandsDir:()=>Uh,getGlobalContextPath:()=>_h,getGlobalSettingsPath:()=>Lh,getProjectCommandsPath:()=>Hh,getProviderBranding:()=>Qr,getSkillsPath:()=>Fh,hasProviderConfig:()=>Mh,needsCursorRouterRegeneration:()=>Nh,needsWindsurfRouterRegeneration:()=>Oh,selectProvider:()=>Hi,validateCliVersion:()=>lu});import ms from"node:os";import _e from"node:path";function Ih(n,e){return{...Ah[n],...e}}async function cu(n){try{let{stdout:e}=await _(`which ${n}`,{timeout:2e3});return e.trim()}catch{return null}}async function $h(n){try{let{stdout:e}=await _(`${n} --version`,{timeout:2e3}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function Yr(n){let e=$e[n];if(!e.cliCommand)return{installed:!1};let t=await cu(e.cliCommand);if(!t)return{installed:!1};let s=await $h(e.cliCommand),r=lu(n,s||void 0);return{installed:!0,version:s||void 0,path:t,versionWarning:r||void 0}}function lu(n,e){let t=$e[n];return!t.minCliVersion||!e?null:Bl(e,t.minCliVersion)<0?`\u26A0\uFE0F ${t.displayName} v${e} is below minimum v${t.minCliVersion}. Some features may not work correctly.`:null}async function ts(n=!1){if(!n){let i=await Ni();if(i)return i}let[e,t,s]=await Promise.all([Yr("claude"),Yr("gemini"),_s()]),r={installed:s.installed},o={claude:e,gemini:t,codex:r};return await Oi(o).catch(()=>{}),o}async function Dh(n){if(n&&$e[n])return $e[n];let e=await ts();return e.claude.installed&&!e.gemini.installed?Kr:e.gemini.installed&&!e.claude.installed?Li:Kr}async function Mh(n){let e=$e[n];return e.configDir?v(e.configDir):!1}function Qr(n){return{commitFooter:"Generated with [p/](https://www.prjct.app/)",signature:{claude:"\u26A1 prjct + Claude",gemini:"\u26A1 prjct + Gemini",cursor:"\u26A1 prjct + Cursor",antigravity:"\u26A1 prjct + Antigravity",windsurf:"\u26A1 prjct + Windsurf",codex:"\u26A1 prjct + Codex"}[n]||"\u26A1 prjct"}}async function uu(n){let e=_e.join(n,".cursor"),t=_e.join(e,"rules"),s=_e.join(t,"prjct.mdc"),[r,o]=await Promise.all([v(e),v(s)]);return{detected:r,routerInstalled:o,projectRoot:r?n:void 0}}async function Nh(n){let e=await uu(n);return e.detected&&!e.routerInstalled}async function du(n){let e=_e.join(n,".windsurf"),t=_e.join(e,"rules"),s=_e.join(t,"prjct.md"),[r,o]=await Promise.all([v(e),v(s)]);return{detected:r,routerInstalled:o,projectRoot:r?n:void 0}}async function Oh(n){let e=await du(n);return e.detected&&!e.routerInstalled}async function cn(){let n=Fi.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=_e.join(n,"skills","prjct","SKILL.md"),[t,s]=await Promise.all([v(n),v(e)]);return{installed:t,skillInstalled:s,configPath:t?n:void 0}}async function _s(){let n=Ui.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=await cu("codex"),t=_e.join(n,"skills","prjct","SKILL.md"),s=await v(t),r=!!e;return{installed:r,skillInstalled:s,configPath:r?n:void 0}}function _h(n){let e=$e[n];return e.configDir?_e.join(e.configDir,e.contextFile):null}function Lh(n){let e=$e[n];return!e.configDir||!e.settingsFile?null:_e.join(e.configDir,e.settingsFile)}function Fh(n){return $e[n].skillsDir}function Uh(n){return $e[n].commandsDir}function Hh(n,e){let t=$e[n];return _e.join(e,t.commandsDir)}async function Hi(){let n=await ts(),e=n.claude.installed,t=n.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:n}:e&&!t?{provider:"claude",userSelected:!1,detection:n}:t&&!e?{provider:"gemini",userSelected:!1,detection:n}:{provider:"claude",userSelected:!0,detection:n}}var Ah,Kr,Li,Fi,iu,au,Ui,$e,Ve=h(()=>{"use strict";Jr();zr();st();z();_i();Ah={full:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!0,webFetch:!0,todoTracking:!0},standard:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!1,webFetch:!1,todoTracking:!1},basic:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!1,subagents:!1,webFetch:!1,todoTracking:!1}};c(Ih,"getCapabilities");Kr={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:_e.join(ms.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:_e.join(ms.homedir(),".claude","skills"),commandsDir:".claude/commands",commandFormat:"md",settingsFile:"settings.json",projectSettingsFile:"settings.local.json",ignoreFile:".claudeignore",websiteUrl:"https://www.anthropic.com/claude",docsUrl:"https://docs.anthropic.com/claude-code",defaultModel:"sonnet",supportedModels:["opus","sonnet","haiku"],minCliVersion:"1.0.0",capabilityTier:"full"},Li={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:_e.join(ms.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:_e.join(ms.homedir(),".gemini","skills"),commandsDir:".gemini/commands",commandFormat:"toml",settingsFile:"settings.json",projectSettingsFile:"settings.json",ignoreFile:".geminiignore",websiteUrl:"https://geminicli.com",docsUrl:"https://geminicli.com/docs",defaultModel:"2.5-flash",supportedModels:["2.5-pro","2.5-flash","2.0-flash"],minCliVersion:"1.0.0",capabilityTier:"standard"},Fi={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:_e.join(ms.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:_e.join(ms.homedir(),".gemini","antigravity","global_skills"),commandsDir:".agent/skills",commandFormat:"md",settingsFile:"mcp_config.json",projectSettingsFile:null,ignoreFile:".agentignore",websiteUrl:"https://gemini.google.com/app/antigravity",docsUrl:"https://gemini.google.com/app/antigravity",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},iu={name:"cursor",displayName:"Cursor IDE",cliCommand:null,configDir:null,contextFile:"prjct.mdc",skillsDir:null,commandsDir:".cursor/commands",rulesDir:".cursor/rules",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".cursorignore",isProjectLevel:!0,websiteUrl:"https://cursor.com",docsUrl:"https://cursor.com/docs",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},au={name:"windsurf",displayName:"Windsurf IDE",cliCommand:null,configDir:null,contextFile:"prjct.md",skillsDir:null,commandsDir:".windsurf/workflows",rulesDir:".windsurf/rules",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".windsurfignore",isProjectLevel:!0,websiteUrl:"https://windsurf.com",docsUrl:"https://docs.windsurf.com",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},Ui={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:_e.join(ms.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:_e.join(ms.homedir(),".codex","skills"),commandsDir:".agents/skills",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".codexignore",websiteUrl:"https://openai.com/codex",docsUrl:"https://github.com/openai/codex",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},$e={claude:Kr,gemini:Li,cursor:iu,antigravity:Fi,windsurf:au,codex:Ui};c(cu,"whichCommand");c($h,"getCliVersion");c(Yr,"detectProvider");c(lu,"validateCliVersion");c(ts,"detectAllProviders");c(Dh,"getActiveProvider");c(Mh,"hasProviderConfig");c(Qr,"getProviderBranding");c(uu,"detectCursorProject");c(Nh,"needsCursorRouterRegeneration");c(du,"detectWindsurfProject");c(Oh,"needsWindsurfRouterRegeneration");c(cn,"detectAntigravity");c(_s,"detectCodex");c(_h,"getGlobalContextPath");c(Lh,"getGlobalSettingsPath");c(Fh,"getSkillsPath");c(Uh,"getCommandsDir");c(Hh,"getProjectCommandsPath");c(Hi,"selectProvider")});import{z as Se}from"zod";function Wh(n){return n instanceof ln}function ge(n){return Wh(n)||n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}var un,kC,SC,vC,bC,TC,EC,ln,Zr,eo,lr,gs=h(()=>{"use strict";un={create(n,e){class t extends Error{static{c(this,"TypedError")}errorName;data;isOperational=!0;constructor(r){let o=e.parse(r);super(`${n}: ${JSON.stringify(o)}`),this.name=n,this.errorName=n,this.data=o,Error.captureStackTrace?.(this,this.constructor)}static throw(r){throw new t(r)}static is(r){return r instanceof t&&r.errorName===n}static create(r){return new t(r)}}return t}},kC=un.create("FileError",Se.object({path:Se.string(),operation:Se.enum(["read","write","delete","create","copy"]),reason:Se.string().optional()})),SC=un.create("ValidationError",Se.object({field:Se.string(),expected:Se.string(),received:Se.string().optional(),message:Se.string().optional()})),vC=un.create("PermissionError",Se.object({action:Se.string(),resource:Se.string(),reason:Se.string().optional()})),bC=un.create("TaskError",Se.object({taskId:Se.string().optional(),operation:Se.enum(["create","update","complete","pause","resume","delete"]),reason:Se.string()})),TC=un.create("SessionError",Se.object({sessionId:Se.string().optional(),reason:Se.string()})),EC=un.create("SyncError",Se.object({projectId:Se.string().optional(),operation:Se.enum(["push","pull","auth","connect"]),reason:Se.string()})),ln=class extends Error{static{c(this,"PrjctError")}code;isOperational;constructor(e,t="PRJCT_ERROR"){super(e),this.name="PrjctError",this.code=t,this.isOperational=!0,Error.captureStackTrace?.(this,this.constructor)}},Zr=class n extends ln{static{c(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new n("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new n(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new n(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},eo=class n extends ln{static{c(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new n(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new n(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},lr=class n extends ln{static{c(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new n(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new n(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};c(Wh,"isPrjctError");c(ge,"getErrorMessage")});import{formatDistanceToNowStrict as xC}from"date-fns";function pu(n){let e=n.getFullYear(),t=(n.getMonth()+1).toString().padStart(2,"0"),s=n.getDate().toString().padStart(2,"0");return`${e}-${t}-${s}`}function mu(n){return{year:n.getFullYear().toString(),month:(n.getMonth()+1).toString().padStart(2,"0"),day:n.getDate().toString().padStart(2,"0")}}function x(){return new Date().toISOString()}function dn(n){let e=new Date;return e.setDate(e.getDate()-n),e}function ur(n){let e=Math.floor(n/1e3),t=Math.floor(e/60),s=Math.floor(t/60),r=Math.floor(s/24);return r>0?`${r}d ${s%24}h`:s>0?`${s}h ${t%60}m`:t>0?`${t}m`:`${e}s`}var Ce=h(()=>{"use strict";c(pu,"formatDate");c(mu,"getYearMonthDay");c(x,"getTimestamp");c(dn,"getDaysAgo");c(ur,"formatDuration")});var mn={};G(mn,{PACKAGE_ROOT:()=>kt,VERSION:()=>ce,compareVersions:()=>gu,getPackageInfo:()=>Gh,getPackageRoot:()=>Gi,getVersion:()=>Ls,isCompatible:()=>Vh,needsMigration:()=>qh,resetPackageRoot:()=>Vi});import Wi from"node:fs";import to from"node:path";function Gi(){if(pn)return pn;let n=__dirname;for(let e=0;e<5;e++){let t=to.join(n,"package.json");if(Wi.existsSync(t))try{if(JSON.parse(Wi.readFileSync(t,"utf-8")).name==="prjct-cli")return pn=n,n}catch{}n=to.dirname(n)}return pn=to.join(__dirname,"..","..",".."),pn}function Ls(){if(dr)return dr;try{let n=to.join(Gi(),"package.json"),e=JSON.parse(Wi.readFileSync(n,"utf-8"));return dr=e.version,so=e,dr}catch(n){return console.error("Failed to read version from package.json:",k(n)),"0.0.0"}}function Gh(){return so||Ls(),so}function gu(n,e){let t=n.split(".").map(Number),s=e.split(".").map(Number);for(let r=0;r<Math.max(t.length,s.length);r++){let o=t[r]||0,i=s[r]||0;if(o>i)return 1;if(o<i)return-1}return 0}function Vh(n){let e=Ls(),[t,s]=e.split(".").map(Number),[r,o]=n.split(".").map(Number);return t===r&&s===o}function qh(n,e=null){let t=e||Ls();return gu(n,t)<0}function Vi(n){pn=n,dr=null,so=null}var dr,so,pn,ce,kt,qe=h(()=>{"use strict";q();dr=null,so=null,pn=null;c(Gi,"getPackageRoot");c(Ls,"getVersion");c(Gh,"getPackageInfo");c(gu,"compareVersions");c(Vh,"isCompatible");c(qh,"needsMigration");c(Vi,"resetPackageRoot");ce=Ls(),kt=Gi()});async function no(n){try{let{stdout:e}=await _(n,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function Bh(){let n=await no("gh api user --jq .login");return n.success&&n.output||(n=await no("git config --global github.user"),n.success&&n.output)?n.output:null}async function Jh(){let n=await no("git config user.name");return n.success&&n.output?n.output:null}async function zh(){let n=await no("git config user.email");return n.success&&n.output?n.output:null}async function gn(){let[n,e,t]=await Promise.all([Bh(),Jh(),zh()]);return{github:n,email:t,name:e||n||"Unknown"}}var ro=h(()=>{"use strict";st();c(no,"execCommand");c(Bh,"detectGitHubUsername");c(Jh,"detectGitName");c(zh,"detectGitEmail");c(gn,"detect")});var fu={};G(fu,{default:()=>$});import Xh from"node:crypto";import Lt from"node:fs/promises";import fn from"node:os";import O from"node:path";import{globSync as Kh}from"glob";var Bi,Yh,$,Pe=h(()=>{"use strict";Ce();z();Bi=class{static{c(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?O.resolve(e):O.join(fn.homedir(),".prjct-cli"),this.globalProjectsDir=O.join(this.globalBaseDir,"projects"),this.globalConfigDir=O.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=O.resolve(e),this.globalProjectsDir=O.join(this.globalBaseDir,"projects"),this.globalConfigDir=O.join(this.globalBaseDir,"config")}generateProjectId(e){return Xh.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return O.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return O.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return O.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return O.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await Qt(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await v(t)}async ensureGlobalStructure(){await jt(this.globalBaseDir),await jt(this.globalProjectsDir),await jt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),s=["core","progress","planning","analysis","memory"];for(let r of s)await jt(O.join(t,r));return await jt(O.join(t,"planning","tasks")),await jt(O.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:s,month:r,day:o}=mu(t);return O.join(this.getGlobalProjectPath(e),"sessions",s,r,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let s=this.getSessionPath(e,t);return await jt(s),s}async listSessions(e,t=null,s=null){let r=O.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Lt.readdir(r,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let l=O.join(r,a.name),u=await Lt.readdir(l,{withFileTypes:!0});for(let d of u){if(!d.isDirectory()||s&&d.name!==s.toString().padStart(2,"0"))continue;let m=O.join(l,d.name),p=await Lt.readdir(m,{withFileTypes:!0});for(let g of p)g.isDirectory()&&o.push({year:a.name,month:d.name,day:g.name,path:O.join(m,g.name),date:new Date(`${a.name}-${d.name}-${g.name}`)})}}return o.sort((a,l)=>l.date.getTime()-a.date.getTime()),o}catch{return[]}}async getSessionsInRange(e,t,s=new Date){return(await this.listSessions(e)).filter(o=>o.date>=t&&o.date<=s)}getFilePath(e,t,s){return O.join(this.getGlobalProjectPath(e),t,s)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Lt.readdir(this.globalProjectsDir,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}async projectExists(e){let t=this.getGlobalProjectPath(e);return await Qt(t)}getDisplayPath(e){let t=fn.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return O.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return O.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return O.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return O.join(this.globalBaseDir,".running")}getDocsPath(){return O.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(Ve(),yt(wt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(Ve(),yt(wt)).getActiveProvider();return(Ve(),yt(wt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return O.join(fn.homedir(),".claude")}getClaudeSettingsPath(){return O.join(this.getClaudeDir(),"settings.json")}getStoragePath(e,t){return O.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return O.join(this.getGlobalProjectPath(e),"context")}getWikiPath(e,t){if(t&&t.trim().length>0)return this.resolveVaultOverride(e,t);let r=O.basename(O.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project";return O.join(fn.homedir(),"Documents","prjct",r)}getWikiPathWithProjectHash(e,t){let r=O.basename(O.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project",o=t.replace(/-/g,"").slice(0,8);return O.join(fn.homedir(),"Documents","prjct",`${r}-${o}`)}getLegacyWikiPath(e){return O.join(e,".prjct","wiki")}resolveVaultOverride(e,t){let s=t.trim();return(s.startsWith("~/")||s==="~")&&(s=O.join(fn.homedir(),s.slice(1))),O.isAbsolute(s)||(s=O.resolve(e,s)),s}async detectMonorepo(e){let t={isMonorepo:!1,type:null,rootPath:e,packages:[]},s=[{file:"pnpm-workspace.yaml",type:"pnpm"},{file:"lerna.json",type:"lerna"},{file:"nx.json",type:"nx"},{file:"rush.json",type:"rush"},{file:"turbo.json",type:"turborepo"}];for(let r of s){let o=O.join(e,r.file);if(await v(o)){t.isMonorepo=!0,t.type=r.type;break}}if(!t.isMonorepo){let r=O.join(e,"package.json");if(await v(r))try{let o=await Lt.readFile(r,"utf-8");JSON.parse(o).workspaces&&(t.isMonorepo=!0,t.type="npm")}catch{}}return t.isMonorepo&&(t.packages=await this.discoverMonorepoPackages(e,t.type)),t}async discoverMonorepoPackages(e,t){let s=[],r=[];try{if(t==="pnpm"){let i=(await Lt.readFile(O.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(r=i[1].split(`
|
|
13
13
|
`).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=O.join(e,"package.json"),i=await Lt.readFile(o,"utf-8"),a=JSON.parse(i);if(Array.isArray(a.workspaces)?r=a.workspaces:a.workspaces?.packages&&(r=a.workspaces.packages),t==="lerna"){let l=O.join(e,"lerna.json");if(await v(l)){let u=await Lt.readFile(l,"utf-8"),d=JSON.parse(u);d.packages&&(r=d.packages)}}}else if(t==="nx")r=["apps/*","libs/*","packages/*"];else if(t==="turborepo"){let o=O.join(e,"package.json"),i=await Lt.readFile(o,"utf-8"),a=JSON.parse(i);Array.isArray(a.workspaces)&&(r=a.workspaces)}r.length===0&&(r=["packages/*","apps/*","libs/*"]);for(let o of r){if(o.startsWith("!"))continue;let i=Kh(o,{cwd:e,absolute:!1});for(let a of i){let l=O.join(e,a),u=O.join(l,"package.json");if(await v(u))try{let d=await Lt.readFile(u,"utf-8"),m=JSON.parse(d),p=O.join(l,"PRJCT.md");s.push({name:m.name||O.basename(a),path:l,relativePath:a,hasPrjctMd:await v(p)})}catch{}}}}catch{}return s}async findContainingPackage(e,t){if(!t.isMonorepo)return null;let s=O.resolve(e);for(let r of t.packages){let o=O.resolve(r.path);if(s.startsWith(o))return r}return null}async findMonorepoRoot(e){let t=O.resolve(e),s=O.parse(t).root;for(;t!==s;){if((await this.detectMonorepo(t)).isMonorepo)return t;t=O.dirname(t)}return null}},Yh=new Bi,$=Yh});var wu={};G(wu,{default:()=>Qh,worktreeService:()=>yu});import Ji from"node:fs/promises";import Ft from"node:path";var hu,zi,yu,Qh,ku=h(()=>{"use strict";st();z();hu=".worktrees",zi=class{static{c(this,"WorktreeService")}async create(e,t,s={}){let r=await this.getMainWorktree(e),o=Ft.join(r,hu,t),i=s.branch||`feat/${t}`;await Ji.mkdir(Ft.join(r,hu),{recursive:!0});let a=s.baseBranch?` ${s.baseBranch}`:"";await _(`git worktree add "${o}" -b "${i}"${a}`,{cwd:r});let{stdout:l}=await _("git rev-parse HEAD",{cwd:o});return{path:o,branch:i,commit:l.trim(),isMain:!1,slug:t}}async remove(e,t=!1){let s=await this.getMainWorktree(e),r;if(t)try{let{stdout:o}=await _("git rev-parse --abbrev-ref HEAD",{cwd:e});r=o.trim()}catch{}if(await _(`git worktree remove "${e}" --force`,{cwd:s}),t&&r&&r!=="main"&&r!=="master")try{await _(`git branch -D "${r}"`,{cwd:s})}catch{}}async list(e){let t=await this.getMainWorktree(e),{stdout:s}=await _("git worktree list --porcelain",{cwd:t});return this.parsePorcelainOutput(s,t)}async detect(e){try{let{stdout:t}=await _("git rev-parse --git-common-dir",{cwd:e}),{stdout:s}=await _("git rev-parse --git-dir",{cwd:e}),r=Ft.resolve(e,t.trim()),o=Ft.resolve(e,s.trim());if(r!==o){let{stdout:i}=await _("git rev-parse --abbrev-ref HEAD",{cwd:e}),{stdout:a}=await _("git rev-parse HEAD",{cwd:e}),{stdout:l}=await _("git rev-parse --show-toplevel",{cwd:e}),u=l.trim(),d=Ft.basename(u);return{path:u,branch:i.trim(),commit:a.trim(),isMain:!1,slug:d}}return null}catch{return null}}async getMainWorktree(e){try{let{stdout:s}=await _("git worktree list --porcelain",{cwd:e}),r=s.split(`
|
|
14
14
|
`)[0];if(r?.startsWith("worktree "))return r.replace("worktree ","").trim()}catch{}let{stdout:t}=await _("git rev-parse --show-toplevel",{cwd:e});return t.trim()}async setup(e,t){let s=Ft.join(t,".env");await v(s)&&await Ji.copyFile(s,Ft.join(e,".env"));let r=Ft.join(t,".prjct"),o=Ft.join(e,".prjct");await v(r)&&!await v(o)&&await Ji.symlink(r,o,"dir")}async teardown(e){}async clean(e){let t=await this.list(e),s=[],r=await this.getMainWorktree(e);await _("git worktree prune",{cwd:r});for(let o of t)o.isMain||await v(o.path)||s.push(o.slug);return s}parsePorcelainOutput(e,t){let s=[],r=e.trim().split(`
|
|
15
15
|
|
|
@@ -491,7 +491,7 @@ var zf=Object.create;var or=Object.defineProperty;var Xf=Object.getOwnPropertyDe
|
|
|
491
491
|
name TEXT NOT NULL,
|
|
492
492
|
applied_at TEXT NOT NULL
|
|
493
493
|
)
|
|
494
|
-
`);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(s=>s.version));for(let s of ry)t.has(s.version)||e.transaction(()=>{s.up(e),e.prepare("INSERT INTO _migrations (version, name, applied_at) VALUES (?, ?, ?)").run(s.version,s.name,new Date().toISOString())})()}getMigrations(e){return this.getDb(e).prepare("SELECT * FROM _migrations ORDER BY version").all()}getSchemaVersion(e){return this.getDb(e).prepare("SELECT MAX(version) as version FROM _migrations").get()?.version??0}},C=new ao,L=C});import{z as H}from"zod";var iy,ay,Cu,cy,ly,uy,dy,py,Pu,mP,ju=h(()=>{"use strict";iy=H.enum(["low","medium","high"]),ay=H.enum(["pending","converted","completed","archived","dormant"]),Cu=H.enum(["high","medium","low"]),cy=H.object({impact:Cu,effort:Cu}),ly=H.object({frontend:H.string().optional(),backend:H.string().optional(),payments:H.string().optional(),ai:H.string().optional(),deploy:H.string().optional(),other:H.array(H.string()).optional()}),uy=H.object({name:H.string(),description:H.string()}),dy=H.object({name:H.string(),description:H.string().optional()}),py=H.object({id:H.string(),text:H.string(),details:H.string().optional(),priority:iy,status:ay,tags:H.array(H.string()),addedAt:H.string(),completedAt:H.string().optional(),convertedTo:H.string().optional(),source:H.string().optional(),sourceFiles:H.array(H.string()).optional(),painPoints:H.array(H.string()).optional(),solutions:H.array(H.string()).optional(),filesAffected:H.array(H.string()).optional(),impactEffort:cy.optional(),implementationNotes:H.string().optional(),stack:ly.optional(),modules:H.array(uy).optional(),roles:H.array(dy).optional(),risks:H.array(H.string()).optional(),risksCount:H.number().optional()}),Pu=H.object({ideas:H.array(py),lastUpdated:H.string()}),mP={priority:"medium",status:"pending",tags:[],addedAt:new Date().toISOString()}});import my from"node:crypto";import{homedir as gy}from"node:os";import{join as fy}from"node:path";function nt(){return my.randomUUID()}var kP,Fs=h(()=>{"use strict";c(nt,"generateUUID");kP=fy(gy(),".prjct-cli","projects")});var ss,ea,rt,hs=h(()=>{"use strict";Fs();Ce();de();ss={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},ea=class{static{c(this,"ArchiveStorage")}archive(e,t){let s=nt(),r=x();return C.run(e,"INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)",s,t.entityType,t.entityId,JSON.stringify(t.entityData),t.summary??null,r,t.reason),s}archiveMany(e,t){if(t.length===0)return 0;let s=x();return C.transaction(e,r=>{let o=r.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(nt(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,s,i.reason)}),t.length}getArchived(e,t,s=50){return t?C.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,s):C.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",s)}getStats(e){let t=C.query(e,"SELECT entity_type, COUNT(*) as count FROM archives GROUP BY entity_type"),s={shipped:0,idea:0,queue_task:0,paused_task:0,memory_entry:0,total:0};for(let r of t){let o=r.entity_type;o in s&&(s[o]=r.count),s.total+=r.count}return s}restore(e,t){let s=C.get(e,"SELECT * FROM archives WHERE id = ?",t);return s?(C.run(e,"DELETE FROM archives WHERE id = ?",t),JSON.parse(s.entity_data)):null}pruneOldArchives(e,t){let s=new Date(Date.now()-t*24*60*60*1e3).toISOString(),r=this.getTotalCount(e);C.run(e,"DELETE FROM archives WHERE archived_at < ?",s);let o=this.getTotalCount(e);return r-o}getTotalCount(e){return C.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},rt=new ea});var ta,ys,sa=h(()=>{"use strict";Pe();Ce();z();ta=class{static{c(this,"SyncEventBus")}async publish(e){let t=$.getSyncPendingPath(e.projectId),s=await Ee(t,[])??[],r=Array.isArray(s)?s:[];r.push(e),await ae(t,r)}async getPending(e){let t=$.getSyncPendingPath(e),s=await Ee(t,[])??[];return Array.isArray(s)?s:[]}async clearPending(e){let t=$.getSyncPendingPath(e);await ae(t,[])}async updateLastSync(e){let t=$.getLastSyncPath(e),s={timestamp:x(),success:!0};await ae(t,s)}async getLastSync(e){let t=$.getLastSyncPath(e);return await Ee(t,null)}},ys=new ta});var Ye,ws=h(()=>{"use strict";sa();cr();Ce();de();Ye=class{static{c(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new Xr({ttl:5e3,maxSize:50})}getStoreKey(){return this.filename.replace(".json","")}async read(e){let t=this.cache.get(e);if(t!==null)return t;try{let s=C.getDoc(e,this.getStoreKey());if(s!==null)return this.cache.set(e,s),s}catch{}return this.getDefault()}async write(e,t){C.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let s=await this.read(e),r=t(s);return await this.write(e,r),r}async publishEvent(e,t,s){let r={type:t,path:[this.filename.replace(".json","")],data:s,timestamp:x(),projectId:e};await ys.publish(r)}async publishEntityEvent(e,t,s,r){let o=`${t}.${s}`,i={...r,timestamp:x()};await this.publishEvent(e,o,i)}async exists(e){try{return C.hasDoc(e,this.getStoreKey())}catch{return!1}}clearCache(e){e?this.cache.delete(e):this.cache.clear()}getCacheStats(){return this.cache.stats()}}});var na,He,gr=h(()=>{"use strict";ju();Fs();Ce();hs();ws();na=class extends Ye{static{c(this,"IdeasStorage")}constructor(){super("ideas.json",Pu)}getDefault(){return{ideas:[],lastUpdated:""}}getEventType(e){return`ideas.${e}d`}async getAll(e){return(await this.read(e)).ideas}async getPending(e){return(await this.read(e)).ideas.filter(s=>s.status==="pending")}async addIdea(e,t,s={}){let r={id:nt(),text:t,status:"pending",priority:s.priority||"medium",tags:s.tags||[],addedAt:x()};return await this.update(e,o=>({ideas:[r,...o.ideas],lastUpdated:x()})),await this.publishEvent(e,"idea.created",{ideaId:r.id,text:r.text,priority:r.priority}),r}async getById(e,t){return(await this.read(e)).ideas.find(r=>r.id===t)}async convertToFeature(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:s}:o),lastUpdated:x()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:s})}async archive(e,t){await this.update(e,s=>({ideas:s.ideas.map(r=>r.id===t?{...r,status:"archived"}:r),lastUpdated:x()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:x()}))}async addTags(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...s])]}:o),lastUpdated:x()}))}async removeIdea(e,t){await this.update(e,s=>({ideas:s.ideas.filter(r=>r.id!==t),lastUpdated:x()}))}async getCounts(e){let t=await this.read(e);return{pending:t.ideas.filter(s=>s.status==="pending").length,converted:t.ideas.filter(s=>s.status==="converted").length,archived:t.ideas.filter(s=>s.status==="archived").length}}async cleanup(e){let s=(await this.read(e)).ideas.filter(a=>a.status==="archived");if(s.length<=50)return{removed:0};let r=s.sort((a,l)=>new Date(l.addedAt).getTime()-new Date(a.addedAt).getTime()),o=new Set(r.slice(50).map(a=>a.id)),i=o.size;return await this.update(e,a=>({ideas:a.ideas.filter(l=>!o.has(l.id)),lastUpdated:x()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),s=dn(ss.IDEA_DORMANT_DAYS),r=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<s);if(r.length===0)return 0;rt.archiveMany(e,r.map(i=>({entityType:"idea",entityId:i.id,entityData:i,summary:i.text,reason:"dormant"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({ideas:i.ideas.map(a=>o.has(a.id)?{...a,status:"dormant"}:a),lastUpdated:x()})),await this.publishEvent(e,"ideas.dormant",{count:r.length}),r.length}},He=new na});import{z as w}from"zod";var hy,co,yy,wy,ky,ra,Ru,Au,Iu,oa,xu,Sy,vy,by,$u,Du,Mu,Ty,Ey,BP,ia=h(()=>{"use strict";zr();hy=w.enum(["low","medium","high","critical"]),co=w.enum(["feature","bug","improvement","chore"]),yy=w.enum(["active","backlog","previously_active"]),wy=w.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),ky=w.enum(["task_completed","feature_shipped","idea_captured","session_started"]),ra=w.object({title:w.string(),description:w.string(),filesChanged:w.array(w.object({path:w.string(),action:w.enum(["created","modified","deleted"])})),whatWasDone:w.array(w.string()).min(1),outputForNextAgent:w.string().min(1),notes:w.string().optional()}),Ru=w.object({output:w.string().min(1,"Subtask output is required"),summary:ra}),Au=w.object({id:w.string(),description:w.string(),domain:w.string(),agent:w.string(),status:wy,dependsOn:w.array(w.string()),startedAt:w.string().optional(),completedAt:w.string().optional(),output:w.string().optional(),summary:ra.optional(),skipReason:w.string().optional(),blockReason:w.string().optional(),estimatedPoints:w.number().optional(),estimatedMinutes:w.number().optional()}),Iu=w.object({completed:w.number(),total:w.number(),percentage:w.number()}),oa=w.object({id:w.string(),description:w.string(),type:co.optional(),startedAt:w.string(),sessionId:w.string(),featureId:w.string().optional(),subtasks:w.array(Au).optional(),currentSubtaskIndex:w.number().optional(),subtaskProgress:Iu.optional(),linearId:w.string().optional(),linearUuid:w.string().optional(),estimatedPoints:w.number().optional(),estimatedMinutes:w.number().optional(),modelMetadata:on.optional(),tokensIn:w.number().optional(),tokensOut:w.number().optional(),parentDescription:w.string().optional(),branch:w.string().optional(),prUrl:w.string().optional()}),xu=w.object({id:w.string(),description:w.string(),status:w.literal("paused"),startedAt:w.string(),pausedAt:w.string(),pauseReason:w.string().optional(),type:co.optional(),sessionId:w.string().optional(),featureId:w.string().optional(),subtasks:w.array(Au).optional(),currentSubtaskIndex:w.number().optional(),subtaskProgress:Iu.optional(),linearId:w.string().optional(),linearUuid:w.string().optional(),estimatedPoints:w.number().optional(),estimatedMinutes:w.number().optional(),modelMetadata:on.optional(),tokensIn:w.number().optional(),tokensOut:w.number().optional()}),Sy=w.object({stackConfirmed:w.array(w.string()).optional(),patternsDiscovered:w.array(w.string()).optional(),agentAccuracy:w.array(w.object({agent:w.string(),rating:w.enum(["helpful","neutral","inaccurate"]),note:w.string().optional()})).optional(),issuesEncountered:w.array(w.string()).optional()}),vy=w.object({taskId:w.string(),title:w.string(),classification:co,startedAt:w.string(),completedAt:w.string(),subtaskCount:w.number(),subtaskSummaries:w.array(ra),outcome:w.string(),branchName:w.string(),linearId:w.string().optional(),linearUuid:w.string().optional(),prUrl:w.string().optional(),feedback:Sy.optional(),tokensIn:w.number().optional(),tokensOut:w.number().optional()}),by=oa.extend({workspaceId:w.string(),worktreePath:w.string().optional(),agentSessionId:w.string().optional(),jiraId:w.string().optional(),jiraUuid:w.string().optional(),dispatchedFrom:w.string().optional()}),$u=w.object({currentTask:oa.nullable(),previousTask:xu.nullable().optional(),pausedTasks:w.array(xu).optional(),taskHistory:w.array(vy).optional(),activeTasks:w.array(by).optional(),lastUpdated:w.string()}),Du=w.object({id:w.string(),description:w.string(),body:w.string().optional(),priority:hy,type:co,featureId:w.string().optional(),originFeature:w.string().optional(),completed:w.boolean(),completedAt:w.string().optional(),createdAt:w.string(),section:yy,agent:w.string().optional(),groupName:w.string().optional(),groupId:w.string().optional()}),Mu=w.object({tasks:w.array(Du),lastUpdated:w.string()}),Ty=w.object({tasksToday:w.number(),tasksThisWeek:w.number(),streak:w.number(),velocity:w.string(),avgDuration:w.string()}),Ey=w.object({type:ky,description:w.string(),timestamp:w.string(),duration:w.string().optional()}),BP=w.object({projectId:w.string(),currentTask:oa.nullable(),queue:w.array(Du),stats:Ty,recentActivity:w.array(Ey),lastSync:w.string()})});function _u(n){return[...n].sort((e,t)=>{let s=Ou[e.section]-Ou[t.section];return s!==0?s:Nu[e.priority]-Nu[t.priority]})}function aa(n,e){let t=new Set;return n.filter(s=>{let r=e(s);return t.has(r)?!1:(t.add(r),!0)})}var Nu,Ou,ca=h(()=>{"use strict";Nu={critical:0,high:1,medium:2,low:3},Ou={active:0,previously_active:1,backlog:2};c(_u,"sortBySectionAndPriority");c(aa,"uniqueBy")});var la,We,fr=h(()=>{"use strict";Fs();ia();ca();Ce();hs();ws();la=class extends Ye{static{c(this,"QueueStorage")}constructor(){super("queue.json",Mu)}getDefault(){return{tasks:[],lastUpdated:""}}getEventType(e){return`queue.${e}d`}async getTasks(e){return(await this.read(e)).tasks}async getActiveTasks(e){return(await this.read(e)).tasks.filter(s=>s.section==="active"&&!s.completed)}async getBacklog(e){return(await this.read(e)).tasks.filter(s=>s.section==="backlog"&&!s.completed)}async getNextTask(e){let t=await this.getActiveTasks(e);return _u(t)[0]||null}async addTask(e,t){let s={...t,id:nt(),createdAt:x(),completed:!1};return await this.update(e,r=>({tasks:[...r.tasks,s],lastUpdated:x()})),await this.publishEvent(e,"queue.task_added",{taskId:s.id,description:s.description,priority:s.priority,section:s.section}),s}async addTasks(e,t){let s=x(),r=t.map(o=>({...o,id:nt(),createdAt:s,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...r],lastUpdated:s})),await this.publishEvent(e,"queue.tasks_added",{count:r.length,tasks:r.map(o=>({id:o.id,description:o.description}))}),r}async removeTask(e,t){await this.update(e,s=>({tasks:s.tasks.filter(r=>r.id!==t),lastUpdated:x()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let s=null;if(await this.update(e,r=>({tasks:r.tasks.map(i=>i.id===t?(s={...i,completed:!0,completedAt:x()},s):i),lastUpdated:x()})),s){let r=s;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:r.description,completedAt:r.completedAt})}return s}async moveToSection(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,section:s}:o),lastUpdated:x()}))}async setPriority(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:x()}))}async getTask(e,t){return(await this.read(e)).tasks.find(r=>r.id===t)||null}async updateTask(e,t,s){let r=null;return await this.update(e,o=>({tasks:o.tasks.map(i=>i.id===t?(r={...i,...s},r):i),lastUpdated:x()})),r&&await this.publishEvent(e,"queue.task_updated",{taskId:t}),r}async clearCompleted(e){let s=(await this.read(e)).tasks.filter(r=>r.completed).length;return await this.update(e,r=>({tasks:r.tasks.filter(o=>!o.completed),lastUpdated:x()})),s}async removeStaleCompleted(e){let t=await this.read(e),s=dn(ss.QUEUE_COMPLETED_DAYS),r=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<s);if(r.length===0)return 0;rt.archiveMany(e,r.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:x()})),await this.publishEvent(e,"queue.stale_removed",{count:r.length}),r.length}},We=new la});import{z as Y}from"zod";var Cy,Lu,Py,jy,xy,Ry,Ay,Iy,$y,Fu,Uu=h(()=>{"use strict";Cy=Y.enum(["feature","fix","improvement","refactor"]),Lu=Y.enum(["pass","warning","fail","skipped"]),Py=Y.enum(["added","changed","fixed","removed"]),jy=Y.object({hours:Y.number(),minutes:Y.number(),totalMinutes:Y.number()}),xy=Y.object({filesChanged:Y.number().nullable().optional(),linesAdded:Y.number().nullable().optional(),linesRemoved:Y.number().nullable().optional(),commits:Y.number().nullable().optional()}),Ry=Y.object({description:Y.string(),type:Py.optional()}),Ay=Y.object({lintStatus:Lu.nullable().optional(),lintDetails:Y.string().optional(),testStatus:Lu.nullable().optional(),testDetails:Y.string().optional()}),Iy=Y.object({hash:Y.string().optional(),message:Y.string().optional(),branch:Y.string().optional()}),$y=Y.object({id:Y.string(),name:Y.string(),version:Y.string().nullable().optional(),type:Cy,agent:Y.string().optional(),description:Y.string().optional(),changes:Y.array(Ry).optional(),codeSnippets:Y.array(Y.string()).optional(),commit:Iy.optional(),codeMetrics:xy.optional(),qualityMetrics:Ay.optional(),quantitativeImpact:Y.string().optional(),duration:jy.optional(),tasksCompleted:Y.number().nullable().optional(),shippedAt:Y.string(),featureId:Y.string().optional()}),Fu=Y.object({shipped:Y.array($y),lastUpdated:Y.string()})});var ua,Qe,Hu,Us=h(()=>{"use strict";Fs();Uu();Ce();hs();ws();ua=class extends Ye{static{c(this,"ShippedStorage")}constructor(){super("shipped.json",Fu)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(e){return`shipped.${e}d`}async getAll(e){return(await this.read(e)).shipped}async getRecent(e,t=5){return(await this.read(e)).shipped.sort((r,o)=>new Date(o.shippedAt).getTime()-new Date(r.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let s={...t,id:nt(),shippedAt:x()};return await this.update(e,r=>({shipped:[s,...Array.isArray(r.shipped)?r.shipped:[]],lastUpdated:x()})),await this.publishEvent(e,"feature.shipped",{shipId:s.id,name:s.name,version:s.version,shippedAt:s.shippedAt}),s}async getByVersion(e,t){return(await this.read(e)).shipped.find(r=>r.version===t)}async getCount(e){return(await this.read(e)).shipped.length}async getByDateRange(e,t,s){return(await this.read(e)).shipped.filter(o=>{let i=new Date(o.shippedAt);return i>=t&&i<=s})}async getStats(e,t="month"){let s=new Date,r;switch(t){case"week":r=new Date(s.getTime()-7*24*60*60*1e3);break;case"month":r=new Date(s.getFullYear(),s.getMonth(),1);break;case"year":r=new Date(s.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,r,s)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),s=dn(ss.SHIPPED_RETENTION_DAYS),r=t.shipped.filter(i=>new Date(i.shippedAt)<s);if(r.length===0)return 0;rt.archiveMany(e,r.map(i=>({entityType:"shipped",entityId:i.id,entityData:i,summary:`${i.name} v${i.version}`,reason:"age"})));let o=new Set(t.shipped.filter(i=>new Date(i.shippedAt)>=s).map(i=>i.id));return await this.update(e,i=>({shipped:i.shipped.filter(a=>o.has(a.id)),lastUpdated:x()})),await this.publishEvent(e,"shipped.archived",{count:r.length,oldestShippedAt:r[r.length-1]?.shippedAt}),r.length}},Qe=new ua,Hu=Qe});var hr,da,Hs,pa=h(()=>{"use strict";hr={idle:{transitions:["task"],prompt:"prjct task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"prjct status done Complete task | prjct status paused Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"prjct status active Continue | prjct task <new> Start different | prjct ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","pause","reopen"],prompt:"prjct ship Ship it | prjct task <next> Start next | prjct status active Reopen",description:"Task completed"},shipped:{transitions:["task"],prompt:"prjct task <description> Start new task",description:"Feature shipped"}},da=class{static{c(this,"WorkflowStateMachine")}getCurrentState(e,t){let s=null;if(t&&e?.activeTasks?.length&&(s=e.activeTasks.find(o=>o.workspaceId===t)),s||(s=e?.currentTask),!s)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof s.status=="string"?s.status:"").toLowerCase()){case"in_progress":case"working":return"working";case"paused":return"paused";case"completed":case"done":return"completed";case"shipped":return"shipped";default:return s?"working":"idle"}}canTransition(e,t){if(hr[e].transitions.includes(t))return{valid:!0};let r=this.formatNextSteps(e).join(" | ");return{valid:!1,error:`Cannot transition to '${t}' from '${e}' state`,suggestion:`Valid next steps: ${r}`}}getNextState(e,t){switch(t){case"task":return"working";case"done":return"completed";case"pause":return"paused";case"resume":return"working";case"ship":return"shipped";case"reopen":return"working";default:return e}}getStateInfo(e){return hr[e]}getPrompt(e){return hr[e].prompt}getValidCommands(e){return hr[e].transitions}formatNextSteps(e){return hr[e].transitions.map(s=>{switch(s){case"task":return"prjct task <desc> Start new task";case"done":return"prjct status done Complete current task";case"pause":return"prjct status paused Pause and switch context";case"resume":return"prjct status active Continue paused task";case"ship":return"prjct ship Ship the feature";case"reopen":return"prjct status active Reopen completed task";default:return`prjct ${s}`}})}},Hs=new da});var ma,M,lt=h(()=>{"use strict";Fs();ia();Ce();pa();hs();ws();ma=class extends Ye{static{c(this,"StateStorage")}constructor(){super("state.json",$u)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],activeTasks:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let s=Hs.getCurrentState(e),r=Hs.canTransition(s,t);if(!r.valid)throw new Error(`${r.error}. ${r.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async getPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async startTask(e,t){let s=await this.read(e);this.validateTransition(s,"task");let r={...t,startedAt:x()};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:x()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId}),r}async updateCurrentTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;let r={...s.currentTask,...t};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:x()})),r}async completeTask(e,t){let s=await this.read(e),r=s.currentTask;if(!r)return null;this.validateTransition(s,"done");let o=x(),i=this.createTaskHistoryEntry(r,o,t),a=this.getTaskHistoryFromState(s),l=[i,...a].slice(0,this.maxTaskHistory);return await this.update(e,u=>({...u,currentTask:null,previousTask:null,taskHistory:l,lastUpdated:o})),await this.publishEvent(e,"task.completed",{taskId:r.id,description:r.description,startedAt:r.startedAt,completedAt:o}),r}createTaskHistoryEntry(e,t,s){let r=(e.subtasks||[]).filter(a=>a.status==="completed"&&a.summary).map(a=>a.summary),o=r.length>0?r.map(a=>a.title).join(", "):"Task completed",i={taskId:e.id,title:e.parentDescription||e.description,classification:e.type||"improvement",startedAt:e.startedAt,completedAt:t,subtaskCount:e.subtasks?.length||0,subtaskSummaries:r,outcome:o,branchName:e.branch||"unknown",linearId:e.linearId,linearUuid:e.linearUuid,prUrl:e.prUrl};return s&&(i.feedback=s),e.tokensIn&&(i.tokensIn=e.tokensIn),e.tokensOut&&(i.tokensOut=e.tokensOut),i}maxPausedTasks=5;maxTaskHistory=20;stalenessThresholdDays=30;async pauseTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;this.validateTransition(s,"pause");let r={...s.currentTask,status:"paused",pausedAt:x(),pauseReason:t},o=this.getPausedTasksFromState(s),i=[r,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:x()})),await this.publishEvent(e,"task.paused",{taskId:r.id,description:r.description,pausedAt:r.pausedAt,reason:t,pausedCount:i.length}),r}async resumeTask(e,t){let s=await this.read(e),r=this.getPausedTasksFromState(s);if(r.length===0)return null;this.validateTransition(s,"resume");let o=0;if(t&&(o=r.findIndex(g=>g.id===t),o===-1))return null;let i=r[o],a=r.filter((g,y)=>y!==o),{status:l,pausedAt:u,pauseReason:d,...m}=i,p={...m,startedAt:x(),sessionId:i.sessionId??nt()};return await this.update(e,g=>({...g,currentTask:p,previousTask:null,pausedTasks:a,lastUpdated:x()})),await this.publishEvent(e,"task.resumed",{taskId:p.id,description:p.description,resumedAt:p.startedAt,remainingPaused:a.length}),p}getPausedTasksFromState(e){return Array.isArray(e.pausedTasks)&&e.pausedTasks.length>0?e.pausedTasks:e.previousTask?[e.previousTask]:[]}getTaskHistoryFromState(e){return e.taskHistory||[]}async getStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return s.filter(o=>new Date(o.pausedAt).getTime()<r)}async archiveStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=s.filter(a=>new Date(a.pausedAt).getTime()<r),i=s.filter(a=>new Date(a.pausedAt).getTime()>=r);if(o.length===0)return[];rt.archiveMany(e,o.map(a=>({entityType:"paused_task",entityId:a.id,entityData:a,summary:a.description,reason:"staleness"}))),await this.update(e,a=>({...a,pausedTasks:i,previousTask:null,lastUpdated:x()}));for(let a of o)await this.publishEvent(e,"task.archived",{taskId:a.id,description:a.description,pausedAt:a.pausedAt,reason:"staleness"});return o}async clearTask(e){await this.update(e,()=>({currentTask:null,previousTask:null,pausedTasks:[],activeTasks:[],lastUpdated:x()}))}async hasTask(e){let t=await this.read(e),s=this.getPausedTasksFromState(t);return t.currentTask!==null||s.length>0}async getPausedTask(e){let t=await this.read(e);return this.getPausedTasksFromState(t)[0]||null}async getAllPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async getTaskHistory(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)}async getMostRecentTask(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)[0]||null}async getTaskHistoryByType(e,t){let s=await this.read(e);return this.getTaskHistoryFromState(s).filter(o=>o.classification===t)}async getAggregatedFeedback(e){let s=(await this.getTaskHistory(e)).filter(p=>p.feedback),r=[],o=[],i=[],a=[];for(let p of s){let g=p.feedback;Array.isArray(g.stackConfirmed)&&r.push(...g.stackConfirmed),Array.isArray(g.patternsDiscovered)&&o.push(...g.patternsDiscovered),Array.isArray(g.agentAccuracy)&&i.push(...g.agentAccuracy),Array.isArray(g.issuesEncountered)&&a.push(...g.issuesEncountered)}let l=[...new Set(r)],u=[...new Set(o)],d=new Map;for(let p of a)d.set(p,(d.get(p)||0)+1);let m=[...d.entries()].filter(([p,g])=>g>=2).map(([p])=>p);return{stackConfirmed:l,patternsDiscovered:u,agentAccuracy:i,issuesEncountered:[...new Set(a)],knownGotchas:m}}async startTaskInWorkspace(e,t,s){let r={...t,workspaceId:s,startedAt:x()};return await this.update(e,o=>({...o,activeTasks:[...o.activeTasks||[],r],lastUpdated:x()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId,workspaceId:s}),r}async getCurrentTaskForWorkspace(e,t){return((await this.read(e)).activeTasks||[]).find(r=>r.workspaceId===t)??null}async completeTaskInWorkspace(e,t,s){let r=await this.read(e),i=(r.activeTasks||[]).find(m=>m.workspaceId===t);if(!i)return null;let a=x(),l=this.createTaskHistoryEntry(i,a,s),u=this.getTaskHistoryFromState(r),d=[l,...u].slice(0,this.maxTaskHistory);return await this.update(e,m=>({...m,activeTasks:(m.activeTasks||[]).filter(p=>p.workspaceId!==t),taskHistory:d,lastUpdated:a})),await this.publishEvent(e,"task.completed",{taskId:i.id,description:i.description,startedAt:i.startedAt,completedAt:a,workspaceId:t}),i}async getActiveTasks(e){return(await this.read(e)).activeTasks||[]}async getActiveTaskCount(e){return((await this.read(e)).activeTasks||[]).length}async updateWorkspaceTask(e,t,s){let o=(await this.read(e)).activeTasks||[],i=o.findIndex(l=>l.workspaceId===t);if(i===-1)return null;let a={...o[i],...s,workspaceId:t};return await this.update(e,l=>{let u=[...l.activeTasks||[]];return u[i]=a,{...l,activeTasks:u,lastUpdated:x()}}),a}async addTokens(e,t,s){let r=await this.read(e);if(!r.currentTask)return null;let o=(r.currentTask.tokensIn||0)+t,i=(r.currentTask.tokensOut||0)+s;return await this.update(e,a=>({...a,currentTask:{...a.currentTask,tokensIn:o,tokensOut:i},lastUpdated:x()})),{tokensIn:o,tokensOut:i}}async createSubtasks(e,t){let s=await this.read(e);if(!s.currentTask)return;let r=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?x():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:r,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:r.length,percentage:0}},lastUpdated:x()})),await this.publishEvent(e,"subtasks.created",{taskId:s.currentTask.id,subtaskCount:r.length,subtasks:r.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let s=Ru.safeParse(t);if(!s.success){let y=s.error.issues.map(j=>`${j.path.join(".")}: ${j.message}`);throw new Error(`Subtask completion requires handoff data:
|
|
494
|
+
`);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(s=>s.version));for(let s of ry)t.has(s.version)||e.transaction(()=>{s.up(e),e.prepare("INSERT INTO _migrations (version, name, applied_at) VALUES (?, ?, ?)").run(s.version,s.name,new Date().toISOString())})()}getMigrations(e){return this.getDb(e).prepare("SELECT * FROM _migrations ORDER BY version").all()}getSchemaVersion(e){return this.getDb(e).prepare("SELECT MAX(version) as version FROM _migrations").get()?.version??0}},C=new ao,L=C});import{z as H}from"zod";var iy,ay,Cu,cy,ly,uy,dy,py,Pu,gP,ju=h(()=>{"use strict";iy=H.enum(["low","medium","high"]),ay=H.enum(["pending","converted","completed","archived","dormant"]),Cu=H.enum(["high","medium","low"]),cy=H.object({impact:Cu,effort:Cu}),ly=H.object({frontend:H.string().optional(),backend:H.string().optional(),payments:H.string().optional(),ai:H.string().optional(),deploy:H.string().optional(),other:H.array(H.string()).optional()}),uy=H.object({name:H.string(),description:H.string()}),dy=H.object({name:H.string(),description:H.string().optional()}),py=H.object({id:H.string(),text:H.string(),details:H.string().optional(),priority:iy,status:ay,tags:H.array(H.string()),addedAt:H.string(),completedAt:H.string().optional(),convertedTo:H.string().optional(),source:H.string().optional(),sourceFiles:H.array(H.string()).optional(),painPoints:H.array(H.string()).optional(),solutions:H.array(H.string()).optional(),filesAffected:H.array(H.string()).optional(),impactEffort:cy.optional(),implementationNotes:H.string().optional(),stack:ly.optional(),modules:H.array(uy).optional(),roles:H.array(dy).optional(),risks:H.array(H.string()).optional(),risksCount:H.number().optional()}),Pu=H.object({ideas:H.array(py),lastUpdated:H.string()}),gP={priority:"medium",status:"pending",tags:[],addedAt:new Date().toISOString()}});import my from"node:crypto";import{homedir as gy}from"node:os";import{join as fy}from"node:path";function nt(){return my.randomUUID()}var SP,Fs=h(()=>{"use strict";c(nt,"generateUUID");SP=fy(gy(),".prjct-cli","projects")});var ss,ea,rt,hs=h(()=>{"use strict";Fs();Ce();de();ss={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},ea=class{static{c(this,"ArchiveStorage")}archive(e,t){let s=nt(),r=x();return C.run(e,"INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)",s,t.entityType,t.entityId,JSON.stringify(t.entityData),t.summary??null,r,t.reason),s}archiveMany(e,t){if(t.length===0)return 0;let s=x();return C.transaction(e,r=>{let o=r.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(nt(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,s,i.reason)}),t.length}getArchived(e,t,s=50){return t?C.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,s):C.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",s)}getStats(e){let t=C.query(e,"SELECT entity_type, COUNT(*) as count FROM archives GROUP BY entity_type"),s={shipped:0,idea:0,queue_task:0,paused_task:0,memory_entry:0,total:0};for(let r of t){let o=r.entity_type;o in s&&(s[o]=r.count),s.total+=r.count}return s}restore(e,t){let s=C.get(e,"SELECT * FROM archives WHERE id = ?",t);return s?(C.run(e,"DELETE FROM archives WHERE id = ?",t),JSON.parse(s.entity_data)):null}pruneOldArchives(e,t){let s=new Date(Date.now()-t*24*60*60*1e3).toISOString(),r=this.getTotalCount(e);C.run(e,"DELETE FROM archives WHERE archived_at < ?",s);let o=this.getTotalCount(e);return r-o}getTotalCount(e){return C.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},rt=new ea});var ta,ys,sa=h(()=>{"use strict";Pe();Ce();z();ta=class{static{c(this,"SyncEventBus")}async publish(e){let t=$.getSyncPendingPath(e.projectId),s=await Ee(t,[])??[],r=Array.isArray(s)?s:[];r.push(e),await ae(t,r)}async getPending(e){let t=$.getSyncPendingPath(e),s=await Ee(t,[])??[];return Array.isArray(s)?s:[]}async clearPending(e){let t=$.getSyncPendingPath(e);await ae(t,[])}async updateLastSync(e){let t=$.getLastSyncPath(e),s={timestamp:x(),success:!0};await ae(t,s)}async getLastSync(e){let t=$.getLastSyncPath(e);return await Ee(t,null)}},ys=new ta});var Ye,ws=h(()=>{"use strict";sa();cr();Ce();de();Ye=class{static{c(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new Xr({ttl:5e3,maxSize:50})}getStoreKey(){return this.filename.replace(".json","")}async read(e){let t=this.cache.get(e);if(t!==null)return t;try{let s=C.getDoc(e,this.getStoreKey());if(s!==null)return this.cache.set(e,s),s}catch{}return this.getDefault()}async write(e,t){C.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let s=await this.read(e),r=t(s);return await this.write(e,r),r}async publishEvent(e,t,s){let r={type:t,path:[this.filename.replace(".json","")],data:s,timestamp:x(),projectId:e};await ys.publish(r)}async publishEntityEvent(e,t,s,r){let o=`${t}.${s}`,i={...r,timestamp:x()};await this.publishEvent(e,o,i)}async exists(e){try{return C.hasDoc(e,this.getStoreKey())}catch{return!1}}clearCache(e){e?this.cache.delete(e):this.cache.clear()}getCacheStats(){return this.cache.stats()}}});var na,He,gr=h(()=>{"use strict";ju();Fs();Ce();hs();ws();na=class extends Ye{static{c(this,"IdeasStorage")}constructor(){super("ideas.json",Pu)}getDefault(){return{ideas:[],lastUpdated:""}}getEventType(e){return`ideas.${e}d`}async getAll(e){return(await this.read(e)).ideas}async getPending(e){return(await this.read(e)).ideas.filter(s=>s.status==="pending")}async addIdea(e,t,s={}){let r={id:nt(),text:t,status:"pending",priority:s.priority||"medium",tags:s.tags||[],addedAt:x()};return await this.update(e,o=>({ideas:[r,...o.ideas],lastUpdated:x()})),await this.publishEvent(e,"idea.created",{ideaId:r.id,text:r.text,priority:r.priority}),r}async getById(e,t){return(await this.read(e)).ideas.find(r=>r.id===t)}async convertToFeature(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:s}:o),lastUpdated:x()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:s})}async archive(e,t){await this.update(e,s=>({ideas:s.ideas.map(r=>r.id===t?{...r,status:"archived"}:r),lastUpdated:x()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:x()}))}async addTags(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...s])]}:o),lastUpdated:x()}))}async removeIdea(e,t){await this.update(e,s=>({ideas:s.ideas.filter(r=>r.id!==t),lastUpdated:x()}))}async getCounts(e){let t=await this.read(e);return{pending:t.ideas.filter(s=>s.status==="pending").length,converted:t.ideas.filter(s=>s.status==="converted").length,archived:t.ideas.filter(s=>s.status==="archived").length}}async cleanup(e){let s=(await this.read(e)).ideas.filter(a=>a.status==="archived");if(s.length<=50)return{removed:0};let r=s.sort((a,l)=>new Date(l.addedAt).getTime()-new Date(a.addedAt).getTime()),o=new Set(r.slice(50).map(a=>a.id)),i=o.size;return await this.update(e,a=>({ideas:a.ideas.filter(l=>!o.has(l.id)),lastUpdated:x()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),s=dn(ss.IDEA_DORMANT_DAYS),r=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<s);if(r.length===0)return 0;rt.archiveMany(e,r.map(i=>({entityType:"idea",entityId:i.id,entityData:i,summary:i.text,reason:"dormant"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({ideas:i.ideas.map(a=>o.has(a.id)?{...a,status:"dormant"}:a),lastUpdated:x()})),await this.publishEvent(e,"ideas.dormant",{count:r.length}),r.length}},He=new na});import{z as w}from"zod";var hy,co,yy,wy,ky,ra,Ru,Au,Iu,oa,xu,Sy,vy,by,$u,Du,Mu,Ty,Ey,JP,ia=h(()=>{"use strict";zr();hy=w.enum(["low","medium","high","critical"]),co=w.enum(["feature","bug","improvement","chore"]),yy=w.enum(["active","backlog","previously_active"]),wy=w.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),ky=w.enum(["task_completed","feature_shipped","idea_captured","session_started"]),ra=w.object({title:w.string(),description:w.string(),filesChanged:w.array(w.object({path:w.string(),action:w.enum(["created","modified","deleted"])})),whatWasDone:w.array(w.string()).min(1),outputForNextAgent:w.string().min(1),notes:w.string().optional()}),Ru=w.object({output:w.string().min(1,"Subtask output is required"),summary:ra}),Au=w.object({id:w.string(),description:w.string(),domain:w.string(),agent:w.string(),status:wy,dependsOn:w.array(w.string()),startedAt:w.string().optional(),completedAt:w.string().optional(),output:w.string().optional(),summary:ra.optional(),skipReason:w.string().optional(),blockReason:w.string().optional(),estimatedPoints:w.number().optional(),estimatedMinutes:w.number().optional()}),Iu=w.object({completed:w.number(),total:w.number(),percentage:w.number()}),oa=w.object({id:w.string(),description:w.string(),type:co.optional(),startedAt:w.string(),sessionId:w.string(),featureId:w.string().optional(),subtasks:w.array(Au).optional(),currentSubtaskIndex:w.number().optional(),subtaskProgress:Iu.optional(),linearId:w.string().optional(),linearUuid:w.string().optional(),estimatedPoints:w.number().optional(),estimatedMinutes:w.number().optional(),modelMetadata:on.optional(),tokensIn:w.number().optional(),tokensOut:w.number().optional(),parentDescription:w.string().optional(),branch:w.string().optional(),prUrl:w.string().optional()}),xu=w.object({id:w.string(),description:w.string(),status:w.literal("paused"),startedAt:w.string(),pausedAt:w.string(),pauseReason:w.string().optional(),type:co.optional(),sessionId:w.string().optional(),featureId:w.string().optional(),subtasks:w.array(Au).optional(),currentSubtaskIndex:w.number().optional(),subtaskProgress:Iu.optional(),linearId:w.string().optional(),linearUuid:w.string().optional(),estimatedPoints:w.number().optional(),estimatedMinutes:w.number().optional(),modelMetadata:on.optional(),tokensIn:w.number().optional(),tokensOut:w.number().optional()}),Sy=w.object({stackConfirmed:w.array(w.string()).optional(),patternsDiscovered:w.array(w.string()).optional(),agentAccuracy:w.array(w.object({agent:w.string(),rating:w.enum(["helpful","neutral","inaccurate"]),note:w.string().optional()})).optional(),issuesEncountered:w.array(w.string()).optional()}),vy=w.object({taskId:w.string(),title:w.string(),classification:co,startedAt:w.string(),completedAt:w.string(),subtaskCount:w.number(),subtaskSummaries:w.array(ra),outcome:w.string(),branchName:w.string(),linearId:w.string().optional(),linearUuid:w.string().optional(),prUrl:w.string().optional(),feedback:Sy.optional(),tokensIn:w.number().optional(),tokensOut:w.number().optional()}),by=oa.extend({workspaceId:w.string(),worktreePath:w.string().optional(),agentSessionId:w.string().optional(),jiraId:w.string().optional(),jiraUuid:w.string().optional(),dispatchedFrom:w.string().optional()}),$u=w.object({currentTask:oa.nullable(),previousTask:xu.nullable().optional(),pausedTasks:w.array(xu).optional(),taskHistory:w.array(vy).optional(),activeTasks:w.array(by).optional(),lastUpdated:w.string()}),Du=w.object({id:w.string(),description:w.string(),body:w.string().optional(),priority:hy,type:co,featureId:w.string().optional(),originFeature:w.string().optional(),completed:w.boolean(),completedAt:w.string().optional(),createdAt:w.string(),section:yy,agent:w.string().optional(),groupName:w.string().optional(),groupId:w.string().optional()}),Mu=w.object({tasks:w.array(Du),lastUpdated:w.string()}),Ty=w.object({tasksToday:w.number(),tasksThisWeek:w.number(),streak:w.number(),velocity:w.string(),avgDuration:w.string()}),Ey=w.object({type:ky,description:w.string(),timestamp:w.string(),duration:w.string().optional()}),JP=w.object({projectId:w.string(),currentTask:oa.nullable(),queue:w.array(Du),stats:Ty,recentActivity:w.array(Ey),lastSync:w.string()})});function _u(n){return[...n].sort((e,t)=>{let s=Ou[e.section]-Ou[t.section];return s!==0?s:Nu[e.priority]-Nu[t.priority]})}function aa(n,e){let t=new Set;return n.filter(s=>{let r=e(s);return t.has(r)?!1:(t.add(r),!0)})}var Nu,Ou,ca=h(()=>{"use strict";Nu={critical:0,high:1,medium:2,low:3},Ou={active:0,previously_active:1,backlog:2};c(_u,"sortBySectionAndPriority");c(aa,"uniqueBy")});var la,We,fr=h(()=>{"use strict";Fs();ia();ca();Ce();hs();ws();la=class extends Ye{static{c(this,"QueueStorage")}constructor(){super("queue.json",Mu)}getDefault(){return{tasks:[],lastUpdated:""}}getEventType(e){return`queue.${e}d`}async getTasks(e){return(await this.read(e)).tasks}async getActiveTasks(e){return(await this.read(e)).tasks.filter(s=>s.section==="active"&&!s.completed)}async getBacklog(e){return(await this.read(e)).tasks.filter(s=>s.section==="backlog"&&!s.completed)}async getNextTask(e){let t=await this.getActiveTasks(e);return _u(t)[0]||null}async addTask(e,t){let s={...t,id:nt(),createdAt:x(),completed:!1};return await this.update(e,r=>({tasks:[...r.tasks,s],lastUpdated:x()})),await this.publishEvent(e,"queue.task_added",{taskId:s.id,description:s.description,priority:s.priority,section:s.section}),s}async addTasks(e,t){let s=x(),r=t.map(o=>({...o,id:nt(),createdAt:s,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...r],lastUpdated:s})),await this.publishEvent(e,"queue.tasks_added",{count:r.length,tasks:r.map(o=>({id:o.id,description:o.description}))}),r}async removeTask(e,t){await this.update(e,s=>({tasks:s.tasks.filter(r=>r.id!==t),lastUpdated:x()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let s=null;if(await this.update(e,r=>({tasks:r.tasks.map(i=>i.id===t?(s={...i,completed:!0,completedAt:x()},s):i),lastUpdated:x()})),s){let r=s;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:r.description,completedAt:r.completedAt})}return s}async moveToSection(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,section:s}:o),lastUpdated:x()}))}async setPriority(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:x()}))}async getTask(e,t){return(await this.read(e)).tasks.find(r=>r.id===t)||null}async updateTask(e,t,s){let r=null;return await this.update(e,o=>({tasks:o.tasks.map(i=>i.id===t?(r={...i,...s},r):i),lastUpdated:x()})),r&&await this.publishEvent(e,"queue.task_updated",{taskId:t}),r}async clearCompleted(e){let s=(await this.read(e)).tasks.filter(r=>r.completed).length;return await this.update(e,r=>({tasks:r.tasks.filter(o=>!o.completed),lastUpdated:x()})),s}async removeStaleCompleted(e){let t=await this.read(e),s=dn(ss.QUEUE_COMPLETED_DAYS),r=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<s);if(r.length===0)return 0;rt.archiveMany(e,r.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:x()})),await this.publishEvent(e,"queue.stale_removed",{count:r.length}),r.length}},We=new la});import{z as Y}from"zod";var Cy,Lu,Py,jy,xy,Ry,Ay,Iy,$y,Fu,Uu=h(()=>{"use strict";Cy=Y.enum(["feature","fix","improvement","refactor"]),Lu=Y.enum(["pass","warning","fail","skipped"]),Py=Y.enum(["added","changed","fixed","removed"]),jy=Y.object({hours:Y.number(),minutes:Y.number(),totalMinutes:Y.number()}),xy=Y.object({filesChanged:Y.number().nullable().optional(),linesAdded:Y.number().nullable().optional(),linesRemoved:Y.number().nullable().optional(),commits:Y.number().nullable().optional()}),Ry=Y.object({description:Y.string(),type:Py.optional()}),Ay=Y.object({lintStatus:Lu.nullable().optional(),lintDetails:Y.string().optional(),testStatus:Lu.nullable().optional(),testDetails:Y.string().optional()}),Iy=Y.object({hash:Y.string().optional(),message:Y.string().optional(),branch:Y.string().optional()}),$y=Y.object({id:Y.string(),name:Y.string(),version:Y.string().nullable().optional(),type:Cy,agent:Y.string().optional(),description:Y.string().optional(),changes:Y.array(Ry).optional(),codeSnippets:Y.array(Y.string()).optional(),commit:Iy.optional(),codeMetrics:xy.optional(),qualityMetrics:Ay.optional(),quantitativeImpact:Y.string().optional(),duration:jy.optional(),tasksCompleted:Y.number().nullable().optional(),shippedAt:Y.string(),featureId:Y.string().optional()}),Fu=Y.object({shipped:Y.array($y),lastUpdated:Y.string()})});var ua,Qe,Hu,Us=h(()=>{"use strict";Fs();Uu();Ce();hs();ws();ua=class extends Ye{static{c(this,"ShippedStorage")}constructor(){super("shipped.json",Fu)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(e){return`shipped.${e}d`}async getAll(e){return(await this.read(e)).shipped}async getRecent(e,t=5){return(await this.read(e)).shipped.sort((r,o)=>new Date(o.shippedAt).getTime()-new Date(r.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let s={...t,id:nt(),shippedAt:x()};return await this.update(e,r=>({shipped:[s,...Array.isArray(r.shipped)?r.shipped:[]],lastUpdated:x()})),await this.publishEvent(e,"feature.shipped",{shipId:s.id,name:s.name,version:s.version,shippedAt:s.shippedAt}),s}async getByVersion(e,t){return(await this.read(e)).shipped.find(r=>r.version===t)}async getCount(e){return(await this.read(e)).shipped.length}async getByDateRange(e,t,s){return(await this.read(e)).shipped.filter(o=>{let i=new Date(o.shippedAt);return i>=t&&i<=s})}async getStats(e,t="month"){let s=new Date,r;switch(t){case"week":r=new Date(s.getTime()-7*24*60*60*1e3);break;case"month":r=new Date(s.getFullYear(),s.getMonth(),1);break;case"year":r=new Date(s.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,r,s)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),s=dn(ss.SHIPPED_RETENTION_DAYS),r=t.shipped.filter(i=>new Date(i.shippedAt)<s);if(r.length===0)return 0;rt.archiveMany(e,r.map(i=>({entityType:"shipped",entityId:i.id,entityData:i,summary:`${i.name} v${i.version}`,reason:"age"})));let o=new Set(t.shipped.filter(i=>new Date(i.shippedAt)>=s).map(i=>i.id));return await this.update(e,i=>({shipped:i.shipped.filter(a=>o.has(a.id)),lastUpdated:x()})),await this.publishEvent(e,"shipped.archived",{count:r.length,oldestShippedAt:r[r.length-1]?.shippedAt}),r.length}},Qe=new ua,Hu=Qe});var hr,da,Hs,pa=h(()=>{"use strict";hr={idle:{transitions:["task"],prompt:"prjct task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"prjct status done Complete task | prjct status paused Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"prjct status active Continue | prjct task <new> Start different | prjct ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","pause","reopen"],prompt:"prjct ship Ship it | prjct task <next> Start next | prjct status active Reopen",description:"Task completed"},shipped:{transitions:["task"],prompt:"prjct task <description> Start new task",description:"Feature shipped"}},da=class{static{c(this,"WorkflowStateMachine")}getCurrentState(e,t){let s=null;if(t&&e?.activeTasks?.length&&(s=e.activeTasks.find(o=>o.workspaceId===t)),s||(s=e?.currentTask),!s)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof s.status=="string"?s.status:"").toLowerCase()){case"in_progress":case"working":return"working";case"paused":return"paused";case"completed":case"done":return"completed";case"shipped":return"shipped";default:return s?"working":"idle"}}canTransition(e,t){if(hr[e].transitions.includes(t))return{valid:!0};let r=this.formatNextSteps(e).join(" | ");return{valid:!1,error:`Cannot transition to '${t}' from '${e}' state`,suggestion:`Valid next steps: ${r}`}}getNextState(e,t){switch(t){case"task":return"working";case"done":return"completed";case"pause":return"paused";case"resume":return"working";case"ship":return"shipped";case"reopen":return"working";default:return e}}getStateInfo(e){return hr[e]}getPrompt(e){return hr[e].prompt}getValidCommands(e){return hr[e].transitions}formatNextSteps(e){return hr[e].transitions.map(s=>{switch(s){case"task":return"prjct task <desc> Start new task";case"done":return"prjct status done Complete current task";case"pause":return"prjct status paused Pause and switch context";case"resume":return"prjct status active Continue paused task";case"ship":return"prjct ship Ship the feature";case"reopen":return"prjct status active Reopen completed task";default:return`prjct ${s}`}})}},Hs=new da});var ma,M,lt=h(()=>{"use strict";Fs();ia();Ce();pa();hs();ws();ma=class extends Ye{static{c(this,"StateStorage")}constructor(){super("state.json",$u)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],activeTasks:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let s=Hs.getCurrentState(e),r=Hs.canTransition(s,t);if(!r.valid)throw new Error(`${r.error}. ${r.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async getPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async startTask(e,t){let s=await this.read(e);this.validateTransition(s,"task");let r={...t,startedAt:x()};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:x()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId}),r}async updateCurrentTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;let r={...s.currentTask,...t};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:x()})),r}async completeTask(e,t){let s=await this.read(e),r=s.currentTask;if(!r)return null;this.validateTransition(s,"done");let o=x(),i=this.createTaskHistoryEntry(r,o,t),a=this.getTaskHistoryFromState(s),l=[i,...a].slice(0,this.maxTaskHistory);return await this.update(e,u=>({...u,currentTask:null,previousTask:null,taskHistory:l,lastUpdated:o})),await this.publishEvent(e,"task.completed",{taskId:r.id,description:r.description,startedAt:r.startedAt,completedAt:o}),r}createTaskHistoryEntry(e,t,s){let r=(e.subtasks||[]).filter(a=>a.status==="completed"&&a.summary).map(a=>a.summary),o=r.length>0?r.map(a=>a.title).join(", "):"Task completed",i={taskId:e.id,title:e.parentDescription||e.description,classification:e.type||"improvement",startedAt:e.startedAt,completedAt:t,subtaskCount:e.subtasks?.length||0,subtaskSummaries:r,outcome:o,branchName:e.branch||"unknown",linearId:e.linearId,linearUuid:e.linearUuid,prUrl:e.prUrl};return s&&(i.feedback=s),e.tokensIn&&(i.tokensIn=e.tokensIn),e.tokensOut&&(i.tokensOut=e.tokensOut),i}maxPausedTasks=5;maxTaskHistory=20;stalenessThresholdDays=30;async pauseTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;this.validateTransition(s,"pause");let r={...s.currentTask,status:"paused",pausedAt:x(),pauseReason:t},o=this.getPausedTasksFromState(s),i=[r,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:x()})),await this.publishEvent(e,"task.paused",{taskId:r.id,description:r.description,pausedAt:r.pausedAt,reason:t,pausedCount:i.length}),r}async resumeTask(e,t){let s=await this.read(e),r=this.getPausedTasksFromState(s);if(r.length===0)return null;this.validateTransition(s,"resume");let o=0;if(t&&(o=r.findIndex(g=>g.id===t),o===-1))return null;let i=r[o],a=r.filter((g,y)=>y!==o),{status:l,pausedAt:u,pauseReason:d,...m}=i,p={...m,startedAt:x(),sessionId:i.sessionId??nt()};return await this.update(e,g=>({...g,currentTask:p,previousTask:null,pausedTasks:a,lastUpdated:x()})),await this.publishEvent(e,"task.resumed",{taskId:p.id,description:p.description,resumedAt:p.startedAt,remainingPaused:a.length}),p}getPausedTasksFromState(e){return Array.isArray(e.pausedTasks)&&e.pausedTasks.length>0?e.pausedTasks:e.previousTask?[e.previousTask]:[]}getTaskHistoryFromState(e){return e.taskHistory||[]}async getStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return s.filter(o=>new Date(o.pausedAt).getTime()<r)}async archiveStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=s.filter(a=>new Date(a.pausedAt).getTime()<r),i=s.filter(a=>new Date(a.pausedAt).getTime()>=r);if(o.length===0)return[];rt.archiveMany(e,o.map(a=>({entityType:"paused_task",entityId:a.id,entityData:a,summary:a.description,reason:"staleness"}))),await this.update(e,a=>({...a,pausedTasks:i,previousTask:null,lastUpdated:x()}));for(let a of o)await this.publishEvent(e,"task.archived",{taskId:a.id,description:a.description,pausedAt:a.pausedAt,reason:"staleness"});return o}async clearTask(e){await this.update(e,()=>({currentTask:null,previousTask:null,pausedTasks:[],activeTasks:[],lastUpdated:x()}))}async hasTask(e){let t=await this.read(e),s=this.getPausedTasksFromState(t);return t.currentTask!==null||s.length>0}async getPausedTask(e){let t=await this.read(e);return this.getPausedTasksFromState(t)[0]||null}async getAllPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async getTaskHistory(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)}async getMostRecentTask(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)[0]||null}async getTaskHistoryByType(e,t){let s=await this.read(e);return this.getTaskHistoryFromState(s).filter(o=>o.classification===t)}async getAggregatedFeedback(e){let s=(await this.getTaskHistory(e)).filter(p=>p.feedback),r=[],o=[],i=[],a=[];for(let p of s){let g=p.feedback;Array.isArray(g.stackConfirmed)&&r.push(...g.stackConfirmed),Array.isArray(g.patternsDiscovered)&&o.push(...g.patternsDiscovered),Array.isArray(g.agentAccuracy)&&i.push(...g.agentAccuracy),Array.isArray(g.issuesEncountered)&&a.push(...g.issuesEncountered)}let l=[...new Set(r)],u=[...new Set(o)],d=new Map;for(let p of a)d.set(p,(d.get(p)||0)+1);let m=[...d.entries()].filter(([p,g])=>g>=2).map(([p])=>p);return{stackConfirmed:l,patternsDiscovered:u,agentAccuracy:i,issuesEncountered:[...new Set(a)],knownGotchas:m}}async startTaskInWorkspace(e,t,s){let r={...t,workspaceId:s,startedAt:x()};return await this.update(e,o=>({...o,activeTasks:[...o.activeTasks||[],r],lastUpdated:x()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId,workspaceId:s}),r}async getCurrentTaskForWorkspace(e,t){return((await this.read(e)).activeTasks||[]).find(r=>r.workspaceId===t)??null}async completeTaskInWorkspace(e,t,s){let r=await this.read(e),i=(r.activeTasks||[]).find(m=>m.workspaceId===t);if(!i)return null;let a=x(),l=this.createTaskHistoryEntry(i,a,s),u=this.getTaskHistoryFromState(r),d=[l,...u].slice(0,this.maxTaskHistory);return await this.update(e,m=>({...m,activeTasks:(m.activeTasks||[]).filter(p=>p.workspaceId!==t),taskHistory:d,lastUpdated:a})),await this.publishEvent(e,"task.completed",{taskId:i.id,description:i.description,startedAt:i.startedAt,completedAt:a,workspaceId:t}),i}async getActiveTasks(e){return(await this.read(e)).activeTasks||[]}async getActiveTaskCount(e){return((await this.read(e)).activeTasks||[]).length}async updateWorkspaceTask(e,t,s){let o=(await this.read(e)).activeTasks||[],i=o.findIndex(l=>l.workspaceId===t);if(i===-1)return null;let a={...o[i],...s,workspaceId:t};return await this.update(e,l=>{let u=[...l.activeTasks||[]];return u[i]=a,{...l,activeTasks:u,lastUpdated:x()}}),a}async addTokens(e,t,s){let r=await this.read(e);if(!r.currentTask)return null;let o=(r.currentTask.tokensIn||0)+t,i=(r.currentTask.tokensOut||0)+s;return await this.update(e,a=>({...a,currentTask:{...a.currentTask,tokensIn:o,tokensOut:i},lastUpdated:x()})),{tokensIn:o,tokensOut:i}}async createSubtasks(e,t){let s=await this.read(e);if(!s.currentTask)return;let r=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?x():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:r,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:r.length,percentage:0}},lastUpdated:x()})),await this.publishEvent(e,"subtasks.created",{taskId:s.currentTask.id,subtaskCount:r.length,subtasks:r.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let s=Ru.safeParse(t);if(!s.success){let y=s.error.issues.map(j=>`${j.path.join(".")}: ${j.message}`);throw new Error(`Subtask completion requires handoff data:
|
|
495
495
|
${y.join(`
|
|
496
496
|
`)}`)}let{output:r,summary:o}=s.data,i=await this.read(e);if(!i.currentTask?.subtasks)return null;let a=i.currentTask.currentSubtaskIndex||0,l=i.currentTask.subtasks[a];if(!l)return null;let u=[...i.currentTask.subtasks];u[a]={...l,status:"completed",completedAt:x(),output:r,summary:o};let d=u.filter(y=>y.status==="completed").length,m=u.length,p=Math.round(d/m*100),g=a+1;return g<u.length&&(u[g]={...u[g],status:"in_progress",startedAt:x()}),await this.update(e,y=>({...y,currentTask:{...y.currentTask,subtasks:u,currentSubtaskIndex:g<m?g:a,subtaskProgress:{completed:d,total:m,percentage:p}},lastUpdated:x()})),await this.publishEvent(e,"subtask.completed",{taskId:i.currentTask.id,subtaskId:l.id,description:l.description,output:r,handoff:o.outputForNextAgent,filesChanged:o.filesChanged.length,progress:{completed:d,total:m,percentage:p}}),g<m?u[g]:null}async getCurrentSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=t.currentTask.currentSubtaskIndex||0;return t.currentTask.subtasks[s]||null}async getNextSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=(t.currentTask.currentSubtaskIndex||0)+1;return t.currentTask.subtasks[s]||null}async getPreviousSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=(t.currentTask.currentSubtaskIndex||0)-1;return s<0?null:t.currentTask.subtasks[s]||null}async getPreviousHandoff(e){let t=await this.getPreviousSubtask(e);return t?.summary?.outputForNextAgent?{fromSubtask:t.description,outputForNextAgent:t.summary.outputForNextAgent,filesChanged:t.summary.filesChanged,whatWasDone:t.summary.whatWasDone}:null}async getSubtasks(e){return(await this.read(e)).currentTask?.subtasks||[]}async getSubtaskProgress(e){return(await this.read(e)).currentTask?.subtaskProgress||null}async hasSubtasks(e){return((await this.read(e)).currentTask?.subtasks?.length||0)>0}async areAllSubtasksComplete(e){let t=await this.read(e);return t.currentTask?.subtasks?t.currentTask.subtasks.every(s=>s.status==="completed"||s.status==="failed"||s.status==="skipped"):!0}async failSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"failed",completedAt:x(),output:`Failed: ${t}`};let a=r+1,l=i.length;a<l&&(i[a]={...i[a],status:"in_progress",startedAt:x()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,d=Math.round(u/l*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<l?a:r,subtaskProgress:{completed:u,total:l,percentage:d}},lastUpdated:x()})),await this.publishEvent(e,"subtask.failed",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,error:t}),a<l?i[a]:null}async skipSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"skipped",completedAt:x(),output:`Skipped: ${t}`,skipReason:t};let a=r+1,l=i.length;a<l&&(i[a]={...i[a],status:"in_progress",startedAt:x()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,d=Math.round(u/l*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<l?a:r,subtaskProgress:{completed:u,total:l,percentage:d}},lastUpdated:x()})),await this.publishEvent(e,"subtask.skipped",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,reason:t}),a<l?i[a]:null}async blockSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"blocked",output:`Blocked: ${t}`,blockReason:t};let a=r+1,l=i.length;return a<l&&(i[a]={...i[a],status:"in_progress",startedAt:x()}),await this.update(e,u=>({...u,currentTask:{...u.currentTask,subtasks:i,currentSubtaskIndex:a<l?a:r},lastUpdated:x()})),await this.publishEvent(e,"subtask.blocked",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,blocker:t}),a<l?i[a]:null}},M=new ma});function My(){let n=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!n)return{level:-1,name:"disabled"};if(Dy.has(n)||n.includes("prjct"))return{level:hn.debug,name:"debug"};let e=hn[n]??-1,t=e>=0?n:"disabled";return{level:e,name:t}}function lo(n,e,t){return Wu>=n?(...s)=>console[t](e,...s):Oy}var hn,Dy,Wu,Ny,Oy,_y,B,ks=h(()=>{"use strict";hn={error:0,warn:1,info:2,debug:3},Dy=new Set(["1","true","*"]);c(My,"getLogLevel");({level:Wu,name:Ny}=My()),Oy=c(()=>{},"noop");c(lo,"createLogMethod");_y={error:lo(hn.error,"[prjct:error]","error"),warn:lo(hn.warn,"[prjct:warn]","warn"),info:lo(hn.info,"[prjct:info]","log"),debug:lo(hn.debug,"[prjct:debug]","log"),isEnabled:c(()=>Wu>=0,"isEnabled"),level:c(()=>Ny,"level")},B=_y});import Ly from"node:fs/promises";import Fy from"node:path";import{Hono as Uy}from"hono";function Hy(n){return $.getGlobalProjectPath(n)}function Gu(n,e){let t=new Uy,s=Hy(n);return t.get("/state",async r=>{let o=await M.read(n);return r.json(o)}),t.get("/queue",async r=>{let o=await We.read(n);return r.json(o)}),t.get("/ideas",async r=>{let o=await He.read(n);return r.json(o)}),t.get("/roadmap",async r=>{let o=C.getDoc(n,"roadmap");return o?r.json(o):r.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async r=>{let o=await Qe.read(n);return r.json(o)}),t.get("/dashboard",async r=>{let[o,i,a,l]=await Promise.all([M.read(n),We.read(n),He.read(n),Qe.read(n)]),u=C.getDoc(n,"roadmap");return r.json({projectId:n,state:o,queue:i,ideas:a,roadmap:u||{features:[],backlog:[],lastUpdated:""},shipped:l,timestamp:new Date().toISOString()})}),t.post("/state",async r=>{try{let o=await r.req.json();if(!o||typeof o!="object"||Array.isArray(o))return r.json({success:!1,error:"Invalid state object"},400);let i=["currentTask","previousTask","lastUpdated"],a={};for(let l of i)l in o&&(a[l]=o[l]);return await M.write(n,a),r.json({success:!0})}catch{return r.json({success:!1,error:"Internal server error"},400)}}),t.get("/context/:name",async r=>{let o=r.req.param("name");if(!["now","next","ideas","shipped"].includes(o))return r.json({error:"Invalid context file"},400);try{let a=Fy.join(s,"context",`${o}.md`),l=await Ly.readFile(a,"utf-8");return r.text(l,200,{"Content-Type":"text/markdown"})}catch(a){return D(a)||B.error(`Context read error: ${k(a)}`),r.text("",200,{"Content-Type":"text/markdown"})}}),t}var Vu=h(()=>{"use strict";Pe();de();gr();fr();Us();lt();q();ks();c(Hy,"getProjectDataPath");c(Gu,"createRoutes")});function Wy(n){return{id:n.id,taskId:n.task_id,author:n.author,content:n.content,createdAt:n.created_at,updatedAt:n.updated_at}}function Gy(){return`cmt_${Math.random().toString(36).slice(2,10)}${Date.now().toString(36)}`}var ga,yr,qu=h(()=>{"use strict";de();c(Wy,"rowToComment");c(Gy,"generateId");ga=class{static{c(this,"CommentStorage")}addComment(e,t,s,r="user"){let o=Gy(),i=new Date().toISOString();return C.run(e,`INSERT INTO queue_task_comments (id, task_id, author, content, created_at, updated_at)
|
|
497
497
|
VALUES (?, ?, ?, ?, ?, ?)`,o,t,r,s,i,i),{id:o,taskId:t,author:r,content:s,createdAt:i,updatedAt:i}}getComments(e,t){return C.query(e,"SELECT * FROM queue_task_comments WHERE task_id = ? ORDER BY created_at ASC",t).map(Wy)}updateComment(e,t,s){return C.get(e,"SELECT id FROM queue_task_comments WHERE id = ?",t)?(C.run(e,"UPDATE queue_task_comments SET content = ?, updated_at = ? WHERE id = ?",s,new Date().toISOString(),t),!0):!1}deleteComment(e,t){return C.get(e,"SELECT id FROM queue_task_comments WHERE id = ?",t)?(C.run(e,"DELETE FROM queue_task_comments WHERE id = ?",t),!0):!1}},yr=new ga});var fa,ha,Bu=h(()=>{"use strict";de();fa=class{static{c(this,"ContextZoneStorage")}recordTransition(e,t,s){C.run(e,`INSERT INTO context_zone_events (project_id, session_id, zone_from, zone_to, usage_percent, action, timestamp)
|
|
@@ -500,14 +500,14 @@ ${y.join(`
|
|
|
500
500
|
WHERE project_id = ? AND timestamp >= ?
|
|
501
501
|
GROUP BY zone_to`,e,s),o={smart:0,warning:0,dumb:0},i=0;for(let u of r)o[u.zone_to]=u.cnt,i+=u.cnt;let l=C.query(e,`SELECT COUNT(*) as cnt FROM context_compactions
|
|
502
502
|
WHERE project_id = ? AND timestamp >= ?`,e,s)[0]?.cnt??0;return i===0?{smartPercent:100,warningPercent:0,dumbPercent:0,compactions:l}:{smartPercent:Math.round(o.smart/i*100),warningPercent:Math.round(o.warning/i*100),dumbPercent:Math.round(o.dumb/i*100),compactions:l}}},ha=new fa});var ya,De,uo=h(()=>{"use strict";de();ya=class{static{c(this,"CustomWorkflowStorage")}createWorkflow(e,t){let s=new Date().toISOString();L.run(e,`INSERT INTO custom_workflows (name, description, created_at, updated_at, is_builtin, enabled, metadata)
|
|
503
|
-
VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,s,s,t.metadata?JSON.stringify(t.metadata):null);let r=L.get(e,"SELECT id FROM custom_workflows WHERE name = ?",t.name);if(!r)throw new Error(`Failed to create workflow: ${t.name}`);return r.id}getWorkflow(e,t){let s=L.get(e,"SELECT * FROM custom_workflows WHERE name = ?",t);return s?this.rowToWorkflow(s):null}getAllWorkflows(e,t=!1){let s=t?"SELECT * FROM custom_workflows ORDER BY is_builtin DESC, name ASC":"SELECT * FROM custom_workflows WHERE enabled = 1 ORDER BY is_builtin DESC, name ASC";return L.query(e,s).map(o=>this.rowToWorkflow(o))}updateWorkflow(e,t,s){if(!this.getWorkflow(e,t))return!1;let o=new Date().toISOString(),i=[],a=[];return s.description!==void 0&&(i.push("description = ?"),a.push(s.description)),s.enabled!==void 0&&(i.push("enabled = ?"),a.push(s.enabled?1:0)),s.metadata!==void 0&&(i.push("metadata = ?"),a.push(JSON.stringify(s.metadata))),i.length===0?!1:(i.push("updated_at = ?"),a.push(o),a.push(t),L.run(e,`UPDATE custom_workflows SET ${i.join(", ")} WHERE name = ?`,...a),!0)}deleteWorkflow(e,t){let s=this.getWorkflow(e,t);if(!s)return!1;if(s.isBuiltin)throw new Error(`Cannot delete built-in workflow: ${t}`);return L.run(e,"UPDATE custom_workflows SET enabled = 0 WHERE name = ?",t),!0}isBuiltin(e,t){return this.getWorkflow(e,t)?.isBuiltin??!1}isReservedName(e){let t=["task","done","ship","sync"],s=["add","rm","gate","list","create","delete","run","help","reset","init"];return t.includes(e)||s.includes(e)}isValidName(e){return/^[a-z0-9-]+$/.test(e)}rowToWorkflow(e){return{id:e.id,name:e.name,description:e.description,createdAt:e.created_at,updatedAt:e.updated_at,isBuiltin:e.is_builtin===1,enabled:e.enabled===1,metadata:e.metadata?JSON.parse(e.metadata):null}}},De=new ya});import{createHash as Ju}from"node:crypto";function wr(n){return Ju("sha256").update(n).digest("hex")}function zu(n){return wr(n).slice(0,16)}function Xu(n){return Ju("md5").update(n).digest("hex")}var kr=h(()=>{"use strict";c(wr,"sha256");c(zu,"sha256Short");c(Xu,"md5")});import po from"node:fs/promises";import Ku from"node:path";function Vy(){return{version:yn,lastUpdated:"",checksums:{}}}var yn,wa,Sr,Yu=h(()=>{"use strict";Pe();q();Ce();kr();de();yn="1.0.0";c(Vy,"getDefaultChecksums");wa=class{static{c(this,"IndexStorage")}getIndexPath(e){return Ku.join($.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await po.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==yn?null:t}catch{}return null}async writeIndex(e,t){this.setIndexMeta(e,"project-index",t)}async hasValidIndex(e){let t=await this.readIndex(e);return t!==null&&t.lastFullScan!==""}async readChecksums(e){try{let t=this.getIndexMeta(e,"checksums");if(t!==null)return t}catch{}return Vy()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await po.readFile(e);return Xu(t)}catch{return""}}async detectChangedFiles(e,t){let r=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[l,u]of t)l in r?r[l]!==u&&i.push(l):o.push(l);for(let l of Object.keys(r))t.has(l)||a.push(l);return{added:o,modified:i,deleted:a}}async readScores(e){try{let t=this.getIndexMeta(e,"file-scores");if(t!==null)return t.scores||[]}catch{}return[]}async writeScores(e,t){let s={version:yn,lastUpdated:x(),scores:t};this.setIndexMeta(e,"file-scores",s)}async clearIndex(e){try{C.getDb(e).prepare("DELETE FROM index_meta").run()}catch{}let t=this.getIndexPath(e);try{let s=await po.readdir(t);await Promise.all(s.map(r=>po.unlink(Ku.join(t,r))))}catch(s){if(!D(s))throw s}}async getIndexAge(e){let t=await this.readIndex(e);if(!t||!t.lastFullScan)return 1/0;let s=new Date(t.lastFullScan);return(new Date().getTime()-s.getTime())/(1e3*60*60)}async readDomains(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null)return t.version!==yn?null:t}catch{}return null}readDomainsSync(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null&&t.version===yn)return t}catch{}return null}async writeDomains(e,t){this.setIndexMeta(e,"domains",t)}async readCategories(e){try{let t=this.getIndexMeta(e,"categories-cache");if(t!==null)return t.version!==yn?null:t}catch{}return null}async writeCategories(e,t){this.setIndexMeta(e,"categories-cache",t)}async getFileCategories(e,t){let s=await this.readCategories(e),r=new Map;if(!s)return r;let o=new Set(t);for(let i of s.fileCategories)o.has(i.path)&&r.set(i.path,i.categories);return r}async getFilesByDomain(e,t){let s=await this.readCategories(e);return s?s.domainIndex[t]||[]:[]}getIndexMeta(e,t){let r=C.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setIndexMeta(e,t,s){let r=C.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();r.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},Sr=new wa});var ka,mo,St,wn=h(()=>{"use strict";Ce();de();ka=class{static{c(this,"LLMAnalysisStorage")}save(e,t){let s=C.getDb(e),r=x();s.transaction(()=>{s.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(r),s.prepare("INSERT INTO llm_analysis (commit_hash, status, analysis, analyzed_at) VALUES (?, ?, ?, ?)").run(t.commitHash??null,"active",JSON.stringify(t),t.analyzedAt)})()}getActive(e){let t=C.get(e,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");return t?JSON.parse(t.analysis):null}getActiveSummary(e){let t=this.getActive(e);return t?{commitHash:t.commitHash,architectureStyle:t.architecture.style,patternCount:t.patterns.length,antiPatternCount:t.antiPatterns.length,analyzedAt:t.analyzedAt}:null}isCurrent(e,t){return t?C.get(e,"SELECT commit_hash FROM llm_analysis WHERE status = 'active' LIMIT 1")?.commit_hash===t:!1}getAllFull(e){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, superseded_at, analysis FROM llm_analysis ORDER BY id DESC").map(s=>({id:s.id,status:s.status,commitHash:s.commit_hash,analyzedAt:s.analyzed_at,supersededAt:s.superseded_at,analysis:JSON.parse(s.analysis)}))}getHistory(e,t=10){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, analysis FROM llm_analysis ORDER BY id DESC LIMIT ?",t).map(r=>{let o=JSON.parse(r.analysis);return{id:r.id,commitHash:r.commit_hash,status:r.status,analyzedAt:r.analyzed_at,patternCount:o.patterns.length}})}},mo=new ka,St=mo});import{z as Me}from"zod";function td(n,e="default"){let t=Qu[e]||Qu.default;return n/1e3*t}function go(n){return n<.01?`$${(n*100).toFixed(2)}\xA2`:`$${n.toFixed(2)}`}var qy,By,Zu,ed,Qu,fo=h(()=>{"use strict";qy=Me.object({date:Me.string(),tokensSaved:Me.number(),syncs:Me.number(),avgCompressionRate:Me.number(),totalDuration:Me.number()}),By=Me.object({agentName:Me.string(),usageCount:Me.number(),tokensSaved:Me.number()}),Zu=Me.object({totalTokensSaved:Me.number(),avgCompressionRate:Me.number(),syncCount:Me.number(),watchTriggers:Me.number(),avgSyncDuration:Me.number(),totalSyncDuration:Me.number(),agentUsage:Me.array(By),dailyStats:Me.array(qy),firstSync:Me.string(),lastUpdated:Me.string()}),ed={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},Qu={"claude-opus-4.5":.005,"claude-sonnet-4.5":.003,"claude-haiku-4.5":.001,"claude-opus-4":.015,"claude-sonnet-4":.003,"gpt-4o":.0025,"gemini-pro":.00125,default:.003};c(td,"estimateCostSaved");c(go,"formatCost")});var Sa,ns,ho=h(()=>{"use strict";fo();Ce();ws();Sa=class extends Ye{static{c(this,"MetricsStorage")}constructor(){super("metrics.json",Zu)}getDefault(){return{...ed}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let s=Math.max(0,t.originalSize-t.filteredSize),r=t.originalSize>0?s/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,l=i.totalTokensSaved+s,u=i.totalSyncDuration+t.duration,d=i.syncCount===0?r:(i.avgCompressionRate*i.syncCount+r)/a,m=[...i.dailyStats],p=m.findIndex(R=>R.date===o);if(p>=0){let R=m[p];m[p]={...R,tokensSaved:R.tokensSaved+s,syncs:R.syncs+1,avgCompressionRate:(R.avgCompressionRate*R.syncs+r)/(R.syncs+1),totalDuration:R.totalDuration+t.duration}}else m.push({date:o,tokensSaved:s,syncs:1,avgCompressionRate:r,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let y=g.toISOString().split("T")[0],j=m.filter(R=>R.date>=y),E=[...i.agentUsage];if(t.agents)for(let R of t.agents){let b=E.findIndex(S=>S.agentName===R);b>=0?E[b]={...E[b],usageCount:E[b].usageCount+1,tokensSaved:E[b].tokensSaved+Math.floor(s/t.agents.length)}:E.push({agentName:R,usageCount:1,tokensSaved:Math.floor(s/t.agents.length)})}return{totalTokensSaved:l,avgCompressionRate:d,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:E,dailyStats:j,firstSync:i.firstSync||x(),lastUpdated:x()}})}async getSummary(e){let t=await this.read(e),s=this.getLast30Days(t.dailyStats),r=this.getPrev30Days(t.dailyStats),o=s.reduce((l,u)=>l+u.tokensSaved,0),i=r.reduce((l,u)=>l+u.tokensSaved,0),a=i>0?(o-i)/i*100:0;return{totalTokensSaved:t.totalTokensSaved,estimatedCostSaved:td(t.totalTokensSaved),compressionRate:t.avgCompressionRate,syncCount:t.syncCount,avgSyncDuration:t.avgSyncDuration,topAgents:[...t.agentUsage].sort((l,u)=>u.usageCount-l.usageCount).slice(0,5),last30DaysTokens:o,trend:a}}async getDailyStats(e,t=30){let s=await this.read(e),r=new Date;r.setDate(r.getDate()-t);let o=r.toISOString().split("T")[0];return s.dailyStats.filter(i=>i.date>=o).sort((i,a)=>i.date.localeCompare(a.date))}getLast30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=t.toISOString().split("T")[0];return e.filter(r=>r.date>=s)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=new Date;s.setDate(s.getDate()-60);let r=s.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=r&&i.date<o)}},ns=new Sa});import{z as pe}from"zod";var Jy,zy,sd,Sx,vx,bx,nd,rd=h(()=>{"use strict";Jy=pe.enum(["improving","stable","declining"]),zy=pe.object({sprintNumber:pe.number(),startDate:pe.string(),endDate:pe.string(),pointsCompleted:pe.number(),tasksCompleted:pe.number(),avgVariance:pe.number(),estimationAccuracy:pe.number()}),sd=pe.object({category:pe.string(),avgVariance:pe.number(),taskCount:pe.number()}),Sx=pe.object({totalPoints:pe.number(),sprints:pe.number(),estimatedDate:pe.string()}),vx=pe.object({sprints:pe.array(zy),averageVelocity:pe.number(),velocityTrend:Jy,estimationAccuracy:pe.number(),overEstimated:pe.array(sd),underEstimated:pe.array(sd),lastUpdated:pe.string()}),bx=pe.object({sprintLengthDays:pe.number().min(1).max(90).default(7),startDay:pe.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:pe.number().min(1).max(52).default(6),accuracyTolerance:pe.number().min(0).max(100).default(20)}),nd={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var va,yo,ba=h(()=>{"use strict";rd();ws();va=class extends Ye{static{c(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:nd,lastUpdated:""}}getEventType(e){return`velocity.${e}d`}async saveMetrics(e,t){await this.write(e,{metrics:t,lastUpdated:t.lastUpdated}),await this.publishEntityEvent(e,"velocity","updated",{averageVelocity:t.averageVelocity,trend:t.velocityTrend,sprintCount:t.sprints.length})}async getMetrics(e){return(await this.read(e)).metrics}},yo=new va});function Ta(n){let e=n.trust_source==="imported"?"imported":"local";return{id:n.id,type:n.type,command:n.command,position:n.position,action:n.action,description:n.description,enabled:n.enabled===1,timeoutMs:n.timeout_ms,createdAt:n.created_at,sortOrder:n.sort_order,whenExpr:n.when_expr??null,parallel:n.parallel===null?!0:n.parallel===1,trustSource:e}}var Ea,te,kn=h(()=>{"use strict";uo();de();c(Ta,"rowToRule");Ea=class{static{c(this,"WorkflowRuleStorage")}addRule(e,t){let s=C.get(e,"SELECT MAX(sort_order) as m FROM workflow_rules WHERE command = ?",t.command),r=t.sortOrder||(s?.m??-1)+1;return C.run(e,`INSERT INTO workflow_rules (type, command, position, action, description, enabled, timeout_ms, created_at, sort_order, when_expr, parallel, trust_source)
|
|
503
|
+
VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,s,s,t.metadata?JSON.stringify(t.metadata):null);let r=L.get(e,"SELECT id FROM custom_workflows WHERE name = ?",t.name);if(!r)throw new Error(`Failed to create workflow: ${t.name}`);return r.id}getWorkflow(e,t){let s=L.get(e,"SELECT * FROM custom_workflows WHERE name = ?",t);return s?this.rowToWorkflow(s):null}getAllWorkflows(e,t=!1){let s=t?"SELECT * FROM custom_workflows ORDER BY is_builtin DESC, name ASC":"SELECT * FROM custom_workflows WHERE enabled = 1 ORDER BY is_builtin DESC, name ASC";return L.query(e,s).map(o=>this.rowToWorkflow(o))}updateWorkflow(e,t,s){if(!this.getWorkflow(e,t))return!1;let o=new Date().toISOString(),i=[],a=[];return s.description!==void 0&&(i.push("description = ?"),a.push(s.description)),s.enabled!==void 0&&(i.push("enabled = ?"),a.push(s.enabled?1:0)),s.metadata!==void 0&&(i.push("metadata = ?"),a.push(JSON.stringify(s.metadata))),i.length===0?!1:(i.push("updated_at = ?"),a.push(o),a.push(t),L.run(e,`UPDATE custom_workflows SET ${i.join(", ")} WHERE name = ?`,...a),!0)}deleteWorkflow(e,t){let s=this.getWorkflow(e,t);if(!s)return!1;if(s.isBuiltin)throw new Error(`Cannot delete built-in workflow: ${t}`);return L.run(e,"UPDATE custom_workflows SET enabled = 0 WHERE name = ?",t),!0}isBuiltin(e,t){return this.getWorkflow(e,t)?.isBuiltin??!1}isReservedName(e){let t=["task","done","ship","sync"],s=["add","rm","gate","list","create","delete","run","help","reset","init"];return t.includes(e)||s.includes(e)}isValidName(e){return/^[a-z0-9-]+$/.test(e)}rowToWorkflow(e){return{id:e.id,name:e.name,description:e.description,createdAt:e.created_at,updatedAt:e.updated_at,isBuiltin:e.is_builtin===1,enabled:e.enabled===1,metadata:e.metadata?JSON.parse(e.metadata):null}}},De=new ya});import{createHash as Ju}from"node:crypto";function wr(n){return Ju("sha256").update(n).digest("hex")}function zu(n){return wr(n).slice(0,16)}function Xu(n){return Ju("md5").update(n).digest("hex")}var kr=h(()=>{"use strict";c(wr,"sha256");c(zu,"sha256Short");c(Xu,"md5")});import po from"node:fs/promises";import Ku from"node:path";function Vy(){return{version:yn,lastUpdated:"",checksums:{}}}var yn,wa,Sr,Yu=h(()=>{"use strict";Pe();q();Ce();kr();de();yn="1.0.0";c(Vy,"getDefaultChecksums");wa=class{static{c(this,"IndexStorage")}getIndexPath(e){return Ku.join($.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await po.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==yn?null:t}catch{}return null}async writeIndex(e,t){this.setIndexMeta(e,"project-index",t)}async hasValidIndex(e){let t=await this.readIndex(e);return t!==null&&t.lastFullScan!==""}async readChecksums(e){try{let t=this.getIndexMeta(e,"checksums");if(t!==null)return t}catch{}return Vy()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await po.readFile(e);return Xu(t)}catch{return""}}async detectChangedFiles(e,t){let r=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[l,u]of t)l in r?r[l]!==u&&i.push(l):o.push(l);for(let l of Object.keys(r))t.has(l)||a.push(l);return{added:o,modified:i,deleted:a}}async readScores(e){try{let t=this.getIndexMeta(e,"file-scores");if(t!==null)return t.scores||[]}catch{}return[]}async writeScores(e,t){let s={version:yn,lastUpdated:x(),scores:t};this.setIndexMeta(e,"file-scores",s)}async clearIndex(e){try{C.getDb(e).prepare("DELETE FROM index_meta").run()}catch{}let t=this.getIndexPath(e);try{let s=await po.readdir(t);await Promise.all(s.map(r=>po.unlink(Ku.join(t,r))))}catch(s){if(!D(s))throw s}}async getIndexAge(e){let t=await this.readIndex(e);if(!t||!t.lastFullScan)return 1/0;let s=new Date(t.lastFullScan);return(new Date().getTime()-s.getTime())/(1e3*60*60)}async readDomains(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null)return t.version!==yn?null:t}catch{}return null}readDomainsSync(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null&&t.version===yn)return t}catch{}return null}async writeDomains(e,t){this.setIndexMeta(e,"domains",t)}async readCategories(e){try{let t=this.getIndexMeta(e,"categories-cache");if(t!==null)return t.version!==yn?null:t}catch{}return null}async writeCategories(e,t){this.setIndexMeta(e,"categories-cache",t)}async getFileCategories(e,t){let s=await this.readCategories(e),r=new Map;if(!s)return r;let o=new Set(t);for(let i of s.fileCategories)o.has(i.path)&&r.set(i.path,i.categories);return r}async getFilesByDomain(e,t){let s=await this.readCategories(e);return s?s.domainIndex[t]||[]:[]}getIndexMeta(e,t){let r=C.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setIndexMeta(e,t,s){let r=C.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();r.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},Sr=new wa});var ka,mo,St,wn=h(()=>{"use strict";Ce();de();ka=class{static{c(this,"LLMAnalysisStorage")}save(e,t){let s=C.getDb(e),r=x();s.transaction(()=>{s.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(r),s.prepare("INSERT INTO llm_analysis (commit_hash, status, analysis, analyzed_at) VALUES (?, ?, ?, ?)").run(t.commitHash??null,"active",JSON.stringify(t),t.analyzedAt)})()}getActive(e){let t=C.get(e,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");return t?JSON.parse(t.analysis):null}getActiveSummary(e){let t=this.getActive(e);return t?{commitHash:t.commitHash,architectureStyle:t.architecture.style,patternCount:t.patterns.length,antiPatternCount:t.antiPatterns.length,analyzedAt:t.analyzedAt}:null}isCurrent(e,t){return t?C.get(e,"SELECT commit_hash FROM llm_analysis WHERE status = 'active' LIMIT 1")?.commit_hash===t:!1}getAllFull(e){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, superseded_at, analysis FROM llm_analysis ORDER BY id DESC").map(s=>({id:s.id,status:s.status,commitHash:s.commit_hash,analyzedAt:s.analyzed_at,supersededAt:s.superseded_at,analysis:JSON.parse(s.analysis)}))}getHistory(e,t=10){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, analysis FROM llm_analysis ORDER BY id DESC LIMIT ?",t).map(r=>{let o=JSON.parse(r.analysis);return{id:r.id,commitHash:r.commit_hash,status:r.status,analyzedAt:r.analyzed_at,patternCount:o.patterns.length}})}},mo=new ka,St=mo});import{z as Me}from"zod";function td(n,e="default"){let t=Qu[e]||Qu.default;return n/1e3*t}function go(n){return n<.01?`$${(n*100).toFixed(2)}\xA2`:`$${n.toFixed(2)}`}var qy,By,Zu,ed,Qu,fo=h(()=>{"use strict";qy=Me.object({date:Me.string(),tokensSaved:Me.number(),syncs:Me.number(),avgCompressionRate:Me.number(),totalDuration:Me.number()}),By=Me.object({agentName:Me.string(),usageCount:Me.number(),tokensSaved:Me.number()}),Zu=Me.object({totalTokensSaved:Me.number(),avgCompressionRate:Me.number(),syncCount:Me.number(),watchTriggers:Me.number(),avgSyncDuration:Me.number(),totalSyncDuration:Me.number(),agentUsage:Me.array(By),dailyStats:Me.array(qy),firstSync:Me.string(),lastUpdated:Me.string()}),ed={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},Qu={"claude-opus-4.5":.005,"claude-sonnet-4.5":.003,"claude-haiku-4.5":.001,"claude-opus-4":.015,"claude-sonnet-4":.003,"gpt-4o":.0025,"gemini-pro":.00125,default:.003};c(td,"estimateCostSaved");c(go,"formatCost")});var Sa,ns,ho=h(()=>{"use strict";fo();Ce();ws();Sa=class extends Ye{static{c(this,"MetricsStorage")}constructor(){super("metrics.json",Zu)}getDefault(){return{...ed}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let s=Math.max(0,t.originalSize-t.filteredSize),r=t.originalSize>0?s/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,l=i.totalTokensSaved+s,u=i.totalSyncDuration+t.duration,d=i.syncCount===0?r:(i.avgCompressionRate*i.syncCount+r)/a,m=[...i.dailyStats],p=m.findIndex(R=>R.date===o);if(p>=0){let R=m[p];m[p]={...R,tokensSaved:R.tokensSaved+s,syncs:R.syncs+1,avgCompressionRate:(R.avgCompressionRate*R.syncs+r)/(R.syncs+1),totalDuration:R.totalDuration+t.duration}}else m.push({date:o,tokensSaved:s,syncs:1,avgCompressionRate:r,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let y=g.toISOString().split("T")[0],j=m.filter(R=>R.date>=y),E=[...i.agentUsage];if(t.agents)for(let R of t.agents){let b=E.findIndex(S=>S.agentName===R);b>=0?E[b]={...E[b],usageCount:E[b].usageCount+1,tokensSaved:E[b].tokensSaved+Math.floor(s/t.agents.length)}:E.push({agentName:R,usageCount:1,tokensSaved:Math.floor(s/t.agents.length)})}return{totalTokensSaved:l,avgCompressionRate:d,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:E,dailyStats:j,firstSync:i.firstSync||x(),lastUpdated:x()}})}async getSummary(e){let t=await this.read(e),s=this.getLast30Days(t.dailyStats),r=this.getPrev30Days(t.dailyStats),o=s.reduce((l,u)=>l+u.tokensSaved,0),i=r.reduce((l,u)=>l+u.tokensSaved,0),a=i>0?(o-i)/i*100:0;return{totalTokensSaved:t.totalTokensSaved,estimatedCostSaved:td(t.totalTokensSaved),compressionRate:t.avgCompressionRate,syncCount:t.syncCount,avgSyncDuration:t.avgSyncDuration,topAgents:[...t.agentUsage].sort((l,u)=>u.usageCount-l.usageCount).slice(0,5),last30DaysTokens:o,trend:a}}async getDailyStats(e,t=30){let s=await this.read(e),r=new Date;r.setDate(r.getDate()-t);let o=r.toISOString().split("T")[0];return s.dailyStats.filter(i=>i.date>=o).sort((i,a)=>i.date.localeCompare(a.date))}getLast30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=t.toISOString().split("T")[0];return e.filter(r=>r.date>=s)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=new Date;s.setDate(s.getDate()-60);let r=s.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=r&&i.date<o)}},ns=new Sa});import{z as pe}from"zod";var Jy,zy,sd,vx,bx,Tx,nd,rd=h(()=>{"use strict";Jy=pe.enum(["improving","stable","declining"]),zy=pe.object({sprintNumber:pe.number(),startDate:pe.string(),endDate:pe.string(),pointsCompleted:pe.number(),tasksCompleted:pe.number(),avgVariance:pe.number(),estimationAccuracy:pe.number()}),sd=pe.object({category:pe.string(),avgVariance:pe.number(),taskCount:pe.number()}),vx=pe.object({totalPoints:pe.number(),sprints:pe.number(),estimatedDate:pe.string()}),bx=pe.object({sprints:pe.array(zy),averageVelocity:pe.number(),velocityTrend:Jy,estimationAccuracy:pe.number(),overEstimated:pe.array(sd),underEstimated:pe.array(sd),lastUpdated:pe.string()}),Tx=pe.object({sprintLengthDays:pe.number().min(1).max(90).default(7),startDay:pe.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:pe.number().min(1).max(52).default(6),accuracyTolerance:pe.number().min(0).max(100).default(20)}),nd={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var va,yo,ba=h(()=>{"use strict";rd();ws();va=class extends Ye{static{c(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:nd,lastUpdated:""}}getEventType(e){return`velocity.${e}d`}async saveMetrics(e,t){await this.write(e,{metrics:t,lastUpdated:t.lastUpdated}),await this.publishEntityEvent(e,"velocity","updated",{averageVelocity:t.averageVelocity,trend:t.velocityTrend,sprintCount:t.sprints.length})}async getMetrics(e){return(await this.read(e)).metrics}},yo=new va});function Ta(n){let e=n.trust_source==="imported"?"imported":"local";return{id:n.id,type:n.type,command:n.command,position:n.position,action:n.action,description:n.description,enabled:n.enabled===1,timeoutMs:n.timeout_ms,createdAt:n.created_at,sortOrder:n.sort_order,whenExpr:n.when_expr??null,parallel:n.parallel===null?!0:n.parallel===1,trustSource:e}}var Ea,te,kn=h(()=>{"use strict";uo();de();c(Ta,"rowToRule");Ea=class{static{c(this,"WorkflowRuleStorage")}addRule(e,t){let s=C.get(e,"SELECT MAX(sort_order) as m FROM workflow_rules WHERE command = ?",t.command),r=t.sortOrder||(s?.m??-1)+1;return C.run(e,`INSERT INTO workflow_rules (type, command, position, action, description, enabled, timeout_ms, created_at, sort_order, when_expr, parallel, trust_source)
|
|
504
504
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,r,t.whenExpr??null,t.parallel===!1?0:1,t.trustSource??"local"),C.get(e,"SELECT last_insert_rowid() as id")?.id??0}removeRule(e,t){return C.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t)?(C.run(e,"DELETE FROM workflow_rules WHERE id = ?",t),!0):!1}updateRule(e,t,s){if(!C.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t))return!1;let o={type:{column:"type"},command:{column:"command"},position:{column:"position"},action:{column:"action"},description:{column:"description"},enabled:{column:"enabled",transform:c(l=>l?1:0,"transform")},timeoutMs:{column:"timeout_ms"},createdAt:{column:"created_at"},sortOrder:{column:"sort_order"},whenExpr:{column:"when_expr"},parallel:{column:"parallel",transform:c(l=>l===!1?0:1,"transform")},trustSource:{column:"trust_source"}},i=[],a=[];for(let[l,u]of Object.entries(s)){let d=o[l];if(!d)continue;i.push(`${d.column} = ?`);let m=u;a.push(d.transform?d.transform(m):m)}return i.length===0||(a.push(t),C.run(e,`UPDATE workflow_rules SET ${i.join(", ")} WHERE id = ?`,...a)),!0}getRuleById(e,t){let s=C.get(e,"SELECT * FROM workflow_rules WHERE id = ?",t);return s?Ta(s):null}getRulesForCommand(e,t){let s=De.getWorkflow(e,t);return!s||!s.enabled?[]:C.query(e,"SELECT * FROM workflow_rules WHERE command = ? AND enabled = 1 ORDER BY sort_order ASC",t).map(Ta)}getAllRules(e){return C.query(e,"SELECT * FROM workflow_rules ORDER BY command ASC, sort_order ASC").map(Ta)}resetRules(e){let t=C.get(e,"SELECT COUNT(*) as c FROM workflow_rules");return C.run(e,"DELETE FROM workflow_rules"),t?.c??0}},te=new Ea});import Ut from"node:fs/promises";import Pa from"node:path";import{Hono as Xy}from"hono";function vr(n){return C.getDoc(n,"project")}async function Ca(n){if(!n)return"";let e=new Date(n),s=new Date().getTime()-e.getTime(),r=Math.floor(s/(1e3*60*60)),o=Math.floor(s%(1e3*60*60)/(1e3*60));return r>0?`${r}h ${o}m`:`${o}m`}function od(){let n=new Xy;return n.get("/projects",async e=>{try{await Ut.mkdir(Sn,{recursive:!0});let s=(await Ut.readdir(Sn,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),r=await Promise.all(s.map(async o=>{let i=vr(o),a=await M.read(o),l=await We.read(o),u=await He.read(o),d=await Qe.read(o),m=a?.currentTask,p=await Ca(m?.startedAt),g=i;return{id:o,name:g?.name||o.slice(0,8),path:g?.repoPath||g?.path||null,stack:g?.stack||null,branch:g?.currentBranch||null,fileCount:g?.fileCount||null,lastSync:g?.lastSync||null,version:g?.version||null,currentTask:m?{...m,duration:p}:null,pausedTask:a?.previousTask||null,stats:{queueCount:l?.tasks?.filter(y=>!y.completed)?.length||0,ideasCount:u?.ideas?.filter(y=>y.status==="pending")?.length||0,shippedCount:d?.shipped?.length||0,tasksToday:0,tasksThisWeek:0}}}));return r.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:String(o.name||"").localeCompare(String(i.name||""))),e.json({projects:r})}catch{return e.json({projects:[],error:"Internal server error"},500)}}),n.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[s,r,o,i,a]=await Promise.all([Promise.resolve(vr(t)),M.read(t),We.read(t),He.read(t),Qe.read(t)]),l=C.getDoc(t,"roadmap");r?.currentTask?.startedAt&&(r.currentTask.duration=await Ca(r.currentTask.startedAt));let u=new Date,d=new Date(u.getFullYear(),u.getMonth(),u.getDate()),m=new Date(d);m.setDate(m.getDate()-m.getDay());let p=o?.tasks?.filter(j=>!j.completed||!j.completedAt?!1:new Date(j.completedAt)>=d)?.length||0,g=o?.tasks?.filter(j=>!j.completed||!j.completedAt?!1:new Date(j.completedAt)>=m)?.length||0,y=null;try{let j=C.get(t,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");if(j){let E=JSON.parse(j.analysis);y={architecture:E.architecture,patterns:(E.patterns||[]).slice(0,6),antiPatterns:(E.antiPatterns||[]).slice(0,4),techDebt:(E.techDebt||[]).slice(0,4),conventions:E.conventions,stack:E.stack,analyzedAt:E.analyzedAt,commitHash:E.commitHash}}}catch{}return e.json({id:t,name:s?.name||t,path:s?.path,state:r||{currentTask:null,previousTask:null,lastUpdated:""},queue:o||{tasks:[],lastUpdated:""},ideas:i||{ideas:[],lastUpdated:""},shipped:a||{shipped:[],lastUpdated:""},roadmap:l||{features:[],backlog:[],lastUpdated:""},analysis:y,stats:{tasksToday:p,tasksThisWeek:g,queueCount:o?.tasks?.filter(j=>!j.completed)?.length||0,ideasCount:i?.ideas?.filter(j=>j.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let s=await M.read(t);if(!s?.currentTask)return e.json({success:!1,error:"No active task"},400);let r=s.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await M.write(t,o),e.json({success:!0,completedTask:r,message:`Completed: ${r.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),r=typeof s.reason=="string"?s.reason.slice(0,500):void 0,o=await M.read(t);if(!o?.currentTask)return e.json({success:!1,error:"No active task"},400);let i={id:o.currentTask.id,description:o.currentTask.description,status:"paused",startedAt:o.currentTask.startedAt,pausedAt:new Date().toISOString(),pauseReason:r},a={currentTask:null,previousTask:i,lastUpdated:new Date().toISOString()};return await M.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let s=await M.read(t);if(!s?.previousTask)return e.json({success:!1,error:"No paused task"},400);let r={id:s.previousTask.id,description:s.previousTask.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`},o={currentTask:r,previousTask:null,lastUpdated:new Date().toISOString()};return await M.write(t,o),e.json({success:!0,resumedTask:r,message:`Resumed: ${r.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{taskId:r}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"taskId required (string)"},400);if(r.length>200)return e.json({success:!1,error:"taskId too long"},400);let[o,i]=await Promise.all([M.read(t),We.read(t)]);if(o?.currentTask)return e.json({success:!1,error:"Complete or pause current task first"},400);let a=i?.tasks?.find(d=>d.id===r);if(!a)return e.json({success:!1,error:"Task not found in queue"},404);let l={id:a.id,description:a.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`,featureId:a.featureId},u={currentTask:l,previousTask:null,lastUpdated:new Date().toISOString()};return await M.write(t,u),e.json({success:!0,task:l,message:`Started: ${l.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{text:r,priority:o="medium",tags:i=[]}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"text required (string)"},400);if(r.length>5e3)return e.json({success:!1,error:"text too long (max 5000 chars)"},400);let l=["low","medium","high","critical"].includes(o)?o:"medium",u=Array.isArray(i)?i.filter(m=>typeof m=="string").slice(0,20):[],d=await He.addIdea(t,r,{priority:l,tags:u});return e.json({success:!0,idea:d,message:`Captured: ${r.slice(0,50)}...`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.get("/stats/global",async e=>{try{await Ut.mkdir(Sn,{recursive:!0});let s=(await Ut.readdir(Sn,{withFileTypes:!0})).filter(l=>l.isDirectory()).map(l=>l.name),r=0,o=0,i=0,a=0;for(let l of s){let u=await M.read(l),d=await We.read(l),m=await He.read(l),p=await Qe.read(l);u?.currentTask&&a++,r+=d?.tasks?.filter(g=>!g.completed)?.length||0,o+=m?.ideas?.filter(g=>g.status==="pending")?.length||0,i+=p?.shipped?.length||0}return e.json({totalProjects:s.length,activeProjects:a,totalTasks:r,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await Ut.mkdir(Sn,{recursive:!0});let r=(await Ut.readdir(Sn,{withFileTypes:!0})).filter(d=>d.isDirectory()).map(d=>d.name),o=null;if(t)for(let d of r){let m=vr(d),p=m?.repoPath||m?.path;if(p&&t.startsWith(p)){o=d;break}}let i=null,a=null,l=null,u=o?[o]:r;for(let d of u){let m=await M.read(d),p=vr(d);if(m?.currentTask){i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},a={...m.currentTask,duration:await Ca(m.currentTask.startedAt)};break}m?.previousTask&&!l&&(i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},l=m.previousTask)}return e.json({hasActiveTask:!!a,hasPausedTask:!!l,activeProject:i,activeTask:a,pausedTask:l,totalProjects:r.length,filtered:!!o,cwd:t||null,timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.post("/projects/:id/queue",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{description:r,priority:o,type:i,section:a}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"description required (string)"},400);if(r.length>5e3)return e.json({success:!1,error:"description too long (max 5000 chars)"},400);let l=await We.addTask(t,{description:r,priority:o||"medium",type:i||"feature",section:a||"active"});return e.json({success:!0,task:l})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.get("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await We.getTask(t,s);if(!r)return e.json({error:"Task not found"},404);let o=yr.getComments(t,s);return e.json({task:r,comments:o})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await e.req.json().catch(()=>({})),o={};if(r.priority&&typeof r.priority=="string"){if(!["low","medium","high","critical","normal","urgent"].includes(r.priority))return e.json({success:!1,error:"Invalid priority"},400);o.priority=r.priority}if(r.section&&typeof r.section=="string"){if(!["active","backlog","previously_active"].includes(r.section))return e.json({success:!1,error:"Invalid section"},400);o.section=r.section}return typeof r.description=="string"&&(o.description=r.description),typeof r.body=="string"&&(o.body=r.body),typeof r.type=="string"&&(o.type=r.type),Object.keys(o).length>0&&!await We.updateTask(t,s,o)?e.json({success:!1,error:"Task not found"},404):e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{return await We.removeTask(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/queue/:taskId/comments",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await e.req.json(),{content:o,author:i}=r;if(!o?.trim())return e.json({error:"Content required"},400);let a=yr.addComment(t,s,o.trim(),i);return e.json({comment:a})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/queue/:taskId/comments/:commentId",async e=>{let t=e.req.param("id"),s=e.req.param("commentId");try{let r=await e.req.json(),{content:o}=r;return o?.trim()?yr.updateComment(t,s,o.trim())?e.json({success:!0}):e.json({error:"Not found"},404):e.json({error:"Content required"},400)}catch(r){return e.json({error:String(r)},500)}}),n.delete("/projects/:id/queue/:taskId/comments/:commentId",e=>{let t=e.req.param("id"),s=e.req.param("commentId");try{return yr.deleteComment(t,s),e.json({success:!0})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/ideas/:ideaId",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{let r=await e.req.json().catch(()=>({})),{priority:o,tags:i}=r;if(o){if(!["low","medium","high"].includes(o))return e.json({success:!1,error:"Invalid priority"},400);await He.setPriority(t,s,o)}if(i&&Array.isArray(i)){let a=i.filter(l=>typeof l=="string").slice(0,20);a.length>0&&await He.addTags(t,s,a)}return e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id/ideas/:ideaId",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{return await He.removeIdea(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/ideas/:ideaId/archive",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{return await He.archive(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.patch("/projects/:id/task",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),{description:r,type:o,branch:i}=s,a={};return r&&typeof r=="string"&&(a.description=r),o&&typeof o=="string"&&(a.type=o),i&&typeof i=="string"&&(a.branch=i),Object.keys(a).length===0?e.json({success:!1,error:"No valid fields to update"},400):await M.updateCurrentTask(t,a)?e.json({success:!0}):e.json({success:!1,error:"No active task"},400)}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.patch("/projects/:id",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),{name:r,description:o,stack:i,techStack:a,repoPath:l}=s,u=$.getGlobalProjectPath(t),d=Pa.join(u,"project.json"),m={};try{let p=await Ut.readFile(d,"utf-8");m=JSON.parse(p)}catch{m={projectId:t}}return r!==void 0&&(m.name=r),o!==void 0&&(m.description=o),i!==void 0&&(m.stack=i),a!==void 0&&(m.techStack=a),l!==void 0&&(m.repoPath=l),await Ut.mkdir(Pa.dirname(d),{recursive:!0}),await Ut.writeFile(d,JSON.stringify(m,null,2)),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id",async e=>{let t=e.req.param("id");try{C.close(t);let s=$.getGlobalProjectPath(t);return await Ut.rm(s,{recursive:!0,force:!0}),e.json({success:!0})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.get("/projects/:id/workflow-graph",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"workflow-graph");return e.json({edges:s?.edges||[]})}catch{return e.json({edges:[]})}}),n.put("/projects/:id/workflow-graph",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{edges:r}=s;return C.setDoc(t,"workflow-graph",{edges:r||[]}),e.json({success:!0})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.get("/projects/:id/workflows",e=>{let t=e.req.param("id");try{let s=De.getAllWorkflows(t),r=te.getAllRules(t);return e.json({workflows:s,rules:r})}catch{return e.json({workflows:[],rules:[]})}}),n.patch("/projects/:id/workflows/:name",async e=>{let{id:t,name:s}=e.req.param();try{let r=await e.req.json().catch(()=>({})),{enabled:o}=r,i=De.getWorkflow(t,s);return i?(De.updateWorkflow(t,s,{enabled:o??!i.enabled}),e.json({success:!0})):e.json({success:!1,error:"Workflow not found"},404)}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.post("/projects/:id/workflow-rules",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{type:r,command:o,position:i,action:a,description:l,enabled:u,timeoutMs:d}=s,m=te.addRule(t,{type:r,command:o,position:i,action:a,description:l||null,enabled:u??!0,timeoutMs:d??3e4,createdAt:new Date().toISOString(),sortOrder:0});return e.json({success:!0,id:m})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.patch("/projects/:id/workflow-rules/:ruleId",async e=>{let t=e.req.param("id"),s=Number(e.req.param("ruleId"));try{let r=await e.req.json();return te.updateRule(t,s,r),e.json({success:!0})}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.delete("/projects/:id/workflow-rules/:ruleId",e=>{let t=e.req.param("id"),s=Number(e.req.param("ruleId"));try{return te.removeRule(t,s),e.json({success:!0})}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.get("/projects/:id/metrics",async e=>{let t=e.req.param("id");try{let s=await ns.getSummary(t),r=await ns.getDailyStats(t,90);return e.json({...s,dailyStats:r})}catch{return e.json({totalTokensSaved:0,avgCompressionRate:0,syncCount:0,dailyStats:[]})}}),n.get("/projects/:id/velocity",async e=>{let t=e.req.param("id");try{let s=await yo.getMetrics(t);return e.json(s)}catch{return e.json({averageVelocity:0,velocityTrend:"stable",sprints:[]})}}),n.get("/projects/:id/analysis/full",e=>{let t=e.req.param("id");try{let s=mo.getActive(t),r=mo.getHistory(t,10);return e.json({analysis:s,history:r})}catch{return e.json({analysis:null,history:[]})}}),n.get("/projects/:id/index",async e=>{let t=e.req.param("id");try{let s=await Sr.readIndex(t),r=await Sr.readDomains(t),o=await Sr.readScores(t),i=await Sr.readCategories(t);return e.json({index:s,domains:r,scores:o?.slice(0,100),categories:i})}catch{return e.json({index:null,domains:null,scores:[],categories:null})}}),n.get("/projects/:id/archives",e=>{let t=e.req.param("id"),s=e.req.query("type")||void 0,r=Number(e.req.query("limit"))||50;try{let o=rt.getArchived(t,s,r),i=rt.getStats(t);return e.json({items:o,stats:i})}catch{return e.json({items:[],stats:{total:0,byType:{}}})}}),n.get("/projects/:id/context-health",e=>{let t=e.req.param("id");try{let s=ha.getSummary(t,30),r=ha.getTransitions(t,50);return e.json({summary:s,transitions:r})}catch{return e.json({summary:null,transitions:[]})}}),n.get("/projects/:id/context-feedback",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM context_feedback ORDER BY created_at DESC LIMIT 50");return e.json({feedback:s})}catch{return e.json({feedback:[]})}}),n.get("/projects/:id/state/full",async e=>{let t=e.req.param("id");try{let s=await M.read(t);return e.json(s)}catch{return e.json({currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""})}}),n.get("/projects/:id/events",e=>{let t=e.req.param("id"),s=Number(e.req.query("limit"))||100,r=Number(e.req.query("offset"))||0,o=e.req.query("type")||void 0;try{let i=o?C.query(t,"SELECT * FROM events WHERE type = ? ORDER BY timestamp DESC LIMIT ? OFFSET ?",o,s,r):C.query(t,"SELECT * FROM events ORDER BY timestamp DESC LIMIT ? OFFSET ?",s,r),a=C.get(t,"SELECT COUNT(*) as c FROM events");return e.json({events:i,total:a?.c||0,limit:s,offset:r})}catch{return e.json({events:[],total:0})}}),n.get("/projects/:id/memory",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM memory ORDER BY updated_at DESC LIMIT 200");return e.json({items:s})}catch{return e.json({items:[]})}}),n.get("/projects/:id/sessions",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM sessions ORDER BY started_at DESC LIMIT 50"),r=C.query(t,"SELECT * FROM agent_sessions ORDER BY started_at DESC LIMIT 50");return e.json({sessions:s,agentSessions:r})}catch{return e.json({sessions:[],agentSessions:[]})}}),n.get("/projects/:id/tasks",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM tasks ORDER BY started_at DESC LIMIT 100"),r=C.query(t,"SELECT * FROM subtasks ORDER BY sort_order ASC");return e.json({tasks:s,subtasks:r})}catch{return e.json({tasks:[],subtasks:[]})}}),n.get("/projects/:id/kv",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT key, value FROM kv_store ORDER BY key"),r={};for(let o of s)try{r[o.key]=JSON.parse(o.value)}catch{r[o.key]=o.value}return e.json(r)}catch{return e.json({})}}),n.get("/projects/:id/issues",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"issues");return e.json({issues:s?.issues||[]})}catch{return e.json({issues:[]})}}),n.get("/projects/:id/roadmap",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"roadmap");return e.json(s||{features:[],backlog:[]})}catch{return e.json({features:[],backlog:[]})}}),n.get("/projects/:id/config",async e=>{let t=e.req.param("id");try{let s=vr(t);return e.json(s||{projectId:t})}catch{return e.json({projectId:t})}}),n}var Ky,Sn,id=h(()=>{"use strict";Pe();hs();qu();Bu();uo();de();gr();Yu();wn();ho();fr();Us();lt();ba();kn();Ky=$.getGlobalBasePath(),Sn=Pa.join(Ky,"projects");c(vr,"getProjectConfig");c(Ca,"calculateDuration");c(od,"createExtendedRoutes")});import{streamSSE as Yy}from"hono/streaming";function cd(){let n=new Map,e=null;function t(o){let i=n.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),n.delete(o))}c(t,"removeClient");function s(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of n)o-new Date(a.client.connectedAt).getTime()>ad&&t(i)},Qy),e&&typeof e=="object"&&"unref"in e&&e.unref())}c(s,"startReaper");function r(){e&&(clearInterval(e),e=null)}return c(r,"stopReaper"),s(),{handleConnection(o){return Yy(o,async i=>{let a=crypto.randomUUID(),l=new Date().toISOString(),u=new AbortController,d={id:a,connectedAt:l,send:c((g,y)=>{i.writeSSE({event:g,data:JSON.stringify(y)})},"send"),close:c(()=>{t(a)},"close")},m=setInterval(async()=>{try{await i.writeSSE({event:"heartbeat",data:JSON.stringify({timestamp:new Date().toISOString()})})}catch{t(a)}},Zy),p=setTimeout(()=>{t(a)},ad);typeof m=="object"&&"unref"in m&&m.unref(),typeof p=="object"&&"unref"in p&&p.unref(),n.set(a,{client:d,heartbeatInterval:m,ttlTimeout:p,abortController:u}),await i.writeSSE({event:"connected",data:JSON.stringify({clientId:a,timestamp:l,message:"Connected to prjct-cli server"})}),i.onAbort(()=>{t(a)}),await new Promise(g=>{u.signal.addEventListener("abort",()=>g(),{once:!0})})})},broadcast(o,i){let a={event:o,data:i,timestamp:new Date().toISOString()};for(let[l,u]of n)try{u.client.send(o,a)}catch{t(l)}},getClientCount(){return n.size},shutdown(){r();for(let o of[...n.keys()])t(o)}}}var ad,Qy,Zy,ld=h(()=>{"use strict";ad=60*60*1e3,Qy=5*60*1e3,Zy=3e4;c(cd,"createSSEManager")});var ud={};G(ud,{DEFAULT_PORT:()=>ko,createServer:()=>wo,startServer:()=>rw});import ja from"node:fs";import Ss from"node:path";import{Hono as ew}from"hono";import{cors as tw}from"hono/cors";import{logger as sw}from"hono/logger";import{secureHeaders as nw}from"hono/secure-headers";function wo(n){let e=new ew,t=cd();e.use("*",nw()),n.enableCors!==!1&&e.use("*",tw({origin:c(l=>{if(!l)return l;try{let u=new URL(l);return u.hostname==="localhost"||u.hostname==="127.0.0.1"?l:null}catch{return null}},"origin"),allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type"]})),n.enableLogging!==!1&&e.use("*",sw()),e.get("/health",l=>l.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/api",l=>l.json({name:"prjct-cli",version:ce,projectId:n.projectId,endpoints:{health:"/health",state:"/api/state",queue:"/api/queue",ideas:"/api/ideas",roadmap:"/api/roadmap",shipped:"/api/shipped",events:"/api/events",projects:"/api/projects",projectFull:"/api/projects/:id/full",statusBarCompact:"/api/status-bar/compact",globalStats:"/api/stats/global"}}));let s=Gu(n.projectId,n.projectPath);e.route("/api",s);let r=od();e.route("/api",r),e.get("/api/events",l=>t.handleConnection(l));let i=[Ss.resolve(__dirname,"..","dist","web"),Ss.resolve(__dirname,"..","..","dist","web"),Ss.resolve(process.cwd(),"dist","web"),Ss.resolve(__dirname,"..","web")].find(l=>ja.existsSync(Ss.join(l,"index.html")))||null;if(i){let l={".html":"text/html",".js":"application/javascript",".css":"text/css",".json":"application/json",".svg":"image/svg+xml",".png":"image/png",".ico":"image/x-icon",".woff2":"font/woff2"};e.get("/assets/*",async u=>{let d=Ss.join(i,u.req.path);try{let m=ja.readFileSync(d),p=Ss.extname(d);return new Response(m,{headers:{"Content-Type":l[p]||"application/octet-stream","Cache-Control":"public, max-age=31536000, immutable"}})}catch{return u.notFound()}}),e.get("*",u=>{if(u.req.path.startsWith("/api"))return u.notFound();try{let d=ja.readFileSync(Ss.join(i,"index.html"),"utf-8");return u.html(d)}catch{return u.json({error:"Dashboard not built. Run: cd web && bun run build"},404)}})}let a=null;return{app:e,async start(){let l=n.port,u=n.host||"0.0.0.0";if(Ms())a=Bun.serve({port:l,hostname:u,fetch:e.fetch});else{let{serve:d}=await import("@hono/node-server"),m=d({fetch:e.fetch,port:l,hostname:u});a={stop:c(()=>m.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${u}:${l}`),console.log(` Project: ${n.projectId}`),console.log(` Runtime: ${Ms()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${l}`)},stop(){t.shutdown(),a&&(a.stop(),a=null,console.log("Server stopped"))},broadcast(l,u){t.broadcast(l,u)}}}async function rw(n,e,t=ko){let s=wo({port:t,projectId:n,projectPath:e});return await s.start(),s}var ko,xa=h(()=>{"use strict";ir();qe();Vu();id();ld();c(wo,"createServer");ko=3478;c(rw,"startServer")});import Ws from"chalk";var dd,ow,iw,xt,pd=h(()=>{"use strict";Ve();dd=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],ow=80,iw={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:dd,speed:ow},cli:{header:c(()=>`${Ws.cyan.bold("\u26A1")} ${Ws.cyan("prjct")}`,"header"),footer:c(()=>Ws.dim("\u26A1 prjct"),"footer"),spin:c((n,e)=>`${Ws.cyan("\u26A1")} ${Ws.cyan("prjct")} ${Ws.cyan(dd[n%10])} ${Ws.dim(e||"")}`,"spin")},template:{header:"\u26A1 prjct",footer:"\u26A1 prjct"},commitFooter:"Generated with [p/](https://www.prjct.app/)",urls:{website:"https://prjct.app",docs:"https://prjct.app/docs"},getCommitFooter:c((n="claude")=>Qr(n).commitFooter,"getCommitFooter"),getSignature:c((n="claude")=>Qr(n).signature,"getSignature")},xt=iw});function vn(n){let e=`PRJCT_TIMEOUT_${n}`,t=process.env[e];if(t){let s=Number.parseInt(t,10);if(!Number.isNaN(s)&&s>0)return s}return aw[n]}var aw,vt,So=h(()=>{"use strict";aw={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};c(vn,"getTimeout");vt={SPINNER_MSG:45,DONE_MSG:50,FAIL_MSG:65,WARN_MSG:65,STEP_MSG:35,PROGRESS_TEXT:25,ISSUE_TITLE:50,FALLBACK_TRUNCATE:50,CLEAR_WIDTH:80}});var md,gd=h(()=>{"use strict";md={NO_PROJECT:{message:"No prjct project found in this directory",hint:"Run 'prjct init' to set up a new project",file:".prjct/prjct.config.json"},NO_PROJECT_ID:{message:"Project ID not found",hint:"Run 'prjct init' or check .prjct/prjct.config.json",file:".prjct/prjct.config.json"},CONFIG_NOT_FOUND:{message:"Configuration file not found",hint:"Run 'prjct init' to create project configuration",file:".prjct/prjct.config.json"},CONFIG_INVALID:{message:"Invalid configuration file",hint:"Check JSON syntax or delete .prjct/ and run init again",file:".prjct/prjct.config.json"},GIT_NOT_FOUND:{message:"Git repository not detected",hint:"Run 'git init' first, then 'prjct init'"},GIT_NO_COMMITS:{message:"No commits in repository",hint:"Make an initial commit before using prjct"},GIT_DIRTY:{message:"Working directory has uncommitted changes",hint:"Commit or stash changes, or use '--force' to override"},GIT_ON_MAIN:{message:"Cannot ship from main/master branch",hint:"Create a feature branch first: git checkout -b feature/your-feature"},GIT_OPERATION_FAILED:{message:"Git operation failed",hint:"Check git status and resolve any conflicts"},GH_NOT_AUTHENTICATED:{message:"GitHub CLI not authenticated",hint:"Run 'gh auth login' to authenticate",docs:"https://cli.github.com/manual/gh_auth_login"},LINEAR_NOT_CONFIGURED:{message:"Linear integration not configured",hint:"Run 'prjct linear setup' to configure Linear MCP"},LINEAR_API_ERROR:{message:"Linear API error",hint:"Check your API key or network connection"},NO_ACTIVE_TASK:{message:"No active task",hint:`Start a task with 'p. task "description"'`},TASK_ALREADY_ACTIVE:{message:"A task is already in progress",hint:"Complete it with 'p. done' or pause with 'p. pause'"},SYNC_FAILED:{message:"Project sync failed",hint:"Check file permissions and try again"},NOTHING_TO_SHIP:{message:"Nothing to ship",hint:"Make some changes first, then run ship"},PR_CREATE_FAILED:{message:"Failed to create pull request",hint:"Check GitHub auth and remote configuration"},NO_AI_PROVIDER:{message:"No AI provider detected",hint:"Install Claude Code or Gemini CLI, then run 'prjct start'",docs:"https://prjct.app/docs"},PROVIDER_NOT_CONFIGURED:{message:"AI provider not configured for prjct",hint:"Run 'prjct start' to configure your provider"},UNKNOWN_COMMAND:{message:"Unknown command",hint:"Run 'prjct --help' to see available commands"},MISSING_PARAM:{message:"Missing required parameter",hint:"Check command usage below"},UNKNOWN:{message:"An unexpected error occurred",hint:"Check the error details and try again"}}});function br(n,e){return{...md[n],...e}}function vo(n,e,t){return{message:n,hint:e,...t}}var bo=h(()=>{"use strict";gd();c(br,"getError");c(vo,"createError")});var hd={};G(hd,{ICONS:()=>vs,OUTPUT_TIERS:()=>fd,default:()=>f,formatForHuman:()=>pw,getOutputTier:()=>lw,getTierConfig:()=>Eo,isQuietMode:()=>dw,limitLines:()=>To,setOutputTier:()=>cw,setQuietMode:()=>uw});import ne from"chalk";function cw(n){Tn=n}function lw(){return Tn}function Eo(){return fd[Tn]}function uw(n){ot=n}function dw(){return ot}function To(n,e){let t=e??Eo().maxLines;if(t===1/0||t===0)return n;let s=n.split(`
|
|
505
505
|
`);if(s.length<=t)return n;let r=s.slice(0,t),o=s.length-t;return`${r.join(`
|
|
506
506
|
`)}
|
|
507
507
|
${ne.dim(`...${o} more lines`)}`}function pw(n){let e=Eo();if(Tn==="silent")return"";if(Tn==="verbose")return JSON.stringify(n,null,2);if(typeof n!="object"||n===null)return bt(String(n),e.maxCharsPerLine);let t=n;if("identifier"in t&&"title"in t){let o=[];return o.push(`${t.identifier}: ${bt(String(t.title),e.maxCharsPerLine-10)}`),t.status&&o.push(`Status: ${t.status}`),t.priority&&t.priority!=="none"&&o.push(`Priority: ${t.priority}`),t.url&&Tn==="compact"&&o.push(ne.dim(String(t.url))),To(o.join(`
|
|
508
508
|
`),e.maxLines)}if("issues"in t&&Array.isArray(t.issues)){let o=t.issues,i=o.slice(0,e.maxLines).map(a=>{let l=a.priority&&a.priority!=="none"?` [${a.priority}]`:"";return`${a.identifier} ${bt(String(a.title),vt.ISSUE_TITLE)}${l}`});return o.length>e.maxLines&&i.push(ne.dim(`...${o.length-e.maxLines} more`)),i.join(`
|
|
509
509
|
`)}let r=["id","name","title","status","message","success","error"].filter(o=>o in t);return r.length>0?To(r.map(o=>`${o}: ${bt(String(t[o]),e.maxCharsPerLine-o.length-2)}`).join(`
|
|
510
|
-
`),e.maxLines):To(JSON.stringify(n,null,2),e.maxLines)}var
|
|
510
|
+
`),e.maxLines):To(JSON.stringify(n,null,2),e.maxLines)}var RR,Ra,fd,Tn,vs,bn,Aa,ot,bt,mw,gw,f,Le=h(()=>{"use strict";pd();So();bo();RR=xt.spinner.frames,Ra=xt.spinner.speed,fd={silent:{maxLines:0,maxCharsPerLine:0,showMetrics:!1},minimal:{maxLines:1,maxCharsPerLine:65,showMetrics:!1},compact:{maxLines:4,maxCharsPerLine:80,showMetrics:!0},verbose:{maxLines:1/0,maxCharsPerLine:1/0,showMetrics:!0}},Tn="compact";c(cw,"setOutputTier");c(lw,"getOutputTier");c(Eo,"getTierConfig");vs={success:ne.green("\u2713"),fail:ne.red("\u2717"),warn:ne.yellow("\u26A0"),info:ne.blue("\u2139"),debug:ne.dim("\u{1F527}"),bullet:ne.dim("\u2022"),arrow:ne.dim("\u2192"),check:ne.green("\u2713"),cross:ne.red("\u2717"),spinner:ne.cyan("\u25D0")},bn=null,Aa=0,ot=!1;c(uw,"setQuietMode");c(dw,"isQuietMode");bt=c((n,e)=>{let t=e??(Eo().maxCharsPerLine||vt.FALLBACK_TRUNCATE);return n&&n.length>t?`${n.slice(0,t-1)}\u2026`:n||""},"truncate");c(To,"limitLines");c(pw,"formatForHuman");mw=c(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(vt.CLEAR_WIDTH)}\r`):!0,"clear"),gw={start(){return ot||console.log(xt.cli.header()),this},end(){return ot||console.log(xt.cli.footer()),this},spin(n){return ot?this:(this.stop(),process.stdout.isTTY?(bn=setInterval(()=>{process.stdout.write(`\r${xt.cli.spin(Aa++,bt(n,vt.SPINNER_MSG))}`)},Ra),this):(process.stdout.write(`${xt.cli.spin(0,bt(n,vt.SPINNER_MSG))}
|
|
511
511
|
`),this))},done(n,e){if(this.stop(),!ot){let t="";if(e){let s=[];e.agents!==void 0&&s.push(`${e.agents}a`),e.reduction!==void 0&&s.push(`${e.reduction}%`),e.tokens!==void 0&&s.push(`${Math.round(e.tokens)}K`),s.length>0&&(t=ne.dim(` [${s.join(" | ")}]`))}console.log(`${vs.success} ${bt(n,vt.DONE_MSG)}${t}`)}return this},fail(n){return this.stop(),console.error(`${vs.fail} ${bt(n,vt.FAIL_MSG)}`),this},failWithHint(n){this.stop();let e=typeof n=="string"?br(n):n;return console.error(),console.error(`${vs.fail} ${e.message}`),e.file&&console.error(ne.dim(` File: ${e.file}`)),e.hint&&console.error(ne.yellow(` \u{1F4A1} ${e.hint}`)),e.docs&&console.error(ne.dim(` Docs: ${e.docs}`)),console.error(),this},warn(n){return this.stop(),ot||console.log(`${vs.warn} ${bt(n,vt.WARN_MSG)}`),this},info(n){return this.stop(),ot||console.log(`${vs.info} ${n}`),this},debug(n){this.stop();let e=process.env.DEBUG==="1"||process.env.DEBUG==="true";return!ot&&e&&console.log(`${vs.debug} ${ne.dim(n)}`),this},success(n,e){return this.done(n,e)},list(n,e={}){if(this.stop(),ot)return this;let t=e.bullet||vs.bullet,s=" ".repeat(e.indent||0);for(let r of n)console.log(`${s}${t} ${r}`);return this},table(n,e={}){if(this.stop(),ot||n.length===0)return this;let t=Object.keys(n[0]),s={};for(let r of t){s[r]=r.length;for(let o of n){let i=String(o[r]??"");i.length>s[r]&&(s[r]=i.length)}}if(e.header!==!1){let r=t.map(o=>o.padEnd(s[o])).join(" ");console.log(ne.dim(r)),console.log(ne.dim("\u2500".repeat(r.length)))}for(let r of n){let o=t.map(i=>String(r[i]??"").padEnd(s[i])).join(" ");console.log(o)}return this},box(n,e){if(this.stop(),ot)return this;let t=e.split(`
|
|
512
512
|
`),s=Math.max(n.length,...t.map(o=>o.length)),r="\u2500".repeat(s+2);console.log(ne.dim(`\u250C${r}\u2510`)),console.log(`${ne.dim("\u2502")} ${ne.bold(n.padEnd(s))} ${ne.dim("\u2502")}`),console.log(ne.dim(`\u251C${r}\u2524`));for(let o of t)console.log(`${ne.dim("\u2502")} ${o.padEnd(s)} ${ne.dim("\u2502")}`);return console.log(ne.dim(`\u2514${r}\u2518`)),this},section(n){return this.stop(),ot?this:(console.log(`
|
|
513
513
|
${ne.bold(n)}`),console.log(ne.dim("\u2500".repeat(n.length))),this)},stop(){return bn&&(clearInterval(bn),bn=null,mw()),this},step(n,e,t){if(ot)return this;this.stop();let s=ne.dim(`[${n}/${e}]`);return process.stdout.isTTY?(bn=setInterval(()=>{process.stdout.write(`\r${xt.cli.spin(Aa++,`${s} ${bt(t,vt.STEP_MSG)}`)}`)},Ra),this):(process.stdout.write(`${xt.cli.spin(0,`${s} ${bt(t,vt.STEP_MSG)}`)}
|
|
@@ -524,7 +524,7 @@ ${e}`,action:"appended"};let o=n.substring(0,n.indexOf(t)),i=n.substring(n.index
|
|
|
524
524
|
|
|
525
525
|
No changes between runs.`;let e=[];e.push("## Analysis Diff"),(n.beforeCommit||n.afterCommit)&&e.push(`> \`${n.beforeCommit?.substring(0,7)??"(none)"}\` \u2192 \`${n.afterCommit?.substring(0,7)??"(none)"}\``),e.push(""),e.push("| Change | Field | Detail |"),e.push("|--------|-------|--------|");for(let s of n.items){let r=s.type==="added"?"+":s.type==="removed"?"-":"~",o=s.type==="changed"?`${s.before} \u2192 ${s.after}`:s.after??s.before??"";e.push(`| ${r} | ${s.field} | ${o} |`)}e.push("");let t=[];return n.summary.added>0&&t.push(`${n.summary.added} added`),n.summary.removed>0&&t.push(`${n.summary.removed} removed`),n.summary.changed>0&&t.push(`${n.summary.changed} changed`),e.push(`**Summary**: ${t.join(", ")}`),e.join(`
|
|
526
526
|
`)}function Id(n){if(!n.hasChanges)return"No changes between analysis runs.";let e=[];(n.beforeCommit||n.afterCommit)&&(e.push(` ${n.beforeCommit?.substring(0,7)??"(none)"} \u2192 ${n.afterCommit?.substring(0,7)??"(none)"}`),e.push(""));for(let t of n.items)t.type==="added"?e.push(` + ${t.field}: ${t.after}`):t.type==="removed"?e.push(` - ${t.field}: ${t.before}`):e.push(` ~ ${t.field}: ${t.before} \u2192 ${t.after}`);return e.join(`
|
|
527
|
-
`)}function Er(n,e,t,s){let r=new Set(e),o=new Set(t);for(let i of t)r.has(i)||s.push({field:n,type:"added",after:i});for(let i of e)o.has(i)||s.push({field:n,type:"removed",before:i})}var Ga=h(()=>{"use strict";c(Ad,"generateAnalysisDiff");c(Wa,"formatAnalysisDiffMd");c(Id,"formatAnalysisDiffText");c(Er,"diffStringArray")});var Va=h(()=>{"use strict"});import xw from"node:fs/promises";import Rw from"node:path";function Pn(n){return n.replace(/([a-z])([A-Z])/g,"$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g,"$1 $2").replace(/[-_./]/g," ").toLowerCase().split(/\s+/).filter(e=>e.length>1)}function Aw(n,e){let t=[],s=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let p of s)t.push(...Pn(p));let r=[/export\s+(?:async\s+)?function\s+(\w+)/g,/export\s+class\s+(\w+)/g,/export\s+interface\s+(\w+)/g,/export\s+type\s+(\w+)/g,/export\s+(?:const|let|var)\s+(\w+)/g,/export\s+default\s+(?:class|function)\s+(\w+)/g];for(let p of r){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Pn(g[1]))}let o=[/(?:async\s+)?function\s+(\w+)/g,/class\s+(\w+)/g,/interface\s+(\w+)/g,/type\s+(\w+)\s*=/g];for(let p of o){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Pn(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(n))!==null;){let p=a[1];if(p.startsWith(".")||p.startsWith("@/"))t.push(...Pn(p));else{let g=p.startsWith("@")?p.split("/").slice(0,2).join("/"):p.split("/")[0];t.push(...Pn(g))}}let l=/\/\/\s*(.+)/g,u;for(;(u=l.exec(n))!==null;){let p=u[1].toLowerCase().split(/\s+/).filter(g=>g.length>2);t.push(...p)}let d=/\/\*\*?([\s\S]*?)\*\//g,m;for(;(m=d.exec(n))!==null;){let p=m[1].replace(/@\w+/g,"").replace(/\*/g,"").toLowerCase().split(/\s+/).filter(g=>g.length>2&&/^[a-z]+$/.test(g));t.push(...p)}return t.filter(p=>p.length>1&&!Md.has(p)&&/^[a-z][a-z0-9]*$/.test(p))}function Iw(n){return n.split(/\s+/).flatMap(e=>Pn(e)).filter(e=>e.length>1&&!Md.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function $w(n){let e=await Ns(n),t={},s={},r=0,o=await Os(e,50,async a=>{try{let l=await xw.readFile(Rw.join(n,a),"utf-8"),u=Aw(l,a);return u.length>0?{filePath:a,tokens:u}:null}catch{return null}});for(let{filePath:a,tokens:l}of o){t[a]={tokens:l,length:l.length},r+=l.length;let u=new Map;for(let d of l)u.set(d,(u.get(d)||0)+1);for(let[d,m]of u)s[d]||(s[d]=[]),s[d].push({path:a,tf:m})}let i=Object.keys(t).length;return{documents:t,invertedIndex:s,avgDocLength:i>0?r/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function Dw(n,e){return Math.log((e-n+.5)/(n+.5)+1)}function Mw(n,e){let t=Iw(n);if(t.length===0)return[];let s=new Map;for(let r of t){let o=e.invertedIndex[r];if(!o)continue;let i=Dw(o.length,e.totalDocs);for(let{path:a,tf:l}of o){let u=e.documents[a];if(!u)continue;let d=l*(1.2+1),m=l+1.2*(1-.75+.75*(u.length/e.avgDocLength)),p=i*(d/m);s.set(a,(s.get(a)||0)+p)}}return Array.from(s.entries()).map(([r,o])=>({path:r,score:o})).sort((r,o)=>o.score-r.score)}function Nw(n,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([s,r])=>[s,r.length]))};L.setDoc(n,Nd,t)}function Ro(n){let e=L.getDoc(n,Nd);if(!e)return null;let t={};for(let[s,r]of Object.entries(e.docLengths))t[s]={tokens:[],length:r};return{documents:t,invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt}}async function Od(n,e){let t=await $w(n);return Nw(e,t),t}function _d(n,e,t=15){let s=Ro(n);return s?Mw(e,s).slice(0,t):[]}var Md,Nd,qa=h(()=>{"use strict";Va();de();z();Md=new Set(["the","a","an","is","are","was","were","be","been","being","have","has","had","do","does","did","will","would","could","should","may","might","shall","can","of","in","to","for","with","on","at","from","by","as","or","and","but","if","not","no","so","up","out","this","that","it","its","all","any","import","export","default","const","let","var","function","class","interface","type","return","new","true","false","null","undefined","void","async","await","static","public","private","protected","readonly","string","number","boolean","object","array"]);c(Pn,"splitIdentifier");c(Aw,"tokenizeFile");c(Iw,"tokenizeQuery");c($w,"buildIndex");c(Dw,"idf");c(Mw,"score");Nd="bm25-index";c(Nw,"saveIndex");c(Ro,"loadIndex");c(Od,"indexProject");c(_d,"queryFiles")});import Ba from"node:fs/promises";import Ts from"node:path";import{z as X}from"zod";async function Uw(n,e){let t=Date.now();if(n.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let s=Ts.join(e,"package.json"),r=await Ba.readFile(s,"utf-8"),o=JSON.parse(r),i={...o.dependencies,...o.devDependencies},a=[],l=[];for(let u of n.frameworks){let d=u.toLowerCase();Object.keys(i).some(p=>p.toLowerCase().includes(d))?l.push(u):a.push(u)}return a.length===0?{name:"Framework verification",passed:!0,output:`${l.length} framework(s) verified in dependencies`,durationMs:Date.now()-t}:{name:"Framework verification",passed:!1,error:`Frameworks not found in dependencies: ${a.join(", ")}`,durationMs:Date.now()-t}}catch(s){return D(s)?{name:"Framework verification",passed:!1,error:"package.json not found (cannot verify frameworks)",durationMs:Date.now()-t}:{name:"Framework verification",passed:!1,error:`Failed to read package.json: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Hw(n,e){let t=Date.now();if(n.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let s=await qw(e),r=new Set(s),o=[],i=[];for(let a of n.languages){let l=Fw[a];if(!l)continue;l.some(d=>r.has(d))?o.push(a):i.push(a)}return i.length===0?{name:"Language verification",passed:!0,output:`${o.length} language(s) verified with matching files`,durationMs:Date.now()-t}:{name:"Language verification",passed:!1,error:`Languages without matching files: ${i.join(", ")}`,durationMs:Date.now()-t}}catch(s){return{name:"Language verification",passed:!1,error:`Failed to scan project files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Ww(n,e){let t=Date.now(),s=n.patterns.filter(i=>i.location);if(s.length===0)return{name:"Pattern location verification",passed:!0,output:"No pattern locations specified (skipped)",durationMs:Date.now()-t};let r=[],o=[];for(let i of s){let a=i.location,l=Ts.join(e,a);await v(l)?o.push(a):r.push(`${i.name} (${a})`)}return r.length===0?{name:"Pattern location verification",passed:!0,output:`${o.length} pattern location(s) verified`,durationMs:Date.now()-t}:{name:"Pattern location verification",passed:!1,error:`Pattern locations not found: ${r.join(", ")}`,durationMs:Date.now()-t}}async function Gw(n,e){let t=Date.now();try{let s=await Bw(e),r=n.fileCount,o=.1,i=Math.abs(s-r),a=r*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${r}, actual: ${s})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${r}, actual ${s} (diff: ${i})`,durationMs:Date.now()-t}}catch(s){return{name:"File count verification",passed:!1,error:`Failed to count files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Vw(n,e){let t=Date.now();if(n.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let s=[],r=[];for(let o of n.antiPatterns){let i=Ts.join(e,o.file);await v(i)?r.push(o.file):s.push(`${o.issue} (${o.file})`)}return s.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${r.length} anti-pattern file(s) verified`,durationMs:Date.now()-t}:{name:"Anti-pattern file verification",passed:!1,error:`Anti-pattern files not found: ${s.join(", ")}`,durationMs:Date.now()-t}}async function Ld(n,e){let t=Date.now(),s=await Promise.all([Uw(n,e),Hw(n,e),Ww(n,e),Gw(n,e),Vw(n,e)]),r=s.filter(i=>!i.passed).length,o=s.filter(i=>i.passed).length;return{passed:r===0,checks:s,totalMs:Date.now()-t,failedCount:r,passedCount:o}}async function qw(n){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Ba.readdir(r,{withFileTypes:!0});for(let i of o){let a=Ts.join(r,i.name),l=Ts.relative(n,a);if(!t.some(u=>u.test(l))){if(i.isDirectory())await s(a);else if(i.isFile()){let u=Ts.extname(i.name);u&&e.add(u)}}}}catch{}}return c(s,"scanDir"),await s(n),Array.from(e)}async function Bw(n){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Ba.readdir(r,{withFileTypes:!0});for(let i of o){let a=Ts.join(r,i.name),l=Ts.relative(n,a);t.some(u=>u.test(l))||(i.isDirectory()?await s(a):i.isFile()&&e++)}}catch{}}return c(s,"scanDir"),await s(n),e}var Ow,_w,Lw,Ja,jA,Fw,Fd=h(()=>{"use strict";q();z();zr();Ow=X.enum(["draft","verified","sealed"]),_w=X.object({name:X.string(),description:X.string(),location:X.string().optional(),severity:X.enum(["low","medium","high"]).optional(),language:X.string().optional(),framework:X.string().optional(),source:X.enum(["baseline","repo","context7","feedback"]).optional(),confidence:X.number().min(0).max(1).optional()}),Lw=X.object({issue:X.string(),file:X.string(),suggestion:X.string(),severity:X.enum(["low","medium","high"]).optional(),language:X.string().optional(),framework:X.string().optional(),source:X.enum(["baseline","repo","context7","feedback"]).optional(),confidence:X.number().min(0).max(1).optional()}),Ja=X.object({projectId:X.string(),languages:X.array(X.string()),frameworks:X.array(X.string()),packageManager:X.string().optional(),sourceDir:X.string().optional(),testDir:X.string().optional(),configFiles:X.array(X.string()),fileCount:X.number(),patterns:X.array(_w),antiPatterns:X.array(Lw),analyzedAt:X.string(),modelMetadata:on.optional(),status:Ow.default("draft"),commitHash:X.string().optional(),signature:X.string().optional(),sealedAt:X.string().optional(),verifiedAt:X.string().optional()}),jA={languages:[],frameworks:[],configFiles:[],fileCount:0,patterns:[],antiPatterns:[],analyzedAt:new Date().toISOString(),status:"draft"},Fw={TypeScript:[".ts",".tsx",".mts",".cts"],JavaScript:[".js",".jsx",".mjs",".cjs"],Python:[".py",".pyw"],Java:[".java"],Go:[".go"],Rust:[".rs"],Ruby:[".rb"],PHP:[".php"],Swift:[".swift"],Kotlin:[".kt",".kts"],"C++":[".cpp",".cc",".cxx",".hpp",".h"],C:[".c",".h"],"C#":[".cs"],Elixir:[".ex",".exs"],Scala:[".scala"]};c(Uw,"verifyFrameworks");c(Hw,"verifyLanguages");c(Ww,"verifyPatternLocations");c(Gw,"verifyFileCount");c(Vw,"verifyAntiPatternFiles");c(Ld,"semanticVerify");c(qw,"getProjectExtensions");c(Bw,"countProjectFiles")});var za,it,Cr=h(()=>{"use strict";Fd();Ga();Ce();kr();ws();za=class extends Ye{static{c(this,"AnalysisStorage")}constructor(){super("analysis.json")}getDefault(){return{draft:null,sealed:null,previousSealed:null,lastUpdated:""}}getEventType(e){return`analysis.${e}d`}async saveDraft(e,t){let s={...t,status:"draft"};Ja.parse(s),await this.update(e,r=>({...r,draft:s,lastUpdated:x()})),await this.publishEntityEvent(e,"analysis","drafted",{commitHash:s.commitHash,fileCount:s.fileCount})}async seal(e){let t=await this.read(e);if(!t.draft)return{success:!1,error:"No draft analysis to seal. Run `p. sync` first."};if(t.draft.status==="sealed")return{success:!1,error:"Draft is already sealed."};let s=this.computeSignature(t.draft),r=x(),o={...t.draft,status:"sealed",signature:s,sealedAt:r};return Ja.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:r}),await this.publishEntityEvent(e,"analysis","sealed",{commitHash:o.commitHash,signature:s}),{success:!0,signature:s}}async getSealed(e){return(await this.read(e)).sealed}async getDraft(e){return(await this.read(e)).draft}async getActive(e){let t=await this.read(e);return t.sealed??t.draft}async getStatus(e){let t=await this.read(e);return{hasSealed:t.sealed!==null,hasDraft:t.draft!==null,hasPreviousSealed:t.previousSealed!==null,sealedCommit:t.sealed?.commitHash??null,draftCommit:t.draft?.commitHash??null,previousSealedCommit:t.previousSealed?.commitHash??null,sealedAt:t.sealed?.sealedAt??null}}async rollback(e){let t=await this.read(e);if(!t.previousSealed)return{success:!1,error:"No previous sealed version to rollback to."};let s=x();return await this.write(e,{draft:t.sealed,sealed:t.previousSealed,previousSealed:null,lastUpdated:s}),await this.publishEntityEvent(e,"analysis","rolled_back",{restoredCommit:t.previousSealed.commitHash,restoredSignature:t.previousSealed.signature}),{success:!0,restoredSignature:t.previousSealed.signature}}async diff(e){let t=await this.read(e);return!t.sealed||!t.draft?null:Ad(t.sealed,t.draft)}checkStaleness(e,t){return e?t?e!==t?{isStale:!0,sealedCommit:e,currentCommit:t,message:`Analysis is stale: sealed at ${e}, HEAD is ${t}. Run \`p. sync\` + \`p. seal\` to update.`}:{isStale:!1,sealedCommit:e,currentCommit:t,message:"Analysis is current."}:{isStale:!0,sealedCommit:e,currentCommit:null,message:"Cannot determine current commit. Analysis may be stale."}:{isStale:!1,sealedCommit:null,currentCommit:t,message:"No sealed analysis. Run `p. sync` then `p. seal`."}}async verify(e){let t=await this.read(e);if(!t.sealed)return{valid:!1,message:"No sealed analysis to verify."};if(!t.sealed.signature)return{valid:!1,message:"Sealed analysis has no signature."};let s=this.computeSignature({...t.sealed,signature:void 0,sealedAt:void 0});return s===t.sealed.signature?{valid:!0,message:"Signature verified. Analysis integrity confirmed."}:{valid:!1,message:`Signature mismatch. Expected ${s}, got ${t.sealed.signature}. Analysis may have been modified.`}}async semanticVerify(e,t){let s=await this.read(e),r=s.sealed??s.draft;return r?await Ld(r,t):{passed:!1,checks:[{name:"Analysis availability",passed:!1,error:"No analysis available. Run `p. sync` to generate.",durationMs:0}],totalMs:0,failedCount:1,passedCount:0}}computeSignature(e){let t={projectId:e.projectId,languages:e.languages,frameworks:e.frameworks,packageManager:e.packageManager,sourceDir:e.sourceDir,testDir:e.testDir,configFiles:e.configFiles,fileCount:e.fileCount,patterns:e.patterns,antiPatterns:e.antiPatterns,analyzedAt:e.analyzedAt,commitHash:e.commitHash};return wr(JSON.stringify(t))}},it=new za});import Ud from"node:fs/promises";import Hd from"node:path";async function Ka(n,e,t,s){let[r,o,i,a]=await Promise.all([Xw(n,e,s),Kw(n),Yw(n),Qw(n)]);return{project:{name:s.name,ecosystem:s.ecosystem,languages:s.languages,frameworks:s.frameworks,fileCount:s.fileCount,projectType:s.projectType},git:{branch:t.branch,recentCommits:t.recentCommits.slice(0,Jw).map(l=>({message:l.message,date:l.date})),hasChanges:t.hasChanges,weeklyCommits:t.weeklyCommits},codeSamples:r,existingPatterns:o,taskHistory:i,previousAnalysis:a??void 0}}async function Xw(n,e,t){let s=[],r=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=_d(n,r,Xa*2);for(let a of o){if(s.length>=Xa)break;try{let l=Hd.join(e,a.path),u=await Ud.readFile(l,"utf-8");u.length>Ao*3?s.push({path:a.path,content:`${u.slice(0,Ao)}
|
|
527
|
+
`)}function Er(n,e,t,s){let r=new Set(e),o=new Set(t);for(let i of t)r.has(i)||s.push({field:n,type:"added",after:i});for(let i of e)o.has(i)||s.push({field:n,type:"removed",before:i})}var Ga=h(()=>{"use strict";c(Ad,"generateAnalysisDiff");c(Wa,"formatAnalysisDiffMd");c(Id,"formatAnalysisDiffText");c(Er,"diffStringArray")});var Va=h(()=>{"use strict"});import xw from"node:fs/promises";import Rw from"node:path";function Pn(n){return n.replace(/([a-z])([A-Z])/g,"$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g,"$1 $2").replace(/[-_./]/g," ").toLowerCase().split(/\s+/).filter(e=>e.length>1)}function Aw(n,e){let t=[],s=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let p of s)t.push(...Pn(p));let r=[/export\s+(?:async\s+)?function\s+(\w+)/g,/export\s+class\s+(\w+)/g,/export\s+interface\s+(\w+)/g,/export\s+type\s+(\w+)/g,/export\s+(?:const|let|var)\s+(\w+)/g,/export\s+default\s+(?:class|function)\s+(\w+)/g];for(let p of r){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Pn(g[1]))}let o=[/(?:async\s+)?function\s+(\w+)/g,/class\s+(\w+)/g,/interface\s+(\w+)/g,/type\s+(\w+)\s*=/g];for(let p of o){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Pn(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(n))!==null;){let p=a[1];if(p.startsWith(".")||p.startsWith("@/"))t.push(...Pn(p));else{let g=p.startsWith("@")?p.split("/").slice(0,2).join("/"):p.split("/")[0];t.push(...Pn(g))}}let l=/\/\/\s*(.+)/g,u;for(;(u=l.exec(n))!==null;){let p=u[1].toLowerCase().split(/\s+/).filter(g=>g.length>2);t.push(...p)}let d=/\/\*\*?([\s\S]*?)\*\//g,m;for(;(m=d.exec(n))!==null;){let p=m[1].replace(/@\w+/g,"").replace(/\*/g,"").toLowerCase().split(/\s+/).filter(g=>g.length>2&&/^[a-z]+$/.test(g));t.push(...p)}return t.filter(p=>p.length>1&&!Md.has(p)&&/^[a-z][a-z0-9]*$/.test(p))}function Iw(n){return n.split(/\s+/).flatMap(e=>Pn(e)).filter(e=>e.length>1&&!Md.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function $w(n){let e=await Ns(n),t={},s={},r=0,o=await Os(e,50,async a=>{try{let l=await xw.readFile(Rw.join(n,a),"utf-8"),u=Aw(l,a);return u.length>0?{filePath:a,tokens:u}:null}catch{return null}});for(let{filePath:a,tokens:l}of o){t[a]={tokens:l,length:l.length},r+=l.length;let u=new Map;for(let d of l)u.set(d,(u.get(d)||0)+1);for(let[d,m]of u)s[d]||(s[d]=[]),s[d].push({path:a,tf:m})}let i=Object.keys(t).length;return{documents:t,invertedIndex:s,avgDocLength:i>0?r/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function Dw(n,e){return Math.log((e-n+.5)/(n+.5)+1)}function Mw(n,e){let t=Iw(n);if(t.length===0)return[];let s=new Map;for(let r of t){let o=e.invertedIndex[r];if(!o)continue;let i=Dw(o.length,e.totalDocs);for(let{path:a,tf:l}of o){let u=e.documents[a];if(!u)continue;let d=l*(1.2+1),m=l+1.2*(1-.75+.75*(u.length/e.avgDocLength)),p=i*(d/m);s.set(a,(s.get(a)||0)+p)}}return Array.from(s.entries()).map(([r,o])=>({path:r,score:o})).sort((r,o)=>o.score-r.score)}function Nw(n,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([s,r])=>[s,r.length]))};L.setDoc(n,Nd,t)}function Ro(n){let e=L.getDoc(n,Nd);if(!e)return null;let t={};for(let[s,r]of Object.entries(e.docLengths))t[s]={tokens:[],length:r};return{documents:t,invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt}}async function Od(n,e){let t=await $w(n);return Nw(e,t),t}function _d(n,e,t=15){let s=Ro(n);return s?Mw(e,s).slice(0,t):[]}var Md,Nd,qa=h(()=>{"use strict";Va();de();z();Md=new Set(["the","a","an","is","are","was","were","be","been","being","have","has","had","do","does","did","will","would","could","should","may","might","shall","can","of","in","to","for","with","on","at","from","by","as","or","and","but","if","not","no","so","up","out","this","that","it","its","all","any","import","export","default","const","let","var","function","class","interface","type","return","new","true","false","null","undefined","void","async","await","static","public","private","protected","readonly","string","number","boolean","object","array"]);c(Pn,"splitIdentifier");c(Aw,"tokenizeFile");c(Iw,"tokenizeQuery");c($w,"buildIndex");c(Dw,"idf");c(Mw,"score");Nd="bm25-index";c(Nw,"saveIndex");c(Ro,"loadIndex");c(Od,"indexProject");c(_d,"queryFiles")});import Ba from"node:fs/promises";import Ts from"node:path";import{z as X}from"zod";async function Uw(n,e){let t=Date.now();if(n.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let s=Ts.join(e,"package.json"),r=await Ba.readFile(s,"utf-8"),o=JSON.parse(r),i={...o.dependencies,...o.devDependencies},a=[],l=[];for(let u of n.frameworks){let d=u.toLowerCase();Object.keys(i).some(p=>p.toLowerCase().includes(d))?l.push(u):a.push(u)}return a.length===0?{name:"Framework verification",passed:!0,output:`${l.length} framework(s) verified in dependencies`,durationMs:Date.now()-t}:{name:"Framework verification",passed:!1,error:`Frameworks not found in dependencies: ${a.join(", ")}`,durationMs:Date.now()-t}}catch(s){return D(s)?{name:"Framework verification",passed:!1,error:"package.json not found (cannot verify frameworks)",durationMs:Date.now()-t}:{name:"Framework verification",passed:!1,error:`Failed to read package.json: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Hw(n,e){let t=Date.now();if(n.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let s=await qw(e),r=new Set(s),o=[],i=[];for(let a of n.languages){let l=Fw[a];if(!l)continue;l.some(d=>r.has(d))?o.push(a):i.push(a)}return i.length===0?{name:"Language verification",passed:!0,output:`${o.length} language(s) verified with matching files`,durationMs:Date.now()-t}:{name:"Language verification",passed:!1,error:`Languages without matching files: ${i.join(", ")}`,durationMs:Date.now()-t}}catch(s){return{name:"Language verification",passed:!1,error:`Failed to scan project files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Ww(n,e){let t=Date.now(),s=n.patterns.filter(i=>i.location);if(s.length===0)return{name:"Pattern location verification",passed:!0,output:"No pattern locations specified (skipped)",durationMs:Date.now()-t};let r=[],o=[];for(let i of s){let a=i.location,l=Ts.join(e,a);await v(l)?o.push(a):r.push(`${i.name} (${a})`)}return r.length===0?{name:"Pattern location verification",passed:!0,output:`${o.length} pattern location(s) verified`,durationMs:Date.now()-t}:{name:"Pattern location verification",passed:!1,error:`Pattern locations not found: ${r.join(", ")}`,durationMs:Date.now()-t}}async function Gw(n,e){let t=Date.now();try{let s=await Bw(e),r=n.fileCount,o=.1,i=Math.abs(s-r),a=r*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${r}, actual: ${s})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${r}, actual ${s} (diff: ${i})`,durationMs:Date.now()-t}}catch(s){return{name:"File count verification",passed:!1,error:`Failed to count files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Vw(n,e){let t=Date.now();if(n.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let s=[],r=[];for(let o of n.antiPatterns){let i=Ts.join(e,o.file);await v(i)?r.push(o.file):s.push(`${o.issue} (${o.file})`)}return s.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${r.length} anti-pattern file(s) verified`,durationMs:Date.now()-t}:{name:"Anti-pattern file verification",passed:!1,error:`Anti-pattern files not found: ${s.join(", ")}`,durationMs:Date.now()-t}}async function Ld(n,e){let t=Date.now(),s=await Promise.all([Uw(n,e),Hw(n,e),Ww(n,e),Gw(n,e),Vw(n,e)]),r=s.filter(i=>!i.passed).length,o=s.filter(i=>i.passed).length;return{passed:r===0,checks:s,totalMs:Date.now()-t,failedCount:r,passedCount:o}}async function qw(n){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Ba.readdir(r,{withFileTypes:!0});for(let i of o){let a=Ts.join(r,i.name),l=Ts.relative(n,a);if(!t.some(u=>u.test(l))){if(i.isDirectory())await s(a);else if(i.isFile()){let u=Ts.extname(i.name);u&&e.add(u)}}}}catch{}}return c(s,"scanDir"),await s(n),Array.from(e)}async function Bw(n){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Ba.readdir(r,{withFileTypes:!0});for(let i of o){let a=Ts.join(r,i.name),l=Ts.relative(n,a);t.some(u=>u.test(l))||(i.isDirectory()?await s(a):i.isFile()&&e++)}}catch{}}return c(s,"scanDir"),await s(n),e}var Ow,_w,Lw,Ja,xA,Fw,Fd=h(()=>{"use strict";q();z();zr();Ow=X.enum(["draft","verified","sealed"]),_w=X.object({name:X.string(),description:X.string(),location:X.string().optional(),severity:X.enum(["low","medium","high"]).optional(),language:X.string().optional(),framework:X.string().optional(),source:X.enum(["baseline","repo","context7","feedback"]).optional(),confidence:X.number().min(0).max(1).optional()}),Lw=X.object({issue:X.string(),file:X.string(),suggestion:X.string(),severity:X.enum(["low","medium","high"]).optional(),language:X.string().optional(),framework:X.string().optional(),source:X.enum(["baseline","repo","context7","feedback"]).optional(),confidence:X.number().min(0).max(1).optional()}),Ja=X.object({projectId:X.string(),languages:X.array(X.string()),frameworks:X.array(X.string()),packageManager:X.string().optional(),sourceDir:X.string().optional(),testDir:X.string().optional(),configFiles:X.array(X.string()),fileCount:X.number(),patterns:X.array(_w),antiPatterns:X.array(Lw),analyzedAt:X.string(),modelMetadata:on.optional(),status:Ow.default("draft"),commitHash:X.string().optional(),signature:X.string().optional(),sealedAt:X.string().optional(),verifiedAt:X.string().optional()}),xA={languages:[],frameworks:[],configFiles:[],fileCount:0,patterns:[],antiPatterns:[],analyzedAt:new Date().toISOString(),status:"draft"},Fw={TypeScript:[".ts",".tsx",".mts",".cts"],JavaScript:[".js",".jsx",".mjs",".cjs"],Python:[".py",".pyw"],Java:[".java"],Go:[".go"],Rust:[".rs"],Ruby:[".rb"],PHP:[".php"],Swift:[".swift"],Kotlin:[".kt",".kts"],"C++":[".cpp",".cc",".cxx",".hpp",".h"],C:[".c",".h"],"C#":[".cs"],Elixir:[".ex",".exs"],Scala:[".scala"]};c(Uw,"verifyFrameworks");c(Hw,"verifyLanguages");c(Ww,"verifyPatternLocations");c(Gw,"verifyFileCount");c(Vw,"verifyAntiPatternFiles");c(Ld,"semanticVerify");c(qw,"getProjectExtensions");c(Bw,"countProjectFiles")});var za,it,Cr=h(()=>{"use strict";Fd();Ga();Ce();kr();ws();za=class extends Ye{static{c(this,"AnalysisStorage")}constructor(){super("analysis.json")}getDefault(){return{draft:null,sealed:null,previousSealed:null,lastUpdated:""}}getEventType(e){return`analysis.${e}d`}async saveDraft(e,t){let s={...t,status:"draft"};Ja.parse(s),await this.update(e,r=>({...r,draft:s,lastUpdated:x()})),await this.publishEntityEvent(e,"analysis","drafted",{commitHash:s.commitHash,fileCount:s.fileCount})}async seal(e){let t=await this.read(e);if(!t.draft)return{success:!1,error:"No draft analysis to seal. Run `p. sync` first."};if(t.draft.status==="sealed")return{success:!1,error:"Draft is already sealed."};let s=this.computeSignature(t.draft),r=x(),o={...t.draft,status:"sealed",signature:s,sealedAt:r};return Ja.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:r}),await this.publishEntityEvent(e,"analysis","sealed",{commitHash:o.commitHash,signature:s}),{success:!0,signature:s}}async getSealed(e){return(await this.read(e)).sealed}async getDraft(e){return(await this.read(e)).draft}async getActive(e){let t=await this.read(e);return t.sealed??t.draft}async getStatus(e){let t=await this.read(e);return{hasSealed:t.sealed!==null,hasDraft:t.draft!==null,hasPreviousSealed:t.previousSealed!==null,sealedCommit:t.sealed?.commitHash??null,draftCommit:t.draft?.commitHash??null,previousSealedCommit:t.previousSealed?.commitHash??null,sealedAt:t.sealed?.sealedAt??null}}async rollback(e){let t=await this.read(e);if(!t.previousSealed)return{success:!1,error:"No previous sealed version to rollback to."};let s=x();return await this.write(e,{draft:t.sealed,sealed:t.previousSealed,previousSealed:null,lastUpdated:s}),await this.publishEntityEvent(e,"analysis","rolled_back",{restoredCommit:t.previousSealed.commitHash,restoredSignature:t.previousSealed.signature}),{success:!0,restoredSignature:t.previousSealed.signature}}async diff(e){let t=await this.read(e);return!t.sealed||!t.draft?null:Ad(t.sealed,t.draft)}checkStaleness(e,t){return e?t?e!==t?{isStale:!0,sealedCommit:e,currentCommit:t,message:`Analysis is stale: sealed at ${e}, HEAD is ${t}. Run \`p. sync\` + \`p. seal\` to update.`}:{isStale:!1,sealedCommit:e,currentCommit:t,message:"Analysis is current."}:{isStale:!0,sealedCommit:e,currentCommit:null,message:"Cannot determine current commit. Analysis may be stale."}:{isStale:!1,sealedCommit:null,currentCommit:t,message:"No sealed analysis. Run `p. sync` then `p. seal`."}}async verify(e){let t=await this.read(e);if(!t.sealed)return{valid:!1,message:"No sealed analysis to verify."};if(!t.sealed.signature)return{valid:!1,message:"Sealed analysis has no signature."};let s=this.computeSignature({...t.sealed,signature:void 0,sealedAt:void 0});return s===t.sealed.signature?{valid:!0,message:"Signature verified. Analysis integrity confirmed."}:{valid:!1,message:`Signature mismatch. Expected ${s}, got ${t.sealed.signature}. Analysis may have been modified.`}}async semanticVerify(e,t){let s=await this.read(e),r=s.sealed??s.draft;return r?await Ld(r,t):{passed:!1,checks:[{name:"Analysis availability",passed:!1,error:"No analysis available. Run `p. sync` to generate.",durationMs:0}],totalMs:0,failedCount:1,passedCount:0}}computeSignature(e){let t={projectId:e.projectId,languages:e.languages,frameworks:e.frameworks,packageManager:e.packageManager,sourceDir:e.sourceDir,testDir:e.testDir,configFiles:e.configFiles,fileCount:e.fileCount,patterns:e.patterns,antiPatterns:e.antiPatterns,analyzedAt:e.analyzedAt,commitHash:e.commitHash};return wr(JSON.stringify(t))}},it=new za});import Ud from"node:fs/promises";import Hd from"node:path";async function Ka(n,e,t,s){let[r,o,i,a]=await Promise.all([Xw(n,e,s),Kw(n),Yw(n),Qw(n)]);return{project:{name:s.name,ecosystem:s.ecosystem,languages:s.languages,frameworks:s.frameworks,fileCount:s.fileCount,projectType:s.projectType},git:{branch:t.branch,recentCommits:t.recentCommits.slice(0,Jw).map(l=>({message:l.message,date:l.date})),hasChanges:t.hasChanges,weeklyCommits:t.weeklyCommits},codeSamples:r,existingPatterns:o,taskHistory:i,previousAnalysis:a??void 0}}async function Xw(n,e,t){let s=[],r=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=_d(n,r,Xa*2);for(let a of o){if(s.length>=Xa)break;try{let l=Hd.join(e,a.path),u=await Ud.readFile(l,"utf-8");u.length>Ao*3?s.push({path:a.path,content:`${u.slice(0,Ao)}
|
|
528
528
|
// ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):s.push({path:a.path,content:u.slice(0,Ao),reason:`BM25 score: ${a.score.toFixed(2)}`})}catch{}}let i=["package.json","tsconfig.json","src/index.ts","src/main.ts","app.ts"];for(let a of i){if(s.length>=Xa)break;if(!s.some(l=>l.path===a))try{let l=Hd.join(e,a),u=await Ud.readFile(l,"utf-8");s.push({path:a,content:u.slice(0,Ao),reason:"entry point"})}catch{}}return s}async function Kw(n){try{let e=await it.getActive(n);return e?{patterns:(e.patterns??[]).map(t=>({name:t.name,description:t.description})),antiPatterns:(e.antiPatterns??[]).map(t=>({issue:t.issue,file:t.file,suggestion:t.suggestion}))}:{patterns:[],antiPatterns:[]}}catch{return{patterns:[],antiPatterns:[]}}}async function Yw(n){try{return(await M.getTaskHistory(n)).slice(0,zw).map(t=>({description:t.title,status:t.classification,branch:t.branchName}))}catch{return[]}}function Qw(n){try{let e=St.getActiveSummary(n);return Promise.resolve(e)}catch(e){return B.debug("Failed to get previous LLM analysis summary",{error:e}),Promise.resolve(null)}}var Ao,Xa,Jw,zw,Wd=h(()=>{"use strict";qa();Cr();wn();lt();ks();Ao=800,Xa=6,Jw=8,zw=5;c(Ka,"buildAnalysisPayload");c(Xw,"selectCodeSamples");c(Kw,"getExistingPatterns");c(Yw,"getTaskHistory");c(Qw,"getPreviousAnalysisSummary")});var Gd=h(()=>{"use strict"});import rs from"chalk";function Vd(n){return Math.ceil(n.length/4)}function qd(n){let e=n.split(`
|
|
529
529
|
`),t=[],s=null;for(let r=0;r<e.length;r++){let o=e[r],i=o.match(/^(#{1,3})\s+(.+)$/);i?(s&&(s.endLine=r-1,t.push(s)),s={name:i[2].trim(),content:o,startLine:r,endLine:r}):s&&(s.content+=`
|
|
530
530
|
${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Ya(n){return n.includes("<!-- prjct:preserve")}function Bd(n,e){let t=qd(n),s=qd(e),r={hasChanges:!1,added:[],modified:[],removed:[],preserved:[],tokensBefore:Vd(n),tokensAfter:Vd(e),tokenDelta:0};r.tokenDelta=r.tokensAfter-r.tokensBefore;let o=new Map(t.map(a=>[a.name.toLowerCase(),a])),i=new Map(s.map(a=>[a.name.toLowerCase(),a]));for(let a of t)Ya(a.content)&&r.preserved.push({name:a.name,lineCount:a.content.split(`
|
|
@@ -762,7 +762,7 @@ Or type /p:help to see all options`,stuck:`Let's break it down:
|
|
|
762
762
|
|
|
763
763
|
Or: /p:now | /p:task | /p:idea`}[e]||`What would you like to do?
|
|
764
764
|
|
|
765
|
-
Type /p:help to see all options`}detectIntent(e){let t=e.toLowerCase();return/^(start|empez|begin|quiero|want|let'?s|voy)/i.test(t)?{intent:"start",command:"now"}:/^(done|termin|finish|acab|complete|listo|ya)/i.test(t)?{intent:"complete",command:"done"}:/^(ship|deploy|launch|public)/i.test(t)?{intent:"ship",command:"ship"}:/^(idea|think|thought|ocurr|tengo)/i.test(t)?{intent:"idea",command:"idea"}:/(show|see|view|muestra|ver).*(progress|status|recap|avance)/i.test(t)||/^(progress|status|recap|avance)/i.test(t)?{intent:"status",command:"recap"}:/^(stuck|help|ayud|atascado|perdido)/i.test(t)?{intent:"stuck",command:"stuck"}:/(what|que).*(next|sigue|after|despues)/i.test(t)||/^(next|sigue)/i.test(t)?{intent:"next",command:"next"}:{intent:"unknown",command:null}}},lm=Rc});function dm(n){if(!n||typeof n!="object")return!1;let e=n;if(e.code&&bS.has(e.code))return!0;if(e.code&&mm.has(e.code))return!1;if(e.message){let t=e.message.toLowerCase();if(t.includes("timeout")||t.includes("timed out"))return!0}return!1}function TS(n){if(!n||typeof n!="object")return!1;let e=n;return!!(e.code&&mm.has(e.code))}function pm(n,e,t){let s=Ps.get(n);return s&&s.consecutiveFailures>=e&&s.openedAt?Date.now()-s.openedAt>=t?(Ps.delete(n),!1):!0:!1}function Ac(n,e){let t=Ps.get(n)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),Ps.set(n,t)}function ES(n){Ps.delete(n)}var bS,mm,Ps,Bo,gm,mD,fm=h(()=>{"use strict";bS=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),mm=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);c(dm,"isTransientError");c(TS,"isPermanentError");Ps=new Map;c(pm,"isCircuitOpen");c(Ac,"recordFailure");c(ES,"recordSuccess");Bo=class{static{c(this,"RetryPolicy")}options;constructor(e={}){this.options={maxAttempts:e.maxAttempts??3,baseDelayMs:e.baseDelayMs??1e3,maxDelayMs:e.maxDelayMs??8e3,circuitBreakerThreshold:e.circuitBreakerThreshold??5,circuitBreakerTimeoutMs:e.circuitBreakerTimeoutMs??6e4}}async execute(e,t="default"){if(pm(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let s,r=0;for(;r<this.options.maxAttempts;)try{let o=await e();return ES(t),o}catch(o){if(s=o,r++,TS(o))throw Ac(t,this.options.circuitBreakerThreshold),o;if(!(dm(o)&&r<this.options.maxAttempts))throw Ac(t,this.options.circuitBreakerThreshold),o;let a=Math.min(this.options.baseDelayMs*2**(r-1),this.options.maxDelayMs);await new Promise(l=>setTimeout(l,a))}throw Ac(t,this.options.circuitBreakerThreshold),s}isTransientError(e){return dm(e)}isCircuitOpen(e){return pm(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return Ps.get(e)}resetCircuit(e){Ps.delete(e)}resetAllCircuits(){Ps.clear()}},gm=new Bo({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),mD=new Bo({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});var CS,Ic,Jo,hm=h(()=>{"use strict";gs();cm();um();fm();CS=["claude"],Ic=class{static{c(this,"AgentService")}agent=null;agentInfo=null;async initialize(){return this.agent?this.agent:await gm.execute(async()=>{if(this.agentInfo=await am(),!this.agentInfo?.isSupported)throw lr.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!CS.includes(e))throw lr.notSupported(this.agentInfo?.type??"unknown");return this.agent=new lm,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}reset(){this.agent=null,this.agentInfo=null}},Jo=new Ic});var $c,Dc,ym=h(()=>{"use strict";$c=class{static{c(this,"BreakdownService")}breakdownFeature(e){return[]}detectBugSeverity(e){return"medium"}estimateComplexity(e){return{level:"medium",hours:4}}detectTaskType(e){return"feature"}},Dc=new $c});import et from"node:path";async function PS(n,e){let t=e?.packageManager?.trim().toLowerCase();return t?.startsWith("pnpm@")?"pnpm":t?.startsWith("yarn@")?"yarn":t?.startsWith("bun@")?"bun":t?.startsWith("npm@")?"npm":await v(et.join(n,"pnpm-lock.yaml"))?"pnpm":await v(et.join(n,"yarn.lock"))?"yarn":await v(et.join(n,"bun.lockb"))||await v(et.join(n,"bun.lock"))?"bun":(await v(et.join(n,"package-lock.json")),"npm")}function wm(n,e){return n==="yarn"?`yarn ${e}`:n==="pnpm"?`pnpm run ${e}`:n==="bun"?`bun run ${e}`:`npm run ${e}`}function jS(n){return n==="yarn"?"yarn test":n==="pnpm"?"pnpm test":n==="bun"?"bun test":"npm test"}async function Dn(n,e){for(let r of xS)if(await v(et.join(n,r)))return r;let s=(e??await Zt(n)).find(r=>r.endsWith(RS));if(s)return s}async function as(n){for(let e of AS)if(await v(et.join(n,e)))return e}async function zo(n){let e=et.join(n,"package.json"),t=await Ee(e,null);if(t){let a=await PS(n,t),l=t.scripts||{},u={stack:"js",packageManager:a};return l.lint&&(u.lint={tool:a,command:wm(a,"lint")}),l.typecheck&&(u.typecheck={tool:a,command:wm(a,"typecheck")}),l.test&&(u.test={tool:a,command:jS(a)}),u.versionFile=await Dn(n),u.changelogFile=await as(n),u}if(await v(et.join(n,"pytest.ini"))){let a=await Dn(n),l=await as(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:l}}let s=await ct(et.join(n,"pyproject.toml"),"");if(s.includes("[tool.pytest")||s.includes("pytest")){let a=await Dn(n),l=await as(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:l}}if(await v(et.join(n,"Cargo.toml"))){let a=await as(n);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await v(et.join(n,"go.mod"))){let a=await Dn(n),l=await as(n);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:l}}let r=await Zt(n);if(r.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await Dn(n,r),l=await as(n);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:l}}if(await v(et.join(n,"pom.xml"))){let a=await as(n);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await v(et.join(n,"gradlew"))&&(await v(et.join(n,"build.gradle"))||await v(et.join(n,"build.gradle.kts")))){let a=await as(n);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await Dn(n),i=await as(n);return{stack:"unknown",versionFile:o,changelogFile:i}}var xS,RS,AS,Mc=h(()=>{"use strict";z();c(PS,"detectPackageManager");c(wm,"pmRun");c(jS,"pmTest");xS=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],RS=".csproj",AS=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];c(Dn,"detectVersionFile");c(as,"detectChangelogFile");c(zo,"detectProjectCommands")});import*as ue from"@clack/prompts";import Js from"chalk";var Xo,km,Mr,Sm=h(()=>{"use strict";z();Le();Xo=[{value:"web-app",title:"Web Application",description:"React, Vue, Angular, Next.js, etc."},{value:"api-backend",title:"API / Backend Service",description:"Express, Hono, FastAPI, etc."},{value:"fullstack",title:"Full-Stack (Monorepo)",description:"Frontend + Backend in one repo"},{value:"cli-tool",title:"CLI Tool",description:"Command-line application"},{value:"library",title:"Library / Package",description:"Reusable npm/pip/cargo package"},{value:"monorepo",title:"Monorepo (Multiple Projects)",description:"Turborepo, Nx, Lerna, etc."}],km=[{value:"claude",title:"Claude Code",description:"Anthropic's Claude in VS Code/CLI"},{value:"cursor",title:"Cursor",description:"AI-first code editor"},{value:"windsurf",title:"Windsurf",description:"Codeium's AI IDE"},{value:"copilot",title:"GitHub Copilot",description:"GitHub's AI pair programmer"},{value:"gemini",title:"Gemini CLI",description:"Google's Gemini in terminal"},{value:"codex",title:"OpenAI Codex",description:"OpenAI's coding agent in terminal"}],Mr=class{static{c(this,"OnboardingWizard")}projectPath;aborted=!1;detectedType="unknown";confirmedType="unknown";selectedAgents=[];detectedStack={language:"Unknown",technologies:[]};confirmedStack={language:"Unknown",technologies:[]};preferences={verbosity:"normal",autoSync:!0,telemetry:!1};constructor(e=process.cwd()){this.projectPath=e}async run(){ue.intro(Js.cyan.bold("\u26A1 prjct-cli setup"));let e=[{id:"project-type",title:"Project Type",run:c(()=>this.stepProjectType(),"run")},{id:"ai-agents",title:"AI Agents",run:c(()=>this.stepAIAgents(),"run")},{id:"stack",title:"Stack Confirmation",run:c(()=>this.stepStack(),"run")},{id:"preferences",title:"Preferences",run:c(()=>this.stepPreferences(),"run")},{id:"summary",title:"Summary",run:c(()=>this.stepSummary(),"run")}];for(let t of e)if(!await t.run()||this.aborted)return this.buildResult(!0);return ue.outro(Js.green("Setup complete!")),this.buildResult(!1)}async runNonInteractive(){f.spin("Auto-detecting project configuration..."),this.detectedType=await this.detectProjectType(),this.confirmedType=this.detectedType;let e=await this.detectInstalledAgents();return this.selectedAgents=e.length>0?e:["claude"],this.detectedStack=await this.detectStack(),this.confirmedStack=this.detectedStack,f.done("Configuration detected"),this.buildResult(!1)}async stepProjectType(){this.detectedType=await this.detectProjectType();let e=Xo.findIndex(s=>s.value===this.detectedType),t=await ue.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:Xo.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValue:e>=0?Xo[e].value:void 0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await ue.multiselect({message:"Which AI agents do you use?",options:km.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValues:e,required:!0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.selectedAgents=t.length>0?t:["claude"],!0)}async stepStack(){this.detectedStack=await this.detectStack();let e=this.formatStackDisplay(this.detectedStack);ue.note(e,"Detected stack");let t=await ue.confirm({message:"Is this stack correct?",initialValue:!0});if(ue.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let s=await ue.group({language:c(()=>ue.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:c(()=>ue.text({message:"Framework (optional):",defaultValue:this.detectedStack.framework||""}),"framework")},{onCancel:c(()=>{this.handleCancel()},"onCancel")});if(this.aborted)return!1;this.confirmedStack={...this.detectedStack,language:s.language||this.detectedStack.language,framework:s.framework||void 0}}return!0}async stepPreferences(){let e=await ue.group({verbosity:c(()=>ue.select({message:"Output verbosity:",options:[{label:"Minimal",hint:"Essential output only",value:"minimal"},{label:"Normal (Recommended)",hint:"Balanced information",value:"normal"},{label:"Verbose",hint:"Detailed logging",value:"verbose"}],initialValue:"normal"}),"verbosity"),autoSync:c(()=>ue.confirm({message:"Auto-sync context on file changes?",initialValue:!0}),"autoSync")},{onCancel:c(()=>{this.handleCancel()},"onCancel")});return this.aborted?!1:(this.preferences={verbosity:e.verbosity||"normal",autoSync:e.autoSync??!0,telemetry:!1},!0)}async stepSummary(){let e=[`${Js.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${Js.cyan("AI Agents:")} ${this.selectedAgents.map(s=>this.getAgentLabel(s)).join(", ")}`,`${Js.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${Js.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${Js.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
|
|
765
|
+
Type /p:help to see all options`}detectIntent(e){let t=e.toLowerCase();return/^(start|empez|begin|quiero|want|let'?s|voy)/i.test(t)?{intent:"start",command:"now"}:/^(done|termin|finish|acab|complete|listo|ya)/i.test(t)?{intent:"complete",command:"done"}:/^(ship|deploy|launch|public)/i.test(t)?{intent:"ship",command:"ship"}:/^(idea|think|thought|ocurr|tengo)/i.test(t)?{intent:"idea",command:"idea"}:/(show|see|view|muestra|ver).*(progress|status|recap|avance)/i.test(t)||/^(progress|status|recap|avance)/i.test(t)?{intent:"status",command:"recap"}:/^(stuck|help|ayud|atascado|perdido)/i.test(t)?{intent:"stuck",command:"stuck"}:/(what|que).*(next|sigue|after|despues)/i.test(t)||/^(next|sigue)/i.test(t)?{intent:"next",command:"next"}:{intent:"unknown",command:null}}},lm=Rc});function dm(n){if(!n||typeof n!="object")return!1;let e=n;if(e.code&&bS.has(e.code))return!0;if(e.code&&mm.has(e.code))return!1;if(e.message){let t=e.message.toLowerCase();if(t.includes("timeout")||t.includes("timed out"))return!0}return!1}function TS(n){if(!n||typeof n!="object")return!1;let e=n;return!!(e.code&&mm.has(e.code))}function pm(n,e,t){let s=Ps.get(n);return s&&s.consecutiveFailures>=e&&s.openedAt?Date.now()-s.openedAt>=t?(Ps.delete(n),!1):!0:!1}function Ac(n,e){let t=Ps.get(n)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),Ps.set(n,t)}function ES(n){Ps.delete(n)}var bS,mm,Ps,Bo,gm,gD,fm=h(()=>{"use strict";bS=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),mm=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);c(dm,"isTransientError");c(TS,"isPermanentError");Ps=new Map;c(pm,"isCircuitOpen");c(Ac,"recordFailure");c(ES,"recordSuccess");Bo=class{static{c(this,"RetryPolicy")}options;constructor(e={}){this.options={maxAttempts:e.maxAttempts??3,baseDelayMs:e.baseDelayMs??1e3,maxDelayMs:e.maxDelayMs??8e3,circuitBreakerThreshold:e.circuitBreakerThreshold??5,circuitBreakerTimeoutMs:e.circuitBreakerTimeoutMs??6e4}}async execute(e,t="default"){if(pm(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let s,r=0;for(;r<this.options.maxAttempts;)try{let o=await e();return ES(t),o}catch(o){if(s=o,r++,TS(o))throw Ac(t,this.options.circuitBreakerThreshold),o;if(!(dm(o)&&r<this.options.maxAttempts))throw Ac(t,this.options.circuitBreakerThreshold),o;let a=Math.min(this.options.baseDelayMs*2**(r-1),this.options.maxDelayMs);await new Promise(l=>setTimeout(l,a))}throw Ac(t,this.options.circuitBreakerThreshold),s}isTransientError(e){return dm(e)}isCircuitOpen(e){return pm(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return Ps.get(e)}resetCircuit(e){Ps.delete(e)}resetAllCircuits(){Ps.clear()}},gm=new Bo({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),gD=new Bo({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});var CS,Ic,Jo,hm=h(()=>{"use strict";gs();cm();um();fm();CS=["claude"],Ic=class{static{c(this,"AgentService")}agent=null;agentInfo=null;async initialize(){return this.agent?this.agent:await gm.execute(async()=>{if(this.agentInfo=await am(),!this.agentInfo?.isSupported)throw lr.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!CS.includes(e))throw lr.notSupported(this.agentInfo?.type??"unknown");return this.agent=new lm,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}reset(){this.agent=null,this.agentInfo=null}},Jo=new Ic});var $c,Dc,ym=h(()=>{"use strict";$c=class{static{c(this,"BreakdownService")}breakdownFeature(e){return[]}detectBugSeverity(e){return"medium"}estimateComplexity(e){return{level:"medium",hours:4}}detectTaskType(e){return"feature"}},Dc=new $c});import et from"node:path";async function PS(n,e){let t=e?.packageManager?.trim().toLowerCase();return t?.startsWith("pnpm@")?"pnpm":t?.startsWith("yarn@")?"yarn":t?.startsWith("bun@")?"bun":t?.startsWith("npm@")?"npm":await v(et.join(n,"pnpm-lock.yaml"))?"pnpm":await v(et.join(n,"yarn.lock"))?"yarn":await v(et.join(n,"bun.lockb"))||await v(et.join(n,"bun.lock"))?"bun":(await v(et.join(n,"package-lock.json")),"npm")}function wm(n,e){return n==="yarn"?`yarn ${e}`:n==="pnpm"?`pnpm run ${e}`:n==="bun"?`bun run ${e}`:`npm run ${e}`}function jS(n){return n==="yarn"?"yarn test":n==="pnpm"?"pnpm test":n==="bun"?"bun test":"npm test"}async function Dn(n,e){for(let r of xS)if(await v(et.join(n,r)))return r;let s=(e??await Zt(n)).find(r=>r.endsWith(RS));if(s)return s}async function as(n){for(let e of AS)if(await v(et.join(n,e)))return e}async function zo(n){let e=et.join(n,"package.json"),t=await Ee(e,null);if(t){let a=await PS(n,t),l=t.scripts||{},u={stack:"js",packageManager:a};return l.lint&&(u.lint={tool:a,command:wm(a,"lint")}),l.typecheck&&(u.typecheck={tool:a,command:wm(a,"typecheck")}),l.test&&(u.test={tool:a,command:jS(a)}),u.versionFile=await Dn(n),u.changelogFile=await as(n),u}if(await v(et.join(n,"pytest.ini"))){let a=await Dn(n),l=await as(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:l}}let s=await ct(et.join(n,"pyproject.toml"),"");if(s.includes("[tool.pytest")||s.includes("pytest")){let a=await Dn(n),l=await as(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:l}}if(await v(et.join(n,"Cargo.toml"))){let a=await as(n);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await v(et.join(n,"go.mod"))){let a=await Dn(n),l=await as(n);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:l}}let r=await Zt(n);if(r.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await Dn(n,r),l=await as(n);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:l}}if(await v(et.join(n,"pom.xml"))){let a=await as(n);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await v(et.join(n,"gradlew"))&&(await v(et.join(n,"build.gradle"))||await v(et.join(n,"build.gradle.kts")))){let a=await as(n);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await Dn(n),i=await as(n);return{stack:"unknown",versionFile:o,changelogFile:i}}var xS,RS,AS,Mc=h(()=>{"use strict";z();c(PS,"detectPackageManager");c(wm,"pmRun");c(jS,"pmTest");xS=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],RS=".csproj",AS=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];c(Dn,"detectVersionFile");c(as,"detectChangelogFile");c(zo,"detectProjectCommands")});import*as ue from"@clack/prompts";import Js from"chalk";var Xo,km,Mr,Sm=h(()=>{"use strict";z();Le();Xo=[{value:"web-app",title:"Web Application",description:"React, Vue, Angular, Next.js, etc."},{value:"api-backend",title:"API / Backend Service",description:"Express, Hono, FastAPI, etc."},{value:"fullstack",title:"Full-Stack (Monorepo)",description:"Frontend + Backend in one repo"},{value:"cli-tool",title:"CLI Tool",description:"Command-line application"},{value:"library",title:"Library / Package",description:"Reusable npm/pip/cargo package"},{value:"monorepo",title:"Monorepo (Multiple Projects)",description:"Turborepo, Nx, Lerna, etc."}],km=[{value:"claude",title:"Claude Code",description:"Anthropic's Claude in VS Code/CLI"},{value:"cursor",title:"Cursor",description:"AI-first code editor"},{value:"windsurf",title:"Windsurf",description:"Codeium's AI IDE"},{value:"copilot",title:"GitHub Copilot",description:"GitHub's AI pair programmer"},{value:"gemini",title:"Gemini CLI",description:"Google's Gemini in terminal"},{value:"codex",title:"OpenAI Codex",description:"OpenAI's coding agent in terminal"}],Mr=class{static{c(this,"OnboardingWizard")}projectPath;aborted=!1;detectedType="unknown";confirmedType="unknown";selectedAgents=[];detectedStack={language:"Unknown",technologies:[]};confirmedStack={language:"Unknown",technologies:[]};preferences={verbosity:"normal",autoSync:!0,telemetry:!1};constructor(e=process.cwd()){this.projectPath=e}async run(){ue.intro(Js.cyan.bold("\u26A1 prjct-cli setup"));let e=[{id:"project-type",title:"Project Type",run:c(()=>this.stepProjectType(),"run")},{id:"ai-agents",title:"AI Agents",run:c(()=>this.stepAIAgents(),"run")},{id:"stack",title:"Stack Confirmation",run:c(()=>this.stepStack(),"run")},{id:"preferences",title:"Preferences",run:c(()=>this.stepPreferences(),"run")},{id:"summary",title:"Summary",run:c(()=>this.stepSummary(),"run")}];for(let t of e)if(!await t.run()||this.aborted)return this.buildResult(!0);return ue.outro(Js.green("Setup complete!")),this.buildResult(!1)}async runNonInteractive(){f.spin("Auto-detecting project configuration..."),this.detectedType=await this.detectProjectType(),this.confirmedType=this.detectedType;let e=await this.detectInstalledAgents();return this.selectedAgents=e.length>0?e:["claude"],this.detectedStack=await this.detectStack(),this.confirmedStack=this.detectedStack,f.done("Configuration detected"),this.buildResult(!1)}async stepProjectType(){this.detectedType=await this.detectProjectType();let e=Xo.findIndex(s=>s.value===this.detectedType),t=await ue.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:Xo.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValue:e>=0?Xo[e].value:void 0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await ue.multiselect({message:"Which AI agents do you use?",options:km.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValues:e,required:!0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.selectedAgents=t.length>0?t:["claude"],!0)}async stepStack(){this.detectedStack=await this.detectStack();let e=this.formatStackDisplay(this.detectedStack);ue.note(e,"Detected stack");let t=await ue.confirm({message:"Is this stack correct?",initialValue:!0});if(ue.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let s=await ue.group({language:c(()=>ue.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:c(()=>ue.text({message:"Framework (optional):",defaultValue:this.detectedStack.framework||""}),"framework")},{onCancel:c(()=>{this.handleCancel()},"onCancel")});if(this.aborted)return!1;this.confirmedStack={...this.detectedStack,language:s.language||this.detectedStack.language,framework:s.framework||void 0}}return!0}async stepPreferences(){let e=await ue.group({verbosity:c(()=>ue.select({message:"Output verbosity:",options:[{label:"Minimal",hint:"Essential output only",value:"minimal"},{label:"Normal (Recommended)",hint:"Balanced information",value:"normal"},{label:"Verbose",hint:"Detailed logging",value:"verbose"}],initialValue:"normal"}),"verbosity"),autoSync:c(()=>ue.confirm({message:"Auto-sync context on file changes?",initialValue:!0}),"autoSync")},{onCancel:c(()=>{this.handleCancel()},"onCancel")});return this.aborted?!1:(this.preferences={verbosity:e.verbosity||"normal",autoSync:e.autoSync??!0,telemetry:!1},!0)}async stepSummary(){let e=[`${Js.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${Js.cyan("AI Agents:")} ${this.selectedAgents.map(s=>this.getAgentLabel(s)).join(", ")}`,`${Js.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${Js.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${Js.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
|
|
766
766
|
`);ue.note(e,"Configuration Summary");let t=await ue.confirm({message:"Generate configuration with these settings?",initialValue:!0});return ue.isCancel(t)||!t?(ue.isCancel(t)&&this.handleCancel(),!1):!0}async detectProjectType(){let e=await import("node:fs/promises"),t=await import("node:path");try{let s=await e.readdir(this.projectPath);if(s.includes("turbo.json")||s.includes("lerna.json")||s.includes("nx.json"))return"monorepo";if(s.includes("package.json")){let r=t.join(this.projectPath,"package.json"),o=await e.readFile(r,"utf-8"),i=JSON.parse(o),a={...i.dependencies,...i.devDependencies};if(i.bin)return"cli-tool";if(i.main&&!a.react&&!a.vue&&!a.angular&&!a.express&&!a.hono)return"library";if((a.react||a.vue)&&(a.express||a.hono||a.fastify))return"fullstack";if(a.react||a.vue||a["@angular/core"]||a.next||a.nuxt)return"web-app";if(a.express||a.hono||a.fastify||a.koa||a.nestjs)return"api-backend"}return s.includes("pyproject.toml")||s.includes("setup.py")?s.some(o=>["main.py","app.py","server.py"].includes(o))?"api-backend":"library":s.includes("go.mod")?s.includes("main.go")?"cli-tool":"library":s.includes("Cargo.toml")?"cli-tool":"unknown"}catch{return"unknown"}}async detectInstalledAgents(){let e=await import("node:path"),t=await import("node:os"),s=[];await Qt(e.join(t.homedir(),".claude"))&&s.push("claude"),await v(e.join(this.projectPath,".cursorrules"))&&s.push("cursor"),await v(e.join(this.projectPath,".windsurfrules"))&&s.push("windsurf"),await v(e.join(this.projectPath,".github","copilot-instructions.md"))&&s.push("copilot"),await Qt(e.join(t.homedir(),".gemini"))&&s.push("gemini");try{let{execAsync:r}=await Promise.resolve().then(()=>(st(),Ii));await r("which codex"),s.push("codex")}catch{await Qt(e.join(t.homedir(),".codex"))&&s.push("codex")}return s.length>0?s:["claude"]}async detectStack(){let e=await import("node:fs/promises"),t=await import("node:path"),s={language:"Unknown",technologies:[]};try{let r=await e.readdir(this.projectPath);if(r.includes("package.json")){let o=t.join(this.projectPath,"package.json"),i=await e.readFile(o,"utf-8"),a=JSON.parse(i),l={...a.dependencies,...a.devDependencies};s.language=l.typescript?"TypeScript":"JavaScript",l.next?s.framework="Next.js":l.nuxt?s.framework="Nuxt":l.react?s.framework="React":l.vue?s.framework="Vue":l["@angular/core"]?s.framework="Angular":l.express?s.framework="Express":l.hono?s.framework="Hono":l.fastify?s.framework="Fastify":(l.nestjs||l["@nestjs/core"])&&(s.framework="NestJS"),l.bun||l["@types/bun"]||a.engines?.bun?s.runtime="Bun":s.runtime="Node.js",r.includes("bun.lockb")?s.packageManager="Bun":r.includes("pnpm-lock.yaml")?s.packageManager="pnpm":r.includes("yarn.lock")?s.packageManager="Yarn":r.includes("package-lock.json")&&(s.packageManager="npm"),(l.prisma||l["@prisma/client"])&&s.technologies.push("Prisma"),(l.drizzle||l["drizzle-orm"])&&s.technologies.push("Drizzle"),l.tailwindcss&&s.technologies.push("Tailwind CSS"),l.zod&&s.technologies.push("Zod"),(l.trpc||l["@trpc/server"])&&s.technologies.push("tRPC")}else r.includes("pyproject.toml")||r.includes("requirements.txt")?s.language="Python":r.includes("go.mod")?s.language="Go":r.includes("Cargo.toml")?s.language="Rust":(r.includes("pom.xml")||r.includes("build.gradle"))&&(s.language="Java");return s}catch{return s}}handleCancel(){this.aborted=!0,ue.cancel("Setup cancelled. Run again anytime.")}getProjectTypeLabel(e){return Xo.find(t=>t.value===e)?.title||"Unknown"}getAgentLabel(e){return km.find(t=>t.value===e)?.title||e}formatStackDisplay(e){let t=[e.language];return e.framework&&t.push(e.framework),e.runtime&&e.runtime!=="Node.js"&&t.push(e.runtime),e.technologies.length>0&&t.push(`+ ${e.technologies.slice(0,3).join(", ")}`),t.join(" / ")}buildResult(e){return{projectType:this.confirmedType,agents:this.selectedAgents,stack:this.confirmedStack,preferences:this.preferences,skipped:e}}getSelectedAgents(){return this.selectedAgents}getConfirmedStack(){return this.confirmedStack}getPreferences(){return this.preferences}}});function vm(n){return Gt[n]??null}function bm(n){let e=new Set;for(let t of n){let s=Gt[t];if(s)for(let r of s.memoryTypes)e.add(r)}return[...e].sort()}function Tm(n){let e={};for(let t of n){let s=Gt[t];if(s)for(let[r,o]of Object.entries(s.workflowSlots))e[r]||(e[r]={...o,pack:t})}return e}function Em(n){let e={};for(let t of n){let s=Gt[t];if(s)for(let r of s.hookSignals){let o=e[r.event]??[];o.push(r),e[r.event]=o}}return e}var Gt,Nc,Oc=h(()=>{"use strict";Gt={code:{name:"code",description:"Coding work: features, bugs, refactors, TDD, shipping.",suggestedPersona:{role:"DEV",mcps:["github"]},memoryTypes:["fact","decision","learning","gotcha","pattern","anti-pattern","shipped"],workflowSlots:{ship:{description:"Publish finished work \u2014 tests, commit, push, PR."},review:{description:"Pre-commit or pre-PR review pass."}},hookSignals:[],suggestedTags:{domain:["auth","api","frontend","infra","data"]}},daily:{name:"daily",description:"Day-to-day capture + review. GTD-style inbox + weekly review.",memoryTypes:["inbox","todo","idea"],workflowSlots:{morning:{description:"Morning briefing \u2014 pull open todos + upcoming commitments."},clarify:{description:"Reclassify inbox entries to real memory types."},review:{description:"Weekly/biweekly review across memory."}},hookSignals:[]},pm:{name:"pm",description:"Product Management: specs, user interviews, roadmap, backlog triage.",suggestedPersona:{role:"PM",mcps:["linear","posthog"]},memoryTypes:["insight","question","stakeholder","decision","source"],workflowSlots:{spec:{description:"Draft a technical/product spec from captured insights."},triage:{description:"Review Linear backlog and prioritize."},interview:{description:"User interview pre-brief + post-synthesis."}},hookSignals:[{event:"UserPromptSubmit",ifMatches:"spec|requirements?|prd",inject:["type=insight","type=question"]}],suggestedTags:{audience:["team","stakeholders"],quarter:["q1","q2","q3","q4"]}},founder:{name:"founder",description:"Founder ops: strategy, fundraising, hiring, stakeholder comms.",suggestedPersona:{role:"Founder",mcps:["gmail","linear","posthog"]},memoryTypes:["goal","okr","person","stakeholder","decision","shipped"],workflowSlots:{"investor-update":{description:"Monthly investor update draft."},"1on1":{description:"1:1 prep + synthesis."},strategy:{description:"Strategy checkpoint \u2014 OKR progress + pivots."}},hookSignals:[{event:"UserPromptSubmit",ifMatches:"investor|board|update|fundrais",inject:["type=okr","type=shipped","type=stakeholder"]}],suggestedTags:{audience:["board","investors","team"]}},research:{name:"research",description:"Research: deep-dives, literature review, competitive scans.",suggestedPersona:{role:"Research",mcps:["web"]},memoryTypes:["source","claim","question","insight"],workflowSlots:{"lit-review":{description:"Literature review across captured sources."},analyze:{description:"Data analysis run via MCP, persist findings."}},hookSignals:[],suggestedTags:{confidence:["high","medium","low"]}}},Nc=Object.keys(Gt);c(vm,"getPackManifest");c(bm,"aggregateMemoryTypes");c(Tm,"aggregateSlots");c(Em,"aggregateHookSignals")});var Cm={};G(Cm,{activatePacks:()=>Lc,deactivatePacks:()=>Fc,detectSuggestedPacks:()=>_c,effectiveProjectSurface:()=>IS,listActivePacks:()=>Uc});async function _c(n){let e=await import("node:fs/promises"),t=await import("node:path"),s=new Set(["daily"]),r=["package.json","go.mod","Cargo.toml","pyproject.toml","Gemfile","pom.xml","build.gradle"];for(let o of r)try{await e.stat(t.join(n,o)),s.add("code");break}catch{}return[...s]}async function Lc(n,e,t={}){let s=[],r=[],o=await A.readConfig(n);if(!o)throw new Error("No prjct project here \u2014 run `prjct init` first.");let i=o.persona??{role:"DEV"},a=new Set(i.packs??[]);for(let m of e){if(!Gt[m]){r.push(m);continue}a.has(m)||(a.add(m),s.push(m))}let l=[...a],u={...i,packs:l};t.suggestPersona&&s.length>0&&$S(u,s);let d={...o,persona:u};return await A.writeConfig(n,d),{activated:s,skipped:r}}async function Fc(n,e){let t=await A.readConfig(n);if(!t)throw new Error("No prjct project here \u2014 run `prjct init` first.");let s=t.persona??{role:"DEV"},r=new Set(s.packs??[]),o=[],i=[];for(let u of e)r.delete(u)?o.push(u):i.push(u);let a={...s,packs:[...r]},l={...t,persona:a};return await A.writeConfig(n,l),{deactivated:o,notActive:i}}async function Uc(n){let t=(await A.readConfig(n))?.persona?.packs??[],s=[];for(let r of t){let o=Gt[r];o&&s.push({name:o.name,description:o.description,memoryTypes:o.memoryTypes,slots:Object.keys(o.workflowSlots)})}return s}async function IS(n){let t=(await A.readConfig(n))?.persona?.packs??[];return{packs:t,memoryTypes:bm(t),slots:Tm(t),hookSignals:Em(t)}}function $S(n,e){let t=n.role&&n.role!=="DEV",s=n.mcps&&n.mcps.length>0;for(let r of e){let o=vm(r);if(o?.suggestedPersona&&(!t&&o.suggestedPersona.role&&(n.role=o.suggestedPersona.role),!n.focus&&o.suggestedPersona.focus&&(n.focus=o.suggestedPersona.focus),!s&&o.suggestedPersona.mcps&&(n.mcps=[...o.suggestedPersona.mcps]),n.role&&n.role!=="DEV"))break}}var Hc=h(()=>{"use strict";ie();Oc();c(_c,"detectSuggestedPacks");c(Lc,"activatePacks");c(Fc,"deactivatePacks");c(Uc,"listActivePacks");c(IS,"effectiveProjectSurface");c($S,"applyPersonaSuggestion")});var Pm,Wc,Gc,jm,Mn,Ko=h(()=>{"use strict";Pm="memory.",Wc="remember.",Gc=`${Pm}${Wc}`,jm=`${Pm}task.tagged`,Mn="status.changed"});import xm from"node:path";var DS,MS,Yo,Rm=h(()=>{"use strict";Ce();z();DS=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"],MS=`# Changelog
|
|
767
767
|
|
|
768
768
|
All notable changes to this project will be documented in this file.
|
|
@@ -964,7 +964,7 @@ Available: ${Nc.join(", ")}`),{success:!1,error:"No pack given"};let r=e.split("
|
|
|
964
964
|
INSERT OR REPLACE INTO mcp_health
|
|
965
965
|
(provider, status, last_checked, last_error, token_version, config_valid, oauth_valid, updated_at)
|
|
966
966
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
967
|
-
`).run(e,t.status,r,t.lastError??null,t.tokenVersion??null,t.configValid?1:0,t.oauthValid?1:0,r)}clearMcpHealth(e){this.getDb().prepare("DELETE FROM mcp_health WHERE provider = ?").run(e)}close(){this.db&&(this.db.close(),this.db=null)}},Cb=new hl});import Pb from"node:fs/promises";import $g from"node:os";import fi from"node:path";function jb(){try{let n=fi.dirname(Ke.resolve("prjct-cli/package.json"));return{command:"node",args:[fi.join(n,"dist","mcp","server.mjs")],description:"prjct data layer (memories, analysis, files, workflows)"}}catch{return{command:"npx",args:["-y","prjct-cli","mcp"],description:"prjct data layer (memories, analysis, files, workflows)"}}}function nn(){return process.env.PRJCT_TEST_MODE==="1"?fi.join($g.tmpdir(),"prjct-context7-test","mcp.json"):fi.join($g.homedir(),".claude","mcp.json")}async function Dg(n=nn()){try{let e=await Pb.readFile(n,"utf-8");return JSON.parse(e)}catch(e){let t=k(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${n}: ${k(e)}`)}}async function xb(n,e=nn()){await ae(e,n)}async function wl(n,e,t=nn()){let s=await Dg(t),r={...s.mcpServers||{}},o=r[n];r[n]=e,s.mcpServers=r;let i=JSON.stringify(o)!==JSON.stringify(e);return await xb(s,t),{path:t,changed:i}}async function kl(n,e=nn()){return!!(await Dg(e)).mcpServers?.[n]}var hi,yl,
|
|
967
|
+
`).run(e,t.status,r,t.lastError??null,t.tokenVersion??null,t.configValid?1:0,t.oauthValid?1:0,r)}clearMcpHealth(e){this.getDb().prepare("DELETE FROM mcp_health WHERE provider = ?").run(e)}close(){this.db&&(this.db.close(),this.db=null)}},Cb=new hl});import Pb from"node:fs/promises";import $g from"node:os";import fi from"node:path";function jb(){try{let n=fi.dirname(Ke.resolve("prjct-cli/package.json"));return{command:"node",args:[fi.join(n,"dist","mcp","server.mjs")],description:"prjct data layer (memories, analysis, files, workflows)"}}catch{return{command:"npx",args:["-y","prjct-cli","mcp"],description:"prjct data layer (memories, analysis, files, workflows)"}}}function nn(){return process.env.PRJCT_TEST_MODE==="1"?fi.join($g.tmpdir(),"prjct-context7-test","mcp.json"):fi.join($g.homedir(),".claude","mcp.json")}async function Dg(n=nn()){try{let e=await Pb.readFile(n,"utf-8");return JSON.parse(e)}catch(e){let t=k(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${n}: ${k(e)}`)}}async function xb(n,e=nn()){await ae(e,n)}async function wl(n,e,t=nn()){let s=await Dg(t),r={...s.mcpServers||{}},o=r[n];r[n]=e,s.mcpServers=r;let i=JSON.stringify(o)!==JSON.stringify(e);return await xb(s,t),{path:t,changed:i}}async function kl(n,e=nn()){return!!(await Dg(e)).mcpServers?.[n]}var hi,yl,$_,Mg=h(()=>{"use strict";Ig();q();z();hi="mcp-remote@0.1.38";c(jb,"getPrjctMcpConfig");yl={prjct:jb(),linear:{command:"npx",args:["-y",hi,"https://mcp.linear.app/mcp"],description:"Linear MCP server (OAuth)"},jira:{command:"npx",args:["-y",hi,"https://mcp.atlassian.com/v1/mcp"],description:"Atlassian MCP server for Jira (OAuth)"}},$_={linear:`npx -y ${hi} https://mcp.linear.app/mcp`,jira:`npx -y ${hi} https://mcp.atlassian.com/v1/mcp`};c(nn,"getClaudeMcpConfigPath");c(Dg,"readMcpConfig");c(xb,"writeMcpConfig");c(wl,"upsertMcpServer");c(kl,"hasMcpServer")});import Rb from"node:fs/promises";import Ab from"node:http";import Ib from"node:path";import ee from"chalk";var Bn,Sl=h(()=>{"use strict";Wt();ie();Pe();Pr();mi();gl();Rg();q();st();z();Mg();Le();qe();Et();Bn=class extends ve{static{c(this,"SetupCommands")}async auth(e=null,t={}){let s=e?.split(" ")[0]||"status",r=e?.split(" ").slice(1)||[];switch(s){case"login":{let o=r[0];if(!o)return t.md||f.fail("Usage: prjct login [--url <url>]"),{success:!1,message:t.md?"## Error\nUsage: `prjct login [--url <url>]`":""};let i,a=r.indexOf("--url");return a!==-1&&r[a+1]&&(i=r[a+1]),await at.write({apiKey:o,...i?{apiUrl:i}:{}}),await qn.testConnection()?(t.md||(f.done("Connected! API key saved"),f.info(ee.dim(`Key: ${o.substring(0,12)}...`))),{success:!0,message:t.md?`## Auth
|
|
968
968
|
- **Status**: Connected
|
|
969
969
|
- **Key**: \`${o.substring(0,12)}...\`
|
|
970
970
|
- **API**: ${i||"default"}`:""}):(t.md||(f.warn("API key saved, but server is unreachable"),f.info(ee.dim(`Key: ${o.substring(0,12)}...`)),f.info(ee.dim("The key will be used when the server becomes available"))),{success:!0,message:t.md?`## Auth
|
|
@@ -1165,7 +1165,7 @@ Run with: p. ${i}`)),{success:!0,workflowId:u,name:i,templatePath:d.path}}catch(
|
|
|
1165
1165
|
`)))}if(o.length>0){let a=o.map(l=>`- **${l.name}** \u2014 ${l.description}`);i.push(le("Custom Workflows",a.join(`
|
|
1166
1166
|
`)))}console.log(V(...i,Je([{label:"Create workflow",command:'prjct workflow create <name> "description" --md'},{label:"View workflow",command:"prjct workflow <name> --md"}])))}else{if(f.done(`${s.length} workflow${s.length!==1?"s":""}`),r.length>0){console.log(`
|
|
1167
1167
|
Built-in:`);for(let i of r)console.log(` ${i.name} \u2014 ${i.description}`)}if(o.length>0){console.log(`
|
|
1168
|
-
Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:s}}async _workflowDelete(e,t,s){let r=e.trim();if(!r){let o="Usage: prjct workflow delete <name>";return s.md?console.log(`> ${o}`):f.warn(o),{success:!1,error:o}}try{if(!De.deleteWorkflow(t,r)){let i=`Workflow '${r}' not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return await Cl.deleteWorkflowTemplate(r),s.md?console.log(V(Re("Workflow Deleted",`Deleted workflow: ${r}`))):f.done(`deleted workflow: ${r}`),{success:!0}}catch(o){let i=k(o);return s.md?console.log(`> Error: ${i}`):f.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await A.getProjectId(t);if(!o)return s.md?console.log("> No project ID found. Run `prjct init` first."):f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e.trim();if(!i){let u="Usage: prjct workflow run <name>";return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let a=De.getWorkflow(o,i);if(!a||!a.enabled){let u=`Workflow '${i}' not found`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let l=await js(o,i,"before",{projectPath:t});if(!l.success){if(s.md)Yp("failed","workflow_gates_failed",[{label:"View rules",command:`prjct workflow ${i} --md`}]);else if(f.fail("Workflow gates failed"),l.gatesFailed)for(let u of l.gatesFailed)console.log(` \u2717 ${u}`);return{success:!1,error:"Workflow gates failed",gatesFailed:l.gatesFailed}}return await js(o,i,"after",{projectPath:t}),s.md?console.log(V(Re(`Workflow: ${i}`,a.description||""),Je([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):f.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(r){let o=k(r);return s.md?console.log(`> Error: ${o}`):f.fail(o),{success:!1,error:o}}}};c(Mb,"buildFlowDiagram")});var Rs,XL,jl=h(()=>{"use strict";ai();ol();li();_r();ii();dl();pi();Sl();oi();bl();Pl();Rs=class{static{c(this,"PrjctCommands")}workflow;planning;shipping;analysis;setupCmds;updateCmds;contextCmds;primitivesCmds;seedCmds;installCmds;captureCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new Kn,this.planning=new Ys,this.shipping=new Ks,this.analysis=new en,this.setupCmds=new Bn,this.updateCmds=new Xn,this.contextCmds=new xs,this.primitivesCmds=new Vn,this.seedCmds=new sn,this.installCmds=new tn,this.captureCmds=new Wn,this.agent=null,this.agentInfo=null,this.currentAuthor=null,this.prjctDir=".prjct"}async task(e=null,t=process.cwd(),s={}){return this.workflow.now(e,t,s)}async workflowPrefs(e=null,t=process.cwd(),s={}){return this.workflow.workflow(e,t,s)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async ship(e,t=process.cwd(),s={}){return this.shipping.ship(e,t,{...s})}async analyze(e={},t=process.cwd()){return this.analysis.analyze(e,t)}async sync(e=process.cwd(),t={}){return this.analysis.sync(e,t)}async saveLlmAnalysis(e,t=process.cwd(),s={}){return this.analysis.saveLlmAnalysis(e,t,s)}async regenVault(e=process.cwd(),t={}){return this.analysis.regenVault(e,t)}async context(e=null,t=process.cwd(),s={}){return this.contextCmds.context(e,t,s)}async status(e=null,t=process.cwd(),s={}){return this.primitivesCmds.status(e,t,s)}async tag(e=null,t=process.cwd(),s={}){return this.primitivesCmds.tag(e,t,s)}async remember(e=null,t=process.cwd(),s={}){return this.primitivesCmds.remember(e,t,s)}async seed(e=null,t=process.cwd(),s={}){return this.seedCmds.seed(e,t,s)}async install(e=null,t=process.cwd(),s={}){return this.installCmds.install(null,t,s)}async capture(e=null,t=process.cwd(),s={}){return this.captureCmds.capture(e,t,s)}async auth(e=null,t={}){return this.setupCmds.auth(e,t)}async login(e={}){return this.setupCmds.login(e)}async logout(){return this.setupCmds.logout()}async start(){return this.setupCmds.start()}async setup(e={}){return this.setupCmds.setup(e)}async update(e={},t=process.cwd()){return this.updateCmds.update(e,t)}async installStatusLine(){return this.setupCmds.installStatusLine()}showAsciiArt(){this.setupCmds.showAsciiArt()}async initializeAgent(){return this.workflow.initializeAgent()}async ensureProjectInit(e){return this.workflow.ensureProjectInit(e)}async ensureAuthor(){return this.workflow.ensureAuthor()}async getGlobalProjectPath(e){return this.workflow.getGlobalProjectPath(e)}async logToMemory(e,t,s){return this.workflow.logToMemory(e,t,s)}},XL=new Rs});var xl,se,wi=h(()=>{"use strict";ie();Pe();q();Ce();xl=class{static{c(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll"]);register(e,t){this.handlers.set(e.name,e),this.setMeta(e.name,t)}registerFn(e,t,s){this.handlerFns.set(e,t),this.setMeta(e,s)}setMeta(e,t){let s=t?.requiresProject??!this.noProjectCommands.has(e);this.metadata.set(e,{name:e,group:t?.group??"unknown",description:t?.description??"",requiresProject:s,usage:t?.usage??{claude:null,terminal:null},implemented:t?.implemented??!0,hasTemplate:t?.hasTemplate??!1,params:t?.params,blockingRules:t?.blockingRules,features:t?.features,isOptional:t?.isOptional,deprecated:t?.deprecated,replacedBy:t?.replacedBy})}registerCategory(e,t){this.categories.set(e,t)}registerMethod(e,t,s,r){let o=t[s];if(typeof o!="function")throw new Error(`${String(s)} is not a function`);let i=c(async(a,l)=>a!=null?o.call(t,a,l.projectPath):o.call(t,l.projectPath),"wrapper");this.handlerFns.set(e,i),this.setMeta(e,r)}has(e){return this.handlers.has(e)||this.handlerFns.has(e)}list(){return[...this.handlers.keys(),...this.handlerFns.keys()]}listByGroup(e){return Array.from(this.metadata.entries()).filter(([,t])=>t.group===e).map(([t])=>t)}getGroups(){let e=new Set;for(let t of this.metadata.values())e.add(t.group);return Array.from(e)}getMeta(e){return this.metadata.get(e)}getAll(){return Array.from(this.metadata.values())}getByName(e){return this.metadata.get(e)}getByCategory(e){return this.getAll().filter(t=>t.group===e)}getAllImplemented(){return this.getAll().filter(e=>e.implemented)}getAllWithTemplates(){return this.getAll().filter(e=>e.hasTemplate)}getClaudeCommands(){return this.getAll().filter(e=>e.usage.claude!==null)}getTerminalCommands(){return this.getAll().filter(e=>e.usage.terminal!==null)}getAllCategories(){return new Map(this.categories)}getCategory(e){return this.categories.get(e)}getRequiresInit(){return this.getAll().filter(e=>e.requiresProject)}getWithBlockingRules(){return this.getAll().filter(e=>e.blockingRules!==void 0)}getOptionalCommands(){return this.getAll().filter(e=>e.isOptional)}getDeprecatedCommands(){return this.getAll().filter(e=>e.deprecated)}getStats(){let e=this.getAll(),t={};for(let s of this.categories.keys())t[s]=e.filter(r=>r.group===s).length;return{total:e.length,implemented:e.filter(s=>s.implemented).length,withTemplates:e.filter(s=>s.hasTemplate).length,claudeOnly:e.filter(s=>s.usage.claude&&!s.usage.terminal).length,terminalOnly:e.filter(s=>!s.usage.claude&&s.usage.terminal).length,both:e.filter(s=>s.usage.claude&&s.usage.terminal).length,requiresInit:e.filter(s=>s.requiresProject).length,byCategory:t}}validate(){let e=[],t=this.getAll(),s=t.map(a=>a.name),r=s.filter((a,l)=>s.indexOf(a)!==l);r.length>0&&e.push(`Duplicate command names: ${r.join(", ")}`);let o=t.filter(a=>a.hasTemplate&&!a.implemented);o.length>0&&e.push(`Commands with templates but not implemented: ${o.map(a=>a.name).join(", ")}`);let i=Array.from(this.categories.keys());if(i.length>0){let a=t.filter(l=>!i.includes(l.group));a.length>0&&e.push(`Invalid categories: ${a.map(l=>`${l.name}:${l.group}`).join(", ")}`)}return{valid:e.length===0,issues:e}}async buildContext(e){let t=await A.getProjectId(e);if(!t)throw new Error("No prjct project found. Run /p:init first.");return{projectId:t,projectPath:e,globalPath:$.getGlobalProjectPath(t),timestamp:x()}}async execute(e,t,s=process.cwd()){let r=this.metadata.get(e),o;if(r?.requiresProject===!1)o={projectId:"",projectPath:s,globalPath:"",timestamp:x()};else try{o=await this.buildContext(s)}catch(l){return{success:!1,error:k(l)}}let i=this.handlers.get(e);if(i)return i.execute(t,o);let a=this.handlerFns.get(e);return a?a(t,o):{success:!1,error:`Command not found: ${e}`}}async executeWithoutProject(e,t,s=process.cwd()){let r=this.handlers.get(e);if(r){let i={projectId:"",projectPath:s,globalPath:"",timestamp:x()};return r.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:s,globalPath:"",timestamp:x()};return o(t,i)}return{success:!1,error:`Command not found: ${e}`}}clear(){this.handlers.clear(),this.handlerFns.clear(),this.metadata.clear(),this.categories.clear()}},se=new xl});var Fr,Yn,Rl=h(()=>{"use strict";Fr={core:{title:"Core Workflow",description:"13 essential commands for daily development workflow",order:1},optional:{title:"Optional Commands",description:"Advanced features for specialized workflows",order:2},setup:{title:"Setup",description:"Installation and configuration (not for daily use)",order:3}},Yn=[{name:"init",group:"core",description:"Deep project analysis and initialization",usage:{claude:'/p:init "[idea]"',terminal:'prjct init "[idea]"'},params:"[idea]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0,features:["Architect mode for blank projects","Auto tech stack recommendation","Analyzes existing codebases"]},{name:"task",group:"core",description:"Register a task (or show the active one)",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"[description]",implemented:!0,hasTemplate:!0,requiresProject:!0,features:["No arg \u2192 shows the active task (or none)","Writes to stateStorage; runs before/after workflow rules","Optional Linear issue link when the arg matches `[A-Z]+-\\d+`"]},{name:"ship",group:"core",description:"Commit, push, and celebrate shipped feature",usage:{claude:'/p:ship ["feature"]',terminal:'prjct ship ["feature"]'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["No arg \u2192 ships the active task description, or falls back to current work"]},{name:"sync",group:"core",description:"Sync project state and update workflow agents",usage:{claude:"/p:sync",terminal:"prjct sync [--package=<name>] [--full]"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Incremental sync: only re-analyzes changed files (default)","Force full sync: --full bypasses incremental cache","Monorepo support: --package=<name> for single package sync","Nested PRJCT.md inheritance","Per-package CLAUDE.md generation"]},{name:"regen",group:"core",description:"Full rebuild of the Obsidian vault for the current project",usage:{claude:"/p:regen",terminal:"prjct regen [--md]"},implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!1,features:["Nukes `_generated/` and rebuilds from SQLite + CHANGELOG","Use after upgrading prjct-cli to migrate an old vault layout","Idempotent \u2014 same output if nothing changed"]},{name:"suggest",group:"core",description:"Smart recommendations based on project state",usage:{claude:"/p:suggest",terminal:"prjct suggest"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"status",group:"core",description:"Inline status change on the active task (Linear-style escape hatch)",usage:{claude:"/p:status <value>",terminal:"prjct status <value>"},params:"[value]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["No args \u2192 prints active task + current status","Workflows are the primary status-change mechanism; this is the escape"]},{name:"tag",group:"core",description:"Attach k:v tags to the active task (type:bug, domain:frontend, \u2026)",usage:{claude:"/p:tag type:bug",terminal:"prjct tag type:bug domain:auth"},params:"<pairs...>",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Claude decides what to tag \u2014 no heuristic classifier","type:<feature|bug|improvement|chore> promotes to tasks.type"]},{name:"remember",group:"core",description:"Capture a project memory entry (fact, decision, learning, gotcha, \u2026)",usage:{claude:'/p:remember learning "message"',terminal:'prjct remember learning "message" --tags domain:auth'},params:'<type> "<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Types: fact, decision, learning, gotcha, pattern, anti-pattern, shipped, inbox, todo, idea, insight, question, source, person \u2014 plus user-defined","Grows the project memory consumable via `prjct context memory`"]},{name:"capture",group:"core",description:"GTD-style universal inbox \u2014 dump anything to project memory with zero ceremony",usage:{claude:'/p:capture "<anything>"',terminal:'prjct capture "call Ana re pricing" --tags domain:sales'},params:'"<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Writes memory type=inbox; Claude retypes later via a clarify workflow","No task id, no branch, no worktree \u2014 just persists",'Bare `prjct "<text>"` auto-routes to `capture`']},{name:"seed",group:"core",description:"Manage declarative packs (persona, memory types, workflow slots, hook signals)",usage:{claude:"/p:seed list",terminal:"prjct seed add pm,daily"},params:"[add|remove|list|suggest] [pack,pack,...]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Packs declare signals only \u2014 no bash is written","Add or remove multi-persona contexts per project","Auto-detect suggestion from project stack"]},{name:"install",group:"core",description:"Install Claude Code hooks (~/.claude/settings.json merge-safe)",usage:{claude:"/p:install",terminal:"prjct install"},params:"",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Writes 7 passive hooks: SessionStart, UserPromptSubmit, \u2026","Idempotent; existing non-prjct hooks stay intact","Remove with `prjct claude uninstall`"]},{name:"help",group:"core",description:"Contextual help and guidance",usage:{claude:"/p:help [topic]",terminal:"prjct help [topic]"},params:"[topic]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"analyze",group:"optional",description:"Analyze repository and sync tasks",usage:{claude:"/p:analyze",terminal:"prjct analyze"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"git",group:"optional",description:"Smart git operations with context",usage:{claude:"/p:git [op]",terminal:"prjct git [op]"},params:"[operation]",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"test",group:"optional",description:"Run tests with auto-fix",usage:{claude:"/p:test",terminal:"prjct test"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"workflow",group:"optional",description:"Configure workflow hooks via natural language",usage:{claude:'/p:workflow ["config"]',terminal:'prjct workflow ["config"]'},params:'["natural language config"]',implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Natural language configuration","Before/after hooks for task, done, ship, sync","Permanent, session, or one-time preferences"]},{name:"start",group:"setup",description:"First-time setup (install commands to editors)",usage:{claude:null,terminal:"prjct start"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"setup",group:"setup",description:"Reconfigure editor installations",usage:{claude:"/p:setup",terminal:"prjct setup"},params:"[--force] [--editor <name>]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"migrate",group:"setup",description:"Migrate project to UUID format + sync",usage:{claude:"/p:migrate",terminal:null},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"login",group:"setup",description:"Authenticate with prjct cloud (opens browser)",usage:{claude:null,terminal:"prjct login [--url <webUrl>]"},params:"[--url <webUrl>]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"logout",group:"setup",description:"Sign out from prjct cloud",usage:{claude:null,terminal:"prjct logout"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"auth",group:"setup",description:"Manage cloud authentication",usage:{claude:"/p:auth [action]",terminal:"prjct auth [action]"},params:"[login|logout|status]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"context",group:"setup",description:"Smart context filtering tools for AI agents",usage:{claude:null,terminal:"prjct context <tool> [args]"},params:"<tool> [args]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["files - Find relevant files for a task","signatures - Extract code structure (~90% compression)","imports - Analyze dependency graphs","recent - Find hot files from git history","summary - Intelligent file summarization"]},{name:"update",group:"setup",description:"Update prjct system-wide: package + migrations + daemon restart",usage:{claude:null,terminal:"prjct update [--dry-run]"},params:"[--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Phase 1: npm update (migrates homebrew \u2192 npm if needed)","Phase 2: All projects \u2014 migrate, sweep, reinstall commands","Phase 3: Daemon stop + restart with new code","--dry-run to preview without changes"]},{name:"uninstall",group:"setup",description:"Complete system removal of prjct",usage:{claude:null,terminal:"prjct uninstall"},params:"[--force] [--backup] [--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Removes ~/.prjct-cli/ data","Cleans CLAUDE.md prjct section","Uninstalls Homebrew/npm packages","Backup option before deletion"]}]});var Wg={};G(Wg,{UninstallCommands:()=>Hr,uninstall:()=>Hg});import{execSync as ki}from"node:child_process";import dt from"node:fs/promises";import Nb from"node:os";import ds from"node:path";import Ob from"node:readline";import be from"chalk";async function Fg(n){let e=0;try{let t=await dt.readdir(n,{withFileTypes:!0});for(let s of t){let r=ds.join(n,s.name);if(s.isDirectory())e+=await Fg(r);else try{let o=await dt.stat(r);e+=o.size}catch{}}}catch{}return e}function Lg(n){if(n===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(n)/Math.log(1024));return`${(n/1024**t).toFixed(1)} ${e[t]}`}async function _b(n){try{return(await dt.readdir(n,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}function Lb(){let n={homebrew:!1,npm:!1};try{ki("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(n.homebrew=!0,n.homebrewFormula="prjct-cli")}catch{}try{ki("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(n.npm=!0)}catch{}return n}async function Fb(){let n=[],e=Ha(),t=$.getGlobalBasePath(),s=await v(t),r=s?await _b(ds.join(t,"projects")):0,o=s?await Fg(t):0;n.push({path:t,type:"directory",description:`All project data${r>0?`, ${r} project${r>1?"s":""}`:""}`,size:o,count:r,exists:s});let i=ds.join(e.claude.config,"CLAUDE.md"),a=await v(i),l=!1;if(a)try{let b=await dt.readFile(i,"utf-8");l=b.includes(Si)&&b.includes(Ur)}catch{}n.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&l});let u=e.claude.router,d=await v(u);n.push({path:u,type:"file",description:"Claude router",exists:d});let m=ds.join(e.claude.config,"prjct-statusline.sh"),p=await v(m);n.push({path:m,type:"file",description:"Status line script",exists:p});let g=e.gemini.router,y=await v(g);n.push({path:g,type:"file",description:"Gemini router",exists:y});let j=ds.join(e.gemini.config,"GEMINI.md"),E=await v(j),R=!1;if(E)try{let b=await dt.readFile(j,"utf-8");R=b.includes(Si)&&b.includes(Ur)}catch{}return E&&R&&n.push({path:j,type:"section",description:"prjct section in GEMINI.md",exists:!0}),n}async function Ub(n){try{let e=await dt.readFile(n,"utf-8");if(!e.includes(Si)||!e.includes(Ur))return!1;let t=e.indexOf(Si),s=e.indexOf(Ur)+Ur.length,r=e.substring(0,t)+e.substring(s);return r=r.replace(/\n{3,}/g,`
|
|
1168
|
+
Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:s}}async _workflowDelete(e,t,s){let r=e.trim();if(!r){let o="Usage: prjct workflow delete <name>";return s.md?console.log(`> ${o}`):f.warn(o),{success:!1,error:o}}try{if(!De.deleteWorkflow(t,r)){let i=`Workflow '${r}' not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return await Cl.deleteWorkflowTemplate(r),s.md?console.log(V(Re("Workflow Deleted",`Deleted workflow: ${r}`))):f.done(`deleted workflow: ${r}`),{success:!0}}catch(o){let i=k(o);return s.md?console.log(`> Error: ${i}`):f.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await A.getProjectId(t);if(!o)return s.md?console.log("> No project ID found. Run `prjct init` first."):f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e.trim();if(!i){let u="Usage: prjct workflow run <name>";return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let a=De.getWorkflow(o,i);if(!a||!a.enabled){let u=`Workflow '${i}' not found`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let l=await js(o,i,"before",{projectPath:t});if(!l.success){if(s.md)Yp("failed","workflow_gates_failed",[{label:"View rules",command:`prjct workflow ${i} --md`}]);else if(f.fail("Workflow gates failed"),l.gatesFailed)for(let u of l.gatesFailed)console.log(` \u2717 ${u}`);return{success:!1,error:"Workflow gates failed",gatesFailed:l.gatesFailed}}return await js(o,i,"after",{projectPath:t}),s.md?console.log(V(Re(`Workflow: ${i}`,a.description||""),Je([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):f.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(r){let o=k(r);return s.md?console.log(`> Error: ${o}`):f.fail(o),{success:!1,error:o}}}};c(Mb,"buildFlowDiagram")});var Rs,KL,jl=h(()=>{"use strict";ai();ol();li();_r();ii();dl();pi();Sl();oi();bl();Pl();Rs=class{static{c(this,"PrjctCommands")}workflow;planning;shipping;analysis;setupCmds;updateCmds;contextCmds;primitivesCmds;seedCmds;installCmds;captureCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new Kn,this.planning=new Ys,this.shipping=new Ks,this.analysis=new en,this.setupCmds=new Bn,this.updateCmds=new Xn,this.contextCmds=new xs,this.primitivesCmds=new Vn,this.seedCmds=new sn,this.installCmds=new tn,this.captureCmds=new Wn,this.agent=null,this.agentInfo=null,this.currentAuthor=null,this.prjctDir=".prjct"}async task(e=null,t=process.cwd(),s={}){return this.workflow.now(e,t,s)}async workflowPrefs(e=null,t=process.cwd(),s={}){return this.workflow.workflow(e,t,s)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async ship(e,t=process.cwd(),s={}){return this.shipping.ship(e,t,{...s})}async analyze(e={},t=process.cwd()){return this.analysis.analyze(e,t)}async sync(e=process.cwd(),t={}){return this.analysis.sync(e,t)}async saveLlmAnalysis(e,t=process.cwd(),s={}){return this.analysis.saveLlmAnalysis(e,t,s)}async regenVault(e=process.cwd(),t={}){return this.analysis.regenVault(e,t)}async context(e=null,t=process.cwd(),s={}){return this.contextCmds.context(e,t,s)}async status(e=null,t=process.cwd(),s={}){return this.primitivesCmds.status(e,t,s)}async tag(e=null,t=process.cwd(),s={}){return this.primitivesCmds.tag(e,t,s)}async remember(e=null,t=process.cwd(),s={}){return this.primitivesCmds.remember(e,t,s)}async seed(e=null,t=process.cwd(),s={}){return this.seedCmds.seed(e,t,s)}async install(e=null,t=process.cwd(),s={}){return this.installCmds.install(null,t,s)}async capture(e=null,t=process.cwd(),s={}){return this.captureCmds.capture(e,t,s)}async auth(e=null,t={}){return this.setupCmds.auth(e,t)}async login(e={}){return this.setupCmds.login(e)}async logout(){return this.setupCmds.logout()}async start(){return this.setupCmds.start()}async setup(e={}){return this.setupCmds.setup(e)}async update(e={},t=process.cwd()){return this.updateCmds.update(e,t)}async installStatusLine(){return this.setupCmds.installStatusLine()}showAsciiArt(){this.setupCmds.showAsciiArt()}async initializeAgent(){return this.workflow.initializeAgent()}async ensureProjectInit(e){return this.workflow.ensureProjectInit(e)}async ensureAuthor(){return this.workflow.ensureAuthor()}async getGlobalProjectPath(e){return this.workflow.getGlobalProjectPath(e)}async logToMemory(e,t,s){return this.workflow.logToMemory(e,t,s)}},KL=new Rs});var xl,se,wi=h(()=>{"use strict";ie();Pe();q();Ce();xl=class{static{c(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll"]);register(e,t){this.handlers.set(e.name,e),this.setMeta(e.name,t)}registerFn(e,t,s){this.handlerFns.set(e,t),this.setMeta(e,s)}setMeta(e,t){let s=t?.requiresProject??!this.noProjectCommands.has(e);this.metadata.set(e,{name:e,group:t?.group??"unknown",description:t?.description??"",requiresProject:s,usage:t?.usage??{claude:null,terminal:null},implemented:t?.implemented??!0,hasTemplate:t?.hasTemplate??!1,params:t?.params,blockingRules:t?.blockingRules,features:t?.features,isOptional:t?.isOptional,deprecated:t?.deprecated,replacedBy:t?.replacedBy})}registerCategory(e,t){this.categories.set(e,t)}registerMethod(e,t,s,r){let o=t[s];if(typeof o!="function")throw new Error(`${String(s)} is not a function`);let i=c(async(a,l)=>a!=null?o.call(t,a,l.projectPath):o.call(t,l.projectPath),"wrapper");this.handlerFns.set(e,i),this.setMeta(e,r)}has(e){return this.handlers.has(e)||this.handlerFns.has(e)}list(){return[...this.handlers.keys(),...this.handlerFns.keys()]}listByGroup(e){return Array.from(this.metadata.entries()).filter(([,t])=>t.group===e).map(([t])=>t)}getGroups(){let e=new Set;for(let t of this.metadata.values())e.add(t.group);return Array.from(e)}getMeta(e){return this.metadata.get(e)}getAll(){return Array.from(this.metadata.values())}getByName(e){return this.metadata.get(e)}getByCategory(e){return this.getAll().filter(t=>t.group===e)}getAllImplemented(){return this.getAll().filter(e=>e.implemented)}getAllWithTemplates(){return this.getAll().filter(e=>e.hasTemplate)}getClaudeCommands(){return this.getAll().filter(e=>e.usage.claude!==null)}getTerminalCommands(){return this.getAll().filter(e=>e.usage.terminal!==null)}getAllCategories(){return new Map(this.categories)}getCategory(e){return this.categories.get(e)}getRequiresInit(){return this.getAll().filter(e=>e.requiresProject)}getWithBlockingRules(){return this.getAll().filter(e=>e.blockingRules!==void 0)}getOptionalCommands(){return this.getAll().filter(e=>e.isOptional)}getDeprecatedCommands(){return this.getAll().filter(e=>e.deprecated)}getStats(){let e=this.getAll(),t={};for(let s of this.categories.keys())t[s]=e.filter(r=>r.group===s).length;return{total:e.length,implemented:e.filter(s=>s.implemented).length,withTemplates:e.filter(s=>s.hasTemplate).length,claudeOnly:e.filter(s=>s.usage.claude&&!s.usage.terminal).length,terminalOnly:e.filter(s=>!s.usage.claude&&s.usage.terminal).length,both:e.filter(s=>s.usage.claude&&s.usage.terminal).length,requiresInit:e.filter(s=>s.requiresProject).length,byCategory:t}}validate(){let e=[],t=this.getAll(),s=t.map(a=>a.name),r=s.filter((a,l)=>s.indexOf(a)!==l);r.length>0&&e.push(`Duplicate command names: ${r.join(", ")}`);let o=t.filter(a=>a.hasTemplate&&!a.implemented);o.length>0&&e.push(`Commands with templates but not implemented: ${o.map(a=>a.name).join(", ")}`);let i=Array.from(this.categories.keys());if(i.length>0){let a=t.filter(l=>!i.includes(l.group));a.length>0&&e.push(`Invalid categories: ${a.map(l=>`${l.name}:${l.group}`).join(", ")}`)}return{valid:e.length===0,issues:e}}async buildContext(e){let t=await A.getProjectId(e);if(!t)throw new Error("No prjct project found. Run /p:init first.");return{projectId:t,projectPath:e,globalPath:$.getGlobalProjectPath(t),timestamp:x()}}async execute(e,t,s=process.cwd()){let r=this.metadata.get(e),o;if(r?.requiresProject===!1)o={projectId:"",projectPath:s,globalPath:"",timestamp:x()};else try{o=await this.buildContext(s)}catch(l){return{success:!1,error:k(l)}}let i=this.handlers.get(e);if(i)return i.execute(t,o);let a=this.handlerFns.get(e);return a?a(t,o):{success:!1,error:`Command not found: ${e}`}}async executeWithoutProject(e,t,s=process.cwd()){let r=this.handlers.get(e);if(r){let i={projectId:"",projectPath:s,globalPath:"",timestamp:x()};return r.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:s,globalPath:"",timestamp:x()};return o(t,i)}return{success:!1,error:`Command not found: ${e}`}}clear(){this.handlers.clear(),this.handlerFns.clear(),this.metadata.clear(),this.categories.clear()}},se=new xl});var Fr,Yn,Rl=h(()=>{"use strict";Fr={core:{title:"Core Workflow",description:"13 essential commands for daily development workflow",order:1},optional:{title:"Optional Commands",description:"Advanced features for specialized workflows",order:2},setup:{title:"Setup",description:"Installation and configuration (not for daily use)",order:3}},Yn=[{name:"init",group:"core",description:"Deep project analysis and initialization",usage:{claude:'/p:init "[idea]"',terminal:'prjct init "[idea]"'},params:"[idea]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0,features:["Architect mode for blank projects","Auto tech stack recommendation","Analyzes existing codebases"]},{name:"task",group:"core",description:"Register a task (or show the active one)",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"[description]",implemented:!0,hasTemplate:!0,requiresProject:!0,features:["No arg \u2192 shows the active task (or none)","Writes to stateStorage; runs before/after workflow rules","Optional Linear issue link when the arg matches `[A-Z]+-\\d+`"]},{name:"ship",group:"core",description:"Commit, push, and celebrate shipped feature",usage:{claude:'/p:ship ["feature"]',terminal:'prjct ship ["feature"]'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["No arg \u2192 ships the active task description, or falls back to current work"]},{name:"sync",group:"core",description:"Sync project state and update workflow agents",usage:{claude:"/p:sync",terminal:"prjct sync [--package=<name>] [--full]"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Incremental sync: only re-analyzes changed files (default)","Force full sync: --full bypasses incremental cache","Monorepo support: --package=<name> for single package sync","Nested PRJCT.md inheritance","Per-package CLAUDE.md generation"]},{name:"regen",group:"core",description:"Full rebuild of the Obsidian vault for the current project",usage:{claude:"/p:regen",terminal:"prjct regen [--md]"},implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!1,features:["Nukes `_generated/` and rebuilds from SQLite + CHANGELOG","Use after upgrading prjct-cli to migrate an old vault layout","Idempotent \u2014 same output if nothing changed"]},{name:"suggest",group:"core",description:"Smart recommendations based on project state",usage:{claude:"/p:suggest",terminal:"prjct suggest"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"status",group:"core",description:"Inline status change on the active task (Linear-style escape hatch)",usage:{claude:"/p:status <value>",terminal:"prjct status <value>"},params:"[value]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["No args \u2192 prints active task + current status","Workflows are the primary status-change mechanism; this is the escape"]},{name:"tag",group:"core",description:"Attach k:v tags to the active task (type:bug, domain:frontend, \u2026)",usage:{claude:"/p:tag type:bug",terminal:"prjct tag type:bug domain:auth"},params:"<pairs...>",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Claude decides what to tag \u2014 no heuristic classifier","type:<feature|bug|improvement|chore> promotes to tasks.type"]},{name:"remember",group:"core",description:"Capture a project memory entry (fact, decision, learning, gotcha, \u2026)",usage:{claude:'/p:remember learning "message"',terminal:'prjct remember learning "message" --tags domain:auth'},params:'<type> "<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Types: fact, decision, learning, gotcha, pattern, anti-pattern, shipped, inbox, todo, idea, insight, question, source, person \u2014 plus user-defined","Grows the project memory consumable via `prjct context memory`"]},{name:"capture",group:"core",description:"GTD-style universal inbox \u2014 dump anything to project memory with zero ceremony",usage:{claude:'/p:capture "<anything>"',terminal:'prjct capture "call Ana re pricing" --tags domain:sales'},params:'"<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Writes memory type=inbox; Claude retypes later via a clarify workflow","No task id, no branch, no worktree \u2014 just persists",'Bare `prjct "<text>"` auto-routes to `capture`']},{name:"seed",group:"core",description:"Manage declarative packs (persona, memory types, workflow slots, hook signals)",usage:{claude:"/p:seed list",terminal:"prjct seed add pm,daily"},params:"[add|remove|list|suggest] [pack,pack,...]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Packs declare signals only \u2014 no bash is written","Add or remove multi-persona contexts per project","Auto-detect suggestion from project stack"]},{name:"install",group:"core",description:"Install Claude Code hooks (~/.claude/settings.json merge-safe)",usage:{claude:"/p:install",terminal:"prjct install"},params:"",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Writes 7 passive hooks: SessionStart, UserPromptSubmit, \u2026","Idempotent; existing non-prjct hooks stay intact","Remove with `prjct claude uninstall`"]},{name:"help",group:"core",description:"Contextual help and guidance",usage:{claude:"/p:help [topic]",terminal:"prjct help [topic]"},params:"[topic]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"analyze",group:"optional",description:"Analyze repository and sync tasks",usage:{claude:"/p:analyze",terminal:"prjct analyze"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"git",group:"optional",description:"Smart git operations with context",usage:{claude:"/p:git [op]",terminal:"prjct git [op]"},params:"[operation]",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"test",group:"optional",description:"Run tests with auto-fix",usage:{claude:"/p:test",terminal:"prjct test"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"workflow",group:"optional",description:"Configure workflow hooks via natural language",usage:{claude:'/p:workflow ["config"]',terminal:'prjct workflow ["config"]'},params:'["natural language config"]',implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Natural language configuration","Before/after hooks for task, done, ship, sync","Permanent, session, or one-time preferences"]},{name:"start",group:"setup",description:"First-time setup (install commands to editors)",usage:{claude:null,terminal:"prjct start"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"setup",group:"setup",description:"Reconfigure editor installations",usage:{claude:"/p:setup",terminal:"prjct setup"},params:"[--force] [--editor <name>]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"migrate",group:"setup",description:"Migrate project to UUID format + sync",usage:{claude:"/p:migrate",terminal:null},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"login",group:"setup",description:"Authenticate with prjct cloud (opens browser)",usage:{claude:null,terminal:"prjct login [--url <webUrl>]"},params:"[--url <webUrl>]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"logout",group:"setup",description:"Sign out from prjct cloud",usage:{claude:null,terminal:"prjct logout"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"auth",group:"setup",description:"Manage cloud authentication",usage:{claude:"/p:auth [action]",terminal:"prjct auth [action]"},params:"[login|logout|status]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"context",group:"setup",description:"Smart context filtering tools for AI agents",usage:{claude:null,terminal:"prjct context <tool> [args]"},params:"<tool> [args]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["files - Find relevant files for a task","signatures - Extract code structure (~90% compression)","imports - Analyze dependency graphs","recent - Find hot files from git history","summary - Intelligent file summarization"]},{name:"update",group:"setup",description:"Update prjct system-wide: package + migrations + daemon restart",usage:{claude:null,terminal:"prjct update [--dry-run]"},params:"[--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Phase 1: npm update (migrates homebrew \u2192 npm if needed)","Phase 2: All projects \u2014 migrate, sweep, reinstall commands","Phase 3: Daemon stop + restart with new code","--dry-run to preview without changes"]},{name:"uninstall",group:"setup",description:"Complete system removal of prjct",usage:{claude:null,terminal:"prjct uninstall"},params:"[--force] [--backup] [--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Removes ~/.prjct-cli/ data","Cleans CLAUDE.md prjct section","Uninstalls Homebrew/npm packages","Backup option before deletion"]}]});var Wg={};G(Wg,{UninstallCommands:()=>Hr,uninstall:()=>Hg});import{execSync as ki}from"node:child_process";import dt from"node:fs/promises";import Nb from"node:os";import ds from"node:path";import Ob from"node:readline";import be from"chalk";async function Fg(n){let e=0;try{let t=await dt.readdir(n,{withFileTypes:!0});for(let s of t){let r=ds.join(n,s.name);if(s.isDirectory())e+=await Fg(r);else try{let o=await dt.stat(r);e+=o.size}catch{}}}catch{}return e}function Lg(n){if(n===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(n)/Math.log(1024));return`${(n/1024**t).toFixed(1)} ${e[t]}`}async function _b(n){try{return(await dt.readdir(n,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}function Lb(){let n={homebrew:!1,npm:!1};try{ki("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(n.homebrew=!0,n.homebrewFormula="prjct-cli")}catch{}try{ki("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(n.npm=!0)}catch{}return n}async function Fb(){let n=[],e=Ha(),t=$.getGlobalBasePath(),s=await v(t),r=s?await _b(ds.join(t,"projects")):0,o=s?await Fg(t):0;n.push({path:t,type:"directory",description:`All project data${r>0?`, ${r} project${r>1?"s":""}`:""}`,size:o,count:r,exists:s});let i=ds.join(e.claude.config,"CLAUDE.md"),a=await v(i),l=!1;if(a)try{let b=await dt.readFile(i,"utf-8");l=b.includes(Si)&&b.includes(Ur)}catch{}n.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&l});let u=e.claude.router,d=await v(u);n.push({path:u,type:"file",description:"Claude router",exists:d});let m=ds.join(e.claude.config,"prjct-statusline.sh"),p=await v(m);n.push({path:m,type:"file",description:"Status line script",exists:p});let g=e.gemini.router,y=await v(g);n.push({path:g,type:"file",description:"Gemini router",exists:y});let j=ds.join(e.gemini.config,"GEMINI.md"),E=await v(j),R=!1;if(E)try{let b=await dt.readFile(j,"utf-8");R=b.includes(Si)&&b.includes(Ur)}catch{}return E&&R&&n.push({path:j,type:"section",description:"prjct section in GEMINI.md",exists:!0}),n}async function Ub(n){try{let e=await dt.readFile(n,"utf-8");if(!e.includes(Si)||!e.includes(Ur))return!1;let t=e.indexOf(Si),s=e.indexOf(Ur)+Ur.length,r=e.substring(0,t)+e.substring(s);return r=r.replace(/\n{3,}/g,`
|
|
1169
1169
|
|
|
1170
1170
|
`).trim(),!r||r.trim().length===0?await dt.unlink(n):await dt.writeFile(n,`${r}
|
|
1171
1171
|
`,"utf-8"),!0}catch{return!1}}async function Hb(){let n=Nb.homedir(),e=new Date().toISOString().replace(/[:.]/g,"-").substring(0,19),t=ds.join(n,`.prjct-backup-${e}`);try{await dt.mkdir(t,{recursive:!0});let s=$.getGlobalBasePath();return await v(s)&&await Ug(s,ds.join(t,".prjct-cli")),t}catch{return null}}async function Ug(n,e){await dt.mkdir(e,{recursive:!0});let t=await dt.readdir(n,{withFileTypes:!0});for(let s of t){let r=ds.join(n,s.name),o=ds.join(e,s.name);s.isDirectory()?await Ug(r,o):await dt.copyFile(r,o)}}async function Wb(n,e,t){let s=[],r=[];for(let o of n)if(o.exists)try{o.type==="section"?await Ub(o.path)&&s.push(o.path):o.type==="directory"?(await dt.rm(o.path,{recursive:!0,force:!0}),s.push(o.path)):o.type==="file"&&(await dt.unlink(o.path),s.push(o.path))}catch(i){r.push(`${o.path}: ${k(i)}`)}try{await new Ht().cleanupLegacyCommands()}catch{}if(!t.keepPackage){if(e.homebrew&&e.homebrewFormula)try{t.dryRun||ki(`brew uninstall ${e.homebrewFormula}`,{stdio:"pipe"}),s.push("Homebrew: prjct-cli")}catch(o){r.push(`Homebrew: ${k(o)}`)}if(e.npm)try{t.dryRun||ki("npm uninstall -g prjct-cli",{stdio:"pipe"}),s.push("npm: prjct-cli")}catch(o){r.push(`npm: ${k(o)}`)}}return{deleted:s,errors:r}}async function Gb(n){let e=Ob.createInterface({input:process.stdin,output:process.stdout});return new Promise(t=>{e.question(n,s=>{e.close(),t(s.toLowerCase()==="uninstall")})})}async function Hg(n={},e=process.cwd()){let t=await Fb(),s=Lb(),r=t.filter(l=>l.exists);if(r.length===0&&!s.homebrew&&!s.npm)return console.log(be.yellow(`
|
|
@@ -1328,26 +1328,31 @@ ${o.split(`
|
|
|
1328
1328
|
\u2026 [truncated]`:a}async function UT(n=process.cwd()){await mt(async()=>{let t=((await pt()).prompt??"").trim();if(!t){Fe({});return}let s=await pf(n,t);Fe(Pt("UserPromptSubmit",s))})}var df,Ol,gf=h(()=>{"use strict";ie();cs();Is();df=1500,Ol=4;c(pf,"buildPromptContext");c(UT,"runPromptHook")});var yf={};G(yf,{buildPreCommitContext:()=>hf,runPreCommitHook:()=>BT});import{execSync as HT}from"node:child_process";function GT(n){try{return HT("git diff --cached --name-only",{cwd:n,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).split(`
|
|
1329
1329
|
`).map(e=>e.trim()).filter(Boolean)}catch{return[]}}function VT(n){let e=new Set;for(let t of n){let s=t.split("/").filter(Boolean);for(let r of s){let o=r.replace(/\.[^.]+$/,"").toLowerCase();o.length>=3&&e.add(o)}}return[...e]}function qT(n,e){let t=n.content.toLowerCase();if(e.some(s=>t.includes(s)))return!0;for(let s of Object.values(n.tags)){let r=s.toLowerCase();if(e.some(o=>r.includes(o)))return!0}return!1}async function hf(n){let e=await A.readConfig(n);if(!e?.projectId)return null;let t=GT(n);if(t.length===0)return null;let s=VT(t);if(s.length===0)return null;let r;try{r=ze.recall(e.projectId,{types:["anti-pattern","gotcha"],limit:50})}catch{return null}let o=r.filter(l=>qT(l,s)).slice(0,WT);if(o.length===0)return null;let i=["# prjct: heads-up for this commit",""];i.push(`${o.length} anti-pattern/gotcha entr${o.length===1?"y":"ies"} match the staged files.`),i.push(""),i.push(ft(o)),i.push(""),i.push("> Nudge, not block. Proceed if you think it still applies.");let a=i.join(`
|
|
1330
1330
|
`);return a.length>ff?`${a.slice(0,ff-20)}
|
|
1331
|
-
\u2026 [truncated]`:a}async function BT(n=process.cwd()){await mt(async()=>{let t=(await pt()).tool_input?.command??"";if(!/\bgit\s+commit\b/.test(t)){Fe({});return}let s=await hf(n);Fe(Pt("PreToolUse",s))})}var ff,WT,wf=h(()=>{"use strict";ie();cs();Is();ff=1200,WT=3;c(GT,"stagedFiles");c(VT,"pathFragments");c(qT,"mentionsFragment");c(hf,"buildPreCommitContext");c(BT,"runPreCommitHook")});var kf={};G(kf,{runPostEditHook:()=>JT});async function JT(n=process.cwd()){await mt(async()=>{let e=await pt(),t=e.tool_input?.file_path;if(!t){Fe({});return}if(!(await A.readConfig(n))?.projectId){Fe({});return}try{await Ze.log(n,"post_edit",{file:t,tool:e.tool_name??"unknown"})}catch{}Fe({})})}var Sf=h(()=>{"use strict";ie();Cs();Is();c(JT,"runPostEditHook")});var bf={};G(bf,{buildStopContext:()=>vf,runStopHook:()=>
|
|
1332
|
-
|
|
1333
|
-
|
|
1331
|
+
\u2026 [truncated]`:a}async function BT(n=process.cwd()){await mt(async()=>{let t=(await pt()).tool_input?.command??"";if(!/\bgit\s+commit\b/.test(t)){Fe({});return}let s=await hf(n);Fe(Pt("PreToolUse",s))})}var ff,WT,wf=h(()=>{"use strict";ie();cs();Is();ff=1200,WT=3;c(GT,"stagedFiles");c(VT,"pathFragments");c(qT,"mentionsFragment");c(hf,"buildPreCommitContext");c(BT,"runPreCommitHook")});var kf={};G(kf,{runPostEditHook:()=>JT});async function JT(n=process.cwd()){await mt(async()=>{let e=await pt(),t=e.tool_input?.file_path;if(!t){Fe({});return}if(!(await A.readConfig(n))?.projectId){Fe({});return}try{await Ze.log(n,"post_edit",{file:t,tool:e.tool_name??"unknown"})}catch{}Fe({})})}var Sf=h(()=>{"use strict";ie();Cs();Is();c(JT,"runPostEditHook")});var bf={};G(bf,{buildStopContext:()=>vf,runStopHook:()=>KT});async function vf(n){let e=await A.readConfig(n);if(!e?.projectId)return null;let t=e.projectId,s=new Date(Date.now()-zT).toISOString(),r;try{r=L.query(t,`SELECT
|
|
1332
|
+
CASE WHEN type = ? THEN 'edit' ELSE 'checkpoint' END AS type,
|
|
1333
|
+
COUNT(*) AS count
|
|
1334
|
+
FROM events
|
|
1335
|
+
WHERE type LIKE 'memory.%' AND timestamp > ?
|
|
1336
|
+
GROUP BY 1`,XT,s)}catch{return null}let o=0,i=0;for(let a of r)a.type==="edit"?o=a.count:i=a.count;return o===0||i>0?null:["# prjct: capture checkpoint","",`${o} file edit${o===1?"":"s"} this session without a memory entry.`,"",'If anything was reusable \u2014 a decision, a gotcha, a pattern \u2014 `prjct remember <type> "<content>"` keeps it around for future sessions.',"","> Skip if nothing worth saving."].join(`
|
|
1337
|
+
`)}async function KT(n=process.cwd()){await mt(async()=>{await pt();let e=await vf(n);Fe(Pt("Stop",e));let t=await A.readConfig(n).catch(()=>null);if(t?.projectId){try{await Yc(n)}catch{}await Or(n,t.projectId).catch(()=>{})}})}var zT,XT,Tf=h(()=>{"use strict";ie();us();si();de();Is();zT=30*60*1e3,XT="memory.post_edit";c(vf,"buildStopContext");c(KT,"runStopHook")});var Ef={};G(Ef,{runSubagentStartHook:()=>YT});async function YT(n=process.cwd()){await mt(async()=>{await pt();let e=await rr(n);Fe(Pt("SubagentStart",e))})}var Cf=h(()=>{"use strict";Is();Ei();c(YT,"runSubagentStartHook")});var Pf={};G(Pf,{runCwdChangedHook:()=>QT});async function QT(n=process.cwd()){await mt(async()=>{let t=(await pt()).cwd||n,s=await rr(t);Fe(Pt("CwdChanged",s))})}var jf=h(()=>{"use strict";Is();Ei();c(QT,"runCwdChangedHook")});var Rf={};G(Rf,{DoctorService:()=>Ci,doctorService:()=>eE});import{execSync as _l}from"node:child_process";import ZT from"node:fs/promises";import xf from"node:path";import $s from"chalk";var Ci,eE,Af=h(()=>{"use strict";ie();Pe();An();lt();z();Le();qe();Pr();Ci=class{static{c(this,"DoctorService")}projectPath="";projectId=null;globalPath="";async check(e=process.cwd()){this.projectPath=e,this.projectId=await A.getProjectId(e),this.projectId&&(this.globalPath=$.getGlobalProjectPath(this.projectId));let t=await this.checkTools(),s=await this.checkProject(),r=this.generateRecommendations(t,s),o=[...t,...s].some(a=>a.status==="error"&&!a.optional),i=[...t,...s].some(a=>a.status==="warn"||a.status==="error"&&a.optional);return{success:!o,tools:t,project:s,recommendations:r,hasErrors:o,hasWarnings:i}}async run(e=process.cwd()){let t=await this.check(e);return this.printHeader(),this.printSection("System Tools",t.tools),this.printSection("Project Status",t.project),t.recommendations.length>0&&this.printRecommendations(t.recommendations),this.printSummary(t),t.hasErrors?1:0}async checkTools(){let e=[];return e.push(this.checkCommand("git","git --version",/git version ([\d.]+)/,!1)),e.push(this.checkCommand("node","node --version",/v([\d.]+)/,!1)),e.push(this.checkCommand("bun","bun --version",/([\d.]+)/,!0)),e.push(this.checkCommand("gh","gh --version",/gh version ([\d.]+)/,!0,"needed for PR commands")),e.push(this.checkCommand("claude","claude --version",/claude ([\d.]+)/,!0,"Anthropic Claude Code CLI")),e.push(this.checkCommand("gemini","gemini --version",/gemini ([\d.]+)/,!0,"Google Gemini CLI")),e}checkCommand(e,t,s,r,o){try{let a=_l(t,{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).match(s),l=a?a[1]:"unknown";return{name:e,status:"ok",version:l,optional:r}}catch{return{name:e,status:"error",message:o?`not found (${o})`:"not found",optional:r}}}async checkProject(){let e=[];return e.push(await this.checkPrjctConfig()),e.push(await this.checkClaudeMd()),e.push(await this.checkGitRepo()),e.push(await this.checkStateFile()),e.push(await this.checkContext7()),e.push(await this.checkCodexPRouter()),e}async checkPrjctConfig(){let e=xf.join(this.projectPath,".prjct","prjct.config.json");return await v(e)?{name:"prjct config",status:"ok",message:"initialized"}:{name:"prjct config",status:"error",message:'not initialized - run "prjct init"'}}async checkClaudeMd(){if(!this.globalPath)return{name:"CLAUDE.md",status:"warn",message:"project not initialized"};let e=xf.join(this.globalPath,"context","CLAUDE.md");try{let t=await ZT.stat(e),s=Date.now()-t.mtimeMs,r=Math.floor(s/(1e3*60*60)),o=Math.floor(r/24),i;return o>0?i=`${o} day${o>1?"s":""} ago`:r>0?i=`${r} hour${r>1?"s":""} ago`:i="recently",r>24?{name:"CLAUDE.md",status:"warn",message:`stale (last sync: ${i})`}:{name:"CLAUDE.md",status:"ok",message:`synced ${i}`}}catch{return{name:"CLAUDE.md",status:"error",message:'not found - run "prjct sync"'}}}async checkGitRepo(){try{_l("git rev-parse --git-dir",{cwd:this.projectPath,stdio:["pipe","pipe","pipe"]});let e=_l("git status --porcelain",{cwd:this.projectPath,encoding:"utf-8"});if(e.trim().length>0){let s=e.trim().split(`
|
|
1338
|
+
`).filter(Boolean);return{name:"git repo",status:"ok",message:`${s.length} uncommitted change${s.length>1?"s":""}`}}return{name:"git repo",status:"ok",message:"clean"}}catch{return{name:"git repo",status:"warn",message:"not a git repository"}}}async checkStateFile(){if(!this.globalPath||!this.projectId)return{name:"task state",status:"warn",message:"project not initialized"};try{let e=await M.read(this.projectId);return e.currentTask?{name:"task state",status:"ok",message:`active: ${e.currentTask.description?.slice(0,30)}...`}:{name:"task state",status:"ok",message:"no active task"}}catch{return{name:"task state",status:"ok",message:"no state data (normal for new projects)",optional:!0}}}async checkContext7(){try{let e=await os.verify();return e.installed?e.verified?{name:"context7 mcp",status:"ok",message:"ready"}:{name:"context7 mcp",status:"error",message:e.message||"configured but verification failed"}:{name:"context7 mcp",status:"error",message:'not configured - run "prjct start"'}}catch(e){return{name:"context7 mcp",status:"error",message:`check failed: ${e instanceof Error?e.message:"unknown error"}`}}}async checkCodexPRouter(){try{let e=await Rn({autoRepair:!0});return e.installed?e.verified?{name:"codex p-router",status:"ok",message:`ready (${e.templateSource||"local-dev"})`}:{name:"codex p-router",status:"error",message:e.message||"router verification failed"}:{name:"codex p-router",status:"ok",message:"codex not detected (check skipped)",optional:!0}}catch(e){return{name:"codex p-router",status:"error",message:`check failed: ${e instanceof Error?e.message:"unknown error"}`}}}generateRecommendations(e,t){let s=[];e.find(d=>d.name==="gh"&&d.status==="error")&&s.push("Install GitHub CLI (gh) for PR commands: https://cli.github.com");let o=t.find(d=>d.name==="CLAUDE.md");o?.status==="warn"&&o.message?.includes("stale")&&s.push('Run "prjct sync" to update context');let i=t.find(d=>d.name==="prjct config");i?.status==="error"&&s.push('Run "prjct init" to initialize this project'),t.find(d=>d.name==="CLAUDE.md"&&d.status==="error")&&!i?.status?.includes("error")&&s.push('Run "prjct sync" to generate context files');let l=t.find(d=>d.name==="context7 mcp");l&&l.status!=="ok"&&s.push('Run "prjct start" to install/repair Context7 MCP');let u=t.find(d=>d.name==="codex p-router");return u&&u.status==="error"&&s.push('Run "prjct start" or "prjct setup" to repair Codex p. router'),s}printHeader(){f.section(`prjct doctor v${ce}`)}printSection(e,t){f.section(e);let s=t.map(r=>{let o=this.getStatusIcon(r.status,r.optional),i=r.name.padEnd(14),a=r.version||r.message||"",l=r.optional&&r.status==="error"?$s.dim(" (optional)"):"";return`${o} ${i} ${$s.dim(a)}${l}`});for(let r of s)console.log(` ${r}`)}printRecommendations(e){f.section("Recommendations"),f.list(e,{bullet:$s.yellow("\u2022")})}printSummary(e){console.log(""),console.log($s.dim("\u2500".repeat(40))),e.hasErrors?f.fail("Some required checks failed"):e.hasWarnings?f.warn("All required checks passed (some warnings)"):f.done("All checks passed"),console.log("")}getStatusIcon(e,t){switch(e){case"ok":return $s.green("\u2713");case"warn":return $s.yellow("\u26A0");case"error":return t?$s.dim("\u25CB"):$s.red("\u2717")}}},eE=new Ci});var If={};G(If,{WatchService:()=>Pi,watchService:()=>oE});import tE from"node:path";import Xe from"chalk";import sE from"chokidar";var nE,rE,Pi,oE,$f=h(()=>{"use strict";ie();q();Ce();Ho();nE=["package.json","package-lock.json","bun.lockb","pnpm-lock.yaml","yarn.lock","tsconfig.json","tsconfig.*.json",".env",".env.*","Cargo.toml","go.mod","pyproject.toml","requirements.txt","src/**/*.ts","src/**/*.tsx","src/**/*.js","src/**/*.jsx","lib/**/*.ts","core/**/*.ts","app/**/*.ts","app/**/*.tsx","pages/**/*.ts","pages/**/*.tsx"],rE=["**/node_modules/**","**/.git/**","**/dist/**","**/build/**","**/.next/**","**/.nuxt/**","**/coverage/**","**/*.log","**/*.tmp","**/CLAUDE.md","**/.cursorrules","**/.windsurfrules","**/.prjct/**","**/.prjct-cli/**"],Pi=class{static{c(this,"WatchService")}watcher=null;projectPath="";projectId=null;debounceTimer=null;lastSyncTime=0;pendingChanges=new Set;options={debounceMs:2e3,minIntervalMs:3e4,verbose:!1,quiet:!1};isRunning=!1;syncCount=0;sigintHandler=null;sigtermHandler=null;async start(e=process.cwd(),t={}){return this.projectPath=e,this.options={...this.options,...t},this.projectId=await A.getProjectId(e),this.projectId?this.isRunning?{success:!1,error:"Watch mode is already running"}:(this.isRunning=!0,this.options.quiet||this.printStartup(),this.watcher=sE.watch(nE,{cwd:this.projectPath,ignored:rE,persistent:!0,ignoreInitial:!0,awaitWriteFinish:{stabilityThreshold:500,pollInterval:100}}),this.watcher.on("add",s=>this.handleChange("add",s)).on("change",s=>this.handleChange("change",s)).on("unlink",s=>this.handleChange("unlink",s)).on("error",s=>this.handleError(s)),this.sigintHandler&&process.off("SIGINT",this.sigintHandler),this.sigtermHandler&&process.off("SIGTERM",this.sigtermHandler),this.sigintHandler=()=>this.stop(),this.sigtermHandler=()=>this.stop(),process.on("SIGINT",this.sigintHandler),process.on("SIGTERM",this.sigtermHandler),{success:!0}):{success:!1,error:'No prjct project. Run "prjct init" first.'}}async stop(){this.options.quiet||(console.log(""),console.log(Xe.dim(`
|
|
1334
1339
|
\u{1F44B} Stopped watching (${this.syncCount} syncs performed)`))),this.debounceTimer&&(clearTimeout(this.debounceTimer),this.debounceTimer=null),this.watcher&&(await this.watcher.close(),this.watcher=null),this.sigintHandler&&(process.off("SIGINT",this.sigintHandler),this.sigintHandler=null),this.sigtermHandler&&(process.off("SIGTERM",this.sigtermHandler),this.sigtermHandler=null),this.pendingChanges.clear(),this.isRunning=!1,process.exit(0)}handleChange(e,t){if(this.pendingChanges.add(t),this.options.verbose&&!this.options.quiet){let s=e==="add"?"\u2795":e==="unlink"?"\u2796":"\u{1F4DD}";console.log(Xe.dim(` ${s} ${t}`))}this.scheduleSyncIfNeeded()}scheduleSyncIfNeeded(){this.debounceTimer&&clearTimeout(this.debounceTimer),this.debounceTimer=setTimeout(async()=>{let t=Date.now()-this.lastSyncTime;if(t<this.options.minIntervalMs&&this.lastSyncTime>0){let s=this.options.minIntervalMs-t;this.options.verbose&&!this.options.quiet&&console.log(Xe.dim(` \u23F3 Rate limited, waiting ${Math.round(s/1e3)}s...`)),this.debounceTimer=setTimeout(()=>this.performSync(),s);return}await this.performSync()},this.options.debounceMs)}async performSync(){let e=Array.from(this.pendingChanges);if(this.pendingChanges.clear(),e.length===0)return;let t=x().split("T")[1].split(".")[0];if(!this.options.quiet){let s=e.length===1?e[0]:`${e.length} files`;console.log(`
|
|
1335
|
-
${Xe.dim(`[${t}]`)} ${Xe.cyan("\u27F3")} ${s} changed \u2192 syncing...`)}try{let s=await is.sync(this.projectPath,{changedFiles:e});this.lastSyncTime=Date.now(),this.syncCount++,s.success?this.options.quiet||console.log(`${Xe.dim(`[${t}]`)} ${Xe.green("\u2713")} Synced`):console.error(`${Xe.dim(`[${t}]`)} ${Xe.red("\u2717")} Sync failed: ${s.error}`)}catch(s){console.error(`${Xe.dim(`[${t}]`)} ${Xe.red("\u2717")} Error: ${k(s)}`)}}handleError(e){console.error(Xe.red(`Watch error: ${e.message}`))}printStartup(){console.log(""),console.log(Xe.cyan("\u{1F441}\uFE0F Watching for changes...")),console.log(Xe.dim(` Project: ${
|
|
1336
|
-
`)}function
|
|
1337
|
-
`)}function
|
|
1338
|
-
`)}function
|
|
1340
|
+
${Xe.dim(`[${t}]`)} ${Xe.cyan("\u27F3")} ${s} changed \u2192 syncing...`)}try{let s=await is.sync(this.projectPath,{changedFiles:e});this.lastSyncTime=Date.now(),this.syncCount++,s.success?this.options.quiet||console.log(`${Xe.dim(`[${t}]`)} ${Xe.green("\u2713")} Synced`):console.error(`${Xe.dim(`[${t}]`)} ${Xe.red("\u2717")} Sync failed: ${s.error}`)}catch(s){console.error(`${Xe.dim(`[${t}]`)} ${Xe.red("\u2717")} Error: ${k(s)}`)}}handleError(e){console.error(Xe.red(`Watch error: ${e.message}`))}printStartup(){console.log(""),console.log(Xe.cyan("\u{1F441}\uFE0F Watching for changes...")),console.log(Xe.dim(` Project: ${tE.basename(this.projectPath)}`)),console.log(Xe.dim(` Debounce: ${this.options.debounceMs}ms`)),console.log(Xe.dim(` Min interval: ${this.options.minIntervalMs/1e3}s`)),console.log(""),console.log(Xe.dim(" Press Ctrl+C to stop")),console.log("")}},oE=new Pi});var Mf={};G(Mf,{getHelp:()=>pE});import J from"chalk";function aE(){let n=[];n.push(""),n.push(`${J.cyan.bold("prjct")} v${ce} - Context layer for AI coding agents`),n.push(J.dim("Works with Claude Code, Gemini CLI, Cursor, Windsurf, and more.")),n.push(""),n.push(J.bold("QUICK START")),n.push(J.dim("\u2500".repeat(60))),n.push(` ${J.green("1.")} prjct start ${J.dim("# Configure AI providers")}`),n.push(` ${J.green("2.")} cd my-project && prjct init`),n.push(` ${J.green("3.")} Open in Claude Code / Gemini CLI / Cursor`),n.push(` ${J.green("4.")} p. sync ${J.dim("# Analyze project")}`),n.push(""),n.push(J.bold("TERMINAL COMMANDS")),n.push(J.dim("\u2500".repeat(60)));for(let t of Df){let s=`prjct ${t.name}`.padEnd(22);n.push(` ${s} ${t.description}`)}n.push(""),n.push(`${J.bold("AI AGENT COMMANDS")} ${J.dim("(inside Claude/Gemini/Cursor)")}`),n.push(J.dim("\u2500".repeat(60))),n.push(` ${"Command".padEnd(22)} Description`),n.push(` ${J.dim("\u2500".repeat(56))}`);let e=Yn.filter(t=>t.group==="core"&&t.usage?.claude);for(let t of e.slice(0,10)){let s=`p. ${t.name}`.padEnd(22);n.push(` ${s} ${t.description}`)}n.push(` ${J.dim(`... and ${e.length-10} more (run 'prjct help commands')`)}`),n.push(""),n.push(J.bold("FLAGS")),n.push(J.dim("\u2500".repeat(60)));for(let t of iE)n.push(` ${t.flag.padEnd(22)} ${t.description}`);return n.push(""),n.push(J.bold("MORE INFO")),n.push(J.dim("\u2500".repeat(60))),n.push(` Documentation: ${J.cyan("https://prjct.app")}`),n.push(` GitHub: ${J.cyan("https://github.com/jlopezlira/prjct-cli")}`),n.push(" Per-command: prjct help <command>"),n.push(""),n.join(`
|
|
1341
|
+
`)}function cE(n){let e=Df.find(s=>s.name===n);if(!e)return null;let t=[];if(t.push(""),t.push(`${J.cyan.bold(`prjct ${e.name}`)} - ${e.description}`),t.push(""),t.push(J.bold("USAGE")),t.push(` ${e.example}`),t.push(""),e.options){t.push(J.bold("OPTIONS"));for(let s of e.options)t.push(` ${s}`);t.push("")}if(e.subcommands){t.push(J.bold("SUBCOMMANDS"));for(let s of e.subcommands)t.push(` ${s}`);t.push("")}return t.join(`
|
|
1342
|
+
`)}function lE(n){let e=Yn.find(r=>r.name===n);if(!e)return null;let t=[];if(t.push(""),t.push(`${J.cyan.bold(`p. ${e.name}`)} - ${e.description}`),t.push(""),t.push(J.bold("USAGE")),e.usage?.claude&&t.push(` Claude/Gemini: ${e.usage.claude.replace("/p:","p. ")}`),e.usage?.terminal&&t.push(` Terminal: ${e.usage.terminal}`),t.push(""),e.params&&(t.push(J.bold("PARAMETERS")),t.push(` ${e.params}`),t.push("")),e.features&&e.features.length>0){t.push(J.bold("FEATURES"));for(let r of e.features)t.push(` \u2022 ${r}`);t.push("")}e.blockingRules&&(t.push(J.bold("REQUIREMENTS")),t.push(` ${J.yellow("\u26A0")} ${e.blockingRules.check}`),t.push(""));let s=Fr[e.group];return s&&(t.push(J.dim(`Category: ${s.title}`)),e.isOptional&&t.push(J.dim("This is an optional command.")),t.push("")),t.join(`
|
|
1343
|
+
`)}function uE(n){let e=cE(n);if(e)return e;let t=lE(n);return t||`
|
|
1339
1344
|
${J.yellow(`Command '${n}' not found.`)}
|
|
1340
1345
|
|
|
1341
1346
|
Run 'prjct help' to see all available commands.
|
|
1342
|
-
`}function
|
|
1343
|
-
`)}function
|
|
1347
|
+
`}function dE(){let n=[];n.push(""),n.push(J.cyan.bold("All Commands")),n.push("");let e=Object.entries(Fr).sort((t,s)=>t[1].order-s[1].order);for(let[t,s]of e){let r=Yn.filter(o=>o.group===t);if(r.length!==0){n.push(`${J.bold(s.title)} ${J.dim(`(${r.length} commands)`)}`),n.push(J.dim(s.description)),n.push("");for(let o of r){let i=`p. ${o.name}`.padEnd(18),a=o.description.length>45?`${o.description.slice(0,42)}...`:o.description;n.push(` ${i} ${a}`)}n.push("")}}return n.push(J.dim("Run 'prjct help <command>' for detailed help on a specific command.")),n.push(""),n.join(`
|
|
1348
|
+
`)}function pE(n){return n?n==="commands"||n==="all"?dE():uE(n):aE()}var Df,iE,Nf=h(()=>{"use strict";Rl();qe();Df=[{name:"start",description:"First-time setup wizard",example:"prjct start"},{name:"init",description:"Initialize project in current directory",example:"prjct init"},{name:"sync",description:"Sync project state and update context files",example:"prjct sync"},{name:"watch",description:"Auto-sync on file changes",example:"prjct watch",options:["--verbose","--debounce=<ms>","--interval=<sec>"]},{name:"hooks",description:"Manage git hooks for auto-sync",example:"prjct hooks install",subcommands:["install","uninstall","status"]},{name:"doctor",description:"Check system health and dependencies",example:"prjct doctor"},{name:"serve",description:"Start web dashboard server",example:"prjct serve [port]"},{name:"context",description:"Smart context filtering tools for AI",example:'prjct context files "add auth"',subcommands:["files","signatures","imports","recent","summary"]},{name:"stop",description:"Stop the background daemon",example:"prjct stop",options:["--force"]},{name:"restart",description:"Restart the background daemon",example:"prjct restart"},{name:"uninstall",description:"Complete system removal of prjct",example:"prjct uninstall --backup",options:["--force","--backup","--dry-run","--keep-package"]}],iE=[{flag:"-q, --quiet",description:"Suppress all output (errors to stderr only)"},{flag:"-v, --version",description:"Show version and provider status"},{flag:"-h, --help",description:"Show this help message"}];c(aE,"formatMainHelp");c(cE,"formatTerminalCommandHelp");c(lE,"formatAgentCommandHelp");c(uE,"formatCommandHelp");c(dE,"formatCommandList");c(pE,"getHelp")});var Of=Zf((w1,mE)=>{mE.exports={name:"prjct-cli",version:"2.2.4",description:"Context layer for AI agents. Project context for Claude Code, Gemini CLI, and more.",main:"dist/bin/prjct.mjs",bin:{prjct:"bin/prjct"},publishConfig:{access:"public",registry:"https://registry.npmjs.org"},scripts:{build:"node scripts/build.js","build:node":"node scripts/build.js",release:"node scripts/release.js","release:patch":"node scripts/release.js patch","release:minor":"node scripts/release.js minor","release:major":"node scripts/release.js major",postinstall:"node scripts/postinstall.js",prepare:"lefthook install","update-commands":`bun -e "const installer = require('./core/infrastructure/command-installer'); installer.syncCommands().then(r => console.log('Commands updated:', r)).catch(e => console.error('Error:', e.message))"`,"install-global":"./scripts/install.sh",update:"./scripts/update.sh",test:"bun test","test:watch":"bun test --watch","test:coverage":"bun test --coverage",typecheck:"tsc --noEmit -p core/tsconfig.json","typecheck:watch":"tsc --noEmit -p core/tsconfig.json --watch",validate:"bun scripts/validate-commands.js",lint:"biome lint .","lint:fix":"biome lint --write .",knip:"knip","lint:meta":"bun core/cli/lint-meta-commentary.ts",format:"biome format --write .","format:check":"biome format .",check:"biome check .","check:fix":"biome check --write ."},keywords:["claude-code","gemini-cli","ai-agents","context-layer","developer-tools","ai-assistant","productivity","mcp","llm","coding-agents"],author:"prjct.app",license:"MIT",dependencies:{"@clack/prompts":"1.0.0","@hono/node-server":"1.19.14","@modelcontextprotocol/sdk":"1.28.0","better-sqlite3":"12.6.2",chalk:"4.1.2",chokidar:"5.0.0","date-fns":"4.1.0",glob:"13.0.1",hono:"4.12.14","jsonc-parser":"3.3.1",zod:"3.24.1"},overrides:{"path-to-regexp":"8.4.0","brace-expansion":"5.0.5",hono:"4.12.14","@hono/node-server":"1.19.14"},devDependencies:{"@biomejs/biome":"2.3.13","@types/better-sqlite3":"7.6.13","@types/bun":"latest","@types/chokidar":"2.1.7",esbuild:"0.25.0",knip:"6.3.1",lefthook:"2.1.0",typescript:"5.9.3"},repository:{type:"git",url:"git+https://github.com/jlopezlira/prjct-cli.git"},bugs:{url:"https://github.com/jlopezlira/prjct-cli/issues"},homepage:"https://prjct.app",packageManager:"bun@1.2.23",engines:{bun:">=1.0.0",node:">=22.22.2"},files:["assets/","bin/prjct","dist/","templates/","scripts/postinstall.js","scripts/ensure-bun.sh","scripts/install.sh","LICENSE","README.md","CHANGELOG.md"],prepublishOnly:"node scripts/build.js",trustedDependencies:["chalk"]}});var SE={};import _f from"node:os";import ji from"node:path";import Ie from"chalk";async function gE(){let[n,...e]=process.argv.slice(2);if(["-v","--version","version"].includes(n)){let s=await Promise.resolve().then(()=>eh(Of()));await wE(s.version),process.exit(0)}if(["-h","--help",void 0].includes(n)&&(kE(),process.exit(0)),n&&Ti(n)&&!se.getByName(n)){let s=bi[n];s&&(f.failWithHint({message:`'prjct ${n}' was removed in v2. ${s.note}`,hint:`Use: ${s.replacement}`}),process.exit(1))}if(n&&!se.getByName(n)&&!(e.length===0&&Lf(n)!==null)){let r=[n,...e.filter(i=>!i.startsWith("-"))].join(" "),o=e.filter(i=>i.startsWith("-"));n="capture",e=[r,...o]}let t=e.includes("--md");t||f.start();try{let s=se.getByName(n);if(!s){let p=Lf(n),g=p?`Did you mean 'prjct ${p}'? Run 'prjct --help' for all commands`:"Run 'prjct --help' to see available commands";f.failWithHint(br("UNKNOWN_COMMAND",{message:`Unknown command: ${n}`,hint:g})),t||f.end(),process.exit(1)}if(s.deprecated){let p=s.replacedBy?`Use 'prjct ${s.replacedBy}' instead`:"Run 'prjct --help' to see available commands";f.failWithHint({message:`Command '${n}' is deprecated`,hint:p}),t||f.end(),process.exit(1)}s.implemented||(f.failWithHint({message:`Command '${n}' is not yet implemented`,hint:"Run 'prjct --help' to see available commands",docs:"https://github.com/jlopezlira/prjct-cli"}),t||f.end(),process.exit(1));let{parsedArgs:r,options:o}=yE(s,e),i=!process.stdin.isTTY||o.md===!0||o.json===!0;s.requiresLlm&&!i&&(f.failWithHint({message:`'prjct ${n}' requires an AI agent to process its output`,hint:`Use 'p. ${n}' inside Claude/Cursor, or add --md flag`}),t||f.end(),process.exit(1));let a=fE(s,r);a&&(f.failWithHint(a),t||f.end(),process.exit(1));let l=null,u=Date.now();try{l=await A.getProjectId(process.cwd()),l&&(await En.expireIfStale(l),await En.touch(l))}catch{}let d=new Rs,m;if(n==="analyze")m=await d.analyze(o);else if(n==="setup")m=await d.setup(o);else if(n==="update")m=await d.update(o);else{let p=r.join(" ")||null,g=o.md===!0,j={task:c(E=>d.task(E,process.cwd(),{md:g}),"task"),init:c(E=>d.init({idea:E,yes:o.yes===!0,pack:o.pack?String(o.pack):void 0,persona:o.persona?String(o.persona):void 0}),"init"),ship:c(E=>d.ship(E,process.cwd(),{md:g}),"ship"),workflow:c(E=>d.workflowPrefs(E,process.cwd(),{md:g}),"workflow"),sync:c(()=>d.sync(process.cwd(),{preview:o.preview===!0||o["dry-run"]===!0,yes:o.yes===!0,json:o.json===!0,md:g,package:o.package?String(o.package):void 0,full:o.full===!0}),"sync"),"analysis-save-llm":c(E=>E?d.saveLlmAnalysis(E,process.cwd(),{md:g}):Promise.resolve({success:!1,error:"analysis-save-llm requires a JSON payload as positional arg"}),"analysis-save-llm"),regen:c(()=>d.regenVault(process.cwd(),{md:g}),"regen"),start:c(()=>d.start(),"start"),context:c(E=>d.context(E),"context"),status:c(E=>d.status(E,process.cwd(),{md:g}),"status"),tag:c(E=>d.tag(E,process.cwd(),{md:g}),"tag"),remember:c(E=>d.remember(E,process.cwd(),{md:g,tags:o.tags?String(o.tags):void 0}),"remember"),login:c(()=>d.login({md:g,url:o.url?String(o.url):void 0}),"login"),logout:c(()=>d.logout(),"logout"),auth:c(E=>d.auth(E,{md:g}),"auth"),seed:c(E=>d.seed(E,process.cwd(),{md:g}),"seed"),install:c(()=>d.install(null,process.cwd(),{md:g}),"install"),capture:c(E=>d.capture(E,process.cwd(),{md:g,tags:o.tags?String(o.tags):void 0,force:o.force===!0}),"capture")}[n];if(j)m=await j(p);else throw new Error(`Command '${n}' has no handler`)}if(l){let p=Date.now()-u;try{await En.trackCommand(l,n,p)}catch{}try{await Tr.recordTiming(l,"command_duration",p,{command:n});let g=globalThis.__perfStartNs;if(g){let y=Number(process.hrtime.bigint()-g)/1e6;await Tr.recordTiming(l,"startup_time",y)}await Tr.recordMemory(l,{command:n})}catch{}}m?.message&&console.log(m.message),t||f.end(),process.exit(m?.success?0:1)}catch(s){console.error("Error:",k(s)),process.env.DEBUG&&console.error(Di(s)),t||f.end(),process.exit(1)}}function fE(n,e){if(!n.params)return null;let t=n.params.match(/<[^>]+>/g);if(!t||t.length===0)return null;if(e.length<t.length){let s=t.map(o=>o.slice(1,-1)).join(", "),r=n.usage.terminal||`prjct ${n.name} ${n.params}`;return br("MISSING_PARAM",{message:`Missing required parameter: ${s}`,hint:`Usage: ${r}`})}return null}function Lf(n){let e=se.getAll().map(r=>r.name),t=null,s=1/0;for(let r of e){let o=hE(n.toLowerCase(),r.toLowerCase());o<s&&(s=o,t=r)}return s<=2?t:null}function hE(n,e){let t=n.length,s=e.length,r=Array.from({length:t+1},()=>Array(s+1).fill(0));for(let o=0;o<=t;o++)r[o][0]=o;for(let o=0;o<=s;o++)r[0][o]=o;for(let o=1;o<=t;o++)for(let i=1;i<=s;i++)r[o][i]=n[o-1]===e[i-1]?r[o-1][i-1]:1+Math.min(r[o-1][i],r[o][i-1],r[o-1][i-1]);return r[t][s]}function yE(n,e){let t=[],s={};for(let r=0;r<e.length;r++){let o=e[r];if(o.startsWith("--")){let i=o.slice(2);r+1<e.length&&!e[r+1].startsWith("--")?s[i]=e[++r]:s[i]=!0}else t.push(o)}return{parsedArgs:t,options:s}}async function wE(n){let e=await ts(),t=ji.join(_f.homedir(),".claude","commands","p.md"),s=ji.join(_f.homedir(),".gemini","commands","p.toml"),[r,o,i,a]=await Promise.all([v(t),v(s),v(ji.join(process.cwd(),".cursor","commands","sync.md")),v(ji.join(process.cwd(),".cursor"))]),l=await cn();if(console.log(`
|
|
1344
1349
|
${Ie.cyan("p/")} prjct v${n}
|
|
1345
1350
|
${Ie.dim("Context layer for AI coding agents")}
|
|
1346
1351
|
|
|
1347
1352
|
${Ie.dim("Providers:")}`),e.claude.installed){let u=r?Ie.green("\u2713 ready"):Ie.yellow("\u25CF installed"),d=e.claude.version?` (v${e.claude.version})`:"";console.log(` Claude Code ${u}${Ie.dim(d)}`)}else console.log(` Claude Code ${Ie.dim("\u25CB not installed")}`);if(e.gemini.installed){let u=o?Ie.green("\u2713 ready"):Ie.yellow("\u25CF installed"),d=e.gemini.version?` (v${e.gemini.version})`:"";console.log(` Gemini CLI ${u}${Ie.dim(d)}`)}else console.log(` Gemini CLI ${Ie.dim("\u25CB not installed")}`);if(l.installed){let u=l.skillInstalled?Ie.green("\u2713 ready"):Ie.yellow("\u25CF detected"),d=l.skillInstalled?"":` ${Ie.dim("(run prjct start)")}`;console.log(` Antigravity ${u}${d}`)}else console.log(` Antigravity ${Ie.dim("\u25CB not installed")}`);console.log(i?` Cursor IDE ${Ie.green("\u2713 ready")} ${Ie.dim("(use /sync, /task)")}`:a?` Cursor IDE ${Ie.yellow("\u25CF detected")} ${Ie.dim("(run prjct init)")}`:` Cursor IDE ${Ie.dim("\u25CB no .cursor/ folder")}`),console.log(`
|
|
1348
1353
|
${Ie.dim("Run 'prjct start' for Claude/Gemini, 'prjct init' for Cursor")}
|
|
1349
1354
|
${Ie.cyan("https://prjct.app")}
|
|
1350
|
-
`)}function
|
|
1355
|
+
`)}function kE(){console.log(`
|
|
1351
1356
|
prjct - Context layer for AI coding agents
|
|
1352
1357
|
Works with Claude Code, Gemini CLI, Antigravity, Cursor IDE, and more.
|
|
1353
1358
|
|
|
@@ -1406,7 +1411,7 @@ MORE INFO
|
|
|
1406
1411
|
---------
|
|
1407
1412
|
Documentation: https://prjct.app
|
|
1408
1413
|
GitHub: https://github.com/jlopezlira/prjct-cli
|
|
1409
|
-
`)}var Ff=h(()=>{"use strict";jl();wi();$l();Dl();Ve();ie();Ma();$a();q();bo();z();Le();c(
|
|
1414
|
+
`)}var Ff=h(()=>{"use strict";jl();wi();$l();Dl();Ve();ie();Ma();$a();q();bo();z();Le();c(gE,"main");c(fE,"validateCommandParams");c(Lf,"findClosestCommand");c(hE,"editDistance");c(yE,"parseCommandArgs");c(wE,"displayVersion");c(kE,"displayHelp");gE().catch(n=>{console.error("Fatal error:",k(n)),process.env.DEBUG&&console.error(Di(n)),process.exit(1)})});globalThis.__perfStartNs=process.hrtime.bigint();var ps=process.argv.slice(2),rn=ps.find(n=>!n.startsWith("--")&&!n.startsWith("-")),Uf=new Set(["daemon","stop","restart","start","setup","update","dev","web","serve","context","hooks","doctor","uninstall","claude","hook","seed","install","watch","help","-h","--help","version","-v","--version"]),{REGISTERED_VERBS_SET:vE}=await Promise.resolve().then(()=>(Hl(),Ul));if(rn&&!Uf.has(rn)&&!vE.has(rn)){let n=ps.filter(t=>!t.startsWith("-")).join(" "),e=ps.filter(t=>t.startsWith("-"));rn="capture",ps=["capture",n,...e]}if(rn&&!Uf.has(rn)&&process.env.PRJCT_NO_DAEMON!=="1"){let n=await import("node:fs"),{DAEMON_PATHS:e}=await Promise.resolve().then(()=>(qr(),Wl)),t=e.socket();if(n.existsSync(t)){let{sendRequest:s}=await Promise.resolve().then(()=>(Xt(),zt)),r=await import("node:crypto"),o=[],i={};for(let a=0;a<ps.length;a++){let l=ps[a];if(l.startsWith("--")){let u=l.slice(2);if(u.includes("=")){let d=u.indexOf("=");i[u.slice(0,d)]=u.slice(d+1)}else a+1<ps.length&&!ps[a+1].startsWith("--")?i[u]=ps[++a]:i[u]=!0}else l.startsWith("-")&&l.length===2?i[l.slice(1)]=!0:a>0&&o.push(l)}try{let a=await s({id:r.randomUUID(),command:rn,args:o,options:i,cwd:process.cwd(),perfStartNs:globalThis.__perfStartNs?.toString()});a.stdout&&console.log(a.stdout),a.stderr&&console.error(a.stderr),process.exit(a.exitCode)}catch{}}}async function bE(){let n=await import("node:os"),e=await import("node:path"),t=(await import("chalk")).default,{detectAllProviders:s}=await Promise.resolve().then(()=>(Ve(),wt)),r=(await Promise.resolve().then(()=>(ie(),pr))).default,o=(await Promise.resolve().then(()=>(io(),bu))).default,{DEFAULT_PORT:i,startServer:a}=await Promise.resolve().then(()=>(xa(),ud)),{fileExists:l}=await Promise.resolve().then(()=>(z(),es)),{invalidateProviderCache:u}=await Promise.resolve().then(()=>(_i(),ru)),{VERSION:d}=await Promise.resolve().then(()=>(qe(),mn));async function m(){let b=n.homedir(),S=await s();if(S.claude.installed){let P=e.join(b,".claude","CLAUDE.md");try{if(!(await import("node:fs/promises").then(N=>N.readFile(P,"utf-8"))).includes("prjct:start"))return!1}catch{return!1}}if(S.gemini.installed){let P=e.join(b,".gemini","GEMINI.md");try{if(!(await import("node:fs/promises").then(N=>N.readFile(P,"utf-8"))).includes("prjct:start"))return!1}catch{return!1}}return!S.claude.installed&&!S.gemini.installed,!0}c(m,"checkRoutersInstalled");let p=process.argv.slice(2),g=p.findIndex(b=>b==="--quiet"||b==="-q"),y=g!==-1;if(y){p.splice(g,1);let{setQuietMode:b}=await Promise.resolve().then(()=>(Le(),hd));b(!0)}let j=p.indexOf("--refresh"),E=j!==-1;E&&(p.splice(j,1),await u());async function R(b){let S=Date.now();try{let P=await r.getProjectId(process.cwd());if(P){let{sessionTracker:T}=await Promise.resolve().then(()=>($a(),kd));return await T.expireIfStale(P),await T.touch(P),()=>{let N=Date.now()-S;T.trackCommand(P,b,N).catch(()=>{}),Promise.resolve().then(()=>(Ma(),vd)).then(({performanceTracker:F})=>{F.recordTiming(P,"command_duration",N,{command:b}).catch(()=>{}),F.recordMemory(P,{command:b}).catch(()=>{})}).catch(()=>{})}}}catch{}return()=>{}}if(c(R,"trackSession"),p[0]==="daemon"){let b=p[1]||"status";if(b==="start"){let{isDaemonRunning:S,spawnDaemon:P}=await Promise.resolve().then(()=>(Xt(),zt));if(await S())console.log("Daemon is already running."),process.exitCode=0;else if(p.includes("--foreground")||p.includes("-f")){let{startDaemon:N}=await Promise.resolve().then(()=>(zg(),Jg)),F=parseInt(p.find(tt=>tt.startsWith("--port="))?.split("=")[1]||"",10)||void 0,ke=p.includes("--no-http");await N({port:F,noHttp:ke,foreground:!0})}else await P()?console.log("Daemon started."):(console.error("Failed to start daemon."),process.exitCode=1)}else if(b==="stop"){let{isDaemonRunning:S,stopDaemon:P}=await Promise.resolve().then(()=>(Xt(),zt));if(await S()){let T=await P();console.log(T?"Daemon stopped.":"Failed to stop daemon."),process.exitCode=T?0:1}else console.log("Daemon is not running."),process.exitCode=0}else if(b==="status"){let{getDaemonStatus:S}=await Promise.resolve().then(()=>(Xt(),zt)),P=await S();if(P.running){let T=P.uptime?Math.round(P.uptime/1e3):0,N=P.stale;console.log(`Daemon running (PID ${P.pid})${N?" \u26A0 STALE":""}`),console.log(` Uptime: ${T}s`),console.log(` Commands served: ${P.commandsServed??0}`),P.lastActivity&&console.log(` Last activity: ${P.lastActivity}`),N&&console.log(` ${t.yellow("\u26A0 Code changed since daemon started. Run: prjct restart")}`)}else console.log("Daemon is not running.");process.exitCode=0}else console.error(`Unknown daemon command: ${b}. Use: start, stop, status`),process.exitCode=1}else if(p[0]==="stop"){let{isDaemonRunning:b,stopDaemon:S,forceKillDaemon:P}=await Promise.resolve().then(()=>(Xt(),zt));if(p.includes("--force")||p.includes("-f")){let N=P();console.log(N?"Daemon force-killed.":"Daemon is not running."),process.exitCode=0}else await b()?await S()?(console.log("Daemon stopped."),process.exitCode=0):(console.log("Graceful stop failed, force-killing..."),P(),console.log("Daemon force-killed."),process.exitCode=0):(P(),console.log("Daemon is not running (cleaned up stale files)."),process.exitCode=0)}else if(p[0]==="restart"){let{isDaemonRunning:b,stopDaemon:S,forceKillDaemon:P,spawnDaemon:T}=await Promise.resolve().then(()=>(Xt(),zt));await b()?(await S()||P(),await new Promise(ke=>setTimeout(ke,300))):P(),await T()?(console.log("Daemon restarted."),process.exitCode=0):(console.error("Failed to restart daemon."),process.exitCode=1)}else if(p[0]==="start"||p[0]==="setup"){let{runStart:b}=await Promise.resolve().then(()=>(Qg(),Yg));await b()}else if(p[0]==="dev")console.log("Dev mode is not yet implemented."),console.log('Use "prjct serve" to start the web server.'),process.exitCode=0;else if(p[0]==="web"||p[0]==="serve")try{let b=process.cwd(),S=await r.getProjectId(b);if(!S)console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let P=parseInt(p[1],10)||i;await a(S,b,P)}}catch(b){console.error("Server error:",b.message),process.exitCode=1}else if(p[0]==="context"){let b=process.cwd(),S=await r.getProjectId(b);if(!S)console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let P=await R("context"),T=p.slice(1).filter(F=>F!=="--md"&&F!=="--json"),N=p.includes("--md");if(T.length===0){let{ContextCommands:F}=await Promise.resolve().then(()=>(li(),pg)),tt=await new F().context(null,b,{md:N});process.exitCode=tt.success?0:1}else{let{runContextTool:F}=await Promise.resolve().then(()=>(tf(),ef)),ke=await F(T,S,b);console.log(JSON.stringify(ke,null,2)),process.exitCode=ke.tool==="error"?1:0}P()}}else if(p[0]==="hooks"){let b=await R("hooks"),{hooksService:S}=await Promise.resolve().then(()=>(af(),of)),P=p[1]||"status",T=await S.run(process.cwd(),P);process.exitCode=T,b()}else if(p[0]==="seed"){let b=p[1]??"list",S=p.slice(2).filter(ke=>!ke.startsWith("-")).join(","),P=p.includes("--md"),{SeedCommands:T}=await Promise.resolve().then(()=>(pi(),Tg)),N=new T,F={success:!1,error:"unknown"};b==="add"?F=await N.add(S||null,process.cwd(),{md:P}):b==="remove"?F=await N.remove(S||null,process.cwd(),{md:P}):b==="list"?F=await N.list(null,process.cwd(),{md:P}):b==="suggest"?F=await N.suggest(null,process.cwd(),{md:P}):console.error(`Unknown seed subcommand: ${b}. Use: add, remove, list, suggest.`),process.exitCode=F.success?0:1}else if(p[0]==="install"){let{InstallCommands:b}=await Promise.resolve().then(()=>(_r(),ll)),S=new b,P=p.includes("--md"),T=await S.install(null,process.cwd(),{md:P});process.exitCode=T.success?0:1}else if(p[0]==="claude"){let b=p[1]??"status",{InstallCommands:S}=await Promise.resolve().then(()=>(_r(),ll)),P=new S,T=p.includes("--md"),N;if(b==="install")N=await P.install(null,process.cwd(),{md:T});else if(b==="uninstall")N=await P.uninstall(null,process.cwd(),{md:T});else{let F=await P.status();F.success?(console.log(T?`# prjct Claude Code hooks
|
|
1410
1415
|
|
|
1411
1416
|
- installed: ${F.installed}
|
|
1412
1417
|
- expected: ${F.expected}
|
|
@@ -1429,5 +1434,5 @@ ${t.cyan.bold(" Welcome to prjct!")}
|
|
|
1429
1434
|
Claude Code, Gemini CLI, or both.`)}
|
|
1430
1435
|
`),process.exitCode=0;else{try{let T=await o.getLastVersion();if(T&&T!==d){console.log(`
|
|
1431
1436
|
${t.yellow("\u2139")} Updating prjct v${T} \u2192 v${d}...
|
|
1432
|
-
`);try{let{default:N}=await Promise.resolve().then(()=>(An(),No));await N.run()}catch{await o.updateVersion(d).catch(()=>{})}}}catch{}p.length>0&&process.env.PRJCT_NO_DAEMON!=="1"&&Promise.resolve().then(()=>(Xt(),zt)).then(({spawnDaemon:T})=>T()).catch(()=>{}),await Promise.resolve().then(()=>(Ff(),
|
|
1437
|
+
`);try{let{default:N}=await Promise.resolve().then(()=>(An(),No));await N.run()}catch{await o.updateVersion(d).catch(()=>{})}}}catch{}p.length>0&&process.env.PRJCT_NO_DAEMON!=="1"&&Promise.resolve().then(()=>(Xt(),zt)).then(({spawnDaemon:T})=>T()).catch(()=>{}),await Promise.resolve().then(()=>(Ff(),SE))}}}c(bE,"main");bE().catch(n=>{process.argv[2]==="hook"&&(process.stdout.write(`{}
|
|
1433
1438
|
`),process.exit(0)),console.error("Fatal error:",n.message),process.exit(1)});
|