prjct-cli 2.2.7 → 2.2.8

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.
@@ -4,15 +4,15 @@ import { dirname as __pathDirname } from 'path';
4
4
  var require = __createRequire(import.meta.url);
5
5
  var __filename = __fileURLToPath(import.meta.url);
6
6
  var __dirname = __pathDirname(__filename);
7
- var Nf=Object.create;var er=Object.defineProperty;var Of=Object.getOwnPropertyDescriptor;var Lf=Object.getOwnPropertyNames;var Ff=Object.getPrototypeOf,Uf=Object.prototype.hasOwnProperty;var l=(n,e)=>er(n,"name",{value:e,configurable:!0}),Je=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var h=(n,e)=>()=>(n&&(e=n(n=0)),e);var Hf=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),W=(n,e)=>{for(var t in e)er(n,t,{get:e[t],enumerable:!0})},Ll=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Lf(e))!Uf.call(n,r)&&r!==t&&er(n,r,{get:()=>e[r],enumerable:!(s=Of(e,r))||s.enumerable});return n};var Wf=(n,e,t)=>(t=n!=null?Nf(Ff(n)):{},Ll(e||!n||!n.__esModule?er(t,"default",{value:n,enumerable:!0}):t,n)),ht=n=>Ll(er({},"__esModule",{value:!0}),n);var Fl={};W(Fl,{REGISTERED_VERBS_SET:()=>qf});var Gf,qf,Ul=h(()=>{"use strict";Gf=["task","ship","tag","remember","status","workflow","init","analyze","analysis-save-llm","sync","regen","context","login","logout","auth","seed","install","capture"],qf=new Set(Gf)});var Hl={};W(Hl,{DAEMON_PATHS:()=>Ee,IDLE_TIMEOUT_MS:()=>Ai,MAX_BUFFER_SIZE:()=>Ii,encodeMessage:()=>js});function js(n){return Buffer.from(`${JSON.stringify(n)}
8
- `)}var Ee,Ai,Ii,Gr=h(()=>{"use strict";Ee={runDir:l(()=>`${process.env.HOME||Je("node:os").homedir()}/.prjct-cli/run`,"runDir"),socket:l(()=>`${Ee.runDir()}/daemon.sock`,"socket"),pid:l(()=>`${Ee.runDir()}/daemon.pid`,"pid"),log:l(()=>`${Ee.runDir()}/daemon.log`,"log")},Ai=30*60*1e3,Ii=1024*1024;l(js,"encodeMessage")});function Wl(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function Rs(){return Wl()==="bun"}function $i(){if(Wl()==="bun")return!0;try{let{execSync:n}=Je("node:child_process");return n("bun --version",{stdio:"ignore"}),!0}catch{return!1}}var tr=h(()=>{"use strict";l(Wl,"detectRuntime");l(Rs,"isBun");l($i,"isBunAvailable")});var Bt={};W(Bt,{executeViaDaemon:()=>Jf,forceKillDaemon:()=>Xf,getDaemonStatus:()=>Bf,isDaemonRunning:()=>Gl,sendRequest:()=>sr,spawnDaemon:()=>ql,stopDaemon:()=>zf});import qr from"node:crypto";import Oe from"node:fs";import{connect as Vf}from"node:net";async function Gl(){let n=Ee.socket();if(!Oe.existsSync(n))return!1;try{return(await sr({id:qr.randomUUID(),command:"__ping",args:[],options:{},cwd:process.cwd()})).success}catch{try{Oe.unlinkSync(n)}catch{}return!1}}async function Bf(){let n=Ee.socket(),e=Ee.pid();if(!Oe.existsSync(n))return{running:!1};try{let t=await sr({id:qr.randomUUID(),command:"daemon",args:["status"],options:{},cwd:process.cwd()});if(t.success&&t.result)return t.result}catch{}return Oe.existsSync(e)?{running:!1,pid:parseInt(Oe.readFileSync(e,"utf-8").trim(),10),socketPath:n}:{running:!1}}function sr(n){return new Promise((e,t)=>{let s=Ee.socket(),r=Vf(s),o="",i=!1,a=setTimeout(()=>{i||(i=!0,r.destroy(),t(new Error("Daemon request timed out")))},3e4);r.on("connect",()=>{r.write(js(n))}),r.on("data",c=>{o+=c.toString();let u=o.indexOf(`
9
- `);if(u!==-1){let d=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(d);i=!0,clearTimeout(a),r.end(),e(m)}catch(m){i=!0,clearTimeout(a),r.end(),t(new Error(`Invalid daemon response: ${m.message}`))}}}),r.on("error",c=>{i||(i=!0,clearTimeout(a),t(c))}),r.on("close",()=>{i||(i=!0,clearTimeout(a),t(new Error("Connection closed before response")))})})}async function Jf(n,e,t,s,r,o=!0){let i=Ee.socket();if(!Oe.existsSync(i))return o&&ql().catch(()=>{}),null;try{return await sr({id:qr.randomUUID(),command:n,args:e,options:t,cwd:s,perfStartNs:r})}catch{return null}}async function zf(){try{return(await sr({id:qr.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function Xf(){let n=Ee.pid(),e=Ee.socket(),t=!1;if(Oe.existsSync(n)){let s=parseInt(Oe.readFileSync(n,"utf-8").trim(),10);if(!Number.isNaN(s))try{process.kill(s,"SIGKILL"),t=!0}catch{}}try{Oe.existsSync(n)&&Oe.unlinkSync(n)}catch{}try{Oe.existsSync(e)&&Oe.unlinkSync(e)}catch{}return t}async function ql(){let{spawn:n}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),s=e.join(__dirname,"..","daemon","entry.mjs"),r=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Oe.existsSync(t))o=t,i="bun";else if(Oe.existsSync(s))o=s,i=$i()?"bun":"node";else if(Oe.existsSync(r))o=r,i=$i()?"bun":"node";else return!1;let a=Ee.runDir();Oe.mkdirSync(a,{recursive:!0});let c=Ee.log(),u=Oe.openSync(c,"a");n(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Oe.closeSync(u);let m=Date.now()+3e3;for(;Date.now()<m;)if(await new Promise(p=>setTimeout(p,300)),await Gl())return!0;return!1}var Jt=h(()=>{"use strict";tr();Gr();l(Gl,"isDaemonRunning");l(Bf,"getDaemonStatus");l(sr,"sendRequest");l(Jf,"executeViaDaemon");l(zf,"stopDaemon");l(Xf,"forceKillDaemon");l(ql,"spawnDaemon")});var Vr=h(()=>{"use strict"});import{z as nr}from"zod";function Vl(n,e){let t=n.split(".").map(Number),s=e.split(".").map(Number);for(let r=0;r<3;r++){let o=t[r]??0,i=s[r]??0;if(o<i)return-1;if(o>i)return 1}return 0}var rr,Br=h(()=>{"use strict";rr=nr.object({provider:nr.string(),model:nr.string(),cliVersion:nr.string().optional(),recordedAt:nr.string()});l(Vl,"compareSemver")});var Di={};W(Di,{execAsync:()=>O,execFileAsync:()=>zt});import{exec as Kf,execFile as Yf}from"node:child_process";import{promisify as Bl}from"node:util";var O,zt,Ze=h(()=>{"use strict";O=Bl(Kf),zt=Bl(Yf)});var Jl,zl,Xl,Mi=h(()=>{"use strict";Jl=new Set(["node_modules",".git","dist","build","out",".next",".nuxt","coverage",".cache",".turbo",".vercel",".parcel-cache","__pycache__",".pytest_cache","target","vendor",".venv","venv","eggs","*.egg-info",".prjct",".worktrees"]),zl=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],Xl=/(?:import|from)\s+['"]([^'"]+)['"]/g});function Qf(n){return n instanceof Error&&"code"in n}function _(n){return Qf(n)&&n.code==="ENOENT"}function k(n){return n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}function _i(n){if(n instanceof Error)return n.stack}var V=h(()=>{"use strict";l(Qf,"isNodeError");l(_,"isNotFoundError");l(k,"getErrorMessage");l(_i,"getErrorStack")});import Ql from"node:fs/promises";async function Zl(n,e){let t;try{t=await Ql.readFile(n,"utf-8")}catch(o){if(_(o))return null;throw o}let s;try{s=JSON.parse(t)}catch{return await Kl(n,t),Yl(n,"Malformed JSON"),null}let r=e.safeParse(s);return r.success?s:(await Kl(n,t),Yl(n,Zf(r.error)),null)}async function Kl(n,e){let t=`${n}.backup`;try{await Ql.writeFile(t,e,"utf-8")}catch{}}function Yl(n,e){console.error(`[prjct] Warning: Corrupted storage file: ${n}`),console.error(`[prjct] Reason: ${e}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function Zf(n){return n.issues.slice(0,3).map(e=>`${e.path.join(".")}: ${e.message}`).join("; ")}var eu=h(()=>{"use strict";V();l(Zl,"safeRead");l(Kl,"createBackup");l(Yl,"logCorruption");l(Zf,"formatZodError")});var Qt={};W(Qt,{batchProcess:()=>As,dirExists:()=>Kt,ensureDir:()=>Pt,fileExists:()=>b,listFiles:()=>Yt,readFile:()=>lt,readJson:()=>Se,walkDir:()=>xs,writeFile:()=>Xt,writeJson:()=>ie});import Ct from"node:fs/promises";import Jr from"node:path";async function xs(n,e={}){let t=[],s=e.maxFiles??1/0,r=e.dotfileAllowlist?new Set(e.dotfileAllowlist):null;async function o(i){if(t.length>=s)return;let a=await Ct.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let c of a){if(t.length>=s)break;let u=String(c.name);if(Jl.has(u)||e.skipDotfiles&&u.startsWith(".")&&(!r||!r.has(u)))continue;let d=Jr.join(i,u);c.isDirectory()?await o(d):c.isFile()&&t.push(Jr.relative(n,d))}}return l(o,"walk"),await o(n),t}async function As(n,e,t){let s=[];for(let r=0;r<n.length;r+=e){let o=await Promise.all(n.slice(r,r+e).map(t));for(let i of o)i!==null&&s.push(i)}return s}async function Se(n,e=null,t){if(t)return await Zl(n,t)??e;try{let s=await Ct.readFile(n,"utf-8");return JSON.parse(s)}catch(s){if(_(s))return e;throw s}}async function ie(n,e,t=2){let s=Jr.dirname(n);await Ct.mkdir(s,{recursive:!0});let r=`${JSON.stringify(e,null,t)}
10
- `;await Ct.writeFile(n,r,"utf-8")}async function lt(n,e=""){try{return await Ct.readFile(n,"utf-8")}catch(t){if(_(t))return e;throw t}}async function Xt(n,e){let t=Jr.dirname(n);await Ct.mkdir(t,{recursive:!0}),await Ct.writeFile(n,e,"utf-8")}async function b(n){try{return await Ct.access(n),!0}catch(e){if(_(e))return!1;throw e}}async function Kt(n){try{return(await Ct.stat(n)).isDirectory()}catch(e){if(_(e))return!1;throw e}}async function Pt(n){await Ct.mkdir(n,{recursive:!0})}async function Yt(n,e={}){try{let s=await Ct.readdir(n,{withFileTypes:!0});return e.filesOnly&&(s=s.filter(r=>r.isFile())),e.dirsOnly&&(s=s.filter(r=>r.isDirectory())),e.extension&&(s=s.filter(r=>r.name.endsWith(e.extension))),s.map(r=>r.name)}catch(t){if(_(t))return[];throw t}}var J=h(()=>{"use strict";Mi();eu();V();l(xs,"walkDir");l(As,"batchProcess");l(Se,"readJson");l(ie,"writeJson");l(lt,"readFile");l(Xt,"writeFile");l(b,"fileExists");l(Kt,"dirExists");l(Pt,"ensureDir");l(Yt,"listFiles")});function sn(n,e){let t=typeof n=="string"?new Date(n).getTime():n;return Date.now()-t>e}var zr,or=h(()=>{"use strict";l(sn,"isExpired");zr=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,r)=>s[1].timestamp-r[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[s]of t)this.cache.delete(s)}stats(){return{size:this.cache.size,maxSize:this.maxSize,ttl:this.ttl}}prune(){let e=0;for(let t of this.cache.keys())this.isValid(t)||(this.cache.delete(t),e++);return e}}});var nu={};W(nu,{invalidateProviderCache:()=>nh,readProviderCache:()=>Oi,writeProviderCache:()=>Li});import tu from"node:fs/promises";import eh from"node:os";import su from"node:path";async function Oi(){try{let n=await tu.readFile(Ni,"utf-8"),e=JSON.parse(n);return!e.timestamp||!e.detection||!e.detection.claude||!e.detection.gemini||!e.detection.codex||sn(e.timestamp,sh)?null:e.detection}catch{return null}}async function Li(n){let e={timestamp:new Date().toISOString(),detection:n};await ie(Ni,e)}async function nh(){try{await tu.unlink(Ni)}catch{}}var th,Ni,sh,Fi=h(()=>{"use strict";or();J();th=su.join(eh.homedir(),".prjct-cli","cache"),Ni=su.join(th,"providers.json"),sh=10*60*1e3;l(Oi,"readProviderCache");l(Li,"writeProviderCache");l(nh,"invalidateProviderCache")});var yt={};W(yt,{ClaudeProvider:()=>ou,CursorProvider:()=>cu,GeminiProvider:()=>iu,Providers:()=>ut,detectAllProviders:()=>us,detectAntigravity:()=>ir,detectCodex:()=>Is,detectProvider:()=>Xr,getProviderBranding:()=>Kr,selectProvider:()=>Ui,validateCliVersion:()=>du});import ls from"node:os";import Ot from"node:path";async function uu(n){try{let{stdout:e}=await O(`which ${n}`,{timeout:2e3});return e.trim()}catch{return null}}async function oh(n){try{let{stdout:e}=await O(`${n} --version`,{timeout:2e3}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function Xr(n){let e=ut[n];if(!e.cliCommand)return{installed:!1};let t=await uu(e.cliCommand);if(!t)return{installed:!1};let s=await oh(e.cliCommand),r=du(n,s||void 0);return{installed:!0,version:s||void 0,path:t,versionWarning:r||void 0}}function du(n,e){let t=ut[n];return!t.minCliVersion||!e?null:Vl(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 us(n=!1){if(!n){let i=await Oi();if(i)return i}let[e,t,s]=await Promise.all([Xr("claude"),Xr("gemini"),Is()]),r={installed:s.installed},o={claude:e,gemini:t,codex:r};return await Li(o).catch(()=>{}),o}function Kr(n){return{commitFooter:"Generated with [p/](https://www.prjct.app/)",signature:{claude:"\u26A1 prjct + Claude",gemini:"\u26A1 prjct + Gemini",cursor:"\u26A1 prjct + Cursor",antigravity:"\u26A1 prjct + Antigravity",windsurf:"\u26A1 prjct + Windsurf",codex:"\u26A1 prjct + Codex"}[n]||"\u26A1 prjct"}}async function ir(){let n=au.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=Ot.join(n,"skills","prjct","SKILL.md"),[t,s]=await Promise.all([b(n),b(e)]);return{installed:t,skillInstalled:s,configPath:t?n:void 0}}async function Is(){let n=lu.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=await uu("codex"),t=Ot.join(n,"skills","prjct","SKILL.md"),s=await b(t),r=!!e;return{installed:r,skillInstalled:s,configPath:r?n:void 0}}async function Ui(){let n=await us(),e=n.claude.installed,t=n.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:n}:e&&!t?{provider:"claude",userSelected:!1,detection:n}:t&&!e?{provider:"gemini",userSelected:!1,detection:n}:{provider:"claude",userSelected:!0,detection:n}}var ou,iu,au,cu,rh,lu,ut,We=h(()=>{"use strict";Vr();Br();Ze();J();Fi();ou={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:Ot.join(ls.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:Ot.join(ls.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"},iu={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:Ot.join(ls.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:Ot.join(ls.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"},au={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:Ot.join(ls.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:Ot.join(ls.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"},cu={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"},rh={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"},lu={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:Ot.join(ls.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:Ot.join(ls.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"},ut={claude:ou,gemini:iu,cursor:cu,antigravity:au,windsurf:rh,codex:lu};l(uu,"whichCommand");l(oh,"getCliVersion");l(Xr,"detectProvider");l(du,"validateCliVersion");l(us,"detectAllProviders");l(Kr,"getProviderBranding");l(ir,"detectAntigravity");l(Is,"detectCodex");l(Ui,"selectProvider")});function ih(n){return n instanceof nn}function ge(n){return ih(n)||n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}var nn,Yr,Qr,ar,ds=h(()=>{"use strict";nn=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 n extends nn{static{l(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new n("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new n(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new n(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},Qr=class n extends nn{static{l(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new n(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new n(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},ar=class n extends nn{static{l(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new n(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new n(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};l(ih,"isPrjctError");l(ge,"getErrorMessage")});import{formatDistanceToNowStrict as $E}from"date-fns";function pu(n){let e=n.getFullYear(),t=(n.getMonth()+1).toString().padStart(2,"0"),s=n.getDate().toString().padStart(2,"0");return`${e}-${t}-${s}`}function mu(n){return{year:n.getFullYear().toString(),month:(n.getMonth()+1).toString().padStart(2,"0"),day:n.getDate().toString().padStart(2,"0")}}function R(){return new Date().toISOString()}function rn(n){let e=new Date;return e.setDate(e.getDate()-n),e}function cr(n){let e=Math.floor(n/1e3),t=Math.floor(e/60),s=Math.floor(t/60),r=Math.floor(s/24);return r>0?`${r}d ${s%24}h`:s>0?`${s}h ${t%60}m`:t>0?`${t}m`:`${e}s`}var be=h(()=>{"use strict";l(pu,"formatDate");l(mu,"getYearMonthDay");l(R,"getTimestamp");l(rn,"getDaysAgo");l(cr,"formatDuration")});var an={};W(an,{PACKAGE_ROOT:()=>jt,VERSION:()=>ae,getPackageRoot:()=>Wi,getVersion:()=>eo,resetPackageRoot:()=>Gi});import Hi from"node:fs";import Zr from"node:path";function Wi(){if(on)return on;let n=__dirname;for(let e=0;e<5;e++){let t=Zr.join(n,"package.json");if(Hi.existsSync(t))try{if(JSON.parse(Hi.readFileSync(t,"utf-8")).name==="prjct-cli")return on=n,n}catch{}n=Zr.dirname(n)}return on=Zr.join(__dirname,"..","..",".."),on}function eo(){if(lr)return lr;try{let n=Zr.join(Wi(),"package.json");return lr=JSON.parse(Hi.readFileSync(n,"utf-8")).version,lr}catch(n){return console.error("Failed to read version from package.json:",k(n)),"0.0.0"}}function Gi(n){on=n,lr=null}var lr,on,ae,jt,ze=h(()=>{"use strict";V();lr=null,on=null;l(Wi,"getPackageRoot");l(eo,"getVersion");l(Gi,"resetPackageRoot");ae=eo(),jt=Wi()});async function to(n){try{let{stdout:e}=await O(n,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function ah(){let n=await to("gh api user --jq .login");return n.success&&n.output||(n=await to("git config --global github.user"),n.success&&n.output)?n.output:null}async function ch(){let n=await to("git config user.name");return n.success&&n.output?n.output:null}async function lh(){let n=await to("git config user.email");return n.success&&n.output?n.output:null}async function cn(){let[n,e,t]=await Promise.all([ah(),ch(),lh()]);return{github:n,email:t,name:e||n||"Unknown"}}var so=h(()=>{"use strict";Ze();l(to,"execCommand");l(ah,"detectGitHubUsername");l(ch,"detectGitName");l(lh,"detectGitEmail");l(cn,"detect")});var gu={};W(gu,{default:()=>$});import uh from"node:crypto";import Lt from"node:fs/promises";import ln from"node:os";import N from"node:path";import{globSync as dh}from"glob";var Vi,ph,$,Re=h(()=>{"use strict";be();J();Vi=class{static{l(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?N.resolve(e):N.join(ln.homedir(),".prjct-cli"),this.globalProjectsDir=N.join(this.globalBaseDir,"projects"),this.globalConfigDir=N.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=N.resolve(e),this.globalProjectsDir=N.join(this.globalBaseDir,"projects"),this.globalConfigDir=N.join(this.globalBaseDir,"config")}generateProjectId(e){return uh.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return N.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return N.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return N.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return N.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await Kt(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await b(t)}async ensureGlobalStructure(){await Pt(this.globalBaseDir),await Pt(this.globalProjectsDir),await Pt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),s=["core","progress","planning","analysis","memory"];for(let r of s)await Pt(N.join(t,r));return await Pt(N.join(t,"planning","tasks")),await Pt(N.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:s,month:r,day:o}=mu(t);return N.join(this.getGlobalProjectPath(e),"sessions",s,r,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let s=this.getSessionPath(e,t);return await Pt(s),s}async listSessions(e,t=null,s=null){let r=N.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Lt.readdir(r,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let c=N.join(r,a.name),u=await Lt.readdir(c,{withFileTypes:!0});for(let d of u){if(!d.isDirectory()||s&&d.name!==s.toString().padStart(2,"0"))continue;let m=N.join(c,d.name),p=await Lt.readdir(m,{withFileTypes:!0});for(let g of p)g.isDirectory()&&o.push({year:a.name,month:d.name,day:g.name,path:N.join(m,g.name),date:new Date(`${a.name}-${d.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 N.join(this.getGlobalProjectPath(e),t,s)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Lt.readdir(this.globalProjectsDir,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}async projectExists(e){let t=this.getGlobalProjectPath(e);return await Kt(t)}getDisplayPath(e){let t=ln.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return N.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return N.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return N.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return N.join(this.globalBaseDir,".running")}getDocsPath(){return N.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(We(),ht(yt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(We(),ht(yt)).getActiveProvider();return(We(),ht(yt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return N.join(ln.homedir(),".claude")}getClaudeSettingsPath(){return N.join(this.getClaudeDir(),"settings.json")}getStoragePath(e,t){return N.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return N.join(this.getGlobalProjectPath(e),"context")}getWikiPath(e,t){if(t&&t.trim().length>0)return this.resolveVaultOverride(e,t);let r=N.basename(N.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project";return N.join(ln.homedir(),"Documents","prjct",r)}getWikiPathWithProjectHash(e,t){let r=N.basename(N.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project",o=t.replace(/-/g,"").slice(0,8);return N.join(ln.homedir(),"Documents","prjct",`${r}-${o}`)}getLegacyWikiPath(e){return N.join(e,".prjct","wiki")}resolveVaultOverride(e,t){let s=t.trim();return(s.startsWith("~/")||s==="~")&&(s=N.join(ln.homedir(),s.slice(1))),N.isAbsolute(s)||(s=N.resolve(e,s)),s}async detectMonorepo(e){let t={isMonorepo:!1,type:null,rootPath:e,packages:[]},s=[{file:"pnpm-workspace.yaml",type:"pnpm"},{file:"lerna.json",type:"lerna"},{file:"nx.json",type:"nx"},{file:"rush.json",type:"rush"},{file:"turbo.json",type:"turborepo"}];for(let r of s){let o=N.join(e,r.file);if(await b(o)){t.isMonorepo=!0,t.type=r.type;break}}if(!t.isMonorepo){let r=N.join(e,"package.json");if(await b(r))try{let o=await Lt.readFile(r,"utf-8");JSON.parse(o).workspaces&&(t.isMonorepo=!0,t.type="npm")}catch{}}return t.isMonorepo&&(t.packages=await this.discoverMonorepoPackages(e,t.type)),t}async discoverMonorepoPackages(e,t){let s=[],r=[];try{if(t==="pnpm"){let i=(await Lt.readFile(N.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(r=i[1].split(`
11
- `).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=N.join(e,"package.json"),i=await Lt.readFile(o,"utf-8"),a=JSON.parse(i);if(Array.isArray(a.workspaces)?r=a.workspaces:a.workspaces?.packages&&(r=a.workspaces.packages),t==="lerna"){let c=N.join(e,"lerna.json");if(await b(c)){let u=await Lt.readFile(c,"utf-8"),d=JSON.parse(u);d.packages&&(r=d.packages)}}}else if(t==="nx")r=["apps/*","libs/*","packages/*"];else if(t==="turborepo"){let o=N.join(e,"package.json"),i=await Lt.readFile(o,"utf-8"),a=JSON.parse(i);Array.isArray(a.workspaces)&&(r=a.workspaces)}r.length===0&&(r=["packages/*","apps/*","libs/*"]);for(let o of r){if(o.startsWith("!"))continue;let i=dh(o,{cwd:e,absolute:!1});for(let a of i){let c=N.join(e,a),u=N.join(c,"package.json");if(await b(u))try{let d=await Lt.readFile(u,"utf-8"),m=JSON.parse(d),p=N.join(c,"PRJCT.md");s.push({name:m.name||N.basename(a),path:c,relativePath:a,hasPrjctMd:await b(p)})}catch{}}}}catch{}return s}async findContainingPackage(e,t){if(!t.isMonorepo)return null;let s=N.resolve(e);for(let r of t.packages){let o=N.resolve(r.path);if(s.startsWith(o))return r}return null}async findMonorepoRoot(e){let t=N.resolve(e),s=N.parse(t).root;for(;t!==s;){if((await this.detectMonorepo(t)).isMonorepo)return t;t=N.dirname(t)}return null}},ph=new Vi,$=ph});var yu={};W(yu,{default:()=>mh,worktreeService:()=>hu});import Bi from"node:fs/promises";import Ft from"node:path";var fu,Ji,hu,mh,wu=h(()=>{"use strict";Ze();J();fu=".worktrees",Ji=class{static{l(this,"WorktreeService")}async create(e,t,s={}){let r=await this.getMainWorktree(e),o=Ft.join(r,fu,t),i=s.branch||`feat/${t}`;await Bi.mkdir(Ft.join(r,fu),{recursive:!0});let a=s.baseBranch?` ${s.baseBranch}`:"";await O(`git worktree add "${o}" -b "${i}"${a}`,{cwd:r});let{stdout:c}=await O("git rev-parse HEAD",{cwd:o});return{path:o,branch:i,commit:c.trim(),isMain:!1,slug:t}}async remove(e,t=!1){let s=await this.getMainWorktree(e),r;if(t)try{let{stdout:o}=await O("git rev-parse --abbrev-ref HEAD",{cwd:e});r=o.trim()}catch{}if(await O(`git worktree remove "${e}" --force`,{cwd:s}),t&&r&&r!=="main"&&r!=="master")try{await O(`git branch -D "${r}"`,{cwd:s})}catch{}}async list(e){let t=await this.getMainWorktree(e),{stdout:s}=await O("git worktree list --porcelain",{cwd:t});return this.parsePorcelainOutput(s,t)}async detect(e){try{let{stdout:t}=await O("git rev-parse --git-common-dir",{cwd:e}),{stdout:s}=await O("git rev-parse --git-dir",{cwd:e}),r=Ft.resolve(e,t.trim()),o=Ft.resolve(e,s.trim());if(r!==o){let{stdout:i}=await O("git rev-parse --abbrev-ref HEAD",{cwd:e}),{stdout:a}=await O("git rev-parse HEAD",{cwd:e}),{stdout:c}=await O("git rev-parse --show-toplevel",{cwd:e}),u=c.trim(),d=Ft.basename(u);return{path:u,branch:i.trim(),commit:a.trim(),isMain:!1,slug:d}}return null}catch{return null}}async getMainWorktree(e){try{let{stdout:s}=await O("git worktree list --porcelain",{cwd:e}),r=s.split(`
12
- `)[0];if(r?.startsWith("worktree "))return r.replace("worktree ","").trim()}catch{}let{stdout:t}=await O("git rev-parse --show-toplevel",{cwd:e});return t.trim()}async setup(e,t){let s=Ft.join(t,".env");await b(s)&&await Bi.copyFile(s,Ft.join(e,".env"));let r=Ft.join(t,".prjct"),o=Ft.join(e,".prjct");await b(r)&&!await b(o)&&await Bi.symlink(r,o,"dir")}async teardown(e){}async clean(e){let t=await this.list(e),s=[],r=await this.getMainWorktree(e);await O("git worktree prune",{cwd:r});for(let o of t)o.isMain||await b(o.path)||s.push(o.slug);return s}parsePorcelainOutput(e,t){let s=[],r=e.trim().split(`
7
+ var Nf=Object.create;var er=Object.defineProperty;var Of=Object.getOwnPropertyDescriptor;var Lf=Object.getOwnPropertyNames;var Ff=Object.getPrototypeOf,Uf=Object.prototype.hasOwnProperty;var l=(n,e)=>er(n,"name",{value:e,configurable:!0}),Je=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});var h=(n,e)=>()=>(n&&(e=n(n=0)),e);var Hf=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),W=(n,e)=>{for(var t in e)er(n,t,{get:e[t],enumerable:!0})},Ul=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Lf(e))!Uf.call(n,r)&&r!==t&&er(n,r,{get:()=>e[r],enumerable:!(s=Of(e,r))||s.enumerable});return n};var Wf=(n,e,t)=>(t=n!=null?Nf(Ff(n)):{},Ul(e||!n||!n.__esModule?er(t,"default",{value:n,enumerable:!0}):t,n)),ht=n=>Ul(er({},"__esModule",{value:!0}),n);var Hl={};W(Hl,{REGISTERED_VERBS_SET:()=>qf});var Gf,qf,Wl=h(()=>{"use strict";Gf=["task","ship","tag","remember","status","workflow","init","analyze","analysis-save-llm","sync","regen","context","login","logout","auth","seed","install","capture"],qf=new Set(Gf)});var Gl={};W(Gl,{DAEMON_PATHS:()=>Ee,IDLE_TIMEOUT_MS:()=>Ii,MAX_BUFFER_SIZE:()=>$i,encodeMessage:()=>js});function js(n){return Buffer.from(`${JSON.stringify(n)}
8
+ `)}var Ee,Ii,$i,Gr=h(()=>{"use strict";Ee={runDir:l(()=>`${process.env.HOME||Je("node:os").homedir()}/.prjct-cli/run`,"runDir"),socket:l(()=>`${Ee.runDir()}/daemon.sock`,"socket"),pid:l(()=>`${Ee.runDir()}/daemon.pid`,"pid"),log:l(()=>`${Ee.runDir()}/daemon.log`,"log")},Ii=30*60*1e3,$i=1024*1024;l(js,"encodeMessage")});function ql(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function Rs(){return ql()==="bun"}function Di(){if(ql()==="bun")return!0;try{let{execSync:n}=Je("node:child_process");return n("bun --version",{stdio:"ignore"}),!0}catch{return!1}}var tr=h(()=>{"use strict";l(ql,"detectRuntime");l(Rs,"isBun");l(Di,"isBunAvailable")});var Bt={};W(Bt,{executeViaDaemon:()=>Jf,forceKillDaemon:()=>Xf,getDaemonStatus:()=>Bf,isDaemonRunning:()=>Vl,sendRequest:()=>sr,spawnDaemon:()=>Bl,stopDaemon:()=>zf});import qr from"node:crypto";import Oe from"node:fs";import{connect as Vf}from"node:net";async function Vl(){let n=Ee.socket();if(!Oe.existsSync(n))return!1;try{return(await sr({id:qr.randomUUID(),command:"__ping",args:[],options:{},cwd:process.cwd()})).success}catch{try{Oe.unlinkSync(n)}catch{}return!1}}async function Bf(){let n=Ee.socket(),e=Ee.pid();if(!Oe.existsSync(n))return{running:!1};try{let t=await sr({id:qr.randomUUID(),command:"daemon",args:["status"],options:{},cwd:process.cwd()});if(t.success&&t.result)return t.result}catch{}return Oe.existsSync(e)?{running:!1,pid:parseInt(Oe.readFileSync(e,"utf-8").trim(),10),socketPath:n}:{running:!1}}function sr(n){return new Promise((e,t)=>{let s=Ee.socket(),r=Vf(s),o="",i=!1,a=setTimeout(()=>{i||(i=!0,r.destroy(),t(new Error("Daemon request timed out")))},3e4);r.on("connect",()=>{r.write(js(n))}),r.on("data",c=>{o+=c.toString();let u=o.indexOf(`
9
+ `);if(u!==-1){let d=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(d);i=!0,clearTimeout(a),r.end(),e(m)}catch(m){i=!0,clearTimeout(a),r.end(),t(new Error(`Invalid daemon response: ${m.message}`))}}}),r.on("error",c=>{i||(i=!0,clearTimeout(a),t(c))}),r.on("close",()=>{i||(i=!0,clearTimeout(a),t(new Error("Connection closed before response")))})})}async function Jf(n,e,t,s,r,o=!0){let i=Ee.socket();if(!Oe.existsSync(i))return o&&Bl().catch(()=>{}),null;try{return await sr({id:qr.randomUUID(),command:n,args:e,options:t,cwd:s,perfStartNs:r})}catch{return null}}async function zf(){try{return(await sr({id:qr.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function Xf(){let n=Ee.pid(),e=Ee.socket(),t=!1;if(Oe.existsSync(n)){let s=parseInt(Oe.readFileSync(n,"utf-8").trim(),10);if(!Number.isNaN(s))try{process.kill(s,"SIGKILL"),t=!0}catch{}}try{Oe.existsSync(n)&&Oe.unlinkSync(n)}catch{}try{Oe.existsSync(e)&&Oe.unlinkSync(e)}catch{}return t}async function Bl(){let{spawn:n}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),s=e.join(__dirname,"..","daemon","entry.mjs"),r=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Oe.existsSync(t))o=t,i="bun";else if(Oe.existsSync(s))o=s,i=Di()?"bun":"node";else if(Oe.existsSync(r))o=r,i=Di()?"bun":"node";else return!1;let a=Ee.runDir();Oe.mkdirSync(a,{recursive:!0});let c=Ee.log(),u=Oe.openSync(c,"a");n(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Oe.closeSync(u);let m=Date.now()+3e3;for(;Date.now()<m;)if(await new Promise(p=>setTimeout(p,300)),await Vl())return!0;return!1}var Jt=h(()=>{"use strict";tr();Gr();l(Vl,"isDaemonRunning");l(Bf,"getDaemonStatus");l(sr,"sendRequest");l(Jf,"executeViaDaemon");l(zf,"stopDaemon");l(Xf,"forceKillDaemon");l(Bl,"spawnDaemon")});var Vr=h(()=>{"use strict"});import{z as nr}from"zod";function Jl(n,e){let t=n.split(".").map(Number),s=e.split(".").map(Number);for(let r=0;r<3;r++){let o=t[r]??0,i=s[r]??0;if(o<i)return-1;if(o>i)return 1}return 0}var rr,Br=h(()=>{"use strict";rr=nr.object({provider:nr.string(),model:nr.string(),cliVersion:nr.string().optional(),recordedAt:nr.string()});l(Jl,"compareSemver")});var Mi={};W(Mi,{execAsync:()=>O,execFileAsync:()=>zt});import{exec as Kf,execFile as Yf}from"node:child_process";import{promisify as zl}from"node:util";var O,zt,Ze=h(()=>{"use strict";O=zl(Kf),zt=zl(Yf)});var Xl,Kl,Yl,_i=h(()=>{"use strict";Xl=new Set(["node_modules",".git","dist","build","out",".next",".nuxt","coverage",".cache",".turbo",".vercel",".parcel-cache","__pycache__",".pytest_cache","target","vendor",".venv","venv","eggs","*.egg-info",".prjct",".worktrees"]),Kl=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],Yl=/(?:import|from)\s+['"]([^'"]+)['"]/g});function Qf(n){return n instanceof Error&&"code"in n}function _(n){return Qf(n)&&n.code==="ENOENT"}function k(n){return n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}function Ni(n){if(n instanceof Error)return n.stack}var V=h(()=>{"use strict";l(Qf,"isNodeError");l(_,"isNotFoundError");l(k,"getErrorMessage");l(Ni,"getErrorStack")});import eu from"node:fs/promises";async function tu(n,e){let t;try{t=await eu.readFile(n,"utf-8")}catch(o){if(_(o))return null;throw o}let s;try{s=JSON.parse(t)}catch{return await Ql(n,t),Zl(n,"Malformed JSON"),null}let r=e.safeParse(s);return r.success?s:(await Ql(n,t),Zl(n,Zf(r.error)),null)}async function Ql(n,e){let t=`${n}.backup`;try{await eu.writeFile(t,e,"utf-8")}catch{}}function Zl(n,e){console.error(`[prjct] Warning: Corrupted storage file: ${n}`),console.error(`[prjct] Reason: ${e}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function Zf(n){return n.issues.slice(0,3).map(e=>`${e.path.join(".")}: ${e.message}`).join("; ")}var su=h(()=>{"use strict";V();l(tu,"safeRead");l(Ql,"createBackup");l(Zl,"logCorruption");l(Zf,"formatZodError")});var Qt={};W(Qt,{batchProcess:()=>As,dirExists:()=>Kt,ensureDir:()=>Pt,fileExists:()=>b,listFiles:()=>Yt,readFile:()=>ut,readJson:()=>Se,walkDir:()=>xs,writeFile:()=>Xt,writeJson:()=>ie});import Ct from"node:fs/promises";import Jr from"node:path";async function xs(n,e={}){let t=[],s=e.maxFiles??1/0,r=e.dotfileAllowlist?new Set(e.dotfileAllowlist):null;async function o(i){if(t.length>=s)return;let a=await Ct.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let c of a){if(t.length>=s)break;let u=String(c.name);if(Xl.has(u)||e.skipDotfiles&&u.startsWith(".")&&(!r||!r.has(u)))continue;let d=Jr.join(i,u);c.isDirectory()?await o(d):c.isFile()&&t.push(Jr.relative(n,d))}}return l(o,"walk"),await o(n),t}async function As(n,e,t){let s=[];for(let r=0;r<n.length;r+=e){let o=await Promise.all(n.slice(r,r+e).map(t));for(let i of o)i!==null&&s.push(i)}return s}async function Se(n,e=null,t){if(t)return await tu(n,t)??e;try{let s=await Ct.readFile(n,"utf-8");return JSON.parse(s)}catch(s){if(_(s))return e;throw s}}async function ie(n,e,t=2){let s=Jr.dirname(n);await Ct.mkdir(s,{recursive:!0});let r=`${JSON.stringify(e,null,t)}
10
+ `;await Ct.writeFile(n,r,"utf-8")}async function ut(n,e=""){try{return await Ct.readFile(n,"utf-8")}catch(t){if(_(t))return e;throw t}}async function Xt(n,e){let t=Jr.dirname(n);await Ct.mkdir(t,{recursive:!0}),await Ct.writeFile(n,e,"utf-8")}async function b(n){try{return await Ct.access(n),!0}catch(e){if(_(e))return!1;throw e}}async function Kt(n){try{return(await Ct.stat(n)).isDirectory()}catch(e){if(_(e))return!1;throw e}}async function Pt(n){await Ct.mkdir(n,{recursive:!0})}async function Yt(n,e={}){try{let s=await Ct.readdir(n,{withFileTypes:!0});return e.filesOnly&&(s=s.filter(r=>r.isFile())),e.dirsOnly&&(s=s.filter(r=>r.isDirectory())),e.extension&&(s=s.filter(r=>r.name.endsWith(e.extension))),s.map(r=>r.name)}catch(t){if(_(t))return[];throw t}}var J=h(()=>{"use strict";_i();su();V();l(xs,"walkDir");l(As,"batchProcess");l(Se,"readJson");l(ie,"writeJson");l(ut,"readFile");l(Xt,"writeFile");l(b,"fileExists");l(Kt,"dirExists");l(Pt,"ensureDir");l(Yt,"listFiles")});function sn(n,e){let t=typeof n=="string"?new Date(n).getTime():n;return Date.now()-t>e}var zr,or=h(()=>{"use strict";l(sn,"isExpired");zr=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,r)=>s[1].timestamp-r[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[s]of t)this.cache.delete(s)}stats(){return{size:this.cache.size,maxSize:this.maxSize,ttl:this.ttl}}prune(){let e=0;for(let t of this.cache.keys())this.isValid(t)||(this.cache.delete(t),e++);return e}}});var ou={};W(ou,{invalidateProviderCache:()=>nh,readProviderCache:()=>Li,writeProviderCache:()=>Fi});import nu from"node:fs/promises";import eh from"node:os";import ru from"node:path";async function Li(){try{let n=await nu.readFile(Oi,"utf-8"),e=JSON.parse(n);return!e.timestamp||!e.detection||!e.detection.claude||!e.detection.gemini||!e.detection.codex||sn(e.timestamp,sh)?null:e.detection}catch{return null}}async function Fi(n){let e={timestamp:new Date().toISOString(),detection:n};await ie(Oi,e)}async function nh(){try{await nu.unlink(Oi)}catch{}}var th,Oi,sh,Ui=h(()=>{"use strict";or();J();th=ru.join(eh.homedir(),".prjct-cli","cache"),Oi=ru.join(th,"providers.json"),sh=10*60*1e3;l(Li,"readProviderCache");l(Fi,"writeProviderCache");l(nh,"invalidateProviderCache")});var yt={};W(yt,{ClaudeProvider:()=>Xr,CursorProvider:()=>cu,GeminiProvider:()=>Hi,Providers:()=>et,detectAllProviders:()=>Zt,detectAntigravity:()=>ir,detectCodex:()=>Is,detectProvider:()=>Kr,getActiveProvider:()=>ih,getProviderBranding:()=>Yr,selectProvider:()=>Wi,validateCliVersion:()=>du});import us from"node:os";import Ot from"node:path";async function uu(n){try{let{stdout:e}=await O(`which ${n}`,{timeout:2e3});return e.trim()}catch{return null}}async function oh(n){try{let{stdout:e}=await O(`${n} --version`,{timeout:2e3}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function Kr(n){let e=et[n];if(!e.cliCommand)return{installed:!1};let t=await uu(e.cliCommand);if(!t)return{installed:!1};let s=await oh(e.cliCommand),r=du(n,s||void 0);return{installed:!0,version:s||void 0,path:t,versionWarning:r||void 0}}function du(n,e){let t=et[n];return!t.minCliVersion||!e?null:Jl(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 Zt(n=!1){if(!n){let i=await Li();if(i)return i}let[e,t,s]=await Promise.all([Kr("claude"),Kr("gemini"),Is()]),r={installed:s.installed},o={claude:e,gemini:t,codex:r};return await Fi(o).catch(()=>{}),o}async function ih(n){if(n&&et[n])return et[n];let e=await Zt();return e.claude.installed&&!e.gemini.installed?Xr:e.gemini.installed&&!e.claude.installed?Hi:Xr}function Yr(n){return{commitFooter:"Generated with [p/](https://www.prjct.app/)",signature:{claude:"\u26A1 prjct + Claude",gemini:"\u26A1 prjct + Gemini",cursor:"\u26A1 prjct + Cursor",antigravity:"\u26A1 prjct + Antigravity",windsurf:"\u26A1 prjct + Windsurf",codex:"\u26A1 prjct + Codex"}[n]||"\u26A1 prjct"}}async function ir(){let n=au.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=Ot.join(n,"skills","prjct","SKILL.md"),[t,s]=await Promise.all([b(n),b(e)]);return{installed:t,skillInstalled:s,configPath:t?n:void 0}}async function Is(){let n=lu.configDir;if(!n)return{installed:!1,skillInstalled:!1};let e=await uu("codex"),t=Ot.join(n,"skills","prjct","SKILL.md"),s=await b(t),r=!!e;return{installed:r,skillInstalled:s,configPath:r?n:void 0}}async function Wi(){let n=await Zt(),e=n.claude.installed,t=n.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:n}:e&&!t?{provider:"claude",userSelected:!1,detection:n}:t&&!e?{provider:"gemini",userSelected:!1,detection:n}:{provider:"claude",userSelected:!0,detection:n}}var Xr,Hi,au,cu,rh,lu,et,We=h(()=>{"use strict";Vr();Br();Ze();J();Ui();Xr={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:Ot.join(us.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:Ot.join(us.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"},Hi={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:Ot.join(us.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:Ot.join(us.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"},au={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:Ot.join(us.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:Ot.join(us.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"},cu={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"},rh={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"},lu={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:Ot.join(us.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:Ot.join(us.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"},et={claude:Xr,gemini:Hi,cursor:cu,antigravity:au,windsurf:rh,codex:lu};l(uu,"whichCommand");l(oh,"getCliVersion");l(Kr,"detectProvider");l(du,"validateCliVersion");l(Zt,"detectAllProviders");l(ih,"getActiveProvider");l(Yr,"getProviderBranding");l(ir,"detectAntigravity");l(Is,"detectCodex");l(Wi,"selectProvider")});function ah(n){return n instanceof nn}function ge(n){return ah(n)||n instanceof Error?n.message:typeof n=="string"?n:"Unknown error"}var nn,Qr,Zr,ar,ds=h(()=>{"use strict";nn=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)}},Qr=class n extends nn{static{l(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new n("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new n(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new n(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},Zr=class n extends nn{static{l(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new n(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new n(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},ar=class n extends nn{static{l(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new n(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new n(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};l(ah,"isPrjctError");l(ge,"getErrorMessage")});import{formatDistanceToNowStrict as DE}from"date-fns";function pu(n){let e=n.getFullYear(),t=(n.getMonth()+1).toString().padStart(2,"0"),s=n.getDate().toString().padStart(2,"0");return`${e}-${t}-${s}`}function mu(n){return{year:n.getFullYear().toString(),month:(n.getMonth()+1).toString().padStart(2,"0"),day:n.getDate().toString().padStart(2,"0")}}function R(){return new Date().toISOString()}function rn(n){let e=new Date;return e.setDate(e.getDate()-n),e}function cr(n){let e=Math.floor(n/1e3),t=Math.floor(e/60),s=Math.floor(t/60),r=Math.floor(s/24);return r>0?`${r}d ${s%24}h`:s>0?`${s}h ${t%60}m`:t>0?`${t}m`:`${e}s`}var be=h(()=>{"use strict";l(pu,"formatDate");l(mu,"getYearMonthDay");l(R,"getTimestamp");l(rn,"getDaysAgo");l(cr,"formatDuration")});var an={};W(an,{PACKAGE_ROOT:()=>jt,VERSION:()=>ae,getPackageRoot:()=>qi,getVersion:()=>to,resetPackageRoot:()=>Vi});import Gi from"node:fs";import eo from"node:path";function qi(){if(on)return on;let n=__dirname;for(let e=0;e<5;e++){let t=eo.join(n,"package.json");if(Gi.existsSync(t))try{if(JSON.parse(Gi.readFileSync(t,"utf-8")).name==="prjct-cli")return on=n,n}catch{}n=eo.dirname(n)}return on=eo.join(__dirname,"..","..",".."),on}function to(){if(lr)return lr;try{let n=eo.join(qi(),"package.json");return lr=JSON.parse(Gi.readFileSync(n,"utf-8")).version,lr}catch(n){return console.error("Failed to read version from package.json:",k(n)),"0.0.0"}}function Vi(n){on=n,lr=null}var lr,on,ae,jt,ze=h(()=>{"use strict";V();lr=null,on=null;l(qi,"getPackageRoot");l(to,"getVersion");l(Vi,"resetPackageRoot");ae=to(),jt=qi()});async function so(n){try{let{stdout:e}=await O(n,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function ch(){let n=await so("gh api user --jq .login");return n.success&&n.output||(n=await so("git config --global github.user"),n.success&&n.output)?n.output:null}async function lh(){let n=await so("git config user.name");return n.success&&n.output?n.output:null}async function uh(){let n=await so("git config user.email");return n.success&&n.output?n.output:null}async function cn(){let[n,e,t]=await Promise.all([ch(),lh(),uh()]);return{github:n,email:t,name:e||n||"Unknown"}}var no=h(()=>{"use strict";Ze();l(so,"execCommand");l(ch,"detectGitHubUsername");l(lh,"detectGitName");l(uh,"detectGitEmail");l(cn,"detect")});var gu={};W(gu,{default:()=>$});import dh from"node:crypto";import Lt from"node:fs/promises";import ln from"node:os";import N from"node:path";import{globSync as ph}from"glob";var Ji,mh,$,Re=h(()=>{"use strict";be();J();Ji=class{static{l(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?N.resolve(e):N.join(ln.homedir(),".prjct-cli"),this.globalProjectsDir=N.join(this.globalBaseDir,"projects"),this.globalConfigDir=N.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=N.resolve(e),this.globalProjectsDir=N.join(this.globalBaseDir,"projects"),this.globalConfigDir=N.join(this.globalBaseDir,"config")}generateProjectId(e){return dh.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return N.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return N.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return N.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return N.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await Kt(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await b(t)}async ensureGlobalStructure(){await Pt(this.globalBaseDir),await Pt(this.globalProjectsDir),await Pt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),s=["core","progress","planning","analysis","memory"];for(let r of s)await Pt(N.join(t,r));return await Pt(N.join(t,"planning","tasks")),await Pt(N.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:s,month:r,day:o}=mu(t);return N.join(this.getGlobalProjectPath(e),"sessions",s,r,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let s=this.getSessionPath(e,t);return await Pt(s),s}async listSessions(e,t=null,s=null){let r=N.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Lt.readdir(r,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let c=N.join(r,a.name),u=await Lt.readdir(c,{withFileTypes:!0});for(let d of u){if(!d.isDirectory()||s&&d.name!==s.toString().padStart(2,"0"))continue;let m=N.join(c,d.name),p=await Lt.readdir(m,{withFileTypes:!0});for(let g of p)g.isDirectory()&&o.push({year:a.name,month:d.name,day:g.name,path:N.join(m,g.name),date:new Date(`${a.name}-${d.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 N.join(this.getGlobalProjectPath(e),t,s)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Lt.readdir(this.globalProjectsDir,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}async projectExists(e){let t=this.getGlobalProjectPath(e);return await Kt(t)}getDisplayPath(e){let t=ln.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return N.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return N.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return N.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return N.join(this.globalBaseDir,".running")}getDocsPath(){return N.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(We(),ht(yt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(We(),ht(yt)).getActiveProvider();return(We(),ht(yt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return N.join(ln.homedir(),".claude")}getClaudeSettingsPath(){return N.join(this.getClaudeDir(),"settings.json")}getStoragePath(e,t){return N.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return N.join(this.getGlobalProjectPath(e),"context")}getWikiPath(e,t){if(t&&t.trim().length>0)return this.resolveVaultOverride(e,t);let r=N.basename(N.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project";return N.join(ln.homedir(),"Documents","prjct",r)}getWikiPathWithProjectHash(e,t){let r=N.basename(N.resolve(e)).toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"project",o=t.replace(/-/g,"").slice(0,8);return N.join(ln.homedir(),"Documents","prjct",`${r}-${o}`)}getLegacyWikiPath(e){return N.join(e,".prjct","wiki")}resolveVaultOverride(e,t){let s=t.trim();return(s.startsWith("~/")||s==="~")&&(s=N.join(ln.homedir(),s.slice(1))),N.isAbsolute(s)||(s=N.resolve(e,s)),s}async detectMonorepo(e){let t={isMonorepo:!1,type:null,rootPath:e,packages:[]},s=[{file:"pnpm-workspace.yaml",type:"pnpm"},{file:"lerna.json",type:"lerna"},{file:"nx.json",type:"nx"},{file:"rush.json",type:"rush"},{file:"turbo.json",type:"turborepo"}];for(let r of s){let o=N.join(e,r.file);if(await b(o)){t.isMonorepo=!0,t.type=r.type;break}}if(!t.isMonorepo){let r=N.join(e,"package.json");if(await b(r))try{let o=await Lt.readFile(r,"utf-8");JSON.parse(o).workspaces&&(t.isMonorepo=!0,t.type="npm")}catch{}}return t.isMonorepo&&(t.packages=await this.discoverMonorepoPackages(e,t.type)),t}async discoverMonorepoPackages(e,t){let s=[],r=[];try{if(t==="pnpm"){let i=(await Lt.readFile(N.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(r=i[1].split(`
11
+ `).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=N.join(e,"package.json"),i=await Lt.readFile(o,"utf-8"),a=JSON.parse(i);if(Array.isArray(a.workspaces)?r=a.workspaces:a.workspaces?.packages&&(r=a.workspaces.packages),t==="lerna"){let c=N.join(e,"lerna.json");if(await b(c)){let u=await Lt.readFile(c,"utf-8"),d=JSON.parse(u);d.packages&&(r=d.packages)}}}else if(t==="nx")r=["apps/*","libs/*","packages/*"];else if(t==="turborepo"){let o=N.join(e,"package.json"),i=await Lt.readFile(o,"utf-8"),a=JSON.parse(i);Array.isArray(a.workspaces)&&(r=a.workspaces)}r.length===0&&(r=["packages/*","apps/*","libs/*"]);for(let o of r){if(o.startsWith("!"))continue;let i=ph(o,{cwd:e,absolute:!1});for(let a of i){let c=N.join(e,a),u=N.join(c,"package.json");if(await b(u))try{let d=await Lt.readFile(u,"utf-8"),m=JSON.parse(d),p=N.join(c,"PRJCT.md");s.push({name:m.name||N.basename(a),path:c,relativePath:a,hasPrjctMd:await b(p)})}catch{}}}}catch{}return s}async findContainingPackage(e,t){if(!t.isMonorepo)return null;let s=N.resolve(e);for(let r of t.packages){let o=N.resolve(r.path);if(s.startsWith(o))return r}return null}async findMonorepoRoot(e){let t=N.resolve(e),s=N.parse(t).root;for(;t!==s;){if((await this.detectMonorepo(t)).isMonorepo)return t;t=N.dirname(t)}return null}},mh=new Ji,$=mh});var yu={};W(yu,{default:()=>gh,worktreeService:()=>hu});import zi from"node:fs/promises";import Ft from"node:path";var fu,Xi,hu,gh,wu=h(()=>{"use strict";Ze();J();fu=".worktrees",Xi=class{static{l(this,"WorktreeService")}async create(e,t,s={}){let r=await this.getMainWorktree(e),o=Ft.join(r,fu,t),i=s.branch||`feat/${t}`;await zi.mkdir(Ft.join(r,fu),{recursive:!0});let a=s.baseBranch?` ${s.baseBranch}`:"";await O(`git worktree add "${o}" -b "${i}"${a}`,{cwd:r});let{stdout:c}=await O("git rev-parse HEAD",{cwd:o});return{path:o,branch:i,commit:c.trim(),isMain:!1,slug:t}}async remove(e,t=!1){let s=await this.getMainWorktree(e),r;if(t)try{let{stdout:o}=await O("git rev-parse --abbrev-ref HEAD",{cwd:e});r=o.trim()}catch{}if(await O(`git worktree remove "${e}" --force`,{cwd:s}),t&&r&&r!=="main"&&r!=="master")try{await O(`git branch -D "${r}"`,{cwd:s})}catch{}}async list(e){let t=await this.getMainWorktree(e),{stdout:s}=await O("git worktree list --porcelain",{cwd:t});return this.parsePorcelainOutput(s,t)}async detect(e){try{let{stdout:t}=await O("git rev-parse --git-common-dir",{cwd:e}),{stdout:s}=await O("git rev-parse --git-dir",{cwd:e}),r=Ft.resolve(e,t.trim()),o=Ft.resolve(e,s.trim());if(r!==o){let{stdout:i}=await O("git rev-parse --abbrev-ref HEAD",{cwd:e}),{stdout:a}=await O("git rev-parse HEAD",{cwd:e}),{stdout:c}=await O("git rev-parse --show-toplevel",{cwd:e}),u=c.trim(),d=Ft.basename(u);return{path:u,branch:i.trim(),commit:a.trim(),isMain:!1,slug:d}}return null}catch{return null}}async getMainWorktree(e){try{let{stdout:s}=await O("git worktree list --porcelain",{cwd:e}),r=s.split(`
12
+ `)[0];if(r?.startsWith("worktree "))return r.replace("worktree ","").trim()}catch{}let{stdout:t}=await O("git rev-parse --show-toplevel",{cwd:e});return t.trim()}async setup(e,t){let s=Ft.join(t,".env");await b(s)&&await zi.copyFile(s,Ft.join(e,".env"));let r=Ft.join(t,".prjct"),o=Ft.join(e,".prjct");await b(r)&&!await b(o)&&await zi.symlink(r,o,"dir")}async teardown(e){}async clean(e){let t=await this.list(e),s=[],r=await this.getMainWorktree(e);await O("git worktree prune",{cwd:r});for(let o of t)o.isMain||await b(o.path)||s.push(o.slug);return s}parsePorcelainOutput(e,t){let s=[],r=e.trim().split(`
13
13
 
14
14
  `);for(let o of r){if(!o.trim())continue;let i=o.trim().split(`
15
- `),a="",c="",u="",d=!1;for(let m of i)m.startsWith("worktree ")?a=m.replace("worktree ","").trim():m.startsWith("HEAD ")?c=m.replace("HEAD ","").trim():m.startsWith("branch ")?u=m.replace("branch refs/heads/","").trim():m==="bare"?d=!0:m==="detached"&&(u="(detached)");if(a){let m=a===t||d;s.push({path:a,branch:u,commit:c,isMain:m,slug:m?"main":Ft.basename(a)})}}return s}},hu=new Ji,mh=hu});var ur={};W(ur,{default:()=>I});import zi from"node:fs/promises";import gh from"node:path";import*as no from"jsonc-parser";function ku(n){let e=[],t=no.parse(n,e,{allowTrailingComma:!0,disallowComments:!1});if(e.length>0){let s=e[0];throw new SyntaxError(`JSON parse error at offset ${s.offset}: ${no.printParseErrorCode(s.error)}`)}return t}var Xi,fh,I,de=h(()=>{"use strict";ds();V();be();J();ze();so();Re();l(ku,"parseJsonc");Xi=class{static{l(this,"ConfigManager")}async readConfig(e){try{let t=$.getLocalConfigPath(e),s=await zi.readFile(t,"utf-8");return ku(s)}catch(t){return _(t)||console.warn(`Warning: Could not read config at ${e}: ${ge(t)}`),null}}async writeConfig(e,t){let s=$.getLocalConfigPath(e);await ie(s,t)}async readGlobalConfig(e){try{let t=$.getGlobalProjectConfigPath(e),s=await zi.readFile(t,"utf-8");return ku(s)}catch(t){return _(t)||console.warn(`Warning: Could not read global config for ${e}: ${ge(t)}`),null}}async writeGlobalConfig(e,t){let s=$.getGlobalProjectConfigPath(e);await ie(s,t)}async ensureGlobalConfig(e){let t=await this.readGlobalConfig(e);if(!t){let s=R();t={projectId:e,authors:[],version:ae,lastSync:s},await this.writeGlobalConfig(e,t)}return t}async createConfig(e,t){let s=$.generateProjectId(e),r=$.getGlobalProjectPath(s),o=$.getDisplayPath(r),i=R(),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=R(),await this.writeGlobalConfig(t,s))}validateConfig(e){return!(!e||!e.projectId||!e.dataPath)}async needsMigration(e){if(!await $.hasLegacyStructure(e))return!1;if(!await $.hasConfig(e))return!0;let r=await this.readConfig(e);if(!r||!r.projectId)return!0;let o=$.getGlobalProjectPath(r.projectId);try{return(await zi.readdir(gh.join(o,"core"))).length===0}catch(i){return _(i),!0}}async getProjectId(e){let t=await this.readConfig(e);if(t?.projectId)return t.projectId;try{let{worktreeService:s}=await Promise.resolve().then(()=>(wu(),yu));if(await s.detect(e)){let o=await s.getMainWorktree(e);if(o!==e){let i=await this.readConfig(o);if(i?.projectId)return i.projectId}}}catch{}return $.generateProjectId(e)}async findAuthor(e,t){let s=await this.readGlobalConfig(e);return!s||!s.authors?null:s.authors.find(r=>r.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=R();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 r=s.authors.find(o=>o.github===t);r&&(r.lastActivity=R(),s.lastSync=r.lastActivity,await this.writeGlobalConfig(e,s))}async getCurrentAuthor(e){let t=await cn(),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=$.generateProjectId(e);return{projectId:s,dataPath:$.getDisplayPath($.getGlobalProjectPath(s))}}},fh=new Xi,I=fh});var Su={};W(Su,{default:()=>dr});import Ki from"node:fs/promises";import hh from"node:os";import vu from"node:path";var Yi,yh,dr,ro=h(()=>{"use strict";V();J();Yi=class{static{l(this,"EditorsConfig")}homeDir;configDir;configFile;constructor(){this.homeDir=hh.homedir(),this.configDir=vu.join(this.homeDir,".prjct-cli","config"),this.configFile=vu.join(this.configDir,"installed-editors.json")}async ensureConfigDir(){try{await Ki.mkdir(this.configDir,{recursive:!0})}catch(e){console.error("[editors-config] Error creating config directory:",k(e))}}async loadConfig(){try{let e=await Ki.readFile(this.configFile,"utf-8");return JSON.parse(e)}catch(e){return e.code==="ENOENT"||console.error("[editors-config] Error loading config:",k(e)),null}}async saveConfig(e,t,s="claude"){try{await this.ensureConfigDir();let r={version:e,provider:s,lastInstall:new Date().toISOString(),path:t};return await ie(this.configFile,r),!0}catch(r){return console.error("[editors-config] Error saving config:",k(r)),!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 ie(this.configFile,t),!0):!1}catch(t){return console.error("[editors-config] Error updating version:",k(t)),!1}}async configExists(){return b(this.configFile)}async deleteConfig(){try{return await this.configExists()&&await Ki.unlink(this.configFile),!0}catch(e){return console.error("[editors-config] Error deleting config:",k(e)),!1}}},yh=new Yi,dr=yh});var Tu={};W(Tu,{PrjctDatabase:()=>oo,default:()=>L,prjctDb:()=>C});import Qi from"node:fs";import bu from"node:path";function wh(n){if(Rs()){let{Database:r}=Je("bun:sqlite");return new r(n,{create:!0})}let e=Je("better-sqlite3"),t=new e(n),s=t.exec.bind(t);return t.run=r=>s(r),t}var kh,vh,oo,C,L,ce=h(()=>{"use strict";Re();tr();l(wh,"openDatabase");kh=[{version:1,name:"initial-schema",up:l(n=>{n.run(`
15
+ `),a="",c="",u="",d=!1;for(let m of i)m.startsWith("worktree ")?a=m.replace("worktree ","").trim():m.startsWith("HEAD ")?c=m.replace("HEAD ","").trim():m.startsWith("branch ")?u=m.replace("branch refs/heads/","").trim():m==="bare"?d=!0:m==="detached"&&(u="(detached)");if(a){let m=a===t||d;s.push({path:a,branch:u,commit:c,isMain:m,slug:m?"main":Ft.basename(a)})}}return s}},hu=new Xi,gh=hu});var ur={};W(ur,{default:()=>I});import Ki from"node:fs/promises";import fh from"node:path";import*as ro from"jsonc-parser";function ku(n){let e=[],t=ro.parse(n,e,{allowTrailingComma:!0,disallowComments:!1});if(e.length>0){let s=e[0];throw new SyntaxError(`JSON parse error at offset ${s.offset}: ${ro.printParseErrorCode(s.error)}`)}return t}var Yi,hh,I,de=h(()=>{"use strict";ds();V();be();J();ze();no();Re();l(ku,"parseJsonc");Yi=class{static{l(this,"ConfigManager")}async readConfig(e){try{let t=$.getLocalConfigPath(e),s=await Ki.readFile(t,"utf-8");return ku(s)}catch(t){return _(t)||console.warn(`Warning: Could not read config at ${e}: ${ge(t)}`),null}}async writeConfig(e,t){let s=$.getLocalConfigPath(e);await ie(s,t)}async readGlobalConfig(e){try{let t=$.getGlobalProjectConfigPath(e),s=await Ki.readFile(t,"utf-8");return ku(s)}catch(t){return _(t)||console.warn(`Warning: Could not read global config for ${e}: ${ge(t)}`),null}}async writeGlobalConfig(e,t){let s=$.getGlobalProjectConfigPath(e);await ie(s,t)}async ensureGlobalConfig(e){let t=await this.readGlobalConfig(e);if(!t){let s=R();t={projectId:e,authors:[],version:ae,lastSync:s},await this.writeGlobalConfig(e,t)}return t}async createConfig(e,t){let s=$.generateProjectId(e),r=$.getGlobalProjectPath(s),o=$.getDisplayPath(r),i=R(),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=R(),await this.writeGlobalConfig(t,s))}validateConfig(e){return!(!e||!e.projectId||!e.dataPath)}async needsMigration(e){if(!await $.hasLegacyStructure(e))return!1;if(!await $.hasConfig(e))return!0;let r=await this.readConfig(e);if(!r||!r.projectId)return!0;let o=$.getGlobalProjectPath(r.projectId);try{return(await Ki.readdir(fh.join(o,"core"))).length===0}catch(i){return _(i),!0}}async getProjectId(e){let t=await this.readConfig(e);if(t?.projectId)return t.projectId;try{let{worktreeService:s}=await Promise.resolve().then(()=>(wu(),yu));if(await s.detect(e)){let o=await s.getMainWorktree(e);if(o!==e){let i=await this.readConfig(o);if(i?.projectId)return i.projectId}}}catch{}return $.generateProjectId(e)}async findAuthor(e,t){let s=await this.readGlobalConfig(e);return!s||!s.authors?null:s.authors.find(r=>r.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=R();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 r=s.authors.find(o=>o.github===t);r&&(r.lastActivity=R(),s.lastSync=r.lastActivity,await this.writeGlobalConfig(e,s))}async getCurrentAuthor(e){let t=await cn(),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=$.generateProjectId(e);return{projectId:s,dataPath:$.getDisplayPath($.getGlobalProjectPath(s))}}},hh=new Yi,I=hh});var Su={};W(Su,{default:()=>dr});import Qi from"node:fs/promises";import yh from"node:os";import vu from"node:path";var Zi,wh,dr,oo=h(()=>{"use strict";V();J();Zi=class{static{l(this,"EditorsConfig")}homeDir;configDir;configFile;constructor(){this.homeDir=yh.homedir(),this.configDir=vu.join(this.homeDir,".prjct-cli","config"),this.configFile=vu.join(this.configDir,"installed-editors.json")}async ensureConfigDir(){try{await Qi.mkdir(this.configDir,{recursive:!0})}catch(e){console.error("[editors-config] Error creating config directory:",k(e))}}async loadConfig(){try{let e=await Qi.readFile(this.configFile,"utf-8");return JSON.parse(e)}catch(e){return e.code==="ENOENT"||console.error("[editors-config] Error loading config:",k(e)),null}}async saveConfig(e,t,s="claude"){try{await this.ensureConfigDir();let r={version:e,provider:s,lastInstall:new Date().toISOString(),path:t};return await ie(this.configFile,r),!0}catch(r){return console.error("[editors-config] Error saving config:",k(r)),!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 ie(this.configFile,t),!0):!1}catch(t){return console.error("[editors-config] Error updating version:",k(t)),!1}}async configExists(){return b(this.configFile)}async deleteConfig(){try{return await this.configExists()&&await Qi.unlink(this.configFile),!0}catch(e){return console.error("[editors-config] Error deleting config:",k(e)),!1}}},wh=new Zi,dr=wh});var Tu={};W(Tu,{PrjctDatabase:()=>io,default:()=>L,prjctDb:()=>C});import ea from"node:fs";import bu from"node:path";function kh(n){if(Rs()){let{Database:r}=Je("bun:sqlite");return new r(n,{create:!0})}let e=Je("better-sqlite3"),t=new e(n),s=t.exec.bind(t);return t.run=r=>s(r),t}var vh,Sh,io,C,L,ce=h(()=>{"use strict";Re();tr();l(kh,"openDatabase");vh=[{version:1,name:"initial-schema",up:l(n=>{n.run(`
16
16
  -- =======================================================================
17
17
  -- Document storage (backward-compatible with JSON file pattern)
18
18
  -- =======================================================================
@@ -483,55 +483,55 @@ var Nf=Object.create;var er=Object.defineProperty;var Of=Object.getOwnPropertyDe
483
483
  );
484
484
 
485
485
  CREATE INDEX IF NOT EXISTS idx_wrc_rule ON workflow_rule_cache(rule_id);
486
- `)},"up")},{version:14,name:"workflow-rules-trust-source",up:l(n=>{try{n.run("ALTER TABLE workflow_rules ADD COLUMN trust_source TEXT NOT NULL DEFAULT 'local'")}catch{}},"up")},{version:15,name:"disable-orphan-workflow-rules",up:l(n=>{let t=["pause","resume","reopen","next","dash","bug","idea","linear","jira","tokens","velocity","plan"].map(s=>`'${s}'`).join(",");n.run(`UPDATE workflow_rules SET enabled = 0 WHERE command IN (${t}) AND enabled = 1`)},"up")}],vh=3,oo=class{static{l(this,"PrjctDatabase")}connections=new Map;accessOrder=[];getDbPath(e){return bu.join($.getGlobalProjectPath(e),"prjct.db")}getDb(e){let t=this.connections.get(e);if(t)return this.touchAccessOrder(e),t;this.connections.size>=vh&&this.evictLru();let s=this.getDbPath(e),r=bu.dirname(s);Qi.existsSync(r)||Qi.mkdirSync(r,{recursive:!0});let o=wh(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 Qi.existsSync(this.getDbPath(e))}getDoc(e,t){let r=this.getDb(e).prepare("SELECT data FROM kv_store WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setDoc(e,t,s){let r=this.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();r.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,r){let o=this.getDb(e),i=new Date().toISOString();o.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)").run(t,r??null,JSON.stringify(s),i)}getEvents(e,t,s=100){let r=this.getDb(e);return t?r.prepare("SELECT * FROM events WHERE type = ? ORDER BY id DESC LIMIT ?").all(t,s):r.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(`
486
+ `)},"up")},{version:14,name:"workflow-rules-trust-source",up:l(n=>{try{n.run("ALTER TABLE workflow_rules ADD COLUMN trust_source TEXT NOT NULL DEFAULT 'local'")}catch{}},"up")},{version:15,name:"disable-orphan-workflow-rules",up:l(n=>{let t=["pause","resume","reopen","next","dash","bug","idea","linear","jira","tokens","velocity","plan"].map(s=>`'${s}'`).join(",");n.run(`UPDATE workflow_rules SET enabled = 0 WHERE command IN (${t}) AND enabled = 1`)},"up")}],Sh=3,io=class{static{l(this,"PrjctDatabase")}connections=new Map;accessOrder=[];getDbPath(e){return bu.join($.getGlobalProjectPath(e),"prjct.db")}getDb(e){let t=this.connections.get(e);if(t)return this.touchAccessOrder(e),t;this.connections.size>=Sh&&this.evictLru();let s=this.getDbPath(e),r=bu.dirname(s);ea.existsSync(r)||ea.mkdirSync(r,{recursive:!0});let o=kh(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 ea.existsSync(this.getDbPath(e))}getDoc(e,t){let r=this.getDb(e).prepare("SELECT data FROM kv_store WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setDoc(e,t,s){let r=this.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();r.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,r){let o=this.getDb(e),i=new Date().toISOString();o.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)").run(t,r??null,JSON.stringify(s),i)}getEvents(e,t,s=100){let r=this.getDb(e);return t?r.prepare("SELECT * FROM events WHERE type = ? ORDER BY id DESC LIMIT ?").all(t,s):r.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(`
487
487
  CREATE TABLE IF NOT EXISTS _migrations (
488
488
  version INTEGER PRIMARY KEY,
489
489
  name TEXT NOT NULL,
490
490
  applied_at TEXT NOT NULL
491
491
  )
492
- `);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(s=>s.version));for(let s of kh)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 oo,L=C});import{z as U}from"zod";var Sh,bh,Eu,Th,Eh,Ch,Ph,jh,Cu,Pu=h(()=>{"use strict";Sh=U.enum(["low","medium","high"]),bh=U.enum(["pending","converted","completed","archived","dormant"]),Eu=U.enum(["high","medium","low"]),Th=U.object({impact:Eu,effort:Eu}),Eh=U.object({frontend:U.string().optional(),backend:U.string().optional(),payments:U.string().optional(),ai:U.string().optional(),deploy:U.string().optional(),other:U.array(U.string()).optional()}),Ch=U.object({name:U.string(),description:U.string()}),Ph=U.object({name:U.string(),description:U.string().optional()}),jh=U.object({id:U.string(),text:U.string(),details:U.string().optional(),priority:Sh,status:bh,tags:U.array(U.string()),addedAt:U.string(),completedAt:U.string().optional(),convertedTo:U.string().optional(),source:U.string().optional(),sourceFiles:U.array(U.string()).optional(),painPoints:U.array(U.string()).optional(),solutions:U.array(U.string()).optional(),filesAffected:U.array(U.string()).optional(),impactEffort:Th.optional(),implementationNotes:U.string().optional(),stack:Eh.optional(),modules:U.array(Ch).optional(),roles:U.array(Ph).optional(),risks:U.array(U.string()).optional(),risksCount:U.number().optional()}),Cu=U.object({ideas:U.array(jh),lastUpdated:U.string()})});import Rh from"node:crypto";function et(){return Rh.randomUUID()}var $s=h(()=>{"use strict";l(et,"generateUUID")});var Zt,Zi,tt,ms=h(()=>{"use strict";$s();be();ce();Zt={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},Zi=class{static{l(this,"ArchiveStorage")}archive(e,t){let s=et(),r=R();return C.run(e,"INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)",s,t.entityType,t.entityId,JSON.stringify(t.entityData),t.summary??null,r,t.reason),s}archiveMany(e,t){if(t.length===0)return 0;let s=R();return C.transaction(e,r=>{let o=r.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(et(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,s,i.reason)}),t.length}getArchived(e,t,s=50){return t?C.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,s):C.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",s)}getStats(e){let t=C.query(e,"SELECT entity_type, COUNT(*) as count FROM archives GROUP BY entity_type"),s={shipped:0,idea:0,queue_task:0,paused_task:0,memory_entry:0,total:0};for(let r of t){let o=r.entity_type;o in s&&(s[o]=r.count),s.total+=r.count}return s}restore(e,t){let s=C.get(e,"SELECT * FROM archives WHERE id = ?",t);return s?(C.run(e,"DELETE FROM archives WHERE id = ?",t),JSON.parse(s.entity_data)):null}pruneOldArchives(e,t){let s=new Date(Date.now()-t*24*60*60*1e3).toISOString(),r=this.getTotalCount(e);C.run(e,"DELETE FROM archives WHERE archived_at < ?",s);let o=this.getTotalCount(e);return r-o}getTotalCount(e){return C.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},tt=new Zi});var ea,gs,ta=h(()=>{"use strict";Re();be();J();ea=class{static{l(this,"SyncEventBus")}async publish(e){let t=$.getSyncPendingPath(e.projectId),s=await Se(t,[])??[],r=Array.isArray(s)?s:[];r.push(e),await ie(t,r)}async getPending(e){let t=$.getSyncPendingPath(e),s=await Se(t,[])??[];return Array.isArray(s)?s:[]}async clearPending(e){let t=$.getSyncPendingPath(e);await ie(t,[])}async updateLastSync(e){let t=$.getLastSyncPath(e),s={timestamp:R(),success:!0};await ie(t,s)}async getLastSync(e){let t=$.getLastSyncPath(e);return await Se(t,null)}},gs=new ea});var Xe,fs=h(()=>{"use strict";ta();or();be();ce();Xe=class{static{l(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new zr({ttl:5e3,maxSize:50})}getStoreKey(){return this.filename.replace(".json","")}async read(e){let t=this.cache.get(e);if(t!==null)return t;try{let s=C.getDoc(e,this.getStoreKey());if(s!==null)return this.cache.set(e,s),s}catch{}return this.getDefault()}async write(e,t){C.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let s=await this.read(e),r=t(s);return await this.write(e,r),r}async publishEvent(e,t,s){let r={type:t,path:[this.filename.replace(".json","")],data:s,timestamp:R(),projectId:e};await gs.publish(r)}async publishEntityEvent(e,t,s,r){let o=`${t}.${s}`,i={...r,timestamp:R()};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 sa,Le,pr=h(()=>{"use strict";Pu();$s();be();ms();fs();sa=class extends Xe{static{l(this,"IdeasStorage")}constructor(){super("ideas.json",Cu)}getDefault(){return{ideas:[],lastUpdated:""}}getEventType(e){return`ideas.${e}d`}async getAll(e){return(await this.read(e)).ideas}async getPending(e){return(await this.read(e)).ideas.filter(s=>s.status==="pending")}async addIdea(e,t,s={}){let r={id:et(),text:t,status:"pending",priority:s.priority||"medium",tags:s.tags||[],addedAt:R()};return await this.update(e,o=>({ideas:[r,...o.ideas],lastUpdated:R()})),await this.publishEvent(e,"idea.created",{ideaId:r.id,text:r.text,priority:r.priority}),r}async getById(e,t){return(await this.read(e)).ideas.find(r=>r.id===t)}async convertToFeature(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:s}:o),lastUpdated:R()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:s})}async archive(e,t){await this.update(e,s=>({ideas:s.ideas.map(r=>r.id===t?{...r,status:"archived"}:r),lastUpdated:R()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:R()}))}async addTags(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...s])]}:o),lastUpdated:R()}))}async removeIdea(e,t){await this.update(e,s=>({ideas:s.ideas.filter(r=>r.id!==t),lastUpdated:R()}))}async getCounts(e){let t=await this.read(e);return{pending:t.ideas.filter(s=>s.status==="pending").length,converted:t.ideas.filter(s=>s.status==="converted").length,archived:t.ideas.filter(s=>s.status==="archived").length}}async cleanup(e){let s=(await this.read(e)).ideas.filter(a=>a.status==="archived");if(s.length<=50)return{removed:0};let r=s.sort((a,c)=>new Date(c.addedAt).getTime()-new Date(a.addedAt).getTime()),o=new Set(r.slice(50).map(a=>a.id)),i=o.size;return await this.update(e,a=>({ideas:a.ideas.filter(c=>!o.has(c.id)),lastUpdated:R()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),s=rn(Zt.IDEA_DORMANT_DAYS),r=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<s);if(r.length===0)return 0;tt.archiveMany(e,r.map(i=>({entityType:"idea",entityId:i.id,entityData:i,summary:i.text,reason:"dormant"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({ideas:i.ideas.map(a=>o.has(a.id)?{...a,status:"dormant"}:a),lastUpdated:R()})),await this.publishEvent(e,"ideas.dormant",{count:r.length}),r.length}},Le=new sa});import{z as E}from"zod";var xh,io,Ah,Ih,na,Ru,xu,Au,Iu,ju,$h,Dh,Mh,$u,_h,Du,ra=h(()=>{"use strict";Br();xh=E.enum(["low","medium","high","critical"]),io=E.enum(["feature","bug","improvement","chore"]),Ah=E.enum(["active","backlog","previously_active"]),Ih=E.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),na=E.object({title:E.string(),description:E.string(),filesChanged:E.array(E.object({path:E.string(),action:E.enum(["created","modified","deleted"])})),whatWasDone:E.array(E.string()).min(1),outputForNextAgent:E.string().min(1),notes:E.string().optional()}),Ru=E.object({output:E.string().min(1,"Subtask output is required"),summary:na}),xu=E.object({id:E.string(),description:E.string(),domain:E.string(),agent:E.string(),status:Ih,dependsOn:E.array(E.string()),startedAt:E.string().optional(),completedAt:E.string().optional(),output:E.string().optional(),summary:na.optional(),skipReason:E.string().optional(),blockReason:E.string().optional(),estimatedPoints:E.number().optional(),estimatedMinutes:E.number().optional()}),Au=E.object({completed:E.number(),total:E.number(),percentage:E.number()}),Iu=E.object({id:E.string(),description:E.string(),type:io.optional(),startedAt:E.string(),sessionId:E.string(),featureId:E.string().optional(),subtasks:E.array(xu).optional(),currentSubtaskIndex:E.number().optional(),subtaskProgress:Au.optional(),linearId:E.string().optional(),linearUuid:E.string().optional(),estimatedPoints:E.number().optional(),estimatedMinutes:E.number().optional(),modelMetadata:rr.optional(),tokensIn:E.number().optional(),tokensOut:E.number().optional(),parentDescription:E.string().optional(),branch:E.string().optional(),prUrl:E.string().optional()}),ju=E.object({id:E.string(),description:E.string(),status:E.literal("paused"),startedAt:E.string(),pausedAt:E.string(),pauseReason:E.string().optional(),type:io.optional(),sessionId:E.string().optional(),featureId:E.string().optional(),subtasks:E.array(xu).optional(),currentSubtaskIndex:E.number().optional(),subtaskProgress:Au.optional(),linearId:E.string().optional(),linearUuid:E.string().optional(),estimatedPoints:E.number().optional(),estimatedMinutes:E.number().optional(),modelMetadata:rr.optional(),tokensIn:E.number().optional(),tokensOut:E.number().optional()}),$h=E.object({stackConfirmed:E.array(E.string()).optional(),patternsDiscovered:E.array(E.string()).optional(),agentAccuracy:E.array(E.object({agent:E.string(),rating:E.enum(["helpful","neutral","inaccurate"]),note:E.string().optional()})).optional(),issuesEncountered:E.array(E.string()).optional()}),Dh=E.object({taskId:E.string(),title:E.string(),classification:io,startedAt:E.string(),completedAt:E.string(),subtaskCount:E.number(),subtaskSummaries:E.array(na),outcome:E.string(),branchName:E.string(),linearId:E.string().optional(),linearUuid:E.string().optional(),prUrl:E.string().optional(),feedback:$h.optional(),tokensIn:E.number().optional(),tokensOut:E.number().optional()}),Mh=Iu.extend({workspaceId:E.string(),worktreePath:E.string().optional(),agentSessionId:E.string().optional(),jiraId:E.string().optional(),jiraUuid:E.string().optional(),dispatchedFrom:E.string().optional()}),$u=E.object({currentTask:Iu.nullable(),previousTask:ju.nullable().optional(),pausedTasks:E.array(ju).optional(),taskHistory:E.array(Dh).optional(),activeTasks:E.array(Mh).optional(),lastUpdated:E.string()}),_h=E.object({id:E.string(),description:E.string(),body:E.string().optional(),priority:xh,type:io,featureId:E.string().optional(),originFeature:E.string().optional(),completed:E.boolean(),completedAt:E.string().optional(),createdAt:E.string(),section:Ah,agent:E.string().optional(),groupName:E.string().optional(),groupId:E.string().optional()}),Du=E.object({tasks:E.array(_h),lastUpdated:E.string()})});function Nu(n){return[...n].sort((e,t)=>{let s=_u[e.section]-_u[t.section];return s!==0?s:Mu[e.priority]-Mu[t.priority]})}function oa(n,e){let t=new Set;return n.filter(s=>{let r=e(s);return t.has(r)?!1:(t.add(r),!0)})}var Mu,_u,ia=h(()=>{"use strict";Mu={critical:0,high:1,medium:2,low:3},_u={active:0,previously_active:1,backlog:2};l(Nu,"sortBySectionAndPriority");l(oa,"uniqueBy")});var aa,Fe,mr=h(()=>{"use strict";$s();ra();ia();be();ms();fs();aa=class extends Xe{static{l(this,"QueueStorage")}constructor(){super("queue.json",Du)}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 Nu(t)[0]||null}async addTask(e,t){let s={...t,id:et(),createdAt:R(),completed:!1};return await this.update(e,r=>({tasks:[...r.tasks,s],lastUpdated:R()})),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=R(),r=t.map(o=>({...o,id:et(),createdAt:s,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...r],lastUpdated:s})),await this.publishEvent(e,"queue.tasks_added",{count:r.length,tasks:r.map(o=>({id:o.id,description:o.description}))}),r}async removeTask(e,t){await this.update(e,s=>({tasks:s.tasks.filter(r=>r.id!==t),lastUpdated:R()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let s=null;if(await this.update(e,r=>({tasks:r.tasks.map(i=>i.id===t?(s={...i,completed:!0,completedAt:R()},s):i),lastUpdated:R()})),s){let r=s;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:r.description,completedAt:r.completedAt})}return s}async moveToSection(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,section:s}:o),lastUpdated:R()}))}async setPriority(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:R()}))}async getTask(e,t){return(await this.read(e)).tasks.find(r=>r.id===t)||null}async updateTask(e,t,s){let r=null;return await this.update(e,o=>({tasks:o.tasks.map(i=>i.id===t?(r={...i,...s},r):i),lastUpdated:R()})),r&&await this.publishEvent(e,"queue.task_updated",{taskId:t}),r}async clearCompleted(e){let s=(await this.read(e)).tasks.filter(r=>r.completed).length;return await this.update(e,r=>({tasks:r.tasks.filter(o=>!o.completed),lastUpdated:R()})),s}async removeStaleCompleted(e){let t=await this.read(e),s=rn(Zt.QUEUE_COMPLETED_DAYS),r=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<s);if(r.length===0)return 0;tt.archiveMany(e,r.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:R()})),await this.publishEvent(e,"queue.stale_removed",{count:r.length}),r.length}},Fe=new aa});import{z as K}from"zod";var Nh,Ou,Oh,Lh,Fh,Uh,Hh,Wh,Gh,Lu,Fu=h(()=>{"use strict";Nh=K.enum(["feature","fix","improvement","refactor"]),Ou=K.enum(["pass","warning","fail","skipped"]),Oh=K.enum(["added","changed","fixed","removed"]),Lh=K.object({hours:K.number(),minutes:K.number(),totalMinutes:K.number()}),Fh=K.object({filesChanged:K.number().nullable().optional(),linesAdded:K.number().nullable().optional(),linesRemoved:K.number().nullable().optional(),commits:K.number().nullable().optional()}),Uh=K.object({description:K.string(),type:Oh.optional()}),Hh=K.object({lintStatus:Ou.nullable().optional(),lintDetails:K.string().optional(),testStatus:Ou.nullable().optional(),testDetails:K.string().optional()}),Wh=K.object({hash:K.string().optional(),message:K.string().optional(),branch:K.string().optional()}),Gh=K.object({id:K.string(),name:K.string(),version:K.string().nullable().optional(),type:Nh,agent:K.string().optional(),description:K.string().optional(),changes:K.array(Uh).optional(),codeSnippets:K.array(K.string()).optional(),commit:Wh.optional(),codeMetrics:Fh.optional(),qualityMetrics:Hh.optional(),quantitativeImpact:K.string().optional(),duration:Lh.optional(),tasksCompleted:K.number().nullable().optional(),shippedAt:K.string(),featureId:K.string().optional()}),Lu=K.object({shipped:K.array(Gh),lastUpdated:K.string()})});var ca,Ke,Uu,Ds=h(()=>{"use strict";$s();Fu();be();ms();fs();ca=class extends Xe{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",Lu)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(e){return`shipped.${e}d`}async getAll(e){return(await this.read(e)).shipped}async getRecent(e,t=5){return(await this.read(e)).shipped.sort((r,o)=>new Date(o.shippedAt).getTime()-new Date(r.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let s={...t,id:et(),shippedAt:R()};return await this.update(e,r=>({shipped:[s,...Array.isArray(r.shipped)?r.shipped:[]],lastUpdated:R()})),await this.publishEvent(e,"feature.shipped",{shipId:s.id,name:s.name,version:s.version,shippedAt:s.shippedAt}),s}async getByVersion(e,t){return(await this.read(e)).shipped.find(r=>r.version===t)}async getCount(e){return(await this.read(e)).shipped.length}async getByDateRange(e,t,s){return(await this.read(e)).shipped.filter(o=>{let i=new Date(o.shippedAt);return i>=t&&i<=s})}async getStats(e,t="month"){let s=new Date,r;switch(t){case"week":r=new Date(s.getTime()-7*24*60*60*1e3);break;case"month":r=new Date(s.getFullYear(),s.getMonth(),1);break;case"year":r=new Date(s.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,r,s)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),s=rn(Zt.SHIPPED_RETENTION_DAYS),r=t.shipped.filter(i=>new Date(i.shippedAt)<s);if(r.length===0)return 0;tt.archiveMany(e,r.map(i=>({entityType:"shipped",entityId:i.id,entityData:i,summary:`${i.name} v${i.version}`,reason:"age"})));let o=new Set(t.shipped.filter(i=>new Date(i.shippedAt)>=s).map(i=>i.id));return await this.update(e,i=>({shipped:i.shipped.filter(a=>o.has(a.id)),lastUpdated:R()})),await this.publishEvent(e,"shipped.archived",{count:r.length,oldestShippedAt:r[r.length-1]?.shippedAt}),r.length}},Ke=new ca,Uu=Ke});var gr,la,Ms,ua=h(()=>{"use strict";gr={idle:{transitions:["task"],prompt:"prjct task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"prjct status done Complete task | prjct status paused Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"prjct status active Continue | prjct task <new> Start different | prjct ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","pause","reopen"],prompt:"prjct ship Ship it | prjct task <next> Start next | prjct status active Reopen",description:"Task completed"},shipped:{transitions:["task"],prompt:"prjct task <description> Start new task",description:"Feature shipped"}},la=class{static{l(this,"WorkflowStateMachine")}getCurrentState(e,t){let s=null;if(t&&e?.activeTasks?.length&&(s=e.activeTasks.find(o=>o.workspaceId===t)),s||(s=e?.currentTask),!s)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof s.status=="string"?s.status:"").toLowerCase()){case"in_progress":case"working":return"working";case"paused":return"paused";case"completed":case"done":return"completed";case"shipped":return"shipped";default:return s?"working":"idle"}}canTransition(e,t){if(gr[e].transitions.includes(t))return{valid:!0};let r=this.formatNextSteps(e).join(" | ");return{valid:!1,error:`Cannot transition to '${t}' from '${e}' state`,suggestion:`Valid next steps: ${r}`}}getNextState(e,t){switch(t){case"task":return"working";case"done":return"completed";case"pause":return"paused";case"resume":return"working";case"ship":return"shipped";case"reopen":return"working";default:return e}}getStateInfo(e){return gr[e]}getPrompt(e){return gr[e].prompt}getValidCommands(e){return gr[e].transitions}formatNextSteps(e){return gr[e].transitions.map(s=>{switch(s){case"task":return"prjct task <desc> Start new task";case"done":return"prjct status done Complete current task";case"pause":return"prjct status paused Pause and switch context";case"resume":return"prjct status active Continue paused task";case"ship":return"prjct ship Ship the feature";case"reopen":return"prjct status active Reopen completed task";default:return`prjct ${s}`}})}},Ms=new la});var da,D,rt=h(()=>{"use strict";$s();ra();be();ua();ms();fs();da=class extends Xe{static{l(this,"StateStorage")}constructor(){super("state.json",$u)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],activeTasks:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let s=Ms.getCurrentState(e),r=Ms.canTransition(s,t);if(!r.valid)throw new Error(`${r.error}. ${r.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async getPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async startTask(e,t){let s=await this.read(e);this.validateTransition(s,"task");let r={...t,startedAt:R()};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:R()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId}),r}async updateCurrentTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;let r={...s.currentTask,...t};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:R()})),r}async completeTask(e,t){let s=await this.read(e),r=s.currentTask;if(!r)return null;this.validateTransition(s,"done");let o=R(),i=this.createTaskHistoryEntry(r,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:r.id,description:r.description,startedAt:r.startedAt,completedAt:o}),r}createTaskHistoryEntry(e,t,s){let r=(e.subtasks||[]).filter(a=>a.status==="completed"&&a.summary).map(a=>a.summary),o=r.length>0?r.map(a=>a.title).join(", "):"Task completed",i={taskId:e.id,title:e.parentDescription||e.description,classification:e.type||"improvement",startedAt:e.startedAt,completedAt:t,subtaskCount:e.subtasks?.length||0,subtaskSummaries:r,outcome:o,branchName:e.branch||"unknown",linearId:e.linearId,linearUuid:e.linearUuid,prUrl:e.prUrl};return s&&(i.feedback=s),e.tokensIn&&(i.tokensIn=e.tokensIn),e.tokensOut&&(i.tokensOut=e.tokensOut),i}maxPausedTasks=5;maxTaskHistory=20;stalenessThresholdDays=30;async pauseTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;this.validateTransition(s,"pause");let r={...s.currentTask,status:"paused",pausedAt:R(),pauseReason:t},o=this.getPausedTasksFromState(s),i=[r,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:R()})),await this.publishEvent(e,"task.paused",{taskId:r.id,description:r.description,pausedAt:r.pausedAt,reason:t,pausedCount:i.length}),r}async resumeTask(e,t){let s=await this.read(e),r=this.getPausedTasksFromState(s);if(r.length===0)return null;this.validateTransition(s,"resume");let o=0;if(t&&(o=r.findIndex(g=>g.id===t),o===-1))return null;let i=r[o],a=r.filter((g,y)=>y!==o),{status:c,pausedAt:u,pauseReason:d,...m}=i,p={...m,startedAt:R(),sessionId:i.sessionId??et()};return await this.update(e,g=>({...g,currentTask:p,previousTask:null,pausedTasks:a,lastUpdated:R()})),await this.publishEvent(e,"task.resumed",{taskId:p.id,description:p.description,resumedAt:p.startedAt,remainingPaused:a.length}),p}getPausedTasksFromState(e){return Array.isArray(e.pausedTasks)&&e.pausedTasks.length>0?e.pausedTasks:e.previousTask?[e.previousTask]:[]}getTaskHistoryFromState(e){return e.taskHistory||[]}async getStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return s.filter(o=>new Date(o.pausedAt).getTime()<r)}async archiveStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=s.filter(a=>new Date(a.pausedAt).getTime()<r),i=s.filter(a=>new Date(a.pausedAt).getTime()>=r);if(o.length===0)return[];tt.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:R()}));for(let a of o)await this.publishEvent(e,"task.archived",{taskId:a.id,description:a.description,pausedAt:a.pausedAt,reason:"staleness"});return o}async clearTask(e){await this.update(e,()=>({currentTask:null,previousTask:null,pausedTasks:[],activeTasks:[],lastUpdated:R()}))}async hasTask(e){let t=await this.read(e),s=this.getPausedTasksFromState(t);return t.currentTask!==null||s.length>0}async getPausedTask(e){let t=await this.read(e);return this.getPausedTasksFromState(t)[0]||null}async getAllPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async getTaskHistory(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)}async getMostRecentTask(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)[0]||null}async getTaskHistoryByType(e,t){let s=await this.read(e);return this.getTaskHistoryFromState(s).filter(o=>o.classification===t)}async getAggregatedFeedback(e){let s=(await this.getTaskHistory(e)).filter(p=>p.feedback),r=[],o=[],i=[],a=[];for(let p of s){let g=p.feedback;Array.isArray(g.stackConfirmed)&&r.push(...g.stackConfirmed),Array.isArray(g.patternsDiscovered)&&o.push(...g.patternsDiscovered),Array.isArray(g.agentAccuracy)&&i.push(...g.agentAccuracy),Array.isArray(g.issuesEncountered)&&a.push(...g.issuesEncountered)}let c=[...new Set(r)],u=[...new Set(o)],d=new Map;for(let p of a)d.set(p,(d.get(p)||0)+1);let m=[...d.entries()].filter(([p,g])=>g>=2).map(([p])=>p);return{stackConfirmed:c,patternsDiscovered:u,agentAccuracy:i,issuesEncountered:[...new Set(a)],knownGotchas:m}}async startTaskInWorkspace(e,t,s){let r={...t,workspaceId:s,startedAt:R()};return await this.update(e,o=>({...o,activeTasks:[...o.activeTasks||[],r],lastUpdated:R()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId,workspaceId:s}),r}async getCurrentTaskForWorkspace(e,t){return((await this.read(e)).activeTasks||[]).find(r=>r.workspaceId===t)??null}async completeTaskInWorkspace(e,t,s){let r=await this.read(e),i=(r.activeTasks||[]).find(m=>m.workspaceId===t);if(!i)return null;let a=R(),c=this.createTaskHistoryEntry(i,a,s),u=this.getTaskHistoryFromState(r),d=[c,...u].slice(0,this.maxTaskHistory);return await this.update(e,m=>({...m,activeTasks:(m.activeTasks||[]).filter(p=>p.workspaceId!==t),taskHistory:d,lastUpdated:a})),await this.publishEvent(e,"task.completed",{taskId:i.id,description:i.description,startedAt:i.startedAt,completedAt:a,workspaceId:t}),i}async getActiveTasks(e){return(await this.read(e)).activeTasks||[]}async getActiveTaskCount(e){return((await this.read(e)).activeTasks||[]).length}async updateWorkspaceTask(e,t,s){let o=(await this.read(e)).activeTasks||[],i=o.findIndex(c=>c.workspaceId===t);if(i===-1)return null;let a={...o[i],...s,workspaceId:t};return await this.update(e,c=>{let u=[...c.activeTasks||[]];return u[i]=a,{...c,activeTasks:u,lastUpdated:R()}}),a}async addTokens(e,t,s){let r=await this.read(e);if(!r.currentTask)return null;let o=(r.currentTask.tokensIn||0)+t,i=(r.currentTask.tokensOut||0)+s;return await this.update(e,a=>({...a,currentTask:{...a.currentTask,tokensIn:o,tokensOut:i},lastUpdated:R()})),{tokensIn:o,tokensOut:i}}async createSubtasks(e,t){let s=await this.read(e);if(!s.currentTask)return;let r=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?R():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:r,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:r.length,percentage:0}},lastUpdated:R()})),await this.publishEvent(e,"subtasks.created",{taskId:s.currentTask.id,subtaskCount:r.length,subtasks:r.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let s=Ru.safeParse(t);if(!s.success){let y=s.error.issues.map(j=>`${j.path.join(".")}: ${j.message}`);throw new Error(`Subtask completion requires handoff data:
492
+ `);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(s=>s.version));for(let s of vh)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 io,L=C});import{z as U}from"zod";var bh,Th,Eu,Eh,Ch,Ph,jh,Rh,Cu,Pu=h(()=>{"use strict";bh=U.enum(["low","medium","high"]),Th=U.enum(["pending","converted","completed","archived","dormant"]),Eu=U.enum(["high","medium","low"]),Eh=U.object({impact:Eu,effort:Eu}),Ch=U.object({frontend:U.string().optional(),backend:U.string().optional(),payments:U.string().optional(),ai:U.string().optional(),deploy:U.string().optional(),other:U.array(U.string()).optional()}),Ph=U.object({name:U.string(),description:U.string()}),jh=U.object({name:U.string(),description:U.string().optional()}),Rh=U.object({id:U.string(),text:U.string(),details:U.string().optional(),priority:bh,status:Th,tags:U.array(U.string()),addedAt:U.string(),completedAt:U.string().optional(),convertedTo:U.string().optional(),source:U.string().optional(),sourceFiles:U.array(U.string()).optional(),painPoints:U.array(U.string()).optional(),solutions:U.array(U.string()).optional(),filesAffected:U.array(U.string()).optional(),impactEffort:Eh.optional(),implementationNotes:U.string().optional(),stack:Ch.optional(),modules:U.array(Ph).optional(),roles:U.array(jh).optional(),risks:U.array(U.string()).optional(),risksCount:U.number().optional()}),Cu=U.object({ideas:U.array(Rh),lastUpdated:U.string()})});import xh from"node:crypto";function tt(){return xh.randomUUID()}var $s=h(()=>{"use strict";l(tt,"generateUUID")});var es,ta,st,ms=h(()=>{"use strict";$s();be();ce();es={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=tt(),r=R();return C.run(e,"INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)",s,t.entityType,t.entityId,JSON.stringify(t.entityData),t.summary??null,r,t.reason),s}archiveMany(e,t){if(t.length===0)return 0;let s=R();return C.transaction(e,r=>{let o=r.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(tt(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,s,i.reason)}),t.length}getArchived(e,t,s=50){return t?C.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,s):C.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",s)}getStats(e){let t=C.query(e,"SELECT entity_type, COUNT(*) as count FROM archives GROUP BY entity_type"),s={shipped:0,idea:0,queue_task:0,paused_task:0,memory_entry:0,total:0};for(let r of t){let o=r.entity_type;o in s&&(s[o]=r.count),s.total+=r.count}return s}restore(e,t){let s=C.get(e,"SELECT * FROM archives WHERE id = ?",t);return s?(C.run(e,"DELETE FROM archives WHERE id = ?",t),JSON.parse(s.entity_data)):null}pruneOldArchives(e,t){let s=new Date(Date.now()-t*24*60*60*1e3).toISOString(),r=this.getTotalCount(e);C.run(e,"DELETE FROM archives WHERE archived_at < ?",s);let o=this.getTotalCount(e);return r-o}getTotalCount(e){return C.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},st=new ta});var sa,gs,na=h(()=>{"use strict";Re();be();J();sa=class{static{l(this,"SyncEventBus")}async publish(e){let t=$.getSyncPendingPath(e.projectId),s=await Se(t,[])??[],r=Array.isArray(s)?s:[];r.push(e),await ie(t,r)}async getPending(e){let t=$.getSyncPendingPath(e),s=await Se(t,[])??[];return Array.isArray(s)?s:[]}async clearPending(e){let t=$.getSyncPendingPath(e);await ie(t,[])}async updateLastSync(e){let t=$.getLastSyncPath(e),s={timestamp:R(),success:!0};await ie(t,s)}async getLastSync(e){let t=$.getLastSyncPath(e);return await Se(t,null)}},gs=new sa});var Xe,fs=h(()=>{"use strict";na();or();be();ce();Xe=class{static{l(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new zr({ttl:5e3,maxSize:50})}getStoreKey(){return this.filename.replace(".json","")}async read(e){let t=this.cache.get(e);if(t!==null)return t;try{let s=C.getDoc(e,this.getStoreKey());if(s!==null)return this.cache.set(e,s),s}catch{}return this.getDefault()}async write(e,t){C.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let s=await this.read(e),r=t(s);return await this.write(e,r),r}async publishEvent(e,t,s){let r={type:t,path:[this.filename.replace(".json","")],data:s,timestamp:R(),projectId:e};await gs.publish(r)}async publishEntityEvent(e,t,s,r){let o=`${t}.${s}`,i={...r,timestamp:R()};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 ra,Le,pr=h(()=>{"use strict";Pu();$s();be();ms();fs();ra=class extends Xe{static{l(this,"IdeasStorage")}constructor(){super("ideas.json",Cu)}getDefault(){return{ideas:[],lastUpdated:""}}getEventType(e){return`ideas.${e}d`}async getAll(e){return(await this.read(e)).ideas}async getPending(e){return(await this.read(e)).ideas.filter(s=>s.status==="pending")}async addIdea(e,t,s={}){let r={id:tt(),text:t,status:"pending",priority:s.priority||"medium",tags:s.tags||[],addedAt:R()};return await this.update(e,o=>({ideas:[r,...o.ideas],lastUpdated:R()})),await this.publishEvent(e,"idea.created",{ideaId:r.id,text:r.text,priority:r.priority}),r}async getById(e,t){return(await this.read(e)).ideas.find(r=>r.id===t)}async convertToFeature(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:s}:o),lastUpdated:R()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:s})}async archive(e,t){await this.update(e,s=>({ideas:s.ideas.map(r=>r.id===t?{...r,status:"archived"}:r),lastUpdated:R()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:R()}))}async addTags(e,t,s){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...s])]}:o),lastUpdated:R()}))}async removeIdea(e,t){await this.update(e,s=>({ideas:s.ideas.filter(r=>r.id!==t),lastUpdated:R()}))}async getCounts(e){let t=await this.read(e);return{pending:t.ideas.filter(s=>s.status==="pending").length,converted:t.ideas.filter(s=>s.status==="converted").length,archived:t.ideas.filter(s=>s.status==="archived").length}}async cleanup(e){let s=(await this.read(e)).ideas.filter(a=>a.status==="archived");if(s.length<=50)return{removed:0};let r=s.sort((a,c)=>new Date(c.addedAt).getTime()-new Date(a.addedAt).getTime()),o=new Set(r.slice(50).map(a=>a.id)),i=o.size;return await this.update(e,a=>({ideas:a.ideas.filter(c=>!o.has(c.id)),lastUpdated:R()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),s=rn(es.IDEA_DORMANT_DAYS),r=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<s);if(r.length===0)return 0;st.archiveMany(e,r.map(i=>({entityType:"idea",entityId:i.id,entityData:i,summary:i.text,reason:"dormant"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({ideas:i.ideas.map(a=>o.has(a.id)?{...a,status:"dormant"}:a),lastUpdated:R()})),await this.publishEvent(e,"ideas.dormant",{count:r.length}),r.length}},Le=new ra});import{z as E}from"zod";var Ah,ao,Ih,$h,oa,Ru,xu,Au,Iu,ju,Dh,Mh,_h,$u,Nh,Du,ia=h(()=>{"use strict";Br();Ah=E.enum(["low","medium","high","critical"]),ao=E.enum(["feature","bug","improvement","chore"]),Ih=E.enum(["active","backlog","previously_active"]),$h=E.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),oa=E.object({title:E.string(),description:E.string(),filesChanged:E.array(E.object({path:E.string(),action:E.enum(["created","modified","deleted"])})),whatWasDone:E.array(E.string()).min(1),outputForNextAgent:E.string().min(1),notes:E.string().optional()}),Ru=E.object({output:E.string().min(1,"Subtask output is required"),summary:oa}),xu=E.object({id:E.string(),description:E.string(),domain:E.string(),agent:E.string(),status:$h,dependsOn:E.array(E.string()),startedAt:E.string().optional(),completedAt:E.string().optional(),output:E.string().optional(),summary:oa.optional(),skipReason:E.string().optional(),blockReason:E.string().optional(),estimatedPoints:E.number().optional(),estimatedMinutes:E.number().optional()}),Au=E.object({completed:E.number(),total:E.number(),percentage:E.number()}),Iu=E.object({id:E.string(),description:E.string(),type:ao.optional(),startedAt:E.string(),sessionId:E.string(),featureId:E.string().optional(),subtasks:E.array(xu).optional(),currentSubtaskIndex:E.number().optional(),subtaskProgress:Au.optional(),linearId:E.string().optional(),linearUuid:E.string().optional(),estimatedPoints:E.number().optional(),estimatedMinutes:E.number().optional(),modelMetadata:rr.optional(),tokensIn:E.number().optional(),tokensOut:E.number().optional(),parentDescription:E.string().optional(),branch:E.string().optional(),prUrl:E.string().optional()}),ju=E.object({id:E.string(),description:E.string(),status:E.literal("paused"),startedAt:E.string(),pausedAt:E.string(),pauseReason:E.string().optional(),type:ao.optional(),sessionId:E.string().optional(),featureId:E.string().optional(),subtasks:E.array(xu).optional(),currentSubtaskIndex:E.number().optional(),subtaskProgress:Au.optional(),linearId:E.string().optional(),linearUuid:E.string().optional(),estimatedPoints:E.number().optional(),estimatedMinutes:E.number().optional(),modelMetadata:rr.optional(),tokensIn:E.number().optional(),tokensOut:E.number().optional()}),Dh=E.object({stackConfirmed:E.array(E.string()).optional(),patternsDiscovered:E.array(E.string()).optional(),agentAccuracy:E.array(E.object({agent:E.string(),rating:E.enum(["helpful","neutral","inaccurate"]),note:E.string().optional()})).optional(),issuesEncountered:E.array(E.string()).optional()}),Mh=E.object({taskId:E.string(),title:E.string(),classification:ao,startedAt:E.string(),completedAt:E.string(),subtaskCount:E.number(),subtaskSummaries:E.array(oa),outcome:E.string(),branchName:E.string(),linearId:E.string().optional(),linearUuid:E.string().optional(),prUrl:E.string().optional(),feedback:Dh.optional(),tokensIn:E.number().optional(),tokensOut:E.number().optional()}),_h=Iu.extend({workspaceId:E.string(),worktreePath:E.string().optional(),agentSessionId:E.string().optional(),jiraId:E.string().optional(),jiraUuid:E.string().optional(),dispatchedFrom:E.string().optional()}),$u=E.object({currentTask:Iu.nullable(),previousTask:ju.nullable().optional(),pausedTasks:E.array(ju).optional(),taskHistory:E.array(Mh).optional(),activeTasks:E.array(_h).optional(),lastUpdated:E.string()}),Nh=E.object({id:E.string(),description:E.string(),body:E.string().optional(),priority:Ah,type:ao,featureId:E.string().optional(),originFeature:E.string().optional(),completed:E.boolean(),completedAt:E.string().optional(),createdAt:E.string(),section:Ih,agent:E.string().optional(),groupName:E.string().optional(),groupId:E.string().optional()}),Du=E.object({tasks:E.array(Nh),lastUpdated:E.string()})});function Nu(n){return[...n].sort((e,t)=>{let s=_u[e.section]-_u[t.section];return s!==0?s:Mu[e.priority]-Mu[t.priority]})}function aa(n,e){let t=new Set;return n.filter(s=>{let r=e(s);return t.has(r)?!1:(t.add(r),!0)})}var Mu,_u,ca=h(()=>{"use strict";Mu={critical:0,high:1,medium:2,low:3},_u={active:0,previously_active:1,backlog:2};l(Nu,"sortBySectionAndPriority");l(aa,"uniqueBy")});var la,Fe,mr=h(()=>{"use strict";$s();ia();ca();be();ms();fs();la=class extends Xe{static{l(this,"QueueStorage")}constructor(){super("queue.json",Du)}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 Nu(t)[0]||null}async addTask(e,t){let s={...t,id:tt(),createdAt:R(),completed:!1};return await this.update(e,r=>({tasks:[...r.tasks,s],lastUpdated:R()})),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=R(),r=t.map(o=>({...o,id:tt(),createdAt:s,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...r],lastUpdated:s})),await this.publishEvent(e,"queue.tasks_added",{count:r.length,tasks:r.map(o=>({id:o.id,description:o.description}))}),r}async removeTask(e,t){await this.update(e,s=>({tasks:s.tasks.filter(r=>r.id!==t),lastUpdated:R()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let s=null;if(await this.update(e,r=>({tasks:r.tasks.map(i=>i.id===t?(s={...i,completed:!0,completedAt:R()},s):i),lastUpdated:R()})),s){let r=s;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:r.description,completedAt:r.completedAt})}return s}async moveToSection(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,section:s}:o),lastUpdated:R()}))}async setPriority(e,t,s){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,priority:s}:o),lastUpdated:R()}))}async getTask(e,t){return(await this.read(e)).tasks.find(r=>r.id===t)||null}async updateTask(e,t,s){let r=null;return await this.update(e,o=>({tasks:o.tasks.map(i=>i.id===t?(r={...i,...s},r):i),lastUpdated:R()})),r&&await this.publishEvent(e,"queue.task_updated",{taskId:t}),r}async clearCompleted(e){let s=(await this.read(e)).tasks.filter(r=>r.completed).length;return await this.update(e,r=>({tasks:r.tasks.filter(o=>!o.completed),lastUpdated:R()})),s}async removeStaleCompleted(e){let t=await this.read(e),s=rn(es.QUEUE_COMPLETED_DAYS),r=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<s);if(r.length===0)return 0;st.archiveMany(e,r.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(r.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:R()})),await this.publishEvent(e,"queue.stale_removed",{count:r.length}),r.length}},Fe=new la});import{z as K}from"zod";var Oh,Ou,Lh,Fh,Uh,Hh,Wh,Gh,qh,Lu,Fu=h(()=>{"use strict";Oh=K.enum(["feature","fix","improvement","refactor"]),Ou=K.enum(["pass","warning","fail","skipped"]),Lh=K.enum(["added","changed","fixed","removed"]),Fh=K.object({hours:K.number(),minutes:K.number(),totalMinutes:K.number()}),Uh=K.object({filesChanged:K.number().nullable().optional(),linesAdded:K.number().nullable().optional(),linesRemoved:K.number().nullable().optional(),commits:K.number().nullable().optional()}),Hh=K.object({description:K.string(),type:Lh.optional()}),Wh=K.object({lintStatus:Ou.nullable().optional(),lintDetails:K.string().optional(),testStatus:Ou.nullable().optional(),testDetails:K.string().optional()}),Gh=K.object({hash:K.string().optional(),message:K.string().optional(),branch:K.string().optional()}),qh=K.object({id:K.string(),name:K.string(),version:K.string().nullable().optional(),type:Oh,agent:K.string().optional(),description:K.string().optional(),changes:K.array(Hh).optional(),codeSnippets:K.array(K.string()).optional(),commit:Gh.optional(),codeMetrics:Uh.optional(),qualityMetrics:Wh.optional(),quantitativeImpact:K.string().optional(),duration:Fh.optional(),tasksCompleted:K.number().nullable().optional(),shippedAt:K.string(),featureId:K.string().optional()}),Lu=K.object({shipped:K.array(qh),lastUpdated:K.string()})});var ua,Ke,Uu,Ds=h(()=>{"use strict";$s();Fu();be();ms();fs();ua=class extends Xe{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",Lu)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(e){return`shipped.${e}d`}async getAll(e){return(await this.read(e)).shipped}async getRecent(e,t=5){return(await this.read(e)).shipped.sort((r,o)=>new Date(o.shippedAt).getTime()-new Date(r.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let s={...t,id:tt(),shippedAt:R()};return await this.update(e,r=>({shipped:[s,...Array.isArray(r.shipped)?r.shipped:[]],lastUpdated:R()})),await this.publishEvent(e,"feature.shipped",{shipId:s.id,name:s.name,version:s.version,shippedAt:s.shippedAt}),s}async getByVersion(e,t){return(await this.read(e)).shipped.find(r=>r.version===t)}async getCount(e){return(await this.read(e)).shipped.length}async getByDateRange(e,t,s){return(await this.read(e)).shipped.filter(o=>{let i=new Date(o.shippedAt);return i>=t&&i<=s})}async getStats(e,t="month"){let s=new Date,r;switch(t){case"week":r=new Date(s.getTime()-7*24*60*60*1e3);break;case"month":r=new Date(s.getFullYear(),s.getMonth(),1);break;case"year":r=new Date(s.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,r,s)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),s=rn(es.SHIPPED_RETENTION_DAYS),r=t.shipped.filter(i=>new Date(i.shippedAt)<s);if(r.length===0)return 0;st.archiveMany(e,r.map(i=>({entityType:"shipped",entityId:i.id,entityData:i,summary:`${i.name} v${i.version}`,reason:"age"})));let o=new Set(t.shipped.filter(i=>new Date(i.shippedAt)>=s).map(i=>i.id));return await this.update(e,i=>({shipped:i.shipped.filter(a=>o.has(a.id)),lastUpdated:R()})),await this.publishEvent(e,"shipped.archived",{count:r.length,oldestShippedAt:r[r.length-1]?.shippedAt}),r.length}},Ke=new ua,Uu=Ke});var gr,da,Ms,pa=h(()=>{"use strict";gr={idle:{transitions:["task"],prompt:"prjct task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"prjct status done Complete task | prjct status paused Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"prjct status active Continue | prjct task <new> Start different | prjct ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","pause","reopen"],prompt:"prjct ship Ship it | prjct task <next> Start next | prjct status active Reopen",description:"Task completed"},shipped:{transitions:["task"],prompt:"prjct task <description> Start new task",description:"Feature shipped"}},da=class{static{l(this,"WorkflowStateMachine")}getCurrentState(e,t){let s=null;if(t&&e?.activeTasks?.length&&(s=e.activeTasks.find(o=>o.workspaceId===t)),s||(s=e?.currentTask),!s)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof s.status=="string"?s.status:"").toLowerCase()){case"in_progress":case"working":return"working";case"paused":return"paused";case"completed":case"done":return"completed";case"shipped":return"shipped";default:return s?"working":"idle"}}canTransition(e,t){if(gr[e].transitions.includes(t))return{valid:!0};let r=this.formatNextSteps(e).join(" | ");return{valid:!1,error:`Cannot transition to '${t}' from '${e}' state`,suggestion:`Valid next steps: ${r}`}}getNextState(e,t){switch(t){case"task":return"working";case"done":return"completed";case"pause":return"paused";case"resume":return"working";case"ship":return"shipped";case"reopen":return"working";default:return e}}getStateInfo(e){return gr[e]}getPrompt(e){return gr[e].prompt}getValidCommands(e){return gr[e].transitions}formatNextSteps(e){return gr[e].transitions.map(s=>{switch(s){case"task":return"prjct task <desc> Start new task";case"done":return"prjct status done Complete current task";case"pause":return"prjct status paused Pause and switch context";case"resume":return"prjct status active Continue paused task";case"ship":return"prjct ship Ship the feature";case"reopen":return"prjct status active Reopen completed task";default:return`prjct ${s}`}})}},Ms=new da});var ma,D,ot=h(()=>{"use strict";$s();ia();be();pa();ms();fs();ma=class extends Xe{static{l(this,"StateStorage")}constructor(){super("state.json",$u)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],activeTasks:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let s=Ms.getCurrentState(e),r=Ms.canTransition(s,t);if(!r.valid)throw new Error(`${r.error}. ${r.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async getPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async startTask(e,t){let s=await this.read(e);this.validateTransition(s,"task");let r={...t,startedAt:R()};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:R()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId}),r}async updateCurrentTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;let r={...s.currentTask,...t};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:R()})),r}async completeTask(e,t){let s=await this.read(e),r=s.currentTask;if(!r)return null;this.validateTransition(s,"done");let o=R(),i=this.createTaskHistoryEntry(r,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:r.id,description:r.description,startedAt:r.startedAt,completedAt:o}),r}createTaskHistoryEntry(e,t,s){let r=(e.subtasks||[]).filter(a=>a.status==="completed"&&a.summary).map(a=>a.summary),o=r.length>0?r.map(a=>a.title).join(", "):"Task completed",i={taskId:e.id,title:e.parentDescription||e.description,classification:e.type||"improvement",startedAt:e.startedAt,completedAt:t,subtaskCount:e.subtasks?.length||0,subtaskSummaries:r,outcome:o,branchName:e.branch||"unknown",linearId:e.linearId,linearUuid:e.linearUuid,prUrl:e.prUrl};return s&&(i.feedback=s),e.tokensIn&&(i.tokensIn=e.tokensIn),e.tokensOut&&(i.tokensOut=e.tokensOut),i}maxPausedTasks=5;maxTaskHistory=20;stalenessThresholdDays=30;async pauseTask(e,t){let s=await this.read(e);if(!s.currentTask)return null;this.validateTransition(s,"pause");let r={...s.currentTask,status:"paused",pausedAt:R(),pauseReason:t},o=this.getPausedTasksFromState(s),i=[r,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:R()})),await this.publishEvent(e,"task.paused",{taskId:r.id,description:r.description,pausedAt:r.pausedAt,reason:t,pausedCount:i.length}),r}async resumeTask(e,t){let s=await this.read(e),r=this.getPausedTasksFromState(s);if(r.length===0)return null;this.validateTransition(s,"resume");let o=0;if(t&&(o=r.findIndex(g=>g.id===t),o===-1))return null;let i=r[o],a=r.filter((g,y)=>y!==o),{status:c,pausedAt:u,pauseReason:d,...m}=i,p={...m,startedAt:R(),sessionId:i.sessionId??tt()};return await this.update(e,g=>({...g,currentTask:p,previousTask:null,pausedTasks:a,lastUpdated:R()})),await this.publishEvent(e,"task.resumed",{taskId:p.id,description:p.description,resumedAt:p.startedAt,remainingPaused:a.length}),p}getPausedTasksFromState(e){return Array.isArray(e.pausedTasks)&&e.pausedTasks.length>0?e.pausedTasks:e.previousTask?[e.previousTask]:[]}getTaskHistoryFromState(e){return e.taskHistory||[]}async getStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return s.filter(o=>new Date(o.pausedAt).getTime()<r)}async archiveStalePausedTasks(e){let t=await this.read(e),s=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=s.filter(a=>new Date(a.pausedAt).getTime()<r),i=s.filter(a=>new Date(a.pausedAt).getTime()>=r);if(o.length===0)return[];st.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:R()}));for(let a of o)await this.publishEvent(e,"task.archived",{taskId:a.id,description:a.description,pausedAt:a.pausedAt,reason:"staleness"});return o}async clearTask(e){await this.update(e,()=>({currentTask:null,previousTask:null,pausedTasks:[],activeTasks:[],lastUpdated:R()}))}async hasTask(e){let t=await this.read(e),s=this.getPausedTasksFromState(t);return t.currentTask!==null||s.length>0}async getPausedTask(e){let t=await this.read(e);return this.getPausedTasksFromState(t)[0]||null}async getAllPausedTasks(e){let t=await this.read(e);return this.getPausedTasksFromState(t)}async getTaskHistory(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)}async getMostRecentTask(e){let t=await this.read(e);return this.getTaskHistoryFromState(t)[0]||null}async getTaskHistoryByType(e,t){let s=await this.read(e);return this.getTaskHistoryFromState(s).filter(o=>o.classification===t)}async getAggregatedFeedback(e){let s=(await this.getTaskHistory(e)).filter(p=>p.feedback),r=[],o=[],i=[],a=[];for(let p of s){let g=p.feedback;Array.isArray(g.stackConfirmed)&&r.push(...g.stackConfirmed),Array.isArray(g.patternsDiscovered)&&o.push(...g.patternsDiscovered),Array.isArray(g.agentAccuracy)&&i.push(...g.agentAccuracy),Array.isArray(g.issuesEncountered)&&a.push(...g.issuesEncountered)}let c=[...new Set(r)],u=[...new Set(o)],d=new Map;for(let p of a)d.set(p,(d.get(p)||0)+1);let m=[...d.entries()].filter(([p,g])=>g>=2).map(([p])=>p);return{stackConfirmed:c,patternsDiscovered:u,agentAccuracy:i,issuesEncountered:[...new Set(a)],knownGotchas:m}}async startTaskInWorkspace(e,t,s){let r={...t,workspaceId:s,startedAt:R()};return await this.update(e,o=>({...o,activeTasks:[...o.activeTasks||[],r],lastUpdated:R()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId,workspaceId:s}),r}async getCurrentTaskForWorkspace(e,t){return((await this.read(e)).activeTasks||[]).find(r=>r.workspaceId===t)??null}async completeTaskInWorkspace(e,t,s){let r=await this.read(e),i=(r.activeTasks||[]).find(m=>m.workspaceId===t);if(!i)return null;let a=R(),c=this.createTaskHistoryEntry(i,a,s),u=this.getTaskHistoryFromState(r),d=[c,...u].slice(0,this.maxTaskHistory);return await this.update(e,m=>({...m,activeTasks:(m.activeTasks||[]).filter(p=>p.workspaceId!==t),taskHistory:d,lastUpdated:a})),await this.publishEvent(e,"task.completed",{taskId:i.id,description:i.description,startedAt:i.startedAt,completedAt:a,workspaceId:t}),i}async getActiveTasks(e){return(await this.read(e)).activeTasks||[]}async getActiveTaskCount(e){return((await this.read(e)).activeTasks||[]).length}async updateWorkspaceTask(e,t,s){let o=(await this.read(e)).activeTasks||[],i=o.findIndex(c=>c.workspaceId===t);if(i===-1)return null;let a={...o[i],...s,workspaceId:t};return await this.update(e,c=>{let u=[...c.activeTasks||[]];return u[i]=a,{...c,activeTasks:u,lastUpdated:R()}}),a}async addTokens(e,t,s){let r=await this.read(e);if(!r.currentTask)return null;let o=(r.currentTask.tokensIn||0)+t,i=(r.currentTask.tokensOut||0)+s;return await this.update(e,a=>({...a,currentTask:{...a.currentTask,tokensIn:o,tokensOut:i},lastUpdated:R()})),{tokensIn:o,tokensOut:i}}async createSubtasks(e,t){let s=await this.read(e);if(!s.currentTask)return;let r=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?R():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:r,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:r.length,percentage:0}},lastUpdated:R()})),await this.publishEvent(e,"subtasks.created",{taskId:s.currentTask.id,subtaskCount:r.length,subtasks:r.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let s=Ru.safeParse(t);if(!s.success){let y=s.error.issues.map(j=>`${j.path.join(".")}: ${j.message}`);throw new Error(`Subtask completion requires handoff data:
493
493
  ${y.join(`
494
- `)}`)}let{output:r,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:R(),output:r,summary:o};let d=u.filter(y=>y.status==="completed").length,m=u.length,p=Math.round(d/m*100),g=a+1;return g<u.length&&(u[g]={...u[g],status:"in_progress",startedAt:R()}),await this.update(e,y=>({...y,currentTask:{...y.currentTask,subtasks:u,currentSubtaskIndex:g<m?g:a,subtaskProgress:{completed:d,total:m,percentage:p}},lastUpdated:R()})),await this.publishEvent(e,"subtask.completed",{taskId:i.currentTask.id,subtaskId:c.id,description:c.description,output:r,handoff:o.outputForNextAgent,filesChanged:o.filesChanged.length,progress:{completed:d,total:m,percentage:p}}),g<m?u[g]:null}async getCurrentSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=t.currentTask.currentSubtaskIndex||0;return t.currentTask.subtasks[s]||null}async getNextSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=(t.currentTask.currentSubtaskIndex||0)+1;return t.currentTask.subtasks[s]||null}async getPreviousSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=(t.currentTask.currentSubtaskIndex||0)-1;return s<0?null:t.currentTask.subtasks[s]||null}async getPreviousHandoff(e){let t=await this.getPreviousSubtask(e);return t?.summary?.outputForNextAgent?{fromSubtask:t.description,outputForNextAgent:t.summary.outputForNextAgent,filesChanged:t.summary.filesChanged,whatWasDone:t.summary.whatWasDone}:null}async getSubtasks(e){return(await this.read(e)).currentTask?.subtasks||[]}async getSubtaskProgress(e){return(await this.read(e)).currentTask?.subtaskProgress||null}async hasSubtasks(e){return((await this.read(e)).currentTask?.subtasks?.length||0)>0}async areAllSubtasksComplete(e){let t=await this.read(e);return t.currentTask?.subtasks?t.currentTask.subtasks.every(s=>s.status==="completed"||s.status==="failed"||s.status==="skipped"):!0}async failSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"failed",completedAt:R(),output:`Failed: ${t}`};let a=r+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:R()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,d=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r,subtaskProgress:{completed:u,total:c,percentage:d}},lastUpdated:R()})),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 r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"skipped",completedAt:R(),output:`Skipped: ${t}`,skipReason:t};let a=r+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:R()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,d=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r,subtaskProgress:{completed:u,total:c,percentage:d}},lastUpdated:R()})),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 r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"blocked",output:`Blocked: ${t}`,blockReason:t};let a=r+1,c=i.length;return a<c&&(i[a]={...i[a],status:"in_progress",startedAt:R()}),await this.update(e,u=>({...u,currentTask:{...u.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r},lastUpdated:R()})),await this.publishEvent(e,"subtask.blocked",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,blocker:t}),a<c?i[a]:null}},D=new da});function Vh(){let n=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!n)return{level:-1,name:"disabled"};if(qh.has(n)||n.includes("prjct"))return{level:un.debug,name:"debug"};let e=un[n]??-1,t=e>=0?n:"disabled";return{level:e,name:t}}function ao(n,e,t){return Hu>=n?(...s)=>console[t](e,...s):Jh}var un,qh,Hu,Bh,Jh,zh,B,_s=h(()=>{"use strict";un={error:0,warn:1,info:2,debug:3},qh=new Set(["1","true","*"]);l(Vh,"getLogLevel");({level:Hu,name:Bh}=Vh()),Jh=l(()=>{},"noop");l(ao,"createLogMethod");zh={error:ao(un.error,"[prjct:error]","error"),warn:ao(un.warn,"[prjct:warn]","warn"),info:ao(un.info,"[prjct:info]","log"),debug:ao(un.debug,"[prjct:debug]","log"),isEnabled:l(()=>Hu>=0,"isEnabled"),level:l(()=>Bh,"level")},B=zh});import Xh from"node:fs/promises";import Kh from"node:path";import{Hono as Yh}from"hono";function Qh(n){return $.getGlobalProjectPath(n)}function Wu(n,e){let t=new Yh,s=Qh(n);return t.get("/state",async r=>{let o=await D.read(n);return r.json(o)}),t.get("/queue",async r=>{let o=await Fe.read(n);return r.json(o)}),t.get("/ideas",async r=>{let o=await Le.read(n);return r.json(o)}),t.get("/roadmap",async r=>{let o=C.getDoc(n,"roadmap");return o?r.json(o):r.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async r=>{let o=await Ke.read(n);return r.json(o)}),t.get("/dashboard",async r=>{let[o,i,a,c]=await Promise.all([D.read(n),Fe.read(n),Le.read(n),Ke.read(n)]),u=C.getDoc(n,"roadmap");return r.json({projectId:n,state:o,queue:i,ideas:a,roadmap:u||{features:[],backlog:[],lastUpdated:""},shipped:c,timestamp:new Date().toISOString()})}),t.post("/state",async r=>{try{let o=await r.req.json();if(!o||typeof o!="object"||Array.isArray(o))return r.json({success:!1,error:"Invalid state object"},400);let i=["currentTask","previousTask","lastUpdated"],a={};for(let c of i)c in o&&(a[c]=o[c]);return await D.write(n,a),r.json({success:!0})}catch{return r.json({success:!1,error:"Internal server error"},400)}}),t.get("/context/:name",async r=>{let o=r.req.param("name");if(!["now","next","ideas","shipped"].includes(o))return r.json({error:"Invalid context file"},400);try{let a=Kh.join(s,"context",`${o}.md`),c=await Xh.readFile(a,"utf-8");return r.text(c,200,{"Content-Type":"text/markdown"})}catch(a){return _(a)||B.error(`Context read error: ${k(a)}`),r.text("",200,{"Content-Type":"text/markdown"})}}),t}var Gu=h(()=>{"use strict";Re();ce();pr();mr();Ds();rt();V();_s();l(Qh,"getProjectDataPath");l(Wu,"createRoutes")});function Zh(n){return{id:n.id,taskId:n.task_id,author:n.author,content:n.content,createdAt:n.created_at,updatedAt:n.updated_at}}function ey(){return`cmt_${Math.random().toString(36).slice(2,10)}${Date.now().toString(36)}`}var pa,fr,qu=h(()=>{"use strict";ce();l(Zh,"rowToComment");l(ey,"generateId");pa=class{static{l(this,"CommentStorage")}addComment(e,t,s,r="user"){let o=ey(),i=new Date().toISOString();return C.run(e,`INSERT INTO queue_task_comments (id, task_id, author, content, created_at, updated_at)
495
- VALUES (?, ?, ?, ?, ?, ?)`,o,t,r,s,i,i),{id:o,taskId:t,author:r,content:s,createdAt:i,updatedAt:i}}getComments(e,t){return C.query(e,"SELECT * FROM queue_task_comments WHERE task_id = ? ORDER BY created_at ASC",t).map(Zh)}updateComment(e,t,s){return C.get(e,"SELECT id FROM queue_task_comments WHERE id = ?",t)?(C.run(e,"UPDATE queue_task_comments SET content = ?, updated_at = ? WHERE id = ?",s,new Date().toISOString(),t),!0):!1}deleteComment(e,t){return C.get(e,"SELECT id FROM queue_task_comments WHERE id = ?",t)?(C.run(e,"DELETE FROM queue_task_comments WHERE id = ?",t),!0):!1}},fr=new pa});var ma,ga,Vu=h(()=>{"use strict";ce();ma=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)
494
+ `)}`)}let{output:r,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:R(),output:r,summary:o};let d=u.filter(y=>y.status==="completed").length,m=u.length,p=Math.round(d/m*100),g=a+1;return g<u.length&&(u[g]={...u[g],status:"in_progress",startedAt:R()}),await this.update(e,y=>({...y,currentTask:{...y.currentTask,subtasks:u,currentSubtaskIndex:g<m?g:a,subtaskProgress:{completed:d,total:m,percentage:p}},lastUpdated:R()})),await this.publishEvent(e,"subtask.completed",{taskId:i.currentTask.id,subtaskId:c.id,description:c.description,output:r,handoff:o.outputForNextAgent,filesChanged:o.filesChanged.length,progress:{completed:d,total:m,percentage:p}}),g<m?u[g]:null}async getCurrentSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=t.currentTask.currentSubtaskIndex||0;return t.currentTask.subtasks[s]||null}async getNextSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=(t.currentTask.currentSubtaskIndex||0)+1;return t.currentTask.subtasks[s]||null}async getPreviousSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let s=(t.currentTask.currentSubtaskIndex||0)-1;return s<0?null:t.currentTask.subtasks[s]||null}async getPreviousHandoff(e){let t=await this.getPreviousSubtask(e);return t?.summary?.outputForNextAgent?{fromSubtask:t.description,outputForNextAgent:t.summary.outputForNextAgent,filesChanged:t.summary.filesChanged,whatWasDone:t.summary.whatWasDone}:null}async getSubtasks(e){return(await this.read(e)).currentTask?.subtasks||[]}async getSubtaskProgress(e){return(await this.read(e)).currentTask?.subtaskProgress||null}async hasSubtasks(e){return((await this.read(e)).currentTask?.subtasks?.length||0)>0}async areAllSubtasksComplete(e){let t=await this.read(e);return t.currentTask?.subtasks?t.currentTask.subtasks.every(s=>s.status==="completed"||s.status==="failed"||s.status==="skipped"):!0}async failSubtask(e,t){let s=await this.read(e);if(!s.currentTask?.subtasks)return null;let r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"failed",completedAt:R(),output:`Failed: ${t}`};let a=r+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:R()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,d=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r,subtaskProgress:{completed:u,total:c,percentage:d}},lastUpdated:R()})),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 r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"skipped",completedAt:R(),output:`Skipped: ${t}`,skipReason:t};let a=r+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:R()});let u=i.filter(m=>m.status==="completed"||m.status==="failed"||m.status==="skipped").length,d=Math.round(u/c*100);return await this.update(e,m=>({...m,currentTask:{...m.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r,subtaskProgress:{completed:u,total:c,percentage:d}},lastUpdated:R()})),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 r=s.currentTask.currentSubtaskIndex||0,o=s.currentTask.subtasks[r];if(!o)return null;let i=[...s.currentTask.subtasks];i[r]={...o,status:"blocked",output:`Blocked: ${t}`,blockReason:t};let a=r+1,c=i.length;return a<c&&(i[a]={...i[a],status:"in_progress",startedAt:R()}),await this.update(e,u=>({...u,currentTask:{...u.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r},lastUpdated:R()})),await this.publishEvent(e,"subtask.blocked",{taskId:s.currentTask.id,subtaskId:o.id,description:o.description,blocker:t}),a<c?i[a]:null}},D=new ma});function Bh(){let n=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!n)return{level:-1,name:"disabled"};if(Vh.has(n)||n.includes("prjct"))return{level:un.debug,name:"debug"};let e=un[n]??-1,t=e>=0?n:"disabled";return{level:e,name:t}}function co(n,e,t){return Hu>=n?(...s)=>console[t](e,...s):zh}var un,Vh,Hu,Jh,zh,Xh,B,_s=h(()=>{"use strict";un={error:0,warn:1,info:2,debug:3},Vh=new Set(["1","true","*"]);l(Bh,"getLogLevel");({level:Hu,name:Jh}=Bh()),zh=l(()=>{},"noop");l(co,"createLogMethod");Xh={error:co(un.error,"[prjct:error]","error"),warn:co(un.warn,"[prjct:warn]","warn"),info:co(un.info,"[prjct:info]","log"),debug:co(un.debug,"[prjct:debug]","log"),isEnabled:l(()=>Hu>=0,"isEnabled"),level:l(()=>Jh,"level")},B=Xh});import Kh from"node:fs/promises";import Yh from"node:path";import{Hono as Qh}from"hono";function Zh(n){return $.getGlobalProjectPath(n)}function Wu(n,e){let t=new Qh,s=Zh(n);return t.get("/state",async r=>{let o=await D.read(n);return r.json(o)}),t.get("/queue",async r=>{let o=await Fe.read(n);return r.json(o)}),t.get("/ideas",async r=>{let o=await Le.read(n);return r.json(o)}),t.get("/roadmap",async r=>{let o=C.getDoc(n,"roadmap");return o?r.json(o):r.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async r=>{let o=await Ke.read(n);return r.json(o)}),t.get("/dashboard",async r=>{let[o,i,a,c]=await Promise.all([D.read(n),Fe.read(n),Le.read(n),Ke.read(n)]),u=C.getDoc(n,"roadmap");return r.json({projectId:n,state:o,queue:i,ideas:a,roadmap:u||{features:[],backlog:[],lastUpdated:""},shipped:c,timestamp:new Date().toISOString()})}),t.post("/state",async r=>{try{let o=await r.req.json();if(!o||typeof o!="object"||Array.isArray(o))return r.json({success:!1,error:"Invalid state object"},400);let i=["currentTask","previousTask","lastUpdated"],a={};for(let c of i)c in o&&(a[c]=o[c]);return await D.write(n,a),r.json({success:!0})}catch{return r.json({success:!1,error:"Internal server error"},400)}}),t.get("/context/:name",async r=>{let o=r.req.param("name");if(!["now","next","ideas","shipped"].includes(o))return r.json({error:"Invalid context file"},400);try{let a=Yh.join(s,"context",`${o}.md`),c=await Kh.readFile(a,"utf-8");return r.text(c,200,{"Content-Type":"text/markdown"})}catch(a){return _(a)||B.error(`Context read error: ${k(a)}`),r.text("",200,{"Content-Type":"text/markdown"})}}),t}var Gu=h(()=>{"use strict";Re();ce();pr();mr();Ds();ot();V();_s();l(Zh,"getProjectDataPath");l(Wu,"createRoutes")});function ey(n){return{id:n.id,taskId:n.task_id,author:n.author,content:n.content,createdAt:n.created_at,updatedAt:n.updated_at}}function ty(){return`cmt_${Math.random().toString(36).slice(2,10)}${Date.now().toString(36)}`}var ga,fr,qu=h(()=>{"use strict";ce();l(ey,"rowToComment");l(ty,"generateId");ga=class{static{l(this,"CommentStorage")}addComment(e,t,s,r="user"){let o=ty(),i=new Date().toISOString();return C.run(e,`INSERT INTO queue_task_comments (id, task_id, author, content, created_at, updated_at)
495
+ VALUES (?, ?, ?, ?, ?, ?)`,o,t,r,s,i,i),{id:o,taskId:t,author:r,content:s,createdAt:i,updatedAt:i}}getComments(e,t){return C.query(e,"SELECT * FROM queue_task_comments WHERE task_id = ? ORDER BY created_at ASC",t).map(ey)}updateComment(e,t,s){return C.get(e,"SELECT id FROM queue_task_comments WHERE id = ?",t)?(C.run(e,"UPDATE queue_task_comments SET content = ?, updated_at = ? WHERE id = ?",s,new Date().toISOString(),t),!0):!1}deleteComment(e,t){return C.get(e,"SELECT id FROM queue_task_comments WHERE id = ?",t)?(C.run(e,"DELETE FROM queue_task_comments WHERE id = ?",t),!0):!1}},fr=new ga});var fa,ha,Vu=h(()=>{"use strict";ce();fa=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)
496
496
  VALUES (?, ?, ?, ?, ?, ?, ?)`,e,s??null,t.from,t.to,t.usagePercent,t.action??null,t.timestamp)}recordCompaction(e,t,s,r){C.run(e,`INSERT INTO context_compactions (project_id, format, original_turns, files_count, timestamp)
497
497
  VALUES (?, ?, ?, ?, ?)`,e,t,s,r,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(r=>({from:r.zone_from,to:r.zone_to,usagePercent:r.usage_percent,timestamp:r.timestamp,action:r.action}))}getSummary(e,t=7){let s=new Date(Date.now()-t*864e5).toISOString(),r=C.query(e,`SELECT zone_to, COUNT(*) as cnt FROM context_zone_events
498
498
  WHERE project_id = ? AND timestamp >= ?
499
499
  GROUP BY zone_to`,e,s),o={smart:0,warning:0,dumb:0},i=0;for(let u of r)o[u.zone_to]=u.cnt,i+=u.cnt;let c=C.query(e,`SELECT COUNT(*) as cnt FROM context_compactions
500
- 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}}},ga=new ma});var fa,xe,co=h(()=>{"use strict";ce();fa=class{static{l(this,"CustomWorkflowStorage")}createWorkflow(e,t){let s=new Date().toISOString();L.run(e,`INSERT INTO custom_workflows (name, description, created_at, updated_at, is_builtin, enabled, metadata)
501
- VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,s,s,t.metadata?JSON.stringify(t.metadata):null);let r=L.get(e,"SELECT id FROM custom_workflows WHERE name = ?",t.name);if(!r)throw new Error(`Failed to create workflow: ${t.name}`);return r.id}getWorkflow(e,t){let s=L.get(e,"SELECT * FROM custom_workflows WHERE name = ?",t);return s?this.rowToWorkflow(s):null}getAllWorkflows(e,t=!1){let s=t?"SELECT * FROM custom_workflows ORDER BY is_builtin DESC, name ASC":"SELECT * FROM custom_workflows WHERE enabled = 1 ORDER BY is_builtin DESC, name ASC";return L.query(e,s).map(o=>this.rowToWorkflow(o))}updateWorkflow(e,t,s){if(!this.getWorkflow(e,t))return!1;let o=new Date().toISOString(),i=[],a=[];return s.description!==void 0&&(i.push("description = ?"),a.push(s.description)),s.enabled!==void 0&&(i.push("enabled = ?"),a.push(s.enabled?1:0)),s.metadata!==void 0&&(i.push("metadata = ?"),a.push(JSON.stringify(s.metadata))),i.length===0?!1:(i.push("updated_at = ?"),a.push(o),a.push(t),L.run(e,`UPDATE custom_workflows SET ${i.join(", ")} WHERE name = ?`,...a),!0)}deleteWorkflow(e,t){let s=this.getWorkflow(e,t);if(!s)return!1;if(s.isBuiltin)throw new Error(`Cannot delete built-in workflow: ${t}`);return L.run(e,"UPDATE custom_workflows SET enabled = 0 WHERE name = ?",t),!0}isBuiltin(e,t){return this.getWorkflow(e,t)?.isBuiltin??!1}isReservedName(e){let t=["task","done","ship","sync"],s=["add","rm","gate","list","create","delete","run","help","reset","init"];return t.includes(e)||s.includes(e)}isValidName(e){return/^[a-z0-9-]+$/.test(e)}rowToWorkflow(e){return{id:e.id,name:e.name,description:e.description,createdAt:e.created_at,updatedAt:e.updated_at,isBuiltin:e.is_builtin===1,enabled:e.enabled===1,metadata:e.metadata?JSON.parse(e.metadata):null}}},xe=new fa});import{createHash as Bu}from"node:crypto";function hr(n){return Bu("sha256").update(n).digest("hex")}function Ju(n){return hr(n).slice(0,16)}function zu(n){return Bu("md5").update(n).digest("hex")}var yr=h(()=>{"use strict";l(hr,"sha256");l(Ju,"sha256Short");l(zu,"md5")});import lo from"node:fs/promises";import Xu from"node:path";function ty(){return{version:dn,lastUpdated:"",checksums:{}}}var dn,ha,wr,Ku=h(()=>{"use strict";Re();V();be();yr();ce();dn="1.0.0";l(ty,"getDefaultChecksums");ha=class{static{l(this,"IndexStorage")}getIndexPath(e){return Xu.join($.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await lo.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==dn?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 ty()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await lo.readFile(e);return zu(t)}catch{return""}}async detectChangedFiles(e,t){let r=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[c,u]of t)c in r?r[c]!==u&&i.push(c):o.push(c);for(let c of Object.keys(r))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:dn,lastUpdated:R(),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 lo.readdir(t);await Promise.all(s.map(r=>lo.unlink(Xu.join(t,r))))}catch(s){if(!_(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!==dn?null:t}catch{}return null}readDomainsSync(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null&&t.version===dn)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!==dn?null:t}catch{}return null}async writeCategories(e,t){this.setIndexMeta(e,"categories-cache",t)}async getFileCategories(e,t){let s=await this.readCategories(e),r=new Map;if(!s)return r;let o=new Set(t);for(let i of s.fileCategories)o.has(i.path)&&r.set(i.path,i.categories);return r}async getFilesByDomain(e,t){let s=await this.readCategories(e);return s?s.domainIndex[t]||[]:[]}getIndexMeta(e,t){let r=C.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setIndexMeta(e,t,s){let r=C.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();r.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},wr=new ha});var ya,uo,wt,pn=h(()=>{"use strict";be();ce();ya=class{static{l(this,"LLMAnalysisStorage")}save(e,t){let s=C.getDb(e),r=R();s.transaction(()=>{s.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(r),s.prepare("INSERT INTO llm_analysis (commit_hash, status, analysis, analyzed_at) VALUES (?, ?, ?, ?)").run(t.commitHash??null,"active",JSON.stringify(t),t.analyzedAt)})()}getActive(e){let t=C.get(e,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");return t?JSON.parse(t.analysis):null}getActiveSummary(e){let t=this.getActive(e);return t?{commitHash:t.commitHash,architectureStyle:t.architecture.style,patternCount:t.patterns.length,antiPatternCount:t.antiPatterns.length,analyzedAt:t.analyzedAt}:null}isCurrent(e,t){return t?C.get(e,"SELECT commit_hash FROM llm_analysis WHERE status = 'active' LIMIT 1")?.commit_hash===t:!1}getAllFull(e){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, superseded_at, analysis FROM llm_analysis ORDER BY id DESC").map(s=>({id:s.id,status:s.status,commitHash:s.commit_hash,analyzedAt:s.analyzed_at,supersededAt:s.superseded_at,analysis:JSON.parse(s.analysis)}))}getHistory(e,t=10){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, analysis FROM llm_analysis ORDER BY id DESC LIMIT ?",t).map(r=>{let o=JSON.parse(r.analysis);return{id:r.id,commitHash:r.commit_hash,status:r.status,analyzedAt:r.analyzed_at,patternCount:o.patterns.length}})}},uo=new ya,wt=uo});import{z as Ae}from"zod";function ed(n,e="default"){let t=Yu[e]||Yu.default;return n/1e3*t}function po(n){return n<.01?`$${(n*100).toFixed(2)}\xA2`:`$${n.toFixed(2)}`}var sy,ny,Qu,Zu,Yu,mo=h(()=>{"use strict";sy=Ae.object({date:Ae.string(),tokensSaved:Ae.number(),syncs:Ae.number(),avgCompressionRate:Ae.number(),totalDuration:Ae.number()}),ny=Ae.object({agentName:Ae.string(),usageCount:Ae.number(),tokensSaved:Ae.number()}),Qu=Ae.object({totalTokensSaved:Ae.number(),avgCompressionRate:Ae.number(),syncCount:Ae.number(),watchTriggers:Ae.number(),avgSyncDuration:Ae.number(),totalSyncDuration:Ae.number(),agentUsage:Ae.array(ny),dailyStats:Ae.array(sy),firstSync:Ae.string(),lastUpdated:Ae.string()}),Zu={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},Yu={"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(ed,"estimateCostSaved");l(po,"formatCost")});var wa,es,go=h(()=>{"use strict";mo();be();fs();wa=class extends Xe{static{l(this,"MetricsStorage")}constructor(){super("metrics.json",Qu)}getDefault(){return{...Zu}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let s=Math.max(0,t.originalSize-t.filteredSize),r=t.originalSize>0?s/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,c=i.totalTokensSaved+s,u=i.totalSyncDuration+t.duration,d=i.syncCount===0?r:(i.avgCompressionRate*i.syncCount+r)/a,m=[...i.dailyStats],p=m.findIndex(x=>x.date===o);if(p>=0){let x=m[p];m[p]={...x,tokensSaved:x.tokensSaved+s,syncs:x.syncs+1,avgCompressionRate:(x.avgCompressionRate*x.syncs+r)/(x.syncs+1),totalDuration:x.totalDuration+t.duration}}else m.push({date:o,tokensSaved:s,syncs:1,avgCompressionRate:r,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let y=g.toISOString().split("T")[0],j=m.filter(x=>x.date>=y),T=[...i.agentUsage];if(t.agents)for(let x of t.agents){let S=T.findIndex(w=>w.agentName===x);S>=0?T[S]={...T[S],usageCount:T[S].usageCount+1,tokensSaved:T[S].tokensSaved+Math.floor(s/t.agents.length)}:T.push({agentName:x,usageCount:1,tokensSaved:Math.floor(s/t.agents.length)})}return{totalTokensSaved:c,avgCompressionRate:d,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:T,dailyStats:j,firstSync:i.firstSync||R(),lastUpdated:R()}})}async getSummary(e){let t=await this.read(e),s=this.getLast30Days(t.dailyStats),r=this.getPrev30Days(t.dailyStats),o=s.reduce((c,u)=>c+u.tokensSaved,0),i=r.reduce((c,u)=>c+u.tokensSaved,0),a=i>0?(o-i)/i*100:0;return{totalTokensSaved:t.totalTokensSaved,estimatedCostSaved:ed(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),r=new Date;r.setDate(r.getDate()-t);let o=r.toISOString().split("T")[0];return s.dailyStats.filter(i=>i.date>=o).sort((i,a)=>i.date.localeCompare(a.date))}getLast30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=t.toISOString().split("T")[0];return e.filter(r=>r.date>=s)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=new Date;s.setDate(s.getDate()-60);let r=s.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=r&&i.date<o)}},es=new wa});import{z as pe}from"zod";var ry,oy,td,wj,kj,vj,sd,nd=h(()=>{"use strict";ry=pe.enum(["improving","stable","declining"]),oy=pe.object({sprintNumber:pe.number(),startDate:pe.string(),endDate:pe.string(),pointsCompleted:pe.number(),tasksCompleted:pe.number(),avgVariance:pe.number(),estimationAccuracy:pe.number()}),td=pe.object({category:pe.string(),avgVariance:pe.number(),taskCount:pe.number()}),wj=pe.object({totalPoints:pe.number(),sprints:pe.number(),estimatedDate:pe.string()}),kj=pe.object({sprints:pe.array(oy),averageVelocity:pe.number(),velocityTrend:ry,estimationAccuracy:pe.number(),overEstimated:pe.array(td),underEstimated:pe.array(td),lastUpdated:pe.string()}),vj=pe.object({sprintLengthDays:pe.number().min(1).max(90).default(7),startDay:pe.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:pe.number().min(1).max(52).default(6),accuracyTolerance:pe.number().min(0).max(100).default(20)}),sd={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var ka,fo,va=h(()=>{"use strict";nd();fs();ka=class extends Xe{static{l(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:sd,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}},fo=new ka});function Sa(n){let e=n.trust_source==="imported"?"imported":"local";return{id:n.id,type:n.type,command:n.command,position:n.position,action:n.action,description:n.description,enabled:n.enabled===1,timeoutMs:n.timeout_ms,createdAt:n.created_at,sortOrder:n.sort_order,whenExpr:n.when_expr??null,parallel:n.parallel===null?!0:n.parallel===1,trustSource:e}}var ba,ee,mn=h(()=>{"use strict";co();ce();l(Sa,"rowToRule");ba=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),r=t.sortOrder||(s?.m??-1)+1;return C.run(e,`INSERT INTO workflow_rules (type, command, position, action, description, enabled, timeout_ms, created_at, sort_order, when_expr, parallel, trust_source)
502
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,r,t.whenExpr??null,t.parallel===!1?0:1,t.trustSource??"local"),C.get(e,"SELECT last_insert_rowid() as id")?.id??0}removeRule(e,t){return C.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t)?(C.run(e,"DELETE FROM workflow_rules WHERE id = ?",t),!0):!1}updateRule(e,t,s){if(!C.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t))return!1;let o={type:{column:"type"},command:{column:"command"},position:{column:"position"},action:{column:"action"},description:{column:"description"},enabled:{column:"enabled",transform:l(c=>c?1:0,"transform")},timeoutMs:{column:"timeout_ms"},createdAt:{column:"created_at"},sortOrder:{column:"sort_order"},whenExpr:{column:"when_expr"},parallel:{column:"parallel",transform:l(c=>c===!1?0:1,"transform")},trustSource:{column:"trust_source"}},i=[],a=[];for(let[c,u]of Object.entries(s)){let d=o[c];if(!d)continue;i.push(`${d.column} = ?`);let m=u;a.push(d.transform?d.transform(m):m)}return i.length===0||(a.push(t),C.run(e,`UPDATE workflow_rules SET ${i.join(", ")} WHERE id = ?`,...a)),!0}getRuleById(e,t){let s=C.get(e,"SELECT * FROM workflow_rules WHERE id = ?",t);return s?Sa(s):null}getRulesForCommand(e,t){let s=xe.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(Sa)}getAllRules(e){return C.query(e,"SELECT * FROM workflow_rules ORDER BY command ASC, sort_order ASC").map(Sa)}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}},ee=new ba});import Ut from"node:fs/promises";import Ea from"node:path";import{Hono as iy}from"hono";function kr(n){return C.getDoc(n,"project")}async function Ta(n){if(!n)return"";let e=new Date(n),s=new Date().getTime()-e.getTime(),r=Math.floor(s/(1e3*60*60)),o=Math.floor(s%(1e3*60*60)/(1e3*60));return r>0?`${r}h ${o}m`:`${o}m`}function rd(){let n=new iy;return n.get("/projects",async e=>{try{await Ut.mkdir(gn,{recursive:!0});let s=(await Ut.readdir(gn,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),r=await Promise.all(s.map(async o=>{let i=kr(o),a=await D.read(o),c=await Fe.read(o),u=await Le.read(o),d=await Ke.read(o),m=a?.currentTask,p=await Ta(m?.startedAt),g=i;return{id:o,name:g?.name||o.slice(0,8),path:g?.repoPath||g?.path||null,stack:g?.stack||null,branch:g?.currentBranch||null,fileCount:g?.fileCount||null,lastSync:g?.lastSync||null,version:g?.version||null,currentTask:m?{...m,duration:p}:null,pausedTask:a?.previousTask||null,stats:{queueCount:c?.tasks?.filter(y=>!y.completed)?.length||0,ideasCount:u?.ideas?.filter(y=>y.status==="pending")?.length||0,shippedCount:d?.shipped?.length||0,tasksToday:0,tasksThisWeek:0}}}));return r.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:String(o.name||"").localeCompare(String(i.name||""))),e.json({projects:r})}catch{return e.json({projects:[],error:"Internal server error"},500)}}),n.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[s,r,o,i,a]=await Promise.all([Promise.resolve(kr(t)),D.read(t),Fe.read(t),Le.read(t),Ke.read(t)]),c=C.getDoc(t,"roadmap");r?.currentTask?.startedAt&&(r.currentTask.duration=await Ta(r.currentTask.startedAt));let u=new Date,d=new Date(u.getFullYear(),u.getMonth(),u.getDate()),m=new Date(d);m.setDate(m.getDate()-m.getDay());let p=o?.tasks?.filter(j=>!j.completed||!j.completedAt?!1:new Date(j.completedAt)>=d)?.length||0,g=o?.tasks?.filter(j=>!j.completed||!j.completedAt?!1:new Date(j.completedAt)>=m)?.length||0,y=null;try{let j=C.get(t,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");if(j){let T=JSON.parse(j.analysis);y={architecture:T.architecture,patterns:(T.patterns||[]).slice(0,6),antiPatterns:(T.antiPatterns||[]).slice(0,4),techDebt:(T.techDebt||[]).slice(0,4),conventions:T.conventions,stack:T.stack,analyzedAt:T.analyzedAt,commitHash:T.commitHash}}}catch{}return e.json({id:t,name:s?.name||t,path:s?.path,state:r||{currentTask:null,previousTask:null,lastUpdated:""},queue:o||{tasks:[],lastUpdated:""},ideas:i||{ideas:[],lastUpdated:""},shipped:a||{shipped:[],lastUpdated:""},roadmap:c||{features:[],backlog:[],lastUpdated:""},analysis:y,stats:{tasksToday:p,tasksThisWeek:g,queueCount:o?.tasks?.filter(j=>!j.completed)?.length||0,ideasCount:i?.ideas?.filter(j=>j.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let s=await D.read(t);if(!s?.currentTask)return e.json({success:!1,error:"No active task"},400);let r=s.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await D.write(t,o),e.json({success:!0,completedTask:r,message:`Completed: ${r.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),r=typeof s.reason=="string"?s.reason.slice(0,500):void 0,o=await D.read(t);if(!o?.currentTask)return e.json({success:!1,error:"No active task"},400);let i={id:o.currentTask.id,description:o.currentTask.description,status:"paused",startedAt:o.currentTask.startedAt,pausedAt:new Date().toISOString(),pauseReason:r},a={currentTask:null,previousTask:i,lastUpdated:new Date().toISOString()};return await D.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let s=await D.read(t);if(!s?.previousTask)return e.json({success:!1,error:"No paused task"},400);let r={id:s.previousTask.id,description:s.previousTask.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`},o={currentTask:r,previousTask:null,lastUpdated:new Date().toISOString()};return await D.write(t,o),e.json({success:!0,resumedTask:r,message:`Resumed: ${r.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{taskId:r}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"taskId required (string)"},400);if(r.length>200)return e.json({success:!1,error:"taskId too long"},400);let[o,i]=await Promise.all([D.read(t),Fe.read(t)]);if(o?.currentTask)return e.json({success:!1,error:"Complete or pause current task first"},400);let a=i?.tasks?.find(d=>d.id===r);if(!a)return e.json({success:!1,error:"Task not found in queue"},404);let 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 D.write(t,u),e.json({success:!0,task:c,message:`Started: ${c.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{text:r,priority:o="medium",tags:i=[]}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"text required (string)"},400);if(r.length>5e3)return e.json({success:!1,error:"text too long (max 5000 chars)"},400);let c=["low","medium","high","critical"].includes(o)?o:"medium",u=Array.isArray(i)?i.filter(m=>typeof m=="string").slice(0,20):[],d=await Le.addIdea(t,r,{priority:c,tags:u});return e.json({success:!0,idea:d,message:`Captured: ${r.slice(0,50)}...`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.get("/stats/global",async e=>{try{await Ut.mkdir(gn,{recursive:!0});let s=(await Ut.readdir(gn,{withFileTypes:!0})).filter(c=>c.isDirectory()).map(c=>c.name),r=0,o=0,i=0,a=0;for(let c of s){let u=await D.read(c),d=await Fe.read(c),m=await Le.read(c),p=await Ke.read(c);u?.currentTask&&a++,r+=d?.tasks?.filter(g=>!g.completed)?.length||0,o+=m?.ideas?.filter(g=>g.status==="pending")?.length||0,i+=p?.shipped?.length||0}return e.json({totalProjects:s.length,activeProjects:a,totalTasks:r,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await Ut.mkdir(gn,{recursive:!0});let r=(await Ut.readdir(gn,{withFileTypes:!0})).filter(d=>d.isDirectory()).map(d=>d.name),o=null;if(t)for(let d of r){let m=kr(d),p=m?.repoPath||m?.path;if(p&&t.startsWith(p)){o=d;break}}let i=null,a=null,c=null,u=o?[o]:r;for(let d of u){let m=await D.read(d),p=kr(d);if(m?.currentTask){i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},a={...m.currentTask,duration:await Ta(m.currentTask.startedAt)};break}m?.previousTask&&!c&&(i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},c=m.previousTask)}return e.json({hasActiveTask:!!a,hasPausedTask:!!c,activeProject:i,activeTask:a,pausedTask:c,totalProjects:r.length,filtered:!!o,cwd:t||null,timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.post("/projects/:id/queue",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{description:r,priority:o,type:i,section:a}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"description required (string)"},400);if(r.length>5e3)return e.json({success:!1,error:"description too long (max 5000 chars)"},400);let c=await Fe.addTask(t,{description:r,priority:o||"medium",type:i||"feature",section:a||"active"});return e.json({success:!0,task:c})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.get("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await Fe.getTask(t,s);if(!r)return e.json({error:"Task not found"},404);let o=fr.getComments(t,s);return e.json({task:r,comments:o})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await e.req.json().catch(()=>({})),o={};if(r.priority&&typeof r.priority=="string"){if(!["low","medium","high","critical","normal","urgent"].includes(r.priority))return e.json({success:!1,error:"Invalid priority"},400);o.priority=r.priority}if(r.section&&typeof r.section=="string"){if(!["active","backlog","previously_active"].includes(r.section))return e.json({success:!1,error:"Invalid section"},400);o.section=r.section}return typeof r.description=="string"&&(o.description=r.description),typeof r.body=="string"&&(o.body=r.body),typeof r.type=="string"&&(o.type=r.type),Object.keys(o).length>0&&!await Fe.updateTask(t,s,o)?e.json({success:!1,error:"Task not found"},404):e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{return await Fe.removeTask(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/queue/:taskId/comments",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await e.req.json(),{content:o,author:i}=r;if(!o?.trim())return e.json({error:"Content required"},400);let a=fr.addComment(t,s,o.trim(),i);return e.json({comment:a})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/queue/:taskId/comments/:commentId",async e=>{let t=e.req.param("id"),s=e.req.param("commentId");try{let r=await e.req.json(),{content:o}=r;return o?.trim()?fr.updateComment(t,s,o.trim())?e.json({success:!0}):e.json({error:"Not found"},404):e.json({error:"Content required"},400)}catch(r){return e.json({error:String(r)},500)}}),n.delete("/projects/:id/queue/:taskId/comments/:commentId",e=>{let t=e.req.param("id"),s=e.req.param("commentId");try{return fr.deleteComment(t,s),e.json({success:!0})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/ideas/:ideaId",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{let r=await e.req.json().catch(()=>({})),{priority:o,tags:i}=r;if(o){if(!["low","medium","high"].includes(o))return e.json({success:!1,error:"Invalid priority"},400);await Le.setPriority(t,s,o)}if(i&&Array.isArray(i)){let a=i.filter(c=>typeof c=="string").slice(0,20);a.length>0&&await Le.addTags(t,s,a)}return e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id/ideas/:ideaId",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{return await Le.removeIdea(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/ideas/:ideaId/archive",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{return await Le.archive(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.patch("/projects/:id/task",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),{description:r,type:o,branch:i}=s,a={};return r&&typeof r=="string"&&(a.description=r),o&&typeof o=="string"&&(a.type=o),i&&typeof i=="string"&&(a.branch=i),Object.keys(a).length===0?e.json({success:!1,error:"No valid fields to update"},400):await D.updateCurrentTask(t,a)?e.json({success:!0}):e.json({success:!1,error:"No active task"},400)}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.patch("/projects/:id",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),{name:r,description:o,stack:i,techStack:a,repoPath:c}=s,u=$.getGlobalProjectPath(t),d=Ea.join(u,"project.json"),m={};try{let p=await Ut.readFile(d,"utf-8");m=JSON.parse(p)}catch{m={projectId:t}}return r!==void 0&&(m.name=r),o!==void 0&&(m.description=o),i!==void 0&&(m.stack=i),a!==void 0&&(m.techStack=a),c!==void 0&&(m.repoPath=c),await Ut.mkdir(Ea.dirname(d),{recursive:!0}),await Ut.writeFile(d,JSON.stringify(m,null,2)),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id",async e=>{let t=e.req.param("id");try{C.close(t);let s=$.getGlobalProjectPath(t);return await Ut.rm(s,{recursive:!0,force:!0}),e.json({success:!0})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.get("/projects/:id/workflow-graph",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"workflow-graph");return e.json({edges:s?.edges||[]})}catch{return e.json({edges:[]})}}),n.put("/projects/:id/workflow-graph",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{edges:r}=s;return C.setDoc(t,"workflow-graph",{edges:r||[]}),e.json({success:!0})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.get("/projects/:id/workflows",e=>{let t=e.req.param("id");try{let s=xe.getAllWorkflows(t),r=ee.getAllRules(t);return e.json({workflows:s,rules:r})}catch{return e.json({workflows:[],rules:[]})}}),n.patch("/projects/:id/workflows/:name",async e=>{let{id:t,name:s}=e.req.param();try{let r=await e.req.json().catch(()=>({})),{enabled:o}=r,i=xe.getWorkflow(t,s);return i?(xe.updateWorkflow(t,s,{enabled:o??!i.enabled}),e.json({success:!0})):e.json({success:!1,error:"Workflow not found"},404)}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.post("/projects/:id/workflow-rules",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{type:r,command:o,position:i,action:a,description:c,enabled:u,timeoutMs:d}=s,m=ee.addRule(t,{type:r,command:o,position:i,action:a,description:c||null,enabled:u??!0,timeoutMs:d??3e4,createdAt:new Date().toISOString(),sortOrder:0});return e.json({success:!0,id:m})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.patch("/projects/:id/workflow-rules/:ruleId",async e=>{let t=e.req.param("id"),s=Number(e.req.param("ruleId"));try{let r=await e.req.json();return ee.updateRule(t,s,r),e.json({success:!0})}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.delete("/projects/:id/workflow-rules/:ruleId",e=>{let t=e.req.param("id"),s=Number(e.req.param("ruleId"));try{return ee.removeRule(t,s),e.json({success:!0})}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.get("/projects/:id/metrics",async e=>{let t=e.req.param("id");try{let s=await es.getSummary(t),r=await es.getDailyStats(t,90);return e.json({...s,dailyStats:r})}catch{return e.json({totalTokensSaved:0,avgCompressionRate:0,syncCount:0,dailyStats:[]})}}),n.get("/projects/:id/velocity",async e=>{let t=e.req.param("id");try{let s=await fo.getMetrics(t);return e.json(s)}catch{return e.json({averageVelocity:0,velocityTrend:"stable",sprints:[]})}}),n.get("/projects/:id/analysis/full",e=>{let t=e.req.param("id");try{let s=uo.getActive(t),r=uo.getHistory(t,10);return e.json({analysis:s,history:r})}catch{return e.json({analysis:null,history:[]})}}),n.get("/projects/:id/index",async e=>{let t=e.req.param("id");try{let s=await wr.readIndex(t),r=await wr.readDomains(t),o=await wr.readScores(t),i=await wr.readCategories(t);return e.json({index:s,domains:r,scores:o?.slice(0,100),categories:i})}catch{return e.json({index:null,domains:null,scores:[],categories:null})}}),n.get("/projects/:id/archives",e=>{let t=e.req.param("id"),s=e.req.query("type")||void 0,r=Number(e.req.query("limit"))||50;try{let o=tt.getArchived(t,s,r),i=tt.getStats(t);return e.json({items:o,stats:i})}catch{return e.json({items:[],stats:{total:0,byType:{}}})}}),n.get("/projects/:id/context-health",e=>{let t=e.req.param("id");try{let s=ga.getSummary(t,30),r=ga.getTransitions(t,50);return e.json({summary:s,transitions:r})}catch{return e.json({summary:null,transitions:[]})}}),n.get("/projects/:id/context-feedback",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM context_feedback ORDER BY created_at DESC LIMIT 50");return e.json({feedback:s})}catch{return e.json({feedback:[]})}}),n.get("/projects/:id/state/full",async e=>{let t=e.req.param("id");try{let s=await D.read(t);return e.json(s)}catch{return e.json({currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""})}}),n.get("/projects/:id/events",e=>{let t=e.req.param("id"),s=Number(e.req.query("limit"))||100,r=Number(e.req.query("offset"))||0,o=e.req.query("type")||void 0;try{let i=o?C.query(t,"SELECT * FROM events WHERE type = ? ORDER BY timestamp DESC LIMIT ? OFFSET ?",o,s,r):C.query(t,"SELECT * FROM events ORDER BY timestamp DESC LIMIT ? OFFSET ?",s,r),a=C.get(t,"SELECT COUNT(*) as c FROM events");return e.json({events:i,total:a?.c||0,limit:s,offset:r})}catch{return e.json({events:[],total:0})}}),n.get("/projects/:id/memory",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM memory ORDER BY updated_at DESC LIMIT 200");return e.json({items:s})}catch{return e.json({items:[]})}}),n.get("/projects/:id/sessions",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM sessions ORDER BY started_at DESC LIMIT 50"),r=C.query(t,"SELECT * FROM agent_sessions ORDER BY started_at DESC LIMIT 50");return e.json({sessions:s,agentSessions:r})}catch{return e.json({sessions:[],agentSessions:[]})}}),n.get("/projects/:id/tasks",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM tasks ORDER BY started_at DESC LIMIT 100"),r=C.query(t,"SELECT * FROM subtasks ORDER BY sort_order ASC");return e.json({tasks:s,subtasks:r})}catch{return e.json({tasks:[],subtasks:[]})}}),n.get("/projects/:id/kv",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT key, value FROM kv_store ORDER BY key"),r={};for(let o of s)try{r[o.key]=JSON.parse(o.value)}catch{r[o.key]=o.value}return e.json(r)}catch{return e.json({})}}),n.get("/projects/:id/issues",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"issues");return e.json({issues:s?.issues||[]})}catch{return e.json({issues:[]})}}),n.get("/projects/:id/roadmap",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"roadmap");return e.json(s||{features:[],backlog:[]})}catch{return e.json({features:[],backlog:[]})}}),n.get("/projects/:id/config",async e=>{let t=e.req.param("id");try{let s=kr(t);return e.json(s||{projectId:t})}catch{return e.json({projectId:t})}}),n}var ay,gn,od=h(()=>{"use strict";Re();ms();qu();Vu();co();ce();pr();Ku();pn();go();mr();Ds();rt();va();mn();ay=$.getGlobalBasePath(),gn=Ea.join(ay,"projects");l(kr,"getProjectConfig");l(Ta,"calculateDuration");l(rd,"createExtendedRoutes")});import{streamSSE as cy}from"hono/streaming";function ad(){let n=new Map,e=null;function t(o){let i=n.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),n.delete(o))}l(t,"removeClient");function s(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of n)o-new Date(a.client.connectedAt).getTime()>id&&t(i)},ly),e&&typeof e=="object"&&"unref"in e&&e.unref())}l(s,"startReaper");function r(){e&&(clearInterval(e),e=null)}return l(r,"stopReaper"),s(),{handleConnection(o){return cy(o,async i=>{let a=crypto.randomUUID(),c=new Date().toISOString(),u=new AbortController,d={id:a,connectedAt:c,send:l((g,y)=>{i.writeSSE({event:g,data:JSON.stringify(y)})},"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)}},uy),p=setTimeout(()=>{t(a)},id);typeof m=="object"&&"unref"in m&&m.unref(),typeof p=="object"&&"unref"in p&&p.unref(),n.set(a,{client:d,heartbeatInterval:m,ttlTimeout:p,abortController:u}),await i.writeSSE({event:"connected",data:JSON.stringify({clientId:a,timestamp: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 n)try{u.client.send(o,a)}catch{t(c)}},getClientCount(){return n.size},shutdown(){r();for(let o of[...n.keys()])t(o)}}}var id,ly,uy,cd=h(()=>{"use strict";id=60*60*1e3,ly=5*60*1e3,uy=3e4;l(ad,"createSSEManager")});var ld={};W(ld,{DEFAULT_PORT:()=>yo,createServer:()=>ho,startServer:()=>fy});import Ca from"node:fs";import hs from"node:path";import{Hono as dy}from"hono";import{cors as py}from"hono/cors";import{logger as my}from"hono/logger";import{secureHeaders as gy}from"hono/secure-headers";function ho(n){let e=new dy,t=ad();e.use("*",gy()),n.enableCors!==!1&&e.use("*",py({origin:l(c=>{if(!c)return c;try{let u=new URL(c);return u.hostname==="localhost"||u.hostname==="127.0.0.1"?c:null}catch{return null}},"origin"),allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type"]})),n.enableLogging!==!1&&e.use("*",my()),e.get("/health",c=>c.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/api",c=>c.json({name:"prjct-cli",version:ae,projectId:n.projectId,endpoints:{health:"/health",state:"/api/state",queue:"/api/queue",ideas:"/api/ideas",roadmap:"/api/roadmap",shipped:"/api/shipped",events:"/api/events",projects:"/api/projects",projectFull:"/api/projects/:id/full",statusBarCompact:"/api/status-bar/compact",globalStats:"/api/stats/global"}}));let s=Wu(n.projectId,n.projectPath);e.route("/api",s);let r=rd();e.route("/api",r),e.get("/api/events",c=>t.handleConnection(c));let i=[hs.resolve(__dirname,"..","dist","web"),hs.resolve(__dirname,"..","..","dist","web"),hs.resolve(process.cwd(),"dist","web"),hs.resolve(__dirname,"..","web")].find(c=>Ca.existsSync(hs.join(c,"index.html")))||null;if(i){let c={".html":"text/html",".js":"application/javascript",".css":"text/css",".json":"application/json",".svg":"image/svg+xml",".png":"image/png",".ico":"image/x-icon",".woff2":"font/woff2"};e.get("/assets/*",async u=>{let d=hs.join(i,u.req.path);try{let m=Ca.readFileSync(d),p=hs.extname(d);return new Response(m,{headers:{"Content-Type":c[p]||"application/octet-stream","Cache-Control":"public, max-age=31536000, immutable"}})}catch{return u.notFound()}}),e.get("*",u=>{if(u.req.path.startsWith("/api"))return u.notFound();try{let d=Ca.readFileSync(hs.join(i,"index.html"),"utf-8");return u.html(d)}catch{return u.json({error:"Dashboard not built. Run: cd web && bun run build"},404)}})}let a=null;return{app:e,async start(){let c=n.port,u=n.host||"0.0.0.0";if(Rs())a=Bun.serve({port:c,hostname:u,fetch:e.fetch});else{let{serve:d}=await import("@hono/node-server"),m=d({fetch:e.fetch,port:c,hostname:u});a={stop:l(()=>m.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${u}:${c}`),console.log(` Project: ${n.projectId}`),console.log(` Runtime: ${Rs()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${c}`)},stop(){t.shutdown(),a&&(a.stop(),a=null,console.log("Server stopped"))},broadcast(c,u){t.broadcast(c,u)}}}async function fy(n,e,t=yo){let s=ho({port:t,projectId:n,projectPath:e});return await s.start(),s}var yo,Pa=h(()=>{"use strict";tr();ze();Gu();od();cd();l(ho,"createServer");yo=3478;l(fy,"startServer")});import Ns from"chalk";var ud,hy,yy,Rt,dd=h(()=>{"use strict";We();ud=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],hy=80,yy={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:ud,speed:hy},cli:{header:l(()=>`${Ns.cyan.bold("\u26A1")} ${Ns.cyan("prjct")}`,"header"),footer:l(()=>Ns.dim("\u26A1 prjct"),"footer"),spin:l((n,e)=>`${Ns.cyan("\u26A1")} ${Ns.cyan("prjct")} ${Ns.cyan(ud[n%10])} ${Ns.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((n="claude")=>Kr(n).commitFooter,"getCommitFooter"),getSignature:l((n="claude")=>Kr(n).signature,"getSignature")},Rt=yy});function fn(n){let e=`PRJCT_TIMEOUT_${n}`,t=process.env[e];if(t){let s=Number.parseInt(t,10);if(!Number.isNaN(s)&&s>0)return s}return wy[n]}var wy,kt,wo=h(()=>{"use strict";wy={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};l(fn,"getTimeout");kt={SPINNER_MSG:45,DONE_MSG:50,FAIL_MSG:65,WARN_MSG:65,STEP_MSG:35,PROGRESS_TEXT:25,ISSUE_TITLE:50,FALLBACK_TRUNCATE:50,CLEAR_WIDTH:80}});var pd,md=h(()=>{"use strict";pd={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 vr(n,e){return{...pd[n],...e}}function ko(n,e,t){return{message:n,hint:e,...t}}var vo=h(()=>{"use strict";md();l(vr,"getError");l(ko,"createError")});var fd={};W(fd,{OUTPUT_TIERS:()=>gd,default:()=>f,formatForHuman:()=>by,getOutputTier:()=>vy,getTierConfig:()=>bo,limitLines:()=>So,setOutputTier:()=>ky,setQuietMode:()=>Sy});import ne from"chalk";function ky(n){yn=n}function vy(){return yn}function bo(){return gd[yn]}function Sy(n){ot=n}function So(n,e){let t=e??bo().maxLines;if(t===1/0||t===0)return n;let s=n.split(`
500
+ 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}}},ha=new fa});var ya,xe,lo=h(()=>{"use strict";ce();ya=class{static{l(this,"CustomWorkflowStorage")}createWorkflow(e,t){let s=new Date().toISOString();L.run(e,`INSERT INTO custom_workflows (name, description, created_at, updated_at, is_builtin, enabled, metadata)
501
+ VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,s,s,t.metadata?JSON.stringify(t.metadata):null);let r=L.get(e,"SELECT id FROM custom_workflows WHERE name = ?",t.name);if(!r)throw new Error(`Failed to create workflow: ${t.name}`);return r.id}getWorkflow(e,t){let s=L.get(e,"SELECT * FROM custom_workflows WHERE name = ?",t);return s?this.rowToWorkflow(s):null}getAllWorkflows(e,t=!1){let s=t?"SELECT * FROM custom_workflows ORDER BY is_builtin DESC, name ASC":"SELECT * FROM custom_workflows WHERE enabled = 1 ORDER BY is_builtin DESC, name ASC";return L.query(e,s).map(o=>this.rowToWorkflow(o))}updateWorkflow(e,t,s){if(!this.getWorkflow(e,t))return!1;let o=new Date().toISOString(),i=[],a=[];return s.description!==void 0&&(i.push("description = ?"),a.push(s.description)),s.enabled!==void 0&&(i.push("enabled = ?"),a.push(s.enabled?1:0)),s.metadata!==void 0&&(i.push("metadata = ?"),a.push(JSON.stringify(s.metadata))),i.length===0?!1:(i.push("updated_at = ?"),a.push(o),a.push(t),L.run(e,`UPDATE custom_workflows SET ${i.join(", ")} WHERE name = ?`,...a),!0)}deleteWorkflow(e,t){let s=this.getWorkflow(e,t);if(!s)return!1;if(s.isBuiltin)throw new Error(`Cannot delete built-in workflow: ${t}`);return L.run(e,"UPDATE custom_workflows SET enabled = 0 WHERE name = ?",t),!0}isBuiltin(e,t){return this.getWorkflow(e,t)?.isBuiltin??!1}isReservedName(e){let t=["task","done","ship","sync"],s=["add","rm","gate","list","create","delete","run","help","reset","init"];return t.includes(e)||s.includes(e)}isValidName(e){return/^[a-z0-9-]+$/.test(e)}rowToWorkflow(e){return{id:e.id,name:e.name,description:e.description,createdAt:e.created_at,updatedAt:e.updated_at,isBuiltin:e.is_builtin===1,enabled:e.enabled===1,metadata:e.metadata?JSON.parse(e.metadata):null}}},xe=new ya});import{createHash as Bu}from"node:crypto";function hr(n){return Bu("sha256").update(n).digest("hex")}function Ju(n){return hr(n).slice(0,16)}function zu(n){return Bu("md5").update(n).digest("hex")}var yr=h(()=>{"use strict";l(hr,"sha256");l(Ju,"sha256Short");l(zu,"md5")});import uo from"node:fs/promises";import Xu from"node:path";function sy(){return{version:dn,lastUpdated:"",checksums:{}}}var dn,wa,wr,Ku=h(()=>{"use strict";Re();V();be();yr();ce();dn="1.0.0";l(sy,"getDefaultChecksums");wa=class{static{l(this,"IndexStorage")}getIndexPath(e){return Xu.join($.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await uo.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==dn?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 sy()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await uo.readFile(e);return zu(t)}catch{return""}}async detectChangedFiles(e,t){let r=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[c,u]of t)c in r?r[c]!==u&&i.push(c):o.push(c);for(let c of Object.keys(r))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:dn,lastUpdated:R(),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 uo.readdir(t);await Promise.all(s.map(r=>uo.unlink(Xu.join(t,r))))}catch(s){if(!_(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!==dn?null:t}catch{}return null}readDomainsSync(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null&&t.version===dn)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!==dn?null:t}catch{}return null}async writeCategories(e,t){this.setIndexMeta(e,"categories-cache",t)}async getFileCategories(e,t){let s=await this.readCategories(e),r=new Map;if(!s)return r;let o=new Set(t);for(let i of s.fileCategories)o.has(i.path)&&r.set(i.path,i.categories);return r}async getFilesByDomain(e,t){let s=await this.readCategories(e);return s?s.domainIndex[t]||[]:[]}getIndexMeta(e,t){let r=C.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setIndexMeta(e,t,s){let r=C.getDb(e),o=JSON.stringify(s),i=new Date().toISOString();r.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},wr=new wa});var ka,po,wt,pn=h(()=>{"use strict";be();ce();ka=class{static{l(this,"LLMAnalysisStorage")}save(e,t){let s=C.getDb(e),r=R();s.transaction(()=>{s.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(r),s.prepare("INSERT INTO llm_analysis (commit_hash, status, analysis, analyzed_at) VALUES (?, ?, ?, ?)").run(t.commitHash??null,"active",JSON.stringify(t),t.analyzedAt)})()}getActive(e){let t=C.get(e,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");return t?JSON.parse(t.analysis):null}getActiveSummary(e){let t=this.getActive(e);return t?{commitHash:t.commitHash,architectureStyle:t.architecture.style,patternCount:t.patterns.length,antiPatternCount:t.antiPatterns.length,analyzedAt:t.analyzedAt}:null}isCurrent(e,t){return t?C.get(e,"SELECT commit_hash FROM llm_analysis WHERE status = 'active' LIMIT 1")?.commit_hash===t:!1}getAllFull(e){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, superseded_at, analysis FROM llm_analysis ORDER BY id DESC").map(s=>({id:s.id,status:s.status,commitHash:s.commit_hash,analyzedAt:s.analyzed_at,supersededAt:s.superseded_at,analysis:JSON.parse(s.analysis)}))}getHistory(e,t=10){return C.query(e,"SELECT id, commit_hash, status, analyzed_at, analysis FROM llm_analysis ORDER BY id DESC LIMIT ?",t).map(r=>{let o=JSON.parse(r.analysis);return{id:r.id,commitHash:r.commit_hash,status:r.status,analyzedAt:r.analyzed_at,patternCount:o.patterns.length}})}},po=new ka,wt=po});import{z as Ae}from"zod";function ed(n,e="default"){let t=Yu[e]||Yu.default;return n/1e3*t}function mo(n){return n<.01?`$${(n*100).toFixed(2)}\xA2`:`$${n.toFixed(2)}`}var ny,ry,Qu,Zu,Yu,go=h(()=>{"use strict";ny=Ae.object({date:Ae.string(),tokensSaved:Ae.number(),syncs:Ae.number(),avgCompressionRate:Ae.number(),totalDuration:Ae.number()}),ry=Ae.object({agentName:Ae.string(),usageCount:Ae.number(),tokensSaved:Ae.number()}),Qu=Ae.object({totalTokensSaved:Ae.number(),avgCompressionRate:Ae.number(),syncCount:Ae.number(),watchTriggers:Ae.number(),avgSyncDuration:Ae.number(),totalSyncDuration:Ae.number(),agentUsage:Ae.array(ry),dailyStats:Ae.array(ny),firstSync:Ae.string(),lastUpdated:Ae.string()}),Zu={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},Yu={"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(ed,"estimateCostSaved");l(mo,"formatCost")});var va,ts,fo=h(()=>{"use strict";go();be();fs();va=class extends Xe{static{l(this,"MetricsStorage")}constructor(){super("metrics.json",Qu)}getDefault(){return{...Zu}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let s=Math.max(0,t.originalSize-t.filteredSize),r=t.originalSize>0?s/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,c=i.totalTokensSaved+s,u=i.totalSyncDuration+t.duration,d=i.syncCount===0?r:(i.avgCompressionRate*i.syncCount+r)/a,m=[...i.dailyStats],p=m.findIndex(x=>x.date===o);if(p>=0){let x=m[p];m[p]={...x,tokensSaved:x.tokensSaved+s,syncs:x.syncs+1,avgCompressionRate:(x.avgCompressionRate*x.syncs+r)/(x.syncs+1),totalDuration:x.totalDuration+t.duration}}else m.push({date:o,tokensSaved:s,syncs:1,avgCompressionRate:r,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let y=g.toISOString().split("T")[0],j=m.filter(x=>x.date>=y),T=[...i.agentUsage];if(t.agents)for(let x of t.agents){let S=T.findIndex(w=>w.agentName===x);S>=0?T[S]={...T[S],usageCount:T[S].usageCount+1,tokensSaved:T[S].tokensSaved+Math.floor(s/t.agents.length)}:T.push({agentName:x,usageCount:1,tokensSaved:Math.floor(s/t.agents.length)})}return{totalTokensSaved:c,avgCompressionRate:d,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:T,dailyStats:j,firstSync:i.firstSync||R(),lastUpdated:R()}})}async getSummary(e){let t=await this.read(e),s=this.getLast30Days(t.dailyStats),r=this.getPrev30Days(t.dailyStats),o=s.reduce((c,u)=>c+u.tokensSaved,0),i=r.reduce((c,u)=>c+u.tokensSaved,0),a=i>0?(o-i)/i*100:0;return{totalTokensSaved:t.totalTokensSaved,estimatedCostSaved:ed(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),r=new Date;r.setDate(r.getDate()-t);let o=r.toISOString().split("T")[0];return s.dailyStats.filter(i=>i.date>=o).sort((i,a)=>i.date.localeCompare(a.date))}getLast30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=t.toISOString().split("T")[0];return e.filter(r=>r.date>=s)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let s=new Date;s.setDate(s.getDate()-60);let r=s.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=r&&i.date<o)}},ts=new va});import{z as pe}from"zod";var oy,iy,td,kj,vj,Sj,sd,nd=h(()=>{"use strict";oy=pe.enum(["improving","stable","declining"]),iy=pe.object({sprintNumber:pe.number(),startDate:pe.string(),endDate:pe.string(),pointsCompleted:pe.number(),tasksCompleted:pe.number(),avgVariance:pe.number(),estimationAccuracy:pe.number()}),td=pe.object({category:pe.string(),avgVariance:pe.number(),taskCount:pe.number()}),kj=pe.object({totalPoints:pe.number(),sprints:pe.number(),estimatedDate:pe.string()}),vj=pe.object({sprints:pe.array(iy),averageVelocity:pe.number(),velocityTrend:oy,estimationAccuracy:pe.number(),overEstimated:pe.array(td),underEstimated:pe.array(td),lastUpdated:pe.string()}),Sj=pe.object({sprintLengthDays:pe.number().min(1).max(90).default(7),startDay:pe.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:pe.number().min(1).max(52).default(6),accuracyTolerance:pe.number().min(0).max(100).default(20)}),sd={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var Sa,ho,ba=h(()=>{"use strict";nd();fs();Sa=class extends Xe{static{l(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:sd,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}},ho=new Sa});function Ta(n){let e=n.trust_source==="imported"?"imported":"local";return{id:n.id,type:n.type,command:n.command,position:n.position,action:n.action,description:n.description,enabled:n.enabled===1,timeoutMs:n.timeout_ms,createdAt:n.created_at,sortOrder:n.sort_order,whenExpr:n.when_expr??null,parallel:n.parallel===null?!0:n.parallel===1,trustSource:e}}var Ea,ee,mn=h(()=>{"use strict";lo();ce();l(Ta,"rowToRule");Ea=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),r=t.sortOrder||(s?.m??-1)+1;return C.run(e,`INSERT INTO workflow_rules (type, command, position, action, description, enabled, timeout_ms, created_at, sort_order, when_expr, parallel, trust_source)
502
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,r,t.whenExpr??null,t.parallel===!1?0:1,t.trustSource??"local"),C.get(e,"SELECT last_insert_rowid() as id")?.id??0}removeRule(e,t){return C.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t)?(C.run(e,"DELETE FROM workflow_rules WHERE id = ?",t),!0):!1}updateRule(e,t,s){if(!C.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t))return!1;let o={type:{column:"type"},command:{column:"command"},position:{column:"position"},action:{column:"action"},description:{column:"description"},enabled:{column:"enabled",transform:l(c=>c?1:0,"transform")},timeoutMs:{column:"timeout_ms"},createdAt:{column:"created_at"},sortOrder:{column:"sort_order"},whenExpr:{column:"when_expr"},parallel:{column:"parallel",transform:l(c=>c===!1?0:1,"transform")},trustSource:{column:"trust_source"}},i=[],a=[];for(let[c,u]of Object.entries(s)){let d=o[c];if(!d)continue;i.push(`${d.column} = ?`);let m=u;a.push(d.transform?d.transform(m):m)}return i.length===0||(a.push(t),C.run(e,`UPDATE workflow_rules SET ${i.join(", ")} WHERE id = ?`,...a)),!0}getRuleById(e,t){let s=C.get(e,"SELECT * FROM workflow_rules WHERE id = ?",t);return s?Ta(s):null}getRulesForCommand(e,t){let s=xe.getWorkflow(e,t);return!s||!s.enabled?[]:C.query(e,"SELECT * FROM workflow_rules WHERE command = ? AND enabled = 1 ORDER BY sort_order ASC",t).map(Ta)}getAllRules(e){return C.query(e,"SELECT * FROM workflow_rules ORDER BY command ASC, sort_order ASC").map(Ta)}resetRules(e){let t=C.get(e,"SELECT COUNT(*) as c FROM workflow_rules");return C.run(e,"DELETE FROM workflow_rules"),t?.c??0}},ee=new Ea});import Ut from"node:fs/promises";import Pa from"node:path";import{Hono as ay}from"hono";function kr(n){return C.getDoc(n,"project")}async function Ca(n){if(!n)return"";let e=new Date(n),s=new Date().getTime()-e.getTime(),r=Math.floor(s/(1e3*60*60)),o=Math.floor(s%(1e3*60*60)/(1e3*60));return r>0?`${r}h ${o}m`:`${o}m`}function rd(){let n=new ay;return n.get("/projects",async e=>{try{await Ut.mkdir(gn,{recursive:!0});let s=(await Ut.readdir(gn,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),r=await Promise.all(s.map(async o=>{let i=kr(o),a=await D.read(o),c=await Fe.read(o),u=await Le.read(o),d=await Ke.read(o),m=a?.currentTask,p=await Ca(m?.startedAt),g=i;return{id:o,name:g?.name||o.slice(0,8),path:g?.repoPath||g?.path||null,stack:g?.stack||null,branch:g?.currentBranch||null,fileCount:g?.fileCount||null,lastSync:g?.lastSync||null,version:g?.version||null,currentTask:m?{...m,duration:p}:null,pausedTask:a?.previousTask||null,stats:{queueCount:c?.tasks?.filter(y=>!y.completed)?.length||0,ideasCount:u?.ideas?.filter(y=>y.status==="pending")?.length||0,shippedCount:d?.shipped?.length||0,tasksToday:0,tasksThisWeek:0}}}));return r.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:String(o.name||"").localeCompare(String(i.name||""))),e.json({projects:r})}catch{return e.json({projects:[],error:"Internal server error"},500)}}),n.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[s,r,o,i,a]=await Promise.all([Promise.resolve(kr(t)),D.read(t),Fe.read(t),Le.read(t),Ke.read(t)]),c=C.getDoc(t,"roadmap");r?.currentTask?.startedAt&&(r.currentTask.duration=await Ca(r.currentTask.startedAt));let u=new Date,d=new Date(u.getFullYear(),u.getMonth(),u.getDate()),m=new Date(d);m.setDate(m.getDate()-m.getDay());let p=o?.tasks?.filter(j=>!j.completed||!j.completedAt?!1:new Date(j.completedAt)>=d)?.length||0,g=o?.tasks?.filter(j=>!j.completed||!j.completedAt?!1:new Date(j.completedAt)>=m)?.length||0,y=null;try{let j=C.get(t,"SELECT analysis FROM llm_analysis WHERE status = 'active' LIMIT 1");if(j){let T=JSON.parse(j.analysis);y={architecture:T.architecture,patterns:(T.patterns||[]).slice(0,6),antiPatterns:(T.antiPatterns||[]).slice(0,4),techDebt:(T.techDebt||[]).slice(0,4),conventions:T.conventions,stack:T.stack,analyzedAt:T.analyzedAt,commitHash:T.commitHash}}}catch{}return e.json({id:t,name:s?.name||t,path:s?.path,state:r||{currentTask:null,previousTask:null,lastUpdated:""},queue:o||{tasks:[],lastUpdated:""},ideas:i||{ideas:[],lastUpdated:""},shipped:a||{shipped:[],lastUpdated:""},roadmap:c||{features:[],backlog:[],lastUpdated:""},analysis:y,stats:{tasksToday:p,tasksThisWeek:g,queueCount:o?.tasks?.filter(j=>!j.completed)?.length||0,ideasCount:i?.ideas?.filter(j=>j.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let s=await D.read(t);if(!s?.currentTask)return e.json({success:!1,error:"No active task"},400);let r=s.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await D.write(t,o),e.json({success:!0,completedTask:r,message:`Completed: ${r.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),r=typeof s.reason=="string"?s.reason.slice(0,500):void 0,o=await D.read(t);if(!o?.currentTask)return e.json({success:!1,error:"No active task"},400);let i={id:o.currentTask.id,description:o.currentTask.description,status:"paused",startedAt:o.currentTask.startedAt,pausedAt:new Date().toISOString(),pauseReason:r},a={currentTask:null,previousTask:i,lastUpdated:new Date().toISOString()};return await D.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let s=await D.read(t);if(!s?.previousTask)return e.json({success:!1,error:"No paused task"},400);let r={id:s.previousTask.id,description:s.previousTask.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`},o={currentTask:r,previousTask:null,lastUpdated:new Date().toISOString()};return await D.write(t,o),e.json({success:!0,resumedTask:r,message:`Resumed: ${r.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{taskId:r}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"taskId required (string)"},400);if(r.length>200)return e.json({success:!1,error:"taskId too long"},400);let[o,i]=await Promise.all([D.read(t),Fe.read(t)]);if(o?.currentTask)return e.json({success:!1,error:"Complete or pause current task first"},400);let a=i?.tasks?.find(d=>d.id===r);if(!a)return e.json({success:!1,error:"Task not found in queue"},404);let 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 D.write(t,u),e.json({success:!0,task:c,message:`Started: ${c.description}`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{text:r,priority:o="medium",tags:i=[]}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"text required (string)"},400);if(r.length>5e3)return e.json({success:!1,error:"text too long (max 5000 chars)"},400);let c=["low","medium","high","critical"].includes(o)?o:"medium",u=Array.isArray(i)?i.filter(m=>typeof m=="string").slice(0,20):[],d=await Le.addIdea(t,r,{priority:c,tags:u});return e.json({success:!0,idea:d,message:`Captured: ${r.slice(0,50)}...`})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.get("/stats/global",async e=>{try{await Ut.mkdir(gn,{recursive:!0});let s=(await Ut.readdir(gn,{withFileTypes:!0})).filter(c=>c.isDirectory()).map(c=>c.name),r=0,o=0,i=0,a=0;for(let c of s){let u=await D.read(c),d=await Fe.read(c),m=await Le.read(c),p=await Ke.read(c);u?.currentTask&&a++,r+=d?.tasks?.filter(g=>!g.completed)?.length||0,o+=m?.ideas?.filter(g=>g.status==="pending")?.length||0,i+=p?.shipped?.length||0}return e.json({totalProjects:s.length,activeProjects:a,totalTasks:r,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await Ut.mkdir(gn,{recursive:!0});let r=(await Ut.readdir(gn,{withFileTypes:!0})).filter(d=>d.isDirectory()).map(d=>d.name),o=null;if(t)for(let d of r){let m=kr(d),p=m?.repoPath||m?.path;if(p&&t.startsWith(p)){o=d;break}}let i=null,a=null,c=null,u=o?[o]:r;for(let d of u){let m=await D.read(d),p=kr(d);if(m?.currentTask){i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},a={...m.currentTask,duration:await Ca(m.currentTask.startedAt)};break}m?.previousTask&&!c&&(i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},c=m.previousTask)}return e.json({hasActiveTask:!!a,hasPausedTask:!!c,activeProject:i,activeTask:a,pausedTask:c,totalProjects:r.length,filtered:!!o,cwd:t||null,timestamp:new Date().toISOString()})}catch{return e.json({error:"Internal server error"},500)}}),n.post("/projects/:id/queue",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{description:r,priority:o,type:i,section:a}=s;if(!r||typeof r!="string")return e.json({success:!1,error:"description required (string)"},400);if(r.length>5e3)return e.json({success:!1,error:"description too long (max 5000 chars)"},400);let c=await Fe.addTask(t,{description:r,priority:o||"medium",type:i||"feature",section:a||"active"});return e.json({success:!0,task:c})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.get("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await Fe.getTask(t,s);if(!r)return e.json({error:"Task not found"},404);let o=fr.getComments(t,s);return e.json({task:r,comments:o})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await e.req.json().catch(()=>({})),o={};if(r.priority&&typeof r.priority=="string"){if(!["low","medium","high","critical","normal","urgent"].includes(r.priority))return e.json({success:!1,error:"Invalid priority"},400);o.priority=r.priority}if(r.section&&typeof r.section=="string"){if(!["active","backlog","previously_active"].includes(r.section))return e.json({success:!1,error:"Invalid section"},400);o.section=r.section}return typeof r.description=="string"&&(o.description=r.description),typeof r.body=="string"&&(o.body=r.body),typeof r.type=="string"&&(o.type=r.type),Object.keys(o).length>0&&!await Fe.updateTask(t,s,o)?e.json({success:!1,error:"Task not found"},404):e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id/queue/:taskId",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{return await Fe.removeTask(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/queue/:taskId/comments",async e=>{let t=e.req.param("id"),s=e.req.param("taskId");try{let r=await e.req.json(),{content:o,author:i}=r;if(!o?.trim())return e.json({error:"Content required"},400);let a=fr.addComment(t,s,o.trim(),i);return e.json({comment:a})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/queue/:taskId/comments/:commentId",async e=>{let t=e.req.param("id"),s=e.req.param("commentId");try{let r=await e.req.json(),{content:o}=r;return o?.trim()?fr.updateComment(t,s,o.trim())?e.json({success:!0}):e.json({error:"Not found"},404):e.json({error:"Content required"},400)}catch(r){return e.json({error:String(r)},500)}}),n.delete("/projects/:id/queue/:taskId/comments/:commentId",e=>{let t=e.req.param("id"),s=e.req.param("commentId");try{return fr.deleteComment(t,s),e.json({success:!0})}catch(r){return e.json({error:String(r)},500)}}),n.patch("/projects/:id/ideas/:ideaId",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{let r=await e.req.json().catch(()=>({})),{priority:o,tags:i}=r;if(o){if(!["low","medium","high"].includes(o))return e.json({success:!1,error:"Invalid priority"},400);await Le.setPriority(t,s,o)}if(i&&Array.isArray(i)){let a=i.filter(c=>typeof c=="string").slice(0,20);a.length>0&&await Le.addTags(t,s,a)}return e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id/ideas/:ideaId",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{return await Le.removeIdea(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.post("/projects/:id/ideas/:ideaId/archive",async e=>{let t=e.req.param("id"),s=e.req.param("ideaId");try{return await Le.archive(t,s),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.patch("/projects/:id/task",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),{description:r,type:o,branch:i}=s,a={};return r&&typeof r=="string"&&(a.description=r),o&&typeof o=="string"&&(a.type=o),i&&typeof i=="string"&&(a.branch=i),Object.keys(a).length===0?e.json({success:!1,error:"No valid fields to update"},400):await D.updateCurrentTask(t,a)?e.json({success:!0}):e.json({success:!1,error:"No active task"},400)}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.patch("/projects/:id",async e=>{let t=e.req.param("id");try{let s=await e.req.json().catch(()=>({})),{name:r,description:o,stack:i,techStack:a,repoPath:c}=s,u=$.getGlobalProjectPath(t),d=Pa.join(u,"project.json"),m={};try{let p=await Ut.readFile(d,"utf-8");m=JSON.parse(p)}catch{m={projectId:t}}return r!==void 0&&(m.name=r),o!==void 0&&(m.description=o),i!==void 0&&(m.stack=i),a!==void 0&&(m.techStack=a),c!==void 0&&(m.repoPath=c),await Ut.mkdir(Pa.dirname(d),{recursive:!0}),await Ut.writeFile(d,JSON.stringify(m,null,2)),e.json({success:!0})}catch{return e.json({success:!1,error:"Internal server error"},500)}}),n.delete("/projects/:id",async e=>{let t=e.req.param("id");try{C.close(t);let s=$.getGlobalProjectPath(t);return await Ut.rm(s,{recursive:!0,force:!0}),e.json({success:!0})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.get("/projects/:id/workflow-graph",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"workflow-graph");return e.json({edges:s?.edges||[]})}catch{return e.json({edges:[]})}}),n.put("/projects/:id/workflow-graph",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{edges:r}=s;return C.setDoc(t,"workflow-graph",{edges:r||[]}),e.json({success:!0})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.get("/projects/:id/workflows",e=>{let t=e.req.param("id");try{let s=xe.getAllWorkflows(t),r=ee.getAllRules(t);return e.json({workflows:s,rules:r})}catch{return e.json({workflows:[],rules:[]})}}),n.patch("/projects/:id/workflows/:name",async e=>{let{id:t,name:s}=e.req.param();try{let r=await e.req.json().catch(()=>({})),{enabled:o}=r,i=xe.getWorkflow(t,s);return i?(xe.updateWorkflow(t,s,{enabled:o??!i.enabled}),e.json({success:!0})):e.json({success:!1,error:"Workflow not found"},404)}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.post("/projects/:id/workflow-rules",async e=>{let t=e.req.param("id");try{let s=await e.req.json(),{type:r,command:o,position:i,action:a,description:c,enabled:u,timeoutMs:d}=s,m=ee.addRule(t,{type:r,command:o,position:i,action:a,description:c||null,enabled:u??!0,timeoutMs:d??3e4,createdAt:new Date().toISOString(),sortOrder:0});return e.json({success:!0,id:m})}catch(s){return e.json({success:!1,error:String(s)},500)}}),n.patch("/projects/:id/workflow-rules/:ruleId",async e=>{let t=e.req.param("id"),s=Number(e.req.param("ruleId"));try{let r=await e.req.json();return ee.updateRule(t,s,r),e.json({success:!0})}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.delete("/projects/:id/workflow-rules/:ruleId",e=>{let t=e.req.param("id"),s=Number(e.req.param("ruleId"));try{return ee.removeRule(t,s),e.json({success:!0})}catch(r){return e.json({success:!1,error:String(r)},500)}}),n.get("/projects/:id/metrics",async e=>{let t=e.req.param("id");try{let s=await ts.getSummary(t),r=await ts.getDailyStats(t,90);return e.json({...s,dailyStats:r})}catch{return e.json({totalTokensSaved:0,avgCompressionRate:0,syncCount:0,dailyStats:[]})}}),n.get("/projects/:id/velocity",async e=>{let t=e.req.param("id");try{let s=await ho.getMetrics(t);return e.json(s)}catch{return e.json({averageVelocity:0,velocityTrend:"stable",sprints:[]})}}),n.get("/projects/:id/analysis/full",e=>{let t=e.req.param("id");try{let s=po.getActive(t),r=po.getHistory(t,10);return e.json({analysis:s,history:r})}catch{return e.json({analysis:null,history:[]})}}),n.get("/projects/:id/index",async e=>{let t=e.req.param("id");try{let s=await wr.readIndex(t),r=await wr.readDomains(t),o=await wr.readScores(t),i=await wr.readCategories(t);return e.json({index:s,domains:r,scores:o?.slice(0,100),categories:i})}catch{return e.json({index:null,domains:null,scores:[],categories:null})}}),n.get("/projects/:id/archives",e=>{let t=e.req.param("id"),s=e.req.query("type")||void 0,r=Number(e.req.query("limit"))||50;try{let o=st.getArchived(t,s,r),i=st.getStats(t);return e.json({items:o,stats:i})}catch{return e.json({items:[],stats:{total:0,byType:{}}})}}),n.get("/projects/:id/context-health",e=>{let t=e.req.param("id");try{let s=ha.getSummary(t,30),r=ha.getTransitions(t,50);return e.json({summary:s,transitions:r})}catch{return e.json({summary:null,transitions:[]})}}),n.get("/projects/:id/context-feedback",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM context_feedback ORDER BY created_at DESC LIMIT 50");return e.json({feedback:s})}catch{return e.json({feedback:[]})}}),n.get("/projects/:id/state/full",async e=>{let t=e.req.param("id");try{let s=await D.read(t);return e.json(s)}catch{return e.json({currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""})}}),n.get("/projects/:id/events",e=>{let t=e.req.param("id"),s=Number(e.req.query("limit"))||100,r=Number(e.req.query("offset"))||0,o=e.req.query("type")||void 0;try{let i=o?C.query(t,"SELECT * FROM events WHERE type = ? ORDER BY timestamp DESC LIMIT ? OFFSET ?",o,s,r):C.query(t,"SELECT * FROM events ORDER BY timestamp DESC LIMIT ? OFFSET ?",s,r),a=C.get(t,"SELECT COUNT(*) as c FROM events");return e.json({events:i,total:a?.c||0,limit:s,offset:r})}catch{return e.json({events:[],total:0})}}),n.get("/projects/:id/memory",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM memory ORDER BY updated_at DESC LIMIT 200");return e.json({items:s})}catch{return e.json({items:[]})}}),n.get("/projects/:id/sessions",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM sessions ORDER BY started_at DESC LIMIT 50"),r=C.query(t,"SELECT * FROM agent_sessions ORDER BY started_at DESC LIMIT 50");return e.json({sessions:s,agentSessions:r})}catch{return e.json({sessions:[],agentSessions:[]})}}),n.get("/projects/:id/tasks",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT * FROM tasks ORDER BY started_at DESC LIMIT 100"),r=C.query(t,"SELECT * FROM subtasks ORDER BY sort_order ASC");return e.json({tasks:s,subtasks:r})}catch{return e.json({tasks:[],subtasks:[]})}}),n.get("/projects/:id/kv",e=>{let t=e.req.param("id");try{let s=C.query(t,"SELECT key, value FROM kv_store ORDER BY key"),r={};for(let o of s)try{r[o.key]=JSON.parse(o.value)}catch{r[o.key]=o.value}return e.json(r)}catch{return e.json({})}}),n.get("/projects/:id/issues",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"issues");return e.json({issues:s?.issues||[]})}catch{return e.json({issues:[]})}}),n.get("/projects/:id/roadmap",e=>{let t=e.req.param("id");try{let s=C.getDoc(t,"roadmap");return e.json(s||{features:[],backlog:[]})}catch{return e.json({features:[],backlog:[]})}}),n.get("/projects/:id/config",async e=>{let t=e.req.param("id");try{let s=kr(t);return e.json(s||{projectId:t})}catch{return e.json({projectId:t})}}),n}var cy,gn,od=h(()=>{"use strict";Re();ms();qu();Vu();lo();ce();pr();Ku();pn();fo();mr();Ds();ot();ba();mn();cy=$.getGlobalBasePath(),gn=Pa.join(cy,"projects");l(kr,"getProjectConfig");l(Ca,"calculateDuration");l(rd,"createExtendedRoutes")});import{streamSSE as ly}from"hono/streaming";function ad(){let n=new Map,e=null;function t(o){let i=n.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),n.delete(o))}l(t,"removeClient");function s(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of n)o-new Date(a.client.connectedAt).getTime()>id&&t(i)},uy),e&&typeof e=="object"&&"unref"in e&&e.unref())}l(s,"startReaper");function r(){e&&(clearInterval(e),e=null)}return l(r,"stopReaper"),s(),{handleConnection(o){return ly(o,async i=>{let a=crypto.randomUUID(),c=new Date().toISOString(),u=new AbortController,d={id:a,connectedAt:c,send:l((g,y)=>{i.writeSSE({event:g,data:JSON.stringify(y)})},"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)}},dy),p=setTimeout(()=>{t(a)},id);typeof m=="object"&&"unref"in m&&m.unref(),typeof p=="object"&&"unref"in p&&p.unref(),n.set(a,{client:d,heartbeatInterval:m,ttlTimeout:p,abortController:u}),await i.writeSSE({event:"connected",data:JSON.stringify({clientId:a,timestamp: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 n)try{u.client.send(o,a)}catch{t(c)}},getClientCount(){return n.size},shutdown(){r();for(let o of[...n.keys()])t(o)}}}var id,uy,dy,cd=h(()=>{"use strict";id=60*60*1e3,uy=5*60*1e3,dy=3e4;l(ad,"createSSEManager")});var ld={};W(ld,{DEFAULT_PORT:()=>wo,createServer:()=>yo,startServer:()=>hy});import ja from"node:fs";import hs from"node:path";import{Hono as py}from"hono";import{cors as my}from"hono/cors";import{logger as gy}from"hono/logger";import{secureHeaders as fy}from"hono/secure-headers";function yo(n){let e=new py,t=ad();e.use("*",fy()),n.enableCors!==!1&&e.use("*",my({origin:l(c=>{if(!c)return c;try{let u=new URL(c);return u.hostname==="localhost"||u.hostname==="127.0.0.1"?c:null}catch{return null}},"origin"),allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type"]})),n.enableLogging!==!1&&e.use("*",gy()),e.get("/health",c=>c.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/api",c=>c.json({name:"prjct-cli",version:ae,projectId:n.projectId,endpoints:{health:"/health",state:"/api/state",queue:"/api/queue",ideas:"/api/ideas",roadmap:"/api/roadmap",shipped:"/api/shipped",events:"/api/events",projects:"/api/projects",projectFull:"/api/projects/:id/full",statusBarCompact:"/api/status-bar/compact",globalStats:"/api/stats/global"}}));let s=Wu(n.projectId,n.projectPath);e.route("/api",s);let r=rd();e.route("/api",r),e.get("/api/events",c=>t.handleConnection(c));let i=[hs.resolve(__dirname,"..","dist","web"),hs.resolve(__dirname,"..","..","dist","web"),hs.resolve(process.cwd(),"dist","web"),hs.resolve(__dirname,"..","web")].find(c=>ja.existsSync(hs.join(c,"index.html")))||null;if(i){let c={".html":"text/html",".js":"application/javascript",".css":"text/css",".json":"application/json",".svg":"image/svg+xml",".png":"image/png",".ico":"image/x-icon",".woff2":"font/woff2"};e.get("/assets/*",async u=>{let d=hs.join(i,u.req.path);try{let m=ja.readFileSync(d),p=hs.extname(d);return new Response(m,{headers:{"Content-Type":c[p]||"application/octet-stream","Cache-Control":"public, max-age=31536000, immutable"}})}catch{return u.notFound()}}),e.get("*",u=>{if(u.req.path.startsWith("/api"))return u.notFound();try{let d=ja.readFileSync(hs.join(i,"index.html"),"utf-8");return u.html(d)}catch{return u.json({error:"Dashboard not built. Run: cd web && bun run build"},404)}})}let a=null;return{app:e,async start(){let c=n.port,u=n.host||"0.0.0.0";if(Rs())a=Bun.serve({port:c,hostname:u,fetch:e.fetch});else{let{serve:d}=await import("@hono/node-server"),m=d({fetch:e.fetch,port:c,hostname:u});a={stop:l(()=>m.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${u}:${c}`),console.log(` Project: ${n.projectId}`),console.log(` Runtime: ${Rs()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${c}`)},stop(){t.shutdown(),a&&(a.stop(),a=null,console.log("Server stopped"))},broadcast(c,u){t.broadcast(c,u)}}}async function hy(n,e,t=wo){let s=yo({port:t,projectId:n,projectPath:e});return await s.start(),s}var wo,Ra=h(()=>{"use strict";tr();ze();Gu();od();cd();l(yo,"createServer");wo=3478;l(hy,"startServer")});import Ns from"chalk";var ud,yy,wy,Rt,dd=h(()=>{"use strict";We();ud=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],yy=80,wy={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:ud,speed:yy},cli:{header:l(()=>`${Ns.cyan.bold("\u26A1")} ${Ns.cyan("prjct")}`,"header"),footer:l(()=>Ns.dim("\u26A1 prjct"),"footer"),spin:l((n,e)=>`${Ns.cyan("\u26A1")} ${Ns.cyan("prjct")} ${Ns.cyan(ud[n%10])} ${Ns.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((n="claude")=>Yr(n).commitFooter,"getCommitFooter"),getSignature:l((n="claude")=>Yr(n).signature,"getSignature")},Rt=wy});function fn(n){let e=`PRJCT_TIMEOUT_${n}`,t=process.env[e];if(t){let s=Number.parseInt(t,10);if(!Number.isNaN(s)&&s>0)return s}return ky[n]}var ky,kt,ko=h(()=>{"use strict";ky={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};l(fn,"getTimeout");kt={SPINNER_MSG:45,DONE_MSG:50,FAIL_MSG:65,WARN_MSG:65,STEP_MSG:35,PROGRESS_TEXT:25,ISSUE_TITLE:50,FALLBACK_TRUNCATE:50,CLEAR_WIDTH:80}});var pd,md=h(()=>{"use strict";pd={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 vr(n,e){return{...pd[n],...e}}function vo(n,e,t){return{message:n,hint:e,...t}}var So=h(()=>{"use strict";md();l(vr,"getError");l(vo,"createError")});var fd={};W(fd,{OUTPUT_TIERS:()=>gd,default:()=>f,formatForHuman:()=>Ty,getOutputTier:()=>Sy,getTierConfig:()=>To,limitLines:()=>bo,setOutputTier:()=>vy,setQuietMode:()=>by});import ne from"chalk";function vy(n){yn=n}function Sy(){return yn}function To(){return gd[yn]}function by(n){it=n}function bo(n,e){let t=e??To().maxLines;if(t===1/0||t===0)return n;let s=n.split(`
503
503
  `);if(s.length<=t)return n;let r=s.slice(0,t),o=s.length-t;return`${r.join(`
504
504
  `)}
505
- ${ne.dim(`...${o} more lines`)}`}function by(n){let e=bo();if(yn==="silent")return"";if(yn==="verbose")return JSON.stringify(n,null,2);if(typeof n!="object"||n===null)return vt(String(n),e.maxCharsPerLine);let t=n;if("identifier"in t&&"title"in t){let o=[];return o.push(`${t.identifier}: ${vt(String(t.title),e.maxCharsPerLine-10)}`),t.status&&o.push(`Status: ${t.status}`),t.priority&&t.priority!=="none"&&o.push(`Priority: ${t.priority}`),t.url&&yn==="compact"&&o.push(ne.dim(String(t.url))),So(o.join(`
505
+ ${ne.dim(`...${o} more lines`)}`}function Ty(n){let e=To();if(yn==="silent")return"";if(yn==="verbose")return JSON.stringify(n,null,2);if(typeof n!="object"||n===null)return vt(String(n),e.maxCharsPerLine);let t=n;if("identifier"in t&&"title"in t){let o=[];return o.push(`${t.identifier}: ${vt(String(t.title),e.maxCharsPerLine-10)}`),t.status&&o.push(`Status: ${t.status}`),t.priority&&t.priority!=="none"&&o.push(`Priority: ${t.priority}`),t.url&&yn==="compact"&&o.push(ne.dim(String(t.url))),bo(o.join(`
506
506
  `),e.maxLines)}if("issues"in t&&Array.isArray(t.issues)){let o=t.issues,i=o.slice(0,e.maxLines).map(a=>{let c=a.priority&&a.priority!=="none"?` [${a.priority}]`:"";return`${a.identifier} ${vt(String(a.title),kt.ISSUE_TITLE)}${c}`});return o.length>e.maxLines&&i.push(ne.dim(`...${o.length-e.maxLines} more`)),i.join(`
507
- `)}let r=["id","name","title","status","message","success","error"].filter(o=>o in t);return r.length>0?So(r.map(o=>`${o}: ${vt(String(t[o]),e.maxCharsPerLine-o.length-2)}`).join(`
508
- `),e.maxLines):So(JSON.stringify(n,null,2),e.maxLines)}var PR,ja,gd,yn,Os,hn,Ra,ot,vt,Ty,Ey,f,Me=h(()=>{"use strict";dd();wo();vo();PR=Rt.spinner.frames,ja=Rt.spinner.speed,gd={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}},yn="compact";l(ky,"setOutputTier");l(vy,"getOutputTier");l(bo,"getTierConfig");Os={success:ne.green("\u2713"),fail:ne.red("\u2717"),warn:ne.yellow("\u26A0"),info:ne.blue("\u2139"),debug:ne.dim("\u{1F527}"),bullet:ne.dim("\u2022"),arrow:ne.dim("\u2192"),check:ne.green("\u2713"),cross:ne.red("\u2717"),spinner:ne.cyan("\u25D0")},hn=null,Ra=0,ot=!1;l(Sy,"setQuietMode");vt=l((n,e)=>{let t=e??(bo().maxCharsPerLine||kt.FALLBACK_TRUNCATE);return n&&n.length>t?`${n.slice(0,t-1)}\u2026`:n||""},"truncate");l(So,"limitLines");l(by,"formatForHuman");Ty=l(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(kt.CLEAR_WIDTH)}\r`):!0,"clear"),Ey={start(){return ot||console.log(Rt.cli.header()),this},end(){return ot||console.log(Rt.cli.footer()),this},spin(n){return ot?this:(this.stop(),process.stdout.isTTY?(hn=setInterval(()=>{process.stdout.write(`\r${Rt.cli.spin(Ra++,vt(n,kt.SPINNER_MSG))}`)},ja),this):(process.stdout.write(`${Rt.cli.spin(0,vt(n,kt.SPINNER_MSG))}
509
- `),this))},done(n,e){if(this.stop(),!ot){let t="";if(e){let s=[];e.agents!==void 0&&s.push(`${e.agents}a`),e.reduction!==void 0&&s.push(`${e.reduction}%`),e.tokens!==void 0&&s.push(`${Math.round(e.tokens)}K`),s.length>0&&(t=ne.dim(` [${s.join(" | ")}]`))}console.log(`${Os.success} ${vt(n,kt.DONE_MSG)}${t}`)}return this},fail(n){return this.stop(),console.error(`${Os.fail} ${vt(n,kt.FAIL_MSG)}`),this},failWithHint(n){this.stop();let e=typeof n=="string"?vr(n):n;return console.error(),console.error(`${Os.fail} ${e.message}`),e.file&&console.error(ne.dim(` File: ${e.file}`)),e.hint&&console.error(ne.yellow(` \u{1F4A1} ${e.hint}`)),e.docs&&console.error(ne.dim(` Docs: ${e.docs}`)),console.error(),this},warn(n){return this.stop(),ot||console.log(`${Os.warn} ${vt(n,kt.WARN_MSG)}`),this},info(n){return this.stop(),ot||console.log(`${Os.info} ${n}`),this},debug(n){this.stop();let e=process.env.DEBUG==="1"||process.env.DEBUG==="true";return!ot&&e&&console.log(`${Os.debug} ${ne.dim(n)}`),this},success(n,e){return this.done(n,e)},list(n,e={}){if(this.stop(),ot)return this;let t=e.bullet||Os.bullet,s=" ".repeat(e.indent||0);for(let r of n)console.log(`${s}${t} ${r}`);return this},table(n,e={}){if(this.stop(),ot||n.length===0)return this;let t=Object.keys(n[0]),s={};for(let r of t){s[r]=r.length;for(let o of n){let i=String(o[r]??"");i.length>s[r]&&(s[r]=i.length)}}if(e.header!==!1){let r=t.map(o=>o.padEnd(s[o])).join(" ");console.log(ne.dim(r)),console.log(ne.dim("\u2500".repeat(r.length)))}for(let r of n){let o=t.map(i=>String(r[i]??"").padEnd(s[i])).join(" ");console.log(o)}return this},box(n,e){if(this.stop(),ot)return this;let t=e.split(`
510
- `),s=Math.max(n.length,...t.map(o=>o.length)),r="\u2500".repeat(s+2);console.log(ne.dim(`\u250C${r}\u2510`)),console.log(`${ne.dim("\u2502")} ${ne.bold(n.padEnd(s))} ${ne.dim("\u2502")}`),console.log(ne.dim(`\u251C${r}\u2524`));for(let o of t)console.log(`${ne.dim("\u2502")} ${o.padEnd(s)} ${ne.dim("\u2502")}`);return console.log(ne.dim(`\u2514${r}\u2518`)),this},section(n){return this.stop(),ot?this:(console.log(`
511
- ${ne.bold(n)}`),console.log(ne.dim("\u2500".repeat(n.length))),this)},stop(){return hn&&(clearInterval(hn),hn=null,Ty()),this},step(n,e,t){if(ot)return this;this.stop();let s=ne.dim(`[${n}/${e}]`);return process.stdout.isTTY?(hn=setInterval(()=>{process.stdout.write(`\r${Rt.cli.spin(Ra++,`${s} ${vt(t,kt.STEP_MSG)}`)}`)},ja),this):(process.stdout.write(`${Rt.cli.spin(0,`${s} ${vt(t,kt.STEP_MSG)}`)}
512
- `),this)},progress(n,e,t){if(ot)return this;this.stop();let s=Math.round(n/e*100),r=Math.round(s/10),o=10-r,i=ne.cyan("\u2588".repeat(r))+ne.dim("\u2591".repeat(o)),a=t?` ${vt(t,kt.PROGRESS_TEXT)}`:"";return process.stdout.isTTY?(hn=setInterval(()=>{process.stdout.write(`\r${Rt.cli.spin(Ra++,`[${i}] ${s}%${a}`)}`)},ja),this):(process.stdout.write(`${Rt.cli.spin(0,`[${i}] ${s}%${a}`)}
513
- `),this)}},f=Ey});var wd={};W(wd,{default:()=>Py,sessionTracker:()=>wn});var hd,yd,xa,wn,Py,Aa=h(()=>{"use strict";Vr();ce();or();be();hd=50,yd=200,xa=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 sn(e.lastActivity,t)}async touch(e){let t=await this.read(e),s=R();if(t.current&&!this.isExpired(t.current,t.config.idleTimeoutMs))return t.current.lastActivity=s,await this.write(e,t),t.current;let r={id:crypto.randomUUID(),projectId:e,status:"active",createdAt:s,lastActivity:s,commands:[],files:[]};return t.current=r,await this.write(e,t),r}async trackCommand(e,t,s){let r=await this.read(e);if(!r.current)return;let o=R();r.current.lastActivity=o,r.current.commands.push({command:t,timestamp:o,durationMs:s}),r.current.commands.length>hd&&(r.current.commands=r.current.commands.slice(-hd)),await this.write(e,r)}async trackFile(e,t,s){let r=await this.read(e);if(!r.current)return;let o=R();r.current.lastActivity=o,r.current.files.push({path:t,operation:s,timestamp:o}),r.current.files.length>yd&&(r.current.files=r.current.files.slice(-yd)),await this.write(e,r)}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,r=Date.now(),o=new Date(s.createdAt).getTime(),i=new Date(s.lastActivity).getTime(),a=r-i,c=t.config.idleTimeoutMs,u=Math.max(0,c-a),d=s.commands.map(g=>g.command),m=new Set(s.files.filter(g=>g.operation==="read").map(g=>g.path)).size,p=new Set(s.files.filter(g=>g.operation==="write").map(g=>g.path)).size;return{active:!0,id:s.id,duration:cr(r-o),idleSince:s.lastActivity,idleMs:a,expiresIn:cr(u),commandCount:s.commands.length,commands:d,filesRead:m,filesWritten:p}}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}},wn=new xa,Py=wn});var vd={};W(vd,{default:()=>Sr,performanceTracker:()=>kd});var jy,Ia,kd,Sr,$a=h(()=>{"use strict";ce();jy=BigInt(5*60*1e9),Ia=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>jy&&this.marks.delete(t)}recordTiming(e,t,s,r){L.appendEvent(e,`perf.${t}`,{metric:t,value:Math.round(s*100)/100,unit:"ms",context:r})}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(),r=[{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 r)L.appendEvent(e,`perf.${o.metric}`,{metric:o.metric,value:o.value,unit:o.unit,context:t});return s}recordContextCorrectness(e,t){L.appendEvent(e,"perf.context_correctness",{metric:"context_correctness",...t})}recordSubtaskHandoff(e,t){L.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 L.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 r=this.getMetrics(e,s),o={period:`${t}d`},i=r.filter(p=>"metric"in p&&p.metric==="startup_time");if(i.length>0){let p=i.map(g=>g.value);o.startup={avg:Math.round(p.reduce((g,y)=>g+y,0)/p.length),min:Math.min(...p),max:Math.max(...p),count:p.length,unit:"ms"}}let a=r.filter(p=>"metric"in p&&p.metric==="heap_used"),c=r.filter(p=>"metric"in p&&p.metric==="rss");if(a.length>0){let p=l(j=>Math.round(j/1048576*10)/10,"toMB"),g=a.map(j=>j.value),y=c.map(j=>j.value);o.memory={avgHeapMB:p(g.reduce((j,T)=>j+T,0)/g.length),peakHeapMB:p(Math.max(...g)),avgRssMB:y.length>0?p(y.reduce((j,T)=>j+T,0)/y.length):0}}let u=r.filter(p=>"metric"in p&&p.metric==="context_correctness");if(u.length>0){let p=u.filter(g=>g.receivedSync).length;o.contextCorrectness={total:u.length,receivedSync:p,rate:Math.round(p/u.length*100)}}let d=r.filter(p=>"metric"in p&&p.metric==="subtask_handoff");if(d.length>0){let p=d.filter(g=>g.outputPopulated).length;o.subtaskHandoff={total:d.length,outputPopulated:p,rate:Math.round(p/d.length*100)}}let m=r.filter(p=>"metric"in p&&p.metric==="command_duration");if(m.length>0){let p={};for(let g of m){let y=g.context?.command||"unknown";p[y]||(p[y]=[]),p[y].push(g.value)}o.commandDurations={};for(let[g,y]of Object.entries(p))o.commandDurations[g]={avg:Math.round(y.reduce((j,T)=>j+T,0)/y.length),min:Math.min(...y),max:Math.max(...y),count:y.length,unit:"ms"}}return o}},kd=new Ia,Sr=kd});import St from"node:fs/promises";import xt from"node:path";var Da,Ry,Ue,Sd=h(()=>{"use strict";V();Ze();J();Da=class{static{l(this,"CodebaseAnalyzer")}projectPath=null;init(e=process.cwd()){this.projectPath=e}async readPackageJson(){try{let e=xt.join(this.projectPath,"package.json"),t=await St.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(_(e)||e instanceof SyntaxError)return null;throw e}}async readCargoToml(){try{let e=xt.join(this.projectPath,"Cargo.toml");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readRequirements(){try{let e=xt.join(this.projectPath,"requirements.txt");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readGoMod(){try{let e=xt.join(this.projectPath,"go.mod");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readGemfile(){try{let e=xt.join(this.projectPath,"Gemfile");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readMixExs(){try{let e=xt.join(this.projectPath,"mix.exs");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readPomXml(){try{let e=xt.join(this.projectPath,"pom.xml");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readComposerJson(){try{let e=xt.join(this.projectPath,"composer.json"),t=await St.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(_(e)||e instanceof SyntaxError)return null;throw e}}async readPyprojectToml(){try{let e=xt.join(this.projectPath,"pyproject.toml");return await St.readFile(e,"utf-8")}catch(e){if(_(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(`
507
+ `)}let r=["id","name","title","status","message","success","error"].filter(o=>o in t);return r.length>0?bo(r.map(o=>`${o}: ${vt(String(t[o]),e.maxCharsPerLine-o.length-2)}`).join(`
508
+ `),e.maxLines):bo(JSON.stringify(n,null,2),e.maxLines)}var jR,xa,gd,yn,Os,hn,Aa,it,vt,Ey,Cy,f,Me=h(()=>{"use strict";dd();ko();So();jR=Rt.spinner.frames,xa=Rt.spinner.speed,gd={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}},yn="compact";l(vy,"setOutputTier");l(Sy,"getOutputTier");l(To,"getTierConfig");Os={success:ne.green("\u2713"),fail:ne.red("\u2717"),warn:ne.yellow("\u26A0"),info:ne.blue("\u2139"),debug:ne.dim("\u{1F527}"),bullet:ne.dim("\u2022"),arrow:ne.dim("\u2192"),check:ne.green("\u2713"),cross:ne.red("\u2717"),spinner:ne.cyan("\u25D0")},hn=null,Aa=0,it=!1;l(by,"setQuietMode");vt=l((n,e)=>{let t=e??(To().maxCharsPerLine||kt.FALLBACK_TRUNCATE);return n&&n.length>t?`${n.slice(0,t-1)}\u2026`:n||""},"truncate");l(bo,"limitLines");l(Ty,"formatForHuman");Ey=l(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(kt.CLEAR_WIDTH)}\r`):!0,"clear"),Cy={start(){return it||console.log(Rt.cli.header()),this},end(){return it||console.log(Rt.cli.footer()),this},spin(n){return it?this:(this.stop(),process.stdout.isTTY?(hn=setInterval(()=>{process.stdout.write(`\r${Rt.cli.spin(Aa++,vt(n,kt.SPINNER_MSG))}`)},xa),this):(process.stdout.write(`${Rt.cli.spin(0,vt(n,kt.SPINNER_MSG))}
509
+ `),this))},done(n,e){if(this.stop(),!it){let t="";if(e){let s=[];e.agents!==void 0&&s.push(`${e.agents}a`),e.reduction!==void 0&&s.push(`${e.reduction}%`),e.tokens!==void 0&&s.push(`${Math.round(e.tokens)}K`),s.length>0&&(t=ne.dim(` [${s.join(" | ")}]`))}console.log(`${Os.success} ${vt(n,kt.DONE_MSG)}${t}`)}return this},fail(n){return this.stop(),console.error(`${Os.fail} ${vt(n,kt.FAIL_MSG)}`),this},failWithHint(n){this.stop();let e=typeof n=="string"?vr(n):n;return console.error(),console.error(`${Os.fail} ${e.message}`),e.file&&console.error(ne.dim(` File: ${e.file}`)),e.hint&&console.error(ne.yellow(` \u{1F4A1} ${e.hint}`)),e.docs&&console.error(ne.dim(` Docs: ${e.docs}`)),console.error(),this},warn(n){return this.stop(),it||console.log(`${Os.warn} ${vt(n,kt.WARN_MSG)}`),this},info(n){return this.stop(),it||console.log(`${Os.info} ${n}`),this},debug(n){this.stop();let e=process.env.DEBUG==="1"||process.env.DEBUG==="true";return!it&&e&&console.log(`${Os.debug} ${ne.dim(n)}`),this},success(n,e){return this.done(n,e)},list(n,e={}){if(this.stop(),it)return this;let t=e.bullet||Os.bullet,s=" ".repeat(e.indent||0);for(let r of n)console.log(`${s}${t} ${r}`);return this},table(n,e={}){if(this.stop(),it||n.length===0)return this;let t=Object.keys(n[0]),s={};for(let r of t){s[r]=r.length;for(let o of n){let i=String(o[r]??"");i.length>s[r]&&(s[r]=i.length)}}if(e.header!==!1){let r=t.map(o=>o.padEnd(s[o])).join(" ");console.log(ne.dim(r)),console.log(ne.dim("\u2500".repeat(r.length)))}for(let r of n){let o=t.map(i=>String(r[i]??"").padEnd(s[i])).join(" ");console.log(o)}return this},box(n,e){if(this.stop(),it)return this;let t=e.split(`
510
+ `),s=Math.max(n.length,...t.map(o=>o.length)),r="\u2500".repeat(s+2);console.log(ne.dim(`\u250C${r}\u2510`)),console.log(`${ne.dim("\u2502")} ${ne.bold(n.padEnd(s))} ${ne.dim("\u2502")}`),console.log(ne.dim(`\u251C${r}\u2524`));for(let o of t)console.log(`${ne.dim("\u2502")} ${o.padEnd(s)} ${ne.dim("\u2502")}`);return console.log(ne.dim(`\u2514${r}\u2518`)),this},section(n){return this.stop(),it?this:(console.log(`
511
+ ${ne.bold(n)}`),console.log(ne.dim("\u2500".repeat(n.length))),this)},stop(){return hn&&(clearInterval(hn),hn=null,Ey()),this},step(n,e,t){if(it)return this;this.stop();let s=ne.dim(`[${n}/${e}]`);return process.stdout.isTTY?(hn=setInterval(()=>{process.stdout.write(`\r${Rt.cli.spin(Aa++,`${s} ${vt(t,kt.STEP_MSG)}`)}`)},xa),this):(process.stdout.write(`${Rt.cli.spin(0,`${s} ${vt(t,kt.STEP_MSG)}`)}
512
+ `),this)},progress(n,e,t){if(it)return this;this.stop();let s=Math.round(n/e*100),r=Math.round(s/10),o=10-r,i=ne.cyan("\u2588".repeat(r))+ne.dim("\u2591".repeat(o)),a=t?` ${vt(t,kt.PROGRESS_TEXT)}`:"";return process.stdout.isTTY?(hn=setInterval(()=>{process.stdout.write(`\r${Rt.cli.spin(Aa++,`[${i}] ${s}%${a}`)}`)},xa),this):(process.stdout.write(`${Rt.cli.spin(0,`[${i}] ${s}%${a}`)}
513
+ `),this)}},f=Cy});var wd={};W(wd,{default:()=>jy,sessionTracker:()=>wn});var hd,yd,Ia,wn,jy,$a=h(()=>{"use strict";Vr();ce();or();be();hd=50,yd=200,Ia=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 sn(e.lastActivity,t)}async touch(e){let t=await this.read(e),s=R();if(t.current&&!this.isExpired(t.current,t.config.idleTimeoutMs))return t.current.lastActivity=s,await this.write(e,t),t.current;let r={id:crypto.randomUUID(),projectId:e,status:"active",createdAt:s,lastActivity:s,commands:[],files:[]};return t.current=r,await this.write(e,t),r}async trackCommand(e,t,s){let r=await this.read(e);if(!r.current)return;let o=R();r.current.lastActivity=o,r.current.commands.push({command:t,timestamp:o,durationMs:s}),r.current.commands.length>hd&&(r.current.commands=r.current.commands.slice(-hd)),await this.write(e,r)}async trackFile(e,t,s){let r=await this.read(e);if(!r.current)return;let o=R();r.current.lastActivity=o,r.current.files.push({path:t,operation:s,timestamp:o}),r.current.files.length>yd&&(r.current.files=r.current.files.slice(-yd)),await this.write(e,r)}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,r=Date.now(),o=new Date(s.createdAt).getTime(),i=new Date(s.lastActivity).getTime(),a=r-i,c=t.config.idleTimeoutMs,u=Math.max(0,c-a),d=s.commands.map(g=>g.command),m=new Set(s.files.filter(g=>g.operation==="read").map(g=>g.path)).size,p=new Set(s.files.filter(g=>g.operation==="write").map(g=>g.path)).size;return{active:!0,id:s.id,duration:cr(r-o),idleSince:s.lastActivity,idleMs:a,expiresIn:cr(u),commandCount:s.commands.length,commands:d,filesRead:m,filesWritten:p}}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}},wn=new Ia,jy=wn});var vd={};W(vd,{default:()=>Sr,performanceTracker:()=>kd});var Ry,Da,kd,Sr,Ma=h(()=>{"use strict";ce();Ry=BigInt(5*60*1e9),Da=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>Ry&&this.marks.delete(t)}recordTiming(e,t,s,r){L.appendEvent(e,`perf.${t}`,{metric:t,value:Math.round(s*100)/100,unit:"ms",context:r})}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(),r=[{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 r)L.appendEvent(e,`perf.${o.metric}`,{metric:o.metric,value:o.value,unit:o.unit,context:t});return s}recordContextCorrectness(e,t){L.appendEvent(e,"perf.context_correctness",{metric:"context_correctness",...t})}recordSubtaskHandoff(e,t){L.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 L.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 r=this.getMetrics(e,s),o={period:`${t}d`},i=r.filter(p=>"metric"in p&&p.metric==="startup_time");if(i.length>0){let p=i.map(g=>g.value);o.startup={avg:Math.round(p.reduce((g,y)=>g+y,0)/p.length),min:Math.min(...p),max:Math.max(...p),count:p.length,unit:"ms"}}let a=r.filter(p=>"metric"in p&&p.metric==="heap_used"),c=r.filter(p=>"metric"in p&&p.metric==="rss");if(a.length>0){let p=l(j=>Math.round(j/1048576*10)/10,"toMB"),g=a.map(j=>j.value),y=c.map(j=>j.value);o.memory={avgHeapMB:p(g.reduce((j,T)=>j+T,0)/g.length),peakHeapMB:p(Math.max(...g)),avgRssMB:y.length>0?p(y.reduce((j,T)=>j+T,0)/y.length):0}}let u=r.filter(p=>"metric"in p&&p.metric==="context_correctness");if(u.length>0){let p=u.filter(g=>g.receivedSync).length;o.contextCorrectness={total:u.length,receivedSync:p,rate:Math.round(p/u.length*100)}}let d=r.filter(p=>"metric"in p&&p.metric==="subtask_handoff");if(d.length>0){let p=d.filter(g=>g.outputPopulated).length;o.subtaskHandoff={total:d.length,outputPopulated:p,rate:Math.round(p/d.length*100)}}let m=r.filter(p=>"metric"in p&&p.metric==="command_duration");if(m.length>0){let p={};for(let g of m){let y=g.context?.command||"unknown";p[y]||(p[y]=[]),p[y].push(g.value)}o.commandDurations={};for(let[g,y]of Object.entries(p))o.commandDurations[g]={avg:Math.round(y.reduce((j,T)=>j+T,0)/y.length),min:Math.min(...y),max:Math.max(...y),count:y.length,unit:"ms"}}return o}},kd=new Da,Sr=kd});import St from"node:fs/promises";import xt from"node:path";var _a,xy,Ue,Sd=h(()=>{"use strict";V();Ze();J();_a=class{static{l(this,"CodebaseAnalyzer")}projectPath=null;init(e=process.cwd()){this.projectPath=e}async readPackageJson(){try{let e=xt.join(this.projectPath,"package.json"),t=await St.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(_(e)||e instanceof SyntaxError)return null;throw e}}async readCargoToml(){try{let e=xt.join(this.projectPath,"Cargo.toml");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readRequirements(){try{let e=xt.join(this.projectPath,"requirements.txt");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readGoMod(){try{let e=xt.join(this.projectPath,"go.mod");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readGemfile(){try{let e=xt.join(this.projectPath,"Gemfile");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readMixExs(){try{let e=xt.join(this.projectPath,"mix.exs");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readPomXml(){try{let e=xt.join(this.projectPath,"pom.xml");return await St.readFile(e,"utf-8")}catch(e){if(_(e))return null;throw e}}async readComposerJson(){try{let e=xt.join(this.projectPath,"composer.json"),t=await St.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(_(e)||e instanceof SyntaxError)return null;throw e}}async readPyprojectToml(){try{let e=xt.join(this.projectPath,"pyproject.toml");return await St.readFile(e,"utf-8")}catch(e){if(_(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(`
514
514
  `).filter(Boolean).forEach(s=>{let r=s.trim().match(/^\s*(\d+)\s+(\.\w+)$/);r&&(t[r[2]]=parseInt(r[1],10))}),t}catch{return{}}}async listConfigFiles(){try{let e=await St.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(r=>r.test(s)))}catch(e){if(_(e))return[];throw e}}async listDirectories(){try{return(await St.readdir(this.projectPath,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name).filter(t=>!t.startsWith(".")&&t!=="node_modules")}catch(e){if(_(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 b(xt.join(this.projectPath,e))}async readFile(e){try{let t=xt.join(this.projectPath,e);return await St.readFile(t,"utf-8")}catch(t){if(_(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(`
515
- `).filter(Boolean)}catch{return[]}}},Ry=new Da,Ue=Ry});var Oa={};W(Oa,{default:()=>Ny,getTemplateContent:()=>dt,listTemplates:()=>vn,resetBundle:()=>My});import _a from"node:fs";import xy from"node:fs/promises";import Eo from"node:path";function Na(){if(Ma)return To;Ma=!0;let n=Eo.join(jt,"dist","templates.json");try{let e=_a.readFileSync(n,"utf-8");return To=JSON.parse(e),To}catch{return null}}function Iy(n){let e=Ls.indexOf(n);e>-1&&Ls.splice(e,1),Ls.push(n)}function $y(){for(;kn.size>=Ay&&Ls.length>0;){let n=Ls.shift();n&&kn.delete(n)}}function bd(n){let e=/^---\n([\s\S]+?)\n---\n([\s\S]*)$/,t=n.match(e);if(!t)return{frontmatter:{},content:n.trim()};let[,s,r]=t,o={};return s.split(`
516
- `).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(d=>d.trim()):o[a.trim()]=u.replace(/^["']|["']$/g,"")}}),{frontmatter:o,content:r.trim()}}async function Td(n){if(kn.has(n))return Iy(n),kn.get(n);let e,t=Na();if(t){let r=`commands/${n}.md`;e=t[r]}if(!e){let r=Eo.join(jt,"templates","commands",`${n}.md`);try{e=await xy.readFile(r,"utf-8")}catch{throw Qr.notFound(n)}}let s=bd(e);return $y(),kn.set(n,s),Ls.push(n),s}async function Dy(n){return(await Td(n)).frontmatter["allowed-tools"]||[]}function Ed(){kn.clear(),Ls.length=0}function My(){To=null,Ma=!1,Ed()}function dt(n){let e=Na();if(e?.[n])return e[n];let t=Eo.join(jt,"templates",n);try{return _a.readFileSync(t,"utf-8")}catch{return null}}function vn(n){let e=Na();if(e)return Object.keys(e).filter(s=>s.startsWith(n));let t=Eo.join(jt,"templates",n);try{return _a.readdirSync(t).map(r=>`${n}${r}`)}catch{return[]}}var Ay,kn,Ls,To,Ma,_y,Ny,Fs=h(()=>{"use strict";ds();ze();Ay=50,kn=new Map,Ls=[],To=null,Ma=!1;l(Na,"loadBundle");l(Iy,"updateLruOrder");l($y,"evictLru");l(bd,"parseFrontmatter");l(Td,"load");l(Dy,"getAllowedTools");l(Ed,"clearCache");l(My,"resetBundle");l(dt,"getTemplateContent");l(vn,"listTemplates");_y={load:Td,parseFrontmatter:bd,getAllowedTools:Dy,clearCache:Ed,getTemplateContent:dt,listTemplates:vn},Ny=_y});function Co(n,e,t,s){if(!n)return{content:e,action:"created"};if(!(n.includes(t)&&n.includes(s)))return{content:`${n}
515
+ `).filter(Boolean)}catch{return[]}}},xy=new _a,Ue=xy});var Fa={};W(Fa,{default:()=>Oy,getTemplateContent:()=>dt,listTemplates:()=>vn,resetBundle:()=>_y});import Oa from"node:fs";import Ay from"node:fs/promises";import Co from"node:path";function La(){if(Na)return Eo;Na=!0;let n=Co.join(jt,"dist","templates.json");try{let e=Oa.readFileSync(n,"utf-8");return Eo=JSON.parse(e),Eo}catch{return null}}function $y(n){let e=Ls.indexOf(n);e>-1&&Ls.splice(e,1),Ls.push(n)}function Dy(){for(;kn.size>=Iy&&Ls.length>0;){let n=Ls.shift();n&&kn.delete(n)}}function bd(n){let e=/^---\n([\s\S]+?)\n---\n([\s\S]*)$/,t=n.match(e);if(!t)return{frontmatter:{},content:n.trim()};let[,s,r]=t,o={};return s.split(`
516
+ `).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(d=>d.trim()):o[a.trim()]=u.replace(/^["']|["']$/g,"")}}),{frontmatter:o,content:r.trim()}}async function Td(n){if(kn.has(n))return $y(n),kn.get(n);let e,t=La();if(t){let r=`commands/${n}.md`;e=t[r]}if(!e){let r=Co.join(jt,"templates","commands",`${n}.md`);try{e=await Ay.readFile(r,"utf-8")}catch{throw Zr.notFound(n)}}let s=bd(e);return Dy(),kn.set(n,s),Ls.push(n),s}async function My(n){return(await Td(n)).frontmatter["allowed-tools"]||[]}function Ed(){kn.clear(),Ls.length=0}function _y(){Eo=null,Na=!1,Ed()}function dt(n){let e=La();if(e?.[n])return e[n];let t=Co.join(jt,"templates",n);try{return Oa.readFileSync(t,"utf-8")}catch{return null}}function vn(n){let e=La();if(e)return Object.keys(e).filter(s=>s.startsWith(n));let t=Co.join(jt,"templates",n);try{return Oa.readdirSync(t).map(r=>`${n}${r}`)}catch{return[]}}var Iy,kn,Ls,Eo,Na,Ny,Oy,Fs=h(()=>{"use strict";ds();ze();Iy=50,kn=new Map,Ls=[],Eo=null,Na=!1;l(La,"loadBundle");l($y,"updateLruOrder");l(Dy,"evictLru");l(bd,"parseFrontmatter");l(Td,"load");l(My,"getAllowedTools");l(Ed,"clearCache");l(_y,"resetBundle");l(dt,"getTemplateContent");l(vn,"listTemplates");Ny={load:Td,parseFrontmatter:bd,getAllowedTools:My,clearCache:Ed,getTemplateContent:dt,listTemplates:vn},Oy=Ny});function Po(n,e,t,s){if(!n)return{content:e,action:"created"};if(!(n.includes(t)&&n.includes(s)))return{content:`${n}
517
517
 
518
- ${e}`,action:"appended"};let o=n.substring(0,n.indexOf(t)),i=n.substring(n.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 La=h(()=>{"use strict";l(Co,"mergeWithMarkers")});var jd={};W(jd,{CommandInstaller:()=>Ht,default:()=>Te,getProviderPaths:()=>Fa,installGlobalConfig:()=>Pd});import Ge from"node:fs/promises";import Po from"node:os";import he from"node:path";async function Oy(){try{let n=he.join(Po.homedir(),".prjct-cli","docs");await Ge.mkdir(n,{recursive:!0});let e=vn("global/docs/");if(e.length>0){for(let r of e)if(r.endsWith(".md")){let o=dt(r);if(o){let i=he.basename(r);await Ge.writeFile(he.join(n,i),o,"utf-8")}}return{success:!0}}let{PACKAGE_ROOT:t}=(ze(),ht(an)),s=he.join(t,"templates/global/docs");try{let r=await Ge.readdir(s);for(let o of r)if(o.endsWith(".md")){let i=he.join(s,o),a=he.join(n,o),c=await Ge.readFile(i,"utf-8");await Ge.writeFile(a,c,"utf-8")}}catch{}return{success:!0}}catch(n){return{success:!1,error:k(n)}}}async function Pd(){let n=(We(),ht(yt)),e=await n.getActiveProvider(),t=e.name;if(!(await n.detectProvider(t)).installed&&!e.configDir)return{success:!1,error:`${e.displayName} not detected`,action:"skipped"};try{await Ge.mkdir(e.configDir,{recursive:!0});let r=he.join(e.configDir,e.contextFile),o=Cd;if(t!=="claude"){let g=dt(`global/${e.contextFile}`);if(g)o=g;else{let{PACKAGE_ROOT:y}=(ze(),ht(an)),j=he.join(y,"templates","global",e.contextFile);try{o=await Ge.readFile(j,"utf-8")}catch{t==="gemini"&&(o=Cd.replace(/Claude/g,"Gemini"))}}}let i="",a=!1;try{i=await Ge.readFile(r,"utf-8"),a=!0}catch(g){if(_(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)),y=i.substring(i.indexOf(u)+u.length);i=`${(g+y).replace(/\n{3,}/g,`
518
+ ${e}`,action:"appended"};let o=n.substring(0,n.indexOf(t)),i=n.substring(n.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 Ua=h(()=>{"use strict";l(Po,"mergeWithMarkers")});var jd={};W(jd,{CommandInstaller:()=>Ht,default:()=>Te,getProviderPaths:()=>Ha,installGlobalConfig:()=>Pd});import Ge from"node:fs/promises";import jo from"node:os";import he from"node:path";async function Ly(){try{let n=he.join(jo.homedir(),".prjct-cli","docs");await Ge.mkdir(n,{recursive:!0});let e=vn("global/docs/");if(e.length>0){for(let r of e)if(r.endsWith(".md")){let o=dt(r);if(o){let i=he.basename(r);await Ge.writeFile(he.join(n,i),o,"utf-8")}}return{success:!0}}let{PACKAGE_ROOT:t}=(ze(),ht(an)),s=he.join(t,"templates/global/docs");try{let r=await Ge.readdir(s);for(let o of r)if(o.endsWith(".md")){let i=he.join(s,o),a=he.join(n,o),c=await Ge.readFile(i,"utf-8");await Ge.writeFile(a,c,"utf-8")}}catch{}return{success:!0}}catch(n){return{success:!1,error:k(n)}}}async function Pd(){let n=(We(),ht(yt)),e=await n.getActiveProvider(),t=e.name;if(!(await n.detectProvider(t)).installed&&!e.configDir)return{success:!1,error:`${e.displayName} not detected`,action:"skipped"};try{await Ge.mkdir(e.configDir,{recursive:!0});let r=he.join(e.configDir,e.contextFile),o=Cd;if(t!=="claude"){let g=dt(`global/${e.contextFile}`);if(g)o=g;else{let{PACKAGE_ROOT:y}=(ze(),ht(an)),j=he.join(y,"templates","global",e.contextFile);try{o=await Ge.readFile(j,"utf-8")}catch{t==="gemini"&&(o=Cd.replace(/Claude/g,"Gemini"))}}}let i="",a=!1;try{i=await Ge.readFile(r,"utf-8"),a=!0}catch(g){if(_(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)),y=i.substring(i.indexOf(u)+u.length);i=`${(g+y).replace(/\n{3,}/g,`
519
519
 
520
520
  `).trim()}
521
- `}let p=Co(a?i:"",o,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Ge.writeFile(r,p.content,"utf-8"),{success:!0,action:p.action,path:r}}catch(r){return{success:!1,error:k(r),action:"failed"}}}function Fa(){let n=Po.homedir();return{claude:{commands:he.join(n,".claude","commands"),config:he.join(n,".claude"),router:he.join(n,".claude","commands","p.md")},gemini:{commands:he.join(n,".gemini","commands"),config:he.join(n,".gemini"),router:he.join(n,".gemini","commands","p.toml")}}}var Cd,Ht,Ly,Te,Wt=h(()=>{"use strict";Fs();V();J();La();Cd='<!-- prjct:start - DO NOT REMOVE THIS MARKER -->\n# p/ \u2014 Context layer for AI agents\n\nSkills auto-activate for: task, ship, status, tag, remember, capture, sync, workflow, seed, install, context\nOther commands: run `prjct <command> --md` and follow CLI output\n\nTask lifecycle (v2): `prjct task "<desc>"` \u2192 work \u2192 `prjct status done` \u2192 `prjct ship`\n- Pause: `prjct status paused` | Resume: `prjct status active` | Reopen: `prjct status active` (on completed task)\n- Capture to inbox (bugs, ideas, anything): `prjct capture "<text>" --tags bug|idea|\u2026`\n\nData:\n- prjct runs \u2192 LLM generates relevant data \u2192 prjct stores it \u2192 LLM requests it from prjct \u2192 LLM uses it\n- Commit footer: `Generated with [p/](https://www.prjct.app/)`\n- Path resolution: `.prjct/prjct.config.json` \u2192 `~/.prjct-cli/projects/{projectId}`\n- Storage: `prjct` CLI (SQLite internally)\n\nMemory (project RAG):\n- Save with `prjct remember <type> "<content>"` or `prjct capture "<text>"` \u2014 these write to SQLite and hooks regenerate the Obsidian vault.\n- Recall via the SessionStart / UserPromptSubmit hook context that prjct injects, or `prjct context memory [topic]`.\n- Do **not** write to `~/.claude/projects/<slug>/memory/` \u2014 that is Claude Code auto-memory, disjoint from this project\'s RAG and invisible to other tools (Cursor, Gemini, web dashboard). In a prjct project, project memory is prjct.\n- The vault at `~/Documents/prjct/<slug>/_generated/` is a read-only snapshot regenerated from DB. Do not hand-edit it \u2014 fix the pipeline instead.\n\n**Auto-managed by prjct-cli** | https://prjct.app\n<!-- prjct:end - DO NOT REMOVE THIS MARKER -->\n';l(Oy,"installDocs");l(Pd,"installGlobalConfig");Ht=class{static{l(this,"CommandInstaller")}homeDir;commandsPath="";configPath="";_initialized=!1;constructor(){this.homeDir=Po.homedir()}async ensureInit(){if(this._initialized)return;let t=await(We(),ht(yt)).getActiveProvider();this.commandsPath=he.join(t.configDir,"commands"),this.configPath=t.configDir,this._initialized=!0}async detectActiveProvider(){return await this.ensureInit(),b(this.configPath)}async installCommands(){let e=await this.detectActiveProvider(),s=await(We(),ht(yt)).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=he.join(this.commandsPath,t);try{await Ge.unlink(s),e.push(t)}catch(r){if(r.code!=="ENOENT")return{success:!1,error:k(r)}}}return{success:!0,uninstalled:e}}catch(e){return{success:!1,error:k(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:k(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=he.join(this.commandsPath,t);try{await Ge.unlink(s),e=!0}catch(r){r.code}}return e}async cleanupLegacyCommands(){await this.ensureInit();let e=he.join(this.commandsPath,"p");try{if((await Ge.stat(e).catch(()=>null))?.isDirectory())return await Ge.rm(e,{recursive:!0,force:!0}),!0}catch{}return!1}async installGlobalConfig(){return Pd()}async cleanupAllLegacy(){let e=Po.homedir(),t=[],s=[he.join(e,".claude","commands","p.md"),he.join(e,".claude","commands","p.toml"),he.join(e,".gemini","commands","p.md"),he.join(e,".gemini","commands","p.toml")];for(let i of s)try{await Ge.unlink(i),t.push(i)}catch{}let r=[he.join(e,".claude","commands","p"),he.join(e,".gemini","commands","p")];for(let i of r)try{(await Ge.stat(i).catch(()=>null))?.isDirectory()&&(await Ge.rm(i,{recursive:!0,force:!0}),t.push(i))}catch{}let o=[he.join(e,".prjct-cli","config","homebrew-migrated")];for(let i of o)try{await Ge.unlink(i),t.push(i)}catch{}return{cleaned:t}}async installDocs(){return Oy()}};l(Fa,"getProviderPaths");Ly=new Ht,Te=Ly});function Rd(n,e){let t=[];br("Languages",n.languages,e.languages,t),br("Frameworks",n.frameworks,e.frameworks,t),(n.packageManager??"")!==(e.packageManager??"")&&t.push({field:"Package manager",type:"changed",before:n.packageManager??"(none)",after:e.packageManager??"(none)"}),(n.sourceDir??"")!==(e.sourceDir??"")&&t.push({field:"Source directory",type:"changed",before:n.sourceDir??"(none)",after:e.sourceDir??"(none)"}),(n.testDir??"")!==(e.testDir??"")&&t.push({field:"Test directory",type:"changed",before:n.testDir??"(none)",after:e.testDir??"(none)"}),br("Config files",n.configFiles,e.configFiles,t),n.fileCount!==e.fileCount&&t.push({field:"File count",type:"changed",before:String(n.fileCount),after:String(e.fileCount)});let s=n.patterns.map(d=>d.name),r=e.patterns.map(d=>d.name);br("Patterns",s,r,t);let o=n.antiPatterns.map(d=>d.issue),i=e.antiPatterns.map(d=>d.issue);br("Anti-patterns",o,i,t);let a=t.filter(d=>d.type==="added").length,c=t.filter(d=>d.type==="removed").length,u=t.filter(d=>d.type==="changed").length;return{hasChanges:t.length>0,items:t,summary:{added:a,removed:c,changed:u},beforeCommit:n.commitHash??null,afterCommit:e.commitHash??null}}function Ua(n){if(!n.hasChanges)return`## Analysis Diff
521
+ `}let p=Po(a?i:"",o,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Ge.writeFile(r,p.content,"utf-8"),{success:!0,action:p.action,path:r}}catch(r){return{success:!1,error:k(r),action:"failed"}}}function Ha(){let n=jo.homedir();return{claude:{commands:he.join(n,".claude","commands"),config:he.join(n,".claude"),router:he.join(n,".claude","commands","p.md")},gemini:{commands:he.join(n,".gemini","commands"),config:he.join(n,".gemini"),router:he.join(n,".gemini","commands","p.toml")}}}var Cd,Ht,Fy,Te,Wt=h(()=>{"use strict";Fs();V();J();Ua();Cd='<!-- prjct:start - DO NOT REMOVE THIS MARKER -->\n# p/ \u2014 Context layer for AI agents\n\nSkills auto-activate for: task, ship, status, tag, remember, capture, sync, workflow, seed, install, context\nOther commands: run `prjct <command> --md` and follow CLI output\n\nTask lifecycle (v2): `prjct task "<desc>"` \u2192 work \u2192 `prjct status done` \u2192 `prjct ship`\n- Pause: `prjct status paused` | Resume: `prjct status active` | Reopen: `prjct status active` (on completed task)\n- Capture to inbox (bugs, ideas, anything): `prjct capture "<text>" --tags bug|idea|\u2026`\n\nData:\n- prjct runs \u2192 LLM generates relevant data \u2192 prjct stores it \u2192 LLM requests it from prjct \u2192 LLM uses it\n- Commit footer: `Generated with [p/](https://www.prjct.app/)`\n- Path resolution: `.prjct/prjct.config.json` \u2192 `~/.prjct-cli/projects/{projectId}`\n- Storage: `prjct` CLI (SQLite internally)\n\nMemory (project RAG):\n- Save with `prjct remember <type> "<content>"` or `prjct capture "<text>"` \u2014 these write to SQLite and hooks regenerate the Obsidian vault.\n- Recall via the SessionStart / UserPromptSubmit hook context that prjct injects, or `prjct context memory [topic]`.\n- Do **not** write to `~/.claude/projects/<slug>/memory/` \u2014 that is Claude Code auto-memory, disjoint from this project\'s RAG and invisible to other tools (Cursor, Gemini, web dashboard). In a prjct project, project memory is prjct.\n- The vault at `~/Documents/prjct/<slug>/_generated/` is a read-only snapshot regenerated from DB. Do not hand-edit it \u2014 fix the pipeline instead.\n\n**Auto-managed by prjct-cli** | https://prjct.app\n<!-- prjct:end - DO NOT REMOVE THIS MARKER -->\n';l(Ly,"installDocs");l(Pd,"installGlobalConfig");Ht=class{static{l(this,"CommandInstaller")}homeDir;commandsPath="";configPath="";_initialized=!1;constructor(){this.homeDir=jo.homedir()}async ensureInit(){if(this._initialized)return;let t=await(We(),ht(yt)).getActiveProvider();this.commandsPath=he.join(t.configDir,"commands"),this.configPath=t.configDir,this._initialized=!0}async detectActiveProvider(){return await this.ensureInit(),b(this.configPath)}async installCommands(){let e=await this.detectActiveProvider(),s=await(We(),ht(yt)).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=he.join(this.commandsPath,t);try{await Ge.unlink(s),e.push(t)}catch(r){if(r.code!=="ENOENT")return{success:!1,error:k(r)}}}return{success:!0,uninstalled:e}}catch(e){return{success:!1,error:k(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:k(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=he.join(this.commandsPath,t);try{await Ge.unlink(s),e=!0}catch(r){r.code}}return e}async cleanupLegacyCommands(){await this.ensureInit();let e=he.join(this.commandsPath,"p");try{if((await Ge.stat(e).catch(()=>null))?.isDirectory())return await Ge.rm(e,{recursive:!0,force:!0}),!0}catch{}return!1}async installGlobalConfig(){return Pd()}async cleanupAllLegacy(){let e=jo.homedir(),t=[],s=[he.join(e,".claude","commands","p.md"),he.join(e,".claude","commands","p.toml"),he.join(e,".gemini","commands","p.md"),he.join(e,".gemini","commands","p.toml")];for(let i of s)try{await Ge.unlink(i),t.push(i)}catch{}let r=[he.join(e,".claude","commands","p"),he.join(e,".gemini","commands","p")];for(let i of r)try{(await Ge.stat(i).catch(()=>null))?.isDirectory()&&(await Ge.rm(i,{recursive:!0,force:!0}),t.push(i))}catch{}let o=[he.join(e,".prjct-cli","config","homebrew-migrated")];for(let i of o)try{await Ge.unlink(i),t.push(i)}catch{}return{cleaned:t}}async installDocs(){return Ly()}};l(Ha,"getProviderPaths");Fy=new Ht,Te=Fy});function Rd(n,e){let t=[];br("Languages",n.languages,e.languages,t),br("Frameworks",n.frameworks,e.frameworks,t),(n.packageManager??"")!==(e.packageManager??"")&&t.push({field:"Package manager",type:"changed",before:n.packageManager??"(none)",after:e.packageManager??"(none)"}),(n.sourceDir??"")!==(e.sourceDir??"")&&t.push({field:"Source directory",type:"changed",before:n.sourceDir??"(none)",after:e.sourceDir??"(none)"}),(n.testDir??"")!==(e.testDir??"")&&t.push({field:"Test directory",type:"changed",before:n.testDir??"(none)",after:e.testDir??"(none)"}),br("Config files",n.configFiles,e.configFiles,t),n.fileCount!==e.fileCount&&t.push({field:"File count",type:"changed",before:String(n.fileCount),after:String(e.fileCount)});let s=n.patterns.map(d=>d.name),r=e.patterns.map(d=>d.name);br("Patterns",s,r,t);let o=n.antiPatterns.map(d=>d.issue),i=e.antiPatterns.map(d=>d.issue);br("Anti-patterns",o,i,t);let a=t.filter(d=>d.type==="added").length,c=t.filter(d=>d.type==="removed").length,u=t.filter(d=>d.type==="changed").length;return{hasChanges:t.length>0,items:t,summary:{added:a,removed:c,changed:u},beforeCommit:n.commitHash??null,afterCommit:e.commitHash??null}}function Wa(n){if(!n.hasChanges)return`## Analysis Diff
522
522
 
523
523
  No changes between runs.`;let e=[];e.push("## Analysis Diff"),(n.beforeCommit||n.afterCommit)&&e.push(`> \`${n.beforeCommit?.substring(0,7)??"(none)"}\` \u2192 \`${n.afterCommit?.substring(0,7)??"(none)"}\``),e.push(""),e.push("| Change | Field | Detail |"),e.push("|--------|-------|--------|");for(let s of n.items){let r=s.type==="added"?"+":s.type==="removed"?"-":"~",o=s.type==="changed"?`${s.before} \u2192 ${s.after}`:s.after??s.before??"";e.push(`| ${r} | ${s.field} | ${o} |`)}e.push("");let t=[];return n.summary.added>0&&t.push(`${n.summary.added} added`),n.summary.removed>0&&t.push(`${n.summary.removed} removed`),n.summary.changed>0&&t.push(`${n.summary.changed} changed`),e.push(`**Summary**: ${t.join(", ")}`),e.join(`
524
524
  `)}function xd(n){if(!n.hasChanges)return"No changes between analysis runs.";let e=[];(n.beforeCommit||n.afterCommit)&&(e.push(` ${n.beforeCommit?.substring(0,7)??"(none)"} \u2192 ${n.afterCommit?.substring(0,7)??"(none)"}`),e.push(""));for(let t of n.items)t.type==="added"?e.push(` + ${t.field}: ${t.after}`):t.type==="removed"?e.push(` - ${t.field}: ${t.before}`):e.push(` ~ ${t.field}: ${t.before} \u2192 ${t.after}`);return e.join(`
525
- `)}function br(n,e,t,s){let r=new Set(e),o=new Set(t);for(let i of t)r.has(i)||s.push({field:n,type:"added",after:i});for(let i of e)o.has(i)||s.push({field:n,type:"removed",before:i})}var Ha=h(()=>{"use strict";l(Rd,"generateAnalysisDiff");l(Ua,"formatAnalysisDiffMd");l(xd,"formatAnalysisDiffText");l(br,"diffStringArray")});var Wa=h(()=>{"use strict"});import Fy from"node:fs/promises";import Uy from"node:path";function Sn(n){return n.replace(/([a-z])([A-Z])/g,"$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g,"$1 $2").replace(/[-_./]/g," ").toLowerCase().split(/\s+/).filter(e=>e.length>1)}function Hy(n,e){let t=[],s=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let p of s)t.push(...Sn(p));let r=[/export\s+(?:async\s+)?function\s+(\w+)/g,/export\s+class\s+(\w+)/g,/export\s+interface\s+(\w+)/g,/export\s+type\s+(\w+)/g,/export\s+(?:const|let|var)\s+(\w+)/g,/export\s+default\s+(?:class|function)\s+(\w+)/g];for(let p of r){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Sn(g[1]))}let o=[/(?:async\s+)?function\s+(\w+)/g,/class\s+(\w+)/g,/interface\s+(\w+)/g,/type\s+(\w+)\s*=/g];for(let p of o){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Sn(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(n))!==null;){let p=a[1];if(p.startsWith(".")||p.startsWith("@/"))t.push(...Sn(p));else{let g=p.startsWith("@")?p.split("/").slice(0,2).join("/"):p.split("/")[0];t.push(...Sn(g))}}let c=/\/\/\s*(.+)/g,u;for(;(u=c.exec(n))!==null;){let p=u[1].toLowerCase().split(/\s+/).filter(g=>g.length>2);t.push(...p)}let d=/\/\*\*?([\s\S]*?)\*\//g,m;for(;(m=d.exec(n))!==null;){let p=m[1].replace(/@\w+/g,"").replace(/\*/g,"").toLowerCase().split(/\s+/).filter(g=>g.length>2&&/^[a-z]+$/.test(g));t.push(...p)}return t.filter(p=>p.length>1&&!$d.has(p)&&/^[a-z][a-z0-9]*$/.test(p))}function Wy(n){return n.split(/\s+/).flatMap(e=>Sn(e)).filter(e=>e.length>1&&!$d.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function Gy(n){let e=await xs(n),t={},s={},r=0,o=await As(e,50,async a=>{try{let c=await Fy.readFile(Uy.join(n,a),"utf-8"),u=Hy(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},r+=c.length;let u=new Map;for(let d of c)u.set(d,(u.get(d)||0)+1);for(let[d,m]of u)s[d]||(s[d]=[]),s[d].push({path:a,tf:m})}let i=Object.keys(t).length;return{documents:t,invertedIndex:s,avgDocLength:i>0?r/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function qy(n,e){return Math.log((e-n+.5)/(n+.5)+1)}function Vy(n,e){let t=Wy(n);if(t.length===0)return[];let s=new Map;for(let r of t){let o=e.invertedIndex[r];if(!o)continue;let i=qy(o.length,e.totalDocs);for(let{path:a,tf:c}of o){let u=e.documents[a];if(!u)continue;let d=c*(1.2+1),m=c+1.2*(1-.75+.75*(u.length/e.avgDocLength)),p=i*(d/m);s.set(a,(s.get(a)||0)+p)}}return Array.from(s.entries()).map(([r,o])=>({path:r,score:o})).sort((r,o)=>o.score-r.score)}function By(n,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([s,r])=>[s,r.length]))};L.setDoc(n,Ga,t),jo.delete(n)}function Ro(n){let e=L.get(n,"SELECT updated_at FROM kv_store WHERE key = ?",Ga);if(!e)return jo.delete(n),null;let t=jo.get(n);if(t&&t.updatedAt===e.updated_at)return t.index;let s=L.getDoc(n,Ga);if(!s)return null;let r={};for(let[i,a]of Object.entries(s.docLengths))r[i]={tokens:[],length:a};let o={documents:r,invertedIndex:s.invertedIndex,avgDocLength:s.avgDocLength,totalDocs:s.totalDocs,builtAt:s.builtAt};return jo.set(n,{index:o,updatedAt:e.updated_at}),o}async function Dd(n,e){let t=await Gy(n);return By(e,t),t}function Md(n,e,t=15){let s=Ro(n);return s?Vy(e,s).slice(0,t):[]}var $d,Ga,jo,qa=h(()=>{"use strict";Wa();ce();J();$d=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(Sn,"splitIdentifier");l(Hy,"tokenizeFile");l(Wy,"tokenizeQuery");l(Gy,"buildIndex");l(qy,"idf");l(Vy,"score");Ga="bm25-index",jo=new Map;l(By,"saveIndex");l(Ro,"loadIndex");l(Dd,"indexProject");l(Md,"queryFiles")});import Va from"node:fs/promises";import ys from"node:path";import{z}from"zod";async function Yy(n,e){let t=Date.now();if(n.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let s=ys.join(e,"package.json"),r=await Va.readFile(s,"utf-8"),o=JSON.parse(r),i={...o.dependencies,...o.devDependencies},a=[],c=[];for(let u of n.frameworks){let d=u.toLowerCase();Object.keys(i).some(p=>p.toLowerCase().includes(d))?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 _(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 Qy(n,e){let t=Date.now();if(n.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let s=await sw(e),r=new Set(s),o=[],i=[];for(let a of n.languages){let c=Ky[a];if(!c)continue;c.some(d=>r.has(d))?o.push(a):i.push(a)}return i.length===0?{name:"Language verification",passed:!0,output:`${o.length} language(s) verified with matching files`,durationMs:Date.now()-t}:{name:"Language verification",passed:!1,error:`Languages without matching files: ${i.join(", ")}`,durationMs:Date.now()-t}}catch(s){return{name:"Language verification",passed:!1,error:`Failed to scan project files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Zy(n,e){let t=Date.now(),s=n.patterns.filter(i=>i.location);if(s.length===0)return{name:"Pattern location verification",passed:!0,output:"No pattern locations specified (skipped)",durationMs:Date.now()-t};let r=[],o=[];for(let i of s){let a=i.location,c=ys.join(e,a);await b(c)?o.push(a):r.push(`${i.name} (${a})`)}return r.length===0?{name:"Pattern location verification",passed:!0,output:`${o.length} pattern location(s) verified`,durationMs:Date.now()-t}:{name:"Pattern location verification",passed:!1,error:`Pattern locations not found: ${r.join(", ")}`,durationMs:Date.now()-t}}async function ew(n,e){let t=Date.now();try{let s=await nw(e),r=n.fileCount,o=.1,i=Math.abs(s-r),a=r*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${r}, actual: ${s})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${r}, actual ${s} (diff: ${i})`,durationMs:Date.now()-t}}catch(s){return{name:"File count verification",passed:!1,error:`Failed to count files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function tw(n,e){let t=Date.now();if(n.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let s=[],r=[];for(let o of n.antiPatterns){let i=ys.join(e,o.file);await b(i)?r.push(o.file):s.push(`${o.issue} (${o.file})`)}return s.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${r.length} anti-pattern file(s) verified`,durationMs:Date.now()-t}:{name:"Anti-pattern file verification",passed:!1,error:`Anti-pattern files not found: ${s.join(", ")}`,durationMs:Date.now()-t}}async function _d(n,e){let t=Date.now(),s=await Promise.all([Yy(n,e),Qy(n,e),Zy(n,e),ew(n,e),tw(n,e)]),r=s.filter(i=>!i.passed).length,o=s.filter(i=>i.passed).length;return{passed:r===0,checks:s,totalMs:Date.now()-t,failedCount:r,passedCount:o}}async function sw(n){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Va.readdir(r,{withFileTypes:!0});for(let i of o){let a=ys.join(r,i.name),c=ys.relative(n,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(n),Array.from(e)}async function nw(n){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Va.readdir(r,{withFileTypes:!0});for(let i of o){let a=ys.join(r,i.name),c=ys.relative(n,a);t.some(u=>u.test(c))||(i.isDirectory()?await s(a):i.isFile()&&e++)}}catch{}}return l(s,"scanDir"),await s(n),e}var Jy,zy,Xy,Ba,Ky,Nd=h(()=>{"use strict";V();J();Br();Jy=z.enum(["draft","verified","sealed"]),zy=z.object({name:z.string(),description:z.string(),location:z.string().optional(),severity:z.enum(["low","medium","high"]).optional(),language:z.string().optional(),framework:z.string().optional(),source:z.enum(["baseline","repo","context7","feedback"]).optional(),confidence:z.number().min(0).max(1).optional()}),Xy=z.object({issue:z.string(),file:z.string(),suggestion:z.string(),severity:z.enum(["low","medium","high"]).optional(),language:z.string().optional(),framework:z.string().optional(),source:z.enum(["baseline","repo","context7","feedback"]).optional(),confidence:z.number().min(0).max(1).optional()}),Ba=z.object({projectId:z.string(),languages:z.array(z.string()),frameworks:z.array(z.string()),packageManager:z.string().optional(),sourceDir:z.string().optional(),testDir:z.string().optional(),configFiles:z.array(z.string()),fileCount:z.number(),patterns:z.array(zy),antiPatterns:z.array(Xy),analyzedAt:z.string(),modelMetadata:rr.optional(),status:Jy.default("draft"),commitHash:z.string().optional(),signature:z.string().optional(),sealedAt:z.string().optional(),verifiedAt:z.string().optional()}),Ky={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(Qy,"verifyLanguages");l(Zy,"verifyPatternLocations");l(ew,"verifyFileCount");l(tw,"verifyAntiPatternFiles");l(_d,"semanticVerify");l(sw,"getProjectExtensions");l(nw,"countProjectFiles")});var Ja,st,Tr=h(()=>{"use strict";Nd();Ha();be();yr();fs();Ja=class extends Xe{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"};Ba.parse(s),await this.update(e,r=>({...r,draft:s,lastUpdated:R()})),await this.publishEntityEvent(e,"analysis","drafted",{commitHash:s.commitHash,fileCount:s.fileCount})}async seal(e){let t=await this.read(e);if(!t.draft)return{success:!1,error:"No draft analysis to seal. Run `p. sync` first."};if(t.draft.status==="sealed")return{success:!1,error:"Draft is already sealed."};let s=this.computeSignature(t.draft),r=R(),o={...t.draft,status:"sealed",signature:s,sealedAt:r};return Ba.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:r}),await this.publishEntityEvent(e,"analysis","sealed",{commitHash:o.commitHash,signature:s}),{success:!0,signature:s}}async getSealed(e){return(await this.read(e)).sealed}async getDraft(e){return(await this.read(e)).draft}async getActive(e){let t=await this.read(e);return t.sealed??t.draft}async getStatus(e){let t=await this.read(e);return{hasSealed:t.sealed!==null,hasDraft:t.draft!==null,hasPreviousSealed:t.previousSealed!==null,sealedCommit:t.sealed?.commitHash??null,draftCommit:t.draft?.commitHash??null,previousSealedCommit:t.previousSealed?.commitHash??null,sealedAt:t.sealed?.sealedAt??null}}async rollback(e){let t=await this.read(e);if(!t.previousSealed)return{success:!1,error:"No previous sealed version to rollback to."};let s=R();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:Rd(t.sealed,t.draft)}checkStaleness(e,t){return e?t?e!==t?{isStale:!0,sealedCommit:e,currentCommit:t,message:`Analysis is stale: sealed at ${e}, HEAD is ${t}. Run \`p. sync\` + \`p. seal\` to update.`}:{isStale:!1,sealedCommit:e,currentCommit:t,message:"Analysis is current."}:{isStale:!0,sealedCommit:e,currentCommit:null,message:"Cannot determine current commit. Analysis may be stale."}:{isStale:!1,sealedCommit:null,currentCommit:t,message:"No sealed analysis. Run `p. sync` then `p. seal`."}}async verify(e){let t=await this.read(e);if(!t.sealed)return{valid:!1,message:"No sealed analysis to verify."};if(!t.sealed.signature)return{valid:!1,message:"Sealed analysis has no signature."};let s=this.computeSignature({...t.sealed,signature:void 0,sealedAt:void 0});return s===t.sealed.signature?{valid:!0,message:"Signature verified. Analysis integrity confirmed."}:{valid:!1,message:`Signature mismatch. Expected ${s}, got ${t.sealed.signature}. Analysis may have been modified.`}}async semanticVerify(e,t){let s=await this.read(e),r=s.sealed??s.draft;return r?await _d(r,t):{passed:!1,checks:[{name:"Analysis availability",passed:!1,error:"No analysis available. Run `p. sync` to generate.",durationMs:0}],totalMs:0,failedCount:1,passedCount:0}}computeSignature(e){let t={projectId:e.projectId,languages:e.languages,frameworks:e.frameworks,packageManager:e.packageManager,sourceDir:e.sourceDir,testDir:e.testDir,configFiles:e.configFiles,fileCount:e.fileCount,patterns:e.patterns,antiPatterns:e.antiPatterns,analyzedAt:e.analyzedAt,commitHash:e.commitHash};return hr(JSON.stringify(t))}},st=new Ja});import Od from"node:fs/promises";import Ld from"node:path";async function Xa(n,e,t,s){let[r,o,i,a]=await Promise.all([iw(n,e,s),aw(n),cw(n),lw(n)]);return{project:{name:s.name,ecosystem:s.ecosystem,languages:s.languages,frameworks:s.frameworks,fileCount:s.fileCount,projectType:s.projectType},git:{branch:t.branch,recentCommits:t.recentCommits.slice(0,rw).map(c=>({message:c.message,date:c.date})),hasChanges:t.hasChanges,weeklyCommits:t.weeklyCommits},codeSamples:r,existingPatterns:o,taskHistory:i,previousAnalysis:a??void 0}}async function iw(n,e,t){let s=[],r=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=Md(n,r,za*2);for(let a of o){if(s.length>=za)break;try{let c=Ld.join(e,a.path),u=await Od.readFile(c,"utf-8");u.length>xo*3?s.push({path:a.path,content:`${u.slice(0,xo)}
526
- // ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):s.push({path:a.path,content:u.slice(0,xo),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>=za)break;if(!s.some(c=>c.path===a))try{let c=Ld.join(e,a),u=await Od.readFile(c,"utf-8");s.push({path:a,content:u.slice(0,xo),reason:"entry point"})}catch{}}return s}async function aw(n){try{let e=await st.getActive(n);return e?{patterns:(e.patterns??[]).map(t=>({name:t.name,description:t.description})),antiPatterns:(e.antiPatterns??[]).map(t=>({issue:t.issue,file:t.file,suggestion:t.suggestion}))}:{patterns:[],antiPatterns:[]}}catch{return{patterns:[],antiPatterns:[]}}}async function cw(n){try{return(await D.getTaskHistory(n)).slice(0,ow).map(t=>({description:t.title,status:t.classification,branch:t.branchName}))}catch{return[]}}function lw(n){try{let e=wt.getActiveSummary(n);return Promise.resolve(e)}catch(e){return B.debug("Failed to get previous LLM analysis summary",{error:e}),Promise.resolve(null)}}var xo,za,rw,ow,Fd=h(()=>{"use strict";qa();Tr();pn();rt();_s();xo=800,za=6,rw=8,ow=5;l(Xa,"buildAnalysisPayload");l(iw,"selectCodeSamples");l(aw,"getExistingPatterns");l(cw,"getTaskHistory");l(lw,"getPreviousAnalysisSummary")});var Ud=h(()=>{"use strict"});import ts from"chalk";function Hd(n){return Math.ceil(n.length/4)}function Wd(n){let e=n.split(`
525
+ `)}function br(n,e,t,s){let r=new Set(e),o=new Set(t);for(let i of t)r.has(i)||s.push({field:n,type:"added",after:i});for(let i of e)o.has(i)||s.push({field:n,type:"removed",before:i})}var Ga=h(()=>{"use strict";l(Rd,"generateAnalysisDiff");l(Wa,"formatAnalysisDiffMd");l(xd,"formatAnalysisDiffText");l(br,"diffStringArray")});var qa=h(()=>{"use strict"});import Uy from"node:fs/promises";import Hy from"node:path";function Sn(n){return n.replace(/([a-z])([A-Z])/g,"$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g,"$1 $2").replace(/[-_./]/g," ").toLowerCase().split(/\s+/).filter(e=>e.length>1)}function Wy(n,e){let t=[],s=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let p of s)t.push(...Sn(p));let r=[/export\s+(?:async\s+)?function\s+(\w+)/g,/export\s+class\s+(\w+)/g,/export\s+interface\s+(\w+)/g,/export\s+type\s+(\w+)/g,/export\s+(?:const|let|var)\s+(\w+)/g,/export\s+default\s+(?:class|function)\s+(\w+)/g];for(let p of r){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Sn(g[1]))}let o=[/(?:async\s+)?function\s+(\w+)/g,/class\s+(\w+)/g,/interface\s+(\w+)/g,/type\s+(\w+)\s*=/g];for(let p of o){let g;for(;(g=p.exec(n))!==null;)g[1]&&t.push(...Sn(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(n))!==null;){let p=a[1];if(p.startsWith(".")||p.startsWith("@/"))t.push(...Sn(p));else{let g=p.startsWith("@")?p.split("/").slice(0,2).join("/"):p.split("/")[0];t.push(...Sn(g))}}let c=/\/\/\s*(.+)/g,u;for(;(u=c.exec(n))!==null;){let p=u[1].toLowerCase().split(/\s+/).filter(g=>g.length>2);t.push(...p)}let d=/\/\*\*?([\s\S]*?)\*\//g,m;for(;(m=d.exec(n))!==null;){let p=m[1].replace(/@\w+/g,"").replace(/\*/g,"").toLowerCase().split(/\s+/).filter(g=>g.length>2&&/^[a-z]+$/.test(g));t.push(...p)}return t.filter(p=>p.length>1&&!$d.has(p)&&/^[a-z][a-z0-9]*$/.test(p))}function Gy(n){return n.split(/\s+/).flatMap(e=>Sn(e)).filter(e=>e.length>1&&!$d.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function qy(n){let e=await xs(n),t={},s={},r=0,o=await As(e,50,async a=>{try{let c=await Uy.readFile(Hy.join(n,a),"utf-8"),u=Wy(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},r+=c.length;let u=new Map;for(let d of c)u.set(d,(u.get(d)||0)+1);for(let[d,m]of u)s[d]||(s[d]=[]),s[d].push({path:a,tf:m})}let i=Object.keys(t).length;return{documents:t,invertedIndex:s,avgDocLength:i>0?r/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function Vy(n,e){return Math.log((e-n+.5)/(n+.5)+1)}function By(n,e){let t=Gy(n);if(t.length===0)return[];let s=new Map;for(let r of t){let o=e.invertedIndex[r];if(!o)continue;let i=Vy(o.length,e.totalDocs);for(let{path:a,tf:c}of o){let u=e.documents[a];if(!u)continue;let d=c*(1.2+1),m=c+1.2*(1-.75+.75*(u.length/e.avgDocLength)),p=i*(d/m);s.set(a,(s.get(a)||0)+p)}}return Array.from(s.entries()).map(([r,o])=>({path:r,score:o})).sort((r,o)=>o.score-r.score)}function Jy(n,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([s,r])=>[s,r.length]))};L.setDoc(n,Va,t),Ro.delete(n)}function xo(n){let e=L.get(n,"SELECT updated_at FROM kv_store WHERE key = ?",Va);if(!e)return Ro.delete(n),null;let t=Ro.get(n);if(t&&t.updatedAt===e.updated_at)return t.index;let s=L.getDoc(n,Va);if(!s)return null;let r={};for(let[i,a]of Object.entries(s.docLengths))r[i]={tokens:[],length:a};let o={documents:r,invertedIndex:s.invertedIndex,avgDocLength:s.avgDocLength,totalDocs:s.totalDocs,builtAt:s.builtAt};return Ro.set(n,{index:o,updatedAt:e.updated_at}),o}async function Dd(n,e){let t=await qy(n);return Jy(e,t),t}function Md(n,e,t=15){let s=xo(n);return s?By(e,s).slice(0,t):[]}var $d,Va,Ro,Ba=h(()=>{"use strict";qa();ce();J();$d=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(Sn,"splitIdentifier");l(Wy,"tokenizeFile");l(Gy,"tokenizeQuery");l(qy,"buildIndex");l(Vy,"idf");l(By,"score");Va="bm25-index",Ro=new Map;l(Jy,"saveIndex");l(xo,"loadIndex");l(Dd,"indexProject");l(Md,"queryFiles")});import Ja from"node:fs/promises";import ys from"node:path";import{z}from"zod";async function Qy(n,e){let t=Date.now();if(n.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let s=ys.join(e,"package.json"),r=await Ja.readFile(s,"utf-8"),o=JSON.parse(r),i={...o.dependencies,...o.devDependencies},a=[],c=[];for(let u of n.frameworks){let d=u.toLowerCase();Object.keys(i).some(p=>p.toLowerCase().includes(d))?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 _(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 Zy(n,e){let t=Date.now();if(n.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let s=await nw(e),r=new Set(s),o=[],i=[];for(let a of n.languages){let c=Yy[a];if(!c)continue;c.some(d=>r.has(d))?o.push(a):i.push(a)}return i.length===0?{name:"Language verification",passed:!0,output:`${o.length} language(s) verified with matching files`,durationMs:Date.now()-t}:{name:"Language verification",passed:!1,error:`Languages without matching files: ${i.join(", ")}`,durationMs:Date.now()-t}}catch(s){return{name:"Language verification",passed:!1,error:`Failed to scan project files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function ew(n,e){let t=Date.now(),s=n.patterns.filter(i=>i.location);if(s.length===0)return{name:"Pattern location verification",passed:!0,output:"No pattern locations specified (skipped)",durationMs:Date.now()-t};let r=[],o=[];for(let i of s){let a=i.location,c=ys.join(e,a);await b(c)?o.push(a):r.push(`${i.name} (${a})`)}return r.length===0?{name:"Pattern location verification",passed:!0,output:`${o.length} pattern location(s) verified`,durationMs:Date.now()-t}:{name:"Pattern location verification",passed:!1,error:`Pattern locations not found: ${r.join(", ")}`,durationMs:Date.now()-t}}async function tw(n,e){let t=Date.now();try{let s=await rw(e),r=n.fileCount,o=.1,i=Math.abs(s-r),a=r*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${r}, actual: ${s})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${r}, actual ${s} (diff: ${i})`,durationMs:Date.now()-t}}catch(s){return{name:"File count verification",passed:!1,error:`Failed to count files: ${s instanceof Error?s.message:"unknown error"}`,durationMs:Date.now()-t}}}async function sw(n,e){let t=Date.now();if(n.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let s=[],r=[];for(let o of n.antiPatterns){let i=ys.join(e,o.file);await b(i)?r.push(o.file):s.push(`${o.issue} (${o.file})`)}return s.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${r.length} anti-pattern file(s) verified`,durationMs:Date.now()-t}:{name:"Anti-pattern file verification",passed:!1,error:`Anti-pattern files not found: ${s.join(", ")}`,durationMs:Date.now()-t}}async function _d(n,e){let t=Date.now(),s=await Promise.all([Qy(n,e),Zy(n,e),ew(n,e),tw(n,e),sw(n,e)]),r=s.filter(i=>!i.passed).length,o=s.filter(i=>i.passed).length;return{passed:r===0,checks:s,totalMs:Date.now()-t,failedCount:r,passedCount:o}}async function nw(n){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Ja.readdir(r,{withFileTypes:!0});for(let i of o){let a=ys.join(r,i.name),c=ys.relative(n,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(n),Array.from(e)}async function rw(n){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function s(r){try{let o=await Ja.readdir(r,{withFileTypes:!0});for(let i of o){let a=ys.join(r,i.name),c=ys.relative(n,a);t.some(u=>u.test(c))||(i.isDirectory()?await s(a):i.isFile()&&e++)}}catch{}}return l(s,"scanDir"),await s(n),e}var zy,Xy,Ky,za,Yy,Nd=h(()=>{"use strict";V();J();Br();zy=z.enum(["draft","verified","sealed"]),Xy=z.object({name:z.string(),description:z.string(),location:z.string().optional(),severity:z.enum(["low","medium","high"]).optional(),language:z.string().optional(),framework:z.string().optional(),source:z.enum(["baseline","repo","context7","feedback"]).optional(),confidence:z.number().min(0).max(1).optional()}),Ky=z.object({issue:z.string(),file:z.string(),suggestion:z.string(),severity:z.enum(["low","medium","high"]).optional(),language:z.string().optional(),framework:z.string().optional(),source:z.enum(["baseline","repo","context7","feedback"]).optional(),confidence:z.number().min(0).max(1).optional()}),za=z.object({projectId:z.string(),languages:z.array(z.string()),frameworks:z.array(z.string()),packageManager:z.string().optional(),sourceDir:z.string().optional(),testDir:z.string().optional(),configFiles:z.array(z.string()),fileCount:z.number(),patterns:z.array(Xy),antiPatterns:z.array(Ky),analyzedAt:z.string(),modelMetadata:rr.optional(),status:zy.default("draft"),commitHash:z.string().optional(),signature:z.string().optional(),sealedAt:z.string().optional(),verifiedAt:z.string().optional()}),Yy={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(Qy,"verifyFrameworks");l(Zy,"verifyLanguages");l(ew,"verifyPatternLocations");l(tw,"verifyFileCount");l(sw,"verifyAntiPatternFiles");l(_d,"semanticVerify");l(nw,"getProjectExtensions");l(rw,"countProjectFiles")});var Xa,nt,Tr=h(()=>{"use strict";Nd();Ga();be();yr();fs();Xa=class extends Xe{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"};za.parse(s),await this.update(e,r=>({...r,draft:s,lastUpdated:R()})),await this.publishEntityEvent(e,"analysis","drafted",{commitHash:s.commitHash,fileCount:s.fileCount})}async seal(e){let t=await this.read(e);if(!t.draft)return{success:!1,error:"No draft analysis to seal. Run `p. sync` first."};if(t.draft.status==="sealed")return{success:!1,error:"Draft is already sealed."};let s=this.computeSignature(t.draft),r=R(),o={...t.draft,status:"sealed",signature:s,sealedAt:r};return za.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:r}),await this.publishEntityEvent(e,"analysis","sealed",{commitHash:o.commitHash,signature:s}),{success:!0,signature:s}}async getSealed(e){return(await this.read(e)).sealed}async getDraft(e){return(await this.read(e)).draft}async getActive(e){let t=await this.read(e);return t.sealed??t.draft}async getStatus(e){let t=await this.read(e);return{hasSealed:t.sealed!==null,hasDraft:t.draft!==null,hasPreviousSealed:t.previousSealed!==null,sealedCommit:t.sealed?.commitHash??null,draftCommit:t.draft?.commitHash??null,previousSealedCommit:t.previousSealed?.commitHash??null,sealedAt:t.sealed?.sealedAt??null}}async rollback(e){let t=await this.read(e);if(!t.previousSealed)return{success:!1,error:"No previous sealed version to rollback to."};let s=R();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:Rd(t.sealed,t.draft)}checkStaleness(e,t){return e?t?e!==t?{isStale:!0,sealedCommit:e,currentCommit:t,message:`Analysis is stale: sealed at ${e}, HEAD is ${t}. Run \`p. sync\` + \`p. seal\` to update.`}:{isStale:!1,sealedCommit:e,currentCommit:t,message:"Analysis is current."}:{isStale:!0,sealedCommit:e,currentCommit:null,message:"Cannot determine current commit. Analysis may be stale."}:{isStale:!1,sealedCommit:null,currentCommit:t,message:"No sealed analysis. Run `p. sync` then `p. seal`."}}async verify(e){let t=await this.read(e);if(!t.sealed)return{valid:!1,message:"No sealed analysis to verify."};if(!t.sealed.signature)return{valid:!1,message:"Sealed analysis has no signature."};let s=this.computeSignature({...t.sealed,signature:void 0,sealedAt:void 0});return s===t.sealed.signature?{valid:!0,message:"Signature verified. Analysis integrity confirmed."}:{valid:!1,message:`Signature mismatch. Expected ${s}, got ${t.sealed.signature}. Analysis may have been modified.`}}async semanticVerify(e,t){let s=await this.read(e),r=s.sealed??s.draft;return r?await _d(r,t):{passed:!1,checks:[{name:"Analysis availability",passed:!1,error:"No analysis available. Run `p. sync` to generate.",durationMs:0}],totalMs:0,failedCount:1,passedCount:0}}computeSignature(e){let t={projectId:e.projectId,languages:e.languages,frameworks:e.frameworks,packageManager:e.packageManager,sourceDir:e.sourceDir,testDir:e.testDir,configFiles:e.configFiles,fileCount:e.fileCount,patterns:e.patterns,antiPatterns:e.antiPatterns,analyzedAt:e.analyzedAt,commitHash:e.commitHash};return hr(JSON.stringify(t))}},nt=new Xa});import Od from"node:fs/promises";import Ld from"node:path";async function Ya(n,e,t,s){let[r,o,i,a]=await Promise.all([aw(n,e,s),cw(n),lw(n),uw(n)]);return{project:{name:s.name,ecosystem:s.ecosystem,languages:s.languages,frameworks:s.frameworks,fileCount:s.fileCount,projectType:s.projectType},git:{branch:t.branch,recentCommits:t.recentCommits.slice(0,ow).map(c=>({message:c.message,date:c.date})),hasChanges:t.hasChanges,weeklyCommits:t.weeklyCommits},codeSamples:r,existingPatterns:o,taskHistory:i,previousAnalysis:a??void 0}}async function aw(n,e,t){let s=[],r=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=Md(n,r,Ka*2);for(let a of o){if(s.length>=Ka)break;try{let c=Ld.join(e,a.path),u=await Od.readFile(c,"utf-8");u.length>Ao*3?s.push({path:a.path,content:`${u.slice(0,Ao)}
526
+ // ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):s.push({path:a.path,content:u.slice(0,Ao),reason:`BM25 score: ${a.score.toFixed(2)}`})}catch{}}let i=["package.json","tsconfig.json","src/index.ts","src/main.ts","app.ts"];for(let a of i){if(s.length>=Ka)break;if(!s.some(c=>c.path===a))try{let c=Ld.join(e,a),u=await Od.readFile(c,"utf-8");s.push({path:a,content:u.slice(0,Ao),reason:"entry point"})}catch{}}return s}async function cw(n){try{let e=await nt.getActive(n);return e?{patterns:(e.patterns??[]).map(t=>({name:t.name,description:t.description})),antiPatterns:(e.antiPatterns??[]).map(t=>({issue:t.issue,file:t.file,suggestion:t.suggestion}))}:{patterns:[],antiPatterns:[]}}catch{return{patterns:[],antiPatterns:[]}}}async function lw(n){try{return(await D.getTaskHistory(n)).slice(0,iw).map(t=>({description:t.title,status:t.classification,branch:t.branchName}))}catch{return[]}}function uw(n){try{let e=wt.getActiveSummary(n);return Promise.resolve(e)}catch(e){return B.debug("Failed to get previous LLM analysis summary",{error:e}),Promise.resolve(null)}}var Ao,Ka,ow,iw,Fd=h(()=>{"use strict";Ba();Tr();pn();ot();_s();Ao=800,Ka=6,ow=8,iw=5;l(Ya,"buildAnalysisPayload");l(aw,"selectCodeSamples");l(cw,"getExistingPatterns");l(lw,"getTaskHistory");l(uw,"getPreviousAnalysisSummary")});var Ud=h(()=>{"use strict"});import ss from"chalk";function Hd(n){return Math.ceil(n.length/4)}function Wd(n){let e=n.split(`
527
527
  `),t=[],s=null;for(let r=0;r<e.length;r++){let o=e[r],i=o.match(/^(#{1,3})\s+(.+)$/);i?(s&&(s.endLine=r-1,t.push(s)),s={name:i[2].trim(),content:o,startLine:r,endLine:r}):s&&(s.content+=`
528
- ${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Ka(n){return n.includes("<!-- prjct:preserve")}function Gd(n,e){let t=Wd(n),s=Wd(e),r={hasChanges:!1,added:[],modified:[],removed:[],preserved:[],tokensBefore:Hd(n),tokensAfter:Hd(e),tokenDelta:0};r.tokenDelta=r.tokensAfter-r.tokensBefore;let o=new Map(t.map(a=>[a.name.toLowerCase(),a])),i=new Map(s.map(a=>[a.name.toLowerCase(),a]));for(let a of t)Ka(a.content)&&r.preserved.push({name:a.name,lineCount:a.content.split(`
529
- `).length});for(let a of s){let c=a.name.toLowerCase(),u=o.get(c);u?u.content.trim()!==a.content.trim()&&(Ka(u.content)||(r.modified.push({name:a.name,type:"modified",before:u.content,after:a.content,lineCount:a.content.split(`
528
+ ${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Qa(n){return n.includes("<!-- prjct:preserve")}function Gd(n,e){let t=Wd(n),s=Wd(e),r={hasChanges:!1,added:[],modified:[],removed:[],preserved:[],tokensBefore:Hd(n),tokensAfter:Hd(e),tokenDelta:0};r.tokenDelta=r.tokensAfter-r.tokensBefore;let o=new Map(t.map(a=>[a.name.toLowerCase(),a])),i=new Map(s.map(a=>[a.name.toLowerCase(),a]));for(let a of t)Qa(a.content)&&r.preserved.push({name:a.name,lineCount:a.content.split(`
529
+ `).length});for(let a of s){let c=a.name.toLowerCase(),u=o.get(c);u?u.content.trim()!==a.content.trim()&&(Qa(u.content)||(r.modified.push({name:a.name,type:"modified",before:u.content,after:a.content,lineCount:a.content.split(`
530
530
  `).length}),r.hasChanges=!0)):(r.added.push({name:a.name,type:"added",after:a.content,lineCount:a.content.split(`
531
- `).length}),r.hasChanges=!0)}for(let a of t){let c=a.name.toLowerCase();!i.has(c)&&!Ka(a.content)&&(r.removed.push({name:a.name,type:"removed",before:a.content,lineCount:a.content.split(`
532
- `).length}),r.hasChanges=!0)}return r}function qd(n,e={}){let{colorize:t=!0}=e,s=[],r=t?ts.green:p=>p,o=t?ts.red:p=>p,i=t?ts.yellow:p=>p,a=t?ts.dim:p=>p,c=t?ts.bold:p=>p;if(!n.hasChanges)return s.push(a("No changes detected (context is up to date)")),s.join(`
531
+ `).length}),r.hasChanges=!0)}for(let a of t){let c=a.name.toLowerCase();!i.has(c)&&!Qa(a.content)&&(r.removed.push({name:a.name,type:"removed",before:a.content,lineCount:a.content.split(`
532
+ `).length}),r.hasChanges=!0)}return r}function qd(n,e={}){let{colorize:t=!0}=e,s=[],r=t?ss.green:p=>p,o=t?ss.red:p=>p,i=t?ss.yellow:p=>p,a=t?ss.dim:p=>p,c=t?ss.bold:p=>p;if(!n.hasChanges)return s.push(a("No changes detected (context is up to date)")),s.join(`
533
533
  `);if(s.push(""),s.push(c("\u{1F4CB} Changes to context files:")),s.push(""),n.added.length>0)for(let p of n.added)s.push(r(`+ \u2502 + ${p.name} (new)`));if(n.modified.length>0)for(let p of n.modified)s.push(i(`~ \u2502 ${p.name} (modified)`));if(n.removed.length>0)for(let p of n.removed)s.push(o(`- \u2502 - ${p.name} (removed)`));if(n.preserved.length>0){s.push(""),s.push(a(" ## Your Customizations"));for(let p of n.preserved)s.push(a(` \u2502 \u2713 ${p.name} (${p.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=[];n.added.length>0&&u.push(r(`+${n.added.length} added`)),n.modified.length>0&&u.push(i(`~${n.modified.length} modified`)),n.removed.length>0&&u.push(o(`-${n.removed.length} removed`)),s.push(`Summary: ${u.join(", ")||"no changes"}`);let d=n.tokenDelta>=0?"+":"",m=n.tokenDelta>=0?r:o;return s.push(`Tokens: ${n.tokensBefore.toLocaleString()} \u2192 ${n.tokensAfter.toLocaleString()} (${m(d+n.tokenDelta.toLocaleString())})`),s.push(""),s.join(`
534
- `)}function Vd(n,e={}){let{colorize:t=!0}=e,s=[],r=t?ts.green:c=>c,o=t?ts.red:c=>c,i=t?ts.cyan:c=>c,a=t?ts.dim:c=>c;for(let c of n.added){if(s.push(i(`@@ +${c.name} @@`)),c.after)for(let u of c.after.split(`
534
+ `)}function Vd(n,e={}){let{colorize:t=!0}=e,s=[],r=t?ss.green:c=>c,o=t?ss.red:c=>c,i=t?ss.cyan:c=>c,a=t?ss.dim:c=>c;for(let c of n.added){if(s.push(i(`@@ +${c.name} @@`)),c.after)for(let u of c.after.split(`
535
535
  `))s.push(r(`+ ${u}`));s.push("")}for(let c of n.modified){if(s.push(i(`@@ ${c.name} @@`)),c.before){for(let u of c.before.split(`
536
536
  `).slice(0,5))s.push(o(`- ${u}`));c.before.split(`
537
537
  `).length>5&&s.push(a(` ... ${c.before.split(`
@@ -542,13 +542,13 @@ ${o}`)}return s&&(s.endLine=e.length-1,t.push(s)),t}function Ka(n){return n.incl
542
542
  `).slice(0,5))s.push(o(`- ${u}`));c.before.split(`
543
543
  `).length>5&&s.push(a(` ... ${c.before.split(`
544
544
  `).length-5} more lines`))}s.push("")}return s.join(`
545
- `)}var Bd=h(()=>{"use strict";Ud();l(Hd,"estimateTokens");l(Wd,"parseMarkdownSections");l(Ka,"isPreservedSection");l(Gd,"generateSyncDiff");l(qd,"formatDiffPreview");l(Vd,"formatFullDiff")});import Jd from"node:fs/promises";import bn from"node:path";function dw(n){let e=[],t,s=new RegExp(Xl.source,"g");for(;(t=s.exec(n))!==null;){let r=t[1];(r.startsWith(".")||r.startsWith("@/"))&&e.push(r)}return e}async function pw(n,e,t){let s;if(n.startsWith("@/"))s=bn.join(t,"src",n.slice(2));else{let r=bn.dirname(bn.join(t,e));s=bn.resolve(r,n)}for(let r of zl){let o=s+r;try{if((await Jd.stat(o)).isFile())return bn.relative(t,o)}catch{}}return null}async function mw(n){let e=await xs(n),t={},s={},r=0,o=await As(e,50,async i=>{try{let a=await Jd.readFile(bn.join(n,i),"utf-8"),c=dw(a),u=[];for(let d of c){let m=await pw(d,i,n);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,r+=a.length;for(let c of a)s[c]||(s[c]=[]),s[c].push(i)}return{forward:t,reverse:s,fileCount:e.length,edgeCount:r,builtAt:new Date().toISOString()}}function gw(n,e){L.setDoc(n,Ya,e),Ao.delete(n)}function Io(n){let e=L.get(n,"SELECT updated_at FROM kv_store WHERE key = ?",Ya);if(!e)return Ao.delete(n),null;let t=Ao.get(n);if(t&&t.updatedAt===e.updated_at)return t.graph;let s=L.getDoc(n,Ya);return s&&Ao.set(n,{graph:s,updatedAt:e.updated_at}),s}async function zd(n,e){let t=await mw(n);return gw(e,t),t}var Ya,Ao,Qa=h(()=>{"use strict";Mi();ce();J();l(dw,"extractImportSources");l(pw,"resolveImport");l(mw,"buildGraph");Ya="import-graph",Ao=new Map;l(gw,"saveGraph");l(Io,"loadGraph");l(zd,"indexImports")});function Xd(n,e){let t=[...n.added,...n.modified],s=new Set(t),r=new Set,o=Io(e);if(o)for(let c of t){let u=o.reverse[c];if(u)for(let d of u)s.has(d)||r.add(d)}let i=Array.from(r),a=[...t,...i];return{directlyChanged:t,affectedByImports:i,deleted:n.deleted,allAffected:a}}function Kd(n){let e=new Set;for(let t of n){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 Yd=h(()=>{"use strict";Qa();l(Xd,"propagateChanges");l(Kd,"affectedDomains")});import Qd from"node:fs/promises";import fw from"node:path";function hw(n){if(typeof Bun<"u"&&Bun.hash)return`xxh64:${Bun.hash(n).toString(36)}`;let e=2166136261;for(let t=0;t<n.length;t++)e^=n.charCodeAt(t),e=Math.imul(e,16777619);return`fnv1a:${(e>>>0).toString(36)}`}async function yw(n){let e=await xs(n,{skipDotfiles:!0,dotfileAllowlist:[".env.example"]}),t=new Map,s=await As(e,100,async r=>{try{let o=fw.join(n,r),[i,a]=await Promise.all([Qd.readFile(o,"utf-8"),Qd.stat(o)]);return{path:r,hash:hw(i),size:a.size,mtime:a.mtime.toISOString()}}catch{return null}});for(let r of s)t.set(r.path,r);return t}function ww(n,e){let t=[],s=[],r=[];for(let[i,a]of n){let c=e.get(i);c?c.hash!==a.hash?s.push(i):r.push(i):t.push(i)}let o=[];for(let i of e.keys())n.has(i)||o.push(i);return{added:t,modified:s,deleted:o,unchanged:r}}function Za(n,e){let t=L.getDb(n);t.transaction(()=>{t.prepare("DELETE FROM index_checksums").run();let s=t.prepare("INSERT INTO index_checksums (path, checksum, size, mtime) VALUES (?, ?, ?, ?)");for(let[,r]of e)s.run(r.path,r.hash,r.size,r.mtime)})(),L.setDoc(n,"file-hashes-meta",{fileCount:e.size,builtAt:new Date().toISOString()})}function kw(n){let e=new Map;try{let t=L.query(n,"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 ec(n,e){let[t,s]=await Promise.all([yw(n),Promise.resolve(kw(e))]);return{diff:ww(t,s),currentHashes:t}}function Zd(n){return L.hasDoc(n,"file-hashes-meta")}var ep=h(()=>{"use strict";ce();J();l(hw,"hashContent");l(yw,"computeHashes");l(ww,"diffHashes");l(Za,"saveHashes");l(kw,"loadHashes");l(ec,"detectChanges");l(Zd,"hasHashRegistry")});async function Sw(n,e=100){try{let{stdout:t}=await O(`git log --name-only --pretty=format:'---COMMIT---' -${e}`,{cwd:n,maxBuffer:10485760}),s=[],r=null;for(let o of t.split(`
546
- `)){let i=o.trim();i==="---COMMIT---"?(r&&r.size>0&&r.size<=30&&s.push(r),r=new Set):i&&r&&bw(i)&&r.add(i)}return r&&r.size>0&&r.size<=30&&s.push(r),s}catch{return[]}}function bw(n){return/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java|cs|rb|php|vue|svelte)$/i.test(n)&&!n.includes("node_modules/")}async function Tw(n,e=100){let t=await Sw(n,e),s=new Map,r=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 d=Ew(a[c],a[u]);r.set(d,(r.get(d)||0)+1)}}let o={};for(let[i,a]of r){let[c,u]=i.split("\0"),d=s.get(c)||0,m=s.get(u)||0;if(d<2||m<2)continue;let p=d+m-a,g=p>0?a/p: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(n,e){return n<e?`${n}\0${e}`:`${e}\0${n}`}function Cw(n,e){L.setDoc(n,tc,e),$o.delete(n)}function np(n){let e=L.get(n,"SELECT updated_at FROM kv_store WHERE key = ?",tc);if(!e)return $o.delete(n),null;let t=$o.get(n);if(t&&t.updatedAt===e.updated_at)return t.matrix;let s=L.getDoc(n,tc);return s&&$o.set(n,{matrix:s,updatedAt:e.updated_at}),s}async function rp(n,e,t=100){let s=await Tw(n,t);return Cw(e,s),s}var tc,$o,op=h(()=>{"use strict";Wa();ce();Ze();l(Sw,"parseGitLog");l(bw,"isSourceFile");l(Tw,"buildMatrix");l(Ew,"pairKey");tc="cochange-index",$o=new Map;l(Cw,"saveMatrix");l(np,"loadMatrix");l(rp,"indexCoChanges")});import lp from"node:fs/promises";import ip from"node:os";import sc from"node:path";function jw(){let n=dt("mcp-config.json");if(!n)return{mcpServers:{context7:nc}};try{return JSON.parse(n)}catch{return{mcpServers:{context7:nc}}}}function up(){return jw().mcpServers?.context7||nc}function ap(){return process.env.PRJCT_CONTEXT7_CONFIG?process.env.PRJCT_CONTEXT7_CONFIG:process.env.NODE_ENV==="test"?sc.join(ip.tmpdir(),"prjct-context7-test","mcp.json"):sc.join(ip.homedir(),".claude","mcp.json")}async function cp(n){try{let e=await lp.readFile(n,"utf-8");return JSON.parse(e)}catch(e){if(_(e))return{};throw e}}async function Rw(){if(process.env.PRJCT_SKIP_CONTEXT7_SMOKE==="1"||process.env.NODE_ENV==="test")return;let n=up(),e=[...n.args||[],"--help"];await zt(n.command||"npx",e,{timeout:15e3})}var nc,Tn,rc,xw,ss,Er=h(()=>{"use strict";Fs();Vr();V();Ze();J();nc={command:"npx",args:["-y","@upstash/context7-mcp@latest"]},Tn=null;l(jw,"parseTemplateConfig");l(up,"getContext7Config");l(ap,"getConfigPath");l(cp,"readConfig");l(Rw,"runSmokeCheck");rc=class{static{l(this,"Context7Service")}async install(){let e=ap(),t=sc.dirname(e);await lp.mkdir(t,{recursive:!0});let s=await cp(e),r=s.mcpServers||{};return r.context7=up(),s.mcpServers=r,await ie(e,s),Tn=null,{installed:!0,verified:!1,configPath:e,message:"Context7 MCP configured"}}async verify(){if(Tn&&Date.now()-Tn.at<3e5)return Tn.status;let e=ap(),r=((await cp(e)).mcpServers||{}).context7;if(!r?.command||!Array.isArray(r.args)||r.args.length===0)return{installed:!1,verified:!1,configPath:e,message:"Context7 MCP not configured in ~/.claude/mcp.json"};try{await Rw();let o={installed:!0,verified:!0,configPath:e};return Tn={at:Date.now(),status:o},o}catch(o){let i={installed:!0,verified:!1,configPath:e,message:`Context7 smoke check failed: ${k(o)}`};return Tn={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}},xw=new rc,ss=xw});import{execFileSync as dp,execSync as Aw}from"node:child_process";var Do,oc,Mo,pp,mp=h(()=>{"use strict";or();vo();Do={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"}},oc=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=Do[e];if(!s)return this.checkUnknownTool(e);let r=this.executeCheck(s);return this.setCache(e,r),r}ensureTool(e){let t=this.checkTool(e);if(!t.available){let s=Do[e],r=t.error||{message:`${e} is not available`,hint:s?.installHint||`Install ${e} and try again`,docs:s?.docs};throw new Mo(r)}}ensureTools(e){let t=[];for(let s of e)this.checkTool(s).available||t.push(s);if(t.length>0){let s=t.map(r=>{let o=Do[r];return o?` ${r}: ${o.installHint}`:` ${r}: Install and try again`}).join(`
547
- `);throw new Mo({message:`Missing required tools: ${t.join(", ")}`,hint:`Install the following:
548
- ${s}`})}}isAvailable(e){return this.checkTool(e).available}getVersion(e){return this.checkTool(e).version}checkAll(e){let t=e||Object.keys(Do),s=new Map;for(let r of t)s.set(r,this.checkTool(r));return s}clearCache(){this.cache.clear(),this.cacheTimestamps.clear()}executeCheck(e){try{let t=Aw(e.command,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),s;if(e.versionRegex){let r=t.match(e.versionRegex);s=r?r[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){if(!/^[a-zA-Z0-9_-]+$/.test(e))return{available:!1,error:ko(`Invalid tool name: ${e}`,"Tool names must only contain alphanumeric characters, hyphens, and underscores")};try{return dp(e,["--version"],{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{try{return dp(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?sn(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())}},Mo=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}},pp=new oc});var No={};W(No,{installCodexSkill:()=>ic,verifyCodexPRouterReady:()=>En});import{execFileSync as Iw}from"node:child_process";import Y from"node:fs/promises";import Us from"node:os";import oe from"node:path";import me from"chalk";async function $w(n){let e=n.name==="claude"?"@anthropic-ai/claude-code":"@google/gemini-cli";if(!pp.isAvailable("npm"))return console.log(`${me.yellow("\u26A0\uFE0F npm is not available")}`),console.log(""),console.log(`${me.dim(`Install ${n.displayName} using one of:`)}`),console.log(me.dim(" \u2022 Install Node.js: https://nodejs.org")),console.log(me.dim(` \u2022 Use Homebrew: brew install ${n.name==="claude"?"claude":"gemini"}`)),console.log(me.dim(` \u2022 Use npx directly: npx ${e}`)),console.log(""),!1;try{return console.log(me.yellow(`\u{1F4E6} ${n.displayName} not found. Installing...`)),console.log(""),Iw("npm",["install","-g",e],{stdio:"inherit",timeout:fn("NPM_INSTALL")}),console.log(""),console.log(`${me.green("\u2713")} ${n.displayName} installed successfully`),console.log(""),!0}catch(t){let s=t;return s.killed&&s.signal==="SIGTERM"?(console.log(me.yellow(`\u26A0\uFE0F Installation timed out for ${n.displayName}`)),console.log(""),console.log(me.dim("The npm install took too long. Try:")),console.log(me.dim(" \u2022 Set PRJCT_TIMEOUT_NPM_INSTALL=300000 for 5 minutes")),console.log(me.dim(` \u2022 Run manually: npm install -g ${e}`))):console.log(me.yellow(`\u26A0\uFE0F Failed to install ${n.displayName}: ${s.message}`)),console.log(""),console.log(me.dim("Alternative installation methods:")),console.log(me.dim(` \u2022 npm: npm install -g ${e}`)),console.log(me.dim(` \u2022 yarn: yarn global add ${e}`)),console.log(me.dim(` \u2022 pnpm: pnpm add -g ${e}`)),console.log(me.dim(` \u2022 brew: brew install ${n.name==="claude"?"claude":"gemini"}`)),console.log(""),!1}}async function Dw(){let n=await us(),e=await Ui(),t=ut[e.provider],s={provider:e.provider,providers:[],cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null},r=["claude","gemini"];for(let a of r){let c=ut[a],u=n[a],d={provider:a,cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null};if(!u.installed)if(a===e.provider)if(await $w(c))d.cliInstalled=!0,s.cliInstalled=!0;else throw new Error(`${c.displayName} installation failed`);else continue;if(a==="claude"){if(await Te.detectActiveProvider()){let p=await Te.syncCommands();p.success&&(d.commandsAdded=p.added,d.commandsUpdated=p.updated,s.commandsAdded+=p.added,s.commandsUpdated+=p.updated);let g=await Te.installGlobalConfig();g.success&&(d.configAction=g.action,s.configAction||(s.configAction=g.action)),await Te.installDocs(),await Uw(),await ss.ensureReady()}}else if(a==="gemini"){await Mw()&&(d.commandsAdded=1,s.commandsAdded+=1);let p=await _w();p.success&&(d.configAction=p.action)}s.providers.push(d)}if((await ir()).installed&&(await Nw()).success&&console.log(` ${me.green("\u2713")} Antigravity skill installed`),(await Is()).installed){if(!(await ic()).success)throw new Error("Codex skill installation failed");let c=await En({autoRepair:!0});if(!c.verified)throw new Error(c.message||"Codex p. router verification failed");console.log(` ${me.green("\u2713")} Codex skill installed`),console.log(` ${me.green("\u2713")} Codex p. router ready`)}await dr.saveConfig(ae,await Te.getInstallPath(),e.provider),await Fw();for(let a of s.providers)Hw(a,ut[a.provider]);return s}async function Mw(){try{let n=oe.join(Us.homedir(),".gemini","commands"),e=oe.join(n,"p.toml");try{return await Y.unlink(e),!0}catch(t){if(t.code==="ENOENT")return!1;throw t}}catch(n){return B.warn(`Gemini router cleanup warning: ${k(n)}`),!1}}async function _w(){try{let n=oe.join(Us.homedir(),".gemini"),e=oe.join(n,"GEMINI.md");await Y.mkdir(n,{recursive:!0});let t=dt("global/GEMINI.md");if(!t){let c=oe.join(jt,"templates","global","GEMINI.md");t=await Y.readFile(c,"utf-8")}let s="",r=!1;try{s=await Y.readFile(e,"utf-8"),r=!0}catch(c){if(_(c))r=!1;else throw c}let a=Co(r?s:"",t,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Y.writeFile(e,a.content,"utf-8"),{success:!0,action:a.action}}catch(n){return B.warn(`Gemini config warning: ${k(n)}`),{success:!1,action:null}}}async function Nw(){try{let n=oe.join(Us.homedir(),".gemini","antigravity","skills"),e=oe.join(n,"prjct"),t=oe.join(e,"SKILL.md");await Y.mkdir(e,{recursive:!0});let s=await b(t),r=dt("antigravity/SKILL.md");if(!r){let o=oe.join(jt,"templates","antigravity","SKILL.md");if(!await b(o))return B.warn("Antigravity SKILL.md template not found"),{success:!1,action:null};r=await Y.readFile(o,"utf-8")}return await Y.writeFile(t,r,"utf-8"),{success:!0,action:s?"updated":"created"}}catch(n){return B.warn(`Antigravity skill warning: ${k(n)}`),{success:!1,action:null}}}function wp(){return oe.join(Us.homedir(),".codex","skills","prjct","SKILL.md")}function Ow(n){return`<!-- ${yp}: ${JSON.stringify({version:ae,templateHash:n})} -->`}function gp(n){let e=n.match(new RegExp(`<!--\\s*${yp}:\\s*(\\{[\\s\\S]*?\\})\\s*-->`));if(!e)return null;try{return JSON.parse(e[1])}catch{return null}}function Lw(n){return hr(n)}async function kp(){let n=dt("codex/SKILL.md");if(n)return n;let e=oe.join(jt,"templates","codex","SKILL.md");return await b(e)?Y.readFile(e,"utf-8"):null}function vp(n){let e=n.trimEnd(),t=Lw(e),s=Ow(t);return{content:`${e}
545
+ `)}var Bd=h(()=>{"use strict";Ud();l(Hd,"estimateTokens");l(Wd,"parseMarkdownSections");l(Qa,"isPreservedSection");l(Gd,"generateSyncDiff");l(qd,"formatDiffPreview");l(Vd,"formatFullDiff")});import Jd from"node:fs/promises";import bn from"node:path";function pw(n){let e=[],t,s=new RegExp(Yl.source,"g");for(;(t=s.exec(n))!==null;){let r=t[1];(r.startsWith(".")||r.startsWith("@/"))&&e.push(r)}return e}async function mw(n,e,t){let s;if(n.startsWith("@/"))s=bn.join(t,"src",n.slice(2));else{let r=bn.dirname(bn.join(t,e));s=bn.resolve(r,n)}for(let r of Kl){let o=s+r;try{if((await Jd.stat(o)).isFile())return bn.relative(t,o)}catch{}}return null}async function gw(n){let e=await xs(n),t={},s={},r=0,o=await As(e,50,async i=>{try{let a=await Jd.readFile(bn.join(n,i),"utf-8"),c=pw(a),u=[];for(let d of c){let m=await mw(d,i,n);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,r+=a.length;for(let c of a)s[c]||(s[c]=[]),s[c].push(i)}return{forward:t,reverse:s,fileCount:e.length,edgeCount:r,builtAt:new Date().toISOString()}}function fw(n,e){L.setDoc(n,Za,e),Io.delete(n)}function $o(n){let e=L.get(n,"SELECT updated_at FROM kv_store WHERE key = ?",Za);if(!e)return Io.delete(n),null;let t=Io.get(n);if(t&&t.updatedAt===e.updated_at)return t.graph;let s=L.getDoc(n,Za);return s&&Io.set(n,{graph:s,updatedAt:e.updated_at}),s}async function zd(n,e){let t=await gw(n);return fw(e,t),t}var Za,Io,ec=h(()=>{"use strict";_i();ce();J();l(pw,"extractImportSources");l(mw,"resolveImport");l(gw,"buildGraph");Za="import-graph",Io=new Map;l(fw,"saveGraph");l($o,"loadGraph");l(zd,"indexImports")});function Xd(n,e){let t=[...n.added,...n.modified],s=new Set(t),r=new Set,o=$o(e);if(o)for(let c of t){let u=o.reverse[c];if(u)for(let d of u)s.has(d)||r.add(d)}let i=Array.from(r),a=[...t,...i];return{directlyChanged:t,affectedByImports:i,deleted:n.deleted,allAffected:a}}function Kd(n){let e=new Set;for(let t of n){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 Yd=h(()=>{"use strict";ec();l(Xd,"propagateChanges");l(Kd,"affectedDomains")});import Qd from"node:fs/promises";import hw from"node:path";function yw(n){if(typeof Bun<"u"&&Bun.hash)return`xxh64:${Bun.hash(n).toString(36)}`;let e=2166136261;for(let t=0;t<n.length;t++)e^=n.charCodeAt(t),e=Math.imul(e,16777619);return`fnv1a:${(e>>>0).toString(36)}`}async function ww(n){let e=await xs(n,{skipDotfiles:!0,dotfileAllowlist:[".env.example"]}),t=new Map,s=await As(e,100,async r=>{try{let o=hw.join(n,r),[i,a]=await Promise.all([Qd.readFile(o,"utf-8"),Qd.stat(o)]);return{path:r,hash:yw(i),size:a.size,mtime:a.mtime.toISOString()}}catch{return null}});for(let r of s)t.set(r.path,r);return t}function kw(n,e){let t=[],s=[],r=[];for(let[i,a]of n){let c=e.get(i);c?c.hash!==a.hash?s.push(i):r.push(i):t.push(i)}let o=[];for(let i of e.keys())n.has(i)||o.push(i);return{added:t,modified:s,deleted:o,unchanged:r}}function tc(n,e){let t=L.getDb(n);t.transaction(()=>{t.prepare("DELETE FROM index_checksums").run();let s=t.prepare("INSERT INTO index_checksums (path, checksum, size, mtime) VALUES (?, ?, ?, ?)");for(let[,r]of e)s.run(r.path,r.hash,r.size,r.mtime)})(),L.setDoc(n,"file-hashes-meta",{fileCount:e.size,builtAt:new Date().toISOString()})}function vw(n){let e=new Map;try{let t=L.query(n,"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 sc(n,e){let[t,s]=await Promise.all([ww(n),Promise.resolve(vw(e))]);return{diff:kw(t,s),currentHashes:t}}function Zd(n){return L.hasDoc(n,"file-hashes-meta")}var ep=h(()=>{"use strict";ce();J();l(yw,"hashContent");l(ww,"computeHashes");l(kw,"diffHashes");l(tc,"saveHashes");l(vw,"loadHashes");l(sc,"detectChanges");l(Zd,"hasHashRegistry")});async function bw(n,e=100){try{let{stdout:t}=await O(`git log --name-only --pretty=format:'---COMMIT---' -${e}`,{cwd:n,maxBuffer:10485760}),s=[],r=null;for(let o of t.split(`
546
+ `)){let i=o.trim();i==="---COMMIT---"?(r&&r.size>0&&r.size<=30&&s.push(r),r=new Set):i&&r&&Tw(i)&&r.add(i)}return r&&r.size>0&&r.size<=30&&s.push(r),s}catch{return[]}}function Tw(n){return/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java|cs|rb|php|vue|svelte)$/i.test(n)&&!n.includes("node_modules/")}async function Ew(n,e=100){let t=await bw(n,e),s=new Map,r=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 d=Cw(a[c],a[u]);r.set(d,(r.get(d)||0)+1)}}let o={};for(let[i,a]of r){let[c,u]=i.split("\0"),d=s.get(c)||0,m=s.get(u)||0;if(d<2||m<2)continue;let p=d+m-a,g=p>0?a/p: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 Cw(n,e){return n<e?`${n}\0${e}`:`${e}\0${n}`}function Pw(n,e){L.setDoc(n,nc,e),Do.delete(n)}function np(n){let e=L.get(n,"SELECT updated_at FROM kv_store WHERE key = ?",nc);if(!e)return Do.delete(n),null;let t=Do.get(n);if(t&&t.updatedAt===e.updated_at)return t.matrix;let s=L.getDoc(n,nc);return s&&Do.set(n,{matrix:s,updatedAt:e.updated_at}),s}async function rp(n,e,t=100){let s=await Ew(n,t);return Pw(e,s),s}var nc,Do,op=h(()=>{"use strict";qa();ce();Ze();l(bw,"parseGitLog");l(Tw,"isSourceFile");l(Ew,"buildMatrix");l(Cw,"pairKey");nc="cochange-index",Do=new Map;l(Pw,"saveMatrix");l(np,"loadMatrix");l(rp,"indexCoChanges")});import lp from"node:fs/promises";import ip from"node:os";import rc from"node:path";function Rw(){let n=dt("mcp-config.json");if(!n)return{mcpServers:{context7:oc}};try{return JSON.parse(n)}catch{return{mcpServers:{context7:oc}}}}function up(){return Rw().mcpServers?.context7||oc}function ap(){return process.env.PRJCT_CONTEXT7_CONFIG?process.env.PRJCT_CONTEXT7_CONFIG:process.env.NODE_ENV==="test"?rc.join(ip.tmpdir(),"prjct-context7-test","mcp.json"):rc.join(ip.homedir(),".claude","mcp.json")}async function cp(n){try{let e=await lp.readFile(n,"utf-8");return JSON.parse(e)}catch(e){if(_(e))return{};throw e}}async function xw(){if(process.env.PRJCT_SKIP_CONTEXT7_SMOKE==="1"||process.env.NODE_ENV==="test")return;let n=up(),e=[...n.args||[],"--help"];await zt(n.command||"npx",e,{timeout:15e3})}var oc,Tn,ic,Aw,ns,Er=h(()=>{"use strict";Fs();Vr();V();Ze();J();oc={command:"npx",args:["-y","@upstash/context7-mcp@latest"]},Tn=null;l(Rw,"parseTemplateConfig");l(up,"getContext7Config");l(ap,"getConfigPath");l(cp,"readConfig");l(xw,"runSmokeCheck");ic=class{static{l(this,"Context7Service")}async install(){let e=ap(),t=rc.dirname(e);await lp.mkdir(t,{recursive:!0});let s=await cp(e),r=s.mcpServers||{};return r.context7=up(),s.mcpServers=r,await ie(e,s),Tn=null,{installed:!0,verified:!1,configPath:e,message:"Context7 MCP configured"}}async verify(){if(Tn&&Date.now()-Tn.at<3e5)return Tn.status;let e=ap(),r=((await cp(e)).mcpServers||{}).context7;if(!r?.command||!Array.isArray(r.args)||r.args.length===0)return{installed:!1,verified:!1,configPath:e,message:"Context7 MCP not configured in ~/.claude/mcp.json"};try{await xw();let o={installed:!0,verified:!0,configPath:e};return Tn={at:Date.now(),status:o},o}catch(o){let i={installed:!0,verified:!1,configPath:e,message:`Context7 smoke check failed: ${k(o)}`};return Tn={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}},Aw=new ic,ns=Aw});import{execFileSync as dp,execSync as Iw}from"node:child_process";var Mo,ac,_o,pp,mp=h(()=>{"use strict";or();So();Mo={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"}},ac=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=Mo[e];if(!s)return this.checkUnknownTool(e);let r=this.executeCheck(s);return this.setCache(e,r),r}ensureTool(e){let t=this.checkTool(e);if(!t.available){let s=Mo[e],r=t.error||{message:`${e} is not available`,hint:s?.installHint||`Install ${e} and try again`,docs:s?.docs};throw new _o(r)}}ensureTools(e){let t=[];for(let s of e)this.checkTool(s).available||t.push(s);if(t.length>0){let s=t.map(r=>{let o=Mo[r];return o?` ${r}: ${o.installHint}`:` ${r}: Install and try again`}).join(`
547
+ `);throw new _o({message:`Missing required tools: ${t.join(", ")}`,hint:`Install the following:
548
+ ${s}`})}}isAvailable(e){return this.checkTool(e).available}getVersion(e){return this.checkTool(e).version}checkAll(e){let t=e||Object.keys(Mo),s=new Map;for(let r of t)s.set(r,this.checkTool(r));return s}clearCache(){this.cache.clear(),this.cacheTimestamps.clear()}executeCheck(e){try{let t=Iw(e.command,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),s;if(e.versionRegex){let r=t.match(e.versionRegex);s=r?r[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){if(!/^[a-zA-Z0-9_-]+$/.test(e))return{available:!1,error:vo(`Invalid tool name: ${e}`,"Tool names must only contain alphanumeric characters, hyphens, and underscores")};try{return dp(e,["--version"],{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{try{return dp(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?sn(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())}},_o=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}},pp=new ac});var Oo={};W(Oo,{installCodexSkill:()=>cc,verifyCodexPRouterReady:()=>En});import{execFileSync as $w}from"node:child_process";import Y from"node:fs/promises";import Us from"node:os";import oe from"node:path";import me from"chalk";async function Dw(n){let e=n.name==="claude"?"@anthropic-ai/claude-code":"@google/gemini-cli";if(!pp.isAvailable("npm"))return console.log(`${me.yellow("\u26A0\uFE0F npm is not available")}`),console.log(""),console.log(`${me.dim(`Install ${n.displayName} using one of:`)}`),console.log(me.dim(" \u2022 Install Node.js: https://nodejs.org")),console.log(me.dim(` \u2022 Use Homebrew: brew install ${n.name==="claude"?"claude":"gemini"}`)),console.log(me.dim(` \u2022 Use npx directly: npx ${e}`)),console.log(""),!1;try{return console.log(me.yellow(`\u{1F4E6} ${n.displayName} not found. Installing...`)),console.log(""),$w("npm",["install","-g",e],{stdio:"inherit",timeout:fn("NPM_INSTALL")}),console.log(""),console.log(`${me.green("\u2713")} ${n.displayName} installed successfully`),console.log(""),!0}catch(t){let s=t;return s.killed&&s.signal==="SIGTERM"?(console.log(me.yellow(`\u26A0\uFE0F Installation timed out for ${n.displayName}`)),console.log(""),console.log(me.dim("The npm install took too long. Try:")),console.log(me.dim(" \u2022 Set PRJCT_TIMEOUT_NPM_INSTALL=300000 for 5 minutes")),console.log(me.dim(` \u2022 Run manually: npm install -g ${e}`))):console.log(me.yellow(`\u26A0\uFE0F Failed to install ${n.displayName}: ${s.message}`)),console.log(""),console.log(me.dim("Alternative installation methods:")),console.log(me.dim(` \u2022 npm: npm install -g ${e}`)),console.log(me.dim(` \u2022 yarn: yarn global add ${e}`)),console.log(me.dim(` \u2022 pnpm: pnpm add -g ${e}`)),console.log(me.dim(` \u2022 brew: brew install ${n.name==="claude"?"claude":"gemini"}`)),console.log(""),!1}}async function Mw(){let n=await Zt(),e=await Wi(),t=et[e.provider],s={provider:e.provider,providers:[],cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null},r=["claude","gemini"];for(let a of r){let c=et[a],u=n[a],d={provider:a,cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null};if(!u.installed)if(a===e.provider)if(await Dw(c))d.cliInstalled=!0,s.cliInstalled=!0;else throw new Error(`${c.displayName} installation failed`);else continue;if(a==="claude"){if(await Te.detectActiveProvider()){let p=await Te.syncCommands();p.success&&(d.commandsAdded=p.added,d.commandsUpdated=p.updated,s.commandsAdded+=p.added,s.commandsUpdated+=p.updated);let g=await Te.installGlobalConfig();g.success&&(d.configAction=g.action,s.configAction||(s.configAction=g.action)),await Te.installDocs(),await Hw(),await ns.ensureReady()}}else if(a==="gemini"){await _w()&&(d.commandsAdded=1,s.commandsAdded+=1);let p=await Nw();p.success&&(d.configAction=p.action)}s.providers.push(d)}if((await ir()).installed&&(await Ow()).success&&console.log(` ${me.green("\u2713")} Antigravity skill installed`),(await Is()).installed){if(!(await cc()).success)throw new Error("Codex skill installation failed");let c=await En({autoRepair:!0});if(!c.verified)throw new Error(c.message||"Codex p. router verification failed");console.log(` ${me.green("\u2713")} Codex skill installed`),console.log(` ${me.green("\u2713")} Codex p. router ready`)}await dr.saveConfig(ae,await Te.getInstallPath(),e.provider),await Uw();for(let a of s.providers)Ww(a,et[a.provider]);return s}async function _w(){try{let n=oe.join(Us.homedir(),".gemini","commands"),e=oe.join(n,"p.toml");try{return await Y.unlink(e),!0}catch(t){if(t.code==="ENOENT")return!1;throw t}}catch(n){return B.warn(`Gemini router cleanup warning: ${k(n)}`),!1}}async function Nw(){try{let n=oe.join(Us.homedir(),".gemini"),e=oe.join(n,"GEMINI.md");await Y.mkdir(n,{recursive:!0});let t=dt("global/GEMINI.md");if(!t){let c=oe.join(jt,"templates","global","GEMINI.md");t=await Y.readFile(c,"utf-8")}let s="",r=!1;try{s=await Y.readFile(e,"utf-8"),r=!0}catch(c){if(_(c))r=!1;else throw c}let a=Po(r?s:"",t,"<!-- prjct:start - DO NOT REMOVE THIS MARKER -->","<!-- prjct:end - DO NOT REMOVE THIS MARKER -->");return await Y.writeFile(e,a.content,"utf-8"),{success:!0,action:a.action}}catch(n){return B.warn(`Gemini config warning: ${k(n)}`),{success:!1,action:null}}}async function Ow(){try{let n=oe.join(Us.homedir(),".gemini","antigravity","skills"),e=oe.join(n,"prjct"),t=oe.join(e,"SKILL.md");await Y.mkdir(e,{recursive:!0});let s=await b(t),r=dt("antigravity/SKILL.md");if(!r){let o=oe.join(jt,"templates","antigravity","SKILL.md");if(!await b(o))return B.warn("Antigravity SKILL.md template not found"),{success:!1,action:null};r=await Y.readFile(o,"utf-8")}return await Y.writeFile(t,r,"utf-8"),{success:!0,action:s?"updated":"created"}}catch(n){return B.warn(`Antigravity skill warning: ${k(n)}`),{success:!1,action:null}}}function wp(){return oe.join(Us.homedir(),".codex","skills","prjct","SKILL.md")}function Lw(n){return`<!-- ${yp}: ${JSON.stringify({version:ae,templateHash:n})} -->`}function gp(n){let e=n.match(new RegExp(`<!--\\s*${yp}:\\s*(\\{[\\s\\S]*?\\})\\s*-->`));if(!e)return null;try{return JSON.parse(e[1])}catch{return null}}function Fw(n){return hr(n)}async function kp(){let n=dt("codex/SKILL.md");if(n)return n;let e=oe.join(jt,"templates","codex","SKILL.md");return await b(e)?Y.readFile(e,"utf-8"):null}function vp(n){let e=n.trimEnd(),t=Fw(e),s=Lw(t);return{content:`${e}
549
549
 
550
550
  ${s}
551
- `,templateHash:t}}async function ic(){try{let n=wp(),e=oe.dirname(n);await Y.mkdir(e,{recursive:!0});let t=await b(n),s=await kp();if(!s)return B.warn("Codex SKILL.md template not found"),{success:!1,action:null};let r=vp(s);return t&&await Y.readFile(n,"utf-8").catch(()=>"")===r.content?{success:!0,action:"unchanged"}:(await Y.writeFile(n,r.content,"utf-8"),{success:!0,action:t?"updated":"created"})}catch(n){return B.warn(`Codex skill warning: ${k(n)}`),{success:!1,action:null}}}async function En(n={}){let e=wp();if(!(await Is()).installed)return{installed:!1,verified:!0,skillPath:e,message:"Codex not detected"};let s=await kp();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 r=vp(s),o=l(async()=>n.autoRepair?(await ic()).success:!1,"maybeRepair"),i="";if(!await b(e)&&!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:r.templateHash,message:"Codex skill missing at ~/.codex/skills/prjct/SKILL.md",fix:["Run `prjct start` to install Codex skill"]};i=await Y.readFile(e,"utf-8").catch(()=>"");let a=gp(i);if(!(a?.version===ae&&a?.templateHash===r.templateHash)){if(!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:r.templateHash,message:"Codex skill metadata mismatch (outdated router)",fix:["Run `prjct start` or `prjct setup` to refresh Codex skill"]};if(i=await Y.readFile(e,"utf-8").catch(()=>""),a=gp(i),!(a?.version===ae&&a?.templateHash===r.templateHash))return{installed:!0,verified:!1,skillPath:e,templateHash:r.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:r.templateHash,message:"Codex p. router ready"}}async function Fw(){try{let n=oe.join(Us.homedir(),".prjct-cli","projects");if(!await b(n))return;let e=(await Y.readdir(n,{withFileTypes:!0})).filter(s=>s.isDirectory()).map(s=>s.name),t=0;for(let s of e)try{let r=C.getDoc(s,"project");if(!r)continue;r.cliVersion!==ae&&(r.cliVersion=ae,C.setDoc(s,"project",r),t++)}catch{}t>0&&console.log(` ${me.green("\u2713")} Updated ${t} project(s) to v${ae}`)}catch(n){_(n)||B.warn(`Migration warning: ${k(n)}`)}}async function fp(n,e){let t={};if(await b(n))try{t=await Se(n)??{}}catch(s){if(!(s instanceof SyntaxError))throw s}t.statusLine={type:"command",command:e},await ie(n,t)}async function Uw(){try{let n=oe.join(Us.homedir(),".claude"),e=oe.join(n,"settings.json"),t=oe.join(n,"prjct-statusline.sh"),s=oe.join(Us.homedir(),".prjct-cli","statusline"),r=oe.join(s,"statusline.sh"),o=oe.join(s,"themes"),i=oe.join(s,"lib"),a=oe.join(s,"components"),c=oe.join(s,"config.json"),u=oe.join(jt,"assets","statusline"),d=oe.join(u,"statusline.sh"),m=oe.join(u,"themes"),p=oe.join(u,"lib"),g=oe.join(u,"components"),y=oe.join(u,"default-config.json");if(await b(n)||await Y.mkdir(n,{recursive:!0}),await b(s)||await Y.mkdir(s,{recursive:!0}),await b(o)||await Y.mkdir(o,{recursive:!0}),await b(i)||await Y.mkdir(i,{recursive:!0}),await b(a)||await Y.mkdir(a,{recursive:!0}),await b(r)){let j=await Y.readFile(r,"utf8");if(j.includes("CLI_VERSION=")){let T=j.match(/CLI_VERSION="([^"]*)"/);if(T&&T[1]!==ae){let x=j.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${ae}"`);await Y.writeFile(r,x,{mode:493})}await _o(p,i),await _o(g,a),await hp(t,r),await fp(e,t);return}}if(await b(d)){let j=await Y.readFile(d,"utf8");if(j=j.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${ae}"`),await Y.writeFile(r,j,{mode:493}),await _o(p,i),await _o(g,a),await b(m)){let T=await Y.readdir(m);for(let x of T){let S=oe.join(m,x),w=oe.join(o,x);await Y.copyFile(S,w)}}!await b(c)&&await b(y)&&await Y.copyFile(y,c)}else{let j=`#!/bin/bash
551
+ `,templateHash:t}}async function cc(){try{let n=wp(),e=oe.dirname(n);await Y.mkdir(e,{recursive:!0});let t=await b(n),s=await kp();if(!s)return B.warn("Codex SKILL.md template not found"),{success:!1,action:null};let r=vp(s);return t&&await Y.readFile(n,"utf-8").catch(()=>"")===r.content?{success:!0,action:"unchanged"}:(await Y.writeFile(n,r.content,"utf-8"),{success:!0,action:t?"updated":"created"})}catch(n){return B.warn(`Codex skill warning: ${k(n)}`),{success:!1,action:null}}}async function En(n={}){let e=wp();if(!(await Is()).installed)return{installed:!1,verified:!0,skillPath:e,message:"Codex not detected"};let s=await kp();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 r=vp(s),o=l(async()=>n.autoRepair?(await cc()).success:!1,"maybeRepair"),i="";if(!await b(e)&&!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:r.templateHash,message:"Codex skill missing at ~/.codex/skills/prjct/SKILL.md",fix:["Run `prjct start` to install Codex skill"]};i=await Y.readFile(e,"utf-8").catch(()=>"");let a=gp(i);if(!(a?.version===ae&&a?.templateHash===r.templateHash)){if(!await o())return{installed:!0,verified:!1,skillPath:e,templateHash:r.templateHash,message:"Codex skill metadata mismatch (outdated router)",fix:["Run `prjct start` or `prjct setup` to refresh Codex skill"]};if(i=await Y.readFile(e,"utf-8").catch(()=>""),a=gp(i),!(a?.version===ae&&a?.templateHash===r.templateHash))return{installed:!0,verified:!1,skillPath:e,templateHash:r.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:r.templateHash,message:"Codex p. router ready"}}async function Uw(){try{let n=oe.join(Us.homedir(),".prjct-cli","projects");if(!await b(n))return;let e=(await Y.readdir(n,{withFileTypes:!0})).filter(s=>s.isDirectory()).map(s=>s.name),t=0;for(let s of e)try{let r=C.getDoc(s,"project");if(!r)continue;r.cliVersion!==ae&&(r.cliVersion=ae,C.setDoc(s,"project",r),t++)}catch{}t>0&&console.log(` ${me.green("\u2713")} Updated ${t} project(s) to v${ae}`)}catch(n){_(n)||B.warn(`Migration warning: ${k(n)}`)}}async function fp(n,e){let t={};if(await b(n))try{t=await Se(n)??{}}catch(s){if(!(s instanceof SyntaxError))throw s}t.statusLine={type:"command",command:e},await ie(n,t)}async function Hw(){try{let n=oe.join(Us.homedir(),".claude"),e=oe.join(n,"settings.json"),t=oe.join(n,"prjct-statusline.sh"),s=oe.join(Us.homedir(),".prjct-cli","statusline"),r=oe.join(s,"statusline.sh"),o=oe.join(s,"themes"),i=oe.join(s,"lib"),a=oe.join(s,"components"),c=oe.join(s,"config.json"),u=oe.join(jt,"assets","statusline"),d=oe.join(u,"statusline.sh"),m=oe.join(u,"themes"),p=oe.join(u,"lib"),g=oe.join(u,"components"),y=oe.join(u,"default-config.json");if(await b(n)||await Y.mkdir(n,{recursive:!0}),await b(s)||await Y.mkdir(s,{recursive:!0}),await b(o)||await Y.mkdir(o,{recursive:!0}),await b(i)||await Y.mkdir(i,{recursive:!0}),await b(a)||await Y.mkdir(a,{recursive:!0}),await b(r)){let j=await Y.readFile(r,"utf8");if(j.includes("CLI_VERSION=")){let T=j.match(/CLI_VERSION="([^"]*)"/);if(T&&T[1]!==ae){let x=j.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${ae}"`);await Y.writeFile(r,x,{mode:493})}await No(p,i),await No(g,a),await hp(t,r),await fp(e,t);return}}if(await b(d)){let j=await Y.readFile(d,"utf8");if(j=j.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${ae}"`),await Y.writeFile(r,j,{mode:493}),await No(p,i),await No(g,a),await b(m)){let T=await Y.readdir(m);for(let x of T){let S=oe.join(m,x),w=oe.join(o,x);await Y.copyFile(S,w)}}!await b(c)&&await b(y)&&await Y.copyFile(y,c)}else{let j=`#!/bin/bash
552
552
  # prjct Status Line for Claude Code
553
553
  CLI_VERSION="${ae}"
554
554
  input=$(cat)
@@ -579,7 +579,7 @@ if [ -f "$CONFIG" ]; then
579
579
  fi
580
580
  fi
581
581
  echo "prjct"
582
- `;await Y.writeFile(r,j,{mode:493})}await hp(t,r),await fp(e,t)}catch(n){_(n)||B.warn(`Status line warning: ${k(n)}`)}}async function _o(n,e){if(!await b(n))return;let t=await Y.readdir(n);for(let s of t)if(s.endsWith(".sh")){let r=oe.join(n,s),o=oe.join(e,s);await Y.copyFile(r,o),await Y.chmod(o,493)}}async function hp(n,e){try{if(await b(n)){if((await Y.lstat(n)).isSymbolicLink()&&await Y.readlink(n)===e)return;await Y.unlink(n)}await Y.symlink(e,n)}catch{try{await b(e)&&(await Y.copyFile(e,n),await Y.chmod(n,493))}catch(s){_(s)||B.warn(`Symlink fallback warning: ${s.message}`)}}}function Hw(n,e){if(console.log(""),n.cliInstalled?console.log(` ${me.green("\u2713")} ${e.displayName} CLI installed`):console.log(` ${me.green("\u2713")} ${e.displayName} CLI found`),n.commandsAdded+n.commandsUpdated>0){let s=[];n.commandsAdded>0&&s.push(`${n.commandsAdded} new`),n.commandsUpdated>0&&s.push(`${n.commandsUpdated} updated`),console.log(` ${me.green("\u2713")} Commands synced (${s.join(", ")})`)}else console.log(` ${me.green("\u2713")} Commands up to date`);n.configAction==="created"?console.log(` ${me.green("\u2713")} Global config created (${e.contextFile})`):n.configAction==="updated"?console.log(` ${me.green("\u2713")} Global config updated (${e.contextFile})`):n.configAction==="appended"&&console.log(` ${me.green("\u2713")} Global config merged (${e.contextFile})`),console.log("")}var yp,Ww,Cn=h(()=>{"use strict";Fs();Er();mp();ce();V();wo();J();yr();_s();ze();We();Wt();ro();La();l($w,"installAICLI");l(Dw,"run");l(Mw,"installGeminiRouter");l(_w,"installGeminiGlobalConfig");l(Nw,"installAntigravitySkill");yp="prjct-codex-router";l(wp,"getCodexSkillPath");l(Ow,"getCodexSkillMetadata");l(gp,"parseCodexSkillMetadata");l(Lw,"hashContent");l(kp,"loadCodexSkillTemplate");l(vp,"buildCodexSkillContent");l(ic,"installCodexSkill");l(En,"verifyCodexPRouterReady");l(Fw,"migrateProjectsCliVersion");l(fp,"ensureStatusLineSettings");l(Uw,"installStatusLine");l(_o,"installStatusLineModules");l(hp,"ensureStatusLineSymlink");l(Hw,"showResults");Ww=process.argv[1]?.includes("setup.ts")||process.argv[1]?.includes("setup.js");Ww&&Dw().catch(n=>{console.error("Setup error:",n.message),process.exit(1)})});import Q from"node:fs/promises";import X from"node:path";async function Oo(n){let e=Date.now(),t={success:!1,migratedFiles:[],skippedFiles:[],errors:[],backupDir:null,duration:0};try{if(C.exists(n)&&C.hasDoc(n,"state"))return t.success=!0,t.duration=Date.now()-e,t;let s=$.getGlobalProjectPath(n),r=X.join(s,"storage"),o=X.join(s,"index"),i=X.join(s,"memory");t.backupDir=await Gw(r,o,i),C.getDb(n);for(let{filename:c,key:u}of lc){let d=X.join(r,c),m=await At(d);if(m===null){t.skippedFiles.push(c);continue}try{C.setDoc(n,u,m),Sp(n,u,m),t.migratedFiles.push(c)}catch(p){t.errors.push({file:c,error:String(p)})}}for(let{filename:c,key:u}of cc){let d=X.join(o,c),m=await At(d);if(m===null){t.skippedFiles.push(`index/${c}`);continue}try{C.run(n,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",u,JSON.stringify(m),new Date().toISOString()),bp(n,u,m),t.migratedFiles.push(`index/${c}`)}catch(p){t.errors.push({file:`index/${c}`,error:String(p)})}}await Yw(n,o,t),await Qw(n,o,t),await Zw(n,i,t),await ek(n,i,t);let a=X.join(s,"sessions");return await tk(n,a,t),t.errors.length===0&&await sk(r,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 Gw(n,e,t){let s=X.join(n,"backup");return await Q.mkdir(s,{recursive:!0}),await Q.mkdir(X.join(s,"index"),{recursive:!0}),await Q.mkdir(X.join(s,"memory"),{recursive:!0}),await ac(n,s,r=>r.endsWith(".json")||r.endsWith(".jsonl")),await ac(e,X.join(s,"index")),await ac(t,X.join(s,"memory")),s}async function ac(n,e,t){try{let s=await Q.readdir(n,{withFileTypes:!0});for(let r of s){if(!r.isFile()||t&&!t(r.name))continue;let o=X.join(n,r.name),i=X.join(e,r.name);await Q.copyFile(o,i)}}catch(s){if(!_(s))throw s}}function Sp(n,e,t){switch(e){case"state":qw(n,t);break;case"queue":Vw(n,t);break;case"ideas":Bw(n,t);break;case"shipped":Jw(n,t);break;case"metrics":zw(n,t);break;case"analysis":Xw(n,t);break}}function qw(n,e){let t=C.getDb(n),s=t.prepare(`
582
+ `;await Y.writeFile(r,j,{mode:493})}await hp(t,r),await fp(e,t)}catch(n){_(n)||B.warn(`Status line warning: ${k(n)}`)}}async function No(n,e){if(!await b(n))return;let t=await Y.readdir(n);for(let s of t)if(s.endsWith(".sh")){let r=oe.join(n,s),o=oe.join(e,s);await Y.copyFile(r,o),await Y.chmod(o,493)}}async function hp(n,e){try{if(await b(n)){if((await Y.lstat(n)).isSymbolicLink()&&await Y.readlink(n)===e)return;await Y.unlink(n)}await Y.symlink(e,n)}catch{try{await b(e)&&(await Y.copyFile(e,n),await Y.chmod(n,493))}catch(s){_(s)||B.warn(`Symlink fallback warning: ${s.message}`)}}}function Ww(n,e){if(console.log(""),n.cliInstalled?console.log(` ${me.green("\u2713")} ${e.displayName} CLI installed`):console.log(` ${me.green("\u2713")} ${e.displayName} CLI found`),n.commandsAdded+n.commandsUpdated>0){let s=[];n.commandsAdded>0&&s.push(`${n.commandsAdded} new`),n.commandsUpdated>0&&s.push(`${n.commandsUpdated} updated`),console.log(` ${me.green("\u2713")} Commands synced (${s.join(", ")})`)}else console.log(` ${me.green("\u2713")} Commands up to date`);n.configAction==="created"?console.log(` ${me.green("\u2713")} Global config created (${e.contextFile})`):n.configAction==="updated"?console.log(` ${me.green("\u2713")} Global config updated (${e.contextFile})`):n.configAction==="appended"&&console.log(` ${me.green("\u2713")} Global config merged (${e.contextFile})`),console.log("")}var yp,Gw,Cn=h(()=>{"use strict";Fs();Er();mp();ce();V();ko();J();yr();_s();ze();We();Wt();oo();Ua();l(Dw,"installAICLI");l(Mw,"run");l(_w,"installGeminiRouter");l(Nw,"installGeminiGlobalConfig");l(Ow,"installAntigravitySkill");yp="prjct-codex-router";l(wp,"getCodexSkillPath");l(Lw,"getCodexSkillMetadata");l(gp,"parseCodexSkillMetadata");l(Fw,"hashContent");l(kp,"loadCodexSkillTemplate");l(vp,"buildCodexSkillContent");l(cc,"installCodexSkill");l(En,"verifyCodexPRouterReady");l(Uw,"migrateProjectsCliVersion");l(fp,"ensureStatusLineSettings");l(Hw,"installStatusLine");l(No,"installStatusLineModules");l(hp,"ensureStatusLineSymlink");l(Ww,"showResults");Gw=process.argv[1]?.includes("setup.ts")||process.argv[1]?.includes("setup.js");Gw&&Mw().catch(n=>{console.error("Setup error:",n.message),process.exit(1)})});import Q from"node:fs/promises";import X from"node:path";async function Lo(n){let e=Date.now(),t={success:!1,migratedFiles:[],skippedFiles:[],errors:[],backupDir:null,duration:0};try{if(C.exists(n)&&C.hasDoc(n,"state"))return t.success=!0,t.duration=Date.now()-e,t;let s=$.getGlobalProjectPath(n),r=X.join(s,"storage"),o=X.join(s,"index"),i=X.join(s,"memory");t.backupDir=await qw(r,o,i),C.getDb(n);for(let{filename:c,key:u}of dc){let d=X.join(r,c),m=await At(d);if(m===null){t.skippedFiles.push(c);continue}try{C.setDoc(n,u,m),Sp(n,u,m),t.migratedFiles.push(c)}catch(p){t.errors.push({file:c,error:String(p)})}}for(let{filename:c,key:u}of uc){let d=X.join(o,c),m=await At(d);if(m===null){t.skippedFiles.push(`index/${c}`);continue}try{C.run(n,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",u,JSON.stringify(m),new Date().toISOString()),bp(n,u,m),t.migratedFiles.push(`index/${c}`)}catch(p){t.errors.push({file:`index/${c}`,error:String(p)})}}await Qw(n,o,t),await Zw(n,o,t),await ek(n,i,t),await tk(n,i,t);let a=X.join(s,"sessions");return await sk(n,a,t),t.errors.length===0&&await nk(r,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 qw(n,e,t){let s=X.join(n,"backup");return await Q.mkdir(s,{recursive:!0}),await Q.mkdir(X.join(s,"index"),{recursive:!0}),await Q.mkdir(X.join(s,"memory"),{recursive:!0}),await lc(n,s,r=>r.endsWith(".json")||r.endsWith(".jsonl")),await lc(e,X.join(s,"index")),await lc(t,X.join(s,"memory")),s}async function lc(n,e,t){try{let s=await Q.readdir(n,{withFileTypes:!0});for(let r of s){if(!r.isFile()||t&&!t(r.name))continue;let o=X.join(n,r.name),i=X.join(e,r.name);await Q.copyFile(o,i)}}catch(s){if(!_(s))throw s}}function Sp(n,e,t){switch(e){case"state":Vw(n,t);break;case"queue":Bw(n,t);break;case"ideas":Jw(n,t);break;case"shipped":zw(n,t);break;case"metrics":Xw(n,t);break;case"analysis":Kw(n,t);break}}function Vw(n,e){let t=C.getDb(n),s=t.prepare(`
583
583
  INSERT OR REPLACE INTO tasks
584
584
  (id, description, type, status, parent_description, branch, linear_id,
585
585
  linear_uuid, session_id, feature_id, started_at, completed_at,
@@ -590,110 +590,110 @@ echo "prjct"
590
590
  (id, task_id, description, status, domain, agent, sort_order,
591
591
  depends_on, started_at, completed_at, output, summary)
592
592
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
593
- `),o=l((a,c)=>{if(!a||!a.id)return;s.run(A(a.id)??`task-${Date.now()}`,A(a.description??a.parentDescription)??"",A(a.type),A(c??a.status)??"unknown",A(a.parentDescription),A(a.branch),A(a.linearId),A(a.linearUuid),A(a.sessionId),A(a.featureId),A(a.startedAt)??new Date().toISOString(),A(a.completedAt),A(a.shippedAt),A(a.pausedAt),A(a.pauseReason),A(a.prUrl),a.expectedValue?JSON.stringify(a.expectedValue):null,JSON.stringify(a));let u=a.subtasks;if(u&&Array.isArray(u))for(let d=0;d<u.length;d++){let m=u[d];r.run(A(m.id)??`subtask-${d}`,A(a.id),A(m.description)??"",A(m.status)??"pending",A(m.domain),A(m.agent),d,m.dependsOn?JSON.stringify(m.dependsOn):null,A(m.startedAt),A(m.completedAt),A(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 Vw(n,e){let t=e.tasks;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
593
+ `),o=l((a,c)=>{if(!a||!a.id)return;s.run(A(a.id)??`task-${Date.now()}`,A(a.description??a.parentDescription)??"",A(a.type),A(c??a.status)??"unknown",A(a.parentDescription),A(a.branch),A(a.linearId),A(a.linearUuid),A(a.sessionId),A(a.featureId),A(a.startedAt)??new Date().toISOString(),A(a.completedAt),A(a.shippedAt),A(a.pausedAt),A(a.pauseReason),A(a.prUrl),a.expectedValue?JSON.stringify(a.expectedValue):null,JSON.stringify(a));let u=a.subtasks;if(u&&Array.isArray(u))for(let d=0;d<u.length;d++){let m=u[d];r.run(A(m.id)??`subtask-${d}`,A(a.id),A(m.description)??"",A(m.status)??"pending",A(m.domain),A(m.agent),d,m.dependsOn?JSON.stringify(m.dependsOn):null,A(m.startedAt),A(m.completedAt),A(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 Bw(n,e){let t=e.tasks;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
594
594
  INSERT OR REPLACE INTO queue_tasks
595
595
  (id, description, type, priority, section, created_at, completed, completed_at,
596
596
  feature_id, feature_name)
597
597
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
598
- `);for(let o of t)r.run(A(o.id)??`queue-${Date.now()}`,A(o.description)??"",A(o.type),A(o.priority),A(o.section),A(o.createdAt)??new Date().toISOString(),o.completed?1:0,A(o.completedAt),A(o.featureId),A(o.featureName))}function Bw(n,e){let t=e.ideas;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
598
+ `);for(let o of t)r.run(A(o.id)??`queue-${Date.now()}`,A(o.description)??"",A(o.type),A(o.priority),A(o.section),A(o.createdAt)??new Date().toISOString(),o.completed?1:0,A(o.completedAt),A(o.featureId),A(o.featureName))}function Jw(n,e){let t=e.ideas;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
599
599
  INSERT OR REPLACE INTO ideas
600
600
  (id, text, status, priority, tags, added_at, converted_to, details, data)
601
601
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
602
- `);for(let o of t)r.run(A(o.id)??`idea-${Date.now()}`,A(o.text)??"",A(o.status)??"pending",A(o.priority)??"medium",o.tags?JSON.stringify(o.tags):null,A(o.addedAt)??new Date().toISOString(),A(o.convertedTo),A(o.details),JSON.stringify(o))}function Jw(n,e){let t=e.shipped;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
602
+ `);for(let o of t)r.run(A(o.id)??`idea-${Date.now()}`,A(o.text)??"",A(o.status)??"pending",A(o.priority)??"medium",o.tags?JSON.stringify(o.tags):null,A(o.addedAt)??new Date().toISOString(),A(o.convertedTo),A(o.details),JSON.stringify(o))}function zw(n,e){let t=e.shipped;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
603
603
  INSERT OR REPLACE INTO shipped_features
604
604
  (id, name, shipped_at, version, description, type, duration, data)
605
605
  VALUES (?, ?, ?, ?, ?, ?, ?, ?)
606
- `);for(let o of t)r.run(A(o.id)??`ship-${Date.now()}`,A(o.name)??"",A(o.shippedAt)??new Date().toISOString(),A(o.version)??"0.0.0",A(o.description),A(o.type),A(o.duration),JSON.stringify(o))}function zw(n,e){let t=e.dailyStats;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
606
+ `);for(let o of t)r.run(A(o.id)??`ship-${Date.now()}`,A(o.name)??"",A(o.shippedAt)??new Date().toISOString(),A(o.version)??"0.0.0",A(o.description),A(o.type),A(o.duration),JSON.stringify(o))}function Xw(n,e){let t=e.dailyStats;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
607
607
  INSERT OR REPLACE INTO metrics_daily
608
608
  (date, tokens_saved, syncs, avg_compression_rate, total_duration)
609
609
  VALUES (?, ?, ?, ?, ?)
610
- `);for(let o of t)r.run(A(o.date)??new Date().toISOString().slice(0,10),ws(o.tokensSaved)??0,ws(o.syncs)??0,ws(o.avgCompressionRate)??0,ws(o.totalDuration)??0)}function Xw(n,e){let s=C.getDb(n).prepare(`
610
+ `);for(let o of t)r.run(A(o.date)??new Date().toISOString().slice(0,10),ws(o.tokensSaved)??0,ws(o.syncs)??0,ws(o.avgCompressionRate)??0,ws(o.totalDuration)??0)}function Kw(n,e){let s=C.getDb(n).prepare(`
611
611
  INSERT OR REPLACE INTO analysis
612
612
  (id, status, commit_hash, signature, sealed_at, analyzed_at, data)
613
613
  VALUES (?, ?, ?, ?, ?, ?, ?)
614
- `),r=l((o,i)=>{o&&s.run(i,A(o.status)??"unknown",A(o.commitHash),A(o.signature),A(o.sealedAt),A(o.analyzedAt),JSON.stringify(o))},"migrate");e.draft&&r(e.draft,"draft"),e.sealed&&r(e.sealed,"sealed")}function bp(n,e,t){e==="categories-cache"&&Kw(n,t)}function Kw(n,e){let t=e.fileCategories;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
614
+ `),r=l((o,i)=>{o&&s.run(i,A(o.status)??"unknown",A(o.commitHash),A(o.signature),A(o.sealedAt),A(o.analyzedAt),JSON.stringify(o))},"migrate");e.draft&&r(e.draft,"draft"),e.sealed&&r(e.sealed,"sealed")}function bp(n,e,t){e==="categories-cache"&&Yw(n,t)}function Yw(n,e){let t=e.fileCategories;if(!t||!Array.isArray(t))return;let r=C.getDb(n).prepare(`
615
615
  INSERT OR REPLACE INTO index_files
616
616
  (path, categories, domain, score, size, mtime, language)
617
617
  VALUES (?, ?, ?, COALESCE((SELECT score FROM index_files WHERE path = ?), 0), NULL, NULL, NULL)
618
- `);for(let o of t){let i=A(o.path);i&&r.run(i,o.categories?JSON.stringify(o.categories):null,A(o.primaryDomain),i)}}async function Yw(n,e,t){let s=X.join(e,"checksums.json"),r=await At(s);if(r===null){t.skippedFiles.push("index/checksums.json");return}try{let o=r.checksums;if(!o)return;let i=C.getDb(n),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 Qw(n,e,t){let s=X.join(e,"file-scores.json"),r=await At(s);if(r===null){t.skippedFiles.push("index/file-scores.json");return}try{let o=r.scores;if(!o||!Array.isArray(o))return;let i=C.getDb(n),a=i.prepare(`
618
+ `);for(let o of t){let i=A(o.path);i&&r.run(i,o.categories?JSON.stringify(o.categories):null,A(o.primaryDomain),i)}}async function Qw(n,e,t){let s=X.join(e,"checksums.json"),r=await At(s);if(r===null){t.skippedFiles.push("index/checksums.json");return}try{let o=r.checksums;if(!o)return;let i=C.getDb(n),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 Zw(n,e,t){let s=X.join(e,"file-scores.json"),r=await At(s);if(r===null){t.skippedFiles.push("index/file-scores.json");return}try{let o=r.scores;if(!o||!Array.isArray(o))return;let i=C.getDb(n),a=i.prepare(`
619
619
  INSERT OR REPLACE INTO index_files
620
620
  (path, score, size, mtime, language, categories, domain)
621
621
  VALUES (?, ?, ?, ?, NULL,
622
622
  COALESCE((SELECT categories FROM index_files WHERE path = ?), NULL),
623
623
  COALESCE((SELECT domain FROM index_files WHERE path = ?), NULL))
624
- `);i.transaction(()=>{for(let c of o){let u=A(c.path);u&&a.run(u,ws(c.score)??0,ws(c.size),A(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 Zw(n,e,t){let s=X.join(e,"events.jsonl");try{let o=(await Q.readFile(s,"utf-8")).split(`
625
- `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/events.jsonl");return}let i=C.getDb(n),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),d=A(u.type??u.action)??"unknown",m=A(u.taskId??u.task_id),p=A(u.timestamp??u.ts)??new Date().toISOString();a.run(d,m,c,p)}catch{}})(),t.migratedFiles.push("memory/events.jsonl")}catch(r){_(r)?t.skippedFiles.push("memory/events.jsonl"):t.errors.push({file:"memory/events.jsonl",error:String(r)})}}async function ek(n,e,t){let s=X.join(e,"learnings.jsonl");try{let o=(await Q.readFile(s,"utf-8")).split(`
626
- `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/learnings.jsonl");return}let i=C.getDb(n),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),d=`learning:${A(u.taskId??u.timestamp)??Date.now()}`,m=u.tags,p=m&&m.length>0?A(m[0]):null;a.run(d,p,c,1,A(u.timestamp)??new Date().toISOString())}catch{}})(),t.migratedFiles.push("memory/learnings.jsonl")}catch(r){_(r)?t.skippedFiles.push("memory/learnings.jsonl"):t.errors.push({file:"memory/learnings.jsonl",error:String(r)})}}async function tk(n,e,t){let r=C.getDb(n).prepare(`
624
+ `);i.transaction(()=>{for(let c of o){let u=A(c.path);u&&a.run(u,ws(c.score)??0,ws(c.size),A(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 ek(n,e,t){let s=X.join(e,"events.jsonl");try{let o=(await Q.readFile(s,"utf-8")).split(`
625
+ `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/events.jsonl");return}let i=C.getDb(n),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),d=A(u.type??u.action)??"unknown",m=A(u.taskId??u.task_id),p=A(u.timestamp??u.ts)??new Date().toISOString();a.run(d,m,c,p)}catch{}})(),t.migratedFiles.push("memory/events.jsonl")}catch(r){_(r)?t.skippedFiles.push("memory/events.jsonl"):t.errors.push({file:"memory/events.jsonl",error:String(r)})}}async function tk(n,e,t){let s=X.join(e,"learnings.jsonl");try{let o=(await Q.readFile(s,"utf-8")).split(`
626
+ `).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/learnings.jsonl");return}let i=C.getDb(n),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),d=`learning:${A(u.taskId??u.timestamp)??Date.now()}`,m=u.tags,p=m&&m.length>0?A(m[0]):null;a.run(d,p,c,1,A(u.timestamp)??new Date().toISOString())}catch{}})(),t.migratedFiles.push("memory/learnings.jsonl")}catch(r){_(r)?t.skippedFiles.push("memory/learnings.jsonl"):t.errors.push({file:"memory/learnings.jsonl",error:String(r)})}}async function sk(n,e,t){let r=C.getDb(n).prepare(`
627
627
  INSERT OR IGNORE INTO sessions
628
628
  (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
629
629
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
630
- `),o=l(u=>{!u||!u.id||r.run(A(u.id),A(u.projectId)??n,A(u.task)??"",A(u.status)??"completed",A(u.startedAt)??new Date().toISOString(),A(u.pausedAt),A(u.completedAt),ws(u.duration)??0,u.metrics?JSON.stringify(u.metrics):"{}",u.timeline?JSON.stringify(u.timeline):"[]")},"insertSession"),i=X.join(e,"current.json"),a=await At(i);if(a!==null)try{o(a),t.migratedFiles.push("sessions/current.json"),await Q.unlink(i).catch(()=>{})}catch(u){t.errors.push({file:"sessions/current.json",error:String(u)})}let c=X.join(e,"archive");try{let u=await Q.readdir(c);for(let m of u){let p=X.join(c,m);try{if(!(await Q.stat(p)).isDirectory())continue;let y=await Q.readdir(p);for(let T of y){if(!T.endsWith(".json"))continue;let x=X.join(p,T),S=await At(x);if(S!==null)try{o(S),t.migratedFiles.push(`sessions/archive/${m}/${T}`),await Q.unlink(x).catch(()=>{})}catch(w){t.errors.push({file:`sessions/archive/${m}/${T}`,error:String(w)})}}(await Q.readdir(p)).length===0&&await Q.rmdir(p).catch(()=>{})}catch{}}(await Q.readdir(c).catch(()=>[])).length===0&&await Q.rmdir(c).catch(()=>{})}catch{}try{(await Q.readdir(e)).length===0&&await Q.rmdir(e).catch(()=>{})}catch{}}async function sk(n,e,t,s){let r=l(async(i,a)=>{try{await Q.unlink(i)}catch(c){_(c)||s.errors.push({file:a,error:`cleanup: ${String(c)}`})}},"deleteFile");for(let{filename:i}of lc)await r(X.join(n,i),`cleanup:${i}`);let o=["project-index.json","domains.json","categories-cache.json","checksums.json","file-scores.json"];for(let i of o)await r(X.join(e,i),`cleanup:index/${i}`);await r(X.join(t,"events.jsonl"),"cleanup:memory/events.jsonl"),await r(X.join(t,"learnings.jsonl"),"cleanup:memory/learnings.jsonl")}function A(n){return n==null?null:typeof n=="string"?n:typeof n=="number"||typeof n=="boolean"||typeof n=="bigint"?String(n):JSON.stringify(n)}function ws(n){if(n==null)return null;if(typeof n=="number")return n;if(typeof n=="string"){let e=Number(n);return Number.isNaN(e)?null:e}return null}async function At(n){try{let e=await Q.readFile(n,"utf-8");return JSON.parse(e)}catch(e){if(_(e)||e instanceof SyntaxError)return null;throw e}}async function Lo(n){let e=$.getGlobalProjectPath(n),t=X.join(e,"storage"),s=0;C.getDb(n);for(let{filename:y,key:j}of lc){let T=X.join(t,y),x=await At(T);if(x!==null){C.setDoc(n,j,x),Sp(n,j,x);try{await Q.unlink(T)}catch{}s++}}let r=X.join(e,"project.json"),o=await At(r);if(o!==null){C.setDoc(n,"project",o);try{await Q.unlink(r)}catch{}s++}let i=X.join(e,"memory");for(let y of["events.jsonl","learnings.jsonl"]){let j=X.join(i,y);try{let x=(await Q.readFile(j,"utf-8")).split(`
630
+ `),o=l(u=>{!u||!u.id||r.run(A(u.id),A(u.projectId)??n,A(u.task)??"",A(u.status)??"completed",A(u.startedAt)??new Date().toISOString(),A(u.pausedAt),A(u.completedAt),ws(u.duration)??0,u.metrics?JSON.stringify(u.metrics):"{}",u.timeline?JSON.stringify(u.timeline):"[]")},"insertSession"),i=X.join(e,"current.json"),a=await At(i);if(a!==null)try{o(a),t.migratedFiles.push("sessions/current.json"),await Q.unlink(i).catch(()=>{})}catch(u){t.errors.push({file:"sessions/current.json",error:String(u)})}let c=X.join(e,"archive");try{let u=await Q.readdir(c);for(let m of u){let p=X.join(c,m);try{if(!(await Q.stat(p)).isDirectory())continue;let y=await Q.readdir(p);for(let T of y){if(!T.endsWith(".json"))continue;let x=X.join(p,T),S=await At(x);if(S!==null)try{o(S),t.migratedFiles.push(`sessions/archive/${m}/${T}`),await Q.unlink(x).catch(()=>{})}catch(w){t.errors.push({file:`sessions/archive/${m}/${T}`,error:String(w)})}}(await Q.readdir(p)).length===0&&await Q.rmdir(p).catch(()=>{})}catch{}}(await Q.readdir(c).catch(()=>[])).length===0&&await Q.rmdir(c).catch(()=>{})}catch{}try{(await Q.readdir(e)).length===0&&await Q.rmdir(e).catch(()=>{})}catch{}}async function nk(n,e,t,s){let r=l(async(i,a)=>{try{await Q.unlink(i)}catch(c){_(c)||s.errors.push({file:a,error:`cleanup: ${String(c)}`})}},"deleteFile");for(let{filename:i}of dc)await r(X.join(n,i),`cleanup:${i}`);let o=["project-index.json","domains.json","categories-cache.json","checksums.json","file-scores.json"];for(let i of o)await r(X.join(e,i),`cleanup:index/${i}`);await r(X.join(t,"events.jsonl"),"cleanup:memory/events.jsonl"),await r(X.join(t,"learnings.jsonl"),"cleanup:memory/learnings.jsonl")}function A(n){return n==null?null:typeof n=="string"?n:typeof n=="number"||typeof n=="boolean"||typeof n=="bigint"?String(n):JSON.stringify(n)}function ws(n){if(n==null)return null;if(typeof n=="number")return n;if(typeof n=="string"){let e=Number(n);return Number.isNaN(e)?null:e}return null}async function At(n){try{let e=await Q.readFile(n,"utf-8");return JSON.parse(e)}catch(e){if(_(e)||e instanceof SyntaxError)return null;throw e}}async function Fo(n){let e=$.getGlobalProjectPath(n),t=X.join(e,"storage"),s=0;C.getDb(n);for(let{filename:y,key:j}of dc){let T=X.join(t,y),x=await At(T);if(x!==null){C.setDoc(n,j,x),Sp(n,j,x);try{await Q.unlink(T)}catch{}s++}}let r=X.join(e,"project.json"),o=await At(r);if(o!==null){C.setDoc(n,"project",o);try{await Q.unlink(r)}catch{}s++}let i=X.join(e,"memory");for(let y of["events.jsonl","learnings.jsonl"]){let j=X.join(i,y);try{let x=(await Q.readFile(j,"utf-8")).split(`
631
631
  `).filter(w=>w.trim());if(x.length===0){await Q.unlink(j),s++;continue}let S=C.getDb(n);if(y==="events.jsonl"){let w=S.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)");S.transaction(()=>{for(let P of x)try{let v=JSON.parse(P);w.run(A(v.type??v.action)??"unknown",A(v.taskId??v.task_id),P,A(v.timestamp??v.ts)??new Date().toISOString())}catch{}})()}else{let w=S.prepare("INSERT OR REPLACE INTO memory (key, domain, value, confidence, updated_at) VALUES (?, ?, ?, ?, ?)");S.transaction(()=>{for(let P of x)try{let v=JSON.parse(P),M=`learning:${A(v.taskId??v.timestamp)??Date.now()}`,F=v.tags;w.run(M,A(F?.[0]),P,1,A(v.timestamp)??new Date().toISOString())}catch{}})()}await Q.unlink(j),s++}catch{}}let a=X.join(e,"sessions"),c=l(y=>{if(!y||!y.id)return;C.getDb(n).prepare(`
632
632
  INSERT OR IGNORE INTO sessions
633
633
  (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
634
634
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
635
- `).run(A(y.id),A(y.projectId)??n,A(y.task)??"",A(y.status)??"completed",A(y.startedAt)??new Date().toISOString(),A(y.pausedAt),A(y.completedAt),ws(y.duration)??0,y.metrics?JSON.stringify(y.metrics):"{}",y.timeline?JSON.stringify(y.timeline):"[]")},"sessionInsert"),u=X.join(a,"current.json"),d=await At(u);d!==null&&(c(d),await Q.unlink(u).catch(()=>{}),s++);let m=X.join(a,"archive");try{let y=await Q.readdir(m);for(let T of y){let x=X.join(m,T);try{if(!(await Q.stat(x)).isDirectory())continue;let w=await Q.readdir(x);for(let v of w){if(!v.endsWith(".json"))continue;let M=await At(X.join(x,v));M!==null&&(c(M),await Q.unlink(X.join(x,v)).catch(()=>{}),s++)}(await Q.readdir(x)).length===0&&await Q.rmdir(x).catch(()=>{})}catch{}}(await Q.readdir(m).catch(()=>[])).length===0&&await Q.rmdir(m).catch(()=>{})}catch{}try{(await Q.readdir(a)).length===0&&await Q.rmdir(a).catch(()=>{})}catch{}let p=X.join(e,"index"),g=[...cc.map(y=>y.filename),"checksums.json","file-scores.json"];for(let y of g){let j=X.join(p,y),T=await At(j);if(T===null)continue;let x=cc.find(S=>S.filename===y);x&&(C.run(n,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",x.key,JSON.stringify(T),new Date().toISOString()),bp(n,x.key,T));try{await Q.unlink(j)}catch{}s++}return s}var lc,cc,uc=h(()=>{"use strict";Re();V();ce();lc=[{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"}],cc=[{filename:"project-index.json",key:"project-index"},{filename:"domains.json",key:"domains"},{filename:"categories-cache.json",key:"categories-cache"}];l(Oo,"migrateJsonToSqlite");l(Gw,"createBackup");l(ac,"copyFiles");l(Sp,"populateNormalized");l(qw,"populateTasksFromState");l(Vw,"populateQueueTasks");l(Bw,"populateIdeas");l(Jw,"populateShippedFeatures");l(zw,"populateMetricsDaily");l(Xw,"populateAnalysis");l(bp,"populateIndexTables");l(Kw,"populateCategoriesIndex");l(Yw,"migrateChecksums");l(Qw,"migrateFileScores");l(Zw,"migrateEventsJsonl");l(ek,"migrateLearningsJsonl");l(tk,"migrateSessionFiles");l(sk,"cleanupJsonFiles");l(A,"toStr");l(ws,"toNum");l(At,"readJsonSafe");l(Lo,"sweepLegacyJson")});import dc from"node:fs/promises";import Fo from"node:path";var pc,mc,Tp,Ep=h(()=>{"use strict";V();J();pc=".prjct/.prjct-state.md",mc=class{static{l(this,"LocalStateGenerator")}async generate(e,t){let s=Fo.join(e,pc);await dc.mkdir(Fo.dirname(s),{recursive:!0});let r=this.toMarkdown(t);await dc.writeFile(s,r,"utf-8")}async remove(e){try{await dc.unlink(Fo.join(e,pc))}catch(t){if(!_(t))throw t}}async exists(e){let t=Fo.join(e,pc);return b(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",d=c===s.currentSubtaskIndex?" \u2190 **Active**":"";t.push(`${c+1}. ${u} ${a.description}${d}`)}),t.push("");let r=s.subtasks.filter(a=>a.status==="completed").length,o=s.subtasks.length,i=Math.round(r/o*100);t.push(`**Progress**: ${r}/${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(`
636
- `)}},Tp=new mc});var gc,Ye,ks=h(()=>{"use strict";de();ms();ce();gc=class{static{l(this,"MemoryService")}async log(e,t,s,r){try{let o=await I.getProjectId(e);if(!o)return;L.appendEvent(o,`memory.${t}`,{...s,author:r})}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?L.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 r=await this.getRecent(e,1e3),o=t.toLowerCase();return r.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 r=await I.getProjectId(e);return r?L.query(r,"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(r){return console.error(`Memory read error: ${r instanceof Error?r.message:String(r)}`),[]}}async clear(e){try{let t=await I.getProjectId(e);if(!t)return;L.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 L.query(e,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(r=>{let o=JSON.parse(r.data);return{timestamp:r.timestamp,action:r.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=L.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(s<=Zt.MEMORY_MAX_ENTRIES)return 0;let r=s-Zt.MEMORY_MAX_ENTRIES,o=L.query(e,"SELECT id, type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?",r);tt.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&&L.run(e,"DELETE FROM events WHERE type LIKE 'memory.%' AND id <= ?",i),r}catch(t){return console.error(`Memory cap error: ${t instanceof Error?t.message:String(t)}`),0}}},Ye=new gc});import nk from"node:path";function rk(n){return Ju(nk.resolve(n))}function Cr(n){return n.toLowerCase().replace(/[^a-z0-9]+/g,"")}function ok(n){return oa(n,e=>`${Cr(e.name)}::${Cr(e.source)}`)}function ik(n){return oa(n,e=>`${Cr(e.issue)}::${Cr(e.file)}::${Cr(e.source)}`)}var fc,ak,Cp,Pp=h(()=>{"use strict";ce();ia();yr();l(rk,"repoHash");l(Cr,"normalizeKey");l(ok,"dedupePatterns");l(ik,"dedupeAntiPatterns");fc=class{static{l(this,"PatternExtractor")}async extract(e){let t=rk(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 r=(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=ok([...s,...r]),a=ik([...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}}},ak=new fc,Cp=ak});import Pr from"node:fs/promises";import ck from"node:os";import jr from"node:path";function lk(n){return`# ${n.projectName}
637
- ${n.stack} | ${n.fileCount} files | v${n.version} | Branch: ${n.branch}`}function uk(n){return n.patterns.length===0?"":`
635
+ `).run(A(y.id),A(y.projectId)??n,A(y.task)??"",A(y.status)??"completed",A(y.startedAt)??new Date().toISOString(),A(y.pausedAt),A(y.completedAt),ws(y.duration)??0,y.metrics?JSON.stringify(y.metrics):"{}",y.timeline?JSON.stringify(y.timeline):"[]")},"sessionInsert"),u=X.join(a,"current.json"),d=await At(u);d!==null&&(c(d),await Q.unlink(u).catch(()=>{}),s++);let m=X.join(a,"archive");try{let y=await Q.readdir(m);for(let T of y){let x=X.join(m,T);try{if(!(await Q.stat(x)).isDirectory())continue;let w=await Q.readdir(x);for(let v of w){if(!v.endsWith(".json"))continue;let M=await At(X.join(x,v));M!==null&&(c(M),await Q.unlink(X.join(x,v)).catch(()=>{}),s++)}(await Q.readdir(x)).length===0&&await Q.rmdir(x).catch(()=>{})}catch{}}(await Q.readdir(m).catch(()=>[])).length===0&&await Q.rmdir(m).catch(()=>{})}catch{}try{(await Q.readdir(a)).length===0&&await Q.rmdir(a).catch(()=>{})}catch{}let p=X.join(e,"index"),g=[...uc.map(y=>y.filename),"checksums.json","file-scores.json"];for(let y of g){let j=X.join(p,y),T=await At(j);if(T===null)continue;let x=uc.find(S=>S.filename===y);x&&(C.run(n,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",x.key,JSON.stringify(T),new Date().toISOString()),bp(n,x.key,T));try{await Q.unlink(j)}catch{}s++}return s}var dc,uc,pc=h(()=>{"use strict";Re();V();ce();dc=[{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"}],uc=[{filename:"project-index.json",key:"project-index"},{filename:"domains.json",key:"domains"},{filename:"categories-cache.json",key:"categories-cache"}];l(Lo,"migrateJsonToSqlite");l(qw,"createBackup");l(lc,"copyFiles");l(Sp,"populateNormalized");l(Vw,"populateTasksFromState");l(Bw,"populateQueueTasks");l(Jw,"populateIdeas");l(zw,"populateShippedFeatures");l(Xw,"populateMetricsDaily");l(Kw,"populateAnalysis");l(bp,"populateIndexTables");l(Yw,"populateCategoriesIndex");l(Qw,"migrateChecksums");l(Zw,"migrateFileScores");l(ek,"migrateEventsJsonl");l(tk,"migrateLearningsJsonl");l(sk,"migrateSessionFiles");l(nk,"cleanupJsonFiles");l(A,"toStr");l(ws,"toNum");l(At,"readJsonSafe");l(Fo,"sweepLegacyJson")});import mc from"node:fs/promises";import Uo from"node:path";var gc,fc,Tp,Ep=h(()=>{"use strict";V();J();gc=".prjct/.prjct-state.md",fc=class{static{l(this,"LocalStateGenerator")}async generate(e,t){let s=Uo.join(e,gc);await mc.mkdir(Uo.dirname(s),{recursive:!0});let r=this.toMarkdown(t);await mc.writeFile(s,r,"utf-8")}async remove(e){try{await mc.unlink(Uo.join(e,gc))}catch(t){if(!_(t))throw t}}async exists(e){let t=Uo.join(e,gc);return b(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",d=c===s.currentSubtaskIndex?" \u2190 **Active**":"";t.push(`${c+1}. ${u} ${a.description}${d}`)}),t.push("");let r=s.subtasks.filter(a=>a.status==="completed").length,o=s.subtasks.length,i=Math.round(r/o*100);t.push(`**Progress**: ${r}/${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(`
636
+ `)}},Tp=new fc});var hc,Ye,ks=h(()=>{"use strict";de();ms();ce();hc=class{static{l(this,"MemoryService")}async log(e,t,s,r){try{let o=await I.getProjectId(e);if(!o)return;L.appendEvent(o,`memory.${t}`,{...s,author:r})}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?L.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 r=await this.getRecent(e,1e3),o=t.toLowerCase();return r.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 r=await I.getProjectId(e);return r?L.query(r,"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(r){return console.error(`Memory read error: ${r instanceof Error?r.message:String(r)}`),[]}}async clear(e){try{let t=await I.getProjectId(e);if(!t)return;L.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 L.query(e,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(r=>{let o=JSON.parse(r.data);return{timestamp:r.timestamp,action:r.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=L.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(s<=es.MEMORY_MAX_ENTRIES)return 0;let r=s-es.MEMORY_MAX_ENTRIES,o=L.query(e,"SELECT id, type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?",r);st.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&&L.run(e,"DELETE FROM events WHERE type LIKE 'memory.%' AND id <= ?",i),r}catch(t){return console.error(`Memory cap error: ${t instanceof Error?t.message:String(t)}`),0}}},Ye=new hc});import rk from"node:path";function ok(n){return Ju(rk.resolve(n))}function Cr(n){return n.toLowerCase().replace(/[^a-z0-9]+/g,"")}function ik(n){return aa(n,e=>`${Cr(e.name)}::${Cr(e.source)}`)}function ak(n){return aa(n,e=>`${Cr(e.issue)}::${Cr(e.file)}::${Cr(e.source)}`)}var yc,ck,Cp,Pp=h(()=>{"use strict";ce();ca();yr();l(ok,"repoHash");l(Cr,"normalizeKey");l(ik,"dedupePatterns");l(ak,"dedupeAntiPatterns");yc=class{static{l(this,"PatternExtractor")}async extract(e){let t=ok(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 r=(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=ik([...s,...r]),a=ak([...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}}},ck=new yc,Cp=ck});import Pr from"node:fs/promises";import lk from"node:os";import jr from"node:path";function uk(n){return`# ${n.projectName}
637
+ ${n.stack} | ${n.fileCount} files | v${n.version} | Branch: ${n.branch}`}function dk(n){return n.patterns.length===0?"":`
638
638
  ## Patterns
639
639
  ${n.patterns.slice(0,6).map(t=>`- **${t.name}**: ${t.description}${t.location?` (${t.location})`:""}`).join(`
640
640
  `)}
641
- `}function dk(n){if(n.antiPatterns.length===0)return"";let e={high:"HIGH",medium:"MEDIUM",low:"LOW"};return`
641
+ `}function pk(n){if(n.antiPatterns.length===0)return"";let e={high:"HIGH",medium:"MEDIUM",low:"LOW"};return`
642
642
  ## Anti-Patterns
643
643
  ${n.antiPatterns.slice(0,6).map(s=>`- ${e[s.severity]||"MEDIUM"}: ${s.issue} in \`${s.file}\` \u2014 ${s.suggestion}`).join(`
644
644
  `)}
645
- `}function pk(n){return n.knownGotchas.length===0?"":`
645
+ `}function mk(n){return n.knownGotchas.length===0?"":`
646
646
  ## Known Gotchas
647
647
  ${n.knownGotchas.slice(0,5).map(t=>`- ${t}`).join(`
648
648
  `)}
649
- `}function mk(n){return n.recentShipped.length===0?"":`
649
+ `}function gk(n){return n.recentShipped.length===0?"":`
650
650
  ## Recent Deliveries
651
651
  ${n.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(`
652
652
  `)}
653
- `}function gk(n){if(!n.velocity)return"";let e=[];return n.velocity.avgPoints!=null&&e.push(`${n.velocity.avgPoints} pts/sprint`),n.velocity.trend&&e.push(n.velocity.trend),n.velocity.accuracy!=null&&e.push(`Estimation accuracy: ${n.velocity.accuracy}%`),e.length===0?"":`
653
+ `}function fk(n){if(!n.velocity)return"";let e=[];return n.velocity.avgPoints!=null&&e.push(`${n.velocity.avgPoints} pts/sprint`),n.velocity.trend&&e.push(n.velocity.trend),n.velocity.accuracy!=null&&e.push(`Estimation accuracy: ${n.velocity.accuracy}%`),e.length===0?"":`
654
654
  ## Velocity
655
655
  ${e.join(" | ")}
656
- `}function fk(n){let e=[["Build",n.build],["Test",n.test],["Lint",n.lint],["Dev",n.dev],["Format",n.format]].filter(([t,s])=>s);return e.length===0?"":`
656
+ `}function hk(n){let e=[["Build",n.build],["Test",n.test],["Lint",n.lint],["Dev",n.dev],["Format",n.format]].filter(([t,s])=>s);return e.length===0?"":`
657
657
  ## Commands
658
658
  | Action | Command |
659
659
  |--------|---------|
660
660
  ${e.map(([t,s])=>`| ${t} | \`${s}\` |`).join(`
661
661
  `)}
662
- `}function hk(n){let e=[];if(n.hasActiveTask&&e.push(`Active task: **${n.activeTaskDescription}**`),n.pausedTasks.length>0)for(let s of n.pausedTasks.slice(0,3))e.push(`Paused: ${s.description} (${s.pausedAt})`);if(n.backlogCount>0){let s=n.topBacklog.slice(0,3).map(r=>`${r.description} [${r.priority}]`).join(", ");e.push(`Backlog: ${n.backlogCount} items${s?` \u2014 ${s}`:""}`)}let t=[];return n.ideasCount>0&&t.push(`Ideas: ${n.ideasCount} pending`),n.shippedCount>0&&t.push(`Shipped: ${n.shippedCount}`),t.length>0&&e.push(t.join(" | ")),e.length===0?"":`
662
+ `}function yk(n){let e=[];if(n.hasActiveTask&&e.push(`Active task: **${n.activeTaskDescription}**`),n.pausedTasks.length>0)for(let s of n.pausedTasks.slice(0,3))e.push(`Paused: ${s.description} (${s.pausedAt})`);if(n.backlogCount>0){let s=n.topBacklog.slice(0,3).map(r=>`${r.description} [${r.priority}]`).join(", ");e.push(`Backlog: ${n.backlogCount} items${s?` \u2014 ${s}`:""}`)}let t=[];return n.ideasCount>0&&t.push(`Ideas: ${n.ideasCount} pending`),n.shippedCount>0&&t.push(`Shipped: ${n.shippedCount}`),t.length>0&&e.push(t.join(" | ")),e.length===0?"":`
663
663
  ## State
664
664
  ${e.join(`
665
665
  `)}
666
- `}function yk(n){return n.userPatterns.length===0?"":`
666
+ `}function wk(n){return n.userPatterns.length===0?"":`
667
667
  ## User Patterns
668
668
  ${n.userPatterns.slice(0,8).map(t=>`- ${t}`).join(`
669
669
  `)}
670
- `}function wk(n){return[uk(n),dk(n),pk(n),mk(n),gk(n),fk(n.commands),hk(n),yk(n)].filter(Boolean).join("")}function kk(n){return["# prjct","","## Use when","","You want to:","- recall prior project decisions, learnings, or shipped features","- capture a thought, todo, or insight without a commitment","- run a workflow the project already registered","- understand your role and the MCPs available in this project","","## What's here","",lk(n),"",wk(n),"","### Primitives","",'- `prjct capture "<anything>"` \u2014 inbox dump (zero ceremony)','- `prjct remember <type> "<content>" [--tags]` \u2014 typed memory entry',"- `prjct context memory [topic]` \u2014 recall with optional keyword filter","- `prjct workflow list` / `prjct workflow run <name>` \u2014 registered workflows","- `prjct seed list` \u2014 active packs (memory types + workflow slots)","","Base memory types: `fact \xB7 decision \xB7 learning \xB7 gotcha \xB7 pattern \xB7 anti-pattern \xB7 shipped \xB7 inbox \xB7 todo \xB7 idea \xB7 insight \xB7 question \xB7 source \xB7 person`. Any lowercase string works (e.g. `recipe`, `okr`, `stakeholder`).","","### Data paths","","- `.prjct/wiki/_generated/` \u2014 agent-crawlable markdown (regenerated on ship/remember)","- `.prjct/wiki/captured/` \u2014 drop notes with frontmatter, run `prjct context wiki sync` to ingest","- `.prjct/prjct.config.json` \u2014 persona + active packs","","## Gotchas","",'- Memory recall is best-effort \u2014 an empty result means no match, not "nothing exists".',"- Tags are freeform strings \u2014 reuse existing vocabulary before inventing new keys.","- Secret-like content is refused by `remember` and `capture` unless `--force`.",'- Bare `prjct "<text>"` routes to `capture` (inbox), not `task`. Use `prjct task` explicitly for work that needs a branch/worktree.',"- Hooks in `~/.claude/settings.json` already inject persona + topical memory on SessionStart / UserPromptSubmit \u2014 you rarely need to call prjct by hand at session start.",""].join(`
671
- `)}function vk(n,e){let t=n.userInvocable!==!1;return`---
670
+ `}function kk(n){return[dk(n),pk(n),mk(n),gk(n),fk(n),hk(n.commands),yk(n),wk(n)].filter(Boolean).join("")}function vk(n){return["# prjct","","## Use when","","You want to:","- recall prior project decisions, learnings, or shipped features","- capture a thought, todo, or insight without a commitment","- run a workflow the project already registered","- understand your role and the MCPs available in this project","","## What's here","",uk(n),"",kk(n),"","### Primitives","",'- `prjct capture "<anything>"` \u2014 inbox dump (zero ceremony)','- `prjct remember <type> "<content>" [--tags]` \u2014 typed memory entry',"- `prjct context memory [topic]` \u2014 recall with optional keyword filter","- `prjct workflow list` / `prjct workflow run <name>` \u2014 registered workflows","- `prjct seed list` \u2014 active packs (memory types + workflow slots)","","Base memory types: `fact \xB7 decision \xB7 learning \xB7 gotcha \xB7 pattern \xB7 anti-pattern \xB7 shipped \xB7 inbox \xB7 todo \xB7 idea \xB7 insight \xB7 question \xB7 source \xB7 person`. Any lowercase string works (e.g. `recipe`, `okr`, `stakeholder`).","","### Data paths","","- `.prjct/wiki/_generated/` \u2014 agent-crawlable markdown (regenerated on ship/remember)","- `.prjct/wiki/captured/` \u2014 drop notes with frontmatter, run `prjct context wiki sync` to ingest","- `.prjct/prjct.config.json` \u2014 persona + active packs","","## Gotchas","",'- Memory recall is best-effort \u2014 an empty result means no match, not "nothing exists".',"- Tags are freeform strings \u2014 reuse existing vocabulary before inventing new keys.","- Secret-like content is refused by `remember` and `capture` unless `--force`.",'- Bare `prjct "<text>"` routes to `capture` (inbox), not `task`. Use `prjct task` explicitly for work that needs a branch/worktree.',"- Hooks in `~/.claude/settings.json` already inject persona + topical memory on SessionStart / UserPromptSubmit \u2014 you rarely need to call prjct by hand at session start.",""].join(`
671
+ `)}function Sk(n,e){let t=n.userInvocable!==!1;return`---
672
672
  description: "${n.description} (${e.projectName}, ${e.stack})"
673
673
  allowed-tools: [${n.allowedTools.map(s=>`"${s}"`).join(", ")}]
674
674
  user-invocable: ${t}
675
- ---`}function Sk(n,e){return`${vk(n,e)}
675
+ ---`}function bk(n,e){return`${Sk(n,e)}
676
676
 
677
- ${n.body(e)}`}var hc,yc,jp,Rp=h(()=>{"use strict";ds();_s();l(lk,"formatProjectHeader");l(uk,"formatPatterns");l(dk,"formatAntiPatterns");l(pk,"formatGotchas");l(mk,"formatRecentShipped");l(gk,"formatVelocity");l(fk,"formatCommands");l(hk,"formatState");l(yk,"formatUserPatterns");l(wk,"formatRichContext");hc=[{name:"prjct",description:"Persona-aware project memory + workflows. Use when you need prior decisions, learnings, or to run a registered workflow.",allowedTools:["Bash","Read","Write","Edit","Glob","Grep","Task"],condition:l(()=>!0,"condition"),body:l(n=>kk(n),"body")}];l(kk,"buildPrjctSkillBody");l(vk,"buildFrontmatter");l(Sk,"buildSkillContent");yc=class{static{l(this,"SkillGenerator")}async generateAndInstall(e,t={backlogCount:0,completedTaskCount:0,pausedTaskCount:0,hasActiveTask:!1},s){let r={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=jr.join(ck.homedir(),".claude","skills");for(let c of hc){if(!c.condition(t)){r.skipped.push({name:c.name,reason:"condition not met"}),await Pr.rm(jr.join(i,c.name),{recursive:!0,force:!0}).catch(()=>{});continue}try{let u=Sk(c,o),d=jr.join(i,c.name),m=jr.join(d,"SKILL.md");await Pr.mkdir(d,{recursive:!0}),await Pr.writeFile(m,u,"utf-8"),r.generated.push({name:c.name,path:m})}catch(u){B.debug(`Failed to generate skill ${c.name}`,{error:ge(u)}),r.skipped.push({name:c.name,reason:ge(u)})}}let a=new Set(hc.map(c=>c.name));try{let c=await Pr.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let u of c)u.isDirectory()&&u.name.startsWith("prjct-")&&!a.has(u.name)&&await Pr.rm(jr.join(i,u.name),{recursive:!0,force:!0}).catch(()=>{})}catch{}return r.generated.length>0&&B.info("Generated native workflow skills",{count:r.generated.length,skills:r.generated.map(c=>c.name)}),r}getDefinitions(){return hc}},jp=new yc});var xp=h(()=>{"use strict"});import bk from"node:fs/promises";import Ap from"node:path";var Uo,Ip=h(()=>{"use strict";J();Uo=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(r=>e[r])&&(t.hasBackend=!0)}detectDatabase(e,t){["prisma","@prisma/client","mongoose","pg","mysql2","sequelize","typeorm","drizzle-orm","knex","better-sqlite3","mongodb","redis","ioredis"].some(r=>e[r])&&(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 bk.readFile(e,"utf-8");return JSON.parse(t)}catch{return null}}async fileExistsInProject(e){return b(Ap.join(this.projectPath,e))}}});import wc from"node:path";async function $p(n){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:n});e.branch=t.trim()||"main";let{stdout:s}=await O("git rev-list --count HEAD",{cwd:n});e.commits=parseInt(s.trim(),10)||0;let{stdout:r}=await O("git shortlog -sn --all | wc -l",{cwd:n});e.contributors=parseInt(r.trim(),10)||0;let{stdout:o}=await O("git status --porcelain",{cwd:n}),i=o.trim().split(`
677
+ ${n.body(e)}`}var wc,kc,jp,Rp=h(()=>{"use strict";ds();_s();l(uk,"formatProjectHeader");l(dk,"formatPatterns");l(pk,"formatAntiPatterns");l(mk,"formatGotchas");l(gk,"formatRecentShipped");l(fk,"formatVelocity");l(hk,"formatCommands");l(yk,"formatState");l(wk,"formatUserPatterns");l(kk,"formatRichContext");wc=[{name:"prjct",description:"Persona-aware project memory + workflows. Use when you need prior decisions, learnings, or to run a registered workflow.",allowedTools:["Bash","Read","Write","Edit","Glob","Grep","Task"],condition:l(()=>!0,"condition"),body:l(n=>vk(n),"body")}];l(vk,"buildPrjctSkillBody");l(Sk,"buildFrontmatter");l(bk,"buildSkillContent");kc=class{static{l(this,"SkillGenerator")}async generateAndInstall(e,t={backlogCount:0,completedTaskCount:0,pausedTaskCount:0,hasActiveTask:!1},s){let r={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=jr.join(lk.homedir(),".claude","skills");for(let c of wc){if(!c.condition(t)){r.skipped.push({name:c.name,reason:"condition not met"}),await Pr.rm(jr.join(i,c.name),{recursive:!0,force:!0}).catch(()=>{});continue}try{let u=bk(c,o),d=jr.join(i,c.name),m=jr.join(d,"SKILL.md");await Pr.mkdir(d,{recursive:!0}),await Pr.writeFile(m,u,"utf-8"),r.generated.push({name:c.name,path:m})}catch(u){B.debug(`Failed to generate skill ${c.name}`,{error:ge(u)}),r.skipped.push({name:c.name,reason:ge(u)})}}let a=new Set(wc.map(c=>c.name));try{let c=await Pr.readdir(i,{withFileTypes:!0}).catch(()=>[]);for(let u of c)u.isDirectory()&&u.name.startsWith("prjct-")&&!a.has(u.name)&&await Pr.rm(jr.join(i,u.name),{recursive:!0,force:!0}).catch(()=>{})}catch{}return r.generated.length>0&&B.info("Generated native workflow skills",{count:r.generated.length,skills:r.generated.map(c=>c.name)}),r}getDefinitions(){return wc}},jp=new kc});var xp=h(()=>{"use strict"});import Tk from"node:fs/promises";import Ap from"node:path";var Ho,Ip=h(()=>{"use strict";J();Ho=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(r=>e[r])&&(t.hasBackend=!0)}detectDatabase(e,t){["prisma","@prisma/client","mongoose","pg","mysql2","sequelize","typeorm","drizzle-orm","knex","better-sqlite3","mongodb","redis","ioredis"].some(r=>e[r])&&(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 Tk.readFile(e,"utf-8");return JSON.parse(t)}catch{return null}}async fileExistsInProject(e){return b(Ap.join(this.projectPath,e))}}});import vc from"node:path";async function $p(n){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:n});e.branch=t.trim()||"main";let{stdout:s}=await O("git rev-list --count HEAD",{cwd:n});e.commits=parseInt(s.trim(),10)||0;let{stdout:r}=await O("git shortlog -sn --all | wc -l",{cwd:n});e.contributors=parseInt(r.trim(),10)||0;let{stdout:o}=await O("git status --porcelain",{cwd:n}),i=o.trim().split(`
678
678
  `).filter(Boolean);e.hasChanges=i.length>0;for(let u of i){let d=u.substring(0,2),m=u.substring(3);d.startsWith("A")||d.startsWith("M ")?e.stagedFiles.push(m):d.includes("M")?e.modifiedFiles.push(m):d.startsWith("??")&&e.untrackedFiles.push(m)}let{stdout:a}=await O('git log --oneline -20 --pretty=format:"%h|%s|%ad" --date=short',{cwd:n});e.recentCommits=a.split(`
679
- `).filter(Boolean).map(u=>{let[d,m,p]=u.split("|");return{hash:d,message:m,date:p}});let{stdout:c}=await O('git log --oneline --since="1 week ago" | wc -l',{cwd:n});e.weeklyCommits=parseInt(c.trim(),10)||0}catch(t){B.debug("Git analysis failed (not a git repo?)",{error:ge(t)})}return e}async function It(n,e){let t=await b(wc.join(n,e));return t||B.debug("File not found",{filename:e}),t}async function Dp(n){let e={fileCount:0,version:"0.0.0",name:wc.basename(n),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:n});e.fileCount=parseInt(t.trim(),10)||0}catch(t){B.debug("File count failed",{path:n,error:ge(t)}),e.fileCount=0}try{let t=wc.join(n,"package.json"),s=await Se(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 It(n,"tsconfig.json")?e.languages.push("TypeScript"):e.languages.push("JavaScript")}catch(t){B.debug("No package.json found",{path:n,error:ge(t)})}return await It(n,"Cargo.toml")?(e.ecosystem="Rust",e.languages.push("Rust")):await It(n,"go.mod")?(e.ecosystem="Go",e.languages.push("Go")):(await It(n,"requirements.txt")||await It(n,"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 Mp(n){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 It(n,"bun.lockb")||await It(n,"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 It(n,"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 It(n,"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 It(n,"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 It(n,"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 _p(n){return new Uo(n).detect()}var Np=h(()=>{"use strict";ds();xp();Ze();J();_s();Ip();l($p,"analyzeGit");l(It,"fileExistsInProject");l(Dp,"gatherStats");l(Mp,"detectCommands");l(_p,"detectStack")});import Op from"node:fs/promises";import Ho from"node:path";var kc,vc,Lp,Fp=h(()=>{"use strict";rt();V();Ze();J();kc={async contextFilesExist(n){let e=Date.now(),t=["context/CLAUDE.md"],s=[];for(let r of t){let o=Ho.join(n,r);await b(o)||s.push(r)}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(n){let e=Date.now(),t=[],s=Ho.basename(n);try{await D.read(s)}catch(r){_(r)||t.push(`state: ${k(r)}`)}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(n){let e=Date.now(),t=Ho.join(n,"context"),s=[/(?:api[_-]?key|apikey)\s*[:=]\s*['"][^'"]{10,}/i,/(?:password|passwd|pwd)\s*[:=]\s*['"][^'"]{4,}/i,/(?:secret|token)\s*[:=]\s*['"][^'"]{10,}/i],r=[];try{let o=await Op.readdir(t);for(let i of o){if(!i.endsWith(".md"))continue;let a=await Op.readFile(Ho.join(t,i),"utf-8");for(let c of s)if(c.test(a)){r.push(`${i}: potential sensitive data detected`);break}}}catch(o){if(!_(o))return{name:"No sensitive data",passed:!1,error:`Could not scan: ${k(o)}`,durationMs:Date.now()-e}}return{name:"No sensitive data",passed:r.length===0,output:r.length===0?"No sensitive patterns found":void 0,error:r.length>0?r.join("; "):void 0,durationMs:Date.now()-e}}},vc=class{static{l(this,"SyncVerifier")}async verify(e,t,s){let r=Date.now(),o=[],i=s?.failFast??!1,a=0,c=[kc.contextFilesExist(t),kc.jsonFilesValid(t),kc.noSensitiveData(t)];for(let p of c){let g=await p;if(o.push(g),!g.passed&&i){a=s?.checks?.filter(y=>y.enabled!==!1).length??0;break}}if((!i||o.every(p=>p.passed))&&s?.checks)for(let p of s.checks){if(p.enabled===!1){a++;continue}let g=await this.runCustomCheck(p,e);if(o.push(g),!g.passed&&i){let y=s.checks.slice(s.checks.indexOf(p)+1);a+=y.filter(j=>j.enabled!==!1).length;break}}let d=o.filter(p=>!p.passed).length,m=o.filter(p=>p.passed).length;return{passed:d===0,checks:o,totalMs:Date.now()-r,failedCount:d,passedCount:m,skippedCount:a}}async runCustomCheck(e,t){let s=Date.now(),r=e.command||(e.script?`sh ${e.script}`:null);if(!r)return{name:e.name,passed:!1,error:"No command or script specified",durationMs:Date.now()-s};try{let{stdout:o,stderr:i}=await O(r,{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}}}},Lp=new vc});import Up from"node:fs/promises";import Sc from"node:path";var bc,ns,Wo=h(()=>{"use strict";qa();Yd();ep();op();Qa();ds();We();Wt();de();Re();Cn();Tr();ms();ce();pr();pn();go();uc();mr();Ds();rt();va();be();J();_s();Er();Ep();ks();Pp();Rp();Np();Fp();bc=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(),r={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=$.getGlobalProjectPath(this.projectId),this.cliVersion=await this.getCliVersion(),await Up.rm(Sc.join(this.globalPath,"agents"),{recursive:!0,force:!0}).catch(()=>{}),(await Is()).installed){let v=await En({autoRepair:!0});v.verified||B.warn(`Codex p. router not ready: ${v.message||"verification failed"}`)}try{r=await ss.ensureReady()}catch(v){return{success:!1,projectId:this.projectId,cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:r.installed,verified:!1,message:ge(v)},error:`Context7 MCP is required but not ready: ${ge(v)}. Run 'prjct start' to repair.`}}await this.ensureDirectories(),await Oo(this.projectId);try{let v=await Lo(this.projectId);v>0&&B.info("Swept legacy JSON files into SQLite",{swept:v})}catch(v){B.debug("Legacy JSON sweep failed (non-critical)",{error:ge(v)})}let[a,c,u,d]=await Promise.all([$p(this.projectPath),Dp(this.projectPath),Mp(this.projectPath),_p(this.projectPath)]),m=t.full===!0,p,g=!0,y=new Set;if(!m&&Zd(this.projectId))try{let{diff:v,currentHashes:M}=await ec(this.projectPath,this.projectId),F=v.added.length+v.modified.length+v.deleted.length;if(F===0&&!t.changedFiles?.length)g=!1,p={isIncremental:!0,filesChanged:0,filesUnchanged:v.unchanged.length,indexesRebuilt:!1,affectedDomains:[]};else{let fe=Xd(v,this.projectId);y=Kd(fe.allAffected);let He=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]);g=fe.allAffected.some(Ie=>{let Vt=Ie.substring(Ie.lastIndexOf("."));return He.has(Vt)}),p={isIncremental:!0,filesChanged:F,filesUnchanged:v.unchanged.length,indexesRebuilt:g,affectedDomains:Array.from(y)}}Za(this.projectId,M)}catch(v){B.debug("Incremental detection failed, falling back to full sync",{error:ge(v)})}else try{let{currentHashes:v}=await ec(this.projectPath,this.projectId);Za(this.projectId,v)}catch(v){B.debug("Hash computation failed (non-critical)",{error:ge(v)})}if(g)try{await Promise.all([Dd(this.projectPath,this.projectId),zd(this.projectPath,this.projectId),rp(this.projectPath,this.projectId)])}catch(v){B.debug("File ranking index build failed (non-critical)",{error:ge(v)})}let j;try{let[v,M,F,fe,He,Nt,Ie,Vt,se,Ne,Ps]=await Promise.all([Promise.resolve(wt.getActive(this.projectId)).catch(()=>null),st.getActive(this.projectId).catch(()=>null),Ke.getRecent(this.projectId,3).catch(()=>[]),fo.getMetrics(this.projectId).catch(()=>null),Fe.getBacklog(this.projectId).catch(()=>[]),D.getTaskHistory(this.projectId).catch(()=>[]),D.getAllPausedTasks(this.projectId).catch(()=>[]),D.getAggregatedFeedback(this.projectId).catch(()=>null),D.getCurrentTask(this.projectId).catch(()=>null),Le.getCounts(this.projectId).catch(()=>({pending:0,converted:0,archived:0})),Ke.getCount(this.projectId).catch(()=>0)]),If={backlogCount:He.length,completedTaskCount:Nt.length,pausedTaskCount:Ie.length,hasActiveTask:!!se},$f=v?v.patterns.map(re=>({name:re.name,description:re.description,location:re.locations?.[0]})):(M?.patterns??[]).filter(re=>re.source!=="repo").map(re=>({name:re.name,description:re.description,location:re.location})),Df=v?v.antiPatterns.map(re=>({issue:re.issue,file:re.files?.[0]??"multiple",suggestion:re.suggestion,severity:re.severity??"medium"})):(M?.antiPatterns??[]).filter(re=>re.source!=="repo").map(re=>({issue:re.issue,file:re.file,suggestion:re.suggestion,severity:re.severity??"medium"})),Mf=v?.commands?{install:v.commands.install??u.install,run:u.run,test:v.commands.test??u.test,build:v.commands.build??u.build,dev:v.commands.dev??u.dev,lint:v.commands.lint??u.lint,format:v.commands.format??u.format}:u,_f={version:c.version,fileCount:c.fileCount,patterns:$f,antiPatterns:Df,recentShipped:F.map(re=>({name:re.name,type:re.type??"feature",duration:re.duration,filesChanged:re.changes?.length})),velocity:fe?{avgPoints:fe.averageVelocity,trend:fe.velocityTrend,accuracy:fe.estimationAccuracy}:null,backlogCount:He.length,completedTaskCount:Nt.length,pausedTaskCount:Ie.length,knownGotchas:Vt?.knownGotchas??[],userPatterns:Vt?.patternsDiscovered??[],hasActiveTask:!!se,activeTaskDescription:se?.description??"",pausedTasks:Ie.map(re=>({description:re.description,pausedAt:re.pausedAt??""})),topBacklog:He.slice(0,3).map(re=>({description:re.description,priority:re.priority??"medium"})),ideasCount:Ne?.pending??0,shippedCount:Ps};j=await jp.generateAndInstall({success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:Mf,stack:d},If,_f)}catch(v){B.debug("Native skill generation failed (non-critical)",{error:ge(v)})}await Promise.all([this.updateProjectJson(a,c),this.updateStateJson(c,d),this.logToMemory(a,c),this.saveDraftAnalysis(a,c,d,r.verified)]);let T=await st.getActive(this.projectId),x={patterns:T?.patterns?.length||0,antiPatterns:T?.antiPatterns?.length||0,criticalAntiPatterns:T?.antiPatterns?.filter(v=>v.severity==="high").length||0},S=Date.now()-s,w=await this.recordSyncMetrics(c,S);await this.archiveStaleData(),await this.autoLearnFromHistory(),await Te.installGlobalConfig(),await Te.syncCommands();let P;try{let v=await I.readConfig(this.projectPath);P=await Lp.verify(this.projectPath,this.globalPath,v?.verification)}catch(v){B.debug("Verification failed (non-critical)",{error:ge(v)})}return{success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:u,stack:d,context7:{installed:r.installed,verified:r.verified,message:r.message},analysisSummary:x,syncMetrics:w,verification:P,incremental:p,generatedSkills:j}}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:r.installed,verified:r.verified,message:r.message},error:ge(o)}}}async ensureDirectories(){let e=["storage","context","memory","analysis","config","sync"];await Promise.all(e.map(t=>Up.mkdir(Sc.join(this.globalPath,t),{recursive:!0})))}async updateProjectJson(e,t){let s=C.getDoc(this.projectId,"project")||{},r={...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||R(),lastSync:R(),lastSyncCommit:e.recentCommits[0]?.hash||null,lastSyncBranch:e.branch};C.setDoc(this.projectId,"project",r)}async updateStateJson(e,t){let r={...await D.read(this.projectId)};r.projectId=this.projectId,r.stack={language:e.languages[0]||"Unknown",framework:e.frameworks[0]||null},r.domains={hasFrontend:t.hasFrontend,hasBackend:t.hasBackend,hasDatabase:t.hasDatabase,hasTesting:t.hasTesting,hasDocker:t.hasDocker},r.projectType=e.projectType,r.metrics={totalFiles:e.fileCount},r.lastSync=R(),r.lastUpdated=R(),r.context={...r.context||{},lastSession:R(),lastAction:"Synced project",nextAction:'Run `p. task "description"` to start working'},await D.write(this.projectId,r);try{await Tp.generate(this.projectPath,r)}catch(o){B.debug("Local state generation failed (optional)",{error:ge(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=Ro(this.projectId);if(a)for(let c of Object.values(a.documents))s+=c.length}catch(a){B.debug("Could not load BM25 index for metrics",{error:ge(a)})}s===0&&(s=e.fileCount*200);let r=0,o=s>0?Math.max(0,(s-r)/s):0;try{await es.recordSync(this.projectId,{originalSize:s,filteredSize:r,duration:t,isWatch:!1})}catch(a){B.debug("Failed to record sync metrics",{error:ge(a)})}let i={};try{let a=Ro(this.projectId);a&&(i.bm25Files=a.totalDocs,i.bm25AvgTokens=Math.round(a.avgDocLength),i.bm25VocabSize=Object.keys(a.invertedIndex).length);let c=Io(this.projectId);c&&(i.importEdges=c.edgeCount,i.importFiles=c.fileCount);let u=np(this.projectId);u&&(i.cochangeCommits=u.commitsAnalyzed,i.cochangeFiles=u.filesAnalyzed)}catch(a){B.debug("Could not load index stats",{error:ge(a)})}return{duration:t,originalSize:s,filteredSize:r,compressionRate:o,indexes:i}}async saveDraftAnalysis(e,t,s,r){try{let o=e.recentCommits[0]?.hash||null,i=[],a=[],c;try{c=await D.getAggregatedFeedback(this.projectId),c.patternsDiscovered.length>0&&(i=c.patternsDiscovered.map(d=>({name:d,description:`Discovered during task execution: ${d}`,source:"feedback",confidence:.74}))),c.knownGotchas.length>0&&(a=c.knownGotchas.map(d=>({issue:d,file:"multiple",suggestion:`Recurring issue reported across tasks: ${d}`,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:r});i=u.patterns,a=u.antiPatterns,await st.saveDraft(this.projectId,{projectId:this.projectId,languages:t.languages,frameworks:t.frameworks,configFiles:[],fileCount:t.fileCount,patterns:i,antiPatterns:a,analyzedAt:R(),status:"draft",commitHash:o??void 0})}catch(o){B.debug("Failed to save draft analysis (non-critical)",{error:ge(o)})}}async archiveStaleData(){if(this.projectId)try{let[e,t,s,r,o]=await Promise.all([Ke.archiveOldShipped(this.projectId).catch(()=>0),Le.markDormantIdeas(this.projectId).catch(()=>0),Fe.removeStaleCompleted(this.projectId).catch(()=>0),D.archiveStalePausedTasks(this.projectId).catch(()=>[]),Ye.capEntries(this.projectId).catch(()=>0)]),i=e+t+s+r.length+o;if(i>0){B.info("Archived stale data",{shipped:e,dormant:t,staleQueue:s,stalePaused:r.length,memoryCapped:o,total:i});let a=tt.getStats(this.projectId);B.debug("Archive stats",a)}}catch(e){B.debug("Archival failed (non-critical)",{error:ge(e)})}}async autoLearnFromHistory(){}async getCliVersion(){try{let e=Sc.join(__dirname,"..","..","package.json");return(await Se(e))?.version||"0.0.0"}catch(e){return B.debug("Failed to read CLI version",{error:ge(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:[]}}},ns=new bc});function Tk(){return"---"}function Ek(){return`---
680
- prjct v${eo()}`}function G(...n){return Ec(Tk(),...n.filter(Boolean),Ek())}function Hp(n,e){let t=`| ${n.join(" | ")} |`,s=`|${n.map(()=>"---").join("|")}|`,r=e.map(o=>`| ${o.join(" | ")} |`);return[t,s,...r].join(`
679
+ `).filter(Boolean).map(u=>{let[d,m,p]=u.split("|");return{hash:d,message:m,date:p}});let{stdout:c}=await O('git log --oneline --since="1 week ago" | wc -l',{cwd:n});e.weeklyCommits=parseInt(c.trim(),10)||0}catch(t){B.debug("Git analysis failed (not a git repo?)",{error:ge(t)})}return e}async function It(n,e){let t=await b(vc.join(n,e));return t||B.debug("File not found",{filename:e}),t}async function Dp(n){let e={fileCount:0,version:"0.0.0",name:vc.basename(n),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:n});e.fileCount=parseInt(t.trim(),10)||0}catch(t){B.debug("File count failed",{path:n,error:ge(t)}),e.fileCount=0}try{let t=vc.join(n,"package.json"),s=await Se(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 It(n,"tsconfig.json")?e.languages.push("TypeScript"):e.languages.push("JavaScript")}catch(t){B.debug("No package.json found",{path:n,error:ge(t)})}return await It(n,"Cargo.toml")?(e.ecosystem="Rust",e.languages.push("Rust")):await It(n,"go.mod")?(e.ecosystem="Go",e.languages.push("Go")):(await It(n,"requirements.txt")||await It(n,"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 Mp(n){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 It(n,"bun.lockb")||await It(n,"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 It(n,"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 It(n,"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 It(n,"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 It(n,"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 _p(n){return new Ho(n).detect()}var Np=h(()=>{"use strict";ds();xp();Ze();J();_s();Ip();l($p,"analyzeGit");l(It,"fileExistsInProject");l(Dp,"gatherStats");l(Mp,"detectCommands");l(_p,"detectStack")});import Op from"node:fs/promises";import Wo from"node:path";var Sc,bc,Lp,Fp=h(()=>{"use strict";ot();V();Ze();J();Sc={async contextFilesExist(n){let e=Date.now(),t=["context/CLAUDE.md"],s=[];for(let r of t){let o=Wo.join(n,r);await b(o)||s.push(r)}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(n){let e=Date.now(),t=[],s=Wo.basename(n);try{await D.read(s)}catch(r){_(r)||t.push(`state: ${k(r)}`)}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(n){let e=Date.now(),t=Wo.join(n,"context"),s=[/(?:api[_-]?key|apikey)\s*[:=]\s*['"][^'"]{10,}/i,/(?:password|passwd|pwd)\s*[:=]\s*['"][^'"]{4,}/i,/(?:secret|token)\s*[:=]\s*['"][^'"]{10,}/i],r=[];try{let o=await Op.readdir(t);for(let i of o){if(!i.endsWith(".md"))continue;let a=await Op.readFile(Wo.join(t,i),"utf-8");for(let c of s)if(c.test(a)){r.push(`${i}: potential sensitive data detected`);break}}}catch(o){if(!_(o))return{name:"No sensitive data",passed:!1,error:`Could not scan: ${k(o)}`,durationMs:Date.now()-e}}return{name:"No sensitive data",passed:r.length===0,output:r.length===0?"No sensitive patterns found":void 0,error:r.length>0?r.join("; "):void 0,durationMs:Date.now()-e}}},bc=class{static{l(this,"SyncVerifier")}async verify(e,t,s){let r=Date.now(),o=[],i=s?.failFast??!1,a=0,c=[Sc.contextFilesExist(t),Sc.jsonFilesValid(t),Sc.noSensitiveData(t)];for(let p of c){let g=await p;if(o.push(g),!g.passed&&i){a=s?.checks?.filter(y=>y.enabled!==!1).length??0;break}}if((!i||o.every(p=>p.passed))&&s?.checks)for(let p of s.checks){if(p.enabled===!1){a++;continue}let g=await this.runCustomCheck(p,e);if(o.push(g),!g.passed&&i){let y=s.checks.slice(s.checks.indexOf(p)+1);a+=y.filter(j=>j.enabled!==!1).length;break}}let d=o.filter(p=>!p.passed).length,m=o.filter(p=>p.passed).length;return{passed:d===0,checks:o,totalMs:Date.now()-r,failedCount:d,passedCount:m,skippedCount:a}}async runCustomCheck(e,t){let s=Date.now(),r=e.command||(e.script?`sh ${e.script}`:null);if(!r)return{name:e.name,passed:!1,error:"No command or script specified",durationMs:Date.now()-s};try{let{stdout:o,stderr:i}=await O(r,{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}}}},Lp=new bc});import Up from"node:fs/promises";import Tc from"node:path";var Ec,rs,Go=h(()=>{"use strict";Ba();Yd();ep();op();ec();ds();We();Wt();de();Re();Cn();Tr();ms();ce();pr();pn();fo();pc();mr();Ds();ot();ba();be();J();_s();Er();Ep();ks();Pp();Rp();Np();Fp();Ec=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(),r={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=$.getGlobalProjectPath(this.projectId),this.cliVersion=await this.getCliVersion(),await Up.rm(Tc.join(this.globalPath,"agents"),{recursive:!0,force:!0}).catch(()=>{}),(await Is()).installed){let v=await En({autoRepair:!0});v.verified||B.warn(`Codex p. router not ready: ${v.message||"verification failed"}`)}try{r=await ns.ensureReady()}catch(v){return{success:!1,projectId:this.projectId,cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),context7:{installed:r.installed,verified:!1,message:ge(v)},error:`Context7 MCP is required but not ready: ${ge(v)}. Run 'prjct start' to repair.`}}await this.ensureDirectories(),await Lo(this.projectId);try{let v=await Fo(this.projectId);v>0&&B.info("Swept legacy JSON files into SQLite",{swept:v})}catch(v){B.debug("Legacy JSON sweep failed (non-critical)",{error:ge(v)})}let[a,c,u,d]=await Promise.all([$p(this.projectPath),Dp(this.projectPath),Mp(this.projectPath),_p(this.projectPath)]),m=t.full===!0,p,g=!0,y=new Set;if(!m&&Zd(this.projectId))try{let{diff:v,currentHashes:M}=await sc(this.projectPath,this.projectId),F=v.added.length+v.modified.length+v.deleted.length;if(F===0&&!t.changedFiles?.length)g=!1,p={isIncremental:!0,filesChanged:0,filesUnchanged:v.unchanged.length,indexesRebuilt:!1,affectedDomains:[]};else{let fe=Xd(v,this.projectId);y=Kd(fe.allAffected);let He=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]);g=fe.allAffected.some(Ie=>{let Vt=Ie.substring(Ie.lastIndexOf("."));return He.has(Vt)}),p={isIncremental:!0,filesChanged:F,filesUnchanged:v.unchanged.length,indexesRebuilt:g,affectedDomains:Array.from(y)}}tc(this.projectId,M)}catch(v){B.debug("Incremental detection failed, falling back to full sync",{error:ge(v)})}else try{let{currentHashes:v}=await sc(this.projectPath,this.projectId);tc(this.projectId,v)}catch(v){B.debug("Hash computation failed (non-critical)",{error:ge(v)})}if(g)try{await Promise.all([Dd(this.projectPath,this.projectId),zd(this.projectPath,this.projectId),rp(this.projectPath,this.projectId)])}catch(v){B.debug("File ranking index build failed (non-critical)",{error:ge(v)})}let j;try{let[v,M,F,fe,He,Nt,Ie,Vt,se,Ne,Ps]=await Promise.all([Promise.resolve(wt.getActive(this.projectId)).catch(()=>null),nt.getActive(this.projectId).catch(()=>null),Ke.getRecent(this.projectId,3).catch(()=>[]),ho.getMetrics(this.projectId).catch(()=>null),Fe.getBacklog(this.projectId).catch(()=>[]),D.getTaskHistory(this.projectId).catch(()=>[]),D.getAllPausedTasks(this.projectId).catch(()=>[]),D.getAggregatedFeedback(this.projectId).catch(()=>null),D.getCurrentTask(this.projectId).catch(()=>null),Le.getCounts(this.projectId).catch(()=>({pending:0,converted:0,archived:0})),Ke.getCount(this.projectId).catch(()=>0)]),If={backlogCount:He.length,completedTaskCount:Nt.length,pausedTaskCount:Ie.length,hasActiveTask:!!se},$f=v?v.patterns.map(re=>({name:re.name,description:re.description,location:re.locations?.[0]})):(M?.patterns??[]).filter(re=>re.source!=="repo").map(re=>({name:re.name,description:re.description,location:re.location})),Df=v?v.antiPatterns.map(re=>({issue:re.issue,file:re.files?.[0]??"multiple",suggestion:re.suggestion,severity:re.severity??"medium"})):(M?.antiPatterns??[]).filter(re=>re.source!=="repo").map(re=>({issue:re.issue,file:re.file,suggestion:re.suggestion,severity:re.severity??"medium"})),Mf=v?.commands?{install:v.commands.install??u.install,run:u.run,test:v.commands.test??u.test,build:v.commands.build??u.build,dev:v.commands.dev??u.dev,lint:v.commands.lint??u.lint,format:v.commands.format??u.format}:u,_f={version:c.version,fileCount:c.fileCount,patterns:$f,antiPatterns:Df,recentShipped:F.map(re=>({name:re.name,type:re.type??"feature",duration:re.duration,filesChanged:re.changes?.length})),velocity:fe?{avgPoints:fe.averageVelocity,trend:fe.velocityTrend,accuracy:fe.estimationAccuracy}:null,backlogCount:He.length,completedTaskCount:Nt.length,pausedTaskCount:Ie.length,knownGotchas:Vt?.knownGotchas??[],userPatterns:Vt?.patternsDiscovered??[],hasActiveTask:!!se,activeTaskDescription:se?.description??"",pausedTasks:Ie.map(re=>({description:re.description,pausedAt:re.pausedAt??""})),topBacklog:He.slice(0,3).map(re=>({description:re.description,priority:re.priority??"medium"})),ideasCount:Ne?.pending??0,shippedCount:Ps};j=await jp.generateAndInstall({success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:Mf,stack:d},If,_f)}catch(v){B.debug("Native skill generation failed (non-critical)",{error:ge(v)})}await Promise.all([this.updateProjectJson(a,c),this.updateStateJson(c,d),this.logToMemory(a,c),this.saveDraftAnalysis(a,c,d,r.verified)]);let T=await nt.getActive(this.projectId),x={patterns:T?.patterns?.length||0,antiPatterns:T?.antiPatterns?.length||0,criticalAntiPatterns:T?.antiPatterns?.filter(v=>v.severity==="high").length||0},S=Date.now()-s,w=await this.recordSyncMetrics(c,S);await this.archiveStaleData(),await this.autoLearnFromHistory(),await Te.installGlobalConfig(),await Te.syncCommands();let P;try{let v=await I.readConfig(this.projectPath);P=await Lp.verify(this.projectPath,this.globalPath,v?.verification)}catch(v){B.debug("Verification failed (non-critical)",{error:ge(v)})}return{success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:a,stats:c,commands:u,stack:d,context7:{installed:r.installed,verified:r.verified,message:r.message},analysisSummary:x,syncMetrics:w,verification:P,incremental:p,generatedSkills:j}}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:r.installed,verified:r.verified,message:r.message},error:ge(o)}}}async ensureDirectories(){let e=["storage","context","memory","analysis","config","sync"];await Promise.all(e.map(t=>Up.mkdir(Tc.join(this.globalPath,t),{recursive:!0})))}async updateProjectJson(e,t){let s=C.getDoc(this.projectId,"project")||{},r={...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||R(),lastSync:R(),lastSyncCommit:e.recentCommits[0]?.hash||null,lastSyncBranch:e.branch};C.setDoc(this.projectId,"project",r)}async updateStateJson(e,t){let r={...await D.read(this.projectId)};r.projectId=this.projectId,r.stack={language:e.languages[0]||"Unknown",framework:e.frameworks[0]||null},r.domains={hasFrontend:t.hasFrontend,hasBackend:t.hasBackend,hasDatabase:t.hasDatabase,hasTesting:t.hasTesting,hasDocker:t.hasDocker},r.projectType=e.projectType,r.metrics={totalFiles:e.fileCount},r.lastSync=R(),r.lastUpdated=R(),r.context={...r.context||{},lastSession:R(),lastAction:"Synced project",nextAction:'Run `p. task "description"` to start working'},await D.write(this.projectId,r);try{await Tp.generate(this.projectPath,r)}catch(o){B.debug("Local state generation failed (optional)",{error:ge(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=xo(this.projectId);if(a)for(let c of Object.values(a.documents))s+=c.length}catch(a){B.debug("Could not load BM25 index for metrics",{error:ge(a)})}s===0&&(s=e.fileCount*200);let r=0,o=s>0?Math.max(0,(s-r)/s):0;try{await ts.recordSync(this.projectId,{originalSize:s,filteredSize:r,duration:t,isWatch:!1})}catch(a){B.debug("Failed to record sync metrics",{error:ge(a)})}let i={};try{let a=xo(this.projectId);a&&(i.bm25Files=a.totalDocs,i.bm25AvgTokens=Math.round(a.avgDocLength),i.bm25VocabSize=Object.keys(a.invertedIndex).length);let c=$o(this.projectId);c&&(i.importEdges=c.edgeCount,i.importFiles=c.fileCount);let u=np(this.projectId);u&&(i.cochangeCommits=u.commitsAnalyzed,i.cochangeFiles=u.filesAnalyzed)}catch(a){B.debug("Could not load index stats",{error:ge(a)})}return{duration:t,originalSize:s,filteredSize:r,compressionRate:o,indexes:i}}async saveDraftAnalysis(e,t,s,r){try{let o=e.recentCommits[0]?.hash||null,i=[],a=[],c;try{c=await D.getAggregatedFeedback(this.projectId),c.patternsDiscovered.length>0&&(i=c.patternsDiscovered.map(d=>({name:d,description:`Discovered during task execution: ${d}`,source:"feedback",confidence:.74}))),c.knownGotchas.length>0&&(a=c.knownGotchas.map(d=>({issue:d,file:"multiple",suggestion:`Recurring issue reported across tasks: ${d}`,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:r});i=u.patterns,a=u.antiPatterns,await nt.saveDraft(this.projectId,{projectId:this.projectId,languages:t.languages,frameworks:t.frameworks,configFiles:[],fileCount:t.fileCount,patterns:i,antiPatterns:a,analyzedAt:R(),status:"draft",commitHash:o??void 0})}catch(o){B.debug("Failed to save draft analysis (non-critical)",{error:ge(o)})}}async archiveStaleData(){if(this.projectId)try{let[e,t,s,r,o]=await Promise.all([Ke.archiveOldShipped(this.projectId).catch(()=>0),Le.markDormantIdeas(this.projectId).catch(()=>0),Fe.removeStaleCompleted(this.projectId).catch(()=>0),D.archiveStalePausedTasks(this.projectId).catch(()=>[]),Ye.capEntries(this.projectId).catch(()=>0)]),i=e+t+s+r.length+o;if(i>0){B.info("Archived stale data",{shipped:e,dormant:t,staleQueue:s,stalePaused:r.length,memoryCapped:o,total:i});let a=st.getStats(this.projectId);B.debug("Archive stats",a)}}catch(e){B.debug("Archival failed (non-critical)",{error:ge(e)})}}async autoLearnFromHistory(){}async getCliVersion(){try{let e=Tc.join(__dirname,"..","..","package.json");return(await Se(e))?.version||"0.0.0"}catch(e){return B.debug("Failed to read CLI version",{error:ge(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:[]}}},rs=new Ec});function Ek(){return"---"}function Ck(){return`---
680
+ prjct v${to()}`}function G(...n){return Pc(Ek(),...n.filter(Boolean),Ck())}function Hp(n,e){let t=`| ${n.join(" | ")} |`,s=`|${n.map(()=>"---").join("|")}|`,r=e.map(o=>`| ${o.join(" | ")} |`);return[t,s,...r].join(`
681
681
  `)}function Wp(n,e=""){return`\`\`\`${e}
682
682
  ${n}
683
- \`\`\``}function Tc(n,e){return`**${n}**: \`${e}\``}function le(n,e,t=3){return`### ${n}
683
+ \`\`\``}function Cc(n,e){return`**${n}**: \`${e}\``}function le(n,e,t=3){return`### ${n}
684
684
  ${e}`}function $e(n,e=!1){return n.map((t,s)=>e?`${s+1}. ${t}`:`- ${t}`).join(`
685
685
  `)}function Rr(n){let e=[];n.branch&&e.push(`Branch: \`${n.branch}\``),n.linearId&&e.push(`Linear: \`${n.linearId}\``),n.type&&e.push(`Type: ${n.type}`),n.estimatedPoints&&e.push(`~${n.estimatedPoints}pts`),n.estimatedMinutes&&e.push(`~${n.estimatedMinutes}min`),n.domains&&n.domains.length>0&&e.push(`Domains: ${n.domains.join(", ")}`),n.duration&&e.push(`Duration: ${n.duration}`),n.status&&e.push(`Status: ${n.status}`);let t=e.length>0?`
686
686
  > ${e.join(" | ")}`:"";return`## ${n.description}${t}`}function qe(n){let e=["Command","Action"],t=n.map(s=>[`\`${s.command}\``,s.label]);return`### Next
687
687
  ${Hp(e,t)}`}function Hs(n){let e=Object.entries(n).filter(([,r])=>r!=null);if(e.length===0)return"";let t=["Metric","Value"],s=e.map(([r,o])=>[r,String(o)]);return Hp(t,s)}function Ce(n,e){return e?`## ${n}
688
- > ${e}`:`## ${n}`}function Gp(n){return`> **WARNING:** ${n}`}function Ec(...n){return n.filter(Boolean).join(`
688
+ > ${e}`:`## ${n}`}function Gp(n){return`> **WARNING:** ${n}`}function Pc(...n){return n.filter(Boolean).join(`
689
689
 
690
690
  `)}function qp(n,e,t,s){let r=e.replace(/_/g," "),o=[`> **${n}**: ${r}`];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(`
691
- `))}var xr=h(()=>{"use strict";ze();l(Tk,"mdHeader");l(Ek,"mdFooter");l(G,"mdOutput");l(Hp,"mdTable");l(Wp,"mdCodeBlock");l(Tc,"mdBadge");l(le,"mdSection");l($e,"mdList");l(Rr,"mdTaskHeader");l(qe,"mdNextSteps");l(Hs,"mdStats");l(Ce,"mdDone");l(Gp,"mdWarn");l(Ec,"mdJoin");l(qp,"mdActionRequired")});import Ar from"chalk";function Pn(n,e={}){if(e.quiet)return;let t=Bp[n]||"idle",s=Ms.getValidCommands(t);if(s.length===0)return;let r=s.map(o=>({cmd:`p. ${o}`,desc:Vp[o]||o}));console.log(Ar.dim(`
692
- Next:`));for(let o of r){let i=Ar.cyan(o.cmd.padEnd(12));console.log(Ar.dim(` ${i} \u2192 ${o.desc}`))}}function Go(n,e=!1){let t=Bp[n]||"idle";return Ms.getValidCommands(t).map(r=>({cmd:e?`prjct ${r} --md`:`p. ${r}`,desc:Vp[r]||r}))}function Jp(n){let e=Ms.getStateInfo(n);console.log(Ar.dim(`\u{1F4CD} State: ${Ar.white(n.toUpperCase())} - ${e.description}`))}var Vp,Bp,Ir=h(()=>{"use strict";ua();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(Pn,"showNextSteps");l(Go,"getNextSteps");l(Jp,"showStateInfo")});import Ck from"node:path";async function Cc(n,e){let t=Date.now()-e;await Te.installGlobalConfig(),f.done(`Synced ${n.stats.name||"project"} (${(t/1e3).toFixed(1)}s)`),console.log("");let s=n.stats.frameworks.length>0?` (${n.stats.frameworks[0]})`:"",r=n.syncMetrics?.indexes,o=[`${n.stats.fileCount} files indexed`,`Stack: ${n.stats.ecosystem}${s} | Branch: ${n.git.branch}`];if(r?.bm25Files){let a=r.bm25Files*(r.bm25AvgTokens||0);o.push(`Index: ${jn(a)} tokens | ${r.bm25VocabSize||0} terms | ${r.importEdges||0} imports`)}f.box("Sync Summary",o.join(`
693
- `));let i=[];if(n.generatedSkills?.generated&&n.generatedSkills.generated.length>0){let a=n.generatedSkills.generated.length,c=a===1?"skill":"skills";i.push(`${a} ${c} generated`)}if(n.context7&&i.push(`Context7: ${n.context7.verified?"verified":`not ready${n.context7.message?` (${n.context7.message})`:""}`}`),n.analysisSummary&&i.push(`Analysis: ${n.analysisSummary.patterns} patterns | ${n.analysisSummary.antiPatterns} anti-patterns (${n.analysisSummary.criticalAntiPatterns} critical)`),f.section("Generated"),f.list(i,{bullet:"\u2713"}),console.log(""),n.git.hasChanges&&(f.warn("Uncommitted changes detected"),console.log("")),n.verification){let a=n.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 Pn("sync"),{success:!0,data:n,metrics:{elapsed:t,fileCount:n.stats.fileCount}}}async function zp(n){try{let e=await Ye.getRecentEvents(n,100),t=new Date().toISOString().split("T")[0],s=e.filter(u=>(u.timestamp||u.ts)?.startsWith(t)),r=null;if(s.length>=2){let u=s.map(d=>new Date(d.timestamp||d.ts).getTime()).filter(d=>!Number.isNaN(d)).sort((d,m)=>d-m);if(u.length>=2){let d=u[u.length-1]-u[0];r=cr(d)}}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 d of u.subagents)a.set(d,(a.get(d)||0)+1);let c=Array.from(a.entries()).map(([u,d])=>({name:u,count:d})).sort((u,d)=>d.count-u.count);return{sessionDuration:r,tasksCompleted:o,featuresShipped:i,agentsUsed:c}}catch{return{sessionDuration:null,tasksCompleted:0,featuresShipped:0,agentsUsed:[]}}}function jn(n){return n>=1e6?`${(n/1e6).toFixed(1)}M`:n>=1e3?`${(n/1e3).toFixed(1)}K`:n.toLocaleString()}function Pc(n){return n<1e3?`${Math.round(n)}ms`:`${(n/1e3).toFixed(1)}s`}function Xp(n){if(n.length===0)return"";let e="\u2581\u2582\u2583\u2584\u2585\u2586\u2587\u2588",t=n.map(r=>r.tokensSaved),s=Math.max(...t,1);return t.map(r=>{let o=Math.min(Math.floor(r/s*(e.length-1)),e.length-1);return e[o]}).join("")}function Kp(n,e,t,s,r,o){let i=[];if(i.push(`# ${t} - Stats Dashboard`),i.push(""),i.push(`_Generated: ${new Date().toLocaleString()} | Tracking since: ${s}_`),i.push(""),r){if(i.push("## Today's Activity"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),r.sessionDuration&&i.push(`| Duration | ${r.sessionDuration} |`),i.push(`| Tasks completed | ${r.tasksCompleted} |`),i.push(`| Features shipped | ${r.featuresShipped} |`),r.agentsUsed.length>0){let a=r.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 | ${jn(n.totalTokensSaved)} |`),i.push(`| Compression | ${(n.compressionRate*100).toFixed(0)}% |`),i.push(`| Est. cost saved | ${po(n.estimatedCostSaved)} |`),i.push(""),i.push("## Performance"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Syncs | ${n.syncCount} |`),i.push(`| Avg time | ${Pc(n.avgSyncDuration)} |`),i.push(""),n.topAgents.length>0){i.push("## Agent Usage"),i.push(""),i.push("| Agent | Usage |"),i.push("|-------|-------|");let a=n.topAgents.reduce((c,u)=>c+u.usageCount,0);for(let c of n.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: ${jn(n.last30DaysTokens)}`),n.trend!==0){let a=n.trend>0?"+":"";i.push(`- Trend: ${a}${n.trend.toFixed(0)}% vs previous period`)}return i.push(""),i.push("---"),i.push(""),i.push("_Generated with [prjct-cli](https://prjct.app)_"),i.join(`
691
+ `))}var xr=h(()=>{"use strict";ze();l(Ek,"mdHeader");l(Ck,"mdFooter");l(G,"mdOutput");l(Hp,"mdTable");l(Wp,"mdCodeBlock");l(Cc,"mdBadge");l(le,"mdSection");l($e,"mdList");l(Rr,"mdTaskHeader");l(qe,"mdNextSteps");l(Hs,"mdStats");l(Ce,"mdDone");l(Gp,"mdWarn");l(Pc,"mdJoin");l(qp,"mdActionRequired")});import Ar from"chalk";function Pn(n,e={}){if(e.quiet)return;let t=Bp[n]||"idle",s=Ms.getValidCommands(t);if(s.length===0)return;let r=s.map(o=>({cmd:`p. ${o}`,desc:Vp[o]||o}));console.log(Ar.dim(`
692
+ Next:`));for(let o of r){let i=Ar.cyan(o.cmd.padEnd(12));console.log(Ar.dim(` ${i} \u2192 ${o.desc}`))}}function qo(n,e=!1){let t=Bp[n]||"idle";return Ms.getValidCommands(t).map(r=>({cmd:e?`prjct ${r} --md`:`p. ${r}`,desc:Vp[r]||r}))}function Jp(n){let e=Ms.getStateInfo(n);console.log(Ar.dim(`\u{1F4CD} State: ${Ar.white(n.toUpperCase())} - ${e.description}`))}var Vp,Bp,Ir=h(()=>{"use strict";pa();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(Pn,"showNextSteps");l(qo,"getNextSteps");l(Jp,"showStateInfo")});import Pk from"node:path";async function jc(n,e){let t=Date.now()-e;await Te.installGlobalConfig(),f.done(`Synced ${n.stats.name||"project"} (${(t/1e3).toFixed(1)}s)`),console.log("");let s=n.stats.frameworks.length>0?` (${n.stats.frameworks[0]})`:"",r=n.syncMetrics?.indexes,o=[`${n.stats.fileCount} files indexed`,`Stack: ${n.stats.ecosystem}${s} | Branch: ${n.git.branch}`];if(r?.bm25Files){let a=r.bm25Files*(r.bm25AvgTokens||0);o.push(`Index: ${jn(a)} tokens | ${r.bm25VocabSize||0} terms | ${r.importEdges||0} imports`)}f.box("Sync Summary",o.join(`
693
+ `));let i=[];if(n.generatedSkills?.generated&&n.generatedSkills.generated.length>0){let a=n.generatedSkills.generated.length,c=a===1?"skill":"skills";i.push(`${a} ${c} generated`)}if(n.context7&&i.push(`Context7: ${n.context7.verified?"verified":`not ready${n.context7.message?` (${n.context7.message})`:""}`}`),n.analysisSummary&&i.push(`Analysis: ${n.analysisSummary.patterns} patterns | ${n.analysisSummary.antiPatterns} anti-patterns (${n.analysisSummary.criticalAntiPatterns} critical)`),f.section("Generated"),f.list(i,{bullet:"\u2713"}),console.log(""),n.git.hasChanges&&(f.warn("Uncommitted changes detected"),console.log("")),n.verification){let a=n.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 Pn("sync"),{success:!0,data:n,metrics:{elapsed:t,fileCount:n.stats.fileCount}}}async function zp(n){try{let e=await Ye.getRecentEvents(n,100),t=new Date().toISOString().split("T")[0],s=e.filter(u=>(u.timestamp||u.ts)?.startsWith(t)),r=null;if(s.length>=2){let u=s.map(d=>new Date(d.timestamp||d.ts).getTime()).filter(d=>!Number.isNaN(d)).sort((d,m)=>d-m);if(u.length>=2){let d=u[u.length-1]-u[0];r=cr(d)}}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 d of u.subagents)a.set(d,(a.get(d)||0)+1);let c=Array.from(a.entries()).map(([u,d])=>({name:u,count:d})).sort((u,d)=>d.count-u.count);return{sessionDuration:r,tasksCompleted:o,featuresShipped:i,agentsUsed:c}}catch{return{sessionDuration:null,tasksCompleted:0,featuresShipped:0,agentsUsed:[]}}}function jn(n){return n>=1e6?`${(n/1e6).toFixed(1)}M`:n>=1e3?`${(n/1e3).toFixed(1)}K`:n.toLocaleString()}function Rc(n){return n<1e3?`${Math.round(n)}ms`:`${(n/1e3).toFixed(1)}s`}function Xp(n){if(n.length===0)return"";let e="\u2581\u2582\u2583\u2584\u2585\u2586\u2587\u2588",t=n.map(r=>r.tokensSaved),s=Math.max(...t,1);return t.map(r=>{let o=Math.min(Math.floor(r/s*(e.length-1)),e.length-1);return e[o]}).join("")}function Kp(n,e,t,s,r,o){let i=[];if(i.push(`# ${t} - Stats Dashboard`),i.push(""),i.push(`_Generated: ${new Date().toLocaleString()} | Tracking since: ${s}_`),i.push(""),r){if(i.push("## Today's Activity"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),r.sessionDuration&&i.push(`| Duration | ${r.sessionDuration} |`),i.push(`| Tasks completed | ${r.tasksCompleted} |`),i.push(`| Features shipped | ${r.featuresShipped} |`),r.agentsUsed.length>0){let a=r.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 | ${jn(n.totalTokensSaved)} |`),i.push(`| Compression | ${(n.compressionRate*100).toFixed(0)}% |`),i.push(`| Est. cost saved | ${mo(n.estimatedCostSaved)} |`),i.push(""),i.push("## Performance"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Syncs | ${n.syncCount} |`),i.push(`| Avg time | ${Rc(n.avgSyncDuration)} |`),i.push(""),n.topAgents.length>0){i.push("## Agent Usage"),i.push(""),i.push("| Agent | Usage |"),i.push("|-------|-------|");let a=n.topAgents.reduce((c,u)=>c+u.usageCount,0);for(let c of n.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: ${jn(n.last30DaysTokens)}`),n.trend!==0){let a=n.trend>0?"+":"";i.push(`- Trend: ${a}${n.trend.toFixed(0)}% vs previous period`)}return i.push(""),i.push("---"),i.push(""),i.push("_Generated with [prjct-cli](https://prjct.app)_"),i.join(`
694
694
  `)}function Yp(n,e){let t=[];t.push(`# Repository Analysis
695
695
  `),t.push(`Generated: ${new Date().toLocaleString()}
696
- `);let s=Ck.basename(e);if(t.push(`## Project: ${s}
696
+ `);let s=Pk.basename(e);if(t.push(`## Project: ${s}
697
697
  `),t.push(`## Stack Detected
698
698
  `),n.packageJson){let i=n.packageJson;if(t.push(`### JavaScript/TypeScript
699
699
  `),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)`:""}`)}n.hasNextConfig&&t.push("- **Framework**: Next.js detected"),n.hasViteConfig&&t.push("- **Build Tool**: Vite detected"),n.hasTsconfig&&t.push("- **Language**: TypeScript"),t.push("")}n.cargoToml&&(t.push(`### Rust
@@ -709,13 +709,13 @@ Next:`));for(let o of r){let i=Ar.cyan(o.cmd.padEnd(12));console.log(Ar.dim(` $
709
709
  `).slice(0,5).forEach(a=>{if(a.trim()){let[c,,u,d]=a.split("|");t.push(`- \`${c}\` ${d} (${u})`)}}),t.push("")),t.push(`## Recommendations
710
710
  `),t.push("Based on detected stack, consider generating specialized agents using `/p:sync`.\n"),t.push(`---
711
711
  `),t.push("*This analysis was generated automatically. For updated information, run `/p:analyze` again.*\n"),t.join(`
712
- `)}var Qp=h(()=>{"use strict";Wt();mo();ks();be();Ir();Me();l(Cc,"showSyncResult");l(zp,"getSessionActivity");l(jn,"formatTokens");l(Pc,"formatDuration");l(Xp,"generateSparkline");l(Kp,"generateStatsMarkdown");l(Yp,"generateAnalysisSummary")});import Pk from"node:https";import jk from"node:os";import jc from"node:path";import $t from"chalk";var Rc,qo,xc=h(()=>{"use strict";V();J();Rc=class{static{l(this,"UpdateChecker")}packageName;cacheDir;cacheFile;checkInterval;constructor(){this.packageName="prjct-cli",this.cacheDir=jc.join(jk.homedir(),".prjct-cli","config"),this.cacheFile=jc.join(this.cacheDir,"update-cache.json"),this.checkInterval=24*60*60*1e3}async getCurrentVersion(){try{let e=jc.join(__dirname,"..","..","package.json");return(await Se(e))?.version??null}catch(e){return console.error("Error reading package version:",k(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"}},r=Pk.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)}})});r.on("error",o=>{t(o)}),r.setTimeout(5e3,()=>{r.destroy(),t(new Error("Request timeout"))}),r.end()})}compareVersions(e,t){let s=e.split(".").map(Number),r=t.split(".").map(Number);for(let o=0;o<3;o++){let i=s[o]||0,a=r[o]||0;if(i>a)return 1;if(i<a)return-1}return 0}async readCache(){try{if(await b(this.cacheFile))return await Se(this.cacheFile)}catch{}return null}async writeCache(e){try{await ie(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 r=await this.getLatestVersion();return await this.writeCache({lastCheck:s,latestVersion:r}),{updateAvailable:this.compareVersions(r,e)>0,currentVersion:e,latestVersion:r}}catch{return null}}async getUpdateNotification(){let e=await this.checkForUpdates();return!e||!e.updateAvailable?null:`
712
+ `)}var Qp=h(()=>{"use strict";Wt();go();ks();be();Ir();Me();l(jc,"showSyncResult");l(zp,"getSessionActivity");l(jn,"formatTokens");l(Rc,"formatDuration");l(Xp,"generateSparkline");l(Kp,"generateStatsMarkdown");l(Yp,"generateAnalysisSummary")});import jk from"node:https";import Rk from"node:os";import xc from"node:path";import $t from"chalk";var Ac,Vo,Ic=h(()=>{"use strict";V();J();Ac=class{static{l(this,"UpdateChecker")}packageName;cacheDir;cacheFile;checkInterval;constructor(){this.packageName="prjct-cli",this.cacheDir=xc.join(Rk.homedir(),".prjct-cli","config"),this.cacheFile=xc.join(this.cacheDir,"update-cache.json"),this.checkInterval=24*60*60*1e3}async getCurrentVersion(){try{let e=xc.join(__dirname,"..","..","package.json");return(await Se(e))?.version??null}catch(e){return console.error("Error reading package version:",k(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"}},r=jk.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)}})});r.on("error",o=>{t(o)}),r.setTimeout(5e3,()=>{r.destroy(),t(new Error("Request timeout"))}),r.end()})}compareVersions(e,t){let s=e.split(".").map(Number),r=t.split(".").map(Number);for(let o=0;o<3;o++){let i=s[o]||0,a=r[o]||0;if(i>a)return 1;if(i<a)return-1}return 0}async readCache(){try{if(await b(this.cacheFile))return await Se(this.cacheFile)}catch{}return null}async writeCache(e){try{await ie(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 r=await this.getLatestVersion();return await this.writeCache({lastCheck:s,latestVersion:r}),{updateAvailable:this.compareVersions(r,e)>0,currentVersion:e,latestVersion:r}}catch{return null}}async getUpdateNotification(){let e=await this.checkForUpdates();return!e||!e.updateAvailable?null:`
713
713
  `+$t.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")+`
714
714
  `+$t.yellow("\u2502")+" "+$t.bold("Update available!")+" "+$t.dim(`${e.currentVersion} \u2192 ${e.latestVersion}`)+" "+$t.yellow("\u2502")+`
715
715
  `+$t.yellow("\u2502")+" "+$t.yellow("\u2502")+`
716
716
  `+$t.yellow("\u2502")+" Run: "+$t.cyan("npm update -g prjct-cli")+" "+$t.yellow("\u2502")+`
717
717
  `+$t.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")+`
718
- `}},qo=Rc});import Zp from"node:path";async function Ak(){if(process.env.CLAUDE_AGENT||process.env.ANTHROPIC_CLAUDE||global.mcp||process.env.MCP_AVAILABLE)return!0;let n=process.cwd();if(await b(Zp.join(n,"CLAUDE.md")))return!0;let e=process.env.HOME||process.env.USERPROFILE||"";if(await b(Zp.join(e,".claude")))return!0;let t=process.cwd();return!!(t.includes("/.claude/")||t.includes("/claude-workspace/"))}function Ik(){return{...Rk}}function $k(){return{...xk}}async function em(){return Vo||(Vo=await Ak()?Ik():$k(),Vo)}var Vo,Rk,xk,tm=h(()=>{"use strict";J();Vo=null,Rk={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}},xk={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(Ak,"isClaudeEnvironment");l(Ik,"getClaudeAgent");l($k,"getTerminalAgent");l(em,"detect")});import Bo from"node:fs/promises";var Ac,sm,nm=h(()=>{"use strict";V();J();Ac=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: ${k(t)}`)}return await Bo.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: ${k(s)}`)}await Bo.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: ${k(t)}`)}return await Bo.readdir(e)}async fileExists(e){return b(e)}async createDirectory(e){await Bo.mkdir(e,{recursive:!0})}getTimestamp(){return new Date().toISOString()}formatTaskList(e){return!e||e.length===0?"\u{1F4CB} No tasks queued":`\u{1F4CB} Queue:
718
+ `}},Vo=Ac});import Zp from"node:path";async function Ik(){if(process.env.CLAUDE_AGENT||process.env.ANTHROPIC_CLAUDE||global.mcp||process.env.MCP_AVAILABLE)return!0;let n=process.cwd();if(await b(Zp.join(n,"CLAUDE.md")))return!0;let e=process.env.HOME||process.env.USERPROFILE||"";if(await b(Zp.join(e,".claude")))return!0;let t=process.cwd();return!!(t.includes("/.claude/")||t.includes("/claude-workspace/"))}function $k(){return{...xk}}function Dk(){return{...Ak}}async function em(){return Bo||(Bo=await Ik()?$k():Dk(),Bo)}var Bo,xk,Ak,tm=h(()=>{"use strict";J();Bo=null,xk={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}},Ak={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(Ik,"isClaudeEnvironment");l($k,"getClaudeAgent");l(Dk,"getTerminalAgent");l(em,"detect")});import Jo from"node:fs/promises";var $c,sm,nm=h(()=>{"use strict";V();J();$c=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: ${k(t)}`)}return await Jo.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: ${k(s)}`)}await Jo.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: ${k(t)}`)}return await Jo.readdir(e)}async fileExists(e){return b(e)}async createDirectory(e){await Jo.mkdir(e,{recursive:!0})}getTimestamp(){return new Date().toISOString()}formatTaskList(e){return!e||e.length===0?"\u{1F4CB} No tasks queued":`\u{1F4CB} Queue:
719
719
  ${e.map((t,s)=>`${s+1}. ${t}`).join(`
720
720
  `)}`}formatRecap(e){return`\u{1F4CA} Recap
721
721
 
@@ -760,15 +760,15 @@ Or type /p:help to see all options`,stuck:`Let's break it down:
760
760
 
761
761
  Or: /p:now | /p:task | /p:idea`}[e]||`What would you like to do?
762
762
 
763
- 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}}},sm=Ac});function rm(n){if(!n||typeof n!="object")return!1;let e=n;if(e.code&&Mk.has(e.code))return!0;if(e.code&&im.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 _k(n){if(!n||typeof n!="object")return!1;let e=n;return!!(e.code&&im.has(e.code))}function om(n,e,t){let s=vs.get(n);return s&&s.consecutiveFailures>=e&&s.openedAt?Date.now()-s.openedAt>=t?(vs.delete(n),!1):!0:!1}function Ic(n,e){let t=vs.get(n)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),vs.set(n,t)}function Nk(n){vs.delete(n)}var Mk,im,vs,Jo,am,o$,cm=h(()=>{"use strict";Mk=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),im=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);l(rm,"isTransientError");l(_k,"isPermanentError");vs=new Map;l(om,"isCircuitOpen");l(Ic,"recordFailure");l(Nk,"recordSuccess");Jo=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(om(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let s,r=0;for(;r<this.options.maxAttempts;)try{let o=await e();return Nk(t),o}catch(o){if(s=o,r++,_k(o))throw Ic(t,this.options.circuitBreakerThreshold),o;if(!(rm(o)&&r<this.options.maxAttempts))throw Ic(t,this.options.circuitBreakerThreshold),o;let a=Math.min(this.options.baseDelayMs*2**(r-1),this.options.maxDelayMs);await new Promise(c=>setTimeout(c,a))}throw Ic(t,this.options.circuitBreakerThreshold),s}isTransientError(e){return rm(e)}isCircuitOpen(e){return om(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return vs.get(e)}resetCircuit(e){vs.delete(e)}resetAllCircuits(){vs.clear()}},am=new Jo({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),o$=new Jo({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});var Ok,$c,zo,lm=h(()=>{"use strict";ds();tm();nm();cm();Ok=["claude"],$c=class{static{l(this,"AgentService")}agent=null;agentInfo=null;async initialize(){return this.agent?this.agent:await am.execute(async()=>{if(this.agentInfo=await em(),!this.agentInfo?.isSupported)throw ar.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!Ok.includes(e))throw ar.notSupported(this.agentInfo?.type??"unknown");return this.agent=new sm,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}reset(){this.agent=null,this.agentInfo=null}},zo=new $c});var Dc,Mc,um=h(()=>{"use strict";Dc=class{static{l(this,"BreakdownService")}breakdownFeature(e){return[]}detectBugSeverity(e){return"medium"}estimateComplexity(e){return{level:"medium",hours:4}}detectTaskType(e){return"feature"}},Mc=new Dc});import Qe from"node:path";async function Lk(n,e){let t=e?.packageManager?.trim().toLowerCase();return t?.startsWith("pnpm@")?"pnpm":t?.startsWith("yarn@")?"yarn":t?.startsWith("bun@")?"bun":t?.startsWith("npm@")?"npm":await b(Qe.join(n,"pnpm-lock.yaml"))?"pnpm":await b(Qe.join(n,"yarn.lock"))?"yarn":await b(Qe.join(n,"bun.lockb"))||await b(Qe.join(n,"bun.lock"))?"bun":(await b(Qe.join(n,"package-lock.json")),"npm")}function dm(n,e){return n==="yarn"?`yarn ${e}`:n==="pnpm"?`pnpm run ${e}`:n==="bun"?`bun run ${e}`:`npm run ${e}`}function Fk(n){return n==="yarn"?"yarn test":n==="pnpm"?"pnpm test":n==="bun"?"bun test":"npm test"}async function Rn(n,e){for(let r of Uk)if(await b(Qe.join(n,r)))return r;let s=(e??await Yt(n)).find(r=>r.endsWith(Hk));if(s)return s}async function rs(n){for(let e of Wk)if(await b(Qe.join(n,e)))return e}async function Xo(n){let e=Qe.join(n,"package.json"),t=await Se(e,null);if(t){let a=await Lk(n,t),c=t.scripts||{},u={stack:"js",packageManager:a};return c.lint&&(u.lint={tool:a,command:dm(a,"lint")}),c.typecheck&&(u.typecheck={tool:a,command:dm(a,"typecheck")}),c.test&&(u.test={tool:a,command:Fk(a)}),u.versionFile=await Rn(n),u.changelogFile=await rs(n),u}if(await b(Qe.join(n,"pytest.ini"))){let a=await Rn(n),c=await rs(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}let s=await lt(Qe.join(n,"pyproject.toml"),"");if(s.includes("[tool.pytest")||s.includes("pytest")){let a=await Rn(n),c=await rs(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}if(await b(Qe.join(n,"Cargo.toml"))){let a=await rs(n);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await b(Qe.join(n,"go.mod"))){let a=await Rn(n),c=await rs(n);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:c}}let r=await Yt(n);if(r.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await Rn(n,r),c=await rs(n);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:c}}if(await b(Qe.join(n,"pom.xml"))){let a=await rs(n);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await b(Qe.join(n,"gradlew"))&&(await b(Qe.join(n,"build.gradle"))||await b(Qe.join(n,"build.gradle.kts")))){let a=await rs(n);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await Rn(n),i=await rs(n);return{stack:"unknown",versionFile:o,changelogFile:i}}var Uk,Hk,Wk,_c=h(()=>{"use strict";J();l(Lk,"detectPackageManager");l(dm,"pmRun");l(Fk,"pmTest");Uk=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],Hk=".csproj",Wk=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];l(Rn,"detectVersionFile");l(rs,"detectChangelogFile");l(Xo,"detectProjectCommands")});import*as ue from"@clack/prompts";import Ws from"chalk";var Ko,pm,$r,mm=h(()=>{"use strict";J();Me();Ko=[{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."}],pm=[{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"}],$r=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(){ue.intro(Ws.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 ue.outro(Ws.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=Ko.findIndex(s=>s.value===this.detectedType),t=await ue.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:Ko.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValue:e>=0?Ko[e].value:void 0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await ue.multiselect({message:"Which AI agents do you use?",options:pm.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValues:e,required:!0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.selectedAgents=t.length>0?t:["claude"],!0)}async stepStack(){this.detectedStack=await this.detectStack();let e=this.formatStackDisplay(this.detectedStack);ue.note(e,"Detected stack");let t=await ue.confirm({message:"Is this stack correct?",initialValue:!0});if(ue.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let s=await ue.group({language:l(()=>ue.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:l(()=>ue.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 ue.group({verbosity:l(()=>ue.select({message:"Output verbosity:",options:[{label:"Minimal",hint:"Essential output only",value:"minimal"},{label:"Normal (Recommended)",hint:"Balanced information",value:"normal"},{label:"Verbose",hint:"Detailed logging",value:"verbose"}],initialValue:"normal"}),"verbosity"),autoSync:l(()=>ue.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=[`${Ws.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${Ws.cyan("AI Agents:")} ${this.selectedAgents.map(s=>this.getAgentLabel(s)).join(", ")}`,`${Ws.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${Ws.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${Ws.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
764
- `);ue.note(e,"Configuration Summary");let t=await ue.confirm({message:"Generate configuration with these settings?",initialValue:!0});return ue.isCancel(t)||!t?(ue.isCancel(t)&&this.handleCancel(),!1):!0}async detectProjectType(){let e=await import("node:fs/promises"),t=await import("node:path");try{let s=await e.readdir(this.projectPath);if(s.includes("turbo.json")||s.includes("lerna.json")||s.includes("nx.json"))return"monorepo";if(s.includes("package.json")){let r=t.join(this.projectPath,"package.json"),o=await e.readFile(r,"utf-8"),i=JSON.parse(o),a={...i.dependencies,...i.devDependencies};if(i.bin)return"cli-tool";if(i.main&&!a.react&&!a.vue&&!a.angular&&!a.express&&!a.hono)return"library";if((a.react||a.vue)&&(a.express||a.hono||a.fastify))return"fullstack";if(a.react||a.vue||a["@angular/core"]||a.next||a.nuxt)return"web-app";if(a.express||a.hono||a.fastify||a.koa||a.nestjs)return"api-backend"}return s.includes("pyproject.toml")||s.includes("setup.py")?s.some(o=>["main.py","app.py","server.py"].includes(o))?"api-backend":"library":s.includes("go.mod")?s.includes("main.go")?"cli-tool":"library":s.includes("Cargo.toml")?"cli-tool":"unknown"}catch{return"unknown"}}async detectInstalledAgents(){let e=await import("node:path"),t=await import("node:os"),s=[];await Kt(e.join(t.homedir(),".claude"))&&s.push("claude"),await b(e.join(this.projectPath,".cursorrules"))&&s.push("cursor"),await b(e.join(this.projectPath,".windsurfrules"))&&s.push("windsurf"),await b(e.join(this.projectPath,".github","copilot-instructions.md"))&&s.push("copilot"),await Kt(e.join(t.homedir(),".gemini"))&&s.push("gemini");try{let{execAsync:r}=await Promise.resolve().then(()=>(Ze(),Di));await r("which codex"),s.push("codex")}catch{await Kt(e.join(t.homedir(),".codex"))&&s.push("codex")}return s.length>0?s:["claude"]}async detectStack(){let e=await import("node:fs/promises"),t=await import("node:path"),s={language:"Unknown",technologies:[]};try{let r=await e.readdir(this.projectPath);if(r.includes("package.json")){let o=t.join(this.projectPath,"package.json"),i=await e.readFile(o,"utf-8"),a=JSON.parse(i),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",r.includes("bun.lockb")?s.packageManager="Bun":r.includes("pnpm-lock.yaml")?s.packageManager="pnpm":r.includes("yarn.lock")?s.packageManager="Yarn":r.includes("package-lock.json")&&(s.packageManager="npm"),(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 r.includes("pyproject.toml")||r.includes("requirements.txt")?s.language="Python":r.includes("go.mod")?s.language="Go":r.includes("Cargo.toml")?s.language="Rust":(r.includes("pom.xml")||r.includes("build.gradle"))&&(s.language="Java");return s}catch{return s}}handleCancel(){this.aborted=!0,ue.cancel("Setup cancelled. Run again anytime.")}getProjectTypeLabel(e){return Ko.find(t=>t.value===e)?.title||"Unknown"}getAgentLabel(e){return pm.find(t=>t.value===e)?.title||e}formatStackDisplay(e){let t=[e.language];return e.framework&&t.push(e.framework),e.runtime&&e.runtime!=="Node.js"&&t.push(e.runtime),e.technologies.length>0&&t.push(`+ ${e.technologies.slice(0,3).join(", ")}`),t.join(" / ")}buildResult(e){return{projectType:this.confirmedType,agents:this.selectedAgents,stack:this.confirmedStack,preferences:this.preferences,skipped:e}}getSelectedAgents(){return this.selectedAgents}getConfirmedStack(){return this.confirmedStack}getPreferences(){return this.preferences}}});function gm(n){return Gs[n]??null}var Gs,Nc,Oc=h(()=>{"use strict";Gs={code:{name:"code",description:"Coding work: features, bugs, refactors, TDD, shipping.",suggestedPersona:{role:"DEV",mcps:["github"]},memoryTypes:["fact","decision","learning","gotcha","pattern","anti-pattern","shipped"],workflowSlots:{ship:{description:"Publish finished work \u2014 tests, commit, push, PR."},review:{description:"Pre-commit or pre-PR review pass."}},hookSignals:[],suggestedTags:{domain:["auth","api","frontend","infra","data"]}},daily:{name:"daily",description:"Day-to-day capture + review. GTD-style inbox + weekly review.",memoryTypes:["inbox","todo","idea"],workflowSlots:{morning:{description:"Morning briefing \u2014 pull open todos + upcoming commitments."},clarify:{description:"Reclassify inbox entries to real memory types."},review:{description:"Weekly/biweekly review across memory."}},hookSignals:[]},pm:{name:"pm",description:"Product Management: specs, user interviews, roadmap, backlog triage.",suggestedPersona:{role:"PM",mcps:["linear","posthog"]},memoryTypes:["insight","question","stakeholder","decision","source"],workflowSlots:{spec:{description:"Draft a technical/product spec from captured insights."},triage:{description:"Review Linear backlog and prioritize."},interview:{description:"User interview pre-brief + post-synthesis."}},hookSignals:[{event:"UserPromptSubmit",ifMatches:"spec|requirements?|prd",inject:["type=insight","type=question"]}],suggestedTags:{audience:["team","stakeholders"],quarter:["q1","q2","q3","q4"]}},founder:{name:"founder",description:"Founder ops: strategy, fundraising, hiring, stakeholder comms.",suggestedPersona:{role:"Founder",mcps:["gmail","linear","posthog"]},memoryTypes:["goal","okr","person","stakeholder","decision","shipped"],workflowSlots:{"investor-update":{description:"Monthly investor update draft."},"1on1":{description:"1:1 prep + synthesis."},strategy:{description:"Strategy checkpoint \u2014 OKR progress + pivots."}},hookSignals:[{event:"UserPromptSubmit",ifMatches:"investor|board|update|fundrais",inject:["type=okr","type=shipped","type=stakeholder"]}],suggestedTags:{audience:["board","investors","team"]}},research:{name:"research",description:"Research: deep-dives, literature review, competitive scans.",suggestedPersona:{role:"Research",mcps:["web"]},memoryTypes:["source","claim","question","insight"],workflowSlots:{"lit-review":{description:"Literature review across captured sources."},analyze:{description:"Data analysis run via MCP, persist findings."}},hookSignals:[],suggestedTags:{confidence:["high","medium","low"]}}},Nc=Object.keys(Gs);l(gm,"getPackManifest")});var fm={};W(fm,{activatePacks:()=>Fc,deactivatePacks:()=>Uc,detectSuggestedPacks:()=>Lc,listActivePacks:()=>Hc});async function Lc(n){let e=await import("node:fs/promises"),t=await import("node:path"),s=new Set(["daily"]),r=["package.json","go.mod","Cargo.toml","pyproject.toml","Gemfile","pom.xml","build.gradle"];for(let o of r)try{await e.stat(t.join(n,o)),s.add("code");break}catch{}return[...s]}async function Fc(n,e,t={}){let s=[],r=[],o=await I.readConfig(n);if(!o)throw new Error("No prjct project here \u2014 run `prjct init` first.");let i=o.persona??{role:"DEV"},a=new Set(i.packs??[]);for(let m of e){if(!Gs[m]){r.push(m);continue}a.has(m)||(a.add(m),s.push(m))}let c=[...a],u={...i,packs:c};t.suggestPersona&&s.length>0&&Gk(u,s);let d={...o,persona:u};return await I.writeConfig(n,d),{activated:s,skipped:r}}async function Uc(n,e){let t=await I.readConfig(n);if(!t)throw new Error("No prjct project here \u2014 run `prjct init` first.");let s=t.persona??{role:"DEV"},r=new Set(s.packs??[]),o=[],i=[];for(let u of e)r.delete(u)?o.push(u):i.push(u);let a={...s,packs:[...r]},c={...t,persona:a};return await I.writeConfig(n,c),{deactivated:o,notActive:i}}async function Hc(n){let t=(await I.readConfig(n))?.persona?.packs??[],s=[];for(let r of t){let o=Gs[r];o&&s.push({name:o.name,description:o.description,memoryTypes:o.memoryTypes,slots:Object.keys(o.workflowSlots)})}return s}function Gk(n,e){let t=n.role&&n.role!=="DEV",s=n.mcps&&n.mcps.length>0;for(let r of e){let o=gm(r);if(o?.suggestedPersona&&(!t&&o.suggestedPersona.role&&(n.role=o.suggestedPersona.role),!n.focus&&o.suggestedPersona.focus&&(n.focus=o.suggestedPersona.focus),!s&&o.suggestedPersona.mcps&&(n.mcps=[...o.suggestedPersona.mcps]),n.role&&n.role!=="DEV"))break}}var Wc=h(()=>{"use strict";de();Oc();l(Lc,"detectSuggestedPacks");l(Fc,"activatePacks");l(Uc,"deactivatePacks");l(Hc,"listActivePacks");l(Gk,"applyPersonaSuggestion")});var hm,Gc,qc,ym,xn,Yo=h(()=>{"use strict";hm="memory.",Gc="remember.",qc=`${hm}${Gc}`,ym=`${hm}task.tagged`,xn="status.changed"});import wm from"node:path";var qk,Vk,Qo,km=h(()=>{"use strict";be();J();qk=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"],Vk=`# Changelog
763
+ 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}}},sm=$c});function rm(n){if(!n||typeof n!="object")return!1;let e=n;if(e.code&&_k.has(e.code))return!0;if(e.code&&im.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 Nk(n){if(!n||typeof n!="object")return!1;let e=n;return!!(e.code&&im.has(e.code))}function om(n,e,t){let s=vs.get(n);return s&&s.consecutiveFailures>=e&&s.openedAt?Date.now()-s.openedAt>=t?(vs.delete(n),!1):!0:!1}function Dc(n,e){let t=vs.get(n)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),vs.set(n,t)}function Ok(n){vs.delete(n)}var _k,im,vs,zo,am,i$,cm=h(()=>{"use strict";_k=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),im=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);l(rm,"isTransientError");l(Nk,"isPermanentError");vs=new Map;l(om,"isCircuitOpen");l(Dc,"recordFailure");l(Ok,"recordSuccess");zo=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(om(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let s,r=0;for(;r<this.options.maxAttempts;)try{let o=await e();return Ok(t),o}catch(o){if(s=o,r++,Nk(o))throw Dc(t,this.options.circuitBreakerThreshold),o;if(!(rm(o)&&r<this.options.maxAttempts))throw Dc(t,this.options.circuitBreakerThreshold),o;let a=Math.min(this.options.baseDelayMs*2**(r-1),this.options.maxDelayMs);await new Promise(c=>setTimeout(c,a))}throw Dc(t,this.options.circuitBreakerThreshold),s}isTransientError(e){return rm(e)}isCircuitOpen(e){return om(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return vs.get(e)}resetCircuit(e){vs.delete(e)}resetAllCircuits(){vs.clear()}},am=new zo({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),i$=new zo({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});var Lk,Mc,Xo,lm=h(()=>{"use strict";ds();tm();nm();cm();Lk=["claude"],Mc=class{static{l(this,"AgentService")}agent=null;agentInfo=null;async initialize(){return this.agent?this.agent:await am.execute(async()=>{if(this.agentInfo=await em(),!this.agentInfo?.isSupported)throw ar.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!Lk.includes(e))throw ar.notSupported(this.agentInfo?.type??"unknown");return this.agent=new sm,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}reset(){this.agent=null,this.agentInfo=null}},Xo=new Mc});var _c,Nc,um=h(()=>{"use strict";_c=class{static{l(this,"BreakdownService")}breakdownFeature(e){return[]}detectBugSeverity(e){return"medium"}estimateComplexity(e){return{level:"medium",hours:4}}detectTaskType(e){return"feature"}},Nc=new _c});import Qe from"node:path";async function Fk(n,e){let t=e?.packageManager?.trim().toLowerCase();return t?.startsWith("pnpm@")?"pnpm":t?.startsWith("yarn@")?"yarn":t?.startsWith("bun@")?"bun":t?.startsWith("npm@")?"npm":await b(Qe.join(n,"pnpm-lock.yaml"))?"pnpm":await b(Qe.join(n,"yarn.lock"))?"yarn":await b(Qe.join(n,"bun.lockb"))||await b(Qe.join(n,"bun.lock"))?"bun":(await b(Qe.join(n,"package-lock.json")),"npm")}function dm(n,e){return n==="yarn"?`yarn ${e}`:n==="pnpm"?`pnpm run ${e}`:n==="bun"?`bun run ${e}`:`npm run ${e}`}function Uk(n){return n==="yarn"?"yarn test":n==="pnpm"?"pnpm test":n==="bun"?"bun test":"npm test"}async function Rn(n,e){for(let r of Hk)if(await b(Qe.join(n,r)))return r;let s=(e??await Yt(n)).find(r=>r.endsWith(Wk));if(s)return s}async function os(n){for(let e of Gk)if(await b(Qe.join(n,e)))return e}async function Ko(n){let e=Qe.join(n,"package.json"),t=await Se(e,null);if(t){let a=await Fk(n,t),c=t.scripts||{},u={stack:"js",packageManager:a};return c.lint&&(u.lint={tool:a,command:dm(a,"lint")}),c.typecheck&&(u.typecheck={tool:a,command:dm(a,"typecheck")}),c.test&&(u.test={tool:a,command:Uk(a)}),u.versionFile=await Rn(n),u.changelogFile=await os(n),u}if(await b(Qe.join(n,"pytest.ini"))){let a=await Rn(n),c=await os(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}let s=await ut(Qe.join(n,"pyproject.toml"),"");if(s.includes("[tool.pytest")||s.includes("pytest")){let a=await Rn(n),c=await os(n);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}if(await b(Qe.join(n,"Cargo.toml"))){let a=await os(n);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await b(Qe.join(n,"go.mod"))){let a=await Rn(n),c=await os(n);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:c}}let r=await Yt(n);if(r.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await Rn(n,r),c=await os(n);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:c}}if(await b(Qe.join(n,"pom.xml"))){let a=await os(n);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await b(Qe.join(n,"gradlew"))&&(await b(Qe.join(n,"build.gradle"))||await b(Qe.join(n,"build.gradle.kts")))){let a=await os(n);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await Rn(n),i=await os(n);return{stack:"unknown",versionFile:o,changelogFile:i}}var Hk,Wk,Gk,Oc=h(()=>{"use strict";J();l(Fk,"detectPackageManager");l(dm,"pmRun");l(Uk,"pmTest");Hk=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],Wk=".csproj",Gk=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];l(Rn,"detectVersionFile");l(os,"detectChangelogFile");l(Ko,"detectProjectCommands")});import*as ue from"@clack/prompts";import Ws from"chalk";var Yo,pm,$r,mm=h(()=>{"use strict";J();Me();Yo=[{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."}],pm=[{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"}],$r=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(){ue.intro(Ws.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 ue.outro(Ws.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=Yo.findIndex(s=>s.value===this.detectedType),t=await ue.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:Yo.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValue:e>=0?Yo[e].value:void 0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await ue.multiselect({message:"Which AI agents do you use?",options:pm.map(s=>({label:s.title,hint:s.description,value:s.value})),initialValues:e,required:!0});return ue.isCancel(t)?(this.handleCancel(),!1):(this.selectedAgents=t.length>0?t:["claude"],!0)}async stepStack(){this.detectedStack=await this.detectStack();let e=this.formatStackDisplay(this.detectedStack);ue.note(e,"Detected stack");let t=await ue.confirm({message:"Is this stack correct?",initialValue:!0});if(ue.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let s=await ue.group({language:l(()=>ue.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:l(()=>ue.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 ue.group({verbosity:l(()=>ue.select({message:"Output verbosity:",options:[{label:"Minimal",hint:"Essential output only",value:"minimal"},{label:"Normal (Recommended)",hint:"Balanced information",value:"normal"},{label:"Verbose",hint:"Detailed logging",value:"verbose"}],initialValue:"normal"}),"verbosity"),autoSync:l(()=>ue.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=[`${Ws.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${Ws.cyan("AI Agents:")} ${this.selectedAgents.map(s=>this.getAgentLabel(s)).join(", ")}`,`${Ws.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${Ws.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${Ws.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
764
+ `);ue.note(e,"Configuration Summary");let t=await ue.confirm({message:"Generate configuration with these settings?",initialValue:!0});return ue.isCancel(t)||!t?(ue.isCancel(t)&&this.handleCancel(),!1):!0}async detectProjectType(){let e=await import("node:fs/promises"),t=await import("node:path");try{let s=await e.readdir(this.projectPath);if(s.includes("turbo.json")||s.includes("lerna.json")||s.includes("nx.json"))return"monorepo";if(s.includes("package.json")){let r=t.join(this.projectPath,"package.json"),o=await e.readFile(r,"utf-8"),i=JSON.parse(o),a={...i.dependencies,...i.devDependencies};if(i.bin)return"cli-tool";if(i.main&&!a.react&&!a.vue&&!a.angular&&!a.express&&!a.hono)return"library";if((a.react||a.vue)&&(a.express||a.hono||a.fastify))return"fullstack";if(a.react||a.vue||a["@angular/core"]||a.next||a.nuxt)return"web-app";if(a.express||a.hono||a.fastify||a.koa||a.nestjs)return"api-backend"}return s.includes("pyproject.toml")||s.includes("setup.py")?s.some(o=>["main.py","app.py","server.py"].includes(o))?"api-backend":"library":s.includes("go.mod")?s.includes("main.go")?"cli-tool":"library":s.includes("Cargo.toml")?"cli-tool":"unknown"}catch{return"unknown"}}async detectInstalledAgents(){let e=await import("node:path"),t=await import("node:os"),s=[];await Kt(e.join(t.homedir(),".claude"))&&s.push("claude"),await b(e.join(this.projectPath,".cursorrules"))&&s.push("cursor"),await b(e.join(this.projectPath,".windsurfrules"))&&s.push("windsurf"),await b(e.join(this.projectPath,".github","copilot-instructions.md"))&&s.push("copilot"),await Kt(e.join(t.homedir(),".gemini"))&&s.push("gemini");try{let{execAsync:r}=await Promise.resolve().then(()=>(Ze(),Mi));await r("which codex"),s.push("codex")}catch{await Kt(e.join(t.homedir(),".codex"))&&s.push("codex")}return s.length>0?s:["claude"]}async detectStack(){let e=await import("node:fs/promises"),t=await import("node:path"),s={language:"Unknown",technologies:[]};try{let r=await e.readdir(this.projectPath);if(r.includes("package.json")){let o=t.join(this.projectPath,"package.json"),i=await e.readFile(o,"utf-8"),a=JSON.parse(i),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",r.includes("bun.lockb")?s.packageManager="Bun":r.includes("pnpm-lock.yaml")?s.packageManager="pnpm":r.includes("yarn.lock")?s.packageManager="Yarn":r.includes("package-lock.json")&&(s.packageManager="npm"),(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 r.includes("pyproject.toml")||r.includes("requirements.txt")?s.language="Python":r.includes("go.mod")?s.language="Go":r.includes("Cargo.toml")?s.language="Rust":(r.includes("pom.xml")||r.includes("build.gradle"))&&(s.language="Java");return s}catch{return s}}handleCancel(){this.aborted=!0,ue.cancel("Setup cancelled. Run again anytime.")}getProjectTypeLabel(e){return Yo.find(t=>t.value===e)?.title||"Unknown"}getAgentLabel(e){return pm.find(t=>t.value===e)?.title||e}formatStackDisplay(e){let t=[e.language];return e.framework&&t.push(e.framework),e.runtime&&e.runtime!=="Node.js"&&t.push(e.runtime),e.technologies.length>0&&t.push(`+ ${e.technologies.slice(0,3).join(", ")}`),t.join(" / ")}buildResult(e){return{projectType:this.confirmedType,agents:this.selectedAgents,stack:this.confirmedStack,preferences:this.preferences,skipped:e}}getSelectedAgents(){return this.selectedAgents}getConfirmedStack(){return this.confirmedStack}getPreferences(){return this.preferences}}});function gm(n){return Gs[n]??null}var Gs,Lc,Fc=h(()=>{"use strict";Gs={code:{name:"code",description:"Coding work: features, bugs, refactors, TDD, shipping.",suggestedPersona:{role:"DEV",mcps:["github"]},memoryTypes:["fact","decision","learning","gotcha","pattern","anti-pattern","shipped"],workflowSlots:{ship:{description:"Publish finished work \u2014 tests, commit, push, PR."},review:{description:"Pre-commit or pre-PR review pass."}},hookSignals:[],suggestedTags:{domain:["auth","api","frontend","infra","data"]}},daily:{name:"daily",description:"Day-to-day capture + review. GTD-style inbox + weekly review.",memoryTypes:["inbox","todo","idea"],workflowSlots:{morning:{description:"Morning briefing \u2014 pull open todos + upcoming commitments."},clarify:{description:"Reclassify inbox entries to real memory types."},review:{description:"Weekly/biweekly review across memory."}},hookSignals:[]},pm:{name:"pm",description:"Product Management: specs, user interviews, roadmap, backlog triage.",suggestedPersona:{role:"PM",mcps:["linear","posthog"]},memoryTypes:["insight","question","stakeholder","decision","source"],workflowSlots:{spec:{description:"Draft a technical/product spec from captured insights."},triage:{description:"Review Linear backlog and prioritize."},interview:{description:"User interview pre-brief + post-synthesis."}},hookSignals:[{event:"UserPromptSubmit",ifMatches:"spec|requirements?|prd",inject:["type=insight","type=question"]}],suggestedTags:{audience:["team","stakeholders"],quarter:["q1","q2","q3","q4"]}},founder:{name:"founder",description:"Founder ops: strategy, fundraising, hiring, stakeholder comms.",suggestedPersona:{role:"Founder",mcps:["gmail","linear","posthog"]},memoryTypes:["goal","okr","person","stakeholder","decision","shipped"],workflowSlots:{"investor-update":{description:"Monthly investor update draft."},"1on1":{description:"1:1 prep + synthesis."},strategy:{description:"Strategy checkpoint \u2014 OKR progress + pivots."}},hookSignals:[{event:"UserPromptSubmit",ifMatches:"investor|board|update|fundrais",inject:["type=okr","type=shipped","type=stakeholder"]}],suggestedTags:{audience:["board","investors","team"]}},research:{name:"research",description:"Research: deep-dives, literature review, competitive scans.",suggestedPersona:{role:"Research",mcps:["web"]},memoryTypes:["source","claim","question","insight"],workflowSlots:{"lit-review":{description:"Literature review across captured sources."},analyze:{description:"Data analysis run via MCP, persist findings."}},hookSignals:[],suggestedTags:{confidence:["high","medium","low"]}}},Lc=Object.keys(Gs);l(gm,"getPackManifest")});var fm={};W(fm,{activatePacks:()=>Hc,deactivatePacks:()=>Wc,detectSuggestedPacks:()=>Uc,listActivePacks:()=>Gc});async function Uc(n){let e=await import("node:fs/promises"),t=await import("node:path"),s=new Set(["daily"]),r=["package.json","go.mod","Cargo.toml","pyproject.toml","Gemfile","pom.xml","build.gradle"];for(let o of r)try{await e.stat(t.join(n,o)),s.add("code");break}catch{}return[...s]}async function Hc(n,e,t={}){let s=[],r=[],o=await I.readConfig(n);if(!o)throw new Error("No prjct project here \u2014 run `prjct init` first.");let i=o.persona??{role:"DEV"},a=new Set(i.packs??[]);for(let m of e){if(!Gs[m]){r.push(m);continue}a.has(m)||(a.add(m),s.push(m))}let c=[...a],u={...i,packs:c};t.suggestPersona&&s.length>0&&qk(u,s);let d={...o,persona:u};return await I.writeConfig(n,d),{activated:s,skipped:r}}async function Wc(n,e){let t=await I.readConfig(n);if(!t)throw new Error("No prjct project here \u2014 run `prjct init` first.");let s=t.persona??{role:"DEV"},r=new Set(s.packs??[]),o=[],i=[];for(let u of e)r.delete(u)?o.push(u):i.push(u);let a={...s,packs:[...r]},c={...t,persona:a};return await I.writeConfig(n,c),{deactivated:o,notActive:i}}async function Gc(n){let t=(await I.readConfig(n))?.persona?.packs??[],s=[];for(let r of t){let o=Gs[r];o&&s.push({name:o.name,description:o.description,memoryTypes:o.memoryTypes,slots:Object.keys(o.workflowSlots)})}return s}function qk(n,e){let t=n.role&&n.role!=="DEV",s=n.mcps&&n.mcps.length>0;for(let r of e){let o=gm(r);if(o?.suggestedPersona&&(!t&&o.suggestedPersona.role&&(n.role=o.suggestedPersona.role),!n.focus&&o.suggestedPersona.focus&&(n.focus=o.suggestedPersona.focus),!s&&o.suggestedPersona.mcps&&(n.mcps=[...o.suggestedPersona.mcps]),n.role&&n.role!=="DEV"))break}}var qc=h(()=>{"use strict";de();Fc();l(Uc,"detectSuggestedPacks");l(Hc,"activatePacks");l(Wc,"deactivatePacks");l(Gc,"listActivePacks");l(qk,"applyPersonaSuggestion")});var hm,Vc,Bc,ym,xn,Qo=h(()=>{"use strict";hm="memory.",Vc="remember.",Bc=`${hm}${Vc}`,ym=`${hm}task.tagged`,xn="status.changed"});import wm from"node:path";var Vk,Bk,Zo,km=h(()=>{"use strict";be();J();Vk=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"],Bk=`# Changelog
765
765
 
766
766
  All notable changes to this project will be documented in this file.
767
767
 
768
768
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
769
769
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
770
- `,Qo=class{static{l(this,"ChangelogService")}projectPath;constructor(e){this.projectPath=e}async detect(){for(let s of qk){let r=wm.join(this.projectPath,s);if(await b(r)){let o=await lt(r),i=this.detectFormat(o);return{filePath:r,fileName:s,format:i,created:!1}}}let e="CHANGELOG.md",t=wm.join(this.projectPath,e);return await Xt(t,`${Vk}
771
- `),{filePath:t,fileName:e,format:"keepachangelog",created:!0}}async addEntry(e){let t=await this.detect(),s=await lt(t.filePath),r=e.date||pu(new Date),o;t.format==="keepachangelog"?o=this.insertKeepAChangelogEntry(s,e,r):o=this.insertMarkdownEntry(s,e,r),await Xt(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 r=this.formatKeepAChangelogEntry(t,s),o=e.search(/^## /m);if(o!==-1){let i=e.slice(0,o),a=e.slice(o);return`${i+r}
770
+ `,Zo=class{static{l(this,"ChangelogService")}projectPath;constructor(e){this.projectPath=e}async detect(){for(let s of Vk){let r=wm.join(this.projectPath,s);if(await b(r)){let o=await ut(r),i=this.detectFormat(o);return{filePath:r,fileName:s,format:i,created:!1}}}let e="CHANGELOG.md",t=wm.join(this.projectPath,e);return await Xt(t,`${Bk}
771
+ `),{filePath:t,fileName:e,format:"keepachangelog",created:!0}}async addEntry(e){let t=await this.detect(),s=await ut(t.filePath),r=e.date||pu(new Date),o;t.format==="keepachangelog"?o=this.insertKeepAChangelogEntry(s,e,r):o=this.insertMarkdownEntry(s,e,r),await Xt(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 r=this.formatKeepAChangelogEntry(t,s),o=e.search(/^## /m);if(o!==-1){let i=e.slice(0,o),a=e.slice(o);return`${i+r}
772
772
  ${a}`}return`${e.trimEnd()}
773
773
 
774
774
  ${r}`}insertMarkdownEntry(e,t,s){let r=this.formatMarkdownEntry(t,s),o=e.indexOf(`
@@ -778,33 +778,33 @@ ${a}`}return`${r}
778
778
 
779
779
  ${e}`}formatKeepAChangelogEntry(e,t){let s=[`## [${e.version}] - ${t}`];if(s.push(""),e.sections)for(let[r,o]of Object.entries(e.sections)){s.push(`### ${r}`);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(`
780
780
  `)}formatMarkdownEntry(e,t){let s=[`## ${e.version} - ${t}`];if(s.push(""),e.sections)for(let[r,o]of Object.entries(e.sections)){s.push(`### ${r}`);for(let i of o)s.push(`- ${i}`);s.push("")}else e.description&&(s.push(`- ${e.description}`),s.push(""));return s.join(`
781
- `)}}});import An from"node:path";function vm(n){return/^\d+\.\d+\.\d+/.test(n)}function In(n){let e=n.match(/^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+[0-9A-Za-z.-]+)?$/);if(!e)return n;let[,t,s,r,o]=e;if(o){let i=o.split("."),a=i.length-1;return/^\d+$/.test(i[a])?(i[a]=String(Number(i[a])+1),`${t}.${s}.${r}-${i.join(".")}`):`${t}.${s}.${r}-${o}.1`}return`${t}.${s}.${Number(r)+1}`}function Bk(n){let e=n.match(/\[package\]([\s\S]*?)(?=\n\[|\n*$)/);return e?e[1].match(/^\s*version\s*=\s*"([^"]+)"/m)?.[1]??null:null}function Jk(n){let e=n.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=n.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}function zk(n){return n.match(/<Version>([^<]+)<\/Version>/)?.[1]?.trim()??null}var Zo,Sm=h(()=>{"use strict";Ze();J();Zo=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=An.join(this.projectPath,"package.json"),t=await Se(e,null);return t?.version?{current:t.version,next:In(t.version),file:e,format:"json"}:null}async fromCargoToml(){let e=An.join(this.projectPath,"Cargo.toml"),t=await lt(e,"");if(!t)return null;let s=Bk(t);return s?{current:s,next:In(s),file:e,format:"toml"}:null}async fromPyprojectToml(){let e=An.join(this.projectPath,"pyproject.toml"),t=await lt(e,"");if(!t)return null;let s=Jk(t);return s?{current:s,next:In(s),file:e,format:"toml"}:null}async fromCsproj(){let e=await Yt(this.projectPath,{extension:".csproj"});if(e.length===0)return null;let t=An.join(this.projectPath,e[0]),s=await lt(t,"");if(!s)return null;let r=zk(s);return r?{current:r,next:In(r),file:t,format:"xml"}:null}async fromVersionFile(e){let t=An.join(this.projectPath,e),s=await lt(t,"");if(!s)return null;let r=s.trim();return vm(r)?{current:r,next:In(r),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(`
781
+ `)}}});import An from"node:path";function vm(n){return/^\d+\.\d+\.\d+/.test(n)}function In(n){let e=n.match(/^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+[0-9A-Za-z.-]+)?$/);if(!e)return n;let[,t,s,r,o]=e;if(o){let i=o.split("."),a=i.length-1;return/^\d+$/.test(i[a])?(i[a]=String(Number(i[a])+1),`${t}.${s}.${r}-${i.join(".")}`):`${t}.${s}.${r}-${o}.1`}return`${t}.${s}.${Number(r)+1}`}function Jk(n){let e=n.match(/\[package\]([\s\S]*?)(?=\n\[|\n*$)/);return e?e[1].match(/^\s*version\s*=\s*"([^"]+)"/m)?.[1]??null:null}function zk(n){let e=n.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=n.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}function Xk(n){return n.match(/<Version>([^<]+)<\/Version>/)?.[1]?.trim()??null}var ei,Sm=h(()=>{"use strict";Ze();J();ei=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=An.join(this.projectPath,"package.json"),t=await Se(e,null);return t?.version?{current:t.version,next:In(t.version),file:e,format:"json"}:null}async fromCargoToml(){let e=An.join(this.projectPath,"Cargo.toml"),t=await ut(e,"");if(!t)return null;let s=Jk(t);return s?{current:s,next:In(s),file:e,format:"toml"}:null}async fromPyprojectToml(){let e=An.join(this.projectPath,"pyproject.toml"),t=await ut(e,"");if(!t)return null;let s=zk(t);return s?{current:s,next:In(s),file:e,format:"toml"}:null}async fromCsproj(){let e=await Yt(this.projectPath,{extension:".csproj"});if(e.length===0)return null;let t=An.join(this.projectPath,e[0]),s=await ut(t,"");if(!s)return null;let r=Xk(s);return r?{current:r,next:In(r),file:t,format:"xml"}:null}async fromVersionFile(e){let t=An.join(this.projectPath,e),s=await ut(t,"");if(!s)return null;let r=s.trim();return vm(r)?{current:r,next:In(r),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(`
782
782
  `);for(let s of t){let r=s.trim().replace(/^v/,"");if(vm(r))return{current:r,next:In(r),file:null,format:"git-tag"}}}catch{}return null}async createFallbackVersion(){let e=An.join(this.projectPath,"VERSION");return await Xt(e,`0.1.0
783
783
  `),{current:"0.1.0",next:"0.1.1",file:e,format:"plaintext"}}async writeVersion(e){if(!e.file){e.format==="git-tag"&&await zt("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 Xt(e.file,`${e.next}
784
- `);break}}async writeJsonVersion(e,t){let s=await Se(e,{});s&&(s.version=t,await ie(e,s))}async writeTomlVersion(e,t){let s=await lt(e,"");if(!s)return;let r=s.replace(/^(\s*version\s*=\s*")([^"]+)(")/m,`$1${t}$3`);await Xt(e,r)}async writeXmlVersion(e,t){let s=await lt(e,"");if(!s)return;let r=s.replace(/(<Version>)([^<]+)(<\/Version>)/,`$1${t}$3`);await Xt(e,r)}};l(vm,"isSemver");l(In,"bumpPatch");l(Bk,"parseTomlVersion");l(Jk,"parsePyprojectVersion");l(zk,"parseCsprojVersion")});async function ei(n){try{let{stdout:e}=await O("git branch --show-current",{cwd:n});return e.trim()||void 0}catch{return}}var Vc=h(()=>{"use strict";Ze();l(ei,"getGitBranch")});function Xk(n){let e=n.split(/\s+/).map(s=>s.trim()).filter(Boolean),t=[];for(let s of e){let r=s.match(/^tags:([a-zA-Z0-9_\-.]+)([=~])(.+)$/);if(r){t.push({kind:"tags",key:r[1],op:r[2],value:r[3]});continue}let o=s.match(/^branch([=~])(.+)$/);if(o){t.push({kind:"branch",op:o[1],value:o[2]});continue}let i=s.match(/^files:(.+)$/);i&&t.push({kind:"files",op:"~",value:i[1]})}return t}function Kk(n){let e=bm.get(n);if(e)return e;let t="";for(let r=0;r<n.length;r++){let o=n[r];o==="*"?n[r+1]==="*"?(t+=".*",r++):t+="[^/]*":/[.+^${}()|[\]\\]/.test(o)?t+=`\\${o}`:t+=o}let s=new RegExp(`^${t}$`);return bm.set(n,s),s}function Yk(n,e){if(n.kind==="tags"){let t=e.tags[n.key??""]??"";return n.op==="="?t===n.value:t.toLowerCase().includes(n.value.toLowerCase())}if(n.kind==="branch")return n.op==="="?e.branch===n.value:e.branch.toLowerCase().includes(n.value.toLowerCase());if(n.kind==="files"){let t=Kk(n.value);return e.filesChanged.some(s=>t.test(s))}return!0}function Tm(n,e){if(!n||!n.trim())return!0;let t=Xk(n);return t.length===0?!0:t.every(s=>Yk(s,e))}var bm,Em=h(()=>{"use strict";l(Xk,"parseWhen");bm=new Map;l(Kk,"globToRegex");l(Yk,"matchCondition");l(Tm,"evaluateWhen")});import{execSync as Qk}from"node:child_process";import Zk from"node:fs/promises";import Bc from"node:path";import pt from"chalk";async function nv(n,e,t){let s=await D.getCurrentTask(n);if(!s)throw new Error(`Cannot transition to '${t}': no active task`);await Ye.log(e,xn,{taskId:s.id,from:s.type??null,to:t,source:"workflow"})}async function rv(n,e){if(n.trustSource==="imported")throw new Error(`Refusing to run imported rule without approval: ${n.description||n.action}. Re-create the rule locally if you trust it.`);await O(n.action,{timeout:n.timeoutMs,cwd:e,env:{...process.env}})}async function ov(n,e,t){if(n.trustSource==="imported")throw new Error(`Refusing to run imported script rule without approval: ${n.description||n.action}.`);let s=n.action.slice(jm.length).trim();if(!s)throw new Error(`Empty script path in action '${n.action}'`);let r=Bc.resolve(e,".prjct/workflows",s),o=Bc.resolve(e,".prjct/workflows");if(!r.startsWith(`${o}${Bc.sep}`)&&r!==o)throw new Error(`Script path escapes workflows dir: ${s}`);try{await Zk.access(r)}catch{throw new Error(`Script not found: .prjct/workflows/${s}`)}await O(`bash ${JSON.stringify(r)}`,{timeout:n.timeoutMs,cwd:e,env:{...process.env,PRJCT_BRANCH:t.branch,PRJCT_FILES_CHANGED:t.filesChanged.join(","),PRJCT_TAGS:Object.entries(t.tags).map(([i,a])=>`${i}=${a}`).join(",")}})}function iv(n){let e=n.action.slice(Rm.length).trim(),t=e.indexOf(":");if(t===-1)return`Call MCP tool ${JSON.stringify(e)} (server unspecified \u2014 re-author rule with format \`mcp:<server>:<tool>[:<args>]\`).`;let s=e.slice(0,t),r=e.slice(t+1),o=r.indexOf(":"),i=o===-1?r:r.slice(0,o),a=o===-1?"":r.slice(o+1),c=n.description?` (${n.description})`:"";return a?`Call MCP \`${s}.${i}\` with args ${a}${c}.`:`Call MCP \`${s}.${i}\`${c}.`}async function av(n){try{let{default:e}=await Promise.resolve().then(()=>(de(),ur)),s=(await e.readConfig(n))?.persona;if(!s)return"No persona declared for this project \u2014 `.prjct/prjct.config.json` has no `persona` field.";let r=[`You are **${s.role}** in this project.`];return s.focus&&r.push(`Focus: ${s.focus}.`),s.mcps&&s.mcps.length>0&&r.push(`MCPs available: ${s.mcps.join(", ")}.`),s.packs&&s.packs.length>0&&r.push(`Active packs: ${s.packs.join(", ")}.`),r.join(" ")}catch(e){return`Could not resolve persona: ${k(e)}`}}async function cv(n,e){let s=await new Zo(n).bump();e.version=s}async function lv(n,e){let t=typeof e.version=="string"?e.version:null,s=typeof e.feature=="string"?e.feature:null;if(!t)throw new Error("changelog:add requires a prior version:bump step (no version in runContext)");if(!s)throw new Error("changelog:add requires a feature name in runContext (set by ship before rules run)");await new Qo(n).addFeature(t,s)}function uv(n,e){return n.replace(/\$([A-Z_]+)/g,(t,s)=>{let r=s.toLowerCase(),o=e[r];return typeof o=="string"?o:""})}async function dv(n,e,t){let r=n.slice(zc.length).replace(/^:/,"").trim()||(t.version?"feat: $FEATURE (v$VERSION)":"feat: $FEATURE"),o=`${uv(r,t)}
784
+ `);break}}async writeJsonVersion(e,t){let s=await Se(e,{});s&&(s.version=t,await ie(e,s))}async writeTomlVersion(e,t){let s=await ut(e,"");if(!s)return;let r=s.replace(/^(\s*version\s*=\s*")([^"]+)(")/m,`$1${t}$3`);await Xt(e,r)}async writeXmlVersion(e,t){let s=await ut(e,"");if(!s)return;let r=s.replace(/(<Version>)([^<]+)(<\/Version>)/,`$1${t}$3`);await Xt(e,r)}};l(vm,"isSemver");l(In,"bumpPatch");l(Jk,"parseTomlVersion");l(zk,"parsePyprojectVersion");l(Xk,"parseCsprojVersion")});async function ti(n){try{let{stdout:e}=await O("git branch --show-current",{cwd:n});return e.trim()||void 0}catch{return}}var Jc=h(()=>{"use strict";Ze();l(ti,"getGitBranch")});function Kk(n){let e=n.split(/\s+/).map(s=>s.trim()).filter(Boolean),t=[];for(let s of e){let r=s.match(/^tags:([a-zA-Z0-9_\-.]+)([=~])(.+)$/);if(r){t.push({kind:"tags",key:r[1],op:r[2],value:r[3]});continue}let o=s.match(/^branch([=~])(.+)$/);if(o){t.push({kind:"branch",op:o[1],value:o[2]});continue}let i=s.match(/^files:(.+)$/);i&&t.push({kind:"files",op:"~",value:i[1]})}return t}function Yk(n){let e=bm.get(n);if(e)return e;let t="";for(let r=0;r<n.length;r++){let o=n[r];o==="*"?n[r+1]==="*"?(t+=".*",r++):t+="[^/]*":/[.+^${}()|[\]\\]/.test(o)?t+=`\\${o}`:t+=o}let s=new RegExp(`^${t}$`);return bm.set(n,s),s}function Qk(n,e){if(n.kind==="tags"){let t=e.tags[n.key??""]??"";return n.op==="="?t===n.value:t.toLowerCase().includes(n.value.toLowerCase())}if(n.kind==="branch")return n.op==="="?e.branch===n.value:e.branch.toLowerCase().includes(n.value.toLowerCase());if(n.kind==="files"){let t=Yk(n.value);return e.filesChanged.some(s=>t.test(s))}return!0}function Tm(n,e){if(!n||!n.trim())return!0;let t=Kk(n);return t.length===0?!0:t.every(s=>Qk(s,e))}var bm,Em=h(()=>{"use strict";l(Kk,"parseWhen");bm=new Map;l(Yk,"globToRegex");l(Qk,"matchCondition");l(Tm,"evaluateWhen")});import{execSync as Zk}from"node:child_process";import ev from"node:fs/promises";import zc from"node:path";import pt from"chalk";async function rv(n,e,t){let s=await D.getCurrentTask(n);if(!s)throw new Error(`Cannot transition to '${t}': no active task`);await Ye.log(e,xn,{taskId:s.id,from:s.type??null,to:t,source:"workflow"})}async function ov(n,e){if(n.trustSource==="imported")throw new Error(`Refusing to run imported rule without approval: ${n.description||n.action}. Re-create the rule locally if you trust it.`);await O(n.action,{timeout:n.timeoutMs,cwd:e,env:{...process.env}})}async function iv(n,e,t){if(n.trustSource==="imported")throw new Error(`Refusing to run imported script rule without approval: ${n.description||n.action}.`);let s=n.action.slice(jm.length).trim();if(!s)throw new Error(`Empty script path in action '${n.action}'`);let r=zc.resolve(e,".prjct/workflows",s),o=zc.resolve(e,".prjct/workflows");if(!r.startsWith(`${o}${zc.sep}`)&&r!==o)throw new Error(`Script path escapes workflows dir: ${s}`);try{await ev.access(r)}catch{throw new Error(`Script not found: .prjct/workflows/${s}`)}await O(`bash ${JSON.stringify(r)}`,{timeout:n.timeoutMs,cwd:e,env:{...process.env,PRJCT_BRANCH:t.branch,PRJCT_FILES_CHANGED:t.filesChanged.join(","),PRJCT_TAGS:Object.entries(t.tags).map(([i,a])=>`${i}=${a}`).join(",")}})}function av(n){let e=n.action.slice(Rm.length).trim(),t=e.indexOf(":");if(t===-1)return`Call MCP tool ${JSON.stringify(e)} (server unspecified \u2014 re-author rule with format \`mcp:<server>:<tool>[:<args>]\`).`;let s=e.slice(0,t),r=e.slice(t+1),o=r.indexOf(":"),i=o===-1?r:r.slice(0,o),a=o===-1?"":r.slice(o+1),c=n.description?` (${n.description})`:"";return a?`Call MCP \`${s}.${i}\` with args ${a}${c}.`:`Call MCP \`${s}.${i}\`${c}.`}async function cv(n){try{let{default:e}=await Promise.resolve().then(()=>(de(),ur)),s=(await e.readConfig(n))?.persona;if(!s)return"No persona declared for this project \u2014 `.prjct/prjct.config.json` has no `persona` field.";let r=[`You are **${s.role}** in this project.`];return s.focus&&r.push(`Focus: ${s.focus}.`),s.mcps&&s.mcps.length>0&&r.push(`MCPs available: ${s.mcps.join(", ")}.`),s.packs&&s.packs.length>0&&r.push(`Active packs: ${s.packs.join(", ")}.`),r.join(" ")}catch(e){return`Could not resolve persona: ${k(e)}`}}async function lv(n,e){let s=await new ei(n).bump();e.version=s}async function uv(n,e){let t=typeof e.version=="string"?e.version:null,s=typeof e.feature=="string"?e.feature:null;if(!t)throw new Error("changelog:add requires a prior version:bump step (no version in runContext)");if(!s)throw new Error("changelog:add requires a feature name in runContext (set by ship before rules run)");await new Zo(n).addFeature(t,s)}function dv(n,e){return n.replace(/\$([A-Z_]+)/g,(t,s)=>{let r=s.toLowerCase(),o=e[r];return typeof o=="string"?o:""})}async function pv(n,e,t){let r=n.slice(Kc.length).replace(/^:/,"").trim()||(t.version?"feat: $FEATURE (v$VERSION)":"feat: $FEATURE"),o=`${dv(r,t)}
785
785
 
786
- Generated with [p/](https://www.prjct.app/)`;await zt("git",["add","."],{cwd:e}),await zt("git",["commit","-m",o],{cwd:e})}async function pv(n){await zt("git",["push"],{cwd:n})}async function Jc(n,e,t,s,r,o){let i=n.action;if(i.startsWith(Cm)){let a=i.slice(Cm.length).trim();if(!a)throw new Error(`Empty status target in action '${i}'`);await nv(e,t,a);return}if(i.startsWith(jm)){await ov(n,t,s);return}if(i.startsWith(Rm)){r.instructions.push(iv(n));return}if(i===ev){r.instructions.push(await av(t));return}if(i===Pm||i.startsWith(`${Pm}:`)){await cv(t,o);return}if(i===tv){await lv(t,o);return}if(i===zc||i.startsWith(`${zc}:`)){await dv(i,t,o);return}if(i===sv){await pv(t);return}await rv(n,t)}async function mv(n,e){let[t,s,r]=await Promise.all([gv(e),fv(e),hv(n)]);return{branch:t,filesChanged:s,tags:r}}async function gv(n){try{return await ei(n)||""}catch{return""}}async function fv(n){let e={cwd:n,encoding:"utf-8"},t=l(async o=>{try{return Qk(o,e).split(`
787
- `).map(i=>i.trim()).filter(Boolean)}catch{return[]}},"runDiff"),[s,r]=await Promise.all([t("git diff --cached --name-only"),t("git diff --name-only")]);return[...new Set([...s,...r])]}async function hv(n){try{let e=await D.getCurrentTask(n),t={};if(e?.type&&(t.type=e.type),!e)return t;let s=L.get(n,"SELECT data FROM events WHERE type = ? ORDER BY id DESC LIMIT 1",ym);if(s)try{let r=JSON.parse(s.data);if(r.taskId===e.id&&r.tags)return{...t,...r.tags}}catch{}return t}catch{return{}}}async function Ss(n,e,t,s={}){let r={success:!0,gatesFailed:[],hooksFailed:[],stepsRun:[],instructions:[],output:""};if(s.skipRules)return r;let o=s.runContext??{},a=ee.getRulesForCommand(n,e).filter(w=>w.position===t),c=s.projectPath||process.cwd(),d=a.some(w=>w.whenExpr||w.type==="gate")?await mv(n,c):{branch:"",filesChanged:[],tags:{}},m=a.filter(w=>Tm(w.whenExpr,d)),p=m.filter(w=>w.type==="gate");for(let w of p){let P=w.description||w.action;console.log(`
788
- ${pt.dim(`[gate] ${t}-${e}: ${w.action}`)}`);try{let v=Date.now();await Jc(w,n,c,d,r,o);let M=Date.now()-v,F=M>1e3?`${(M/1e3).toFixed(1)}s`:`${M}ms`;console.log(`${pt.green("\u2713")} ${pt.dim(`gate passed (${F})`)}`)}catch(v){return console.log(`${pt.red("\u2717")} gate failed: ${P}`),r.gatesFailed.push(P),r.success=!1,r.output+=`Gate failed: ${P}
786
+ Generated with [p/](https://www.prjct.app/)`;await zt("git",["add","."],{cwd:e}),await zt("git",["commit","-m",o],{cwd:e})}async function mv(n){await zt("git",["push"],{cwd:n})}async function Xc(n,e,t,s,r,o){let i=n.action;if(i.startsWith(Cm)){let a=i.slice(Cm.length).trim();if(!a)throw new Error(`Empty status target in action '${i}'`);await rv(e,t,a);return}if(i.startsWith(jm)){await iv(n,t,s);return}if(i.startsWith(Rm)){r.instructions.push(av(n));return}if(i===tv){r.instructions.push(await cv(t));return}if(i===Pm||i.startsWith(`${Pm}:`)){await lv(t,o);return}if(i===sv){await uv(t,o);return}if(i===Kc||i.startsWith(`${Kc}:`)){await pv(i,t,o);return}if(i===nv){await mv(t);return}await ov(n,t)}async function gv(n,e){let[t,s,r]=await Promise.all([fv(e),hv(e),yv(n)]);return{branch:t,filesChanged:s,tags:r}}async function fv(n){try{return await ti(n)||""}catch{return""}}async function hv(n){let e={cwd:n,encoding:"utf-8"},t=l(async o=>{try{return Zk(o,e).split(`
787
+ `).map(i=>i.trim()).filter(Boolean)}catch{return[]}},"runDiff"),[s,r]=await Promise.all([t("git diff --cached --name-only"),t("git diff --name-only")]);return[...new Set([...s,...r])]}async function yv(n){try{let e=await D.getCurrentTask(n),t={};if(e?.type&&(t.type=e.type),!e)return t;let s=L.get(n,"SELECT data FROM events WHERE type = ? ORDER BY id DESC LIMIT 1",ym);if(s)try{let r=JSON.parse(s.data);if(r.taskId===e.id&&r.tags)return{...t,...r.tags}}catch{}return t}catch{return{}}}async function Ss(n,e,t,s={}){let r={success:!0,gatesFailed:[],hooksFailed:[],stepsRun:[],instructions:[],output:""};if(s.skipRules)return r;let o=s.runContext??{},a=ee.getRulesForCommand(n,e).filter(w=>w.position===t),c=s.projectPath||process.cwd(),d=a.some(w=>w.whenExpr||w.type==="gate")?await gv(n,c):{branch:"",filesChanged:[],tags:{}},m=a.filter(w=>Tm(w.whenExpr,d)),p=m.filter(w=>w.type==="gate");for(let w of p){let P=w.description||w.action;console.log(`
788
+ ${pt.dim(`[gate] ${t}-${e}: ${w.action}`)}`);try{let v=Date.now();await Xc(w,n,c,d,r,o);let M=Date.now()-v,F=M>1e3?`${(M/1e3).toFixed(1)}s`:`${M}ms`;console.log(`${pt.green("\u2713")} ${pt.dim(`gate passed (${F})`)}`)}catch(v){return console.log(`${pt.red("\u2717")} gate failed: ${P}`),r.gatesFailed.push(P),r.success=!1,r.output+=`Gate failed: ${P}
789
789
  ${k(v)}
790
790
  `,r}}let g=m.filter(w=>w.type==="instruction");for(let w of g){let P=w.description||w.action;console.log(`
791
791
  ${pt.dim(`[instruction] ${t}-${e}: ${P}`)}`),r.instructions.push(w.action)}let y=m.filter(w=>w.type==="hook"),j=y.filter(w=>w.parallel===!1),T=y.filter(w=>w.parallel!==!1),x=l(async w=>{console.log(`
792
- ${pt.dim(`[hook] ${t}-${e}: ${w.action}`)}`);try{let P=Date.now();await Jc(w,n,c,d,r,o);let v=Date.now()-P,M=v>1e3?`${(v/1e3).toFixed(1)}s`:`${v}ms`;console.log(`${pt.green("\u2713")} ${pt.dim(`(${M})`)}`)}catch(P){console.log(`${pt.yellow("\u26A0")} hook failed (non-blocking): ${w.action}`),r.hooksFailed.push(w.description||w.action),r.output+=`Hook failed: ${w.action}
792
+ ${pt.dim(`[hook] ${t}-${e}: ${w.action}`)}`);try{let P=Date.now();await Xc(w,n,c,d,r,o);let v=Date.now()-P,M=v>1e3?`${(v/1e3).toFixed(1)}s`:`${v}ms`;console.log(`${pt.green("\u2713")} ${pt.dim(`(${M})`)}`)}catch(P){console.log(`${pt.yellow("\u26A0")} hook failed (non-blocking): ${w.action}`),r.hooksFailed.push(w.description||w.action),r.output+=`Hook failed: ${w.action}
793
793
  ${k(P)}
794
794
  `}},"runHook");for(let w of j)await x(w);T.length>0&&await Promise.all(T.map(x));let S=m.filter(w=>w.type==="step");for(let w of S){console.log(`
795
- ${pt.dim(`[step] ${e}: ${w.action}`)}`);try{let P=Date.now();await Jc(w,n,c,d,r,o);let v=Date.now()-P,M=v>1e3?`${(v/1e3).toFixed(1)}s`:`${v}ms`;console.log(`${pt.green("\u2713")} ${pt.dim(`step passed (${M})`)}`),r.stepsRun.push(w.description||w.action)}catch(P){return console.log(`${pt.red("\u2717")} step failed: ${w.action}`),r.gatesFailed.push(w.description||w.action),r.success=!1,r.output+=`Step failed: ${w.action}
795
+ ${pt.dim(`[step] ${e}: ${w.action}`)}`);try{let P=Date.now();await Xc(w,n,c,d,r,o);let v=Date.now()-P,M=v>1e3?`${(v/1e3).toFixed(1)}s`:`${v}ms`;console.log(`${pt.green("\u2713")} ${pt.dim(`step passed (${M})`)}`),r.stepsRun.push(w.description||w.action)}catch(P){return console.log(`${pt.red("\u2717")} step failed: ${w.action}`),r.gatesFailed.push(w.description||w.action),r.success=!1,r.output+=`Step failed: ${w.action}
796
796
  ${k(P)}
797
- `,r}}return r}var Cm,jm,Rm,ev,Pm,tv,zc,sv,Xc=h(()=>{"use strict";Yo();km();ks();Sm();Vc();ce();rt();mn();V();Ze();Em();Cm="status:",jm="script:",Rm="mcp:",ev="persona:context",Pm="version:bump",tv="changelog:add",zc="git:commit",sv="git:push";l(nv,"runStatusTransition");l(rv,"runShellAction");l(ov,"runScriptAction");l(iv,"buildMcpInstruction");l(av,"buildPersonaInstruction");l(cv,"runVersionBump");l(lv,"runChangelogAdd");l(uv,"expandTemplate");l(dv,"runGitCommit");l(pv,"runGitPush");l(Jc,"runRuleAction");l(mv,"buildWhenContext");l(gv,"resolveBranch");l(fv,"resolveChangedFiles");l(hv,"resolveActiveTags");l(Ss,"executeWorkflowRules")});function xm(n,e){try{return JSON.parse(n)}catch{return e}}function Sv(n){let e=n.type.slice(qc.length),t=xm(n.data,{});return{id:`mem_${n.id}`,type:e,content:t.content??"",tags:t.tags??{},rememberedAt:n.timestamp,source:t.source,provenance:t.provenance??"declared"}}function bv(n){let e=n.data?xm(n.data,{}):{},t=e.tags??{};return n.type&&(t.type=n.type),{id:`ship_${n.id}`,type:"shipped",content:n.name,tags:t,rememberedAt:n.shipped_at,source:e.taskId,provenance:"extracted"}}function Tv(n,e){let t=e.toLowerCase();if(n.content.toLowerCase().includes(t))return!0;for(let s of Object.values(n.tags))if(s.toLowerCase().includes(t))return!0;return!1}function Ev(n,e){for(let[t,s]of Object.entries(e))if(n.tags[t]!==s)return!1;return!0}function mt(n){if(n.length===0)return"> No matching memory entries.";let e=new Map;for(let o of n){let i=e.get(o.type)??[];i.push(o),e.set(o.type,i)}let t=["decision","learning","anti-pattern","gotcha","pattern","fact","shipped"],s=[],r={declared:"DECL",extracted:"EXTR",inferred:"INFR",ambiguous:"AMBG"};for(let o of t){let i=e.get(o);if(!(!i||i.length===0)){s.push(`### ${o.toUpperCase()}`);for(let a of i){let c=Object.entries(a.tags).map(([m,p])=>`${m}=${p}`).join(" "),u=c?` _(${c})_`:"",d=r[a.provenance];s.push(`- \`${d}\` [${a.id}] ${a.content}${u}`)}s.push("")}}return s.join(`
798
- `).trim()}var yv,$n,wv,kv,vv,Ve,os=h(()=>{"use strict";ks();ce();Yo();yv=["fact","decision","learning","gotcha","pattern","anti-pattern","shipped","inbox","todo","idea","insight","question","source","person"],$n=yv,wv=25,kv=4,vv=100;l(xm,"safeJson");l(Sv,"rowToEntry");l(bv,"shippedRowToEntry");l(Tv,"matchesTopic");l(Ev,"matchesTags");Ve={async remember(n,e){await Ye.log(n,`${Gc}${e.type}`,{content:e.content,tags:e.tags??{},source:e.source,provenance:e.provenance??"declared"})},recall(n,e={}){let t=e.limit??wv,s=Math.max(t*kv,vv),r=L.query(n,"SELECT id, type, data, timestamp FROM events WHERE type LIKE ? ORDER BY id DESC LIMIT ?",`${qc}%`,s),o=L.query(n,"SELECT id, name, type, shipped_at, data FROM shipped_features ORDER BY shipped_at DESC LIMIT ?",s),i=[...r.map(Sv),...o.map(bv)];if(e.types&&e.types.length>0){let a=new Set(e.types);i=i.filter(c=>a.has(c.type))}return e.tags&&(i=i.filter(a=>Ev(a,e.tags??{}))),e.topic&&(i=i.filter(a=>Tv(a,e.topic))),i.sort((a,c)=>c.rememberedAt.localeCompare(a.rememberedAt)),i.slice(0,t)},similar(n,e,t=10){let s=e.toLowerCase().split(/[^a-z0-9]+/).filter(i=>i.length>3);return s.length===0?[]:Ve.recall(n,{limit:200}).map(i=>{let a=`${i.content} ${Object.values(i.tags).join(" ")}`.toLowerCase(),c=s.reduce((u,d)=>a.includes(d)?u+1:u,0);return{entry:i,hits:c}}).filter(i=>i.hits>0).sort((i,a)=>a.hits-i.hits).slice(0,t).map(i=>i.entry)}};l(mt,"formatMemoryMd")});import Cv from"node:crypto";import Dr from"node:fs/promises";import Pv from"node:os";import Dt from"node:path";async function Am(n){let e=await Rv(n),t=Dt.basename(n),s=`obsidian://open?vault=${encodeURIComponent(t)}`,r=jv();if(!r)return{bootstrapped:e,registered:!1,vaultName:t,openUrl:s,obsidianConfigFound:!1,alreadyRegistered:!1};let{registered:o,alreadyRegistered:i}=await xv(r,n);return{bootstrapped:e,registered:o,vaultName:t,openUrl:s,obsidianConfigFound:!0,alreadyRegistered:i}}function jv(){let n=Pv.homedir(),e,t=process.env.PRJCT_OBSIDIAN_CONFIG_DIR?.trim();if(t)e=t;else switch(process.platform){case"darwin":e=Dt.join(n,"Library","Application Support","obsidian");break;case"win32":e=Dt.join(process.env.APPDATA||Dt.join(n,"AppData","Roaming"),"obsidian");break;default:e=Dt.join(process.env.XDG_CONFIG_HOME||Dt.join(n,".config"),"obsidian");break}try{if(!Je("node:fs").existsSync(e))return null}catch{return null}return Dt.join(e,"obsidian.json")}async function Rv(n){let e=Dt.join(n,".obsidian"),t=Dt.join(e,"app.json");try{return await Dr.stat(t),!1}catch{}return await Dr.mkdir(e,{recursive:!0}),await Dr.writeFile(t,`${JSON.stringify({},null,2)}
799
- `,"utf-8"),!0}async function xv(n,e){let t={};try{let a=await Dr.readFile(n,"utf-8");t=JSON.parse(a)}catch{}let s=t.vaults??{},r=Dt.resolve(e);for(let a of Object.values(s))if(Dt.resolve(a.path)===r)return{registered:!1,alreadyRegistered:!0};let o=Cv.randomBytes(8).toString("hex");s[o]={path:r,ts:Date.now()};let i={...t,vaults:s};try{return await Dr.writeFile(n,JSON.stringify(i),"utf-8"),{registered:!0,alreadyRegistered:!1}}catch{return{registered:!1,alreadyRegistered:!1}}}var Im=h(()=>{"use strict";l(Am,"ensureObsidianVault");l(jv,"resolveObsidianConfigPath");l(Rv,"bootstrapObsidianDir");l(xv,"registerVaultInObsidianConfig")});function Dn(n){let e=[];for(let{name:t,re:s}of Av)s.test(n)&&e.push(t);return e}var Av,ti=h(()=>{"use strict";Av=[{name:"sk-\u2026 token",re:/\bsk-[A-Za-z0-9_-]{16,}/},{name:"GitHub PAT",re:/\bghp_[A-Za-z0-9]{30,}/},{name:"GitHub server PAT",re:/\bghs_[A-Za-z0-9]{30,}/},{name:"AWS access key",re:/\bAKIA[0-9A-Z]{16}\b/},{name:"Slack token",re:/\bxox[abps]-[A-Za-z0-9-]{10,}/},{name:"bearer JWT-ish",re:/\beyJ[A-Za-z0-9_-]{20,}\.[A-Za-z0-9_-]{20,}\.[A-Za-z0-9_-]{20,}\b/}];l(Dn,"scanForSecrets")});import Mt from"node:fs/promises";import Mn from"node:path";async function si(n){await $v(n);let e=await I.readConfig(n).catch(()=>null);return $.getWikiPath(n,e?.vaultPath)}async function $v(n){let e=await I.readConfig(n).catch(()=>null);if(e?.vaultPath&&e.vaultPath.trim().length>0)return{moved:!1,reason:"user-override"};let t=$.getLegacyWikiPath(n);if(!await Dm(t))return{moved:!1,reason:"no-legacy"};let r=$.getWikiPath(n);if(await Dm(r))return console.error(`\u26A0 prjct: legacy wiki at ${t} was NOT migrated \u2014 ${r} already has content.
800
- Merge manually or set \`vaultPath\` in .prjct/prjct.config.json to choose one.`),{moved:!1,reason:"conflict",from:t,to:r};await Mt.mkdir(Mn.dirname(r),{recursive:!0});let i=await Dv(t,r);return await Mv(n),console.error(`\u2139 prjct: migrated Obsidian vault
797
+ `,r}}return r}var Cm,jm,Rm,tv,Pm,sv,Kc,nv,Yc=h(()=>{"use strict";Qo();km();ks();Sm();Jc();ce();ot();mn();V();Ze();Em();Cm="status:",jm="script:",Rm="mcp:",tv="persona:context",Pm="version:bump",sv="changelog:add",Kc="git:commit",nv="git:push";l(rv,"runStatusTransition");l(ov,"runShellAction");l(iv,"runScriptAction");l(av,"buildMcpInstruction");l(cv,"buildPersonaInstruction");l(lv,"runVersionBump");l(uv,"runChangelogAdd");l(dv,"expandTemplate");l(pv,"runGitCommit");l(mv,"runGitPush");l(Xc,"runRuleAction");l(gv,"buildWhenContext");l(fv,"resolveBranch");l(hv,"resolveChangedFiles");l(yv,"resolveActiveTags");l(Ss,"executeWorkflowRules")});function xm(n,e){try{return JSON.parse(n)}catch{return e}}function bv(n){let e=n.type.slice(Bc.length),t=xm(n.data,{});return{id:`mem_${n.id}`,type:e,content:t.content??"",tags:t.tags??{},rememberedAt:n.timestamp,source:t.source,provenance:t.provenance??"declared"}}function Tv(n){let e=n.data?xm(n.data,{}):{},t=e.tags??{};return n.type&&(t.type=n.type),{id:`ship_${n.id}`,type:"shipped",content:n.name,tags:t,rememberedAt:n.shipped_at,source:e.taskId,provenance:"extracted"}}function Ev(n,e){let t=e.toLowerCase();if(n.content.toLowerCase().includes(t))return!0;for(let s of Object.values(n.tags))if(s.toLowerCase().includes(t))return!0;return!1}function Cv(n,e){for(let[t,s]of Object.entries(e))if(n.tags[t]!==s)return!1;return!0}function mt(n){if(n.length===0)return"> No matching memory entries.";let e=new Map;for(let o of n){let i=e.get(o.type)??[];i.push(o),e.set(o.type,i)}let t=["decision","learning","anti-pattern","gotcha","pattern","fact","shipped"],s=[],r={declared:"DECL",extracted:"EXTR",inferred:"INFR",ambiguous:"AMBG"};for(let o of t){let i=e.get(o);if(!(!i||i.length===0)){s.push(`### ${o.toUpperCase()}`);for(let a of i){let c=Object.entries(a.tags).map(([m,p])=>`${m}=${p}`).join(" "),u=c?` _(${c})_`:"",d=r[a.provenance];s.push(`- \`${d}\` [${a.id}] ${a.content}${u}`)}s.push("")}}return s.join(`
798
+ `).trim()}var wv,$n,kv,vv,Sv,Ve,is=h(()=>{"use strict";ks();ce();Qo();wv=["fact","decision","learning","gotcha","pattern","anti-pattern","shipped","inbox","todo","idea","insight","question","source","person"],$n=wv,kv=25,vv=4,Sv=100;l(xm,"safeJson");l(bv,"rowToEntry");l(Tv,"shippedRowToEntry");l(Ev,"matchesTopic");l(Cv,"matchesTags");Ve={async remember(n,e){await Ye.log(n,`${Vc}${e.type}`,{content:e.content,tags:e.tags??{},source:e.source,provenance:e.provenance??"declared"})},recall(n,e={}){let t=e.limit??kv,s=Math.max(t*vv,Sv),r=L.query(n,"SELECT id, type, data, timestamp FROM events WHERE type LIKE ? ORDER BY id DESC LIMIT ?",`${Bc}%`,s),o=L.query(n,"SELECT id, name, type, shipped_at, data FROM shipped_features ORDER BY shipped_at DESC LIMIT ?",s),i=[...r.map(bv),...o.map(Tv)];if(e.types&&e.types.length>0){let a=new Set(e.types);i=i.filter(c=>a.has(c.type))}return e.tags&&(i=i.filter(a=>Cv(a,e.tags??{}))),e.topic&&(i=i.filter(a=>Ev(a,e.topic))),i.sort((a,c)=>c.rememberedAt.localeCompare(a.rememberedAt)),i.slice(0,t)},similar(n,e,t=10){let s=e.toLowerCase().split(/[^a-z0-9]+/).filter(i=>i.length>3);return s.length===0?[]:Ve.recall(n,{limit:200}).map(i=>{let a=`${i.content} ${Object.values(i.tags).join(" ")}`.toLowerCase(),c=s.reduce((u,d)=>a.includes(d)?u+1:u,0);return{entry:i,hits:c}}).filter(i=>i.hits>0).sort((i,a)=>a.hits-i.hits).slice(0,t).map(i=>i.entry)}};l(mt,"formatMemoryMd")});import Pv from"node:crypto";import Dr from"node:fs/promises";import jv from"node:os";import Dt from"node:path";async function Am(n){let e=await xv(n),t=Dt.basename(n),s=`obsidian://open?vault=${encodeURIComponent(t)}`,r=Rv();if(!r)return{bootstrapped:e,registered:!1,vaultName:t,openUrl:s,obsidianConfigFound:!1,alreadyRegistered:!1};let{registered:o,alreadyRegistered:i}=await Av(r,n);return{bootstrapped:e,registered:o,vaultName:t,openUrl:s,obsidianConfigFound:!0,alreadyRegistered:i}}function Rv(){let n=jv.homedir(),e,t=process.env.PRJCT_OBSIDIAN_CONFIG_DIR?.trim();if(t)e=t;else switch(process.platform){case"darwin":e=Dt.join(n,"Library","Application Support","obsidian");break;case"win32":e=Dt.join(process.env.APPDATA||Dt.join(n,"AppData","Roaming"),"obsidian");break;default:e=Dt.join(process.env.XDG_CONFIG_HOME||Dt.join(n,".config"),"obsidian");break}try{if(!Je("node:fs").existsSync(e))return null}catch{return null}return Dt.join(e,"obsidian.json")}async function xv(n){let e=Dt.join(n,".obsidian"),t=Dt.join(e,"app.json");try{return await Dr.stat(t),!1}catch{}return await Dr.mkdir(e,{recursive:!0}),await Dr.writeFile(t,`${JSON.stringify({},null,2)}
799
+ `,"utf-8"),!0}async function Av(n,e){let t={};try{let a=await Dr.readFile(n,"utf-8");t=JSON.parse(a)}catch{}let s=t.vaults??{},r=Dt.resolve(e);for(let a of Object.values(s))if(Dt.resolve(a.path)===r)return{registered:!1,alreadyRegistered:!0};let o=Pv.randomBytes(8).toString("hex");s[o]={path:r,ts:Date.now()};let i={...t,vaults:s};try{return await Dr.writeFile(n,JSON.stringify(i),"utf-8"),{registered:!0,alreadyRegistered:!1}}catch{return{registered:!1,alreadyRegistered:!1}}}var Im=h(()=>{"use strict";l(Am,"ensureObsidianVault");l(Rv,"resolveObsidianConfigPath");l(xv,"bootstrapObsidianDir");l(Av,"registerVaultInObsidianConfig")});function Dn(n){let e=[];for(let{name:t,re:s}of Iv)s.test(n)&&e.push(t);return e}var Iv,si=h(()=>{"use strict";Iv=[{name:"sk-\u2026 token",re:/\bsk-[A-Za-z0-9_-]{16,}/},{name:"GitHub PAT",re:/\bghp_[A-Za-z0-9]{30,}/},{name:"GitHub server PAT",re:/\bghs_[A-Za-z0-9]{30,}/},{name:"AWS access key",re:/\bAKIA[0-9A-Z]{16}\b/},{name:"Slack token",re:/\bxox[abps]-[A-Za-z0-9-]{10,}/},{name:"bearer JWT-ish",re:/\beyJ[A-Za-z0-9_-]{20,}\.[A-Za-z0-9_-]{20,}\.[A-Za-z0-9_-]{20,}\b/}];l(Dn,"scanForSecrets")});import Mt from"node:fs/promises";import Mn from"node:path";async function ni(n){await Dv(n);let e=await I.readConfig(n).catch(()=>null);return $.getWikiPath(n,e?.vaultPath)}async function Dv(n){let e=await I.readConfig(n).catch(()=>null);if(e?.vaultPath&&e.vaultPath.trim().length>0)return{moved:!1,reason:"user-override"};let t=$.getLegacyWikiPath(n);if(!await Dm(t))return{moved:!1,reason:"no-legacy"};let r=$.getWikiPath(n);if(await Dm(r))return console.error(`\u26A0 prjct: legacy wiki at ${t} was NOT migrated \u2014 ${r} already has content.
800
+ Merge manually or set \`vaultPath\` in .prjct/prjct.config.json to choose one.`),{moved:!1,reason:"conflict",from:t,to:r};await Mt.mkdir(Mn.dirname(r),{recursive:!0});let i=await Mv(t,r);return await _v(n),console.error(`\u2139 prjct: migrated Obsidian vault
801
801
  from: ${$.getDisplayPath(t)}
802
802
  to: ${$.getDisplayPath(r)}
803
- (set \`vaultPath\` in .prjct/prjct.config.json to override)`),{moved:!0,reason:"moved",from:t,to:r,filesMoved:i}}async function Dm(n){try{return(await Mt.readdir(n)).filter(s=>s!==".DS_Store"&&s!==".gitkeep").length>0}catch{return!1}}async function Dv(n,e){try{return await Mt.rename(n,e),await Kc(e)}catch(t){if(t.code!=="EXDEV")throw t;await Mm(n,e);let r=await Kc(e);return await Mt.rm(n,{recursive:!0,force:!0}),r}}async function Mm(n,e){await Mt.mkdir(e,{recursive:!0});let t=await Mt.readdir(n,{withFileTypes:!0});for(let s of t){let r=Mn.join(n,s.name),o=Mn.join(e,s.name);s.isDirectory()?await Mm(r,o):s.isFile()&&await Mt.copyFile(r,o)}}async function Kc(n){let e=0,t=await Mt.readdir(n,{withFileTypes:!0});for(let s of t){let r=Mn.join(n,s.name);s.isDirectory()?e+=await Kc(r):s.isFile()&&e++}return e}async function Mv(n){let e=Mn.join(n,".gitignore"),t="";try{t=await Mt.readFile(e,"utf-8")}catch{if(!await _v(Mn.join(n,".git")))return}if(t.includes($m))return;let s=`
804
- ${Iv}
803
+ (set \`vaultPath\` in .prjct/prjct.config.json to override)`),{moved:!0,reason:"moved",from:t,to:r,filesMoved:i}}async function Dm(n){try{return(await Mt.readdir(n)).filter(s=>s!==".DS_Store"&&s!==".gitkeep").length>0}catch{return!1}}async function Mv(n,e){try{return await Mt.rename(n,e),await Qc(e)}catch(t){if(t.code!=="EXDEV")throw t;await Mm(n,e);let r=await Qc(e);return await Mt.rm(n,{recursive:!0,force:!0}),r}}async function Mm(n,e){await Mt.mkdir(e,{recursive:!0});let t=await Mt.readdir(n,{withFileTypes:!0});for(let s of t){let r=Mn.join(n,s.name),o=Mn.join(e,s.name);s.isDirectory()?await Mm(r,o):s.isFile()&&await Mt.copyFile(r,o)}}async function Qc(n){let e=0,t=await Mt.readdir(n,{withFileTypes:!0});for(let s of t){let r=Mn.join(n,s.name);s.isDirectory()?e+=await Qc(r):s.isFile()&&e++}return e}async function _v(n){let e=Mn.join(n,".gitignore"),t="";try{t=await Mt.readFile(e,"utf-8")}catch{if(!await Nv(Mn.join(n,".git")))return}if(t.includes($m))return;let s=`
804
+ ${$v}
805
805
  ${$m}
806
806
  `,r=t.endsWith(`
807
- `)||t.length===0?t+s:`${t}${s}`;await Mt.writeFile(e,r,"utf-8")}async function _v(n){try{return await Mt.stat(n),!0}catch{return!1}}var Iv,$m,Yc=h(()=>{"use strict";de();Re();Iv="# prjct: legacy wiki \u2014 vault moved to ~/Documents/prjct/ in 2.2.0",$m=".prjct/wiki/";l(si,"resolveVaultRoot");l($v,"migrateWikiLocationIfNeeded");l(Dm,"dirHasContent");l(Dv,"moveDirectory");l(Mm,"copyRecursive");l(Kc,"countFiles");l(Mv,"ensureLegacyGitignore");l(_v,"fileExists")});var Fm={};W(Fm,{ensureCapturedReadme:()=>Zc,ingestCapturedNotes:()=>Qc});import qs from"node:fs/promises";import _n from"node:path";async function Lm(n){return _n.join(await si(n),Nv)}async function Qc(n,e={}){let t=await Lm(n),s={ingested:0,skipped:[],errors:[]},r=await Lv(t);if(r.length===0)return s;let o=_n.join(t,Nm,Uv());for(let i of r){let a=_n.basename(i);try{let c=await qs.readFile(i,"utf-8"),u=Hv(c);if(!u.ok){s.skipped.push({file:a,reason:u.error});continue}let d=Dn(u.note.content);if(d.length>0&&!e.force){s.skipped.push({file:a,reason:`secret-like content (${d.join(", ")}). Remove or re-run with --force.`});continue}await Ve.remember(n,{type:u.note.type,content:u.note.content,tags:u.note.tags}),await Fv(i,o,a),s.ingested++}catch(c){s.errors.push({file:a,error:c instanceof Error?c.message:String(c)})}}return s}async function Zc(n){let e=await Lm(n);await qs.mkdir(e,{recursive:!0});let t=_n.join(e,Om);await qs.stat(t).then(()=>!0,()=>!1)||await qs.writeFile(t,Ov,"utf-8")}async function Lv(n){let e;try{e=await qs.readdir(n)}catch{return[]}let t=[];for(let s of e)s.startsWith(".")||s!==Nm&&s!==Om&&s.toLowerCase().endsWith(".md")&&t.push(_n.join(n,s));return t}async function Fv(n,e,t){await qs.mkdir(e,{recursive:!0});let s=_n.join(e,t);await qs.rename(n,s)}function Uv(){let n=new Date,e=l(t=>String(t).padStart(2,"0"),"pad");return`${n.getUTCFullYear()}${e(n.getUTCMonth()+1)}${e(n.getUTCDate())}-${e(n.getUTCHours())}${e(n.getUTCMinutes())}${e(n.getUTCSeconds())}`}function Hv(n){let e=n.match(/^---\s*\r?\n([\s\S]*?)\r?\n---\s*\r?\n?([\s\S]*)$/);if(!e)return{ok:!1,error:"no frontmatter (expected leading `---` block)"};let[,t,s]=e,{type:r,tags:o,error:i}=Wv(t);if(i)return{ok:!1,error:i};if(!r)return{ok:!1,error:"missing `type` in frontmatter"};if(!/^[a-z][a-z0-9-]*$/.test(r))return{ok:!1,error:`invalid type '${r}'. Lowercase letters + dashes only. Base types: ${$n.join(", ")}`};let a=s.trim();return a?{ok:!0,note:{type:r,tags:o,content:a}}:{ok:!1,error:"body is empty"}}function Wv(n){let e=n.split(/\r?\n/),t,s={},r=!1;for(let o of e){if(o.trim()==="")continue;if(r&&/^\s+/.test(o)){let u=o.trim(),d=u.indexOf(":");if(d>0){let m=u.slice(0,d).trim(),p=_m(u.slice(d+1).trim());m&&(s[m]=p)}continue}r=!1;let i=o.indexOf(":");if(i<=0)continue;let a=o.slice(0,i).trim(),c=_m(o.slice(i+1).trim());if(a==="type")t=c.toLowerCase();else if(a==="tags")if(c)for(let u of c.split(",")){let d=u.trim(),m=d.indexOf("="),p=d.indexOf(":"),g=m>0?m:p;g<=0||(s[d.slice(0,g).trim()]=d.slice(g+1).trim())}else r=!0}return{type:t,tags:s}}function _m(n){return n.startsWith('"')&&n.endsWith('"')||n.startsWith("'")&&n.endsWith("'")?n.slice(1,-1):n}var Nv,Nm,Om,Ov,ni=h(()=>{"use strict";os();ti();Yc();Nv="captured",Nm="_ingested",Om="README.md";l(Lm,"resolveCapturedRoot");l(Qc,"ingestCapturedNotes");l(Zc,"ensureCapturedReadme");Ov=`# Captured notes (Obsidian dropzone)
807
+ `)||t.length===0?t+s:`${t}${s}`;await Mt.writeFile(e,r,"utf-8")}async function Nv(n){try{return await Mt.stat(n),!0}catch{return!1}}var $v,$m,Zc=h(()=>{"use strict";de();Re();$v="# prjct: legacy wiki \u2014 vault moved to ~/Documents/prjct/ in 2.2.0",$m=".prjct/wiki/";l(ni,"resolveVaultRoot");l(Dv,"migrateWikiLocationIfNeeded");l(Dm,"dirHasContent");l(Mv,"moveDirectory");l(Mm,"copyRecursive");l(Qc,"countFiles");l(_v,"ensureLegacyGitignore");l(Nv,"fileExists")});var Fm={};W(Fm,{ensureCapturedReadme:()=>tl,ingestCapturedNotes:()=>el});import qs from"node:fs/promises";import _n from"node:path";async function Lm(n){return _n.join(await ni(n),Ov)}async function el(n,e={}){let t=await Lm(n),s={ingested:0,skipped:[],errors:[]},r=await Fv(t);if(r.length===0)return s;let o=_n.join(t,Nm,Hv());for(let i of r){let a=_n.basename(i);try{let c=await qs.readFile(i,"utf-8"),u=Wv(c);if(!u.ok){s.skipped.push({file:a,reason:u.error});continue}let d=Dn(u.note.content);if(d.length>0&&!e.force){s.skipped.push({file:a,reason:`secret-like content (${d.join(", ")}). Remove or re-run with --force.`});continue}await Ve.remember(n,{type:u.note.type,content:u.note.content,tags:u.note.tags}),await Uv(i,o,a),s.ingested++}catch(c){s.errors.push({file:a,error:c instanceof Error?c.message:String(c)})}}return s}async function tl(n){let e=await Lm(n);await qs.mkdir(e,{recursive:!0});let t=_n.join(e,Om);await qs.stat(t).then(()=>!0,()=>!1)||await qs.writeFile(t,Lv,"utf-8")}async function Fv(n){let e;try{e=await qs.readdir(n)}catch{return[]}let t=[];for(let s of e)s.startsWith(".")||s!==Nm&&s!==Om&&s.toLowerCase().endsWith(".md")&&t.push(_n.join(n,s));return t}async function Uv(n,e,t){await qs.mkdir(e,{recursive:!0});let s=_n.join(e,t);await qs.rename(n,s)}function Hv(){let n=new Date,e=l(t=>String(t).padStart(2,"0"),"pad");return`${n.getUTCFullYear()}${e(n.getUTCMonth()+1)}${e(n.getUTCDate())}-${e(n.getUTCHours())}${e(n.getUTCMinutes())}${e(n.getUTCSeconds())}`}function Wv(n){let e=n.match(/^---\s*\r?\n([\s\S]*?)\r?\n---\s*\r?\n?([\s\S]*)$/);if(!e)return{ok:!1,error:"no frontmatter (expected leading `---` block)"};let[,t,s]=e,{type:r,tags:o,error:i}=Gv(t);if(i)return{ok:!1,error:i};if(!r)return{ok:!1,error:"missing `type` in frontmatter"};if(!/^[a-z][a-z0-9-]*$/.test(r))return{ok:!1,error:`invalid type '${r}'. Lowercase letters + dashes only. Base types: ${$n.join(", ")}`};let a=s.trim();return a?{ok:!0,note:{type:r,tags:o,content:a}}:{ok:!1,error:"body is empty"}}function Gv(n){let e=n.split(/\r?\n/),t,s={},r=!1;for(let o of e){if(o.trim()==="")continue;if(r&&/^\s+/.test(o)){let u=o.trim(),d=u.indexOf(":");if(d>0){let m=u.slice(0,d).trim(),p=_m(u.slice(d+1).trim());m&&(s[m]=p)}continue}r=!1;let i=o.indexOf(":");if(i<=0)continue;let a=o.slice(0,i).trim(),c=_m(o.slice(i+1).trim());if(a==="type")t=c.toLowerCase();else if(a==="tags")if(c)for(let u of c.split(",")){let d=u.trim(),m=d.indexOf("="),p=d.indexOf(":"),g=m>0?m:p;g<=0||(s[d.slice(0,g).trim()]=d.slice(g+1).trim())}else r=!0}return{type:t,tags:s}}function _m(n){return n.startsWith('"')&&n.endsWith('"')||n.startsWith("'")&&n.endsWith("'")?n.slice(1,-1):n}var Ov,Nm,Om,Lv,ri=h(()=>{"use strict";is();si();Zc();Ov="captured",Nm="_ingested",Om="README.md";l(Lm,"resolveCapturedRoot");l(el,"ingestCapturedNotes");l(tl,"ensureCapturedReadme");Lv=`# Captured notes (Obsidian dropzone)
808
808
 
809
809
  Drop a markdown note here, run \`prjct context wiki sync\`, and each note
810
810
  becomes a project-memory entry. Processed notes move to \`_ingested/\` so
@@ -836,55 +836,55 @@ ${$n.map(n=>`- \`${n}\``).join(`
836
836
  - Secret-like content (API keys, JWTs) is refused unless you pass
837
837
  \`--force\` to \`prjct context wiki sync\`.
838
838
  - Files already in \`_ingested/\` are ignored.
839
- `;l(Lv,"listNoteFiles");l(Fv,"moveToArchive");l(Uv,"timestampSlug");l(Hv,"parseNote");l(Wv,"parseFrontmatter");l(_m,"stripQuotes")});var Vs={};W(Vs,{generateWiki:()=>tl,regenerateWikiDeferred:()=>Mr});import Gv from"node:crypto";import gt from"node:fs/promises";import _t from"node:path";function Nn(n){return n.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-|-$/g,"").slice(0,60)||"unnamed"}function Bv(n){return Gv.createHash("sha256").update(n).digest("hex").slice(0,16)}function Jv(n){let e=[];return e.push(`# ${n.name}`),e.push(""),e.push(`- Shipped: ${n.shippedAt}`),e.push(`- Version: ${n.version}`),n.type&&e.push(`- Type: ${n.type}`),n.duration&&e.push(`- Duration: ${n.duration}`),e.push(""),n.description&&(e.push("## Description"),e.push(""),e.push(n.description)),`${e.join(`
839
+ `;l(Fv,"listNoteFiles");l(Uv,"moveToArchive");l(Hv,"timestampSlug");l(Wv,"parseNote");l(Gv,"parseFrontmatter");l(_m,"stripQuotes")});var Vs={};W(Vs,{generateWiki:()=>nl,regenerateWikiDeferred:()=>Mr});import qv from"node:crypto";import gt from"node:fs/promises";import _t from"node:path";function Nn(n){return n.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-|-$/g,"").slice(0,60)||"unnamed"}function Jv(n){return qv.createHash("sha256").update(n).digest("hex").slice(0,16)}function zv(n){let e=[];return e.push(`# ${n.name}`),e.push(""),e.push(`- Shipped: ${n.shippedAt}`),e.push(`- Version: ${n.version}`),n.type&&e.push(`- Type: ${n.type}`),n.duration&&e.push(`- Duration: ${n.duration}`),e.push(""),n.description&&(e.push("## Description"),e.push(""),e.push(n.description)),`${e.join(`
840
840
  `)}
841
- `}function zv(n){let e=new Map;for(let t of n)for(let[s,r]of Object.entries(t.tags)){let o=e.get(s);o||(o=new Map,e.set(s,o));let i=o.get(r)??[];i.push(t),o.set(r,i)}return e}function Gm(n,e=Vv){if(n.length<=e)return[n];let t=[];for(let s=0;s<n.length;s+=e)t.push(n.slice(s,s+e));return t}function Xv(n){let e=new Map,t=new Map;for(let s of n){let r=t.get(s.type)??[];r.push(s),t.set(s.type,r)}for(let[s,r]of t){let o=Gm(r);if(o.length===1){let a=[`# ${s.toUpperCase()}`,"",mt(r),""].join(`
841
+ `}function Xv(n){let e=new Map;for(let t of n)for(let[s,r]of Object.entries(t.tags)){let o=e.get(s);o||(o=new Map,e.set(s,o));let i=o.get(r)??[];i.push(t),o.set(r,i)}return e}function Gm(n,e=Bv){if(n.length<=e)return[n];let t=[];for(let s=0;s<n.length;s+=e)t.push(n.slice(s,s+e));return t}function Kv(n){let e=new Map,t=new Map;for(let s of n){let r=t.get(s.type)??[];r.push(s),t.set(s.type,r)}for(let[s,r]of t){let o=Gm(r);if(o.length===1){let a=[`# ${s.toUpperCase()}`,"",mt(r),""].join(`
842
842
  `);e.set(`memory/${s}.md`,a);continue}let i=[`# ${s.toUpperCase()}`,"",`_${r.length} entries across ${o.length} chunks._`,""];for(let a=0;a<o.length;a++){let c=`${s}/chunk-${a+1}.md`,u=[`# ${s.toUpperCase()} \u2014 chunk ${a+1}/${o.length}`,"",mt(o[a]),""].join(`
843
843
  `);e.set(`memory/${c}`,u),i.push(`- [chunk ${a+1}](${c}) \u2014 ${o[a].length} entries`)}e.set(`memory/${s}.md`,`${i.join(`
844
844
  `)}
845
- `)}return e}function Kv(n){let e=new Map,t=zv(n);for(let[s,r]of t){let o=Nn(s),i=[`# Tag: ${s}`,""],a=[...r.entries()].sort((c,u)=>c[0].localeCompare(u[0]));for(let[c,u]of a){let d=Nn(c),m=Gm(u);if(m.length===1){let p=[`# ${s}: ${c}`,"",mt(u),""].join(`
845
+ `)}return e}function Yv(n){let e=new Map,t=Xv(n);for(let[s,r]of t){let o=Nn(s),i=[`# Tag: ${s}`,""],a=[...r.entries()].sort((c,u)=>c[0].localeCompare(u[0]));for(let[c,u]of a){let d=Nn(c),m=Gm(u);if(m.length===1){let p=[`# ${s}: ${c}`,"",mt(u),""].join(`
846
846
  `);e.set(`tags/${o}/${d}.md`,p),i.push(`- [${c}](${o}/${d}.md) \u2014 ${u.length} entries`)}else{for(let p=0;p<m.length;p++){let g=[`# ${s}: ${c} \u2014 chunk ${p+1}/${m.length}`,"",mt(m[p]),""].join(`
847
847
  `);e.set(`tags/${o}/${d}-${p+1}.md`,g)}i.push(`- **${c}** \u2014 ${u.length} entries across ${m.length} chunks`);for(let p=0;p<m.length;p++)i.push(` - [chunk ${p+1}](${o}/${d}-${p+1}.md)`)}}i.push(""),e.set(`tags/${o}.md`,`${i.join(`
848
848
  `)}
849
- `)}return e}function Yv(n,e){if(n.length===0&&e.length===0)return null;let t=["# Patterns (inferred)",""];if(n.length>0){t.push("## Patterns");for(let s of n){let r=s.locations&&s.locations.length>0?` \u2014 ${s.locations.slice(0,3).join(", ")}`:"",o=s.category?` _[${s.category}]_`:"";t.push(`- **${s.name}**${o}: ${s.description}${r}`)}t.push("")}if(e.length>0){t.push("## Anti-patterns");for(let s of e){let r=s.files&&s.files.length>0?` (${s.files[0]})`:"",o=s.severity?` _[${s.severity}]_`:"";t.push(`- **${s.issue}**${o}${r} \u2014 ${s.suggestion}`),s.reasoning&&t.push(` - Why: ${s.reasoning}`)}t.push("")}return t.push("> Source: `prjct sync` analysis. Provenance: INFR."),`${t.join(`
849
+ `)}return e}function Qv(n,e){if(n.length===0&&e.length===0)return null;let t=["# Patterns (inferred)",""];if(n.length>0){t.push("## Patterns");for(let s of n){let r=s.locations&&s.locations.length>0?` \u2014 ${s.locations.slice(0,3).join(", ")}`:"",o=s.category?` _[${s.category}]_`:"";t.push(`- **${s.name}**${o}: ${s.description}${r}`)}t.push("")}if(e.length>0){t.push("## Anti-patterns");for(let s of e){let r=s.files&&s.files.length>0?` (${s.files[0]})`:"",o=s.severity?` _[${s.severity}]_`:"";t.push(`- **${s.issue}**${o}${r} \u2014 ${s.suggestion}`),s.reasoning&&t.push(` - Why: ${s.reasoning}`)}t.push("")}return t.push("> Source: `prjct sync` analysis. Provenance: INFR."),`${t.join(`
850
850
  `)}
851
- `}function Qv(n){let{architecture:e,conventions:t}=n;if(!(e&&(e.style||e.insights?.length||e.domains?.length))&&(!t||t.length===0))return null;let r=["# Architecture",""];if(e?.style&&r.push(`**Style**: ${e.style}`,""),e?.domains&&e.domains.length>0){r.push("## Domains");for(let o of e.domains)r.push(`- ${o}`);r.push("")}if(e?.insights&&e.insights.length>0){r.push("## Insights");for(let o of e.insights)r.push(`- ${o}`);r.push("")}if(t&&t.length>0){r.push("## Conventions");for(let o of t){let i=o.example?` \u2014 \`${o.example}\``:"";r.push(`- **${o.category}**: ${o.rule}${i}`)}r.push("")}return r.push("> Source: `prjct sync` LLM analysis."),`${r.join(`
851
+ `}function Zv(n){let{architecture:e,conventions:t}=n;if(!(e&&(e.style||e.insights?.length||e.domains?.length))&&(!t||t.length===0))return null;let r=["# Architecture",""];if(e?.style&&r.push(`**Style**: ${e.style}`,""),e?.domains&&e.domains.length>0){r.push("## Domains");for(let o of e.domains)r.push(`- ${o}`);r.push("")}if(e?.insights&&e.insights.length>0){r.push("## Insights");for(let o of e.insights)r.push(`- ${o}`);r.push("")}if(t&&t.length>0){r.push("## Conventions");for(let o of t){let i=o.example?` \u2014 \`${o.example}\``:"";r.push(`- **${o.category}**: ${o.rule}${i}`)}r.push("")}return r.push("> Source: `prjct sync` LLM analysis."),`${r.join(`
852
852
  `)}
853
- `}function Zv(n){let{techDebt:e,riskAreas:t,refactorSuggestions:s}=n;if((e?.length??0)+(t?.length??0)+(s?.length??0)===0)return null;let o=["# Tech debt, risks & refactors",""];if(e&&e.length>0){o.push("## Tech debt");for(let i of e)o.push(`- **${i.description}** _[${i.priority}, ${i.effort}]_ \u2014 ${i.area}. Impact: ${i.impact}`);o.push("")}if(t&&t.length>0){o.push("## Risk areas");for(let i of t)o.push(`- **${i.path}** _[${i.severity}]_ \u2014 ${i.reason}. Risk: ${i.risk}`);o.push("")}if(s&&s.length>0){o.push("## Refactor suggestions");for(let i of s){let a=i.files&&i.files.length>0?` (${i.files.slice(0,3).join(", ")})`:"";o.push(`- **${i.description}** _[${i.effort}]_${a} \u2014 ${i.benefit}`)}o.push("")}return o.push("> Source: `prjct sync` LLM analysis."),`${o.join(`
853
+ `}function eS(n){let{techDebt:e,riskAreas:t,refactorSuggestions:s}=n;if((e?.length??0)+(t?.length??0)+(s?.length??0)===0)return null;let o=["# Tech debt, risks & refactors",""];if(e&&e.length>0){o.push("## Tech debt");for(let i of e)o.push(`- **${i.description}** _[${i.priority}, ${i.effort}]_ \u2014 ${i.area}. Impact: ${i.impact}`);o.push("")}if(t&&t.length>0){o.push("## Risk areas");for(let i of t)o.push(`- **${i.path}** _[${i.severity}]_ \u2014 ${i.reason}. Risk: ${i.risk}`);o.push("")}if(s&&s.length>0){o.push("## Refactor suggestions");for(let i of s){let a=i.files&&i.files.length>0?` (${i.files.slice(0,3).join(", ")})`:"";o.push(`- **${i.description}** _[${i.effort}]_${a} \u2014 ${i.benefit}`)}o.push("")}return o.push("> Source: `prjct sync` LLM analysis."),`${o.join(`
854
854
  `)}
855
- `}function eS(n){if(!n.projectInsights||n.projectInsights.length===0)return null;let e=["# Project insights",""];for(let t of n.projectInsights)e.push(`- ${t}`);return e.push("","> Source: `prjct sync` LLM analysis."),`${e.join(`
855
+ `}function tS(n){if(!n.projectInsights||n.projectInsights.length===0)return null;let e=["# Project insights",""];for(let t of n.projectInsights)e.push(`- ${t}`);return e.push("","> Source: `prjct sync` LLM analysis."),`${e.join(`
856
856
  `)}
857
- `}function tS(n){let e=[],t=/^## \[([^\]]+)\]\s*-\s*(\d{4}-\d{2}-\d{2})\s*$/,s=n.split(`
857
+ `}function sS(n){let e=[],t=/^## \[([^\]]+)\]\s*-\s*(\d{4}-\d{2}-\d{2})\s*$/,s=n.split(`
858
858
  `),r=null,o=[],i=l(()=>{r&&(e.push({version:r.version,date:r.date,body:o.join(`
859
- `).trim()}),o=[])},"flush");for(let a of s){let c=a.match(t);if(c){i(),r={version:c[1],date:c[2]};continue}r&&o.push(a)}return i(),e}function sS(n){return`v${n.replace(/[^a-zA-Z0-9._-]+/g,"-")}`}function nS(n,e,t){let s=[];s.push("---"),s.push("type: release"),s.push(`version: ${n.version}`),s.push(`date: ${n.date}`),s.push("tags: [release]"),s.push("---"),s.push(""),s.push(`# v${n.version} \u2014 ${n.date}`),s.push("");let r=[];return e&&r.push(`\u2190 [v${e.entry.version}](${e.slug}.md)`),r.push("[releases index](index.md)"),t&&r.push(`[v${t.entry.version}](${t.slug}.md) \u2192`),s.push(r.join(" \xB7 ")),s.push(""),n.body?(s.push(n.body),s.push("")):(s.push("_No changelog body._"),s.push("")),s.push("---"),s.push(""),s.push("[project wiki](../index.md) \xB7 [releases index](index.md)"),s.push(""),`${s.join(`
859
+ `).trim()}),o=[])},"flush");for(let a of s){let c=a.match(t);if(c){i(),r={version:c[1],date:c[2]};continue}r&&o.push(a)}return i(),e}function nS(n){return`v${n.replace(/[^a-zA-Z0-9._-]+/g,"-")}`}function rS(n,e,t){let s=[];s.push("---"),s.push("type: release"),s.push(`version: ${n.version}`),s.push(`date: ${n.date}`),s.push("tags: [release]"),s.push("---"),s.push(""),s.push(`# v${n.version} \u2014 ${n.date}`),s.push("");let r=[];return e&&r.push(`\u2190 [v${e.entry.version}](${e.slug}.md)`),r.push("[releases index](index.md)"),t&&r.push(`[v${t.entry.version}](${t.slug}.md) \u2192`),s.push(r.join(" \xB7 ")),s.push(""),n.body?(s.push(n.body),s.push("")):(s.push("_No changelog body._"),s.push("")),s.push("---"),s.push(""),s.push("[project wiki](../index.md) \xB7 [releases index](index.md)"),s.push(""),`${s.join(`
860
860
  `)}
861
- `}function rS(n){let e=["# Releases",""];e.push(`${n.length} version entr${n.length===1?"y":"ies"} parsed from \`CHANGELOG.md\`. Newest first.`),e.push(""),e.push("See also: [project wiki](../index.md)"),e.push(""),e.push("| Date | Version | Link |"),e.push("|---|---|---|");for(let{entry:t,slug:s}of n)e.push(`| ${t.date} | ${t.version} | [v${t.version}](${s}.md) |`);return e.push(""),`${e.join(`
861
+ `}function oS(n){let e=["# Releases",""];e.push(`${n.length} version entr${n.length===1?"y":"ies"} parsed from \`CHANGELOG.md\`. Newest first.`),e.push(""),e.push("See also: [project wiki](../index.md)"),e.push(""),e.push("| Date | Version | Link |"),e.push("|---|---|---|");for(let{entry:t,slug:s}of n)e.push(`| ${t.date} | ${t.version} | [v${t.version}](${s}.md) |`);return e.push(""),`${e.join(`
862
862
  `)}
863
- `}async function oS(n){let e=new Map,t=_t.join(n,"CHANGELOG.md"),s;try{s=await gt.readFile(t,"utf-8")}catch{return e}let r=tS(s);if(r.length===0)return e;let o=new Map,i=[];for(let a of r){let c=sS(a.version),u=o.get(c)??0;o.set(c,u+1);let d=u===0?c:`${c}-${u+1}b`;i.push({entry:a,slug:d})}for(let a=0;a<i.length;a++){let c=i[a],u=a>0?i[a-1]:null,d=a+1<i.length?i[a+1]:null;e.set(`releases/${c.slug}.md`,nS(c.entry,d,u))}return e.set("releases/index.md",rS(i)),e}function el(n){let e=(n.analyzedAt||"").match(/^(\d{4}-\d{2}-\d{2})/);return e?e[1]:"undated"}function qm(n,e){return`${n}::${e.trim().toLowerCase()}`}function Vm(n){let e=new Map,t=[...n].reverse(),s=l((o,i,a,c)=>{if(!i||!i.trim())return;let u=qm(o,i),d=el(c),m=e.get(u);if(m){m.lastSeen=d,m.latestBody=a,m.seenIn.push({analysisId:c.id,date:d,commit:c.commitHash}),c.status==="active"&&(m.stillActive=!0);return}e.set(u,{kind:o,name:i.trim(),slug:Nn(i).slice(0,60)||"unnamed",latestBody:a,firstSeen:d,lastSeen:d,seenIn:[{analysisId:c.id,date:d,commit:c.commitHash}],stillActive:c.status==="active"})},"touch");for(let o of t){let i=o.analysis;for(let a of i.patterns??[])s("pattern",a.name,a,o);for(let a of i.antiPatterns??[])s("anti-pattern",a.issue,a,o);for(let a of i.techDebt??[])s("tech-debt",a.description,a,o);for(let a of i.riskAreas??[])s("risk-area",a.path,a,o);for(let a of i.refactorSuggestions??[])s("refactor",a.description,a,o);for(let a of i.projectInsights??[])s("insight",a,{description:a},o)}let r=new Map;for(let o of e.values()){let i=ii[o.kind],a=r.get(i);a||(a=new Set,r.set(i,a));let c=o.slug,u=2;for(;a.has(c);)c=`${o.slug}-${u}`,u+=1;o.slug=c,a.add(c)}return e}function iS(n){let e=[],t=n.latestBody,s=[...new Set(n.seenIn.map(u=>u.date))];e.push("---"),e.push(`type: ${n.kind}`),e.push(`name: ${JSON.stringify(n.name)}`),e.push(`firstSeen: ${n.firstSeen}`),e.push(`lastSeen: ${n.lastSeen}`),e.push(`seenIn: ${n.seenIn.length}`),e.push(`stillActive: ${n.stillActive}`),e.push(`tags: [${n.kind}]`),e.push("---"),e.push(""),e.push(`# ${n.name}`),e.push("");let r=t.description||t.reason||t.issue;r&&r!==n.name&&(e.push(r),e.push(""));let o=[];t.severity&&o.push(`**Severity**: ${t.severity}`),t.priority&&o.push(`**Priority**: ${t.priority}`),t.effort&&o.push(`**Effort**: ${t.effort}`),t.impact&&o.push(`**Impact**: ${t.impact}`),t.benefit&&o.push(`**Benefit**: ${t.benefit}`),t.confidence!==void 0&&o.push(`**Confidence**: ${t.confidence}`),t.category&&o.push(`**Category**: ${t.category}`),t.area&&o.push(`**Area**: ${t.area}`),t.risk&&o.push(`**Risk**: ${t.risk}`),t.suggestion&&o.push(`**Suggestion**: ${t.suggestion}`),t.reasoning&&t.reasoning!==r&&o.push(`**Reasoning**: ${t.reasoning}`),o.length>0&&(e.push(...o.map(u=>`- ${u}`)),e.push(""));let i=t.files||[],a=t.locations||[],c=[...new Set([...i,...a])];if(c.length>0){e.push("## Where");for(let u of c)e.push(`- \`${u}\``);e.push("")}return e.push("## Seen in"),e.push(`First: ${n.firstSeen} \xB7 Last: ${n.lastSeen} \xB7 ${n.seenIn.length} analysis run${n.seenIn.length===1?"":"s"} (${s.length} distinct date${s.length===1?"":"s"})`),e.push(""),e.push("---"),e.push(""),e.push("See also: [analysis index](../index.md) \xB7 [change log](../history.md)"),e.push(""),`${e.join(`
863
+ `}async function iS(n){let e=new Map,t=_t.join(n,"CHANGELOG.md"),s;try{s=await gt.readFile(t,"utf-8")}catch{return e}let r=sS(s);if(r.length===0)return e;let o=new Map,i=[];for(let a of r){let c=nS(a.version),u=o.get(c)??0;o.set(c,u+1);let d=u===0?c:`${c}-${u+1}b`;i.push({entry:a,slug:d})}for(let a=0;a<i.length;a++){let c=i[a],u=a>0?i[a-1]:null,d=a+1<i.length?i[a+1]:null;e.set(`releases/${c.slug}.md`,rS(c.entry,d,u))}return e.set("releases/index.md",oS(i)),e}function sl(n){let e=(n.analyzedAt||"").match(/^(\d{4}-\d{2}-\d{2})/);return e?e[1]:"undated"}function qm(n,e){return`${n}::${e.trim().toLowerCase()}`}function Vm(n){let e=new Map,t=[...n].reverse(),s=l((o,i,a,c)=>{if(!i||!i.trim())return;let u=qm(o,i),d=sl(c),m=e.get(u);if(m){m.lastSeen=d,m.latestBody=a,m.seenIn.push({analysisId:c.id,date:d,commit:c.commitHash}),c.status==="active"&&(m.stillActive=!0);return}e.set(u,{kind:o,name:i.trim(),slug:Nn(i).slice(0,60)||"unnamed",latestBody:a,firstSeen:d,lastSeen:d,seenIn:[{analysisId:c.id,date:d,commit:c.commitHash}],stillActive:c.status==="active"})},"touch");for(let o of t){let i=o.analysis;for(let a of i.patterns??[])s("pattern",a.name,a,o);for(let a of i.antiPatterns??[])s("anti-pattern",a.issue,a,o);for(let a of i.techDebt??[])s("tech-debt",a.description,a,o);for(let a of i.riskAreas??[])s("risk-area",a.path,a,o);for(let a of i.refactorSuggestions??[])s("refactor",a.description,a,o);for(let a of i.projectInsights??[])s("insight",a,{description:a},o)}let r=new Map;for(let o of e.values()){let i=ai[o.kind],a=r.get(i);a||(a=new Set,r.set(i,a));let c=o.slug,u=2;for(;a.has(c);)c=`${o.slug}-${u}`,u+=1;o.slug=c,a.add(c)}return e}function aS(n){let e=[],t=n.latestBody,s=[...new Set(n.seenIn.map(u=>u.date))];e.push("---"),e.push(`type: ${n.kind}`),e.push(`name: ${JSON.stringify(n.name)}`),e.push(`firstSeen: ${n.firstSeen}`),e.push(`lastSeen: ${n.lastSeen}`),e.push(`seenIn: ${n.seenIn.length}`),e.push(`stillActive: ${n.stillActive}`),e.push(`tags: [${n.kind}]`),e.push("---"),e.push(""),e.push(`# ${n.name}`),e.push("");let r=t.description||t.reason||t.issue;r&&r!==n.name&&(e.push(r),e.push(""));let o=[];t.severity&&o.push(`**Severity**: ${t.severity}`),t.priority&&o.push(`**Priority**: ${t.priority}`),t.effort&&o.push(`**Effort**: ${t.effort}`),t.impact&&o.push(`**Impact**: ${t.impact}`),t.benefit&&o.push(`**Benefit**: ${t.benefit}`),t.confidence!==void 0&&o.push(`**Confidence**: ${t.confidence}`),t.category&&o.push(`**Category**: ${t.category}`),t.area&&o.push(`**Area**: ${t.area}`),t.risk&&o.push(`**Risk**: ${t.risk}`),t.suggestion&&o.push(`**Suggestion**: ${t.suggestion}`),t.reasoning&&t.reasoning!==r&&o.push(`**Reasoning**: ${t.reasoning}`),o.length>0&&(e.push(...o.map(u=>`- ${u}`)),e.push(""));let i=t.files||[],a=t.locations||[],c=[...new Set([...i,...a])];if(c.length>0){e.push("## Where");for(let u of c)e.push(`- \`${u}\``);e.push("")}return e.push("## Seen in"),e.push(`First: ${n.firstSeen} \xB7 Last: ${n.lastSeen} \xB7 ${n.seenIn.length} analysis run${n.seenIn.length===1?"":"s"} (${s.length} distinct date${s.length===1?"":"s"})`),e.push(""),e.push("---"),e.push(""),e.push("See also: [analysis index](../index.md) \xB7 [change log](../history.md)"),e.push(""),`${e.join(`
864
864
  `)}
865
- `}function aS(n,e){let t=["# Analysis evolution",""];if(t.push("One entry per analysis save where *something changed* (architecture, patterns, anti-patterns, tech debt, risks, refactors, or insights). Repeated saves with identical contents are collapsed."),t.push(""),t.push("See also: [analysis index](index.md) \xB7 [project wiki](../index.md)"),t.push(""),n.length===0)return t.push("> No analyses saved yet. Run `prjct sync` to generate one."),`${t.join(`
865
+ `}function cS(n,e){let t=["# Analysis evolution",""];if(t.push("One entry per analysis save where *something changed* (architecture, patterns, anti-patterns, tech debt, risks, refactors, or insights). Repeated saves with identical contents are collapsed."),t.push(""),t.push("See also: [analysis index](index.md) \xB7 [project wiki](../index.md)"),t.push(""),n.length===0)return t.push("> No analyses saved yet. Run `prjct sync` to generate one."),`${t.join(`
866
866
  `)}
867
- `;let s=l((u,d)=>{let m=e.get(qm(u,d)),p=d.length>80?`${d.slice(0,77)}\u2026`:d;if(!m)return`"${p}"`;let g=ii[m.kind];return`[${p}](${g}/${m.slug}.md)`},"linkFor"),r=l(u=>{let d=u.analysis;return{arch:d.architecture?.style??"\u2014",patterns:new Set((d.patterns??[]).map(m=>m.name)),anti:new Set((d.antiPatterns??[]).map(m=>m.issue)),debt:new Set((d.techDebt??[]).map(m=>m.description)),risks:new Set((d.riskAreas??[]).map(m=>m.path)),refactors:new Set((d.refactorSuggestions??[]).map(m=>m.description)),insights:new Set(d.projectInsights??[])}},"rowFor"),o=l((u,d)=>{let m=[],p=[];for(let g of d)u.has(g)||m.push(g);for(let g of u)d.has(g)||p.push(g);return{added:m,removed:p}},"diffNames"),i=[...n].reverse(),a=null,c=[];for(let u of i){let d=r(u);if(a===null){c.push(`- **${el(u)}** \u2014 baseline captured (arch: ${d.arch}, ${d.patterns.size} patterns, ${d.anti.size} anti, ${d.debt.size} debt, ${d.risks.size} risks, ${d.refactors.size} refactors, ${d.insights.size} insights).`),a=d;continue}let m=[];a.arch!==d.arch&&m.push(`arch ${a.arch} \u2192 ${d.arch}`);let p=[["pattern","patterns","pattern"],["anti-pattern","anti","anti-pattern"],["tech-debt","debt","tech-debt"],["risk","risks","risk-area"],["refactor","refactors","refactor"],["insight","insights","insight"]];for(let[g,y,j]of p){let T=o(a[y],d[y]);for(let x of T.added)m.push(`+${g} ${s(j,x)}`);for(let x of T.removed)m.push(`\u2212${g} ${s(j,x)}`)}m.length!==0&&(c.push(`- **${el(u)}** \u2014 ${m.join("; ")}.`),a=d)}return c.length===0?t.push("> No changes recorded yet."):t.push(...c.reverse()),t.push(""),`${t.join(`
867
+ `;let s=l((u,d)=>{let m=e.get(qm(u,d)),p=d.length>80?`${d.slice(0,77)}\u2026`:d;if(!m)return`"${p}"`;let g=ai[m.kind];return`[${p}](${g}/${m.slug}.md)`},"linkFor"),r=l(u=>{let d=u.analysis;return{arch:d.architecture?.style??"\u2014",patterns:new Set((d.patterns??[]).map(m=>m.name)),anti:new Set((d.antiPatterns??[]).map(m=>m.issue)),debt:new Set((d.techDebt??[]).map(m=>m.description)),risks:new Set((d.riskAreas??[]).map(m=>m.path)),refactors:new Set((d.refactorSuggestions??[]).map(m=>m.description)),insights:new Set(d.projectInsights??[])}},"rowFor"),o=l((u,d)=>{let m=[],p=[];for(let g of d)u.has(g)||m.push(g);for(let g of u)d.has(g)||p.push(g);return{added:m,removed:p}},"diffNames"),i=[...n].reverse(),a=null,c=[];for(let u of i){let d=r(u);if(a===null){c.push(`- **${sl(u)}** \u2014 baseline captured (arch: ${d.arch}, ${d.patterns.size} patterns, ${d.anti.size} anti, ${d.debt.size} debt, ${d.risks.size} risks, ${d.refactors.size} refactors, ${d.insights.size} insights).`),a=d;continue}let m=[];a.arch!==d.arch&&m.push(`arch ${a.arch} \u2192 ${d.arch}`);let p=[["pattern","patterns","pattern"],["anti-pattern","anti","anti-pattern"],["tech-debt","debt","tech-debt"],["risk","risks","risk-area"],["refactor","refactors","refactor"],["insight","insights","insight"]];for(let[g,y,j]of p){let T=o(a[y],d[y]);for(let x of T.added)m.push(`+${g} ${s(j,x)}`);for(let x of T.removed)m.push(`\u2212${g} ${s(j,x)}`)}m.length!==0&&(c.push(`- **${sl(u)}** \u2014 ${m.join("; ")}.`),a=d)}return c.length===0?t.push("> No changes recorded yet."):t.push(...c.reverse()),t.push(""),`${t.join(`
868
868
  `)}
869
- `}function cS(n){let e=new Map;for(let r of n.values()){let o=e.get(r.kind)??[];o.push(r),e.set(r.kind,o)}let t=["# Analysis",""];t.push("One file per concept from `prjct sync`. Files are deduped across history \u2014 the same pattern or risk always lands at the same path, updated with first/last-seen dates."),t.push(""),t.push("See also: [change log](history.md) \xB7 [project wiki](../index.md)"),t.push("");let s=["pattern","anti-pattern","tech-debt","risk-area","refactor","insight"];for(let r of s){let o=e.get(r);if(!o||o.length===0)continue;let i=ii[r],a=o.filter(u=>u.stillActive).length;t.push(`## ${i} (${a} active / ${o.length} total)`),t.push("");let c=[...o].sort((u,d)=>u.stillActive!==d.stillActive?u.stillActive?-1:1:u.lastSeen>d.lastSeen?-1:1);for(let u of c){let d=u.stillActive?"":" _(historical)_";t.push(`- [${u.name}](${i}/${u.slug}.md)${d}`)}t.push("")}return`${t.join(`
869
+ `}function lS(n){let e=new Map;for(let r of n.values()){let o=e.get(r.kind)??[];o.push(r),e.set(r.kind,o)}let t=["# Analysis",""];t.push("One file per concept from `prjct sync`. Files are deduped across history \u2014 the same pattern or risk always lands at the same path, updated with first/last-seen dates."),t.push(""),t.push("See also: [change log](history.md) \xB7 [project wiki](../index.md)"),t.push("");let s=["pattern","anti-pattern","tech-debt","risk-area","refactor","insight"];for(let r of s){let o=e.get(r);if(!o||o.length===0)continue;let i=ai[r],a=o.filter(u=>u.stillActive).length;t.push(`## ${i} (${a} active / ${o.length} total)`),t.push("");let c=[...o].sort((u,d)=>u.stillActive!==d.stillActive?u.stillActive?-1:1:u.lastSeen>d.lastSeen?-1:1);for(let u of c){let d=u.stillActive?"":" _(historical)_";t.push(`- [${u.name}](${i}/${u.slug}.md)${d}`)}t.push("")}return`${t.join(`
870
870
  `)}
871
- `}function lS(n){let e=new Map;if(n.length===0)return e;let t=Vm(n);for(let s of t.values()){let r=ii[s.kind];e.set(`analysis/${r}/${s.slug}.md`,iS(s))}return e.set("analysis/index.md",cS(t)),e.set("analysis/history.md",aS(n,t)),e}function uS(n){let{ships:e,memoryTypeCounts:t,tagKeyCounts:s,patternsCount:r,antiPatternsCount:o,llmAnalysis:i}=n,a=["# Project context export (generated)","","Agent-readable snapshot of project memory. Regenerated on `prjct remember`, `prjct capture`,","`prjct ship`, `prjct sync`, and the SessionStart / Stop hooks.","Read directly with Read/Glob \u2014 no CLI round-trip needed.","","> \u26A0\uFE0F **Snapshot, not source.** SQLite is the source of truth. Edits to files under","> `_generated/` are silently overwritten on the next regen. To add memory, run",'> `prjct remember <type> "..."` or drop a markdown note in `../captured/` (parent directory)',"> with `type:` frontmatter \u2014 the Stop hook ingests it.",""];if(e.length>0){a.push("## Ships");for(let c of e)a.push(`- [${c.name}](ships/${Nn(c.name)}.md) \u2014 ${c.shippedAt}`);a.push("")}if(n.releaseCount>0&&(a.push("## Releases"),a.push(`- [releases/index](releases/index.md) \u2014 ${n.releaseCount} versions parsed from \`CHANGELOG.md\``),a.push("")),t.size>0){a.push("## Memory by type");for(let[c,u]of t)a.push(`- [${c}](memory/${c}.md) \u2014 ${u} entries`);a.push("")}if(s.size>0){a.push("## Memory by tag");for(let[c,u]of s)a.push(`- [${c}](tags/${Nn(c)}.md) \u2014 ${u} entries`);a.push("")}return(r>0||o>0||i)&&(a.push("## Inferred"),(r>0||o>0)&&a.push(`- [patterns](patterns.md) \u2014 ${r} patterns, ${o} anti-patterns`),i&&((i.architecture?.style||i.architecture?.insights?.length||i.conventions?.length)&&a.push(`- [architecture](architecture.md) \u2014 ${i.architecture?.style??"\u2014"}, ${i.conventions?.length??0} conventions`),(i.techDebt?.length??0)+(i.riskAreas?.length??0)+(i.refactorSuggestions?.length??0)>0&&a.push(`- [tech-debt](tech-debt.md) \u2014 ${i.techDebt?.length??0} debt items, ${i.riskAreas?.length??0} risks, ${i.refactorSuggestions?.length??0} refactors`),i.projectInsights&&i.projectInsights.length>0&&a.push(`- [insights](insights.md) \u2014 ${i.projectInsights.length} project insights`)),n.archiveCount>0&&a.push(`- [analysis drill-down](analysis/index.md) \u2014 ${n.archiveCount} concepts (patterns, anti-patterns, tech-debt, risks, refactors, insights) + [history](analysis/history.md)`),a.push("")),e.length===0&&t.size===0&&r===0&&o===0&&a.push("> No ships, memory, or patterns yet. Run `prjct remember`, `prjct ship`, or `prjct sync`."),`${a.join(`
871
+ `}function uS(n){let e=new Map;if(n.length===0)return e;let t=Vm(n);for(let s of t.values()){let r=ai[s.kind];e.set(`analysis/${r}/${s.slug}.md`,aS(s))}return e.set("analysis/index.md",lS(t)),e.set("analysis/history.md",cS(n,t)),e}function dS(n){let{ships:e,memoryTypeCounts:t,tagKeyCounts:s,patternsCount:r,antiPatternsCount:o,llmAnalysis:i}=n,a=["# Project context export (generated)","","Agent-readable snapshot of project memory. Regenerated on `prjct remember`, `prjct capture`,","`prjct ship`, `prjct sync`, and the SessionStart / Stop hooks.","Read directly with Read/Glob \u2014 no CLI round-trip needed.","","> \u26A0\uFE0F **Snapshot, not source.** SQLite is the source of truth. Edits to files under","> `_generated/` are silently overwritten on the next regen. To add memory, run",'> `prjct remember <type> "..."` or drop a markdown note in `../captured/` (parent directory)',"> with `type:` frontmatter \u2014 the Stop hook ingests it.",""];if(e.length>0){a.push("## Ships");for(let c of e)a.push(`- [${c.name}](ships/${Nn(c.name)}.md) \u2014 ${c.shippedAt}`);a.push("")}if(n.releaseCount>0&&(a.push("## Releases"),a.push(`- [releases/index](releases/index.md) \u2014 ${n.releaseCount} versions parsed from \`CHANGELOG.md\``),a.push("")),t.size>0){a.push("## Memory by type");for(let[c,u]of t)a.push(`- [${c}](memory/${c}.md) \u2014 ${u} entries`);a.push("")}if(s.size>0){a.push("## Memory by tag");for(let[c,u]of s)a.push(`- [${c}](tags/${Nn(c)}.md) \u2014 ${u} entries`);a.push("")}return(r>0||o>0||i)&&(a.push("## Inferred"),(r>0||o>0)&&a.push(`- [patterns](patterns.md) \u2014 ${r} patterns, ${o} anti-patterns`),i&&((i.architecture?.style||i.architecture?.insights?.length||i.conventions?.length)&&a.push(`- [architecture](architecture.md) \u2014 ${i.architecture?.style??"\u2014"}, ${i.conventions?.length??0} conventions`),(i.techDebt?.length??0)+(i.riskAreas?.length??0)+(i.refactorSuggestions?.length??0)>0&&a.push(`- [tech-debt](tech-debt.md) \u2014 ${i.techDebt?.length??0} debt items, ${i.riskAreas?.length??0} risks, ${i.refactorSuggestions?.length??0} refactors`),i.projectInsights&&i.projectInsights.length>0&&a.push(`- [insights](insights.md) \u2014 ${i.projectInsights.length} project insights`)),n.archiveCount>0&&a.push(`- [analysis drill-down](analysis/index.md) \u2014 ${n.archiveCount} concepts (patterns, anti-patterns, tech-debt, risks, refactors, insights) + [history](analysis/history.md)`),a.push("")),e.length===0&&t.size===0&&r===0&&o===0&&a.push("> No ships, memory, or patterns yet. Run `prjct remember`, `prjct ship`, or `prjct sync`."),`${a.join(`
872
872
  `)}
873
- `}async function Hm(n){try{let e=await gt.readFile(_t.join(n,Wm),"utf-8"),t=JSON.parse(e);return t&&typeof t=="object"?t:{}}catch{return{}}}async function oi(n,e,t){let s=_t.join(n,e);await gt.mkdir(_t.dirname(s),{recursive:!0}),await gt.writeFile(s,t,"utf-8")}async function dS(n,e){try{await gt.rm(_t.join(n,e),{force:!0})}catch{}}async function pS(n,e){let t=0,s=l(async r=>{let o;try{o=await gt.readdir(r,{withFileTypes:!0})}catch{return}for(let i of o){let a=_t.join(r,i.name);if(i.isDirectory()){await s(a);try{(await gt.readdir(a)).length===0&&await gt.rmdir(a)}catch{}continue}if(!i.name.endsWith(".md"))continue;let c=_t.relative(n,a);if(!e[c])try{await gt.rm(a,{force:!0}),t++}catch{}}},"walk");return await s(n),t}async function mS(n,e){let t=null;try{t=C.get(e,`SELECT
873
+ `}async function Hm(n){try{let e=await gt.readFile(_t.join(n,Wm),"utf-8"),t=JSON.parse(e);return t&&typeof t=="object"?t:{}}catch{return{}}}async function ii(n,e,t){let s=_t.join(n,e);await gt.mkdir(_t.dirname(s),{recursive:!0}),await gt.writeFile(s,t,"utf-8")}async function pS(n,e){try{await gt.rm(_t.join(n,e),{force:!0})}catch{}}async function mS(n,e){let t=0,s=l(async r=>{let o;try{o=await gt.readdir(r,{withFileTypes:!0})}catch{return}for(let i of o){let a=_t.join(r,i.name);if(i.isDirectory()){await s(a);try{(await gt.readdir(a)).length===0&&await gt.rmdir(a)}catch{}continue}if(!i.name.endsWith(".md"))continue;let c=_t.relative(n,a);if(!e[c])try{await gt.rm(a,{force:!0}),t++}catch{}}},"walk");return await s(n),t}async function gS(n,e){let t=null;try{t=C.get(e,`SELECT
874
874
  (SELECT COALESCE(MAX(id), 0) FROM events) AS max_event_id,
875
875
  (SELECT COALESCE(MAX(id), 0) FROM llm_analysis) AS max_analysis_id,
876
876
  (SELECT COUNT(*) FROM shipped_features) AS ship_count,
877
- (SELECT MAX(shipped_at) FROM shipped_features) AS last_ship`)}catch{}let s=t?.max_event_id??0,r=t?.max_analysis_id??0,o=t?.ship_count??0,i=t?.last_ship??"",a=await gt.stat(_t.join(n,"CHANGELOG.md")).then(c=>Math.floor(c.mtimeMs)).catch(()=>0);return`v${qv}|e${s}|a${r}|s${o}|ls${i}|c${a}`}async function tl(n,e){let t=await si(n),s=_t.join(t,ri);await gt.mkdir(s,{recursive:!0});let r=_t.join(s,Um),o=await mS(n,e);if(await gt.readFile(r,"utf-8").catch(()=>null)===o){let se=await Hm(s);return{wikiRoot:t,filesWritten:0,filesSkipped:Object.keys(se).length,filesRemoved:0}}let[a,c,u,d]=await Promise.all([Uu.getAll(e),Promise.resolve(Ve.recall(e,{limit:5e3})),st.getActive(e).catch(()=>null),Promise.resolve(wt.getActive(e)).catch(()=>null)]),m=c.filter(se=>se.type!=="shipped"),p=new Map;for(let se of a)p.set(`ships/${Nn(se.name)}.md`,Jv(se));for(let[se,Ne]of Xv(m))p.set(se,Ne);for(let[se,Ne]of Kv(m))p.set(se,Ne);let g=d?.patterns??u?.patterns??[],y=d?.antiPatterns??u?.antiPatterns??[],j=Yv(g,y);if(j&&p.set("patterns.md",j),d){let se=Qv(d);se&&p.set("architecture.md",se);let Ne=Zv(d);Ne&&p.set("tech-debt.md",Ne);let Ps=eS(d);Ps&&p.set("insights.md",Ps)}let T=wt.getAllFull(e);for(let[se,Ne]of lS(T))p.set(se,Ne);let x=await oS(n);for(let[se,Ne]of x)p.set(se,Ne);let S=x.size>0?x.size-1:0,w=new Map;for(let se of m)w.set(se.type,(w.get(se.type)??0)+1);let P=new Map;for(let se of m)for(let Ne of Object.keys(se.tags))P.set(Ne,(P.get(Ne)??0)+1);p.set("index.md",uS({ships:a,memoryTypeCounts:w,tagKeyCounts:P,patternsCount:g.length,antiPatternsCount:y.length,llmAnalysis:d,archiveCount:Vm(T).size,releaseCount:S}));let v=await Hm(s),M={},F=0,fe=0,He=0;for(let[se,Ne]of p){let Ps=Bv(Ne);if(M[se]=Ps,v[se]===Ps){fe++;continue}await oi(s,se,Ne),F++}for(let se of Object.keys(v))M[se]||(await dS(s,se),He++);let Nt=await pS(s,M);He+=Nt,await oi(s,Wm,`${JSON.stringify(M,null,2)}
878
- `),await oi(s,Um,o);let Ie=_t.join(t,"README.md");return await gt.stat(Ie).then(()=>!0,()=>!1)||(await oi(t,"README.md",`# Project Wiki
877
+ (SELECT MAX(shipped_at) FROM shipped_features) AS last_ship`)}catch{}let s=t?.max_event_id??0,r=t?.max_analysis_id??0,o=t?.ship_count??0,i=t?.last_ship??"",a=await gt.stat(_t.join(n,"CHANGELOG.md")).then(c=>Math.floor(c.mtimeMs)).catch(()=>0);return`v${Vv}|e${s}|a${r}|s${o}|ls${i}|c${a}`}async function nl(n,e){let t=await ni(n),s=_t.join(t,oi);await gt.mkdir(s,{recursive:!0});let r=_t.join(s,Um),o=await gS(n,e);if(await gt.readFile(r,"utf-8").catch(()=>null)===o){let se=await Hm(s);return{wikiRoot:t,filesWritten:0,filesSkipped:Object.keys(se).length,filesRemoved:0}}let[a,c,u,d]=await Promise.all([Uu.getAll(e),Promise.resolve(Ve.recall(e,{limit:5e3})),nt.getActive(e).catch(()=>null),Promise.resolve(wt.getActive(e)).catch(()=>null)]),m=c.filter(se=>se.type!=="shipped"),p=new Map;for(let se of a)p.set(`ships/${Nn(se.name)}.md`,zv(se));for(let[se,Ne]of Kv(m))p.set(se,Ne);for(let[se,Ne]of Yv(m))p.set(se,Ne);let g=d?.patterns??u?.patterns??[],y=d?.antiPatterns??u?.antiPatterns??[],j=Qv(g,y);if(j&&p.set("patterns.md",j),d){let se=Zv(d);se&&p.set("architecture.md",se);let Ne=eS(d);Ne&&p.set("tech-debt.md",Ne);let Ps=tS(d);Ps&&p.set("insights.md",Ps)}let T=wt.getAllFull(e);for(let[se,Ne]of uS(T))p.set(se,Ne);let x=await iS(n);for(let[se,Ne]of x)p.set(se,Ne);let S=x.size>0?x.size-1:0,w=new Map;for(let se of m)w.set(se.type,(w.get(se.type)??0)+1);let P=new Map;for(let se of m)for(let Ne of Object.keys(se.tags))P.set(Ne,(P.get(Ne)??0)+1);p.set("index.md",dS({ships:a,memoryTypeCounts:w,tagKeyCounts:P,patternsCount:g.length,antiPatternsCount:y.length,llmAnalysis:d,archiveCount:Vm(T).size,releaseCount:S}));let v=await Hm(s),M={},F=0,fe=0,He=0;for(let[se,Ne]of p){let Ps=Jv(Ne);if(M[se]=Ps,v[se]===Ps){fe++;continue}await ii(s,se,Ne),F++}for(let se of Object.keys(v))M[se]||(await pS(s,se),He++);let Nt=await mS(s,M);He+=Nt,await ii(s,Wm,`${JSON.stringify(M,null,2)}
878
+ `),await ii(s,Um,o);let Ie=_t.join(t,"README.md");return await gt.stat(Ie).then(()=>!0,()=>!1)||(await ii(t,"README.md",`# Project Wiki
879
879
 
880
880
  Open this folder as an Obsidian vault to browse project memory.
881
881
 
882
- - Auto-generated content lives in \`${ri}/\` \u2014 start at [${ri}/index.md](${ri}/index.md). Do not edit; it rebuilds on \`prjct ship\` / \`prjct remember\`.
882
+ - Auto-generated content lives in \`${oi}/\` \u2014 start at [${oi}/index.md](${oi}/index.md). Do not edit; it rebuilds on \`prjct ship\` / \`prjct remember\`.
883
883
  - Drop notes into \`captured/\` with frontmatter, then run \`prjct context wiki sync\` to ingest them into project memory. See [captured/README.md](captured/README.md).
884
884
  - Any other markdown you place here survives rebuilds.
885
- `),F++),await Zc(n),await Am(t).catch(()=>{}),{wikiRoot:t,filesWritten:F,filesSkipped:fe,filesRemoved:He}}async function Mr(n,e){if(process.env.PRJCT_IN_DAEMON==="1"){setImmediate(()=>{tl(n,e).catch(()=>{})});return}try{await tl(n,e)}catch{}}var ri,Wm,Um,qv,Vv,ii,is=h(()=>{"use strict";os();Tr();ce();pn();Ds();Im();ni();Yc();ri="_generated",Wm=".manifest.json",Um=".regen-fingerprint",qv=1,Vv=50;l(Nn,"slugify");l(Bv,"sha256");l(Jv,"formatShipBody");l(zv,"groupByTagPair");l(Gm,"chunkEntries");l(Xv,"buildMemoryFiles");l(Kv,"buildTagFiles");l(Yv,"buildPatternsFile");l(Qv,"buildArchitectureFile");l(Zv,"buildTechDebtFile");l(eS,"buildInsightsFile");l(tS,"parseChangelog");l(sS,"releaseSlug");l(nS,"buildReleaseFile");l(rS,"buildReleasesIndex");l(oS,"buildReleasesFiles");ii={pattern:"patterns","anti-pattern":"anti-patterns","tech-debt":"tech-debt","risk-area":"risk-areas",refactor:"refactors",insight:"insights"};l(el,"analysisDateOnly");l(qm,"conceptKey");l(Vm,"collectConcepts");l(iS,"buildConceptFile");l(aS,"buildHistoryFile");l(cS,"buildAnalysisIndex");l(lS,"buildAnalysisArchiveFiles");l(uS,"buildIndexFile");l(Hm,"readManifest");l(oi,"writeFile");l(dS,"removeFile");l(pS,"sweepStaleFiles");l(mS,"computeRegenFingerprint");l(tl,"generateWiki");l(Mr,"regenerateWikiDeferred")});var Xm={};W(Xm,{ShippingCommands:()=>Bs,seedCodeShipRules:()=>nl});import{existsSync as Bm}from"node:fs";import Jm from"node:path";function zm(n){return["package.json","Cargo.toml","pyproject.toml","go.mod","Gemfile","pom.xml","build.gradle","VERSION"].some(t=>Bm(Jm.join(n,t)))}function sl(n){return Bm(Jm.join(n,".git"))}async function nl(n,e){if(!zm(e))return!1;let t=new Date().toISOString(),s=ee.getRulesForCommand(n,"ship"),r=new Set(s.map(d=>d.action)),i=s.reduce((d,m)=>Math.max(d,m.sortOrder??0),0)+1,a=[];sl(e)&&a.push({action:'git branch --show-current | grep -vE "^(main|master)$"',description:"Prevent shipping from main branch",timeoutMs:5e3});let c=[{action:"version:bump",description:"Bump version (stack-aware)",timeoutMs:1e4},{action:"changelog:add",description:"Append CHANGELOG entry",timeoutMs:1e4}];sl(e)&&(c.push({action:"git:commit",description:"Commit ship",timeoutMs:15e3}),c.push({action:"git:push",description:"Push to origin",timeoutMs:3e4}));let u=0;for(let d of a)r.has(d.action)||(ee.addRule(n,{type:"gate",command:"ship",position:"before",action:d.action,description:d.description,enabled:!0,timeoutMs:d.timeoutMs,sortOrder:i++,createdAt:t}),u++);for(let d of c)r.has(d.action)||(ee.addRule(n,{type:"step",command:"ship",position:"before",action:d.action,description:d.description,enabled:!0,timeoutMs:d.timeoutMs,sortOrder:i++,createdAt:t}),u++);return u>0}async function gS(n,e,t,s){if(s.intent==="proceed"||s.intent==="register-only")return null;if(!t.some(a=>a.type==="step"&&a.position==="before"))return{question:"No `ship` workflow steps are configured for this project. What should ship do?",options:["register-only","seed-code-workflow","abort"],state:{rulesCount:t.length,looksLikeCode:zm(e)}};if(await D.getCurrentTask(n))return null;let i=await hS(e);return i?{question:`No active task, and PR #${i.number} ("${i.title}") is OPEN for this branch. Continue ship anyway?`,options:["proceed","abort"],state:{openPr:i.number,branch:i.branch}}:null}function fS(n,e){if(e){let t=G(le("Clarification needed",n.question),le("Options",$e(n.options.map(s=>`\`prjct ship --intent=${s}\``))),n.state?le("State",$e(Object.entries(n.state).map(([s,r])=>`${s}: ${JSON.stringify(r)}`))):null);console.log(t);return}console.log(`
885
+ `),F++),await tl(n),await Am(t).catch(()=>{}),{wikiRoot:t,filesWritten:F,filesSkipped:fe,filesRemoved:He}}async function Mr(n,e){if(process.env.PRJCT_IN_DAEMON==="1"){setImmediate(()=>{nl(n,e).catch(()=>{})});return}try{await nl(n,e)}catch{}}var oi,Wm,Um,Vv,Bv,ai,as=h(()=>{"use strict";is();Tr();ce();pn();Ds();Im();ri();Zc();oi="_generated",Wm=".manifest.json",Um=".regen-fingerprint",Vv=1,Bv=50;l(Nn,"slugify");l(Jv,"sha256");l(zv,"formatShipBody");l(Xv,"groupByTagPair");l(Gm,"chunkEntries");l(Kv,"buildMemoryFiles");l(Yv,"buildTagFiles");l(Qv,"buildPatternsFile");l(Zv,"buildArchitectureFile");l(eS,"buildTechDebtFile");l(tS,"buildInsightsFile");l(sS,"parseChangelog");l(nS,"releaseSlug");l(rS,"buildReleaseFile");l(oS,"buildReleasesIndex");l(iS,"buildReleasesFiles");ai={pattern:"patterns","anti-pattern":"anti-patterns","tech-debt":"tech-debt","risk-area":"risk-areas",refactor:"refactors",insight:"insights"};l(sl,"analysisDateOnly");l(qm,"conceptKey");l(Vm,"collectConcepts");l(aS,"buildConceptFile");l(cS,"buildHistoryFile");l(lS,"buildAnalysisIndex");l(uS,"buildAnalysisArchiveFiles");l(dS,"buildIndexFile");l(Hm,"readManifest");l(ii,"writeFile");l(pS,"removeFile");l(mS,"sweepStaleFiles");l(gS,"computeRegenFingerprint");l(nl,"generateWiki");l(Mr,"regenerateWikiDeferred")});var Xm={};W(Xm,{ShippingCommands:()=>Bs,seedCodeShipRules:()=>ol});import{existsSync as Bm}from"node:fs";import Jm from"node:path";function zm(n){return["package.json","Cargo.toml","pyproject.toml","go.mod","Gemfile","pom.xml","build.gradle","VERSION"].some(t=>Bm(Jm.join(n,t)))}function rl(n){return Bm(Jm.join(n,".git"))}async function ol(n,e){if(!zm(e))return!1;let t=new Date().toISOString(),s=ee.getRulesForCommand(n,"ship"),r=new Set(s.map(d=>d.action)),i=s.reduce((d,m)=>Math.max(d,m.sortOrder??0),0)+1,a=[];rl(e)&&a.push({action:'git branch --show-current | grep -vE "^(main|master)$"',description:"Prevent shipping from main branch",timeoutMs:5e3});let c=[{action:"version:bump",description:"Bump version (stack-aware)",timeoutMs:1e4},{action:"changelog:add",description:"Append CHANGELOG entry",timeoutMs:1e4}];rl(e)&&(c.push({action:"git:commit",description:"Commit ship",timeoutMs:15e3}),c.push({action:"git:push",description:"Push to origin",timeoutMs:3e4}));let u=0;for(let d of a)r.has(d.action)||(ee.addRule(n,{type:"gate",command:"ship",position:"before",action:d.action,description:d.description,enabled:!0,timeoutMs:d.timeoutMs,sortOrder:i++,createdAt:t}),u++);for(let d of c)r.has(d.action)||(ee.addRule(n,{type:"step",command:"ship",position:"before",action:d.action,description:d.description,enabled:!0,timeoutMs:d.timeoutMs,sortOrder:i++,createdAt:t}),u++);return u>0}async function fS(n,e,t,s){if(s.intent==="proceed"||s.intent==="register-only")return null;if(!t.some(a=>a.type==="step"&&a.position==="before"))return{question:"No `ship` workflow steps are configured for this project. What should ship do?",options:["register-only","seed-code-workflow","abort"],state:{rulesCount:t.length,looksLikeCode:zm(e)}};if(await D.getCurrentTask(n))return null;let i=await yS(e);return i?{question:`No active task, and PR #${i.number} ("${i.title}") is OPEN for this branch. Continue ship anyway?`,options:["proceed","abort"],state:{openPr:i.number,branch:i.branch}}:null}function hS(n,e){if(e){let t=G(le("Clarification needed",n.question),le("Options",$e(n.options.map(s=>`\`prjct ship --intent=${s}\``))),n.state?le("State",$e(Object.entries(n.state).map(([s,r])=>`${s}: ${JSON.stringify(r)}`))):null);console.log(t);return}console.log(`
886
886
  \u26A0\uFE0F ${n.question}`),console.log(`
887
- Options:`);for(let t of n.options)console.log(` prjct ship --intent=${t}`)}async function hS(n){if(!sl(n))return null;try{let{execFileAsync:e}=await Promise.resolve().then(()=>(Ze(),Di)),{stdout:t}=await e("git",["branch","--show-current"],{cwd:n,timeout:3e3}),s=t.toString().trim();if(!s)return null;let{stdout:r}=await e("gh",["pr","list","--head",s,"--state","open","--json","number,title","--limit","1"],{cwd:n,timeout:5e3}),o=JSON.parse(r.toString());return o.length===0?null:{number:o[0].number,title:o[0].title,branch:s}}catch{return null}}var Bs,ai=h(()=>{"use strict";de();Wo();Ds();rt();mn();V();be();xr();Ir();Me();Xc();bt();Bs=class extends we{static{l(this,"ShippingCommands")}async ship(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;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 D.getCurrentTask(o);a&&(i||(i=a.description||"current work"),await D.completeTask(o)),i||(i="current work");let c=ee.getRulesForCommand(o,"ship");if(s.intent==="seed-code-workflow"){if(!await nl(o,t))return{success:!1,error:"seed-code-workflow requested but this project does not look like code (no package.json / Cargo.toml / pyproject.toml / VERSION). Add rules manually with `prjct workflow add`."};c=ee.getRulesForCommand(o,"ship")}!c.some(x=>x.type==="step"&&x.position==="before")&&s.intent!=="register-only"&&await nl(o,t)&&(console.log("\u2139\uFE0F Auto-seeded code ship workflow (one-time migration)"),c=ee.getRulesForCommand(o,"ship"));let d=await gS(o,t,c,s);if(d)return fS(d,s.md===!0),{success:!1,clarification:d};let m={feature:i},p=await Ss(o,"ship","before",{projectPath:t,skipRules:s.skipHooks,runContext:m});if(!p.success)return{success:!1,error:`Ship blocked: ${p.gatesFailed.length>0?p.gatesFailed.join(", "):"unknown step"}`};let g=typeof m.version=="string"?m.version:"unversioned";await Ke.addShipped(o,{name:i,version:g}),await this.logToMemory(t,"feature_shipped",{feature:i,version:g,timestamp:R()});let y=await Ss(o,"ship","after",{projectPath:t,skipRules:s.skipHooks,runContext:m}),j=[...p.instructions,...y.instructions];try{await ns.sync(t)}catch(x){console.warn("\u26A0\uFE0F Failed to sync AI context after shipping:",k(x))}try{let{regenerateWikiDeferred:x}=await Promise.resolve().then(()=>(is(),Vs));await x(t,o)}catch(x){console.warn("\u26A0\uFE0F Wiki regeneration failed (non-blocking):",k(x))}let T=p.stepsRun.length+y.stepsRun.length;if(s.md){let x=Go("ship",!0),S=G(Ce(`Shipped: ${i}`,`Version: ${g}`),le("Results",$e([`Version: ${g}`,`Workflow steps run: ${T>0?[...p.stepsRun,...y.stepsRun].join(", "):"none"}`,`Hooks failed (non-blocking): ${p.hooksFailed.length+y.hooksFailed.length}`])),j.length>0?le("Agent Instructions",$e(j)):null,qe(x.map(w=>({label:w.desc,command:w.cmd}))));console.log(S)}else f.done(`v${g} shipped`),Pn("ship");return{success:!0,feature:i,version:g}}catch(r){return f.fail(k(r)),{success:!1,error:k(r)}}}};l(zm,"isCodeProject");l(sl,"isGitRepo");l(nl,"seedCodeShipRules");l(gS,"buildClarification");l(fS,"renderClarification");l(hS,"findOpenPrForBranch")});var Qm={};W(Qm,{PlanningCommands:()=>Js});import Km from"node:fs/promises";import Ym from"node:path";async function yS(){if(!rl){let{AnalysisCommands:n}=await Promise.resolve().then(()=>(li(),Zm));rl=new n}return rl}var rl,Js,ci=h(()=>{"use strict";so();Wt();de();Re();mn();V();Me();_c();mm();bt();rl=null;l(yS,"getAnalysisCommands");Js=class extends we{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 $r(t).runNonInteractive());else if(a=await new $r(t).run(),a.skipped)return{success:!1,message:"Setup cancelled"};f.step(1,4,"Detecting author...");let c=await cn(),u={name:c.name||void 0,email:c.email||void 0,github:c.github||void 0},m=(await I.createConfig(t,u)).projectId;await this._applyInitialPacksAndPersona(t,s),f.step(2,4,"Creating structure..."),await $.ensureProjectStructure(m);let p=$.getGlobalProjectPath(m);await this._seedShipWorkflow(m,t);let g={"core/now.md":`# NOW
887
+ Options:`);for(let t of n.options)console.log(` prjct ship --intent=${t}`)}async function yS(n){if(!rl(n))return null;try{let{execFileAsync:e}=await Promise.resolve().then(()=>(Ze(),Mi)),{stdout:t}=await e("git",["branch","--show-current"],{cwd:n,timeout:3e3}),s=t.toString().trim();if(!s)return null;let{stdout:r}=await e("gh",["pr","list","--head",s,"--state","open","--json","number,title","--limit","1"],{cwd:n,timeout:5e3}),o=JSON.parse(r.toString());return o.length===0?null:{number:o[0].number,title:o[0].title,branch:s}}catch{return null}}var Bs,ci=h(()=>{"use strict";de();Go();Ds();ot();mn();V();be();xr();Ir();Me();Yc();bt();Bs=class extends we{static{l(this,"ShippingCommands")}async ship(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;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 D.getCurrentTask(o);a&&(i||(i=a.description||"current work"),await D.completeTask(o)),i||(i="current work");let c=ee.getRulesForCommand(o,"ship");if(s.intent==="seed-code-workflow"){if(!await ol(o,t))return{success:!1,error:"seed-code-workflow requested but this project does not look like code (no package.json / Cargo.toml / pyproject.toml / VERSION). Add rules manually with `prjct workflow add`."};c=ee.getRulesForCommand(o,"ship")}!c.some(x=>x.type==="step"&&x.position==="before")&&s.intent!=="register-only"&&await ol(o,t)&&(console.log("\u2139\uFE0F Auto-seeded code ship workflow (one-time migration)"),c=ee.getRulesForCommand(o,"ship"));let d=await fS(o,t,c,s);if(d)return hS(d,s.md===!0),{success:!1,clarification:d};let m={feature:i},p=await Ss(o,"ship","before",{projectPath:t,skipRules:s.skipHooks,runContext:m});if(!p.success)return{success:!1,error:`Ship blocked: ${p.gatesFailed.length>0?p.gatesFailed.join(", "):"unknown step"}`};let g=typeof m.version=="string"?m.version:"unversioned";await Ke.addShipped(o,{name:i,version:g}),await this.logToMemory(t,"feature_shipped",{feature:i,version:g,timestamp:R()});let y=await Ss(o,"ship","after",{projectPath:t,skipRules:s.skipHooks,runContext:m}),j=[...p.instructions,...y.instructions];try{await rs.sync(t)}catch(x){console.warn("\u26A0\uFE0F Failed to sync AI context after shipping:",k(x))}try{let{regenerateWikiDeferred:x}=await Promise.resolve().then(()=>(as(),Vs));await x(t,o)}catch(x){console.warn("\u26A0\uFE0F Wiki regeneration failed (non-blocking):",k(x))}let T=p.stepsRun.length+y.stepsRun.length;if(s.md){let x=qo("ship",!0),S=G(Ce(`Shipped: ${i}`,`Version: ${g}`),le("Results",$e([`Version: ${g}`,`Workflow steps run: ${T>0?[...p.stepsRun,...y.stepsRun].join(", "):"none"}`,`Hooks failed (non-blocking): ${p.hooksFailed.length+y.hooksFailed.length}`])),j.length>0?le("Agent Instructions",$e(j)):null,qe(x.map(w=>({label:w.desc,command:w.cmd}))));console.log(S)}else f.done(`v${g} shipped`),Pn("ship");return{success:!0,feature:i,version:g}}catch(r){return f.fail(k(r)),{success:!1,error:k(r)}}}};l(zm,"isCodeProject");l(rl,"isGitRepo");l(ol,"seedCodeShipRules");l(fS,"buildClarification");l(hS,"renderClarification");l(yS,"findOpenPrForBranch")});var Qm={};W(Qm,{PlanningCommands:()=>Js});import Km from"node:fs/promises";import Ym from"node:path";async function wS(){if(!il){let{AnalysisCommands:n}=await Promise.resolve().then(()=>(ui(),Zm));il=new n}return il}var il,Js,li=h(()=>{"use strict";no();Wt();de();Re();mn();V();Me();Oc();mm();bt();il=null;l(wS,"getAnalysisCommands");Js=class extends we{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 $r(t).runNonInteractive());else if(a=await new $r(t).run(),a.skipped)return{success:!1,message:"Setup cancelled"};f.step(1,4,"Detecting author...");let c=await cn(),u={name:c.name||void 0,email:c.email||void 0,github:c.github||void 0},m=(await I.createConfig(t,u)).projectId;await this._applyInitialPacksAndPersona(t,s),f.step(2,4,"Creating structure..."),await $.ensureProjectStructure(m);let p=$.getGlobalProjectPath(m);await this._seedShipWorkflow(m,t);let g={"core/now.md":`# NOW
888
888
 
889
889
  No current task. Use \`/p:now\` to set focus.
890
890
  `,"core/next.md":`# NEXT
@@ -903,7 +903,7 @@ No current task. Use \`/p:now\` to set focus.
903
903
 
904
904
  `,"planning/roadmap.md":`# ROADMAP
905
905
 
906
- `,"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[x,S]of Object.entries(g))await Km.writeFile(Ym.join(p,x),S);let y=await this._detectEmptyDirectory(t),j=await this._detectExistingCode(t);if(j||!y){f.step(3,4,"Analyzing project...");let x=await yS();if((await x.analyze({},t)).success)return f.step(4,4,"Generating agents..."),await x.sync(t),f.done("initialized"),this._printNextSteps(a),{success:!0,mode:"existing",projectId:m,wizard:a}}let T=s.idea;if(y&&!j){if(!T)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 x=Ym.join(p,"planning","architect-session.md"),S=`# Architect Session
906
+ `,"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[x,S]of Object.entries(g))await Km.writeFile(Ym.join(p,x),S);let y=await this._detectEmptyDirectory(t),j=await this._detectExistingCode(t);if(j||!y){f.step(3,4,"Analyzing project...");let x=await wS();if((await x.analyze({},t)).success)return f.step(4,4,"Generating agents..."),await x.sync(t),f.done("initialized"),this._printNextSteps(a),{success:!0,mode:"existing",projectId:m,wizard:a}}let T=s.idea;if(y&&!j){if(!T)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 x=Ym.join(p,"planning","architect-session.md"),S=`# Architect Session
907
907
 
908
908
  ## Idea
909
909
  ${T}
@@ -912,7 +912,7 @@ ${T}
912
912
  Initialized - awaiting stack recommendation
913
913
 
914
914
  Generated: ${new Date().toLocaleString()}
915
- `;return await Km.writeFile(x,S),await Te.installGlobalConfig(),f.done("architect mode ready"),{success:!0,mode:"architect",projectId:m,idea:T,wizard:a}}return await Te.installGlobalConfig(),f.done("initialized"),this._printNextSteps(a),{success:!0,projectId:m,wizard:a}}catch(s){return f.fail(k(s)),{success:!1,error:k(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 _applyInitialPacksAndPersona(e,t){let{activatePacks:s,detectSuggestedPacks:r}=await Promise.resolve().then(()=>(Wc(),fm)),o=[];if(t.pack?o=t.pack.split(",").map(i=>i.trim()).filter(Boolean):t.persona||(o=await r(e)),o.length>0&&await s(e,o,{suggestPersona:!0}),t.persona){let i=(await Promise.resolve().then(()=>(de(),ur))).default,a=await i.readConfig(e);if(a){let c=a.persona??{role:t.persona};c.role=t.persona,await i.writeConfig(e,{...a,persona:c})}}}async _seedShipWorkflow(e,t){let s=await Xo(t),r=0,{seedCodeShipRules:o}=await Promise.resolve().then(()=>(ai(),Xm));await o(e,t),r=ee.getRulesForCommand(e,"ship").reduce((i,a)=>Math.max(i,a.sortOrder??0),0)+1,ee.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:r++,createdAt:new Date().toISOString()}),s.lint&&ee.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:r++,createdAt:new Date().toISOString()}),s.test&&ee.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:r++,createdAt:new Date().toISOString()})}}});var ol,zs,eg=h(()=>{"use strict";ds();so();de();Re();V();J();Me();ol=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(()=>(ci(),Qm)),r=await new t().init(null,e);return r.success?{success:!0}:r}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 $.ensureProjectStructure(t),$.getGlobalProjectPath(t)}async ensureAuthor(){if(this.currentAuthor)return this.currentAuthor;let e=await cn();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 Yt(e)).filter(r=>!r.startsWith(".")&&r!=="node_modules"&&r!=="package.json"&&r!=="package-lock.json"&&r!=="README.md").length===0}catch(t){return _(t)||console.error(`Directory check error: ${k(t)}`),!0}}async hasExistingCode(e){try{let t=["src","lib","app","components","pages","api","main.go","main.rs","main.py"];return(await Yt(e)).some(r=>t.includes(r))}catch(t){return _(t)||console.error(`Code check error: ${k(t)}`),!1}}async isConfigured(e){return await I.isConfigured(e)}async needsMigration(e){return await I.needsMigration(e)}},zs=new ol});var we,bt=h(()=>{"use strict";xc();lm();um();ks();eg();we=class{static{l(this,"PrjctCommandsBase")}prjctDir;updateChecker;updateNotificationShown;constructor(){this.prjctDir=".prjct",this.updateChecker=new qo,this.updateNotificationShown=!1}get agent(){return zo.getAgent()}get agentInfo(){return zo.getInfo()}get currentAuthor(){return zs.getCurrentAuthor()}async initializeAgent(){return zo.initialize()}async ensureProjectInit(e){return zs.ensureInit(e)}async ensureAuthor(){return zs.ensureAuthor()}async getGlobalProjectPath(e){return zs.getGlobalPath(e)}async logToMemory(e,t,s){let r=await this.ensureAuthor();return Ye.log(e,t,s,r.name)}async _detectEmptyDirectory(e){return zs.isEmptyDirectory(e)}async _detectExistingCode(e){return zs.hasExistingCode(e)}_breakdownFeatureTasks(e){return Mc.breakdownFeature(e)}_detectBugSeverity(e){return Mc.detectBugSeverity(e)}}});var Zm={};W(Zm,{AnalysisCommands:()=>Ks});import ui from"node:fs/promises";import wS from"node:path";import*as Xs from"@clack/prompts";var tg,Ks,li=h(()=>{"use strict";Sd();Wt();de();Re();mo();Ha();Fd();Bd();Wo();Tr();ce();pn();go();V();be();xr();Ir();Me();Qp();bt();tg=`{version:1, commitHash, analyzedAt,
915
+ `;return await Km.writeFile(x,S),await Te.installGlobalConfig(),f.done("architect mode ready"),{success:!0,mode:"architect",projectId:m,idea:T,wizard:a}}return await Te.installGlobalConfig(),f.done("initialized"),this._printNextSteps(a),{success:!0,projectId:m,wizard:a}}catch(s){return f.fail(k(s)),{success:!1,error:k(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 _applyInitialPacksAndPersona(e,t){let{activatePacks:s,detectSuggestedPacks:r}=await Promise.resolve().then(()=>(qc(),fm)),o=[];if(t.pack?o=t.pack.split(",").map(i=>i.trim()).filter(Boolean):t.persona||(o=await r(e)),o.length>0&&await s(e,o,{suggestPersona:!0}),t.persona){let i=(await Promise.resolve().then(()=>(de(),ur))).default,a=await i.readConfig(e);if(a){let c=a.persona??{role:t.persona};c.role=t.persona,await i.writeConfig(e,{...a,persona:c})}}}async _seedShipWorkflow(e,t){let s=await Ko(t),r=0,{seedCodeShipRules:o}=await Promise.resolve().then(()=>(ci(),Xm));await o(e,t),r=ee.getRulesForCommand(e,"ship").reduce((i,a)=>Math.max(i,a.sortOrder??0),0)+1,ee.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:r++,createdAt:new Date().toISOString()}),s.lint&&ee.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:r++,createdAt:new Date().toISOString()}),s.test&&ee.addRule(e,{type:"step",command:"ship",position:"before",action:`${s.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:r++,createdAt:new Date().toISOString()})}}});var al,zs,eg=h(()=>{"use strict";ds();no();de();Re();V();J();Me();al=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(()=>(li(),Qm)),r=await new t().init(null,e);return r.success?{success:!0}:r}async getProjectId(e){let t=await I.getProjectId(e);if(!t)throw Qr.notInitialized();return t}async getGlobalPath(e){let t=await this.getProjectId(e);return await $.ensureProjectStructure(t),$.getGlobalProjectPath(t)}async ensureAuthor(){if(this.currentAuthor)return this.currentAuthor;let e=await cn();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 Yt(e)).filter(r=>!r.startsWith(".")&&r!=="node_modules"&&r!=="package.json"&&r!=="package-lock.json"&&r!=="README.md").length===0}catch(t){return _(t)||console.error(`Directory check error: ${k(t)}`),!0}}async hasExistingCode(e){try{let t=["src","lib","app","components","pages","api","main.go","main.rs","main.py"];return(await Yt(e)).some(r=>t.includes(r))}catch(t){return _(t)||console.error(`Code check error: ${k(t)}`),!1}}async isConfigured(e){return await I.isConfigured(e)}async needsMigration(e){return await I.needsMigration(e)}},zs=new al});var we,bt=h(()=>{"use strict";Ic();lm();um();ks();eg();we=class{static{l(this,"PrjctCommandsBase")}prjctDir;updateChecker;updateNotificationShown;constructor(){this.prjctDir=".prjct",this.updateChecker=new Vo,this.updateNotificationShown=!1}get agent(){return Xo.getAgent()}get agentInfo(){return Xo.getInfo()}get currentAuthor(){return zs.getCurrentAuthor()}async initializeAgent(){return Xo.initialize()}async ensureProjectInit(e){return zs.ensureInit(e)}async ensureAuthor(){return zs.ensureAuthor()}async getGlobalProjectPath(e){return zs.getGlobalPath(e)}async logToMemory(e,t,s){let r=await this.ensureAuthor();return Ye.log(e,t,s,r.name)}async _detectEmptyDirectory(e){return zs.isEmptyDirectory(e)}async _detectExistingCode(e){return zs.hasExistingCode(e)}_breakdownFeatureTasks(e){return Nc.breakdownFeature(e)}_detectBugSeverity(e){return Nc.detectBugSeverity(e)}}});var Zm={};W(Zm,{AnalysisCommands:()=>Ks});import di from"node:fs/promises";import kS from"node:path";import*as Xs from"@clack/prompts";var tg,Ks,ui=h(()=>{"use strict";Sd();Wt();de();Re();go();Ga();Fd();Bd();Go();Tr();ce();pn();fo();V();be();xr();Ir();Me();Qp();bt();tg=`{version:1, commitHash, analyzedAt,
916
916
  architecture:{style:"monolith|monorepo|microservices|modular-monolith", insights:[], domains:[]},
917
917
  patterns:[{name, description, locations:[], confidence:0-1, category:"architecture|data-flow|error-handling|testing"}],
918
918
  antiPatterns:[{issue, reasoning, files:[], suggestion, severity:"low|medium|high", confidence:0-1}],
@@ -920,11 +920,11 @@ Generated: ${new Date().toLocaleString()}
920
920
  riskAreas:[{path, reason, risk, severity}], refactorSuggestions:[{description, files:[], benefit, effort}],
921
921
  projectInsights:[], conventions:[{category, rule, example}],
922
922
  commands:{build, test, lint, dev, format, install}, stack:{languages:[], frameworks:[], packageManager}}`,Ks=class extends we{static{l(this,"AnalysisCommands")}async analyze(e={},t=process.cwd()){try{await this.initializeAgent(),console.log(`\u{1F50D} Analyzing repository...
923
- `),Ue.init(t);let s={packageJson:await Ue.readPackageJson(),cargoToml:await Ue.readCargoToml(),goMod:await Ue.readGoMod(),requirements:await Ue.readRequirements(),directories:await Ue.listDirectories(),fileCount:await Ue.countFiles(),gitStats:await Ue.getGitStats(),gitLog:await Ue.getGitLog(20),hasDockerfile:await Ue.fileExists("Dockerfile"),hasDockerCompose:await Ue.fileExists("docker-compose.yml"),hasReadme:await Ue.fileExists("README.md"),hasTsconfig:await Ue.fileExists("tsconfig.json"),hasViteConfig:await Ue.fileExists("vite.config.ts")||await Ue.fileExists("vite.config.js"),hasNextConfig:await Ue.fileExists("next.config.js")||await Ue.fileExists("next.config.mjs")},r=Yp(s,t),o=await I.getProjectId(t),i=$.getFilePath(o,"analysis","repo-summary.md");await ui.writeFile(i,r,"utf-8"),await this.logToMemory(t,"repository_analyzed",{timestamp:R(),fileCount:s.fileCount,gitCommits:s.gitStats.totalCommits});let c=await(We(),ht(yt)).getActiveProvider(),u=await Te.installGlobalConfig();return u.success&&console.log(`\u{1F4DD} Updated ${$.getDisplayPath(u.path)}`),console.log(`\u2705 Analysis complete!
923
+ `),Ue.init(t);let s={packageJson:await Ue.readPackageJson(),cargoToml:await Ue.readCargoToml(),goMod:await Ue.readGoMod(),requirements:await Ue.readRequirements(),directories:await Ue.listDirectories(),fileCount:await Ue.countFiles(),gitStats:await Ue.getGitStats(),gitLog:await Ue.getGitLog(20),hasDockerfile:await Ue.fileExists("Dockerfile"),hasDockerCompose:await Ue.fileExists("docker-compose.yml"),hasReadme:await Ue.fileExists("README.md"),hasTsconfig:await Ue.fileExists("tsconfig.json"),hasViteConfig:await Ue.fileExists("vite.config.ts")||await Ue.fileExists("vite.config.js"),hasNextConfig:await Ue.fileExists("next.config.js")||await Ue.fileExists("next.config.mjs")},r=Yp(s,t),o=await I.getProjectId(t),i=$.getFilePath(o,"analysis","repo-summary.md");await di.writeFile(i,r,"utf-8"),await this.logToMemory(t,"repository_analyzed",{timestamp:R(),fileCount:s.fileCount,gitCommits:s.gitStats.totalCommits});let c=await(We(),ht(yt)).getActiveProvider(),u=await Te.installGlobalConfig();return u.success&&console.log(`\u{1F4DD} Updated ${$.getDisplayPath(u.path)}`),console.log(`\u2705 Analysis complete!
924
924
  `),console.log(`\u{1F4C4} Full report: ${$.getDisplayPath(i)}`),console.log(`\u{1F4DD} Context: ~/.prjct-cli/projects/${o}/${c.contextFile}
925
- `),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:i,data:s}}catch(s){return console.error("\u274C Error:",k(s)),{success:!1,error:k(s)}}}async sync(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=$.getGlobalProjectPath(r),i=Date.now();if(t.package){let m=await $.detectMonorepo(e);if(!m.isMonorepo)return{success:!1,error:"Not a monorepo. --package flag only works in monorepos."};let p=m.packages.find(y=>y.name===t.package||y.relativePath===t.package);if(!p){let y=m.packages.map(j=>j.name).join(", ");return{success:!1,error:`Package "${t.package}" not found. Available: ${y}`}}let g=await ns.sync(e,{packagePath:p.path,packageName:p.name});return t.json?console.log(JSON.stringify({success:g.success,package:p.name,path:p.relativePath})):t.md?console.log(G(Ce(`Synced package: ${p.name}`))):f.done(`Synced package: ${p.name}`),{success:g.success}}let a=wS.join(o,"context","CLAUDE.md"),c=null;try{c=await ui.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 ns.sync(e,{full:t.full});if(!m.success)return t.md?(console.log(G("## 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 p;try{p=await ui.readFile(a,"utf-8")}catch{p=""}let g=Gd(c,p);if(u||f.stop(),!g.hasChanges)return t.md?(console.log(G(Ce("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 y=l(async()=>{c!=null&&await ui.writeFile(a,c,"utf-8")},"restoreOriginal");if(t.md){await y();let T=[];for(let S of g.added)T.push(`Added: ${S.name} (${S.lineCount} lines)`);for(let S of g.modified)T.push(`Modified: ${S.name} (${S.lineCount} lines)`);for(let S of g.removed)T.push(`Removed: ${S.name} (${S.lineCount} lines)`);let x=G("## Sync Preview",T.length>0?le("Changes",$e(T)):"No section changes.",Hs({"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(x),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(u){await y();let T={added:g.added.map(x=>({name:x.name,lineCount:x.lineCount})),modified:g.modified.map(x=>({name:x.name,lineCount:x.lineCount})),removed:g.removed.map(x=>({name:x.name,lineCount:x.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:T,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(qd(g)),t.preview)return await y(),{success:!0,isPreview:!0,diff:g,message:"Preview complete (no changes applied)"};let j=await Xs.select({message:"Apply these changes?",options:[{label:"Yes, apply changes",value:"apply"},{label:"No, cancel",value:"cancel"},{label:"Show full diff",value:"diff"}]});if(Xs.isCancel(j)||j==="cancel")return await y(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"};if(j==="diff"){console.log(`
926
- ${Vd(g)}`);let T=await Xs.confirm({message:"Apply these changes?",initialValue:!0});if(Xs.isCancel(T)||!T)return await y(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"}}return f.done("Changes applied"),Cc(m,i)}t.md||f.spin("Syncing project...");let d=await ns.sync(e,{full:t.full});if(!d.success)return t.md?console.log(G("## Sync Failed",`> ${d.error||"Unknown error"}`)):f.fail(d.error||"Sync failed"),{success:!1,error:d.error};if(t.md||f.stop(),t.md){let m=Date.now()-i,p=d.generatedSkills?.generated?.length??0,g=null;try{let v=await st.diff(r);v?.hasChanges&&(g=Ua(v))}catch{}let y=d.git.recentCommits[0]?.hash??null,j=y&&wt.isCurrent(r,y),T=null;if(!j)try{let v=await Xa(r,e,d.git,d.stats);T=["## Analysis Payload","> Analyze this project data. Return JSON matching the schema.","### Schema","```",tg,"```","### Data","```json",JSON.stringify(v),"```","> Save: `prjct analysis-save-llm '<JSON>' --md`"].join(`
927
- `)}catch{T="### Next: Run `prjct analysis-payload --md` to update project analysis"}let x=Go("sync",!0),S=d.syncMetrics?.indexes,w={Duration:`${(m/1e3).toFixed(1)}s`,Skills:`${p} generated`,"Files indexed":d.stats.fileCount};if(S?.bm25Files){let v=S.bm25Files*(S.bm25AvgTokens||0);w["Tokens indexed"]=`${Math.round(v/1e3)}K`,w["Import edges"]=S.importEdges||0,w["Co-change commits"]=S.cochangeCommits||0}let P=G(Ce("Sync Complete"),Hs(w),g,d.git.hasChanges?Gp("Uncommitted changes detected"):null,T,qe(x.map(v=>({label:v.desc,command:v.cmd}))));return console.log(P),{success:!0,data:d,metrics:{elapsed:m,skillCount:p,fileCount:d.stats.fileCount}}}return Cc(d,i)}catch(s){return t.md?console.log(G("## Sync Failed",`> ${k(s)}`)):f.fail(k(s)),{success:!1,error:k(s)}}}async analysisPayload(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await ns.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&&wt.isCurrent(r,i))return t.md?console.log(G(Ce("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 Xa(r,e,o.git,o.stats);return t.md?console.log(G("## Analysis Payload","> Analyze this project data. Return JSON matching the schema.","### Schema","```",tg,"```","### Data","```json",JSON.stringify(a),"```","> Save: `prjct analysis-save-llm '<JSON>' --md`")):console.log(JSON.stringify({success:!0,payload:a})),{success:!0,data:a}}catch(s){return{success:!1,error:k(s)}}}async regenVault(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await import("node:fs/promises"),i=(await Promise.resolve().then(()=>(Re(),gu))).default,c=await(await Promise.resolve().then(()=>(de(),ur))).default.readConfig(e).catch(()=>null),d=`${i.getWikiPath(e,c?.vaultPath)}/_generated`;await o.rm(d,{recursive:!0,force:!0});let{generateWiki:m}=await Promise.resolve().then(()=>(is(),Vs)),p=await m(e,r);return t.md?console.log(`---
925
+ `),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:i,data:s}}catch(s){return console.error("\u274C Error:",k(s)),{success:!1,error:k(s)}}}async sync(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=$.getGlobalProjectPath(r),i=Date.now();if(t.package){let m=await $.detectMonorepo(e);if(!m.isMonorepo)return{success:!1,error:"Not a monorepo. --package flag only works in monorepos."};let p=m.packages.find(y=>y.name===t.package||y.relativePath===t.package);if(!p){let y=m.packages.map(j=>j.name).join(", ");return{success:!1,error:`Package "${t.package}" not found. Available: ${y}`}}let g=await rs.sync(e,{packagePath:p.path,packageName:p.name});return t.json?console.log(JSON.stringify({success:g.success,package:p.name,path:p.relativePath})):t.md?console.log(G(Ce(`Synced package: ${p.name}`))):f.done(`Synced package: ${p.name}`),{success:g.success}}let a=kS.join(o,"context","CLAUDE.md"),c=null;try{c=await di.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 rs.sync(e,{full:t.full});if(!m.success)return t.md?(console.log(G("## 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 p;try{p=await di.readFile(a,"utf-8")}catch{p=""}let g=Gd(c,p);if(u||f.stop(),!g.hasChanges)return t.md?(console.log(G(Ce("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 y=l(async()=>{c!=null&&await di.writeFile(a,c,"utf-8")},"restoreOriginal");if(t.md){await y();let T=[];for(let S of g.added)T.push(`Added: ${S.name} (${S.lineCount} lines)`);for(let S of g.modified)T.push(`Modified: ${S.name} (${S.lineCount} lines)`);for(let S of g.removed)T.push(`Removed: ${S.name} (${S.lineCount} lines)`);let x=G("## Sync Preview",T.length>0?le("Changes",$e(T)):"No section changes.",Hs({"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(x),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(u){await y();let T={added:g.added.map(x=>({name:x.name,lineCount:x.lineCount})),modified:g.modified.map(x=>({name:x.name,lineCount:x.lineCount})),removed:g.removed.map(x=>({name:x.name,lineCount:x.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:T,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(qd(g)),t.preview)return await y(),{success:!0,isPreview:!0,diff:g,message:"Preview complete (no changes applied)"};let j=await Xs.select({message:"Apply these changes?",options:[{label:"Yes, apply changes",value:"apply"},{label:"No, cancel",value:"cancel"},{label:"Show full diff",value:"diff"}]});if(Xs.isCancel(j)||j==="cancel")return await y(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"};if(j==="diff"){console.log(`
926
+ ${Vd(g)}`);let T=await Xs.confirm({message:"Apply these changes?",initialValue:!0});if(Xs.isCancel(T)||!T)return await y(),f.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"}}return f.done("Changes applied"),jc(m,i)}t.md||f.spin("Syncing project...");let d=await rs.sync(e,{full:t.full});if(!d.success)return t.md?console.log(G("## Sync Failed",`> ${d.error||"Unknown error"}`)):f.fail(d.error||"Sync failed"),{success:!1,error:d.error};if(t.md||f.stop(),t.md){let m=Date.now()-i,p=d.generatedSkills?.generated?.length??0,g=null;try{let v=await nt.diff(r);v?.hasChanges&&(g=Wa(v))}catch{}let y=d.git.recentCommits[0]?.hash??null,j=y&&wt.isCurrent(r,y),T=null;if(!j)try{let v=await Ya(r,e,d.git,d.stats);T=["## Analysis Payload","> Analyze this project data. Return JSON matching the schema.","### Schema","```",tg,"```","### Data","```json",JSON.stringify(v),"```","> Save: `prjct analysis-save-llm '<JSON>' --md`"].join(`
927
+ `)}catch{T="### Next: Run `prjct analysis-payload --md` to update project analysis"}let x=qo("sync",!0),S=d.syncMetrics?.indexes,w={Duration:`${(m/1e3).toFixed(1)}s`,Skills:`${p} generated`,"Files indexed":d.stats.fileCount};if(S?.bm25Files){let v=S.bm25Files*(S.bm25AvgTokens||0);w["Tokens indexed"]=`${Math.round(v/1e3)}K`,w["Import edges"]=S.importEdges||0,w["Co-change commits"]=S.cochangeCommits||0}let P=G(Ce("Sync Complete"),Hs(w),g,d.git.hasChanges?Gp("Uncommitted changes detected"):null,T,qe(x.map(v=>({label:v.desc,command:v.cmd}))));return console.log(P),{success:!0,data:d,metrics:{elapsed:m,skillCount:p,fileCount:d.stats.fileCount}}}return jc(d,i)}catch(s){return t.md?console.log(G("## Sync Failed",`> ${k(s)}`)):f.fail(k(s)),{success:!1,error:k(s)}}}async analysisPayload(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await rs.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&&wt.isCurrent(r,i))return t.md?console.log(G(Ce("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 Ya(r,e,o.git,o.stats);return t.md?console.log(G("## Analysis Payload","> Analyze this project data. Return JSON matching the schema.","### Schema","```",tg,"```","### Data","```json",JSON.stringify(a),"```","> Save: `prjct analysis-save-llm '<JSON>' --md`")):console.log(JSON.stringify({success:!0,payload:a})),{success:!0,data:a}}catch(s){return{success:!1,error:k(s)}}}async regenVault(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await import("node:fs/promises"),i=(await Promise.resolve().then(()=>(Re(),gu))).default,c=await(await Promise.resolve().then(()=>(de(),ur))).default.readConfig(e).catch(()=>null),d=`${i.getWikiPath(e,c?.vaultPath)}/_generated`;await o.rm(d,{recursive:!0,force:!0});let{generateWiki:m}=await Promise.resolve().then(()=>(as(),Vs)),p=await m(e,r);return t.md?console.log(`---
928
928
 
929
929
  ## Vault regenerated
930
930
 
@@ -934,18 +934,18 @@ ${Vd(g)}`);let T=await Xs.confirm({message:"Apply these changes?",initialValue:!
934
934
  | Files written | ${p.filesWritten} |
935
935
  | Files skipped | ${p.filesSkipped} |
936
936
  | Files removed | ${p.filesRemoved} |
937
- `):console.log(JSON.stringify({success:!0,message:"Vault regenerated",...p})),{success:!0}}catch(s){return{success:!1,error:k(s)}}}async saveLlmAnalysis(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await I.getProjectId(t);if(!o)return{success:!1,error:"No project ID found"};let i=JSON.parse(e);if(!i.version||!i.architecture||!i.patterns)return{success:!1,error:"Invalid LLM analysis format. Missing required fields."};wt.save(o,i);let{regenerateWikiDeferred:a}=await Promise.resolve().then(()=>(is(),Vs));return await a(t,o),s.md?console.log(G(Ce("LLM Analysis Saved"),Hs({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(r){return{success:!1,error:k(r)}}}async getLlmAnalysis(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=wt.getActive(r);if(!o)return t.md?console.log(G("## 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=[Ce(`LLM Analysis (${o.architecture.style})`),""];if(o.architecture.insights.length>0&&i.push(le("Architecture Insights",$e(o.architecture.insights.slice(0,5)))),o.patterns.length>0){let a=o.patterns.slice(0,8);i.push(le(`Patterns (${o.patterns.length})`,$e(a.map(c=>`**${c.name}** \u2014 ${c.description} (${c.category})`))))}if(o.antiPatterns.length>0){let a=o.antiPatterns.slice(0,5);i.push(le(`Anti-Patterns (${o.antiPatterns.length})`,$e(a.map(c=>`[${c.severity}] ${c.issue} \u2014 ${c.suggestion}`))))}if(o.techDebt.length>0){let a=o.techDebt.slice(0,5);i.push(le(`Tech Debt (${o.techDebt.length})`,$e(a.map(c=>`[${c.priority}/${c.effort}] ${c.description}`))))}o.conventions.length>0&&i.push(le("Conventions",$e(o.conventions.slice(0,5).map(a=>`**${a.category}**: ${a.rule}`)))),console.log(G(...i))}else{let i={...o,patterns:o.patterns.slice(0,10),antiPatterns:o.antiPatterns.slice(0,6),techDebt:o.techDebt.slice(0,6),conventions:o.conventions.slice(0,6)};console.log(JSON.stringify({success:!0,analysis:i}))}return{success:!0,data:o}}catch(s){return{success:!1,error:k(s)}}}async stats(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await es.getSummary(r),i=await es.getDailyStats(r,30),a=await zp(r),c={decisions:0,preferences:0,workflows:0,learnedDecisions:0};if(t.json){let p={session:a,patterns:c,totalTokensSaved:o.totalTokensSaved,estimatedCostSaved:o.estimatedCostSaved,compressionRate:o.compressionRate,syncCount:o.syncCount,avgSyncDuration:o.avgSyncDuration,topAgents:o.topAgents.slice(0,5),last30DaysTokens:o.last30DaysTokens,trend:o.trend,dailyStats:i.slice(0,7)};return console.log(JSON.stringify(p)),{success:!0,data:p}}let u="Unknown";try{u=C.getDoc(r,"project")?.name||"Unknown"}catch{}let d=await es.read(r),m=d.firstSync?new Date(d.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 p=a.agentsUsed.slice(0,3).map(g=>`${g.name} (${g.count}\xD7)`).join(", ");console.log(` Agents used: ${p}`)}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: ${jn(o.totalTokensSaved)} tokens`),console.log(` Compression: ${(o.compressionRate*100).toFixed(0)}% average reduction`),console.log(` Estimated cost: ${po(o.estimatedCostSaved)} saved`),console.log(""),console.log("\u26A1 PERFORMANCE"),console.log(` Syncs completed: ${o.syncCount.toLocaleString()}`),console.log(` Avg sync time: ${Pc(o.avgSyncDuration)}`),console.log(""),o.topAgents.length>0){console.log("\u{1F916} AGENT USAGE (all time)");let p=o.topAgents.reduce((g,y)=>g+y.usageCount,0);for(let g of o.topAgents){let y=p>0?(g.usageCount/p*100).toFixed(0):0;console.log(` ${g.agentName.padEnd(12)}: ${y}% (${g.usageCount} uses)`)}console.log("")}if(i.length>0){console.log("\u{1F4C8} TREND (last 30 days)");let p=Xp(i);if(console.log(` ${p} ${jn(o.last30DaysTokens)} tokens saved`),o.trend!==0){let g=o.trend>0?"\u2191":"\u2193",y=o.trend>0?"+":"";console.log(` ${g} ${y}${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 p=Kp(o,i,u,m,a,c);return console.log(p),{success:!0,data:{markdown:p}}}return{success:!0,data:{...o,session:a,patterns:c}}}catch(s){return console.error("\u274C Error:",k(s)),{success:!1,error:k(s)}}}async diff(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await st.diff(r);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(G("## 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(G(Ua(o))),{success:!0,data:o};if(!o.hasChanges)f.done("No changes between draft and sealed analysis");else{f.section("Analysis Diff"),console.log(xd(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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):t.md?console.log(G("## Diff Failed",`> ${r}`)):f.fail(r),{success:!1,error:r}}}async seal(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await st.seal(r);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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):f.fail(r),{success:!1,error:r}}}async rollback(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await st.rollback(r);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(G(Ce("Analysis Rolled Back"),Hs({"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(G("## 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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):t.md?console.log(G("## Rollback Failed",`> ${r}`)):f.fail(r),{success:!1,error:r}}}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 r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await st.verify(r);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 r=k(s);return f.fail(r),{success:!1,error:r}}}async semanticVerify(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)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(r,"project")?.repoPath||e}catch{}let i=await st.semanticVerify(r,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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):f.fail(r),{success:!1,error:r}}}}});function kS(n){if(!n)return{};let e={};for(let t of n.split(",")){let s=t.trim(),r=s.indexOf(":");r>0&&(e[s.slice(0,r)]=s.slice(r+1))}return e}var On,il=h(()=>{"use strict";os();ti();V();Me();bt();On=class extends we{static{l(this,"CaptureCommands")}async capture(e=null,t=process.cwd(),s={}){try{if(!e||!e.trim())return f.info('Usage: prjct capture "<anything>" [--tags k:v,...]'),{success:!1,error:"Content required"};let r=e.trim(),o=Dn(r);if(o.length>0&&!s.force)return f.fail(`refusing to capture content that looks like a secret (${o.join(", ")}). Re-run with --force if intentional.`),{success:!1,error:"Secret-like content detected"};let i=kS(s.tags),a=await this.ensureProjectInit(t);if(!a.success)return a;await Ve.remember(t,{type:"inbox",content:r,tags:i,provenance:"declared"});let c=r.length>60?`${r.slice(0,57)}\u2026`:r;return s.md?console.log(`\u2713 captured: ${c}`):f.done(`captured: ${c}`),{success:!0,type:"inbox",content:r,tags:i}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}};l(kS,"parseFlagTags")});var ng={};W(ng,{ContextCommands:()=>bs,contextCommands:()=>sg,default:()=>bS});import vS from"node:fs/promises";import SS from"node:path";var bs,sg,bS,di=h(()=>{"use strict";de();Re();rt();V();xr();bs=class{static{l(this,"ContextCommands")}async context(e=null,t=process.cwd(),s={}){try{let r=await I.readConfig(t);if(!r||!r.projectId)return console.log(JSON.stringify({projectId:"",globalPath:"",currentTask:null,domains:[],primaryDomain:null,subtasks:null,repoAnalysis:{ecosystem:"unknown",frameworks:[],hasTests:!1,technologies:[]}})),{success:!1,message:"No prjct project. Run `prjct init` first."};let o=r.projectId,i=$.getGlobalProjectPath(o),a=await D.read(o),c=a?.currentTask?{id:a.currentTask.id,description:a.currentTask.description,startedAt:a.currentTask.startedAt,subtasks:a.currentTask.subtasks?.map(m=>({id:m.id,description:m.description,status:m.status,domain:m.domain})),currentSubtaskIndex:a.currentTask.currentSubtaskIndex}:null,u=await this.loadRepoAnalysis(i),d={projectId:o,globalPath:i,currentTask:c,domains:[],primaryDomain:null,subtasks:null,repoAnalysis:{ecosystem:u?.ecosystem||"unknown",frameworks:u?.frameworks||[],hasTests:u?.hasTests||!1,technologies:u?.technologies||[]}};return s.md?console.log(this.formatContextMd(d)):console.log(JSON.stringify(d)),{success:!0,message:""}}catch(r){return{success:!1,message:`Context error: ${k(r)}`}}}formatContextMd(e){let t=[];if(t.push(le("Project",Ec(Tc("ID",e.projectId),Tc("Path",e.globalPath)))),e.currentTask){let s=e.currentTask;if(t.push(Rr({description:s.description,status:"in-progress"})),s.subtasks&&s.subtasks.length>0){let r=s.subtasks.map(o=>`- [${o.status==="completed"?"x":" "}] ${o.description}${o.domain?` (${o.domain})`:""}`);t.push(r.join(`
938
- `))}}else t.push("> No active task");return e.repoAnalysis&&t.push(le("Stack",Hs({Ecosystem:e.repoAnalysis.ecosystem,Frameworks:e.repoAnalysis.frameworks.join(", ")||"none",Tests:e.repoAnalysis.hasTests?"yes":"no",Tech:e.repoAnalysis.technologies.join(", ")||"none"}))),G(...t)}async loadRepoAnalysis(e){try{let t=SS.join(e,"analysis","repo-analysis.json"),s=await vS.readFile(t,"utf-8"),r=JSON.parse(s);return{ecosystem:r.ecosystem||"unknown",frameworks:r.frameworks||[],hasTests:r.hasTests??!1,technologies:r.technologies||[]}}catch(t){return _(t),null}}},sg=new bs,bS=sg});import al from"node:fs/promises";import TS from"node:os";import og from"node:path";function Ln(){let n=process.env.HOME||TS.homedir();return og.join(n,".claude","settings.json")}async function cl(){try{let n=await al.readFile(Ln(),"utf-8"),e=JSON.parse(n);return e&&typeof e=="object"?e:{}}catch(n){if(n.code==="ENOENT")return{};throw n}}async function ag(n){await al.mkdir(og.dirname(Ln()),{recursive:!0}),await al.writeFile(Ln(),`${JSON.stringify(n,null,2)}
939
- `,"utf-8")}function cg(n){return`${process.env.PRJCT_BIN??"prjct"} hook ${n}`}function ll(n){return n[ig]===!0}function rg(n){let e={type:"command",command:cg(n.subcommand),[ig]:!0};return"ifClause"in n&&n.ifClause&&(e.if=n.ifClause),e}async function lg(){let n=await cl(),e=n.hooks??{},t=0,s=0;for(let r of pi){let o=e[r.event]??[],i=cg(r.subcommand),a=o.find(u=>(u.matcher??"")===r.matcher);a||(a={matcher:r.matcher,hooks:[]},o.push(a));let c=a.hooks.find(u=>ll(u));if(c){let u=rg(r);c.command===u.command&&c.if===u.if?s++:(c.command=u.command,c.if=u.if,t++)}else a.hooks.push(rg(r)),t++;e[r.event]=o}return n.hooks=e,await ag(n),{settingsPath:Ln(),hooksWritten:t,alreadyPresent:s}}async function ug(){let n=await cl();if(!n.hooks)return{settingsPath:Ln(),hooksRemoved:0};let e=0;for(let[t,s]of Object.entries(n.hooks)){let r=[];for(let o of s){let i=o.hooks.filter(a=>ll(a)?(e++,!1):!0);i.length>0&&r.push({...o,hooks:i})}r.length>0?n.hooks[t]=r:delete n.hooks[t]}return Object.keys(n.hooks).length===0&&delete n.hooks,await ag(n),{settingsPath:Ln(),hooksRemoved:e}}async function dg(){let e=(await cl()).hooks??{},t=0;for(let s of Object.values(e))for(let r of s)for(let o of r.hooks)ll(o)&&t++;return{installed:t,expected:pi.length}}var ig,pi,pg=h(()=>{"use strict";l(Ln,"settingsPath");ig="_prjctManaged",pi=[{event:"SessionStart",matcher:"",subcommand:"session-start"},{event:"UserPromptSubmit",matcher:"",subcommand:"prompt"},{event:"PreToolUse",matcher:"Bash",subcommand:"pre-commit",ifClause:"Bash(git commit *)"},{event:"PostToolUse",matcher:"Edit|Write",subcommand:"post-edit"},{event:"Stop",matcher:"",subcommand:"stop"},{event:"SubagentStart",matcher:"",subcommand:"subagent-start"},{event:"CwdChanged",matcher:"",subcommand:"cwd-changed"}];l(cl,"readSettings");l(ag,"writeSettings");l(cg,"hookCommand");l(ll,"isPrjctHook");l(rg,"hookEntryFor");l(lg,"install");l(ug,"uninstall");l(dg,"status")});var ul={};W(ul,{InstallCommands:()=>Ys});var Ys,_r=h(()=>{"use strict";pg();V();Me();bt();Ys=class extends we{static{l(this,"InstallCommands")}async install(e=null,t=process.cwd(),s={}){try{let r=await lg(),o=pi.length,i=`installed ${r.hooksWritten} new, ${r.alreadyPresent} already present (total ${o} hooks)`;return s.md?console.log(["# prjct hooks installed","",`Wrote to \`${r.settingsPath}\`.`,"",`- new: ${r.hooksWritten}`,`- already present: ${r.alreadyPresent}`,`- total expected: ${o}`,"","> Only `_prjctManaged: true` entries were touched. Your other hooks are untouched."].join(`
937
+ `):console.log(JSON.stringify({success:!0,message:"Vault regenerated",...p})),{success:!0}}catch(s){return{success:!1,error:k(s)}}}async saveLlmAnalysis(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await I.getProjectId(t);if(!o)return{success:!1,error:"No project ID found"};let i=JSON.parse(e);if(!i.version||!i.architecture||!i.patterns)return{success:!1,error:"Invalid LLM analysis format. Missing required fields."};wt.save(o,i);let{regenerateWikiDeferred:a}=await Promise.resolve().then(()=>(as(),Vs));return await a(t,o),s.md?console.log(G(Ce("LLM Analysis Saved"),Hs({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(r){return{success:!1,error:k(r)}}}async getLlmAnalysis(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=wt.getActive(r);if(!o)return t.md?console.log(G("## 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=[Ce(`LLM Analysis (${o.architecture.style})`),""];if(o.architecture.insights.length>0&&i.push(le("Architecture Insights",$e(o.architecture.insights.slice(0,5)))),o.patterns.length>0){let a=o.patterns.slice(0,8);i.push(le(`Patterns (${o.patterns.length})`,$e(a.map(c=>`**${c.name}** \u2014 ${c.description} (${c.category})`))))}if(o.antiPatterns.length>0){let a=o.antiPatterns.slice(0,5);i.push(le(`Anti-Patterns (${o.antiPatterns.length})`,$e(a.map(c=>`[${c.severity}] ${c.issue} \u2014 ${c.suggestion}`))))}if(o.techDebt.length>0){let a=o.techDebt.slice(0,5);i.push(le(`Tech Debt (${o.techDebt.length})`,$e(a.map(c=>`[${c.priority}/${c.effort}] ${c.description}`))))}o.conventions.length>0&&i.push(le("Conventions",$e(o.conventions.slice(0,5).map(a=>`**${a.category}**: ${a.rule}`)))),console.log(G(...i))}else{let i={...o,patterns:o.patterns.slice(0,10),antiPatterns:o.antiPatterns.slice(0,6),techDebt:o.techDebt.slice(0,6),conventions:o.conventions.slice(0,6)};console.log(JSON.stringify({success:!0,analysis:i}))}return{success:!0,data:o}}catch(s){return{success:!1,error:k(s)}}}async stats(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await ts.getSummary(r),i=await ts.getDailyStats(r,30),a=await zp(r),c={decisions:0,preferences:0,workflows:0,learnedDecisions:0};if(t.json){let p={session:a,patterns:c,totalTokensSaved:o.totalTokensSaved,estimatedCostSaved:o.estimatedCostSaved,compressionRate:o.compressionRate,syncCount:o.syncCount,avgSyncDuration:o.avgSyncDuration,topAgents:o.topAgents.slice(0,5),last30DaysTokens:o.last30DaysTokens,trend:o.trend,dailyStats:i.slice(0,7)};return console.log(JSON.stringify(p)),{success:!0,data:p}}let u="Unknown";try{u=C.getDoc(r,"project")?.name||"Unknown"}catch{}let d=await ts.read(r),m=d.firstSync?new Date(d.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 p=a.agentsUsed.slice(0,3).map(g=>`${g.name} (${g.count}\xD7)`).join(", ");console.log(` Agents used: ${p}`)}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: ${jn(o.totalTokensSaved)} tokens`),console.log(` Compression: ${(o.compressionRate*100).toFixed(0)}% average reduction`),console.log(` Estimated cost: ${mo(o.estimatedCostSaved)} saved`),console.log(""),console.log("\u26A1 PERFORMANCE"),console.log(` Syncs completed: ${o.syncCount.toLocaleString()}`),console.log(` Avg sync time: ${Rc(o.avgSyncDuration)}`),console.log(""),o.topAgents.length>0){console.log("\u{1F916} AGENT USAGE (all time)");let p=o.topAgents.reduce((g,y)=>g+y.usageCount,0);for(let g of o.topAgents){let y=p>0?(g.usageCount/p*100).toFixed(0):0;console.log(` ${g.agentName.padEnd(12)}: ${y}% (${g.usageCount} uses)`)}console.log("")}if(i.length>0){console.log("\u{1F4C8} TREND (last 30 days)");let p=Xp(i);if(console.log(` ${p} ${jn(o.last30DaysTokens)} tokens saved`),o.trend!==0){let g=o.trend>0?"\u2191":"\u2193",y=o.trend>0?"+":"";console.log(` ${g} ${y}${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 p=Kp(o,i,u,m,a,c);return console.log(p),{success:!0,data:{markdown:p}}}return{success:!0,data:{...o,session:a,patterns:c}}}catch(s){return console.error("\u274C Error:",k(s)),{success:!1,error:k(s)}}}async diff(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await nt.diff(r);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(G("## 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(G(Wa(o))),{success:!0,data:o};if(!o.hasChanges)f.done("No changes between draft and sealed analysis");else{f.section("Analysis Diff"),console.log(xd(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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):t.md?console.log(G("## Diff Failed",`> ${r}`)):f.fail(r),{success:!1,error:r}}}async seal(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await nt.seal(r);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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):f.fail(r),{success:!1,error:r}}}async rollback(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await nt.rollback(r);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(G(Ce("Analysis Rolled Back"),Hs({"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(G("## 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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):t.md?console.log(G("## Rollback Failed",`> ${r}`)):f.fail(r),{success:!1,error:r}}}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 r=await I.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await nt.verify(r);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 r=k(s);return f.fail(r),{success:!1,error:r}}}async semanticVerify(e=process.cwd(),t={}){try{let s=await this.ensureProjectInit(e);if(!s.success)return s;let r=await I.getProjectId(e);if(!r)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(r,"project")?.repoPath||e}catch{}let i=await nt.semanticVerify(r,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 r=k(s);return t.json?console.log(JSON.stringify({success:!1,error:r})):f.fail(r),{success:!1,error:r}}}}});function vS(n){if(!n)return{};let e={};for(let t of n.split(",")){let s=t.trim(),r=s.indexOf(":");r>0&&(e[s.slice(0,r)]=s.slice(r+1))}return e}var On,cl=h(()=>{"use strict";is();si();V();Me();bt();On=class extends we{static{l(this,"CaptureCommands")}async capture(e=null,t=process.cwd(),s={}){try{if(!e||!e.trim())return f.info('Usage: prjct capture "<anything>" [--tags k:v,...]'),{success:!1,error:"Content required"};let r=e.trim(),o=Dn(r);if(o.length>0&&!s.force)return f.fail(`refusing to capture content that looks like a secret (${o.join(", ")}). Re-run with --force if intentional.`),{success:!1,error:"Secret-like content detected"};let i=vS(s.tags),a=await this.ensureProjectInit(t);if(!a.success)return a;await Ve.remember(t,{type:"inbox",content:r,tags:i,provenance:"declared"});let c=r.length>60?`${r.slice(0,57)}\u2026`:r;return s.md?console.log(`\u2713 captured: ${c}`):f.done(`captured: ${c}`),{success:!0,type:"inbox",content:r,tags:i}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}};l(vS,"parseFlagTags")});var ng={};W(ng,{ContextCommands:()=>bs,contextCommands:()=>sg,default:()=>TS});import SS from"node:fs/promises";import bS from"node:path";var bs,sg,TS,pi=h(()=>{"use strict";de();Re();ot();V();xr();bs=class{static{l(this,"ContextCommands")}async context(e=null,t=process.cwd(),s={}){try{let r=await I.readConfig(t);if(!r||!r.projectId)return console.log(JSON.stringify({projectId:"",globalPath:"",currentTask:null,domains:[],primaryDomain:null,subtasks:null,repoAnalysis:{ecosystem:"unknown",frameworks:[],hasTests:!1,technologies:[]}})),{success:!1,message:"No prjct project. Run `prjct init` first."};let o=r.projectId,i=$.getGlobalProjectPath(o),a=await D.read(o),c=a?.currentTask?{id:a.currentTask.id,description:a.currentTask.description,startedAt:a.currentTask.startedAt,subtasks:a.currentTask.subtasks?.map(m=>({id:m.id,description:m.description,status:m.status,domain:m.domain})),currentSubtaskIndex:a.currentTask.currentSubtaskIndex}:null,u=await this.loadRepoAnalysis(i),d={projectId:o,globalPath:i,currentTask:c,domains:[],primaryDomain:null,subtasks:null,repoAnalysis:{ecosystem:u?.ecosystem||"unknown",frameworks:u?.frameworks||[],hasTests:u?.hasTests||!1,technologies:u?.technologies||[]}};return s.md?console.log(this.formatContextMd(d)):console.log(JSON.stringify(d)),{success:!0,message:""}}catch(r){return{success:!1,message:`Context error: ${k(r)}`}}}formatContextMd(e){let t=[];if(t.push(le("Project",Pc(Cc("ID",e.projectId),Cc("Path",e.globalPath)))),e.currentTask){let s=e.currentTask;if(t.push(Rr({description:s.description,status:"in-progress"})),s.subtasks&&s.subtasks.length>0){let r=s.subtasks.map(o=>`- [${o.status==="completed"?"x":" "}] ${o.description}${o.domain?` (${o.domain})`:""}`);t.push(r.join(`
938
+ `))}}else t.push("> No active task");return e.repoAnalysis&&t.push(le("Stack",Hs({Ecosystem:e.repoAnalysis.ecosystem,Frameworks:e.repoAnalysis.frameworks.join(", ")||"none",Tests:e.repoAnalysis.hasTests?"yes":"no",Tech:e.repoAnalysis.technologies.join(", ")||"none"}))),G(...t)}async loadRepoAnalysis(e){try{let t=bS.join(e,"analysis","repo-analysis.json"),s=await SS.readFile(t,"utf-8"),r=JSON.parse(s);return{ecosystem:r.ecosystem||"unknown",frameworks:r.frameworks||[],hasTests:r.hasTests??!1,technologies:r.technologies||[]}}catch(t){return _(t),null}}},sg=new bs,TS=sg});import ll from"node:fs/promises";import ES from"node:os";import og from"node:path";function Ln(){let n=process.env.HOME||ES.homedir();return og.join(n,".claude","settings.json")}async function ul(){try{let n=await ll.readFile(Ln(),"utf-8"),e=JSON.parse(n);return e&&typeof e=="object"?e:{}}catch(n){if(n.code==="ENOENT")return{};throw n}}async function ag(n){await ll.mkdir(og.dirname(Ln()),{recursive:!0}),await ll.writeFile(Ln(),`${JSON.stringify(n,null,2)}
939
+ `,"utf-8")}function cg(n){return`${process.env.PRJCT_BIN??"prjct"} hook ${n}`}function dl(n){return n[ig]===!0}function rg(n){let e={type:"command",command:cg(n.subcommand),[ig]:!0};return"ifClause"in n&&n.ifClause&&(e.if=n.ifClause),e}async function lg(){let n=await ul(),e=n.hooks??{},t=0,s=0;for(let r of mi){let o=e[r.event]??[],i=cg(r.subcommand),a=o.find(u=>(u.matcher??"")===r.matcher);a||(a={matcher:r.matcher,hooks:[]},o.push(a));let c=a.hooks.find(u=>dl(u));if(c){let u=rg(r);c.command===u.command&&c.if===u.if?s++:(c.command=u.command,c.if=u.if,t++)}else a.hooks.push(rg(r)),t++;e[r.event]=o}return n.hooks=e,await ag(n),{settingsPath:Ln(),hooksWritten:t,alreadyPresent:s}}async function ug(){let n=await ul();if(!n.hooks)return{settingsPath:Ln(),hooksRemoved:0};let e=0;for(let[t,s]of Object.entries(n.hooks)){let r=[];for(let o of s){let i=o.hooks.filter(a=>dl(a)?(e++,!1):!0);i.length>0&&r.push({...o,hooks:i})}r.length>0?n.hooks[t]=r:delete n.hooks[t]}return Object.keys(n.hooks).length===0&&delete n.hooks,await ag(n),{settingsPath:Ln(),hooksRemoved:e}}async function dg(){let e=(await ul()).hooks??{},t=0;for(let s of Object.values(e))for(let r of s)for(let o of r.hooks)dl(o)&&t++;return{installed:t,expected:mi.length}}var ig,mi,pg=h(()=>{"use strict";l(Ln,"settingsPath");ig="_prjctManaged",mi=[{event:"SessionStart",matcher:"",subcommand:"session-start"},{event:"UserPromptSubmit",matcher:"",subcommand:"prompt"},{event:"PreToolUse",matcher:"Bash",subcommand:"pre-commit",ifClause:"Bash(git commit *)"},{event:"PostToolUse",matcher:"Edit|Write",subcommand:"post-edit"},{event:"Stop",matcher:"",subcommand:"stop"},{event:"SubagentStart",matcher:"",subcommand:"subagent-start"},{event:"CwdChanged",matcher:"",subcommand:"cwd-changed"}];l(ul,"readSettings");l(ag,"writeSettings");l(cg,"hookCommand");l(dl,"isPrjctHook");l(rg,"hookEntryFor");l(lg,"install");l(ug,"uninstall");l(dg,"status")});var pl={};W(pl,{InstallCommands:()=>Ys});var Ys,_r=h(()=>{"use strict";pg();V();Me();bt();Ys=class extends we{static{l(this,"InstallCommands")}async install(e=null,t=process.cwd(),s={}){try{let r=await lg(),o=mi.length,i=`installed ${r.hooksWritten} new, ${r.alreadyPresent} already present (total ${o} hooks)`;return s.md?console.log(["# prjct hooks installed","",`Wrote to \`${r.settingsPath}\`.`,"",`- new: ${r.hooksWritten}`,`- already present: ${r.alreadyPresent}`,`- total expected: ${o}`,"","> Only `_prjctManaged: true` entries were touched. Your other hooks are untouched."].join(`
940
940
  `)):(f.done(i),f.info(`settings: ${r.settingsPath}`)),{success:!0,hooksWritten:r.hooksWritten}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async uninstall(e=null,t=process.cwd(),s={}){try{let r=await ug(),o=`removed ${r.hooksRemoved} prjct hook(s)`;return s.md?console.log(`# prjct hooks removed
941
941
 
942
942
  - removed: ${r.hooksRemoved}
943
943
  - settings: \`${r.settingsPath}\`
944
- `):f.done(o),{success:!0,hooksRemoved:r.hooksRemoved}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async status(e=null,t=process.cwd()){try{let s=await dg();return{success:!0,installed:s.installed,expected:s.expected}}catch(s){return{success:!1,error:k(s)}}}}});async function mi(n){let e=await I.getProjectId(n);return e?{ok:!0,value:e}:(f.failWithHint("NO_PROJECT_ID"),{ok:!1,result:{success:!1,error:"No project ID found"}})}async function dl(n,e={}){let t=await D.getCurrentTask(n);if(!t){let s='No active task \u2014 start one with `prjct task "<desc>"`';return e.md?console.log(`> ${s}`):f.warn("no active task"),{ok:!1,result:{success:!1,error:s}}}return{ok:!0,value:t}}var mg=h(()=>{"use strict";de();rt();Me();l(mi,"requireProjectId");l(dl,"requireActiveTask")});function CS(n){let e=n.split(/\s+/).map(t=>t.trim()).filter(Boolean).map(t=>{let s=t.indexOf(":");return s<=0?null:[t.slice(0,s),t.slice(s+1)]}).filter(t=>t!==null);return Object.fromEntries(e)}function PS(n){if(!n)return{};let e={};for(let t of n.split(",")){let s=t.trim(),r=s.indexOf(":");r>0&&(e[s.slice(0,r)]=s.slice(r+1))}return e}function jS(n){let e=n.trim(),t=e.search(/\s/);if(t<=0)return{ok:!1,error:'expected `<type> "<content>"`'};let s=e.slice(0,t).toLowerCase().trim();if(!s||!/^[a-z][a-z0-9-]*$/.test(s))return{ok:!1,error:`invalid type '${s}'. Lowercase letters + dashes only. Base types: ${$n.join(", ")}`};let r=s,o=e.slice(t+1).trim();return(o.startsWith('"')&&o.endsWith('"')||o.startsWith("'")&&o.endsWith("'"))&&(o=o.slice(1,-1)),o?{ok:!0,type:r,content:o}:{ok:!1,error:"content is required"}}async function RS(n,e){try{let{default:t}=await Promise.resolve().then(()=>(ce(),Tu)),s=t.query(n,"SELECT data FROM events WHERE type = ? ORDER BY id DESC LIMIT 10",`memory.${xn}`);for(let r of s)try{let o=JSON.parse(r.data);if(o.taskId===e&&o.to)return o.to}catch{}}catch{}return null}var ES,Fn,pl=h(()=>{"use strict";Yo();os();ti();ks();rt();V();Me();bt();mg();ES=["feature","bug","improvement","chore"],Fn=class extends we{static{l(this,"PrimitiveCommands")}async status(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await mi(t);if(!o.ok)return o.result;if(e!==null&&["active","resume","in_progress","working"].includes(e.toLowerCase())&&!await D.getCurrentTask(o.value)){let g=await D.resumeTask(o.value);if(g){await Ye.log(t,xn,{taskId:g.id,from:"paused",to:e});let y=`status \u2192 ${e}`;return s.md?console.log(`\u2713 ${y}`):f.done(y),{success:!0,taskId:g.id,status:e}}}if(!e&&!await D.getCurrentTask(o.value)){let g=await D.getPausedTasks(o.value);if(g.length>0){let y=g[0],j=`Task: ${y.id} | Type: ${y.type??"unset"} | Status: paused`;return s.md?console.log(j):f.info(j),{success:!0,taskId:y.id,status:"paused"}}}let a=await dl(o.value,s);if(!a.ok)return a.result;let c=a.value,u=await RS(o.value,c.id);if(!e){let p=`Task: ${c.id} | Type: ${c.type??"unset"} | Status: ${u??"active"}`;return s.md?console.log(p):f.info(p),{success:!0,taskId:c.id,status:u??"active"}}await Ye.log(t,xn,{taskId:c.id,from:u??null,to:e});let d=e.toLowerCase();try{d==="done"||d==="completed"?await D.completeTask(o.value):d==="paused"||d==="pause"?await D.pauseTask(o.value):(d==="active"||d==="resume"||d==="in_progress"||d==="working")&&(await D.getCurrentTask(o.value)||await D.resumeTask(o.value))}catch{}let m=`status \u2192 ${e}`;return s.md?console.log(`\u2713 ${m}`):f.done(m),{success:!0,taskId:c.id,status:e}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async tag(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await mi(t);if(!o.ok)return o.result;let i=await dl(o.value,s);if(!i.ok)return i.result;if(!e)return f.info("Usage: prjct tag <key:value> [<key:value>...]"),{success:!1,error:"No tags provided"};let a=CS(e);if(Object.keys(a).length===0)return f.fail("no valid k:v pairs (expected `key:value`)"),{success:!1,error:"Invalid tag format"};let c=a.type;c&&ES.includes(c)&&await D.updateCurrentTask(o.value,{type:c}),await Ye.log(t,"task.tagged",{taskId:i.value.id,tags:a});let u=Object.entries(a).map(([d,m])=>`${d}=${m}`).join(", ");return s.md?console.log(`\u2713 tagged ${u}`):f.done(`tagged ${u}`),{success:!0,taskId:i.value.id,tags:a}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async remember(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;if(!e)return f.info(`Usage: prjct remember <type> "<content>" [--tags k:v,...]
945
- Types: ${$n.join(" | ")}`),{success:!1,error:"Missing args"};let o=jS(e);if(!o.ok)return f.fail(o.error),{success:!1,error:o.error};let{type:i,content:a}=o,c=Dn(a);if(c.length>0&&!s.force){let g=c.join(", ");return f.fail(`refusing to store memory that looks like a secret (${g}). Re-run with --force if intentional.`),{success:!1,error:"Secret-like content detected"}}let u=PS(s.tags),d=await mi(t);if(!d.ok)return d.result;let m=await D.getCurrentTask(d.value);await Ve.remember(t,{type:i,content:a,tags:u,source:m?.id});let{regenerateWikiDeferred:p}=await Promise.resolve().then(()=>(is(),Vs));return await p(t,d.value),s.md?console.log(`\u2713 remembered ${i}: ${a}`):f.done(`remembered ${i}`),{success:!0,type:i,content:a,tags:u}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}};l(CS,"parseTagPairs");l(PS,"parseFlagTags");l(jS,"parseRememberArgs");l(RS,"readLastStatus")});var gg={};W(gg,{SeedCommands:()=>Qs});var Qs,gi=h(()=>{"use strict";Oc();Wc();V();Me();bt();Qs=class extends we{static{l(this,"SeedCommands")}async seed(e=null,t=process.cwd(),s={}){let r=(e??"").trim().split(/\s+/).filter(Boolean),o=r[0]??"list",i=r.slice(1).join(",");switch(o){case"add":return this.add(i||null,t,s);case"remove":return this.remove(i||null,t,s);case"list":return this.list(null,t,s);case"suggest":return this.suggest(null,t,s);default:return f.fail(`Unknown seed subcommand: ${o}. Use: add, remove, list, suggest.`),{success:!1,error:"Unknown seed subcommand"}}}async add(e=null,t=process.cwd(),s={}){try{if(!e)return f.info(`Usage: prjct seed add <pack>[,<pack>...]
946
- Available: ${Nc.join(", ")}`),{success:!1,error:"No pack given"};let r=e.split(",").map(a=>a.trim()).filter(Boolean),o=await Fc(t,r,{suggestPersona:s.suggestPersona??!1}),i=`activated: ${o.activated.join(", ")||"none"}${o.skipped.length?` \u2022 unknown: ${o.skipped.join(", ")}`:""}`;return s.md?console.log(`\u2713 ${i}`):f.done(i),{success:!0,...o}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async remove(e=null,t=process.cwd(),s={}){try{if(!e)return f.info("Usage: prjct seed remove <pack>[,<pack>...]"),{success:!1,error:"No pack given"};let r=e.split(",").map(a=>a.trim()).filter(Boolean),o=await Uc(t,r),i=`deactivated: ${o.deactivated.join(", ")||"none"}${o.notActive.length?` \u2022 not active: ${o.notActive.join(", ")}`:""}`;return s.md?console.log(`\u2713 ${i}`):f.done(i),{success:!0,...o}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async list(e=null,t=process.cwd(),s={}){try{let r=await Hc(t);if(r.length===0){let o=`no packs active. Run \`prjct seed add <name>\` \u2014 available: ${Nc.join(", ")}`;return s.md?console.log(`> ${o}`):f.info(o),{success:!0,active:[]}}if(s.md){let o=["# Active packs",""];for(let i of r)o.push(`## ${i.name}`),o.push(i.description),o.push(`- memory types: ${i.memoryTypes.join(", ")||"\u2014"}`),o.push(`- workflow slots: ${i.slots.join(", ")||"\u2014"}`),o.push("");console.log(o.join(`
947
- `))}else for(let o of r)f.info(`${o.name}: ${o.description}`),f.info(` memory: ${o.memoryTypes.join(", ")||"\u2014"}`),f.info(` slots: ${o.slots.join(", ")||"\u2014"}`);return{success:!0,active:r}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async suggest(e=null,t=process.cwd(),s={}){try{let r=await Lc(t),o=r.map(i=>{let a=Gs[i];return{name:i,description:a?.description??""}});if(s.md){let i=["# Suggested packs for this project",""];for(let a of o)i.push(`- **${a.name}** \u2014 ${a.description}`);i.push(""),i.push(`Activate with: \`prjct seed add ${r.join(",")}\``),console.log(i.join(`
948
- `))}else f.info(`Suggested: ${r.join(", ")}`),f.info(`Activate: prjct seed add ${r.join(",")}`);return{success:!0,suggested:r}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}}});import xS from"node:fs/promises";import AS from"node:path";var hg,fg,ml,IS,nt,fi=h(()=>{"use strict";Re();J();hg="https://api.prjct.app",fg={apiKey:null,apiUrl:hg,userId:null,email:null,lastAuth:null},ml=class{static{l(this,"AuthConfigManager")}configPath;cachedConfig=null;constructor(){this.configPath=$.getAuthConfigPath()}getConfigPath(){return this.configPath}async read(){if(this.cachedConfig)return this.cachedConfig;let e=await Se(this.configPath);return this.cachedConfig=e??{...fg},this.cachedConfig}async write(e){let s={...await this.read(),...e,lastAuth:new Date().toISOString()};await Pt(AS.dirname(this.configPath)),await ie(this.configPath,s),await xS.chmod(this.configPath,384),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||hg}async saveAuth(e,t,s){await this.write({apiKey:e,userId:t,email:s})}async clearAuth(){this.cachedConfig={...fg},await ie(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}},IS=new ml,nt=IS});function DS(n){return n.replace(/[A-Z]/g,e=>`_${e.toLowerCase()}`)}function MS(n){let e={};for(let[t,s]of Object.entries(n))e[DS(t)]=s;return e}function _S(n,e){let[t,s]=e.type.split("."),r=$S[t];if(!r)return null;let i=s==="deleted"?"delete":"upsert",a=e.data||{},c=MS(a),u=c.id||a.id||"";return{event_type:i,entity_type:r,entity_id:u,data:{...c,project_id:n},project_id:n}}function yg(n,e){return e.map(t=>_S(n,t)).filter(t=>t!==null)}var $S,wg=h(()=>{"use strict";$S={task:"tasks",idea:"ideas",feature:"roadmap_features",shipped:"shipped_items",queue:"queue_tasks",project:"projects",session:"sessions",agent:"agents"};l(DS,"camelToSnake");l(MS,"snakeCaseKeys");l(_S,"mapCliEventToWebFormat");l(yg,"mapCliEventsToWebFormat")});var gl,Un,fl=h(()=>{"use strict";wo();fi();wg();gl=class{static{l(this,"SyncClient")}retryConfig={maxRetries:3,baseDelayMs:1e3,maxDelayMs:3e4};async pushEvents(e,t){let{apiUrl:s,apiKey:r}=await this.getAuthHeaders();if(!r)throw this.createError("AUTH_REQUIRED","No API key configured");let o=yg(e,t),i=await this.fetchWithRetry(`${s}/sync/batch`,{method:"POST",headers:{"Content-Type":"application/json","X-Api-Key":r},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:r}=await this.getAuthHeaders();if(!r)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":r},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 r=await this.fetchWithRetry(`${t}/sync/status/${e}`,{method:"GET",headers:{"X-Api-Key":s}});if(!r.ok)throw await this.parseErrorResponse(r);return await r.json()}async testConnection(){let e=new AbortController,t=setTimeout(()=>e.abort(),fn("API_REQUEST"));try{let{apiUrl:s,apiKey:r}=await this.getAuthHeaders();if(!r)return clearTimeout(t),!1;let o=await fetch(`${s}/health`,{method:"GET",headers:{"X-Api-Key":r},signal:e.signal});return clearTimeout(t),o.ok}catch{return clearTimeout(t),!1}}async hasAuth(){return await nt.hasAuth()}async getAuthHeaders(){let[e,t]=await Promise.all([nt.getApiUrl(),nt.getApiKey()]);return{apiUrl:e,apiKey:t}}async fetchWithRetry(e,t,s=0){let r=new AbortController,o=setTimeout(()=>r.abort(),fn("API_REQUEST"));try{let i=await fetch(e,{...t,signal:r.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: ${fn("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))}},Un=new gl});var hl,NS,kg,vg=h(()=>{"use strict";ta();pr();mr();Ds();rt();fi();fl();hl=class{static{l(this,"SyncManager")}async hasAuth(){return await nt.hasAuth()}async getStatus(e){if(!await this.hasAuth())return null;try{return await Un.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 r=await this.pull(e);return r.success&&!r.skipped&&(t.pulled={count:r.count||0,syncedAt:r.syncedAt||new Date().toISOString()}),(!s.success||!r.success)&&(t.success=!1,t.error=s.error||r.error),t}async push(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};try{let t=await gs.getPending(e);if(t.length===0)return{success:!0,skipped:!0,reason:"no_pending"};let s=await this.createProjectLinkEvent(e),r=s?[s,...t]:t,o=await Un.pushEvents(e,r);if(o.success)return await gs.clearPending(e),await gs.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 gs.getLastSync(e))?.timestamp,r=await Un.pullEvents(e,s);if(r.events.length===0)return{success:!0,skipped:!1,count:0,applied:0,syncedAt:r.syncedAt};let o=await this.applyPulledEvents(e,r.events);return await gs.updateLastSync(e),{success:!0,skipped:!1,count:r.events.length,applied:o,syncedAt:r.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 r of t)try{await this.applyEvent(e,r),s++}catch(o){let i=r.entity_type||r.type||"unknown";console.error(`Failed to apply event ${i}:`,o)}return s}async applyEvent(e,t){let s,r,o;if(t.entity_type)s=t.entity_type,r=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,r=a==="deleted"?"delete":"upsert",o=t.data||{}}if(r!=="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 D.update(e,r=>!r.currentTask||t.id!==r.currentTask.id?{...r,currentTask:{id:t.id,description:t.description,startedAt:t.started_at||t.startedAt,sessionId:t.session_id||t.sessionId||""}}:r):s==="completed"?await D.update(e,r=>r.currentTask?.id===t.id?{...r,currentTask:null}:r):await Fe.addTask(e,{description:t.description,priority:t.priority||"medium",type:t.type||"feature",section:"backlog"})}async applyIdeaUpsert(e,t){(t.status||"active")==="archived"?await Le.update(e,r=>({...r,ideas:r.ideas.map(o=>o.id===t.id?{...o,status:"archived"}:o)})):await Le.addIdea(e,t.title||t.text||"",{priority:t.priority||"medium"})}async applyShippedUpsert(e,t){await Ke.addShipped(e,{name:t.name||t.title||"",version:t.version||"",description:t.description||""})}async applyQueueUpsert(e,t){await Fe.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}}},NS=new hl,kg=NS});import Sg from"node:fs";import hi from"node:path";function OS(n){if(Rs()){let{Database:r}=Je("bun:sqlite");return new r(n,{create:!0})}let e=Je("better-sqlite3"),t=new e(n),s=t.exec.bind(t);return t.run=r=>s(r),t}var yl,LS,bg=h(()=>{"use strict";tr();l(OS,"openDatabase");yl=class{static{l(this,"SystemDatabase")}db=null;dbPath;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim(),t=e?hi.resolve(e):hi.join(Je("node:os").homedir(),".prjct-cli");this.dbPath=hi.join(t,"system.db")}getDb(){if(this.db)return this.db;let e=hi.dirname(this.dbPath);Sg.existsSync(e)||Sg.mkdirSync(e,{recursive:!0});let t=OS(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(`
944
+ `):f.done(o),{success:!0,hooksRemoved:r.hooksRemoved}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async status(e=null,t=process.cwd()){try{let s=await dg();return{success:!0,installed:s.installed,expected:s.expected}}catch(s){return{success:!1,error:k(s)}}}}});async function gi(n){let e=await I.getProjectId(n);return e?{ok:!0,value:e}:(f.failWithHint("NO_PROJECT_ID"),{ok:!1,result:{success:!1,error:"No project ID found"}})}async function ml(n,e={}){let t=await D.getCurrentTask(n);if(!t){let s='No active task \u2014 start one with `prjct task "<desc>"`';return e.md?console.log(`> ${s}`):f.warn("no active task"),{ok:!1,result:{success:!1,error:s}}}return{ok:!0,value:t}}var mg=h(()=>{"use strict";de();ot();Me();l(gi,"requireProjectId");l(ml,"requireActiveTask")});function PS(n){let e=n.split(/\s+/).map(t=>t.trim()).filter(Boolean).map(t=>{let s=t.indexOf(":");return s<=0?null:[t.slice(0,s),t.slice(s+1)]}).filter(t=>t!==null);return Object.fromEntries(e)}function jS(n){if(!n)return{};let e={};for(let t of n.split(",")){let s=t.trim(),r=s.indexOf(":");r>0&&(e[s.slice(0,r)]=s.slice(r+1))}return e}function RS(n){let e=n.trim(),t=e.search(/\s/);if(t<=0)return{ok:!1,error:'expected `<type> "<content>"`'};let s=e.slice(0,t).toLowerCase().trim();if(!s||!/^[a-z][a-z0-9-]*$/.test(s))return{ok:!1,error:`invalid type '${s}'. Lowercase letters + dashes only. Base types: ${$n.join(", ")}`};let r=s,o=e.slice(t+1).trim();return(o.startsWith('"')&&o.endsWith('"')||o.startsWith("'")&&o.endsWith("'"))&&(o=o.slice(1,-1)),o?{ok:!0,type:r,content:o}:{ok:!1,error:"content is required"}}async function xS(n,e){try{let{default:t}=await Promise.resolve().then(()=>(ce(),Tu)),s=t.query(n,"SELECT data FROM events WHERE type = ? ORDER BY id DESC LIMIT 10",`memory.${xn}`);for(let r of s)try{let o=JSON.parse(r.data);if(o.taskId===e&&o.to)return o.to}catch{}}catch{}return null}var CS,Fn,gl=h(()=>{"use strict";Qo();is();si();ks();ot();V();Me();bt();mg();CS=["feature","bug","improvement","chore"],Fn=class extends we{static{l(this,"PrimitiveCommands")}async status(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await gi(t);if(!o.ok)return o.result;if(e!==null&&["active","resume","in_progress","working"].includes(e.toLowerCase())&&!await D.getCurrentTask(o.value)){let g=await D.resumeTask(o.value);if(g){await Ye.log(t,xn,{taskId:g.id,from:"paused",to:e});let y=`status \u2192 ${e}`;return s.md?console.log(`\u2713 ${y}`):f.done(y),{success:!0,taskId:g.id,status:e}}}if(!e&&!await D.getCurrentTask(o.value)){let g=await D.getPausedTasks(o.value);if(g.length>0){let y=g[0],j=`Task: ${y.id} | Type: ${y.type??"unset"} | Status: paused`;return s.md?console.log(j):f.info(j),{success:!0,taskId:y.id,status:"paused"}}}let a=await ml(o.value,s);if(!a.ok)return a.result;let c=a.value,u=await xS(o.value,c.id);if(!e){let p=`Task: ${c.id} | Type: ${c.type??"unset"} | Status: ${u??"active"}`;return s.md?console.log(p):f.info(p),{success:!0,taskId:c.id,status:u??"active"}}await Ye.log(t,xn,{taskId:c.id,from:u??null,to:e});let d=e.toLowerCase();try{d==="done"||d==="completed"?await D.completeTask(o.value):d==="paused"||d==="pause"?await D.pauseTask(o.value):(d==="active"||d==="resume"||d==="in_progress"||d==="working")&&(await D.getCurrentTask(o.value)||await D.resumeTask(o.value))}catch{}let m=`status \u2192 ${e}`;return s.md?console.log(`\u2713 ${m}`):f.done(m),{success:!0,taskId:c.id,status:e}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async tag(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await gi(t);if(!o.ok)return o.result;let i=await ml(o.value,s);if(!i.ok)return i.result;if(!e)return f.info("Usage: prjct tag <key:value> [<key:value>...]"),{success:!1,error:"No tags provided"};let a=PS(e);if(Object.keys(a).length===0)return f.fail("no valid k:v pairs (expected `key:value`)"),{success:!1,error:"Invalid tag format"};let c=a.type;c&&CS.includes(c)&&await D.updateCurrentTask(o.value,{type:c}),await Ye.log(t,"task.tagged",{taskId:i.value.id,tags:a});let u=Object.entries(a).map(([d,m])=>`${d}=${m}`).join(", ");return s.md?console.log(`\u2713 tagged ${u}`):f.done(`tagged ${u}`),{success:!0,taskId:i.value.id,tags:a}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async remember(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;if(!e)return f.info(`Usage: prjct remember <type> "<content>" [--tags k:v,...]
945
+ Types: ${$n.join(" | ")}`),{success:!1,error:"Missing args"};let o=RS(e);if(!o.ok)return f.fail(o.error),{success:!1,error:o.error};let{type:i,content:a}=o,c=Dn(a);if(c.length>0&&!s.force){let g=c.join(", ");return f.fail(`refusing to store memory that looks like a secret (${g}). Re-run with --force if intentional.`),{success:!1,error:"Secret-like content detected"}}let u=jS(s.tags),d=await gi(t);if(!d.ok)return d.result;let m=await D.getCurrentTask(d.value);await Ve.remember(t,{type:i,content:a,tags:u,source:m?.id});let{regenerateWikiDeferred:p}=await Promise.resolve().then(()=>(as(),Vs));return await p(t,d.value),s.md?console.log(`\u2713 remembered ${i}: ${a}`):f.done(`remembered ${i}`),{success:!0,type:i,content:a,tags:u}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}};l(PS,"parseTagPairs");l(jS,"parseFlagTags");l(RS,"parseRememberArgs");l(xS,"readLastStatus")});var gg={};W(gg,{SeedCommands:()=>Qs});var Qs,fi=h(()=>{"use strict";Fc();qc();V();Me();bt();Qs=class extends we{static{l(this,"SeedCommands")}async seed(e=null,t=process.cwd(),s={}){let r=(e??"").trim().split(/\s+/).filter(Boolean),o=r[0]??"list",i=r.slice(1).join(",");switch(o){case"add":return this.add(i||null,t,s);case"remove":return this.remove(i||null,t,s);case"list":return this.list(null,t,s);case"suggest":return this.suggest(null,t,s);default:return f.fail(`Unknown seed subcommand: ${o}. Use: add, remove, list, suggest.`),{success:!1,error:"Unknown seed subcommand"}}}async add(e=null,t=process.cwd(),s={}){try{if(!e)return f.info(`Usage: prjct seed add <pack>[,<pack>...]
946
+ Available: ${Lc.join(", ")}`),{success:!1,error:"No pack given"};let r=e.split(",").map(a=>a.trim()).filter(Boolean),o=await Hc(t,r,{suggestPersona:s.suggestPersona??!1}),i=`activated: ${o.activated.join(", ")||"none"}${o.skipped.length?` \u2022 unknown: ${o.skipped.join(", ")}`:""}`;return s.md?console.log(`\u2713 ${i}`):f.done(i),{success:!0,...o}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async remove(e=null,t=process.cwd(),s={}){try{if(!e)return f.info("Usage: prjct seed remove <pack>[,<pack>...]"),{success:!1,error:"No pack given"};let r=e.split(",").map(a=>a.trim()).filter(Boolean),o=await Wc(t,r),i=`deactivated: ${o.deactivated.join(", ")||"none"}${o.notActive.length?` \u2022 not active: ${o.notActive.join(", ")}`:""}`;return s.md?console.log(`\u2713 ${i}`):f.done(i),{success:!0,...o}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async list(e=null,t=process.cwd(),s={}){try{let r=await Gc(t);if(r.length===0){let o=`no packs active. Run \`prjct seed add <name>\` \u2014 available: ${Lc.join(", ")}`;return s.md?console.log(`> ${o}`):f.info(o),{success:!0,active:[]}}if(s.md){let o=["# Active packs",""];for(let i of r)o.push(`## ${i.name}`),o.push(i.description),o.push(`- memory types: ${i.memoryTypes.join(", ")||"\u2014"}`),o.push(`- workflow slots: ${i.slots.join(", ")||"\u2014"}`),o.push("");console.log(o.join(`
947
+ `))}else for(let o of r)f.info(`${o.name}: ${o.description}`),f.info(` memory: ${o.memoryTypes.join(", ")||"\u2014"}`),f.info(` slots: ${o.slots.join(", ")||"\u2014"}`);return{success:!0,active:r}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}async suggest(e=null,t=process.cwd(),s={}){try{let r=await Uc(t),o=r.map(i=>{let a=Gs[i];return{name:i,description:a?.description??""}});if(s.md){let i=["# Suggested packs for this project",""];for(let a of o)i.push(`- **${a.name}** \u2014 ${a.description}`);i.push(""),i.push(`Activate with: \`prjct seed add ${r.join(",")}\``),console.log(i.join(`
948
+ `))}else f.info(`Suggested: ${r.join(", ")}`),f.info(`Activate: prjct seed add ${r.join(",")}`);return{success:!0,suggested:r}}catch(r){let o=k(r);return f.fail(o),{success:!1,error:o}}}}});import AS from"node:fs/promises";import IS from"node:path";var hg,fg,fl,$S,rt,hi=h(()=>{"use strict";Re();J();hg="https://api.prjct.app",fg={apiKey:null,apiUrl:hg,userId:null,email:null,lastAuth:null},fl=class{static{l(this,"AuthConfigManager")}configPath;cachedConfig=null;constructor(){this.configPath=$.getAuthConfigPath()}getConfigPath(){return this.configPath}async read(){if(this.cachedConfig)return this.cachedConfig;let e=await Se(this.configPath);return this.cachedConfig=e??{...fg},this.cachedConfig}async write(e){let s={...await this.read(),...e,lastAuth:new Date().toISOString()};await Pt(IS.dirname(this.configPath)),await ie(this.configPath,s),await AS.chmod(this.configPath,384),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||hg}async saveAuth(e,t,s){await this.write({apiKey:e,userId:t,email:s})}async clearAuth(){this.cachedConfig={...fg},await ie(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}},$S=new fl,rt=$S});function MS(n){return n.replace(/[A-Z]/g,e=>`_${e.toLowerCase()}`)}function _S(n){let e={};for(let[t,s]of Object.entries(n))e[MS(t)]=s;return e}function NS(n,e){let[t,s]=e.type.split("."),r=DS[t];if(!r)return null;let i=s==="deleted"?"delete":"upsert",a=e.data||{},c=_S(a),u=c.id||a.id||"";return{event_type:i,entity_type:r,entity_id:u,data:{...c,project_id:n},project_id:n}}function yg(n,e){return e.map(t=>NS(n,t)).filter(t=>t!==null)}var DS,wg=h(()=>{"use strict";DS={task:"tasks",idea:"ideas",feature:"roadmap_features",shipped:"shipped_items",queue:"queue_tasks",project:"projects",session:"sessions",agent:"agents"};l(MS,"camelToSnake");l(_S,"snakeCaseKeys");l(NS,"mapCliEventToWebFormat");l(yg,"mapCliEventsToWebFormat")});var hl,Un,yl=h(()=>{"use strict";ko();hi();wg();hl=class{static{l(this,"SyncClient")}retryConfig={maxRetries:3,baseDelayMs:1e3,maxDelayMs:3e4};async pushEvents(e,t){let{apiUrl:s,apiKey:r}=await this.getAuthHeaders();if(!r)throw this.createError("AUTH_REQUIRED","No API key configured");let o=yg(e,t),i=await this.fetchWithRetry(`${s}/sync/batch`,{method:"POST",headers:{"Content-Type":"application/json","X-Api-Key":r},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:r}=await this.getAuthHeaders();if(!r)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":r},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 r=await this.fetchWithRetry(`${t}/sync/status/${e}`,{method:"GET",headers:{"X-Api-Key":s}});if(!r.ok)throw await this.parseErrorResponse(r);return await r.json()}async testConnection(){let e=new AbortController,t=setTimeout(()=>e.abort(),fn("API_REQUEST"));try{let{apiUrl:s,apiKey:r}=await this.getAuthHeaders();if(!r)return clearTimeout(t),!1;let o=await fetch(`${s}/health`,{method:"GET",headers:{"X-Api-Key":r},signal:e.signal});return clearTimeout(t),o.ok}catch{return clearTimeout(t),!1}}async hasAuth(){return await rt.hasAuth()}async getAuthHeaders(){let[e,t]=await Promise.all([rt.getApiUrl(),rt.getApiKey()]);return{apiUrl:e,apiKey:t}}async fetchWithRetry(e,t,s=0){let r=new AbortController,o=setTimeout(()=>r.abort(),fn("API_REQUEST"));try{let i=await fetch(e,{...t,signal:r.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: ${fn("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))}},Un=new hl});var wl,OS,kg,vg=h(()=>{"use strict";na();pr();mr();Ds();ot();hi();yl();wl=class{static{l(this,"SyncManager")}async hasAuth(){return await rt.hasAuth()}async getStatus(e){if(!await this.hasAuth())return null;try{return await Un.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 r=await this.pull(e);return r.success&&!r.skipped&&(t.pulled={count:r.count||0,syncedAt:r.syncedAt||new Date().toISOString()}),(!s.success||!r.success)&&(t.success=!1,t.error=s.error||r.error),t}async push(e){if(!await this.hasAuth())return{success:!0,skipped:!0,reason:"no_auth"};try{let t=await gs.getPending(e);if(t.length===0)return{success:!0,skipped:!0,reason:"no_pending"};let s=await this.createProjectLinkEvent(e),r=s?[s,...t]:t,o=await Un.pushEvents(e,r);if(o.success)return await gs.clearPending(e),await gs.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 gs.getLastSync(e))?.timestamp,r=await Un.pullEvents(e,s);if(r.events.length===0)return{success:!0,skipped:!1,count:0,applied:0,syncedAt:r.syncedAt};let o=await this.applyPulledEvents(e,r.events);return await gs.updateLastSync(e),{success:!0,skipped:!1,count:r.events.length,applied:o,syncedAt:r.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 r of t)try{await this.applyEvent(e,r),s++}catch(o){let i=r.entity_type||r.type||"unknown";console.error(`Failed to apply event ${i}:`,o)}return s}async applyEvent(e,t){let s,r,o;if(t.entity_type)s=t.entity_type,r=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,r=a==="deleted"?"delete":"upsert",o=t.data||{}}if(r!=="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 D.update(e,r=>!r.currentTask||t.id!==r.currentTask.id?{...r,currentTask:{id:t.id,description:t.description,startedAt:t.started_at||t.startedAt,sessionId:t.session_id||t.sessionId||""}}:r):s==="completed"?await D.update(e,r=>r.currentTask?.id===t.id?{...r,currentTask:null}:r):await Fe.addTask(e,{description:t.description,priority:t.priority||"medium",type:t.type||"feature",section:"backlog"})}async applyIdeaUpsert(e,t){(t.status||"active")==="archived"?await Le.update(e,r=>({...r,ideas:r.ideas.map(o=>o.id===t.id?{...o,status:"archived"}:o)})):await Le.addIdea(e,t.title||t.text||"",{priority:t.priority||"medium"})}async applyShippedUpsert(e,t){await Ke.addShipped(e,{name:t.name||t.title||"",version:t.version||"",description:t.description||""})}async applyQueueUpsert(e,t){await Fe.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}}},OS=new wl,kg=OS});import Sg from"node:fs";import yi from"node:path";function LS(n){if(Rs()){let{Database:r}=Je("bun:sqlite");return new r(n,{create:!0})}let e=Je("better-sqlite3"),t=new e(n),s=t.exec.bind(t);return t.run=r=>s(r),t}var kl,FS,bg=h(()=>{"use strict";tr();l(LS,"openDatabase");kl=class{static{l(this,"SystemDatabase")}db=null;dbPath;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim(),t=e?yi.resolve(e):yi.join(Je("node:os").homedir(),".prjct-cli");this.dbPath=yi.join(t,"system.db")}getDb(){if(this.db)return this.db;let e=yi.dirname(this.dbPath);Sg.existsSync(e)||Sg.mkdirSync(e,{recursive:!0});let t=LS(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(`
949
949
  CREATE TABLE IF NOT EXISTS _system_migrations (
950
950
  version INTEGER PRIMARY KEY,
951
951
  name TEXT NOT NULL,
@@ -966,30 +966,30 @@ Available: ${Nc.join(", ")}`),{success:!1,error:"No pack given"};let r=e.split("
966
966
  INSERT OR REPLACE INTO mcp_health
967
967
  (provider, status, last_checked, last_error, token_version, config_valid, oauth_valid, updated_at)
968
968
  VALUES (?, ?, ?, ?, ?, ?, ?, ?)
969
- `).run(e,t.status,r,t.lastError??null,t.tokenVersion??null,t.configValid?1:0,t.oauthValid?1:0,r)}clearMcpHealth(e){this.getDb().prepare("DELETE FROM mcp_health WHERE provider = ?").run(e)}close(){this.db&&(this.db.close(),this.db=null)}},LS=new yl});import FS from"node:fs/promises";import Tg from"node:os";import yi from"node:path";function US(){try{let n=yi.dirname(Je.resolve("prjct-cli/package.json"));return{command:"node",args:[yi.join(n,"dist","mcp","server.mjs")],description:"prjct data layer (memories, analysis, files, workflows)"}}catch{return{command:"npx",args:["-y","prjct-cli","mcp"],description:"prjct data layer (memories, analysis, files, workflows)"}}}function Zs(){return process.env.PRJCT_TEST_MODE==="1"?yi.join(Tg.tmpdir(),"prjct-context7-test","mcp.json"):yi.join(Tg.homedir(),".claude","mcp.json")}async function Eg(n=Zs()){try{let e=await FS.readFile(n,"utf-8");return JSON.parse(e)}catch(e){let t=k(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${n}: ${k(e)}`)}}async function HS(n,e=Zs()){await ie(e,n)}async function kl(n,e,t=Zs()){let s=await Eg(t),r={...s.mcpServers||{}},o=r[n];r[n]=e,s.mcpServers=r;let i=JSON.stringify(o)!==JSON.stringify(e);return await HS(s,t),{path:t,changed:i}}async function vl(n,e=Zs()){return!!(await Eg(e)).mcpServers?.[n]}var wi,wl,TN,Cg=h(()=>{"use strict";bg();V();J();wi="mcp-remote@0.1.38";l(US,"getPrjctMcpConfig");wl={prjct:US(),linear:{command:"npx",args:["-y",wi,"https://mcp.linear.app/mcp"],description:"Linear MCP server (OAuth)"},jira:{command:"npx",args:["-y",wi,"https://mcp.atlassian.com/v1/mcp"],description:"Atlassian MCP server for Jira (OAuth)"}},TN={linear:`npx -y ${wi} https://mcp.linear.app/mcp`,jira:`npx -y ${wi} https://mcp.atlassian.com/v1/mcp`};l(Zs,"getClaudeMcpConfigPath");l(Eg,"readMcpConfig");l(HS,"writeMcpConfig");l(kl,"upsertMcpServer");l(vl,"hasMcpServer")});import WS from"node:fs/promises";import GS from"node:http";import qS from"node:path";import Z from"chalk";var Hn,Sl=h(()=>{"use strict";Wt();de();Re();Er();fi();fl();vg();V();Ze();J();Cg();Me();ze();bt();Hn=class extends we{static{l(this,"SetupCommands")}async auth(e=null,t={}){let s=e?.split(" ")[0]||"status",r=e?.split(" ").slice(1)||[];switch(s){case"login":{let o=r[0];if(!o)return t.md||f.fail("Usage: prjct login [--url <url>]"),{success:!1,message:t.md?"## Error\nUsage: `prjct login [--url <url>]`":""};let i,a=r.indexOf("--url");return a!==-1&&r[a+1]&&(i=r[a+1]),await nt.write({apiKey:o,...i?{apiUrl:i}:{}}),await Un.testConnection()?(t.md||(f.done("Connected! API key saved"),f.info(Z.dim(`Key: ${o.substring(0,12)}...`))),{success:!0,message:t.md?`## Auth
969
+ `).run(e,t.status,r,t.lastError??null,t.tokenVersion??null,t.configValid?1:0,t.oauthValid?1:0,r)}clearMcpHealth(e){this.getDb().prepare("DELETE FROM mcp_health WHERE provider = ?").run(e)}close(){this.db&&(this.db.close(),this.db=null)}},FS=new kl});import US from"node:fs/promises";import Tg from"node:os";import wi from"node:path";function HS(){try{let n=wi.dirname(Je.resolve("prjct-cli/package.json"));return{command:"node",args:[wi.join(n,"dist","mcp","server.mjs")],description:"prjct data layer (memories, analysis, files, workflows)"}}catch{return{command:"npx",args:["-y","prjct-cli","mcp"],description:"prjct data layer (memories, analysis, files, workflows)"}}}function Zs(){return process.env.PRJCT_TEST_MODE==="1"?wi.join(Tg.tmpdir(),"prjct-context7-test","mcp.json"):wi.join(Tg.homedir(),".claude","mcp.json")}async function Eg(n=Zs()){try{let e=await US.readFile(n,"utf-8");return JSON.parse(e)}catch(e){let t=k(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${n}: ${k(e)}`)}}async function WS(n,e=Zs()){await ie(e,n)}async function Sl(n,e,t=Zs()){let s=await Eg(t),r={...s.mcpServers||{}},o=r[n];r[n]=e,s.mcpServers=r;let i=JSON.stringify(o)!==JSON.stringify(e);return await WS(s,t),{path:t,changed:i}}async function bl(n,e=Zs()){return!!(await Eg(e)).mcpServers?.[n]}var ki,vl,EN,Cg=h(()=>{"use strict";bg();V();J();ki="mcp-remote@0.1.38";l(HS,"getPrjctMcpConfig");vl={prjct:HS(),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)"}},EN={linear:`npx -y ${ki} https://mcp.linear.app/mcp`,jira:`npx -y ${ki} https://mcp.atlassian.com/v1/mcp`};l(Zs,"getClaudeMcpConfigPath");l(Eg,"readMcpConfig");l(WS,"writeMcpConfig");l(Sl,"upsertMcpServer");l(bl,"hasMcpServer")});import GS from"node:fs/promises";import qS from"node:http";import VS from"node:path";import Z from"chalk";var Hn,Tl=h(()=>{"use strict";Wt();de();Re();Er();hi();yl();vg();V();Ze();J();Cg();Me();ze();bt();Hn=class extends we{static{l(this,"SetupCommands")}async auth(e=null,t={}){let s=e?.split(" ")[0]||"status",r=e?.split(" ").slice(1)||[];switch(s){case"login":{let o=r[0];if(!o)return t.md||f.fail("Usage: prjct login [--url <url>]"),{success:!1,message:t.md?"## Error\nUsage: `prjct login [--url <url>]`":""};let i,a=r.indexOf("--url");return a!==-1&&r[a+1]&&(i=r[a+1]),await rt.write({apiKey:o,...i?{apiUrl:i}:{}}),await Un.testConnection()?(t.md||(f.done("Connected! API key saved"),f.info(Z.dim(`Key: ${o.substring(0,12)}...`))),{success:!0,message:t.md?`## Auth
970
970
  - **Status**: Connected
971
971
  - **Key**: \`${o.substring(0,12)}...\`
972
972
  - **API**: ${i||"default"}`:""}):(t.md||(f.warn("API key saved, but server is unreachable"),f.info(Z.dim(`Key: ${o.substring(0,12)}...`)),f.info(Z.dim("The key will be used when the server becomes available"))),{success:!0,message:t.md?`## Auth
973
973
  - **Status**: Key saved (server unreachable)
974
- - **Key**: \`${o.substring(0,12)}...\``:""})}case"logout":return await nt.clearAuth(),t.md||f.done("Logged out. Auth credentials cleared"),{success:!0,message:t.md?`## Auth
975
- - **Status**: Logged out`:""};default:{let o=await nt.getStatus();return t.md?{success:!0,message:o.authenticated?`## Auth Status
974
+ - **Key**: \`${o.substring(0,12)}...\``:""})}case"logout":return await rt.clearAuth(),t.md||f.done("Logged out. Auth credentials cleared"),{success:!0,message:t.md?`## Auth
975
+ - **Status**: Logged out`:""};default:{let o=await rt.getStatus();return t.md?{success:!0,message:o.authenticated?`## Auth Status
976
976
  - **Authenticated**: Yes
977
977
  - **Email**: ${o.email||"N/A"}
978
978
  - **Key**: \`${o.apiKeyPrefix}\`
979
979
  - **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"}
980
980
  Key: ${o.apiKeyPrefix}
981
- Since: ${o.lastAuth||"N/A"}`):(f.info("Not authenticated"),f.info(`Run ${Z.cyan("prjct login")} to connect`)),{success:!0,message:""})}}}async login(e={}){let t=await nt.getStatus();if(t.authenticated)return e.md||(f.box("Already Authenticated",`Email: ${t.email}
981
+ Since: ${o.lastAuth||"N/A"}`):(f.info("Not authenticated"),f.info(`Run ${Z.cyan("prjct login")} to connect`)),{success:!0,message:""})}}}async login(e={}){let t=await rt.getStatus();if(t.authenticated)return e.md||(f.box("Already Authenticated",`Email: ${t.email}
982
982
  Key: ${t.apiKeyPrefix}`),f.info(`Run ${Z.cyan("prjct logout")} first to re-authenticate`)),{success:!0,message:e.md?`## Already Authenticated
983
983
  - **Email**: ${t.email}
984
984
  - **Key**: \`${t.apiKeyPrefix}\`
985
985
 
986
- Run \`prjct logout\` first to re-authenticate.`:""};let s=e.url||process.env.PRJCT_WEB_URL||"http://localhost:3000";return new Promise(r=>{let o=GS.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"),d=c.searchParams.get("email"),m=c.searchParams.get("user_id");if(u){await nt.saveAuth(u,m||"",d||"");let p=`${s}/api`;await nt.write({apiUrl:p}),a.writeHead(200,{"Content-Type":"text/html"}),a.end(this.buildSuccessPage(d||"",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: ${d}
986
+ Run \`prjct logout\` first to re-authenticate.`:""};let s=e.url||process.env.PRJCT_WEB_URL||"http://localhost:3000";return new Promise(r=>{let o=qS.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"),d=c.searchParams.get("email"),m=c.searchParams.get("user_id");if(u){await rt.saveAuth(u,m||"",d||"");let p=`${s}/api`;await rt.write({apiUrl:p}),a.writeHead(200,{"Content-Type":"text/html"}),a.end(this.buildSuccessPage(d||"",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: ${d}
987
987
  Key: ${u.substring(0,12)}...
988
988
  Status: Connected`)),await this.autoSync(),r({success:!0,message:e.md?`## Authenticated
989
989
  - **Email**: ${d}
990
990
  - **Key**: \`${u.substring(0,12)}...\``:""})):(e.md||f.fail("Authentication failed: no API key received"),r({success:!1,message:e.md?`## Error
991
991
  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"),r({success:!1,message:e.md?`## Error
992
- 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(Z.dim(c));let u=process.platform,d=u==="darwin"?`open "${c}"`:u==="win32"?`start "${c}"`:`xdg-open "${c}"`;try{await O(d)}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 ${Z.cyan("prjct login")} to try again`)),r({success:!1,message:e.md?"## Error\nAuthentication timed out. Run `prjct login` to try again.":""})},5*60*1e3)})}async logout(){return(await nt.getStatus()).authenticated?(await nt.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 kg.sync(e);if(f.stop(),t.success&&!t.skipped){let s=t.pushed?.count||0,r=t.pulled?.count||0;s>0||r>0?f.done(`Synced (${s} pushed, ${r} pulled)`):f.done("Synced \u2014 everything up to date")}}catch{f.stop()}}buildSuccessPage(e,t){return`<!DOCTYPE html>
992
+ 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(Z.dim(c));let u=process.platform,d=u==="darwin"?`open "${c}"`:u==="win32"?`start "${c}"`:`xdg-open "${c}"`;try{await O(d)}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 ${Z.cyan("prjct login")} to try again`)),r({success:!1,message:e.md?"## Error\nAuthentication timed out. Run `prjct login` to try again.":""})},5*60*1e3)})}async logout(){return(await rt.getStatus()).authenticated?(await rt.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 kg.sync(e);if(f.stop(),t.success&&!t.skipped){let s=t.pushed?.count||0,r=t.pulled?.count||0;s>0||r>0?f.done(`Synced (${s} pushed, ${r} pulled)`):f.done("Synced \u2014 everything up to date")}}catch{f.stop()}}buildSuccessPage(e,t){return`<!DOCTYPE html>
993
993
  <html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1">
994
994
  <title>prjct CLI Connected</title>
995
995
  <style>
@@ -1053,17 +1053,17 @@ Please install one first:
1053
1053
  - OpenAI Codex: https://github.com/openai/codex`};if(r){console.log("\u{1F4E6} Installing /p:* commands...");let a=await Te.installCommands();if(!a.success)return{success:!1,message:`\u274C Installation failed: ${a.error}`};if(console.log(`
1054
1054
  \u2705 Installed ${a.installed?.length??0} commands to:
1055
1055
  ${$.getDisplayPath(a.path||"")}`),(a.errors?.length??0)>0){console.log(`
1056
- \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(()=>(Cn(),No));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): ${k(a)}`)}return await this.setupMcpServers(),console.log(`
1056
+ \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(()=>(Cn(),Oo));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): ${k(a)}`)}return await this.setupMcpServers(),console.log(`
1057
1057
  \u{1F389} Setup complete!`),console.log(`
1058
1058
  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...
1059
1059
  `),e.force&&(console.log("\u{1F5D1}\uFE0F Removing existing installation..."),await Te.uninstallCommands()),console.log("\u{1F4E6} Installing /p:* commands...");let t=await Te.installCommands();if(!t.success)return{success:!1,message:`\u274C Setup failed: ${t.error}`};if(console.log(`
1060
1060
  \u2705 Installed ${t.installed?.length??0} commands`),(t.errors?.length??0)>0){console.log(`
1061
1061
  \u26A0\uFE0F ${t.errors?.length??0} errors:`);for(let c of t.errors??[])console.log(` - ${c.file}: ${c.error}`)}console.log(`
1062
1062
  \u{1F4DD} Installing global configuration...`);let s=await Te.installGlobalConfig(),r=s.path?$.getDisplayPath(s.path):"global config";s.success?s.action==="created"?console.log(`\u2705 Created ${r}`):s.action==="updated"?console.log(`\u2705 Updated ${r}`):s.action==="appended"&&console.log(`\u2705 Added prjct config to ${r}`):console.log(`\u26A0\uFE0F ${s.error}`);let o=(We(),ht(yt)),i=await o.getActiveProvider(),a=await o.detectCodex();if(i.name==="claude"){console.log(`
1063
- \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(()=>(Cn(),No));await c();let d=await u({autoRepair:!0});d.verified?(console.log("\u2705 Codex skill installed"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${d.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): ${k(c)}`)}return await this.setupMcpServers(),console.log(`
1063
+ \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(()=>(Cn(),Oo));await c();let d=await u({autoRepair:!0});d.verified?(console.log("\u2705 Codex skill installed"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${d.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): ${k(c)}`)}return await this.setupMcpServers(),console.log(`
1064
1064
  \u{1F389} Setup complete!
1065
1065
  `),this.showAsciiArt(),{success:!0,message:""}}async setupMcpServers(){console.log(`
1066
- \u{1F50C} Configuring MCP servers...`);try{await ss.install();let e=await ss.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: ${k(e)}`),console.log(" Run `prjct start` again to retry.")}try{let e=Zs();await vl("linear",e)?console.log("\u2705 Linear MCP already configured"):(await kl("linear",wl.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: ${k(e)}`),console.log(" Run `prjct linear setup` to configure manually.")}try{let e=Zs();await vl("jira",e)?console.log("\u2705 Jira MCP already configured"):(await kl("jira",wl.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: ${k(e)}`),console.log(" Run `prjct jira setup` to configure manually.")}}async installStatusLine(){try{let e=$.getClaudeDir(),t=$.getClaudeSettingsPath(),s=qS.join(e,"prjct-statusline.sh"),r=`#!/bin/bash
1066
+ \u{1F50C} Configuring MCP servers...`);try{await ns.install();let e=await ns.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: ${k(e)}`),console.log(" Run `prjct start` again to retry.")}try{let e=Zs();await bl("linear",e)?console.log("\u2705 Linear MCP already configured"):(await Sl("linear",vl.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: ${k(e)}`),console.log(" Run `prjct linear setup` to configure manually.")}try{let e=Zs();await bl("jira",e)?console.log("\u2705 Jira MCP already configured"):(await Sl("jira",vl.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: ${k(e)}`),console.log(" Run `prjct jira setup` to configure manually.")}}async installStatusLine(){try{let e=$.getClaudeDir(),t=$.getClaudeSettingsPath(),s=VS.join(e,"prjct-statusline.sh"),r=`#!/bin/bash
1067
1067
  # prjct Status Line for Claude Code
1068
1068
  # Shows version update notifications and current task
1069
1069
 
@@ -1119,11 +1119,11 @@ fi
1119
1119
 
1120
1120
  # Default: show prjct branding
1121
1121
  echo "\u26A1 prjct"
1122
- `;await WS.writeFile(s,r,{mode:493});let o={};if(await b(t))try{o=await Se(t)??{}}catch{}return o.statusLine={type:"command",command:s},await ie(t,o),{success:!0}}catch(e){return{success:!1,error:k(e)}}}showAsciiArt(){console.log(Z.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(Z.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(Z.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(Z.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(Z.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(Z.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(Z.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(` ${Z.bold.cyan("prjct")}${Z.magenta("/")}${Z.green("cli")} ${Z.dim.white(`v${ae} installed`)}`),console.log(""),console.log(` ${Z.yellow("\u26A1")} Ship faster with zero friction`),console.log(` ${Z.green("\u{1F4DD}")} From idea to technical tasks in minutes`),console.log(` ${Z.cyan("\u{1F916}")} Perfect context for AI agents`),console.log(""),console.log(Z.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(Z.bold.cyan("\u{1F680} Quick Start")),console.log(Z.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(` ${Z.bold("1.")} Initialize your project:`),console.log(` ${Z.green("cd your-project && prjct init")}`),console.log(""),console.log(` ${Z.bold("2.")} Start your first task:`),console.log(` ${Z.green('prjct task "build auth"')}`),console.log(""),console.log(` ${Z.bold("3.")} Ship & celebrate:`),console.log(` ${Z.green('prjct ship "user login"')}`),console.log(""),console.log(Z.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(` ${Z.dim("Documentation:")} ${Z.cyan("https://prjct.app")}`),console.log(` ${Z.dim("Report issues:")} ${Z.cyan("https://github.com/jlopezlira/prjct-cli/issues")}`),console.log(""),console.log(Z.bold.magenta("Happy shipping! \u{1F680}")),console.log("")}}});import{execSync as Gn}from"node:child_process";import bl from"node:fs/promises";import Nr from"node:path";import Wn from"chalk";function Pg(){try{return!!Gn("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})}catch{return!1}}function jg(){try{let e=Gn("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}}var qn,Tl=h(()=>{"use strict";Wt();ro();Re();xc();uc();V();Me();ze();bt();l(Pg,"isHomebrewInstall");l(jg,"getCurrentVersion");qn=class extends we{static{l(this,"UpdateCommands")}async update(e={},t=process.cwd()){let s=e["dry-run"]===!0,r=e.md===!0,o={phase1:{success:!0,details:[],errors:[]},phase2:{success:!0,details:[],errors:[]},phase3:{success:!0,details:[],errors:[]}};try{if(r||f.step(1,3,"Updating package..."),o.phase1=await this.phasePackageUpdate(s),r||f.stop(),!s&&o.phase1.success&&this.redirectToInstalledPackage(),r||f.step(2,3,"Cleaning up all projects..."),o.phase2=await this.phaseGlobalCleanup(s),r||f.stop(),r||f.step(3,3,"Restarting daemon..."),o.phase3=await this.phaseDaemonRestart(s),r||f.stop(),!s){try{await dr.updateVersion(ae)}catch{}try{await new qo().writeCache({lastCheck:0,latestVersion:""})}catch{}}return r?this.formatMdOutput(o,s):this.formatTerminalOutput(o,s)}catch(i){return r||f.stop(),f.fail(k(i)),{success:!1,error:k(i)}}}async phasePackageUpdate(e){let t={success:!0,details:[],errors:[]},s=jg();if(e)return Pg()?(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(Pg()){try{Gn("brew uninstall prjct-cli 2>/dev/null",{stdio:"pipe"}),t.details.push("Uninstalled homebrew formula")}catch{t.details.push("Homebrew uninstall skipped (not found)")}Gn("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("Installed via npm")}else Gn("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("npm install complete");let o=jg();s&&o&&s!==o?t.details.push(`${s} \u2192 ${o}`):o&&t.details.push(`v${o} (already latest)`)}catch(r){t.success=!1,t.errors.push(k(r))}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 r=0,o=0;for(let i of s)if(!e)try{let a=await Oo(i),c=await Lo(i);if(r+=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)}: ${k(a)}`)}if(e)t.details.push(`Would migrate ${s.length} project(s)`);else{let i=[`${s.length} project(s) checked`];r>0&&i.push(`${r} 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 Ht().cleanupAllLegacy();o.cleaned.length>0&&t.details.push(`Cleaned ${o.cleaned.length} legacy artifact(s)`)}catch(r){t.errors.push(`Legacy cleanup: ${k(r)}`)}try{let o=await new Ht().installCommands();t.details.push(`Editor commands reinstalled (${o.installed?.length||0} providers)`)}catch(r){t.errors.push(`Commands: ${k(r)}`)}try{await new Ht().installGlobalConfig(),t.details.push("Global config updated (prjct section replaced)")}catch(r){t.errors.push(`Global config: ${k(r)}`)}try{let{detectAllProviders:r}=await Promise.resolve().then(()=>(We(),yt)),o=await r(),i=Nr.join(Je("node:os").homedir());if(o.gemini.installed){let a=Nr.join(i,".gemini","GEMINI.md");try{let c=await bl.readFile(a,"utf-8"),u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",d="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(c.includes(u)&&c.includes(d)){let{getTemplateContent:m}=await Promise.resolve().then(()=>(Fs(),Oa)),p=m("global/GEMINI.md");if(p?.includes(u)&&p.includes(d)){let g=p.substring(p.indexOf(u),p.indexOf(d)+d.length),y=c.substring(0,c.indexOf(u)),j=c.substring(c.indexOf(d)+d.length),T=y+g+j,x="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",S="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->";if(T.includes(x)&&T.includes(S)){let w=T.substring(0,T.indexOf(x)),P=T.substring(T.indexOf(S)+S.length);T=`${(w+P).replace(/\n{3,}/g,`
1122
+ `;await GS.writeFile(s,r,{mode:493});let o={};if(await b(t))try{o=await Se(t)??{}}catch{}return o.statusLine={type:"command",command:s},await ie(t,o),{success:!0}}catch(e){return{success:!1,error:k(e)}}}showAsciiArt(){console.log(Z.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(Z.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(Z.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(Z.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(Z.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(Z.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(Z.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(` ${Z.bold.cyan("prjct")}${Z.magenta("/")}${Z.green("cli")} ${Z.dim.white(`v${ae} installed`)}`),console.log(""),console.log(` ${Z.yellow("\u26A1")} Ship faster with zero friction`),console.log(` ${Z.green("\u{1F4DD}")} From idea to technical tasks in minutes`),console.log(` ${Z.cyan("\u{1F916}")} Perfect context for AI agents`),console.log(""),console.log(Z.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(Z.bold.cyan("\u{1F680} Quick Start")),console.log(Z.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(` ${Z.bold("1.")} Initialize your project:`),console.log(` ${Z.green("cd your-project && prjct init")}`),console.log(""),console.log(` ${Z.bold("2.")} Start your first task:`),console.log(` ${Z.green('prjct task "build auth"')}`),console.log(""),console.log(` ${Z.bold("3.")} Ship & celebrate:`),console.log(` ${Z.green('prjct ship "user login"')}`),console.log(""),console.log(Z.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(` ${Z.dim("Documentation:")} ${Z.cyan("https://prjct.app")}`),console.log(` ${Z.dim("Report issues:")} ${Z.cyan("https://github.com/jlopezlira/prjct-cli/issues")}`),console.log(""),console.log(Z.bold.magenta("Happy shipping! \u{1F680}")),console.log("")}}});import{execSync as Gn}from"node:child_process";import El from"node:fs/promises";import Nr from"node:path";import Wn from"chalk";function Pg(){try{return!!Gn("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})}catch{return!1}}function jg(){try{let e=Gn("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}}var qn,Cl=h(()=>{"use strict";Wt();oo();Re();Ic();pc();V();Me();ze();bt();l(Pg,"isHomebrewInstall");l(jg,"getCurrentVersion");qn=class extends we{static{l(this,"UpdateCommands")}async update(e={},t=process.cwd()){let s=e["dry-run"]===!0,r=e.md===!0,o={phase1:{success:!0,details:[],errors:[]},phase2:{success:!0,details:[],errors:[]},phase3:{success:!0,details:[],errors:[]}};try{if(r||f.step(1,3,"Updating package..."),o.phase1=await this.phasePackageUpdate(s),r||f.stop(),!s&&o.phase1.success&&this.redirectToInstalledPackage(),r||f.step(2,3,"Cleaning up all projects..."),o.phase2=await this.phaseGlobalCleanup(s),r||f.stop(),r||f.step(3,3,"Restarting daemon..."),o.phase3=await this.phaseDaemonRestart(s),r||f.stop(),!s){try{await dr.updateVersion(ae)}catch{}try{await new Vo().writeCache({lastCheck:0,latestVersion:""})}catch{}}return r?this.formatMdOutput(o,s):this.formatTerminalOutput(o,s)}catch(i){return r||f.stop(),f.fail(k(i)),{success:!1,error:k(i)}}}async phasePackageUpdate(e){let t={success:!0,details:[],errors:[]},s=jg();if(e)return Pg()?(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(Pg()){try{Gn("brew uninstall prjct-cli 2>/dev/null",{stdio:"pipe"}),t.details.push("Uninstalled homebrew formula")}catch{t.details.push("Homebrew uninstall skipped (not found)")}Gn("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("Installed via npm")}else Gn("npm install -g prjct-cli@latest",{stdio:"pipe"}),t.details.push("npm install complete");let o=jg();s&&o&&s!==o?t.details.push(`${s} \u2192 ${o}`):o&&t.details.push(`v${o} (already latest)`)}catch(r){t.success=!1,t.errors.push(k(r))}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 r=0,o=0;for(let i of s)if(!e)try{let a=await Lo(i),c=await Fo(i);if(r+=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)}: ${k(a)}`)}if(e)t.details.push(`Would migrate ${s.length} project(s)`);else{let i=[`${s.length} project(s) checked`];r>0&&i.push(`${r} 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 Ht().cleanupAllLegacy();o.cleaned.length>0&&t.details.push(`Cleaned ${o.cleaned.length} legacy artifact(s)`)}catch(r){t.errors.push(`Legacy cleanup: ${k(r)}`)}try{let o=await new Ht().installCommands();t.details.push(`Editor commands reinstalled (${o.installed?.length||0} providers)`)}catch(r){t.errors.push(`Commands: ${k(r)}`)}try{await new Ht().installGlobalConfig(),t.details.push("Global config updated (prjct section replaced)")}catch(r){t.errors.push(`Global config: ${k(r)}`)}try{let{detectAllProviders:r}=await Promise.resolve().then(()=>(We(),yt)),o=await r(),i=Nr.join(Je("node:os").homedir());if(o.gemini.installed){let a=Nr.join(i,".gemini","GEMINI.md");try{let c=await El.readFile(a,"utf-8"),u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",d="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(c.includes(u)&&c.includes(d)){let{getTemplateContent:m}=await Promise.resolve().then(()=>(Fs(),Fa)),p=m("global/GEMINI.md");if(p?.includes(u)&&p.includes(d)){let g=p.substring(p.indexOf(u),p.indexOf(d)+d.length),y=c.substring(0,c.indexOf(u)),j=c.substring(c.indexOf(d)+d.length),T=y+g+j,x="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",S="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->";if(T.includes(x)&&T.includes(S)){let w=T.substring(0,T.indexOf(x)),P=T.substring(T.indexOf(S)+S.length);T=`${(w+P).replace(/\n{3,}/g,`
1123
1123
 
1124
1124
  `).trim()}
1125
- `}await bl.writeFile(a,T,"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:r,forceKillDaemon:o,spawnDaemon:i}=await Promise.resolve().then(()=>(Jt(),Bt));await s()?(await r()||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(k(s))}return t}formatTerminalOutput(e,t){let s=e.phase1.success&&e.phase2.success,r=[...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?Wn.green("\u2713"):c?Wn.red("\u2717"):Wn.yellow("\u26A0");console.log(` ${u} ${Wn.bold(i)}`);for(let d of a.details)console.log(` ${Wn.dim(d)}`);for(let d of a.errors)console.log(` ${Wn.yellow("\u26A0")} ${d}`)}return console.log(""),t?f.done("Dry run complete \u2014 no changes made"):s?f.done("System updated"):f.warn(`Updated with ${r.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,r=[];r.push(t?"# Update (Dry Run)":"# System Update"),r.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";r.push(`## ${i} (${u})`);for(let d of a.details)r.push(`- ${d}`);for(let d of a.errors)r.push(`- WARNING: ${d}`);r.push("")}return t||r.push(s?"**Status:** All phases completed successfully.":"**Status:** Completed with errors."),console.log(r.join(`
1126
- `)),{success:s,message:t?"Dry run complete":s?"System updated":"Updated with errors"}}redirectToInstalledPackage(){try{let e=Gn("npm root -g",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim(),t=Nr.join(e,"prjct-cli"),s=Nr.join(t,"package.json"),{existsSync:r,lstatSync:o,readFileSync:i}=Je("node:fs");if(!r(s)||o(t).isSymbolicLink())return;try{if(JSON.parse(i(s,"utf-8")).name!=="prjct-cli")return}catch{return}Gi(t);let{resetBundle:c}=(Fs(),ht(Oa));c()}catch{}}async getAllProjectIds(){let e=Nr.join($.getGlobalBasePath(),"projects");try{return(await bl.readdir(e,{withFileTypes:!0})).filter(s=>s.isDirectory()&&!s.name.startsWith(".")).map(s=>s.name)}catch{return[]}}}});import El from"node:fs/promises";import VS from"node:os";import ki from"node:path";var Cl,Pl,Rg=h(()=>{"use strict";V();J();Cl=class{static{l(this,"TemplateGenerator")}commandsPath;constructor(){this.commandsPath=ki.join(VS.homedir(),".claude","commands","p")}async generateWorkflowTemplate(e,t){try{await El.mkdir(this.commandsPath,{recursive:!0});let s=ki.join(this.commandsPath,`${e}.md`),r=this.buildTemplateContent(e,t);return await El.writeFile(s,r,"utf-8"),{success:!0,path:s}}catch(s){return{success:!1,error:k(s)}}}async deleteWorkflowTemplate(e){try{let t=ki.join(this.commandsPath,`${e}.md`);return await El.unlink(t),{success:!0}}catch(t){return _(t)?{success:!0}:{success:!1,error:k(t)}}}async templateExists(e){let t=ki.join(this.commandsPath,`${e}.md`);return b(t)}buildTemplateContent(e,t){return`---
1125
+ `}await El.writeFile(a,T,"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:r,forceKillDaemon:o,spawnDaemon:i}=await Promise.resolve().then(()=>(Jt(),Bt));await s()?(await r()||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(k(s))}return t}formatTerminalOutput(e,t){let s=e.phase1.success&&e.phase2.success,r=[...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?Wn.green("\u2713"):c?Wn.red("\u2717"):Wn.yellow("\u26A0");console.log(` ${u} ${Wn.bold(i)}`);for(let d of a.details)console.log(` ${Wn.dim(d)}`);for(let d of a.errors)console.log(` ${Wn.yellow("\u26A0")} ${d}`)}return console.log(""),t?f.done("Dry run complete \u2014 no changes made"):s?f.done("System updated"):f.warn(`Updated with ${r.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,r=[];r.push(t?"# Update (Dry Run)":"# System Update"),r.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";r.push(`## ${i} (${u})`);for(let d of a.details)r.push(`- ${d}`);for(let d of a.errors)r.push(`- WARNING: ${d}`);r.push("")}return t||r.push(s?"**Status:** All phases completed successfully.":"**Status:** Completed with errors."),console.log(r.join(`
1126
+ `)),{success:s,message:t?"Dry run complete":s?"System updated":"Updated with errors"}}redirectToInstalledPackage(){try{let e=Gn("npm root -g",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim(),t=Nr.join(e,"prjct-cli"),s=Nr.join(t,"package.json"),{existsSync:r,lstatSync:o,readFileSync:i}=Je("node:fs");if(!r(s)||o(t).isSymbolicLink())return;try{if(JSON.parse(i(s,"utf-8")).name!=="prjct-cli")return}catch{return}Vi(t);let{resetBundle:c}=(Fs(),ht(Fa));c()}catch{}}async getAllProjectIds(){let e=Nr.join($.getGlobalBasePath(),"projects");try{return(await El.readdir(e,{withFileTypes:!0})).filter(s=>s.isDirectory()&&!s.name.startsWith(".")).map(s=>s.name)}catch{return[]}}}});import Pl from"node:fs/promises";import BS from"node:os";import vi from"node:path";var jl,Rl,Rg=h(()=>{"use strict";V();J();jl=class{static{l(this,"TemplateGenerator")}commandsPath;constructor(){this.commandsPath=vi.join(BS.homedir(),".claude","commands","p")}async generateWorkflowTemplate(e,t){try{await Pl.mkdir(this.commandsPath,{recursive:!0});let s=vi.join(this.commandsPath,`${e}.md`),r=this.buildTemplateContent(e,t);return await Pl.writeFile(s,r,"utf-8"),{success:!0,path:s}}catch(s){return{success:!1,error:k(s)}}}async deleteWorkflowTemplate(e){try{let t=vi.join(this.commandsPath,`${e}.md`);return await Pl.unlink(t),{success:!0}}catch(t){return _(t)?{success:!0}:{success:!1,error:k(t)}}}async templateExists(e){let t=vi.join(this.commandsPath,`${e}.md`);return b(t)}buildTemplateContent(e,t){return`---
1127
1127
  allowed-tools: [Bash, Read, Write, Edit, Glob, Grep, Task, AskUserQuestion]
1128
1128
  ---
1129
1129
 
@@ -1159,38 +1159,38 @@ Suggest relevant actions based on the workflow results:
1159
1159
  - View rules: \`prjct workflow ${e} --md\`
1160
1160
  - Add rules: \`prjct workflow add "command" before ${e} --md\`
1161
1161
  - Run again: \`p. ${e}\`
1162
- `}},Pl=new Cl});function JS(n,e){let t=e.filter(p=>p.type==="gate"&&p.position==="before"),s=e.filter(p=>p.type==="instruction"&&p.position==="before"),r=e.filter(p=>p.type==="hook"&&p.position==="before"),o=e.filter(p=>p.type==="step"&&p.position==="before"),i=e.filter(p=>p.type==="instruction"&&p.position==="after"),a=e.filter(p=>p.type==="hook"&&p.position==="after"),c=e.filter(p=>p.type==="step"&&p.position==="after"),u=[],d=l((p,g,y)=>{let j=g.map(w=>` ${w.enabled?y:"o"} #${w.id} ${w.action}`),T=[p,...j],S=Math.max(...T.map(w=>w.length))+2;u.push(`+${"-".repeat(S)}+`);for(let w of T)u.push(`| ${w.padEnd(S-1)}|`);u.push(`+${"-".repeat(S)}+`)},"drawBox"),m=l(p=>{p.push(" |"),p.push(" v")},"arrow");return t.length>0&&(d("GATES (must pass)",t,"#"),m(u)),s.length>0&&(d("INSTRUCTIONS (before)",s,"\u{1F4CB}"),m(u)),r.length>0&&(d("HOOKS (before)",r,">"),m(u)),o.length>0&&(d("STEPS (before)",o,">"),m(u)),u.push(` [ ${n.toUpperCase()} ]`),i.length>0&&(m(u),d("INSTRUCTIONS (after)",i,"\u{1F4CB}")),a.length>0&&(m(u),d("HOOKS (after)",a,">")),c.length>0&&(m(u),d("STEPS (after)",c,">")),u.join(`
1163
- `)}var BS,Vn,jl=h(()=>{"use strict";de();Rg();$s();Vc();co();rt();mn();V();be();xr();Ir();Me();_c();Xc();bt();BS=[{type:"help",patterns:/^help\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|new)\b/i},{type:"list",patterns:/^list\b/i},{type:"delete",patterns:/^delete\b/i},{type:"run",patterns:/^run\b/i},{type:"disable",patterns:/^disable\b/i},{type:"view",patterns:/^(?:show|view)\b/i}],Vn=class extends we{static{l(this,"WorkflowCommands")}async now(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(!e)return this._showActiveTask(o,s);let i=await Ss(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=/^[A-Z]+-\d+$/.test(e)?e:void 0,c=e,u=et();await D.startTask(o,{id:u,description:c,sessionId:et(),linearId:a}),await this.logToMemory(t,"task_started",{task:c,taskId:u,timestamp:R()}),await Ss(o,"task","after",{projectPath:t,skipRules:s.skipHooks});let d=await ei(t).catch(()=>"");return s.md?console.log(G(Rr({description:c,status:"active"}),le("State",$e([`Task: \`${u}\``,d?`Branch: \`${d}\``:null,a?`Linear: \`${a}\``:null,i.instructions.length>0?`Agent instructions: ${i.instructions.length}`:null].filter(m=>m!==null))),i.instructions.length>0?le("Agent Instructions",$e(i.instructions)):null,qe([{label:"Pull project memory",command:"prjct context memory <topic>"},{label:"Tag the task",command:"prjct tag type:bug domain:auth"},{label:"Capture learnings",command:'prjct remember learning "..."'},{label:"Ship when done",command:"prjct ship --md"}]))):(f.done(`Task: ${c}`),Jp("working"),Pn("task")),{success:!0,task:c,taskId:u}}catch(r){let o=k(r);return s.md?console.log(`> ${o}`):f.fail(o),{success:!1,error:o}}}async _showActiveTask(e,t){let s=await D.getCurrentTask(e);if(!s){let r='no active task. `prjct task "<description>"` to start one.';return t.md?console.log(`> ${r}`):f.info(r),{success:!0,message:"no active task"}}return t.md?console.log(G(Rr({description:s.description,status:"active"}),le("State",$e([`Task: \`${s.id}\``,s.branch?`Branch: \`${s.branch}\``:null,s.linearId?`Linear: \`${s.linearId}\``:null,`Started: ${s.startedAt}`].filter(r=>r!==null))))):f.info(`Active: ${s.description}`),{success:!0,currentTask:s}}async workflow(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;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(r){return s.md?console.log(`> Error: ${k(r)}`):f.fail(k(r)),{success:!1,error:k(r)}}}_detectIntent(e){let t=e.trim();for(let{type:s,patterns:r}of BS){let o=t.match(r);if(o){let i=o[0],a=t.slice(i.length).trim();return{type:s,args:a,confidence:"exact"}}}return{type:"view",args:t,confidence:"exact"}}_searchRules(e,t){let s=t.toLowerCase();return e.filter(r=>r.action.toLowerCase().includes(s)||(r.description?.toLowerCase().includes(s)??!1)||r.command.toLowerCase().includes(s)||String(r.id)===s)}_parseAction(e){let t=e.trim();if(t.startsWith('"')){let r=t.indexOf('"',1);return r===-1?[t.slice(1),""]:[t.slice(1,r),t.slice(r+1).trim()]}if(t.startsWith("'")){let r=t.indexOf("'",1);return r===-1?[t.slice(1),""]:[t.slice(1,r),t.slice(r+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[r,o]=this._parseAction(e);if(!r||!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=xe.getWorkflow(t,c||"");if(!c||!u||!u.enabled){let p=xe.getAllWorkflows(t).map(y=>y.name).join(", "),g=`Workflow '${c}' not found. Available: ${p}`;return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let d=ee.addRule(t,{type:"hook",command:c,position:a,action:r,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(G(Ce("Rule Added",`#${d} [hook] ${a} ${c} \u2192 \`${r}\``),qe([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${d} --md`}]))):f.done(`rule #${d} added: [hook] ${a} ${c} \u2192 ${r}`),{success:!0,ruleId:d}}async _workflowGate(e,t,s){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=xe.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let m=xe.getAllWorkflows(t).map(g=>g.name).join(", "),p=`Workflow '${o}' not found. Available: ${m}`;return s.md?console.log(`> ${p}`):f.warn(p),{success:!1,error:p}}let a=e.slice(e.indexOf(o)+o.length).trim(),[c]=this._parseAction(a);if(!c){let d='Usage: prjct workflow gate <command> "shell command"';return s.md?console.log(`> ${d}`):f.warn(d),{success:!1,error:d}}let u=ee.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(G(Ce("Gate Added",`#${u} [gate] before ${o} \u2192 \`${c}\``),qe([{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=xe.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let y=xe.getAllWorkflows(t).map(T=>T.name).join(", "),j=`Workflow '${o}' not found. Available: ${y}`;return s.md?console.log(`> ${j}`):f.warn(j),{success:!1,error:j}}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(),d=a.slice(c[0].length).trim(),[m]=this._parseAction(d);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 p=ee.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(G(Ce("Instruction Added",`#${p} [instruction] ${u} ${o} \u2192 \`${m}\``),qe([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${p} --md`}]))):f.done(`instruction #${p} added: ${u} ${o} \u2192 ${m}`),{success:!0,ruleId:p}}async _workflowRm(e,t,s){let r=parseInt(e.trim(),10);if(Number.isNaN(r)){let i="Usage: prjct workflow rm <rule-id>";return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}if(!ee.removeRule(t,r)){let i=`Rule #${r} not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return s.md?console.log(G(Ce("Rule Removed",`Removed rule #${r}`))):f.done(`removed rule #${r}`),{success:!0}}async _workflowReset(e,t){let s=ee.resetRules(e);return t.md?console.log(G(Ce("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 r=e.trim(),o=parseInt(r,10);if(!Number.isNaN(o)){let u=ee.getRuleById(t,o);if(!u){let d=`Rule #${o} not found`;return s.md?console.log(`> ${d}`):f.warn(d),{success:!1,error:d}}if(!u.enabled){let d=`Rule #${o} is already disabled`;return s.md?console.log(`> ${d}`):f.warn(d),{success:!0,message:d}}return ee.updateRule(t,o,{enabled:!1}),s.md?console.log(G(Ce("Rule Disabled",`#${o} [${u.type}] ${u.action}`),qe([{label:"Re-enable this rule",command:`prjct workflow enable ${o} --md`},{label:"View all rules",command:"prjct workflow --md"}]))):f.done(`disabled rule #${o}: ${u.action}`),{success:!0,ruleId:o}}let i=ee.getAllRules(t),a=this._searchRules(i,r);if(a.length===0){let u=`No rules matching "${r}"`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(a.length===1){let u=a[0];return ee.updateRule(t,u.id,{enabled:!1}),s.md?console.log(G(Ce("Rule Disabled",`#${u.id} [${u.type}] ${u.action}`))):f.done(`disabled rule #${u.id}: ${u.action}`),{success:!0,ruleId:u.id}}let c=a.slice(0,5);if(s.md){let u=c.map(d=>`#${d.id} [${d.type}] ${d.position} ${d.command} -> \`${d.action}\``);a.length>5&&u.push(`...and ${a.length-5} more`),console.log(G(le("Multiple matches",`${a.length} rules match "${r}"`),$e(u),qe(c.map(d=>({label:`Disable #${d.id}`,command:`prjct workflow disable ${d.id} --md`})))))}else{f.warn(`${a.length} rules match "${r}" \u2014 specify an ID:`);for(let u of c)console.log(` #${u.id} [${u.type}] ${u.position} ${u.command} -> ${u.action}`);a.length>5&&console.log(` ...and ${a.length-5} more`)}return{success:!0,matches:a.map(u=>u.id)}}async _workflowHelp(e){return e.md?console.log(G(le("Workflow Help","Manage hooks, gates, and steps for your workflow"),le("Commands",$e(["`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"])),le("Natural Language (EN/ES)",$e(['`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 r=["task","done","ship","sync"],o;if(e&&r.includes(e)?o=ee.getRulesForCommand(t,e):o=ee.getAllRules(t),o.length===0)return s.md?console.log(G(le("Workflow Rules","No rules configured"),qe([{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]:r,a=[];for(let d of i){let m=o.filter(p=>p.command===d);m.length!==0&&a.push(JS(d,m))}let c=e?`Workflow: ${e}`:"Workflow Rules",u=`${o.length} rule${o.length!==1?"s":""}`;console.log(G(le(c,u),a.length>0?Wp(a.join(`
1162
+ `}},Rl=new jl});function zS(n,e){let t=e.filter(p=>p.type==="gate"&&p.position==="before"),s=e.filter(p=>p.type==="instruction"&&p.position==="before"),r=e.filter(p=>p.type==="hook"&&p.position==="before"),o=e.filter(p=>p.type==="step"&&p.position==="before"),i=e.filter(p=>p.type==="instruction"&&p.position==="after"),a=e.filter(p=>p.type==="hook"&&p.position==="after"),c=e.filter(p=>p.type==="step"&&p.position==="after"),u=[],d=l((p,g,y)=>{let j=g.map(w=>` ${w.enabled?y:"o"} #${w.id} ${w.action}`),T=[p,...j],S=Math.max(...T.map(w=>w.length))+2;u.push(`+${"-".repeat(S)}+`);for(let w of T)u.push(`| ${w.padEnd(S-1)}|`);u.push(`+${"-".repeat(S)}+`)},"drawBox"),m=l(p=>{p.push(" |"),p.push(" v")},"arrow");return t.length>0&&(d("GATES (must pass)",t,"#"),m(u)),s.length>0&&(d("INSTRUCTIONS (before)",s,"\u{1F4CB}"),m(u)),r.length>0&&(d("HOOKS (before)",r,">"),m(u)),o.length>0&&(d("STEPS (before)",o,">"),m(u)),u.push(` [ ${n.toUpperCase()} ]`),i.length>0&&(m(u),d("INSTRUCTIONS (after)",i,"\u{1F4CB}")),a.length>0&&(m(u),d("HOOKS (after)",a,">")),c.length>0&&(m(u),d("STEPS (after)",c,">")),u.join(`
1163
+ `)}var JS,Vn,xl=h(()=>{"use strict";de();Rg();$s();Jc();lo();ot();mn();V();be();xr();Ir();Me();Oc();Yc();bt();JS=[{type:"help",patterns:/^help\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|new)\b/i},{type:"list",patterns:/^list\b/i},{type:"delete",patterns:/^delete\b/i},{type:"run",patterns:/^run\b/i},{type:"disable",patterns:/^disable\b/i},{type:"view",patterns:/^(?:show|view)\b/i}],Vn=class extends we{static{l(this,"WorkflowCommands")}async now(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await I.getProjectId(t);if(!o)return f.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(!e)return this._showActiveTask(o,s);let i=await Ss(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=/^[A-Z]+-\d+$/.test(e)?e:void 0,c=e,u=tt();await D.startTask(o,{id:u,description:c,sessionId:tt(),linearId:a}),await this.logToMemory(t,"task_started",{task:c,taskId:u,timestamp:R()}),await Ss(o,"task","after",{projectPath:t,skipRules:s.skipHooks});let d=await ti(t).catch(()=>"");return s.md?console.log(G(Rr({description:c,status:"active"}),le("State",$e([`Task: \`${u}\``,d?`Branch: \`${d}\``:null,a?`Linear: \`${a}\``:null,i.instructions.length>0?`Agent instructions: ${i.instructions.length}`:null].filter(m=>m!==null))),i.instructions.length>0?le("Agent Instructions",$e(i.instructions)):null,qe([{label:"Pull project memory",command:"prjct context memory <topic>"},{label:"Tag the task",command:"prjct tag type:bug domain:auth"},{label:"Capture learnings",command:'prjct remember learning "..."'},{label:"Ship when done",command:"prjct ship --md"}]))):(f.done(`Task: ${c}`),Jp("working"),Pn("task")),{success:!0,task:c,taskId:u}}catch(r){let o=k(r);return s.md?console.log(`> ${o}`):f.fail(o),{success:!1,error:o}}}async _showActiveTask(e,t){let s=await D.getCurrentTask(e);if(!s){let r='no active task. `prjct task "<description>"` to start one.';return t.md?console.log(`> ${r}`):f.info(r),{success:!0,message:"no active task"}}return t.md?console.log(G(Rr({description:s.description,status:"active"}),le("State",$e([`Task: \`${s.id}\``,s.branch?`Branch: \`${s.branch}\``:null,s.linearId?`Linear: \`${s.linearId}\``:null,`Started: ${s.startedAt}`].filter(r=>r!==null))))):f.info(`Active: ${s.description}`),{success:!0,currentTask:s}}async workflow(e=null,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;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(r){return s.md?console.log(`> Error: ${k(r)}`):f.fail(k(r)),{success:!1,error:k(r)}}}_detectIntent(e){let t=e.trim();for(let{type:s,patterns:r}of JS){let o=t.match(r);if(o){let i=o[0],a=t.slice(i.length).trim();return{type:s,args:a,confidence:"exact"}}}return{type:"view",args:t,confidence:"exact"}}_searchRules(e,t){let s=t.toLowerCase();return e.filter(r=>r.action.toLowerCase().includes(s)||(r.description?.toLowerCase().includes(s)??!1)||r.command.toLowerCase().includes(s)||String(r.id)===s)}_parseAction(e){let t=e.trim();if(t.startsWith('"')){let r=t.indexOf('"',1);return r===-1?[t.slice(1),""]:[t.slice(1,r),t.slice(r+1).trim()]}if(t.startsWith("'")){let r=t.indexOf("'",1);return r===-1?[t.slice(1),""]:[t.slice(1,r),t.slice(r+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[r,o]=this._parseAction(e);if(!r||!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=xe.getWorkflow(t,c||"");if(!c||!u||!u.enabled){let p=xe.getAllWorkflows(t).map(y=>y.name).join(", "),g=`Workflow '${c}' not found. Available: ${p}`;return s.md?console.log(`> ${g}`):f.warn(g),{success:!1,error:g}}let d=ee.addRule(t,{type:"hook",command:c,position:a,action:r,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return s.md?console.log(G(Ce("Rule Added",`#${d} [hook] ${a} ${c} \u2192 \`${r}\``),qe([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${d} --md`}]))):f.done(`rule #${d} added: [hook] ${a} ${c} \u2192 ${r}`),{success:!0,ruleId:d}}async _workflowGate(e,t,s){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=xe.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let m=xe.getAllWorkflows(t).map(g=>g.name).join(", "),p=`Workflow '${o}' not found. Available: ${m}`;return s.md?console.log(`> ${p}`):f.warn(p),{success:!1,error:p}}let a=e.slice(e.indexOf(o)+o.length).trim(),[c]=this._parseAction(a);if(!c){let d='Usage: prjct workflow gate <command> "shell command"';return s.md?console.log(`> ${d}`):f.warn(d),{success:!1,error:d}}let u=ee.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(G(Ce("Gate Added",`#${u} [gate] before ${o} \u2192 \`${c}\``),qe([{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=xe.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let y=xe.getAllWorkflows(t).map(T=>T.name).join(", "),j=`Workflow '${o}' not found. Available: ${y}`;return s.md?console.log(`> ${j}`):f.warn(j),{success:!1,error:j}}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(),d=a.slice(c[0].length).trim(),[m]=this._parseAction(d);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 p=ee.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(G(Ce("Instruction Added",`#${p} [instruction] ${u} ${o} \u2192 \`${m}\``),qe([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${p} --md`}]))):f.done(`instruction #${p} added: ${u} ${o} \u2192 ${m}`),{success:!0,ruleId:p}}async _workflowRm(e,t,s){let r=parseInt(e.trim(),10);if(Number.isNaN(r)){let i="Usage: prjct workflow rm <rule-id>";return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}if(!ee.removeRule(t,r)){let i=`Rule #${r} not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return s.md?console.log(G(Ce("Rule Removed",`Removed rule #${r}`))):f.done(`removed rule #${r}`),{success:!0}}async _workflowReset(e,t){let s=ee.resetRules(e);return t.md?console.log(G(Ce("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 r=e.trim(),o=parseInt(r,10);if(!Number.isNaN(o)){let u=ee.getRuleById(t,o);if(!u){let d=`Rule #${o} not found`;return s.md?console.log(`> ${d}`):f.warn(d),{success:!1,error:d}}if(!u.enabled){let d=`Rule #${o} is already disabled`;return s.md?console.log(`> ${d}`):f.warn(d),{success:!0,message:d}}return ee.updateRule(t,o,{enabled:!1}),s.md?console.log(G(Ce("Rule Disabled",`#${o} [${u.type}] ${u.action}`),qe([{label:"Re-enable this rule",command:`prjct workflow enable ${o} --md`},{label:"View all rules",command:"prjct workflow --md"}]))):f.done(`disabled rule #${o}: ${u.action}`),{success:!0,ruleId:o}}let i=ee.getAllRules(t),a=this._searchRules(i,r);if(a.length===0){let u=`No rules matching "${r}"`;return s.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(a.length===1){let u=a[0];return ee.updateRule(t,u.id,{enabled:!1}),s.md?console.log(G(Ce("Rule Disabled",`#${u.id} [${u.type}] ${u.action}`))):f.done(`disabled rule #${u.id}: ${u.action}`),{success:!0,ruleId:u.id}}let c=a.slice(0,5);if(s.md){let u=c.map(d=>`#${d.id} [${d.type}] ${d.position} ${d.command} -> \`${d.action}\``);a.length>5&&u.push(`...and ${a.length-5} more`),console.log(G(le("Multiple matches",`${a.length} rules match "${r}"`),$e(u),qe(c.map(d=>({label:`Disable #${d.id}`,command:`prjct workflow disable ${d.id} --md`})))))}else{f.warn(`${a.length} rules match "${r}" \u2014 specify an ID:`);for(let u of c)console.log(` #${u.id} [${u.type}] ${u.position} ${u.command} -> ${u.action}`);a.length>5&&console.log(` ...and ${a.length-5} more`)}return{success:!0,matches:a.map(u=>u.id)}}async _workflowHelp(e){return e.md?console.log(G(le("Workflow Help","Manage hooks, gates, and steps for your workflow"),le("Commands",$e(["`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"])),le("Natural Language (EN/ES)",$e(['`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 r=["task","done","ship","sync"],o;if(e&&r.includes(e)?o=ee.getRulesForCommand(t,e):o=ee.getAllRules(t),o.length===0)return s.md?console.log(G(le("Workflow Rules","No rules configured"),qe([{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]:r,a=[];for(let d of i){let m=o.filter(p=>p.command===d);m.length!==0&&a.push(zS(d,m))}let c=e?`Workflow: ${e}`:"Workflow Rules",u=`${o.length} rule${o.length!==1?"s":""}`;console.log(G(le(c,u),a.length>0?Wp(a.join(`
1164
1164
 
1165
- `),""):null,qe([{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 r=ee.getRulesForCommand(e,"ship").filter(u=>u.position==="before");if(r.length>0){let u=`Ship workflow already has ${r.length} rule${r.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 Xo(t),i=0,a=[],c=ee.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=ee.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=ee.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(G(Ce("Workflow Initialized",`Added ${a.length} default ship rules`),$e(a),qe([{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,r){let o=e.match(/^(\S+)\s+"([^"]+)"/);if(!o){let u='Usage: prjct workflow create <name> "description"';return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let[,i,a]=o;if(!xe.isValidName(i)){let u='Workflow name must be lowercase alphanumeric + hyphens (e.g., "qa", "deploy-prod")';return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(xe.isReservedName(i)){let u=`Workflow name '${i}' is reserved`;return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(xe.getWorkflow(t,i)){let u=`Workflow '${i}' already exists`;return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}try{let u=xe.createWorkflow(t,{name:i,description:a}),d=await Pl.generateWorkflowTemplate(i,a);if(!d.success){xe.deleteWorkflow(t,i);let m=`Failed to generate template: ${d.error}`;return r.md?console.log(`> Error: ${m}`):f.fail(m),{success:!1,error:m}}return r.md?console.log(G(Ce("Workflow Created",`Created workflow: ${i}`),le("Description",a),le("Template",`Installed at ${d.path}`),qe([{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: ${d.path}`),console.log(`
1165
+ `),""):null,qe([{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 r=ee.getRulesForCommand(e,"ship").filter(u=>u.position==="before");if(r.length>0){let u=`Ship workflow already has ${r.length} rule${r.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 Ko(t),i=0,a=[],c=ee.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=ee.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=ee.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(G(Ce("Workflow Initialized",`Added ${a.length} default ship rules`),$e(a),qe([{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,r){let o=e.match(/^(\S+)\s+"([^"]+)"/);if(!o){let u='Usage: prjct workflow create <name> "description"';return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}let[,i,a]=o;if(!xe.isValidName(i)){let u='Workflow name must be lowercase alphanumeric + hyphens (e.g., "qa", "deploy-prod")';return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(xe.isReservedName(i)){let u=`Workflow name '${i}' is reserved`;return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}if(xe.getWorkflow(t,i)){let u=`Workflow '${i}' already exists`;return r.md?console.log(`> ${u}`):f.warn(u),{success:!1,error:u}}try{let u=xe.createWorkflow(t,{name:i,description:a}),d=await Rl.generateWorkflowTemplate(i,a);if(!d.success){xe.deleteWorkflow(t,i);let m=`Failed to generate template: ${d.error}`;return r.md?console.log(`> Error: ${m}`):f.fail(m),{success:!1,error:m}}return r.md?console.log(G(Ce("Workflow Created",`Created workflow: ${i}`),le("Description",a),le("Template",`Installed at ${d.path}`),qe([{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: ${d.path}`),console.log(`
1166
1166
  Run with: p. ${i}`)),{success:!0,workflowId:u,name:i,templatePath:d.path}}catch(u){let d=k(u);return r.md?console.log(`> Error: ${d}`):f.fail(d),{success:!1,error:d}}}async _workflowList(e,t){let s=xe.getAllWorkflows(e);if(s.length===0){let i="No workflows found";return t.md?console.log(`> ${i}`):f.warn(i),{success:!0,workflows:[]}}let r=s.filter(i=>i.isBuiltin),o=s.filter(i=>!i.isBuiltin);if(t.md){let i=[];if(r.length>0){let a=r.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(le("Built-in Workflows",a.join(`
1167
1167
  `)))}if(o.length>0){let a=o.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(le("Custom Workflows",a.join(`
1168
1168
  `)))}console.log(G(...i,qe([{label:"Create workflow",command:'prjct workflow create <name> "description" --md'},{label:"View workflow",command:"prjct workflow <name> --md"}])))}else{if(f.done(`${s.length} workflow${s.length!==1?"s":""}`),r.length>0){console.log(`
1169
1169
  Built-in:`);for(let i of r)console.log(` ${i.name} \u2014 ${i.description}`)}if(o.length>0){console.log(`
1170
- Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:s}}async _workflowDelete(e,t,s){let r=e.trim();if(!r){let o="Usage: prjct workflow delete <name>";return s.md?console.log(`> ${o}`):f.warn(o),{success:!1,error:o}}try{if(!xe.deleteWorkflow(t,r)){let i=`Workflow '${r}' not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return await Pl.deleteWorkflowTemplate(r),s.md?console.log(G(Ce("Workflow Deleted",`Deleted workflow: ${r}`))):f.done(`deleted workflow: ${r}`),{success:!0}}catch(o){let i=k(o);return s.md?console.log(`> Error: ${i}`):f.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await 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=xe.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 Ss(o,i,"before",{projectPath:t});if(!c.success){if(s.md)qp("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 Ss(o,i,"after",{projectPath:t}),s.md?console.log(G(Ce(`Workflow: ${i}`,a.description||""),qe([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):f.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(r){let o=k(r);return s.md?console.log(`> Error: ${o}`):f.fail(o),{success:!1,error:o}}}};l(JS,"buildFlowDiagram")});var Ts,HO,Rl=h(()=>{"use strict";li();il();di();_r();ci();pl();gi();Sl();ai();Tl();jl();Ts=class{static{l(this,"PrjctCommands")}workflow;planning;shipping;analysis;setupCmds;updateCmds;contextCmds;primitivesCmds;seedCmds;installCmds;captureCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new Vn,this.planning=new Js,this.shipping=new Bs,this.analysis=new Ks,this.setupCmds=new Hn,this.updateCmds=new qn,this.contextCmds=new bs,this.primitivesCmds=new Fn,this.seedCmds=new Qs,this.installCmds=new Ys,this.captureCmds=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 workflowPrefs(e=null,t=process.cwd(),s={}){return this.workflow.workflow(e,t,s)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async ship(e,t=process.cwd(),s={}){return this.shipping.ship(e,t,{...s})}async analyze(e={},t=process.cwd()){return this.analysis.analyze(e,t)}async sync(e=process.cwd(),t={}){return this.analysis.sync(e,t)}async saveLlmAnalysis(e,t=process.cwd(),s={}){return this.analysis.saveLlmAnalysis(e,t,s)}async regenVault(e=process.cwd(),t={}){return this.analysis.regenVault(e,t)}async context(e=null,t=process.cwd(),s={}){return this.contextCmds.context(e,t,s)}async status(e=null,t=process.cwd(),s={}){return this.primitivesCmds.status(e,t,s)}async tag(e=null,t=process.cwd(),s={}){return this.primitivesCmds.tag(e,t,s)}async remember(e=null,t=process.cwd(),s={}){return this.primitivesCmds.remember(e,t,s)}async seed(e=null,t=process.cwd(),s={}){return this.seedCmds.seed(e,t,s)}async install(e=null,t=process.cwd(),s={}){return this.installCmds.install(null,t,s)}async capture(e=null,t=process.cwd(),s={}){return this.captureCmds.capture(e,t,s)}async auth(e=null,t={}){return this.setupCmds.auth(e,t)}async login(e={}){return this.setupCmds.login(e)}async logout(){return this.setupCmds.logout()}async start(){return this.setupCmds.start()}async setup(e={}){return this.setupCmds.setup(e)}async update(e={},t=process.cwd()){return this.updateCmds.update(e,t)}async installStatusLine(){return this.setupCmds.installStatusLine()}showAsciiArt(){this.setupCmds.showAsciiArt()}async initializeAgent(){return this.workflow.initializeAgent()}async ensureProjectInit(e){return this.workflow.ensureProjectInit(e)}async ensureAuthor(){return this.workflow.ensureAuthor()}async getGlobalProjectPath(e){return this.workflow.getGlobalProjectPath(e)}async logToMemory(e,t,s){return this.workflow.logToMemory(e,t,s)}},HO=new Ts});var xl,te,vi=h(()=>{"use strict";de();Re();V();be();xl=class{static{l(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll"]);register(e,t){this.handlers.set(e.name,e),this.setMeta(e.name,t)}registerFn(e,t,s){this.handlerFns.set(e,t),this.setMeta(e,s)}setMeta(e,t){let s=t?.requiresProject??!this.noProjectCommands.has(e);this.metadata.set(e,{name:e,group:t?.group??"unknown",description:t?.description??"",requiresProject:s,usage:t?.usage??{claude:null,terminal:null},implemented:t?.implemented??!0,hasTemplate:t?.hasTemplate??!1,params:t?.params,blockingRules:t?.blockingRules,features:t?.features,isOptional:t?.isOptional,deprecated:t?.deprecated,replacedBy:t?.replacedBy})}registerCategory(e,t){this.categories.set(e,t)}registerMethod(e,t,s,r){let o=t[s];if(typeof o!="function")throw new Error(`${String(s)} is not a function`);let i=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,r)}has(e){return this.handlers.has(e)||this.handlerFns.has(e)}list(){return[...this.handlers.keys(),...this.handlerFns.keys()]}listByGroup(e){return Array.from(this.metadata.entries()).filter(([,t])=>t.group===e).map(([t])=>t)}getGroups(){let e=new Set;for(let t of this.metadata.values())e.add(t.group);return Array.from(e)}getMeta(e){return this.metadata.get(e)}getAll(){return Array.from(this.metadata.values())}getByName(e){return this.metadata.get(e)}getByCategory(e){return this.getAll().filter(t=>t.group===e)}getAllImplemented(){return this.getAll().filter(e=>e.implemented)}getAllWithTemplates(){return this.getAll().filter(e=>e.hasTemplate)}getClaudeCommands(){return this.getAll().filter(e=>e.usage.claude!==null)}getTerminalCommands(){return this.getAll().filter(e=>e.usage.terminal!==null)}getAllCategories(){return new Map(this.categories)}getCategory(e){return this.categories.get(e)}getRequiresInit(){return this.getAll().filter(e=>e.requiresProject)}getWithBlockingRules(){return this.getAll().filter(e=>e.blockingRules!==void 0)}getOptionalCommands(){return this.getAll().filter(e=>e.isOptional)}getDeprecatedCommands(){return this.getAll().filter(e=>e.deprecated)}getStats(){let e=this.getAll(),t={};for(let s of this.categories.keys())t[s]=e.filter(r=>r.group===s).length;return{total:e.length,implemented:e.filter(s=>s.implemented).length,withTemplates:e.filter(s=>s.hasTemplate).length,claudeOnly:e.filter(s=>s.usage.claude&&!s.usage.terminal).length,terminalOnly:e.filter(s=>!s.usage.claude&&s.usage.terminal).length,both:e.filter(s=>s.usage.claude&&s.usage.terminal).length,requiresInit:e.filter(s=>s.requiresProject).length,byCategory:t}}validate(){let e=[],t=this.getAll(),s=t.map(a=>a.name),r=s.filter((a,c)=>s.indexOf(a)!==c);r.length>0&&e.push(`Duplicate command names: ${r.join(", ")}`);let o=t.filter(a=>a.hasTemplate&&!a.implemented);o.length>0&&e.push(`Commands with templates but not implemented: ${o.map(a=>a.name).join(", ")}`);let i=Array.from(this.categories.keys());if(i.length>0){let a=t.filter(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:$.getGlobalProjectPath(t),timestamp:R()}}async execute(e,t,s=process.cwd()){let r=this.metadata.get(e),o;if(r?.requiresProject===!1)o={projectId:"",projectPath:s,globalPath:"",timestamp:R()};else try{o=await this.buildContext(s)}catch(c){return{success:!1,error:k(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 r=this.handlers.get(e);if(r){let i={projectId:"",projectPath:s,globalPath:"",timestamp:R()};return r.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:s,globalPath:"",timestamp:R()};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()}},te=new xl});var Or,Bn,Al=h(()=>{"use strict";Or={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}},Bn=[{name:"init",group:"core",description:"Deep project analysis and initialization",usage:{claude:'/p:init "[idea]"',terminal:'prjct init "[idea]"'},params:"[idea]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0,features:["Architect mode for blank projects","Auto tech stack recommendation","Analyzes existing codebases"]},{name:"task",group:"core",description:"Register a task (or show the active one)",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"[description]",implemented:!0,hasTemplate:!0,requiresProject:!0,features:["No arg \u2192 shows the active task (or none)","Writes to stateStorage; runs before/after workflow rules","Optional Linear issue link when the arg matches `[A-Z]+-\\d+`"]},{name:"ship",group:"core",description:"Commit, push, and celebrate shipped feature",usage:{claude:'/p:ship ["feature"]',terminal:'prjct ship ["feature"]'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["No arg \u2192 ships the active task description, or falls back to current work"]},{name:"sync",group:"core",description:"Sync project state and update workflow agents",usage:{claude:"/p:sync",terminal:"prjct sync [--package=<name>] [--full]"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Incremental sync: only re-analyzes changed files (default)","Force full sync: --full bypasses incremental cache","Monorepo support: --package=<name> for single package sync","Nested PRJCT.md inheritance","Per-package CLAUDE.md generation"]},{name:"regen",group:"core",description:"Full rebuild of the Obsidian vault for the current project",usage:{claude:"/p:regen",terminal:"prjct regen [--md]"},implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!1,features:["Nukes `_generated/` and rebuilds from SQLite + CHANGELOG","Use after upgrading prjct-cli to migrate an old vault layout","Idempotent \u2014 same output if nothing changed"]},{name:"suggest",group:"core",description:"Smart recommendations based on project state",usage:{claude:"/p:suggest",terminal:"prjct suggest"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"status",group:"core",description:"Inline status change on the active task (Linear-style escape hatch)",usage:{claude:"/p:status <value>",terminal:"prjct status <value>"},params:"[value]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["No args \u2192 prints active task + current status","Workflows are the primary status-change mechanism; this is the escape"]},{name:"tag",group:"core",description:"Attach k:v tags to the active task (type:bug, domain:frontend, \u2026)",usage:{claude:"/p:tag type:bug",terminal:"prjct tag type:bug domain:auth"},params:"<pairs...>",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Claude decides what to tag \u2014 no heuristic classifier","type:<feature|bug|improvement|chore> promotes to tasks.type"]},{name:"remember",group:"core",description:"Capture a project memory entry (fact, decision, learning, gotcha, \u2026)",usage:{claude:'/p:remember learning "message"',terminal:'prjct remember learning "message" --tags domain:auth'},params:'<type> "<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Types: fact, decision, learning, gotcha, pattern, anti-pattern, shipped, inbox, todo, idea, insight, question, source, person \u2014 plus user-defined","Grows the project memory consumable via `prjct context memory`"]},{name:"capture",group:"core",description:"GTD-style universal inbox \u2014 dump anything to project memory with zero ceremony",usage:{claude:'/p:capture "<anything>"',terminal:'prjct capture "call Ana re pricing" --tags domain:sales'},params:'"<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Writes memory type=inbox; Claude retypes later via a clarify workflow","No task id, no branch, no worktree \u2014 just persists",'Bare `prjct "<text>"` auto-routes to `capture`']},{name:"seed",group:"core",description:"Manage declarative packs (persona, memory types, workflow slots, hook signals)",usage:{claude:"/p:seed list",terminal:"prjct seed add pm,daily"},params:"[add|remove|list|suggest] [pack,pack,...]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Packs declare signals only \u2014 no bash is written","Add or remove multi-persona contexts per project","Auto-detect suggestion from project stack"]},{name:"install",group:"core",description:"Install Claude Code hooks (~/.claude/settings.json merge-safe)",usage:{claude:"/p:install",terminal:"prjct install"},params:"",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Writes 7 passive hooks: SessionStart, UserPromptSubmit, \u2026","Idempotent; existing non-prjct hooks stay intact","Remove with `prjct claude uninstall`"]},{name:"help",group:"core",description:"Contextual help and guidance",usage:{claude:"/p:help [topic]",terminal:"prjct help [topic]"},params:"[topic]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"analyze",group:"optional",description:"Analyze repository and sync tasks",usage:{claude:"/p:analyze",terminal:"prjct analyze"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"git",group:"optional",description:"Smart git operations with context",usage:{claude:"/p:git [op]",terminal:"prjct git [op]"},params:"[operation]",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"test",group:"optional",description:"Run tests with auto-fix",usage:{claude:"/p:test",terminal:"prjct test"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"workflow",group:"optional",description:"Configure workflow hooks via natural language",usage:{claude:'/p:workflow ["config"]',terminal:'prjct workflow ["config"]'},params:'["natural language config"]',implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Natural language configuration","Before/after hooks for task, done, ship, sync","Permanent, session, or one-time preferences"]},{name:"start",group:"setup",description:"First-time setup (install commands to editors)",usage:{claude:null,terminal:"prjct start"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"setup",group:"setup",description:"Reconfigure editor installations",usage:{claude:"/p:setup",terminal:"prjct setup"},params:"[--force] [--editor <name>]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"migrate",group:"setup",description:"Migrate project to UUID format + sync",usage:{claude:"/p:migrate",terminal:null},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"login",group:"setup",description:"Authenticate with prjct cloud (opens browser)",usage:{claude:null,terminal:"prjct login [--url <webUrl>]"},params:"[--url <webUrl>]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"logout",group:"setup",description:"Sign out from prjct cloud",usage:{claude:null,terminal:"prjct logout"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"auth",group:"setup",description:"Manage cloud authentication",usage:{claude:"/p:auth [action]",terminal:"prjct auth [action]"},params:"[login|logout|status]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"context",group:"setup",description:"Smart context filtering tools for AI agents",usage:{claude:null,terminal:"prjct context <tool> [args]"},params:"<tool> [args]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["files - Find relevant files for a task","signatures - Extract code structure (~90% compression)","imports - Analyze dependency graphs","recent - Find hot files from git history","summary - Intelligent file summarization"]},{name:"update",group:"setup",description:"Update prjct system-wide: package + migrations + daemon restart",usage:{claude:null,terminal:"prjct update [--dry-run]"},params:"[--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Phase 1: npm update (migrates homebrew \u2192 npm if needed)","Phase 2: All projects \u2014 migrate, sweep, reinstall commands","Phase 3: Daemon stop + restart with new code","--dry-run to preview without changes"]},{name:"uninstall",group:"setup",description:"Complete system removal of prjct",usage:{claude:null,terminal:"prjct uninstall"},params:"[--force] [--backup] [--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Removes ~/.prjct-cli/ data","Cleans CLAUDE.md prjct section","Uninstalls Homebrew/npm packages","Backup option before deletion"]}]});var Dg={};W(Dg,{UninstallCommands:()=>Fr,uninstall:()=>$g});import{execSync as Si}from"node:child_process";import it from"node:fs/promises";import zS from"node:os";import as from"node:path";import XS from"node:readline";import ke from"chalk";async function Ag(n){let e=0;try{let t=await it.readdir(n,{withFileTypes:!0});for(let s of t){let r=as.join(n,s.name);if(s.isDirectory())e+=await Ag(r);else try{let o=await it.stat(r);e+=o.size}catch{}}}catch{}return e}function xg(n){if(n===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(n)/Math.log(1024));return`${(n/1024**t).toFixed(1)} ${e[t]}`}async function KS(n){try{return(await it.readdir(n,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}function YS(){let n={homebrew:!1,npm:!1};try{Si("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(n.homebrew=!0,n.homebrewFormula="prjct-cli")}catch{}try{Si("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(n.npm=!0)}catch{}return n}async function QS(){let n=[],e=Fa(),t=$.getGlobalBasePath(),s=await b(t),r=s?await KS(as.join(t,"projects")):0,o=s?await Ag(t):0;n.push({path:t,type:"directory",description:`All project data${r>0?`, ${r} project${r>1?"s":""}`:""}`,size:o,count:r,exists:s});let i=as.join(e.claude.config,"CLAUDE.md"),a=await b(i),c=!1;if(a)try{let S=await it.readFile(i,"utf-8");c=S.includes(bi)&&S.includes(Lr)}catch{}n.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&c});let u=e.claude.router,d=await b(u);n.push({path:u,type:"file",description:"Claude router",exists:d});let m=as.join(e.claude.config,"prjct-statusline.sh"),p=await b(m);n.push({path:m,type:"file",description:"Status line script",exists:p});let g=e.gemini.router,y=await b(g);n.push({path:g,type:"file",description:"Gemini router",exists:y});let j=as.join(e.gemini.config,"GEMINI.md"),T=await b(j),x=!1;if(T)try{let S=await it.readFile(j,"utf-8");x=S.includes(bi)&&S.includes(Lr)}catch{}return T&&x&&n.push({path:j,type:"section",description:"prjct section in GEMINI.md",exists:!0}),n}async function ZS(n){try{let e=await it.readFile(n,"utf-8");if(!e.includes(bi)||!e.includes(Lr))return!1;let t=e.indexOf(bi),s=e.indexOf(Lr)+Lr.length,r=e.substring(0,t)+e.substring(s);return r=r.replace(/\n{3,}/g,`
1170
+ Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:s}}async _workflowDelete(e,t,s){let r=e.trim();if(!r){let o="Usage: prjct workflow delete <name>";return s.md?console.log(`> ${o}`):f.warn(o),{success:!1,error:o}}try{if(!xe.deleteWorkflow(t,r)){let i=`Workflow '${r}' not found`;return s.md?console.log(`> ${i}`):f.warn(i),{success:!1,error:i}}return await Rl.deleteWorkflowTemplate(r),s.md?console.log(G(Ce("Workflow Deleted",`Deleted workflow: ${r}`))):f.done(`deleted workflow: ${r}`),{success:!0}}catch(o){let i=k(o);return s.md?console.log(`> Error: ${i}`):f.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),s={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await 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=xe.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 Ss(o,i,"before",{projectPath:t});if(!c.success){if(s.md)qp("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 Ss(o,i,"after",{projectPath:t}),s.md?console.log(G(Ce(`Workflow: ${i}`,a.description||""),qe([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):f.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(r){let o=k(r);return s.md?console.log(`> Error: ${o}`):f.fail(o),{success:!1,error:o}}}};l(zS,"buildFlowDiagram")});var Ts,WO,Al=h(()=>{"use strict";ui();cl();pi();_r();li();gl();fi();Tl();ci();Cl();xl();Ts=class{static{l(this,"PrjctCommands")}workflow;planning;shipping;analysis;setupCmds;updateCmds;contextCmds;primitivesCmds;seedCmds;installCmds;captureCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new Vn,this.planning=new Js,this.shipping=new Bs,this.analysis=new Ks,this.setupCmds=new Hn,this.updateCmds=new qn,this.contextCmds=new bs,this.primitivesCmds=new Fn,this.seedCmds=new Qs,this.installCmds=new Ys,this.captureCmds=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 workflowPrefs(e=null,t=process.cwd(),s={}){return this.workflow.workflow(e,t,s)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async ship(e,t=process.cwd(),s={}){return this.shipping.ship(e,t,{...s})}async analyze(e={},t=process.cwd()){return this.analysis.analyze(e,t)}async sync(e=process.cwd(),t={}){return this.analysis.sync(e,t)}async saveLlmAnalysis(e,t=process.cwd(),s={}){return this.analysis.saveLlmAnalysis(e,t,s)}async regenVault(e=process.cwd(),t={}){return this.analysis.regenVault(e,t)}async context(e=null,t=process.cwd(),s={}){return this.contextCmds.context(e,t,s)}async status(e=null,t=process.cwd(),s={}){return this.primitivesCmds.status(e,t,s)}async tag(e=null,t=process.cwd(),s={}){return this.primitivesCmds.tag(e,t,s)}async remember(e=null,t=process.cwd(),s={}){return this.primitivesCmds.remember(e,t,s)}async seed(e=null,t=process.cwd(),s={}){return this.seedCmds.seed(e,t,s)}async install(e=null,t=process.cwd(),s={}){return this.installCmds.install(null,t,s)}async capture(e=null,t=process.cwd(),s={}){return this.captureCmds.capture(e,t,s)}async auth(e=null,t={}){return this.setupCmds.auth(e,t)}async login(e={}){return this.setupCmds.login(e)}async logout(){return this.setupCmds.logout()}async start(){return this.setupCmds.start()}async setup(e={}){return this.setupCmds.setup(e)}async update(e={},t=process.cwd()){return this.updateCmds.update(e,t)}async installStatusLine(){return this.setupCmds.installStatusLine()}showAsciiArt(){this.setupCmds.showAsciiArt()}async initializeAgent(){return this.workflow.initializeAgent()}async ensureProjectInit(e){return this.workflow.ensureProjectInit(e)}async ensureAuthor(){return this.workflow.ensureAuthor()}async getGlobalProjectPath(e){return this.workflow.getGlobalProjectPath(e)}async logToMemory(e,t,s){return this.workflow.logToMemory(e,t,s)}},WO=new Ts});var Il,te,Si=h(()=>{"use strict";de();Re();V();be();Il=class{static{l(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll"]);register(e,t){this.handlers.set(e.name,e),this.setMeta(e.name,t)}registerFn(e,t,s){this.handlerFns.set(e,t),this.setMeta(e,s)}setMeta(e,t){let s=t?.requiresProject??!this.noProjectCommands.has(e);this.metadata.set(e,{name:e,group:t?.group??"unknown",description:t?.description??"",requiresProject:s,usage:t?.usage??{claude:null,terminal:null},implemented:t?.implemented??!0,hasTemplate:t?.hasTemplate??!1,params:t?.params,blockingRules:t?.blockingRules,features:t?.features,isOptional:t?.isOptional,deprecated:t?.deprecated,replacedBy:t?.replacedBy})}registerCategory(e,t){this.categories.set(e,t)}registerMethod(e,t,s,r){let o=t[s];if(typeof o!="function")throw new Error(`${String(s)} is not a function`);let i=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,r)}has(e){return this.handlers.has(e)||this.handlerFns.has(e)}list(){return[...this.handlers.keys(),...this.handlerFns.keys()]}listByGroup(e){return Array.from(this.metadata.entries()).filter(([,t])=>t.group===e).map(([t])=>t)}getGroups(){let e=new Set;for(let t of this.metadata.values())e.add(t.group);return Array.from(e)}getMeta(e){return this.metadata.get(e)}getAll(){return Array.from(this.metadata.values())}getByName(e){return this.metadata.get(e)}getByCategory(e){return this.getAll().filter(t=>t.group===e)}getAllImplemented(){return this.getAll().filter(e=>e.implemented)}getAllWithTemplates(){return this.getAll().filter(e=>e.hasTemplate)}getClaudeCommands(){return this.getAll().filter(e=>e.usage.claude!==null)}getTerminalCommands(){return this.getAll().filter(e=>e.usage.terminal!==null)}getAllCategories(){return new Map(this.categories)}getCategory(e){return this.categories.get(e)}getRequiresInit(){return this.getAll().filter(e=>e.requiresProject)}getWithBlockingRules(){return this.getAll().filter(e=>e.blockingRules!==void 0)}getOptionalCommands(){return this.getAll().filter(e=>e.isOptional)}getDeprecatedCommands(){return this.getAll().filter(e=>e.deprecated)}getStats(){let e=this.getAll(),t={};for(let s of this.categories.keys())t[s]=e.filter(r=>r.group===s).length;return{total:e.length,implemented:e.filter(s=>s.implemented).length,withTemplates:e.filter(s=>s.hasTemplate).length,claudeOnly:e.filter(s=>s.usage.claude&&!s.usage.terminal).length,terminalOnly:e.filter(s=>!s.usage.claude&&s.usage.terminal).length,both:e.filter(s=>s.usage.claude&&s.usage.terminal).length,requiresInit:e.filter(s=>s.requiresProject).length,byCategory:t}}validate(){let e=[],t=this.getAll(),s=t.map(a=>a.name),r=s.filter((a,c)=>s.indexOf(a)!==c);r.length>0&&e.push(`Duplicate command names: ${r.join(", ")}`);let o=t.filter(a=>a.hasTemplate&&!a.implemented);o.length>0&&e.push(`Commands with templates but not implemented: ${o.map(a=>a.name).join(", ")}`);let i=Array.from(this.categories.keys());if(i.length>0){let a=t.filter(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:$.getGlobalProjectPath(t),timestamp:R()}}async execute(e,t,s=process.cwd()){let r=this.metadata.get(e),o;if(r?.requiresProject===!1)o={projectId:"",projectPath:s,globalPath:"",timestamp:R()};else try{o=await this.buildContext(s)}catch(c){return{success:!1,error:k(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 r=this.handlers.get(e);if(r){let i={projectId:"",projectPath:s,globalPath:"",timestamp:R()};return r.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:s,globalPath:"",timestamp:R()};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()}},te=new Il});var Or,Bn,$l=h(()=>{"use strict";Or={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}},Bn=[{name:"init",group:"core",description:"Deep project analysis and initialization",usage:{claude:'/p:init "[idea]"',terminal:'prjct init "[idea]"'},params:"[idea]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0,features:["Architect mode for blank projects","Auto tech stack recommendation","Analyzes existing codebases"]},{name:"task",group:"core",description:"Register a task (or show the active one)",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"[description]",implemented:!0,hasTemplate:!0,requiresProject:!0,features:["No arg \u2192 shows the active task (or none)","Writes to stateStorage; runs before/after workflow rules","Optional Linear issue link when the arg matches `[A-Z]+-\\d+`"]},{name:"ship",group:"core",description:"Commit, push, and celebrate shipped feature",usage:{claude:'/p:ship ["feature"]',terminal:'prjct ship ["feature"]'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["No arg \u2192 ships the active task description, or falls back to current work"]},{name:"sync",group:"core",description:"Sync project state and update workflow agents",usage:{claude:"/p:sync",terminal:"prjct sync [--package=<name>] [--full]"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Incremental sync: only re-analyzes changed files (default)","Force full sync: --full bypasses incremental cache","Monorepo support: --package=<name> for single package sync","Nested PRJCT.md inheritance","Per-package CLAUDE.md generation"]},{name:"regen",group:"core",description:"Full rebuild of the Obsidian vault for the current project",usage:{claude:"/p:regen",terminal:"prjct regen [--md]"},implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!1,features:["Nukes `_generated/` and rebuilds from SQLite + CHANGELOG","Use after upgrading prjct-cli to migrate an old vault layout","Idempotent \u2014 same output if nothing changed"]},{name:"suggest",group:"core",description:"Smart recommendations based on project state",usage:{claude:"/p:suggest",terminal:"prjct suggest"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"status",group:"core",description:"Inline status change on the active task (Linear-style escape hatch)",usage:{claude:"/p:status <value>",terminal:"prjct status <value>"},params:"[value]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["No args \u2192 prints active task + current status","Workflows are the primary status-change mechanism; this is the escape"]},{name:"tag",group:"core",description:"Attach k:v tags to the active task (type:bug, domain:frontend, \u2026)",usage:{claude:"/p:tag type:bug",terminal:"prjct tag type:bug domain:auth"},params:"<pairs...>",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Claude decides what to tag \u2014 no heuristic classifier","type:<feature|bug|improvement|chore> promotes to tasks.type"]},{name:"remember",group:"core",description:"Capture a project memory entry (fact, decision, learning, gotcha, \u2026)",usage:{claude:'/p:remember learning "message"',terminal:'prjct remember learning "message" --tags domain:auth'},params:'<type> "<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Types: fact, decision, learning, gotcha, pattern, anti-pattern, shipped, inbox, todo, idea, insight, question, source, person \u2014 plus user-defined","Grows the project memory consumable via `prjct context memory`"]},{name:"capture",group:"core",description:"GTD-style universal inbox \u2014 dump anything to project memory with zero ceremony",usage:{claude:'/p:capture "<anything>"',terminal:'prjct capture "call Ana re pricing" --tags domain:sales'},params:'"<content>" [--tags k:v,...]',implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Writes memory type=inbox; Claude retypes later via a clarify workflow","No task id, no branch, no worktree \u2014 just persists",'Bare `prjct "<text>"` auto-routes to `capture`']},{name:"seed",group:"core",description:"Manage declarative packs (persona, memory types, workflow slots, hook signals)",usage:{claude:"/p:seed list",terminal:"prjct seed add pm,daily"},params:"[add|remove|list|suggest] [pack,pack,...]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["Packs declare signals only \u2014 no bash is written","Add or remove multi-persona contexts per project","Auto-detect suggestion from project stack"]},{name:"install",group:"core",description:"Install Claude Code hooks (~/.claude/settings.json merge-safe)",usage:{claude:"/p:install",terminal:"prjct install"},params:"",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Writes 7 passive hooks: SessionStart, UserPromptSubmit, \u2026","Idempotent; existing non-prjct hooks stay intact","Remove with `prjct claude uninstall`"]},{name:"help",group:"core",description:"Contextual help and guidance",usage:{claude:"/p:help [topic]",terminal:"prjct help [topic]"},params:"[topic]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"analyze",group:"optional",description:"Analyze repository and sync tasks",usage:{claude:"/p:analyze",terminal:"prjct analyze"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"git",group:"optional",description:"Smart git operations with context",usage:{claude:"/p:git [op]",terminal:"prjct git [op]"},params:"[operation]",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"test",group:"optional",description:"Run tests with auto-fix",usage:{claude:"/p:test",terminal:"prjct test"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"workflow",group:"optional",description:"Configure workflow hooks via natural language",usage:{claude:'/p:workflow ["config"]',terminal:'prjct workflow ["config"]'},params:'["natural language config"]',implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Natural language configuration","Before/after hooks for task, done, ship, sync","Permanent, session, or one-time preferences"]},{name:"start",group:"setup",description:"First-time setup (install commands to editors)",usage:{claude:null,terminal:"prjct start"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"setup",group:"setup",description:"Reconfigure editor installations",usage:{claude:"/p:setup",terminal:"prjct setup"},params:"[--force] [--editor <name>]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"migrate",group:"setup",description:"Migrate project to UUID format + sync",usage:{claude:"/p:migrate",terminal:null},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"login",group:"setup",description:"Authenticate with prjct cloud (opens browser)",usage:{claude:null,terminal:"prjct login [--url <webUrl>]"},params:"[--url <webUrl>]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"logout",group:"setup",description:"Sign out from prjct cloud",usage:{claude:null,terminal:"prjct logout"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"auth",group:"setup",description:"Manage cloud authentication",usage:{claude:"/p:auth [action]",terminal:"prjct auth [action]"},params:"[login|logout|status]",implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"context",group:"setup",description:"Smart context filtering tools for AI agents",usage:{claude:null,terminal:"prjct context <tool> [args]"},params:"<tool> [args]",implemented:!0,hasTemplate:!1,requiresProject:!0,features:["files - Find relevant files for a task","signatures - Extract code structure (~90% compression)","imports - Analyze dependency graphs","recent - Find hot files from git history","summary - Intelligent file summarization"]},{name:"update",group:"setup",description:"Update prjct system-wide: package + migrations + daemon restart",usage:{claude:null,terminal:"prjct update [--dry-run]"},params:"[--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Phase 1: npm update (migrates homebrew \u2192 npm if needed)","Phase 2: All projects \u2014 migrate, sweep, reinstall commands","Phase 3: Daemon stop + restart with new code","--dry-run to preview without changes"]},{name:"uninstall",group:"setup",description:"Complete system removal of prjct",usage:{claude:null,terminal:"prjct uninstall"},params:"[--force] [--backup] [--dry-run]",implemented:!0,hasTemplate:!1,requiresProject:!1,features:["Removes ~/.prjct-cli/ data","Cleans CLAUDE.md prjct section","Uninstalls Homebrew/npm packages","Backup option before deletion"]}]});var Dg={};W(Dg,{UninstallCommands:()=>Fr,uninstall:()=>$g});import{execSync as bi}from"node:child_process";import at from"node:fs/promises";import XS from"node:os";import cs from"node:path";import KS from"node:readline";import ke from"chalk";async function Ag(n){let e=0;try{let t=await at.readdir(n,{withFileTypes:!0});for(let s of t){let r=cs.join(n,s.name);if(s.isDirectory())e+=await Ag(r);else try{let o=await at.stat(r);e+=o.size}catch{}}}catch{}return e}function xg(n){if(n===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(n)/Math.log(1024));return`${(n/1024**t).toFixed(1)} ${e[t]}`}async function YS(n){try{return(await at.readdir(n,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}function QS(){let n={homebrew:!1,npm:!1};try{bi("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(n.homebrew=!0,n.homebrewFormula="prjct-cli")}catch{}try{bi("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(n.npm=!0)}catch{}return n}async function ZS(){let n=[],e=Ha(),t=$.getGlobalBasePath(),s=await b(t),r=s?await YS(cs.join(t,"projects")):0,o=s?await Ag(t):0;n.push({path:t,type:"directory",description:`All project data${r>0?`, ${r} project${r>1?"s":""}`:""}`,size:o,count:r,exists:s});let i=cs.join(e.claude.config,"CLAUDE.md"),a=await b(i),c=!1;if(a)try{let S=await at.readFile(i,"utf-8");c=S.includes(Ti)&&S.includes(Lr)}catch{}n.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&c});let u=e.claude.router,d=await b(u);n.push({path:u,type:"file",description:"Claude router",exists:d});let m=cs.join(e.claude.config,"prjct-statusline.sh"),p=await b(m);n.push({path:m,type:"file",description:"Status line script",exists:p});let g=e.gemini.router,y=await b(g);n.push({path:g,type:"file",description:"Gemini router",exists:y});let j=cs.join(e.gemini.config,"GEMINI.md"),T=await b(j),x=!1;if(T)try{let S=await at.readFile(j,"utf-8");x=S.includes(Ti)&&S.includes(Lr)}catch{}return T&&x&&n.push({path:j,type:"section",description:"prjct section in GEMINI.md",exists:!0}),n}async function eb(n){try{let e=await at.readFile(n,"utf-8");if(!e.includes(Ti)||!e.includes(Lr))return!1;let t=e.indexOf(Ti),s=e.indexOf(Lr)+Lr.length,r=e.substring(0,t)+e.substring(s);return r=r.replace(/\n{3,}/g,`
1171
1171
 
1172
- `).trim(),!r||r.trim().length===0?await it.unlink(n):await it.writeFile(n,`${r}
1173
- `,"utf-8"),!0}catch{return!1}}async function eb(){let n=zS.homedir(),e=new Date().toISOString().replace(/[:.]/g,"-").substring(0,19),t=as.join(n,`.prjct-backup-${e}`);try{await it.mkdir(t,{recursive:!0});let s=$.getGlobalBasePath();return await b(s)&&await Ig(s,as.join(t,".prjct-cli")),t}catch{return null}}async function Ig(n,e){await it.mkdir(e,{recursive:!0});let t=await it.readdir(n,{withFileTypes:!0});for(let s of t){let r=as.join(n,s.name),o=as.join(e,s.name);s.isDirectory()?await Ig(r,o):await it.copyFile(r,o)}}async function tb(n,e,t){let s=[],r=[];for(let o of n)if(o.exists)try{o.type==="section"?await ZS(o.path)&&s.push(o.path):o.type==="directory"?(await it.rm(o.path,{recursive:!0,force:!0}),s.push(o.path)):o.type==="file"&&(await it.unlink(o.path),s.push(o.path))}catch(i){r.push(`${o.path}: ${k(i)}`)}try{await new Ht().cleanupLegacyCommands()}catch{}if(!t.keepPackage){if(e.homebrew&&e.homebrewFormula)try{t.dryRun||Si(`brew uninstall ${e.homebrewFormula}`,{stdio:"pipe"}),s.push("Homebrew: prjct-cli")}catch(o){r.push(`Homebrew: ${k(o)}`)}if(e.npm)try{t.dryRun||Si("npm uninstall -g prjct-cli",{stdio:"pipe"}),s.push("npm: prjct-cli")}catch(o){r.push(`npm: ${k(o)}`)}}return{deleted:s,errors:r}}async function sb(n){let e=XS.createInterface({input:process.stdin,output:process.stdout});return new Promise(t=>{e.question(n,s=>{e.close(),t(s.toLowerCase()==="uninstall")})})}async function $g(n={},e=process.cwd()){let t=await QS(),s=YS(),r=t.filter(c=>c.exists);if(r.length===0&&!s.homebrew&&!s.npm)return console.log(ke.yellow(`
1174
- No prjct installation found.`)),{success:!0,message:"Nothing to uninstall"};let o=r.reduce((c,u)=>c+(u.size||0),0);console.log(""),console.log(ke.red.bold(" WARNING: This action is DANGEROUS and IRREVERSIBLE")),console.log(""),console.log(ke.white("The following will be permanently deleted:")),console.log("");for(let c of r){let u=$.getDisplayPath(c.path),d="";c.type==="section"?d=ke.dim("(section only)"):c.size&&(d=ke.dim(`(${xg(c.size)})`)),console.log(` ${ke.cyan(u.padEnd(35))} ${d}`),console.log(` ${ke.dim(c.description)}`),console.log("")}if(s.homebrew&&(console.log(` ${ke.cyan("Homebrew".padEnd(35))} ${ke.dim("prjct-cli formula")}`),console.log("")),s.npm&&(console.log(` ${ke.cyan("npm global".padEnd(35))} ${ke.dim("prjct-cli package")}`),console.log("")),o>0&&(console.log(ke.dim(` Total size: ${xg(o)}`)),console.log("")),n.dryRun)return console.log(ke.yellow("Dry run - no changes made")),{success:!0,message:"Dry run complete",itemsFound:r.length};if(n.backup){console.log(ke.blue("Creating backup..."));let c=await eb();c?(console.log(ke.green(`Backup created: ${$.getDisplayPath(c)}`)),console.log("")):console.log(ke.yellow("Failed to create backup, continuing..."))}if(!n.force&&(console.log(ke.yellow('Type "uninstall" to confirm:')),!await sb("> ")))return console.log(ke.yellow(`
1175
- Uninstall cancelled.`)),{success:!1,message:"Uninstall cancelled by user"};console.log(""),console.log(ke.blue("Removing prjct..."));let{deleted:i,errors:a}=await tb(t,s,n);if(console.log(""),i.length>0&&console.log(ke.green(`Removed ${i.length} items`)),a.length>0){console.log(ke.yellow(`
1176
- ${a.length} errors:`));for(let c of a)console.log(ke.red(` - ${c}`))}return console.log(""),console.log(ke.green("prjct has been uninstalled.")),console.log(ke.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}}var bi,Lr,Fr,Il=h(()=>{"use strict";Wt();Re();V();J();bt();bi="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",Lr="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";l(Ag,"getDirectorySize");l(xg,"formatSize");l(KS,"countDirectoryItems");l(YS,"detectInstallation");l(QS,"gatherUninstallItems");l(ZS,"removePrjctSection");l(eb,"createBackup");l(Ig,"copyDirectory");l(tb,"performUninstall");l(sb,"promptConfirmation");l($g,"uninstall");Fr=class extends we{static{l(this,"UninstallCommands")}async uninstall(e={},t=process.cwd()){return $g(e,t)}}});function db(){for(let[n,e]of Object.entries(Or))te.registerCategory(n,e)}function pb(){if(te.has("work"))return;db();let n=l(e=>Bn.find(t=>t.name===e),"getMeta");te.registerMethod("task",Mg,"now",n("task")),te.registerMethod("workflow",Mg,"workflow",n("workflow")),te.registerMethod("init",nb,"init",n("init")),te.registerMethod("ship",rb,"ship",n("ship")),te.registerMethod("analyze",Ti,"analyze",n("analyze")),te.registerMethod("analysis-save-llm",Ti,"saveLlmAnalysis",n("analysis-save-llm")),te.registerMethod("sync",Ti,"sync",n("sync")),te.registerMethod("regen",Ti,"regenVault",n("regen")),te.registerMethod("start",Ur,"start",n("start")),te.registerMethod("setup",Ur,"setup",n("setup")),te.registerMethod("login",Ur,"login",n("login")),te.registerMethod("logout",Ur,"logout",n("logout")),te.registerMethod("auth",Ur,"auth",n("auth")),te.registerMethod("uninstall",ib,"uninstall",n("uninstall")),te.registerMethod("update",ab,"update",n("update")),te.registerMethod("context",ob,"context",n("context")),te.registerMethod("status",$l,"status",n("status")),te.registerMethod("tag",$l,"tag",n("tag")),te.registerMethod("remember",$l,"remember",n("remember")),te.registerMethod("seed",cb,"seed",n("seed")),te.registerMethod("install",lb,"install",n("install")),te.registerMethod("capture",ub,"capture",n("capture"))}var Mg,nb,rb,Ti,Ur,ob,$l,ib,ab,cb,lb,ub,Dl=h(()=>{"use strict";li();il();Al();di();_r();ci();pl();vi();gi();Sl();ai();Il();Tl();jl();Mg=new Vn,nb=new Js,rb=new Bs,Ti=new Ks,Ur=new Hn,ob=new bs,$l=new Fn,ib=new Fr,ab=new qn,cb=new Qs,lb=new Ys,ub=new On;l(db,"registerCategories");l(pb,"registerAllCommands");pb()});function Ci(n){return Object.hasOwn(Ei,n)}function _g(n){let e=Ei[n];return e?`'prjct ${n}' was removed in v2.
1172
+ `).trim(),!r||r.trim().length===0?await at.unlink(n):await at.writeFile(n,`${r}
1173
+ `,"utf-8"),!0}catch{return!1}}async function tb(){let n=XS.homedir(),e=new Date().toISOString().replace(/[:.]/g,"-").substring(0,19),t=cs.join(n,`.prjct-backup-${e}`);try{await at.mkdir(t,{recursive:!0});let s=$.getGlobalBasePath();return await b(s)&&await Ig(s,cs.join(t,".prjct-cli")),t}catch{return null}}async function Ig(n,e){await at.mkdir(e,{recursive:!0});let t=await at.readdir(n,{withFileTypes:!0});for(let s of t){let r=cs.join(n,s.name),o=cs.join(e,s.name);s.isDirectory()?await Ig(r,o):await at.copyFile(r,o)}}async function sb(n,e,t){let s=[],r=[];for(let o of n)if(o.exists)try{o.type==="section"?await eb(o.path)&&s.push(o.path):o.type==="directory"?(await at.rm(o.path,{recursive:!0,force:!0}),s.push(o.path)):o.type==="file"&&(await at.unlink(o.path),s.push(o.path))}catch(i){r.push(`${o.path}: ${k(i)}`)}try{await new Ht().cleanupLegacyCommands()}catch{}if(!t.keepPackage){if(e.homebrew&&e.homebrewFormula)try{t.dryRun||bi(`brew uninstall ${e.homebrewFormula}`,{stdio:"pipe"}),s.push("Homebrew: prjct-cli")}catch(o){r.push(`Homebrew: ${k(o)}`)}if(e.npm)try{t.dryRun||bi("npm uninstall -g prjct-cli",{stdio:"pipe"}),s.push("npm: prjct-cli")}catch(o){r.push(`npm: ${k(o)}`)}}return{deleted:s,errors:r}}async function nb(n){let e=KS.createInterface({input:process.stdin,output:process.stdout});return new Promise(t=>{e.question(n,s=>{e.close(),t(s.toLowerCase()==="uninstall")})})}async function $g(n={},e=process.cwd()){let t=await ZS(),s=QS(),r=t.filter(c=>c.exists);if(r.length===0&&!s.homebrew&&!s.npm)return console.log(ke.yellow(`
1174
+ No prjct installation found.`)),{success:!0,message:"Nothing to uninstall"};let o=r.reduce((c,u)=>c+(u.size||0),0);console.log(""),console.log(ke.red.bold(" WARNING: This action is DANGEROUS and IRREVERSIBLE")),console.log(""),console.log(ke.white("The following will be permanently deleted:")),console.log("");for(let c of r){let u=$.getDisplayPath(c.path),d="";c.type==="section"?d=ke.dim("(section only)"):c.size&&(d=ke.dim(`(${xg(c.size)})`)),console.log(` ${ke.cyan(u.padEnd(35))} ${d}`),console.log(` ${ke.dim(c.description)}`),console.log("")}if(s.homebrew&&(console.log(` ${ke.cyan("Homebrew".padEnd(35))} ${ke.dim("prjct-cli formula")}`),console.log("")),s.npm&&(console.log(` ${ke.cyan("npm global".padEnd(35))} ${ke.dim("prjct-cli package")}`),console.log("")),o>0&&(console.log(ke.dim(` Total size: ${xg(o)}`)),console.log("")),n.dryRun)return console.log(ke.yellow("Dry run - no changes made")),{success:!0,message:"Dry run complete",itemsFound:r.length};if(n.backup){console.log(ke.blue("Creating backup..."));let c=await tb();c?(console.log(ke.green(`Backup created: ${$.getDisplayPath(c)}`)),console.log("")):console.log(ke.yellow("Failed to create backup, continuing..."))}if(!n.force&&(console.log(ke.yellow('Type "uninstall" to confirm:')),!await nb("> ")))return console.log(ke.yellow(`
1175
+ Uninstall cancelled.`)),{success:!1,message:"Uninstall cancelled by user"};console.log(""),console.log(ke.blue("Removing prjct..."));let{deleted:i,errors:a}=await sb(t,s,n);if(console.log(""),i.length>0&&console.log(ke.green(`Removed ${i.length} items`)),a.length>0){console.log(ke.yellow(`
1176
+ ${a.length} errors:`));for(let c of a)console.log(ke.red(` - ${c}`))}return console.log(""),console.log(ke.green("prjct has been uninstalled.")),console.log(ke.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}}var Ti,Lr,Fr,Dl=h(()=>{"use strict";Wt();Re();V();J();bt();Ti="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",Lr="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";l(Ag,"getDirectorySize");l(xg,"formatSize");l(YS,"countDirectoryItems");l(QS,"detectInstallation");l(ZS,"gatherUninstallItems");l(eb,"removePrjctSection");l(tb,"createBackup");l(Ig,"copyDirectory");l(sb,"performUninstall");l(nb,"promptConfirmation");l($g,"uninstall");Fr=class extends we{static{l(this,"UninstallCommands")}async uninstall(e={},t=process.cwd()){return $g(e,t)}}});function pb(){for(let[n,e]of Object.entries(Or))te.registerCategory(n,e)}function mb(){if(te.has("work"))return;pb();let n=l(e=>Bn.find(t=>t.name===e),"getMeta");te.registerMethod("task",Mg,"now",n("task")),te.registerMethod("workflow",Mg,"workflow",n("workflow")),te.registerMethod("init",rb,"init",n("init")),te.registerMethod("ship",ob,"ship",n("ship")),te.registerMethod("analyze",Ei,"analyze",n("analyze")),te.registerMethod("analysis-save-llm",Ei,"saveLlmAnalysis",n("analysis-save-llm")),te.registerMethod("sync",Ei,"sync",n("sync")),te.registerMethod("regen",Ei,"regenVault",n("regen")),te.registerMethod("start",Ur,"start",n("start")),te.registerMethod("setup",Ur,"setup",n("setup")),te.registerMethod("login",Ur,"login",n("login")),te.registerMethod("logout",Ur,"logout",n("logout")),te.registerMethod("auth",Ur,"auth",n("auth")),te.registerMethod("uninstall",ab,"uninstall",n("uninstall")),te.registerMethod("update",cb,"update",n("update")),te.registerMethod("context",ib,"context",n("context")),te.registerMethod("status",Ml,"status",n("status")),te.registerMethod("tag",Ml,"tag",n("tag")),te.registerMethod("remember",Ml,"remember",n("remember")),te.registerMethod("seed",lb,"seed",n("seed")),te.registerMethod("install",ub,"install",n("install")),te.registerMethod("capture",db,"capture",n("capture"))}var Mg,rb,ob,Ei,Ur,ib,Ml,ab,cb,lb,ub,db,_l=h(()=>{"use strict";ui();cl();$l();pi();_r();li();gl();Si();fi();Tl();ci();Dl();Cl();xl();Mg=new Vn,rb=new Js,ob=new Bs,Ei=new Ks,Ur=new Hn,ib=new bs,Ml=new Fn,ab=new Fr,cb=new qn,lb=new Qs,ub=new Ys,db=new On;l(pb,"registerCategories");l(mb,"registerAllCommands");mb()});function Pi(n){return Object.hasOwn(Ci,n)}function _g(n){let e=Ci[n];return e?`'prjct ${n}' was removed in v2.
1177
1177
  \u2192 Use: ${e.replacement}
1178
- ${e.note}`:null}var Ei,Ml=h(()=>{"use strict";Ei={done:{replacement:"prjct status done",note:"Mark the active task complete via the v2 status primitive."},pause:{replacement:"prjct status paused",note:"Pause the active task via the v2 status primitive."},resume:{replacement:"prjct status active",note:"Resume the active task via the v2 status primitive."},reopen:{replacement:"prjct status active",note:"Reopen a completed task by setting status back to active."},next:{replacement:"prjct status",note:"Queue view is not part of v2. Use status for the active task."},dash:{replacement:"prjct status",note:"The dash command was removed. Use status, or open the web dashboard."},bug:{replacement:'prjct capture "<description>" --tags bug',note:"Bugs are captured via the GTD inbox with a tag in v2."},idea:{replacement:'prjct capture "<description>" --tags idea',note:"Ideas are captured via the GTD inbox with a tag in v2."},linear:{replacement:"MCP server (see `prjct seed list`)",note:"Native Linear CLI was removed; integration is now via MCP."},jira:{replacement:"MCP server (see `prjct seed list`)",note:"Native Jira CLI was removed; integration is now via MCP."},tokens:{replacement:"prjct status",note:"Token tracking was removed in v2."},velocity:{replacement:"prjct status",note:"Velocity reports were removed in v2."},plan:{replacement:"prjct init",note:"Planning is now part of init/task flow."}};l(Ci,"isRemovedVerb");l(_g,"migrationMessage")});var Lg={};W(Lg,{startDaemon:()=>hb});import ve from"node:fs";import{createServer as mb}from"node:net";async function hb(n){process.env.PRJCT_IN_DAEMON="1";let e=Ee.socket(),t=Ee.pid(),s=Ee.runDir();if(ve.mkdirSync(s,{recursive:!0}),ve.existsSync(t)){let i=parseInt(ve.readFileSync(t,"utf-8").trim(),10);Sb(i)&&(console.error(`Daemon already running (PID ${i})`),process.exit(1)),ve.unlinkSync(t)}ve.existsSync(e)&&ve.unlinkSync(e),Eb();let r=bb(),o=null;if(r)try{o=ve.statSync(r).mtimeMs}catch{}if(Wr=Cb(),ye={startedAt:Date.now(),commandsServed:0,lastActivity:Date.now(),idleTimeoutMs:Ai,idleTimer:null,entryPath:r,entryMtime:o},Tt=new Ts,Jn=mb(i=>yb(i)),Jn.listen(e,()=>{ve.chmodSync(e,384),ve.writeFileSync(t,String(process.pid)),console.log(`prjct daemon started (PID ${process.pid})`),console.log(` Socket: ${e}`),r&&console.log(` Watching: ${r}`),Ng()}),Jn.on("error",i=>{console.error("Daemon socket error:",i.message),en(1)}),!n.noHttp)try{let i=process.cwd(),a=await I.getProjectId(i);if(a){let c=n.port||yo;Hr=ho({port:c,projectId:a,projectPath:i,enableLogging:!1}),await Hr.start()}}catch{}if(process.on("SIGTERM",()=>en(0)),process.on("SIGINT",()=>en(0)),process.on("SIGHUP",()=>{Tt=new Ts,console.log("Daemon reloaded (SIGHUP)")}),!n.foreground)try{process.stdin?.unref?.()}catch{}}function yb(n){let e="";n.on("data",async t=>{if(e+=t.toString(),e.length>Ii){let r={id:"unknown",success:!1,exitCode:1,stderr:"Request too large"};n.write(js(r)),n.destroy(),e="";return}let s;for(;(s=e.indexOf(`
1179
- `))!==-1;){let r=e.slice(0,s);if(e=e.slice(s+1),!!r.trim())try{let o=JSON.parse(r),i=await wb(o);n.write(js(i))}catch(o){let i={id:"unknown",success:!1,exitCode:1,stderr:`Protocol error: ${o.message}`};n.write(js(i))}}}),n.on("error",()=>{})}async function wb(n){if(!ye||!Tt)return{id:n.id,success:!1,exitCode:1,stderr:"Daemon not initialized"};if(Ng(),ye.commandsServed++,ye.lastActivity=Date.now(),ye.commandsServed%gb===0&&L.checkpointAll(),Og()&&(console.log("Build changed detected \u2014 daemon will restart after this request"),setTimeout(()=>{console.log("Daemon shutting down for code reload..."),en(0)},200)),Wr&&ye.commandsServed%fb===0&&Pb()&&(console.log(`Version drift detected \u2014 daemon v${Wr} is stale; shutting down so the next request spawns fresh.`),setTimeout(()=>en(0),200)),n.command==="daemon")return vb(n);if(n.command==="__ping")return{id:n.id,success:!0,exitCode:0,result:{pong:!0,pid:process.pid}};try{let e=[],t=[],s=console.log,r=console.error;console.log=(...o)=>e.push(o.map(String).join(" ")),console.error=(...o)=>t.push(o.map(String).join(" "));try{let o=await kb(n);return{id:n.id,success:o.success,exitCode:o.success?0:1,stdout:e.join(`
1178
+ ${e.note}`:null}var Ci,Nl=h(()=>{"use strict";Ci={done:{replacement:"prjct status done",note:"Mark the active task complete via the v2 status primitive."},pause:{replacement:"prjct status paused",note:"Pause the active task via the v2 status primitive."},resume:{replacement:"prjct status active",note:"Resume the active task via the v2 status primitive."},reopen:{replacement:"prjct status active",note:"Reopen a completed task by setting status back to active."},next:{replacement:"prjct status",note:"Queue view is not part of v2. Use status for the active task."},dash:{replacement:"prjct status",note:"The dash command was removed. Use status, or open the web dashboard."},bug:{replacement:'prjct capture "<description>" --tags bug',note:"Bugs are captured via the GTD inbox with a tag in v2."},idea:{replacement:'prjct capture "<description>" --tags idea',note:"Ideas are captured via the GTD inbox with a tag in v2."},linear:{replacement:"MCP server (see `prjct seed list`)",note:"Native Linear CLI was removed; integration is now via MCP."},jira:{replacement:"MCP server (see `prjct seed list`)",note:"Native Jira CLI was removed; integration is now via MCP."},tokens:{replacement:"prjct status",note:"Token tracking was removed in v2."},velocity:{replacement:"prjct status",note:"Velocity reports were removed in v2."},plan:{replacement:"prjct init",note:"Planning is now part of init/task flow."}};l(Pi,"isRemovedVerb");l(_g,"migrationMessage")});var Lg={};W(Lg,{startDaemon:()=>yb});import ve from"node:fs";import{createServer as gb}from"node:net";async function yb(n){process.env.PRJCT_IN_DAEMON="1";let e=Ee.socket(),t=Ee.pid(),s=Ee.runDir();if(ve.mkdirSync(s,{recursive:!0}),ve.existsSync(t)){let i=parseInt(ve.readFileSync(t,"utf-8").trim(),10);bb(i)&&(console.error(`Daemon already running (PID ${i})`),process.exit(1)),ve.unlinkSync(t)}ve.existsSync(e)&&ve.unlinkSync(e),Cb();let r=Tb(),o=null;if(r)try{o=ve.statSync(r).mtimeMs}catch{}if(Wr=Pb(),ye={startedAt:Date.now(),commandsServed:0,lastActivity:Date.now(),idleTimeoutMs:Ii,idleTimer:null,entryPath:r,entryMtime:o},Tt=new Ts,Jn=gb(i=>wb(i)),Jn.listen(e,()=>{ve.chmodSync(e,384),ve.writeFileSync(t,String(process.pid)),console.log(`prjct daemon started (PID ${process.pid})`),console.log(` Socket: ${e}`),r&&console.log(` Watching: ${r}`),Ng()}),Jn.on("error",i=>{console.error("Daemon socket error:",i.message),en(1)}),!n.noHttp)try{let i=process.cwd(),a=await I.getProjectId(i);if(a){let c=n.port||wo;Hr=yo({port:c,projectId:a,projectPath:i,enableLogging:!1}),await Hr.start()}}catch{}if(process.on("SIGTERM",()=>en(0)),process.on("SIGINT",()=>en(0)),process.on("SIGHUP",()=>{Tt=new Ts,console.log("Daemon reloaded (SIGHUP)")}),!n.foreground)try{process.stdin?.unref?.()}catch{}}function wb(n){let e="";n.on("data",async t=>{if(e+=t.toString(),e.length>$i){let r={id:"unknown",success:!1,exitCode:1,stderr:"Request too large"};n.write(js(r)),n.destroy(),e="";return}let s;for(;(s=e.indexOf(`
1179
+ `))!==-1;){let r=e.slice(0,s);if(e=e.slice(s+1),!!r.trim())try{let o=JSON.parse(r),i=await kb(o);n.write(js(i))}catch(o){let i={id:"unknown",success:!1,exitCode:1,stderr:`Protocol error: ${o.message}`};n.write(js(i))}}}),n.on("error",()=>{})}async function kb(n){if(!ye||!Tt)return{id:n.id,success:!1,exitCode:1,stderr:"Daemon not initialized"};if(Ng(),ye.commandsServed++,ye.lastActivity=Date.now(),ye.commandsServed%fb===0&&L.checkpointAll(),Og()&&(console.log("Build changed detected \u2014 daemon will restart after this request"),setTimeout(()=>{console.log("Daemon shutting down for code reload..."),en(0)},200)),Wr&&ye.commandsServed%hb===0&&jb()&&(console.log(`Version drift detected \u2014 daemon v${Wr} is stale; shutting down so the next request spawns fresh.`),setTimeout(()=>en(0),200)),n.command==="daemon")return Sb(n);if(n.command==="__ping")return{id:n.id,success:!0,exitCode:0,result:{pong:!0,pid:process.pid}};try{let e=[],t=[],s=console.log,r=console.error;console.log=(...o)=>e.push(o.map(String).join(" ")),console.error=(...o)=>t.push(o.map(String).join(" "));try{let o=await vb(n);return{id:n.id,success:o.success,exitCode:o.success?0:1,stdout:e.join(`
1180
1180
  `)||o.message||void 0,stderr:t.join(`
1181
- `)||o.error||void 0,result:o}}finally{console.log=s,console.error=r}}catch(e){return{id:n.id,success:!1,exitCode:1,stderr:e.message}}}async function kb(n){let e=n.args.join(" ")||null,t=n.options,s=t.md===!0;if(Ci(n.command)&&!te.getByName(n.command))return{success:!1,error:_g(n.command)??`'${n.command}' was removed in v2.`};switch(n.command){case"sync":return Tt.sync(n.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"task":return Tt.task(e,n.cwd,{md:s});case"ship":{let r=typeof t.intent=="string"?t.intent:void 0;return Tt.ship(e,n.cwd,{md:s,intent:r,skipHooks:t["skip-hooks"]===!0})}case"workflow":return Tt.workflowPrefs(e,n.cwd,{md:s});case"analyze":return Tt.analyze(t,n.cwd);case"analysis-save-llm":return e?Tt.saveLlmAnalysis(e,n.cwd,{md:s}):{success:!1,error:"analysis-save-llm requires a JSON payload as positional arg"};case"status":return Tt.status(e,n.cwd,{md:s});case"tag":return Tt.tag(e,n.cwd,{md:s});case"remember":return Tt.remember(e,n.cwd,{md:s,tags:t.tags?String(t.tags):void 0});default:return te.execute(n.command,e,n.cwd)}}function vb(n){let e=n.args[0];if(e==="status")return{id:n.id,success:!0,exitCode:0,result:{running:!0,pid:process.pid,socketPath:Ee.socket(),uptime:ye?Date.now()-ye.startedAt:0,commandsServed:ye?.commandsServed??0,lastActivity:ye?new Date(ye.lastActivity).toISOString():null,registeredCommands:te.list().length,stale:Og()}};if(e==="stop"){let t={id:n.id,success:!0,exitCode:0,stdout:"Daemon stopping..."};return setTimeout(()=>en(0),100),t}return{id:n.id,success:!1,exitCode:1,stderr:`Unknown daemon command: ${e}. Use: status, stop`}}function Ng(){ye&&(ye.idleTimer&&clearTimeout(ye.idleTimer),ye.idleTimer=setTimeout(()=>{console.log(`Daemon idle for ${ye.idleTimeoutMs/1e3/60} minutes, shutting down`),en(0)},ye.idleTimeoutMs),ye.idleTimer.unref&&ye.idleTimer.unref())}function en(n){console.log("Daemon shutting down..."),ye?.idleTimer&&clearTimeout(ye.idleTimer),Hr&&(Hr.stop(),Hr=null),Jn&&(Jn.close(),Jn=null),L.close();let e=Ee.socket(),t=Ee.pid();try{ve.existsSync(e)&&ve.unlinkSync(e)}catch{}try{ve.existsSync(t)&&ve.unlinkSync(t)}catch{}process.exit(n)}function Sb(n){try{return process.kill(n,0),!0}catch{return!1}}function bb(){let n=Je("node:path"),e=__dirname;for(let r=0;r<5;r++){if(ve.existsSync(n.join(e,"package.json"))){let o=n.join(e,"dist","daemon","entry.mjs");if(ve.existsSync(o))return o;break}e=n.dirname(e)}let t=[n.join(__dirname,"..","daemon","entry.mjs"),n.join(__dirname,"..","dist","daemon","entry.mjs")];for(let r of t)if(ve.existsSync(r))return r;let s=process.argv[1];return s&&ve.existsSync(s)?s:null}function Eb(){let n=Ee.log();try{if(ve.statSync(n).size>Tb){let t=`${n}.1`;try{ve.unlinkSync(t)}catch{}ve.renameSync(n,t)}}catch{}}function Og(){if(!ye?.entryPath||ye.entryMtime===null)return!1;try{return ve.statSync(ye.entryPath).mtimeMs!==ye.entryMtime}catch{return!1}}function Cb(){let n=Je("node:path"),e=__dirname;for(let t=0;t<6;t++){let s=n.join(e,"package.json");try{let o=JSON.parse(ve.readFileSync(s,"utf-8"));if(o?.name==="prjct-cli"&&typeof o.version=="string")return o.version}catch{}let r=n.dirname(e);if(r===e)break;e=r}return null}function Pb(){if(!Wr)return!1;let n=Je("node:os"),e=Je("node:path"),t=n.homedir(),s=[`${t}/Library/pnpm/prjct`,`${t}/.local/share/pnpm/prjct`,`${t}/.npm-global/bin/prjct`,"/usr/local/bin/prjct","/opt/homebrew/bin/prjct",`${t}/.volta/bin/prjct`,`${t}/.asdf/shims/prjct`];for(let r of s){let o;try{o=ve.realpathSync(r)}catch{continue}let i=e.dirname(o);for(let a=0;a<6;a++){let c=e.join(i,"package.json");try{let d=JSON.parse(ve.readFileSync(c,"utf-8"));if(d?.name==="prjct-cli"&&typeof d.version=="string")return d.version!==Wr}catch{}let u=e.dirname(i);if(u===i)break;i=u}}return!1}var gb,fb,Jn,Hr,Tt,ye,Wr,Tb,Fg=h(()=>{"use strict";Rl();vi();Dl();Ml();de();Pa();ce();Gr();gb=50,fb=10,Jn=null,Hr=null,Tt=null,ye=null,Wr=null;l(hb,"startDaemon");l(yb,"handleConnection");l(wb,"handleRequest");l(kb,"executeCommand");l(vb,"handleDaemonCommand");l(Ng,"resetIdleTimer");l(en,"shutdown");l(Sb,"isProcessRunning");l(bb,"resolveEntryPath");Tb=1024*1024;l(Eb,"rotateLog");l(Og,"isCodeStale");l(Cb,"readOwnPackageVersion");l(Pb,"isGlobalVersionDrifted")});var Wg={};W(Wg,{runStart:()=>Nb});import Gt from"node:fs/promises";import Ug from"node:os";import qt from"node:path";import H from"chalk";function xb(){console.clear(),console.log(jb),console.log(Rb)}function Hg(n,e){console.log(`
1181
+ `)||o.error||void 0,result:o}}finally{console.log=s,console.error=r}}catch(e){return{id:n.id,success:!1,exitCode:1,stderr:e.message}}}async function vb(n){let e=n.args.join(" ")||null,t=n.options,s=t.md===!0;if(Pi(n.command)&&!te.getByName(n.command))return{success:!1,error:_g(n.command)??`'${n.command}' was removed in v2.`};switch(n.command){case"sync":return Tt.sync(n.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"task":return Tt.task(e,n.cwd,{md:s});case"ship":{let r=typeof t.intent=="string"?t.intent:void 0;return Tt.ship(e,n.cwd,{md:s,intent:r,skipHooks:t["skip-hooks"]===!0})}case"workflow":return Tt.workflowPrefs(e,n.cwd,{md:s});case"analyze":return Tt.analyze(t,n.cwd);case"analysis-save-llm":return e?Tt.saveLlmAnalysis(e,n.cwd,{md:s}):{success:!1,error:"analysis-save-llm requires a JSON payload as positional arg"};case"status":return Tt.status(e,n.cwd,{md:s});case"tag":return Tt.tag(e,n.cwd,{md:s});case"remember":return Tt.remember(e,n.cwd,{md:s,tags:t.tags?String(t.tags):void 0});default:return te.execute(n.command,e,n.cwd)}}function Sb(n){let e=n.args[0];if(e==="status")return{id:n.id,success:!0,exitCode:0,result:{running:!0,pid:process.pid,socketPath:Ee.socket(),uptime:ye?Date.now()-ye.startedAt:0,commandsServed:ye?.commandsServed??0,lastActivity:ye?new Date(ye.lastActivity).toISOString():null,registeredCommands:te.list().length,stale:Og()}};if(e==="stop"){let t={id:n.id,success:!0,exitCode:0,stdout:"Daemon stopping..."};return setTimeout(()=>en(0),100),t}return{id:n.id,success:!1,exitCode:1,stderr:`Unknown daemon command: ${e}. Use: status, stop`}}function Ng(){ye&&(ye.idleTimer&&clearTimeout(ye.idleTimer),ye.idleTimer=setTimeout(()=>{console.log(`Daemon idle for ${ye.idleTimeoutMs/1e3/60} minutes, shutting down`),en(0)},ye.idleTimeoutMs),ye.idleTimer.unref&&ye.idleTimer.unref())}function en(n){console.log("Daemon shutting down..."),ye?.idleTimer&&clearTimeout(ye.idleTimer),Hr&&(Hr.stop(),Hr=null),Jn&&(Jn.close(),Jn=null),L.close();let e=Ee.socket(),t=Ee.pid();try{ve.existsSync(e)&&ve.unlinkSync(e)}catch{}try{ve.existsSync(t)&&ve.unlinkSync(t)}catch{}process.exit(n)}function bb(n){try{return process.kill(n,0),!0}catch{return!1}}function Tb(){let n=Je("node:path"),e=__dirname;for(let r=0;r<5;r++){if(ve.existsSync(n.join(e,"package.json"))){let o=n.join(e,"dist","daemon","entry.mjs");if(ve.existsSync(o))return o;break}e=n.dirname(e)}let t=[n.join(__dirname,"..","daemon","entry.mjs"),n.join(__dirname,"..","dist","daemon","entry.mjs")];for(let r of t)if(ve.existsSync(r))return r;let s=process.argv[1];return s&&ve.existsSync(s)?s:null}function Cb(){let n=Ee.log();try{if(ve.statSync(n).size>Eb){let t=`${n}.1`;try{ve.unlinkSync(t)}catch{}ve.renameSync(n,t)}}catch{}}function Og(){if(!ye?.entryPath||ye.entryMtime===null)return!1;try{return ve.statSync(ye.entryPath).mtimeMs!==ye.entryMtime}catch{return!1}}function Pb(){let n=Je("node:path"),e=__dirname;for(let t=0;t<6;t++){let s=n.join(e,"package.json");try{let o=JSON.parse(ve.readFileSync(s,"utf-8"));if(o?.name==="prjct-cli"&&typeof o.version=="string")return o.version}catch{}let r=n.dirname(e);if(r===e)break;e=r}return null}function jb(){if(!Wr)return!1;let n=Je("node:os"),e=Je("node:path"),t=n.homedir(),s=[`${t}/Library/pnpm/prjct`,`${t}/.local/share/pnpm/prjct`,`${t}/.npm-global/bin/prjct`,"/usr/local/bin/prjct","/opt/homebrew/bin/prjct",`${t}/.volta/bin/prjct`,`${t}/.asdf/shims/prjct`];for(let r of s){let o;try{o=ve.realpathSync(r)}catch{continue}let i=e.dirname(o);for(let a=0;a<6;a++){let c=e.join(i,"package.json");try{let d=JSON.parse(ve.readFileSync(c,"utf-8"));if(d?.name==="prjct-cli"&&typeof d.version=="string")return d.version!==Wr}catch{}let u=e.dirname(i);if(u===i)break;i=u}}return!1}var fb,hb,Jn,Hr,Tt,ye,Wr,Eb,Fg=h(()=>{"use strict";Al();Si();_l();Nl();de();Ra();ce();Gr();fb=50,hb=10,Jn=null,Hr=null,Tt=null,ye=null,Wr=null;l(yb,"startDaemon");l(wb,"handleConnection");l(kb,"handleRequest");l(vb,"executeCommand");l(Sb,"handleDaemonCommand");l(Ng,"resetIdleTimer");l(en,"shutdown");l(bb,"isProcessRunning");l(Tb,"resolveEntryPath");Eb=1024*1024;l(Cb,"rotateLog");l(Og,"isCodeStale");l(Pb,"readOwnPackageVersion");l(jb,"isGlobalVersionDrifted")});var Wg={};W(Wg,{runStart:()=>Ob});import Gt from"node:fs/promises";import Ug from"node:os";import qt from"node:path";import H from"chalk";function Ab(){console.clear(),console.log(Rb),console.log(xb)}function Hg(n,e){console.log(`
1182
1182
  ${H.bold(" Select AI providers to configure:")}
1183
1183
  `),console.log(` ${H.dim("(Use arrow keys to navigate, space to toggle, enter to confirm)")}
1184
- `),n.forEach((t,s)=>{let r=s===e?H.cyan("\u276F"):" ",o=t.selected?H.green("[\u2713]"):H.dim("[ ]"),i=t.installed?H.green("(installed)"):H.yellow("(will install)"),a=s===e?H.bold(t.displayName):t.displayName;console.log(` ${r} ${o} ${a} ${i}`)}),console.log("")}async function Ab(){let n=await us(),e=[{name:"claude",displayName:"Claude Code",installed:n.claude.installed,selected:n.claude.installed},{name:"gemini",displayName:"Gemini CLI",installed:n.gemini.installed,selected:n.gemini.installed},{name:"codex",displayName:"OpenAI Codex",installed:n.codex.installed,selected:n.codex.installed}];return e.some(t=>t.selected)||(e[0].selected=!0),process.stdin.isTTY?new Promise(t=>{let s=0,r=l(()=>{process.stdout.write("\x1B[8A"),process.stdout.write("\x1B[0J"),Hg(e,s)},"render");Hg(e,s),process.stdin.setRawMode(!0),process.stdin.resume(),process.stdin.setEncoding("utf8");let o=l(()=>{process.stdin.setRawMode(!1),process.stdin.removeListener("data",i),process.stdin.pause()},"cleanup"),i=l(a=>{if(a===""&&(o(),console.log(`
1184
+ `),n.forEach((t,s)=>{let r=s===e?H.cyan("\u276F"):" ",o=t.selected?H.green("[\u2713]"):H.dim("[ ]"),i=t.installed?H.green("(installed)"):H.yellow("(will install)"),a=s===e?H.bold(t.displayName):t.displayName;console.log(` ${r} ${o} ${a} ${i}`)}),console.log("")}async function Ib(){let n=await Zt(),e=[{name:"claude",displayName:"Claude Code",installed:n.claude.installed,selected:n.claude.installed},{name:"gemini",displayName:"Gemini CLI",installed:n.gemini.installed,selected:n.gemini.installed},{name:"codex",displayName:"OpenAI Codex",installed:n.codex.installed,selected:n.codex.installed}];return e.some(t=>t.selected)||(e[0].selected=!0),process.stdin.isTTY?new Promise(t=>{let s=0,r=l(()=>{process.stdout.write("\x1B[8A"),process.stdout.write("\x1B[0J"),Hg(e,s)},"render");Hg(e,s),process.stdin.setRawMode(!0),process.stdin.resume(),process.stdin.setEncoding("utf8");let o=l(()=>{process.stdin.setRawMode(!1),process.stdin.removeListener("data",i),process.stdin.pause()},"cleanup"),i=l(a=>{if(a===""&&(o(),console.log(`
1185
1185
  Cancelled.
1186
1186
  `),process.exit(0)),a==="\r"||a===`
1187
1187
  `){o();let c=e.filter(u=>u.selected).map(u=>u.name);t(c.length>0?c:["claude"]);return}a==="\x1B[A"&&(s=Math.max(0,s-1),r()),a==="\x1B[B"&&(s=Math.min(e.length-1,s+1),r()),a===" "&&(e[s].selected=!e[s].selected,r())},"handleKey");process.stdin.on("data",i)}):(console.log(`
1188
1188
  ${H.bold(" Detected providers:")}
1189
- `),e.forEach(t=>{t.installed&&console.log(` ${H.green("\u2713")} ${t.displayName}`)}),console.log(""),e.filter(t=>t.selected).map(t=>t.name))}async function Ib(n){let e=ut[n];if(!e.configDir)return!1;try{let t=qt.join(e.configDir,"commands");await Gt.mkdir(t,{recursive:!0});let{getPackageRoot:s}=await Promise.resolve().then(()=>(ze(),an)),r=s(),o=n==="claude"?"p.md":"p.toml",i=qt.join(r,"templates","commands",o),a=qt.join(t,o);return await b(i)?(await Gt.copyFile(i,a),!0):!1}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install ${n} router: ${k(t)}`),!1}}async function $b(n){let e=ut[n];if(!e.configDir)return!1;try{let t=n==="gemini"?qt.join(e.configDir,"commands"):qt.join(e.configDir,"commands","p");await Gt.mkdir(t,{recursive:!0});let s=new Set(["p.md","p.toml"]),o=vn("commands/").filter(i=>i.endsWith(".md")).map(i=>i.replace("commands/","")).filter(i=>!s.has(i));for(let i of o){let a=dt(`commands/${i}`);a&&await Gt.writeFile(qt.join(t,i),a,"utf-8")}return!0}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install ${n} subcommands: ${k(t)}`),!1}}async function Db(n){let e=ut[n];if(!e.configDir)return!1;if(n==="claude")try{let{installGlobalConfig:t}=await Promise.resolve().then(()=>(Wt(),jd));return(await t()).success}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install claude config: ${k(t)}`),!1}try{await Gt.mkdir(e.configDir,{recursive:!0});let{getPackageRoot:t}=await Promise.resolve().then(()=>(ze(),an)),s=t(),r="GEMINI.md",o=qt.join(s,"templates","global",r),i=qt.join(e.configDir,r);if(await b(o)){let a=await Gt.readFile(o,"utf-8");if(await b(i)){let c=await Gt.readFile(i,"utf-8"),u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",d="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(c.includes(u)&&c.includes(d)){let m=c.substring(0,c.indexOf(u)),p=c.substring(c.indexOf(d)+d.length),g=a.substring(a.indexOf(u),a.indexOf(d)+d.length);await Gt.writeFile(i,m+g+p)}else await Gt.writeFile(i,`${c}
1189
+ `),e.forEach(t=>{t.installed&&console.log(` ${H.green("\u2713")} ${t.displayName}`)}),console.log(""),e.filter(t=>t.selected).map(t=>t.name))}async function $b(n){let e=et[n];if(!e.configDir)return!1;try{let t=qt.join(e.configDir,"commands");await Gt.mkdir(t,{recursive:!0});let{getPackageRoot:s}=await Promise.resolve().then(()=>(ze(),an)),r=s(),o=n==="claude"?"p.md":"p.toml",i=qt.join(r,"templates","commands",o),a=qt.join(t,o);return await b(i)?(await Gt.copyFile(i,a),!0):!1}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install ${n} router: ${k(t)}`),!1}}async function Db(n){let e=et[n];if(!e.configDir)return!1;try{let t=n==="gemini"?qt.join(e.configDir,"commands"):qt.join(e.configDir,"commands","p");await Gt.mkdir(t,{recursive:!0});let s=new Set(["p.md","p.toml"]),o=vn("commands/").filter(i=>i.endsWith(".md")).map(i=>i.replace("commands/","")).filter(i=>!s.has(i));for(let i of o){let a=dt(`commands/${i}`);a&&await Gt.writeFile(qt.join(t,i),a,"utf-8")}return!0}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install ${n} subcommands: ${k(t)}`),!1}}async function Mb(n){let e=et[n];if(!e.configDir)return!1;if(n==="claude")try{let{installGlobalConfig:t}=await Promise.resolve().then(()=>(Wt(),jd));return(await t()).success}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install claude config: ${k(t)}`),!1}try{await Gt.mkdir(e.configDir,{recursive:!0});let{getPackageRoot:t}=await Promise.resolve().then(()=>(ze(),an)),s=t(),r="GEMINI.md",o=qt.join(s,"templates","global",r),i=qt.join(e.configDir,r);if(await b(o)){let a=await Gt.readFile(o,"utf-8");if(await b(i)){let c=await Gt.readFile(i,"utf-8"),u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",d="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(c.includes(u)&&c.includes(d)){let m=c.substring(0,c.indexOf(u)),p=c.substring(c.indexOf(d)+d.length),g=a.substring(a.indexOf(u),a.indexOf(d)+d.length);await Gt.writeFile(i,m+g+p)}else await Gt.writeFile(i,`${c}
1190
1190
 
1191
- ${a}`)}else await Gt.writeFile(i,a);return!0}return!1}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install ${n} config: ${k(t)}`),!1}}async function Mb(n){let e=qt.join(Ug.homedir(),".prjct-cli","config","installed-editors.json"),t={version:ae,providers:n,editor:n[0],provider:n[0],lastInstall:new Date().toISOString(),path:qt.join(Ug.homedir(),`.${n[0]}`,"commands")};await ie(e,t)}function _b(n){console.log(`
1191
+ ${a}`)}else await Gt.writeFile(i,a);return!0}return!1}catch(t){return console.error(` ${H.yellow("\u26A0")} Failed to install ${n} config: ${k(t)}`),!1}}async function _b(n){let e=qt.join(Ug.homedir(),".prjct-cli","config","installed-editors.json"),t={version:ae,providers:n,editor:n[0],provider:n[0],lastInstall:new Date().toISOString(),path:qt.join(Ug.homedir(),`.${n[0]}`,"commands")};await ie(e,t)}function Nb(n){console.log(`
1192
1192
  ${H.green.bold(" \u2713 Setup complete!")}
1193
- `),console.log(` ${H.dim("Configured providers:")}`),n.forEach(e=>{let t=ut[e];console.log(` ${H.green("\u2713")} ${t.displayName}`)}),console.log(`
1193
+ `),console.log(` ${H.dim("Configured providers:")}`),n.forEach(e=>{let t=et[e];console.log(` ${H.green("\u2713")} ${t.displayName}`)}),console.log(`
1194
1194
  ${H.bold("Next steps:")}
1195
1195
 
1196
1196
  ${H.cyan("1.")} Navigate to your project directory
@@ -1203,9 +1203,9 @@ ${H.green.bold(" \u2713 Setup complete!")}
1203
1203
  ${H.dim("\u2022")} Use ${H.bold("p. ship")} to create PRs
1204
1204
 
1205
1205
  ${H.dim("Learn more: https://prjct.app/docs")}
1206
- `)}async function Nb(){xb();let n=await Ab();console.log(`
1206
+ `)}async function Ob(){Ab();let n=await Ib();console.log(`
1207
1207
  ${H.cyan("Setting up...")}
1208
- `);for(let e of n){let t=ut[e];process.stdout.write(` ${H.dim("\u2022")} ${t.displayName}... `);let s=await Ib(e),r=await $b(e),o=await Db(e);console.log(s&&r&&o?H.green("\u2713"):s||o?H.yellow("partial"):H.yellow("skipped"))}await Mb(n),_b(n)}var zn,Xn,Kn,Yn,Qn,jb,Rb,Gg=h(()=>{"use strict";Fs();We();V();J();ze();zn=H.rgb(180,180,175),Xn=H.rgb(200,200,195),Kn=H.rgb(220,220,215),Yn=H.rgb(235,235,230),Qn=H.rgb(250,250,245),jb=`
1208
+ `);for(let e of n){let t=et[e];process.stdout.write(` ${H.dim("\u2022")} ${t.displayName}... `);let s=await $b(e),r=await Db(e),o=await Mb(e);console.log(s&&r&&o?H.green("\u2713"):s||o?H.yellow("partial"):H.yellow("skipped"))}await _b(n),Nb(n)}var zn,Xn,Kn,Yn,Qn,Rb,xb,Gg=h(()=>{"use strict";Fs();We();V();J();ze();zn=H.rgb(180,180,175),Xn=H.rgb(200,200,195),Kn=H.rgb(220,220,215),Yn=H.rgb(235,235,230),Qn=H.rgb(250,250,245),Rb=`
1209
1209
 
1210
1210
  ${zn(" \u2588\u2588\u2588\u2588\u2588\u2588\u2557 ")}${Xn(" \u2588\u2588\u2588\u2588\u2588\u2588\u2557 ")}${Kn(" \u2588\u2588\u2557")}${Yn(" \u2588\u2588\u2588\u2588\u2588\u2588\u2557")}${Qn("\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")}
1211
1211
  ${zn(" \u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557")}${Xn(" \u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557")}${Kn(" \u2588\u2588\u2551")}${Yn("\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D")}${Qn("\u255A\u2550\u2550\u2588\u2588\u2554\u2550\u2550\u255D")}
@@ -1214,13 +1214,13 @@ ${zn(" \u2588\u2588\u2554\u2550\u2550\u2550\u255D ")}${Xn(" \u2588\u2588\u2554\u
1214
1214
  ${zn(" \u2588\u2588\u2551 ")}${Xn(" \u2588\u2588\u2551 \u2588\u2588\u2551")}${Kn("\u255A\u2588\u2588\u2588\u2588\u2588\u2554\u255D")}${Yn("\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2557")}${Qn(" \u2588\u2588\u2551 ")}
1215
1215
  ${zn(" \u255A\u2550\u255D ")}${Xn(" \u255A\u2550\u255D \u255A\u2550\u255D")}${Kn(" \u255A\u2550\u2550\u2550\u2550\u255D ")}${Yn(" \u255A\u2550\u2550\u2550\u2550\u2550\u255D")}${Qn(" \u255A\u2550\u255D ")}
1216
1216
 
1217
- `,Rb=` ${H.white("Context Layer for AI Agents")} ${H.dim(`v${ae}`)}
1217
+ `,xb=` ${H.white("Context Layer for AI Agents")} ${H.dim(`v${ae}`)}
1218
1218
 
1219
1219
  ${H.dim(`Project context layer for AI coding agents.
1220
1220
  Works with Claude Code, Gemini CLI, Codex, and more.`)}
1221
1221
  ${H.cyan("https://prjct.app")}
1222
- `;l(xb,"showBanner");l(Hg,"showProviderSelection");l(Ab,"selectProviders");l(Ib,"installRouter");l($b,"installSubcommands");l(Db,"installGlobalConfig");l(Mb,"saveSetupConfig");l(_b,"showCompletion");l(Nb,"runStart")});var Vg={};W(Vg,{runContextTool:()=>Ob});async function Ob(n,e,t){let[s,...r]=n;try{switch(s){case"memory":return await qg(r,t,{kind:"memory"});case"learnings":return await qg(r,t,{kind:"learnings"});case"wiki":return await Lb(t,r);case"help":return{tool:"error",result:{error:Ub(),code:"HELP"}};default:return{tool:"error",result:{error:`Unknown tool: ${s}. Use 'prjct context help' for usage.`,code:"UNKNOWN_TOOL"}}}}catch(o){return{tool:"error",result:{error:k(o),code:"EXECUTION_ERROR"}}}}async function Lb(n,e=[]){let t=await I.getProjectId(n);if(!t)return{tool:"error",result:{error:"No prjct project. Run `prjct init` first.",code:"NO_PROJECT"}};if(e[0]==="sync")return Fb(n,t,e.slice(1));let{generateWiki:r}=await Promise.resolve().then(()=>(is(),Vs)),{wikiRoot:o,filesWritten:i}=await r(n,t);return{tool:"wiki",result:{markdown:`> Wiki rebuilt at \`${o}\` \u2014 ${i} files. Read \`${o}/_generated/index.md\` with the Read tool.`,entryCount:i}}}async function Fb(n,e,t){let s=t.includes("--force"),{ingestCapturedNotes:r}=await Promise.resolve().then(()=>(ni(),Fm)),{regenerateWikiDeferred:o}=await Promise.resolve().then(()=>(is(),Vs)),i=await r(n,{force:s});i.ingested>0&&await o(n,e);let a=[];if(a.push(`> Ingested ${i.ingested} note(s) from \`.prjct/wiki/captured/\`.`),i.skipped.length>0){a.push("","**Skipped:**");for(let c of i.skipped)a.push(`- \`${c.file}\` \u2014 ${c.reason}`)}if(i.errors.length>0){a.push("","**Errors:**");for(let c of i.errors)a.push(`- \`${c.file}\` \u2014 ${c.error}`)}return i.ingested===0&&i.skipped.length===0&&i.errors.length===0&&a.push("","Nothing to ingest. Drop markdown notes with frontmatter into `.prjct/wiki/captured/` and re-run."),{tool:"wiki",result:{markdown:a.join(`
1223
- `),entryCount:i.ingested}}}async function qg(n,e,t){let s=await I.getProjectId(e);if(!s)return{tool:"error",result:{error:"No prjct project. Run `prjct init` first.",code:"NO_PROJECT"}};let r=n.filter(c=>!c.startsWith("-")).join(" ").trim()||void 0,o=["learning","anti-pattern","gotcha"],i=t.kind==="learnings"?o:void 0,a=Ve.recall(s,{topic:r,types:i,limit:30});return{tool:t.kind,result:{markdown:mt(a),entryCount:a.length,topic:r}}}function Ub(){return`
1222
+ `;l(Ab,"showBanner");l(Hg,"showProviderSelection");l(Ib,"selectProviders");l($b,"installRouter");l(Db,"installSubcommands");l(Mb,"installGlobalConfig");l(_b,"saveSetupConfig");l(Nb,"showCompletion");l(Ob,"runStart")});var Vg={};W(Vg,{runContextTool:()=>Lb});async function Lb(n,e,t){let[s,...r]=n;try{switch(s){case"memory":return await qg(r,t,{kind:"memory"});case"learnings":return await qg(r,t,{kind:"learnings"});case"wiki":return await Fb(t,r);case"help":return{tool:"error",result:{error:Hb(),code:"HELP"}};default:return{tool:"error",result:{error:`Unknown tool: ${s}. Use 'prjct context help' for usage.`,code:"UNKNOWN_TOOL"}}}}catch(o){return{tool:"error",result:{error:k(o),code:"EXECUTION_ERROR"}}}}async function Fb(n,e=[]){let t=await I.getProjectId(n);if(!t)return{tool:"error",result:{error:"No prjct project. Run `prjct init` first.",code:"NO_PROJECT"}};if(e[0]==="sync")return Ub(n,t,e.slice(1));let{generateWiki:r}=await Promise.resolve().then(()=>(as(),Vs)),{wikiRoot:o,filesWritten:i}=await r(n,t);return{tool:"wiki",result:{markdown:`> Wiki rebuilt at \`${o}\` \u2014 ${i} files. Read \`${o}/_generated/index.md\` with the Read tool.`,entryCount:i}}}async function Ub(n,e,t){let s=t.includes("--force"),{ingestCapturedNotes:r}=await Promise.resolve().then(()=>(ri(),Fm)),{regenerateWikiDeferred:o}=await Promise.resolve().then(()=>(as(),Vs)),i=await r(n,{force:s});i.ingested>0&&await o(n,e);let a=[];if(a.push(`> Ingested ${i.ingested} note(s) from \`.prjct/wiki/captured/\`.`),i.skipped.length>0){a.push("","**Skipped:**");for(let c of i.skipped)a.push(`- \`${c.file}\` \u2014 ${c.reason}`)}if(i.errors.length>0){a.push("","**Errors:**");for(let c of i.errors)a.push(`- \`${c.file}\` \u2014 ${c.error}`)}return i.ingested===0&&i.skipped.length===0&&i.errors.length===0&&a.push("","Nothing to ingest. Drop markdown notes with frontmatter into `.prjct/wiki/captured/` and re-run."),{tool:"wiki",result:{markdown:a.join(`
1223
+ `),entryCount:i.ingested}}}async function qg(n,e,t){let s=await I.getProjectId(e);if(!s)return{tool:"error",result:{error:"No prjct project. Run `prjct init` first.",code:"NO_PROJECT"}};let r=n.filter(c=>!c.startsWith("-")).join(" ").trim()||void 0,o=["learning","anti-pattern","gotcha"],i=t.kind==="learnings"?o:void 0,a=Ve.recall(s,{topic:r,types:i,limit:30});return{tool:t.kind,result:{markdown:mt(a),entryCount:a.length,topic:r}}}function Hb(){return`
1224
1224
  prjct context \u2014 memory-bound context subtools
1225
1225
 
1226
1226
  USAGE:
@@ -1245,7 +1245,7 @@ NOTE: File-oriented subtools (files, signatures, imports, recent,
1245
1245
  summary) were removed in alpha.12 \u2014 Claude has Glob/Grep/Read/git
1246
1246
  natively and re-implementing them in prjct was harness. The
1247
1247
  underlying functions still exist for the orchestrator + MCP surface.
1248
- `.trim()}var Bg=h(()=>{"use strict";de();os();V();l(Ob,"runContextTool");l(Lb,"runWikiTool");l(Fb,"runWikiSyncTool");l(qg,"runMemoryTool");l(Ub,"getHelpText")});var Kg={};W(Kg,{hooksService:()=>Jb});import De from"node:fs/promises";import Pe from"node:path";import ft from"chalk";function zg(){return`#!/bin/sh
1248
+ `.trim()}var Bg=h(()=>{"use strict";de();is();V();l(Lb,"runContextTool");l(Fb,"runWikiTool");l(Ub,"runWikiSyncTool");l(qg,"runMemoryTool");l(Hb,"getHelpText")});var Kg={};W(Kg,{hooksService:()=>zb});import De from"node:fs/promises";import Pe from"node:path";import ft from"chalk";function zg(){return`#!/bin/sh
1249
1249
  # prjct auto-sync hook (post-commit)
1250
1250
  # Syncs project context after each commit
1251
1251
  # Installed by: prjct hooks install
@@ -1298,7 +1298,7 @@ if command -v prjct >/dev/null 2>&1; then
1298
1298
  fi
1299
1299
 
1300
1300
  exit 0
1301
- `}async function _l(n){let e=[];return(await b(Pe.join(n,"lefthook.yml"))||await b(Pe.join(n,"lefthook.yaml")))&&e.push("lefthook"),(await b(Pe.join(n,".husky"))||await b(Pe.join(n,".husky","_")))&&e.push("husky"),await b(Pe.join(n,".git"))&&e.push("direct"),e}function Jg(n){return n.includes("lefthook")?"lefthook":n.includes("husky")?"husky":"direct"}async function Hb(n,e){let t=await b(Pe.join(n,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml",s=Pe.join(n,t),r=await De.readFile(s,"utf-8");for(let o of e){let i=o,a=`prjct-sync-${o}`;if(r.includes(a))continue;let c=`
1301
+ `}async function Ol(n){let e=[];return(await b(Pe.join(n,"lefthook.yml"))||await b(Pe.join(n,"lefthook.yaml")))&&e.push("lefthook"),(await b(Pe.join(n,".husky"))||await b(Pe.join(n,".husky","_")))&&e.push("husky"),await b(Pe.join(n,".git"))&&e.push("direct"),e}function Jg(n){return n.includes("lefthook")?"lefthook":n.includes("husky")?"husky":"direct"}async function Wb(n,e){let t=await b(Pe.join(n,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml",s=Pe.join(n,t),r=await De.readFile(s,"utf-8");for(let o of e){let i=o,a=`prjct-sync-${o}`;if(r.includes(a))continue;let c=`
1302
1302
  ${i}:
1303
1303
  commands:
1304
1304
  ${a}:
@@ -1309,52 +1309,52 @@ ${i}:
1309
1309
  ${a}:
1310
1310
  run: prjct sync --quiet --yes
1311
1311
  fail_text: "prjct sync failed (non-blocking)"`):r=`${r.trimEnd()}
1312
- ${c}`}return await De.writeFile(s,r,"utf-8"),!0}async function Wb(n,e){let t=Pe.join(n,".husky");for(let s of e){let r=Pe.join(t,s),o=s==="post-commit"?zg():Xg();if(await b(r)){if((await De.readFile(r,"utf-8")).includes("prjct sync"))continue;await De.appendFile(r,`
1312
+ ${c}`}return await De.writeFile(s,r,"utf-8"),!0}async function Gb(n,e){let t=Pe.join(n,".husky");for(let s of e){let r=Pe.join(t,s),o=s==="post-commit"?zg():Xg();if(await b(r)){if((await De.readFile(r,"utf-8")).includes("prjct sync"))continue;await De.appendFile(r,`
1313
1313
  # prjct auto-sync
1314
1314
  prjct sync --quiet --yes &
1315
- `)}else await De.writeFile(r,o,{mode:493})}return!0}async function Gb(n,e){let t=Pe.join(n,".git","hooks");await b(t)||await De.mkdir(t,{recursive:!0});for(let s of e){let r=Pe.join(t,s),o=s==="post-commit"?zg():Xg();if(await b(r)){if((await De.readFile(r,"utf-8")).includes("prjct sync"))continue;await De.appendFile(r,`
1315
+ `)}else await De.writeFile(r,o,{mode:493})}return!0}async function qb(n,e){let t=Pe.join(n,".git","hooks");await b(t)||await De.mkdir(t,{recursive:!0});for(let s of e){let r=Pe.join(t,s),o=s==="post-commit"?zg():Xg();if(await b(r)){if((await De.readFile(r,"utf-8")).includes("prjct sync"))continue;await De.appendFile(r,`
1316
1316
  # prjct auto-sync
1317
1317
  ${o.split(`
1318
1318
  `).slice(1).join(`
1319
- `)}`)}else await De.writeFile(r,o,{mode:493})}return!0}async function qb(n){let e=await b(Pe.join(n,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml",t=Pe.join(n,e);if(!await b(t))return!1;let s=await De.readFile(t,"utf-8");return s=s.replace(/\s*prjct-sync-[\w-]+:[\s\S]*?(?=\n\S|\n*$)/g,""),s=s.replace(/^(post-commit|post-checkout):\s*commands:\s*$/gm,""),await De.writeFile(t,`${s.trimEnd()}
1320
- `,"utf-8"),!0}async function Vb(n){let e=Pe.join(n,".husky");for(let t of["post-commit","post-checkout"]){let s=Pe.join(e,t);if(!await b(s))continue;let r=await De.readFile(s,"utf-8");if(!r.includes("prjct sync"))continue;let o=r.split(`
1319
+ `)}`)}else await De.writeFile(r,o,{mode:493})}return!0}async function Vb(n){let e=await b(Pe.join(n,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml",t=Pe.join(n,e);if(!await b(t))return!1;let s=await De.readFile(t,"utf-8");return s=s.replace(/\s*prjct-sync-[\w-]+:[\s\S]*?(?=\n\S|\n*$)/g,""),s=s.replace(/^(post-commit|post-checkout):\s*commands:\s*$/gm,""),await De.writeFile(t,`${s.trimEnd()}
1320
+ `,"utf-8"),!0}async function Bb(n){let e=Pe.join(n,".husky");for(let t of["post-commit","post-checkout"]){let s=Pe.join(e,t);if(!await b(s))continue;let r=await De.readFile(s,"utf-8");if(!r.includes("prjct sync"))continue;let o=r.split(`
1321
1321
  `).filter(i=>!i.includes("prjct sync")&&!i.includes("prjct auto-sync")).join(`
1322
- `);o.trim()==="#!/bin/sh"||o.trim()==="#!/usr/bin/env sh"?await De.unlink(s):await De.writeFile(s,o,{mode:493})}return!0}async function Bb(n){let e=Pe.join(n,".git","hooks");for(let t of["post-commit","post-checkout"]){let s=Pe.join(e,t);if(!await b(s))continue;let r=await De.readFile(s,"utf-8");if(r.includes("prjct sync"))if(r.includes("Installed by: prjct hooks install"))await De.unlink(s);else{let o=r.split(`
1322
+ `);o.trim()==="#!/bin/sh"||o.trim()==="#!/usr/bin/env sh"?await De.unlink(s):await De.writeFile(s,o,{mode:493})}return!0}async function Jb(n){let e=Pe.join(n,".git","hooks");for(let t of["post-commit","post-checkout"]){let s=Pe.join(e,t);if(!await b(s))continue;let r=await De.readFile(s,"utf-8");if(r.includes("prjct sync"))if(r.includes("Installed by: prjct hooks install"))await De.unlink(s);else{let o=r.split(`
1323
1323
  `).filter(i=>!i.includes("prjct sync")&&!i.includes("prjct auto-sync")).join(`
1324
- `);await De.writeFile(s,o,{mode:493})}}return!0}var Nl,Jb,Yg=h(()=>{"use strict";de();ce();V();J();Me();l(zg,"getPostCommitScript");l(Xg,"getPostCheckoutScript");l(_l,"detectHookManagers");l(Jg,"selectStrategy");l(Hb,"installLefthook");l(Wb,"installHusky");l(Gb,"installDirect");l(qb,"uninstallLefthook");l(Vb,"uninstallHusky");l(Bb,"uninstallDirect");Nl=class{static{l(this,"HooksService")}async install(e,t={}){let s=t.hooks||["post-commit","post-checkout"],r=await _l(e);if(r.length===0)return{success:!1,strategy:"direct",hooksInstalled:[],error:'Not a git repository. Run "git init" first.'};let o=t.strategy||Jg(r);try{let i=!1;switch(o){case"lefthook":i=await Hb(e,s);break;case"husky":i=await Wb(e,s);break;case"direct":i=await Gb(e,s);break}return i&&await this.saveHookConfig(e,{enabled:!0,strategy:o,hooks:s,installedAt:new Date().toISOString()}),{success:i,strategy:o,hooksInstalled:i?s:[]}}catch(i){return{success:!1,strategy:o,hooksInstalled:[],error:k(i)}}}async uninstall(e){try{let s=(await this.getHookConfig(e))?.strategy||"direct",r=!1;switch(s){case"lefthook":r=await qb(e);break;case"husky":r=await Vb(e);break;case"direct":r=await Bb(e);break}return r&&await this.saveHookConfig(e,{enabled:!1,strategy:s,hooks:[]}),{success:r}}catch(t){return{success:!1,error:k(t)}}}async status(e){let t=await _l(e),s=await this.getHookConfig(e),r=["post-commit","post-checkout"],o=await Promise.all(r.map(async i=>({name:i,installed:await this.isHookInstalled(e,i,s?.strategy||null),path:await this.getHookPath(e,i,s?.strategy||null)})));return{installed:o.some(i=>i.installed),strategy:s?.strategy||null,hooks:o,detectedManagers:t}}async run(e,t){if(!await I.getProjectId(e))return console.error('No prjct project found. Run "prjct init" first.'),1;switch(t){case"install":return this.runInstall(e);case"uninstall":return this.runUninstall(e);case"status":return this.runStatus(e);default:return this.runStatus(e)}}async runInstall(e){f.start(),f.section("Git Hooks Installation");let t=await _l(e),s=Jg(t);console.log(` Strategy: ${ft.cyan(s)}`),console.log(` Hooks: ${ft.dim("post-commit, post-checkout")}`),console.log("");let r=await this.install(e,{strategy:s});if(r.success){f.done(`Hooks installed via ${r.strategy}`),console.log("");for(let o of r.hooksInstalled)console.log(` ${ft.green("\u2713")} ${o}`);console.log(""),console.log(ft.dim(" Context will auto-sync on commit and branch switch.")),console.log(ft.dim(" Remove with: prjct hooks uninstall"))}else f.fail(r.error||"Failed to install hooks");return console.log(""),f.end(),r.success?0:1}async runUninstall(e){f.start(),f.section("Git Hooks Removal");let t=await this.uninstall(e);return t.success?f.done("Hooks removed"):f.fail(t.error||"Failed to remove hooks"),console.log(""),f.end(),t.success?0:1}async runStatus(e){f.start(),f.section("Git Hooks Status");let t=await this.status(e);t.installed?(console.log(` Status: ${ft.green("Active")}`),console.log(` Strategy: ${ft.cyan(t.strategy)}`)):console.log(` Status: ${ft.dim("Not installed")}`),console.log("");for(let s of t.hooks){let r=s.installed?ft.green("\u2713"):ft.dim("\u25CB"),o=s.installed?s.name:ft.dim(s.name);console.log(` ${r} ${o}`)}return t.detectedManagers.length>0&&(console.log(""),console.log(` ${ft.dim("Available managers:")} ${t.detectedManagers.join(", ")}`)),t.installed||(console.log(""),console.log(ft.dim(" Install with: prjct hooks install"))),console.log(""),f.end(),0}async isHookInstalled(e,t,s){if(s==="lefthook"){let o=await b(Pe.join(e,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml",i=Pe.join(e,o);return await b(i)?(await De.readFile(i,"utf-8")).includes(`prjct-sync-${t}`):!1}if(s==="husky"){let o=Pe.join(e,".husky",t);return await b(o)?(await De.readFile(o,"utf-8")).includes("prjct sync"):!1}let r=Pe.join(e,".git","hooks",t);return await b(r)?(await De.readFile(r,"utf-8")).includes("prjct sync"):!1}async getHookPath(e,t,s){return s==="lefthook"?await b(Pe.join(e,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml":s==="husky"?`.husky/${t}`:`.git/hooks/${t}`}async getHookConfig(e){let t=await I.getProjectId(e);if(!t)return null;try{let s=C.getDoc(t,"project");return s&&s.hooks||null}catch{return null}}async saveHookConfig(e,t){let s=await I.getProjectId(e);if(s)try{let r=C.getDoc(s,"project")||{};r.hooks=t,C.setDoc(s,"project",r)}catch{}}},Jb=new Nl});async function at(){return process.stdin.isTTY?{}:new Promise(n=>{let e=[];process.stdin.on("data",t=>e.push(t)),process.stdin.on("end",()=>{try{let t=Buffer.concat(e).toString("utf-8").trim();if(!t)return n({});n(JSON.parse(t))}catch{n({})}}),process.stdin.on("error",()=>n({})),setTimeout(()=>n({}),200)})}function _e(n){process.stdout.write(`${JSON.stringify(n)}
1325
- `)}function Xb(){_e({})}async function ct(n){try{await n()}catch{Xb()}}function Qg(n,e=8){let t=new Set(["this","that","with","from","have","your","please","need","want","would","should","could","about","there","these","those","what","when","where","which","while","will","been","were","they","them","their"]),s=new Set,r=[];for(let o of n.toLowerCase().match(/[a-z0-9-]{4,}/g)??[])if(!t.has(o)&&!s.has(o)&&(s.add(o),r.push(o),r.length>=e))break;return r}function Et(n,e){return e?zb.has(n)?{hookSpecificOutput:{hookEventName:n,additionalContext:e}}:{systemMessage:e}:{}}var zb,Es=h(()=>{"use strict";zb=new Set(["SessionStart","UserPromptSubmit","PostToolUse"]);l(at,"readStdinSafe");l(_e,"emit");l(Xb,"emitEmpty");l(ct,"safeRun");l(Qg,"extractKeywords");l(Et,"buildHookOutput")});var ef={};W(ef,{buildSessionContext:()=>Zn,runSessionStartHook:()=>Qb});async function Zn(n,e){let t=e??await I.readConfig(n);if(!t?.projectId)return null;let s=t.persona,r=[];try{r=Ve.recall(t.projectId,{limit:Kb})}catch{r=[]}if(!s&&r.length===0)return null;let o=[];o.push("# prjct: project context"),o.push(""),s&&(o.push(Yb(s)),o.push("")),r.length>0&&(o.push("## Recent memory"),o.push(""),o.push(mt(r)),o.push("")),o.push("> Exposed as state, not prescription. Decide whether any of this matters for the current turn.");let i=o.join(`
1324
+ `);await De.writeFile(s,o,{mode:493})}}return!0}var Ll,zb,Yg=h(()=>{"use strict";de();ce();V();J();Me();l(zg,"getPostCommitScript");l(Xg,"getPostCheckoutScript");l(Ol,"detectHookManagers");l(Jg,"selectStrategy");l(Wb,"installLefthook");l(Gb,"installHusky");l(qb,"installDirect");l(Vb,"uninstallLefthook");l(Bb,"uninstallHusky");l(Jb,"uninstallDirect");Ll=class{static{l(this,"HooksService")}async install(e,t={}){let s=t.hooks||["post-commit","post-checkout"],r=await Ol(e);if(r.length===0)return{success:!1,strategy:"direct",hooksInstalled:[],error:'Not a git repository. Run "git init" first.'};let o=t.strategy||Jg(r);try{let i=!1;switch(o){case"lefthook":i=await Wb(e,s);break;case"husky":i=await Gb(e,s);break;case"direct":i=await qb(e,s);break}return i&&await this.saveHookConfig(e,{enabled:!0,strategy:o,hooks:s,installedAt:new Date().toISOString()}),{success:i,strategy:o,hooksInstalled:i?s:[]}}catch(i){return{success:!1,strategy:o,hooksInstalled:[],error:k(i)}}}async uninstall(e){try{let s=(await this.getHookConfig(e))?.strategy||"direct",r=!1;switch(s){case"lefthook":r=await Vb(e);break;case"husky":r=await Bb(e);break;case"direct":r=await Jb(e);break}return r&&await this.saveHookConfig(e,{enabled:!1,strategy:s,hooks:[]}),{success:r}}catch(t){return{success:!1,error:k(t)}}}async status(e){let t=await Ol(e),s=await this.getHookConfig(e),r=["post-commit","post-checkout"],o=await Promise.all(r.map(async i=>({name:i,installed:await this.isHookInstalled(e,i,s?.strategy||null),path:await this.getHookPath(e,i,s?.strategy||null)})));return{installed:o.some(i=>i.installed),strategy:s?.strategy||null,hooks:o,detectedManagers:t}}async run(e,t){if(!await I.getProjectId(e))return console.error('No prjct project found. Run "prjct init" first.'),1;switch(t){case"install":return this.runInstall(e);case"uninstall":return this.runUninstall(e);case"status":return this.runStatus(e);default:return this.runStatus(e)}}async runInstall(e){f.start(),f.section("Git Hooks Installation");let t=await Ol(e),s=Jg(t);console.log(` Strategy: ${ft.cyan(s)}`),console.log(` Hooks: ${ft.dim("post-commit, post-checkout")}`),console.log("");let r=await this.install(e,{strategy:s});if(r.success){f.done(`Hooks installed via ${r.strategy}`),console.log("");for(let o of r.hooksInstalled)console.log(` ${ft.green("\u2713")} ${o}`);console.log(""),console.log(ft.dim(" Context will auto-sync on commit and branch switch.")),console.log(ft.dim(" Remove with: prjct hooks uninstall"))}else f.fail(r.error||"Failed to install hooks");return console.log(""),f.end(),r.success?0:1}async runUninstall(e){f.start(),f.section("Git Hooks Removal");let t=await this.uninstall(e);return t.success?f.done("Hooks removed"):f.fail(t.error||"Failed to remove hooks"),console.log(""),f.end(),t.success?0:1}async runStatus(e){f.start(),f.section("Git Hooks Status");let t=await this.status(e);t.installed?(console.log(` Status: ${ft.green("Active")}`),console.log(` Strategy: ${ft.cyan(t.strategy)}`)):console.log(` Status: ${ft.dim("Not installed")}`),console.log("");for(let s of t.hooks){let r=s.installed?ft.green("\u2713"):ft.dim("\u25CB"),o=s.installed?s.name:ft.dim(s.name);console.log(` ${r} ${o}`)}return t.detectedManagers.length>0&&(console.log(""),console.log(` ${ft.dim("Available managers:")} ${t.detectedManagers.join(", ")}`)),t.installed||(console.log(""),console.log(ft.dim(" Install with: prjct hooks install"))),console.log(""),f.end(),0}async isHookInstalled(e,t,s){if(s==="lefthook"){let o=await b(Pe.join(e,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml",i=Pe.join(e,o);return await b(i)?(await De.readFile(i,"utf-8")).includes(`prjct-sync-${t}`):!1}if(s==="husky"){let o=Pe.join(e,".husky",t);return await b(o)?(await De.readFile(o,"utf-8")).includes("prjct sync"):!1}let r=Pe.join(e,".git","hooks",t);return await b(r)?(await De.readFile(r,"utf-8")).includes("prjct sync"):!1}async getHookPath(e,t,s){return s==="lefthook"?await b(Pe.join(e,"lefthook.yml"))?"lefthook.yml":"lefthook.yaml":s==="husky"?`.husky/${t}`:`.git/hooks/${t}`}async getHookConfig(e){let t=await I.getProjectId(e);if(!t)return null;try{let s=C.getDoc(t,"project");return s&&s.hooks||null}catch{return null}}async saveHookConfig(e,t){let s=await I.getProjectId(e);if(s)try{let r=C.getDoc(s,"project")||{};r.hooks=t,C.setDoc(s,"project",r)}catch{}}},zb=new Ll});async function ct(){return process.stdin.isTTY?{}:new Promise(n=>{let e=[];process.stdin.on("data",t=>e.push(t)),process.stdin.on("end",()=>{try{let t=Buffer.concat(e).toString("utf-8").trim();if(!t)return n({});n(JSON.parse(t))}catch{n({})}}),process.stdin.on("error",()=>n({})),setTimeout(()=>n({}),200)})}function _e(n){process.stdout.write(`${JSON.stringify(n)}
1325
+ `)}function Kb(){_e({})}async function lt(n){try{await n()}catch{Kb()}}function Qg(n,e=8){let t=new Set(["this","that","with","from","have","your","please","need","want","would","should","could","about","there","these","those","what","when","where","which","while","will","been","were","they","them","their"]),s=new Set,r=[];for(let o of n.toLowerCase().match(/[a-z0-9-]{4,}/g)??[])if(!t.has(o)&&!s.has(o)&&(s.add(o),r.push(o),r.length>=e))break;return r}function Et(n,e){return e?Xb.has(n)?{hookSpecificOutput:{hookEventName:n,additionalContext:e}}:{systemMessage:e}:{}}var Xb,Es=h(()=>{"use strict";Xb=new Set(["SessionStart","UserPromptSubmit","PostToolUse"]);l(ct,"readStdinSafe");l(_e,"emit");l(Kb,"emitEmpty");l(lt,"safeRun");l(Qg,"extractKeywords");l(Et,"buildHookOutput")});var ef={};W(ef,{buildSessionContext:()=>Zn,runSessionStartHook:()=>Zb});async function Zn(n,e){let t=e??await I.readConfig(n);if(!t?.projectId)return null;let s=t.persona,r=[];try{r=Ve.recall(t.projectId,{limit:Yb})}catch{r=[]}if(!s&&r.length===0)return null;let o=[];o.push("# prjct: project context"),o.push(""),s&&(o.push(Qb(s)),o.push("")),r.length>0&&(o.push("## Recent memory"),o.push(""),o.push(mt(r)),o.push("")),o.push("> Exposed as state, not prescription. Decide whether any of this matters for the current turn.");let i=o.join(`
1326
1326
  `);return i.length>Zg?`${i.slice(0,Zg-20)}
1327
- \u2026 [truncated]`:i}function Yb(n){let e=[];return e.push(`## Your role in this project: **${n.role}**`),n.focus&&e.push(`Focus: ${n.focus}`),n.mcps&&n.mcps.length>0&&e.push(`Available MCPs this project expects: ${n.mcps.join(", ")}`),n.packs&&n.packs.length>0&&e.push(`Active packs: ${n.packs.join(", ")}`),e.join(`
1328
- `)}async function Qb(n=process.cwd()){await ct(async()=>{await at();let e=await I.readConfig(n).catch(()=>null),t=await Zn(n,e);_e(Et("SessionStart",t)),e?.projectId&&await Mr(n,e.projectId).catch(()=>{})})}var Zg,Kb,Pi=h(()=>{"use strict";de();os();is();Es();Zg=2500,Kb=5;l(Zn,"buildSessionContext");l(Yb,"formatPersona");l(Qb,"runSessionStartHook")});var nf={};W(nf,{runPromptHook:()=>eT});async function Zb(n,e){let t=await I.readConfig(n);if(!t?.projectId)return null;let s=Qg(e);if(s.length===0)return null;let r=s.map(u=>u.toLowerCase()),o=[];try{o=Ve.recall(t.projectId,{limit:sf*4})}catch{return null}let i=[];for(let u of o){let d=`${u.content} ${Object.values(u.tags).join(" ")}`.toLowerCase();if(r.some(m=>d.includes(m))&&(i.push(u),i.length>=sf))break}if(i.length===0)return null;let a=["# prjct: topical memory"];a.push(""),a.push(`Recalled ${i.length} entr${i.length===1?"y":"ies"} matching: ${s.slice(0,3).join(", ")}`),a.push(""),a.push(mt(i)),a.push(""),a.push("> Exposed as state. Use if relevant; ignore if not.");let c=a.join(`
1327
+ \u2026 [truncated]`:i}function Qb(n){let e=[];return e.push(`## Your role in this project: **${n.role}**`),n.focus&&e.push(`Focus: ${n.focus}`),n.mcps&&n.mcps.length>0&&e.push(`Available MCPs this project expects: ${n.mcps.join(", ")}`),n.packs&&n.packs.length>0&&e.push(`Active packs: ${n.packs.join(", ")}`),e.join(`
1328
+ `)}async function Zb(n=process.cwd()){await lt(async()=>{await ct();let e=await I.readConfig(n).catch(()=>null),t=await Zn(n,e);_e(Et("SessionStart",t)),e?.projectId&&await Mr(n,e.projectId).catch(()=>{})})}var Zg,Yb,ji=h(()=>{"use strict";de();is();as();Es();Zg=2500,Yb=5;l(Zn,"buildSessionContext");l(Qb,"formatPersona");l(Zb,"runSessionStartHook")});var nf={};W(nf,{runPromptHook:()=>tT});async function eT(n,e){let t=await I.readConfig(n);if(!t?.projectId)return null;let s=Qg(e);if(s.length===0)return null;let r=s.map(u=>u.toLowerCase()),o=[];try{o=Ve.recall(t.projectId,{limit:sf*4})}catch{return null}let i=[];for(let u of o){let d=`${u.content} ${Object.values(u.tags).join(" ")}`.toLowerCase();if(r.some(m=>d.includes(m))&&(i.push(u),i.length>=sf))break}if(i.length===0)return null;let a=["# prjct: topical memory"];a.push(""),a.push(`Recalled ${i.length} entr${i.length===1?"y":"ies"} matching: ${s.slice(0,3).join(", ")}`),a.push(""),a.push(mt(i)),a.push(""),a.push("> Exposed as state. Use if relevant; ignore if not.");let c=a.join(`
1329
1329
  `);return c.length>tf?`${c.slice(0,tf-20)}
1330
- \u2026 [truncated]`:c}async function eT(n=process.cwd()){await ct(async()=>{let t=((await at()).prompt??"").trim();if(!t){_e({});return}let s=await Zb(n,t);_e(Et("UserPromptSubmit",s))})}var tf,sf,rf=h(()=>{"use strict";de();os();Es();tf=1500,sf=4;l(Zb,"buildPromptContext");l(eT,"runPromptHook")});var af={};W(af,{runPreCommitHook:()=>aT});import{execSync as tT}from"node:child_process";function nT(n){try{return tT("git diff --cached --name-only",{cwd:n,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).split(`
1331
- `).map(e=>e.trim()).filter(Boolean)}catch{return[]}}function rT(n){let e=new Set;for(let t of n){let s=t.split("/").filter(Boolean);for(let r of s){let o=r.replace(/\.[^.]+$/,"").toLowerCase();o.length>=3&&e.add(o)}}return[...e]}function oT(n,e){let t=n.content.toLowerCase();if(e.some(s=>t.includes(s)))return!0;for(let s of Object.values(n.tags)){let r=s.toLowerCase();if(e.some(o=>r.includes(o)))return!0}return!1}async function iT(n){let e=await I.readConfig(n);if(!e?.projectId)return null;let t=nT(n);if(t.length===0)return null;let s=rT(t);if(s.length===0)return null;let r;try{r=Ve.recall(e.projectId,{types:["anti-pattern","gotcha"],limit:50})}catch{return null}let o=r.filter(c=>oT(c,s)).slice(0,sT);if(o.length===0)return null;let i=["# prjct: heads-up for this commit",""];i.push(`${o.length} anti-pattern/gotcha entr${o.length===1?"y":"ies"} match the staged files.`),i.push(""),i.push(mt(o)),i.push(""),i.push("> Nudge, not block. Proceed if you think it still applies.");let a=i.join(`
1330
+ \u2026 [truncated]`:c}async function tT(n=process.cwd()){await lt(async()=>{let t=((await ct()).prompt??"").trim();if(!t){_e({});return}let s=await eT(n,t);_e(Et("UserPromptSubmit",s))})}var tf,sf,rf=h(()=>{"use strict";de();is();Es();tf=1500,sf=4;l(eT,"buildPromptContext");l(tT,"runPromptHook")});var af={};W(af,{runPreCommitHook:()=>cT});import{execSync as sT}from"node:child_process";function rT(n){try{return sT("git diff --cached --name-only",{cwd:n,encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).split(`
1331
+ `).map(e=>e.trim()).filter(Boolean)}catch{return[]}}function oT(n){let e=new Set;for(let t of n){let s=t.split("/").filter(Boolean);for(let r of s){let o=r.replace(/\.[^.]+$/,"").toLowerCase();o.length>=3&&e.add(o)}}return[...e]}function iT(n,e){let t=n.content.toLowerCase();if(e.some(s=>t.includes(s)))return!0;for(let s of Object.values(n.tags)){let r=s.toLowerCase();if(e.some(o=>r.includes(o)))return!0}return!1}async function aT(n){let e=await I.readConfig(n);if(!e?.projectId)return null;let t=rT(n);if(t.length===0)return null;let s=oT(t);if(s.length===0)return null;let r;try{r=Ve.recall(e.projectId,{types:["anti-pattern","gotcha"],limit:50})}catch{return null}let o=r.filter(c=>iT(c,s)).slice(0,nT);if(o.length===0)return null;let i=["# prjct: heads-up for this commit",""];i.push(`${o.length} anti-pattern/gotcha entr${o.length===1?"y":"ies"} match the staged files.`),i.push(""),i.push(mt(o)),i.push(""),i.push("> Nudge, not block. Proceed if you think it still applies.");let a=i.join(`
1332
1332
  `);return a.length>of?`${a.slice(0,of-20)}
1333
- \u2026 [truncated]`:a}async function aT(n=process.cwd()){await ct(async()=>{let t=(await at()).tool_input?.command??"";if(!/\bgit\s+commit\b/.test(t)){_e({});return}let s=await iT(n);_e(Et("PreToolUse",s))})}var of,sT,cf=h(()=>{"use strict";de();os();Es();of=1200,sT=3;l(nT,"stagedFiles");l(rT,"pathFragments");l(oT,"mentionsFragment");l(iT,"buildPreCommitContext");l(aT,"runPreCommitHook")});var lf={};W(lf,{runPostEditHook:()=>cT});async function cT(n=process.cwd()){await ct(async()=>{let e=await at(),t=e.tool_input?.file_path;if(!t){_e({});return}if(!(await I.readConfig(n))?.projectId){_e({});return}try{await Ye.log(n,"post_edit",{file:t,tool:e.tool_name??"unknown"})}catch{}_e({})})}var uf=h(()=>{"use strict";de();ks();Es();l(cT,"runPostEditHook")});var pf={};W(pf,{buildStopContext:()=>df,runStopHook:()=>dT});async function df(n,e){let t=e??await I.readConfig(n);if(!t?.projectId)return null;let s=t.projectId,r=new Date(Date.now()-lT).toISOString(),o;try{o=L.query(s,`SELECT
1333
+ \u2026 [truncated]`:a}async function cT(n=process.cwd()){await lt(async()=>{let t=(await ct()).tool_input?.command??"";if(!/\bgit\s+commit\b/.test(t)){_e({});return}let s=await aT(n);_e(Et("PreToolUse",s))})}var of,nT,cf=h(()=>{"use strict";de();is();Es();of=1200,nT=3;l(rT,"stagedFiles");l(oT,"pathFragments");l(iT,"mentionsFragment");l(aT,"buildPreCommitContext");l(cT,"runPreCommitHook")});var lf={};W(lf,{runPostEditHook:()=>lT});async function lT(n=process.cwd()){await lt(async()=>{let e=await ct(),t=e.tool_input?.file_path;if(!t){_e({});return}if(!(await I.readConfig(n))?.projectId){_e({});return}try{await Ye.log(n,"post_edit",{file:t,tool:e.tool_name??"unknown"})}catch{}_e({})})}var uf=h(()=>{"use strict";de();ks();Es();l(lT,"runPostEditHook")});var pf={};W(pf,{buildStopContext:()=>df,runStopHook:()=>pT});async function df(n,e){let t=e??await I.readConfig(n);if(!t?.projectId)return null;let s=t.projectId,r=new Date(Date.now()-uT).toISOString(),o;try{o=L.query(s,`SELECT
1334
1334
  CASE WHEN type = ? THEN 'edit' ELSE 'checkpoint' END AS type,
1335
1335
  COUNT(*) AS count
1336
1336
  FROM events
1337
1337
  WHERE type LIKE 'memory.%' AND timestamp > ?
1338
- GROUP BY 1`,uT,r)}catch{return null}let i=0,a=0;for(let c of o)c.type==="edit"?i=c.count:a=c.count;return i===0||a>0?null:["# prjct: capture checkpoint","",`${i} file edit${i===1?"":"s"} this session without a memory entry.`,"",'If anything was reusable \u2014 a decision, a gotcha, a pattern \u2014 `prjct remember <type> "<content>"` keeps it around for future sessions.',"","> Skip if nothing worth saving."].join(`
1339
- `)}async function dT(n=process.cwd()){await ct(async()=>{await at();let e=await I.readConfig(n).catch(()=>null),t=await df(n,e);if(_e(Et("Stop",t)),!!e?.projectId){try{await Qc(n)}catch{}await Mr(n,e.projectId).catch(()=>{})}})}var lT,uT,mf=h(()=>{"use strict";de();is();ni();ce();Es();lT=30*60*1e3,uT="memory.post_edit";l(df,"buildStopContext");l(dT,"runStopHook")});var gf={};W(gf,{runSubagentStartHook:()=>pT});async function pT(n=process.cwd()){await ct(async()=>{await at();let e=await Zn(n);_e(Et("SubagentStart",e))})}var ff=h(()=>{"use strict";Es();Pi();l(pT,"runSubagentStartHook")});var hf={};W(hf,{runCwdChangedHook:()=>mT});async function mT(n=process.cwd()){await ct(async()=>{let t=(await at()).cwd||n,s=await Zn(t);_e(Et("CwdChanged",s))})}var yf=h(()=>{"use strict";Es();Pi();l(mT,"runCwdChangedHook")});var kf={};W(kf,{DoctorService:()=>ji,doctorService:()=>fT});import{execSync as Ol}from"node:child_process";import gT from"node:fs/promises";import wf from"node:path";import Cs from"chalk";var ji,fT,vf=h(()=>{"use strict";de();Re();Cn();rt();J();Me();ze();Er();ji=class{static{l(this,"DoctorService")}projectPath="";projectId=null;globalPath="";async check(e=process.cwd()){this.projectPath=e,this.projectId=await I.getProjectId(e),this.projectId&&(this.globalPath=$.getGlobalProjectPath(this.projectId));let t=await this.checkTools(),s=await this.checkProject(),r=this.generateRecommendations(t,s),o=[...t,...s].some(a=>a.status==="error"&&!a.optional),i=[...t,...s].some(a=>a.status==="warn"||a.status==="error"&&a.optional);return{success:!o,tools:t,project:s,recommendations:r,hasErrors:o,hasWarnings:i}}async run(e=process.cwd()){let t=await this.check(e);return this.printHeader(),this.printSection("System Tools",t.tools),this.printSection("Project Status",t.project),t.recommendations.length>0&&this.printRecommendations(t.recommendations),this.printSummary(t),t.hasErrors?1:0}async checkTools(){let e=[];return e.push(this.checkCommand("git","git --version",/git version ([\d.]+)/,!1)),e.push(this.checkCommand("node","node --version",/v([\d.]+)/,!1)),e.push(this.checkCommand("bun","bun --version",/([\d.]+)/,!0)),e.push(this.checkCommand("gh","gh --version",/gh version ([\d.]+)/,!0,"needed for PR commands")),e.push(this.checkCommand("claude","claude --version",/claude ([\d.]+)/,!0,"Anthropic Claude Code CLI")),e.push(this.checkCommand("gemini","gemini --version",/gemini ([\d.]+)/,!0,"Google Gemini CLI")),e}checkCommand(e,t,s,r,o){try{let a=Ol(t,{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).match(s),c=a?a[1]:"unknown";return{name:e,status:"ok",version:c,optional:r}}catch{return{name:e,status:"error",message:o?`not found (${o})`:"not found",optional:r}}}async checkProject(){let e=[];return e.push(await this.checkPrjctConfig()),e.push(await this.checkClaudeMd()),e.push(await this.checkGitRepo()),e.push(await this.checkStateFile()),e.push(await this.checkContext7()),e.push(await this.checkCodexPRouter()),e}async checkPrjctConfig(){let e=wf.join(this.projectPath,".prjct","prjct.config.json");return await b(e)?{name:"prjct config",status:"ok",message:"initialized"}:{name:"prjct config",status:"error",message:'not initialized - run "prjct init"'}}async checkClaudeMd(){if(!this.globalPath)return{name:"CLAUDE.md",status:"warn",message:"project not initialized"};let e=wf.join(this.globalPath,"context","CLAUDE.md");try{let t=await gT.stat(e),s=Date.now()-t.mtimeMs,r=Math.floor(s/(1e3*60*60)),o=Math.floor(r/24),i;return o>0?i=`${o} day${o>1?"s":""} ago`:r>0?i=`${r} hour${r>1?"s":""} ago`:i="recently",r>24?{name:"CLAUDE.md",status:"warn",message:`stale (last sync: ${i})`}:{name:"CLAUDE.md",status:"ok",message:`synced ${i}`}}catch{return{name:"CLAUDE.md",status:"error",message:'not found - run "prjct sync"'}}}async checkGitRepo(){try{Ol("git rev-parse --git-dir",{cwd:this.projectPath,stdio:["pipe","pipe","pipe"]});let e=Ol("git status --porcelain",{cwd:this.projectPath,encoding:"utf-8"});if(e.trim().length>0){let s=e.trim().split(`
1340
- `).filter(Boolean);return{name:"git repo",status:"ok",message:`${s.length} uncommitted change${s.length>1?"s":""}`}}return{name:"git repo",status:"ok",message:"clean"}}catch{return{name:"git repo",status:"warn",message:"not a git repository"}}}async checkStateFile(){if(!this.globalPath||!this.projectId)return{name:"task state",status:"warn",message:"project not initialized"};try{let e=await D.read(this.projectId);return e.currentTask?{name:"task state",status:"ok",message:`active: ${e.currentTask.description?.slice(0,30)}...`}:{name:"task state",status:"ok",message:"no active task"}}catch{return{name:"task state",status:"ok",message:"no state data (normal for new projects)",optional:!0}}}async checkContext7(){try{let e=await ss.verify();return e.installed?e.verified?{name:"context7 mcp",status:"ok",message:"ready"}:{name:"context7 mcp",status:"error",message:e.message||"configured but verification failed"}:{name:"context7 mcp",status:"error",message:'not configured - run "prjct start"'}}catch(e){return{name:"context7 mcp",status:"error",message:`check failed: ${e instanceof Error?e.message:"unknown error"}`}}}async checkCodexPRouter(){try{let e=await En({autoRepair:!0});return e.installed?e.verified?{name:"codex p-router",status:"ok",message:`ready (${e.templateSource||"local-dev"})`}:{name:"codex p-router",status:"error",message:e.message||"router verification failed"}:{name:"codex p-router",status:"ok",message:"codex not detected (check skipped)",optional:!0}}catch(e){return{name:"codex p-router",status:"error",message:`check failed: ${e instanceof Error?e.message:"unknown error"}`}}}generateRecommendations(e,t){let s=[];e.find(d=>d.name==="gh"&&d.status==="error")&&s.push("Install GitHub CLI (gh) for PR commands: https://cli.github.com");let o=t.find(d=>d.name==="CLAUDE.md");o?.status==="warn"&&o.message?.includes("stale")&&s.push('Run "prjct sync" to update context');let i=t.find(d=>d.name==="prjct config");i?.status==="error"&&s.push('Run "prjct init" to initialize this project'),t.find(d=>d.name==="CLAUDE.md"&&d.status==="error")&&!i?.status?.includes("error")&&s.push('Run "prjct sync" to generate context files');let c=t.find(d=>d.name==="context7 mcp");c&&c.status!=="ok"&&s.push('Run "prjct start" to install/repair Context7 MCP');let u=t.find(d=>d.name==="codex p-router");return u&&u.status==="error"&&s.push('Run "prjct start" or "prjct setup" to repair Codex p. router'),s}printHeader(){f.section(`prjct doctor v${ae}`)}printSection(e,t){f.section(e);let s=t.map(r=>{let o=this.getStatusIcon(r.status,r.optional),i=r.name.padEnd(14),a=r.version||r.message||"",c=r.optional&&r.status==="error"?Cs.dim(" (optional)"):"";return`${o} ${i} ${Cs.dim(a)}${c}`});for(let r of s)console.log(` ${r}`)}printRecommendations(e){f.section("Recommendations"),f.list(e,{bullet:Cs.yellow("\u2022")})}printSummary(e){console.log(""),console.log(Cs.dim("\u2500".repeat(40))),e.hasErrors?f.fail("Some required checks failed"):e.hasWarnings?f.warn("All required checks passed (some warnings)"):f.done("All checks passed"),console.log("")}getStatusIcon(e,t){switch(e){case"ok":return Cs.green("\u2713");case"warn":return Cs.yellow("\u26A0");case"error":return t?Cs.dim("\u25CB"):Cs.red("\u2717")}}},fT=new ji});var Sf={};W(Sf,{WatchService:()=>Ri,watchService:()=>vT});import hT from"node:path";import Be from"chalk";import yT from"chokidar";var wT,kT,Ri,vT,bf=h(()=>{"use strict";de();V();be();Wo();wT=["package.json","package-lock.json","bun.lockb","pnpm-lock.yaml","yarn.lock","tsconfig.json","tsconfig.*.json",".env",".env.*","Cargo.toml","go.mod","pyproject.toml","requirements.txt","src/**/*.ts","src/**/*.tsx","src/**/*.js","src/**/*.jsx","lib/**/*.ts","core/**/*.ts","app/**/*.ts","app/**/*.tsx","pages/**/*.ts","pages/**/*.tsx"],kT=["**/node_modules/**","**/.git/**","**/dist/**","**/build/**","**/.next/**","**/.nuxt/**","**/coverage/**","**/*.log","**/*.tmp","**/CLAUDE.md","**/.cursorrules","**/.windsurfrules","**/.prjct/**","**/.prjct-cli/**"],Ri=class{static{l(this,"WatchService")}watcher=null;projectPath="";projectId=null;debounceTimer=null;lastSyncTime=0;pendingChanges=new Set;options={debounceMs:2e3,minIntervalMs:3e4,verbose:!1,quiet:!1};isRunning=!1;syncCount=0;sigintHandler=null;sigtermHandler=null;async start(e=process.cwd(),t={}){return this.projectPath=e,this.options={...this.options,...t},this.projectId=await I.getProjectId(e),this.projectId?this.isRunning?{success:!1,error:"Watch mode is already running"}:(this.isRunning=!0,this.options.quiet||this.printStartup(),this.watcher=yT.watch(wT,{cwd:this.projectPath,ignored:kT,persistent:!0,ignoreInitial:!0,awaitWriteFinish:{stabilityThreshold:500,pollInterval:100}}),this.watcher.on("add",s=>this.handleChange("add",s)).on("change",s=>this.handleChange("change",s)).on("unlink",s=>this.handleChange("unlink",s)).on("error",s=>this.handleError(s)),this.sigintHandler&&process.off("SIGINT",this.sigintHandler),this.sigtermHandler&&process.off("SIGTERM",this.sigtermHandler),this.sigintHandler=()=>this.stop(),this.sigtermHandler=()=>this.stop(),process.on("SIGINT",this.sigintHandler),process.on("SIGTERM",this.sigtermHandler),{success:!0}):{success:!1,error:'No prjct project. Run "prjct init" first.'}}async stop(){this.options.quiet||(console.log(""),console.log(Be.dim(`
1338
+ GROUP BY 1`,dT,r)}catch{return null}let i=0,a=0;for(let c of o)c.type==="edit"?i=c.count:a=c.count;return i===0||a>0?null:["# prjct: capture checkpoint","",`${i} file edit${i===1?"":"s"} this session without a memory entry.`,"",'If anything was reusable \u2014 a decision, a gotcha, a pattern \u2014 `prjct remember <type> "<content>"` keeps it around for future sessions.',"","> Skip if nothing worth saving."].join(`
1339
+ `)}async function pT(n=process.cwd()){await lt(async()=>{await ct();let e=await I.readConfig(n).catch(()=>null),t=await df(n,e);if(_e(Et("Stop",t)),!!e?.projectId){try{await el(n)}catch{}await Mr(n,e.projectId).catch(()=>{})}})}var uT,dT,mf=h(()=>{"use strict";de();as();ri();ce();Es();uT=30*60*1e3,dT="memory.post_edit";l(df,"buildStopContext");l(pT,"runStopHook")});var gf={};W(gf,{runSubagentStartHook:()=>mT});async function mT(n=process.cwd()){await lt(async()=>{await ct();let e=await Zn(n);_e(Et("SubagentStart",e))})}var ff=h(()=>{"use strict";Es();ji();l(mT,"runSubagentStartHook")});var hf={};W(hf,{runCwdChangedHook:()=>gT});async function gT(n=process.cwd()){await lt(async()=>{let t=(await ct()).cwd||n,s=await Zn(t);_e(Et("CwdChanged",s))})}var yf=h(()=>{"use strict";Es();ji();l(gT,"runCwdChangedHook")});var kf={};W(kf,{DoctorService:()=>Ri,doctorService:()=>hT});import{execSync as Fl}from"node:child_process";import fT from"node:fs/promises";import wf from"node:path";import Cs from"chalk";var Ri,hT,vf=h(()=>{"use strict";de();Re();Cn();ot();J();Me();ze();Er();Ri=class{static{l(this,"DoctorService")}projectPath="";projectId=null;globalPath="";async check(e=process.cwd()){this.projectPath=e,this.projectId=await I.getProjectId(e),this.projectId&&(this.globalPath=$.getGlobalProjectPath(this.projectId));let t=await this.checkTools(),s=await this.checkProject(),r=this.generateRecommendations(t,s),o=[...t,...s].some(a=>a.status==="error"&&!a.optional),i=[...t,...s].some(a=>a.status==="warn"||a.status==="error"&&a.optional);return{success:!o,tools:t,project:s,recommendations:r,hasErrors:o,hasWarnings:i}}async run(e=process.cwd()){let t=await this.check(e);return this.printHeader(),this.printSection("System Tools",t.tools),this.printSection("Project Status",t.project),t.recommendations.length>0&&this.printRecommendations(t.recommendations),this.printSummary(t),t.hasErrors?1:0}async checkTools(){let e=[];return e.push(this.checkCommand("git","git --version",/git version ([\d.]+)/,!1)),e.push(this.checkCommand("node","node --version",/v([\d.]+)/,!1)),e.push(this.checkCommand("bun","bun --version",/([\d.]+)/,!0)),e.push(this.checkCommand("gh","gh --version",/gh version ([\d.]+)/,!0,"needed for PR commands")),e.push(this.checkCommand("claude","claude --version",/claude ([\d.]+)/,!0,"Anthropic Claude Code CLI")),e.push(this.checkCommand("gemini","gemini --version",/gemini ([\d.]+)/,!0,"Google Gemini CLI")),e}checkCommand(e,t,s,r,o){try{let a=Fl(t,{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).match(s),c=a?a[1]:"unknown";return{name:e,status:"ok",version:c,optional:r}}catch{return{name:e,status:"error",message:o?`not found (${o})`:"not found",optional:r}}}async checkProject(){let e=[];return e.push(await this.checkPrjctConfig()),e.push(await this.checkClaudeMd()),e.push(await this.checkGitRepo()),e.push(await this.checkStateFile()),e.push(await this.checkContext7()),e.push(await this.checkCodexPRouter()),e}async checkPrjctConfig(){let e=wf.join(this.projectPath,".prjct","prjct.config.json");return await b(e)?{name:"prjct config",status:"ok",message:"initialized"}:{name:"prjct config",status:"error",message:'not initialized - run "prjct init"'}}async checkClaudeMd(){if(!this.globalPath)return{name:"CLAUDE.md",status:"warn",message:"project not initialized"};let e=wf.join(this.globalPath,"context","CLAUDE.md");try{let t=await fT.stat(e),s=Date.now()-t.mtimeMs,r=Math.floor(s/(1e3*60*60)),o=Math.floor(r/24),i;return o>0?i=`${o} day${o>1?"s":""} ago`:r>0?i=`${r} hour${r>1?"s":""} ago`:i="recently",r>24?{name:"CLAUDE.md",status:"warn",message:`stale (last sync: ${i})`}:{name:"CLAUDE.md",status:"ok",message:`synced ${i}`}}catch{return{name:"CLAUDE.md",status:"error",message:'not found - run "prjct sync"'}}}async checkGitRepo(){try{Fl("git rev-parse --git-dir",{cwd:this.projectPath,stdio:["pipe","pipe","pipe"]});let e=Fl("git status --porcelain",{cwd:this.projectPath,encoding:"utf-8"});if(e.trim().length>0){let s=e.trim().split(`
1340
+ `).filter(Boolean);return{name:"git repo",status:"ok",message:`${s.length} uncommitted change${s.length>1?"s":""}`}}return{name:"git repo",status:"ok",message:"clean"}}catch{return{name:"git repo",status:"warn",message:"not a git repository"}}}async checkStateFile(){if(!this.globalPath||!this.projectId)return{name:"task state",status:"warn",message:"project not initialized"};try{let e=await D.read(this.projectId);return e.currentTask?{name:"task state",status:"ok",message:`active: ${e.currentTask.description?.slice(0,30)}...`}:{name:"task state",status:"ok",message:"no active task"}}catch{return{name:"task state",status:"ok",message:"no state data (normal for new projects)",optional:!0}}}async checkContext7(){try{let e=await ns.verify();return e.installed?e.verified?{name:"context7 mcp",status:"ok",message:"ready"}:{name:"context7 mcp",status:"error",message:e.message||"configured but verification failed"}:{name:"context7 mcp",status:"error",message:'not configured - run "prjct start"'}}catch(e){return{name:"context7 mcp",status:"error",message:`check failed: ${e instanceof Error?e.message:"unknown error"}`}}}async checkCodexPRouter(){try{let e=await En({autoRepair:!0});return e.installed?e.verified?{name:"codex p-router",status:"ok",message:`ready (${e.templateSource||"local-dev"})`}:{name:"codex p-router",status:"error",message:e.message||"router verification failed"}:{name:"codex p-router",status:"ok",message:"codex not detected (check skipped)",optional:!0}}catch(e){return{name:"codex p-router",status:"error",message:`check failed: ${e instanceof Error?e.message:"unknown error"}`}}}generateRecommendations(e,t){let s=[];e.find(d=>d.name==="gh"&&d.status==="error")&&s.push("Install GitHub CLI (gh) for PR commands: https://cli.github.com");let o=t.find(d=>d.name==="CLAUDE.md");o?.status==="warn"&&o.message?.includes("stale")&&s.push('Run "prjct sync" to update context');let i=t.find(d=>d.name==="prjct config");i?.status==="error"&&s.push('Run "prjct init" to initialize this project'),t.find(d=>d.name==="CLAUDE.md"&&d.status==="error")&&!i?.status?.includes("error")&&s.push('Run "prjct sync" to generate context files');let c=t.find(d=>d.name==="context7 mcp");c&&c.status!=="ok"&&s.push('Run "prjct start" to install/repair Context7 MCP');let u=t.find(d=>d.name==="codex p-router");return u&&u.status==="error"&&s.push('Run "prjct start" or "prjct setup" to repair Codex p. router'),s}printHeader(){f.section(`prjct doctor v${ae}`)}printSection(e,t){f.section(e);let s=t.map(r=>{let o=this.getStatusIcon(r.status,r.optional),i=r.name.padEnd(14),a=r.version||r.message||"",c=r.optional&&r.status==="error"?Cs.dim(" (optional)"):"";return`${o} ${i} ${Cs.dim(a)}${c}`});for(let r of s)console.log(` ${r}`)}printRecommendations(e){f.section("Recommendations"),f.list(e,{bullet:Cs.yellow("\u2022")})}printSummary(e){console.log(""),console.log(Cs.dim("\u2500".repeat(40))),e.hasErrors?f.fail("Some required checks failed"):e.hasWarnings?f.warn("All required checks passed (some warnings)"):f.done("All checks passed"),console.log("")}getStatusIcon(e,t){switch(e){case"ok":return Cs.green("\u2713");case"warn":return Cs.yellow("\u26A0");case"error":return t?Cs.dim("\u25CB"):Cs.red("\u2717")}}},hT=new Ri});var Sf={};W(Sf,{WatchService:()=>xi,watchService:()=>ST});import yT from"node:path";import Be from"chalk";import wT from"chokidar";var kT,vT,xi,ST,bf=h(()=>{"use strict";de();V();be();Go();kT=["package.json","package-lock.json","bun.lockb","pnpm-lock.yaml","yarn.lock","tsconfig.json","tsconfig.*.json",".env",".env.*","Cargo.toml","go.mod","pyproject.toml","requirements.txt","src/**/*.ts","src/**/*.tsx","src/**/*.js","src/**/*.jsx","lib/**/*.ts","core/**/*.ts","app/**/*.ts","app/**/*.tsx","pages/**/*.ts","pages/**/*.tsx"],vT=["**/node_modules/**","**/.git/**","**/dist/**","**/build/**","**/.next/**","**/.nuxt/**","**/coverage/**","**/*.log","**/*.tmp","**/CLAUDE.md","**/.cursorrules","**/.windsurfrules","**/.prjct/**","**/.prjct-cli/**"],xi=class{static{l(this,"WatchService")}watcher=null;projectPath="";projectId=null;debounceTimer=null;lastSyncTime=0;pendingChanges=new Set;options={debounceMs:2e3,minIntervalMs:3e4,verbose:!1,quiet:!1};isRunning=!1;syncCount=0;sigintHandler=null;sigtermHandler=null;async start(e=process.cwd(),t={}){return this.projectPath=e,this.options={...this.options,...t},this.projectId=await I.getProjectId(e),this.projectId?this.isRunning?{success:!1,error:"Watch mode is already running"}:(this.isRunning=!0,this.options.quiet||this.printStartup(),this.watcher=wT.watch(kT,{cwd:this.projectPath,ignored:vT,persistent:!0,ignoreInitial:!0,awaitWriteFinish:{stabilityThreshold:500,pollInterval:100}}),this.watcher.on("add",s=>this.handleChange("add",s)).on("change",s=>this.handleChange("change",s)).on("unlink",s=>this.handleChange("unlink",s)).on("error",s=>this.handleError(s)),this.sigintHandler&&process.off("SIGINT",this.sigintHandler),this.sigtermHandler&&process.off("SIGTERM",this.sigtermHandler),this.sigintHandler=()=>this.stop(),this.sigtermHandler=()=>this.stop(),process.on("SIGINT",this.sigintHandler),process.on("SIGTERM",this.sigtermHandler),{success:!0}):{success:!1,error:'No prjct project. Run "prjct init" first.'}}async stop(){this.options.quiet||(console.log(""),console.log(Be.dim(`
1341
1341
  \u{1F44B} Stopped watching (${this.syncCount} syncs performed)`))),this.debounceTimer&&(clearTimeout(this.debounceTimer),this.debounceTimer=null),this.watcher&&(await this.watcher.close(),this.watcher=null),this.sigintHandler&&(process.off("SIGINT",this.sigintHandler),this.sigintHandler=null),this.sigtermHandler&&(process.off("SIGTERM",this.sigtermHandler),this.sigtermHandler=null),this.pendingChanges.clear(),this.isRunning=!1,process.exit(0)}handleChange(e,t){if(this.pendingChanges.add(t),this.options.verbose&&!this.options.quiet){let s=e==="add"?"\u2795":e==="unlink"?"\u2796":"\u{1F4DD}";console.log(Be.dim(` ${s} ${t}`))}this.scheduleSyncIfNeeded()}scheduleSyncIfNeeded(){this.debounceTimer&&clearTimeout(this.debounceTimer),this.debounceTimer=setTimeout(async()=>{let t=Date.now()-this.lastSyncTime;if(t<this.options.minIntervalMs&&this.lastSyncTime>0){let s=this.options.minIntervalMs-t;this.options.verbose&&!this.options.quiet&&console.log(Be.dim(` \u23F3 Rate limited, waiting ${Math.round(s/1e3)}s...`)),this.debounceTimer=setTimeout(()=>this.performSync(),s);return}await this.performSync()},this.options.debounceMs)}async performSync(){let e=Array.from(this.pendingChanges);if(this.pendingChanges.clear(),e.length===0)return;let t=R().split("T")[1].split(".")[0];if(!this.options.quiet){let s=e.length===1?e[0]:`${e.length} files`;console.log(`
1342
- ${Be.dim(`[${t}]`)} ${Be.cyan("\u27F3")} ${s} changed \u2192 syncing...`)}try{let s=await ns.sync(this.projectPath,{changedFiles:e});this.lastSyncTime=Date.now(),this.syncCount++,s.success?this.options.quiet||console.log(`${Be.dim(`[${t}]`)} ${Be.green("\u2713")} Synced`):console.error(`${Be.dim(`[${t}]`)} ${Be.red("\u2717")} Sync failed: ${s.error}`)}catch(s){console.error(`${Be.dim(`[${t}]`)} ${Be.red("\u2717")} Error: ${k(s)}`)}}handleError(e){console.error(Be.red(`Watch error: ${e.message}`))}printStartup(){console.log(""),console.log(Be.cyan("\u{1F441}\uFE0F Watching for changes...")),console.log(Be.dim(` Project: ${hT.basename(this.projectPath)}`)),console.log(Be.dim(` Debounce: ${this.options.debounceMs}ms`)),console.log(Be.dim(` Min interval: ${this.options.minIntervalMs/1e3}s`)),console.log(""),console.log(Be.dim(" Press Ctrl+C to stop")),console.log("")}},vT=new Ri});var Ef={};W(Ef,{getHelp:()=>jT});import q from"chalk";function bT(){let n=[];n.push(""),n.push(`${q.cyan.bold("prjct")} v${ae} - Context layer for AI coding agents`),n.push(q.dim("Works with Claude Code, Gemini CLI, Cursor, Windsurf, and more.")),n.push(""),n.push(q.bold("QUICK START")),n.push(q.dim("\u2500".repeat(60))),n.push(` ${q.green("1.")} prjct start ${q.dim("# Configure AI providers")}`),n.push(` ${q.green("2.")} cd my-project && prjct init`),n.push(` ${q.green("3.")} Open in Claude Code / Gemini CLI / Cursor`),n.push(` ${q.green("4.")} p. sync ${q.dim("# Analyze project")}`),n.push(""),n.push(q.bold("TERMINAL COMMANDS")),n.push(q.dim("\u2500".repeat(60)));for(let t of Tf){let s=`prjct ${t.name}`.padEnd(22);n.push(` ${s} ${t.description}`)}n.push(""),n.push(`${q.bold("AI AGENT COMMANDS")} ${q.dim("(inside Claude/Gemini/Cursor)")}`),n.push(q.dim("\u2500".repeat(60))),n.push(` ${"Command".padEnd(22)} Description`),n.push(` ${q.dim("\u2500".repeat(56))}`);let e=Bn.filter(t=>t.group==="core"&&t.usage?.claude);for(let t of e.slice(0,10)){let s=`p. ${t.name}`.padEnd(22);n.push(` ${s} ${t.description}`)}n.push(` ${q.dim(`... and ${e.length-10} more (run 'prjct help commands')`)}`),n.push(""),n.push(q.bold("FLAGS")),n.push(q.dim("\u2500".repeat(60)));for(let t of ST)n.push(` ${t.flag.padEnd(22)} ${t.description}`);return n.push(""),n.push(q.bold("MORE INFO")),n.push(q.dim("\u2500".repeat(60))),n.push(` Documentation: ${q.cyan("https://prjct.app")}`),n.push(` GitHub: ${q.cyan("https://github.com/jlopezlira/prjct-cli")}`),n.push(" Per-command: prjct help <command>"),n.push(""),n.join(`
1343
- `)}function TT(n){let e=Tf.find(s=>s.name===n);if(!e)return null;let t=[];if(t.push(""),t.push(`${q.cyan.bold(`prjct ${e.name}`)} - ${e.description}`),t.push(""),t.push(q.bold("USAGE")),t.push(` ${e.example}`),t.push(""),e.options){t.push(q.bold("OPTIONS"));for(let s of e.options)t.push(` ${s}`);t.push("")}if(e.subcommands){t.push(q.bold("SUBCOMMANDS"));for(let s of e.subcommands)t.push(` ${s}`);t.push("")}return t.join(`
1344
- `)}function ET(n){let e=Bn.find(r=>r.name===n);if(!e)return null;let t=[];if(t.push(""),t.push(`${q.cyan.bold(`p. ${e.name}`)} - ${e.description}`),t.push(""),t.push(q.bold("USAGE")),e.usage?.claude&&t.push(` Claude/Gemini: ${e.usage.claude.replace("/p:","p. ")}`),e.usage?.terminal&&t.push(` Terminal: ${e.usage.terminal}`),t.push(""),e.params&&(t.push(q.bold("PARAMETERS")),t.push(` ${e.params}`),t.push("")),e.features&&e.features.length>0){t.push(q.bold("FEATURES"));for(let r of e.features)t.push(` \u2022 ${r}`);t.push("")}e.blockingRules&&(t.push(q.bold("REQUIREMENTS")),t.push(` ${q.yellow("\u26A0")} ${e.blockingRules.check}`),t.push(""));let s=Or[e.group];return s&&(t.push(q.dim(`Category: ${s.title}`)),e.isOptional&&t.push(q.dim("This is an optional command.")),t.push("")),t.join(`
1345
- `)}function CT(n){let e=TT(n);if(e)return e;let t=ET(n);return t||`
1342
+ ${Be.dim(`[${t}]`)} ${Be.cyan("\u27F3")} ${s} changed \u2192 syncing...`)}try{let s=await rs.sync(this.projectPath,{changedFiles:e});this.lastSyncTime=Date.now(),this.syncCount++,s.success?this.options.quiet||console.log(`${Be.dim(`[${t}]`)} ${Be.green("\u2713")} Synced`):console.error(`${Be.dim(`[${t}]`)} ${Be.red("\u2717")} Sync failed: ${s.error}`)}catch(s){console.error(`${Be.dim(`[${t}]`)} ${Be.red("\u2717")} Error: ${k(s)}`)}}handleError(e){console.error(Be.red(`Watch error: ${e.message}`))}printStartup(){console.log(""),console.log(Be.cyan("\u{1F441}\uFE0F Watching for changes...")),console.log(Be.dim(` Project: ${yT.basename(this.projectPath)}`)),console.log(Be.dim(` Debounce: ${this.options.debounceMs}ms`)),console.log(Be.dim(` Min interval: ${this.options.minIntervalMs/1e3}s`)),console.log(""),console.log(Be.dim(" Press Ctrl+C to stop")),console.log("")}},ST=new xi});var Ef={};W(Ef,{getHelp:()=>RT});import q from"chalk";function TT(){let n=[];n.push(""),n.push(`${q.cyan.bold("prjct")} v${ae} - Context layer for AI coding agents`),n.push(q.dim("Works with Claude Code, Gemini CLI, Cursor, Windsurf, and more.")),n.push(""),n.push(q.bold("QUICK START")),n.push(q.dim("\u2500".repeat(60))),n.push(` ${q.green("1.")} prjct start ${q.dim("# Configure AI providers")}`),n.push(` ${q.green("2.")} cd my-project && prjct init`),n.push(` ${q.green("3.")} Open in Claude Code / Gemini CLI / Cursor`),n.push(` ${q.green("4.")} p. sync ${q.dim("# Analyze project")}`),n.push(""),n.push(q.bold("TERMINAL COMMANDS")),n.push(q.dim("\u2500".repeat(60)));for(let t of Tf){let s=`prjct ${t.name}`.padEnd(22);n.push(` ${s} ${t.description}`)}n.push(""),n.push(`${q.bold("AI AGENT COMMANDS")} ${q.dim("(inside Claude/Gemini/Cursor)")}`),n.push(q.dim("\u2500".repeat(60))),n.push(` ${"Command".padEnd(22)} Description`),n.push(` ${q.dim("\u2500".repeat(56))}`);let e=Bn.filter(t=>t.group==="core"&&t.usage?.claude);for(let t of e.slice(0,10)){let s=`p. ${t.name}`.padEnd(22);n.push(` ${s} ${t.description}`)}n.push(` ${q.dim(`... and ${e.length-10} more (run 'prjct help commands')`)}`),n.push(""),n.push(q.bold("FLAGS")),n.push(q.dim("\u2500".repeat(60)));for(let t of bT)n.push(` ${t.flag.padEnd(22)} ${t.description}`);return n.push(""),n.push(q.bold("MORE INFO")),n.push(q.dim("\u2500".repeat(60))),n.push(` Documentation: ${q.cyan("https://prjct.app")}`),n.push(` GitHub: ${q.cyan("https://github.com/jlopezlira/prjct-cli")}`),n.push(" Per-command: prjct help <command>"),n.push(""),n.join(`
1343
+ `)}function ET(n){let e=Tf.find(s=>s.name===n);if(!e)return null;let t=[];if(t.push(""),t.push(`${q.cyan.bold(`prjct ${e.name}`)} - ${e.description}`),t.push(""),t.push(q.bold("USAGE")),t.push(` ${e.example}`),t.push(""),e.options){t.push(q.bold("OPTIONS"));for(let s of e.options)t.push(` ${s}`);t.push("")}if(e.subcommands){t.push(q.bold("SUBCOMMANDS"));for(let s of e.subcommands)t.push(` ${s}`);t.push("")}return t.join(`
1344
+ `)}function CT(n){let e=Bn.find(r=>r.name===n);if(!e)return null;let t=[];if(t.push(""),t.push(`${q.cyan.bold(`p. ${e.name}`)} - ${e.description}`),t.push(""),t.push(q.bold("USAGE")),e.usage?.claude&&t.push(` Claude/Gemini: ${e.usage.claude.replace("/p:","p. ")}`),e.usage?.terminal&&t.push(` Terminal: ${e.usage.terminal}`),t.push(""),e.params&&(t.push(q.bold("PARAMETERS")),t.push(` ${e.params}`),t.push("")),e.features&&e.features.length>0){t.push(q.bold("FEATURES"));for(let r of e.features)t.push(` \u2022 ${r}`);t.push("")}e.blockingRules&&(t.push(q.bold("REQUIREMENTS")),t.push(` ${q.yellow("\u26A0")} ${e.blockingRules.check}`),t.push(""));let s=Or[e.group];return s&&(t.push(q.dim(`Category: ${s.title}`)),e.isOptional&&t.push(q.dim("This is an optional command.")),t.push("")),t.join(`
1345
+ `)}function PT(n){let e=ET(n);if(e)return e;let t=CT(n);return t||`
1346
1346
  ${q.yellow(`Command '${n}' not found.`)}
1347
1347
 
1348
1348
  Run 'prjct help' to see all available commands.
1349
- `}function PT(){let n=[];n.push(""),n.push(q.cyan.bold("All Commands")),n.push("");let e=Object.entries(Or).sort((t,s)=>t[1].order-s[1].order);for(let[t,s]of e){let r=Bn.filter(o=>o.group===t);if(r.length!==0){n.push(`${q.bold(s.title)} ${q.dim(`(${r.length} commands)`)}`),n.push(q.dim(s.description)),n.push("");for(let o of r){let i=`p. ${o.name}`.padEnd(18),a=o.description.length>45?`${o.description.slice(0,42)}...`:o.description;n.push(` ${i} ${a}`)}n.push("")}}return n.push(q.dim("Run 'prjct help <command>' for detailed help on a specific command.")),n.push(""),n.join(`
1350
- `)}function jT(n){return n?n==="commands"||n==="all"?PT():CT(n):bT()}var Tf,ST,Cf=h(()=>{"use strict";Al();ze();Tf=[{name:"start",description:"First-time setup wizard",example:"prjct start"},{name:"init",description:"Initialize project in current directory",example:"prjct init"},{name:"sync",description:"Sync project state and update context files",example:"prjct sync"},{name:"watch",description:"Auto-sync on file changes",example:"prjct watch",options:["--verbose","--debounce=<ms>","--interval=<sec>"]},{name:"hooks",description:"Manage git hooks for auto-sync",example:"prjct hooks install",subcommands:["install","uninstall","status"]},{name:"doctor",description:"Check system health and dependencies",example:"prjct doctor"},{name:"serve",description:"Start web dashboard server",example:"prjct serve [port]"},{name:"context",description:"Smart context filtering tools for AI",example:'prjct context files "add auth"',subcommands:["files","signatures","imports","recent","summary"]},{name:"stop",description:"Stop the background daemon",example:"prjct stop",options:["--force"]},{name:"restart",description:"Restart the background daemon",example:"prjct restart"},{name:"uninstall",description:"Complete system removal of prjct",example:"prjct uninstall --backup",options:["--force","--backup","--dry-run","--keep-package"]}],ST=[{flag:"-q, --quiet",description:"Suppress all output (errors to stderr only)"},{flag:"-v, --version",description:"Show version and provider status"},{flag:"-h, --help",description:"Show this help message"}];l(bT,"formatMainHelp");l(TT,"formatTerminalCommandHelp");l(ET,"formatAgentCommandHelp");l(CT,"formatCommandHelp");l(PT,"formatCommandList");l(jT,"getHelp")});var Pf=Hf((c1,RT)=>{RT.exports={name:"prjct-cli",version:"2.2.7",description:"Context layer for AI agents. Project context for Claude Code, Gemini CLI, and more.",main:"dist/bin/prjct.mjs",bin:{prjct:"bin/prjct"},publishConfig:{access:"public",registry:"https://registry.npmjs.org"},scripts:{build:"node scripts/build.js","build:node":"node scripts/build.js",release:"node scripts/release.js","release:patch":"node scripts/release.js patch","release:minor":"node scripts/release.js minor","release:major":"node scripts/release.js major",postinstall:"node scripts/postinstall.js",prepare:"lefthook install","update-commands":`bun -e "const installer = require('./core/infrastructure/command-installer'); installer.syncCommands().then(r => console.log('Commands updated:', r)).catch(e => console.error('Error:', e.message))"`,"install-global":"./scripts/install.sh",update:"./scripts/update.sh",test:"bun test","test:watch":"bun test --watch","test:coverage":"bun test --coverage",typecheck:"tsc --noEmit -p core/tsconfig.json","typecheck:watch":"tsc --noEmit -p core/tsconfig.json --watch",validate:"bun scripts/validate-commands.js",lint:"biome lint .","lint:fix":"biome lint --write .",knip:"knip","lint:meta":"bun core/cli/lint-meta-commentary.ts",format:"biome format --write .","format:check":"biome format .",check:"biome check .","check:fix":"biome check --write ."},keywords:["claude-code","gemini-cli","ai-agents","context-layer","developer-tools","ai-assistant","productivity","mcp","llm","coding-agents"],author:"prjct.app",license:"MIT",dependencies:{"@clack/prompts":"1.0.0","@hono/node-server":"1.19.14","@modelcontextprotocol/sdk":"1.28.0","better-sqlite3":"12.6.2",chalk:"4.1.2",chokidar:"5.0.0","date-fns":"4.1.0",glob:"13.0.1",hono:"4.12.14","jsonc-parser":"3.3.1",zod:"3.24.1"},overrides:{"path-to-regexp":"8.4.0","brace-expansion":"5.0.5",hono:"4.12.14","@hono/node-server":"1.19.14"},devDependencies:{"@biomejs/biome":"2.3.13","@types/better-sqlite3":"7.6.13","@types/bun":"latest","@types/chokidar":"2.1.7",esbuild:"0.25.0",knip:"6.3.1",lefthook:"2.1.0",typescript:"5.9.3"},repository:{type:"git",url:"git+https://github.com/jlopezlira/prjct-cli.git"},bugs:{url:"https://github.com/jlopezlira/prjct-cli/issues"},homepage:"https://prjct.app",packageManager:"bun@1.2.23",engines:{bun:">=1.0.0",node:">=22.22.2"},files:["assets/","bin/prjct","dist/","templates/","scripts/postinstall.js","scripts/ensure-bun.sh","scripts/install.sh","LICENSE","README.md","CHANGELOG.md"],prepublishOnly:"node scripts/build.js",trustedDependencies:["chalk"]}});var _T={};import jf from"node:os";import xi from"node:path";import je from"chalk";async function xT(){let[n,...e]=process.argv.slice(2);if(["-v","--version","version"].includes(n)){let s=await Promise.resolve().then(()=>Wf(Pf()));await DT(s.version),process.exit(0)}if(["-h","--help",void 0].includes(n)&&(MT(),process.exit(0)),n&&Ci(n)&&!te.getByName(n)){let s=Ei[n];s&&(f.failWithHint({message:`'prjct ${n}' was removed in v2. ${s.note}`,hint:`Use: ${s.replacement}`}),process.exit(1))}if(n&&!te.getByName(n)&&!(e.length===0&&Rf(n)!==null)){let r=[n,...e.filter(i=>!i.startsWith("-"))].join(" "),o=e.filter(i=>i.startsWith("-"));n="capture",e=[r,...o]}let t=e.includes("--md");t||f.start();try{let s=te.getByName(n);if(!s){let p=Rf(n),g=p?`Did you mean 'prjct ${p}'? Run 'prjct --help' for all commands`:"Run 'prjct --help' to see available commands";f.failWithHint(vr("UNKNOWN_COMMAND",{message:`Unknown command: ${n}`,hint:g})),t||f.end(),process.exit(1)}if(s.deprecated){let p=s.replacedBy?`Use 'prjct ${s.replacedBy}' instead`:"Run 'prjct --help' to see available commands";f.failWithHint({message:`Command '${n}' is deprecated`,hint:p}),t||f.end(),process.exit(1)}s.implemented||(f.failWithHint({message:`Command '${n}' is not yet implemented`,hint:"Run 'prjct --help' to see available commands",docs:"https://github.com/jlopezlira/prjct-cli"}),t||f.end(),process.exit(1));let{parsedArgs:r,options:o}=$T(s,e),i=!process.stdin.isTTY||o.md===!0||o.json===!0;s.requiresLlm&&!i&&(f.failWithHint({message:`'prjct ${n}' requires an AI agent to process its output`,hint:`Use 'p. ${n}' inside Claude/Cursor, or add --md flag`}),t||f.end(),process.exit(1));let a=AT(s,r);a&&(f.failWithHint(a),t||f.end(),process.exit(1));let c=null,u=Date.now();try{c=await I.getProjectId(process.cwd()),c&&(await wn.expireIfStale(c),await wn.touch(c))}catch{}let d=new Ts,m;if(n==="analyze")m=await d.analyze(o);else if(n==="setup")m=await d.setup(o);else if(n==="update")m=await d.update(o);else{let p=r.join(" ")||null,g=o.md===!0,j={task:l(T=>d.task(T,process.cwd(),{md:g}),"task"),init:l(T=>d.init({idea:T,yes:o.yes===!0,pack:o.pack?String(o.pack):void 0,persona:o.persona?String(o.persona):void 0}),"init"),ship:l(T=>d.ship(T,process.cwd(),{md:g}),"ship"),workflow:l(T=>d.workflowPrefs(T,process.cwd(),{md:g}),"workflow"),sync:l(()=>d.sync(process.cwd(),{preview:o.preview===!0||o["dry-run"]===!0,yes:o.yes===!0,json:o.json===!0,md:g,package:o.package?String(o.package):void 0,full:o.full===!0}),"sync"),"analysis-save-llm":l(T=>T?d.saveLlmAnalysis(T,process.cwd(),{md:g}):Promise.resolve({success:!1,error:"analysis-save-llm requires a JSON payload as positional arg"}),"analysis-save-llm"),regen:l(()=>d.regenVault(process.cwd(),{md:g}),"regen"),start:l(()=>d.start(),"start"),context:l(T=>d.context(T),"context"),status:l(T=>d.status(T,process.cwd(),{md:g}),"status"),tag:l(T=>d.tag(T,process.cwd(),{md:g}),"tag"),remember:l(T=>d.remember(T,process.cwd(),{md:g,tags:o.tags?String(o.tags):void 0}),"remember"),login:l(()=>d.login({md:g,url:o.url?String(o.url):void 0}),"login"),logout:l(()=>d.logout(),"logout"),auth:l(T=>d.auth(T,{md:g}),"auth"),seed:l(T=>d.seed(T,process.cwd(),{md:g}),"seed"),install:l(()=>d.install(null,process.cwd(),{md:g}),"install"),capture:l(T=>d.capture(T,process.cwd(),{md:g,tags:o.tags?String(o.tags):void 0,force:o.force===!0}),"capture")}[n];if(j)m=await j(p);else throw new Error(`Command '${n}' has no handler`)}if(c){let p=Date.now()-u;try{await wn.trackCommand(c,n,p)}catch{}try{await Sr.recordTiming(c,"command_duration",p,{command:n});let g=globalThis.__perfStartNs;if(g){let y=Number(process.hrtime.bigint()-g)/1e6;await Sr.recordTiming(c,"startup_time",y)}await Sr.recordMemory(c,{command:n})}catch{}}m?.message&&console.log(m.message),t||f.end(),process.exit(m?.success?0:1)}catch(s){console.error("Error:",k(s)),process.env.DEBUG&&console.error(_i(s)),t||f.end(),process.exit(1)}}function AT(n,e){if(!n.params)return null;let t=n.params.match(/<[^>]+>/g);if(!t||t.length===0)return null;if(e.length<t.length){let s=t.map(o=>o.slice(1,-1)).join(", "),r=n.usage.terminal||`prjct ${n.name} ${n.params}`;return vr("MISSING_PARAM",{message:`Missing required parameter: ${s}`,hint:`Usage: ${r}`})}return null}function Rf(n){let e=te.getAll().map(r=>r.name),t=null,s=1/0;for(let r of e){let o=IT(n.toLowerCase(),r.toLowerCase());o<s&&(s=o,t=r)}return s<=2?t:null}function IT(n,e){let t=n.length,s=e.length,r=Array.from({length:t+1},()=>Array(s+1).fill(0));for(let o=0;o<=t;o++)r[o][0]=o;for(let o=0;o<=s;o++)r[0][o]=o;for(let o=1;o<=t;o++)for(let i=1;i<=s;i++)r[o][i]=n[o-1]===e[i-1]?r[o-1][i-1]:1+Math.min(r[o-1][i],r[o][i-1],r[o-1][i-1]);return r[t][s]}function $T(n,e){let t=[],s={};for(let r=0;r<e.length;r++){let o=e[r];if(o.startsWith("--")){let i=o.slice(2);r+1<e.length&&!e[r+1].startsWith("--")?s[i]=e[++r]:s[i]=!0}else t.push(o)}return{parsedArgs:t,options:s}}async function DT(n){let e=await us(),t=xi.join(jf.homedir(),".claude","commands","p.md"),s=xi.join(jf.homedir(),".gemini","commands","p.toml"),[r,o,i,a]=await Promise.all([b(t),b(s),b(xi.join(process.cwd(),".cursor","commands","sync.md")),b(xi.join(process.cwd(),".cursor"))]),c=await ir();if(console.log(`
1349
+ `}function jT(){let n=[];n.push(""),n.push(q.cyan.bold("All Commands")),n.push("");let e=Object.entries(Or).sort((t,s)=>t[1].order-s[1].order);for(let[t,s]of e){let r=Bn.filter(o=>o.group===t);if(r.length!==0){n.push(`${q.bold(s.title)} ${q.dim(`(${r.length} commands)`)}`),n.push(q.dim(s.description)),n.push("");for(let o of r){let i=`p. ${o.name}`.padEnd(18),a=o.description.length>45?`${o.description.slice(0,42)}...`:o.description;n.push(` ${i} ${a}`)}n.push("")}}return n.push(q.dim("Run 'prjct help <command>' for detailed help on a specific command.")),n.push(""),n.join(`
1350
+ `)}function RT(n){return n?n==="commands"||n==="all"?jT():PT(n):TT()}var Tf,bT,Cf=h(()=>{"use strict";$l();ze();Tf=[{name:"start",description:"First-time setup wizard",example:"prjct start"},{name:"init",description:"Initialize project in current directory",example:"prjct init"},{name:"sync",description:"Sync project state and update context files",example:"prjct sync"},{name:"watch",description:"Auto-sync on file changes",example:"prjct watch",options:["--verbose","--debounce=<ms>","--interval=<sec>"]},{name:"hooks",description:"Manage git hooks for auto-sync",example:"prjct hooks install",subcommands:["install","uninstall","status"]},{name:"doctor",description:"Check system health and dependencies",example:"prjct doctor"},{name:"serve",description:"Start web dashboard server",example:"prjct serve [port]"},{name:"context",description:"Smart context filtering tools for AI",example:'prjct context files "add auth"',subcommands:["files","signatures","imports","recent","summary"]},{name:"stop",description:"Stop the background daemon",example:"prjct stop",options:["--force"]},{name:"restart",description:"Restart the background daemon",example:"prjct restart"},{name:"uninstall",description:"Complete system removal of prjct",example:"prjct uninstall --backup",options:["--force","--backup","--dry-run","--keep-package"]}],bT=[{flag:"-q, --quiet",description:"Suppress all output (errors to stderr only)"},{flag:"-v, --version",description:"Show version and provider status"},{flag:"-h, --help",description:"Show this help message"}];l(TT,"formatMainHelp");l(ET,"formatTerminalCommandHelp");l(CT,"formatAgentCommandHelp");l(PT,"formatCommandHelp");l(jT,"formatCommandList");l(RT,"getHelp")});var Pf=Hf((l1,xT)=>{xT.exports={name:"prjct-cli",version:"2.2.8",description:"Context layer for AI agents. Project context for Claude Code, Gemini CLI, and more.",main:"dist/bin/prjct.mjs",bin:{prjct:"bin/prjct"},publishConfig:{access:"public",registry:"https://registry.npmjs.org"},scripts:{build:"node scripts/build.js","build:node":"node scripts/build.js",release:"node scripts/release.js","release:patch":"node scripts/release.js patch","release:minor":"node scripts/release.js minor","release:major":"node scripts/release.js major",postinstall:"node scripts/postinstall.js",prepare:"lefthook install","update-commands":`bun -e "const installer = require('./core/infrastructure/command-installer'); installer.syncCommands().then(r => console.log('Commands updated:', r)).catch(e => console.error('Error:', e.message))"`,"install-global":"./scripts/install.sh",update:"./scripts/update.sh",test:"bun test","test:watch":"bun test --watch","test:coverage":"bun test --coverage",typecheck:"tsc --noEmit -p core/tsconfig.json","typecheck:watch":"tsc --noEmit -p core/tsconfig.json --watch",validate:"bun scripts/validate-commands.js",lint:"biome lint .","lint:fix":"biome lint --write .",knip:"knip","lint:meta":"bun core/cli/lint-meta-commentary.ts",format:"biome format --write .","format:check":"biome format .",check:"biome check .","check:fix":"biome check --write ."},keywords:["claude-code","gemini-cli","ai-agents","context-layer","developer-tools","ai-assistant","productivity","mcp","llm","coding-agents"],author:"prjct.app",license:"MIT",dependencies:{"@clack/prompts":"1.0.0","@hono/node-server":"1.19.14","@modelcontextprotocol/sdk":"1.28.0","better-sqlite3":"12.6.2",chalk:"4.1.2",chokidar:"5.0.0","date-fns":"4.1.0",glob:"13.0.1",hono:"4.12.14","jsonc-parser":"3.3.1",zod:"3.24.1"},overrides:{"path-to-regexp":"8.4.0","brace-expansion":"5.0.5",hono:"4.12.14","@hono/node-server":"1.19.14"},devDependencies:{"@biomejs/biome":"2.3.13","@types/better-sqlite3":"7.6.13","@types/bun":"latest","@types/chokidar":"2.1.7",esbuild:"0.25.0",knip:"6.3.1",lefthook:"2.1.0",typescript:"5.9.3"},repository:{type:"git",url:"git+https://github.com/jlopezlira/prjct-cli.git"},bugs:{url:"https://github.com/jlopezlira/prjct-cli/issues"},homepage:"https://prjct.app",packageManager:"bun@1.2.23",engines:{bun:">=1.0.0",node:">=22.22.2"},files:["assets/","bin/prjct","dist/","templates/","scripts/postinstall.js","scripts/ensure-bun.sh","scripts/install.sh","LICENSE","README.md","CHANGELOG.md"],prepublishOnly:"node scripts/build.js",trustedDependencies:["chalk"]}});var NT={};import jf from"node:os";import Ai from"node:path";import je from"chalk";async function AT(){let[n,...e]=process.argv.slice(2);if(["-v","--version","version"].includes(n)){let s=await Promise.resolve().then(()=>Wf(Pf()));await MT(s.version),process.exit(0)}if(["-h","--help",void 0].includes(n)&&(_T(),process.exit(0)),n&&Pi(n)&&!te.getByName(n)){let s=Ci[n];s&&(f.failWithHint({message:`'prjct ${n}' was removed in v2. ${s.note}`,hint:`Use: ${s.replacement}`}),process.exit(1))}if(n&&!te.getByName(n)&&!(e.length===0&&Rf(n)!==null)){let r=[n,...e.filter(i=>!i.startsWith("-"))].join(" "),o=e.filter(i=>i.startsWith("-"));n="capture",e=[r,...o]}let t=e.includes("--md");t||f.start();try{let s=te.getByName(n);if(!s){let p=Rf(n),g=p?`Did you mean 'prjct ${p}'? Run 'prjct --help' for all commands`:"Run 'prjct --help' to see available commands";f.failWithHint(vr("UNKNOWN_COMMAND",{message:`Unknown command: ${n}`,hint:g})),t||f.end(),process.exit(1)}if(s.deprecated){let p=s.replacedBy?`Use 'prjct ${s.replacedBy}' instead`:"Run 'prjct --help' to see available commands";f.failWithHint({message:`Command '${n}' is deprecated`,hint:p}),t||f.end(),process.exit(1)}s.implemented||(f.failWithHint({message:`Command '${n}' is not yet implemented`,hint:"Run 'prjct --help' to see available commands",docs:"https://github.com/jlopezlira/prjct-cli"}),t||f.end(),process.exit(1));let{parsedArgs:r,options:o}=DT(s,e),i=!process.stdin.isTTY||o.md===!0||o.json===!0;s.requiresLlm&&!i&&(f.failWithHint({message:`'prjct ${n}' requires an AI agent to process its output`,hint:`Use 'p. ${n}' inside Claude/Cursor, or add --md flag`}),t||f.end(),process.exit(1));let a=IT(s,r);a&&(f.failWithHint(a),t||f.end(),process.exit(1));let c=null,u=Date.now();try{c=await I.getProjectId(process.cwd()),c&&(await wn.expireIfStale(c),await wn.touch(c))}catch{}let d=new Ts,m;if(n==="analyze")m=await d.analyze(o);else if(n==="setup")m=await d.setup(o);else if(n==="update")m=await d.update(o);else{let p=r.join(" ")||null,g=o.md===!0,j={task:l(T=>d.task(T,process.cwd(),{md:g}),"task"),init:l(T=>d.init({idea:T,yes:o.yes===!0,pack:o.pack?String(o.pack):void 0,persona:o.persona?String(o.persona):void 0}),"init"),ship:l(T=>d.ship(T,process.cwd(),{md:g}),"ship"),workflow:l(T=>d.workflowPrefs(T,process.cwd(),{md:g}),"workflow"),sync:l(()=>d.sync(process.cwd(),{preview:o.preview===!0||o["dry-run"]===!0,yes:o.yes===!0,json:o.json===!0,md:g,package:o.package?String(o.package):void 0,full:o.full===!0}),"sync"),"analysis-save-llm":l(T=>T?d.saveLlmAnalysis(T,process.cwd(),{md:g}):Promise.resolve({success:!1,error:"analysis-save-llm requires a JSON payload as positional arg"}),"analysis-save-llm"),regen:l(()=>d.regenVault(process.cwd(),{md:g}),"regen"),start:l(()=>d.start(),"start"),context:l(T=>d.context(T),"context"),status:l(T=>d.status(T,process.cwd(),{md:g}),"status"),tag:l(T=>d.tag(T,process.cwd(),{md:g}),"tag"),remember:l(T=>d.remember(T,process.cwd(),{md:g,tags:o.tags?String(o.tags):void 0}),"remember"),login:l(()=>d.login({md:g,url:o.url?String(o.url):void 0}),"login"),logout:l(()=>d.logout(),"logout"),auth:l(T=>d.auth(T,{md:g}),"auth"),seed:l(T=>d.seed(T,process.cwd(),{md:g}),"seed"),install:l(()=>d.install(null,process.cwd(),{md:g}),"install"),capture:l(T=>d.capture(T,process.cwd(),{md:g,tags:o.tags?String(o.tags):void 0,force:o.force===!0}),"capture")}[n];if(j)m=await j(p);else throw new Error(`Command '${n}' has no handler`)}if(c){let p=Date.now()-u;try{await wn.trackCommand(c,n,p)}catch{}try{await Sr.recordTiming(c,"command_duration",p,{command:n});let g=globalThis.__perfStartNs;if(g){let y=Number(process.hrtime.bigint()-g)/1e6;await Sr.recordTiming(c,"startup_time",y)}await Sr.recordMemory(c,{command:n})}catch{}}m?.message&&console.log(m.message),t||f.end(),process.exit(m?.success?0:1)}catch(s){console.error("Error:",k(s)),process.env.DEBUG&&console.error(Ni(s)),t||f.end(),process.exit(1)}}function IT(n,e){if(!n.params)return null;let t=n.params.match(/<[^>]+>/g);if(!t||t.length===0)return null;if(e.length<t.length){let s=t.map(o=>o.slice(1,-1)).join(", "),r=n.usage.terminal||`prjct ${n.name} ${n.params}`;return vr("MISSING_PARAM",{message:`Missing required parameter: ${s}`,hint:`Usage: ${r}`})}return null}function Rf(n){let e=te.getAll().map(r=>r.name),t=null,s=1/0;for(let r of e){let o=$T(n.toLowerCase(),r.toLowerCase());o<s&&(s=o,t=r)}return s<=2?t:null}function $T(n,e){let t=n.length,s=e.length,r=Array.from({length:t+1},()=>Array(s+1).fill(0));for(let o=0;o<=t;o++)r[o][0]=o;for(let o=0;o<=s;o++)r[0][o]=o;for(let o=1;o<=t;o++)for(let i=1;i<=s;i++)r[o][i]=n[o-1]===e[i-1]?r[o-1][i-1]:1+Math.min(r[o-1][i],r[o][i-1],r[o-1][i-1]);return r[t][s]}function DT(n,e){let t=[],s={};for(let r=0;r<e.length;r++){let o=e[r];if(o.startsWith("--")){let i=o.slice(2);r+1<e.length&&!e[r+1].startsWith("--")?s[i]=e[++r]:s[i]=!0}else t.push(o)}return{parsedArgs:t,options:s}}async function MT(n){let e=await Zt(),t=Ai.join(jf.homedir(),".claude","commands","p.md"),s=Ai.join(jf.homedir(),".gemini","commands","p.toml"),[r,o,i,a]=await Promise.all([b(t),b(s),b(Ai.join(process.cwd(),".cursor","commands","sync.md")),b(Ai.join(process.cwd(),".cursor"))]),c=await ir();if(console.log(`
1351
1351
  ${je.cyan("p/")} prjct v${n}
1352
1352
  ${je.dim("Context layer for AI coding agents")}
1353
1353
 
1354
1354
  ${je.dim("Providers:")}`),e.claude.installed){let u=r?je.green("\u2713 ready"):je.yellow("\u25CF installed"),d=e.claude.version?` (v${e.claude.version})`:"";console.log(` Claude Code ${u}${je.dim(d)}`)}else console.log(` Claude Code ${je.dim("\u25CB not installed")}`);if(e.gemini.installed){let u=o?je.green("\u2713 ready"):je.yellow("\u25CF installed"),d=e.gemini.version?` (v${e.gemini.version})`:"";console.log(` Gemini CLI ${u}${je.dim(d)}`)}else console.log(` Gemini CLI ${je.dim("\u25CB not installed")}`);if(c.installed){let u=c.skillInstalled?je.green("\u2713 ready"):je.yellow("\u25CF detected"),d=c.skillInstalled?"":` ${je.dim("(run prjct start)")}`;console.log(` Antigravity ${u}${d}`)}else console.log(` Antigravity ${je.dim("\u25CB not installed")}`);console.log(i?` Cursor IDE ${je.green("\u2713 ready")} ${je.dim("(use /sync, /task)")}`:a?` Cursor IDE ${je.yellow("\u25CF detected")} ${je.dim("(run prjct init)")}`:` Cursor IDE ${je.dim("\u25CB no .cursor/ folder")}`),console.log(`
1355
1355
  ${je.dim("Run 'prjct start' for Claude/Gemini, 'prjct init' for Cursor")}
1356
1356
  ${je.cyan("https://prjct.app")}
1357
- `)}function MT(){console.log(`
1357
+ `)}function _T(){console.log(`
1358
1358
  prjct - Context layer for AI coding agents
1359
1359
  Works with Claude Code, Gemini CLI, Antigravity, Cursor IDE, and more.
1360
1360
 
@@ -1413,13 +1413,13 @@ MORE INFO
1413
1413
  ---------
1414
1414
  Documentation: https://prjct.app
1415
1415
  GitHub: https://github.com/jlopezlira/prjct-cli
1416
- `)}var xf=h(()=>{"use strict";Rl();vi();Dl();Ml();We();de();$a();Aa();V();vo();J();Me();l(xT,"main");l(AT,"validateCommandParams");l(Rf,"findClosestCommand");l(IT,"editDistance");l($T,"parseCommandArgs");l(DT,"displayVersion");l(MT,"displayHelp");xT().catch(n=>{console.error("Fatal error:",k(n)),process.env.DEBUG&&console.error(_i(n)),process.exit(1)})});globalThis.__perfStartNs=process.hrtime.bigint();var cs=process.argv.slice(2),tn=cs.find(n=>!n.startsWith("--")&&!n.startsWith("-")),Af=new Set(["daemon","stop","restart","start","setup","update","dev","web","serve","context","hooks","doctor","uninstall","claude","hook","seed","install","watch","help","-h","--help","version","-v","--version"]),{REGISTERED_VERBS_SET:NT}=await Promise.resolve().then(()=>(Ul(),Fl));if(tn&&!Af.has(tn)&&!NT.has(tn)){let n=cs.filter(t=>!t.startsWith("-")).join(" "),e=cs.filter(t=>t.startsWith("-"));tn="capture",cs=["capture",n,...e]}if(tn&&!Af.has(tn)&&process.env.PRJCT_NO_DAEMON!=="1"){let n=await import("node:fs"),{DAEMON_PATHS:e}=await Promise.resolve().then(()=>(Gr(),Hl)),t=e.socket();if(n.existsSync(t)){let{sendRequest:s}=await Promise.resolve().then(()=>(Jt(),Bt)),r=await import("node:crypto"),o=[],i={};for(let a=0;a<cs.length;a++){let c=cs[a];if(c.startsWith("--")){let u=c.slice(2);if(u.includes("=")){let d=u.indexOf("=");i[u.slice(0,d)]=u.slice(d+1)}else a+1<cs.length&&!cs[a+1].startsWith("--")?i[u]=cs[++a]:i[u]=!0}else c.startsWith("-")&&c.length===2?i[c.slice(1)]=!0:a>0&&o.push(c)}try{let a=await s({id:r.randomUUID(),command:tn,args:o,options:i,cwd:process.cwd(),perfStartNs:globalThis.__perfStartNs?.toString()});a.stdout&&console.log(a.stdout),a.stderr&&console.error(a.stderr),process.exit(a.exitCode)}catch{}}}async function OT(){let n=await import("node:os"),e=await import("node:path"),t=(await import("chalk")).default,{detectAllProviders:s}=await Promise.resolve().then(()=>(We(),yt)),r=(await Promise.resolve().then(()=>(de(),ur))).default,o=(await Promise.resolve().then(()=>(ro(),Su))).default,{DEFAULT_PORT:i,startServer:a}=await Promise.resolve().then(()=>(Pa(),ld)),{fileExists:c}=await Promise.resolve().then(()=>(J(),Qt)),{invalidateProviderCache:u}=await Promise.resolve().then(()=>(Fi(),nu)),{VERSION:d}=await Promise.resolve().then(()=>(ze(),an));async function m(){let S=n.homedir(),w=await s();if(w.claude.installed){let P=e.join(S,".claude","CLAUDE.md");try{if(!(await import("node:fs/promises").then(M=>M.readFile(P,"utf-8"))).includes("prjct:start"))return!1}catch{return!1}}if(w.gemini.installed){let P=e.join(S,".gemini","GEMINI.md");try{if(!(await import("node:fs/promises").then(M=>M.readFile(P,"utf-8"))).includes("prjct:start"))return!1}catch{return!1}}return!w.claude.installed&&!w.gemini.installed,!0}l(m,"checkRoutersInstalled");let p=process.argv.slice(2),g=p.findIndex(S=>S==="--quiet"||S==="-q"),y=g!==-1;if(y){p.splice(g,1);let{setQuietMode:S}=await Promise.resolve().then(()=>(Me(),fd));S(!0)}let j=p.indexOf("--refresh"),T=j!==-1;T&&(p.splice(j,1),await u());async function x(S){let w=Date.now();try{let P=await r.getProjectId(process.cwd());if(P){let{sessionTracker:v}=await Promise.resolve().then(()=>(Aa(),wd));return await v.expireIfStale(P),await v.touch(P),()=>{let M=Date.now()-w;v.trackCommand(P,S,M).catch(()=>{}),Promise.resolve().then(()=>($a(),vd)).then(({performanceTracker:F})=>{F.recordTiming(P,"command_duration",M,{command:S}).catch(()=>{}),F.recordMemory(P,{command:S}).catch(()=>{})}).catch(()=>{})}}}catch{}return()=>{}}if(l(x,"trackSession"),p[0]==="daemon"){let S=p[1]||"status";if(S==="start"){let{isDaemonRunning:w,spawnDaemon:P}=await Promise.resolve().then(()=>(Jt(),Bt));if(await w())console.log("Daemon is already running."),process.exitCode=0;else if(p.includes("--foreground")||p.includes("-f")){let{startDaemon:M}=await Promise.resolve().then(()=>(Fg(),Lg)),F=parseInt(p.find(He=>He.startsWith("--port="))?.split("=")[1]||"",10)||void 0,fe=p.includes("--no-http");await M({port:F,noHttp:fe,foreground:!0})}else await P()?console.log("Daemon started."):(console.error("Failed to start daemon."),process.exitCode=1)}else if(S==="stop"){let{isDaemonRunning:w,stopDaemon:P}=await Promise.resolve().then(()=>(Jt(),Bt));if(await w()){let v=await P();console.log(v?"Daemon stopped.":"Failed to stop daemon."),process.exitCode=v?0:1}else console.log("Daemon is not running."),process.exitCode=0}else if(S==="status"){let{getDaemonStatus:w}=await Promise.resolve().then(()=>(Jt(),Bt)),P=await w();if(P.running){let v=P.uptime?Math.round(P.uptime/1e3):0,M=P.stale;console.log(`Daemon running (PID ${P.pid})${M?" \u26A0 STALE":""}`),console.log(` Uptime: ${v}s`),console.log(` Commands served: ${P.commandsServed??0}`),P.lastActivity&&console.log(` Last activity: ${P.lastActivity}`),M&&console.log(` ${t.yellow("\u26A0 Code changed since daemon started. Run: prjct restart")}`)}else console.log("Daemon is not running.");process.exitCode=0}else console.error(`Unknown daemon command: ${S}. Use: start, stop, status`),process.exitCode=1}else if(p[0]==="stop"){let{isDaemonRunning:S,stopDaemon:w,forceKillDaemon:P}=await Promise.resolve().then(()=>(Jt(),Bt));if(p.includes("--force")||p.includes("-f")){let M=P();console.log(M?"Daemon force-killed.":"Daemon is not running."),process.exitCode=0}else await S()?await w()?(console.log("Daemon stopped."),process.exitCode=0):(console.log("Graceful stop failed, force-killing..."),P(),console.log("Daemon force-killed."),process.exitCode=0):(P(),console.log("Daemon is not running (cleaned up stale files)."),process.exitCode=0)}else if(p[0]==="restart"){let{isDaemonRunning:S,stopDaemon:w,forceKillDaemon:P,spawnDaemon:v}=await Promise.resolve().then(()=>(Jt(),Bt));await S()?(await w()||P(),await new Promise(fe=>setTimeout(fe,300))):P(),await v()?(console.log("Daemon restarted."),process.exitCode=0):(console.error("Failed to restart daemon."),process.exitCode=1)}else if(p[0]==="start"||p[0]==="setup"){let{runStart:S}=await Promise.resolve().then(()=>(Gg(),Wg));await S()}else if(p[0]==="dev")console.log("Dev mode is not yet implemented."),console.log('Use "prjct serve" to start the web server.'),process.exitCode=0;else if(p[0]==="web"||p[0]==="serve")try{let S=process.cwd(),w=await r.getProjectId(S);if(!w)console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let P=parseInt(p[1],10)||i;await a(w,S,P)}}catch(S){console.error("Server error:",S.message),process.exitCode=1}else if(p[0]==="context"){let S=process.cwd(),w=await r.getProjectId(S);if(!w)console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let P=await x("context"),v=p.slice(1).filter(F=>F!=="--md"&&F!=="--json"),M=p.includes("--md");if(v.length===0){let{ContextCommands:F}=await Promise.resolve().then(()=>(di(),ng)),He=await new F().context(null,S,{md:M});process.exitCode=He.success?0:1}else{let{runContextTool:F}=await Promise.resolve().then(()=>(Bg(),Vg)),fe=await F(v,w,S);console.log(JSON.stringify(fe,null,2)),process.exitCode=fe.tool==="error"?1:0}P()}}else if(p[0]==="hooks"){let S=await x("hooks"),{hooksService:w}=await Promise.resolve().then(()=>(Yg(),Kg)),P=p[1]||"status",v=await w.run(process.cwd(),P);process.exitCode=v,S()}else if(p[0]==="seed"){let S=p[1]??"list",w=p.slice(2).filter(fe=>!fe.startsWith("-")).join(","),P=p.includes("--md"),{SeedCommands:v}=await Promise.resolve().then(()=>(gi(),gg)),M=new v,F={success:!1,error:"unknown"};S==="add"?F=await M.add(w||null,process.cwd(),{md:P}):S==="remove"?F=await M.remove(w||null,process.cwd(),{md:P}):S==="list"?F=await M.list(null,process.cwd(),{md:P}):S==="suggest"?F=await M.suggest(null,process.cwd(),{md:P}):console.error(`Unknown seed subcommand: ${S}. Use: add, remove, list, suggest.`),process.exitCode=F.success?0:1}else if(p[0]==="install"){let{InstallCommands:S}=await Promise.resolve().then(()=>(_r(),ul)),w=new S,P=p.includes("--md"),v=await w.install(null,process.cwd(),{md:P});process.exitCode=v.success?0:1}else if(p[0]==="claude"){let S=p[1]??"status",{InstallCommands:w}=await Promise.resolve().then(()=>(_r(),ul)),P=new w,v=p.includes("--md"),M;if(S==="install")M=await P.install(null,process.cwd(),{md:v});else if(S==="uninstall")M=await P.uninstall(null,process.cwd(),{md:v});else{let F=await P.status();F.success?(console.log(v?`# prjct Claude Code hooks
1416
+ `)}var xf=h(()=>{"use strict";Al();Si();_l();Nl();We();de();Ma();$a();V();So();J();Me();l(AT,"main");l(IT,"validateCommandParams");l(Rf,"findClosestCommand");l($T,"editDistance");l(DT,"parseCommandArgs");l(MT,"displayVersion");l(_T,"displayHelp");AT().catch(n=>{console.error("Fatal error:",k(n)),process.env.DEBUG&&console.error(Ni(n)),process.exit(1)})});globalThis.__perfStartNs=process.hrtime.bigint();var ls=process.argv.slice(2),tn=ls.find(n=>!n.startsWith("--")&&!n.startsWith("-")),Af=new Set(["daemon","stop","restart","start","setup","update","dev","web","serve","context","hooks","doctor","uninstall","claude","hook","seed","install","watch","help","-h","--help","version","-v","--version"]),{REGISTERED_VERBS_SET:OT}=await Promise.resolve().then(()=>(Wl(),Hl));if(tn&&!Af.has(tn)&&!OT.has(tn)){let n=ls.filter(t=>!t.startsWith("-")).join(" "),e=ls.filter(t=>t.startsWith("-"));tn="capture",ls=["capture",n,...e]}if(tn&&!Af.has(tn)&&process.env.PRJCT_NO_DAEMON!=="1"){let n=await import("node:fs"),{DAEMON_PATHS:e}=await Promise.resolve().then(()=>(Gr(),Gl)),t=e.socket();if(n.existsSync(t)){let{sendRequest:s}=await Promise.resolve().then(()=>(Jt(),Bt)),r=await import("node:crypto"),o=[],i={};for(let a=0;a<ls.length;a++){let c=ls[a];if(c.startsWith("--")){let u=c.slice(2);if(u.includes("=")){let d=u.indexOf("=");i[u.slice(0,d)]=u.slice(d+1)}else a+1<ls.length&&!ls[a+1].startsWith("--")?i[u]=ls[++a]:i[u]=!0}else c.startsWith("-")&&c.length===2?i[c.slice(1)]=!0:a>0&&o.push(c)}try{let a=await s({id:r.randomUUID(),command:tn,args:o,options:i,cwd:process.cwd(),perfStartNs:globalThis.__perfStartNs?.toString()});a.stdout&&console.log(a.stdout),a.stderr&&console.error(a.stderr),process.exit(a.exitCode)}catch{}}}async function LT(){let n=await import("node:os"),e=await import("node:path"),t=(await import("chalk")).default,{detectAllProviders:s}=await Promise.resolve().then(()=>(We(),yt)),r=(await Promise.resolve().then(()=>(de(),ur))).default,o=(await Promise.resolve().then(()=>(oo(),Su))).default,{DEFAULT_PORT:i,startServer:a}=await Promise.resolve().then(()=>(Ra(),ld)),{fileExists:c}=await Promise.resolve().then(()=>(J(),Qt)),{invalidateProviderCache:u}=await Promise.resolve().then(()=>(Ui(),ou)),{VERSION:d}=await Promise.resolve().then(()=>(ze(),an));async function m(){let S=n.homedir(),w=await s();if(w.claude.installed){let P=e.join(S,".claude","CLAUDE.md");try{if(!(await import("node:fs/promises").then(M=>M.readFile(P,"utf-8"))).includes("prjct:start"))return!1}catch{return!1}}if(w.gemini.installed){let P=e.join(S,".gemini","GEMINI.md");try{if(!(await import("node:fs/promises").then(M=>M.readFile(P,"utf-8"))).includes("prjct:start"))return!1}catch{return!1}}return!w.claude.installed&&!w.gemini.installed,!0}l(m,"checkRoutersInstalled");let p=process.argv.slice(2),g=p.findIndex(S=>S==="--quiet"||S==="-q"),y=g!==-1;if(y){p.splice(g,1);let{setQuietMode:S}=await Promise.resolve().then(()=>(Me(),fd));S(!0)}let j=p.indexOf("--refresh"),T=j!==-1;T&&(p.splice(j,1),await u());async function x(S){let w=Date.now();try{let P=await r.getProjectId(process.cwd());if(P){let{sessionTracker:v}=await Promise.resolve().then(()=>($a(),wd));return await v.expireIfStale(P),await v.touch(P),()=>{let M=Date.now()-w;v.trackCommand(P,S,M).catch(()=>{}),Promise.resolve().then(()=>(Ma(),vd)).then(({performanceTracker:F})=>{F.recordTiming(P,"command_duration",M,{command:S}).catch(()=>{}),F.recordMemory(P,{command:S}).catch(()=>{})}).catch(()=>{})}}}catch{}return()=>{}}if(l(x,"trackSession"),p[0]==="daemon"){let S=p[1]||"status";if(S==="start"){let{isDaemonRunning:w,spawnDaemon:P}=await Promise.resolve().then(()=>(Jt(),Bt));if(await w())console.log("Daemon is already running."),process.exitCode=0;else if(p.includes("--foreground")||p.includes("-f")){let{startDaemon:M}=await Promise.resolve().then(()=>(Fg(),Lg)),F=parseInt(p.find(He=>He.startsWith("--port="))?.split("=")[1]||"",10)||void 0,fe=p.includes("--no-http");await M({port:F,noHttp:fe,foreground:!0})}else await P()?console.log("Daemon started."):(console.error("Failed to start daemon."),process.exitCode=1)}else if(S==="stop"){let{isDaemonRunning:w,stopDaemon:P}=await Promise.resolve().then(()=>(Jt(),Bt));if(await w()){let v=await P();console.log(v?"Daemon stopped.":"Failed to stop daemon."),process.exitCode=v?0:1}else console.log("Daemon is not running."),process.exitCode=0}else if(S==="status"){let{getDaemonStatus:w}=await Promise.resolve().then(()=>(Jt(),Bt)),P=await w();if(P.running){let v=P.uptime?Math.round(P.uptime/1e3):0,M=P.stale;console.log(`Daemon running (PID ${P.pid})${M?" \u26A0 STALE":""}`),console.log(` Uptime: ${v}s`),console.log(` Commands served: ${P.commandsServed??0}`),P.lastActivity&&console.log(` Last activity: ${P.lastActivity}`),M&&console.log(` ${t.yellow("\u26A0 Code changed since daemon started. Run: prjct restart")}`)}else console.log("Daemon is not running.");process.exitCode=0}else console.error(`Unknown daemon command: ${S}. Use: start, stop, status`),process.exitCode=1}else if(p[0]==="stop"){let{isDaemonRunning:S,stopDaemon:w,forceKillDaemon:P}=await Promise.resolve().then(()=>(Jt(),Bt));if(p.includes("--force")||p.includes("-f")){let M=P();console.log(M?"Daemon force-killed.":"Daemon is not running."),process.exitCode=0}else await S()?await w()?(console.log("Daemon stopped."),process.exitCode=0):(console.log("Graceful stop failed, force-killing..."),P(),console.log("Daemon force-killed."),process.exitCode=0):(P(),console.log("Daemon is not running (cleaned up stale files)."),process.exitCode=0)}else if(p[0]==="restart"){let{isDaemonRunning:S,stopDaemon:w,forceKillDaemon:P,spawnDaemon:v}=await Promise.resolve().then(()=>(Jt(),Bt));await S()?(await w()||P(),await new Promise(fe=>setTimeout(fe,300))):P(),await v()?(console.log("Daemon restarted."),process.exitCode=0):(console.error("Failed to restart daemon."),process.exitCode=1)}else if(p[0]==="start"||p[0]==="setup"){let{runStart:S}=await Promise.resolve().then(()=>(Gg(),Wg));await S()}else if(p[0]==="dev")console.log("Dev mode is not yet implemented."),console.log('Use "prjct serve" to start the web server.'),process.exitCode=0;else if(p[0]==="web"||p[0]==="serve")try{let S=process.cwd(),w=await r.getProjectId(S);if(!w)console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let P=parseInt(p[1],10)||i;await a(w,S,P)}}catch(S){console.error("Server error:",S.message),process.exitCode=1}else if(p[0]==="context"){let S=process.cwd(),w=await r.getProjectId(S);if(!w)console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let P=await x("context"),v=p.slice(1).filter(F=>F!=="--md"&&F!=="--json"),M=p.includes("--md");if(v.length===0){let{ContextCommands:F}=await Promise.resolve().then(()=>(pi(),ng)),He=await new F().context(null,S,{md:M});process.exitCode=He.success?0:1}else{let{runContextTool:F}=await Promise.resolve().then(()=>(Bg(),Vg)),fe=await F(v,w,S);console.log(JSON.stringify(fe,null,2)),process.exitCode=fe.tool==="error"?1:0}P()}}else if(p[0]==="hooks"){let S=await x("hooks"),{hooksService:w}=await Promise.resolve().then(()=>(Yg(),Kg)),P=p[1]||"status",v=await w.run(process.cwd(),P);process.exitCode=v,S()}else if(p[0]==="seed"){let S=p[1]??"list",w=p.slice(2).filter(fe=>!fe.startsWith("-")).join(","),P=p.includes("--md"),{SeedCommands:v}=await Promise.resolve().then(()=>(fi(),gg)),M=new v,F={success:!1,error:"unknown"};S==="add"?F=await M.add(w||null,process.cwd(),{md:P}):S==="remove"?F=await M.remove(w||null,process.cwd(),{md:P}):S==="list"?F=await M.list(null,process.cwd(),{md:P}):S==="suggest"?F=await M.suggest(null,process.cwd(),{md:P}):console.error(`Unknown seed subcommand: ${S}. Use: add, remove, list, suggest.`),process.exitCode=F.success?0:1}else if(p[0]==="install"){let{InstallCommands:S}=await Promise.resolve().then(()=>(_r(),pl)),w=new S,P=p.includes("--md"),v=await w.install(null,process.cwd(),{md:P});process.exitCode=v.success?0:1}else if(p[0]==="claude"){let S=p[1]??"status",{InstallCommands:w}=await Promise.resolve().then(()=>(_r(),pl)),P=new w,v=p.includes("--md"),M;if(S==="install")M=await P.install(null,process.cwd(),{md:v});else if(S==="uninstall")M=await P.uninstall(null,process.cwd(),{md:v});else{let F=await P.status();F.success?(console.log(v?`# prjct Claude Code hooks
1417
1417
 
1418
1418
  - installed: ${F.installed}
1419
1419
  - expected: ${F.expected}
1420
- `:`installed: ${F.installed}/${F.expected}`),M=F):(console.error(F.error),M=F)}process.exitCode=M.success?0:1}else if(p[0]==="hook"){let S=p[1],w=process.cwd();try{switch(S){case"session-start":{let{runSessionStartHook:P}=await Promise.resolve().then(()=>(Pi(),ef));await P(w);break}case"prompt":{let{runPromptHook:P}=await Promise.resolve().then(()=>(rf(),nf));await P(w);break}case"pre-commit":{let{runPreCommitHook:P}=await Promise.resolve().then(()=>(cf(),af));await P(w);break}case"post-edit":{let{runPostEditHook:P}=await Promise.resolve().then(()=>(uf(),lf));await P(w);break}case"stop":{let{runStopHook:P}=await Promise.resolve().then(()=>(mf(),pf));await P(w);break}case"subagent-start":{let{runSubagentStartHook:P}=await Promise.resolve().then(()=>(ff(),gf));await P(w);break}case"cwd-changed":{let{runCwdChangedHook:P}=await Promise.resolve().then(()=>(yf(),hf));await P(w);break}default:process.stdout.write(`{}
1420
+ `:`installed: ${F.installed}/${F.expected}`),M=F):(console.error(F.error),M=F)}process.exitCode=M.success?0:1}else if(p[0]==="hook"){let S=p[1],w=process.cwd();try{switch(S){case"session-start":{let{runSessionStartHook:P}=await Promise.resolve().then(()=>(ji(),ef));await P(w);break}case"prompt":{let{runPromptHook:P}=await Promise.resolve().then(()=>(rf(),nf));await P(w);break}case"pre-commit":{let{runPreCommitHook:P}=await Promise.resolve().then(()=>(cf(),af));await P(w);break}case"post-edit":{let{runPostEditHook:P}=await Promise.resolve().then(()=>(uf(),lf));await P(w);break}case"stop":{let{runStopHook:P}=await Promise.resolve().then(()=>(mf(),pf));await P(w);break}case"subagent-start":{let{runSubagentStartHook:P}=await Promise.resolve().then(()=>(ff(),gf));await P(w);break}case"cwd-changed":{let{runCwdChangedHook:P}=await Promise.resolve().then(()=>(yf(),hf));await P(w);break}default:process.stdout.write(`{}
1421
1421
  `)}process.exitCode=0}catch{process.stdout.write(`{}
1422
- `),process.exitCode=0}}else if(p[0]==="doctor"){let S=await x("doctor"),{doctorService:w}=await Promise.resolve().then(()=>(vf(),kf)),P=await w.run(process.cwd());process.exitCode=P,S()}else if(p[0]==="uninstall"){let{uninstall:S}=await Promise.resolve().then(()=>(Il(),Dg)),w=p.includes("--force")||p.includes("-f"),P=p.includes("--backup")||p.includes("-b"),v=p.includes("--dry-run")||p.includes("-n"),M=p.includes("--keep-package"),F=await S({force:w,backup:P,dryRun:v,keepPackage:M});process.exitCode=F.success?0:1}else if(p[0]==="watch"){let S=process.cwd();if(!await r.getProjectId(S))console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let{watchService:P}=await Promise.resolve().then(()=>(bf(),Sf)),v=p.includes("--verbose")||p.includes("-v"),M=p.find(Ie=>Ie.startsWith("--debounce=")),F=M?parseInt(M.split("=")[1],10):void 0,fe=p.find(Ie=>Ie.startsWith("--interval=")),He=fe?parseInt(fe.split("=")[1],10)*1e3:void 0,Nt=await P.start(S,{verbose:v,quiet:y,debounceMs:F,minIntervalMs:He});Nt.success||(console.error(Nt.error),process.exitCode=1)}}else if(p[0]==="help"||p[0]==="-h"||p[0]==="--help"){let{getHelp:S}=await Promise.resolve().then(()=>(Cf(),Ef)),w=p[1];console.log(S(w)),process.exitCode=0}else if(p[0]==="version"||p[0]==="-v"||p[0]==="--version"){let S=await s(T),w=n.homedir(),P=process.cwd(),[v,M,F,fe,He,Nt]=await Promise.all([c(e.join(w,".claude","commands","p.md")),c(e.join(w,".gemini","commands","p.toml")),c(e.join(P,".cursor")),c(e.join(P,".cursor","rules","prjct.mdc")),c(e.join(P,".windsurf")),c(e.join(P,".windsurf","rules","prjct.md"))]);if(console.log(`
1422
+ `),process.exitCode=0}}else if(p[0]==="doctor"){let S=await x("doctor"),{doctorService:w}=await Promise.resolve().then(()=>(vf(),kf)),P=await w.run(process.cwd());process.exitCode=P,S()}else if(p[0]==="uninstall"){let{uninstall:S}=await Promise.resolve().then(()=>(Dl(),Dg)),w=p.includes("--force")||p.includes("-f"),P=p.includes("--backup")||p.includes("-b"),v=p.includes("--dry-run")||p.includes("-n"),M=p.includes("--keep-package"),F=await S({force:w,backup:P,dryRun:v,keepPackage:M});process.exitCode=F.success?0:1}else if(p[0]==="watch"){let S=process.cwd();if(!await r.getProjectId(S))console.error('No prjct project found. Run "prjct init" first.'),process.exitCode=1;else{let{watchService:P}=await Promise.resolve().then(()=>(bf(),Sf)),v=p.includes("--verbose")||p.includes("-v"),M=p.find(Ie=>Ie.startsWith("--debounce=")),F=M?parseInt(M.split("=")[1],10):void 0,fe=p.find(Ie=>Ie.startsWith("--interval=")),He=fe?parseInt(fe.split("=")[1],10)*1e3:void 0,Nt=await P.start(S,{verbose:v,quiet:y,debounceMs:F,minIntervalMs:He});Nt.success||(console.error(Nt.error),process.exitCode=1)}}else if(p[0]==="help"||p[0]==="-h"||p[0]==="--help"){let{getHelp:S}=await Promise.resolve().then(()=>(Cf(),Ef)),w=p[1];console.log(S(w)),process.exitCode=0}else if(p[0]==="version"||p[0]==="-v"||p[0]==="--version"){let S=await s(T),w=n.homedir(),P=process.cwd(),[v,M,F,fe,He,Nt]=await Promise.all([c(e.join(w,".claude","commands","p.md")),c(e.join(w,".gemini","commands","p.toml")),c(e.join(P,".cursor")),c(e.join(P,".cursor","rules","prjct.mdc")),c(e.join(P,".windsurf")),c(e.join(P,".windsurf","rules","prjct.md"))]);if(console.log(`
1423
1423
  ${t.cyan("p/")} prjct v${d}
1424
1424
  ${t.dim("Context layer for AI coding agents")}
1425
1425
 
@@ -1436,5 +1436,5 @@ ${t.cyan.bold(" Welcome to prjct!")}
1436
1436
  Claude Code, Gemini CLI, or both.`)}
1437
1437
  `),process.exitCode=0;else{try{let v=await o.getLastVersion();if(v&&v!==d){console.log(`
1438
1438
  ${t.yellow("\u2139")} Updating prjct v${v} \u2192 v${d}...
1439
- `);try{let{default:M}=await Promise.resolve().then(()=>(Cn(),No));await M.run()}catch{await o.updateVersion(d).catch(()=>{})}}}catch{}p.length>0&&process.env.PRJCT_NO_DAEMON!=="1"&&Promise.resolve().then(()=>(Jt(),Bt)).then(({spawnDaemon:v})=>v()).catch(()=>{}),await Promise.resolve().then(()=>(xf(),_T))}}}l(OT,"main");OT().catch(n=>{process.argv[2]==="hook"&&(process.stdout.write(`{}
1439
+ `);try{let{default:M}=await Promise.resolve().then(()=>(Cn(),Oo));await M.run()}catch{await o.updateVersion(d).catch(()=>{})}}}catch{}p.length>0&&process.env.PRJCT_NO_DAEMON!=="1"&&Promise.resolve().then(()=>(Jt(),Bt)).then(({spawnDaemon:v})=>v()).catch(()=>{}),await Promise.resolve().then(()=>(xf(),NT))}}}l(LT,"main");LT().catch(n=>{process.argv[2]==="hook"&&(process.stdout.write(`{}
1440
1440
  `),process.exit(0)),console.error("Fatal error:",n.message),process.exit(1)});