prjct-cli 1.50.2 → 1.51.1

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.
@@ -5,11 +5,11 @@ import { dirname as __pathDirname } from 'path';
5
5
  var require = __createRequire(import.meta.url);
6
6
  var __filename = __fileURLToPath(import.meta.url);
7
7
  var __dirname = __pathDirname(__filename);
8
- var Wr=Object.defineProperty;var Rf=Object.getOwnPropertyDescriptor;var Af=Object.getOwnPropertyNames;var Df=Object.prototype.hasOwnProperty;var l=(r,e)=>Wr(r,"name",{value:e,configurable:!0}),St=(r=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(r,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):r)(function(r){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+r+'" is not supported')});var S=(r,e)=>()=>(r&&(e=r(r=0)),e);var Bt=(r,e)=>{for(var t in e)Wr(r,t,{get:e[t],enumerable:!0})},jf=(r,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Af(e))!Df.call(r,n)&&n!==t&&Wr(r,n,{get:()=>e[n],enumerable:!(s=Rf(e,n))||s.enumerable});return r};var bt=r=>jf(Wr({},"__esModule",{value:!0}),r);var z={};Bt(z,{calculateDuration:()=>Uf,formatDate:()=>cn,formatDuration:()=>ft,formatMonth:()=>$f,getDateKey:()=>Mf,getDateRange:()=>Nf,getDaysAgo:()=>gs,getDaysFromNow:()=>_f,getEndOfDay:()=>Gf,getStartOfDay:()=>Hf,getTimestamp:()=>v,getTodayKey:()=>Xl,getYearMonthDay:()=>$i,isToday:()=>Lf,isWithinLastDays:()=>Ff,parseDate:()=>Of,parseDurationMinutes:()=>ht,parseVarianceMinutes:()=>js,toRelative:()=>Vf});import{formatDistanceToNowStrict as If}from"date-fns";function cn(r){let e=r.getFullYear(),t=(r.getMonth()+1).toString().padStart(2,"0"),s=r.getDate().toString().padStart(2,"0");return`${e}-${t}-${s}`}function $f(r){let e=r.getFullYear(),t=(r.getMonth()+1).toString().padStart(2,"0");return`${e}-${t}`}function Xl(){return cn(new Date)}function Mf(r){return cn(r)}function $i(r){return{year:r.getFullYear().toString(),month:(r.getMonth()+1).toString().padStart(2,"0"),day:r.getDate().toString().padStart(2,"0")}}function Of(r){return new Date(r)}function v(){return new Date().toISOString()}function gs(r){let e=new Date;return e.setDate(e.getDate()-r),e}function _f(r){let e=new Date;return e.setDate(e.getDate()+r),e}function Nf(r,e){let t=[],s=new Date(r);for(;s<=e;)t.push(new Date(s)),s=new Date(s.getFullYear(),s.getMonth(),s.getDate()+1);return t}function Lf(r){return cn(r)===Xl()}function Ff(r,e){let t=gs(e);return r>=t}function ft(r){let e=Math.floor(r/1e3),t=Math.floor(e/60),s=Math.floor(t/60),n=Math.floor(s/24);return n>0?`${n}d ${s%24}h`:s>0?`${s}h ${t%60}m`:t>0?`${t}m`:`${e}s`}function Uf(r,e=new Date){let t=e.getTime()-r.getTime();return ft(t)}function Hf(r){let e=new Date(r);return e.setHours(0,0,0,0),e}function Gf(r){let e=new Date(r);return e.setHours(23,59,59,999),e}function Vf(r){let e=typeof r=="string"?new Date(r):r;return If(e,{addSuffix:!0})}function js(r){let e=r.match(/^([+-])(\d+)([mh])$/);if(!e)return 0;let t=e[1]==="-"?-1:1,s=Number.parseInt(e[2],10),n=e[3];return t*(n==="h"?s*60:s)}function ht(r){let e=0,t=r.match(/(\d+)h/);t&&(e+=Number.parseInt(t[1],10)*60);let s=r.match(/(\d+)m/);return s&&(e+=Number.parseInt(s[1],10)),r.match(/(\d+)s/)&&e===0&&(e=1),e}var oe=S(()=>{"use strict";l(cn,"formatDate");l($f,"formatMonth");l(Xl,"getTodayKey");l(Mf,"getDateKey");l($i,"getYearMonthDay");l(Of,"parseDate");l(v,"getTimestamp");l(gs,"getDaysAgo");l(_f,"getDaysFromNow");l(Nf,"getDateRange");l(Lf,"isToday");l(Ff,"isWithinLastDays");l(ft,"formatDuration");l(Uf,"calculateDuration");l(Hf,"getStartOfDay");l(Gf,"getEndOfDay");l(Vf,"toRelative");l(js,"parseVarianceMinutes");l(ht,"parseDurationMinutes")});var Yl,Ql,Zl,Mi=S(()=>{"use strict";Yl=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"]),Ql=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],Zl=/(?:import|from)\s+['"]([^'"]+)['"]/g});function Wf(r){return r instanceof Error&&"code"in r}function R(r){return Wf(r)&&r.code==="ENOENT"}function y(r){return r instanceof Error?r.message:typeof r=="string"?r:"Unknown error"}var V=S(()=>{"use strict";l(Wf,"isNodeError");l(R,"isNotFoundError");l(y,"getErrorMessage")});import su from"node:fs/promises";async function nu(r,e){let t;try{t=await su.readFile(r,"utf-8")}catch(o){if(R(o))return null;throw o}let s;try{s=JSON.parse(t)}catch{return await eu(r,t),tu(r,"Malformed JSON"),null}let n=e.safeParse(s);return n.success?s:(await eu(r,t),tu(r,Bf(n.error)),null)}async function eu(r,e){let t=`${r}.backup`;try{await su.writeFile(t,e,"utf-8")}catch{}}function tu(r,e){console.error(`[prjct] Warning: Corrupted storage file: ${r}`),console.error(`[prjct] Reason: ${e}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function Bf(r){return r.issues.slice(0,3).map(e=>`${e.path.join(".")}: ${e.message}`).join("; ")}var ru=S(()=>{"use strict";V();l(nu,"safeRead");l(eu,"createBackup");l(tu,"logCorruption");l(Bf,"formatZodError")});var Re={};Bt(Re,{appendLine:()=>Oi,appendToFile:()=>zf,atomicWrite:()=>Jf,batchProcess:()=>$s,copyFile:()=>Zf,deleteDir:()=>Xf,deleteFile:()=>Kf,dirExists:()=>es,ensureDir:()=>vt,fileExists:()=>C,getFileExtension:()=>nh,getFileModifiedTime:()=>Qf,getFileNameWithoutExtension:()=>rh,getFileSize:()=>Yf,listFiles:()=>ts,moveFile:()=>eh,prependToFile:()=>qf,readFile:()=>ot,readJson:()=>xe,readLines:()=>th,walkDir:()=>Is,writeFile:()=>Jt,writeJson:()=>le,writeLines:()=>sh});import we from"node:fs/promises";import Zt from"node:path";async function Is(r,e={}){let t=[],s=e.maxFiles??1/0,n=e.dotfileAllowlist?new Set(e.dotfileAllowlist):null;async function o(i){if(t.length>=s)return;let a=await we.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let c of a){if(t.length>=s)break;let u=String(c.name);if(Yl.has(u)||e.skipDotfiles&&u.startsWith(".")&&(!n||!n.has(u)))continue;let p=Zt.join(i,u);c.isDirectory()?await o(p):c.isFile()&&t.push(Zt.relative(r,p))}}return l(o,"walk"),await o(r),t}async function $s(r,e,t){let s=[];for(let n=0;n<r.length;n+=e){let o=await Promise.all(r.slice(n,n+e).map(t));for(let i of o)i!==null&&s.push(i)}return s}async function xe(r,e=null,t){if(t)return await nu(r,t)??e;try{let s=await we.readFile(r,"utf-8");return JSON.parse(s)}catch(s){if(R(s))return e;throw s}}async function le(r,e,t=2){let s=Zt.dirname(r);await we.mkdir(s,{recursive:!0});let n=JSON.stringify(e,null,t);await we.writeFile(r,n,"utf-8")}async function ot(r,e=""){try{return await we.readFile(r,"utf-8")}catch(t){if(R(t))return e;throw t}}async function Jt(r,e){let t=Zt.dirname(r);await we.mkdir(t,{recursive:!0}),await we.writeFile(r,e,"utf-8")}async function Jf(r,e){let t=Zt.dirname(r);await we.mkdir(t,{recursive:!0});let s=`${r}.${Date.now()}.tmp`;await we.writeFile(s,e,"utf-8"),await we.rename(s,r)}async function zf(r,e){await we.appendFile(r,e,"utf-8")}async function Oi(r,e){let t=Zt.dirname(r);await we.mkdir(t,{recursive:!0}),await we.appendFile(r,`${e}
9
- `,"utf-8")}async function qf(r,e){try{let t=await we.readFile(r,"utf-8");await we.writeFile(r,e+t,"utf-8")}catch(t){if(R(t))await we.writeFile(r,e,"utf-8");else throw t}}async function C(r){try{return await we.access(r),!0}catch(e){if(R(e))return!1;throw e}}async function es(r){try{return(await we.stat(r)).isDirectory()}catch(e){if(R(e))return!1;throw e}}async function vt(r){await we.mkdir(r,{recursive:!0})}async function Kf(r){try{return await we.unlink(r),!0}catch(e){if(R(e))return!1;throw e}}async function Xf(r){try{return await we.rm(r,{recursive:!0,force:!0}),!0}catch(e){if(R(e))return!1;throw e}}async function ts(r,e={}){try{let s=await we.readdir(r,{withFileTypes:!0});return e.filesOnly&&(s=s.filter(n=>n.isFile())),e.dirsOnly&&(s=s.filter(n=>n.isDirectory())),e.extension&&(s=s.filter(n=>n.name.endsWith(e.extension))),s.map(n=>n.name)}catch(t){if(R(t))return[];throw t}}async function Yf(r){return(await we.stat(r)).size}async function Qf(r){return(await we.stat(r)).mtime}async function Zf(r,e){await we.copyFile(r,e)}async function eh(r,e){await we.rename(r,e)}async function th(r){return(await ot(r,"")).split(`
10
- `)}async function sh(r,e){let t=e.join(`
11
- `);await Jt(r,t)}function nh(r){return Zt.extname(r)}function rh(r){return Zt.basename(r,Zt.extname(r))}var q=S(()=>{"use strict";Mi();ru();V();l(Is,"walkDir");l($s,"batchProcess");l(xe,"readJson");l(le,"writeJson");l(ot,"readFile");l(Jt,"writeFile");l(Jf,"atomicWrite");l(zf,"appendToFile");l(Oi,"appendLine");l(qf,"prependToFile");l(C,"fileExists");l(es,"dirExists");l(vt,"ensureDir");l(Kf,"deleteFile");l(Xf,"deleteDir");l(ts,"listFiles");l(Yf,"getFileSize");l(Qf,"getFileModifiedTime");l(Zf,"copyFile");l(eh,"moveFile");l(th,"readLines");l(sh,"writeLines");l(nh,"getFileExtension");l(rh,"getFileNameWithoutExtension")});var or=S(()=>{"use strict"});import{z as zt}from"zod";function ou(r,e){let t=r.split(".").map(Number),s=e.split(".").map(Number);for(let n=0;n<3;n++){let o=t[n]??0,i=s[n]??0;if(o<i)return-1;if(o>i)return 1}return 0}var _T,NT,LT,ln,FT,Br=S(()=>{"use strict";_T=zt.enum(["opus","sonnet","haiku"]),NT=zt.enum(["2.5-pro","2.5-flash","2.0-flash"]),LT=zt.string().min(1),ln=zt.object({provider:zt.string(),model:zt.string(),cliVersion:zt.string().optional(),recordedAt:zt.string()}),FT=zt.object({preferredModel:zt.string().optional(),lastAnalysisModel:ln.optional()});l(ou,"compareSemver")});var au={};Bt(au,{execAsync:()=>N,execFileAsync:()=>_i});import{exec as oh,execFile as ih}from"node:child_process";import{promisify as iu}from"node:util";var N,_i,Ue=S(()=>{"use strict";N=iu(oh),_i=iu(ih)});function fs(r,e){let t=typeof r=="string"?new Date(r).getTime():r;return Date.now()-t>e}var un,Ms=S(()=>{"use strict";l(fs,"isExpired");un=class{static{l(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,n)=>s[1].timestamp-n[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}}});import ah from"node:fs/promises";import ch from"node:os";import cu from"node:path";async function uu(){try{let r=await ah.readFile(lu,"utf-8"),e=JSON.parse(r);return!e.timestamp||!e.detection||!e.detection.claude||!e.detection.gemini||!e.detection.codex||fs(e.timestamp,uh)?null:e.detection}catch{return null}}async function du(r){let e={timestamp:new Date().toISOString(),detection:r};await le(lu,e)}var lh,lu,uh,pu=S(()=>{"use strict";Ms();q();lh=cu.join(ch.homedir(),".prjct-cli","cache"),lu=cu.join(lh,"providers.json"),uh=600*1e3;l(uu,"readProviderCache");l(du,"writeProviderCache")});var Tt={};Bt(Tt,{AntigravityProvider:()=>Li,ClaudeProvider:()=>Jr,CodexProvider:()=>Fi,CursorProvider:()=>gu,GeminiProvider:()=>Ni,Providers:()=>pt,WindsurfProvider:()=>fu,detectAllProviders:()=>ir,detectAntigravity:()=>Kr,detectCodex:()=>Os,detectCursorProject:()=>wu,detectProvider:()=>zr,detectWindsurfProject:()=>ku,getActiveProvider:()=>gh,getCapabilities:()=>ph,getCommandsDir:()=>bh,getGlobalContextPath:()=>wh,getGlobalSettingsPath:()=>kh,getProjectCommandsPath:()=>vh,getProviderBranding:()=>qr,getSkillsPath:()=>Sh,hasProviderConfig:()=>fh,needsCursorRouterRegeneration:()=>hh,needsWindsurfRouterRegeneration:()=>yh,selectProvider:()=>Ui,validateCliVersion:()=>yu});import hs from"node:os";import Ve from"node:path";function ph(r,e){return{...dh[r],...e}}async function hu(r){try{let{stdout:e}=await N(`which ${r}`,{timeout:2e3});return e.trim()}catch{return null}}async function mh(r){try{let{stdout:e}=await N(`${r} --version`,{timeout:2e3}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function zr(r){let e=pt[r];if(!e.cliCommand)return{installed:!1};let t=await hu(e.cliCommand);if(!t)return{installed:!1};let s=await mh(e.cliCommand),n=yu(r,s||void 0);return{installed:!0,version:s||void 0,path:t,versionWarning:n||void 0}}function yu(r,e){let t=pt[r];return!t.minCliVersion||!e?null:ou(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 ir(r=!1){if(!r){let i=await uu();if(i)return i}let[e,t,s]=await Promise.all([zr("claude"),zr("gemini"),Os()]),n={installed:s.installed},o={claude:e,gemini:t,codex:n};return await du(o).catch(()=>{}),o}async function gh(r){if(r&&pt[r])return pt[r];let e=await ir();return e.claude.installed&&!e.gemini.installed?Jr:e.gemini.installed&&!e.claude.installed?Ni:Jr}async function fh(r){let e=pt[r];return e.configDir?C(e.configDir):!1}function qr(r){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"}[r]||"\u26A1 prjct"}}async function wu(r){let e=Ve.join(r,".cursor"),t=Ve.join(e,"rules"),s=Ve.join(t,"prjct.mdc"),[n,o]=await Promise.all([C(e),C(s)]);return{detected:n,routerInstalled:o,projectRoot:n?r:void 0}}async function hh(r){let e=await wu(r);return e.detected&&!e.routerInstalled}async function ku(r){let e=Ve.join(r,".windsurf"),t=Ve.join(e,"rules"),s=Ve.join(t,"prjct.md"),[n,o]=await Promise.all([C(e),C(s)]);return{detected:n,routerInstalled:o,projectRoot:n?r:void 0}}async function yh(r){let e=await ku(r);return e.detected&&!e.routerInstalled}async function Kr(){let r=Li.configDir;if(!r)return{installed:!1,skillInstalled:!1};let e=Ve.join(r,"skills","prjct","SKILL.md"),[t,s]=await Promise.all([C(r),C(e)]);return{installed:t,skillInstalled:s,configPath:t?r:void 0}}async function Os(){let r=Fi.configDir;if(!r)return{installed:!1,skillInstalled:!1};let e=await hu("codex"),t=Ve.join(r,"skills","prjct","SKILL.md"),s=await C(t),n=!!e;return{installed:n,skillInstalled:s,configPath:n?r:void 0}}function wh(r){let e=pt[r];return e.configDir?Ve.join(e.configDir,e.contextFile):null}function kh(r){let e=pt[r];return!e.configDir||!e.settingsFile?null:Ve.join(e.configDir,e.settingsFile)}function Sh(r){return pt[r].skillsDir}function bh(r){return pt[r].commandsDir}function vh(r,e){let t=pt[r];return Ve.join(e,t.commandsDir)}async function Ui(){let r=await ir(),e=r.claude.installed,t=r.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:r}:e&&!t?{provider:"claude",userSelected:!1,detection:r}:t&&!e?{provider:"gemini",userSelected:!1,detection:r}:{provider:"claude",userSelected:!0,detection:r}}var dh,Jr,Ni,Li,gu,fu,Fi,pt,it=S(()=>{"use strict";or();Br();Ue();q();pu();dh={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}};l(ph,"getCapabilities");Jr={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:Ve.join(hs.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:Ve.join(hs.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"},Ni={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:Ve.join(hs.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:Ve.join(hs.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"},Li={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:Ve.join(hs.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:Ve.join(hs.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"},gu={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"},fu={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"},Fi={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:Ve.join(hs.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:Ve.join(hs.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"},pt={claude:Jr,gemini:Ni,cursor:gu,antigravity:Li,windsurf:fu,codex:Fi};l(hu,"whichCommand");l(mh,"getCliVersion");l(zr,"detectProvider");l(yu,"validateCliVersion");l(ir,"detectAllProviders");l(gh,"getActiveProvider");l(fh,"hasProviderConfig");l(qr,"getProviderBranding");l(wu,"detectCursorProject");l(hh,"needsCursorRouterRegeneration");l(ku,"detectWindsurfProject");l(yh,"needsWindsurfRouterRegeneration");l(Kr,"detectAntigravity");l(Os,"detectCodex");l(wh,"getGlobalContextPath");l(kh,"getGlobalSettingsPath");l(Sh,"getSkillsPath");l(bh,"getCommandsDir");l(vh,"getProjectCommandsPath");l(Ui,"selectProvider")});import Th from"node:crypto";import qt from"node:fs/promises";import Hi from"node:os";import J from"node:path";import{globSync as Ch}from"glob";var Gi,Ph,A,ve=S(()=>{"use strict";oe();q();Gi=class{static{l(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?J.resolve(e):J.join(Hi.homedir(),".prjct-cli"),this.globalProjectsDir=J.join(this.globalBaseDir,"projects"),this.globalConfigDir=J.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=J.resolve(e),this.globalProjectsDir=J.join(this.globalBaseDir,"projects"),this.globalConfigDir=J.join(this.globalBaseDir,"config")}generateProjectId(e){return Th.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return J.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return J.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return J.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return J.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await es(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await C(t)}async ensureGlobalStructure(){await vt(this.globalBaseDir),await vt(this.globalProjectsDir),await vt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),s=["core","progress","planning","analysis","memory"];for(let n of s)await vt(J.join(t,n));return await vt(J.join(t,"planning","tasks")),await vt(J.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:s,month:n,day:o}=$i(t);return J.join(this.getGlobalProjectPath(e),"sessions",s,n,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let s=this.getSessionPath(e,t);return await vt(s),s}async listSessions(e,t=null,s=null){let n=J.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await qt.readdir(n,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let c=J.join(n,a.name),u=await qt.readdir(c,{withFileTypes:!0});for(let p of u){if(!p.isDirectory()||s&&p.name!==s.toString().padStart(2,"0"))continue;let m=J.join(c,p.name),d=await qt.readdir(m,{withFileTypes:!0});for(let g of d)g.isDirectory()&&o.push({year:a.name,month:p.name,day:g.name,path:J.join(m,g.name),date:new Date(`${a.name}-${p.name}-${g.name}`)})}}return o.sort((a,c)=>c.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 J.join(this.getGlobalProjectPath(e),t,s)}async listProjects(){try{return await this.ensureGlobalStructure(),(await qt.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 es(t)}getDisplayPath(e){let t=Hi.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return J.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return J.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return J.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return J.join(this.globalBaseDir,".running")}getDocsPath(){return J.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(it(),bt(Tt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(it(),bt(Tt)).getActiveProvider();return(it(),bt(Tt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return J.join(Hi.homedir(),".claude")}getClaudeSettingsPath(){return J.join(this.getClaudeDir(),"settings.json")}getStoragePath(e,t){return J.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return J.join(this.getGlobalProjectPath(e),"context")}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 n of s){let o=J.join(e,n.file);if(await C(o)){t.isMonorepo=!0,t.type=n.type;break}}if(!t.isMonorepo){let n=J.join(e,"package.json");if(await C(n))try{let o=await qt.readFile(n,"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=[],n=[];try{if(t==="pnpm"){let i=(await qt.readFile(J.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(n=i[1].split(`
12
- `).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=J.join(e,"package.json"),i=await qt.readFile(o,"utf-8"),a=JSON.parse(i);if(Array.isArray(a.workspaces)?n=a.workspaces:a.workspaces?.packages&&(n=a.workspaces.packages),t==="lerna"){let c=J.join(e,"lerna.json");if(await C(c)){let u=await qt.readFile(c,"utf-8"),p=JSON.parse(u);p.packages&&(n=p.packages)}}}else if(t==="nx")n=["apps/*","libs/*","packages/*"];else if(t==="turborepo"){let o=J.join(e,"package.json"),i=await qt.readFile(o,"utf-8"),a=JSON.parse(i);Array.isArray(a.workspaces)&&(n=a.workspaces)}n.length===0&&(n=["packages/*","apps/*","libs/*"]);for(let o of n){if(o.startsWith("!"))continue;let i=Ch(o,{cwd:e,absolute:!1});for(let a of i){let c=J.join(e,a),u=J.join(c,"package.json");if(await C(u))try{let p=await qt.readFile(u,"utf-8"),m=JSON.parse(p),d=J.join(c,"PRJCT.md");s.push({name:m.name||J.basename(a),path:c,relativePath:a,hasPrjctMd:await C(d)})}catch{}}}}catch{}return s}async findContainingPackage(e,t){if(!t.isMonorepo)return null;let s=J.resolve(e);for(let n of t.packages){let o=J.resolve(n.path);if(s.startsWith(o))return n}return null}async findMonorepoRoot(e){let t=J.resolve(e),s=J.parse(t).root;for(;t!==s;){if((await this.detectMonorepo(t)).isMonorepo)return t;t=J.dirname(t)}return null}},Ph=new Gi,A=Ph});function Su(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function Vi(){if(Su()==="bun")return!0;try{let{execSync:r}=St("node:child_process");return r("bun --version",{stdio:"ignore"}),!0}catch{return!1}}function _s(){return Su()==="bun"}var ar=S(()=>{"use strict";l(Su,"detectRuntime");l(Vi,"isBunAvailable");l(_s,"isBun")});import Wi from"node:fs";import bu from"node:path";function Eh(r){if(_s()){let{Database:n}=St("bun:sqlite");return new n(r,{create:!0})}let e=St("better-sqlite3"),t=new e(r),s=t.exec.bind(t);return t.run=n=>s(n),t}var xh,Rh,Bi,P,F,ce=S(()=>{"use strict";ve();ar();l(Eh,"openDatabase");xh=[{version:1,name:"initial-schema",up:l(r=>{r.run(`
8
+ var zr=Object.defineProperty;var If=Object.getOwnPropertyDescriptor;var $f=Object.getOwnPropertyNames;var Mf=Object.prototype.hasOwnProperty;var l=(r,e)=>zr(r,"name",{value:e,configurable:!0}),bt=(r=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(r,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):r)(function(r){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+r+'" is not supported')});var S=(r,e)=>()=>(r&&(e=r(r=0)),e);var Ot=(r,e)=>{for(var t in e)zr(r,t,{get:e[t],enumerable:!0})},_f=(r,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of $f(e))!Mf.call(r,n)&&n!==t&&zr(r,n,{get:()=>e[n],enumerable:!(s=If(e,n))||s.enumerable});return r};var ot=r=>_f(zr({},"__esModule",{value:!0}),r);var J={};Ot(J,{calculateDuration:()=>Vf,formatDate:()=>ln,formatDuration:()=>ht,formatMonth:()=>Nf,getDateKey:()=>Lf,getDateRange:()=>Hf,getDaysAgo:()=>gs,getDaysFromNow:()=>Uf,getEndOfDay:()=>zf,getStartOfDay:()=>Bf,getTimestamp:()=>T,getTodayKey:()=>Zl,getYearMonthDay:()=>Oi,isToday:()=>Gf,isWithinLastDays:()=>Wf,parseDate:()=>Ff,parseDurationMinutes:()=>yt,parseVarianceMinutes:()=>js,toRelative:()=>Jf});import{formatDistanceToNowStrict as Of}from"date-fns";function ln(r){let e=r.getFullYear(),t=(r.getMonth()+1).toString().padStart(2,"0"),s=r.getDate().toString().padStart(2,"0");return`${e}-${t}-${s}`}function Nf(r){let e=r.getFullYear(),t=(r.getMonth()+1).toString().padStart(2,"0");return`${e}-${t}`}function Zl(){return ln(new Date)}function Lf(r){return ln(r)}function Oi(r){return{year:r.getFullYear().toString(),month:(r.getMonth()+1).toString().padStart(2,"0"),day:r.getDate().toString().padStart(2,"0")}}function Ff(r){return new Date(r)}function T(){return new Date().toISOString()}function gs(r){let e=new Date;return e.setDate(e.getDate()-r),e}function Uf(r){let e=new Date;return e.setDate(e.getDate()+r),e}function Hf(r,e){let t=[],s=new Date(r);for(;s<=e;)t.push(new Date(s)),s=new Date(s.getFullYear(),s.getMonth(),s.getDate()+1);return t}function Gf(r){return ln(r)===Zl()}function Wf(r,e){let t=gs(e);return r>=t}function ht(r){let e=Math.floor(r/1e3),t=Math.floor(e/60),s=Math.floor(t/60),n=Math.floor(s/24);return n>0?`${n}d ${s%24}h`:s>0?`${s}h ${t%60}m`:t>0?`${t}m`:`${e}s`}function Vf(r,e=new Date){let t=e.getTime()-r.getTime();return ht(t)}function Bf(r){let e=new Date(r);return e.setHours(0,0,0,0),e}function zf(r){let e=new Date(r);return e.setHours(23,59,59,999),e}function Jf(r){let e=typeof r=="string"?new Date(r):r;return Of(e,{addSuffix:!0})}function js(r){let e=r.match(/^([+-])(\d+)([mh])$/);if(!e)return 0;let t=e[1]==="-"?-1:1,s=Number.parseInt(e[2],10),n=e[3];return t*(n==="h"?s*60:s)}function yt(r){let e=0,t=r.match(/(\d+)h/);t&&(e+=Number.parseInt(t[1],10)*60);let s=r.match(/(\d+)m/);return s&&(e+=Number.parseInt(s[1],10)),r.match(/(\d+)s/)&&e===0&&(e=1),e}var ie=S(()=>{"use strict";l(ln,"formatDate");l(Nf,"formatMonth");l(Zl,"getTodayKey");l(Lf,"getDateKey");l(Oi,"getYearMonthDay");l(Ff,"parseDate");l(T,"getTimestamp");l(gs,"getDaysAgo");l(Uf,"getDaysFromNow");l(Hf,"getDateRange");l(Gf,"isToday");l(Wf,"isWithinLastDays");l(ht,"formatDuration");l(Vf,"calculateDuration");l(Bf,"getStartOfDay");l(zf,"getEndOfDay");l(Jf,"toRelative");l(js,"parseVarianceMinutes");l(yt,"parseDurationMinutes")});var eu,tu,su,Ni=S(()=>{"use strict";eu=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"]),tu=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],su=/(?:import|from)\s+['"]([^'"]+)['"]/g});function qf(r){return r instanceof Error&&"code"in r}function R(r){return qf(r)&&r.code==="ENOENT"}function w(r){return r instanceof Error?r.message:typeof r=="string"?r:"Unknown error"}var W=S(()=>{"use strict";l(qf,"isNodeError");l(R,"isNotFoundError");l(w,"getErrorMessage")});import ou from"node:fs/promises";async function iu(r,e){let t;try{t=await ou.readFile(r,"utf-8")}catch(o){if(R(o))return null;throw o}let s;try{s=JSON.parse(t)}catch{return await nu(r,t),ru(r,"Malformed JSON"),null}let n=e.safeParse(s);return n.success?s:(await nu(r,t),ru(r,Kf(n.error)),null)}async function nu(r,e){let t=`${r}.backup`;try{await ou.writeFile(t,e,"utf-8")}catch{}}function ru(r,e){console.error(`[prjct] Warning: Corrupted storage file: ${r}`),console.error(`[prjct] Reason: ${e}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function Kf(r){return r.issues.slice(0,3).map(e=>`${e.path.join(".")}: ${e.message}`).join("; ")}var au=S(()=>{"use strict";W();l(iu,"safeRead");l(nu,"createBackup");l(ru,"logCorruption");l(Kf,"formatZodError")});var Re={};Ot(Re,{appendLine:()=>Li,appendToFile:()=>Yf,atomicWrite:()=>Xf,batchProcess:()=>$s,copyFile:()=>nh,deleteDir:()=>eh,deleteFile:()=>Zf,dirExists:()=>es,ensureDir:()=>Tt,fileExists:()=>P,getFileExtension:()=>ah,getFileModifiedTime:()=>sh,getFileNameWithoutExtension:()=>ch,getFileSize:()=>th,listFiles:()=>ts,moveFile:()=>rh,prependToFile:()=>Qf,readFile:()=>it,readJson:()=>xe,readLines:()=>oh,walkDir:()=>Is,writeFile:()=>Jt,writeJson:()=>le,writeLines:()=>ih});import we from"node:fs/promises";import Zt from"node:path";async function Is(r,e={}){let t=[],s=e.maxFiles??1/0,n=e.dotfileAllowlist?new Set(e.dotfileAllowlist):null;async function o(i){if(t.length>=s)return;let a=await we.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let c of a){if(t.length>=s)break;let u=String(c.name);if(eu.has(u)||e.skipDotfiles&&u.startsWith(".")&&(!n||!n.has(u)))continue;let p=Zt.join(i,u);c.isDirectory()?await o(p):c.isFile()&&t.push(Zt.relative(r,p))}}return l(o,"walk"),await o(r),t}async function $s(r,e,t){let s=[];for(let n=0;n<r.length;n+=e){let o=await Promise.all(r.slice(n,n+e).map(t));for(let i of o)i!==null&&s.push(i)}return s}async function xe(r,e=null,t){if(t)return await iu(r,t)??e;try{let s=await we.readFile(r,"utf-8");return JSON.parse(s)}catch(s){if(R(s))return e;throw s}}async function le(r,e,t=2){let s=Zt.dirname(r);await we.mkdir(s,{recursive:!0});let n=JSON.stringify(e,null,t);await we.writeFile(r,n,"utf-8")}async function it(r,e=""){try{return await we.readFile(r,"utf-8")}catch(t){if(R(t))return e;throw t}}async function Jt(r,e){let t=Zt.dirname(r);await we.mkdir(t,{recursive:!0}),await we.writeFile(r,e,"utf-8")}async function Xf(r,e){let t=Zt.dirname(r);await we.mkdir(t,{recursive:!0});let s=`${r}.${Date.now()}.tmp`;await we.writeFile(s,e,"utf-8"),await we.rename(s,r)}async function Yf(r,e){await we.appendFile(r,e,"utf-8")}async function Li(r,e){let t=Zt.dirname(r);await we.mkdir(t,{recursive:!0}),await we.appendFile(r,`${e}
9
+ `,"utf-8")}async function Qf(r,e){try{let t=await we.readFile(r,"utf-8");await we.writeFile(r,e+t,"utf-8")}catch(t){if(R(t))await we.writeFile(r,e,"utf-8");else throw t}}async function P(r){try{return await we.access(r),!0}catch(e){if(R(e))return!1;throw e}}async function es(r){try{return(await we.stat(r)).isDirectory()}catch(e){if(R(e))return!1;throw e}}async function Tt(r){await we.mkdir(r,{recursive:!0})}async function Zf(r){try{return await we.unlink(r),!0}catch(e){if(R(e))return!1;throw e}}async function eh(r){try{return await we.rm(r,{recursive:!0,force:!0}),!0}catch(e){if(R(e))return!1;throw e}}async function ts(r,e={}){try{let s=await we.readdir(r,{withFileTypes:!0});return e.filesOnly&&(s=s.filter(n=>n.isFile())),e.dirsOnly&&(s=s.filter(n=>n.isDirectory())),e.extension&&(s=s.filter(n=>n.name.endsWith(e.extension))),s.map(n=>n.name)}catch(t){if(R(t))return[];throw t}}async function th(r){return(await we.stat(r)).size}async function sh(r){return(await we.stat(r)).mtime}async function nh(r,e){await we.copyFile(r,e)}async function rh(r,e){await we.rename(r,e)}async function oh(r){return(await it(r,"")).split(`
10
+ `)}async function ih(r,e){let t=e.join(`
11
+ `);await Jt(r,t)}function ah(r){return Zt.extname(r)}function ch(r){return Zt.basename(r,Zt.extname(r))}var K=S(()=>{"use strict";Ni();au();W();l(Is,"walkDir");l($s,"batchProcess");l(xe,"readJson");l(le,"writeJson");l(it,"readFile");l(Jt,"writeFile");l(Xf,"atomicWrite");l(Yf,"appendToFile");l(Li,"appendLine");l(Qf,"prependToFile");l(P,"fileExists");l(es,"dirExists");l(Tt,"ensureDir");l(Zf,"deleteFile");l(eh,"deleteDir");l(ts,"listFiles");l(th,"getFileSize");l(sh,"getFileModifiedTime");l(nh,"copyFile");l(rh,"moveFile");l(oh,"readLines");l(ih,"writeLines");l(ah,"getFileExtension");l(ch,"getFileNameWithoutExtension")});var or=S(()=>{"use strict"});import{z as qt}from"zod";function cu(r,e){let t=r.split(".").map(Number),s=e.split(".").map(Number);for(let n=0;n<3;n++){let o=t[n]??0,i=s[n]??0;if(o<i)return-1;if(o>i)return 1}return 0}var Uv,Hv,Gv,un,Wv,Jr=S(()=>{"use strict";Uv=qt.enum(["opus","sonnet","haiku"]),Hv=qt.enum(["2.5-pro","2.5-flash","2.0-flash"]),Gv=qt.string().min(1),un=qt.object({provider:qt.string(),model:qt.string(),cliVersion:qt.string().optional(),recordedAt:qt.string()}),Wv=qt.object({preferredModel:qt.string().optional(),lastAnalysisModel:un.optional()});l(cu,"compareSemver")});var uu={};Ot(uu,{execAsync:()=>O,execFileAsync:()=>Fi});import{exec as lh,execFile as uh}from"node:child_process";import{promisify as lu}from"node:util";var O,Fi,He=S(()=>{"use strict";O=lu(lh),Fi=lu(uh)});function fs(r,e){let t=typeof r=="string"?new Date(r).getTime():r;return Date.now()-t>e}var dn,Ms=S(()=>{"use strict";l(fs,"isExpired");dn=class{static{l(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,n)=>s[1].timestamp-n[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}}});import dh from"node:fs/promises";import ph from"node:os";import du from"node:path";async function mu(){try{let r=await dh.readFile(pu,"utf-8"),e=JSON.parse(r);return!e.timestamp||!e.detection||!e.detection.claude||!e.detection.gemini||!e.detection.codex||fs(e.timestamp,gh)?null:e.detection}catch{return null}}async function gu(r){let e={timestamp:new Date().toISOString(),detection:r};await le(pu,e)}var mh,pu,gh,fu=S(()=>{"use strict";Ms();K();mh=du.join(ph.homedir(),".prjct-cli","cache"),pu=du.join(mh,"providers.json"),gh=600*1e3;l(mu,"readProviderCache");l(gu,"writeProviderCache")});var vt={};Ot(vt,{AntigravityProvider:()=>Hi,ClaudeProvider:()=>qr,CodexProvider:()=>Gi,CursorProvider:()=>yu,GeminiProvider:()=>Ui,Providers:()=>gt,WindsurfProvider:()=>wu,detectAllProviders:()=>ir,detectAntigravity:()=>Yr,detectCodex:()=>_s,detectCursorProject:()=>bu,detectProvider:()=>Kr,detectWindsurfProject:()=>Tu,getActiveProvider:()=>wh,getCapabilities:()=>hh,getCommandsDir:()=>Ph,getGlobalContextPath:()=>Th,getGlobalSettingsPath:()=>vh,getProjectCommandsPath:()=>Eh,getProviderBranding:()=>Xr,getSkillsPath:()=>Ch,hasProviderConfig:()=>kh,needsCursorRouterRegeneration:()=>Sh,needsWindsurfRouterRegeneration:()=>bh,selectProvider:()=>Wi,validateCliVersion:()=>Su});import hs from"node:os";import Ve from"node:path";function hh(r,e){return{...fh[r],...e}}async function ku(r){try{let{stdout:e}=await O(`which ${r}`,{timeout:2e3});return e.trim()}catch{return null}}async function yh(r){try{let{stdout:e}=await O(`${r} --version`,{timeout:2e3}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function Kr(r){let e=gt[r];if(!e.cliCommand)return{installed:!1};let t=await ku(e.cliCommand);if(!t)return{installed:!1};let s=await yh(e.cliCommand),n=Su(r,s||void 0);return{installed:!0,version:s||void 0,path:t,versionWarning:n||void 0}}function Su(r,e){let t=gt[r];return!t.minCliVersion||!e?null:cu(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 ir(r=!1){if(!r){let i=await mu();if(i)return i}let[e,t,s]=await Promise.all([Kr("claude"),Kr("gemini"),_s()]),n={installed:s.installed},o={claude:e,gemini:t,codex:n};return await gu(o).catch(()=>{}),o}async function wh(r){if(r&&gt[r])return gt[r];let e=await ir();return e.claude.installed&&!e.gemini.installed?qr:e.gemini.installed&&!e.claude.installed?Ui:qr}async function kh(r){let e=gt[r];return e.configDir?P(e.configDir):!1}function Xr(r){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"}[r]||"\u26A1 prjct"}}async function bu(r){let e=Ve.join(r,".cursor"),t=Ve.join(e,"rules"),s=Ve.join(t,"prjct.mdc"),[n,o]=await Promise.all([P(e),P(s)]);return{detected:n,routerInstalled:o,projectRoot:n?r:void 0}}async function Sh(r){let e=await bu(r);return e.detected&&!e.routerInstalled}async function Tu(r){let e=Ve.join(r,".windsurf"),t=Ve.join(e,"rules"),s=Ve.join(t,"prjct.md"),[n,o]=await Promise.all([P(e),P(s)]);return{detected:n,routerInstalled:o,projectRoot:n?r:void 0}}async function bh(r){let e=await Tu(r);return e.detected&&!e.routerInstalled}async function Yr(){let r=Hi.configDir;if(!r)return{installed:!1,skillInstalled:!1};let e=Ve.join(r,"skills","prjct","SKILL.md"),[t,s]=await Promise.all([P(r),P(e)]);return{installed:t,skillInstalled:s,configPath:t?r:void 0}}async function _s(){let r=Gi.configDir;if(!r)return{installed:!1,skillInstalled:!1};let e=await ku("codex"),t=Ve.join(r,"skills","prjct","SKILL.md"),s=await P(t),n=!!e;return{installed:n,skillInstalled:s,configPath:n?r:void 0}}function Th(r){let e=gt[r];return e.configDir?Ve.join(e.configDir,e.contextFile):null}function vh(r){let e=gt[r];return!e.configDir||!e.settingsFile?null:Ve.join(e.configDir,e.settingsFile)}function Ch(r){return gt[r].skillsDir}function Ph(r){return gt[r].commandsDir}function Eh(r,e){let t=gt[r];return Ve.join(e,t.commandsDir)}async function Wi(){let r=await ir(),e=r.claude.installed,t=r.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:r}:e&&!t?{provider:"claude",userSelected:!1,detection:r}:t&&!e?{provider:"gemini",userSelected:!1,detection:r}:{provider:"claude",userSelected:!0,detection:r}}var fh,qr,Ui,Hi,yu,wu,Gi,gt,at=S(()=>{"use strict";or();Jr();He();K();fu();fh={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}};l(hh,"getCapabilities");qr={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:Ve.join(hs.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:Ve.join(hs.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"},Ui={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:Ve.join(hs.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:Ve.join(hs.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"},Hi={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:Ve.join(hs.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:Ve.join(hs.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"},yu={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"},wu={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"},Gi={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:Ve.join(hs.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:Ve.join(hs.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"},gt={claude:qr,gemini:Ui,cursor:yu,antigravity:Hi,windsurf:wu,codex:Gi};l(ku,"whichCommand");l(yh,"getCliVersion");l(Kr,"detectProvider");l(Su,"validateCliVersion");l(ir,"detectAllProviders");l(wh,"getActiveProvider");l(kh,"hasProviderConfig");l(Xr,"getProviderBranding");l(bu,"detectCursorProject");l(Sh,"needsCursorRouterRegeneration");l(Tu,"detectWindsurfProject");l(bh,"needsWindsurfRouterRegeneration");l(Yr,"detectAntigravity");l(_s,"detectCodex");l(Th,"getGlobalContextPath");l(vh,"getGlobalSettingsPath");l(Ch,"getSkillsPath");l(Ph,"getCommandsDir");l(Eh,"getProjectCommandsPath");l(Wi,"selectProvider")});import xh from"node:crypto";import Kt from"node:fs/promises";import Vi from"node:os";import z from"node:path";import{globSync as Rh}from"glob";var Bi,Ah,A,Te=S(()=>{"use strict";ie();K();Bi=class{static{l(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?z.resolve(e):z.join(Vi.homedir(),".prjct-cli"),this.globalProjectsDir=z.join(this.globalBaseDir,"projects"),this.globalConfigDir=z.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=z.resolve(e),this.globalProjectsDir=z.join(this.globalBaseDir,"projects"),this.globalConfigDir=z.join(this.globalBaseDir,"config")}generateProjectId(e){return xh.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return z.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return z.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return z.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return z.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await es(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await P(t)}async ensureGlobalStructure(){await Tt(this.globalBaseDir),await Tt(this.globalProjectsDir),await Tt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),s=["core","progress","planning","analysis","memory"];for(let n of s)await Tt(z.join(t,n));return await Tt(z.join(t,"planning","tasks")),await Tt(z.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:s,month:n,day:o}=Oi(t);return z.join(this.getGlobalProjectPath(e),"sessions",s,n,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let s=this.getSessionPath(e,t);return await Tt(s),s}async listSessions(e,t=null,s=null){let n=z.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Kt.readdir(n,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let c=z.join(n,a.name),u=await Kt.readdir(c,{withFileTypes:!0});for(let p of u){if(!p.isDirectory()||s&&p.name!==s.toString().padStart(2,"0"))continue;let m=z.join(c,p.name),d=await Kt.readdir(m,{withFileTypes:!0});for(let g of d)g.isDirectory()&&o.push({year:a.name,month:p.name,day:g.name,path:z.join(m,g.name),date:new Date(`${a.name}-${p.name}-${g.name}`)})}}return o.sort((a,c)=>c.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 z.join(this.getGlobalProjectPath(e),t,s)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Kt.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 es(t)}getDisplayPath(e){let t=Vi.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return z.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return z.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return z.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return z.join(this.globalBaseDir,".running")}getDocsPath(){return z.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(at(),ot(vt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(at(),ot(vt)).getActiveProvider();return(at(),ot(vt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return z.join(Vi.homedir(),".claude")}getClaudeSettingsPath(){return z.join(this.getClaudeDir(),"settings.json")}getStoragePath(e,t){return z.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return z.join(this.getGlobalProjectPath(e),"context")}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 n of s){let o=z.join(e,n.file);if(await P(o)){t.isMonorepo=!0,t.type=n.type;break}}if(!t.isMonorepo){let n=z.join(e,"package.json");if(await P(n))try{let o=await Kt.readFile(n,"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=[],n=[];try{if(t==="pnpm"){let i=(await Kt.readFile(z.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(n=i[1].split(`
12
+ `).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=z.join(e,"package.json"),i=await Kt.readFile(o,"utf-8"),a=JSON.parse(i);if(Array.isArray(a.workspaces)?n=a.workspaces:a.workspaces?.packages&&(n=a.workspaces.packages),t==="lerna"){let c=z.join(e,"lerna.json");if(await P(c)){let u=await Kt.readFile(c,"utf-8"),p=JSON.parse(u);p.packages&&(n=p.packages)}}}else if(t==="nx")n=["apps/*","libs/*","packages/*"];else if(t==="turborepo"){let o=z.join(e,"package.json"),i=await Kt.readFile(o,"utf-8"),a=JSON.parse(i);Array.isArray(a.workspaces)&&(n=a.workspaces)}n.length===0&&(n=["packages/*","apps/*","libs/*"]);for(let o of n){if(o.startsWith("!"))continue;let i=Rh(o,{cwd:e,absolute:!1});for(let a of i){let c=z.join(e,a),u=z.join(c,"package.json");if(await P(u))try{let p=await Kt.readFile(u,"utf-8"),m=JSON.parse(p),d=z.join(c,"PRJCT.md");s.push({name:m.name||z.basename(a),path:c,relativePath:a,hasPrjctMd:await P(d)})}catch{}}}}catch{}return s}async findContainingPackage(e,t){if(!t.isMonorepo)return null;let s=z.resolve(e);for(let n of t.packages){let o=z.resolve(n.path);if(s.startsWith(o))return n}return null}async findMonorepoRoot(e){let t=z.resolve(e),s=z.parse(t).root;for(;t!==s;){if((await this.detectMonorepo(t)).isMonorepo)return t;t=z.dirname(t)}return null}},Ah=new Bi,A=Ah});function vu(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function zi(){if(vu()==="bun")return!0;try{let{execSync:r}=bt("node:child_process");return r("bun --version",{stdio:"ignore"}),!0}catch{return!1}}function Os(){return vu()==="bun"}var ar=S(()=>{"use strict";l(vu,"detectRuntime");l(zi,"isBunAvailable");l(Os,"isBun")});var Zr={};Ot(Zr,{PrjctDatabase:()=>Qr,default:()=>N,prjctDb:()=>C});import Ji from"node:fs";import Cu from"node:path";function Dh(r){if(Os()){let{Database:n}=bt("bun:sqlite");return new n(r,{create:!0})}let e=bt("better-sqlite3"),t=new e(r),s=t.exec.bind(t);return t.run=n=>s(n),t}var jh,Ih,Qr,C,N,re=S(()=>{"use strict";Te();ar();l(Dh,"openDatabase");jh=[{version:1,name:"initial-schema",up:l(r=>{r.run(`
13
13
  -- =======================================================================
14
14
  -- Document storage (backward-compatible with JSON file pattern)
15
15
  -- =======================================================================
@@ -343,22 +343,52 @@ var Wr=Object.defineProperty;var Rf=Object.getOwnPropertyDescriptor;var Af=Objec
343
343
  -- =======================================================================
344
344
  ALTER TABLE tasks ADD COLUMN tokens_in INTEGER DEFAULT 0;
345
345
  ALTER TABLE tasks ADD COLUMN tokens_out INTEGER DEFAULT 0;
346
- `)},"up")}],Rh=3,Bi=class{static{l(this,"PrjctDatabase")}connections=new Map;accessOrder=[];getDbPath(e){return bu.join(A.getGlobalProjectPath(e),"prjct.db")}getDb(e){let t=this.connections.get(e);if(t)return this.touchAccessOrder(e),t;this.connections.size>=Rh&&this.evictLru();let s=this.getDbPath(e),n=bu.dirname(s);Wi.existsSync(n)||Wi.mkdirSync(n,{recursive:!0});let o=Eh(s);return o.run("PRAGMA journal_mode = WAL"),o.run("PRAGMA synchronous = NORMAL"),o.run("PRAGMA cache_size = -2000"),o.run("PRAGMA temp_store = MEMORY"),o.run("PRAGMA mmap_size = 33554432"),this.runMigrations(o),this.connections.set(e,o),this.touchAccessOrder(e),o}close(e){if(e){let t=this.connections.get(e);t&&(t.close(),this.connections.delete(e),this.accessOrder=this.accessOrder.filter(s=>s!==e))}else this.connections.forEach(t=>{t.close()}),this.connections.clear(),this.accessOrder=[]}touchAccessOrder(e){this.accessOrder=this.accessOrder.filter(t=>t!==e),this.accessOrder.push(e)}evictLru(){if(this.accessOrder.length===0)return;let e=this.accessOrder.shift(),t=this.connections.get(e);t&&(t.close(),this.connections.delete(e))}checkpointAll(){for(let[e,t]of this.connections)try{t.run("PRAGMA wal_checkpoint(TRUNCATE)")}catch{}}exists(e){return Wi.existsSync(this.getDbPath(e))}getDoc(e,t){let n=this.getDb(e).prepare("SELECT data FROM kv_store WHERE key = ?").get(t);return n?JSON.parse(n.data):null}setDoc(e,t,s){let n=this.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();n.prepare("INSERT OR REPLACE INTO kv_store (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}deleteDoc(e,t){this.getDb(e).prepare("DELETE FROM kv_store WHERE key = ?").run(t)}hasDoc(e,t){return this.getDb(e).prepare("SELECT 1 FROM kv_store WHERE key = ?").get(t)!==null}appendEvent(e,t,s,n){let o=this.getDb(e),i=new Date().toISOString();o.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)").run(t,n??null,JSON.stringify(s),i)}getEvents(e,t,s=100){let n=this.getDb(e);return t?n.prepare("SELECT * FROM events WHERE type = ? ORDER BY id DESC LIMIT ?").all(t,s):n.prepare("SELECT * FROM events ORDER BY id DESC LIMIT ?").all(s)}query(e,t,...s){return this.getDb(e).prepare(t).all(...s)}run(e,t,...s){this.getDb(e).prepare(t).run(...s)}get(e,t,...s){return this.getDb(e).prepare(t).get(...s)??null}transaction(e,t){let s=this.getDb(e);return s.transaction(t)(s)}runMigrations(e){e.run(`
346
+ `)},"up")},{version:9,name:"context-health-tables",up:l(r=>{r.run(`
347
+ -- =======================================================================
348
+ -- Context Zone Events: Track zone transitions for health analytics
349
+ -- =======================================================================
350
+ CREATE TABLE context_zone_events (
351
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
352
+ project_id TEXT NOT NULL,
353
+ session_id TEXT,
354
+ zone_from TEXT NOT NULL,
355
+ zone_to TEXT NOT NULL,
356
+ usage_percent REAL NOT NULL,
357
+ action TEXT,
358
+ timestamp TEXT NOT NULL
359
+ );
360
+
361
+ CREATE INDEX idx_cze_project ON context_zone_events(project_id);
362
+
363
+ -- =======================================================================
364
+ -- Context Compactions: Track compaction events
365
+ -- =======================================================================
366
+ CREATE TABLE context_compactions (
367
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
368
+ project_id TEXT NOT NULL,
369
+ format TEXT NOT NULL DEFAULT 'standard',
370
+ original_turns INTEGER NOT NULL,
371
+ files_count INTEGER NOT NULL DEFAULT 0,
372
+ timestamp TEXT NOT NULL
373
+ );
374
+
375
+ CREATE INDEX idx_cc_project ON context_compactions(project_id);
376
+ `)},"up")}],Ih=3,Qr=class{static{l(this,"PrjctDatabase")}connections=new Map;accessOrder=[];getDbPath(e){return Cu.join(A.getGlobalProjectPath(e),"prjct.db")}getDb(e){let t=this.connections.get(e);if(t)return this.touchAccessOrder(e),t;this.connections.size>=Ih&&this.evictLru();let s=this.getDbPath(e),n=Cu.dirname(s);Ji.existsSync(n)||Ji.mkdirSync(n,{recursive:!0});let o=Dh(s);return o.run("PRAGMA journal_mode = WAL"),o.run("PRAGMA synchronous = NORMAL"),o.run("PRAGMA cache_size = -2000"),o.run("PRAGMA temp_store = MEMORY"),o.run("PRAGMA mmap_size = 33554432"),this.runMigrations(o),this.connections.set(e,o),this.touchAccessOrder(e),o}close(e){if(e){let t=this.connections.get(e);t&&(t.close(),this.connections.delete(e),this.accessOrder=this.accessOrder.filter(s=>s!==e))}else this.connections.forEach(t=>{t.close()}),this.connections.clear(),this.accessOrder=[]}touchAccessOrder(e){this.accessOrder=this.accessOrder.filter(t=>t!==e),this.accessOrder.push(e)}evictLru(){if(this.accessOrder.length===0)return;let e=this.accessOrder.shift(),t=this.connections.get(e);t&&(t.close(),this.connections.delete(e))}checkpointAll(){for(let[e,t]of this.connections)try{t.run("PRAGMA wal_checkpoint(TRUNCATE)")}catch{}}exists(e){return Ji.existsSync(this.getDbPath(e))}getDoc(e,t){let n=this.getDb(e).prepare("SELECT data FROM kv_store WHERE key = ?").get(t);return n?JSON.parse(n.data):null}setDoc(e,t,s){let n=this.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();n.prepare("INSERT OR REPLACE INTO kv_store (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}deleteDoc(e,t){this.getDb(e).prepare("DELETE FROM kv_store WHERE key = ?").run(t)}hasDoc(e,t){return this.getDb(e).prepare("SELECT 1 FROM kv_store WHERE key = ?").get(t)!==null}appendEvent(e,t,s,n){let o=this.getDb(e),i=new Date().toISOString();o.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)").run(t,n??null,JSON.stringify(s),i)}getEvents(e,t,s=100){let n=this.getDb(e);return t?n.prepare("SELECT * FROM events WHERE type = ? ORDER BY id DESC LIMIT ?").all(t,s):n.prepare("SELECT * FROM events ORDER BY id DESC LIMIT ?").all(s)}query(e,t,...s){return this.getDb(e).prepare(t).all(...s)}run(e,t,...s){this.getDb(e).prepare(t).run(...s)}get(e,t,...s){return this.getDb(e).prepare(t).get(...s)??null}transaction(e,t){let s=this.getDb(e);return s.transaction(t)(s)}runMigrations(e){e.run(`
347
377
  CREATE TABLE IF NOT EXISTS _migrations (
348
378
  version INTEGER PRIMARY KEY,
349
379
  name TEXT NOT NULL,
350
380
  applied_at TEXT NOT NULL
351
381
  )
352
- `);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(s=>s.version));for(let s of xh)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}},P=new Bi,F=P});function Xr(r,e=!1){return e||r>=6?"high":r>=3?"medium":"low"}var H,cr=S(()=>{"use strict";H={CODE_STYLE:"code_style",NAMING_CONVENTION:"naming_convention",FILE_STRUCTURE:"file_structure",COMMIT_STYLE:"commit_style",BRANCH_NAMING:"branch_naming",TEST_BEHAVIOR:"test_behavior",SHIP_WORKFLOW:"ship_workflow",TECH_STACK:"tech_stack",ARCHITECTURE:"architecture",DEPENDENCIES:"dependencies",OUTPUT_VERBOSITY:"output_verbosity",CONFIRMATION_LEVEL:"confirmation_level",AGENT_PREFERENCE:"agent_preference"};l(Xr,"calculateConfidence")});var Ns,lr,ur,dr=S(()=>{"use strict";ce();cr();oe();Ns=class{static{l(this,"CachedStore")}_data=null;_loaded=!1;_projectId=null;getSubdirectory(){return null}getStoreKey(){let e=this.getFilename().replace(".json",""),t=this.getSubdirectory();return t?`memory:${t}:${e}`:`memory:${e}`}async load(e){if(this._loaded&&this._data&&this._projectId===e)return this._data;let t=this.getStoreKey(),s=F.getDoc(e,t);return s!==null?(this._data=s,this.afterLoad(this._data)):this._data=this.getDefault(),this._loaded=!0,this._projectId=e,this._data}afterLoad(e){}async save(e){if(!this._data)return;let t=this.getStoreKey();F.setDoc(e,t,this._data)}getData(){return this._data}setData(e){this._data=e}async update(e,t){let s=await this.load(e),n=t(s);return this._data=n,await this.save(e),n}isLoaded(e){return e?this._loaded&&this._projectId===e:this._loaded}reset(){this._data=null,this._loaded=!1,this._projectId=null}},lr=class{static{l(this,"SessionStore")}_sessionMemory=new Map;setSession(e,t){this._sessionMemory.set(e,{value:t,timestamp:Date.now()})}getSession(e){return this._sessionMemory.get(e)?.value}clearSession(){this._sessionMemory.clear()}},ur=class{static{l(this,"HistoryStore")}async appendHistory(e,t){let s={ts:v(),...t,type:t.type};F.appendEvent(e,`history.${t.type}`,s)}async getRecentHistory(e,t=20){return F.query(e,"SELECT data, timestamp FROM events WHERE type LIKE 'history.%' ORDER BY id DESC LIMIT ?",t).reverse().map(n=>JSON.parse(n.data))}}});var pr,Ji=S(()=>{"use strict";ce();cr();oe();dr();pr=class r extends Ns{static{l(this,"PatternStore")}static MAX_CONTEXTS=20;static ARCHIVE_AGE_DAYS=90;getFilename(){return"patterns.json"}getDefault(){return{version:1,decisions:{},preferences:{},workflows:{},counters:{}}}afterLoad(e){for(let t of Object.values(e.decisions))Array.isArray(t.contexts)||(t.contexts=[]),t.contexts.length>r.MAX_CONTEXTS&&(t.contexts=t.contexts.slice(-r.MAX_CONTEXTS))}async loadPatterns(e){return this.load(e)}async savePatterns(e){return this.save(e)}async recordDecision(e,t,s,n="",o={}){let i=await this.load(e),a=v();if(!i.decisions[t])i.decisions[t]={value:s,count:1,firstSeen:a,lastSeen:a,confidence:o.userConfirmed?"high":"low",contexts:[n].filter(Boolean),userConfirmed:o.userConfirmed||!1};else{let c=i.decisions[t];c.value===s?(c.count++,c.lastSeen=a,n&&!c.contexts.includes(n)&&(c.contexts.push(n),c.contexts.length>r.MAX_CONTEXTS&&(c.contexts=c.contexts.slice(-r.MAX_CONTEXTS))),o.userConfirmed&&(c.userConfirmed=!0),c.confidence=Xr(c.count,c.userConfirmed)):(c.value=s,c.count=1,c.lastSeen=a,c.userConfirmed=o.userConfirmed||!1,c.confidence=o.userConfirmed?"high":"low")}await this.save(e)}async confirmDecision(e,t){let n=(await this.load(e)).decisions[t];return n?(n.userConfirmed=!0,n.confidence="high",n.lastSeen=v(),await this.save(e),!0):!1}async getDecision(e,t){let n=(await this.load(e)).decisions[t];return!n||n.confidence==="low"?null:{value:n.value,confidence:n.confidence}}async hasPattern(e,t){return await this.getDecision(e,t)!==null}async recordWorkflow(e,t,s){let n=await this.load(e),o=v();if(!n.workflows[t])n.workflows[t]={...s,count:1,firstSeen:o,lastSeen:o,confidence:"low",userConfirmed:!1};else{let i=n.workflows[t];i.count++,i.lastSeen=o,i.confidence=Xr(i.count,i.userConfirmed)}await this.save(e)}async confirmWorkflow(e,t){let n=(await this.load(e)).workflows[t];return n?(n.userConfirmed=!0,n.confidence="high",n.lastSeen=v(),await this.save(e),!0):!1}async getWorkflow(e,t){let n=(await this.load(e)).workflows[t];return!n||n.count<3?null:n}async setPreference(e,t,s,n={}){let o=await this.load(e),i=o.preferences[t],a=i?i.observationCount+1:1,c=n.userConfirmed||i?.userConfirmed||!1;o.preferences[t]={value:s,updatedAt:v(),confidence:Xr(a,c),observationCount:a,userConfirmed:c},await this.save(e)}async confirmPreference(e,t){let n=(await this.load(e)).preferences[t];return n?(n.userConfirmed=!0,n.confidence="high",n.updatedAt=v(),await this.save(e),!0):!1}async getPreference(e,t,s=null){return(await this.load(e)).preferences[t]?.value??s}async getPatternsSummary(e){let t=await this.load(e);return{decisions:Object.keys(t.decisions).length,learnedDecisions:Object.values(t.decisions).filter(s=>s.confidence!=="low").length,workflows:Object.keys(t.workflows).length,preferences:Object.keys(t.preferences).length}}async archiveStaleDecisions(e){let t=await this.load(e),s=Date.now(),n=r.ARCHIVE_AGE_DAYS*24*60*60*1e3,o=[];for(let[a,c]of Object.entries(t.decisions)){let u=new Date(c.lastSeen).getTime();s-u>n&&o.push(a)}if(o.length===0)return 0;let i=F.getDoc(e,"memory:patterns-archive")??{};for(let a of o)i[a]=t.decisions[a],delete t.decisions[a];return F.setDoc(e,"memory:patterns-archive",i),await this.save(e),o.length}}});import Ah from"node:crypto";import{homedir as Dh}from"node:os";import{join as jh}from"node:path";function ye(){return Ah.randomUUID()}var FC,It=S(()=>{"use strict";l(ye,"generateUUID");FC=jh(Dh(),".prjct-cli","projects")});var Ls,zi=S(()=>{"use strict";It();cr();oe();dr();Ls=class extends Ns{static{l(this,"SemanticMemories")}getFilename(){return"memories.json"}getDefault(){return{version:1,memories:[],index:this._createEmptyIndex()}}afterLoad(e){this._normalizeIndex(e)}_createEmptyIndex(){let e=Object.values(H),t={};for(let s of e)t[s]=[];return t}_normalizeIndex(e){let t=Object.values(H);for(let s of t)e.index[s]||(e.index[s]=[])}_coerceTags(e){let t=new Set(Object.values(H));return e.filter(s=>t.has(s))}async loadMemories(e){return this.load(e)}async saveMemories(e){return this.save(e)}async createMemory(e,{title:t,content:s,tags:n=[],userTriggered:o=!1}){let i=await this.load(e),a=this._coerceTags(n),c=v(),u={id:ye(),title:t,content:s,tags:a,userTriggered:o,createdAt:c,updatedAt:c};i.memories.push(u);for(let p of a)i.index[p].push(u.id);return await this.save(e),u.id}async updateMemory(e,t,s){let n=await this.load(e),o=n.memories.findIndex(c=>c.id===t);if(o===-1)return!1;let i=n.memories[o],a=i.tags||[];if(s.title&&(i.title=s.title),s.content&&(i.content=s.content),s.tags){let c=this._coerceTags(s.tags);for(let u of a)n.index[u]=n.index[u].filter(p=>p!==t);for(let u of c)n.index[u].push(t);i.tags=c}return i.updatedAt=v(),await this.save(e),!0}async deleteMemory(e,t){let s=await this.load(e),n=s.memories.findIndex(i=>i.id===t);if(n===-1)return!1;let o=s.memories[n];for(let i of o.tags||[])s.index[i]&&(s.index[i]=s.index[i].filter(a=>a!==t));return s.memories.splice(n,1),await this.save(e),!0}async findByTags(e,t,s=!1){let n=await this.load(e),o=this._coerceTags(t);if(s)return n.memories.filter(i=>o.every(a=>(i.tags||[]).includes(a)));{let i=new Set;for(let a of o){let c=n.index[a];for(let u of c)i.add(u)}return n.memories.filter(a=>i.has(a.id))}}async searchMemories(e,t){let s=await this.load(e),n=t.toLowerCase();return s.memories.filter(o=>o.title.toLowerCase().includes(n)||o.content.toLowerCase().includes(n))}async getRelevantMemories(e,t,s=5){return(await this.load(e)).memories.map(i=>{let a=0,c=this._extractContextTags(t);for(let d of i.tags||[])c.includes(d)&&(a+=10);let p=(Date.now()-new Date(i.updatedAt).getTime())/(1e3*60*60*24);a+=Math.max(0,5-p),i.userTriggered&&(a+=5);let m=this._extractKeywords(t);for(let d of m)i.content.toLowerCase().includes(d)&&(a+=2),i.title.toLowerCase().includes(d)&&(a+=3);return{...i,_score:a}}).filter(i=>i._score>0).sort((i,a)=>a._score-i._score).slice(0,s).map(({_score:i,...a})=>a)}async getRelevantMemoriesWithMetrics(e,t){let s=await this.load(e),n=s.memories.length;if(n===0)return{memories:[],metrics:{totalMemories:0,memoriesConsidered:0,memoriesReturned:0,filteringRatio:0,avgRelevanceScore:0}};let o=t.maxResults??10,i=t.minRelevance??10,c=s.memories.map(d=>{let g={domainMatch:0,tagMatch:0,recency:0,confidence:0,keywords:0,userTriggered:0};if(t.taskDomain&&(g.domainMatch=this._getSemanticDomainScore(t.taskDomain,d.tags||[])),t.commandName){let T=this._getCommandTags(t.commandName),E=(d.tags||[]).filter(M=>T.includes(M));g.tagMatch=Math.min(20,E.length*8)}let k=(Date.now()-new Date(d.updatedAt).getTime())/(1e3*60*60*24);if(g.recency=Math.max(0,Math.round(15-k*.5)),d.confidence?g.confidence=d.confidence==="high"?20:d.confidence==="medium"?12:5:d.observationCount&&(g.confidence=Math.min(20,d.observationCount*3)),t.taskDescription){let T=this._extractKeywordsFromText(t.taskDescription),E=0;for(let M of T)d.content.toLowerCase().includes(M)&&(E+=2),d.title.toLowerCase().includes(M)&&(E+=3);g.keywords=Math.min(15,E)}d.userTriggered&&(g.userTriggered=5);let w=g.domainMatch+g.tagMatch+g.recency+g.confidence+g.keywords+g.userTriggered;return{...d,relevanceScore:w,scoreBreakdown:g}}).filter(d=>d.relevanceScore>=i),p=c.sort((d,g)=>g.relevanceScore-d.relevanceScore).slice(0,o),m=p.length>0?Math.round(p.reduce((d,g)=>d+g.relevanceScore,0)/p.length):0;return{memories:p,metrics:{totalMemories:n,memoriesConsidered:c.length,memoriesReturned:p.length,filteringRatio:n>0?p.length/n:0,avgRelevanceScore:m}}}_getSemanticDomainScore(e,t){return 0}_getCommandTags(e){return{ship:[H.COMMIT_STYLE,H.SHIP_WORKFLOW,H.TEST_BEHAVIOR],feature:[H.ARCHITECTURE,H.CODE_STYLE],done:[H.SHIP_WORKFLOW],analyze:[H.TECH_STACK,H.ARCHITECTURE],spec:[H.ARCHITECTURE,H.CODE_STYLE],task:[H.BRANCH_NAMING,H.CODE_STYLE],sync:[H.TECH_STACK,H.ARCHITECTURE,H.DEPENDENCIES],test:[H.TEST_BEHAVIOR],bug:[H.CODE_STYLE,H.TEST_BEHAVIOR]}[e]||[]}_extractKeywordsFromText(e){let t=e.toLowerCase().split(/\s+/),s=new Set(["the","a","an","is","are","to","for","and","or","in","on","at","by","with","from","as","it","this","that","be","have","has"]);return t.filter(n=>n.length>2&&!s.has(n))}_extractContextTags(e){let t=[],s={ship:[H.COMMIT_STYLE,H.SHIP_WORKFLOW,H.TEST_BEHAVIOR],feature:[H.ARCHITECTURE,H.CODE_STYLE],done:[H.SHIP_WORKFLOW],analyze:[H.TECH_STACK,H.ARCHITECTURE],spec:[H.ARCHITECTURE,H.CODE_STYLE]};return e.commandName&&s[e.commandName]&&t.push(...s[e.commandName]),t}_extractKeywords(e){let t=[];e.params?.description&&t.push(...e.params.description.toLowerCase().split(/\s+/)),e.params?.feature&&t.push(...e.params.feature.toLowerCase().split(/\s+/));let s=["the","a","an","is","are","to","for","and","or","in"];return t.filter(n=>n.length>2&&!s.includes(n))}async autoRemember(e,t,s,n=""){let i={commit_footer:[H.COMMIT_STYLE],branch_naming:[H.BRANCH_NAMING],test_before_ship:[H.TEST_BEHAVIOR,H.SHIP_WORKFLOW],preferred_agent:[H.AGENT_PREFERENCE],code_style:[H.CODE_STYLE],verbosity:[H.OUTPUT_VERBOSITY]}[t]||[],a=await this.searchMemories(e,t);a.length>0?await this.updateMemory(e,a[0].id,{content:`${t}: ${s}`,tags:i}):await this.createMemory(e,{title:`Preference: ${t}`,content:`${t}: ${s}${n?`
353
- Context: ${n}`:""}`,tags:i,userTriggered:!0})}async getAllMemories(e){return(await this.load(e)).memories}async getMemoryStats(e){let t=await this.load(e),s={};for(let[n,o]of Object.entries(t.index))s[n]=o.length;return{totalMemories:t.memories.length,userTriggered:t.memories.filter(n=>n.userTriggered).length,tagCounts:s,oldestMemory:t.memories[0]?.createdAt,newestMemory:t.memories[t.memories.length-1]?.createdAt}}}});var qi,Ih,at,mr=S(()=>{"use strict";dr();Ji();zi();dr();Ji();zi();qi=class{static{l(this,"MemorySystem")}_semanticMemories;_patternStore;_historyStore;_sessionStore;constructor(){this._semanticMemories=new Ls,this._patternStore=new pr,this._historyStore=new ur,this._sessionStore=new lr}loadMemories(e){return this._semanticMemories.loadMemories(e)}saveMemories(e){return this._semanticMemories.saveMemories(e)}createMemory(e,t){return this._semanticMemories.createMemory(e,t)}updateMemory(e,t,s){return this._semanticMemories.updateMemory(e,t,s)}deleteMemory(e,t){return this._semanticMemories.deleteMemory(e,t)}findByTags(e,t,s){return this._semanticMemories.findByTags(e,t,s)}searchMemories(e,t){return this._semanticMemories.searchMemories(e,t)}getRelevantMemories(e,t,s){return this._semanticMemories.getRelevantMemories(e,t,s)}autoRemember(e,t,s,n){return this._semanticMemories.autoRemember(e,t,s,n)}getAllMemories(e){return this._semanticMemories.getAllMemories(e)}getMemoryStats(e){return this._semanticMemories.getMemoryStats(e)}getRelevantMemoriesWithMetrics(e,t){return this._semanticMemories.getRelevantMemoriesWithMetrics(e,t)}setSession(e,t){this._sessionStore.setSession(e,t)}getSession(e){return this._sessionStore.getSession(e)}clearSession(){this._sessionStore.clearSession()}loadPatterns(e){return this._patternStore.loadPatterns(e)}savePatterns(e){return this._patternStore.savePatterns(e)}recordDecision(e,t,s,n){return this._patternStore.recordDecision(e,t,s,n)}getDecision(e,t){return this._patternStore.getDecision(e,t)}hasPattern(e,t){return this._patternStore.hasPattern(e,t)}recordWorkflow(e,t,s){return this._patternStore.recordWorkflow(e,t,s)}getWorkflow(e,t){return this._patternStore.getWorkflow(e,t)}setPreference(e,t,s,n){return this._patternStore.setPreference(e,t,s,n)}getPreference(e,t,s){return this._patternStore.getPreference(e,t,s)}confirmPreference(e,t){return this._patternStore.confirmPreference(e,t)}confirmDecision(e,t){return this._patternStore.confirmDecision(e,t)}confirmWorkflow(e,t){return this._patternStore.confirmWorkflow(e,t)}getPatternsSummary(e){return this._patternStore.getPatternsSummary(e)}archiveStaleDecisions(e){return this._patternStore.archiveStaleDecisions(e)}appendHistory(e,t){return this._historyStore.appendHistory(e,t)}getRecentHistory(e,t){return this._historyStore.getRecentHistory(e,t)}async getSmartDecision(e,t){let s=this.getSession(`decision:${t}`);if(s!==void 0)return s;let n=await this.getDecision(e,t);return n?n.value:null}async learnDecision(e,t,s,n=""){this.setSession(`decision:${t}`,s),await this.recordDecision(e,t,s,n),await this.appendHistory(e,{type:"decision",key:t,value:s,context:n})}resetState(){this._sessionStore.clearSession(),this._semanticMemories.reset(),this._patternStore.reset()}},Ih=new qi,at=Ih});import $t from"node:fs/promises";import _t from"node:path";var Ki,$h,Je,vu=S(()=>{"use strict";V();Ue();q();Ki=class{static{l(this,"CodebaseAnalyzer")}projectPath=null;init(e=process.cwd()){this.projectPath=e}async readPackageJson(){try{let e=_t.join(this.projectPath,"package.json"),t=await $t.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(R(e)||e instanceof SyntaxError)return null;throw e}}async readCargoToml(){try{let e=_t.join(this.projectPath,"Cargo.toml");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readRequirements(){try{let e=_t.join(this.projectPath,"requirements.txt");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readGoMod(){try{let e=_t.join(this.projectPath,"go.mod");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readGemfile(){try{let e=_t.join(this.projectPath,"Gemfile");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readMixExs(){try{let e=_t.join(this.projectPath,"mix.exs");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readPomXml(){try{let e=_t.join(this.projectPath,"pom.xml");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readComposerJson(){try{let e=_t.join(this.projectPath,"composer.json"),t=await $t.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(R(e)||e instanceof SyntaxError)return null;throw e}}async readPyprojectToml(){try{let e=_t.join(this.projectPath,"pyproject.toml");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async getFileExtensions(){try{let{stdout:e}=await N('find . -type f ! -path "*/node_modules/*" ! -path "*/.git/*" ! -path "*/dist/*" ! -path "*/.next/*" | sed "s/.*\\./\\./" | sort | uniq -c | sort -rn',{cwd:this.projectPath}),t={};return e.trim().split(`
354
- `).filter(Boolean).forEach(s=>{let n=s.trim().match(/^\s*(\d+)\s+(\.\w+)$/);n&&(t[n[2]]=parseInt(n[1],10))}),t}catch{return{}}}async listConfigFiles(){try{let e=await $t.readdir(this.projectPath),t=[/^package\.json$/,/^Cargo\.toml$/,/^go\.mod$/,/^requirements\.txt$/,/^Gemfile$/,/^mix\.exs$/,/^pom\.xml$/,/^composer\.json$/,/^pyproject\.toml$/,/^tsconfig.*\.json$/,/^\..*rc(\.json|\.js|\.cjs)?$/,/^Dockerfile$/,/^docker-compose.*\.ya?ml$/,/^\.env.*$/];return e.filter(s=>t.some(n=>n.test(s)))}catch(e){if(R(e))return[];throw e}}async listDirectories(){try{return(await $t.readdir(this.projectPath,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name).filter(t=>!t.startsWith(".")&&t!=="node_modules")}catch(e){if(R(e))return[];throw e}}async getGitLog(e=50){try{let{stdout:t}=await N(`git log -n ${e} --pretty=format:"%h|%an|%ar|%s"`,{cwd:this.projectPath});return t}catch{return""}}async getGitStats(){try{let{stdout:e}=await N("git rev-list --count HEAD",{cwd:this.projectPath}),{stdout:t}=await N('git log --format="%an" | sort -u | wc -l',{cwd:this.projectPath}),{stdout:s}=await N('git log --reverse --pretty=format:"%ar" | head -1',{cwd:this.projectPath});return{totalCommits:parseInt(e.trim(),10)||0,contributors:parseInt(t.trim(),10)||0,age:s.trim()||"unknown"}}catch{return{totalCommits:0,contributors:0,age:"unknown"}}}async countFiles(){try{let{stdout:e}=await N('find . -type f ! -path "*/node_modules/*" ! -path "*/.git/*" ! -path "*/dist/*" | wc -l',{cwd:this.projectPath});return parseInt(e.trim(),10)||0}catch{return 0}}async fileExists(e){return C(_t.join(this.projectPath,e))}async readFile(e){try{let t=_t.join(this.projectPath,e);return await $t.readFile(t,"utf-8")}catch(t){if(R(t))return null;throw t}}async findFiles(e){try{let{stdout:t}=await N(`find . -type f -name "${e}" ! -path "*/node_modules/*" ! -path "*/.git/*"`,{cwd:this.projectPath});return t.trim().split(`
355
- `).filter(Boolean)}catch{return[]}}},$h=new Ki,Je=$h});import{z as Te}from"zod";function Mh(r){return r instanceof dn}function ue(r){return Mh(r)||r instanceof Error?r.message:typeof r=="string"?r:"Unknown error"}var pn,dP,pP,mP,gP,fP,hP,dn,Yr,Qr,gr,ss=S(()=>{"use strict";pn={create(r,e){class t extends Error{static{l(this,"TypedError")}errorName;data;isOperational=!0;constructor(n){let o=e.parse(n);super(`${r}: ${JSON.stringify(o)}`),this.name=r,this.errorName=r,this.data=o,Error.captureStackTrace?.(this,this.constructor)}static throw(n){throw new t(n)}static is(n){return n instanceof t&&n.errorName===r}static create(n){return new t(n)}}return t}},dP=pn.create("FileError",Te.object({path:Te.string(),operation:Te.enum(["read","write","delete","create","copy"]),reason:Te.string().optional()})),pP=pn.create("ValidationError",Te.object({field:Te.string(),expected:Te.string(),received:Te.string().optional(),message:Te.string().optional()})),mP=pn.create("PermissionError",Te.object({action:Te.string(),resource:Te.string(),reason:Te.string().optional()})),gP=pn.create("TaskError",Te.object({taskId:Te.string().optional(),operation:Te.enum(["create","update","complete","pause","resume","delete"]),reason:Te.string()})),fP=pn.create("SessionError",Te.object({sessionId:Te.string().optional(),reason:Te.string()})),hP=pn.create("SyncError",Te.object({projectId:Te.string().optional(),operation:Te.enum(["push","pull","auth","connect"]),reason:Te.string()})),dn=class extends Error{static{l(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)}},Yr=class r extends dn{static{l(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new r("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new r(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new r(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},Qr=class r extends dn{static{l(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new r(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new r(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},gr=class r extends dn{static{l(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new r(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new r(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};l(Mh,"isPrjctError");l(ue,"getErrorMessage")});var Zi={};Bt(Zi,{PACKAGE_ROOT:()=>Qe,VERSION:()=>Ae,compareVersions:()=>Tu,getPackageInfo:()=>Oh,getPackageRoot:()=>Qi,getVersion:()=>Fs,isCompatible:()=>_h,needsMigration:()=>Nh});import Xi from"node:fs";import eo from"node:path";function Qi(){if(fr)return fr;let r=__dirname;for(let e=0;e<5;e++){let t=eo.join(r,"package.json");if(Xi.existsSync(t))try{if(JSON.parse(Xi.readFileSync(t,"utf-8")).name==="prjct-cli")return fr=r,r}catch{}r=eo.dirname(r)}return fr=eo.join(__dirname,"..","..",".."),fr}function Fs(){if(Zr)return Zr;try{let r=eo.join(Qi(),"package.json"),e=JSON.parse(Xi.readFileSync(r,"utf-8"));return Zr=e.version,Yi=e,Zr}catch(r){return console.error("Failed to read version from package.json:",y(r)),"0.0.0"}}function Oh(){return Yi||Fs(),Yi}function Tu(r,e){let t=r.split(".").map(Number),s=e.split(".").map(Number);for(let n=0;n<Math.max(t.length,s.length);n++){let o=t[n]||0,i=s[n]||0;if(o>i)return 1;if(o<i)return-1}return 0}function _h(r){let e=Fs(),[t,s]=e.split(".").map(Number),[n,o]=r.split(".").map(Number);return t===n&&s===o}function Nh(r,e=null){let t=e||Fs();return Tu(r,t)<0}var Zr,Yi,fr,Ae,Qe,Ct=S(()=>{"use strict";V();Zr=null,Yi=null,fr=null;l(Qi,"getPackageRoot");l(Fs,"getVersion");l(Oh,"getPackageInfo");l(Tu,"compareVersions");l(_h,"isCompatible");l(Nh,"needsMigration");Ae=Fs(),Qe=Qi()});import ta from"node:fs";import Lh from"node:fs/promises";import to from"node:path";function sa(){if(Cu)return ea;Cu=!0;let r=to.join(Qe,"dist","templates.json");try{let e=ta.readFileSync(r,"utf-8");return ea=JSON.parse(e),ea}catch{return null}}function Uh(r){let e=Us.indexOf(r);e>-1&&Us.splice(e,1),Us.push(r)}function Hh(){for(;mn.size>=Fh&&Us.length>0;){let r=Us.shift();r&&mn.delete(r)}}function Pu(r){let e=/^---\n([\s\S]+?)\n---\n([\s\S]*)$/,t=r.match(e);if(!t)return{frontmatter:{},content:r.trim()};let[,s,n]=t,o={};return s.split(`
356
- `).forEach(i=>{let[a,...c]=i.split(":");if(a&&c.length>0){let u=c.join(":").trim();u.startsWith("[")&&u.endsWith("]")?o[a.trim()]=u.slice(1,-1).split(",").map(p=>p.trim()):o[a.trim()]=u.replace(/^["']|["']$/g,"")}}),{frontmatter:o,content:n.trim()}}async function Eu(r){if(mn.has(r))return Uh(r),mn.get(r);let e,t=sa();if(t){let n=`commands/${r}.md`;e=t[n]}if(!e){let n=to.join(Qe,"templates","commands",`${r}.md`);try{e=await Lh.readFile(n,"utf-8")}catch{throw Qr.notFound(r)}}let s=Pu(e);return Hh(),mn.set(r,s),Us.push(r),s}async function Gh(r){return(await Eu(r)).frontmatter["allowed-tools"]||[]}function Vh(){mn.clear(),Us.length=0}function yt(r){let e=sa();if(e?.[r])return e[r];let t=to.join(Qe,"templates",r);try{return ta.readFileSync(t,"utf-8")}catch{return null}}function gn(r){let e=sa();if(e)return Object.keys(e).filter(s=>s.startsWith(r));let t=to.join(Qe,"templates",r);try{return ta.readdirSync(t).map(n=>`${r}${n}`)}catch{return[]}}var Fh,mn,Us,ea,Cu,Wh,na,Hs=S(()=>{"use strict";ss();Ct();Fh=50,mn=new Map,Us=[],ea=null,Cu=!1;l(sa,"loadBundle");l(Uh,"updateLruOrder");l(Hh,"evictLru");l(Pu,"parseFrontmatter");l(Eu,"load");l(Gh,"getAllowedTools");l(Vh,"clearCache");l(yt,"getTemplateContent");l(gn,"listTemplates");Wh={load:Eu,parseFrontmatter:Pu,getAllowedTools:Gh,clearCache:Vh,getTemplateContent:yt,listTemplates:gn},na=Wh});function Jh(){let r=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!r)return{level:-1,name:"disabled"};if(Bh.has(r)||r.includes("prjct"))return{level:fn.debug,name:"debug"};let e=fn[r]??-1,t=e>=0?r:"disabled";return{level:e,name:t}}function so(r,e,t){return xu>=r?(...s)=>console[t](e,...s):qh}var fn,Bh,xu,zh,qh,Kh,W,ns=S(()=>{"use strict";fn={error:0,warn:1,info:2,debug:3},Bh=new Set(["1","true","*"]);l(Jh,"getLogLevel");({level:xu,name:zh}=Jh()),qh=l(()=>{},"noop");l(so,"createLogMethod");Kh={error:so(fn.error,"[prjct:error]","error"),warn:so(fn.warn,"[prjct:warn]","warn"),info:so(fn.info,"[prjct:info]","log"),debug:so(fn.debug,"[prjct:debug]","log"),isEnabled:l(()=>xu>=0,"isEnabled"),level:l(()=>zh,"level")},W=Kh});function no(r,e,t,s){if(!r)return{content:e,action:"created"};if(!(r.includes(t)&&r.includes(s)))return{content:`${r}
382
+ `);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(s=>s.version));for(let s of jh)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 Qr,N=C});function eo(r,e=!1){return e||r>=6?"high":r>=3?"medium":"low"}var H,cr=S(()=>{"use strict";H={CODE_STYLE:"code_style",NAMING_CONVENTION:"naming_convention",FILE_STRUCTURE:"file_structure",COMMIT_STYLE:"commit_style",BRANCH_NAMING:"branch_naming",TEST_BEHAVIOR:"test_behavior",SHIP_WORKFLOW:"ship_workflow",TECH_STACK:"tech_stack",ARCHITECTURE:"architecture",DEPENDENCIES:"dependencies",OUTPUT_VERBOSITY:"output_verbosity",CONFIRMATION_LEVEL:"confirmation_level",AGENT_PREFERENCE:"agent_preference"};l(eo,"calculateConfidence")});var Ns,lr,ur,dr=S(()=>{"use strict";re();cr();ie();Ns=class{static{l(this,"CachedStore")}_data=null;_loaded=!1;_projectId=null;getSubdirectory(){return null}getStoreKey(){let e=this.getFilename().replace(".json",""),t=this.getSubdirectory();return t?`memory:${t}:${e}`:`memory:${e}`}async load(e){if(this._loaded&&this._data&&this._projectId===e)return this._data;let t=this.getStoreKey(),s=N.getDoc(e,t);return s!==null?(this._data=s,this.afterLoad(this._data)):this._data=this.getDefault(),this._loaded=!0,this._projectId=e,this._data}afterLoad(e){}async save(e){if(!this._data)return;let t=this.getStoreKey();N.setDoc(e,t,this._data)}getData(){return this._data}setData(e){this._data=e}async update(e,t){let s=await this.load(e),n=t(s);return this._data=n,await this.save(e),n}isLoaded(e){return e?this._loaded&&this._projectId===e:this._loaded}reset(){this._data=null,this._loaded=!1,this._projectId=null}},lr=class{static{l(this,"SessionStore")}_sessionMemory=new Map;setSession(e,t){this._sessionMemory.set(e,{value:t,timestamp:Date.now()})}getSession(e){return this._sessionMemory.get(e)?.value}clearSession(){this._sessionMemory.clear()}},ur=class{static{l(this,"HistoryStore")}async appendHistory(e,t){let s={ts:T(),...t,type:t.type};N.appendEvent(e,`history.${t.type}`,s)}async getRecentHistory(e,t=20){return N.query(e,"SELECT data, timestamp FROM events WHERE type LIKE 'history.%' ORDER BY id DESC LIMIT ?",t).reverse().map(n=>JSON.parse(n.data))}}});var pr,qi=S(()=>{"use strict";re();cr();ie();dr();pr=class r extends Ns{static{l(this,"PatternStore")}static MAX_CONTEXTS=20;static ARCHIVE_AGE_DAYS=90;getFilename(){return"patterns.json"}getDefault(){return{version:1,decisions:{},preferences:{},workflows:{},counters:{}}}afterLoad(e){for(let t of Object.values(e.decisions))Array.isArray(t.contexts)||(t.contexts=[]),t.contexts.length>r.MAX_CONTEXTS&&(t.contexts=t.contexts.slice(-r.MAX_CONTEXTS))}async loadPatterns(e){return this.load(e)}async savePatterns(e){return this.save(e)}async recordDecision(e,t,s,n="",o={}){let i=await this.load(e),a=T();if(!i.decisions[t])i.decisions[t]={value:s,count:1,firstSeen:a,lastSeen:a,confidence:o.userConfirmed?"high":"low",contexts:[n].filter(Boolean),userConfirmed:o.userConfirmed||!1};else{let c=i.decisions[t];c.value===s?(c.count++,c.lastSeen=a,n&&!c.contexts.includes(n)&&(c.contexts.push(n),c.contexts.length>r.MAX_CONTEXTS&&(c.contexts=c.contexts.slice(-r.MAX_CONTEXTS))),o.userConfirmed&&(c.userConfirmed=!0),c.confidence=eo(c.count,c.userConfirmed)):(c.value=s,c.count=1,c.lastSeen=a,c.userConfirmed=o.userConfirmed||!1,c.confidence=o.userConfirmed?"high":"low")}await this.save(e)}async confirmDecision(e,t){let n=(await this.load(e)).decisions[t];return n?(n.userConfirmed=!0,n.confidence="high",n.lastSeen=T(),await this.save(e),!0):!1}async getDecision(e,t){let n=(await this.load(e)).decisions[t];return!n||n.confidence==="low"?null:{value:n.value,confidence:n.confidence}}async hasPattern(e,t){return await this.getDecision(e,t)!==null}async recordWorkflow(e,t,s){let n=await this.load(e),o=T();if(!n.workflows[t])n.workflows[t]={...s,count:1,firstSeen:o,lastSeen:o,confidence:"low",userConfirmed:!1};else{let i=n.workflows[t];i.count++,i.lastSeen=o,i.confidence=eo(i.count,i.userConfirmed)}await this.save(e)}async confirmWorkflow(e,t){let n=(await this.load(e)).workflows[t];return n?(n.userConfirmed=!0,n.confidence="high",n.lastSeen=T(),await this.save(e),!0):!1}async getWorkflow(e,t){let n=(await this.load(e)).workflows[t];return!n||n.count<3?null:n}async setPreference(e,t,s,n={}){let o=await this.load(e),i=o.preferences[t],a=i?i.observationCount+1:1,c=n.userConfirmed||i?.userConfirmed||!1;o.preferences[t]={value:s,updatedAt:T(),confidence:eo(a,c),observationCount:a,userConfirmed:c},await this.save(e)}async confirmPreference(e,t){let n=(await this.load(e)).preferences[t];return n?(n.userConfirmed=!0,n.confidence="high",n.updatedAt=T(),await this.save(e),!0):!1}async getPreference(e,t,s=null){return(await this.load(e)).preferences[t]?.value??s}async getPatternsSummary(e){let t=await this.load(e);return{decisions:Object.keys(t.decisions).length,learnedDecisions:Object.values(t.decisions).filter(s=>s.confidence!=="low").length,workflows:Object.keys(t.workflows).length,preferences:Object.keys(t.preferences).length}}async archiveStaleDecisions(e){let t=await this.load(e),s=Date.now(),n=r.ARCHIVE_AGE_DAYS*24*60*60*1e3,o=[];for(let[a,c]of Object.entries(t.decisions)){let u=new Date(c.lastSeen).getTime();s-u>n&&o.push(a)}if(o.length===0)return 0;let i=N.getDoc(e,"memory:patterns-archive")??{};for(let a of o)i[a]=t.decisions[a],delete t.decisions[a];return N.setDoc(e,"memory:patterns-archive",i),await this.save(e),o.length}}});import $h from"node:crypto";import{homedir as Mh}from"node:os";import{join as _h}from"node:path";function ye(){return $h.randomUUID()}var GC,It=S(()=>{"use strict";l(ye,"generateUUID");GC=_h(Mh(),".prjct-cli","projects")});var Ls,Ki=S(()=>{"use strict";It();cr();ie();dr();Ls=class extends Ns{static{l(this,"SemanticMemories")}getFilename(){return"memories.json"}getDefault(){return{version:1,memories:[],index:this._createEmptyIndex()}}afterLoad(e){this._normalizeIndex(e)}_createEmptyIndex(){let e=Object.values(H),t={};for(let s of e)t[s]=[];return t}_normalizeIndex(e){let t=Object.values(H);for(let s of t)e.index[s]||(e.index[s]=[])}_coerceTags(e){let t=new Set(Object.values(H));return e.filter(s=>t.has(s))}async loadMemories(e){return this.load(e)}async saveMemories(e){return this.save(e)}async createMemory(e,{title:t,content:s,tags:n=[],userTriggered:o=!1}){let i=await this.load(e),a=this._coerceTags(n),c=T(),u={id:ye(),title:t,content:s,tags:a,userTriggered:o,createdAt:c,updatedAt:c};i.memories.push(u);for(let p of a)i.index[p].push(u.id);return await this.save(e),u.id}async updateMemory(e,t,s){let n=await this.load(e),o=n.memories.findIndex(c=>c.id===t);if(o===-1)return!1;let i=n.memories[o],a=i.tags||[];if(s.title&&(i.title=s.title),s.content&&(i.content=s.content),s.tags){let c=this._coerceTags(s.tags);for(let u of a)n.index[u]=n.index[u].filter(p=>p!==t);for(let u of c)n.index[u].push(t);i.tags=c}return i.updatedAt=T(),await this.save(e),!0}async deleteMemory(e,t){let s=await this.load(e),n=s.memories.findIndex(i=>i.id===t);if(n===-1)return!1;let o=s.memories[n];for(let i of o.tags||[])s.index[i]&&(s.index[i]=s.index[i].filter(a=>a!==t));return s.memories.splice(n,1),await this.save(e),!0}async findByTags(e,t,s=!1){let n=await this.load(e),o=this._coerceTags(t);if(s)return n.memories.filter(i=>o.every(a=>(i.tags||[]).includes(a)));{let i=new Set;for(let a of o){let c=n.index[a];for(let u of c)i.add(u)}return n.memories.filter(a=>i.has(a.id))}}async searchMemories(e,t){let s=await this.load(e),n=t.toLowerCase();return s.memories.filter(o=>o.title.toLowerCase().includes(n)||o.content.toLowerCase().includes(n))}async getRelevantMemories(e,t,s=5){return(await this.load(e)).memories.map(i=>{let a=0,c=this._extractContextTags(t);for(let d of i.tags||[])c.includes(d)&&(a+=10);let p=(Date.now()-new Date(i.updatedAt).getTime())/(1e3*60*60*24);a+=Math.max(0,5-p),i.userTriggered&&(a+=5);let m=this._extractKeywords(t);for(let d of m)i.content.toLowerCase().includes(d)&&(a+=2),i.title.toLowerCase().includes(d)&&(a+=3);return{...i,_score:a}}).filter(i=>i._score>0).sort((i,a)=>a._score-i._score).slice(0,s).map(({_score:i,...a})=>a)}async getRelevantMemoriesWithMetrics(e,t){let s=await this.load(e),n=s.memories.length;if(n===0)return{memories:[],metrics:{totalMemories:0,memoriesConsidered:0,memoriesReturned:0,filteringRatio:0,avgRelevanceScore:0}};let o=t.maxResults??10,i=t.minRelevance??10,c=s.memories.map(d=>{let g={domainMatch:0,tagMatch:0,recency:0,confidence:0,keywords:0,userTriggered:0};if(t.taskDomain&&(g.domainMatch=this._getSemanticDomainScore(t.taskDomain,d.tags||[])),t.commandName){let v=this._getCommandTags(t.commandName),D=(d.tags||[]).filter(U=>v.includes(U));g.tagMatch=Math.min(20,D.length*8)}let k=(Date.now()-new Date(d.updatedAt).getTime())/(1e3*60*60*24);if(g.recency=Math.max(0,Math.round(15-k*.5)),d.confidence?g.confidence=d.confidence==="high"?20:d.confidence==="medium"?12:5:d.observationCount&&(g.confidence=Math.min(20,d.observationCount*3)),t.taskDescription){let v=this._extractKeywordsFromText(t.taskDescription),D=0;for(let U of v)d.content.toLowerCase().includes(U)&&(D+=2),d.title.toLowerCase().includes(U)&&(D+=3);g.keywords=Math.min(15,D)}d.userTriggered&&(g.userTriggered=5);let y=g.domainMatch+g.tagMatch+g.recency+g.confidence+g.keywords+g.userTriggered;return{...d,relevanceScore:y,scoreBreakdown:g}}).filter(d=>d.relevanceScore>=i),p=c.sort((d,g)=>g.relevanceScore-d.relevanceScore).slice(0,o),m=p.length>0?Math.round(p.reduce((d,g)=>d+g.relevanceScore,0)/p.length):0;return{memories:p,metrics:{totalMemories:n,memoriesConsidered:c.length,memoriesReturned:p.length,filteringRatio:n>0?p.length/n:0,avgRelevanceScore:m}}}_getSemanticDomainScore(e,t){return 0}_getCommandTags(e){return{ship:[H.COMMIT_STYLE,H.SHIP_WORKFLOW,H.TEST_BEHAVIOR],feature:[H.ARCHITECTURE,H.CODE_STYLE],done:[H.SHIP_WORKFLOW],analyze:[H.TECH_STACK,H.ARCHITECTURE],spec:[H.ARCHITECTURE,H.CODE_STYLE],task:[H.BRANCH_NAMING,H.CODE_STYLE],sync:[H.TECH_STACK,H.ARCHITECTURE,H.DEPENDENCIES],test:[H.TEST_BEHAVIOR],bug:[H.CODE_STYLE,H.TEST_BEHAVIOR]}[e]||[]}_extractKeywordsFromText(e){let t=e.toLowerCase().split(/\s+/),s=new Set(["the","a","an","is","are","to","for","and","or","in","on","at","by","with","from","as","it","this","that","be","have","has"]);return t.filter(n=>n.length>2&&!s.has(n))}_extractContextTags(e){let t=[],s={ship:[H.COMMIT_STYLE,H.SHIP_WORKFLOW,H.TEST_BEHAVIOR],feature:[H.ARCHITECTURE,H.CODE_STYLE],done:[H.SHIP_WORKFLOW],analyze:[H.TECH_STACK,H.ARCHITECTURE],spec:[H.ARCHITECTURE,H.CODE_STYLE]};return e.commandName&&s[e.commandName]&&t.push(...s[e.commandName]),t}_extractKeywords(e){let t=[];e.params?.description&&t.push(...e.params.description.toLowerCase().split(/\s+/)),e.params?.feature&&t.push(...e.params.feature.toLowerCase().split(/\s+/));let s=["the","a","an","is","are","to","for","and","or","in"];return t.filter(n=>n.length>2&&!s.includes(n))}async autoRemember(e,t,s,n=""){let i={commit_footer:[H.COMMIT_STYLE],branch_naming:[H.BRANCH_NAMING],test_before_ship:[H.TEST_BEHAVIOR,H.SHIP_WORKFLOW],preferred_agent:[H.AGENT_PREFERENCE],code_style:[H.CODE_STYLE],verbosity:[H.OUTPUT_VERBOSITY]}[t]||[],a=await this.searchMemories(e,t);a.length>0?await this.updateMemory(e,a[0].id,{content:`${t}: ${s}`,tags:i}):await this.createMemory(e,{title:`Preference: ${t}`,content:`${t}: ${s}${n?`
383
+ Context: ${n}`:""}`,tags:i,userTriggered:!0})}async getAllMemories(e){return(await this.load(e)).memories}async getMemoryStats(e){let t=await this.load(e),s={};for(let[n,o]of Object.entries(t.index))s[n]=o.length;return{totalMemories:t.memories.length,userTriggered:t.memories.filter(n=>n.userTriggered).length,tagCounts:s,oldestMemory:t.memories[0]?.createdAt,newestMemory:t.memories[t.memories.length-1]?.createdAt}}}});var Xi,Oh,ct,mr=S(()=>{"use strict";dr();qi();Ki();dr();qi();Ki();Xi=class{static{l(this,"MemorySystem")}_semanticMemories;_patternStore;_historyStore;_sessionStore;constructor(){this._semanticMemories=new Ls,this._patternStore=new pr,this._historyStore=new ur,this._sessionStore=new lr}loadMemories(e){return this._semanticMemories.loadMemories(e)}saveMemories(e){return this._semanticMemories.saveMemories(e)}createMemory(e,t){return this._semanticMemories.createMemory(e,t)}updateMemory(e,t,s){return this._semanticMemories.updateMemory(e,t,s)}deleteMemory(e,t){return this._semanticMemories.deleteMemory(e,t)}findByTags(e,t,s){return this._semanticMemories.findByTags(e,t,s)}searchMemories(e,t){return this._semanticMemories.searchMemories(e,t)}getRelevantMemories(e,t,s){return this._semanticMemories.getRelevantMemories(e,t,s)}autoRemember(e,t,s,n){return this._semanticMemories.autoRemember(e,t,s,n)}getAllMemories(e){return this._semanticMemories.getAllMemories(e)}getMemoryStats(e){return this._semanticMemories.getMemoryStats(e)}getRelevantMemoriesWithMetrics(e,t){return this._semanticMemories.getRelevantMemoriesWithMetrics(e,t)}setSession(e,t){this._sessionStore.setSession(e,t)}getSession(e){return this._sessionStore.getSession(e)}clearSession(){this._sessionStore.clearSession()}loadPatterns(e){return this._patternStore.loadPatterns(e)}savePatterns(e){return this._patternStore.savePatterns(e)}recordDecision(e,t,s,n){return this._patternStore.recordDecision(e,t,s,n)}getDecision(e,t){return this._patternStore.getDecision(e,t)}hasPattern(e,t){return this._patternStore.hasPattern(e,t)}recordWorkflow(e,t,s){return this._patternStore.recordWorkflow(e,t,s)}getWorkflow(e,t){return this._patternStore.getWorkflow(e,t)}setPreference(e,t,s,n){return this._patternStore.setPreference(e,t,s,n)}getPreference(e,t,s){return this._patternStore.getPreference(e,t,s)}confirmPreference(e,t){return this._patternStore.confirmPreference(e,t)}confirmDecision(e,t){return this._patternStore.confirmDecision(e,t)}confirmWorkflow(e,t){return this._patternStore.confirmWorkflow(e,t)}getPatternsSummary(e){return this._patternStore.getPatternsSummary(e)}archiveStaleDecisions(e){return this._patternStore.archiveStaleDecisions(e)}appendHistory(e,t){return this._historyStore.appendHistory(e,t)}getRecentHistory(e,t){return this._historyStore.getRecentHistory(e,t)}async getSmartDecision(e,t){let s=this.getSession(`decision:${t}`);if(s!==void 0)return s;let n=await this.getDecision(e,t);return n?n.value:null}async learnDecision(e,t,s,n=""){this.setSession(`decision:${t}`,s),await this.recordDecision(e,t,s,n),await this.appendHistory(e,{type:"decision",key:t,value:s,context:n})}resetState(){this._sessionStore.clearSession(),this._semanticMemories.reset(),this._patternStore.reset()}},Oh=new Xi,ct=Oh});import $t from"node:fs/promises";import Nt from"node:path";var Yi,Nh,Je,Pu=S(()=>{"use strict";W();He();K();Yi=class{static{l(this,"CodebaseAnalyzer")}projectPath=null;init(e=process.cwd()){this.projectPath=e}async readPackageJson(){try{let e=Nt.join(this.projectPath,"package.json"),t=await $t.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(R(e)||e instanceof SyntaxError)return null;throw e}}async readCargoToml(){try{let e=Nt.join(this.projectPath,"Cargo.toml");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readRequirements(){try{let e=Nt.join(this.projectPath,"requirements.txt");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readGoMod(){try{let e=Nt.join(this.projectPath,"go.mod");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readGemfile(){try{let e=Nt.join(this.projectPath,"Gemfile");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readMixExs(){try{let e=Nt.join(this.projectPath,"mix.exs");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readPomXml(){try{let e=Nt.join(this.projectPath,"pom.xml");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async readComposerJson(){try{let e=Nt.join(this.projectPath,"composer.json"),t=await $t.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(R(e)||e instanceof SyntaxError)return null;throw e}}async readPyprojectToml(){try{let e=Nt.join(this.projectPath,"pyproject.toml");return await $t.readFile(e,"utf-8")}catch(e){if(R(e))return null;throw e}}async getFileExtensions(){try{let{stdout:e}=await O('find . -type f ! -path "*/node_modules/*" ! -path "*/.git/*" ! -path "*/dist/*" ! -path "*/.next/*" | sed "s/.*\\./\\./" | sort | uniq -c | sort -rn',{cwd:this.projectPath}),t={};return e.trim().split(`
384
+ `).filter(Boolean).forEach(s=>{let n=s.trim().match(/^\s*(\d+)\s+(\.\w+)$/);n&&(t[n[2]]=parseInt(n[1],10))}),t}catch{return{}}}async listConfigFiles(){try{let e=await $t.readdir(this.projectPath),t=[/^package\.json$/,/^Cargo\.toml$/,/^go\.mod$/,/^requirements\.txt$/,/^Gemfile$/,/^mix\.exs$/,/^pom\.xml$/,/^composer\.json$/,/^pyproject\.toml$/,/^tsconfig.*\.json$/,/^\..*rc(\.json|\.js|\.cjs)?$/,/^Dockerfile$/,/^docker-compose.*\.ya?ml$/,/^\.env.*$/];return e.filter(s=>t.some(n=>n.test(s)))}catch(e){if(R(e))return[];throw e}}async listDirectories(){try{return(await $t.readdir(this.projectPath,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name).filter(t=>!t.startsWith(".")&&t!=="node_modules")}catch(e){if(R(e))return[];throw e}}async getGitLog(e=50){try{let{stdout:t}=await O(`git log -n ${e} --pretty=format:"%h|%an|%ar|%s"`,{cwd:this.projectPath});return t}catch{return""}}async getGitStats(){try{let{stdout:e}=await O("git rev-list --count HEAD",{cwd:this.projectPath}),{stdout:t}=await O('git log --format="%an" | sort -u | wc -l',{cwd:this.projectPath}),{stdout:s}=await O('git log --reverse --pretty=format:"%ar" | head -1',{cwd:this.projectPath});return{totalCommits:parseInt(e.trim(),10)||0,contributors:parseInt(t.trim(),10)||0,age:s.trim()||"unknown"}}catch{return{totalCommits:0,contributors:0,age:"unknown"}}}async countFiles(){try{let{stdout:e}=await O('find . -type f ! -path "*/node_modules/*" ! -path "*/.git/*" ! -path "*/dist/*" | wc -l',{cwd:this.projectPath});return parseInt(e.trim(),10)||0}catch{return 0}}async fileExists(e){return P(Nt.join(this.projectPath,e))}async readFile(e){try{let t=Nt.join(this.projectPath,e);return await $t.readFile(t,"utf-8")}catch(t){if(R(t))return null;throw t}}async findFiles(e){try{let{stdout:t}=await O(`find . -type f -name "${e}" ! -path "*/node_modules/*" ! -path "*/.git/*"`,{cwd:this.projectPath});return t.trim().split(`
385
+ `).filter(Boolean)}catch{return[]}}},Nh=new Yi,Je=Nh});import{z as ve}from"zod";function Lh(r){return r instanceof pn}function ue(r){return Lh(r)||r instanceof Error?r.message:typeof r=="string"?r:"Unknown error"}var mn,gP,fP,hP,yP,wP,kP,pn,to,so,gr,ss=S(()=>{"use strict";mn={create(r,e){class t extends Error{static{l(this,"TypedError")}errorName;data;isOperational=!0;constructor(n){let o=e.parse(n);super(`${r}: ${JSON.stringify(o)}`),this.name=r,this.errorName=r,this.data=o,Error.captureStackTrace?.(this,this.constructor)}static throw(n){throw new t(n)}static is(n){return n instanceof t&&n.errorName===r}static create(n){return new t(n)}}return t}},gP=mn.create("FileError",ve.object({path:ve.string(),operation:ve.enum(["read","write","delete","create","copy"]),reason:ve.string().optional()})),fP=mn.create("ValidationError",ve.object({field:ve.string(),expected:ve.string(),received:ve.string().optional(),message:ve.string().optional()})),hP=mn.create("PermissionError",ve.object({action:ve.string(),resource:ve.string(),reason:ve.string().optional()})),yP=mn.create("TaskError",ve.object({taskId:ve.string().optional(),operation:ve.enum(["create","update","complete","pause","resume","delete"]),reason:ve.string()})),wP=mn.create("SessionError",ve.object({sessionId:ve.string().optional(),reason:ve.string()})),kP=mn.create("SyncError",ve.object({projectId:ve.string().optional(),operation:ve.enum(["push","pull","auth","connect"]),reason:ve.string()})),pn=class extends Error{static{l(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)}},to=class r extends pn{static{l(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new r("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new r(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new r(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},so=class r extends pn{static{l(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new r(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new r(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},gr=class r extends pn{static{l(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new r(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new r(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};l(Lh,"isPrjctError");l(ue,"getErrorMessage")});var ta={};Ot(ta,{PACKAGE_ROOT:()=>Ze,VERSION:()=>Ae,compareVersions:()=>Eu,getPackageInfo:()=>Fh,getPackageRoot:()=>ea,getVersion:()=>Fs,isCompatible:()=>Uh,needsMigration:()=>Hh});import Qi from"node:fs";import ro from"node:path";function ea(){if(fr)return fr;let r=__dirname;for(let e=0;e<5;e++){let t=ro.join(r,"package.json");if(Qi.existsSync(t))try{if(JSON.parse(Qi.readFileSync(t,"utf-8")).name==="prjct-cli")return fr=r,r}catch{}r=ro.dirname(r)}return fr=ro.join(__dirname,"..","..",".."),fr}function Fs(){if(no)return no;try{let r=ro.join(ea(),"package.json"),e=JSON.parse(Qi.readFileSync(r,"utf-8"));return no=e.version,Zi=e,no}catch(r){return console.error("Failed to read version from package.json:",w(r)),"0.0.0"}}function Fh(){return Zi||Fs(),Zi}function Eu(r,e){let t=r.split(".").map(Number),s=e.split(".").map(Number);for(let n=0;n<Math.max(t.length,s.length);n++){let o=t[n]||0,i=s[n]||0;if(o>i)return 1;if(o<i)return-1}return 0}function Uh(r){let e=Fs(),[t,s]=e.split(".").map(Number),[n,o]=r.split(".").map(Number);return t===n&&s===o}function Hh(r,e=null){let t=e||Fs();return Eu(r,t)<0}var no,Zi,fr,Ae,Ze,Ct=S(()=>{"use strict";W();no=null,Zi=null,fr=null;l(ea,"getPackageRoot");l(Fs,"getVersion");l(Fh,"getPackageInfo");l(Eu,"compareVersions");l(Uh,"isCompatible");l(Hh,"needsMigration");Ae=Fs(),Ze=ea()});import na from"node:fs";import Gh from"node:fs/promises";import oo from"node:path";function ra(){if(xu)return sa;xu=!0;let r=oo.join(Ze,"dist","templates.json");try{let e=na.readFileSync(r,"utf-8");return sa=JSON.parse(e),sa}catch{return null}}function Vh(r){let e=Us.indexOf(r);e>-1&&Us.splice(e,1),Us.push(r)}function Bh(){for(;gn.size>=Wh&&Us.length>0;){let r=Us.shift();r&&gn.delete(r)}}function Ru(r){let e=/^---\n([\s\S]+?)\n---\n([\s\S]*)$/,t=r.match(e);if(!t)return{frontmatter:{},content:r.trim()};let[,s,n]=t,o={};return s.split(`
386
+ `).forEach(i=>{let[a,...c]=i.split(":");if(a&&c.length>0){let u=c.join(":").trim();u.startsWith("[")&&u.endsWith("]")?o[a.trim()]=u.slice(1,-1).split(",").map(p=>p.trim()):o[a.trim()]=u.replace(/^["']|["']$/g,"")}}),{frontmatter:o,content:n.trim()}}async function Au(r){if(gn.has(r))return Vh(r),gn.get(r);let e,t=ra();if(t){let n=`commands/${r}.md`;e=t[n]}if(!e){let n=oo.join(Ze,"templates","commands",`${r}.md`);try{e=await Gh.readFile(n,"utf-8")}catch{throw so.notFound(r)}}let s=Ru(e);return Bh(),gn.set(r,s),Us.push(r),s}async function zh(r){return(await Au(r)).frontmatter["allowed-tools"]||[]}function Jh(){gn.clear(),Us.length=0}function wt(r){let e=ra();if(e?.[r])return e[r];let t=oo.join(Ze,"templates",r);try{return na.readFileSync(t,"utf-8")}catch{return null}}function fn(r){let e=ra();if(e)return Object.keys(e).filter(s=>s.startsWith(r));let t=oo.join(Ze,"templates",r);try{return na.readdirSync(t).map(n=>`${r}${n}`)}catch{return[]}}var Wh,gn,Us,sa,xu,qh,oa,Hs=S(()=>{"use strict";ss();Ct();Wh=50,gn=new Map,Us=[],sa=null,xu=!1;l(ra,"loadBundle");l(Vh,"updateLruOrder");l(Bh,"evictLru");l(Ru,"parseFrontmatter");l(Au,"load");l(zh,"getAllowedTools");l(Jh,"clearCache");l(wt,"getTemplateContent");l(fn,"listTemplates");qh={load:Au,parseFrontmatter:Ru,getAllowedTools:zh,clearCache:Jh,getTemplateContent:wt,listTemplates:fn},oa=qh});function Xh(){let r=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!r)return{level:-1,name:"disabled"};if(Kh.has(r)||r.includes("prjct"))return{level:hn.debug,name:"debug"};let e=hn[r]??-1,t=e>=0?r:"disabled";return{level:e,name:t}}function io(r,e,t){return Du>=r?(...s)=>console[t](e,...s):Qh}var hn,Kh,Du,Yh,Qh,Zh,V,ns=S(()=>{"use strict";hn={error:0,warn:1,info:2,debug:3},Kh=new Set(["1","true","*"]);l(Xh,"getLogLevel");({level:Du,name:Yh}=Xh()),Qh=l(()=>{},"noop");l(io,"createLogMethod");Zh={error:io(hn.error,"[prjct:error]","error"),warn:io(hn.warn,"[prjct:warn]","warn"),info:io(hn.info,"[prjct:info]","log"),debug:io(hn.debug,"[prjct:debug]","log"),isEnabled:l(()=>Du>=0,"isEnabled"),level:l(()=>Yh,"level")},V=Zh});function ao(r,e,t,s){if(!r)return{content:e,action:"created"};if(!(r.includes(t)&&r.includes(s)))return{content:`${r}
357
387
 
358
- ${e}`,action:"appended"};let o=r.substring(0,r.indexOf(t)),i=r.substring(r.indexOf(s)+s.length),a;return e.includes(t)&&e.includes(s)?a=e.substring(e.indexOf(t),e.indexOf(s)+s.length):a=e,{content:o+a+i,action:"updated"}}var ra=S(()=>{"use strict";Hs();V();q();ns();Ct();l(no,"mergeWithMarkers")});import Ze from"node:fs/promises";import ro from"node:os";import Se from"node:path";async function Xh(){try{let r=Se.join(ro.homedir(),".prjct-cli","docs");await Ze.mkdir(r,{recursive:!0});let e=gn("global/docs/");if(e.length>0){for(let n of e)if(n.endsWith(".md")){let o=yt(n);if(o){let i=Se.basename(n);await Ze.writeFile(Se.join(r,i),o,"utf-8")}}return{success:!0}}let{PACKAGE_ROOT:t}=(Ct(),bt(Zi)),s=Se.join(t,"templates/global/docs");try{let n=await Ze.readdir(s);for(let o of n)if(o.endsWith(".md")){let i=Se.join(s,o),a=Se.join(r,o),c=await Ze.readFile(i,"utf-8");await Ze.writeFile(a,c,"utf-8")}}catch{}return{success:!0}}catch(r){return{success:!1,error:y(r)}}}async function Yh(){let r=(it(),bt(Tt)),e=await r.getActiveProvider(),t=e.name;if(!(await r.detectProvider(t)).installed&&!e.configDir)return{success:!1,error:`${e.displayName} not detected`,action:"skipped"};try{await Ze.mkdir(e.configDir,{recursive:!0});let n=Se.join(e.configDir,e.contextFile),o=Ru;if(t!=="claude"){let g=yt(`global/${e.contextFile}`);if(g)o=g;else{let{PACKAGE_ROOT:h}=(Ct(),bt(Zi)),k=Se.join(h,"templates","global",e.contextFile);try{o=await Ze.readFile(k,"utf-8")}catch{t==="gemini"&&(o=Ru.replace(/Claude/g,"Gemini"))}}}let i="",a=!1;try{i=await Ze.readFile(n,"utf-8"),a=!0}catch(g){if(R(g))a=!1;else throw g}let c="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",u="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->";if(i.includes(c)&&i.includes(u)){let g=i.substring(0,i.indexOf(c)),h=i.substring(i.indexOf(u)+u.length);i=`${(g+h).replace(/\n{3,}/g,`
388
+ ${e}`,action:"appended"};let o=r.substring(0,r.indexOf(t)),i=r.substring(r.indexOf(s)+s.length),a;return e.includes(t)&&e.includes(s)?a=e.substring(e.indexOf(t),e.indexOf(s)+s.length):a=e,{content:o+a+i,action:"updated"}}var ia=S(()=>{"use strict";Hs();W();K();ns();Ct();l(ao,"mergeWithMarkers")});import et from"node:fs/promises";import co from"node:os";import Se from"node:path";async function ey(){try{let r=Se.join(co.homedir(),".prjct-cli","docs");await et.mkdir(r,{recursive:!0});let e=fn("global/docs/");if(e.length>0){for(let n of e)if(n.endsWith(".md")){let o=wt(n);if(o){let i=Se.basename(n);await et.writeFile(Se.join(r,i),o,"utf-8")}}return{success:!0}}let{PACKAGE_ROOT:t}=(Ct(),ot(ta)),s=Se.join(t,"templates/global/docs");try{let n=await et.readdir(s);for(let o of n)if(o.endsWith(".md")){let i=Se.join(s,o),a=Se.join(r,o),c=await et.readFile(i,"utf-8");await et.writeFile(a,c,"utf-8")}}catch{}return{success:!0}}catch(r){return{success:!1,error:w(r)}}}async function ty(){let r=(at(),ot(vt)),e=await r.getActiveProvider(),t=e.name;if(!(await r.detectProvider(t)).installed&&!e.configDir)return{success:!1,error:`${e.displayName} not detected`,action:"skipped"};try{await et.mkdir(e.configDir,{recursive:!0});let n=Se.join(e.configDir,e.contextFile),o=ju;if(t!=="claude"){let g=wt(`global/${e.contextFile}`);if(g)o=g;else{let{PACKAGE_ROOT:h}=(Ct(),ot(ta)),k=Se.join(h,"templates","global",e.contextFile);try{o=await et.readFile(k,"utf-8")}catch{t==="gemini"&&(o=ju.replace(/Claude/g,"Gemini"))}}}let i="",a=!1;try{i=await et.readFile(n,"utf-8"),a=!0}catch(g){if(R(g))a=!1;else throw g}let c="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",u="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->";if(i.includes(c)&&i.includes(u)){let g=i.substring(0,i.indexOf(c)),h=i.substring(i.indexOf(u)+u.length);i=`${(g+h).replace(/\n{3,}/g,`
359
389
 
360
390
  `).trim()}
361
- `}let d=no(a?i:"",o,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Ze.writeFile(n,d.content,"utf-8"),{success:!0,action:d.action,path:n}}catch(n){return{success:!1,error:y(n),action:"failed"}}}function Au(){let r=ro.homedir();return{claude:{commands:Se.join(r,".claude","commands"),config:Se.join(r,".claude"),router:Se.join(r,".claude","commands","p.md")},gemini:{commands:Se.join(r,".gemini","commands"),config:Se.join(r,".gemini"),router:Se.join(r,".gemini","commands","p.toml")}}}var Ru,rs,Qh,De,os=S(()=>{"use strict";Hs();V();q();ra();Ru=`<!-- prjct:start - DO NOT REMOVE THIS MARKER -->
391
+ `}let d=ao(a?i:"",o,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await et.writeFile(n,d.content,"utf-8"),{success:!0,action:d.action,path:n}}catch(n){return{success:!1,error:w(n),action:"failed"}}}function Iu(){let r=co.homedir();return{claude:{commands:Se.join(r,".claude","commands"),config:Se.join(r,".claude"),router:Se.join(r,".claude","commands","p.md")},gemini:{commands:Se.join(r,".gemini","commands"),config:Se.join(r,".gemini"),router:Se.join(r,".gemini","commands","p.toml")}}}var ju,rs,sy,De,os=S(()=>{"use strict";Hs();W();K();ia();ju=`<!-- prjct:start - DO NOT REMOVE THIS MARKER -->
362
392
  # p/ \u2014 Context layer for AI agents
363
393
 
364
394
  Skills auto-activate for: task, done, pause, resume, ship, next, sync, bug, workflow, enrich, linear, jira, plan, velocity, tokens
@@ -374,22 +404,22 @@ Data:
374
404
 
375
405
  **Auto-managed by prjct-cli** | https://prjct.app
376
406
  <!-- prjct:end - DO NOT REMOVE THIS MARKER -->
377
- `;l(Xh,"installDocs");l(Yh,"installGlobalConfig");rs=class{static{l(this,"CommandInstaller")}homeDir;commandsPath="";configPath="";_initialized=!1;constructor(){this.homeDir=ro.homedir()}async ensureInit(){if(this._initialized)return;let t=await(it(),bt(Tt)).getActiveProvider();this.commandsPath=Se.join(t.configDir,"commands"),this.configPath=t.configDir,this._initialized=!0}async detectActiveProvider(){return await this.ensureInit(),C(this.configPath)}async installCommands(){let e=await this.detectActiveProvider(),s=await(it(),bt(Tt)).getActiveProvider();return e?(await this.cleanupRouter(),{success:!0,installed:[],path:this.commandsPath}):{success:!1,error:`${s.displayName} not detected. Please install it first.`}}async uninstallCommands(){try{let e=[];await this.ensureInit();for(let t of["p.md","p.toml"]){let s=Se.join(this.commandsPath,t);try{await Ze.unlink(s),e.push(t)}catch(n){if(n.code!=="ENOENT")return{success:!1,error:y(n)}}}return{success:!0,uninstalled:e}}catch(e){return{success:!1,error:y(e)}}}async checkInstallation(){return await this.detectActiveProvider()?{installed:!0,providerDetected:!0,commands:[],path:this.commandsPath}:{installed:!1,providerDetected:!1}}async getInstallPath(){return await this.ensureInit(),this.commandsPath}async syncCommands(){if(!await this.detectActiveProvider())return{success:!1,error:"AI agent not detected",added:0,updated:0,removed:0};try{return{success:!0,added:0,updated:0,removed:await this.cleanupRouter()?1:0}}catch(t){return{success:!1,error:y(t),added:0,updated:0,removed:0}}}async cleanupRouter(){await this.ensureInit();let e=!1;for(let t of["p.md","p.toml"]){let s=Se.join(this.commandsPath,t);try{await Ze.unlink(s),e=!0}catch(n){n.code}}return e}async cleanupLegacyCommands(){await this.ensureInit();let e=Se.join(this.commandsPath,"p");try{if((await Ze.stat(e).catch(()=>null))?.isDirectory())return await Ze.rm(e,{recursive:!0,force:!0}),!0}catch{}return!1}async installGlobalConfig(){return Yh()}async cleanupAllLegacy(){let e=ro.homedir(),t=[],s=[Se.join(e,".claude","commands","p.md"),Se.join(e,".claude","commands","p.toml"),Se.join(e,".gemini","commands","p.md"),Se.join(e,".gemini","commands","p.toml")];for(let i of s)try{await Ze.unlink(i),t.push(i)}catch{}let n=[Se.join(e,".claude","commands","p"),Se.join(e,".gemini","commands","p")];for(let i of n)try{(await Ze.stat(i).catch(()=>null))?.isDirectory()&&(await Ze.rm(i,{recursive:!0,force:!0}),t.push(i))}catch{}let o=[Se.join(e,".prjct-cli","config","homebrew-migrated")];for(let i of o)try{await Ze.unlink(i),t.push(i)}catch{}return{cleaned:t}}async installDocs(){return Xh()}};l(Au,"getProviderPaths");Qh=new rs,De=Qh});import{z as Oe}from"zod";function $u(r,e="default"){let t=Du[e]||Du.default;return r/1e3*t}function oo(r){return r<.01?`$${(r*100).toFixed(2)}\xA2`:`$${r.toFixed(2)}`}var Zh,ey,ju,Iu,Du,io=S(()=>{"use strict";Zh=Oe.object({date:Oe.string(),tokensSaved:Oe.number(),syncs:Oe.number(),avgCompressionRate:Oe.number(),totalDuration:Oe.number()}),ey=Oe.object({agentName:Oe.string(),usageCount:Oe.number(),tokensSaved:Oe.number()}),ju=Oe.object({totalTokensSaved:Oe.number(),avgCompressionRate:Oe.number(),syncCount:Oe.number(),watchTriggers:Oe.number(),avgSyncDuration:Oe.number(),totalSyncDuration:Oe.number(),agentUsage:Oe.array(ey),dailyStats:Oe.array(Zh),firstSync:Oe.string(),lastUpdated:Oe.string()}),Iu={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},Du={"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};l($u,"estimateCostSaved");l(oo,"formatCost")});function Mu(r,e){let t=[];hr("Languages",r.languages,e.languages,t),hr("Frameworks",r.frameworks,e.frameworks,t),(r.packageManager??"")!==(e.packageManager??"")&&t.push({field:"Package manager",type:"changed",before:r.packageManager??"(none)",after:e.packageManager??"(none)"}),(r.sourceDir??"")!==(e.sourceDir??"")&&t.push({field:"Source directory",type:"changed",before:r.sourceDir??"(none)",after:e.sourceDir??"(none)"}),(r.testDir??"")!==(e.testDir??"")&&t.push({field:"Test directory",type:"changed",before:r.testDir??"(none)",after:e.testDir??"(none)"}),hr("Config files",r.configFiles,e.configFiles,t),r.fileCount!==e.fileCount&&t.push({field:"File count",type:"changed",before:String(r.fileCount),after:String(e.fileCount)});let s=r.patterns.map(p=>p.name),n=e.patterns.map(p=>p.name);hr("Patterns",s,n,t);let o=r.antiPatterns.map(p=>p.issue),i=e.antiPatterns.map(p=>p.issue);hr("Anti-patterns",o,i,t);let a=t.filter(p=>p.type==="added").length,c=t.filter(p=>p.type==="removed").length,u=t.filter(p=>p.type==="changed").length;return{hasChanges:t.length>0,items:t,summary:{added:a,removed:c,changed:u},beforeCommit:r.commitHash??null,afterCommit:e.commitHash??null}}function oa(r){if(!r.hasChanges)return`## Analysis Diff
407
+ `;l(ey,"installDocs");l(ty,"installGlobalConfig");rs=class{static{l(this,"CommandInstaller")}homeDir;commandsPath="";configPath="";_initialized=!1;constructor(){this.homeDir=co.homedir()}async ensureInit(){if(this._initialized)return;let t=await(at(),ot(vt)).getActiveProvider();this.commandsPath=Se.join(t.configDir,"commands"),this.configPath=t.configDir,this._initialized=!0}async detectActiveProvider(){return await this.ensureInit(),P(this.configPath)}async installCommands(){let e=await this.detectActiveProvider(),s=await(at(),ot(vt)).getActiveProvider();return e?(await this.cleanupRouter(),{success:!0,installed:[],path:this.commandsPath}):{success:!1,error:`${s.displayName} not detected. Please install it first.`}}async uninstallCommands(){try{let e=[];await this.ensureInit();for(let t of["p.md","p.toml"]){let s=Se.join(this.commandsPath,t);try{await et.unlink(s),e.push(t)}catch(n){if(n.code!=="ENOENT")return{success:!1,error:w(n)}}}return{success:!0,uninstalled:e}}catch(e){return{success:!1,error:w(e)}}}async checkInstallation(){return await this.detectActiveProvider()?{installed:!0,providerDetected:!0,commands:[],path:this.commandsPath}:{installed:!1,providerDetected:!1}}async getInstallPath(){return await this.ensureInit(),this.commandsPath}async syncCommands(){if(!await this.detectActiveProvider())return{success:!1,error:"AI agent not detected",added:0,updated:0,removed:0};try{return{success:!0,added:0,updated:0,removed:await this.cleanupRouter()?1:0}}catch(t){return{success:!1,error:w(t),added:0,updated:0,removed:0}}}async cleanupRouter(){await this.ensureInit();let e=!1;for(let t of["p.md","p.toml"]){let s=Se.join(this.commandsPath,t);try{await et.unlink(s),e=!0}catch(n){n.code}}return e}async cleanupLegacyCommands(){await this.ensureInit();let e=Se.join(this.commandsPath,"p");try{if((await et.stat(e).catch(()=>null))?.isDirectory())return await et.rm(e,{recursive:!0,force:!0}),!0}catch{}return!1}async installGlobalConfig(){return ty()}async cleanupAllLegacy(){let e=co.homedir(),t=[],s=[Se.join(e,".claude","commands","p.md"),Se.join(e,".claude","commands","p.toml"),Se.join(e,".gemini","commands","p.md"),Se.join(e,".gemini","commands","p.toml")];for(let i of s)try{await et.unlink(i),t.push(i)}catch{}let n=[Se.join(e,".claude","commands","p"),Se.join(e,".gemini","commands","p")];for(let i of n)try{(await et.stat(i).catch(()=>null))?.isDirectory()&&(await et.rm(i,{recursive:!0,force:!0}),t.push(i))}catch{}let o=[Se.join(e,".prjct-cli","config","homebrew-migrated")];for(let i of o)try{await et.unlink(i),t.push(i)}catch{}return{cleaned:t}}async installDocs(){return ey()}};l(Iu,"getProviderPaths");sy=new rs,De=sy});import{z as _e}from"zod";function Ou(r,e="default"){let t=$u[e]||$u.default;return r/1e3*t}function lo(r){return r<.01?`$${(r*100).toFixed(2)}\xA2`:`$${r.toFixed(2)}`}var ny,ry,Mu,_u,$u,uo=S(()=>{"use strict";ny=_e.object({date:_e.string(),tokensSaved:_e.number(),syncs:_e.number(),avgCompressionRate:_e.number(),totalDuration:_e.number()}),ry=_e.object({agentName:_e.string(),usageCount:_e.number(),tokensSaved:_e.number()}),Mu=_e.object({totalTokensSaved:_e.number(),avgCompressionRate:_e.number(),syncCount:_e.number(),watchTriggers:_e.number(),avgSyncDuration:_e.number(),totalSyncDuration:_e.number(),agentUsage:_e.array(ry),dailyStats:_e.array(ny),firstSync:_e.string(),lastUpdated:_e.string()}),_u={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},$u={"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};l(Ou,"estimateCostSaved");l(lo,"formatCost")});function Nu(r,e){let t=[];hr("Languages",r.languages,e.languages,t),hr("Frameworks",r.frameworks,e.frameworks,t),(r.packageManager??"")!==(e.packageManager??"")&&t.push({field:"Package manager",type:"changed",before:r.packageManager??"(none)",after:e.packageManager??"(none)"}),(r.sourceDir??"")!==(e.sourceDir??"")&&t.push({field:"Source directory",type:"changed",before:r.sourceDir??"(none)",after:e.sourceDir??"(none)"}),(r.testDir??"")!==(e.testDir??"")&&t.push({field:"Test directory",type:"changed",before:r.testDir??"(none)",after:e.testDir??"(none)"}),hr("Config files",r.configFiles,e.configFiles,t),r.fileCount!==e.fileCount&&t.push({field:"File count",type:"changed",before:String(r.fileCount),after:String(e.fileCount)});let s=r.patterns.map(p=>p.name),n=e.patterns.map(p=>p.name);hr("Patterns",s,n,t);let o=r.antiPatterns.map(p=>p.issue),i=e.antiPatterns.map(p=>p.issue);hr("Anti-patterns",o,i,t);let a=t.filter(p=>p.type==="added").length,c=t.filter(p=>p.type==="removed").length,u=t.filter(p=>p.type==="changed").length;return{hasChanges:t.length>0,items:t,summary:{added:a,removed:c,changed:u},beforeCommit:r.commitHash??null,afterCommit:e.commitHash??null}}function aa(r){if(!r.hasChanges)return`## Analysis Diff
378
408
 
379
409
  No changes between runs.`;let e=[];e.push("## Analysis Diff"),(r.beforeCommit||r.afterCommit)&&e.push(`> \`${r.beforeCommit?.substring(0,7)??"(none)"}\` \u2192 \`${r.afterCommit?.substring(0,7)??"(none)"}\``),e.push(""),e.push("| Change | Field | Detail |"),e.push("|--------|-------|--------|");for(let s of r.items){let n=s.type==="added"?"+":s.type==="removed"?"-":"~",o=s.type==="changed"?`${s.before} \u2192 ${s.after}`:s.after??s.before??"";e.push(`| ${n} | ${s.field} | ${o} |`)}e.push("");let t=[];return r.summary.added>0&&t.push(`${r.summary.added} added`),r.summary.removed>0&&t.push(`${r.summary.removed} removed`),r.summary.changed>0&&t.push(`${r.summary.changed} changed`),e.push(`**Summary**: ${t.join(", ")}`),e.join(`
380
- `)}function Ou(r){if(!r.hasChanges)return"No changes between analysis runs.";let e=[];(r.beforeCommit||r.afterCommit)&&(e.push(` ${r.beforeCommit?.substring(0,7)??"(none)"} \u2192 ${r.afterCommit?.substring(0,7)??"(none)"}`),e.push(""));for(let t of r.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(`
381
- `)}function hr(r,e,t,s){let n=new Set(e),o=new Set(t);for(let i of t)n.has(i)||s.push({field:r,type:"added",after:i});for(let i of e)o.has(i)||s.push({field:r,type:"removed",before:i})}var ia=S(()=>{"use strict";l(Mu,"generateAnalysisDiff");l(oa,"formatAnalysisDiffMd");l(Ou,"formatAnalysisDiffText");l(hr,"diffStringArray")});var aa,ca,_u,yr=S(()=>{"use strict";aa=[1,2,3,5,8,13,21],ca={1:{min:5,max:15,typical:10},2:{min:15,max:30,typical:20},3:{min:30,max:60,typical:45},5:{min:60,max:120,typical:90},8:{min:120,max:240,typical:180},13:{min:240,max:480,typical:360},21:{min:480,max:960,typical:720}},_u={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6}});import ty from"node:fs/promises";import sy from"node:path";function hn(r){return r.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 ny(r,e){let t=[],s=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let d of s)t.push(...hn(d));let n=[/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 d of n){let g;for(;(g=d.exec(r))!==null;)g[1]&&t.push(...hn(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 d of o){let g;for(;(g=d.exec(r))!==null;)g[1]&&t.push(...hn(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(r))!==null;){let d=a[1];if(d.startsWith(".")||d.startsWith("@/"))t.push(...hn(d));else{let g=d.startsWith("@")?d.split("/").slice(0,2).join("/"):d.split("/")[0];t.push(...hn(g))}}let c=/\/\/\s*(.+)/g,u;for(;(u=c.exec(r))!==null;){let d=u[1].toLowerCase().split(/\s+/).filter(g=>g.length>2);t.push(...d)}let p=/\/\*\*?([\s\S]*?)\*\//g,m;for(;(m=p.exec(r))!==null;){let d=m[1].replace(/@\w+/g,"").replace(/\*/g,"").toLowerCase().split(/\s+/).filter(g=>g.length>2&&/^[a-z]+$/.test(g));t.push(...d)}return t.filter(d=>d.length>1&&!Fu.has(d)&&/^[a-z][a-z0-9]*$/.test(d))}function ry(r){return r.split(/\s+/).flatMap(e=>hn(e)).filter(e=>e.length>1&&!Fu.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function oy(r){let e=await Is(r),t={},s={},n=0,o=await $s(e,50,async a=>{try{let c=await ty.readFile(sy.join(r,a),"utf-8"),u=ny(c,a);return u.length>0?{filePath:a,tokens:u}:null}catch{return null}});for(let{filePath:a,tokens:c}of o){t[a]={tokens:c,length:c.length},n+=c.length;let u=new Map;for(let p of c)u.set(p,(u.get(p)||0)+1);for(let[p,m]of u)s[p]||(s[p]=[]),s[p].push({path:a,tf:m})}let i=Object.keys(t).length;return{documents:t,invertedIndex:s,avgDocLength:i>0?n/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function iy(r,e){return Math.log((e-r+.5)/(r+.5)+1)}function ay(r,e){let t=ry(r);if(t.length===0)return[];let s=new Map;for(let n of t){let o=e.invertedIndex[n];if(!o)continue;let i=iy(o.length,e.totalDocs);for(let{path:a,tf:c}of o){let u=e.documents[a];if(!u)continue;let p=c*(1.2+1),m=c+1.2*(1-.75+.75*(u.length/e.avgDocLength)),d=i*(p/m);s.set(a,(s.get(a)||0)+d)}}return Array.from(s.entries()).map(([n,o])=>({path:n,score:o})).sort((n,o)=>o.score-n.score)}function cy(r,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([s,n])=>[s,n.length]))};F.setDoc(r,Uu,t)}function ao(r){let e=F.getDoc(r,Uu);if(!e)return null;let t={};for(let[s,n]of Object.entries(e.docLengths))t[s]={tokens:[],length:n};return{documents:t,invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt}}async function Hu(r,e){let t=await oy(r);return cy(e,t),t}function Gu(r,e,t=15){let s=ao(r);return s?ay(e,s).slice(0,t):[]}var Fu,Uu,la=S(()=>{"use strict";yr();ce();q();Fu=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"]);l(hn,"splitIdentifier");l(ny,"tokenizeFile");l(ry,"tokenizeQuery");l(oy,"buildIndex");l(iy,"idf");l(ay,"score");Uu="bm25-index";l(cy,"saveIndex");l(ao,"loadIndex");l(Hu,"indexProject");l(Gu,"queryFiles")});import ua from"node:fs/promises";import ys from"node:path";import{z as X}from"zod";async function my(r,e){let t=Date.now();if(r.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let s=ys.join(e,"package.json"),n=await ua.readFile(s,"utf-8"),o=JSON.parse(n),i={...o.dependencies,...o.devDependencies},a=[],c=[];for(let u of r.frameworks){let p=u.toLowerCase();Object.keys(i).some(d=>d.toLowerCase().includes(p))?c.push(u):a.push(u)}return a.length===0?{name:"Framework verification",passed:!0,output:`${c.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 R(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 gy(r,e){let t=Date.now();if(r.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let s=await wy(e),n=new Set(s),o=[],i=[];for(let a of r.languages){let c=py[a];if(!c)continue;c.some(p=>n.has(p))?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 fy(r,e){let t=Date.now(),s=r.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 n=[],o=[];for(let i of s){let a=i.location,c=ys.join(e,a);await C(c)?o.push(a):n.push(`${i.name} (${a})`)}return n.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: ${n.join(", ")}`,durationMs:Date.now()-t}}async function hy(r,e){let t=Date.now();try{let s=await ky(e),n=r.fileCount,o=.1,i=Math.abs(s-n),a=n*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${n}, actual: ${s})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${n}, 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 yy(r,e){let t=Date.now();if(r.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let s=[],n=[];for(let o of r.antiPatterns){let i=ys.join(e,o.file);await C(i)?n.push(o.file):s.push(`${o.issue} (${o.file})`)}return s.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${n.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 Vu(r,e){let t=Date.now(),s=await Promise.all([my(r,e),gy(r,e),fy(r,e),hy(r,e),yy(r,e)]),n=s.filter(i=>!i.passed).length,o=s.filter(i=>i.passed).length;return{passed:n===0,checks:s,totalMs:Date.now()-t,failedCount:n,passedCount:o}}async function wy(r){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(n){try{let o=await ua.readdir(n,{withFileTypes:!0});for(let i of o){let a=ys.join(n,i.name),c=ys.relative(r,a);if(!t.some(u=>u.test(c))){if(i.isDirectory())await s(a);else if(i.isFile()){let u=ys.extname(i.name);u&&e.add(u)}}}}catch{}}return l(s,"scanDir"),await s(r),Array.from(e)}async function ky(r){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(n){try{let o=await ua.readdir(n,{withFileTypes:!0});for(let i of o){let a=ys.join(n,i.name),c=ys.relative(r,a);t.some(u=>u.test(c))||(i.isDirectory()?await s(a):i.isFile()&&e++)}}catch{}}return l(s,"scanDir"),await s(r),e}var ly,uy,dy,da,mE,py,Wu=S(()=>{"use strict";V();q();Br();ly=X.enum(["draft","verified","sealed"]),uy=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()}),dy=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()}),da=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(uy),antiPatterns:X.array(dy),analyzedAt:X.string(),modelMetadata:ln.optional(),status:ly.default("draft"),commitHash:X.string().optional(),signature:X.string().optional(),sealedAt:X.string().optional(),verifiedAt:X.string().optional()}),mE={languages:[],frameworks:[],configFiles:[],fileCount:0,patterns:[],antiPatterns:[],analyzedAt:new Date().toISOString(),status:"draft"},py={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"]};l(my,"verifyFrameworks");l(gy,"verifyLanguages");l(fy,"verifyPatternLocations");l(hy,"verifyFileCount");l(yy,"verifyAntiPatternFiles");l(Vu,"semanticVerify");l(wy,"getProjectExtensions");l(ky,"countProjectFiles")});import{createHash as Bu}from"node:crypto";function wr(r){return Bu("sha256").update(r).digest("hex")}function co(r){return wr(r).slice(0,16)}function Ju(r){return Bu("md5").update(r).digest("hex")}var yn=S(()=>{"use strict";l(wr,"sha256");l(co,"sha256Short");l(Ju,"md5")});var pa,ws,ma=S(()=>{"use strict";ve();oe();q();pa=class{static{l(this,"SyncEventBus")}async publish(e){let t=A.getSyncPendingPath(e.projectId),s=await xe(t,[])??[];s.push(e),await le(t,s)}async getPending(e){let t=A.getSyncPendingPath(e);return await xe(t,[])??[]}async clearPending(e){let t=A.getSyncPendingPath(e);await le(t,[])}async updateLastSync(e){let t=A.getLastSyncPath(e),s={timestamp:v(),success:!0};await le(t,s)}async getLastSync(e){let t=A.getLastSyncPath(e);return await xe(t,null)}},ws=new pa});var ze,is=S(()=>{"use strict";ma();Ms();oe();ce();ze=class{static{l(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new un({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=P.getDoc(e,this.getStoreKey());if(s!==null)return this.cache.set(e,s),s}catch{}return this.getDefault()}async write(e,t){P.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let s=await this.read(e),n=t(s);return await this.write(e,n),n}async publishEvent(e,t,s){let n={type:t,path:[this.filename.replace(".json","")],data:s,timestamp:v(),projectId:e};await ws.publish(n)}async publishEntityEvent(e,t,s,n){let o=`${t}.${s}`,i={...n,timestamp:v()};await this.publishEvent(e,o,i)}async exists(e){try{return P.hasDoc(e,this.getStoreKey())}catch{return!1}}clearCache(e){e?this.cache.delete(e):this.cache.clear()}getCacheStats(){return this.cache.stats()}}});var ga,qe,wn=S(()=>{"use strict";Wu();ia();oe();yn();is();ga=class extends ze{static{l(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"};da.parse(s),await this.update(e,n=>({...n,draft:s,lastUpdated:v()})),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),n=v(),o={...t.draft,status:"sealed",signature:s,sealedAt:n};return da.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:n}),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=v();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:Mu(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),n=s.sealed??s.draft;return n?await Vu(n,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))}},qe=new ga});var fa,Sy,Kt,kr=S(()=>{"use strict";oe();ce();fa=class{static{l(this,"LLMAnalysisStorage")}save(e,t){let s=P.getDb(e),n=v();s.transaction(()=>{s.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(n),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=P.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?P.get(e,"SELECT commit_hash FROM llm_analysis WHERE status = 'active' LIMIT 1")?.commit_hash===t:!1}getHistory(e,t=10){return P.query(e,"SELECT id, commit_hash, status, analyzed_at, analysis FROM llm_analysis ORDER BY id DESC LIMIT ?",t).map(n=>{let o=JSON.parse(n.analysis);return{id:n.id,commitHash:n.commit_hash,status:n.status,analyzedAt:n.analyzed_at,patternCount:o.patterns.length}})}},Sy=new fa,Kt=Sy});import{z as b}from"zod";var by,lo,vy,Ty,Cy,ha,qu,Ku,Xu,Yu,zu,Py,Ey,Qu,Zu,ed,xy,Ry,GE,ya=S(()=>{"use strict";Br();by=b.enum(["low","medium","high","critical"]),lo=b.enum(["feature","bug","improvement","chore"]),vy=b.enum(["active","backlog","previously_active"]),Ty=b.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),Cy=b.enum(["task_completed","feature_shipped","idea_captured","session_started"]),ha=b.object({title:b.string(),description:b.string(),filesChanged:b.array(b.object({path:b.string(),action:b.enum(["created","modified","deleted"])})),whatWasDone:b.array(b.string()).min(1),outputForNextAgent:b.string().min(1),notes:b.string().optional()}),qu=b.object({output:b.string().min(1,"Subtask output is required"),summary:ha}),Ku=b.object({id:b.string(),description:b.string(),domain:b.string(),agent:b.string(),status:Ty,dependsOn:b.array(b.string()),startedAt:b.string().optional(),completedAt:b.string().optional(),output:b.string().optional(),summary:ha.optional(),skipReason:b.string().optional(),blockReason:b.string().optional(),estimatedPoints:b.number().optional(),estimatedMinutes:b.number().optional()}),Xu=b.object({completed:b.number(),total:b.number(),percentage:b.number()}),Yu=b.object({id:b.string(),description:b.string(),type:lo.optional(),startedAt:b.string(),sessionId:b.string(),featureId:b.string().optional(),subtasks:b.array(Ku).optional(),currentSubtaskIndex:b.number().optional(),subtaskProgress:Xu.optional(),linearId:b.string().optional(),linearUuid:b.string().optional(),estimatedPoints:b.number().optional(),estimatedMinutes:b.number().optional(),modelMetadata:ln.optional(),tokensIn:b.number().optional(),tokensOut:b.number().optional(),parentDescription:b.string().optional(),branch:b.string().optional(),prUrl:b.string().optional()}),zu=b.object({id:b.string(),description:b.string(),status:b.literal("paused"),startedAt:b.string(),pausedAt:b.string(),pauseReason:b.string().optional(),type:lo.optional(),sessionId:b.string().optional(),featureId:b.string().optional(),subtasks:b.array(Ku).optional(),currentSubtaskIndex:b.number().optional(),subtaskProgress:Xu.optional(),linearId:b.string().optional(),linearUuid:b.string().optional(),estimatedPoints:b.number().optional(),estimatedMinutes:b.number().optional(),modelMetadata:ln.optional(),tokensIn:b.number().optional(),tokensOut:b.number().optional()}),Py=b.object({stackConfirmed:b.array(b.string()).optional(),patternsDiscovered:b.array(b.string()).optional(),agentAccuracy:b.array(b.object({agent:b.string(),rating:b.enum(["helpful","neutral","inaccurate"]),note:b.string().optional()})).optional(),issuesEncountered:b.array(b.string()).optional()}),Ey=b.object({taskId:b.string(),title:b.string(),classification:lo,startedAt:b.string(),completedAt:b.string(),subtaskCount:b.number(),subtaskSummaries:b.array(ha),outcome:b.string(),branchName:b.string(),linearId:b.string().optional(),linearUuid:b.string().optional(),prUrl:b.string().optional(),feedback:Py.optional(),tokensIn:b.number().optional(),tokensOut:b.number().optional()}),Qu=b.object({currentTask:Yu.nullable(),previousTask:zu.nullable().optional(),pausedTasks:b.array(zu).optional(),taskHistory:b.array(Ey).optional(),lastUpdated:b.string()}),Zu=b.object({id:b.string(),description:b.string(),priority:by,type:lo,featureId:b.string().optional(),originFeature:b.string().optional(),completed:b.boolean(),completedAt:b.string().optional(),createdAt:b.string(),section:vy,agent:b.string().optional(),groupName:b.string().optional(),groupId:b.string().optional()}),ed=b.object({tasks:b.array(Zu),lastUpdated:b.string()}),xy=b.object({tasksToday:b.number(),tasksThisWeek:b.number(),streak:b.number(),velocity:b.string(),avgDuration:b.string()}),Ry=b.object({type:Cy,description:b.string(),timestamp:b.string(),duration:b.string().optional()}),GE=b.object({projectId:b.string(),currentTask:Yu.nullable(),queue:b.array(Zu),stats:xy,recentActivity:b.array(Ry),lastSync:b.string()})});var Sr,wa,Gs,ka=S(()=>{"use strict";Sr={idle:{transitions:["task","next"],prompt:"p. task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"p. done Complete task | p. pause Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"p. resume Continue | p. task <new> Start different | p. ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","next","pause","reopen"],prompt:"p. ship Ship it | p. task <next> Start next | p. reopen Reopen for rework",description:"Task completed"},shipped:{transitions:["task","next"],prompt:"p. task <description> Start new task",description:"Feature shipped"}},wa=class{static{l(this,"WorkflowStateMachine")}getCurrentState(e){let t=e?.currentTask;if(!t)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof t.status=="string"?t.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 t?"working":"idle"}}canTransition(e,t){let s=Sr[e];if(s.transitions.includes(t))return{valid:!0};let n=s.transitions.map(o=>`p. ${o}`).join(", ");return{valid:!1,error:`Cannot run 'p. ${t}' in ${e} state`,suggestion:`Valid commands: ${n}`}}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";case"next":return e;default:return e}}getStateInfo(e){return Sr[e]}getPrompt(e){return Sr[e].prompt}getValidCommands(e){return Sr[e].transitions}formatNextSteps(e){return Sr[e].transitions.map(s=>{switch(s){case"task":return"p. task <desc> Start new task";case"done":return"p. done Complete current task";case"pause":return"p. pause Pause and switch context";case"resume":return"p. resume Continue paused task";case"ship":return"p. ship Ship the feature";case"reopen":return"p. reopen Reopen for rework";case"next":return"p. next View task queue";default:return`p. ${s}`}})}},Gs=new wa});var as,Sa,Mt,Vs=S(()=>{"use strict";It();oe();ce();as={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},Sa=class{static{l(this,"ArchiveStorage")}archive(e,t){let s=ye(),n=v();return P.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,n,t.reason),s}archiveMany(e,t){if(t.length===0)return 0;let s=v();return P.transaction(e,n=>{let o=n.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(ye(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,s,i.reason)}),t.length}getArchived(e,t,s=50){return t?P.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,s):P.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",s)}getStats(e){let t=P.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 n of t){let o=n.entity_type;o in s&&(s[o]=n.count),s.total+=n.count}return s}restore(e,t){let s=P.get(e,"SELECT * FROM archives WHERE id = ?",t);return s?(P.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(),n=this.getTotalCount(e);P.run(e,"DELETE FROM archives WHERE archived_at < ?",s);let o=this.getTotalCount(e);return n-o}getTotalCount(e){return P.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},Mt=new Sa});var ba,_,Pt=S(()=>{"use strict";It();ya();oe();ka();Vs();is();ba=class extends ze{static{l(this,"StateStorage")}constructor(){super("state.json",Qu)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let s=Gs.getCurrentState(e),n=Gs.canTransition(s,t);if(!n.valid)throw new Error(`${n.error}. ${n.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async startTask(e,t){let s=await this.read(e);this.validateTransition(s,"task");let n={...t,startedAt:v()};return await this.update(e,o=>({...o,currentTask:n,lastUpdated:v()})),await this.publishEvent(e,"task.started",{taskId:n.id,description:n.description,startedAt:n.startedAt,sessionId:n.sessionId}),n}async updateCurrentTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;let n={...s.currentTask,...t};return await this.update(e,o=>({...o,currentTask:n,lastUpdated:v()})),n}async completeTask(e,t){let s=await this.read(e),n=s.currentTask;if(!n)return null;this.validateTransition(s,"done");let o=v(),i=this.createTaskHistoryEntry(n,o,t),a=this.getTaskHistoryFromState(s),c=[i,...a].slice(0,this.maxTaskHistory);return await this.update(e,u=>({...u,currentTask:null,previousTask:null,taskHistory:c,lastUpdated:o})),await this.publishEvent(e,"task.completed",{taskId:n.id,description:n.description,startedAt:n.startedAt,completedAt:o}),n}createTaskHistoryEntry(e,t,s){let n=(e.subtasks||[]).filter(a=>a.status==="completed"&&a.summary).map(a=>a.summary),o=n.length>0?n.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:n,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 n={...s.currentTask,status:"paused",pausedAt:v(),pauseReason:t},o=this.getPausedTasksFromState(s),i=[n,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:v()})),await this.publishEvent(e,"task.paused",{taskId:n.id,description:n.description,pausedAt:n.pausedAt,reason:t,pausedCount:i.length}),n}async resumeTask(e,t){let s=await this.read(e),n=this.getPausedTasksFromState(s);if(n.length===0)return null;this.validateTransition(s,"resume");let o=0;if(t&&(o=n.findIndex(g=>g.id===t),o===-1))return null;let i=n[o],a=n.filter((g,h)=>h!==o),{status:c,pausedAt:u,pauseReason:p,...m}=i,d={...m,startedAt:v(),sessionId:i.sessionId??ye()};return await this.update(e,g=>({...g,currentTask:d,previousTask:null,pausedTasks:a,lastUpdated:v()})),await this.publishEvent(e,"task.resumed",{taskId:d.id,description:d.description,resumedAt:d.startedAt,remainingPaused:a.length}),d}getPausedTasksFromState(e){return 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),n=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return s.filter(o=>new Date(o.pausedAt).getTime()<n)}async archiveStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),n=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=s.filter(a=>new Date(a.pausedAt).getTime()<n),i=s.filter(a=>new Date(a.pausedAt).getTime()>=n);if(o.length===0)return[];Mt.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:v()}));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:[],lastUpdated:v()}))}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(d=>d.feedback),n=[],o=[],i=[],a=[];for(let d of s){let g=d.feedback;g.stackConfirmed&&n.push(...g.stackConfirmed),g.patternsDiscovered&&o.push(...g.patternsDiscovered),g.agentAccuracy&&i.push(...g.agentAccuracy),g.issuesEncountered&&a.push(...g.issuesEncountered)}let c=[...new Set(n)],u=[...new Set(o)],p=new Map;for(let d of a)p.set(d,(p.get(d)||0)+1);let m=[...p.entries()].filter(([d,g])=>g>=2).map(([d])=>d);return{stackConfirmed:c,patternsDiscovered:u,agentAccuracy:i,issuesEncountered:[...new Set(a)],knownGotchas:m}}async addTokens(e,t,s){let n=await this.read(e);if(!n.currentTask)return null;let o=(n.currentTask.tokensIn||0)+t,i=(n.currentTask.tokensOut||0)+s;return await this.update(e,a=>({...a,currentTask:{...a.currentTask,tokensIn:o,tokensOut:i},lastUpdated:v()})),{tokensIn:o,tokensOut:i}}async createSubtasks(e,t){let s=await this.read(e);if(!s.currentTask)return;let n=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?v():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:n,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:n.length,percentage:0}},lastUpdated:v()})),await this.publishEvent(e,"subtasks.created",{taskId:s.currentTask.id,subtaskCount:n.length,subtasks:n.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let s=qu.safeParse(t);if(!s.success){let h=s.error.issues.map(k=>`${k.path.join(".")}: ${k.message}`);throw new Error(`Subtask completion requires handoff data:
410
+ `)}function Lu(r){if(!r.hasChanges)return"No changes between analysis runs.";let e=[];(r.beforeCommit||r.afterCommit)&&(e.push(` ${r.beforeCommit?.substring(0,7)??"(none)"} \u2192 ${r.afterCommit?.substring(0,7)??"(none)"}`),e.push(""));for(let t of r.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(`
411
+ `)}function hr(r,e,t,s){let n=new Set(e),o=new Set(t);for(let i of t)n.has(i)||s.push({field:r,type:"added",after:i});for(let i of e)o.has(i)||s.push({field:r,type:"removed",before:i})}var ca=S(()=>{"use strict";l(Nu,"generateAnalysisDiff");l(aa,"formatAnalysisDiffMd");l(Lu,"formatAnalysisDiffText");l(hr,"diffStringArray")});var la,ua,Fu,yr=S(()=>{"use strict";la=[1,2,3,5,8,13,21],ua={1:{min:5,max:15,typical:10},2:{min:15,max:30,typical:20},3:{min:30,max:60,typical:45},5:{min:60,max:120,typical:90},8:{min:120,max:240,typical:180},13:{min:240,max:480,typical:360},21:{min:480,max:960,typical:720}},Fu={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6}});import oy from"node:fs/promises";import iy from"node:path";function yn(r){return r.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 ay(r,e){let t=[],s=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let d of s)t.push(...yn(d));let n=[/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 d of n){let g;for(;(g=d.exec(r))!==null;)g[1]&&t.push(...yn(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 d of o){let g;for(;(g=d.exec(r))!==null;)g[1]&&t.push(...yn(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(r))!==null;){let d=a[1];if(d.startsWith(".")||d.startsWith("@/"))t.push(...yn(d));else{let g=d.startsWith("@")?d.split("/").slice(0,2).join("/"):d.split("/")[0];t.push(...yn(g))}}let c=/\/\/\s*(.+)/g,u;for(;(u=c.exec(r))!==null;){let d=u[1].toLowerCase().split(/\s+/).filter(g=>g.length>2);t.push(...d)}let p=/\/\*\*?([\s\S]*?)\*\//g,m;for(;(m=p.exec(r))!==null;){let d=m[1].replace(/@\w+/g,"").replace(/\*/g,"").toLowerCase().split(/\s+/).filter(g=>g.length>2&&/^[a-z]+$/.test(g));t.push(...d)}return t.filter(d=>d.length>1&&!Gu.has(d)&&/^[a-z][a-z0-9]*$/.test(d))}function cy(r){return r.split(/\s+/).flatMap(e=>yn(e)).filter(e=>e.length>1&&!Gu.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function ly(r){let e=await Is(r),t={},s={},n=0,o=await $s(e,50,async a=>{try{let c=await oy.readFile(iy.join(r,a),"utf-8"),u=ay(c,a);return u.length>0?{filePath:a,tokens:u}:null}catch{return null}});for(let{filePath:a,tokens:c}of o){t[a]={tokens:c,length:c.length},n+=c.length;let u=new Map;for(let p of c)u.set(p,(u.get(p)||0)+1);for(let[p,m]of u)s[p]||(s[p]=[]),s[p].push({path:a,tf:m})}let i=Object.keys(t).length;return{documents:t,invertedIndex:s,avgDocLength:i>0?n/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function uy(r,e){return Math.log((e-r+.5)/(r+.5)+1)}function dy(r,e){let t=cy(r);if(t.length===0)return[];let s=new Map;for(let n of t){let o=e.invertedIndex[n];if(!o)continue;let i=uy(o.length,e.totalDocs);for(let{path:a,tf:c}of o){let u=e.documents[a];if(!u)continue;let p=c*(1.2+1),m=c+1.2*(1-.75+.75*(u.length/e.avgDocLength)),d=i*(p/m);s.set(a,(s.get(a)||0)+d)}}return Array.from(s.entries()).map(([n,o])=>({path:n,score:o})).sort((n,o)=>o.score-n.score)}function py(r,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([s,n])=>[s,n.length]))};N.setDoc(r,Wu,t)}function po(r){let e=N.getDoc(r,Wu);if(!e)return null;let t={};for(let[s,n]of Object.entries(e.docLengths))t[s]={tokens:[],length:n};return{documents:t,invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt}}async function Vu(r,e){let t=await ly(r);return py(e,t),t}function Bu(r,e,t=15){let s=po(r);return s?dy(e,s).slice(0,t):[]}var Gu,Wu,da=S(()=>{"use strict";yr();re();K();Gu=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"]);l(yn,"splitIdentifier");l(ay,"tokenizeFile");l(cy,"tokenizeQuery");l(ly,"buildIndex");l(uy,"idf");l(dy,"score");Wu="bm25-index";l(py,"saveIndex");l(po,"loadIndex");l(Vu,"indexProject");l(Bu,"queryFiles")});import pa from"node:fs/promises";import ys from"node:path";import{z as X}from"zod";async function yy(r,e){let t=Date.now();if(r.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let s=ys.join(e,"package.json"),n=await pa.readFile(s,"utf-8"),o=JSON.parse(n),i={...o.dependencies,...o.devDependencies},a=[],c=[];for(let u of r.frameworks){let p=u.toLowerCase();Object.keys(i).some(d=>d.toLowerCase().includes(p))?c.push(u):a.push(u)}return a.length===0?{name:"Framework verification",passed:!0,output:`${c.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 R(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 wy(r,e){let t=Date.now();if(r.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let s=await Ty(e),n=new Set(s),o=[],i=[];for(let a of r.languages){let c=hy[a];if(!c)continue;c.some(p=>n.has(p))?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 ky(r,e){let t=Date.now(),s=r.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 n=[],o=[];for(let i of s){let a=i.location,c=ys.join(e,a);await P(c)?o.push(a):n.push(`${i.name} (${a})`)}return n.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: ${n.join(", ")}`,durationMs:Date.now()-t}}async function Sy(r,e){let t=Date.now();try{let s=await vy(e),n=r.fileCount,o=.1,i=Math.abs(s-n),a=n*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${n}, actual: ${s})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${n}, 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 by(r,e){let t=Date.now();if(r.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let s=[],n=[];for(let o of r.antiPatterns){let i=ys.join(e,o.file);await P(i)?n.push(o.file):s.push(`${o.issue} (${o.file})`)}return s.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${n.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 zu(r,e){let t=Date.now(),s=await Promise.all([yy(r,e),wy(r,e),ky(r,e),Sy(r,e),by(r,e)]),n=s.filter(i=>!i.passed).length,o=s.filter(i=>i.passed).length;return{passed:n===0,checks:s,totalMs:Date.now()-t,failedCount:n,passedCount:o}}async function Ty(r){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(n){try{let o=await pa.readdir(n,{withFileTypes:!0});for(let i of o){let a=ys.join(n,i.name),c=ys.relative(r,a);if(!t.some(u=>u.test(c))){if(i.isDirectory())await s(a);else if(i.isFile()){let u=ys.extname(i.name);u&&e.add(u)}}}}catch{}}return l(s,"scanDir"),await s(r),Array.from(e)}async function vy(r){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(n){try{let o=await pa.readdir(n,{withFileTypes:!0});for(let i of o){let a=ys.join(n,i.name),c=ys.relative(r,a);t.some(u=>u.test(c))||(i.isDirectory()?await s(a):i.isFile()&&e++)}}catch{}}return l(s,"scanDir"),await s(r),e}var my,gy,fy,ma,hE,hy,Ju=S(()=>{"use strict";W();K();Jr();my=X.enum(["draft","verified","sealed"]),gy=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()}),fy=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()}),ma=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(gy),antiPatterns:X.array(fy),analyzedAt:X.string(),modelMetadata:un.optional(),status:my.default("draft"),commitHash:X.string().optional(),signature:X.string().optional(),sealedAt:X.string().optional(),verifiedAt:X.string().optional()}),hE={languages:[],frameworks:[],configFiles:[],fileCount:0,patterns:[],antiPatterns:[],analyzedAt:new Date().toISOString(),status:"draft"},hy={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"]};l(yy,"verifyFrameworks");l(wy,"verifyLanguages");l(ky,"verifyPatternLocations");l(Sy,"verifyFileCount");l(by,"verifyAntiPatternFiles");l(zu,"semanticVerify");l(Ty,"getProjectExtensions");l(vy,"countProjectFiles")});import{createHash as qu}from"node:crypto";function wr(r){return qu("sha256").update(r).digest("hex")}function mo(r){return wr(r).slice(0,16)}function Ku(r){return qu("md5").update(r).digest("hex")}var wn=S(()=>{"use strict";l(wr,"sha256");l(mo,"sha256Short");l(Ku,"md5")});var ga,ws,fa=S(()=>{"use strict";Te();ie();K();ga=class{static{l(this,"SyncEventBus")}async publish(e){let t=A.getSyncPendingPath(e.projectId),s=await xe(t,[])??[];s.push(e),await le(t,s)}async getPending(e){let t=A.getSyncPendingPath(e);return await xe(t,[])??[]}async clearPending(e){let t=A.getSyncPendingPath(e);await le(t,[])}async updateLastSync(e){let t=A.getLastSyncPath(e),s={timestamp:T(),success:!0};await le(t,s)}async getLastSync(e){let t=A.getLastSyncPath(e);return await xe(t,null)}},ws=new ga});var qe,is=S(()=>{"use strict";fa();Ms();ie();re();qe=class{static{l(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new dn({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),n=t(s);return await this.write(e,n),n}async publishEvent(e,t,s){let n={type:t,path:[this.filename.replace(".json","")],data:s,timestamp:T(),projectId:e};await ws.publish(n)}async publishEntityEvent(e,t,s,n){let o=`${t}.${s}`,i={...n,timestamp:T()};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 ha,Ke,kn=S(()=>{"use strict";Ju();ca();ie();wn();is();ha=class extends qe{static{l(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"};ma.parse(s),await this.update(e,n=>({...n,draft:s,lastUpdated:T()})),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),n=T(),o={...t.draft,status:"sealed",signature:s,sealedAt:n};return ma.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:n}),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=T();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:Nu(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),n=s.sealed??s.draft;return n?await zu(n,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))}},Ke=new ha});var ya,Cy,Lt,kr=S(()=>{"use strict";ie();re();ya=class{static{l(this,"LLMAnalysisStorage")}save(e,t){let s=C.getDb(e),n=T();s.transaction(()=>{s.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(n),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}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(n=>{let o=JSON.parse(n.analysis);return{id:n.id,commitHash:n.commit_hash,status:n.status,analyzedAt:n.analyzed_at,patternCount:o.patterns.length}})}},Cy=new ya,Lt=Cy});import{z as b}from"zod";var Py,go,Ey,xy,Ry,wa,Yu,Qu,Zu,ed,Xu,Ay,Dy,td,sd,nd,jy,Iy,BE,ka=S(()=>{"use strict";Jr();Py=b.enum(["low","medium","high","critical"]),go=b.enum(["feature","bug","improvement","chore"]),Ey=b.enum(["active","backlog","previously_active"]),xy=b.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),Ry=b.enum(["task_completed","feature_shipped","idea_captured","session_started"]),wa=b.object({title:b.string(),description:b.string(),filesChanged:b.array(b.object({path:b.string(),action:b.enum(["created","modified","deleted"])})),whatWasDone:b.array(b.string()).min(1),outputForNextAgent:b.string().min(1),notes:b.string().optional()}),Yu=b.object({output:b.string().min(1,"Subtask output is required"),summary:wa}),Qu=b.object({id:b.string(),description:b.string(),domain:b.string(),agent:b.string(),status:xy,dependsOn:b.array(b.string()),startedAt:b.string().optional(),completedAt:b.string().optional(),output:b.string().optional(),summary:wa.optional(),skipReason:b.string().optional(),blockReason:b.string().optional(),estimatedPoints:b.number().optional(),estimatedMinutes:b.number().optional()}),Zu=b.object({completed:b.number(),total:b.number(),percentage:b.number()}),ed=b.object({id:b.string(),description:b.string(),type:go.optional(),startedAt:b.string(),sessionId:b.string(),featureId:b.string().optional(),subtasks:b.array(Qu).optional(),currentSubtaskIndex:b.number().optional(),subtaskProgress:Zu.optional(),linearId:b.string().optional(),linearUuid:b.string().optional(),estimatedPoints:b.number().optional(),estimatedMinutes:b.number().optional(),modelMetadata:un.optional(),tokensIn:b.number().optional(),tokensOut:b.number().optional(),parentDescription:b.string().optional(),branch:b.string().optional(),prUrl:b.string().optional()}),Xu=b.object({id:b.string(),description:b.string(),status:b.literal("paused"),startedAt:b.string(),pausedAt:b.string(),pauseReason:b.string().optional(),type:go.optional(),sessionId:b.string().optional(),featureId:b.string().optional(),subtasks:b.array(Qu).optional(),currentSubtaskIndex:b.number().optional(),subtaskProgress:Zu.optional(),linearId:b.string().optional(),linearUuid:b.string().optional(),estimatedPoints:b.number().optional(),estimatedMinutes:b.number().optional(),modelMetadata:un.optional(),tokensIn:b.number().optional(),tokensOut:b.number().optional()}),Ay=b.object({stackConfirmed:b.array(b.string()).optional(),patternsDiscovered:b.array(b.string()).optional(),agentAccuracy:b.array(b.object({agent:b.string(),rating:b.enum(["helpful","neutral","inaccurate"]),note:b.string().optional()})).optional(),issuesEncountered:b.array(b.string()).optional()}),Dy=b.object({taskId:b.string(),title:b.string(),classification:go,startedAt:b.string(),completedAt:b.string(),subtaskCount:b.number(),subtaskSummaries:b.array(wa),outcome:b.string(),branchName:b.string(),linearId:b.string().optional(),linearUuid:b.string().optional(),prUrl:b.string().optional(),feedback:Ay.optional(),tokensIn:b.number().optional(),tokensOut:b.number().optional()}),td=b.object({currentTask:ed.nullable(),previousTask:Xu.nullable().optional(),pausedTasks:b.array(Xu).optional(),taskHistory:b.array(Dy).optional(),lastUpdated:b.string()}),sd=b.object({id:b.string(),description:b.string(),priority:Py,type:go,featureId:b.string().optional(),originFeature:b.string().optional(),completed:b.boolean(),completedAt:b.string().optional(),createdAt:b.string(),section:Ey,agent:b.string().optional(),groupName:b.string().optional(),groupId:b.string().optional()}),nd=b.object({tasks:b.array(sd),lastUpdated:b.string()}),jy=b.object({tasksToday:b.number(),tasksThisWeek:b.number(),streak:b.number(),velocity:b.string(),avgDuration:b.string()}),Iy=b.object({type:Ry,description:b.string(),timestamp:b.string(),duration:b.string().optional()}),BE=b.object({projectId:b.string(),currentTask:ed.nullable(),queue:b.array(sd),stats:jy,recentActivity:b.array(Iy),lastSync:b.string()})});var Sr,Sa,Gs,ba=S(()=>{"use strict";Sr={idle:{transitions:["task","next"],prompt:"p. task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"p. done Complete task | p. pause Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"p. resume Continue | p. task <new> Start different | p. ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","next","pause","reopen"],prompt:"p. ship Ship it | p. task <next> Start next | p. reopen Reopen for rework",description:"Task completed"},shipped:{transitions:["task","next"],prompt:"p. task <description> Start new task",description:"Feature shipped"}},Sa=class{static{l(this,"WorkflowStateMachine")}getCurrentState(e){let t=e?.currentTask;if(!t)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof t.status=="string"?t.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 t?"working":"idle"}}canTransition(e,t){let s=Sr[e];if(s.transitions.includes(t))return{valid:!0};let n=s.transitions.map(o=>`p. ${o}`).join(", ");return{valid:!1,error:`Cannot run 'p. ${t}' in ${e} state`,suggestion:`Valid commands: ${n}`}}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";case"next":return e;default:return e}}getStateInfo(e){return Sr[e]}getPrompt(e){return Sr[e].prompt}getValidCommands(e){return Sr[e].transitions}formatNextSteps(e){return Sr[e].transitions.map(s=>{switch(s){case"task":return"p. task <desc> Start new task";case"done":return"p. done Complete current task";case"pause":return"p. pause Pause and switch context";case"resume":return"p. resume Continue paused task";case"ship":return"p. ship Ship the feature";case"reopen":return"p. reopen Reopen for rework";case"next":return"p. next View task queue";default:return`p. ${s}`}})}},Gs=new Sa});var as,Ta,Mt,Ws=S(()=>{"use strict";It();ie();re();as={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},Ta=class{static{l(this,"ArchiveStorage")}archive(e,t){let s=ye(),n=T();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,n,t.reason),s}archiveMany(e,t){if(t.length===0)return 0;let s=T();return C.transaction(e,n=>{let o=n.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(ye(),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 n of t){let o=n.entity_type;o in s&&(s[o]=n.count),s.total+=n.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(),n=this.getTotalCount(e);C.run(e,"DELETE FROM archives WHERE archived_at < ?",s);let o=this.getTotalCount(e);return n-o}getTotalCount(e){return C.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},Mt=new Ta});var va,_,Pt=S(()=>{"use strict";It();ka();ie();ba();Ws();is();va=class extends qe{static{l(this,"StateStorage")}constructor(){super("state.json",td)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let s=Gs.getCurrentState(e),n=Gs.canTransition(s,t);if(!n.valid)throw new Error(`${n.error}. ${n.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async startTask(e,t){let s=await this.read(e);this.validateTransition(s,"task");let n={...t,startedAt:T()};return await this.update(e,o=>({...o,currentTask:n,lastUpdated:T()})),await this.publishEvent(e,"task.started",{taskId:n.id,description:n.description,startedAt:n.startedAt,sessionId:n.sessionId}),n}async updateCurrentTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;let n={...s.currentTask,...t};return await this.update(e,o=>({...o,currentTask:n,lastUpdated:T()})),n}async completeTask(e,t){let s=await this.read(e),n=s.currentTask;if(!n)return null;this.validateTransition(s,"done");let o=T(),i=this.createTaskHistoryEntry(n,o,t),a=this.getTaskHistoryFromState(s),c=[i,...a].slice(0,this.maxTaskHistory);return await this.update(e,u=>({...u,currentTask:null,previousTask:null,taskHistory:c,lastUpdated:o})),await this.publishEvent(e,"task.completed",{taskId:n.id,description:n.description,startedAt:n.startedAt,completedAt:o}),n}createTaskHistoryEntry(e,t,s){let n=(e.subtasks||[]).filter(a=>a.status==="completed"&&a.summary).map(a=>a.summary),o=n.length>0?n.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:n,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 n={...s.currentTask,status:"paused",pausedAt:T(),pauseReason:t},o=this.getPausedTasksFromState(s),i=[n,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:T()})),await this.publishEvent(e,"task.paused",{taskId:n.id,description:n.description,pausedAt:n.pausedAt,reason:t,pausedCount:i.length}),n}async resumeTask(e,t){let s=await this.read(e),n=this.getPausedTasksFromState(s);if(n.length===0)return null;this.validateTransition(s,"resume");let o=0;if(t&&(o=n.findIndex(g=>g.id===t),o===-1))return null;let i=n[o],a=n.filter((g,h)=>h!==o),{status:c,pausedAt:u,pauseReason:p,...m}=i,d={...m,startedAt:T(),sessionId:i.sessionId??ye()};return await this.update(e,g=>({...g,currentTask:d,previousTask:null,pausedTasks:a,lastUpdated:T()})),await this.publishEvent(e,"task.resumed",{taskId:d.id,description:d.description,resumedAt:d.startedAt,remainingPaused:a.length}),d}getPausedTasksFromState(e){return 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),n=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return s.filter(o=>new Date(o.pausedAt).getTime()<n)}async archiveStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),n=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=s.filter(a=>new Date(a.pausedAt).getTime()<n),i=s.filter(a=>new Date(a.pausedAt).getTime()>=n);if(o.length===0)return[];Mt.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:T()}));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:[],lastUpdated:T()}))}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(d=>d.feedback),n=[],o=[],i=[],a=[];for(let d of s){let g=d.feedback;g.stackConfirmed&&n.push(...g.stackConfirmed),g.patternsDiscovered&&o.push(...g.patternsDiscovered),g.agentAccuracy&&i.push(...g.agentAccuracy),g.issuesEncountered&&a.push(...g.issuesEncountered)}let c=[...new Set(n)],u=[...new Set(o)],p=new Map;for(let d of a)p.set(d,(p.get(d)||0)+1);let m=[...p.entries()].filter(([d,g])=>g>=2).map(([d])=>d);return{stackConfirmed:c,patternsDiscovered:u,agentAccuracy:i,issuesEncountered:[...new Set(a)],knownGotchas:m}}async addTokens(e,t,s){let n=await this.read(e);if(!n.currentTask)return null;let o=(n.currentTask.tokensIn||0)+t,i=(n.currentTask.tokensOut||0)+s;return await this.update(e,a=>({...a,currentTask:{...a.currentTask,tokensIn:o,tokensOut:i},lastUpdated:T()})),{tokensIn:o,tokensOut:i}}async createSubtasks(e,t){let s=await this.read(e);if(!s.currentTask)return;let n=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?T():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:n,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:n.length,percentage:0}},lastUpdated:T()})),await this.publishEvent(e,"subtasks.created",{taskId:s.currentTask.id,subtaskCount:n.length,subtasks:n.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let s=Yu.safeParse(t);if(!s.success){let h=s.error.issues.map(k=>`${k.path.join(".")}: ${k.message}`);throw new Error(`Subtask completion requires handoff data:
382
412
  ${h.join(`
383
- `)}`)}let{output:n,summary:o}=s.data,i=await this.read(e);if(!i.currentTask?.subtasks)return null;let a=i.currentTask.currentSubtaskIndex||0,c=i.currentTask.subtasks[a];if(!c)return null;let u=[...i.currentTask.subtasks];u[a]={...c,status:"completed",completedAt:v(),output:n,summary:o};let p=u.filter(h=>h.status==="completed").length,m=u.length,d=Math.round(p/m*100),g=a+1;return g<u.length&&(u[g]={...u[g],status:"in_progress",startedAt:v()}),await this.update(e,h=>({...h,currentTask:{...h.currentTask,subtasks:u,currentSubtaskIndex:g<m?g:a,subtaskProgress:{completed:p,total:m,percentage:d}},lastUpdated:v()})),await this.publishEvent(e,"subtask.completed",{taskId:i.currentTask.id,subtaskId:c.id,description:c.description,output:n,handoff:o.outputForNextAgent,filesChanged:o.filesChanged.length,progress:{completed:p,total:m,percentage:d}}),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 n=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[n];if(!o)return null;let i=[...s.currentTask.subtasks];i[n]={...o,status:"failed",completedAt:v(),output:`Failed: ${t}`};let a=n+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:v()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,p=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:n,subtaskProgress:{completed:u,total:c,percentage:p}},lastUpdated:v()})),await this.publishEvent(e,"subtask.failed",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,error:t}),a<c?i[a]:null}async skipSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let n=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[n];if(!o)return null;let i=[...s.currentTask.subtasks];i[n]={...o,status:"skipped",completedAt:v(),output:`Skipped: ${t}`,skipReason:t};let a=n+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:v()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,p=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:n,subtaskProgress:{completed:u,total:c,percentage:p}},lastUpdated:v()})),await this.publishEvent(e,"subtask.skipped",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,reason:t}),a<c?i[a]:null}async blockSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let n=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[n];if(!o)return null;let i=[...s.currentTask.subtasks];i[n]={...o,status:"blocked",output:`Blocked: ${t}`,blockReason:t};let a=n+1,c=i.length;return a<c&&(i[a]={...i[a],status:"in_progress",startedAt:v()}),await this.update(e,u=>({...u,currentTask:{...u.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:n},lastUpdated:v()})),await this.publishEvent(e,"subtask.blocked",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,blocker:t}),a<c?i[a]:null}},_=new ba});import td from"node:fs/promises";import sd from"node:path";async function nd(r,e,t,s){let[n,o,i,a]=await Promise.all([jy(r,e,s),Iy(r),$y(r),My(r)]);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,Ay).map(c=>({message:c.message,date:c.date})),hasChanges:t.hasChanges,weeklyCommits:t.weeklyCommits},codeSamples:n,existingPatterns:o,taskHistory:i,previousAnalysis:a??void 0}}async function jy(r,e,t){let s=[],n=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=Gu(r,n,va*2);for(let a of o){if(s.length>=va)break;try{let c=sd.join(e,a.path),u=await td.readFile(c,"utf-8");u.length>uo*3?s.push({path:a.path,content:`${u.slice(0,uo)}
384
- // ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):s.push({path:a.path,content:u.slice(0,uo),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>=va)break;if(!s.some(c=>c.path===a))try{let c=sd.join(e,a),u=await td.readFile(c,"utf-8");s.push({path:a,content:u.slice(0,uo),reason:"entry point"})}catch{}}return s}async function Iy(r){try{let e=await qe.getActive(r);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 $y(r){try{return(await _.getTaskHistory(r)).slice(0,Dy).map(t=>({description:t.title,status:t.classification,branch:t.branchName}))}catch{return[]}}function My(r){try{let e=Kt.getActiveSummary(r);return Promise.resolve(e)}catch(e){return W.debug("Failed to get previous LLM analysis summary",{error:e}),Promise.resolve(null)}}var uo,va,Ay,Dy,rd=S(()=>{"use strict";la();wn();kr();Pt();ns();uo=3e3,va=15,Ay=15,Dy=10;l(nd,"buildAnalysisPayload");l(jy,"selectCodeSamples");l(Iy,"getExistingPatterns");l($y,"getTaskHistory");l(My,"getPreviousAnalysisSummary")});var po=S(()=>{"use strict"});import cs from"chalk";function od(r){return Math.ceil(r.length/4)}function id(r){let e=r.split(`
413
+ `)}`)}let{output:n,summary:o}=s.data,i=await this.read(e);if(!i.currentTask?.subtasks)return null;let a=i.currentTask.currentSubtaskIndex||0,c=i.currentTask.subtasks[a];if(!c)return null;let u=[...i.currentTask.subtasks];u[a]={...c,status:"completed",completedAt:T(),output:n,summary:o};let p=u.filter(h=>h.status==="completed").length,m=u.length,d=Math.round(p/m*100),g=a+1;return g<u.length&&(u[g]={...u[g],status:"in_progress",startedAt:T()}),await this.update(e,h=>({...h,currentTask:{...h.currentTask,subtasks:u,currentSubtaskIndex:g<m?g:a,subtaskProgress:{completed:p,total:m,percentage:d}},lastUpdated:T()})),await this.publishEvent(e,"subtask.completed",{taskId:i.currentTask.id,subtaskId:c.id,description:c.description,output:n,handoff:o.outputForNextAgent,filesChanged:o.filesChanged.length,progress:{completed:p,total:m,percentage:d}}),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 n=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[n];if(!o)return null;let i=[...s.currentTask.subtasks];i[n]={...o,status:"failed",completedAt:T(),output:`Failed: ${t}`};let a=n+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:T()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,p=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:n,subtaskProgress:{completed:u,total:c,percentage:p}},lastUpdated:T()})),await this.publishEvent(e,"subtask.failed",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,error:t}),a<c?i[a]:null}async skipSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let n=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[n];if(!o)return null;let i=[...s.currentTask.subtasks];i[n]={...o,status:"skipped",completedAt:T(),output:`Skipped: ${t}`,skipReason:t};let a=n+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:T()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,p=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:n,subtaskProgress:{completed:u,total:c,percentage:p}},lastUpdated:T()})),await this.publishEvent(e,"subtask.skipped",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,reason:t}),a<c?i[a]:null}async blockSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let n=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[n];if(!o)return null;let i=[...s.currentTask.subtasks];i[n]={...o,status:"blocked",output:`Blocked: ${t}`,blockReason:t};let a=n+1,c=i.length;return a<c&&(i[a]={...i[a],status:"in_progress",startedAt:T()}),await this.update(e,u=>({...u,currentTask:{...u.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:n},lastUpdated:T()})),await this.publishEvent(e,"subtask.blocked",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,blocker:t}),a<c?i[a]:null}},_=new va});import rd from"node:fs/promises";import od from"node:path";async function id(r,e,t,s){let[n,o,i,a]=await Promise.all([_y(r,e,s),Oy(r),Ny(r),Ly(r)]);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,$y).map(c=>({message:c.message,date:c.date})),hasChanges:t.hasChanges,weeklyCommits:t.weeklyCommits},codeSamples:n,existingPatterns:o,taskHistory:i,previousAnalysis:a??void 0}}async function _y(r,e,t){let s=[],n=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=Bu(r,n,Ca*2);for(let a of o){if(s.length>=Ca)break;try{let c=od.join(e,a.path),u=await rd.readFile(c,"utf-8");u.length>fo*3?s.push({path:a.path,content:`${u.slice(0,fo)}
414
+ // ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):s.push({path:a.path,content:u.slice(0,fo),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>=Ca)break;if(!s.some(c=>c.path===a))try{let c=od.join(e,a),u=await rd.readFile(c,"utf-8");s.push({path:a,content:u.slice(0,fo),reason:"entry point"})}catch{}}return s}async function Oy(r){try{let e=await Ke.getActive(r);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 Ny(r){try{return(await _.getTaskHistory(r)).slice(0,My).map(t=>({description:t.title,status:t.classification,branch:t.branchName}))}catch{return[]}}function Ly(r){try{let e=Lt.getActiveSummary(r);return Promise.resolve(e)}catch(e){return V.debug("Failed to get previous LLM analysis summary",{error:e}),Promise.resolve(null)}}var fo,Ca,$y,My,ad=S(()=>{"use strict";da();kn();kr();Pt();ns();fo=3e3,Ca=15,$y=15,My=10;l(id,"buildAnalysisPayload");l(_y,"selectCodeSamples");l(Oy,"getExistingPatterns");l(Ny,"getTaskHistory");l(Ly,"getPreviousAnalysisSummary")});var ho=S(()=>{"use strict"});import cs from"chalk";function cd(r){return Math.ceil(r.length/4)}function ld(r){let e=r.split(`
385
415
  `),t=[],s=null;for(let n=0;n<e.length;n++){let o=e[n],i=o.match(/^(#{1,3})\s+(.+)$/);i?(s&&(s.endLine=n-1,t.push(s)),s={name:i[2].trim(),content:o,startLine:n,endLine:n}):s&&(s.content+=`
386
- ${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Ta(r){return r.includes("<!-- prjct:preserve")}function ad(r,e){let t=id(r),s=id(e),n={hasChanges:!1,added:[],modified:[],removed:[],preserved:[],tokensBefore:od(r),tokensAfter:od(e),tokenDelta:0};n.tokenDelta=n.tokensAfter-n.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)Ta(a.content)&&n.preserved.push({name:a.name,lineCount:a.content.split(`
387
- `).length});for(let a of s){let c=a.name.toLowerCase(),u=o.get(c);u?u.content.trim()!==a.content.trim()&&(Ta(u.content)||(n.modified.push({name:a.name,type:"modified",before:u.content,after:a.content,lineCount:a.content.split(`
416
+ ${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Pa(r){return r.includes("<!-- prjct:preserve")}function ud(r,e){let t=ld(r),s=ld(e),n={hasChanges:!1,added:[],modified:[],removed:[],preserved:[],tokensBefore:cd(r),tokensAfter:cd(e),tokenDelta:0};n.tokenDelta=n.tokensAfter-n.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)Pa(a.content)&&n.preserved.push({name:a.name,lineCount:a.content.split(`
417
+ `).length});for(let a of s){let c=a.name.toLowerCase(),u=o.get(c);u?u.content.trim()!==a.content.trim()&&(Pa(u.content)||(n.modified.push({name:a.name,type:"modified",before:u.content,after:a.content,lineCount:a.content.split(`
388
418
  `).length}),n.hasChanges=!0)):(n.added.push({name:a.name,type:"added",after:a.content,lineCount:a.content.split(`
389
- `).length}),n.hasChanges=!0)}for(let a of t){let c=a.name.toLowerCase();!i.has(c)&&!Ta(a.content)&&(n.removed.push({name:a.name,type:"removed",before:a.content,lineCount:a.content.split(`
390
- `).length}),n.hasChanges=!0)}return n}function cd(r,e={}){let{colorize:t=!0}=e,s=[],n=t?cs.green:d=>d,o=t?cs.red:d=>d,i=t?cs.yellow:d=>d,a=t?cs.dim:d=>d,c=t?cs.bold:d=>d;if(!r.hasChanges)return s.push(a("No changes detected (context is up to date)")),s.join(`
419
+ `).length}),n.hasChanges=!0)}for(let a of t){let c=a.name.toLowerCase();!i.has(c)&&!Pa(a.content)&&(n.removed.push({name:a.name,type:"removed",before:a.content,lineCount:a.content.split(`
420
+ `).length}),n.hasChanges=!0)}return n}function dd(r,e={}){let{colorize:t=!0}=e,s=[],n=t?cs.green:d=>d,o=t?cs.red:d=>d,i=t?cs.yellow:d=>d,a=t?cs.dim:d=>d,c=t?cs.bold:d=>d;if(!r.hasChanges)return s.push(a("No changes detected (context is up to date)")),s.join(`
391
421
  `);if(s.push(""),s.push(c("\u{1F4CB} Changes to context files:")),s.push(""),r.added.length>0)for(let d of r.added)s.push(n(`+ \u2502 + ${d.name} (new)`));if(r.modified.length>0)for(let d of r.modified)s.push(i(`~ \u2502 ${d.name} (modified)`));if(r.removed.length>0)for(let d of r.removed)s.push(o(`- \u2502 - ${d.name} (removed)`));if(r.preserved.length>0){s.push(""),s.push(a(" ## Your Customizations"));for(let d of r.preserved)s.push(a(` \u2502 \u2713 ${d.name} (${d.lineCount} lines preserved)`))}s.push(""),s.push(a("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"));let u=[];r.added.length>0&&u.push(n(`+${r.added.length} added`)),r.modified.length>0&&u.push(i(`~${r.modified.length} modified`)),r.removed.length>0&&u.push(o(`-${r.removed.length} removed`)),s.push(`Summary: ${u.join(", ")||"no changes"}`);let p=r.tokenDelta>=0?"+":"",m=r.tokenDelta>=0?n:o;return s.push(`Tokens: ${r.tokensBefore.toLocaleString()} \u2192 ${r.tokensAfter.toLocaleString()} (${m(p+r.tokenDelta.toLocaleString())})`),s.push(""),s.join(`
392
- `)}function ld(r,e={}){let{colorize:t=!0}=e,s=[],n=t?cs.green:c=>c,o=t?cs.red:c=>c,i=t?cs.cyan:c=>c,a=t?cs.dim:c=>c;for(let c of r.added){if(s.push(i(`@@ +${c.name} @@`)),c.after)for(let u of c.after.split(`
422
+ `)}function pd(r,e={}){let{colorize:t=!0}=e,s=[],n=t?cs.green:c=>c,o=t?cs.red:c=>c,i=t?cs.cyan:c=>c,a=t?cs.dim:c=>c;for(let c of r.added){if(s.push(i(`@@ +${c.name} @@`)),c.after)for(let u of c.after.split(`
393
423
  `))s.push(n(`+ ${u}`));s.push("")}for(let c of r.modified){if(s.push(i(`@@ ${c.name} @@`)),c.before){for(let u of c.before.split(`
394
424
  `).slice(0,5))s.push(o(`- ${u}`));c.before.split(`
395
425
  `).length>5&&s.push(a(` ... ${c.before.split(`
@@ -400,17 +430,17 @@ ${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Ta(r){return r.incl
400
430
  `).slice(0,5))s.push(o(`- ${u}`));c.before.split(`
401
431
  `).length>5&&s.push(a(` ... ${c.before.split(`
402
432
  `).length-5} more lines`))}s.push("")}return s.join(`
403
- `)}var ud=S(()=>{"use strict";po();l(od,"estimateTokens");l(id,"parseMarkdownSections");l(Ta,"isPreservedSection");l(ad,"generateSyncDiff");l(cd,"formatDiffPreview");l(ld,"formatFullDiff")});var dd,pd,Ca,md,gd=S(()=>{"use strict";or();ce();Ms();oe();dd=50,pd=200,Ca=class{static{l(this,"SessionTracker")}async read(e){try{return P.getDoc(e,"session-tracker")??this.getDefault()}catch{return this.getDefault()}}async write(e,t){P.setDoc(e,"session-tracker",t)}getDefault(){return{current:null,config:{idleTimeoutMs:18e5}}}isExpired(e,t){return fs(e.lastActivity,t)}async touch(e){let t=await this.read(e),s=v();if(t.current&&!this.isExpired(t.current,t.config.idleTimeoutMs))return t.current.lastActivity=s,await this.write(e,t),t.current;let n={id:crypto.randomUUID(),projectId:e,status:"active",createdAt:s,lastActivity:s,commands:[],files:[]};return t.current=n,await this.write(e,t),n}async trackCommand(e,t,s){let n=await this.read(e);if(!n.current)return;let o=v();n.current.lastActivity=o,n.current.commands.push({command:t,timestamp:o,durationMs:s}),n.current.commands.length>dd&&(n.current.commands=n.current.commands.slice(-dd)),await this.write(e,n)}async trackFile(e,t,s){let n=await this.read(e);if(!n.current)return;let o=v();n.current.lastActivity=o,n.current.files.push({path:t,operation:s,timestamp:o}),n.current.files.length>pd&&(n.current.files=n.current.files.slice(-pd)),await this.write(e,n)}async getInfo(e){let t=await this.read(e);if(!t.current||this.isExpired(t.current,t.config.idleTimeoutMs))return{active:!1,id:null,duration:null,idleSince:null,idleMs:0,expiresIn:null,commandCount:0,commands:[],filesRead:0,filesWritten:0};let s=t.current,n=Date.now(),o=new Date(s.createdAt).getTime(),i=new Date(s.lastActivity).getTime(),a=n-i,c=t.config.idleTimeoutMs,u=Math.max(0,c-a),p=s.commands.map(g=>g.command),m=new Set(s.files.filter(g=>g.operation==="read").map(g=>g.path)).size,d=new Set(s.files.filter(g=>g.operation==="write").map(g=>g.path)).size;return{active:!0,id:s.id,duration:ft(n-o),idleSince:s.lastActivity,idleMs:a,expiresIn:ft(u),commandCount:s.commands.length,commands:p,filesRead:m,filesWritten:d}}async expire(e){let t=await this.read(e);t.current&&(t.current.status="expired",t.current=null,await this.write(e,t))}async expireIfStale(e){let t=await this.read(e);return t.current&&this.isExpired(t.current,t.config.idleTimeoutMs)?(t.current=null,await this.write(e,t),!0):!1}},md=new Ca});var _y,Pa,mo,Ea=S(()=>{"use strict";ce();V();Ue();gd();_y={commitThreshold:10,dayThreshold:3,significantFiles:["package.json","tsconfig.json","Cargo.toml","go.mod","requirements.txt","pyproject.toml",".env.example","docker-compose.yml","Dockerfile"]},Pa=class{static{l(this,"StalenessChecker")}projectPath;config;constructor(e,t={}){this.projectPath=e,this.config={..._y,...t}}async check(e){let t={isStale:!1,reason:null,lastSyncCommit:null,currentCommit:null,commitsSinceSync:0,daysSinceSync:0,changedFiles:[],significantChanges:[]};try{let s={};try{let c=P.getDoc(e,"project");if(!c)return t.isStale=!0,t.reason="No sync history found. Run `prjct sync` to initialize.",t;s=c}catch{return t.isStale=!0,t.reason="No sync history found. Run `prjct sync` to initialize.",t}t.lastSyncCommit=s.lastSyncCommit||null;let n=s.lastSync;try{let{stdout:c}=await N("git rev-parse --short HEAD",{cwd:this.projectPath});t.currentCommit=c.trim()}catch{return t.reason="Not a git repository",t}if(!t.lastSyncCommit)return t.isStale=!0,t.reason="No sync commit recorded. Run `prjct sync` to track.",t;if(t.lastSyncCommit===t.currentCommit)return t.reason="Context is up to date",t;let o=this.projectPath,[i,a]=await Promise.all([N(`git rev-list --count ${t.lastSyncCommit}..HEAD`,{cwd:o}).catch(()=>null),N(`git diff --name-only ${t.lastSyncCommit}..HEAD`,{cwd:o}).catch(()=>null)]);if(!i)return t.isStale=!0,t.reason="Sync commit no longer exists (history changed). Run `prjct sync`.",t;if(t.commitsSinceSync=parseInt(i.stdout.trim(),10)||0,t.changedFiles=a?a.stdout.trim().split(`
404
- `).filter(Boolean):[],n){let c=new Date(n),u=new Date;t.daysSinceSync=Math.floor((u.getTime()-c.getTime())/(1e3*60*60*24))}return t.significantChanges=t.changedFiles.filter(c=>this.config.significantFiles.some(u=>c.endsWith(u)||c.includes(u))),t.commitsSinceSync>=this.config.commitThreshold?(t.isStale=!0,t.reason=`${t.commitsSinceSync} commits since last sync (threshold: ${this.config.commitThreshold})`):t.daysSinceSync>=this.config.dayThreshold?(t.isStale=!0,t.reason=`${t.daysSinceSync} days since last sync (threshold: ${this.config.dayThreshold})`):t.significantChanges.length>0?(t.isStale=!0,t.reason=`Significant files changed: ${t.significantChanges.join(", ")}`):t.commitsSinceSync>0?t.reason=`${t.commitsSinceSync} commits since sync (threshold: ${this.config.commitThreshold})`:t.reason="Context is up to date",t}catch(s){return t.reason=`Error checking staleness: ${y(s)}`,t}}formatStatus(e){let t=[];e.isStale?t.push("CLAUDE.md status: \u26A0\uFE0F STALE"):t.push("CLAUDE.md status: \u2713 Fresh");let s=[];if(e.lastSyncCommit&&s.push(`Last sync: ${e.lastSyncCommit}`),e.currentCommit&&s.push(`Current: ${e.currentCommit}`),e.commitsSinceSync>0&&s.push(`Commits since: ${e.commitsSinceSync}`),e.daysSinceSync>0&&s.push(`Days since: ${e.daysSinceSync}`),e.changedFiles.length>0&&s.push(`Files changed: ${e.changedFiles.length}`),s.length>0){let n=Math.max(...s.map(i=>i.length)),o="\u2500".repeat(n+2);t.push(`\u250C${o}\u2510`);for(let i of s)t.push(`\u2502 ${i.padEnd(n)} \u2502`);t.push(`\u2514${o}\u2518`)}if(e.significantChanges.length>0){t.push(""),t.push("Significant changes:");for(let n of e.significantChanges.slice(0,5))t.push(` \u2022 ${n}`);e.significantChanges.length>5&&t.push(` ... and ${e.significantChanges.length-5} more`)}return e.reason&&(t.push(""),t.push(e.reason)),e.isStale&&(t.push(""),t.push("Run `prjct sync` to update context")),t.join(`
405
- `)}async getSessionInfo(e){return md.getInfo(e)}formatSessionInfo(e){let t=[];if(!e.active)return t.push("Session: \u25CB No active session"),t.join(`
433
+ `)}var md=S(()=>{"use strict";ho();l(cd,"estimateTokens");l(ld,"parseMarkdownSections");l(Pa,"isPreservedSection");l(ud,"generateSyncDiff");l(dd,"formatDiffPreview");l(pd,"formatFullDiff")});var gd,fd,Ea,hd,yd=S(()=>{"use strict";or();re();Ms();ie();gd=50,fd=200,Ea=class{static{l(this,"SessionTracker")}async read(e){try{return C.getDoc(e,"session-tracker")??this.getDefault()}catch{return this.getDefault()}}async write(e,t){C.setDoc(e,"session-tracker",t)}getDefault(){return{current:null,config:{idleTimeoutMs:18e5}}}isExpired(e,t){return fs(e.lastActivity,t)}async touch(e){let t=await this.read(e),s=T();if(t.current&&!this.isExpired(t.current,t.config.idleTimeoutMs))return t.current.lastActivity=s,await this.write(e,t),t.current;let n={id:crypto.randomUUID(),projectId:e,status:"active",createdAt:s,lastActivity:s,commands:[],files:[]};return t.current=n,await this.write(e,t),n}async trackCommand(e,t,s){let n=await this.read(e);if(!n.current)return;let o=T();n.current.lastActivity=o,n.current.commands.push({command:t,timestamp:o,durationMs:s}),n.current.commands.length>gd&&(n.current.commands=n.current.commands.slice(-gd)),await this.write(e,n)}async trackFile(e,t,s){let n=await this.read(e);if(!n.current)return;let o=T();n.current.lastActivity=o,n.current.files.push({path:t,operation:s,timestamp:o}),n.current.files.length>fd&&(n.current.files=n.current.files.slice(-fd)),await this.write(e,n)}async getInfo(e){let t=await this.read(e);if(!t.current||this.isExpired(t.current,t.config.idleTimeoutMs))return{active:!1,id:null,duration:null,idleSince:null,idleMs:0,expiresIn:null,commandCount:0,commands:[],filesRead:0,filesWritten:0};let s=t.current,n=Date.now(),o=new Date(s.createdAt).getTime(),i=new Date(s.lastActivity).getTime(),a=n-i,c=t.config.idleTimeoutMs,u=Math.max(0,c-a),p=s.commands.map(g=>g.command),m=new Set(s.files.filter(g=>g.operation==="read").map(g=>g.path)).size,d=new Set(s.files.filter(g=>g.operation==="write").map(g=>g.path)).size;return{active:!0,id:s.id,duration:ht(n-o),idleSince:s.lastActivity,idleMs:a,expiresIn:ht(u),commandCount:s.commands.length,commands:p,filesRead:m,filesWritten:d}}async expire(e){let t=await this.read(e);t.current&&(t.current.status="expired",t.current=null,await this.write(e,t))}async expireIfStale(e){let t=await this.read(e);return t.current&&this.isExpired(t.current,t.config.idleTimeoutMs)?(t.current=null,await this.write(e,t),!0):!1}},hd=new Ea});var Uy,xa,yo,Ra=S(()=>{"use strict";re();W();He();yd();Uy={commitThreshold:10,dayThreshold:3,significantFiles:["package.json","tsconfig.json","Cargo.toml","go.mod","requirements.txt","pyproject.toml",".env.example","docker-compose.yml","Dockerfile"]},xa=class{static{l(this,"StalenessChecker")}projectPath;config;constructor(e,t={}){this.projectPath=e,this.config={...Uy,...t}}async check(e){let t={isStale:!1,reason:null,lastSyncCommit:null,currentCommit:null,commitsSinceSync:0,daysSinceSync:0,changedFiles:[],significantChanges:[]};try{let s={};try{let c=C.getDoc(e,"project");if(!c)return t.isStale=!0,t.reason="No sync history found. Run `prjct sync` to initialize.",t;s=c}catch{return t.isStale=!0,t.reason="No sync history found. Run `prjct sync` to initialize.",t}t.lastSyncCommit=s.lastSyncCommit||null;let n=s.lastSync;try{let{stdout:c}=await O("git rev-parse --short HEAD",{cwd:this.projectPath});t.currentCommit=c.trim()}catch{return t.reason="Not a git repository",t}if(!t.lastSyncCommit)return t.isStale=!0,t.reason="No sync commit recorded. Run `prjct sync` to track.",t;if(t.lastSyncCommit===t.currentCommit)return t.reason="Context is up to date",t;let o=this.projectPath,[i,a]=await Promise.all([O(`git rev-list --count ${t.lastSyncCommit}..HEAD`,{cwd:o}).catch(()=>null),O(`git diff --name-only ${t.lastSyncCommit}..HEAD`,{cwd:o}).catch(()=>null)]);if(!i)return t.isStale=!0,t.reason="Sync commit no longer exists (history changed). Run `prjct sync`.",t;if(t.commitsSinceSync=parseInt(i.stdout.trim(),10)||0,t.changedFiles=a?a.stdout.trim().split(`
434
+ `).filter(Boolean):[],n){let c=new Date(n),u=new Date;t.daysSinceSync=Math.floor((u.getTime()-c.getTime())/(1e3*60*60*24))}return t.significantChanges=t.changedFiles.filter(c=>this.config.significantFiles.some(u=>c.endsWith(u)||c.includes(u))),t.commitsSinceSync>=this.config.commitThreshold?(t.isStale=!0,t.reason=`${t.commitsSinceSync} commits since last sync (threshold: ${this.config.commitThreshold})`):t.daysSinceSync>=this.config.dayThreshold?(t.isStale=!0,t.reason=`${t.daysSinceSync} days since last sync (threshold: ${this.config.dayThreshold})`):t.significantChanges.length>0?(t.isStale=!0,t.reason=`Significant files changed: ${t.significantChanges.join(", ")}`):t.commitsSinceSync>0?t.reason=`${t.commitsSinceSync} commits since sync (threshold: ${this.config.commitThreshold})`:t.reason="Context is up to date",t}catch(s){return t.reason=`Error checking staleness: ${w(s)}`,t}}formatStatus(e){let t=[];e.isStale?t.push("CLAUDE.md status: \u26A0\uFE0F STALE"):t.push("CLAUDE.md status: \u2713 Fresh");let s=[];if(e.lastSyncCommit&&s.push(`Last sync: ${e.lastSyncCommit}`),e.currentCommit&&s.push(`Current: ${e.currentCommit}`),e.commitsSinceSync>0&&s.push(`Commits since: ${e.commitsSinceSync}`),e.daysSinceSync>0&&s.push(`Days since: ${e.daysSinceSync}`),e.changedFiles.length>0&&s.push(`Files changed: ${e.changedFiles.length}`),s.length>0){let n=Math.max(...s.map(i=>i.length)),o="\u2500".repeat(n+2);t.push(`\u250C${o}\u2510`);for(let i of s)t.push(`\u2502 ${i.padEnd(n)} \u2502`);t.push(`\u2514${o}\u2518`)}if(e.significantChanges.length>0){t.push(""),t.push("Significant changes:");for(let n of e.significantChanges.slice(0,5))t.push(` \u2022 ${n}`);e.significantChanges.length>5&&t.push(` ... and ${e.significantChanges.length-5} more`)}return e.reason&&(t.push(""),t.push(e.reason)),e.isStale&&(t.push(""),t.push("Run `prjct sync` to update context")),t.join(`
435
+ `)}async getSessionInfo(e){return hd.getInfo(e)}formatSessionInfo(e){let t=[];if(!e.active)return t.push("Session: \u25CB No active session"),t.join(`
406
436
  `);t.push(`Session: \u25B6 Active (${e.duration})`);let s=[];if(e.commandCount>0){let n=new Set,o=[];for(let i of e.commands)n.has(i)||(n.add(i),o.push(i));s.push(`Commands: ${o.join(" \u2192 ")} (${e.commandCount} total)`)}if((e.filesRead>0||e.filesWritten>0)&&s.push(`Files: ${e.filesRead} read, ${e.filesWritten} written`),s.push(`Idle: ${e.expiresIn} until timeout`),s.length>0){let n=Math.max(...s.map(i=>i.length)),o="\u2500".repeat(n+2);t.push(`\u250C${o}\u2510`);for(let i of s)t.push(`\u2502 ${i.padEnd(n)} \u2502`);t.push(`\u2514${o}\u2518`)}return t.join(`
407
- `)}getWarning(e){return e.isStale?e.commitsSinceSync>0?`\u26A0\uFE0F Context stale (${e.commitsSinceSync} commits behind). Run \`prjct sync\``:e.daysSinceSync>0?`\u26A0\uFE0F Context stale (${e.daysSinceSync} days old). Run \`prjct sync\``:"\u26A0\uFE0F Context may be stale. Run `prjct sync`":null}},mo=l((r,e)=>new Pa(r,e),"createStalenessChecker")});import fd from"node:fs/promises";import Sn from"node:path";function Ny(r){let e=[],t,s=new RegExp(Zl.source,"g");for(;(t=s.exec(r))!==null;){let n=t[1];(n.startsWith(".")||n.startsWith("@/"))&&e.push(n)}return e}async function Ly(r,e,t){let s;if(r.startsWith("@/"))s=Sn.join(t,"src",r.slice(2));else{let n=Sn.dirname(Sn.join(t,e));s=Sn.resolve(n,r)}for(let n of Ql){let o=s+n;try{if((await fd.stat(o)).isFile())return Sn.relative(t,o)}catch{}}return null}async function Fy(r){let e=await Is(r),t={},s={},n=0,o=await $s(e,50,async i=>{try{let a=await fd.readFile(Sn.join(r,i),"utf-8"),c=Ny(a),u=[];for(let p of c){let m=await Ly(p,i,r);m&&m!==i&&u.push(m)}return u.length>0?{filePath:i,imports:u}:null}catch{return null}});for(let{filePath:i,imports:a}of o){t[i]=a,n+=a.length;for(let c of a)s[c]||(s[c]=[]),s[c].push(i)}return{forward:t,reverse:s,fileCount:e.length,edgeCount:n,builtAt:new Date().toISOString()}}function Uy(r,e){F.setDoc(r,hd,e)}function go(r){return F.getDoc(r,hd)}async function yd(r,e){let t=await Fy(r);return Uy(e,t),t}var hd,xa=S(()=>{"use strict";Mi();ce();q();l(Ny,"extractImportSources");l(Ly,"resolveImport");l(Fy,"buildGraph");hd="import-graph";l(Uy,"saveGraph");l(go,"loadGraph");l(yd,"indexImports")});function wd(r,e){let t=[...r.added,...r.modified],s=new Set(t),n=new Set,o=go(e);if(o)for(let c of t){let u=o.reverse[c];if(u)for(let p of u)s.has(p)||n.add(p)}let i=Array.from(n),a=[...t,...i];return{directlyChanged:t,affectedByImports:i,deleted:r.deleted,allAffected:a}}function kd(r){let e=new Set;for(let t of r){let s=t.toLowerCase();(s.endsWith(".tsx")||s.endsWith(".jsx")||s.endsWith(".css")||s.endsWith(".scss")||s.endsWith(".vue")||s.endsWith(".svelte")||s.includes("/components/")||s.includes("/pages/")||s.includes("/app/"))&&(e.add("frontend"),e.add("uxui")),(s.includes(".test.")||s.includes(".spec.")||s.includes("__tests__")||s.includes("/test/"))&&e.add("testing"),(s.includes("dockerfile")||s.includes("docker-compose")||s.includes(".dockerignore")||s.includes(".github/")||s.includes("ci/")||s.includes("cd/"))&&e.add("devops"),(s.endsWith(".sql")||s.includes("prisma")||s.includes("drizzle")||s.includes("migration")||s.includes("/db/"))&&e.add("database"),(s.endsWith(".ts")||s.endsWith(".js"))&&!s.includes(".test.")&&!s.includes(".spec.")&&!s.endsWith(".d.ts")&&e.add("backend")}return e}var Sd=S(()=>{"use strict";xa();l(wd,"propagateChanges");l(kd,"affectedDomains")});import bd from"node:fs/promises";import Hy from"node:path";function Gy(r){if(typeof Bun<"u"&&Bun.hash)return`xxh64:${Bun.hash(r).toString(36)}`;let e=2166136261;for(let t=0;t<r.length;t++)e^=r.charCodeAt(t),e=Math.imul(e,16777619);return`fnv1a:${(e>>>0).toString(36)}`}async function Vy(r){let e=await Is(r,{skipDotfiles:!0,dotfileAllowlist:[".env.example"]}),t=new Map,s=await $s(e,100,async n=>{try{let o=Hy.join(r,n),[i,a]=await Promise.all([bd.readFile(o,"utf-8"),bd.stat(o)]);return{path:n,hash:Gy(i),size:a.size,mtime:a.mtime.toISOString()}}catch{return null}});for(let n of s)t.set(n.path,n);return t}function Wy(r,e){let t=[],s=[],n=[];for(let[i,a]of r){let c=e.get(i);c?c.hash!==a.hash?s.push(i):n.push(i):t.push(i)}let o=[];for(let i of e.keys())r.has(i)||o.push(i);return{added:t,modified:s,deleted:o,unchanged:n}}function Ra(r,e){let t=F.getDb(r);t.transaction(()=>{t.prepare("DELETE FROM index_checksums").run();let s=t.prepare("INSERT INTO index_checksums (path, checksum, size, mtime) VALUES (?, ?, ?, ?)");for(let[,n]of e)s.run(n.path,n.hash,n.size,n.mtime)})(),F.setDoc(r,"file-hashes-meta",{fileCount:e.size,builtAt:new Date().toISOString()})}function By(r){let e=new Map;try{let t=F.query(r,"SELECT path, checksum, size, mtime FROM index_checksums");for(let s of t)e.set(s.path,{path:s.path,hash:s.checksum,size:s.size||0,mtime:s.mtime||""})}catch{}return e}async function Aa(r,e){let[t,s]=await Promise.all([Vy(r),Promise.resolve(By(e))]);return{diff:Wy(t,s),currentHashes:t}}function vd(r){return F.hasDoc(r,"file-hashes-meta")}var Td=S(()=>{"use strict";ce();q();l(Gy,"hashContent");l(Vy,"computeHashes");l(Wy,"diffHashes");l(Ra,"saveHashes");l(By,"loadHashes");l(Aa,"detectChanges");l(vd,"hasHashRegistry")});async function zy(r,e=100){try{let{stdout:t}=await N(`git log --name-only --pretty=format:'---COMMIT---' -${e}`,{cwd:r,maxBuffer:10485760}),s=[],n=null;for(let o of t.split(`
408
- `)){let i=o.trim();i==="---COMMIT---"?(n&&n.size>0&&n.size<=30&&s.push(n),n=new Set):i&&n&&qy(i)&&n.add(i)}return n&&n.size>0&&n.size<=30&&s.push(n),s}catch{return[]}}function qy(r){return/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java|cs|rb|php|vue|svelte)$/i.test(r)&&!r.includes("node_modules/")}async function Ky(r,e=100){let t=await zy(r,e),s=new Map,n=new Map;for(let i of t){let a=Array.from(i);for(let c of a)s.set(c,(s.get(c)||0)+1);for(let c=0;c<a.length;c++)for(let u=c+1;u<a.length;u++){let p=Xy(a[c],a[u]);n.set(p,(n.get(p)||0)+1)}}let o={};for(let[i,a]of n){let[c,u]=i.split("\0"),p=s.get(c)||0,m=s.get(u)||0;if(p<2||m<2)continue;let d=p+m-a,g=d>0?a/d:0;g<.1||(o[c]||(o[c]={}),o[u]||(o[u]={}),o[c][u]=g,o[u][c]=g)}return{matrix:o,commitsAnalyzed:t.length,filesAnalyzed:s.size,builtAt:new Date().toISOString()}}function Xy(r,e){return r<e?`${r}\0${e}`:`${e}\0${r}`}function Yy(r,e){F.setDoc(r,Ed,e)}function xd(r){return F.getDoc(r,Ed)}async function Rd(r,e,t=100){let s=await Ky(r,t);return Yy(e,s),s}var Ed,Ad=S(()=>{"use strict";yr();ce();Ue();l(zy,"parseGitLog");l(qy,"isSourceFile");l(Ky,"buildMatrix");l(Xy,"pairKey");Ed="cochange-index";l(Yy,"saveMatrix");l(xd,"loadMatrix");l(Rd,"indexCoChanges")});async function fo(r){try{let{stdout:e}=await N(r,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function Qy(){let r=await fo("gh api user --jq .login");return r.success&&r.output||(r=await fo("git config --global github.user"),r.success&&r.output)?r.output:null}async function Zy(){let r=await fo("git config user.name");return r.success&&r.output?r.output:null}async function ew(){let r=await fo("git config user.email");return r.success&&r.output?r.output:null}async function bn(){let[r,e,t]=await Promise.all([Qy(),Zy(),ew()]);return{github:r,email:t,name:e||r||"Unknown"}}var ho=S(()=>{"use strict";Ue();l(fo,"execCommand");l(Qy,"detectGitHubUsername");l(Zy,"detectGitName");l(ew,"detectGitEmail");l(bn,"detect")});import ja from"node:fs/promises";import tw from"node:path";import*as yo from"jsonc-parser";function Dd(r){let e=[],t=yo.parse(r,e,{allowTrailingComma:!0,disallowComments:!1});if(e.length>0){let s=e[0];throw new SyntaxError(`JSON parse error at offset ${s.offset}: ${yo.printParseErrorCode(s.error)}`)}return t}var Ia,sw,I,Et=S(()=>{"use strict";ss();V();oe();q();Ct();ho();ve();l(Dd,"parseJsonc");Ia=class{static{l(this,"ConfigManager")}async readConfig(e){try{let t=A.getLocalConfigPath(e),s=await ja.readFile(t,"utf-8");return Dd(s)}catch(t){return R(t)||console.warn(`Warning: Could not read config at ${e}: ${ue(t)}`),null}}async writeConfig(e,t){let s=A.getLocalConfigPath(e);await le(s,t)}async readGlobalConfig(e){try{let t=A.getGlobalProjectConfigPath(e),s=await ja.readFile(t,"utf-8");return Dd(s)}catch(t){return R(t)||console.warn(`Warning: Could not read global config for ${e}: ${ue(t)}`),null}}async writeGlobalConfig(e,t){let s=A.getGlobalProjectConfigPath(e);await le(s,t)}async ensureGlobalConfig(e){let t=await this.readGlobalConfig(e);if(!t){let s=v();t={projectId:e,authors:[],version:Ae,lastSync:s},await this.writeGlobalConfig(e,t)}return t}async createConfig(e,t){let s=A.generateProjectId(e),n=A.getGlobalProjectPath(s),o=A.getDisplayPath(n),i=v(),a={projectId:s,dataPath:o,showMetrics:!0};await this.writeConfig(e,a);let c={projectId:s,authors:[{name:t.name||"Unknown",email:t.email||"",github:t.github||"",firstContribution:i,lastActivity:i}],version:Ae,created:i,lastSync:i};return await this.writeGlobalConfig(s,c),a}async updateLastSync(e){let t=await this.getProjectId(e),s=await this.readGlobalConfig(t);s&&(s.lastSync=v(),await this.writeGlobalConfig(t,s))}validateConfig(e){return!(!e||!e.projectId||!e.dataPath)}async needsMigration(e){if(!await A.hasLegacyStructure(e))return!1;if(!await A.hasConfig(e))return!0;let n=await this.readConfig(e);if(!n||!n.projectId)return!0;let o=A.getGlobalProjectPath(n.projectId);try{return(await ja.readdir(tw.join(o,"core"))).length===0}catch(i){return R(i),!0}}async getProjectId(e){let t=await this.readConfig(e);return t?.projectId?t.projectId:A.generateProjectId(e)}async findAuthor(e,t){let s=await this.readGlobalConfig(e);return!s||!s.authors?null:s.authors.find(n=>n.github===t)||null}async addAuthor(e,t){let s=await this.ensureGlobalConfig(e);if(s.authors.some(i=>i.github===t.github))return;let o=v();s.authors.push({name:t.name||"Unknown",email:t.email||"",github:t.github||"",firstContribution:o,lastActivity:o}),s.lastSync=o,await this.writeGlobalConfig(e,s)}async updateAuthorActivity(e,t){let s=await this.readGlobalConfig(e);if(!s||!s.authors)return;let n=s.authors.find(o=>o.github===t);n&&(n.lastActivity=v(),s.lastSync=n.lastActivity,await this.writeGlobalConfig(e,s))}async getCurrentAuthor(e){let t=await bn(),s=await this.getProjectId(e);return await this.addAuthor(s,{name:t.name??void 0,email:t.email??void 0,github:t.github??void 0}),t.github||t.name||"Unknown"}async isConfigured(e){let t=await this.readConfig(e);return this.validateConfig(t)}async getShowMetrics(e){return(await this.readConfig(e))?.showMetrics??!0}async setShowMetrics(e,t){let s=await this.readConfig(e);s&&(s.showMetrics=t,await this.writeConfig(e,s))}async getConfigWithDefaults(e){let t=await this.readConfig(e);if(t)return t;let s=A.generateProjectId(e);return{projectId:s,dataPath:A.getDisplayPath(A.getGlobalProjectPath(s))}}},sw=new Ia,I=sw});import Md from"node:fs/promises";import jd from"node:os";import $a from"node:path";function rw(){let r=yt("mcp-config.json");if(!r)return{mcpServers:{context7:Ma}};try{return JSON.parse(r)}catch{return{mcpServers:{context7:Ma}}}}function Od(){return rw().mcpServers?.context7||Ma}function Id(){return process.env.PRJCT_CONTEXT7_CONFIG?process.env.PRJCT_CONTEXT7_CONFIG:process.env.NODE_ENV==="test"?$a.join(jd.tmpdir(),"prjct-context7-test","mcp.json"):$a.join(jd.homedir(),".claude","mcp.json")}async function $d(r){try{let e=await Md.readFile(r,"utf-8");return JSON.parse(e)}catch(e){if(R(e))return{};throw e}}async function ow(){if(process.env.PRJCT_SKIP_CONTEXT7_SMOKE==="1"||process.env.NODE_ENV==="test")return;let r=Od(),e=[...r.args||[],"--help"];await _i(r.command||"npx",e,{timeout:15e3})}var Ma,vn,Oa,iw,ls,br=S(()=>{"use strict";Hs();or();V();Ue();q();Ma={command:"npx",args:["-y","@upstash/context7-mcp@latest"]},vn=null;l(rw,"parseTemplateConfig");l(Od,"getContext7Config");l(Id,"getConfigPath");l($d,"readConfig");l(ow,"runSmokeCheck");Oa=class{static{l(this,"Context7Service")}async install(){let e=Id(),t=$a.dirname(e);await Md.mkdir(t,{recursive:!0});let s=await $d(e),n=s.mcpServers||{};return n.context7=Od(),s.mcpServers=n,await le(e,s),vn=null,{installed:!0,verified:!1,configPath:e,message:"Context7 MCP configured"}}async verify(){if(vn&&Date.now()-vn.at<3e5)return vn.status;let e=Id(),n=((await $d(e)).mcpServers||{}).context7;if(!n?.command||!Array.isArray(n.args)||n.args.length===0)return{installed:!1,verified:!1,configPath:e,message:"Context7 MCP not configured in ~/.claude/mcp.json"};try{await ow();let o={installed:!0,verified:!0,configPath:e};return vn={at:Date.now(),status:o},o}catch(o){let i={installed:!0,verified:!1,configPath:e,message:`Context7 smoke check failed: ${y(o)}`};return vn={at:Date.now(),status:i},i}}async ensureReady(){await this.install();let e=await this.verify();if(!e.verified){let t=e.message||"Context7 MCP is required but not ready. Run `prjct start` to repair configuration.";throw new Error(t)}return e}},iw=new Oa,ls=iw});var wo,_a=S(()=>{"use strict";wo={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 Na(r,e){return{...wo[r],...e}}function ko(r,e,t){return{message:r,hint:e,...t}}var So=S(()=>{"use strict";_a();_a();l(Na,"getError");l(ko,"createError")});import{execSync as La}from"node:child_process";var bo,Fa,vo,_d,Nd=S(()=>{"use strict";Ms();So();bo={git:{name:"git",command:"git --version",versionRegex:/git version ([\d.]+)/,required:!0,installHint:"Install Git: https://git-scm.com/downloads",docs:"https://git-scm.com/doc"},node:{name:"node",command:"node --version",versionRegex:/v([\d.]+)/,required:!0,installHint:"Install Node.js: https://nodejs.org",docs:"https://nodejs.org/docs"},bun:{name:"bun",command:"bun --version",versionRegex:/([\d.]+)/,required:!1,installHint:"Install Bun: curl -fsSL https://bun.sh/install | bash",docs:"https://bun.sh/docs"},gh:{name:"gh",command:"gh --version",versionRegex:/gh version ([\d.]+)/,required:!1,installHint:"Install GitHub CLI: https://cli.github.com",docs:"https://cli.github.com/manual"},npm:{name:"npm",command:"npm --version",versionRegex:/([\d.]+)/,required:!1,installHint:"npm comes with Node.js: https://nodejs.org"},claude:{name:"claude",command:"claude --version",versionRegex:/claude ([\d.]+)/,required:!1,installHint:"Install Claude Code: npm install -g @anthropic-ai/claude-code",docs:"https://docs.anthropic.com/claude-code"},gemini:{name:"gemini",command:"gemini --version",versionRegex:/gemini ([\d.]+)/,required:!1,installHint:"Install Gemini CLI: npm install -g @google/gemini-cli",docs:"https://ai.google.dev/gemini-api/docs"}},Fa=class{static{l(this,"DependencyValidator")}cache=new Map;cacheTimeout=6e4;cacheTimestamps=new Map;checkTool(e){let t=this.getCached(e);if(t)return t;let s=bo[e];if(!s)return this.checkUnknownTool(e);let n=this.executeCheck(s);return this.setCache(e,n),n}ensureTool(e){let t=this.checkTool(e);if(!t.available){let s=bo[e],n=t.error||{message:`${e} is not available`,hint:s?.installHint||`Install ${e} and try again`,docs:s?.docs};throw new vo(n)}}ensureTools(e){let t=[];for(let s of e)this.checkTool(s).available||t.push(s);if(t.length>0){let s=t.map(n=>{let o=bo[n];return o?` ${n}: ${o.installHint}`:` ${n}: Install and try again`}).join(`
409
- `);throw new vo({message:`Missing required tools: ${t.join(", ")}`,hint:`Install the following:
410
- ${s}`})}}isAvailable(e){return this.checkTool(e).available}getVersion(e){return this.checkTool(e).version}checkAll(e){let t=e||Object.keys(bo),s=new Map;for(let n of t)s.set(n,this.checkTool(n));return s}clearCache(){this.cache.clear(),this.cacheTimestamps.clear()}executeCheck(e){try{let t=La(e.command,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),s;if(e.versionRegex){let n=t.match(e.versionRegex);s=n?n[1]:void 0}return{available:!0,version:s}}catch{return{available:!1,error:ko(`${e.name} is not installed or not in PATH`,e.installHint,{docs:e.docs})}}}checkUnknownTool(e){try{return La(`${e} --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{try{return La(`${e} -v`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{return{available:!1,error:ko(`${e} is not installed or not in PATH`,`Install ${e} and try again`)}}}}getCached(e){let t=this.cacheTimestamps.get(e);return t?fs(t,this.cacheTimeout)?(this.cache.delete(e),this.cacheTimestamps.delete(e),null):this.cache.get(e)||null:null}setCache(e,t){this.cache.set(e,t),this.cacheTimestamps.set(e,Date.now())}},vo=class extends Error{static{l(this,"DependencyError")}hint;docs;constructor(e){super(e.message),this.name="DependencyError",this.hint=e.hint,this.docs=e.docs}},_d=new Fa});function Tn(r){let e=`PRJCT_TIMEOUT_${r}`,t=process.env[e];if(t){let s=Number.parseInt(t,10);if(!Number.isNaN(s)&&s>0)return s}return aw[r]}var ie,Ua,Ha,To,aw,Nt,Ld,Ws=S(()=>{"use strict";ie={GATHERING:"gathering",ANALYZING:"analyzing",PROPOSING:"proposing",PENDING_APPROVAL:"awaiting_approval",APPROVED:"approved",REJECTED:"rejected",EXECUTING:"executing",COMPLETED:"completed",ABORTED:"aborted"},Ua=["feature","spec","design","refactor","migrate"],Ha=["ship","cleanup","git","migrate"],To=["Read","Glob","Grep","GetTimestamp","GetDate","GetDateTime"],aw={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};l(Tn,"getTimeout");Nt={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},Ld={HISTORY_MAX:100}});import Ga from"node:fs/promises";import cw from"node:os";import Fd from"node:path";var Va,lw,Co,Wa=S(()=>{"use strict";V();q();Va=class{static{l(this,"EditorsConfig")}homeDir;configDir;configFile;constructor(){this.homeDir=cw.homedir(),this.configDir=Fd.join(this.homeDir,".prjct-cli","config"),this.configFile=Fd.join(this.configDir,"installed-editors.json")}async ensureConfigDir(){try{await Ga.mkdir(this.configDir,{recursive:!0})}catch(e){console.error("[editors-config] Error creating config directory:",y(e))}}async loadConfig(){try{let e=await Ga.readFile(this.configFile,"utf-8");return JSON.parse(e)}catch(e){return e.code==="ENOENT"||console.error("[editors-config] Error loading config:",y(e)),null}}async saveConfig(e,t,s="claude"){try{await this.ensureConfigDir();let n={version:e,provider:s,lastInstall:new Date().toISOString(),path:t};return await le(this.configFile,n),!0}catch(n){return console.error("[editors-config] Error saving config:",y(n)),!1}}async getProvider(){let e=await this.loadConfig();return e?e.provider||"claude":null}async getLastVersion(){let e=await this.loadConfig();return e?e.version:null}async hasVersionChanged(e){let t=await this.getLastVersion();return t!==null&&t!==e}async updateVersion(e){try{let t=await this.loadConfig();return t?(t.version=e,t.lastInstall=new Date().toISOString(),await le(this.configFile,t),!0):!1}catch(t){return console.error("[editors-config] Error updating version:",y(t)),!1}}async configExists(){return C(this.configFile)}async deleteConfig(){try{return await this.configExists()&&await Ga.unlink(this.configFile),!0}catch(e){return console.error("[editors-config] Error deleting config:",y(e)),!1}}},lw=new Va,Co=lw});var Ja={};Bt(Ja,{installAntigravitySkill:()=>Wd,installCodexSkill:()=>Ba,needsAntigravityInstallation:()=>gw,run:()=>Vd,verifyCodexPRouterReady:()=>Eo});import{execSync as uw}from"node:child_process";import Q from"node:fs/promises";import Bs from"node:os";import ae from"node:path";import fe from"chalk";async function dw(r){let e=r.name==="claude"?"@anthropic-ai/claude-code":"@google/gemini-cli";if(!_d.isAvailable("npm"))return console.log(`${fe.yellow("\u26A0\uFE0F npm is not available")}`),console.log(""),console.log(`${fe.dim(`Install ${r.displayName} using one of:`)}`),console.log(fe.dim(" \u2022 Install Node.js: https://nodejs.org")),console.log(fe.dim(` \u2022 Use Homebrew: brew install ${r.name==="claude"?"claude":"gemini"}`)),console.log(fe.dim(` \u2022 Use npx directly: npx ${e}`)),console.log(""),!1;try{return console.log(fe.yellow(`\u{1F4E6} ${r.displayName} not found. Installing...`)),console.log(""),uw(`npm install -g ${e}`,{stdio:"inherit",timeout:Tn("NPM_INSTALL")}),console.log(""),console.log(`${fe.green("\u2713")} ${r.displayName} installed successfully`),console.log(""),!0}catch(t){let s=t;return s.killed&&s.signal==="SIGTERM"?(console.log(fe.yellow(`\u26A0\uFE0F Installation timed out for ${r.displayName}`)),console.log(""),console.log(fe.dim("The npm install took too long. Try:")),console.log(fe.dim(" \u2022 Set PRJCT_TIMEOUT_NPM_INSTALL=300000 for 5 minutes")),console.log(fe.dim(` \u2022 Run manually: npm install -g ${e}`))):console.log(fe.yellow(`\u26A0\uFE0F Failed to install ${r.displayName}: ${s.message}`)),console.log(""),console.log(fe.dim("Alternative installation methods:")),console.log(fe.dim(` \u2022 npm: npm install -g ${e}`)),console.log(fe.dim(` \u2022 yarn: yarn global add ${e}`)),console.log(fe.dim(` \u2022 pnpm: pnpm add -g ${e}`)),console.log(fe.dim(` \u2022 brew: brew install ${r.name==="claude"?"claude":"gemini"}`)),console.log(""),!1}}async function Vd(){let r=await ir(),e=await Ui(),t=pt[e.provider],s={provider:e.provider,providers:[],cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null},n=["claude","gemini"];for(let a of n){let c=pt[a],u=r[a],p={provider:a,cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null};if(!u.installed)if(a===e.provider)if(await dw(c))p.cliInstalled=!0,s.cliInstalled=!0;else throw new Error(`${c.displayName} installation failed`);else continue;if(a==="claude"){if(await De.detectActiveProvider()){let d=await De.syncCommands();d.success&&(p.commandsAdded=d.added,p.commandsUpdated=d.updated,s.commandsAdded+=d.added,s.commandsUpdated+=d.updated);let g=await De.installGlobalConfig();g.success&&(p.configAction=g.action,s.configAction||(s.configAction=g.action)),await De.installDocs(),await ww(),await ls.ensureReady()}}else if(a==="gemini"){await pw()&&(p.commandsAdded=1,s.commandsAdded+=1);let d=await mw();d.success&&(p.configAction=d.action)}s.providers.push(p)}if((await Kr()).installed&&(await Wd()).success&&console.log(` ${fe.green("\u2713")} Antigravity skill installed`),(await Os()).installed){if(!(await Ba()).success)throw new Error("Codex skill installation failed");let c=await Eo({autoRepair:!0});if(!c.verified)throw new Error(c.message||"Codex p. router verification failed");console.log(` ${fe.green("\u2713")} Codex skill installed`),console.log(` ${fe.green("\u2713")} Codex p. router ready`)}await Co.saveConfig(Ae,await De.getInstallPath(),e.provider),await yw();for(let a of s.providers)kw(a,pt[a.provider]);return s}async function pw(){try{let r=ae.join(Bs.homedir(),".gemini","commands"),e=ae.join(r,"p.toml");try{return await Q.unlink(e),!0}catch(t){if(t.code==="ENOENT")return!1;throw t}}catch(r){return W.warn(`Gemini router cleanup warning: ${y(r)}`),!1}}async function mw(){try{let r=ae.join(Bs.homedir(),".gemini"),e=ae.join(r,"GEMINI.md");await Q.mkdir(r,{recursive:!0});let t=yt("global/GEMINI.md");if(!t){let c=ae.join(Qe,"templates","global","GEMINI.md");t=await Q.readFile(c,"utf-8")}let s="",n=!1;try{s=await Q.readFile(e,"utf-8"),n=!0}catch(c){if(R(c))n=!1;else throw c}let a=no(n?s:"",t,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Q.writeFile(e,a.content,"utf-8"),{success:!0,action:a.action}}catch(r){return W.warn(`Gemini config warning: ${y(r)}`),{success:!1,action:null}}}async function Wd(){try{let r=ae.join(Bs.homedir(),".gemini","antigravity","skills"),e=ae.join(r,"prjct"),t=ae.join(e,"SKILL.md");await Q.mkdir(e,{recursive:!0});let s=await C(t),n=yt("antigravity/SKILL.md");if(!n){let o=ae.join(Qe,"templates","antigravity","SKILL.md");if(!await C(o))return W.warn("Antigravity SKILL.md template not found"),{success:!1,action:null};n=await Q.readFile(o,"utf-8")}return await Q.writeFile(t,n,"utf-8"),{success:!0,action:s?"updated":"created"}}catch(r){return W.warn(`Antigravity skill warning: ${y(r)}`),{success:!1,action:null}}}async function gw(){let r=await Kr();return r.installed&&!r.skillInstalled}function Jd(){return ae.join(Bs.homedir(),".codex","skills","prjct","SKILL.md")}function fw(r){return`<!-- ${Bd}: ${JSON.stringify({version:Ae,templateHash:r})} -->`}function Ud(r){let e=r.match(new RegExp(`<!--\\s*${Bd}:\\s*(\\{[\\s\\S]*?\\})\\s*-->`));if(!e)return null;try{return JSON.parse(e[1])}catch{return null}}function hw(r){return wr(r)}async function zd(){let r=yt("codex/SKILL.md");if(r)return r;let e=ae.join(Qe,"templates","codex","SKILL.md");return await C(e)?Q.readFile(e,"utf-8"):null}function qd(r){let e=r.trimEnd(),t=hw(e),s=fw(t);return{content:`${e}
437
+ `)}getWarning(e){return e.isStale?e.commitsSinceSync>0?`\u26A0\uFE0F Context stale (${e.commitsSinceSync} commits behind). Run \`prjct sync\``:e.daysSinceSync>0?`\u26A0\uFE0F Context stale (${e.daysSinceSync} days old). Run \`prjct sync\``:"\u26A0\uFE0F Context may be stale. Run `prjct sync`":null}},yo=l((r,e)=>new xa(r,e),"createStalenessChecker")});import wd from"node:fs/promises";import bn from"node:path";function Hy(r){let e=[],t,s=new RegExp(su.source,"g");for(;(t=s.exec(r))!==null;){let n=t[1];(n.startsWith(".")||n.startsWith("@/"))&&e.push(n)}return e}async function Gy(r,e,t){let s;if(r.startsWith("@/"))s=bn.join(t,"src",r.slice(2));else{let n=bn.dirname(bn.join(t,e));s=bn.resolve(n,r)}for(let n of tu){let o=s+n;try{if((await wd.stat(o)).isFile())return bn.relative(t,o)}catch{}}return null}async function Wy(r){let e=await Is(r),t={},s={},n=0,o=await $s(e,50,async i=>{try{let a=await wd.readFile(bn.join(r,i),"utf-8"),c=Hy(a),u=[];for(let p of c){let m=await Gy(p,i,r);m&&m!==i&&u.push(m)}return u.length>0?{filePath:i,imports:u}:null}catch{return null}});for(let{filePath:i,imports:a}of o){t[i]=a,n+=a.length;for(let c of a)s[c]||(s[c]=[]),s[c].push(i)}return{forward:t,reverse:s,fileCount:e.length,edgeCount:n,builtAt:new Date().toISOString()}}function Vy(r,e){N.setDoc(r,kd,e)}function wo(r){return N.getDoc(r,kd)}async function Sd(r,e){let t=await Wy(r);return Vy(e,t),t}var kd,Aa=S(()=>{"use strict";Ni();re();K();l(Hy,"extractImportSources");l(Gy,"resolveImport");l(Wy,"buildGraph");kd="import-graph";l(Vy,"saveGraph");l(wo,"loadGraph");l(Sd,"indexImports")});function bd(r,e){let t=[...r.added,...r.modified],s=new Set(t),n=new Set,o=wo(e);if(o)for(let c of t){let u=o.reverse[c];if(u)for(let p of u)s.has(p)||n.add(p)}let i=Array.from(n),a=[...t,...i];return{directlyChanged:t,affectedByImports:i,deleted:r.deleted,allAffected:a}}function Td(r){let e=new Set;for(let t of r){let s=t.toLowerCase();(s.endsWith(".tsx")||s.endsWith(".jsx")||s.endsWith(".css")||s.endsWith(".scss")||s.endsWith(".vue")||s.endsWith(".svelte")||s.includes("/components/")||s.includes("/pages/")||s.includes("/app/"))&&(e.add("frontend"),e.add("uxui")),(s.includes(".test.")||s.includes(".spec.")||s.includes("__tests__")||s.includes("/test/"))&&e.add("testing"),(s.includes("dockerfile")||s.includes("docker-compose")||s.includes(".dockerignore")||s.includes(".github/")||s.includes("ci/")||s.includes("cd/"))&&e.add("devops"),(s.endsWith(".sql")||s.includes("prisma")||s.includes("drizzle")||s.includes("migration")||s.includes("/db/"))&&e.add("database"),(s.endsWith(".ts")||s.endsWith(".js"))&&!s.includes(".test.")&&!s.includes(".spec.")&&!s.endsWith(".d.ts")&&e.add("backend")}return e}var vd=S(()=>{"use strict";Aa();l(bd,"propagateChanges");l(Td,"affectedDomains")});import Cd from"node:fs/promises";import By from"node:path";function zy(r){if(typeof Bun<"u"&&Bun.hash)return`xxh64:${Bun.hash(r).toString(36)}`;let e=2166136261;for(let t=0;t<r.length;t++)e^=r.charCodeAt(t),e=Math.imul(e,16777619);return`fnv1a:${(e>>>0).toString(36)}`}async function Jy(r){let e=await Is(r,{skipDotfiles:!0,dotfileAllowlist:[".env.example"]}),t=new Map,s=await $s(e,100,async n=>{try{let o=By.join(r,n),[i,a]=await Promise.all([Cd.readFile(o,"utf-8"),Cd.stat(o)]);return{path:n,hash:zy(i),size:a.size,mtime:a.mtime.toISOString()}}catch{return null}});for(let n of s)t.set(n.path,n);return t}function qy(r,e){let t=[],s=[],n=[];for(let[i,a]of r){let c=e.get(i);c?c.hash!==a.hash?s.push(i):n.push(i):t.push(i)}let o=[];for(let i of e.keys())r.has(i)||o.push(i);return{added:t,modified:s,deleted:o,unchanged:n}}function Da(r,e){let t=N.getDb(r);t.transaction(()=>{t.prepare("DELETE FROM index_checksums").run();let s=t.prepare("INSERT INTO index_checksums (path, checksum, size, mtime) VALUES (?, ?, ?, ?)");for(let[,n]of e)s.run(n.path,n.hash,n.size,n.mtime)})(),N.setDoc(r,"file-hashes-meta",{fileCount:e.size,builtAt:new Date().toISOString()})}function Ky(r){let e=new Map;try{let t=N.query(r,"SELECT path, checksum, size, mtime FROM index_checksums");for(let s of t)e.set(s.path,{path:s.path,hash:s.checksum,size:s.size||0,mtime:s.mtime||""})}catch{}return e}async function ja(r,e){let[t,s]=await Promise.all([Jy(r),Promise.resolve(Ky(e))]);return{diff:qy(t,s),currentHashes:t}}function Pd(r){return N.hasDoc(r,"file-hashes-meta")}var Ed=S(()=>{"use strict";re();K();l(zy,"hashContent");l(Jy,"computeHashes");l(qy,"diffHashes");l(Da,"saveHashes");l(Ky,"loadHashes");l(ja,"detectChanges");l(Pd,"hasHashRegistry")});async function Yy(r,e=100){try{let{stdout:t}=await O(`git log --name-only --pretty=format:'---COMMIT---' -${e}`,{cwd:r,maxBuffer:10485760}),s=[],n=null;for(let o of t.split(`
438
+ `)){let i=o.trim();i==="---COMMIT---"?(n&&n.size>0&&n.size<=30&&s.push(n),n=new Set):i&&n&&Qy(i)&&n.add(i)}return n&&n.size>0&&n.size<=30&&s.push(n),s}catch{return[]}}function Qy(r){return/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java|cs|rb|php|vue|svelte)$/i.test(r)&&!r.includes("node_modules/")}async function Zy(r,e=100){let t=await Yy(r,e),s=new Map,n=new Map;for(let i of t){let a=Array.from(i);for(let c of a)s.set(c,(s.get(c)||0)+1);for(let c=0;c<a.length;c++)for(let u=c+1;u<a.length;u++){let p=ew(a[c],a[u]);n.set(p,(n.get(p)||0)+1)}}let o={};for(let[i,a]of n){let[c,u]=i.split("\0"),p=s.get(c)||0,m=s.get(u)||0;if(p<2||m<2)continue;let d=p+m-a,g=d>0?a/d:0;g<.1||(o[c]||(o[c]={}),o[u]||(o[u]={}),o[c][u]=g,o[u][c]=g)}return{matrix:o,commitsAnalyzed:t.length,filesAnalyzed:s.size,builtAt:new Date().toISOString()}}function ew(r,e){return r<e?`${r}\0${e}`:`${e}\0${r}`}function tw(r,e){N.setDoc(r,Ad,e)}function Dd(r){return N.getDoc(r,Ad)}async function jd(r,e,t=100){let s=await Zy(r,t);return tw(e,s),s}var Ad,Id=S(()=>{"use strict";yr();re();He();l(Yy,"parseGitLog");l(Qy,"isSourceFile");l(Zy,"buildMatrix");l(ew,"pairKey");Ad="cochange-index";l(tw,"saveMatrix");l(Dd,"loadMatrix");l(jd,"indexCoChanges")});async function ko(r){try{let{stdout:e}=await O(r,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function sw(){let r=await ko("gh api user --jq .login");return r.success&&r.output||(r=await ko("git config --global github.user"),r.success&&r.output)?r.output:null}async function nw(){let r=await ko("git config user.name");return r.success&&r.output?r.output:null}async function rw(){let r=await ko("git config user.email");return r.success&&r.output?r.output:null}async function Tn(){let[r,e,t]=await Promise.all([sw(),nw(),rw()]);return{github:r,email:t,name:e||r||"Unknown"}}var So=S(()=>{"use strict";He();l(ko,"execCommand");l(sw,"detectGitHubUsername");l(nw,"detectGitName");l(rw,"detectGitEmail");l(Tn,"detect")});import $a from"node:fs/promises";import ow from"node:path";import*as bo from"jsonc-parser";function $d(r){let e=[],t=bo.parse(r,e,{allowTrailingComma:!0,disallowComments:!1});if(e.length>0){let s=e[0];throw new SyntaxError(`JSON parse error at offset ${s.offset}: ${bo.printParseErrorCode(s.error)}`)}return t}var Ma,iw,$,Et=S(()=>{"use strict";ss();W();ie();K();Ct();So();Te();l($d,"parseJsonc");Ma=class{static{l(this,"ConfigManager")}async readConfig(e){try{let t=A.getLocalConfigPath(e),s=await $a.readFile(t,"utf-8");return $d(s)}catch(t){return R(t)||console.warn(`Warning: Could not read config at ${e}: ${ue(t)}`),null}}async writeConfig(e,t){let s=A.getLocalConfigPath(e);await le(s,t)}async readGlobalConfig(e){try{let t=A.getGlobalProjectConfigPath(e),s=await $a.readFile(t,"utf-8");return $d(s)}catch(t){return R(t)||console.warn(`Warning: Could not read global config for ${e}: ${ue(t)}`),null}}async writeGlobalConfig(e,t){let s=A.getGlobalProjectConfigPath(e);await le(s,t)}async ensureGlobalConfig(e){let t=await this.readGlobalConfig(e);if(!t){let s=T();t={projectId:e,authors:[],version:Ae,lastSync:s},await this.writeGlobalConfig(e,t)}return t}async createConfig(e,t){let s=A.generateProjectId(e),n=A.getGlobalProjectPath(s),o=A.getDisplayPath(n),i=T(),a={projectId:s,dataPath:o,showMetrics:!0};await this.writeConfig(e,a);let c={projectId:s,authors:[{name:t.name||"Unknown",email:t.email||"",github:t.github||"",firstContribution:i,lastActivity:i}],version:Ae,created:i,lastSync:i};return await this.writeGlobalConfig(s,c),a}async updateLastSync(e){let t=await this.getProjectId(e),s=await this.readGlobalConfig(t);s&&(s.lastSync=T(),await this.writeGlobalConfig(t,s))}validateConfig(e){return!(!e||!e.projectId||!e.dataPath)}async needsMigration(e){if(!await A.hasLegacyStructure(e))return!1;if(!await A.hasConfig(e))return!0;let n=await this.readConfig(e);if(!n||!n.projectId)return!0;let o=A.getGlobalProjectPath(n.projectId);try{return(await $a.readdir(ow.join(o,"core"))).length===0}catch(i){return R(i),!0}}async getProjectId(e){let t=await this.readConfig(e);return t?.projectId?t.projectId:A.generateProjectId(e)}async findAuthor(e,t){let s=await this.readGlobalConfig(e);return!s||!s.authors?null:s.authors.find(n=>n.github===t)||null}async addAuthor(e,t){let s=await this.ensureGlobalConfig(e);if(s.authors.some(i=>i.github===t.github))return;let o=T();s.authors.push({name:t.name||"Unknown",email:t.email||"",github:t.github||"",firstContribution:o,lastActivity:o}),s.lastSync=o,await this.writeGlobalConfig(e,s)}async updateAuthorActivity(e,t){let s=await this.readGlobalConfig(e);if(!s||!s.authors)return;let n=s.authors.find(o=>o.github===t);n&&(n.lastActivity=T(),s.lastSync=n.lastActivity,await this.writeGlobalConfig(e,s))}async getCurrentAuthor(e){let t=await Tn(),s=await this.getProjectId(e);return await this.addAuthor(s,{name:t.name??void 0,email:t.email??void 0,github:t.github??void 0}),t.github||t.name||"Unknown"}async isConfigured(e){let t=await this.readConfig(e);return this.validateConfig(t)}async getShowMetrics(e){return(await this.readConfig(e))?.showMetrics??!0}async setShowMetrics(e,t){let s=await this.readConfig(e);s&&(s.showMetrics=t,await this.writeConfig(e,s))}async getConfigWithDefaults(e){let t=await this.readConfig(e);if(t)return t;let s=A.generateProjectId(e);return{projectId:s,dataPath:A.getDisplayPath(A.getGlobalProjectPath(s))}}},iw=new Ma,$=iw});import Nd from"node:fs/promises";import Md from"node:os";import _a from"node:path";function cw(){let r=wt("mcp-config.json");if(!r)return{mcpServers:{context7:Oa}};try{return JSON.parse(r)}catch{return{mcpServers:{context7:Oa}}}}function Ld(){return cw().mcpServers?.context7||Oa}function _d(){return process.env.PRJCT_CONTEXT7_CONFIG?process.env.PRJCT_CONTEXT7_CONFIG:process.env.NODE_ENV==="test"?_a.join(Md.tmpdir(),"prjct-context7-test","mcp.json"):_a.join(Md.homedir(),".claude","mcp.json")}async function Od(r){try{let e=await Nd.readFile(r,"utf-8");return JSON.parse(e)}catch(e){if(R(e))return{};throw e}}async function lw(){if(process.env.PRJCT_SKIP_CONTEXT7_SMOKE==="1"||process.env.NODE_ENV==="test")return;let r=Ld(),e=[...r.args||[],"--help"];await Fi(r.command||"npx",e,{timeout:15e3})}var Oa,vn,Na,uw,ls,br=S(()=>{"use strict";Hs();or();W();He();K();Oa={command:"npx",args:["-y","@upstash/context7-mcp@latest"]},vn=null;l(cw,"parseTemplateConfig");l(Ld,"getContext7Config");l(_d,"getConfigPath");l(Od,"readConfig");l(lw,"runSmokeCheck");Na=class{static{l(this,"Context7Service")}async install(){let e=_d(),t=_a.dirname(e);await Nd.mkdir(t,{recursive:!0});let s=await Od(e),n=s.mcpServers||{};return n.context7=Ld(),s.mcpServers=n,await le(e,s),vn=null,{installed:!0,verified:!1,configPath:e,message:"Context7 MCP configured"}}async verify(){if(vn&&Date.now()-vn.at<3e5)return vn.status;let e=_d(),n=((await Od(e)).mcpServers||{}).context7;if(!n?.command||!Array.isArray(n.args)||n.args.length===0)return{installed:!1,verified:!1,configPath:e,message:"Context7 MCP not configured in ~/.claude/mcp.json"};try{await lw();let o={installed:!0,verified:!0,configPath:e};return vn={at:Date.now(),status:o},o}catch(o){let i={installed:!0,verified:!1,configPath:e,message:`Context7 smoke check failed: ${w(o)}`};return vn={at:Date.now(),status:i},i}}async ensureReady(){await this.install();let e=await this.verify();if(!e.verified){let t=e.message||"Context7 MCP is required but not ready. Run `prjct start` to repair configuration.";throw new Error(t)}return e}},uw=new Na,ls=uw});var To,La=S(()=>{"use strict";To={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 Fa(r,e){return{...To[r],...e}}function vo(r,e,t){return{message:r,hint:e,...t}}var Co=S(()=>{"use strict";La();La();l(Fa,"getError");l(vo,"createError")});import{execSync as Ua}from"node:child_process";var Po,Ha,Eo,Fd,Ud=S(()=>{"use strict";Ms();Co();Po={git:{name:"git",command:"git --version",versionRegex:/git version ([\d.]+)/,required:!0,installHint:"Install Git: https://git-scm.com/downloads",docs:"https://git-scm.com/doc"},node:{name:"node",command:"node --version",versionRegex:/v([\d.]+)/,required:!0,installHint:"Install Node.js: https://nodejs.org",docs:"https://nodejs.org/docs"},bun:{name:"bun",command:"bun --version",versionRegex:/([\d.]+)/,required:!1,installHint:"Install Bun: curl -fsSL https://bun.sh/install | bash",docs:"https://bun.sh/docs"},gh:{name:"gh",command:"gh --version",versionRegex:/gh version ([\d.]+)/,required:!1,installHint:"Install GitHub CLI: https://cli.github.com",docs:"https://cli.github.com/manual"},npm:{name:"npm",command:"npm --version",versionRegex:/([\d.]+)/,required:!1,installHint:"npm comes with Node.js: https://nodejs.org"},claude:{name:"claude",command:"claude --version",versionRegex:/claude ([\d.]+)/,required:!1,installHint:"Install Claude Code: npm install -g @anthropic-ai/claude-code",docs:"https://docs.anthropic.com/claude-code"},gemini:{name:"gemini",command:"gemini --version",versionRegex:/gemini ([\d.]+)/,required:!1,installHint:"Install Gemini CLI: npm install -g @google/gemini-cli",docs:"https://ai.google.dev/gemini-api/docs"}},Ha=class{static{l(this,"DependencyValidator")}cache=new Map;cacheTimeout=6e4;cacheTimestamps=new Map;checkTool(e){let t=this.getCached(e);if(t)return t;let s=Po[e];if(!s)return this.checkUnknownTool(e);let n=this.executeCheck(s);return this.setCache(e,n),n}ensureTool(e){let t=this.checkTool(e);if(!t.available){let s=Po[e],n=t.error||{message:`${e} is not available`,hint:s?.installHint||`Install ${e} and try again`,docs:s?.docs};throw new Eo(n)}}ensureTools(e){let t=[];for(let s of e)this.checkTool(s).available||t.push(s);if(t.length>0){let s=t.map(n=>{let o=Po[n];return o?` ${n}: ${o.installHint}`:` ${n}: Install and try again`}).join(`
439
+ `);throw new Eo({message:`Missing required tools: ${t.join(", ")}`,hint:`Install the following:
440
+ ${s}`})}}isAvailable(e){return this.checkTool(e).available}getVersion(e){return this.checkTool(e).version}checkAll(e){let t=e||Object.keys(Po),s=new Map;for(let n of t)s.set(n,this.checkTool(n));return s}clearCache(){this.cache.clear(),this.cacheTimestamps.clear()}executeCheck(e){try{let t=Ua(e.command,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),s;if(e.versionRegex){let n=t.match(e.versionRegex);s=n?n[1]:void 0}return{available:!0,version:s}}catch{return{available:!1,error:vo(`${e.name} is not installed or not in PATH`,e.installHint,{docs:e.docs})}}}checkUnknownTool(e){try{return Ua(`${e} --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{try{return Ua(`${e} -v`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{return{available:!1,error:vo(`${e} is not installed or not in PATH`,`Install ${e} and try again`)}}}}getCached(e){let t=this.cacheTimestamps.get(e);return t?fs(t,this.cacheTimeout)?(this.cache.delete(e),this.cacheTimestamps.delete(e),null):this.cache.get(e)||null:null}setCache(e,t){this.cache.set(e,t),this.cacheTimestamps.set(e,Date.now())}},Eo=class extends Error{static{l(this,"DependencyError")}hint;docs;constructor(e){super(e.message),this.name="DependencyError",this.hint=e.hint,this.docs=e.docs}},Fd=new Ha});function Cn(r){let e=`PRJCT_TIMEOUT_${r}`,t=process.env[e];if(t){let s=Number.parseInt(t,10);if(!Number.isNaN(s)&&s>0)return s}return dw[r]}var ae,Ga,Wa,xo,dw,Ft,Hd,Vs=S(()=>{"use strict";ae={GATHERING:"gathering",ANALYZING:"analyzing",PROPOSING:"proposing",PENDING_APPROVAL:"awaiting_approval",APPROVED:"approved",REJECTED:"rejected",EXECUTING:"executing",COMPLETED:"completed",ABORTED:"aborted"},Ga=["feature","spec","design","refactor","migrate"],Wa=["ship","cleanup","git","migrate"],xo=["Read","Glob","Grep","GetTimestamp","GetDate","GetDateTime"],dw={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};l(Cn,"getTimeout");Ft={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},Hd={HISTORY_MAX:100}});import Va from"node:fs/promises";import pw from"node:os";import Gd from"node:path";var Ba,mw,Ro,za=S(()=>{"use strict";W();K();Ba=class{static{l(this,"EditorsConfig")}homeDir;configDir;configFile;constructor(){this.homeDir=pw.homedir(),this.configDir=Gd.join(this.homeDir,".prjct-cli","config"),this.configFile=Gd.join(this.configDir,"installed-editors.json")}async ensureConfigDir(){try{await Va.mkdir(this.configDir,{recursive:!0})}catch(e){console.error("[editors-config] Error creating config directory:",w(e))}}async loadConfig(){try{let e=await Va.readFile(this.configFile,"utf-8");return JSON.parse(e)}catch(e){return e.code==="ENOENT"||console.error("[editors-config] Error loading config:",w(e)),null}}async saveConfig(e,t,s="claude"){try{await this.ensureConfigDir();let n={version:e,provider:s,lastInstall:new Date().toISOString(),path:t};return await le(this.configFile,n),!0}catch(n){return console.error("[editors-config] Error saving config:",w(n)),!1}}async getProvider(){let e=await this.loadConfig();return e?e.provider||"claude":null}async getLastVersion(){let e=await this.loadConfig();return e?e.version:null}async hasVersionChanged(e){let t=await this.getLastVersion();return t!==null&&t!==e}async updateVersion(e){try{let t=await this.loadConfig();return t?(t.version=e,t.lastInstall=new Date().toISOString(),await le(this.configFile,t),!0):!1}catch(t){return console.error("[editors-config] Error updating version:",w(t)),!1}}async configExists(){return P(this.configFile)}async deleteConfig(){try{return await this.configExists()&&await Va.unlink(this.configFile),!0}catch(e){return console.error("[editors-config] Error deleting config:",w(e)),!1}}},mw=new Ba,Ro=mw});var qa={};Ot(qa,{installAntigravitySkill:()=>Jd,installCodexSkill:()=>Ja,needsAntigravityInstallation:()=>ww,run:()=>zd,verifyCodexPRouterReady:()=>Do});import{execSync as gw}from"node:child_process";import Z from"node:fs/promises";import Bs from"node:os";import ce from"node:path";import fe from"chalk";async function fw(r){let e=r.name==="claude"?"@anthropic-ai/claude-code":"@google/gemini-cli";if(!Fd.isAvailable("npm"))return console.log(`${fe.yellow("\u26A0\uFE0F npm is not available")}`),console.log(""),console.log(`${fe.dim(`Install ${r.displayName} using one of:`)}`),console.log(fe.dim(" \u2022 Install Node.js: https://nodejs.org")),console.log(fe.dim(` \u2022 Use Homebrew: brew install ${r.name==="claude"?"claude":"gemini"}`)),console.log(fe.dim(` \u2022 Use npx directly: npx ${e}`)),console.log(""),!1;try{return console.log(fe.yellow(`\u{1F4E6} ${r.displayName} not found. Installing...`)),console.log(""),gw(`npm install -g ${e}`,{stdio:"inherit",timeout:Cn("NPM_INSTALL")}),console.log(""),console.log(`${fe.green("\u2713")} ${r.displayName} installed successfully`),console.log(""),!0}catch(t){let s=t;return s.killed&&s.signal==="SIGTERM"?(console.log(fe.yellow(`\u26A0\uFE0F Installation timed out for ${r.displayName}`)),console.log(""),console.log(fe.dim("The npm install took too long. Try:")),console.log(fe.dim(" \u2022 Set PRJCT_TIMEOUT_NPM_INSTALL=300000 for 5 minutes")),console.log(fe.dim(` \u2022 Run manually: npm install -g ${e}`))):console.log(fe.yellow(`\u26A0\uFE0F Failed to install ${r.displayName}: ${s.message}`)),console.log(""),console.log(fe.dim("Alternative installation methods:")),console.log(fe.dim(` \u2022 npm: npm install -g ${e}`)),console.log(fe.dim(` \u2022 yarn: yarn global add ${e}`)),console.log(fe.dim(` \u2022 pnpm: pnpm add -g ${e}`)),console.log(fe.dim(` \u2022 brew: brew install ${r.name==="claude"?"claude":"gemini"}`)),console.log(""),!1}}async function zd(){let r=await ir(),e=await Wi(),t=gt[e.provider],s={provider:e.provider,providers:[],cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null},n=["claude","gemini"];for(let a of n){let c=gt[a],u=r[a],p={provider:a,cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null};if(!u.installed)if(a===e.provider)if(await fw(c))p.cliInstalled=!0,s.cliInstalled=!0;else throw new Error(`${c.displayName} installation failed`);else continue;if(a==="claude"){if(await De.detectActiveProvider()){let d=await De.syncCommands();d.success&&(p.commandsAdded=d.added,p.commandsUpdated=d.updated,s.commandsAdded+=d.added,s.commandsUpdated+=d.updated);let g=await De.installGlobalConfig();g.success&&(p.configAction=g.action,s.configAction||(s.configAction=g.action)),await De.installDocs(),await Tw(),await ls.ensureReady()}}else if(a==="gemini"){await hw()&&(p.commandsAdded=1,s.commandsAdded+=1);let d=await yw();d.success&&(p.configAction=d.action)}s.providers.push(p)}if((await Yr()).installed&&(await Jd()).success&&console.log(` ${fe.green("\u2713")} Antigravity skill installed`),(await _s()).installed){if(!(await Ja()).success)throw new Error("Codex skill installation failed");let c=await Do({autoRepair:!0});if(!c.verified)throw new Error(c.message||"Codex p. router verification failed");console.log(` ${fe.green("\u2713")} Codex skill installed`),console.log(` ${fe.green("\u2713")} Codex p. router ready`)}await Ro.saveConfig(Ae,await De.getInstallPath(),e.provider),await bw();for(let a of s.providers)vw(a,gt[a.provider]);return s}async function hw(){try{let r=ce.join(Bs.homedir(),".gemini","commands"),e=ce.join(r,"p.toml");try{return await Z.unlink(e),!0}catch(t){if(t.code==="ENOENT")return!1;throw t}}catch(r){return V.warn(`Gemini router cleanup warning: ${w(r)}`),!1}}async function yw(){try{let r=ce.join(Bs.homedir(),".gemini"),e=ce.join(r,"GEMINI.md");await Z.mkdir(r,{recursive:!0});let t=wt("global/GEMINI.md");if(!t){let c=ce.join(Ze,"templates","global","GEMINI.md");t=await Z.readFile(c,"utf-8")}let s="",n=!1;try{s=await Z.readFile(e,"utf-8"),n=!0}catch(c){if(R(c))n=!1;else throw c}let a=ao(n?s:"",t,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Z.writeFile(e,a.content,"utf-8"),{success:!0,action:a.action}}catch(r){return V.warn(`Gemini config warning: ${w(r)}`),{success:!1,action:null}}}async function Jd(){try{let r=ce.join(Bs.homedir(),".gemini","antigravity","skills"),e=ce.join(r,"prjct"),t=ce.join(e,"SKILL.md");await Z.mkdir(e,{recursive:!0});let s=await P(t),n=wt("antigravity/SKILL.md");if(!n){let o=ce.join(Ze,"templates","antigravity","SKILL.md");if(!await P(o))return V.warn("Antigravity SKILL.md template not found"),{success:!1,action:null};n=await Z.readFile(o,"utf-8")}return await Z.writeFile(t,n,"utf-8"),{success:!0,action:s?"updated":"created"}}catch(r){return V.warn(`Antigravity skill warning: ${w(r)}`),{success:!1,action:null}}}async function ww(){let r=await Yr();return r.installed&&!r.skillInstalled}function Kd(){return ce.join(Bs.homedir(),".codex","skills","prjct","SKILL.md")}function kw(r){return`<!-- ${qd}: ${JSON.stringify({version:Ae,templateHash:r})} -->`}function Wd(r){let e=r.match(new RegExp(`<!--\\s*${qd}:\\s*(\\{[\\s\\S]*?\\})\\s*-->`));if(!e)return null;try{return JSON.parse(e[1])}catch{return null}}function Sw(r){return wr(r)}async function Xd(){let r=wt("codex/SKILL.md");if(r)return r;let e=ce.join(Ze,"templates","codex","SKILL.md");return await P(e)?Z.readFile(e,"utf-8"):null}function Yd(r){let e=r.trimEnd(),t=Sw(e),s=kw(t);return{content:`${e}
411
441
 
412
442
  ${s}
413
- `,templateHash:t}}async function Ba(){try{let r=Jd(),e=ae.dirname(r);await Q.mkdir(e,{recursive:!0});let t=await C(r),s=await zd();if(!s)return W.warn("Codex SKILL.md template not found"),{success:!1,action:null};let n=qd(s);return t&&await Q.readFile(r,"utf-8").catch(()=>"")===n.content?{success:!0,action:"unchanged"}:(await Q.writeFile(r,n.content,"utf-8"),{success:!0,action:t?"updated":"created"})}catch(r){return W.warn(`Codex skill warning: ${y(r)}`),{success:!1,action:null}}}async function Eo(r={}){let e=Jd();if(!(await Os()).installed)return{installed:!1,verified:!0,skillPath:e,message:"Codex not detected"};let s=await zd();if(!s)return{installed:!0,verified:!1,skillPath:e,message:"Codex SKILL.md template missing from prjct installation",fix:["Reinstall prjct-cli package","Run `prjct setup`"]};let n=qd(s),o=l(async()=>r.autoRepair?(await Ba()).success:!1,"maybeRepair"),i="";if(!await C(e)&&!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:n.templateHash,message:"Codex skill missing at ~/.codex/skills/prjct/SKILL.md",fix:["Run `prjct start` to install Codex skill"]};i=await Q.readFile(e,"utf-8").catch(()=>"");let a=Ud(i);if(!(a?.version===Ae&&a?.templateHash===n.templateHash)){if(!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:n.templateHash,message:"Codex skill metadata mismatch (outdated router)",fix:["Run `prjct start` or `prjct setup` to refresh Codex skill"]};if(i=await Q.readFile(e,"utf-8").catch(()=>""),a=Ud(i),!(a?.version===Ae&&a?.templateHash===n.templateHash))return{installed:!0,verified:!1,skillPath:e,templateHash:n.templateHash,message:"Codex skill could not be repaired automatically",fix:["Delete ~/.codex/skills/prjct/SKILL.md","Run `prjct setup`"]}}return{installed:!0,verified:!0,skillPath:e,templateHash:n.templateHash,message:"Codex p. router ready"}}async function yw(){try{let r=ae.join(Bs.homedir(),".prjct-cli","projects");if(!await C(r))return;let e=(await Q.readdir(r,{withFileTypes:!0})).filter(s=>s.isDirectory()).map(s=>s.name),t=0;for(let s of e)try{let n=P.getDoc(s,"project");if(!n)continue;n.cliVersion!==Ae&&(n.cliVersion=Ae,P.setDoc(s,"project",n),t++)}catch{}t>0&&console.log(` ${fe.green("\u2713")} Updated ${t} project(s) to v${Ae}`)}catch(r){R(r)||W.warn(`Migration warning: ${y(r)}`)}}async function Hd(r,e){let t={};if(await C(r))try{t=await xe(r)??{}}catch(s){if(!(s instanceof SyntaxError))throw s}t.statusLine={type:"command",command:e},await le(r,t)}async function ww(){try{let r=ae.join(Bs.homedir(),".claude"),e=ae.join(r,"settings.json"),t=ae.join(r,"prjct-statusline.sh"),s=ae.join(Bs.homedir(),".prjct-cli","statusline"),n=ae.join(s,"statusline.sh"),o=ae.join(s,"themes"),i=ae.join(s,"lib"),a=ae.join(s,"components"),c=ae.join(s,"config.json"),u=ae.join(Qe,"assets","statusline"),p=ae.join(u,"statusline.sh"),m=ae.join(u,"themes"),d=ae.join(u,"lib"),g=ae.join(u,"components"),h=ae.join(u,"default-config.json");if(await C(r)||await Q.mkdir(r,{recursive:!0}),await C(s)||await Q.mkdir(s,{recursive:!0}),await C(o)||await Q.mkdir(o,{recursive:!0}),await C(i)||await Q.mkdir(i,{recursive:!0}),await C(a)||await Q.mkdir(a,{recursive:!0}),await C(n)){let k=await Q.readFile(n,"utf8");if(k.includes("CLI_VERSION=")){let w=k.match(/CLI_VERSION="([^"]*)"/);if(w&&w[1]!==Ae){let T=k.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${Ae}"`);await Q.writeFile(n,T,{mode:493})}await Po(d,i),await Po(g,a),await Gd(t,n),await Hd(e,t);return}}if(await C(p)){let k=await Q.readFile(p,"utf8");if(k=k.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${Ae}"`),await Q.writeFile(n,k,{mode:493}),await Po(d,i),await Po(g,a),await C(m)){let w=await Q.readdir(m);for(let T of w){let E=ae.join(m,T),M=ae.join(o,T);await Q.copyFile(E,M)}}!await C(c)&&await C(h)&&await Q.copyFile(h,c)}else{let k=`#!/bin/bash
443
+ `,templateHash:t}}async function Ja(){try{let r=Kd(),e=ce.dirname(r);await Z.mkdir(e,{recursive:!0});let t=await P(r),s=await Xd();if(!s)return V.warn("Codex SKILL.md template not found"),{success:!1,action:null};let n=Yd(s);return t&&await Z.readFile(r,"utf-8").catch(()=>"")===n.content?{success:!0,action:"unchanged"}:(await Z.writeFile(r,n.content,"utf-8"),{success:!0,action:t?"updated":"created"})}catch(r){return V.warn(`Codex skill warning: ${w(r)}`),{success:!1,action:null}}}async function Do(r={}){let e=Kd();if(!(await _s()).installed)return{installed:!1,verified:!0,skillPath:e,message:"Codex not detected"};let s=await Xd();if(!s)return{installed:!0,verified:!1,skillPath:e,message:"Codex SKILL.md template missing from prjct installation",fix:["Reinstall prjct-cli package","Run `prjct setup`"]};let n=Yd(s),o=l(async()=>r.autoRepair?(await Ja()).success:!1,"maybeRepair"),i="";if(!await P(e)&&!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:n.templateHash,message:"Codex skill missing at ~/.codex/skills/prjct/SKILL.md",fix:["Run `prjct start` to install Codex skill"]};i=await Z.readFile(e,"utf-8").catch(()=>"");let a=Wd(i);if(!(a?.version===Ae&&a?.templateHash===n.templateHash)){if(!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:n.templateHash,message:"Codex skill metadata mismatch (outdated router)",fix:["Run `prjct start` or `prjct setup` to refresh Codex skill"]};if(i=await Z.readFile(e,"utf-8").catch(()=>""),a=Wd(i),!(a?.version===Ae&&a?.templateHash===n.templateHash))return{installed:!0,verified:!1,skillPath:e,templateHash:n.templateHash,message:"Codex skill could not be repaired automatically",fix:["Delete ~/.codex/skills/prjct/SKILL.md","Run `prjct setup`"]}}return{installed:!0,verified:!0,skillPath:e,templateHash:n.templateHash,message:"Codex p. router ready"}}async function bw(){try{let r=ce.join(Bs.homedir(),".prjct-cli","projects");if(!await P(r))return;let e=(await Z.readdir(r,{withFileTypes:!0})).filter(s=>s.isDirectory()).map(s=>s.name),t=0;for(let s of e)try{let n=C.getDoc(s,"project");if(!n)continue;n.cliVersion!==Ae&&(n.cliVersion=Ae,C.setDoc(s,"project",n),t++)}catch{}t>0&&console.log(` ${fe.green("\u2713")} Updated ${t} project(s) to v${Ae}`)}catch(r){R(r)||V.warn(`Migration warning: ${w(r)}`)}}async function Vd(r,e){let t={};if(await P(r))try{t=await xe(r)??{}}catch(s){if(!(s instanceof SyntaxError))throw s}t.statusLine={type:"command",command:e},await le(r,t)}async function Tw(){try{let r=ce.join(Bs.homedir(),".claude"),e=ce.join(r,"settings.json"),t=ce.join(r,"prjct-statusline.sh"),s=ce.join(Bs.homedir(),".prjct-cli","statusline"),n=ce.join(s,"statusline.sh"),o=ce.join(s,"themes"),i=ce.join(s,"lib"),a=ce.join(s,"components"),c=ce.join(s,"config.json"),u=ce.join(Ze,"assets","statusline"),p=ce.join(u,"statusline.sh"),m=ce.join(u,"themes"),d=ce.join(u,"lib"),g=ce.join(u,"components"),h=ce.join(u,"default-config.json");if(await P(r)||await Z.mkdir(r,{recursive:!0}),await P(s)||await Z.mkdir(s,{recursive:!0}),await P(o)||await Z.mkdir(o,{recursive:!0}),await P(i)||await Z.mkdir(i,{recursive:!0}),await P(a)||await Z.mkdir(a,{recursive:!0}),await P(n)){let k=await Z.readFile(n,"utf8");if(k.includes("CLI_VERSION=")){let y=k.match(/CLI_VERSION="([^"]*)"/);if(y&&y[1]!==Ae){let v=k.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${Ae}"`);await Z.writeFile(n,v,{mode:493})}await Ao(d,i),await Ao(g,a),await Bd(t,n),await Vd(e,t);return}}if(await P(p)){let k=await Z.readFile(p,"utf8");if(k=k.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${Ae}"`),await Z.writeFile(n,k,{mode:493}),await Ao(d,i),await Ao(g,a),await P(m)){let y=await Z.readdir(m);for(let v of y){let D=ce.join(m,v),U=ce.join(o,v);await Z.copyFile(D,U)}}!await P(c)&&await P(h)&&await Z.copyFile(h,c)}else{let k=`#!/bin/bash
414
444
  # prjct Status Line for Claude Code
415
445
  CLI_VERSION="${Ae}"
416
446
  input=$(cat)
@@ -441,7 +471,7 @@ if [ -f "$CONFIG" ]; then
441
471
  fi
442
472
  fi
443
473
  echo "prjct"
444
- `;await Q.writeFile(n,k,{mode:493})}await Gd(t,n),await Hd(e,t)}catch(r){R(r)||W.warn(`Status line warning: ${y(r)}`)}}async function Po(r,e){if(!await C(r))return;let t=await Q.readdir(r);for(let s of t)if(s.endsWith(".sh")){let n=ae.join(r,s),o=ae.join(e,s);await Q.copyFile(n,o),await Q.chmod(o,493)}}async function Gd(r,e){try{if(await C(r)){if((await Q.lstat(r)).isSymbolicLink()&&await Q.readlink(r)===e)return;await Q.unlink(r)}await Q.symlink(e,r)}catch{try{await C(e)&&(await Q.copyFile(e,r),await Q.chmod(r,493))}catch(s){R(s)||W.warn(`Symlink fallback warning: ${s.message}`)}}}function kw(r,e){if(console.log(""),r.cliInstalled?console.log(` ${fe.green("\u2713")} ${e.displayName} CLI installed`):console.log(` ${fe.green("\u2713")} ${e.displayName} CLI found`),r.commandsAdded+r.commandsUpdated>0){let s=[];r.commandsAdded>0&&s.push(`${r.commandsAdded} new`),r.commandsUpdated>0&&s.push(`${r.commandsUpdated} updated`),console.log(` ${fe.green("\u2713")} Commands synced (${s.join(", ")})`)}else console.log(` ${fe.green("\u2713")} Commands up to date`);r.configAction==="created"?console.log(` ${fe.green("\u2713")} Global config created (${e.contextFile})`):r.configAction==="updated"?console.log(` ${fe.green("\u2713")} Global config updated (${e.contextFile})`):r.configAction==="appended"&&console.log(` ${fe.green("\u2713")} Global config merged (${e.contextFile})`),console.log("")}var Bd,Sw,xo=S(()=>{"use strict";Hs();br();Nd();ce();V();Ws();q();yn();ns();Ct();it();os();Wa();ra();l(dw,"installAICLI");l(Vd,"run");l(pw,"installGeminiRouter");l(mw,"installGeminiGlobalConfig");l(Wd,"installAntigravitySkill");l(gw,"needsAntigravityInstallation");Bd="prjct-codex-router";l(Jd,"getCodexSkillPath");l(fw,"getCodexSkillMetadata");l(Ud,"parseCodexSkillMetadata");l(hw,"hashContent");l(zd,"loadCodexSkillTemplate");l(qd,"buildCodexSkillContent");l(Ba,"installCodexSkill");l(Eo,"verifyCodexPRouterReady");l(yw,"migrateProjectsCliVersion");l(Hd,"ensureStatusLineSettings");l(ww,"installStatusLine");l(Po,"installStatusLineModules");l(Gd,"ensureStatusLineSymlink");l(kw,"showResults");Sw=process.argv[1]?.includes("setup.ts")||process.argv[1]?.includes("setup.js");Sw&&Vd().catch(r=>{console.error("Setup error:",r.message),process.exit(1)})});import{z as B}from"zod";var bw,vw,Kd,Tw,Cw,Pw,Ew,xw,Xd,aA,Yd=S(()=>{"use strict";bw=B.enum(["low","medium","high"]),vw=B.enum(["pending","converted","completed","archived","dormant"]),Kd=B.enum(["high","medium","low"]),Tw=B.object({impact:Kd,effort:Kd}),Cw=B.object({frontend:B.string().optional(),backend:B.string().optional(),payments:B.string().optional(),ai:B.string().optional(),deploy:B.string().optional(),other:B.array(B.string()).optional()}),Pw=B.object({name:B.string(),description:B.string()}),Ew=B.object({name:B.string(),description:B.string().optional()}),xw=B.object({id:B.string(),text:B.string(),details:B.string().optional(),priority:bw,status:vw,tags:B.array(B.string()),addedAt:B.string(),completedAt:B.string().optional(),convertedTo:B.string().optional(),source:B.string().optional(),sourceFiles:B.array(B.string()).optional(),painPoints:B.array(B.string()).optional(),solutions:B.array(B.string()).optional(),filesAffected:B.array(B.string()).optional(),impactEffort:Tw.optional(),implementationNotes:B.string().optional(),stack:Cw.optional(),modules:B.array(Pw).optional(),roles:B.array(Ew).optional(),risks:B.array(B.string()).optional(),risksCount:B.number().optional()}),Xd=B.object({ideas:B.array(xw),lastUpdated:B.string()}),aA={priority:"medium",status:"pending",tags:[],addedAt:new Date().toISOString()}});var za,He,ks=S(()=>{"use strict";Yd();It();oe();Vs();is();za=class extends ze{static{l(this,"IdeasStorage")}constructor(){super("ideas.json",Xd)}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 n={id:ye(),text:t,status:"pending",priority:s.priority||"medium",tags:s.tags||[],addedAt:v()};return await this.update(e,o=>({ideas:[n,...o.ideas],lastUpdated:v()})),await this.publishEvent(e,"idea.created",{ideaId:n.id,text:n.text,priority:n.priority}),n}async getById(e,t){return(await this.read(e)).ideas.find(n=>n.id===t)}async convertToFeature(e,t,s){await this.update(e,n=>({ideas:n.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:s}:o),lastUpdated:v()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:s})}async archive(e,t){await this.update(e,s=>({ideas:s.ideas.map(n=>n.id===t?{...n,status:"archived"}:n),lastUpdated:v()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,s){await this.update(e,n=>({ideas:n.ideas.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:v()}))}async addTags(e,t,s){await this.update(e,n=>({ideas:n.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...s])]}:o),lastUpdated:v()}))}async removeIdea(e,t){await this.update(e,s=>({ideas:s.ideas.filter(n=>n.id!==t),lastUpdated:v()}))}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 n=s.sort((a,c)=>new Date(c.addedAt).getTime()-new Date(a.addedAt).getTime()),o=new Set(n.slice(50).map(a=>a.id)),i=o.size;return await this.update(e,a=>({ideas:a.ideas.filter(c=>!o.has(c.id)),lastUpdated:v()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),s=gs(as.IDEA_DORMANT_DAYS),n=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<s);if(n.length===0)return 0;Mt.archiveMany(e,n.map(i=>({entityType:"idea",entityId:i.id,entityData:i,summary:i.text,reason:"dormant"})));let o=new Set(n.map(i=>i.id));return await this.update(e,i=>({ideas:i.ideas.map(a=>o.has(a.id)?{...a,status:"dormant"}:a),lastUpdated:v()})),await this.publishEvent(e,"ideas.dormant",{count:n.length}),n.length}},He=new za});var qa,Cn,Ka=S(()=>{"use strict";io();oe();is();qa=class extends ze{static{l(this,"MetricsStorage")}constructor(){super("metrics.json",ju)}getDefault(){return{...Iu}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let s=Math.max(0,t.originalSize-t.filteredSize),n=t.originalSize>0?s/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,c=i.totalTokensSaved+s,u=i.totalSyncDuration+t.duration,p=i.syncCount===0?n:(i.avgCompressionRate*i.syncCount+n)/a,m=[...i.dailyStats],d=m.findIndex(T=>T.date===o);if(d>=0){let T=m[d];m[d]={...T,tokensSaved:T.tokensSaved+s,syncs:T.syncs+1,avgCompressionRate:(T.avgCompressionRate*T.syncs+n)/(T.syncs+1),totalDuration:T.totalDuration+t.duration}}else m.push({date:o,tokensSaved:s,syncs:1,avgCompressionRate:n,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let h=g.toISOString().split("T")[0],k=m.filter(T=>T.date>=h),w=[...i.agentUsage];if(t.agents)for(let T of t.agents){let E=w.findIndex(M=>M.agentName===T);E>=0?w[E]={...w[E],usageCount:w[E].usageCount+1,tokensSaved:w[E].tokensSaved+Math.floor(s/t.agents.length)}:w.push({agentName:T,usageCount:1,tokensSaved:Math.floor(s/t.agents.length)})}return{totalTokensSaved:c,avgCompressionRate:p,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:w,dailyStats:k,firstSync:i.firstSync||v(),lastUpdated:v()}})}async getSummary(e){let t=await this.read(e),s=this.getLast30Days(t.dailyStats),n=this.getPrev30Days(t.dailyStats),o=s.reduce((c,u)=>c+u.tokensSaved,0),i=n.reduce((c,u)=>c+u.tokensSaved,0),a=i>0?(o-i)/i*100:0;return{totalTokensSaved:t.totalTokensSaved,estimatedCostSaved:$u(t.totalTokensSaved),compressionRate:t.avgCompressionRate,syncCount:t.syncCount,avgSyncDuration:t.avgSyncDuration,topAgents:[...t.agentUsage].sort((c,u)=>u.usageCount-c.usageCount).slice(0,5),last30DaysTokens:o,trend:a}}async getDailyStats(e,t=30){let s=await this.read(e),n=new Date;n.setDate(n.getDate()-t);let o=n.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(n=>n.date>=s)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=new Date;s.setDate(s.getDate()-60);let n=s.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=n&&i.date<o)}},Cn=new qa});import Z from"node:fs/promises";import Y from"node:path";async function Ro(r){let e=Date.now(),t={success:!1,migratedFiles:[],skippedFiles:[],errors:[],backupDir:null,duration:0};try{if(P.exists(r)&&P.hasDoc(r,"state"))return t.success=!0,t.duration=Date.now()-e,t;let s=A.getGlobalProjectPath(r),n=Y.join(s,"storage"),o=Y.join(s,"index"),i=Y.join(s,"memory");t.backupDir=await Rw(n,o,i),P.getDb(r);for(let{filename:c,key:u}of Qa){let p=Y.join(n,c),m=await Lt(p);if(m===null){t.skippedFiles.push(c);continue}try{P.setDoc(r,u,m),Qd(r,u,m),t.migratedFiles.push(c)}catch(d){t.errors.push({file:c,error:String(d)})}}for(let{filename:c,key:u}of Ya){let p=Y.join(o,c),m=await Lt(p);if(m===null){t.skippedFiles.push(`index/${c}`);continue}try{P.run(r,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",u,JSON.stringify(m),new Date().toISOString()),Zd(r,u,m),t.migratedFiles.push(`index/${c}`)}catch(d){t.errors.push({file:`index/${c}`,error:String(d)})}}await _w(r,o,t),await Nw(r,o,t),await Lw(r,i,t),await Fw(r,i,t);let a=Y.join(s,"sessions");return await Uw(r,a,t),t.errors.length===0&&await Hw(n,o,i,t),t.success=t.errors.length===0,t.duration=Date.now()-e,t}catch(s){return t.errors.push({file:"<migration>",error:String(s)}),t.duration=Date.now()-e,t}}async function Rw(r,e,t){let s=Y.join(r,"backup");return await Z.mkdir(s,{recursive:!0}),await Z.mkdir(Y.join(s,"index"),{recursive:!0}),await Z.mkdir(Y.join(s,"memory"),{recursive:!0}),await Xa(r,s,n=>n.endsWith(".json")||n.endsWith(".jsonl")),await Xa(e,Y.join(s,"index")),await Xa(t,Y.join(s,"memory")),s}async function Xa(r,e,t){try{let s=await Z.readdir(r,{withFileTypes:!0});for(let n of s){if(!n.isFile()||t&&!t(n.name))continue;let o=Y.join(r,n.name),i=Y.join(e,n.name);await Z.copyFile(o,i)}}catch(s){if(!R(s))throw s}}function Qd(r,e,t){switch(e){case"state":Aw(r,t);break;case"queue":Dw(r,t);break;case"ideas":jw(r,t);break;case"shipped":Iw(r,t);break;case"metrics":$w(r,t);break;case"analysis":Mw(r,t);break}}function Aw(r,e){let t=P.getDb(r),s=t.prepare(`
474
+ `;await Z.writeFile(n,k,{mode:493})}await Bd(t,n),await Vd(e,t)}catch(r){R(r)||V.warn(`Status line warning: ${w(r)}`)}}async function Ao(r,e){if(!await P(r))return;let t=await Z.readdir(r);for(let s of t)if(s.endsWith(".sh")){let n=ce.join(r,s),o=ce.join(e,s);await Z.copyFile(n,o),await Z.chmod(o,493)}}async function Bd(r,e){try{if(await P(r)){if((await Z.lstat(r)).isSymbolicLink()&&await Z.readlink(r)===e)return;await Z.unlink(r)}await Z.symlink(e,r)}catch{try{await P(e)&&(await Z.copyFile(e,r),await Z.chmod(r,493))}catch(s){R(s)||V.warn(`Symlink fallback warning: ${s.message}`)}}}function vw(r,e){if(console.log(""),r.cliInstalled?console.log(` ${fe.green("\u2713")} ${e.displayName} CLI installed`):console.log(` ${fe.green("\u2713")} ${e.displayName} CLI found`),r.commandsAdded+r.commandsUpdated>0){let s=[];r.commandsAdded>0&&s.push(`${r.commandsAdded} new`),r.commandsUpdated>0&&s.push(`${r.commandsUpdated} updated`),console.log(` ${fe.green("\u2713")} Commands synced (${s.join(", ")})`)}else console.log(` ${fe.green("\u2713")} Commands up to date`);r.configAction==="created"?console.log(` ${fe.green("\u2713")} Global config created (${e.contextFile})`):r.configAction==="updated"?console.log(` ${fe.green("\u2713")} Global config updated (${e.contextFile})`):r.configAction==="appended"&&console.log(` ${fe.green("\u2713")} Global config merged (${e.contextFile})`),console.log("")}var qd,Cw,jo=S(()=>{"use strict";Hs();br();Ud();re();W();Vs();K();wn();ns();Ct();at();os();za();ia();l(fw,"installAICLI");l(zd,"run");l(hw,"installGeminiRouter");l(yw,"installGeminiGlobalConfig");l(Jd,"installAntigravitySkill");l(ww,"needsAntigravityInstallation");qd="prjct-codex-router";l(Kd,"getCodexSkillPath");l(kw,"getCodexSkillMetadata");l(Wd,"parseCodexSkillMetadata");l(Sw,"hashContent");l(Xd,"loadCodexSkillTemplate");l(Yd,"buildCodexSkillContent");l(Ja,"installCodexSkill");l(Do,"verifyCodexPRouterReady");l(bw,"migrateProjectsCliVersion");l(Vd,"ensureStatusLineSettings");l(Tw,"installStatusLine");l(Ao,"installStatusLineModules");l(Bd,"ensureStatusLineSymlink");l(vw,"showResults");Cw=process.argv[1]?.includes("setup.ts")||process.argv[1]?.includes("setup.js");Cw&&zd().catch(r=>{console.error("Setup error:",r.message),process.exit(1)})});import{z as B}from"zod";var Pw,Ew,Qd,xw,Rw,Aw,Dw,jw,Zd,uA,ep=S(()=>{"use strict";Pw=B.enum(["low","medium","high"]),Ew=B.enum(["pending","converted","completed","archived","dormant"]),Qd=B.enum(["high","medium","low"]),xw=B.object({impact:Qd,effort:Qd}),Rw=B.object({frontend:B.string().optional(),backend:B.string().optional(),payments:B.string().optional(),ai:B.string().optional(),deploy:B.string().optional(),other:B.array(B.string()).optional()}),Aw=B.object({name:B.string(),description:B.string()}),Dw=B.object({name:B.string(),description:B.string().optional()}),jw=B.object({id:B.string(),text:B.string(),details:B.string().optional(),priority:Pw,status:Ew,tags:B.array(B.string()),addedAt:B.string(),completedAt:B.string().optional(),convertedTo:B.string().optional(),source:B.string().optional(),sourceFiles:B.array(B.string()).optional(),painPoints:B.array(B.string()).optional(),solutions:B.array(B.string()).optional(),filesAffected:B.array(B.string()).optional(),impactEffort:xw.optional(),implementationNotes:B.string().optional(),stack:Rw.optional(),modules:B.array(Aw).optional(),roles:B.array(Dw).optional(),risks:B.array(B.string()).optional(),risksCount:B.number().optional()}),Zd=B.object({ideas:B.array(jw),lastUpdated:B.string()}),uA={priority:"medium",status:"pending",tags:[],addedAt:new Date().toISOString()}});var Ka,Ge,ks=S(()=>{"use strict";ep();It();ie();Ws();is();Ka=class extends qe{static{l(this,"IdeasStorage")}constructor(){super("ideas.json",Zd)}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 n={id:ye(),text:t,status:"pending",priority:s.priority||"medium",tags:s.tags||[],addedAt:T()};return await this.update(e,o=>({ideas:[n,...o.ideas],lastUpdated:T()})),await this.publishEvent(e,"idea.created",{ideaId:n.id,text:n.text,priority:n.priority}),n}async getById(e,t){return(await this.read(e)).ideas.find(n=>n.id===t)}async convertToFeature(e,t,s){await this.update(e,n=>({ideas:n.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:s}:o),lastUpdated:T()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:s})}async archive(e,t){await this.update(e,s=>({ideas:s.ideas.map(n=>n.id===t?{...n,status:"archived"}:n),lastUpdated:T()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,s){await this.update(e,n=>({ideas:n.ideas.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:T()}))}async addTags(e,t,s){await this.update(e,n=>({ideas:n.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...s])]}:o),lastUpdated:T()}))}async removeIdea(e,t){await this.update(e,s=>({ideas:s.ideas.filter(n=>n.id!==t),lastUpdated:T()}))}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 n=s.sort((a,c)=>new Date(c.addedAt).getTime()-new Date(a.addedAt).getTime()),o=new Set(n.slice(50).map(a=>a.id)),i=o.size;return await this.update(e,a=>({ideas:a.ideas.filter(c=>!o.has(c.id)),lastUpdated:T()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),s=gs(as.IDEA_DORMANT_DAYS),n=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<s);if(n.length===0)return 0;Mt.archiveMany(e,n.map(i=>({entityType:"idea",entityId:i.id,entityData:i,summary:i.text,reason:"dormant"})));let o=new Set(n.map(i=>i.id));return await this.update(e,i=>({ideas:i.ideas.map(a=>o.has(a.id)?{...a,status:"dormant"}:a),lastUpdated:T()})),await this.publishEvent(e,"ideas.dormant",{count:n.length}),n.length}},Ge=new Ka});var Xa,Pn,Ya=S(()=>{"use strict";uo();ie();is();Xa=class extends qe{static{l(this,"MetricsStorage")}constructor(){super("metrics.json",Mu)}getDefault(){return{..._u}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let s=Math.max(0,t.originalSize-t.filteredSize),n=t.originalSize>0?s/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,c=i.totalTokensSaved+s,u=i.totalSyncDuration+t.duration,p=i.syncCount===0?n:(i.avgCompressionRate*i.syncCount+n)/a,m=[...i.dailyStats],d=m.findIndex(v=>v.date===o);if(d>=0){let v=m[d];m[d]={...v,tokensSaved:v.tokensSaved+s,syncs:v.syncs+1,avgCompressionRate:(v.avgCompressionRate*v.syncs+n)/(v.syncs+1),totalDuration:v.totalDuration+t.duration}}else m.push({date:o,tokensSaved:s,syncs:1,avgCompressionRate:n,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let h=g.toISOString().split("T")[0],k=m.filter(v=>v.date>=h),y=[...i.agentUsage];if(t.agents)for(let v of t.agents){let D=y.findIndex(U=>U.agentName===v);D>=0?y[D]={...y[D],usageCount:y[D].usageCount+1,tokensSaved:y[D].tokensSaved+Math.floor(s/t.agents.length)}:y.push({agentName:v,usageCount:1,tokensSaved:Math.floor(s/t.agents.length)})}return{totalTokensSaved:c,avgCompressionRate:p,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:y,dailyStats:k,firstSync:i.firstSync||T(),lastUpdated:T()}})}async getSummary(e){let t=await this.read(e),s=this.getLast30Days(t.dailyStats),n=this.getPrev30Days(t.dailyStats),o=s.reduce((c,u)=>c+u.tokensSaved,0),i=n.reduce((c,u)=>c+u.tokensSaved,0),a=i>0?(o-i)/i*100:0;return{totalTokensSaved:t.totalTokensSaved,estimatedCostSaved:Ou(t.totalTokensSaved),compressionRate:t.avgCompressionRate,syncCount:t.syncCount,avgSyncDuration:t.avgSyncDuration,topAgents:[...t.agentUsage].sort((c,u)=>u.usageCount-c.usageCount).slice(0,5),last30DaysTokens:o,trend:a}}async getDailyStats(e,t=30){let s=await this.read(e),n=new Date;n.setDate(n.getDate()-t);let o=n.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(n=>n.date>=s)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=new Date;s.setDate(s.getDate()-60);let n=s.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=n&&i.date<o)}},Pn=new Xa});import ee from"node:fs/promises";import Y from"node:path";async function Io(r){let e=Date.now(),t={success:!1,migratedFiles:[],skippedFiles:[],errors:[],backupDir:null,duration:0};try{if(C.exists(r)&&C.hasDoc(r,"state"))return t.success=!0,t.duration=Date.now()-e,t;let s=A.getGlobalProjectPath(r),n=Y.join(s,"storage"),o=Y.join(s,"index"),i=Y.join(s,"memory");t.backupDir=await Iw(n,o,i),C.getDb(r);for(let{filename:c,key:u}of ec){let p=Y.join(n,c),m=await Ut(p);if(m===null){t.skippedFiles.push(c);continue}try{C.setDoc(r,u,m),tp(r,u,m),t.migratedFiles.push(c)}catch(d){t.errors.push({file:c,error:String(d)})}}for(let{filename:c,key:u}of Za){let p=Y.join(o,c),m=await Ut(p);if(m===null){t.skippedFiles.push(`index/${c}`);continue}try{C.run(r,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",u,JSON.stringify(m),new Date().toISOString()),sp(r,u,m),t.migratedFiles.push(`index/${c}`)}catch(d){t.errors.push({file:`index/${c}`,error:String(d)})}}await Uw(r,o,t),await Hw(r,o,t),await Gw(r,i,t),await Ww(r,i,t);let a=Y.join(s,"sessions");return await Vw(r,a,t),t.errors.length===0&&await Bw(n,o,i,t),t.success=t.errors.length===0,t.duration=Date.now()-e,t}catch(s){return t.errors.push({file:"<migration>",error:String(s)}),t.duration=Date.now()-e,t}}async function Iw(r,e,t){let s=Y.join(r,"backup");return await ee.mkdir(s,{recursive:!0}),await ee.mkdir(Y.join(s,"index"),{recursive:!0}),await ee.mkdir(Y.join(s,"memory"),{recursive:!0}),await Qa(r,s,n=>n.endsWith(".json")||n.endsWith(".jsonl")),await Qa(e,Y.join(s,"index")),await Qa(t,Y.join(s,"memory")),s}async function Qa(r,e,t){try{let s=await ee.readdir(r,{withFileTypes:!0});for(let n of s){if(!n.isFile()||t&&!t(n.name))continue;let o=Y.join(r,n.name),i=Y.join(e,n.name);await ee.copyFile(o,i)}}catch(s){if(!R(s))throw s}}function tp(r,e,t){switch(e){case"state":$w(r,t);break;case"queue":Mw(r,t);break;case"ideas":_w(r,t);break;case"shipped":Ow(r,t);break;case"metrics":Nw(r,t);break;case"analysis":Lw(r,t);break}}function $w(r,e){let t=C.getDb(r),s=t.prepare(`
445
475
  INSERT OR REPLACE INTO tasks
446
476
  (id, description, type, status, parent_description, branch, linear_id,
447
477
  linear_uuid, session_id, feature_id, started_at, completed_at,
@@ -452,92 +482,92 @@ echo "prjct"
452
482
  (id, task_id, description, status, domain, agent, sort_order,
453
483
  depends_on, started_at, completed_at, output, summary)
454
484
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
455
- `),o=l((a,c)=>{if(!a||!a.id)return;s.run(j(a.id)??`task-${Date.now()}`,j(a.description??a.parentDescription)??"",j(a.type),j(c??a.status)??"unknown",j(a.parentDescription),j(a.branch),j(a.linearId),j(a.linearUuid),j(a.sessionId),j(a.featureId),j(a.startedAt)??new Date().toISOString(),j(a.completedAt),j(a.shippedAt),j(a.pausedAt),j(a.pauseReason),j(a.prUrl),a.expectedValue?JSON.stringify(a.expectedValue):null,JSON.stringify(a));let u=a.subtasks;if(u&&Array.isArray(u))for(let p=0;p<u.length;p++){let m=u[p];n.run(j(m.id)??`subtask-${p}`,j(a.id),j(m.description)??"",j(m.status)??"pending",j(m.domain),j(m.agent),p,m.dependsOn?JSON.stringify(m.dependsOn):null,j(m.startedAt),j(m.completedAt),j(m.output),m.summary?JSON.stringify(m.summary):null)}},"migrateTask");e.currentTask&&o(e.currentTask),e.previousTask&&o(e.previousTask);let i=e.pausedTasks;if(i&&Array.isArray(i))for(let a of i)o(a,"paused")}function Dw(r,e){let t=e.tasks;if(!t||!Array.isArray(t))return;let n=P.getDb(r).prepare(`
485
+ `),o=l((a,c)=>{if(!a||!a.id)return;s.run(I(a.id)??`task-${Date.now()}`,I(a.description??a.parentDescription)??"",I(a.type),I(c??a.status)??"unknown",I(a.parentDescription),I(a.branch),I(a.linearId),I(a.linearUuid),I(a.sessionId),I(a.featureId),I(a.startedAt)??new Date().toISOString(),I(a.completedAt),I(a.shippedAt),I(a.pausedAt),I(a.pauseReason),I(a.prUrl),a.expectedValue?JSON.stringify(a.expectedValue):null,JSON.stringify(a));let u=a.subtasks;if(u&&Array.isArray(u))for(let p=0;p<u.length;p++){let m=u[p];n.run(I(m.id)??`subtask-${p}`,I(a.id),I(m.description)??"",I(m.status)??"pending",I(m.domain),I(m.agent),p,m.dependsOn?JSON.stringify(m.dependsOn):null,I(m.startedAt),I(m.completedAt),I(m.output),m.summary?JSON.stringify(m.summary):null)}},"migrateTask");e.currentTask&&o(e.currentTask),e.previousTask&&o(e.previousTask);let i=e.pausedTasks;if(i&&Array.isArray(i))for(let a of i)o(a,"paused")}function Mw(r,e){let t=e.tasks;if(!t||!Array.isArray(t))return;let n=C.getDb(r).prepare(`
456
486
  INSERT OR REPLACE INTO queue_tasks
457
487
  (id, description, type, priority, section, created_at, completed, completed_at,
458
488
  feature_id, feature_name)
459
489
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
460
- `);for(let o of t)n.run(j(o.id)??`queue-${Date.now()}`,j(o.description)??"",j(o.type),j(o.priority),j(o.section),j(o.createdAt)??new Date().toISOString(),o.completed?1:0,j(o.completedAt),j(o.featureId),j(o.featureName))}function jw(r,e){let t=e.ideas;if(!t||!Array.isArray(t))return;let n=P.getDb(r).prepare(`
490
+ `);for(let o of t)n.run(I(o.id)??`queue-${Date.now()}`,I(o.description)??"",I(o.type),I(o.priority),I(o.section),I(o.createdAt)??new Date().toISOString(),o.completed?1:0,I(o.completedAt),I(o.featureId),I(o.featureName))}function _w(r,e){let t=e.ideas;if(!t||!Array.isArray(t))return;let n=C.getDb(r).prepare(`
461
491
  INSERT OR REPLACE INTO ideas
462
492
  (id, text, status, priority, tags, added_at, converted_to, details, data)
463
493
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
464
- `);for(let o of t)n.run(j(o.id)??`idea-${Date.now()}`,j(o.text)??"",j(o.status)??"pending",j(o.priority)??"medium",o.tags?JSON.stringify(o.tags):null,j(o.addedAt)??new Date().toISOString(),j(o.convertedTo),j(o.details),JSON.stringify(o))}function Iw(r,e){let t=e.shipped;if(!t||!Array.isArray(t))return;let n=P.getDb(r).prepare(`
494
+ `);for(let o of t)n.run(I(o.id)??`idea-${Date.now()}`,I(o.text)??"",I(o.status)??"pending",I(o.priority)??"medium",o.tags?JSON.stringify(o.tags):null,I(o.addedAt)??new Date().toISOString(),I(o.convertedTo),I(o.details),JSON.stringify(o))}function Ow(r,e){let t=e.shipped;if(!t||!Array.isArray(t))return;let n=C.getDb(r).prepare(`
465
495
  INSERT OR REPLACE INTO shipped_features
466
496
  (id, name, shipped_at, version, description, type, duration, data)
467
497
  VALUES (?, ?, ?, ?, ?, ?, ?, ?)
468
- `);for(let o of t)n.run(j(o.id)??`ship-${Date.now()}`,j(o.name)??"",j(o.shippedAt)??new Date().toISOString(),j(o.version)??"0.0.0",j(o.description),j(o.type),j(o.duration),JSON.stringify(o))}function $w(r,e){let t=e.dailyStats;if(!t||!Array.isArray(t))return;let n=P.getDb(r).prepare(`
498
+ `);for(let o of t)n.run(I(o.id)??`ship-${Date.now()}`,I(o.name)??"",I(o.shippedAt)??new Date().toISOString(),I(o.version)??"0.0.0",I(o.description),I(o.type),I(o.duration),JSON.stringify(o))}function Nw(r,e){let t=e.dailyStats;if(!t||!Array.isArray(t))return;let n=C.getDb(r).prepare(`
469
499
  INSERT OR REPLACE INTO metrics_daily
470
500
  (date, tokens_saved, syncs, avg_compression_rate, total_duration)
471
501
  VALUES (?, ?, ?, ?, ?)
472
- `);for(let o of t)n.run(j(o.date)??new Date().toISOString().slice(0,10),Ss(o.tokensSaved)??0,Ss(o.syncs)??0,Ss(o.avgCompressionRate)??0,Ss(o.totalDuration)??0)}function Mw(r,e){let s=P.getDb(r).prepare(`
502
+ `);for(let o of t)n.run(I(o.date)??new Date().toISOString().slice(0,10),Ss(o.tokensSaved)??0,Ss(o.syncs)??0,Ss(o.avgCompressionRate)??0,Ss(o.totalDuration)??0)}function Lw(r,e){let s=C.getDb(r).prepare(`
473
503
  INSERT OR REPLACE INTO analysis
474
504
  (id, status, commit_hash, signature, sealed_at, analyzed_at, data)
475
505
  VALUES (?, ?, ?, ?, ?, ?, ?)
476
- `),n=l((o,i)=>{o&&s.run(i,j(o.status)??"unknown",j(o.commitHash),j(o.signature),j(o.sealedAt),j(o.analyzedAt),JSON.stringify(o))},"migrate");e.draft&&n(e.draft,"draft"),e.sealed&&n(e.sealed,"sealed")}function Zd(r,e,t){e==="categories-cache"&&Ow(r,t)}function Ow(r,e){let t=e.fileCategories;if(!t||!Array.isArray(t))return;let n=P.getDb(r).prepare(`
506
+ `),n=l((o,i)=>{o&&s.run(i,I(o.status)??"unknown",I(o.commitHash),I(o.signature),I(o.sealedAt),I(o.analyzedAt),JSON.stringify(o))},"migrate");e.draft&&n(e.draft,"draft"),e.sealed&&n(e.sealed,"sealed")}function sp(r,e,t){e==="categories-cache"&&Fw(r,t)}function Fw(r,e){let t=e.fileCategories;if(!t||!Array.isArray(t))return;let n=C.getDb(r).prepare(`
477
507
  INSERT OR REPLACE INTO index_files
478
508
  (path, categories, domain, score, size, mtime, language)
479
509
  VALUES (?, ?, ?, COALESCE((SELECT score FROM index_files WHERE path = ?), 0), NULL, NULL, NULL)
480
- `);for(let o of t){let i=j(o.path);i&&n.run(i,o.categories?JSON.stringify(o.categories):null,j(o.primaryDomain),i)}}async function _w(r,e,t){let s=Y.join(e,"checksums.json"),n=await Lt(s);if(n===null){t.skippedFiles.push("index/checksums.json");return}try{let o=n.checksums;if(!o)return;let i=P.getDb(r),a=i.prepare("INSERT OR REPLACE INTO index_checksums (path, checksum) VALUES (?, ?)");i.transaction(()=>{for(let[c,u]of Object.entries(o))a.run(c,u)})(),t.migratedFiles.push("index/checksums.json")}catch(o){t.errors.push({file:"index/checksums.json",error:String(o)})}}async function Nw(r,e,t){let s=Y.join(e,"file-scores.json"),n=await Lt(s);if(n===null){t.skippedFiles.push("index/file-scores.json");return}try{let o=n.scores;if(!o||!Array.isArray(o))return;let i=P.getDb(r),a=i.prepare(`
510
+ `);for(let o of t){let i=I(o.path);i&&n.run(i,o.categories?JSON.stringify(o.categories):null,I(o.primaryDomain),i)}}async function Uw(r,e,t){let s=Y.join(e,"checksums.json"),n=await Ut(s);if(n===null){t.skippedFiles.push("index/checksums.json");return}try{let o=n.checksums;if(!o)return;let i=C.getDb(r),a=i.prepare("INSERT OR REPLACE INTO index_checksums (path, checksum) VALUES (?, ?)");i.transaction(()=>{for(let[c,u]of Object.entries(o))a.run(c,u)})(),t.migratedFiles.push("index/checksums.json")}catch(o){t.errors.push({file:"index/checksums.json",error:String(o)})}}async function Hw(r,e,t){let s=Y.join(e,"file-scores.json"),n=await Ut(s);if(n===null){t.skippedFiles.push("index/file-scores.json");return}try{let o=n.scores;if(!o||!Array.isArray(o))return;let i=C.getDb(r),a=i.prepare(`
481
511
  INSERT OR REPLACE INTO index_files
482
512
  (path, score, size, mtime, language, categories, domain)
483
513
  VALUES (?, ?, ?, ?, NULL,
484
514
  COALESCE((SELECT categories FROM index_files WHERE path = ?), NULL),
485
515
  COALESCE((SELECT domain FROM index_files WHERE path = ?), NULL))
486
- `);i.transaction(()=>{for(let c of o){let u=j(c.path);u&&a.run(u,Ss(c.score)??0,Ss(c.size),j(c.mtime),u,u)}})(),t.migratedFiles.push("index/file-scores.json")}catch(o){t.errors.push({file:"index/file-scores.json",error:String(o)})}}async function Lw(r,e,t){let s=Y.join(e,"events.jsonl");try{let o=(await Z.readFile(s,"utf-8")).split(`
487
- `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/events.jsonl");return}let i=P.getDb(r),a=i.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)");i.transaction(()=>{for(let c of o)try{let u=JSON.parse(c),p=j(u.type??u.action)??"unknown",m=j(u.taskId??u.task_id),d=j(u.timestamp??u.ts)??new Date().toISOString();a.run(p,m,c,d)}catch{}})(),t.migratedFiles.push("memory/events.jsonl")}catch(n){R(n)?t.skippedFiles.push("memory/events.jsonl"):t.errors.push({file:"memory/events.jsonl",error:String(n)})}}async function Fw(r,e,t){let s=Y.join(e,"learnings.jsonl");try{let o=(await Z.readFile(s,"utf-8")).split(`
488
- `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/learnings.jsonl");return}let i=P.getDb(r),a=i.prepare("INSERT OR REPLACE INTO memory (key, domain, value, confidence, updated_at) VALUES (?, ?, ?, ?, ?)");i.transaction(()=>{for(let c of o)try{let u=JSON.parse(c),p=`learning:${j(u.taskId??u.timestamp)??Date.now()}`,m=u.tags,d=m&&m.length>0?j(m[0]):null;a.run(p,d,c,1,j(u.timestamp)??new Date().toISOString())}catch{}})(),t.migratedFiles.push("memory/learnings.jsonl")}catch(n){R(n)?t.skippedFiles.push("memory/learnings.jsonl"):t.errors.push({file:"memory/learnings.jsonl",error:String(n)})}}async function Uw(r,e,t){let n=P.getDb(r).prepare(`
516
+ `);i.transaction(()=>{for(let c of o){let u=I(c.path);u&&a.run(u,Ss(c.score)??0,Ss(c.size),I(c.mtime),u,u)}})(),t.migratedFiles.push("index/file-scores.json")}catch(o){t.errors.push({file:"index/file-scores.json",error:String(o)})}}async function Gw(r,e,t){let s=Y.join(e,"events.jsonl");try{let o=(await ee.readFile(s,"utf-8")).split(`
517
+ `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/events.jsonl");return}let i=C.getDb(r),a=i.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)");i.transaction(()=>{for(let c of o)try{let u=JSON.parse(c),p=I(u.type??u.action)??"unknown",m=I(u.taskId??u.task_id),d=I(u.timestamp??u.ts)??new Date().toISOString();a.run(p,m,c,d)}catch{}})(),t.migratedFiles.push("memory/events.jsonl")}catch(n){R(n)?t.skippedFiles.push("memory/events.jsonl"):t.errors.push({file:"memory/events.jsonl",error:String(n)})}}async function Ww(r,e,t){let s=Y.join(e,"learnings.jsonl");try{let o=(await ee.readFile(s,"utf-8")).split(`
518
+ `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/learnings.jsonl");return}let i=C.getDb(r),a=i.prepare("INSERT OR REPLACE INTO memory (key, domain, value, confidence, updated_at) VALUES (?, ?, ?, ?, ?)");i.transaction(()=>{for(let c of o)try{let u=JSON.parse(c),p=`learning:${I(u.taskId??u.timestamp)??Date.now()}`,m=u.tags,d=m&&m.length>0?I(m[0]):null;a.run(p,d,c,1,I(u.timestamp)??new Date().toISOString())}catch{}})(),t.migratedFiles.push("memory/learnings.jsonl")}catch(n){R(n)?t.skippedFiles.push("memory/learnings.jsonl"):t.errors.push({file:"memory/learnings.jsonl",error:String(n)})}}async function Vw(r,e,t){let n=C.getDb(r).prepare(`
489
519
  INSERT OR IGNORE INTO sessions
490
520
  (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
491
521
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
492
- `),o=l(u=>{!u||!u.id||n.run(j(u.id),j(u.projectId)??r,j(u.task)??"",j(u.status)??"completed",j(u.startedAt)??new Date().toISOString(),j(u.pausedAt),j(u.completedAt),Ss(u.duration)??0,u.metrics?JSON.stringify(u.metrics):"{}",u.timeline?JSON.stringify(u.timeline):"[]")},"insertSession"),i=Y.join(e,"current.json"),a=await Lt(i);if(a!==null)try{o(a),t.migratedFiles.push("sessions/current.json"),await Z.unlink(i).catch(()=>{})}catch(u){t.errors.push({file:"sessions/current.json",error:String(u)})}let c=Y.join(e,"archive");try{let u=await Z.readdir(c);for(let m of u){let d=Y.join(c,m);try{if(!(await Z.stat(d)).isDirectory())continue;let h=await Z.readdir(d);for(let w of h){if(!w.endsWith(".json"))continue;let T=Y.join(d,w),E=await Lt(T);if(E!==null)try{o(E),t.migratedFiles.push(`sessions/archive/${m}/${w}`),await Z.unlink(T).catch(()=>{})}catch(M){t.errors.push({file:`sessions/archive/${m}/${w}`,error:String(M)})}}(await Z.readdir(d)).length===0&&await Z.rmdir(d).catch(()=>{})}catch{}}(await Z.readdir(c).catch(()=>[])).length===0&&await Z.rmdir(c).catch(()=>{})}catch{}try{(await Z.readdir(e)).length===0&&await Z.rmdir(e).catch(()=>{})}catch{}}async function Hw(r,e,t,s){let n=l(async(i,a)=>{try{await Z.unlink(i)}catch(c){R(c)||s.errors.push({file:a,error:`cleanup: ${String(c)}`})}},"deleteFile");for(let{filename:i}of Qa)await n(Y.join(r,i),`cleanup:${i}`);let o=["project-index.json","domains.json","categories-cache.json","checksums.json","file-scores.json"];for(let i of o)await n(Y.join(e,i),`cleanup:index/${i}`);await n(Y.join(t,"events.jsonl"),"cleanup:memory/events.jsonl"),await n(Y.join(t,"learnings.jsonl"),"cleanup:memory/learnings.jsonl")}function j(r){return r==null?null:typeof r=="string"?r:typeof r=="number"||typeof r=="boolean"||typeof r=="bigint"?String(r):JSON.stringify(r)}function Ss(r){if(r==null)return null;if(typeof r=="number")return r;if(typeof r=="string"){let e=Number(r);return Number.isNaN(e)?null:e}return null}async function Lt(r){try{let e=await Z.readFile(r,"utf-8");return JSON.parse(e)}catch(e){if(R(e)||e instanceof SyntaxError)return null;throw e}}async function Ao(r){let e=A.getGlobalProjectPath(r),t=Y.join(e,"storage"),s=0;P.getDb(r);for(let{filename:h,key:k}of Qa){let w=Y.join(t,h),T=await Lt(w);if(T!==null){P.setDoc(r,k,T),Qd(r,k,T);try{await Z.unlink(w)}catch{}s++}}let n=Y.join(e,"project.json"),o=await Lt(n);if(o!==null){P.setDoc(r,"project",o);try{await Z.unlink(n)}catch{}s++}let i=Y.join(e,"memory");for(let h of["events.jsonl","learnings.jsonl"]){let k=Y.join(i,h);try{let T=(await Z.readFile(k,"utf-8")).split(`
493
- `).filter(M=>M.trim());if(T.length===0){await Z.unlink(k),s++;continue}let E=P.getDb(r);if(h==="events.jsonl"){let M=E.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)");E.transaction(()=>{for(let L of T)try{let $=JSON.parse(L);M.run(j($.type??$.action)??"unknown",j($.taskId??$.task_id),L,j($.timestamp??$.ts)??new Date().toISOString())}catch{}})()}else{let M=E.prepare("INSERT OR REPLACE INTO memory (key, domain, value, confidence, updated_at) VALUES (?, ?, ?, ?, ?)");E.transaction(()=>{for(let L of T)try{let $=JSON.parse(L),D=`learning:${j($.taskId??$.timestamp)??Date.now()}`,O=$.tags;M.run(D,j(O?.[0]),L,1,j($.timestamp)??new Date().toISOString())}catch{}})()}await Z.unlink(k),s++}catch{}}let a=Y.join(e,"sessions"),c=l(h=>{if(!h||!h.id)return;P.getDb(r).prepare(`
522
+ `),o=l(u=>{!u||!u.id||n.run(I(u.id),I(u.projectId)??r,I(u.task)??"",I(u.status)??"completed",I(u.startedAt)??new Date().toISOString(),I(u.pausedAt),I(u.completedAt),Ss(u.duration)??0,u.metrics?JSON.stringify(u.metrics):"{}",u.timeline?JSON.stringify(u.timeline):"[]")},"insertSession"),i=Y.join(e,"current.json"),a=await Ut(i);if(a!==null)try{o(a),t.migratedFiles.push("sessions/current.json"),await ee.unlink(i).catch(()=>{})}catch(u){t.errors.push({file:"sessions/current.json",error:String(u)})}let c=Y.join(e,"archive");try{let u=await ee.readdir(c);for(let m of u){let d=Y.join(c,m);try{if(!(await ee.stat(d)).isDirectory())continue;let h=await ee.readdir(d);for(let y of h){if(!y.endsWith(".json"))continue;let v=Y.join(d,y),D=await Ut(v);if(D!==null)try{o(D),t.migratedFiles.push(`sessions/archive/${m}/${y}`),await ee.unlink(v).catch(()=>{})}catch(U){t.errors.push({file:`sessions/archive/${m}/${y}`,error:String(U)})}}(await ee.readdir(d)).length===0&&await ee.rmdir(d).catch(()=>{})}catch{}}(await ee.readdir(c).catch(()=>[])).length===0&&await ee.rmdir(c).catch(()=>{})}catch{}try{(await ee.readdir(e)).length===0&&await ee.rmdir(e).catch(()=>{})}catch{}}async function Bw(r,e,t,s){let n=l(async(i,a)=>{try{await ee.unlink(i)}catch(c){R(c)||s.errors.push({file:a,error:`cleanup: ${String(c)}`})}},"deleteFile");for(let{filename:i}of ec)await n(Y.join(r,i),`cleanup:${i}`);let o=["project-index.json","domains.json","categories-cache.json","checksums.json","file-scores.json"];for(let i of o)await n(Y.join(e,i),`cleanup:index/${i}`);await n(Y.join(t,"events.jsonl"),"cleanup:memory/events.jsonl"),await n(Y.join(t,"learnings.jsonl"),"cleanup:memory/learnings.jsonl")}function I(r){return r==null?null:typeof r=="string"?r:typeof r=="number"||typeof r=="boolean"||typeof r=="bigint"?String(r):JSON.stringify(r)}function Ss(r){if(r==null)return null;if(typeof r=="number")return r;if(typeof r=="string"){let e=Number(r);return Number.isNaN(e)?null:e}return null}async function Ut(r){try{let e=await ee.readFile(r,"utf-8");return JSON.parse(e)}catch(e){if(R(e)||e instanceof SyntaxError)return null;throw e}}async function $o(r){let e=A.getGlobalProjectPath(r),t=Y.join(e,"storage"),s=0;C.getDb(r);for(let{filename:h,key:k}of ec){let y=Y.join(t,h),v=await Ut(y);if(v!==null){C.setDoc(r,k,v),tp(r,k,v);try{await ee.unlink(y)}catch{}s++}}let n=Y.join(e,"project.json"),o=await Ut(n);if(o!==null){C.setDoc(r,"project",o);try{await ee.unlink(n)}catch{}s++}let i=Y.join(e,"memory");for(let h of["events.jsonl","learnings.jsonl"]){let k=Y.join(i,h);try{let v=(await ee.readFile(k,"utf-8")).split(`
523
+ `).filter(U=>U.trim());if(v.length===0){await ee.unlink(k),s++;continue}let D=C.getDb(r);if(h==="events.jsonl"){let U=D.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)");D.transaction(()=>{for(let F of v)try{let j=JSON.parse(F);U.run(I(j.type??j.action)??"unknown",I(j.taskId??j.task_id),F,I(j.timestamp??j.ts)??new Date().toISOString())}catch{}})()}else{let U=D.prepare("INSERT OR REPLACE INTO memory (key, domain, value, confidence, updated_at) VALUES (?, ?, ?, ?, ?)");D.transaction(()=>{for(let F of v)try{let j=JSON.parse(F),E=`learning:${I(j.taskId??j.timestamp)??Date.now()}`,M=j.tags;U.run(E,I(M?.[0]),F,1,I(j.timestamp)??new Date().toISOString())}catch{}})()}await ee.unlink(k),s++}catch{}}let a=Y.join(e,"sessions"),c=l(h=>{if(!h||!h.id)return;C.getDb(r).prepare(`
494
524
  INSERT OR IGNORE INTO sessions
495
525
  (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
496
526
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
497
- `).run(j(h.id),j(h.projectId)??r,j(h.task)??"",j(h.status)??"completed",j(h.startedAt)??new Date().toISOString(),j(h.pausedAt),j(h.completedAt),Ss(h.duration)??0,h.metrics?JSON.stringify(h.metrics):"{}",h.timeline?JSON.stringify(h.timeline):"[]")},"sessionInsert"),u=Y.join(a,"current.json"),p=await Lt(u);p!==null&&(c(p),await Z.unlink(u).catch(()=>{}),s++);let m=Y.join(a,"archive");try{let h=await Z.readdir(m);for(let w of h){let T=Y.join(m,w);try{if(!(await Z.stat(T)).isDirectory())continue;let M=await Z.readdir(T);for(let $ of M){if(!$.endsWith(".json"))continue;let D=await Lt(Y.join(T,$));D!==null&&(c(D),await Z.unlink(Y.join(T,$)).catch(()=>{}),s++)}(await Z.readdir(T)).length===0&&await Z.rmdir(T).catch(()=>{})}catch{}}(await Z.readdir(m).catch(()=>[])).length===0&&await Z.rmdir(m).catch(()=>{})}catch{}try{(await Z.readdir(a)).length===0&&await Z.rmdir(a).catch(()=>{})}catch{}let d=Y.join(e,"index"),g=[...Ya.map(h=>h.filename),"checksums.json","file-scores.json"];for(let h of g){let k=Y.join(d,h),w=await Lt(k);if(w===null)continue;let T=Ya.find(E=>E.filename===h);T&&(P.run(r,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",T.key,JSON.stringify(w),new Date().toISOString()),Zd(r,T.key,w));try{await Z.unlink(k)}catch{}s++}return s}var Qa,Ya,Za=S(()=>{"use strict";ve();V();ce();Qa=[{filename:"state.json",key:"state"},{filename:"queue.json",key:"queue"},{filename:"ideas.json",key:"ideas"},{filename:"shipped.json",key:"shipped"},{filename:"metrics.json",key:"metrics"},{filename:"velocity.json",key:"velocity"},{filename:"analysis.json",key:"analysis"},{filename:"roadmap.json",key:"roadmap"},{filename:"session.json",key:"session"},{filename:"issues.json",key:"issues"}],Ya=[{filename:"project-index.json",key:"project-index"},{filename:"domains.json",key:"domains"},{filename:"categories-cache.json",key:"categories-cache"}];l(Ro,"migrateJsonToSqlite");l(Rw,"createBackup");l(Xa,"copyFiles");l(Qd,"populateNormalized");l(Aw,"populateTasksFromState");l(Dw,"populateQueueTasks");l(jw,"populateIdeas");l(Iw,"populateShippedFeatures");l($w,"populateMetricsDaily");l(Mw,"populateAnalysis");l(Zd,"populateIndexTables");l(Ow,"populateCategoriesIndex");l(_w,"migrateChecksums");l(Nw,"migrateFileScores");l(Lw,"migrateEventsJsonl");l(Fw,"migrateLearningsJsonl");l(Uw,"migrateSessionFiles");l(Hw,"cleanupJsonFiles");l(j,"toStr");l(Ss,"toNum");l(Lt,"readJsonSafe");l(Ao,"sweepLegacyJson")});function sp(r){return[...r].sort((e,t)=>{let s=tp[e.section]-tp[t.section];return s!==0?s:ep[e.priority]-ep[t.priority]})}function vr(r,e){let t=new Set;return r.filter(s=>{let n=e(s);return t.has(n)?!1:(t.add(n),!0)})}var ep,tp,Do=S(()=>{"use strict";ep={critical:0,high:1,medium:2,low:3},tp={active:0,previously_active:1,backlog:2};l(sp,"sortBySectionAndPriority");l(vr,"uniqueBy")});var ec,be,Xt=S(()=>{"use strict";It();ya();Do();oe();Vs();is();ec=class extends ze{static{l(this,"QueueStorage")}constructor(){super("queue.json",ed)}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 sp(t)[0]||null}async addTask(e,t){let s={...t,id:ye(),createdAt:v(),completed:!1};return await this.update(e,n=>({tasks:[...n.tasks,s],lastUpdated:v()})),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=v(),n=t.map(o=>({...o,id:ye(),createdAt:s,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...n],lastUpdated:s})),await this.publishEvent(e,"queue.tasks_added",{count:n.length,tasks:n.map(o=>({id:o.id,description:o.description}))}),n}async removeTask(e,t){await this.update(e,s=>({tasks:s.tasks.filter(n=>n.id!==t),lastUpdated:v()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let s=null;if(await this.update(e,n=>({tasks:n.tasks.map(i=>i.id===t?(s={...i,completed:!0,completedAt:v()},s):i),lastUpdated:v()})),s){let n=s;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:n.description,completedAt:n.completedAt})}return s}async moveToSection(e,t,s){await this.update(e,n=>({tasks:n.tasks.map(o=>o.id===t?{...o,section:s}:o),lastUpdated:v()}))}async setPriority(e,t,s){await this.update(e,n=>({tasks:n.tasks.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:v()}))}async clearCompleted(e){let s=(await this.read(e)).tasks.filter(n=>n.completed).length;return await this.update(e,n=>({tasks:n.tasks.filter(o=>!o.completed),lastUpdated:v()})),s}async removeStaleCompleted(e){let t=await this.read(e),s=gs(as.QUEUE_COMPLETED_DAYS),n=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<s);if(n.length===0)return 0;Mt.archiveMany(e,n.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(n.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:v()})),await this.publishEvent(e,"queue.stale_removed",{count:n.length}),n.length}},be=new ec});import{z as ee}from"zod";var Gw,np,Vw,Ww,Bw,Jw,zw,qw,Kw,rp,op=S(()=>{"use strict";Gw=ee.enum(["feature","fix","improvement","refactor"]),np=ee.enum(["pass","warning","fail","skipped"]),Vw=ee.enum(["added","changed","fixed","removed"]),Ww=ee.object({hours:ee.number(),minutes:ee.number(),totalMinutes:ee.number()}),Bw=ee.object({filesChanged:ee.number().nullable().optional(),linesAdded:ee.number().nullable().optional(),linesRemoved:ee.number().nullable().optional(),commits:ee.number().nullable().optional()}),Jw=ee.object({description:ee.string(),type:Vw.optional()}),zw=ee.object({lintStatus:np.nullable().optional(),lintDetails:ee.string().optional(),testStatus:np.nullable().optional(),testDetails:ee.string().optional()}),qw=ee.object({hash:ee.string().optional(),message:ee.string().optional(),branch:ee.string().optional()}),Kw=ee.object({id:ee.string(),name:ee.string(),version:ee.string().nullable().optional(),type:Gw,agent:ee.string().optional(),description:ee.string().optional(),changes:ee.array(Jw).optional(),codeSnippets:ee.array(ee.string()).optional(),commit:qw.optional(),codeMetrics:Bw.optional(),qualityMetrics:zw.optional(),quantitativeImpact:ee.string().optional(),duration:Ww.optional(),tasksCompleted:ee.number().nullable().optional(),shippedAt:ee.string(),featureId:ee.string().optional()}),rp=ee.object({shipped:ee.array(Kw),lastUpdated:ee.string()})});var tc,et,Js=S(()=>{"use strict";It();op();oe();Vs();is();tc=class extends ze{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",rp)}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((n,o)=>new Date(o.shippedAt).getTime()-new Date(n.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let s={...t,id:ye(),shippedAt:v()};return await this.update(e,n=>({shipped:[s,...n.shipped],lastUpdated:v()})),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(n=>n.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,n;switch(t){case"week":n=new Date(s.getTime()-10080*60*1e3);break;case"month":n=new Date(s.getFullYear(),s.getMonth(),1);break;case"year":n=new Date(s.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,n,s)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),s=gs(as.SHIPPED_RETENTION_DAYS),n=t.shipped.filter(i=>new Date(i.shippedAt)<s);if(n.length===0)return 0;Mt.archiveMany(e,n.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:v()})),await this.publishEvent(e,"shipped.archived",{count:n.length,oldestShippedAt:n[n.length-1]?.shippedAt}),n.length}},et=new tc});import{z as me}from"zod";var Xw,Yw,ip,XA,YA,QA,bs,ap,Tr=S(()=>{"use strict";Xw=me.enum(["improving","stable","declining"]),Yw=me.object({sprintNumber:me.number(),startDate:me.string(),endDate:me.string(),pointsCompleted:me.number(),tasksCompleted:me.number(),avgVariance:me.number(),estimationAccuracy:me.number()}),ip=me.object({category:me.string(),avgVariance:me.number(),taskCount:me.number()}),XA=me.object({totalPoints:me.number(),sprints:me.number(),estimatedDate:me.string()}),YA=me.object({sprints:me.array(Yw),averageVelocity:me.number(),velocityTrend:Xw,estimationAccuracy:me.number(),overEstimated:me.array(ip),underEstimated:me.array(ip),lastUpdated:me.string()}),QA=me.object({sprintLengthDays:me.number().min(1).max(90).default(7),startDay:me.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:me.number().min(1).max(52).default(6),accuracyTolerance:me.number().min(0).max(100).default(20)}),bs={sprintLengthDays:7,startDay:"monday",windowSize:6,accuracyTolerance:20},ap={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var sc,jo,nc=S(()=>{"use strict";Tr();is();sc=class extends ze{static{l(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:ap,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}},jo=new sc});var Cr,rc,oc,cp=S(()=>{"use strict";cr();oe();Cr=3,rc=class{static{l(this,"OutcomeMemoryLearner")}async learnFromTaskHistory(e,t,s){let n={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return n;let o=[...this.extractFileCochangePatterns(t),...this.extractStackPatterns(t),...this.extractArchitecturePatterns(t),...this.extractGotchaPatterns(t)];n.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Cr){n.patternsQualified++;let a=await this.injectIntoMemory(e,i,s);a&&(n.memoriesInjected++,n.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else n.patternsSkipped++,n.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Cr} occurrences needed`});return n}async learnFromOutcomes(e,t,s){let n={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return n;let o=this.extractOutcomePatterns(t);n.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Cr){n.patternsQualified++;let a=await this.injectIntoMemory(e,i,s);a&&(n.memoriesInjected++,n.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else n.patternsSkipped++,n.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Cr} occurrences needed`});return n}extractFileCochangePatterns(e){let t=new Map;for(let n of e){if(!n.subtaskSummaries)continue;let o=new Set;for(let a of n.subtaskSummaries)if(a.filesChanged)for(let c of a.filesChanged)o.add(c.path);let i=Array.from(o).sort();for(let a=0;a<i.length;a++)for(let c=a+1;c<i.length;c++){let u=`${i[a]}|${i[c]}`,p=t.get(u)||{count:0,tasks:[]};p.count++,p.tasks.push(n.taskId),t.set(u,p)}}let s=[];for(let[n,{count:o,tasks:i}]of t)if(o>=2){let[a,c]=n.split("|");s.push({pattern:`Files "${a}" and "${c}" frequently change together (${o} tasks)`,occurrences:o,confidence:this.calculateConfidence(o),category:"file_cochange",sourceTasks:i})}return s.sort((n,o)=>o.occurrences-n.occurrences)}extractStackPatterns(e){let t=new Map;for(let s of e)if(s.feedback?.stackConfirmed)for(let n of s.feedback.stackConfirmed){let o=t.get(n)||{count:0,tasks:[]};o.count++,o.tasks.push(s.taskId),t.set(n,o)}return Array.from(t.entries()).map(([s,{count:n,tasks:o}])=>({pattern:`Project uses ${s}`,occurrences:n,confidence:this.calculateConfidence(n),category:"tech_stack",sourceTasks:o}))}extractArchitecturePatterns(e){let t=new Map;for(let s of e)if(s.feedback?.patternsDiscovered)for(let n of s.feedback.patternsDiscovered){let o=t.get(n)||{count:0,tasks:[]};o.count++,o.tasks.push(s.taskId),t.set(n,o)}return Array.from(t.entries()).map(([s,{count:n,tasks:o}])=>({pattern:s,occurrences:n,confidence:this.calculateConfidence(n),category:"architecture",sourceTasks:o}))}extractGotchaPatterns(e){let t=new Map;for(let s of e)if(s.feedback?.issuesEncountered)for(let n of s.feedback.issuesEncountered){let o=t.get(n)||{count:0,tasks:[]};o.count++,o.tasks.push(s.taskId),t.set(n,o)}return Array.from(t.entries()).filter(([s,{count:n}])=>n>=2).map(([s,{count:n,tasks:o}])=>({pattern:`Known gotcha: ${s}`,occurrences:n,confidence:this.calculateConfidence(n),category:"gotcha",sourceTasks:o}))}extractOutcomePatterns(e){let t=[],s=new Map,n=new Map;for(let i of e){for(let a of i.learnings.whatWorked){let c=s.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),s.set(a,c)}for(let a of i.learnings.whatDidnt){let c=n.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),n.set(a,c)}}for(let[i,{count:a,ids:c}]of s)t.push({pattern:`What works: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"workflow",sourceTasks:c});for(let[i,{count:a,ids:c}]of n)t.push({pattern:`Known issue: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"gotcha",sourceTasks:c});let o=e.filter(i=>i.effort.variance.percentage>30);return o.length>=Cr&&t.push({pattern:`Tasks are frequently underestimated (${o.length}/${e.length} over 30% variance)`,occurrences:o.length,confidence:this.calculateConfidence(o.length),category:"estimation",sourceTasks:o.map(i=>i.id)}),t}getAllPatterns(e,t=[]){return[...this.extractFileCochangePatterns(e),...this.extractStackPatterns(e),...this.extractArchitecturePatterns(e),...this.extractGotchaPatterns(e),...this.extractOutcomePatterns(t)].sort((s,n)=>n.occurrences-s.occurrences)}async injectIntoMemory(e,t,s){let n=this.getTagsForCategory(t.category),o=`[auto-learned] ${this.getTitleForPattern(t)}`,i=this.formatPatternContent(t),c=(await s.searchMemories(e,t.pattern)).find(u=>u.title.startsWith("[auto-learned]")&&u.content.includes(t.pattern));return c?(await s.updateMemory(e,c.id,{content:i,tags:n}),{action:"updated"}):(await s.createMemory(e,{title:o,content:i,tags:n,userTriggered:!1}),{action:"created"})}calculateConfidence(e){return e>=5?"high":e>=3?"medium":"low"}getTagsForCategory(e){return{file_cochange:[H.FILE_STRUCTURE,H.ARCHITECTURE],tech_stack:[H.TECH_STACK],architecture:[H.ARCHITECTURE,H.CODE_STYLE],estimation:[H.SHIP_WORKFLOW],workflow:[H.SHIP_WORKFLOW,H.CODE_STYLE],gotcha:[H.TEST_BEHAVIOR,H.ARCHITECTURE]}[e]||[]}getTitleForPattern(e){return`${{file_cochange:"File coupling",tech_stack:"Tech stack",architecture:"Architecture pattern",estimation:"Estimation insight",workflow:"Workflow pattern",gotcha:"Known gotcha"}[e.category]}: ${e.pattern.slice(0,80)}`}formatPatternContent(e){let t=["source: auto-learned",`pattern: ${e.pattern}`,`occurrences: ${e.occurrences}`,`confidence: ${e.confidence}`,`category: ${e.category}`,`last_updated: ${v()}`];return e.sourceTasks.length>0&&t.push(`source_tasks: ${e.sourceTasks.slice(0,5).join(", ")}`),t.join(`
498
- `)}},oc=new rc});import{z as x}from"zod";var lp,Qw,Zw,up,ek,tk,sk,nk,rk,ok,ik,dp,ak,ck,uD,pp,mp,gp,fp,lk,Io,hp=S(()=>{"use strict";lp=x.number().min(1).max(5),Qw=x.enum(["exceeded","met","partial","failed"]),Zw=x.enum(["definitely","probably","maybe","no"]),up=x.enum(["scope_creep","underestimated_complexity","technical_debt","external_blockers","learning_curve","requirements_changed","optimistic_estimate","team_changes","other"]),ek=x.object({estimated:x.object({hours:x.number(),confidence:x.enum(["low","medium","high"]).optional(),source:x.enum(["prd","manual","historical"]).optional()}),actual:x.object({hours:x.number(),commits:x.number().optional(),linesAdded:x.number().optional(),linesRemoved:x.number().optional(),sessions:x.number().optional()}),variance:x.object({hours:x.number(),percentage:x.number(),reason:up.optional(),explanation:x.string().optional()})}),tk=x.object({name:x.string(),baseline:x.number().nullable(),target:x.number(),actual:x.number(),unit:x.string(),achieved:x.boolean(),percentOfTarget:x.number()}),sk=x.object({criteria:x.string(),met:x.boolean(),notes:x.string().optional()}),nk=x.object({metrics:x.array(tk),acceptanceCriteria:x.array(sk),overallSuccess:Qw,successScore:x.number().min(0).max(100)}),rk=x.object({category:x.enum(["estimation","technical","process","communication","tooling","architecture","testing","other"]),insight:x.string(),actionable:x.boolean(),action:x.string().optional()}),ok=x.object({whatWorked:x.array(x.string()),whatDidnt:x.array(x.string()),surprises:x.array(x.string()),recommendations:x.array(rk)}),ik=x.object({valueDelivered:x.number().min(1).max(10),userImpact:x.enum(["none","low","medium","high","critical"]),businessImpact:x.enum(["none","low","medium","high","critical"]),roiScore:x.number(),worthIt:Zw,worthItReason:x.string().optional(),alternativeConsidered:x.string().optional(),betterAlternativeExists:x.boolean().optional()}),dp=x.object({id:x.string(),taskId:x.string(),description:x.string(),estimatedMinutes:x.number().optional(),actualMinutes:x.number(),completedAsPlanned:x.boolean(),qualityScore:lp,blockers:x.array(x.string()),agentUsed:x.string().optional(),skillsUsed:x.array(x.string()).optional(),startedAt:x.string(),completedAt:x.string()}),ak=x.object({id:x.string(),featureId:x.string(),featureName:x.string(),prdId:x.string().nullable(),version:x.string().optional(),branch:x.string().optional(),prUrl:x.string().optional(),effort:ek,success:nk.optional(),learnings:ok,roi:ik,rating:lp,taskOutcomes:x.array(dp).optional(),startedAt:x.string(),shippedAt:x.string(),reviewedAt:x.string().optional(),reviewedBy:x.string().optional(),legacy:x.boolean().optional()}),ck=x.object({totalFeatures:x.number(),averageEstimationAccuracy:x.number(),averageSuccessRate:x.number(),averageROI:x.number(),bySuccessLevel:x.object({exceeded:x.number(),met:x.number(),partial:x.number(),failed:x.number()}),variancePatterns:x.array(x.object({reason:up,count:x.number(),averageVariance:x.number()})),topLearnings:x.array(x.object({insight:x.string(),frequency:x.number()}))}),uD=x.object({outcomes:x.array(ak),taskOutcomes:x.array(dp).optional(),aggregates:ck.optional(),lastUpdated:x.string(),lastAggregated:x.string().optional()}),pp={outcomes:[],taskOutcomes:[],lastUpdated:""},mp=l((r,e)=>{let t=e-r,s=r>0?(e-r)/r*100:0;return{hours:t,percentage:Math.round(s*10)/10}},"calculateVariance"),gp=l((r,e)=>e<=0?r*10:Math.round(r*10/e*100)/100,"calculateROIScore"),fp=l(r=>r>=100?"exceeded":r>=80?"met":r>=50?"partial":"failed","determineSuccessLevel"),lk=l(r=>Math.max(0,100-Math.abs(r)),"calculateEstimationAccuracy"),Io=l(r=>{if(r.length===0)return{totalFeatures:0,averageEstimationAccuracy:0,averageSuccessRate:0,averageROI:0,bySuccessLevel:{exceeded:0,met:0,partial:0,failed:0},variancePatterns:[],topLearnings:[]};let e=r.map(p=>lk(p.effort.variance.percentage)),t=r.filter(p=>p.success).map(p=>p.success.successScore),s=r.map(p=>p.roi.roiScore),n={exceeded:r.filter(p=>p.success?.overallSuccess==="exceeded").length,met:r.filter(p=>p.success?.overallSuccess==="met").length,partial:r.filter(p=>p.success?.overallSuccess==="partial").length,failed:r.filter(p=>p.success?.overallSuccess==="failed").length},o=r.filter(p=>p.effort.variance.reason).reduce((p,m)=>{let d=m.effort.variance.reason;return p[d]||(p[d]={count:0,totalVariance:0}),p[d].count++,p[d].totalVariance+=m.effort.variance.percentage,p},{}),i=Object.entries(o).map(([p,m])=>({reason:p,count:m.count,averageVariance:Math.round(m.totalVariance/m.count)})),c=r.flatMap(p=>[...p.learnings.whatWorked,...p.learnings.whatDidnt]).reduce((p,m)=>(p[m]=(p[m]||0)+1,p),{}),u=Object.entries(c).sort((p,m)=>m[1]-p[1]).slice(0,10).map(([p,m])=>({insight:p,frequency:m}));return{totalFeatures:r.length,averageEstimationAccuracy:Math.round(e.reduce((p,m)=>p+m,0)/e.length),averageSuccessRate:t.length>0?Math.round(t.reduce((p,m)=>p+m,0)/t.length):0,averageROI:Math.round(s.reduce((p,m)=>p+m,0)/s.length*100)/100,bySuccessLevel:n,variancePatterns:i,topLearnings:u}},"aggregateOutcomes")});var ic,yp,wp=S(()=>{"use strict";hp();is();oe();ic=class extends ze{static{l(this,"OutcomeStorage")}constructor(){super("outcomes.json")}getDefault(){return{...pp,lastUpdated:""}}getEventType(e){return`outcomes.${e}d`}async addFeatureOutcome(e,t){await this.update(e,s=>({...s,outcomes:[t,...s.outcomes],aggregates:Io([t,...s.outcomes]),lastUpdated:v()})),await this.publishEvent(e,"outcome.recorded",{outcomeId:t.id,featureName:t.featureName,success:t.success?.overallSuccess})}async addTaskOutcome(e,t){await this.update(e,s=>({...s,taskOutcomes:[t,...s.taskOutcomes||[]],lastUpdated:v()}))}async getFeatureOutcomes(e){return(await this.read(e)).outcomes}async getRecentOutcomes(e,t=10){return(await this.read(e)).outcomes.sort((n,o)=>new Date(o.shippedAt).getTime()-new Date(n.shippedAt).getTime()).slice(0,t)}async getTaskOutcomes(e,t){let s=await this.read(e),n=s.taskOutcomes||[];return t?s.outcomes.find(i=>i.featureId===t)?.taskOutcomes||[]:n}async getAggregates(e){let t=await this.read(e);return!t.aggregates&&t.outcomes.length>0?Io(t.outcomes):t.aggregates}async reaggregate(e){await this.update(e,t=>({...t,aggregates:Io(t.outcomes),lastAggregated:v(),lastUpdated:v()}))}migrateFromShipped(e){return e.shipped.map(t=>this.convertShippedToOutcome(t))}convertShippedToOutcome(e){let t=e.duration&&ht(e.duration)||60,s=t/60,n=t/60,o=mp(s,n),i={whatWorked:[],whatDidnt:[],surprises:[],recommendations:[]},a=100,c=gp(5,n);return{id:`out_feat_${e.id}`,featureId:e.featureId||e.id,featureName:e.name,prdId:null,version:e.version||void 0,branch:e.commit?.branch||void 0,prUrl:void 0,effort:{estimated:{hours:s,confidence:"low",source:"manual"},actual:{hours:n,commits:e.codeMetrics?.commits||void 0,linesAdded:e.codeMetrics?.linesAdded||void 0,linesRemoved:e.codeMetrics?.linesRemoved||void 0},variance:o},success:{metrics:[],acceptanceCriteria:[],overallSuccess:fp(a),successScore:a},learnings:i,roi:{valueDelivered:5,userImpact:"medium",businessImpact:"medium",roiScore:c,worthIt:"probably"},rating:3,startedAt:e.shippedAt,shippedAt:e.shippedAt,legacy:!0}}},yp=new ic});import ac from"node:fs/promises";import $o from"node:path";var cc,lc,kp,Sp=S(()=>{"use strict";V();q();cc=".prjct/.prjct-state.md",lc=class{static{l(this,"LocalStateGenerator")}async generate(e,t){let s=$o.join(e,cc);await ac.mkdir($o.dirname(s),{recursive:!0});let n=this.toMarkdown(t);await ac.writeFile(s,n,"utf-8")}async remove(e){try{await ac.unlink($o.join(e,cc))}catch(t){if(!R(t))throw t}}async exists(e){let t=$o.join(e,cc);return C(t)}toMarkdown(e){let t=["<!-- Auto-generated by prjct - DO NOT EDIT -->","<!-- This file provides local state persistence for AI tools -->","","# prjct State",""];if(e.currentTask){let s=e.currentTask;if(t.push("## Current Task"),t.push(""),t.push(`**${s.description}**`),t.push(""),t.push(`- Started: ${s.startedAt}`),s.linearId&&t.push(`- Linear: ${s.linearId}`),s.branch&&t.push(`- Branch: ${s.branch}`),t.push(`- Status: ${s.status||"active"}`),t.push(""),s.subtasks&&s.subtasks.length>0){t.push("### Subtasks"),t.push(""),s.subtasks.forEach((a,c)=>{let u=a.status==="completed"?"\u2705":a.status==="in_progress"?"\u25B6\uFE0F":"\u23F3",p=c===s.currentSubtaskIndex?" \u2190 **Active**":"";t.push(`${c+1}. ${u} ${a.description}${p}`)}),t.push("");let n=s.subtasks.filter(a=>a.status==="completed").length,o=s.subtasks.length,i=Math.round(n/o*100);t.push(`**Progress**: ${n}/${o} (${i}%)`),t.push("")}}else t.push("*No active task*"),t.push(""),t.push('Start a task with `p. task "description"`'),t.push("");if(e.previousTask){let s=e.previousTask;t.push("---"),t.push(""),t.push("## Previous Task"),t.push(""),t.push(`**${s.description}**`),t.push(""),t.push(`- Status: ${s.status}`),s.prUrl&&t.push(`- PR: ${s.prUrl}`),t.push("")}return t.push("---"),t.push(`*Last updated: ${e.lastUpdated||new Date().toISOString()}*`),t.push(""),t.join(`
499
- `)}},kp=new lc});var uc,xt,zs=S(()=>{"use strict";Et();Vs();ce();uc=class{static{l(this,"MemoryService")}async log(e,t,s,n){try{let o=await I.getProjectId(e);if(!o)return;F.appendEvent(o,`memory.${t}`,{...s,author:n})}catch(o){console.error(`Memory log error: ${o instanceof Error?o.message:String(o)}`)}}async getRecent(e,t=100){try{let s=await I.getProjectId(e);return s?F.query(s,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(o=>{let i=JSON.parse(o.data),{author:a,...c}=i;return{timestamp:o.timestamp,action:o.type.replace("memory.",""),data:c,author:a}}):[]}catch(s){return console.error(`Memory read error: ${s instanceof Error?s.message:String(s)}`),[]}}async search(e,t,s=50){let n=await this.getRecent(e,1e3),o=t.toLowerCase();return n.filter(i=>{let a=i.action.toLowerCase().includes(o),c=JSON.stringify(i.data).toLowerCase().includes(o);return a||c}).slice(-s)}async getByAction(e,t,s=50){try{let n=await I.getProjectId(e);return n?F.query(n,"SELECT type, data, timestamp FROM events WHERE type = ? ORDER BY id DESC LIMIT ?",`memory.${t}`,s).reverse().map(i=>{let a=JSON.parse(i.data),{author:c,...u}=a;return{timestamp:i.timestamp,action:i.type.replace("memory.",""),data:u,author:c}}):[]}catch(n){return console.error(`Memory read error: ${n instanceof Error?n.message:String(n)}`),[]}}async clear(e){try{let t=await I.getProjectId(e);if(!t)return;F.run(t,"DELETE FROM events WHERE type LIKE 'memory.%'")}catch(t){console.error(`Memory clear error: ${t instanceof Error?t.message:String(t)}`)}}async getRecentEvents(e,t=100){try{return F.query(e,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(n=>{let o=JSON.parse(n.data);return{timestamp:n.timestamp,action:n.type.replace("memory.",""),...o}})}catch(s){return console.error(`Memory read error: ${s instanceof Error?s.message:String(s)}`),[]}}async capEntries(e){try{let s=F.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(s<=as.MEMORY_MAX_ENTRIES)return 0;let n=s-as.MEMORY_MAX_ENTRIES,o=F.query(e,"SELECT id, type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?",n);Mt.archiveMany(e,o.map((a,c)=>({entityType:"memory_entry",entityId:`memory-${a.timestamp||c}`,entityData:{type:a.type,data:JSON.parse(a.data),timestamp:a.timestamp},summary:a.type.replace("memory.",""),reason:"overflow"})));let i=o[o.length-1]?.id;return i!==void 0&&F.run(e,"DELETE FROM events WHERE type LIKE 'memory.%' AND id <= ?",i),n}catch(t){return console.error(`Memory cap error: ${t instanceof Error?t.message:String(t)}`),0}}},xt=new uc});import uk from"node:path";function dk(r){return co(uk.resolve(r))}function Pr(r){return r.toLowerCase().replace(/[^a-z0-9]+/g,"")}function pk(r){return vr(r,e=>`${Pr(e.name)}::${Pr(e.source)}`)}function mk(r){return vr(r,e=>`${Pr(e.issue)}::${Pr(e.file)}::${Pr(e.source)}`)}var dc,gk,bp,vp=S(()=>{"use strict";ce();Do();yn();l(dk,"repoHash");l(Pr,"normalizeKey");l(pk,"dedupePatterns");l(mk,"dedupeAntiPatterns");dc=class{static{l(this,"PatternExtractor")}async extract(e){let t=dk(e.projectPath),s=[];if(e.context7Verified)for(let u of e.frameworks)s.push({name:`${u} API validation via Context7`,description:`Validate ${u} APIs against current documentation through Context7 before implementation.`,framework:u,source:"context7",confidence:.7});let n=(e.feedback?.patternsDiscovered||[]).map(u=>({name:u,description:`Confirmed during completed tasks: ${u}`,source:"feedback",confidence:.75})),o=(e.feedback?.knownGotchas||[]).map(u=>({issue:u,file:"multiple",suggestion:`Recurring gotcha. Prevent this pattern during implementation: ${u}`,source:"feedback",severity:"medium",confidence:.7})),i=pk([...s,...n]),a=mk([...o]),c=`analysis:derived-rules:${t}`;return P.setDoc(e.projectId,c,{projectId:e.projectId,repoPathHash:t,patterns:i,antiPatterns:a,updatedAt:new Date().toISOString(),version:1}),{patterns:i,antiPatterns:a,repoPathHash:t}}},gk=new dc,bp=gk});import Er from"node:fs/promises";import fk from"node:os";import xr from"node:path";function hk(r){return`# ${r.projectName}
500
- ${r.stack} | ${r.fileCount} files | v${r.version} | Branch: ${r.branch}`}function yk(r){return r.patterns.length===0?"":`
527
+ `).run(I(h.id),I(h.projectId)??r,I(h.task)??"",I(h.status)??"completed",I(h.startedAt)??new Date().toISOString(),I(h.pausedAt),I(h.completedAt),Ss(h.duration)??0,h.metrics?JSON.stringify(h.metrics):"{}",h.timeline?JSON.stringify(h.timeline):"[]")},"sessionInsert"),u=Y.join(a,"current.json"),p=await Ut(u);p!==null&&(c(p),await ee.unlink(u).catch(()=>{}),s++);let m=Y.join(a,"archive");try{let h=await ee.readdir(m);for(let y of h){let v=Y.join(m,y);try{if(!(await ee.stat(v)).isDirectory())continue;let U=await ee.readdir(v);for(let j of U){if(!j.endsWith(".json"))continue;let E=await Ut(Y.join(v,j));E!==null&&(c(E),await ee.unlink(Y.join(v,j)).catch(()=>{}),s++)}(await ee.readdir(v)).length===0&&await ee.rmdir(v).catch(()=>{})}catch{}}(await ee.readdir(m).catch(()=>[])).length===0&&await ee.rmdir(m).catch(()=>{})}catch{}try{(await ee.readdir(a)).length===0&&await ee.rmdir(a).catch(()=>{})}catch{}let d=Y.join(e,"index"),g=[...Za.map(h=>h.filename),"checksums.json","file-scores.json"];for(let h of g){let k=Y.join(d,h),y=await Ut(k);if(y===null)continue;let v=Za.find(D=>D.filename===h);v&&(C.run(r,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",v.key,JSON.stringify(y),new Date().toISOString()),sp(r,v.key,y));try{await ee.unlink(k)}catch{}s++}return s}var ec,Za,tc=S(()=>{"use strict";Te();W();re();ec=[{filename:"state.json",key:"state"},{filename:"queue.json",key:"queue"},{filename:"ideas.json",key:"ideas"},{filename:"shipped.json",key:"shipped"},{filename:"metrics.json",key:"metrics"},{filename:"velocity.json",key:"velocity"},{filename:"analysis.json",key:"analysis"},{filename:"roadmap.json",key:"roadmap"},{filename:"session.json",key:"session"},{filename:"issues.json",key:"issues"}],Za=[{filename:"project-index.json",key:"project-index"},{filename:"domains.json",key:"domains"},{filename:"categories-cache.json",key:"categories-cache"}];l(Io,"migrateJsonToSqlite");l(Iw,"createBackup");l(Qa,"copyFiles");l(tp,"populateNormalized");l($w,"populateTasksFromState");l(Mw,"populateQueueTasks");l(_w,"populateIdeas");l(Ow,"populateShippedFeatures");l(Nw,"populateMetricsDaily");l(Lw,"populateAnalysis");l(sp,"populateIndexTables");l(Fw,"populateCategoriesIndex");l(Uw,"migrateChecksums");l(Hw,"migrateFileScores");l(Gw,"migrateEventsJsonl");l(Ww,"migrateLearningsJsonl");l(Vw,"migrateSessionFiles");l(Bw,"cleanupJsonFiles");l(I,"toStr");l(Ss,"toNum");l(Ut,"readJsonSafe");l($o,"sweepLegacyJson")});function op(r){return[...r].sort((e,t)=>{let s=rp[e.section]-rp[t.section];return s!==0?s:np[e.priority]-np[t.priority]})}function Tr(r,e){let t=new Set;return r.filter(s=>{let n=e(s);return t.has(n)?!1:(t.add(n),!0)})}var np,rp,Mo=S(()=>{"use strict";np={critical:0,high:1,medium:2,low:3},rp={active:0,previously_active:1,backlog:2};l(op,"sortBySectionAndPriority");l(Tr,"uniqueBy")});var sc,be,Xt=S(()=>{"use strict";It();ka();Mo();ie();Ws();is();sc=class extends qe{static{l(this,"QueueStorage")}constructor(){super("queue.json",nd)}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 op(t)[0]||null}async addTask(e,t){let s={...t,id:ye(),createdAt:T(),completed:!1};return await this.update(e,n=>({tasks:[...n.tasks,s],lastUpdated:T()})),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=T(),n=t.map(o=>({...o,id:ye(),createdAt:s,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...n],lastUpdated:s})),await this.publishEvent(e,"queue.tasks_added",{count:n.length,tasks:n.map(o=>({id:o.id,description:o.description}))}),n}async removeTask(e,t){await this.update(e,s=>({tasks:s.tasks.filter(n=>n.id!==t),lastUpdated:T()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let s=null;if(await this.update(e,n=>({tasks:n.tasks.map(i=>i.id===t?(s={...i,completed:!0,completedAt:T()},s):i),lastUpdated:T()})),s){let n=s;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:n.description,completedAt:n.completedAt})}return s}async moveToSection(e,t,s){await this.update(e,n=>({tasks:n.tasks.map(o=>o.id===t?{...o,section:s}:o),lastUpdated:T()}))}async setPriority(e,t,s){await this.update(e,n=>({tasks:n.tasks.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:T()}))}async clearCompleted(e){let s=(await this.read(e)).tasks.filter(n=>n.completed).length;return await this.update(e,n=>({tasks:n.tasks.filter(o=>!o.completed),lastUpdated:T()})),s}async removeStaleCompleted(e){let t=await this.read(e),s=gs(as.QUEUE_COMPLETED_DAYS),n=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<s);if(n.length===0)return 0;Mt.archiveMany(e,n.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(n.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:T()})),await this.publishEvent(e,"queue.stale_removed",{count:n.length}),n.length}},be=new sc});import{z as te}from"zod";var zw,ip,Jw,qw,Kw,Xw,Yw,Qw,Zw,ap,cp=S(()=>{"use strict";zw=te.enum(["feature","fix","improvement","refactor"]),ip=te.enum(["pass","warning","fail","skipped"]),Jw=te.enum(["added","changed","fixed","removed"]),qw=te.object({hours:te.number(),minutes:te.number(),totalMinutes:te.number()}),Kw=te.object({filesChanged:te.number().nullable().optional(),linesAdded:te.number().nullable().optional(),linesRemoved:te.number().nullable().optional(),commits:te.number().nullable().optional()}),Xw=te.object({description:te.string(),type:Jw.optional()}),Yw=te.object({lintStatus:ip.nullable().optional(),lintDetails:te.string().optional(),testStatus:ip.nullable().optional(),testDetails:te.string().optional()}),Qw=te.object({hash:te.string().optional(),message:te.string().optional(),branch:te.string().optional()}),Zw=te.object({id:te.string(),name:te.string(),version:te.string().nullable().optional(),type:zw,agent:te.string().optional(),description:te.string().optional(),changes:te.array(Xw).optional(),codeSnippets:te.array(te.string()).optional(),commit:Qw.optional(),codeMetrics:Kw.optional(),qualityMetrics:Yw.optional(),quantitativeImpact:te.string().optional(),duration:qw.optional(),tasksCompleted:te.number().nullable().optional(),shippedAt:te.string(),featureId:te.string().optional()}),ap=te.object({shipped:te.array(Zw),lastUpdated:te.string()})});var nc,tt,zs=S(()=>{"use strict";It();cp();ie();Ws();is();nc=class extends qe{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",ap)}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((n,o)=>new Date(o.shippedAt).getTime()-new Date(n.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let s={...t,id:ye(),shippedAt:T()};return await this.update(e,n=>({shipped:[s,...n.shipped],lastUpdated:T()})),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(n=>n.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,n;switch(t){case"week":n=new Date(s.getTime()-10080*60*1e3);break;case"month":n=new Date(s.getFullYear(),s.getMonth(),1);break;case"year":n=new Date(s.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,n,s)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),s=gs(as.SHIPPED_RETENTION_DAYS),n=t.shipped.filter(i=>new Date(i.shippedAt)<s);if(n.length===0)return 0;Mt.archiveMany(e,n.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:T()})),await this.publishEvent(e,"shipped.archived",{count:n.length,oldestShippedAt:n[n.length-1]?.shippedAt}),n.length}},tt=new nc});import{z as me}from"zod";var ek,tk,lp,ZA,eD,tD,bs,up,vr=S(()=>{"use strict";ek=me.enum(["improving","stable","declining"]),tk=me.object({sprintNumber:me.number(),startDate:me.string(),endDate:me.string(),pointsCompleted:me.number(),tasksCompleted:me.number(),avgVariance:me.number(),estimationAccuracy:me.number()}),lp=me.object({category:me.string(),avgVariance:me.number(),taskCount:me.number()}),ZA=me.object({totalPoints:me.number(),sprints:me.number(),estimatedDate:me.string()}),eD=me.object({sprints:me.array(tk),averageVelocity:me.number(),velocityTrend:ek,estimationAccuracy:me.number(),overEstimated:me.array(lp),underEstimated:me.array(lp),lastUpdated:me.string()}),tD=me.object({sprintLengthDays:me.number().min(1).max(90).default(7),startDay:me.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:me.number().min(1).max(52).default(6),accuracyTolerance:me.number().min(0).max(100).default(20)}),bs={sprintLengthDays:7,startDay:"monday",windowSize:6,accuracyTolerance:20},up={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var rc,_o,oc=S(()=>{"use strict";vr();is();rc=class extends qe{static{l(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:up,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}},_o=new rc});var Cr,ic,ac,dp=S(()=>{"use strict";cr();ie();Cr=3,ic=class{static{l(this,"OutcomeMemoryLearner")}async learnFromTaskHistory(e,t,s){let n={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return n;let o=[...this.extractFileCochangePatterns(t),...this.extractStackPatterns(t),...this.extractArchitecturePatterns(t),...this.extractGotchaPatterns(t)];n.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Cr){n.patternsQualified++;let a=await this.injectIntoMemory(e,i,s);a&&(n.memoriesInjected++,n.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else n.patternsSkipped++,n.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Cr} occurrences needed`});return n}async learnFromOutcomes(e,t,s){let n={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return n;let o=this.extractOutcomePatterns(t);n.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Cr){n.patternsQualified++;let a=await this.injectIntoMemory(e,i,s);a&&(n.memoriesInjected++,n.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else n.patternsSkipped++,n.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Cr} occurrences needed`});return n}extractFileCochangePatterns(e){let t=new Map;for(let n of e){if(!n.subtaskSummaries)continue;let o=new Set;for(let a of n.subtaskSummaries)if(a.filesChanged)for(let c of a.filesChanged)o.add(c.path);let i=Array.from(o).sort();for(let a=0;a<i.length;a++)for(let c=a+1;c<i.length;c++){let u=`${i[a]}|${i[c]}`,p=t.get(u)||{count:0,tasks:[]};p.count++,p.tasks.push(n.taskId),t.set(u,p)}}let s=[];for(let[n,{count:o,tasks:i}]of t)if(o>=2){let[a,c]=n.split("|");s.push({pattern:`Files "${a}" and "${c}" frequently change together (${o} tasks)`,occurrences:o,confidence:this.calculateConfidence(o),category:"file_cochange",sourceTasks:i})}return s.sort((n,o)=>o.occurrences-n.occurrences)}extractStackPatterns(e){let t=new Map;for(let s of e)if(s.feedback?.stackConfirmed)for(let n of s.feedback.stackConfirmed){let o=t.get(n)||{count:0,tasks:[]};o.count++,o.tasks.push(s.taskId),t.set(n,o)}return Array.from(t.entries()).map(([s,{count:n,tasks:o}])=>({pattern:`Project uses ${s}`,occurrences:n,confidence:this.calculateConfidence(n),category:"tech_stack",sourceTasks:o}))}extractArchitecturePatterns(e){let t=new Map;for(let s of e)if(s.feedback?.patternsDiscovered)for(let n of s.feedback.patternsDiscovered){let o=t.get(n)||{count:0,tasks:[]};o.count++,o.tasks.push(s.taskId),t.set(n,o)}return Array.from(t.entries()).map(([s,{count:n,tasks:o}])=>({pattern:s,occurrences:n,confidence:this.calculateConfidence(n),category:"architecture",sourceTasks:o}))}extractGotchaPatterns(e){let t=new Map;for(let s of e)if(s.feedback?.issuesEncountered)for(let n of s.feedback.issuesEncountered){let o=t.get(n)||{count:0,tasks:[]};o.count++,o.tasks.push(s.taskId),t.set(n,o)}return Array.from(t.entries()).filter(([s,{count:n}])=>n>=2).map(([s,{count:n,tasks:o}])=>({pattern:`Known gotcha: ${s}`,occurrences:n,confidence:this.calculateConfidence(n),category:"gotcha",sourceTasks:o}))}extractOutcomePatterns(e){let t=[],s=new Map,n=new Map;for(let i of e){for(let a of i.learnings.whatWorked){let c=s.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),s.set(a,c)}for(let a of i.learnings.whatDidnt){let c=n.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),n.set(a,c)}}for(let[i,{count:a,ids:c}]of s)t.push({pattern:`What works: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"workflow",sourceTasks:c});for(let[i,{count:a,ids:c}]of n)t.push({pattern:`Known issue: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"gotcha",sourceTasks:c});let o=e.filter(i=>i.effort.variance.percentage>30);return o.length>=Cr&&t.push({pattern:`Tasks are frequently underestimated (${o.length}/${e.length} over 30% variance)`,occurrences:o.length,confidence:this.calculateConfidence(o.length),category:"estimation",sourceTasks:o.map(i=>i.id)}),t}getAllPatterns(e,t=[]){return[...this.extractFileCochangePatterns(e),...this.extractStackPatterns(e),...this.extractArchitecturePatterns(e),...this.extractGotchaPatterns(e),...this.extractOutcomePatterns(t)].sort((s,n)=>n.occurrences-s.occurrences)}async injectIntoMemory(e,t,s){let n=this.getTagsForCategory(t.category),o=`[auto-learned] ${this.getTitleForPattern(t)}`,i=this.formatPatternContent(t),c=(await s.searchMemories(e,t.pattern)).find(u=>u.title.startsWith("[auto-learned]")&&u.content.includes(t.pattern));return c?(await s.updateMemory(e,c.id,{content:i,tags:n}),{action:"updated"}):(await s.createMemory(e,{title:o,content:i,tags:n,userTriggered:!1}),{action:"created"})}calculateConfidence(e){return e>=5?"high":e>=3?"medium":"low"}getTagsForCategory(e){return{file_cochange:[H.FILE_STRUCTURE,H.ARCHITECTURE],tech_stack:[H.TECH_STACK],architecture:[H.ARCHITECTURE,H.CODE_STYLE],estimation:[H.SHIP_WORKFLOW],workflow:[H.SHIP_WORKFLOW,H.CODE_STYLE],gotcha:[H.TEST_BEHAVIOR,H.ARCHITECTURE]}[e]||[]}getTitleForPattern(e){return`${{file_cochange:"File coupling",tech_stack:"Tech stack",architecture:"Architecture pattern",estimation:"Estimation insight",workflow:"Workflow pattern",gotcha:"Known gotcha"}[e.category]}: ${e.pattern.slice(0,80)}`}formatPatternContent(e){let t=["source: auto-learned",`pattern: ${e.pattern}`,`occurrences: ${e.occurrences}`,`confidence: ${e.confidence}`,`category: ${e.category}`,`last_updated: ${T()}`];return e.sourceTasks.length>0&&t.push(`source_tasks: ${e.sourceTasks.slice(0,5).join(", ")}`),t.join(`
528
+ `)}},ac=new ic});import{z as x}from"zod";var pp,sk,nk,mp,rk,ok,ik,ak,ck,lk,uk,gp,dk,pk,mD,fp,hp,yp,wp,mk,Oo,kp=S(()=>{"use strict";pp=x.number().min(1).max(5),sk=x.enum(["exceeded","met","partial","failed"]),nk=x.enum(["definitely","probably","maybe","no"]),mp=x.enum(["scope_creep","underestimated_complexity","technical_debt","external_blockers","learning_curve","requirements_changed","optimistic_estimate","team_changes","other"]),rk=x.object({estimated:x.object({hours:x.number(),confidence:x.enum(["low","medium","high"]).optional(),source:x.enum(["prd","manual","historical"]).optional()}),actual:x.object({hours:x.number(),commits:x.number().optional(),linesAdded:x.number().optional(),linesRemoved:x.number().optional(),sessions:x.number().optional()}),variance:x.object({hours:x.number(),percentage:x.number(),reason:mp.optional(),explanation:x.string().optional()})}),ok=x.object({name:x.string(),baseline:x.number().nullable(),target:x.number(),actual:x.number(),unit:x.string(),achieved:x.boolean(),percentOfTarget:x.number()}),ik=x.object({criteria:x.string(),met:x.boolean(),notes:x.string().optional()}),ak=x.object({metrics:x.array(ok),acceptanceCriteria:x.array(ik),overallSuccess:sk,successScore:x.number().min(0).max(100)}),ck=x.object({category:x.enum(["estimation","technical","process","communication","tooling","architecture","testing","other"]),insight:x.string(),actionable:x.boolean(),action:x.string().optional()}),lk=x.object({whatWorked:x.array(x.string()),whatDidnt:x.array(x.string()),surprises:x.array(x.string()),recommendations:x.array(ck)}),uk=x.object({valueDelivered:x.number().min(1).max(10),userImpact:x.enum(["none","low","medium","high","critical"]),businessImpact:x.enum(["none","low","medium","high","critical"]),roiScore:x.number(),worthIt:nk,worthItReason:x.string().optional(),alternativeConsidered:x.string().optional(),betterAlternativeExists:x.boolean().optional()}),gp=x.object({id:x.string(),taskId:x.string(),description:x.string(),estimatedMinutes:x.number().optional(),actualMinutes:x.number(),completedAsPlanned:x.boolean(),qualityScore:pp,blockers:x.array(x.string()),agentUsed:x.string().optional(),skillsUsed:x.array(x.string()).optional(),startedAt:x.string(),completedAt:x.string()}),dk=x.object({id:x.string(),featureId:x.string(),featureName:x.string(),prdId:x.string().nullable(),version:x.string().optional(),branch:x.string().optional(),prUrl:x.string().optional(),effort:rk,success:ak.optional(),learnings:lk,roi:uk,rating:pp,taskOutcomes:x.array(gp).optional(),startedAt:x.string(),shippedAt:x.string(),reviewedAt:x.string().optional(),reviewedBy:x.string().optional(),legacy:x.boolean().optional()}),pk=x.object({totalFeatures:x.number(),averageEstimationAccuracy:x.number(),averageSuccessRate:x.number(),averageROI:x.number(),bySuccessLevel:x.object({exceeded:x.number(),met:x.number(),partial:x.number(),failed:x.number()}),variancePatterns:x.array(x.object({reason:mp,count:x.number(),averageVariance:x.number()})),topLearnings:x.array(x.object({insight:x.string(),frequency:x.number()}))}),mD=x.object({outcomes:x.array(dk),taskOutcomes:x.array(gp).optional(),aggregates:pk.optional(),lastUpdated:x.string(),lastAggregated:x.string().optional()}),fp={outcomes:[],taskOutcomes:[],lastUpdated:""},hp=l((r,e)=>{let t=e-r,s=r>0?(e-r)/r*100:0;return{hours:t,percentage:Math.round(s*10)/10}},"calculateVariance"),yp=l((r,e)=>e<=0?r*10:Math.round(r*10/e*100)/100,"calculateROIScore"),wp=l(r=>r>=100?"exceeded":r>=80?"met":r>=50?"partial":"failed","determineSuccessLevel"),mk=l(r=>Math.max(0,100-Math.abs(r)),"calculateEstimationAccuracy"),Oo=l(r=>{if(r.length===0)return{totalFeatures:0,averageEstimationAccuracy:0,averageSuccessRate:0,averageROI:0,bySuccessLevel:{exceeded:0,met:0,partial:0,failed:0},variancePatterns:[],topLearnings:[]};let e=r.map(p=>mk(p.effort.variance.percentage)),t=r.filter(p=>p.success).map(p=>p.success.successScore),s=r.map(p=>p.roi.roiScore),n={exceeded:r.filter(p=>p.success?.overallSuccess==="exceeded").length,met:r.filter(p=>p.success?.overallSuccess==="met").length,partial:r.filter(p=>p.success?.overallSuccess==="partial").length,failed:r.filter(p=>p.success?.overallSuccess==="failed").length},o=r.filter(p=>p.effort.variance.reason).reduce((p,m)=>{let d=m.effort.variance.reason;return p[d]||(p[d]={count:0,totalVariance:0}),p[d].count++,p[d].totalVariance+=m.effort.variance.percentage,p},{}),i=Object.entries(o).map(([p,m])=>({reason:p,count:m.count,averageVariance:Math.round(m.totalVariance/m.count)})),c=r.flatMap(p=>[...p.learnings.whatWorked,...p.learnings.whatDidnt]).reduce((p,m)=>(p[m]=(p[m]||0)+1,p),{}),u=Object.entries(c).sort((p,m)=>m[1]-p[1]).slice(0,10).map(([p,m])=>({insight:p,frequency:m}));return{totalFeatures:r.length,averageEstimationAccuracy:Math.round(e.reduce((p,m)=>p+m,0)/e.length),averageSuccessRate:t.length>0?Math.round(t.reduce((p,m)=>p+m,0)/t.length):0,averageROI:Math.round(s.reduce((p,m)=>p+m,0)/s.length*100)/100,bySuccessLevel:n,variancePatterns:i,topLearnings:u}},"aggregateOutcomes")});var cc,Sp,bp=S(()=>{"use strict";kp();is();ie();cc=class extends qe{static{l(this,"OutcomeStorage")}constructor(){super("outcomes.json")}getDefault(){return{...fp,lastUpdated:""}}getEventType(e){return`outcomes.${e}d`}async addFeatureOutcome(e,t){await this.update(e,s=>({...s,outcomes:[t,...s.outcomes],aggregates:Oo([t,...s.outcomes]),lastUpdated:T()})),await this.publishEvent(e,"outcome.recorded",{outcomeId:t.id,featureName:t.featureName,success:t.success?.overallSuccess})}async addTaskOutcome(e,t){await this.update(e,s=>({...s,taskOutcomes:[t,...s.taskOutcomes||[]],lastUpdated:T()}))}async getFeatureOutcomes(e){return(await this.read(e)).outcomes}async getRecentOutcomes(e,t=10){return(await this.read(e)).outcomes.sort((n,o)=>new Date(o.shippedAt).getTime()-new Date(n.shippedAt).getTime()).slice(0,t)}async getTaskOutcomes(e,t){let s=await this.read(e),n=s.taskOutcomes||[];return t?s.outcomes.find(i=>i.featureId===t)?.taskOutcomes||[]:n}async getAggregates(e){let t=await this.read(e);return!t.aggregates&&t.outcomes.length>0?Oo(t.outcomes):t.aggregates}async reaggregate(e){await this.update(e,t=>({...t,aggregates:Oo(t.outcomes),lastAggregated:T(),lastUpdated:T()}))}migrateFromShipped(e){return e.shipped.map(t=>this.convertShippedToOutcome(t))}convertShippedToOutcome(e){let t=e.duration&&yt(e.duration)||60,s=t/60,n=t/60,o=hp(s,n),i={whatWorked:[],whatDidnt:[],surprises:[],recommendations:[]},a=100,c=yp(5,n);return{id:`out_feat_${e.id}`,featureId:e.featureId||e.id,featureName:e.name,prdId:null,version:e.version||void 0,branch:e.commit?.branch||void 0,prUrl:void 0,effort:{estimated:{hours:s,confidence:"low",source:"manual"},actual:{hours:n,commits:e.codeMetrics?.commits||void 0,linesAdded:e.codeMetrics?.linesAdded||void 0,linesRemoved:e.codeMetrics?.linesRemoved||void 0},variance:o},success:{metrics:[],acceptanceCriteria:[],overallSuccess:wp(a),successScore:a},learnings:i,roi:{valueDelivered:5,userImpact:"medium",businessImpact:"medium",roiScore:c,worthIt:"probably"},rating:3,startedAt:e.shippedAt,shippedAt:e.shippedAt,legacy:!0}}},Sp=new cc});import lc from"node:fs/promises";import No from"node:path";var uc,dc,Tp,vp=S(()=>{"use strict";W();K();uc=".prjct/.prjct-state.md",dc=class{static{l(this,"LocalStateGenerator")}async generate(e,t){let s=No.join(e,uc);await lc.mkdir(No.dirname(s),{recursive:!0});let n=this.toMarkdown(t);await lc.writeFile(s,n,"utf-8")}async remove(e){try{await lc.unlink(No.join(e,uc))}catch(t){if(!R(t))throw t}}async exists(e){let t=No.join(e,uc);return P(t)}toMarkdown(e){let t=["<!-- Auto-generated by prjct - DO NOT EDIT -->","<!-- This file provides local state persistence for AI tools -->","","# prjct State",""];if(e.currentTask){let s=e.currentTask;if(t.push("## Current Task"),t.push(""),t.push(`**${s.description}**`),t.push(""),t.push(`- Started: ${s.startedAt}`),s.linearId&&t.push(`- Linear: ${s.linearId}`),s.branch&&t.push(`- Branch: ${s.branch}`),t.push(`- Status: ${s.status||"active"}`),t.push(""),s.subtasks&&s.subtasks.length>0){t.push("### Subtasks"),t.push(""),s.subtasks.forEach((a,c)=>{let u=a.status==="completed"?"\u2705":a.status==="in_progress"?"\u25B6\uFE0F":"\u23F3",p=c===s.currentSubtaskIndex?" \u2190 **Active**":"";t.push(`${c+1}. ${u} ${a.description}${p}`)}),t.push("");let n=s.subtasks.filter(a=>a.status==="completed").length,o=s.subtasks.length,i=Math.round(n/o*100);t.push(`**Progress**: ${n}/${o} (${i}%)`),t.push("")}}else t.push("*No active task*"),t.push(""),t.push('Start a task with `p. task "description"`'),t.push("");if(e.previousTask){let s=e.previousTask;t.push("---"),t.push(""),t.push("## Previous Task"),t.push(""),t.push(`**${s.description}**`),t.push(""),t.push(`- Status: ${s.status}`),s.prUrl&&t.push(`- PR: ${s.prUrl}`),t.push("")}return t.push("---"),t.push(`*Last updated: ${e.lastUpdated||new Date().toISOString()}*`),t.push(""),t.join(`
529
+ `)}},Tp=new dc});var pc,xt,Js=S(()=>{"use strict";Et();Ws();re();pc=class{static{l(this,"MemoryService")}async log(e,t,s,n){try{let o=await $.getProjectId(e);if(!o)return;N.appendEvent(o,`memory.${t}`,{...s,author:n})}catch(o){console.error(`Memory log error: ${o instanceof Error?o.message:String(o)}`)}}async getRecent(e,t=100){try{let s=await $.getProjectId(e);return s?N.query(s,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(o=>{let i=JSON.parse(o.data),{author:a,...c}=i;return{timestamp:o.timestamp,action:o.type.replace("memory.",""),data:c,author:a}}):[]}catch(s){return console.error(`Memory read error: ${s instanceof Error?s.message:String(s)}`),[]}}async search(e,t,s=50){let n=await this.getRecent(e,1e3),o=t.toLowerCase();return n.filter(i=>{let a=i.action.toLowerCase().includes(o),c=JSON.stringify(i.data).toLowerCase().includes(o);return a||c}).slice(-s)}async getByAction(e,t,s=50){try{let n=await $.getProjectId(e);return n?N.query(n,"SELECT type, data, timestamp FROM events WHERE type = ? ORDER BY id DESC LIMIT ?",`memory.${t}`,s).reverse().map(i=>{let a=JSON.parse(i.data),{author:c,...u}=a;return{timestamp:i.timestamp,action:i.type.replace("memory.",""),data:u,author:c}}):[]}catch(n){return console.error(`Memory read error: ${n instanceof Error?n.message:String(n)}`),[]}}async clear(e){try{let t=await $.getProjectId(e);if(!t)return;N.run(t,"DELETE FROM events WHERE type LIKE 'memory.%'")}catch(t){console.error(`Memory clear error: ${t instanceof Error?t.message:String(t)}`)}}async getRecentEvents(e,t=100){try{return N.query(e,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(n=>{let o=JSON.parse(n.data);return{timestamp:n.timestamp,action:n.type.replace("memory.",""),...o}})}catch(s){return console.error(`Memory read error: ${s instanceof Error?s.message:String(s)}`),[]}}async capEntries(e){try{let s=N.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(s<=as.MEMORY_MAX_ENTRIES)return 0;let n=s-as.MEMORY_MAX_ENTRIES,o=N.query(e,"SELECT id, type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?",n);Mt.archiveMany(e,o.map((a,c)=>({entityType:"memory_entry",entityId:`memory-${a.timestamp||c}`,entityData:{type:a.type,data:JSON.parse(a.data),timestamp:a.timestamp},summary:a.type.replace("memory.",""),reason:"overflow"})));let i=o[o.length-1]?.id;return i!==void 0&&N.run(e,"DELETE FROM events WHERE type LIKE 'memory.%' AND id <= ?",i),n}catch(t){return console.error(`Memory cap error: ${t instanceof Error?t.message:String(t)}`),0}}},xt=new pc});import gk from"node:path";function fk(r){return mo(gk.resolve(r))}function Pr(r){return r.toLowerCase().replace(/[^a-z0-9]+/g,"")}function hk(r){return Tr(r,e=>`${Pr(e.name)}::${Pr(e.source)}`)}function yk(r){return Tr(r,e=>`${Pr(e.issue)}::${Pr(e.file)}::${Pr(e.source)}`)}var mc,wk,Cp,Pp=S(()=>{"use strict";re();Mo();wn();l(fk,"repoHash");l(Pr,"normalizeKey");l(hk,"dedupePatterns");l(yk,"dedupeAntiPatterns");mc=class{static{l(this,"PatternExtractor")}async extract(e){let t=fk(e.projectPath),s=[];if(e.context7Verified)for(let u of e.frameworks)s.push({name:`${u} API validation via Context7`,description:`Validate ${u} APIs against current documentation through Context7 before implementation.`,framework:u,source:"context7",confidence:.7});let n=(e.feedback?.patternsDiscovered||[]).map(u=>({name:u,description:`Confirmed during completed tasks: ${u}`,source:"feedback",confidence:.75})),o=(e.feedback?.knownGotchas||[]).map(u=>({issue:u,file:"multiple",suggestion:`Recurring gotcha. Prevent this pattern during implementation: ${u}`,source:"feedback",severity:"medium",confidence:.7})),i=hk([...s,...n]),a=yk([...o]),c=`analysis:derived-rules:${t}`;return C.setDoc(e.projectId,c,{projectId:e.projectId,repoPathHash:t,patterns:i,antiPatterns:a,updatedAt:new Date().toISOString(),version:1}),{patterns:i,antiPatterns:a,repoPathHash:t}}},wk=new mc,Cp=wk});import Er from"node:fs/promises";import kk from"node:os";import xr from"node:path";function Sk(r){return`# ${r.projectName}
530
+ ${r.stack} | ${r.fileCount} files | v${r.version} | Branch: ${r.branch}`}function bk(r){return r.patterns.length===0?"":`
501
531
  ## Patterns
502
532
  ${r.patterns.slice(0,6).map(t=>`- **${t.name}**: ${t.description}${t.location?` (${t.location})`:""}`).join(`
503
533
  `)}
504
- `}function wk(r){if(r.antiPatterns.length===0)return"";let e={high:"HIGH",medium:"MEDIUM",low:"LOW"};return`
534
+ `}function Tk(r){if(r.antiPatterns.length===0)return"";let e={high:"HIGH",medium:"MEDIUM",low:"LOW"};return`
505
535
  ## Anti-Patterns
506
536
  ${r.antiPatterns.slice(0,6).map(s=>`- ${e[s.severity]||"MEDIUM"}: ${s.issue} in \`${s.file}\` \u2014 ${s.suggestion}`).join(`
507
537
  `)}
508
- `}function kk(r){return r.knownGotchas.length===0?"":`
538
+ `}function vk(r){return r.knownGotchas.length===0?"":`
509
539
  ## Known Gotchas
510
540
  ${r.knownGotchas.slice(0,5).map(t=>`- ${t}`).join(`
511
541
  `)}
512
- `}function Sk(r){return r.recentShipped.length===0?"":`
542
+ `}function Ck(r){return r.recentShipped.length===0?"":`
513
543
  ## Recent Deliveries
514
544
  ${r.recentShipped.slice(0,5).map(t=>{let s=[`"${t.name}"`,t.type];return t.duration&&s.push(t.duration),t.filesChanged&&s.push(`${t.filesChanged} files`),`- ${s.join(" \u2014 ")}`}).join(`
515
545
  `)}
516
- `}function bk(r){if(!r.velocity)return"";let e=[];return r.velocity.avgPoints!=null&&e.push(`${r.velocity.avgPoints} pts/sprint`),r.velocity.trend&&e.push(r.velocity.trend),r.velocity.accuracy!=null&&e.push(`Estimation accuracy: ${r.velocity.accuracy}%`),e.length===0?"":`
546
+ `}function Pk(r){if(!r.velocity)return"";let e=[];return r.velocity.avgPoints!=null&&e.push(`${r.velocity.avgPoints} pts/sprint`),r.velocity.trend&&e.push(r.velocity.trend),r.velocity.accuracy!=null&&e.push(`Estimation accuracy: ${r.velocity.accuracy}%`),e.length===0?"":`
517
547
  ## Velocity
518
548
  ${e.join(" | ")}
519
- `}function vk(r){let e=[["Build",r.build],["Test",r.test],["Lint",r.lint],["Dev",r.dev],["Format",r.format]].filter(([t,s])=>s);return e.length===0?"":`
549
+ `}function Ek(r){let e=[["Build",r.build],["Test",r.test],["Lint",r.lint],["Dev",r.dev],["Format",r.format]].filter(([t,s])=>s);return e.length===0?"":`
520
550
  ## Commands
521
551
  | Action | Command |
522
552
  |--------|---------|
523
553
  ${e.map(([t,s])=>`| ${t} | \`${s}\` |`).join(`
524
554
  `)}
525
- `}function Tk(r){let e=[];if(r.hasActiveTask&&e.push(`Active task: **${r.activeTaskDescription}**`),r.pausedTasks.length>0)for(let s of r.pausedTasks.slice(0,3))e.push(`Paused: ${s.description} (${s.pausedAt})`);if(r.backlogCount>0){let s=r.topBacklog.slice(0,3).map(n=>`${n.description} [${n.priority}]`).join(", ");e.push(`Backlog: ${r.backlogCount} items${s?` \u2014 ${s}`:""}`)}let t=[];return r.ideasCount>0&&t.push(`Ideas: ${r.ideasCount} pending`),r.shippedCount>0&&t.push(`Shipped: ${r.shippedCount}`),t.length>0&&e.push(t.join(" | ")),e.length===0?"":`
555
+ `}function xk(r){let e=[];if(r.hasActiveTask&&e.push(`Active task: **${r.activeTaskDescription}**`),r.pausedTasks.length>0)for(let s of r.pausedTasks.slice(0,3))e.push(`Paused: ${s.description} (${s.pausedAt})`);if(r.backlogCount>0){let s=r.topBacklog.slice(0,3).map(n=>`${n.description} [${n.priority}]`).join(", ");e.push(`Backlog: ${r.backlogCount} items${s?` \u2014 ${s}`:""}`)}let t=[];return r.ideasCount>0&&t.push(`Ideas: ${r.ideasCount} pending`),r.shippedCount>0&&t.push(`Shipped: ${r.shippedCount}`),t.length>0&&e.push(t.join(" | ")),e.length===0?"":`
526
556
  ## State
527
557
  ${e.join(`
528
558
  `)}
529
- `}function Ck(r){return r.userPatterns.length===0?"":`
559
+ `}function Rk(r){return r.userPatterns.length===0?"":`
530
560
  ## User Patterns
531
561
  ${r.userPatterns.slice(0,8).map(t=>`- ${t}`).join(`
532
562
  `)}
533
- `}function Pk(r){return[yk(r),wk(r),kk(r),Sk(r),bk(r),vk(r.commands),Tk(r),Ck(r)].filter(Boolean).join("")}function Ek(r,e){let t=r.userInvocable!==!1;return`---
563
+ `}function Ak(r){return[bk(r),Tk(r),vk(r),Ck(r),Pk(r),Ek(r.commands),xk(r),Rk(r)].filter(Boolean).join("")}function Dk(r,e){let t=r.userInvocable!==!1;return`---
534
564
  description: "${r.description} (${e.projectName}, ${e.stack})"
535
565
  allowed-tools: [${r.allowedTools.map(s=>`"${s}"`).join(", ")}]
536
566
  user-invocable: ${t}
537
- ---`}function xk(r,e){return`${Ek(r,e)}
567
+ ---`}function jk(r,e){return`${Dk(r,e)}
538
568
 
539
- ${r.body(e)}`}var pc,mc,Tp,Cp=S(()=>{"use strict";ss();ns();l(hk,"formatProjectHeader");l(yk,"formatPatterns");l(wk,"formatAntiPatterns");l(kk,"formatGotchas");l(Sk,"formatRecentShipped");l(bk,"formatVelocity");l(vk,"formatCommands");l(Tk,"formatState");l(Ck,"formatUserPatterns");l(Pk,"formatRichContext");pc=[{name:"prjct-context",description:"Project context with state and user patterns",allowedTools:[],userInvocable:!1,condition:l(()=>!0,"condition"),body:l(r=>`${hk(r)}
540
- ${Pk(r)}`,"body")},{name:"prjct-task",description:"Start a task with full project context",allowedTools:["Bash","Read","Write","Edit","Glob","Grep","Task","AskUserQuestion"],condition:l(()=>!0,"condition"),body:l(r=>'## Workflow\n\n### Register Task\n```bash\nprjct task "$ARGUMENTS" --md\n```\nRead the Context Contract from CLI output \u2014 it has file paths, subtasks, and scope.\nIf CLI output is JSON with `options`, present choices to user.\n\n### Execute\n- Create feature branch if on main: `git checkout -b {type}/{slug}`\n- Work through subtasks; mark each done: `prjct done --md`\n### Ship\nWhen complete: `p. ship` or `prjct ship --md`\n',"body")},{name:"prjct-done",description:'Marks the current task as complete and feeds the feedback loop. Use when the user says "done", "finished", "ship it", or wants to complete current work. Completion data flows to sync \u2192 skill regeneration.',allowedTools:["Bash","AskUserQuestion"],condition:l(()=>!0,"condition"),body:l(r=>{let e=["## Workflow"];return r.hasActiveTask&&e.push(`
569
+ ${r.body(e)}`}var gc,fc,Ep,xp=S(()=>{"use strict";ss();ns();l(Sk,"formatProjectHeader");l(bk,"formatPatterns");l(Tk,"formatAntiPatterns");l(vk,"formatGotchas");l(Ck,"formatRecentShipped");l(Pk,"formatVelocity");l(Ek,"formatCommands");l(xk,"formatState");l(Rk,"formatUserPatterns");l(Ak,"formatRichContext");gc=[{name:"prjct-context",description:"Project context with state and user patterns",allowedTools:[],userInvocable:!1,condition:l(()=>!0,"condition"),body:l(r=>`${Sk(r)}
570
+ ${Ak(r)}`,"body")},{name:"prjct-task",description:"Start a task with full project context",allowedTools:["Bash","Read","Write","Edit","Glob","Grep","Task","AskUserQuestion"],condition:l(()=>!0,"condition"),body:l(r=>'## Workflow\n\n### Register Task\n```bash\nprjct task "$ARGUMENTS" --md\n```\nRead the Context Contract from CLI output \u2014 it has file paths, subtasks, and scope.\nIf CLI output is JSON with `options`, present choices to user.\n\n### Execute\n- Create feature branch if on main: `git checkout -b {type}/{slug}`\n- Work through subtasks; mark each done: `prjct done --md`\n### Ship\nWhen complete: `p. ship` or `prjct ship --md`\n',"body")},{name:"prjct-done",description:'Marks the current task as complete and feeds the feedback loop. Use when the user says "done", "finished", "ship it", or wants to complete current work. Completion data flows to sync \u2192 skill regeneration.',allowedTools:["Bash","AskUserQuestion"],condition:l(()=>!0,"condition"),body:l(r=>{let e=["## Workflow"];return r.hasActiveTask&&e.push(`
541
571
  Active task: **${r.activeTaskDescription}**`),e.push('\n```bash\nprjct done "$ARGUMENTS" --md\n```\nRead CLI output for completion summary and next steps.\n'),e.join(`
542
572
  `)},"body")},{name:"prjct-ship",description:"Ship feature: PR, version bump, changelog. Auto-completes active task if one exists before shipping.",allowedTools:["Bash","Read","AskUserQuestion"],condition:l(()=>!0,"condition"),body:l(r=>`## Workflow
543
573
 
@@ -620,48 +650,47 @@ prjct tokens <input_tokens> <output_tokens>
620
650
 
621
651
  Tokens accumulate \u2014 call multiple times during a task and they add up.
622
652
  Token totals are saved to task history on completion for cost comparison across tasks.
623
- `,"body")}];l(Ek,"buildFrontmatter");l(xk,"buildSkillContent");mc=class{static{l(this,"SkillGenerator")}async generateAndInstall(e,t={backlogCount:0,completedTaskCount:0,pausedTaskCount:0,hasActiveTask:!1},s){let n={generated:[],skipped:[]},o={projectName:e.stats.name,stack:[...e.stats.languages,...e.stats.frameworks].filter(Boolean).join("/")||e.stats.ecosystem,branch:e.git.branch,commands:e.commands,projectId:e.projectId,version:s?.version??e.stats.version??"0.0.0",fileCount:s?.fileCount??e.stats.fileCount??0,patterns:s?.patterns??[],antiPatterns:s?.antiPatterns??[],recentShipped:s?.recentShipped??[],velocity:s?.velocity??null,backlogCount:s?.backlogCount??t.backlogCount,completedTaskCount:s?.completedTaskCount??t.completedTaskCount,pausedTaskCount:s?.pausedTaskCount??t.pausedTaskCount,knownGotchas:s?.knownGotchas??[],hasActiveTask:s?.hasActiveTask??t.hasActiveTask,activeTaskDescription:s?.activeTaskDescription??"",pausedTasks:s?.pausedTasks??[],topBacklog:s?.topBacklog??[],ideasCount:s?.ideasCount??0,shippedCount:s?.shippedCount??0,userPatterns:s?.userPatterns??[]},i=xr.join(fk.homedir(),".claude","skills");for(let c of pc){if(!c.condition(t)){n.skipped.push({name:c.name,reason:"condition not met"}),await Er.rm(xr.join(i,c.name),{recursive:!0,force:!0}).catch(()=>{});continue}try{let u=xk(c,o),p=xr.join(i,c.name),m=xr.join(p,"SKILL.md");await Er.mkdir(p,{recursive:!0}),await Er.writeFile(m,u,"utf-8"),n.generated.push({name:c.name,path:m})}catch(u){W.debug(`Failed to generate skill ${c.name}`,{error:ue(u)}),n.skipped.push({name:c.name,reason:ue(u)})}}let a=new Set(pc.map(c=>c.name));try{let c=await Er.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let u of c)u.isDirectory()&&u.name.startsWith("prjct-")&&!a.has(u.name)&&await Er.rm(xr.join(i,u.name),{recursive:!0,force:!0}).catch(()=>{})}catch{}return n.generated.length>0&&W.info("Generated native workflow skills",{count:n.generated.length,skills:n.generated.map(c=>c.name)}),n}getDefinitions(){return pc}},Tp=new mc});var Pp=S(()=>{"use strict"});import Rk from"node:fs/promises";import Ep from"node:path";var Mo,xp=S(()=>{"use strict";q();Mo=class{static{l(this,"StackDetector")}projectPath;constructor(e){this.projectPath=e}async detect(){let e={hasFrontend:!1,hasBackend:!1,hasDatabase:!1,hasDocker:!1,hasTesting:!1,frontendType:null,frameworks:[]},t=await this.readPackageJson();if(t){let s={...t.dependencies,...t.devDependencies};this.detectFrontend(s,e),this.detectBackend(s,e),this.detectDatabase(s,e),this.detectTesting(s,t,e),this.collectFrameworks(s,e)}return e.hasDocker=await this.detectDocker(),e}detectFrontend(e,t){(e.react||e.vue||e.svelte||e["@angular/core"])&&(t.hasFrontend=!0,t.frontendType="web"),(e["react-native"]||e.expo)&&(t.hasFrontend=!0,t.frontendType=t.frontendType==="web"?"both":"mobile")}detectBackend(e,t){["express","fastify","hono","koa","@nestjs/core","nest","@hapi/hapi","restify","polka"].some(n=>e[n])&&(t.hasBackend=!0)}detectDatabase(e,t){["prisma","@prisma/client","mongoose","pg","mysql2","sequelize","typeorm","drizzle-orm","knex","better-sqlite3","mongodb","redis","ioredis"].some(n=>e[n])&&(t.hasDatabase=!0)}detectTesting(e,t,s){["jest","vitest","mocha","@testing-library/react","@testing-library/vue","cypress","playwright","@playwright/test","ava","tap","bun-types"].some(o=>e[o]||t.devDependencies?.[o])&&(s.hasTesting=!0)}async detectDocker(){let e=["Dockerfile","docker-compose.yml","docker-compose.yaml",".dockerignore"];for(let t of e)if(await this.fileExistsInProject(t))return!0;return!1}collectFrameworks(e,t){e.react&&t.frameworks.push("React"),e.next&&t.frameworks.push("Next.js"),e.vue&&t.frameworks.push("Vue"),e.nuxt&&t.frameworks.push("Nuxt"),e.svelte&&t.frameworks.push("Svelte"),e["@angular/core"]&&t.frameworks.push("Angular"),e["react-native"]&&t.frameworks.push("React Native"),e.expo&&t.frameworks.push("Expo"),e.express&&t.frameworks.push("Express"),e.fastify&&t.frameworks.push("Fastify"),e.hono&&t.frameworks.push("Hono"),e.koa&&t.frameworks.push("Koa"),(e["@nestjs/core"]||e.nest)&&t.frameworks.push("NestJS"),e.astro&&t.frameworks.push("Astro"),e.remix&&t.frameworks.push("Remix"),e.gatsby&&t.frameworks.push("Gatsby")}async readPackageJson(){try{let e=Ep.join(this.projectPath,"package.json"),t=await Rk.readFile(e,"utf-8");return JSON.parse(t)}catch{return null}}async fileExistsInProject(e){return C(Ep.join(this.projectPath,e))}}});import gc from"node:path";async function Rp(r){let e={branch:"main",commits:0,contributors:0,hasChanges:!1,stagedFiles:[],modifiedFiles:[],untrackedFiles:[],recentCommits:[],weeklyCommits:0};try{let{stdout:t}=await N("git branch --show-current",{cwd:r});e.branch=t.trim()||"main";let{stdout:s}=await N("git rev-list --count HEAD",{cwd:r});e.commits=parseInt(s.trim(),10)||0;let{stdout:n}=await N("git shortlog -sn --all | wc -l",{cwd:r});e.contributors=parseInt(n.trim(),10)||0;let{stdout:o}=await N("git status --porcelain",{cwd:r}),i=o.trim().split(`
624
- `).filter(Boolean);e.hasChanges=i.length>0;for(let u of i){let p=u.substring(0,2),m=u.substring(3);p.startsWith("A")||p.startsWith("M ")?e.stagedFiles.push(m):p.includes("M")?e.modifiedFiles.push(m):p.startsWith("??")&&e.untrackedFiles.push(m)}let{stdout:a}=await N('git log --oneline -20 --pretty=format:"%h|%s|%ad" --date=short',{cwd:r});e.recentCommits=a.split(`
625
- `).filter(Boolean).map(u=>{let[p,m,d]=u.split("|");return{hash:p,message:m,date:d}});let{stdout:c}=await N('git log --oneline --since="1 week ago" | wc -l',{cwd:r});e.weeklyCommits=parseInt(c.trim(),10)||0}catch(t){W.debug("Git analysis failed (not a git repo?)",{error:ue(t)})}return e}async function Ft(r,e){let t=await C(gc.join(r,e));return t||W.debug("File not found",{filename:e}),t}async function Ap(r){let e={fileCount:0,version:"0.0.0",name:gc.basename(r),ecosystem:"unknown",projectType:"simple",languages:[],frameworks:[]};try{let{stdout:t}=await N('find . -type f \\( -name "*.js" -o -name "*.ts" -o -name "*.tsx" -o -name "*.py" -o -name "*.go" -o -name "*.rs" \\) -not -path "./node_modules/*" -not -path "./.git/*" | wc -l',{cwd:r});e.fileCount=parseInt(t.trim(),10)||0}catch(t){W.debug("File count failed",{path:r,error:ue(t)}),e.fileCount=0}try{let t=gc.join(r,"package.json"),s=await xe(t);if(!s)throw new Error("No package.json found");e.version=s.version||"0.0.0",e.name=s.name||e.name,e.ecosystem="JavaScript",s.devDependencies?.typescript||await Ft(r,"tsconfig.json")?e.languages.push("TypeScript"):e.languages.push("JavaScript")}catch(t){W.debug("No package.json found",{path:r,error:ue(t)})}return await Ft(r,"Cargo.toml")?(e.ecosystem="Rust",e.languages.push("Rust")):await Ft(r,"go.mod")?(e.ecosystem="Go",e.languages.push("Go")):(await Ft(r,"requirements.txt")||await Ft(r,"pyproject.toml"))&&(e.ecosystem="Python",e.languages.push("Python")),e.fileCount>300||e.frameworks.length>=3?e.projectType="enterprise":(e.fileCount>50||e.frameworks.length>=2)&&(e.projectType="complex"),e}async function Dp(r){let e={install:"npm install",run:"npm run",test:"npm test",build:"npm run build",dev:"npm run dev",lint:"npm run lint",format:"npm run format"};return await Ft(r,"bun.lockb")||await Ft(r,"bun.lock")?(e.install="bun install",e.run="bun run",e.test="bun test",e.build="bun run build",e.dev="bun run dev",e.lint="bun run lint",e.format="bun run format"):await Ft(r,"pnpm-lock.yaml")?(e.install="pnpm install",e.run="pnpm run",e.test="pnpm test",e.build="pnpm run build",e.dev="pnpm run dev",e.lint="pnpm run lint",e.format="pnpm run format"):await Ft(r,"yarn.lock")&&(e.install="yarn",e.run="yarn",e.test="yarn test",e.build="yarn build",e.dev="yarn dev",e.lint="yarn lint",e.format="yarn format"),await Ft(r,"Cargo.toml")&&(e.install="cargo build",e.run="cargo run",e.test="cargo test",e.build="cargo build --release",e.dev="cargo run",e.lint="cargo clippy",e.format="cargo fmt"),await Ft(r,"go.mod")&&(e.install="go mod download",e.run="go run .",e.test="go test ./...",e.build="go build",e.dev="go run .",e.lint="golangci-lint run",e.format="go fmt ./..."),e}async function jp(r){return new Mo(r).detect()}var Ip=S(()=>{"use strict";ss();Pp();Ue();q();ns();xp();l(Rp,"analyzeGit");l(Ft,"fileExistsInProject");l(Ap,"gatherStats");l(Dp,"detectCommands");l(jp,"detectStack")});import $p from"node:fs/promises";import Oo from"node:path";var fc,hc,Mp,Op=S(()=>{"use strict";Pt();V();Ue();q();fc={async contextFilesExist(r){let e=Date.now(),t=["context/CLAUDE.md"],s=[];for(let n of t){let o=Oo.join(r,n);await C(o)||s.push(n)}return{name:"Context files exist",passed:s.length===0,output:s.length===0?`${t.length} files verified`:void 0,error:s.length>0?`Missing: ${s.join(", ")}`:void 0,durationMs:Date.now()-e}},async jsonFilesValid(r){let e=Date.now(),t=[],s=Oo.basename(r);try{await _.read(s)}catch(n){R(n)||t.push(`state: ${y(n)}`)}return{name:"State data valid",passed:t.length===0,output:t.length===0?"1 store validated":void 0,error:t.length>0?t.join("; "):void 0,durationMs:Date.now()-e}},async noSensitiveData(r){let e=Date.now(),t=Oo.join(r,"context"),s=[/(?:api[_-]?key|apikey)\s*[:=]\s*['"][^'"]{10,}/i,/(?:password|passwd|pwd)\s*[:=]\s*['"][^'"]{4,}/i,/(?:secret|token)\s*[:=]\s*['"][^'"]{10,}/i],n=[];try{let o=await $p.readdir(t);for(let i of o){if(!i.endsWith(".md"))continue;let a=await $p.readFile(Oo.join(t,i),"utf-8");for(let c of s)if(c.test(a)){n.push(`${i}: potential sensitive data detected`);break}}}catch(o){if(!R(o))return{name:"No sensitive data",passed:!1,error:`Could not scan: ${y(o)}`,durationMs:Date.now()-e}}return{name:"No sensitive data",passed:n.length===0,output:n.length===0?"No sensitive patterns found":void 0,error:n.length>0?n.join("; "):void 0,durationMs:Date.now()-e}}},hc=class{static{l(this,"SyncVerifier")}async verify(e,t,s){let n=Date.now(),o=[],i=s?.failFast??!1,a=0,c=[fc.contextFilesExist(t),fc.jsonFilesValid(t),fc.noSensitiveData(t)];for(let d of c){let g=await d;if(o.push(g),!g.passed&&i){a=s?.checks?.filter(h=>h.enabled!==!1).length??0;break}}if((!i||o.every(d=>d.passed))&&s?.checks)for(let d of s.checks){if(d.enabled===!1){a++;continue}let g=await this.runCustomCheck(d,e);if(o.push(g),!g.passed&&i){let h=s.checks.slice(s.checks.indexOf(d)+1);a+=h.filter(k=>k.enabled!==!1).length;break}}let p=o.filter(d=>!d.passed).length,m=o.filter(d=>d.passed).length;return{passed:p===0,checks:o,totalMs:Date.now()-n,failedCount:p,passedCount:m,skippedCount:a}}async runCustomCheck(e,t){let s=Date.now(),n=e.command||(e.script?`sh ${e.script}`:null);if(!n)return{name:e.name,passed:!1,error:"No command or script specified",durationMs:Date.now()-s};try{let{stdout:o,stderr:i}=await N(n,{cwd:t,timeout:3e4});return{name:e.name,passed:!0,output:(o.trim()||i.trim()).slice(0,200)||void 0,durationMs:Date.now()-s}}catch(o){let i=o;return{name:e.name,passed:!1,error:(i.stderr?.trim()||i.message).slice(0,200),durationMs:Date.now()-s}}}},Mp=new hc});import _p from"node:fs/promises";import yc from"node:path";var wc,qs,kc=S(()=>{"use strict";mr();la();Sd();Td();Ad();xa();ss();it();os();Et();ve();xo();wn();Vs();ce();ks();kr();Ka();Za();Xt();Js();Pt();nc();oe();q();ns();cp();wp();br();Sp();zs();vp();Cp();Ip();Op();wc=class{static{l(this,"SyncService")}projectPath;projectId=null;globalPath="";cliVersion="0.0.0";constructor(){this.projectPath=process.cwd()}async sync(e=process.cwd(),t={}){this.projectPath=e;let s=Date.now(),n={installed:!1,verified:!1,configPath:"",message:""};try{if(this.projectId=await I.getProjectId(e),!this.projectId)return{success:!1,projectId:"",cliVersion:"",git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:!1,verified:!1},error:"No prjct project. Run p. init first."};if(this.globalPath=A.getGlobalProjectPath(this.projectId),this.cliVersion=await this.getCliVersion(),await _p.rm(yc.join(this.globalPath,"agents"),{recursive:!0,force:!0}).catch(()=>{}),(await Os()).installed){let $=await Eo({autoRepair:!0});$.verified||W.warn(`Codex p. router not ready: ${$.message||"verification failed"}`)}try{n=await ls.ensureReady()}catch($){return{success:!1,projectId:this.projectId,cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:n.installed,verified:!1,message:ue($)},error:`Context7 MCP is required but not ready: ${ue($)}. Run 'prjct start' to repair.`}}await this.ensureDirectories(),await Ro(this.projectId);try{let $=await Ao(this.projectId);$>0&&W.info("Swept legacy JSON files into SQLite",{swept:$})}catch($){W.debug("Legacy JSON sweep failed (non-critical)",{error:ue($)})}let[a,c,u,p]=await Promise.all([Rp(this.projectPath),Ap(this.projectPath),Dp(this.projectPath),jp(this.projectPath)]),m=t.full===!0,d,g=!0,h=new Set;if(!m&&vd(this.projectId))try{let{diff:$,currentHashes:D}=await Aa(this.projectPath,this.projectId),O=$.added.length+$.modified.length+$.deleted.length;if(O===0&&!t.changedFiles?.length)g=!1,d={isIncremental:!0,filesChanged:0,filesUnchanged:$.unchanged.length,indexesRebuilt:!1,affectedDomains:[]};else{let ne=wd($,this.projectId);h=kd(ne.allAffected);let rt=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]);g=ne.allAffected.some(dt=>{let ms=dt.substring(dt.lastIndexOf("."));return rt.has(ms)}),d={isIncremental:!0,filesChanged:O,filesUnchanged:$.unchanged.length,indexesRebuilt:g,affectedDomains:Array.from(h)}}Ra(this.projectId,D)}catch($){W.debug("Incremental detection failed, falling back to full sync",{error:ue($)})}else try{let{currentHashes:$}=await Aa(this.projectPath,this.projectId);Ra(this.projectId,$)}catch($){W.debug("Hash computation failed (non-critical)",{error:ue($)})}if(g)try{await Promise.all([Hu(this.projectPath,this.projectId),yd(this.projectPath,this.projectId),Rd(this.projectPath,this.projectId)])}catch($){W.debug("File ranking index build failed (non-critical)",{error:ue($)})}let k;try{let[$,D,O,ne,rt,K,dt,ms,nr,Ai,Di]=await Promise.all([Promise.resolve(Kt.getActive(this.projectId)).catch(()=>null),qe.getActive(this.projectId).catch(()=>null),et.getRecent(this.projectId,3).catch(()=>[]),jo.getMetrics(this.projectId).catch(()=>null),be.getBacklog(this.projectId).catch(()=>[]),_.getTaskHistory(this.projectId).catch(()=>[]),_.getAllPausedTasks(this.projectId).catch(()=>[]),_.getAggregatedFeedback(this.projectId).catch(()=>null),_.getCurrentTask(this.projectId).catch(()=>null),He.getCounts(this.projectId).catch(()=>({pending:0,converted:0,archived:0})),et.getCount(this.projectId).catch(()=>0)]),ji={backlogCount:rt.length,completedTaskCount:K.length,pausedTaskCount:dt.length,hasActiveTask:!!nr},Ii=$?$.patterns.map(re=>({name:re.name,description:re.description,location:re.locations?.[0]})):(D?.patterns??[]).filter(re=>re.source!=="repo").map(re=>({name:re.name,description:re.description,location:re.location})),Fe=$?$.antiPatterns.map(re=>({issue:re.issue,file:re.files?.[0]??"multiple",suggestion:re.suggestion,severity:re.severity??"medium"})):(D?.antiPatterns??[]).filter(re=>re.source!=="repo").map(re=>({issue:re.issue,file:re.file,suggestion:re.suggestion,severity:re.severity??"medium"})),Ot=$?.commands?{install:$.commands.install??u.install,run:u.run,test:$.commands.test??u.test,build:$.commands.build??u.build,dev:$.commands.dev??u.dev,lint:$.commands.lint??u.lint,format:$.commands.format??u.format}:u,rr={version:c.version,fileCount:c.fileCount,patterns:Ii,antiPatterns:Fe,recentShipped:O.map(re=>({name:re.name,type:re.type??"feature",duration:re.duration,filesChanged:re.changes?.length})),velocity:ne?{avgPoints:ne.averageVelocity,trend:ne.velocityTrend,accuracy:ne.estimationAccuracy}:null,backlogCount:rt.length,completedTaskCount:K.length,pausedTaskCount:dt.length,knownGotchas:ms?.knownGotchas??[],userPatterns:ms?.patternsDiscovered??[],hasActiveTask:!!nr,activeTaskDescription:nr?.description??"",pausedTasks:dt.map(re=>({description:re.description,pausedAt:re.pausedAt??""})),topBacklog:rt.slice(0,3).map(re=>({description:re.description,priority:re.priority??"medium"})),ideasCount:Ai?.pending??0,shippedCount:Di};k=await Tp.generateAndInstall({success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:Ot,stack:p},ji,rr)}catch($){W.debug("Native skill generation failed (non-critical)",{error:ue($)})}await Promise.all([this.updateProjectJson(a,c),this.updateStateJson(c,p),this.logToMemory(a,c),this.saveDraftAnalysis(a,c,p,n.verified)]);let w=await qe.getActive(this.projectId),T={patterns:w?.patterns?.length||0,antiPatterns:w?.antiPatterns?.length||0,criticalAntiPatterns:w?.antiPatterns?.filter($=>$.severity==="high").length||0},E=Date.now()-s,M=await this.recordSyncMetrics(c,E);await this.archiveStaleData(),await this.autoLearnFromHistory(),await De.installGlobalConfig(),await De.syncCommands();let L;try{let $=await I.readConfig(this.projectPath);L=await Mp.verify(this.projectPath,this.globalPath,$?.verification)}catch($){W.debug("Verification failed (non-critical)",{error:ue($)})}return{success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:u,stack:p,context7:{installed:n.installed,verified:n.verified,message:n.message},analysisSummary:T,syncMetrics:M,verification:L,incremental:d,generatedSkills:k}}catch(o){return{success:!1,projectId:this.projectId||"",cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:n.installed,verified:n.verified,message:n.message},error:ue(o)}}}async ensureDirectories(){let e=["storage","context","memory","analysis","config","sync"];await Promise.all(e.map(t=>_p.mkdir(yc.join(this.globalPath,t),{recursive:!0})))}async updateProjectJson(e,t){let s=P.getDoc(this.projectId,"project")||{},n={...s,projectId:this.projectId,repoPath:this.projectPath,name:t.name,version:t.version,cliVersion:this.cliVersion,techStack:t.frameworks,fileCount:t.fileCount,commitCount:e.commits,stack:t.ecosystem,currentBranch:e.branch,hasUncommittedChanges:e.hasChanges,createdAt:s.createdAt||v(),lastSync:v(),lastSyncCommit:e.recentCommits[0]?.hash||null,lastSyncBranch:e.branch};P.setDoc(this.projectId,"project",n)}async updateStateJson(e,t){let n={...await _.read(this.projectId)};n.projectId=this.projectId,n.stack={language:e.languages[0]||"Unknown",framework:e.frameworks[0]||null},n.domains={hasFrontend:t.hasFrontend,hasBackend:t.hasBackend,hasDatabase:t.hasDatabase,hasTesting:t.hasTesting,hasDocker:t.hasDocker},n.projectType=e.projectType,n.metrics={totalFiles:e.fileCount},n.lastSync=v(),n.lastUpdated=v(),n.context={...n.context||{},lastSession:v(),lastAction:"Synced project",nextAction:'Run `p. task "description"` to start working'},await _.write(this.projectId,n);try{await kp.generate(this.projectPath,n)}catch(o){W.debug("Local state generation failed (optional)",{error:ue(o)})}}async logToMemory(e,t){P.appendEvent(this.projectId,"sync",{branch:e.branch,uncommitted:e.hasChanges,fileCount:t.fileCount,commitCount:e.commits})}async recordSyncMetrics(e,t){let s=0;try{let a=ao(this.projectId);if(a)for(let c of Object.values(a.documents))s+=c.length}catch(a){W.debug("Could not load BM25 index for metrics",{error:ue(a)})}s===0&&(s=e.fileCount*200);let n=0,o=s>0?Math.max(0,(s-n)/s):0;try{await Cn.recordSync(this.projectId,{originalSize:s,filteredSize:n,duration:t,isWatch:!1})}catch(a){W.debug("Failed to record sync metrics",{error:ue(a)})}let i={};try{let a=ao(this.projectId);a&&(i.bm25Files=a.totalDocs,i.bm25AvgTokens=Math.round(a.avgDocLength),i.bm25VocabSize=Object.keys(a.invertedIndex).length);let c=go(this.projectId);c&&(i.importEdges=c.edgeCount,i.importFiles=c.fileCount);let u=xd(this.projectId);u&&(i.cochangeCommits=u.commitsAnalyzed,i.cochangeFiles=u.filesAnalyzed)}catch(a){W.debug("Could not load index stats",{error:ue(a)})}return{duration:t,originalSize:s,filteredSize:n,compressionRate:o,indexes:i}}async saveDraftAnalysis(e,t,s,n){try{let o=e.recentCommits[0]?.hash||null,i=[],a=[],c;try{c=await _.getAggregatedFeedback(this.projectId),c.patternsDiscovered.length>0&&(i=c.patternsDiscovered.map(p=>({name:p,description:`Discovered during task execution: ${p}`,source:"feedback",confidence:.74}))),c.knownGotchas.length>0&&(a=c.knownGotchas.map(p=>({issue:p,file:"multiple",suggestion:`Recurring issue reported across tasks: ${p}`,source:"feedback",severity:"medium",confidence:.7})))}catch{}let u=await bp.extract({projectId:this.projectId,projectPath:this.projectPath,languages:t.languages,frameworks:Array.from(new Set([...t.frameworks,...s.frameworks])),feedback:c,context7Verified:n});i=u.patterns,a=u.antiPatterns,await qe.saveDraft(this.projectId,{projectId:this.projectId,languages:t.languages,frameworks:t.frameworks,configFiles:[],fileCount:t.fileCount,patterns:i,antiPatterns:a,analyzedAt:v(),status:"draft",commitHash:o??void 0})}catch(o){W.debug("Failed to save draft analysis (non-critical)",{error:ue(o)})}}async archiveStaleData(){if(this.projectId)try{let[e,t,s,n,o]=await Promise.all([et.archiveOldShipped(this.projectId).catch(()=>0),He.markDormantIdeas(this.projectId).catch(()=>0),be.removeStaleCompleted(this.projectId).catch(()=>0),_.archiveStalePausedTasks(this.projectId).catch(()=>[]),xt.capEntries(this.projectId).catch(()=>0)]),i=e+t+s+n.length+o;if(i>0){W.info("Archived stale data",{shipped:e,dormant:t,staleQueue:s,stalePaused:n.length,memoryCapped:o,total:i});let a=Mt.getStats(this.projectId);W.debug("Archive stats",a)}}catch(e){W.debug("Archival failed (non-critical)",{error:ue(e)})}}async autoLearnFromHistory(){if(this.projectId)try{let e=await _.getTaskHistory(this.projectId);if(e.length===0)return;let t=new Ls,s=await oc.learnFromTaskHistory(this.projectId,e,t);try{let n=await yp.getFeatureOutcomes(this.projectId);n.length>0&&await oc.learnFromOutcomes(this.projectId,n,t)}catch{}s.memoriesInjected>0&&W.info("Auto-learned from task history",{patternsExtracted:s.patternsExtracted,memoriesInjected:s.memoriesInjected,patternsSkipped:s.patternsSkipped})}catch(e){W.debug("Auto-learning failed (non-critical)",{error:ue(e)})}}async getCliVersion(){try{let e=yc.join(__dirname,"..","..","package.json");return(await xe(e))?.version||"0.0.0"}catch(e){return W.debug("Failed to read CLI version",{error:ue(e)}),"0.0.0"}}emptyGitData(){return{branch:"main",commits:0,contributors:0,hasChanges:!1,stagedFiles:[],modifiedFiles:[],untrackedFiles:[],recentCommits:[],weeklyCommits:0}}emptyStats(){return{fileCount:0,version:"0.0.0",name:"unknown",ecosystem:"unknown",projectType:"simple",languages:[],frameworks:[]}}emptyCommands(){return{install:"npm install",run:"npm run",test:"npm test",build:"npm run build",dev:"npm run dev",lint:"npm run lint",format:"npm run format"}}emptyStack(){return{hasFrontend:!1,hasBackend:!1,hasDatabase:!1,hasDocker:!1,hasTesting:!1,frontendType:null,frameworks:[]}}},qs=new wc});function Ak(){return`\u26A1 prjct
626
-
627
- ---`}function Dk(){return`---
628
- \u26A1 prjct \xB7 v${Fs()}`}function U(...r){return jk(Ak(),...r.filter(Boolean),Dk())}function Sc(r,e){let t=`| ${r.join(" | ")} |`,s=`|${r.map(()=>"---").join("|")}|`,n=e.map(o=>`| ${o.join(" | ")} |`);return[t,s,...n].join(`
629
- `)}function Np(r,e=""){return`\`\`\`${e}
653
+ `,"body")}];l(Dk,"buildFrontmatter");l(jk,"buildSkillContent");fc=class{static{l(this,"SkillGenerator")}async generateAndInstall(e,t={backlogCount:0,completedTaskCount:0,pausedTaskCount:0,hasActiveTask:!1},s){let n={generated:[],skipped:[]},o={projectName:e.stats.name,stack:[...e.stats.languages,...e.stats.frameworks].filter(Boolean).join("/")||e.stats.ecosystem,branch:e.git.branch,commands:e.commands,projectId:e.projectId,version:s?.version??e.stats.version??"0.0.0",fileCount:s?.fileCount??e.stats.fileCount??0,patterns:s?.patterns??[],antiPatterns:s?.antiPatterns??[],recentShipped:s?.recentShipped??[],velocity:s?.velocity??null,backlogCount:s?.backlogCount??t.backlogCount,completedTaskCount:s?.completedTaskCount??t.completedTaskCount,pausedTaskCount:s?.pausedTaskCount??t.pausedTaskCount,knownGotchas:s?.knownGotchas??[],hasActiveTask:s?.hasActiveTask??t.hasActiveTask,activeTaskDescription:s?.activeTaskDescription??"",pausedTasks:s?.pausedTasks??[],topBacklog:s?.topBacklog??[],ideasCount:s?.ideasCount??0,shippedCount:s?.shippedCount??0,userPatterns:s?.userPatterns??[]},i=xr.join(kk.homedir(),".claude","skills");for(let c of gc){if(!c.condition(t)){n.skipped.push({name:c.name,reason:"condition not met"}),await Er.rm(xr.join(i,c.name),{recursive:!0,force:!0}).catch(()=>{});continue}try{let u=jk(c,o),p=xr.join(i,c.name),m=xr.join(p,"SKILL.md");await Er.mkdir(p,{recursive:!0}),await Er.writeFile(m,u,"utf-8"),n.generated.push({name:c.name,path:m})}catch(u){V.debug(`Failed to generate skill ${c.name}`,{error:ue(u)}),n.skipped.push({name:c.name,reason:ue(u)})}}let a=new Set(gc.map(c=>c.name));try{let c=await Er.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let u of c)u.isDirectory()&&u.name.startsWith("prjct-")&&!a.has(u.name)&&await Er.rm(xr.join(i,u.name),{recursive:!0,force:!0}).catch(()=>{})}catch{}return n.generated.length>0&&V.info("Generated native workflow skills",{count:n.generated.length,skills:n.generated.map(c=>c.name)}),n}getDefinitions(){return gc}},Ep=new fc});var Rp=S(()=>{"use strict"});import Ik from"node:fs/promises";import Ap from"node:path";var Lo,Dp=S(()=>{"use strict";K();Lo=class{static{l(this,"StackDetector")}projectPath;constructor(e){this.projectPath=e}async detect(){let e={hasFrontend:!1,hasBackend:!1,hasDatabase:!1,hasDocker:!1,hasTesting:!1,frontendType:null,frameworks:[]},t=await this.readPackageJson();if(t){let s={...t.dependencies,...t.devDependencies};this.detectFrontend(s,e),this.detectBackend(s,e),this.detectDatabase(s,e),this.detectTesting(s,t,e),this.collectFrameworks(s,e)}return e.hasDocker=await this.detectDocker(),e}detectFrontend(e,t){(e.react||e.vue||e.svelte||e["@angular/core"])&&(t.hasFrontend=!0,t.frontendType="web"),(e["react-native"]||e.expo)&&(t.hasFrontend=!0,t.frontendType=t.frontendType==="web"?"both":"mobile")}detectBackend(e,t){["express","fastify","hono","koa","@nestjs/core","nest","@hapi/hapi","restify","polka"].some(n=>e[n])&&(t.hasBackend=!0)}detectDatabase(e,t){["prisma","@prisma/client","mongoose","pg","mysql2","sequelize","typeorm","drizzle-orm","knex","better-sqlite3","mongodb","redis","ioredis"].some(n=>e[n])&&(t.hasDatabase=!0)}detectTesting(e,t,s){["jest","vitest","mocha","@testing-library/react","@testing-library/vue","cypress","playwright","@playwright/test","ava","tap","bun-types"].some(o=>e[o]||t.devDependencies?.[o])&&(s.hasTesting=!0)}async detectDocker(){let e=["Dockerfile","docker-compose.yml","docker-compose.yaml",".dockerignore"];for(let t of e)if(await this.fileExistsInProject(t))return!0;return!1}collectFrameworks(e,t){e.react&&t.frameworks.push("React"),e.next&&t.frameworks.push("Next.js"),e.vue&&t.frameworks.push("Vue"),e.nuxt&&t.frameworks.push("Nuxt"),e.svelte&&t.frameworks.push("Svelte"),e["@angular/core"]&&t.frameworks.push("Angular"),e["react-native"]&&t.frameworks.push("React Native"),e.expo&&t.frameworks.push("Expo"),e.express&&t.frameworks.push("Express"),e.fastify&&t.frameworks.push("Fastify"),e.hono&&t.frameworks.push("Hono"),e.koa&&t.frameworks.push("Koa"),(e["@nestjs/core"]||e.nest)&&t.frameworks.push("NestJS"),e.astro&&t.frameworks.push("Astro"),e.remix&&t.frameworks.push("Remix"),e.gatsby&&t.frameworks.push("Gatsby")}async readPackageJson(){try{let e=Ap.join(this.projectPath,"package.json"),t=await Ik.readFile(e,"utf-8");return JSON.parse(t)}catch{return null}}async fileExistsInProject(e){return P(Ap.join(this.projectPath,e))}}});import hc from"node:path";async function jp(r){let e={branch:"main",commits:0,contributors:0,hasChanges:!1,stagedFiles:[],modifiedFiles:[],untrackedFiles:[],recentCommits:[],weeklyCommits:0};try{let{stdout:t}=await O("git branch --show-current",{cwd:r});e.branch=t.trim()||"main";let{stdout:s}=await O("git rev-list --count HEAD",{cwd:r});e.commits=parseInt(s.trim(),10)||0;let{stdout:n}=await O("git shortlog -sn --all | wc -l",{cwd:r});e.contributors=parseInt(n.trim(),10)||0;let{stdout:o}=await O("git status --porcelain",{cwd:r}),i=o.trim().split(`
654
+ `).filter(Boolean);e.hasChanges=i.length>0;for(let u of i){let p=u.substring(0,2),m=u.substring(3);p.startsWith("A")||p.startsWith("M ")?e.stagedFiles.push(m):p.includes("M")?e.modifiedFiles.push(m):p.startsWith("??")&&e.untrackedFiles.push(m)}let{stdout:a}=await O('git log --oneline -20 --pretty=format:"%h|%s|%ad" --date=short',{cwd:r});e.recentCommits=a.split(`
655
+ `).filter(Boolean).map(u=>{let[p,m,d]=u.split("|");return{hash:p,message:m,date:d}});let{stdout:c}=await O('git log --oneline --since="1 week ago" | wc -l',{cwd:r});e.weeklyCommits=parseInt(c.trim(),10)||0}catch(t){V.debug("Git analysis failed (not a git repo?)",{error:ue(t)})}return e}async function Ht(r,e){let t=await P(hc.join(r,e));return t||V.debug("File not found",{filename:e}),t}async function Ip(r){let e={fileCount:0,version:"0.0.0",name:hc.basename(r),ecosystem:"unknown",projectType:"simple",languages:[],frameworks:[]};try{let{stdout:t}=await O('find . -type f \\( -name "*.js" -o -name "*.ts" -o -name "*.tsx" -o -name "*.py" -o -name "*.go" -o -name "*.rs" \\) -not -path "./node_modules/*" -not -path "./.git/*" | wc -l',{cwd:r});e.fileCount=parseInt(t.trim(),10)||0}catch(t){V.debug("File count failed",{path:r,error:ue(t)}),e.fileCount=0}try{let t=hc.join(r,"package.json"),s=await xe(t);if(!s)throw new Error("No package.json found");e.version=s.version||"0.0.0",e.name=s.name||e.name,e.ecosystem="JavaScript",s.devDependencies?.typescript||await Ht(r,"tsconfig.json")?e.languages.push("TypeScript"):e.languages.push("JavaScript")}catch(t){V.debug("No package.json found",{path:r,error:ue(t)})}return await Ht(r,"Cargo.toml")?(e.ecosystem="Rust",e.languages.push("Rust")):await Ht(r,"go.mod")?(e.ecosystem="Go",e.languages.push("Go")):(await Ht(r,"requirements.txt")||await Ht(r,"pyproject.toml"))&&(e.ecosystem="Python",e.languages.push("Python")),e.fileCount>300||e.frameworks.length>=3?e.projectType="enterprise":(e.fileCount>50||e.frameworks.length>=2)&&(e.projectType="complex"),e}async function $p(r){let e={install:"npm install",run:"npm run",test:"npm test",build:"npm run build",dev:"npm run dev",lint:"npm run lint",format:"npm run format"};return await Ht(r,"bun.lockb")||await Ht(r,"bun.lock")?(e.install="bun install",e.run="bun run",e.test="bun test",e.build="bun run build",e.dev="bun run dev",e.lint="bun run lint",e.format="bun run format"):await Ht(r,"pnpm-lock.yaml")?(e.install="pnpm install",e.run="pnpm run",e.test="pnpm test",e.build="pnpm run build",e.dev="pnpm run dev",e.lint="pnpm run lint",e.format="pnpm run format"):await Ht(r,"yarn.lock")&&(e.install="yarn",e.run="yarn",e.test="yarn test",e.build="yarn build",e.dev="yarn dev",e.lint="yarn lint",e.format="yarn format"),await Ht(r,"Cargo.toml")&&(e.install="cargo build",e.run="cargo run",e.test="cargo test",e.build="cargo build --release",e.dev="cargo run",e.lint="cargo clippy",e.format="cargo fmt"),await Ht(r,"go.mod")&&(e.install="go mod download",e.run="go run .",e.test="go test ./...",e.build="go build",e.dev="go run .",e.lint="golangci-lint run",e.format="go fmt ./..."),e}async function Mp(r){return new Lo(r).detect()}var _p=S(()=>{"use strict";ss();Rp();He();K();ns();Dp();l(jp,"analyzeGit");l(Ht,"fileExistsInProject");l(Ip,"gatherStats");l($p,"detectCommands");l(Mp,"detectStack")});import Op from"node:fs/promises";import Fo from"node:path";var yc,wc,Np,Lp=S(()=>{"use strict";Pt();W();He();K();yc={async contextFilesExist(r){let e=Date.now(),t=["context/CLAUDE.md"],s=[];for(let n of t){let o=Fo.join(r,n);await P(o)||s.push(n)}return{name:"Context files exist",passed:s.length===0,output:s.length===0?`${t.length} files verified`:void 0,error:s.length>0?`Missing: ${s.join(", ")}`:void 0,durationMs:Date.now()-e}},async jsonFilesValid(r){let e=Date.now(),t=[],s=Fo.basename(r);try{await _.read(s)}catch(n){R(n)||t.push(`state: ${w(n)}`)}return{name:"State data valid",passed:t.length===0,output:t.length===0?"1 store validated":void 0,error:t.length>0?t.join("; "):void 0,durationMs:Date.now()-e}},async noSensitiveData(r){let e=Date.now(),t=Fo.join(r,"context"),s=[/(?:api[_-]?key|apikey)\s*[:=]\s*['"][^'"]{10,}/i,/(?:password|passwd|pwd)\s*[:=]\s*['"][^'"]{4,}/i,/(?:secret|token)\s*[:=]\s*['"][^'"]{10,}/i],n=[];try{let o=await Op.readdir(t);for(let i of o){if(!i.endsWith(".md"))continue;let a=await Op.readFile(Fo.join(t,i),"utf-8");for(let c of s)if(c.test(a)){n.push(`${i}: potential sensitive data detected`);break}}}catch(o){if(!R(o))return{name:"No sensitive data",passed:!1,error:`Could not scan: ${w(o)}`,durationMs:Date.now()-e}}return{name:"No sensitive data",passed:n.length===0,output:n.length===0?"No sensitive patterns found":void 0,error:n.length>0?n.join("; "):void 0,durationMs:Date.now()-e}}},wc=class{static{l(this,"SyncVerifier")}async verify(e,t,s){let n=Date.now(),o=[],i=s?.failFast??!1,a=0,c=[yc.contextFilesExist(t),yc.jsonFilesValid(t),yc.noSensitiveData(t)];for(let d of c){let g=await d;if(o.push(g),!g.passed&&i){a=s?.checks?.filter(h=>h.enabled!==!1).length??0;break}}if((!i||o.every(d=>d.passed))&&s?.checks)for(let d of s.checks){if(d.enabled===!1){a++;continue}let g=await this.runCustomCheck(d,e);if(o.push(g),!g.passed&&i){let h=s.checks.slice(s.checks.indexOf(d)+1);a+=h.filter(k=>k.enabled!==!1).length;break}}let p=o.filter(d=>!d.passed).length,m=o.filter(d=>d.passed).length;return{passed:p===0,checks:o,totalMs:Date.now()-n,failedCount:p,passedCount:m,skippedCount:a}}async runCustomCheck(e,t){let s=Date.now(),n=e.command||(e.script?`sh ${e.script}`:null);if(!n)return{name:e.name,passed:!1,error:"No command or script specified",durationMs:Date.now()-s};try{let{stdout:o,stderr:i}=await O(n,{cwd:t,timeout:3e4});return{name:e.name,passed:!0,output:(o.trim()||i.trim()).slice(0,200)||void 0,durationMs:Date.now()-s}}catch(o){let i=o;return{name:e.name,passed:!1,error:(i.stderr?.trim()||i.message).slice(0,200),durationMs:Date.now()-s}}}},Np=new wc});import Fp from"node:fs/promises";import kc from"node:path";var Sc,qs,bc=S(()=>{"use strict";mr();da();vd();Ed();Id();Aa();ss();at();os();Et();Te();jo();kn();Ws();re();ks();kr();Ya();tc();Xt();zs();Pt();oc();ie();K();ns();dp();bp();br();vp();Js();Pp();xp();_p();Lp();Sc=class{static{l(this,"SyncService")}projectPath;projectId=null;globalPath="";cliVersion="0.0.0";constructor(){this.projectPath=process.cwd()}async sync(e=process.cwd(),t={}){this.projectPath=e;let s=Date.now(),n={installed:!1,verified:!1,configPath:"",message:""};try{if(this.projectId=await $.getProjectId(e),!this.projectId)return{success:!1,projectId:"",cliVersion:"",git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:!1,verified:!1},error:"No prjct project. Run p. init first."};if(this.globalPath=A.getGlobalProjectPath(this.projectId),this.cliVersion=await this.getCliVersion(),await Fp.rm(kc.join(this.globalPath,"agents"),{recursive:!0,force:!0}).catch(()=>{}),(await _s()).installed){let j=await Do({autoRepair:!0});j.verified||V.warn(`Codex p. router not ready: ${j.message||"verification failed"}`)}try{n=await ls.ensureReady()}catch(j){return{success:!1,projectId:this.projectId,cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:n.installed,verified:!1,message:ue(j)},error:`Context7 MCP is required but not ready: ${ue(j)}. Run 'prjct start' to repair.`}}await this.ensureDirectories(),await Io(this.projectId);try{let j=await $o(this.projectId);j>0&&V.info("Swept legacy JSON files into SQLite",{swept:j})}catch(j){V.debug("Legacy JSON sweep failed (non-critical)",{error:ue(j)})}let[a,c,u,p]=await Promise.all([jp(this.projectPath),Ip(this.projectPath),$p(this.projectPath),Mp(this.projectPath)]),m=t.full===!0,d,g=!0,h=new Set;if(!m&&Pd(this.projectId))try{let{diff:j,currentHashes:E}=await ja(this.projectPath,this.projectId),M=j.added.length+j.modified.length+j.deleted.length;if(M===0&&!t.changedFiles?.length)g=!1,d={isIncremental:!0,filesChanged:0,filesUnchanged:j.unchanged.length,indexesRebuilt:!1,affectedDomains:[]};else{let se=bd(j,this.projectId);h=Td(se.allAffected);let Me=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]);g=se.allAffected.some(mt=>{let ms=mt.substring(mt.lastIndexOf("."));return Me.has(ms)}),d={isIncremental:!0,filesChanged:M,filesUnchanged:j.unchanged.length,indexesRebuilt:g,affectedDomains:Array.from(h)}}Da(this.projectId,E)}catch(j){V.debug("Incremental detection failed, falling back to full sync",{error:ue(j)})}else try{let{currentHashes:j}=await ja(this.projectPath,this.projectId);Da(this.projectId,j)}catch(j){V.debug("Hash computation failed (non-critical)",{error:ue(j)})}if(g)try{await Promise.all([Vu(this.projectPath,this.projectId),Sd(this.projectPath,this.projectId),jd(this.projectPath,this.projectId)])}catch(j){V.debug("File ranking index build failed (non-critical)",{error:ue(j)})}let k;try{let[j,E,M,se,Me,q,mt,ms,nr,Ii,$i]=await Promise.all([Promise.resolve(Lt.getActive(this.projectId)).catch(()=>null),Ke.getActive(this.projectId).catch(()=>null),tt.getRecent(this.projectId,3).catch(()=>[]),_o.getMetrics(this.projectId).catch(()=>null),be.getBacklog(this.projectId).catch(()=>[]),_.getTaskHistory(this.projectId).catch(()=>[]),_.getAllPausedTasks(this.projectId).catch(()=>[]),_.getAggregatedFeedback(this.projectId).catch(()=>null),_.getCurrentTask(this.projectId).catch(()=>null),Ge.getCounts(this.projectId).catch(()=>({pending:0,converted:0,archived:0})),tt.getCount(this.projectId).catch(()=>0)]),Mi={backlogCount:Me.length,completedTaskCount:q.length,pausedTaskCount:mt.length,hasActiveTask:!!nr},_i=j?j.patterns.map(oe=>({name:oe.name,description:oe.description,location:oe.locations?.[0]})):(E?.patterns??[]).filter(oe=>oe.source!=="repo").map(oe=>({name:oe.name,description:oe.description,location:oe.location})),Ue=j?j.antiPatterns.map(oe=>({issue:oe.issue,file:oe.files?.[0]??"multiple",suggestion:oe.suggestion,severity:oe.severity??"medium"})):(E?.antiPatterns??[]).filter(oe=>oe.source!=="repo").map(oe=>({issue:oe.issue,file:oe.file,suggestion:oe.suggestion,severity:oe.severity??"medium"})),_t=j?.commands?{install:j.commands.install??u.install,run:u.run,test:j.commands.test??u.test,build:j.commands.build??u.build,dev:j.commands.dev??u.dev,lint:j.commands.lint??u.lint,format:j.commands.format??u.format}:u,rr={version:c.version,fileCount:c.fileCount,patterns:_i,antiPatterns:Ue,recentShipped:M.map(oe=>({name:oe.name,type:oe.type??"feature",duration:oe.duration,filesChanged:oe.changes?.length})),velocity:se?{avgPoints:se.averageVelocity,trend:se.velocityTrend,accuracy:se.estimationAccuracy}:null,backlogCount:Me.length,completedTaskCount:q.length,pausedTaskCount:mt.length,knownGotchas:ms?.knownGotchas??[],userPatterns:ms?.patternsDiscovered??[],hasActiveTask:!!nr,activeTaskDescription:nr?.description??"",pausedTasks:mt.map(oe=>({description:oe.description,pausedAt:oe.pausedAt??""})),topBacklog:Me.slice(0,3).map(oe=>({description:oe.description,priority:oe.priority??"medium"})),ideasCount:Ii?.pending??0,shippedCount:$i};k=await Ep.generateAndInstall({success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:_t,stack:p},Mi,rr)}catch(j){V.debug("Native skill generation failed (non-critical)",{error:ue(j)})}await Promise.all([this.updateProjectJson(a,c),this.updateStateJson(c,p),this.logToMemory(a,c),this.saveDraftAnalysis(a,c,p,n.verified)]);let y=await Ke.getActive(this.projectId),v={patterns:y?.patterns?.length||0,antiPatterns:y?.antiPatterns?.length||0,criticalAntiPatterns:y?.antiPatterns?.filter(j=>j.severity==="high").length||0},D=Date.now()-s,U=await this.recordSyncMetrics(c,D);await this.archiveStaleData(),await this.autoLearnFromHistory(),await De.installGlobalConfig(),await De.syncCommands();let F;try{let j=await $.readConfig(this.projectPath);F=await Np.verify(this.projectPath,this.globalPath,j?.verification)}catch(j){V.debug("Verification failed (non-critical)",{error:ue(j)})}return{success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:u,stack:p,context7:{installed:n.installed,verified:n.verified,message:n.message},analysisSummary:v,syncMetrics:U,verification:F,incremental:d,generatedSkills:k}}catch(o){return{success:!1,projectId:this.projectId||"",cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:n.installed,verified:n.verified,message:n.message},error:ue(o)}}}async ensureDirectories(){let e=["storage","context","memory","analysis","config","sync"];await Promise.all(e.map(t=>Fp.mkdir(kc.join(this.globalPath,t),{recursive:!0})))}async updateProjectJson(e,t){let s=C.getDoc(this.projectId,"project")||{},n={...s,projectId:this.projectId,repoPath:this.projectPath,name:t.name,version:t.version,cliVersion:this.cliVersion,techStack:t.frameworks,fileCount:t.fileCount,commitCount:e.commits,stack:t.ecosystem,currentBranch:e.branch,hasUncommittedChanges:e.hasChanges,createdAt:s.createdAt||T(),lastSync:T(),lastSyncCommit:e.recentCommits[0]?.hash||null,lastSyncBranch:e.branch};C.setDoc(this.projectId,"project",n)}async updateStateJson(e,t){let n={...await _.read(this.projectId)};n.projectId=this.projectId,n.stack={language:e.languages[0]||"Unknown",framework:e.frameworks[0]||null},n.domains={hasFrontend:t.hasFrontend,hasBackend:t.hasBackend,hasDatabase:t.hasDatabase,hasTesting:t.hasTesting,hasDocker:t.hasDocker},n.projectType=e.projectType,n.metrics={totalFiles:e.fileCount},n.lastSync=T(),n.lastUpdated=T(),n.context={...n.context||{},lastSession:T(),lastAction:"Synced project",nextAction:'Run `p. task "description"` to start working'},await _.write(this.projectId,n);try{await Tp.generate(this.projectPath,n)}catch(o){V.debug("Local state generation failed (optional)",{error:ue(o)})}}async logToMemory(e,t){C.appendEvent(this.projectId,"sync",{branch:e.branch,uncommitted:e.hasChanges,fileCount:t.fileCount,commitCount:e.commits})}async recordSyncMetrics(e,t){let s=0;try{let a=po(this.projectId);if(a)for(let c of Object.values(a.documents))s+=c.length}catch(a){V.debug("Could not load BM25 index for metrics",{error:ue(a)})}s===0&&(s=e.fileCount*200);let n=0,o=s>0?Math.max(0,(s-n)/s):0;try{await Pn.recordSync(this.projectId,{originalSize:s,filteredSize:n,duration:t,isWatch:!1})}catch(a){V.debug("Failed to record sync metrics",{error:ue(a)})}let i={};try{let a=po(this.projectId);a&&(i.bm25Files=a.totalDocs,i.bm25AvgTokens=Math.round(a.avgDocLength),i.bm25VocabSize=Object.keys(a.invertedIndex).length);let c=wo(this.projectId);c&&(i.importEdges=c.edgeCount,i.importFiles=c.fileCount);let u=Dd(this.projectId);u&&(i.cochangeCommits=u.commitsAnalyzed,i.cochangeFiles=u.filesAnalyzed)}catch(a){V.debug("Could not load index stats",{error:ue(a)})}return{duration:t,originalSize:s,filteredSize:n,compressionRate:o,indexes:i}}async saveDraftAnalysis(e,t,s,n){try{let o=e.recentCommits[0]?.hash||null,i=[],a=[],c;try{c=await _.getAggregatedFeedback(this.projectId),c.patternsDiscovered.length>0&&(i=c.patternsDiscovered.map(p=>({name:p,description:`Discovered during task execution: ${p}`,source:"feedback",confidence:.74}))),c.knownGotchas.length>0&&(a=c.knownGotchas.map(p=>({issue:p,file:"multiple",suggestion:`Recurring issue reported across tasks: ${p}`,source:"feedback",severity:"medium",confidence:.7})))}catch{}let u=await Cp.extract({projectId:this.projectId,projectPath:this.projectPath,languages:t.languages,frameworks:Array.from(new Set([...t.frameworks,...s.frameworks])),feedback:c,context7Verified:n});i=u.patterns,a=u.antiPatterns,await Ke.saveDraft(this.projectId,{projectId:this.projectId,languages:t.languages,frameworks:t.frameworks,configFiles:[],fileCount:t.fileCount,patterns:i,antiPatterns:a,analyzedAt:T(),status:"draft",commitHash:o??void 0})}catch(o){V.debug("Failed to save draft analysis (non-critical)",{error:ue(o)})}}async archiveStaleData(){if(this.projectId)try{let[e,t,s,n,o]=await Promise.all([tt.archiveOldShipped(this.projectId).catch(()=>0),Ge.markDormantIdeas(this.projectId).catch(()=>0),be.removeStaleCompleted(this.projectId).catch(()=>0),_.archiveStalePausedTasks(this.projectId).catch(()=>[]),xt.capEntries(this.projectId).catch(()=>0)]),i=e+t+s+n.length+o;if(i>0){V.info("Archived stale data",{shipped:e,dormant:t,staleQueue:s,stalePaused:n.length,memoryCapped:o,total:i});let a=Mt.getStats(this.projectId);V.debug("Archive stats",a)}}catch(e){V.debug("Archival failed (non-critical)",{error:ue(e)})}}async autoLearnFromHistory(){if(this.projectId)try{let e=await _.getTaskHistory(this.projectId);if(e.length===0)return;let t=new Ls,s=await ac.learnFromTaskHistory(this.projectId,e,t);try{let n=await Sp.getFeatureOutcomes(this.projectId);n.length>0&&await ac.learnFromOutcomes(this.projectId,n,t)}catch{}s.memoriesInjected>0&&V.info("Auto-learned from task history",{patternsExtracted:s.patternsExtracted,memoriesInjected:s.memoriesInjected,patternsSkipped:s.patternsSkipped})}catch(e){V.debug("Auto-learning failed (non-critical)",{error:ue(e)})}}async getCliVersion(){try{let e=kc.join(__dirname,"..","..","package.json");return(await xe(e))?.version||"0.0.0"}catch(e){return V.debug("Failed to read CLI version",{error:ue(e)}),"0.0.0"}}emptyGitData(){return{branch:"main",commits:0,contributors:0,hasChanges:!1,stagedFiles:[],modifiedFiles:[],untrackedFiles:[],recentCommits:[],weeklyCommits:0}}emptyStats(){return{fileCount:0,version:"0.0.0",name:"unknown",ecosystem:"unknown",projectType:"simple",languages:[],frameworks:[]}}emptyCommands(){return{install:"npm install",run:"npm run",test:"npm test",build:"npm run build",dev:"npm run dev",lint:"npm run lint",format:"npm run format"}}emptyStack(){return{hasFrontend:!1,hasBackend:!1,hasDatabase:!1,hasDocker:!1,hasTesting:!1,frontendType:null,frameworks:[]}}},qs=new Sc});function $k(){return"---"}function Mk(){return`---
656
+ prjct v${Fs()}`}function L(...r){return Cc($k(),...r.filter(Boolean),Mk())}function Rr(r,e){let t=`| ${r.join(" | ")} |`,s=`|${r.map(()=>"---").join("|")}|`,n=e.map(o=>`| ${o.join(" | ")} |`);return[t,s,...n].join(`
657
+ `)}function Up(r,e=""){return`\`\`\`${e}
630
658
  ${r}
631
- \`\`\``}function bc(r,e){return`> ${{success:"\u2705",warn:"\u26A0\uFE0F",error:"\u274C",info:"\u2139\uFE0F"}[r]} **${e}**`}function se(r,e,t=3){return`### ${r}
632
- ${e}`}function je(r,e=!1){return r.map((t,s)=>e?`${s+1}. ${t}`:`- ${t}`).join(`
633
- `)}function vc(r){let e=[];r.branch&&e.push(`Branch: \`${r.branch}\``),r.linearId&&e.push(`Linear: \`${r.linearId}\``),r.type&&e.push(`Type: ${r.type}`),r.estimatedPoints&&e.push(`~${r.estimatedPoints}pts`),r.estimatedMinutes&&e.push(`~${r.estimatedMinutes}min`),r.domains&&r.domains.length>0&&e.push(`Domains: ${r.domains.join(", ")}`),r.duration&&e.push(`Duration: ${r.duration}`),r.status&&e.push(`Status: ${r.status}`);let t=e.length>0?`
634
- > ${e.join(" | ")}`:"";return`## \u26A1 ${r.description}${t}`}function Lp(r,e){let t=["#","Status","Description"],s=r.map((n,o)=>{let i=String(o+1),a;n.status==="completed"?a="\u2705":o===e?a="\u{1F504}":a="\u2B1C";let c=o===e?" **\u2190 current**":"";return[i,a,`${n.description}${c}`]});return`### Subtasks
635
- ${Sc(t,s)}`}function Fp(r){return r.length===0?"":`### Relevant Files
659
+ \`\`\``}function Tc(r,e){return`**${r}**: \`${e}\``}function vc(r,e){return`> **${{success:"OK",warn:"WARNING",error:"ERROR",info:"INFO"}[r]}:** ${e}`}function Q(r,e,t=3){return`### ${r}
660
+ ${e}`}function Oe(r,e=!1){return r.map((t,s)=>e?`${s+1}. ${t}`:`- ${t}`).join(`
661
+ `)}function Ar(r){let e=[];r.branch&&e.push(`Branch: \`${r.branch}\``),r.linearId&&e.push(`Linear: \`${r.linearId}\``),r.type&&e.push(`Type: ${r.type}`),r.estimatedPoints&&e.push(`~${r.estimatedPoints}pts`),r.estimatedMinutes&&e.push(`~${r.estimatedMinutes}min`),r.domains&&r.domains.length>0&&e.push(`Domains: ${r.domains.join(", ")}`),r.duration&&e.push(`Duration: ${r.duration}`),r.status&&e.push(`Status: ${r.status}`);let t=e.length>0?`
662
+ > ${e.join(" | ")}`:"";return`## ${r.description}${t}`}function Hp(r,e){let t=["#","Status","Description"],s=r.map((n,o)=>{let i=String(o+1),a;n.status==="completed"?a="done":o===e?a="current":a="pending";let c=o===e?" **<- current**":"";return[i,a,`${n.description}${c}`]});return`### Subtasks
663
+ ${Rr(t,s)}`}function Gp(r){return r.length===0?"":`### Relevant Files
636
664
  ${r.map(t=>{let s=t.lineRange?`:${t.lineRange}`:"",n=t.description?` \u2014 ${t.description}`:"";return`- \`${t.path}${s}\`${n}`}).join(`
637
665
  `)}`}function ge(r){let e=["Command","Action"],t=r.map(s=>[`\`${s.command}\``,s.label]);return`### Next
638
- ${Sc(e,t)}`}function mt(r){let e=Object.entries(r).filter(([,n])=>n!=null);if(e.length===0)return"";let t=["Metric","Value"],s=e.map(([n,o])=>[n,String(o)]);return Sc(t,s)}function ke(r,e){return e?`## \u2705 ${r}
639
- > ${e}`:`## \u2705 ${r}`}function Up(r){return`> \u26A0\uFE0F **${r}**`}function jk(...r){return r.filter(Boolean).join(`
666
+ ${Rr(e,t)}`}function lt(r){let e=Object.entries(r).filter(([,n])=>n!=null);if(e.length===0)return"";let t=["Metric","Value"],s=e.map(([n,o])=>[n,String(o)]);return Rr(t,s)}function ke(r,e){return e?`## ${r}
667
+ > ${e}`:`## ${r}`}function Wp(r){return`> **WARNING:** ${r}`}function Cc(...r){return r.filter(Boolean).join(`
640
668
 
641
- `)}function Rt(r,e,t,s){console.log(JSON.stringify({status:r,reason:e,...s,options:t}))}var Pn=S(()=>{"use strict";Ct();l(Ak,"mdHeader");l(Dk,"mdFooter");l(U,"mdOutput");l(Sc,"mdTable");l(Np,"mdCodeBlock");l(bc,"mdCallout");l(se,"mdSection");l(je,"mdList");l(vc,"mdTaskHeader");l(Lp,"mdSubtasks");l(Fp,"mdRelevantFiles");l(ge,"mdNextSteps");l(mt,"mdStats");l(ke,"mdDone");l(Up,"mdWarn");l(jk,"mdJoin");l(Rt,"mdActionRequired")});import Rr from"chalk";function At(r,e={}){if(e.quiet)return;let t=Gp[r]||"idle",s=Gs.getValidCommands(t);if(s.length===0)return;let n=s.map(o=>({cmd:`p. ${o}`,desc:Hp[o]||o}));console.log(Rr.dim(`
642
- Next:`));for(let o of n){let i=Rr.cyan(o.cmd.padEnd(12));console.log(Rr.dim(` ${i} \u2192 ${o.desc}`))}}function _o(r){let e=Gp[r]||"idle";return Gs.getValidCommands(e).map(s=>({cmd:`p. ${s}`,desc:Hp[s]||s}))}function Ar(r){let e=Gs.getStateInfo(r);console.log(Rr.dim(`\u{1F4CD} State: ${Rr.white(r.toUpperCase())} - ${e.description}`))}var Hp,Gp,En=S(()=>{"use strict";ka();Hp={task:"Start new task",done:"Complete current task",pause:"Pause and switch context",resume:"Continue paused task",ship:"Ship the feature",reopen:"Reopen for rework",next:"View task queue",sync:"Analyze project",bug:"Report a bug",idea:"Capture an idea"},Gp={task:"working",done:"completed","done-subtask":"working",pause:"paused",resume:"working",ship:"shipped",reopen:"working",next:"idle",sync:"idle",init:"idle",bug:"working",idea:"idle"};l(At,"showNextSteps");l(_o,"getNextSteps");l(Ar,"showStateInfo")});import Ks from"chalk";var Vp,Ik,$k,Ut,Wp=S(()=>{"use strict";it();Vp=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],Ik=80,$k={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:Vp,speed:Ik},cli:{header:l(()=>`${Ks.cyan.bold("\u26A1")} ${Ks.cyan("prjct")}`,"header"),footer:l(()=>Ks.dim("\u26A1 prjct"),"footer"),spin:l((r,e)=>`${Ks.cyan("\u26A1")} ${Ks.cyan("prjct")} ${Ks.cyan(Vp[r%10])} ${Ks.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:l((r="claude")=>qr(r).commitFooter,"getCommitFooter"),getSignature:l((r="claude")=>qr(r).signature,"getSignature")},Ut=$k});import de from"chalk";function _k(){return Mk[Ok]}var p0,Tc,Mk,Ok,Xs,xn,Cc,Dt,vs,Nk,Lk,f,Ts=S(()=>{"use strict";Wp();Ws();So();So();p0=Ut.spinner.frames,Tc=Ut.spinner.speed,Mk={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}},Ok="compact";l(_k,"getTierConfig");Xs={success:de.green("\u2713"),fail:de.red("\u2717"),warn:de.yellow("\u26A0"),info:de.blue("\u2139"),debug:de.dim("\u{1F527}"),bullet:de.dim("\u2022"),arrow:de.dim("\u2192"),check:de.green("\u2713"),cross:de.red("\u2717"),spinner:de.cyan("\u25D0")},xn=null,Cc=0,Dt=!1,vs=l((r,e)=>{let t=e??(_k().maxCharsPerLine||Nt.FALLBACK_TRUNCATE);return r&&r.length>t?`${r.slice(0,t-1)}\u2026`:r||""},"truncate"),Nk=l(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(Nt.CLEAR_WIDTH)}\r`):!0,"clear"),Lk={start(){return Dt||console.log(Ut.cli.header()),this},end(){return Dt||console.log(Ut.cli.footer()),this},spin(r){return Dt?this:(this.stop(),process.stdout.isTTY?(xn=setInterval(()=>{process.stdout.write(`\r${Ut.cli.spin(Cc++,vs(r,Nt.SPINNER_MSG))}`)},Tc),this):(process.stdout.write(`${Ut.cli.spin(0,vs(r,Nt.SPINNER_MSG))}
643
- `),this))},done(r,e){if(this.stop(),!Dt){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=de.dim(` [${s.join(" | ")}]`))}console.log(`${Xs.success} ${vs(r,Nt.DONE_MSG)}${t}`)}return this},fail(r){return this.stop(),console.error(`${Xs.fail} ${vs(r,Nt.FAIL_MSG)}`),this},failWithHint(r){this.stop();let e=typeof r=="string"?Na(r):r;return console.error(),console.error(`${Xs.fail} ${e.message}`),e.file&&console.error(de.dim(` File: ${e.file}`)),e.hint&&console.error(de.yellow(` \u{1F4A1} ${e.hint}`)),e.docs&&console.error(de.dim(` Docs: ${e.docs}`)),console.error(),this},warn(r){return this.stop(),Dt||console.log(`${Xs.warn} ${vs(r,Nt.WARN_MSG)}`),this},info(r){return this.stop(),Dt||console.log(`${Xs.info} ${r}`),this},debug(r){this.stop();let e=process.env.DEBUG==="1"||process.env.DEBUG==="true";return!Dt&&e&&console.log(`${Xs.debug} ${de.dim(r)}`),this},success(r,e){return this.done(r,e)},list(r,e={}){if(this.stop(),Dt)return this;let t=e.bullet||Xs.bullet,s=" ".repeat(e.indent||0);for(let n of r)console.log(`${s}${t} ${n}`);return this},table(r,e={}){if(this.stop(),Dt||r.length===0)return this;let t=Object.keys(r[0]),s={};for(let n of t){s[n]=n.length;for(let o of r){let i=String(o[n]??"");i.length>s[n]&&(s[n]=i.length)}}if(e.header!==!1){let n=t.map(o=>o.padEnd(s[o])).join(" ");console.log(de.dim(n)),console.log(de.dim("\u2500".repeat(n.length)))}for(let n of r){let o=t.map(i=>String(n[i]??"").padEnd(s[i])).join(" ");console.log(o)}return this},box(r,e){if(this.stop(),Dt)return this;let t=e.split(`
669
+ `)}function Rt(r,e,t,s){let n=e.replace(/_/g," "),o=[`> **${r}**: ${n}`];if(s)for(let[i,a]of Object.entries(s))o.push(`> ${i}: ${a}`);if(t.length>0){o.push("");for(let i of t)o.push(`- ${i.label}: \`${i.command}\``)}console.log(o.join(`
670
+ `))}var Ks=S(()=>{"use strict";Ct();l($k,"mdHeader");l(Mk,"mdFooter");l(L,"mdOutput");l(Rr,"mdTable");l(Up,"mdCodeBlock");l(Tc,"mdBadge");l(vc,"mdCallout");l(Q,"mdSection");l(Oe,"mdList");l(Ar,"mdTaskHeader");l(Hp,"mdSubtasks");l(Gp,"mdRelevantFiles");l(ge,"mdNextSteps");l(lt,"mdStats");l(ke,"mdDone");l(Wp,"mdWarn");l(Cc,"mdJoin");l(Rt,"mdActionRequired")});import Dr from"chalk";function At(r,e={}){if(e.quiet)return;let t=Bp[r]||"idle",s=Gs.getValidCommands(t);if(s.length===0)return;let n=s.map(o=>({cmd:`p. ${o}`,desc:Vp[o]||o}));console.log(Dr.dim(`
671
+ Next:`));for(let o of n){let i=Dr.cyan(o.cmd.padEnd(12));console.log(Dr.dim(` ${i} \u2192 ${o.desc}`))}}function Uo(r,e=!1){let t=Bp[r]||"idle";return Gs.getValidCommands(t).map(n=>({cmd:e?`prjct ${n} --md`:`p. ${n}`,desc:Vp[n]||n}))}function jr(r){let e=Gs.getStateInfo(r);console.log(Dr.dim(`\u{1F4CD} State: ${Dr.white(r.toUpperCase())} - ${e.description}`))}var Vp,Bp,En=S(()=>{"use strict";ba();Vp={task:"Start new task",done:"Complete current task",pause:"Pause and switch context",resume:"Continue paused task",ship:"Ship the feature",reopen:"Reopen for rework",next:"View task queue",sync:"Analyze project",bug:"Report a bug",idea:"Capture an idea"},Bp={task:"working",done:"completed","done-subtask":"working",pause:"paused",resume:"working",ship:"shipped",reopen:"working",next:"idle",sync:"idle",init:"idle",bug:"working",idea:"idle"};l(At,"showNextSteps");l(Uo,"getNextSteps");l(jr,"showStateInfo")});import Xs from"chalk";var zp,_k,Ok,Gt,Jp=S(()=>{"use strict";at();zp=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],_k=80,Ok={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:zp,speed:_k},cli:{header:l(()=>`${Xs.cyan.bold("\u26A1")} ${Xs.cyan("prjct")}`,"header"),footer:l(()=>Xs.dim("\u26A1 prjct"),"footer"),spin:l((r,e)=>`${Xs.cyan("\u26A1")} ${Xs.cyan("prjct")} ${Xs.cyan(zp[r%10])} ${Xs.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:l((r="claude")=>Xr(r).commitFooter,"getCommitFooter"),getSignature:l((r="claude")=>Xr(r).signature,"getSignature")},Gt=Ok});import de from"chalk";function Fk(){return Nk[Lk]}var f0,Pc,Nk,Lk,Ys,xn,Ec,Dt,Ts,Uk,Hk,f,vs=S(()=>{"use strict";Jp();Vs();Co();Co();f0=Gt.spinner.frames,Pc=Gt.spinner.speed,Nk={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}},Lk="compact";l(Fk,"getTierConfig");Ys={success:de.green("\u2713"),fail:de.red("\u2717"),warn:de.yellow("\u26A0"),info:de.blue("\u2139"),debug:de.dim("\u{1F527}"),bullet:de.dim("\u2022"),arrow:de.dim("\u2192"),check:de.green("\u2713"),cross:de.red("\u2717"),spinner:de.cyan("\u25D0")},xn=null,Ec=0,Dt=!1,Ts=l((r,e)=>{let t=e??(Fk().maxCharsPerLine||Ft.FALLBACK_TRUNCATE);return r&&r.length>t?`${r.slice(0,t-1)}\u2026`:r||""},"truncate"),Uk=l(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(Ft.CLEAR_WIDTH)}\r`):!0,"clear"),Hk={start(){return Dt||console.log(Gt.cli.header()),this},end(){return Dt||console.log(Gt.cli.footer()),this},spin(r){return Dt?this:(this.stop(),process.stdout.isTTY?(xn=setInterval(()=>{process.stdout.write(`\r${Gt.cli.spin(Ec++,Ts(r,Ft.SPINNER_MSG))}`)},Pc),this):(process.stdout.write(`${Gt.cli.spin(0,Ts(r,Ft.SPINNER_MSG))}
672
+ `),this))},done(r,e){if(this.stop(),!Dt){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=de.dim(` [${s.join(" | ")}]`))}console.log(`${Ys.success} ${Ts(r,Ft.DONE_MSG)}${t}`)}return this},fail(r){return this.stop(),console.error(`${Ys.fail} ${Ts(r,Ft.FAIL_MSG)}`),this},failWithHint(r){this.stop();let e=typeof r=="string"?Fa(r):r;return console.error(),console.error(`${Ys.fail} ${e.message}`),e.file&&console.error(de.dim(` File: ${e.file}`)),e.hint&&console.error(de.yellow(` \u{1F4A1} ${e.hint}`)),e.docs&&console.error(de.dim(` Docs: ${e.docs}`)),console.error(),this},warn(r){return this.stop(),Dt||console.log(`${Ys.warn} ${Ts(r,Ft.WARN_MSG)}`),this},info(r){return this.stop(),Dt||console.log(`${Ys.info} ${r}`),this},debug(r){this.stop();let e=process.env.DEBUG==="1"||process.env.DEBUG==="true";return!Dt&&e&&console.log(`${Ys.debug} ${de.dim(r)}`),this},success(r,e){return this.done(r,e)},list(r,e={}){if(this.stop(),Dt)return this;let t=e.bullet||Ys.bullet,s=" ".repeat(e.indent||0);for(let n of r)console.log(`${s}${t} ${n}`);return this},table(r,e={}){if(this.stop(),Dt||r.length===0)return this;let t=Object.keys(r[0]),s={};for(let n of t){s[n]=n.length;for(let o of r){let i=String(o[n]??"");i.length>s[n]&&(s[n]=i.length)}}if(e.header!==!1){let n=t.map(o=>o.padEnd(s[o])).join(" ");console.log(de.dim(n)),console.log(de.dim("\u2500".repeat(n.length)))}for(let n of r){let o=t.map(i=>String(n[i]??"").padEnd(s[i])).join(" ");console.log(o)}return this},box(r,e){if(this.stop(),Dt)return this;let t=e.split(`
644
673
  `),s=Math.max(r.length,...t.map(o=>o.length)),n="\u2500".repeat(s+2);console.log(de.dim(`\u250C${n}\u2510`)),console.log(`${de.dim("\u2502")} ${de.bold(r.padEnd(s))} ${de.dim("\u2502")}`),console.log(de.dim(`\u251C${n}\u2524`));for(let o of t)console.log(`${de.dim("\u2502")} ${o.padEnd(s)} ${de.dim("\u2502")}`);return console.log(de.dim(`\u2514${n}\u2518`)),this},section(r){return this.stop(),Dt?this:(console.log(`
645
- ${de.bold(r)}`),console.log(de.dim("\u2500".repeat(r.length))),this)},stop(){return xn&&(clearInterval(xn),xn=null,Nk()),this},step(r,e,t){if(Dt)return this;this.stop();let s=de.dim(`[${r}/${e}]`);return process.stdout.isTTY?(xn=setInterval(()=>{process.stdout.write(`\r${Ut.cli.spin(Cc++,`${s} ${vs(t,Nt.STEP_MSG)}`)}`)},Tc),this):(process.stdout.write(`${Ut.cli.spin(0,`${s} ${vs(t,Nt.STEP_MSG)}`)}
646
- `),this)},progress(r,e,t){if(Dt)return this;this.stop();let s=Math.round(r/e*100),n=Math.round(s/10),o=10-n,i=de.cyan("\u2588".repeat(n))+de.dim("\u2591".repeat(o)),a=t?` ${vs(t,Nt.PROGRESS_TEXT)}`:"";return process.stdout.isTTY?(xn=setInterval(()=>{process.stdout.write(`\r${Ut.cli.spin(Cc++,`[${i}] ${s}%${a}`)}`)},Tc),this):(process.stdout.write(`${Ut.cli.spin(0,`[${i}] ${s}%${a}`)}
647
- `),this)}},f=Lk});import Yt from"chalk";function Fk(r){return Bp[r.toLowerCase()]||Bp.default}var Bp,Pc,Jp,zp=S(()=>{"use strict";Bp={database:"\u{1F4BE}",backend:"\u{1F527}",frontend:"\u{1F4E6}",testing:"\u{1F9EA}",devops:"\u{1F680}",uxui:"\u{1F3A8}",security:"\u{1F512}",docs:"\u{1F4DD}",api:"\u{1F310}",default:"\u26A1"};l(Fk,"getIcon");Pc=class{static{l(this,"AgentStream")}currentAgent=null;startTime=0;quiet=!1;setQuiet(e){this.quiet=e}orchestrate(e){this.quiet||console.log(Yt.cyan(`
674
+ ${de.bold(r)}`),console.log(de.dim("\u2500".repeat(r.length))),this)},stop(){return xn&&(clearInterval(xn),xn=null,Uk()),this},step(r,e,t){if(Dt)return this;this.stop();let s=de.dim(`[${r}/${e}]`);return process.stdout.isTTY?(xn=setInterval(()=>{process.stdout.write(`\r${Gt.cli.spin(Ec++,`${s} ${Ts(t,Ft.STEP_MSG)}`)}`)},Pc),this):(process.stdout.write(`${Gt.cli.spin(0,`${s} ${Ts(t,Ft.STEP_MSG)}`)}
675
+ `),this)},progress(r,e,t){if(Dt)return this;this.stop();let s=Math.round(r/e*100),n=Math.round(s/10),o=10-n,i=de.cyan("\u2588".repeat(n))+de.dim("\u2591".repeat(o)),a=t?` ${Ts(t,Ft.PROGRESS_TEXT)}`:"";return process.stdout.isTTY?(xn=setInterval(()=>{process.stdout.write(`\r${Gt.cli.spin(Ec++,`[${i}] ${s}%${a}`)}`)},Pc),this):(process.stdout.write(`${Gt.cli.spin(0,`[${i}] ${s}%${a}`)}
676
+ `),this)}},f=Hk});import Yt from"chalk";function Gk(r){return qp[r.toLowerCase()]||qp.default}var qp,xc,Kp,Xp=S(()=>{"use strict";qp={database:"\u{1F4BE}",backend:"\u{1F527}",frontend:"\u{1F4E6}",testing:"\u{1F9EA}",devops:"\u{1F680}",uxui:"\u{1F3A8}",security:"\u{1F512}",docs:"\u{1F4DD}",api:"\u{1F310}",default:"\u26A1"};l(Gk,"getIcon");xc=class{static{l(this,"AgentStream")}currentAgent=null;startTime=0;quiet=!1;setQuiet(e){this.quiet=e}orchestrate(e){this.quiet||console.log(Yt.cyan(`
648
677
  \u{1F3AF} Orchestrating: ${e.join(", ")} domains detected
649
- `))}startAgent(e,t,s){if(this.quiet)return;this.currentAgent=e,this.startTime=Date.now();let n=Fk(t);console.log(Yt.cyan(`\u250C\u2500 ${n} ${e} (${t})`)),s&&console.log(Yt.dim(`\u2502 ${s}`))}progress(e){this.quiet||!this.currentAgent||console.log(Yt.dim(`\u2502 \u2514\u2500\u2500 ${e}`))}progressList(e){if(!(this.quiet||!this.currentAgent))for(let t of e)console.log(Yt.dim(`\u2502 \u2514\u2500\u2500 ${t}`))}endAgent(e=!0){if(this.quiet||!this.currentAgent)return;let t=Date.now()-this.startTime,s=this.formatDuration(t),n=e?Yt.green("\u2713"):Yt.red("\u2717");console.log(`\u2514\u2500 ${n} ${e?"Complete":"Failed"} ${Yt.dim(`(${s})`)}
650
- `),this.currentAgent=null}status(e,t){this.quiet||console.log(`${e} ${t}`)}complete(e,t){if(this.quiet)return;let s=t?` ${Yt.dim(`[${this.formatDuration(t)}]`)}`:"";console.log(Yt.green(`\u2705 ${e}${s}`))}formatDuration(e){return e<1e3?`${e}ms`:`${(e/1e3).toFixed(1)}s`}},Jp=new Pc});import tt from"chalk";function Uk(r){let e=0;for(let s of r)e=(e<<5)-e+s.charCodeAt(0),e=e&e;let t=Math.abs(e)%qp.length;return qp[t]}function Hk(r,e,t="\u25B6"){let s=tt.dim(String(r+1).padStart(2)),o=Uk(e.domain)(e.domain.padEnd(10)),i=e.description.length>32?`${e.description.slice(0,29)}...`:e.description.padEnd(32),a;switch(e.status){case"completed":a=tt.green("\u2713 Complete");break;case"in_progress":a=tt.yellow(`${t} Working...`);break;case"pending":a=tt.gray("\u25CB Pending");break;case"failed":a=tt.red("\u2717 Failed");break;case"blocked":a=tt.gray("\u2298 Blocked");break;default:a=tt.gray(`\u25CB ${e.status}`)}return` ${s} ${o} ${i} ${a}`}function Gk(r){if(r.length===0)return"";let e=[];e.push(""),e.push(` ${tt.bold.white("SUBTASK PROGRESS")}`),e.push(` ${tt.dim("\u2500".repeat(58))}`);for(let t=0;t<r.length;t++)e.push(Hk(t,r[t]));return e.push(""),e.join(`
651
- `)}function Kp(r){console.log(Gk(r))}var qp,Xp=S(()=>{"use strict";qp=[tt.cyan,tt.magenta,tt.yellow,tt.blue,tt.green,tt.redBright,tt.magentaBright,tt.cyanBright];l(Uk,"getDomainColor");l(Hk,"formatSubtaskLine");l(Gk,"renderSubtaskProgress");l(Kp,"printSubtaskProgress")});var Yp,Qp,Ec,xc=S(()=>{"use strict";Yp=["task","done","ship","resume","bug","enrich"],Qp=["init","sync","pause","next","dash","history","undo","redo"],Ec=["ship","feature","spec","cleanup","migrate"]});function Vk(r){return Ec.includes(r)}async function Wk(r,e,t){let s=[],n=[],o=[];switch(r){case"ship":t.now&&!t.now.includes("No current task")?s.push({step:"Has active task",passed:!0}):(s.push({step:"Has active task",passed:!1,details:"No active task to ship"}),o.push("No active task")),t.shipped?s.push({step:"Shipped log accessible",passed:!0}):s.push({step:"Shipped log accessible",passed:!1,details:"shipped.md not found"}),n.push("Read current task from now.md"),n.push("Calculate duration"),n.push("Append to shipped.md"),n.push("Clear now.md"),n.push("Update metrics");break;case"feature":e.params.description||e.params.feature?s.push({step:"Has feature description",passed:!0}):(s.push({step:"Has feature description",passed:!1,details:"No description provided"}),o.push("Missing feature description")),t.analysis?s.push({step:"Project analyzed",passed:!0}):s.push({step:"Project analyzed",passed:!1,details:"Run /p:sync first"}),n.push("Parse feature description"),n.push("Generate tasks breakdown"),n.push("Add to roadmap.md"),n.push("Add tasks to next.md"),n.push("Suggest starting first task");break;case"spec":e.params.feature||e.params.name?s.push({step:"Has spec name",passed:!0}):(s.push({step:"Has spec name",passed:!1,details:"No spec name provided"}),o.push("Missing spec name")),n.push("Generate spec template"),n.push("Analyze requirements"),n.push("Create spec file"),n.push("Link to roadmap");break;case"cleanup":t.analysis?s.push({step:"Has code analysis",passed:!0}):s.push({step:"Has code analysis",passed:!1,details:"Run /p:analyze first"}),n.push("Scan for unused code"),n.push("Identify dead imports"),n.push("List files to clean"),n.push("Show preview"),n.push("Wait for approval"),n.push("Execute cleanup");break;case"migrate":s.push({step:"Migration safety check",passed:!0,details:"Will require manual approval"}),n.push("Analyze current state"),n.push("Generate migration plan"),n.push("Show affected files"),n.push("Request approval"),n.push("Execute migration"),n.push("Verify results");break;default:n.push("Execute command");break}let i=s.filter(u=>u.passed).length,a=s.length,c=a>0?i/a:1;return{commandName:r,reasoning:s.length>0?{steps:s,allPassed:o.length===0,criticalIssues:o}:null,plan:n,confidence:c}}function Bk(r){let e=[];return e.push(`\u{1F4CB} Chain of Thought: ${r.commandName}`),e.push(""),r.reasoning&&(e.push("Steps:"),r.reasoning.steps.forEach(t=>{let s=t.passed?"\u2705":"\u274C";e.push(` ${s} ${t.step}`),t.details&&e.push(` ${t.details}`)}),e.push(""),r.reasoning.criticalIssues.length>0&&(e.push("Critical Issues:"),r.reasoning.criticalIssues.forEach(t=>{e.push(` \u26A0\uFE0F ${t}`)}),e.push(""))),r.plan.length>0&&(e.push("Plan:"),r.plan.forEach((t,s)=>{e.push(` ${s+1}. ${t}`)}),e.push("")),e.push(`Confidence: ${Math.round(r.confidence*100)}%`),e.join(`
652
- `)}var Jk,No,Zp=S(()=>{"use strict";xc();l(Vk,"requiresReasoning");l(Wk,"reason");l(Bk,"formatPlan");Jk={requiresReasoning:Vk,reason:Wk,formatPlan:Bk,REASONING_REQUIRED_COMMANDS:Ec},No=Jk});import Lo from"node:fs/promises";var Rc,zk,Ht,Ac=S(()=>{"use strict";Et();ve();V();Ms();q();Rc=class{static{l(this,"ContextBuilder")}_cache;_currentProjectId;constructor(){this._cache=new un({ttl:5e3,maxSize:200}),this._currentProjectId=null}async build(e,t={}){let s=await I.getProjectId(e),n=A.getGlobalProjectPath(s);return this._currentProjectId!==null&&this._currentProjectId!==s&&this._cache.clear(),this._currentProjectId=s,{projectId:s,projectPath:e,globalPath:n,paths:{now:A.getFilePath(s,"core","now.md"),next:A.getFilePath(s,"core","next.md"),context:A.getFilePath(s,"core","context.md"),shipped:A.getFilePath(s,"progress","shipped.md"),metrics:A.getFilePath(s,"progress","metrics.md"),ideas:A.getFilePath(s,"planning","ideas.md"),roadmap:A.getFilePath(s,"planning","roadmap.md"),specs:A.getFilePath(s,"planning","specs"),memory:A.getFilePath(s,"memory","context.jsonl"),patterns:A.getFilePath(s,"memory","patterns.json"),analysis:A.getFilePath(s,"analysis","repo-summary.md"),codePatterns:A.getFilePath(s,"analysis","patterns.md")},params:t,timestamp:new Date().toISOString(),date:new Date().toISOString().split("T")[0]}}async loadState(e,t=null){let s={},n=Object.entries(e.paths),o=t?n.filter(([a])=>t.includes(a)):n;for(let[,a]of o){let c=this._cache.get(a);if(c!==null)try{let u=await Lo.stat(a);(!c.mtime||u.mtimeMs>c.mtime)&&this._cache.delete(a)}catch(u){if(R(u))this._cache.delete(a);else throw u}}let i=[];for(let[a,c]of o){let u=this._cache.get(c);u!==null?s[a]=u.content:i.push([a,c])}if(i.length>0){let a=i.map(async([u,p])=>{try{let[m,d]=await Promise.all([Lo.readFile(p,"utf-8"),Lo.stat(p)]);return{key:u,filePath:p,content:m,mtime:d.mtimeMs}}catch(m){if(R(m))return{key:u,filePath:p,content:null,mtime:null};throw m}}),c=await Promise.all(a);for(let{key:u,filePath:p,content:m,mtime:d}of c)s[u]=m,this._cache.set(p,{content:m,mtime:d})}return s}async loadStateForCommand(e,t){let s={now:["now","next","analysis","codePatterns"],done:["now","next","metrics","analysis"],next:["next","analysis"],ship:["now","shipped","metrics","analysis"],recap:["shipped","metrics","now","analysis"],progress:["shipped","metrics","analysis"],idea:["ideas","next","analysis"],feature:["roadmap","next","ideas","analysis","codePatterns"],roadmap:["roadmap","analysis"],spec:["roadmap","next","specs","analysis","codePatterns"],analyze:["analysis","context","codePatterns"],sync:["analysis","context","now","codePatterns"],work:["now","next","analysis","context","codePatterns"],build:["now","next","analysis","context","codePatterns"],design:["analysis","context","codePatterns"],cleanup:["analysis","context","codePatterns"],fix:["analysis","context","codePatterns"],test:["analysis","context","codePatterns"],default:["analysis","codePatterns"]},n=s[t]||s.default;return this.loadState(e,n)}async batchRead(e){let t=new Map,s=[];for(let n of e){let o=this._cache.get(n);o!==null?t.set(n,o.content):s.push(n)}if(s.length>0){let n=s.map(async i=>{try{let a=await Lo.readFile(i,"utf-8");return{filePath:i,content:a}}catch(a){if(R(a))return{filePath:i,content:null};throw a}}),o=await Promise.all(n);for(let{filePath:i,content:a}of o)t.set(i,a),this._cache.set(i,{content:a,mtime:null})}return t}invalidateCache(e){this._cache.delete(e)}clearCache(){this._cache.clear(),this._currentProjectId=null}async fileExists(e){return C(e)}getCacheStats(){return this._cache.stats()}},zk=new Rc,Ht=zk});import We from"node:fs/promises";import em from"node:os";import Cs from"node:path";function Dc(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function qk(r){if(r.verified||r.warnings.length===0)return null;let e=` Ground Truth Warnings:
678
+ `))}startAgent(e,t,s){if(this.quiet)return;this.currentAgent=e,this.startTime=Date.now();let n=Gk(t);console.log(Yt.cyan(`\u250C\u2500 ${n} ${e} (${t})`)),s&&console.log(Yt.dim(`\u2502 ${s}`))}progress(e){this.quiet||!this.currentAgent||console.log(Yt.dim(`\u2502 \u2514\u2500\u2500 ${e}`))}progressList(e){if(!(this.quiet||!this.currentAgent))for(let t of e)console.log(Yt.dim(`\u2502 \u2514\u2500\u2500 ${t}`))}endAgent(e=!0){if(this.quiet||!this.currentAgent)return;let t=Date.now()-this.startTime,s=this.formatDuration(t),n=e?Yt.green("\u2713"):Yt.red("\u2717");console.log(`\u2514\u2500 ${n} ${e?"Complete":"Failed"} ${Yt.dim(`(${s})`)}
679
+ `),this.currentAgent=null}status(e,t){this.quiet||console.log(`${e} ${t}`)}complete(e,t){if(this.quiet)return;let s=t?` ${Yt.dim(`[${this.formatDuration(t)}]`)}`:"";console.log(Yt.green(`\u2705 ${e}${s}`))}formatDuration(e){return e<1e3?`${e}ms`:`${(e/1e3).toFixed(1)}s`}},Kp=new xc});import st from"chalk";function Wk(r){let e=0;for(let s of r)e=(e<<5)-e+s.charCodeAt(0),e=e&e;let t=Math.abs(e)%Yp.length;return Yp[t]}function Vk(r,e,t="\u25B6"){let s=st.dim(String(r+1).padStart(2)),o=Wk(e.domain)(e.domain.padEnd(10)),i=e.description.length>32?`${e.description.slice(0,29)}...`:e.description.padEnd(32),a;switch(e.status){case"completed":a=st.green("\u2713 Complete");break;case"in_progress":a=st.yellow(`${t} Working...`);break;case"pending":a=st.gray("\u25CB Pending");break;case"failed":a=st.red("\u2717 Failed");break;case"blocked":a=st.gray("\u2298 Blocked");break;default:a=st.gray(`\u25CB ${e.status}`)}return` ${s} ${o} ${i} ${a}`}function Bk(r){if(r.length===0)return"";let e=[];e.push(""),e.push(` ${st.bold.white("SUBTASK PROGRESS")}`),e.push(` ${st.dim("\u2500".repeat(58))}`);for(let t=0;t<r.length;t++)e.push(Vk(t,r[t]));return e.push(""),e.join(`
680
+ `)}function Qp(r){console.log(Bk(r))}var Yp,Zp=S(()=>{"use strict";Yp=[st.cyan,st.magenta,st.yellow,st.blue,st.green,st.redBright,st.magentaBright,st.cyanBright];l(Wk,"getDomainColor");l(Vk,"formatSubtaskLine");l(Bk,"renderSubtaskProgress");l(Qp,"printSubtaskProgress")});var em,tm,Rc,Ac=S(()=>{"use strict";em=["task","done","ship","resume","bug","enrich"],tm=["init","sync","pause","next","dash","history","undo","redo"],Rc=["ship","feature","spec","cleanup","migrate"]});function zk(r){return Rc.includes(r)}async function Jk(r,e,t){let s=[],n=[],o=[];switch(r){case"ship":t.now&&!t.now.includes("No current task")?s.push({step:"Has active task",passed:!0}):(s.push({step:"Has active task",passed:!1,details:"No active task to ship"}),o.push("No active task")),t.shipped?s.push({step:"Shipped log accessible",passed:!0}):s.push({step:"Shipped log accessible",passed:!1,details:"shipped.md not found"}),n.push("Read current task from now.md"),n.push("Calculate duration"),n.push("Append to shipped.md"),n.push("Clear now.md"),n.push("Update metrics");break;case"feature":e.params.description||e.params.feature?s.push({step:"Has feature description",passed:!0}):(s.push({step:"Has feature description",passed:!1,details:"No description provided"}),o.push("Missing feature description")),t.analysis?s.push({step:"Project analyzed",passed:!0}):s.push({step:"Project analyzed",passed:!1,details:"Run /p:sync first"}),n.push("Parse feature description"),n.push("Generate tasks breakdown"),n.push("Add to roadmap.md"),n.push("Add tasks to next.md"),n.push("Suggest starting first task");break;case"spec":e.params.feature||e.params.name?s.push({step:"Has spec name",passed:!0}):(s.push({step:"Has spec name",passed:!1,details:"No spec name provided"}),o.push("Missing spec name")),n.push("Generate spec template"),n.push("Analyze requirements"),n.push("Create spec file"),n.push("Link to roadmap");break;case"cleanup":t.analysis?s.push({step:"Has code analysis",passed:!0}):s.push({step:"Has code analysis",passed:!1,details:"Run /p:analyze first"}),n.push("Scan for unused code"),n.push("Identify dead imports"),n.push("List files to clean"),n.push("Show preview"),n.push("Wait for approval"),n.push("Execute cleanup");break;case"migrate":s.push({step:"Migration safety check",passed:!0,details:"Will require manual approval"}),n.push("Analyze current state"),n.push("Generate migration plan"),n.push("Show affected files"),n.push("Request approval"),n.push("Execute migration"),n.push("Verify results");break;default:n.push("Execute command");break}let i=s.filter(u=>u.passed).length,a=s.length,c=a>0?i/a:1;return{commandName:r,reasoning:s.length>0?{steps:s,allPassed:o.length===0,criticalIssues:o}:null,plan:n,confidence:c}}function qk(r){let e=[];return e.push(`\u{1F4CB} Chain of Thought: ${r.commandName}`),e.push(""),r.reasoning&&(e.push("Steps:"),r.reasoning.steps.forEach(t=>{let s=t.passed?"\u2705":"\u274C";e.push(` ${s} ${t.step}`),t.details&&e.push(` ${t.details}`)}),e.push(""),r.reasoning.criticalIssues.length>0&&(e.push("Critical Issues:"),r.reasoning.criticalIssues.forEach(t=>{e.push(` \u26A0\uFE0F ${t}`)}),e.push(""))),r.plan.length>0&&(e.push("Plan:"),r.plan.forEach((t,s)=>{e.push(` ${s+1}. ${t}`)}),e.push("")),e.push(`Confidence: ${Math.round(r.confidence*100)}%`),e.join(`
681
+ `)}var Kk,Ho,sm=S(()=>{"use strict";Ac();l(zk,"requiresReasoning");l(Jk,"reason");l(qk,"formatPlan");Kk={requiresReasoning:zk,reason:Jk,formatPlan:qk,REASONING_REQUIRED_COMMANDS:Rc},Ho=Kk});import Go from"node:fs/promises";var Dc,Xk,Wt,jc=S(()=>{"use strict";Et();Te();W();Ms();K();Dc=class{static{l(this,"ContextBuilder")}_cache;_currentProjectId;constructor(){this._cache=new dn({ttl:5e3,maxSize:200}),this._currentProjectId=null}async build(e,t={}){let s=await $.getProjectId(e),n=A.getGlobalProjectPath(s);return this._currentProjectId!==null&&this._currentProjectId!==s&&this._cache.clear(),this._currentProjectId=s,{projectId:s,projectPath:e,globalPath:n,paths:{now:A.getFilePath(s,"core","now.md"),next:A.getFilePath(s,"core","next.md"),context:A.getFilePath(s,"core","context.md"),shipped:A.getFilePath(s,"progress","shipped.md"),metrics:A.getFilePath(s,"progress","metrics.md"),ideas:A.getFilePath(s,"planning","ideas.md"),roadmap:A.getFilePath(s,"planning","roadmap.md"),specs:A.getFilePath(s,"planning","specs"),memory:A.getFilePath(s,"memory","context.jsonl"),patterns:A.getFilePath(s,"memory","patterns.json"),analysis:A.getFilePath(s,"analysis","repo-summary.md"),codePatterns:A.getFilePath(s,"analysis","patterns.md")},params:t,timestamp:new Date().toISOString(),date:new Date().toISOString().split("T")[0]}}async loadState(e,t=null){let s={},n=Object.entries(e.paths),o=t?n.filter(([a])=>t.includes(a)):n;for(let[,a]of o){let c=this._cache.get(a);if(c!==null)try{let u=await Go.stat(a);(!c.mtime||u.mtimeMs>c.mtime)&&this._cache.delete(a)}catch(u){if(R(u))this._cache.delete(a);else throw u}}let i=[];for(let[a,c]of o){let u=this._cache.get(c);u!==null?s[a]=u.content:i.push([a,c])}if(i.length>0){let a=i.map(async([u,p])=>{try{let[m,d]=await Promise.all([Go.readFile(p,"utf-8"),Go.stat(p)]);return{key:u,filePath:p,content:m,mtime:d.mtimeMs}}catch(m){if(R(m))return{key:u,filePath:p,content:null,mtime:null};throw m}}),c=await Promise.all(a);for(let{key:u,filePath:p,content:m,mtime:d}of c)s[u]=m,this._cache.set(p,{content:m,mtime:d})}return s}async loadStateForCommand(e,t){let s={now:["now","next","analysis","codePatterns"],done:["now","next","metrics","analysis"],next:["next","analysis"],ship:["now","shipped","metrics","analysis"],recap:["shipped","metrics","now","analysis"],progress:["shipped","metrics","analysis"],idea:["ideas","next","analysis"],feature:["roadmap","next","ideas","analysis","codePatterns"],roadmap:["roadmap","analysis"],spec:["roadmap","next","specs","analysis","codePatterns"],analyze:["analysis","context","codePatterns"],sync:["analysis","context","now","codePatterns"],work:["now","next","analysis","context","codePatterns"],build:["now","next","analysis","context","codePatterns"],design:["analysis","context","codePatterns"],cleanup:["analysis","context","codePatterns"],fix:["analysis","context","codePatterns"],test:["analysis","context","codePatterns"],default:["analysis","codePatterns"]},n=s[t]||s.default;return this.loadState(e,n)}async batchRead(e){let t=new Map,s=[];for(let n of e){let o=this._cache.get(n);o!==null?t.set(n,o.content):s.push(n)}if(s.length>0){let n=s.map(async i=>{try{let a=await Go.readFile(i,"utf-8");return{filePath:i,content:a}}catch(a){if(R(a))return{filePath:i,content:null};throw a}}),o=await Promise.all(n);for(let{filePath:i,content:a}of o)t.set(i,a),this._cache.set(i,{content:a,mtime:null})}return t}invalidateCache(e){this._cache.delete(e)}clearCache(){this._cache.clear(),this._currentProjectId=null}async fileExists(e){return P(e)}getCacheStats(){return this._cache.stats()}},Xk=new Dc,Wt=Xk});import Be from"node:fs/promises";import nm from"node:os";import Cs from"node:path";function Ic(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Yk(r){if(r.verified||r.warnings.length===0)return null;let e=` Ground Truth Warnings:
653
682
  `;return r.warnings.forEach(t=>{e+=` - ${t}
654
683
  `}),r.recommendations.length>0&&(e+=`
655
684
  Recommendations:
656
685
  `,r.recommendations.forEach(t=>{e+=` -> ${t}
657
- `})),e}async function tm(r){let e=[],t=[],s={},n=r.paths.now;try{let a=await We.readFile(n,"utf-8");s.nowExists=!0,s.nowContent=a.trim(),s.nowLength=a.length,(a.includes("No current task")||a.match(/^#\s*NOW\s*$/m))&&(e.push("now.md appears to be empty or placeholder"),t.push('Start a task first with /p:now "task"'));let c=a.match(/Started:\s*(.+)/i);if(c){s.startedAt=c[1];let u=new Date(c[1]);Number.isNaN(u.getTime())||(s.durationMs=Date.now()-u.getTime(),s.durationFormatted=ft(s.durationMs))}}catch(a){if(R(a))s.nowExists=!1,e.push("now.md does not exist"),t.push('Create a task with /p:now "task"');else throw a}let o=r.paths.next;try{let a=await We.readFile(o,"utf-8");s.nextExists=!0;let c=a.match(/- \[ \]/g)||[];s.pendingTasks=c.length}catch(a){if(R(a))s.nextExists=!1,s.pendingTasks=0;else throw a}let i=r.paths.metrics;try{await We.access(Cs.dirname(i),We.constants.W_OK),s.metricsWritable=!0}catch(a){if(R(a))s.metricsWritable=!1,e.push("Cannot write to metrics directory");else throw a}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function sm(r){let e=[],t=[],s={};try{let{stdout:i}=await N("git status --porcelain",{cwd:r.projectPath});s.hasUncommittedChanges=i.trim().length>0,s.uncommittedFiles=i.trim().split(`
658
- `).filter(Boolean).length,s.hasUncommittedChanges&&(e.push(`${s.uncommittedFiles} uncommitted file(s)`),t.push("Commit changes before shipping"))}catch{s.gitAvailable=!1}let n=Cs.join(r.projectPath,"package.json");try{let i=await We.readFile(n,"utf-8"),a=JSON.parse(i);s.currentVersion=a.version,s.hasPackageJson=!0}catch(i){if(R(i))s.hasPackageJson=!1;else if(i instanceof SyntaxError)s.hasPackageJson=!1,e.push("package.json has invalid JSON");else throw i}let o=r.paths.shipped;try{let i=await We.readFile(o,"utf-8");s.shippedExists=!0;let a=r.params.feature||r.params.description;if(a){let c=new Date().toISOString().split("T")[0];new RegExp(`${c}.*${Dc(a)}`,"i").test(i)&&(e.push(`Feature "${a}" already shipped today`),t.push("Use a different feature name or skip /p:ship"))}}catch(i){if(R(i))s.shippedExists=!1;else throw i}if(s.hasPackageJson)try{let i=await We.readFile(n,"utf-8"),a=JSON.parse(i);s.hasTestScript=!!a.scripts?.test}catch(i){if(R(i)||i instanceof SyntaxError)s.hasTestScript=!1;else throw i}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function nm(r){let e=[],t=[],s={},n=r.paths.next;try{let a=await We.readFile(n,"utf-8");s.nextExists=!0;let c=a.match(/- \[[ x]\]/g)||[];s.taskCount=c.length,s.pendingTasks=(a.match(/- \[ \]/g)||[]).length,s.taskCount>=90&&(e.push(`Queue nearly full (${s.taskCount}/100 tasks)`),t.push("Complete some tasks before adding more"))}catch(a){if(R(a))s.nextExists=!1,s.taskCount=0;else throw a}let o=r.paths.roadmap;try{let a=await We.readFile(o,"utf-8");s.roadmapExists=!0;let c=r.params.description||r.params.feature;c&&new RegExp(Dc(c),"i").test(a)&&(e.push(`Feature "${c}" may already exist in roadmap`),t.push("Check roadmap for duplicates with /p:roadmap"))}catch(a){if(R(a))s.roadmapExists=!1;else throw a}let i=r.paths.now;try{let a=await We.readFile(i,"utf-8");s.hasActiveTask=a.trim().length>0&&!a.includes("No current task"),s.hasActiveTask&&t.push("Consider completing current task first with /p:done")}catch(a){if(R(a))s.hasActiveTask=!1;else throw a}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function rm(r){let e=[],t=[],s={},n=r.paths.now;try{let i=await We.readFile(n,"utf-8");s.nowExists=!0,s.nowContent=i.trim();let a=i.trim().length>0&&!i.includes("No current task")&&!i.match(/^#\s*NOW\s*$/m);if(s.hasActiveTask=a,a&&r.params.task){let c=i.substring(0,50).replace(/\n/g," ");e.push(`Replacing existing task: "${c}..."`),t.push("Use /p:done first to track completion")}}catch(i){if(R(i))s.nowExists=!1,s.hasActiveTask=!1;else throw i}let o=r.paths.next;try{let a=((await We.readFile(o,"utf-8")).match(/- \[ \]/g)||[]).length;s.pendingTasks=a,!r.params.task&&a>0&&t.push(`${a} tasks available in queue`)}catch(i){if(R(i))s.pendingTasks=0;else throw i}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function om(r){let e=[],t=[],s={},n=Cs.join(r.projectPath,".prjct/prjct.config.json");try{let i=await We.readFile(n,"utf-8");s.alreadyInitialized=!0,s.existingConfig=JSON.parse(i),e.push("Project already initialized"),t.push("Use /p:analyze to refresh analysis or delete .prjct/ to reinitialize")}catch(i){if(R(i))s.alreadyInitialized=!1;else if(i instanceof SyntaxError)s.alreadyInitialized=!1,e.push("Existing config has invalid JSON");else throw i}let o=Cs.join(em.homedir(),".prjct-cli");try{await We.access(o,We.constants.W_OK),s.globalPathWritable=!0}catch(i){if(R(i))try{await We.mkdir(o,{recursive:!0}),s.globalPathWritable=!0,s.globalPathCreated=!0}catch{s.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}else s.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function im(r){let e=[],t=[],s={},n=Cs.join(r.projectPath,".prjct/prjct.config.json");try{let a=await We.readFile(n,"utf-8");s.hasConfig=!0,s.config=JSON.parse(a)}catch(a){if(R(a))return s.hasConfig=!1,e.push("Project not initialized"),t.push("Run /p:init first"),{verified:!1,actual:s,warnings:e,recommendations:t};if(a instanceof SyntaxError)return s.hasConfig=!1,e.push("Config file has invalid JSON"),t.push("Delete .prjct/ and run /p:init"),{verified:!1,actual:s,warnings:e,recommendations:t};throw a}let o=s.config?.projectId,i=Cs.join(em.homedir(),".prjct-cli/projects",o||"");return await C(i)?s.globalStorageExists=!0:(s.globalStorageExists=!1,e.push("Global storage missing"),t.push("Run /p:init to recreate")),{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function am(r){let e=[],t=[],s={},n=["package.json","Cargo.toml","go.mod","requirements.txt","Gemfile","pom.xml"];s.detectedFiles=[];for(let i of n)await C(Cs.join(r.projectPath,i))&&s.detectedFiles.push(i);s.detectedFiles.length===0&&(e.push("No recognizable project files detected"),t.push("Analysis may be limited without package.json or similar"));let o=["src","lib","app","core","components"];s.detectedSrcDirs=[];for(let i of o)try{(await We.stat(Cs.join(r.projectPath,i))).isDirectory()&&s.detectedSrcDirs.push(i)}catch(a){if(!R(a))throw a}return{verified:!0,actual:s,warnings:e,recommendations:t}}async function cm(r){let e=[],t=[],s={},n=r.paths.specs;if(await C(n)){s.specsExists=!0;let i=await We.readdir(n);s.existingSpecs=i.filter(a=>a.endsWith(".md")),s.specCount=s.existingSpecs.length}else s.specsExists=!1,s.specCount=0;let o=r.params.feature||r.params.name||r.params.description;if(o&&s.existingSpecs){let i=o.toLowerCase().replace(/\s+/g,"-");s.existingSpecs.includes(`${i}.md`)&&(e.push(`Spec "${o}" already exists`),t.push("Use a different name or edit existing spec"))}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function um(r,e,t){let s=lm[r];if(!s)return{verified:!0,actual:{},warnings:[],recommendations:[]};try{return await s(e,t)}catch(n){return{verified:!1,actual:{},warnings:[`Verification error: ${y(n)}`],recommendations:["Check file permissions and project configuration"]}}}async function Kk(r,e,t){let s=await um(r,e,t);return{...e,groundTruth:{...s,verifiedAt:new Date().toISOString(),command:r}}}function Xk(r){return["done","ship","feature","spec","now","init","sync","analyze"].includes(r)}var lm,Yk,Fo,dm=S(()=>{"use strict";V();Ue();q();oe();l(Dc,"escapeRegex");l(qk,"formatWarnings");l(tm,"verifyDone");l(sm,"verifyShip");l(nm,"verifyFeature");l(rm,"verifyNow");l(om,"verifyInit");l(im,"verifySync");l(am,"verifyAnalyze");l(cm,"verifySpec");lm={done:tm,ship:sm,feature:nm,now:rm,init:om,sync:im,analyze:am,spec:cm};l(um,"verify");l(Kk,"prepareCommand");l(Xk,"requiresVerification");Yk={verify:um,prepareCommand:Kk,requiresVerification:Xk,verifiers:lm,formatWarnings:qk,formatDuration:ft,escapeRegex:Dc,verifyDone:tm,verifyShip:sm,verifyFeature:nm,verifyNow:rm,verifyInit:om,verifySync:im,verifyAnalyze:am,verifySpec:cm},Fo=Yk});function Zk(r){return{contradiction:"Verify file/resource state before reporting. Use Read tool to check actual state.",state:"Check current task state from now.md before assuming completion.",invented:"Verify prerequisites exist (package.json, git remote) before claiming actions."}[r]||"Verify actual state before proceeding."}function eS(r){if(!r||typeof r!="string")return{detected:!1};for(let{pattern:e,type:t,description:s}of Qk)if(e.test(r))return{detected:!0,type:t,pattern:e.source,description:s,message:`Potential hallucination detected: ${s}`,suggestion:Zk(t)};return{detected:!1}}function tS(r,e){if(!r||!e)return!1;let t=l(s=>s.toLowerCase().replace(/[0-9]+/g,"N").replace(/['"`]/g,"").replace(/\s+/g," ").trim(),"normalize");return t(r)===t(e)}function sS(r){if(!r||r.length===0)return{type:"unknown",description:"No error information"};let e=r[r.length-1]?.message?.toLowerCase()||"";return e.includes("permission")||e.includes("access denied")?{type:"permission",description:"File or directory permission issue"}:e.includes("not found")||e.includes("no such file")?{type:"not_found",description:"File or resource not found"}:e.includes("syntax")||e.includes("parse")?{type:"syntax",description:"Syntax or parsing error"}:e.includes("timeout")||e.includes("timed out")?{type:"timeout",description:"Operation timed out"}:e.includes("network")||e.includes("connection")?{type:"network",description:"Network or connection issue"}:e.includes("config")||e.includes("configuration")?{type:"config",description:"Configuration issue"}:e.includes("validation")||e.includes("invalid")?{type:"validation",description:"Validation failed"}:{type:"unknown",description:"Unrecognized error pattern"}}function nS(r,e,t){let s={permission:`I've tried ${r} ${t} times but keep hitting permission issues.`,not_found:`After ${t} attempts, I still can't find the required file or resource.`,syntax:`I'm encountering repeated syntax errors with ${r}.`,timeout:`The operation keeps timing out after ${t} attempts.`,network:`Network issues are preventing ${r} from completing.`,validation:`Validation keeps failing for ${r}.`,config:`There seems to be a configuration issue affecting ${r}.`,unknown:`I've tried ${r} ${t} times without success.`};return s[e.type]||s.unknown}function rS(r){let e={permission:"Check file permissions. Try: chmod -R u+w ~/.prjct-cli/",not_found:"Verify the file path exists. Run /p:init if project not initialized.",syntax:"Check the file format. There may be invalid JSON or markdown.",timeout:"Check your network connection or try again in a moment.",network:"Verify internet connection and try again.",validation:"Review the input parameters and try with different values.",config:"Check .prjct/prjct.config.json for issues. Try /p:init to reinitialize.",unknown:"Can you check the issue manually and provide more context?"};return e[r.type]||e.unknown}var Qk,jc,oS,Rn,pm=S(()=>{"use strict";Qk=[{pattern:/file.*not found.*created/i,type:"contradiction",description:"Claims file created but also not found"},{pattern:/created.*but.*error/i,type:"contradiction",description:"Claims success but also error"},{pattern:/successfully.*failed/i,type:"contradiction",description:"Contradictory success/failure"},{pattern:/already.*completed.*completing/i,type:"state",description:"Completing already-completed task"},{pattern:/no task.*marking complete/i,type:"state",description:"Completing non-existent task"},{pattern:/no.*active.*done with/i,type:"state",description:"Finishing task that doesnt exist"},{pattern:/version.*updated.*no package/i,type:"invented",description:"Version update without package.json"},{pattern:/committed.*nothing to commit/i,type:"invented",description:"Commit without changes"},{pattern:/pushed.*no remote/i,type:"invented",description:"Push without remote"}];l(Zk,"getHallucinationSuggestion");l(eS,"detectHallucination");l(tS,"isSimilarError");l(sS,"analyzeErrorPattern");l(nS,"generateEscalationMessage");l(rS,"generateSuggestion");jc=class{static{l(this,"LoopDetector")}_attempts;_errorPatterns;maxAttempts;sessionTimeout;constructor(){this._attempts=new Map,this._errorPatterns=new Map,this.maxAttempts=3,this.sessionTimeout=300*1e3}_getKey(e,t=""){return`${e}:${t}`.toLowerCase()}recordAttempt(e,t="",s={}){let n=this._getKey(e,t),o=Date.now(),i=this._attempts.get(n);return(!i||o-i.lastAttempt>this.sessionTimeout)&&(i={command:e,context:t,attempts:0,errors:[],firstAttempt:o,lastAttempt:o,success:!1}),i.attempts++,i.lastAttempt=o,i.success=s.success||!1,s.error&&i.errors.push({message:s.error,timestamp:o}),this._attempts.set(n,i),{attemptNumber:i.attempts,isLooping:this.isLooping(e,t),shouldEscalate:this.shouldEscalate(e,t)}}isLooping(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);if(!n)return!1;if(n.attempts>=2&&!n.success){let o=n.errors.slice(-3);if(o.length>=2){let i=o[0]?.message||"";return o.every(c=>tS(c.message,i))}}return!1}shouldEscalate(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);return n?n.attempts>=this.maxAttempts&&!n.success:!1}getEscalationInfo(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);if(!n)return null;let o=sS(n.errors);return{status:"BLOCKED",command:e,context:t,attempts:n.attempts,duration:n.lastAttempt-n.firstAttempt,errorPattern:o,message:nS(e,o,this.maxAttempts),suggestion:rS(o),lastError:n.errors[n.errors.length-1]?.message||null}}recordSuccess(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);n&&(n.success=!0,n.attempts=0,n.errors=[],this._attempts.set(s,n))}clearTracking(e,t=""){let s=this._getKey(e,t);this._attempts.delete(s)}clearAll(){this._attempts.clear(),this._errorPatterns.clear()}getStats(){let e={activeTracking:this._attempts.size,commands:{}};for(let[t,s]of this._attempts)e.commands[t]={attempts:s.attempts,success:s.success,errorCount:s.errors.length};return e}detectHallucination(e){return eS(e)}analyzeOutput(e,t){let s=this.detectHallucination(t);return s.detected?(this.recordAttempt(e,"hallucination",{success:!1,error:`HALLUCINATION: ${s.description}`}),{...s,shouldBlock:!0,action:"VERIFY_STATE"}):{detected:!1,shouldBlock:!1}}},oS=new jc,Rn=oS});function Ic(r,e){let t=Dr(e),s=_u[t.startDay],n=new Date(r);n.setHours(0,0,0,0);let i=(n.getDay()-s+7)%7;return n.setDate(n.getDate()-i),n}function iS(r,e){let t=Dr(e),s=new Date(r);return s.setDate(s.getDate()+t.sprintLengthDays-1),s.setHours(23,59,59,999),s}function aS(r,e,t){let s=Dr(t),n=Ic(r,t),o=Ic(e,t),i=n.getTime()-o.getTime(),a=Math.round(i/(1e3*60*60*24));return Math.floor(a/s.sprintLengthDays)+1}function Uo(r,e=bs){let t=Dr(e);if(r.length===0)return{sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:new Date().toISOString()};let s=cS(r,e),n=lS(s,t.accuracyTolerance),o=n.slice(-t.windowSize),i=pS(o),a=uS(o),c=dS(r,t.accuracyTolerance),{overEstimated:u,underEstimated:p}=mS(r);return{sprints:n,averageVelocity:i,velocityTrend:a,estimationAccuracy:c,overEstimated:u,underEstimated:p,lastUpdated:new Date().toISOString()}}function gm(r,e,t=bs){let s=Dr(t);if(e<=0)return{totalPoints:r,sprints:0,estimatedDate:""};let n=Math.ceil(r/e),o=n*s.sprintLengthDays,i=new Date;return i.setDate(i.getDate()+o),{totalPoints:r,sprints:n,estimatedDate:i.toISOString()}}function cS(r,e){let t=new Map,s=r.map(o=>new Date(o.completedAt)),n=new Date(Math.min(...s.map(o=>o.getTime())));for(let o of r){let i=new Date(o.completedAt),a=aS(i,n,e);if(!t.has(a)){let c=Ic(i,e),u=iS(c,e);t.set(a,{sprintNumber:a,startDate:c,endDate:u,outcomes:[]})}t.get(a).outcomes.push(o)}return t}function lS(r,e){let t=[];for(let[,s]of r){let n=s.outcomes.reduce((u,p)=>u+gS(p),0),o=s.outcomes.filter(u=>u.variance).map(u=>$c(u)),i=o.length>0?Math.round(o.reduce((u,p)=>u+p,0)/o.length):0,a=o.filter(u=>Math.abs(u)<=e).length,c=o.length>0?Math.round(a/o.length*100):0;t.push({sprintNumber:s.sprintNumber,startDate:s.startDate.toISOString(),endDate:s.endDate.toISOString(),pointsCompleted:n,tasksCompleted:s.outcomes.length,avgVariance:i,estimationAccuracy:c})}return t.sort((s,n)=>s.sprintNumber-n.sprintNumber)}function uS(r){if(r.length<3)return"stable";let e=r.map(p=>p.pointsCompleted),t=e.length,s=0,n=0,o=0,i=0;for(let p=0;p<t;p++)s+=p,n+=e[p],o+=p*e[p],i+=p*p;let a=(t*o-s*n)/(t*i-s*s),c=n/t;if(c===0)return"stable";let u=a/c;return u>.1?"improving":u<-.1?"declining":"stable"}function dS(r,e){let t=r.filter(n=>n.variance);if(t.length===0)return 0;let s=t.filter(n=>{let o=$c(n);return Math.abs(o)<=e});return Math.round(s.length/t.length*100)}function pS(r){if(r.length===0)return 0;let e=r.reduce((t,s)=>t+s.pointsCompleted,0);return Math.round(e/r.length*10)/10}function mS(r){let e=new Map;for(let n of r){if(!n.variance)continue;let o=$c(n),i=n.tags&&n.tags.length>0?n.tags:["uncategorized"];for(let a of i){e.has(a)||e.set(a,{variances:[],count:0});let c=e.get(a);c.variances.push(o),c.count++}}let t=[],s=[];for(let[n,o]of e){if(o.count<2)continue;let i=Math.round(o.variances.reduce((a,c)=>a+c,0)/o.variances.length);i>10?s.push({category:n,avgVariance:i,taskCount:o.count}):i<-10&&t.push({category:n,avgVariance:Math.abs(i),taskCount:o.count})}return t.sort((n,o)=>o.avgVariance-n.avgVariance),s.sort((n,o)=>o.avgVariance-n.avgVariance),{overEstimated:t,underEstimated:s}}function $c(r){if(!r.variance)return 0;let e=ht(r.estimatedDuration),t=ht(r.actualDuration);return e<=0?0:Math.round((t-e)/e*100)}function fm(r){if(r.sprints.length===0)return"No velocity data available yet.";let e=[];e.push(`Project velocity: ${r.averageVelocity} pts/sprint (trend: ${r.velocityTrend})`),e.push(`Estimation accuracy: ${r.estimationAccuracy}%`);for(let t of r.underEstimated)e.push(`\u26A0 "${t.category}" tasks historically take ${t.avgVariance}% longer than estimated`);for(let t of r.overEstimated)e.push(`"${t.category}" tasks typically finish ${t.avgVariance}% faster than estimated`);return e.join(`
659
- `)}function gS(r){if(!r.estimatedDuration)return 0;let e=ht(r.estimatedDuration);if(e<=0)return 0;let t=mm[0],s=Number.POSITIVE_INFINITY;for(let n of mm){let o=Math.abs(n.typical-e);o<s&&(s=o,t=n)}return t.points}function Dr(r){return{sprintLengthDays:r.sprintLengthDays??7,startDay:r.startDay??"monday",windowSize:r.windowSize??6,accuracyTolerance:r.accuracyTolerance??20}}var mm,Mc=S(()=>{"use strict";yr();Tr();oe();l(Ic,"getSprintStart");l(iS,"getSprintEnd");l(aS,"getSprintNumber");l(Uo,"calculateVelocity");l(gm,"projectCompletion");l(cS,"bucketBySprint");l(lS,"buildSprintVelocities");l(uS,"detectTrend");l(dS,"calculateOverallAccuracy");l(pS,"calculateAverageVelocity");l(mS,"detectEstimationPatterns");l($c,"parseVariancePercent");l(fm,"formatVelocityContext");mm=[{points:1,typical:10},{points:2,typical:20},{points:3,typical:45},{points:5,typical:90},{points:8,typical:180},{points:13,typical:360},{points:21,typical:720}];l(gS,"derivePoints");l(Dr,"resolveConfig")});import fS from"node:fs/promises";import Ho from"node:path";async function An(r,e,t={}){let s=Date.now(),n=t.maxFiles??30,o=t.minScore??.1,i=t.includeTests??!1,a=Oc(r),c=await kS(e),u=await SS(e),p=[];for(let d of c){if(!i&&vS(d))continue;let g=bS(d,a,u,t.historicalBoosts);g.score>=o&&p.push(g)}p.sort((d,g)=>g.score-d.score);let m=p.slice(0,n);return{files:m,metrics:{filesScanned:c.length,filesReturned:m.length,scanDuration:Date.now()-s}}}function Oc(r){let e=r.toLowerCase().split(/[^a-z0-9]+/).filter(Boolean),t=new Set(["a","an","the","and","or","but","is","are","was","were","be","been","being","have","has","had","do","does","did","will","would","could","should","may","might","must","shall","can","need","to","of","in","for","on","with","at","by","from","as","into","through","during","before","after","above","below","between","under","again","further","then","once","here","there","when","where","why","how","all","each","few","more","most","other","some","such","no","nor","not","only","own","same","so","than","too","very","just","add","create","make","implement","fix","update","change","modify","remove","delete","new"]);return e.filter(s=>!t.has(s)&&s.length>2)}async function kS(r){let e=[];async function t(s,n=""){try{let o=await fS.readdir(s,{withFileTypes:!0});for(let i of o){let a=Ho.join(s,i.name),c=Ho.join(n,i.name);if(i.isDirectory()){if(wS.has(i.name)||i.name.startsWith("."))continue;await t(a,c)}else if(i.isFile()){let u=Ho.extname(i.name).toLowerCase();yS.has(u)&&e.push(c)}}}catch(o){R(o)}}return l(t,"walk"),await t(r),e}async function SS(r){let e=new Map;try{let{stdout:t}=await N(`git log -30 --pretty=format:"%H %ct" --name-only | awk '
686
+ `})),e}async function rm(r){let e=[],t=[],s={},n=r.paths.now;try{let a=await Be.readFile(n,"utf-8");s.nowExists=!0,s.nowContent=a.trim(),s.nowLength=a.length,(a.includes("No current task")||a.match(/^#\s*NOW\s*$/m))&&(e.push("now.md appears to be empty or placeholder"),t.push('Start a task first with /p:now "task"'));let c=a.match(/Started:\s*(.+)/i);if(c){s.startedAt=c[1];let u=new Date(c[1]);Number.isNaN(u.getTime())||(s.durationMs=Date.now()-u.getTime(),s.durationFormatted=ht(s.durationMs))}}catch(a){if(R(a))s.nowExists=!1,e.push("now.md does not exist"),t.push('Create a task with /p:now "task"');else throw a}let o=r.paths.next;try{let a=await Be.readFile(o,"utf-8");s.nextExists=!0;let c=a.match(/- \[ \]/g)||[];s.pendingTasks=c.length}catch(a){if(R(a))s.nextExists=!1,s.pendingTasks=0;else throw a}let i=r.paths.metrics;try{await Be.access(Cs.dirname(i),Be.constants.W_OK),s.metricsWritable=!0}catch(a){if(R(a))s.metricsWritable=!1,e.push("Cannot write to metrics directory");else throw a}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function om(r){let e=[],t=[],s={};try{let{stdout:i}=await O("git status --porcelain",{cwd:r.projectPath});s.hasUncommittedChanges=i.trim().length>0,s.uncommittedFiles=i.trim().split(`
687
+ `).filter(Boolean).length,s.hasUncommittedChanges&&(e.push(`${s.uncommittedFiles} uncommitted file(s)`),t.push("Commit changes before shipping"))}catch{s.gitAvailable=!1}let n=Cs.join(r.projectPath,"package.json");try{let i=await Be.readFile(n,"utf-8"),a=JSON.parse(i);s.currentVersion=a.version,s.hasPackageJson=!0}catch(i){if(R(i))s.hasPackageJson=!1;else if(i instanceof SyntaxError)s.hasPackageJson=!1,e.push("package.json has invalid JSON");else throw i}let o=r.paths.shipped;try{let i=await Be.readFile(o,"utf-8");s.shippedExists=!0;let a=r.params.feature||r.params.description;if(a){let c=new Date().toISOString().split("T")[0];new RegExp(`${c}.*${Ic(a)}`,"i").test(i)&&(e.push(`Feature "${a}" already shipped today`),t.push("Use a different feature name or skip /p:ship"))}}catch(i){if(R(i))s.shippedExists=!1;else throw i}if(s.hasPackageJson)try{let i=await Be.readFile(n,"utf-8"),a=JSON.parse(i);s.hasTestScript=!!a.scripts?.test}catch(i){if(R(i)||i instanceof SyntaxError)s.hasTestScript=!1;else throw i}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function im(r){let e=[],t=[],s={},n=r.paths.next;try{let a=await Be.readFile(n,"utf-8");s.nextExists=!0;let c=a.match(/- \[[ x]\]/g)||[];s.taskCount=c.length,s.pendingTasks=(a.match(/- \[ \]/g)||[]).length,s.taskCount>=90&&(e.push(`Queue nearly full (${s.taskCount}/100 tasks)`),t.push("Complete some tasks before adding more"))}catch(a){if(R(a))s.nextExists=!1,s.taskCount=0;else throw a}let o=r.paths.roadmap;try{let a=await Be.readFile(o,"utf-8");s.roadmapExists=!0;let c=r.params.description||r.params.feature;c&&new RegExp(Ic(c),"i").test(a)&&(e.push(`Feature "${c}" may already exist in roadmap`),t.push("Check roadmap for duplicates with /p:roadmap"))}catch(a){if(R(a))s.roadmapExists=!1;else throw a}let i=r.paths.now;try{let a=await Be.readFile(i,"utf-8");s.hasActiveTask=a.trim().length>0&&!a.includes("No current task"),s.hasActiveTask&&t.push("Consider completing current task first with /p:done")}catch(a){if(R(a))s.hasActiveTask=!1;else throw a}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function am(r){let e=[],t=[],s={},n=r.paths.now;try{let i=await Be.readFile(n,"utf-8");s.nowExists=!0,s.nowContent=i.trim();let a=i.trim().length>0&&!i.includes("No current task")&&!i.match(/^#\s*NOW\s*$/m);if(s.hasActiveTask=a,a&&r.params.task){let c=i.substring(0,50).replace(/\n/g," ");e.push(`Replacing existing task: "${c}..."`),t.push("Use /p:done first to track completion")}}catch(i){if(R(i))s.nowExists=!1,s.hasActiveTask=!1;else throw i}let o=r.paths.next;try{let a=((await Be.readFile(o,"utf-8")).match(/- \[ \]/g)||[]).length;s.pendingTasks=a,!r.params.task&&a>0&&t.push(`${a} tasks available in queue`)}catch(i){if(R(i))s.pendingTasks=0;else throw i}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function cm(r){let e=[],t=[],s={},n=Cs.join(r.projectPath,".prjct/prjct.config.json");try{let i=await Be.readFile(n,"utf-8");s.alreadyInitialized=!0,s.existingConfig=JSON.parse(i),e.push("Project already initialized"),t.push("Use /p:analyze to refresh analysis or delete .prjct/ to reinitialize")}catch(i){if(R(i))s.alreadyInitialized=!1;else if(i instanceof SyntaxError)s.alreadyInitialized=!1,e.push("Existing config has invalid JSON");else throw i}let o=Cs.join(nm.homedir(),".prjct-cli");try{await Be.access(o,Be.constants.W_OK),s.globalPathWritable=!0}catch(i){if(R(i))try{await Be.mkdir(o,{recursive:!0}),s.globalPathWritable=!0,s.globalPathCreated=!0}catch{s.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}else s.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function lm(r){let e=[],t=[],s={},n=Cs.join(r.projectPath,".prjct/prjct.config.json");try{let a=await Be.readFile(n,"utf-8");s.hasConfig=!0,s.config=JSON.parse(a)}catch(a){if(R(a))return s.hasConfig=!1,e.push("Project not initialized"),t.push("Run /p:init first"),{verified:!1,actual:s,warnings:e,recommendations:t};if(a instanceof SyntaxError)return s.hasConfig=!1,e.push("Config file has invalid JSON"),t.push("Delete .prjct/ and run /p:init"),{verified:!1,actual:s,warnings:e,recommendations:t};throw a}let o=s.config?.projectId,i=Cs.join(nm.homedir(),".prjct-cli/projects",o||"");return await P(i)?s.globalStorageExists=!0:(s.globalStorageExists=!1,e.push("Global storage missing"),t.push("Run /p:init to recreate")),{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function um(r){let e=[],t=[],s={},n=["package.json","Cargo.toml","go.mod","requirements.txt","Gemfile","pom.xml"];s.detectedFiles=[];for(let i of n)await P(Cs.join(r.projectPath,i))&&s.detectedFiles.push(i);s.detectedFiles.length===0&&(e.push("No recognizable project files detected"),t.push("Analysis may be limited without package.json or similar"));let o=["src","lib","app","core","components"];s.detectedSrcDirs=[];for(let i of o)try{(await Be.stat(Cs.join(r.projectPath,i))).isDirectory()&&s.detectedSrcDirs.push(i)}catch(a){if(!R(a))throw a}return{verified:!0,actual:s,warnings:e,recommendations:t}}async function dm(r){let e=[],t=[],s={},n=r.paths.specs;if(await P(n)){s.specsExists=!0;let i=await Be.readdir(n);s.existingSpecs=i.filter(a=>a.endsWith(".md")),s.specCount=s.existingSpecs.length}else s.specsExists=!1,s.specCount=0;let o=r.params.feature||r.params.name||r.params.description;if(o&&s.existingSpecs){let i=o.toLowerCase().replace(/\s+/g,"-");s.existingSpecs.includes(`${i}.md`)&&(e.push(`Spec "${o}" already exists`),t.push("Use a different name or edit existing spec"))}return{verified:e.length===0,actual:s,warnings:e,recommendations:t}}async function mm(r,e,t){let s=pm[r];if(!s)return{verified:!0,actual:{},warnings:[],recommendations:[]};try{return await s(e,t)}catch(n){return{verified:!1,actual:{},warnings:[`Verification error: ${w(n)}`],recommendations:["Check file permissions and project configuration"]}}}async function Qk(r,e,t){let s=await mm(r,e,t);return{...e,groundTruth:{...s,verifiedAt:new Date().toISOString(),command:r}}}function Zk(r){return["done","ship","feature","spec","now","init","sync","analyze"].includes(r)}var pm,eS,Wo,gm=S(()=>{"use strict";W();He();K();ie();l(Ic,"escapeRegex");l(Yk,"formatWarnings");l(rm,"verifyDone");l(om,"verifyShip");l(im,"verifyFeature");l(am,"verifyNow");l(cm,"verifyInit");l(lm,"verifySync");l(um,"verifyAnalyze");l(dm,"verifySpec");pm={done:rm,ship:om,feature:im,now:am,init:cm,sync:lm,analyze:um,spec:dm};l(mm,"verify");l(Qk,"prepareCommand");l(Zk,"requiresVerification");eS={verify:mm,prepareCommand:Qk,requiresVerification:Zk,verifiers:pm,formatWarnings:Yk,formatDuration:ht,escapeRegex:Ic,verifyDone:rm,verifyShip:om,verifyFeature:im,verifyNow:am,verifyInit:cm,verifySync:lm,verifyAnalyze:um,verifySpec:dm},Wo=eS});function sS(r){return{contradiction:"Verify file/resource state before reporting. Use Read tool to check actual state.",state:"Check current task state from now.md before assuming completion.",invented:"Verify prerequisites exist (package.json, git remote) before claiming actions."}[r]||"Verify actual state before proceeding."}function nS(r){if(!r||typeof r!="string")return{detected:!1};for(let{pattern:e,type:t,description:s}of tS)if(e.test(r))return{detected:!0,type:t,pattern:e.source,description:s,message:`Potential hallucination detected: ${s}`,suggestion:sS(t)};return{detected:!1}}function rS(r,e){if(!r||!e)return!1;let t=l(s=>s.toLowerCase().replace(/[0-9]+/g,"N").replace(/['"`]/g,"").replace(/\s+/g," ").trim(),"normalize");return t(r)===t(e)}function oS(r){if(!r||r.length===0)return{type:"unknown",description:"No error information"};let e=r[r.length-1]?.message?.toLowerCase()||"";return e.includes("permission")||e.includes("access denied")?{type:"permission",description:"File or directory permission issue"}:e.includes("not found")||e.includes("no such file")?{type:"not_found",description:"File or resource not found"}:e.includes("syntax")||e.includes("parse")?{type:"syntax",description:"Syntax or parsing error"}:e.includes("timeout")||e.includes("timed out")?{type:"timeout",description:"Operation timed out"}:e.includes("network")||e.includes("connection")?{type:"network",description:"Network or connection issue"}:e.includes("config")||e.includes("configuration")?{type:"config",description:"Configuration issue"}:e.includes("validation")||e.includes("invalid")?{type:"validation",description:"Validation failed"}:{type:"unknown",description:"Unrecognized error pattern"}}function iS(r,e,t){let s={permission:`I've tried ${r} ${t} times but keep hitting permission issues.`,not_found:`After ${t} attempts, I still can't find the required file or resource.`,syntax:`I'm encountering repeated syntax errors with ${r}.`,timeout:`The operation keeps timing out after ${t} attempts.`,network:`Network issues are preventing ${r} from completing.`,validation:`Validation keeps failing for ${r}.`,config:`There seems to be a configuration issue affecting ${r}.`,unknown:`I've tried ${r} ${t} times without success.`};return s[e.type]||s.unknown}function aS(r){let e={permission:"Check file permissions. Try: chmod -R u+w ~/.prjct-cli/",not_found:"Verify the file path exists. Run /p:init if project not initialized.",syntax:"Check the file format. There may be invalid JSON or markdown.",timeout:"Check your network connection or try again in a moment.",network:"Verify internet connection and try again.",validation:"Review the input parameters and try with different values.",config:"Check .prjct/prjct.config.json for issues. Try /p:init to reinitialize.",unknown:"Can you check the issue manually and provide more context?"};return e[r.type]||e.unknown}var tS,$c,cS,Rn,fm=S(()=>{"use strict";tS=[{pattern:/file.*not found.*created/i,type:"contradiction",description:"Claims file created but also not found"},{pattern:/created.*but.*error/i,type:"contradiction",description:"Claims success but also error"},{pattern:/successfully.*failed/i,type:"contradiction",description:"Contradictory success/failure"},{pattern:/already.*completed.*completing/i,type:"state",description:"Completing already-completed task"},{pattern:/no task.*marking complete/i,type:"state",description:"Completing non-existent task"},{pattern:/no.*active.*done with/i,type:"state",description:"Finishing task that doesnt exist"},{pattern:/version.*updated.*no package/i,type:"invented",description:"Version update without package.json"},{pattern:/committed.*nothing to commit/i,type:"invented",description:"Commit without changes"},{pattern:/pushed.*no remote/i,type:"invented",description:"Push without remote"}];l(sS,"getHallucinationSuggestion");l(nS,"detectHallucination");l(rS,"isSimilarError");l(oS,"analyzeErrorPattern");l(iS,"generateEscalationMessage");l(aS,"generateSuggestion");$c=class{static{l(this,"LoopDetector")}_attempts;_errorPatterns;maxAttempts;sessionTimeout;constructor(){this._attempts=new Map,this._errorPatterns=new Map,this.maxAttempts=3,this.sessionTimeout=300*1e3}_getKey(e,t=""){return`${e}:${t}`.toLowerCase()}recordAttempt(e,t="",s={}){let n=this._getKey(e,t),o=Date.now(),i=this._attempts.get(n);return(!i||o-i.lastAttempt>this.sessionTimeout)&&(i={command:e,context:t,attempts:0,errors:[],firstAttempt:o,lastAttempt:o,success:!1}),i.attempts++,i.lastAttempt=o,i.success=s.success||!1,s.error&&i.errors.push({message:s.error,timestamp:o}),this._attempts.set(n,i),{attemptNumber:i.attempts,isLooping:this.isLooping(e,t),shouldEscalate:this.shouldEscalate(e,t)}}isLooping(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);if(!n)return!1;if(n.attempts>=2&&!n.success){let o=n.errors.slice(-3);if(o.length>=2){let i=o[0]?.message||"";return o.every(c=>rS(c.message,i))}}return!1}shouldEscalate(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);return n?n.attempts>=this.maxAttempts&&!n.success:!1}getEscalationInfo(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);if(!n)return null;let o=oS(n.errors);return{status:"BLOCKED",command:e,context:t,attempts:n.attempts,duration:n.lastAttempt-n.firstAttempt,errorPattern:o,message:iS(e,o,this.maxAttempts),suggestion:aS(o),lastError:n.errors[n.errors.length-1]?.message||null}}recordSuccess(e,t=""){let s=this._getKey(e,t),n=this._attempts.get(s);n&&(n.success=!0,n.attempts=0,n.errors=[],this._attempts.set(s,n))}clearTracking(e,t=""){let s=this._getKey(e,t);this._attempts.delete(s)}clearAll(){this._attempts.clear(),this._errorPatterns.clear()}getStats(){let e={activeTracking:this._attempts.size,commands:{}};for(let[t,s]of this._attempts)e.commands[t]={attempts:s.attempts,success:s.success,errorCount:s.errors.length};return e}detectHallucination(e){return nS(e)}analyzeOutput(e,t){let s=this.detectHallucination(t);return s.detected?(this.recordAttempt(e,"hallucination",{success:!1,error:`HALLUCINATION: ${s.description}`}),{...s,shouldBlock:!0,action:"VERIFY_STATE"}):{detected:!1,shouldBlock:!1}}},cS=new $c,Rn=cS});function Mc(r,e){let t=Ir(e),s=Fu[t.startDay],n=new Date(r);n.setHours(0,0,0,0);let i=(n.getDay()-s+7)%7;return n.setDate(n.getDate()-i),n}function lS(r,e){let t=Ir(e),s=new Date(r);return s.setDate(s.getDate()+t.sprintLengthDays-1),s.setHours(23,59,59,999),s}function uS(r,e,t){let s=Ir(t),n=Mc(r,t),o=Mc(e,t),i=n.getTime()-o.getTime(),a=Math.round(i/(1e3*60*60*24));return Math.floor(a/s.sprintLengthDays)+1}function Vo(r,e=bs){let t=Ir(e);if(r.length===0)return{sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:new Date().toISOString()};let s=dS(r,e),n=pS(s,t.accuracyTolerance),o=n.slice(-t.windowSize),i=fS(o),a=mS(o),c=gS(r,t.accuracyTolerance),{overEstimated:u,underEstimated:p}=hS(r);return{sprints:n,averageVelocity:i,velocityTrend:a,estimationAccuracy:c,overEstimated:u,underEstimated:p,lastUpdated:new Date().toISOString()}}function ym(r,e,t=bs){let s=Ir(t);if(e<=0)return{totalPoints:r,sprints:0,estimatedDate:""};let n=Math.ceil(r/e),o=n*s.sprintLengthDays,i=new Date;return i.setDate(i.getDate()+o),{totalPoints:r,sprints:n,estimatedDate:i.toISOString()}}function dS(r,e){let t=new Map,s=r.map(o=>new Date(o.completedAt)),n=new Date(Math.min(...s.map(o=>o.getTime())));for(let o of r){let i=new Date(o.completedAt),a=uS(i,n,e);if(!t.has(a)){let c=Mc(i,e),u=lS(c,e);t.set(a,{sprintNumber:a,startDate:c,endDate:u,outcomes:[]})}t.get(a).outcomes.push(o)}return t}function pS(r,e){let t=[];for(let[,s]of r){let n=s.outcomes.reduce((u,p)=>u+yS(p),0),o=s.outcomes.filter(u=>u.variance).map(u=>_c(u)),i=o.length>0?Math.round(o.reduce((u,p)=>u+p,0)/o.length):0,a=o.filter(u=>Math.abs(u)<=e).length,c=o.length>0?Math.round(a/o.length*100):0;t.push({sprintNumber:s.sprintNumber,startDate:s.startDate.toISOString(),endDate:s.endDate.toISOString(),pointsCompleted:n,tasksCompleted:s.outcomes.length,avgVariance:i,estimationAccuracy:c})}return t.sort((s,n)=>s.sprintNumber-n.sprintNumber)}function mS(r){if(r.length<3)return"stable";let e=r.map(p=>p.pointsCompleted),t=e.length,s=0,n=0,o=0,i=0;for(let p=0;p<t;p++)s+=p,n+=e[p],o+=p*e[p],i+=p*p;let a=(t*o-s*n)/(t*i-s*s),c=n/t;if(c===0)return"stable";let u=a/c;return u>.1?"improving":u<-.1?"declining":"stable"}function gS(r,e){let t=r.filter(n=>n.variance);if(t.length===0)return 0;let s=t.filter(n=>{let o=_c(n);return Math.abs(o)<=e});return Math.round(s.length/t.length*100)}function fS(r){if(r.length===0)return 0;let e=r.reduce((t,s)=>t+s.pointsCompleted,0);return Math.round(e/r.length*10)/10}function hS(r){let e=new Map;for(let n of r){if(!n.variance)continue;let o=_c(n),i=n.tags&&n.tags.length>0?n.tags:["uncategorized"];for(let a of i){e.has(a)||e.set(a,{variances:[],count:0});let c=e.get(a);c.variances.push(o),c.count++}}let t=[],s=[];for(let[n,o]of e){if(o.count<2)continue;let i=Math.round(o.variances.reduce((a,c)=>a+c,0)/o.variances.length);i>10?s.push({category:n,avgVariance:i,taskCount:o.count}):i<-10&&t.push({category:n,avgVariance:Math.abs(i),taskCount:o.count})}return t.sort((n,o)=>o.avgVariance-n.avgVariance),s.sort((n,o)=>o.avgVariance-n.avgVariance),{overEstimated:t,underEstimated:s}}function _c(r){if(!r.variance)return 0;let e=yt(r.estimatedDuration),t=yt(r.actualDuration);return e<=0?0:Math.round((t-e)/e*100)}function wm(r){if(r.sprints.length===0)return"No velocity data available yet.";let e=[];e.push(`Project velocity: ${r.averageVelocity} pts/sprint (trend: ${r.velocityTrend})`),e.push(`Estimation accuracy: ${r.estimationAccuracy}%`);for(let t of r.underEstimated)e.push(`\u26A0 "${t.category}" tasks historically take ${t.avgVariance}% longer than estimated`);for(let t of r.overEstimated)e.push(`"${t.category}" tasks typically finish ${t.avgVariance}% faster than estimated`);return e.join(`
688
+ `)}function yS(r){if(!r.estimatedDuration)return 0;let e=yt(r.estimatedDuration);if(e<=0)return 0;let t=hm[0],s=Number.POSITIVE_INFINITY;for(let n of hm){let o=Math.abs(n.typical-e);o<s&&(s=o,t=n)}return t.points}function Ir(r){return{sprintLengthDays:r.sprintLengthDays??7,startDay:r.startDay??"monday",windowSize:r.windowSize??6,accuracyTolerance:r.accuracyTolerance??20}}var hm,Oc=S(()=>{"use strict";yr();vr();ie();l(Mc,"getSprintStart");l(lS,"getSprintEnd");l(uS,"getSprintNumber");l(Vo,"calculateVelocity");l(ym,"projectCompletion");l(dS,"bucketBySprint");l(pS,"buildSprintVelocities");l(mS,"detectTrend");l(gS,"calculateOverallAccuracy");l(fS,"calculateAverageVelocity");l(hS,"detectEstimationPatterns");l(_c,"parseVariancePercent");l(wm,"formatVelocityContext");hm=[{points:1,typical:10},{points:2,typical:20},{points:3,typical:45},{points:5,typical:90},{points:8,typical:180},{points:13,typical:360},{points:21,typical:720}];l(yS,"derivePoints");l(Ir,"resolveConfig")});import wS from"node:fs/promises";import Bo from"node:path";async function An(r,e,t={}){let s=Date.now(),n=t.maxFiles??30,o=t.minScore??.1,i=t.includeTests??!1,a=Nc(r),c=await TS(e),u=await vS(e),p=[];for(let d of c){if(!i&&PS(d))continue;let g=CS(d,a,u,t.historicalBoosts);g.score>=o&&p.push(g)}p.sort((d,g)=>g.score-d.score);let m=p.slice(0,n);return{files:m,metrics:{filesScanned:c.length,filesReturned:m.length,scanDuration:Date.now()-s}}}function Nc(r){let e=r.toLowerCase().split(/[^a-z0-9]+/).filter(Boolean),t=new Set(["a","an","the","and","or","but","is","are","was","were","be","been","being","have","has","had","do","does","did","will","would","could","should","may","might","must","shall","can","need","to","of","in","for","on","with","at","by","from","as","into","through","during","before","after","above","below","between","under","again","further","then","once","here","there","when","where","why","how","all","each","few","more","most","other","some","such","no","nor","not","only","own","same","so","than","too","very","just","add","create","make","implement","fix","update","change","modify","remove","delete","new"]);return e.filter(s=>!t.has(s)&&s.length>2)}async function TS(r){let e=[];async function t(s,n=""){try{let o=await wS.readdir(s,{withFileTypes:!0});for(let i of o){let a=Bo.join(s,i.name),c=Bo.join(n,i.name);if(i.isDirectory()){if(bS.has(i.name)||i.name.startsWith("."))continue;await t(a,c)}else if(i.isFile()){let u=Bo.extname(i.name).toLowerCase();SS.has(u)&&e.push(c)}}}catch(o){R(o)}}return l(t,"walk"),await t(r),e}async function vS(r){let e=new Map;try{let{stdout:t}=await O(`git log -30 --pretty=format:"%H %ct" --name-only | awk '
660
689
  /^[a-f0-9]{40}/ { commit=$1; timestamp=$2; next }
661
690
  NF { files[$0]++; if (!lastmod[$0]) lastmod[$0]=timestamp }
662
691
  END { for (f in files) print files[f], lastmod[f], f }
663
692
  '`,{cwd:r,maxBuffer:10485760}),s=Math.floor(Date.now()/1e3),n=t.trim().split(`
664
- `).filter(Boolean);for(let o of n){let i=o.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(i){let a=parseInt(i[1],10),c=parseInt(i[2],10),u=i[3],p=Math.floor((s-c)/86400);e.set(u,{commits:a,daysAgo:p})}}}catch{}return e}function bS(r,e,t,s){let n=[],o=0,i=0,a=0,c=0,u=0,p=r.toLowerCase(),m=p.split("/").join(" ").split(/[^a-z0-9]+/);for(let w of e){p.includes(w)&&(o+=.3,n.push(`keyword:${w}`));for(let T of m)if(T.includes(w)||w.includes(T)){o+=.15;break}}o=Math.min(1,o);for(let[w,T]of Object.entries(hS))for(let E of T)if(p.includes(E)&&e.some(L=>T.includes(L)||L.includes(w)||w.includes(L))){i+=.4,n.push(`domain:${w}`);break}i=Math.min(1,i);let d=t.get(r);d&&(d.daysAgo<=1?(a=1,n.push("recent:1d")):d.daysAgo<=3?(a=.8,n.push("recent:3d")):d.daysAgo<=7?(a=.6,n.push("recent:1w")):d.daysAgo<=30&&(a=.3,n.push("recent:1m")),d.commits>=5&&(a=Math.min(1,a+.2)));let g=Ho.basename(r).toLowerCase();if((g.includes("index")||g.includes("main")||g.includes("app")||g.includes("entry"))&&(c=.5,n.push("import:0")),(p.includes("/core/")||p.includes("/shared/")||p.includes("/lib/"))&&(c=Math.max(c,.3),n.some(w=>w.startsWith("import:"))||n.push("import:1")),s){let w=s.get(r);w!==void 0&&(u=(w+1)/2,w>0?n.push("history:boosted"):w<0&&n.push("history:penalized"))}let k=s&&s.size>0?o*.54+i*.18+a*.13+c*.05+u*.1:o*.6+i*.2+a*.15+c*.05;return{path:r,score:Math.min(1,k),reasons:[...new Set(n)]}}function vS(r){let e=r.toLowerCase();return e.includes(".test.")||e.includes(".spec.")||e.includes("__tests__")||e.includes("__mocks__")||e.includes("/tests/")||e.includes("/test/")||e.endsWith("_test.go")||e.endsWith("_test.py")}var hS,yS,wS,Go=S(()=>{"use strict";V();Ue();hS={frontend:["component","page","view","ui","layout","style","css","scss","sass","hook","context","store","redux","zustand","react","vue","svelte","angular","next","nuxt","app","client"],backend:["api","route","controller","service","middleware","handler","resolver","schema","model","entity","repository","server","socket","graphql","rest","trpc"],database:["migration","seed","schema","model","entity","repository","prisma","drizzle","sequelize","typeorm","mongoose","knex","sql","db"],auth:["auth","login","logout","session","token","jwt","oauth","passport","credential","permission","role","user","account"],testing:["test","spec","e2e","integration","unit","mock","fixture","stub","jest","vitest","cypress","playwright"],config:["config","env","setting","constant","option","tsconfig","eslint","prettier","vite","webpack","rollup"],infra:["docker","compose","kubernetes","k8s","ci","cd","github","gitlab","jenkins","terraform","ansible","deploy"],util:["util","helper","lib","common","shared","core","base","abstract"]},yS=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".go",".rs",".java",".kt",".swift",".rb",".php",".c",".cpp",".h",".hpp",".cs",".vue",".svelte"]),wS=new Set(["node_modules",".git","dist","build",".next",".nuxt",".output","coverage",".cache","__pycache__",".pytest_cache","vendor","target",".turbo",".vercel"]);l(An,"findRelevantFiles");l(Oc,"extractKeywords");l(kS,"getAllCodeFiles");l(SS,"getGitRecency");l(bS,"scoreFile");l(vS,"isTestFile")});async function hm(r=process.cwd(),e={}){let t=e.commits??30,s=e.maxFiles??50,n=e.branch??!1;try{let o=[],i=[],a=`${t} commits`;if(n){let c=await PS(r);o=c.hotFiles,i=c.branchOnlyFiles,a=c.analysisWindow}else o=await CS(r,t);return o=o.filter(c=>!ES(c.path)).slice(0,s),{hotFiles:o,branchOnlyFiles:i,metrics:{commitsAnalyzed:t,totalFilesChanged:o.length,filesReturned:Math.min(o.length,s),analysisWindow:a}}}catch{return{hotFiles:[],branchOnlyFiles:[],metrics:{commitsAnalyzed:0,totalFilesChanged:0,filesReturned:0,analysisWindow:"N/A (git error)"}}}}async function CS(r,e){let{stdout:t}=await N(`git log -${e} --pretty=format:"%ct" --name-only | awk '
693
+ `).filter(Boolean);for(let o of n){let i=o.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(i){let a=parseInt(i[1],10),c=parseInt(i[2],10),u=i[3],p=Math.floor((s-c)/86400);e.set(u,{commits:a,daysAgo:p})}}}catch{}return e}function CS(r,e,t,s){let n=[],o=0,i=0,a=0,c=0,u=0,p=r.toLowerCase(),m=p.split("/").join(" ").split(/[^a-z0-9]+/);for(let y of e){p.includes(y)&&(o+=.3,n.push(`keyword:${y}`));for(let v of m)if(v.includes(y)||y.includes(v)){o+=.15;break}}o=Math.min(1,o);for(let[y,v]of Object.entries(kS))for(let D of v)if(p.includes(D)&&e.some(F=>v.includes(F)||F.includes(y)||y.includes(F))){i+=.4,n.push(`domain:${y}`);break}i=Math.min(1,i);let d=t.get(r);d&&(d.daysAgo<=1?(a=1,n.push("recent:1d")):d.daysAgo<=3?(a=.8,n.push("recent:3d")):d.daysAgo<=7?(a=.6,n.push("recent:1w")):d.daysAgo<=30&&(a=.3,n.push("recent:1m")),d.commits>=5&&(a=Math.min(1,a+.2)));let g=Bo.basename(r).toLowerCase();if((g.includes("index")||g.includes("main")||g.includes("app")||g.includes("entry"))&&(c=.5,n.push("import:0")),(p.includes("/core/")||p.includes("/shared/")||p.includes("/lib/"))&&(c=Math.max(c,.3),n.some(y=>y.startsWith("import:"))||n.push("import:1")),s){let y=s.get(r);y!==void 0&&(u=(y+1)/2,y>0?n.push("history:boosted"):y<0&&n.push("history:penalized"))}let k=s&&s.size>0?o*.54+i*.18+a*.13+c*.05+u*.1:o*.6+i*.2+a*.15+c*.05;return{path:r,score:Math.min(1,k),reasons:[...new Set(n)]}}function PS(r){let e=r.toLowerCase();return e.includes(".test.")||e.includes(".spec.")||e.includes("__tests__")||e.includes("__mocks__")||e.includes("/tests/")||e.includes("/test/")||e.endsWith("_test.go")||e.endsWith("_test.py")}var kS,SS,bS,zo=S(()=>{"use strict";W();He();kS={frontend:["component","page","view","ui","layout","style","css","scss","sass","hook","context","store","redux","zustand","react","vue","svelte","angular","next","nuxt","app","client"],backend:["api","route","controller","service","middleware","handler","resolver","schema","model","entity","repository","server","socket","graphql","rest","trpc"],database:["migration","seed","schema","model","entity","repository","prisma","drizzle","sequelize","typeorm","mongoose","knex","sql","db"],auth:["auth","login","logout","session","token","jwt","oauth","passport","credential","permission","role","user","account"],testing:["test","spec","e2e","integration","unit","mock","fixture","stub","jest","vitest","cypress","playwright"],config:["config","env","setting","constant","option","tsconfig","eslint","prettier","vite","webpack","rollup"],infra:["docker","compose","kubernetes","k8s","ci","cd","github","gitlab","jenkins","terraform","ansible","deploy"],util:["util","helper","lib","common","shared","core","base","abstract"]},SS=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".go",".rs",".java",".kt",".swift",".rb",".php",".c",".cpp",".h",".hpp",".cs",".vue",".svelte"]),bS=new Set(["node_modules",".git","dist","build",".next",".nuxt",".output","coverage",".cache","__pycache__",".pytest_cache","vendor","target",".turbo",".vercel"]);l(An,"findRelevantFiles");l(Nc,"extractKeywords");l(TS,"getAllCodeFiles");l(vS,"getGitRecency");l(CS,"scoreFile");l(PS,"isTestFile")});async function km(r=process.cwd(),e={}){let t=e.commits??30,s=e.maxFiles??50,n=e.branch??!1;try{let o=[],i=[],a=`${t} commits`;if(n){let c=await RS(r);o=c.hotFiles,i=c.branchOnlyFiles,a=c.analysisWindow}else o=await xS(r,t);return o=o.filter(c=>!AS(c.path)).slice(0,s),{hotFiles:o,branchOnlyFiles:i,metrics:{commitsAnalyzed:t,totalFilesChanged:o.length,filesReturned:Math.min(o.length,s),analysisWindow:a}}}catch{return{hotFiles:[],branchOnlyFiles:[],metrics:{commitsAnalyzed:0,totalFilesChanged:0,filesReturned:0,analysisWindow:"N/A (git error)"}}}}async function xS(r,e){let{stdout:t}=await O(`git log -${e} --pretty=format:"%ct" --name-only | awk '
665
694
  /^[0-9]+$/ { timestamp=$1; next }
666
695
  NF {
667
696
  count[$0]++
@@ -671,8 +700,8 @@ Recommendations:
671
700
  for (f in count) print count[f], lastmod[f], f
672
701
  }
673
702
  ' | sort -rn`,{cwd:r,maxBuffer:10485760}),s=[],n=t.trim().split(`
674
- `).filter(Boolean),o=Math.floor(Date.now()/1e3),i=1;for(let a of n){let c=a.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(c){let u=parseInt(c[1],10);u>i&&(i=u)}}for(let a of n){let c=a.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!c)continue;let u=parseInt(c[1],10),p=parseInt(c[2],10),m=c[3],d=o-p,g=Math.floor(d/86400),h=Math.floor(d/3600),k=Math.max(0,1-g/30),w=u/i,T=k*.6+w*.4,E;h<1?E="just now":h<24?E=`${h}h ago`:g<7?E=`${g}d ago`:g<30?E=`${Math.floor(g/7)}w ago`:E=`${Math.floor(g/30)}mo ago`,s.push({path:m,changes:u,heatScore:Math.round(T*100)/100,lastChanged:E,lastChangedAt:new Date(p*1e3).toISOString()})}return s.sort((a,c)=>c.heatScore-a.heatScore)}async function PS(r){let e="main";try{await N("git rev-parse --verify main",{cwd:r})}catch{e="master"}let{stdout:t}=await N(`git diff --name-only ${e}...HEAD`,{cwd:r}),s=t.trim().split(`
675
- `).filter(Boolean),{stdout:n}=await N(`git log ${e}..HEAD --pretty=format:"%ct" --name-only | awk '
703
+ `).filter(Boolean),o=Math.floor(Date.now()/1e3),i=1;for(let a of n){let c=a.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(c){let u=parseInt(c[1],10);u>i&&(i=u)}}for(let a of n){let c=a.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!c)continue;let u=parseInt(c[1],10),p=parseInt(c[2],10),m=c[3],d=o-p,g=Math.floor(d/86400),h=Math.floor(d/3600),k=Math.max(0,1-g/30),y=u/i,v=k*.6+y*.4,D;h<1?D="just now":h<24?D=`${h}h ago`:g<7?D=`${g}d ago`:g<30?D=`${Math.floor(g/7)}w ago`:D=`${Math.floor(g/30)}mo ago`,s.push({path:m,changes:u,heatScore:Math.round(v*100)/100,lastChanged:D,lastChangedAt:new Date(p*1e3).toISOString()})}return s.sort((a,c)=>c.heatScore-a.heatScore)}async function RS(r){let e="main";try{await O("git rev-parse --verify main",{cwd:r})}catch{e="master"}let{stdout:t}=await O(`git diff --name-only ${e}...HEAD`,{cwd:r}),s=t.trim().split(`
704
+ `).filter(Boolean),{stdout:n}=await O(`git log ${e}..HEAD --pretty=format:"%ct" --name-only | awk '
676
705
  /^[0-9]+$/ { timestamp=$1; next }
677
706
  NF {
678
707
  count[$0]++
@@ -682,22 +711,22 @@ Recommendations:
682
711
  for (f in count) print count[f], lastmod[f], f
683
712
  }
684
713
  '`,{cwd:r,maxBuffer:10*1024*1024}),o=[],i=n.trim().split(`
685
- `).filter(Boolean),a=Math.floor(Date.now()/1e3),c=1;for(let u of i){let p=u.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(p){let m=parseInt(p[1],10);m>c&&(c=m)}}for(let u of i){let p=u.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!p)continue;let m=parseInt(p[1],10),d=parseInt(p[2],10),g=p[3],h=a-d,k=Math.floor(h/86400),w=Math.floor(h/3600),T=Math.max(0,1-k/14),E=m/c,M=T*.5+E*.5,L;w<1?L="just now":w<24?L=`${w}h ago`:L=`${k}d ago`,o.push({path:g,changes:m,heatScore:Math.round(M*100)/100,lastChanged:L,lastChangedAt:new Date(d*1e3).toISOString()})}return{hotFiles:o.sort((u,p)=>p.heatScore-u.heatScore),branchOnlyFiles:s,analysisWindow:`${e}..HEAD`}}function ES(r){let e=r.split("/").pop()||"";for(let t of TS)if(t.startsWith("*.")){if(e.endsWith(t.slice(1)))return!0}else if(e===t)return!0;return!1}var TS,ym=S(()=>{"use strict";Ue();TS=["package-lock.json","yarn.lock","pnpm-lock.yaml","bun.lockb",".gitignore",".env",".env.local","*.md","CHANGELOG.md","LICENSE"];l(hm,"getRecentFiles");l(CS,"getHotFilesFromCommits");l(PS,"getBranchOnlyFiles");l(ES,"shouldIgnore")});function _c(r){return!r||r.length===0?0:Math.ceil(r.length/4)}function wm(r,e){let t=xS[e],s=r/1e3*t.input,n=r/1e3*t.output*.3;return{inputSaved:s,outputPotential:n,total:s+n}}function AS(r){return r<.001?"<$0.01":r<.01?`$${r.toFixed(3)}`:`$${r.toFixed(2)}`}function Sm(r,e){let t=_c(r),s=_c(e),n=Math.max(0,t-s),o=t>0?(t-s)/t:0,i=wm(n,RS),a=km.map(c=>({model:c,...wm(n,c)}));return{tokens:{original:t,filtered:s,saved:n},compression:Math.max(0,Math.min(1,o)),cost:{saved:i.total,formatted:AS(i.total),byModel:a}}}function Nc(r){let e=_c(r);return{tokens:{original:e,filtered:e,saved:0},compression:0,cost:{saved:0,formatted:"$0.00",byModel:km.map(t=>({model:t,inputSaved:0,outputPotential:0,total:0}))}}}var xS,RS,km,bm=S(()=>{"use strict";po();xS={"claude-opus-4.5":{input:.005,output:.025},"claude-sonnet-4.5":{input:.003,output:.015},"claude-haiku-4.5":{input:.001,output:.005},"claude-opus-4":{input:.015,output:.075},"claude-opus-4-6":{input:.015,output:.075},"gpt-4o":{input:.0025,output:.01},"gpt-4-turbo":{input:.01,output:.03},"gpt-4o-mini":{input:15e-5,output:6e-4},"gemini-1.5-pro":{input:.00125,output:.005},"gemini-1.5-flash":{input:75e-6,output:3e-4}},RS="claude-sonnet-4.5";l(_c,"countTokens");km=["claude-sonnet-4.5","claude-opus-4.5","claude-opus-4-6","gpt-4o","gemini-1.5-pro"];l(wm,"calculateModelCost");l(AS,"formatCostSaved");l(Sm,"measureCompression");l(Nc,"noCompression")});import DS from"node:fs/promises";import Lc from"node:path";async function Cm(r,e=process.cwd()){let t=Lc.isAbsolute(r)?r:Lc.join(e,r),s;try{s=await DS.readFile(t,"utf-8")}catch(u){if(R(u))return{file:r,language:"unknown",signatures:[],fallback:!0,fallbackReason:"File not found",metrics:Nc("")};throw u}let n=Lc.extname(r).toLowerCase(),o=jS[n]||"unknown",i=OS[o];if(!i||i.length===0)return{file:r,language:o,signatures:[],fallback:!0,fallbackReason:`No extraction patterns for ${o}`,metrics:Nc(s)};let a=_S(s,i),c=a.map(u=>`${u.exported?"export ":""}${u.type} ${u.name}: ${u.signature}`).join(`
686
- `);return{file:r,language:o,signatures:a,fallback:!1,metrics:Sm(s,c)}}function _S(r,e){let t=[],s=r.split(`
714
+ `).filter(Boolean),a=Math.floor(Date.now()/1e3),c=1;for(let u of i){let p=u.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(p){let m=parseInt(p[1],10);m>c&&(c=m)}}for(let u of i){let p=u.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!p)continue;let m=parseInt(p[1],10),d=parseInt(p[2],10),g=p[3],h=a-d,k=Math.floor(h/86400),y=Math.floor(h/3600),v=Math.max(0,1-k/14),D=m/c,U=v*.5+D*.5,F;y<1?F="just now":y<24?F=`${y}h ago`:F=`${k}d ago`,o.push({path:g,changes:m,heatScore:Math.round(U*100)/100,lastChanged:F,lastChangedAt:new Date(d*1e3).toISOString()})}return{hotFiles:o.sort((u,p)=>p.heatScore-u.heatScore),branchOnlyFiles:s,analysisWindow:`${e}..HEAD`}}function AS(r){let e=r.split("/").pop()||"";for(let t of ES)if(t.startsWith("*.")){if(e.endsWith(t.slice(1)))return!0}else if(e===t)return!0;return!1}var ES,Sm=S(()=>{"use strict";He();ES=["package-lock.json","yarn.lock","pnpm-lock.yaml","bun.lockb",".gitignore",".env",".env.local","*.md","CHANGELOG.md","LICENSE"];l(km,"getRecentFiles");l(xS,"getHotFilesFromCommits");l(RS,"getBranchOnlyFiles");l(AS,"shouldIgnore")});function Lc(r){return!r||r.length===0?0:Math.ceil(r.length/4)}function bm(r,e){let t=DS[e],s=r/1e3*t.input,n=r/1e3*t.output*.3;return{inputSaved:s,outputPotential:n,total:s+n}}function IS(r){return r<.001?"<$0.01":r<.01?`$${r.toFixed(3)}`:`$${r.toFixed(2)}`}function vm(r,e){let t=Lc(r),s=Lc(e),n=Math.max(0,t-s),o=t>0?(t-s)/t:0,i=bm(n,jS),a=Tm.map(c=>({model:c,...bm(n,c)}));return{tokens:{original:t,filtered:s,saved:n},compression:Math.max(0,Math.min(1,o)),cost:{saved:i.total,formatted:IS(i.total),byModel:a}}}function Fc(r){let e=Lc(r);return{tokens:{original:e,filtered:e,saved:0},compression:0,cost:{saved:0,formatted:"$0.00",byModel:Tm.map(t=>({model:t,inputSaved:0,outputPotential:0,total:0}))}}}var DS,jS,Tm,Cm=S(()=>{"use strict";ho();DS={"claude-opus-4.5":{input:.005,output:.025},"claude-sonnet-4.5":{input:.003,output:.015},"claude-haiku-4.5":{input:.001,output:.005},"claude-opus-4":{input:.015,output:.075},"claude-opus-4-6":{input:.015,output:.075},"gpt-4o":{input:.0025,output:.01},"gpt-4-turbo":{input:.01,output:.03},"gpt-4o-mini":{input:15e-5,output:6e-4},"gemini-1.5-pro":{input:.00125,output:.005},"gemini-1.5-flash":{input:75e-6,output:3e-4}},jS="claude-sonnet-4.5";l(Lc,"countTokens");Tm=["claude-sonnet-4.5","claude-opus-4.5","claude-opus-4-6","gpt-4o","gemini-1.5-pro"];l(bm,"calculateModelCost");l(IS,"formatCostSaved");l(vm,"measureCompression");l(Fc,"noCompression")});import $S from"node:fs/promises";import Uc from"node:path";async function xm(r,e=process.cwd()){let t=Uc.isAbsolute(r)?r:Uc.join(e,r),s;try{s=await $S.readFile(t,"utf-8")}catch(u){if(R(u))return{file:r,language:"unknown",signatures:[],fallback:!0,fallbackReason:"File not found",metrics:Fc("")};throw u}let n=Uc.extname(r).toLowerCase(),o=MS[n]||"unknown",i=LS[o];if(!i||i.length===0)return{file:r,language:o,signatures:[],fallback:!0,fallbackReason:`No extraction patterns for ${o}`,metrics:Fc(s)};let a=FS(s,i),c=a.map(u=>`${u.exported?"export ":""}${u.type} ${u.name}: ${u.signature}`).join(`
715
+ `);return{file:r,language:o,signatures:a,fallback:!1,metrics:vm(s,c)}}function FS(r,e){let t=[],s=r.split(`
687
716
  `),n=new Set;for(let o of e){o.pattern.lastIndex=0;let i;for(;(i=o.pattern.exec(r))!==null;){let a=i[o.nameIndex];if(!a)continue;let c=`${o.type}:${a}`;if(n.has(c))continue;n.add(c);let u=i.index,p=r.substring(0,u).split(`
688
- `).length,m=i[0].trim(),d;if(p>1){let g=s[p-2]?.trim();(g?.startsWith("/**")||g?.startsWith("///")||g?.startsWith("#"))&&(d=g)}t.push({type:o.type,name:a,signature:NS(m),exported:o.exported||!1,line:p,docstring:d})}}return t.sort((o,i)=>o.line-i.line)}function NS(r){return r.replace(/\{$/,"").replace(/\s+/g," ").trim()}var jS,vm,IS,$S,MS,Tm,OS,Pm=S(()=>{"use strict";V();bm();jS={".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".mjs":"javascript",".cjs":"javascript",".py":"python",".go":"go",".rs":"rust",".java":"java",".cs":"csharp",".php":"php",".rb":"ruby"},vm=[{type:"function",pattern:/^export\s+(?:async\s+)?function\s+(\w+)\s*(<[^>]*>)?\s*\(([^)]*)\)\s*(?::\s*([^{;]+))?/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^export\s+const\s+(\w+)\s*(?::\s*[^=]+)?\s*=\s*(?:async\s+)?\([^)]*\)\s*(?::\s*[^=]+)?\s*=>/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^(?:async\s+)?function\s+(\w+)\s*(<[^>]*>)?\s*\(([^)]*)\)\s*(?::\s*([^{;]+))?/gm,nameIndex:1},{type:"function",pattern:/^const\s+(\w+)\s*(?::\s*[^=]+)?\s*=\s*(?:async\s+)?\([^)]*\)\s*(?::\s*[^=]+)?\s*=>/gm,nameIndex:1},{type:"interface",pattern:/^export\s+interface\s+(\w+)(?:<[^>]+>)?\s*(?:extends\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^interface\s+(\w+)(?:<[^>]+>)?\s*(?:extends\s+[^{]+)?\s*\{/gm,nameIndex:1},{type:"type",pattern:/^export\s+type\s+(\w+)(?:<[^>]+>)?\s*=/gm,nameIndex:1,exported:!0},{type:"type",pattern:/^type\s+(\w+)(?:<[^>]+>)?\s*=/gm,nameIndex:1},{type:"class",pattern:/^export\s+(?:abstract\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"class",pattern:/^(?:abstract\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1},{type:"enum",pattern:/^export\s+enum\s+(\w+)\s*\{/gm,nameIndex:1,exported:!0},{type:"enum",pattern:/^enum\s+(\w+)\s*\{/gm,nameIndex:1},{type:"const",pattern:/^export\s+const\s+(\w+)\s*(?::\s*([^=]+))?\s*=/gm,nameIndex:1,exported:!0}],IS=[{type:"function",pattern:/^def\s+(\w+)\s*\(([^)]*)\)\s*(?:->\s*([^:]+))?\s*:/gm,nameIndex:1},{type:"function",pattern:/^async\s+def\s+(\w+)\s*\(([^)]*)\)\s*(?:->\s*([^:]+))?\s*:/gm,nameIndex:1},{type:"class",pattern:/^class\s+(\w+)(?:\(([^)]*)\))?\s*:/gm,nameIndex:1}],$S=[{type:"function",pattern:/^func\s+(\w+)\s*\(([^)]*)\)\s*(?:\(([^)]*)\)|([^\s{]+))?\s*\{/gm,nameIndex:1},{type:"method",pattern:/^func\s+\([^)]+\)\s+(\w+)\s*\(([^)]*)\)\s*(?:\(([^)]*)\)|([^\s{]+))?\s*\{/gm,nameIndex:1},{type:"type",pattern:/^type\s+(\w+)\s+(?:struct|interface)\s*\{/gm,nameIndex:1}],MS=[{type:"function",pattern:/^pub\s+(?:async\s+)?fn\s+(\w+)(?:<[^>]+>)?\s*\(([^)]*)\)\s*(?:->\s*([^{]+))?\s*\{/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^(?:async\s+)?fn\s+(\w+)(?:<[^>]+>)?\s*\(([^)]*)\)\s*(?:->\s*([^{]+))?\s*\{/gm,nameIndex:1},{type:"class",pattern:/^pub\s+struct\s+(\w+)(?:<[^>]+>)?\s*(?:\{|;)/gm,nameIndex:1,exported:!0},{type:"class",pattern:/^struct\s+(\w+)(?:<[^>]+>)?\s*(?:\{|;)/gm,nameIndex:1},{type:"interface",pattern:/^pub\s+trait\s+(\w+)(?:<[^>]+>)?\s*(?:\{|:)/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^trait\s+(\w+)(?:<[^>]+>)?\s*(?:\{|:)/gm,nameIndex:1},{type:"enum",pattern:/^pub\s+enum\s+(\w+)(?:<[^>]+>)?\s*\{/gm,nameIndex:1,exported:!0},{type:"enum",pattern:/^enum\s+(\w+)(?:<[^>]+>)?\s*\{/gm,nameIndex:1}],Tm=[{type:"class",pattern:/^(?:public\s+)?(?:abstract\s+)?(?:final\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+\w+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^(?:public\s+)?interface\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"method",pattern:/^\s+(?:public|private|protected)?\s*(?:static\s+)?(?:final\s+)?(?:synchronized\s+)?(?:<[^>]+>\s+)?(\w+(?:<[^>]+>)?)\s+(\w+)\s*\([^)]*\)\s*(?:throws\s+[^{]+)?\s*\{/gm,nameIndex:2}],OS={typescript:vm,javascript:vm,python:IS,go:$S,rust:MS,java:Tm,csharp:Tm,php:[],ruby:[],unknown:[]};l(Cm,"extractSignatures");l(_S,"extractFromContent");l(NS,"cleanSignature")});import Fc from"node:path";var LS,FS,Uc,US,wt,Dn=S(()=>{"use strict";ve();It();oe();q();LS="outcomes",FS="outcomes.jsonl",Uc=class{static{l(this,"OutcomeRecorder")}getOutcomesDir(e){let t=A.getGlobalProjectPath(e);return Fc.join(t,LS)}getOutcomesPath(e){return Fc.join(this.getOutcomesDir(e),FS)}async record(e,t){let s={...t,id:ye()},n=this.getOutcomesPath(e);return await vt(Fc.dirname(n)),await Oi(n,JSON.stringify(s)),s}async getAll(e){let t=this.getOutcomesPath(e);if(!await C(t))return[];let s=await ot(t);return s.trim()?s.trim().split(`
689
- `).filter(n=>n.trim()).map(n=>JSON.parse(n)):[]}async filter(e,t){return(await this.getAll(e)).filter(n=>{if(t.sessionId&&n.sessionId!==t.sessionId||t.command&&n.command!==t.command||t.agent&&n.agentUsed!==t.agent||t.fromDate&&n.startedAt<t.fromDate||t.toDate&&n.completedAt>t.toDate||t.minQuality&&n.qualityScore<t.minQuality)return!1;if(t.tags&&t.tags.length>0){let o=n.tags||[];if(!t.tags.some(i=>o.includes(i)))return!1}return!0})}async getRecent(e,t=10){return(await this.getAll(e)).slice(-t)}async getByCommand(e,t){return this.filter(e,{command:t})}async getByAgent(e,t){return this.filter(e,{agent:t})}async getEstimateAccuracy(e){let t=await this.getAll(e);if(t.length===0)return 0;let s=t.filter(n=>{if(!n.variance)return!1;let o=js(n.variance),i=ht(n.estimatedDuration);return i===0?!1:Math.abs(o)/i<=.2});return Math.round(s.length/t.length*100)}},US=new Uc,wt=US});import{z as _e}from"zod";var Vo,jn,HS,bI,Hc,Em,Wo=S(()=>{"use strict";Vo=_e.enum(["frontend","backend","database","devops","testing","docs","uxui","general"]),jn=_e.object({primaryDomain:Vo,secondaryDomains:_e.array(Vo),confidence:_e.number().min(0).max(1),filePatterns:_e.array(_e.string()),relevantAgents:_e.array(_e.string())}),HS=_e.object({classification:jn,classifiedAt:_e.string(),source:_e.enum(["cache","history","llm","heuristic"]),descriptionHash:_e.string(),projectId:_e.string()}),bI=_e.object({entries:_e.record(_e.string(),HS),confirmedPatterns:_e.array(_e.object({descriptionHash:_e.string(),classification:jn,confirmedAt:_e.string(),taskDescription:_e.string()}))}),Hc={entries:{},confirmedPatterns:[]},Em={primaryDomain:"general",secondaryDomains:[],confidence:.3,filePatterns:["**/*.ts","**/*.js"],relevantAgents:[]}});import VS from"node:fs/promises";import Am from"node:path";function xm(r){return co(r.toLowerCase().trim())}async function Rm(r){try{let e=Am.join(r,"storage","classification-cache.json"),t=await VS.readFile(e,"utf-8");return JSON.parse(t)}catch(e){return R(e)?Hc:(console.warn("[classifier] Failed to load cache:",y(e)),Hc)}}async function WS(r,e){try{let t=Am.join(r,"storage","classification-cache.json");await le(t,e)}catch(t){console.warn("[classifier] Failed to save cache:",y(t))}}function BS(r,e,t){let s=r.entries[e];return!s||s.projectId!==t||fs(s.classifiedAt,36e5)?null:s.classification}function JS(r,e){return r.confirmedPatterns.find(s=>s.descriptionHash===e)?.classification??null}var Gc,zS,Dm,jm=S(()=>{"use strict";or();Wo();V();Ms();q();yn();l(xm,"hashDescription");l(Rm,"loadCache");l(WS,"saveCache");l(BS,"lookupCache");l(JS,"lookupPatterns");Gc=class{static{l(this,"DomainClassifier")}async classify(e,t,s,n){let o=xm(e),i=await Rm(s),a=BS(i,o,t);if(a)return{classification:a,source:"cache"};let c=JS(i,o);return c?{classification:c,source:"history"}:{classification:Em,source:"heuristic"}}async confirmClassification(e,t,s){let n=xm(e),o=await Rm(s);o.confirmedPatterns.some(i=>i.descriptionHash===n)||(o.confirmedPatterns.push({descriptionHash:n,classification:t,confirmedAt:new Date().toISOString(),taskDescription:e}),await WS(s,o))}},zS=new Gc,Dm=zS});import qS from"node:fs/promises";import KS from"node:path";var Im,Vc,XS,Bo,Wc=S(()=>{"use strict";Mc();Et();ve();Tr();wn();kr();Pt();Go();ym();Pm();V();Ue();Dn();jm();Im=["database","backend","frontend","testing","devops"],Vc=class{static{l(this,"OrchestratorExecutor")}async execute(e,t,s){let n=await I.getProjectId(s),o=A.getGlobalProjectPath(n),i=await this.loadRepoAnalysis(o),{domains:a,primary:c}=await this.detectDomains(t,n,i),u=await Promise.allSettled([this.gatherRealContext(t,s),this.loadSealedAnalysis(n),this.loadVelocityContext(n)]),p=["realContext","sealedAnalysis","velocity"],m=[],d=u.map((M,L)=>{if(M.status==="fulfilled")return M.value;m.push(p[L]),console.warn(`Context tool "${p[L]}" failed: ${y(M.reason)}`)}),[g,h,k]=d,w={level:m.length===0?"full":m.length>=2?"minimal":"partial",failedTools:m},T=this.shouldFragment(a,t),E=null;return T&&e==="task"&&(E=await this.createSubtasks(t,a,[],n)),{detectedDomains:a,primaryDomain:c,requiresFragmentation:T,subtasks:E,project:{id:n,ecosystem:i?.ecosystem||"unknown",conventions:i?.conventions||[]},realContext:g,sealedAnalysis:h??null,velocityContext:k??null,contextDegradation:w}}async gatherRealContext(e,t){try{let[s,n,o]=await Promise.all([this.getGitState(t),An(e,t,{maxFiles:10,minScore:.15}),hm(t,{commits:10,maxFiles:10})]),i=n.files.slice(0,3),a=await Promise.all(i.map(async c=>{try{let u=await Cm(c.path,t);if(u.signatures.length===0)return null;let p=u.signatures.map(m=>`${m.exported?"export ":""}${m.type} ${m.name}: ${m.signature}`).join(`
690
- `);return{path:c.path,content:p}}catch{return null}}));return{gitBranch:s.branch,gitStatus:s.status,relevantFiles:n.files.map(c=>({path:c.path,score:Math.round(c.score*100),reason:c.reasons.join(", ")})),recentFiles:o.hotFiles.slice(0,5).map(c=>({path:c.path,lastChanged:c.lastChanged,changes:c.changes})),signatures:a.filter(c=>c!==null)}}catch{return}}async getGitState(e){try{let[t,s]=await Promise.all([N("git branch --show-current",{cwd:e}),N("git status --porcelain",{cwd:e})]),n=t.stdout.trim()||"main",o=s.stdout.trim().split(`
691
- `).filter(Boolean),i=0,a=0,c=0;for(let m of o){let d=m.substring(0,2);d.startsWith("??")?a++:d[0]!==" "&&d[0]!=="?"?c++:i++}let u=[];c>0&&u.push(`${c} staged`),i>0&&u.push(`${i} modified`),a>0&&u.push(`${a} untracked`);let p=u.length>0?u.join(", "):"clean";return{branch:n,status:p}}catch{return{branch:"unknown",status:"git unavailable"}}}async loadSealedAnalysis(e){try{let t=Kt.getActive(e);if(t){let s=t.conventions.find(o=>o.category==="file-structure"&&/source|src/i.test(o.rule)),n=t.conventions.find(o=>o.category==="file-structure"&&/test/i.test(o.rule));return{languages:t.stack?.languages??[],frameworks:t.stack?.frameworks??[],packageManager:t.stack?.packageManager,sourceDir:s?.example,testDir:n?.example,fileCount:0,patterns:t.patterns.map(o=>({name:o.name,description:o.description,location:o.locations?.[0]})),antiPatterns:t.antiPatterns.map(o=>({issue:o.issue,file:o.files?.[0]??"multiple",suggestion:o.suggestion})),status:"sealed",commitHash:t.commitHash??void 0}}return this.loadHeuristicAnalysis(e)}catch{return null}}async loadHeuristicAnalysis(e){try{let t=await qe.getActive(e);return t?{languages:t.languages??[],frameworks:t.frameworks??[],packageManager:t.packageManager,sourceDir:t.sourceDir,testDir:t.testDir,fileCount:t.fileCount??0,patterns:t.patterns??[],antiPatterns:t.antiPatterns??[],status:t.status??"draft",commitHash:t.commitHash}:null}catch{return null}}async loadVelocityContext(e){try{let t=await wt.getAll(e);if(t.length===0)return null;let s=Uo(t,bs);return s.sprints.length===0?null:fm(s)}catch{return null}}async loadRepoAnalysis(e){try{let t=KS.join(e,"analysis","repo-analysis.json"),s=await qS.readFile(t,"utf-8");return JSON.parse(s)}catch(t){return R(t)||console.warn("Failed to load repo-analysis.json:",y(t)),null}}async detectDomains(e,t,s){let n=A.getGlobalProjectPath(t),o={hasFrontend:!1,hasBackend:!0,hasDatabase:!1,hasTesting:!1,hasDocker:!1};try{let u=await _.read(t);u.domains&&(o=u.domains)}catch{}let i={domains:o,stack:s?{language:s.ecosystem}:void 0},{classification:a}=await Dm.classify(e,t,n,i),c=[a.primaryDomain,...a.secondaryDomains||[]];return c.length===0?{domains:["general"],primary:"general"}:{domains:c,primary:c[0]}}shouldFragment(e,t){if(e.length>=3)return!0;let s=["full stack","fullstack","end to end","e2e","complete feature","from database to ui","across layers"],n=t.toLowerCase();for(let i of s)if(n.includes(i))return!0;return t.split(/\s+/).length>30&&e.length>=2}async createSubtasks(e,t,s,n){let o=[...t].sort((a,c)=>{let u=Im.indexOf(a),p=Im.indexOf(c);return(u===-1?99:u)-(p===-1?99:p)}),i=o.map((a,c)=>{let u=`${a}.md`,p=o.slice(0,c).map((m,d)=>`subtask-${d+1}`);return{id:`subtask-${c+1}`,description:this.generateSubtaskDescription(e,a),domain:a,agent:u,status:c===0?"in_progress":"pending",dependsOn:p,order:c+1}});return await _.createSubtasks(n,i.map(a=>({id:a.id,description:a.description,domain:a.domain,agent:a.agent,dependsOn:a.dependsOn}))),i}generateSubtaskDescription(e,t){let n={database:"Set up data layer: schema, models, migrations",backend:"Implement API: routes, controllers, services, validation",frontend:"Build UI: components, forms, state management",testing:"Write tests: unit, integration, e2e",devops:"Configure deployment: CI/CD, environment, containers",uxui:"Design user experience: flows, accessibility, styling"}[t]||`Handle ${t} aspects`;return`[${t.toUpperCase()}] ${n} for: ${e.substring(0,80)}${e.length>80?"...":""}`}},XS=new Vc,Bo=XS});function YS(r,e){return{ship:{title:"Ship Confirmation",message:"Ready to commit and push changes?",details:[`Branch: ${e.branch||"current"}`,`Files: ${e.changedFiles?.length||0} changed`,`Commit: "${e.commitMessage||"No message"}"`],options:[{key:"y",label:"Yes, ship it",action:"approve"},{key:"n",label:"No, cancel",action:"reject"},{key:"e",label:"Edit message",action:"edit"}]},cleanup:{title:"Cleanup Confirmation",message:"This will delete files/code. Continue?",details:[`Files to delete: ${e.filesToDelete?.length||0}`,`Code to remove: ${e.linesOfCode||0} lines`],options:[{key:"y",label:"Yes, cleanup",action:"approve"},{key:"n",label:"No, cancel",action:"reject"},{key:"l",label:"List files first",action:"list"}]},git:{title:"Git Operation Confirmation",message:`Execute: ${e.operation||"git operation"}?`,details:e.warnings||[],options:[{key:"y",label:"Yes, execute",action:"approve"},{key:"n",label:"No, cancel",action:"reject"}]}}[r]||{title:"Confirmation Required",message:`Execute ${r}?`,options:[{key:"y",label:"Yes",action:"approve"},{key:"n",label:"No",action:"reject"}]}}var Bc,QS,Ge,$m=S(()=>{"use strict";It();oe();Ws();Ws();l(YS,"generateApprovalPrompt");Bc=class{static{l(this,"PlanMode")}activePlans;constructor(){this.activePlans=new Map}requiresPlanning(e){return Ua.includes(e)}isDestructive(e){return Ha.includes(e)}isToolAllowedInPlanning(e){return To.includes(e)}getAllowedTools(e,t){return e?t.filter(s=>To.includes(s)):t}startPlanning(e,t,s){let n={id:ye(),projectId:e,command:t,params:s,status:ie.GATHERING,startedAt:v(),gatheredInfo:[],analysis:null,proposedPlan:null,userFeedback:null,approvedAt:null,executionStartedAt:null,completedAt:null,steps:[],currentStep:0};return this.activePlans.set(e,n),n}getActivePlan(e){return this.activePlans.get(e)||null}isInPlanningMode(e){let t=this.getActivePlan(e);return t?[ie.GATHERING,ie.ANALYZING,ie.PROPOSING,ie.PENDING_APPROVAL].includes(t.status):!1}recordGatheredInfo(e,t){let s=this.getActivePlan(e);s&&s.gatheredInfo.push({...t,gatheredAt:v()})}updateStatus(e,t){let s=this.getActivePlan(e);s&&(s.status=t,t===ie.APPROVED?s.approvedAt=v():t===ie.EXECUTING?s.executionStartedAt=v():(t===ie.COMPLETED||t===ie.ABORTED)&&(s.completedAt=v()))}setAnalysis(e,t){let s=this.getActivePlan(e);s&&(s.analysis=t,s.status=ie.ANALYZING)}proposePlan(e,t){let s=this.getActivePlan(e);return s?(s.proposedPlan=t,s.status=ie.PENDING_APPROVAL,this.formatPlanForApproval(s)):null}formatPlanForApproval(e){let t=e.proposedPlan;return{summary:t?.summary||`Plan for: ${e.command}`,approach:t?.approach,steps:t?.steps||[],risks:t?.risks||[],alternatives:t?.alternatives||[],estimatedTime:t?.estimatedTime,affectedFiles:t?.affectedFiles||[],requiresConfirmation:!0,planId:e.id}}approvePlan(e,t=null){let s=this.getActivePlan(e);return!s||s.status!==ie.PENDING_APPROVAL?null:(s.userFeedback=t,s.status=ie.APPROVED,s.approvedAt=v(),s.steps=(s.proposedPlan?.steps||[]).map((n,o)=>({index:o,description:typeof n=="string"?n:n.description||"",status:"pending",tool:typeof n=="string"?void 0:n.tool,args:typeof n=="string"?void 0:n.args})),{approved:!0,planId:s.id,steps:s.steps,message:`Plan approved. ${s.steps.length} steps to execute.`})}rejectPlan(e,t=null){let s=this.getActivePlan(e);return s?(s.status=ie.REJECTED,s.userFeedback=t,s.completedAt=v(),this.activePlans.delete(e),{rejected:!0,planId:s.id,reason:t,message:"Plan rejected. No changes made."}):null}startExecution(e){let t=this.getActivePlan(e);return!t||t.status!==ie.APPROVED?null:(t.status=ie.EXECUTING,t.executionStartedAt=v(),t.currentStep=0,this.getNextStep(e))}getNextStep(e){let t=this.getActivePlan(e);if(!t||t.status!==ie.EXECUTING)return null;let s=t.steps[t.currentStep];return s?{stepNumber:t.currentStep+1,totalSteps:t.steps.length,step:s,progress:Math.round(t.currentStep/t.steps.length*100)}:(this.completePlan(e),null)}completeStep(e,t={success:!0}){let s=this.getActivePlan(e);return!s||s.status!==ie.EXECUTING?null:(s.steps[s.currentStep].status="completed",s.steps[s.currentStep].result=t,s.steps[s.currentStep].completedAt=v(),s.currentStep++,this.getNextStep(e))}failStep(e,t){let s=this.getActivePlan(e);return s?(s.steps[s.currentStep].status="failed",s.steps[s.currentStep].error=t,{failed:!0,step:s.currentStep+1,error:t,options:["retry","skip","abort"]}):null}completePlan(e){let t=this.getActivePlan(e);if(!t)return null;t.status=ie.COMPLETED,t.completedAt=v();let s={planId:t.id,command:t.command,totalSteps:t.steps.length,completedSteps:t.steps.filter(n=>n.status==="completed").length,failedSteps:t.steps.filter(n=>n.status==="failed").length,duration:this._calculateDuration(t.executionStartedAt,t.completedAt)};return this.activePlans.delete(e),s}abortPlan(e,t="User requested"){let s=this.getActivePlan(e);if(!s)return null;s.status=ie.ABORTED,s.completedAt=v(),s.abortReason=t;let n={aborted:!0,planId:s.id,reason:t,completedSteps:s.steps.filter(o=>o.status==="completed").length,totalSteps:s.steps.length};return this.activePlans.delete(e),n}generateApprovalPrompt(e,t){return YS(e,t)}formatStatus(e){let t=this.getActivePlan(e);if(!t)return"No active plan";let n=[`${{[ie.GATHERING]:"\u{1F50D}",[ie.ANALYZING]:"\u{1F9E0}",[ie.PROPOSING]:"\u{1F4DD}",[ie.PENDING_APPROVAL]:"\u23F3",[ie.APPROVED]:"\u2705",[ie.EXECUTING]:"\u26A1",[ie.COMPLETED]:"\u{1F389}",[ie.REJECTED]:"\u274C",[ie.ABORTED]:"\u{1F6D1}"}[t.status]||"\u{1F4CB}"} Plan: ${t.command}`,`Status: ${t.status}`];if(t.status===ie.EXECUTING){let o=Math.round(t.currentStep/t.steps.length*100);n.push(`Progress: ${t.currentStep}/${t.steps.length} (${o}%)`)}return n.join(`
692
- `)}_calculateDuration(e,t){if(!e||!t)return null;let s=new Date(t).getTime()-new Date(e).getTime(),n=Math.floor(s/1e3),o=Math.floor(n/60),i=Math.floor(o/60);return i>0?`${i}h ${o%60}m`:o>0?`${o}m ${n%60}s`:`${n}s`}},QS=new Bc,Ge=QS});var Jc,ZS,Mm,Om=S(()=>{"use strict";oe();Dn();Jc=class{static{l(this,"OutcomeAnalyzer")}async summarize(e){let t=await wt.getAll(e);if(t.length===0)return{totalOutcomes:0,avgQualityScore:0,estimateAccuracy:0,topBlockers:[],topAgents:[],patternsDetected:[]};let s=t.reduce((m,d)=>m+d.qualityScore,0)/t.length,n=await wt.getEstimateAccuracy(e),o=new Map;for(let m of t)for(let d of m.blockers||[])o.set(d,(o.get(d)||0)+1);let i=[...o.entries()].sort((m,d)=>d[1]-m[1]).slice(0,5).map(([m])=>m),c=(await this.getAgentMetrics(e)).sort((m,d)=>d.successRate-m.successRate).slice(0,3).map(m=>m.agent),p=(await this.detectPatterns(e)).map(m=>m.description);return{totalOutcomes:t.length,avgQualityScore:Math.round(s*10)/10,estimateAccuracy:n,topBlockers:i,topAgents:c,patternsDetected:p}}async getAgentMetrics(e){let t=await wt.getAll(e),s=new Map;for(let o of t){let i=o.agentUsed||"unknown";s.has(i)||s.set(i,[]),s.get(i).push(o)}let n=[];for(let[o,i]of s){let a=i.length,c=i.filter(k=>k.completedAsPlanned),u=Math.round(c.length/a*100),p=i.reduce((k,w)=>k+w.qualityScore,0)/a,m=i.filter(k=>{if(!k.variance)return!1;let w=js(k.variance),T=ht(k.estimatedDuration);return T===0?!1:Math.abs(w)/T<=.2}),d=Math.round(m.length/a*100),g=new Map;for(let k of i.filter(w=>w.completedAsPlanned))for(let w of k.tags||[])g.set(w,(g.get(w)||0)+1);let h=[...g.entries()].sort((k,w)=>w[1]-k[1]).slice(0,3).map(([k])=>k);n.push({agent:o,tasksCompleted:a,successRate:u,avgQualityScore:Math.round(p*10)/10,estimateAccuracy:d,bestFor:h})}return n}async detectPatterns(e){let t=await wt.getAll(e),s=[];if(t.length<3)return s;let n=t.filter(c=>js(c.variance)>0);n.length/t.length>.6&&s.push({description:"Tasks consistently take longer than estimated",confidence:n.length/t.length,occurrences:n.length,suggestedAction:"Add 30% buffer to estimates"});let o=t.filter(c=>js(c.variance)<0);o.length/t.length>.6&&s.push({description:"Tasks consistently finish faster than estimated",confidence:o.length/t.length,occurrences:o.length,suggestedAction:"Reduce estimates by 20%"});let i=new Map;for(let c of t)for(let u of c.blockers||[])i.set(u,(i.get(u)||0)+1);for(let[c,u]of i)u>=3&&s.push({description:`Recurring blocker: ${c}`,confidence:u/t.length,occurrences:u,suggestedAction:`Address root cause of "${c}"`});let a=await this.getAgentMetrics(e);for(let c of a)c.tasksCompleted>=5&&c.successRate>90&&s.push({description:`${c.agent} has high success rate (${c.successRate}%)`,confidence:.9,occurrences:c.tasksCompleted,suggestedAction:`Prefer ${c.agent} for similar tasks`});return s.sort((c,u)=>u.confidence-c.confidence)}async suggestEstimate(e,t){let n=(await wt.getAll(e)).filter(a=>a.tags?.includes(t));if(n.length<2)return null;let o=n.reduce((a,c)=>a+ht(c.actualDuration),0),i=Math.round(o/n.length);if(i>=60){let a=Math.floor(i/60),c=i%60;return c>0?`${a}h ${c}m`:`${a}h`}return`${i}m`}async suggestAgent(e,t){let n=(await this.getAgentMetrics(e)).filter(o=>o.bestFor.includes(t));return n.length===0?null:n.sort((o,i)=>i.successRate-o.successRate)[0].agent}},ZS=new Jc,Mm=ZS});function eb(r){return r.trim().toLowerCase()}function Jo(r){return vr(r,eb)}var zc=S(()=>{"use strict";Do();l(eb,"normalizeFrameworkName");l(Jo,"deduplicateTechStack")});import{z as Ke}from"zod";function _m(r){let e=[];e.push(`## CONSTRAINTS (Read Before Acting)
693
- `);let t=[];r.language&&t.push(r.language),r.framework&&t.push(r.framework);let s=r.techStack??[];t.push(...s);let n=r.analysisLanguages??[],o=r.analysisFrameworks??[];t.push(...n,...o);let i=Jo(t);if(i.length>0&&e.push(`AVAILABLE in this project: ${i.join(", ")}`),r.analysisPackageManager&&e.push(`PACKAGE MANAGER: ${r.analysisPackageManager}`),r.domains){let a=Object.entries(r.domains).filter(([,c])=>!c).map(([c])=>c.replace(/^has/,"").toLowerCase());a.length>0&&e.push(`NOT PRESENT: ${a.join(", ")}`)}return e.push(""),e.push(`SCOPE: Only files in \`${r.projectPath}\` are accessible.`),r.fileCount&&e.push(`
717
+ `).length,m=i[0].trim(),d;if(p>1){let g=s[p-2]?.trim();(g?.startsWith("/**")||g?.startsWith("///")||g?.startsWith("#"))&&(d=g)}t.push({type:o.type,name:a,signature:US(m),exported:o.exported||!1,line:p,docstring:d})}}return t.sort((o,i)=>o.line-i.line)}function US(r){return r.replace(/\{$/,"").replace(/\s+/g," ").trim()}var MS,Pm,_S,OS,NS,Em,LS,Rm=S(()=>{"use strict";W();Cm();MS={".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".mjs":"javascript",".cjs":"javascript",".py":"python",".go":"go",".rs":"rust",".java":"java",".cs":"csharp",".php":"php",".rb":"ruby"},Pm=[{type:"function",pattern:/^export\s+(?:async\s+)?function\s+(\w+)\s*(<[^>]*>)?\s*\(([^)]*)\)\s*(?::\s*([^{;]+))?/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^export\s+const\s+(\w+)\s*(?::\s*[^=]+)?\s*=\s*(?:async\s+)?\([^)]*\)\s*(?::\s*[^=]+)?\s*=>/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^(?:async\s+)?function\s+(\w+)\s*(<[^>]*>)?\s*\(([^)]*)\)\s*(?::\s*([^{;]+))?/gm,nameIndex:1},{type:"function",pattern:/^const\s+(\w+)\s*(?::\s*[^=]+)?\s*=\s*(?:async\s+)?\([^)]*\)\s*(?::\s*[^=]+)?\s*=>/gm,nameIndex:1},{type:"interface",pattern:/^export\s+interface\s+(\w+)(?:<[^>]+>)?\s*(?:extends\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^interface\s+(\w+)(?:<[^>]+>)?\s*(?:extends\s+[^{]+)?\s*\{/gm,nameIndex:1},{type:"type",pattern:/^export\s+type\s+(\w+)(?:<[^>]+>)?\s*=/gm,nameIndex:1,exported:!0},{type:"type",pattern:/^type\s+(\w+)(?:<[^>]+>)?\s*=/gm,nameIndex:1},{type:"class",pattern:/^export\s+(?:abstract\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"class",pattern:/^(?:abstract\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1},{type:"enum",pattern:/^export\s+enum\s+(\w+)\s*\{/gm,nameIndex:1,exported:!0},{type:"enum",pattern:/^enum\s+(\w+)\s*\{/gm,nameIndex:1},{type:"const",pattern:/^export\s+const\s+(\w+)\s*(?::\s*([^=]+))?\s*=/gm,nameIndex:1,exported:!0}],_S=[{type:"function",pattern:/^def\s+(\w+)\s*\(([^)]*)\)\s*(?:->\s*([^:]+))?\s*:/gm,nameIndex:1},{type:"function",pattern:/^async\s+def\s+(\w+)\s*\(([^)]*)\)\s*(?:->\s*([^:]+))?\s*:/gm,nameIndex:1},{type:"class",pattern:/^class\s+(\w+)(?:\(([^)]*)\))?\s*:/gm,nameIndex:1}],OS=[{type:"function",pattern:/^func\s+(\w+)\s*\(([^)]*)\)\s*(?:\(([^)]*)\)|([^\s{]+))?\s*\{/gm,nameIndex:1},{type:"method",pattern:/^func\s+\([^)]+\)\s+(\w+)\s*\(([^)]*)\)\s*(?:\(([^)]*)\)|([^\s{]+))?\s*\{/gm,nameIndex:1},{type:"type",pattern:/^type\s+(\w+)\s+(?:struct|interface)\s*\{/gm,nameIndex:1}],NS=[{type:"function",pattern:/^pub\s+(?:async\s+)?fn\s+(\w+)(?:<[^>]+>)?\s*\(([^)]*)\)\s*(?:->\s*([^{]+))?\s*\{/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^(?:async\s+)?fn\s+(\w+)(?:<[^>]+>)?\s*\(([^)]*)\)\s*(?:->\s*([^{]+))?\s*\{/gm,nameIndex:1},{type:"class",pattern:/^pub\s+struct\s+(\w+)(?:<[^>]+>)?\s*(?:\{|;)/gm,nameIndex:1,exported:!0},{type:"class",pattern:/^struct\s+(\w+)(?:<[^>]+>)?\s*(?:\{|;)/gm,nameIndex:1},{type:"interface",pattern:/^pub\s+trait\s+(\w+)(?:<[^>]+>)?\s*(?:\{|:)/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^trait\s+(\w+)(?:<[^>]+>)?\s*(?:\{|:)/gm,nameIndex:1},{type:"enum",pattern:/^pub\s+enum\s+(\w+)(?:<[^>]+>)?\s*\{/gm,nameIndex:1,exported:!0},{type:"enum",pattern:/^enum\s+(\w+)(?:<[^>]+>)?\s*\{/gm,nameIndex:1}],Em=[{type:"class",pattern:/^(?:public\s+)?(?:abstract\s+)?(?:final\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+\w+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^(?:public\s+)?interface\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"method",pattern:/^\s+(?:public|private|protected)?\s*(?:static\s+)?(?:final\s+)?(?:synchronized\s+)?(?:<[^>]+>\s+)?(\w+(?:<[^>]+>)?)\s+(\w+)\s*\([^)]*\)\s*(?:throws\s+[^{]+)?\s*\{/gm,nameIndex:2}],LS={typescript:Pm,javascript:Pm,python:_S,go:OS,rust:NS,java:Em,csharp:Em,php:[],ruby:[],unknown:[]};l(xm,"extractSignatures");l(FS,"extractFromContent");l(US,"cleanSignature")});import Hc from"node:path";var HS,GS,Gc,WS,kt,Dn=S(()=>{"use strict";Te();It();ie();K();HS="outcomes",GS="outcomes.jsonl",Gc=class{static{l(this,"OutcomeRecorder")}getOutcomesDir(e){let t=A.getGlobalProjectPath(e);return Hc.join(t,HS)}getOutcomesPath(e){return Hc.join(this.getOutcomesDir(e),GS)}async record(e,t){let s={...t,id:ye()},n=this.getOutcomesPath(e);return await Tt(Hc.dirname(n)),await Li(n,JSON.stringify(s)),s}async getAll(e){let t=this.getOutcomesPath(e);if(!await P(t))return[];let s=await it(t);return s.trim()?s.trim().split(`
718
+ `).filter(n=>n.trim()).map(n=>JSON.parse(n)):[]}async filter(e,t){return(await this.getAll(e)).filter(n=>{if(t.sessionId&&n.sessionId!==t.sessionId||t.command&&n.command!==t.command||t.agent&&n.agentUsed!==t.agent||t.fromDate&&n.startedAt<t.fromDate||t.toDate&&n.completedAt>t.toDate||t.minQuality&&n.qualityScore<t.minQuality)return!1;if(t.tags&&t.tags.length>0){let o=n.tags||[];if(!t.tags.some(i=>o.includes(i)))return!1}return!0})}async getRecent(e,t=10){return(await this.getAll(e)).slice(-t)}async getByCommand(e,t){return this.filter(e,{command:t})}async getByAgent(e,t){return this.filter(e,{agent:t})}async getEstimateAccuracy(e){let t=await this.getAll(e);if(t.length===0)return 0;let s=t.filter(n=>{if(!n.variance)return!1;let o=js(n.variance),i=yt(n.estimatedDuration);return i===0?!1:Math.abs(o)/i<=.2});return Math.round(s.length/t.length*100)}},WS=new Gc,kt=WS});import{z as Ne}from"zod";var Jo,jn,VS,CI,Wc,Am,qo=S(()=>{"use strict";Jo=Ne.enum(["frontend","backend","database","devops","testing","docs","uxui","general"]),jn=Ne.object({primaryDomain:Jo,secondaryDomains:Ne.array(Jo),confidence:Ne.number().min(0).max(1),filePatterns:Ne.array(Ne.string()),relevantAgents:Ne.array(Ne.string())}),VS=Ne.object({classification:jn,classifiedAt:Ne.string(),source:Ne.enum(["cache","history","llm","heuristic"]),descriptionHash:Ne.string(),projectId:Ne.string()}),CI=Ne.object({entries:Ne.record(Ne.string(),VS),confirmedPatterns:Ne.array(Ne.object({descriptionHash:Ne.string(),classification:jn,confirmedAt:Ne.string(),taskDescription:Ne.string()}))}),Wc={entries:{},confirmedPatterns:[]},Am={primaryDomain:"general",secondaryDomains:[],confidence:.3,filePatterns:["**/*.ts","**/*.js"],relevantAgents:[]}});import zS from"node:fs/promises";import Im from"node:path";function Dm(r){return mo(r.toLowerCase().trim())}async function jm(r){try{let e=Im.join(r,"storage","classification-cache.json"),t=await zS.readFile(e,"utf-8");return JSON.parse(t)}catch(e){return R(e)?Wc:(console.warn("[classifier] Failed to load cache:",w(e)),Wc)}}async function JS(r,e){try{let t=Im.join(r,"storage","classification-cache.json");await le(t,e)}catch(t){console.warn("[classifier] Failed to save cache:",w(t))}}function qS(r,e,t){let s=r.entries[e];return!s||s.projectId!==t||fs(s.classifiedAt,36e5)?null:s.classification}function KS(r,e){return r.confirmedPatterns.find(s=>s.descriptionHash===e)?.classification??null}var Vc,XS,$m,Mm=S(()=>{"use strict";or();qo();W();Ms();K();wn();l(Dm,"hashDescription");l(jm,"loadCache");l(JS,"saveCache");l(qS,"lookupCache");l(KS,"lookupPatterns");Vc=class{static{l(this,"DomainClassifier")}async classify(e,t,s,n){let o=Dm(e),i=await jm(s),a=qS(i,o,t);if(a)return{classification:a,source:"cache"};let c=KS(i,o);return c?{classification:c,source:"history"}:{classification:Am,source:"heuristic"}}async confirmClassification(e,t,s){let n=Dm(e),o=await jm(s);o.confirmedPatterns.some(i=>i.descriptionHash===n)||(o.confirmedPatterns.push({descriptionHash:n,classification:t,confirmedAt:new Date().toISOString(),taskDescription:e}),await JS(s,o))}},XS=new Vc,$m=XS});import YS from"node:fs/promises";import QS from"node:path";var _m,Bc,ZS,Ko,zc=S(()=>{"use strict";Oc();Et();Te();vr();kn();kr();Pt();zo();Sm();Rm();W();He();Dn();Mm();_m=["database","backend","frontend","testing","devops"],Bc=class{static{l(this,"OrchestratorExecutor")}async execute(e,t,s){let n=await $.getProjectId(s),o=A.getGlobalProjectPath(n),i=await this.loadRepoAnalysis(o),{domains:a,primary:c}=await this.detectDomains(t,n,i),u=await Promise.allSettled([this.gatherRealContext(t,s),this.loadSealedAnalysis(n),this.loadVelocityContext(n)]),p=["realContext","sealedAnalysis","velocity"],m=[],d=u.map((F,j)=>{if(F.status==="fulfilled")return F.value;m.push(p[j]),console.warn(`Context tool "${p[j]}" failed: ${w(F.reason)}`)}),[g,h,k]=d,y={level:m.length===0?"full":m.length>=2?"minimal":"partial",failedTools:m},v=this.shouldFragment(a,t),D=null;v&&e==="task"&&(D=await this.createSubtasks(t,a,[],n));let U=this.resolveRpiPhase(n);return{detectedDomains:a,primaryDomain:c,requiresFragmentation:v,subtasks:D,project:{id:n,ecosystem:i?.ecosystem||"unknown",conventions:i?.conventions||[]},realContext:g,sealedAnalysis:h??null,velocityContext:k??null,contextDegradation:y,rpiContext:U}}resolveRpiPhase(e){try{let{prjctDb:t}=(re(),ot(Zr)),s=t.getDoc(e,"rpi:current:research"),n=t.getDoc(e,"rpi:current:plan");if(!s)return{phase:"research"};if(!n)return{phase:"plan",researchDoc:s};let o=this.extractScopedFilesFromPlan(n);return{phase:"implement",researchDoc:s,planDoc:n,scopedFiles:o}}catch{return null}}extractScopedFilesFromPlan(e){let t=/`([a-zA-Z0-9_\-./]+\.[a-zA-Z]{1,6})`/g,s=new Set;for(let n of e.matchAll(t))s.add(n[1]);return[...s].slice(0,20)}async gatherRealContext(e,t){try{let[s,n,o]=await Promise.all([this.getGitState(t),An(e,t,{maxFiles:10,minScore:.15}),km(t,{commits:10,maxFiles:10})]),i=n.files.slice(0,3),a=await Promise.all(i.map(async c=>{try{let u=await xm(c.path,t);if(u.signatures.length===0)return null;let p=u.signatures.map(m=>`${m.exported?"export ":""}${m.type} ${m.name}: ${m.signature}`).join(`
719
+ `);return{path:c.path,content:p}}catch{return null}}));return{gitBranch:s.branch,gitStatus:s.status,relevantFiles:n.files.map(c=>({path:c.path,score:Math.round(c.score*100),reason:c.reasons.join(", ")})),recentFiles:o.hotFiles.slice(0,5).map(c=>({path:c.path,lastChanged:c.lastChanged,changes:c.changes})),signatures:a.filter(c=>c!==null)}}catch{return}}async getGitState(e){try{let[t,s]=await Promise.all([O("git branch --show-current",{cwd:e}),O("git status --porcelain",{cwd:e})]),n=t.stdout.trim()||"main",o=s.stdout.trim().split(`
720
+ `).filter(Boolean),i=0,a=0,c=0;for(let m of o){let d=m.substring(0,2);d.startsWith("??")?a++:d[0]!==" "&&d[0]!=="?"?c++:i++}let u=[];c>0&&u.push(`${c} staged`),i>0&&u.push(`${i} modified`),a>0&&u.push(`${a} untracked`);let p=u.length>0?u.join(", "):"clean";return{branch:n,status:p}}catch{return{branch:"unknown",status:"git unavailable"}}}async loadSealedAnalysis(e){try{let t=Lt.getActive(e);if(t){let s=t.conventions.find(o=>o.category==="file-structure"&&/source|src/i.test(o.rule)),n=t.conventions.find(o=>o.category==="file-structure"&&/test/i.test(o.rule));return{languages:t.stack?.languages??[],frameworks:t.stack?.frameworks??[],packageManager:t.stack?.packageManager,sourceDir:s?.example,testDir:n?.example,fileCount:0,patterns:t.patterns.map(o=>({name:o.name,description:o.description,location:o.locations?.[0]})),antiPatterns:t.antiPatterns.map(o=>({issue:o.issue,file:o.files?.[0]??"multiple",suggestion:o.suggestion})),status:"sealed",commitHash:t.commitHash??void 0}}return this.loadHeuristicAnalysis(e)}catch{return null}}async loadHeuristicAnalysis(e){try{let t=await Ke.getActive(e);return t?{languages:t.languages??[],frameworks:t.frameworks??[],packageManager:t.packageManager,sourceDir:t.sourceDir,testDir:t.testDir,fileCount:t.fileCount??0,patterns:t.patterns??[],antiPatterns:t.antiPatterns??[],status:t.status??"draft",commitHash:t.commitHash}:null}catch{return null}}async loadVelocityContext(e){try{let t=await kt.getAll(e);if(t.length===0)return null;let s=Vo(t,bs);return s.sprints.length===0?null:wm(s)}catch{return null}}async loadRepoAnalysis(e){try{let t=QS.join(e,"analysis","repo-analysis.json"),s=await YS.readFile(t,"utf-8");return JSON.parse(s)}catch(t){return R(t)||console.warn("Failed to load repo-analysis.json:",w(t)),null}}async detectDomains(e,t,s){let n=A.getGlobalProjectPath(t),o={hasFrontend:!1,hasBackend:!0,hasDatabase:!1,hasTesting:!1,hasDocker:!1};try{let u=await _.read(t);u.domains&&(o=u.domains)}catch{}let i={domains:o,stack:s?{language:s.ecosystem}:void 0},{classification:a}=await $m.classify(e,t,n,i),c=[a.primaryDomain,...a.secondaryDomains||[]];return c.length===0?{domains:["general"],primary:"general"}:{domains:c,primary:c[0]}}shouldFragment(e,t){if(e.length>=3)return!0;let s=["full stack","fullstack","end to end","e2e","complete feature","from database to ui","across layers"],n=t.toLowerCase();for(let i of s)if(n.includes(i))return!0;return t.split(/\s+/).length>30&&e.length>=2}async createSubtasks(e,t,s,n){let o=[...t].sort((a,c)=>{let u=_m.indexOf(a),p=_m.indexOf(c);return(u===-1?99:u)-(p===-1?99:p)}),i=o.map((a,c)=>{let u=`${a}.md`,p=o.slice(0,c).map((m,d)=>`subtask-${d+1}`);return{id:`subtask-${c+1}`,description:this.generateSubtaskDescription(e,a),domain:a,agent:u,status:c===0?"in_progress":"pending",dependsOn:p,order:c+1}});return await _.createSubtasks(n,i.map(a=>({id:a.id,description:a.description,domain:a.domain,agent:a.agent,dependsOn:a.dependsOn}))),i}generateSubtaskDescription(e,t){let n={database:"Set up data layer: schema, models, migrations",backend:"Implement API: routes, controllers, services, validation",frontend:"Build UI: components, forms, state management",testing:"Write tests: unit, integration, e2e",devops:"Configure deployment: CI/CD, environment, containers",uxui:"Design user experience: flows, accessibility, styling"}[t]||`Handle ${t} aspects`;return`[${t.toUpperCase()}] ${n} for: ${e.substring(0,80)}${e.length>80?"...":""}`}},ZS=new Bc,Ko=ZS});function eb(r,e){return{ship:{title:"Ship Confirmation",message:"Ready to commit and push changes?",details:[`Branch: ${e.branch||"current"}`,`Files: ${e.changedFiles?.length||0} changed`,`Commit: "${e.commitMessage||"No message"}"`],options:[{key:"y",label:"Yes, ship it",action:"approve"},{key:"n",label:"No, cancel",action:"reject"},{key:"e",label:"Edit message",action:"edit"}]},cleanup:{title:"Cleanup Confirmation",message:"This will delete files/code. Continue?",details:[`Files to delete: ${e.filesToDelete?.length||0}`,`Code to remove: ${e.linesOfCode||0} lines`],options:[{key:"y",label:"Yes, cleanup",action:"approve"},{key:"n",label:"No, cancel",action:"reject"},{key:"l",label:"List files first",action:"list"}]},git:{title:"Git Operation Confirmation",message:`Execute: ${e.operation||"git operation"}?`,details:e.warnings||[],options:[{key:"y",label:"Yes, execute",action:"approve"},{key:"n",label:"No, cancel",action:"reject"}]}}[r]||{title:"Confirmation Required",message:`Execute ${r}?`,options:[{key:"y",label:"Yes",action:"approve"},{key:"n",label:"No",action:"reject"}]}}var Jc,tb,We,Om=S(()=>{"use strict";It();ie();Vs();Vs();l(eb,"generateApprovalPrompt");Jc=class{static{l(this,"PlanMode")}activePlans;constructor(){this.activePlans=new Map}requiresPlanning(e){return Ga.includes(e)}isDestructive(e){return Wa.includes(e)}isToolAllowedInPlanning(e){return xo.includes(e)}getAllowedTools(e,t){return e?t.filter(s=>xo.includes(s)):t}startPlanning(e,t,s){let n={id:ye(),projectId:e,command:t,params:s,status:ae.GATHERING,startedAt:T(),gatheredInfo:[],analysis:null,proposedPlan:null,userFeedback:null,approvedAt:null,executionStartedAt:null,completedAt:null,steps:[],currentStep:0};return this.activePlans.set(e,n),n}getActivePlan(e){return this.activePlans.get(e)||null}isInPlanningMode(e){let t=this.getActivePlan(e);return t?[ae.GATHERING,ae.ANALYZING,ae.PROPOSING,ae.PENDING_APPROVAL].includes(t.status):!1}recordGatheredInfo(e,t){let s=this.getActivePlan(e);s&&s.gatheredInfo.push({...t,gatheredAt:T()})}updateStatus(e,t){let s=this.getActivePlan(e);s&&(s.status=t,t===ae.APPROVED?s.approvedAt=T():t===ae.EXECUTING?s.executionStartedAt=T():(t===ae.COMPLETED||t===ae.ABORTED)&&(s.completedAt=T()))}setAnalysis(e,t){let s=this.getActivePlan(e);s&&(s.analysis=t,s.status=ae.ANALYZING)}proposePlan(e,t){let s=this.getActivePlan(e);return s?(s.proposedPlan=t,s.status=ae.PENDING_APPROVAL,this.formatPlanForApproval(s)):null}formatPlanForApproval(e){let t=e.proposedPlan;return{summary:t?.summary||`Plan for: ${e.command}`,approach:t?.approach,steps:t?.steps||[],risks:t?.risks||[],alternatives:t?.alternatives||[],estimatedTime:t?.estimatedTime,affectedFiles:t?.affectedFiles||[],requiresConfirmation:!0,planId:e.id}}approvePlan(e,t=null){let s=this.getActivePlan(e);return!s||s.status!==ae.PENDING_APPROVAL?null:(s.userFeedback=t,s.status=ae.APPROVED,s.approvedAt=T(),s.steps=(s.proposedPlan?.steps||[]).map((n,o)=>({index:o,description:typeof n=="string"?n:n.description||"",status:"pending",tool:typeof n=="string"?void 0:n.tool,args:typeof n=="string"?void 0:n.args})),{approved:!0,planId:s.id,steps:s.steps,message:`Plan approved. ${s.steps.length} steps to execute.`})}rejectPlan(e,t=null){let s=this.getActivePlan(e);return s?(s.status=ae.REJECTED,s.userFeedback=t,s.completedAt=T(),this.activePlans.delete(e),{rejected:!0,planId:s.id,reason:t,message:"Plan rejected. No changes made."}):null}startExecution(e){let t=this.getActivePlan(e);return!t||t.status!==ae.APPROVED?null:(t.status=ae.EXECUTING,t.executionStartedAt=T(),t.currentStep=0,this.getNextStep(e))}getNextStep(e){let t=this.getActivePlan(e);if(!t||t.status!==ae.EXECUTING)return null;let s=t.steps[t.currentStep];return s?{stepNumber:t.currentStep+1,totalSteps:t.steps.length,step:s,progress:Math.round(t.currentStep/t.steps.length*100)}:(this.completePlan(e),null)}completeStep(e,t={success:!0}){let s=this.getActivePlan(e);return!s||s.status!==ae.EXECUTING?null:(s.steps[s.currentStep].status="completed",s.steps[s.currentStep].result=t,s.steps[s.currentStep].completedAt=T(),s.currentStep++,this.getNextStep(e))}failStep(e,t){let s=this.getActivePlan(e);return s?(s.steps[s.currentStep].status="failed",s.steps[s.currentStep].error=t,{failed:!0,step:s.currentStep+1,error:t,options:["retry","skip","abort"]}):null}completePlan(e){let t=this.getActivePlan(e);if(!t)return null;t.status=ae.COMPLETED,t.completedAt=T();let s={planId:t.id,command:t.command,totalSteps:t.steps.length,completedSteps:t.steps.filter(n=>n.status==="completed").length,failedSteps:t.steps.filter(n=>n.status==="failed").length,duration:this._calculateDuration(t.executionStartedAt,t.completedAt)};return this.activePlans.delete(e),s}abortPlan(e,t="User requested"){let s=this.getActivePlan(e);if(!s)return null;s.status=ae.ABORTED,s.completedAt=T(),s.abortReason=t;let n={aborted:!0,planId:s.id,reason:t,completedSteps:s.steps.filter(o=>o.status==="completed").length,totalSteps:s.steps.length};return this.activePlans.delete(e),n}generateApprovalPrompt(e,t){return eb(e,t)}formatStatus(e){let t=this.getActivePlan(e);if(!t)return"No active plan";let n=[`${{[ae.GATHERING]:"\u{1F50D}",[ae.ANALYZING]:"\u{1F9E0}",[ae.PROPOSING]:"\u{1F4DD}",[ae.PENDING_APPROVAL]:"\u23F3",[ae.APPROVED]:"\u2705",[ae.EXECUTING]:"\u26A1",[ae.COMPLETED]:"\u{1F389}",[ae.REJECTED]:"\u274C",[ae.ABORTED]:"\u{1F6D1}"}[t.status]||"\u{1F4CB}"} Plan: ${t.command}`,`Status: ${t.status}`];if(t.status===ae.EXECUTING){let o=Math.round(t.currentStep/t.steps.length*100);n.push(`Progress: ${t.currentStep}/${t.steps.length} (${o}%)`)}return n.join(`
721
+ `)}_calculateDuration(e,t){if(!e||!t)return null;let s=new Date(t).getTime()-new Date(e).getTime(),n=Math.floor(s/1e3),o=Math.floor(n/60),i=Math.floor(o/60);return i>0?`${i}h ${o%60}m`:o>0?`${o}m ${n%60}s`:`${n}s`}},tb=new Jc,We=tb});var qc,sb,Nm,Lm=S(()=>{"use strict";ie();Dn();qc=class{static{l(this,"OutcomeAnalyzer")}async summarize(e){let t=await kt.getAll(e);if(t.length===0)return{totalOutcomes:0,avgQualityScore:0,estimateAccuracy:0,topBlockers:[],topAgents:[],patternsDetected:[]};let s=t.reduce((m,d)=>m+d.qualityScore,0)/t.length,n=await kt.getEstimateAccuracy(e),o=new Map;for(let m of t)for(let d of m.blockers||[])o.set(d,(o.get(d)||0)+1);let i=[...o.entries()].sort((m,d)=>d[1]-m[1]).slice(0,5).map(([m])=>m),c=(await this.getAgentMetrics(e)).sort((m,d)=>d.successRate-m.successRate).slice(0,3).map(m=>m.agent),p=(await this.detectPatterns(e)).map(m=>m.description);return{totalOutcomes:t.length,avgQualityScore:Math.round(s*10)/10,estimateAccuracy:n,topBlockers:i,topAgents:c,patternsDetected:p}}async getAgentMetrics(e){let t=await kt.getAll(e),s=new Map;for(let o of t){let i=o.agentUsed||"unknown";s.has(i)||s.set(i,[]),s.get(i).push(o)}let n=[];for(let[o,i]of s){let a=i.length,c=i.filter(k=>k.completedAsPlanned),u=Math.round(c.length/a*100),p=i.reduce((k,y)=>k+y.qualityScore,0)/a,m=i.filter(k=>{if(!k.variance)return!1;let y=js(k.variance),v=yt(k.estimatedDuration);return v===0?!1:Math.abs(y)/v<=.2}),d=Math.round(m.length/a*100),g=new Map;for(let k of i.filter(y=>y.completedAsPlanned))for(let y of k.tags||[])g.set(y,(g.get(y)||0)+1);let h=[...g.entries()].sort((k,y)=>y[1]-k[1]).slice(0,3).map(([k])=>k);n.push({agent:o,tasksCompleted:a,successRate:u,avgQualityScore:Math.round(p*10)/10,estimateAccuracy:d,bestFor:h})}return n}async detectPatterns(e){let t=await kt.getAll(e),s=[];if(t.length<3)return s;let n=t.filter(c=>js(c.variance)>0);n.length/t.length>.6&&s.push({description:"Tasks consistently take longer than estimated",confidence:n.length/t.length,occurrences:n.length,suggestedAction:"Add 30% buffer to estimates"});let o=t.filter(c=>js(c.variance)<0);o.length/t.length>.6&&s.push({description:"Tasks consistently finish faster than estimated",confidence:o.length/t.length,occurrences:o.length,suggestedAction:"Reduce estimates by 20%"});let i=new Map;for(let c of t)for(let u of c.blockers||[])i.set(u,(i.get(u)||0)+1);for(let[c,u]of i)u>=3&&s.push({description:`Recurring blocker: ${c}`,confidence:u/t.length,occurrences:u,suggestedAction:`Address root cause of "${c}"`});let a=await this.getAgentMetrics(e);for(let c of a)c.tasksCompleted>=5&&c.successRate>90&&s.push({description:`${c.agent} has high success rate (${c.successRate}%)`,confidence:.9,occurrences:c.tasksCompleted,suggestedAction:`Prefer ${c.agent} for similar tasks`});return s.sort((c,u)=>u.confidence-c.confidence)}async suggestEstimate(e,t){let n=(await kt.getAll(e)).filter(a=>a.tags?.includes(t));if(n.length<2)return null;let o=n.reduce((a,c)=>a+yt(c.actualDuration),0),i=Math.round(o/n.length);if(i>=60){let a=Math.floor(i/60),c=i%60;return c>0?`${a}h ${c}m`:`${a}h`}return`${i}m`}async suggestAgent(e,t){let n=(await this.getAgentMetrics(e)).filter(o=>o.bestFor.includes(t));return n.length===0?null:n.sort((o,i)=>i.successRate-o.successRate)[0].agent}},sb=new qc,Nm=sb});function nb(r){return r.trim().toLowerCase()}function Xo(r){return Tr(r,nb)}var Kc=S(()=>{"use strict";Mo();l(nb,"normalizeFrameworkName");l(Xo,"deduplicateTechStack")});import{z as Xe}from"zod";function Fm(r){let e=[];e.push(`## CONSTRAINTS (Read Before Acting)
722
+ `);let t=[];r.language&&t.push(r.language),r.framework&&t.push(r.framework);let s=r.techStack??[];t.push(...s);let n=r.analysisLanguages??[],o=r.analysisFrameworks??[];t.push(...n,...o);let i=Xo(t);if(i.length>0&&e.push(`AVAILABLE in this project: ${i.join(", ")}`),r.analysisPackageManager&&e.push(`PACKAGE MANAGER: ${r.analysisPackageManager}`),r.domains){let a=Object.entries(r.domains).filter(([,c])=>!c).map(([c])=>c.replace(/^has/,"").toLowerCase());a.length>0&&e.push(`NOT PRESENT: ${a.join(", ")}`)}return e.push(""),e.push(`SCOPE: Only files in \`${r.projectPath}\` are accessible.`),r.fileCount&&e.push(`
694
723
  Context: ${r.fileCount} files in project.`),e.join(`
695
- `)}var p$,Nm=S(()=>{"use strict";zc();p$=Ke.object({projectPath:Ke.string(),language:Ke.string().optional(),framework:Ke.string().optional(),techStack:Ke.array(Ke.string()).default([]),domains:Ke.object({hasFrontend:Ke.boolean().default(!1),hasBackend:Ke.boolean().default(!1),hasDatabase:Ke.boolean().default(!1),hasTesting:Ke.boolean().default(!1),hasDocker:Ke.boolean().default(!1)}).optional(),fileCount:Ke.number().optional(),analysisLanguages:Ke.array(Ke.string()).default([]),analysisFrameworks:Ke.array(Ke.string()).default([]),analysisPackageManager:Ke.string().optional()});l(_m,"buildAntiHallucinationBlock")});import{z as Gt}from"zod";var tb,Lm,Fm=S(()=>{"use strict";tb=Gt.object({agents:Gt.boolean(),patterns:Gt.boolean(),checklist:Gt.boolean(),modules:Gt.array(Gt.string())}),Lm=Gt.object({version:Gt.string(),description:Gt.string().optional(),commands:Gt.record(Gt.string(),tb).refine(r=>"*"in r,{message:'Config must include a "*" wildcard entry for unknown commands'})})});function Um(r,e){return{agents:!0,patterns:!0,checklist:!1,modules:[]}}var Hm=S(()=>{"use strict";l(Um,"classifyCommand")});import qc from"node:fs/promises";import sb from"node:path";async function Vm(){if(jr)return jr;let r=await qc.readFile(Kc,"utf-8"),e=JSON.parse(r);return jr=Lm.parse(e),jr}function nb(r){return Wm.get(r)}function rb(r,e){Wm.set(r,e)}function ib(r,e){let t=r,s=Gm.get(t);return s&&cb(s.entry,e)?(s.count++,s.count>=ob):(Gm.set(t,{entry:e,count:1}),!1)}async function ab(r,e){let t=await qc.readFile(Kc,"utf-8"),s=JSON.parse(t);s.commands[r]=e,await qc.writeFile(Kc,`${JSON.stringify(s,null,2)}
696
- `,"utf-8"),jr=null}function cb(r,e){return r.agents===e.agents&&r.patterns===e.patterns&&r.checklist===e.checklist&&r.modules.length===e.modules.length&&r.modules.every((t,s)=>t===e.modules[s])}function Bm(r,e,t){if(e in r.commands&&e!=="*")return{entry:r.commands[e],source:"config"};let s=nb(e);if(s)return{entry:s,source:"cache"};if(t){let n=Um(e,t);return rb(e,n),ib(e,n)&&ab(e,n).catch(()=>{}),{entry:n,source:"classified"}}return{entry:r.commands["*"],source:"wildcard"}}var Kc,jr,Wm,Gm,ob,Jm=S(()=>{"use strict";Fm();Ct();Hm();Kc=sb.join(Qe,"core/config/command-context.config.json"),jr=null;l(Vm,"loadCommandContextConfig");Wm=new Map;l(nb,"getCachedClassification");l(rb,"cacheClassification");Gm=new Map,ob=3;l(ib,"trackClassification");l(ab,"persistClassification");l(cb,"isSameEntry");l(Bm,"resolveCommandContextFull")});import lb from"node:os";import{z as Qt}from"zod";function ub(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function db(r){return{darwin:"macOS",linux:"Linux",win32:"Windows",freebsd:"FreeBSD"}[r]??r}function zm(r){let e=r.platform??lb.platform(),t=r.runtime??ub(),s=r.date??new Date().toISOString().split("T")[0];return`<env>
697
- ${[["project",r.projectName],["path",r.projectPath],["git",r.isGitRepo?"true":"false"],["branch",r.gitBranch],["platform",db(e)],["runtime",t],["date",s],["model",r.model],["provider",r.provider]].filter(([,i])=>i!==void 0).map(([i,a])=>`${i}: ${a}`).join(`
724
+ `)}var f$,Um=S(()=>{"use strict";Kc();f$=Xe.object({projectPath:Xe.string(),language:Xe.string().optional(),framework:Xe.string().optional(),techStack:Xe.array(Xe.string()).default([]),domains:Xe.object({hasFrontend:Xe.boolean().default(!1),hasBackend:Xe.boolean().default(!1),hasDatabase:Xe.boolean().default(!1),hasTesting:Xe.boolean().default(!1),hasDocker:Xe.boolean().default(!1)}).optional(),fileCount:Xe.number().optional(),analysisLanguages:Xe.array(Xe.string()).default([]),analysisFrameworks:Xe.array(Xe.string()).default([]),analysisPackageManager:Xe.string().optional()});l(Fm,"buildAntiHallucinationBlock")});import{z as Vt}from"zod";var rb,Hm,Gm=S(()=>{"use strict";rb=Vt.object({agents:Vt.boolean(),patterns:Vt.boolean(),checklist:Vt.boolean(),modules:Vt.array(Vt.string())}),Hm=Vt.object({version:Vt.string(),description:Vt.string().optional(),commands:Vt.record(Vt.string(),rb).refine(r=>"*"in r,{message:'Config must include a "*" wildcard entry for unknown commands'})})});function Wm(r,e){return{agents:!0,patterns:!0,checklist:!1,modules:[]}}var Vm=S(()=>{"use strict";l(Wm,"classifyCommand")});import Xc from"node:fs/promises";import ob from"node:path";async function zm(){if($r)return $r;let r=await Xc.readFile(Yc,"utf-8"),e=JSON.parse(r);return $r=Hm.parse(e),$r}function ib(r){return Jm.get(r)}function ab(r,e){Jm.set(r,e)}function lb(r,e){let t=r,s=Bm.get(t);return s&&db(s.entry,e)?(s.count++,s.count>=cb):(Bm.set(t,{entry:e,count:1}),!1)}async function ub(r,e){let t=await Xc.readFile(Yc,"utf-8"),s=JSON.parse(t);s.commands[r]=e,await Xc.writeFile(Yc,`${JSON.stringify(s,null,2)}
725
+ `,"utf-8"),$r=null}function db(r,e){return r.agents===e.agents&&r.patterns===e.patterns&&r.checklist===e.checklist&&r.modules.length===e.modules.length&&r.modules.every((t,s)=>t===e.modules[s])}function qm(r,e,t){if(e in r.commands&&e!=="*")return{entry:r.commands[e],source:"config"};let s=ib(e);if(s)return{entry:s,source:"cache"};if(t){let n=Wm(e,t);return ab(e,n),lb(e,n)&&ub(e,n).catch(()=>{}),{entry:n,source:"classified"}}return{entry:r.commands["*"],source:"wildcard"}}var Yc,$r,Jm,Bm,cb,Km=S(()=>{"use strict";Gm();Ct();Vm();Yc=ob.join(Ze,"core/config/command-context.config.json"),$r=null;l(zm,"loadCommandContextConfig");Jm=new Map;l(ib,"getCachedClassification");l(ab,"cacheClassification");Bm=new Map,cb=3;l(lb,"trackClassification");l(ub,"persistClassification");l(db,"isSameEntry");l(qm,"resolveCommandContextFull")});import pb from"node:os";import{z as Qt}from"zod";function mb(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function gb(r){return{darwin:"macOS",linux:"Linux",win32:"Windows",freebsd:"FreeBSD"}[r]??r}function Xm(r){let e=r.platform??pb.platform(),t=r.runtime??mb(),s=r.date??new Date().toISOString().split("T")[0];return`<env>
726
+ ${[["project",r.projectName],["path",r.projectPath],["git",r.isGitRepo?"true":"false"],["branch",r.gitBranch],["platform",gb(e)],["runtime",t],["date",s],["model",r.model],["provider",r.provider]].filter(([,i])=>i!==void 0).map(([i,a])=>`${i}: ${a}`).join(`
698
727
  `)}
699
- </env>`}var R$,qm=S(()=>{"use strict";R$=Qt.object({projectName:Qt.string(),projectPath:Qt.string(),isGitRepo:Qt.boolean().default(!0),gitBranch:Qt.string().optional(),platform:Qt.string().optional(),runtime:Qt.string().optional(),date:Qt.string().optional(),model:Qt.string().optional(),provider:Qt.string().optional()});l(ub,"detectRuntime");l(db,"normalizePlatform");l(zm,"buildEnvironmentBlock")});function Xm(r){let e=r.getAllocationFor("injection");return{...qo,totalPrompt:e}}function Ir(r,e){let t=e*4;return r.length<=t?r:`${r.substring(0,t)}
700
- ... (truncated to ~${e} tokens)`}function Km(r){return Math.ceil(r.length/4)}var qo,zo,Ym=S(()=>{"use strict";po();qo={autoContext:500,stateData:1e3,memories:600,totalPrompt:8e3};l(Xm,"budgetsFromCoordinator");l(Ir,"truncateToTokenBudget");l(Km,"estimateTokens");zo=class{static{l(this,"InjectionBudgetTracker")}used=0;budgets;constructor(e={}){this.budgets={...qo,...e}}addSection(e,t){let s=Ir(e,t),n=Km(s);if(this.used+n>this.budgets.totalPrompt){let o=this.budgets.totalPrompt-this.used;if(o<=0)return"";let i=Ir(s,o);return this.used+=Km(i),i}return this.used+=n,s}get remaining(){return Math.max(0,this.budgets.totalPrompt-this.used)}get totalUsed(){return this.used}get config(){return this.budgets}}});var sg={};Bt(sg,{AgentAssignmentSchema:()=>Qm,OUTPUT_SCHEMAS:()=>eg,SubtaskBreakdownSchema:()=>Zm,TaskClassificationSchema:()=>jn,renderSchemaForPrompt:()=>pb});import{z as Xe}from"zod";function pb(r){let e=eg[r];return e?`## OUTPUT FORMAT
728
+ </env>`}var j$,Ym=S(()=>{"use strict";j$=Qt.object({projectName:Qt.string(),projectPath:Qt.string(),isGitRepo:Qt.boolean().default(!0),gitBranch:Qt.string().optional(),platform:Qt.string().optional(),runtime:Qt.string().optional(),date:Qt.string().optional(),model:Qt.string().optional(),provider:Qt.string().optional()});l(mb,"detectRuntime");l(gb,"normalizePlatform");l(Xm,"buildEnvironmentBlock")});function Zm(r){let e=r.getAllocationFor("injection");return{...Qo,totalPrompt:e}}function Mr(r,e){let t=e*4;return r.length<=t?r:`${r.substring(0,t)}
729
+ ... (truncated to ~${e} tokens)`}function Qm(r){return Math.ceil(r.length/4)}var Qo,Yo,eg=S(()=>{"use strict";ho();Qo={autoContext:500,stateData:1e3,memories:600,totalPrompt:8e3};l(Zm,"budgetsFromCoordinator");l(Mr,"truncateToTokenBudget");l(Qm,"estimateTokens");Yo=class{static{l(this,"InjectionBudgetTracker")}used=0;budgets;constructor(e={}){this.budgets={...Qo,...e}}addSection(e,t){let s=Mr(e,t),n=Qm(s);if(this.used+n>this.budgets.totalPrompt){let o=this.budgets.totalPrompt-this.used;if(o<=0)return"";let i=Mr(s,o);return this.used+=Qm(i),i}return this.used+=n,s}get remaining(){return Math.max(0,this.budgets.totalPrompt-this.used)}get totalUsed(){return this.used}get config(){return this.budgets}}});var og={};Ot(og,{AgentAssignmentSchema:()=>tg,OUTPUT_SCHEMAS:()=>ng,SubtaskBreakdownSchema:()=>sg,TaskClassificationSchema:()=>jn,renderSchemaForPrompt:()=>fb});import{z as Ye}from"zod";function fb(r){let e=ng[r];return e?`## OUTPUT FORMAT
701
730
 
702
731
  Return ONLY valid JSON matching this schema (no markdown, no explanation):
703
732
 
@@ -706,9 +735,9 @@ ${e.example}
706
735
  \`\`\`
707
736
 
708
737
  Fields:
709
- ${mb(e.schema)}`:null}function mb(r){if(r instanceof Xe.ZodObject){let e=r.shape;return Object.entries(e).map(([t,s])=>`- \`${t}\`: ${tg(s)}`).join(`
710
- `)}return"(see example above)"}function tg(r){return r instanceof Xe.ZodString?"string":r instanceof Xe.ZodNumber?"number":r instanceof Xe.ZodEnum?`one of: ${r.options.join(", ")}`:r instanceof Xe.ZodArray?`array of ${tg(r.element)}`:r instanceof Xe.ZodObject?"object":"any"}var Qm,Zm,eg,ng=S(()=>{"use strict";Wo();Wo();Qm=Xe.object({agentName:Xe.string(),reasoning:Xe.string(),confidence:Xe.number().min(0).max(1)}),Zm=Xe.object({subtasks:Xe.array(Xe.object({description:Xe.string(),domain:Vo,agent:Xe.string(),dependsOn:Xe.array(Xe.number())})),effort:Xe.enum(["low","medium","high"])}),eg={classification:{schema:jn,example:JSON.stringify({primaryDomain:"backend",secondaryDomains:["database"],confidence:.9,filePatterns:["src/api/**"],relevantAgents:["backend.md"]},null,2)},agentAssignment:{schema:Qm,example:JSON.stringify({agentName:"backend.md",reasoning:"Task involves API endpoint creation",confidence:.85},null,2)},subtaskBreakdown:{schema:Zm,example:JSON.stringify({subtasks:[{description:"Add schema validation",domain:"backend",agent:"backend.md",dependsOn:[]},{description:"Add unit tests",domain:"testing",agent:"testing.md",dependsOn:[0]}],effort:"medium"},null,2)}};l(pb,"renderSchemaForPrompt");l(mb,"describeSchema");l(tg,"describeField")});import rg from"node:fs/promises";import Ys from"node:path";var Xc,gb,og,ig=S(()=>{"use strict";Xt();Pt();V();q();Ct();Om();Nm();Jm();qm();Ym();zc();Hs();Xc=class{static{l(this,"PromptBuilder")}_checklistsCache=null;_checklistsCacheTime=0;_checklistRoutingCache=null;_checklistRoutingCacheTime=0;_stateCache=new Map;_stateCacheTTL=5e3;_templateCache=new Map;TEMPLATE_CACHE_TTL_MS=6e4;_coordinator=null;async getTemplate(e){let t=this._templateCache.get(e),s=Date.now();if(t&&s-t.loadedAt<this.TEMPLATE_CACHE_TTL_MS)return t.content;try{if(await C(e)){let n=await rg.readFile(e,"utf-8");return this._templateCache.set(e,{content:n,loadedAt:s}),n}}catch(n){R(n)||console.error(`Template loading warning: ${y(n)}`)}return null}clearTemplateCache(){this._templateCache.clear(),this._checklistsCache=null,this._checklistsCacheTime=0,this._checklistRoutingCache=null,this._checklistRoutingCacheTime=0}setCoordinator(e){this._coordinator=e}getCoordinator(){return this._coordinator}getEffectiveBudgets(){return this._coordinator?Xm(this._coordinator):qo}resetContext(){}setContext(e){}async loadModule(e){let t=yt(`global/modules/${e}`);if(t)return t;let s=Ys.join(Qe,"templates/global/modules",e);return this.getTemplate(s)}getModulesForCommand(e,t){return t?t.modules:[]}async loadChecklists(){let e=Date.now();if(this._checklistsCache&&e-this._checklistsCacheTime<this.TEMPLATE_CACHE_TTL_MS)return this._checklistsCache;let t={};try{let s=gn("checklists/");if(s.length>0){for(let n of s)if(n.endsWith(".md")){let o=yt(n);if(o){let i=Ys.basename(n,".md");t[i]=o}}}else{let n=Ys.join(Qe,"templates","checklists");if(await C(n)){let o=(await rg.readdir(n)).filter(i=>i.endsWith(".md"));for(let i of o){let a=i.replace(".md",""),c=Ys.join(n,i),u=await this.getTemplate(c);u&&(t[a]=u)}}}}catch(s){R(s)||console.error(`Checklist loading warning: ${y(s)}`)}return this._checklistsCache=t,this._checklistsCacheTime=e,t}async getProjectState(e){if(!e)return null;let t=this._stateCache.get(e);if(t&&Date.now()-t.timestamp<this._stateCacheTTL)return t.state;try{let[s,n]=await Promise.all([_.read(e),be.read(e)]),o={projectId:e,currentTask:s.currentTask,queue:n.tasks};return this._stateCache.set(e,{state:o,timestamp:Date.now()}),o}catch(s){if(R(s)||s instanceof SyntaxError)return null;throw s}}async buildInjectedContext(e){if(!e)return null;let t=await this.getProjectState(e);if(!t)return null;let s=[];if(s.push("## AUTO-INJECTED CONTEXT"),s.push(""),t.currentTask){let o=this.calculateElapsed(t.currentTask.startedAt);s.push(`**Current Task**: ${t.currentTask.description}`),s.push(`- Started: ${o} ago`)}else s.push("**Current Task**: None");if(s.push(""),t.queue.length>0){s.push(`**Queue**: ${t.queue.length} tasks pending`);let o=t.queue.slice(0,3);for(let i of o)s.push(`- [${i.priority}] ${i.description}`);t.queue.length>3&&s.push(`- ... and ${t.queue.length-3} more`)}s.push("");try{let o=await Mm.detectPatterns(e);if(o.length>0){s.push("**Project Conventions**");for(let i of o.slice(0,3))s.push(`- ${i.description}`),i.suggestedAction&&s.push(` \u2192 ${i.suggestedAction}`);s.push("")}}catch(o){!R(o)&&!(o instanceof SyntaxError)&&console.error(`Outcome detection warning: ${y(o)}`)}s.push("---"),s.push("");let n=s.join(`
711
- `);return Ir(n,this.getEffectiveBudgets().autoContext)}calculateElapsed(e){let t=new Date(e).getTime(),n=Date.now()-t,o=Math.floor(n/6e4),i=Math.floor(o/60),a=Math.floor(i/24);return a>0?`${a}d ${i%24}h`:i>0?`${i}h ${o%60}m`:`${o}m`}async loadChecklistRouting(){let e=Date.now();if(this._checklistRoutingCache&&e-this._checklistRoutingCacheTime<this.TEMPLATE_CACHE_TTL_MS)return this._checklistRoutingCache;let t=Ys.join(__dirname,"..","..","templates","agentic","checklist-routing.md"),s=await this.getTemplate(t);return s&&(this._checklistRoutingCache=s,this._checklistRoutingCacheTime=e),this._checklistRoutingCache||null}async buildWithInjection(e,t,s,n=null,o=null,i=null,a=null,c=null){let u=[];if(t.projectId){let m=await this.buildInjectedContext(t.projectId);m&&u.push(m)}let p=await this.build(e,t,s,n,o,i,a,c);return u.push(p),u.join("")}async build(e,t,s,n=null,o=null,i=null,a=null,c=null,u=null,p){let m=p?.skipNativeContext??!1,d=[],g=e.frontmatter?.name?.replace("p:","")||"",h;try{let D=await Vm();h=Bm(D,g,e).entry}catch{h={agents:!0,patterns:!0,checklist:!1,modules:[]}}let k=h.agents;n&&k&&(d.push(`# AGENT: ${n.name}
738
+ ${hb(e.schema)}`:null}function hb(r){if(r instanceof Ye.ZodObject){let e=r.shape;return Object.entries(e).map(([t,s])=>`- \`${t}\`: ${rg(s)}`).join(`
739
+ `)}return"(see example above)"}function rg(r){return r instanceof Ye.ZodString?"string":r instanceof Ye.ZodNumber?"number":r instanceof Ye.ZodEnum?`one of: ${r.options.join(", ")}`:r instanceof Ye.ZodArray?`array of ${rg(r.element)}`:r instanceof Ye.ZodObject?"object":"any"}var tg,sg,ng,ig=S(()=>{"use strict";qo();qo();tg=Ye.object({agentName:Ye.string(),reasoning:Ye.string(),confidence:Ye.number().min(0).max(1)}),sg=Ye.object({subtasks:Ye.array(Ye.object({description:Ye.string(),domain:Jo,agent:Ye.string(),dependsOn:Ye.array(Ye.number())})),effort:Ye.enum(["low","medium","high"])}),ng={classification:{schema:jn,example:JSON.stringify({primaryDomain:"backend",secondaryDomains:["database"],confidence:.9,filePatterns:["src/api/**"],relevantAgents:["backend.md"]},null,2)},agentAssignment:{schema:tg,example:JSON.stringify({agentName:"backend.md",reasoning:"Task involves API endpoint creation",confidence:.85},null,2)},subtaskBreakdown:{schema:sg,example:JSON.stringify({subtasks:[{description:"Add schema validation",domain:"backend",agent:"backend.md",dependsOn:[]},{description:"Add unit tests",domain:"testing",agent:"testing.md",dependsOn:[0]}],effort:"medium"},null,2)}};l(fb,"renderSchemaForPrompt");l(hb,"describeSchema");l(rg,"describeField")});import ag from"node:fs/promises";import Qs from"node:path";var Qc,yb,cg,lg=S(()=>{"use strict";Xt();Pt();W();K();Ct();Lm();Um();Km();Ym();eg();Kc();Hs();Qc=class{static{l(this,"PromptBuilder")}_checklistsCache=null;_checklistsCacheTime=0;_checklistRoutingCache=null;_checklistRoutingCacheTime=0;_stateCache=new Map;_stateCacheTTL=5e3;_templateCache=new Map;TEMPLATE_CACHE_TTL_MS=6e4;_coordinator=null;_healthMonitor=null;async getTemplate(e){let t=this._templateCache.get(e),s=Date.now();if(t&&s-t.loadedAt<this.TEMPLATE_CACHE_TTL_MS)return t.content;try{if(await P(e)){let n=await ag.readFile(e,"utf-8");return this._templateCache.set(e,{content:n,loadedAt:s}),n}}catch(n){R(n)||console.error(`Template loading warning: ${w(n)}`)}return null}clearTemplateCache(){this._templateCache.clear(),this._checklistsCache=null,this._checklistsCacheTime=0,this._checklistRoutingCache=null,this._checklistRoutingCacheTime=0}setCoordinator(e){this._coordinator=e}getCoordinator(){return this._coordinator}setHealthMonitor(e){this._healthMonitor=e}getHealthMonitor(){return this._healthMonitor}getEffectiveBudgets(){return this._coordinator?Zm(this._coordinator):Qo}resetContext(){}setContext(e){}async loadModule(e){let t=wt(`global/modules/${e}`);if(t)return t;let s=Qs.join(Ze,"templates/global/modules",e);return this.getTemplate(s)}getModulesForCommand(e,t){return t?t.modules:[]}async loadChecklists(){let e=Date.now();if(this._checklistsCache&&e-this._checklistsCacheTime<this.TEMPLATE_CACHE_TTL_MS)return this._checklistsCache;let t={};try{let s=fn("checklists/");if(s.length>0){for(let n of s)if(n.endsWith(".md")){let o=wt(n);if(o){let i=Qs.basename(n,".md");t[i]=o}}}else{let n=Qs.join(Ze,"templates","checklists");if(await P(n)){let o=(await ag.readdir(n)).filter(i=>i.endsWith(".md"));for(let i of o){let a=i.replace(".md",""),c=Qs.join(n,i),u=await this.getTemplate(c);u&&(t[a]=u)}}}}catch(s){R(s)||console.error(`Checklist loading warning: ${w(s)}`)}return this._checklistsCache=t,this._checklistsCacheTime=e,t}async getProjectState(e){if(!e)return null;let t=this._stateCache.get(e);if(t&&Date.now()-t.timestamp<this._stateCacheTTL)return t.state;try{let[s,n]=await Promise.all([_.read(e),be.read(e)]),o={projectId:e,currentTask:s.currentTask,queue:n.tasks};return this._stateCache.set(e,{state:o,timestamp:Date.now()}),o}catch(s){if(R(s)||s instanceof SyntaxError)return null;throw s}}async buildInjectedContext(e){if(!e)return null;let t=await this.getProjectState(e);if(!t)return null;let s=[];if(s.push("## AUTO-INJECTED CONTEXT"),s.push(""),t.currentTask){let o=this.calculateElapsed(t.currentTask.startedAt);s.push(`**Current Task**: ${t.currentTask.description}`),s.push(`- Started: ${o} ago`)}else s.push("**Current Task**: None");if(s.push(""),t.queue.length>0){s.push(`**Queue**: ${t.queue.length} tasks pending`);let o=t.queue.slice(0,3);for(let i of o)s.push(`- [${i.priority}] ${i.description}`);t.queue.length>3&&s.push(`- ... and ${t.queue.length-3} more`)}s.push("");try{let o=await Nm.detectPatterns(e);if(o.length>0){s.push("**Project Conventions**");for(let i of o.slice(0,3))s.push(`- ${i.description}`),i.suggestedAction&&s.push(` \u2192 ${i.suggestedAction}`);s.push("")}}catch(o){!R(o)&&!(o instanceof SyntaxError)&&console.error(`Outcome detection warning: ${w(o)}`)}s.push("---"),s.push("");let n=s.join(`
740
+ `);return Mr(n,this.getEffectiveBudgets().autoContext)}calculateElapsed(e){let t=new Date(e).getTime(),n=Date.now()-t,o=Math.floor(n/6e4),i=Math.floor(o/60),a=Math.floor(i/24);return a>0?`${a}d ${i%24}h`:i>0?`${i}h ${o%60}m`:`${o}m`}async loadChecklistRouting(){let e=Date.now();if(this._checklistRoutingCache&&e-this._checklistRoutingCacheTime<this.TEMPLATE_CACHE_TTL_MS)return this._checklistRoutingCache;let t=Qs.join(__dirname,"..","..","templates","agentic","checklist-routing.md"),s=await this.getTemplate(t);return s&&(this._checklistRoutingCache=s,this._checklistRoutingCacheTime=e),this._checklistRoutingCache||null}async buildWithInjection(e,t,s,n=null,o=null,i=null,a=null,c=null){let u=[];if(t.projectId){let m=await this.buildInjectedContext(t.projectId);m&&u.push(m)}let p=await this.build(e,t,s,n,o,i,a,c);return u.push(p),u.join("")}async build(e,t,s,n=null,o=null,i=null,a=null,c=null,u=null,p){let m=p?.skipNativeContext??!1,d=[],g=e.frontmatter?.name?.replace("p:","")||"",h;try{let E=await zm();h=qm(E,g,e).entry}catch{h={agents:!0,patterns:!0,checklist:!1,modules:[]}}let k=h.agents;n&&k&&(d.push(`# AGENT: ${n.name}
712
741
  `),n.role&&d.push(`Role: ${n.role}
713
742
  `),n.skills?.length&&d.push(`Skills: ${n.skills.join(", ")}
714
743
  `),d.push(`
@@ -716,100 +745,117 @@ Apply specialized expertise. Read agent file for details if needed.
716
745
 
717
746
  `)),d.push(`TASK: ${e.frontmatter.description}
718
747
  `),e.frontmatter["allowed-tools"]&&d.push(`TOOLS: ${e.frontmatter["allowed-tools"].join(", ")}
719
- `);let w=t;(w.params?.task||w.params?.description)&&d.push(`INPUT: ${w.params.task||w.params.description}
720
- `);let T=t.projectPath;if(T){let D=u?.project?.id?Ys.basename(T):Ys.basename(T),O=zm({projectName:D,projectPath:T,isGitRepo:!0,gitBranch:u?.realContext?.gitBranch});d.push(`
721
- ${O}
722
- `)}if(u){let D=u.sealedAnalysis;if(d.push(`
748
+ `);let y=t;(y.params?.task||y.params?.description)&&d.push(`INPUT: ${y.params.task||y.params.description}
749
+ `);let v=t.projectPath;if(v){let E=u?.project?.id?Qs.basename(v):Qs.basename(v),M=Xm({projectName:E,projectPath:v,isGitRepo:!0,gitBranch:u?.realContext?.gitBranch});d.push(`
750
+ ${M}
751
+ `)}if(u){let E=u.sealedAnalysis;if(d.push(`
723
752
  ## PROJECT ANALYSIS (Sealed)
724
753
  `),d.push(`**Ecosystem**: ${u.project.ecosystem}
725
754
  `),d.push(`**Primary Domain**: ${u.primaryDomain}
726
755
  `),d.push(`**Domains**: ${u.detectedDomains.join(", ")}
727
- `),D&&(D.languages?.length>0&&d.push(`**Languages**: ${D.languages.join(", ")}
728
- `),D.frameworks?.length>0&&d.push(`**Frameworks**: ${D.frameworks.join(", ")}
729
- `),D.packageManager&&d.push(`**Package Manager**: ${D.packageManager}
730
- `),D.sourceDir&&d.push(`**Source Dir**: ${D.sourceDir}
731
- `),D.testDir&&d.push(`**Test Dir**: ${D.testDir}
732
- `),d.push(`**Files Analyzed**: ${D.fileCount}
733
- `),d.push(`**Analysis Status**: ${D.status}${D.commitHash?` (commit: ${D.commitHash.slice(0,8)})`:""}
734
- `),!m)){if(D.patterns?.length>0){d.push(`
756
+ `),E&&(E.languages?.length>0&&d.push(`**Languages**: ${E.languages.join(", ")}
757
+ `),E.frameworks?.length>0&&d.push(`**Frameworks**: ${E.frameworks.join(", ")}
758
+ `),E.packageManager&&d.push(`**Package Manager**: ${E.packageManager}
759
+ `),E.sourceDir&&d.push(`**Source Dir**: ${E.sourceDir}
760
+ `),E.testDir&&d.push(`**Test Dir**: ${E.testDir}
761
+ `),d.push(`**Files Analyzed**: ${E.fileCount}
762
+ `),d.push(`**Analysis Status**: ${E.status}${E.commitHash?` (commit: ${E.commitHash.slice(0,8)})`:""}
763
+ `),!m)){if(E.patterns?.length>0){d.push(`
735
764
  ### Code Patterns (Follow These)
736
- `);for(let O of D.patterns)d.push(`- **${O.name}**: ${O.description}${O.location?` (${O.location})`:""}
737
- `)}if(D.antiPatterns?.length>0){d.push(`
765
+ `);for(let M of E.patterns)d.push(`- **${M.name}**: ${M.description}${M.location?` (${M.location})`:""}
766
+ `)}if(E.antiPatterns?.length>0){d.push(`
738
767
  ### Anti-Patterns (Avoid These)
739
- `);for(let O of D.antiPatterns)d.push(`- **${O.issue}** in \`${O.file}\` \u2014 ${O.suggestion}
768
+ `);for(let M of E.antiPatterns)d.push(`- **${M.issue}** in \`${M.file}\` \u2014 ${M.suggestion}
740
769
  `)}}d.push(`
741
- `)}if(!m){let D=h.patterns,O=s?.codePatterns||"";if(D&&O&&O.trim()){let rt=this.extractPatternSummary(O);rt&&(d.push(`## CODE PATTERNS
742
- `),d.push(rt),d.push(`
770
+ `)}if(!m){let E=h.patterns,M=s?.codePatterns||"";if(E&&M&&M.trim()){let Me=this.extractPatternSummary(M);Me&&(d.push(`## CODE PATTERNS
771
+ `),d.push(Me),d.push(`
743
772
  Full patterns: Read analysis/patterns.md
744
- `))}let ne=s?.analysis||"";if(D&&ne&&ne.trim()){let rt=ne.match(/Stack[:\s]+([^\n]+)/i)||ne.match(/Technology[:\s]+([^\n]+)/i),K=rt?rt[1].trim():"detected";d.push(`
773
+ `))}let se=s?.analysis||"";if(E&&se&&se.trim()){let Me=se.match(/Stack[:\s]+([^\n]+)/i)||se.match(/Technology[:\s]+([^\n]+)/i),q=Me?Me[1].trim():"detected";d.push(`
745
774
  ## STACK
746
- Stack: ${K}
747
- `),O||d.push(`Read analysis/repo-summary.md + similar files before coding. Match patterns exactly.
748
- `)}}let E=this.getModulesForCommand(g,h);if(E.length>0)for(let D of E){let O=await this.loadModule(D);O&&(d.push(`
749
- `),d.push(O))}if(c?.isPlanning&&(d.push(`
775
+ Stack: ${q}
776
+ `),M||d.push(`Read analysis/repo-summary.md + similar files before coding. Match patterns exactly.
777
+ `)}}let D=this.getModulesForCommand(g,h);if(D.length>0)for(let E of D){let M=await this.loadModule(E);M&&(d.push(`
778
+ `),d.push(M))}if(c?.isPlanning&&(d.push(`
750
779
  ## PLAN MODE
751
780
  Read-only. Gather info \u2192 Analyze \u2192 Propose plan \u2192 Wait for approval.
752
781
  `),c.allowedTools&&d.push(`Tools: ${c.allowedTools.join(", ")}
753
782
  `)),c?.requiresApproval&&d.push(`
754
783
  ## APPROVAL REQUIRED
755
784
  Show changes, list affected files, ask for confirmation.
756
- `),T){let D=u?.sealedAnalysis,O=[...D?.frameworks||[],...Array.isArray(u?.project?.conventions)?u.project.conventions:[]],ne={projectPath:T,language:u?.project?.ecosystem,framework:D?.frameworks?.[0],techStack:Jo(O),domains:this.extractDomains(s),fileCount:t.files?.length||t.filteredSize||0,analysisLanguages:D?.languages||[],analysisFrameworks:D?.frameworks||[],analysisPackageManager:D?.packageManager};d.push(`
757
- ${_m(ne)}
758
- `)}else d.push(this.buildCriticalRules());if(u?.contextDegradation?.level!=="full"&&u?.contextDegradation){let D=u.contextDegradation;d.push(`
785
+ `),v){let E=u?.sealedAnalysis,M=[...E?.frameworks||[],...Array.isArray(u?.project?.conventions)?u.project.conventions:[]],se={projectPath:v,language:u?.project?.ecosystem,framework:E?.frameworks?.[0],techStack:Xo(M),domains:this.extractDomains(s),fileCount:t.files?.length||t.filteredSize||0,analysisLanguages:E?.languages||[],analysisFrameworks:E?.frameworks||[],analysisPackageManager:E?.packageManager};d.push(`
786
+ ${Fm(se)}
787
+ `)}else d.push(this.buildCriticalRules());if(u?.contextDegradation?.level!=="full"&&u?.contextDegradation){let E=u.contextDegradation;d.push(`
759
788
  ### CONTEXT DEGRADATION NOTICE
760
789
 
761
- `),d.push(`**Level**: ${D.level}
762
- `),d.push(`**Unavailable**: ${D.failedTools.join(", ")}
790
+ `),d.push(`**Level**: ${E.level}
791
+ `),d.push(`**Unavailable**: ${E.failedTools.join(", ")}
763
792
  `),d.push(`Some context tools failed. Explore the codebase manually for missing context.
764
793
 
765
- `)}if(u?.realContext){let D=u.realContext;if(d.push(`
794
+ `)}if(u?.realContext){let E=u.realContext;if(d.push(`
766
795
  ### CODEBASE CONTEXT
767
796
 
768
- `),d.push(`**Git State**: Branch \`${D.gitBranch}\` | ${D.gitStatus}
797
+ `),d.push(`**Git State**: Branch \`${E.gitBranch}\` | ${E.gitStatus}
769
798
 
770
- `),D.relevantFiles.length>0){d.push(`**Relevant Files** (scored by task relevance):
799
+ `),E.relevantFiles.length>0){d.push(`**Relevant Files** (scored by task relevance):
771
800
  `),d.push(`| Score | File | Why |
772
801
  `),d.push(`|-------|------|-----|
773
- `);for(let O of D.relevantFiles.slice(0,8))d.push(`| ${O.score} | ${O.path} | ${O.reason} |
802
+ `);for(let M of E.relevantFiles.slice(0,8))d.push(`| ${M.score} | ${M.path} | ${M.reason} |
774
803
  `);d.push(`
775
- `)}if(D.signatures.length>0){d.push(`**Code Signatures** (top files):
776
- `);for(let O of D.signatures)d.push(`\`\`\`typescript
777
- // ${O.path}
778
- ${O.content}
804
+ `)}if(E.signatures.length>0){d.push(`**Code Signatures** (top files):
805
+ `);for(let M of E.signatures)d.push(`\`\`\`typescript
806
+ // ${M.path}
807
+ ${M.content}
779
808
  \`\`\`
780
809
  `);d.push(`
781
- `)}if(D.recentFiles.length>0){d.push("**Recently Changed**: ");let O=D.recentFiles.slice(0,5).map(ne=>`${ne.path} (${ne.lastChanged})`).join(", ");d.push(`${O}
810
+ `)}if(E.recentFiles.length>0){d.push("**Recently Changed**: ");let M=E.recentFiles.slice(0,5).map(se=>`${se.path} (${se.lastChanged})`).join(", ");d.push(`${M}
782
811
 
783
- `)}}let M=t.files||[];if(M.length>0){let D=M.slice(0,5).join(", ");d.push(`
784
- ## FILES: ${M.length} available. Top: ${D}
812
+ `)}}let U=t.files||[];if(U.length>0){let E=U.slice(0,5).join(", ");d.push(`
813
+ ## FILES: ${U.length} available. Top: ${E}
785
814
  `),d.push(`Read BEFORE modifying. Use Glob/Grep to find more.
786
815
 
787
- `)}else T&&d.push(`
788
- ## PROJECT: ${T}
816
+ `)}else v&&d.push(`
817
+ ## PROJECT: ${v}
789
818
  Read files before modifying.
790
819
 
791
- `);let L=this.filterRelevantState(s);if(L&&(d.push(`
820
+ `);let F=this.filterRelevantState(s);if(F&&(d.push(`
792
821
  ## PRJCT STATE (Project Management Data)
793
- `),d.push(L),d.push(`
822
+ `),d.push(F),d.push(`
794
823
  `)),u?.velocityContext&&(d.push(`
795
824
  ### VELOCITY (Historical Estimation Data)
796
825
 
797
826
  `),d.push(u.velocityContext),d.push(`
798
827
 
799
- `)),o&&Object.keys(o).some(D=>o[D])){d.push(`
828
+ `)),o&&Object.keys(o).some(E=>o[E])){d.push(`
800
829
  ## PROJECT DEFAULTS (apply automatically)
801
- `);for(let[D,O]of Object.entries(o))O&&d.push(`- ${D}: ${O}
830
+ `);for(let[E,M]of Object.entries(o))M&&d.push(`- ${E}: ${M}
802
831
  `)}if(i?.plan&&i.plan.length>0){if(d.push(`
803
832
  ## THINK FIRST (reasoning from analysis)
804
833
  `),i.conclusions&&i.conclusions.length>0){d.push(`Conclusions:
805
- `);for(let D of i.conclusions)d.push(` \u2192 ${D}
834
+ `);for(let E of i.conclusions)d.push(` \u2192 ${E}
806
835
  `)}d.push(`Plan:
807
- `);for(let D=0;D<i.plan.length;D++)d.push(` ${D+1}. ${i.plan[D]}
836
+ `);for(let E=0;E<i.plan.length;E++)d.push(` ${E+1}. ${i.plan[E]}
808
837
  `);d.push(`Confidence: ${Math.round((i.confidence||.5)*100)}%
809
838
  `)}if(a&&a.length>0){d.push(`
810
839
  ## CONTEXT (apply these)
811
- `);for(let D of a)d.push(`- **${D.title}**: ${D.content}
812
- `),D.tags&&D.tags.length>0&&d.push(` Tags: ${D.tags.join(", ")}
840
+ `);for(let E of a)d.push(`- **${E.title}**: ${E.content}
841
+ `),E.tags&&E.tags.length>0&&d.push(` Tags: ${E.tags.join(", ")}
842
+ `)}if(u?.rpiContext){let E=u.rpiContext;switch(d.push(`
843
+ ### RPI PHASE
844
+
845
+ `),E.phase){case"research":d.push(`**Phase: RESEARCH** \u2014 Explore the codebase. Produce a truth snapshot: exact files + lines, function call chains, test locations. Use sub-agents for broad exploration.
846
+ `);break;case"plan":d.push(`**Phase: PLAN** \u2014 Create an implementation plan with real code snippets. Reference exact files and line numbers from research.
847
+ `),E.researchDoc&&d.push(`
848
+ <research-context>
849
+ ${E.researchDoc}
850
+ </research-context>
851
+ `);break;case"implement":d.push(`**Phase: IMPLEMENT** \u2014 Execute the plan. Minimal exploration. Work only with the scoped files below.
852
+ `),E.planDoc&&d.push(`
853
+ <plan-context>
854
+ ${E.planDoc}
855
+ </plan-context>
856
+ `),E.scopedFiles&&E.scopedFiles.length>0&&d.push(`
857
+ **Scoped Files**: ${E.scopedFiles.map(M=>`\`${M}\``).join(", ")}
858
+ `);break}d.push(`
813
859
  `)}if(d.push(`
814
860
  ---
815
861
  `),d.push(e.content),u?.requiresFragmentation&&u.subtasks){d.push(`
@@ -817,34 +863,34 @@ Read files before modifying.
817
863
 
818
864
  `),d.push("**IMPORTANT**: Focus on the CURRENT subtask. Use `p. done` when complete to advance.\n\n"),d.push(`| # | Domain | Description | Status |
819
865
  `),d.push(`|---|--------|-------------|--------|
820
- `);for(let O of u.subtasks){let ne=O.status==="in_progress"?"\u25B6\uFE0F **CURRENT**":O.status==="completed"?"\u2705 Done":O.status==="failed"?"\u274C Failed":"\u23F3 Pending";d.push(`| ${O.order} | ${O.domain} | ${O.description} | ${ne} |
821
- `)}let D=u.subtasks.find(O=>O.status==="in_progress");if(D&&(d.push(`
822
- **FOCUS ON SUBTASK #${D.order}**: ${D.description}
823
- `),d.push(`Agent: ${D.agent} | Domain: ${D.domain}
824
- `),D.dependsOn.length>0&&d.push(`Dependencies: ${D.dependsOn.join(", ")}
825
- `),D.handoff)){let O=D.handoff;d.push(`
866
+ `);for(let M of u.subtasks){let se=M.status==="in_progress"?"\u25B6\uFE0F **CURRENT**":M.status==="completed"?"\u2705 Done":M.status==="failed"?"\u274C Failed":"\u23F3 Pending";d.push(`| ${M.order} | ${M.domain} | ${M.description} | ${se} |
867
+ `)}let E=u.subtasks.find(M=>M.status==="in_progress");if(E&&(d.push(`
868
+ **FOCUS ON SUBTASK #${E.order}**: ${E.description}
869
+ `),d.push(`Agent: ${E.agent} | Domain: ${E.domain}
870
+ `),E.dependsOn.length>0&&d.push(`Dependencies: ${E.dependsOn.join(", ")}
871
+ `),E.handoff)){let M=E.handoff;d.push(`
826
872
  ### Previous Subtask Handoff
827
873
 
828
- `),d.push(`**From:** ${O.fromSubtask}
874
+ `),d.push(`**From:** ${M.fromSubtask}
829
875
 
830
876
  `),d.push(`**What was done:**
831
- `);for(let ne of O.whatWasDone)d.push(`- ${ne}
832
- `);if(O.filesChanged.length>0){d.push(`
877
+ `);for(let se of M.whatWasDone)d.push(`- ${se}
878
+ `);if(M.filesChanged.length>0){d.push(`
833
879
  **Files changed:**
834
- `);for(let ne of O.filesChanged)d.push(`- \`${ne.path}\` (${ne.action})
880
+ `);for(let se of M.filesChanged)d.push(`- \`${se.path}\` (${se.action})
835
881
  `)}d.push(`
836
882
  **Context for this subtask:**
837
- ${O.outputForNextAgent}
883
+ ${M.outputForNextAgent}
838
884
  `)}d.push(`
839
- `)}let $=this.getSchemaTypeForCommand(g);if($){let{renderSchemaForPrompt:D}=await Promise.resolve().then(()=>(ng(),sg)),O=D($);O&&d.push(`
840
- ${O}
841
- `)}if(h.checklist){let D=await this.loadChecklistRouting(),O=await this.loadChecklists();D&&Object.keys(O).length>0&&(d.push(`
885
+ `)}let j=this.getSchemaTypeForCommand(g);if(j){let{renderSchemaForPrompt:E}=await Promise.resolve().then(()=>(ig(),og)),M=E(j);M&&d.push(`
886
+ ${M}
887
+ `)}if(h.checklist){let E=await this.loadChecklistRouting(),M=await this.loadChecklists();E&&Object.keys(M).length>0&&(d.push(`
842
888
  ## QUALITY CHECKLISTS
843
889
  `),d.push(`Apply relevant checklists based on task. Read checklist-routing.md for guidance.
844
- `),d.push(`Available: ${Object.keys(O).join(", ")}
890
+ `),d.push(`Available: ${Object.keys(M).join(", ")}
845
891
  `),d.push(`Path: templates/checklists/{name}.md
846
892
  `),d.push(`Use Read tool to load checklists you determine are relevant.
847
- `))}return d.push(this.buildEfficiencyDirective()),d.join("")}filterRelevantState(e){if(!e||Object.keys(e).length===0)return null;let t=this.getEffectiveBudgets(),s=new zo({totalPrompt:t.stateData}),n=["now","next","context","analysis","codePatterns"],o=[];for(let[i,a]of Object.entries(e))if(a&&a.trim()){let c=n.includes(i)?500:250,u=s.addSection(`### ${i}
893
+ `))}return d.push(this.buildEfficiencyDirective()),d.join("")}filterRelevantState(e){if(!e||Object.keys(e).length===0)return null;let t=this.getEffectiveBudgets(),s=new Yo({totalPrompt:t.stateData}),n=["now","next","context","analysis","codePatterns"],o=[];for(let[i,a]of Object.entries(e))if(a&&a.trim()){let c=n.includes(i)?500:250,u=s.addSection(`### ${i}
848
894
  ${a}`,c);u&&o.push(u)}return o.length>0?o.join(`
849
895
 
850
896
  `):null}buildAnalysis(e,t){let s=[];return s.push(`# Analyze: ${e}
@@ -861,7 +907,16 @@ ${a}`,c);u&&o.push(u)}return o.length>0?o.join(`
861
907
  `);a&&t.push(a)}let n=e.match(/### High Priority[\s\S]*?(?=###|##|$)/i);if(n){let a=n[0].substring(0,300);t.push(`
862
908
  Avoid:
863
909
  ${a}`)}let o=t.join(`
864
- `);return Ir(o,200)||null}getSchemaTypeForCommand(e){return{task:"subtaskBreakdown",bug:"classification"}[e]??null}buildCriticalRules(){return""}buildEfficiencyDirective(){return""}extractDomains(e){if(!e)return;let t=e;if(t.domains&&typeof t.domains=="object"){let s=t.domains;return{hasFrontend:s.hasFrontend??!1,hasBackend:s.hasBackend??!1,hasDatabase:s.hasDatabase??!1,hasTesting:s.hasTesting??!1,hasDocker:s.hasDocker??!1}}}},gb=new Xc,og=gb});import Ps from"node:path";var Yc,fb,Ko,ag=S(()=>{"use strict";xc();Et();ve();Yc=class{static{l(this,"TemplateExecutor")}async getNpmRoot(){return Ps.dirname(St.resolve("prjct-cli/package.json"))}async getProjectId(e){return I.getProjectId(e)}async buildContext(e,t,s){let n=await this.getProjectId(s),o=A.getGlobalProjectPath(n),a=await(it(),bt(Tt)).getActiveProvider(),c;try{let u=await this.getNpmRoot();c=Ps.join(u,"templates")}catch{c=Ps.join(__dirname,"..","..","templates")}return{projectPath:s,projectId:n,globalPath:o,command:e,args:t,agentName:a.displayName,agentSettingsPath:await A.getAgentSettingsPath(),paths:{orchestrator:Ps.join(c,"agentic","orchestrator.md"),taskFragmentation:Ps.join(c,"agentic","task-fragmentation.md"),commandTemplate:Ps.join(c,"commands",`${e}.md`),repoAnalysis:Ps.join(o,"analysis","repo-analysis.json"),skillsDir:a.skillsDir,stateJson:Ps.join(o,"storage","state.json")}}}requiresOrchestration(e){return Yp.includes(e)?!0:!Qp.includes(e)}buildAgenticPrompt(e){let t=this.requiresOrchestration(e.command);return{prompt:`
910
+ `);return Mr(o,200)||null}getSchemaTypeForCommand(e){return{task:"subtaskBreakdown",bug:"classification"}[e]??null}buildCriticalRules(){return""}buildEfficiencyDirective(){let e=[];if(e.push(`
911
+ ## EFFICIENCY
912
+ `),e.push(`- Be concise. No preamble, no filler.
913
+ `),e.push(`- Use sub-agents for exploration that produces >5 file reads.
914
+ `),e.push(`- Prefer file:line references over dumping full file contents.
915
+ `),this._healthMonitor){let t=this._healthMonitor.getStatus();t.zone==="warning"?e.push(`
916
+ **CONTEXT WARNING** (${Math.round(t.usagePercent)}% used): Use sub-agents for all exploration. Consider compacting conversation.
917
+ `):t.zone==="dumb"&&e.push(`
918
+ **CONTEXT CRITICAL** (${Math.round(t.usagePercent)}% used): STOP expanding context. Work only with referenced files. Compact now.
919
+ `),this._healthMonitor.checkTransition()}return e.join("")}extractDomains(e){if(!e)return;let t=e;if(t.domains&&typeof t.domains=="object"){let s=t.domains;return{hasFrontend:s.hasFrontend??!1,hasBackend:s.hasBackend??!1,hasDatabase:s.hasDatabase??!1,hasTesting:s.hasTesting??!1,hasDocker:s.hasDocker??!1}}}},yb=new Qc,cg=yb});import Ps from"node:path";var Zc,wb,Zo,ug=S(()=>{"use strict";Ac();Et();Te();Zc=class{static{l(this,"TemplateExecutor")}async getNpmRoot(){return Ps.dirname(bt.resolve("prjct-cli/package.json"))}async getProjectId(e){return $.getProjectId(e)}async buildContext(e,t,s){let n=await this.getProjectId(s),o=A.getGlobalProjectPath(n),a=await(at(),ot(vt)).getActiveProvider(),c;try{let u=await this.getNpmRoot();c=Ps.join(u,"templates")}catch{c=Ps.join(__dirname,"..","..","templates")}return{projectPath:s,projectId:n,globalPath:o,command:e,args:t,agentName:a.displayName,agentSettingsPath:await A.getAgentSettingsPath(),paths:{orchestrator:Ps.join(c,"agentic","orchestrator.md"),taskFragmentation:Ps.join(c,"agentic","task-fragmentation.md"),commandTemplate:Ps.join(c,"commands",`${e}.md`),repoAnalysis:Ps.join(o,"analysis","repo-analysis.json"),skillsDir:a.skillsDir,stateJson:Ps.join(o,"storage","state.json")}}}requiresOrchestration(e){return em.includes(e)?!0:!tm.includes(e)}buildAgenticPrompt(e){let t=this.requiresOrchestration(e.command);return{prompt:`
865
920
  ## Agentic Execution Mode
866
921
 
867
922
  You are executing a prjct command as ${e.agentName}. Follow the template-first approach.
@@ -891,13 +946,13 @@ ${t?`
891
946
  2. **Execute the command template directly**
892
947
  `}
893
948
  3. **Return results**
894
- `,context:e,requiresOrchestration:t}}},fb=new Yc,Ko=fb});function $r(r){if(!r||typeof r!="object")return!1;let e=r;if(e.code&&hb.has(e.code))return!0;if(e.code&&lg.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 Yo(r){if(!r||typeof r!="object")return!1;let e=r;return!!(e.code&&lg.has(e.code))}function cg(r,e,t){let s=Es.get(r);return s&&s.consecutiveFailures>=e&&s.openedAt?Date.now()-s.openedAt>=t?(Es.delete(r),!1):!0:!1}function Qc(r,e){let t=Es.get(r)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),Es.set(r,t)}function yb(r){Es.delete(r)}var hb,lg,Es,Xo,ug,Qo,Zc=S(()=>{"use strict";hb=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),lg=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);l($r,"isTransientError");l(Yo,"isPermanentError");Es=new Map;l(cg,"isCircuitOpen");l(Qc,"recordFailure");l(yb,"recordSuccess");Xo=class{static{l(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(cg(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let s,n=0;for(;n<this.options.maxAttempts;)try{let o=await e();return yb(t),o}catch(o){if(s=o,n++,Yo(o))throw Qc(t,this.options.circuitBreakerThreshold),o;if(!($r(o)&&n<this.options.maxAttempts))throw Qc(t,this.options.circuitBreakerThreshold),o;let a=Math.min(this.options.baseDelayMs*2**(n-1),this.options.maxDelayMs);await new Promise(c=>setTimeout(c,a))}throw Qc(t,this.options.circuitBreakerThreshold),s}isTransientError(e){return $r(e)}isCircuitOpen(e){return cg(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return Es.get(e)}resetCircuit(e){Es.delete(e)}resetAllCircuits(){Es.clear()}},ug=new Xo({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),Qo=new Xo({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});import dg from"node:fs/promises";var Qs,st,el=S(()=>{"use strict";Ue();Zc();Qs={tools:new Map,register(r,e){this.tools.set(r,e)},get(r){return this.tools.get(r)},isAllowed(r,e){return!e||e.length===0?!0:e.some(t=>t.endsWith("*")?r.startsWith(t.slice(0,-1)):r===t)},list(){return Array.from(this.tools.keys())}};Qs.register("Read",async r=>{try{return await Qo.execute(async()=>await dg.readFile(r,"utf-8"),`read-${r}`)}catch(e){return Yo(e)||$r(e),null}});Qs.register("Write",async(r,e)=>{try{return await Qo.execute(async()=>await dg.writeFile(r,e,"utf-8"),`write-${r}`),!0}catch(t){return Yo(t)||$r(t),!1}});Qs.register("Bash",async r=>{try{return await Qo.execute(async()=>await N(r),`bash-${r}`)}catch(e){let t=e;return{stdout:t.stdout||"",stderr:t.stderr||t.message||"Command failed"}}});Qs.register("GetTimestamp",async()=>new Date().toISOString());Qs.register("GetDate",async()=>new Date().toISOString().split("T")[0]);Qs.register("GetDateTime",async()=>new Date().toISOString());st=Qs});import tl from"node:fs/promises";import wb from"node:os";import sl from"node:path";function pg(){let r=process.env.PRJCT_CLI_HOME?.trim()||sl.join(wb.homedir(),".prjct-cli");return sl.join(r,".running")}async function kb(r){try{let e=pg(),t=sl.dirname(e);await C(t)||await tl.mkdir(t,{recursive:!0}),await tl.writeFile(e,`/p:${r}`)}catch{}}async function Sb(){try{let r=pg();await C(r)&&await tl.unlink(r)}catch{}}var nl,bb,Zo,rl=S(()=>{"use strict";V();zp();q();Xp();Zp();Ac();dm();pm();mr();Wc();$m();ig();ag();Hs();el();l(pg,"getRunningFilePath");l(kb,"signalStart");l(Sb,"signalEnd");nl=class{static{l(this,"CommandExecutor")}async signalStart(e){await kb(e)}async signalEnd(){await Sb()}async execute(e,t,s){await this.signalStart(e);let n=t.task||t.description||"";if(Rn.shouldEscalate(e,n)){let o=Rn.getEscalationInfo(e,n);return await this.signalEnd(),{success:!1,error:o?.message,escalation:o,isLoopDetected:!0,suggestion:o?.suggestion}}try{let o=await na.load(e),i=await Ht.build(s,t),a=Ge.requiresPlanning(e),c=Ge.isDestructive(e),u=Ge.isInPlanningMode(i.projectId),p=null;a&&!u&&!t.skipPlanning?p=Ge.startPlanning(i.projectId,e,t):u&&(p=Ge.getActivePlan(i.projectId));let m=null;if(Fo.requiresVerification(e)){let K=await Ht.loadStateForCommand(i,e);m=await Fo.verify(e,i,K),!m.verified&&m.warnings.length>0&&console.log(Fo.formatWarnings(m))}let d=null;if(No.requiresReasoning(e)){let K=await Ht.loadStateForCommand(i,e);d=await No.reason(e,i,K),d.reasoning&&!d.reasoning.allPassed&&(console.log("\u26A0\uFE0F Chain of Thought detected issues:"),console.log(No.formatPlan(d)))}let g=t.task||t.description||"",h=await Ko.buildContext(e,g,s),k=Ko.buildAgenticPrompt(h),w=null;if(Ko.requiresOrchestration(e)&&g)try{if(w=await Bo.execute(e,g,s),w.detectedDomains.length>0&&Jp.orchestrate(w.detectedDomains),w.requiresFragmentation&&w.subtasks){let K=w.subtasks.map(dt=>({id:dt.id,domain:dt.domain,description:dt.description,status:dt.status}));Kp(K)}}catch(K){console.warn(`\u26A0\uFE0F Orchestrator warning: ${y(K)}`)}let T={...i,orchestratorPath:h.paths.orchestrator,taskFragmentationPath:h.paths.taskFragmentation,agenticDelegation:!0,agenticMode:!0},E=await Ht.loadState(i),M=null,L=null;i.projectId&&(M={commit_footer:await at.getSmartDecision(i.projectId,"commit_footer"),branch_naming:await at.getSmartDecision(i.projectId,"branch_naming"),test_before_ship:await at.getSmartDecision(i.projectId,"test_before_ship"),preferred_agent:await at.getSmartDecision(i.projectId,`preferred_agent_${e}`)},L=await at.getRelevantMemories(i.projectId,{commandName:e,params:t},5));let $={isPlanning:a||u,requiresApproval:c&&!t.approved,active:p,allowedTools:Ge.getAllowedTools(u,o.frontmatter["allowed-tools"]||[])},ne=(await(it(),bt(Tt)).getActiveProvider()).name==="claude",rt=await og.build(o,T,E,null,M,null,L,$,w,{skipNativeContext:ne});return console.log("\u{1F916} Template-first execution: Claude reads templates and decides"),k.requiresOrchestration&&console.log(` \u2192 Orchestration: ${h.paths.orchestrator}`),Rn.recordSuccess(e,n),await this.signalEnd(),{success:!0,template:o,context:T,state:E,prompt:rt,agenticDelegation:!0,agenticMode:!0,agenticExecContext:h,agenticPrompt:k.prompt,requiresOrchestration:k.requiresOrchestration,orchestratorPath:h.paths.orchestrator,taskFragmentationPath:h.paths.taskFragmentation,reasoning:d,groundTruth:m,learnedPatterns:M,relevantMemories:L,orchestratorContext:w,memory:{create:l(K=>at.createMemory(i.projectId,K),"create"),autoRemember:l((K,dt,ms)=>at.autoRemember(i.projectId,K,dt,ms),"autoRemember"),search:l(K=>at.searchMemories(i.projectId,K),"search"),findByTags:l(K=>at.findByTags(i.projectId,K),"findByTags"),getStats:l(()=>at.getMemoryStats(i.projectId),"getStats")},plan:{active:p,isPlanning:a||u,isDestructive:c,requiresApproval:c&&!t.approved,recordInfo:l(K=>Ge.recordGatheredInfo(i.projectId,K),"recordInfo"),setAnalysis:l(K=>Ge.setAnalysis(i.projectId,K),"setAnalysis"),propose:l(K=>Ge.proposePlan(i.projectId,K),"propose"),approve:l(K=>Ge.approvePlan(i.projectId,K),"approve"),reject:l(K=>Ge.rejectPlan(i.projectId,K),"reject"),getApprovalPrompt:l(()=>Ge.generateApprovalPrompt(e,{changedFiles:[],filesToDelete:[],operation:e==="ship"?"git_push":e==="cleanup"?"delete_files":"run_command",warnings:[]}),"getApprovalPrompt"),startExecution:l(()=>Ge.startExecution(i.projectId),"startExecution"),getNextStep:l(()=>Ge.getNextStep(i.projectId),"getNextStep"),completeStep:l(K=>Ge.completeStep(i.projectId,K),"completeStep"),failStep:l(K=>Ge.failStep(i.projectId,K),"failStep"),abort:l(K=>Ge.abortPlan(i.projectId,K),"abort"),getStatus:l(()=>Ge.formatStatus(i.projectId),"getStatus"),getAllowedTools:l(()=>Ge.getAllowedTools(u,o.frontmatter["allowed-tools"]||[]),"getAllowedTools")}}}catch(o){await this.signalEnd();let i=Rn.recordAttempt(e,n,{success:!1,error:y(o)});if(i.shouldEscalate){let a=Rn.getEscalationInfo(e,n);return{success:!1,error:a?.message,escalation:a,isLoopDetected:!0,suggestion:a?.suggestion}}return{success:!1,error:y(o),attemptNumber:i.attemptNumber,isLooping:i.isLooping}}}async executeTool(e,t,s){if(!st.isAllowed(e,s))throw new Error(`Tool ${e} not allowed for this command`);let n=st.get(e);if(!n)throw new Error(`Tool ${e} not found`);return await n(...t)}async executeSimple(e,t,s){try{let o=(await na.load(e)).frontmatter["allowed-tools"]||[],i=await Ht.build(s);return{success:!0,result:await t({read:l(async u=>this.executeTool("Read",[u],o),"read"),write:l(async(u,p)=>this.executeTool("Write",[u,p],o),"write"),bash:l(async u=>this.executeTool("Bash",[u],o),"bash")},i)}}catch(n){return{success:!1,error:y(n)}}}},bb=new nl,Zo=bb});import vb from"node:https";import Tb from"node:os";import ol from"node:path";import Vt from"chalk";var il,ei,al=S(()=>{"use strict";V();q();il=class{static{l(this,"UpdateChecker")}packageName;cacheDir;cacheFile;checkInterval;constructor(){this.packageName="prjct-cli",this.cacheDir=ol.join(Tb.homedir(),".prjct-cli","config"),this.cacheFile=ol.join(this.cacheDir,"update-cache.json"),this.checkInterval=1440*60*1e3}async getCurrentVersion(){try{let e=ol.join(__dirname,"..","..","package.json");return(await xe(e))?.version??null}catch(e){return console.error("Error reading package version:",y(e)),null}}async getLatestVersion(){return new Promise((e,t)=>{let s={hostname:"registry.npmjs.org",path:`/${this.packageName}/latest`,method:"GET",headers:{"User-Agent":"prjct-cli-update-checker",Accept:"application/json"}},n=vb.request(s,o=>{let i="";o.on("data",a=>{i+=a}),o.on("end",()=>{try{if(o.statusCode===200){let a=JSON.parse(i);e(a.version)}else t(new Error(`npm registry returned status ${o.statusCode}`))}catch(a){t(a)}})});n.on("error",o=>{t(o)}),n.setTimeout(5e3,()=>{n.destroy(),t(new Error("Request timeout"))}),n.end()})}compareVersions(e,t){let s=e.split(".").map(Number),n=t.split(".").map(Number);for(let o=0;o<3;o++){let i=s[o]||0,a=n[o]||0;if(i>a)return 1;if(i<a)return-1}return 0}async readCache(){try{if(await C(this.cacheFile))return await xe(this.cacheFile)}catch{}return null}async writeCache(e){try{await le(this.cacheFile,e)}catch{}}async checkForUpdates(){try{let e=await this.getCurrentVersion();if(!e)return null;let t=await this.readCache(),s=Date.now();if(t?.lastCheck&&s-t.lastCheck<this.checkInterval)return t.latestVersion&&this.compareVersions(t.latestVersion,e)>0?{updateAvailable:!0,currentVersion:e,latestVersion:t.latestVersion}:{updateAvailable:!1,currentVersion:e,latestVersion:e};let n=await this.getLatestVersion();return await this.writeCache({lastCheck:s,latestVersion:n}),{updateAvailable:this.compareVersions(n,e)>0,currentVersion:e,latestVersion:n}}catch{return null}}async getUpdateNotification(){let e=await this.checkForUpdates();return!e||!e.updateAvailable?null:`
895
- `+Vt.yellow("\u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510")+`
896
- `+Vt.yellow("\u2502")+" "+Vt.bold("Update available!")+" "+Vt.dim(`${e.currentVersion} \u2192 ${e.latestVersion}`)+" "+Vt.yellow("\u2502")+`
897
- `+Vt.yellow("\u2502")+" "+Vt.yellow("\u2502")+`
898
- `+Vt.yellow("\u2502")+" Run: "+Vt.cyan("npm update -g prjct-cli")+" "+Vt.yellow("\u2502")+`
899
- `+Vt.yellow("\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518")+`
900
- `}},ei=il});import mg from"node:path";async function Eb(){if(process.env.CLAUDE_AGENT||process.env.ANTHROPIC_CLAUDE||global.mcp||process.env.MCP_AVAILABLE)return!0;let r=process.cwd();if(await C(mg.join(r,"CLAUDE.md")))return!0;let e=process.env.HOME||process.env.USERPROFILE||"";if(await C(mg.join(e,".claude")))return!0;let t=process.cwd();return!!(t.includes("/.claude/")||t.includes("/claude-workspace/"))}function xb(){return{...Cb}}function Rb(){return{...Pb}}async function gg(){return ti||(ti=await Eb()?xb():Rb(),ti)}var ti,Cb,Pb,fg=S(()=>{"use strict";q();ti=null,Cb={type:"claude",name:"Claude (Code + Desktop)",isSupported:!0,capabilities:{mcp:!0,filesystem:"mcp",markdown:!0,emojis:!0,colors:!0,interactive:!0,agents:!0},config:{configFile:"CLAUDE.md",commandPrefix:"/p:",responseStyle:"rich",dataDir:".prjct",commandsDir:"~/.claude/commands/p"},environment:{hasMCP:!0,sandboxed:!1,persistent:!0,agentSystem:!0}},Pb={type:"terminal",name:"Terminal/CLI",isSupported:!0,capabilities:{mcp:!1,filesystem:"native",markdown:!1,emojis:!0,colors:!0,interactive:!0,agents:!1},config:{configFile:null,commandPrefix:"prjct",responseStyle:"cli",dataDir:".prjct",commandsDir:null},environment:{hasMCP:!1,sandboxed:!1,persistent:!0,agentSystem:!1}};l(Eb,"isClaudeEnvironment");l(xb,"getClaudeAgent");l(Rb,"getTerminalAgent");l(gg,"detect")});import si from"node:fs/promises";var cl,hg,yg=S(()=>{"use strict";V();q();cl=class{static{l(this,"ClaudeAgent")}name;type;constructor(){this.name="Claude Code",this.type="claude"}formatResponse(e,t="info"){let s={success:"\u2705",error:"\u274C",warning:"\u26A0\uFE0F",info:"\u2139\uFE0F",celebrate:"\u{1F389}",ship:"\u{1F680}",focus:"\u{1F3AF}",idea:"\u{1F4A1}",progress:"\u{1F4CA}",task:"\u{1F4DD}"};return`${s[t]||s.info} ${e}`}async readFile(e){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.read(e)}catch(t){console.warn(`MCP readFile failed, falling back to fs: ${y(t)}`)}return await si.readFile(e,"utf8")}async writeFile(e,t){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.write(e,t)}catch(s){console.warn(`MCP writeFile failed, falling back to fs: ${y(s)}`)}await si.writeFile(e,t,"utf8")}async listDirectory(e){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.list(e)}catch(t){console.warn(`MCP listDirectory failed, falling back to fs: ${y(t)}`)}return await si.readdir(e)}async fileExists(e){return C(e)}async createDirectory(e){await si.mkdir(e,{recursive:!0})}getTimestamp(){return new Date().toISOString()}formatTaskList(e){return!e||e.length===0?"\u{1F4CB} No tasks queued":`\u{1F4CB} Queue:
949
+ `,context:e,requiresOrchestration:t}}},wb=new Zc,Zo=wb});function _r(r){if(!r||typeof r!="object")return!1;let e=r;if(e.code&&kb.has(e.code))return!0;if(e.code&&pg.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 ti(r){if(!r||typeof r!="object")return!1;let e=r;return!!(e.code&&pg.has(e.code))}function dg(r,e,t){let s=Es.get(r);return s&&s.consecutiveFailures>=e&&s.openedAt?Date.now()-s.openedAt>=t?(Es.delete(r),!1):!0:!1}function el(r,e){let t=Es.get(r)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),Es.set(r,t)}function Sb(r){Es.delete(r)}var kb,pg,Es,ei,mg,si,tl=S(()=>{"use strict";kb=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),pg=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);l(_r,"isTransientError");l(ti,"isPermanentError");Es=new Map;l(dg,"isCircuitOpen");l(el,"recordFailure");l(Sb,"recordSuccess");ei=class{static{l(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(dg(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let s,n=0;for(;n<this.options.maxAttempts;)try{let o=await e();return Sb(t),o}catch(o){if(s=o,n++,ti(o))throw el(t,this.options.circuitBreakerThreshold),o;if(!(_r(o)&&n<this.options.maxAttempts))throw el(t,this.options.circuitBreakerThreshold),o;let a=Math.min(this.options.baseDelayMs*2**(n-1),this.options.maxDelayMs);await new Promise(c=>setTimeout(c,a))}throw el(t,this.options.circuitBreakerThreshold),s}isTransientError(e){return _r(e)}isCircuitOpen(e){return dg(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return Es.get(e)}resetCircuit(e){Es.delete(e)}resetAllCircuits(){Es.clear()}},mg=new ei({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),si=new ei({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});import gg from"node:fs/promises";var Zs,nt,sl=S(()=>{"use strict";He();tl();Zs={tools:new Map,register(r,e){this.tools.set(r,e)},get(r){return this.tools.get(r)},isAllowed(r,e){return!e||e.length===0?!0:e.some(t=>t.endsWith("*")?r.startsWith(t.slice(0,-1)):r===t)},list(){return Array.from(this.tools.keys())}};Zs.register("Read",async r=>{try{return await si.execute(async()=>await gg.readFile(r,"utf-8"),`read-${r}`)}catch(e){return ti(e)||_r(e),null}});Zs.register("Write",async(r,e)=>{try{return await si.execute(async()=>await gg.writeFile(r,e,"utf-8"),`write-${r}`),!0}catch(t){return ti(t)||_r(t),!1}});Zs.register("Bash",async r=>{try{return await si.execute(async()=>await O(r),`bash-${r}`)}catch(e){let t=e;return{stdout:t.stdout||"",stderr:t.stderr||t.message||"Command failed"}}});Zs.register("GetTimestamp",async()=>new Date().toISOString());Zs.register("GetDate",async()=>new Date().toISOString().split("T")[0]);Zs.register("GetDateTime",async()=>new Date().toISOString());nt=Zs});import nl from"node:fs/promises";import bb from"node:os";import rl from"node:path";function fg(){let r=process.env.PRJCT_CLI_HOME?.trim()||rl.join(bb.homedir(),".prjct-cli");return rl.join(r,".running")}async function Tb(r){try{let e=fg(),t=rl.dirname(e);await P(t)||await nl.mkdir(t,{recursive:!0}),await nl.writeFile(e,`/p:${r}`)}catch{}}async function vb(){try{let r=fg();await P(r)&&await nl.unlink(r)}catch{}}var ol,Cb,ni,il=S(()=>{"use strict";W();Xp();K();Zp();sm();jc();gm();fm();mr();zc();Om();lg();ug();Hs();sl();l(fg,"getRunningFilePath");l(Tb,"signalStart");l(vb,"signalEnd");ol=class{static{l(this,"CommandExecutor")}async signalStart(e){await Tb(e)}async signalEnd(){await vb()}async execute(e,t,s){await this.signalStart(e);let n=t.task||t.description||"";if(Rn.shouldEscalate(e,n)){let o=Rn.getEscalationInfo(e,n);return await this.signalEnd(),{success:!1,error:o?.message,escalation:o,isLoopDetected:!0,suggestion:o?.suggestion}}try{let o=await oa.load(e),i=await Wt.build(s,t),a=We.requiresPlanning(e),c=We.isDestructive(e),u=We.isInPlanningMode(i.projectId),p=null;a&&!u&&!t.skipPlanning?p=We.startPlanning(i.projectId,e,t):u&&(p=We.getActivePlan(i.projectId));let m=null;if(Wo.requiresVerification(e)){let q=await Wt.loadStateForCommand(i,e);m=await Wo.verify(e,i,q),!m.verified&&m.warnings.length>0&&console.log(Wo.formatWarnings(m))}let d=null;if(Ho.requiresReasoning(e)){let q=await Wt.loadStateForCommand(i,e);d=await Ho.reason(e,i,q),d.reasoning&&!d.reasoning.allPassed&&(console.log("\u26A0\uFE0F Chain of Thought detected issues:"),console.log(Ho.formatPlan(d)))}let g=t.task||t.description||"",h=await Zo.buildContext(e,g,s),k=Zo.buildAgenticPrompt(h),y=null;if(Zo.requiresOrchestration(e)&&g)try{if(y=await Ko.execute(e,g,s),y.detectedDomains.length>0&&Kp.orchestrate(y.detectedDomains),y.requiresFragmentation&&y.subtasks){let q=y.subtasks.map(mt=>({id:mt.id,domain:mt.domain,description:mt.description,status:mt.status}));Qp(q)}}catch(q){console.warn(`\u26A0\uFE0F Orchestrator warning: ${w(q)}`)}let v={...i,orchestratorPath:h.paths.orchestrator,taskFragmentationPath:h.paths.taskFragmentation,agenticDelegation:!0,agenticMode:!0},D=await Wt.loadState(i),U=null,F=null;i.projectId&&(U={commit_footer:await ct.getSmartDecision(i.projectId,"commit_footer"),branch_naming:await ct.getSmartDecision(i.projectId,"branch_naming"),test_before_ship:await ct.getSmartDecision(i.projectId,"test_before_ship"),preferred_agent:await ct.getSmartDecision(i.projectId,`preferred_agent_${e}`)},F=await ct.getRelevantMemories(i.projectId,{commandName:e,params:t},5));let j={isPlanning:a||u,requiresApproval:c&&!t.approved,active:p,allowedTools:We.getAllowedTools(u,o.frontmatter["allowed-tools"]||[])},se=(await(at(),ot(vt)).getActiveProvider()).name==="claude",Me=await cg.build(o,v,D,null,U,null,F,j,y,{skipNativeContext:se});return console.log("\u{1F916} Template-first execution: Claude reads templates and decides"),k.requiresOrchestration&&console.log(` \u2192 Orchestration: ${h.paths.orchestrator}`),Rn.recordSuccess(e,n),await this.signalEnd(),{success:!0,template:o,context:v,state:D,prompt:Me,agenticDelegation:!0,agenticMode:!0,agenticExecContext:h,agenticPrompt:k.prompt,requiresOrchestration:k.requiresOrchestration,orchestratorPath:h.paths.orchestrator,taskFragmentationPath:h.paths.taskFragmentation,reasoning:d,groundTruth:m,learnedPatterns:U,relevantMemories:F,orchestratorContext:y,memory:{create:l(q=>ct.createMemory(i.projectId,q),"create"),autoRemember:l((q,mt,ms)=>ct.autoRemember(i.projectId,q,mt,ms),"autoRemember"),search:l(q=>ct.searchMemories(i.projectId,q),"search"),findByTags:l(q=>ct.findByTags(i.projectId,q),"findByTags"),getStats:l(()=>ct.getMemoryStats(i.projectId),"getStats")},plan:{active:p,isPlanning:a||u,isDestructive:c,requiresApproval:c&&!t.approved,recordInfo:l(q=>We.recordGatheredInfo(i.projectId,q),"recordInfo"),setAnalysis:l(q=>We.setAnalysis(i.projectId,q),"setAnalysis"),propose:l(q=>We.proposePlan(i.projectId,q),"propose"),approve:l(q=>We.approvePlan(i.projectId,q),"approve"),reject:l(q=>We.rejectPlan(i.projectId,q),"reject"),getApprovalPrompt:l(()=>We.generateApprovalPrompt(e,{changedFiles:[],filesToDelete:[],operation:e==="ship"?"git_push":e==="cleanup"?"delete_files":"run_command",warnings:[]}),"getApprovalPrompt"),startExecution:l(()=>We.startExecution(i.projectId),"startExecution"),getNextStep:l(()=>We.getNextStep(i.projectId),"getNextStep"),completeStep:l(q=>We.completeStep(i.projectId,q),"completeStep"),failStep:l(q=>We.failStep(i.projectId,q),"failStep"),abort:l(q=>We.abortPlan(i.projectId,q),"abort"),getStatus:l(()=>We.formatStatus(i.projectId),"getStatus"),getAllowedTools:l(()=>We.getAllowedTools(u,o.frontmatter["allowed-tools"]||[]),"getAllowedTools")}}}catch(o){await this.signalEnd();let i=Rn.recordAttempt(e,n,{success:!1,error:w(o)});if(i.shouldEscalate){let a=Rn.getEscalationInfo(e,n);return{success:!1,error:a?.message,escalation:a,isLoopDetected:!0,suggestion:a?.suggestion}}return{success:!1,error:w(o),attemptNumber:i.attemptNumber,isLooping:i.isLooping}}}async executeTool(e,t,s){if(!nt.isAllowed(e,s))throw new Error(`Tool ${e} not allowed for this command`);let n=nt.get(e);if(!n)throw new Error(`Tool ${e} not found`);return await n(...t)}async executeSimple(e,t,s){try{let o=(await oa.load(e)).frontmatter["allowed-tools"]||[],i=await Wt.build(s);return{success:!0,result:await t({read:l(async u=>this.executeTool("Read",[u],o),"read"),write:l(async(u,p)=>this.executeTool("Write",[u,p],o),"write"),bash:l(async u=>this.executeTool("Bash",[u],o),"bash")},i)}}catch(n){return{success:!1,error:w(n)}}}},Cb=new ol,ni=Cb});import Pb from"node:https";import Eb from"node:os";import al from"node:path";import Bt from"chalk";var cl,ri,ll=S(()=>{"use strict";W();K();cl=class{static{l(this,"UpdateChecker")}packageName;cacheDir;cacheFile;checkInterval;constructor(){this.packageName="prjct-cli",this.cacheDir=al.join(Eb.homedir(),".prjct-cli","config"),this.cacheFile=al.join(this.cacheDir,"update-cache.json"),this.checkInterval=1440*60*1e3}async getCurrentVersion(){try{let e=al.join(__dirname,"..","..","package.json");return(await xe(e))?.version??null}catch(e){return console.error("Error reading package version:",w(e)),null}}async getLatestVersion(){return new Promise((e,t)=>{let s={hostname:"registry.npmjs.org",path:`/${this.packageName}/latest`,method:"GET",headers:{"User-Agent":"prjct-cli-update-checker",Accept:"application/json"}},n=Pb.request(s,o=>{let i="";o.on("data",a=>{i+=a}),o.on("end",()=>{try{if(o.statusCode===200){let a=JSON.parse(i);e(a.version)}else t(new Error(`npm registry returned status ${o.statusCode}`))}catch(a){t(a)}})});n.on("error",o=>{t(o)}),n.setTimeout(5e3,()=>{n.destroy(),t(new Error("Request timeout"))}),n.end()})}compareVersions(e,t){let s=e.split(".").map(Number),n=t.split(".").map(Number);for(let o=0;o<3;o++){let i=s[o]||0,a=n[o]||0;if(i>a)return 1;if(i<a)return-1}return 0}async readCache(){try{if(await P(this.cacheFile))return await xe(this.cacheFile)}catch{}return null}async writeCache(e){try{await le(this.cacheFile,e)}catch{}}async checkForUpdates(){try{let e=await this.getCurrentVersion();if(!e)return null;let t=await this.readCache(),s=Date.now();if(t?.lastCheck&&s-t.lastCheck<this.checkInterval)return t.latestVersion&&this.compareVersions(t.latestVersion,e)>0?{updateAvailable:!0,currentVersion:e,latestVersion:t.latestVersion}:{updateAvailable:!1,currentVersion:e,latestVersion:e};let n=await this.getLatestVersion();return await this.writeCache({lastCheck:s,latestVersion:n}),{updateAvailable:this.compareVersions(n,e)>0,currentVersion:e,latestVersion:n}}catch{return null}}async getUpdateNotification(){let e=await this.checkForUpdates();return!e||!e.updateAvailable?null:`
950
+ `+Bt.yellow("\u250C\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510")+`
951
+ `+Bt.yellow("\u2502")+" "+Bt.bold("Update available!")+" "+Bt.dim(`${e.currentVersion} \u2192 ${e.latestVersion}`)+" "+Bt.yellow("\u2502")+`
952
+ `+Bt.yellow("\u2502")+" "+Bt.yellow("\u2502")+`
953
+ `+Bt.yellow("\u2502")+" Run: "+Bt.cyan("npm update -g prjct-cli")+" "+Bt.yellow("\u2502")+`
954
+ `+Bt.yellow("\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518")+`
955
+ `}},ri=cl});import hg from"node:path";async function Ab(){if(process.env.CLAUDE_AGENT||process.env.ANTHROPIC_CLAUDE||global.mcp||process.env.MCP_AVAILABLE)return!0;let r=process.cwd();if(await P(hg.join(r,"CLAUDE.md")))return!0;let e=process.env.HOME||process.env.USERPROFILE||"";if(await P(hg.join(e,".claude")))return!0;let t=process.cwd();return!!(t.includes("/.claude/")||t.includes("/claude-workspace/"))}function Db(){return{...xb}}function jb(){return{...Rb}}async function yg(){return oi||(oi=await Ab()?Db():jb(),oi)}var oi,xb,Rb,wg=S(()=>{"use strict";K();oi=null,xb={type:"claude",name:"Claude (Code + Desktop)",isSupported:!0,capabilities:{mcp:!0,filesystem:"mcp",markdown:!0,emojis:!0,colors:!0,interactive:!0,agents:!0},config:{configFile:"CLAUDE.md",commandPrefix:"/p:",responseStyle:"rich",dataDir:".prjct",commandsDir:"~/.claude/commands/p"},environment:{hasMCP:!0,sandboxed:!1,persistent:!0,agentSystem:!0}},Rb={type:"terminal",name:"Terminal/CLI",isSupported:!0,capabilities:{mcp:!1,filesystem:"native",markdown:!1,emojis:!0,colors:!0,interactive:!0,agents:!1},config:{configFile:null,commandPrefix:"prjct",responseStyle:"cli",dataDir:".prjct",commandsDir:null},environment:{hasMCP:!1,sandboxed:!1,persistent:!0,agentSystem:!1}};l(Ab,"isClaudeEnvironment");l(Db,"getClaudeAgent");l(jb,"getTerminalAgent");l(yg,"detect")});import ii from"node:fs/promises";var ul,kg,Sg=S(()=>{"use strict";W();K();ul=class{static{l(this,"ClaudeAgent")}name;type;constructor(){this.name="Claude Code",this.type="claude"}formatResponse(e,t="info"){let s={success:"\u2705",error:"\u274C",warning:"\u26A0\uFE0F",info:"\u2139\uFE0F",celebrate:"\u{1F389}",ship:"\u{1F680}",focus:"\u{1F3AF}",idea:"\u{1F4A1}",progress:"\u{1F4CA}",task:"\u{1F4DD}"};return`${s[t]||s.info} ${e}`}async readFile(e){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.read(e)}catch(t){console.warn(`MCP readFile failed, falling back to fs: ${w(t)}`)}return await ii.readFile(e,"utf8")}async writeFile(e,t){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.write(e,t)}catch(s){console.warn(`MCP writeFile failed, falling back to fs: ${w(s)}`)}await ii.writeFile(e,t,"utf8")}async listDirectory(e){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.list(e)}catch(t){console.warn(`MCP listDirectory failed, falling back to fs: ${w(t)}`)}return await ii.readdir(e)}async fileExists(e){return P(e)}async createDirectory(e){await ii.mkdir(e,{recursive:!0})}getTimestamp(){return new Date().toISOString()}formatTaskList(e){return!e||e.length===0?"\u{1F4CB} No tasks queued":`\u{1F4CB} Queue:
901
956
  ${e.map((t,s)=>`${s+1}. ${t}`).join(`
902
957
  `)}`}formatRecap(e){return`\u{1F4CA} Recap
903
958
 
@@ -942,10 +997,10 @@ Or type /p:help to see all options`,stuck:`Let's break it down:
942
997
 
943
998
  Or: /p:now | /p:task | /p:idea`}[e]||`What would you like to do?
944
999
 
945
- 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}}},hg=cl});var Db,ll,ni,wg=S(()=>{"use strict";ss();fg();yg();Zc();Db=["claude"],ll=class{static{l(this,"AgentService")}agent=null;agentInfo=null;async initialize(){return this.agent?this.agent:await ug.execute(async()=>{if(this.agentInfo=await gg(),!this.agentInfo?.isSupported)throw gr.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!Db.includes(e))throw gr.notSupported(this.agentInfo?.type??"unknown");return this.agent=new hg,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}reset(){this.agent=null,this.agentInfo=null}},ni=new ll});var ul,In,dl=S(()=>{"use strict";ul=class{static{l(this,"BreakdownService")}breakdownFeature(e){return[]}detectBugSeverity(e){return"medium"}estimateComplexity(e){return{level:"medium",hours:4}}detectTaskType(e){return"feature"}},In=new ul});var pl,nt,ml=S(()=>{"use strict";ce();pl=class{static{l(this,"CustomWorkflowStorage")}createWorkflow(e,t){let s=new Date().toISOString();F.run(e,`INSERT INTO custom_workflows (name, description, created_at, updated_at, is_builtin, enabled, metadata)
946
- VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,s,s,t.metadata?JSON.stringify(t.metadata):null);let n=F.get(e,"SELECT id FROM custom_workflows WHERE name = ?",t.name);if(!n)throw new Error(`Failed to create workflow: ${t.name}`);return n.id}getWorkflow(e,t){let s=F.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 F.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),F.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 F.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}}},nt=new pl});function gl(r){return{id:r.id,type:r.type,command:r.command,position:r.position,action:r.action,description:r.description,enabled:r.enabled===1,timeoutMs:r.timeout_ms,createdAt:r.created_at,sortOrder:r.sort_order}}var fl,Ie,ri=S(()=>{"use strict";ml();ce();l(gl,"rowToRule");fl=class{static{l(this,"WorkflowRuleStorage")}addRule(e,t){let s=P.get(e,"SELECT MAX(sort_order) as m FROM workflow_rules WHERE command = ?",t.command),n=t.sortOrder||(s?.m??-1)+1;return P.run(e,`INSERT INTO workflow_rules (type, command, position, action, description, enabled, timeout_ms, created_at, sort_order)
947
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,n),P.get(e,"SELECT last_insert_rowid() as id")?.id??0}removeRule(e,t){return P.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t)?(P.run(e,"DELETE FROM workflow_rules WHERE id = ?",t),!0):!1}updateRule(e,t,s){if(!P.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:l(c=>c?1:0,"transform")},timeoutMs:{column:"timeout_ms"},createdAt:{column:"created_at"},sortOrder:{column:"sort_order"}},i=[],a=[];for(let[c,u]of Object.entries(s)){let p=o[c];if(!p)continue;i.push(`${p.column} = ?`);let m=u;a.push(p.transform?p.transform(m):m)}return i.length===0||(a.push(t),P.run(e,`UPDATE workflow_rules SET ${i.join(", ")} WHERE id = ?`,...a)),!0}getRuleById(e,t){let s=P.get(e,"SELECT * FROM workflow_rules WHERE id = ?",t);return s?gl(s):null}getRulesForCommand(e,t){let s=nt.getWorkflow(e,t);return!s||!s.enabled?[]:P.query(e,"SELECT * FROM workflow_rules WHERE command = ? AND enabled = 1 ORDER BY sort_order ASC",t).map(gl)}getAllRules(e){return P.query(e,"SELECT * FROM workflow_rules ORDER BY command ASC, sort_order ASC").map(gl)}resetRules(e){let t=P.get(e,"SELECT COUNT(*) as c FROM workflow_rules");return P.run(e,"DELETE FROM workflow_rules"),t?.c??0}},Ie=new fl});import ct from"node:path";async function jb(r,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 C(ct.join(r,"pnpm-lock.yaml"))?"pnpm":await C(ct.join(r,"yarn.lock"))?"yarn":await C(ct.join(r,"bun.lockb"))||await C(ct.join(r,"bun.lock"))?"bun":(await C(ct.join(r,"package-lock.json")),"npm")}function kg(r,e){return r==="yarn"?`yarn ${e}`:r==="pnpm"?`pnpm run ${e}`:r==="bun"?`bun run ${e}`:`npm run ${e}`}function Ib(r){return r==="yarn"?"yarn test":r==="pnpm"?"pnpm test":r==="bun"?"bun test":"npm test"}async function $n(r,e){for(let n of $b)if(await C(ct.join(r,n)))return n;let s=(e??await ts(r)).find(n=>n.endsWith(Mb));if(s)return s}async function us(r){for(let e of Ob)if(await C(ct.join(r,e)))return e}async function oi(r){let e=ct.join(r,"package.json"),t=await xe(e,null);if(t){let a=await jb(r,t),c=t.scripts||{},u={stack:"js",packageManager:a};return c.lint&&(u.lint={tool:a,command:kg(a,"lint")}),c.typecheck&&(u.typecheck={tool:a,command:kg(a,"typecheck")}),c.test&&(u.test={tool:a,command:Ib(a)}),u.versionFile=await $n(r),u.changelogFile=await us(r),u}if(await C(ct.join(r,"pytest.ini"))){let a=await $n(r),c=await us(r);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}let s=await ot(ct.join(r,"pyproject.toml"),"");if(s.includes("[tool.pytest")||s.includes("pytest")){let a=await $n(r),c=await us(r);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}if(await C(ct.join(r,"Cargo.toml"))){let a=await us(r);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await C(ct.join(r,"go.mod"))){let a=await $n(r),c=await us(r);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:c}}let n=await ts(r);if(n.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await $n(r,n),c=await us(r);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:c}}if(await C(ct.join(r,"pom.xml"))){let a=await us(r);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await C(ct.join(r,"gradlew"))&&(await C(ct.join(r,"build.gradle"))||await C(ct.join(r,"build.gradle.kts")))){let a=await us(r);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await $n(r),i=await us(r);return{stack:"unknown",versionFile:o,changelogFile:i}}var $b,Mb,Ob,hl=S(()=>{"use strict";q();l(jb,"detectPackageManager");l(kg,"pmRun");l(Ib,"pmTest");$b=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],Mb=".csproj",Ob=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];l($n,"detectVersionFile");l(us,"detectChangelogFile");l(oi,"detectProjectCommands")});import*as pe from"@clack/prompts";import Zs from"chalk";var ii,Sg,Mr,bg=S(()=>{"use strict";q();Ts();ii=[{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."}],Sg=[{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{l(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(){pe.intro(Zs.cyan.bold("\u26A1 prjct-cli setup"));let e=[{id:"project-type",title:"Project Type",run:l(()=>this.stepProjectType(),"run")},{id:"ai-agents",title:"AI Agents",run:l(()=>this.stepAIAgents(),"run")},{id:"stack",title:"Stack Confirmation",run:l(()=>this.stepStack(),"run")},{id:"preferences",title:"Preferences",run:l(()=>this.stepPreferences(),"run")},{id:"summary",title:"Summary",run:l(()=>this.stepSummary(),"run")}];for(let t of e)if(!await t.run()||this.aborted)return this.buildResult(!0);return pe.outro(Zs.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=ii.findIndex(s=>s.value===this.detectedType),t=await pe.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:ii.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValue:e>=0?ii[e].value:void 0});return pe.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await pe.multiselect({message:"Which AI agents do you use?",options:Sg.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValues:e,required:!0});return pe.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);pe.note(e,"Detected stack");let t=await pe.confirm({message:"Is this stack correct?",initialValue:!0});if(pe.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let s=await pe.group({language:l(()=>pe.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:l(()=>pe.text({message:"Framework (optional):",defaultValue:this.detectedStack.framework||""}),"framework")},{onCancel:l(()=>{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 pe.group({verbosity:l(()=>pe.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:l(()=>pe.confirm({message:"Auto-sync context on file changes?",initialValue:!0}),"autoSync")},{onCancel:l(()=>{this.handleCancel()},"onCancel")});return this.aborted?!1:(this.preferences={verbosity:e.verbosity||"normal",autoSync:e.autoSync??!0,telemetry:!1},!0)}async stepSummary(){let e=[`${Zs.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${Zs.cyan("AI Agents:")} ${this.selectedAgents.map(s=>this.getAgentLabel(s)).join(", ")}`,`${Zs.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${Zs.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${Zs.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
948
- `);pe.note(e,"Configuration Summary");let t=await pe.confirm({message:"Generate configuration with these settings?",initialValue:!0});return pe.isCancel(t)||!t?(pe.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 n=t.join(this.projectPath,"package.json"),o=await e.readFile(n,"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 es(e.join(t.homedir(),".claude"))&&s.push("claude"),await C(e.join(this.projectPath,".cursorrules"))&&s.push("cursor"),await C(e.join(this.projectPath,".windsurfrules"))&&s.push("windsurf"),await C(e.join(this.projectPath,".github","copilot-instructions.md"))&&s.push("copilot"),await es(e.join(t.homedir(),".gemini"))&&s.push("gemini");try{let{execAsync:n}=await Promise.resolve().then(()=>(Ue(),au));await n("which codex"),s.push("codex")}catch{await es(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 n=await e.readdir(this.projectPath);if(n.includes("package.json")){let o=t.join(this.projectPath,"package.json"),i=await e.readFile(o,"utf-8"),a=JSON.parse(i),c={...a.dependencies,...a.devDependencies};s.language=c.typescript?"TypeScript":"JavaScript",c.next?s.framework="Next.js":c.nuxt?s.framework="Nuxt":c.react?s.framework="React":c.vue?s.framework="Vue":c["@angular/core"]?s.framework="Angular":c.express?s.framework="Express":c.hono?s.framework="Hono":c.fastify?s.framework="Fastify":(c.nestjs||c["@nestjs/core"])&&(s.framework="NestJS"),c.bun||c["@types/bun"]||a.engines?.bun?s.runtime="Bun":s.runtime="Node.js",n.includes("bun.lockb")?s.packageManager="Bun":n.includes("pnpm-lock.yaml")?s.packageManager="pnpm":n.includes("yarn.lock")?s.packageManager="Yarn":n.includes("package-lock.json")&&(s.packageManager="npm"),(c.prisma||c["@prisma/client"])&&s.technologies.push("Prisma"),(c.drizzle||c["drizzle-orm"])&&s.technologies.push("Drizzle"),c.tailwindcss&&s.technologies.push("Tailwind CSS"),c.zod&&s.technologies.push("Zod"),(c.trpc||c["@trpc/server"])&&s.technologies.push("tRPC")}else n.includes("pyproject.toml")||n.includes("requirements.txt")?s.language="Python":n.includes("go.mod")?s.language="Go":n.includes("Cargo.toml")?s.language="Rust":(n.includes("pom.xml")||n.includes("build.gradle"))&&(s.language="Java");return s}catch{return s}}handleCancel(){this.aborted=!0,pe.cancel("Setup cancelled. Run again anytime.")}getProjectTypeLabel(e){return ii.find(t=>t.value===e)?.title||"Unknown"}getAgentLabel(e){return Sg.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}}});var vg={};Bt(vg,{PlanningCommands:()=>tn});import en from"node:path";async function _b(){if(!yl){let{AnalysisCommands:r}=await Promise.resolve().then(()=>(ci(),Tg));yl=new r}return yl}var yl,tn,ai=S(()=>{"use strict";ho();os();It();ks();Xt();ri();V();Pn();En();hl();bg();lt();yl=null;l(_b,"getAnalysisCommands");tn=class extends Ce{static{l(this,"PlanningCommands")}async init(e={},t=process.cwd()){try{let s={};if(typeof e=="string"||e===null?s={idea:e}:s=e,await this.initializeAgent(),await I.isConfigured(t))return f.warn("already initialized"),{success:!1,message:"Already initialized"};let o=process.stdout.isTTY&&process.stdin.isTTY,i=s.yes||!o||process.env.CI==="true",a=null;if(i)o&&s.yes&&(a=await new Mr(t).runNonInteractive());else if(a=await new Mr(t).run(),a.skipped)return{success:!1,message:"Setup cancelled"};f.step(1,4,"Detecting author...");let c=await bn(),u={name:c.name||void 0,email:c.email||void 0,github:c.github||void 0},m=(await I.createConfig(t,u)).projectId;f.step(2,4,"Creating structure..."),await A.ensureProjectStructure(m);let d=A.getGlobalProjectPath(m);await this._seedShipWorkflow(m,t);let g={"core/now.md":`# NOW
1000
+ 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}}},kg=ul});var $b,dl,ai,bg=S(()=>{"use strict";ss();wg();Sg();tl();$b=["claude"],dl=class{static{l(this,"AgentService")}agent=null;agentInfo=null;async initialize(){return this.agent?this.agent:await mg.execute(async()=>{if(this.agentInfo=await yg(),!this.agentInfo?.isSupported)throw gr.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!$b.includes(e))throw gr.notSupported(this.agentInfo?.type??"unknown");return this.agent=new kg,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}reset(){this.agent=null,this.agentInfo=null}},ai=new dl});var pl,In,ml=S(()=>{"use strict";pl=class{static{l(this,"BreakdownService")}breakdownFeature(e){return[]}detectBugSeverity(e){return"medium"}estimateComplexity(e){return{level:"medium",hours:4}}detectTaskType(e){return"feature"}},In=new pl});var gl,rt,fl=S(()=>{"use strict";re();gl=class{static{l(this,"CustomWorkflowStorage")}createWorkflow(e,t){let s=new Date().toISOString();N.run(e,`INSERT INTO custom_workflows (name, description, created_at, updated_at, is_builtin, enabled, metadata)
1001
+ VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,s,s,t.metadata?JSON.stringify(t.metadata):null);let n=N.get(e,"SELECT id FROM custom_workflows WHERE name = ?",t.name);if(!n)throw new Error(`Failed to create workflow: ${t.name}`);return n.id}getWorkflow(e,t){let s=N.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 N.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),N.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 N.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}}},rt=new gl});function hl(r){return{id:r.id,type:r.type,command:r.command,position:r.position,action:r.action,description:r.description,enabled:r.enabled===1,timeoutMs:r.timeout_ms,createdAt:r.created_at,sortOrder:r.sort_order}}var yl,je,ci=S(()=>{"use strict";fl();re();l(hl,"rowToRule");yl=class{static{l(this,"WorkflowRuleStorage")}addRule(e,t){let s=C.get(e,"SELECT MAX(sort_order) as m FROM workflow_rules WHERE command = ?",t.command),n=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)
1002
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,n),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:l(c=>c?1:0,"transform")},timeoutMs:{column:"timeout_ms"},createdAt:{column:"created_at"},sortOrder:{column:"sort_order"}},i=[],a=[];for(let[c,u]of Object.entries(s)){let p=o[c];if(!p)continue;i.push(`${p.column} = ?`);let m=u;a.push(p.transform?p.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?hl(s):null}getRulesForCommand(e,t){let s=rt.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(hl)}getAllRules(e){return C.query(e,"SELECT * FROM workflow_rules ORDER BY command ASC, sort_order ASC").map(hl)}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}},je=new yl});import ut from"node:path";async function Mb(r,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 P(ut.join(r,"pnpm-lock.yaml"))?"pnpm":await P(ut.join(r,"yarn.lock"))?"yarn":await P(ut.join(r,"bun.lockb"))||await P(ut.join(r,"bun.lock"))?"bun":(await P(ut.join(r,"package-lock.json")),"npm")}function Tg(r,e){return r==="yarn"?`yarn ${e}`:r==="pnpm"?`pnpm run ${e}`:r==="bun"?`bun run ${e}`:`npm run ${e}`}function _b(r){return r==="yarn"?"yarn test":r==="pnpm"?"pnpm test":r==="bun"?"bun test":"npm test"}async function $n(r,e){for(let n of Ob)if(await P(ut.join(r,n)))return n;let s=(e??await ts(r)).find(n=>n.endsWith(Nb));if(s)return s}async function us(r){for(let e of Lb)if(await P(ut.join(r,e)))return e}async function li(r){let e=ut.join(r,"package.json"),t=await xe(e,null);if(t){let a=await Mb(r,t),c=t.scripts||{},u={stack:"js",packageManager:a};return c.lint&&(u.lint={tool:a,command:Tg(a,"lint")}),c.typecheck&&(u.typecheck={tool:a,command:Tg(a,"typecheck")}),c.test&&(u.test={tool:a,command:_b(a)}),u.versionFile=await $n(r),u.changelogFile=await us(r),u}if(await P(ut.join(r,"pytest.ini"))){let a=await $n(r),c=await us(r);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}let s=await it(ut.join(r,"pyproject.toml"),"");if(s.includes("[tool.pytest")||s.includes("pytest")){let a=await $n(r),c=await us(r);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}if(await P(ut.join(r,"Cargo.toml"))){let a=await us(r);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await P(ut.join(r,"go.mod"))){let a=await $n(r),c=await us(r);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:c}}let n=await ts(r);if(n.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await $n(r,n),c=await us(r);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:c}}if(await P(ut.join(r,"pom.xml"))){let a=await us(r);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await P(ut.join(r,"gradlew"))&&(await P(ut.join(r,"build.gradle"))||await P(ut.join(r,"build.gradle.kts")))){let a=await us(r);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await $n(r),i=await us(r);return{stack:"unknown",versionFile:o,changelogFile:i}}var Ob,Nb,Lb,wl=S(()=>{"use strict";K();l(Mb,"detectPackageManager");l(Tg,"pmRun");l(_b,"pmTest");Ob=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],Nb=".csproj",Lb=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];l($n,"detectVersionFile");l(us,"detectChangelogFile");l(li,"detectProjectCommands")});import*as pe from"@clack/prompts";import en from"chalk";var ui,vg,Or,Cg=S(()=>{"use strict";K();vs();ui=[{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."}],vg=[{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"}],Or=class{static{l(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(){pe.intro(en.cyan.bold("\u26A1 prjct-cli setup"));let e=[{id:"project-type",title:"Project Type",run:l(()=>this.stepProjectType(),"run")},{id:"ai-agents",title:"AI Agents",run:l(()=>this.stepAIAgents(),"run")},{id:"stack",title:"Stack Confirmation",run:l(()=>this.stepStack(),"run")},{id:"preferences",title:"Preferences",run:l(()=>this.stepPreferences(),"run")},{id:"summary",title:"Summary",run:l(()=>this.stepSummary(),"run")}];for(let t of e)if(!await t.run()||this.aborted)return this.buildResult(!0);return pe.outro(en.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=ui.findIndex(s=>s.value===this.detectedType),t=await pe.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:ui.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValue:e>=0?ui[e].value:void 0});return pe.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await pe.multiselect({message:"Which AI agents do you use?",options:vg.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValues:e,required:!0});return pe.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);pe.note(e,"Detected stack");let t=await pe.confirm({message:"Is this stack correct?",initialValue:!0});if(pe.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let s=await pe.group({language:l(()=>pe.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:l(()=>pe.text({message:"Framework (optional):",defaultValue:this.detectedStack.framework||""}),"framework")},{onCancel:l(()=>{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 pe.group({verbosity:l(()=>pe.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:l(()=>pe.confirm({message:"Auto-sync context on file changes?",initialValue:!0}),"autoSync")},{onCancel:l(()=>{this.handleCancel()},"onCancel")});return this.aborted?!1:(this.preferences={verbosity:e.verbosity||"normal",autoSync:e.autoSync??!0,telemetry:!1},!0)}async stepSummary(){let e=[`${en.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${en.cyan("AI Agents:")} ${this.selectedAgents.map(s=>this.getAgentLabel(s)).join(", ")}`,`${en.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${en.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${en.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
1003
+ `);pe.note(e,"Configuration Summary");let t=await pe.confirm({message:"Generate configuration with these settings?",initialValue:!0});return pe.isCancel(t)||!t?(pe.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 n=t.join(this.projectPath,"package.json"),o=await e.readFile(n,"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 es(e.join(t.homedir(),".claude"))&&s.push("claude"),await P(e.join(this.projectPath,".cursorrules"))&&s.push("cursor"),await P(e.join(this.projectPath,".windsurfrules"))&&s.push("windsurf"),await P(e.join(this.projectPath,".github","copilot-instructions.md"))&&s.push("copilot"),await es(e.join(t.homedir(),".gemini"))&&s.push("gemini");try{let{execAsync:n}=await Promise.resolve().then(()=>(He(),uu));await n("which codex"),s.push("codex")}catch{await es(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 n=await e.readdir(this.projectPath);if(n.includes("package.json")){let o=t.join(this.projectPath,"package.json"),i=await e.readFile(o,"utf-8"),a=JSON.parse(i),c={...a.dependencies,...a.devDependencies};s.language=c.typescript?"TypeScript":"JavaScript",c.next?s.framework="Next.js":c.nuxt?s.framework="Nuxt":c.react?s.framework="React":c.vue?s.framework="Vue":c["@angular/core"]?s.framework="Angular":c.express?s.framework="Express":c.hono?s.framework="Hono":c.fastify?s.framework="Fastify":(c.nestjs||c["@nestjs/core"])&&(s.framework="NestJS"),c.bun||c["@types/bun"]||a.engines?.bun?s.runtime="Bun":s.runtime="Node.js",n.includes("bun.lockb")?s.packageManager="Bun":n.includes("pnpm-lock.yaml")?s.packageManager="pnpm":n.includes("yarn.lock")?s.packageManager="Yarn":n.includes("package-lock.json")&&(s.packageManager="npm"),(c.prisma||c["@prisma/client"])&&s.technologies.push("Prisma"),(c.drizzle||c["drizzle-orm"])&&s.technologies.push("Drizzle"),c.tailwindcss&&s.technologies.push("Tailwind CSS"),c.zod&&s.technologies.push("Zod"),(c.trpc||c["@trpc/server"])&&s.technologies.push("tRPC")}else n.includes("pyproject.toml")||n.includes("requirements.txt")?s.language="Python":n.includes("go.mod")?s.language="Go":n.includes("Cargo.toml")?s.language="Rust":(n.includes("pom.xml")||n.includes("build.gradle"))&&(s.language="Java");return s}catch{return s}}handleCancel(){this.aborted=!0,pe.cancel("Setup cancelled. Run again anytime.")}getProjectTypeLabel(e){return ui.find(t=>t.value===e)?.title||"Unknown"}getAgentLabel(e){return vg.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}}});var Pg={};Ot(Pg,{PlanningCommands:()=>sn});import tn from"node:path";async function Fb(){if(!kl){let{AnalysisCommands:r}=await Promise.resolve().then(()=>(pi(),Eg));kl=new r}return kl}var kl,sn,di=S(()=>{"use strict";So();os();It();ks();Xt();ci();W();Ks();En();wl();Cg();dt();kl=null;l(Fb,"getAnalysisCommands");sn=class extends Ce{static{l(this,"PlanningCommands")}async init(e={},t=process.cwd()){try{let s={};if(typeof e=="string"||e===null?s={idea:e}:s=e,await this.initializeAgent(),await $.isConfigured(t))return f.warn("already initialized"),{success:!1,message:"Already initialized"};let o=process.stdout.isTTY&&process.stdin.isTTY,i=s.yes||!o||process.env.CI==="true",a=null;if(i)o&&s.yes&&(a=await new Or(t).runNonInteractive());else if(a=await new Or(t).run(),a.skipped)return{success:!1,message:"Setup cancelled"};f.step(1,4,"Detecting author...");let c=await Tn(),u={name:c.name||void 0,email:c.email||void 0,github:c.github||void 0},m=(await $.createConfig(t,u)).projectId;f.step(2,4,"Creating structure..."),await A.ensureProjectStructure(m);let d=A.getGlobalProjectPath(m);await this._seedShipWorkflow(m,t);let g={"core/now.md":`# NOW
949
1004
 
950
1005
  No current task. Use \`/p:now\` to set focus.
951
1006
  `,"core/next.md":`# NEXT
@@ -965,17 +1020,17 @@ No current task. Use \`/p:now\` to set focus.
965
1020
  `,"planning/roadmap.md":`# ROADMAP
966
1021
 
967
1022
  `,"planning/specs/.gitkeep":`# Specs directory - created by /p:spec
968
- `,"memory/context.jsonl":"","memory/patterns.json":JSON.stringify({version:1,decisions:{},preferences:{},workflows:{},counters:{}},null,2)};a&&(g["config/wizard.json"]=JSON.stringify({projectType:a.projectType,agents:a.agents,stack:a.stack,preferences:a.preferences,createdAt:new Date().toISOString()},null,2));for(let[T,E]of Object.entries(g))await st.get("Write")(en.join(d,T),E);let h=await this._detectEmptyDirectory(t),k=await this._detectExistingCode(t);if(k||!h){f.step(3,4,"Analyzing project...");let T=await _b();if((await T.analyze({},t)).success)return f.step(4,4,"Generating agents..."),await T.sync(t),f.done("initialized"),this._printNextSteps(a),{success:!0,mode:"existing",projectId:m,wizard:a}}let w=s.idea;if(h&&!k){if(!w)return f.done("blank project - provide idea for architect mode"),{success:!0,mode:"blank_no_idea",projectId:m,wizard:a};f.spin("architect mode...");let T=en.join(d,"planning","architect-session.md"),E=`# Architect Session
1023
+ `,"memory/context.jsonl":"","memory/patterns.json":JSON.stringify({version:1,decisions:{},preferences:{},workflows:{},counters:{}},null,2)};a&&(g["config/wizard.json"]=JSON.stringify({projectType:a.projectType,agents:a.agents,stack:a.stack,preferences:a.preferences,createdAt:new Date().toISOString()},null,2));for(let[v,D]of Object.entries(g))await nt.get("Write")(tn.join(d,v),D);let h=await this._detectEmptyDirectory(t),k=await this._detectExistingCode(t);if(k||!h){f.step(3,4,"Analyzing project...");let v=await Fb();if((await v.analyze({},t)).success)return f.step(4,4,"Generating agents..."),await v.sync(t),f.done("initialized"),this._printNextSteps(a),{success:!0,mode:"existing",projectId:m,wizard:a}}let y=s.idea;if(h&&!k){if(!y)return f.done("blank project - provide idea for architect mode"),{success:!0,mode:"blank_no_idea",projectId:m,wizard:a};f.spin("architect mode...");let v=tn.join(d,"planning","architect-session.md"),D=`# Architect Session
969
1024
 
970
1025
  ## Idea
971
- ${w}
1026
+ ${y}
972
1027
 
973
1028
  ## Status
974
1029
  Initialized - awaiting stack recommendation
975
1030
 
976
1031
  Generated: ${new Date().toLocaleString()}
977
- `;return await st.get("Write")(T,E),await De.installGlobalConfig(),f.done("architect mode ready"),{success:!0,mode:"architect",projectId:m,idea:w,wizard:a}}return await De.installGlobalConfig(),f.done("initialized"),this._printNextSteps(a),{success:!0,projectId:m,wizard:a}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}_printNextSteps(e){if(console.log(""),console.log(" Quick start:"),console.log(" prjct sync Update context after changes"),console.log(" prjct task Start working on a task"),console.log(" prjct hooks Auto-sync on commit/checkout"),console.log(""),e){let t=e.agents.map(s=>{switch(s){case"claude":return"CLAUDE.md";case"cursor":return".cursorrules";case"windsurf":return".windsurfrules";case"copilot":return".github/copilot-instructions.md";case"gemini":return"GEMINI.md";case"codex":return"AGENTS.md";default:return null}}).filter(Boolean);t.length>0&&(console.log(` Generated: ${t.join(", ")}`),console.log(""))}console.log(" Docs: https://prjct.app/docs"),console.log("")}async feature(e,t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;if(!e)return f.fail("description required"),{success:!1,error:"Description required"};let n=await I.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};f.spin(`planning ${e}...`);let o=this._breakdownFeatureTasks(e),i=ye();return await be.addTasks(n,o.map(a=>({description:a,priority:"medium",type:"feature",section:"active",featureId:i,originFeature:e}))),await this.logToMemory(t,"feature_planned",{feature:e,featureId:i,tasks:o.length,timestamp:z.getTimestamp()}),f.done(`${o.length} tasks planned`),{success:!0,feature:e,featureId:i,tasks:o}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}async bug(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;if(!e)return s.md||f.fail("bug description required"),{success:!1,error:"Description required"};let o=await I.getProjectId(t);if(!o)return s.md||f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};s.md||f.spin("tracking bug...");let i=this._detectBugSeverity(e),c={critical:"critical",high:"high",medium:"medium",low:"low"}[i]||"medium";return await be.addTask(o,{description:`\u{1F41B} ${e}`,priority:c,type:"bug",section:"active"}),await this.logToMemory(t,"bug_reported",{bug:e,severity:i,priority:c,timestamp:z.getTimestamp()}),s.md?console.log(U(se("Bug Reported",e),mt({Severity:i,Priority:c}),ge([{label:"Fix now",command:`prjct task "fix: ${e}" --md`},{label:"View queue",command:"prjct next --md"}]))):(f.done(`bug [${i}] [${c}]`),At("bug")),{success:!0,bug:e,severity:i}}catch(n){return s.md||f.fail(y(n)),{success:!1,error:y(n)}}}async architect(e="execute",t=process.cwd()){if(e!=="execute")return{success:!1,message:"\u274C Invalid action. Use: /p:architect execute"};try{let s=await this.ensureProjectInit(t);if(!s.success)return s;console.log(`\u{1F3D7}\uFE0F Architect Mode - Code Generation
978
- `);let n=await this.getGlobalProjectPath(t),o=en.join(n,"planning","architect-session.md"),i;try{i=await Re.readFile(o)}catch{return{success:!1,message:`\u274C No architect plan found.
1032
+ `;return await nt.get("Write")(v,D),await De.installGlobalConfig(),f.done("architect mode ready"),{success:!0,mode:"architect",projectId:m,idea:y,wizard:a}}return await De.installGlobalConfig(),f.done("initialized"),this._printNextSteps(a),{success:!0,projectId:m,wizard:a}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}_printNextSteps(e){if(console.log(""),console.log(" Quick start:"),console.log(" prjct sync Update context after changes"),console.log(" prjct task Start working on a task"),console.log(" prjct hooks Auto-sync on commit/checkout"),console.log(""),e){let t=e.agents.map(s=>{switch(s){case"claude":return"CLAUDE.md";case"cursor":return".cursorrules";case"windsurf":return".windsurfrules";case"copilot":return".github/copilot-instructions.md";case"gemini":return"GEMINI.md";case"codex":return"AGENTS.md";default:return null}}).filter(Boolean);t.length>0&&(console.log(` Generated: ${t.join(", ")}`),console.log(""))}console.log(" Docs: https://prjct.app/docs"),console.log("")}async feature(e,t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;if(!e)return f.fail("description required"),{success:!1,error:"Description required"};let n=await $.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};f.spin(`planning ${e}...`);let o=this._breakdownFeatureTasks(e),i=ye();return await be.addTasks(n,o.map(a=>({description:a,priority:"medium",type:"feature",section:"active",featureId:i,originFeature:e}))),await this.logToMemory(t,"feature_planned",{feature:e,featureId:i,tasks:o.length,timestamp:J.getTimestamp()}),f.done(`${o.length} tasks planned`),{success:!0,feature:e,featureId:i,tasks:o}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}async bug(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;if(!e)return s.md||f.fail("bug description required"),{success:!1,error:"Description required"};let o=await $.getProjectId(t);if(!o)return s.md||f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};s.md||f.spin("tracking bug...");let i=this._detectBugSeverity(e),c={critical:"critical",high:"high",medium:"medium",low:"low"}[i]||"medium";return await be.addTask(o,{description:e,priority:c,type:"bug",section:"active"}),await this.logToMemory(t,"bug_reported",{bug:e,severity:i,priority:c,timestamp:J.getTimestamp()}),s.md?console.log(L(Q("Bug Reported",e),lt({Severity:i,Priority:c}),ge([{label:"Fix now",command:`prjct task "fix: ${e}" --md`},{label:"View queue",command:"prjct next --md"}]))):(f.done(`bug [${i}] [${c}]`),At("bug")),{success:!0,bug:e,severity:i}}catch(n){return s.md||f.fail(w(n)),{success:!1,error:w(n)}}}async architect(e="execute",t=process.cwd()){if(e!=="execute")return{success:!1,message:"\u274C Invalid action. Use: /p:architect execute"};try{let s=await this.ensureProjectInit(t);if(!s.success)return s;console.log(`\u{1F3D7}\uFE0F Architect Mode - Code Generation
1033
+ `);let n=await this.getGlobalProjectPath(t),o=tn.join(n,"planning","architect-session.md"),i;try{i=await Re.readFile(o)}catch{return{success:!1,message:`\u274C No architect plan found.
979
1034
 
980
1035
  Create a plan first:
981
1036
  1. Run /p:init in an empty directory
@@ -996,7 +1051,7 @@ The architect plan is ready. Claude will now:
996
1051
  4. Create starter files with boilerplate
997
1052
  `),console.log(`
998
1053
  \u{1F4A1} This command shows the plan.`),console.log(" For code generation, Claude Code will read this plan"),console.log(` and generate the structure automatically.
999
- `),await this.logToMemory(t,"architect_executed",{timestamp:z.getTimestamp(),idea:p}),{success:!0,plan:i,idea:p}}catch(s){return console.error("\u274C Error:",y(s)),{success:!1,error:y(s)}}}async idea(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;if(!e)return s.md||f.fail("idea description required"),{success:!1,error:"Idea description required"};let o=await I.getProjectId(t);if(!o)return s.md||f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(e.split(/\s+/).length>20||e.includes("with")||e.includes("that")){s.md||f.spin("analyzing idea...");let c=A.getGlobalProjectPath(o),u=en.join(c,"planning","architect-session.md"),p=`# Architect Session
1054
+ `),await this.logToMemory(t,"architect_executed",{timestamp:J.getTimestamp(),idea:p}),{success:!0,plan:i,idea:p}}catch(s){return console.error("\u274C Error:",w(s)),{success:!1,error:w(s)}}}async idea(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;if(!e)return s.md||f.fail("idea description required"),{success:!1,error:"Idea description required"};let o=await $.getProjectId(t);if(!o)return s.md||f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(e.split(/\s+/).length>20||e.includes("with")||e.includes("that")){s.md||f.spin("analyzing idea...");let c=A.getGlobalProjectPath(o),u=tn.join(c,"planning","architect-session.md"),p=`# Architect Session
1000
1055
 
1001
1056
  ## Idea
1002
1057
  ${e}
@@ -1011,14 +1066,14 @@ Initialized - awaiting architecture design
1011
1066
  4. Generate roadmap
1012
1067
 
1013
1068
  Generated: ${new Date().toLocaleString()}
1014
- `;return await st.get("Write")(u,p),await this.logToMemory(t,"idea_architecture_started",{idea:e,timestamp:z.getTimestamp()}),s.md?console.log(U(se("Idea Captured",e),mt({Mode:"architecture"}),ge([{label:"Continue planning",command:"prjct architect execute"}]))):(f.done("architecture session created"),console.log(`
1069
+ `;return await nt.get("Write")(u,p),await this.logToMemory(t,"idea_architecture_started",{idea:e,timestamp:J.getTimestamp()}),s.md?console.log(L(Q("Idea Captured",e),lt({Mode:"architecture"}),ge([{label:"Continue planning",command:"prjct architect execute"}]))):(f.done("architecture session created"),console.log(`
1015
1070
  \u{1F4A1} Use /p:architect execute to continue planning
1016
- `)),{success:!0,mode:"architecture",idea:e}}else return s.md||f.spin("capturing idea..."),await He.addIdea(o,e),await this.logToMemory(t,"idea_captured",{idea:e,timestamp:z.getTimestamp()}),s.md?console.log(U(se("Idea Captured",e),mt({Mode:"capture"}),ge([{label:"Start working on it",command:`prjct task "${e}" --md`},{label:"View ideas",command:"prjct dash ideas"}]))):(f.done(`idea captured: ${e.slice(0,40)}`),At("idea")),{success:!0,mode:"capture",idea:e}}catch(n){return s.md||f.fail(y(n)),{success:!1,error:y(n)}}}async spec(e=null,t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let n=await I.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(!e){f.spin("loading specs...");let p=A.getGlobalProjectPath(n),m=en.join(p,"planning","specs");try{let h=(await(await import("node:fs/promises")).readdir(m)).filter(k=>k.endsWith(".md")&&k!==".gitkeep");return h.length===0?(f.warn("no specs yet"),console.log(`
1071
+ `)),{success:!0,mode:"architecture",idea:e}}else return s.md||f.spin("capturing idea..."),await Ge.addIdea(o,e),await this.logToMemory(t,"idea_captured",{idea:e,timestamp:J.getTimestamp()}),s.md?console.log(L(Q("Idea Captured",e),lt({Mode:"capture"}),ge([{label:"Start working on it",command:`prjct task "${e}" --md`},{label:"View ideas",command:"prjct dash ideas"}]))):(f.done(`idea captured: ${e.slice(0,40)}`),At("idea")),{success:!0,mode:"capture",idea:e}}catch(n){return s.md||f.fail(w(n)),{success:!1,error:w(n)}}}async spec(e=null,t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let n=await $.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(!e){f.spin("loading specs...");let p=A.getGlobalProjectPath(n),m=tn.join(p,"planning","specs");try{let h=(await(await import("node:fs/promises")).readdir(m)).filter(k=>k.endsWith(".md")&&k!==".gitkeep");return h.length===0?(f.warn("no specs yet"),console.log(`
1017
1072
  \u{1F4A1} Create one with /p:spec "feature name"
1018
1073
  `),{success:!0,specs:[]}):(console.log(`
1019
1074
  \u{1F4CB} SPECIFICATIONS
1020
- `),console.log("\u2550".repeat(50)),h.forEach((k,w)=>{let T=k.replace(".md","").replace(/-/g," ");console.log(` ${w+1}. ${T}`)}),console.log(`${"\u2550".repeat(50)}
1021
- `),{success:!0,specs:h})}catch{return f.warn("no specs directory"),{success:!0,specs:[]}}}f.spin("creating spec...");let o=A.getGlobalProjectPath(n),i=en.join(o,"planning","specs");await Re.ensureDir(i);let a=e.toLowerCase().replace(/\s+/g,"-"),c=en.join(i,`${a}.md`),u=`# Specification: ${e}
1075
+ `),console.log("\u2550".repeat(50)),h.forEach((k,y)=>{let v=k.replace(".md","").replace(/-/g," ");console.log(` ${y+1}. ${v}`)}),console.log(`${"\u2550".repeat(50)}
1076
+ `),{success:!0,specs:h})}catch{return f.warn("no specs directory"),{success:!0,specs:[]}}}f.spin("creating spec...");let o=A.getGlobalProjectPath(n),i=tn.join(o,"planning","specs");await Re.ensureDir(i);let a=e.toLowerCase().replace(/\s+/g,"-"),c=tn.join(i,`${a}.md`),u=`# Specification: ${e}
1022
1077
 
1023
1078
  ## Overview
1024
1079
  [Brief description of the feature]
@@ -1048,13 +1103,13 @@ Generated: ${new Date().toLocaleString()}
1048
1103
  ---
1049
1104
  Created: ${new Date().toLocaleString()}
1050
1105
  Status: Draft
1051
- `;return await st.get("Write")(c,u),await this.logToMemory(t,"spec_created",{feature:e,timestamp:z.getTimestamp()}),f.done(`spec created: ${a}.md`),console.log(`
1106
+ `;return await nt.get("Write")(c,u),await this.logToMemory(t,"spec_created",{feature:e,timestamp:J.getTimestamp()}),f.done(`spec created: ${a}.md`),console.log(`
1052
1107
  \u{1F4DD} Edit: ~/.prjct-cli/projects/${n}/planning/specs/${a}.md`),console.log(`\u{1F4A1} When ready, use /p:feature to add tasks to queue
1053
- `),{success:!0,feature:e,specPath:c}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}async _seedShipWorkflow(e,t){let s=await oi(t),n=0;Ie.addRule(e,{type:"gate",command:"ship",position:"before",action:'git branch --show-current | grep -vE "^(main|master)$"',description:"Prevent shipping from main branch",enabled:!0,timeoutMs:5e3,sortOrder:n++,createdAt:new Date().toISOString()}),s.lint&&Ie.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:n++,createdAt:new Date().toISOString()}),s.test&&Ie.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:n++,createdAt:new Date().toISOString()})}}});var wl,sn,Cg=S(()=>{"use strict";ss();ho();Et();ve();V();q();Ts();wl=class{static{l(this,"ProjectService")}currentAuthor=null;async ensureInit(e){if(await I.isConfigured(e))return{success:!0};f.spin("initializing project...");let{PlanningCommands:t}=await Promise.resolve().then(()=>(ai(),vg)),n=await new t().init(null,e);return n.success?{success:!0}:n}async getProjectId(e){let t=await I.getProjectId(e);if(!t)throw Yr.notInitialized();return t}async getGlobalPath(e){let t=await this.getProjectId(e);return await A.ensureProjectStructure(t),A.getGlobalProjectPath(t)}async ensureAuthor(){if(this.currentAuthor)return this.currentAuthor;let e=await bn();return this.currentAuthor={name:e.name??void 0,email:e.email??void 0,github:e.github??void 0},this.currentAuthor}getCurrentAuthor(){return this.currentAuthor}clearAuthorCache(){this.currentAuthor=null}async isEmptyDirectory(e){try{return(await ts(e)).filter(n=>!n.startsWith(".")&&n!=="node_modules"&&n!=="package.json"&&n!=="package-lock.json"&&n!=="README.md").length===0}catch(t){return R(t)||console.error(`Directory check error: ${y(t)}`),!0}}async hasExistingCode(e){try{let t=["src","lib","app","components","pages","api","main.go","main.rs","main.py"];return(await ts(e)).some(n=>t.includes(n))}catch(t){return R(t)||console.error(`Code check error: ${y(t)}`),!1}}async isConfigured(e){return await I.isConfigured(e)}async needsMigration(e){return await I.needsMigration(e)}},sn=new wl});var Ce,lt=S(()=>{"use strict";rl();Ac();el();Et();ve();al();wg();dl();zs();Cg();oe();q();Ts();Ce=class{static{l(this,"PrjctCommandsBase")}prjctDir;updateChecker;updateNotificationShown;commandExecutor;constructor(){this.prjctDir=".prjct",this.updateChecker=new ei,this.updateNotificationShown=!1,this.commandExecutor=Zo}get agent(){return ni.getAgent()}get agentInfo(){return ni.getInfo()}get currentAuthor(){return sn.getCurrentAuthor()}async initializeAgent(){return ni.initialize()}async ensureProjectInit(e){return sn.ensureInit(e)}async ensureAuthor(){return sn.ensureAuthor()}async getGlobalProjectPath(e){return sn.getGlobalPath(e)}async logToMemory(e,t,s){let n=await this.ensureAuthor();return xt.log(e,t,s,n.name)}async _detectEmptyDirectory(e){return sn.isEmptyDirectory(e)}async _detectExistingCode(e){return sn.hasExistingCode(e)}_breakdownFeatureTasks(e){return In.breakdownFeature(e)}_detectBugSeverity(e){return In.detectBugSeverity(e)}}});import Nb from"node:path";async function kl(r,e){let t=Date.now()-e;await De.installGlobalConfig(),f.done(`Synced ${r.stats.name||"project"} (${(t/1e3).toFixed(1)}s)`),console.log("");let s=r.stats.frameworks.length>0?` (${r.stats.frameworks[0]})`:"",n=r.syncMetrics?.indexes,o=[`${r.stats.fileCount} files indexed`,`Stack: ${r.stats.ecosystem}${s} | Branch: ${r.git.branch}`];if(n?.bm25Files){let a=n.bm25Files*(n.bm25AvgTokens||0);o.push(`Index: ${Mn(a)} tokens | ${n.bm25VocabSize||0} terms | ${n.importEdges||0} imports`)}f.box("Sync Summary",o.join(`
1054
- `));let i=[];if(r.generatedSkills?.generated&&r.generatedSkills.generated.length>0){let a=r.generatedSkills.generated.length,c=a===1?"skill":"skills";i.push(`${a} ${c} generated`)}if(r.context7&&i.push(`Context7: ${r.context7.verified?"verified":`not ready${r.context7.message?` (${r.context7.message})`:""}`}`),r.analysisSummary&&i.push(`Analysis: ${r.analysisSummary.patterns} patterns | ${r.analysisSummary.antiPatterns} anti-patterns (${r.analysisSummary.criticalAntiPatterns} critical)`),f.section("Generated"),f.list(i,{bullet:"\u2713"}),console.log(""),r.git.hasChanges&&(f.warn("Uncommitted changes detected"),console.log("")),r.verification){let a=r.verification;if(a.passed){let c=a.checks.map(u=>`${u.name} (${u.durationMs}ms)`);f.section("Verified"),f.list(c,{bullet:"\u2713"})}else{f.section("Verification");let c=a.checks.map(u=>u.passed?`\u2713 ${u.name}`:`\u2717 ${u.name}${u.error?` \u2014 ${u.error}`:""}`);f.list(c),a.skippedCount>0&&f.warn(`${a.skippedCount} check(s) skipped (fail-fast)`)}console.log("")}return At("sync"),{success:!0,data:r,metrics:{elapsed:t,fileCount:r.stats.fileCount}}}async function Pg(r){try{let e=await xt.getRecentEvents(r,100),t=new Date().toISOString().split("T")[0],s=e.filter(u=>(u.timestamp||u.ts)?.startsWith(t)),n=null;if(s.length>=2){let u=s.map(p=>new Date(p.timestamp||p.ts).getTime()).filter(p=>!Number.isNaN(p)).sort((p,m)=>p-m);if(u.length>=2){let p=u[u.length-1]-u[0];n=z.formatDuration(p)}}let o=s.filter(u=>u.action==="task_completed").length,i=s.filter(u=>u.action==="feature_shipped").length,a=new Map;for(let u of s)if(u.action==="sync"&&Array.isArray(u.subagents))for(let p of u.subagents)a.set(p,(a.get(p)||0)+1);let c=Array.from(a.entries()).map(([u,p])=>({name:u,count:p})).sort((u,p)=>p.count-u.count);return{sessionDuration:n,tasksCompleted:o,featuresShipped:i,agentsUsed:c}}catch{return{sessionDuration:null,tasksCompleted:0,featuresShipped:0,agentsUsed:[]}}}function Mn(r){return r>=1e6?`${(r/1e6).toFixed(1)}M`:r>=1e3?`${(r/1e3).toFixed(1)}K`:r.toLocaleString()}function Sl(r){return r<1e3?`${Math.round(r)}ms`:`${(r/1e3).toFixed(1)}s`}function Eg(r){if(r.length===0)return"";let e="\u2581\u2582\u2583\u2584\u2585\u2586\u2587\u2588",t=r.map(n=>n.tokensSaved),s=Math.max(...t,1);return t.map(n=>{let o=Math.min(Math.floor(n/s*(e.length-1)),e.length-1);return e[o]}).join("")}function xg(r,e,t,s,n,o){let i=[];if(i.push(`# ${t} - Stats Dashboard`),i.push(""),i.push(`_Generated: ${new Date().toLocaleString()} | Tracking since: ${s}_`),i.push(""),n){if(i.push("## \u{1F3AF} Today's Activity"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),n.sessionDuration&&i.push(`| Duration | ${n.sessionDuration} |`),i.push(`| Tasks completed | ${n.tasksCompleted} |`),i.push(`| Features shipped | ${n.featuresShipped} |`),n.agentsUsed.length>0){let a=n.agentsUsed.slice(0,3).map(c=>`${c.name} (${c.count}\xD7)`).join(", ");i.push(`| Agents used | ${a} |`)}i.push("")}if(o&&(o.decisions>0||o.preferences>0)&&(i.push("## \u{1F9E0} Patterns Learned"),i.push(""),i.push("| Type | Count |"),i.push("|------|-------|"),i.push(`| Decisions | ${o.learnedDecisions} confirmed (${o.decisions} total) |`),i.push(`| Preferences | ${o.preferences} |`),i.push(`| Workflows | ${o.workflows} |`),i.push("")),i.push("## \u{1F4B0} Context Efficiency"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Tokens reduced | ${Mn(r.totalTokensSaved)} |`),i.push(`| Compression | ${(r.compressionRate*100).toFixed(0)}% |`),i.push(`| Est. cost saved | ${oo(r.estimatedCostSaved)} |`),i.push(""),i.push("## \u26A1 Performance"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Syncs | ${r.syncCount} |`),i.push(`| Avg time | ${Sl(r.avgSyncDuration)} |`),i.push(""),r.topAgents.length>0){i.push("## \u{1F916} Agent Usage"),i.push(""),i.push("| Agent | Usage |"),i.push("|-------|-------|");let a=r.topAgents.reduce((c,u)=>c+u.usageCount,0);for(let c of r.topAgents){let u=a>0?(c.usageCount/a*100).toFixed(0):0;i.push(`| ${c.agentName} | ${u}% (${c.usageCount}) |`)}i.push("")}if(i.push("## \u{1F4C8} 30-Day Trend"),i.push(""),i.push(`- Tokens saved: ${Mn(r.last30DaysTokens)}`),r.trend!==0){let a=r.trend>0?"+":"";i.push(`- Trend: ${a}${r.trend.toFixed(0)}% vs previous period`)}return i.push(""),i.push("---"),i.push(""),i.push("_Generated with [prjct-cli](https://prjct.app)_"),i.join(`
1055
- `)}function Rg(r,e){let t=[];t.push(`# Repository Analysis
1108
+ `),{success:!0,feature:e,specPath:c}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}async _seedShipWorkflow(e,t){let s=await li(t),n=0;je.addRule(e,{type:"gate",command:"ship",position:"before",action:'git branch --show-current | grep -vE "^(main|master)$"',description:"Prevent shipping from main branch",enabled:!0,timeoutMs:5e3,sortOrder:n++,createdAt:new Date().toISOString()}),s.lint&&je.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:n++,createdAt:new Date().toISOString()}),s.test&&je.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:n++,createdAt:new Date().toISOString()})}}});var Sl,nn,xg=S(()=>{"use strict";ss();So();Et();Te();W();K();vs();Sl=class{static{l(this,"ProjectService")}currentAuthor=null;async ensureInit(e){if(await $.isConfigured(e))return{success:!0};f.spin("initializing project...");let{PlanningCommands:t}=await Promise.resolve().then(()=>(di(),Pg)),n=await new t().init(null,e);return n.success?{success:!0}:n}async getProjectId(e){let t=await $.getProjectId(e);if(!t)throw to.notInitialized();return t}async getGlobalPath(e){let t=await this.getProjectId(e);return await A.ensureProjectStructure(t),A.getGlobalProjectPath(t)}async ensureAuthor(){if(this.currentAuthor)return this.currentAuthor;let e=await Tn();return this.currentAuthor={name:e.name??void 0,email:e.email??void 0,github:e.github??void 0},this.currentAuthor}getCurrentAuthor(){return this.currentAuthor}clearAuthorCache(){this.currentAuthor=null}async isEmptyDirectory(e){try{return(await ts(e)).filter(n=>!n.startsWith(".")&&n!=="node_modules"&&n!=="package.json"&&n!=="package-lock.json"&&n!=="README.md").length===0}catch(t){return R(t)||console.error(`Directory check error: ${w(t)}`),!0}}async hasExistingCode(e){try{let t=["src","lib","app","components","pages","api","main.go","main.rs","main.py"];return(await ts(e)).some(n=>t.includes(n))}catch(t){return R(t)||console.error(`Code check error: ${w(t)}`),!1}}async isConfigured(e){return await $.isConfigured(e)}async needsMigration(e){return await $.needsMigration(e)}},nn=new Sl});var Ce,dt=S(()=>{"use strict";il();jc();sl();Et();Te();ll();bg();ml();Js();xg();ie();K();vs();Ce=class{static{l(this,"PrjctCommandsBase")}prjctDir;updateChecker;updateNotificationShown;commandExecutor;constructor(){this.prjctDir=".prjct",this.updateChecker=new ri,this.updateNotificationShown=!1,this.commandExecutor=ni}get agent(){return ai.getAgent()}get agentInfo(){return ai.getInfo()}get currentAuthor(){return nn.getCurrentAuthor()}async initializeAgent(){return ai.initialize()}async ensureProjectInit(e){return nn.ensureInit(e)}async ensureAuthor(){return nn.ensureAuthor()}async getGlobalProjectPath(e){return nn.getGlobalPath(e)}async logToMemory(e,t,s){let n=await this.ensureAuthor();return xt.log(e,t,s,n.name)}async _detectEmptyDirectory(e){return nn.isEmptyDirectory(e)}async _detectExistingCode(e){return nn.hasExistingCode(e)}_breakdownFeatureTasks(e){return In.breakdownFeature(e)}_detectBugSeverity(e){return In.detectBugSeverity(e)}}});import Ub from"node:path";async function bl(r,e){let t=Date.now()-e;await De.installGlobalConfig(),f.done(`Synced ${r.stats.name||"project"} (${(t/1e3).toFixed(1)}s)`),console.log("");let s=r.stats.frameworks.length>0?` (${r.stats.frameworks[0]})`:"",n=r.syncMetrics?.indexes,o=[`${r.stats.fileCount} files indexed`,`Stack: ${r.stats.ecosystem}${s} | Branch: ${r.git.branch}`];if(n?.bm25Files){let a=n.bm25Files*(n.bm25AvgTokens||0);o.push(`Index: ${Mn(a)} tokens | ${n.bm25VocabSize||0} terms | ${n.importEdges||0} imports`)}f.box("Sync Summary",o.join(`
1109
+ `));let i=[];if(r.generatedSkills?.generated&&r.generatedSkills.generated.length>0){let a=r.generatedSkills.generated.length,c=a===1?"skill":"skills";i.push(`${a} ${c} generated`)}if(r.context7&&i.push(`Context7: ${r.context7.verified?"verified":`not ready${r.context7.message?` (${r.context7.message})`:""}`}`),r.analysisSummary&&i.push(`Analysis: ${r.analysisSummary.patterns} patterns | ${r.analysisSummary.antiPatterns} anti-patterns (${r.analysisSummary.criticalAntiPatterns} critical)`),f.section("Generated"),f.list(i,{bullet:"\u2713"}),console.log(""),r.git.hasChanges&&(f.warn("Uncommitted changes detected"),console.log("")),r.verification){let a=r.verification;if(a.passed){let c=a.checks.map(u=>`${u.name} (${u.durationMs}ms)`);f.section("Verified"),f.list(c,{bullet:"\u2713"})}else{f.section("Verification");let c=a.checks.map(u=>u.passed?`\u2713 ${u.name}`:`\u2717 ${u.name}${u.error?` \u2014 ${u.error}`:""}`);f.list(c),a.skippedCount>0&&f.warn(`${a.skippedCount} check(s) skipped (fail-fast)`)}console.log("")}return At("sync"),{success:!0,data:r,metrics:{elapsed:t,fileCount:r.stats.fileCount}}}async function Rg(r){try{let e=await xt.getRecentEvents(r,100),t=new Date().toISOString().split("T")[0],s=e.filter(u=>(u.timestamp||u.ts)?.startsWith(t)),n=null;if(s.length>=2){let u=s.map(p=>new Date(p.timestamp||p.ts).getTime()).filter(p=>!Number.isNaN(p)).sort((p,m)=>p-m);if(u.length>=2){let p=u[u.length-1]-u[0];n=J.formatDuration(p)}}let o=s.filter(u=>u.action==="task_completed").length,i=s.filter(u=>u.action==="feature_shipped").length,a=new Map;for(let u of s)if(u.action==="sync"&&Array.isArray(u.subagents))for(let p of u.subagents)a.set(p,(a.get(p)||0)+1);let c=Array.from(a.entries()).map(([u,p])=>({name:u,count:p})).sort((u,p)=>p.count-u.count);return{sessionDuration:n,tasksCompleted:o,featuresShipped:i,agentsUsed:c}}catch{return{sessionDuration:null,tasksCompleted:0,featuresShipped:0,agentsUsed:[]}}}function Mn(r){return r>=1e6?`${(r/1e6).toFixed(1)}M`:r>=1e3?`${(r/1e3).toFixed(1)}K`:r.toLocaleString()}function Tl(r){return r<1e3?`${Math.round(r)}ms`:`${(r/1e3).toFixed(1)}s`}function Ag(r){if(r.length===0)return"";let e="\u2581\u2582\u2583\u2584\u2585\u2586\u2587\u2588",t=r.map(n=>n.tokensSaved),s=Math.max(...t,1);return t.map(n=>{let o=Math.min(Math.floor(n/s*(e.length-1)),e.length-1);return e[o]}).join("")}function Dg(r,e,t,s,n,o){let i=[];if(i.push(`# ${t} - Stats Dashboard`),i.push(""),i.push(`_Generated: ${new Date().toLocaleString()} | Tracking since: ${s}_`),i.push(""),n){if(i.push("## Today's Activity"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),n.sessionDuration&&i.push(`| Duration | ${n.sessionDuration} |`),i.push(`| Tasks completed | ${n.tasksCompleted} |`),i.push(`| Features shipped | ${n.featuresShipped} |`),n.agentsUsed.length>0){let a=n.agentsUsed.slice(0,3).map(c=>`${c.name} (${c.count}\xD7)`).join(", ");i.push(`| Agents used | ${a} |`)}i.push("")}if(o&&(o.decisions>0||o.preferences>0)&&(i.push("## Patterns Learned"),i.push(""),i.push("| Type | Count |"),i.push("|------|-------|"),i.push(`| Decisions | ${o.learnedDecisions} confirmed (${o.decisions} total) |`),i.push(`| Preferences | ${o.preferences} |`),i.push(`| Workflows | ${o.workflows} |`),i.push("")),i.push("## Context Efficiency"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Tokens reduced | ${Mn(r.totalTokensSaved)} |`),i.push(`| Compression | ${(r.compressionRate*100).toFixed(0)}% |`),i.push(`| Est. cost saved | ${lo(r.estimatedCostSaved)} |`),i.push(""),i.push("## Performance"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Syncs | ${r.syncCount} |`),i.push(`| Avg time | ${Tl(r.avgSyncDuration)} |`),i.push(""),r.topAgents.length>0){i.push("## Agent Usage"),i.push(""),i.push("| Agent | Usage |"),i.push("|-------|-------|");let a=r.topAgents.reduce((c,u)=>c+u.usageCount,0);for(let c of r.topAgents){let u=a>0?(c.usageCount/a*100).toFixed(0):0;i.push(`| ${c.agentName} | ${u}% (${c.usageCount}) |`)}i.push("")}if(i.push("## 30-Day Trend"),i.push(""),i.push(`- Tokens saved: ${Mn(r.last30DaysTokens)}`),r.trend!==0){let a=r.trend>0?"+":"";i.push(`- Trend: ${a}${r.trend.toFixed(0)}% vs previous period`)}return i.push(""),i.push("---"),i.push(""),i.push("_Generated with [prjct-cli](https://prjct.app)_"),i.join(`
1110
+ `)}function jg(r,e){let t=[];t.push(`# Repository Analysis
1056
1111
  `),t.push(`Generated: ${new Date().toLocaleString()}
1057
- `);let s=Nb.basename(e);if(t.push(`## Project: ${s}
1112
+ `);let s=Ub.basename(e);if(t.push(`## Project: ${s}
1058
1113
  `),t.push(`## Stack Detected
1059
1114
  `),r.packageJson){let i=r.packageJson;if(t.push(`### JavaScript/TypeScript
1060
1115
  `),t.push("- **Package Manager**: npm/yarn/pnpm"),i.dependencies){let a=Object.keys(i.dependencies);a.length>0&&t.push(`- **Dependencies**: ${a.slice(0,10).join(", ")}${a.length>10?` (+${a.length-10} more)`:""}`)}r.hasNextConfig&&t.push("- **Framework**: Next.js detected"),r.hasViteConfig&&t.push("- **Build Tool**: Vite detected"),r.hasTsconfig&&t.push("- **Language**: TypeScript"),t.push("")}r.cargoToml&&(t.push(`### Rust
@@ -1070,67 +1125,37 @@ Status: Draft
1070
1125
  `).slice(0,5).forEach(a=>{if(a.trim()){let[c,,u,p]=a.split("|");t.push(`- \`${c}\` ${p} (${u})`)}}),t.push("")),t.push(`## Recommendations
1071
1126
  `),t.push("Based on detected stack, consider generating specialized agents using `/p:sync`.\n"),t.push(`---
1072
1127
  `),t.push("*This analysis was generated automatically. For updated information, run `/p:analyze` again.*\n"),t.join(`
1073
- `)}var Ag=S(()=>{"use strict";os();io();zs();En();Ts();lt();l(kl,"showSyncResult");l(Pg,"getSessionActivity");l(Mn,"formatTokens");l(Sl,"formatDuration");l(Eg,"generateSparkline");l(xg,"generateStatsMarkdown");l(Rg,"generateAnalysisSummary")});var Tg={};Bt(Tg,{AnalysisCommands:()=>rn});import bl from"node:fs/promises";import Dg from"node:path";import*as nn from"@clack/prompts";var rn,ci=S(()=>{"use strict";mr();vu();os();io();ia();rd();ud();Ea();kc();wn();ce();kr();Ka();V();Pn();En();Ts();Ag();lt();rn=class extends Ce{static{l(this,"AnalysisCommands")}async analyze(e={},t=process.cwd()){try{await this.initializeAgent(),console.log(`\u{1F50D} Analyzing repository...
1074
- `),Je.init(t);let s=await Ht.build(t,e),n={packageJson:await Je.readPackageJson(),cargoToml:await Je.readCargoToml(),goMod:await Je.readGoMod(),requirements:await Je.readRequirements(),directories:await Je.listDirectories(),fileCount:await Je.countFiles(),gitStats:await Je.getGitStats(),gitLog:await Je.getGitLog(20),hasDockerfile:await Je.fileExists("Dockerfile"),hasDockerCompose:await Je.fileExists("docker-compose.yml"),hasReadme:await Je.fileExists("README.md"),hasTsconfig:await Je.fileExists("tsconfig.json"),hasViteConfig:await Je.fileExists("vite.config.ts")||await Je.fileExists("vite.config.js"),hasNextConfig:await Je.fileExists("next.config.js")||await Je.fileExists("next.config.mjs")},o=Rg(n,t),i=await I.getProjectId(t),a=s.paths.analysis||A.getFilePath(i,"analysis","repo-summary.md");await st.get("Write")(a,o),await this.logToMemory(t,"repository_analyzed",{timestamp:z.getTimestamp(),fileCount:n.fileCount,gitCommits:n.gitStats.totalCommits});let u=await(it(),bt(Tt)).getActiveProvider(),p=await De.installGlobalConfig();return p.success&&console.log(`\u{1F4DD} Updated ${A.getDisplayPath(p.path)}`),console.log(`\u2705 Analysis complete!
1128
+ `)}var Ig=S(()=>{"use strict";os();uo();Js();En();vs();dt();l(bl,"showSyncResult");l(Rg,"getSessionActivity");l(Mn,"formatTokens");l(Tl,"formatDuration");l(Ag,"generateSparkline");l(Dg,"generateStatsMarkdown");l(jg,"generateAnalysisSummary")});var Eg={};Ot(Eg,{AnalysisCommands:()=>on});import vl from"node:fs/promises";import $g from"node:path";import*as rn from"@clack/prompts";var on,pi=S(()=>{"use strict";mr();Pu();os();uo();ca();ad();md();Ra();bc();kn();re();kr();Ya();W();Ks();En();vs();Ig();dt();on=class extends Ce{static{l(this,"AnalysisCommands")}async analyze(e={},t=process.cwd()){try{await this.initializeAgent(),console.log(`\u{1F50D} Analyzing repository...
1129
+ `),Je.init(t);let s=await Wt.build(t,e),n={packageJson:await Je.readPackageJson(),cargoToml:await Je.readCargoToml(),goMod:await Je.readGoMod(),requirements:await Je.readRequirements(),directories:await Je.listDirectories(),fileCount:await Je.countFiles(),gitStats:await Je.getGitStats(),gitLog:await Je.getGitLog(20),hasDockerfile:await Je.fileExists("Dockerfile"),hasDockerCompose:await Je.fileExists("docker-compose.yml"),hasReadme:await Je.fileExists("README.md"),hasTsconfig:await Je.fileExists("tsconfig.json"),hasViteConfig:await Je.fileExists("vite.config.ts")||await Je.fileExists("vite.config.js"),hasNextConfig:await Je.fileExists("next.config.js")||await Je.fileExists("next.config.mjs")},o=jg(n,t),i=await $.getProjectId(t),a=s.paths.analysis||A.getFilePath(i,"analysis","repo-summary.md");await nt.get("Write")(a,o),await this.logToMemory(t,"repository_analyzed",{timestamp:J.getTimestamp(),fileCount:n.fileCount,gitCommits:n.gitStats.totalCommits});let u=await(at(),ot(vt)).getActiveProvider(),p=await De.installGlobalConfig();return p.success&&console.log(`\u{1F4DD} Updated ${A.getDisplayPath(p.path)}`),console.log(`\u2705 Analysis complete!
1075
1130
  `),console.log(`\u{1F4C4} Full report: ${A.getDisplayPath(a)}`),console.log(`\u{1F4DD} Context: ~/.prjct-cli/projects/${i}/${u.contextFile}
1076
- `),console.log("Next steps:"),console.log("\u2022 /p:sync \u2192 Generate agents based on stack"),console.log("\u2022 /p:feature \u2192 Add a new feature"),{success:!0,summaryPath:a,data:n}}catch(s){return console.error("\u274C Error:",y(s)),{success:!1,error:y(s)}}}async sync(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=A.getGlobalProjectPath(n),i=Date.now();if(t.package){let m=await A.detectMonorepo(e);if(!m.isMonorepo)return{success:!1,error:"Not a monorepo. --package flag only works in monorepos."};let d=m.packages.find(h=>h.name===t.package||h.relativePath===t.package);if(!d){let h=m.packages.map(k=>k.name).join(", ");return{success:!1,error:`Package "${t.package}" not found. Available: ${h}`}}let g=await qs.sync(e,{packagePath:d.path,packageName:d.name});return t.json?console.log(JSON.stringify({success:g.success,package:d.name,path:d.relativePath})):t.md?console.log(U(ke(`Synced package: ${d.name}`))):f.done(`Synced package: ${d.name}`),{success:g.success}}let a=Dg.join(o,"context","CLAUDE.md"),c=null;try{c=await bl.readFile(a,"utf-8")}catch{}let u=!process.stdin.isTTY||t.json||t.md;if(c&&!t.yes&&!u){u||f.spin("Analyzing changes...");let m=await qs.sync(e,{full:t.full});if(!m.success)return t.md?(console.log(U("## \u274C Sync Failed",`> ${m.error||"Unknown error"}`)),{success:!1,error:m.error}):u?(console.log(JSON.stringify({success:!1,error:m.error||"Sync failed"})),{success:!1,error:m.error}):(f.fail(m.error||"Sync failed"),{success:!1,error:m.error});let d;try{d=await bl.readFile(a,"utf-8")}catch{d=""}let g=ad(c,d);if(u||f.stop(),!g.hasChanges)return t.md?(console.log(U(ke("No changes detected","Context is up to date."))),{success:!0,message:"No changes"}):u?(console.log(JSON.stringify({success:!0,action:"no_changes",message:"No changes detected (context is up to date)"})),{success:!0,message:"No changes"}):(f.done("No changes detected (context is up to date)"),{success:!0,message:"No changes"});let h=l(async()=>{c!=null&&await bl.writeFile(a,c,"utf-8")},"restoreOriginal");if(t.md){await h();let w=[];for(let E of g.added)w.push(`Added: ${E.name} (${E.lineCount} lines)`);for(let E of g.modified)w.push(`Modified: ${E.name} (${E.lineCount} lines)`);for(let E of g.removed)w.push(`Removed: ${E.name} (${E.lineCount} lines)`);let T=U("## \u26A1 Sync Preview",w.length>0?se("Changes",je(w)):"No section changes.",mt({"Tokens before":g.tokensBefore,"Tokens after":g.tokensAfter,"Token delta":g.tokenDelta>0?`+${g.tokenDelta}`:String(g.tokenDelta)}),"> Run `prjct sync --yes` to apply changes.");return console.log(T),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(u){await h();let w={added:g.added.map(T=>({name:T.name,lineCount:T.lineCount})),modified:g.modified.map(T=>({name:T.name,lineCount:T.lineCount})),removed:g.removed.map(T=>({name:T.name,lineCount:T.lineCount})),preserved:g.preserved,tokensBefore:g.tokensBefore,tokensAfter:g.tokensAfter,tokenDelta:g.tokenDelta};return console.log(JSON.stringify({success:!0,action:"confirm_required",message:"Changes detected. Confirmation required to apply.",diff:w,fullDiff:t.preview?{added:g.added,modified:g.modified,removed:g.removed}:void 0,hint:"Run `prjct sync --yes` to apply changes"})),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(console.log(cd(g)),t.preview)return await h(),{success:!0,isPreview:!0,diff:g,message:"Preview complete (no changes applied)"};let k=await nn.select({message:"Apply these changes?",options:[{label:"Yes, apply changes",value:"apply"},{label:"No, cancel",value:"cancel"},{label:"Show full diff",value:"diff"}]});if(nn.isCancel(k)||k==="cancel")return await h(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"};if(k==="diff"){console.log(`
1077
- ${ld(g)}`);let w=await nn.confirm({message:"Apply these changes?",initialValue:!0});if(nn.isCancel(w)||!w)return await h(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"}}return f.done("Changes applied"),kl(m,i)}t.md||f.spin("Syncing project...");let p=await qs.sync(e,{full:t.full});if(!p.success)return t.md?console.log(U("## \u274C Sync Failed",`> ${p.error||"Unknown error"}`)):f.fail(p.error||"Sync failed"),{success:!1,error:p.error};if(t.md||f.stop(),t.md){let m=Date.now()-i,d=p.generatedSkills?.generated?.length??0,g=null;try{let M=await qe.diff(n);M?.hasChanges&&(g=oa(M))}catch{}let h=`## LLM Analysis (hybrid pipeline)
1078
-
1079
- After sync, run the analysis payload builder:
1080
- \`\`\`bash
1081
- prjct analysis-payload --md
1082
- \`\`\`
1083
-
1084
- If the output says "Analysis is current", skip analysis.
1085
-
1086
- Otherwise, analyze the JSON payload and produce a structured \`LLMAnalysis\` JSON:
1087
-
1088
- \`\`\`json
1089
- {
1090
- "version": 1,
1091
- "commitHash": "from payload git data",
1092
- "analyzedAt": "ISO timestamp",
1093
- "architecture": {
1094
- "style": "monolith|monorepo|microservices|modular-monolith",
1095
- "insights": ["key architectural observations"],
1096
- "domains": ["identified modules/domains"]
1097
- },
1098
- "patterns": [{"name": "", "description": "", "locations": [], "confidence": 0.0, "category": ""}],
1099
- "antiPatterns": [{"issue": "", "reasoning": "", "files": [], "suggestion": "", "severity": "low|medium|high", "confidence": 0.0}],
1100
- "techDebt": [{"description": "", "area": "", "effort": "small|medium|large", "impact": "", "priority": "low|medium|high"}],
1101
- "riskAreas": [{"path": "", "reason": "", "risk": "", "severity": "low|medium|high"}],
1102
- "refactorSuggestions": [{"description": "", "files": [], "benefit": "", "effort": "small|medium|large"}],
1103
- "projectInsights": ["key insights about the project"],
1104
- "conventions": [{"category": "naming|file-structure|imports|error-handling", "rule": "", "example": ""}],
1105
- "commands": {"build": "", "test": "", "lint": "", "dev": "", "format": "", "install": ""},
1106
- "stack": {"languages": [], "frameworks": [], "packageManager": "npm|bun|pnpm|yarn|cargo|go"}
1107
- }
1108
- \`\`\`
1109
-
1110
- Save the analysis:
1111
- \`\`\`bash
1112
- prjct analysis-save-llm '<your JSON here>' --md
1113
- \`\`\``,k=_o("sync"),w=p.syncMetrics?.indexes,T={Duration:`${(m/1e3).toFixed(1)}s`,Skills:`${d} generated`,"Files indexed":p.stats.fileCount};if(w?.bm25Files){let M=w.bm25Files*(w.bm25AvgTokens||0);T["Tokens indexed"]=`${Math.round(M/1e3)}K`,T["Import edges"]=w.importEdges||0,T["Co-change commits"]=w.cochangeCommits||0}let E=U(ke("Sync Complete"),mt(T),g,p.git.hasChanges?Up("Uncommitted changes detected"):null,h,ge(k.map(M=>({label:M.desc,command:M.cmd}))));return console.log(E),{success:!0,data:p,metrics:{elapsed:m,skillCount:d,fileCount:p.stats.fileCount}}}return kl(p,i)}catch(s){return t.md?console.log(U("## \u274C Sync Failed",`> ${y(s)}`)):f.fail(y(s)),{success:!1,error:y(s)}}}async analysisPayload(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=await qs.sync(e);if(!o.success)return{success:!1,error:o.error||"Failed to gather project data"};let i=o.git.recentCommits[0]?.hash??null;if(i&&Kt.isCurrent(n,i))return t.md?console.log(U(ke("LLM analysis is current"),"> No re-analysis needed.")):console.log(JSON.stringify({success:!0,action:"skip",message:"Analysis is current"})),{success:!0,message:"Analysis is current"};let a=await nd(n,e,o.git,o.stats);return t.md?console.log(U("## \u{1F50D} Analysis Payload","> Analyze this project data and produce structured findings.","","```json",JSON.stringify(a,null,2),"```","","> After analyzing, call: `prjct analysis save-llm --json '{...}'`")):console.log(JSON.stringify({success:!0,payload:a})),{success:!0,data:a}}catch(s){return{success:!1,error:y(s)}}}async saveLlmAnalysis(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.getProjectId(t);if(!o)return{success:!1,error:"No project ID found"};let i=JSON.parse(e);return!i.version||!i.architecture||!i.patterns?{success:!1,error:"Invalid LLM analysis format. Missing required fields."}:(Kt.save(o,i),s.md?console.log(U(ke("LLM Analysis Saved"),mt({Architecture:i.architecture.style,Patterns:i.patterns.length,"Anti-patterns":i.antiPatterns?.length||0,"Tech debt items":i.techDebt?.length||0,"Risk areas":i.riskAreas?.length||0,Conventions:i.conventions?.length||0}))):console.log(JSON.stringify({success:!0,message:"LLM analysis saved",stats:{patterns:i.patterns.length,antiPatterns:i.antiPatterns?.length||0,techDebt:i.techDebt?.length||0}})),{success:!0})}catch(n){return{success:!1,error:y(n)}}}async getLlmAnalysis(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=Kt.getActive(n);if(!o)return t.md?console.log(U("## No LLM Analysis","> Run `prjct sync` to generate.")):console.log(JSON.stringify({success:!1,message:"No LLM analysis found"})),{success:!1,message:"No LLM analysis found"};if(t.md){let i=[ke(`LLM Analysis (${o.architecture.style})`),""];o.architecture.insights.length>0&&i.push(se("Architecture Insights",je(o.architecture.insights))),o.patterns.length>0&&i.push(se("Patterns",je(o.patterns.map(a=>`**${a.name}** \u2014 ${a.description} (${a.category})`)))),o.antiPatterns.length>0&&i.push(se("Anti-Patterns",je(o.antiPatterns.map(a=>`[${a.severity}] ${a.issue} \u2014 ${a.suggestion}`)))),o.techDebt.length>0&&i.push(se("Tech Debt",je(o.techDebt.map(a=>`[${a.priority}/${a.effort}] ${a.description}`)))),o.conventions.length>0&&i.push(se("Conventions",je(o.conventions.map(a=>`**${a.category}**: ${a.rule}`)))),console.log(U(...i))}else console.log(JSON.stringify({success:!0,analysis:o}));return{success:!0,data:o}}catch(s){return{success:!1,error:y(s)}}}async stats(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=await Cn.getSummary(n),i=await Cn.getDailyStats(n,30),a=await Pg(n),c=await at.getPatternsSummary(n);if(t.json){let d={session:a,patterns:c,totalTokensSaved:o.totalTokensSaved,estimatedCostSaved:o.estimatedCostSaved,compressionRate:o.compressionRate,syncCount:o.syncCount,avgSyncDuration:o.avgSyncDuration,topAgents:o.topAgents,last30DaysTokens:o.last30DaysTokens,trend:o.trend,dailyStats:i};return console.log(JSON.stringify(d,null,2)),{success:!0,data:d}}let u="Unknown";try{u=P.getDoc(n,"project")?.name||"Unknown"}catch{}let p=await Cn.read(n),m=p.firstSync?new Date(p.firstSync).toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}):"N/A";if(console.log(""),console.log("\u256D\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256E"),console.log("\u2502 \u{1F4CA} prjct-cli Stats Dashboard \u2502"),console.log(`\u2502 Project: ${u.padEnd(20).slice(0,20)} | Since: ${m.padEnd(12).slice(0,12)} \u2502`),console.log("\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256F"),console.log(""),console.log("\u{1F3AF} TODAY'S ACTIVITY"),a.sessionDuration&&console.log(` Duration: ${a.sessionDuration}`),console.log(` Tasks completed: ${a.tasksCompleted}`),console.log(` Features shipped: ${a.featuresShipped}`),a.agentsUsed.length>0){let d=a.agentsUsed.slice(0,3).map(g=>`${g.name} (${g.count}\xD7)`).join(", ");console.log(` Agents used: ${d}`)}if(console.log(""),(c.decisions>0||c.preferences>0)&&(console.log("\u{1F9E0} PATTERNS LEARNED"),console.log(` Decisions: ${c.learnedDecisions} confirmed (${c.decisions} total)`),console.log(` Preferences: ${c.preferences} saved`),console.log(` Workflows: ${c.workflows} tracked`),console.log("")),console.log("\u{1F4B0} TOKEN SAVINGS"),console.log(` Total saved: ${Mn(o.totalTokensSaved)} tokens`),console.log(` Compression: ${(o.compressionRate*100).toFixed(0)}% average reduction`),console.log(` Estimated cost: ${oo(o.estimatedCostSaved)} saved`),console.log(""),console.log("\u26A1 PERFORMANCE"),console.log(` Syncs completed: ${o.syncCount.toLocaleString()}`),console.log(` Avg sync time: ${Sl(o.avgSyncDuration)}`),console.log(""),o.topAgents.length>0){console.log("\u{1F916} AGENT USAGE (all time)");let d=o.topAgents.reduce((g,h)=>g+h.usageCount,0);for(let g of o.topAgents){let h=d>0?(g.usageCount/d*100).toFixed(0):0;console.log(` ${g.agentName.padEnd(12)}: ${h}% (${g.usageCount} uses)`)}console.log("")}if(i.length>0){console.log("\u{1F4C8} TREND (last 30 days)");let d=Eg(i);if(console.log(` ${d} ${Mn(o.last30DaysTokens)} tokens saved`),o.trend!==0){let g=o.trend>0?"\u2191":"\u2193",h=o.trend>0?"+":"";console.log(` ${g} ${h}${o.trend.toFixed(0)}% vs previous 30 days`)}console.log("")}if(console.log("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log("Export: prjct stats --export > stats.md"),console.log(""),t.export){let d=xg(o,i,u,m,a,c);return console.log(d),{success:!0,data:{markdown:d}}}return{success:!0,data:{...o,session:a,patterns:c}}}catch(s){return console.error("\u274C Error:",y(s)),{success:!1,error:y(s)}}}async status(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):f.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=mo(e),i=await o.check(n),a=await o.getSessionInfo(n),c=await qe.getStatus(n);if(t.json)return console.log(JSON.stringify({success:!0,...i,session:a,analysis:c})),{success:!0,data:{...i,session:a,analysis:c}};if(t.md){let u=Dg.basename(e),p=i.isStale?"stale":"fresh",m=i.daysSinceSync>0?`${i.daysSinceSync} day${i.daysSinceSync!==1?"s":""} ago`:"today",d=[];c.hasSealed&&d.push(`Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&d.push(`Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&d.push(`Previous: ${c.previousSealedCommit} (rollback available)`);let g=U(`## \u26A1 Status: ${u}`,mt({Staleness:p,"Last sync":m,"Commits since sync":i.commitsSinceSync,Reason:i.reason}),d.length>0?se("Analysis",je(d)):null);return console.log(g),{success:!0,data:{...i,session:a,analysis:c}}}return console.log(""),console.log(o.formatStatus(i)),console.log(""),console.log(o.formatSessionInfo(a)),(c.hasSealed||c.hasDraft)&&(console.log(""),console.log("Analysis:"),c.hasSealed&&console.log(` Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&console.log(` Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&console.log(` Previous: ${c.previousSealedCommit} (rollback available)`)),console.log(""),{success:!0,data:{...i,session:a,analysis:c}}}catch(s){let n=y(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):f.fail(n),{success:!1,error:n}}}async diff(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await qe.diff(n);if(!o){let i="Cannot compute diff: need both a sealed and a draft analysis. Run `p. sync` to create a draft.";return t.json?console.log(JSON.stringify({success:!1,error:i})):t.md?console.log(U("## Analysis Diff",`> ${i}`)):f.warn(i),{success:!1,error:i}}if(t.json)return console.log(JSON.stringify({success:!0,...o})),{success:!0,data:o};if(t.md)return console.log(U(oa(o))),{success:!0,data:o};if(!o.hasChanges)f.done("No changes between draft and sealed analysis");else{f.section("Analysis Diff"),console.log(Ou(o)),console.log("");let i=[];o.summary.added>0&&i.push(`${o.summary.added} added`),o.summary.removed>0&&i.push(`${o.summary.removed} removed`),o.summary.changed>0&&i.push(`${o.summary.changed} changed`),f.done(i.join(", "))}return console.log(""),{success:!0,data:o}}catch(s){let n=y(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):t.md?console.log(U("## \u274C Diff Failed",`> ${n}`)):f.fail(n),{success:!1,error:n}}}async seal(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await qe.seal(n);return t.json?(console.log(JSON.stringify({success:o.success,signature:o.signature,error:o.error})),{success:o.success,error:o.error}):o.success?(f.done("Analysis sealed"),console.log(` Signature: ${o.signature?.substring(0,16)}...`),console.log(""),{success:!0,data:{signature:o.signature}}):(f.fail(o.error||"Seal failed"),{success:!1,error:o.error})}catch(s){let n=y(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):f.fail(n),{success:!1,error:n}}}async rollback(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await qe.rollback(n);return t.json?(console.log(JSON.stringify({success:o.success,restoredSignature:o.restoredSignature,error:o.error})),{success:o.success,error:o.error}):t.md?o.success?(console.log(U(ke("Analysis Rolled Back"),mt({"Restored signature":`${o.restoredSignature?.substring(0,16)}...`,Note:"Previous sealed version is now active. Current version moved to draft."}))),{success:!0,data:{restoredSignature:o.restoredSignature}}):(console.log(U("## \u274C Rollback Failed",`> ${o.error}`)),{success:!1,error:o.error}):o.success?(f.done("Analysis rolled back to previous sealed version"),console.log(` Restored signature: ${o.restoredSignature?.substring(0,16)}...`),console.log(" Previous sealed version demoted to draft"),console.log(""),{success:!0,data:{restoredSignature:o.restoredSignature}}):(f.fail(o.error||"Rollback failed"),{success:!1,error:o.error})}catch(s){let n=y(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):t.md?console.log(U("## \u274C Rollback Failed",`> ${n}`)):f.fail(n),{success:!1,error:n}}}async verify(e=process.cwd(),t={}){if(t.semantic)return this.semanticVerify(e,t);try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=await qe.verify(n);return t.json?(console.log(JSON.stringify(o)),{success:o.valid}):(o.valid?f.done(o.message):f.fail(o.message),console.log(""),{success:o.valid,data:o})}catch(s){let n=y(s);return f.fail(n),{success:!1,error:n}}}async semanticVerify(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):f.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=e;try{o=P.getDoc(n,"project")?.repoPath||e}catch{}let i=await qe.semanticVerify(n,o);if(t.json)return console.log(JSON.stringify(i)),{success:i.passed,data:i};console.log(""),i.passed?(f.done("Semantic verification passed"),console.log(` ${i.passedCount}/${i.checks.length} checks passed (${i.totalMs}ms)`)):(f.fail("Semantic verification failed"),console.log(` ${i.failedCount}/${i.checks.length} checks failed`)),console.log(""),console.log("Check Results:");for(let a of i.checks){let c=a.passed?"\u2713":"\u2717",u=a.passed?`${a.output} (${a.durationMs}ms)`:a.error||"Failed";console.log(` ${c} ${a.name}: ${u}`)}return console.log(""),{success:i.passed,data:i}}catch(s){let n=y(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):f.fail(n),{success:!1,error:n}}}}});function Wn(r){return Buffer.from(`${JSON.stringify(r)}
1114
- `)}var Ne,qg,Kg,Ll=S(()=>{"use strict";Ne={runDir:l(()=>`${process.env.HOME||St("node:os").homedir()}/.prjct-cli/run`,"runDir"),socket:l(()=>`${Ne.runDir()}/daemon.sock`,"socket"),pid:l(()=>`${Ne.runDir()}/daemon.pid`,"pid"),log:l(()=>`${Ne.runDir()}/daemon.log`,"log")},qg=1800*1e3,Kg=1024*1024;l(Wn,"encodeMessage")});var Qg={};Bt(Qg,{executeViaDaemon:()=>dv,forceKillDaemon:()=>mv,getDaemonStatus:()=>uv,isDaemonRunning:()=>Xg,sendRequest:()=>Nr,spawnDaemon:()=>Yg,stopDaemon:()=>pv});import wi from"node:crypto";import Ye from"node:fs";import{connect as lv}from"node:net";async function Xg(){let r=Ne.socket();if(!Ye.existsSync(r))return!1;try{return(await Nr({id:wi.randomUUID(),command:"__ping",args:[],options:{},cwd:process.cwd()})).success}catch{try{Ye.unlinkSync(r)}catch{}return!1}}async function uv(){let r=Ne.socket(),e=Ne.pid();if(!Ye.existsSync(r))return{running:!1};try{let t=await Nr({id:wi.randomUUID(),command:"daemon",args:["status"],options:{},cwd:process.cwd()});if(t.success&&t.result)return t.result}catch{}return Ye.existsSync(e)?{running:!1,pid:parseInt(Ye.readFileSync(e,"utf-8").trim(),10),socketPath:r}:{running:!1}}function Nr(r){return new Promise((e,t)=>{let s=Ne.socket(),n=lv(s),o="",i=!1,a=setTimeout(()=>{i||(i=!0,n.destroy(),t(new Error("Daemon request timed out")))},3e4);n.on("connect",()=>{n.write(Wn(r))}),n.on("data",c=>{o+=c.toString();let u=o.indexOf(`
1115
- `);if(u!==-1){let p=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(p);i=!0,clearTimeout(a),n.end(),e(m)}catch(m){i=!0,clearTimeout(a),n.end(),t(new Error(`Invalid daemon response: ${m.message}`))}}}),n.on("error",c=>{i||(i=!0,clearTimeout(a),t(c))}),n.on("close",()=>{i||(i=!0,clearTimeout(a),t(new Error("Connection closed before response")))})})}async function dv(r,e,t,s,n,o=!0){let i=Ne.socket();if(!Ye.existsSync(i))return o&&Yg().catch(()=>{}),null;try{return await Nr({id:wi.randomUUID(),command:r,args:e,options:t,cwd:s,perfStartNs:n})}catch{return null}}async function pv(){try{return(await Nr({id:wi.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function mv(){let r=Ne.pid(),e=Ne.socket(),t=!1;if(Ye.existsSync(r)){let s=parseInt(Ye.readFileSync(r,"utf-8").trim(),10);if(!Number.isNaN(s))try{process.kill(s,"SIGKILL"),t=!0}catch{}}try{Ye.existsSync(r)&&Ye.unlinkSync(r)}catch{}try{Ye.existsSync(e)&&Ye.unlinkSync(e)}catch{}return t}async function Yg(){let{spawn:r}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),s=e.join(__dirname,"..","daemon","entry.mjs"),n=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Ye.existsSync(t))o=t,i="bun";else if(Ye.existsSync(s))o=s,i=Vi()?"bun":"node";else if(Ye.existsSync(n))o=n,i=Vi()?"bun":"node";else return!1;let a=Ne.runDir();Ye.mkdirSync(a,{recursive:!0});let c=Ne.log(),u=Ye.openSync(c,"a");r(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Ye.closeSync(u);let m=Date.now()+3e3;for(;Date.now()<m;)if(await new Promise(d=>setTimeout(d,300)),await Xg())return!0;return!1}var Zg=S(()=>{"use strict";ar();Ll();l(Xg,"isDaemonRunning");l(uv,"getDaemonStatus");l(Nr,"sendRequest");l(dv,"executeViaDaemon");l(pv,"stopDaemon");l(mv,"forceKillDaemon");l(Yg,"spawnDaemon")});import Le from"node:fs";import{createServer as oT}from"node:net";ci();Ea();ce();ks();Xt();Js();Pt();V();Pn();lt();import Lb from"node:path";Et();ve();V();oe();var vl=class{static{l(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll","sessions"]);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,n){let o=t[s];if(typeof o!="function")throw new Error(`${String(s)} is not a function`);let i=l(async(a,c)=>a!=null?o.call(t,a,c.projectPath):o.call(t,c.projectPath),"wrapper");this.handlerFns.set(e,i),this.setMeta(e,n)}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(n=>n.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),n=s.filter((a,c)=>s.indexOf(a)!==c);n.length>0&&e.push(`Duplicate command names: ${n.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(c=>!i.includes(c.group));a.length>0&&e.push(`Invalid categories: ${a.map(c=>`${c.name}:${c.group}`).join(", ")}`)}return{valid:e.length===0,issues:e}}async buildContext(e){let t=await I.getProjectId(e);if(!t)throw new Error("No prjct project found. Run /p:init first.");return{projectId:t,projectPath:e,globalPath:A.getGlobalProjectPath(t),timestamp:v()}}async execute(e,t,s=process.cwd()){let n=this.metadata.get(e),o;if(n?.requiresProject===!1)o={projectId:"",projectPath:s,globalPath:"",timestamp:v()};else try{o=await this.buildContext(s)}catch(c){return{success:!1,error:y(c)}}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 n=this.handlers.get(e);if(n){let i={projectId:"",projectPath:s,globalPath:"",timestamp:v()};return n.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:s,globalPath:"",timestamp:v()};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()}},G=new vl;var On=class extends Ce{static{l(this,"AnalyticsCommands")}async dash(e="default",t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=Lb.basename(t),a=await _.getCurrentTask(o),c=await be.getActiveTasks(o),u=await et.getRecent(o,5),p=await He.getPending(o);if(e==="compact"){let m=a?`\u{1F3AF} ${a.description.slice(0,30)}`:"\u{1F4A4} idle",d=`\u{1F4CB} ${c.length}`,g=`\u{1F680} ${u.length}`;return f.done(`${m} | ${d} | ${g}`),{success:!0,view:"compact"}}if(e==="week"||e==="month"){let m=e==="week"?7:30,d=z.getDaysAgo(m),g=[];try{let w=d.toISOString();g=P.query(o,"SELECT data, timestamp FROM events WHERE type LIKE ? AND timestamp >= ? ORDER BY id DESC","memory.%",w).map(E=>({...JSON.parse(E.data),timestamp:E.timestamp}))}catch{g=[]}let h={tasksCompleted:g.filter(w=>w.action==="task_completed").length,featuresShipped:g.filter(w=>w.action==="feature_shipped").length,totalActions:g.length};console.log(`
1131
+ `),console.log("Next steps:"),console.log("\u2022 /p:sync \u2192 Generate agents based on stack"),console.log("\u2022 /p:feature \u2192 Add a new feature"),{success:!0,summaryPath:a,data:n}}catch(s){return console.error("\u274C Error:",w(s)),{success:!1,error:w(s)}}}async sync(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=A.getGlobalProjectPath(n),i=Date.now();if(t.package){let m=await A.detectMonorepo(e);if(!m.isMonorepo)return{success:!1,error:"Not a monorepo. --package flag only works in monorepos."};let d=m.packages.find(h=>h.name===t.package||h.relativePath===t.package);if(!d){let h=m.packages.map(k=>k.name).join(", ");return{success:!1,error:`Package "${t.package}" not found. Available: ${h}`}}let g=await qs.sync(e,{packagePath:d.path,packageName:d.name});return t.json?console.log(JSON.stringify({success:g.success,package:d.name,path:d.relativePath})):t.md?console.log(L(ke(`Synced package: ${d.name}`))):f.done(`Synced package: ${d.name}`),{success:g.success}}let a=$g.join(o,"context","CLAUDE.md"),c=null;try{c=await vl.readFile(a,"utf-8")}catch{}let u=!process.stdin.isTTY||t.json||t.md;if(c&&!t.yes&&!u){u||f.spin("Analyzing changes...");let m=await qs.sync(e,{full:t.full});if(!m.success)return t.md?(console.log(L("## Sync Failed",`> ${m.error||"Unknown error"}`)),{success:!1,error:m.error}):u?(console.log(JSON.stringify({success:!1,error:m.error||"Sync failed"})),{success:!1,error:m.error}):(f.fail(m.error||"Sync failed"),{success:!1,error:m.error});let d;try{d=await vl.readFile(a,"utf-8")}catch{d=""}let g=ud(c,d);if(u||f.stop(),!g.hasChanges)return t.md?(console.log(L(ke("No changes detected","Context is up to date."))),{success:!0,message:"No changes"}):u?(console.log(JSON.stringify({success:!0,action:"no_changes",message:"No changes detected (context is up to date)"})),{success:!0,message:"No changes"}):(f.done("No changes detected (context is up to date)"),{success:!0,message:"No changes"});let h=l(async()=>{c!=null&&await vl.writeFile(a,c,"utf-8")},"restoreOriginal");if(t.md){await h();let y=[];for(let D of g.added)y.push(`Added: ${D.name} (${D.lineCount} lines)`);for(let D of g.modified)y.push(`Modified: ${D.name} (${D.lineCount} lines)`);for(let D of g.removed)y.push(`Removed: ${D.name} (${D.lineCount} lines)`);let v=L("## Sync Preview",y.length>0?Q("Changes",Oe(y)):"No section changes.",lt({"Tokens before":g.tokensBefore,"Tokens after":g.tokensAfter,"Token delta":g.tokenDelta>0?`+${g.tokenDelta}`:String(g.tokenDelta)}),"> Run `prjct sync --yes` to apply changes.");return console.log(v),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(u){await h();let y={added:g.added.map(v=>({name:v.name,lineCount:v.lineCount})),modified:g.modified.map(v=>({name:v.name,lineCount:v.lineCount})),removed:g.removed.map(v=>({name:v.name,lineCount:v.lineCount})),preserved:g.preserved,tokensBefore:g.tokensBefore,tokensAfter:g.tokensAfter,tokenDelta:g.tokenDelta};return console.log(JSON.stringify({success:!0,action:"confirm_required",message:"Changes detected. Confirmation required to apply.",diff:y,fullDiff:t.preview?{added:g.added,modified:g.modified,removed:g.removed}:void 0,hint:"Run `prjct sync --yes` to apply changes"})),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(console.log(dd(g)),t.preview)return await h(),{success:!0,isPreview:!0,diff:g,message:"Preview complete (no changes applied)"};let k=await rn.select({message:"Apply these changes?",options:[{label:"Yes, apply changes",value:"apply"},{label:"No, cancel",value:"cancel"},{label:"Show full diff",value:"diff"}]});if(rn.isCancel(k)||k==="cancel")return await h(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"};if(k==="diff"){console.log(`
1132
+ ${pd(g)}`);let y=await rn.confirm({message:"Apply these changes?",initialValue:!0});if(rn.isCancel(y)||!y)return await h(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"}}return f.done("Changes applied"),bl(m,i)}t.md||f.spin("Syncing project...");let p=await qs.sync(e,{full:t.full});if(!p.success)return t.md?console.log(L("## Sync Failed",`> ${p.error||"Unknown error"}`)):f.fail(p.error||"Sync failed"),{success:!1,error:p.error};if(t.md||f.stop(),t.md){let m=Date.now()-i,d=p.generatedSkills?.generated?.length??0,g=null;try{let j=await Ke.diff(n);j?.hasChanges&&(g=aa(j))}catch{}let h=p.git.recentCommits[0]?.hash??null,y=h&&Lt.isCurrent(n,h)?null:"### Next: Run `prjct analysis-payload --md` to update project analysis",v=Uo("sync",!0),D=p.syncMetrics?.indexes,U={Duration:`${(m/1e3).toFixed(1)}s`,Skills:`${d} generated`,"Files indexed":p.stats.fileCount};if(D?.bm25Files){let j=D.bm25Files*(D.bm25AvgTokens||0);U["Tokens indexed"]=`${Math.round(j/1e3)}K`,U["Import edges"]=D.importEdges||0,U["Co-change commits"]=D.cochangeCommits||0}let F=L(ke("Sync Complete"),lt(U),g,p.git.hasChanges?Wp("Uncommitted changes detected"):null,y,ge(v.map(j=>({label:j.desc,command:j.cmd}))));return console.log(F),{success:!0,data:p,metrics:{elapsed:m,skillCount:d,fileCount:p.stats.fileCount}}}return bl(p,i)}catch(s){return t.md?console.log(L("## Sync Failed",`> ${w(s)}`)):f.fail(w(s)),{success:!1,error:w(s)}}}async analysisPayload(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=await qs.sync(e);if(!o.success)return{success:!1,error:o.error||"Failed to gather project data"};let i=o.git.recentCommits[0]?.hash??null;if(i&&Lt.isCurrent(n,i))return t.md?console.log(L(ke("LLM analysis is current"),"> No re-analysis needed.")):console.log(JSON.stringify({success:!0,action:"skip",message:"Analysis is current"})),{success:!0,message:"Analysis is current"};let a=await id(n,e,o.git,o.stats);return t.md?console.log(L("## Analysis Payload","> Analyze this data and return a JSON object matching the schema below.","### Expected output schema","```json",JSON.stringify({version:1,commitHash:"string (from git data)",analyzedAt:"ISO timestamp",architecture:{style:"monolith|monorepo|microservices|modular-monolith",insights:["string"],domains:["string"]},patterns:[{name:"",description:"",locations:["file paths"],confidence:0,category:"architecture|data-flow|error-handling|testing"}],antiPatterns:[{issue:"",reasoning:"",files:[],suggestion:"",severity:"low|medium|high",confidence:0}],techDebt:[{description:"",area:"",effort:"small|medium|large",impact:"",priority:"low|medium|high"}],riskAreas:[{path:"",reason:"",risk:"",severity:"low|medium|high"}],refactorSuggestions:[{description:"",files:[],benefit:"",effort:"small|medium|large"}],projectInsights:["string"],conventions:[{category:"naming|file-structure|imports|error-handling",rule:"",example:""}],commands:{build:"",test:"",lint:"",dev:"",format:"",install:""},stack:{languages:["string"],frameworks:["string"],packageManager:"detected from project"}},null,2),"```","### Project data","```json",JSON.stringify(a,null,2),"```","> Save result: `prjct analysis-save-llm '<JSON>' --md`")):console.log(JSON.stringify({success:!0,payload:a})),{success:!0,data:a}}catch(s){return{success:!1,error:w(s)}}}async saveLlmAnalysis(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.getProjectId(t);if(!o)return{success:!1,error:"No project ID found"};let i=JSON.parse(e);return!i.version||!i.architecture||!i.patterns?{success:!1,error:"Invalid LLM analysis format. Missing required fields."}:(Lt.save(o,i),s.md?console.log(L(ke("LLM Analysis Saved"),lt({Architecture:i.architecture.style,Patterns:i.patterns.length,"Anti-patterns":i.antiPatterns?.length||0,"Tech debt items":i.techDebt?.length||0,"Risk areas":i.riskAreas?.length||0,Conventions:i.conventions?.length||0}))):console.log(JSON.stringify({success:!0,message:"LLM analysis saved",stats:{patterns:i.patterns.length,antiPatterns:i.antiPatterns?.length||0,techDebt:i.techDebt?.length||0}})),{success:!0})}catch(n){return{success:!1,error:w(n)}}}async getLlmAnalysis(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=Lt.getActive(n);if(!o)return t.md?console.log(L("## No LLM Analysis","> Run `prjct sync` to generate.")):console.log(JSON.stringify({success:!1,message:"No LLM analysis found"})),{success:!1,message:"No LLM analysis found"};if(t.md){let i=[ke(`LLM Analysis (${o.architecture.style})`),""];o.architecture.insights.length>0&&i.push(Q("Architecture Insights",Oe(o.architecture.insights))),o.patterns.length>0&&i.push(Q("Patterns",Oe(o.patterns.map(a=>`**${a.name}** \u2014 ${a.description} (${a.category})`)))),o.antiPatterns.length>0&&i.push(Q("Anti-Patterns",Oe(o.antiPatterns.map(a=>`[${a.severity}] ${a.issue} \u2014 ${a.suggestion}`)))),o.techDebt.length>0&&i.push(Q("Tech Debt",Oe(o.techDebt.map(a=>`[${a.priority}/${a.effort}] ${a.description}`)))),o.conventions.length>0&&i.push(Q("Conventions",Oe(o.conventions.map(a=>`**${a.category}**: ${a.rule}`)))),console.log(L(...i))}else console.log(JSON.stringify({success:!0,analysis:o}));return{success:!0,data:o}}catch(s){return{success:!1,error:w(s)}}}async stats(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=await Pn.getSummary(n),i=await Pn.getDailyStats(n,30),a=await Rg(n),c=await ct.getPatternsSummary(n);if(t.json){let d={session:a,patterns:c,totalTokensSaved:o.totalTokensSaved,estimatedCostSaved:o.estimatedCostSaved,compressionRate:o.compressionRate,syncCount:o.syncCount,avgSyncDuration:o.avgSyncDuration,topAgents:o.topAgents,last30DaysTokens:o.last30DaysTokens,trend:o.trend,dailyStats:i};return console.log(JSON.stringify(d,null,2)),{success:!0,data:d}}let u="Unknown";try{u=C.getDoc(n,"project")?.name||"Unknown"}catch{}let p=await Pn.read(n),m=p.firstSync?new Date(p.firstSync).toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}):"N/A";if(console.log(""),console.log("\u256D\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256E"),console.log("\u2502 \u{1F4CA} prjct-cli Stats Dashboard \u2502"),console.log(`\u2502 Project: ${u.padEnd(20).slice(0,20)} | Since: ${m.padEnd(12).slice(0,12)} \u2502`),console.log("\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256F"),console.log(""),console.log("\u{1F3AF} TODAY'S ACTIVITY"),a.sessionDuration&&console.log(` Duration: ${a.sessionDuration}`),console.log(` Tasks completed: ${a.tasksCompleted}`),console.log(` Features shipped: ${a.featuresShipped}`),a.agentsUsed.length>0){let d=a.agentsUsed.slice(0,3).map(g=>`${g.name} (${g.count}\xD7)`).join(", ");console.log(` Agents used: ${d}`)}if(console.log(""),(c.decisions>0||c.preferences>0)&&(console.log("\u{1F9E0} PATTERNS LEARNED"),console.log(` Decisions: ${c.learnedDecisions} confirmed (${c.decisions} total)`),console.log(` Preferences: ${c.preferences} saved`),console.log(` Workflows: ${c.workflows} tracked`),console.log("")),console.log("\u{1F4B0} TOKEN SAVINGS"),console.log(` Total saved: ${Mn(o.totalTokensSaved)} tokens`),console.log(` Compression: ${(o.compressionRate*100).toFixed(0)}% average reduction`),console.log(` Estimated cost: ${lo(o.estimatedCostSaved)} saved`),console.log(""),console.log("\u26A1 PERFORMANCE"),console.log(` Syncs completed: ${o.syncCount.toLocaleString()}`),console.log(` Avg sync time: ${Tl(o.avgSyncDuration)}`),console.log(""),o.topAgents.length>0){console.log("\u{1F916} AGENT USAGE (all time)");let d=o.topAgents.reduce((g,h)=>g+h.usageCount,0);for(let g of o.topAgents){let h=d>0?(g.usageCount/d*100).toFixed(0):0;console.log(` ${g.agentName.padEnd(12)}: ${h}% (${g.usageCount} uses)`)}console.log("")}if(i.length>0){console.log("\u{1F4C8} TREND (last 30 days)");let d=Ag(i);if(console.log(` ${d} ${Mn(o.last30DaysTokens)} tokens saved`),o.trend!==0){let g=o.trend>0?"\u2191":"\u2193",h=o.trend>0?"+":"";console.log(` ${g} ${h}${o.trend.toFixed(0)}% vs previous 30 days`)}console.log("")}if(console.log("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log("Export: prjct stats --export > stats.md"),console.log(""),t.export){let d=Dg(o,i,u,m,a,c);return console.log(d),{success:!0,data:{markdown:d}}}return{success:!0,data:{...o,session:a,patterns:c}}}catch(s){return console.error("\u274C Error:",w(s)),{success:!1,error:w(s)}}}async status(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):f.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=yo(e),i=await o.check(n),a=await o.getSessionInfo(n),c=await Ke.getStatus(n);if(t.json)return console.log(JSON.stringify({success:!0,...i,session:a,analysis:c})),{success:!0,data:{...i,session:a,analysis:c}};if(t.md){let u=$g.basename(e),p=i.isStale?"stale":"fresh",m=i.daysSinceSync>0?`${i.daysSinceSync} day${i.daysSinceSync!==1?"s":""} ago`:"today",d=[];c.hasSealed&&d.push(`Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&d.push(`Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&d.push(`Previous: ${c.previousSealedCommit} (rollback available)`);let g=L(`## Status: ${u}`,lt({Staleness:p,"Last sync":m,"Commits since sync":i.commitsSinceSync,Reason:i.reason}),d.length>0?Q("Analysis",Oe(d)):null);return console.log(g),{success:!0,data:{...i,session:a,analysis:c}}}return console.log(""),console.log(o.formatStatus(i)),console.log(""),console.log(o.formatSessionInfo(a)),(c.hasSealed||c.hasDraft)&&(console.log(""),console.log("Analysis:"),c.hasSealed&&console.log(` Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&console.log(` Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&console.log(` Previous: ${c.previousSealedCommit} (rollback available)`)),console.log(""),{success:!0,data:{...i,session:a,analysis:c}}}catch(s){let n=w(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):f.fail(n),{success:!1,error:n}}}async diff(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await Ke.diff(n);if(!o){let i="Cannot compute diff: need both a sealed and a draft analysis. Run `p. sync` to create a draft.";return t.json?console.log(JSON.stringify({success:!1,error:i})):t.md?console.log(L("## Analysis Diff",`> ${i}`)):f.warn(i),{success:!1,error:i}}if(t.json)return console.log(JSON.stringify({success:!0,...o})),{success:!0,data:o};if(t.md)return console.log(L(aa(o))),{success:!0,data:o};if(!o.hasChanges)f.done("No changes between draft and sealed analysis");else{f.section("Analysis Diff"),console.log(Lu(o)),console.log("");let i=[];o.summary.added>0&&i.push(`${o.summary.added} added`),o.summary.removed>0&&i.push(`${o.summary.removed} removed`),o.summary.changed>0&&i.push(`${o.summary.changed} changed`),f.done(i.join(", "))}return console.log(""),{success:!0,data:o}}catch(s){let n=w(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):t.md?console.log(L("## Diff Failed",`> ${n}`)):f.fail(n),{success:!1,error:n}}}async seal(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await Ke.seal(n);return t.json?(console.log(JSON.stringify({success:o.success,signature:o.signature,error:o.error})),{success:o.success,error:o.error}):o.success?(f.done("Analysis sealed"),console.log(` Signature: ${o.signature?.substring(0,16)}...`),console.log(""),{success:!0,data:{signature:o.signature}}):(f.fail(o.error||"Seal failed"),{success:!1,error:o.error})}catch(s){let n=w(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):f.fail(n),{success:!1,error:n}}}async rollback(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await Ke.rollback(n);return t.json?(console.log(JSON.stringify({success:o.success,restoredSignature:o.restoredSignature,error:o.error})),{success:o.success,error:o.error}):t.md?o.success?(console.log(L(ke("Analysis Rolled Back"),lt({"Restored signature":`${o.restoredSignature?.substring(0,16)}...`,Note:"Previous sealed version is now active. Current version moved to draft."}))),{success:!0,data:{restoredSignature:o.restoredSignature}}):(console.log(L("## Rollback Failed",`> ${o.error}`)),{success:!1,error:o.error}):o.success?(f.done("Analysis rolled back to previous sealed version"),console.log(` Restored signature: ${o.restoredSignature?.substring(0,16)}...`),console.log(" Previous sealed version demoted to draft"),console.log(""),{success:!0,data:{restoredSignature:o.restoredSignature}}):(f.fail(o.error||"Rollback failed"),{success:!1,error:o.error})}catch(s){let n=w(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):t.md?console.log(L("## Rollback Failed",`> ${n}`)):f.fail(n),{success:!1,error:n}}}async verify(e=process.cwd(),t={}){if(t.semantic)return this.semanticVerify(e,t);try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return{success:!1,error:"No project ID found"};let o=await Ke.verify(n);return t.json?(console.log(JSON.stringify(o)),{success:o.valid}):(o.valid?f.done(o.message):f.fail(o.message),console.log(""),{success:o.valid,data:o})}catch(s){let n=w(s);return f.fail(n),{success:!1,error:n}}}async semanticVerify(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):f.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=e;try{o=C.getDoc(n,"project")?.repoPath||e}catch{}let i=await Ke.semanticVerify(n,o);if(t.json)return console.log(JSON.stringify(i)),{success:i.passed,data:i};console.log(""),i.passed?(f.done("Semantic verification passed"),console.log(` ${i.passedCount}/${i.checks.length} checks passed (${i.totalMs}ms)`)):(f.fail("Semantic verification failed"),console.log(` ${i.failedCount}/${i.checks.length} checks failed`)),console.log(""),console.log("Check Results:");for(let a of i.checks){let c=a.passed?"\u2713":"\u2717",u=a.passed?`${a.output} (${a.durationMs}ms)`:a.error||"Failed";console.log(` ${c} ${a.name}: ${u}`)}return console.log(""),{success:i.passed,data:i}}catch(s){let n=w(s);return t.json?console.log(JSON.stringify({success:!1,error:n})):f.fail(n),{success:!1,error:n}}}}});function Vn(r){return Buffer.from(`${JSON.stringify(r)}
1133
+ `)}var Le,Qg,Zg,Hl=S(()=>{"use strict";Le={runDir:l(()=>`${process.env.HOME||bt("node:os").homedir()}/.prjct-cli/run`,"runDir"),socket:l(()=>`${Le.runDir()}/daemon.sock`,"socket"),pid:l(()=>`${Le.runDir()}/daemon.pid`,"pid"),log:l(()=>`${Le.runDir()}/daemon.log`,"log")},Qg=1800*1e3,Zg=1024*1024;l(Vn,"encodeMessage")});var sf={};Ot(sf,{executeViaDaemon:()=>gT,forceKillDaemon:()=>hT,getDaemonStatus:()=>mT,isDaemonRunning:()=>ef,sendRequest:()=>Fr,spawnDaemon:()=>tf,stopDaemon:()=>fT});import Ti from"node:crypto";import Qe from"node:fs";import{connect as pT}from"node:net";async function ef(){let r=Le.socket();if(!Qe.existsSync(r))return!1;try{return(await Fr({id:Ti.randomUUID(),command:"__ping",args:[],options:{},cwd:process.cwd()})).success}catch{try{Qe.unlinkSync(r)}catch{}return!1}}async function mT(){let r=Le.socket(),e=Le.pid();if(!Qe.existsSync(r))return{running:!1};try{let t=await Fr({id:Ti.randomUUID(),command:"daemon",args:["status"],options:{},cwd:process.cwd()});if(t.success&&t.result)return t.result}catch{}return Qe.existsSync(e)?{running:!1,pid:parseInt(Qe.readFileSync(e,"utf-8").trim(),10),socketPath:r}:{running:!1}}function Fr(r){return new Promise((e,t)=>{let s=Le.socket(),n=pT(s),o="",i=!1,a=setTimeout(()=>{i||(i=!0,n.destroy(),t(new Error("Daemon request timed out")))},3e4);n.on("connect",()=>{n.write(Vn(r))}),n.on("data",c=>{o+=c.toString();let u=o.indexOf(`
1134
+ `);if(u!==-1){let p=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(p);i=!0,clearTimeout(a),n.end(),e(m)}catch(m){i=!0,clearTimeout(a),n.end(),t(new Error(`Invalid daemon response: ${m.message}`))}}}),n.on("error",c=>{i||(i=!0,clearTimeout(a),t(c))}),n.on("close",()=>{i||(i=!0,clearTimeout(a),t(new Error("Connection closed before response")))})})}async function gT(r,e,t,s,n,o=!0){let i=Le.socket();if(!Qe.existsSync(i))return o&&tf().catch(()=>{}),null;try{return await Fr({id:Ti.randomUUID(),command:r,args:e,options:t,cwd:s,perfStartNs:n})}catch{return null}}async function fT(){try{return(await Fr({id:Ti.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function hT(){let r=Le.pid(),e=Le.socket(),t=!1;if(Qe.existsSync(r)){let s=parseInt(Qe.readFileSync(r,"utf-8").trim(),10);if(!Number.isNaN(s))try{process.kill(s,"SIGKILL"),t=!0}catch{}}try{Qe.existsSync(r)&&Qe.unlinkSync(r)}catch{}try{Qe.existsSync(e)&&Qe.unlinkSync(e)}catch{}return t}async function tf(){let{spawn:r}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),s=e.join(__dirname,"..","daemon","entry.mjs"),n=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Qe.existsSync(t))o=t,i="bun";else if(Qe.existsSync(s))o=s,i=zi()?"bun":"node";else if(Qe.existsSync(n))o=n,i=zi()?"bun":"node";else return!1;let a=Le.runDir();Qe.mkdirSync(a,{recursive:!0});let c=Le.log(),u=Qe.openSync(c,"a");r(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Qe.closeSync(u);let m=Date.now()+3e3;for(;Date.now()<m;)if(await new Promise(d=>setTimeout(d,300)),await ef())return!0;return!1}var nf=S(()=>{"use strict";ar();Hl();l(ef,"isDaemonRunning");l(mT,"getDaemonStatus");l(Fr,"sendRequest");l(gT,"executeViaDaemon");l(fT,"stopDaemon");l(hT,"forceKillDaemon");l(tf,"spawnDaemon")});import Fe from"node:fs";import{createServer as lv}from"node:net";pi();Ra();import Hb from"node:path";re();var Cl=class{static{l(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)
1135
+ VALUES (?, ?, ?, ?, ?, ?, ?)`,e,s??null,t.from,t.to,t.usagePercent,t.action??null,t.timestamp)}recordCompaction(e,t,s,n){C.run(e,`INSERT INTO context_compactions (project_id, format, original_turns, files_count, timestamp)
1136
+ VALUES (?, ?, ?, ?, ?)`,e,t,s,n,new Date().toISOString())}getTransitions(e,t=20){return C.query(e,"SELECT * FROM context_zone_events WHERE project_id = ? ORDER BY id DESC LIMIT ?",e,t).map(n=>({from:n.zone_from,to:n.zone_to,usagePercent:n.usage_percent,timestamp:n.timestamp,action:n.action}))}getSummary(e,t=7){let s=new Date(Date.now()-t*864e5).toISOString(),n=C.query(e,`SELECT zone_to, COUNT(*) as cnt FROM context_zone_events
1137
+ WHERE project_id = ? AND timestamp >= ?
1138
+ GROUP BY zone_to`,e,s),o={smart:0,warning:0,dumb:0},i=0;for(let u of n)o[u.zone_to]=u.cnt,i+=u.cnt;let c=C.query(e,`SELECT COUNT(*) as cnt FROM context_compactions
1139
+ WHERE project_id = ? AND timestamp >= ?`,e,s)[0]?.cnt??0;return i===0?{smartPercent:100,warningPercent:0,dumbPercent:0,compactions:c}:{smartPercent:Math.round(o.smart/i*100),warningPercent:Math.round(o.warning/i*100),dumbPercent:Math.round(o.dumb/i*100),compactions:c}}},Mg=new Cl;re();ks();Xt();zs();Pt();W();Ks();dt();Et();Te();W();ie();var Pl=class{static{l(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll","sessions"]);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,n){let o=t[s];if(typeof o!="function")throw new Error(`${String(s)} is not a function`);let i=l(async(a,c)=>a!=null?o.call(t,a,c.projectPath):o.call(t,c.projectPath),"wrapper");this.handlerFns.set(e,i),this.setMeta(e,n)}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(n=>n.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),n=s.filter((a,c)=>s.indexOf(a)!==c);n.length>0&&e.push(`Duplicate command names: ${n.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(c=>!i.includes(c.group));a.length>0&&e.push(`Invalid categories: ${a.map(c=>`${c.name}:${c.group}`).join(", ")}`)}return{valid:e.length===0,issues:e}}async buildContext(e){let t=await $.getProjectId(e);if(!t)throw new Error("No prjct project found. Run /p:init first.");return{projectId:t,projectPath:e,globalPath:A.getGlobalProjectPath(t),timestamp:T()}}async execute(e,t,s=process.cwd()){let n=this.metadata.get(e),o;if(n?.requiresProject===!1)o={projectId:"",projectPath:s,globalPath:"",timestamp:T()};else try{o=await this.buildContext(s)}catch(c){return{success:!1,error:w(c)}}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 n=this.handlers.get(e);if(n){let i={projectId:"",projectPath:s,globalPath:"",timestamp:T()};return n.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:s,globalPath:"",timestamp:T()};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()}},G=new Pl;var _n=class extends Ce{static{l(this,"AnalyticsCommands")}async dash(e="default",t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=Hb.basename(t),a=await _.getCurrentTask(o),c=await be.getActiveTasks(o),u=await tt.getRecent(o,5),p=await Ge.getPending(o);if(e==="compact"){let m=a?`\u{1F3AF} ${a.description.slice(0,30)}`:"\u{1F4A4} idle",d=`\u{1F4CB} ${c.length}`,g=`\u{1F680} ${u.length}`;return f.done(`${m} | ${d} | ${g}`),{success:!0,view:"compact"}}if(e==="week"||e==="month"){let m=e==="week"?7:30,d=J.getDaysAgo(m),g=[];try{let y=d.toISOString();g=C.query(o,"SELECT data, timestamp FROM events WHERE type LIKE ? AND timestamp >= ? ORDER BY id DESC","memory.%",y).map(D=>({...JSON.parse(D.data),timestamp:D.timestamp}))}catch{g=[]}let h={tasksCompleted:g.filter(y=>y.action==="task_completed").length,featuresShipped:g.filter(y=>y.action==="feature_shipped").length,totalActions:g.length};console.log(`
1116
1140
  \u{1F4CA} ${e.toUpperCase()} PROGRESS - ${i}
1117
1141
  `),console.log("\u2550".repeat(50)),console.log(` Tasks completed: ${h.tasksCompleted}`),console.log(` Features shipped: ${h.featuresShipped}`),console.log(` Total actions: ${h.totalActions}`),console.log("\u2550".repeat(50));let k=this._generateSparkline(g,m);return console.log(`
1118
1142
  Activity: ${k}
1119
- `),{success:!0,view:e,metrics:h}}if(e==="roadmap"){let m=await Ht.build(t),d=await st.get("Read")(m.paths.roadmap);if(console.log(`
1143
+ `),{success:!0,view:e,metrics:h}}if(e==="roadmap"){let m=await Wt.build(t),d=await nt.get("Read")(m.paths.roadmap);if(console.log(`
1120
1144
  \u{1F5FA}\uFE0F ROADMAP - ${i}
1121
1145
  `),console.log("\u2550".repeat(50)),!d||d.trim()==="# ROADMAP")console.log(" No features planned yet."),console.log(` Use /p:feature to add features.
1122
- `);else{let g=d.split("##").filter(h=>h.trim()&&!h.includes("ROADMAP"));g.slice(0,5).forEach((h,k)=>{let w=h.split(`
1123
- `)[0].trim();console.log(` ${k+1}. ${w}`)}),g.length>5&&console.log(` ... and ${g.length-5} more`)}return console.log(`${"\u2550".repeat(50)}
1124
- `),{success:!0,view:"roadmap"}}if(s.md){let m=a?`${a.description}${a.startedAt?` (started ${z.calculateDuration(new Date(a.startedAt))} ago)`:""}`:"No active task",d=c.length>0?c.slice(0,5).map(k=>{let w=k.priority?` [${k.priority}]`:"";return`${k.description}${w}`}):["Queue is empty"],g=u.length>0?u.slice(0,5).map(k=>{let w=k.shippedAt?new Date(k.shippedAt).toLocaleDateString():"";return`${k.name}${w?` (${w})`:""}`}):["Nothing shipped yet"],h=U(`## \u26A1 Dashboard: ${i}`,se("Current Focus",m),se(`Queue (${c.length})`,je(d,!0)),se("Recent Ships",je(g)),se("Ideas",`${p.length} pending`),ge([{label:"Start task",command:"p. task"},{label:"Complete",command:"p. done"},{label:"Ship",command:"p. ship"}]));console.log(h)}else{console.log(`
1146
+ `);else{let g=d.split("##").filter(h=>h.trim()&&!h.includes("ROADMAP"));g.slice(0,5).forEach((h,k)=>{let y=h.split(`
1147
+ `)[0].trim();console.log(` ${k+1}. ${y}`)}),g.length>5&&console.log(` ... and ${g.length-5} more`)}return console.log(`${"\u2550".repeat(50)}
1148
+ `),{success:!0,view:"roadmap"}}if(s.md){let m=a?`${a.description}${a.startedAt?` (started ${J.calculateDuration(new Date(a.startedAt))} ago)`:""}`:"No active task",d=c.length>0?c.slice(0,5).map(y=>{let v=y.priority?` [${y.priority}]`:"";return`${y.description.replace(/^[\u{1F300}-\u{1F9FF}]\s*/u,"")}${v}`}):["Queue is empty"],g=u.length>0?u.slice(0,5).map(y=>{let v=y.shippedAt?new Date(y.shippedAt).toLocaleDateString():"";return`${y.name}${v?` (${v})`:""}`}):["Nothing shipped yet"],h=null;try{let y=Mg.getSummary(o,7);(y.smartPercent<100||y.compactions>0)&&(h=`### Context Health (7d)
1149
+ `+Rr(["Zone","%"],[["Smart",`${y.smartPercent}%`],["Warning",`${y.warningPercent}%`],["Dumb",`${y.dumbPercent}%`],["Compactions",`${y.compactions}`]]))}catch{}let k=L(`## Dashboard: ${i}`,Q("Current Focus",m),Q(`Queue (${c.length})`,Oe(d,!0)),Q("Recent Ships",Oe(g)),Q("Ideas",`${p.length} pending`),h,ge([{label:"Start task",command:'prjct task "..." --md'},{label:"Complete",command:"prjct done --md"},{label:"Ship",command:"prjct ship --md"}]));console.log(k)}else{console.log(`
1125
1150
  \u{1F4CA} DASHBOARD - ${i}
1126
- `),console.log("\u2550".repeat(50));let m=mo(t),d=await m.check(o),g=m.getWarning(d);if(g&&console.log(`
1151
+ `),console.log("\u2550".repeat(50));let m=yo(t),d=await m.check(o),g=m.getWarning(d);if(g&&console.log(`
1127
1152
  ${g}`),console.log(`
1128
- \u{1F3AF} CURRENT FOCUS`),a){if(console.log(` ${a.description}`),a.startedAt){let h=z.calculateDuration(new Date(a.startedAt));console.log(` Started: ${h} ago`)}}else console.log(" No active task. Use /p:work to start.");console.log(`
1129
- \u{1F4CB} QUEUE`),c.length===0?console.log(" Queue is empty"):(c.slice(0,3).forEach((h,k)=>{let w=h.priority?`[${h.priority}]`:"";console.log(` ${k+1}. ${h.description.slice(0,40)} ${w}`)}),c.length>3&&console.log(` ... and ${c.length-3} more`)),console.log(`
1153
+ \u{1F3AF} CURRENT FOCUS`),a){if(console.log(` ${a.description}`),a.startedAt){let h=J.calculateDuration(new Date(a.startedAt));console.log(` Started: ${h} ago`)}}else console.log(" No active task. Use /p:work to start.");console.log(`
1154
+ \u{1F4CB} QUEUE`),c.length===0?console.log(" Queue is empty"):(c.slice(0,3).forEach((h,k)=>{let y=h.priority?`[${h.priority}]`:"";console.log(` ${k+1}. ${h.description.slice(0,40)} ${y}`)}),c.length>3&&console.log(` ... and ${c.length-3} more`)),console.log(`
1130
1155
  \u{1F680} RECENT SHIPS`),u.length===0?console.log(" Nothing shipped yet"):u.slice(0,3).forEach(h=>{let k=h.shippedAt?new Date(h.shippedAt).toLocaleDateString():"";console.log(` \u2022 ${h.name} ${k?`(${k})`:""}`)}),console.log(`
1131
1156
  \u{1F4A1} IDEAS`),console.log(` ${p.length} pending ideas`),console.log(`
1132
1157
  ${"\u2550".repeat(50)}`),console.log(`\u{1F4A1} /p:work to start | /p:done to complete | /p:ship to ship
1133
- `)}return await this.logToMemory(t,"dash_viewed",{view:e,timestamp:z.getTimestamp()}),{success:!0,view:"default",stats:{currentTask:a?.description||null,queueCount:c.length,shippedCount:u.length,ideasCount:p.length}}}catch(n){return f.fail(y(n)),{success:!1,error:y(n)}}}async help(e="",t=process.cwd()){try{if(!e){console.log(`
1158
+ `)}return await this.logToMemory(t,"dash_viewed",{view:e,timestamp:J.getTimestamp()}),{success:!0,view:"default",stats:{currentTask:a?.description||null,queueCount:c.length,shippedCount:u.length,ideasCount:p.length}}}catch(n){return f.fail(w(n)),{success:!1,error:w(n)}}}async help(e="",t=process.cwd()){try{if(!e){console.log(`
1134
1159
  PRJCT COMMANDS
1135
1160
  `),console.log("=".repeat(50));let i=G.getAllCategories(),a=G.getAll(),c={};return a.forEach(u=>{u.deprecated||(c[u.group]||(c[u.group]=[]),c[u.group].push(u))}),Object.entries(c).forEach(([u,p])=>{let m=i.get(u);console.log(`
1136
1161
  ${m?.title||u}:`),p.forEach(d=>{let g=d.params?` ${d.params}`:"";console.log(` ${d.name}${g}`),console.log(` ${d.description}`)})}),console.log(`
@@ -1145,8 +1170,9 @@ ${"\u2550".repeat(50)}
1145
1170
  \u{1F4A1} Did you mean /p:${a.command}?`),console.log(` ${a.hint}
1146
1171
  `),{success:!0,topic:e,suggestion:a.command};return console.log(`
1147
1172
  \u2753 Unknown topic: ${e}`),console.log(` Use /p:help to see all commands
1148
- `),{success:!1,error:`Unknown topic: ${e}`}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}_generateSparkline(e,t){let s=["\u2581","\u2582","\u2583","\u2584","\u2585","\u2586","\u2587","\u2588"],n=new Date,o=[];for(let a=t-1;a>=0;a--){let c=new Date(n);c.setDate(c.getDate()-a);let u=new Date(c.setHours(0,0,0,0)),p=new Date(c.setHours(23,59,59,999)),m=e.filter(d=>{let g=new Date(d.timestamp);return g>=u&&g<=p}).length;o.push(m)}let i=Math.max(...o,1);return o.map(a=>s[Math.floor(a/i*(s.length-1))]).join("")}};Wc();Et();ve();Pt();V();import Fb from"node:fs/promises";import Ub from"node:path";var on=class{static{l(this,"ContextCommands")}async context(e=null,t=process.cwd()){try{let s=(e||"").trim().split(/\s+/),n=s[0]||"task",o=s.slice(1).join(" "),i=await I.readConfig(t);if(!i||!i.projectId)return console.log(JSON.stringify({projectId:"",globalPath:"",currentTask:null,domains:[],primaryDomain:null,subtasks:null,repoAnalysis:{ecosystem:"unknown",frameworks:[],hasTests:!1,technologies:[]}},null,2)),{success:!1,message:"No prjct project. Run `p. init` first."};let a=i.projectId,c=A.getGlobalProjectPath(a),u=await _.read(a),p=u?.currentTask?{id:u.currentTask.id,description:u.currentTask.description,startedAt:u.currentTask.startedAt,subtasks:u.currentTask.subtasks?.map(h=>({id:h.id,description:h.description,status:h.status,domain:h.domain})),currentSubtaskIndex:u.currentTask.currentSubtaskIndex}:null,m=null;if(o)try{m=await Bo.execute(n,o,t)}catch(h){console.error(`Warning: Orchestrator failed: ${y(h)}`)}let d=await this.loadRepoAnalysis(c),g={projectId:a,globalPath:c,currentTask:p,domains:m?.detectedDomains||[],primaryDomain:m?.primaryDomain||null,subtasks:m?.subtasks?.map(h=>({id:h.id,description:h.description,domain:h.domain,agent:h.agent,status:h.status,order:h.order}))||null,repoAnalysis:{ecosystem:d?.ecosystem||"unknown",frameworks:d?.frameworks||[],hasTests:d?.hasTests||!1,technologies:d?.technologies||[]}};return console.log(JSON.stringify(g,null,2)),{success:!0,message:""}}catch(s){return{success:!1,message:`Context error: ${y(s)}`}}}async loadRepoAnalysis(e){try{let t=Ub.join(e,"analysis","repo-analysis.json"),s=await Fb.readFile(t,"utf-8"),n=JSON.parse(s);return{ecosystem:n.ecosystem||"unknown",frameworks:n.frameworks||[],hasTests:n.hasTests??!1,technologies:n.technologies||[]}}catch(t){return R(t),null}}},Q_=new on;Go();lt();ve();zs();ce();ks();Xt();V();lt();import Tl from"node:fs";import jg from"node:path";async function li(r){let e=await I.getProjectId(r),t={rotated:[],totalSize:0,freedSpace:0};if(!e)return{success:!0,results:t};let n=F.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(n>500){let o=n-500;F.run(e,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",o),t.rotated.push("memory-events"),t.freedSpace=o}return{success:!0,results:t}}l(li,"cleanupMemory");async function ui(r){let e=await I.getProjectId(r);if(!e)return;let s=F.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(s>500){let n=s-500;F.run(e,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",n)}}l(ui,"cleanupMemoryInternal");async function Cl(r={},e=process.cwd()){try{if(r.memory===!0||r.type==="memory"){f.spin("cleaning memory...");let a=await li(e);return f.done("memory cleaned"),a}f.spin("cleaning up...");let s=await I.getProjectId(e);if(!s)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let n=[],i=F.get(s,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(i>100){let a=i-100;F.run(s,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",a),n.push(`Memory: ${a} old entries removed`)}else n.push("Memory: No cleanup needed");try{let a=await He.cleanup(s);a.removed>0?n.push(`Ideas: ${a.removed} old archived ideas removed`):n.push("Ideas: No cleanup needed")}catch(a){n.push(`Ideas: Error - ${y(a)}`)}try{let c=(await be.getActiveTasks(s)).filter(u=>u.completed).length;c>0?n.push(`Queue: ${c} completed tasks found (not removed - use /p:done to clear)`):n.push("Queue: No completed tasks")}catch(a){n.push(`Queue: Error - ${y(a)}`)}return await ui(e),await xt.log(e,"cleanup_performed",{items:n.length,timestamp:z.getTimestamp()}),f.done(`${n.length} items cleaned`),{success:!0,cleaned:n}}catch(t){return f.fail(y(t)),{success:!1,error:y(t)}}}l(Cl,"cleanup");var Hb=[/^qa-/,/^nonexistent-/,/^test-/];async function Ig(r){let e=A.getGlobalBasePath(),t=jg.join(e,"projects");if(!Tl.existsSync(t))return{success:!0,message:"No projects directory found"};let s=Tl.readdirSync(t,{withFileTypes:!0}),n=[],o=[];for(let i of s){if(!i.isDirectory())continue;let a=i.name,c=jg.join(t,a);if(!Hb.some(p=>p.test(a))){o.push(a);continue}if(r.dryRun){n.push(a);continue}try{F.close(a),Tl.rmSync(c,{recursive:!0,force:!0}),n.push(a)}catch{o.push(a)}}if(r.md){let i=[`## ${r.dryRun?"Dry Run: ":""}Project Cleanup`,"","| Metric | Value |","|---|---|",`| Removed | ${n.length} |`,`| Kept | ${o.length} |`];return n.length>0&&i.push("","### Removed",...n.map(a=>`- \`${a}\``)),{success:!0,message:i.join(`
1149
- `)}}return{success:!0,message:`Cleaned ${n.length} stale project(s), kept ${o.length}`,removed:n,kept:o.length}}l(Ig,"cleanupProjects");zs();V();lt();import $g from"node:path";async function Pl(r=null,e={},t=process.cwd()){try{let s=e.type||"architecture";if(!["architecture","api","component","database","flow"].includes(s))return f.fail(`invalid type: ${s}`),{success:!1,error:"Invalid design type"};let o=r||"system";f.spin(`designing ${s}...`);let i=await I.getProjectId(t),a=$g.join(A.getGlobalProjectPath(i),"planning","designs");await Re.ensureDir(a);let c="";switch(s){case"architecture":c=`# Architecture Design: ${o}
1173
+ `),{success:!1,error:`Unknown topic: ${e}`}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}_generateSparkline(e,t){let s=["\u2581","\u2582","\u2583","\u2584","\u2585","\u2586","\u2587","\u2588"],n=new Date,o=[];for(let a=t-1;a>=0;a--){let c=new Date(n);c.setDate(c.getDate()-a);let u=new Date(c.setHours(0,0,0,0)),p=new Date(c.setHours(23,59,59,999)),m=e.filter(d=>{let g=new Date(d.timestamp);return g>=u&&g<=p}).length;o.push(m)}let i=Math.max(...o,1);return o.map(a=>s[Math.floor(a/i*(s.length-1))]).join("")}};zc();Et();Te();Pt();W();Ks();import Gb from"node:fs/promises";import Wb from"node:path";var an=class{static{l(this,"ContextCommands")}async context(e=null,t=process.cwd(),s={}){try{let n=(e||"").trim().split(/\s+/),o=n[0]||"task",i=n.slice(1).join(" "),a=await $.readConfig(t);if(!a||!a.projectId)return console.log(JSON.stringify({projectId:"",globalPath:"",currentTask:null,domains:[],primaryDomain:null,subtasks:null,repoAnalysis:{ecosystem:"unknown",frameworks:[],hasTests:!1,technologies:[]}},null,2)),{success:!1,message:"No prjct project. Run `p. init` first."};let c=a.projectId,u=A.getGlobalProjectPath(c),p=await _.read(c),m=p?.currentTask?{id:p.currentTask.id,description:p.currentTask.description,startedAt:p.currentTask.startedAt,subtasks:p.currentTask.subtasks?.map(k=>({id:k.id,description:k.description,status:k.status,domain:k.domain})),currentSubtaskIndex:p.currentTask.currentSubtaskIndex}:null,d=null;if(i)try{d=await Ko.execute(o,i,t)}catch(k){console.error(`Warning: Orchestrator failed: ${w(k)}`)}let g=await this.loadRepoAnalysis(u),h={projectId:c,globalPath:u,currentTask:m,domains:d?.detectedDomains||[],primaryDomain:d?.primaryDomain||null,subtasks:d?.subtasks?.map(k=>({id:k.id,description:k.description,domain:k.domain,agent:k.agent,status:k.status,order:k.order}))||null,repoAnalysis:{ecosystem:g?.ecosystem||"unknown",frameworks:g?.frameworks||[],hasTests:g?.hasTests||!1,technologies:g?.technologies||[]}};return s.md?console.log(this.formatContextMd(h)):console.log(JSON.stringify(h,null,2)),{success:!0,message:""}}catch(n){return{success:!1,message:`Context error: ${w(n)}`}}}formatContextMd(e){let t=[];if(t.push(Q("Project",Cc(Tc("ID",e.projectId),Tc("Path",e.globalPath)))),e.currentTask){let s=e.currentTask;if(t.push(Ar({description:s.description,status:"in-progress"})),s.subtasks&&s.subtasks.length>0){let n=s.subtasks.map(o=>`- [${o.status==="completed"?"x":" "}] ${o.description}${o.domain?` (${o.domain})`:""}`);t.push(n.join(`
1174
+ `))}}else t.push("> No active task");return e.repoAnalysis&&t.push(Q("Stack",lt({Ecosystem:e.repoAnalysis.ecosystem,Frameworks:e.repoAnalysis.frameworks.join(", ")||"none",Tests:e.repoAnalysis.hasTests?"yes":"no",Tech:e.repoAnalysis.technologies.join(", ")||"none"}))),L(...t)}async loadRepoAnalysis(e){try{let t=Wb.join(e,"analysis","repo-analysis.json"),s=await Gb.readFile(t,"utf-8"),n=JSON.parse(s);return{ecosystem:n.ecosystem||"unknown",frameworks:n.frameworks||[],hasTests:n.hasTests??!1,technologies:n.technologies||[]}}catch(t){return R(t),null}}},iN=new an;zo();dt();Te();Js();re();ks();Xt();W();dt();import El from"node:fs";import _g from"node:path";async function mi(r){let e=await $.getProjectId(r),t={rotated:[],totalSize:0,freedSpace:0};if(!e)return{success:!0,results:t};let n=N.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(n>500){let o=n-500;N.run(e,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",o),t.rotated.push("memory-events"),t.freedSpace=o}return{success:!0,results:t}}l(mi,"cleanupMemory");async function gi(r){let e=await $.getProjectId(r);if(!e)return;let s=N.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(s>500){let n=s-500;N.run(e,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",n)}}l(gi,"cleanupMemoryInternal");async function xl(r={},e=process.cwd()){try{if(r.memory===!0||r.type==="memory"){f.spin("cleaning memory...");let a=await mi(e);return f.done("memory cleaned"),a}f.spin("cleaning up...");let s=await $.getProjectId(e);if(!s)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let n=[],i=N.get(s,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(i>100){let a=i-100;N.run(s,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",a),n.push(`Memory: ${a} old entries removed`)}else n.push("Memory: No cleanup needed");try{let a=await Ge.cleanup(s);a.removed>0?n.push(`Ideas: ${a.removed} old archived ideas removed`):n.push("Ideas: No cleanup needed")}catch(a){n.push(`Ideas: Error - ${w(a)}`)}try{let c=(await be.getActiveTasks(s)).filter(u=>u.completed).length;c>0?n.push(`Queue: ${c} completed tasks found (not removed - use /p:done to clear)`):n.push("Queue: No completed tasks")}catch(a){n.push(`Queue: Error - ${w(a)}`)}return await gi(e),await xt.log(e,"cleanup_performed",{items:n.length,timestamp:J.getTimestamp()}),f.done(`${n.length} items cleaned`),{success:!0,cleaned:n}}catch(t){return f.fail(w(t)),{success:!1,error:w(t)}}}l(xl,"cleanup");var Vb=[/^qa-/,/^nonexistent-/,/^test-/];async function Og(r){let e=A.getGlobalBasePath(),t=_g.join(e,"projects");if(!El.existsSync(t))return{success:!0,message:"No projects directory found"};let s=El.readdirSync(t,{withFileTypes:!0}),n=[],o=[];for(let i of s){if(!i.isDirectory())continue;let a=i.name,c=_g.join(t,a);if(!Vb.some(p=>p.test(a))){o.push(a);continue}if(r.dryRun){n.push(a);continue}try{N.close(a),El.rmSync(c,{recursive:!0,force:!0}),n.push(a)}catch{o.push(a)}}if(r.md){let i=[`## ${r.dryRun?"Dry Run: ":""}Project Cleanup`,"","| Metric | Value |","|---|---|",`| Removed | ${n.length} |`,`| Kept | ${o.length} |`];return n.length>0&&i.push("","### Removed",...n.map(a=>`- \`${a}\``)),{success:!0,message:i.join(`
1175
+ `)}}return{success:!0,message:`Cleaned ${n.length} stale project(s), kept ${o.length}`,removed:n,kept:o.length}}l(Og,"cleanupProjects");Js();W();dt();import Ng from"node:path";async function Rl(r=null,e={},t=process.cwd()){try{let s=e.type||"architecture";if(!["architecture","api","component","database","flow"].includes(s))return f.fail(`invalid type: ${s}`),{success:!1,error:"Invalid design type"};let o=r||"system";f.spin(`designing ${s}...`);let i=await $.getProjectId(t),a=Ng.join(A.getGlobalProjectPath(i),"planning","designs");await Re.ensureDir(a);let c="";switch(s){case"architecture":c=`# Architecture Design: ${o}
1150
1176
 
1151
1177
  *Use templates/design/architecture.md for full design*
1152
1178
  `;break;case"api":c=`# API Design: ${o}
@@ -1161,14 +1187,14 @@ ${"\u2550".repeat(50)}
1161
1187
  `;break;case"flow":c=`# Flow Design: ${o}
1162
1188
 
1163
1189
  *Use templates/design/flow.md for full design*
1164
- `;break}let u=`${s}-${o.toLowerCase().replace(/\s+/g,"-")}.md`,p=$g.join(a,u);return await Re.writeFile(p,c),await xt.log(t,"design_created",{type:s,target:o,timestamp:z.getTimestamp()}),f.done(`${s} design created`),{success:!0,designPath:p,type:s,target:o}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}l(Pl,"design");zs();import _n from"node:path";ss();ce();var Be={SESSION_STARTED:"session.started",SESSION_PAUSED:"session.paused",SESSION_RESUMED:"session.resumed",SESSION_COMPLETED:"session.completed",TASK_CREATED:"task.created",TASK_COMPLETED:"task.completed",TASK_UPDATED:"task.updated",FEATURE_ADDED:"feature.added",FEATURE_SHIPPED:"feature.shipped",FEATURE_UPDATED:"feature.updated",IDEA_CAPTURED:"idea.captured",IDEA_PROMOTED:"idea.promoted",SNAPSHOT_CREATED:"snapshot.created",SNAPSHOT_RESTORED:"snapshot.restored",COMMIT_CREATED:"git.commit",PUSH_COMPLETED:"git.push",PROJECT_INITIALIZED:"project.init",PROJECT_SYNCED:"project.sync",ANALYSIS_COMPLETED:"analysis.completed",ALL:"*"};Ws();ns();var El=class{static{l(this,"EventBus")}listeners;onceListeners;history;historyLimit;projectId;constructor(){this.listeners=new Map,this.onceListeners=new Map,this.history=[],this.historyLimit=Ld.HISTORY_MAX,this.projectId=null}async initialize(e){this.projectId=e}on(e,t){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(t),()=>this.off(e,t)}once(e,t){return this.onceListeners.has(e)||this.onceListeners.set(e,new Set),this.onceListeners.get(e).add(t),()=>{let s=this.onceListeners.get(e);s&&s.delete(t)}}off(e,t){let s=this.listeners.get(e);s&&s.delete(t)}async emit(e,t={}){let s=new Date().toISOString(),n={type:e,timestamp:s,projectId:this.projectId,...t};this.history.push(n),this.history.length>this.historyLimit&&this.history.shift(),this.projectId&&await this.logEvent(n);let o=this.getMatchingListeners(e);(await Promise.allSettled(o.map(u=>this.executeCallback(u,n)))).forEach(u=>{u.status==="rejected"&&W.error(`Event listener error for ${e}:`,u.reason)});let a=this.onceListeners.get(e);if(a){for(let u of a)await this.executeCallback(u,n);this.onceListeners.delete(e)}let c=this.onceListeners.get(Be.ALL);if(c)for(let u of c)await this.executeCallback(u,n)}getMatchingListeners(e){let t=[],s=this.listeners.get(e);s&&t.push(...s);let n=this.listeners.get(Be.ALL);n&&t.push(...n);let o=e.split(".")[0],i=this.listeners.get(`${o}.*`);return i&&t.push(...i),t}async executeCallback(e,t){try{let s=e(t);s instanceof Promise&&await s}catch(s){throw W.error("Event callback error:",s),s}}async logEvent(e){try{P.appendEvent(this.projectId,e.type,e)}catch(t){W.debug("Failed to log event:",ue(t))}}getHistory(e=10,t=null){let s=this.history;return t&&(s=s.filter(n=>n.type===t||n.type.startsWith(t))),s.slice(-e)}clear(){this.listeners.clear(),this.onceListeners.clear()}flush(){this.history=[],this.onceListeners.clear()}removeAllListeners(e){e?(this.listeners.delete(e),this.onceListeners.delete(e)):(this.listeners.clear(),this.onceListeners.clear())}listenerCount(e){let t=this.listeners.get(e);return t?t.size:0}getRegisteredEvents(){return Array.from(this.listeners.keys())}},ut=new El,Or={sessionStarted:l(r=>ut.emit(Be.SESSION_STARTED,r),"sessionStarted"),sessionPaused:l(r=>ut.emit(Be.SESSION_PAUSED,r),"sessionPaused"),sessionResumed:l(r=>ut.emit(Be.SESSION_RESUMED,r),"sessionResumed"),sessionCompleted:l(r=>ut.emit(Be.SESSION_COMPLETED,r),"sessionCompleted"),taskCreated:l(r=>ut.emit(Be.TASK_CREATED,r),"taskCreated"),taskCompleted:l(r=>ut.emit(Be.TASK_COMPLETED,r),"taskCompleted"),featureAdded:l(r=>ut.emit(Be.FEATURE_ADDED,r),"featureAdded"),featureShipped:l(r=>ut.emit(Be.FEATURE_SHIPPED,r),"featureShipped"),ideaCaptured:l(r=>ut.emit(Be.IDEA_CAPTURED,r),"ideaCaptured"),snapshotCreated:l(r=>ut.emit(Be.SNAPSHOT_CREATED,r),"snapshotCreated"),snapshotRestored:l(r=>ut.emit(Be.SNAPSHOT_RESTORED,r),"snapshotRestored"),commitCreated:l(r=>ut.emit(Be.COMMIT_CREATED,r),"commitCreated"),pushCompleted:l(r=>ut.emit(Be.PUSH_COMPLETED,r),"pushCompleted"),projectInitialized:l(r=>ut.emit(Be.PROJECT_INITIALIZED,r),"projectInitialized"),projectSynced:l(r=>ut.emit(Be.PROJECT_SYNCED,r),"projectSynced"),analysisCompleted:l(r=>ut.emit(Be.ANALYSIS_COMPLETED,r),"analysisCompleted")};Et();ce();V();Ue();It();oe();var Mg=ye;function di(r){let e=0,t=null;for(let s of r.timeline)s.type==="start"||s.type==="resume"?t=new Date(s.at):(s.type==="pause"||s.type==="complete")&&t&&(e+=new Date(s.at).getTime()-t.getTime(),t=null);return t&&r.status==="active"&&(e+=Date.now()-t.getTime()),Math.round(e/1e3)}l(di,"calculateDuration");function Og(r){return ft(r*1e3)}l(Og,"formatDuration");function _g(r){return{id:r.id,projectId:r.project_id,task:r.task,status:r.status,startedAt:r.started_at,pausedAt:r.paused_at,completedAt:r.completed_at,duration:r.duration,metrics:JSON.parse(r.metrics),timeline:JSON.parse(r.timeline)}}l(_g,"rowToSession");var pi=class{static{l(this,"TaskSessionManager")}projectPath;projectId;initialized;constructor(e){this.projectPath=e,this.projectId=null,this.initialized=!1}async initialize(){if(this.projectId=await I.getProjectId(this.projectPath),!this.projectId)throw new Error("No prjct project found. Run /p:init first.");P.getDb(this.projectId),this.initialized=!0}generateId(){return Mg()}async getCurrent(){this.initialized||await this.initialize();let e=P.get(this.projectId,"SELECT * FROM sessions WHERE project_id = ? AND status IN ('active', 'paused') ORDER BY started_at DESC LIMIT 1",this.projectId);return e?_g(e):null}async create(e){this.initialized||await this.initialize();let t=await this.getCurrent();if(t&&t.status==="active")throw new Error(`Session already active: "${t.task}". Use /p:done or /p:pause first.`);let s=new Date().toISOString(),n={id:this.generateId(),projectId:this.projectId,task:e,status:"active",startedAt:s,pausedAt:null,completedAt:null,duration:0,metrics:{filesCreated:0,filesChanged:0,filesModified:0,linesAdded:0,linesRemoved:0,commits:0,snapshots:[]},timeline:[{type:"start",at:s}]};return this.saveSession(n),await this.logEvent("session_started",{sessionId:n.id,task:e}),await Or.sessionStarted({sessionId:n.id,task:e,projectId:this.projectId}),n}async resume(e=null){this.initialized||await this.initialize();let t=await this.getCurrent();if(e&&(!t||t.task!==e))return this.create(e);if(!t){if(!e)throw new Error("No active session. Provide a task to start one.");return this.create(e)}if(t.status==="active")return t;let s=new Date().toISOString();return t.status="active",t.timeline.push({type:"resume",at:s}),this.saveSession(t),await this.logEvent("session_resumed",{sessionId:t.id}),await Or.sessionResumed({sessionId:t.id,task:t.task,projectId:this.projectId}),t}async pause(){this.initialized||await this.initialize();let e=await this.getCurrent();if(!e)throw new Error("No active session to pause.");if(e.status==="paused")return e;let t=new Date().toISOString();return e.status="paused",e.pausedAt=t,e.duration=di(e),e.timeline.push({type:"pause",at:t}),this.saveSession(e),await this.logEvent("session_paused",{sessionId:e.id,duration:e.duration}),await Or.sessionPaused({sessionId:e.id,task:e.task,duration:e.duration,projectId:this.projectId}),e}async complete(){this.initialized||await this.initialize();let e=await this.getCurrent();if(!e)throw new Error("No active session to complete.");let t=new Date().toISOString();return e.status="completed",e.completedAt=t,e.duration=di(e),e.metrics=await this.calculateMetrics(e),e.timeline.push({type:"complete",at:t}),this.saveSession(e),await this.logEvent("session_completed",{sessionId:e.id,task:e.task,duration:e.duration,metrics:e.metrics}),await Or.sessionCompleted({sessionId:e.id,task:e.task,duration:e.duration,metrics:e.metrics,projectId:this.projectId}),e}calculateDuration(e){return di(e)}async calculateMetrics(e){let t={...e.metrics};try{let s=e.startedAt.split("T")[0],{stdout:n}=await N(`git rev-list --count --since="${s}" HEAD 2>/dev/null || echo "0"`,{cwd:this.projectPath});t.commits=parseInt(n.trim(),10)||0;let{stdout:o}=await N(`git diff --stat HEAD~${Math.max(t.commits,1)} 2>/dev/null || echo ""`,{cwd:this.projectPath}),i=o.split(`
1165
- `),c=(i[i.length-2]||"").match(/(\d+) files? changed(?:, (\d+) insertions?)?(?:, (\d+) deletions?)?/);c&&(t.filesChanged=parseInt(c[1],10)||0,t.linesAdded=parseInt(c[2],10)||0,t.linesRemoved=parseInt(c[3],10)||0)}catch(s){R(s)||console.error(`Metrics calculation warning: ${y(s)}`)}return t}saveSession(e){P.run(this.projectId,`INSERT OR REPLACE INTO sessions (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
1166
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,e.id,e.projectId,e.task,e.status,e.startedAt,e.pausedAt??null,e.completedAt??null,e.duration,JSON.stringify(e.metrics),JSON.stringify(e.timeline))}async getHistory(e=10){return this.initialized||await this.initialize(),P.query(this.projectId,"SELECT * FROM sessions WHERE project_id = ? AND status = 'completed' ORDER BY completed_at DESC LIMIT ?",this.projectId,e).map(_g)}async logEvent(e,t){try{P.appendEvent(this.projectId,`session.${e}`,t)}catch{}}static formatDuration(e){return Og(e)}};V();lt();async function xl(r=process.cwd()){try{if(!await I.getProjectId(r))return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};f.spin("checking for abandoned sessions...");let s=await new pi(r).getCurrent(),n=s?{task:s.task,startedAt:s.startedAt}:null;if(!n||!n.task)return f.warn("no abandoned session found"),{success:!0,message:"No abandoned session found"};if(console.log(`
1190
+ `;break}let u=`${s}-${o.toLowerCase().replace(/\s+/g,"-")}.md`,p=Ng.join(a,u);return await Re.writeFile(p,c),await xt.log(t,"design_created",{type:s,target:o,timestamp:J.getTimestamp()}),f.done(`${s} design created`),{success:!0,designPath:p,type:s,target:o}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}l(Rl,"design");Js();import On from"node:path";ss();re();var ze={SESSION_STARTED:"session.started",SESSION_PAUSED:"session.paused",SESSION_RESUMED:"session.resumed",SESSION_COMPLETED:"session.completed",TASK_CREATED:"task.created",TASK_COMPLETED:"task.completed",TASK_UPDATED:"task.updated",FEATURE_ADDED:"feature.added",FEATURE_SHIPPED:"feature.shipped",FEATURE_UPDATED:"feature.updated",IDEA_CAPTURED:"idea.captured",IDEA_PROMOTED:"idea.promoted",SNAPSHOT_CREATED:"snapshot.created",SNAPSHOT_RESTORED:"snapshot.restored",COMMIT_CREATED:"git.commit",PUSH_COMPLETED:"git.push",PROJECT_INITIALIZED:"project.init",PROJECT_SYNCED:"project.sync",ANALYSIS_COMPLETED:"analysis.completed",ALL:"*"};Vs();ns();var Al=class{static{l(this,"EventBus")}listeners;onceListeners;history;historyLimit;projectId;constructor(){this.listeners=new Map,this.onceListeners=new Map,this.history=[],this.historyLimit=Hd.HISTORY_MAX,this.projectId=null}async initialize(e){this.projectId=e}on(e,t){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(t),()=>this.off(e,t)}once(e,t){return this.onceListeners.has(e)||this.onceListeners.set(e,new Set),this.onceListeners.get(e).add(t),()=>{let s=this.onceListeners.get(e);s&&s.delete(t)}}off(e,t){let s=this.listeners.get(e);s&&s.delete(t)}async emit(e,t={}){let s=new Date().toISOString(),n={type:e,timestamp:s,projectId:this.projectId,...t};this.history.push(n),this.history.length>this.historyLimit&&this.history.shift(),this.projectId&&await this.logEvent(n);let o=this.getMatchingListeners(e);(await Promise.allSettled(o.map(u=>this.executeCallback(u,n)))).forEach(u=>{u.status==="rejected"&&V.error(`Event listener error for ${e}:`,u.reason)});let a=this.onceListeners.get(e);if(a){for(let u of a)await this.executeCallback(u,n);this.onceListeners.delete(e)}let c=this.onceListeners.get(ze.ALL);if(c)for(let u of c)await this.executeCallback(u,n)}getMatchingListeners(e){let t=[],s=this.listeners.get(e);s&&t.push(...s);let n=this.listeners.get(ze.ALL);n&&t.push(...n);let o=e.split(".")[0],i=this.listeners.get(`${o}.*`);return i&&t.push(...i),t}async executeCallback(e,t){try{let s=e(t);s instanceof Promise&&await s}catch(s){throw V.error("Event callback error:",s),s}}async logEvent(e){try{C.appendEvent(this.projectId,e.type,e)}catch(t){V.debug("Failed to log event:",ue(t))}}getHistory(e=10,t=null){let s=this.history;return t&&(s=s.filter(n=>n.type===t||n.type.startsWith(t))),s.slice(-e)}clear(){this.listeners.clear(),this.onceListeners.clear()}flush(){this.history=[],this.onceListeners.clear()}removeAllListeners(e){e?(this.listeners.delete(e),this.onceListeners.delete(e)):(this.listeners.clear(),this.onceListeners.clear())}listenerCount(e){let t=this.listeners.get(e);return t?t.size:0}getRegisteredEvents(){return Array.from(this.listeners.keys())}},pt=new Al,Nr={sessionStarted:l(r=>pt.emit(ze.SESSION_STARTED,r),"sessionStarted"),sessionPaused:l(r=>pt.emit(ze.SESSION_PAUSED,r),"sessionPaused"),sessionResumed:l(r=>pt.emit(ze.SESSION_RESUMED,r),"sessionResumed"),sessionCompleted:l(r=>pt.emit(ze.SESSION_COMPLETED,r),"sessionCompleted"),taskCreated:l(r=>pt.emit(ze.TASK_CREATED,r),"taskCreated"),taskCompleted:l(r=>pt.emit(ze.TASK_COMPLETED,r),"taskCompleted"),featureAdded:l(r=>pt.emit(ze.FEATURE_ADDED,r),"featureAdded"),featureShipped:l(r=>pt.emit(ze.FEATURE_SHIPPED,r),"featureShipped"),ideaCaptured:l(r=>pt.emit(ze.IDEA_CAPTURED,r),"ideaCaptured"),snapshotCreated:l(r=>pt.emit(ze.SNAPSHOT_CREATED,r),"snapshotCreated"),snapshotRestored:l(r=>pt.emit(ze.SNAPSHOT_RESTORED,r),"snapshotRestored"),commitCreated:l(r=>pt.emit(ze.COMMIT_CREATED,r),"commitCreated"),pushCompleted:l(r=>pt.emit(ze.PUSH_COMPLETED,r),"pushCompleted"),projectInitialized:l(r=>pt.emit(ze.PROJECT_INITIALIZED,r),"projectInitialized"),projectSynced:l(r=>pt.emit(ze.PROJECT_SYNCED,r),"projectSynced"),analysisCompleted:l(r=>pt.emit(ze.ANALYSIS_COMPLETED,r),"analysisCompleted")};Et();re();W();He();It();ie();var Lg=ye;function fi(r){let e=0,t=null;for(let s of r.timeline)s.type==="start"||s.type==="resume"?t=new Date(s.at):(s.type==="pause"||s.type==="complete")&&t&&(e+=new Date(s.at).getTime()-t.getTime(),t=null);return t&&r.status==="active"&&(e+=Date.now()-t.getTime()),Math.round(e/1e3)}l(fi,"calculateDuration");function Fg(r){return ht(r*1e3)}l(Fg,"formatDuration");function Ug(r){return{id:r.id,projectId:r.project_id,task:r.task,status:r.status,startedAt:r.started_at,pausedAt:r.paused_at,completedAt:r.completed_at,duration:r.duration,metrics:JSON.parse(r.metrics),timeline:JSON.parse(r.timeline)}}l(Ug,"rowToSession");var hi=class{static{l(this,"TaskSessionManager")}projectPath;projectId;initialized;constructor(e){this.projectPath=e,this.projectId=null,this.initialized=!1}async initialize(){if(this.projectId=await $.getProjectId(this.projectPath),!this.projectId)throw new Error("No prjct project found. Run /p:init first.");C.getDb(this.projectId),this.initialized=!0}generateId(){return Lg()}async getCurrent(){this.initialized||await this.initialize();let e=C.get(this.projectId,"SELECT * FROM sessions WHERE project_id = ? AND status IN ('active', 'paused') ORDER BY started_at DESC LIMIT 1",this.projectId);return e?Ug(e):null}async create(e){this.initialized||await this.initialize();let t=await this.getCurrent();if(t&&t.status==="active")throw new Error(`Session already active: "${t.task}". Use /p:done or /p:pause first.`);let s=new Date().toISOString(),n={id:this.generateId(),projectId:this.projectId,task:e,status:"active",startedAt:s,pausedAt:null,completedAt:null,duration:0,metrics:{filesCreated:0,filesChanged:0,filesModified:0,linesAdded:0,linesRemoved:0,commits:0,snapshots:[]},timeline:[{type:"start",at:s}]};return this.saveSession(n),await this.logEvent("session_started",{sessionId:n.id,task:e}),await Nr.sessionStarted({sessionId:n.id,task:e,projectId:this.projectId}),n}async resume(e=null){this.initialized||await this.initialize();let t=await this.getCurrent();if(e&&(!t||t.task!==e))return this.create(e);if(!t){if(!e)throw new Error("No active session. Provide a task to start one.");return this.create(e)}if(t.status==="active")return t;let s=new Date().toISOString();return t.status="active",t.timeline.push({type:"resume",at:s}),this.saveSession(t),await this.logEvent("session_resumed",{sessionId:t.id}),await Nr.sessionResumed({sessionId:t.id,task:t.task,projectId:this.projectId}),t}async pause(){this.initialized||await this.initialize();let e=await this.getCurrent();if(!e)throw new Error("No active session to pause.");if(e.status==="paused")return e;let t=new Date().toISOString();return e.status="paused",e.pausedAt=t,e.duration=fi(e),e.timeline.push({type:"pause",at:t}),this.saveSession(e),await this.logEvent("session_paused",{sessionId:e.id,duration:e.duration}),await Nr.sessionPaused({sessionId:e.id,task:e.task,duration:e.duration,projectId:this.projectId}),e}async complete(){this.initialized||await this.initialize();let e=await this.getCurrent();if(!e)throw new Error("No active session to complete.");let t=new Date().toISOString();return e.status="completed",e.completedAt=t,e.duration=fi(e),e.metrics=await this.calculateMetrics(e),e.timeline.push({type:"complete",at:t}),this.saveSession(e),await this.logEvent("session_completed",{sessionId:e.id,task:e.task,duration:e.duration,metrics:e.metrics}),await Nr.sessionCompleted({sessionId:e.id,task:e.task,duration:e.duration,metrics:e.metrics,projectId:this.projectId}),e}calculateDuration(e){return fi(e)}async calculateMetrics(e){let t={...e.metrics};try{let s=e.startedAt.split("T")[0],{stdout:n}=await O(`git rev-list --count --since="${s}" HEAD 2>/dev/null || echo "0"`,{cwd:this.projectPath});t.commits=parseInt(n.trim(),10)||0;let{stdout:o}=await O(`git diff --stat HEAD~${Math.max(t.commits,1)} 2>/dev/null || echo ""`,{cwd:this.projectPath}),i=o.split(`
1191
+ `),c=(i[i.length-2]||"").match(/(\d+) files? changed(?:, (\d+) insertions?)?(?:, (\d+) deletions?)?/);c&&(t.filesChanged=parseInt(c[1],10)||0,t.linesAdded=parseInt(c[2],10)||0,t.linesRemoved=parseInt(c[3],10)||0)}catch(s){R(s)||console.error(`Metrics calculation warning: ${w(s)}`)}return t}saveSession(e){C.run(this.projectId,`INSERT OR REPLACE INTO sessions (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
1192
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,e.id,e.projectId,e.task,e.status,e.startedAt,e.pausedAt??null,e.completedAt??null,e.duration,JSON.stringify(e.metrics),JSON.stringify(e.timeline))}async getHistory(e=10){return this.initialized||await this.initialize(),C.query(this.projectId,"SELECT * FROM sessions WHERE project_id = ? AND status = 'completed' ORDER BY completed_at DESC LIMIT ?",this.projectId,e).map(Ug)}async logEvent(e,t){try{C.appendEvent(this.projectId,`session.${e}`,t)}catch{}}static formatDuration(e){return Fg(e)}};W();dt();async function Dl(r=process.cwd()){try{if(!await $.getProjectId(r))return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};f.spin("checking for abandoned sessions...");let s=await new hi(r).getCurrent(),n=s?{task:s.task,startedAt:s.startedAt}:null;if(!n||!n.task)return f.warn("no abandoned session found"),{success:!0,message:"No abandoned session found"};if(console.log(`
1167
1193
  Found abandoned session:
1168
- `),console.log(` Task: ${n.task}`),n.startedAt){let o=z.calculateDuration(new Date(n.startedAt));console.log(` Started: ${o} ago`)}return n.context&&console.log(` Context: ${n.context.slice(0,100)}...`),console.log(`
1194
+ `),console.log(` Task: ${n.task}`),n.startedAt){let o=J.calculateDuration(new Date(n.startedAt));console.log(` Started: ${o} ago`)}return n.context&&console.log(` Context: ${n.context.slice(0,100)}...`),console.log(`
1169
1195
  Options:`),console.log(" 1. Use /p:work to resume working"),console.log(" 2. Use /p:done to mark as complete"),console.log(` 3. Delete session file to discard
1170
- `),{success:!0,session:n}}catch(e){return f.fail(y(e)),{success:!1,error:y(e)}}}l(xl,"recover");async function Rl(r=process.cwd()){try{f.spin("creating undo point...");let e=await I.getProjectId(r);if(!e)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=_n.join(A.getGlobalProjectPath(e),"snapshots");await Re.ensureDir(t);let{execSync:s}=await import("node:child_process");try{if(!s("git status --porcelain",{cwd:r,encoding:"utf-8"}).trim())return f.warn("nothing to undo (no changes)"),{success:!0,message:"No changes to undo"};let i=`prjct-undo-${new Date().toISOString().replace(/[:.]/g,"-")}`;s(`git stash push -m "${i}"`,{cwd:r,encoding:"utf-8"});let a=_n.join(t,"history.json"),c={snapshots:[],current:-1};try{let u=await Re.readFile(a);c=JSON.parse(u)}catch(u){if(!R(u)&&!(u instanceof SyntaxError))throw u}return c.snapshots.push({id:i,timestamp:new Date().toISOString(),message:i}),c.current=c.snapshots.length-1,await Re.writeFile(a,JSON.stringify(c,null,2)),await xt.log(r,"undo_performed",{snapshotId:i,timestamp:z.getTimestamp()}),f.done("changes stashed (use /p:redo to restore)"),{success:!0,snapshotId:i}}catch(n){return f.failWithHint("GIT_OPERATION_FAILED"),{success:!1,error:y(n)}}}catch(e){return f.fail(y(e)),{success:!1,error:y(e)}}}l(Rl,"undo");async function Al(r=process.cwd()){try{f.spin("restoring changes...");let e=await I.getProjectId(r);if(!e)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=_n.join(A.getGlobalProjectPath(e),"snapshots"),s=_n.join(t,"history.json"),n;try{let i=await Re.readFile(s);n=JSON.parse(i)}catch(i){if(R(i)||i instanceof SyntaxError)return f.warn("no undo history found"),{success:!1,message:"No undo history found"};throw i}if(n.snapshots.length===0)return f.warn("nothing to redo"),{success:!1,message:"Nothing to redo"};let{execSync:o}=await import("node:child_process");try{let i=o("git stash list",{cwd:r,encoding:"utf-8"}).trim();return i?i.split(`
1171
- `).find(c=>c.includes("prjct-undo-"))?(o("git stash pop",{cwd:r,encoding:"utf-8"}),n.snapshots.pop(),n.current=Math.max(0,n.current-1),await Re.writeFile(s,JSON.stringify(n,null,2)),await xt.log(r,"redo_performed",{timestamp:z.getTimestamp()}),f.done("changes restored"),{success:!0}):(f.warn("no prjct undo point found"),{success:!1,message:"No prjct undo point found"}):(f.warn("no stashed changes"),{success:!1,message:"No stashed changes found"})}catch(i){return f.failWithHint("GIT_OPERATION_FAILED"),{success:!1,error:y(i)}}}catch(e){return f.fail(y(e)),{success:!1,error:y(e)}}}l(Al,"redo");async function Dl(r=process.cwd()){try{let e=await I.getProjectId(r);if(!e)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=_n.join(A.getGlobalProjectPath(e),"snapshots"),s=_n.join(t,"history.json"),n;try{let o=await Re.readFile(s);n=JSON.parse(o)}catch(o){if(R(o)||o instanceof SyntaxError)return console.log(`
1196
+ `),{success:!0,session:n}}catch(e){return f.fail(w(e)),{success:!1,error:w(e)}}}l(Dl,"recover");async function jl(r=process.cwd()){try{f.spin("creating undo point...");let e=await $.getProjectId(r);if(!e)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=On.join(A.getGlobalProjectPath(e),"snapshots");await Re.ensureDir(t);let{execSync:s}=await import("node:child_process");try{if(!s("git status --porcelain",{cwd:r,encoding:"utf-8"}).trim())return f.warn("nothing to undo (no changes)"),{success:!0,message:"No changes to undo"};let i=`prjct-undo-${new Date().toISOString().replace(/[:.]/g,"-")}`;s(`git stash push -m "${i}"`,{cwd:r,encoding:"utf-8"});let a=On.join(t,"history.json"),c={snapshots:[],current:-1};try{let u=await Re.readFile(a);c=JSON.parse(u)}catch(u){if(!R(u)&&!(u instanceof SyntaxError))throw u}return c.snapshots.push({id:i,timestamp:new Date().toISOString(),message:i}),c.current=c.snapshots.length-1,await Re.writeFile(a,JSON.stringify(c,null,2)),await xt.log(r,"undo_performed",{snapshotId:i,timestamp:J.getTimestamp()}),f.done("changes stashed (use /p:redo to restore)"),{success:!0,snapshotId:i}}catch(n){return f.failWithHint("GIT_OPERATION_FAILED"),{success:!1,error:w(n)}}}catch(e){return f.fail(w(e)),{success:!1,error:w(e)}}}l(jl,"undo");async function Il(r=process.cwd()){try{f.spin("restoring changes...");let e=await $.getProjectId(r);if(!e)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=On.join(A.getGlobalProjectPath(e),"snapshots"),s=On.join(t,"history.json"),n;try{let i=await Re.readFile(s);n=JSON.parse(i)}catch(i){if(R(i)||i instanceof SyntaxError)return f.warn("no undo history found"),{success:!1,message:"No undo history found"};throw i}if(n.snapshots.length===0)return f.warn("nothing to redo"),{success:!1,message:"Nothing to redo"};let{execSync:o}=await import("node:child_process");try{let i=o("git stash list",{cwd:r,encoding:"utf-8"}).trim();return i?i.split(`
1197
+ `).find(c=>c.includes("prjct-undo-"))?(o("git stash pop",{cwd:r,encoding:"utf-8"}),n.snapshots.pop(),n.current=Math.max(0,n.current-1),await Re.writeFile(s,JSON.stringify(n,null,2)),await xt.log(r,"redo_performed",{timestamp:J.getTimestamp()}),f.done("changes restored"),{success:!0}):(f.warn("no prjct undo point found"),{success:!1,message:"No prjct undo point found"}):(f.warn("no stashed changes"),{success:!1,message:"No stashed changes found"})}catch(i){return f.failWithHint("GIT_OPERATION_FAILED"),{success:!1,error:w(i)}}}catch(e){return f.fail(w(e)),{success:!1,error:w(e)}}}l(Il,"redo");async function $l(r=process.cwd()){try{let e=await $.getProjectId(r);if(!e)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=On.join(A.getGlobalProjectPath(e),"snapshots"),s=On.join(t,"history.json"),n;try{let o=await Re.readFile(s);n=JSON.parse(o)}catch(o){if(R(o)||o instanceof SyntaxError)return console.log(`
1172
1198
  SNAPSHOT HISTORY
1173
1199
  `),console.log("=".repeat(50)),console.log(" No snapshots yet."),console.log(` Use /p:undo to create a snapshot.
1174
1200
  `),{success:!0,snapshots:[]};throw o}return console.log(`
@@ -1176,12 +1202,12 @@ ${"\u2550".repeat(50)}
1176
1202
  `),console.log("=".repeat(50)),n.snapshots.length===0?(console.log(" No snapshots yet."),console.log(` Use /p:undo to create a snapshot.
1177
1203
  `)):(n.snapshots.forEach((o,i)=>{let a=i===n.current?">":" ",c=new Date(o.timestamp).toLocaleString();console.log(` ${a} ${i+1}. ${c}`)}),console.log(""),console.log(` ${n.snapshots.length} snapshot(s) available`),console.log(` Use /p:redo to restore the latest
1178
1204
  `)),console.log(`${"=".repeat(50)}
1179
- `),{success:!0,snapshots:n.snapshots,current:n.current}}catch(e){return f.fail(y(e)),{success:!1,error:y(e)}}}l(Dl,"history");var Nn=class extends Ce{static{l(this,"MaintenanceCommands")}_cleanupMemory=li;_cleanupMemoryInternal=ui;async cleanup(e={},t=process.cwd()){let s=await this.ensureProjectInit(t);return s.success?Cl(e,t):s}async cleanupProjects(e={}){return Ig(e)}async design(e=null,t={},s=process.cwd()){let n=await this.ensureProjectInit(s);return n.success?Pl(e,t,s):n}async recover(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?xl(e):t}async undo(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Rl(e):t}async redo(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Al(e):t}async history(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Dl(e):t}async enrich(e=null,t=process.cwd(),s={}){let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=e?.trim();if(!o)return{success:!1,error:"Missing issue ID or description",message:'Usage: prjct enrich "<issue-id-or-description>" --md'};let i=o.match(/\b[A-Z]+-\d+\b/)?.[0]||null,a=await An(o,t,{maxFiles:10,minScore:.1,includeTests:!0}),c={success:!0,mode:"mcp",issueId:i,query:o,files:a.files.map(u=>({path:u.path,score:Number(u.score.toFixed(3)),reasons:u.reasons})),publish:{linear:"Use your AI client Linear MCP tools to update description/comment.",jira:"Use your AI client Jira MCP tools to update description/comment."}};if(s.json)return console.log(JSON.stringify(c,null,2)),{success:!0};if(s.md){let u=[];if(u.push("## Enrichment Context"),u.push(""),u.push(`- Query: ${o}`),i&&u.push(`- Issue ID: ${i}`),u.push(`- Candidate files: ${c.files.length}`),u.push(""),u.push("### Suggested Files"),u.push(""),c.files.length===0)u.push("- No relevant files found.");else for(let p of c.files)u.push(`- \`${p.path}\` (${p.score})`);return u.push(""),u.push("### Publish"),u.push(""),u.push("- Update description via MCP"),u.push("- Add enrichment as comment via MCP"),u.push("- Or keep local only"),console.log(u.join(`
1180
- `)),{success:!0}}return{success:!0,message:`Prepared enrichment context (${c.files.length} files).`}}};import $e from"chalk";ce();var Gb=BigInt(300*1e9),jl=class{static{l(this,"PerformanceTracker")}marks=new Map;markStart(e){this.pruneStaleMarks(),this.marks.set(e,process.hrtime.bigint())}markEnd(e){let t=this.marks.get(e);if(t===void 0)return null;let s=process.hrtime.bigint();return this.marks.delete(e),Number(s-t)/1e6}pruneStaleMarks(){if(this.marks.size<10)return;let e=process.hrtime.bigint();for(let[t,s]of this.marks)e-s>Gb&&this.marks.delete(t)}recordTiming(e,t,s,n){F.appendEvent(e,`perf.${t}`,{metric:t,value:Math.round(s*100)/100,unit:"ms",context:n})}snapshotMemory(){let e=process.memoryUsage();return{heapUsed:e.heapUsed,heapTotal:e.heapTotal,rss:e.rss,external:e.external}}recordMemory(e,t){let s=this.snapshotMemory(),n=[{metric:"heap_used",value:s.heapUsed,unit:"bytes"},{metric:"heap_total",value:s.heapTotal,unit:"bytes"},{metric:"rss",value:s.rss,unit:"bytes"},{metric:"external_memory",value:s.external,unit:"bytes"}];for(let o of n)F.appendEvent(e,`perf.${o.metric}`,{metric:o.metric,value:o.value,unit:o.unit,context:t});return s}recordContextCorrectness(e,t){F.appendEvent(e,"perf.context_correctness",{metric:"context_correctness",...t})}recordSubtaskHandoff(e,t){F.appendEvent(e,"perf.subtask_handoff",{metric:"subtask_handoff",...t})}getMetrics(e,t){t||(t=new Date,t.setDate(t.getDate()-7));let s=t.toISOString();return F.query(e,"SELECT data, timestamp FROM events WHERE type LIKE ? AND timestamp >= ? ORDER BY id DESC","perf.%",s).map(o=>({...JSON.parse(o.data),timestamp:o.timestamp}))}getReport(e,t=7){let s=new Date;s.setDate(s.getDate()-t),s.setHours(0,0,0,0);let n=this.getMetrics(e,s),o={period:`${t}d`},i=n.filter(d=>"metric"in d&&d.metric==="startup_time");if(i.length>0){let d=i.map(g=>g.value);o.startup={avg:Math.round(d.reduce((g,h)=>g+h,0)/d.length),min:Math.min(...d),max:Math.max(...d),count:d.length,unit:"ms"}}let a=n.filter(d=>"metric"in d&&d.metric==="heap_used"),c=n.filter(d=>"metric"in d&&d.metric==="rss");if(a.length>0){let d=l(k=>Math.round(k/1048576*10)/10,"toMB"),g=a.map(k=>k.value),h=c.map(k=>k.value);o.memory={avgHeapMB:d(g.reduce((k,w)=>k+w,0)/g.length),peakHeapMB:d(Math.max(...g)),avgRssMB:h.length>0?d(h.reduce((k,w)=>k+w,0)/h.length):0}}let u=n.filter(d=>"metric"in d&&d.metric==="context_correctness");if(u.length>0){let d=u.filter(g=>g.receivedSync).length;o.contextCorrectness={total:u.length,receivedSync:d,rate:Math.round(d/u.length*100)}}let p=n.filter(d=>"metric"in d&&d.metric==="subtask_handoff");if(p.length>0){let d=p.filter(g=>g.outputPopulated).length;o.subtaskHandoff={total:p.length,outputPopulated:d,rate:Math.round(d/p.length*100)}}let m=n.filter(d=>"metric"in d&&d.metric==="command_duration");if(m.length>0){let d={};for(let g of m){let h=g.context?.command||"unknown";d[h]||(d[h]=[]),d[h].push(g.value)}o.commandDurations={};for(let[g,h]of Object.entries(d))o.commandDurations[g]={avg:Math.round(h.reduce((k,w)=>k+w,0)/h.length),min:Math.min(...h),max:Math.max(...h),count:h.length,unit:"ms"}}return o}},Vb=new jl,Ng=Vb;V();lt();var xs={startup:{max:500,unit:"ms"},heapMB:{max:80,unit:"MB"},contextRate:{min:100,unit:"%"},handoffRate:{min:100,unit:"%"}};function mi(r,e,t){return t==="below"?r<=e?$e.green("\u2713"):$e.yellow("\u26A0"):r>=e?$e.green("\u2713"):$e.yellow("\u26A0")}l(mi,"statusIcon");var Ln=class extends Ce{static{l(this,"PerformanceCommands")}async perf(e="7",t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let n=await I.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=parseInt(e,10)||7,i=await Ng.getReport(n,o);if(!(i.startup||i.memory||i.contextCorrectness||i.subtaskHandoff||i.commandDurations))return console.log(`
1181
- ${$e.dim("No performance data yet.")}`),console.log(`${$e.dim("Metrics are collected automatically as you use the CLI.")}
1205
+ `),{success:!0,snapshots:n.snapshots,current:n.current}}catch(e){return f.fail(w(e)),{success:!1,error:w(e)}}}l($l,"history");var Nn=class extends Ce{static{l(this,"MaintenanceCommands")}_cleanupMemory=mi;_cleanupMemoryInternal=gi;async cleanup(e={},t=process.cwd()){let s=await this.ensureProjectInit(t);return s.success?xl(e,t):s}async cleanupProjects(e={}){return Og(e)}async design(e=null,t={},s=process.cwd()){let n=await this.ensureProjectInit(s);return n.success?Rl(e,t,s):n}async recover(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Dl(e):t}async undo(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?jl(e):t}async redo(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Il(e):t}async history(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?$l(e):t}async enrich(e=null,t=process.cwd(),s={}){let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=e?.trim();if(!o)return{success:!1,error:"Missing issue ID or description",message:'Usage: prjct enrich "<issue-id-or-description>" --md'};let i=o.match(/\b[A-Z]+-\d+\b/)?.[0]||null,a=await An(o,t,{maxFiles:10,minScore:.1,includeTests:!0}),c={success:!0,mode:"mcp",issueId:i,query:o,files:a.files.map(u=>({path:u.path,score:Number(u.score.toFixed(3)),reasons:u.reasons})),publish:{linear:"Use your AI client Linear MCP tools to update description/comment.",jira:"Use your AI client Jira MCP tools to update description/comment."}};if(s.json)return console.log(JSON.stringify(c,null,2)),{success:!0};if(s.md){let u=[];if(u.push("## Enrichment Context"),u.push(""),u.push(`- Query: ${o}`),i&&u.push(`- Issue ID: ${i}`),u.push(`- Candidate files: ${c.files.length}`),u.push(""),u.push("### Suggested Files"),u.push(""),c.files.length===0)u.push("- No relevant files found.");else for(let p of c.files)u.push(`- \`${p.path}\` (${p.score})`);return u.push(""),u.push("### Publish"),u.push(""),u.push("- Update description via MCP"),u.push("- Add enrichment as comment via MCP"),u.push("- Or keep local only"),console.log(u.join(`
1206
+ `)),{success:!0}}return{success:!0,message:`Prepared enrichment context (${c.files.length} files).`}}};import Ie from"chalk";re();var Bb=BigInt(300*1e9),Ml=class{static{l(this,"PerformanceTracker")}marks=new Map;markStart(e){this.pruneStaleMarks(),this.marks.set(e,process.hrtime.bigint())}markEnd(e){let t=this.marks.get(e);if(t===void 0)return null;let s=process.hrtime.bigint();return this.marks.delete(e),Number(s-t)/1e6}pruneStaleMarks(){if(this.marks.size<10)return;let e=process.hrtime.bigint();for(let[t,s]of this.marks)e-s>Bb&&this.marks.delete(t)}recordTiming(e,t,s,n){N.appendEvent(e,`perf.${t}`,{metric:t,value:Math.round(s*100)/100,unit:"ms",context:n})}snapshotMemory(){let e=process.memoryUsage();return{heapUsed:e.heapUsed,heapTotal:e.heapTotal,rss:e.rss,external:e.external}}recordMemory(e,t){let s=this.snapshotMemory(),n=[{metric:"heap_used",value:s.heapUsed,unit:"bytes"},{metric:"heap_total",value:s.heapTotal,unit:"bytes"},{metric:"rss",value:s.rss,unit:"bytes"},{metric:"external_memory",value:s.external,unit:"bytes"}];for(let o of n)N.appendEvent(e,`perf.${o.metric}`,{metric:o.metric,value:o.value,unit:o.unit,context:t});return s}recordContextCorrectness(e,t){N.appendEvent(e,"perf.context_correctness",{metric:"context_correctness",...t})}recordSubtaskHandoff(e,t){N.appendEvent(e,"perf.subtask_handoff",{metric:"subtask_handoff",...t})}getMetrics(e,t){t||(t=new Date,t.setDate(t.getDate()-7));let s=t.toISOString();return N.query(e,"SELECT data, timestamp FROM events WHERE type LIKE ? AND timestamp >= ? ORDER BY id DESC","perf.%",s).map(o=>({...JSON.parse(o.data),timestamp:o.timestamp}))}getReport(e,t=7){let s=new Date;s.setDate(s.getDate()-t),s.setHours(0,0,0,0);let n=this.getMetrics(e,s),o={period:`${t}d`},i=n.filter(d=>"metric"in d&&d.metric==="startup_time");if(i.length>0){let d=i.map(g=>g.value);o.startup={avg:Math.round(d.reduce((g,h)=>g+h,0)/d.length),min:Math.min(...d),max:Math.max(...d),count:d.length,unit:"ms"}}let a=n.filter(d=>"metric"in d&&d.metric==="heap_used"),c=n.filter(d=>"metric"in d&&d.metric==="rss");if(a.length>0){let d=l(k=>Math.round(k/1048576*10)/10,"toMB"),g=a.map(k=>k.value),h=c.map(k=>k.value);o.memory={avgHeapMB:d(g.reduce((k,y)=>k+y,0)/g.length),peakHeapMB:d(Math.max(...g)),avgRssMB:h.length>0?d(h.reduce((k,y)=>k+y,0)/h.length):0}}let u=n.filter(d=>"metric"in d&&d.metric==="context_correctness");if(u.length>0){let d=u.filter(g=>g.receivedSync).length;o.contextCorrectness={total:u.length,receivedSync:d,rate:Math.round(d/u.length*100)}}let p=n.filter(d=>"metric"in d&&d.metric==="subtask_handoff");if(p.length>0){let d=p.filter(g=>g.outputPopulated).length;o.subtaskHandoff={total:p.length,outputPopulated:d,rate:Math.round(d/p.length*100)}}let m=n.filter(d=>"metric"in d&&d.metric==="command_duration");if(m.length>0){let d={};for(let g of m){let h=g.context?.command||"unknown";d[h]||(d[h]=[]),d[h].push(g.value)}o.commandDurations={};for(let[g,h]of Object.entries(d))o.commandDurations[g]={avg:Math.round(h.reduce((k,y)=>k+y,0)/h.length),min:Math.min(...h),max:Math.max(...h),count:h.length,unit:"ms"}}return o}},zb=new Ml,Hg=zb;W();dt();var xs={startup:{max:500,unit:"ms"},heapMB:{max:80,unit:"MB"},contextRate:{min:100,unit:"%"},handoffRate:{min:100,unit:"%"}};function yi(r,e,t){return t==="below"?r<=e?Ie.green("\u2713"):Ie.yellow("\u26A0"):r>=e?Ie.green("\u2713"):Ie.yellow("\u26A0")}l(yi,"statusIcon");var Ln=class extends Ce{static{l(this,"PerformanceCommands")}async perf(e="7",t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let n=await $.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=parseInt(e,10)||7,i=await Hg.getReport(n,o);if(!(i.startup||i.memory||i.contextCorrectness||i.subtaskHandoff||i.commandDurations))return console.log(`
1207
+ ${Ie.dim("No performance data yet.")}`),console.log(`${Ie.dim("Metrics are collected automatically as you use the CLI.")}
1182
1208
  `),{success:!0,message:"No data"};if(console.log(`
1183
- ${$e.cyan("Performance Report")} ${$e.dim(`(last ${o} days)`)}`),console.log("\u2550".repeat(55)),i.startup){let c=mi(i.startup.avg,xs.startup.max,"below");console.log(` Startup: avg ${$e.bold(`${i.startup.avg}ms`)} ${$e.dim(`(min ${i.startup.min}, max ${i.startup.max}, n=${i.startup.count})`)} ${c} ${$e.dim(`target: <${xs.startup.max}ms`)}`)}if(i.memory){let c=mi(i.memory.peakHeapMB,xs.heapMB.max,"below");console.log(` Memory: avg ${$e.bold(`${i.memory.avgHeapMB}MB`)} heap, peak ${i.memory.peakHeapMB}MB, rss ${i.memory.avgRssMB}MB ${c} ${$e.dim(`target: <${xs.heapMB.max}MB`)}`)}if(i.contextCorrectness){let c=mi(i.contextCorrectness.rate,xs.contextRate.min,"above");console.log(` Context: ${$e.bold(`${i.contextCorrectness.rate}%`)} tasks received sync ${$e.dim(`(${i.contextCorrectness.receivedSync}/${i.contextCorrectness.total})`)} ${c} ${$e.dim(`target: ${xs.contextRate.min}%`)}`)}if(i.subtaskHandoff){let c=mi(i.subtaskHandoff.rate,xs.handoffRate.min,"above");console.log(` Handoff: ${$e.bold(`${i.subtaskHandoff.rate}%`)} subtasks with output ${$e.dim(`(${i.subtaskHandoff.outputPopulated}/${i.subtaskHandoff.total})`)} ${c} ${$e.dim(`target: ${xs.handoffRate.min}%`)}`)}if(i.commandDurations&&Object.keys(i.commandDurations).length>0){console.log(`
1184
- ${$e.dim("Command Durations:")}`);for(let[c,u]of Object.entries(i.commandDurations))console.log(` ${c.padEnd(12)} avg ${$e.bold(`${u.avg}ms`)} ${$e.dim(`(min ${u.min}, max ${u.max}, n=${u.count})`)}`)}return console.log("\u2550".repeat(55)),console.log(""),{success:!0}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}};ai();os();Et();ve();br();import tv from"node:fs/promises";import sv from"node:http";import nv from"node:path";import te from"chalk";ve();q();import Wb from"node:path";var Fg="https://api.prjct.app",Lg={apiKey:null,apiUrl:Fg,userId:null,email:null,lastAuth:null},Il=class{static{l(this,"AuthConfigManager")}configPath;cachedConfig=null;constructor(){this.configPath=A.getAuthConfigPath()}getConfigPath(){return this.configPath}async read(){if(this.cachedConfig)return this.cachedConfig;let e=await xe(this.configPath);return this.cachedConfig=e??{...Lg},this.cachedConfig}async write(e){let s={...await this.read(),...e,lastAuth:new Date().toISOString()};await vt(Wb.dirname(this.configPath)),await le(this.configPath,s),this.cachedConfig=s}async hasAuth(){let e=await this.read();return e.apiKey!==null&&e.apiKey.length>0}async getApiKey(){return(await this.read()).apiKey}async getApiUrl(){return(await this.read()).apiUrl||Fg}async saveAuth(e,t,s){await this.write({apiKey:e,userId:t,email:s})}async clearAuth(){this.cachedConfig={...Lg},await le(this.configPath,this.cachedConfig)}async getStatus(){let e=await this.read();return{authenticated:e.apiKey!==null,email:e.email,apiKeyPrefix:e.apiKey?`${e.apiKey.substring(0,12)}...`:null,lastAuth:e.lastAuth}}clearCache(){this.cachedConfig=null}},Bb=new Il,gt=Bb;Ws();var Jb={task:"tasks",idea:"ideas",feature:"roadmap_features",shipped:"shipped_items",queue:"queue_tasks",project:"projects",session:"sessions",agent:"agents"};function zb(r){return r.replace(/[A-Z]/g,e=>`_${e.toLowerCase()}`)}l(zb,"camelToSnake");function qb(r){let e={};for(let[t,s]of Object.entries(r))e[zb(t)]=s;return e}l(qb,"snakeCaseKeys");function Kb(r,e){let[t,s]=e.type.split("."),n=Jb[t];if(!n)return null;let i=s==="deleted"?"delete":"upsert",a=e.data||{},c=qb(a),u=c.id||a.id||"";return{event_type:i,entity_type:n,entity_id:u,data:{...c,project_id:r},project_id:r}}l(Kb,"mapCliEventToWebFormat");function Ug(r,e){return e.map(t=>Kb(r,t)).filter(t=>t!==null)}l(Ug,"mapCliEventsToWebFormat");var $l=class{static{l(this,"SyncClient")}retryConfig={maxRetries:3,baseDelayMs:1e3,maxDelayMs:3e4};async pushEvents(e,t){let{apiUrl:s,apiKey:n}=await this.getAuthHeaders();if(!n)throw this.createError("AUTH_REQUIRED","No API key configured");let o=Ug(e,t),i=await this.fetchWithRetry(`${s}/sync/batch`,{method:"POST",headers:{"Content-Type":"application/json","X-Api-Key":n},body:JSON.stringify({projectId:e,events:o})});if(!i.ok)throw await this.parseErrorResponse(i);return await i.json()}async pullEvents(e,t){let{apiUrl:s,apiKey:n}=await this.getAuthHeaders();if(!n)throw this.createError("AUTH_REQUIRED","No API key configured");let o=await this.fetchWithRetry(`${s}/sync/pull`,{method:"POST",headers:{"Content-Type":"application/json","X-Api-Key":n},body:JSON.stringify({projectId:e,since:t})});if(!o.ok)throw await this.parseErrorResponse(o);return await o.json()}async getStatus(e){let{apiUrl:t,apiKey:s}=await this.getAuthHeaders();if(!s)throw this.createError("AUTH_REQUIRED","No API key configured");let n=await this.fetchWithRetry(`${t}/sync/status/${e}`,{method:"GET",headers:{"X-Api-Key":s}});if(!n.ok)throw await this.parseErrorResponse(n);return await n.json()}async testConnection(){let e=new AbortController,t=setTimeout(()=>e.abort(),Tn("API_REQUEST"));try{let{apiUrl:s,apiKey:n}=await this.getAuthHeaders();if(!n)return clearTimeout(t),!1;let o=await fetch(`${s}/health`,{method:"GET",headers:{"X-Api-Key":n},signal:e.signal});return clearTimeout(t),o.ok}catch{return clearTimeout(t),!1}}async hasAuth(){return await gt.hasAuth()}async getAuthHeaders(){let[e,t]=await Promise.all([gt.getApiUrl(),gt.getApiKey()]);return{apiUrl:e,apiKey:t}}async fetchWithRetry(e,t,s=0){let n=new AbortController,o=setTimeout(()=>n.abort(),Tn("API_REQUEST"));try{let i=await fetch(e,{...t,signal:n.signal});if(clearTimeout(o),i.status>=500&&s<this.retryConfig.maxRetries){let a=Math.min(this.retryConfig.baseDelayMs*2**s,this.retryConfig.maxDelayMs);return await this.sleep(a),this.fetchWithRetry(e,t,s+1)}return i}catch(i){if(clearTimeout(o),i instanceof Error&&i.name==="AbortError")throw this.createError("NETWORK_ERROR",`Request timed out. Try increasing PRJCT_TIMEOUT_API_REQUEST (current: ${Tn("API_REQUEST")}ms)`);if(s<this.retryConfig.maxRetries){let a=Math.min(this.retryConfig.baseDelayMs*2**s,this.retryConfig.maxDelayMs);return await this.sleep(a),this.fetchWithRetry(e,t,s+1)}throw this.createError("NETWORK_ERROR",i instanceof Error?i.message:"Network request failed")}}async parseErrorResponse(e){try{let t=await e.json(),s=t.message||t.error||`HTTP ${e.status}`;return e.status===401||e.status===403?this.createError("AUTH_REQUIRED",s,e.status):this.createError("API_ERROR",s,e.status)}catch{return this.createError("API_ERROR",`HTTP ${e.status}`,e.status)}}createError(e,t,s){return{code:e,message:t,status:s}}sleep(e){return new Promise(t=>setTimeout(t,e))}},Fn=new $l;ma();ks();Xt();Js();Pt();var Ml=class{static{l(this,"SyncManager")}async hasAuth(){return await gt.hasAuth()}async getStatus(e){if(!await this.hasAuth())return null;try{return await Fn.getStatus(e)}catch{return null}}async sync(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};let t={success:!0,skipped:!1},s=await this.push(e);s.success&&!s.skipped&&(t.pushed={count:s.count||0,syncedAt:s.syncedAt||new Date().toISOString()});let n=await this.pull(e);return n.success&&!n.skipped&&(t.pulled={count:n.count||0,syncedAt:n.syncedAt||new Date().toISOString()}),(!s.success||!n.success)&&(t.success=!1,t.error=s.error||n.error),t}async push(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};try{let t=await ws.getPending(e);if(t.length===0)return{success:!0,skipped:!0,reason:"no_pending"};let s=await this.createProjectLinkEvent(e),n=s?[s,...t]:t,o=await Fn.pushEvents(e,n);if(o.success)return await ws.clearPending(e),await ws.updateLastSync(e),{success:!0,skipped:!1,count:o.processed,syncedAt:o.syncedAt};{let i=o.processed,a=o.errors.length,c=o.errors.map(u=>u.error).join(", ");return{success:!1,skipped:!1,count:i,syncedAt:o.syncedAt,error:`${a} events failed: ${c}`}}}catch(t){return{success:!1,skipped:!1,reason:"error",error:t instanceof Error?t.message:"Unknown error"}}}async pull(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};try{let s=(await ws.getLastSync(e))?.timestamp,n=await Fn.pullEvents(e,s);if(n.events.length===0)return{success:!0,skipped:!1,count:0,applied:0,syncedAt:n.syncedAt};let o=await this.applyPulledEvents(e,n.events);return await ws.updateLastSync(e),{success:!0,skipped:!1,count:n.events.length,applied:o,syncedAt:n.syncedAt}}catch(t){return{success:!1,skipped:!1,reason:"error",error:t instanceof Error?t.message:"Unknown error"}}}async applyPulledEvents(e,t){let s=0;for(let n of t)try{await this.applyEvent(e,n),s++}catch(o){let i=n.entity_type||n.type||"unknown";console.error(`Failed to apply event ${i}:`,o)}return s}async applyEvent(e,t){let s,n,o;if(t.entity_type)s=t.entity_type,n=t.event_type,o=t.data||{};else{let[i,a]=(t.type||"").split(".");s={task:"tasks",idea:"ideas",feature:"roadmap_features",shipped:"shipped_items",queue:"queue_tasks",project:"projects"}[i]||i,n=a==="deleted"?"delete":"upsert",o=t.data||{}}if(n!=="delete")switch(s){case"tasks":await this.applyTaskUpsert(e,o);break;case"ideas":await this.applyIdeaUpsert(e,o);break;case"shipped_items":await this.applyShippedUpsert(e,o);break;case"queue_tasks":await this.applyQueueUpsert(e,o);break;case"roadmap_features":break;case"projects":break}}async applyTaskUpsert(e,t){let s=t.status||"";s==="active"||t.started_at||t.startedAt?await _.update(e,n=>!n.currentTask||t.id!==n.currentTask.id?{...n,currentTask:{id:t.id,description:t.description,startedAt:t.started_at||t.startedAt,sessionId:t.session_id||t.sessionId||""}}:n):s==="completed"?await _.update(e,n=>n.currentTask?.id===t.id?{...n,currentTask:null}:n):await be.addTask(e,{description:t.description,priority:t.priority||"medium",type:t.type||"feature",section:"backlog"})}async applyIdeaUpsert(e,t){(t.status||"active")==="archived"?await He.update(e,n=>({...n,ideas:n.ideas.map(o=>o.id===t.id?{...o,status:"archived"}:o)})):await He.addIdea(e,t.title||t.text||"",{priority:t.priority||"medium"})}async applyShippedUpsert(e,t){await et.addShipped(e,{name:t.name||t.title||"",version:t.version||"",description:t.description||""})}async applyQueueUpsert(e,t){await be.addTask(e,{description:t.description||"",priority:t.priority||"medium",type:t.type||"feature",section:t.section||"backlog"})}async createProjectLinkEvent(e){try{return{type:"project.updated",path:["project"],data:{id:e,cli_project_id:e},timestamp:new Date().toISOString(),projectId:e}}catch{return null}}},Xb=new Ml,Hg=Xb;V();Ue();q();import Zb from"node:fs/promises";import Vg from"node:os";import Wg from"node:path";ar();import Gg from"node:fs";import gi from"node:path";function Yb(r){if(_s()){let{Database:n}=St("bun:sqlite");return new n(r,{create:!0})}let e=St("better-sqlite3"),t=new e(r),s=t.exec.bind(t);return t.run=n=>s(n),t}l(Yb,"openDatabase");var Ol=class{static{l(this,"SystemDatabase")}db=null;dbPath;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim(),t=e?gi.resolve(e):gi.join(St("node:os").homedir(),".prjct-cli");this.dbPath=gi.join(t,"system.db")}getDb(){if(this.db)return this.db;let e=gi.dirname(this.dbPath);Gg.existsSync(e)||Gg.mkdirSync(e,{recursive:!0});let t=Yb(this.dbPath);return t.run("PRAGMA journal_mode = WAL"),t.run("PRAGMA synchronous = NORMAL"),t.run("PRAGMA cache_size = -1000"),t.run("PRAGMA temp_store = MEMORY"),this.runMigrations(t),this.db=t,t}runMigrations(e){e.run(`
1209
+ ${Ie.cyan("Performance Report")} ${Ie.dim(`(last ${o} days)`)}`),console.log("\u2550".repeat(55)),i.startup){let c=yi(i.startup.avg,xs.startup.max,"below");console.log(` Startup: avg ${Ie.bold(`${i.startup.avg}ms`)} ${Ie.dim(`(min ${i.startup.min}, max ${i.startup.max}, n=${i.startup.count})`)} ${c} ${Ie.dim(`target: <${xs.startup.max}ms`)}`)}if(i.memory){let c=yi(i.memory.peakHeapMB,xs.heapMB.max,"below");console.log(` Memory: avg ${Ie.bold(`${i.memory.avgHeapMB}MB`)} heap, peak ${i.memory.peakHeapMB}MB, rss ${i.memory.avgRssMB}MB ${c} ${Ie.dim(`target: <${xs.heapMB.max}MB`)}`)}if(i.contextCorrectness){let c=yi(i.contextCorrectness.rate,xs.contextRate.min,"above");console.log(` Context: ${Ie.bold(`${i.contextCorrectness.rate}%`)} tasks received sync ${Ie.dim(`(${i.contextCorrectness.receivedSync}/${i.contextCorrectness.total})`)} ${c} ${Ie.dim(`target: ${xs.contextRate.min}%`)}`)}if(i.subtaskHandoff){let c=yi(i.subtaskHandoff.rate,xs.handoffRate.min,"above");console.log(` Handoff: ${Ie.bold(`${i.subtaskHandoff.rate}%`)} subtasks with output ${Ie.dim(`(${i.subtaskHandoff.outputPopulated}/${i.subtaskHandoff.total})`)} ${c} ${Ie.dim(`target: ${xs.handoffRate.min}%`)}`)}if(i.commandDurations&&Object.keys(i.commandDurations).length>0){console.log(`
1210
+ ${Ie.dim("Command Durations:")}`);for(let[c,u]of Object.entries(i.commandDurations))console.log(` ${c.padEnd(12)} avg ${Ie.bold(`${u.avg}ms`)} ${Ie.dim(`(min ${u.min}, max ${u.max}, n=${u.count})`)}`)}return console.log("\u2550".repeat(55)),console.log(""),{success:!0}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}};di();os();Et();Te();br();import rT from"node:fs/promises";import oT from"node:http";import iT from"node:path";import ne from"chalk";Te();K();import Jb from"node:path";var Wg="https://api.prjct.app",Gg={apiKey:null,apiUrl:Wg,userId:null,email:null,lastAuth:null},_l=class{static{l(this,"AuthConfigManager")}configPath;cachedConfig=null;constructor(){this.configPath=A.getAuthConfigPath()}getConfigPath(){return this.configPath}async read(){if(this.cachedConfig)return this.cachedConfig;let e=await xe(this.configPath);return this.cachedConfig=e??{...Gg},this.cachedConfig}async write(e){let s={...await this.read(),...e,lastAuth:new Date().toISOString()};await Tt(Jb.dirname(this.configPath)),await le(this.configPath,s),this.cachedConfig=s}async hasAuth(){let e=await this.read();return e.apiKey!==null&&e.apiKey.length>0}async getApiKey(){return(await this.read()).apiKey}async getApiUrl(){return(await this.read()).apiUrl||Wg}async saveAuth(e,t,s){await this.write({apiKey:e,userId:t,email:s})}async clearAuth(){this.cachedConfig={...Gg},await le(this.configPath,this.cachedConfig)}async getStatus(){let e=await this.read();return{authenticated:e.apiKey!==null,email:e.email,apiKeyPrefix:e.apiKey?`${e.apiKey.substring(0,12)}...`:null,lastAuth:e.lastAuth}}clearCache(){this.cachedConfig=null}},qb=new _l,ft=qb;Vs();var Kb={task:"tasks",idea:"ideas",feature:"roadmap_features",shipped:"shipped_items",queue:"queue_tasks",project:"projects",session:"sessions",agent:"agents"};function Xb(r){return r.replace(/[A-Z]/g,e=>`_${e.toLowerCase()}`)}l(Xb,"camelToSnake");function Yb(r){let e={};for(let[t,s]of Object.entries(r))e[Xb(t)]=s;return e}l(Yb,"snakeCaseKeys");function Qb(r,e){let[t,s]=e.type.split("."),n=Kb[t];if(!n)return null;let i=s==="deleted"?"delete":"upsert",a=e.data||{},c=Yb(a),u=c.id||a.id||"";return{event_type:i,entity_type:n,entity_id:u,data:{...c,project_id:r},project_id:r}}l(Qb,"mapCliEventToWebFormat");function Vg(r,e){return e.map(t=>Qb(r,t)).filter(t=>t!==null)}l(Vg,"mapCliEventsToWebFormat");var Ol=class{static{l(this,"SyncClient")}retryConfig={maxRetries:3,baseDelayMs:1e3,maxDelayMs:3e4};async pushEvents(e,t){let{apiUrl:s,apiKey:n}=await this.getAuthHeaders();if(!n)throw this.createError("AUTH_REQUIRED","No API key configured");let o=Vg(e,t),i=await this.fetchWithRetry(`${s}/sync/batch`,{method:"POST",headers:{"Content-Type":"application/json","X-Api-Key":n},body:JSON.stringify({projectId:e,events:o})});if(!i.ok)throw await this.parseErrorResponse(i);return await i.json()}async pullEvents(e,t){let{apiUrl:s,apiKey:n}=await this.getAuthHeaders();if(!n)throw this.createError("AUTH_REQUIRED","No API key configured");let o=await this.fetchWithRetry(`${s}/sync/pull`,{method:"POST",headers:{"Content-Type":"application/json","X-Api-Key":n},body:JSON.stringify({projectId:e,since:t})});if(!o.ok)throw await this.parseErrorResponse(o);return await o.json()}async getStatus(e){let{apiUrl:t,apiKey:s}=await this.getAuthHeaders();if(!s)throw this.createError("AUTH_REQUIRED","No API key configured");let n=await this.fetchWithRetry(`${t}/sync/status/${e}`,{method:"GET",headers:{"X-Api-Key":s}});if(!n.ok)throw await this.parseErrorResponse(n);return await n.json()}async testConnection(){let e=new AbortController,t=setTimeout(()=>e.abort(),Cn("API_REQUEST"));try{let{apiUrl:s,apiKey:n}=await this.getAuthHeaders();if(!n)return clearTimeout(t),!1;let o=await fetch(`${s}/health`,{method:"GET",headers:{"X-Api-Key":n},signal:e.signal});return clearTimeout(t),o.ok}catch{return clearTimeout(t),!1}}async hasAuth(){return await ft.hasAuth()}async getAuthHeaders(){let[e,t]=await Promise.all([ft.getApiUrl(),ft.getApiKey()]);return{apiUrl:e,apiKey:t}}async fetchWithRetry(e,t,s=0){let n=new AbortController,o=setTimeout(()=>n.abort(),Cn("API_REQUEST"));try{let i=await fetch(e,{...t,signal:n.signal});if(clearTimeout(o),i.status>=500&&s<this.retryConfig.maxRetries){let a=Math.min(this.retryConfig.baseDelayMs*2**s,this.retryConfig.maxDelayMs);return await this.sleep(a),this.fetchWithRetry(e,t,s+1)}return i}catch(i){if(clearTimeout(o),i instanceof Error&&i.name==="AbortError")throw this.createError("NETWORK_ERROR",`Request timed out. Try increasing PRJCT_TIMEOUT_API_REQUEST (current: ${Cn("API_REQUEST")}ms)`);if(s<this.retryConfig.maxRetries){let a=Math.min(this.retryConfig.baseDelayMs*2**s,this.retryConfig.maxDelayMs);return await this.sleep(a),this.fetchWithRetry(e,t,s+1)}throw this.createError("NETWORK_ERROR",i instanceof Error?i.message:"Network request failed")}}async parseErrorResponse(e){try{let t=await e.json(),s=t.message||t.error||`HTTP ${e.status}`;return e.status===401||e.status===403?this.createError("AUTH_REQUIRED",s,e.status):this.createError("API_ERROR",s,e.status)}catch{return this.createError("API_ERROR",`HTTP ${e.status}`,e.status)}}createError(e,t,s){return{code:e,message:t,status:s}}sleep(e){return new Promise(t=>setTimeout(t,e))}},Fn=new Ol;fa();ks();Xt();zs();Pt();var Nl=class{static{l(this,"SyncManager")}async hasAuth(){return await ft.hasAuth()}async getStatus(e){if(!await this.hasAuth())return null;try{return await Fn.getStatus(e)}catch{return null}}async sync(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};let t={success:!0,skipped:!1},s=await this.push(e);s.success&&!s.skipped&&(t.pushed={count:s.count||0,syncedAt:s.syncedAt||new Date().toISOString()});let n=await this.pull(e);return n.success&&!n.skipped&&(t.pulled={count:n.count||0,syncedAt:n.syncedAt||new Date().toISOString()}),(!s.success||!n.success)&&(t.success=!1,t.error=s.error||n.error),t}async push(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};try{let t=await ws.getPending(e);if(t.length===0)return{success:!0,skipped:!0,reason:"no_pending"};let s=await this.createProjectLinkEvent(e),n=s?[s,...t]:t,o=await Fn.pushEvents(e,n);if(o.success)return await ws.clearPending(e),await ws.updateLastSync(e),{success:!0,skipped:!1,count:o.processed,syncedAt:o.syncedAt};{let i=o.processed,a=o.errors.length,c=o.errors.map(u=>u.error).join(", ");return{success:!1,skipped:!1,count:i,syncedAt:o.syncedAt,error:`${a} events failed: ${c}`}}}catch(t){return{success:!1,skipped:!1,reason:"error",error:t instanceof Error?t.message:"Unknown error"}}}async pull(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};try{let s=(await ws.getLastSync(e))?.timestamp,n=await Fn.pullEvents(e,s);if(n.events.length===0)return{success:!0,skipped:!1,count:0,applied:0,syncedAt:n.syncedAt};let o=await this.applyPulledEvents(e,n.events);return await ws.updateLastSync(e),{success:!0,skipped:!1,count:n.events.length,applied:o,syncedAt:n.syncedAt}}catch(t){return{success:!1,skipped:!1,reason:"error",error:t instanceof Error?t.message:"Unknown error"}}}async applyPulledEvents(e,t){let s=0;for(let n of t)try{await this.applyEvent(e,n),s++}catch(o){let i=n.entity_type||n.type||"unknown";console.error(`Failed to apply event ${i}:`,o)}return s}async applyEvent(e,t){let s,n,o;if(t.entity_type)s=t.entity_type,n=t.event_type,o=t.data||{};else{let[i,a]=(t.type||"").split(".");s={task:"tasks",idea:"ideas",feature:"roadmap_features",shipped:"shipped_items",queue:"queue_tasks",project:"projects"}[i]||i,n=a==="deleted"?"delete":"upsert",o=t.data||{}}if(n!=="delete")switch(s){case"tasks":await this.applyTaskUpsert(e,o);break;case"ideas":await this.applyIdeaUpsert(e,o);break;case"shipped_items":await this.applyShippedUpsert(e,o);break;case"queue_tasks":await this.applyQueueUpsert(e,o);break;case"roadmap_features":break;case"projects":break}}async applyTaskUpsert(e,t){let s=t.status||"";s==="active"||t.started_at||t.startedAt?await _.update(e,n=>!n.currentTask||t.id!==n.currentTask.id?{...n,currentTask:{id:t.id,description:t.description,startedAt:t.started_at||t.startedAt,sessionId:t.session_id||t.sessionId||""}}:n):s==="completed"?await _.update(e,n=>n.currentTask?.id===t.id?{...n,currentTask:null}:n):await be.addTask(e,{description:t.description,priority:t.priority||"medium",type:t.type||"feature",section:"backlog"})}async applyIdeaUpsert(e,t){(t.status||"active")==="archived"?await Ge.update(e,n=>({...n,ideas:n.ideas.map(o=>o.id===t.id?{...o,status:"archived"}:o)})):await Ge.addIdea(e,t.title||t.text||"",{priority:t.priority||"medium"})}async applyShippedUpsert(e,t){await tt.addShipped(e,{name:t.name||t.title||"",version:t.version||"",description:t.description||""})}async applyQueueUpsert(e,t){await be.addTask(e,{description:t.description||"",priority:t.priority||"medium",type:t.type||"feature",section:t.section||"backlog"})}async createProjectLinkEvent(e){try{return{type:"project.updated",path:["project"],data:{id:e,cli_project_id:e},timestamp:new Date().toISOString(),projectId:e}}catch{return null}}},Zb=new Nl,Bg=Zb;W();He();K();import sT from"node:fs/promises";import Jg from"node:os";import qg from"node:path";ar();import zg from"node:fs";import wi from"node:path";function eT(r){if(Os()){let{Database:n}=bt("bun:sqlite");return new n(r,{create:!0})}let e=bt("better-sqlite3"),t=new e(r),s=t.exec.bind(t);return t.run=n=>s(n),t}l(eT,"openDatabase");var Ll=class{static{l(this,"SystemDatabase")}db=null;dbPath;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim(),t=e?wi.resolve(e):wi.join(bt("node:os").homedir(),".prjct-cli");this.dbPath=wi.join(t,"system.db")}getDb(){if(this.db)return this.db;let e=wi.dirname(this.dbPath);zg.existsSync(e)||zg.mkdirSync(e,{recursive:!0});let t=eT(this.dbPath);return t.run("PRAGMA journal_mode = WAL"),t.run("PRAGMA synchronous = NORMAL"),t.run("PRAGMA cache_size = -1000"),t.run("PRAGMA temp_store = MEMORY"),this.runMigrations(t),this.db=t,t}runMigrations(e){e.run(`
1185
1211
  CREATE TABLE IF NOT EXISTS _system_migrations (
1186
1212
  version INTEGER PRIMARY KEY,
1187
1213
  name TEXT NOT NULL,
@@ -1202,30 +1228,30 @@ ${$e.cyan("Performance Report")} ${$e.dim(`(last ${o} days)`)}`),console.log("\u
1202
1228
  INSERT OR REPLACE INTO mcp_health
1203
1229
  (provider, status, last_checked, last_error, token_version, config_valid, oauth_valid, updated_at)
1204
1230
  VALUES (?, ?, ?, ?, ?, ?, ?, ?)
1205
- `).run(e,t.status,n,t.lastError??null,t.tokenVersion??null,t.configValid?1:0,t.oauthValid?1:0,n)}clearMcpHealth(e){this.getDb().prepare("DELETE FROM mcp_health WHERE provider = ?").run(e)}close(){this.db&&(this.db.close(),this.db=null)}},Qb=new Ol;V();q();var fi="mcp-remote@0.1.38",_l={linear:{command:"npx",args:["-y",fi,"https://mcp.linear.app/mcp"],description:"Linear MCP server (OAuth)"},jira:{command:"npx",args:["-y",fi,"https://mcp.atlassian.com/v1/mcp"],description:"Atlassian MCP server for Jira (OAuth)"}},HL={linear:`npx -y ${fi} https://mcp.linear.app/mcp`,jira:`npx -y ${fi} https://mcp.atlassian.com/v1/mcp`};function ds(){return process.env.PRJCT_TEST_MODE==="1"?Wg.join(Vg.tmpdir(),"prjct-context7-test","mcp.json"):Wg.join(Vg.homedir(),".claude","mcp.json")}l(ds,"getClaudeMcpConfigPath");async function Bg(r=ds()){try{let e=await Zb.readFile(r,"utf-8");return JSON.parse(e)}catch(e){let t=y(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${r}: ${y(e)}`)}}l(Bg,"readMcpConfig");async function ev(r,e=ds()){await le(e,r)}l(ev,"writeMcpConfig");async function Nl(r,e,t=ds()){let s=await Bg(t),n={...s.mcpServers||{}},o=n[r];n[r]=e,s.mcpServers=n;let i=JSON.stringify(o)!==JSON.stringify(e);return await ev(s,t),{path:t,changed:i}}l(Nl,"upsertMcpServer");async function _r(r,e=ds()){return!!(await Bg(e)).mcpServers?.[r]}l(_r,"hasMcpServer");Ts();Ct();lt();var Un=class extends Ce{static{l(this,"SetupCommands")}async auth(e=null,t={}){let s=e?.split(" ")[0]||"status",n=e?.split(" ").slice(1)||[];switch(s){case"login":{let o=n[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=n.indexOf("--url");return a!==-1&&n[a+1]&&(i=n[a+1]),await gt.write({apiKey:o,...i?{apiUrl:i}:{}}),await Fn.testConnection()?(t.md||(f.done("Connected! API key saved"),f.info(te.dim(`Key: ${o.substring(0,12)}...`))),{success:!0,message:t.md?`## Auth
1231
+ `).run(e,t.status,n,t.lastError??null,t.tokenVersion??null,t.configValid?1:0,t.oauthValid?1:0,n)}clearMcpHealth(e){this.getDb().prepare("DELETE FROM mcp_health WHERE provider = ?").run(e)}close(){this.db&&(this.db.close(),this.db=null)}},tT=new Ll;W();K();var ki="mcp-remote@0.1.38",Fl={linear:{command:"npx",args:["-y",ki,"https://mcp.linear.app/mcp"],description:"Linear MCP server (OAuth)"},jira:{command:"npx",args:["-y",ki,"https://mcp.atlassian.com/v1/mcp"],description:"Atlassian MCP server for Jira (OAuth)"}},KL={linear:`npx -y ${ki} https://mcp.linear.app/mcp`,jira:`npx -y ${ki} https://mcp.atlassian.com/v1/mcp`};function ds(){return process.env.PRJCT_TEST_MODE==="1"?qg.join(Jg.tmpdir(),"prjct-context7-test","mcp.json"):qg.join(Jg.homedir(),".claude","mcp.json")}l(ds,"getClaudeMcpConfigPath");async function Kg(r=ds()){try{let e=await sT.readFile(r,"utf-8");return JSON.parse(e)}catch(e){let t=w(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${r}: ${w(e)}`)}}l(Kg,"readMcpConfig");async function nT(r,e=ds()){await le(e,r)}l(nT,"writeMcpConfig");async function Ul(r,e,t=ds()){let s=await Kg(t),n={...s.mcpServers||{}},o=n[r];n[r]=e,s.mcpServers=n;let i=JSON.stringify(o)!==JSON.stringify(e);return await nT(s,t),{path:t,changed:i}}l(Ul,"upsertMcpServer");async function Lr(r,e=ds()){return!!(await Kg(e)).mcpServers?.[r]}l(Lr,"hasMcpServer");vs();Ct();dt();var Un=class extends Ce{static{l(this,"SetupCommands")}async auth(e=null,t={}){let s=e?.split(" ")[0]||"status",n=e?.split(" ").slice(1)||[];switch(s){case"login":{let o=n[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=n.indexOf("--url");return a!==-1&&n[a+1]&&(i=n[a+1]),await ft.write({apiKey:o,...i?{apiUrl:i}:{}}),await Fn.testConnection()?(t.md||(f.done("Connected! API key saved"),f.info(ne.dim(`Key: ${o.substring(0,12)}...`))),{success:!0,message:t.md?`## Auth
1206
1232
  - **Status**: Connected
1207
1233
  - **Key**: \`${o.substring(0,12)}...\`
1208
- - **API**: ${i||"default"}`:""}):(t.md||(f.warn("API key saved, but server is unreachable"),f.info(te.dim(`Key: ${o.substring(0,12)}...`)),f.info(te.dim("The key will be used when the server becomes available"))),{success:!0,message:t.md?`## Auth
1234
+ - **API**: ${i||"default"}`:""}):(t.md||(f.warn("API key saved, but server is unreachable"),f.info(ne.dim(`Key: ${o.substring(0,12)}...`)),f.info(ne.dim("The key will be used when the server becomes available"))),{success:!0,message:t.md?`## Auth
1209
1235
  - **Status**: Key saved (server unreachable)
1210
- - **Key**: \`${o.substring(0,12)}...\``:""})}case"logout":return await gt.clearAuth(),t.md||f.done("Logged out. Auth credentials cleared"),{success:!0,message:t.md?`## Auth
1211
- - **Status**: Logged out`:""};default:{let o=await gt.getStatus();return t.md?{success:!0,message:o.authenticated?`## Auth Status
1236
+ - **Key**: \`${o.substring(0,12)}...\``:""})}case"logout":return await ft.clearAuth(),t.md||f.done("Logged out. Auth credentials cleared"),{success:!0,message:t.md?`## Auth
1237
+ - **Status**: Logged out`:""};default:{let o=await ft.getStatus();return t.md?{success:!0,message:o.authenticated?`## Auth Status
1212
1238
  - **Authenticated**: Yes
1213
1239
  - **Email**: ${o.email||"N/A"}
1214
1240
  - **Key**: \`${o.apiKeyPrefix}\`
1215
1241
  - **Last auth**: ${o.lastAuth||"N/A"}`:"## Auth Status\n- **Authenticated**: No\n- Run `prjct login` to connect"}:(o.authenticated?f.box("Auth Status",`Email: ${o.email||"N/A"}
1216
1242
  Key: ${o.apiKeyPrefix}
1217
- Since: ${o.lastAuth||"N/A"}`):(f.info("Not authenticated"),f.info(`Run ${te.cyan("prjct login")} to connect`)),{success:!0,message:""})}}}async login(e={}){let t=await gt.getStatus();if(t.authenticated)return e.md||(f.box("Already Authenticated",`Email: ${t.email}
1218
- Key: ${t.apiKeyPrefix}`),f.info(`Run ${te.cyan("prjct logout")} first to re-authenticate`)),{success:!0,message:e.md?`## Already Authenticated
1243
+ Since: ${o.lastAuth||"N/A"}`):(f.info("Not authenticated"),f.info(`Run ${ne.cyan("prjct login")} to connect`)),{success:!0,message:""})}}}async login(e={}){let t=await ft.getStatus();if(t.authenticated)return e.md||(f.box("Already Authenticated",`Email: ${t.email}
1244
+ Key: ${t.apiKeyPrefix}`),f.info(`Run ${ne.cyan("prjct logout")} first to re-authenticate`)),{success:!0,message:e.md?`## Already Authenticated
1219
1245
  - **Email**: ${t.email}
1220
1246
  - **Key**: \`${t.apiKeyPrefix}\`
1221
1247
 
1222
- Run \`prjct logout\` first to re-authenticate.`:""};let s=e.url||process.env.PRJCT_WEB_URL||"http://localhost:3000";return new Promise(n=>{let o=sv.createServer(async(i,a)=>{let c=new URL(i.url||"/","http://127.0.0.1");if(c.pathname==="/callback"){let u=c.searchParams.get("key"),p=c.searchParams.get("email"),m=c.searchParams.get("user_id");if(u){await gt.saveAuth(u,m||"",p||"");let d=`${s}/api`;await gt.write({apiUrl:d}),a.writeHead(200,{"Content-Type":"text/html"}),a.end(this.buildSuccessPage(p||"",u.substring(0,12)))}else a.writeHead(400,{"Content-Type":"text/html"}),a.end(this.buildErrorPage("No API key received"));o.close(),u?(e.md||(f.step(3,3,"Connected"),f.stop(),f.box("Authentication Complete",`Email: ${p}
1248
+ Run \`prjct logout\` first to re-authenticate.`:""};let s=e.url||process.env.PRJCT_WEB_URL||"http://localhost:3000";return new Promise(n=>{let o=oT.createServer(async(i,a)=>{let c=new URL(i.url||"/","http://127.0.0.1");if(c.pathname==="/callback"){let u=c.searchParams.get("key"),p=c.searchParams.get("email"),m=c.searchParams.get("user_id");if(u){await ft.saveAuth(u,m||"",p||"");let d=`${s}/api`;await ft.write({apiUrl:d}),a.writeHead(200,{"Content-Type":"text/html"}),a.end(this.buildSuccessPage(p||"",u.substring(0,12)))}else a.writeHead(400,{"Content-Type":"text/html"}),a.end(this.buildErrorPage("No API key received"));o.close(),u?(e.md||(f.step(3,3,"Connected"),f.stop(),f.box("Authentication Complete",`Email: ${p}
1223
1249
  Key: ${u.substring(0,12)}...
1224
1250
  Status: Connected`)),await this.autoSync(),n({success:!0,message:e.md?`## Authenticated
1225
1251
  - **Email**: ${p}
1226
1252
  - **Key**: \`${u.substring(0,12)}...\``:""})):(e.md||f.fail("Authentication failed: no API key received"),n({success:!1,message:e.md?`## Error
1227
1253
  Authentication failed: no API key received`:""}));return}a.writeHead(404),a.end("Not found")});o.listen(0,"127.0.0.1",async()=>{let i=o.address();if(!i||typeof i=="string"){o.close(),e.md||f.fail("Failed to start callback server"),n({success:!1,message:e.md?`## Error
1228
- Failed to start callback server`:""});return}let a=i.port,c=`${s}/login?redirect=${encodeURIComponent(`/api/auth/cli-login?port=${a}`)}`;f.step(1,3,"Opening browser..."),f.stop(),f.info(te.dim(c));let u=process.platform,p=u==="darwin"?`open "${c}"`:u==="win32"?`start "${c}"`:`xdg-open "${c}"`;try{await N(p)}catch{f.warn("Could not open browser automatically"),f.info(`Visit: ${c}`)}f.step(2,3,"Waiting for authentication...")}),setTimeout(()=>{o.close(),f.stop(),e.md||(f.fail("Authentication timed out"),f.info(`Run ${te.cyan("prjct login")} to try again`)),n({success:!1,message:e.md?"## Error\nAuthentication timed out. Run `prjct login` to try again.":""})},300*1e3)})}async logout(){return(await gt.getStatus()).authenticated?(await gt.clearAuth(),f.done("Logged out"),{success:!0,message:""}):(f.info("Already logged out"),{success:!0,message:""})}async autoSync(){try{let e=await I.getProjectId(process.cwd());if(!e)return;f.spin("Syncing project...");let t=await Hg.sync(e);if(f.stop(),t.success&&!t.skipped){let s=t.pushed?.count||0,n=t.pulled?.count||0;s>0||n>0?f.done(`Synced (${s} pushed, ${n} pulled)`):f.done("Synced \u2014 everything up to date")}}catch{f.stop()}}buildSuccessPage(e,t){return`<!DOCTYPE html>
1254
+ Failed to start callback server`:""});return}let a=i.port,c=`${s}/login?redirect=${encodeURIComponent(`/api/auth/cli-login?port=${a}`)}`;f.step(1,3,"Opening browser..."),f.stop(),f.info(ne.dim(c));let u=process.platform,p=u==="darwin"?`open "${c}"`:u==="win32"?`start "${c}"`:`xdg-open "${c}"`;try{await O(p)}catch{f.warn("Could not open browser automatically"),f.info(`Visit: ${c}`)}f.step(2,3,"Waiting for authentication...")}),setTimeout(()=>{o.close(),f.stop(),e.md||(f.fail("Authentication timed out"),f.info(`Run ${ne.cyan("prjct login")} to try again`)),n({success:!1,message:e.md?"## Error\nAuthentication timed out. Run `prjct login` to try again.":""})},300*1e3)})}async logout(){return(await ft.getStatus()).authenticated?(await ft.clearAuth(),f.done("Logged out"),{success:!0,message:""}):(f.info("Already logged out"),{success:!0,message:""})}async autoSync(){try{let e=await $.getProjectId(process.cwd());if(!e)return;f.spin("Syncing project...");let t=await Bg.sync(e);if(f.stop(),t.success&&!t.skipped){let s=t.pushed?.count||0,n=t.pulled?.count||0;s>0||n>0?f.done(`Synced (${s} pushed, ${n} pulled)`):f.done("Synced \u2014 everything up to date")}}catch{f.stop()}}buildSuccessPage(e,t){return`<!DOCTYPE html>
1229
1255
  <html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1">
1230
1256
  <title>prjct CLI Connected</title>
1231
1257
  <style>
@@ -1280,7 +1306,7 @@ margin:1.25rem 0;font-size:.875rem;color:#f87171}
1280
1306
  <h1>Authentication Failed</h1>
1281
1307
  <div class="msg">${e}</div>
1282
1308
  <p class="hint">Return to your terminal and try again.</p>
1283
- </div></body></html>`}async start(){let e=await De.checkInstallation(),t=(it(),bt(Tt)),s=await t.detectCodex(),n=e.providerDetected,o=n?await t.getActiveProvider():null,i=n?o.displayName:"OpenAI Codex";if(console.log(`\u{1F680} Setting up prjct for ${i}...
1309
+ </div></body></html>`}async start(){let e=await De.checkInstallation(),t=(at(),ot(vt)),s=await t.detectCodex(),n=e.providerDetected,o=n?await t.getActiveProvider():null,i=n?o.displayName:"OpenAI Codex";if(console.log(`\u{1F680} Setting up prjct for ${i}...
1284
1310
  `),!n&&!s.installed)return{success:!1,message:`\u274C No supported AI provider detected.
1285
1311
 
1286
1312
  Please install one first:
@@ -1289,17 +1315,17 @@ Please install one first:
1289
1315
  - OpenAI Codex: https://github.com/openai/codex`};if(n){console.log("\u{1F4E6} Installing /p:* commands...");let a=await De.installCommands();if(!a.success)return{success:!1,message:`\u274C Installation failed: ${a.error}`};if(console.log(`
1290
1316
  \u2705 Installed ${a.installed?.length??0} commands to:
1291
1317
  ${A.getDisplayPath(a.path||"")}`),(a.errors?.length??0)>0){console.log(`
1292
- \u26A0\uFE0F ${a.errors?.length??0} errors:`);for(let c of a.errors??[])console.log(` - ${c.file}: ${c.error}`)}}if(s.installed)try{let{installCodexSkill:a,verifyCodexPRouterReady:c}=await Promise.resolve().then(()=>(xo(),Ja));await a();let u=await c({autoRepair:!0});u.verified?(console.log("\u2705 Installed Codex skill: ~/.codex/skills/prjct/SKILL.md"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${u.message||"router verification failed"}`),console.log(" Run `prjct setup` to retry Codex configuration."))}catch(a){console.log(`\u26A0\uFE0F Codex skill setup failed (non-blocking): ${y(a)}`)}return await this.setupMcpServers(),console.log(`
1318
+ \u26A0\uFE0F ${a.errors?.length??0} errors:`);for(let c of a.errors??[])console.log(` - ${c.file}: ${c.error}`)}}if(s.installed)try{let{installCodexSkill:a,verifyCodexPRouterReady:c}=await Promise.resolve().then(()=>(jo(),qa));await a();let u=await c({autoRepair:!0});u.verified?(console.log("\u2705 Installed Codex skill: ~/.codex/skills/prjct/SKILL.md"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${u.message||"router verification failed"}`),console.log(" Run `prjct setup` to retry Codex configuration."))}catch(a){console.log(`\u26A0\uFE0F Codex skill setup failed (non-blocking): ${w(a)}`)}return await this.setupMcpServers(),console.log(`
1293
1319
  \u{1F389} Setup complete!`),console.log(`
1294
1320
  Next steps:`),console.log(` 1. Open ${i}`),console.log(" 2. Navigate to your project"),console.log(" 3. Run: prjct init"),{success:!0,message:""}}async setup(e={}){console.log(`\u{1F527} Reconfiguring prjct...
1295
1321
  `),e.force&&(console.log("\u{1F5D1}\uFE0F Removing existing installation..."),await De.uninstallCommands()),console.log("\u{1F4E6} Installing /p:* commands...");let t=await De.installCommands();if(!t.success)return{success:!1,message:`\u274C Setup failed: ${t.error}`};if(console.log(`
1296
1322
  \u2705 Installed ${t.installed?.length??0} commands`),(t.errors?.length??0)>0){console.log(`
1297
1323
  \u26A0\uFE0F ${t.errors?.length??0} errors:`);for(let c of t.errors??[])console.log(` - ${c.file}: ${c.error}`)}console.log(`
1298
- \u{1F4DD} Installing global configuration...`);let s=await De.installGlobalConfig(),n=s.path?A.getDisplayPath(s.path):"global config";s.success?s.action==="created"?console.log(`\u2705 Created ${n}`):s.action==="updated"?console.log(`\u2705 Updated ${n}`):s.action==="appended"&&console.log(`\u2705 Added prjct config to ${n}`):console.log(`\u26A0\uFE0F ${s.error}`);let o=(it(),bt(Tt)),i=await o.getActiveProvider(),a=await o.detectCodex();if(i.name==="claude"){console.log(`
1299
- \u26A1 Installing status line...`);let c=await this.installStatusLine();c.success?console.log("\u2705 Status line configured"):console.log(`\u26A0\uFE0F ${c.error}`)}if(a.installed)try{let{installCodexSkill:c,verifyCodexPRouterReady:u}=await Promise.resolve().then(()=>(xo(),Ja));await c();let p=await u({autoRepair:!0});p.verified?(console.log("\u2705 Codex skill installed"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${p.message||"router verification failed"}`),console.log(" Run `prjct setup` again to retry Codex configuration."))}catch(c){console.log(`\u26A0\uFE0F Codex skill setup failed (non-blocking): ${y(c)}`)}return await this.setupMcpServers(),console.log(`
1324
+ \u{1F4DD} Installing global configuration...`);let s=await De.installGlobalConfig(),n=s.path?A.getDisplayPath(s.path):"global config";s.success?s.action==="created"?console.log(`\u2705 Created ${n}`):s.action==="updated"?console.log(`\u2705 Updated ${n}`):s.action==="appended"&&console.log(`\u2705 Added prjct config to ${n}`):console.log(`\u26A0\uFE0F ${s.error}`);let o=(at(),ot(vt)),i=await o.getActiveProvider(),a=await o.detectCodex();if(i.name==="claude"){console.log(`
1325
+ \u26A1 Installing status line...`);let c=await this.installStatusLine();c.success?console.log("\u2705 Status line configured"):console.log(`\u26A0\uFE0F ${c.error}`)}if(a.installed)try{let{installCodexSkill:c,verifyCodexPRouterReady:u}=await Promise.resolve().then(()=>(jo(),qa));await c();let p=await u({autoRepair:!0});p.verified?(console.log("\u2705 Codex skill installed"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${p.message||"router verification failed"}`),console.log(" Run `prjct setup` again to retry Codex configuration."))}catch(c){console.log(`\u26A0\uFE0F Codex skill setup failed (non-blocking): ${w(c)}`)}return await this.setupMcpServers(),console.log(`
1300
1326
  \u{1F389} Setup complete!
1301
1327
  `),this.showAsciiArt(),{success:!0,message:""}}async setupMcpServers(){console.log(`
1302
- \u{1F50C} Configuring MCP servers...`);try{await ls.install();let e=await ls.verify();e.verified?console.log("\u2705 Context7 MCP ready (framework API lookups)"):(console.log(`\u26A0\uFE0F Context7 configured but not yet verified: ${e.message||""}`),console.log(" It will activate on the next time you open your AI client."))}catch(e){console.log(`\u26A0\uFE0F Context7 MCP setup failed: ${y(e)}`),console.log(" Run `prjct start` again to retry.")}try{let e=ds();await _r("linear",e)?console.log("\u2705 Linear MCP already configured"):(await Nl("linear",_l.linear),console.log("\u2705 Linear MCP added to mcp.json"),console.log(" \u2192 Open your AI client and run any Linear command to complete OAuth."))}catch(e){console.log(`\u26A0\uFE0F Linear MCP setup failed: ${y(e)}`),console.log(" Run `prjct linear setup` to configure manually.")}try{let e=ds();await _r("jira",e)?console.log("\u2705 Jira MCP already configured"):(await Nl("jira",_l.jira),console.log("\u2705 Jira MCP added to mcp.json"),console.log(" \u2192 Open your AI client and run any Jira command to complete OAuth."))}catch(e){console.log(`\u26A0\uFE0F Jira MCP setup failed: ${y(e)}`),console.log(" Run `prjct jira setup` to configure manually.")}}async installStatusLine(){try{let e=A.getClaudeDir(),t=A.getClaudeSettingsPath(),s=nv.join(e,"prjct-statusline.sh"),n=`#!/bin/bash
1328
+ \u{1F50C} Configuring MCP servers...`);try{await ls.install();let e=await ls.verify();e.verified?console.log("\u2705 Context7 MCP ready (framework API lookups)"):(console.log(`\u26A0\uFE0F Context7 configured but not yet verified: ${e.message||""}`),console.log(" It will activate on the next time you open your AI client."))}catch(e){console.log(`\u26A0\uFE0F Context7 MCP setup failed: ${w(e)}`),console.log(" Run `prjct start` again to retry.")}try{let e=ds();await Lr("linear",e)?console.log("\u2705 Linear MCP already configured"):(await Ul("linear",Fl.linear),console.log("\u2705 Linear MCP added to mcp.json"),console.log(" \u2192 Open your AI client and run any Linear command to complete OAuth."))}catch(e){console.log(`\u26A0\uFE0F Linear MCP setup failed: ${w(e)}`),console.log(" Run `prjct linear setup` to configure manually.")}try{let e=ds();await Lr("jira",e)?console.log("\u2705 Jira MCP already configured"):(await Ul("jira",Fl.jira),console.log("\u2705 Jira MCP added to mcp.json"),console.log(" \u2192 Open your AI client and run any Jira command to complete OAuth."))}catch(e){console.log(`\u26A0\uFE0F Jira MCP setup failed: ${w(e)}`),console.log(" Run `prjct jira setup` to configure manually.")}}async installStatusLine(){try{let e=A.getClaudeDir(),t=A.getClaudeSettingsPath(),s=iT.join(e,"prjct-statusline.sh"),n=`#!/bin/bash
1303
1329
  # prjct Status Line for Claude Code
1304
1330
  # Shows version update notifications and current task
1305
1331
 
@@ -1355,14 +1381,14 @@ fi
1355
1381
 
1356
1382
  # Default: show prjct branding
1357
1383
  echo "\u26A1 prjct"
1358
- `;await tv.writeFile(s,n,{mode:493});let o={};if(await C(t))try{o=await xe(t)??{}}catch{}return o.statusLine={type:"command",command:s},await le(t,o),{success:!0}}catch(e){return{success:!1,error:y(e)}}}showAsciiArt(){console.log(te.cyan("\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501")),console.log(""),console.log(te.bold.cyan(" \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")),console.log(te.bold.cyan(" \u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557 \u2588\u2588\u2551\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D\u255A\u2550\u2550\u2588\u2588\u2554\u2550\u2550\u255D")),console.log(te.bold.cyan(" \u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D \u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551")),console.log(te.bold.cyan(" \u2588\u2588\u2554\u2550\u2550\u2550\u255D \u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588 \u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551")),console.log(te.bold.cyan(" \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2551")),console.log(te.bold.cyan(" \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D")),console.log(""),console.log(` ${te.bold.cyan("prjct")}${te.magenta("/")}${te.green("cli")} ${te.dim.white(`v${Ae} installed`)}`),console.log(""),console.log(` ${te.yellow("\u26A1")} Ship faster with zero friction`),console.log(` ${te.green("\u{1F4DD}")} From idea to technical tasks in minutes`),console.log(` ${te.cyan("\u{1F916}")} Perfect context for AI agents`),console.log(""),console.log(te.cyan("\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501")),console.log(""),console.log(te.bold.cyan("\u{1F680} Quick Start")),console.log(te.dim("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500")),console.log(""),console.log(` ${te.bold("1.")} Initialize your project:`),console.log(` ${te.green("cd your-project && prjct init")}`),console.log(""),console.log(` ${te.bold("2.")} Start your first task:`),console.log(` ${te.green('prjct task "build auth"')}`),console.log(""),console.log(` ${te.bold("3.")} Ship & celebrate:`),console.log(` ${te.green('prjct ship "user login"')}`),console.log(""),console.log(te.dim("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500")),console.log(""),console.log(` ${te.dim("Documentation:")} ${te.cyan("https://prjct.app")}`),console.log(` ${te.dim("Report issues:")} ${te.cyan("https://github.com/jlopezlira/prjct-cli/issues")}`),console.log(""),console.log(te.bold.magenta("Happy shipping! \u{1F680}")),console.log("")}};mr();oe();q();import Jg from"node:path";var rv=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"],ov=`# Changelog
1384
+ `;await rT.writeFile(s,n,{mode:493});let o={};if(await P(t))try{o=await xe(t)??{}}catch{}return o.statusLine={type:"command",command:s},await le(t,o),{success:!0}}catch(e){return{success:!1,error:w(e)}}}showAsciiArt(){console.log(ne.cyan("\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501")),console.log(""),console.log(ne.bold.cyan(" \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")),console.log(ne.bold.cyan(" \u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557 \u2588\u2588\u2551\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D\u255A\u2550\u2550\u2588\u2588\u2554\u2550\u2550\u255D")),console.log(ne.bold.cyan(" \u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D \u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551")),console.log(ne.bold.cyan(" \u2588\u2588\u2554\u2550\u2550\u2550\u255D \u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588 \u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551")),console.log(ne.bold.cyan(" \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2551")),console.log(ne.bold.cyan(" \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D")),console.log(""),console.log(` ${ne.bold.cyan("prjct")}${ne.magenta("/")}${ne.green("cli")} ${ne.dim.white(`v${Ae} installed`)}`),console.log(""),console.log(` ${ne.yellow("\u26A1")} Ship faster with zero friction`),console.log(` ${ne.green("\u{1F4DD}")} From idea to technical tasks in minutes`),console.log(` ${ne.cyan("\u{1F916}")} Perfect context for AI agents`),console.log(""),console.log(ne.cyan("\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501")),console.log(""),console.log(ne.bold.cyan("\u{1F680} Quick Start")),console.log(ne.dim("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500")),console.log(""),console.log(` ${ne.bold("1.")} Initialize your project:`),console.log(` ${ne.green("cd your-project && prjct init")}`),console.log(""),console.log(` ${ne.bold("2.")} Start your first task:`),console.log(` ${ne.green('prjct task "build auth"')}`),console.log(""),console.log(` ${ne.bold("3.")} Ship & celebrate:`),console.log(` ${ne.green('prjct ship "user login"')}`),console.log(""),console.log(ne.dim("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500")),console.log(""),console.log(` ${ne.dim("Documentation:")} ${ne.cyan("https://prjct.app")}`),console.log(` ${ne.dim("Report issues:")} ${ne.cyan("https://github.com/jlopezlira/prjct-cli/issues")}`),console.log(""),console.log(ne.bold.magenta("Happy shipping! \u{1F680}")),console.log("")}};mr();ie();K();import Xg from"node:path";var aT=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"],cT=`# Changelog
1359
1385
 
1360
1386
  All notable changes to this project will be documented in this file.
1361
1387
 
1362
1388
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
1363
1389
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
1364
- `,hi=class{static{l(this,"ChangelogService")}projectPath;constructor(e){this.projectPath=e}async detect(){for(let s of rv){let n=Jg.join(this.projectPath,s);if(await C(n)){let o=await ot(n),i=this.detectFormat(o);return{filePath:n,fileName:s,format:i,created:!1}}}let e="CHANGELOG.md",t=Jg.join(this.projectPath,e);return await Jt(t,`${ov}
1365
- `),{filePath:t,fileName:e,format:"keepachangelog",created:!0}}async addEntry(e){let t=await this.detect(),s=await ot(t.filePath),n=e.date||cn(new Date),o;t.format==="keepachangelog"?o=this.insertKeepAChangelogEntry(s,e,n):o=this.insertMarkdownEntry(s,e,n),await Jt(t.filePath,o)}async addFeature(e,t){await this.addEntry({version:e,sections:{Added:[t]}})}detectFormat(e){return e.includes("Keep a Changelog")||e.includes("keepachangelog.com")||/^### (?:Added|Changed|Deprecated|Removed|Fixed|Security)\s*$/m.test(e)?"keepachangelog":"markdown"}insertKeepAChangelogEntry(e,t,s){let n=this.formatKeepAChangelogEntry(t,s),o=e.search(/^## /m);if(o!==-1){let i=e.slice(0,o),a=e.slice(o);return`${i+n}
1390
+ `,Si=class{static{l(this,"ChangelogService")}projectPath;constructor(e){this.projectPath=e}async detect(){for(let s of aT){let n=Xg.join(this.projectPath,s);if(await P(n)){let o=await it(n),i=this.detectFormat(o);return{filePath:n,fileName:s,format:i,created:!1}}}let e="CHANGELOG.md",t=Xg.join(this.projectPath,e);return await Jt(t,`${cT}
1391
+ `),{filePath:t,fileName:e,format:"keepachangelog",created:!0}}async addEntry(e){let t=await this.detect(),s=await it(t.filePath),n=e.date||ln(new Date),o;t.format==="keepachangelog"?o=this.insertKeepAChangelogEntry(s,e,n):o=this.insertMarkdownEntry(s,e,n),await Jt(t.filePath,o)}async addFeature(e,t){await this.addEntry({version:e,sections:{Added:[t]}})}detectFormat(e){return e.includes("Keep a Changelog")||e.includes("keepachangelog.com")||/^### (?:Added|Changed|Deprecated|Removed|Fixed|Security)\s*$/m.test(e)?"keepachangelog":"markdown"}insertKeepAChangelogEntry(e,t,s){let n=this.formatKeepAChangelogEntry(t,s),o=e.search(/^## /m);if(o!==-1){let i=e.slice(0,o),a=e.slice(o);return`${i+n}
1366
1392
  ${a}`}return`${e.trimEnd()}
1367
1393
 
1368
1394
  ${n}`}insertMarkdownEntry(e,t,s){let n=this.formatMarkdownEntry(t,s),o=e.indexOf(`
@@ -1372,31 +1398,31 @@ ${a}`}return`${n}
1372
1398
 
1373
1399
  ${e}`}formatKeepAChangelogEntry(e,t){let s=[`## [${e.version}] - ${t}`];if(s.push(""),e.sections)for(let[n,o]of Object.entries(e.sections)){s.push(`### ${n}`);for(let i of o)s.push(`- ${i}`);s.push("")}else e.description&&(s.push("### Added"),s.push(`- ${e.description}`),s.push(""));return s.join(`
1374
1400
  `)}formatMarkdownEntry(e,t){let s=[`## ${e.version} - ${t}`];if(s.push(""),e.sections)for(let[n,o]of Object.entries(e.sections)){s.push(`### ${n}`);for(let i of o)s.push(`- ${i}`);s.push("")}else e.description&&(s.push(`- ${e.description}`),s.push(""));return s.join(`
1375
- `)}};kc();Ue();q();import Hn from"node:path";var yi=class{static{l(this,"VersionService")}projectPath;constructor(e){this.projectPath=e}async detect(){let e=[()=>this.fromPackageJson(),()=>this.fromCargoToml(),()=>this.fromPyprojectToml(),()=>this.fromCsproj(),()=>this.fromVersionFile("VERSION"),()=>this.fromVersionFile("version.txt"),()=>this.fromGitTag()];for(let t of e){let s=await t();if(s)return s}return this.createFallbackVersion()}async bump(){let e=await this.detect();return await this.writeVersion(e),e.next}async fromPackageJson(){let e=Hn.join(this.projectPath,"package.json"),t=await xe(e,null);return t?.version?{current:t.version,next:Gn(t.version),file:e,format:"json"}:null}async fromCargoToml(){let e=Hn.join(this.projectPath,"Cargo.toml"),t=await ot(e,"");if(!t)return null;let s=iv(t);return s?{current:s,next:Gn(s),file:e,format:"toml"}:null}async fromPyprojectToml(){let e=Hn.join(this.projectPath,"pyproject.toml"),t=await ot(e,"");if(!t)return null;let s=av(t);return s?{current:s,next:Gn(s),file:e,format:"toml"}:null}async fromCsproj(){let e=await ts(this.projectPath,{extension:".csproj"});if(e.length===0)return null;let t=Hn.join(this.projectPath,e[0]),s=await ot(t,"");if(!s)return null;let n=cv(s);return n?{current:n,next:Gn(n),file:t,format:"xml"}:null}async fromVersionFile(e){let t=Hn.join(this.projectPath,e),s=await ot(t,"");if(!s)return null;let n=s.trim();return zg(n)?{current:n,next:Gn(n),file:t,format:"plaintext"}:null}async fromGitTag(){try{let{stdout:e}=await N("git tag --sort=-v:refname",{cwd:this.projectPath}),t=e.trim().split(`
1376
- `);for(let s of t){let n=s.trim().replace(/^v/,"");if(zg(n))return{current:n,next:Gn(n),file:null,format:"git-tag"}}}catch{}return null}async createFallbackVersion(){let e=Hn.join(this.projectPath,"VERSION");return await Jt(e,`0.1.0
1377
- `),{current:"0.1.0",next:"0.1.1",file:e,format:"plaintext"}}async writeVersion(e){if(!e.file){e.format==="git-tag"&&await N(`git tag v${e.next}`,{cwd:this.projectPath});return}switch(e.format){case"json":await this.writeJsonVersion(e.file,e.next);break;case"toml":await this.writeTomlVersion(e.file,e.next);break;case"xml":await this.writeXmlVersion(e.file,e.next);break;case"plaintext":await Jt(e.file,`${e.next}
1378
- `);break}}async writeJsonVersion(e,t){let s=await xe(e,{});s&&(s.version=t,await le(e,s))}async writeTomlVersion(e,t){let s=await ot(e,"");if(!s)return;let n=s.replace(/^(\s*version\s*=\s*")([^"]+)(")/m,`$1${t}$3`);await Jt(e,n)}async writeXmlVersion(e,t){let s=await ot(e,"");if(!s)return;let n=s.replace(/(<Version>)([^<]+)(<\/Version>)/,`$1${t}$3`);await Jt(e,n)}};function zg(r){return/^\d+\.\d+\.\d+/.test(r)}l(zg,"isSemver");function Gn(r){let e=r.match(/^(\d+)\.(\d+)\.(\d+)/);if(!e)return r;let[,t,s,n]=e;return`${t}.${s}.${Number(n)+1}`}l(Gn,"bumpPatch");function iv(r){let e=r.match(/\[package\]([\s\S]*?)(?=\n\[|\n*$)/);return e?e[1].match(/^\s*version\s*=\s*"([^"]+)"/m)?.[1]??null:null}l(iv,"parseTomlVersion");function av(r){let e=r.match(/\[project\]([\s\S]*?)(?=\n\[|\n*$)/);if(e){let s=e[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(s)return s[1]}let t=r.match(/\[tool\.poetry\]([\s\S]*?)(?=\n\[|\n*$)/);if(t){let s=t[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(s)return s[1]}return null}l(av,"parsePyprojectVersion");function cv(r){return r.match(/<Version>([^<]+)<\/Version>/)?.[1]?.trim()??null}l(cv,"parseCsprojVersion");Js();Pt();V();Pn();En();ri();V();Ue();import jt from"chalk";async function Wt(r,e,t,s={}){let n={success:!0,gatesFailed:[],hooksFailed:[],stepsRun:[],instructions:[],output:""};if(s.skipRules)return n;let i=Ie.getRulesForCommand(r,e).filter(m=>m.position===t),a=i.filter(m=>m.type==="gate");for(let m of a){let d=m.description||m.action;console.log(`
1379
- ${jt.dim(`[gate] ${t}-${e}: ${m.action}`)}`);try{let g=Date.now();await N(m.action,{timeout:m.timeoutMs,cwd:s.projectPath||process.cwd(),env:{...process.env}});let h=Date.now()-g,k=h>1e3?`${(h/1e3).toFixed(1)}s`:`${h}ms`;console.log(`${jt.green("\u2713")} ${jt.dim(`gate passed (${k})`)}`)}catch(g){return console.log(`${jt.red("\u2717")} gate failed: ${d}`),n.gatesFailed.push(d),n.success=!1,n.output+=`Gate failed: ${d}
1380
- ${y(g)}
1401
+ `)}};bc();He();K();import Hn from"node:path";var bi=class{static{l(this,"VersionService")}projectPath;constructor(e){this.projectPath=e}async detect(){let e=[()=>this.fromPackageJson(),()=>this.fromCargoToml(),()=>this.fromPyprojectToml(),()=>this.fromCsproj(),()=>this.fromVersionFile("VERSION"),()=>this.fromVersionFile("version.txt"),()=>this.fromGitTag()];for(let t of e){let s=await t();if(s)return s}return this.createFallbackVersion()}async bump(){let e=await this.detect();return await this.writeVersion(e),e.next}async fromPackageJson(){let e=Hn.join(this.projectPath,"package.json"),t=await xe(e,null);return t?.version?{current:t.version,next:Gn(t.version),file:e,format:"json"}:null}async fromCargoToml(){let e=Hn.join(this.projectPath,"Cargo.toml"),t=await it(e,"");if(!t)return null;let s=lT(t);return s?{current:s,next:Gn(s),file:e,format:"toml"}:null}async fromPyprojectToml(){let e=Hn.join(this.projectPath,"pyproject.toml"),t=await it(e,"");if(!t)return null;let s=uT(t);return s?{current:s,next:Gn(s),file:e,format:"toml"}:null}async fromCsproj(){let e=await ts(this.projectPath,{extension:".csproj"});if(e.length===0)return null;let t=Hn.join(this.projectPath,e[0]),s=await it(t,"");if(!s)return null;let n=dT(s);return n?{current:n,next:Gn(n),file:t,format:"xml"}:null}async fromVersionFile(e){let t=Hn.join(this.projectPath,e),s=await it(t,"");if(!s)return null;let n=s.trim();return Yg(n)?{current:n,next:Gn(n),file:t,format:"plaintext"}:null}async fromGitTag(){try{let{stdout:e}=await O("git tag --sort=-v:refname",{cwd:this.projectPath}),t=e.trim().split(`
1402
+ `);for(let s of t){let n=s.trim().replace(/^v/,"");if(Yg(n))return{current:n,next:Gn(n),file:null,format:"git-tag"}}}catch{}return null}async createFallbackVersion(){let e=Hn.join(this.projectPath,"VERSION");return await Jt(e,`0.1.0
1403
+ `),{current:"0.1.0",next:"0.1.1",file:e,format:"plaintext"}}async writeVersion(e){if(!e.file){e.format==="git-tag"&&await O(`git tag v${e.next}`,{cwd:this.projectPath});return}switch(e.format){case"json":await this.writeJsonVersion(e.file,e.next);break;case"toml":await this.writeTomlVersion(e.file,e.next);break;case"xml":await this.writeXmlVersion(e.file,e.next);break;case"plaintext":await Jt(e.file,`${e.next}
1404
+ `);break}}async writeJsonVersion(e,t){let s=await xe(e,{});s&&(s.version=t,await le(e,s))}async writeTomlVersion(e,t){let s=await it(e,"");if(!s)return;let n=s.replace(/^(\s*version\s*=\s*")([^"]+)(")/m,`$1${t}$3`);await Jt(e,n)}async writeXmlVersion(e,t){let s=await it(e,"");if(!s)return;let n=s.replace(/(<Version>)([^<]+)(<\/Version>)/,`$1${t}$3`);await Jt(e,n)}};function Yg(r){return/^\d+\.\d+\.\d+/.test(r)}l(Yg,"isSemver");function Gn(r){let e=r.match(/^(\d+)\.(\d+)\.(\d+)/);if(!e)return r;let[,t,s,n]=e;return`${t}.${s}.${Number(n)+1}`}l(Gn,"bumpPatch");function lT(r){let e=r.match(/\[package\]([\s\S]*?)(?=\n\[|\n*$)/);return e?e[1].match(/^\s*version\s*=\s*"([^"]+)"/m)?.[1]??null:null}l(lT,"parseTomlVersion");function uT(r){let e=r.match(/\[project\]([\s\S]*?)(?=\n\[|\n*$)/);if(e){let s=e[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(s)return s[1]}let t=r.match(/\[tool\.poetry\]([\s\S]*?)(?=\n\[|\n*$)/);if(t){let s=t[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(s)return s[1]}return null}l(uT,"parsePyprojectVersion");function dT(r){return r.match(/<Version>([^<]+)<\/Version>/)?.[1]?.trim()??null}l(dT,"parseCsprojVersion");zs();Pt();W();Ks();En();ci();W();He();import jt from"chalk";async function zt(r,e,t,s={}){let n={success:!0,gatesFailed:[],hooksFailed:[],stepsRun:[],instructions:[],output:""};if(s.skipRules)return n;let i=je.getRulesForCommand(r,e).filter(m=>m.position===t),a=i.filter(m=>m.type==="gate");for(let m of a){let d=m.description||m.action;console.log(`
1405
+ ${jt.dim(`[gate] ${t}-${e}: ${m.action}`)}`);try{let g=Date.now();await O(m.action,{timeout:m.timeoutMs,cwd:s.projectPath||process.cwd(),env:{...process.env}});let h=Date.now()-g,k=h>1e3?`${(h/1e3).toFixed(1)}s`:`${h}ms`;console.log(`${jt.green("\u2713")} ${jt.dim(`gate passed (${k})`)}`)}catch(g){return console.log(`${jt.red("\u2717")} gate failed: ${d}`),n.gatesFailed.push(d),n.success=!1,n.output+=`Gate failed: ${d}
1406
+ ${w(g)}
1381
1407
  `,n}}let c=i.filter(m=>m.type==="instruction");for(let m of c){let d=m.description||m.action;console.log(`
1382
1408
  ${jt.dim(`[instruction] ${t}-${e}: ${d}`)}`),n.instructions.push(m.action)}let u=i.filter(m=>m.type==="hook");for(let m of u){console.log(`
1383
- ${jt.dim(`[hook] ${t}-${e}: ${m.action}`)}`);try{let d=Date.now();await N(m.action,{timeout:m.timeoutMs,cwd:s.projectPath||process.cwd(),env:{...process.env}});let g=Date.now()-d,h=g>1e3?`${(g/1e3).toFixed(1)}s`:`${g}ms`;console.log(`${jt.green("\u2713")} ${jt.dim(`(${h})`)}`)}catch(d){console.log(`${jt.yellow("\u26A0")} hook failed (non-blocking): ${m.action}`),n.hooksFailed.push(m.description||m.action),n.output+=`Hook failed: ${m.action}
1384
- ${y(d)}
1409
+ ${jt.dim(`[hook] ${t}-${e}: ${m.action}`)}`);try{let d=Date.now();await O(m.action,{timeout:m.timeoutMs,cwd:s.projectPath||process.cwd(),env:{...process.env}});let g=Date.now()-d,h=g>1e3?`${(g/1e3).toFixed(1)}s`:`${g}ms`;console.log(`${jt.green("\u2713")} ${jt.dim(`(${h})`)}`)}catch(d){console.log(`${jt.yellow("\u26A0")} hook failed (non-blocking): ${m.action}`),n.hooksFailed.push(m.description||m.action),n.output+=`Hook failed: ${m.action}
1410
+ ${w(d)}
1385
1411
  `}}let p=i.filter(m=>m.type==="step");for(let m of p){console.log(`
1386
- ${jt.dim(`[step] ${e}: ${m.action}`)}`);try{let d=Date.now();await N(m.action,{timeout:m.timeoutMs,cwd:s.projectPath||process.cwd(),env:{...process.env}});let g=Date.now()-d,h=g>1e3?`${(g/1e3).toFixed(1)}s`:`${g}ms`;console.log(`${jt.green("\u2713")} ${jt.dim(`step passed (${h})`)}`),n.stepsRun.push(m.description||m.action)}catch(d){return console.log(`${jt.red("\u2717")} step failed: ${m.action}`),n.gatesFailed.push(m.description||m.action),n.success=!1,n.output+=`Step failed: ${m.action}
1387
- ${y(d)}
1388
- `,n}}return n}l(Wt,"executeWorkflowRules");lt();var Vn=class extends Ce{static{l(this,"ShippingCommands")}async ship(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e,a=await _.getCurrentTask(o);a&&(i||(i=a.description||"current work"),await _.completeTask(o)),i||(i="current work");let c=await Wt(o,"ship","before",{projectPath:t,skipRules:s.skipHooks});if(!c.success)return{success:!1,error:c.gatesFailed.length>0?`Blocked: ${c.gatesFailed.join(", ")}`:`Step failed: ${c.gatesFailed.join(", ")}`};s.md||f.step(1,4,"Bumping version...");let p=await new yi(t).bump();s.md||f.step(2,4,"Updating changelog..."),await new hi(t).addFeature(p,i),s.md||f.step(3,4,"Committing...");let d=await this._createShipCommit(i,t),g="skipped";if(d.success){let w=await this._gitPush(t);g=w.success?"pushed":w.message}await et.addShipped(o,{name:i,version:p}),await this.logToMemory(t,"feature_shipped",{feature:i,version:p,timestamp:z.getTimestamp()}),await at.learnDecision(o,"commit_footer","prjct","ship"),await at.recordWorkflow(o,"ship_completed",{description:"Ship with workflow rules",feature:i,version:p});let h=await Wt(o,"ship","after",{projectPath:t,skipRules:s.skipHooks}),k=[...c.instructions,...h.instructions];try{s.md||f.step(4,4,"Updating AI context..."),await qs.sync(t),s.md||f.done("\u2713 AI context updated")}catch(w){console.warn("\u26A0\uFE0F Failed to sync AI context after shipping:",y(w))}if(s.md){let w=_o("ship"),T=U(ke(`Shipped: ${i}`,`Version: ${p}`),se("Results",je([`Version: ${p}`,`Commit: ${d.success?"created":d.message}`,`Push: ${g}`,`Workflow steps: ${c.stepsRun.length>0?c.stepsRun.join(", "):"none"}`])),k.length>0?se("Agent Instructions",je(k)):null,ge(w.map(E=>({label:E.desc,command:E.cmd}))));console.log(T)}else f.done(`v${p} shipped`),At("ship");return{success:!0,feature:i,version:p}}catch(n){return f.fail(y(n)),{success:!1,error:y(n)}}}async _createShipCommit(e,t){try{await st.get("Bash")("git add .");let s=`feat: ${e}
1412
+ ${jt.dim(`[step] ${e}: ${m.action}`)}`);try{let d=Date.now();await O(m.action,{timeout:m.timeoutMs,cwd:s.projectPath||process.cwd(),env:{...process.env}});let g=Date.now()-d,h=g>1e3?`${(g/1e3).toFixed(1)}s`:`${g}ms`;console.log(`${jt.green("\u2713")} ${jt.dim(`step passed (${h})`)}`),n.stepsRun.push(m.description||m.action)}catch(d){return console.log(`${jt.red("\u2717")} step failed: ${m.action}`),n.gatesFailed.push(m.description||m.action),n.success=!1,n.output+=`Step failed: ${m.action}
1413
+ ${w(d)}
1414
+ `,n}}return n}l(zt,"executeWorkflowRules");dt();var Wn=class extends Ce{static{l(this,"ShippingCommands")}async ship(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e,a=await _.getCurrentTask(o);a&&(i||(i=a.description||"current work"),await _.completeTask(o)),i||(i="current work");let c=await zt(o,"ship","before",{projectPath:t,skipRules:s.skipHooks});if(!c.success)return{success:!1,error:c.gatesFailed.length>0?`Blocked: ${c.gatesFailed.join(", ")}`:`Step failed: ${c.gatesFailed.join(", ")}`};s.md||f.step(1,4,"Bumping version...");let p=await new bi(t).bump();s.md||f.step(2,4,"Updating changelog..."),await new Si(t).addFeature(p,i),s.md||f.step(3,4,"Committing...");let d=await this._createShipCommit(i,t),g="skipped";if(d.success){let y=await this._gitPush(t);g=y.success?"pushed":y.message}await tt.addShipped(o,{name:i,version:p}),await this.logToMemory(t,"feature_shipped",{feature:i,version:p,timestamp:J.getTimestamp()}),await ct.learnDecision(o,"commit_footer","prjct","ship"),await ct.recordWorkflow(o,"ship_completed",{description:"Ship with workflow rules",feature:i,version:p});let h=await zt(o,"ship","after",{projectPath:t,skipRules:s.skipHooks}),k=[...c.instructions,...h.instructions];try{s.md||f.step(4,4,"Updating AI context..."),await qs.sync(t),s.md||f.done("\u2713 AI context updated")}catch(y){console.warn("\u26A0\uFE0F Failed to sync AI context after shipping:",w(y))}if(s.md){let y=Uo("ship",!0),v=L(ke(`Shipped: ${i}`,`Version: ${p}`),Q("Results",Oe([`Version: ${p}`,`Commit: ${d.success?"created":d.message}`,`Push: ${g}`,`Workflow steps: ${c.stepsRun.length>0?c.stepsRun.join(", "):"none"}`])),k.length>0?Q("Agent Instructions",Oe(k)):null,ge(y.map(D=>({label:D.desc,command:D.cmd}))));console.log(v)}else f.done(`v${p} shipped`),At("ship");return{success:!0,feature:i,version:p}}catch(n){return f.fail(w(n)),{success:!1,error:w(n)}}}async _createShipCommit(e,t){try{await nt.get("Bash")("git add .");let s=`feat: ${e}
1389
1415
 
1390
- Generated with [p/](https://www.prjct.app/)`;return await st.get("Bash")(`git commit -m "${s.replace(/"/g,'\\"')}"`),{success:!0,message:"Committed"}}catch(s){return R(s)?{success:!1,message:"Git not found"}:{success:!1,message:"No changes to commit"}}}async _gitPush(e){try{return await st.get("Bash")("git push"),{success:!0,message:"Pushed to remote"}}catch(t){return R(t)?{success:!1,message:"Git not found"}:{success:!1,message:"Push failed (no remote or auth issue)"}}}};os();Wa();ve();al();Za();V();Ts();Ct();lt();import{execSync as Fr}from"node:child_process";import ki from"node:fs/promises";import Lr from"node:path";import Bn from"chalk";function ef(){try{return!!Fr("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})}catch{return!1}}l(ef,"isHomebrewInstall");function tf(){try{let e=Fr("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).match(/prjct-cli@([\d.]+)/);return e?e[1]:null}catch{return null}}l(tf,"getCurrentVersion");var Jn=class extends Ce{static{l(this,"UpdateCommands")}async update(e={},t=process.cwd()){let s=e["dry-run"]===!0,n=e.md===!0,o={phase1:{success:!0,details:[],errors:[]},phase2:{success:!0,details:[],errors:[]},phase3:{success:!0,details:[],errors:[]}};try{if(n||f.step(1,3,"Updating package..."),o.phase1=await this.phasePackageUpdate(s),n||f.stop(),n||f.step(2,3,"Cleaning up all projects..."),o.phase2=await this.phaseGlobalCleanup(s),n||f.stop(),n||f.step(3,3,"Restarting daemon..."),o.phase3=await this.phaseDaemonRestart(s),n||f.stop(),!s){try{await Co.updateVersion(Ae)}catch{}try{await new ei().writeCache({lastCheck:0,latestVersion:""})}catch{}}return n?this.formatMdOutput(o,s):this.formatTerminalOutput(o,s)}catch(i){return n||f.stop(),f.fail(y(i)),{success:!1,error:y(i)}}}async phasePackageUpdate(e){let t={success:!0,details:[],errors:[]},s=tf();if(e)return ef()?(t.details.push("Would uninstall homebrew formula"),t.details.push("Would install via npm: npm install -g prjct-cli")):t.details.push("Would run: npm update -g prjct-cli"),t;try{if(ef()){try{Fr("brew uninstall prjct-cli 2>/dev/null",{stdio:"pipe"}),t.details.push("Uninstalled homebrew formula")}catch{t.details.push("Homebrew uninstall skipped (not found)")}Fr("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("Installed via npm")}else Fr("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("npm install complete");let o=tf();s&&o&&s!==o?t.details.push(`${s} \u2192 ${o}`):o&&t.details.push(`v${o} (already latest)`)}catch(n){t.success=!1,t.errors.push(y(n))}return t}async phaseGlobalCleanup(e){let t={success:!0,details:[],errors:[]},s=await this.getAllProjectIds();if(s.length===0)t.details.push("No projects found");else{let n=0,o=0;for(let i of s)if(!e)try{let a=await Ro(i),c=await Ao(i);if(n+=a.migratedFiles.length,o+=c,a.errors.length>0)for(let u of a.errors)t.errors.push(`${i.slice(0,8)}: ${u.file}: ${u.error}`)}catch(a){t.errors.push(`${i.slice(0,8)}: ${y(a)}`)}if(e)t.details.push(`Would migrate ${s.length} project(s)`);else{let i=[`${s.length} project(s) checked`];n>0&&i.push(`${n} files migrated`),o>0&&i.push(`${o} leftovers swept`),t.details.push(i.join(", "))}}if(e)t.details.push("Would clean all legacy artifacts"),t.details.push("Would reinstall editor commands"),t.details.push("Would reinstall global config (all providers)");else{try{let o=await new rs().cleanupAllLegacy();o.cleaned.length>0&&t.details.push(`Cleaned ${o.cleaned.length} legacy artifact(s)`)}catch(n){t.errors.push(`Legacy cleanup: ${y(n)}`)}try{let o=await new rs().installCommands();t.details.push(`Editor commands reinstalled (${o.installed?.length||0} providers)`)}catch(n){t.errors.push(`Commands: ${y(n)}`)}try{await new rs().installGlobalConfig(),t.details.push("Global config updated (prjct section replaced)")}catch(n){t.errors.push(`Global config: ${y(n)}`)}try{let{detectAllProviders:n}=await Promise.resolve().then(()=>(it(),Tt)),o=await n(),i=Lr.join(St("node:os").homedir());if(o.gemini.installed){let a=Lr.join(i,".gemini","GEMINI.md");try{let c=await ki.readFile(a,"utf-8"),u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",p="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(c.includes(u)&&c.includes(p)){let m=Lr.join(Lr.dirname(St.resolve("../../package.json")),"templates","global","GEMINI.md"),d=await ki.readFile(m,"utf-8"),g=d.substring(d.indexOf(u),d.indexOf(p)+p.length),h=c.substring(0,c.indexOf(u)),k=c.substring(c.indexOf(p)+p.length),w=h+g+k,T="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",E="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->";if(w.includes(T)&&w.includes(E)){let M=w.substring(0,w.indexOf(T)),L=w.substring(w.indexOf(E)+E.length);w=`${(M+L).replace(/\n{3,}/g,`
1416
+ Generated with [p/](https://www.prjct.app/)`;return await nt.get("Bash")(`git commit -m "${s.replace(/"/g,'\\"')}"`),{success:!0,message:"Committed"}}catch(s){return R(s)?{success:!1,message:"Git not found"}:{success:!1,message:"No changes to commit"}}}async _gitPush(e){try{return await nt.get("Bash")("git push"),{success:!0,message:"Pushed to remote"}}catch(t){return R(t)?{success:!1,message:"Git not found"}:{success:!1,message:"Push failed (no remote or auth issue)"}}}};os();za();Te();ll();tc();W();vs();Ct();dt();import{execSync as Hr}from"node:child_process";import vi from"node:fs/promises";import Ur from"node:path";import Bn from"chalk";function rf(){try{return!!Hr("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})}catch{return!1}}l(rf,"isHomebrewInstall");function of(){try{let e=Hr("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).match(/prjct-cli@([\d.]+)/);return e?e[1]:null}catch{return null}}l(of,"getCurrentVersion");var zn=class extends Ce{static{l(this,"UpdateCommands")}async update(e={},t=process.cwd()){let s=e["dry-run"]===!0,n=e.md===!0,o={phase1:{success:!0,details:[],errors:[]},phase2:{success:!0,details:[],errors:[]},phase3:{success:!0,details:[],errors:[]}};try{if(n||f.step(1,3,"Updating package..."),o.phase1=await this.phasePackageUpdate(s),n||f.stop(),n||f.step(2,3,"Cleaning up all projects..."),o.phase2=await this.phaseGlobalCleanup(s),n||f.stop(),n||f.step(3,3,"Restarting daemon..."),o.phase3=await this.phaseDaemonRestart(s),n||f.stop(),!s){try{await Ro.updateVersion(Ae)}catch{}try{await new ri().writeCache({lastCheck:0,latestVersion:""})}catch{}}return n?this.formatMdOutput(o,s):this.formatTerminalOutput(o,s)}catch(i){return n||f.stop(),f.fail(w(i)),{success:!1,error:w(i)}}}async phasePackageUpdate(e){let t={success:!0,details:[],errors:[]},s=of();if(e)return rf()?(t.details.push("Would uninstall homebrew formula"),t.details.push("Would install via npm: npm install -g prjct-cli")):t.details.push("Would run: npm update -g prjct-cli"),t;try{if(rf()){try{Hr("brew uninstall prjct-cli 2>/dev/null",{stdio:"pipe"}),t.details.push("Uninstalled homebrew formula")}catch{t.details.push("Homebrew uninstall skipped (not found)")}Hr("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("Installed via npm")}else Hr("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("npm install complete");let o=of();s&&o&&s!==o?t.details.push(`${s} \u2192 ${o}`):o&&t.details.push(`v${o} (already latest)`)}catch(n){t.success=!1,t.errors.push(w(n))}return t}async phaseGlobalCleanup(e){let t={success:!0,details:[],errors:[]},s=await this.getAllProjectIds();if(s.length===0)t.details.push("No projects found");else{let n=0,o=0;for(let i of s)if(!e)try{let a=await Io(i),c=await $o(i);if(n+=a.migratedFiles.length,o+=c,a.errors.length>0)for(let u of a.errors)t.errors.push(`${i.slice(0,8)}: ${u.file}: ${u.error}`)}catch(a){t.errors.push(`${i.slice(0,8)}: ${w(a)}`)}if(e)t.details.push(`Would migrate ${s.length} project(s)`);else{let i=[`${s.length} project(s) checked`];n>0&&i.push(`${n} files migrated`),o>0&&i.push(`${o} leftovers swept`),t.details.push(i.join(", "))}}if(e)t.details.push("Would clean all legacy artifacts"),t.details.push("Would reinstall editor commands"),t.details.push("Would reinstall global config (all providers)");else{try{let o=await new rs().cleanupAllLegacy();o.cleaned.length>0&&t.details.push(`Cleaned ${o.cleaned.length} legacy artifact(s)`)}catch(n){t.errors.push(`Legacy cleanup: ${w(n)}`)}try{let o=await new rs().installCommands();t.details.push(`Editor commands reinstalled (${o.installed?.length||0} providers)`)}catch(n){t.errors.push(`Commands: ${w(n)}`)}try{await new rs().installGlobalConfig(),t.details.push("Global config updated (prjct section replaced)")}catch(n){t.errors.push(`Global config: ${w(n)}`)}try{let{detectAllProviders:n}=await Promise.resolve().then(()=>(at(),vt)),o=await n(),i=Ur.join(bt("node:os").homedir());if(o.gemini.installed){let a=Ur.join(i,".gemini","GEMINI.md");try{let c=await vi.readFile(a,"utf-8"),u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",p="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(c.includes(u)&&c.includes(p)){let m=Ur.join(Ur.dirname(bt.resolve("../../package.json")),"templates","global","GEMINI.md"),d=await vi.readFile(m,"utf-8"),g=d.substring(d.indexOf(u),d.indexOf(p)+p.length),h=c.substring(0,c.indexOf(u)),k=c.substring(c.indexOf(p)+p.length),y=h+g+k,v="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",D="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->";if(y.includes(v)&&y.includes(D)){let U=y.substring(0,y.indexOf(v)),F=y.substring(y.indexOf(D)+D.length);y=`${(U+F).replace(/\n{3,}/g,`
1391
1417
 
1392
1418
  `).trim()}
1393
- `}await ki.writeFile(a,w,"utf-8"),t.details.push("Gemini global config updated")}}catch{}}}catch{}}return t.errors.length>0&&(t.success=!1),t}async phaseDaemonRestart(e){let t={success:!0,details:[],errors:[]};if(e)return t.details.push("Would restart daemon"),t;try{let{isDaemonRunning:s,stopDaemon:n,forceKillDaemon:o,spawnDaemon:i}=await Promise.resolve().then(()=>(Zg(),Qg));await s()?(await n()||o(),await new Promise(u=>setTimeout(u,300)),t.details.push("Daemon stopped")):(o(),t.details.push("No running daemon (cleaned stale files)")),await i()?t.details.push("Daemon restarted"):t.details.push("Daemon will start automatically on next use")}catch(s){t.success=!1,t.errors.push(y(s))}return t}formatTerminalOutput(e,t){let s=e.phase1.success&&e.phase2.success,n=[...e.phase1.errors,...e.phase2.errors];console.log("");let o=[{label:"Package",result:e.phase1,fatal:!0},{label:"Cleanup",result:e.phase2,fatal:!0},{label:"Daemon",result:e.phase3,fatal:!1}];for(let{label:i,result:a,fatal:c}of o){let u=a.success?Bn.green("\u2713"):c?Bn.red("\u2717"):Bn.yellow("\u26A0");console.log(` ${u} ${Bn.bold(i)}`);for(let p of a.details)console.log(` ${Bn.dim(p)}`);for(let p of a.errors)console.log(` ${Bn.yellow("\u26A0")} ${p}`)}return console.log(""),t?f.done("Dry run complete \u2014 no changes made"):s?f.done("System updated"):f.warn(`Updated with ${n.length} error(s)`),{success:s,message:t?"Dry run complete":s?"System updated":"Updated with errors"}}formatMdOutput(e,t){let s=e.phase1.success&&e.phase2.success,n=[];n.push(t?"# Update (Dry Run)":"# System Update"),n.push("");let o=[{label:"Package Update",result:e.phase1,fatal:!0},{label:"Global Cleanup",result:e.phase2,fatal:!0},{label:"Daemon Restart",result:e.phase3,fatal:!1}];for(let{label:i,result:a,fatal:c}of o){let u=a.success?"\u2705":c?"\u274C":"\u26A0\uFE0F";n.push(`## ${u} ${i}`);for(let p of a.details)n.push(`- ${p}`);for(let p of a.errors)n.push(`- \u26A0\uFE0F ${p}`);n.push("")}return t||n.push(s?"**Status:** All phases completed successfully.":"**Status:** Completed with errors."),console.log(n.join(`
1394
- `)),{success:s,message:t?"Dry run complete":s?"System updated":"Updated with errors"}}async getAllProjectIds(){let e=Lr.join(A.getGlobalBasePath(),"projects");try{return(await ki.readdir(e,{withFileTypes:!0})).filter(s=>s.isDirectory()&&!s.name.startsWith(".")).map(s=>s.name)}catch{return[]}}};Mc();Tr();nc();V();Dn();lt();import Me from"chalk";var zn=class extends Ce{static{l(this,"VelocityCommands")}async velocity(e="0",t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let n=await I.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await this.loadVelocityConfig(t),i=await wt.getAll(n);if(i.length===0)return console.log(`
1395
- ${Me.dim("No velocity data yet.")}`),console.log(`${Me.dim("Complete tasks with estimates to build velocity history.")}
1396
- `),{success:!0,message:"No data"};let a=Uo(i,o);await jo.saveMetrics(n,a),console.log(`
1397
- ${Me.cyan("Sprint Velocity")} ${Me.dim(`(last ${o.windowSize??6} sprints)`)}`),console.log("\u2550".repeat(60));let c=a.sprints.slice(-(o.windowSize??6));for(let m of c){let d=m.estimationAccuracy>=80?Me.green:m.estimationAccuracy>=60?Me.yellow:Me.red;console.log(` Sprint ${String(m.sprintNumber).padStart(2)}: ${Me.bold(`${m.pointsCompleted} pts`)} | ${m.tasksCompleted} tasks | accuracy: ${d(`${m.estimationAccuracy}%`)}`)}console.log("");let u=a.velocityTrend==="improving"?Me.green("\u2191"):a.velocityTrend==="declining"?Me.red("\u2193"):Me.dim("\u2192");if(console.log(` Average: ${Me.bold(`${a.averageVelocity} pts/sprint`)} | Trend: ${u} ${a.velocityTrend}`),console.log(` Estimation accuracy: ${Me.bold(`${a.estimationAccuracy}%`)} ${Me.dim(`(\xB1${o.accuracyTolerance??20}% tolerance)`)}`),a.underEstimated.length>0||a.overEstimated.length>0){console.log(`
1398
- ${Me.dim("Patterns:")}`);for(let m of a.underEstimated)console.log(` ${Me.yellow("\u26A0")} ${m.category} tasks underestimated by avg ${Me.bold(`${m.avgVariance}%`)}`);for(let m of a.overEstimated)console.log(` ${Me.green("\u2713")} ${m.category} tasks estimated within ${Me.bold(`${m.avgVariance}%`)}`)}let p=parseInt(e,10);if(p>0&&a.averageVelocity>0){let m=gm(p,a.averageVelocity,o),d=m.estimatedDate?new Date(m.estimatedDate).toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}):"unknown";console.log(`
1399
- ${Me.dim("Projection:")}`),console.log(` Backlog: ${Me.bold(`${p} pts`)} remaining`),console.log(` At current velocity: ~${m.sprints} sprints (${m.sprints*(o.sprintLengthDays??7)} days)`),console.log(` Estimated completion: ${Me.bold(d)}`)}return console.log("\u2550".repeat(60)),console.log(""),{success:!0}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}async loadVelocityConfig(e){try{let s=await I.readConfig(e);if(s?.velocity&&typeof s.velocity=="object")return{...bs,...s.velocity}}catch{}return bs}};rl();import Sv from"node:fs/promises";import bv from"node:path";yr();oe();Dn();var nf=l(r=>aa.includes(r),"isValidPoint"),an=l(r=>ca[r],"pointsToMinutes"),sf=l(r=>{if(r<60)return`${r}m`;let e=Math.floor(r/60),t=r%60;return t>0?`${e}h ${t}m`:`${e}h`},"formatMinutes"),rf=l(r=>{let e=an(r);return`${sf(e.min)}\u2013${sf(e.max)}`},"pointsToTimeRange"),of=l(async(r,e)=>{let s=(await wt.getAll(r)).filter(a=>a.tags?.includes(e));if(s.length<3)return null;let o=s.reduce((a,c)=>a+ht(c.actualDuration),0)/s.length;return{points:gv(o),basedOn:s.length}},"suggestFromHistory"),gv=l(r=>{let e=1,t=Number.POSITIVE_INFINITY;for(let s of aa){let n=Math.abs(ca[s].typical-r);n<t&&(t=n,e=s)}return e},"findClosestPoint");ve();V();q();import Fl from"node:fs/promises";import fv from"node:os";import Si from"node:path";var Ul=class{static{l(this,"TemplateGenerator")}commandsPath;constructor(){this.commandsPath=Si.join(fv.homedir(),".claude","commands","p")}async generateWorkflowTemplate(e,t){try{await Fl.mkdir(this.commandsPath,{recursive:!0});let s=Si.join(this.commandsPath,`${e}.md`),n=this.buildTemplateContent(e,t);return await Fl.writeFile(s,n,"utf-8"),{success:!0,path:s}}catch(s){return{success:!1,error:y(s)}}}async deleteWorkflowTemplate(e){try{let t=Si.join(this.commandsPath,`${e}.md`);return await Fl.unlink(t),{success:!0}}catch(t){return R(t)?{success:!0}:{success:!1,error:y(t)}}}async templateExists(e){let t=Si.join(this.commandsPath,`${e}.md`);return C(t)}buildTemplateContent(e,t){return`---
1419
+ `}await vi.writeFile(a,y,"utf-8"),t.details.push("Gemini global config updated")}}catch{}}}catch{}}return t.errors.length>0&&(t.success=!1),t}async phaseDaemonRestart(e){let t={success:!0,details:[],errors:[]};if(e)return t.details.push("Would restart daemon"),t;try{let{isDaemonRunning:s,stopDaemon:n,forceKillDaemon:o,spawnDaemon:i}=await Promise.resolve().then(()=>(nf(),sf));await s()?(await n()||o(),await new Promise(u=>setTimeout(u,300)),t.details.push("Daemon stopped")):(o(),t.details.push("No running daemon (cleaned stale files)")),await i()?t.details.push("Daemon restarted"):t.details.push("Daemon will start automatically on next use")}catch(s){t.success=!1,t.errors.push(w(s))}return t}formatTerminalOutput(e,t){let s=e.phase1.success&&e.phase2.success,n=[...e.phase1.errors,...e.phase2.errors];console.log("");let o=[{label:"Package",result:e.phase1,fatal:!0},{label:"Cleanup",result:e.phase2,fatal:!0},{label:"Daemon",result:e.phase3,fatal:!1}];for(let{label:i,result:a,fatal:c}of o){let u=a.success?Bn.green("\u2713"):c?Bn.red("\u2717"):Bn.yellow("\u26A0");console.log(` ${u} ${Bn.bold(i)}`);for(let p of a.details)console.log(` ${Bn.dim(p)}`);for(let p of a.errors)console.log(` ${Bn.yellow("\u26A0")} ${p}`)}return console.log(""),t?f.done("Dry run complete \u2014 no changes made"):s?f.done("System updated"):f.warn(`Updated with ${n.length} error(s)`),{success:s,message:t?"Dry run complete":s?"System updated":"Updated with errors"}}formatMdOutput(e,t){let s=e.phase1.success&&e.phase2.success,n=[];n.push(t?"# Update (Dry Run)":"# System Update"),n.push("");let o=[{label:"Package Update",result:e.phase1,fatal:!0},{label:"Global Cleanup",result:e.phase2,fatal:!0},{label:"Daemon Restart",result:e.phase3,fatal:!1}];for(let{label:i,result:a,fatal:c}of o){let u=a.success?"OK":c?"FAILED":"WARNING";n.push(`## ${i} (${u})`);for(let p of a.details)n.push(`- ${p}`);for(let p of a.errors)n.push(`- WARNING: ${p}`);n.push("")}return t||n.push(s?"**Status:** All phases completed successfully.":"**Status:** Completed with errors."),console.log(n.join(`
1420
+ `)),{success:s,message:t?"Dry run complete":s?"System updated":"Updated with errors"}}async getAllProjectIds(){let e=Ur.join(A.getGlobalBasePath(),"projects");try{return(await vi.readdir(e,{withFileTypes:!0})).filter(s=>s.isDirectory()&&!s.name.startsWith(".")).map(s=>s.name)}catch{return[]}}};Oc();vr();oc();W();Dn();dt();import $e from"chalk";var Jn=class extends Ce{static{l(this,"VelocityCommands")}async velocity(e="0",t=process.cwd()){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let n=await $.getProjectId(t);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await this.loadVelocityConfig(t),i=await kt.getAll(n);if(i.length===0)return console.log(`
1421
+ ${$e.dim("No velocity data yet.")}`),console.log(`${$e.dim("Complete tasks with estimates to build velocity history.")}
1422
+ `),{success:!0,message:"No data"};let a=Vo(i,o);await _o.saveMetrics(n,a),console.log(`
1423
+ ${$e.cyan("Sprint Velocity")} ${$e.dim(`(last ${o.windowSize??6} sprints)`)}`),console.log("\u2550".repeat(60));let c=a.sprints.slice(-(o.windowSize??6));for(let m of c){let d=m.estimationAccuracy>=80?$e.green:m.estimationAccuracy>=60?$e.yellow:$e.red;console.log(` Sprint ${String(m.sprintNumber).padStart(2)}: ${$e.bold(`${m.pointsCompleted} pts`)} | ${m.tasksCompleted} tasks | accuracy: ${d(`${m.estimationAccuracy}%`)}`)}console.log("");let u=a.velocityTrend==="improving"?$e.green("\u2191"):a.velocityTrend==="declining"?$e.red("\u2193"):$e.dim("\u2192");if(console.log(` Average: ${$e.bold(`${a.averageVelocity} pts/sprint`)} | Trend: ${u} ${a.velocityTrend}`),console.log(` Estimation accuracy: ${$e.bold(`${a.estimationAccuracy}%`)} ${$e.dim(`(\xB1${o.accuracyTolerance??20}% tolerance)`)}`),a.underEstimated.length>0||a.overEstimated.length>0){console.log(`
1424
+ ${$e.dim("Patterns:")}`);for(let m of a.underEstimated)console.log(` ${$e.yellow("\u26A0")} ${m.category} tasks underestimated by avg ${$e.bold(`${m.avgVariance}%`)}`);for(let m of a.overEstimated)console.log(` ${$e.green("\u2713")} ${m.category} tasks estimated within ${$e.bold(`${m.avgVariance}%`)}`)}let p=parseInt(e,10);if(p>0&&a.averageVelocity>0){let m=ym(p,a.averageVelocity,o),d=m.estimatedDate?new Date(m.estimatedDate).toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}):"unknown";console.log(`
1425
+ ${$e.dim("Projection:")}`),console.log(` Backlog: ${$e.bold(`${p} pts`)} remaining`),console.log(` At current velocity: ~${m.sprints} sprints (${m.sprints*(o.sprintLengthDays??7)} days)`),console.log(` Estimated completion: ${$e.bold(d)}`)}return console.log("\u2550".repeat(60)),console.log(""),{success:!0}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}async loadVelocityConfig(e){try{let s=await $.readConfig(e);if(s?.velocity&&typeof s.velocity=="object")return{...bs,...s.velocity}}catch{}return bs}};il();import vT from"node:fs/promises";import CT from"node:path";yr();ie();Dn();var cf=l(r=>la.includes(r),"isValidPoint"),cn=l(r=>ua[r],"pointsToMinutes"),af=l(r=>{if(r<60)return`${r}m`;let e=Math.floor(r/60),t=r%60;return t>0?`${e}h ${t}m`:`${e}h`},"formatMinutes"),lf=l(r=>{let e=cn(r);return`${af(e.min)}\u2013${af(e.max)}`},"pointsToTimeRange"),uf=l(async(r,e)=>{let s=(await kt.getAll(r)).filter(a=>a.tags?.includes(e));if(s.length<3)return null;let o=s.reduce((a,c)=>a+yt(c.actualDuration),0)/s.length;return{points:yT(o),basedOn:s.length}},"suggestFromHistory"),yT=l(r=>{let e=1,t=Number.POSITIVE_INFINITY;for(let s of la){let n=Math.abs(ua[s].typical-r);n<t&&(t=n,e=s)}return e},"findClosestPoint");Te();W();K();import Gl from"node:fs/promises";import wT from"node:os";import Ci from"node:path";var Wl=class{static{l(this,"TemplateGenerator")}commandsPath;constructor(){this.commandsPath=Ci.join(wT.homedir(),".claude","commands","p")}async generateWorkflowTemplate(e,t){try{await Gl.mkdir(this.commandsPath,{recursive:!0});let s=Ci.join(this.commandsPath,`${e}.md`),n=this.buildTemplateContent(e,t);return await Gl.writeFile(s,n,"utf-8"),{success:!0,path:s}}catch(s){return{success:!1,error:w(s)}}}async deleteWorkflowTemplate(e){try{let t=Ci.join(this.commandsPath,`${e}.md`);return await Gl.unlink(t),{success:!0}}catch(t){return R(t)?{success:!0}:{success:!1,error:w(t)}}}async templateExists(e){let t=Ci.join(this.commandsPath,`${e}.md`);return P(t)}buildTemplateContent(e,t){return`---
1400
1426
  allowed-tools: [Bash, Read, Write, Edit, Glob, Grep, Task, AskUserQuestion]
1401
1427
  ---
1402
1428
 
@@ -1432,47 +1458,46 @@ Suggest relevant actions based on the workflow results:
1432
1458
  - View rules: \`prjct workflow ${e} --md\`
1433
1459
  - Add rules: \`prjct workflow add "command" before ${e} --md\`
1434
1460
  - Run again: \`p. ${e}\`
1435
- `}},Hl=new Ul;It();br();dl();function hv(r){switch(r){case"low":return 2;case"medium":return 5;case"high":return 8}}l(hv,"complexityToPoints");async function yv(r,e){let t=In.detectTaskType(e),s=await of(r,t);if(s){let a=an(s.points);return{taskType:t,estimatedPoints:s.points,estimatedMinutes:a.typical,source:"history"}}let n=In.estimateComplexity(e),o=hv(n.level),i=an(o);return{taskType:t,estimatedPoints:o,estimatedMinutes:i.typical,source:"heuristic"}}l(yv,"estimateTaskForStart");var Gl=yv;Ue();async function bi(r){try{let{stdout:e}=await N("git branch --show-current",{cwd:r});return e.trim()||void 0}catch{return}}l(bi,"getGitBranch");async function af(r,e=20){try{let{stdout:t}=await N("git diff --name-only HEAD 2>/dev/null || git diff --name-only 2>/dev/null",{cwd:r});return t.trim().split(`
1436
- `).filter(s=>s.length>0).slice(0,e)}catch{return[]}}l(af,"getModifiedFiles");ve();ce();oe();var qn="session-snapshot",wv=30,Vl=class{static{l(this,"SessionSnapshotManager")}async capture(e,t,s){let n=await bi(t),o=await af(t),i=s.startedAt?Math.round((Date.now()-new Date(s.startedAt).getTime())/1e3):void 0,a=t.split("/").pop()||t,c=this.generateResumeHint(s,i),u={sessionId:s.sessionId,projectId:e,projectPath:t,projectName:a,taskDescription:s.taskDescription,taskStatus:s.taskStatus,activeSubtaskIndex:s.activeSubtaskIndex,subtaskCount:s.subtaskCount,branch:n,linearId:s.linearId,filesModified:o,durationWorkedSec:i,timestamp:v(),resumeHint:c};return P.setDoc(e,qn,u),u}getSnapshot(e){try{return P.getDoc(e,qn)}catch{return null}}clearSnapshot(e){try{P.deleteDoc(e,qn)}catch{}}async listAllSnapshots(){let e=await A.listProjects(),t=[];for(let s of e)try{if(!P.exists(s))continue;let n=P.getDoc(s,qn);n&&t.push(n)}catch{}return t.sort((s,n)=>new Date(n.timestamp).getTime()-new Date(s.timestamp).getTime()),t}async cleanup(e=wv){let t=await A.listProjects(),s=Date.now()-e*24*60*60*1e3,n=0;for(let o of t)try{if(!P.exists(o))continue;let i=P.getDoc(o,qn);i&&new Date(i.timestamp).getTime()<s&&(P.deleteDoc(o,qn),n++)}catch{}return n}formatContinuityContext(e){let s=["Session Continuity",`- Last session: ${ft(Date.now()-new Date(e.timestamp).getTime())} ago`,`- Task: ${e.taskDescription}`,`- Status: ${e.taskStatus}`];if(e.subtaskCount&&e.activeSubtaskIndex!==void 0&&s.push(`- Progress: subtask ${e.activeSubtaskIndex+1}/${e.subtaskCount}`),e.branch&&s.push(`- Branch: ${e.branch}`),e.filesModified&&e.filesModified.length>0){let n=e.filesModified.slice(0,5).join(", "),o=e.filesModified.length>5?` (+${e.filesModified.length-5} more)`:"";s.push(`- Modified files: ${n}${o}`)}return e.durationWorkedSec&&s.push(`- Time worked: ${ft(e.durationWorkedSec*1e3)}`),s.push(`- Resume hint: ${e.resumeHint}`),s.join(`
1437
- `)}generateResumeHint(e,t){let s=[];return e.taskStatus==="paused"?s.push("Task was paused"):s.push("Task was in progress"),e.subtaskCount&&e.activeSubtaskIndex!==void 0&&s.push(`on subtask ${e.activeSubtaskIndex+1} of ${e.subtaskCount}`),t&&t>60&&s.push(`after ${ft(t*1e3)} of work`),s.join(" ")}},Rs=new Vl;wn();ce();var Wl=class{static{l(this,"ContextFeedbackStorage")}recordSuggestions(e,t,s,n){P.run(e,`INSERT INTO context_feedback (task_id, keywords, suggested_files, created_at)
1438
- VALUES (?, ?, ?, ?)`,t,JSON.stringify(s),JSON.stringify(n),new Date().toISOString())}completeFeedback(e,t,s){let n=P.get(e,"SELECT * FROM context_feedback WHERE task_id = ? ORDER BY id DESC LIMIT 1",t);if(!n)return;let o=new Set(JSON.parse(n.suggested_files)),i=new Set(s),a=[...o].filter(p=>i.has(p)).length,c=o.size>0?a/o.size:0,u=i.size>0?a/i.size:0;P.run(e,`UPDATE context_feedback
1461
+ `}},Vl=new Wl;It();br();ml();function kT(r){switch(r){case"low":return 2;case"medium":return 5;case"high":return 8}}l(kT,"complexityToPoints");async function ST(r,e){let t=In.detectTaskType(e),s=await uf(r,t);if(s){let a=cn(s.points);return{taskType:t,estimatedPoints:s.points,estimatedMinutes:a.typical,source:"history"}}let n=In.estimateComplexity(e),o=kT(n.level),i=cn(o);return{taskType:t,estimatedPoints:o,estimatedMinutes:i.typical,source:"heuristic"}}l(ST,"estimateTaskForStart");var Bl=ST;He();async function Pi(r){try{let{stdout:e}=await O("git branch --show-current",{cwd:r});return e.trim()||void 0}catch{return}}l(Pi,"getGitBranch");async function df(r,e=20){try{let{stdout:t}=await O("git diff --name-only HEAD 2>/dev/null || git diff --name-only 2>/dev/null",{cwd:r});return t.trim().split(`
1462
+ `).filter(s=>s.length>0).slice(0,e)}catch{return[]}}l(df,"getModifiedFiles");Te();re();ie();var qn="session-snapshot",bT=30,zl=class{static{l(this,"SessionSnapshotManager")}async capture(e,t,s){let n=await Pi(t),o=await df(t),i=s.startedAt?Math.round((Date.now()-new Date(s.startedAt).getTime())/1e3):void 0,a=t.split("/").pop()||t,c=this.generateResumeHint(s,i),u={sessionId:s.sessionId,projectId:e,projectPath:t,projectName:a,taskDescription:s.taskDescription,taskStatus:s.taskStatus,activeSubtaskIndex:s.activeSubtaskIndex,subtaskCount:s.subtaskCount,branch:n,linearId:s.linearId,filesModified:o,durationWorkedSec:i,timestamp:T(),resumeHint:c};return C.setDoc(e,qn,u),u}getSnapshot(e){try{return C.getDoc(e,qn)}catch{return null}}clearSnapshot(e){try{C.deleteDoc(e,qn)}catch{}}async listAllSnapshots(){let e=await A.listProjects(),t=[];for(let s of e)try{if(!C.exists(s))continue;let n=C.getDoc(s,qn);n&&t.push(n)}catch{}return t.sort((s,n)=>new Date(n.timestamp).getTime()-new Date(s.timestamp).getTime()),t}async cleanup(e=bT){let t=await A.listProjects(),s=Date.now()-e*24*60*60*1e3,n=0;for(let o of t)try{if(!C.exists(o))continue;let i=C.getDoc(o,qn);i&&new Date(i.timestamp).getTime()<s&&(C.deleteDoc(o,qn),n++)}catch{}return n}formatContinuityContext(e){let s=["Session Continuity",`- Last session: ${ht(Date.now()-new Date(e.timestamp).getTime())} ago`,`- Task: ${e.taskDescription}`,`- Status: ${e.taskStatus}`];if(e.subtaskCount&&e.activeSubtaskIndex!==void 0&&s.push(`- Progress: subtask ${e.activeSubtaskIndex+1}/${e.subtaskCount}`),e.branch&&s.push(`- Branch: ${e.branch}`),e.filesModified&&e.filesModified.length>0){let n=e.filesModified.slice(0,5).join(", "),o=e.filesModified.length>5?` (+${e.filesModified.length-5} more)`:"";s.push(`- Modified files: ${n}${o}`)}return e.durationWorkedSec&&s.push(`- Time worked: ${ht(e.durationWorkedSec*1e3)}`),s.push(`- Resume hint: ${e.resumeHint}`),s.join(`
1463
+ `)}generateResumeHint(e,t){let s=[];return e.taskStatus==="paused"?s.push("Task was paused"):s.push("Task was in progress"),e.subtaskCount&&e.activeSubtaskIndex!==void 0&&s.push(`on subtask ${e.activeSubtaskIndex+1} of ${e.subtaskCount}`),t&&t>60&&s.push(`after ${ht(t*1e3)} of work`),s.join(" ")}},Rs=new zl;kn();re();var Jl=class{static{l(this,"ContextFeedbackStorage")}recordSuggestions(e,t,s,n){C.run(e,`INSERT INTO context_feedback (task_id, keywords, suggested_files, created_at)
1464
+ VALUES (?, ?, ?, ?)`,t,JSON.stringify(s),JSON.stringify(n),new Date().toISOString())}completeFeedback(e,t,s){let n=C.get(e,"SELECT * FROM context_feedback WHERE task_id = ? ORDER BY id DESC LIMIT 1",t);if(!n)return;let o=new Set(JSON.parse(n.suggested_files)),i=new Set(s),a=[...o].filter(p=>i.has(p)).length,c=o.size>0?a/o.size:0,u=i.size>0?a/i.size:0;C.run(e,`UPDATE context_feedback
1439
1465
  SET actual_files = ?, precision = ?, recall = ?, completed_at = ?
1440
- WHERE id = ?`,JSON.stringify(s),c,u,new Date().toISOString(),n.id)}getFeedback(e,t){let s=P.get(e,"SELECT precision, recall FROM context_feedback WHERE task_id = ? ORDER BY id DESC LIMIT 1",t);return s?{precision:s.precision,recall:s.recall}:null}getHistoricalBoosts(e,t){let s=new Map;if(t.length===0)return s;let n=P.query(e,`SELECT * FROM context_feedback
1466
+ WHERE id = ?`,JSON.stringify(s),c,u,new Date().toISOString(),n.id)}getFeedback(e,t){let s=C.get(e,"SELECT precision, recall FROM context_feedback WHERE task_id = ? ORDER BY id DESC LIMIT 1",t);return s?{precision:s.precision,recall:s.recall}:null}getHistoricalBoosts(e,t){let s=new Map;if(t.length===0)return s;let n=C.query(e,`SELECT * FROM context_feedback
1441
1467
  WHERE actual_files IS NOT NULL
1442
- ORDER BY id DESC LIMIT 50`);if(n.length===0)return s;let o=new Set(t),i=new Map;for(let c of n){let u=JSON.parse(c.keywords),p=new Set(u),m=[...o].filter(w=>p.has(w)).length,d=new Set([...o,...p]).size,g=d>0?m/d:0;if(g===0)continue;let h=new Set(JSON.parse(c.suggested_files)),k=new Set(JSON.parse(c.actual_files));for(let w of k){let T=i.get(w)??0;i.set(w,T+g)}for(let w of h)if(!k.has(w)){let T=i.get(w)??0;i.set(w,T-g*.5)}}if(i.size===0)return s;let a=Math.max(...[...i.values()].map(Math.abs),1);for(let[c,u]of i)s.set(c,u/a);return s}},Ur=new Wl;ml();Xt();Pt();ri();Go();V();Pn();En();hl();Dn();lt();ve();V();oe();yn();ce();import vi from"node:fs/promises";import cf from"node:path";var Kn="1.0.0";function kv(){return{version:Kn,lastUpdated:"",checksums:{}}}l(kv,"getDefaultChecksums");var Bl=class{static{l(this,"IndexStorage")}getIndexPath(e){return cf.join(A.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await vi.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==Kn?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 kv()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await vi.readFile(e);return Ju(t)}catch{return""}}async detectChangedFiles(e,t){let n=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[c,u]of t)c in n?n[c]!==u&&i.push(c):o.push(c);for(let c of Object.keys(n))t.has(c)||a.push(c);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:Kn,lastUpdated:v(),scores:t};this.setIndexMeta(e,"file-scores",s)}async clearIndex(e){try{P.getDb(e).prepare("DELETE FROM index_meta").run()}catch{}let t=this.getIndexPath(e);try{let s=await vi.readdir(t);await Promise.all(s.map(n=>vi.unlink(cf.join(t,n))))}catch(s){if(!R(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!==Kn?null:t}catch{}return null}readDomainsSync(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null&&t.version===Kn)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!==Kn?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),n=new Map;if(!s)return n;let o=new Set(t);for(let i of s.fileCategories)o.has(i.path)&&n.set(i.path,i.categories);return n}async getFilesByDomain(e,t){let s=await this.readCategories(e);return s?s.domainIndex[t]||[]:[]}getIndexMeta(e,t){let n=P.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return n?JSON.parse(n.data):null}setIndexMeta(e,t,s){let n=P.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();n.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},lf=new Bl;function Ti(r,e,t,s){if(r.length===0)return[];let n=new Set((e?.frameworks||[]).map(a=>a.toLowerCase())),o=new Set((e?.languages||[]).map(a=>a.toLowerCase())),i=r.map(a=>{let c=0;return a.source==="repo"?c+=100:a.source==="context7"?c+=60:a.source==="feedback"?c+=50:a.source==="baseline"&&(c+=10),a.framework&&n.has(a.framework.toLowerCase())&&(c+=40),a.language&&o.has(a.language.toLowerCase())&&(c+=20),typeof a.confidence=="number"&&(c+=Math.round(a.confidence*30)),a.location&&t.length>0&&a.location.toLowerCase().replace(/\*+/g,"").split(/[/,\s]+/).filter(Boolean).some(p=>t.some(m=>m.toLowerCase().includes(p)))&&(c+=25),{pattern:a,score:c}});return i.sort((a,c)=>c.score-a.score),i.slice(0,s).map(a=>a.pattern)}l(Ti,"rankPatterns");function uf(r){let e=new Set;return r.filter(t=>{let s=t.toLowerCase().replace(/[`*_()]/g,"").trim();return e.has(s)?!1:(e.add(s),!0)})}l(uf,"deduplicateDecisions");function df(r,e){let t=r.toLowerCase(),s=new Set;if(e)try{let n=lf.readDomainsSync(e);if(n?.domains)for(let o of n.domains){if(t.includes(o.name.toLowerCase())){s.add(o.name);continue}for(let i of o.keywords)if(t.includes(i.toLowerCase())){s.add(o.name);break}}}catch{}return s.size>0?[...s]:["general"]}l(df,"detectDomainsFromTask");function Jl(r,e){if(!r)return null;let t=r.patterns,s=r.antiPatterns;if(!Array.isArray(t)||t.length===0)return null;let n=Ti(t,r,e,5),o=new Set;return`### Pattern Briefing (for this task)
1468
+ ORDER BY id DESC LIMIT 50`);if(n.length===0)return s;let o=new Set(t),i=new Map;for(let c of n){let u=JSON.parse(c.keywords),p=new Set(u),m=[...o].filter(y=>p.has(y)).length,d=new Set([...o,...p]).size,g=d>0?m/d:0;if(g===0)continue;let h=new Set(JSON.parse(c.suggested_files)),k=new Set(JSON.parse(c.actual_files));for(let y of k){let v=i.get(y)??0;i.set(y,v+g)}for(let y of h)if(!k.has(y)){let v=i.get(y)??0;i.set(y,v-g*.5)}}if(i.size===0)return s;let a=Math.max(...[...i.values()].map(Math.abs),1);for(let[c,u]of i)s.set(c,u/a);return s}},Gr=new Jl;fl();Xt();Pt();ci();zo();W();Ks();En();wl();Dn();dt();Te();W();ie();wn();re();import Ei from"node:fs/promises";import pf from"node:path";var Kn="1.0.0";function TT(){return{version:Kn,lastUpdated:"",checksums:{}}}l(TT,"getDefaultChecksums");var ql=class{static{l(this,"IndexStorage")}getIndexPath(e){return pf.join(A.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await Ei.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==Kn?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 TT()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await Ei.readFile(e);return Ku(t)}catch{return""}}async detectChangedFiles(e,t){let n=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[c,u]of t)c in n?n[c]!==u&&i.push(c):o.push(c);for(let c of Object.keys(n))t.has(c)||a.push(c);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:Kn,lastUpdated:T(),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 Ei.readdir(t);await Promise.all(s.map(n=>Ei.unlink(pf.join(t,n))))}catch(s){if(!R(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!==Kn?null:t}catch{}return null}readDomainsSync(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null&&t.version===Kn)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!==Kn?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),n=new Map;if(!s)return n;let o=new Set(t);for(let i of s.fileCategories)o.has(i.path)&&n.set(i.path,i.categories);return n}async getFilesByDomain(e,t){let s=await this.readCategories(e);return s?s.domainIndex[t]||[]:[]}getIndexMeta(e,t){let n=C.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return n?JSON.parse(n.data):null}setIndexMeta(e,t,s){let n=C.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();n.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},mf=new ql;function gf(r,e,t,s){if(r.length===0)return[];let n=new Set((e?.frameworks||[]).map(a=>a.toLowerCase())),o=new Set((e?.languages||[]).map(a=>a.toLowerCase())),i=r.map(a=>{let c=0;return a.source==="repo"?c+=100:a.source==="context7"?c+=60:a.source==="feedback"?c+=50:a.source==="baseline"&&(c+=10),a.framework&&n.has(a.framework.toLowerCase())&&(c+=40),a.language&&o.has(a.language.toLowerCase())&&(c+=20),typeof a.confidence=="number"&&(c+=Math.round(a.confidence*30)),a.location&&t.length>0&&a.location.toLowerCase().replace(/\*+/g,"").split(/[/,\s]+/).filter(Boolean).some(p=>t.some(m=>m.toLowerCase().includes(p)))&&(c+=25),{pattern:a,score:c}});return i.sort((a,c)=>c.score-a.score),i.slice(0,s).map(a=>a.pattern)}l(gf,"rankPatterns");function ff(r,e){let t=r.toLowerCase(),s=new Set;if(e)try{let n=mf.readDomainsSync(e);if(n?.domains)for(let o of n.domains){if(t.includes(o.name.toLowerCase())){s.add(o.name);continue}for(let i of o.keywords)if(t.includes(i.toLowerCase())){s.add(o.name);break}}}catch{}return s.size>0?[...s]:["general"]}l(ff,"detectDomainsFromTask");function Kl(r,e){if(!r)return null;let t=r.patterns,s=r.antiPatterns;if(!Array.isArray(t)||t.length===0)return null;let n=gf(t,r,e,5),o=new Set;return`### Pattern Briefing (for this task)
1443
1469
 
1444
- ${n.map((a,c)=>{let u=a.source?` [${a.source}]`:"",p=a.location?` (\`${a.location}\`)`:"",m=a.name.toLowerCase().split(/[\s\-_/]+/).filter(h=>h.length>2),d;if(Array.isArray(s))for(let h=0;h<s.length;h++){if(o.has(h))continue;let k=`${s[h].issue} ${s[h].suggestion}`.toLowerCase();if(m.some(w=>k.includes(w))){d=s[h],o.add(h);break}}let g=[`**${c+1}. ${a.name}**${u}`,` ${a.description}${p}`];return d&&g.push(` - VIOLATION: ${d.issue} \u2014 ${d.suggestion}`),g.join(`
1470
+ ${n.map((a,c)=>{let u=a.source?` [${a.source}]`:"",p=a.location?` (\`${a.location}\`)`:"",m=a.name.toLowerCase().split(/[\s\-_/]+/).filter(h=>h.length>2),d;if(Array.isArray(s))for(let h=0;h<s.length;h++){if(o.has(h))continue;let k=`${s[h].issue} ${s[h].suggestion}`.toLowerCase();if(m.some(y=>k.includes(y))){d=s[h],o.add(h);break}}let g=[`**${c+1}. ${a.name}**${u}`,` ${a.description}${p}`];return d&&g.push(` - VIOLATION: ${d.issue} \u2014 ${d.suggestion}`),g.join(`
1445
1471
  `)}).join(`
1446
1472
 
1447
- `)}`}l(Jl,"buildPatternBriefing");function zl(r,e,t,s,n,o){let i=e.map(E=>E.path),a=e.slice(0,6).map(E=>`\`${E.path}\``),c=["### Context Contract",`- **Goal**: ${r}`];s&&c.push(`- **Scope**: ${s.taskType} \xB7 ~${s.estimatedPoints}pts \xB7 ~${s.estimatedMinutes}min (${s.source})`),n&&n.length>0&&c.push(`- **Domains**: ${n.join(", ")}`),c.push(`- **Key files**: ${a.length>0?a.join(", "):"Run `prjct sync` to improve file targeting"}`);let p=["All commits include footer: `Generated with [p/](https://www.prjct.app/)`","Never commit directly to main/master"],m=o?.rules;if(Array.isArray(m))for(let E of m)typeof E=="string"&&p.push(E);let d=t?.antiPatterns||[];if(Array.isArray(d)){let E=d.filter(M=>M.severity==="high");for(let M of E.slice(0,3))p.push(M.suggestion)}let g=t?.patterns||[],h=new Set;if(Array.isArray(g)){let E=Ti(g.filter(M=>M.source==="repo"),t,i,3);for(let M of E){let L=M.location?` (\`${M.location}\`)`:"";p.push(`${M.description}${L}`),h.add(M.name)}}let k=uf(p);c.push(""),c.push("#### Locked Decisions (NON-NEGOTIABLE)");for(let E of k)c.push(`- ${E}`);let w=Array.isArray(g)?g.filter(E=>!h.has(E.name)):[],T=w.length>0?Ti(w,t,i||[],3):[];return T.length>0&&(c.push(""),c.push("#### Task Patterns (MUST follow)"),T.forEach((E,M)=>{let L=E.location?` (\`${E.location}\`)`:"";c.push(`${M+1}. **${E.name}** \u2014 ${E.description}${L}`)})),c.join(`
1448
- `)}l(zl,"buildContextContract");var vv=[{type:"help",patterns:/^(?:help|ayuda|c[oó]mo|how)\b/i},{type:"add",patterns:/^add\b/i},{type:"gate",patterns:/^gate\b/i},{type:"instruction",patterns:/^instruction\b/i},{type:"remove",patterns:/^rm\b/i},{type:"reset",patterns:/^reset\b/i},{type:"init",patterns:/^init\b/i},{type:"create",patterns:/^(?:create|crear|new|nuevo)\b/i},{type:"list",patterns:/^(?:list|listar|show all|mostrar todos)\b/i},{type:"delete",patterns:/^(?:delete|borrar|remove workflow)\b/i},{type:"run",patterns:/^run\b/i},{type:"view",patterns:/^(?:muestra|show|ver|display|mostrar)\b/i},{type:"add",patterns:/^(?:a[nñ]ade|agrega|pon|nueva?)\b/i},{type:"remove",patterns:/^(?:quita|remove|elimina|borra|borrar)\b/i},{type:"disable",patterns:/^(?:deshabilita|disable|no\s+corras|apaga|turn\s+off|desactiva)\b/i},{type:"gate",patterns:/^(?:bloquea|block|protect|protege)\b/i}],Xn=class extends Ce{static{l(this,"WorkflowCommands")}async now(e=null,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.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"};if(e){let i=await Wt(o,"task","before",{projectPath:t,skipRules:s.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a,c=e;if(/^[A-Z]+-\d+$/.test(e)&&(a=e),s.md){try{await ls.ensureReady()}catch(Fe){return Rt("blocked","context7_not_ready",[{label:"Fix Context7 now",command:"prjct start"},{label:"Retry task after fix",command:`prjct task "${c}" --md`},{label:"Cancel"}],{error:y(Fe)}),{success:!1,error:y(Fe)}}let d=await Gl(o,c),g=await _.getCurrentTask(o);if(g)return Rt("blocked","task_already_active",[{label:"Complete current task first",command:"prjct done --md"},{label:"Pause current and start this one",command:"prjct pause --md"},{label:"Cancel"}],{current_task:g.description,requested_task:c}),{success:!0,message:"Task already active",currentTask:g};await _.startTask(o,{id:ye(),description:c,sessionId:ye(),linearId:a,type:d.taskType,estimatedPoints:d.estimatedPoints,estimatedMinutes:d.estimatedMinutes});let h=A.getGlobalProjectPath(o),k=Oc(c),w;try{w=Ur.getHistoricalBoosts(o,k),w.size===0&&(w=void 0)}catch{}let E=({bug:30,chore:40,improvement:80,feature:100}[d.taskType]??80)>=80?15:10,[M,L,$,D]=await Promise.all([bi(t),qe.getActive(o).catch(()=>null),Tv(h),An(c,t,{maxFiles:E,minScore:.15,historicalBoosts:w}).catch(()=>({files:[],metrics:{filesScanned:0,filesReturned:0,scanDuration:0}}))]),O=null;try{let Fe=Rs.getSnapshot(o);Fe&&(O=Rs.formatContinuityContext(Fe),Rs.clearSnapshot(o))}catch{}let ne=null;if(L?.analyzedAt){let Fe=new Date(L.analyzedAt),Ot=Math.floor((Date.now()-Fe.getTime())/(1e3*60*60*24));Ot>7&&(ne=bc("warn",`Analysis is ${Ot} days old. Run \`p. sync\` to refresh patterns and file index.`))}else L||(ne=bc("info","No project analysis found. Run `p. sync` for better context targeting."));let rt=null;if(w&&w.size>0){let Fe=[...w.entries()].filter(([,Ot])=>Ot>.3).sort((Ot,rr)=>rr[1]-Ot[1]).slice(0,5);Fe.length>0&&(rt=`### Previously Useful Files
1449
- ${Fe.map(([rr])=>`\`${rr}\``).join(", ")}`)}let K=df(c,o),dt=vc({description:c,branch:M,linearId:a,type:d.taskType,estimatedPoints:d.estimatedPoints,estimatedMinutes:d.estimatedMinutes,estimateSource:d.source,domains:K}),ms=Cv(L,$),nr=Fp(D.files.map(Fe=>({path:Fe.path,description:Fe.reasons.join(", ")}))),Ai=D.files.map(Fe=>Fe.path),Di=Jl(L,Ai),ji=zl(c,D.files,L,d,K,$),Ii=ge([{label:"Find relevant files",command:`prjct context files "${e}"`},{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(U(O,ne,dt,ji,ms,nr,rt,Di,Ii));try{let Fe=await _.getCurrentTask(o);Fe&&Ur.recordSuggestions(o,Fe.id,k,D.files.map(Ot=>Ot.path))}catch{}return await this.logToMemory(t,"task_started",{task:e,timestamp:z.getTimestamp()}),await Wt(o,"task","after",{projectPath:t,skipRules:s.skipHooks}),{success:!0,task:e,taskDescription:c}}let p=await Zo.execute("task",{task:e},t);if(!p.success)return f.fail(p.error||"Failed to execute task"),{success:!1,error:p.error};let m=await Gl(o,c);return await _.startTask(o,{id:ye(),description:c,sessionId:ye(),linearId:a,type:m.taskType,estimatedPoints:m.estimatedPoints,estimatedMinutes:m.estimatedMinutes}),f.done(`${e}`),Ar("working"),At("task"),await this.logToMemory(t,"task_started",{task:e,orchestratorContext:p.orchestratorContext,timestamp:z.getTimestamp()}),await Wt(o,"task","after",{projectPath:t,skipRules:s.skipHooks}),{...p,success:!0,task:e,fibonacci:{isValidPoint:nf,pointsToMinutes:an,pointsToTimeRange:rf,storeEstimate:l(async d=>{let g=an(d);return await _.updateCurrentTask(o,{estimatedPoints:d,estimatedMinutes:g.typical}),g},"storeEstimate")}}}else{let i=await _.getCurrentTask(o);if(!i)return s.md?Rt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):f.warn("no active task"),{success:!0,message:"No active task"};if(s.md){let a=i.startedAt?z.calculateDuration(new Date(i.startedAt)):void 0,c=vc({description:i.description,status:"active",branch:i.branch,linearId:i.linearId,type:i.type,duration:a}),u=i.subtasks||[],p=i.currentSubtaskIndex,m=u.length>0?Lp(u,p):"",d=ge([{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(U(c,m,d))}else f.done(`working on: ${i.description}`);return{success:!0,task:i.description,currentTask:i}}}catch(n){let o=y(n);return s.md?o.includes("Cannot run")||o.includes("working state")?Rt("blocked","state_conflict",[{label:"Complete current task",command:"prjct done --md"},{label:"Pause current task",command:"prjct pause --md"}],{error:o.split(".")[0]}):console.log(JSON.stringify({status:"error",error:o})):f.fail(o),{success:!1,error:o}}}async done(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await _.getCurrentTask(n);if(!o)return t.md?Rt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):f.warn("no active task"),{success:!0,message:"No active task to complete"};let i=await Wt(n,"done","before",{projectPath:e,skipRules:t.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a=o.description,c="",u=0;if(o.startedAt){let L=new Date(o.startedAt);c=z.calculateDuration(L),u=Math.round((Date.now()-L.getTime())/6e4)}let p=o.estimatedMinutes,m=o.estimatedPoints,d=o.type||"feature",g=o.linearId;try{await wt.record(n,{sessionId:o.sessionId,command:"done",task:a,startedAt:o.startedAt,completedAt:z.getTimestamp(),estimatedDuration:p?pf(p):"0m",actualDuration:c||"0m",variance:p?xv(u-p):"+0m",completedAsPlanned:!0,qualityScore:3,tags:[d,g].filter(Boolean)})}catch{}let h="";if(m&&p){let L=u-p,$=p>0?Math.round((u-p)/p*100):0,D=L>=0?"+":"";h=` | est: ${m}pt (${pf(p)}) \u2192 ${D}${$}%`}let k=[],w=null,T=null;try{if(k=await Ev(e,o.startedAt),k.length>0){Ur.completeFeedback(n,o.id,k);let L=Ur.getFeedback(n,o.id);L&&(w=L.precision,T=L.recall)}}catch{}await _.completeTask(n,t.feedback);try{Rs.clearSnapshot(n)}catch{}let E=o.linearId,M=E!=null?await _r("linear",ds()).catch(()=>!1):!1;if(t.md){let L=c?` (${c})`:"",$=null;if(k.length>0){let O=k.slice(0,20).map(ne=>`\`${ne}\``);$=`### Files Modified (${k.length})
1450
- ${O.join(", ")}`}let D=null;if(w!==null&&T!==null){let O=Math.round(w*100),ne=Math.round(T*100);D=`### Context Accuracy
1473
+ `)}`}l(Kl,"buildPatternBriefing");function Xl(r,e){let t=r.slice(0,6).map(i=>`\`${i.path}\``),n=["### Context Contract",`- **Key files**: ${t.length>0?t.join(", "):"Run `prjct sync` to improve file targeting"}`],o=e?.antiPatterns||[];if(Array.isArray(o)){let i=o.filter(a=>a.severity==="high");if(i.length>0){n.push(""),n.push("#### Avoid (high-severity)");for(let a of i.slice(0,3))n.push(`- ${a.suggestion}`)}}return n.join(`
1474
+ `)}l(Xl,"buildContextContract");var PT=[{type:"help",patterns:/^(?:help|ayuda|c[oó]mo|how)\b/i},{type:"add",patterns:/^add\b/i},{type:"gate",patterns:/^gate\b/i},{type:"instruction",patterns:/^instruction\b/i},{type:"remove",patterns:/^rm\b/i},{type:"reset",patterns:/^reset\b/i},{type:"init",patterns:/^init\b/i},{type:"create",patterns:/^(?:create|crear|new|nuevo)\b/i},{type:"list",patterns:/^(?:list|listar|show all|mostrar todos)\b/i},{type:"delete",patterns:/^(?:delete|borrar|remove workflow)\b/i},{type:"run",patterns:/^run\b/i},{type:"view",patterns:/^(?:muestra|show|ver|display|mostrar)\b/i},{type:"add",patterns:/^(?:a[nñ]ade|agrega|pon|nueva?)\b/i},{type:"remove",patterns:/^(?:quita|remove|elimina|borra|borrar)\b/i},{type:"disable",patterns:/^(?:deshabilita|disable|no\s+corras|apaga|turn\s+off|desactiva)\b/i},{type:"gate",patterns:/^(?:bloquea|block|protect|protege)\b/i}],Xn=class extends Ce{static{l(this,"WorkflowCommands")}async now(e=null,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.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"};if(e){let i=await zt(o,"task","before",{projectPath:t,skipRules:s.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a,c=e;if(/^[A-Z]+-\d+$/.test(e)&&(a=e),s.md){try{await ls.ensureReady()}catch(Ue){return Rt("blocked","context7_not_ready",[{label:"Fix Context7 now",command:"prjct start"},{label:"Retry task after fix",command:`prjct task "${c}" --md`},{label:"Cancel"}],{error:w(Ue)}),{success:!1,error:w(Ue)}}let d=await Bl(o,c),g=await _.getCurrentTask(o);if(g)return Rt("blocked","task_already_active",[{label:"Complete current task first",command:"prjct done --md"},{label:"Pause current and start this one",command:"prjct pause --md"},{label:"Cancel"}],{current_task:g.description,requested_task:c}),{success:!0,message:"Task already active",currentTask:g};await _.startTask(o,{id:ye(),description:c,sessionId:ye(),linearId:a,type:d.taskType,estimatedPoints:d.estimatedPoints,estimatedMinutes:d.estimatedMinutes});let h=A.getGlobalProjectPath(o),k=Nc(c),y;try{y=Gr.getHistoricalBoosts(o,k),y.size===0&&(y=void 0)}catch{}let D=({bug:30,chore:40,improvement:80,feature:100}[d.taskType]??80)>=80?15:10,[U,F,,j]=await Promise.all([Pi(t),Ke.getActive(o).catch(()=>null),RT(h),An(c,t,{maxFiles:D,minScore:.15,historicalBoosts:y}).catch(()=>({files:[],metrics:{filesScanned:0,filesReturned:0,scanDuration:0}}))]),E=null;try{let Ue=Rs.getSnapshot(o);Ue&&(E=Rs.formatContinuityContext(Ue),Rs.clearSnapshot(o))}catch{}let M=null;if(F?.analyzedAt){let Ue=new Date(F.analyzedAt),_t=Math.floor((Date.now()-Ue.getTime())/(1e3*60*60*24));_t>7&&(M=vc("warn",`Analysis is ${_t} days old. Run \`p. sync\` to refresh patterns and file index.`))}else F||(M=vc("info","No project analysis found. Run `p. sync` for better context targeting."));let se=null;if(y&&y.size>0){let Ue=[...y.entries()].filter(([,_t])=>_t>.3).sort((_t,rr)=>rr[1]-_t[1]).slice(0,5);Ue.length>0&&(se=`### Previously Useful Files
1475
+ ${Ue.map(([rr])=>`\`${rr}\``).join(", ")}`)}let Me=ff(c,o),q=Ar({description:c,branch:U,linearId:a,type:d.taskType,estimatedPoints:d.estimatedPoints,estimatedMinutes:d.estimatedMinutes,estimateSource:d.source,domains:Me}),mt=Gp(j.files.map(Ue=>({path:Ue.path,description:Ue.reasons.join(", ")}))),ms=j.files.map(Ue=>Ue.path),nr=Kl(F,ms),Ii=Xl(j.files,F),$i=ge([{label:"Find relevant files",command:'prjct context files "..."'},{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]),Mi=ET(),_i=xT(o);console.log(L(E,M,q,Ii,mt,se,nr,_i,Mi,$i));try{let Ue=await _.getCurrentTask(o);Ue&&Gr.recordSuggestions(o,Ue.id,k,j.files.map(_t=>_t.path))}catch{}return await this.logToMemory(t,"task_started",{task:e,timestamp:J.getTimestamp()}),await zt(o,"task","after",{projectPath:t,skipRules:s.skipHooks}),{success:!0,task:e,taskDescription:c}}let p=await ni.execute("task",{task:e},t);if(!p.success)return f.fail(p.error||"Failed to execute task"),{success:!1,error:p.error};let m=await Bl(o,c);return await _.startTask(o,{id:ye(),description:c,sessionId:ye(),linearId:a,type:m.taskType,estimatedPoints:m.estimatedPoints,estimatedMinutes:m.estimatedMinutes}),f.done(`${e}`),jr("working"),At("task"),await this.logToMemory(t,"task_started",{task:e,orchestratorContext:p.orchestratorContext,timestamp:J.getTimestamp()}),await zt(o,"task","after",{projectPath:t,skipRules:s.skipHooks}),{...p,success:!0,task:e,fibonacci:{isValidPoint:cf,pointsToMinutes:cn,pointsToTimeRange:lf,storeEstimate:l(async d=>{let g=cn(d);return await _.updateCurrentTask(o,{estimatedPoints:d,estimatedMinutes:g.typical}),g},"storeEstimate")}}}else{let i=await _.getCurrentTask(o);if(!i)return s.md?Rt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):f.warn("no active task"),{success:!0,message:"No active task"};if(s.md){let a=i.startedAt?J.calculateDuration(new Date(i.startedAt)):void 0,c=Ar({description:i.description,status:"active",branch:i.branch,linearId:i.linearId,type:i.type,duration:a}),u=i.subtasks||[],p=i.currentSubtaskIndex,m=u.length>0?Hp(u,p):"",d=ge([{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(L(c,m,d))}else f.done(`working on: ${i.description}`);return{success:!0,task:i.description,currentTask:i}}}catch(n){let o=w(n);return s.md?o.includes("Cannot run")||o.includes("working state")?Rt("blocked","state_conflict",[{label:"Complete current task",command:"prjct done --md"},{label:"Pause current task",command:"prjct pause --md"}],{error:o.split(".")[0]}):console.log(JSON.stringify({status:"error",error:o})):f.fail(o),{success:!1,error:o}}}async done(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await _.getCurrentTask(n);if(!o)return t.md?Rt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):f.warn("no active task"),{success:!0,message:"No active task to complete"};let i=await zt(n,"done","before",{projectPath:e,skipRules:t.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a=o.description,c="",u=0;if(o.startedAt){let F=new Date(o.startedAt);c=J.calculateDuration(F),u=Math.round((Date.now()-F.getTime())/6e4)}let p=o.estimatedMinutes,m=o.estimatedPoints,d=o.type||"feature",g=o.linearId;try{await kt.record(n,{sessionId:o.sessionId,command:"done",task:a,startedAt:o.startedAt,completedAt:J.getTimestamp(),estimatedDuration:p?hf(p):"0m",actualDuration:c||"0m",variance:p?jT(u-p):"+0m",completedAsPlanned:!0,qualityScore:3,tags:[d,g].filter(Boolean)})}catch{}let h="";if(m&&p){let F=u-p,j=p>0?Math.round((u-p)/p*100):0,E=F>=0?"+":"";h=` | est: ${m}pt (${hf(p)}) \u2192 ${E}${j}%`}let k=[],y=null,v=null;try{if(k=await DT(e,o.startedAt),k.length>0){Gr.completeFeedback(n,o.id,k);let F=Gr.getFeedback(n,o.id);F&&(y=F.precision,v=F.recall)}}catch{}await _.completeTask(n,t.feedback);try{Rs.clearSnapshot(n)}catch{}let D=o.linearId,U=D!=null?await Lr("linear",ds()).catch(()=>!1):!1;if(t.md){let F=c?` (${c})`:"",j=null;if(k.length>0){let se=k.slice(0,20).map(Me=>`\`${Me}\``);j=`### Files Modified (${k.length})
1476
+ ${se.join(", ")}`}let E=null;if(y!==null&&v!==null){let se=Math.round(y*100),Me=Math.round(v*100);E=`### Context Accuracy
1451
1477
  | Metric | Value |
1452
1478
  |--------|-------|
1453
- | Precision | ${O}% of suggested files were used |
1454
- | Recall | ${ne}% of modified files were suggested |`}console.log(U(ke("Completed",`${a}${L}`),mt({Duration:c||"unknown",...h?{Variance:h.replace(" | ","")}:{}}),$,D,ge([{label:"Complete next subtask",command:"p. done"},{label:"Ship when ready",command:"p. ship"}])))}else{let L=c?` (${c}${h})`:"";E&&M?f.done(`${a}${L} \u2192 Linear linked (update via MCP)`):f.done(`${a}${L}`),Ar("completed"),At("done")}return await this.logToMemory(e,"task_completed",{task:a,duration:c,estimatedPoints:m,estimatedMinutes:p,actualMinutes:u,timestamp:z.getTimestamp()}),await Wt(n,"done","after",{projectPath:e,skipRules:t.skipHooks}),{success:!0,task:a,duration:c}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}async next(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await I.getProjectId(e);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await be.getActiveTasks(n);if(o.length===0)return t.md?Rt("empty","queue_empty",[{label:"Add a task",command:'prjct task "description" --md'},{label:"Add a bug",command:'prjct bug "description" --md'}]):f.warn("queue empty"),{success:!0,message:"Queue is empty"};if(t.md){let i=o.map(a=>{let c=a.type?` [${a.type}]`:"",u=a.priority?` ${a.priority}`:"";return`${a.description}${c}${u}`});console.log(U(se("Queue",`${o.length} task${o.length!==1?"s":""}`),je(i,!0),ge([{label:"Start working",command:`p. task "${o[0].description}"`}])))}else f.done(`${o.length} task${o.length!==1?"s":""} queued`),At("next");return{success:!0,tasks:o,count:o.length}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}async pause(e="",t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await _.getCurrentTask(o);if(!i)return s.md?Rt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'}]):f.warn("no active task to pause"),{success:!0,message:"No active task to pause"};let a="";i.startedAt&&(a=z.calculateDuration(new Date(i.startedAt))),await _.pauseTask(o,e);try{await Rs.capture(o,t,{taskDescription:i.description,taskStatus:"paused",sessionId:i.sessionId,activeSubtaskIndex:i.currentSubtaskIndex,subtaskCount:i.subtasks?.length,linearId:i.linearId,startedAt:i.startedAt})}catch{}if(s.md)console.log(U(ke("Task Paused",`**Paused:** ${i.description}`),mt({Reason:e||void 0,"Duration worked":a||void 0}),ge([{label:"Resume this task",command:"p. resume"},{label:"Start something new",command:"p. task"}])));else{let c=i.description.slice(0,40);f.done(`paused: ${c}${e?` (${e})`:""}`),Ar("paused"),At("pause")}return await this.logToMemory(t,"task_paused",{task:i.description,reason:e,timestamp:z.getTimestamp()}),{success:!0,task:i.description,reason:e}}catch(n){return f.fail(y(n)),{success:!1,error:y(n)}}}async resume(e=null,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await _.getCurrentTask(o);if(i)return s.md?Rt("blocked","task_already_active",[{label:"Continue working",command:"prjct done --md"},{label:"Pause and switch",command:"prjct pause --md"}],{current_task:i.description}):f.warn("already working on a task"),{success:!0,message:`Already working on: ${i.description}`};let a=await _.resumeTask(o);return a?(s.md?console.log(U(ke("Task Resumed",`**Resumed:** ${a.description}`),ge([{label:"Continue working, then finish",command:"p. done"}]))):(f.done(`resumed: ${a.description.slice(0,40)}`),Ar("working"),At("resume")),await this.logToMemory(t,"task_resumed",{task:a.description,timestamp:z.getTimestamp()}),{success:!0,task:a.description}):(s.md?Rt("idle","no_paused_task",[{label:"Start a new task",command:'prjct task "description" --md'}]):f.warn("no paused task to resume"),{success:!0,message:"No paused task found"})}catch(n){return f.fail(y(n)),{success:!1,error:y(n)}}}async workflow(e=null,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.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)return this._workflowShow(null,o,s);let a=this._detectIntent(i);switch(a.type){case"add":return this._workflowAdd(a.args,o,s);case"gate":return this._workflowGate(a.args,o,s);case"instruction":return this._workflowInstruction(a.args,o,s);case"remove":return this._workflowRm(a.args,o,s);case"disable":return this._workflowDisable(a.args,o,s);case"reset":return this._workflowReset(o,s);case"init":return this._workflowInit(o,t,s);case"help":return this._workflowHelp(s);case"create":return this._workflowCreate(a.args,o,t,s);case"list":return this._workflowList(o,s);case"delete":return this._workflowDelete(a.args,o,s);case"run":return this.run(a.args,t,s);case"view":return this._workflowShow(a.args||null,o,s);default:return this._workflowShow(i.split(/\s+/)[0]?.toLowerCase()||null,o,s)}}catch(n){return s.md?console.log(`> Error: ${y(n)}`):f.fail(y(n)),{success:!1,error:y(n)}}}_detectIntent(e){let t=e.trim();for(let{type:s,patterns:n}of vv){let o=t.match(n);if(o){let i=o[0],a=t.slice(i.length).trim(),c=/^(?:add|gate|rm|reset|init|help)\b/i.test(i);return{type:s,args:a,confidence:c?"exact":"fuzzy"}}}return{type:"view",args:t,confidence:"fuzzy"}}_searchRules(e,t){let s=t.toLowerCase();return e.filter(n=>n.action.toLowerCase().includes(s)||(n.description?.toLowerCase().includes(s)??!1)||n.command.toLowerCase().includes(s)||String(n.id)===s)}_parseAction(e){let t=e.trim();if(t.startsWith('"')){let n=t.indexOf('"',1);return n===-1?[t.slice(1),""]:[t.slice(1,n),t.slice(n+1).trim()]}if(t.startsWith("'")){let n=t.indexOf("'",1);return n===-1?[t.slice(1),""]:[t.slice(1,n),t.slice(n+1).trim()]}let s=t.match(/^(.+?)\s+(before|after)\s+/i);return s?[s[1].trim(),t.slice(s[1].length).trim()]:[t,""]}async _workflowAdd(e,t,s){let[n,o]=this._parseAction(e);if(!n||!o){let m='Usage: prjct workflow add "command" before|after <task|done|ship|sync>';return s.md?console.log(`> ${m}`):f.warn(m),{success:!1,error:m}}let i=o.split(/\s+/),a=i[0]?.toLowerCase(),c=i[1]?.toLowerCase();if(!a||!["before","after"].includes(a)){let m='Position must be "before" or "after"';return s.md?console.log(`> ${m}`):f.warn(m),{success:!1,error:m}}let u=nt.getWorkflow(t,c||"");if(!c||!u||!u.enabled){let d=nt.getAllWorkflows(t).map(h=>h.name).join(", "),g=`Workflow '${c}' not found. Available: ${d}`;return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let p=Ie.addRule(t,{type:"hook",command:c,position:a,action:n,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(U(ke("Rule Added",`#${p} [hook] ${a} ${c} \u2192 \`${n}\``),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${p} --md`}]))):f.done(`rule #${p} added: [hook] ${a} ${c} \u2192 ${n}`),{success:!0,ruleId:p}}async _workflowGate(e,t,s){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=nt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let m=nt.getAllWorkflows(t).map(g=>g.name).join(", "),d=`Workflow '${o}' not found. Available: ${m}`;return s.md?console.log(`> ${d}`):f.warn(d),{success:!1,error:d}}let a=e.slice(e.indexOf(o)+o.length).trim(),[c]=this._parseAction(a);if(!c){let p='Usage: prjct workflow gate <command> "shell command"';return s.md?console.log(`> ${p}`):f.warn(p),{success:!1,error:p}}let u=Ie.addRule(t,{type:"gate",command:o,position:"before",action:c,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(U(ke("Gate Added",`#${u} [gate] before ${o} \u2192 \`${c}\``),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this gate",command:`prjct workflow rm ${u} --md`}]))):f.done(`gate #${u} added: before ${o} \u2192 ${c}`),{success:!0,ruleId:u}}async _workflowInstruction(e,t,s){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=nt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let h=nt.getAllWorkflows(t).map(w=>w.name).join(", "),k=`Workflow '${o}' not found. Available: ${h}`;return s.md?console.log(`> ${k}`):f.warn(k),{success:!1,error:k}}let a=e.slice(e.indexOf(o)+o.length).trim(),c=a.match(/^(before|after)\s+/i);if(!c){let g='Usage: prjct workflow instruction <command> before|after "instruction text"';return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let u=c[1].toLowerCase(),p=a.slice(c[0].length).trim(),[m]=this._parseAction(p);if(!m){let g='Usage: prjct workflow instruction <command> before|after "instruction text"';return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let d=Ie.addRule(t,{type:"instruction",command:o,position:u,action:m,description:null,enabled:!0,timeoutMs:0,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(U(ke("Instruction Added",`#${d} [instruction] ${u} ${o} \u2192 \`${m}\``),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${d} --md`}]))):f.done(`instruction #${d} added: ${u} ${o} \u2192 ${m}`),{success:!0,ruleId:d}}async _workflowRm(e,t,s){let n=parseInt(e.trim(),10);if(Number.isNaN(n)){let i="Usage: prjct workflow rm <rule-id>";return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}if(!Ie.removeRule(t,n)){let i=`Rule #${n} not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return s.md?console.log(U(ke("Rule Removed",`Removed rule #${n}`))):f.done(`removed rule #${n}`),{success:!0}}async _workflowReset(e,t){let s=Ie.resetRules(e);return t.md?console.log(U(ke("Rules Reset",`Removed ${s} rule${s!==1?"s":""}`))):f.done(`reset: removed ${s} rule${s!==1?"s":""}`),{success:!0,count:s}}async _workflowDisable(e,t,s){let n=e.trim(),o=parseInt(n,10);if(!Number.isNaN(o)){let c=Ie.getRuleById(t,o);if(!c){let u=`Rule #${o} not found`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(!c.enabled){let u=`Rule #${o} is already disabled`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!0,message:u}}return Ie.updateRule(t,o,{enabled:!1}),s.md?console.log(U(ke("Rule Disabled",`#${o} [${c.type}] ${c.action}`),ge([{label:"Re-enable this rule",command:`prjct workflow enable ${o} --md`},{label:"View all rules",command:"prjct workflow --md"}]))):f.done(`disabled rule #${o}: ${c.action}`),{success:!0,ruleId:o}}let i=Ie.getAllRules(t),a=this._searchRules(i,n);if(a.length===0){let c=`No rules matching "${n}"`;return s.md?console.log(`> ${c}`):f.warn(c),{success:!1,error:c}}if(a.length===1){let c=a[0];return Ie.updateRule(t,c.id,{enabled:!1}),s.md?console.log(U(ke("Rule Disabled",`#${c.id} [${c.type}] ${c.action}`))):f.done(`disabled rule #${c.id}: ${c.action}`),{success:!0,ruleId:c.id}}if(s.md){let c=a.map(u=>`#${u.id} [${u.type}] ${u.position} ${u.command} -> \`${u.action}\``);console.log(U(se("Multiple matches",`${a.length} rules match "${n}"`),je(c),ge(a.map(u=>({label:`Disable #${u.id}`,command:`prjct workflow disable ${u.id} --md`})))))}else{f.warn(`${a.length} rules match "${n}" \u2014 specify an ID:`);for(let c of a)console.log(` #${c.id} [${c.type}] ${c.position} ${c.command} -> ${c.action}`)}return{success:!0,matches:a.map(c=>c.id)}}async _workflowHelp(e){return e.md?console.log(U(se("Workflow Help","Manage hooks, gates, and steps for your workflow"),se("Commands",je(["`prjct workflow` \u2014 View all rules","`prjct workflow ship` \u2014 View rules for a command",'`prjct workflow add "npm test" before ship` \u2014 Add a hook','`prjct workflow gate ship "npm test"` \u2014 Add a blocking gate','`prjct workflow instruction ship after "Post review in Linear"` \u2014 Add an agent instruction',"`prjct workflow disable 3` \u2014 Disable rule #3","`prjct workflow rm 3` \u2014 Remove rule #3","`prjct workflow reset` \u2014 Remove all rules","`prjct workflow init` \u2014 Seed defaults from project"])),se("Natural Language (EN/ES)",je(['`prjct workflow "show ship rules"` \u2014 muestra / show / list / ver','`prjct workflow "add npm test before ship"` \u2014 a\xF1ade / add / agrega / pon','`prjct workflow "remove 3"` \u2014 quita / remove / elimina / borra','`prjct workflow "disable lint"` \u2014 deshabilita / disable / apaga','`prjct workflow "gate ship npm test"` \u2014 gate / bloquea'])))):(console.log(""),console.log("WORKFLOW HELP"),console.log("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log(""),console.log(" Commands:"),console.log(" prjct workflow View all rules"),console.log(" prjct workflow <command> View rules for command"),console.log(' prjct workflow add "cmd" before ship Add a hook'),console.log(' prjct workflow gate ship "cmd" Add a blocking gate'),console.log(' prjct workflow instruction ship after "text" Add an agent instruction'),console.log(" prjct workflow disable <id|query> Disable a rule"),console.log(" prjct workflow rm <id> Remove a rule"),console.log(" prjct workflow reset Remove all rules"),console.log(" prjct workflow init Seed defaults"),console.log(""),console.log(" Natural language (EN/ES):"),console.log(" show/muestra add/a\xF1ade remove/quita disable/deshabilita gate/bloquea"),console.log("")),{success:!0}}async _workflowShow(e,t,s){let n=["task","done","ship","sync"],o;if(e&&n.includes(e)?o=Ie.getRulesForCommand(t,e):o=Ie.getAllRules(t),o.length===0)return s.md?console.log(U(se("Workflow Rules","No rules configured"),ge([{label:"Add a hook",command:'prjct workflow add "npm test" before ship --md'},{label:"Add a gate",command:'prjct workflow gate ship "npm test" --md'}]))):(f.warn("no workflow rules configured"),console.log(""),console.log(' Add a hook: prjct workflow add "npm test" before ship'),console.log(' Add a gate: prjct workflow gate ship "npm test"'),console.log(" Reset all: prjct workflow reset")),{success:!0,rules:[]};if(s.md){let i=e?[e]:n,a=[];for(let p of i){let m=o.filter(d=>d.command===p);m.length!==0&&a.push(Pv(p,m))}let c=e?`Workflow: ${e}`:"Workflow Rules",u=`${o.length} rule${o.length!==1?"s":""}`;console.log(U(se(c,u),a.length>0?Np(a.join(`
1455
-
1456
- `),""):null,ge([{label:"Add a hook",command:'prjct workflow add "cmd" before ship --md'},{label:"Add a gate",command:'prjct workflow gate ship "cmd" --md'},{label:"Remove a rule",command:"prjct workflow rm <id> --md"}])))}else{let i=e?`WORKFLOW RULES: ${e.toUpperCase()}`:"WORKFLOW RULES";console.log(""),console.log(i),console.log("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500");for(let a of o){let c=a.enabled?"":" (disabled)";console.log(` #${a.id} [${a.type}] ${a.position.padEnd(6)} ${a.command.padEnd(5)} \u2192 ${a.action}${c}`)}console.log(""),console.log("Commands: add | gate | rm | reset")}return{success:!0,rules:o}}async _workflowInit(e,t,s){let n=Ie.getRulesForCommand(e,"ship").filter(u=>u.position==="before");if(n.length>0){let u=`Ship workflow already has ${n.length} rule${n.length!==1?"s":""}. Use 'prjct workflow reset' first if you want to reinitialize.`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let o=await oi(t),i=0,a=[],c=Ie.addRule(e,{type:"gate",command:"ship",position:"before",action:'git branch --show-current | grep -vE "^(main|master)$"',description:"Prevent shipping from main branch",enabled:!0,timeoutMs:5e3,sortOrder:i++,createdAt:new Date().toISOString()});if(a.push(`#${c} [gate] prevent main branch`),o.lint){let u=Ie.addRule(e,{type:"step",command:"ship",position:"before",action:`${o.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:i++,createdAt:new Date().toISOString()});a.push(`#${u} [step] lint \u2192 ${o.lint.command}`)}if(o.test){let u=Ie.addRule(e,{type:"step",command:"ship",position:"before",action:`${o.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:i++,createdAt:new Date().toISOString()});a.push(`#${u} [step] test \u2192 ${o.test.command}`)}if(s.md)console.log(U(ke("Workflow Initialized",`Added ${a.length} default ship rules`),je(a),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Ship your work",command:"prjct ship --md"}])));else{f.done(`initialized ${a.length} workflow rules for ship`);for(let u of a)console.log(` ${u}`)}return{success:!0,rulesAdded:a.length}}async _workflowCreate(e,t,s,n){let o=e.match(/^(\S+)\s+"([^"]+)"/);if(!o){let u='Usage: prjct workflow create <name> "description"';return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let[,i,a]=o;if(!nt.isValidName(i)){let u='Workflow name must be lowercase alphanumeric + hyphens (e.g., "qa", "deploy-prod")';return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(nt.isReservedName(i)){let u=`Workflow name '${i}' is reserved`;return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(nt.getWorkflow(t,i)){let u=`Workflow '${i}' already exists`;return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}try{let u=nt.createWorkflow(t,{name:i,description:a}),p=await Hl.generateWorkflowTemplate(i,a);if(!p.success){nt.deleteWorkflow(t,i);let m=`Failed to generate template: ${p.error}`;return n.md?console.log(`> Error: ${m}`):f.fail(m),{success:!1,error:m}}return n.md?console.log(U(ke("Workflow Created",`Created workflow: ${i}`),se("Description",a),se("Template",`Installed at ${p.path}`),ge([{label:"Add rules",command:`prjct workflow add "action" before ${i} --md`},{label:"View workflow",command:`prjct workflow ${i} --md`},{label:"Run workflow",command:`p. ${i}`}]))):(f.done(`created workflow: ${i}`),console.log(` ${a}`),console.log(` Template: ${p.path}`),console.log(`
1457
- Run with: p. ${i}`)),{success:!0,workflowId:u,name:i,templatePath:p.path}}catch(u){let p=y(u);return n.md?console.log(`> Error: ${p}`):f.fail(p),{success:!1,error:p}}}async _workflowList(e,t){let s=nt.getAllWorkflows(e);if(s.length===0){let i="No workflows found";return t.md?console.log(`> ${i}`):f.warn(i),{success:!0,workflows:[]}}let n=s.filter(i=>i.isBuiltin),o=s.filter(i=>!i.isBuiltin);if(t.md){let i=[];if(n.length>0){let a=n.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(se("Built-in Workflows",a.join(`
1458
- `)))}if(o.length>0){let a=o.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(se("Custom Workflows",a.join(`
1459
- `)))}console.log(U(...i,ge([{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":""}`),n.length>0){console.log(`
1479
+ | Precision | ${se}% of suggested files were used |
1480
+ | Recall | ${Me}% of modified files were suggested |`}let M=null;try{let{prjctDb:se}=(re(),ot(Zr)),Me=se.getDoc(n,"rpi:current:research"),q=se.getDoc(n,"rpi:current:plan");Me?q||(M=`### RPI Phase: Plan Ready
1481
+ Research is available. Create your implementation plan next.`):M="### RPI Phase: Research Complete\nSave your research findings with `prjct compact --md` before planning."}catch{}console.log(L(ke("Completed",`${a}${F}`),lt({Duration:c||"unknown",...h?{Variance:h.replace(" | ","")}:{}}),j,E,M,ge([{label:"Complete next subtask",command:"prjct done --md"},{label:"Ship when ready",command:"prjct ship --md"}])))}else{let F=c?` (${c}${h})`:"";D&&U?f.done(`${a}${F} \u2192 Linear linked (update via MCP)`):f.done(`${a}${F}`),jr("completed"),At("done")}return await this.logToMemory(e,"task_completed",{task:a,duration:c,estimatedPoints:m,estimatedMinutes:p,actualMinutes:u,timestamp:J.getTimestamp()}),await zt(n,"done","after",{projectPath:e,skipRules:t.skipHooks}),{success:!0,task:a,duration:c}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}async next(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let n=await $.getProjectId(e);if(!n)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await be.getActiveTasks(n);if(o.length===0)return t.md?Rt("empty","queue_empty",[{label:"Add a task",command:'prjct task "description" --md'},{label:"Add a bug",command:'prjct bug "description" --md'}]):f.warn("queue empty"),{success:!0,message:"Queue is empty"};if(t.md){let i=o.map(a=>{let c=a.type?` [${a.type}]`:"",u=a.priority?` ${a.priority}`:"";return`${a.description.replace(/^[\u{1F300}-\u{1F9FF}]\s*/u,"")}${c}${u}`});console.log(L(Q("Queue",`${o.length} task${o.length!==1?"s":""}`),Oe(i,!0),ge([{label:"Start top task",command:'prjct task "..." --md'}])))}else f.done(`${o.length} task${o.length!==1?"s":""} queued`),At("next");return{success:!0,tasks:o,count:o.length}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}async pause(e="",t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await _.getCurrentTask(o);if(!i)return s.md?Rt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'}]):f.warn("no active task to pause"),{success:!0,message:"No active task to pause"};let a="";i.startedAt&&(a=J.calculateDuration(new Date(i.startedAt))),await _.pauseTask(o,e);try{await Rs.capture(o,t,{taskDescription:i.description,taskStatus:"paused",sessionId:i.sessionId,activeSubtaskIndex:i.currentSubtaskIndex,subtaskCount:i.subtasks?.length,linearId:i.linearId,startedAt:i.startedAt})}catch{}if(s.md)console.log(L(ke("Task Paused",`**Paused:** ${i.description}`),lt({Reason:e||void 0,"Duration worked":a||void 0}),ge([{label:"Resume this task",command:"prjct resume --md"},{label:"Start something new",command:'prjct task "..." --md'}])));else{let c=i.description.slice(0,40);f.done(`paused: ${c}${e?` (${e})`:""}`),jr("paused"),At("pause")}return await this.logToMemory(t,"task_paused",{task:i.description,reason:e,timestamp:J.getTimestamp()}),{success:!0,task:i.description,reason:e}}catch(n){return f.fail(w(n)),{success:!1,error:w(n)}}}async resume(e=null,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await _.getCurrentTask(o);if(i)return s.md?Rt("blocked","task_already_active",[{label:"Continue working",command:"prjct done --md"},{label:"Pause and switch",command:"prjct pause --md"}],{current_task:i.description}):f.warn("already working on a task"),{success:!0,message:`Already working on: ${i.description}`};let a=await _.resumeTask(o);return a?(s.md?console.log(L(ke("Task Resumed",`**Resumed:** ${a.description}`),ge([{label:"Continue working, then finish",command:"prjct done --md"}]))):(f.done(`resumed: ${a.description.slice(0,40)}`),jr("working"),At("resume")),await this.logToMemory(t,"task_resumed",{task:a.description,timestamp:J.getTimestamp()}),{success:!0,task:a.description}):(s.md?Rt("idle","no_paused_task",[{label:"Start a new task",command:'prjct task "description" --md'}]):f.warn("no paused task to resume"),{success:!0,message:"No paused task found"})}catch(n){return f.fail(w(n)),{success:!1,error:w(n)}}}async workflow(e=null,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.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)return this._workflowShow(null,o,s);let a=this._detectIntent(i);switch(a.type){case"add":return this._workflowAdd(a.args,o,s);case"gate":return this._workflowGate(a.args,o,s);case"instruction":return this._workflowInstruction(a.args,o,s);case"remove":return this._workflowRm(a.args,o,s);case"disable":return this._workflowDisable(a.args,o,s);case"reset":return this._workflowReset(o,s);case"init":return this._workflowInit(o,t,s);case"help":return this._workflowHelp(s);case"create":return this._workflowCreate(a.args,o,t,s);case"list":return this._workflowList(o,s);case"delete":return this._workflowDelete(a.args,o,s);case"run":return this.run(a.args,t,s);case"view":return this._workflowShow(a.args||null,o,s);default:return this._workflowShow(i.split(/\s+/)[0]?.toLowerCase()||null,o,s)}}catch(n){return s.md?console.log(`> Error: ${w(n)}`):f.fail(w(n)),{success:!1,error:w(n)}}}_detectIntent(e){let t=e.trim();for(let{type:s,patterns:n}of PT){let o=t.match(n);if(o){let i=o[0],a=t.slice(i.length).trim(),c=/^(?:add|gate|rm|reset|init|help)\b/i.test(i);return{type:s,args:a,confidence:c?"exact":"fuzzy"}}}return{type:"view",args:t,confidence:"fuzzy"}}_searchRules(e,t){let s=t.toLowerCase();return e.filter(n=>n.action.toLowerCase().includes(s)||(n.description?.toLowerCase().includes(s)??!1)||n.command.toLowerCase().includes(s)||String(n.id)===s)}_parseAction(e){let t=e.trim();if(t.startsWith('"')){let n=t.indexOf('"',1);return n===-1?[t.slice(1),""]:[t.slice(1,n),t.slice(n+1).trim()]}if(t.startsWith("'")){let n=t.indexOf("'",1);return n===-1?[t.slice(1),""]:[t.slice(1,n),t.slice(n+1).trim()]}let s=t.match(/^(.+?)\s+(before|after)\s+/i);return s?[s[1].trim(),t.slice(s[1].length).trim()]:[t,""]}async _workflowAdd(e,t,s){let[n,o]=this._parseAction(e);if(!n||!o){let m='Usage: prjct workflow add "command" before|after <task|done|ship|sync>';return s.md?console.log(`> ${m}`):f.warn(m),{success:!1,error:m}}let i=o.split(/\s+/),a=i[0]?.toLowerCase(),c=i[1]?.toLowerCase();if(!a||!["before","after"].includes(a)){let m='Position must be "before" or "after"';return s.md?console.log(`> ${m}`):f.warn(m),{success:!1,error:m}}let u=rt.getWorkflow(t,c||"");if(!c||!u||!u.enabled){let d=rt.getAllWorkflows(t).map(h=>h.name).join(", "),g=`Workflow '${c}' not found. Available: ${d}`;return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let p=je.addRule(t,{type:"hook",command:c,position:a,action:n,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(L(ke("Rule Added",`#${p} [hook] ${a} ${c} \u2192 \`${n}\``),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${p} --md`}]))):f.done(`rule #${p} added: [hook] ${a} ${c} \u2192 ${n}`),{success:!0,ruleId:p}}async _workflowGate(e,t,s){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=rt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let m=rt.getAllWorkflows(t).map(g=>g.name).join(", "),d=`Workflow '${o}' not found. Available: ${m}`;return s.md?console.log(`> ${d}`):f.warn(d),{success:!1,error:d}}let a=e.slice(e.indexOf(o)+o.length).trim(),[c]=this._parseAction(a);if(!c){let p='Usage: prjct workflow gate <command> "shell command"';return s.md?console.log(`> ${p}`):f.warn(p),{success:!1,error:p}}let u=je.addRule(t,{type:"gate",command:o,position:"before",action:c,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(L(ke("Gate Added",`#${u} [gate] before ${o} \u2192 \`${c}\``),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this gate",command:`prjct workflow rm ${u} --md`}]))):f.done(`gate #${u} added: before ${o} \u2192 ${c}`),{success:!0,ruleId:u}}async _workflowInstruction(e,t,s){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=rt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let h=rt.getAllWorkflows(t).map(y=>y.name).join(", "),k=`Workflow '${o}' not found. Available: ${h}`;return s.md?console.log(`> ${k}`):f.warn(k),{success:!1,error:k}}let a=e.slice(e.indexOf(o)+o.length).trim(),c=a.match(/^(before|after)\s+/i);if(!c){let g='Usage: prjct workflow instruction <command> before|after "instruction text"';return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let u=c[1].toLowerCase(),p=a.slice(c[0].length).trim(),[m]=this._parseAction(p);if(!m){let g='Usage: prjct workflow instruction <command> before|after "instruction text"';return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let d=je.addRule(t,{type:"instruction",command:o,position:u,action:m,description:null,enabled:!0,timeoutMs:0,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(L(ke("Instruction Added",`#${d} [instruction] ${u} ${o} \u2192 \`${m}\``),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${d} --md`}]))):f.done(`instruction #${d} added: ${u} ${o} \u2192 ${m}`),{success:!0,ruleId:d}}async _workflowRm(e,t,s){let n=parseInt(e.trim(),10);if(Number.isNaN(n)){let i="Usage: prjct workflow rm <rule-id>";return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}if(!je.removeRule(t,n)){let i=`Rule #${n} not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return s.md?console.log(L(ke("Rule Removed",`Removed rule #${n}`))):f.done(`removed rule #${n}`),{success:!0}}async _workflowReset(e,t){let s=je.resetRules(e);return t.md?console.log(L(ke("Rules Reset",`Removed ${s} rule${s!==1?"s":""}`))):f.done(`reset: removed ${s} rule${s!==1?"s":""}`),{success:!0,count:s}}async _workflowDisable(e,t,s){let n=e.trim(),o=parseInt(n,10);if(!Number.isNaN(o)){let c=je.getRuleById(t,o);if(!c){let u=`Rule #${o} not found`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(!c.enabled){let u=`Rule #${o} is already disabled`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!0,message:u}}return je.updateRule(t,o,{enabled:!1}),s.md?console.log(L(ke("Rule Disabled",`#${o} [${c.type}] ${c.action}`),ge([{label:"Re-enable this rule",command:`prjct workflow enable ${o} --md`},{label:"View all rules",command:"prjct workflow --md"}]))):f.done(`disabled rule #${o}: ${c.action}`),{success:!0,ruleId:o}}let i=je.getAllRules(t),a=this._searchRules(i,n);if(a.length===0){let c=`No rules matching "${n}"`;return s.md?console.log(`> ${c}`):f.warn(c),{success:!1,error:c}}if(a.length===1){let c=a[0];return je.updateRule(t,c.id,{enabled:!1}),s.md?console.log(L(ke("Rule Disabled",`#${c.id} [${c.type}] ${c.action}`))):f.done(`disabled rule #${c.id}: ${c.action}`),{success:!0,ruleId:c.id}}if(s.md){let c=a.map(u=>`#${u.id} [${u.type}] ${u.position} ${u.command} -> \`${u.action}\``);console.log(L(Q("Multiple matches",`${a.length} rules match "${n}"`),Oe(c),ge(a.map(u=>({label:`Disable #${u.id}`,command:`prjct workflow disable ${u.id} --md`})))))}else{f.warn(`${a.length} rules match "${n}" \u2014 specify an ID:`);for(let c of a)console.log(` #${c.id} [${c.type}] ${c.position} ${c.command} -> ${c.action}`)}return{success:!0,matches:a.map(c=>c.id)}}async _workflowHelp(e){return e.md?console.log(L(Q("Workflow Help","Manage hooks, gates, and steps for your workflow"),Q("Commands",Oe(["`prjct workflow` \u2014 View all rules","`prjct workflow ship` \u2014 View rules for a command",'`prjct workflow add "npm test" before ship` \u2014 Add a hook','`prjct workflow gate ship "npm test"` \u2014 Add a blocking gate','`prjct workflow instruction ship after "Post review in Linear"` \u2014 Add an agent instruction',"`prjct workflow disable 3` \u2014 Disable rule #3","`prjct workflow rm 3` \u2014 Remove rule #3","`prjct workflow reset` \u2014 Remove all rules","`prjct workflow init` \u2014 Seed defaults from project"])),Q("Natural Language (EN/ES)",Oe(['`prjct workflow "show ship rules"` \u2014 muestra / show / list / ver','`prjct workflow "add npm test before ship"` \u2014 a\xF1ade / add / agrega / pon','`prjct workflow "remove 3"` \u2014 quita / remove / elimina / borra','`prjct workflow "disable lint"` \u2014 deshabilita / disable / apaga','`prjct workflow "gate ship npm test"` \u2014 gate / bloquea'])))):(console.log(""),console.log("WORKFLOW HELP"),console.log("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log(""),console.log(" Commands:"),console.log(" prjct workflow View all rules"),console.log(" prjct workflow <command> View rules for command"),console.log(' prjct workflow add "cmd" before ship Add a hook'),console.log(' prjct workflow gate ship "cmd" Add a blocking gate'),console.log(' prjct workflow instruction ship after "text" Add an agent instruction'),console.log(" prjct workflow disable <id|query> Disable a rule"),console.log(" prjct workflow rm <id> Remove a rule"),console.log(" prjct workflow reset Remove all rules"),console.log(" prjct workflow init Seed defaults"),console.log(""),console.log(" Natural language (EN/ES):"),console.log(" show/muestra add/a\xF1ade remove/quita disable/deshabilita gate/bloquea"),console.log("")),{success:!0}}async _workflowShow(e,t,s){let n=["task","done","ship","sync"],o;if(e&&n.includes(e)?o=je.getRulesForCommand(t,e):o=je.getAllRules(t),o.length===0)return s.md?console.log(L(Q("Workflow Rules","No rules configured"),ge([{label:"Add a hook",command:'prjct workflow add "npm test" before ship --md'},{label:"Add a gate",command:'prjct workflow gate ship "npm test" --md'}]))):(f.warn("no workflow rules configured"),console.log(""),console.log(' Add a hook: prjct workflow add "npm test" before ship'),console.log(' Add a gate: prjct workflow gate ship "npm test"'),console.log(" Reset all: prjct workflow reset")),{success:!0,rules:[]};if(s.md){let i=e?[e]:n,a=[];for(let p of i){let m=o.filter(d=>d.command===p);m.length!==0&&a.push(AT(p,m))}let c=e?`Workflow: ${e}`:"Workflow Rules",u=`${o.length} rule${o.length!==1?"s":""}`;console.log(L(Q(c,u),a.length>0?Up(a.join(`
1482
+
1483
+ `),""):null,ge([{label:"Add a hook",command:'prjct workflow add "cmd" before ship --md'},{label:"Add a gate",command:'prjct workflow gate ship "cmd" --md'},{label:"Remove a rule",command:"prjct workflow rm <id> --md"}])))}else{let i=e?`WORKFLOW RULES: ${e.toUpperCase()}`:"WORKFLOW RULES";console.log(""),console.log(i),console.log("\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500");for(let a of o){let c=a.enabled?"":" (disabled)";console.log(` #${a.id} [${a.type}] ${a.position.padEnd(6)} ${a.command.padEnd(5)} \u2192 ${a.action}${c}`)}console.log(""),console.log("Commands: add | gate | rm | reset")}return{success:!0,rules:o}}async _workflowInit(e,t,s){let n=je.getRulesForCommand(e,"ship").filter(u=>u.position==="before");if(n.length>0){let u=`Ship workflow already has ${n.length} rule${n.length!==1?"s":""}. Use 'prjct workflow reset' first if you want to reinitialize.`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let o=await li(t),i=0,a=[],c=je.addRule(e,{type:"gate",command:"ship",position:"before",action:'git branch --show-current | grep -vE "^(main|master)$"',description:"Prevent shipping from main branch",enabled:!0,timeoutMs:5e3,sortOrder:i++,createdAt:new Date().toISOString()});if(a.push(`#${c} [gate] prevent main branch`),o.lint){let u=je.addRule(e,{type:"step",command:"ship",position:"before",action:`${o.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:i++,createdAt:new Date().toISOString()});a.push(`#${u} [step] lint \u2192 ${o.lint.command}`)}if(o.test){let u=je.addRule(e,{type:"step",command:"ship",position:"before",action:`${o.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:i++,createdAt:new Date().toISOString()});a.push(`#${u} [step] test \u2192 ${o.test.command}`)}if(s.md)console.log(L(ke("Workflow Initialized",`Added ${a.length} default ship rules`),Oe(a),ge([{label:"View all rules",command:"prjct workflow --md"},{label:"Ship your work",command:"prjct ship --md"}])));else{f.done(`initialized ${a.length} workflow rules for ship`);for(let u of a)console.log(` ${u}`)}return{success:!0,rulesAdded:a.length}}async _workflowCreate(e,t,s,n){let o=e.match(/^(\S+)\s+"([^"]+)"/);if(!o){let u='Usage: prjct workflow create <name> "description"';return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let[,i,a]=o;if(!rt.isValidName(i)){let u='Workflow name must be lowercase alphanumeric + hyphens (e.g., "qa", "deploy-prod")';return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(rt.isReservedName(i)){let u=`Workflow name '${i}' is reserved`;return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(rt.getWorkflow(t,i)){let u=`Workflow '${i}' already exists`;return n.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}try{let u=rt.createWorkflow(t,{name:i,description:a}),p=await Vl.generateWorkflowTemplate(i,a);if(!p.success){rt.deleteWorkflow(t,i);let m=`Failed to generate template: ${p.error}`;return n.md?console.log(`> Error: ${m}`):f.fail(m),{success:!1,error:m}}return n.md?console.log(L(ke("Workflow Created",`Created workflow: ${i}`),Q("Description",a),Q("Template",`Installed at ${p.path}`),ge([{label:"Add rules",command:`prjct workflow add "action" before ${i} --md`},{label:"View workflow",command:`prjct workflow ${i} --md`},{label:"Run workflow",command:`p. ${i}`}]))):(f.done(`created workflow: ${i}`),console.log(` ${a}`),console.log(` Template: ${p.path}`),console.log(`
1484
+ Run with: p. ${i}`)),{success:!0,workflowId:u,name:i,templatePath:p.path}}catch(u){let p=w(u);return n.md?console.log(`> Error: ${p}`):f.fail(p),{success:!1,error:p}}}async _workflowList(e,t){let s=rt.getAllWorkflows(e);if(s.length===0){let i="No workflows found";return t.md?console.log(`> ${i}`):f.warn(i),{success:!0,workflows:[]}}let n=s.filter(i=>i.isBuiltin),o=s.filter(i=>!i.isBuiltin);if(t.md){let i=[];if(n.length>0){let a=n.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(Q("Built-in Workflows",a.join(`
1485
+ `)))}if(o.length>0){let a=o.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(Q("Custom Workflows",a.join(`
1486
+ `)))}console.log(L(...i,ge([{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":""}`),n.length>0){console.log(`
1460
1487
  Built-in:`);for(let i of n)console.log(` ${i.name} \u2014 ${i.description}`)}if(o.length>0){console.log(`
1461
- Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:s}}async _workflowDelete(e,t,s){let n=e.trim();if(!n){let o="Usage: prjct workflow delete <name>";return s.md?console.log(`> ${o}`):f.warn(o),{success:!1,error:o}}try{if(!nt.deleteWorkflow(t,n)){let i=`Workflow '${n}' not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return await Hl.deleteWorkflowTemplate(n),s.md?console.log(U(ke("Workflow Deleted",`Deleted workflow: ${n}`))):f.done(`deleted workflow: ${n}`),{success:!0}}catch(o){let i=y(o);return s.md?console.log(`> Error: ${i}`):f.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.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=nt.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 c=await Wt(o,i,"before",{projectPath:t});if(!c.success){if(s.md)Rt("failed","workflow_gates_failed",[{label:"View rules",command:`prjct workflow ${i} --md`}]);else if(f.fail("Workflow gates failed"),c.gatesFailed)for(let u of c.gatesFailed)console.log(` \u2717 ${u}`);return{success:!1,error:"Workflow gates failed",gatesFailed:c.gatesFailed}}return await Wt(o,i,"after",{projectPath:t}),s.md?console.log(U(ke(`Workflow: ${i}`,a.description||""),ge([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):f.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(n){let o=y(n);return s.md?console.log(`> Error: ${o}`):f.fail(o),{success:!1,error:o}}}async sessions(e=process.cwd(),t={}){try{if(t.cleanup){let n=await Rs.cleanup();return t.md?console.log(ke("Cleanup",`Removed ${n} stale snapshot${n!==1?"s":""}`)):f.done(`cleaned ${n} stale snapshot${n!==1?"s":""}`),{success:!0,cleaned:n}}let s=await Rs.listAllSnapshots();if(s.length===0)return t.md?Rt("empty","no_sessions",[{label:"Start a task",command:'prjct task "description" --md'}]):f.warn("no recent sessions found"),{success:!0,message:"No recent sessions"};if(t.md){let n=s.map(o=>{let i=z.formatDuration(Date.now()-new Date(o.timestamp).getTime()),a=o.projectName||o.projectId.slice(0,8),c=o.subtaskCount&&o.activeSubtaskIndex!==void 0?` (${o.activeSubtaskIndex+1}/${o.subtaskCount})`:"";return`[${o.taskStatus}] **${a}** \u2014 ${o.taskDescription}${c} (${i} ago)`});console.log(U(se("Recent Sessions",`${s.length} session${s.length!==1?"s":""} across projects`),je(n),ge([{label:"Resume a session",command:"prjct resume --md"},{label:"Clean old sessions",command:"prjct sessions --cleanup --md"}])))}else{f.done(`${s.length} recent session${s.length!==1?"s":""}`);for(let n of s){let o=z.formatDuration(Date.now()-new Date(n.timestamp).getTime()),i=n.projectName||n.projectId.slice(0,8);console.log(` [${n.taskStatus}] ${i} \u2014 ${n.taskDescription} (${o} ago)`)}}return{success:!0,snapshots:s,count:s.length}}catch(s){return f.fail(y(s)),{success:!1,error:y(s)}}}async tokens(e="",t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await _.getCurrentTask(o);if(!i)return s.md?Rt("idle","no_active_task",[{label:"Start a task first",command:'prjct task "description" --md'}]):f.warn("no active task \u2014 start one first to track tokens"),{success:!1,error:"No active task"};let a=e.trim().split(/\s+/),c=parseInt(a[0],10),u=parseInt(a[1],10);if(Number.isNaN(c)||Number.isNaN(u)){let m="Usage: prjct tokens <input_tokens> <output_tokens>";return s.md?console.log(U(se("Tokens",m))):f.fail(m),{success:!1,error:m}}let p=await _.addTokens(o,c,u);return p?(s.md?console.log(U(se("Tokens Recorded",`+${c.toLocaleString()} in / +${u.toLocaleString()} out`),mt({"Total In":p.tokensIn.toLocaleString(),"Total Out":p.tokensOut.toLocaleString(),Total:(p.tokensIn+p.tokensOut).toLocaleString(),Task:i.description}))):f.done(`tokens recorded: ${p.tokensIn.toLocaleString()} in / ${p.tokensOut.toLocaleString()} out`),{success:!0,tokensIn:p.tokensIn,tokensOut:p.tokensOut}):{success:!1,error:"Failed to record tokens"}}catch(n){return f.fail(y(n)),{success:!1,error:y(n)}}}};function pf(r){if(r<60)return`${r}m`;let e=Math.floor(r/60),t=r%60;return t>0?`${e}h ${t}m`:`${e}h`}l(pf,"formatMinutesToDuration");async function Tv(r){try{let e=bv.join(r,"analysis","repo-analysis.json"),t=await Sv.readFile(e,"utf-8");return JSON.parse(t)}catch(e){return R(e),null}}l(Tv,"loadRepoAnalysis");function Cv(r,e){if(!r&&!e)return null;let t=e?.ecosystem||null,s=r?.languages?.join(", ")||null,n=r?.frameworks?.join(", ")||null,o=r?.packageManager||null,i=r?.sourceDir||e?.structure?.srcDir||null,a=r?.testDir||e?.structure?.testDir||null,c={};if(t&&(c.Ecosystem=t),s&&(c.Languages=s),n&&(c.Frameworks=n),o&&(c["Package manager"]=o),i||a){let g=[];i&&g.push(`${i}`),a&&g.push(`Tests: ${a}`),c.Source=g.join(" | ")}let u=mt(c),p=e?.commands,m=null;if(p&&Object.keys(p).length>0){let g=Object.entries(p).map(([h,k])=>`${h.charAt(0).toUpperCase()+h.slice(1)}: \`${k}\``);m=`### Commands
1462
- ${je(g)}`}return[u?`### Project
1463
- ${u}`:null,m].filter(Boolean).join(`
1464
-
1465
- `)||null}l(Cv,"buildProjectContext");function Pv(r,e){let t=e.filter(d=>d.type==="gate"&&d.position==="before"),s=e.filter(d=>d.type==="instruction"&&d.position==="before"),n=e.filter(d=>d.type==="hook"&&d.position==="before"),o=e.filter(d=>d.type==="step"&&d.position==="before"),i=e.filter(d=>d.type==="instruction"&&d.position==="after"),a=e.filter(d=>d.type==="hook"&&d.position==="after"),c=e.filter(d=>d.type==="step"&&d.position==="after"),u=[],p=l((d,g,h)=>{let k=g.map(M=>` ${M.enabled?h:"o"} #${M.id} ${M.action}`),w=[d,...k],E=Math.max(...w.map(M=>M.length))+2;u.push(`+${"-".repeat(E)}+`);for(let M of w)u.push(`| ${M.padEnd(E-1)}|`);u.push(`+${"-".repeat(E)}+`)},"drawBox"),m=l(d=>{d.push(" |"),d.push(" v")},"arrow");return t.length>0&&(p("GATES (must pass)",t,"#"),m(u)),s.length>0&&(p("INSTRUCTIONS (before)",s,"\u{1F4CB}"),m(u)),n.length>0&&(p("HOOKS (before)",n,">"),m(u)),o.length>0&&(p("STEPS (before)",o,">"),m(u)),u.push(` [ ${r.toUpperCase()} ]`),i.length>0&&(m(u),p("INSTRUCTIONS (after)",i,"\u{1F4CB}")),a.length>0&&(m(u),p("HOOKS (after)",a,">")),c.length>0&&(m(u),p("STEPS (after)",c,">")),u.join(`
1466
- `)}l(Pv,"buildFlowDiagram");async function Ev(r,e){let{execSync:t}=await import("node:child_process"),s=new Set,n={cwd:r,encoding:"utf-8"};try{let o=t(`git log --since="${e}" --name-only --pretty=format:""`,n);for(let i of o.split(`
1488
+ Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:s}}async _workflowDelete(e,t,s){let n=e.trim();if(!n){let o="Usage: prjct workflow delete <name>";return s.md?console.log(`> ${o}`):f.warn(o),{success:!1,error:o}}try{if(!rt.deleteWorkflow(t,n)){let i=`Workflow '${n}' not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return await Vl.deleteWorkflowTemplate(n),s.md?console.log(L(ke("Workflow Deleted",`Deleted workflow: ${n}`))):f.done(`deleted workflow: ${n}`),{success:!0}}catch(o){let i=w(o);return s.md?console.log(`> Error: ${i}`):f.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.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=rt.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 c=await zt(o,i,"before",{projectPath:t});if(!c.success){if(s.md)Rt("failed","workflow_gates_failed",[{label:"View rules",command:`prjct workflow ${i} --md`}]);else if(f.fail("Workflow gates failed"),c.gatesFailed)for(let u of c.gatesFailed)console.log(` \u2717 ${u}`);return{success:!1,error:"Workflow gates failed",gatesFailed:c.gatesFailed}}return await zt(o,i,"after",{projectPath:t}),s.md?console.log(L(ke(`Workflow: ${i}`,a.description||""),ge([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):f.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(n){let o=w(n);return s.md?console.log(`> Error: ${o}`):f.fail(o),{success:!1,error:o}}}async sessions(e=process.cwd(),t={}){try{if(t.cleanup){let n=await Rs.cleanup();return t.md?console.log(ke("Cleanup",`Removed ${n} stale snapshot${n!==1?"s":""}`)):f.done(`cleaned ${n} stale snapshot${n!==1?"s":""}`),{success:!0,cleaned:n}}let s=await Rs.listAllSnapshots();if(s.length===0)return t.md?Rt("empty","no_sessions",[{label:"Start a task",command:'prjct task "description" --md'}]):f.warn("no recent sessions found"),{success:!0,message:"No recent sessions"};if(t.md){let n=s.map(o=>{let i=J.formatDuration(Date.now()-new Date(o.timestamp).getTime()),a=o.projectName||o.projectId.slice(0,8),c=o.subtaskCount&&o.activeSubtaskIndex!==void 0?` (${o.activeSubtaskIndex+1}/${o.subtaskCount})`:"";return`[${o.taskStatus}] **${a}** \u2014 ${o.taskDescription}${c} (${i} ago)`});console.log(L(Q("Recent Sessions",`${s.length} session${s.length!==1?"s":""} across projects`),Oe(n),ge([{label:"Resume a session",command:"prjct resume --md"},{label:"Clean old sessions",command:"prjct sessions --cleanup --md"}])))}else{f.done(`${s.length} recent session${s.length!==1?"s":""}`);for(let n of s){let o=J.formatDuration(Date.now()-new Date(n.timestamp).getTime()),i=n.projectName||n.projectId.slice(0,8);console.log(` [${n.taskStatus}] ${i} \u2014 ${n.taskDescription} (${o} ago)`)}}return{success:!0,snapshots:s,count:s.length}}catch(s){return f.fail(w(s)),{success:!1,error:w(s)}}}async tokens(e="",t=process.cwd(),s={}){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let o=await $.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await _.getCurrentTask(o);if(!i)return s.md?Rt("idle","no_active_task",[{label:"Start a task first",command:'prjct task "description" --md'}]):f.warn("no active task \u2014 start one first to track tokens"),{success:!1,error:"No active task"};let a=e.trim().split(/\s+/),c=parseInt(a[0],10),u=parseInt(a[1],10);if(Number.isNaN(c)||Number.isNaN(u)){let m="Usage: prjct tokens <input_tokens> <output_tokens>";return s.md?console.log(L(Q("Tokens",m))):f.fail(m),{success:!1,error:m}}let p=await _.addTokens(o,c,u);return p?(s.md?console.log(L(Q("Tokens Recorded",`+${c.toLocaleString()} in / +${u.toLocaleString()} out`),lt({"Total In":p.tokensIn.toLocaleString(),"Total Out":p.tokensOut.toLocaleString(),Total:(p.tokensIn+p.tokensOut).toLocaleString(),Task:i.description}))):f.done(`tokens recorded: ${p.tokensIn.toLocaleString()} in / ${p.tokensOut.toLocaleString()} out`),{success:!0,tokensIn:p.tokensIn,tokensOut:p.tokensOut}):{success:!1,error:"Failed to record tokens"}}catch(n){return f.fail(w(n)),{success:!1,error:w(n)}}}};function ET(){return["### Efficiency","- Be concise. No preamble, no filler.","- **Use sub-agents (Agent tool) for exploration that produces >5 file reads.** Sub-agents isolate context and prevent the main conversation from bloating.","- Prefer `file:line` references over dumping full file contents.","- When context grows large, use `prjct compact --md` to create a truth snapshot."].join(`
1489
+ `)}l(ET,"buildEfficiencySection");function xT(r){try{let{prjctDb:e}=(re(),ot(Zr)),t=e.getDoc(r,"rpi:current:research"),s=e.getDoc(r,"rpi:current:plan"),n;t?s?n={phase:"implement",researchDoc:t,planDoc:s}:n={phase:"plan",researchDoc:t}:n={phase:"research"};let o=["### RPI Phase"];switch(n.phase){case"research":o.push("**Phase: RESEARCH** \u2014 Explore the codebase first. Use the **Agent tool** (sub-agents) for broad exploration.","Produce a truth snapshot: exact files + lines, function call chains, test locations.","Save findings with `prjct compact --md` when done exploring.");break;case"plan":o.push("**Phase: PLAN** \u2014 Create an implementation plan with real code snippets.","Reference exact files and line numbers from research.","Use sub-agents to verify assumptions if needed."),n.researchDoc&&o.push("","<research-context>",n.researchDoc,"</research-context>");break;case"implement":if(o.push("**Phase: IMPLEMENT** \u2014 Execute the plan. Minimal exploration.","Work only with the scoped files. Avoid reading new files unless absolutely necessary."),n.planDoc){let i=/`([a-zA-Z0-9_\-./]+\.[a-zA-Z]{1,6})`/g,a=new Set;for(let c of n.planDoc.matchAll(i))a.add(c[1]);a.size>0&&o.push(`**Scoped Files**: ${[...a].slice(0,20).map(c=>`\`${c}\``).join(", ")}`)}break}return o.join(`
1490
+ `)}catch{return null}}l(xT,"buildRpiSection");function hf(r){if(r<60)return`${r}m`;let e=Math.floor(r/60),t=r%60;return t>0?`${e}h ${t}m`:`${e}h`}l(hf,"formatMinutesToDuration");async function RT(r){try{let e=CT.join(r,"analysis","repo-analysis.json"),t=await vT.readFile(e,"utf-8");return JSON.parse(t)}catch(e){return R(e),null}}l(RT,"loadRepoAnalysis");function AT(r,e){let t=e.filter(d=>d.type==="gate"&&d.position==="before"),s=e.filter(d=>d.type==="instruction"&&d.position==="before"),n=e.filter(d=>d.type==="hook"&&d.position==="before"),o=e.filter(d=>d.type==="step"&&d.position==="before"),i=e.filter(d=>d.type==="instruction"&&d.position==="after"),a=e.filter(d=>d.type==="hook"&&d.position==="after"),c=e.filter(d=>d.type==="step"&&d.position==="after"),u=[],p=l((d,g,h)=>{let k=g.map(U=>` ${U.enabled?h:"o"} #${U.id} ${U.action}`),y=[d,...k],D=Math.max(...y.map(U=>U.length))+2;u.push(`+${"-".repeat(D)}+`);for(let U of y)u.push(`| ${U.padEnd(D-1)}|`);u.push(`+${"-".repeat(D)}+`)},"drawBox"),m=l(d=>{d.push(" |"),d.push(" v")},"arrow");return t.length>0&&(p("GATES (must pass)",t,"#"),m(u)),s.length>0&&(p("INSTRUCTIONS (before)",s,"\u{1F4CB}"),m(u)),n.length>0&&(p("HOOKS (before)",n,">"),m(u)),o.length>0&&(p("STEPS (before)",o,">"),m(u)),u.push(` [ ${r.toUpperCase()} ]`),i.length>0&&(m(u),p("INSTRUCTIONS (after)",i,"\u{1F4CB}")),a.length>0&&(m(u),p("HOOKS (after)",a,">")),c.length>0&&(m(u),p("STEPS (after)",c,">")),u.join(`
1491
+ `)}l(AT,"buildFlowDiagram");async function DT(r,e){let{execSync:t}=await import("node:child_process"),s=new Set,n={cwd:r,encoding:"utf-8"};try{let o=t(`git log --since="${e}" --name-only --pretty=format:""`,n);for(let i of o.split(`
1467
1492
  `)){let a=i.trim();a&&s.add(a)}}catch{}try{let o=t("git diff --cached --name-only",n);for(let i of o.split(`
1468
1493
  `)){let a=i.trim();a&&s.add(a)}}catch{}try{let o=t("git diff --name-only",n);for(let i of o.split(`
1469
- `)){let a=i.trim();a&&s.add(a)}}catch{}return[...s]}l(Ev,"getFilesModifiedSinceTaskStart");function xv(r){let e=r>=0?"+":"-",t=Math.abs(r);if(t>=60){let s=Math.floor(t/60),n=t%60;return n>0?`${e}${s}h ${n}m`:`${e}${s}h`}return`${e}${t}m`}l(xv,"formatVariance");var Yn=class{static{l(this,"PrjctCommands")}workflow;planning;shipping;analytics;performanceCmds;maintenance;analysis;setupCmds;updateCmds;velocityCmds;contextCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new Xn,this.planning=new tn,this.shipping=new Vn,this.analytics=new On,this.performanceCmds=new Ln,this.maintenance=new Nn,this.analysis=new rn,this.setupCmds=new Un,this.updateCmds=new Jn,this.velocityCmds=new zn,this.contextCmds=new on,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 done(e=process.cwd(),t={}){return this.workflow.done(e,t)}async next(e=process.cwd(),t={}){return this.workflow.next(e,t)}async pause(e="",t=process.cwd(),s={}){return this.workflow.pause(e,t,s)}async resume(e=null,t=process.cwd(),s={}){return this.workflow.resume(e,t,s)}async workflowPrefs(e=null,t=process.cwd(),s={}){return this.workflow.workflow(e,t,s)}async sessions(e=process.cwd(),t={}){return this.workflow.sessions(e,t)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async bug(e,t=process.cwd(),s={}){return this.planning.bug(e,t,s)}async idea(e,t=process.cwd(),s={}){return this.planning.idea(e,t,s)}async spec(e=null,t=process.cwd()){return this.planning.spec(e,t)}async ship(e,t=process.cwd(),s={}){return this.shipping.ship(e,t,{...s})}async dash(e="default",t=process.cwd(),s={}){return this.analytics.dash(e,t,s)}async help(e="",t=process.cwd()){return this.analytics.help(e,t)}async perf(e="7",t=process.cwd()){return this.performanceCmds.perf(e,t)}async velocity(e="0",t=process.cwd()){return this.velocityCmds.velocity(e,t)}async cleanup(e={},t=process.cwd()){return this.maintenance.cleanup(e,t)}async cleanupProjects(e={}){return this.maintenance.cleanupProjects(e)}async design(e=null,t={},s=process.cwd()){return this.maintenance.design(e,t,s)}async recover(e=process.cwd()){return this.maintenance.recover(e)}async undo(e=process.cwd()){return this.maintenance.undo(e)}async redo(e=process.cwd()){return this.maintenance.redo(e)}async history(e=process.cwd()){return this.maintenance.history(e)}async enrich(e=null,t=process.cwd(),s={}){return this.maintenance.enrich(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 stats(e=process.cwd(),t={}){return this.analysis.stats(e,t)}async status(e=process.cwd(),t={}){return this.analysis.status(e,t)}async diff(e=process.cwd(),t={}){return this.analysis.diff(e,t)}async seal(e=process.cwd(),t={}){return this.analysis.seal(e,t)}async rollback(e=process.cwd(),t={}){return this.analysis.rollback(e,t)}async verify(e=process.cwd(),t={}){return this.analysis.verify(e,t)}async analysisPayload(e=process.cwd(),t={}){return this.analysis.analysisPayload(e,t)}async saveLlmAnalysis(e,t=process.cwd(),s={}){return this.analysis.saveLlmAnalysis(e,t,s)}async getLlmAnalysis(e=process.cwd(),t={}){return this.analysis.getLlmAnalysis(e,t)}async context(e=null,t=process.cwd()){return this.contextCmds.context(e,t)}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)}},H1=new Yn;ci();var mf={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}},gf=[{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:"idea",group:"core",description:"Transform ideas into complete technical architectures",usage:{claude:'/p:idea "build a CRM"',terminal:'prjct idea "build a CRM"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Simple ideas -> Quick capture","Complex ideas -> Full architecture"]},{name:"task",group:"core",description:"Start task with agentic classification and 7-phase workflow",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Agentic type classification","7-phase workflow","Git branch management","Task breakdown"]},{name:"spec",group:"core",description:"Create detailed specifications for complex features",usage:{claude:'/p:spec "Dark Mode"',terminal:'prjct spec "Dark Mode"'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"pause",group:"core",description:"Pause active task to handle interruption",usage:{claude:'/p:pause ["reason"]',terminal:'prjct pause ["reason"]'},params:"[reason]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,blockingRules:{check:"Active task exists",message:"No active task to pause"}},{name:"resume",group:"core",description:"Resume paused task or recover abandoned session",usage:{claude:"/p:resume",terminal:"prjct resume"},params:"[task_id]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"next",group:"core",description:"Show priority queue or roadmap view",usage:{claude:"/p:next",terminal:"prjct next"},params:"[roadmap]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"done",group:"core",description:"Mark current task as complete",usage:{claude:"/p:done",terminal:"prjct done"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{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},{name:"bug",group:"core",description:"Report and track bugs with priority",usage:{claude:'/p:bug "description"',terminal:'prjct bug "description"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"dash",group:"core",description:"Unified dashboard - status, progress, and roadmap",usage:{claude:"/p:dash [view]",terminal:"prjct dash [view]"},params:"[week|month|roadmap|compact]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"stats",group:"core",description:"Value dashboard - token savings, performance, and impact",usage:{claude:"/p:stats",terminal:"prjct stats"},params:"[--json] [--export]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Token savings tracking","Compression metrics","Cost estimates","30-day trends"]},{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:"perf",group:"core",description:"Performance dashboard - startup, memory, context, and handoff metrics",usage:{claude:"/p:perf",terminal:"prjct perf [days]"},params:"[days]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Startup time tracking","Memory usage snapshots","Context correctness rate","Subtask handoff rate","Command duration breakdown"]},{name:"velocity",group:"core",description:"Sprint-based velocity dashboard with trend detection and projections",usage:{claude:"/p:velocity",terminal:"prjct velocity [backlogPoints]"},params:"[backlogPoints]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Sprint-by-sprint velocity breakdown","Trend detection (improving/stable/declining)","Estimation accuracy tracking","Over/under estimation pattern detection","Completion projections for backlog"]},{name:"tokens",group:"core",description:"Record token usage (input + output) on the active task",usage:{claude:"/p:tokens",terminal:"prjct tokens <in> <out>"},params:"<input_tokens> <output_tokens>",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!1,features:["Accumulates tokens per task","Persisted to task history on completion","Enables cost comparison across tasks"]},{name:"sessions",group:"core",description:"Show recent sessions across all projects with resume context",usage:{claude:"/p:sessions",terminal:"prjct sessions [--cleanup]"},params:"[--cleanup]",implemented:!0,hasTemplate:!1,requiresProject:!1,requiresLlm:!0,features:["Cross-project session listing","Resume context with LLM hints","Auto-cleanup of stale snapshots"]},{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:"Check if CLAUDE.md context is stale and needs resync",usage:{claude:"/p:status",terminal:"prjct status"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares current HEAD with last sync commit","Counts commits and days since sync","Detects significant file changes","Configurable staleness thresholds"]},{name:"diff",group:"core",description:"Show diff between draft and sealed analysis runs",usage:{claude:"/p:diff",terminal:"prjct diff"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares draft vs sealed analysis field-by-field","Shows languages, frameworks, patterns, file count changes","Markdown and JSON output modes"]},{name:"seal",group:"core",description:"Seal the current draft analysis with a commit-hash signature",usage:{claude:"/p:seal",terminal:"prjct seal"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Locks draft analysis with SHA-256 signature","Only sealed analysis feeds task context","Detects staleness when HEAD moves past sealed commit"]},{name:"rollback",group:"core",description:"Rollback to the previous sealed analysis version",usage:{claude:"/p:rollback",terminal:"prjct rollback"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Restores previous sealed version as active","Current sealed moves to draft (recoverable)","One level of rollback supported"]},{name:"verify",group:"core",description:"Verify integrity of sealed analysis",usage:{claude:"/p:verify",terminal:"prjct verify"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Recomputes SHA-256 signature and compares","Detects if sealed analysis was modified"]},{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:"design",group:"optional",description:"Design system architecture, APIs, and components",usage:{claude:"/p:design [target]",terminal:"prjct design [target]"},params:"[target] --type architecture|api|component",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"cleanup",group:"optional",description:"Clean up temp files and old entries",usage:{claude:"/p:cleanup",terminal:"prjct cleanup"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"cleanup-projects",group:"optional",description:"Remove stale/test project directories",usage:{claude:"/p:cleanup-projects",terminal:"prjct cleanup-projects [--dry-run]"},params:"[--dry-run] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!1,isOptional:!0},{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:"enrich",group:"optional",description:"Build enrichment context for an issue or request",usage:{claude:'/p:enrich "<issue-or-description>"',terminal:'prjct enrich "<input>"'},params:"<issue_or_description>",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"undo",group:"optional",description:"Revert to previous snapshot",usage:{claude:"/p:undo",terminal:"prjct undo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Git-based snapshots","Preserves redo history"]},{name:"redo",group:"optional",description:"Redo previously undone changes",usage:{claude:"/p:redo",terminal:"prjct redo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"history",group:"optional",description:"View snapshot history",usage:{claude:"/p:history",terminal:"prjct history"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"recover",group:"optional",description:"Recover abandoned session with context",usage:{claude:"/p:recover",terminal:"prjct recover"},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:"linear",group:"optional",description:"Linear integration via MCP (setup/status + delegated operations)",usage:{claude:"/p:linear [command]",terminal:"prjct linear [command]"},params:"[setup|status|sync|list|get|create|update|start|done|comment|teams|projects]",implemented:!0,hasTemplate:!0,requiresProject:!1,isOptional:!0,requiresLlm:!0},{name:"jira",group:"optional",description:"Jira integration via MCP (setup/status + delegated operations)",usage:{claude:"/p:jira [command]",terminal:"prjct jira [command]"},params:"[setup|status|sync|list|get|create|update|start|done|transition|comment|projects|boards]",implemented:!0,hasTemplate:!0,requiresProject:!1,isOptional:!0,requiresLlm:!0},{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"]}];ai();os();ve();V();q();lt();import{execSync as Ci}from"node:child_process";import kt from"node:fs/promises";import Rv from"node:os";import ps from"node:path";import Av from"node:readline";import Pe from"chalk";var Pi="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",Hr="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";async function hf(r){let e=0;try{let t=await kt.readdir(r,{withFileTypes:!0});for(let s of t){let n=ps.join(r,s.name);if(s.isDirectory())e+=await hf(n);else try{let o=await kt.stat(n);e+=o.size}catch{}}}catch{}return e}l(hf,"getDirectorySize");function ff(r){if(r===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));return`${(r/1024**t).toFixed(1)} ${e[t]}`}l(ff,"formatSize");async function Dv(r){try{return(await kt.readdir(r,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}l(Dv,"countDirectoryItems");function jv(){let r={homebrew:!1,npm:!1};try{Ci("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(r.homebrew=!0,r.homebrewFormula="prjct-cli")}catch{}try{Ci("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(r.npm=!0)}catch{}return r}l(jv,"detectInstallation");async function Iv(){let r=[],e=Au(),t=A.getGlobalBasePath(),s=await C(t),n=s?await Dv(ps.join(t,"projects")):0,o=s?await hf(t):0;r.push({path:t,type:"directory",description:`All project data${n>0?`, ${n} project${n>1?"s":""}`:""}`,size:o,count:n,exists:s});let i=ps.join(e.claude.config,"CLAUDE.md"),a=await C(i),c=!1;if(a)try{let E=await kt.readFile(i,"utf-8");c=E.includes(Pi)&&E.includes(Hr)}catch{}r.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&c});let u=e.claude.router,p=await C(u);r.push({path:u,type:"file",description:"Claude router",exists:p});let m=ps.join(e.claude.config,"prjct-statusline.sh"),d=await C(m);r.push({path:m,type:"file",description:"Status line script",exists:d});let g=e.gemini.router,h=await C(g);r.push({path:g,type:"file",description:"Gemini router",exists:h});let k=ps.join(e.gemini.config,"GEMINI.md"),w=await C(k),T=!1;if(w)try{let E=await kt.readFile(k,"utf-8");T=E.includes(Pi)&&E.includes(Hr)}catch{}return w&&T&&r.push({path:k,type:"section",description:"prjct section in GEMINI.md",exists:!0}),r}l(Iv,"gatherUninstallItems");async function $v(r){try{let e=await kt.readFile(r,"utf-8");if(!e.includes(Pi)||!e.includes(Hr))return!1;let t=e.indexOf(Pi),s=e.indexOf(Hr)+Hr.length,n=e.substring(0,t)+e.substring(s);return n=n.replace(/\n{3,}/g,`
1470
-
1471
- `).trim(),!n||n.trim().length===0?await kt.unlink(r):await kt.writeFile(r,`${n}
1472
- `,"utf-8"),!0}catch{return!1}}l($v,"removePrjctSection");async function Mv(){let r=Rv.homedir(),e=new Date().toISOString().replace(/[:.]/g,"-").substring(0,19),t=ps.join(r,`.prjct-backup-${e}`);try{await kt.mkdir(t,{recursive:!0});let s=A.getGlobalBasePath();return await C(s)&&await yf(s,ps.join(t,".prjct-cli")),t}catch{return null}}l(Mv,"createBackup");async function yf(r,e){await kt.mkdir(e,{recursive:!0});let t=await kt.readdir(r,{withFileTypes:!0});for(let s of t){let n=ps.join(r,s.name),o=ps.join(e,s.name);s.isDirectory()?await yf(n,o):await kt.copyFile(n,o)}}l(yf,"copyDirectory");async function Ov(r,e,t){let s=[],n=[];for(let o of r)if(o.exists)try{o.type==="section"?await $v(o.path)&&s.push(o.path):o.type==="directory"?(await kt.rm(o.path,{recursive:!0,force:!0}),s.push(o.path)):o.type==="file"&&(await kt.unlink(o.path),s.push(o.path))}catch(i){n.push(`${o.path}: ${y(i)}`)}try{await new rs().cleanupLegacyCommands()}catch{}if(!t.keepPackage){if(e.homebrew&&e.homebrewFormula)try{t.dryRun||Ci(`brew uninstall ${e.homebrewFormula}`,{stdio:"pipe"}),s.push("Homebrew: prjct-cli")}catch(o){n.push(`Homebrew: ${y(o)}`)}if(e.npm)try{t.dryRun||Ci("npm uninstall -g prjct-cli",{stdio:"pipe"}),s.push("npm: prjct-cli")}catch(o){n.push(`npm: ${y(o)}`)}}return{deleted:s,errors:n}}l(Ov,"performUninstall");async function _v(r){let e=Av.createInterface({input:process.stdin,output:process.stdout});return new Promise(t=>{e.question(r,s=>{e.close(),t(s.toLowerCase()==="uninstall")})})}l(_v,"promptConfirmation");async function Nv(r={},e=process.cwd()){let t=await Iv(),s=jv(),n=t.filter(c=>c.exists);if(n.length===0&&!s.homebrew&&!s.npm)return console.log(Pe.yellow(`
1473
- No prjct installation found.`)),{success:!0,message:"Nothing to uninstall"};let o=n.reduce((c,u)=>c+(u.size||0),0);console.log(""),console.log(Pe.red.bold(" WARNING: This action is DANGEROUS and IRREVERSIBLE")),console.log(""),console.log(Pe.white("The following will be permanently deleted:")),console.log("");for(let c of n){let u=A.getDisplayPath(c.path),p="";c.type==="section"?p=Pe.dim("(section only)"):c.size&&(p=Pe.dim(`(${ff(c.size)})`)),console.log(` ${Pe.cyan(u.padEnd(35))} ${p}`),console.log(` ${Pe.dim(c.description)}`),console.log("")}if(s.homebrew&&(console.log(` ${Pe.cyan("Homebrew".padEnd(35))} ${Pe.dim("prjct-cli formula")}`),console.log("")),s.npm&&(console.log(` ${Pe.cyan("npm global".padEnd(35))} ${Pe.dim("prjct-cli package")}`),console.log("")),o>0&&(console.log(Pe.dim(` Total size: ${ff(o)}`)),console.log("")),r.dryRun)return console.log(Pe.yellow("Dry run - no changes made")),{success:!0,message:"Dry run complete",itemsFound:n.length};if(r.backup){console.log(Pe.blue("Creating backup..."));let c=await Mv();c?(console.log(Pe.green(`Backup created: ${A.getDisplayPath(c)}`)),console.log("")):console.log(Pe.yellow("Failed to create backup, continuing..."))}if(!r.force&&(console.log(Pe.yellow('Type "uninstall" to confirm:')),!await _v("> ")))return console.log(Pe.yellow(`
1474
- Uninstall cancelled.`)),{success:!1,message:"Uninstall cancelled by user"};console.log(""),console.log(Pe.blue("Removing prjct..."));let{deleted:i,errors:a}=await Ov(t,s,r);if(console.log(""),i.length>0&&console.log(Pe.green(`Removed ${i.length} items`)),a.length>0){console.log(Pe.yellow(`
1475
- ${a.length} errors:`));for(let c of a)console.log(Pe.red(` - ${c}`))}return console.log(""),console.log(Pe.green("prjct has been uninstalled.")),console.log(Pe.dim("Thanks for using prjct! We hope to see you again.")),console.log(""),{success:a.length===0,message:`Removed ${i.length} items`,deleted:i,errors:a.length>0?a:void 0}}l(Nv,"uninstall");var Ei=class extends Ce{static{l(this,"UninstallCommands")}async uninstall(e={},t=process.cwd()){return Nv(e,t)}};var As=new Xn,xi=new tn,Lv=new Vn,wf=new On,Fv=new Ln,Ds=new Nn,Qn=new rn,Gr=new Un,Uv=new on,Hv=new zn,Gv=new Ei,Vv=new Jn;function Wv(){for(let[r,e]of Object.entries(mf))G.registerCategory(r,e)}l(Wv,"registerCategories");function Bv(){if(G.has("work"))return;Wv();let r=l(e=>gf.find(t=>t.name===e),"getMeta");G.registerMethod("task",As,"now",r("task")),G.registerMethod("done",As,"done",r("done")),G.registerMethod("next",As,"next",r("next")),G.registerMethod("pause",As,"pause",r("pause")),G.registerMethod("resume",As,"resume",r("resume")),G.registerMethod("workflow",As,"workflow",r("workflow")),G.registerMethod("tokens",As,"tokens",r("tokens")),G.registerMethod("sessions",As,"sessions",r("sessions")),G.registerMethod("init",xi,"init",r("init")),G.registerMethod("bug",xi,"bug",r("bug")),G.registerMethod("idea",xi,"idea",r("idea")),G.registerMethod("spec",xi,"spec",r("spec")),G.registerMethod("ship",Lv,"ship",r("ship")),G.registerMethod("dash",wf,"dash",r("dash")),G.registerMethod("help",wf,"help",r("help")),G.registerMethod("perf",Fv,"perf",r("perf")),G.registerMethod("velocity",Hv,"velocity",r("velocity")),G.registerMethod("cleanup",Ds,"cleanup",r("cleanup")),G.registerMethod("cleanup-projects",Ds,"cleanupProjects",r("cleanup-projects")),G.registerMethod("design",Ds,"design",r("design")),G.registerMethod("recover",Ds,"recover",r("recover")),G.registerMethod("undo",Ds,"undo",r("undo")),G.registerMethod("redo",Ds,"redo",r("redo")),G.registerMethod("history",Ds,"history",r("history")),G.registerMethod("enrich",Ds,"enrich",r("enrich")),G.registerMethod("analyze",Qn,"analyze",r("analyze")),G.registerMethod("sync",Qn,"sync",r("sync")),G.registerMethod("stats",Qn,"stats",r("stats")),G.registerMethod("status",Qn,"status",r("status")),G.registerMethod("seal",Qn,"seal",r("seal")),G.registerMethod("verify",Qn,"verify",r("verify")),G.registerMethod("start",Gr,"start",r("start")),G.registerMethod("setup",Gr,"setup",r("setup")),G.registerMethod("login",Gr,"login",r("login")),G.registerMethod("logout",Gr,"logout",r("logout")),G.registerMethod("auth",Gr,"auth",r("auth")),G.registerMethod("uninstall",Gv,"uninstall",r("uninstall")),G.registerMethod("update",Vv,"update",r("update")),G.registerMethod("context",Uv,"context",r("context"))}l(Bv,"registerAllCommands");Bv();Et();ar();Ct();import{Hono as sT}from"hono";import{cors as nT}from"hono/cors";import{logger as rT}from"hono/logger";ve();ce();ks();Xt();Js();Pt();V();ns();import Jv from"node:fs/promises";import zv from"node:path";import{Hono as qv}from"hono";function Kv(r){return A.getGlobalProjectPath(r)}l(Kv,"getProjectDataPath");function kf(r,e){let t=new qv,s=Kv(r);return t.get("/state",async n=>{let o=await _.read(r);return n.json(o)}),t.get("/queue",async n=>{let o=await be.read(r);return n.json(o)}),t.get("/ideas",async n=>{let o=await He.read(r);return n.json(o)}),t.get("/roadmap",async n=>{let o=P.getDoc(r,"roadmap");return o?n.json(o):n.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async n=>{let o=await et.read(r);return n.json(o)}),t.get("/dashboard",async n=>{let[o,i,a,c]=await Promise.all([_.read(r),be.read(r),He.read(r),et.read(r)]),u=P.getDoc(r,"roadmap");return n.json({projectId:r,state:o,queue:i,ideas:a,roadmap:u||{features:[],backlog:[],lastUpdated:""},shipped:c,timestamp:new Date().toISOString()})}),t.post("/state",async n=>{try{let o=await n.req.json();return await _.write(r,o),n.json({success:!0})}catch(o){return n.json({success:!1,error:String(o)},400)}}),t.get("/context/:name",async n=>{let o=n.req.param("name");if(!["now","next","ideas","shipped"].includes(o))return n.json({error:"Invalid context file"},400);try{let a=zv.join(s,"context",`${o}.md`),c=await Jv.readFile(a,"utf-8");return n.text(c,200,{"Content-Type":"text/markdown"})}catch(a){return R(a)||W.error(`Context read error: ${y(a)}`),n.text("",200,{"Content-Type":"text/markdown"})}}),t}l(kf,"createRoutes");ve();ce();ks();Xt();Js();Pt();import Zn from"node:fs/promises";import Xv from"node:path";import{Hono as Yv}from"hono";var Qv=A.getGlobalBasePath(),er=Xv.join(Qv,"projects");function Ri(r){return P.getDoc(r,"project")}l(Ri,"getProjectConfig");async function ql(r){if(!r)return"";let e=new Date(r),s=new Date().getTime()-e.getTime(),n=Math.floor(s/(1e3*60*60)),o=Math.floor(s%(1e3*60*60)/(1e3*60));return n>0?`${n}h ${o}m`:`${o}m`}l(ql,"calculateDuration");function Sf(){let r=new Yv;return r.get("/projects",async e=>{try{await Zn.mkdir(er,{recursive:!0});let s=(await Zn.readdir(er,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),n=await Promise.all(s.map(async o=>{let i=Ri(o),a=await _.read(o),c=await be.read(o),u=await He.read(o),p=await et.read(o),m=a?.currentTask,d=await ql(m?.startedAt);return{id:o,name:i?.name||o.slice(0,8),path:i?.path||null,currentTask:m?{...m,duration:d}:null,pausedTask:a?.previousTask||null,stats:{queueCount:c?.tasks?.filter(g=>!g.completed)?.length||0,ideasCount:u?.ideas?.filter(g=>g.status==="pending")?.length||0,shippedCount:p?.shipped?.length||0}}}));return n.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:(o.name||"").localeCompare(i.name||"")),e.json({projects:n})}catch(t){return e.json({projects:[],error:String(t)},500)}}),r.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[s,n,o,i,a]=await Promise.all([Promise.resolve(Ri(t)),_.read(t),be.read(t),He.read(t),et.read(t)]),c=P.getDoc(t,"roadmap");n?.currentTask?.startedAt&&(n.currentTask.duration=await ql(n.currentTask.startedAt));let u=new Date,p=new Date(u.getFullYear(),u.getMonth(),u.getDate()),m=new Date(p);m.setDate(m.getDate()-m.getDay());let d=o?.tasks?.filter(h=>!h.completed||!h.completedAt?!1:new Date(h.completedAt)>=p)?.length||0,g=o?.tasks?.filter(h=>!h.completed||!h.completedAt?!1:new Date(h.completedAt)>=m)?.length||0;return e.json({id:t,name:s?.name||t,path:s?.path,state:n||{currentTask:null,previousTask:null,lastUpdated:""},queue:o||{tasks:[],lastUpdated:""},ideas:i||{ideas:[],lastUpdated:""},shipped:a||{shipped:[],lastUpdated:""},roadmap:c||{features:[],backlog:[],lastUpdated:""},stats:{tasksToday:d,tasksThisWeek:g,queueCount:o?.tasks?.filter(h=>!h.completed)?.length||0,ideasCount:i?.ideas?.filter(h=>h.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch(s){return e.json({error:String(s)},500)}}),r.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let s=await _.read(t);if(!s?.currentTask)return e.json({success:!1,error:"No active task"},400);let n=s.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await _.write(t,o),e.json({success:!0,completedTask:n,message:`Completed: ${n.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let n=(await e.req.json().catch(()=>({}))).reason,o=await _.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:n},a={currentTask:null,previousTask:i,lastUpdated:new Date().toISOString()};return await _.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let s=await _.read(t);if(!s?.previousTask)return e.json({success:!1,error:"No paused task"},400);let n={id:s.previousTask.id,description:s.previousTask.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`},o={currentTask:n,previousTask:null,lastUpdated:new Date().toISOString()};return await _.write(t,o),e.json({success:!0,resumedTask:n,message:`Resumed: ${n.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{taskId:n}=s;if(!n)return e.json({success:!1,error:"taskId required"},400);let[o,i]=await Promise.all([_.read(t),be.read(t)]);if(o?.currentTask)return e.json({success:!1,error:"Complete or pause current task first"},400);let a=i?.tasks?.find(p=>p.id===n);if(!a)return e.json({success:!1,error:"Task not found in queue"},404);let c={id:a.id,description:a.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`,featureId:a.featureId},u={currentTask:c,previousTask:null,lastUpdated:new Date().toISOString()};return await _.write(t,u),e.json({success:!0,task:c,message:`Started: ${c.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{text:n,priority:o="medium",tags:i=[]}=s;if(!n)return e.json({success:!1,error:"text required"},400);let a=await He.addIdea(t,n,{priority:o||"medium",tags:i});return e.json({success:!0,idea:a,message:`Captured: ${n.slice(0,50)}...`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.get("/stats/global",async e=>{try{await Zn.mkdir(er,{recursive:!0});let s=(await Zn.readdir(er,{withFileTypes:!0})).filter(c=>c.isDirectory()).map(c=>c.name),n=0,o=0,i=0,a=0;for(let c of s){let u=await _.read(c),p=await be.read(c),m=await He.read(c),d=await et.read(c);u?.currentTask&&a++,n+=p?.tasks?.filter(g=>!g.completed)?.length||0,o+=m?.ideas?.filter(g=>g.status==="pending")?.length||0,i+=d?.shipped?.length||0}return e.json({totalProjects:s.length,activeProjects:a,totalTasks:n,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),r.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await Zn.mkdir(er,{recursive:!0});let n=(await Zn.readdir(er,{withFileTypes:!0})).filter(p=>p.isDirectory()).map(p=>p.name),o=null;if(t)for(let p of n){let m=Ri(p),d=m?.repoPath||m?.path;if(d&&t.startsWith(d)){o=p;break}}let i=null,a=null,c=null,u=o?[o]:n;for(let p of u){let m=await _.read(p),d=Ri(p);if(m?.currentTask){i={id:p,name:d?.name||p,path:d?.repoPath||d?.path},a={...m.currentTask,duration:await ql(m.currentTask.startedAt)};break}m?.previousTask&&!c&&(i={id:p,name:d?.name||p,path:d?.repoPath||d?.path},c=m.previousTask)}return e.json({hasActiveTask:!!a,hasPausedTask:!!c,activeProject:i,activeTask:a,pausedTask:c,totalProjects:n.length,filtered:!!o,cwd:t||null,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),r}l(Sf,"createExtendedRoutes");import{streamSSE as Zv}from"hono/streaming";var bf=3600*1e3,eT=300*1e3,tT=3e4;function vf(){let r=new Map,e=null;function t(o){let i=r.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),r.delete(o))}l(t,"removeClient");function s(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of r)o-new Date(a.client.connectedAt).getTime()>bf&&t(i)},eT),e&&typeof e=="object"&&"unref"in e&&e.unref())}l(s,"startReaper");function n(){e&&(clearInterval(e),e=null)}return l(n,"stopReaper"),s(),{handleConnection(o){return Zv(o,async i=>{let a=crypto.randomUUID(),c=new Date().toISOString(),u=new AbortController,p={id:a,connectedAt:c,send:l((g,h)=>{i.writeSSE({event:g,data:JSON.stringify(h)})},"send"),close:l(()=>{t(a)},"close")},m=setInterval(async()=>{try{await i.writeSSE({event:"heartbeat",data:JSON.stringify({timestamp:new Date().toISOString()})})}catch{t(a)}},tT),d=setTimeout(()=>{t(a)},bf);typeof m=="object"&&"unref"in m&&m.unref(),typeof d=="object"&&"unref"in d&&d.unref(),r.set(a,{client:p,heartbeatInterval:m,ttlTimeout:d,abortController:u}),await i.writeSSE({event:"connected",data:JSON.stringify({clientId:a,timestamp:c,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[c,u]of r)try{u.client.send(o,a)}catch{t(c)}},getClientCount(){return r.size},shutdown(){n();for(let o of[...r.keys()])t(o)}}}l(vf,"createSSEManager");function Tf(r){let e=new sT,t=vf();r.enableCors!==!1&&e.use("*",nT({origin:"*",allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type","Authorization"]})),r.enableLogging!==!1&&e.use("*",rT()),e.get("/health",i=>i.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/",i=>i.json({name:"prjct-cli",version:Ae,projectId:r.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=kf(r.projectId,r.projectPath);e.route("/api",s);let n=Sf();e.route("/api",n),e.get("/api/events",i=>t.handleConnection(i));let o=null;return{app:e,async start(){let i=r.port,a=r.host||"0.0.0.0";if(_s())o=Bun.serve({port:i,hostname:a,fetch:e.fetch});else{let{serve:c}=await import("@hono/node-server"),u=c({fetch:e.fetch,port:i,hostname:a});o={stop:l(()=>u.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${a}:${i}`),console.log(` Project: ${r.projectId}`),console.log(` Runtime: ${_s()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${i}`)},stop(){t.shutdown(),o&&(o.stop(),o=null,console.log("Server stopped"))},broadcast(i,a){t.broadcast(i,a)}}}l(Tf,"createServer");var Cf=3478;ce();Ll();var iT=50,tr=null,Vr=null,he=null,Ee=null;async function Pf(r){let e=Ne.socket(),t=Ne.pid(),s=Ne.runDir();if(Le.mkdirSync(s,{recursive:!0}),Le.existsSync(t)){let i=parseInt(Le.readFileSync(t,"utf-8").trim(),10);dT(i)&&(console.error(`Daemon already running (PID ${i})`),process.exit(1)),Le.unlinkSync(t)}Le.existsSync(e)&&Le.unlinkSync(e),gT();let n=pT(),o=null;if(n)try{o=Le.statSync(n).mtimeMs}catch{}if(Ee={startedAt:Date.now(),commandsServed:0,lastActivity:Date.now(),idleTimeoutMs:qg,idleTimer:null,entryPath:n,entryMtime:o},he=new Yn,tr=oT(i=>aT(i)),tr.listen(e,()=>{Le.chmodSync(e,384),Le.writeFileSync(t,String(process.pid)),console.log(`prjct daemon started (PID ${process.pid})`),console.log(` Socket: ${e}`),n&&console.log(` Watching: ${n}`),Ef()}),tr.on("error",i=>{console.error("Daemon socket error:",i.message),sr(1)}),!r.noHttp)try{let i=process.cwd(),a=await I.getProjectId(i);if(a){let c=r.port||Cf;Vr=Tf({port:c,projectId:a,projectPath:i,enableLogging:!1}),await Vr.start()}}catch{}if(process.on("SIGTERM",()=>sr(0)),process.on("SIGINT",()=>sr(0)),process.on("SIGHUP",()=>{he=new Yn,console.log("Daemon reloaded (SIGHUP)")}),!r.foreground)try{process.stdin?.unref?.()}catch{}}l(Pf,"startDaemon");function aT(r){let e="";r.on("data",async t=>{if(e+=t.toString(),e.length>Kg){let n={id:"unknown",success:!1,exitCode:1,stderr:"Request too large"};r.write(Wn(n)),r.destroy(),e="";return}let s;for(;(s=e.indexOf(`
1476
- `))!==-1;){let n=e.slice(0,s);if(e=e.slice(s+1),!!n.trim())try{let o=JSON.parse(n),i=await cT(o);r.write(Wn(i))}catch(o){let i={id:"unknown",success:!1,exitCode:1,stderr:`Protocol error: ${o.message}`};r.write(Wn(i))}}}),r.on("error",()=>{})}l(aT,"handleConnection");async function cT(r){if(!Ee||!he)return{id:r.id,success:!1,exitCode:1,stderr:"Daemon not initialized"};if(Ef(),Ee.commandsServed++,Ee.lastActivity=Date.now(),Ee.commandsServed%iT===0&&F.checkpointAll(),xf()&&(console.log("Build changed detected \u2014 daemon will restart after this request"),setTimeout(()=>{console.log("Daemon shutting down for code reload..."),sr(0)},200)),r.command==="daemon")return uT(r);if(r.command==="__ping")return{id:r.id,success:!0,exitCode:0,result:{pong:!0,pid:process.pid}};try{let e=[],t=[],s=console.log,n=console.error;console.log=(...o)=>e.push(o.map(String).join(" ")),console.error=(...o)=>t.push(o.map(String).join(" "));try{let o=await lT(r);return{id:r.id,success:o.success,exitCode:o.success?0:1,stdout:e.join(`
1494
+ `)){let a=i.trim();a&&s.add(a)}}catch{}return[...s]}l(DT,"getFilesModifiedSinceTaskStart");function jT(r){let e=r>=0?"+":"-",t=Math.abs(r);if(t>=60){let s=Math.floor(t/60),n=t%60;return n>0?`${e}${s}h ${n}m`:`${e}${s}h`}return`${e}${t}m`}l(jT,"formatVariance");var Yn=class{static{l(this,"PrjctCommands")}workflow;planning;shipping;analytics;performanceCmds;maintenance;analysis;setupCmds;updateCmds;velocityCmds;contextCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new Xn,this.planning=new sn,this.shipping=new Wn,this.analytics=new _n,this.performanceCmds=new Ln,this.maintenance=new Nn,this.analysis=new on,this.setupCmds=new Un,this.updateCmds=new zn,this.velocityCmds=new Jn,this.contextCmds=new an,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 done(e=process.cwd(),t={}){return this.workflow.done(e,t)}async next(e=process.cwd(),t={}){return this.workflow.next(e,t)}async pause(e="",t=process.cwd(),s={}){return this.workflow.pause(e,t,s)}async resume(e=null,t=process.cwd(),s={}){return this.workflow.resume(e,t,s)}async workflowPrefs(e=null,t=process.cwd(),s={}){return this.workflow.workflow(e,t,s)}async sessions(e=process.cwd(),t={}){return this.workflow.sessions(e,t)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async bug(e,t=process.cwd(),s={}){return this.planning.bug(e,t,s)}async idea(e,t=process.cwd(),s={}){return this.planning.idea(e,t,s)}async spec(e=null,t=process.cwd()){return this.planning.spec(e,t)}async ship(e,t=process.cwd(),s={}){return this.shipping.ship(e,t,{...s})}async dash(e="default",t=process.cwd(),s={}){return this.analytics.dash(e,t,s)}async help(e="",t=process.cwd()){return this.analytics.help(e,t)}async perf(e="7",t=process.cwd()){return this.performanceCmds.perf(e,t)}async velocity(e="0",t=process.cwd()){return this.velocityCmds.velocity(e,t)}async cleanup(e={},t=process.cwd()){return this.maintenance.cleanup(e,t)}async cleanupProjects(e={}){return this.maintenance.cleanupProjects(e)}async design(e=null,t={},s=process.cwd()){return this.maintenance.design(e,t,s)}async recover(e=process.cwd()){return this.maintenance.recover(e)}async undo(e=process.cwd()){return this.maintenance.undo(e)}async redo(e=process.cwd()){return this.maintenance.redo(e)}async history(e=process.cwd()){return this.maintenance.history(e)}async enrich(e=null,t=process.cwd(),s={}){return this.maintenance.enrich(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 stats(e=process.cwd(),t={}){return this.analysis.stats(e,t)}async status(e=process.cwd(),t={}){return this.analysis.status(e,t)}async diff(e=process.cwd(),t={}){return this.analysis.diff(e,t)}async seal(e=process.cwd(),t={}){return this.analysis.seal(e,t)}async rollback(e=process.cwd(),t={}){return this.analysis.rollback(e,t)}async verify(e=process.cwd(),t={}){return this.analysis.verify(e,t)}async analysisPayload(e=process.cwd(),t={}){return this.analysis.analysisPayload(e,t)}async saveLlmAnalysis(e,t=process.cwd(),s={}){return this.analysis.saveLlmAnalysis(e,t,s)}async getLlmAnalysis(e=process.cwd(),t={}){return this.analysis.getLlmAnalysis(e,t)}async context(e=null,t=process.cwd(),s={}){return this.contextCmds.context(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)}},X1=new Yn;pi();var yf={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}},wf=[{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:"idea",group:"core",description:"Transform ideas into complete technical architectures",usage:{claude:'/p:idea "build a CRM"',terminal:'prjct idea "build a CRM"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Simple ideas -> Quick capture","Complex ideas -> Full architecture"]},{name:"task",group:"core",description:"Start task with agentic classification and 7-phase workflow",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Agentic type classification","7-phase workflow","Git branch management","Task breakdown"]},{name:"spec",group:"core",description:"Create detailed specifications for complex features",usage:{claude:'/p:spec "Dark Mode"',terminal:'prjct spec "Dark Mode"'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"pause",group:"core",description:"Pause active task to handle interruption",usage:{claude:'/p:pause ["reason"]',terminal:'prjct pause ["reason"]'},params:"[reason]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,blockingRules:{check:"Active task exists",message:"No active task to pause"}},{name:"resume",group:"core",description:"Resume paused task or recover abandoned session",usage:{claude:"/p:resume",terminal:"prjct resume"},params:"[task_id]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"next",group:"core",description:"Show priority queue or roadmap view",usage:{claude:"/p:next",terminal:"prjct next"},params:"[roadmap]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"done",group:"core",description:"Mark current task as complete",usage:{claude:"/p:done",terminal:"prjct done"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{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},{name:"bug",group:"core",description:"Report and track bugs with priority",usage:{claude:'/p:bug "description"',terminal:'prjct bug "description"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"dash",group:"core",description:"Unified dashboard - status, progress, and roadmap",usage:{claude:"/p:dash [view]",terminal:"prjct dash [view]"},params:"[week|month|roadmap|compact]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"stats",group:"core",description:"Value dashboard - token savings, performance, and impact",usage:{claude:"/p:stats",terminal:"prjct stats"},params:"[--json] [--export]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Token savings tracking","Compression metrics","Cost estimates","30-day trends"]},{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:"perf",group:"core",description:"Performance dashboard - startup, memory, context, and handoff metrics",usage:{claude:"/p:perf",terminal:"prjct perf [days]"},params:"[days]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Startup time tracking","Memory usage snapshots","Context correctness rate","Subtask handoff rate","Command duration breakdown"]},{name:"velocity",group:"core",description:"Sprint-based velocity dashboard with trend detection and projections",usage:{claude:"/p:velocity",terminal:"prjct velocity [backlogPoints]"},params:"[backlogPoints]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Sprint-by-sprint velocity breakdown","Trend detection (improving/stable/declining)","Estimation accuracy tracking","Over/under estimation pattern detection","Completion projections for backlog"]},{name:"tokens",group:"core",description:"Record token usage (input + output) on the active task",usage:{claude:"/p:tokens",terminal:"prjct tokens <in> <out>"},params:"<input_tokens> <output_tokens>",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!1,features:["Accumulates tokens per task","Persisted to task history on completion","Enables cost comparison across tasks"]},{name:"sessions",group:"core",description:"Show recent sessions across all projects with resume context",usage:{claude:"/p:sessions",terminal:"prjct sessions [--cleanup]"},params:"[--cleanup]",implemented:!0,hasTemplate:!1,requiresProject:!1,requiresLlm:!0,features:["Cross-project session listing","Resume context with LLM hints","Auto-cleanup of stale snapshots"]},{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:"Check if CLAUDE.md context is stale and needs resync",usage:{claude:"/p:status",terminal:"prjct status"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares current HEAD with last sync commit","Counts commits and days since sync","Detects significant file changes","Configurable staleness thresholds"]},{name:"diff",group:"core",description:"Show diff between draft and sealed analysis runs",usage:{claude:"/p:diff",terminal:"prjct diff"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares draft vs sealed analysis field-by-field","Shows languages, frameworks, patterns, file count changes","Markdown and JSON output modes"]},{name:"seal",group:"core",description:"Seal the current draft analysis with a commit-hash signature",usage:{claude:"/p:seal",terminal:"prjct seal"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Locks draft analysis with SHA-256 signature","Only sealed analysis feeds task context","Detects staleness when HEAD moves past sealed commit"]},{name:"rollback",group:"core",description:"Rollback to the previous sealed analysis version",usage:{claude:"/p:rollback",terminal:"prjct rollback"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Restores previous sealed version as active","Current sealed moves to draft (recoverable)","One level of rollback supported"]},{name:"verify",group:"core",description:"Verify integrity of sealed analysis",usage:{claude:"/p:verify",terminal:"prjct verify"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Recomputes SHA-256 signature and compares","Detects if sealed analysis was modified"]},{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:"design",group:"optional",description:"Design system architecture, APIs, and components",usage:{claude:"/p:design [target]",terminal:"prjct design [target]"},params:"[target] --type architecture|api|component",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"cleanup",group:"optional",description:"Clean up temp files and old entries",usage:{claude:"/p:cleanup",terminal:"prjct cleanup"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"cleanup-projects",group:"optional",description:"Remove stale/test project directories",usage:{claude:"/p:cleanup-projects",terminal:"prjct cleanup-projects [--dry-run]"},params:"[--dry-run] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!1,isOptional:!0},{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:"enrich",group:"optional",description:"Build enrichment context for an issue or request",usage:{claude:'/p:enrich "<issue-or-description>"',terminal:'prjct enrich "<input>"'},params:"<issue_or_description>",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"undo",group:"optional",description:"Revert to previous snapshot",usage:{claude:"/p:undo",terminal:"prjct undo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Git-based snapshots","Preserves redo history"]},{name:"redo",group:"optional",description:"Redo previously undone changes",usage:{claude:"/p:redo",terminal:"prjct redo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"history",group:"optional",description:"View snapshot history",usage:{claude:"/p:history",terminal:"prjct history"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"recover",group:"optional",description:"Recover abandoned session with context",usage:{claude:"/p:recover",terminal:"prjct recover"},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:"linear",group:"optional",description:"Linear integration via MCP (setup/status + delegated operations)",usage:{claude:"/p:linear [command]",terminal:"prjct linear [command]"},params:"[setup|status|sync|list|get|create|update|start|done|comment|teams|projects]",implemented:!0,hasTemplate:!0,requiresProject:!1,isOptional:!0,requiresLlm:!0},{name:"jira",group:"optional",description:"Jira integration via MCP (setup/status + delegated operations)",usage:{claude:"/p:jira [command]",terminal:"prjct jira [command]"},params:"[setup|status|sync|list|get|create|update|start|done|transition|comment|projects|boards]",implemented:!0,hasTemplate:!0,requiresProject:!1,isOptional:!0,requiresLlm:!0},{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"]}];di();os();Te();W();K();dt();import{execSync as xi}from"node:child_process";import St from"node:fs/promises";import IT from"node:os";import ps from"node:path";import $T from"node:readline";import Pe from"chalk";var Ri="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",Wr="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";async function Sf(r){let e=0;try{let t=await St.readdir(r,{withFileTypes:!0});for(let s of t){let n=ps.join(r,s.name);if(s.isDirectory())e+=await Sf(n);else try{let o=await St.stat(n);e+=o.size}catch{}}}catch{}return e}l(Sf,"getDirectorySize");function kf(r){if(r===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));return`${(r/1024**t).toFixed(1)} ${e[t]}`}l(kf,"formatSize");async function MT(r){try{return(await St.readdir(r,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}l(MT,"countDirectoryItems");function _T(){let r={homebrew:!1,npm:!1};try{xi("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(r.homebrew=!0,r.homebrewFormula="prjct-cli")}catch{}try{xi("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(r.npm=!0)}catch{}return r}l(_T,"detectInstallation");async function OT(){let r=[],e=Iu(),t=A.getGlobalBasePath(),s=await P(t),n=s?await MT(ps.join(t,"projects")):0,o=s?await Sf(t):0;r.push({path:t,type:"directory",description:`All project data${n>0?`, ${n} project${n>1?"s":""}`:""}`,size:o,count:n,exists:s});let i=ps.join(e.claude.config,"CLAUDE.md"),a=await P(i),c=!1;if(a)try{let D=await St.readFile(i,"utf-8");c=D.includes(Ri)&&D.includes(Wr)}catch{}r.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&c});let u=e.claude.router,p=await P(u);r.push({path:u,type:"file",description:"Claude router",exists:p});let m=ps.join(e.claude.config,"prjct-statusline.sh"),d=await P(m);r.push({path:m,type:"file",description:"Status line script",exists:d});let g=e.gemini.router,h=await P(g);r.push({path:g,type:"file",description:"Gemini router",exists:h});let k=ps.join(e.gemini.config,"GEMINI.md"),y=await P(k),v=!1;if(y)try{let D=await St.readFile(k,"utf-8");v=D.includes(Ri)&&D.includes(Wr)}catch{}return y&&v&&r.push({path:k,type:"section",description:"prjct section in GEMINI.md",exists:!0}),r}l(OT,"gatherUninstallItems");async function NT(r){try{let e=await St.readFile(r,"utf-8");if(!e.includes(Ri)||!e.includes(Wr))return!1;let t=e.indexOf(Ri),s=e.indexOf(Wr)+Wr.length,n=e.substring(0,t)+e.substring(s);return n=n.replace(/\n{3,}/g,`
1495
+
1496
+ `).trim(),!n||n.trim().length===0?await St.unlink(r):await St.writeFile(r,`${n}
1497
+ `,"utf-8"),!0}catch{return!1}}l(NT,"removePrjctSection");async function LT(){let r=IT.homedir(),e=new Date().toISOString().replace(/[:.]/g,"-").substring(0,19),t=ps.join(r,`.prjct-backup-${e}`);try{await St.mkdir(t,{recursive:!0});let s=A.getGlobalBasePath();return await P(s)&&await bf(s,ps.join(t,".prjct-cli")),t}catch{return null}}l(LT,"createBackup");async function bf(r,e){await St.mkdir(e,{recursive:!0});let t=await St.readdir(r,{withFileTypes:!0});for(let s of t){let n=ps.join(r,s.name),o=ps.join(e,s.name);s.isDirectory()?await bf(n,o):await St.copyFile(n,o)}}l(bf,"copyDirectory");async function FT(r,e,t){let s=[],n=[];for(let o of r)if(o.exists)try{o.type==="section"?await NT(o.path)&&s.push(o.path):o.type==="directory"?(await St.rm(o.path,{recursive:!0,force:!0}),s.push(o.path)):o.type==="file"&&(await St.unlink(o.path),s.push(o.path))}catch(i){n.push(`${o.path}: ${w(i)}`)}try{await new rs().cleanupLegacyCommands()}catch{}if(!t.keepPackage){if(e.homebrew&&e.homebrewFormula)try{t.dryRun||xi(`brew uninstall ${e.homebrewFormula}`,{stdio:"pipe"}),s.push("Homebrew: prjct-cli")}catch(o){n.push(`Homebrew: ${w(o)}`)}if(e.npm)try{t.dryRun||xi("npm uninstall -g prjct-cli",{stdio:"pipe"}),s.push("npm: prjct-cli")}catch(o){n.push(`npm: ${w(o)}`)}}return{deleted:s,errors:n}}l(FT,"performUninstall");async function UT(r){let e=$T.createInterface({input:process.stdin,output:process.stdout});return new Promise(t=>{e.question(r,s=>{e.close(),t(s.toLowerCase()==="uninstall")})})}l(UT,"promptConfirmation");async function HT(r={},e=process.cwd()){let t=await OT(),s=_T(),n=t.filter(c=>c.exists);if(n.length===0&&!s.homebrew&&!s.npm)return console.log(Pe.yellow(`
1498
+ No prjct installation found.`)),{success:!0,message:"Nothing to uninstall"};let o=n.reduce((c,u)=>c+(u.size||0),0);console.log(""),console.log(Pe.red.bold(" WARNING: This action is DANGEROUS and IRREVERSIBLE")),console.log(""),console.log(Pe.white("The following will be permanently deleted:")),console.log("");for(let c of n){let u=A.getDisplayPath(c.path),p="";c.type==="section"?p=Pe.dim("(section only)"):c.size&&(p=Pe.dim(`(${kf(c.size)})`)),console.log(` ${Pe.cyan(u.padEnd(35))} ${p}`),console.log(` ${Pe.dim(c.description)}`),console.log("")}if(s.homebrew&&(console.log(` ${Pe.cyan("Homebrew".padEnd(35))} ${Pe.dim("prjct-cli formula")}`),console.log("")),s.npm&&(console.log(` ${Pe.cyan("npm global".padEnd(35))} ${Pe.dim("prjct-cli package")}`),console.log("")),o>0&&(console.log(Pe.dim(` Total size: ${kf(o)}`)),console.log("")),r.dryRun)return console.log(Pe.yellow("Dry run - no changes made")),{success:!0,message:"Dry run complete",itemsFound:n.length};if(r.backup){console.log(Pe.blue("Creating backup..."));let c=await LT();c?(console.log(Pe.green(`Backup created: ${A.getDisplayPath(c)}`)),console.log("")):console.log(Pe.yellow("Failed to create backup, continuing..."))}if(!r.force&&(console.log(Pe.yellow('Type "uninstall" to confirm:')),!await UT("> ")))return console.log(Pe.yellow(`
1499
+ Uninstall cancelled.`)),{success:!1,message:"Uninstall cancelled by user"};console.log(""),console.log(Pe.blue("Removing prjct..."));let{deleted:i,errors:a}=await FT(t,s,r);if(console.log(""),i.length>0&&console.log(Pe.green(`Removed ${i.length} items`)),a.length>0){console.log(Pe.yellow(`
1500
+ ${a.length} errors:`));for(let c of a)console.log(Pe.red(` - ${c}`))}return console.log(""),console.log(Pe.green("prjct has been uninstalled.")),console.log(Pe.dim("Thanks for using prjct! We hope to see you again.")),console.log(""),{success:a.length===0,message:`Removed ${i.length} items`,deleted:i,errors:a.length>0?a:void 0}}l(HT,"uninstall");var Ai=class extends Ce{static{l(this,"UninstallCommands")}async uninstall(e={},t=process.cwd()){return HT(e,t)}};var As=new Xn,Di=new sn,GT=new Wn,Tf=new _n,WT=new Ln,Ds=new Nn,Qn=new on,Vr=new Un,VT=new an,BT=new Jn,zT=new Ai,JT=new zn;function qT(){for(let[r,e]of Object.entries(yf))G.registerCategory(r,e)}l(qT,"registerCategories");function KT(){if(G.has("work"))return;qT();let r=l(e=>wf.find(t=>t.name===e),"getMeta");G.registerMethod("task",As,"now",r("task")),G.registerMethod("done",As,"done",r("done")),G.registerMethod("next",As,"next",r("next")),G.registerMethod("pause",As,"pause",r("pause")),G.registerMethod("resume",As,"resume",r("resume")),G.registerMethod("workflow",As,"workflow",r("workflow")),G.registerMethod("tokens",As,"tokens",r("tokens")),G.registerMethod("sessions",As,"sessions",r("sessions")),G.registerMethod("init",Di,"init",r("init")),G.registerMethod("bug",Di,"bug",r("bug")),G.registerMethod("idea",Di,"idea",r("idea")),G.registerMethod("spec",Di,"spec",r("spec")),G.registerMethod("ship",GT,"ship",r("ship")),G.registerMethod("dash",Tf,"dash",r("dash")),G.registerMethod("help",Tf,"help",r("help")),G.registerMethod("perf",WT,"perf",r("perf")),G.registerMethod("velocity",BT,"velocity",r("velocity")),G.registerMethod("cleanup",Ds,"cleanup",r("cleanup")),G.registerMethod("cleanup-projects",Ds,"cleanupProjects",r("cleanup-projects")),G.registerMethod("design",Ds,"design",r("design")),G.registerMethod("recover",Ds,"recover",r("recover")),G.registerMethod("undo",Ds,"undo",r("undo")),G.registerMethod("redo",Ds,"redo",r("redo")),G.registerMethod("history",Ds,"history",r("history")),G.registerMethod("enrich",Ds,"enrich",r("enrich")),G.registerMethod("analyze",Qn,"analyze",r("analyze")),G.registerMethod("sync",Qn,"sync",r("sync")),G.registerMethod("stats",Qn,"stats",r("stats")),G.registerMethod("status",Qn,"status",r("status")),G.registerMethod("seal",Qn,"seal",r("seal")),G.registerMethod("verify",Qn,"verify",r("verify")),G.registerMethod("start",Vr,"start",r("start")),G.registerMethod("setup",Vr,"setup",r("setup")),G.registerMethod("login",Vr,"login",r("login")),G.registerMethod("logout",Vr,"logout",r("logout")),G.registerMethod("auth",Vr,"auth",r("auth")),G.registerMethod("uninstall",zT,"uninstall",r("uninstall")),G.registerMethod("update",JT,"update",r("update")),G.registerMethod("context",VT,"context",r("context"))}l(KT,"registerAllCommands");KT();Et();ar();Ct();import{Hono as iv}from"hono";import{cors as av}from"hono/cors";import{logger as cv}from"hono/logger";Te();re();ks();Xt();zs();Pt();W();ns();import XT from"node:fs/promises";import YT from"node:path";import{Hono as QT}from"hono";function ZT(r){return A.getGlobalProjectPath(r)}l(ZT,"getProjectDataPath");function vf(r,e){let t=new QT,s=ZT(r);return t.get("/state",async n=>{let o=await _.read(r);return n.json(o)}),t.get("/queue",async n=>{let o=await be.read(r);return n.json(o)}),t.get("/ideas",async n=>{let o=await Ge.read(r);return n.json(o)}),t.get("/roadmap",async n=>{let o=C.getDoc(r,"roadmap");return o?n.json(o):n.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async n=>{let o=await tt.read(r);return n.json(o)}),t.get("/dashboard",async n=>{let[o,i,a,c]=await Promise.all([_.read(r),be.read(r),Ge.read(r),tt.read(r)]),u=C.getDoc(r,"roadmap");return n.json({projectId:r,state:o,queue:i,ideas:a,roadmap:u||{features:[],backlog:[],lastUpdated:""},shipped:c,timestamp:new Date().toISOString()})}),t.post("/state",async n=>{try{let o=await n.req.json();return await _.write(r,o),n.json({success:!0})}catch(o){return n.json({success:!1,error:String(o)},400)}}),t.get("/context/:name",async n=>{let o=n.req.param("name");if(!["now","next","ideas","shipped"].includes(o))return n.json({error:"Invalid context file"},400);try{let a=YT.join(s,"context",`${o}.md`),c=await XT.readFile(a,"utf-8");return n.text(c,200,{"Content-Type":"text/markdown"})}catch(a){return R(a)||V.error(`Context read error: ${w(a)}`),n.text("",200,{"Content-Type":"text/markdown"})}}),t}l(vf,"createRoutes");Te();re();ks();Xt();zs();Pt();import Zn from"node:fs/promises";import ev from"node:path";import{Hono as tv}from"hono";var sv=A.getGlobalBasePath(),er=ev.join(sv,"projects");function ji(r){return C.getDoc(r,"project")}l(ji,"getProjectConfig");async function Yl(r){if(!r)return"";let e=new Date(r),s=new Date().getTime()-e.getTime(),n=Math.floor(s/(1e3*60*60)),o=Math.floor(s%(1e3*60*60)/(1e3*60));return n>0?`${n}h ${o}m`:`${o}m`}l(Yl,"calculateDuration");function Cf(){let r=new tv;return r.get("/projects",async e=>{try{await Zn.mkdir(er,{recursive:!0});let s=(await Zn.readdir(er,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),n=await Promise.all(s.map(async o=>{let i=ji(o),a=await _.read(o),c=await be.read(o),u=await Ge.read(o),p=await tt.read(o),m=a?.currentTask,d=await Yl(m?.startedAt);return{id:o,name:i?.name||o.slice(0,8),path:i?.path||null,currentTask:m?{...m,duration:d}:null,pausedTask:a?.previousTask||null,stats:{queueCount:c?.tasks?.filter(g=>!g.completed)?.length||0,ideasCount:u?.ideas?.filter(g=>g.status==="pending")?.length||0,shippedCount:p?.shipped?.length||0}}}));return n.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:(o.name||"").localeCompare(i.name||"")),e.json({projects:n})}catch(t){return e.json({projects:[],error:String(t)},500)}}),r.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[s,n,o,i,a]=await Promise.all([Promise.resolve(ji(t)),_.read(t),be.read(t),Ge.read(t),tt.read(t)]),c=C.getDoc(t,"roadmap");n?.currentTask?.startedAt&&(n.currentTask.duration=await Yl(n.currentTask.startedAt));let u=new Date,p=new Date(u.getFullYear(),u.getMonth(),u.getDate()),m=new Date(p);m.setDate(m.getDate()-m.getDay());let d=o?.tasks?.filter(h=>!h.completed||!h.completedAt?!1:new Date(h.completedAt)>=p)?.length||0,g=o?.tasks?.filter(h=>!h.completed||!h.completedAt?!1:new Date(h.completedAt)>=m)?.length||0;return e.json({id:t,name:s?.name||t,path:s?.path,state:n||{currentTask:null,previousTask:null,lastUpdated:""},queue:o||{tasks:[],lastUpdated:""},ideas:i||{ideas:[],lastUpdated:""},shipped:a||{shipped:[],lastUpdated:""},roadmap:c||{features:[],backlog:[],lastUpdated:""},stats:{tasksToday:d,tasksThisWeek:g,queueCount:o?.tasks?.filter(h=>!h.completed)?.length||0,ideasCount:i?.ideas?.filter(h=>h.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch(s){return e.json({error:String(s)},500)}}),r.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let s=await _.read(t);if(!s?.currentTask)return e.json({success:!1,error:"No active task"},400);let n=s.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await _.write(t,o),e.json({success:!0,completedTask:n,message:`Completed: ${n.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let n=(await e.req.json().catch(()=>({}))).reason,o=await _.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:n},a={currentTask:null,previousTask:i,lastUpdated:new Date().toISOString()};return await _.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let s=await _.read(t);if(!s?.previousTask)return e.json({success:!1,error:"No paused task"},400);let n={id:s.previousTask.id,description:s.previousTask.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`},o={currentTask:n,previousTask:null,lastUpdated:new Date().toISOString()};return await _.write(t,o),e.json({success:!0,resumedTask:n,message:`Resumed: ${n.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{taskId:n}=s;if(!n)return e.json({success:!1,error:"taskId required"},400);let[o,i]=await Promise.all([_.read(t),be.read(t)]);if(o?.currentTask)return e.json({success:!1,error:"Complete or pause current task first"},400);let a=i?.tasks?.find(p=>p.id===n);if(!a)return e.json({success:!1,error:"Task not found in queue"},404);let c={id:a.id,description:a.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`,featureId:a.featureId},u={currentTask:c,previousTask:null,lastUpdated:new Date().toISOString()};return await _.write(t,u),e.json({success:!0,task:c,message:`Started: ${c.description}`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{text:n,priority:o="medium",tags:i=[]}=s;if(!n)return e.json({success:!1,error:"text required"},400);let a=await Ge.addIdea(t,n,{priority:o||"medium",tags:i});return e.json({success:!0,idea:a,message:`Captured: ${n.slice(0,50)}...`})}catch(s){return e.json({success:!1,error:String(s)},500)}}),r.get("/stats/global",async e=>{try{await Zn.mkdir(er,{recursive:!0});let s=(await Zn.readdir(er,{withFileTypes:!0})).filter(c=>c.isDirectory()).map(c=>c.name),n=0,o=0,i=0,a=0;for(let c of s){let u=await _.read(c),p=await be.read(c),m=await Ge.read(c),d=await tt.read(c);u?.currentTask&&a++,n+=p?.tasks?.filter(g=>!g.completed)?.length||0,o+=m?.ideas?.filter(g=>g.status==="pending")?.length||0,i+=d?.shipped?.length||0}return e.json({totalProjects:s.length,activeProjects:a,totalTasks:n,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),r.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await Zn.mkdir(er,{recursive:!0});let n=(await Zn.readdir(er,{withFileTypes:!0})).filter(p=>p.isDirectory()).map(p=>p.name),o=null;if(t)for(let p of n){let m=ji(p),d=m?.repoPath||m?.path;if(d&&t.startsWith(d)){o=p;break}}let i=null,a=null,c=null,u=o?[o]:n;for(let p of u){let m=await _.read(p),d=ji(p);if(m?.currentTask){i={id:p,name:d?.name||p,path:d?.repoPath||d?.path},a={...m.currentTask,duration:await Yl(m.currentTask.startedAt)};break}m?.previousTask&&!c&&(i={id:p,name:d?.name||p,path:d?.repoPath||d?.path},c=m.previousTask)}return e.json({hasActiveTask:!!a,hasPausedTask:!!c,activeProject:i,activeTask:a,pausedTask:c,totalProjects:n.length,filtered:!!o,cwd:t||null,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),r}l(Cf,"createExtendedRoutes");import{streamSSE as nv}from"hono/streaming";var Pf=3600*1e3,rv=300*1e3,ov=3e4;function Ef(){let r=new Map,e=null;function t(o){let i=r.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),r.delete(o))}l(t,"removeClient");function s(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of r)o-new Date(a.client.connectedAt).getTime()>Pf&&t(i)},rv),e&&typeof e=="object"&&"unref"in e&&e.unref())}l(s,"startReaper");function n(){e&&(clearInterval(e),e=null)}return l(n,"stopReaper"),s(),{handleConnection(o){return nv(o,async i=>{let a=crypto.randomUUID(),c=new Date().toISOString(),u=new AbortController,p={id:a,connectedAt:c,send:l((g,h)=>{i.writeSSE({event:g,data:JSON.stringify(h)})},"send"),close:l(()=>{t(a)},"close")},m=setInterval(async()=>{try{await i.writeSSE({event:"heartbeat",data:JSON.stringify({timestamp:new Date().toISOString()})})}catch{t(a)}},ov),d=setTimeout(()=>{t(a)},Pf);typeof m=="object"&&"unref"in m&&m.unref(),typeof d=="object"&&"unref"in d&&d.unref(),r.set(a,{client:p,heartbeatInterval:m,ttlTimeout:d,abortController:u}),await i.writeSSE({event:"connected",data:JSON.stringify({clientId:a,timestamp:c,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[c,u]of r)try{u.client.send(o,a)}catch{t(c)}},getClientCount(){return r.size},shutdown(){n();for(let o of[...r.keys()])t(o)}}}l(Ef,"createSSEManager");function xf(r){let e=new iv,t=Ef();r.enableCors!==!1&&e.use("*",av({origin:"*",allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type","Authorization"]})),r.enableLogging!==!1&&e.use("*",cv()),e.get("/health",i=>i.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/",i=>i.json({name:"prjct-cli",version:Ae,projectId:r.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=vf(r.projectId,r.projectPath);e.route("/api",s);let n=Cf();e.route("/api",n),e.get("/api/events",i=>t.handleConnection(i));let o=null;return{app:e,async start(){let i=r.port,a=r.host||"0.0.0.0";if(Os())o=Bun.serve({port:i,hostname:a,fetch:e.fetch});else{let{serve:c}=await import("@hono/node-server"),u=c({fetch:e.fetch,port:i,hostname:a});o={stop:l(()=>u.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${a}:${i}`),console.log(` Project: ${r.projectId}`),console.log(` Runtime: ${Os()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${i}`)},stop(){t.shutdown(),o&&(o.stop(),o=null,console.log("Server stopped"))},broadcast(i,a){t.broadcast(i,a)}}}l(xf,"createServer");var Rf=3478;re();Hl();var uv=50,tr=null,Br=null,he=null,Ee=null;async function Af(r){let e=Le.socket(),t=Le.pid(),s=Le.runDir();if(Fe.mkdirSync(s,{recursive:!0}),Fe.existsSync(t)){let i=parseInt(Fe.readFileSync(t,"utf-8").trim(),10);fv(i)&&(console.error(`Daemon already running (PID ${i})`),process.exit(1)),Fe.unlinkSync(t)}Fe.existsSync(e)&&Fe.unlinkSync(e),wv();let n=hv(),o=null;if(n)try{o=Fe.statSync(n).mtimeMs}catch{}if(Ee={startedAt:Date.now(),commandsServed:0,lastActivity:Date.now(),idleTimeoutMs:Qg,idleTimer:null,entryPath:n,entryMtime:o},he=new Yn,tr=lv(i=>dv(i)),tr.listen(e,()=>{Fe.chmodSync(e,384),Fe.writeFileSync(t,String(process.pid)),console.log(`prjct daemon started (PID ${process.pid})`),console.log(` Socket: ${e}`),n&&console.log(` Watching: ${n}`),Df()}),tr.on("error",i=>{console.error("Daemon socket error:",i.message),sr(1)}),!r.noHttp)try{let i=process.cwd(),a=await $.getProjectId(i);if(a){let c=r.port||Rf;Br=xf({port:c,projectId:a,projectPath:i,enableLogging:!1}),await Br.start()}}catch{}if(process.on("SIGTERM",()=>sr(0)),process.on("SIGINT",()=>sr(0)),process.on("SIGHUP",()=>{he=new Yn,console.log("Daemon reloaded (SIGHUP)")}),!r.foreground)try{process.stdin?.unref?.()}catch{}}l(Af,"startDaemon");function dv(r){let e="";r.on("data",async t=>{if(e+=t.toString(),e.length>Zg){let n={id:"unknown",success:!1,exitCode:1,stderr:"Request too large"};r.write(Vn(n)),r.destroy(),e="";return}let s;for(;(s=e.indexOf(`
1501
+ `))!==-1;){let n=e.slice(0,s);if(e=e.slice(s+1),!!n.trim())try{let o=JSON.parse(n),i=await pv(o);r.write(Vn(i))}catch(o){let i={id:"unknown",success:!1,exitCode:1,stderr:`Protocol error: ${o.message}`};r.write(Vn(i))}}}),r.on("error",()=>{})}l(dv,"handleConnection");async function pv(r){if(!Ee||!he)return{id:r.id,success:!1,exitCode:1,stderr:"Daemon not initialized"};if(Df(),Ee.commandsServed++,Ee.lastActivity=Date.now(),Ee.commandsServed%uv===0&&N.checkpointAll(),jf()&&(console.log("Build changed detected \u2014 daemon will restart after this request"),setTimeout(()=>{console.log("Daemon shutting down for code reload..."),sr(0)},200)),r.command==="daemon")return gv(r);if(r.command==="__ping")return{id:r.id,success:!0,exitCode:0,result:{pong:!0,pid:process.pid}};try{let e=[],t=[],s=console.log,n=console.error;console.log=(...o)=>e.push(o.map(String).join(" ")),console.error=(...o)=>t.push(o.map(String).join(" "));try{let o=await mv(r);return{id:r.id,success:o.success,exitCode:o.success?0:1,stdout:e.join(`
1477
1502
  `)||o.message||void 0,stderr:t.join(`
1478
- `)||o.error||void 0,result:o}}finally{console.log=s,console.error=n}}catch(e){return{id:r.id,success:!1,exitCode:1,stderr:e.message}}}l(cT,"handleRequest");async function lT(r){let e=r.args.join(" ")||null,t=r.options,s=t.md===!0;switch(r.command){case"sync":return he.sync(r.cwd,{preview:t.preview===!0||t["dry-run"]===!0,yes:t.yes===!0,json:t.json===!0,md:s,package:t.package?String(t.package):void 0,full:t.full===!0});case"status":return he.status(r.cwd,{json:t.json===!0,md:s});case"stats":return he.stats(r.cwd,{json:t.json===!0,export:t.export===!0});case"diff":return he.diff(r.cwd,{json:t.json===!0,md:s});case"seal":return he.seal(r.cwd,{json:t.json===!0});case"rollback":return he.rollback(r.cwd,{json:t.json===!0,md:s});case"verify":return he.verify(r.cwd,{json:t.json===!0,semantic:t.semantic===!0});case"task":return he.task(e,r.cwd,{md:s});case"done":return he.done(r.cwd,{md:s});case"next":return he.next(r.cwd,{md:s});case"pause":return he.pause(e||"",r.cwd,{md:s});case"resume":return he.resume(e,r.cwd,{md:s});case"bug":return he.bug(e||"",r.cwd,{md:s});case"idea":return he.idea(e||"",r.cwd,{md:s});case"ship":return he.ship(e,r.cwd,{md:s});case"dash":return he.dash(e||"default",r.cwd,{md:s});case"workflow":return he.workflowPrefs(e,r.cwd,{md:s});case"sessions":return he.sessions(r.cwd,{md:s,cleanup:t.cleanup===!0});case"design":return he.design(e||"",t,r.cwd);case"analysis-payload":return he.analysisPayload(r.cwd,{json:t.json===!0,md:s});case"analysis-save-llm":return he.saveLlmAnalysis(e||"",r.cwd,{md:s});case"analysis-llm":return he.getLlmAnalysis(r.cwd,{json:t.json===!0,md:s});case"analyze":return he.analyze(t,r.cwd);case"cleanup":return he.cleanup(t,r.cwd);case"cleanup-projects":return he.cleanupProjects({dryRun:t["dry-run"]===!0,md:s});default:return G.execute(r.command,e,r.cwd)}}l(lT,"executeCommand");function uT(r){let e=r.args[0];if(e==="status")return{id:r.id,success:!0,exitCode:0,result:{running:!0,pid:process.pid,socketPath:Ne.socket(),uptime:Ee?Date.now()-Ee.startedAt:0,commandsServed:Ee?.commandsServed??0,lastActivity:Ee?new Date(Ee.lastActivity).toISOString():null,registeredCommands:G.list().length,stale:xf()}};if(e==="stop"){let t={id:r.id,success:!0,exitCode:0,stdout:"Daemon stopping..."};return setTimeout(()=>sr(0),100),t}return{id:r.id,success:!1,exitCode:1,stderr:`Unknown daemon command: ${e}. Use: status, stop`}}l(uT,"handleDaemonCommand");function Ef(){Ee&&(Ee.idleTimer&&clearTimeout(Ee.idleTimer),Ee.idleTimer=setTimeout(()=>{console.log(`Daemon idle for ${Ee.idleTimeoutMs/1e3/60} minutes, shutting down`),sr(0)},Ee.idleTimeoutMs),Ee.idleTimer.unref&&Ee.idleTimer.unref())}l(Ef,"resetIdleTimer");function sr(r){console.log("Daemon shutting down..."),Ee?.idleTimer&&clearTimeout(Ee.idleTimer),Vr&&(Vr.stop(),Vr=null),tr&&(tr.close(),tr=null),F.close();let e=Ne.socket(),t=Ne.pid();try{Le.existsSync(e)&&Le.unlinkSync(e)}catch{}try{Le.existsSync(t)&&Le.unlinkSync(t)}catch{}process.exit(r)}l(sr,"shutdown");function dT(r){try{return process.kill(r,0),!0}catch{return!1}}l(dT,"isProcessRunning");function pT(){let r=St("node:path"),e=__dirname;for(let n=0;n<5;n++){if(Le.existsSync(r.join(e,"package.json"))){let o=r.join(e,"dist","daemon","entry.mjs");if(Le.existsSync(o))return o;break}e=r.dirname(e)}let t=[r.join(__dirname,"..","daemon","entry.mjs"),r.join(__dirname,"..","dist","daemon","entry.mjs")];for(let n of t)if(Le.existsSync(n))return n;let s=process.argv[1];return s&&Le.existsSync(s)?s:null}l(pT,"resolveEntryPath");var mT=1024*1024;function gT(){let r=Ne.log();try{if(Le.statSync(r).size>mT){let t=`${r}.1`;try{Le.unlinkSync(t)}catch{}Le.renameSync(r,t)}}catch{}}l(gT,"rotateLog");function xf(){if(!Ee?.entryPath||Ee.entryMtime===null)return!1;try{return Le.statSync(Ee.entryPath).mtimeMs!==Ee.entryMtime}catch{return!1}}l(xf,"isCodeStale");var Kl=process.argv.slice(2),fT=parseInt(Kl.find(r=>r.startsWith("--port="))?.split("=")[1]||"",10)||void 0,hT=Kl.includes("--no-http"),yT=Kl.includes("--foreground");Pf({port:fT,noHttp:hT,foreground:yT}).catch(r=>{console.error("Failed to start daemon:",r.message),process.exit(1)});
1503
+ `)||o.error||void 0,result:o}}finally{console.log=s,console.error=n}}catch(e){return{id:r.id,success:!1,exitCode:1,stderr:e.message}}}l(pv,"handleRequest");async function mv(r){let e=r.args.join(" ")||null,t=r.options,s=t.md===!0;switch(r.command){case"sync":return he.sync(r.cwd,{preview:t.preview===!0||t["dry-run"]===!0,yes:t.yes===!0,json:t.json===!0,md:s,package:t.package?String(t.package):void 0,full:t.full===!0});case"status":return he.status(r.cwd,{json:t.json===!0,md:s});case"stats":return he.stats(r.cwd,{json:t.json===!0,export:t.export===!0});case"diff":return he.diff(r.cwd,{json:t.json===!0,md:s});case"seal":return he.seal(r.cwd,{json:t.json===!0});case"rollback":return he.rollback(r.cwd,{json:t.json===!0,md:s});case"verify":return he.verify(r.cwd,{json:t.json===!0,semantic:t.semantic===!0});case"task":return he.task(e,r.cwd,{md:s});case"done":return he.done(r.cwd,{md:s});case"next":return he.next(r.cwd,{md:s});case"pause":return he.pause(e||"",r.cwd,{md:s});case"resume":return he.resume(e,r.cwd,{md:s});case"bug":return he.bug(e||"",r.cwd,{md:s});case"idea":return he.idea(e||"",r.cwd,{md:s});case"ship":return he.ship(e,r.cwd,{md:s});case"dash":return he.dash(e||"default",r.cwd,{md:s});case"workflow":return he.workflowPrefs(e,r.cwd,{md:s});case"sessions":return he.sessions(r.cwd,{md:s,cleanup:t.cleanup===!0});case"design":return he.design(e||"",t,r.cwd);case"analysis-payload":return he.analysisPayload(r.cwd,{json:t.json===!0,md:s});case"analysis-save-llm":return he.saveLlmAnalysis(e||"",r.cwd,{md:s});case"analysis-llm":return he.getLlmAnalysis(r.cwd,{json:t.json===!0,md:s});case"analyze":return he.analyze(t,r.cwd);case"cleanup":return he.cleanup(t,r.cwd);case"cleanup-projects":return he.cleanupProjects({dryRun:t["dry-run"]===!0,md:s});default:return G.execute(r.command,e,r.cwd)}}l(mv,"executeCommand");function gv(r){let e=r.args[0];if(e==="status")return{id:r.id,success:!0,exitCode:0,result:{running:!0,pid:process.pid,socketPath:Le.socket(),uptime:Ee?Date.now()-Ee.startedAt:0,commandsServed:Ee?.commandsServed??0,lastActivity:Ee?new Date(Ee.lastActivity).toISOString():null,registeredCommands:G.list().length,stale:jf()}};if(e==="stop"){let t={id:r.id,success:!0,exitCode:0,stdout:"Daemon stopping..."};return setTimeout(()=>sr(0),100),t}return{id:r.id,success:!1,exitCode:1,stderr:`Unknown daemon command: ${e}. Use: status, stop`}}l(gv,"handleDaemonCommand");function Df(){Ee&&(Ee.idleTimer&&clearTimeout(Ee.idleTimer),Ee.idleTimer=setTimeout(()=>{console.log(`Daemon idle for ${Ee.idleTimeoutMs/1e3/60} minutes, shutting down`),sr(0)},Ee.idleTimeoutMs),Ee.idleTimer.unref&&Ee.idleTimer.unref())}l(Df,"resetIdleTimer");function sr(r){console.log("Daemon shutting down..."),Ee?.idleTimer&&clearTimeout(Ee.idleTimer),Br&&(Br.stop(),Br=null),tr&&(tr.close(),tr=null),N.close();let e=Le.socket(),t=Le.pid();try{Fe.existsSync(e)&&Fe.unlinkSync(e)}catch{}try{Fe.existsSync(t)&&Fe.unlinkSync(t)}catch{}process.exit(r)}l(sr,"shutdown");function fv(r){try{return process.kill(r,0),!0}catch{return!1}}l(fv,"isProcessRunning");function hv(){let r=bt("node:path"),e=__dirname;for(let n=0;n<5;n++){if(Fe.existsSync(r.join(e,"package.json"))){let o=r.join(e,"dist","daemon","entry.mjs");if(Fe.existsSync(o))return o;break}e=r.dirname(e)}let t=[r.join(__dirname,"..","daemon","entry.mjs"),r.join(__dirname,"..","dist","daemon","entry.mjs")];for(let n of t)if(Fe.existsSync(n))return n;let s=process.argv[1];return s&&Fe.existsSync(s)?s:null}l(hv,"resolveEntryPath");var yv=1024*1024;function wv(){let r=Le.log();try{if(Fe.statSync(r).size>yv){let t=`${r}.1`;try{Fe.unlinkSync(t)}catch{}Fe.renameSync(r,t)}}catch{}}l(wv,"rotateLog");function jf(){if(!Ee?.entryPath||Ee.entryMtime===null)return!1;try{return Fe.statSync(Ee.entryPath).mtimeMs!==Ee.entryMtime}catch{return!1}}l(jf,"isCodeStale");var Ql=process.argv.slice(2),kv=parseInt(Ql.find(r=>r.startsWith("--port="))?.split("=")[1]||"",10)||void 0,Sv=Ql.includes("--no-http"),bv=Ql.includes("--foreground");Af({port:kv,noHttp:Sv,foreground:bv}).catch(r=>{console.error("Failed to start daemon:",r.message),process.exit(1)});