prjct-cli 1.44.5 → 1.45.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +27 -1
- package/README.md +13 -10
- package/dist/bin/prjct-core.mjs +283 -305
- package/dist/bin/prjct.mjs +1 -1
- package/dist/cli/jira.mjs +8 -0
- package/dist/cli/linear.mjs +1 -344
- package/dist/daemon/entry.mjs +392 -414
- package/dist/templates.json +1 -1
- package/package.json +1 -2
package/dist/daemon/entry.mjs
CHANGED
|
@@ -5,11 +5,11 @@ import { dirname as __pathDirname } from 'path';
|
|
|
5
5
|
var require = __createRequire(import.meta.url);
|
|
6
6
|
var __filename = __fileURLToPath(import.meta.url);
|
|
7
7
|
var __dirname = __pathDirname(__filename);
|
|
8
|
-
var
|
|
9
|
-
`,"utf-8")}async function
|
|
10
|
-
`)}async function
|
|
11
|
-
`);await Xt(r,t)}function aw(r){return ws.extname(r)}function cw(r){return ws.basename(r,ws.extname(r))}var Ue=k(()=>{"use strict";Sd();F();l(Kt,"readJson");l(Ln,"writeJson");l(it,"readFile");l(Xt,"writeFile");l(Xy,"atomicWrite");l(Yy,"appendToFile");l(Ia,"appendLine");l(Qy,"prependToFile");l(D,"fileExists");l(po,"dirExists");l(Nt,"ensureDir");l(Zy,"deleteFile");l(ew,"deleteDir");l(ln,"listFiles");l(tw,"getFileSize");l(nw,"getFileModifiedTime");l(sw,"copyFile");l(rw,"moveFile");l(ow,"readLines");l(iw,"writeLines");l(aw,"getFileExtension");l(cw,"getFileNameWithoutExtension")});import{z as Yt}from"zod";function kd(r,e){let t=r.split(".").map(Number),n=e.split(".").map(Number);for(let s=0;s<3;s++){let o=t[s]??0,i=n[s]??0;if(o<i)return-1;if(o>i)return 1}return 0}var IA,RA,DA,Ss,jA,gr=k(()=>{"use strict";IA=Yt.enum(["opus","sonnet","haiku"]),RA=Yt.enum(["2.5-pro","2.5-flash","2.0-flash"]),DA=Yt.string().min(1),Ss=Yt.object({provider:Yt.string(),model:Yt.string(),cliVersion:Yt.string().optional(),recordedAt:Yt.string()}),jA=Yt.object({preferredModel:Yt.string().optional(),lastAnalysisModel:Ss.optional()});l(kd,"compareSemver")});import Ra from"node:fs/promises";import lw from"node:os";import bd from"node:path";async function Cd(){try{let r=await Ra.readFile(Pd,"utf-8"),e=JSON.parse(r);return!e.timestamp||!e.detection||Date.now()-new Date(e.timestamp).getTime()>uw?null:e.detection}catch{return null}}async function xd(r){let e={timestamp:new Date().toISOString(),detection:r};await Ra.mkdir(vd,{recursive:!0}),await Ra.writeFile(Pd,JSON.stringify(e,null,2))}var vd,Pd,uw,Td=k(()=>{"use strict";vd=bd.join(lw.homedir(),".prjct-cli","cache"),Pd=bd.join(vd,"providers.json"),uw=600*1e3;l(Cd,"readProviderCache");l(xd,"writeProviderCache")});var mt={};kn(mt,{AntigravityProvider:()=>ja,ClaudeProvider:()=>mo,CodexProvider:()=>$a,CursorProvider:()=>Id,GeminiProvider:()=>Da,Providers:()=>pt,WindsurfProvider:()=>Rd,detectAllProviders:()=>fr,detectAntigravity:()=>ho,detectCodex:()=>Un,detectCursorProject:()=>$d,detectProvider:()=>go,detectWindsurfProject:()=>Md,getActiveProvider:()=>hw,getCapabilities:()=>gw,getCommandsDir:()=>Pw,getGlobalContextPath:()=>kw,getGlobalSettingsPath:()=>bw,getProjectCommandsPath:()=>Cw,getProviderBranding:()=>fo,getSkillsPath:()=>vw,hasProviderConfig:()=>yw,needsCursorRouterRegeneration:()=>ww,needsWindsurfRouterRegeneration:()=>Sw,selectProvider:()=>Ma,validateCliVersion:()=>jd});import{exec as dw}from"node:child_process";import vn from"node:os";import We from"node:path";import{promisify as pw}from"node:util";function gw(r,e){return{...mw[r],...e}}async function Dd(r){try{let{stdout:e}=await Ed(`which ${r}`,{timeout:Ad});return e.trim()}catch{return null}}async function fw(r){try{let{stdout:e}=await Ed(`${r} --version`,{timeout:Ad}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function go(r){let e=pt[r];if(!e.cliCommand)return{installed:!1};let t=await Dd(e.cliCommand);if(!t)return{installed:!1};let n=await fw(e.cliCommand),s=jd(r,n||void 0);return{installed:!0,version:n||void 0,path:t,versionWarning:s||void 0}}function jd(r,e){let t=pt[r];return!t.minCliVersion||!e?null:kd(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 fr(r=!1){if(!r){let i=await Cd();if(i)return i}let[e,t,n]=await Promise.all([go("claude"),go("gemini"),Un()]),s={installed:n.installed},o={claude:e,gemini:t,codex:s};return await xd(o).catch(()=>{}),o}async function hw(r){if(r&&pt[r])return pt[r];let e=await fr();return e.claude.installed&&!e.gemini.installed?mo:e.gemini.installed&&!e.claude.installed?Da:mo}async function yw(r){let e=pt[r];return e.configDir?D(e.configDir):!1}function fo(r){return{commitFooter:"Generated with [p/](https://www.prjct.app/)",signature:{claude:"\u26A1 prjct + Claude",gemini:"\u26A1 prjct + Gemini",cursor:"\u26A1 prjct + Cursor",antigravity:"\u26A1 prjct + Antigravity",windsurf:"\u26A1 prjct + Windsurf",codex:"\u26A1 prjct + Codex"}[r]||"\u26A1 prjct"}}async function $d(r){let e=We.join(r,".cursor"),t=We.join(e,"rules"),n=We.join(t,"prjct.mdc"),[s,o]=await Promise.all([D(e),D(n)]);return{detected:s,routerInstalled:o,projectRoot:s?r:void 0}}async function ww(r){let e=await $d(r);return e.detected&&!e.routerInstalled}async function Md(r){let e=We.join(r,".windsurf"),t=We.join(e,"rules"),n=We.join(t,"prjct.md"),[s,o]=await Promise.all([D(e),D(n)]);return{detected:s,routerInstalled:o,projectRoot:s?r:void 0}}async function Sw(r){let e=await Md(r);return e.detected&&!e.routerInstalled}async function ho(){let r=ja.configDir;if(!r)return{installed:!1,skillInstalled:!1};let e=We.join(r,"skills","prjct","SKILL.md"),[t,n]=await Promise.all([D(r),D(e)]);return{installed:t,skillInstalled:n,configPath:t?r:void 0}}async function Un(){let r=$a.configDir;if(!r)return{installed:!1,skillInstalled:!1};let e=await Dd("codex"),t=We.join(r,"skills","prjct","SKILL.md"),n=await D(t),s=!!e;return{installed:s,skillInstalled:n,configPath:s?r:void 0}}function kw(r){let e=pt[r];return e.configDir?We.join(e.configDir,e.contextFile):null}function bw(r){let e=pt[r];return!e.configDir||!e.settingsFile?null:We.join(e.configDir,e.settingsFile)}function vw(r){return pt[r].skillsDir}function Pw(r){return pt[r].commandsDir}function Cw(r,e){let t=pt[r];return We.join(e,t.commandsDir)}async function Ma(){let r=await fr(),e=r.claude.installed,t=r.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:r}:e&&!t?{provider:"claude",userSelected:!1,detection:r}:t&&!e?{provider:"gemini",userSelected:!1,detection:r}:{provider:"claude",userSelected:!0,detection:r}}var Ed,Ad,mw,mo,Da,ja,Id,Rd,$a,pt,qe=k(()=>{"use strict";gr();Ue();Td();Ed=pw(dw),Ad=2e3,mw={full:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!0,webFetch:!0,todoTracking:!0},standard:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!1,webFetch:!1,todoTracking:!1},basic:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!1,subagents:!1,webFetch:!1,todoTracking:!1}};l(gw,"getCapabilities");mo={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:We.join(vn.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:We.join(vn.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"},Da={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:We.join(vn.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:We.join(vn.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"},ja={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:We.join(vn.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:We.join(vn.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"},Id={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"},Rd={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"},$a={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:We.join(vn.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:We.join(vn.homedir(),".codex","skills"),commandsDir:".agents/skills",commandFormat:"md",settingsFile:null,projectSettingsFile:null,ignoreFile:".codexignore",websiteUrl:"https://openai.com/codex",docsUrl:"https://github.com/openai/codex",defaultModel:null,supportedModels:[],minCliVersion:null,capabilityTier:"basic"},pt={claude:mo,gemini:Da,cursor:Id,antigravity:ja,windsurf:Rd,codex:$a};l(Dd,"whichCommand");l(fw,"getCliVersion");l(go,"detectProvider");l(jd,"validateCliVersion");l(fr,"detectAllProviders");l(hw,"getActiveProvider");l(yw,"hasProviderConfig");l(fo,"getProviderBranding");l($d,"detectCursorProject");l(ww,"needsCursorRouterRegeneration");l(Md,"detectWindsurfProject");l(Sw,"needsWindsurfRouterRegeneration");l(ho,"detectAntigravity");l(Un,"detectCodex");l(kw,"getGlobalContextPath");l(bw,"getGlobalSettingsPath");l(vw,"getSkillsPath");l(Pw,"getCommandsDir");l(Cw,"getProjectCommandsPath");l(Ma,"selectProvider")});import xw from"node:crypto";import Qt from"node:fs/promises";import Oa from"node:os";import z from"node:path";import{globSync as Tw}from"glob";var _a,Ew,A,Pe=k(()=>{"use strict";ce();Ue();_a=class{static{l(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?z.resolve(e):z.join(Oa.homedir(),".prjct-cli"),this.globalProjectsDir=z.join(this.globalBaseDir,"projects"),this.globalConfigDir=z.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=z.resolve(e),this.globalProjectsDir=z.join(this.globalBaseDir,"projects"),this.globalConfigDir=z.join(this.globalBaseDir,"config")}generateProjectId(e){return xw.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return z.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return z.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return z.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return z.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await po(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await D(t)}async ensureGlobalStructure(){await Nt(this.globalBaseDir),await Nt(this.globalProjectsDir),await Nt(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),n=["core","progress","planning","analysis","memory","agents"];for(let s of n)await Nt(z.join(t,s));return await Nt(z.join(t,"planning","tasks")),await Nt(z.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:n,month:s,day:o}=Aa(t);return z.join(this.getGlobalProjectPath(e),"sessions",n,s,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let n=this.getSessionPath(e,t);return await Nt(n),n}async listSessions(e,t=null,n=null){let s=z.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Qt.readdir(s,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let c=z.join(s,a.name),u=await Qt.readdir(c,{withFileTypes:!0});for(let d of u){if(!d.isDirectory()||n&&d.name!==n.toString().padStart(2,"0"))continue;let m=z.join(c,d.name),p=await Qt.readdir(m,{withFileTypes:!0});for(let g of p)g.isDirectory()&&o.push({year:a.name,month:d.name,day:g.name,path:z.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,n=new Date){return(await this.listSessions(e)).filter(o=>o.date>=t&&o.date<=n)}getFilePath(e,t,n){return z.join(this.getGlobalProjectPath(e),t,n)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Qt.readdir(this.globalProjectsDir,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}async projectExists(e){let t=this.getGlobalProjectPath(e);return await po(t)}getDisplayPath(e){let t=Oa.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return z.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return z.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return z.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return z.join(this.globalBaseDir,".running")}getDocsPath(){return z.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(qe(),yt(mt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(qe(),yt(mt)).getActiveProvider();return(qe(),yt(mt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return z.join(Oa.homedir(),".claude")}getClaudeSettingsPath(){return z.join(this.getClaudeDir(),"settings.json")}getAgentsPath(e){return e?z.join(this.getGlobalProjectPath(e),"agents"):z.join(this.globalBaseDir,"agents")}getStoragePath(e,t){return z.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return z.join(this.getGlobalProjectPath(e),"context")}async detectMonorepo(e){let t={isMonorepo:!1,type:null,rootPath:e,packages:[]},n=[{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 s of n){let o=z.join(e,s.file);if(await D(o)){t.isMonorepo=!0,t.type=s.type;break}}if(!t.isMonorepo){let s=z.join(e,"package.json");if(await D(s))try{let o=await Qt.readFile(s,"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 n=[],s=[];try{if(t==="pnpm"){let i=(await Qt.readFile(z.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(s=i[1].split(`
|
|
12
|
-
`).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=
|
|
8
|
+
var oo=Object.defineProperty;var wy=Object.getOwnPropertyDescriptor;var Sy=Object.getOwnPropertyNames;var ky=Object.prototype.hasOwnProperty;var l=(s,e)=>oo(s,"name",{value:e,configurable:!0}),fn=(s=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(s,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):s)(function(s){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+s+'" is not supported')});var k=(s,e)=>()=>(s&&(e=s(s=0)),e);var hn=(s,e)=>{for(var t in e)oo(s,t,{get:e[t],enumerable:!0})},by=(s,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Sy(e))!ky.call(s,r)&&r!==t&&oo(s,r,{get:()=>e[r],enumerable:!(n=wy(e,r))||n.enumerable});return s};var ht=s=>by(oo({},"__esModule",{value:!0}),s);var Yu=k(()=>{"use strict"});var Le,Qu=k(()=>{"use strict";Le={SESSION_STARTED:"session.started",SESSION_PAUSED:"session.paused",SESSION_RESUMED:"session.resumed",SESSION_COMPLETED:"session.completed",TASK_CREATED:"task.created",TASK_COMPLETED:"task.completed",TASK_UPDATED:"task.updated",FEATURE_ADDED:"feature.added",FEATURE_SHIPPED:"feature.shipped",FEATURE_UPDATED:"feature.updated",IDEA_CAPTURED:"idea.captured",IDEA_PROMOTED:"idea.promoted",SNAPSHOT_CREATED:"snapshot.created",SNAPSHOT_RESTORED:"snapshot.restored",COMMIT_CREATED:"git.commit",PUSH_COMPLETED:"git.push",PROJECT_INITIALIZED:"project.init",PROJECT_SYNCED:"project.sync",ANALYSIS_COMPLETED:"analysis.completed",ALL:"*"}});var cr,io=k(()=>{"use strict";cr={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 Zu(s){return s instanceof Error&&"code"in s}function C(s){return Zu(s)&&s.code==="ENOENT"}function y(s){return s instanceof Error?s.message:typeof s=="string"?s:"Unknown error"}var L=k(()=>{"use strict";l(Zu,"isNodeError");l(C,"isNotFoundError");l(y,"getErrorMessage")});var ed=k(()=>{"use strict"});var td=k(()=>{"use strict";ed()});function ao(s,e=!1){return e||s>=6?"high":s>=3?"medium":"low"}var O,nd,ms=k(()=>{"use strict";O={CODE_STYLE:"code_style",NAMING_CONVENTION:"naming_convention",FILE_STRUCTURE:"file_structure",COMMIT_STYLE:"commit_style",BRANCH_NAMING:"branch_naming",TEST_BEHAVIOR:"test_behavior",SHIP_WORKFLOW:"ship_workflow",TECH_STACK:"tech_stack",ARCHITECTURE:"architecture",DEPENDENCIES:"dependencies",OUTPUT_VERBOSITY:"output_verbosity",CONFIRMATION_LEVEL:"confirmation_level",AGENT_PREFERENCE:"agent_preference"},nd=["frontend","backend","devops","docs","testing","database","general"];l(ao,"calculateConfidence")});var fa=k(()=>{"use strict"});var ha=k(()=>{"use strict";Yu();Qu();io();L();td();ms();fa()});var B={};hn(B,{calculateDuration:()=>$y,formatDate:()=>gs,formatDuration:()=>nn,formatMonth:()=>Ty,getDateKey:()=>Ey,getDateRange:()=>Dy,getDaysAgo:()=>yn,getDaysFromNow:()=>Ry,getEndOfDay:()=>Oy,getStartOfDay:()=>My,getTimestamp:()=>b,getTodayKey:()=>sd,getYearMonthDay:()=>ya,isToday:()=>jy,isWithinLastDays:()=>Iy,parseDate:()=>Ay,toRelative:()=>Fy});import{formatDistanceToNowStrict as xy}from"date-fns";function gs(s){let e=s.getFullYear(),t=(s.getMonth()+1).toString().padStart(2,"0"),n=s.getDate().toString().padStart(2,"0");return`${e}-${t}-${n}`}function Ty(s){let e=s.getFullYear(),t=(s.getMonth()+1).toString().padStart(2,"0");return`${e}-${t}`}function sd(){return gs(new Date)}function Ey(s){return gs(s)}function ya(s){return{year:s.getFullYear().toString(),month:(s.getMonth()+1).toString().padStart(2,"0"),day:s.getDate().toString().padStart(2,"0")}}function Ay(s){return new Date(s)}function b(){return new Date().toISOString()}function yn(s){let e=new Date;return e.setDate(e.getDate()-s),e}function Ry(s){let e=new Date;return e.setDate(e.getDate()+s),e}function Dy(s,e){let t=[],n=new Date(s);for(;n<=e;)t.push(new Date(n)),n=new Date(n.getFullYear(),n.getMonth(),n.getDate()+1);return t}function jy(s){return gs(s)===sd()}function Iy(s,e){let t=yn(e);return s>=t}function nn(s){let e=Math.floor(s/1e3),t=Math.floor(e/60),n=Math.floor(t/60),r=Math.floor(n/24);return r>0?`${r}d ${n%24}h`:n>0?`${n}h ${t%60}m`:t>0?`${t}m`:`${e}s`}function $y(s,e=new Date){let t=e.getTime()-s.getTime();return nn(t)}function My(s){let e=new Date(s);return e.setHours(0,0,0,0),e}function Oy(s){let e=new Date(s);return e.setHours(23,59,59,999),e}function Fy(s){let e=typeof s=="string"?new Date(s):s;return xy(e,{addSuffix:!0})}var ce=k(()=>{"use strict";l(gs,"formatDate");l(Ty,"formatMonth");l(sd,"getTodayKey");l(Ey,"getDateKey");l(ya,"getYearMonthDay");l(Ay,"parseDate");l(b,"getTimestamp");l(yn,"getDaysAgo");l(Ry,"getDaysFromNow");l(Dy,"getDateRange");l(jy,"isToday");l(Iy,"isWithinLastDays");l(nn,"formatDuration");l($y,"calculateDuration");l(My,"getStartOfDay");l(Oy,"getEndOfDay");l(Fy,"toRelative")});import id from"node:fs/promises";async function ad(s,e){let t;try{t=await id.readFile(s,"utf-8")}catch(o){if(C(o))return null;throw o}let n;try{n=JSON.parse(t)}catch{return await rd(s,t),od(s,"Malformed JSON"),null}let r=e.safeParse(n);return r.success?n:(await rd(s,t),od(s,_y(r.error)),null)}async function rd(s,e){let t=`${s}.backup`;try{await id.writeFile(t,e,"utf-8")}catch{}}function od(s,e){console.error(`[prjct] Warning: Corrupted storage file: ${s}`),console.error(`[prjct] Reason: ${e}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function _y(s){return s.issues.slice(0,3).map(e=>`${e.path.join(".")}: ${e.message}`).join("; ")}var cd=k(()=>{"use strict";L();l(ad,"safeRead");l(rd,"createBackup");l(od,"logCorruption");l(_y,"formatZodError")});var Te={};hn(Te,{appendLine:()=>wa,appendToFile:()=>Ly,atomicWrite:()=>Ny,copyFile:()=>Vy,deleteDir:()=>Gy,deleteFile:()=>Hy,dirExists:()=>co,ensureDir:()=>Ot,fileExists:()=>j,getFileExtension:()=>Ky,getFileModifiedTime:()=>zy,getFileNameWithoutExtension:()=>Xy,getFileSize:()=>Wy,listFiles:()=>sn,moveFile:()=>By,prependToFile:()=>Uy,readFile:()=>ot,readJson:()=>zt,readLines:()=>Jy,writeFile:()=>Vt,writeJson:()=>On,writeLines:()=>qy});import be from"node:fs/promises";import fs from"node:path";async function zt(s,e=null,t){if(t)return await ad(s,t)??e;try{let n=await be.readFile(s,"utf-8");return JSON.parse(n)}catch(n){if(C(n))return e;throw n}}async function On(s,e,t=2){let n=JSON.stringify(e,null,t);await be.writeFile(s,n,"utf-8")}async function ot(s,e=""){try{return await be.readFile(s,"utf-8")}catch(t){if(C(t))return e;throw t}}async function Vt(s,e){let t=fs.dirname(s);await be.mkdir(t,{recursive:!0}),await be.writeFile(s,e,"utf-8")}async function Ny(s,e){let t=fs.dirname(s);await be.mkdir(t,{recursive:!0});let n=`${s}.${Date.now()}.tmp`;await be.writeFile(n,e,"utf-8"),await be.rename(n,s)}async function Ly(s,e){await be.appendFile(s,e,"utf-8")}async function wa(s,e){let t=fs.dirname(s);await be.mkdir(t,{recursive:!0}),await be.appendFile(s,`${e}
|
|
9
|
+
`,"utf-8")}async function Uy(s,e){try{let t=await be.readFile(s,"utf-8");await be.writeFile(s,e+t,"utf-8")}catch(t){if(C(t))await be.writeFile(s,e,"utf-8");else throw t}}async function j(s){try{return await be.access(s),!0}catch(e){if(C(e))return!1;throw e}}async function co(s){try{return(await be.stat(s)).isDirectory()}catch(e){if(C(e))return!1;throw e}}async function Ot(s){await be.mkdir(s,{recursive:!0})}async function Hy(s){try{return await be.unlink(s),!0}catch(e){if(C(e))return!1;throw e}}async function Gy(s){try{return await be.rm(s,{recursive:!0,force:!0}),!0}catch(e){if(C(e))return!1;throw e}}async function sn(s,e={}){try{let n=await be.readdir(s,{withFileTypes:!0});return e.filesOnly&&(n=n.filter(r=>r.isFile())),e.dirsOnly&&(n=n.filter(r=>r.isDirectory())),e.extension&&(n=n.filter(r=>r.name.endsWith(e.extension))),n.map(r=>r.name)}catch(t){if(C(t))return[];throw t}}async function Wy(s){return(await be.stat(s)).size}async function zy(s){return(await be.stat(s)).mtime}async function Vy(s,e){await be.copyFile(s,e)}async function By(s,e){await be.rename(s,e)}async function Jy(s){return(await ot(s,"")).split(`
|
|
10
|
+
`)}async function qy(s,e){let t=e.join(`
|
|
11
|
+
`);await Vt(s,t)}function Ky(s){return fs.extname(s)}function Xy(s){return fs.basename(s,fs.extname(s))}var We=k(()=>{"use strict";cd();L();l(zt,"readJson");l(On,"writeJson");l(ot,"readFile");l(Vt,"writeFile");l(Ny,"atomicWrite");l(Ly,"appendToFile");l(wa,"appendLine");l(Uy,"prependToFile");l(j,"fileExists");l(co,"dirExists");l(Ot,"ensureDir");l(Hy,"deleteFile");l(Gy,"deleteDir");l(sn,"listFiles");l(Wy,"getFileSize");l(zy,"getFileModifiedTime");l(Vy,"copyFile");l(By,"moveFile");l(Jy,"readLines");l(qy,"writeLines");l(Ky,"getFileExtension");l(Xy,"getFileNameWithoutExtension")});import{z as Bt}from"zod";function ld(s,e){let t=s.split(".").map(Number),n=e.split(".").map(Number);for(let r=0;r<3;r++){let o=t[r]??0,i=n[r]??0;if(o<i)return-1;if(o>i)return 1}return 0}var iA,aA,cA,hs,lA,lr=k(()=>{"use strict";iA=Bt.enum(["opus","sonnet","haiku"]),aA=Bt.enum(["2.5-pro","2.5-flash","2.0-flash"]),cA=Bt.string().min(1),hs=Bt.object({provider:Bt.string(),model:Bt.string(),cliVersion:Bt.string().optional(),recordedAt:Bt.string()}),lA=Bt.object({preferredModel:Bt.string().optional(),lastAnalysisModel:hs.optional()});l(ld,"compareSemver")});import Sa from"node:fs/promises";import Yy from"node:os";import ud from"node:path";async function md(){try{let s=await Sa.readFile(pd,"utf-8"),e=JSON.parse(s);return!e.timestamp||!e.detection||Date.now()-new Date(e.timestamp).getTime()>Qy?null:e.detection}catch{return null}}async function gd(s){let e={timestamp:new Date().toISOString(),detection:s};await Sa.mkdir(dd,{recursive:!0}),await Sa.writeFile(pd,JSON.stringify(e,null,2))}var dd,pd,Qy,fd=k(()=>{"use strict";dd=ud.join(Yy.homedir(),".prjct-cli","cache"),pd=ud.join(dd,"providers.json"),Qy=600*1e3;l(md,"readProviderCache");l(gd,"writeProviderCache")});var pt={};hn(pt,{AntigravityProvider:()=>ba,ClaudeProvider:()=>lo,CodexProvider:()=>va,CursorProvider:()=>wd,GeminiProvider:()=>ka,Providers:()=>dt,WindsurfProvider:()=>Sd,detectAllProviders:()=>ur,detectAntigravity:()=>mo,detectCodex:()=>Fn,detectCursorProject:()=>vd,detectProvider:()=>uo,detectWindsurfProject:()=>Pd,getActiveProvider:()=>rw,getCapabilities:()=>nw,getCommandsDir:()=>dw,getGlobalContextPath:()=>cw,getGlobalSettingsPath:()=>lw,getProjectCommandsPath:()=>pw,getProviderBranding:()=>po,getSkillsPath:()=>uw,hasProviderConfig:()=>ow,needsCursorRouterRegeneration:()=>iw,needsWindsurfRouterRegeneration:()=>aw,selectProvider:()=>Pa,validateCliVersion:()=>bd});import{exec as Zy}from"node:child_process";import wn from"node:os";import ze from"node:path";import{promisify as ew}from"node:util";function nw(s,e){return{...tw[s],...e}}async function kd(s){try{let{stdout:e}=await hd(`which ${s}`,{timeout:yd});return e.trim()}catch{return null}}async function sw(s){try{let{stdout:e}=await hd(`${s} --version`,{timeout:yd}),t=e.match(/\d+\.\d+\.\d+/);return t?t[0]:e.trim()}catch{return null}}async function uo(s){let e=dt[s];if(!e.cliCommand)return{installed:!1};let t=await kd(e.cliCommand);if(!t)return{installed:!1};let n=await sw(e.cliCommand),r=bd(s,n||void 0);return{installed:!0,version:n||void 0,path:t,versionWarning:r||void 0}}function bd(s,e){let t=dt[s];return!t.minCliVersion||!e?null:ld(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 ur(s=!1){if(!s){let i=await md();if(i)return i}let[e,t,n]=await Promise.all([uo("claude"),uo("gemini"),Fn()]),r={installed:n.installed},o={claude:e,gemini:t,codex:r};return await gd(o).catch(()=>{}),o}async function rw(s){if(s&&dt[s])return dt[s];let e=await ur();return e.claude.installed&&!e.gemini.installed?lo:e.gemini.installed&&!e.claude.installed?ka:lo}async function ow(s){let e=dt[s];return e.configDir?j(e.configDir):!1}function po(s){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"}[s]||"\u26A1 prjct"}}async function vd(s){let e=ze.join(s,".cursor"),t=ze.join(e,"rules"),n=ze.join(t,"prjct.mdc"),[r,o]=await Promise.all([j(e),j(n)]);return{detected:r,routerInstalled:o,projectRoot:r?s:void 0}}async function iw(s){let e=await vd(s);return e.detected&&!e.routerInstalled}async function Pd(s){let e=ze.join(s,".windsurf"),t=ze.join(e,"rules"),n=ze.join(t,"prjct.md"),[r,o]=await Promise.all([j(e),j(n)]);return{detected:r,routerInstalled:o,projectRoot:r?s:void 0}}async function aw(s){let e=await Pd(s);return e.detected&&!e.routerInstalled}async function mo(){let s=ba.configDir;if(!s)return{installed:!1,skillInstalled:!1};let e=ze.join(s,"skills","prjct","SKILL.md"),[t,n]=await Promise.all([j(s),j(e)]);return{installed:t,skillInstalled:n,configPath:t?s:void 0}}async function Fn(){let s=va.configDir;if(!s)return{installed:!1,skillInstalled:!1};let e=await kd("codex"),t=ze.join(s,"skills","prjct","SKILL.md"),n=await j(t),r=!!e;return{installed:r,skillInstalled:n,configPath:r?s:void 0}}function cw(s){let e=dt[s];return e.configDir?ze.join(e.configDir,e.contextFile):null}function lw(s){let e=dt[s];return!e.configDir||!e.settingsFile?null:ze.join(e.configDir,e.settingsFile)}function uw(s){return dt[s].skillsDir}function dw(s){return dt[s].commandsDir}function pw(s,e){let t=dt[s];return ze.join(e,t.commandsDir)}async function Pa(){let s=await ur(),e=s.claude.installed,t=s.gemini.installed;return!e&&!t?{provider:"claude",userSelected:!1,detection:s}:e&&!t?{provider:"claude",userSelected:!1,detection:s}:t&&!e?{provider:"gemini",userSelected:!1,detection:s}:{provider:"claude",userSelected:!0,detection:s}}var hd,yd,tw,lo,ka,ba,wd,Sd,va,dt,qe=k(()=>{"use strict";lr();We();fd();hd=ew(Zy),yd=2e3,tw={full:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!0,webFetch:!0,todoTracking:!0},standard:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!0,subagents:!1,webFetch:!1,todoTracking:!1},basic:{shell:!0,fileRead:!0,fileWrite:!0,fileSearch:!0,structuredQuestions:!1,subagents:!1,webFetch:!1,todoTracking:!1}};l(nw,"getCapabilities");lo={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:ze.join(wn.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:ze.join(wn.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"},ka={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:ze.join(wn.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:ze.join(wn.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"},ba={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:ze.join(wn.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:ze.join(wn.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"},wd={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"},Sd={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"},va={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:ze.join(wn.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:ze.join(wn.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"},dt={claude:lo,gemini:ka,cursor:wd,antigravity:ba,windsurf:Sd,codex:va};l(kd,"whichCommand");l(sw,"getCliVersion");l(uo,"detectProvider");l(bd,"validateCliVersion");l(ur,"detectAllProviders");l(rw,"getActiveProvider");l(ow,"hasProviderConfig");l(po,"getProviderBranding");l(vd,"detectCursorProject");l(iw,"needsCursorRouterRegeneration");l(Pd,"detectWindsurfProject");l(aw,"needsWindsurfRouterRegeneration");l(mo,"detectAntigravity");l(Fn,"detectCodex");l(cw,"getGlobalContextPath");l(lw,"getGlobalSettingsPath");l(uw,"getSkillsPath");l(dw,"getCommandsDir");l(pw,"getProjectCommandsPath");l(Pa,"selectProvider")});import mw from"node:crypto";import Jt from"node:fs/promises";import Ca from"node:os";import W from"node:path";import{globSync as gw}from"glob";var xa,fw,A,ve=k(()=>{"use strict";ce();We();xa=class{static{l(this,"PathManager")}globalBaseDir;globalProjectsDir;globalConfigDir;constructor(){let e=process.env.PRJCT_CLI_HOME?.trim();this.globalBaseDir=e?W.resolve(e):W.join(Ca.homedir(),".prjct-cli"),this.globalProjectsDir=W.join(this.globalBaseDir,"projects"),this.globalConfigDir=W.join(this.globalBaseDir,"config")}setGlobalBaseDir(e){this.globalBaseDir=W.resolve(e),this.globalProjectsDir=W.join(this.globalBaseDir,"projects"),this.globalConfigDir=W.join(this.globalBaseDir,"config")}generateProjectId(e){return mw.randomUUID()}getGlobalBasePath(){return this.globalBaseDir}getGlobalProjectPath(e){return W.join(this.globalProjectsDir,e)}getLocalConfigPath(e){return W.join(e,".prjct","prjct.config.json")}getGlobalProjectConfigPath(e){return W.join(this.getGlobalProjectPath(e),"project.json")}getLegacyPrjctPath(e){return W.join(e,".prjct")}async hasLegacyStructure(e){let t=this.getLegacyPrjctPath(e);return await co(t)}async hasConfig(e){let t=this.getLocalConfigPath(e);return await j(t)}async ensureGlobalStructure(){await Ot(this.globalBaseDir),await Ot(this.globalProjectsDir),await Ot(this.globalConfigDir)}async ensureProjectStructure(e){await this.ensureGlobalStructure();let t=this.getGlobalProjectPath(e),n=["core","progress","planning","analysis","memory","agents"];for(let r of n)await Ot(W.join(t,r));return await Ot(W.join(t,"planning","tasks")),await Ot(W.join(t,"sessions")),t}getSessionPath(e,t=new Date){let{year:n,month:r,day:o}=ya(t);return W.join(this.getGlobalProjectPath(e),"sessions",n,r,o)}getCurrentSessionPath(e){return this.getSessionPath(e,new Date)}async ensureSessionPath(e,t=new Date){let n=this.getSessionPath(e,t);return await Ot(n),n}async listSessions(e,t=null,n=null){let r=W.join(this.getGlobalProjectPath(e),"sessions"),o=[];try{let i=await Jt.readdir(r,{withFileTypes:!0});for(let a of i){if(!a.isDirectory()||t&&a.name!==t.toString())continue;let c=W.join(r,a.name),u=await Jt.readdir(c,{withFileTypes:!0});for(let d of u){if(!d.isDirectory()||n&&d.name!==n.toString().padStart(2,"0"))continue;let m=W.join(c,d.name),p=await Jt.readdir(m,{withFileTypes:!0});for(let g of p)g.isDirectory()&&o.push({year:a.name,month:d.name,day:g.name,path:W.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,n=new Date){return(await this.listSessions(e)).filter(o=>o.date>=t&&o.date<=n)}getFilePath(e,t,n){return W.join(this.getGlobalProjectPath(e),t,n)}async listProjects(){try{return await this.ensureGlobalStructure(),(await Jt.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 co(t)}getDisplayPath(e){let t=Ca.homedir();return e.startsWith(t)?e.replace(t,"~"):e}getAuthConfigPath(){return W.join(this.globalConfigDir,"auth.json")}getSyncPendingPath(e){return W.join(this.getGlobalProjectPath(e),"sync","pending.json")}getLastSyncPath(e){return W.join(this.getGlobalProjectPath(e),"sync","last-sync.json")}getRunningStatusPath(){return W.join(this.globalBaseDir,".running")}getDocsPath(){return W.join(this.globalBaseDir,"docs")}async getAgentDir(){return(await(qe(),ht(pt)).getActiveProvider()).configDir}async getAgentSettingsPath(){let e=await(qe(),ht(pt)).getActiveProvider();return(qe(),ht(pt)).getGlobalSettingsPath(e.name)}getClaudeDir(){return W.join(Ca.homedir(),".claude")}getClaudeSettingsPath(){return W.join(this.getClaudeDir(),"settings.json")}getAgentsPath(e){return e?W.join(this.getGlobalProjectPath(e),"agents"):W.join(this.globalBaseDir,"agents")}getStoragePath(e,t){return W.join(this.getGlobalProjectPath(e),"storage",t)}getContextPath(e){return W.join(this.getGlobalProjectPath(e),"context")}async detectMonorepo(e){let t={isMonorepo:!1,type:null,rootPath:e,packages:[]},n=[{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 n){let o=W.join(e,r.file);if(await j(o)){t.isMonorepo=!0,t.type=r.type;break}}if(!t.isMonorepo){let r=W.join(e,"package.json");if(await j(r))try{let o=await Jt.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 n=[],r=[];try{if(t==="pnpm"){let i=(await Jt.readFile(W.join(e,"pnpm-workspace.yaml"),"utf-8")).match(/packages:\s*\n((?:\s*-\s*.+\n?)+)/);i&&(r=i[1].split(`
|
|
12
|
+
`).map(a=>a.replace(/^\s*-\s*['"]?|['"]?\s*$/g,"")).filter(Boolean))}else if(t==="npm"||t==="lerna"){let o=W.join(e,"package.json"),i=await Jt.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=W.join(e,"lerna.json");if(await j(c)){let u=await Jt.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=W.join(e,"package.json"),i=await Jt.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=gw(o,{cwd:e,absolute:!1});for(let a of i){let c=W.join(e,a),u=W.join(c,"package.json");if(await j(u))try{let d=await Jt.readFile(u,"utf-8"),m=JSON.parse(d),p=W.join(c,"PRJCT.md");n.push({name:m.name||W.basename(a),path:c,relativePath:a,hasPrjctMd:await j(p)})}catch{}}}}catch{}return n}async findContainingPackage(e,t){if(!t.isMonorepo)return null;let n=W.resolve(e);for(let r of t.packages){let o=W.resolve(r.path);if(n.startsWith(o))return r}return null}async findMonorepoRoot(e){let t=W.resolve(e),n=W.parse(t).root;for(;t!==n;){if((await this.detectMonorepo(t)).isMonorepo)return t;t=W.dirname(t)}return null}},fw=new xa,A=fw});function hw(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function dr(){return hw()==="bun"}var Ta=k(()=>{"use strict";l(hw,"detectRuntime");l(dr,"isBun")});import Ea from"node:fs";import Cd from"node:path";function yw(s){if(dr()){let{Database:r}=fn("bun:sqlite");return new r(s,{create:!0})}let e=fn("better-sqlite3"),t=new e(s),n=t.exec.bind(t);return t.run=r=>n(r),t}var ww,go,E,G,oe=k(()=>{"use strict";ve();Ta();l(yw,"openDatabase");ww=[{version:1,name:"initial-schema",up:l(s=>{s.run(`
|
|
13
13
|
-- =======================================================================
|
|
14
14
|
-- Document storage (backward-compatible with JSON file pattern)
|
|
15
15
|
-- =======================================================================
|
|
@@ -223,7 +223,7 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
223
223
|
started_at TEXT,
|
|
224
224
|
ended_at TEXT
|
|
225
225
|
);
|
|
226
|
-
`)},"up")},{version:2,name:"archives-table",up:l(
|
|
226
|
+
`)},"up")},{version:2,name:"archives-table",up:l(s=>{s.run(`
|
|
227
227
|
-- =======================================================================
|
|
228
228
|
-- Archives: Stale data moved out of active storage (PRJ-267)
|
|
229
229
|
-- =======================================================================
|
|
@@ -240,7 +240,7 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
240
240
|
CREATE INDEX idx_archives_entity_type ON archives(entity_type);
|
|
241
241
|
CREATE INDEX idx_archives_archived_at ON archives(archived_at);
|
|
242
242
|
CREATE INDEX idx_archives_entity_id ON archives(entity_id);
|
|
243
|
-
`)},"up")},{version:3,name:"workflow-rules-table",up:l(
|
|
243
|
+
`)},"up")},{version:3,name:"workflow-rules-table",up:l(s=>{s.run(`
|
|
244
244
|
-- =======================================================================
|
|
245
245
|
-- Workflow Rules: hooks, gates, and custom steps (Phase 2)
|
|
246
246
|
-- =======================================================================
|
|
@@ -258,7 +258,7 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
258
258
|
);
|
|
259
259
|
|
|
260
260
|
CREATE INDEX idx_workflow_rules_command ON workflow_rules(command);
|
|
261
|
-
`)},"up")},{version:4,name:"custom-workflows-table",up:l(
|
|
261
|
+
`)},"up")},{version:4,name:"custom-workflows-table",up:l(s=>{s.run(`
|
|
262
262
|
-- =======================================================================
|
|
263
263
|
-- Custom Workflows: User-defined workflows with agentic auto-config
|
|
264
264
|
-- =======================================================================
|
|
@@ -283,7 +283,7 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
283
283
|
('done', 'Complete current task/subtask', 1, 1, datetime('now'), datetime('now')),
|
|
284
284
|
('ship', 'Ship feature with version bump and PR', 1, 1, datetime('now'), datetime('now')),
|
|
285
285
|
('sync', 'Analyze project and regenerate context', 1, 1, datetime('now'), datetime('now'));
|
|
286
|
-
`)},"up")},{version:5,name:"llm-analysis-table",up:l(
|
|
286
|
+
`)},"up")},{version:5,name:"llm-analysis-table",up:l(s=>{s.run(`
|
|
287
287
|
-- =======================================================================
|
|
288
288
|
-- LLM Analysis: Structured findings from hybrid sync pipeline
|
|
289
289
|
-- Pipeline: CLI (collect) \u2192 LLM (analyze) \u2192 CLI (store)
|
|
@@ -299,7 +299,7 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
299
299
|
|
|
300
300
|
CREATE INDEX idx_llm_analysis_status ON llm_analysis(status);
|
|
301
301
|
CREATE INDEX idx_llm_analysis_commit ON llm_analysis(commit_hash);
|
|
302
|
-
`)},"up")},{version:6,name:"context-feedback-table",up:l(
|
|
302
|
+
`)},"up")},{version:6,name:"context-feedback-table",up:l(s=>{s.run(`
|
|
303
303
|
-- =======================================================================
|
|
304
304
|
-- Context Feedback: RL loop for file suggestion improvement
|
|
305
305
|
-- Records suggested vs actual files per task for scoring boosts
|
|
@@ -317,7 +317,7 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
317
317
|
);
|
|
318
318
|
|
|
319
319
|
CREATE INDEX idx_cf_task ON context_feedback(task_id);
|
|
320
|
-
`)},"up")},{version:7,name:"sessions-table",up:l(
|
|
320
|
+
`)},"up")},{version:7,name:"sessions-table",up:l(s=>{s.run(`
|
|
321
321
|
-- =======================================================================
|
|
322
322
|
-- Sessions: Task lifecycle tracking (replaces current.json + archive/)
|
|
323
323
|
-- =======================================================================
|
|
@@ -337,13 +337,13 @@ var co=Object.defineProperty;var Ry=Object.getOwnPropertyDescriptor;var Dy=Objec
|
|
|
337
337
|
CREATE INDEX idx_sessions_project ON sessions(project_id);
|
|
338
338
|
CREATE INDEX idx_sessions_status ON sessions(status);
|
|
339
339
|
CREATE INDEX idx_sessions_completed ON sessions(completed_at);
|
|
340
|
-
`)},"up")}],
|
|
340
|
+
`)},"up")}],go=class{static{l(this,"PrjctDatabase")}connections=new Map;getDbPath(e){return Cd.join(A.getGlobalProjectPath(e),"prjct.db")}getDb(e){let t=this.connections.get(e);if(t)return t;let n=this.getDbPath(e),r=Cd.dirname(n);Ea.existsSync(r)||Ea.mkdirSync(r,{recursive:!0});let o=yw(n);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 = 268435456"),this.runMigrations(o),this.connections.set(e,o),o}close(e){if(e){let t=this.connections.get(e);t&&(t.close(),this.connections.delete(e))}else this.connections.forEach(t=>{t.close()}),this.connections.clear()}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,n){let r=this.getDb(e),o=JSON.stringify(n),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,n,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(n),i)}getEvents(e,t,n=100){let r=this.getDb(e);return t?r.prepare("SELECT * FROM events WHERE type = ? ORDER BY id DESC LIMIT ?").all(t,n):r.prepare("SELECT * FROM events ORDER BY id DESC LIMIT ?").all(n)}query(e,t,...n){return this.getDb(e).prepare(t).all(...n)}run(e,t,...n){this.getDb(e).prepare(t).run(...n)}get(e,t,...n){return this.getDb(e).prepare(t).get(...n)??null}transaction(e,t){let n=this.getDb(e);return n.transaction(t)(n)}runMigrations(e){e.run(`
|
|
341
341
|
CREATE TABLE IF NOT EXISTS _migrations (
|
|
342
342
|
version INTEGER PRIMARY KEY,
|
|
343
343
|
name TEXT NOT NULL,
|
|
344
344
|
applied_at TEXT NOT NULL
|
|
345
345
|
)
|
|
346
|
-
`);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(n=>n.version));for(let n of Rw)t.has(n.version)||e.transaction(()=>{n.up(e),e.prepare("INSERT INTO _migrations (version, name, applied_at) VALUES (?, ?, ?)").run(n.version,n.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}},T=new yo,G=T});function Ua(r){if(md.includes(r))return[r];let e=r.toLowerCase().replace(/[-_\s]/g,""),t=[];for(let[n,s]of Object.entries(wo))if(n!=="general"){for(let o of s)if(e.includes(o)||o.includes(e)){t.push(n);break}}return t.length>0?t:["general"]}var La,wo,Hn,yr,wr,Sr=k(()=>{"use strict";se();hs();ce();La={frontend:[O.CODE_STYLE,O.FILE_STRUCTURE,O.ARCHITECTURE,O.TECH_STACK],backend:[O.CODE_STYLE,O.ARCHITECTURE,O.DEPENDENCIES,O.TECH_STACK],devops:[O.SHIP_WORKFLOW,O.TEST_BEHAVIOR,O.DEPENDENCIES,O.ARCHITECTURE],docs:[O.CODE_STYLE,O.NAMING_CONVENTION,O.FILE_STRUCTURE],testing:[O.TEST_BEHAVIOR,O.CODE_STYLE,O.DEPENDENCIES],database:[O.ARCHITECTURE,O.NAMING_CONVENTION,O.TECH_STACK,O.DEPENDENCIES],general:Object.values(O)},wo={frontend:["ui","ux","uxui","css","styling","component","layout","design","responsive","react","vue","svelte","angular","html","tailwind","sass","web","accessibility","a11y"],backend:["api","server","route","endpoint","rest","graphql","middleware","worker","queue","auth","hono","express","service","microservice"],devops:["ci","cd","docker","kubernetes","deploy","infra","infrastructure","monitoring","cloud","aws","gcp","azure","pipeline","helm","terraform"],docs:["documentation","readme","guide","tutorial","wiki","changelog","jsdoc","typedoc"],testing:["test","spec","e2e","unit","integration","coverage","mock","vitest","jest","playwright","cypress"],database:["db","sql","schema","migration","query","orm","prisma","mongo","postgres","redis","drizzle","sqlite"],general:[]};l(Ua,"resolveCanonicalDomains");Hn=class{static{l(this,"CachedStore")}_data=null;_loaded=!1;_projectId=null;getSubdirectory(){return null}getStoreKey(){let e=this.getFilename().replace(".json",""),t=this.getSubdirectory();return t?`memory:${t}:${e}`:`memory:${e}`}async load(e){if(this._loaded&&this._data&&this._projectId===e)return this._data;let t=this.getStoreKey(),n=G.getDoc(e,t);return n!==null?(this._data=n,this.afterLoad(this._data)):this._data=this.getDefault(),this._loaded=!0,this._projectId=e,this._data}afterLoad(e){}async save(e){if(!this._data)return;let t=this.getStoreKey();G.setDoc(e,t,this._data)}getData(){return this._data}setData(e){this._data=e}async update(e,t){let n=await this.load(e),s=t(n);return this._data=s,await this.save(e),s}isLoaded(e){return e?this._loaded&&this._projectId===e:this._loaded}reset(){this._data=null,this._loaded=!1,this._projectId=null}},yr=class{static{l(this,"SessionStore")}_sessionMemory=new Map;setSession(e,t){this._sessionMemory.set(e,{value:t,timestamp:Date.now()})}getSession(e){return this._sessionMemory.get(e)?.value}clearSession(){this._sessionMemory.clear()}},wr=class{static{l(this,"HistoryStore")}async appendHistory(e,t){let n={ts:b(),...t,type:t.type};G.appendEvent(e,`history.${t.type}`,n)}async getRecentHistory(e,t=20){return G.query(e,"SELECT data, timestamp FROM events WHERE type LIKE 'history.%' ORDER BY id DESC LIMIT ?",t).reverse().map(s=>JSON.parse(s.data))}}});var kr,Ha=k(()=>{"use strict";se();hs();ce();Sr();kr=class r extends Hn{static{l(this,"PatternStore")}static MAX_CONTEXTS=20;static ARCHIVE_AGE_DAYS=90;getFilename(){return"patterns.json"}getDefault(){return{version:1,decisions:{},preferences:{},workflows:{},counters:{}}}afterLoad(e){for(let t of Object.values(e.decisions))t.contexts.length>r.MAX_CONTEXTS&&(t.contexts=t.contexts.slice(-r.MAX_CONTEXTS))}async loadPatterns(e){return this.load(e)}async savePatterns(e){return this.save(e)}async recordDecision(e,t,n,s="",o={}){let i=await this.load(e),a=b();if(!i.decisions[t])i.decisions[t]={value:n,count:1,firstSeen:a,lastSeen:a,confidence:o.userConfirmed?"high":"low",contexts:[s].filter(Boolean),userConfirmed:o.userConfirmed||!1};else{let c=i.decisions[t];c.value===n?(c.count++,c.lastSeen=a,s&&!c.contexts.includes(s)&&(c.contexts.push(s),c.contexts.length>r.MAX_CONTEXTS&&(c.contexts=c.contexts.slice(-r.MAX_CONTEXTS))),o.userConfirmed&&(c.userConfirmed=!0),c.confidence=uo(c.count,c.userConfirmed)):(c.value=n,c.count=1,c.lastSeen=a,c.userConfirmed=o.userConfirmed||!1,c.confidence=o.userConfirmed?"high":"low")}await this.save(e)}async confirmDecision(e,t){let s=(await this.load(e)).decisions[t];return s?(s.userConfirmed=!0,s.confidence="high",s.lastSeen=b(),await this.save(e),!0):!1}async getDecision(e,t){let s=(await this.load(e)).decisions[t];return!s||s.confidence==="low"?null:{value:s.value,confidence:s.confidence}}async hasPattern(e,t){return await this.getDecision(e,t)!==null}async recordWorkflow(e,t,n){let s=await this.load(e),o=b();if(!s.workflows[t])s.workflows[t]={...n,count:1,firstSeen:o,lastSeen:o,confidence:"low",userConfirmed:!1};else{let i=s.workflows[t];i.count++,i.lastSeen=o,i.confidence=uo(i.count,i.userConfirmed)}await this.save(e)}async confirmWorkflow(e,t){let s=(await this.load(e)).workflows[t];return s?(s.userConfirmed=!0,s.confidence="high",s.lastSeen=b(),await this.save(e),!0):!1}async getWorkflow(e,t){let s=(await this.load(e)).workflows[t];return!s||s.count<3?null:s}async setPreference(e,t,n,s={}){let o=await this.load(e),i=o.preferences[t],a=i?i.observationCount+1:1,c=s.userConfirmed||i?.userConfirmed||!1;o.preferences[t]={value:n,updatedAt:b(),confidence:uo(a,c),observationCount:a,userConfirmed:c},await this.save(e)}async confirmPreference(e,t){let s=(await this.load(e)).preferences[t];return s?(s.userConfirmed=!0,s.confidence="high",s.updatedAt=b(),await this.save(e),!0):!1}async getPreference(e,t,n=null){return(await this.load(e)).preferences[t]?.value??n}async getPatternsSummary(e){let t=await this.load(e);return{decisions:Object.keys(t.decisions).length,learnedDecisions:Object.values(t.decisions).filter(n=>n.confidence!=="low").length,workflows:Object.keys(t.workflows).length,preferences:Object.keys(t.preferences).length}}async archiveStaleDecisions(e){let t=await this.load(e),n=Date.now(),s=r.ARCHIVE_AGE_DAYS*24*60*60*1e3,o=[];for(let[a,c]of Object.entries(t.decisions)){let u=new Date(c.lastSeen).getTime();n-u>s&&o.push(a)}if(o.length===0)return 0;let i=G.getDoc(e,"memory:patterns-archive")??{};for(let a of o)i[a]=t.decisions[a],delete t.decisions[a];return G.setDoc(e,"memory:patterns-archive",i),await this.save(e),o.length}}});var _d=k(()=>{"use strict"});import br from"node:fs/promises";import Pn from"node:path";import{z as K}from"zod";async function Ow(r,e){let t=Date.now();if(r.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let n=Pn.join(e,"package.json"),s=await br.readFile(n,"utf-8"),o=JSON.parse(s),i={...o.dependencies,...o.devDependencies},a=[],c=[];for(let u of r.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(n){return P(n)?{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: ${n instanceof Error?n.message:"unknown error"}`,durationMs:Date.now()-t}}}async function _w(r,e){let t=Date.now();if(r.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let n=await Uw(e),s=new Set(n),o=[],i=[];for(let a of r.languages){let c=Mw[a];if(!c)continue;c.some(d=>s.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(n){return{name:"Language verification",passed:!1,error:`Failed to scan project files: ${n instanceof Error?n.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Fw(r,e){let t=Date.now(),n=r.patterns.filter(i=>i.location);if(n.length===0)return{name:"Pattern location verification",passed:!0,output:"No pattern locations specified (skipped)",durationMs:Date.now()-t};let s=[],o=[];for(let i of n){let a=i.location,c=Pn.join(e,a);try{await br.access(c),o.push(a)}catch{s.push(`${i.name} (${a})`)}}return s.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: ${s.join(", ")}`,durationMs:Date.now()-t}}async function Nw(r,e){let t=Date.now();try{let n=await Hw(e),s=r.fileCount,o=.1,i=Math.abs(n-s),a=s*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${s}, actual: ${n})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${s}, actual ${n} (diff: ${i})`,durationMs:Date.now()-t}}catch(n){return{name:"File count verification",passed:!1,error:`Failed to count files: ${n instanceof Error?n.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Lw(r,e){let t=Date.now();if(r.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let n=[],s=[];for(let o of r.antiPatterns){let i=Pn.join(e,o.file);try{await br.access(i),s.push(o.file)}catch{n.push(`${o.issue} (${o.file})`)}}return n.length===0?{name:"Anti-pattern file verification",passed:!0,output:`${s.length} anti-pattern file(s) verified`,durationMs:Date.now()-t}:{name:"Anti-pattern file verification",passed:!1,error:`Anti-pattern files not found: ${n.join(", ")}`,durationMs:Date.now()-t}}async function Fd(r,e){let t=Date.now(),n=await Promise.all([Ow(r,e),_w(r,e),Fw(r,e),Nw(r,e),Lw(r,e)]),s=n.filter(i=>!i.passed).length,o=n.filter(i=>i.passed).length;return{passed:s===0,checks:n,totalMs:Date.now()-t,failedCount:s,passedCount:o}}async function Uw(r){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function n(s){try{let o=await br.readdir(s,{withFileTypes:!0});for(let i of o){let a=Pn.join(s,i.name),c=Pn.relative(r,a);if(!t.some(u=>u.test(c))){if(i.isDirectory())await n(a);else if(i.isFile()){let u=Pn.extname(i.name);u&&e.add(u)}}}}catch{}}return l(n,"scanDir"),await n(r),Array.from(e)}async function Hw(r){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function n(s){try{let o=await br.readdir(s,{withFileTypes:!0});for(let i of o){let a=Pn.join(s,i.name),c=Pn.relative(r,a);t.some(u=>u.test(c))||(i.isDirectory()?await n(a):i.isFile()&&e++)}}catch{}}return l(n,"scanDir"),await n(r),e}var Dw,jw,$w,Ga,TI,Mw,za=k(()=>{"use strict";F();gr();Dw=K.enum(["draft","verified","sealed"]),jw=K.object({name:K.string(),description:K.string(),location:K.string().optional(),severity:K.enum(["low","medium","high"]).optional(),language:K.string().optional(),framework:K.string().optional(),source:K.enum(["baseline","repo","context7","feedback"]).optional(),confidence:K.number().min(0).max(1).optional()}),$w=K.object({issue:K.string(),file:K.string(),suggestion:K.string(),severity:K.enum(["low","medium","high"]).optional(),language:K.string().optional(),framework:K.string().optional(),source:K.enum(["baseline","repo","context7","feedback"]).optional(),confidence:K.number().min(0).max(1).optional()}),Ga=K.object({projectId:K.string(),languages:K.array(K.string()),frameworks:K.array(K.string()),packageManager:K.string().optional(),sourceDir:K.string().optional(),testDir:K.string().optional(),configFiles:K.array(K.string()),fileCount:K.number(),patterns:K.array(jw),antiPatterns:K.array($w),analyzedAt:K.string(),modelMetadata:Ss.optional(),status:Dw.default("draft"),commitHash:K.string().optional(),signature:K.string().optional(),sealedAt:K.string().optional(),verifiedAt:K.string().optional()}),TI={languages:[],frameworks:[],configFiles:[],fileCount:0,patterns:[],antiPatterns:[],analyzedAt:new Date().toISOString(),status:"draft"},Mw={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(Ow,"verifyFrameworks");l(_w,"verifyLanguages");l(Fw,"verifyPatternLocations");l(Nw,"verifyFileCount");l(Lw,"verifyAntiPatternFiles");l(Fd,"semanticVerify");l(Uw,"getProjectExtensions");l(Hw,"countProjectFiles")});import{z as Fe}from"zod";var So,Cn,Gw,RI,Wa,Nd,vr=k(()=>{"use strict";So=Fe.enum(["frontend","backend","database","devops","testing","docs","uxui","general"]),Cn=Fe.object({primaryDomain:So,secondaryDomains:Fe.array(So),confidence:Fe.number().min(0).max(1),filePatterns:Fe.array(Fe.string()),relevantAgents:Fe.array(Fe.string())}),Gw=Fe.object({classification:Cn,classifiedAt:Fe.string(),source:Fe.enum(["cache","history","llm","heuristic"]),descriptionHash:Fe.string(),projectId:Fe.string()}),RI=Fe.object({entries:Fe.record(Fe.string(),Gw),confirmedPatterns:Fe.array(Fe.object({descriptionHash:Fe.string(),classification:Cn,confirmedAt:Fe.string(),taskDescription:Fe.string()}))}),Wa={entries:{},confirmedPatterns:[]},Nd={primaryDomain:"general",secondaryDomains:[],confidence:.3,filePatterns:["**/*.ts","**/*.js"],relevantAgents:[]}});import{z as W}from"zod";var zw,Ww,Ld,Vw,Bw,Jw,qw,Kw,Ud,$I,Va=k(()=>{"use strict";zw=W.enum(["low","medium","high"]),Ww=W.enum(["pending","converted","completed","archived","dormant"]),Ld=W.enum(["high","medium","low"]),Vw=W.object({impact:Ld,effort:Ld}),Bw=W.object({frontend:W.string().optional(),backend:W.string().optional(),payments:W.string().optional(),ai:W.string().optional(),deploy:W.string().optional(),other:W.array(W.string()).optional()}),Jw=W.object({name:W.string(),description:W.string()}),qw=W.object({name:W.string(),description:W.string().optional()}),Kw=W.object({id:W.string(),text:W.string(),details:W.string().optional(),priority:zw,status:Ww,tags:W.array(W.string()),addedAt:W.string(),completedAt:W.string().optional(),convertedTo:W.string().optional(),source:W.string().optional(),sourceFiles:W.array(W.string()).optional(),painPoints:W.array(W.string()).optional(),solutions:W.array(W.string()).optional(),filesAffected:W.array(W.string()).optional(),impactEffort:Vw.optional(),implementationNotes:W.string().optional(),stack:Bw.optional(),modules:W.array(Jw).optional(),roles:W.array(qw).optional(),risks:W.array(W.string()).optional(),risksCount:W.number().optional()}),Ud=W.object({ideas:W.array(Kw),lastUpdated:W.string()}),$I={priority:"medium",status:"pending",tags:[],addedAt:new Date().toISOString()}});import{z as q}from"zod";function Gd(r){return{provider:r,lastSync:"",staleAfter:18e5,issues:{}}}var Hd,Xw,Yw,Qw,Zw,FI,NI,Ba=k(()=>{"use strict";Hd=q.enum(["linear","jira","github","monday","asana","none"]),Xw=q.enum(["backlog","todo","in_progress","in_review","done","cancelled"]),Yw=q.enum(["none","urgent","high","medium","low"]),Qw=q.enum(["feature","bug","improvement","task","chore","epic"]),Zw=q.object({id:q.string(),identifier:q.string(),title:q.string(),description:q.string().optional(),status:Xw,priority:Yw,type:Qw.optional(),assignee:q.object({id:q.string(),name:q.string(),email:q.string().optional()}).optional(),labels:q.array(q.string()).default([]),team:q.object({id:q.string(),name:q.string(),key:q.string().optional()}).optional(),project:q.object({id:q.string(),name:q.string()}).optional(),url:q.string(),createdAt:q.string(),updatedAt:q.string(),fetchedAt:q.string()}),FI=q.object({provider:Hd,lastSync:q.string(),staleAfter:q.number().default(18e5),issues:q.record(q.string(),Zw)}),NI=q.object({provider:Hd,fetched:q.number(),updated:q.number(),errors:q.array(q.object({issueId:q.string(),error:q.string()})),timestamp:q.string()});l(Gd,"createEmptyIssues")});var Jd={};kn(Jd,{AgentAssignmentSchema:()=>zd,OUTPUT_SCHEMAS:()=>Vd,SubtaskBreakdownSchema:()=>Wd,TaskClassificationSchema:()=>Cn,renderSchemaForPrompt:()=>Ja});import{z as Ke}from"zod";function Ja(r){let e=Vd[r];return e?`## OUTPUT FORMAT
|
|
346
|
+
`);let t=new Set(e.prepare("SELECT version FROM _migrations").all().map(n=>n.version));for(let n of ww)t.has(n.version)||e.transaction(()=>{n.up(e),e.prepare("INSERT INTO _migrations (version, name, applied_at) VALUES (?, ?, ?)").run(n.version,n.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}},E=new go,G=E});function Ra(s){if(nd.includes(s))return[s];let e=s.toLowerCase().replace(/[-_\s]/g,""),t=[];for(let[n,r]of Object.entries(fo))if(n!=="general"){for(let o of r)if(e.includes(o)||o.includes(e)){t.push(n);break}}return t.length>0?t:["general"]}var Aa,fo,_n,pr,mr,gr=k(()=>{"use strict";oe();ms();ce();Aa={frontend:[O.CODE_STYLE,O.FILE_STRUCTURE,O.ARCHITECTURE,O.TECH_STACK],backend:[O.CODE_STYLE,O.ARCHITECTURE,O.DEPENDENCIES,O.TECH_STACK],devops:[O.SHIP_WORKFLOW,O.TEST_BEHAVIOR,O.DEPENDENCIES,O.ARCHITECTURE],docs:[O.CODE_STYLE,O.NAMING_CONVENTION,O.FILE_STRUCTURE],testing:[O.TEST_BEHAVIOR,O.CODE_STYLE,O.DEPENDENCIES],database:[O.ARCHITECTURE,O.NAMING_CONVENTION,O.TECH_STACK,O.DEPENDENCIES],general:Object.values(O)},fo={frontend:["ui","ux","uxui","css","styling","component","layout","design","responsive","react","vue","svelte","angular","html","tailwind","sass","web","accessibility","a11y"],backend:["api","server","route","endpoint","rest","graphql","middleware","worker","queue","auth","hono","express","service","microservice"],devops:["ci","cd","docker","kubernetes","deploy","infra","infrastructure","monitoring","cloud","aws","gcp","azure","pipeline","helm","terraform"],docs:["documentation","readme","guide","tutorial","wiki","changelog","jsdoc","typedoc"],testing:["test","spec","e2e","unit","integration","coverage","mock","vitest","jest","playwright","cypress"],database:["db","sql","schema","migration","query","orm","prisma","mongo","postgres","redis","drizzle","sqlite"],general:[]};l(Ra,"resolveCanonicalDomains");_n=class{static{l(this,"CachedStore")}_data=null;_loaded=!1;_projectId=null;getSubdirectory(){return null}getStoreKey(){let e=this.getFilename().replace(".json",""),t=this.getSubdirectory();return t?`memory:${t}:${e}`:`memory:${e}`}async load(e){if(this._loaded&&this._data&&this._projectId===e)return this._data;let t=this.getStoreKey(),n=G.getDoc(e,t);return n!==null?(this._data=n,this.afterLoad(this._data)):this._data=this.getDefault(),this._loaded=!0,this._projectId=e,this._data}afterLoad(e){}async save(e){if(!this._data)return;let t=this.getStoreKey();G.setDoc(e,t,this._data)}getData(){return this._data}setData(e){this._data=e}async update(e,t){let n=await this.load(e),r=t(n);return this._data=r,await this.save(e),r}isLoaded(e){return e?this._loaded&&this._projectId===e:this._loaded}reset(){this._data=null,this._loaded=!1,this._projectId=null}},pr=class{static{l(this,"SessionStore")}_sessionMemory=new Map;setSession(e,t){this._sessionMemory.set(e,{value:t,timestamp:Date.now()})}getSession(e){return this._sessionMemory.get(e)?.value}clearSession(){this._sessionMemory.clear()}},mr=class{static{l(this,"HistoryStore")}async appendHistory(e,t){let n={ts:b(),...t,type:t.type};G.appendEvent(e,`history.${t.type}`,n)}async getRecentHistory(e,t=20){return G.query(e,"SELECT data, timestamp FROM events WHERE type LIKE 'history.%' ORDER BY id DESC LIMIT ?",t).reverse().map(r=>JSON.parse(r.data))}}});var fr,Da=k(()=>{"use strict";oe();ms();ce();gr();fr=class s extends _n{static{l(this,"PatternStore")}static MAX_CONTEXTS=20;static ARCHIVE_AGE_DAYS=90;getFilename(){return"patterns.json"}getDefault(){return{version:1,decisions:{},preferences:{},workflows:{},counters:{}}}afterLoad(e){for(let t of Object.values(e.decisions))t.contexts.length>s.MAX_CONTEXTS&&(t.contexts=t.contexts.slice(-s.MAX_CONTEXTS))}async loadPatterns(e){return this.load(e)}async savePatterns(e){return this.save(e)}async recordDecision(e,t,n,r="",o={}){let i=await this.load(e),a=b();if(!i.decisions[t])i.decisions[t]={value:n,count:1,firstSeen:a,lastSeen:a,confidence:o.userConfirmed?"high":"low",contexts:[r].filter(Boolean),userConfirmed:o.userConfirmed||!1};else{let c=i.decisions[t];c.value===n?(c.count++,c.lastSeen=a,r&&!c.contexts.includes(r)&&(c.contexts.push(r),c.contexts.length>s.MAX_CONTEXTS&&(c.contexts=c.contexts.slice(-s.MAX_CONTEXTS))),o.userConfirmed&&(c.userConfirmed=!0),c.confidence=ao(c.count,c.userConfirmed)):(c.value=n,c.count=1,c.lastSeen=a,c.userConfirmed=o.userConfirmed||!1,c.confidence=o.userConfirmed?"high":"low")}await this.save(e)}async confirmDecision(e,t){let r=(await this.load(e)).decisions[t];return r?(r.userConfirmed=!0,r.confidence="high",r.lastSeen=b(),await this.save(e),!0):!1}async getDecision(e,t){let r=(await this.load(e)).decisions[t];return!r||r.confidence==="low"?null:{value:r.value,confidence:r.confidence}}async hasPattern(e,t){return await this.getDecision(e,t)!==null}async recordWorkflow(e,t,n){let r=await this.load(e),o=b();if(!r.workflows[t])r.workflows[t]={...n,count:1,firstSeen:o,lastSeen:o,confidence:"low",userConfirmed:!1};else{let i=r.workflows[t];i.count++,i.lastSeen=o,i.confidence=ao(i.count,i.userConfirmed)}await this.save(e)}async confirmWorkflow(e,t){let r=(await this.load(e)).workflows[t];return r?(r.userConfirmed=!0,r.confidence="high",r.lastSeen=b(),await this.save(e),!0):!1}async getWorkflow(e,t){let r=(await this.load(e)).workflows[t];return!r||r.count<3?null:r}async setPreference(e,t,n,r={}){let o=await this.load(e),i=o.preferences[t],a=i?i.observationCount+1:1,c=r.userConfirmed||i?.userConfirmed||!1;o.preferences[t]={value:n,updatedAt:b(),confidence:ao(a,c),observationCount:a,userConfirmed:c},await this.save(e)}async confirmPreference(e,t){let r=(await this.load(e)).preferences[t];return r?(r.userConfirmed=!0,r.confidence="high",r.updatedAt=b(),await this.save(e),!0):!1}async getPreference(e,t,n=null){return(await this.load(e)).preferences[t]?.value??n}async getPatternsSummary(e){let t=await this.load(e);return{decisions:Object.keys(t.decisions).length,learnedDecisions:Object.values(t.decisions).filter(n=>n.confidence!=="low").length,workflows:Object.keys(t.workflows).length,preferences:Object.keys(t.preferences).length}}async archiveStaleDecisions(e){let t=await this.load(e),n=Date.now(),r=s.ARCHIVE_AGE_DAYS*24*60*60*1e3,o=[];for(let[a,c]of Object.entries(t.decisions)){let u=new Date(c.lastSeen).getTime();n-u>r&&o.push(a)}if(o.length===0)return 0;let i=G.getDoc(e,"memory:patterns-archive")??{};for(let a of o)i[a]=t.decisions[a],delete t.decisions[a];return G.setDoc(e,"memory:patterns-archive",i),await this.save(e),o.length}}});var xd=k(()=>{"use strict"});import hr from"node:fs/promises";import Sn from"node:path";import{z as K}from"zod";async function Pw(s,e){let t=Date.now();if(s.frameworks.length===0)return{name:"Framework verification",passed:!0,output:"No frameworks declared (skipped)",durationMs:Date.now()-t};try{let n=Sn.join(e,"package.json"),r=await hr.readFile(n,"utf-8"),o=JSON.parse(r),i={...o.dependencies,...o.devDependencies},a=[],c=[];for(let u of s.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(n){return C(n)?{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: ${n instanceof Error?n.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Cw(s,e){let t=Date.now();if(s.languages.length===0)return{name:"Language verification",passed:!0,output:"No languages declared (skipped)",durationMs:Date.now()-t};try{let n=await Aw(e),r=new Set(n),o=[],i=[];for(let a of s.languages){let c=vw[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(n){return{name:"Language verification",passed:!1,error:`Failed to scan project files: ${n instanceof Error?n.message:"unknown error"}`,durationMs:Date.now()-t}}}async function xw(s,e){let t=Date.now(),n=s.patterns.filter(i=>i.location);if(n.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 n){let a=i.location,c=Sn.join(e,a);try{await hr.access(c),o.push(a)}catch{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(s,e){let t=Date.now();try{let n=await Rw(e),r=s.fileCount,o=.1,i=Math.abs(n-r),a=r*o;return i<=a?{name:"File count verification",passed:!0,output:`File count accurate (declared: ${r}, actual: ${n})`,durationMs:Date.now()-t}:{name:"File count verification",passed:!1,error:`File count mismatch: declared ${r}, actual ${n} (diff: ${i})`,durationMs:Date.now()-t}}catch(n){return{name:"File count verification",passed:!1,error:`Failed to count files: ${n instanceof Error?n.message:"unknown error"}`,durationMs:Date.now()-t}}}async function Ew(s,e){let t=Date.now();if(s.antiPatterns.length===0)return{name:"Anti-pattern file verification",passed:!0,output:"No anti-patterns declared (skipped)",durationMs:Date.now()-t};let n=[],r=[];for(let o of s.antiPatterns){let i=Sn.join(e,o.file);try{await hr.access(i),r.push(o.file)}catch{n.push(`${o.issue} (${o.file})`)}}return n.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: ${n.join(", ")}`,durationMs:Date.now()-t}}async function Td(s,e){let t=Date.now(),n=await Promise.all([Pw(s,e),Cw(s,e),xw(s,e),Tw(s,e),Ew(s,e)]),r=n.filter(i=>!i.passed).length,o=n.filter(i=>i.passed).length;return{passed:r===0,checks:n,totalMs:Date.now()-t,failedCount:r,passedCount:o}}async function Aw(s){let e=new Set,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function n(r){try{let o=await hr.readdir(r,{withFileTypes:!0});for(let i of o){let a=Sn.join(r,i.name),c=Sn.relative(s,a);if(!t.some(u=>u.test(c))){if(i.isDirectory())await n(a);else if(i.isFile()){let u=Sn.extname(i.name);u&&e.add(u)}}}}catch{}}return l(n,"scanDir"),await n(s),Array.from(e)}async function Rw(s){let e=0,t=[/node_modules/,/\.git/,/dist/,/build/,/\.next/,/\.turbo/,/coverage/];async function n(r){try{let o=await hr.readdir(r,{withFileTypes:!0});for(let i of o){let a=Sn.join(r,i.name),c=Sn.relative(s,a);t.some(u=>u.test(c))||(i.isDirectory()?await n(a):i.isFile()&&e++)}}catch{}}return l(n,"scanDir"),await n(s),e}var Sw,kw,bw,ja,sR,vw,Ia=k(()=>{"use strict";L();lr();Sw=K.enum(["draft","verified","sealed"]),kw=K.object({name:K.string(),description:K.string(),location:K.string().optional(),severity:K.enum(["low","medium","high"]).optional(),language:K.string().optional(),framework:K.string().optional(),source:K.enum(["baseline","repo","context7","feedback"]).optional(),confidence:K.number().min(0).max(1).optional()}),bw=K.object({issue:K.string(),file:K.string(),suggestion:K.string(),severity:K.enum(["low","medium","high"]).optional(),language:K.string().optional(),framework:K.string().optional(),source:K.enum(["baseline","repo","context7","feedback"]).optional(),confidence:K.number().min(0).max(1).optional()}),ja=K.object({projectId:K.string(),languages:K.array(K.string()),frameworks:K.array(K.string()),packageManager:K.string().optional(),sourceDir:K.string().optional(),testDir:K.string().optional(),configFiles:K.array(K.string()),fileCount:K.number(),patterns:K.array(kw),antiPatterns:K.array(bw),analyzedAt:K.string(),modelMetadata:hs.optional(),status:Sw.default("draft"),commitHash:K.string().optional(),signature:K.string().optional(),sealedAt:K.string().optional(),verifiedAt:K.string().optional()}),sR={languages:[],frameworks:[],configFiles:[],fileCount:0,patterns:[],antiPatterns:[],analyzedAt:new Date().toISOString(),status:"draft"},vw={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(Pw,"verifyFrameworks");l(Cw,"verifyLanguages");l(xw,"verifyPatternLocations");l(Tw,"verifyFileCount");l(Ew,"verifyAntiPatternFiles");l(Td,"semanticVerify");l(Aw,"getProjectExtensions");l(Rw,"countProjectFiles")});import{z as _e}from"zod";var ho,kn,Dw,aR,$a,Ed,yr=k(()=>{"use strict";ho=_e.enum(["frontend","backend","database","devops","testing","docs","uxui","general"]),kn=_e.object({primaryDomain:ho,secondaryDomains:_e.array(ho),confidence:_e.number().min(0).max(1),filePatterns:_e.array(_e.string()),relevantAgents:_e.array(_e.string())}),Dw=_e.object({classification:kn,classifiedAt:_e.string(),source:_e.enum(["cache","history","llm","heuristic"]),descriptionHash:_e.string(),projectId:_e.string()}),aR=_e.object({entries:_e.record(_e.string(),Dw),confirmedPatterns:_e.array(_e.object({descriptionHash:_e.string(),classification:kn,confirmedAt:_e.string(),taskDescription:_e.string()}))}),$a={entries:{},confirmedPatterns:[]},Ed={primaryDomain:"general",secondaryDomains:[],confidence:.3,filePatterns:["**/*.ts","**/*.js"],relevantAgents:[]}});import{z}from"zod";var jw,Iw,Ad,$w,Mw,Ow,Fw,_w,Rd,uR,Ma=k(()=>{"use strict";jw=z.enum(["low","medium","high"]),Iw=z.enum(["pending","converted","completed","archived","dormant"]),Ad=z.enum(["high","medium","low"]),$w=z.object({impact:Ad,effort:Ad}),Mw=z.object({frontend:z.string().optional(),backend:z.string().optional(),payments:z.string().optional(),ai:z.string().optional(),deploy:z.string().optional(),other:z.array(z.string()).optional()}),Ow=z.object({name:z.string(),description:z.string()}),Fw=z.object({name:z.string(),description:z.string().optional()}),_w=z.object({id:z.string(),text:z.string(),details:z.string().optional(),priority:jw,status:Iw,tags:z.array(z.string()),addedAt:z.string(),completedAt:z.string().optional(),convertedTo:z.string().optional(),source:z.string().optional(),sourceFiles:z.array(z.string()).optional(),painPoints:z.array(z.string()).optional(),solutions:z.array(z.string()).optional(),filesAffected:z.array(z.string()).optional(),impactEffort:$w.optional(),implementationNotes:z.string().optional(),stack:Mw.optional(),modules:z.array(Ow).optional(),roles:z.array(Fw).optional(),risks:z.array(z.string()).optional(),risksCount:z.number().optional()}),Rd=z.object({ideas:z.array(_w),lastUpdated:z.string()}),uR={priority:"medium",status:"pending",tags:[],addedAt:new Date().toISOString()}});import{z as q}from"zod";var Dd,Nw,Lw,Uw,Hw,gR,fR,jd=k(()=>{"use strict";Dd=q.enum(["linear","jira","github","monday","asana","none"]),Nw=q.enum(["backlog","todo","in_progress","in_review","done","cancelled"]),Lw=q.enum(["none","urgent","high","medium","low"]),Uw=q.enum(["feature","bug","improvement","task","chore","epic"]),Hw=q.object({id:q.string(),identifier:q.string(),title:q.string(),description:q.string().optional(),status:Nw,priority:Lw,type:Uw.optional(),assignee:q.object({id:q.string(),name:q.string(),email:q.string().optional()}).optional(),labels:q.array(q.string()).default([]),team:q.object({id:q.string(),name:q.string(),key:q.string().optional()}).optional(),project:q.object({id:q.string(),name:q.string()}).optional(),url:q.string(),createdAt:q.string(),updatedAt:q.string(),fetchedAt:q.string()}),gR=q.object({provider:Dd,lastSync:q.string(),staleAfter:q.number().default(18e5),issues:q.record(q.string(),Hw)}),fR=q.object({provider:Dd,fetched:q.number(),updated:q.number(),errors:q.array(q.object({issueId:q.string(),error:q.string()})),timestamp:q.string()})});var Fd={};hn(Fd,{AgentAssignmentSchema:()=>Id,OUTPUT_SCHEMAS:()=>Md,SubtaskBreakdownSchema:()=>$d,TaskClassificationSchema:()=>kn,renderSchemaForPrompt:()=>Oa});import{z as Ke}from"zod";function Oa(s){let e=Md[s];return e?`## OUTPUT FORMAT
|
|
347
347
|
|
|
348
348
|
Return ONLY valid JSON matching this schema (no markdown, no explanation):
|
|
349
349
|
|
|
@@ -352,15 +352,15 @@ ${e.example}
|
|
|
352
352
|
\`\`\`
|
|
353
353
|
|
|
354
354
|
Fields:
|
|
355
|
-
${
|
|
356
|
-
`)}return"(see example above)"}function Bd(r){return r instanceof Ke.ZodString?"string":r instanceof Ke.ZodNumber?"number":r instanceof Ke.ZodEnum?`one of: ${r.options.join(", ")}`:r instanceof Ke.ZodArray?`array of ${Bd(r.element)}`:r instanceof Ke.ZodObject?"object":"any"}var zd,Wd,Vd,ko=k(()=>{"use strict";vr();vr();zd=Ke.object({agentName:Ke.string(),reasoning:Ke.string(),confidence:Ke.number().min(0).max(1)}),Wd=Ke.object({subtasks:Ke.array(Ke.object({description:Ke.string(),domain:So,agent:Ke.string(),dependsOn:Ke.array(Ke.number())})),effort:Ke.enum(["low","medium","high"])}),Vd={classification:{schema:Cn,example:JSON.stringify({primaryDomain:"backend",secondaryDomains:["database"],confidence:.9,filePatterns:["src/api/**"],relevantAgents:["backend.md"]},null,2)},agentAssignment:{schema:zd,example:JSON.stringify({agentName:"backend.md",reasoning:"Task involves API endpoint creation",confidence:.85},null,2)},subtaskBreakdown:{schema:Wd,example:JSON.stringify({subtasks:[{description:"Add schema validation",domain:"backend",agent:"backend.md",dependsOn:[]},{description:"Add unit tests",domain:"testing",agent:"testing.md",dependsOn:[0]}],effort:"medium"},null,2)}};l(Ja,"renderSchemaForPrompt");l(eS,"describeSchema");l(Bd,"describeField")});import{z as I}from"zod";var qd,tS,nS,Kd,sS,rS,oS,iS,aS,cS,lS,Xd,uS,dS,BI,Yd,Qd,Zd,ep,pS,bo,qa=k(()=>{"use strict";qd=I.number().min(1).max(5),tS=I.enum(["exceeded","met","partial","failed"]),nS=I.enum(["definitely","probably","maybe","no"]),Kd=I.enum(["scope_creep","underestimated_complexity","technical_debt","external_blockers","learning_curve","requirements_changed","optimistic_estimate","team_changes","other"]),sS=I.object({estimated:I.object({hours:I.number(),confidence:I.enum(["low","medium","high"]).optional(),source:I.enum(["prd","manual","historical"]).optional()}),actual:I.object({hours:I.number(),commits:I.number().optional(),linesAdded:I.number().optional(),linesRemoved:I.number().optional(),sessions:I.number().optional()}),variance:I.object({hours:I.number(),percentage:I.number(),reason:Kd.optional(),explanation:I.string().optional()})}),rS=I.object({name:I.string(),baseline:I.number().nullable(),target:I.number(),actual:I.number(),unit:I.string(),achieved:I.boolean(),percentOfTarget:I.number()}),oS=I.object({criteria:I.string(),met:I.boolean(),notes:I.string().optional()}),iS=I.object({metrics:I.array(rS),acceptanceCriteria:I.array(oS),overallSuccess:tS,successScore:I.number().min(0).max(100)}),aS=I.object({category:I.enum(["estimation","technical","process","communication","tooling","architecture","testing","other"]),insight:I.string(),actionable:I.boolean(),action:I.string().optional()}),cS=I.object({whatWorked:I.array(I.string()),whatDidnt:I.array(I.string()),surprises:I.array(I.string()),recommendations:I.array(aS)}),lS=I.object({valueDelivered:I.number().min(1).max(10),userImpact:I.enum(["none","low","medium","high","critical"]),businessImpact:I.enum(["none","low","medium","high","critical"]),roiScore:I.number(),worthIt:nS,worthItReason:I.string().optional(),alternativeConsidered:I.string().optional(),betterAlternativeExists:I.boolean().optional()}),Xd=I.object({id:I.string(),taskId:I.string(),description:I.string(),estimatedMinutes:I.number().optional(),actualMinutes:I.number(),completedAsPlanned:I.boolean(),qualityScore:qd,blockers:I.array(I.string()),agentUsed:I.string().optional(),skillsUsed:I.array(I.string()).optional(),startedAt:I.string(),completedAt:I.string()}),uS=I.object({id:I.string(),featureId:I.string(),featureName:I.string(),prdId:I.string().nullable(),version:I.string().optional(),branch:I.string().optional(),prUrl:I.string().optional(),effort:sS,success:iS.optional(),learnings:cS,roi:lS,rating:qd,taskOutcomes:I.array(Xd).optional(),startedAt:I.string(),shippedAt:I.string(),reviewedAt:I.string().optional(),reviewedBy:I.string().optional(),legacy:I.boolean().optional()}),dS=I.object({totalFeatures:I.number(),averageEstimationAccuracy:I.number(),averageSuccessRate:I.number(),averageROI:I.number(),bySuccessLevel:I.object({exceeded:I.number(),met:I.number(),partial:I.number(),failed:I.number()}),variancePatterns:I.array(I.object({reason:Kd,count:I.number(),averageVariance:I.number()})),topLearnings:I.array(I.object({insight:I.string(),frequency:I.number()}))}),BI=I.object({outcomes:I.array(uS),taskOutcomes:I.array(Xd).optional(),aggregates:dS.optional(),lastUpdated:I.string(),lastAggregated:I.string().optional()}),Yd={outcomes:[],taskOutcomes:[],lastUpdated:""},Qd=l((r,e)=>{let t=e-r,n=r>0?(e-r)/r*100:0;return{hours:t,percentage:Math.round(n*10)/10}},"calculateVariance"),Zd=l((r,e)=>e<=0?r*10:Math.round(r*10/e*100)/100,"calculateROIScore"),ep=l(r=>r>=100?"exceeded":r>=80?"met":r>=50?"partial":"failed","determineSuccessLevel"),pS=l(r=>Math.max(0,100-Math.abs(r)),"calculateEstimationAccuracy"),bo=l(r=>{if(r.length===0)return{totalFeatures:0,averageEstimationAccuracy:0,averageSuccessRate:0,averageROI:0,bySuccessLevel:{exceeded:0,met:0,partial:0,failed:0},variancePatterns:[],topLearnings:[]};let e=r.map(d=>pS(d.effort.variance.percentage)),t=r.filter(d=>d.success).map(d=>d.success.successScore),n=r.map(d=>d.roi.roiScore),s={exceeded:r.filter(d=>d.success?.overallSuccess==="exceeded").length,met:r.filter(d=>d.success?.overallSuccess==="met").length,partial:r.filter(d=>d.success?.overallSuccess==="partial").length,failed:r.filter(d=>d.success?.overallSuccess==="failed").length},o=r.filter(d=>d.effort.variance.reason).reduce((d,m)=>{let p=m.effort.variance.reason;return d[p]||(d[p]={count:0,totalVariance:0}),d[p].count++,d[p].totalVariance+=m.effort.variance.percentage,d},{}),i=Object.entries(o).map(([d,m])=>({reason:d,count:m.count,averageVariance:Math.round(m.totalVariance/m.count)})),c=r.flatMap(d=>[...d.learnings.whatWorked,...d.learnings.whatDidnt]).reduce((d,m)=>(d[m]=(d[m]||0)+1,d),{}),u=Object.entries(c).sort((d,m)=>m[1]-d[1]).slice(0,10).map(([d,m])=>({insight:d,frequency:m}));return{totalFeatures:r.length,averageEstimationAccuracy:Math.round(e.reduce((d,m)=>d+m,0)/e.length),averageSuccessRate:t.length>0?Math.round(t.reduce((d,m)=>d+m,0)/t.length):0,averageROI:Math.round(n.reduce((d,m)=>d+m,0)/n.length*100)/100,bySuccessLevel:s,variancePatterns:i,topLearnings:u}},"aggregateOutcomes")});import{z as Ve}from"zod";function wS(){let r={};for(let e of fS)r[e]="allow";for(let e of hS)r[e]="ask";for(let e of yS)r[e]="deny";return{bash:r,files:{read:{"**/*":"allow"},write:{"**/*":"allow"},delete:{"**/*":"ask"}},web:{enabled:!0},doomLoop:{enabled:!0,maxRetries:3},externalDirectories:"ask"}}var vo,XI,mS,Ka,gS,YI,fS,hS,yS,QI,tp=k(()=>{"use strict";vo=Ve.enum(["allow","deny","ask"]),XI=Ve.enum(["read","write","delete","create"]),mS=Ve.record(Ve.string(),vo),Ka=Ve.record(Ve.string(),vo),gS=Ve.object({enabled:Ve.boolean().default(!0),allowedDomains:Ve.array(Ve.string()).optional(),blockedDomains:Ve.array(Ve.string()).optional()}),YI=Ve.object({bash:mS.optional(),files:Ve.object({read:Ka.optional(),write:Ka.optional(),delete:Ka.optional()}).optional(),web:gS.optional(),skills:Ve.record(Ve.string(),vo).optional(),doomLoop:Ve.object({enabled:Ve.boolean().default(!0),maxRetries:Ve.number().default(3)}).optional(),externalDirectories:vo.default("ask")}),fS=["git status*","git log*","git diff*","git branch*","git remote*","ls*","pwd","cat*","head*","tail*","grep*","find*","which*","echo*","node -e*","bun -e*","npm list*","npm view*","npx tsc --noEmit*"],hS=["rm -rf*","rm -r*","git push*","git reset --hard*","git clean*","npm publish*","chmod*","chown*","sudo*","curl*|*sh","wget*|*sh"],yS=["rm -rf /*","rm -rf ~/*",":(){ :|:& };:*","mkfs*","dd if=*of=/dev/*"];l(wS,"buildDefaultPermissions");QI=wS()});import{z as gt}from"zod";var nR,sR,np=k(()=>{"use strict";nR=gt.object({projectId:gt.string(),name:gt.string(),repoPath:gt.string(),description:gt.string().optional(),version:gt.string().optional(),cliVersion:gt.string().optional(),techStack:gt.array(gt.string()),fileCount:gt.number(),commitCount:gt.number(),createdAt:gt.string(),lastSync:gt.string(),lastSyncCommit:gt.string().optional(),lastSyncBranch:gt.string().optional()}),sR={techStack:[],fileCount:0,commitCount:0,createdAt:new Date().toISOString(),lastSync:new Date().toISOString()}});import{z as R}from"zod";var SS,kS,bS,vS,PS,CS,xS,TS,ES,AS,IS,RS,DS,jS,$S,MS,OS,_S,aR,cR,sp=k(()=>{"use strict";SS=R.enum(["planned","active","completed","shipped"]),kS=R.enum(["low","medium","high"]),bS=R.enum(["feature","breaking_change","refactor","infrastructure"]),vS=R.enum(["completed","active","planned"]),PS=R.enum(["planned","active","completed"]),CS=R.enum(["git","git-branch","manual","prd"]),xS=R.object({id:R.string(),description:R.string(),completed:R.boolean(),completedAt:R.string().optional()}),TS=R.object({id:R.string(),name:R.string(),status:vS,completedAt:R.string().optional()}),ES=R.object({goal:R.string(),phases:R.array(TS),successMetrics:R.array(R.string()).optional()}),AS=R.object({hours:R.number(),minutes:R.number(),totalMinutes:R.number(),display:R.string().optional()}),IS=R.object({hash:R.string(),message:R.string(),date:R.string(),author:R.string().optional()}),RS=R.object({hours:R.number(),confidence:R.enum(["low","medium","high"]).optional(),breakdown:R.array(R.object({area:R.string(),hours:R.number()})).optional()}),DS=R.object({hours:R.number().optional(),commits:R.number().optional(),linesAdded:R.number().optional(),linesRemoved:R.number().optional()}),jS=R.object({estimated:RS.nullable(),actual:DS.nullable()}),$S=R.object({totalHours:R.number(),allocatedHours:R.number(),bufferPercent:R.number().optional()}),MS=R.object({id:R.string(),name:R.string(),theme:R.string().optional(),goals:R.array(R.string()).optional(),features:R.array(R.string()),capacity:$S.optional(),status:PS,startDate:R.string().optional(),endDate:R.string().optional()}),OS=R.object({id:R.string(),name:R.string(),description:R.string().optional(),date:R.string(),status:SS,impact:kS,effort:R.string().optional(),progress:R.number(),type:bS.optional(),roi:R.number().optional(),why:R.array(R.string()).optional(),technicalNotes:R.array(R.string()).optional(),compatibility:R.string().optional(),phase:R.string().optional(),tasks:R.array(xS),createdAt:R.string(),shippedAt:R.string().optional(),version:R.string().optional(),duration:AS.optional(),taskCount:R.number().optional(),agent:R.string().optional(),sprintName:R.string().optional(),completedDate:R.string().optional(),prdId:R.string().nullable().optional(),legacy:R.boolean().optional(),inferredFrom:CS.optional(),quarter:R.string().nullable().optional(),dependencies:R.array(R.string()).optional(),blockedBy:R.array(R.string()).optional(),effortTracking:jS.optional(),valueScore:R.number().optional(),commits:R.array(IS).optional(),branch:R.string().optional(),commitsAhead:R.number().optional()}),_S=R.object({id:R.string(),title:R.string(),prdId:R.string().nullable().optional(),valueScore:R.number().optional(),effortEstimate:R.number().optional(),reason:R.string().optional()}),aR=R.object({strategy:ES.nullable().optional(),features:R.array(OS),backlog:R.array(R.union([R.string(),_S])),lastUpdated:R.string(),quarters:R.array(MS).optional(),generatedFrom:R.enum(["git-history","manual","prd"]).optional(),generatedAt:R.string().optional()}),cR={date:new Date().toISOString().split("T")[0],status:"planned",impact:"medium",progress:0,tasks:[],createdAt:new Date().toISOString(),prdId:null,legacy:!1,quarter:null}});import FS from"node:crypto";import{homedir as NS}from"node:os";import{join as LS}from"node:path";function me(){return FS.randomUUID()}var US,rp=k(()=>{"use strict";l(me,"generateUUID");US=LS(NS(),".prjct-cli","projects")});import{z as at}from"zod";var yR,op=k(()=>{"use strict";yR=at.object({sessionId:at.string(),projectId:at.string(),projectPath:at.string(),projectName:at.string().optional(),taskDescription:at.string(),taskStatus:at.enum(["active","paused"]),activeSubtaskIndex:at.number().optional(),subtaskCount:at.number().optional(),branch:at.string().optional(),linearId:at.string().optional(),filesModified:at.array(at.string()).optional(),durationWorkedSec:at.number().optional(),timestamp:at.string(),resumeHint:at.string()})});import{z as Y}from"zod";var HS,ip,GS,zS,WS,VS,BS,JS,qS,ap,Xa=k(()=>{"use strict";HS=Y.enum(["feature","fix","improvement","refactor"]),ip=Y.enum(["pass","warning","fail","skipped"]),GS=Y.enum(["added","changed","fixed","removed"]),zS=Y.object({hours:Y.number(),minutes:Y.number(),totalMinutes:Y.number()}),WS=Y.object({filesChanged:Y.number().nullable().optional(),linesAdded:Y.number().nullable().optional(),linesRemoved:Y.number().nullable().optional(),commits:Y.number().nullable().optional()}),VS=Y.object({description:Y.string(),type:GS.optional()}),BS=Y.object({lintStatus:ip.nullable().optional(),lintDetails:Y.string().optional(),testStatus:ip.nullable().optional(),testDetails:Y.string().optional()}),JS=Y.object({hash:Y.string().optional(),message:Y.string().optional(),branch:Y.string().optional()}),qS=Y.object({id:Y.string(),name:Y.string(),version:Y.string().nullable().optional(),type:HS,agent:Y.string().optional(),description:Y.string().optional(),changes:Y.array(VS).optional(),codeSnippets:Y.array(Y.string()).optional(),commit:JS.optional(),codeMetrics:WS.optional(),qualityMetrics:BS.optional(),quantitativeImpact:Y.string().optional(),duration:zS.optional(),tasksCompleted:Y.number().nullable().optional(),shippedAt:Y.string(),featureId:Y.string().optional()}),ap=Y.object({shipped:Y.array(qS),lastUpdated:Y.string()})});import{z as x}from"zod";var KS,Po,XS,YS,QS,Ya,lp,up,dp,pp,cp,ZS,ek,mp,gp,fp,tk,nk,CR,Co=k(()=>{"use strict";gr();KS=x.enum(["low","medium","high","critical"]),Po=x.enum(["feature","bug","improvement","chore"]),XS=x.enum(["active","backlog","previously_active"]),YS=x.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),QS=x.enum(["task_completed","feature_shipped","idea_captured","session_started"]),Ya=x.object({title:x.string(),description:x.string(),filesChanged:x.array(x.object({path:x.string(),action:x.enum(["created","modified","deleted"])})),whatWasDone:x.array(x.string()).min(1),outputForNextAgent:x.string().min(1),notes:x.string().optional()}),lp=x.object({output:x.string().min(1,"Subtask output is required"),summary:Ya}),up=x.object({id:x.string(),description:x.string(),domain:x.string(),agent:x.string(),status:YS,dependsOn:x.array(x.string()),startedAt:x.string().optional(),completedAt:x.string().optional(),output:x.string().optional(),summary:Ya.optional(),skipReason:x.string().optional(),blockReason:x.string().optional(),estimatedPoints:x.number().optional(),estimatedMinutes:x.number().optional()}),dp=x.object({completed:x.number(),total:x.number(),percentage:x.number()}),pp=x.object({id:x.string(),description:x.string(),type:Po.optional(),startedAt:x.string(),sessionId:x.string(),featureId:x.string().optional(),subtasks:x.array(up).optional(),currentSubtaskIndex:x.number().optional(),subtaskProgress:dp.optional(),linearId:x.string().optional(),linearUuid:x.string().optional(),estimatedPoints:x.number().optional(),estimatedMinutes:x.number().optional(),modelMetadata:Ss.optional()}),cp=x.object({id:x.string(),description:x.string(),status:x.literal("paused"),startedAt:x.string(),pausedAt:x.string(),pauseReason:x.string().optional(),type:Po.optional(),sessionId:x.string().optional(),featureId:x.string().optional(),subtasks:x.array(up).optional(),currentSubtaskIndex:x.number().optional(),subtaskProgress:dp.optional(),linearId:x.string().optional(),linearUuid:x.string().optional(),estimatedPoints:x.number().optional(),estimatedMinutes:x.number().optional(),modelMetadata:Ss.optional()}),ZS=x.object({stackConfirmed:x.array(x.string()).optional(),patternsDiscovered:x.array(x.string()).optional(),agentAccuracy:x.array(x.object({agent:x.string(),rating:x.enum(["helpful","neutral","inaccurate"]),note:x.string().optional()})).optional(),issuesEncountered:x.array(x.string()).optional()}),ek=x.object({taskId:x.string(),title:x.string(),classification:Po,startedAt:x.string(),completedAt:x.string(),subtaskCount:x.number(),subtaskSummaries:x.array(Ya),outcome:x.string(),branchName:x.string(),linearId:x.string().optional(),linearUuid:x.string().optional(),prUrl:x.string().optional(),feedback:ZS.optional()}),mp=x.object({currentTask:pp.nullable(),previousTask:cp.nullable().optional(),pausedTasks:x.array(cp).optional(),taskHistory:x.array(ek).optional(),lastUpdated:x.string()}),gp=x.object({id:x.string(),description:x.string(),priority:KS,type:Po,featureId:x.string().optional(),originFeature:x.string().optional(),completed:x.boolean(),completedAt:x.string().optional(),createdAt:x.string(),section:XS,agent:x.string().optional(),groupName:x.string().optional(),groupId:x.string().optional()}),fp=x.object({tasks:x.array(gp),lastUpdated:x.string()}),tk=x.object({tasksToday:x.number(),tasksThisWeek:x.number(),streak:x.number(),velocity:x.string(),avgDuration:x.string()}),nk=x.object({type:QS,description:x.string(),timestamp:x.string(),duration:x.string().optional()}),CR=x.object({projectId:x.string(),currentTask:pp.nullable(),queue:x.array(gp),stats:tk,recentActivity:x.array(nk),lastSync:x.string()})});import{z as le}from"zod";var sk,rk,hp,AR,IR,RR,xn,yp,ks=k(()=>{"use strict";sk=le.enum(["improving","stable","declining"]),rk=le.object({sprintNumber:le.number(),startDate:le.string(),endDate:le.string(),pointsCompleted:le.number(),tasksCompleted:le.number(),avgVariance:le.number(),estimationAccuracy:le.number()}),hp=le.object({category:le.string(),avgVariance:le.number(),taskCount:le.number()}),AR=le.object({totalPoints:le.number(),sprints:le.number(),estimatedDate:le.string()}),IR=le.object({sprints:le.array(rk),averageVelocity:le.number(),velocityTrend:sk,estimationAccuracy:le.number(),overEstimated:le.array(hp),underEstimated:le.array(hp),lastUpdated:le.string()}),RR=le.object({sprintLengthDays:le.number().min(1).max(90).default(7),startDay:le.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:le.number().min(1).max(52).default(6),accuracyTolerance:le.number().min(0).max(100).default(20)}),xn={sprintLengthDays:7,startDay:"monday",windowSize:6,accuracyTolerance:20},yp={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var Dt=k(()=>{"use strict";_d();za();vr();Va();Ba();ko();gr();qa();tp();np();sp();rp();op();Xa();Co();ks()});var Gn,Qa=k(()=>{"use strict";Dt();hs();ce();Sr();Gn=class extends Hn{static{l(this,"SemanticMemories")}getFilename(){return"memories.json"}getDefault(){return{version:1,memories:[],index:this._createEmptyIndex()}}afterLoad(e){this._normalizeIndex(e)}_createEmptyIndex(){let e=Object.values(O),t={};for(let n of e)t[n]=[];return t}_normalizeIndex(e){let t=Object.values(O);for(let n of t)e.index[n]||(e.index[n]=[])}_coerceTags(e){let t=new Set(Object.values(O));return e.filter(n=>t.has(n))}async loadMemories(e){return this.load(e)}async saveMemories(e){return this.save(e)}async createMemory(e,{title:t,content:n,tags:s=[],userTriggered:o=!1}){let i=await this.load(e),a=this._coerceTags(s),c=b(),u={id:me(),title:t,content:n,tags:a,userTriggered:o,createdAt:c,updatedAt:c};i.memories.push(u);for(let d of a)i.index[d].push(u.id);return await this.save(e),u.id}async updateMemory(e,t,n){let s=await this.load(e),o=s.memories.findIndex(c=>c.id===t);if(o===-1)return!1;let i=s.memories[o],a=i.tags||[];if(n.title&&(i.title=n.title),n.content&&(i.content=n.content),n.tags){let c=this._coerceTags(n.tags);for(let u of a)s.index[u]=s.index[u].filter(d=>d!==t);for(let u of c)s.index[u].push(t);i.tags=c}return i.updatedAt=b(),await this.save(e),!0}async deleteMemory(e,t){let n=await this.load(e),s=n.memories.findIndex(i=>i.id===t);if(s===-1)return!1;let o=n.memories[s];for(let i of o.tags||[])n.index[i]&&(n.index[i]=n.index[i].filter(a=>a!==t));return n.memories.splice(s,1),await this.save(e),!0}async findByTags(e,t,n=!1){let s=await this.load(e),o=this._coerceTags(t);if(n)return s.memories.filter(i=>o.every(a=>(i.tags||[]).includes(a)));{let i=new Set;for(let a of o){let c=s.index[a];for(let u of c)i.add(u)}return s.memories.filter(a=>i.has(a.id))}}async searchMemories(e,t){let n=await this.load(e),s=t.toLowerCase();return n.memories.filter(o=>o.title.toLowerCase().includes(s)||o.content.toLowerCase().includes(s))}async getRelevantMemories(e,t,n=5){return(await this.load(e)).memories.map(i=>{let a=0,c=this._extractContextTags(t);for(let p of i.tags||[])c.includes(p)&&(a+=10);let d=(Date.now()-new Date(i.updatedAt).getTime())/(1e3*60*60*24);a+=Math.max(0,5-d),i.userTriggered&&(a+=5);let m=this._extractKeywords(t);for(let p of m)i.content.toLowerCase().includes(p)&&(a+=2),i.title.toLowerCase().includes(p)&&(a+=3);return{...i,_score:a}}).filter(i=>i._score>0).sort((i,a)=>a._score-i._score).slice(0,n).map(({_score:i,...a})=>a)}async getRelevantMemoriesWithMetrics(e,t){let n=await this.load(e),s=n.memories.length;if(s===0)return{memories:[],metrics:{totalMemories:0,memoriesConsidered:0,memoriesReturned:0,filteringRatio:0,avgRelevanceScore:0}};let o=t.maxResults??10,i=t.minRelevance??10,c=n.memories.map(p=>{let g={domainMatch:0,tagMatch:0,recency:0,confidence:0,keywords:0,userTriggered:0};if(t.taskDomain&&(g.domainMatch=this._getSemanticDomainScore(t.taskDomain,p.tags||[])),t.commandName){let C=this._getCommandTags(t.commandName),E=(p.tags||[]).filter(N=>C.includes(N));g.tagMatch=Math.min(20,E.length*8)}let S=(Date.now()-new Date(p.updatedAt).getTime())/(1e3*60*60*24);if(g.recency=Math.max(0,Math.round(15-S*.5)),p.confidence?g.confidence=p.confidence==="high"?20:p.confidence==="medium"?12:5:p.observationCount&&(g.confidence=Math.min(20,p.observationCount*3)),t.taskDescription){let C=this._extractKeywordsFromText(t.taskDescription),E=0;for(let N of C)p.content.toLowerCase().includes(N)&&(E+=2),p.title.toLowerCase().includes(N)&&(E+=3);g.keywords=Math.min(15,E)}p.userTriggered&&(g.userTriggered=5);let y=g.domainMatch+g.tagMatch+g.recency+g.confidence+g.keywords+g.userTriggered;return{...p,relevanceScore:y,scoreBreakdown:g}}).filter(p=>p.relevanceScore>=i),d=c.sort((p,g)=>g.relevanceScore-p.relevanceScore).slice(0,o),m=d.length>0?Math.round(d.reduce((p,g)=>p+g.relevanceScore,0)/d.length):0;return{memories:d,metrics:{totalMemories:s,memoriesConsidered:c.length,memoriesReturned:d.length,filteringRatio:s>0?d.length/s:0,avgRelevanceScore:m}}}_getSemanticDomainScore(e,t){let n=this._resolveCanonicalDomains(e);if(n.length===0)return 0;let s=new Set;for(let a of n){let c=La[a];if(c)for(let u of c)s.add(u)}let o=new Set;for(let a of n){let c=wo[a];if(c)for(let u of c)o.add(u)}let i=0;for(let a of t){if(s.has(a)){i+=10;continue}let c=a.toLowerCase().replace(/[-_\s]/g,"");for(let u of o)if(c.includes(u)||u.includes(c)){i+=5;break}}return Math.min(25,i)}_resolveCanonicalDomains(e){return Ua(e)}_getCommandTags(e){return{ship:[O.COMMIT_STYLE,O.SHIP_WORKFLOW,O.TEST_BEHAVIOR],feature:[O.ARCHITECTURE,O.CODE_STYLE],done:[O.SHIP_WORKFLOW],analyze:[O.TECH_STACK,O.ARCHITECTURE],spec:[O.ARCHITECTURE,O.CODE_STYLE],task:[O.BRANCH_NAMING,O.CODE_STYLE],sync:[O.TECH_STACK,O.ARCHITECTURE,O.DEPENDENCIES],test:[O.TEST_BEHAVIOR],bug:[O.CODE_STYLE,O.TEST_BEHAVIOR]}[e]||[]}_extractKeywordsFromText(e){let t=e.toLowerCase().split(/\s+/),n=new Set(["the","a","an","is","are","to","for","and","or","in","on","at","by","with","from","as","it","this","that","be","have","has"]);return t.filter(s=>s.length>2&&!n.has(s))}_extractContextTags(e){let t=[],n={ship:[O.COMMIT_STYLE,O.SHIP_WORKFLOW,O.TEST_BEHAVIOR],feature:[O.ARCHITECTURE,O.CODE_STYLE],done:[O.SHIP_WORKFLOW],analyze:[O.TECH_STACK,O.ARCHITECTURE],spec:[O.ARCHITECTURE,O.CODE_STYLE]};return e.commandName&&n[e.commandName]&&t.push(...n[e.commandName]),t}_extractKeywords(e){let t=[];e.params?.description&&t.push(...e.params.description.toLowerCase().split(/\s+/)),e.params?.feature&&t.push(...e.params.feature.toLowerCase().split(/\s+/));let n=["the","a","an","is","are","to","for","and","or","in"];return t.filter(s=>s.length>2&&!n.includes(s))}async autoRemember(e,t,n,s=""){let i={commit_footer:[O.COMMIT_STYLE],branch_naming:[O.BRANCH_NAMING],test_before_ship:[O.TEST_BEHAVIOR,O.SHIP_WORKFLOW],preferred_agent:[O.AGENT_PREFERENCE],code_style:[O.CODE_STYLE],verbosity:[O.OUTPUT_VERBOSITY]}[t]||[],a=await this.searchMemories(e,t);a.length>0?await this.updateMemory(e,a[0].id,{content:`${t}: ${n}`,tags:i}):await this.createMemory(e,{title:`Preference: ${t}`,content:`${t}: ${n}${s?`
|
|
357
|
-
Context: ${
|
|
358
|
-
`).filter(Boolean).forEach(n=>{let
|
|
359
|
-
`).filter(Boolean)}catch{return[]}}},
|
|
360
|
-
`).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:
|
|
361
|
-
`)}async function
|
|
362
|
-
|
|
363
|
-
${i}`;return await ye.writeFile(
|
|
355
|
+
${Gw(e.schema)}`:null}function Gw(s){if(s instanceof Ke.ZodObject){let e=s.shape;return Object.entries(e).map(([t,n])=>`- \`${t}\`: ${Od(n)}`).join(`
|
|
356
|
+
`)}return"(see example above)"}function Od(s){return s instanceof Ke.ZodString?"string":s instanceof Ke.ZodNumber?"number":s instanceof Ke.ZodEnum?`one of: ${s.options.join(", ")}`:s instanceof Ke.ZodArray?`array of ${Od(s.element)}`:s instanceof Ke.ZodObject?"object":"any"}var Id,$d,Md,yo=k(()=>{"use strict";yr();yr();Id=Ke.object({agentName:Ke.string(),reasoning:Ke.string(),confidence:Ke.number().min(0).max(1)}),$d=Ke.object({subtasks:Ke.array(Ke.object({description:Ke.string(),domain:ho,agent:Ke.string(),dependsOn:Ke.array(Ke.number())})),effort:Ke.enum(["low","medium","high"])}),Md={classification:{schema:kn,example:JSON.stringify({primaryDomain:"backend",secondaryDomains:["database"],confidence:.9,filePatterns:["src/api/**"],relevantAgents:["backend.md"]},null,2)},agentAssignment:{schema:Id,example:JSON.stringify({agentName:"backend.md",reasoning:"Task involves API endpoint creation",confidence:.85},null,2)},subtaskBreakdown:{schema:$d,example:JSON.stringify({subtasks:[{description:"Add schema validation",domain:"backend",agent:"backend.md",dependsOn:[]},{description:"Add unit tests",domain:"testing",agent:"testing.md",dependsOn:[0]}],effort:"medium"},null,2)}};l(Oa,"renderSchemaForPrompt");l(Gw,"describeSchema");l(Od,"describeField")});import{z as R}from"zod";var _d,Ww,zw,Nd,Vw,Bw,Jw,qw,Kw,Xw,Yw,Ld,Qw,Zw,PR,Ud,Hd,Gd,Wd,eS,wo,Fa=k(()=>{"use strict";_d=R.number().min(1).max(5),Ww=R.enum(["exceeded","met","partial","failed"]),zw=R.enum(["definitely","probably","maybe","no"]),Nd=R.enum(["scope_creep","underestimated_complexity","technical_debt","external_blockers","learning_curve","requirements_changed","optimistic_estimate","team_changes","other"]),Vw=R.object({estimated:R.object({hours:R.number(),confidence:R.enum(["low","medium","high"]).optional(),source:R.enum(["prd","manual","historical"]).optional()}),actual:R.object({hours:R.number(),commits:R.number().optional(),linesAdded:R.number().optional(),linesRemoved:R.number().optional(),sessions:R.number().optional()}),variance:R.object({hours:R.number(),percentage:R.number(),reason:Nd.optional(),explanation:R.string().optional()})}),Bw=R.object({name:R.string(),baseline:R.number().nullable(),target:R.number(),actual:R.number(),unit:R.string(),achieved:R.boolean(),percentOfTarget:R.number()}),Jw=R.object({criteria:R.string(),met:R.boolean(),notes:R.string().optional()}),qw=R.object({metrics:R.array(Bw),acceptanceCriteria:R.array(Jw),overallSuccess:Ww,successScore:R.number().min(0).max(100)}),Kw=R.object({category:R.enum(["estimation","technical","process","communication","tooling","architecture","testing","other"]),insight:R.string(),actionable:R.boolean(),action:R.string().optional()}),Xw=R.object({whatWorked:R.array(R.string()),whatDidnt:R.array(R.string()),surprises:R.array(R.string()),recommendations:R.array(Kw)}),Yw=R.object({valueDelivered:R.number().min(1).max(10),userImpact:R.enum(["none","low","medium","high","critical"]),businessImpact:R.enum(["none","low","medium","high","critical"]),roiScore:R.number(),worthIt:zw,worthItReason:R.string().optional(),alternativeConsidered:R.string().optional(),betterAlternativeExists:R.boolean().optional()}),Ld=R.object({id:R.string(),taskId:R.string(),description:R.string(),estimatedMinutes:R.number().optional(),actualMinutes:R.number(),completedAsPlanned:R.boolean(),qualityScore:_d,blockers:R.array(R.string()),agentUsed:R.string().optional(),skillsUsed:R.array(R.string()).optional(),startedAt:R.string(),completedAt:R.string()}),Qw=R.object({id:R.string(),featureId:R.string(),featureName:R.string(),prdId:R.string().nullable(),version:R.string().optional(),branch:R.string().optional(),prUrl:R.string().optional(),effort:Vw,success:qw.optional(),learnings:Xw,roi:Yw,rating:_d,taskOutcomes:R.array(Ld).optional(),startedAt:R.string(),shippedAt:R.string(),reviewedAt:R.string().optional(),reviewedBy:R.string().optional(),legacy:R.boolean().optional()}),Zw=R.object({totalFeatures:R.number(),averageEstimationAccuracy:R.number(),averageSuccessRate:R.number(),averageROI:R.number(),bySuccessLevel:R.object({exceeded:R.number(),met:R.number(),partial:R.number(),failed:R.number()}),variancePatterns:R.array(R.object({reason:Nd,count:R.number(),averageVariance:R.number()})),topLearnings:R.array(R.object({insight:R.string(),frequency:R.number()}))}),PR=R.object({outcomes:R.array(Qw),taskOutcomes:R.array(Ld).optional(),aggregates:Zw.optional(),lastUpdated:R.string(),lastAggregated:R.string().optional()}),Ud={outcomes:[],taskOutcomes:[],lastUpdated:""},Hd=l((s,e)=>{let t=e-s,n=s>0?(e-s)/s*100:0;return{hours:t,percentage:Math.round(n*10)/10}},"calculateVariance"),Gd=l((s,e)=>e<=0?s*10:Math.round(s*10/e*100)/100,"calculateROIScore"),Wd=l(s=>s>=100?"exceeded":s>=80?"met":s>=50?"partial":"failed","determineSuccessLevel"),eS=l(s=>Math.max(0,100-Math.abs(s)),"calculateEstimationAccuracy"),wo=l(s=>{if(s.length===0)return{totalFeatures:0,averageEstimationAccuracy:0,averageSuccessRate:0,averageROI:0,bySuccessLevel:{exceeded:0,met:0,partial:0,failed:0},variancePatterns:[],topLearnings:[]};let e=s.map(d=>eS(d.effort.variance.percentage)),t=s.filter(d=>d.success).map(d=>d.success.successScore),n=s.map(d=>d.roi.roiScore),r={exceeded:s.filter(d=>d.success?.overallSuccess==="exceeded").length,met:s.filter(d=>d.success?.overallSuccess==="met").length,partial:s.filter(d=>d.success?.overallSuccess==="partial").length,failed:s.filter(d=>d.success?.overallSuccess==="failed").length},o=s.filter(d=>d.effort.variance.reason).reduce((d,m)=>{let p=m.effort.variance.reason;return d[p]||(d[p]={count:0,totalVariance:0}),d[p].count++,d[p].totalVariance+=m.effort.variance.percentage,d},{}),i=Object.entries(o).map(([d,m])=>({reason:d,count:m.count,averageVariance:Math.round(m.totalVariance/m.count)})),c=s.flatMap(d=>[...d.learnings.whatWorked,...d.learnings.whatDidnt]).reduce((d,m)=>(d[m]=(d[m]||0)+1,d),{}),u=Object.entries(c).sort((d,m)=>m[1]-d[1]).slice(0,10).map(([d,m])=>({insight:d,frequency:m}));return{totalFeatures:s.length,averageEstimationAccuracy:Math.round(e.reduce((d,m)=>d+m,0)/e.length),averageSuccessRate:t.length>0?Math.round(t.reduce((d,m)=>d+m,0)/t.length):0,averageROI:Math.round(n.reduce((d,m)=>d+m,0)/n.length*100)/100,bySuccessLevel:r,variancePatterns:i,topLearnings:u}},"aggregateOutcomes")});import{z as Ve}from"zod";function iS(){let s={};for(let e of sS)s[e]="allow";for(let e of rS)s[e]="ask";for(let e of oS)s[e]="deny";return{bash:s,files:{read:{"**/*":"allow"},write:{"**/*":"allow"},delete:{"**/*":"ask"}},web:{enabled:!0},doomLoop:{enabled:!0,maxRetries:3},externalDirectories:"ask"}}var So,ER,tS,_a,nS,AR,sS,rS,oS,RR,zd=k(()=>{"use strict";So=Ve.enum(["allow","deny","ask"]),ER=Ve.enum(["read","write","delete","create"]),tS=Ve.record(Ve.string(),So),_a=Ve.record(Ve.string(),So),nS=Ve.object({enabled:Ve.boolean().default(!0),allowedDomains:Ve.array(Ve.string()).optional(),blockedDomains:Ve.array(Ve.string()).optional()}),AR=Ve.object({bash:tS.optional(),files:Ve.object({read:_a.optional(),write:_a.optional(),delete:_a.optional()}).optional(),web:nS.optional(),skills:Ve.record(Ve.string(),So).optional(),doomLoop:Ve.object({enabled:Ve.boolean().default(!0),maxRetries:Ve.number().default(3)}).optional(),externalDirectories:So.default("ask")}),sS=["git status*","git log*","git diff*","git branch*","git remote*","ls*","pwd","cat*","head*","tail*","grep*","find*","which*","echo*","node -e*","bun -e*","npm list*","npm view*","npx tsc --noEmit*"],rS=["rm -rf*","rm -r*","git push*","git reset --hard*","git clean*","npm publish*","chmod*","chown*","sudo*","curl*|*sh","wget*|*sh"],oS=["rm -rf /*","rm -rf ~/*",":(){ :|:& };:*","mkfs*","dd if=*of=/dev/*"];l(iS,"buildDefaultPermissions");RR=iS()});import{z as mt}from"zod";var $R,MR,Vd=k(()=>{"use strict";$R=mt.object({projectId:mt.string(),name:mt.string(),repoPath:mt.string(),description:mt.string().optional(),version:mt.string().optional(),cliVersion:mt.string().optional(),techStack:mt.array(mt.string()),fileCount:mt.number(),commitCount:mt.number(),createdAt:mt.string(),lastSync:mt.string(),lastSyncCommit:mt.string().optional(),lastSyncBranch:mt.string().optional()}),MR={techStack:[],fileCount:0,commitCount:0,createdAt:new Date().toISOString(),lastSync:new Date().toISOString()}});import{z as D}from"zod";var aS,cS,lS,uS,dS,pS,mS,gS,fS,hS,yS,wS,SS,kS,bS,vS,PS,CS,NR,LR,Bd=k(()=>{"use strict";aS=D.enum(["planned","active","completed","shipped"]),cS=D.enum(["low","medium","high"]),lS=D.enum(["feature","breaking_change","refactor","infrastructure"]),uS=D.enum(["completed","active","planned"]),dS=D.enum(["planned","active","completed"]),pS=D.enum(["git","git-branch","manual","prd"]),mS=D.object({id:D.string(),description:D.string(),completed:D.boolean(),completedAt:D.string().optional()}),gS=D.object({id:D.string(),name:D.string(),status:uS,completedAt:D.string().optional()}),fS=D.object({goal:D.string(),phases:D.array(gS),successMetrics:D.array(D.string()).optional()}),hS=D.object({hours:D.number(),minutes:D.number(),totalMinutes:D.number(),display:D.string().optional()}),yS=D.object({hash:D.string(),message:D.string(),date:D.string(),author:D.string().optional()}),wS=D.object({hours:D.number(),confidence:D.enum(["low","medium","high"]).optional(),breakdown:D.array(D.object({area:D.string(),hours:D.number()})).optional()}),SS=D.object({hours:D.number().optional(),commits:D.number().optional(),linesAdded:D.number().optional(),linesRemoved:D.number().optional()}),kS=D.object({estimated:wS.nullable(),actual:SS.nullable()}),bS=D.object({totalHours:D.number(),allocatedHours:D.number(),bufferPercent:D.number().optional()}),vS=D.object({id:D.string(),name:D.string(),theme:D.string().optional(),goals:D.array(D.string()).optional(),features:D.array(D.string()),capacity:bS.optional(),status:dS,startDate:D.string().optional(),endDate:D.string().optional()}),PS=D.object({id:D.string(),name:D.string(),description:D.string().optional(),date:D.string(),status:aS,impact:cS,effort:D.string().optional(),progress:D.number(),type:lS.optional(),roi:D.number().optional(),why:D.array(D.string()).optional(),technicalNotes:D.array(D.string()).optional(),compatibility:D.string().optional(),phase:D.string().optional(),tasks:D.array(mS),createdAt:D.string(),shippedAt:D.string().optional(),version:D.string().optional(),duration:hS.optional(),taskCount:D.number().optional(),agent:D.string().optional(),sprintName:D.string().optional(),completedDate:D.string().optional(),prdId:D.string().nullable().optional(),legacy:D.boolean().optional(),inferredFrom:pS.optional(),quarter:D.string().nullable().optional(),dependencies:D.array(D.string()).optional(),blockedBy:D.array(D.string()).optional(),effortTracking:kS.optional(),valueScore:D.number().optional(),commits:D.array(yS).optional(),branch:D.string().optional(),commitsAhead:D.number().optional()}),CS=D.object({id:D.string(),title:D.string(),prdId:D.string().nullable().optional(),valueScore:D.number().optional(),effortEstimate:D.number().optional(),reason:D.string().optional()}),NR=D.object({strategy:fS.nullable().optional(),features:D.array(PS),backlog:D.array(D.union([D.string(),CS])),lastUpdated:D.string(),quarters:D.array(vS).optional(),generatedFrom:D.enum(["git-history","manual","prd"]).optional(),generatedAt:D.string().optional()}),LR={date:new Date().toISOString().split("T")[0],status:"planned",impact:"medium",progress:0,tasks:[],createdAt:new Date().toISOString(),prdId:null,legacy:!1,quarter:null}});import xS from"node:crypto";import{homedir as TS}from"node:os";import{join as ES}from"node:path";function me(){return xS.randomUUID()}var AS,Jd=k(()=>{"use strict";l(me,"generateUUID");AS=ES(TS(),".prjct-cli","projects")});import{z as it}from"zod";var qR,qd=k(()=>{"use strict";qR=it.object({sessionId:it.string(),projectId:it.string(),projectPath:it.string(),projectName:it.string().optional(),taskDescription:it.string(),taskStatus:it.enum(["active","paused"]),activeSubtaskIndex:it.number().optional(),subtaskCount:it.number().optional(),branch:it.string().optional(),linearId:it.string().optional(),filesModified:it.array(it.string()).optional(),durationWorkedSec:it.number().optional(),timestamp:it.string(),resumeHint:it.string()})});import{z as Y}from"zod";var RS,Kd,DS,jS,IS,$S,MS,OS,FS,Xd,Na=k(()=>{"use strict";RS=Y.enum(["feature","fix","improvement","refactor"]),Kd=Y.enum(["pass","warning","fail","skipped"]),DS=Y.enum(["added","changed","fixed","removed"]),jS=Y.object({hours:Y.number(),minutes:Y.number(),totalMinutes:Y.number()}),IS=Y.object({filesChanged:Y.number().nullable().optional(),linesAdded:Y.number().nullable().optional(),linesRemoved:Y.number().nullable().optional(),commits:Y.number().nullable().optional()}),$S=Y.object({description:Y.string(),type:DS.optional()}),MS=Y.object({lintStatus:Kd.nullable().optional(),lintDetails:Y.string().optional(),testStatus:Kd.nullable().optional(),testDetails:Y.string().optional()}),OS=Y.object({hash:Y.string().optional(),message:Y.string().optional(),branch:Y.string().optional()}),FS=Y.object({id:Y.string(),name:Y.string(),version:Y.string().nullable().optional(),type:RS,agent:Y.string().optional(),description:Y.string().optional(),changes:Y.array($S).optional(),codeSnippets:Y.array(Y.string()).optional(),commit:OS.optional(),codeMetrics:IS.optional(),qualityMetrics:MS.optional(),quantitativeImpact:Y.string().optional(),duration:jS.optional(),tasksCompleted:Y.number().nullable().optional(),shippedAt:Y.string(),featureId:Y.string().optional()}),Xd=Y.object({shipped:Y.array(FS),lastUpdated:Y.string()})});import{z as x}from"zod";var _S,ko,NS,LS,US,La,Qd,Zd,ep,tp,Yd,HS,GS,np,sp,rp,WS,zS,tD,bo=k(()=>{"use strict";lr();_S=x.enum(["low","medium","high","critical"]),ko=x.enum(["feature","bug","improvement","chore"]),NS=x.enum(["active","backlog","previously_active"]),LS=x.enum(["pending","in_progress","completed","blocked","paused","failed","skipped"]),US=x.enum(["task_completed","feature_shipped","idea_captured","session_started"]),La=x.object({title:x.string(),description:x.string(),filesChanged:x.array(x.object({path:x.string(),action:x.enum(["created","modified","deleted"])})),whatWasDone:x.array(x.string()).min(1),outputForNextAgent:x.string().min(1),notes:x.string().optional()}),Qd=x.object({output:x.string().min(1,"Subtask output is required"),summary:La}),Zd=x.object({id:x.string(),description:x.string(),domain:x.string(),agent:x.string(),status:LS,dependsOn:x.array(x.string()),startedAt:x.string().optional(),completedAt:x.string().optional(),output:x.string().optional(),summary:La.optional(),skipReason:x.string().optional(),blockReason:x.string().optional(),estimatedPoints:x.number().optional(),estimatedMinutes:x.number().optional()}),ep=x.object({completed:x.number(),total:x.number(),percentage:x.number()}),tp=x.object({id:x.string(),description:x.string(),type:ko.optional(),startedAt:x.string(),sessionId:x.string(),featureId:x.string().optional(),subtasks:x.array(Zd).optional(),currentSubtaskIndex:x.number().optional(),subtaskProgress:ep.optional(),linearId:x.string().optional(),linearUuid:x.string().optional(),estimatedPoints:x.number().optional(),estimatedMinutes:x.number().optional(),modelMetadata:hs.optional()}),Yd=x.object({id:x.string(),description:x.string(),status:x.literal("paused"),startedAt:x.string(),pausedAt:x.string(),pauseReason:x.string().optional(),type:ko.optional(),sessionId:x.string().optional(),featureId:x.string().optional(),subtasks:x.array(Zd).optional(),currentSubtaskIndex:x.number().optional(),subtaskProgress:ep.optional(),linearId:x.string().optional(),linearUuid:x.string().optional(),estimatedPoints:x.number().optional(),estimatedMinutes:x.number().optional(),modelMetadata:hs.optional()}),HS=x.object({stackConfirmed:x.array(x.string()).optional(),patternsDiscovered:x.array(x.string()).optional(),agentAccuracy:x.array(x.object({agent:x.string(),rating:x.enum(["helpful","neutral","inaccurate"]),note:x.string().optional()})).optional(),issuesEncountered:x.array(x.string()).optional()}),GS=x.object({taskId:x.string(),title:x.string(),classification:ko,startedAt:x.string(),completedAt:x.string(),subtaskCount:x.number(),subtaskSummaries:x.array(La),outcome:x.string(),branchName:x.string(),linearId:x.string().optional(),linearUuid:x.string().optional(),prUrl:x.string().optional(),feedback:HS.optional()}),np=x.object({currentTask:tp.nullable(),previousTask:Yd.nullable().optional(),pausedTasks:x.array(Yd).optional(),taskHistory:x.array(GS).optional(),lastUpdated:x.string()}),sp=x.object({id:x.string(),description:x.string(),priority:_S,type:ko,featureId:x.string().optional(),originFeature:x.string().optional(),completed:x.boolean(),completedAt:x.string().optional(),createdAt:x.string(),section:NS,agent:x.string().optional(),groupName:x.string().optional(),groupId:x.string().optional()}),rp=x.object({tasks:x.array(sp),lastUpdated:x.string()}),WS=x.object({tasksToday:x.number(),tasksThisWeek:x.number(),streak:x.number(),velocity:x.string(),avgDuration:x.string()}),zS=x.object({type:US,description:x.string(),timestamp:x.string(),duration:x.string().optional()}),tD=x.object({projectId:x.string(),currentTask:tp.nullable(),queue:x.array(sp),stats:WS,recentActivity:x.array(zS),lastSync:x.string()})});import{z as le}from"zod";var VS,BS,op,oD,iD,aD,bn,ip,ys=k(()=>{"use strict";VS=le.enum(["improving","stable","declining"]),BS=le.object({sprintNumber:le.number(),startDate:le.string(),endDate:le.string(),pointsCompleted:le.number(),tasksCompleted:le.number(),avgVariance:le.number(),estimationAccuracy:le.number()}),op=le.object({category:le.string(),avgVariance:le.number(),taskCount:le.number()}),oD=le.object({totalPoints:le.number(),sprints:le.number(),estimatedDate:le.string()}),iD=le.object({sprints:le.array(BS),averageVelocity:le.number(),velocityTrend:VS,estimationAccuracy:le.number(),overEstimated:le.array(op),underEstimated:le.array(op),lastUpdated:le.string()}),aD=le.object({sprintLengthDays:le.number().min(1).max(90).default(7),startDay:le.enum(["monday","tuesday","wednesday","thursday","friday","saturday","sunday"]).default("monday"),windowSize:le.number().min(1).max(52).default(6),accuracyTolerance:le.number().min(0).max(100).default(20)}),bn={sprintLengthDays:7,startDay:"monday",windowSize:6,accuracyTolerance:20},ip={sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:""}});var Rt=k(()=>{"use strict";xd();Ia();yr();Ma();jd();yo();lr();Fa();zd();Vd();Bd();Jd();qd();Na();bo();ys()});var Nn,Ua=k(()=>{"use strict";Rt();ms();ce();gr();Nn=class extends _n{static{l(this,"SemanticMemories")}getFilename(){return"memories.json"}getDefault(){return{version:1,memories:[],index:this._createEmptyIndex()}}afterLoad(e){this._normalizeIndex(e)}_createEmptyIndex(){let e=Object.values(O),t={};for(let n of e)t[n]=[];return t}_normalizeIndex(e){let t=Object.values(O);for(let n of t)e.index[n]||(e.index[n]=[])}_coerceTags(e){let t=new Set(Object.values(O));return e.filter(n=>t.has(n))}async loadMemories(e){return this.load(e)}async saveMemories(e){return this.save(e)}async createMemory(e,{title:t,content:n,tags:r=[],userTriggered:o=!1}){let i=await this.load(e),a=this._coerceTags(r),c=b(),u={id:me(),title:t,content:n,tags:a,userTriggered:o,createdAt:c,updatedAt:c};i.memories.push(u);for(let d of a)i.index[d].push(u.id);return await this.save(e),u.id}async updateMemory(e,t,n){let r=await this.load(e),o=r.memories.findIndex(c=>c.id===t);if(o===-1)return!1;let i=r.memories[o],a=i.tags||[];if(n.title&&(i.title=n.title),n.content&&(i.content=n.content),n.tags){let c=this._coerceTags(n.tags);for(let u of a)r.index[u]=r.index[u].filter(d=>d!==t);for(let u of c)r.index[u].push(t);i.tags=c}return i.updatedAt=b(),await this.save(e),!0}async deleteMemory(e,t){let n=await this.load(e),r=n.memories.findIndex(i=>i.id===t);if(r===-1)return!1;let o=n.memories[r];for(let i of o.tags||[])n.index[i]&&(n.index[i]=n.index[i].filter(a=>a!==t));return n.memories.splice(r,1),await this.save(e),!0}async findByTags(e,t,n=!1){let r=await this.load(e),o=this._coerceTags(t);if(n)return r.memories.filter(i=>o.every(a=>(i.tags||[]).includes(a)));{let i=new Set;for(let a of o){let c=r.index[a];for(let u of c)i.add(u)}return r.memories.filter(a=>i.has(a.id))}}async searchMemories(e,t){let n=await this.load(e),r=t.toLowerCase();return n.memories.filter(o=>o.title.toLowerCase().includes(r)||o.content.toLowerCase().includes(r))}async getRelevantMemories(e,t,n=5){return(await this.load(e)).memories.map(i=>{let a=0,c=this._extractContextTags(t);for(let p of i.tags||[])c.includes(p)&&(a+=10);let d=(Date.now()-new Date(i.updatedAt).getTime())/(1e3*60*60*24);a+=Math.max(0,5-d),i.userTriggered&&(a+=5);let m=this._extractKeywords(t);for(let p of m)i.content.toLowerCase().includes(p)&&(a+=2),i.title.toLowerCase().includes(p)&&(a+=3);return{...i,_score:a}}).filter(i=>i._score>0).sort((i,a)=>a._score-i._score).slice(0,n).map(({_score:i,...a})=>a)}async getRelevantMemoriesWithMetrics(e,t){let n=await this.load(e),r=n.memories.length;if(r===0)return{memories:[],metrics:{totalMemories:0,memoriesConsidered:0,memoriesReturned:0,filteringRatio:0,avgRelevanceScore:0}};let o=t.maxResults??10,i=t.minRelevance??10,c=n.memories.map(p=>{let g={domainMatch:0,tagMatch:0,recency:0,confidence:0,keywords:0,userTriggered:0};if(t.taskDomain&&(g.domainMatch=this._getSemanticDomainScore(t.taskDomain,p.tags||[])),t.commandName){let v=this._getCommandTags(t.commandName),T=(p.tags||[]).filter(_=>v.includes(_));g.tagMatch=Math.min(20,T.length*8)}let S=(Date.now()-new Date(p.updatedAt).getTime())/(1e3*60*60*24);if(g.recency=Math.max(0,Math.round(15-S*.5)),p.confidence?g.confidence=p.confidence==="high"?20:p.confidence==="medium"?12:5:p.observationCount&&(g.confidence=Math.min(20,p.observationCount*3)),t.taskDescription){let v=this._extractKeywordsFromText(t.taskDescription),T=0;for(let _ of v)p.content.toLowerCase().includes(_)&&(T+=2),p.title.toLowerCase().includes(_)&&(T+=3);g.keywords=Math.min(15,T)}p.userTriggered&&(g.userTriggered=5);let w=g.domainMatch+g.tagMatch+g.recency+g.confidence+g.keywords+g.userTriggered;return{...p,relevanceScore:w,scoreBreakdown:g}}).filter(p=>p.relevanceScore>=i),d=c.sort((p,g)=>g.relevanceScore-p.relevanceScore).slice(0,o),m=d.length>0?Math.round(d.reduce((p,g)=>p+g.relevanceScore,0)/d.length):0;return{memories:d,metrics:{totalMemories:r,memoriesConsidered:c.length,memoriesReturned:d.length,filteringRatio:r>0?d.length/r:0,avgRelevanceScore:m}}}_getSemanticDomainScore(e,t){let n=this._resolveCanonicalDomains(e);if(n.length===0)return 0;let r=new Set;for(let a of n){let c=Aa[a];if(c)for(let u of c)r.add(u)}let o=new Set;for(let a of n){let c=fo[a];if(c)for(let u of c)o.add(u)}let i=0;for(let a of t){if(r.has(a)){i+=10;continue}let c=a.toLowerCase().replace(/[-_\s]/g,"");for(let u of o)if(c.includes(u)||u.includes(c)){i+=5;break}}return Math.min(25,i)}_resolveCanonicalDomains(e){return Ra(e)}_getCommandTags(e){return{ship:[O.COMMIT_STYLE,O.SHIP_WORKFLOW,O.TEST_BEHAVIOR],feature:[O.ARCHITECTURE,O.CODE_STYLE],done:[O.SHIP_WORKFLOW],analyze:[O.TECH_STACK,O.ARCHITECTURE],spec:[O.ARCHITECTURE,O.CODE_STYLE],task:[O.BRANCH_NAMING,O.CODE_STYLE],sync:[O.TECH_STACK,O.ARCHITECTURE,O.DEPENDENCIES],test:[O.TEST_BEHAVIOR],bug:[O.CODE_STYLE,O.TEST_BEHAVIOR]}[e]||[]}_extractKeywordsFromText(e){let t=e.toLowerCase().split(/\s+/),n=new Set(["the","a","an","is","are","to","for","and","or","in","on","at","by","with","from","as","it","this","that","be","have","has"]);return t.filter(r=>r.length>2&&!n.has(r))}_extractContextTags(e){let t=[],n={ship:[O.COMMIT_STYLE,O.SHIP_WORKFLOW,O.TEST_BEHAVIOR],feature:[O.ARCHITECTURE,O.CODE_STYLE],done:[O.SHIP_WORKFLOW],analyze:[O.TECH_STACK,O.ARCHITECTURE],spec:[O.ARCHITECTURE,O.CODE_STYLE]};return e.commandName&&n[e.commandName]&&t.push(...n[e.commandName]),t}_extractKeywords(e){let t=[];e.params?.description&&t.push(...e.params.description.toLowerCase().split(/\s+/)),e.params?.feature&&t.push(...e.params.feature.toLowerCase().split(/\s+/));let n=["the","a","an","is","are","to","for","and","or","in"];return t.filter(r=>r.length>2&&!n.includes(r))}async autoRemember(e,t,n,r=""){let i={commit_footer:[O.COMMIT_STYLE],branch_naming:[O.BRANCH_NAMING],test_before_ship:[O.TEST_BEHAVIOR,O.SHIP_WORKFLOW],preferred_agent:[O.AGENT_PREFERENCE],code_style:[O.CODE_STYLE],verbosity:[O.OUTPUT_VERBOSITY]}[t]||[],a=await this.searchMemories(e,t);a.length>0?await this.updateMemory(e,a[0].id,{content:`${t}: ${n}`,tags:i}):await this.createMemory(e,{title:`Preference: ${t}`,content:`${t}: ${n}${r?`
|
|
357
|
+
Context: ${r}`:""}`,tags:i,userTriggered:!0})}async getAllMemories(e){return(await this.load(e)).memories}async getMemoryStats(e){let t=await this.load(e),n={};for(let[r,o]of Object.entries(t.index))n[r]=o.length;return{totalMemories:t.memories.length,userTriggered:t.memories.filter(r=>r.userTriggered).length,tagCounts:n,oldestMemory:t.memories[0]?.createdAt,newestMemory:t.memories[t.memories.length-1]?.createdAt}}}});var Ha,JS,at,wr=k(()=>{"use strict";gr();Da();Ua();gr();Da();Ua();Ha=class{static{l(this,"MemorySystem")}_semanticMemories;_patternStore;_historyStore;_sessionStore;constructor(){this._semanticMemories=new Nn,this._patternStore=new fr,this._historyStore=new mr,this._sessionStore=new pr}loadMemories(e){return this._semanticMemories.loadMemories(e)}saveMemories(e){return this._semanticMemories.saveMemories(e)}createMemory(e,t){return this._semanticMemories.createMemory(e,t)}updateMemory(e,t,n){return this._semanticMemories.updateMemory(e,t,n)}deleteMemory(e,t){return this._semanticMemories.deleteMemory(e,t)}findByTags(e,t,n){return this._semanticMemories.findByTags(e,t,n)}searchMemories(e,t){return this._semanticMemories.searchMemories(e,t)}getRelevantMemories(e,t,n){return this._semanticMemories.getRelevantMemories(e,t,n)}autoRemember(e,t,n,r){return this._semanticMemories.autoRemember(e,t,n,r)}getAllMemories(e){return this._semanticMemories.getAllMemories(e)}getMemoryStats(e){return this._semanticMemories.getMemoryStats(e)}getRelevantMemoriesWithMetrics(e,t){return this._semanticMemories.getRelevantMemoriesWithMetrics(e,t)}setSession(e,t){this._sessionStore.setSession(e,t)}getSession(e){return this._sessionStore.getSession(e)}clearSession(){this._sessionStore.clearSession()}loadPatterns(e){return this._patternStore.loadPatterns(e)}savePatterns(e){return this._patternStore.savePatterns(e)}recordDecision(e,t,n,r){return this._patternStore.recordDecision(e,t,n,r)}getDecision(e,t){return this._patternStore.getDecision(e,t)}hasPattern(e,t){return this._patternStore.hasPattern(e,t)}recordWorkflow(e,t,n){return this._patternStore.recordWorkflow(e,t,n)}getWorkflow(e,t){return this._patternStore.getWorkflow(e,t)}setPreference(e,t,n,r){return this._patternStore.setPreference(e,t,n,r)}getPreference(e,t,n){return this._patternStore.getPreference(e,t,n)}confirmPreference(e,t){return this._patternStore.confirmPreference(e,t)}confirmDecision(e,t){return this._patternStore.confirmDecision(e,t)}confirmWorkflow(e,t){return this._patternStore.confirmWorkflow(e,t)}getPatternsSummary(e){return this._patternStore.getPatternsSummary(e)}archiveStaleDecisions(e){return this._patternStore.archiveStaleDecisions(e)}appendHistory(e,t){return this._historyStore.appendHistory(e,t)}getRecentHistory(e,t){return this._historyStore.getRecentHistory(e,t)}async getSmartDecision(e,t){let n=this.getSession(`decision:${t}`);if(n!==void 0)return n;let r=await this.getDecision(e,t);return r?r.value:null}async learnDecision(e,t,n,r=""){this.setSession(`decision:${t}`,n),await this.recordDecision(e,t,n,r),await this.appendHistory(e,{type:"decision",key:t,value:n,context:r})}resetState(){this._sessionStore.clearSession(),this._semanticMemories.reset(),this._patternStore.reset()}},JS=new Ha,at=JS});import{exec as qS}from"node:child_process";import vt from"node:fs/promises";import Ft from"node:path";import{promisify as KS}from"node:util";var Ln,Ga,XS,Xe,ap=k(()=>{"use strict";L();Ln=KS(qS),Ga=class{static{l(this,"CodebaseAnalyzer")}projectPath=null;init(e=process.cwd()){this.projectPath=e}async readPackageJson(){try{let e=Ft.join(this.projectPath,"package.json"),t=await vt.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(C(e)||e instanceof SyntaxError)return null;throw e}}async readCargoToml(){try{let e=Ft.join(this.projectPath,"Cargo.toml");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async readRequirements(){try{let e=Ft.join(this.projectPath,"requirements.txt");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async readGoMod(){try{let e=Ft.join(this.projectPath,"go.mod");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async readGemfile(){try{let e=Ft.join(this.projectPath,"Gemfile");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async readMixExs(){try{let e=Ft.join(this.projectPath,"mix.exs");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async readPomXml(){try{let e=Ft.join(this.projectPath,"pom.xml");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async readComposerJson(){try{let e=Ft.join(this.projectPath,"composer.json"),t=await vt.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if(C(e)||e instanceof SyntaxError)return null;throw e}}async readPyprojectToml(){try{let e=Ft.join(this.projectPath,"pyproject.toml");return await vt.readFile(e,"utf-8")}catch(e){if(C(e))return null;throw e}}async getFileExtensions(){try{let{stdout:e}=await Ln('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(`
|
|
358
|
+
`).filter(Boolean).forEach(n=>{let r=n.trim().match(/^\s*(\d+)\s+(\.\w+)$/);r&&(t[r[2]]=parseInt(r[1],10))}),t}catch{return{}}}async listConfigFiles(){try{let e=await vt.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(n=>t.some(r=>r.test(n)))}catch(e){if(C(e))return[];throw e}}async listDirectories(){try{return(await vt.readdir(this.projectPath,{withFileTypes:!0})).filter(t=>t.isDirectory()).map(t=>t.name).filter(t=>!t.startsWith(".")&&t!=="node_modules")}catch(e){if(C(e))return[];throw e}}async getGitLog(e=50){try{let{stdout:t}=await Ln(`git log -n ${e} --pretty=format:"%h|%an|%ar|%s"`,{cwd:this.projectPath});return t}catch{return""}}async getGitStats(){try{let{stdout:e}=await Ln("git rev-list --count HEAD",{cwd:this.projectPath}),{stdout:t}=await Ln('git log --format="%an" | sort -u | wc -l',{cwd:this.projectPath}),{stdout:n}=await Ln('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:n.trim()||"unknown"}}catch{return{totalCommits:0,contributors:0,age:"unknown"}}}async countFiles(){try{let{stdout:e}=await Ln('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){try{return await vt.access(Ft.join(this.projectPath,e)),!0}catch(t){if(C(t))return!1;throw t}}async readFile(e){try{let t=Ft.join(this.projectPath,e);return await vt.readFile(t,"utf-8")}catch(t){if(C(t))return null;throw t}}async findFiles(e){try{let{stdout:t}=await Ln(`find . -type f -name "${e}" ! -path "*/node_modules/*" ! -path "*/.git/*"`,{cwd:this.projectPath});return t.trim().split(`
|
|
359
|
+
`).filter(Boolean)}catch{return[]}}},XS=new Ga,Xe=XS});import{z as Pe}from"zod";function YS(s){return s instanceof ws}function Z(s){return YS(s)||s instanceof Error?s.message:typeof s=="string"?s:"Unknown error"}var Ss,tj,nj,sj,rj,oj,ij,ws,vo,Po,Sr,rn=k(()=>{"use strict";Ss={create(s,e){class t extends Error{static{l(this,"TypedError")}errorName;data;isOperational=!0;constructor(r){let o=e.parse(r);super(`${s}: ${JSON.stringify(o)}`),this.name=s,this.errorName=s,this.data=o,Error.captureStackTrace?.(this,this.constructor)}static throw(r){throw new t(r)}static is(r){return r instanceof t&&r.errorName===s}static create(r){return new t(r)}}return t}},tj=Ss.create("FileError",Pe.object({path:Pe.string(),operation:Pe.enum(["read","write","delete","create","copy"]),reason:Pe.string().optional()})),nj=Ss.create("ValidationError",Pe.object({field:Pe.string(),expected:Pe.string(),received:Pe.string().optional(),message:Pe.string().optional()})),sj=Ss.create("PermissionError",Pe.object({action:Pe.string(),resource:Pe.string(),reason:Pe.string().optional()})),rj=Ss.create("TaskError",Pe.object({taskId:Pe.string().optional(),operation:Pe.enum(["create","update","complete","pause","resume","delete"]),reason:Pe.string()})),oj=Ss.create("SessionError",Pe.object({sessionId:Pe.string().optional(),reason:Pe.string()})),ij=Ss.create("SyncError",Pe.object({projectId:Pe.string().optional(),operation:Pe.enum(["push","pull","auth","connect"]),reason:Pe.string()})),ws=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)}},vo=class s extends ws{static{l(this,"ProjectError")}constructor(e,t="PROJECT_ERROR"){super(e,t),this.name="ProjectError"}static notInitialized(){return new s("Project not initialized. Run /p:init first.","PROJECT_NOT_INIT")}static notFound(e){return new s(`Project not found: ${e}`,"PROJECT_NOT_FOUND")}static invalidId(e){return new s(`Invalid project ID: ${e}`,"PROJECT_INVALID_ID")}},Po=class s extends ws{static{l(this,"TemplateError")}constructor(e,t="TEMPLATE_ERROR"){super(e,t),this.name="TemplateError"}static notFound(e){return new s(`Template not found: ${e}.md`,"TEMPLATE_NOT_FOUND")}static parseFailed(e){return new s(`Failed to parse template: ${e}`,"TEMPLATE_PARSE_ERROR")}},Sr=class s extends ws{static{l(this,"AgentError")}constructor(e,t="AGENT_ERROR"){super(e,t),this.name="AgentError"}static notSupported(e){return new s(`Unsupported agent type: ${e}`,"AGENT_NOT_SUPPORTED")}static initFailed(e){return new s(`Agent initialization failed: ${e}`,"AGENT_INIT_FAILED")}};l(YS,"isPrjctError");l(Z,"getErrorMessage")});import Wa from"node:fs";import xo from"node:path";function cp(){if(kr)return kr;let s=__dirname;for(let e=0;e<5;e++){let t=xo.join(s,"package.json");if(Wa.existsSync(t))try{if(JSON.parse(Wa.readFileSync(t,"utf-8")).name==="prjct-cli")return kr=s,s}catch{}s=xo.dirname(s)}return kr=xo.join(__dirname,"..","..",".."),kr}function za(){if(Co)return Co;try{let s=xo.join(cp(),"package.json"),e=JSON.parse(Wa.readFileSync(s,"utf-8"));return Co=e.version,QS=e,Co}catch(s){return console.error("Failed to read version from package.json:",y(s)),"0.0.0"}}var Co,QS,kr,De,ge,Dt=k(()=>{"use strict";L();Co=null,QS=null,kr=null;l(cp,"getPackageRoot");l(za,"getVersion");De=za(),ge=cp()});import Ba from"node:fs";import ZS from"node:fs/promises";import To from"node:path";function Ja(){if(lp)return Va;lp=!0;let s=To.join(ge,"dist","templates.json");try{let e=Ba.readFileSync(s,"utf-8");return Va=JSON.parse(e),Va}catch{return null}}function tk(s){let e=Un.indexOf(s);e>-1&&Un.splice(e,1),Un.push(s)}function nk(){for(;ks.size>=ek&&Un.length>0;){let s=Un.shift();s&&ks.delete(s)}}function Eo(s){let e=/^---\n([\s\S]+?)\n---\n([\s\S]*)$/,t=s.match(e);if(!t)return{frontmatter:{},content:s.trim()};let[,n,r]=t,o={};return n.split(`
|
|
360
|
+
`).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 up(s){if(ks.has(s))return tk(s),ks.get(s);let e,t=Ja();if(t){let r=`commands/${s}.md`;e=t[r]}if(!e){let r=To.join(ge,"templates","commands",`${s}.md`);try{e=await ZS.readFile(r,"utf-8")}catch{throw Po.notFound(s)}}let n=Eo(e);return nk(),ks.set(s,n),Un.push(s),n}async function sk(s){return(await up(s)).frontmatter["allowed-tools"]||[]}function rk(){ks.clear(),Un.length=0}function he(s){let e=Ja();if(e?.[s])return e[s];let t=To.join(ge,"templates",s);try{return Ba.readFileSync(t,"utf-8")}catch{return null}}function vn(s){let e=Ja();if(e)return Object.keys(e).filter(n=>n.startsWith(s));let t=To.join(ge,"templates",s);try{return Ba.readdirSync(t).map(r=>`${s}${r}`)}catch{return[]}}var ek,ks,Un,Va,lp,ok,qa,qt=k(()=>{"use strict";rn();Dt();ek=50,ks=new Map,Un=[],Va=null,lp=!1;l(Ja,"loadBundle");l(tk,"updateLruOrder");l(nk,"evictLru");l(Eo,"parseFrontmatter");l(up,"load");l(sk,"getAllowedTools");l(rk,"clearCache");l(he,"getTemplateContent");l(vn,"listTemplates");ok={load:up,parseFrontmatter:Eo,getAllowedTools:sk,clearCache:rk,getTemplateContent:he,listTemplates:vn},qa=ok});import ye from"node:fs/promises";import Ka from"node:os";import ue from"node:path";async function ik(){try{let s=he("global/modules/module-config.json");if(s)return JSON.parse(s);let e=ue.join(ge,"templates/global/modules/module-config.json"),t=await ye.readFile(e,"utf-8");return JSON.parse(t)}catch{return null}}async function ak(s){let e=await ik();if(!e){let i=he("global/CLAUDE.md");if(i)return i;let a=ue.join(ge,"templates/global/CLAUDE.md");return ye.readFile(a,"utf-8")}let t=s||e.default,n=e.profiles[t];if(!n&&!e.profiles[e.default]){let a=he("global/CLAUDE.md");if(a)return a;let c=ue.join(ge,"templates/global/CLAUDE.md");return ye.readFile(c,"utf-8")}let r=(n||e.profiles[e.default]).modules,o=[];o.push("<!-- prjct:start - DO NOT REMOVE THIS MARKER -->");for(let i of r){let a=he(`global/modules/${i}`);if(a)o.push(""),o.push(a);else try{let c=ue.join(ge,"templates/global/modules",i),u=await ye.readFile(c,"utf-8");o.push(""),o.push(u)}catch{console.warn(`Module not found: ${i}`)}}return o.push(""),o.push("<!-- prjct:end - DO NOT REMOVE THIS MARKER -->"),o.push(""),o.join(`
|
|
361
|
+
`)}async function ck(){try{let s=ue.join(Ka.homedir(),".prjct-cli","docs");await ye.mkdir(s,{recursive:!0});let e=vn("global/docs/");if(e.length>0){for(let r of e)if(r.endsWith(".md")){let o=he(r);if(o){let i=ue.basename(r);await ye.writeFile(ue.join(s,i),o,"utf-8")}}return{success:!0}}let t=ue.join(ge,"templates/global/docs"),n=await ye.readdir(t);for(let r of n)if(r.endsWith(".md")){let o=ue.join(t,r),i=ue.join(s,r),a=await ye.readFile(o,"utf-8");await ye.writeFile(i,a,"utf-8")}return{success:!0}}catch(s){return{success:!1,error:y(s)}}}async function lk(){let s=(qe(),ht(pt)),e=await s.getActiveProvider(),t=e.name;if(!(await s.detectProvider(t)).installed&&!e.configDir)return{success:!1,error:`${e.displayName} not detected`,action:"skipped"};try{await ye.mkdir(e.configDir,{recursive:!0});let r=ue.join(e.configDir,e.contextFile),o=ue.join(ge,"templates","global",e.contextFile),i="";try{let u=he(`global/${e.contextFile}`);u?i=u:i=await ye.readFile(o,"utf-8")}catch{if(t==="claude")try{i=await ak()}catch{let d=he("global/CLAUDE.md");if(d)i=d;else{let m=ue.join(ge,"templates/global/CLAUDE.md");i=await ye.readFile(m,"utf-8")}}else{let d=he("global/CLAUDE.md");if(d)i=d;else{let m=ue.join(ge,"templates/global/CLAUDE.md");i=await ye.readFile(m,"utf-8")}t==="gemini"&&(i=i.replace(/Claude/g,"Gemini"))}}let a="",c=!1;try{a=await ye.readFile(r,"utf-8"),c=!0}catch(u){if(C(u))c=!1;else throw u}if(c){let u="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",d="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(a.includes(u)&&a.includes(d)){let p=a.substring(0,a.indexOf(u)),g=a.substring(a.indexOf(d)+d.length),f=i.substring(i.indexOf(u),i.indexOf(d)+d.length),S=p+f+g;return await ye.writeFile(r,S,"utf-8"),{success:!0,action:"updated",path:r}}else{let p=`${a}
|
|
362
|
+
|
|
363
|
+
${i}`;return await ye.writeFile(r,p,"utf-8"),{success:!0,action:"appended",path:r}}}else return await ye.writeFile(r,i,"utf-8"),{success:!0,action:"created",path:r}}catch(r){return{success:!1,error:y(r),action:"failed"}}}function dp(){let s=Ka.homedir();return{claude:{commands:ue.join(s,".claude","commands"),config:ue.join(s,".claude"),router:ue.join(s,".claude","commands","p.md")},gemini:{commands:ue.join(s,".gemini","commands"),config:ue.join(s,".gemini"),router:ue.join(s,".gemini","commands","p.toml")}}}var bs,uk,je,on=k(()=>{"use strict";qt();L();Dt();l(ik,"loadModuleConfig");l(ak,"composeGlobalTemplate");l(ck,"installDocs");l(lk,"installGlobalConfig");bs=class{static{l(this,"CommandInstaller")}homeDir;commandsPath="";configPath="";templatesDir;_initialized=!1;constructor(){this.homeDir=Ka.homedir(),this.templatesDir=ue.join(ge,"templates","commands")}async ensureInit(){if(this._initialized)return;let t=await(qe(),ht(pt)).getActiveProvider();this.commandsPath=ue.join(t.configDir,"commands"),this.configPath=t.configDir,this._initialized=!0}async detectActiveProvider(){await this.ensureInit();try{return await ye.access(this.configPath),!0}catch(e){if(C(e))return!1;throw e}}async getCommandFiles(){let e=new Set(["p.md","p.toml"]),t=vn("commands/");return t.length>0?t.filter(r=>r.endsWith(".md")).map(r=>r.replace("commands/","")).filter(r=>!e.has(r)):(await ye.readdir(this.templatesDir)).filter(r=>r.endsWith(".md")&&!e.has(r))}async installCommands(){let e=await this.detectActiveProvider(),n=await(qe(),ht(pt)).getActiveProvider();if(!e)return{success:!1,error:`${n.displayName} not detected. Please install it first.`};try{return await this.installRouter(),{success:!0,installed:["p (router)"],path:this.commandsPath}}catch(r){return{success:!1,error:y(r)}}}async uninstallCommands(){try{let e=[],r=(await(qe(),ht(pt)).getActiveProvider()).name==="gemini"?"p.toml":"p.md",o=ue.join(this.commandsPath,r);try{await ye.unlink(o),e.push("p (router)")}catch(i){if(i.code!=="ENOENT")return{success:!1,error:y(i)}}return{success:!0,uninstalled:e}}catch(e){return{success:!1,error:y(e)}}}async checkInstallation(){if(!await this.detectActiveProvider())return{installed:!1,providerDetected:!1};try{let r=(await(qe(),ht(pt)).getActiveProvider()).name==="gemini"?"p.toml":"p.md",o=ue.join(this.commandsPath,r);return await ye.access(o),{installed:!0,providerDetected:!0,commands:["p (router)"],path:this.commandsPath}}catch(t){if(C(t))return{installed:!1,providerDetected:!0,commands:[]};throw t}}async getInstallPath(){return await this.ensureInit(),this.commandsPath}async installRouter(){let t=await(qe(),ht(pt)).getActiveProvider();if(t.name==="gemini")return this.installStaticRouter("p.toml");try{let n=ue.join(t.configDir,"commands","p.md");await ye.mkdir(ue.dirname(n),{recursive:!0});let r=await this.generateRouterContent();return await ye.writeFile(n,r,"utf-8"),!0}catch(n){if(C(n))return!1;throw n}}async installStaticRouter(e){let n=await(qe(),ht(pt)).getActiveProvider();try{let r=ue.join(n.configDir,"commands",e);await ye.mkdir(ue.dirname(r),{recursive:!0});let o=he(`commands/${e}`);if(o)return await ye.writeFile(r,o,"utf-8"),!0;let i=ue.join(this.templatesDir,e),a=await ye.readFile(i,"utf-8");return await ye.writeFile(r,a,"utf-8"),!0}catch(r){if(C(r))return!1;throw r}}async generateRouterContent(){let e=await this.getCommandFiles(),t={task:"Start a task",done:"Complete current subtask",ship:"Ship feature with PR + version bump",sync:"Analyze project, regenerate agents",pause:"Pause current task",resume:"Resume paused task",next:"Show priority queue",idea:"Quick idea capture",bug:"Report bug with auto-priority",dash:"Dashboard view",status:"Project status check",linear:"Linear integration (via MCP)",jira:"JIRA integration (via MCP)",init:"Initialize prjct in a project",analyze:"Deep repository analysis",plan:"Create implementation plan",design:"UI/UX design workflow",test:"Test workflow",cleanup:"Code cleanup",git:"Git operations",review:"Code review",history:"Task history & undo/redo",sessions:"Session management",workflow:"Workflow management",enrich:"Enrich task context",impact:"Impact analysis",learnings:"View learned patterns",merge:"Merge workflow",prd:"Product requirements doc",serve:"Start dev server",setup:"Setup prjct",skill:"Skill management",spec:"Technical specification",update:"Update prjct",verify:"Verify analysis integrity",auth:"Authentication"},n=[];for(let r of e){let o=r.replace(".md",""),i=t[o]||`${o} command`;n.push(`| \`p. ${o}${["task","idea","bug","ship"].includes(o)?" <desc>":""}\` | ${i} |`)}return`---
|
|
364
364
|
description: 'prjct CLI - Context layer for AI agents'
|
|
365
365
|
allowed-tools: [Read, Write, Edit, Bash, Glob, Grep, Task, AskUserQuestion, TodoWrite, WebFetch]
|
|
366
366
|
---
|
|
@@ -413,7 +413,7 @@ Templates should use CLI commands for data operations \u2014 never read/write JS
|
|
|
413
413
|
2. Handle aliases (undo \u2192 history undo, redo \u2192 history redo)
|
|
414
414
|
3. Run \`npm root -g\` to get template path
|
|
415
415
|
4. Load and execute command template
|
|
416
|
-
`}async syncCommands(){if(!await this.detectActiveProvider())return{success:!1,error:"AI agent not detected",added:0,updated:0,removed:0};try{return await this.installRouter(),{success:!0,added:0,updated:1,removed:0}}catch(t){return{success:!1,error:
|
|
416
|
+
`}async syncCommands(){if(!await this.detectActiveProvider())return{success:!1,error:"AI agent not detected",added:0,updated:0,removed:0};try{return await this.installRouter(),{success:!0,added:0,updated:1,removed:0}}catch(t){return{success:!1,error:y(t),added:0,updated:0,removed:0}}}async installGlobalConfig(){return lk()}async installDocs(){return ck()}};l(dp,"getProviderPaths");uk=new bs,je=uk});import{z as Ne}from"zod";function fp(s,e="default"){let t=pp[e]||pp.default;return s/1e3*t}function Ao(s){return s<.01?`$${(s*100).toFixed(2)}\xA2`:`$${s.toFixed(2)}`}var dk,pk,mp,gp,pp,Ro=k(()=>{"use strict";dk=Ne.object({date:Ne.string(),tokensSaved:Ne.number(),syncs:Ne.number(),avgCompressionRate:Ne.number(),totalDuration:Ne.number()}),pk=Ne.object({agentName:Ne.string(),usageCount:Ne.number(),tokensSaved:Ne.number()}),mp=Ne.object({totalTokensSaved:Ne.number(),avgCompressionRate:Ne.number(),syncCount:Ne.number(),watchTriggers:Ne.number(),avgSyncDuration:Ne.number(),totalSyncDuration:Ne.number(),agentUsage:Ne.array(pk),dailyStats:Ne.array(dk),firstSync:Ne.string(),lastUpdated:Ne.string()}),gp={totalTokensSaved:0,avgCompressionRate:0,syncCount:0,watchTriggers:0,avgSyncDuration:0,totalSyncDuration:0,agentUsage:[],dailyStats:[],firstSync:"",lastUpdated:""},pp={"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(fp,"estimateCostSaved");l(Ao,"formatCost")});function mk(){return/<!-- prjct:preserve(?::([\w-]+))? -->/g}function gk(s){let e=[],t=mk(),n,r=0;for(;(n=t.exec(s))!==null;){let o=n.index,i=n[0],a=n[1]||`section-${r++}`,c=s.indexOf(Xa,o+i.length);if(c===-1)continue;let u=c+Xa.length,d=s.substring(o,u);e.push({id:a,content:d,startIndex:o,endIndex:u})}return e}function Ya(s,e){let t=gk(e);if(t.length===0)return s;let n=s.trimEnd();n+=`
|
|
417
417
|
|
|
418
418
|
---
|
|
419
419
|
|
|
@@ -421,14 +421,14 @@ Templates should use CLI commands for data operations \u2014 never read/write JS
|
|
|
421
421
|
|
|
422
422
|
`,n+=`_The sections below are preserved during sync. Edit freely._
|
|
423
423
|
|
|
424
|
-
`;for(let
|
|
424
|
+
`;for(let r of t)n+=r.content,n+=`
|
|
425
425
|
|
|
426
426
|
`;return`${n.trimEnd()}
|
|
427
|
-
`}function
|
|
428
|
-
`);for(let a=0;a<i.length;a++){let c=i[a];/<!-- prjct:preserve(?::\w+)? -->/.test(c)&&(
|
|
429
|
-
`,"utf-8")}async readGlobalConfig(e){try{let t=A.getGlobalProjectConfigPath(e),n=await
|
|
430
|
-
`,"utf-8")}async ensureGlobalConfig(e){let t=await this.readGlobalConfig(e);if(!t){let n=b();t={projectId:e,authors:[],version:De,lastSync:n},await this.writeGlobalConfig(e,t)}return t}async createConfig(e,t){let n=A.generateProjectId(e),
|
|
431
|
-
`;await
|
|
427
|
+
`}function Qa(s){let e=[],t=s.match(/<!-- prjct:preserve(?::\w+)? -->/g)||[],n=s.match(/<!-- \/prjct:preserve -->/g)||[];t.length!==n.length&&e.push(`Mismatched preserve markers: ${t.length} opening, ${n.length} closing`);let r=0,o=0,i=s.split(`
|
|
428
|
+
`);for(let a=0;a<i.length;a++){let c=i[a];/<!-- prjct:preserve(?::\w+)? -->/.test(c)&&(r++,o=Math.max(o,r)),c.includes(Xa)&&r--,r>1&&e.push(`Nested preserve blocks detected at line ${a+1} (not supported)`),r<0&&e.push(`Unexpected closing marker at line ${a+1}`)}return{valid:e.length===0,errors:e}}var Xa,Za=k(()=>{"use strict";Xa="<!-- /prjct:preserve -->";l(mk,"createPreserveStartRegex");l(gk,"extractPreservedSections");l(Ya,"mergePreservedSections");l(Qa,"validatePreserveBlocks")});function br(s){if(!s||typeof s!="object")return!1;let e=s;if(e.code&&fk.has(e.code))return!0;if(e.code&&yp.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 jo(s){if(!s||typeof s!="object")return!1;let e=s;return!!(e.code&&yp.has(e.code))}function hp(s,e,t){let n=Pn.get(s);return n&&n.consecutiveFailures>=e&&n.openedAt?Date.now()-n.openedAt>=t?(Pn.delete(s),!1):!0:!1}function ec(s,e){let t=Pn.get(s)||{consecutiveFailures:0,openedAt:null};t.consecutiveFailures++,t.consecutiveFailures>=e&&!t.openedAt&&(t.openedAt=Date.now()),Pn.set(s,t)}function hk(s){Pn.delete(s)}var fk,yp,Pn,Do,wp,vr,Io=k(()=>{"use strict";fk=new Set(["EBUSY","EAGAIN","ETIMEDOUT","ECONNRESET","ECONNREFUSED","ENOTFOUND","EAI_AGAIN"]),yp=new Set(["ENOENT","EACCES","EPERM","EISDIR","ENOTDIR","EINVAL"]);l(br,"isTransientError");l(jo,"isPermanentError");Pn=new Map;l(hp,"isCircuitOpen");l(ec,"recordFailure");l(hk,"recordSuccess");Do=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(hp(t,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs))throw new Error(`Circuit breaker is open for operation: ${t}. Too many consecutive failures.`);let n,r=0;for(;r<this.options.maxAttempts;)try{let o=await e();return hk(t),o}catch(o){if(n=o,r++,jo(o))throw ec(t,this.options.circuitBreakerThreshold),o;if(!(br(o)&&r<this.options.maxAttempts))throw ec(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 ec(t,this.options.circuitBreakerThreshold),n}isTransientError(e){return br(e)}isCircuitOpen(e){return hp(e,this.options.circuitBreakerThreshold,this.options.circuitBreakerTimeoutMs)}getCircuitState(e){return Pn.get(e)}resetCircuit(e){Pn.delete(e)}resetAllCircuits(){Pn.clear()}},wp=new Do({maxAttempts:3,baseDelayMs:1e3,maxDelayMs:8e3}),vr=new Do({maxAttempts:2,baseDelayMs:500,maxDelayMs:2e3})});var Sp=k(()=>{"use strict";Za();Io()});import{exec as yk}from"node:child_process";import{promisify as wk}from"node:util";async function $o(s){try{let{stdout:e}=await Sk(s,{timeout:5e3});return{success:!0,output:e.trim()}}catch{return{success:!1,output:""}}}async function kk(){let s=await $o("gh api user --jq .login");return s.success&&s.output||(s=await $o("git config --global github.user"),s.success&&s.output)?s.output:null}async function bk(){let s=await $o("git config user.name");return s.success&&s.output?s.output:null}async function vk(){let s=await $o("git config user.email");return s.success&&s.output?s.output:null}async function vs(){let[s,e,t]=await Promise.all([kk(),bk(),vk()]);return{github:s,email:t,name:e||s||"Unknown"}}var Sk,Mo=k(()=>{"use strict";Sk=wk(yk);l($o,"execCommand");l(kk,"detectGitHubUsername");l(bk,"detectGitName");l(vk,"detectGitEmail");l(vs,"detect")});import Hn from"node:fs/promises";import Pk from"node:path";import*as Oo from"jsonc-parser";function kp(s){let e=[],t=Oo.parse(s,e,{allowTrailingComma:!0,disallowComments:!1});if(e.length>0){let n=e[0];throw new SyntaxError(`JSON parse error at offset ${n.offset}: ${Oo.printParseErrorCode(n.error)}`)}return t}var nc,Ck,M,Pt=k(()=>{"use strict";rn();L();ce();Dt();Mo();ve();l(kp,"parseJsonc");nc=class{static{l(this,"ConfigManager")}async readConfig(e){try{let t=A.getLocalConfigPath(e),n=await Hn.readFile(t,"utf-8");return kp(n)}catch(t){return C(t)||console.warn(`Warning: Could not read config at ${e}: ${Z(t)}`),null}}async writeConfig(e,t){let n=A.getLocalConfigPath(e),r=A.getLegacyPrjctPath(e);await Hn.mkdir(r,{recursive:!0});let o=JSON.stringify(t,null,2);await Hn.writeFile(n,`${o}
|
|
429
|
+
`,"utf-8")}async readGlobalConfig(e){try{let t=A.getGlobalProjectConfigPath(e),n=await Hn.readFile(t,"utf-8");return kp(n)}catch(t){return C(t)||console.warn(`Warning: Could not read global config for ${e}: ${Z(t)}`),null}}async writeGlobalConfig(e,t){let n=A.getGlobalProjectConfigPath(e),r=A.getGlobalProjectPath(e);await Hn.mkdir(r,{recursive:!0});let o=JSON.stringify(t,null,2);await Hn.writeFile(n,`${o}
|
|
430
|
+
`,"utf-8")}async ensureGlobalConfig(e){let t=await this.readGlobalConfig(e);if(!t){let n=b();t={projectId:e,authors:[],version:De,lastSync:n},await this.writeGlobalConfig(e,t)}return t}async createConfig(e,t){let n=A.generateProjectId(e),r=A.getGlobalProjectPath(n),o=A.getDisplayPath(r),i=b(),a={projectId:n,dataPath:o,showMetrics:!0};await this.writeConfig(e,a);let c={projectId:n,authors:[{name:t.name||"Unknown",email:t.email||"",github:t.github||"",firstContribution:i,lastActivity:i}],version:De,created:i,lastSync:i};return await this.writeGlobalConfig(n,c),a}async updateLastSync(e){let t=await this.getProjectId(e),n=await this.readGlobalConfig(t);n&&(n.lastSync=b(),await this.writeGlobalConfig(t,n))}validateConfig(e){return!(!e||!e.projectId||!e.dataPath)}async needsMigration(e){if(!await A.hasLegacyStructure(e))return!1;if(!await A.hasConfig(e))return!0;let r=await this.readConfig(e);if(!r||!r.projectId)return!0;let o=A.getGlobalProjectPath(r.projectId);try{return(await Hn.readdir(Pk.join(o,"core"))).length===0}catch(i){return C(i),!0}}async getProjectId(e){let t=await this.readConfig(e);return t?.projectId?t.projectId:A.generateProjectId(e)}async findAuthor(e,t){let n=await this.readGlobalConfig(e);return!n||!n.authors?null:n.authors.find(r=>r.github===t)||null}async addAuthor(e,t){let n=await this.ensureGlobalConfig(e);if(n.authors.some(i=>i.github===t.github))return;let o=b();n.authors.push({name:t.name||"Unknown",email:t.email||"",github:t.github||"",firstContribution:o,lastActivity:o}),n.lastSync=o,await this.writeGlobalConfig(e,n)}async updateAuthorActivity(e,t){let n=await this.readGlobalConfig(e);if(!n||!n.authors)return;let r=n.authors.find(o=>o.github===t);r&&(r.lastActivity=b(),n.lastSync=r.lastActivity,await this.writeGlobalConfig(e,n))}async getCurrentAuthor(e){let t=await vs(),n=await this.getProjectId(e);return await this.addAuthor(n,{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 n=await this.readConfig(e);n&&(n.showMetrics=t,await this.writeConfig(e,n))}async getConfigWithDefaults(e){let t=await this.readConfig(e);if(t)return t;let n=A.generateProjectId(e);return{projectId:n,dataPath:A.getDisplayPath(A.getGlobalProjectPath(n))}}},Ck=new nc,M=Ck});import Fo from"node:fs/promises";import sc from"node:path";var rc,bp,vp=k(()=>{"use strict";Pt();ve();L();rc=class{static{l(this,"AgentRouter")}projectId=null;projectPath=null;agentsPath=null;async initialize(e){this.projectId=await M.getProjectId(e),this.projectPath=e,this.agentsPath=A.getFilePath(this.projectId,"agents","")}async loadAvailableAgents(){if(!this.agentsPath)return[];try{let e=await Fo.readdir(this.agentsPath),t=[];for(let n of e)if(n.endsWith(".md")){let r=n.replace(".md",""),o=await Fo.readFile(sc.join(this.agentsPath,n),"utf-8");t.push({name:r,content:o})}return t}catch(e){return C(e)||console.error(`Agent loading error: ${y(e)}`),[]}}async getAgentNames(){return(await this.loadAvailableAgents()).map(t=>t.name)}async loadAgent(e){if(!this.agentsPath)return null;try{let t=sc.join(this.agentsPath,`${e}.md`),n=await Fo.readFile(t,"utf-8");return{name:e,content:n}}catch(t){return C(t)||console.error(`Agent load error: ${y(t)}`),null}}async buildAssignmentContext(e,t){let n=await this.getAgentNames();return{task:typeof e=="string"?e:e.description||"",availableAgents:n,projectPath:t,projectId:this.projectId,_template:"templates/agent-assignment.md"}}async logUsage(e,t,n){try{let r=sc.join(process.env.HOME||"",".prjct-cli","projects",this.projectId||"","agent-usage.jsonl"),o=`${JSON.stringify({timestamp:new Date().toISOString(),task:typeof e=="string"?e:e.description,agent:typeof t=="string"?t:t.name,projectId:this.projectId})}
|
|
431
|
+
`;await Fo.appendFile(r,o)}catch(r){C(r)||console.error(`Agent usage log error: ${y(r)}`)}}},bp=rc});import Pp from"node:path";async function Ek(){if(process.env.CLAUDE_AGENT||process.env.ANTHROPIC_CLAUDE||global.mcp||process.env.MCP_AVAILABLE)return!0;let s=process.cwd();if(await j(Pp.join(s,"CLAUDE.md")))return!0;let e=process.env.HOME||process.env.USERPROFILE||"";if(await j(Pp.join(e,".claude")))return!0;let t=process.cwd();return!!(t.includes("/.claude/")||t.includes("/claude-workspace/"))}function Ak(){return{...xk}}function Rk(){return{...Tk}}async function Cp(){return _o||(_o=await Ek()?Ak():Rk(),_o)}var _o,xk,Tk,xp=k(()=>{"use strict";We();_o=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",agentsDir:"~/.claude/agents",commandsDir:"~/.claude/commands/p"},environment:{hasMCP:!0,sandboxed:!1,persistent:!0,agentSystem:!0}},Tk={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",agentsDir:null,commandsDir:null},environment:{hasMCP:!1,sandboxed:!1,persistent:!0,agentSystem:!1}};l(Ek,"isClaudeEnvironment");l(Ak,"getClaudeAgent");l(Rk,"getTerminalAgent");l(Cp,"detect")});import Pr from"node:fs/promises";var oc,Tp,Ep=k(()=>{"use strict";L();oc=class{static{l(this,"ClaudeAgent")}name;type;constructor(){this.name="Claude Code",this.type="claude"}formatResponse(e,t="info"){let n={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`${n[t]||n.info} ${e}`}async readFile(e){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.read(e)}catch(t){console.warn(`MCP readFile failed, falling back to fs: ${y(t)}`)}return await Pr.readFile(e,"utf8")}async writeFile(e,t){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.write(e,t)}catch(n){console.warn(`MCP writeFile failed, falling back to fs: ${y(n)}`)}await Pr.writeFile(e,t,"utf8")}async listDirectory(e){try{if(global.mcp?.filesystem)return await global.mcp.filesystem.list(e)}catch(t){console.warn(`MCP listDirectory failed, falling back to fs: ${y(t)}`)}return await Pr.readdir(e)}async fileExists(e){try{return await Pr.access(e),!0}catch(t){if(C(t))return!1;throw t}}async createDirectory(e){await Pr.mkdir(e,{recursive:!0})}getTimestamp(){return new Date().toISOString()}formatTaskList(e){return!e||e.length===0?"\u{1F4CB} No tasks queued":`\u{1F4CB} Queue:
|
|
432
432
|
${e.map((t,n)=>`${n+1}. ${t}`).join(`
|
|
433
433
|
`)}`}formatRecap(e){return`\u{1F4CA} Recap
|
|
434
434
|
|
|
@@ -449,7 +449,7 @@ ${e.recentFeatures||""}`}getHelpContent(e){let t={debugging:`\u{1F50D} 1. Isolat
|
|
|
449
449
|
2. Optimize slowest parts
|
|
450
450
|
3. Cache expensive operations`,default:`\u{1F4A1} 1. Break into smaller tasks
|
|
451
451
|
2. Start with simplest part
|
|
452
|
-
3. Ship it`},n=Object.keys(t).find(
|
|
452
|
+
3. Ship it`},n=Object.keys(t).find(r=>e.toLowerCase().includes(r))||"default";return t[n]}suggestNextAction(e){return{taskCompleted:`What's next?
|
|
453
453
|
\u2022 "start [task]" \u2192 Begin working
|
|
454
454
|
\u2022 "ship feature" \u2192 Track & celebrate
|
|
455
455
|
\u2022 "add idea" \u2192 Brainstorm
|
|
@@ -473,143 +473,143 @@ Or type /p:help to see all options`,stuck:`Let's break it down:
|
|
|
473
473
|
|
|
474
474
|
Or: /p:now | /p:task | /p:idea`}[e]||`What would you like to do?
|
|
475
475
|
|
|
476
|
-
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}}},
|
|
476
|
+
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}}},Tp=oc});var jk,No,Ps,Ap=k(()=>{"use strict";vp();rn();xp();Ep();Io();jk=["claude"],No=class{static{l(this,"AgentService")}agent=null;agentInfo=null;agentRouter;constructor(){this.agentRouter=new bp}async initialize(){return this.agent?this.agent:await wp.execute(async()=>{if(this.agentInfo=await Cp(),!this.agentInfo?.isSupported)throw Sr.notSupported(this.agentInfo?.type??"unknown");let e=this.agentInfo.type;if(!e||!jk.includes(e))throw Sr.notSupported(this.agentInfo?.type??"unknown");return this.agent=new Tp,this.agent},"agent-initialization")}getInfo(){return this.agentInfo}getAgent(){return this.agent}isInitialized(){return this.agent!==null}async assignForTask(e,t,n){try{await this.agentRouter.initialize(t);let r=await this.agentRouter.getAgentNames();return r.length===0?{agent:null,routing:{confidence:0,reason:'No specialized agents available. Run "p. sync" to generate agents.',availableAgents:[]},_agenticNote:"AGENTIC: Claude reads orchestrator.md and decides how to proceed"}:{agent:null,routing:{confidence:0,reason:"AGENTIC: Claude will analyze task and select appropriate specialist agents",availableAgents:r},_agenticNote:`
|
|
477
477
|
AGENTIC EXECUTION:
|
|
478
478
|
- Read: templates/agentic/orchestrator.md
|
|
479
479
|
- Analyze task: "${e}"
|
|
480
|
-
- Available specialists: ${
|
|
480
|
+
- Available specialists: ${r.join(", ")}
|
|
481
481
|
- Claude decides which agent(s) to use
|
|
482
482
|
- Always prefer specialists over generalist
|
|
483
483
|
- Fragment complex tasks into subtasks
|
|
484
|
-
`}}catch{return{agent:null,routing:{confidence:0,reason:'Agent routing unavailable - run "p. sync" first',availableAgents:[]},_agenticNote:"AGENTIC: Suggest running p. sync to generate agents"}}}async getAvailableAgents(e){try{return await this.agentRouter.initialize(e),await this.agentRouter.getAgentNames()}catch{return[]}}reset(){this.agent=null,this.agentInfo=null}},
|
|
484
|
+
`}}catch{return{agent:null,routing:{confidence:0,reason:'Agent routing unavailable - run "p. sync" first',availableAgents:[]},_agenticNote:"AGENTIC: Suggest running p. sync to generate agents"}}}async getAvailableAgents(e){try{return await this.agentRouter.initialize(e),await this.agentRouter.getAgentNames()}catch{return[]}}reset(){this.agent=null,this.agentInfo=null}},Ps=new No});var Lo,Gn,ic=k(()=>{"use strict";Lo=class{static{l(this,"BreakdownService")}breakdownFeature(e){return[`Analyze and plan: ${e}`,"Implement core functionality","Test and validate","Document changes"]}detectBugSeverity(e){let t=e.toLowerCase();return t.includes("crash")||t.includes("data loss")||t.includes("security")||t.includes("production down")?"critical":t.includes("broken")||t.includes("not working")||t.includes("error")||t.includes("blocking")?"high":t.includes("minor")||t.includes("cosmetic")||t.includes("typo")||t.includes("polish")?"low":"medium"}estimateComplexity(e){let t=e.split(/\s+/).length;return["refactor","migrate","redesign","overhaul","rewrite","integration","authentication","authorization"].some(o=>e.toLowerCase().includes(o))||t>30?{level:"high",hours:8}:t>10?{level:"medium",hours:4}:{level:"low",hours:1}}detectTaskType(e){let t=e.toLowerCase();return t.includes("bug")||t.includes("fix")||t.includes("error")?"bug":t.includes("refactor")||t.includes("improve")||t.includes("optimize")||t.includes("cleanup")?"improvement":t.includes("update")||t.includes("deps")||t.includes("config")||t.includes("chore")?"chore":"feature"}},Gn=new Lo});import Rp from"node:path";var Ik,$k,Cr,Dp=k(()=>{"use strict";ce();We();Ik=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"],$k=`# Changelog
|
|
485
485
|
|
|
486
486
|
All notable changes to this project will be documented in this file.
|
|
487
487
|
|
|
488
488
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
|
|
489
489
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
490
|
-
`,
|
|
491
|
-
`),{filePath:t,fileName:e,format:"keepachangelog",created:!0}}async addEntry(e){let t=await this.detect(),n=await
|
|
490
|
+
`,Cr=class{static{l(this,"ChangelogService")}projectPath;constructor(e){this.projectPath=e}async detect(){for(let n of Ik){let r=Rp.join(this.projectPath,n);if(await j(r)){let o=await ot(r),i=this.detectFormat(o);return{filePath:r,fileName:n,format:i,created:!1}}}let e="CHANGELOG.md",t=Rp.join(this.projectPath,e);return await Vt(t,`${$k}
|
|
491
|
+
`),{filePath:t,fileName:e,format:"keepachangelog",created:!0}}async addEntry(e){let t=await this.detect(),n=await ot(t.filePath),r=e.date||gs(new Date),o;t.format==="keepachangelog"?o=this.insertKeepAChangelogEntry(n,e,r):o=this.insertMarkdownEntry(n,e,r),await Vt(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,n){let r=this.formatKeepAChangelogEntry(t,n),o=e.search(/^## /m);if(o!==-1){let i=e.slice(0,o),a=e.slice(o);return`${i+r}
|
|
492
492
|
${a}`}return`${e.trimEnd()}
|
|
493
493
|
|
|
494
|
-
${
|
|
494
|
+
${r}`}insertMarkdownEntry(e,t,n){let r=this.formatMarkdownEntry(t,n),o=e.indexOf(`
|
|
495
495
|
`);if(o!==-1){let i=e.slice(0,o+1),a=e.slice(o+1);return`${i}
|
|
496
|
-
${
|
|
497
|
-
${a}`}return`${
|
|
498
|
-
|
|
499
|
-
${e}`}formatKeepAChangelogEntry(e,t){let n=[`## [${e.version}] - ${t}`];if(n.push(""),e.sections)for(let[
|
|
500
|
-
`)}formatMarkdownEntry(e,t){let n=[`## ${e.version} - ${t}`];if(n.push(""),e.sections)for(let[
|
|
501
|
-
`)}}});import Bk from"node:crypto";import zo from"node:fs/promises";import Gp from"node:path";function zp(){return{version:Ut,lastUpdated:"",checksums:{}}}var Ut,Sc,Ze,Rr=k(()=>{"use strict";Pe();F();ce();se();Ut="1.0.0";l(zp,"getDefaultChecksums");Sc=class{static{l(this,"IndexStorage")}getIndexPath(e){return Gp.join(A.getGlobalProjectPath(e),"index")}async ensureIndexDir(e){let t=this.getIndexPath(e);return await zo.mkdir(t,{recursive:!0}),t}async readIndex(e){try{let t=this.getIndexMeta(e,"project-index");if(t!==null)return t.version!==Ut?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 zp()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await zo.readFile(e);return Bk.createHash("md5").update(t).digest("hex")}catch{return""}}async detectChangedFiles(e,t){let s=(await this.readChecksums(e)).checksums,o=[],i=[],a=[];for(let[c,u]of t)c in s?s[c]!==u&&i.push(c):o.push(c);for(let c of Object.keys(s))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 n={version:Ut,lastUpdated:b(),scores:t};this.setIndexMeta(e,"file-scores",n)}async clearIndex(e){try{T.getDb(e).prepare("DELETE FROM index_meta").run()}catch{}let t=this.getIndexPath(e);try{let n=await zo.readdir(t);await Promise.all(n.map(s=>zo.unlink(Gp.join(t,s))))}catch(n){if(!P(n))throw n}}async getIndexAge(e){let t=await this.readIndex(e);if(!t||!t.lastFullScan)return 1/0;let n=new Date(t.lastFullScan);return(new Date().getTime()-n.getTime())/(1e3*60*60)}async readDomains(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null)return t.version!==Ut?null: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!==Ut?null:t}catch{}return null}async writeCategories(e,t){this.setIndexMeta(e,"categories-cache",t)}async getFileCategories(e,t){let n=await this.readCategories(e),s=new Map;if(!n)return s;let o=new Set(t);for(let i of n.fileCategories)o.has(i.path)&&s.set(i.path,i.categories);return s}async getFilesByDomain(e,t){let n=await this.readCategories(e);return n?n.domainIndex[t]||[]:[]}getIndexMeta(e,t){let s=T.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return s?JSON.parse(s.data):null}setIndexMeta(e,t,n){let s=T.getDb(e),o=JSON.stringify(n),i=new Date().toISOString();s.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},Ze=new Sc});var Wp,Jk,Wo,qk,Vp=k(()=>{"use strict";Rr();Wp=8e4,Jk={payments:["payment","pay","stripe","billing","checkout","invoice","subscription","charge","refund","transaction","pricing","price"],auth:["auth","login","logout","signup","sign up","sign in","register","password","session","token","jwt","oauth","sso","permission","role","access","user"],api:["api","endpoint","route","rest","graphql","webhook","request","response","http","fetch","axios"],database:["database","db","model","schema","migration","query","sql","prisma","drizzle","mongoose","sequelize","typeorm"],frontend:["component","page","view","ui","button","form","modal","layout","style","css","react","vue","svelte","html"],testing:["test","spec","unit","e2e","cypress","jest","vitest","mocha","coverage","mock"],integrations:["integration","integrate","connect","sync","webhook","oauth","linear","jira","github","slack","discord"],config:["config","configuration","setting","env","environment","setup"],utilities:["util","utility","helper","lib","common","shared","tool"],services:["service","handler","processor","worker","job","queue","cron"],types:["type","interface","dto","schema","definition"]},Wo=class{static{l(this,"ContextSelector")}CHARS_PER_TOKEN=4;async selectForTask(e,t,n={}){let s=n.maxFiles||50,o=n.minScore||30,i=n.includeGeneral!==!1,a=n.tokenBudget||Wp,[c,u,d]=await Promise.all([Ze.readIndex(t),Ze.readDomains(t),Ze.readCategories(t)]);if(!c||!u||!d)return this.fallbackSelection(c?.relevantFiles||[],n);let m=this.detectTaskDomains(e,u.domains),p=new Set;for(let E of m){let N=d.domainIndex[E]||[];for(let ne of N)p.add(ne)}if(i&&d.domainIndex.general){let E=d.domainIndex.general.slice(0,10);for(let N of E)p.add(N)}let g=c.relevantFiles.filter(E=>p.has(E.path)&&E.score>=o);g.sort((E,N)=>N.score-E.score);let f=0,S=[];for(let E of g){let N=Math.ceil(E.size/this.CHARS_PER_TOKEN);if(f+N>a||S.length>=s)break;S.push(E),f+=N}let y=Math.ceil(c.relevantFiles.reduce((E,N)=>E+N.size,0)/this.CHARS_PER_TOKEN),C=y>0?(y-f)/y:0;return{files:S,domains:m,metrics:{totalFiles:c.relevantFiles.length,selectedFiles:S.length,compressionRate:C,estimatedTokensSaved:y-f}}}detectTaskDomains(e,t){let n=e.toLowerCase(),s=new Set;for(let[o,i]of Object.entries(Jk))for(let a of i)if(n.includes(a)){s.add(o);break}for(let o of t){if(n.includes(o.name.toLowerCase())){s.add(o.name);continue}for(let i of o.keywords)if(n.includes(i.toLowerCase())){s.add(o.name);break}}return s.size===0&&(s.add("services"),s.add("api")),Array.from(s)}async filterByDomains(e,t,n){let s=await Ze.readCategories(e);if(!s)return n||[];let o=new Set;for(let a of t){let c=s.domainIndex[a]||[];for(let u of c)o.add(u)}if(n)return n.filter(a=>o.has(a.path));let i=await Ze.readIndex(e);return i?i.relevantFiles.filter(a=>o.has(a.path)):[]}async getFilesDomains(e,t){return Ze.getFileCategories(e,t)}fallbackSelection(e,t){let n=t.maxFiles||50,s=t.minScore||30,o=t.tokenBudget||Wp,i=e.filter(d=>d.score>=s).sort((d,m)=>m.score-d.score),a=0,c=[];for(let d of i){let m=Math.ceil(d.size/this.CHARS_PER_TOKEN);if(a+m>o||c.length>=n)break;c.push(d),a+=m}let u=Math.ceil(e.reduce((d,m)=>d+m.size,0)/this.CHARS_PER_TOKEN);return{files:c,domains:[],metrics:{totalFiles:e.length,selectedFiles:c.length,compressionRate:u>0?(u-a)/u:0,estimatedTokensSaved:u-a}}}suggestRelatedDomains(e){let t=new Set,n={payments:["api","database","services"],auth:["api","database","users"],api:["services","types"],database:["types","services"],frontend:["types","utilities"],testing:["services","api"]};for(let s of e){let o=n[s];if(o)for(let i of o)e.includes(i)||t.add(i)}return Array.from(t)}},qk=new Wo});import{execFile as Kk}from"node:child_process";import kc from"node:fs/promises";import Bp from"node:os";import bc from"node:path";import{promisify as Xk}from"node:util";function Zk(){let r=he("mcp-config.json");if(!r)return{mcpServers:{context7:vc}};try{return JSON.parse(r)}catch{return{mcpServers:{context7:vc}}}}function Kp(){return Zk().mcpServers?.context7||vc}function Jp(){return process.env.PRJCT_CONTEXT7_CONFIG?process.env.PRJCT_CONTEXT7_CONFIG:process.env.NODE_ENV==="test"?bc.join(Bp.tmpdir(),"prjct-context7-test","mcp.json"):bc.join(Bp.homedir(),".claude","mcp.json")}async function qp(r){try{let e=await kc.readFile(r,"utf-8");return JSON.parse(e)}catch(e){if(P(e))return{};throw e}}async function eb(){if(process.env.PRJCT_SKIP_CONTEXT7_SMOKE==="1"||process.env.NODE_ENV==="test")return;let r=Kp(),e=[...r.args||[],"--help"];await Yk(r.command||"npx",e,{timeout:15e3})}var Yk,vc,Qk,Es,Pc,Xp,pn,As=k(()=>{"use strict";Zt();F();Yk=Xk(Kk),vc={command:"npx",args:["-y","@upstash/context7-mcp@latest"]},Qk=300*1e3,Es=null;l(Zk,"parseTemplateConfig");l(Kp,"getContext7Config");l(Jp,"getConfigPath");l(qp,"readConfig");l(eb,"runSmokeCheck");Pc=class{static{l(this,"Context7Service")}async install(){let e=Jp(),t=bc.dirname(e);await kc.mkdir(t,{recursive:!0});let n=await qp(e),s=n.mcpServers||{};return s.context7=Kp(),n.mcpServers=s,await kc.writeFile(e,JSON.stringify(n,null,2),"utf-8"),Es=null,{installed:!0,verified:!1,configPath:e,message:"Context7 MCP configured"}}async verify(){if(Es&&Date.now()-Es.at<Qk)return Es.status;let e=Jp(),s=((await qp(e)).mcpServers||{}).context7;if(!s?.command||!Array.isArray(s.args)||s.args.length===0)return{installed:!1,verified:!1,configPath:e,message:"Context7 MCP not configured in ~/.claude/mcp.json"};try{await eb();let o={installed:!0,verified:!0,configPath:e};return Es={at:Date.now(),status:o},o}catch(o){let i={installed:!0,verified:!1,configPath:e,message:`Context7 smoke check failed: ${w(o)}`};return Es={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}},Xp=new Pc,pn=Xp});import Yp from"node:path";var Cc,Vo,tb,Qp=k(()=>{"use strict";Rr();ce();Cc=[{pattern:/\b(payment|stripe|billing|checkout|invoice)/i,domain:"payments"},{pattern:/\b(auth|login|signup|user|session|password|oauth)/i,domain:"auth"},{pattern:/\b(api|endpoint|route|controller)/i,domain:"api"},{pattern:/\b(model|schema|migration|database|db|prisma|drizzle)/i,domain:"database"},{pattern:/\b(component|page|view|layout|ui|button|form|modal)/i,domain:"frontend"},{pattern:/\b(test|spec|__tests__|e2e|cypress)/i,domain:"testing"},{pattern:/\b(config|setting|env)/i,domain:"config"},{pattern:/\b(util|helper|lib|common|shared)/i,domain:"utilities"},{pattern:/\b(service|handler|processor|worker)/i,domain:"services"},{pattern:/\b(type|interface|dto)/i,domain:"types"}],Vo=class{static{l(this,"FileCategorizer")}batchSize;maxDomains;constructor(e={}){this.batchSize=e.batchSize||20,this.maxDomains=e.maxDomains||15}async analyzeProject(e,t,n={}){let s=n.useLLM!==!1,o=s?await this.discoverDomainsWithLLM(e,t):this.discoverDomainsHeuristic(t),i=s?await this.categorizeFilesWithLLM(t,o):this.categorizeFilesHeuristic(t,o);for(let a of o)a.fileCount=i.filter(c=>c.primaryDomain===a.name).length;return n.projectId&&await this.saveToCache(n.projectId,o,i),{domains:o,categories:i,metrics:{totalFiles:t.length,categorizedFiles:i.length,domainsDiscovered:o.length,llmCalls:s?Math.ceil(t.length/this.batchSize)+1:0,usedHeuristics:!s}}}async discoverDomainsWithLLM(e,t){return this.discoverDomainsHeuristic(t)}async categorizeFilesWithLLM(e,t){return this.categorizeFilesHeuristic(e,t)}discoverDomainsHeuristic(e){let t=new Map,n=new Map;for(let i of e){let a=i.path.toLowerCase();for(let{pattern:c,domain:u}of Cc)if(c.test(a)){t.set(u,(t.get(u)||0)+1),n.has(u)||n.set(u,new Set);let d=Yp.dirname(i.path);n.get(u).add(`**/${Yp.basename(d)}/**`)}}let s=this.extractDirectoryDomains(e);for(let[i,a]of s)t.set(i,(t.get(i)||0)+a);let o=[];for(let[i,a]of t)if(a>=2){let c=Cc.find(u=>u.domain===i);o.push({name:i,description:`Files related to ${i}`,keywords:c?[i]:[i],filePatterns:Array.from(n.get(i)||[]),fileCount:a})}return o.sort((i,a)=>a.fileCount-i.fileCount).slice(0,this.maxDomains)}extractDirectoryDomains(e){let t=new Map;for(let n of e){let s=n.path.split("/");for(let o of s.slice(0,-1)){let i=o.toLowerCase();["src","lib","app","core","dist","build"].includes(i)||i.length>2&&!i.startsWith(".")&&t.set(i,(t.get(i)||0)+1)}}return t}categorizeFilesHeuristic(e,t){let n=[],s=b();for(let o of e){let i=[],a=o.path.toLowerCase();for(let m of t){let p=0;for(let g of m.keywords)a.includes(g.toLowerCase())&&(p+=1);for(let{pattern:g,domain:f}of Cc)f===m.name&&g.test(a)&&(p+=2);for(let g of m.filePatterns){let f=g.replace(/\*\*/g,"").replace(/\//g,"");a.includes(f.toLowerCase())&&(p+=1)}p>0&&i.push({domain:m.name,score:p})}i.sort((m,p)=>p.score-m.score);let c=i.length>0?i.slice(0,3).map(m=>m.domain):["general"],u=c[0],d=i.length>0?Math.min(1,i[0].score/5):.1;n.push({path:o.path,categories:c,primaryDomain:u,confidence:d,categorizedAt:s,method:"heuristic"})}return n}async saveToCache(e,t,n){let s=b(),o={version:Ut,projectId:e,domains:t,discoveredAt:s};await Ze.writeDomains(e,o);let i={};for(let c of n)for(let u of c.categories)i[u]||(i[u]=[]),i[u].push(c.path);let a={version:Ut,lastUpdate:s,fileCategories:n,domainIndex:i};await Ze.writeCategories(e,a)}async loadFromCache(e){let[t,n]=await Promise.all([Ze.readDomains(e),Ze.readCategories(e)]);return!t||!n?null:{domains:t.domains,categories:n.fileCategories,metrics:{totalFiles:n.fileCategories.length,categorizedFiles:n.fileCategories.length,domainsDiscovered:t.domains.length,llmCalls:0,usedHeuristics:n.fileCategories[0]?.method==="heuristic"}}}async updateFilesCategories(e,t,n={}){let s=await Ze.readDomains(e);if(!s)return(await this.analyzeProject("",t,{...n,projectId:e})).categories;let o=n.useLLM!==!1?await this.categorizeFilesWithLLM(t,s.domains):this.categorizeFilesHeuristic(t,s.domains),i=await Ze.readCategories(e);if(i){let a=new Set(t.map(p=>p.path)),u=[...i.fileCategories.filter(p=>!a.has(p.path)),...o],d={};for(let p of u)for(let g of p.categories)d[g]||(d[g]=[]),d[g].push(p.path);let m={version:Ut,lastUpdate:b(),fileCategories:u,domainIndex:d};await Ze.writeCategories(e,m)}return o}},tb=new Vo});import xc from"node:path";var Tc,nb,sb,Bo,Zp,Ec=k(()=>{"use strict";Tc=30,nb=[/^package\.json$/,/^tsconfig.*\.json$/,/^\.env(\..*)?$/,/^\.eslintrc.*$/,/^\.prettierrc.*$/,/^vite\.config\.\w+$/,/^next\.config\.\w+$/,/^webpack\.config\.\w+$/,/^rollup\.config\.\w+$/,/^jest\.config\.\w+$/,/^vitest\.config\.\w+$/,/^tailwind\.config\.\w+$/,/^postcss\.config\.\w+$/,/^Cargo\.toml$/,/^go\.mod$/,/^pyproject\.toml$/,/^requirements\.txt$/,/^Dockerfile$/,/^docker-compose\.ya?ml$/,/^\.github\/workflows\/.*\.ya?ml$/],sb=[/^index\.\w+$/,/^main\.\w+$/,/^app\.\w+$/,/^server\.\w+$/,/^router\.\w+$/,/^routes\.\w+$/,/^api\.\w+$/,/^schema\.\w+$/,/^types?\.\w+$/,/^constants?\.\w+$/,/^config\.\w+$/,/^utils?\.\w+$/,/^helpers?\.\w+$/,/README\.md$/i,/CHANGELOG\.md$/i],Bo=class{static{l(this,"FileScorer")}scoreFile(e,t){let n={recency:this.calculateRecency(e,t),centrality:this.calculateCentrality(e,t),configRelevance:this.calculateConfigRelevance(e),nameRelevance:this.calculateNameRelevance(e),sizeOptimal:this.calculateSizeOptimal(e,t),gitActivity:this.calculateGitActivity(e,t)},s=Object.values(n).reduce((o,i)=>o+i,0);return{path:e.path,score:Math.min(100,Math.max(0,s)),factors:n}}scoreAll(e){let t=[];for(let n of e.allFiles.values())t.push(this.scoreFile(n,e));return t.sort((n,s)=>s.score-n.score)}getRelevantFiles(e,t=Tc){return this.scoreAll(e).filter(n=>n.score>=t)}calculateRecency(e,t){let n=(t.now.getTime()-e.mtime.getTime())/864e5;return n<1?20:n<7?15:n<30?10:n<90?5:0}calculateCentrality(e,t){let n=e.importedBy?.length||0,s=t.allFiles.size;if(s===0)return 0;let o=n/s;return o>=.2?25:o>=.1?20:o>=.05?15:n>=5?10:n>=2?5:0}calculateConfigRelevance(e){let t=xc.basename(e.path);for(let n of nb)if(n.test(t)||n.test(e.path))return 20;return 0}calculateNameRelevance(e){let t=xc.basename(e.path);for(let s of sb)if(s.test(t))return 15;let n=xc.dirname(e.path);return n.includes("/api/")||n.includes("/routes/")||n.includes("/components/")&&t.startsWith("index")?10:n.includes("/pages/")||n.includes("/app/")?8:0}calculateSizeOptimal(e,t){let n=e.size;return n<100?2:n>=500&&n<=5e4?10:n>5e4&&n<=2e5?5:n>2e5?0:5}calculateGitActivity(e,t){let n=e.recentCommits||0;if(t.maxRecentCommits===0)return 0;let s=n/t.maxRecentCommits;return s>=.5?10:s>=.25?7:s>=.1?5:n>0?2:0}},Zp=new Bo});function Is(r){let e=`PRJCT_TIMEOUT_${r}`,t=process.env[e];if(t){let n=Number.parseInt(t,10);if(!Number.isNaN(n)&&n>0)return n}return rb[r]}var re,Ac,Ic,Jo,rb,Ht,em,An=k(()=>{"use strict";re={GATHERING:"gathering",ANALYZING:"analyzing",PROPOSING:"proposing",PENDING_APPROVAL:"awaiting_approval",APPROVED:"approved",REJECTED:"rejected",EXECUTING:"executing",COMPLETED:"completed",ABORTED:"aborted"},Ac=["feature","spec","design","refactor","migrate"],Ic=["ship","cleanup","git","migrate"],Jo=["Read","Glob","Grep","GetTimestamp","GetDate","GetDateTime"],rb={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};l(Is,"getTimeout");Ht={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},em={HISTORY_MAX:100}});function Rc(r,e){return{...mr[r],...e}}function qo(r,e,t){return{message:r,hint:e,...t}}var Ko=k(()=>{"use strict";lo();lo();l(Rc,"getError");l(qo,"createError")});import{execSync as Dc}from"node:child_process";var Xo,jc,Yo,Rs,Qo=k(()=>{"use strict";Ko();Xo={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"}},jc=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 n=Xo[e];if(!n)return this.checkUnknownTool(e);let s=this.executeCheck(n);return this.setCache(e,s),s}ensureTool(e){let t=this.checkTool(e);if(!t.available){let n=Xo[e],s=t.error||{message:`${e} is not available`,hint:n?.installHint||`Install ${e} and try again`,docs:n?.docs};throw new Yo(s)}}ensureTools(e){let t=[];for(let n of e)this.checkTool(n).available||t.push(n);if(t.length>0){let n=t.map(s=>{let o=Xo[s];return o?` ${s}: ${o.installHint}`:` ${s}: Install and try again`}).join(`
|
|
502
|
-
`);throw new
|
|
503
|
-
${n}`})}}isAvailable(e){return this.checkTool(e).available}getVersion(e){return this.checkTool(e).version}checkAll(e){let t=e||Object.keys(Xo),n=new Map;for(let s of t)n.set(s,this.checkTool(s));return n}clearCache(){this.cache.clear(),this.cacheTimestamps.clear()}executeCheck(e){try{let t=Dc(e.command,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),n;if(e.versionRegex){let s=t.match(e.versionRegex);n=s?s[1]:void 0}return{available:!0,version:n}}catch{return{available:!1,error:qo(`${e.name} is not installed or not in PATH`,e.installHint,{docs:e.docs})}}}checkUnknownTool(e){try{return Dc(`${e} --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{try{return Dc(`${e} -v`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{return{available:!1,error:qo(`${e} is not installed or not in PATH`,`Install ${e} and try again`)}}}}getCached(e){let t=this.cacheTimestamps.get(e);return t?Date.now()-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())}},Yo=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}},Rs=new jc});import{exec as ob}from"node:child_process";import{promisify as ib}from"node:util";var _0,tm=k(()=>{"use strict";An();Qo();_0=ib(ob)});var en,$c,Tt,In=k(()=>{"use strict";Dt();ce();se();en={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},$c=class{static{l(this,"ArchiveStorage")}archive(e,t){let n=me(),s=b();return T.run(e,"INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)",n,t.entityType,t.entityId,JSON.stringify(t.entityData),t.summary??null,s,t.reason),n}archiveMany(e,t){if(t.length===0)return 0;let n=b();return T.transaction(e,s=>{let o=s.prepare("INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)");for(let i of t)o.run(me(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,n,i.reason)}),t.length}getArchived(e,t,n=50){return t?T.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,n):T.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",n)}getStats(e){let t=T.query(e,"SELECT entity_type, COUNT(*) as count FROM archives GROUP BY entity_type"),n={shipped:0,idea:0,queue_task:0,paused_task:0,memory_entry:0,total:0};for(let s of t){let o=s.entity_type;o in n&&(n[o]=s.count),n.total+=s.count}return n}restore(e,t){let n=T.get(e,"SELECT * FROM archives WHERE id = ?",t);return n?(T.run(e,"DELETE FROM archives WHERE id = ?",t),JSON.parse(n.entity_data)):null}pruneOldArchives(e,t){let n=new Date(Date.now()-t*24*60*60*1e3).toISOString(),s=this.getTotalCount(e);T.run(e,"DELETE FROM archives WHERE archived_at < ?",n);let o=this.getTotalCount(e);return s-o}getTotalCount(e){return T.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},Tt=new $c});var Zo,wt,Mc=k(()=>{"use strict";xt();In();se();Zo=class{static{l(this,"MemoryService")}async log(e,t,n,s){try{let o=await M.getProjectId(e);if(!o)return;G.appendEvent(o,`memory.${t}`,{...n,author:s})}catch(o){console.error(`Memory log error: ${o instanceof Error?o.message:String(o)}`)}}async getRecent(e,t=100){try{let n=await M.getProjectId(e);return n?G.query(n,"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(n){return console.error(`Memory read error: ${n instanceof Error?n.message:String(n)}`),[]}}async search(e,t,n=50){let s=await this.getRecent(e,1e3),o=t.toLowerCase();return s.filter(i=>{let a=i.action.toLowerCase().includes(o),c=JSON.stringify(i.data).toLowerCase().includes(o);return a||c}).slice(-n)}async getByAction(e,t,n=50){try{let s=await M.getProjectId(e);return s?G.query(s,"SELECT type, data, timestamp FROM events WHERE type = ? ORDER BY id DESC LIMIT ?",`memory.${t}`,n).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(s){return console.error(`Memory read error: ${s instanceof Error?s.message:String(s)}`),[]}}async clear(e){try{let t=await M.getProjectId(e);if(!t)return;G.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 G.query(e,"SELECT type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id DESC LIMIT ?",t).reverse().map(s=>{let o=JSON.parse(s.data);return{timestamp:s.timestamp,action:s.type.replace("memory.",""),...o}})}catch(n){return console.error(`Memory read error: ${n instanceof Error?n.message:String(n)}`),[]}}async capEntries(e){try{let n=G.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(n<=en.MEMORY_MAX_ENTRIES)return 0;let s=n-en.MEMORY_MAX_ENTRIES,o=G.query(e,"SELECT id, type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?",s);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&&G.run(e,"DELETE FROM events WHERE type LIKE 'memory.%' AND id <= ?",i),s}catch(t){return console.error(`Memory cap error: ${t instanceof Error?t.message:String(t)}`),0}}},wt=new Zo});var nm=k(()=>{"use strict";Pe();Ue()});import{execSync as ab}from"node:child_process";import cb from"node:fs/promises";import ei from"node:path";function lb(r){return r.trim().toLowerCase()}async function ub(r){try{return await cb.access(r),!0}catch{return!1}}function db(){let r=process.env.PRJCT_P_RESOLVER_PACKAGE_ROOT;if(r)return r;try{let e=Sn.resolve("prjct-cli/package.json");return ei.dirname(e)}catch{return null}}function pb(){let r=process.env.PRJCT_P_RESOLVER_NPM_ROOT;if(r)return r;if(process.env.PRJCT_P_RESOLVER_DISABLE_NPM_ROOT==="1")return null;try{return ab("npm root -g",{encoding:"utf-8",stdio:["pipe","pipe","ignore"],timeout:5e3}).trim().replace(/\r?\n/g,"")}catch{return null}}function mb(){return process.env.PRJCT_P_RESOLVER_LOCAL_ROOT||ge}function gb(){let r=[],e=db();e&&r.push({source:"package-resolve",root:e});let t=pb();return t&&r.push({source:"npm-root-g",root:ei.join(t,"prjct-cli")}),r.push({source:"local-dev",root:mb()}),r}function fb(){let e=Tn("commands/").filter(t=>t.endsWith(".md")).map(t=>ei.basename(t,".md")).filter(t=>t!=="p");return Array.from(new Set(e)).sort()}function _c(r){return r instanceof Error&&typeof r.code=="string"&&typeof r.message=="string"}var Dr,Oc,Fc,Nc=k(()=>{"use strict";Zt();jt();Dr=class extends Error{static{l(this,"PCommandResolverError")}code;fix;constructor(e,t,n){super(t),this.name="PCommandResolverError",this.code=e,this.fix=n}};l(lb,"normalizeCommand");l(ub,"fileExists");l(db,"getPackageResolveRoot");l(pb,"getNpmGlobalRoot");l(mb,"getLocalDevRoot");l(gb,"getCandidateRoots");l(fb,"getCatalogFromTemplates");Oc=class{static{l(this,"PCommandResolver")}getPCommandCatalog(){return fb()}validatePCommand(e){let t=lb(e);return/^[a-z][a-z0-9-]*$/.test(t)?this.getPCommandCatalog().includes(t)?{valid:!0,command:t}:{valid:!1,command:t,code:"UNKNOWN_COMMAND",message:`Unknown command: p. ${t}`}:{valid:!1,command:t,code:"UNKNOWN_COMMAND",message:`Invalid p. command "${e}"`}}async resolvePCommandTemplate(e){if(this.getPCommandCatalog().length===0)throw new Dr("ROUTER_NOT_READY","p. router command catalog is empty",["Run `prjct setup` to reinstall command templates"]);let t=this.validatePCommand(e);if(!t.valid)throw new Dr(t.code||"UNKNOWN_COMMAND",t.message||`Unknown command: p. ${t.command}`,[`Use one of: ${this.getPCommandCatalog().join(", ")}`,"Run `prjct setup` to refresh command templates"]);if(!process.env.PRJCT_P_RESOLVER_DISABLE_BUNDLE){let n=`commands/${t.command}.md`;if(he(n))return{command:t.command,templatePath:n,source:"bundle"}}for(let n of gb()){let s=ei.join(n.root,"templates","commands",`${t.command}.md`);if(await ub(s))return{command:t.command,templatePath:s,source:n.source}}throw new Dr("TEMPLATE_NOT_FOUND",`Template not found for p. ${t.command}`,["Run `prjct start` to repair Codex skill and command templates","Run `prjct setup` to refresh installation"])}};l(_c,"isPCommandResolveError");Fc=new Oc});import{createHash as hb}from"node:crypto";import rm from"node:fs/promises";import Uc from"node:path";function Jn(r){return r.toLowerCase().replace(/[^a-z0-9]+/g,"")}function wb(r){let e=Uc.resolve(r);return hb("sha256").update(e).digest("hex").slice(0,16)}function ti(r){let e=he(r);if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t.items)?t.items:[]}catch{return[]}}async function Sb(r){let e=[],t=[r];for(;t.length>0&&e.length<sm;){let n=t.pop();if(!n)break;let s=await rm.readdir(n,{withFileTypes:!0});for(let o of s){if(e.length>=sm)break;let i=Uc.join(n,o.name);if(o.isDirectory()){yb.has(o.name)||t.push(i);continue}o.isFile()&&/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java)$/.test(o.name)&&e.push(i)}}return e}async function kb(r,e){let t=[],n=[],s=!1,o=!1,i=!1,a=0,c=0,u=0;for(let d of e){let m=Uc.relative(r,d),p=await rm.readFile(d,"utf-8");/from\s+['"]next\/image['"]/.test(p)&&(s=!0),(/from\s+['"]@?heroui\//.test(p)||/from\s+['"]@nextui-org\//.test(p))&&(o=!0),/<UiButton\b|from\s+['"][^'"]*UiButton[^'"]*['"]/.test(p)&&(i=!0);let g=p.match(/:\s*any\b|<\s*any\s*>/g);g&&(a+=g.length,n.push({issue:"Unbounded any usage",file:m,suggestion:"Replace with specific types or justified unknown + narrowing.",severity:"high",language:"TypeScript",source:"repo",confidence:.92}));let f=p.match(/@ts-ignore/g);f&&(c+=f.length,n.push({issue:"Unchecked @ts-ignore usage",file:m,suggestion:"Use @ts-expect-error with reason or refactor typings.",severity:"medium",language:"TypeScript",source:"repo",confidence:.88})),/\.(tsx|jsx)$/.test(d)&&/<img\s+/.test(p)&&!/next\/image/.test(p)&&(u+=1,n.push({issue:"Raw <img> in React/Next component",file:m,suggestion:"Prefer framework image component or documented exception.",severity:"medium",framework:"Next.js",source:"repo",confidence:.8}))}return s&&t.push({name:"Image rendering via next/image",description:"Project uses next/image for optimized image delivery.",location:"app/** or src/**",framework:"Next.js",source:"repo",confidence:.9}),o&&t.push({name:"HeroUI as component system",description:"UI components are sourced from HeroUI/NextUI packages.",location:"components/**",source:"repo",confidence:.87}),i&&t.push({name:"Use UiButton abstraction",description:"Buttons are wrapped in UiButton instead of native button in app UI.",location:"components/**",source:"repo",confidence:.84}),(a>0||c>0||u>0)&&t.push({name:"Strict type/lint hygiene",description:`Detected ${a} any, ${c} ts-ignore, ${u} raw img potential violations.`,source:"repo",confidence:.76}),{patterns:t,antiPatterns:n}}function bb(r){let e=new Set,t=[];for(let n of r){let s=`${Jn(n.name)}::${Jn(n.source)}`;e.has(s)||(e.add(s),t.push(n))}return t}function vb(r){let e=new Set,t=[];for(let n of r){let s=`${Jn(n.issue)}::${Jn(n.file)}::${Jn(n.source)}`;e.has(s)||(e.add(s),t.push(n))}return t}var yb,sm,Lc,om,im,Hc=k(()=>{"use strict";Zt();se();yb=new Set([".git","node_modules",".next","dist","build","coverage",".turbo",".cache"]),sm=400;l(Jn,"normalizeKey");l(wb,"repoHash");l(ti,"parseBaselineFile");l(Sb,"listSourceFiles");l(kb,"detectRepoRules");l(bb,"dedupePatterns");l(vb,"dedupeAntiPatterns");Lc=class{static{l(this,"PatternExtractor")}async extract(e){let t=wb(e.projectPath),n=await Sb(e.projectPath),s=[],o=[];for(let p of e.languages){let g=Jn(p),f=ti(`baseline/patterns/${g}.json`),S=ti(`baseline/anti-patterns/${g}.json`);s.push(...f.map(y=>({...y,language:p,source:"baseline",confidence:y.confidence??.8}))),o.push(...S.map(y=>({...y,file:y.file||"multiple",language:p,source:"baseline",confidence:y.confidence??.8})))}for(let p of e.frameworks){let g=Jn(p),f=ti(`baseline/patterns/${g}.json`),S=ti(`baseline/anti-patterns/${g}.json`);s.push(...f.map(y=>({...y,framework:p,source:"baseline",confidence:y.confidence??.82}))),o.push(...S.map(y=>({...y,file:y.file||"multiple",framework:p,source:"baseline",confidence:y.confidence??.82}))),e.context7Verified&&s.push({name:`${p} API validation via Context7`,description:`Validate ${p} APIs against current documentation through Context7 before implementation.`,framework:p,source:"context7",confidence:.7})}let i=await kb(e.projectPath,n),a=(e.feedback?.patternsDiscovered||[]).map(p=>({name:p,description:`Confirmed during completed tasks: ${p}`,source:"feedback",confidence:.75})),c=(e.feedback?.knownGotchas||[]).map(p=>({issue:p,file:"multiple",suggestion:`Recurring gotcha. Prevent this pattern during implementation: ${p}`,source:"feedback",severity:"medium",confidence:.7})),u=bb([...s,...i.patterns,...a]),d=vb([...o,...i.antiPatterns,...c]),m=`analysis:derived-rules:${t}`;return T.setDoc(e.projectId,m,{projectId:e.projectId,repoPathHash:t,patterns:u,antiPatterns:d,updatedAt:new Date().toISOString(),version:1}),{patterns:u,antiPatterns:d,repoPathHash:t}}},om=new Lc,im=om});import{exec as Cb}from"node:child_process";import{promisify as xb}from"node:util";var y$,am=k(()=>{"use strict";Rr();ce();Ec();y$=xb(Cb)});import qn from"chalk";var cm,Tb,Eb,Gt,lm=k(()=>{"use strict";qe();cm=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],Tb=80,Eb={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:cm,speed:Tb},cli:{header:l(()=>`${qn.cyan.bold("\u26A1")} ${qn.cyan("prjct")}`,"header"),footer:l(()=>qn.dim("\u26A1 prjct"),"footer"),spin:l((r,e)=>`${qn.cyan("\u26A1")} ${qn.cyan("prjct")} ${qn.cyan(cm[r%10])} ${qn.dim(e||"")}`,"spin")},template:{header:"\u26A1 prjct",footer:"\u26A1 prjct"},commitFooter:"Generated with [p/](https://www.prjct.app/)",urls:{website:"https://prjct.app",docs:"https://prjct.app/docs"},getCommitFooter:l((r="claude")=>fo(r).commitFooter,"getCommitFooter"),getSignature:l((r="claude")=>fo(r).signature,"getSignature")},Gt=Eb});import ie from"chalk";function Rb(){return Ab[Ib]}var A$,Gc,Ab,Ib,Kn,Ds,zc,Et,Rn,Db,jb,h,Xn=k(()=>{"use strict";lm();An();Ko();Ko();A$=Gt.spinner.frames,Gc=Gt.spinner.speed,Ab={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}},Ib="compact";l(Rb,"getTierConfig");Kn={success:ie.green("\u2713"),fail:ie.red("\u2717"),warn:ie.yellow("\u26A0"),info:ie.blue("\u2139"),debug:ie.dim("\u{1F527}"),bullet:ie.dim("\u2022"),arrow:ie.dim("\u2192"),check:ie.green("\u2713"),cross:ie.red("\u2717"),spinner:ie.cyan("\u25D0")},Ds=null,zc=0,Et=!1,Rn=l((r,e)=>{let t=e??(Rb().maxCharsPerLine||Ht.FALLBACK_TRUNCATE);return r&&r.length>t?`${r.slice(0,t-1)}\u2026`:r||""},"truncate"),Db=l(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(Ht.CLEAR_WIDTH)}\r`):!0,"clear"),jb={start(){return Et||console.log(Gt.cli.header()),this},end(){return Et||console.log(Gt.cli.footer()),this},spin(r){return Et?this:(this.stop(),process.stdout.isTTY?(Ds=setInterval(()=>{process.stdout.write(`\r${Gt.cli.spin(zc++,Rn(r,Ht.SPINNER_MSG))}`)},Gc),this):(process.stdout.write(`${Gt.cli.spin(0,Rn(r,Ht.SPINNER_MSG))}
|
|
504
|
-
`),this))},done(
|
|
505
|
-
`),n=Math.max(
|
|
506
|
-
${ie.bold(
|
|
507
|
-
`),this)},progress(
|
|
508
|
-
`),this)}},h=
|
|
509
|
-
|
|
510
|
-
No changes between runs.`;let e=[];e.push("## Analysis Diff"),(
|
|
511
|
-
`)}function
|
|
512
|
-
`)}function jr(r,e,t,n){let s=new Set(e),o=new Set(t);for(let i of t)s.has(i)||n.push({field:r,type:"added",after:i});for(let i of e)o.has(i)||n.push({field:r,type:"removed",before:i})}var Vc=k(()=>{"use strict";l(um,"generateAnalysisDiff");l(Wc,"formatAnalysisDiffMd");l(dm,"formatAnalysisDiffText");l(jr,"diffStringArray")});function Mb(){let r=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!r)return{level:-1,name:"disabled"};if($b.has(r)||r.includes("prjct"))return{level:js.debug,name:"debug"};let e=js[r]??-1,t=e>=0?r:"disabled";return{level:e,name:t}}function ni(r,e,t){return pm>=r?(...n)=>console[t](e,...n):_b}var js,$b,pm,Ob,_b,Fb,H,Dn=k(()=>{"use strict";js={error:0,warn:1,info:2,debug:3},$b=new Set(["1","true","*"]);l(Mb,"getLogLevel");({level:pm,name:Ob}=Mb()),_b=l(()=>{},"noop");l(ni,"createLogMethod");Fb={error:ni(js.error,"[prjct:error]","error"),warn:ni(js.warn,"[prjct:warn]","warn"),info:ni(js.info,"[prjct:info]","log"),debug:ni(js.debug,"[prjct:debug]","log"),isEnabled:l(()=>pm>=0,"isEnabled"),level:l(()=>Ob,"level")},H=Fb});var si,et,$s,mm=k(()=>{"use strict";un();se();Ea();An();Dn();si=class{static{l(this,"EventBus")}listeners;onceListeners;history;historyLimit;projectId;constructor(){this.listeners=new Map,this.onceListeners=new Map,this.history=[],this.historyLimit=em.HISTORY_MAX,this.projectId=null}async initialize(e){this.projectId=e}on(e,t){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(t),()=>this.off(e,t)}once(e,t){return this.onceListeners.has(e)||this.onceListeners.set(e,new Set),this.onceListeners.get(e).add(t),()=>{let n=this.onceListeners.get(e);n&&n.delete(t)}}off(e,t){let n=this.listeners.get(e);n&&n.delete(t)}async emit(e,t={}){let n=new Date().toISOString(),s={type:e,timestamp:n,projectId:this.projectId,...t};this.history.push(s),this.history.length>this.historyLimit&&this.history.shift(),this.projectId&&await this.logEvent(s);let o=this.getMatchingListeners(e);(await Promise.allSettled(o.map(u=>this.executeCallback(u,s)))).forEach(u=>{u.status==="rejected"&&H.error(`Event listener error for ${e}:`,u.reason)});let a=this.onceListeners.get(e);if(a){for(let u of a)await this.executeCallback(u,s);this.onceListeners.delete(e)}let c=this.onceListeners.get(Le.ALL);if(c)for(let u of c)await this.executeCallback(u,s)}getMatchingListeners(e){let t=[],n=this.listeners.get(e);n&&t.push(...n);let s=this.listeners.get(Le.ALL);s&&t.push(...s);let o=e.split(".")[0],i=this.listeners.get(`${o}.*`);return i&&t.push(...i),t}async executeCallback(e,t){try{let n=e(t);n instanceof Promise&&await n}catch(n){throw H.error("Event callback error:",n),n}}async logEvent(e){try{T.appendEvent(this.projectId,e.type,e)}catch(t){H.debug("Failed to log event:",Z(t))}}getHistory(e=10,t=null){let n=this.history;return t&&(n=n.filter(s=>s.type===t||s.type.startsWith(t))),n.slice(-e)}clear(){this.listeners.clear(),this.onceListeners.clear()}flush(){this.history=[],this.onceListeners.clear()}removeAllListeners(e){e?(this.listeners.delete(e),this.onceListeners.delete(e)):(this.listeners.clear(),this.onceListeners.clear())}listenerCount(e){let t=this.listeners.get(e);return t?t.size:0}getRegisteredEvents(){return Array.from(this.listeners.keys())}},et=new si,$s={sessionStarted:l(r=>et.emit(Le.SESSION_STARTED,r),"sessionStarted"),sessionPaused:l(r=>et.emit(Le.SESSION_PAUSED,r),"sessionPaused"),sessionResumed:l(r=>et.emit(Le.SESSION_RESUMED,r),"sessionResumed"),sessionCompleted:l(r=>et.emit(Le.SESSION_COMPLETED,r),"sessionCompleted"),taskCreated:l(r=>et.emit(Le.TASK_CREATED,r),"taskCreated"),taskCompleted:l(r=>et.emit(Le.TASK_COMPLETED,r),"taskCompleted"),featureAdded:l(r=>et.emit(Le.FEATURE_ADDED,r),"featureAdded"),featureShipped:l(r=>et.emit(Le.FEATURE_SHIPPED,r),"featureShipped"),ideaCaptured:l(r=>et.emit(Le.IDEA_CAPTURED,r),"ideaCaptured"),snapshotCreated:l(r=>et.emit(Le.SNAPSHOT_CREATED,r),"snapshotCreated"),snapshotRestored:l(r=>et.emit(Le.SNAPSHOT_RESTORED,r),"snapshotRestored"),commitCreated:l(r=>et.emit(Le.COMMIT_CREATED,r),"commitCreated"),pushCompleted:l(r=>et.emit(Le.PUSH_COMPLETED,r),"pushCompleted"),projectInitialized:l(r=>et.emit(Le.PROJECT_INITIALIZED,r),"projectInitialized"),projectSynced:l(r=>et.emit(Le.PROJECT_SYNCED,r),"projectSynced"),analysisCompleted:l(r=>et.emit(Le.ANALYSIS_COMPLETED,r),"analysisCompleted")}});var ri,oi,gm=k(()=>{"use strict";Pe();ce();Ue();ri=class{static{l(this,"SyncEventBus")}async publish(e){let t=A.getSyncPendingPath(e.projectId),n=await Kt(t,[])??[];n.push(e),await Ln(t,n)}async getPending(e){let t=A.getSyncPendingPath(e);return await Kt(t,[])??[]}async clearPending(e){let t=A.getSyncPendingPath(e);await Ln(t,[])}async updateLastSync(e){let t=A.getLastSyncPath(e),n={timestamp:b(),success:!0};await Ln(t,n)}async getLastSync(e){let t=A.getLastSyncPath(e);return await Kt(t,null)}},oi=new ri});var ii=k(()=>{"use strict";mm();gm()});var zt,ai=k(()=>{"use strict";zt=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((n,s)=>n[1].timestamp-s[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[n]of t)this.cache.delete(n)}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 Be,tn=k(()=>{"use strict";ii();ai();ce();se();Be=class{static{l(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new zt({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 n=T.getDoc(e,this.getStoreKey());if(n!==null)return this.cache.set(e,n),n}catch{}return this.getDefault()}async write(e,t){T.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let n=await this.read(e),s=t(n);return await this.write(e,s),s}async publishEvent(e,t,n){let s={type:t,path:[this.filename.replace(".json","")],data:n,timestamp:b(),projectId:e};await oi.publish(s)}async publishEntityEvent(e,t,n,s){let o=`${t}.${n}`,i={...s,timestamp:b()};await this.publishEvent(e,o,i)}async exists(e){try{return T.hasDoc(e,this.getStoreKey())}catch{return!1}}clearCache(e){e?this.cache.delete(e):this.cache.clear()}getCacheStats(){return this.cache.stats()}}});import{createHash as Lb}from"node:crypto";var Bc,Je,$r=k(()=>{"use strict";za();Vc();ce();tn();Bc=class extends Be{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 n={...t,status:"draft"};Ga.parse(n),await this.update(e,s=>({...s,draft:n,lastUpdated:b()})),await this.publishEntityEvent(e,"analysis","drafted",{commitHash:n.commitHash,fileCount:n.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 n=this.computeSignature(t.draft),s=b(),o={...t.draft,status:"sealed",signature:n,sealedAt:s};return Ga.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:s}),await this.publishEntityEvent(e,"analysis","sealed",{commitHash:o.commitHash,signature:n}),{success:!0,signature:n}}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 n=b();return await this.write(e,{draft:t.sealed,sealed:t.previousSealed,previousSealed:null,lastUpdated:n}),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:um(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 n=this.computeSignature({...t.sealed,signature:void 0,sealedAt:void 0});return n===t.sealed.signature?{valid:!0,message:"Signature verified. Analysis integrity confirmed."}:{valid:!1,message:`Signature mismatch. Expected ${n}, got ${t.sealed.signature}. Analysis may have been modified.`}}async semanticVerify(e,t){let n=await this.read(e),s=n.sealed??n.draft;return s?await Fd(s,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 Lb("sha256").update(JSON.stringify(t)).digest("hex")}},Je=new Bc});var Jc,Mr,fm=k(()=>{"use strict";se();Jc=class{static{l(this,"ContextFeedbackStorage")}recordSuggestions(e,t,n,s){T.run(e,`INSERT INTO context_feedback (task_id, keywords, suggested_files, created_at)
|
|
513
|
-
VALUES (?, ?, ?, ?)`,t,JSON.stringify(n),JSON.stringify(
|
|
496
|
+
${r}
|
|
497
|
+
${a}`}return`${r}
|
|
498
|
+
|
|
499
|
+
${e}`}formatKeepAChangelogEntry(e,t){let n=[`## [${e.version}] - ${t}`];if(n.push(""),e.sections)for(let[r,o]of Object.entries(e.sections)){n.push(`### ${r}`);for(let i of o)n.push(`- ${i}`);n.push("")}else e.description&&(n.push("### Added"),n.push(`- ${e.description}`),n.push(""));return n.join(`
|
|
500
|
+
`)}formatMarkdownEntry(e,t){let n=[`## ${e.version} - ${t}`];if(n.push(""),e.sections)for(let[r,o]of Object.entries(e.sections)){n.push(`### ${r}`);for(let i of o)n.push(`- ${i}`);n.push("")}else e.description&&(n.push(`- ${e.description}`),n.push(""));return n.join(`
|
|
501
|
+
`)}}});import Mk from"node:crypto";import Uo from"node:fs/promises";import jp from"node:path";function Ip(){return{version:_t,lastUpdated:"",checksums:{}}}var _t,ac,Ze,xr=k(()=>{"use strict";ve();L();ce();oe();_t="1.0.0";l(Ip,"getDefaultChecksums");ac=class{static{l(this,"IndexStorage")}getIndexPath(e){return jp.join(A.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!==_t?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 Ip()}async writeChecksums(e,t){this.setIndexMeta(e,"checksums",t)}async calculateChecksum(e){try{let t=await Uo.readFile(e);return Mk.createHash("md5").update(t).digest("hex")}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 n={version:_t,lastUpdated:b(),scores:t};this.setIndexMeta(e,"file-scores",n)}async clearIndex(e){try{E.getDb(e).prepare("DELETE FROM index_meta").run()}catch{}let t=this.getIndexPath(e);try{let n=await Uo.readdir(t);await Promise.all(n.map(r=>Uo.unlink(jp.join(t,r))))}catch(n){if(!C(n))throw n}}async getIndexAge(e){let t=await this.readIndex(e);if(!t||!t.lastFullScan)return 1/0;let n=new Date(t.lastFullScan);return(new Date().getTime()-n.getTime())/(1e3*60*60)}async readDomains(e){try{let t=this.getIndexMeta(e,"domains");if(t!==null)return t.version!==_t?null: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!==_t?null:t}catch{}return null}async writeCategories(e,t){this.setIndexMeta(e,"categories-cache",t)}async getFileCategories(e,t){let n=await this.readCategories(e),r=new Map;if(!n)return r;let o=new Set(t);for(let i of n.fileCategories)o.has(i.path)&&r.set(i.path,i.categories);return r}async getFilesByDomain(e,t){let n=await this.readCategories(e);return n?n.domainIndex[t]||[]:[]}getIndexMeta(e,t){let r=E.getDb(e).prepare("SELECT data FROM index_meta WHERE key = ?").get(t);return r?JSON.parse(r.data):null}setIndexMeta(e,t,n){let r=E.getDb(e),o=JSON.stringify(n),i=new Date().toISOString();r.prepare("INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)").run(t,o,i)}},Ze=new ac});var $p,Ok,Ho,Fk,Mp=k(()=>{"use strict";xr();$p=8e4,Ok={payments:["payment","pay","stripe","billing","checkout","invoice","subscription","charge","refund","transaction","pricing","price"],auth:["auth","login","logout","signup","sign up","sign in","register","password","session","token","jwt","oauth","sso","permission","role","access","user"],api:["api","endpoint","route","rest","graphql","webhook","request","response","http","fetch","axios"],database:["database","db","model","schema","migration","query","sql","prisma","drizzle","mongoose","sequelize","typeorm"],frontend:["component","page","view","ui","button","form","modal","layout","style","css","react","vue","svelte","html"],testing:["test","spec","unit","e2e","cypress","jest","vitest","mocha","coverage","mock"],integrations:["integration","integrate","connect","sync","webhook","oauth","linear","jira","github","slack","discord"],config:["config","configuration","setting","env","environment","setup"],utilities:["util","utility","helper","lib","common","shared","tool"],services:["service","handler","processor","worker","job","queue","cron"],types:["type","interface","dto","schema","definition"]},Ho=class{static{l(this,"ContextSelector")}CHARS_PER_TOKEN=4;async selectForTask(e,t,n={}){let r=n.maxFiles||50,o=n.minScore||30,i=n.includeGeneral!==!1,a=n.tokenBudget||$p,[c,u,d]=await Promise.all([Ze.readIndex(t),Ze.readDomains(t),Ze.readCategories(t)]);if(!c||!u||!d)return this.fallbackSelection(c?.relevantFiles||[],n);let m=this.detectTaskDomains(e,u.domains),p=new Set;for(let T of m){let _=d.domainIndex[T]||[];for(let ne of _)p.add(ne)}if(i&&d.domainIndex.general){let T=d.domainIndex.general.slice(0,10);for(let _ of T)p.add(_)}let g=c.relevantFiles.filter(T=>p.has(T.path)&&T.score>=o);g.sort((T,_)=>_.score-T.score);let f=0,S=[];for(let T of g){let _=Math.ceil(T.size/this.CHARS_PER_TOKEN);if(f+_>a||S.length>=r)break;S.push(T),f+=_}let w=Math.ceil(c.relevantFiles.reduce((T,_)=>T+_.size,0)/this.CHARS_PER_TOKEN),v=w>0?(w-f)/w:0;return{files:S,domains:m,metrics:{totalFiles:c.relevantFiles.length,selectedFiles:S.length,compressionRate:v,estimatedTokensSaved:w-f}}}detectTaskDomains(e,t){let n=e.toLowerCase(),r=new Set;for(let[o,i]of Object.entries(Ok))for(let a of i)if(n.includes(a)){r.add(o);break}for(let o of t){if(n.includes(o.name.toLowerCase())){r.add(o.name);continue}for(let i of o.keywords)if(n.includes(i.toLowerCase())){r.add(o.name);break}}return r.size===0&&(r.add("services"),r.add("api")),Array.from(r)}async filterByDomains(e,t,n){let r=await Ze.readCategories(e);if(!r)return n||[];let o=new Set;for(let a of t){let c=r.domainIndex[a]||[];for(let u of c)o.add(u)}if(n)return n.filter(a=>o.has(a.path));let i=await Ze.readIndex(e);return i?i.relevantFiles.filter(a=>o.has(a.path)):[]}async getFilesDomains(e,t){return Ze.getFileCategories(e,t)}fallbackSelection(e,t){let n=t.maxFiles||50,r=t.minScore||30,o=t.tokenBudget||$p,i=e.filter(d=>d.score>=r).sort((d,m)=>m.score-d.score),a=0,c=[];for(let d of i){let m=Math.ceil(d.size/this.CHARS_PER_TOKEN);if(a+m>o||c.length>=n)break;c.push(d),a+=m}let u=Math.ceil(e.reduce((d,m)=>d+m.size,0)/this.CHARS_PER_TOKEN);return{files:c,domains:[],metrics:{totalFiles:e.length,selectedFiles:c.length,compressionRate:u>0?(u-a)/u:0,estimatedTokensSaved:u-a}}}suggestRelatedDomains(e){let t=new Set,n={payments:["api","database","services"],auth:["api","database","users"],api:["services","types"],database:["types","services"],frontend:["types","utilities"],testing:["services","api"]};for(let r of e){let o=n[r];if(o)for(let i of o)e.includes(i)||t.add(i)}return Array.from(t)}},Fk=new Ho});import{execFile as _k}from"node:child_process";import cc from"node:fs/promises";import Op from"node:os";import lc from"node:path";import{promisify as Nk}from"node:util";function Hk(){let s=he("mcp-config.json");if(!s)return{mcpServers:{context7:uc}};try{return JSON.parse(s)}catch{return{mcpServers:{context7:uc}}}}function Np(){return Hk().mcpServers?.context7||uc}function Fp(){return process.env.PRJCT_CONTEXT7_CONFIG?process.env.PRJCT_CONTEXT7_CONFIG:process.env.NODE_ENV==="test"?lc.join(Op.tmpdir(),"prjct-context7-test","mcp.json"):lc.join(Op.homedir(),".claude","mcp.json")}async function _p(s){try{let e=await cc.readFile(s,"utf-8");return JSON.parse(e)}catch(e){if(C(e))return{};throw e}}async function Gk(){if(process.env.PRJCT_SKIP_CONTEXT7_SMOKE==="1"||process.env.NODE_ENV==="test")return;let s=Np(),e=[...s.args||[],"--help"];await Lk(s.command||"npx",e,{timeout:15e3})}var Lk,uc,Uk,Cs,dc,Lp,an,xs=k(()=>{"use strict";qt();L();Lk=Nk(_k),uc={command:"npx",args:["-y","@upstash/context7-mcp@latest"]},Uk=300*1e3,Cs=null;l(Hk,"parseTemplateConfig");l(Np,"getContext7Config");l(Fp,"getConfigPath");l(_p,"readConfig");l(Gk,"runSmokeCheck");dc=class{static{l(this,"Context7Service")}async install(){let e=Fp(),t=lc.dirname(e);await cc.mkdir(t,{recursive:!0});let n=await _p(e),r=n.mcpServers||{};return r.context7=Np(),n.mcpServers=r,await cc.writeFile(e,JSON.stringify(n,null,2),"utf-8"),Cs=null,{installed:!0,verified:!1,configPath:e,message:"Context7 MCP configured"}}async verify(){if(Cs&&Date.now()-Cs.at<Uk)return Cs.status;let e=Fp(),r=((await _p(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 Gk();let o={installed:!0,verified:!0,configPath:e};return Cs={at:Date.now(),status:o},o}catch(o){let i={installed:!0,verified:!1,configPath:e,message:`Context7 smoke check failed: ${y(o)}`};return Cs={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}},Lp=new dc,an=Lp});import Up from"node:path";var pc,Go,Wk,Hp=k(()=>{"use strict";xr();ce();pc=[{pattern:/\b(payment|stripe|billing|checkout|invoice)/i,domain:"payments"},{pattern:/\b(auth|login|signup|user|session|password|oauth)/i,domain:"auth"},{pattern:/\b(api|endpoint|route|controller)/i,domain:"api"},{pattern:/\b(model|schema|migration|database|db|prisma|drizzle)/i,domain:"database"},{pattern:/\b(component|page|view|layout|ui|button|form|modal)/i,domain:"frontend"},{pattern:/\b(test|spec|__tests__|e2e|cypress)/i,domain:"testing"},{pattern:/\b(config|setting|env)/i,domain:"config"},{pattern:/\b(util|helper|lib|common|shared)/i,domain:"utilities"},{pattern:/\b(service|handler|processor|worker)/i,domain:"services"},{pattern:/\b(type|interface|dto)/i,domain:"types"}],Go=class{static{l(this,"FileCategorizer")}batchSize;maxDomains;constructor(e={}){this.batchSize=e.batchSize||20,this.maxDomains=e.maxDomains||15}async analyzeProject(e,t,n={}){let r=n.useLLM!==!1,o=r?await this.discoverDomainsWithLLM(e,t):this.discoverDomainsHeuristic(t),i=r?await this.categorizeFilesWithLLM(t,o):this.categorizeFilesHeuristic(t,o);for(let a of o)a.fileCount=i.filter(c=>c.primaryDomain===a.name).length;return n.projectId&&await this.saveToCache(n.projectId,o,i),{domains:o,categories:i,metrics:{totalFiles:t.length,categorizedFiles:i.length,domainsDiscovered:o.length,llmCalls:r?Math.ceil(t.length/this.batchSize)+1:0,usedHeuristics:!r}}}async discoverDomainsWithLLM(e,t){return this.discoverDomainsHeuristic(t)}async categorizeFilesWithLLM(e,t){return this.categorizeFilesHeuristic(e,t)}discoverDomainsHeuristic(e){let t=new Map,n=new Map;for(let i of e){let a=i.path.toLowerCase();for(let{pattern:c,domain:u}of pc)if(c.test(a)){t.set(u,(t.get(u)||0)+1),n.has(u)||n.set(u,new Set);let d=Up.dirname(i.path);n.get(u).add(`**/${Up.basename(d)}/**`)}}let r=this.extractDirectoryDomains(e);for(let[i,a]of r)t.set(i,(t.get(i)||0)+a);let o=[];for(let[i,a]of t)if(a>=2){let c=pc.find(u=>u.domain===i);o.push({name:i,description:`Files related to ${i}`,keywords:c?[i]:[i],filePatterns:Array.from(n.get(i)||[]),fileCount:a})}return o.sort((i,a)=>a.fileCount-i.fileCount).slice(0,this.maxDomains)}extractDirectoryDomains(e){let t=new Map;for(let n of e){let r=n.path.split("/");for(let o of r.slice(0,-1)){let i=o.toLowerCase();["src","lib","app","core","dist","build"].includes(i)||i.length>2&&!i.startsWith(".")&&t.set(i,(t.get(i)||0)+1)}}return t}categorizeFilesHeuristic(e,t){let n=[],r=b();for(let o of e){let i=[],a=o.path.toLowerCase();for(let m of t){let p=0;for(let g of m.keywords)a.includes(g.toLowerCase())&&(p+=1);for(let{pattern:g,domain:f}of pc)f===m.name&&g.test(a)&&(p+=2);for(let g of m.filePatterns){let f=g.replace(/\*\*/g,"").replace(/\//g,"");a.includes(f.toLowerCase())&&(p+=1)}p>0&&i.push({domain:m.name,score:p})}i.sort((m,p)=>p.score-m.score);let c=i.length>0?i.slice(0,3).map(m=>m.domain):["general"],u=c[0],d=i.length>0?Math.min(1,i[0].score/5):.1;n.push({path:o.path,categories:c,primaryDomain:u,confidence:d,categorizedAt:r,method:"heuristic"})}return n}async saveToCache(e,t,n){let r=b(),o={version:_t,projectId:e,domains:t,discoveredAt:r};await Ze.writeDomains(e,o);let i={};for(let c of n)for(let u of c.categories)i[u]||(i[u]=[]),i[u].push(c.path);let a={version:_t,lastUpdate:r,fileCategories:n,domainIndex:i};await Ze.writeCategories(e,a)}async loadFromCache(e){let[t,n]=await Promise.all([Ze.readDomains(e),Ze.readCategories(e)]);return!t||!n?null:{domains:t.domains,categories:n.fileCategories,metrics:{totalFiles:n.fileCategories.length,categorizedFiles:n.fileCategories.length,domainsDiscovered:t.domains.length,llmCalls:0,usedHeuristics:n.fileCategories[0]?.method==="heuristic"}}}async updateFilesCategories(e,t,n={}){let r=await Ze.readDomains(e);if(!r)return(await this.analyzeProject("",t,{...n,projectId:e})).categories;let o=n.useLLM!==!1?await this.categorizeFilesWithLLM(t,r.domains):this.categorizeFilesHeuristic(t,r.domains),i=await Ze.readCategories(e);if(i){let a=new Set(t.map(p=>p.path)),u=[...i.fileCategories.filter(p=>!a.has(p.path)),...o],d={};for(let p of u)for(let g of p.categories)d[g]||(d[g]=[]),d[g].push(p.path);let m={version:_t,lastUpdate:b(),fileCategories:u,domainIndex:d};await Ze.writeCategories(e,m)}return o}},Wk=new Go});import mc from"node:path";var gc,zk,Vk,Wo,Gp,fc=k(()=>{"use strict";gc=30,zk=[/^package\.json$/,/^tsconfig.*\.json$/,/^\.env(\..*)?$/,/^\.eslintrc.*$/,/^\.prettierrc.*$/,/^vite\.config\.\w+$/,/^next\.config\.\w+$/,/^webpack\.config\.\w+$/,/^rollup\.config\.\w+$/,/^jest\.config\.\w+$/,/^vitest\.config\.\w+$/,/^tailwind\.config\.\w+$/,/^postcss\.config\.\w+$/,/^Cargo\.toml$/,/^go\.mod$/,/^pyproject\.toml$/,/^requirements\.txt$/,/^Dockerfile$/,/^docker-compose\.ya?ml$/,/^\.github\/workflows\/.*\.ya?ml$/],Vk=[/^index\.\w+$/,/^main\.\w+$/,/^app\.\w+$/,/^server\.\w+$/,/^router\.\w+$/,/^routes\.\w+$/,/^api\.\w+$/,/^schema\.\w+$/,/^types?\.\w+$/,/^constants?\.\w+$/,/^config\.\w+$/,/^utils?\.\w+$/,/^helpers?\.\w+$/,/README\.md$/i,/CHANGELOG\.md$/i],Wo=class{static{l(this,"FileScorer")}scoreFile(e,t){let n={recency:this.calculateRecency(e,t),centrality:this.calculateCentrality(e,t),configRelevance:this.calculateConfigRelevance(e),nameRelevance:this.calculateNameRelevance(e),sizeOptimal:this.calculateSizeOptimal(e,t),gitActivity:this.calculateGitActivity(e,t)},r=Object.values(n).reduce((o,i)=>o+i,0);return{path:e.path,score:Math.min(100,Math.max(0,r)),factors:n}}scoreAll(e){let t=[];for(let n of e.allFiles.values())t.push(this.scoreFile(n,e));return t.sort((n,r)=>r.score-n.score)}getRelevantFiles(e,t=gc){return this.scoreAll(e).filter(n=>n.score>=t)}calculateRecency(e,t){let n=(t.now.getTime()-e.mtime.getTime())/864e5;return n<1?20:n<7?15:n<30?10:n<90?5:0}calculateCentrality(e,t){let n=e.importedBy?.length||0,r=t.allFiles.size;if(r===0)return 0;let o=n/r;return o>=.2?25:o>=.1?20:o>=.05?15:n>=5?10:n>=2?5:0}calculateConfigRelevance(e){let t=mc.basename(e.path);for(let n of zk)if(n.test(t)||n.test(e.path))return 20;return 0}calculateNameRelevance(e){let t=mc.basename(e.path);for(let r of Vk)if(r.test(t))return 15;let n=mc.dirname(e.path);return n.includes("/api/")||n.includes("/routes/")||n.includes("/components/")&&t.startsWith("index")?10:n.includes("/pages/")||n.includes("/app/")?8:0}calculateSizeOptimal(e,t){let n=e.size;return n<100?2:n>=500&&n<=5e4?10:n>5e4&&n<=2e5?5:n>2e5?0:5}calculateGitActivity(e,t){let n=e.recentCommits||0;if(t.maxRecentCommits===0)return 0;let r=n/t.maxRecentCommits;return r>=.5?10:r>=.25?7:r>=.1?5:n>0?2:0}},Gp=new Wo});function Ts(s){let e=`PRJCT_TIMEOUT_${s}`,t=process.env[e];if(t){let n=Number.parseInt(t,10);if(!Number.isNaN(n)&&n>0)return n}return Bk[s]}var se,hc,yc,zo,Bk,Nt,Wp,Cn=k(()=>{"use strict";se={GATHERING:"gathering",ANALYZING:"analyzing",PROPOSING:"proposing",PENDING_APPROVAL:"awaiting_approval",APPROVED:"approved",REJECTED:"rejected",EXECUTING:"executing",COMPLETED:"completed",ABORTED:"aborted"},hc=["feature","spec","design","refactor","migrate"],yc=["ship","cleanup","git","migrate"],zo=["Read","Glob","Grep","GetTimestamp","GetDate","GetDateTime"],Bk={TOOL_CHECK:5e3,GIT_OPERATION:1e4,GIT_CLONE:6e4,API_REQUEST:3e4,NPM_INSTALL:12e4,WORKFLOW_HOOK:6e4};l(Ts,"getTimeout");Nt={SPINNER_MSG:45,DONE_MSG:50,FAIL_MSG:65,WARN_MSG:65,STEP_MSG:35,PROGRESS_TEXT:25,ISSUE_TITLE:50,FALLBACK_TRUNCATE:50,CLEAR_WIDTH:80},Wp={HISTORY_MAX:100}});function wc(s,e){return{...cr[s],...e}}function Vo(s,e,t){return{message:s,hint:e,...t}}var Bo=k(()=>{"use strict";io();io();l(wc,"getError");l(Vo,"createError")});import{execSync as Sc}from"node:child_process";var Jo,kc,qo,Es,Ko=k(()=>{"use strict";Bo();Jo={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"}},kc=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 n=Jo[e];if(!n)return this.checkUnknownTool(e);let r=this.executeCheck(n);return this.setCache(e,r),r}ensureTool(e){let t=this.checkTool(e);if(!t.available){let n=Jo[e],r=t.error||{message:`${e} is not available`,hint:n?.installHint||`Install ${e} and try again`,docs:n?.docs};throw new qo(r)}}ensureTools(e){let t=[];for(let n of e)this.checkTool(n).available||t.push(n);if(t.length>0){let n=t.map(r=>{let o=Jo[r];return o?` ${r}: ${o.installHint}`:` ${r}: Install and try again`}).join(`
|
|
502
|
+
`);throw new qo({message:`Missing required tools: ${t.join(", ")}`,hint:`Install the following:
|
|
503
|
+
${n}`})}}isAvailable(e){return this.checkTool(e).available}getVersion(e){return this.checkTool(e).version}checkAll(e){let t=e||Object.keys(Jo),n=new Map;for(let r of t)n.set(r,this.checkTool(r));return n}clearCache(){this.cache.clear(),this.cacheTimestamps.clear()}executeCheck(e){try{let t=Sc(e.command,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),n;if(e.versionRegex){let r=t.match(e.versionRegex);n=r?r[1]:void 0}return{available:!0,version:n}}catch{return{available:!1,error:Vo(`${e.name} is not installed or not in PATH`,e.installHint,{docs:e.docs})}}}checkUnknownTool(e){try{return Sc(`${e} --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}),{available:!0}}catch{try{return Sc(`${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?Date.now()-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())}},qo=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}},Es=new kc});import{exec as Jk}from"node:child_process";import{promisify as qk}from"node:util";var m0,zp=k(()=>{"use strict";Cn();Ko();m0=qk(Jk)});var Kt,bc,Ct,xn=k(()=>{"use strict";Rt();ce();oe();Kt={SHIPPED_RETENTION_DAYS:90,IDEA_DORMANT_DAYS:180,QUEUE_COMPLETED_DAYS:7,PAUSED_TASK_DAYS:30,MEMORY_MAX_ENTRIES:500},bc=class{static{l(this,"ArchiveStorage")}archive(e,t){let n=me(),r=b();return E.run(e,"INSERT INTO archives (id, entity_type, entity_id, entity_data, summary, archived_at, reason) VALUES (?, ?, ?, ?, ?, ?, ?)",n,t.entityType,t.entityId,JSON.stringify(t.entityData),t.summary??null,r,t.reason),n}archiveMany(e,t){if(t.length===0)return 0;let n=b();return E.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(me(),i.entityType,i.entityId,JSON.stringify(i.entityData),i.summary??null,n,i.reason)}),t.length}getArchived(e,t,n=50){return t?E.query(e,"SELECT * FROM archives WHERE entity_type = ? ORDER BY archived_at DESC LIMIT ?",t,n):E.query(e,"SELECT * FROM archives ORDER BY archived_at DESC LIMIT ?",n)}getStats(e){let t=E.query(e,"SELECT entity_type, COUNT(*) as count FROM archives GROUP BY entity_type"),n={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 n&&(n[o]=r.count),n.total+=r.count}return n}restore(e,t){let n=E.get(e,"SELECT * FROM archives WHERE id = ?",t);return n?(E.run(e,"DELETE FROM archives WHERE id = ?",t),JSON.parse(n.entity_data)):null}pruneOldArchives(e,t){let n=new Date(Date.now()-t*24*60*60*1e3).toISOString(),r=this.getTotalCount(e);E.run(e,"DELETE FROM archives WHERE archived_at < ?",n);let o=this.getTotalCount(e);return r-o}getTotalCount(e){return E.get(e,"SELECT COUNT(*) as count FROM archives")?.count??0}},Ct=new bc});var Xo,yt,vc=k(()=>{"use strict";Pt();xn();oe();Xo=class{static{l(this,"MemoryService")}async log(e,t,n,r){try{let o=await M.getProjectId(e);if(!o)return;G.appendEvent(o,`memory.${t}`,{...n,author:r})}catch(o){console.error(`Memory log error: ${o instanceof Error?o.message:String(o)}`)}}async getRecent(e,t=100){try{let n=await M.getProjectId(e);return n?G.query(n,"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(n){return console.error(`Memory read error: ${n instanceof Error?n.message:String(n)}`),[]}}async search(e,t,n=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(-n)}async getByAction(e,t,n=50){try{let r=await M.getProjectId(e);return r?G.query(r,"SELECT type, data, timestamp FROM events WHERE type = ? ORDER BY id DESC LIMIT ?",`memory.${t}`,n).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 M.getProjectId(e);if(!t)return;G.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 G.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(n){return console.error(`Memory read error: ${n instanceof Error?n.message:String(n)}`),[]}}async capEntries(e){try{let n=G.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(n<=Kt.MEMORY_MAX_ENTRIES)return 0;let r=n-Kt.MEMORY_MAX_ENTRIES,o=G.query(e,"SELECT id, type, data, timestamp FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?",r);Ct.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&&G.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}}},yt=new Xo});var Vp=k(()=>{"use strict";ve();We()});import{execSync as Kk}from"node:child_process";import Xk from"node:fs/promises";import Yo from"node:path";function Yk(s){return s.trim().toLowerCase()}async function Qk(s){try{return await Xk.access(s),!0}catch{return!1}}function Zk(){let s=process.env.PRJCT_P_RESOLVER_PACKAGE_ROOT;if(s)return s;try{let e=fn.resolve("prjct-cli/package.json");return Yo.dirname(e)}catch{return null}}function eb(){let s=process.env.PRJCT_P_RESOLVER_NPM_ROOT;if(s)return s;if(process.env.PRJCT_P_RESOLVER_DISABLE_NPM_ROOT==="1")return null;try{return Kk("npm root -g",{encoding:"utf-8",stdio:["pipe","pipe","ignore"],timeout:5e3}).trim().replace(/\r?\n/g,"")}catch{return null}}function tb(){return process.env.PRJCT_P_RESOLVER_LOCAL_ROOT||ge}function nb(){let s=[],e=Zk();e&&s.push({source:"package-resolve",root:e});let t=eb();return t&&s.push({source:"npm-root-g",root:Yo.join(t,"prjct-cli")}),s.push({source:"local-dev",root:tb()}),s}function sb(){let e=vn("commands/").filter(t=>t.endsWith(".md")).map(t=>Yo.basename(t,".md")).filter(t=>t!=="p");return Array.from(new Set(e)).sort()}function Cc(s){return s instanceof Error&&typeof s.code=="string"&&typeof s.message=="string"}var Tr,Pc,xc,Tc=k(()=>{"use strict";qt();Dt();Tr=class extends Error{static{l(this,"PCommandResolverError")}code;fix;constructor(e,t,n){super(t),this.name="PCommandResolverError",this.code=e,this.fix=n}};l(Yk,"normalizeCommand");l(Qk,"fileExists");l(Zk,"getPackageResolveRoot");l(eb,"getNpmGlobalRoot");l(tb,"getLocalDevRoot");l(nb,"getCandidateRoots");l(sb,"getCatalogFromTemplates");Pc=class{static{l(this,"PCommandResolver")}getPCommandCatalog(){return sb()}validatePCommand(e){let t=Yk(e);return/^[a-z][a-z0-9-]*$/.test(t)?this.getPCommandCatalog().includes(t)?{valid:!0,command:t}:{valid:!1,command:t,code:"UNKNOWN_COMMAND",message:`Unknown command: p. ${t}`}:{valid:!1,command:t,code:"UNKNOWN_COMMAND",message:`Invalid p. command "${e}"`}}async resolvePCommandTemplate(e){if(this.getPCommandCatalog().length===0)throw new Tr("ROUTER_NOT_READY","p. router command catalog is empty",["Run `prjct setup` to reinstall command templates"]);let t=this.validatePCommand(e);if(!t.valid)throw new Tr(t.code||"UNKNOWN_COMMAND",t.message||`Unknown command: p. ${t.command}`,[`Use one of: ${this.getPCommandCatalog().join(", ")}`,"Run `prjct setup` to refresh command templates"]);if(!process.env.PRJCT_P_RESOLVER_DISABLE_BUNDLE){let n=`commands/${t.command}.md`;if(he(n))return{command:t.command,templatePath:n,source:"bundle"}}for(let n of nb()){let r=Yo.join(n.root,"templates","commands",`${t.command}.md`);if(await Qk(r))return{command:t.command,templatePath:r,source:n.source}}throw new Tr("TEMPLATE_NOT_FOUND",`Template not found for p. ${t.command}`,["Run `prjct start` to repair Codex skill and command templates","Run `prjct setup` to refresh installation"])}};l(Cc,"isPCommandResolveError");xc=new Pc});import{createHash as rb}from"node:crypto";import Jp from"node:fs/promises";import Ac from"node:path";function Wn(s){return s.toLowerCase().replace(/[^a-z0-9]+/g,"")}function ib(s){let e=Ac.resolve(s);return rb("sha256").update(e).digest("hex").slice(0,16)}function Qo(s){let e=he(s);if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t.items)?t.items:[]}catch{return[]}}async function ab(s){let e=[],t=[s];for(;t.length>0&&e.length<Bp;){let n=t.pop();if(!n)break;let r=await Jp.readdir(n,{withFileTypes:!0});for(let o of r){if(e.length>=Bp)break;let i=Ac.join(n,o.name);if(o.isDirectory()){ob.has(o.name)||t.push(i);continue}o.isFile()&&/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java)$/.test(o.name)&&e.push(i)}}return e}async function cb(s,e){let t=[],n=[],r=!1,o=!1,i=!1,a=0,c=0,u=0;for(let d of e){let m=Ac.relative(s,d),p=await Jp.readFile(d,"utf-8");/from\s+['"]next\/image['"]/.test(p)&&(r=!0),(/from\s+['"]@?heroui\//.test(p)||/from\s+['"]@nextui-org\//.test(p))&&(o=!0),/<UiButton\b|from\s+['"][^'"]*UiButton[^'"]*['"]/.test(p)&&(i=!0);let g=p.match(/:\s*any\b|<\s*any\s*>/g);g&&(a+=g.length,n.push({issue:"Unbounded any usage",file:m,suggestion:"Replace with specific types or justified unknown + narrowing.",severity:"high",language:"TypeScript",source:"repo",confidence:.92}));let f=p.match(/@ts-ignore/g);f&&(c+=f.length,n.push({issue:"Unchecked @ts-ignore usage",file:m,suggestion:"Use @ts-expect-error with reason or refactor typings.",severity:"medium",language:"TypeScript",source:"repo",confidence:.88})),/\.(tsx|jsx)$/.test(d)&&/<img\s+/.test(p)&&!/next\/image/.test(p)&&(u+=1,n.push({issue:"Raw <img> in React/Next component",file:m,suggestion:"Prefer framework image component or documented exception.",severity:"medium",framework:"Next.js",source:"repo",confidence:.8}))}return r&&t.push({name:"Image rendering via next/image",description:"Project uses next/image for optimized image delivery.",location:"app/** or src/**",framework:"Next.js",source:"repo",confidence:.9}),o&&t.push({name:"HeroUI as component system",description:"UI components are sourced from HeroUI/NextUI packages.",location:"components/**",source:"repo",confidence:.87}),i&&t.push({name:"Use UiButton abstraction",description:"Buttons are wrapped in UiButton instead of native button in app UI.",location:"components/**",source:"repo",confidence:.84}),(a>0||c>0||u>0)&&t.push({name:"Strict type/lint hygiene",description:`Detected ${a} any, ${c} ts-ignore, ${u} raw img potential violations.`,source:"repo",confidence:.76}),{patterns:t,antiPatterns:n}}function lb(s){let e=new Set,t=[];for(let n of s){let r=`${Wn(n.name)}::${Wn(n.source)}`;e.has(r)||(e.add(r),t.push(n))}return t}function ub(s){let e=new Set,t=[];for(let n of s){let r=`${Wn(n.issue)}::${Wn(n.file)}::${Wn(n.source)}`;e.has(r)||(e.add(r),t.push(n))}return t}var ob,Bp,Ec,qp,Kp,Rc=k(()=>{"use strict";qt();oe();ob=new Set([".git","node_modules",".next","dist","build","coverage",".turbo",".cache"]),Bp=400;l(Wn,"normalizeKey");l(ib,"repoHash");l(Qo,"parseBaselineFile");l(ab,"listSourceFiles");l(cb,"detectRepoRules");l(lb,"dedupePatterns");l(ub,"dedupeAntiPatterns");Ec=class{static{l(this,"PatternExtractor")}async extract(e){let t=ib(e.projectPath),n=await ab(e.projectPath),r=[],o=[];for(let p of e.languages){let g=Wn(p),f=Qo(`baseline/patterns/${g}.json`),S=Qo(`baseline/anti-patterns/${g}.json`);r.push(...f.map(w=>({...w,language:p,source:"baseline",confidence:w.confidence??.8}))),o.push(...S.map(w=>({...w,file:w.file||"multiple",language:p,source:"baseline",confidence:w.confidence??.8})))}for(let p of e.frameworks){let g=Wn(p),f=Qo(`baseline/patterns/${g}.json`),S=Qo(`baseline/anti-patterns/${g}.json`);r.push(...f.map(w=>({...w,framework:p,source:"baseline",confidence:w.confidence??.82}))),o.push(...S.map(w=>({...w,file:w.file||"multiple",framework:p,source:"baseline",confidence:w.confidence??.82}))),e.context7Verified&&r.push({name:`${p} API validation via Context7`,description:`Validate ${p} APIs against current documentation through Context7 before implementation.`,framework:p,source:"context7",confidence:.7})}let i=await cb(e.projectPath,n),a=(e.feedback?.patternsDiscovered||[]).map(p=>({name:p,description:`Confirmed during completed tasks: ${p}`,source:"feedback",confidence:.75})),c=(e.feedback?.knownGotchas||[]).map(p=>({issue:p,file:"multiple",suggestion:`Recurring gotcha. Prevent this pattern during implementation: ${p}`,source:"feedback",severity:"medium",confidence:.7})),u=lb([...r,...i.patterns,...a]),d=ub([...o,...i.antiPatterns,...c]),m=`analysis:derived-rules:${t}`;return E.setDoc(e.projectId,m,{projectId:e.projectId,repoPathHash:t,patterns:u,antiPatterns:d,updatedAt:new Date().toISOString(),version:1}),{patterns:u,antiPatterns:d,repoPathHash:t}}},qp=new Ec,Kp=qp});import{exec as pb}from"node:child_process";import{promisify as mb}from"node:util";var q0,Xp=k(()=>{"use strict";xr();ce();fc();q0=mb(pb)});import zn from"chalk";var Yp,gb,fb,Lt,Qp=k(()=>{"use strict";qe();Yp=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],gb=80,fb={name:"prjct",icon:"\u26A1",signature:"\u26A1 prjct",spinner:{frames:Yp,speed:gb},cli:{header:l(()=>`${zn.cyan.bold("\u26A1")} ${zn.cyan("prjct")}`,"header"),footer:l(()=>zn.dim("\u26A1 prjct"),"footer"),spin:l((s,e)=>`${zn.cyan("\u26A1")} ${zn.cyan("prjct")} ${zn.cyan(Yp[s%10])} ${zn.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((s="claude")=>po(s).commitFooter,"getCommitFooter"),getSignature:l((s="claude")=>po(s).signature,"getSignature")},Lt=fb});import ie from"chalk";function wb(){return hb[yb]}var o$,Dc,hb,yb,Vn,As,jc,xt,Tn,Sb,kb,h,Bn=k(()=>{"use strict";Qp();Cn();Bo();Bo();o$=Lt.spinner.frames,Dc=Lt.spinner.speed,hb={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}},yb="compact";l(wb,"getTierConfig");Vn={success:ie.green("\u2713"),fail:ie.red("\u2717"),warn:ie.yellow("\u26A0"),info:ie.blue("\u2139"),debug:ie.dim("\u{1F527}"),bullet:ie.dim("\u2022"),arrow:ie.dim("\u2192"),check:ie.green("\u2713"),cross:ie.red("\u2717"),spinner:ie.cyan("\u25D0")},As=null,jc=0,xt=!1,Tn=l((s,e)=>{let t=e??(wb().maxCharsPerLine||Nt.FALLBACK_TRUNCATE);return s&&s.length>t?`${s.slice(0,t-1)}\u2026`:s||""},"truncate"),Sb=l(()=>process.stdout.isTTY?process.stdout.write(`\r${" ".repeat(Nt.CLEAR_WIDTH)}\r`):!0,"clear"),kb={start(){return xt||console.log(Lt.cli.header()),this},end(){return xt||console.log(Lt.cli.footer()),this},spin(s){return xt?this:(this.stop(),process.stdout.isTTY?(As=setInterval(()=>{process.stdout.write(`\r${Lt.cli.spin(jc++,Tn(s,Nt.SPINNER_MSG))}`)},Dc),this):(process.stdout.write(`${Lt.cli.spin(0,Tn(s,Nt.SPINNER_MSG))}
|
|
504
|
+
`),this))},done(s,e){if(this.stop(),!xt){let t="";if(e){let n=[];e.agents!==void 0&&n.push(`${e.agents}a`),e.reduction!==void 0&&n.push(`${e.reduction}%`),e.tokens!==void 0&&n.push(`${Math.round(e.tokens)}K`),n.length>0&&(t=ie.dim(` [${n.join(" | ")}]`))}console.log(`${Vn.success} ${Tn(s,Nt.DONE_MSG)}${t}`)}return this},fail(s){return this.stop(),console.error(`${Vn.fail} ${Tn(s,Nt.FAIL_MSG)}`),this},failWithHint(s){this.stop();let e=typeof s=="string"?wc(s):s;return console.error(),console.error(`${Vn.fail} ${e.message}`),e.file&&console.error(ie.dim(` File: ${e.file}`)),e.hint&&console.error(ie.yellow(` \u{1F4A1} ${e.hint}`)),e.docs&&console.error(ie.dim(` Docs: ${e.docs}`)),console.error(),this},warn(s){return this.stop(),xt||console.log(`${Vn.warn} ${Tn(s,Nt.WARN_MSG)}`),this},info(s){return this.stop(),xt||console.log(`${Vn.info} ${s}`),this},debug(s){this.stop();let e=process.env.DEBUG==="1"||process.env.DEBUG==="true";return!xt&&e&&console.log(`${Vn.debug} ${ie.dim(s)}`),this},success(s,e){return this.done(s,e)},list(s,e={}){if(this.stop(),xt)return this;let t=e.bullet||Vn.bullet,n=" ".repeat(e.indent||0);for(let r of s)console.log(`${n}${t} ${r}`);return this},table(s,e={}){if(this.stop(),xt||s.length===0)return this;let t=Object.keys(s[0]),n={};for(let r of t){n[r]=r.length;for(let o of s){let i=String(o[r]??"");i.length>n[r]&&(n[r]=i.length)}}if(e.header!==!1){let r=t.map(o=>o.padEnd(n[o])).join(" ");console.log(ie.dim(r)),console.log(ie.dim("\u2500".repeat(r.length)))}for(let r of s){let o=t.map(i=>String(r[i]??"").padEnd(n[i])).join(" ");console.log(o)}return this},box(s,e){if(this.stop(),xt)return this;let t=e.split(`
|
|
505
|
+
`),n=Math.max(s.length,...t.map(o=>o.length)),r="\u2500".repeat(n+2);console.log(ie.dim(`\u250C${r}\u2510`)),console.log(`${ie.dim("\u2502")} ${ie.bold(s.padEnd(n))} ${ie.dim("\u2502")}`),console.log(ie.dim(`\u251C${r}\u2524`));for(let o of t)console.log(`${ie.dim("\u2502")} ${o.padEnd(n)} ${ie.dim("\u2502")}`);return console.log(ie.dim(`\u2514${r}\u2518`)),this},section(s){return this.stop(),xt?this:(console.log(`
|
|
506
|
+
${ie.bold(s)}`),console.log(ie.dim("\u2500".repeat(s.length))),this)},stop(){return As&&(clearInterval(As),As=null,Sb()),this},step(s,e,t){if(xt)return this;this.stop();let n=ie.dim(`[${s}/${e}]`);return process.stdout.isTTY?(As=setInterval(()=>{process.stdout.write(`\r${Lt.cli.spin(jc++,`${n} ${Tn(t,Nt.STEP_MSG)}`)}`)},Dc),this):(process.stdout.write(`${Lt.cli.spin(0,`${n} ${Tn(t,Nt.STEP_MSG)}`)}
|
|
507
|
+
`),this)},progress(s,e,t){if(xt)return this;this.stop();let n=Math.round(s/e*100),r=Math.round(n/10),o=10-r,i=ie.cyan("\u2588".repeat(r))+ie.dim("\u2591".repeat(o)),a=t?` ${Tn(t,Nt.PROGRESS_TEXT)}`:"";return process.stdout.isTTY?(As=setInterval(()=>{process.stdout.write(`\r${Lt.cli.spin(jc++,`[${i}] ${n}%${a}`)}`)},Dc),this):(process.stdout.write(`${Lt.cli.spin(0,`[${i}] ${n}%${a}`)}
|
|
508
|
+
`),this)}},h=kb});function Zp(s,e){let t=[];Er("Languages",s.languages,e.languages,t),Er("Frameworks",s.frameworks,e.frameworks,t),(s.packageManager??"")!==(e.packageManager??"")&&t.push({field:"Package manager",type:"changed",before:s.packageManager??"(none)",after:e.packageManager??"(none)"}),(s.sourceDir??"")!==(e.sourceDir??"")&&t.push({field:"Source directory",type:"changed",before:s.sourceDir??"(none)",after:e.sourceDir??"(none)"}),(s.testDir??"")!==(e.testDir??"")&&t.push({field:"Test directory",type:"changed",before:s.testDir??"(none)",after:e.testDir??"(none)"}),Er("Config files",s.configFiles,e.configFiles,t),s.fileCount!==e.fileCount&&t.push({field:"File count",type:"changed",before:String(s.fileCount),after:String(e.fileCount)});let n=s.patterns.map(d=>d.name),r=e.patterns.map(d=>d.name);Er("Patterns",n,r,t);let o=s.antiPatterns.map(d=>d.issue),i=e.antiPatterns.map(d=>d.issue);Er("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:s.commitHash??null,afterCommit:e.commitHash??null}}function Ic(s){if(!s.hasChanges)return`## Analysis Diff
|
|
509
|
+
|
|
510
|
+
No changes between runs.`;let e=[];e.push("## Analysis Diff"),(s.beforeCommit||s.afterCommit)&&e.push(`> \`${s.beforeCommit?.substring(0,7)??"(none)"}\` \u2192 \`${s.afterCommit?.substring(0,7)??"(none)"}\``),e.push(""),e.push("| Change | Field | Detail |"),e.push("|--------|-------|--------|");for(let n of s.items){let r=n.type==="added"?"+":n.type==="removed"?"-":"~",o=n.type==="changed"?`${n.before} \u2192 ${n.after}`:n.after??n.before??"";e.push(`| ${r} | ${n.field} | ${o} |`)}e.push("");let t=[];return s.summary.added>0&&t.push(`${s.summary.added} added`),s.summary.removed>0&&t.push(`${s.summary.removed} removed`),s.summary.changed>0&&t.push(`${s.summary.changed} changed`),e.push(`**Summary**: ${t.join(", ")}`),e.join(`
|
|
511
|
+
`)}function em(s){if(!s.hasChanges)return"No changes between analysis runs.";let e=[];(s.beforeCommit||s.afterCommit)&&(e.push(` ${s.beforeCommit?.substring(0,7)??"(none)"} \u2192 ${s.afterCommit?.substring(0,7)??"(none)"}`),e.push(""));for(let t of s.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(`
|
|
512
|
+
`)}function Er(s,e,t,n){let r=new Set(e),o=new Set(t);for(let i of t)r.has(i)||n.push({field:s,type:"added",after:i});for(let i of e)o.has(i)||n.push({field:s,type:"removed",before:i})}var $c=k(()=>{"use strict";l(Zp,"generateAnalysisDiff");l(Ic,"formatAnalysisDiffMd");l(em,"formatAnalysisDiffText");l(Er,"diffStringArray")});function vb(){let s=process.env.PRJCT_DEBUG||process.env.DEBUG||"";if(!s)return{level:-1,name:"disabled"};if(bb.has(s)||s.includes("prjct"))return{level:Rs.debug,name:"debug"};let e=Rs[s]??-1,t=e>=0?s:"disabled";return{level:e,name:t}}function Zo(s,e,t){return tm>=s?(...n)=>console[t](e,...n):Cb}var Rs,bb,tm,Pb,Cb,xb,H,En=k(()=>{"use strict";Rs={error:0,warn:1,info:2,debug:3},bb=new Set(["1","true","*"]);l(vb,"getLogLevel");({level:tm,name:Pb}=vb()),Cb=l(()=>{},"noop");l(Zo,"createLogMethod");xb={error:Zo(Rs.error,"[prjct:error]","error"),warn:Zo(Rs.warn,"[prjct:warn]","warn"),info:Zo(Rs.info,"[prjct:info]","log"),debug:Zo(Rs.debug,"[prjct:debug]","log"),isEnabled:l(()=>tm>=0,"isEnabled"),level:l(()=>Pb,"level")},H=xb});var ei,et,Ds,nm=k(()=>{"use strict";rn();oe();ha();Cn();En();ei=class{static{l(this,"EventBus")}listeners;onceListeners;history;historyLimit;projectId;constructor(){this.listeners=new Map,this.onceListeners=new Map,this.history=[],this.historyLimit=Wp.HISTORY_MAX,this.projectId=null}async initialize(e){this.projectId=e}on(e,t){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(t),()=>this.off(e,t)}once(e,t){return this.onceListeners.has(e)||this.onceListeners.set(e,new Set),this.onceListeners.get(e).add(t),()=>{let n=this.onceListeners.get(e);n&&n.delete(t)}}off(e,t){let n=this.listeners.get(e);n&&n.delete(t)}async emit(e,t={}){let n=new Date().toISOString(),r={type:e,timestamp:n,projectId:this.projectId,...t};this.history.push(r),this.history.length>this.historyLimit&&this.history.shift(),this.projectId&&await this.logEvent(r);let o=this.getMatchingListeners(e);(await Promise.allSettled(o.map(u=>this.executeCallback(u,r)))).forEach(u=>{u.status==="rejected"&&H.error(`Event listener error for ${e}:`,u.reason)});let a=this.onceListeners.get(e);if(a){for(let u of a)await this.executeCallback(u,r);this.onceListeners.delete(e)}let c=this.onceListeners.get(Le.ALL);if(c)for(let u of c)await this.executeCallback(u,r)}getMatchingListeners(e){let t=[],n=this.listeners.get(e);n&&t.push(...n);let r=this.listeners.get(Le.ALL);r&&t.push(...r);let o=e.split(".")[0],i=this.listeners.get(`${o}.*`);return i&&t.push(...i),t}async executeCallback(e,t){try{let n=e(t);n instanceof Promise&&await n}catch(n){throw H.error("Event callback error:",n),n}}async logEvent(e){try{E.appendEvent(this.projectId,e.type,e)}catch(t){H.debug("Failed to log event:",Z(t))}}getHistory(e=10,t=null){let n=this.history;return t&&(n=n.filter(r=>r.type===t||r.type.startsWith(t))),n.slice(-e)}clear(){this.listeners.clear(),this.onceListeners.clear()}flush(){this.history=[],this.onceListeners.clear()}removeAllListeners(e){e?(this.listeners.delete(e),this.onceListeners.delete(e)):(this.listeners.clear(),this.onceListeners.clear())}listenerCount(e){let t=this.listeners.get(e);return t?t.size:0}getRegisteredEvents(){return Array.from(this.listeners.keys())}},et=new ei,Ds={sessionStarted:l(s=>et.emit(Le.SESSION_STARTED,s),"sessionStarted"),sessionPaused:l(s=>et.emit(Le.SESSION_PAUSED,s),"sessionPaused"),sessionResumed:l(s=>et.emit(Le.SESSION_RESUMED,s),"sessionResumed"),sessionCompleted:l(s=>et.emit(Le.SESSION_COMPLETED,s),"sessionCompleted"),taskCreated:l(s=>et.emit(Le.TASK_CREATED,s),"taskCreated"),taskCompleted:l(s=>et.emit(Le.TASK_COMPLETED,s),"taskCompleted"),featureAdded:l(s=>et.emit(Le.FEATURE_ADDED,s),"featureAdded"),featureShipped:l(s=>et.emit(Le.FEATURE_SHIPPED,s),"featureShipped"),ideaCaptured:l(s=>et.emit(Le.IDEA_CAPTURED,s),"ideaCaptured"),snapshotCreated:l(s=>et.emit(Le.SNAPSHOT_CREATED,s),"snapshotCreated"),snapshotRestored:l(s=>et.emit(Le.SNAPSHOT_RESTORED,s),"snapshotRestored"),commitCreated:l(s=>et.emit(Le.COMMIT_CREATED,s),"commitCreated"),pushCompleted:l(s=>et.emit(Le.PUSH_COMPLETED,s),"pushCompleted"),projectInitialized:l(s=>et.emit(Le.PROJECT_INITIALIZED,s),"projectInitialized"),projectSynced:l(s=>et.emit(Le.PROJECT_SYNCED,s),"projectSynced"),analysisCompleted:l(s=>et.emit(Le.ANALYSIS_COMPLETED,s),"analysisCompleted")}});var ti,ni,sm=k(()=>{"use strict";ve();ce();We();ti=class{static{l(this,"SyncEventBus")}async publish(e){let t=A.getSyncPendingPath(e.projectId),n=await zt(t,[])??[];n.push(e),await On(t,n)}async getPending(e){let t=A.getSyncPendingPath(e);return await zt(t,[])??[]}async clearPending(e){let t=A.getSyncPendingPath(e);await On(t,[])}async updateLastSync(e){let t=A.getLastSyncPath(e),n={timestamp:b(),success:!0};await On(t,n)}async getLastSync(e){let t=A.getLastSyncPath(e);return await zt(t,null)}},ni=new ti});var si=k(()=>{"use strict";nm();sm()});var js,Mc=k(()=>{"use strict";js=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((n,r)=>n[1].timestamp-r[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[n]of t)this.cache.delete(n)}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 Be,Xt=k(()=>{"use strict";si();Mc();ce();oe();Be=class{static{l(this,"StorageManager")}filename;cache;constructor(e,t){this.filename=e,this.cache=new js({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 n=E.getDoc(e,this.getStoreKey());if(n!==null)return this.cache.set(e,n),n}catch{}return this.getDefault()}async write(e,t){E.setDoc(e,this.getStoreKey(),t),this.cache.set(e,t)}async update(e,t){let n=await this.read(e),r=t(n);return await this.write(e,r),r}async publishEvent(e,t,n){let r={type:t,path:[this.filename.replace(".json","")],data:n,timestamp:b(),projectId:e};await ni.publish(r)}async publishEntityEvent(e,t,n,r){let o=`${t}.${n}`,i={...r,timestamp:b()};await this.publishEvent(e,o,i)}async exists(e){try{return E.hasDoc(e,this.getStoreKey())}catch{return!1}}clearCache(e){e?this.cache.delete(e):this.cache.clear()}getCacheStats(){return this.cache.stats()}}});import{createHash as Eb}from"node:crypto";var Oc,Je,Ar=k(()=>{"use strict";Ia();$c();ce();Xt();Oc=class extends Be{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 n={...t,status:"draft"};ja.parse(n),await this.update(e,r=>({...r,draft:n,lastUpdated:b()})),await this.publishEntityEvent(e,"analysis","drafted",{commitHash:n.commitHash,fileCount:n.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 n=this.computeSignature(t.draft),r=b(),o={...t.draft,status:"sealed",signature:n,sealedAt:r};return ja.parse(o),await this.write(e,{draft:null,sealed:o,previousSealed:t.sealed,lastUpdated:r}),await this.publishEntityEvent(e,"analysis","sealed",{commitHash:o.commitHash,signature:n}),{success:!0,signature:n}}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 n=b();return await this.write(e,{draft:t.sealed,sealed:t.previousSealed,previousSealed:null,lastUpdated:n}),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:Zp(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 n=this.computeSignature({...t.sealed,signature:void 0,sealedAt:void 0});return n===t.sealed.signature?{valid:!0,message:"Signature verified. Analysis integrity confirmed."}:{valid:!1,message:`Signature mismatch. Expected ${n}, got ${t.sealed.signature}. Analysis may have been modified.`}}async semanticVerify(e,t){let n=await this.read(e),r=n.sealed??n.draft;return r?await Td(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 Eb("sha256").update(JSON.stringify(t)).digest("hex")}},Je=new Oc});var Fc,Rr,rm=k(()=>{"use strict";oe();Fc=class{static{l(this,"ContextFeedbackStorage")}recordSuggestions(e,t,n,r){E.run(e,`INSERT INTO context_feedback (task_id, keywords, suggested_files, created_at)
|
|
513
|
+
VALUES (?, ?, ?, ?)`,t,JSON.stringify(n),JSON.stringify(r),new Date().toISOString())}completeFeedback(e,t,n){let r=E.get(e,"SELECT * FROM context_feedback WHERE task_id = ? ORDER BY id DESC LIMIT 1",t);if(!r)return;let o=new Set(JSON.parse(r.suggested_files)),i=new Set(n),a=[...o].filter(d=>i.has(d)).length,c=o.size>0?a/o.size:0,u=i.size>0?a/i.size:0;E.run(e,`UPDATE context_feedback
|
|
514
514
|
SET actual_files = ?, precision = ?, recall = ?, completed_at = ?
|
|
515
|
-
WHERE id = ?`,JSON.stringify(n),c,u,new Date().toISOString(),
|
|
515
|
+
WHERE id = ?`,JSON.stringify(n),c,u,new Date().toISOString(),r.id)}getHistoricalBoosts(e,t){let n=new Map;if(t.length===0)return n;let r=E.query(e,`SELECT * FROM context_feedback
|
|
516
516
|
WHERE actual_files IS NOT NULL
|
|
517
|
-
ORDER BY id DESC LIMIT 50`);if(
|
|
517
|
+
ORDER BY id DESC LIMIT 50`);if(r.length===0)return n;let o=new Set(t),i=new Map;for(let c of r){let u=JSON.parse(c.keywords),d=new Set(u),m=[...o].filter(w=>d.has(w)).length,p=new Set([...o,...d]).size,g=p>0?m/p:0;if(g===0)continue;let f=new Set(JSON.parse(c.suggested_files)),S=new Set(JSON.parse(c.actual_files));for(let w of S){let v=i.get(w)??0;i.set(w,v+g)}for(let w of f)if(!S.has(w)){let v=i.get(w)??0;i.set(w,v-g*.5)}}if(i.size===0)return n;let a=Math.max(...[...i.values()].map(Math.abs),1);for(let[c,u]of i)n.set(c,u/a);return n}},Rr=new Fc});var _c,tt,Dr=k(()=>{"use strict";Rt();Ma();ce();xn();Xt();_c=class extends Be{static{l(this,"IdeasStorage")}constructor(){super("ideas.json",Rd)}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(n=>n.status==="pending")}async addIdea(e,t,n={}){let r={id:me(),text:t,status:"pending",priority:n.priority||"medium",tags:n.tags||[],addedAt:b()};return await this.update(e,o=>({ideas:[r,...o.ideas],lastUpdated:b()})),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,n){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,status:"converted",convertedTo:n}:o),lastUpdated:b()})),await this.publishEvent(e,"idea.converted",{ideaId:t,featureId:n})}async archive(e,t){await this.update(e,n=>({ideas:n.ideas.map(r=>r.id===t?{...r,status:"archived"}:r),lastUpdated:b()})),await this.publishEvent(e,"idea.archived",{ideaId:t})}async setPriority(e,t,n){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,priority:n}:o),lastUpdated:b()}))}async addTags(e,t,n){await this.update(e,r=>({ideas:r.ideas.map(o=>o.id===t?{...o,tags:[...new Set([...o.tags,...n])]}:o),lastUpdated:b()}))}async removeIdea(e,t){await this.update(e,n=>({ideas:n.ideas.filter(r=>r.id!==t),lastUpdated:b()}))}async getCounts(e){let t=await this.read(e);return{pending:t.ideas.filter(n=>n.status==="pending").length,converted:t.ideas.filter(n=>n.status==="converted").length,archived:t.ideas.filter(n=>n.status==="archived").length}}async cleanup(e){let n=(await this.read(e)).ideas.filter(a=>a.status==="archived");if(n.length<=50)return{removed:0};let r=n.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:b()})),{removed:i}}async markDormantIdeas(e){let t=await this.read(e),n=yn(Kt.IDEA_DORMANT_DAYS),r=t.ideas.filter(i=>i.status==="pending"&&new Date(i.addedAt)<n);if(r.length===0)return 0;Ct.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:b()})),await this.publishEvent(e,"ideas.dormant",{count:r.length}),r.length}},tt=new _c});var Nc,Jn,ri=k(()=>{"use strict";Ro();ce();Xt();Nc=class extends Be{static{l(this,"MetricsStorage")}constructor(){super("metrics.json",mp)}getDefault(){return{...gp}}getEventType(e){return`metrics.${e}d`}async recordSync(e,t){let n=Math.max(0,t.originalSize-t.filteredSize),r=t.originalSize>0?n/t.originalSize:0,o=new Date().toISOString().split("T")[0];await this.update(e,i=>{let a=i.syncCount+1,c=i.totalTokensSaved+n,u=i.totalSyncDuration+t.duration,d=i.syncCount===0?r:(i.avgCompressionRate*i.syncCount+r)/a,m=[...i.dailyStats],p=m.findIndex(v=>v.date===o);if(p>=0){let v=m[p];m[p]={...v,tokensSaved:v.tokensSaved+n,syncs:v.syncs+1,avgCompressionRate:(v.avgCompressionRate*v.syncs+r)/(v.syncs+1),totalDuration:v.totalDuration+t.duration}}else m.push({date:o,tokensSaved:n,syncs:1,avgCompressionRate:r,totalDuration:t.duration});let g=new Date;g.setDate(g.getDate()-90);let f=g.toISOString().split("T")[0],S=m.filter(v=>v.date>=f),w=[...i.agentUsage];if(t.agents)for(let v of t.agents){let T=w.findIndex(_=>_.agentName===v);T>=0?w[T]={...w[T],usageCount:w[T].usageCount+1,tokensSaved:w[T].tokensSaved+Math.floor(n/t.agents.length)}:w.push({agentName:v,usageCount:1,tokensSaved:Math.floor(n/t.agents.length)})}return{totalTokensSaved:c,avgCompressionRate:d,syncCount:a,watchTriggers:i.watchTriggers+(t.isWatch?1:0),avgSyncDuration:u/a,totalSyncDuration:u,agentUsage:w,dailyStats:S,firstSync:i.firstSync||b(),lastUpdated:b()}})}async getSummary(e){let t=await this.read(e),n=this.getLast30Days(t.dailyStats),r=this.getPrev30Days(t.dailyStats),o=n.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:fp(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 n=await this.read(e),r=new Date;r.setDate(r.getDate()-t);let o=r.toISOString().split("T")[0];return n.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 n=t.toISOString().split("T")[0];return e.filter(r=>r.date>=n)}getPrev30Days(e){let t=new Date;t.setDate(t.getDate()-30);let n=new Date;n.setDate(n.getDate()-60);let r=n.toISOString().split("T")[0],o=t.toISOString().split("T")[0];return e.filter(i=>i.date>=r&&i.date<o)}},Jn=new Nc});import Q from"node:fs/promises";import X from"node:path";async function jr(s){let e=Date.now(),t={success:!1,migratedFiles:[],skippedFiles:[],errors:[],backupDir:null,duration:0};try{if(E.exists(s)&&E.hasDoc(s,"state"))return t.success=!0,t.duration=Date.now()-e,t;let n=A.getGlobalProjectPath(s),r=X.join(n,"storage"),o=X.join(n,"index"),i=X.join(n,"memory");t.backupDir=await Ab(r,o,i),E.getDb(s);for(let{filename:c,key:u}of Hc){let d=X.join(r,c),m=await Ut(d);if(m===null){t.skippedFiles.push(c);continue}try{E.setDoc(s,u,m),om(s,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 Ut(d);if(m===null){t.skippedFiles.push(`index/${c}`);continue}try{E.run(s,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",u,JSON.stringify(m),new Date().toISOString()),im(s,u,m),t.migratedFiles.push(`index/${c}`)}catch(p){t.errors.push({file:`index/${c}`,error:String(p)})}}await Fb(s,o,t),await _b(s,o,t),await Nb(s,i,t),await Lb(s,i,t);let a=X.join(n,"sessions");return await Ub(s,a,t),t.errors.length===0&&await Hb(r,o,i,t),t.success=t.errors.length===0,t.duration=Date.now()-e,t}catch(n){return t.errors.push({file:"<migration>",error:String(n)}),t.duration=Date.now()-e,t}}async function Ab(s,e,t){let n=X.join(s,"backup");return await Q.mkdir(n,{recursive:!0}),await Q.mkdir(X.join(n,"index"),{recursive:!0}),await Q.mkdir(X.join(n,"memory"),{recursive:!0}),await Lc(s,n,r=>r.endsWith(".json")||r.endsWith(".jsonl")),await Lc(e,X.join(n,"index")),await Lc(t,X.join(n,"memory")),n}async function Lc(s,e,t){try{let n=await Q.readdir(s,{withFileTypes:!0});for(let r of n){if(!r.isFile()||t&&!t(r.name))continue;let o=X.join(s,r.name),i=X.join(e,r.name);await Q.copyFile(o,i)}}catch(n){if(!C(n))throw n}}function om(s,e,t){switch(e){case"state":Rb(s,t);break;case"queue":Db(s,t);break;case"ideas":jb(s,t);break;case"shipped":Ib(s,t);break;case"metrics":$b(s,t);break;case"analysis":Mb(s,t);break}}function Rb(s,e){let t=E.getDb(s),n=t.prepare(`
|
|
518
518
|
INSERT OR REPLACE INTO tasks
|
|
519
519
|
(id, description, type, status, parent_description, branch, linear_id,
|
|
520
520
|
linear_uuid, session_id, feature_id, started_at, completed_at,
|
|
521
521
|
shipped_at, paused_at, pause_reason, pr_url, expected_value, data)
|
|
522
522
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
523
|
-
`),
|
|
523
|
+
`),r=t.prepare(`
|
|
524
524
|
INSERT OR REPLACE INTO subtasks
|
|
525
525
|
(id, task_id, description, status, domain, agent, sort_order,
|
|
526
526
|
depends_on, started_at, completed_at, output, summary)
|
|
527
527
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
528
|
-
`),o=l((a,c)=>{if(!a||!a.id)return;n.run(
|
|
528
|
+
`),o=l((a,c)=>{if(!a||!a.id)return;n.run(I(a.id)??`task-${Date.now()}`,I(a.description??a.parentDescription)??"",I(a.type),I(c??a.status)??"unknown",I(a.parentDescription),I(a.branch),I(a.linearId),I(a.linearUuid),I(a.sessionId),I(a.featureId),I(a.startedAt)??new Date().toISOString(),I(a.completedAt),I(a.shippedAt),I(a.pausedAt),I(a.pauseReason),I(a.prUrl),a.expectedValue?JSON.stringify(a.expectedValue):null,JSON.stringify(a));let u=a.subtasks;if(u&&Array.isArray(u))for(let d=0;d<u.length;d++){let m=u[d];r.run(I(m.id)??`subtask-${d}`,I(a.id),I(m.description)??"",I(m.status)??"pending",I(m.domain),I(m.agent),d,m.dependsOn?JSON.stringify(m.dependsOn):null,I(m.startedAt),I(m.completedAt),I(m.output),m.summary?JSON.stringify(m.summary):null)}},"migrateTask");e.currentTask&&o(e.currentTask),e.previousTask&&o(e.previousTask);let i=e.pausedTasks;if(i&&Array.isArray(i))for(let a of i)o(a,"paused")}function Db(s,e){let t=e.tasks;if(!t||!Array.isArray(t))return;let r=E.getDb(s).prepare(`
|
|
529
529
|
INSERT OR REPLACE INTO queue_tasks
|
|
530
530
|
(id, description, type, priority, section, created_at, completed, completed_at,
|
|
531
531
|
feature_id, feature_name)
|
|
532
532
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
533
|
-
`);for(let o of t)
|
|
533
|
+
`);for(let o of t)r.run(I(o.id)??`queue-${Date.now()}`,I(o.description)??"",I(o.type),I(o.priority),I(o.section),I(o.createdAt)??new Date().toISOString(),o.completed?1:0,I(o.completedAt),I(o.featureId),I(o.featureName))}function jb(s,e){let t=e.ideas;if(!t||!Array.isArray(t))return;let r=E.getDb(s).prepare(`
|
|
534
534
|
INSERT OR REPLACE INTO ideas
|
|
535
535
|
(id, text, status, priority, tags, added_at, converted_to, details, data)
|
|
536
536
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
537
|
-
`);for(let o of t)
|
|
537
|
+
`);for(let o of t)r.run(I(o.id)??`idea-${Date.now()}`,I(o.text)??"",I(o.status)??"pending",I(o.priority)??"medium",o.tags?JSON.stringify(o.tags):null,I(o.addedAt)??new Date().toISOString(),I(o.convertedTo),I(o.details),JSON.stringify(o))}function Ib(s,e){let t=e.shipped;if(!t||!Array.isArray(t))return;let r=E.getDb(s).prepare(`
|
|
538
538
|
INSERT OR REPLACE INTO shipped_features
|
|
539
539
|
(id, name, shipped_at, version, description, type, duration, data)
|
|
540
540
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
541
|
-
`);for(let o of t)
|
|
541
|
+
`);for(let o of t)r.run(I(o.id)??`ship-${Date.now()}`,I(o.name)??"",I(o.shippedAt)??new Date().toISOString(),I(o.version)??"0.0.0",I(o.description),I(o.type),I(o.duration),JSON.stringify(o))}function $b(s,e){let t=e.dailyStats;if(!t||!Array.isArray(t))return;let r=E.getDb(s).prepare(`
|
|
542
542
|
INSERT OR REPLACE INTO metrics_daily
|
|
543
543
|
(date, tokens_saved, syncs, avg_compression_rate, total_duration)
|
|
544
544
|
VALUES (?, ?, ?, ?, ?)
|
|
545
|
-
`);for(let o of t)
|
|
545
|
+
`);for(let o of t)r.run(I(o.date)??new Date().toISOString().slice(0,10),An(o.tokensSaved)??0,An(o.syncs)??0,An(o.avgCompressionRate)??0,An(o.totalDuration)??0)}function Mb(s,e){let n=E.getDb(s).prepare(`
|
|
546
546
|
INSERT OR REPLACE INTO analysis
|
|
547
547
|
(id, status, commit_hash, signature, sealed_at, analyzed_at, data)
|
|
548
548
|
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
549
|
-
`),
|
|
549
|
+
`),r=l((o,i)=>{o&&n.run(i,I(o.status)??"unknown",I(o.commitHash),I(o.signature),I(o.sealedAt),I(o.analyzedAt),JSON.stringify(o))},"migrate");e.draft&&r(e.draft,"draft"),e.sealed&&r(e.sealed,"sealed")}function im(s,e,t){e==="categories-cache"&&Ob(s,t)}function Ob(s,e){let t=e.fileCategories;if(!t||!Array.isArray(t))return;let r=E.getDb(s).prepare(`
|
|
550
550
|
INSERT OR REPLACE INTO index_files
|
|
551
551
|
(path, categories, domain, score, size, mtime, language)
|
|
552
552
|
VALUES (?, ?, ?, COALESCE((SELECT score FROM index_files WHERE path = ?), 0), NULL, NULL, NULL)
|
|
553
|
-
`);for(let o of t){let i=
|
|
553
|
+
`);for(let o of t){let i=I(o.path);i&&r.run(i,o.categories?JSON.stringify(o.categories):null,I(o.primaryDomain),i)}}async function Fb(s,e,t){let n=X.join(e,"checksums.json"),r=await Ut(n);if(r===null){t.skippedFiles.push("index/checksums.json");return}try{let o=r.checksums;if(!o)return;let i=E.getDb(s),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 _b(s,e,t){let n=X.join(e,"file-scores.json"),r=await Ut(n);if(r===null){t.skippedFiles.push("index/file-scores.json");return}try{let o=r.scores;if(!o||!Array.isArray(o))return;let i=E.getDb(s),a=i.prepare(`
|
|
554
554
|
INSERT OR REPLACE INTO index_files
|
|
555
555
|
(path, score, size, mtime, language, categories, domain)
|
|
556
556
|
VALUES (?, ?, ?, ?, NULL,
|
|
557
557
|
COALESCE((SELECT categories FROM index_files WHERE path = ?), NULL),
|
|
558
558
|
COALESCE((SELECT domain FROM index_files WHERE path = ?), NULL))
|
|
559
|
-
`);i.transaction(()=>{for(let c of o){let u=
|
|
560
|
-
`).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/events.jsonl");return}let i=
|
|
561
|
-
`).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/learnings.jsonl");return}let i=
|
|
559
|
+
`);i.transaction(()=>{for(let c of o){let u=I(c.path);u&&a.run(u,An(c.score)??0,An(c.size),I(c.mtime),u,u)}})(),t.migratedFiles.push("index/file-scores.json")}catch(o){t.errors.push({file:"index/file-scores.json",error:String(o)})}}async function Nb(s,e,t){let n=X.join(e,"events.jsonl");try{let o=(await Q.readFile(n,"utf-8")).split(`
|
|
560
|
+
`).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/events.jsonl");return}let i=E.getDb(s),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=I(u.type??u.action)??"unknown",m=I(u.taskId??u.task_id),p=I(u.timestamp??u.ts)??new Date().toISOString();a.run(d,m,c,p)}catch{}})(),t.migratedFiles.push("memory/events.jsonl")}catch(r){C(r)?t.skippedFiles.push("memory/events.jsonl"):t.errors.push({file:"memory/events.jsonl",error:String(r)})}}async function Lb(s,e,t){let n=X.join(e,"learnings.jsonl");try{let o=(await Q.readFile(n,"utf-8")).split(`
|
|
561
|
+
`).filter(c=>c.trim());if(o.length===0){t.skippedFiles.push("memory/learnings.jsonl");return}let i=E.getDb(s),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:${I(u.taskId??u.timestamp)??Date.now()}`,m=u.tags,p=m&&m.length>0?I(m[0]):null;a.run(d,p,c,1,I(u.timestamp)??new Date().toISOString())}catch{}})(),t.migratedFiles.push("memory/learnings.jsonl")}catch(r){C(r)?t.skippedFiles.push("memory/learnings.jsonl"):t.errors.push({file:"memory/learnings.jsonl",error:String(r)})}}async function Ub(s,e,t){let r=E.getDb(s).prepare(`
|
|
562
562
|
INSERT OR IGNORE INTO sessions
|
|
563
563
|
(id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
|
|
564
564
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
565
|
-
`),o=l(u=>{!u||!u.id||
|
|
566
|
-
`).filter(
|
|
565
|
+
`),o=l(u=>{!u||!u.id||r.run(I(u.id),I(u.projectId)??s,I(u.task)??"",I(u.status)??"completed",I(u.startedAt)??new Date().toISOString(),I(u.pausedAt),I(u.completedAt),An(u.duration)??0,u.metrics?JSON.stringify(u.metrics):"{}",u.timeline?JSON.stringify(u.timeline):"[]")},"insertSession"),i=X.join(e,"current.json"),a=await Ut(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 f=await Q.readdir(p);for(let w of f){if(!w.endsWith(".json"))continue;let v=X.join(p,w),T=await Ut(v);if(T!==null)try{o(T),t.migratedFiles.push(`sessions/archive/${m}/${w}`),await Q.unlink(v).catch(()=>{})}catch(_){t.errors.push({file:`sessions/archive/${m}/${w}`,error:String(_)})}}(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 Hb(s,e,t,n){let r=l(async(i,a)=>{try{await Q.unlink(i)}catch(c){C(c)||n.errors.push({file:a,error:`cleanup: ${String(c)}`})}},"deleteFile");for(let{filename:i}of Hc)await r(X.join(s,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 I(s){return s==null?null:typeof s=="string"?s:typeof s=="number"||typeof s=="boolean"||typeof s=="bigint"?String(s):JSON.stringify(s)}function An(s){if(s==null)return null;if(typeof s=="number")return s;if(typeof s=="string"){let e=Number(s);return Number.isNaN(e)?null:e}return null}async function Ut(s){try{let e=await Q.readFile(s,"utf-8");return JSON.parse(e)}catch(e){if(C(e)||e instanceof SyntaxError)return null;throw e}}async function oi(s){let e=A.getGlobalProjectPath(s),t=X.join(e,"storage"),n=0;E.getDb(s);for(let{filename:f,key:S}of Hc){let w=X.join(t,f),v=await Ut(w);if(v!==null){E.setDoc(s,S,v),om(s,S,v);try{await Q.unlink(w)}catch{}n++}}let r=X.join(e,"project.json"),o=await Ut(r);if(o!==null){E.setDoc(s,"project",o);try{await Q.unlink(r)}catch{}n++}let i=X.join(e,"memory");for(let f of["events.jsonl","learnings.jsonl"]){let S=X.join(i,f);try{let v=(await Q.readFile(S,"utf-8")).split(`
|
|
566
|
+
`).filter(_=>_.trim());if(v.length===0){await Q.unlink(S),n++;continue}let T=E.getDb(s);if(f==="events.jsonl"){let _=T.prepare("INSERT INTO events (type, task_id, data, timestamp) VALUES (?, ?, ?, ?)");T.transaction(()=>{for(let ne of v)try{let re=JSON.parse(ne);_.run(I(re.type??re.action)??"unknown",I(re.taskId??re.task_id),ne,I(re.timestamp??re.ts)??new Date().toISOString())}catch{}})()}else{let _=T.prepare("INSERT OR REPLACE INTO memory (key, domain, value, confidence, updated_at) VALUES (?, ?, ?, ?, ?)");T.transaction(()=>{for(let ne of v)try{let re=JSON.parse(ne),ke=`learning:${I(re.taskId??re.timestamp)??Date.now()}`,P=re.tags;_.run(ke,I(P?.[0]),ne,1,I(re.timestamp)??new Date().toISOString())}catch{}})()}await Q.unlink(S),n++}catch{}}let a=X.join(e,"sessions"),c=l(f=>{if(!f||!f.id)return;E.getDb(s).prepare(`
|
|
567
567
|
INSERT OR IGNORE INTO sessions
|
|
568
568
|
(id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
|
|
569
569
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
570
|
-
`).run(j(f.id),j(f.projectId)??r,j(f.task)??"",j(f.status)??"completed",j(f.startedAt)??new Date().toISOString(),j(f.pausedAt),j(f.completedAt),jn(f.duration)??0,f.metrics?JSON.stringify(f.metrics):"{}",f.timeline?JSON.stringify(f.timeline):"[]")},"sessionInsert"),u=X.join(a,"current.json"),d=await Wt(u);d!==null&&(c(d),await Q.unlink(u).catch(()=>{}),n++);let m=X.join(a,"archive");try{let f=await Q.readdir(m);for(let y of f){let C=X.join(m,y);try{if(!(await Q.stat(C)).isDirectory())continue;let N=await Q.readdir(C);for(let oe of N){if(!oe.endsWith(".json"))continue;let be=await Wt(X.join(C,oe));be!==null&&(c(be),await Q.unlink(X.join(C,oe)).catch(()=>{}),n++)}(await Q.readdir(C)).length===0&&await Q.rmdir(C).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=[...Yc.map(f=>f.filename),"checksums.json","file-scores.json"];for(let f of g){let S=X.join(p,f),y=await Wt(S);if(y===null)continue;let C=Yc.find(E=>E.filename===f);C&&(T.run(r,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",C.key,JSON.stringify(y),new Date().toISOString()),ym(r,C.key,y));try{await Q.unlink(S)}catch{}n++}return n}var Qc,Yc,ui=k(()=>{"use strict";Pe();F();se();Qc=[{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"}],Yc=[{filename:"project-index.json",key:"project-index"},{filename:"domains.json",key:"domains"},{filename:"categories-cache.json",key:"categories-cache"}];l(_r,"migrateJsonToSqlite");l(Ub,"createBackup");l(Xc,"copyFiles");l(hm,"populateNormalized");l(Hb,"populateTasksFromState");l(Gb,"populateQueueTasks");l(zb,"populateIdeas");l(Wb,"populateShippedFeatures");l(Vb,"populateMetricsDaily");l(Bb,"populateAnalysis");l(ym,"populateIndexTables");l(Jb,"populateCategoriesIndex");l(qb,"migrateChecksums");l(Kb,"migrateFileScores");l(Xb,"migrateEventsJsonl");l(Yb,"migrateLearningsJsonl");l(Qb,"migrateSessionFiles");l(Zb,"cleanupJsonFiles");l(j,"toStr");l(jn,"toNum");l(Wt,"readJsonSafe");l(li,"sweepLegacyJson")});var Zc,ke,Ms=k(()=>{"use strict";Dt();Co();ce();In();tn();Zc=class extends Be{static{l(this,"QueueStorage")}constructor(){super("queue.json",fp)}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(n=>n.section==="active"&&!n.completed)}async getBacklog(e){return(await this.read(e)).tasks.filter(n=>n.section==="backlog"&&!n.completed)}async getNextTask(e){let t=await this.getActiveTasks(e);return this.sortTasks(t)[0]||null}async addTask(e,t){let n={...t,id:me(),createdAt:b(),completed:!1};return await this.update(e,s=>({tasks:[...s.tasks,n],lastUpdated:b()})),await this.publishEvent(e,"queue.task_added",{taskId:n.id,description:n.description,priority:n.priority,section:n.section}),n}async addTasks(e,t){let n=b(),s=t.map(o=>({...o,id:me(),createdAt:n,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...s],lastUpdated:n})),await this.publishEvent(e,"queue.tasks_added",{count:s.length,tasks:s.map(o=>({id:o.id,description:o.description}))}),s}async removeTask(e,t){await this.update(e,n=>({tasks:n.tasks.filter(s=>s.id!==t),lastUpdated:b()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let n=null;if(await this.update(e,s=>({tasks:s.tasks.map(i=>i.id===t?(n={...i,completed:!0,completedAt:b()},n):i),lastUpdated:b()})),n){let s=n;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:s.description,completedAt:s.completedAt})}return n}async moveToSection(e,t,n){await this.update(e,s=>({tasks:s.tasks.map(o=>o.id===t?{...o,section:n}:o),lastUpdated:b()}))}async setPriority(e,t,n){await this.update(e,s=>({tasks:s.tasks.map(o=>o.id===t?{...o,priority:n}:o),lastUpdated:b()}))}async clearCompleted(e){let n=(await this.read(e)).tasks.filter(s=>s.completed).length;return await this.update(e,s=>({tasks:s.tasks.filter(o=>!o.completed),lastUpdated:b()})),n}async removeStaleCompleted(e){let t=await this.read(e),n=bn(en.QUEUE_COMPLETED_DAYS),s=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<n);if(s.length===0)return 0;Tt.archiveMany(e,s.map(i=>({entityType:"queue_task",entityId:i.id,entityData:i,summary:i.description,reason:"age"})));let o=new Set(s.map(i=>i.id));return await this.update(e,i=>({tasks:i.tasks.filter(a=>!o.has(a.id)),lastUpdated:b()})),await this.publishEvent(e,"queue.stale_removed",{count:s.length}),s.length}sortTasks(e){let t={critical:0,high:1,medium:2,low:3},n={active:0,previously_active:1,backlog:2};return[...e].sort((s,o)=>{let i=n[s.section]-n[o.section];if(i!==0)return i;let a=t[s.priority]-t[o.priority];return a!==0?a:new Date(s.createdAt).getTime()-new Date(o.createdAt).getTime()})}},ke=new Zc});var el,St,Fr=k(()=>{"use strict";Dt();Xa();ce();In();tn();el=class extends Be{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",ap)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(e){return`shipped.${e}d`}async getAll(e){return(await this.read(e)).shipped}async getRecent(e,t=5){return(await this.read(e)).shipped.sort((s,o)=>new Date(o.shippedAt).getTime()-new Date(s.shippedAt).getTime()).slice(0,t)}async addShipped(e,t){let n={...t,id:me(),shippedAt:b()};return await this.update(e,s=>({shipped:[n,...s.shipped],lastUpdated:b()})),await this.publishEvent(e,"feature.shipped",{shipId:n.id,name:n.name,version:n.version,shippedAt:n.shippedAt}),n}async getByVersion(e,t){return(await this.read(e)).shipped.find(s=>s.version===t)}async getCount(e){return(await this.read(e)).shipped.length}async getByDateRange(e,t,n){return(await this.read(e)).shipped.filter(o=>{let i=new Date(o.shippedAt);return i>=t&&i<=n})}async getStats(e,t="month"){let n=new Date,s;switch(t){case"week":s=new Date(n.getTime()-10080*60*1e3);break;case"month":s=new Date(n.getFullYear(),n.getMonth(),1);break;case"year":s=new Date(n.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,s,n)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),n=bn(en.SHIPPED_RETENTION_DAYS),s=t.shipped.filter(i=>new Date(i.shippedAt)<n);if(s.length===0)return 0;Tt.archiveMany(e,s.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)>=n).map(i=>i.id));return await this.update(e,i=>({shipped:i.shipped.filter(a=>o.has(a.id)),lastUpdated:b()})),await this.publishEvent(e,"shipped.archived",{count:s.length,oldestShippedAt:s[s.length-1]?.shippedAt}),s.length}},St=new el});var Nr,tl,Qn,nl=k(()=>{"use strict";Nr={idle:{transitions:["task","next"],prompt:"p. task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"p. done Complete task | p. pause Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"p. resume Continue | p. task <new> Start different | p. ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","next","pause","reopen"],prompt:"p. ship Ship it | p. task <next> Start next | p. reopen Reopen for rework",description:"Task completed"},shipped:{transitions:["task","next"],prompt:"p. task <description> Start new task",description:"Feature shipped"}},tl=class{static{l(this,"WorkflowStateMachine")}getCurrentState(e){let t=e?.currentTask;if(!t)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof t.status=="string"?t.status:"").toLowerCase()){case"in_progress":case"working":return"working";case"paused":return"paused";case"completed":case"done":return"completed";case"shipped":return"shipped";default:return t?"working":"idle"}}canTransition(e,t){let n=Nr[e];if(n.transitions.includes(t))return{valid:!0};let s=n.transitions.map(o=>`p. ${o}`).join(", ");return{valid:!1,error:`Cannot run 'p. ${t}' in ${e} state`,suggestion:`Valid commands: ${s}`}}getNextState(e,t){switch(t){case"task":return"working";case"done":return"completed";case"pause":return"paused";case"resume":return"working";case"ship":return"shipped";case"reopen":return"working";case"next":return e;default:return e}}getStateInfo(e){return Nr[e]}getPrompt(e){return Nr[e].prompt}getValidCommands(e){return Nr[e].transitions}formatNextSteps(e){return Nr[e].transitions.map(n=>{switch(n){case"task":return"p. task <desc> Start new task";case"done":return"p. done Complete current task";case"pause":return"p. pause Pause and switch context";case"resume":return"p. resume Continue paused task";case"ship":return"p. ship Ship the feature";case"reopen":return"p. reopen Reopen for rework";case"next":return"p. next View task queue";default:return`p. ${n}`}})}},Qn=new tl});var sl,L,Os=k(()=>{"use strict";Dt();Co();ce();nl();In();tn();sl=class extends Be{static{l(this,"StateStorage")}constructor(){super("state.json",mp)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let n=Qn.getCurrentState(e),s=Qn.canTransition(n,t);if(!s.valid)throw new Error(`${s.error}. ${s.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async startTask(e,t){let n=await this.read(e);this.validateTransition(n,"task");let s={...t,startedAt:b()};return await this.update(e,o=>({...o,currentTask:s,lastUpdated:b()})),await this.publishEvent(e,"task.started",{taskId:s.id,description:s.description,startedAt:s.startedAt,sessionId:s.sessionId}),s}async updateCurrentTask(e,t){let n=await this.read(e);if(!n.currentTask)return null;let s={...n.currentTask,...t};return await this.update(e,o=>({...o,currentTask:s,lastUpdated:b()})),s}async completeTask(e,t){let n=await this.read(e),s=n.currentTask;if(!s)return null;this.validateTransition(n,"done");let o=b(),i=this.createTaskHistoryEntry(s,o,t),a=this.getTaskHistoryFromState(n),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:s.id,description:s.description,startedAt:s.startedAt,completedAt:o}),s}createTaskHistoryEntry(e,t,n){let s=e,o=(e.subtasks||[]).filter(c=>c.status==="completed"&&c.summary).map(c=>c.summary),i=o.length>0?o.map(c=>c.title).join(", "):"Task completed",a={taskId:e.id,title:s.parentDescription||e.description,classification:s.type||"improvement",startedAt:e.startedAt,completedAt:t,subtaskCount:e.subtasks?.length||0,subtaskSummaries:o,outcome:i,branchName:s.branch||"unknown",linearId:e.linearId,linearUuid:e.linearUuid,prUrl:s.prUrl};return n&&(a.feedback=n),a}maxPausedTasks=5;maxTaskHistory=20;stalenessThresholdDays=30;async pauseTask(e,t){let n=await this.read(e);if(!n.currentTask)return null;this.validateTransition(n,"pause");let s={...n.currentTask,status:"paused",pausedAt:b(),pauseReason:t},o=this.getPausedTasksFromState(n),i=[s,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:b()})),await this.publishEvent(e,"task.paused",{taskId:s.id,description:s.description,pausedAt:s.pausedAt,reason:t,pausedCount:i.length}),s}async resumeTask(e,t){let n=await this.read(e),s=this.getPausedTasksFromState(n);if(s.length===0)return null;this.validateTransition(n,"resume");let o=0;if(t&&(o=s.findIndex(g=>g.id===t),o===-1))return null;let i=s[o],a=s.filter((g,f)=>f!==o),{status:c,pausedAt:u,pauseReason:d,...m}=i,p={...m,startedAt:b(),sessionId:i.sessionId??me()};return await this.update(e,g=>({...g,currentTask:p,previousTask:null,pausedTasks:a,lastUpdated:b()})),await this.publishEvent(e,"task.resumed",{taskId:p.id,description:p.description,resumedAt:p.startedAt,remainingPaused:a.length}),p}getPausedTasksFromState(e){return e.pausedTasks&&e.pausedTasks.length>0?e.pausedTasks:e.previousTask?[e.previousTask]:[]}getTaskHistoryFromState(e){return e.taskHistory||[]}async getStalePausedTasks(e){let t=await this.read(e),n=this.getPausedTasksFromState(t),s=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return n.filter(o=>new Date(o.pausedAt).getTime()<s)}async archiveStalePausedTasks(e){let t=await this.read(e),n=this.getPausedTasksFromState(t),s=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=n.filter(a=>new Date(a.pausedAt).getTime()<s),i=n.filter(a=>new Date(a.pausedAt).getTime()>=s);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:b()}));for(let a of o)await this.publishEvent(e,"task.archived",{taskId:a.id,description:a.description,pausedAt:a.pausedAt,reason:"staleness"});return o}async clearTask(e){await this.update(e,()=>({currentTask:null,previousTask:null,pausedTasks:[],lastUpdated:b()}))}async hasTask(e){let t=await this.read(e),n=this.getPausedTasksFromState(t);return t.currentTask!==null||n.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 n=await this.read(e);return this.getTaskHistoryFromState(n).filter(o=>o.classification===t)}async getAggregatedFeedback(e){let n=(await this.getTaskHistory(e)).filter(p=>p.feedback),s=[],o=[],i=[],a=[];for(let p of n){let g=p.feedback;g.stackConfirmed&&s.push(...g.stackConfirmed),g.patternsDiscovered&&o.push(...g.patternsDiscovered),g.agentAccuracy&&i.push(...g.agentAccuracy),g.issuesEncountered&&a.push(...g.issuesEncountered)}let c=[...new Set(s)],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 createSubtasks(e,t){let n=await this.read(e);if(!n.currentTask)return;let s=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?b():void 0,dependsOn:o.dependsOn||[]}));await this.update(e,o=>({...o,currentTask:{...o.currentTask,subtasks:s,currentSubtaskIndex:0,subtaskProgress:{completed:0,total:s.length,percentage:0}},lastUpdated:b()})),await this.publishEvent(e,"subtasks.created",{taskId:n.currentTask.id,subtaskCount:s.length,subtasks:s.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let n=lp.safeParse(t);if(!n.success){let f=n.error.issues.map(S=>`${S.path.join(".")}: ${S.message}`);throw new Error(`Subtask completion requires handoff data:
|
|
570
|
+
`).run(I(f.id),I(f.projectId)??s,I(f.task)??"",I(f.status)??"completed",I(f.startedAt)??new Date().toISOString(),I(f.pausedAt),I(f.completedAt),An(f.duration)??0,f.metrics?JSON.stringify(f.metrics):"{}",f.timeline?JSON.stringify(f.timeline):"[]")},"sessionInsert"),u=X.join(a,"current.json"),d=await Ut(u);d!==null&&(c(d),await Q.unlink(u).catch(()=>{}),n++);let m=X.join(a,"archive");try{let f=await Q.readdir(m);for(let w of f){let v=X.join(m,w);try{if(!(await Q.stat(v)).isDirectory())continue;let _=await Q.readdir(v);for(let re of _){if(!re.endsWith(".json"))continue;let ke=await Ut(X.join(v,re));ke!==null&&(c(ke),await Q.unlink(X.join(v,re)).catch(()=>{}),n++)}(await Q.readdir(v)).length===0&&await Q.rmdir(v).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(f=>f.filename),"checksums.json","file-scores.json"];for(let f of g){let S=X.join(p,f),w=await Ut(S);if(w===null)continue;let v=Uc.find(T=>T.filename===f);v&&(E.run(s,"INSERT OR REPLACE INTO index_meta (key, data, updated_at) VALUES (?, ?, ?)",v.key,JSON.stringify(w),new Date().toISOString()),im(s,v.key,w));try{await Q.unlink(S)}catch{}n++}return n}var Hc,Uc,ii=k(()=>{"use strict";ve();L();oe();Hc=[{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(jr,"migrateJsonToSqlite");l(Ab,"createBackup");l(Lc,"copyFiles");l(om,"populateNormalized");l(Rb,"populateTasksFromState");l(Db,"populateQueueTasks");l(jb,"populateIdeas");l(Ib,"populateShippedFeatures");l($b,"populateMetricsDaily");l(Mb,"populateAnalysis");l(im,"populateIndexTables");l(Ob,"populateCategoriesIndex");l(Fb,"migrateChecksums");l(_b,"migrateFileScores");l(Nb,"migrateEventsJsonl");l(Lb,"migrateLearningsJsonl");l(Ub,"migrateSessionFiles");l(Hb,"cleanupJsonFiles");l(I,"toStr");l(An,"toNum");l(Ut,"readJsonSafe");l(oi,"sweepLegacyJson")});var Gc,Ie,Ir=k(()=>{"use strict";Rt();bo();ce();xn();Xt();Gc=class extends Be{static{l(this,"QueueStorage")}constructor(){super("queue.json",rp)}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(n=>n.section==="active"&&!n.completed)}async getBacklog(e){return(await this.read(e)).tasks.filter(n=>n.section==="backlog"&&!n.completed)}async getNextTask(e){let t=await this.getActiveTasks(e);return this.sortTasks(t)[0]||null}async addTask(e,t){let n={...t,id:me(),createdAt:b(),completed:!1};return await this.update(e,r=>({tasks:[...r.tasks,n],lastUpdated:b()})),await this.publishEvent(e,"queue.task_added",{taskId:n.id,description:n.description,priority:n.priority,section:n.section}),n}async addTasks(e,t){let n=b(),r=t.map(o=>({...o,id:me(),createdAt:n,completed:!1}));return await this.update(e,o=>({tasks:[...o.tasks,...r],lastUpdated:n})),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,n=>({tasks:n.tasks.filter(r=>r.id!==t),lastUpdated:b()})),await this.publishEvent(e,"queue.task_removed",{taskId:t})}async completeTask(e,t){let n=null;if(await this.update(e,r=>({tasks:r.tasks.map(i=>i.id===t?(n={...i,completed:!0,completedAt:b()},n):i),lastUpdated:b()})),n){let r=n;await this.publishEvent(e,"queue.task_completed",{taskId:t,description:r.description,completedAt:r.completedAt})}return n}async moveToSection(e,t,n){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,section:n}:o),lastUpdated:b()}))}async setPriority(e,t,n){await this.update(e,r=>({tasks:r.tasks.map(o=>o.id===t?{...o,priority:n}:o),lastUpdated:b()}))}async clearCompleted(e){let n=(await this.read(e)).tasks.filter(r=>r.completed).length;return await this.update(e,r=>({tasks:r.tasks.filter(o=>!o.completed),lastUpdated:b()})),n}async removeStaleCompleted(e){let t=await this.read(e),n=yn(Kt.QUEUE_COMPLETED_DAYS),r=t.tasks.filter(i=>i.completed&&i.completedAt&&new Date(i.completedAt)<n);if(r.length===0)return 0;Ct.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:b()})),await this.publishEvent(e,"queue.stale_removed",{count:r.length}),r.length}sortTasks(e){let t={critical:0,high:1,medium:2,low:3},n={active:0,previously_active:1,backlog:2};return[...e].sort((r,o)=>{let i=n[r.section]-n[o.section];if(i!==0)return i;let a=t[r.priority]-t[o.priority];return a!==0?a:new Date(r.createdAt).getTime()-new Date(o.createdAt).getTime()})}},Ie=new Gc});var Wc,wt,$r=k(()=>{"use strict";Rt();Na();ce();xn();Xt();Wc=class extends Be{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",Xd)}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 n={...t,id:me(),shippedAt:b()};return await this.update(e,r=>({shipped:[n,...r.shipped],lastUpdated:b()})),await this.publishEvent(e,"feature.shipped",{shipId:n.id,name:n.name,version:n.version,shippedAt:n.shippedAt}),n}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,n){return(await this.read(e)).shipped.filter(o=>{let i=new Date(o.shippedAt);return i>=t&&i<=n})}async getStats(e,t="month"){let n=new Date,r;switch(t){case"week":r=new Date(n.getTime()-10080*60*1e3);break;case"month":r=new Date(n.getFullYear(),n.getMonth(),1);break;case"year":r=new Date(n.getFullYear(),0,1);break}return{count:(await this.getByDateRange(e,r,n)).length,period:t}}async archiveOldShipped(e){let t=await this.read(e),n=yn(Kt.SHIPPED_RETENTION_DAYS),r=t.shipped.filter(i=>new Date(i.shippedAt)<n);if(r.length===0)return 0;Ct.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)>=n).map(i=>i.id));return await this.update(e,i=>({shipped:i.shipped.filter(a=>o.has(a.id)),lastUpdated:b()})),await this.publishEvent(e,"shipped.archived",{count:r.length,oldestShippedAt:r[r.length-1]?.shippedAt}),r.length}},wt=new Wc});var Mr,zc,qn,Vc=k(()=>{"use strict";Mr={idle:{transitions:["task","next"],prompt:"p. task <description> Start working",description:"No active task"},working:{transitions:["done","pause"],prompt:"p. done Complete task | p. pause Switch context",description:"Task in progress"},paused:{transitions:["resume","task","ship"],prompt:"p. resume Continue | p. task <new> Start different | p. ship Ship directly",description:"Task paused"},completed:{transitions:["ship","task","next","pause","reopen"],prompt:"p. ship Ship it | p. task <next> Start next | p. reopen Reopen for rework",description:"Task completed"},shipped:{transitions:["task","next"],prompt:"p. task <description> Start new task",description:"Feature shipped"}},zc=class{static{l(this,"WorkflowStateMachine")}getCurrentState(e){let t=e?.currentTask;if(!t)return(e?.pausedTasks?.length||0)>0||e?.previousTask?.status==="paused"?"paused":"idle";switch((typeof t.status=="string"?t.status:"").toLowerCase()){case"in_progress":case"working":return"working";case"paused":return"paused";case"completed":case"done":return"completed";case"shipped":return"shipped";default:return t?"working":"idle"}}canTransition(e,t){let n=Mr[e];if(n.transitions.includes(t))return{valid:!0};let r=n.transitions.map(o=>`p. ${o}`).join(", ");return{valid:!1,error:`Cannot run 'p. ${t}' in ${e} state`,suggestion:`Valid commands: ${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";case"next":return e;default:return e}}getStateInfo(e){return Mr[e]}getPrompt(e){return Mr[e].prompt}getValidCommands(e){return Mr[e].transitions}formatNextSteps(e){return Mr[e].transitions.map(n=>{switch(n){case"task":return"p. task <desc> Start new task";case"done":return"p. done Complete current task";case"pause":return"p. pause Pause and switch context";case"resume":return"p. resume Continue paused task";case"ship":return"p. ship Ship the feature";case"reopen":return"p. reopen Reopen for rework";case"next":return"p. next View task queue";default:return`p. ${n}`}})}},qn=new zc});var Bc,N,Is=k(()=>{"use strict";Rt();bo();ce();Vc();xn();Xt();Bc=class extends Be{static{l(this,"StateStorage")}constructor(){super("state.json",np)}getDefault(){return{currentTask:null,previousTask:null,pausedTasks:[],taskHistory:[],lastUpdated:""}}getEventType(e){return`state.${e}d`}validateTransition(e,t){let n=qn.getCurrentState(e),r=qn.canTransition(n,t);if(!r.valid)throw new Error(`${r.error}. ${r.suggestion||""}`.trim())}async getCurrentTask(e){return(await this.read(e)).currentTask}async startTask(e,t){let n=await this.read(e);this.validateTransition(n,"task");let r={...t,startedAt:b()};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:b()})),await this.publishEvent(e,"task.started",{taskId:r.id,description:r.description,startedAt:r.startedAt,sessionId:r.sessionId}),r}async updateCurrentTask(e,t){let n=await this.read(e);if(!n.currentTask)return null;let r={...n.currentTask,...t};return await this.update(e,o=>({...o,currentTask:r,lastUpdated:b()})),r}async completeTask(e,t){let n=await this.read(e),r=n.currentTask;if(!r)return null;this.validateTransition(n,"done");let o=b(),i=this.createTaskHistoryEntry(r,o,t),a=this.getTaskHistoryFromState(n),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,n){let r=e,o=(e.subtasks||[]).filter(c=>c.status==="completed"&&c.summary).map(c=>c.summary),i=o.length>0?o.map(c=>c.title).join(", "):"Task completed",a={taskId:e.id,title:r.parentDescription||e.description,classification:r.type||"improvement",startedAt:e.startedAt,completedAt:t,subtaskCount:e.subtasks?.length||0,subtaskSummaries:o,outcome:i,branchName:r.branch||"unknown",linearId:e.linearId,linearUuid:e.linearUuid,prUrl:r.prUrl};return n&&(a.feedback=n),a}maxPausedTasks=5;maxTaskHistory=20;stalenessThresholdDays=30;async pauseTask(e,t){let n=await this.read(e);if(!n.currentTask)return null;this.validateTransition(n,"pause");let r={...n.currentTask,status:"paused",pausedAt:b(),pauseReason:t},o=this.getPausedTasksFromState(n),i=[r,...o].slice(0,this.maxPausedTasks);return await this.update(e,a=>({...a,currentTask:null,previousTask:null,pausedTasks:i,lastUpdated:b()})),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 n=await this.read(e),r=this.getPausedTasksFromState(n);if(r.length===0)return null;this.validateTransition(n,"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,f)=>f!==o),{status:c,pausedAt:u,pauseReason:d,...m}=i,p={...m,startedAt:b(),sessionId:i.sessionId??me()};return await this.update(e,g=>({...g,currentTask:p,previousTask:null,pausedTasks:a,lastUpdated:b()})),await this.publishEvent(e,"task.resumed",{taskId:p.id,description:p.description,resumedAt:p.startedAt,remainingPaused:a.length}),p}getPausedTasksFromState(e){return e.pausedTasks&&e.pausedTasks.length>0?e.pausedTasks:e.previousTask?[e.previousTask]:[]}getTaskHistoryFromState(e){return e.taskHistory||[]}async getStalePausedTasks(e){let t=await this.read(e),n=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3;return n.filter(o=>new Date(o.pausedAt).getTime()<r)}async archiveStalePausedTasks(e){let t=await this.read(e),n=this.getPausedTasksFromState(t),r=Date.now()-this.stalenessThresholdDays*24*60*60*1e3,o=n.filter(a=>new Date(a.pausedAt).getTime()<r),i=n.filter(a=>new Date(a.pausedAt).getTime()>=r);if(o.length===0)return[];Ct.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:b()}));for(let a of o)await this.publishEvent(e,"task.archived",{taskId:a.id,description:a.description,pausedAt:a.pausedAt,reason:"staleness"});return o}async clearTask(e){await this.update(e,()=>({currentTask:null,previousTask:null,pausedTasks:[],lastUpdated:b()}))}async hasTask(e){let t=await this.read(e),n=this.getPausedTasksFromState(t);return t.currentTask!==null||n.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 n=await this.read(e);return this.getTaskHistoryFromState(n).filter(o=>o.classification===t)}async getAggregatedFeedback(e){let n=(await this.getTaskHistory(e)).filter(p=>p.feedback),r=[],o=[],i=[],a=[];for(let p of n){let g=p.feedback;g.stackConfirmed&&r.push(...g.stackConfirmed),g.patternsDiscovered&&o.push(...g.patternsDiscovered),g.agentAccuracy&&i.push(...g.agentAccuracy),g.issuesEncountered&&a.push(...g.issuesEncountered)}let c=[...new Set(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 createSubtasks(e,t){let n=await this.read(e);if(!n.currentTask)return;let r=t.map((o,i)=>({...o,status:i===0?"in_progress":"pending",startedAt:i===0?b():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:b()})),await this.publishEvent(e,"subtasks.created",{taskId:n.currentTask.id,subtaskCount:r.length,subtasks:r.map(o=>({id:o.id,description:o.description,domain:o.domain}))})}async completeSubtask(e,t){let n=Qd.safeParse(t);if(!n.success){let f=n.error.issues.map(S=>`${S.path.join(".")}: ${S.message}`);throw new Error(`Subtask completion requires handoff data:
|
|
571
571
|
${f.join(`
|
|
572
|
-
`)}`)}let{output:
|
|
573
|
-
VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,n,n,t.metadata?JSON.stringify(t.metadata):null);let
|
|
574
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,
|
|
572
|
+
`)}`)}let{output:r,summary:o}=n.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:b(),output:r,summary:o};let d=u.filter(f=>f.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:b()}),await this.update(e,f=>({...f,currentTask:{...f.currentTask,subtasks:u,currentSubtaskIndex:g<m?g:a,subtaskProgress:{completed:d,total:m,percentage:p}},lastUpdated:b()})),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 n=t.currentTask.currentSubtaskIndex||0;return t.currentTask.subtasks[n]||null}async getNextSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let n=(t.currentTask.currentSubtaskIndex||0)+1;return t.currentTask.subtasks[n]||null}async getPreviousSubtask(e){let t=await this.read(e);if(!t.currentTask?.subtasks)return null;let n=(t.currentTask.currentSubtaskIndex||0)-1;return n<0?null:t.currentTask.subtasks[n]||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(n=>n.status==="completed"||n.status==="failed"||n.status==="skipped"):!0}async failSubtask(e,t){let n=await this.read(e);if(!n.currentTask?.subtasks)return null;let r=n.currentTask.currentSubtaskIndex||0,o=n.currentTask.subtasks[r];if(!o)return null;let i=[...n.currentTask.subtasks];i[r]={...o,status:"failed",completedAt:b(),output:`Failed: ${t}`};let a=r+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:b()});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:b()})),await this.publishEvent(e,"subtask.failed",{taskId:n.currentTask.id,subtaskId:o.id,description:o.description,error:t}),a<c?i[a]:null}async skipSubtask(e,t){let n=await this.read(e);if(!n.currentTask?.subtasks)return null;let r=n.currentTask.currentSubtaskIndex||0,o=n.currentTask.subtasks[r];if(!o)return null;let i=[...n.currentTask.subtasks];i[r]={...o,status:"skipped",completedAt:b(),output:`Skipped: ${t}`,skipReason:t};let a=r+1,c=i.length;a<c&&(i[a]={...i[a],status:"in_progress",startedAt:b()});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:b()})),await this.publishEvent(e,"subtask.skipped",{taskId:n.currentTask.id,subtaskId:o.id,description:o.description,reason:t}),a<c?i[a]:null}async blockSubtask(e,t){let n=await this.read(e);if(!n.currentTask?.subtasks)return null;let r=n.currentTask.currentSubtaskIndex||0,o=n.currentTask.subtasks[r];if(!o)return null;let i=[...n.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:b()}),await this.update(e,u=>({...u,currentTask:{...u.currentTask,subtasks:i,currentSubtaskIndex:a<c?a:r},lastUpdated:b()})),await this.publishEvent(e,"subtask.blocked",{taskId:n.currentTask.id,subtaskId:o.id,description:o.description,blocker:t}),a<c?i[a]:null}},N=new Bc});var am=k(()=>{"use strict";si();L()});var Jc,qc,Kc=k(()=>{"use strict";ys();Xt();Jc=class extends Be{static{l(this,"VelocityStorage")}constructor(){super("velocity.json")}getDefault(){return{metrics:ip,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}},qc=new Jc});var Xc,nt,Yc=k(()=>{"use strict";oe();Xc=class{static{l(this,"CustomWorkflowStorage")}createWorkflow(e,t){let n=new Date().toISOString();G.run(e,`INSERT INTO custom_workflows (name, description, created_at, updated_at, is_builtin, enabled, metadata)
|
|
573
|
+
VALUES (?, ?, ?, ?, 0, 1, ?)`,t.name,t.description??null,n,n,t.metadata?JSON.stringify(t.metadata):null);let r=G.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 n=G.get(e,"SELECT * FROM custom_workflows WHERE name = ?",t);return n?this.rowToWorkflow(n):null}getAllWorkflows(e,t=!1){let n=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 G.query(e,n).map(o=>this.rowToWorkflow(o))}updateWorkflow(e,t,n){if(!this.getWorkflow(e,t))return!1;let o=new Date().toISOString(),i=[],a=[];return n.description!==void 0&&(i.push("description = ?"),a.push(n.description)),n.enabled!==void 0&&(i.push("enabled = ?"),a.push(n.enabled?1:0)),n.metadata!==void 0&&(i.push("metadata = ?"),a.push(JSON.stringify(n.metadata))),i.length===0?!1:(i.push("updated_at = ?"),a.push(o),a.push(t),G.run(e,`UPDATE custom_workflows SET ${i.join(", ")} WHERE name = ?`,...a),!0)}deleteWorkflow(e,t){let n=this.getWorkflow(e,t);if(!n)return!1;if(n.isBuiltin)throw new Error(`Cannot delete built-in workflow: ${t}`);return G.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"],n=["add","rm","gate","list","create","delete","run","help","reset","init"];return t.includes(e)||n.includes(e)}isValidName(e){return/^[a-z0-9-]+$/.test(e)}rowToWorkflow(e){return{id:e.id,name:e.name,description:e.description,createdAt:e.created_at,updatedAt:e.updated_at,isBuiltin:e.is_builtin===1,enabled:e.enabled===1,metadata:e.metadata?JSON.parse(e.metadata):null}}},nt=new Xc});function Qc(s){return{id:s.id,type:s.type,command:s.command,position:s.position,action:s.action,description:s.description,enabled:s.enabled===1,timeoutMs:s.timeout_ms,createdAt:s.created_at,sortOrder:s.sort_order}}var Zc,Ee,Or=k(()=>{"use strict";Yc();oe();l(Qc,"rowToRule");Zc=class{static{l(this,"WorkflowRuleStorage")}addRule(e,t){let n=E.get(e,"SELECT MAX(sort_order) as m FROM workflow_rules WHERE command = ?",t.command),r=t.sortOrder||(n?.m??-1)+1;return E.run(e,`INSERT INTO workflow_rules (type, command, position, action, description, enabled, timeout_ms, created_at, sort_order)
|
|
574
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,t.type,t.command,t.position,t.action,t.description??null,t.enabled?1:0,t.timeoutMs,t.createdAt,r),E.get(e,"SELECT last_insert_rowid() as id")?.id??0}removeRule(e,t){return E.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t)?(E.run(e,"DELETE FROM workflow_rules WHERE id = ?",t),!0):!1}updateRule(e,t,n){if(!E.get(e,"SELECT id FROM workflow_rules WHERE id = ?",t))return!1;let o={type:{column:"type"},command:{column:"command"},position:{column:"position"},action:{column:"action"},description:{column:"description"},enabled:{column:"enabled",transform:l(c=>c?1:0,"transform")},timeoutMs:{column:"timeout_ms"},createdAt:{column:"created_at"},sortOrder:{column:"sort_order"}},i=[],a=[];for(let[c,u]of Object.entries(n)){let d=o[c];d&&(i.push(`${d.column} = ?`),a.push(d.transform?d.transform(u):u))}return i.length===0||(a.push(t),E.run(e,`UPDATE workflow_rules SET ${i.join(", ")} WHERE id = ?`,...a)),!0}getRuleById(e,t){let n=E.get(e,"SELECT * FROM workflow_rules WHERE id = ?",t);return n?Qc(n):null}getRulesForCommand(e,t){let n=nt.getWorkflow(e,t);return!n||!n.enabled?[]:E.query(e,"SELECT * FROM workflow_rules WHERE command = ? AND enabled = 1 ORDER BY sort_order ASC",t).map(Qc)}getAllRules(e){return E.query(e,"SELECT * FROM workflow_rules ORDER BY command ASC, sort_order ASC").map(Qc)}resetRules(e){let t=E.get(e,"SELECT COUNT(*) as c FROM workflow_rules");return E.run(e,"DELETE FROM workflow_rules"),t?.c??0}},Ee=new Zc});var Yt=k(()=>{"use strict";Ar();xn();rm();oe();Dr();xr();ri();ii();Ir();$r();Is();am();Xt();Kc();Or()});function Gb(){return`\u26A1 prjct
|
|
575
575
|
|
|
576
|
-
---`}function
|
|
577
|
-
\u26A1 prjct \xB7 v${
|
|
578
|
-
`)}function
|
|
579
|
-
${
|
|
580
|
-
\`\`\``}function ee(
|
|
581
|
-
${e}`}function
|
|
582
|
-
`)}function
|
|
583
|
-
> ${e.join(" | ")}`:"";return`## \u26A1 ${
|
|
584
|
-
${
|
|
585
|
-
${
|
|
586
|
-
`)}`}function
|
|
587
|
-
${
|
|
588
|
-
${
|
|
589
|
-
> ${e}`:`## \u2705 ${
|
|
590
|
-
|
|
591
|
-
`)}function
|
|
592
|
-
Next:`));for(let o of
|
|
593
|
-
`);ae.note(e,"Configuration Summary");let t=await ae.confirm({message:"Generate configuration with these settings?",initialValue:!0});return ae.isCancel(t)||!t?(ae.isCancel(t)&&this.handleCancel(),!1):!0}async detectProjectType(){let e=await import("node:fs/promises"),t=await import("node:path");try{let n=await e.readdir(this.projectPath);if(n.includes("turbo.json")||n.includes("lerna.json")||n.includes("nx.json"))return"monorepo";if(n.includes("package.json")){let
|
|
594
|
-
`).filter(s=>s.trim()).map(s=>JSON.parse(s)):[]}async filter(e,t){return(await this.getAll(e)).filter(s=>{if(t.sessionId&&s.sessionId!==t.sessionId||t.command&&s.command!==t.command||t.agent&&s.agentUsed!==t.agent||t.fromDate&&s.startedAt<t.fromDate||t.toDate&&s.completedAt>t.toDate||t.minQuality&&s.qualityScore<t.minQuality)return!1;if(t.tags&&t.tags.length>0){let o=s.tags||[];if(!t.tags.some(i=>o.includes(i)))return!1}return!0})}async getRecent(e,t=10){return(await this.getAll(e)).slice(-t)}async getByCommand(e,t){return this.filter(e,{command:t})}async getByAgent(e,t){return this.filter(e,{agent:t})}async getEstimateAccuracy(e){let t=await this.getAll(e);if(t.length===0)return 0;let n=t.filter(s=>{if(!s.variance)return!1;let o=this.parseVariance(s.variance),i=this.parseDuration(s.estimatedDuration);return i===0?!1:Math.abs(o)/i<=.2});return Math.round(n.length/t.length*100)}parseVariance(e){let t=e.match(/^([+-])(\d+)([mh])$/);if(!t)return 0;let n=t[1]==="-"?-1:1,s=parseInt(t[2],10),o=t[3];return n*(o==="h"?s*60:s)}parseDuration(e){let t=0,n=e.match(/(\d+)h/);n&&(t+=parseInt(n[1],10)*60);let s=e.match(/(\d+)m/);return s&&(t+=parseInt(s[1],10)),t}},uv=new gi,ft=uv});var fi,dv,fl,Im=k(()=>{"use strict";es();fi=class{static{l(this,"OutcomeAnalyzer")}async summarize(e){let t=await ft.getAll(e);if(t.length===0)return{totalOutcomes:0,avgQualityScore:0,estimateAccuracy:0,topBlockers:[],topAgents:[],patternsDetected:[]};let n=t.reduce((m,p)=>m+p.qualityScore,0)/t.length,s=await ft.getEstimateAccuracy(e),o=new Map;for(let m of t)for(let p of m.blockers||[])o.set(p,(o.get(p)||0)+1);let i=[...o.entries()].sort((m,p)=>p[1]-m[1]).slice(0,5).map(([m])=>m),c=(await this.getAgentMetrics(e)).sort((m,p)=>p.successRate-m.successRate).slice(0,3).map(m=>m.agent),d=(await this.detectPatterns(e)).map(m=>m.description);return{totalOutcomes:t.length,avgQualityScore:Math.round(n*10)/10,estimateAccuracy:s,topBlockers:i,topAgents:c,patternsDetected:d}}async getAgentMetrics(e){let t=await ft.getAll(e),n=new Map;for(let o of t){let i=o.agentUsed||"unknown";n.has(i)||n.set(i,[]),n.get(i).push(o)}let s=[];for(let[o,i]of n){let a=i.length,c=i.filter(S=>S.completedAsPlanned),u=Math.round(c.length/a*100),d=i.reduce((S,y)=>S+y.qualityScore,0)/a,m=i.filter(S=>{if(!S.variance)return!1;let y=this.parseVariance(S.variance),C=this.parseDuration(S.estimatedDuration);return C===0?!1:Math.abs(y)/C<=.2}),p=Math.round(m.length/a*100),g=new Map;for(let S of i.filter(y=>y.completedAsPlanned))for(let y of S.tags||[])g.set(y,(g.get(y)||0)+1);let f=[...g.entries()].sort((S,y)=>y[1]-S[1]).slice(0,3).map(([S])=>S);s.push({agent:o,tasksCompleted:a,successRate:u,avgQualityScore:Math.round(d*10)/10,estimateAccuracy:p,bestFor:f})}return s}async detectPatterns(e){let t=await ft.getAll(e),n=[];if(t.length<3)return n;let s=t.filter(c=>this.parseVariance(c.variance)>0);s.length/t.length>.6&&n.push({description:"Tasks consistently take longer than estimated",confidence:s.length/t.length,occurrences:s.length,suggestedAction:"Add 30% buffer to estimates"});let o=t.filter(c=>this.parseVariance(c.variance)<0);o.length/t.length>.6&&n.push({description:"Tasks consistently finish faster than estimated",confidence:o.length/t.length,occurrences:o.length,suggestedAction:"Reduce estimates by 20%"});let i=new Map;for(let c of t)for(let u of c.blockers||[])i.set(u,(i.get(u)||0)+1);for(let[c,u]of i)u>=3&&n.push({description:`Recurring blocker: ${c}`,confidence:u/t.length,occurrences:u,suggestedAction:`Address root cause of "${c}"`});let a=await this.getAgentMetrics(e);for(let c of a)c.tasksCompleted>=5&&c.successRate>90&&n.push({description:`${c.agent} has high success rate (${c.successRate}%)`,confidence:.9,occurrences:c.tasksCompleted,suggestedAction:`Prefer ${c.agent} for similar tasks`});return n.sort((c,u)=>u.confidence-c.confidence)}async suggestEstimate(e,t){let s=(await ft.getAll(e)).filter(a=>a.tags?.includes(t));if(s.length<2)return null;let o=s.reduce((a,c)=>a+this.parseDuration(c.actualDuration),0),i=Math.round(o/s.length);if(i>=60){let a=Math.floor(i/60),c=i%60;return c>0?`${a}h ${c}m`:`${a}h`}return`${i}m`}async suggestAgent(e,t){let s=(await this.getAgentMetrics(e)).filter(o=>o.bestFor.includes(t));return s.length===0?null:s.sort((o,i)=>i.successRate-o.successRate)[0].agent}parseVariance(e){let t=e.match(/^([+-])(\d+)([mh])$/);if(!t)return 0;let n=t[1]==="-"?-1:1,s=parseInt(t[2],10),o=t[3];return n*(o==="h"?s*60:s)}parseDuration(e){let t=0,n=e.match(/(\d+)h/);n&&(t+=parseInt(n[1],10)*60);let s=e.match(/(\d+)m/);return s&&(t+=parseInt(s[1],10)),t}},dv=new fi,fl=dv});var Gr,hi,hl,yl=k(()=>{"use strict";hs();ce();Gr=3,hi=class{static{l(this,"OutcomeMemoryLearner")}async learnFromTaskHistory(e,t,n){let s={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return s;let o=[...this.extractFileCochangePatterns(t),...this.extractStackPatterns(t),...this.extractArchitecturePatterns(t),...this.extractGotchaPatterns(t)];s.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Gr){s.patternsQualified++;let a=await this.injectIntoMemory(e,i,n);a&&(s.memoriesInjected++,s.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else s.patternsSkipped++,s.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Gr} occurrences needed`});return s}async learnFromOutcomes(e,t,n){let s={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return s;let o=this.extractOutcomePatterns(t);s.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Gr){s.patternsQualified++;let a=await this.injectIntoMemory(e,i,n);a&&(s.memoriesInjected++,s.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else s.patternsSkipped++,s.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Gr} occurrences needed`});return s}extractFileCochangePatterns(e){let t=new Map;for(let s of e){if(!s.subtaskSummaries)continue;let o=new Set;for(let a of s.subtaskSummaries)if(a.filesChanged)for(let c of a.filesChanged)o.add(c.path);let i=Array.from(o).sort();for(let a=0;a<i.length;a++)for(let c=a+1;c<i.length;c++){let u=`${i[a]}|${i[c]}`,d=t.get(u)||{count:0,tasks:[]};d.count++,d.tasks.push(s.taskId),t.set(u,d)}}let n=[];for(let[s,{count:o,tasks:i}]of t)if(o>=2){let[a,c]=s.split("|");n.push({pattern:`Files "${a}" and "${c}" frequently change together (${o} tasks)`,occurrences:o,confidence:this.calculateConfidence(o),category:"file_cochange",sourceTasks:i})}return n.sort((s,o)=>o.occurrences-s.occurrences)}extractStackPatterns(e){let t=new Map;for(let n of e)if(n.feedback?.stackConfirmed)for(let s of n.feedback.stackConfirmed){let o=t.get(s)||{count:0,tasks:[]};o.count++,o.tasks.push(n.taskId),t.set(s,o)}return Array.from(t.entries()).map(([n,{count:s,tasks:o}])=>({pattern:`Project uses ${n}`,occurrences:s,confidence:this.calculateConfidence(s),category:"tech_stack",sourceTasks:o}))}extractArchitecturePatterns(e){let t=new Map;for(let n of e)if(n.feedback?.patternsDiscovered)for(let s of n.feedback.patternsDiscovered){let o=t.get(s)||{count:0,tasks:[]};o.count++,o.tasks.push(n.taskId),t.set(s,o)}return Array.from(t.entries()).map(([n,{count:s,tasks:o}])=>({pattern:n,occurrences:s,confidence:this.calculateConfidence(s),category:"architecture",sourceTasks:o}))}extractGotchaPatterns(e){let t=new Map;for(let n of e)if(n.feedback?.issuesEncountered)for(let s of n.feedback.issuesEncountered){let o=t.get(s)||{count:0,tasks:[]};o.count++,o.tasks.push(n.taskId),t.set(s,o)}return Array.from(t.entries()).filter(([n,{count:s}])=>s>=2).map(([n,{count:s,tasks:o}])=>({pattern:`Known gotcha: ${n}`,occurrences:s,confidence:this.calculateConfidence(s),category:"gotcha",sourceTasks:o}))}extractOutcomePatterns(e){let t=[],n=new Map,s=new Map;for(let i of e){for(let a of i.learnings.whatWorked){let c=n.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),n.set(a,c)}for(let a of i.learnings.whatDidnt){let c=s.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),s.set(a,c)}}for(let[i,{count:a,ids:c}]of n)t.push({pattern:`What works: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"workflow",sourceTasks:c});for(let[i,{count:a,ids:c}]of s)t.push({pattern:`Known issue: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"gotcha",sourceTasks:c});let o=e.filter(i=>i.effort.variance.percentage>30);return o.length>=Gr&&t.push({pattern:`Tasks are frequently underestimated (${o.length}/${e.length} over 30% variance)`,occurrences:o.length,confidence:this.calculateConfidence(o.length),category:"estimation",sourceTasks:o.map(i=>i.id)}),t}getAllPatterns(e,t=[]){return[...this.extractFileCochangePatterns(e),...this.extractStackPatterns(e),...this.extractArchitecturePatterns(e),...this.extractGotchaPatterns(e),...this.extractOutcomePatterns(t)].sort((n,s)=>s.occurrences-n.occurrences)}async injectIntoMemory(e,t,n){let s=this.getTagsForCategory(t.category),o=`[auto-learned] ${this.getTitleForPattern(t)}`,i=this.formatPatternContent(t),c=(await n.searchMemories(e,t.pattern)).find(u=>u.title.startsWith("[auto-learned]")&&u.content.includes(t.pattern));return c?(await n.updateMemory(e,c.id,{content:i,tags:s}),{action:"updated"}):(await n.createMemory(e,{title:o,content:i,tags:s,userTriggered:!1}),{action:"created"})}calculateConfidence(e){return e>=5?"high":e>=3?"medium":"low"}getTagsForCategory(e){return{file_cochange:[O.FILE_STRUCTURE,O.ARCHITECTURE],tech_stack:[O.TECH_STACK],architecture:[O.ARCHITECTURE,O.CODE_STYLE],estimation:[O.SHIP_WORKFLOW],workflow:[O.SHIP_WORKFLOW,O.CODE_STYLE],gotcha:[O.TEST_BEHAVIOR,O.ARCHITECTURE]}[e]||[]}getTitleForPattern(e){return`${{file_cochange:"File coupling",tech_stack:"Tech stack",architecture:"Architecture pattern",estimation:"Estimation insight",workflow:"Workflow pattern",gotcha:"Known gotcha"}[e.category]}: ${e.pattern.slice(0,80)}`}formatPatternContent(e){let t=["source: auto-learned",`pattern: ${e.pattern}`,`occurrences: ${e.occurrences}`,`confidence: ${e.confidence}`,`category: ${e.category}`,`last_updated: ${b()}`];return e.sourceTasks.length>0&&t.push(`source_tasks: ${e.sourceTasks.slice(0,5).join(", ")}`),t.join(`
|
|
595
|
-
`)}},
|
|
576
|
+
---`}function Wb(){return`---
|
|
577
|
+
\u26A1 prjct \xB7 v${za()}`}function U(...s){return zb(Gb(),...s.filter(Boolean),Wb())}function el(s,e){let t=`| ${s.join(" | ")} |`,n=`|${s.map(()=>"---").join("|")}|`,r=e.map(o=>`| ${o.join(" | ")} |`);return[t,n,...r].join(`
|
|
578
|
+
`)}function cm(s,e=""){return`\`\`\`${e}
|
|
579
|
+
${s}
|
|
580
|
+
\`\`\``}function ee(s,e,t=3){return`### ${s}
|
|
581
|
+
${e}`}function Ae(s,e=!1){return s.map((t,n)=>e?`${n+1}. ${t}`:`- ${t}`).join(`
|
|
582
|
+
`)}function tl(s){let e=[];s.branch&&e.push(`Branch: \`${s.branch}\``),s.linearId&&e.push(`Linear: \`${s.linearId}\``),s.type&&e.push(`Type: ${s.type}`),s.duration&&e.push(`Duration: ${s.duration}`),s.status&&e.push(`Status: ${s.status}`);let t=e.length>0?`
|
|
583
|
+
> ${e.join(" | ")}`:"";return`## \u26A1 ${s.description}${t}`}function lm(s,e){let t=["#","Status","Description"],n=s.map((r,o)=>{let i=String(o+1),a;r.status==="completed"?a="\u2705":o===e?a="\u{1F504}":a="\u2B1C";let c=o===e?" **\u2190 current**":"";return[i,a,`${r.description}${c}`]});return`### Subtasks
|
|
584
|
+
${el(t,n)}`}function um(s){return s.length===0?"":`### Relevant Files
|
|
585
|
+
${s.map(t=>{let n=t.lineRange?`:${t.lineRange}`:"",r=t.description?` \u2014 ${t.description}`:"";return`- \`${t.path}${n}\`${r}`}).join(`
|
|
586
|
+
`)}`}function dm(s){return`### Rules
|
|
587
|
+
${Ae(s)}`}function de(s){let e=["Command","Action"],t=s.map(n=>[`\`${n.command}\``,n.label]);return`### Next
|
|
588
|
+
${el(e,t)}`}function St(s){let e=Object.entries(s).filter(([,r])=>r!=null);if(e.length===0)return"";let t=["Metric","Value"],n=e.map(([r,o])=>[r,String(o)]);return el(t,n)}function Se(s,e){return e?`## \u2705 ${s}
|
|
589
|
+
> ${e}`:`## \u2705 ${s}`}function pm(s){return`> \u26A0\uFE0F **${s}**`}function zb(...s){return s.filter(Boolean).join(`
|
|
590
|
+
|
|
591
|
+
`)}function jt(s,e,t,n){console.log(JSON.stringify({status:s,reason:e,...n,options:t}))}var $s=k(()=>{"use strict";Dt();l(Gb,"mdHeader");l(Wb,"mdFooter");l(U,"mdOutput");l(el,"mdTable");l(cm,"mdCodeBlock");l(ee,"mdSection");l(Ae,"mdList");l(tl,"mdTaskHeader");l(lm,"mdSubtasks");l(um,"mdRelevantFiles");l(dm,"mdRules");l(de,"mdNextSteps");l(St,"mdStats");l(Se,"mdDone");l(pm,"mdWarn");l(zb,"mdJoin");l(jt,"mdActionRequired")});import Fr from"chalk";function Tt(s,e={}){if(e.quiet)return;let t=gm[s]||"idle",n=qn.getValidCommands(t);if(n.length===0)return;let r=n.map(o=>({cmd:`p. ${o}`,desc:mm[o]||o}));console.log(Fr.dim(`
|
|
592
|
+
Next:`));for(let o of r){let i=Fr.cyan(o.cmd.padEnd(12));console.log(Fr.dim(` ${i} \u2192 ${o.desc}`))}}function ai(s){let e=gm[s]||"idle";return qn.getValidCommands(e).map(n=>({cmd:`p. ${n}`,desc:mm[n]||n}))}function _r(s){let e=qn.getStateInfo(s);console.log(Fr.dim(`\u{1F4CD} State: ${Fr.white(s.toUpperCase())} - ${e.description}`))}var mm,gm,Ms=k(()=>{"use strict";Vc();mm={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"},gm={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(Tt,"showNextSteps");l(ai,"getNextSteps");l(_r,"showStateInfo")});import ct from"node:path";async function Vb(s,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 j(ct.join(s,"pnpm-lock.yaml"))?"pnpm":await j(ct.join(s,"yarn.lock"))?"yarn":await j(ct.join(s,"bun.lockb"))||await j(ct.join(s,"bun.lock"))?"bun":(await j(ct.join(s,"package-lock.json")),"npm")}function fm(s,e){return s==="yarn"?`yarn ${e}`:s==="pnpm"?`pnpm run ${e}`:s==="bun"?`bun run ${e}`:`npm run ${e}`}function Bb(s){return s==="yarn"?"yarn test":s==="pnpm"?"pnpm test":s==="bun"?"bun test":"npm test"}async function Os(s,e){for(let r of Jb)if(await j(ct.join(s,r)))return r;let n=(e??await sn(s)).find(r=>r.endsWith(qb));if(n)return n}async function cn(s){for(let e of Kb)if(await j(ct.join(s,e)))return e}async function ci(s){let e=ct.join(s,"package.json"),t=await zt(e,null);if(t){let a=await Vb(s,t),c=t.scripts||{},u={stack:"js",packageManager:a};return c.lint&&(u.lint={tool:a,command:fm(a,"lint")}),c.typecheck&&(u.typecheck={tool:a,command:fm(a,"typecheck")}),c.test&&(u.test={tool:a,command:Bb(a)}),u.versionFile=await Os(s),u.changelogFile=await cn(s),u}if(await j(ct.join(s,"pytest.ini"))){let a=await Os(s),c=await cn(s);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}let n=await ot(ct.join(s,"pyproject.toml"),"");if(n.includes("[tool.pytest")||n.includes("pytest")){let a=await Os(s),c=await cn(s);return{stack:"python",test:{tool:"pytest",command:"pytest"},versionFile:a,changelogFile:c}}if(await j(ct.join(s,"Cargo.toml"))){let a=await cn(s);return{stack:"rust",test:{tool:"cargo",command:"cargo test"},versionFile:"Cargo.toml",changelogFile:a}}if(await j(ct.join(s,"go.mod"))){let a=await Os(s),c=await cn(s);return{stack:"go",test:{tool:"go",command:"go test ./..."},versionFile:a,changelogFile:c}}let r=await sn(s);if(r.some(a=>a.endsWith(".sln")||a.endsWith(".csproj")||a.endsWith(".fsproj"))){let a=await Os(s,r),c=await cn(s);return{stack:"dotnet",test:{tool:"dotnet",command:"dotnet test"},versionFile:a,changelogFile:c}}if(await j(ct.join(s,"pom.xml"))){let a=await cn(s);return{stack:"java",test:{tool:"maven",command:"mvn test"},versionFile:"pom.xml",changelogFile:a}}if(await j(ct.join(s,"gradlew"))&&(await j(ct.join(s,"build.gradle"))||await j(ct.join(s,"build.gradle.kts")))){let a=await cn(s);return{stack:"java",test:{tool:"gradle",command:"./gradlew test"},changelogFile:a}}let o=await Os(s),i=await cn(s);return{stack:"unknown",versionFile:o,changelogFile:i}}var Jb,qb,Kb,nl=k(()=>{"use strict";We();l(Vb,"detectPackageManager");l(fm,"pmRun");l(Bb,"pmTest");Jb=["package.json","Cargo.toml","pyproject.toml","VERSION","version.txt"],qb=".csproj",Kb=["CHANGELOG.md","HISTORY.md","NEWS.md","CHANGES.md"];l(Os,"detectVersionFile");l(cn,"detectChangelogFile");l(ci,"detectProjectCommands")});import*as ae from"@clack/prompts";import Kn from"chalk";var li,hm,Fs,ym=k(()=>{"use strict";Bn();li=[{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."}],hm=[{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"}],Fs=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(){ae.intro(Kn.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 ae.outro(Kn.green("Setup complete!")),this.buildResult(!1)}async runNonInteractive(){h.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,h.done("Configuration detected"),this.buildResult(!1)}async stepProjectType(){this.detectedType=await this.detectProjectType();let e=li.findIndex(n=>n.value===this.detectedType),t=await ae.select({message:this.detectedType!=="unknown"?`Detected: ${this.getProjectTypeLabel(this.detectedType)}. Is this correct?`:"What type of project is this?",options:li.map(n=>({label:n.title,hint:n.description,value:n.value})),initialValue:e>=0?li[e].value:void 0});return ae.isCancel(t)?(this.handleCancel(),!1):(this.confirmedType=t||this.detectedType,!0)}async stepAIAgents(){let e=await this.detectInstalledAgents(),t=await ae.multiselect({message:"Which AI agents do you use?",options:hm.map(n=>({label:n.title,hint:n.description,value:n.value})),initialValues:e,required:!0});return ae.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);ae.note(e,"Detected stack");let t=await ae.confirm({message:"Is this stack correct?",initialValue:!0});if(ae.isCancel(t))return this.handleCancel(),!1;if(t)this.confirmedStack=this.detectedStack;else{let n=await ae.group({language:l(()=>ae.text({message:"Primary language:",defaultValue:this.detectedStack.language}),"language"),framework:l(()=>ae.text({message:"Framework (optional):",defaultValue:this.detectedStack.framework||""}),"framework")},{onCancel:l(()=>{this.handleCancel()},"onCancel")});if(this.aborted)return!1;this.confirmedStack={...this.detectedStack,language:n.language||this.detectedStack.language,framework:n.framework||void 0}}return!0}async stepPreferences(){let e=await ae.group({verbosity:l(()=>ae.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(()=>ae.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=[`${Kn.cyan("Project Type:")} ${this.getProjectTypeLabel(this.confirmedType)}`,`${Kn.cyan("AI Agents:")} ${this.selectedAgents.map(n=>this.getAgentLabel(n)).join(", ")}`,`${Kn.cyan("Stack:")} ${this.formatStackDisplay(this.confirmedStack)}`,`${Kn.cyan("Verbosity:")} ${this.preferences.verbosity}`,`${Kn.cyan("Auto-sync:")} ${this.preferences.autoSync?"Yes":"No"}`].join(`
|
|
593
|
+
`);ae.note(e,"Configuration Summary");let t=await ae.confirm({message:"Generate configuration with these settings?",initialValue:!0});return ae.isCancel(t)||!t?(ae.isCancel(t)&&this.handleCancel(),!1):!0}async detectProjectType(){let e=await import("node:fs/promises"),t=await import("node:path");try{let n=await e.readdir(this.projectPath);if(n.includes("turbo.json")||n.includes("lerna.json")||n.includes("nx.json"))return"monorepo";if(n.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 n.includes("pyproject.toml")||n.includes("setup.py")?n.some(o=>["main.py","app.py","server.py"].includes(o))?"api-backend":"library":n.includes("go.mod")?n.includes("main.go")?"cli-tool":"library":n.includes("Cargo.toml")?"cli-tool":"unknown"}catch{return"unknown"}}async detectInstalledAgents(){let e=await import("node:fs/promises"),t=await import("node:path"),n=await import("node:os"),r=[];try{await e.access(t.join(n.homedir(),".claude")),r.push("claude")}catch{}try{await e.access(t.join(this.projectPath,".cursorrules")),r.push("cursor")}catch{}try{await e.access(t.join(this.projectPath,".windsurfrules")),r.push("windsurf")}catch{}try{await e.access(t.join(this.projectPath,".github","copilot-instructions.md")),r.push("copilot")}catch{}try{await e.access(t.join(n.homedir(),".gemini")),r.push("gemini")}catch{}try{let{exec:o}=await import("node:child_process"),{promisify:i}=await import("node:util");await i(o)("which codex"),r.push("codex")}catch{try{await e.access(t.join(n.homedir(),".codex")),r.push("codex")}catch{}}return r.length>0?r:["claude"]}async detectStack(){let e=await import("node:fs/promises"),t=await import("node:path"),n={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};n.language=c.typescript?"TypeScript":"JavaScript",c.next?n.framework="Next.js":c.nuxt?n.framework="Nuxt":c.react?n.framework="React":c.vue?n.framework="Vue":c["@angular/core"]?n.framework="Angular":c.express?n.framework="Express":c.hono?n.framework="Hono":c.fastify?n.framework="Fastify":(c.nestjs||c["@nestjs/core"])&&(n.framework="NestJS"),c.bun||c["@types/bun"]||a.engines?.bun?n.runtime="Bun":n.runtime="Node.js",r.includes("bun.lockb")?n.packageManager="Bun":r.includes("pnpm-lock.yaml")?n.packageManager="pnpm":r.includes("yarn.lock")?n.packageManager="Yarn":r.includes("package-lock.json")&&(n.packageManager="npm"),(c.prisma||c["@prisma/client"])&&n.technologies.push("Prisma"),(c.drizzle||c["drizzle-orm"])&&n.technologies.push("Drizzle"),c.tailwindcss&&n.technologies.push("Tailwind CSS"),c.zod&&n.technologies.push("Zod"),(c.trpc||c["@trpc/server"])&&n.technologies.push("tRPC")}else r.includes("pyproject.toml")||r.includes("requirements.txt")?n.language="Python":r.includes("go.mod")?n.language="Go":r.includes("Cargo.toml")?n.language="Rust":(r.includes("pom.xml")||r.includes("build.gradle"))&&(n.language="Java");return n}catch{return n}}handleCancel(){this.aborted=!0,ae.cancel("Setup cancelled. Run again anytime.")}getProjectTypeLabel(e){return li.find(t=>t.value===e)?.title||"Unknown"}getAgentLabel(e){return hm.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}}});import sl from"node:path";var Xb,Yb,ui,Qb,gt,Xn=k(()=>{"use strict";ve();Rt();We();Xb="outcomes",Yb="outcomes.jsonl",ui=class{static{l(this,"OutcomeRecorder")}getOutcomesDir(e){let t=A.getGlobalProjectPath(e);return sl.join(t,Xb)}getOutcomesPath(e){return sl.join(this.getOutcomesDir(e),Yb)}async record(e,t){let n={...t,id:me()},r=this.getOutcomesPath(e);return await Ot(sl.dirname(r)),await wa(r,JSON.stringify(n)),n}async getAll(e){let t=this.getOutcomesPath(e);if(!await j(t))return[];let n=await ot(t);return n.trim()?n.trim().split(`
|
|
594
|
+
`).filter(r=>r.trim()).map(r=>JSON.parse(r)):[]}async filter(e,t){return(await this.getAll(e)).filter(r=>{if(t.sessionId&&r.sessionId!==t.sessionId||t.command&&r.command!==t.command||t.agent&&r.agentUsed!==t.agent||t.fromDate&&r.startedAt<t.fromDate||t.toDate&&r.completedAt>t.toDate||t.minQuality&&r.qualityScore<t.minQuality)return!1;if(t.tags&&t.tags.length>0){let o=r.tags||[];if(!t.tags.some(i=>o.includes(i)))return!1}return!0})}async getRecent(e,t=10){return(await this.getAll(e)).slice(-t)}async getByCommand(e,t){return this.filter(e,{command:t})}async getByAgent(e,t){return this.filter(e,{agent:t})}async getEstimateAccuracy(e){let t=await this.getAll(e);if(t.length===0)return 0;let n=t.filter(r=>{if(!r.variance)return!1;let o=this.parseVariance(r.variance),i=this.parseDuration(r.estimatedDuration);return i===0?!1:Math.abs(o)/i<=.2});return Math.round(n.length/t.length*100)}parseVariance(e){let t=e.match(/^([+-])(\d+)([mh])$/);if(!t)return 0;let n=t[1]==="-"?-1:1,r=parseInt(t[2],10),o=t[3];return n*(o==="h"?r*60:r)}parseDuration(e){let t=0,n=e.match(/(\d+)h/);n&&(t+=parseInt(n[1],10)*60);let r=e.match(/(\d+)m/);return r&&(t+=parseInt(r[1],10)),t}},Qb=new ui,gt=Qb});var di,Zb,rl,wm=k(()=>{"use strict";Xn();di=class{static{l(this,"OutcomeAnalyzer")}async summarize(e){let t=await gt.getAll(e);if(t.length===0)return{totalOutcomes:0,avgQualityScore:0,estimateAccuracy:0,topBlockers:[],topAgents:[],patternsDetected:[]};let n=t.reduce((m,p)=>m+p.qualityScore,0)/t.length,r=await gt.getEstimateAccuracy(e),o=new Map;for(let m of t)for(let p of m.blockers||[])o.set(p,(o.get(p)||0)+1);let i=[...o.entries()].sort((m,p)=>p[1]-m[1]).slice(0,5).map(([m])=>m),c=(await this.getAgentMetrics(e)).sort((m,p)=>p.successRate-m.successRate).slice(0,3).map(m=>m.agent),d=(await this.detectPatterns(e)).map(m=>m.description);return{totalOutcomes:t.length,avgQualityScore:Math.round(n*10)/10,estimateAccuracy:r,topBlockers:i,topAgents:c,patternsDetected:d}}async getAgentMetrics(e){let t=await gt.getAll(e),n=new Map;for(let o of t){let i=o.agentUsed||"unknown";n.has(i)||n.set(i,[]),n.get(i).push(o)}let r=[];for(let[o,i]of n){let a=i.length,c=i.filter(S=>S.completedAsPlanned),u=Math.round(c.length/a*100),d=i.reduce((S,w)=>S+w.qualityScore,0)/a,m=i.filter(S=>{if(!S.variance)return!1;let w=this.parseVariance(S.variance),v=this.parseDuration(S.estimatedDuration);return v===0?!1:Math.abs(w)/v<=.2}),p=Math.round(m.length/a*100),g=new Map;for(let S of i.filter(w=>w.completedAsPlanned))for(let w of S.tags||[])g.set(w,(g.get(w)||0)+1);let f=[...g.entries()].sort((S,w)=>w[1]-S[1]).slice(0,3).map(([S])=>S);r.push({agent:o,tasksCompleted:a,successRate:u,avgQualityScore:Math.round(d*10)/10,estimateAccuracy:p,bestFor:f})}return r}async detectPatterns(e){let t=await gt.getAll(e),n=[];if(t.length<3)return n;let r=t.filter(c=>this.parseVariance(c.variance)>0);r.length/t.length>.6&&n.push({description:"Tasks consistently take longer than estimated",confidence:r.length/t.length,occurrences:r.length,suggestedAction:"Add 30% buffer to estimates"});let o=t.filter(c=>this.parseVariance(c.variance)<0);o.length/t.length>.6&&n.push({description:"Tasks consistently finish faster than estimated",confidence:o.length/t.length,occurrences:o.length,suggestedAction:"Reduce estimates by 20%"});let i=new Map;for(let c of t)for(let u of c.blockers||[])i.set(u,(i.get(u)||0)+1);for(let[c,u]of i)u>=3&&n.push({description:`Recurring blocker: ${c}`,confidence:u/t.length,occurrences:u,suggestedAction:`Address root cause of "${c}"`});let a=await this.getAgentMetrics(e);for(let c of a)c.tasksCompleted>=5&&c.successRate>90&&n.push({description:`${c.agent} has high success rate (${c.successRate}%)`,confidence:.9,occurrences:c.tasksCompleted,suggestedAction:`Prefer ${c.agent} for similar tasks`});return n.sort((c,u)=>u.confidence-c.confidence)}async suggestEstimate(e,t){let r=(await gt.getAll(e)).filter(a=>a.tags?.includes(t));if(r.length<2)return null;let o=r.reduce((a,c)=>a+this.parseDuration(c.actualDuration),0),i=Math.round(o/r.length);if(i>=60){let a=Math.floor(i/60),c=i%60;return c>0?`${a}h ${c}m`:`${a}h`}return`${i}m`}async suggestAgent(e,t){let r=(await this.getAgentMetrics(e)).filter(o=>o.bestFor.includes(t));return r.length===0?null:r.sort((o,i)=>i.successRate-o.successRate)[0].agent}parseVariance(e){let t=e.match(/^([+-])(\d+)([mh])$/);if(!t)return 0;let n=t[1]==="-"?-1:1,r=parseInt(t[2],10),o=t[3];return n*(o==="h"?r*60:r)}parseDuration(e){let t=0,n=e.match(/(\d+)h/);n&&(t+=parseInt(n[1],10)*60);let r=e.match(/(\d+)m/);return r&&(t+=parseInt(r[1],10)),t}},Zb=new di,rl=Zb});var Nr,pi,ol,il=k(()=>{"use strict";ms();ce();Nr=3,pi=class{static{l(this,"OutcomeMemoryLearner")}async learnFromTaskHistory(e,t,n){let r={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return r;let o=[...this.extractFileCochangePatterns(t),...this.extractStackPatterns(t),...this.extractArchitecturePatterns(t),...this.extractGotchaPatterns(t)];r.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Nr){r.patternsQualified++;let a=await this.injectIntoMemory(e,i,n);a&&(r.memoriesInjected++,r.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else r.patternsSkipped++,r.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Nr} occurrences needed`});return r}async learnFromOutcomes(e,t,n){let r={patternsExtracted:0,patternsQualified:0,memoriesInjected:0,patternsSkipped:0,details:[]};if(t.length===0)return r;let o=this.extractOutcomePatterns(t);r.patternsExtracted=o.length;for(let i of o)if(i.occurrences>=Nr){r.patternsQualified++;let a=await this.injectIntoMemory(e,i,n);a&&(r.memoriesInjected++,r.details.push({pattern:i.pattern,action:a.action,confidence:i.confidence}))}else r.patternsSkipped++,r.details.push({pattern:i.pattern,action:"skipped",confidence:i.confidence,reason:`${i.occurrences}/${Nr} occurrences needed`});return r}extractFileCochangePatterns(e){let t=new Map;for(let r of e){if(!r.subtaskSummaries)continue;let o=new Set;for(let a of r.subtaskSummaries)if(a.filesChanged)for(let c of a.filesChanged)o.add(c.path);let i=Array.from(o).sort();for(let a=0;a<i.length;a++)for(let c=a+1;c<i.length;c++){let u=`${i[a]}|${i[c]}`,d=t.get(u)||{count:0,tasks:[]};d.count++,d.tasks.push(r.taskId),t.set(u,d)}}let n=[];for(let[r,{count:o,tasks:i}]of t)if(o>=2){let[a,c]=r.split("|");n.push({pattern:`Files "${a}" and "${c}" frequently change together (${o} tasks)`,occurrences:o,confidence:this.calculateConfidence(o),category:"file_cochange",sourceTasks:i})}return n.sort((r,o)=>o.occurrences-r.occurrences)}extractStackPatterns(e){let t=new Map;for(let n of e)if(n.feedback?.stackConfirmed)for(let r of n.feedback.stackConfirmed){let o=t.get(r)||{count:0,tasks:[]};o.count++,o.tasks.push(n.taskId),t.set(r,o)}return Array.from(t.entries()).map(([n,{count:r,tasks:o}])=>({pattern:`Project uses ${n}`,occurrences:r,confidence:this.calculateConfidence(r),category:"tech_stack",sourceTasks:o}))}extractArchitecturePatterns(e){let t=new Map;for(let n of e)if(n.feedback?.patternsDiscovered)for(let r of n.feedback.patternsDiscovered){let o=t.get(r)||{count:0,tasks:[]};o.count++,o.tasks.push(n.taskId),t.set(r,o)}return Array.from(t.entries()).map(([n,{count:r,tasks:o}])=>({pattern:n,occurrences:r,confidence:this.calculateConfidence(r),category:"architecture",sourceTasks:o}))}extractGotchaPatterns(e){let t=new Map;for(let n of e)if(n.feedback?.issuesEncountered)for(let r of n.feedback.issuesEncountered){let o=t.get(r)||{count:0,tasks:[]};o.count++,o.tasks.push(n.taskId),t.set(r,o)}return Array.from(t.entries()).filter(([n,{count:r}])=>r>=2).map(([n,{count:r,tasks:o}])=>({pattern:`Known gotcha: ${n}`,occurrences:r,confidence:this.calculateConfidence(r),category:"gotcha",sourceTasks:o}))}extractOutcomePatterns(e){let t=[],n=new Map,r=new Map;for(let i of e){for(let a of i.learnings.whatWorked){let c=n.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),n.set(a,c)}for(let a of i.learnings.whatDidnt){let c=r.get(a)||{count:0,ids:[]};c.count++,c.ids.push(i.id),r.set(a,c)}}for(let[i,{count:a,ids:c}]of n)t.push({pattern:`What works: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"workflow",sourceTasks:c});for(let[i,{count:a,ids:c}]of r)t.push({pattern:`Known issue: ${i}`,occurrences:a,confidence:this.calculateConfidence(a),category:"gotcha",sourceTasks:c});let o=e.filter(i=>i.effort.variance.percentage>30);return o.length>=Nr&&t.push({pattern:`Tasks are frequently underestimated (${o.length}/${e.length} over 30% variance)`,occurrences:o.length,confidence:this.calculateConfidence(o.length),category:"estimation",sourceTasks:o.map(i=>i.id)}),t}getAllPatterns(e,t=[]){return[...this.extractFileCochangePatterns(e),...this.extractStackPatterns(e),...this.extractArchitecturePatterns(e),...this.extractGotchaPatterns(e),...this.extractOutcomePatterns(t)].sort((n,r)=>r.occurrences-n.occurrences)}async injectIntoMemory(e,t,n){let r=this.getTagsForCategory(t.category),o=`[auto-learned] ${this.getTitleForPattern(t)}`,i=this.formatPatternContent(t),c=(await n.searchMemories(e,t.pattern)).find(u=>u.title.startsWith("[auto-learned]")&&u.content.includes(t.pattern));return c?(await n.updateMemory(e,c.id,{content:i,tags:r}),{action:"updated"}):(await n.createMemory(e,{title:o,content:i,tags:r,userTriggered:!1}),{action:"created"})}calculateConfidence(e){return e>=5?"high":e>=3?"medium":"low"}getTagsForCategory(e){return{file_cochange:[O.FILE_STRUCTURE,O.ARCHITECTURE],tech_stack:[O.TECH_STACK],architecture:[O.ARCHITECTURE,O.CODE_STYLE],estimation:[O.SHIP_WORKFLOW],workflow:[O.SHIP_WORKFLOW,O.CODE_STYLE],gotcha:[O.TEST_BEHAVIOR,O.ARCHITECTURE]}[e]||[]}getTitleForPattern(e){return`${{file_cochange:"File coupling",tech_stack:"Tech stack",architecture:"Architecture pattern",estimation:"Estimation insight",workflow:"Workflow pattern",gotcha:"Known gotcha"}[e.category]}: ${e.pattern.slice(0,80)}`}formatPatternContent(e){let t=["source: auto-learned",`pattern: ${e.pattern}`,`occurrences: ${e.occurrences}`,`confidence: ${e.confidence}`,`category: ${e.category}`,`last_updated: ${b()}`];return e.sourceTasks.length>0&&t.push(`source_tasks: ${e.sourceTasks.slice(0,5).join(", ")}`),t.join(`
|
|
595
|
+
`)}},ol=new pi});var mi,Sm,al=k(()=>{"use strict";Fa();Xt();ce();mi=class extends Be{static{l(this,"OutcomeStorage")}constructor(){super("outcomes.json")}getDefault(){return{...Ud,lastUpdated:""}}getEventType(e){return`outcomes.${e}d`}async addFeatureOutcome(e,t){await this.update(e,n=>({...n,outcomes:[t,...n.outcomes],aggregates:wo([t,...n.outcomes]),lastUpdated:b()})),await this.publishEvent(e,"outcome.recorded",{outcomeId:t.id,featureName:t.featureName,success:t.success?.overallSuccess})}async addTaskOutcome(e,t){await this.update(e,n=>({...n,taskOutcomes:[t,...n.taskOutcomes||[]],lastUpdated:b()}))}async getFeatureOutcomes(e){return(await this.read(e)).outcomes}async getRecentOutcomes(e,t=10){return(await this.read(e)).outcomes.sort((r,o)=>new Date(o.shippedAt).getTime()-new Date(r.shippedAt).getTime()).slice(0,t)}async getTaskOutcomes(e,t){let n=await this.read(e),r=n.taskOutcomes||[];return t?n.outcomes.find(i=>i.featureId===t)?.taskOutcomes||[]:r}async getAggregates(e){let t=await this.read(e);return!t.aggregates&&t.outcomes.length>0?wo(t.outcomes):t.aggregates}async reaggregate(e){await this.update(e,t=>({...t,aggregates:wo(t.outcomes),lastAggregated:b(),lastUpdated:b()}))}migrateFromShipped(e){return e.shipped.map(t=>this.convertShippedToOutcome(t))}convertShippedToOutcome(e){let t=e.duration?this.parseDurationString(e.duration):60,n=t/60,r=t/60,o=Hd(n,r),i={whatWorked:[],whatDidnt:[],surprises:[],recommendations:[]},a=100,c=Gd(5,r);return{id:`out_feat_${e.id}`,featureId:e.featureId||e.id,featureName:e.name,prdId:null,version:e.version||void 0,branch:e.commit?.branch||void 0,prUrl:void 0,effort:{estimated:{hours:n,confidence:"low",source:"manual"},actual:{hours:r,commits:e.codeMetrics?.commits||void 0,linesAdded:e.codeMetrics?.linesAdded||void 0,linesRemoved:e.codeMetrics?.linesRemoved||void 0},variance:o},success:{metrics:[],acceptanceCriteria:[],overallSuccess:Wd(a),successScore:a},learnings:i,roi:{valueDelivered:5,userImpact:"medium",businessImpact:"medium",roiScore:c,worthIt:"probably"},rating:3,startedAt:e.shippedAt,shippedAt:e.shippedAt,legacy:!0}}parseDurationString(e){let t=0,n=e.match(/(\d+)h/);n&&(t+=parseInt(n[1],10)*60);let r=e.match(/(\d+)m/);return r&&(t+=parseInt(r[1],10)),t||60}},Sm=new mi});var cl=k(()=>{"use strict";ym();wm();il();Xn();al()});import Qt from"chalk";function ev(s){return km[s.toLowerCase()]||km.default}var km,ll,gi,bm=k(()=>{"use strict";km={database:"\u{1F4BE}",backend:"\u{1F527}",frontend:"\u{1F4E6}",testing:"\u{1F9EA}",devops:"\u{1F680}",uxui:"\u{1F3A8}",security:"\u{1F512}",docs:"\u{1F4DD}",api:"\u{1F310}",default:"\u26A1"};l(ev,"getIcon");ll=class{static{l(this,"AgentStream")}currentAgent=null;startTime=0;quiet=!1;setQuiet(e){this.quiet=e}orchestrate(e){this.quiet||console.log(Qt.cyan(`
|
|
596
596
|
\u{1F3AF} Orchestrating: ${e.join(", ")} domains detected
|
|
597
|
-
`))}startAgent(e,t,n){if(this.quiet)return;this.currentAgent=e,this.startTime=Date.now();let
|
|
598
|
-
`),this.currentAgent=null}status(e,t){this.quiet||console.log(`${e} ${t}`)}complete(e,t){if(this.quiet)return;let n=t?` ${
|
|
599
|
-
`)}function
|
|
600
|
-
`)}var
|
|
601
|
-
`;return
|
|
602
|
-
`}),
|
|
597
|
+
`))}startAgent(e,t,n){if(this.quiet)return;this.currentAgent=e,this.startTime=Date.now();let r=ev(t);console.log(Qt.cyan(`\u250C\u2500 ${r} ${e} (${t})`)),n&&console.log(Qt.dim(`\u2502 ${n}`))}progress(e){this.quiet||!this.currentAgent||console.log(Qt.dim(`\u2502 \u2514\u2500\u2500 ${e}`))}progressList(e){if(!(this.quiet||!this.currentAgent))for(let t of e)console.log(Qt.dim(`\u2502 \u2514\u2500\u2500 ${t}`))}endAgent(e=!0){if(this.quiet||!this.currentAgent)return;let t=Date.now()-this.startTime,n=this.formatDuration(t),r=e?Qt.green("\u2713"):Qt.red("\u2717");console.log(`\u2514\u2500 ${r} ${e?"Complete":"Failed"} ${Qt.dim(`(${n})`)}
|
|
598
|
+
`),this.currentAgent=null}status(e,t){this.quiet||console.log(`${e} ${t}`)}complete(e,t){if(this.quiet)return;let n=t?` ${Qt.dim(`[${this.formatDuration(t)}]`)}`:"";console.log(Qt.green(`\u2705 ${e}${n}`))}formatDuration(e){return e<1e3?`${e}ms`:`${(e/1e3).toFixed(1)}s`}},gi=new ll});import st from"chalk";function tv(s){let e=0;for(let n of s)e=(e<<5)-e+n.charCodeAt(0),e=e&e;let t=Math.abs(e)%vm.length;return vm[t]}function nv(s,e,t="\u25B6"){let n=st.dim(String(s+1).padStart(2)),o=tv(e.domain)(e.domain.padEnd(10)),i=e.description.length>32?`${e.description.slice(0,29)}...`:e.description.padEnd(32),a;switch(e.status){case"completed":a=st.green("\u2713 Complete");break;case"in_progress":a=st.yellow(`${t} Working...`);break;case"pending":a=st.gray("\u25CB Pending");break;case"failed":a=st.red("\u2717 Failed");break;case"blocked":a=st.gray("\u2298 Blocked");break;default:a=st.gray(`\u25CB ${e.status}`)}return` ${n} ${o} ${i} ${a}`}function sv(s){if(s.length===0)return"";let e=[];e.push(""),e.push(` ${st.bold.white("SUBTASK PROGRESS")}`),e.push(` ${st.dim("\u2500".repeat(58))}`);for(let t=0;t<s.length;t++)e.push(nv(t,s[t]));return e.push(""),e.join(`
|
|
599
|
+
`)}function Pm(s){console.log(sv(s))}var vm,Cm=k(()=>{"use strict";vm=[st.cyan,st.magenta,st.yellow,st.blue,st.green,st.redBright,st.magentaBright,st.cyanBright];l(tv,"getDomainColor");l(nv,"formatSubtaskLine");l(sv,"renderSubtaskProgress");l(Pm,"printSubtaskProgress")});function rv(s){return xm.includes(s)}async function ov(s,e,t){let n=[],r=[],o=[];switch(s){case"ship":t.now&&!t.now.includes("No current task")?n.push({step:"Has active task",passed:!0}):(n.push({step:"Has active task",passed:!1,details:"No active task to ship"}),o.push("No active task")),t.shipped?n.push({step:"Shipped log accessible",passed:!0}):n.push({step:"Shipped log accessible",passed:!1,details:"shipped.md not found"}),r.push("Read current task from now.md"),r.push("Calculate duration"),r.push("Append to shipped.md"),r.push("Clear now.md"),r.push("Update metrics");break;case"feature":e.params.description||e.params.feature?n.push({step:"Has feature description",passed:!0}):(n.push({step:"Has feature description",passed:!1,details:"No description provided"}),o.push("Missing feature description")),t.analysis?n.push({step:"Project analyzed",passed:!0}):n.push({step:"Project analyzed",passed:!1,details:"Run /p:sync first"}),r.push("Parse feature description"),r.push("Generate tasks breakdown"),r.push("Add to roadmap.md"),r.push("Add tasks to next.md"),r.push("Suggest starting first task");break;case"spec":e.params.feature||e.params.name?n.push({step:"Has spec name",passed:!0}):(n.push({step:"Has spec name",passed:!1,details:"No spec name provided"}),o.push("Missing spec name")),r.push("Generate spec template"),r.push("Analyze requirements"),r.push("Create spec file"),r.push("Link to roadmap");break;case"cleanup":t.analysis?n.push({step:"Has code analysis",passed:!0}):n.push({step:"Has code analysis",passed:!1,details:"Run /p:analyze first"}),r.push("Scan for unused code"),r.push("Identify dead imports"),r.push("List files to clean"),r.push("Show preview"),r.push("Wait for approval"),r.push("Execute cleanup");break;case"migrate":n.push({step:"Migration safety check",passed:!0,details:"Will require manual approval"}),r.push("Analyze current state"),r.push("Generate migration plan"),r.push("Show affected files"),r.push("Request approval"),r.push("Execute migration"),r.push("Verify results");break;default:r.push("Execute command");break}let i=n.filter(u=>u.passed).length,a=n.length,c=a>0?i/a:1;return{commandName:s,reasoning:n.length>0?{steps:n,allPassed:o.length===0,criticalIssues:o}:null,plan:r,confidence:c}}function iv(s){let e=[];return e.push(`\u{1F4CB} Chain of Thought: ${s.commandName}`),e.push(""),s.reasoning&&(e.push("Steps:"),s.reasoning.steps.forEach(t=>{let n=t.passed?"\u2705":"\u274C";e.push(` ${n} ${t.step}`),t.details&&e.push(` ${t.details}`)}),e.push(""),s.reasoning.criticalIssues.length>0&&(e.push("Critical Issues:"),s.reasoning.criticalIssues.forEach(t=>{e.push(` \u26A0\uFE0F ${t}`)}),e.push(""))),s.plan.length>0&&(e.push("Plan:"),s.plan.forEach((t,n)=>{e.push(` ${n+1}. ${t}`)}),e.push("")),e.push(`Confidence: ${Math.round(s.confidence*100)}%`),e.join(`
|
|
600
|
+
`)}var xm,av,fi,Tm=k(()=>{"use strict";xm=["ship","feature","spec","cleanup","migrate"];l(rv,"requiresReasoning");l(ov,"reason");l(iv,"formatPlan");av={requiresReasoning:rv,reason:ov,formatPlan:iv,REASONING_REQUIRED_COMMANDS:xm},fi=av});import Lr from"node:fs/promises";var ul,cv,kt,dl=k(()=>{"use strict";Pt();ve();L();Mc();ul=class{static{l(this,"ContextBuilder")}_cache;_currentProjectId;constructor(){this._cache=new js({ttl:5e3,maxSize:200}),this._currentProjectId=null}async build(e,t={}){let n=await M.getProjectId(e),r=A.getGlobalProjectPath(n);return this._currentProjectId!==null&&this._currentProjectId!==n&&this._cache.clear(),this._currentProjectId=n,{projectId:n,projectPath:e,globalPath:r,paths:{now:A.getFilePath(n,"core","now.md"),next:A.getFilePath(n,"core","next.md"),context:A.getFilePath(n,"core","context.md"),shipped:A.getFilePath(n,"progress","shipped.md"),metrics:A.getFilePath(n,"progress","metrics.md"),ideas:A.getFilePath(n,"planning","ideas.md"),roadmap:A.getFilePath(n,"planning","roadmap.md"),specs:A.getFilePath(n,"planning","specs"),memory:A.getFilePath(n,"memory","context.jsonl"),patterns:A.getFilePath(n,"memory","patterns.json"),analysis:A.getFilePath(n,"analysis","repo-summary.md"),codePatterns:A.getFilePath(n,"analysis","patterns.md")},params:t,timestamp:new Date().toISOString(),date:new Date().toISOString().split("T")[0]}}async loadState(e,t=null){let n={},r=Object.entries(e.paths),o=t?r.filter(([a])=>t.includes(a)):r;for(let[,a]of o){let c=this._cache.get(a);if(c!==null)try{let u=await Lr.stat(a);(!c.mtime||u.mtimeMs>c.mtime)&&this._cache.delete(a)}catch(u){if(C(u))this._cache.delete(a);else throw u}}let i=[];for(let[a,c]of o){let u=this._cache.get(c);u!==null?n[a]=u.content:i.push([a,c])}if(i.length>0){let a=i.map(async([u,d])=>{try{let[m,p]=await Promise.all([Lr.readFile(d,"utf-8"),Lr.stat(d)]);return{key:u,filePath:d,content:m,mtime:p.mtimeMs}}catch(m){if(C(m))return{key:u,filePath:d,content:null,mtime:null};throw m}}),c=await Promise.all(a);for(let{key:u,filePath:d,content:m,mtime:p}of c)n[u]=m,this._cache.set(d,{content:m,mtime:p})}return n}async loadStateForCommand(e,t){let n={now:["now","next","analysis","codePatterns"],done:["now","next","metrics","analysis"],next:["next","analysis"],ship:["now","shipped","metrics","analysis"],recap:["shipped","metrics","now","analysis"],progress:["shipped","metrics","analysis"],idea:["ideas","next","analysis"],feature:["roadmap","next","ideas","analysis","codePatterns"],roadmap:["roadmap","analysis"],spec:["roadmap","next","specs","analysis","codePatterns"],analyze:["analysis","context","codePatterns"],sync:["analysis","context","now","codePatterns"],work:["now","next","analysis","context","codePatterns"],build:["now","next","analysis","context","codePatterns"],design:["analysis","context","codePatterns"],cleanup:["analysis","context","codePatterns"],fix:["analysis","context","codePatterns"],test:["analysis","context","codePatterns"],default:["analysis","codePatterns"]},r=n[t]||n.default;return this.loadState(e,r)}async batchRead(e){let t=new Map,n=[];for(let r of e){let o=this._cache.get(r);o!==null?t.set(r,o.content):n.push(r)}if(n.length>0){let r=n.map(async i=>{try{let a=await Lr.readFile(i,"utf-8");return{filePath:i,content:a}}catch(a){if(C(a))return{filePath:i,content:null};throw a}}),o=await Promise.all(r);for(let{filePath:i,content:a}of o)t.set(i,a),this._cache.set(i,{content:a,mtime:null})}return t}invalidateCache(e){this._cache.delete(e)}clearCache(){this._cache.clear(),this._currentProjectId=null}async fileExists(e){try{return await Lr.access(e),!0}catch(t){if(C(t))return!1;throw t}}getCacheStats(){return this._cache.stats()}},cv=new ul,kt=cv});import{exec as lv}from"node:child_process";import $e from"node:fs/promises";import Em from"node:os";import Rn from"node:path";import{promisify as uv}from"node:util";function Am(s){let e=Math.floor(s/36e5),t=Math.floor(s%(1e3*60*60)/(1e3*60));return e>0?`${e}h ${t}m`:`${t}m`}function pl(s){return s.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function pv(s){if(s.verified||s.warnings.length===0)return null;let e=` Ground Truth Warnings:
|
|
601
|
+
`;return s.warnings.forEach(t=>{e+=` - ${t}
|
|
602
|
+
`}),s.recommendations.length>0&&(e+=`
|
|
603
603
|
Recommendations:
|
|
604
|
-
`,
|
|
605
|
-
`})),e}async function
|
|
606
|
-
`).filter(Boolean).length,n.hasUncommittedChanges&&(e.push(`${n.uncommittedFiles} uncommitted file(s)`),t.push("Commit changes before shipping"))}catch{n.gitAvailable=!1}let s=$n.join(r.projectPath,"package.json");try{let i=await $e.readFile(s,"utf-8"),a=JSON.parse(i);n.currentVersion=a.version,n.hasPackageJson=!0}catch(i){if(P(i))n.hasPackageJson=!1;else if(i instanceof SyntaxError)n.hasPackageJson=!1,e.push("package.json has invalid JSON");else throw i}let o=r.paths.shipped;try{let i=await $e.readFile(o,"utf-8");n.shippedExists=!0;let a=r.params.feature||r.params.description;if(a){let c=new Date().toISOString().split("T")[0];new RegExp(`${c}.*${Pl(a)}`,"i").test(i)&&(e.push(`Feature "${a}" already shipped today`),t.push("Use a different feature name or skip /p:ship"))}}catch(i){if(P(i))n.shippedExists=!1;else throw i}if(n.hasPackageJson)try{let i=await $e.readFile(s,"utf-8"),a=JSON.parse(i);n.hasTestScript=!!a.scripts?.test}catch(i){if(P(i)||i instanceof SyntaxError)n.hasTestScript=!1;else throw i}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Gm(r){let e=[],t=[],n={},s=r.paths.next;try{let a=await $e.readFile(s,"utf-8");n.nextExists=!0;let c=a.match(/- \[[ x]\]/g)||[];n.taskCount=c.length,n.pendingTasks=(a.match(/- \[ \]/g)||[]).length,n.taskCount>=90&&(e.push(`Queue nearly full (${n.taskCount}/100 tasks)`),t.push("Complete some tasks before adding more"))}catch(a){if(P(a))n.nextExists=!1,n.taskCount=0;else throw a}let o=r.paths.roadmap;try{let a=await $e.readFile(o,"utf-8");n.roadmapExists=!0;let c=r.params.description||r.params.feature;c&&new RegExp(Pl(c),"i").test(a)&&(e.push(`Feature "${c}" may already exist in roadmap`),t.push("Check roadmap for duplicates with /p:roadmap"))}catch(a){if(P(a))n.roadmapExists=!1;else throw a}let i=r.paths.now;try{let a=await $e.readFile(i,"utf-8");n.hasActiveTask=a.trim().length>0&&!a.includes("No current task"),n.hasActiveTask&&t.push("Consider completing current task first with /p:done")}catch(a){if(P(a))n.hasActiveTask=!1;else throw a}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function zm(r){let e=[],t=[],n={},s=r.paths.now;try{let i=await $e.readFile(s,"utf-8");n.nowExists=!0,n.nowContent=i.trim();let a=i.trim().length>0&&!i.includes("No current task")&&!i.match(/^#\s*NOW\s*$/m);if(n.hasActiveTask=a,a&&r.params.task){let c=i.substring(0,50).replace(/\n/g," ");e.push(`Replacing existing task: "${c}..."`),t.push("Use /p:done first to track completion")}}catch(i){if(P(i))n.nowExists=!1,n.hasActiveTask=!1;else throw i}let o=r.paths.next;try{let a=((await $e.readFile(o,"utf-8")).match(/- \[ \]/g)||[]).length;n.pendingTasks=a,!r.params.task&&a>0&&t.push(`${a} tasks available in queue`)}catch(i){if(P(i))n.pendingTasks=0;else throw i}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Wm(r){let e=[],t=[],n={},s=$n.join(r.projectPath,".prjct/prjct.config.json");try{let i=await $e.readFile(s,"utf-8");n.alreadyInitialized=!0,n.existingConfig=JSON.parse(i),e.push("Project already initialized"),t.push("Use /p:analyze to refresh analysis or delete .prjct/ to reinitialize")}catch(i){if(P(i))n.alreadyInitialized=!1;else if(i instanceof SyntaxError)n.alreadyInitialized=!1,e.push("Existing config has invalid JSON");else throw i}let o=$n.join(Nm.homedir(),".prjct-cli");try{await $e.access(o,$e.constants.W_OK),n.globalPathWritable=!0}catch(i){if(P(i))try{await $e.mkdir(o,{recursive:!0}),n.globalPathWritable=!0,n.globalPathCreated=!0}catch{n.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}else n.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Vm(r){let e=[],t=[],n={},s=$n.join(r.projectPath,".prjct/prjct.config.json");try{let a=await $e.readFile(s,"utf-8");n.hasConfig=!0,n.config=JSON.parse(a)}catch(a){if(P(a))return n.hasConfig=!1,e.push("Project not initialized"),t.push("Run /p:init first"),{verified:!1,actual:n,warnings:e,recommendations:t};if(a instanceof SyntaxError)return n.hasConfig=!1,e.push("Config file has invalid JSON"),t.push("Delete .prjct/ and run /p:init"),{verified:!1,actual:n,warnings:e,recommendations:t};throw a}let o=n.config?.projectId,i=$n.join(Nm.homedir(),".prjct-cli/projects",o||"");try{await $e.access(i),n.globalStorageExists=!0}catch(a){if(P(a))n.globalStorageExists=!1,e.push("Global storage missing"),t.push("Run /p:init to recreate");else throw a}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Bm(r){let e=[],t=[],n={},s=["package.json","Cargo.toml","go.mod","requirements.txt","Gemfile","pom.xml"];n.detectedFiles=[];for(let i of s)try{await $e.access($n.join(r.projectPath,i)),n.detectedFiles.push(i)}catch(a){if(!P(a))throw a}n.detectedFiles.length===0&&(e.push("No recognizable project files detected"),t.push("Analysis may be limited without package.json or similar"));let o=["src","lib","app","core","components"];n.detectedSrcDirs=[];for(let i of o)try{(await $e.stat($n.join(r.projectPath,i))).isDirectory()&&n.detectedSrcDirs.push(i)}catch(a){if(!P(a))throw a}return{verified:!0,actual:n,warnings:e,recommendations:t}}async function Jm(r){let e=[],t=[],n={},s=r.paths.specs;try{await $e.access(s),n.specsExists=!0;let i=await $e.readdir(s);n.existingSpecs=i.filter(a=>a.endsWith(".md")),n.specCount=n.existingSpecs.length}catch(i){if(P(i))n.specsExists=!1,n.specCount=0;else throw i}let o=r.params.feature||r.params.name||r.params.description;if(o&&n.existingSpecs){let i=o.toLowerCase().replace(/\s+/g,"-");n.existingSpecs.includes(`${i}.md`)&&(e.push(`Spec "${o}" already exists`),t.push("Use a different name or edit existing spec"))}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Km(r,e,t){let n=qm[r];if(!n)return{verified:!0,actual:{},warnings:[],recommendations:[]};try{return await n(e,t)}catch(s){return{verified:!1,actual:{},warnings:[`Verification error: ${w(s)}`],recommendations:["Check file permissions and project configuration"]}}}async function xv(r,e,t){let n=await Km(r,e,t);return{...e,groundTruth:{...n,verifiedAt:new Date().toISOString(),command:r}}}function Tv(r){return["done","ship","feature","spec","now","init","sync","analyze"].includes(r)}var Pv,qm,Ev,ki,Xm=k(()=>{"use strict";F();Pv=vv(bv);l(Lm,"formatDuration");l(Pl,"escapeRegex");l(Cv,"formatWarnings");l(Um,"verifyDone");l(Hm,"verifyShip");l(Gm,"verifyFeature");l(zm,"verifyNow");l(Wm,"verifyInit");l(Vm,"verifySync");l(Bm,"verifyAnalyze");l(Jm,"verifySpec");qm={done:Um,ship:Hm,feature:Gm,now:zm,init:Wm,sync:Vm,analyze:Bm,spec:Jm};l(Km,"verify");l(xv,"prepareCommand");l(Tv,"requiresVerification");Ev={verify:Km,prepareCommand:xv,requiresVerification:Tv,verifiers:qm,formatWarnings:Cv,formatDuration:Lm,escapeRegex:Pl,verifyDone:Um,verifyShip:Hm,verifyFeature:Gm,verifyNow:zm,verifyInit:Wm,verifySync:Vm,verifyAnalyze:Bm,verifySpec:Jm},ki=Ev});function Iv(r){return{contradiction:"Verify file/resource state before reporting. Use Read tool to check actual state.",state:"Check current task state from now.md before assuming completion.",invented:"Verify prerequisites exist (package.json, git remote) before claiming actions."}[r]||"Verify actual state before proceeding."}function Rv(r){if(!r||typeof r!="string")return{detected:!1};for(let{pattern:e,type:t,description:n}of Av)if(e.test(r))return{detected:!0,type:t,pattern:e.source,description:n,message:`Potential hallucination detected: ${n}`,suggestion:Iv(t)};return{detected:!1}}function Dv(r,e){if(!r||!e)return!1;let t=l(n=>n.toLowerCase().replace(/[0-9]+/g,"N").replace(/['"`]/g,"").replace(/\s+/g," ").trim(),"normalize");return t(r)===t(e)}function jv(r){if(!r||r.length===0)return{type:"unknown",description:"No error information"};let e=r[r.length-1]?.message?.toLowerCase()||"";return e.includes("permission")||e.includes("access denied")?{type:"permission",description:"File or directory permission issue"}:e.includes("not found")||e.includes("no such file")?{type:"not_found",description:"File or resource not found"}:e.includes("syntax")||e.includes("parse")?{type:"syntax",description:"Syntax or parsing error"}:e.includes("timeout")||e.includes("timed out")?{type:"timeout",description:"Operation timed out"}:e.includes("network")||e.includes("connection")?{type:"network",description:"Network or connection issue"}:e.includes("config")||e.includes("configuration")?{type:"config",description:"Configuration issue"}:e.includes("validation")||e.includes("invalid")?{type:"validation",description:"Validation failed"}:{type:"unknown",description:"Unrecognized error pattern"}}function $v(r,e,t){let n={permission:`I've tried ${r} ${t} times but keep hitting permission issues.`,not_found:`After ${t} attempts, I still can't find the required file or resource.`,syntax:`I'm encountering repeated syntax errors with ${r}.`,timeout:`The operation keeps timing out after ${t} attempts.`,network:`Network issues are preventing ${r} from completing.`,validation:`Validation keeps failing for ${r}.`,config:`There seems to be a configuration issue affecting ${r}.`,unknown:`I've tried ${r} ${t} times without success.`};return n[e.type]||n.unknown}function Mv(r){let e={permission:"Check file permissions. Try: chmod -R u+w ~/.prjct-cli/",not_found:"Verify the file path exists. Run /p:init if project not initialized.",syntax:"Check the file format. There may be invalid JSON or markdown.",timeout:"Check your network connection or try again in a moment.",network:"Verify internet connection and try again.",validation:"Review the input parameters and try with different values.",config:"Check .prjct/prjct.config.json for issues. Try /p:init to reinitialize.",unknown:"Can you check the issue manually and provide more context?"};return e[r.type]||e.unknown}var Av,Cl,Ov,Us,Ym=k(()=>{"use strict";Av=[{pattern:/file.*not found.*created/i,type:"contradiction",description:"Claims file created but also not found"},{pattern:/created.*but.*error/i,type:"contradiction",description:"Claims success but also error"},{pattern:/successfully.*failed/i,type:"contradiction",description:"Contradictory success/failure"},{pattern:/already.*completed.*completing/i,type:"state",description:"Completing already-completed task"},{pattern:/no task.*marking complete/i,type:"state",description:"Completing non-existent task"},{pattern:/no.*active.*done with/i,type:"state",description:"Finishing task that doesnt exist"},{pattern:/version.*updated.*no package/i,type:"invented",description:"Version update without package.json"},{pattern:/committed.*nothing to commit/i,type:"invented",description:"Commit without changes"},{pattern:/pushed.*no remote/i,type:"invented",description:"Push without remote"}];l(Iv,"getHallucinationSuggestion");l(Rv,"detectHallucination");l(Dv,"isSimilarError");l(jv,"analyzeErrorPattern");l($v,"generateEscalationMessage");l(Mv,"generateSuggestion");Cl=class{static{l(this,"LoopDetector")}_attempts;_errorPatterns;maxAttempts;sessionTimeout;constructor(){this._attempts=new Map,this._errorPatterns=new Map,this.maxAttempts=3,this.sessionTimeout=300*1e3}_getKey(e,t=""){return`${e}:${t}`.toLowerCase()}recordAttempt(e,t="",n={}){let s=this._getKey(e,t),o=Date.now(),i=this._attempts.get(s);return(!i||o-i.lastAttempt>this.sessionTimeout)&&(i={command:e,context:t,attempts:0,errors:[],firstAttempt:o,lastAttempt:o,success:!1}),i.attempts++,i.lastAttempt=o,i.success=n.success||!1,n.error&&i.errors.push({message:n.error,timestamp:o}),this._attempts.set(s,i),{attemptNumber:i.attempts,isLooping:this.isLooping(e,t),shouldEscalate:this.shouldEscalate(e,t)}}isLooping(e,t=""){let n=this._getKey(e,t),s=this._attempts.get(n);if(!s)return!1;if(s.attempts>=2&&!s.success){let o=s.errors.slice(-3);if(o.length>=2){let i=o[0]?.message||"";return o.every(c=>Dv(c.message,i))}}return!1}shouldEscalate(e,t=""){let n=this._getKey(e,t),s=this._attempts.get(n);return s?s.attempts>=this.maxAttempts&&!s.success:!1}getEscalationInfo(e,t=""){let n=this._getKey(e,t),s=this._attempts.get(n);if(!s)return null;let o=jv(s.errors);return{status:"BLOCKED",command:e,context:t,attempts:s.attempts,duration:s.lastAttempt-s.firstAttempt,errorPattern:o,message:$v(e,o,this.maxAttempts),suggestion:Mv(o),lastError:s.errors[s.errors.length-1]?.message||null}}recordSuccess(e,t=""){let n=this._getKey(e,t),s=this._attempts.get(n);s&&(s.success=!0,s.attempts=0,s.errors=[],this._attempts.set(n,s))}clearTracking(e,t=""){let n=this._getKey(e,t);this._attempts.delete(n)}clearAll(){this._attempts.clear(),this._errorPatterns.clear()}getStats(){let e={activeTracking:this._attempts.size,commands:{}};for(let[t,n]of this._attempts)e.commands[t]={attempts:n.attempts,success:n.success,errorCount:n.errors.length};return e}detectHallucination(e){return Rv(e)}analyzeOutput(e,t){let n=this.detectHallucination(t);return n.detected?(this.recordAttempt(e,"hallucination",{success:!1,error:`HALLUCINATION: ${n.description}`}),{...n,shouldBlock:!0,action:"VERIFY_STATE"}):{detected:!1,shouldBlock:!1}}},Ov=new Cl,Us=Ov});function xl(r,e){let t=Wr(e),n=_v[t.startDay],s=new Date(r);s.setHours(0,0,0,0);let i=(s.getDay()-n+7)%7;return s.setDate(s.getDate()-i),s}function Fv(r,e){let t=Wr(e),n=new Date(r);return n.setDate(n.getDate()+t.sprintLengthDays-1),n.setHours(23,59,59,999),n}function Nv(r,e,t){let n=Wr(t),s=xl(r,t),o=xl(e,t),i=s.getTime()-o.getTime(),a=Math.round(i/(1e3*60*60*24));return Math.floor(a/n.sprintLengthDays)+1}function bi(r,e=xn){let t=Wr(e);if(r.length===0)return{sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:new Date().toISOString()};let n=Lv(r,e),s=Uv(n,t.accuracyTolerance),o=s.slice(-t.windowSize),i=zv(o),a=Hv(o),c=Gv(r,t.accuracyTolerance),{overEstimated:u,underEstimated:d}=Wv(r);return{sprints:s,averageVelocity:i,velocityTrend:a,estimationAccuracy:c,overEstimated:u,underEstimated:d,lastUpdated:new Date().toISOString()}}function Zm(r,e,t=xn){let n=Wr(t);if(e<=0)return{totalPoints:r,sprints:0,estimatedDate:""};let s=Math.ceil(r/e),o=s*n.sprintLengthDays,i=new Date;return i.setDate(i.getDate()+o),{totalPoints:r,sprints:s,estimatedDate:i.toISOString()}}function Lv(r,e){let t=new Map,n=r.map(o=>new Date(o.completedAt)),s=new Date(Math.min(...n.map(o=>o.getTime())));for(let o of r){let i=new Date(o.completedAt),a=Nv(i,s,e);if(!t.has(a)){let c=xl(i,e),u=Fv(c,e);t.set(a,{sprintNumber:a,startDate:c,endDate:u,outcomes:[]})}t.get(a).outcomes.push(o)}return t}function Uv(r,e){let t=[];for(let[,n]of r){let s=n.outcomes.reduce((u,d)=>u+Vv(d),0),o=n.outcomes.filter(u=>u.variance).map(u=>El(u)),i=o.length>0?Math.round(o.reduce((u,d)=>u+d,0)/o.length):0,a=o.filter(u=>Math.abs(u)<=e).length,c=o.length>0?Math.round(a/o.length*100):0;t.push({sprintNumber:n.sprintNumber,startDate:n.startDate.toISOString(),endDate:n.endDate.toISOString(),pointsCompleted:s,tasksCompleted:n.outcomes.length,avgVariance:i,estimationAccuracy:c})}return t.sort((n,s)=>n.sprintNumber-s.sprintNumber)}function Hv(r){if(r.length<3)return"stable";let e=r.map(d=>d.pointsCompleted),t=e.length,n=0,s=0,o=0,i=0;for(let d=0;d<t;d++)n+=d,s+=e[d],o+=d*e[d],i+=d*d;let a=(t*o-n*s)/(t*i-n*n),c=s/t;if(c===0)return"stable";let u=a/c;return u>.1?"improving":u<-.1?"declining":"stable"}function Gv(r,e){let t=r.filter(s=>s.variance);if(t.length===0)return 0;let n=t.filter(s=>{let o=El(s);return Math.abs(o)<=e});return Math.round(n.length/t.length*100)}function zv(r){if(r.length===0)return 0;let e=r.reduce((t,n)=>t+n.pointsCompleted,0);return Math.round(e/r.length*10)/10}function Wv(r){let e=new Map;for(let s of r){if(!s.variance)continue;let o=El(s),i=s.tags&&s.tags.length>0?s.tags:["uncategorized"];for(let a of i){e.has(a)||e.set(a,{variances:[],count:0});let c=e.get(a);c.variances.push(o),c.count++}}let t=[],n=[];for(let[s,o]of e){if(o.count<2)continue;let i=Math.round(o.variances.reduce((a,c)=>a+c,0)/o.variances.length);i>10?n.push({category:s,avgVariance:i,taskCount:o.count}):i<-10&&t.push({category:s,avgVariance:Math.abs(i),taskCount:o.count})}return t.sort((s,o)=>o.avgVariance-s.avgVariance),n.sort((s,o)=>o.avgVariance-s.avgVariance),{overEstimated:t,underEstimated:n}}function El(r){if(!r.variance)return 0;let e=Tl(r.estimatedDuration),t=Tl(r.actualDuration);return e<=0?0:Math.round((t-e)/e*100)}function Tl(r){let e=0,t=r.match(/(\d+)h/);t&&(e+=Number.parseInt(t[1],10)*60);let n=r.match(/(\d+)m/);return n&&(e+=Number.parseInt(n[1],10)),r.match(/(\d+)s/)&&e===0&&(e=1),e}function eg(r){if(r.sprints.length===0)return"No velocity data available yet.";let e=[];e.push(`Project velocity: ${r.averageVelocity} pts/sprint (trend: ${r.velocityTrend})`),e.push(`Estimation accuracy: ${r.estimationAccuracy}%`);for(let t of r.underEstimated)e.push(`\u26A0 "${t.category}" tasks historically take ${t.avgVariance}% longer than estimated`);for(let t of r.overEstimated)e.push(`"${t.category}" tasks typically finish ${t.avgVariance}% faster than estimated`);return e.join(`
|
|
607
|
-
`)}function
|
|
604
|
+
`,s.recommendations.forEach(t=>{e+=` -> ${t}
|
|
605
|
+
`})),e}async function Rm(s){let e=[],t=[],n={},r=s.paths.now;try{let a=await $e.readFile(r,"utf-8");n.nowExists=!0,n.nowContent=a.trim(),n.nowLength=a.length,(a.includes("No current task")||a.match(/^#\s*NOW\s*$/m))&&(e.push("now.md appears to be empty or placeholder"),t.push('Start a task first with /p:now "task"'));let c=a.match(/Started:\s*(.+)/i);if(c){n.startedAt=c[1];let u=new Date(c[1]);Number.isNaN(u.getTime())||(n.durationMs=Date.now()-u.getTime(),n.durationFormatted=Am(n.durationMs))}}catch(a){if(C(a))n.nowExists=!1,e.push("now.md does not exist"),t.push('Create a task with /p:now "task"');else throw a}let o=s.paths.next;try{let a=await $e.readFile(o,"utf-8");n.nextExists=!0;let c=a.match(/- \[ \]/g)||[];n.pendingTasks=c.length}catch(a){if(C(a))n.nextExists=!1,n.pendingTasks=0;else throw a}let i=s.paths.metrics;try{await $e.access(Rn.dirname(i),$e.constants.W_OK),n.metricsWritable=!0}catch(a){if(C(a))n.metricsWritable=!1,e.push("Cannot write to metrics directory");else throw a}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Dm(s){let e=[],t=[],n={};try{let{stdout:i}=await dv("git status --porcelain",{cwd:s.projectPath});n.hasUncommittedChanges=i.trim().length>0,n.uncommittedFiles=i.trim().split(`
|
|
606
|
+
`).filter(Boolean).length,n.hasUncommittedChanges&&(e.push(`${n.uncommittedFiles} uncommitted file(s)`),t.push("Commit changes before shipping"))}catch{n.gitAvailable=!1}let r=Rn.join(s.projectPath,"package.json");try{let i=await $e.readFile(r,"utf-8"),a=JSON.parse(i);n.currentVersion=a.version,n.hasPackageJson=!0}catch(i){if(C(i))n.hasPackageJson=!1;else if(i instanceof SyntaxError)n.hasPackageJson=!1,e.push("package.json has invalid JSON");else throw i}let o=s.paths.shipped;try{let i=await $e.readFile(o,"utf-8");n.shippedExists=!0;let a=s.params.feature||s.params.description;if(a){let c=new Date().toISOString().split("T")[0];new RegExp(`${c}.*${pl(a)}`,"i").test(i)&&(e.push(`Feature "${a}" already shipped today`),t.push("Use a different feature name or skip /p:ship"))}}catch(i){if(C(i))n.shippedExists=!1;else throw i}if(n.hasPackageJson)try{let i=await $e.readFile(r,"utf-8"),a=JSON.parse(i);n.hasTestScript=!!a.scripts?.test}catch(i){if(C(i)||i instanceof SyntaxError)n.hasTestScript=!1;else throw i}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function jm(s){let e=[],t=[],n={},r=s.paths.next;try{let a=await $e.readFile(r,"utf-8");n.nextExists=!0;let c=a.match(/- \[[ x]\]/g)||[];n.taskCount=c.length,n.pendingTasks=(a.match(/- \[ \]/g)||[]).length,n.taskCount>=90&&(e.push(`Queue nearly full (${n.taskCount}/100 tasks)`),t.push("Complete some tasks before adding more"))}catch(a){if(C(a))n.nextExists=!1,n.taskCount=0;else throw a}let o=s.paths.roadmap;try{let a=await $e.readFile(o,"utf-8");n.roadmapExists=!0;let c=s.params.description||s.params.feature;c&&new RegExp(pl(c),"i").test(a)&&(e.push(`Feature "${c}" may already exist in roadmap`),t.push("Check roadmap for duplicates with /p:roadmap"))}catch(a){if(C(a))n.roadmapExists=!1;else throw a}let i=s.paths.now;try{let a=await $e.readFile(i,"utf-8");n.hasActiveTask=a.trim().length>0&&!a.includes("No current task"),n.hasActiveTask&&t.push("Consider completing current task first with /p:done")}catch(a){if(C(a))n.hasActiveTask=!1;else throw a}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Im(s){let e=[],t=[],n={},r=s.paths.now;try{let i=await $e.readFile(r,"utf-8");n.nowExists=!0,n.nowContent=i.trim();let a=i.trim().length>0&&!i.includes("No current task")&&!i.match(/^#\s*NOW\s*$/m);if(n.hasActiveTask=a,a&&s.params.task){let c=i.substring(0,50).replace(/\n/g," ");e.push(`Replacing existing task: "${c}..."`),t.push("Use /p:done first to track completion")}}catch(i){if(C(i))n.nowExists=!1,n.hasActiveTask=!1;else throw i}let o=s.paths.next;try{let a=((await $e.readFile(o,"utf-8")).match(/- \[ \]/g)||[]).length;n.pendingTasks=a,!s.params.task&&a>0&&t.push(`${a} tasks available in queue`)}catch(i){if(C(i))n.pendingTasks=0;else throw i}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function $m(s){let e=[],t=[],n={},r=Rn.join(s.projectPath,".prjct/prjct.config.json");try{let i=await $e.readFile(r,"utf-8");n.alreadyInitialized=!0,n.existingConfig=JSON.parse(i),e.push("Project already initialized"),t.push("Use /p:analyze to refresh analysis or delete .prjct/ to reinitialize")}catch(i){if(C(i))n.alreadyInitialized=!1;else if(i instanceof SyntaxError)n.alreadyInitialized=!1,e.push("Existing config has invalid JSON");else throw i}let o=Rn.join(Em.homedir(),".prjct-cli");try{await $e.access(o,$e.constants.W_OK),n.globalPathWritable=!0}catch(i){if(C(i))try{await $e.mkdir(o,{recursive:!0}),n.globalPathWritable=!0,n.globalPathCreated=!0}catch{n.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}else n.globalPathWritable=!1,e.push("Cannot write to ~/.prjct-cli"),t.push("Check directory permissions")}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Mm(s){let e=[],t=[],n={},r=Rn.join(s.projectPath,".prjct/prjct.config.json");try{let a=await $e.readFile(r,"utf-8");n.hasConfig=!0,n.config=JSON.parse(a)}catch(a){if(C(a))return n.hasConfig=!1,e.push("Project not initialized"),t.push("Run /p:init first"),{verified:!1,actual:n,warnings:e,recommendations:t};if(a instanceof SyntaxError)return n.hasConfig=!1,e.push("Config file has invalid JSON"),t.push("Delete .prjct/ and run /p:init"),{verified:!1,actual:n,warnings:e,recommendations:t};throw a}let o=n.config?.projectId,i=Rn.join(Em.homedir(),".prjct-cli/projects",o||"");try{await $e.access(i),n.globalStorageExists=!0}catch(a){if(C(a))n.globalStorageExists=!1,e.push("Global storage missing"),t.push("Run /p:init to recreate");else throw a}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Om(s){let e=[],t=[],n={},r=["package.json","Cargo.toml","go.mod","requirements.txt","Gemfile","pom.xml"];n.detectedFiles=[];for(let i of r)try{await $e.access(Rn.join(s.projectPath,i)),n.detectedFiles.push(i)}catch(a){if(!C(a))throw a}n.detectedFiles.length===0&&(e.push("No recognizable project files detected"),t.push("Analysis may be limited without package.json or similar"));let o=["src","lib","app","core","components"];n.detectedSrcDirs=[];for(let i of o)try{(await $e.stat(Rn.join(s.projectPath,i))).isDirectory()&&n.detectedSrcDirs.push(i)}catch(a){if(!C(a))throw a}return{verified:!0,actual:n,warnings:e,recommendations:t}}async function Fm(s){let e=[],t=[],n={},r=s.paths.specs;try{await $e.access(r),n.specsExists=!0;let i=await $e.readdir(r);n.existingSpecs=i.filter(a=>a.endsWith(".md")),n.specCount=n.existingSpecs.length}catch(i){if(C(i))n.specsExists=!1,n.specCount=0;else throw i}let o=s.params.feature||s.params.name||s.params.description;if(o&&n.existingSpecs){let i=o.toLowerCase().replace(/\s+/g,"-");n.existingSpecs.includes(`${i}.md`)&&(e.push(`Spec "${o}" already exists`),t.push("Use a different name or edit existing spec"))}return{verified:e.length===0,actual:n,warnings:e,recommendations:t}}async function Nm(s,e,t){let n=_m[s];if(!n)return{verified:!0,actual:{},warnings:[],recommendations:[]};try{return await n(e,t)}catch(r){return{verified:!1,actual:{},warnings:[`Verification error: ${y(r)}`],recommendations:["Check file permissions and project configuration"]}}}async function mv(s,e,t){let n=await Nm(s,e,t);return{...e,groundTruth:{...n,verifiedAt:new Date().toISOString(),command:s}}}function gv(s){return["done","ship","feature","spec","now","init","sync","analyze"].includes(s)}var dv,_m,fv,hi,Lm=k(()=>{"use strict";L();dv=uv(lv);l(Am,"formatDuration");l(pl,"escapeRegex");l(pv,"formatWarnings");l(Rm,"verifyDone");l(Dm,"verifyShip");l(jm,"verifyFeature");l(Im,"verifyNow");l($m,"verifyInit");l(Mm,"verifySync");l(Om,"verifyAnalyze");l(Fm,"verifySpec");_m={done:Rm,ship:Dm,feature:jm,now:Im,init:$m,sync:Mm,analyze:Om,spec:Fm};l(Nm,"verify");l(mv,"prepareCommand");l(gv,"requiresVerification");fv={verify:Nm,prepareCommand:mv,requiresVerification:gv,verifiers:_m,formatWarnings:pv,formatDuration:Am,escapeRegex:pl,verifyDone:Rm,verifyShip:Dm,verifyFeature:jm,verifyNow:Im,verifyInit:$m,verifySync:Mm,verifyAnalyze:Om,verifySpec:Fm},hi=fv});function yv(s){return{contradiction:"Verify file/resource state before reporting. Use Read tool to check actual state.",state:"Check current task state from now.md before assuming completion.",invented:"Verify prerequisites exist (package.json, git remote) before claiming actions."}[s]||"Verify actual state before proceeding."}function wv(s){if(!s||typeof s!="string")return{detected:!1};for(let{pattern:e,type:t,description:n}of hv)if(e.test(s))return{detected:!0,type:t,pattern:e.source,description:n,message:`Potential hallucination detected: ${n}`,suggestion:yv(t)};return{detected:!1}}function Sv(s,e){if(!s||!e)return!1;let t=l(n=>n.toLowerCase().replace(/[0-9]+/g,"N").replace(/['"`]/g,"").replace(/\s+/g," ").trim(),"normalize");return t(s)===t(e)}function kv(s){if(!s||s.length===0)return{type:"unknown",description:"No error information"};let e=s[s.length-1]?.message?.toLowerCase()||"";return e.includes("permission")||e.includes("access denied")?{type:"permission",description:"File or directory permission issue"}:e.includes("not found")||e.includes("no such file")?{type:"not_found",description:"File or resource not found"}:e.includes("syntax")||e.includes("parse")?{type:"syntax",description:"Syntax or parsing error"}:e.includes("timeout")||e.includes("timed out")?{type:"timeout",description:"Operation timed out"}:e.includes("network")||e.includes("connection")?{type:"network",description:"Network or connection issue"}:e.includes("config")||e.includes("configuration")?{type:"config",description:"Configuration issue"}:e.includes("validation")||e.includes("invalid")?{type:"validation",description:"Validation failed"}:{type:"unknown",description:"Unrecognized error pattern"}}function bv(s,e,t){let n={permission:`I've tried ${s} ${t} times but keep hitting permission issues.`,not_found:`After ${t} attempts, I still can't find the required file or resource.`,syntax:`I'm encountering repeated syntax errors with ${s}.`,timeout:`The operation keeps timing out after ${t} attempts.`,network:`Network issues are preventing ${s} from completing.`,validation:`Validation keeps failing for ${s}.`,config:`There seems to be a configuration issue affecting ${s}.`,unknown:`I've tried ${s} ${t} times without success.`};return n[e.type]||n.unknown}function vv(s){let e={permission:"Check file permissions. Try: chmod -R u+w ~/.prjct-cli/",not_found:"Verify the file path exists. Run /p:init if project not initialized.",syntax:"Check the file format. There may be invalid JSON or markdown.",timeout:"Check your network connection or try again in a moment.",network:"Verify internet connection and try again.",validation:"Review the input parameters and try with different values.",config:"Check .prjct/prjct.config.json for issues. Try /p:init to reinitialize.",unknown:"Can you check the issue manually and provide more context?"};return e[s.type]||e.unknown}var hv,ml,Pv,_s,Um=k(()=>{"use strict";hv=[{pattern:/file.*not found.*created/i,type:"contradiction",description:"Claims file created but also not found"},{pattern:/created.*but.*error/i,type:"contradiction",description:"Claims success but also error"},{pattern:/successfully.*failed/i,type:"contradiction",description:"Contradictory success/failure"},{pattern:/already.*completed.*completing/i,type:"state",description:"Completing already-completed task"},{pattern:/no task.*marking complete/i,type:"state",description:"Completing non-existent task"},{pattern:/no.*active.*done with/i,type:"state",description:"Finishing task that doesnt exist"},{pattern:/version.*updated.*no package/i,type:"invented",description:"Version update without package.json"},{pattern:/committed.*nothing to commit/i,type:"invented",description:"Commit without changes"},{pattern:/pushed.*no remote/i,type:"invented",description:"Push without remote"}];l(yv,"getHallucinationSuggestion");l(wv,"detectHallucination");l(Sv,"isSimilarError");l(kv,"analyzeErrorPattern");l(bv,"generateEscalationMessage");l(vv,"generateSuggestion");ml=class{static{l(this,"LoopDetector")}_attempts;_errorPatterns;maxAttempts;sessionTimeout;constructor(){this._attempts=new Map,this._errorPatterns=new Map,this.maxAttempts=3,this.sessionTimeout=300*1e3}_getKey(e,t=""){return`${e}:${t}`.toLowerCase()}recordAttempt(e,t="",n={}){let r=this._getKey(e,t),o=Date.now(),i=this._attempts.get(r);return(!i||o-i.lastAttempt>this.sessionTimeout)&&(i={command:e,context:t,attempts:0,errors:[],firstAttempt:o,lastAttempt:o,success:!1}),i.attempts++,i.lastAttempt=o,i.success=n.success||!1,n.error&&i.errors.push({message:n.error,timestamp:o}),this._attempts.set(r,i),{attemptNumber:i.attempts,isLooping:this.isLooping(e,t),shouldEscalate:this.shouldEscalate(e,t)}}isLooping(e,t=""){let n=this._getKey(e,t),r=this._attempts.get(n);if(!r)return!1;if(r.attempts>=2&&!r.success){let o=r.errors.slice(-3);if(o.length>=2){let i=o[0]?.message||"";return o.every(c=>Sv(c.message,i))}}return!1}shouldEscalate(e,t=""){let n=this._getKey(e,t),r=this._attempts.get(n);return r?r.attempts>=this.maxAttempts&&!r.success:!1}getEscalationInfo(e,t=""){let n=this._getKey(e,t),r=this._attempts.get(n);if(!r)return null;let o=kv(r.errors);return{status:"BLOCKED",command:e,context:t,attempts:r.attempts,duration:r.lastAttempt-r.firstAttempt,errorPattern:o,message:bv(e,o,this.maxAttempts),suggestion:vv(o),lastError:r.errors[r.errors.length-1]?.message||null}}recordSuccess(e,t=""){let n=this._getKey(e,t),r=this._attempts.get(n);r&&(r.success=!0,r.attempts=0,r.errors=[],this._attempts.set(n,r))}clearTracking(e,t=""){let n=this._getKey(e,t);this._attempts.delete(n)}clearAll(){this._attempts.clear(),this._errorPatterns.clear()}getStats(){let e={activeTracking:this._attempts.size,commands:{}};for(let[t,n]of this._attempts)e.commands[t]={attempts:n.attempts,success:n.success,errorCount:n.errors.length};return e}detectHallucination(e){return wv(e)}analyzeOutput(e,t){let n=this.detectHallucination(t);return n.detected?(this.recordAttempt(e,"hallucination",{success:!1,error:`HALLUCINATION: ${n.description}`}),{...n,shouldBlock:!0,action:"VERIFY_STATE"}):{detected:!1,shouldBlock:!1}}},Pv=new ml,_s=Pv});function gl(s,e){let t=Ur(e),n=Cv[t.startDay],r=new Date(s);r.setHours(0,0,0,0);let i=(r.getDay()-n+7)%7;return r.setDate(r.getDate()-i),r}function xv(s,e){let t=Ur(e),n=new Date(s);return n.setDate(n.getDate()+t.sprintLengthDays-1),n.setHours(23,59,59,999),n}function Tv(s,e,t){let n=Ur(t),r=gl(s,t),o=gl(e,t),i=r.getTime()-o.getTime(),a=Math.round(i/(1e3*60*60*24));return Math.floor(a/n.sprintLengthDays)+1}function yi(s,e=bn){let t=Ur(e);if(s.length===0)return{sprints:[],averageVelocity:0,velocityTrend:"stable",estimationAccuracy:0,overEstimated:[],underEstimated:[],lastUpdated:new Date().toISOString()};let n=Ev(s,e),r=Av(n,t.accuracyTolerance),o=r.slice(-t.windowSize),i=jv(o),a=Rv(o),c=Dv(s,t.accuracyTolerance),{overEstimated:u,underEstimated:d}=Iv(s);return{sprints:r,averageVelocity:i,velocityTrend:a,estimationAccuracy:c,overEstimated:u,underEstimated:d,lastUpdated:new Date().toISOString()}}function Gm(s,e,t=bn){let n=Ur(t);if(e<=0)return{totalPoints:s,sprints:0,estimatedDate:""};let r=Math.ceil(s/e),o=r*n.sprintLengthDays,i=new Date;return i.setDate(i.getDate()+o),{totalPoints:s,sprints:r,estimatedDate:i.toISOString()}}function Ev(s,e){let t=new Map,n=s.map(o=>new Date(o.completedAt)),r=new Date(Math.min(...n.map(o=>o.getTime())));for(let o of s){let i=new Date(o.completedAt),a=Tv(i,r,e);if(!t.has(a)){let c=gl(i,e),u=xv(c,e);t.set(a,{sprintNumber:a,startDate:c,endDate:u,outcomes:[]})}t.get(a).outcomes.push(o)}return t}function Av(s,e){let t=[];for(let[,n]of s){let r=n.outcomes.reduce((u,d)=>u+$v(d),0),o=n.outcomes.filter(u=>u.variance).map(u=>hl(u)),i=o.length>0?Math.round(o.reduce((u,d)=>u+d,0)/o.length):0,a=o.filter(u=>Math.abs(u)<=e).length,c=o.length>0?Math.round(a/o.length*100):0;t.push({sprintNumber:n.sprintNumber,startDate:n.startDate.toISOString(),endDate:n.endDate.toISOString(),pointsCompleted:r,tasksCompleted:n.outcomes.length,avgVariance:i,estimationAccuracy:c})}return t.sort((n,r)=>n.sprintNumber-r.sprintNumber)}function Rv(s){if(s.length<3)return"stable";let e=s.map(d=>d.pointsCompleted),t=e.length,n=0,r=0,o=0,i=0;for(let d=0;d<t;d++)n+=d,r+=e[d],o+=d*e[d],i+=d*d;let a=(t*o-n*r)/(t*i-n*n),c=r/t;if(c===0)return"stable";let u=a/c;return u>.1?"improving":u<-.1?"declining":"stable"}function Dv(s,e){let t=s.filter(r=>r.variance);if(t.length===0)return 0;let n=t.filter(r=>{let o=hl(r);return Math.abs(o)<=e});return Math.round(n.length/t.length*100)}function jv(s){if(s.length===0)return 0;let e=s.reduce((t,n)=>t+n.pointsCompleted,0);return Math.round(e/s.length*10)/10}function Iv(s){let e=new Map;for(let r of s){if(!r.variance)continue;let o=hl(r),i=r.tags&&r.tags.length>0?r.tags:["uncategorized"];for(let a of i){e.has(a)||e.set(a,{variances:[],count:0});let c=e.get(a);c.variances.push(o),c.count++}}let t=[],n=[];for(let[r,o]of e){if(o.count<2)continue;let i=Math.round(o.variances.reduce((a,c)=>a+c,0)/o.variances.length);i>10?n.push({category:r,avgVariance:i,taskCount:o.count}):i<-10&&t.push({category:r,avgVariance:Math.abs(i),taskCount:o.count})}return t.sort((r,o)=>o.avgVariance-r.avgVariance),n.sort((r,o)=>o.avgVariance-r.avgVariance),{overEstimated:t,underEstimated:n}}function hl(s){if(!s.variance)return 0;let e=fl(s.estimatedDuration),t=fl(s.actualDuration);return e<=0?0:Math.round((t-e)/e*100)}function fl(s){let e=0,t=s.match(/(\d+)h/);t&&(e+=Number.parseInt(t[1],10)*60);let n=s.match(/(\d+)m/);return n&&(e+=Number.parseInt(n[1],10)),s.match(/(\d+)s/)&&e===0&&(e=1),e}function Wm(s){if(s.sprints.length===0)return"No velocity data available yet.";let e=[];e.push(`Project velocity: ${s.averageVelocity} pts/sprint (trend: ${s.velocityTrend})`),e.push(`Estimation accuracy: ${s.estimationAccuracy}%`);for(let t of s.underEstimated)e.push(`\u26A0 "${t.category}" tasks historically take ${t.avgVariance}% longer than estimated`);for(let t of s.overEstimated)e.push(`"${t.category}" tasks typically finish ${t.avgVariance}% faster than estimated`);return e.join(`
|
|
607
|
+
`)}function $v(s){if(!s.estimatedDuration)return 0;let e=fl(s.estimatedDuration);if(e<=0)return 0;let t=Hm[0],n=Number.POSITIVE_INFINITY;for(let r of Hm){let o=Math.abs(r.typical-e);o<n&&(n=o,t=r)}return t.points}function Ur(s){return{sprintLengthDays:s.sprintLengthDays??7,startDay:s.startDay??"monday",windowSize:s.windowSize??6,accuracyTolerance:s.accuracyTolerance??20}}var Cv,Hm,yl=k(()=>{"use strict";ys();Cv={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6};l(gl,"getSprintStart");l(xv,"getSprintEnd");l(Tv,"getSprintNumber");l(yi,"calculateVelocity");l(Gm,"projectCompletion");l(Ev,"bucketBySprint");l(Av,"buildSprintVelocities");l(Rv,"detectTrend");l(Dv,"calculateOverallAccuracy");l(jv,"calculateAverageVelocity");l(Iv,"detectEstimationPatterns");l(hl,"parseVariancePercent");l(fl,"parseDurationMinutes");l(Wm,"formatVelocityContext");Hm=[{points:1,typical:10},{points:2,typical:20},{points:3,typical:45},{points:5,typical:90},{points:8,typical:180},{points:13,typical:360},{points:21,typical:720}];l($v,"derivePoints");l(Ur,"resolveConfig")});import{exec as Mv}from"node:child_process";import Ov from"node:fs/promises";import wi from"node:path";import{promisify as Fv}from"node:util";async function Ns(s,e,t={}){let n=Date.now(),r=t.maxFiles??30,o=t.minScore??.1,i=t.includeTests??!1,a=wl(s),c=await Hv(e),u=await Gv(e),d=[];for(let p of c){if(!i&&zv(p))continue;let g=Wv(p,a,u,t.historicalBoosts);g.score>=o&&d.push(g)}d.sort((p,g)=>g.score-p.score);let m=d.slice(0,r);return{files:m,metrics:{filesScanned:c.length,filesReturned:m.length,scanDuration:Date.now()-n}}}function wl(s){let e=s.toLowerCase().split(/[^a-z0-9]+/).filter(Boolean),t=new Set(["a","an","the","and","or","but","is","are","was","were","be","been","being","have","has","had","do","does","did","will","would","could","should","may","might","must","shall","can","need","to","of","in","for","on","with","at","by","from","as","into","through","during","before","after","above","below","between","under","again","further","then","once","here","there","when","where","why","how","all","each","few","more","most","other","some","such","no","nor","not","only","own","same","so","than","too","very","just","add","create","make","implement","fix","update","change","modify","remove","delete","new"]);return e.filter(n=>!t.has(n)&&n.length>2)}async function Hv(s){let e=[];async function t(n,r=""){try{let o=await Ov.readdir(n,{withFileTypes:!0});for(let i of o){let a=wi.join(n,i.name),c=wi.join(r,i.name);if(i.isDirectory()){if(Uv.has(i.name)||i.name.startsWith("."))continue;await t(a,c)}else if(i.isFile()){let u=wi.extname(i.name).toLowerCase();Lv.has(u)&&e.push(c)}}}catch(o){C(o)}}return l(t,"walk"),await t(s),e}async function Gv(s){let e=new Map;try{let{stdout:t}=await _v(`git log -30 --pretty=format:"%H %ct" --name-only | awk '
|
|
608
608
|
/^[a-f0-9]{40}/ { commit=$1; timestamp=$2; next }
|
|
609
609
|
NF { files[$0]++; if (!lastmod[$0]) lastmod[$0]=timestamp }
|
|
610
610
|
END { for (f in files) print files[f], lastmod[f], f }
|
|
611
|
-
'`,{cwd:
|
|
612
|
-
`).filter(Boolean);for(let o of
|
|
611
|
+
'`,{cwd:s,maxBuffer:10485760}),n=Math.floor(Date.now()/1e3),r=t.trim().split(`
|
|
612
|
+
`).filter(Boolean);for(let o of r){let i=o.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(i){let a=parseInt(i[1],10),c=parseInt(i[2],10),u=i[3],d=Math.floor((n-c)/86400);e.set(u,{commits:a,daysAgo:d})}}}catch{}return e}function Wv(s,e,t,n){let r=[],o=0,i=0,a=0,c=0,u=0,d=s.toLowerCase(),m=d.split("/").join(" ").split(/[^a-z0-9]+/);for(let w of e){d.includes(w)&&(o+=.3,r.push(`keyword:${w}`));for(let v of m)if(v.includes(w)||w.includes(v)){o+=.15;break}}o=Math.min(1,o);for(let[w,v]of Object.entries(Nv))for(let T of v)if(d.includes(T)&&e.some(ne=>v.includes(ne)||ne.includes(w)||w.includes(ne))){i+=.4,r.push(`domain:${w}`);break}i=Math.min(1,i);let p=t.get(s);p&&(p.daysAgo<=1?(a=1,r.push("recent:1d")):p.daysAgo<=3?(a=.8,r.push("recent:3d")):p.daysAgo<=7?(a=.6,r.push("recent:1w")):p.daysAgo<=30&&(a=.3,r.push("recent:1m")),p.commits>=5&&(a=Math.min(1,a+.2)));let g=wi.basename(s).toLowerCase();if((g.includes("index")||g.includes("main")||g.includes("app")||g.includes("entry"))&&(c=.5,r.push("import:0")),(d.includes("/core/")||d.includes("/shared/")||d.includes("/lib/"))&&(c=Math.max(c,.3),r.some(w=>w.startsWith("import:"))||r.push("import:1")),n){let w=n.get(s);w!==void 0&&(u=(w+1)/2,w>0?r.push("history:boosted"):w<0&&r.push("history:penalized"))}let S=n&&n.size>0?o*.54+i*.18+a*.13+c*.05+u*.1:o*.6+i*.2+a*.15+c*.05;return{path:s,score:Math.min(1,S),reasons:[...new Set(r)]}}function zv(s){let e=s.toLowerCase();return e.includes(".test.")||e.includes(".spec.")||e.includes("__tests__")||e.includes("__mocks__")||e.includes("/tests/")||e.includes("/test/")||e.endsWith("_test.go")||e.endsWith("_test.py")}var _v,Nv,Lv,Uv,Si=k(()=>{"use strict";L();_v=Fv(Mv),Nv={frontend:["component","page","view","ui","layout","style","css","scss","sass","hook","context","store","redux","zustand","react","vue","svelte","angular","next","nuxt","app","client"],backend:["api","route","controller","service","middleware","handler","resolver","schema","model","entity","repository","server","socket","graphql","rest","trpc"],database:["migration","seed","schema","model","entity","repository","prisma","drizzle","sequelize","typeorm","mongoose","knex","sql","db"],auth:["auth","login","logout","session","token","jwt","oauth","passport","credential","permission","role","user","account"],testing:["test","spec","e2e","integration","unit","mock","fixture","stub","jest","vitest","cypress","playwright"],config:["config","env","setting","constant","option","tsconfig","eslint","prettier","vite","webpack","rollup"],infra:["docker","compose","kubernetes","k8s","ci","cd","github","gitlab","jenkins","terraform","ansible","deploy"],util:["util","helper","lib","common","shared","core","base","abstract"]},Lv=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".go",".rs",".java",".kt",".swift",".rb",".php",".c",".cpp",".h",".hpp",".cs",".vue",".svelte"]),Uv=new Set(["node_modules",".git","dist","build",".next",".nuxt",".output","coverage",".cache","__pycache__",".pytest_cache","vendor","target",".turbo",".vercel"]);l(Ns,"findRelevantFiles");l(wl,"extractKeywords");l(Hv,"getAllCodeFiles");l(Gv,"getGitRecency");l(Wv,"scoreFile");l(zv,"isTestFile")});import{exec as Vv}from"node:child_process";import{promisify as Bv}from"node:util";async function zm(s=process.cwd(),e={}){let t=e.commits??30,n=e.maxFiles??50,r=e.branch??!1;try{let o=[],i=[],a=`${t} commits`;if(r){let c=await Kv(s);o=c.hotFiles,i=c.branchOnlyFiles,a=c.analysisWindow}else o=await qv(s,t);return o=o.filter(c=>!Xv(c.path)).slice(0,n),{hotFiles:o,branchOnlyFiles:i,metrics:{commitsAnalyzed:t,totalFilesChanged:o.length,filesReturned:Math.min(o.length,n),analysisWindow:a}}}catch{return{hotFiles:[],branchOnlyFiles:[],metrics:{commitsAnalyzed:0,totalFilesChanged:0,filesReturned:0,analysisWindow:"N/A (git error)"}}}}async function qv(s,e){let{stdout:t}=await Hr(`git log -${e} --pretty=format:"%ct" --name-only | awk '
|
|
613
613
|
/^[0-9]+$/ { timestamp=$1; next }
|
|
614
614
|
NF {
|
|
615
615
|
count[$0]++
|
|
@@ -618,9 +618,9 @@ Recommendations:
|
|
|
618
618
|
END {
|
|
619
619
|
for (f in count) print count[f], lastmod[f], f
|
|
620
620
|
}
|
|
621
|
-
' | sort -rn`,{cwd:
|
|
622
|
-
`).filter(Boolean),o=Math.floor(Date.now()/1e3),i=1;for(let a of
|
|
623
|
-
`).filter(Boolean),{stdout:i}=await
|
|
621
|
+
' | sort -rn`,{cwd:s,maxBuffer:10485760}),n=[],r=t.trim().split(`
|
|
622
|
+
`).filter(Boolean),o=Math.floor(Date.now()/1e3),i=1;for(let a of r){let c=a.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(c){let u=parseInt(c[1],10);u>i&&(i=u)}}for(let a of r){let c=a.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!c)continue;let u=parseInt(c[1],10),d=parseInt(c[2],10),m=c[3],p=o-d,g=Math.floor(p/86400),f=Math.floor(p/3600),S=Math.max(0,1-g/30),w=u/i,v=S*.6+w*.4,T;f<1?T="just now":f<24?T=`${f}h ago`:g<7?T=`${g}d ago`:g<30?T=`${Math.floor(g/7)}w ago`:T=`${Math.floor(g/30)}mo ago`,n.push({path:m,changes:u,heatScore:Math.round(v*100)/100,lastChanged:T,lastChangedAt:new Date(d*1e3).toISOString()})}return n.sort((a,c)=>c.heatScore-a.heatScore)}async function Kv(s){let{stdout:e}=await Hr("git branch --show-current",{cwd:s}),t=e.trim(),n="main";try{await Hr("git rev-parse --verify main",{cwd:s})}catch{n="master"}let{stdout:r}=await Hr(`git diff --name-only ${n}...HEAD`,{cwd:s}),o=r.trim().split(`
|
|
623
|
+
`).filter(Boolean),{stdout:i}=await Hr(`git log ${n}..HEAD --pretty=format:"%ct" --name-only | awk '
|
|
624
624
|
/^[0-9]+$/ { timestamp=$1; next }
|
|
625
625
|
NF {
|
|
626
626
|
count[$0]++
|
|
@@ -629,67 +629,67 @@ Recommendations:
|
|
|
629
629
|
END {
|
|
630
630
|
for (f in count) print count[f], lastmod[f], f
|
|
631
631
|
}
|
|
632
|
-
'`,{cwd:
|
|
633
|
-
`).filter(Boolean),u=Math.floor(Date.now()/1e3),d=1;for(let m of c){let p=m.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(p){let g=parseInt(p[1],10);g>d&&(d=g)}}for(let m of c){let p=m.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!p)continue;let g=parseInt(p[1],10),f=parseInt(p[2],10),S=p[3],
|
|
634
|
-
`);return{file:
|
|
635
|
-
`),
|
|
636
|
-
`).length,m=i[0].trim(),p;if(d>1){let g=n[d-2]?.trim();(g?.startsWith("/**")||g?.startsWith("///")||g?.startsWith("#"))&&(p=g)}t.push({type:o.type,name:a,signature:
|
|
632
|
+
'`,{cwd:s,maxBuffer:10*1024*1024}),a=[],c=i.trim().split(`
|
|
633
|
+
`).filter(Boolean),u=Math.floor(Date.now()/1e3),d=1;for(let m of c){let p=m.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(p){let g=parseInt(p[1],10);g>d&&(d=g)}}for(let m of c){let p=m.match(/^(\d+)\s+(\d+)\s+(.+)$/);if(!p)continue;let g=parseInt(p[1],10),f=parseInt(p[2],10),S=p[3],w=u-f,v=Math.floor(w/86400),T=Math.floor(w/3600),_=Math.max(0,1-v/14),ne=g/d,re=_*.5+ne*.5,ke;T<1?ke="just now":T<24?ke=`${T}h ago`:ke=`${v}d ago`,a.push({path:S,changes:g,heatScore:Math.round(re*100)/100,lastChanged:ke,lastChangedAt:new Date(f*1e3).toISOString()})}return{hotFiles:a.sort((m,p)=>p.heatScore-m.heatScore),branchOnlyFiles:o,analysisWindow:`${n}..HEAD`}}function Xv(s){let e=s.split("/").pop()||"";for(let t of Jv)if(t.startsWith("*.")){if(e.endsWith(t.slice(1)))return!0}else if(e===t)return!0;return!1}var Hr,Jv,Vm=k(()=>{"use strict";Hr=Bv(Vv),Jv=["package-lock.json","yarn.lock","pnpm-lock.yaml","bun.lockb",".gitignore",".env",".env.local","*.md","CHANGELOG.md","LICENSE"];l(zm,"getRecentFiles");l(qv,"getHotFilesFromCommits");l(Kv,"getBranchOnlyFiles");l(Xv,"shouldIgnore")});function Sl(s){return!s||s.length===0?0:Math.ceil(s.length/4)}function Bm(s,e){let t=Yv[e],n=s/1e3*t.input,r=s/1e3*t.output*.3;return{inputSaved:n,outputPotential:r,total:n+r}}function Zv(s){return s<.001?"<$0.01":s<.01?`$${s.toFixed(3)}`:`$${s.toFixed(2)}`}function qm(s,e){let t=Sl(s),n=Sl(e),r=Math.max(0,t-n),o=t>0?(t-n)/t:0,i=Bm(r,Qv),a=Jm.map(c=>({model:c,...Bm(r,c)}));return{tokens:{original:t,filtered:n,saved:r},compression:Math.max(0,Math.min(1,o)),cost:{saved:i.total,formatted:Zv(i.total),byModel:a}}}function kl(s){let e=Sl(s);return{tokens:{original:e,filtered:e,saved:0},compression:0,cost:{saved:0,formatted:"$0.00",byModel:Jm.map(t=>({model:t,inputSaved:0,outputPotential:0,total:0}))}}}var Yv,Qv,Jm,Km=k(()=>{"use strict";Yv={"claude-opus-4.5":{input:.005,output:.025},"claude-sonnet-4.5":{input:.003,output:.015},"claude-haiku-4.5":{input:.001,output:.005},"claude-opus-4":{input:.015,output:.075},"claude-opus-4-6":{input:.015,output:.075},"gpt-4o":{input:.0025,output:.01},"gpt-4-turbo":{input:.01,output:.03},"gpt-4o-mini":{input:15e-5,output:6e-4},"gemini-1.5-pro":{input:.00125,output:.005},"gemini-1.5-flash":{input:75e-6,output:3e-4}},Qv="claude-sonnet-4.5";l(Sl,"countTokens");Jm=["claude-sonnet-4.5","claude-opus-4.5","claude-opus-4-6","gpt-4o","gemini-1.5-pro"];l(Bm,"calculateModelCost");l(Zv,"formatCostSaved");l(qm,"measureCompression");l(kl,"noCompression")});import eP from"node:fs/promises";import bl from"node:path";async function Qm(s,e=process.cwd()){let t=bl.isAbsolute(s)?s:bl.join(e,s),n;try{n=await eP.readFile(t,"utf-8")}catch(u){if(C(u))return{file:s,language:"unknown",signatures:[],fallback:!0,fallbackReason:"File not found",metrics:kl("")};throw u}let r=bl.extname(s).toLowerCase(),o=tP[r]||"unknown",i=oP[o];if(!i||i.length===0)return{file:s,language:o,signatures:[],fallback:!0,fallbackReason:`No extraction patterns for ${o}`,metrics:kl(n)};let a=iP(n,i),c=a.map(u=>`${u.exported?"export ":""}${u.type} ${u.name}: ${u.signature}`).join(`
|
|
634
|
+
`);return{file:s,language:o,signatures:a,fallback:!1,metrics:qm(n,c)}}function iP(s,e){let t=[],n=s.split(`
|
|
635
|
+
`),r=new Set;for(let o of e){o.pattern.lastIndex=0;let i;for(;(i=o.pattern.exec(s))!==null;){let a=i[o.nameIndex];if(!a)continue;let c=`${o.type}:${a}`;if(r.has(c))continue;r.add(c);let u=i.index,d=s.substring(0,u).split(`
|
|
636
|
+
`).length,m=i[0].trim(),p;if(d>1){let g=n[d-2]?.trim();(g?.startsWith("/**")||g?.startsWith("///")||g?.startsWith("#"))&&(p=g)}t.push({type:o.type,name:a,signature:aP(m),exported:o.exported||!1,line:d,docstring:p})}}return t.sort((o,i)=>o.line-i.line)}function aP(s){return s.replace(/\{$/,"").replace(/\s+/g," ").trim()}var tP,Xm,nP,sP,rP,Ym,oP,Zm=k(()=>{"use strict";L();Km();tP={".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".mjs":"javascript",".cjs":"javascript",".py":"python",".go":"go",".rs":"rust",".java":"java",".cs":"csharp",".php":"php",".rb":"ruby"},Xm=[{type:"function",pattern:/^export\s+(?:async\s+)?function\s+(\w+)\s*(<[^>]*>)?\s*\(([^)]*)\)\s*(?::\s*([^{;]+))?/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^export\s+const\s+(\w+)\s*(?::\s*[^=]+)?\s*=\s*(?:async\s+)?\([^)]*\)\s*(?::\s*[^=]+)?\s*=>/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^(?:async\s+)?function\s+(\w+)\s*(<[^>]*>)?\s*\(([^)]*)\)\s*(?::\s*([^{;]+))?/gm,nameIndex:1},{type:"function",pattern:/^const\s+(\w+)\s*(?::\s*[^=]+)?\s*=\s*(?:async\s+)?\([^)]*\)\s*(?::\s*[^=]+)?\s*=>/gm,nameIndex:1},{type:"interface",pattern:/^export\s+interface\s+(\w+)(?:<[^>]+>)?\s*(?:extends\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^interface\s+(\w+)(?:<[^>]+>)?\s*(?:extends\s+[^{]+)?\s*\{/gm,nameIndex:1},{type:"type",pattern:/^export\s+type\s+(\w+)(?:<[^>]+>)?\s*=/gm,nameIndex:1,exported:!0},{type:"type",pattern:/^type\s+(\w+)(?:<[^>]+>)?\s*=/gm,nameIndex:1},{type:"class",pattern:/^export\s+(?:abstract\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"class",pattern:/^(?:abstract\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1},{type:"enum",pattern:/^export\s+enum\s+(\w+)\s*\{/gm,nameIndex:1,exported:!0},{type:"enum",pattern:/^enum\s+(\w+)\s*\{/gm,nameIndex:1},{type:"const",pattern:/^export\s+const\s+(\w+)\s*(?::\s*([^=]+))?\s*=/gm,nameIndex:1,exported:!0}],nP=[{type:"function",pattern:/^def\s+(\w+)\s*\(([^)]*)\)\s*(?:->\s*([^:]+))?\s*:/gm,nameIndex:1},{type:"function",pattern:/^async\s+def\s+(\w+)\s*\(([^)]*)\)\s*(?:->\s*([^:]+))?\s*:/gm,nameIndex:1},{type:"class",pattern:/^class\s+(\w+)(?:\(([^)]*)\))?\s*:/gm,nameIndex:1}],sP=[{type:"function",pattern:/^func\s+(\w+)\s*\(([^)]*)\)\s*(?:\(([^)]*)\)|([^\s{]+))?\s*\{/gm,nameIndex:1},{type:"method",pattern:/^func\s+\([^)]+\)\s+(\w+)\s*\(([^)]*)\)\s*(?:\(([^)]*)\)|([^\s{]+))?\s*\{/gm,nameIndex:1},{type:"type",pattern:/^type\s+(\w+)\s+(?:struct|interface)\s*\{/gm,nameIndex:1}],rP=[{type:"function",pattern:/^pub\s+(?:async\s+)?fn\s+(\w+)(?:<[^>]+>)?\s*\(([^)]*)\)\s*(?:->\s*([^{]+))?\s*\{/gm,nameIndex:1,exported:!0},{type:"function",pattern:/^(?:async\s+)?fn\s+(\w+)(?:<[^>]+>)?\s*\(([^)]*)\)\s*(?:->\s*([^{]+))?\s*\{/gm,nameIndex:1},{type:"class",pattern:/^pub\s+struct\s+(\w+)(?:<[^>]+>)?\s*(?:\{|;)/gm,nameIndex:1,exported:!0},{type:"class",pattern:/^struct\s+(\w+)(?:<[^>]+>)?\s*(?:\{|;)/gm,nameIndex:1},{type:"interface",pattern:/^pub\s+trait\s+(\w+)(?:<[^>]+>)?\s*(?:\{|:)/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^trait\s+(\w+)(?:<[^>]+>)?\s*(?:\{|:)/gm,nameIndex:1},{type:"enum",pattern:/^pub\s+enum\s+(\w+)(?:<[^>]+>)?\s*\{/gm,nameIndex:1,exported:!0},{type:"enum",pattern:/^enum\s+(\w+)(?:<[^>]+>)?\s*\{/gm,nameIndex:1}],Ym=[{type:"class",pattern:/^(?:public\s+)?(?:abstract\s+)?(?:final\s+)?class\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+\w+)?(?:\s+implements\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"interface",pattern:/^(?:public\s+)?interface\s+(\w+)(?:<[^>]+>)?(?:\s+extends\s+[^{]+)?\s*\{/gm,nameIndex:1,exported:!0},{type:"method",pattern:/^\s+(?:public|private|protected)?\s*(?:static\s+)?(?:final\s+)?(?:synchronized\s+)?(?:<[^>]+>\s+)?(\w+(?:<[^>]+>)?)\s+(\w+)\s*\([^)]*\)\s*(?:throws\s+[^{]+)?\s*\{/gm,nameIndex:2}],oP={typescript:Xm,javascript:Xm,python:nP,go:sP,rust:rP,java:Ym,csharp:Ym,php:[],ruby:[],unknown:[]};l(Qm,"extractSignatures");l(iP,"extractFromContent");l(aP,"cleanSignature")});import{createHash as cP}from"node:crypto";import ng from"node:fs/promises";import sg from"node:path";function eg(s){return cP("sha256").update(s.toLowerCase().trim()).digest("hex").slice(0,16)}async function tg(s){try{let e=sg.join(s,"storage","classification-cache.json"),t=await ng.readFile(e,"utf-8");return JSON.parse(t)}catch(e){return C(e)?$a:(console.warn("[classifier] Failed to load cache:",y(e)),$a)}}async function vl(s,e){try{let t=sg.join(s,"storage","classification-cache.json");await ng.writeFile(t,JSON.stringify(e,null,2))}catch(t){console.warn("[classifier] Failed to save cache:",y(t))}}function uP(s,e,t){let n=s.entries[e];return!n||n.projectId!==t||Date.now()-new Date(n.classifiedAt).getTime()>lP?null:n.classification}function dP(s,e){return s.confirmedPatterns.find(n=>n.descriptionHash===e)?.classification??null}async function pP(s,e){let t=process.env.ANTHROPIC_API_KEY;if(!t)return null;let n=rg(e),r=Oa("classification")||"",o=`Classify this software engineering task into a domain.
|
|
637
637
|
|
|
638
|
-
Task: "${
|
|
638
|
+
Task: "${s}"
|
|
639
639
|
|
|
640
640
|
Available domains in this project: ${n.join(", ")}
|
|
641
641
|
Available agents: ${e.agents.join(", ")||"none"}
|
|
642
642
|
Stack: ${e.stack?.language||"unknown"} / ${e.stack?.framework||"unknown"}
|
|
643
643
|
|
|
644
|
-
${
|
|
645
|
-
`);return{path:c.path,content:d}}catch{return null}}));return{gitBranch:n.branch,gitStatus:n.status,relevantFiles:
|
|
646
|
-
`).filter(Boolean),i=0,a=0,c=0;for(let m of o){let p=m.substring(0,2);p.startsWith("??")?a++:p[0]!==" "&&p[0]!=="?"?c++:i++}let u=[];c>0&&u.push(`${c} staged`),i>0&&u.push(`${i} modified`),a>0&&u.push(`${a} untracked`);let d=u.length>0?u.join(", "):"clean";return{branch:
|
|
647
|
-
`)}_calculateDuration(e,t){if(!e||!t)return null;let n=new Date(t).getTime()-new Date(e).getTime(),
|
|
648
|
-
`);let t=[];
|
|
649
|
-
Context: ${
|
|
650
|
-
`)}var
|
|
651
|
-
`,"utf-8"),
|
|
652
|
-
${[["project",
|
|
644
|
+
${r}`;try{let i=await fetch("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"Content-Type":"application/json","x-api-key":t,"anthropic-version":"2023-06-01"},body:JSON.stringify({model:"claude-haiku-4-5-20251001",max_tokens:200,messages:[{role:"user",content:o}]})});if(!i.ok)return null;let c=(await i.json()).content?.[0]?.text;if(!c)return null;let u=JSON.parse(c),d=kn.safeParse(u);return d.success?d.data:{primaryDomain:n.includes(u.primaryDomain)?u.primaryDomain:"general",secondaryDomains:(u.secondaryDomains||[]).filter(m=>n.includes(m)),confidence:Math.min(1,Math.max(0,u.confidence||.5)),filePatterns:Array.isArray(u.filePatterns)?u.filePatterns:[],relevantAgents:Array.isArray(u.relevantAgents)?u.relevantAgents:[]}}catch{return null}}function gP(s,e){let t=rg(e),n=new Map;for(let[p,g]of Object.entries(mP)){if(p==="general"||!t.includes(p))continue;let f=0;for(let S of g)s.match(new RegExp(S,"gi"))&&(f+=S.source.includes("\\s")?3:1);f>0&&n.set(p,f)}if(n.size===0)return Ed;let r=Array.from(n.entries()).sort((p,g)=>g[1]-p[1]),o=r[0][0],i=r[0][1],a=r.slice(1,3).map(([p])=>p),c=r.reduce((p,[,g])=>p+g,0),u=Math.min(.85,i/c+.2),d=fP(o),m=e.agents.filter(p=>p===o||p.includes(o)||o.includes(p.replace(".md","")));return{primaryDomain:o,secondaryDomains:a,confidence:u,filePatterns:d,relevantAgents:m}}function rg(s){let e=[];return s.domains.hasFrontend&&e.push("frontend"),s.domains.hasBackend&&e.push("backend"),s.domains.hasDatabase&&e.push("database"),s.domains.hasTesting&&e.push("testing"),s.domains.hasDocker&&e.push("devops"),e.push("docs","uxui","general"),e}function fP(s){let e={frontend:["src/components/**","src/pages/**","src/hooks/**","**/*.tsx","**/*.jsx"],backend:["src/api/**","src/routes/**","src/services/**","src/handlers/**"],database:["src/models/**","src/schemas/**","**/*.sql","prisma/**"],devops:[".github/**","docker/**","deploy/**","infra/**","**/*.yml","**/*.yaml"],testing:["**/*.test.*","**/*.spec.*","tests/**","__tests__/**","e2e/**"],docs:["docs/**","**/*.md","**/*.mdx"],uxui:["src/components/**","src/styles/**","**/*.css"],general:["**/*.ts","**/*.js"]};return e[s]||e.general}var lP,mP,Pl,hP,og,ig=k(()=>{"use strict";yr();yo();L();lP=3600*1e3;l(eg,"hashDescription");l(tg,"loadCache");l(vl,"saveCache");l(uP,"lookupCache");l(dP,"lookupPatterns");l(pP,"classifyWithLLM");mP={frontend:[/\bui\b/i,/\bcomponents?\b/i,/\breact\b/i,/\bvue\b/i,/\bangular\b/i,/\bsvelte\b/i,/\bnext\.?js\b/i,/\bnuxt\b/i,/\bcss\b/i,/\bscss\b/i,/\bstyles?\b/i,/\bbuttons?\b/i,/\bforms?\b/i,/\bmodals?\b/i,/\blayout\b/i,/\bresponsive\b/i,/\banimation\b/i,/\bdom\b/i,/\bhtml\b/i,/\bfrontend\b/i,/\bclient[- ]side\b/i,/\bbrowser\b/i,/\bjsx\b/i,/\btsx\b/i,/\bhooks?\b/i,/\bredux\b/i,/\bzustand\b/i,/\btailwind\b/i,/\bdashboard\b/i,/\bpage\b/i,/\bnavigation\b/i,/\bsidebar\b/i,/\bheader\b/i,/\bfooter\b/i,/\bwidget\b/i,/\btooltip\b/i,/\bdropdown\b/i,/\bcarousel\b/i,/\bprofile\s+page\b/i,/\bdisplay\b/i],backend:[/\bapi\b/i,/\bendpoints?\b/i,/\bserver\b/i,/\broutes?\b/i,/\bhandlers?\b/i,/\bcontrollers?\b/i,/\bservices?\b/i,/\bmiddleware\b/i,/\bauth\b/i,/\bauthentication\b/i,/\bauthorization\b/i,/\bjwt\b/i,/\boauth\b/i,/\brest\b/i,/\bgraphql\b/i,/\btrpc\b/i,/\bexpress\b/i,/\bfastify\b/i,/\bhono\b/i,/\bnest\.?js\b/i,/\bvalidation\b/i,/\bbusiness\s+logic\b/i,/\bcron\b/i,/\bwebhook\b/i,/\bworker\b/i,/\bqueue\b/i,/\bcache\b/i],database:[/\bdatabase\b/i,/\bdb\b/i,/\bsql\b/i,/\bquery\b/i,/\btables?\b/i,/\bschema\b/i,/\bmigrations?\b/i,/\bpostgres\b/i,/\bmysql\b/i,/\bsqlite\b/i,/\bmongo\b/i,/\bredis\b/i,/\bprisma\b/i,/\bdrizzle\b/i,/\borm\b/i,/\bentity\b/i,/\brepository\b/i,/\bdata\s+layer\b/i,/\bpersist\b/i,/\bindex(?:es|ing)?\b/i,/\bconnection\s+pool\b/i],devops:[/\bdocker\b/i,/\bkubernetes\b/i,/\bk8s\b/i,/\bci\b/i,/\bcd\b/i,/\bpipeline\b/i,/\bdeploy\b/i,/\bgithub\s+actions\b/i,/\bvercel\b/i,/\baws\b/i,/\bgcp\b/i,/\bazure\b/i,/\bterraform\b/i,/\bnginx\b/i,/\bcaddy\b/i,/\binfrastructure\b/i,/\bmonitoring\b/i,/\blogging\b/i,/\bcontainer\b/i,/\bhelm\b/i],testing:[/\btests?\b/i,/\bspec\b/i,/\bunit\s+tests?\b/i,/\bintegration\s+tests?\b/i,/\be2e\b/i,/\bjest\b/i,/\bvitest\b/i,/\bplaywright\b/i,/\bcypress\b/i,/\bmocha\b/i,/\bmocks?\b/i,/\bstubs?\b/i,/\bfixtures?\b/i,/\bcoverage\b/i,/\bassertions?\b/i],docs:[/\bdocument(?:ation)?\b/i,/\bdocs\b/i,/\breadme\b/i,/\bchangelog\b/i,/\bjsdoc\b/i,/\btutorial\b/i,/\bguide\b/i,/\bmarkdown\b/i],uxui:[/\bdesign\b/i,/\bux\b/i,/\buser\s+experience\b/i,/\baccessibility\b/i,/\ba11y\b/i,/\bwcag\b/i,/\bfigma\b/i,/\bprototype\b/i,/\bwireframe\b/i,/\busability\b/i],general:[]};l(gP,"classifyWithHeuristic");l(rg,"buildAvailableDomains");l(fP,"getFilePatterns");Pl=class{static{l(this,"DomainClassifier")}async classify(e,t,n,r){let o=eg(e),i=await tg(n),a=uP(i,o,t);if(a)return{classification:a,source:"cache"};let c=dP(i,o);if(c)return{classification:c,source:"history"};let u=await pP(e,r);if(u)return i.entries[o]={classification:u,classifiedAt:new Date().toISOString(),source:"llm",descriptionHash:o,projectId:t},await vl(n,i),{classification:u,source:"llm"};let d=gP(e,r);return i.entries[o]={classification:d,classifiedAt:new Date().toISOString(),source:"heuristic",descriptionHash:o,projectId:t},await vl(n,i),{classification:d,source:"heuristic"}}async confirmClassification(e,t,n){let r=eg(e),o=await tg(n);o.confirmedPatterns.some(i=>i.descriptionHash===r)||(o.confirmedPatterns.push({descriptionHash:r,classification:t,confirmedAt:new Date().toISOString(),taskDescription:e}),await vl(n,o))}},hP=new Pl,og=hP});import{exec as yP}from"node:child_process";import Gr from"node:fs/promises";import wP from"node:os";import Yn from"node:path";import{promisify as SP}from"node:util";var ag,cg,Cl,kP,ki,xl=k(()=>{"use strict";yl();Pt();ve();ys();Yt();Si();Vm();Zm();L();Xn();ig();qt();ag=SP(yP),cg=["database","backend","frontend","testing","devops"],Cl=class{static{l(this,"OrchestratorExecutor")}async execute(e,t,n){let r=await M.getProjectId(n),o=A.getGlobalProjectPath(r),i=await this.loadRepoAnalysis(o),{domains:a,primary:c}=await this.detectDomains(t,r,i),u=await this.loadAgents(a,r),d=await this.loadSkills(u),m=await Promise.allSettled([this.gatherRealContext(t,n),this.loadSealedAnalysis(r),this.loadVelocityContext(r)]),p=["realContext","sealedAnalysis","velocity"],g=[],f=m.map((re,ke)=>{if(re.status==="fulfilled")return re.value;g.push(p[ke]),console.warn(`Context tool "${p[ke]}" failed: ${y(re.reason)}`)}),[S,w,v]=f,T={level:g.length===0?"full":g.length>=2?"minimal":"partial",failedTools:g},_=this.shouldFragment(a,t),ne=null;return _&&e==="task"&&(ne=await this.createSubtasks(t,a,u,r)),{detectedDomains:a,primaryDomain:c,agents:u,skills:d,requiresFragmentation:_,subtasks:ne,project:{id:r,ecosystem:i?.ecosystem||"unknown",conventions:i?.conventions||[]},realContext:S,sealedAnalysis:w??null,velocityContext:v??null,contextDegradation:T}}async gatherRealContext(e,t){try{let[n,r,o]=await Promise.all([this.getGitState(t),Ns(e,t,{maxFiles:10,minScore:.15}),zm(t,{commits:10,maxFiles:10})]),i=r.files.slice(0,3),a=await Promise.all(i.map(async c=>{try{let u=await Qm(c.path,t);if(u.signatures.length===0)return null;let d=u.signatures.map(m=>`${m.exported?"export ":""}${m.type} ${m.name}: ${m.signature}`).join(`
|
|
645
|
+
`);return{path:c.path,content:d}}catch{return null}}));return{gitBranch:n.branch,gitStatus:n.status,relevantFiles:r.files.map(c=>({path:c.path,score:Math.round(c.score*100),reason:c.reasons.join(", ")})),recentFiles:o.hotFiles.slice(0,5).map(c=>({path:c.path,lastChanged:c.lastChanged,changes:c.changes})),signatures:a.filter(c=>c!==null)}}catch{return}}async getGitState(e){try{let[t,n]=await Promise.all([ag("git branch --show-current",{cwd:e}),ag("git status --porcelain",{cwd:e})]),r=t.stdout.trim()||"main",o=n.stdout.trim().split(`
|
|
646
|
+
`).filter(Boolean),i=0,a=0,c=0;for(let m of o){let p=m.substring(0,2);p.startsWith("??")?a++:p[0]!==" "&&p[0]!=="?"?c++:i++}let u=[];c>0&&u.push(`${c} staged`),i>0&&u.push(`${i} modified`),a>0&&u.push(`${a} untracked`);let d=u.length>0?u.join(", "):"clean";return{branch:r,status:d}}catch{return{branch:"unknown",status:"git unavailable"}}}async loadSealedAnalysis(e){try{let t=await Je.getActive(e);return t?{languages:t.languages??[],frameworks:t.frameworks??[],packageManager:t.packageManager,sourceDir:t.sourceDir,testDir:t.testDir,fileCount:t.fileCount??0,patterns:t.patterns??[],antiPatterns:t.antiPatterns??[],status:t.status??"draft",commitHash:t.commitHash}:null}catch{return null}}async loadVelocityContext(e){try{let t=await gt.getAll(e);if(t.length===0)return null;let n=yi(t,bn);return n.sprints.length===0?null:Wm(n)}catch{return null}}async loadRepoAnalysis(e){try{let t=Yn.join(e,"analysis","repo-analysis.json"),n=await Gr.readFile(t,"utf-8");return JSON.parse(n)}catch(t){return C(t)||console.warn("Failed to load repo-analysis.json:",y(t)),null}}async detectDomains(e,t,n){let r=A.getGlobalProjectPath(t),o=await this.getAvailableAgentNames(r),i={hasFrontend:!1,hasBackend:!0,hasDatabase:!1,hasTesting:!1,hasDocker:!1};try{let m=await N.read(t);m.domains&&(i=m.domains)}catch{}let a={domains:i,agents:o,stack:n?{language:n.ecosystem}:void 0},{classification:c}=await og.classify(e,t,r,a),d=[c.primaryDomain,...c.secondaryDomains||[]].filter(m=>o.some(p=>p===m||p.includes(m)||m.includes(p.replace(".md",""))));return d.length===0?{domains:["general"],primary:"general"}:{domains:d,primary:d[0]}}async getAvailableAgentNames(e){try{let t=Yn.join(e,"agents");return(await Gr.readdir(t)).filter(r=>r.endsWith(".md")).map(r=>r.replace(".md",""))}catch{return[]}}async loadAgents(e,t){let n=A.getGlobalProjectPath(t),r=Yn.join(n,"agents"),o=e.map(async a=>{let c=[`${a}.md`,`${a}-agent.md`,`prjct-${a}.md`];for(let u of c){let d=Yn.join(r,u);try{let m=await Gr.readFile(d,"utf-8"),{frontmatter:p,body:g}=this.parseAgentFile(m);return{name:u.replace(".md",""),domain:a,content:g,skills:p.skills||[],filePath:d,effort:p.effort,model:p.model}}catch{}}return null});return(await Promise.all(o)).filter(a=>a!==null)}parseAgentFile(e){let t=Eo(e),n={...t.frontmatter};return typeof n.skills=="string"&&(n.skills=n.skills.split(",").map(r=>r.trim())),{frontmatter:n,body:t.content}}async loadSkills(e){let t=Yn.join(wP.homedir(),".claude","skills"),n=new Map;for(let i of e)for(let a of i.skills){let c=n.get(a)||[];c.push(i.name),n.set(a,c)}let r=Array.from(n.keys()).map(async i=>{let a=Yn.join(t,`${i}.md`),c=Yn.join(t,i,"SKILL.md");try{let u=await Gr.readFile(c,"utf-8");return{name:i,content:u,filePath:c}}catch{try{let u=await Gr.readFile(a,"utf-8");return{name:i,content:u,filePath:a}}catch{let u=n.get(i)||[];return console.warn(`\u26A0 Skill "${i}" not installed (needed by: ${u.join(", ")}). Run \`prjct sync\` to auto-install.`),null}}});return(await Promise.all(r)).filter(i=>i!==null)}shouldFragment(e,t){if(e.length>=3)return!0;let n=["full stack","fullstack","end to end","e2e","complete feature","from database to ui","across layers"],r=t.toLowerCase();for(let i of n)if(r.includes(i))return!0;return t.split(/\s+/).length>30&&e.length>=2}async createSubtasks(e,t,n,r){let o=[...t].sort((a,c)=>{let u=cg.indexOf(a),d=cg.indexOf(c);return(u===-1?99:u)-(d===-1?99:d)}),i=o.map((a,c)=>{let u=n.find(p=>p.domain===a),d=u?`${u.name}.md`:`${a}.md`,m=o.slice(0,c).map((p,g)=>`subtask-${g+1}`);return{id:`subtask-${c+1}`,description:this.generateSubtaskDescription(e,a),domain:a,agent:d,status:c===0?"in_progress":"pending",dependsOn:m,order:c+1}});return await N.createSubtasks(r,i.map(a=>({id:a.id,description:a.description,domain:a.domain,agent:a.agent,dependsOn:a.dependsOn}))),i}generateSubtaskDescription(e,t){let r={database:"Set up data layer: schema, models, migrations",backend:"Implement API: routes, controllers, services, validation",frontend:"Build UI: components, forms, state management",testing:"Write tests: unit, integration, e2e",devops:"Configure deployment: CI/CD, environment, containers",uxui:"Design user experience: flows, accessibility, styling"}[t]||`Handle ${t} aspects`;return`[${t.toUpperCase()}] ${r} for: ${e.substring(0,80)}${e.length>80?"...":""}`}},kP=new Cl,ki=kP});function bP(s,e){return{ship:{title:"Ship Confirmation",message:"Ready to commit and push changes?",details:[`Branch: ${e.branch||"current"}`,`Files: ${e.changedFiles?.length||0} changed`,`Commit: "${e.commitMessage||"No message"}"`],options:[{key:"y",label:"Yes, ship it",action:"approve"},{key:"n",label:"No, cancel",action:"reject"},{key:"e",label:"Edit message",action:"edit"}]},cleanup:{title:"Cleanup Confirmation",message:"This will delete files/code. Continue?",details:[`Files to delete: ${e.filesToDelete?.length||0}`,`Code to remove: ${e.linesOfCode||0} lines`],options:[{key:"y",label:"Yes, cleanup",action:"approve"},{key:"n",label:"No, cancel",action:"reject"},{key:"l",label:"List files first",action:"list"}]},git:{title:"Git Operation Confirmation",message:`Execute: ${e.operation||"git operation"}?`,details:e.warnings||[],options:[{key:"y",label:"Yes, execute",action:"approve"},{key:"n",label:"No, cancel",action:"reject"}]}}[s]||{title:"Confirmation Required",message:`Execute ${s}?`,options:[{key:"y",label:"Yes",action:"approve"},{key:"n",label:"No",action:"reject"}]}}var Tl,vP,Ue,lg=k(()=>{"use strict";Rt();ce();Cn();Cn();l(bP,"generateApprovalPrompt");Tl=class{static{l(this,"PlanMode")}activePlans;constructor(){this.activePlans=new Map}requiresPlanning(e){return hc.includes(e)}isDestructive(e){return yc.includes(e)}isToolAllowedInPlanning(e){return zo.includes(e)}getAllowedTools(e,t){return e?t.filter(n=>zo.includes(n)):t}startPlanning(e,t,n){let r={id:me(),projectId:e,command:t,params:n,status:se.GATHERING,startedAt:b(),gatheredInfo:[],analysis:null,proposedPlan:null,userFeedback:null,approvedAt:null,executionStartedAt:null,completedAt:null,steps:[],currentStep:0};return this.activePlans.set(e,r),r}getActivePlan(e){return this.activePlans.get(e)||null}isInPlanningMode(e){let t=this.getActivePlan(e);return t?[se.GATHERING,se.ANALYZING,se.PROPOSING,se.PENDING_APPROVAL].includes(t.status):!1}recordGatheredInfo(e,t){let n=this.getActivePlan(e);n&&n.gatheredInfo.push({...t,gatheredAt:b()})}updateStatus(e,t){let n=this.getActivePlan(e);n&&(n.status=t,t===se.APPROVED?n.approvedAt=b():t===se.EXECUTING?n.executionStartedAt=b():(t===se.COMPLETED||t===se.ABORTED)&&(n.completedAt=b()))}setAnalysis(e,t){let n=this.getActivePlan(e);n&&(n.analysis=t,n.status=se.ANALYZING)}proposePlan(e,t){let n=this.getActivePlan(e);return n?(n.proposedPlan=t,n.status=se.PENDING_APPROVAL,this.formatPlanForApproval(n)):null}formatPlanForApproval(e){let t=e.proposedPlan;return{summary:t?.summary||`Plan for: ${e.command}`,approach:t?.approach,steps:t?.steps||[],risks:t?.risks||[],alternatives:t?.alternatives||[],estimatedTime:t?.estimatedTime,affectedFiles:t?.affectedFiles||[],requiresConfirmation:!0,planId:e.id}}approvePlan(e,t=null){let n=this.getActivePlan(e);return!n||n.status!==se.PENDING_APPROVAL?null:(n.userFeedback=t,n.status=se.APPROVED,n.approvedAt=b(),n.steps=(n.proposedPlan?.steps||[]).map((r,o)=>({index:o,description:typeof r=="string"?r:r.description||"",status:"pending",tool:typeof r=="string"?void 0:r.tool,args:typeof r=="string"?void 0:r.args})),{approved:!0,planId:n.id,steps:n.steps,message:`Plan approved. ${n.steps.length} steps to execute.`})}rejectPlan(e,t=null){let n=this.getActivePlan(e);return n?(n.status=se.REJECTED,n.userFeedback=t,n.completedAt=b(),this.activePlans.delete(e),{rejected:!0,planId:n.id,reason:t,message:"Plan rejected. No changes made."}):null}startExecution(e){let t=this.getActivePlan(e);return!t||t.status!==se.APPROVED?null:(t.status=se.EXECUTING,t.executionStartedAt=b(),t.currentStep=0,this.getNextStep(e))}getNextStep(e){let t=this.getActivePlan(e);if(!t||t.status!==se.EXECUTING)return null;let n=t.steps[t.currentStep];return n?{stepNumber:t.currentStep+1,totalSteps:t.steps.length,step:n,progress:Math.round(t.currentStep/t.steps.length*100)}:(this.completePlan(e),null)}completeStep(e,t={success:!0}){let n=this.getActivePlan(e);return!n||n.status!==se.EXECUTING?null:(n.steps[n.currentStep].status="completed",n.steps[n.currentStep].result=t,n.steps[n.currentStep].completedAt=b(),n.currentStep++,this.getNextStep(e))}failStep(e,t){let n=this.getActivePlan(e);return n?(n.steps[n.currentStep].status="failed",n.steps[n.currentStep].error=t,{failed:!0,step:n.currentStep+1,error:t,options:["retry","skip","abort"]}):null}completePlan(e){let t=this.getActivePlan(e);if(!t)return null;t.status=se.COMPLETED,t.completedAt=b();let n={planId:t.id,command:t.command,totalSteps:t.steps.length,completedSteps:t.steps.filter(r=>r.status==="completed").length,failedSteps:t.steps.filter(r=>r.status==="failed").length,duration:this._calculateDuration(t.executionStartedAt,t.completedAt)};return this.activePlans.delete(e),n}abortPlan(e,t="User requested"){let n=this.getActivePlan(e);if(!n)return null;n.status=se.ABORTED,n.completedAt=b(),n.abortReason=t;let r={aborted:!0,planId:n.id,reason:t,completedSteps:n.steps.filter(o=>o.status==="completed").length,totalSteps:n.steps.length};return this.activePlans.delete(e),r}generateApprovalPrompt(e,t){return bP(e,t)}formatStatus(e){let t=this.getActivePlan(e);if(!t)return"No active plan";let r=[`${{[se.GATHERING]:"\u{1F50D}",[se.ANALYZING]:"\u{1F9E0}",[se.PROPOSING]:"\u{1F4DD}",[se.PENDING_APPROVAL]:"\u23F3",[se.APPROVED]:"\u2705",[se.EXECUTING]:"\u26A1",[se.COMPLETED]:"\u{1F389}",[se.REJECTED]:"\u274C",[se.ABORTED]:"\u{1F6D1}"}[t.status]||"\u{1F4CB}"} Plan: ${t.command}`,`Status: ${t.status}`];if(t.status===se.EXECUTING){let o=Math.round(t.currentStep/t.steps.length*100);r.push(`Progress: ${t.currentStep}/${t.steps.length} (${o}%)`)}return r.join(`
|
|
647
|
+
`)}_calculateDuration(e,t){if(!e||!t)return null;let n=new Date(t).getTime()-new Date(e).getTime(),r=Math.floor(n/1e3),o=Math.floor(r/60),i=Math.floor(o/60);return i>0?`${i}h ${o%60}m`:o>0?`${o}m ${r%60}s`:`${r}s`}},vP=new Tl,Ue=vP});function PP(s){let e=s.trim().toLowerCase(),t=e.replace(/[.\s-]/g,"");return bi[t]?bi[t]:bi[e]?bi[e]:e}function vi(s){let e=new Set,t=[];for(let n of s){let r=PP(n);e.has(r)||(e.add(r),t.push(n))}return t}var bi,El=k(()=>{"use strict";bi={nextjs:"next.js",nuxtjs:"nuxt.js",expressjs:"express",fastifyjs:"fastify","react.js":"react","vue.js":"vue","svelte.js":"svelte","angular.js":"angular",angularjs:"angular","node.js":"node",nodejs:"node",ts:"typescript",js:"javascript",pg:"postgres",postgresql:"postgres",mongo:"mongodb"};l(PP,"normalizeFrameworkName");l(vi,"deduplicateTechStack")});import{z as He}from"zod";function ug(s){let e=[];e.push(`## CONSTRAINTS (Read Before Acting)
|
|
648
|
+
`);let t=[];s.language&&t.push(s.language),s.framework&&t.push(s.framework);let n=s.techStack??[];t.push(...n);let r=s.analysisLanguages??[],o=s.analysisFrameworks??[];t.push(...r,...o);let i=vi(t);if(i.length>0&&e.push(`AVAILABLE in this project: ${i.join(", ")}`),s.analysisPackageManager&&e.push(`PACKAGE MANAGER: ${s.analysisPackageManager}`),s.domains){let c=Object.entries(s.domains).filter(([,u])=>!u).map(([u])=>CP[u]).filter(Boolean);c.length>0&&e.push(`NOT PRESENT: ${c.join(", ")}`)}let a=s.availableAgents??[];return a.length>0&&e.push(`AGENTS: ${a.join(", ")}`),e.push(""),e.push(`SCOPE: Only files in \`${s.projectPath}\` are accessible.`),e.push("RULE: Use ONLY file paths explicitly shown in context. Do NOT infer or guess paths."),e.push("RULE: NEVER assume a library is available. Check package.json/imports first."),e.push("RULE: If previous context contradicts this section, trust this section."),e.push("RULE: Read files BEFORE modifying. Never assume code structure."),s.fileCount&&e.push(`
|
|
649
|
+
Context: ${s.fileCount} files in project.`),e.join(`
|
|
650
|
+
`)}var E_,CP,dg=k(()=>{"use strict";El();E_=He.object({projectPath:He.string(),language:He.string().optional(),framework:He.string().optional(),techStack:He.array(He.string()).default([]),domains:He.object({hasFrontend:He.boolean().default(!1),hasBackend:He.boolean().default(!1),hasDatabase:He.boolean().default(!1),hasTesting:He.boolean().default(!1),hasDocker:He.boolean().default(!1)}).optional(),fileCount:He.number().optional(),availableAgents:He.array(He.string()).default([]),analysisLanguages:He.array(He.string()).default([]),analysisFrameworks:He.array(He.string()).default([]),analysisPackageManager:He.string().optional()}),CP={hasFrontend:"Frontend (UI/components)",hasBackend:"Backend (APIs/servers)",hasDatabase:"Database (SQL/ORM)",hasTesting:"Testing (unit/integration)",hasDocker:"Docker/containers"};l(ug,"buildAntiHallucinationBlock")});import{z as Ht}from"zod";var xP,pg,mg=k(()=>{"use strict";xP=Ht.object({agents:Ht.boolean(),patterns:Ht.boolean(),checklist:Ht.boolean(),modules:Ht.array(Ht.string())}),pg=Ht.object({version:Ht.string(),description:Ht.string().optional(),commands:Ht.record(Ht.string(),xP).refine(s=>"*"in s,{message:'Config must include a "*" wildcard entry for unknown commands'})})});function Al(s,e){return e.filter(t=>new RegExp(`\\b${t}\\b`).test(s)).length}function gg(s,e){let t=(e.frontmatter?.description||"").toLowerCase(),n=e.content.toLowerCase(),r=e.frontmatter?.["allowed-tools"]||[],o=`${s} ${t} ${n}`,i=Al(o,TP),a=Al(o,EP),c=Al(o,AP);return r.some(d=>RP.includes(d))&&i>0?{agents:!0,patterns:!0,checklist:c>0,modules:[]}:c>0&&c>=a?{agents:!1,patterns:!0,checklist:!0,modules:[]}:a>0&&i===0?{agents:!1,patterns:!1,checklist:!1,modules:[]}:{agents:!0,patterns:!0,checklist:!1,modules:[]}}var TP,EP,AP,RP,fg=k(()=>{"use strict";TP=["build","create","add","implement","fix","refactor","update","modify","change","write","generate","scaffold","migrate","optimize","improve","enhance","redesign","rewrite"],EP=["list","show","get","status","info","check","view","display","describe","explain","analyze","report","dashboard"],AP=["test","verify","validate","review","audit","check","lint","ship","deploy","release","complete","done","finish"],RP=["Write","Edit","Bash"];l(Al,"countMatches");l(gg,"classifyCommand")});import Rl from"node:fs/promises";import DP from"node:path";async function yg(){if(Wr)return Wr;let s=await Rl.readFile(Dl,"utf-8"),e=JSON.parse(s);return Wr=pg.parse(e),Wr}function jP(s){return wg.get(s)}function IP(s,e){wg.set(s,e)}function MP(s,e){let t=s,n=hg.get(t);return n&&FP(n.entry,e)?(n.count++,n.count>=$P):(hg.set(t,{entry:e,count:1}),!1)}async function OP(s,e){let t=await Rl.readFile(Dl,"utf-8"),n=JSON.parse(t);n.commands[s]=e,await Rl.writeFile(Dl,`${JSON.stringify(n,null,2)}
|
|
651
|
+
`,"utf-8"),Wr=null}function FP(s,e){return s.agents===e.agents&&s.patterns===e.patterns&&s.checklist===e.checklist&&s.modules.length===e.modules.length&&s.modules.every((t,n)=>t===e.modules[n])}function Sg(s,e,t){if(e in s.commands&&e!=="*")return{entry:s.commands[e],source:"config"};let n=jP(e);if(n)return{entry:n,source:"cache"};if(t){let r=gg(e,t);return IP(e,r),MP(e,r)&&OP(e,r).catch(()=>{}),{entry:r,source:"classified"}}return{entry:s.commands["*"],source:"wildcard"}}var Dl,Wr,wg,hg,$P,kg=k(()=>{"use strict";mg();Dt();fg();Dl=DP.join(ge,"core/config/command-context.config.json"),Wr=null;l(yg,"loadCommandContextConfig");wg=new Map;l(jP,"getCachedClassification");l(IP,"cacheClassification");hg=new Map,$P=3;l(MP,"trackClassification");l(OP,"persistClassification");l(FP,"isSameEntry");l(Sg,"resolveCommandContextFull")});import _P from"node:os";import{z as Zt}from"zod";function NP(){return typeof globalThis<"u"&&"Bun"in globalThis?"bun":"node"}function LP(s){return{darwin:"macOS",linux:"Linux",win32:"Windows",freebsd:"FreeBSD"}[s]??s}function bg(s){let e=s.platform??_P.platform(),t=s.runtime??NP(),n=s.date??new Date().toISOString().split("T")[0];return`<env>
|
|
652
|
+
${[["project",s.projectName],["path",s.projectPath],["git",s.isGitRepo?"true":"false"],["branch",s.gitBranch],["platform",LP(e)],["runtime",t],["date",n],["model",s.model],["provider",s.provider]].filter(([,i])=>i!==void 0).map(([i,a])=>`${i}: ${a}`).join(`
|
|
653
653
|
`)}
|
|
654
|
-
</env>`}var
|
|
655
|
-
... (truncated to ~${e} tokens)`}function
|
|
656
|
-
`);return
|
|
657
|
-
`),
|
|
658
|
-
`),
|
|
654
|
+
</env>`}var W_,vg=k(()=>{"use strict";W_=Zt.object({projectName:Zt.string(),projectPath:Zt.string(),isGitRepo:Zt.boolean().default(!0),gitBranch:Zt.string().optional(),platform:Zt.string().optional(),runtime:Zt.string().optional(),date:Zt.string().optional(),model:Zt.string().optional(),provider:Zt.string().optional()});l(NP,"detectRuntime");l(LP,"normalizePlatform");l(bg,"buildEnvironmentBlock")});function Cg(s){let e=s.getAllocationFor("injection");return{...Ci,totalPrompt:e}}function Qn(s,e){let t=e*xg;return s.length<=t?s:`${s.substring(0,t)}
|
|
655
|
+
... (truncated to ~${e} tokens)`}function Pg(s){return Math.ceil(s.length/xg)}function Tg(s,e){if(e.length===0||s.length===0)return s;let t=new Set;for(let n of e){let r=UP[n.toLowerCase()];if(r)for(let o of r)t.add(o);t.add(n.toLowerCase())}return s.filter(n=>{let r=`${n.name} ${n.content}`.toLowerCase();for(let o of t)if(r.includes(o))return!0;return!1})}var Ci,xg,UP,Pi,Eg=k(()=>{"use strict";Ci={autoContext:500,agentContent:400,skillContent:500,stateData:1e3,memories:600,totalPrompt:8e3};l(Cg,"budgetsFromCoordinator");xg=4;l(Qn,"truncateToTokenBudget");l(Pg,"estimateTokens");UP={frontend:["react","vue","svelte","css","html","ui","component","frontend","web","dom"],backend:["api","server","backend","endpoint","route","middleware","database","sql"],testing:["test","spec","jest","vitest","cypress","playwright","coverage","assert"],devops:["docker","ci","cd","deploy","kubernetes","terraform","pipeline","github-actions"],docs:["documentation","readme","guide","tutorial","markdown"],design:["design","ux","ui","figma","wireframe","layout","accessibility"]};l(Tg,"filterSkillsByDomains");Pi=class{static{l(this,"InjectionBudgetTracker")}used=0;budgets;constructor(e={}){this.budgets={...Ci,...e}}addSection(e,t){let n=Qn(e,t),r=Pg(n);if(this.used+r>this.budgets.totalPrompt){let o=this.budgets.totalPrompt-this.used;if(o<=0)return"";let i=Qn(n,o);return this.used+=Pg(i),i}return this.used+=r,n}get remaining(){return Math.max(0,this.budgets.totalPrompt-this.used)}get totalUsed(){return this.used}get config(){return this.budgets}}});import Ag from"node:fs/promises";import Zn from"node:path";var jl,HP,Rg,Dg=k(()=>{"use strict";Yt();L();We();Dt();cl();dg();kg();vg();Eg();El();qt();jl=class{static{l(this,"PromptBuilder")}_checklistsCache=null;_checklistsCacheTime=0;_checklistRoutingCache=null;_checklistRoutingCacheTime=0;_currentContext=null;_stateCache=new Map;_stateCacheTTL=5e3;_templateCache=new Map;TEMPLATE_CACHE_TTL_MS=6e4;_coordinator=null;async getTemplate(e){let t=this._templateCache.get(e),n=Date.now();if(t&&n-t.loadedAt<this.TEMPLATE_CACHE_TTL_MS)return t.content;try{if(await j(e)){let r=await Ag.readFile(e,"utf-8");return this._templateCache.set(e,{content:r,loadedAt:n}),r}}catch(r){C(r)||console.error(`Template loading warning: ${y(r)}`)}return null}clearTemplateCache(){this._templateCache.clear(),this._checklistsCache=null,this._checklistsCacheTime=0,this._checklistRoutingCache=null,this._checklistRoutingCacheTime=0}setCoordinator(e){this._coordinator=e}getCoordinator(){return this._coordinator}getEffectiveBudgets(){return this._coordinator?Cg(this._coordinator):Ci}resetContext(){this._currentContext=null}setContext(e){this._currentContext=e}async loadModule(e){let t=he(`global/modules/${e}`);if(t)return t;let n=Zn.join(ge,"templates/global/modules",e);return this.getTemplate(n)}getModulesForCommand(e,t){return t?t.modules:[]}async loadChecklists(){let e=Date.now();if(this._checklistsCache&&e-this._checklistsCacheTime<this.TEMPLATE_CACHE_TTL_MS)return this._checklistsCache;let t={};try{let n=vn("checklists/");if(n.length>0){for(let r of n)if(r.endsWith(".md")){let o=he(r);if(o){let i=Zn.basename(r,".md");t[i]=o}}}else{let r=Zn.join(ge,"templates","checklists");if(await j(r)){let o=(await Ag.readdir(r)).filter(i=>i.endsWith(".md"));for(let i of o){let a=i.replace(".md",""),c=Zn.join(r,i),u=await this.getTemplate(c);u&&(t[a]=u)}}}}catch(n){C(n)||console.error(`Checklist loading warning: ${y(n)}`)}return this._checklistsCache=t,this._checklistsCacheTime=e,t}async getProjectState(e){if(!e)return null;let t=this._stateCache.get(e);if(t&&Date.now()-t.timestamp<this._stateCacheTTL)return t.state;try{let[n,r]=await Promise.all([N.read(e),Ie.read(e)]),o={projectId:e,currentTask:n.currentTask,queue:r.tasks};return this._stateCache.set(e,{state:o,timestamp:Date.now()}),o}catch(n){if(C(n)||n instanceof SyntaxError)return null;throw n}}async buildInjectedContext(e){if(!e)return null;let t=await this.getProjectState(e);if(!t)return null;let n=[];if(n.push("## AUTO-INJECTED CONTEXT"),n.push(""),t.currentTask){let o=this.calculateElapsed(t.currentTask.startedAt);n.push(`**Current Task**: ${t.currentTask.description}`),n.push(`- Started: ${o} ago`)}else n.push("**Current Task**: None");if(n.push(""),t.queue.length>0){n.push(`**Queue**: ${t.queue.length} tasks pending`);let o=t.queue.slice(0,3);for(let i of o)n.push(`- [${i.priority}] ${i.description}`);t.queue.length>3&&n.push(`- ... and ${t.queue.length-3} more`)}n.push("");try{let o=await rl.detectPatterns(e);if(o.length>0){n.push("**Project Conventions**");for(let i of o.slice(0,3))n.push(`- ${i.description}`),i.suggestedAction&&n.push(` \u2192 ${i.suggestedAction}`);n.push("")}}catch(o){!C(o)&&!(o instanceof SyntaxError)&&console.error(`Outcome detection warning: ${y(o)}`)}n.push("---"),n.push("");let r=n.join(`
|
|
656
|
+
`);return Qn(r,this.getEffectiveBudgets().autoContext)}calculateElapsed(e){let t=new Date(e).getTime(),r=Date.now()-t,o=Math.floor(r/6e4),i=Math.floor(o/60),a=Math.floor(i/24);return a>0?`${a}d ${i%24}h`:i>0?`${i}h ${o%60}m`:`${o}m`}async loadChecklistRouting(){let e=Date.now();if(this._checklistRoutingCache&&e-this._checklistRoutingCacheTime<this.TEMPLATE_CACHE_TTL_MS)return this._checklistRoutingCache;let t=Zn.join(__dirname,"..","..","templates","agentic","checklist-routing.md"),n=await this.getTemplate(t);return n&&(this._checklistRoutingCache=n,this._checklistRoutingCacheTime=e),this._checklistRoutingCache||null}async buildWithInjection(e,t,n,r=null,o=null,i=null,a=null,c=null){let u=[];if(t.projectId){let m=await this.buildInjectedContext(t.projectId);m&&u.push(m)}let d=await this.build(e,t,n,r,o,i,a,c);return u.push(d),u.join("")}async build(e,t,n,r=null,o=null,i=null,a=null,c=null,u=null){let d=[];this._currentContext=t;let m=e.frontmatter?.name?.replace("p:","")||"",p;try{let P=await yg();p=Sg(P,m,e).entry}catch{p={agents:!0,patterns:!0,checklist:!1,modules:[]}}let g=p.agents;r&&g&&(d.push(`# AGENT: ${r.name}
|
|
657
|
+
`),r.role&&d.push(`Role: ${r.role}
|
|
658
|
+
`),r.skills?.length&&d.push(`Skills: ${r.skills.join(", ")}
|
|
659
659
|
`),d.push(`
|
|
660
660
|
Apply specialized expertise. Read agent file for details if needed.
|
|
661
661
|
|
|
662
662
|
`)),d.push(`TASK: ${e.frontmatter.description}
|
|
663
663
|
`),e.frontmatter["allowed-tools"]&&d.push(`TOOLS: ${e.frontmatter["allowed-tools"].join(", ")}
|
|
664
664
|
`);let f=t;(f.params?.task||f.params?.description)&&d.push(`INPUT: ${f.params.task||f.params.description}
|
|
665
|
-
`);let S=t.projectPath;if(S){let
|
|
665
|
+
`);let S=t.projectPath;if(S){let P=u?.project?.id?Zn.basename(S):Zn.basename(S),$=bg({projectName:P,projectPath:S,isGitRepo:!0,gitBranch:u?.realContext?.gitBranch});d.push(`
|
|
666
666
|
${$}
|
|
667
|
-
`)}if(u){let
|
|
667
|
+
`)}if(u){let P=u.sealedAnalysis;if(d.push(`
|
|
668
668
|
## PROJECT ANALYSIS (Sealed)
|
|
669
669
|
`),d.push(`**Ecosystem**: ${u.project.ecosystem}
|
|
670
670
|
`),d.push(`**Primary Domain**: ${u.primaryDomain}
|
|
671
671
|
`),d.push(`**Domains**: ${u.detectedDomains.join(", ")}
|
|
672
|
-
`),
|
|
673
|
-
`),
|
|
674
|
-
`),
|
|
675
|
-
`),
|
|
676
|
-
`),
|
|
677
|
-
`),d.push(`**Files Analyzed**: ${
|
|
678
|
-
`),d.push(`**Analysis Status**: ${
|
|
679
|
-
`),
|
|
672
|
+
`),P){if(P.languages?.length>0&&d.push(`**Languages**: ${P.languages.join(", ")}
|
|
673
|
+
`),P.frameworks?.length>0&&d.push(`**Frameworks**: ${P.frameworks.join(", ")}
|
|
674
|
+
`),P.packageManager&&d.push(`**Package Manager**: ${P.packageManager}
|
|
675
|
+
`),P.sourceDir&&d.push(`**Source Dir**: ${P.sourceDir}
|
|
676
|
+
`),P.testDir&&d.push(`**Test Dir**: ${P.testDir}
|
|
677
|
+
`),d.push(`**Files Analyzed**: ${P.fileCount}
|
|
678
|
+
`),d.push(`**Analysis Status**: ${P.status}${P.commitHash?` (commit: ${P.commitHash.slice(0,8)})`:""}
|
|
679
|
+
`),P.patterns?.length>0){d.push(`
|
|
680
680
|
### Code Patterns (Follow These)
|
|
681
|
-
`);for(let $ of
|
|
682
|
-
`)}if(
|
|
681
|
+
`);for(let $ of P.patterns)d.push(`- **${$.name}**: ${$.description}${$.location?` (${$.location})`:""}
|
|
682
|
+
`)}if(P.antiPatterns?.length>0){d.push(`
|
|
683
683
|
### Anti-Patterns (Avoid These)
|
|
684
|
-
`);for(let $ of
|
|
684
|
+
`);for(let $ of P.antiPatterns)d.push(`- **${$.issue}** in \`${$.file}\` \u2014 ${$.suggestion}
|
|
685
685
|
`)}}d.push(`
|
|
686
|
-
`)}let
|
|
687
|
-
`),d.push(
|
|
686
|
+
`)}let w=p.patterns,v=n?.codePatterns||"";if(w&&v&&v.trim()){let P=this.extractPatternSummary(v);P&&(d.push(`## CODE PATTERNS
|
|
687
|
+
`),d.push(P),d.push(`
|
|
688
688
|
Full patterns: Read analysis/patterns.md
|
|
689
|
-
`))}let
|
|
689
|
+
`))}let T=n?.analysis||"";if(w&&T&&T.trim()){let P=T.match(/Stack[:\s]+([^\n]+)/i)||T.match(/Technology[:\s]+([^\n]+)/i),$=P?P[1].trim():"detected";d.push(`
|
|
690
690
|
## STACK
|
|
691
691
|
Stack: ${$}
|
|
692
|
-
`),
|
|
692
|
+
`),v||d.push(`Read analysis/repo-summary.md + similar files before coding. Match patterns exactly.
|
|
693
693
|
`)}if(u){if(u.agents.length>0){d.push(`
|
|
694
694
|
### LOADED AGENTS (Project-Specific Specialists)
|
|
695
695
|
|
|
@@ -697,18 +697,18 @@ Stack: ${$}
|
|
|
697
697
|
`),$.effort&&d.push(`Effort: ${$.effort}
|
|
698
698
|
`),$.model&&d.push(`Model: ${$.model}
|
|
699
699
|
`),$.skills.length>0&&d.push(`Skills: ${$.skills.join(", ")}
|
|
700
|
-
`);let
|
|
701
|
-
${
|
|
700
|
+
`);let Fe=Qn($.content,this.getEffectiveBudgets().agentContent);d.push(`\`\`\`markdown
|
|
701
|
+
${Fe}
|
|
702
702
|
\`\`\`
|
|
703
703
|
|
|
704
|
-
`)}}let
|
|
704
|
+
`)}}let P=Tg(u.skills,u.detectedDomains);if(P.length>0){d.push(`### LOADED SKILLS (From Agent Frontmatter)
|
|
705
705
|
|
|
706
|
-
`);for(let $ of
|
|
707
|
-
`);let
|
|
708
|
-
${
|
|
706
|
+
`);for(let $ of P){d.push(`#### Skill: ${$.name}
|
|
707
|
+
`);let Fe=Qn($.content,this.getEffectiveBudgets().skillContent);d.push(`\`\`\`markdown
|
|
708
|
+
${Fe}
|
|
709
709
|
\`\`\`
|
|
710
710
|
|
|
711
|
-
`)}}}let
|
|
711
|
+
`)}}}let _=this.getModulesForCommand(m,p);if(_.length>0)for(let P of _){let $=await this.loadModule(P);$&&(d.push(`
|
|
712
712
|
`),d.push($))}if(c?.isPlanning&&(d.push(`
|
|
713
713
|
## PLAN MODE
|
|
714
714
|
Read-only. Gather info \u2192 Analyze \u2192 Propose plan \u2192 Wait for approval.
|
|
@@ -716,63 +716,63 @@ Read-only. Gather info \u2192 Analyze \u2192 Propose plan \u2192 Wait for approv
|
|
|
716
716
|
`)),c?.requiresApproval&&d.push(`
|
|
717
717
|
## APPROVAL REQUIRED
|
|
718
718
|
Show changes, list affected files, ask for confirmation.
|
|
719
|
-
`),S){let
|
|
720
|
-
${
|
|
721
|
-
`)}else d.push(this.buildCriticalRules());if(u?.contextDegradation?.level!=="full"&&u?.contextDegradation){let
|
|
719
|
+
`),S){let P=u?.sealedAnalysis,$=[...P?.frameworks||[],...Array.isArray(u?.project?.conventions)?u.project.conventions:[]],Fe={projectPath:S,language:u?.project?.ecosystem,framework:P?.frameworks?.[0],techStack:vi($),domains:this.extractDomains(n),fileCount:t.files?.length||t.filteredSize||0,availableAgents:u?.agents?.map(ir=>ir.name)||[],analysisLanguages:P?.languages||[],analysisFrameworks:P?.frameworks||[],analysisPackageManager:P?.packageManager};d.push(`
|
|
720
|
+
${ug(Fe)}
|
|
721
|
+
`)}else d.push(this.buildCriticalRules());if(u?.contextDegradation?.level!=="full"&&u?.contextDegradation){let P=u.contextDegradation;d.push(`
|
|
722
722
|
### CONTEXT DEGRADATION NOTICE
|
|
723
723
|
|
|
724
|
-
`),d.push(`**Level**: ${
|
|
725
|
-
`),d.push(`**Unavailable**: ${
|
|
724
|
+
`),d.push(`**Level**: ${P.level}
|
|
725
|
+
`),d.push(`**Unavailable**: ${P.failedTools.join(", ")}
|
|
726
726
|
`),d.push(`Some context tools failed. Explore the codebase manually for missing context.
|
|
727
727
|
|
|
728
|
-
`)}if(u?.realContext){let
|
|
728
|
+
`)}if(u?.realContext){let P=u.realContext;if(d.push(`
|
|
729
729
|
### CODEBASE CONTEXT
|
|
730
730
|
|
|
731
|
-
`),d.push(`**Git State**: Branch \`${
|
|
731
|
+
`),d.push(`**Git State**: Branch \`${P.gitBranch}\` | ${P.gitStatus}
|
|
732
732
|
|
|
733
|
-
`),
|
|
733
|
+
`),P.relevantFiles.length>0){d.push(`**Relevant Files** (scored by task relevance):
|
|
734
734
|
`),d.push(`| Score | File | Why |
|
|
735
735
|
`),d.push(`|-------|------|-----|
|
|
736
|
-
`);for(let $ of
|
|
736
|
+
`);for(let $ of P.relevantFiles.slice(0,8))d.push(`| ${$.score} | ${$.path} | ${$.reason} |
|
|
737
737
|
`);d.push(`
|
|
738
|
-
`)}if(
|
|
739
|
-
`);for(let $ of
|
|
738
|
+
`)}if(P.signatures.length>0){d.push(`**Code Signatures** (top files):
|
|
739
|
+
`);for(let $ of P.signatures)d.push(`\`\`\`typescript
|
|
740
740
|
// ${$.path}
|
|
741
741
|
${$.content}
|
|
742
742
|
\`\`\`
|
|
743
743
|
`);d.push(`
|
|
744
|
-
`)}if(
|
|
744
|
+
`)}if(P.recentFiles.length>0){d.push("**Recently Changed**: ");let $=P.recentFiles.slice(0,5).map(Fe=>`${Fe.path} (${Fe.lastChanged})`).join(", ");d.push(`${$}
|
|
745
745
|
|
|
746
|
-
`)}}let ne=t.files||[];if(ne.length>0){let
|
|
747
|
-
## FILES: ${ne.length} available. Top: ${
|
|
746
|
+
`)}}let ne=t.files||[];if(ne.length>0){let P=ne.slice(0,5).join(", ");d.push(`
|
|
747
|
+
## FILES: ${ne.length} available. Top: ${P}
|
|
748
748
|
`),d.push(`Read BEFORE modifying. Use Glob/Grep to find more.
|
|
749
749
|
|
|
750
750
|
`)}else S&&d.push(`
|
|
751
751
|
## PROJECT: ${S}
|
|
752
752
|
Read files before modifying.
|
|
753
753
|
|
|
754
|
-
`);let
|
|
754
|
+
`);let re=this.filterRelevantState(n);if(re&&(d.push(`
|
|
755
755
|
## PRJCT STATE (Project Management Data)
|
|
756
|
-
`),d.push(
|
|
756
|
+
`),d.push(re),d.push(`
|
|
757
757
|
`)),u?.velocityContext&&(d.push(`
|
|
758
758
|
### VELOCITY (Historical Estimation Data)
|
|
759
759
|
|
|
760
760
|
`),d.push(u.velocityContext),d.push(`
|
|
761
761
|
|
|
762
|
-
`)),o&&Object.keys(o).some(
|
|
762
|
+
`)),o&&Object.keys(o).some(P=>o[P])){d.push(`
|
|
763
763
|
## PROJECT DEFAULTS (apply automatically)
|
|
764
|
-
`);for(let[
|
|
764
|
+
`);for(let[P,$]of Object.entries(o))$&&d.push(`- ${P}: ${$}
|
|
765
765
|
`)}if(i?.plan&&i.plan.length>0){if(d.push(`
|
|
766
766
|
## THINK FIRST (reasoning from analysis)
|
|
767
767
|
`),i.conclusions&&i.conclusions.length>0){d.push(`Conclusions:
|
|
768
|
-
`);for(let
|
|
768
|
+
`);for(let P of i.conclusions)d.push(` \u2192 ${P}
|
|
769
769
|
`)}d.push(`Plan:
|
|
770
|
-
`);for(let
|
|
770
|
+
`);for(let P=0;P<i.plan.length;P++)d.push(` ${P+1}. ${i.plan[P]}
|
|
771
771
|
`);d.push(`Confidence: ${Math.round((i.confidence||.5)*100)}%
|
|
772
772
|
`)}if(a&&a.length>0){d.push(`
|
|
773
773
|
## CONTEXT (apply these)
|
|
774
|
-
`);for(let
|
|
775
|
-
`),
|
|
774
|
+
`);for(let P of a)d.push(`- **${P.title}**: ${P.content}
|
|
775
|
+
`),P.tags&&P.tags.length>0&&d.push(` Tags: ${P.tags.join(", ")}
|
|
776
776
|
`)}if(d.push(`
|
|
777
777
|
---
|
|
778
778
|
`),d.push(e.content),u?.requiresFragmentation&&u.subtasks){d.push(`
|
|
@@ -780,34 +780,34 @@ Read files before modifying.
|
|
|
780
780
|
|
|
781
781
|
`),d.push("**IMPORTANT**: Focus on the CURRENT subtask. Use `p. done` when complete to advance.\n\n"),d.push(`| # | Domain | Description | Status |
|
|
782
782
|
`),d.push(`|---|--------|-------------|--------|
|
|
783
|
-
`);for(let $ of u.subtasks){let
|
|
784
|
-
`)}let
|
|
785
|
-
**FOCUS ON SUBTASK #${
|
|
786
|
-
`),d.push(`Agent: ${
|
|
787
|
-
`),
|
|
788
|
-
`),
|
|
783
|
+
`);for(let $ of u.subtasks){let Fe=$.status==="in_progress"?"\u25B6\uFE0F **CURRENT**":$.status==="completed"?"\u2705 Done":$.status==="failed"?"\u274C Failed":"\u23F3 Pending";d.push(`| ${$.order} | ${$.domain} | ${$.description} | ${Fe} |
|
|
784
|
+
`)}let P=u.subtasks.find($=>$.status==="in_progress");if(P&&(d.push(`
|
|
785
|
+
**FOCUS ON SUBTASK #${P.order}**: ${P.description}
|
|
786
|
+
`),d.push(`Agent: ${P.agent} | Domain: ${P.domain}
|
|
787
|
+
`),P.dependsOn.length>0&&d.push(`Dependencies: ${P.dependsOn.join(", ")}
|
|
788
|
+
`),P.handoff)){let $=P.handoff;d.push(`
|
|
789
789
|
### Previous Subtask Handoff
|
|
790
790
|
|
|
791
791
|
`),d.push(`**From:** ${$.fromSubtask}
|
|
792
792
|
|
|
793
793
|
`),d.push(`**What was done:**
|
|
794
|
-
`);for(let
|
|
794
|
+
`);for(let Fe of $.whatWasDone)d.push(`- ${Fe}
|
|
795
795
|
`);if($.filesChanged.length>0){d.push(`
|
|
796
796
|
**Files changed:**
|
|
797
|
-
`);for(let
|
|
797
|
+
`);for(let Fe of $.filesChanged)d.push(`- \`${Fe.path}\` (${Fe.action})
|
|
798
798
|
`)}d.push(`
|
|
799
799
|
**Context for this subtask:**
|
|
800
800
|
${$.outputForNextAgent}
|
|
801
801
|
`)}d.push(`
|
|
802
|
-
`)}let
|
|
802
|
+
`)}let ke=this.getSchemaTypeForCommand(m);if(ke){let{renderSchemaForPrompt:P}=await Promise.resolve().then(()=>(yo(),Fd)),$=P(ke);$&&d.push(`
|
|
803
803
|
${$}
|
|
804
|
-
`)}if(p.checklist){let
|
|
804
|
+
`)}if(p.checklist){let P=await this.loadChecklistRouting(),$=await this.loadChecklists();P&&Object.keys($).length>0&&(d.push(`
|
|
805
805
|
## QUALITY CHECKLISTS
|
|
806
806
|
`),d.push(`Apply relevant checklists based on task. Read checklist-routing.md for guidance.
|
|
807
807
|
`),d.push(`Available: ${Object.keys($).join(", ")}
|
|
808
808
|
`),d.push(`Path: templates/checklists/{name}.md
|
|
809
809
|
`),d.push(`Use Read tool to load checklists you determine are relevant.
|
|
810
|
-
`))}return d.push(this.buildEfficiencyDirective()),d.join("")}filterRelevantState(e){if(!e||Object.keys(e).length===0)return null;let t=this.getEffectiveBudgets(),n=new
|
|
810
|
+
`))}return d.push(this.buildEfficiencyDirective()),d.join("")}filterRelevantState(e){if(!e||Object.keys(e).length===0)return null;let t=this.getEffectiveBudgets(),n=new Pi({totalPrompt:t.stateData}),r=["now","next","context","analysis","codePatterns"],o=[];for(let[i,a]of Object.entries(e))if(a&&a.trim()){let c=r.includes(i)?500:250,u=n.addSection(`### ${i}
|
|
811
811
|
${a}`,c);u&&o.push(u)}return o.length>0?o.join(`
|
|
812
812
|
|
|
813
813
|
`):null}buildAnalysis(e,t){let n=[];return n.push(`# Analyze: ${e}
|
|
@@ -821,10 +821,10 @@ ${a}`,c);u&&o.push(u)}return o.length>0?o.join(`
|
|
|
821
821
|
|
|
822
822
|
`),n.join("")}extractPatternSummary(e){if(!e)return null;let t=[],n=e.match(/## Conventions[\s\S]*?(?=##|$)/i);if(n){let a=n[0].split(`
|
|
823
823
|
`).filter(c=>c.includes(":")||c.startsWith("-")).slice(0,6).join(`
|
|
824
|
-
`);a&&t.push(a)}let
|
|
824
|
+
`);a&&t.push(a)}let r=e.match(/### High Priority[\s\S]*?(?=###|##|$)/i);if(r){let a=r[0].substring(0,300);t.push(`
|
|
825
825
|
Avoid:
|
|
826
826
|
${a}`)}let o=t.join(`
|
|
827
|
-
`);return
|
|
827
|
+
`);return Qn(o,200)||null}getSchemaTypeForCommand(e){return{task:"subtaskBreakdown",bug:"classification"}[e]??null}buildCriticalRules(){return`
|
|
828
828
|
## RULES (CRITICAL)
|
|
829
829
|
1. **READ FIRST**: Use Read tool BEFORE modifying any file. Never assume code structure.
|
|
830
830
|
2. **MATCH PATTERNS**: Follow existing style, architecture, naming, imports exactly.
|
|
@@ -841,7 +841,7 @@ Context: ${this._currentContext?.files?.length||this._currentContext?.filteredSi
|
|
|
841
841
|
- Prefer structured output (JSON) over free text when applicable.
|
|
842
842
|
|
|
843
843
|
EXECUTE: Follow flow. Use tools. Decide.
|
|
844
|
-
`}extractDomains(e){if(!e)return;let t=e;if(t.domains&&typeof t.domains=="object"){let n=t.domains;return{hasFrontend:n.hasFrontend??!1,hasBackend:n.hasBackend??!1,hasDatabase:n.hasDatabase??!1,hasTesting:n.hasTesting??!1,hasDocker:n.hasDocker??!1}}}},
|
|
844
|
+
`}extractDomains(e){if(!e)return;let t=e;if(t.domains&&typeof t.domains=="object"){let n=t.domains;return{hasFrontend:n.hasFrontend??!1,hasBackend:n.hasBackend??!1,hasDatabase:n.hasDatabase??!1,hasTesting:n.hasTesting??!1,hasDocker:n.hasDocker??!1}}}},HP=new jl,Rg=HP});import jg from"node:fs/promises";import It from"node:path";var GP,WP,Il,$l,xi,Ml=k(()=>{"use strict";Pt();ve();L();GP=["task","done","ship","resume","bug","enrich"],WP=["init","sync","pause","next","dash","history","undo","redo"],Il=class{static{l(this,"TemplateExecutor")}async getNpmRoot(){return It.dirname(fn.resolve("prjct-cli/package.json"))}async getProjectId(e){return M.getProjectId(e)}async buildContext(e,t,n){let r=await this.getProjectId(n),o=A.getGlobalProjectPath(r),a=await(qe(),ht(pt)).getActiveProvider(),c;try{let u=await this.getNpmRoot();c=It.join(u,"templates")}catch{c=It.join(__dirname,"..","..","templates")}return{projectPath:n,projectId:r,globalPath:o,command:e,args:t,agentName:a.displayName,agentSettingsPath:await A.getAgentSettingsPath(),paths:{orchestrator:It.join(c,"agentic","orchestrator.md"),agentRouting:It.join(c,"agentic","agent-routing.md"),taskFragmentation:It.join(c,"agentic","task-fragmentation.md"),commandTemplate:It.join(c,"commands",`${e}.md`),repoAnalysis:It.join(o,"analysis","repo-analysis.json"),agentsDir:It.join(o,"agents"),skillsDir:a.skillsDir,stateJson:It.join(o,"storage","state.json")}}}requiresOrchestration(e){return GP.includes(e)?!0:!WP.includes(e)}async hasAgents(e){try{let t=await this.getProjectId(e),n=It.join(A.getGlobalProjectPath(t),"agents");return(await jg.readdir(n)).some(o=>o.endsWith(".md"))}catch(t){return C(t),!1}}async getAvailableAgents(e){try{let t=await this.getProjectId(e),n=It.join(A.getGlobalProjectPath(t),"agents");return(await jg.readdir(n)).filter(o=>o.endsWith(".md")).map(o=>o.replace(".md",""))}catch{return[]}}buildAgenticPrompt(e){let t=this.requiresOrchestration(e.command);return{prompt:`
|
|
845
845
|
## Agentic Execution Mode
|
|
846
846
|
|
|
847
847
|
You are executing a prjct command as ${e.agentName}. Follow the template-first approach.
|
|
@@ -924,13 +924,13 @@ When fragmenting tasks:
|
|
|
924
924
|
2. Track progress: currentSubtaskIndex, subtaskProgress
|
|
925
925
|
3. Each completed subtask generates a summary
|
|
926
926
|
4. Pass summary to next agent for context handoff
|
|
927
|
-
`,context:e,requiresOrchestration:t}}}
|
|
928
|
-
`+
|
|
929
|
-
`+
|
|
930
|
-
`+
|
|
931
|
-
`+
|
|
932
|
-
`+
|
|
933
|
-
`}}
|
|
927
|
+
`,context:e,requiresOrchestration:t}}},$l=new Il,xi=$l});import{exec as zP}from"node:child_process";import Ig from"node:fs/promises";import{promisify as VP}from"node:util";var BP,es,rt,Ol=k(()=>{"use strict";Io();BP=VP(zP),es={tools:new Map,register(s,e){this.tools.set(s,e)},get(s){return this.tools.get(s)},isAllowed(s,e){return!e||e.length===0?!0:e.some(t=>t.endsWith("*")?s.startsWith(t.slice(0,-1)):s===t)},list(){return Array.from(this.tools.keys())}};es.register("Read",async s=>{try{return await vr.execute(async()=>await Ig.readFile(s,"utf-8"),`read-${s}`)}catch(e){return jo(e)||br(e),null}});es.register("Write",async(s,e)=>{try{return await vr.execute(async()=>await Ig.writeFile(s,e,"utf-8"),`write-${s}`),!0}catch(t){return jo(t)||br(t),!1}});es.register("Bash",async s=>{try{return await vr.execute(async()=>await BP(s),`bash-${s}`)}catch(e){let t=e;return{stdout:t.stdout||"",stderr:t.stderr||t.message||"Command failed"}}});es.register("GetTimestamp",async()=>new Date().toISOString());es.register("GetDate",async()=>new Date().toISOString().split("T")[0]);es.register("GetDateTime",async()=>new Date().toISOString());rt=es});import Fl from"node:fs/promises";import JP from"node:os";import _l from"node:path";function $g(){let s=process.env.PRJCT_CLI_HOME?.trim()||_l.join(JP.homedir(),".prjct-cli");return _l.join(s,".running")}async function qP(s){try{let e=$g(),t=_l.dirname(e);await j(t)||await Fl.mkdir(t,{recursive:!0}),await Fl.writeFile(e,`/p:${s}`)}catch{}}async function KP(){try{let s=$g();await j(s)&&await Fl.unlink(s)}catch{}}var Nl,XP,Ti,Ll=k(()=>{"use strict";L();bm();We();Cm();Tm();dl();Lm();Um();wr();xl();lg();Dg();Ml();qt();Ol();l($g,"getRunningFilePath");l(qP,"signalStart");l(KP,"signalEnd");Nl=class{static{l(this,"CommandExecutor")}async signalStart(e){await qP(e)}async signalEnd(){await KP()}async execute(e,t,n){await this.signalStart(e);let r=t.task||t.description||"";if(_s.shouldEscalate(e,r)){let o=_s.getEscalationInfo(e,r);return await this.signalEnd(),{success:!1,error:o?.message,escalation:o,isLoopDetected:!0,suggestion:o?.suggestion}}try{let o=await qa.load(e),i=await kt.build(n,t),a=Ue.requiresPlanning(e),c=Ue.isDestructive(e),u=Ue.isInPlanningMode(i.projectId),d=null;a&&!u&&!t.skipPlanning?d=Ue.startPlanning(i.projectId,e,t):u&&(d=Ue.getActivePlan(i.projectId));let m=null;if(hi.requiresVerification(e)){let P=await kt.loadStateForCommand(i,e);m=await hi.verify(e,i,P),!m.verified&&m.warnings.length>0&&console.log(hi.formatWarnings(m))}let p=null;if(fi.requiresReasoning(e)){let P=await kt.loadStateForCommand(i,e);p=await fi.reason(e,i,P),p.reasoning&&!p.reasoning.allPassed&&(console.log("\u26A0\uFE0F Chain of Thought detected issues:"),console.log(fi.formatPlan(p)))}let g=t.task||t.description||"",f=await xi.buildContext(e,g,n),S=xi.buildAgenticPrompt(f),w=null;if(xi.requiresOrchestration(e)&&g)try{w=await ki.execute(e,g,n),w.detectedDomains.length>0&&gi.orchestrate(w.detectedDomains);for(let P of w.agents){let $=P.domain||P.name.replace(".md","");gi.startAgent(P.name,$,`Loading ${$} specialist...`),gi.endAgent(!0)}if(w.requiresFragmentation&&w.subtasks){let P=w.subtasks.map($=>({id:$.id,domain:$.domain,description:$.description,status:$.status}));Pm(P)}}catch(P){console.warn(`\u26A0\uFE0F Orchestrator warning: ${y(P)}`)}let v={...i,agentsPath:f.paths.agentsDir,agentRoutingPath:f.paths.agentRouting,orchestratorPath:f.paths.orchestrator,taskFragmentationPath:f.paths.taskFragmentation,agenticDelegation:!0,agenticMode:!0},T=await kt.loadState(i),_=null,ne=null;i.projectId&&(_={commit_footer:await at.getSmartDecision(i.projectId,"commit_footer"),branch_naming:await at.getSmartDecision(i.projectId,"branch_naming"),test_before_ship:await at.getSmartDecision(i.projectId,"test_before_ship"),preferred_agent:await at.getSmartDecision(i.projectId,`preferred_agent_${e}`)},ne=await at.getRelevantMemories(i.projectId,{commandName:e,params:t},5));let re={isPlanning:a||u,requiresApproval:c&&!t.approved,active:d,allowedTools:Ue.getAllowedTools(u,o.frontmatter["allowed-tools"]||[])},ke=await Rg.build(o,v,T,null,_,null,ne,re,w);return console.log("\u{1F916} Template-first execution: Claude reads templates and decides"),S.requiresOrchestration&&console.log(` \u2192 Orchestration: ${f.paths.orchestrator}`),_s.recordSuccess(e,r),await this.signalEnd(),{success:!0,template:o,context:v,state:T,prompt:ke,agenticDelegation:!0,agenticMode:!0,agenticExecContext:f,agenticPrompt:S.prompt,requiresOrchestration:S.requiresOrchestration,agentsPath:v.agentsPath,agentRoutingPath:v.agentRoutingPath,orchestratorPath:f.paths.orchestrator,taskFragmentationPath:f.paths.taskFragmentation,reasoning:p,groundTruth:m,learnedPatterns:_,relevantMemories:ne,orchestratorContext:w,memory:{create:l(P=>at.createMemory(i.projectId,P),"create"),autoRemember:l((P,$,Fe)=>at.autoRemember(i.projectId,P,$,Fe),"autoRemember"),search:l(P=>at.searchMemories(i.projectId,P),"search"),findByTags:l(P=>at.findByTags(i.projectId,P),"findByTags"),getStats:l(()=>at.getMemoryStats(i.projectId),"getStats")},plan:{active:d,isPlanning:a||u,isDestructive:c,requiresApproval:c&&!t.approved,recordInfo:l(P=>Ue.recordGatheredInfo(i.projectId,P),"recordInfo"),setAnalysis:l(P=>Ue.setAnalysis(i.projectId,P),"setAnalysis"),propose:l(P=>Ue.proposePlan(i.projectId,P),"propose"),approve:l(P=>Ue.approvePlan(i.projectId,P),"approve"),reject:l(P=>Ue.rejectPlan(i.projectId,P),"reject"),getApprovalPrompt:l(()=>Ue.generateApprovalPrompt(e,{changedFiles:[],filesToDelete:[],operation:e==="ship"?"git_push":e==="cleanup"?"delete_files":"run_command",warnings:[]}),"getApprovalPrompt"),startExecution:l(()=>Ue.startExecution(i.projectId),"startExecution"),getNextStep:l(()=>Ue.getNextStep(i.projectId),"getNextStep"),completeStep:l(P=>Ue.completeStep(i.projectId,P),"completeStep"),failStep:l(P=>Ue.failStep(i.projectId,P),"failStep"),abort:l(P=>Ue.abortPlan(i.projectId,P),"abort"),getStatus:l(()=>Ue.formatStatus(i.projectId),"getStatus"),getAllowedTools:l(()=>Ue.getAllowedTools(u,o.frontmatter["allowed-tools"]||[]),"getAllowedTools")}}}catch(o){await this.signalEnd();let i=_s.recordAttempt(e,r,{success:!1,error:y(o)});if(i.shouldEscalate){let a=_s.getEscalationInfo(e,r);return{success:!1,error:a?.message,escalation:a,isLoopDetected:!0,suggestion:a?.suggestion}}return{success:!1,error:y(o),attemptNumber:i.attemptNumber,isLooping:i.isLooping}}}async executeTool(e,t,n){if(!rt.isAllowed(e,n))throw new Error(`Tool ${e} not allowed for this command`);let r=rt.get(e);if(!r)throw new Error(`Tool ${e} not found`);return await r(...t)}async executeSimple(e,t,n){try{let o=(await qa.load(e)).frontmatter["allowed-tools"]||[],i=await kt.build(n);return{success:!0,result:await t({read:l(async u=>this.executeTool("Read",[u],o),"read"),write:l(async(u,d)=>this.executeTool("Write",[u,d],o),"write"),bash:l(async u=>this.executeTool("Bash",[u],o),"bash")},i)}}catch(r){return{success:!1,error:y(r)}}}},XP=new Nl,Ti=XP});import Ei from"node:fs/promises";import YP from"node:https";import QP from"node:os";import Ul from"node:path";import Gt from"chalk";var Hl,Ai,Gl=k(()=>{"use strict";L();We();Hl=class{static{l(this,"UpdateChecker")}packageName;cacheDir;cacheFile;checkInterval;constructor(){this.packageName="prjct-cli",this.cacheDir=Ul.join(QP.homedir(),".prjct-cli","config"),this.cacheFile=Ul.join(this.cacheDir,"update-cache.json"),this.checkInterval=1440*60*1e3}async getCurrentVersion(){try{let e=Ul.join(__dirname,"..","..","package.json");return JSON.parse(await Ei.readFile(e,"utf8")).version}catch(e){return console.error("Error reading package version:",y(e)),null}}async getLatestVersion(){return new Promise((e,t)=>{let n={hostname:"registry.npmjs.org",path:`/${this.packageName}/latest`,method:"GET",headers:{"User-Agent":"prjct-cli-update-checker",Accept:"application/json"}},r=YP.request(n,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 n=e.split(".").map(Number),r=t.split(".").map(Number);for(let o=0;o<3;o++){let i=n[o]||0,a=r[o]||0;if(i>a)return 1;if(i<a)return-1}return 0}async readCache(){try{if(await j(this.cacheFile))return JSON.parse(await Ei.readFile(this.cacheFile,"utf8"))}catch{}return null}async writeCache(e){try{await j(this.cacheDir)||await Ei.mkdir(this.cacheDir,{recursive:!0}),await Ei.writeFile(this.cacheFile,JSON.stringify(e,null,2),"utf8")}catch{}}async checkForUpdates(){try{let e=await this.getCurrentVersion();if(!e)return null;let t=await this.readCache(),n=Date.now();if(t?.lastCheck&&n-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:n,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:`
|
|
928
|
+
`+Gt.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")+`
|
|
929
|
+
`+Gt.yellow("\u2502")+" "+Gt.bold("Update available!")+" "+Gt.dim(`${e.currentVersion} \u2192 ${e.latestVersion}`)+" "+Gt.yellow("\u2502")+`
|
|
930
|
+
`+Gt.yellow("\u2502")+" "+Gt.yellow("\u2502")+`
|
|
931
|
+
`+Gt.yellow("\u2502")+" Run: "+Gt.cyan("npm update -g prjct-cli")+" "+Gt.yellow("\u2502")+`
|
|
932
|
+
`+Gt.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")+`
|
|
933
|
+
`}},Ai=Hl});var Ce,lt=k(()=>{"use strict";Ll();dl();Ol();Pt();ve();Gl();ln();ce();We();Bn();Ce=class{static{l(this,"PrjctCommandsBase")}prjctDir;updateChecker;updateNotificationShown;commandExecutor;constructor(){this.prjctDir=".prjct",this.updateChecker=new Ai,this.updateNotificationShown=!1,this.commandExecutor=Ti}get agent(){return Ps.getAgent()}get agentInfo(){return Ps.getInfo()}get currentAuthor(){return Dn.getCurrentAuthor()}async initializeAgent(){return Ps.initialize()}async ensureProjectInit(e){return Dn.ensureInit(e)}async ensureAuthor(){return Dn.ensureAuthor()}async getGlobalProjectPath(e){return Dn.getGlobalPath(e)}async logToMemory(e,t,n){let r=await this.ensureAuthor();return yt.log(e,t,n,r.name)}async _detectEmptyDirectory(e){return Dn.isEmptyDirectory(e)}async _detectExistingCode(e){return Dn.hasExistingCode(e)}_breakdownFeatureTasks(e){return Gn.breakdownFeature(e)}_detectBugSeverity(e){return Gn.detectBugSeverity(e)}async _assignAgentForTask(e,t,n){return Ps.assignForTask(e,t,n)}}});var Mg={};hn(Mg,{PlanningCommands:()=>ns});import ts from"node:path";async function ZP(){if(!Wl){let{AnalysisCommands:s}=await Promise.resolve().then(()=>(Di(),Og));Wl=new s}return Wl}var Wl,ns,Ri=k(()=>{"use strict";Mo();on();Rt();Yt();Or();L();$s();Ms();nl();cl();lt();Wl=null;l(ZP,"getAnalysisCommands");ns=class extends Ce{static{l(this,"PlanningCommands")}async init(e={},t=process.cwd()){try{let n={};if(typeof e=="string"||e===null?n={idea:e}:n=e,await this.initializeAgent(),await M.isConfigured(t))return h.warn("already initialized"),{success:!1,message:"Already initialized"};let o=process.stdout.isTTY&&process.stdin.isTTY,i=n.yes||!o||process.env.CI==="true",a=null;if(i)o&&n.yes&&(a=await new Fs(t).runNonInteractive());else if(a=await new Fs(t).run(),a.skipped)return{success:!1,message:"Setup cancelled"};h.step(1,4,"Detecting author...");let c=await vs(),u={name:c.name||void 0,email:c.email||void 0,github:c.github||void 0},m=(await M.createConfig(t,u)).projectId;h.step(2,4,"Creating structure..."),await A.ensureProjectStructure(m);let p=A.getGlobalProjectPath(m);await this._seedShipWorkflow(m,t);let g={"core/now.md":`# NOW
|
|
934
934
|
|
|
935
935
|
No current task. Use \`/p:now\` to set focus.
|
|
936
936
|
`,"core/next.md":`# NEXT
|
|
@@ -950,17 +950,17 @@ No current task. Use \`/p:now\` to set focus.
|
|
|
950
950
|
`,"planning/roadmap.md":`# ROADMAP
|
|
951
951
|
|
|
952
952
|
`,"planning/specs/.gitkeep":`# Specs directory - created by /p:spec
|
|
953
|
-
`,"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[
|
|
953
|
+
`,"memory/context.jsonl":"","memory/patterns.json":JSON.stringify({version:1,decisions:{},preferences:{},workflows:{},counters:{}},null,2)};a&&(g["config/wizard.json"]=JSON.stringify({projectType:a.projectType,agents:a.agents,stack:a.stack,preferences:a.preferences,createdAt:new Date().toISOString()},null,2));for(let[v,T]of Object.entries(g))await rt.get("Write")(ts.join(p,v),T);let f=await this._detectEmptyDirectory(t),S=await this._detectExistingCode(t);if(S||!f){h.step(3,4,"Analyzing project...");let v=await ZP();if((await v.analyze({},t)).success)return h.step(4,4,"Generating agents..."),a?.agents?await v.sync(t,{aiTools:a.agents}):await v.sync(t),h.done("initialized"),this._printNextSteps(a),{success:!0,mode:"existing",projectId:m,wizard:a}}let w=n.idea;if(f&&!S){if(!w)return h.done("blank project - provide idea for architect mode"),{success:!0,mode:"blank_no_idea",projectId:m,wizard:a};h.spin("architect mode...");let v=ts.join(p,"planning","architect-session.md"),T=`# Architect Session
|
|
954
954
|
|
|
955
955
|
## Idea
|
|
956
|
-
${
|
|
956
|
+
${w}
|
|
957
957
|
|
|
958
958
|
## Status
|
|
959
959
|
Initialized - awaiting stack recommendation
|
|
960
960
|
|
|
961
961
|
Generated: ${new Date().toLocaleString()}
|
|
962
|
-
`;return await rt.get("Write")(
|
|
963
|
-
`);let
|
|
962
|
+
`;return await rt.get("Write")(v,T),await je.installGlobalConfig(),h.done("architect mode ready"),{success:!0,mode:"architect",projectId:m,idea:w,wizard:a}}return await je.installGlobalConfig(),h.done("initialized"),this._printNextSteps(a),{success:!0,projectId:m,wizard:a}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}_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(n=>{switch(n){case"claude":return"CLAUDE.md";case"cursor":return".cursorrules";case"windsurf":return".windsurfrules";case"copilot":return".github/copilot-instructions.md";case"gemini":return"GEMINI.md";case"codex":return"AGENTS.md";default:return null}}).filter(Boolean);t.length>0&&(console.log(` Generated: ${t.join(", ")}`),console.log(""))}console.log(" Docs: https://prjct.app/docs"),console.log("")}async feature(e,t=process.cwd()){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;if(!e)return h.fail("description required"),{success:!1,error:"Description required"};let r=await M.getProjectId(t);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};h.spin(`planning ${e}...`);let o=await kt.build(t,{description:e}),i=this._breakdownFeatureTasks(e),a=me(),c=[];for(let m of i){let g=(await this._assignAgentForTask(m,t,o)).agent?.name||"generalist";c.push({task:m,agent:g})}await Ie.addTasks(r,c.map(m=>({description:m.task,priority:"medium",type:"feature",section:"active",featureId:a,originFeature:e,agent:m.agent}))),await this.logToMemory(t,"feature_planned",{feature:e,featureId:a,tasks:c.length,assignments:c.map(m=>({task:m.task,agent:m.agent})),timestamp:B.getTimestamp()});let u=c.reduce((m,p)=>(m[p.agent]=(m[p.agent]||0)+1,m),{}),d=Object.entries(u).map(([m,p])=>`${m}:${p}`).join(" ");return h.done(`${i.length} tasks [${d}]`),{success:!0,feature:e,featureId:a,tasks:c}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}async bug(e,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;if(!e)return n.md||h.fail("bug description required"),{success:!1,error:"Description required"};let o=await M.getProjectId(t);if(!o)return n.md||h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};n.md||h.spin("tracking bug...");let i=await kt.build(t,{description:e}),a=this._detectBugSeverity(e),u=(await this._assignAgentForTask(`fix bug: ${e}`,t,i)).agent?.name||"generalist",m={critical:"critical",high:"high",medium:"medium",low:"low"}[a]||"medium";return await Ie.addTask(o,{description:`\u{1F41B} ${e}`,priority:m,type:"bug",section:"active",agent:u}),await this.logToMemory(t,"bug_reported",{bug:e,severity:a,priority:m,agent:u,timestamp:B.getTimestamp()}),n.md?console.log(U(ee("Bug Reported",e),St({Severity:a,Priority:m,Agent:u}),de([{label:"Fix now",command:`prjct task "fix: ${e}" --md`},{label:"View queue",command:"prjct next --md"}]))):(h.done(`bug [${a}] \u2192 ${u}`),Tt("bug")),{success:!0,bug:e,severity:a,agent:u}}catch(r){return n.md||h.fail(y(r)),{success:!1,error:y(r)}}}async architect(e="execute",t=process.cwd()){if(e!=="execute")return{success:!1,message:"\u274C Invalid action. Use: /p:architect execute"};try{let n=await this.ensureProjectInit(t);if(!n.success)return n;console.log(`\u{1F3D7}\uFE0F Architect Mode - Code Generation
|
|
963
|
+
`);let r=await this.getGlobalProjectPath(t),o=ts.join(r,"planning","architect-session.md"),i;try{i=await Te.readFile(o)}catch{return{success:!1,message:`\u274C No architect plan found.
|
|
964
964
|
|
|
965
965
|
Create a plan first:
|
|
966
966
|
1. Run /p:init in an empty directory
|
|
@@ -981,7 +981,7 @@ The architect plan is ready. Claude will now:
|
|
|
981
981
|
4. Create starter files with boilerplate
|
|
982
982
|
`),console.log(`
|
|
983
983
|
\u{1F4A1} This command shows the plan.`),console.log(" For code generation, Claude Code will read this plan"),console.log(` and generate the structure automatically.
|
|
984
|
-
`),await this.logToMemory(t,"architect_executed",{timestamp:
|
|
984
|
+
`),await this.logToMemory(t,"architect_executed",{timestamp:B.getTimestamp(),idea:d}),{success:!0,plan:i,idea:d}}catch(n){return console.error("\u274C Error:",y(n)),{success:!1,error:y(n)}}}async idea(e,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;if(!e)return n.md||h.fail("idea description required"),{success:!1,error:"Idea description required"};let o=await M.getProjectId(t);if(!o)return n.md||h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(e.split(/\s+/).length>20||e.includes("with")||e.includes("that")){n.md||h.spin("analyzing idea...");let c=A.getGlobalProjectPath(o),u=ts.join(c,"planning","architect-session.md"),d=`# Architect Session
|
|
985
985
|
|
|
986
986
|
## Idea
|
|
987
987
|
${e}
|
|
@@ -996,14 +996,14 @@ Initialized - awaiting architecture design
|
|
|
996
996
|
4. Generate roadmap
|
|
997
997
|
|
|
998
998
|
Generated: ${new Date().toLocaleString()}
|
|
999
|
-
`;return await rt.get("Write")(u,d),await this.logToMemory(t,"idea_architecture_started",{idea:e,timestamp:
|
|
999
|
+
`;return await rt.get("Write")(u,d),await this.logToMemory(t,"idea_architecture_started",{idea:e,timestamp:B.getTimestamp()}),n.md?console.log(U(ee("Idea Captured",e),St({Mode:"architecture"}),de([{label:"Continue planning",command:"prjct architect execute"}]))):(h.done("architecture session created"),console.log(`
|
|
1000
1000
|
\u{1F4A1} Use /p:architect execute to continue planning
|
|
1001
|
-
`)),{success:!0,mode:"architecture",idea:e}}else return n.md||h.spin("capturing idea..."),await tt.addIdea(o,e),await this.logToMemory(t,"idea_captured",{idea:e,timestamp:
|
|
1001
|
+
`)),{success:!0,mode:"architecture",idea:e}}else return n.md||h.spin("capturing idea..."),await tt.addIdea(o,e),await this.logToMemory(t,"idea_captured",{idea:e,timestamp:B.getTimestamp()}),n.md?console.log(U(ee("Idea Captured",e),St({Mode:"capture"}),de([{label:"Start working on it",command:`prjct task "${e}" --md`},{label:"View ideas",command:"prjct dash ideas"}]))):(h.done(`idea captured: ${e.slice(0,40)}`),Tt("idea")),{success:!0,mode:"capture",idea:e}}catch(r){return n.md||h.fail(y(r)),{success:!1,error:y(r)}}}async spec(e=null,t=process.cwd()){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let r=await M.getProjectId(t);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(!e){h.spin("loading specs...");let d=A.getGlobalProjectPath(r),m=ts.join(d,"planning","specs");try{let f=(await(await import("node:fs/promises")).readdir(m)).filter(S=>S.endsWith(".md")&&S!==".gitkeep");return f.length===0?(h.warn("no specs yet"),console.log(`
|
|
1002
1002
|
\u{1F4A1} Create one with /p:spec "feature name"
|
|
1003
1003
|
`),{success:!0,specs:[]}):(console.log(`
|
|
1004
1004
|
\u{1F4CB} SPECIFICATIONS
|
|
1005
|
-
`),console.log("\u2550".repeat(50)),f.forEach((S,
|
|
1006
|
-
`),{success:!0,specs:f})}catch{return h.warn("no specs directory"),{success:!0,specs:[]}}}h.spin("creating spec...");let o=A.getGlobalProjectPath(
|
|
1005
|
+
`),console.log("\u2550".repeat(50)),f.forEach((S,w)=>{let v=S.replace(".md","").replace(/-/g," ");console.log(` ${w+1}. ${v}`)}),console.log(`${"\u2550".repeat(50)}
|
|
1006
|
+
`),{success:!0,specs:f})}catch{return h.warn("no specs directory"),{success:!0,specs:[]}}}h.spin("creating spec...");let o=A.getGlobalProjectPath(r),i=ts.join(o,"planning","specs");await Te.ensureDir(i);let a=e.toLowerCase().replace(/\s+/g,"-"),c=ts.join(i,`${a}.md`),u=`# Specification: ${e}
|
|
1007
1007
|
|
|
1008
1008
|
## Overview
|
|
1009
1009
|
[Brief description of the feature]
|
|
@@ -1033,19 +1033,19 @@ Generated: ${new Date().toLocaleString()}
|
|
|
1033
1033
|
---
|
|
1034
1034
|
Created: ${new Date().toLocaleString()}
|
|
1035
1035
|
Status: Draft
|
|
1036
|
-
`;return await rt.get("Write")(c,u),await this.logToMemory(t,"spec_created",{feature:e,timestamp:
|
|
1037
|
-
\u{1F4DD} Edit: ~/.prjct-cli/projects/${
|
|
1038
|
-
`),{success:!0,feature:e,specPath:c}}catch(n){return h.fail(
|
|
1039
|
-
`).filter(Boolean):[],
|
|
1040
|
-
`)}async getSessionInfo(e){return
|
|
1041
|
-
`);t.push(`Session: \u25B6 Active (${e.duration})`);let n=[];if(e.commandCount>0){let
|
|
1042
|
-
`)}getWarning(e){return e.isStale?e.commitsSinceSync>0?`\u26A0\uFE0F Context stale (${e.commitsSinceSync} commits behind). Run \`prjct sync\``:e.daysSinceSync>0?`\u26A0\uFE0F Context stale (${e.daysSinceSync} days old). Run \`prjct sync\``:"\u26A0\uFE0F Context may be stale. Run `prjct sync`":null}},qr=l((r,e)=>new Fi(r,e),"createStalenessChecker")});import tf from"node:fs/promises";import Ni from"node:path";function Hs(r){return r.replace(/([a-z])([A-Z])/g,"$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g,"$1 $2").replace(/[-_./]/g," ").toLowerCase().split(/\s+/).filter(e=>e.length>1)}function wC(r,e){let t=[],n=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let p of n)t.push(...Hs(p));let s=[/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 s){let g;for(;(g=p.exec(r))!==null;)g[1]&&t.push(...Hs(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(r))!==null;)g[1]&&t.push(...Hs(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(r))!==null;){let p=a[1];if(p.startsWith(".")||p.startsWith("@/"))t.push(...Hs(p));else{let g=p.startsWith("@")?p.split("/").slice(0,2).join("/"):p.split("/")[0];t.push(...Hs(g))}}let c=/\/\/\s*(.+)/g,u;for(;(u=c.exec(r))!==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(r))!==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&&!nf.has(p)&&/^[a-z][a-z0-9]*$/.test(p))}function SC(r){return r.split(/\s+/).flatMap(e=>Hs(e)).filter(e=>e.length>1&&!nf.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function sf(r,e){let t=[],n=await tf.readdir(r,{withFileTypes:!0});for(let s of n){if(yC.has(s.name))continue;let o=Ni.join(r,s.name);if(s.isDirectory())t.push(...await sf(o,e));else if(s.isFile()){let i=Ni.extname(s.name).toLowerCase();hC.has(i)&&t.push(Ni.relative(e,o))}}return t}async function kC(r){let e=await sf(r,r),t={},n={},s=0,o=50;for(let a=0;a<e.length;a+=o){let c=e.slice(a,a+o),u=await Promise.all(c.map(async d=>{try{let m=await tf.readFile(Ni.join(r,d),"utf-8"),p=wC(m,d);return{filePath:d,tokens:p}}catch{return{filePath:d,tokens:[]}}}));for(let{filePath:d,tokens:m}of u){if(m.length===0)continue;t[d]={tokens:m,length:m.length},s+=m.length;let p=new Map;for(let g of m)p.set(g,(p.get(g)||0)+1);for(let[g,f]of p)n[g]||(n[g]=[]),n[g].push({path:d,tf:f})}}let i=Object.keys(t).length;return{documents:t,invertedIndex:n,avgDocLength:i>0?s/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function bC(r,e){return Math.log((e-r+.5)/(r+.5)+1)}function vC(r,e){let t=SC(r);if(t.length===0)return[];let n=new Map;for(let s of t){let o=e.invertedIndex[s];if(!o)continue;let i=bC(o.length,e.totalDocs);for(let{path:a,tf:c}of o){let u=e.documents[a];if(!u)continue;let d=c*(Zg+1),m=c+Zg*(1-ef+ef*(u.length/e.avgDocLength)),p=i*(d/m);n.set(a,(n.get(a)||0)+p)}}return Array.from(n.entries()).map(([s,o])=>({path:s,score:o})).sort((s,o)=>o.score-s.score)}function PC(r,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([n,s])=>[n,s.length]))};G.setDoc(r,rf,t)}function CC(r){let e=G.getDoc(r,rf);if(!e)return null;let t={};for(let[n,s]of Object.entries(e.docLengths))t[n]={tokens:[],length:s};return{documents:t,invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt}}async function of(r,e){let t=await kC(r);return PC(e,t),t}function af(r,e,t=15){let n=CC(r);return n?vC(e,n).slice(0,t):[]}var Zg,ef,hC,nf,yC,rf,su=k(()=>{"use strict";se();Zg=1.2,ef=.75,hC=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".go",".rs",".java",".cs",".rb",".php",".vue",".svelte"]),nf=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"]),yC=new Set(["node_modules",".git","dist","build","out",".next","coverage",".cache",".turbo",".vercel","__pycache__","vendor","target"]);l(Hs,"splitIdentifier");l(wC,"tokenizeFile");l(SC,"tokenizeQuery");l(sf,"listFiles");l(kC,"buildIndex");l(bC,"idf");l(vC,"score");rf="bm25-index";l(PC,"saveIndex");l(CC,"loadIndex");l(of,"indexProject");l(af,"queryFiles")});import ru from"node:fs/promises";import fn from"node:path";function IC(r){let e=[],t,n=new RegExp(AC.source,"g");for(;(t=n.exec(r))!==null;){let s=t[1];(s.startsWith(".")||s.startsWith("@/"))&&e.push(s)}return e}async function RC(r,e,t){let n;if(r.startsWith("@/"))n=fn.join(t,"src",r.slice(2));else{let s=fn.dirname(fn.join(t,e));n=fn.resolve(s,r)}for(let s of EC){let o=n+s;try{if((await ru.stat(o)).isFile())return fn.relative(t,o)}catch{}}return null}async function cf(r,e){let t=[],n=await ru.readdir(r,{withFileTypes:!0});for(let s of n){if(TC.has(s.name))continue;let o=fn.join(r,s.name);if(s.isDirectory())t.push(...await cf(o,e));else if(s.isFile()){let i=fn.extname(s.name).toLowerCase();xC.has(i)&&t.push(fn.relative(e,o))}}return t}async function DC(r){let e=await cf(r,r),t={},n={},s=0,o=50;for(let i=0;i<e.length;i+=o){let a=e.slice(i,i+o),c=await Promise.all(a.map(async u=>{try{let d=await ru.readFile(fn.join(r,u),"utf-8"),m=IC(d),p=[];for(let g of m){let f=await RC(g,u,r);f&&f!==u&&p.push(f)}return{filePath:u,imports:p}}catch{return{filePath:u,imports:[]}}}));for(let{filePath:u,imports:d}of c)if(d.length!==0){t[u]=d,s+=d.length;for(let m of d)n[m]||(n[m]=[]),n[m].push(u)}}return{forward:t,reverse:n,fileCount:e.length,edgeCount:s,builtAt:new Date().toISOString()}}function jC(r,e){G.setDoc(r,lf,e)}function uf(r){return G.getDoc(r,lf)}async function df(r,e){let t=await DC(r);return jC(e,t),t}var xC,TC,EC,AC,lf,ou=k(()=>{"use strict";se();xC=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]),TC=new Set(["node_modules",".git","dist","build","out",".next","coverage",".cache",".turbo",".vercel"]),EC=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],AC=/(?:import|from)\s+['"]([^'"]+)['"]/g;l(IC,"extractImportSources");l(RC,"resolveImport");l(cf,"listFiles");l(DC,"buildGraph");lf="import-graph";l(jC,"saveGraph");l(uf,"loadGraph");l(df,"indexImports")});function pf(r,e){let t=[...r.added,...r.modified],n=new Set(t),s=new Set,o=uf(e);if(o)for(let c of t){let u=o.reverse[c];if(u)for(let d of u)n.has(d)||s.add(d)}let i=Array.from(s),a=[...t,...i];return{directlyChanged:t,affectedByImports:i,deleted:r.deleted,allAffected:a}}function mf(r){let e=new Set;for(let t of r){let n=t.toLowerCase();(n.endsWith(".tsx")||n.endsWith(".jsx")||n.endsWith(".css")||n.endsWith(".scss")||n.endsWith(".vue")||n.endsWith(".svelte")||n.includes("/components/")||n.includes("/pages/")||n.includes("/app/"))&&(e.add("frontend"),e.add("uxui")),(n.includes(".test.")||n.includes(".spec.")||n.includes("__tests__")||n.includes("/test/"))&&e.add("testing"),(n.includes("dockerfile")||n.includes("docker-compose")||n.includes(".dockerignore")||n.includes(".github/")||n.includes("ci/")||n.includes("cd/"))&&e.add("devops"),(n.endsWith(".sql")||n.includes("prisma")||n.includes("drizzle")||n.includes("migration")||n.includes("/db/"))&&e.add("database"),(n.endsWith(".ts")||n.endsWith(".js"))&&!n.includes(".test.")&&!n.includes(".spec.")&&!n.endsWith(".d.ts")&&e.add("backend")}return e}var gf=k(()=>{"use strict";ou();l(pf,"propagateChanges");l(mf,"affectedDomains")});import iu from"node:fs/promises";import Li from"node:path";async function ff(r,e){let t=[],n=await iu.readdir(r,{withFileTypes:!0}).catch(()=>[]);for(let s of n){let o=String(s.name);if(MC.has(o)||o.startsWith(".")&&o!==".env.example")continue;let i=Li.join(r,o);if(s.isDirectory())t.push(...await ff(i,e));else if(s.isFile()){let a=Li.extname(o).toLowerCase();$C.has(a)&&t.push(Li.relative(e,i))}}return t}function OC(r){if(typeof Bun<"u"&&Bun.hash)return`xxh64:${Bun.hash(r).toString(36)}`;let e=2166136261;for(let t=0;t<r.length;t++)e^=r.charCodeAt(t),e=Math.imul(e,16777619);return`fnv1a:${(e>>>0).toString(36)}`}async function _C(r){let e=await ff(r,r),t=new Map,n=100;for(let s=0;s<e.length;s+=n){let o=e.slice(s,s+n),i=await Promise.all(o.map(async a=>{try{let c=Li.join(r,a),[u,d]=await Promise.all([iu.readFile(c,"utf-8"),iu.stat(c)]);return{path:a,hash:OC(u),size:d.size,mtime:d.mtime.toISOString()}}catch{return null}}));for(let a of i)a&&t.set(a.path,a)}return t}function FC(r,e){let t=[],n=[],s=[];for(let[i,a]of r){let c=e.get(i);c?c.hash!==a.hash?n.push(i):s.push(i):t.push(i)}let o=[];for(let i of e.keys())r.has(i)||o.push(i);return{added:t,modified:n,deleted:o,unchanged:s}}function au(r,e){let t=G.getDb(r);t.transaction(()=>{t.prepare("DELETE FROM index_checksums").run();let n=t.prepare("INSERT INTO index_checksums (path, checksum, size, mtime) VALUES (?, ?, ?, ?)");for(let[,s]of e)n.run(s.path,s.hash,s.size,s.mtime)})(),G.setDoc(r,"file-hashes-meta",{fileCount:e.size,builtAt:new Date().toISOString()})}function NC(r){let e=new Map;try{let t=G.query(r,"SELECT path, checksum, size, mtime FROM index_checksums");for(let n of t)e.set(n.path,{path:n.path,hash:n.checksum,size:n.size||0,mtime:n.mtime||""})}catch{}return e}async function cu(r,e){let[t,n]=await Promise.all([_C(r),Promise.resolve(NC(e))]);return{diff:FC(t,n),currentHashes:t}}function hf(r){return G.hasDoc(r,"file-hashes-meta")}var $C,MC,yf=k(()=>{"use strict";se();$C=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".json",".md",".css",".scss",".html",".vue",".svelte",".py",".go",".rs",".yaml",".yml",".toml"]),MC=new Set(["node_modules",".git","dist","build","out",".next","coverage",".cache",".turbo",".vercel",".prjct"]);l(ff,"listProjectFiles");l(OC,"hashContent");l(_C,"computeHashes");l(FC,"diffHashes");l(au,"saveHashes");l(NC,"loadHashes");l(cu,"detectChanges");l(hf,"hasHashRegistry")});import{exec as LC}from"node:child_process";import{promisify as UC}from"node:util";async function zC(r,e=100){try{let{stdout:t}=await HC(`git log --name-only --pretty=format:'---COMMIT---' -${e}`,{cwd:r,maxBuffer:10485760}),n=[],s=null;for(let o of t.split(`
|
|
1043
|
-
`)){let i=o.trim();i==="---COMMIT---"?(
|
|
1036
|
+
`;return await rt.get("Write")(c,u),await this.logToMemory(t,"spec_created",{feature:e,timestamp:B.getTimestamp()}),h.done(`spec created: ${a}.md`),console.log(`
|
|
1037
|
+
\u{1F4DD} Edit: ~/.prjct-cli/projects/${r}/planning/specs/${a}.md`),console.log(`\u{1F4A1} When ready, use /p:feature to add tasks to queue
|
|
1038
|
+
`),{success:!0,feature:e,specPath:c}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}async _seedShipWorkflow(e,t){let n=await ci(t),r=0;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()}),n.lint&&Ee.addRule(e,{type:"step",command:"ship",position:"before",action:`${n.lint.command} || true`,description:"Lint code",enabled:!0,timeoutMs:12e4,sortOrder:r++,createdAt:new Date().toISOString()}),n.test&&Ee.addRule(e,{type:"step",command:"ship",position:"before",action:`${n.test.command} || true`,description:"Run tests",enabled:!0,timeoutMs:3e5,sortOrder:r++,createdAt:new Date().toISOString()})}}});var ji,Dn,Fg=k(()=>{"use strict";rn();Mo();Pt();ve();L();We();Bn();ji=class{static{l(this,"ProjectService")}currentAuthor=null;async ensureInit(e){if(await M.isConfigured(e))return{success:!0};h.spin("initializing project...");let{PlanningCommands:t}=await Promise.resolve().then(()=>(Ri(),Mg)),r=await new t().init(null,e);return r.success?{success:!0}:r}async getProjectId(e){let t=await M.getProjectId(e);if(!t)throw vo.notInitialized();return t}async getGlobalPath(e){let t=await this.getProjectId(e);return await A.ensureProjectStructure(t),A.getGlobalProjectPath(t)}async ensureAuthor(){if(this.currentAuthor)return this.currentAuthor;let e=await vs();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 sn(e)).filter(r=>!r.startsWith(".")&&r!=="node_modules"&&r!=="package.json"&&r!=="package-lock.json"&&r!=="README.md").length===0}catch(t){return C(t)||console.error(`Directory check error: ${y(t)}`),!0}}async hasExistingCode(e){try{let t=["src","lib","app","components","pages","api","main.go","main.rs","main.py"];return(await sn(e)).some(r=>t.includes(r))}catch(t){return C(t)||console.error(`Code check error: ${y(t)}`),!1}}async isConfigured(e){return await M.isConfigured(e)}async needsMigration(e){return await M.needsMigration(e)}},Dn=new ji});var eC,_g,Ng,zl,Lg,Ug=k(()=>{"use strict";oe();ce();eC=1800*1e3,_g=50,Ng=200,zl=class{static{l(this,"SessionTracker")}async read(e){try{return E.getDoc(e,"session-tracker")??this.getDefault()}catch{return this.getDefault()}}async write(e,t){E.setDoc(e,"session-tracker",t)}getDefault(){return{current:null,config:{idleTimeoutMs:eC}}}isExpired(e,t){let n=new Date(e.lastActivity).getTime();return Date.now()-n>t}async touch(e){let t=await this.read(e),n=b();if(t.current&&!this.isExpired(t.current,t.config.idleTimeoutMs))return t.current.lastActivity=n,await this.write(e,t),t.current;let r={id:crypto.randomUUID(),projectId:e,status:"active",createdAt:n,lastActivity:n,commands:[],files:[]};return t.current=r,await this.write(e,t),r}async trackCommand(e,t,n){let r=await this.read(e);if(!r.current)return;let o=b();r.current.lastActivity=o,r.current.commands.push({command:t,timestamp:o,durationMs:n}),r.current.commands.length>_g&&(r.current.commands=r.current.commands.slice(-_g)),await this.write(e,r)}async trackFile(e,t,n){let r=await this.read(e);if(!r.current)return;let o=b();r.current.lastActivity=o,r.current.files.push({path:t,operation:n,timestamp:o}),r.current.files.length>Ng&&(r.current.files=r.current.files.slice(-Ng)),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 n=t.current,r=Date.now(),o=new Date(n.createdAt).getTime(),i=new Date(n.lastActivity).getTime(),a=r-i,c=t.config.idleTimeoutMs,u=Math.max(0,c-a),d=n.commands.map(g=>g.command),m=new Set(n.files.filter(g=>g.operation==="read").map(g=>g.path)).size,p=new Set(n.files.filter(g=>g.operation==="write").map(g=>g.path)).size;return{active:!0,id:n.id,duration:nn(r-o),idleSince:n.lastActivity,idleMs:a,expiresIn:nn(u),commandCount:n.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}},Lg=new zl});import{exec as tC}from"node:child_process";import{promisify as nC}from"node:util";var Vl,sC,Ii,zr,Hg=k(()=>{"use strict";oe();L();Ug();Vl=nC(tC),sC={commitThreshold:10,dayThreshold:3,significantFiles:["package.json","tsconfig.json","Cargo.toml","go.mod","requirements.txt","pyproject.toml",".env.example","docker-compose.yml","Dockerfile"]},Ii=class{static{l(this,"StalenessChecker")}projectPath;config;constructor(e,t={}){this.projectPath=e,this.config={...sC,...t}}async check(e){let t={isStale:!1,reason:null,lastSyncCommit:null,currentCommit:null,commitsSinceSync:0,daysSinceSync:0,changedFiles:[],significantChanges:[]};try{let n={};try{let c=E.getDoc(e,"project");if(!c)return t.isStale=!0,t.reason="No sync history found. Run `prjct sync` to initialize.",t;n=c}catch{return t.isStale=!0,t.reason="No sync history found. Run `prjct sync` to initialize.",t}t.lastSyncCommit=n.lastSyncCommit||null;let r=n.lastSync;try{let{stdout:c}=await Vl("git rev-parse --short HEAD",{cwd:this.projectPath});t.currentCommit=c.trim()}catch{return t.reason="Not a git repository",t}if(!t.lastSyncCommit)return t.isStale=!0,t.reason="No sync commit recorded. Run `prjct sync` to track.",t;if(t.lastSyncCommit===t.currentCommit)return t.reason="Context is up to date",t;let o=this.projectPath,[i,a]=await Promise.all([Vl(`git rev-list --count ${t.lastSyncCommit}..HEAD`,{cwd:o}).catch(()=>null),Vl(`git diff --name-only ${t.lastSyncCommit}..HEAD`,{cwd:o}).catch(()=>null)]);if(!i)return t.isStale=!0,t.reason="Sync commit no longer exists (history changed). Run `prjct sync`.",t;if(t.commitsSinceSync=parseInt(i.stdout.trim(),10)||0,t.changedFiles=a?a.stdout.trim().split(`
|
|
1039
|
+
`).filter(Boolean):[],r){let c=new Date(r),u=new Date;t.daysSinceSync=Math.floor((u.getTime()-c.getTime())/(1e3*60*60*24))}return t.significantChanges=t.changedFiles.filter(c=>this.config.significantFiles.some(u=>c.endsWith(u)||c.includes(u))),t.commitsSinceSync>=this.config.commitThreshold?(t.isStale=!0,t.reason=`${t.commitsSinceSync} commits since last sync (threshold: ${this.config.commitThreshold})`):t.daysSinceSync>=this.config.dayThreshold?(t.isStale=!0,t.reason=`${t.daysSinceSync} days since last sync (threshold: ${this.config.dayThreshold})`):t.significantChanges.length>0?(t.isStale=!0,t.reason=`Significant files changed: ${t.significantChanges.join(", ")}`):t.commitsSinceSync>0?t.reason=`${t.commitsSinceSync} commits since sync (threshold: ${this.config.commitThreshold})`:t.reason="Context is up to date",t}catch(n){return t.reason=`Error checking staleness: ${y(n)}`,t}}formatStatus(e){let t=[];e.isStale?t.push("CLAUDE.md status: \u26A0\uFE0F STALE"):t.push("CLAUDE.md status: \u2713 Fresh");let n=[];if(e.lastSyncCommit&&n.push(`Last sync: ${e.lastSyncCommit}`),e.currentCommit&&n.push(`Current: ${e.currentCommit}`),e.commitsSinceSync>0&&n.push(`Commits since: ${e.commitsSinceSync}`),e.daysSinceSync>0&&n.push(`Days since: ${e.daysSinceSync}`),e.changedFiles.length>0&&n.push(`Files changed: ${e.changedFiles.length}`),n.length>0){let r=Math.max(...n.map(i=>i.length)),o="\u2500".repeat(r+2);t.push(`\u250C${o}\u2510`);for(let i of n)t.push(`\u2502 ${i.padEnd(r)} \u2502`);t.push(`\u2514${o}\u2518`)}if(e.significantChanges.length>0){t.push(""),t.push("Significant changes:");for(let r of e.significantChanges.slice(0,5))t.push(` \u2022 ${r}`);e.significantChanges.length>5&&t.push(` ... and ${e.significantChanges.length-5} more`)}return e.reason&&(t.push(""),t.push(e.reason)),e.isStale&&(t.push(""),t.push("Run `prjct sync` to update context")),t.join(`
|
|
1040
|
+
`)}async getSessionInfo(e){return Lg.getInfo(e)}formatSessionInfo(e){let t=[];if(!e.active)return t.push("Session: \u25CB No active session"),t.join(`
|
|
1041
|
+
`);t.push(`Session: \u25B6 Active (${e.duration})`);let n=[];if(e.commandCount>0){let r=new Set,o=[];for(let i of e.commands)r.has(i)||(r.add(i),o.push(i));n.push(`Commands: ${o.join(" \u2192 ")} (${e.commandCount} total)`)}if((e.filesRead>0||e.filesWritten>0)&&n.push(`Files: ${e.filesRead} read, ${e.filesWritten} written`),n.push(`Idle: ${e.expiresIn} until timeout`),n.length>0){let r=Math.max(...n.map(i=>i.length)),o="\u2500".repeat(r+2);t.push(`\u250C${o}\u2510`);for(let i of n)t.push(`\u2502 ${i.padEnd(r)} \u2502`);t.push(`\u2514${o}\u2518`)}return t.join(`
|
|
1042
|
+
`)}getWarning(e){return e.isStale?e.commitsSinceSync>0?`\u26A0\uFE0F Context stale (${e.commitsSinceSync} commits behind). Run \`prjct sync\``:e.daysSinceSync>0?`\u26A0\uFE0F Context stale (${e.daysSinceSync} days old). Run \`prjct sync\``:"\u26A0\uFE0F Context may be stale. Run `prjct sync`":null}},zr=l((s,e)=>new Ii(s,e),"createStalenessChecker")});import zg from"node:fs/promises";import $i from"node:path";function Ls(s){return s.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 iC(s,e){let t=[],n=e.replace(/\.[^.]+$/,"").split(/[/\\]/).filter(Boolean);for(let p of n)t.push(...Ls(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(s))!==null;)g[1]&&t.push(...Ls(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(s))!==null;)g[1]&&t.push(...Ls(g[1]))}let i=/(?:from|import)\s+['"]([^'"]+)['"]/g,a;for(;(a=i.exec(s))!==null;){let p=a[1];if(p.startsWith(".")||p.startsWith("@/"))t.push(...Ls(p));else{let g=p.startsWith("@")?p.split("/").slice(0,2).join("/"):p.split("/")[0];t.push(...Ls(g))}}let c=/\/\/\s*(.+)/g,u;for(;(u=c.exec(s))!==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(s))!==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&&!Vg.has(p)&&/^[a-z][a-z0-9]*$/.test(p))}function aC(s){return s.split(/\s+/).flatMap(e=>Ls(e)).filter(e=>e.length>1&&!Vg.has(e)&&/^[a-z][a-z0-9]*$/.test(e))}async function Bg(s,e){let t=[],n=await zg.readdir(s,{withFileTypes:!0});for(let r of n){if(oC.has(r.name))continue;let o=$i.join(s,r.name);if(r.isDirectory())t.push(...await Bg(o,e));else if(r.isFile()){let i=$i.extname(r.name).toLowerCase();rC.has(i)&&t.push($i.relative(e,o))}}return t}async function cC(s){let e=await Bg(s,s),t={},n={},r=0,o=50;for(let a=0;a<e.length;a+=o){let c=e.slice(a,a+o),u=await Promise.all(c.map(async d=>{try{let m=await zg.readFile($i.join(s,d),"utf-8"),p=iC(m,d);return{filePath:d,tokens:p}}catch{return{filePath:d,tokens:[]}}}));for(let{filePath:d,tokens:m}of u){if(m.length===0)continue;t[d]={tokens:m,length:m.length},r+=m.length;let p=new Map;for(let g of m)p.set(g,(p.get(g)||0)+1);for(let[g,f]of p)n[g]||(n[g]=[]),n[g].push({path:d,tf:f})}}let i=Object.keys(t).length;return{documents:t,invertedIndex:n,avgDocLength:i>0?r/i:0,totalDocs:i,builtAt:new Date().toISOString()}}function lC(s,e){return Math.log((e-s+.5)/(s+.5)+1)}function uC(s,e){let t=aC(s);if(t.length===0)return[];let n=new Map;for(let r of t){let o=e.invertedIndex[r];if(!o)continue;let i=lC(o.length,e.totalDocs);for(let{path:a,tf:c}of o){let u=e.documents[a];if(!u)continue;let d=c*(Gg+1),m=c+Gg*(1-Wg+Wg*(u.length/e.avgDocLength)),p=i*(d/m);n.set(a,(n.get(a)||0)+p)}}return Array.from(n.entries()).map(([r,o])=>({path:r,score:o})).sort((r,o)=>o.score-r.score)}function dC(s,e){let t={invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt,docLengths:Object.fromEntries(Object.entries(e.documents).map(([n,r])=>[n,r.length]))};G.setDoc(s,Jg,t)}function pC(s){let e=G.getDoc(s,Jg);if(!e)return null;let t={};for(let[n,r]of Object.entries(e.docLengths))t[n]={tokens:[],length:r};return{documents:t,invertedIndex:e.invertedIndex,avgDocLength:e.avgDocLength,totalDocs:e.totalDocs,builtAt:e.builtAt}}async function qg(s,e){let t=await cC(s);return dC(e,t),t}function Kg(s,e,t=15){let n=pC(s);return n?uC(e,n).slice(0,t):[]}var Gg,Wg,rC,Vg,oC,Jg,Bl=k(()=>{"use strict";oe();Gg=1.2,Wg=.75,rC=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".py",".go",".rs",".java",".cs",".rb",".php",".vue",".svelte"]),Vg=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"]),oC=new Set(["node_modules",".git","dist","build","out",".next","coverage",".cache",".turbo",".vercel","__pycache__","vendor","target"]);l(Ls,"splitIdentifier");l(iC,"tokenizeFile");l(aC,"tokenizeQuery");l(Bg,"listFiles");l(cC,"buildIndex");l(lC,"idf");l(uC,"score");Jg="bm25-index";l(dC,"saveIndex");l(pC,"loadIndex");l(qg,"indexProject");l(Kg,"queryFiles")});import Jl from"node:fs/promises";import un from"node:path";function yC(s){let e=[],t,n=new RegExp(hC.source,"g");for(;(t=n.exec(s))!==null;){let r=t[1];(r.startsWith(".")||r.startsWith("@/"))&&e.push(r)}return e}async function wC(s,e,t){let n;if(s.startsWith("@/"))n=un.join(t,"src",s.slice(2));else{let r=un.dirname(un.join(t,e));n=un.resolve(r,s)}for(let r of fC){let o=n+r;try{if((await Jl.stat(o)).isFile())return un.relative(t,o)}catch{}}return null}async function Xg(s,e){let t=[],n=await Jl.readdir(s,{withFileTypes:!0});for(let r of n){if(gC.has(r.name))continue;let o=un.join(s,r.name);if(r.isDirectory())t.push(...await Xg(o,e));else if(r.isFile()){let i=un.extname(r.name).toLowerCase();mC.has(i)&&t.push(un.relative(e,o))}}return t}async function SC(s){let e=await Xg(s,s),t={},n={},r=0,o=50;for(let i=0;i<e.length;i+=o){let a=e.slice(i,i+o),c=await Promise.all(a.map(async u=>{try{let d=await Jl.readFile(un.join(s,u),"utf-8"),m=yC(d),p=[];for(let g of m){let f=await wC(g,u,s);f&&f!==u&&p.push(f)}return{filePath:u,imports:p}}catch{return{filePath:u,imports:[]}}}));for(let{filePath:u,imports:d}of c)if(d.length!==0){t[u]=d,r+=d.length;for(let m of d)n[m]||(n[m]=[]),n[m].push(u)}}return{forward:t,reverse:n,fileCount:e.length,edgeCount:r,builtAt:new Date().toISOString()}}function kC(s,e){G.setDoc(s,Yg,e)}function Qg(s){return G.getDoc(s,Yg)}async function Zg(s,e){let t=await SC(s);return kC(e,t),t}var mC,gC,fC,hC,Yg,ql=k(()=>{"use strict";oe();mC=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]),gC=new Set(["node_modules",".git","dist","build","out",".next","coverage",".cache",".turbo",".vercel"]),fC=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],hC=/(?:import|from)\s+['"]([^'"]+)['"]/g;l(yC,"extractImportSources");l(wC,"resolveImport");l(Xg,"listFiles");l(SC,"buildGraph");Yg="import-graph";l(kC,"saveGraph");l(Qg,"loadGraph");l(Zg,"indexImports")});function ef(s,e){let t=[...s.added,...s.modified],n=new Set(t),r=new Set,o=Qg(e);if(o)for(let c of t){let u=o.reverse[c];if(u)for(let d of u)n.has(d)||r.add(d)}let i=Array.from(r),a=[...t,...i];return{directlyChanged:t,affectedByImports:i,deleted:s.deleted,allAffected:a}}function tf(s){let e=new Set;for(let t of s){let n=t.toLowerCase();(n.endsWith(".tsx")||n.endsWith(".jsx")||n.endsWith(".css")||n.endsWith(".scss")||n.endsWith(".vue")||n.endsWith(".svelte")||n.includes("/components/")||n.includes("/pages/")||n.includes("/app/"))&&(e.add("frontend"),e.add("uxui")),(n.includes(".test.")||n.includes(".spec.")||n.includes("__tests__")||n.includes("/test/"))&&e.add("testing"),(n.includes("dockerfile")||n.includes("docker-compose")||n.includes(".dockerignore")||n.includes(".github/")||n.includes("ci/")||n.includes("cd/"))&&e.add("devops"),(n.endsWith(".sql")||n.includes("prisma")||n.includes("drizzle")||n.includes("migration")||n.includes("/db/"))&&e.add("database"),(n.endsWith(".ts")||n.endsWith(".js"))&&!n.includes(".test.")&&!n.includes(".spec.")&&!n.endsWith(".d.ts")&&e.add("backend")}return e}var nf=k(()=>{"use strict";ql();l(ef,"propagateChanges");l(tf,"affectedDomains")});import Kl from"node:fs/promises";import Mi from"node:path";async function sf(s,e){let t=[],n=await Kl.readdir(s,{withFileTypes:!0}).catch(()=>[]);for(let r of n){let o=String(r.name);if(vC.has(o)||o.startsWith(".")&&o!==".env.example")continue;let i=Mi.join(s,o);if(r.isDirectory())t.push(...await sf(i,e));else if(r.isFile()){let a=Mi.extname(o).toLowerCase();bC.has(a)&&t.push(Mi.relative(e,i))}}return t}function PC(s){if(typeof Bun<"u"&&Bun.hash)return`xxh64:${Bun.hash(s).toString(36)}`;let e=2166136261;for(let t=0;t<s.length;t++)e^=s.charCodeAt(t),e=Math.imul(e,16777619);return`fnv1a:${(e>>>0).toString(36)}`}async function CC(s){let e=await sf(s,s),t=new Map,n=100;for(let r=0;r<e.length;r+=n){let o=e.slice(r,r+n),i=await Promise.all(o.map(async a=>{try{let c=Mi.join(s,a),[u,d]=await Promise.all([Kl.readFile(c,"utf-8"),Kl.stat(c)]);return{path:a,hash:PC(u),size:d.size,mtime:d.mtime.toISOString()}}catch{return null}}));for(let a of i)a&&t.set(a.path,a)}return t}function xC(s,e){let t=[],n=[],r=[];for(let[i,a]of s){let c=e.get(i);c?c.hash!==a.hash?n.push(i):r.push(i):t.push(i)}let o=[];for(let i of e.keys())s.has(i)||o.push(i);return{added:t,modified:n,deleted:o,unchanged:r}}function Xl(s,e){let t=G.getDb(s);t.transaction(()=>{t.prepare("DELETE FROM index_checksums").run();let n=t.prepare("INSERT INTO index_checksums (path, checksum, size, mtime) VALUES (?, ?, ?, ?)");for(let[,r]of e)n.run(r.path,r.hash,r.size,r.mtime)})(),G.setDoc(s,"file-hashes-meta",{fileCount:e.size,builtAt:new Date().toISOString()})}function TC(s){let e=new Map;try{let t=G.query(s,"SELECT path, checksum, size, mtime FROM index_checksums");for(let n of t)e.set(n.path,{path:n.path,hash:n.checksum,size:n.size||0,mtime:n.mtime||""})}catch{}return e}async function Yl(s,e){let[t,n]=await Promise.all([CC(s),Promise.resolve(TC(e))]);return{diff:xC(t,n),currentHashes:t}}function rf(s){return G.hasDoc(s,"file-hashes-meta")}var bC,vC,of=k(()=>{"use strict";oe();bC=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs",".json",".md",".css",".scss",".html",".vue",".svelte",".py",".go",".rs",".yaml",".yml",".toml"]),vC=new Set(["node_modules",".git","dist","build","out",".next","coverage",".cache",".turbo",".vercel",".prjct"]);l(sf,"listProjectFiles");l(PC,"hashContent");l(CC,"computeHashes");l(xC,"diffHashes");l(Xl,"saveHashes");l(TC,"loadHashes");l(Yl,"detectChanges");l(rf,"hasHashRegistry")});import{exec as EC}from"node:child_process";import{promisify as AC}from"node:util";async function jC(s,e=100){try{let{stdout:t}=await RC(`git log --name-only --pretty=format:'---COMMIT---' -${e}`,{cwd:s,maxBuffer:10485760}),n=[],r=null;for(let o of t.split(`
|
|
1043
|
+
`)){let i=o.trim();i==="---COMMIT---"?(r&&r.size>0&&r.size<=cf&&n.push(r),r=new Set):i&&r&&IC(i)&&r.add(i)}return r&&r.size>0&&r.size<=cf&&n.push(r),n}catch{return[]}}function IC(s){return/\.(ts|tsx|js|jsx|mjs|cjs|py|go|rs|java|cs|rb|php|vue|svelte)$/i.test(s)&&!s.includes("node_modules/")}async function $C(s,e=100){let t=await jC(s,e),n=new Map,r=new Map;for(let i of t){let a=Array.from(i);for(let c of a)n.set(c,(n.get(c)||0)+1);for(let c=0;c<a.length;c++)for(let u=c+1;u<a.length;u++){let d=MC(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=n.get(c)||0,m=n.get(u)||0;if(d<af||m<af)continue;let p=d+m-a,g=p>0?a/p:0;g<DC||(o[c]||(o[c]={}),o[u]||(o[u]={}),o[c][u]=g,o[u][c]=g)}return{matrix:o,commitsAnalyzed:t.length,filesAnalyzed:n.size,builtAt:new Date().toISOString()}}function MC(s,e){return s<e?`${s}\0${e}`:`${e}\0${s}`}function FC(s,e){G.setDoc(s,OC,e)}async function lf(s,e,t=100){let n=await $C(s,t);return FC(e,n),n}var RC,DC,af,cf,OC,uf=k(()=>{"use strict";oe();RC=AC(EC),DC=.1,af=2,cf=30;l(jC,"parseGitLog");l(IC,"isSourceFile");l($C,"buildMatrix");l(MC,"pairKey");OC="cochange-index";l(FC,"saveMatrix");l(lf,"indexCoChanges")});import Us from"node:fs/promises";import _C from"node:os";import df from"node:path";var Ql,NC,Oi,Zl=k(()=>{"use strict";L();Ql=class{static{l(this,"EditorsConfig")}homeDir;configDir;configFile;constructor(){this.homeDir=_C.homedir(),this.configDir=df.join(this.homeDir,".prjct-cli","config"),this.configFile=df.join(this.configDir,"installed-editors.json")}async ensureConfigDir(){try{await Us.mkdir(this.configDir,{recursive:!0})}catch(e){console.error("[editors-config] Error creating config directory:",y(e))}}async loadConfig(){try{let e=await Us.readFile(this.configFile,"utf-8");return JSON.parse(e)}catch(e){return e.code==="ENOENT"||console.error("[editors-config] Error loading config:",y(e)),null}}async saveConfig(e,t,n="claude"){try{await this.ensureConfigDir();let r={version:e,provider:n,lastInstall:new Date().toISOString(),path:t};return await Us.writeFile(this.configFile,JSON.stringify(r,null,2),"utf-8"),!0}catch(r){return console.error("[editors-config] Error saving config:",y(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 Us.writeFile(this.configFile,JSON.stringify(t,null,2),"utf-8"),!0):!1}catch(t){return console.error("[editors-config] Error updating version:",y(t)),!1}}async configExists(){try{return await Us.access(this.configFile),!0}catch{return!1}}async deleteConfig(){try{return await this.configExists()&&await Us.unlink(this.configFile),!0}catch(e){return console.error("[editors-config] Error deleting config:",y(e)),!1}}},NC=new Ql,Oi=NC});var tu={};hn(tu,{installAntigravitySkill:()=>hf,installCodexSkill:()=>eu,needsAntigravityInstallation:()=>zC,run:()=>ff,verifyCodexPRouterReady:()=>_i});import{execSync as LC}from"node:child_process";import{createHash as UC}from"node:crypto";import J from"node:fs/promises";import ss from"node:os";import te from"node:path";import fe from"chalk";async function HC(s){let e=s.name==="claude"?"@anthropic-ai/claude-code":"@google/gemini-cli";if(!Es.isAvailable("npm"))return console.log(`${fe.yellow("\u26A0\uFE0F npm is not available")}`),console.log(""),console.log(`${fe.dim(`Install ${s.displayName} using one of:`)}`),console.log(fe.dim(" \u2022 Install Node.js: https://nodejs.org")),console.log(fe.dim(` \u2022 Use Homebrew: brew install ${s.name==="claude"?"claude":"gemini"}`)),console.log(fe.dim(` \u2022 Use npx directly: npx ${e}`)),console.log(""),!1;try{return console.log(fe.yellow(`\u{1F4E6} ${s.displayName} not found. Installing...`)),console.log(""),LC(`npm install -g ${e}`,{stdio:"inherit",timeout:Ts("NPM_INSTALL")}),console.log(""),console.log(`${fe.green("\u2713")} ${s.displayName} installed successfully`),console.log(""),!0}catch(t){let n=t;return n.killed&&n.signal==="SIGTERM"?(console.log(fe.yellow(`\u26A0\uFE0F Installation timed out for ${s.displayName}`)),console.log(""),console.log(fe.dim("The npm install took too long. Try:")),console.log(fe.dim(" \u2022 Set PRJCT_TIMEOUT_NPM_INSTALL=300000 for 5 minutes")),console.log(fe.dim(` \u2022 Run manually: npm install -g ${e}`))):console.log(fe.yellow(`\u26A0\uFE0F Failed to install ${s.displayName}: ${n.message}`)),console.log(""),console.log(fe.dim("Alternative installation methods:")),console.log(fe.dim(` \u2022 npm: npm install -g ${e}`)),console.log(fe.dim(` \u2022 yarn: yarn global add ${e}`)),console.log(fe.dim(` \u2022 pnpm: pnpm add -g ${e}`)),console.log(fe.dim(` \u2022 brew: brew install ${s.name==="claude"?"claude":"gemini"}`)),console.log(""),!1}}async function ff(){let s=await ur(),e=await Pa(),t=dt[e.provider],n={provider:e.provider,providers:[],cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null},r=["claude","gemini"];for(let a of r){let c=dt[a],u=s[a],d={provider:a,cliInstalled:!1,commandsAdded:0,commandsUpdated:0,configAction:null};if(!u.installed)if(a===e.provider)if(await HC(c))d.cliInstalled=!0,n.cliInstalled=!0;else throw new Error(`${c.displayName} installation failed`);else continue;if(a==="claude"){if(await je.detectActiveProvider()){let p=await je.syncCommands();p.success&&(d.commandsAdded=p.added,d.commandsUpdated=p.updated,n.commandsAdded+=p.added,n.commandsUpdated+=p.updated);let g=await je.installGlobalConfig();g.success&&(d.configAction=g.action,n.configAction||(n.configAction=g.action)),await je.installDocs(),await qC(),await an.ensureReady()}}else if(a==="gemini"){await GC()&&(d.commandsAdded=1,n.commandsAdded+=1);let p=await WC();p.success&&(d.configAction=p.action)}n.providers.push(d)}if((await mo()).installed&&(await hf()).success&&console.log(` ${fe.green("\u2713")} Antigravity skill installed`),(await Fn()).installed){if(!(await eu()).success)throw new Error("Codex skill installation failed");let c=await _i({autoRepair:!0});if(!c.verified)throw new Error(c.message||"Codex p. router verification failed");console.log(` ${fe.green("\u2713")} Codex skill installed`),console.log(` ${fe.green("\u2713")} Codex p. router ready`)}await Oi.saveConfig(De,await je.getInstallPath(),e.provider),await JC();for(let a of n.providers)KC(a,dt[a.provider]);return n}async function GC(){try{let s=te.join(ss.homedir(),".gemini","commands"),e=te.join(s,"p.toml");await J.mkdir(s,{recursive:!0});let t=he("commands/p.toml");if(t)return await J.writeFile(e,t,"utf-8"),!0;let n=te.join(ge,"templates","commands","p.toml");return await j(n)?(await J.copyFile(n,e),!0):!1}catch(s){return H.warn(`Gemini router warning: ${y(s)}`),!1}}async function WC(){try{let s=te.join(ss.homedir(),".gemini"),e=te.join(s,"GEMINI.md");await J.mkdir(s,{recursive:!0});let t=he("global/GEMINI.md");if(!t){let p=te.join(ge,"templates","global","GEMINI.md");t=await J.readFile(p,"utf-8")}let n="",r=!1;try{n=await J.readFile(e,"utf-8"),r=!0}catch(p){if(C(p))r=!1;else throw p}if(!r)return await J.writeFile(e,t,"utf-8"),{success:!0,action:"created"};let o="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",i="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";if(!(n.includes(o)&&n.includes(i))){let p=`${n}
|
|
1044
1044
|
|
|
1045
|
-
${t}`;return await J.writeFile(e,p,"utf-8"),{success:!0,action:"appended"}}let c=n.substring(0,n.indexOf(o)),u=n.substring(n.indexOf(i)+i.length),d=t.substring(t.indexOf(o),t.indexOf(i)+i.length),m=c+d+u;return await J.writeFile(e,m,"utf-8"),{success:!0,action:"updated"}}catch(
|
|
1045
|
+
${t}`;return await J.writeFile(e,p,"utf-8"),{success:!0,action:"appended"}}let c=n.substring(0,n.indexOf(o)),u=n.substring(n.indexOf(i)+i.length),d=t.substring(t.indexOf(o),t.indexOf(i)+i.length),m=c+d+u;return await J.writeFile(e,m,"utf-8"),{success:!0,action:"updated"}}catch(s){return H.warn(`Gemini config warning: ${y(s)}`),{success:!1,action:null}}}async function hf(){try{let s=te.join(ss.homedir(),".gemini","antigravity","skills"),e=te.join(s,"prjct"),t=te.join(e,"SKILL.md");await J.mkdir(e,{recursive:!0});let n=await j(t),r=he("antigravity/SKILL.md");if(!r){let o=te.join(ge,"templates","antigravity","SKILL.md");if(!await j(o))return H.warn("Antigravity SKILL.md template not found"),{success:!1,action:null};r=await J.readFile(o,"utf-8")}return await J.writeFile(t,r,"utf-8"),{success:!0,action:n?"updated":"created"}}catch(s){return H.warn(`Antigravity skill warning: ${y(s)}`),{success:!1,action:null}}}async function zC(){let s=await mo();return s.installed&&!s.skillInstalled}function wf(){return te.join(ss.homedir(),".codex","skills","prjct","SKILL.md")}function VC(s){return`<!-- ${yf}: ${JSON.stringify({version:De,templateHash:s})} -->`}function pf(s){let e=s.match(new RegExp(`<!--\\s*${yf}:\\s*(\\{[\\s\\S]*?\\})\\s*-->`));if(!e)return null;try{return JSON.parse(e[1])}catch{return null}}function BC(s){return UC("sha256").update(s).digest("hex")}async function Sf(){let s=he("codex/SKILL.md");if(s)return s;let e=te.join(ge,"templates","codex","SKILL.md");return await j(e)?J.readFile(e,"utf-8"):null}function kf(s){let e=s.trimEnd(),t=BC(e),n=VC(t);return{content:`${e}
|
|
1046
1046
|
|
|
1047
1047
|
${n}
|
|
1048
|
-
`,templateHash:t}}async function
|
|
1048
|
+
`,templateHash:t}}async function eu(){try{let s=wf(),e=te.dirname(s);await J.mkdir(e,{recursive:!0});let t=await j(s),n=await Sf();if(!n)return H.warn("Codex SKILL.md template not found"),{success:!1,action:null};let r=kf(n);return t&&await J.readFile(s,"utf-8").catch(()=>"")===r.content?{success:!0,action:"unchanged"}:(await J.writeFile(s,r.content,"utf-8"),{success:!0,action:t?"updated":"created"})}catch(s){return H.warn(`Codex skill warning: ${y(s)}`),{success:!1,action:null}}}async function _i(s={}){let e=wf();if(!(await Fn()).installed)return{installed:!1,verified:!0,skillPath:e,message:"Codex not detected"};let n=await Sf();if(!n)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=kf(n),o=l(async()=>s.autoRepair?(await eu()).success:!1,"maybeRepair"),i="";if(!await j(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 J.readFile(e,"utf-8").catch(()=>"");let a=pf(i);if(!(a?.version===De&&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 J.readFile(e,"utf-8").catch(()=>""),a=pf(i),!(a?.version===De&&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`"]}}try{let u=await xc.resolvePCommandTemplate("sync");return{installed:!0,verified:!0,skillPath:e,templateHash:r.templateHash,command:u.command,templatePath:u.templatePath,templateSource:u.source,message:"Codex p. router ready"}}catch(u){let d=Cc(u)?u.fix:["Run `prjct setup` to repair command template routing"];return{installed:!0,verified:!1,skillPath:e,templateHash:r.templateHash,message:u instanceof Error?u.message:"Failed to resolve p. sync template",fix:d}}}async function JC(){try{let s=te.join(ss.homedir(),".prjct-cli","projects");if(!await j(s))return;let e=(await J.readdir(s,{withFileTypes:!0})).filter(n=>n.isDirectory()).map(n=>n.name),t=0;for(let n of e)try{let r=E.getDoc(n,"project");if(!r)continue;r.cliVersion!==De&&(r.cliVersion=De,E.setDoc(n,"project",r),t++)}catch{}t>0&&console.log(` ${fe.green("\u2713")} Updated ${t} project(s) to v${De}`)}catch(s){C(s)||H.warn(`Migration warning: ${y(s)}`)}}async function mf(s,e){let t={};if(await j(s))try{t=JSON.parse(await J.readFile(s,"utf8"))}catch(n){if(!(n instanceof SyntaxError))throw n}t.statusLine={type:"command",command:e},await J.writeFile(s,JSON.stringify(t,null,2))}async function qC(){try{let s=te.join(ss.homedir(),".claude"),e=te.join(s,"settings.json"),t=te.join(s,"prjct-statusline.sh"),n=te.join(ss.homedir(),".prjct-cli","statusline"),r=te.join(n,"statusline.sh"),o=te.join(n,"themes"),i=te.join(n,"lib"),a=te.join(n,"components"),c=te.join(n,"config.json"),u=te.join(ge,"assets","statusline"),d=te.join(u,"statusline.sh"),m=te.join(u,"themes"),p=te.join(u,"lib"),g=te.join(u,"components"),f=te.join(u,"default-config.json");if(await j(s)||await J.mkdir(s,{recursive:!0}),await j(n)||await J.mkdir(n,{recursive:!0}),await j(o)||await J.mkdir(o,{recursive:!0}),await j(i)||await J.mkdir(i,{recursive:!0}),await j(a)||await J.mkdir(a,{recursive:!0}),await j(r)){let S=await J.readFile(r,"utf8");if(S.includes("CLI_VERSION=")){let w=S.match(/CLI_VERSION="([^"]*)"/);if(w&&w[1]!==De){let v=S.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${De}"`);await J.writeFile(r,v,{mode:493})}await Fi(p,i),await Fi(g,a),await gf(t,r),await mf(e,t);return}}if(await j(d)){let S=await J.readFile(d,"utf8");if(S=S.replace(/CLI_VERSION="[^"]*"/,`CLI_VERSION="${De}"`),await J.writeFile(r,S,{mode:493}),await Fi(p,i),await Fi(g,a),await j(m)){let w=await J.readdir(m);for(let v of w){let T=te.join(m,v),_=te.join(o,v);await J.copyFile(T,_)}}!await j(c)&&await j(f)&&await J.copyFile(f,c)}else{let S=`#!/bin/bash
|
|
1049
1049
|
# prjct Status Line for Claude Code
|
|
1050
1050
|
CLI_VERSION="${De}"
|
|
1051
1051
|
input=$(cat)
|
|
@@ -1076,61 +1076,61 @@ if [ -f "$CONFIG" ]; then
|
|
|
1076
1076
|
fi
|
|
1077
1077
|
fi
|
|
1078
1078
|
echo "prjct"
|
|
1079
|
-
`;await J.writeFile(
|
|
1080
|
-
`)),t.push("")),
|
|
1081
|
-
`)),t.push("")),
|
|
1079
|
+
`;await J.writeFile(r,S,{mode:493})}await gf(t,r),await mf(e,t)}catch(s){C(s)||H.warn(`Status line warning: ${y(s)}`)}}async function Fi(s,e){if(!await j(s))return;let t=await J.readdir(s);for(let n of t)if(n.endsWith(".sh")){let r=te.join(s,n),o=te.join(e,n);await J.copyFile(r,o),await J.chmod(o,493)}}async function gf(s,e){try{if(await j(s)){if((await J.lstat(s)).isSymbolicLink()&&await J.readlink(s)===e)return;await J.unlink(s)}await J.symlink(e,s)}catch{try{await j(e)&&(await J.copyFile(e,s),await J.chmod(s,493))}catch(n){C(n)||H.warn(`Symlink fallback warning: ${n.message}`)}}}function KC(s,e){if(console.log(""),s.cliInstalled?console.log(` ${fe.green("\u2713")} ${e.displayName} CLI installed`):console.log(` ${fe.green("\u2713")} ${e.displayName} CLI found`),s.commandsAdded+s.commandsUpdated>0){let n=[];s.commandsAdded>0&&n.push(`${s.commandsAdded} new`),s.commandsUpdated>0&&n.push(`${s.commandsUpdated} updated`),console.log(` ${fe.green("\u2713")} Commands synced (${n.join(", ")})`)}else console.log(` ${fe.green("\u2713")} Commands up to date`);s.configAction==="created"?console.log(` ${fe.green("\u2713")} Global config created (${e.contextFile})`):s.configAction==="updated"?console.log(` ${fe.green("\u2713")} Global config updated (${e.contextFile})`):s.configAction==="appended"&&console.log(` ${fe.green("\u2713")} Global config merged (${e.contextFile})`),console.log("")}var yf,XC,Ni=k(()=>{"use strict";qt();xs();Ko();Tc();oe();L();Cn();We();En();Dt();qe();on();Zl();l(HC,"installAICLI");l(ff,"run");l(GC,"installGeminiRouter");l(WC,"installGeminiGlobalConfig");l(hf,"installAntigravitySkill");l(zC,"needsAntigravityInstallation");yf="prjct-codex-router";l(wf,"getCodexSkillPath");l(VC,"getCodexSkillMetadata");l(pf,"parseCodexSkillMetadata");l(BC,"hashContent");l(Sf,"loadCodexSkillTemplate");l(kf,"buildCodexSkillContent");l(eu,"installCodexSkill");l(_i,"verifyCodexPRouterReady");l(JC,"migrateProjectsCliVersion");l(mf,"ensureStatusLineSettings");l(qC,"installStatusLine");l(Fi,"installStatusLineModules");l(gf,"ensureStatusLineSymlink");l(KC,"showResults");XC=process.argv[1]?.includes("setup.ts")||process.argv[1]?.includes("setup.js");XC&&ff().catch(s=>{console.error("Setup error:",s.message),process.exit(1)})});function $t(s){return`<!-- source: ${s.file}, ${s.type} -->`}function rs(){let s={file:"unknown",type:"detected"};return{name:{...s},version:{...s},ecosystem:{...s},languages:{...s},frameworks:{...s},commands:{...s},projectType:{...s},git:{file:"git",type:"detected"}}}var nu=k(()=>{"use strict";l($t,"cite");l(rs,"defaultSources")});function Li(s,e){let t=[];return e==="full"?(t.push("## prjct Rules"),t.push(""),t.push("### Path Resolution"),t.push(`**ALL prjct writes go to**: \`~/.prjct-cli/projects/${s.projectId}/\``),t.push("- NEVER write to `.prjct/`"),t.push("- NEVER write to `./` for prjct data"),t.push(""),t.push("### Workflow"),t.push("```"),t.push('p. sync \u2192 p. task "desc" \u2192 [work] \u2192 p. done \u2192 p. ship'),t.push("```"),t.push(""),t.push("| Command | Action |"),t.push("|---------|--------|"),t.push("| `p. sync` | Re-analyze project |"),t.push("| `p. task X` | Start task |"),t.push("| `p. done` | Complete subtask |"),t.push("| `p. ship X` | Ship feature |"),t.push("")):(t.push("## prjct Rules"),t.push(""),t.push(`Path: \`~/.prjct-cli/projects/${s.projectId}/\``),t.push('Workflow: `p. sync` \u2192 `p. task "desc"` \u2192 work \u2192 `p. done` \u2192 `p. ship`'),t.push("")),t.push("## Project State"),t.push(""),t.push("| Field | Value |"),t.push("|-------|-------|"),t.push(`| Name | ${s.name} |`),t.push(`| Version | ${s.version} |`),t.push(`| Ecosystem | ${s.ecosystem} |`),t.push(`| Branch | ${s.branch} |`),t.push(`| Files | ~${s.fileCount} |`),t.push(`| Commits | ${s.commits} |`),t.push(""),(s.agents.workflow.length>0||s.agents.domain.length>0)&&(t.push("## Agents"),t.push(""),t.push(`Load from \`~/.prjct-cli/projects/${s.projectId}/agents/\`:`),t.push(""),t.push(`**Workflow**: ${s.agents.workflow.join(", ")}`),t.push(`**Domain**: ${s.agents.domain.join(", ")||"none"}`),t.push("")),s.learnings&&(s.learnings.completedTasks.length>0||s.learnings.resolvedBugs.length>0||s.learnings.shippedFeatures.length>0)&&(t.push("## Recent Learnings"),t.push(""),s.learnings.completedTasks.length>0&&(t.push("### Completed Tasks"),t.push(s.learnings.completedTasks.map(n=>`- ${n.description}${n.branch?` (${n.branch})`:""}`).join(`
|
|
1080
|
+
`)),t.push("")),s.learnings.resolvedBugs.length>0&&(t.push("### Resolved Bugs"),t.push(s.learnings.resolvedBugs.map(n=>`- ${n.description}`).join(`
|
|
1081
|
+
`)),t.push("")),s.learnings.shippedFeatures.length>0&&(t.push("### Shipped Features"),t.push(s.learnings.shippedFeatures.map(n=>`- **${n.name}** (v${n.version})${n.description?`: ${n.description}`:""}`).join(`
|
|
1082
1082
|
`)),t.push(""))),t.join(`
|
|
1083
|
-
`)}function
|
|
1084
|
-
`)}function
|
|
1085
|
-
`)}function
|
|
1083
|
+
`)}function Vr(s,e){return(e?s.slice(0,e):s).map(n=>`- **${n.name}**: ${n.description}${n.location?` (${n.location})`:""}`).join(`
|
|
1084
|
+
`)}function Br(s,e){return(e?s.slice(0,e):s).map(n=>`- **${n.issue}** in \`${n.file}\` \u2014 ${n.suggestion}`).join(`
|
|
1085
|
+
`)}function su(s){let e=[];return s.packageManager&&e.push(`- Package Manager: \`${s.packageManager}\``),s.sourceDir&&e.push(`- Source: \`${s.sourceDir}/\``),s.testDir&&e.push(`- Tests: \`${s.testDir}/\``),e.length>0?`
|
|
1086
1086
|
### Project Structure
|
|
1087
1087
|
|
|
1088
1088
|
${e.join(`
|
|
1089
1089
|
`)}
|
|
1090
|
-
`:""}function
|
|
1090
|
+
`:""}function YC(s){let e=[];return s.patterns?.length>0&&e.push(`
|
|
1091
1091
|
### Code Patterns (Follow These)
|
|
1092
1092
|
|
|
1093
|
-
${
|
|
1093
|
+
${Vr(s.patterns)}`),s.antiPatterns?.length>0&&e.push(`
|
|
1094
1094
|
### Anti-Patterns (Avoid These)
|
|
1095
1095
|
|
|
1096
|
-
${
|
|
1097
|
-
`)}function
|
|
1098
|
-
# ${
|
|
1099
|
-
<!-- projectId: ${
|
|
1096
|
+
${Br(s.antiPatterns)}`),e.push(su(s)),e.join(`
|
|
1097
|
+
`)}function QC(s,e){let t=s.sources||rs();return`<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->
|
|
1098
|
+
# ${s.name} - Project Rules
|
|
1099
|
+
<!-- projectId: ${s.projectId} -->
|
|
1100
1100
|
<!-- Generated: ${new Date().toISOString()} -->
|
|
1101
|
-
<!-- Ecosystem: ${
|
|
1101
|
+
<!-- Ecosystem: ${s.ecosystem} | Type: ${s.projectType} -->
|
|
1102
1102
|
|
|
1103
|
-
## THIS PROJECT (${
|
|
1103
|
+
## THIS PROJECT (${s.ecosystem})
|
|
1104
1104
|
|
|
1105
|
-
${
|
|
1106
|
-
**Type:** ${
|
|
1107
|
-
**Path:** ${
|
|
1105
|
+
${$t(t.ecosystem)}
|
|
1106
|
+
**Type:** ${s.projectType}
|
|
1107
|
+
**Path:** ${s.repoPath}
|
|
1108
1108
|
|
|
1109
1109
|
### Commands (USE THESE, NOT OTHERS)
|
|
1110
1110
|
|
|
1111
|
-
${
|
|
1111
|
+
${$t(t.commands)}
|
|
1112
1112
|
| Action | Command |
|
|
1113
1113
|
|--------|---------|
|
|
1114
|
-
| Install dependencies | \`${
|
|
1115
|
-
| Run dev server | \`${
|
|
1116
|
-
| Run tests | \`${
|
|
1117
|
-
| Build | \`${
|
|
1118
|
-
| Lint | \`${
|
|
1119
|
-
| Format | \`${
|
|
1114
|
+
| Install dependencies | \`${s.commands.install}\` |
|
|
1115
|
+
| Run dev server | \`${s.commands.dev}\` |
|
|
1116
|
+
| Run tests | \`${s.commands.test}\` |
|
|
1117
|
+
| Build | \`${s.commands.build}\` |
|
|
1118
|
+
| Lint | \`${s.commands.lint}\` |
|
|
1119
|
+
| Format | \`${s.commands.format}\` |
|
|
1120
1120
|
|
|
1121
1121
|
### Code Conventions
|
|
1122
1122
|
|
|
1123
|
-
${
|
|
1124
|
-
- **Languages**: ${
|
|
1125
|
-
${
|
|
1126
|
-
- **Frameworks**: ${
|
|
1127
|
-
${
|
|
1123
|
+
${$t(t.languages)}
|
|
1124
|
+
- **Languages**: ${s.languages.join(", ")||"Not detected"}
|
|
1125
|
+
${$t(t.frameworks)}
|
|
1126
|
+
- **Frameworks**: ${s.frameworks.join(", ")||"Not detected"}
|
|
1127
|
+
${s.analysis?YC(s.analysis):"\n> Run `p. sync` to populate project intelligence\n"}
|
|
1128
1128
|
---
|
|
1129
1129
|
|
|
1130
1130
|
## PRJCT RULES
|
|
1131
1131
|
|
|
1132
1132
|
### Path Resolution
|
|
1133
|
-
**ALL prjct writes go to**: \`~/.prjct-cli/projects/${
|
|
1133
|
+
**ALL prjct writes go to**: \`~/.prjct-cli/projects/${s.projectId}/\`
|
|
1134
1134
|
- NEVER write to \`.prjct/\`
|
|
1135
1135
|
- NEVER write to \`./\` for prjct data
|
|
1136
1136
|
|
|
@@ -1150,53 +1150,53 @@ p. sync \u2192 p. task "desc" \u2192 [work] \u2192 p. done \u2192 p. ship
|
|
|
1150
1150
|
|
|
1151
1151
|
## PROJECT STATE
|
|
1152
1152
|
|
|
1153
|
-
${
|
|
1153
|
+
${$t(t.name)}
|
|
1154
1154
|
| Field | Value |
|
|
1155
1155
|
|-------|-------|
|
|
1156
|
-
| Name | ${
|
|
1157
|
-
| Version | ${
|
|
1158
|
-
| Ecosystem | ${
|
|
1159
|
-
| Branch | ${
|
|
1160
|
-
| Files | ~${
|
|
1161
|
-
| Commits | ${
|
|
1156
|
+
| Name | ${s.name} |
|
|
1157
|
+
| Version | ${s.version} |
|
|
1158
|
+
| Ecosystem | ${s.ecosystem} |
|
|
1159
|
+
| Branch | ${s.branch} |
|
|
1160
|
+
| Files | ~${s.fileCount} |
|
|
1161
|
+
| Commits | ${s.commits} |
|
|
1162
1162
|
|
|
1163
1163
|
---
|
|
1164
1164
|
|
|
1165
1165
|
## AGENTS
|
|
1166
1166
|
|
|
1167
|
-
Load from \`~/.prjct-cli/projects/${
|
|
1167
|
+
Load from \`~/.prjct-cli/projects/${s.projectId}/agents/\`:
|
|
1168
1168
|
|
|
1169
|
-
**Workflow**: ${
|
|
1170
|
-
**Domain**: ${
|
|
1169
|
+
**Workflow**: ${s.agents.workflow.join(", ")}
|
|
1170
|
+
**Domain**: ${s.agents.domain.join(", ")||"none"}
|
|
1171
1171
|
|
|
1172
1172
|
---
|
|
1173
1173
|
|
|
1174
1174
|
## RECENT LEARNINGS
|
|
1175
1175
|
|
|
1176
|
-
${
|
|
1176
|
+
${s.learnings&&(s.learnings.completedTasks.length>0||s.learnings.resolvedBugs.length>0||s.learnings.shippedFeatures.length>0)?`
|
|
1177
1177
|
### Completed Tasks
|
|
1178
|
-
${
|
|
1178
|
+
${s.learnings.completedTasks.length>0?s.learnings.completedTasks.map(n=>`- ${n.description}${n.branch?` (${n.branch})`:""}`).join(`
|
|
1179
1179
|
`):"_(No completed tasks yet)_"}
|
|
1180
1180
|
|
|
1181
1181
|
### Resolved Bugs
|
|
1182
|
-
${
|
|
1182
|
+
${s.learnings.resolvedBugs.length>0?s.learnings.resolvedBugs.map(n=>`- ${n.description}`).join(`
|
|
1183
1183
|
`):"_(No resolved bugs yet)_"}
|
|
1184
1184
|
|
|
1185
1185
|
### Shipped Features
|
|
1186
|
-
${
|
|
1186
|
+
${s.learnings.shippedFeatures.length>0?s.learnings.shippedFeatures.map(n=>`- **${n.name}** (v${n.version})${n.description?`: ${n.description}`:""}`).join(`
|
|
1187
1187
|
`):"_(No shipped features yet)_"}
|
|
1188
1188
|
`:"> Run `p. sync` to populate learnings from task history"}
|
|
1189
1189
|
<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->
|
|
1190
|
-
`}function
|
|
1191
|
-
`)}function
|
|
1192
|
-
`)}function
|
|
1193
|
-
`)}function
|
|
1194
|
-
`),models:[],contextProviders:[{name:"code"},{name:"docs"},{name:"diff"},{name:"terminal"},{name:"problems"},{name:"folder"},{name:"codebase"}],slashCommands:[{name:"edit",description:"Edit selected code"},{name:"comment",description:"Add comments to code"},{name:"share",description:"Export conversation"},{name:"cmd",description:"Run terminal command"}],customCommands:[{name:"test",prompt:`Write tests for the selected code. Use the project's testing conventions. Test command: ${
|
|
1195
|
-
`)}function
|
|
1190
|
+
`}function ZC(s,e){let t=s.sources||rs(),n=[];if(n.push("---"),n.push(`description: prjct context for ${s.name}`),n.push("globs:"),n.push("alwaysApply: true"),n.push("---"),n.push(""),n.push(`You are working on ${s.name}, a ${s.projectType} ${s.ecosystem} project.`),n.push(""),n.push($t(t.languages)),n.push("## Tech Stack"),s.languages.length>0&&n.push(`- Languages: ${s.languages.join(", ")}`),s.frameworks.length>0&&n.push(`- Frameworks: ${s.frameworks.join(", ")}`),n.push(""),n.push($t(t.commands)),n.push("## Commands"),n.push(`- Install: \`${s.commands.install}\``),n.push(`- Dev: \`${s.commands.dev}\``),n.push(`- Test: \`${s.commands.test}\``),n.push(`- Build: \`${s.commands.build}\``),n.push(""),s.analysis){s.analysis.patterns?.length>0&&(n.push("## Code Patterns"),n.push(Vr(s.analysis.patterns)),n.push("")),s.analysis.antiPatterns?.length>0&&(n.push("## Anti-Patterns (Avoid)"),n.push(Br(s.analysis.antiPatterns)),n.push(""));let r=su(s.analysis);r&&(n.push(r.trim()),n.push(""))}else n.push("> Run `p. sync` to populate project intelligence");return n.push(""),n.push(Li(s,"concise")),n.join(`
|
|
1191
|
+
`)}function ex(s,e){let t=s.sources||rs(),n=[];return n.push("# Copilot Instructions"),n.push(""),n.push(`This is ${s.name}, a ${s.ecosystem} project.`),n.push(""),n.push($t(t.ecosystem)),n.push("## Project Info"),n.push(`- Type: ${s.projectType}`),n.push(`- Stack: ${s.frameworks.join(", ")||s.ecosystem}`),n.push(""),s.analysis?(s.analysis.patterns?.length>0&&(n.push("## Code Patterns"),n.push(Vr(s.analysis.patterns,5)),n.push("")),s.analysis.antiPatterns?.length>0&&(n.push("## Anti-Patterns"),n.push(Br(s.analysis.antiPatterns,3)),n.push(""))):(n.push("> Run `p. sync` to populate project intelligence"),n.push("")),n.push($t(t.commands)),n.push("## Commands"),n.push(`- Test: \`${s.commands.test}\``),n.push(`- Build: \`${s.commands.build}\``),n.push(""),n.push(Li(s,"concise")),n.join(`
|
|
1192
|
+
`)}function tx(s,e){let t=s.sources||rs(),n=[];return n.push("---"),n.push(`description: prjct context for ${s.name}`),n.push("trigger: always_on"),n.push("---"),n.push(""),n.push(`# ${s.name}`),n.push(""),n.push(`${s.projectType} project using ${s.ecosystem}.`),n.push(""),n.push($t(t.languages)),n.push("## Stack"),n.push(`- ${s.languages.join(", ")}`),s.frameworks.length>0&&n.push(`- ${s.frameworks.join(", ")}`),n.push(""),n.push($t(t.commands)),n.push("## Commands"),n.push("```bash"),n.push("# Install"),n.push(s.commands.install),n.push("# Dev"),n.push(s.commands.dev),n.push("# Test"),n.push(s.commands.test),n.push("# Build"),n.push(s.commands.build),n.push("```"),n.push(""),s.analysis?(s.analysis.patterns?.length>0&&(n.push("## Code Patterns"),n.push(Vr(s.analysis.patterns)),n.push("")),s.analysis.antiPatterns?.length>0&&(n.push("## Anti-Patterns (Avoid)"),n.push(Br(s.analysis.antiPatterns)))):n.push("> Run `p. sync` to populate project intelligence"),n.push(""),n.push(Li(s,"concise")),n.join(`
|
|
1193
|
+
`)}function nx(s,e){let t=[`You are working on ${s.name}, a ${s.projectType} ${s.ecosystem} project.`,"",`Stack: ${s.languages.join(", ")}${s.frameworks.length>0?` with ${s.frameworks.join(", ")}`:""}`,"","Commands:",`- Install: ${s.commands.install}`,`- Dev: ${s.commands.dev}`,`- Test: ${s.commands.test}`,`- Build: ${s.commands.build}`];if(s.analysis?.patterns?.length){t.push("","Code Patterns:");for(let o of s.analysis.patterns)t.push(`- ${o.name}: ${o.description}`)}if(s.analysis?.antiPatterns?.length){t.push("","Anti-Patterns (Avoid):");for(let o of s.analysis.antiPatterns)t.push(`- ${o.issue} in ${o.file} \u2014 ${o.suggestion}`)}s.analysis||t.push("","Run `p. sync` to populate project intelligence."),t.push(""),t.push("prjct Rules:"),t.push(`- All prjct data: ~/.prjct-cli/projects/${s.projectId}/`),t.push('- Workflow: p. sync \u2192 p. task "desc" \u2192 work \u2192 p. done \u2192 p. ship'),t.push(""),t.push(`Project: ${s.name} v${s.version} | ${s.ecosystem} | Branch: ${s.branch} | Files: ~${s.fileCount}`),s.agents.workflow.length>0&&t.push(`Agents: ${[...s.agents.workflow,...s.agents.domain].join(", ")}`);let r={systemMessage:t.join(`
|
|
1194
|
+
`),models:[],contextProviders:[{name:"code"},{name:"docs"},{name:"diff"},{name:"terminal"},{name:"problems"},{name:"folder"},{name:"codebase"}],slashCommands:[{name:"edit",description:"Edit selected code"},{name:"comment",description:"Add comments to code"},{name:"share",description:"Export conversation"},{name:"cmd",description:"Run terminal command"}],customCommands:[{name:"test",prompt:`Write tests for the selected code. Use the project's testing conventions. Test command: ${s.commands.test}`}]};return JSON.stringify(r,null,2)}function sx(s,e){let t=[];return t.push("<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->"),t.push(`# ${s.name} - Project Rules`),t.push(`<!-- projectId: ${s.projectId} -->`),t.push(`<!-- Generated: ${new Date().toISOString()} -->`),t.push(`<!-- Ecosystem: ${s.ecosystem} | Type: ${s.projectType} -->`),t.push(""),t.push(`## THIS PROJECT (${s.ecosystem})`),t.push(""),t.push(`**Type:** ${s.projectType}`),t.push(`**Path:** ${s.repoPath}`),t.push(""),t.push("### Commands (USE THESE, NOT OTHERS)"),t.push(""),t.push("| Action | Command |"),t.push("|--------|---------|"),t.push(`| Install dependencies | \`${s.commands.install}\` |`),t.push(`| Run dev server | \`${s.commands.dev}\` |`),t.push(`| Run tests | \`${s.commands.test}\` |`),t.push(`| Build | \`${s.commands.build}\` |`),t.push(`| Lint | \`${s.commands.lint}\` |`),t.push(`| Format | \`${s.commands.format}\` |`),t.push(""),t.push("### Code Conventions"),t.push(""),t.push(`- **Languages**: ${s.languages.join(", ")||"Not detected"}`),t.push(`- **Frameworks**: ${s.frameworks.join(", ")||"Not detected"}`),s.analysis?(s.analysis.patterns?.length>0&&(t.push(""),t.push("### Code Patterns (Follow These)"),t.push(""),t.push(Vr(s.analysis.patterns))),s.analysis.antiPatterns?.length>0&&(t.push(""),t.push("### Anti-Patterns (Avoid These)"),t.push(""),t.push(Br(s.analysis.antiPatterns))),t.push(su(s.analysis))):(t.push(""),t.push("> Run `p. sync` to populate project intelligence"),t.push("")),t.push("---"),t.push(""),t.push(Li(s,"full")),t.push("<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->"),t.join(`
|
|
1195
|
+
`)}function bf(s){return{claude:QC,cursor:ZC,copilot:ex,windsurf:tx,continue:nx,codex:sx}[s]||null}var ru=k(()=>{"use strict";nu();l(Li,"formatOperationalContext");l(Vr,"formatPatterns");l(Br,"formatAntiPatterns");l(su,"formatStructure");l(YC,"formatAnalysisForClaude");l(QC,"formatForClaude");l(ZC,"formatForCursor");l(ex,"formatForCopilot");l(tx,"formatForWindsurf");l(nx,"formatForContinue");l(sx,"formatForCodex");l(bf,"getFormatter")});import{exec as rx}from"node:child_process";import vf from"node:os";import en from"node:path";import{promisify as ox}from"node:util";function Pf(s){return Hi[s]||null}function Cf(s){let e=vf.homedir();switch(s){case"claude":return en.join(e,".claude","CLAUDE.md");case"gemini":return en.join(e,".gemini","GEMINI.md");case"codex":return en.join(e,".codex","CODEX.md");case"aider":return en.join(e,".aider","AIDER.md");default:return""}}async function Ui(s){try{return await ix(`which ${s}`),!0}catch{return!1}}async function Gi(s=process.cwd()){let e=[];return await Ui("claude")&&e.push("claude"),(await Ui("cursor")||await j(en.join(s,".cursor")))&&e.push("cursor"),await j(en.join(s,".github"))&&e.push("copilot"),(await Ui("windsurf")||await j(en.join(s,".windsurf")))&&e.push("windsurf"),(await j(en.join(s,".continue"))||await j(en.join(vf.homedir(),".continue")))&&e.push("continue"),(await Ui("codex")||await j(en.join(s,".agents")))&&e.push("codex"),e}async function xf(s,e=process.cwd()){if(s==="auto"){let t=await Gi(e);return t.length>0?t:["claude"]}return s==="all"?ax:s.filter(t=>Hi[t])}var ix,Hi,Hs,ax,ou=k(()=>{"use strict";We();ix=ox(rx),Hi={claude:{id:"claude",name:"Claude Code",outputFile:"CLAUDE.md",outputPath:"global",maxTokens:6e3,format:"detailed",description:"Anthropic Claude Code CLI"},cursor:{id:"cursor",name:"Cursor",outputFile:".cursor/rules/prjct.mdc",outputPath:"repo",maxTokens:2e3,format:"concise",description:"Cursor AI Editor"},copilot:{id:"copilot",name:"GitHub Copilot",outputFile:".github/copilot-instructions.md",outputPath:"repo",maxTokens:1500,format:"minimal",description:"GitHub Copilot"},windsurf:{id:"windsurf",name:"Windsurf",outputFile:".windsurf/rules/prjct.md",outputPath:"repo",maxTokens:2e3,format:"concise",description:"Codeium Windsurf Editor"},continue:{id:"continue",name:"Continue.dev",outputFile:".continue/config.json",outputPath:"repo",maxTokens:1500,format:"json",description:"Continue.dev open-source AI assistant"},codex:{id:"codex",name:"OpenAI Codex",outputFile:"AGENTS.md",outputPath:"repo",maxTokens:4e3,format:"detailed",description:"OpenAI Codex CLI"}},Hs=["claude"],ax=Object.keys(Hi);l(Pf,"getAIToolConfig");l(Cf,"getGlobalConfigPath");l(Ui,"commandExists");l(Gi,"detectInstalledTools");l(xf,"resolveToolIds")});import Jr from"node:fs/promises";import cx from"node:path";function Ef(s){let e=s.match(/<!-- projectId: ([a-f0-9-]+) -->/);return e?e[1]:null}function lx(s){let e=[],t="<!-- prjct-project:start - DO NOT REMOVE THIS MARKER -->",n="<!-- prjct-project:end - DO NOT REMOVE THIS MARKER -->",r=0;for(;;){let o=s.indexOf(t,r);if(o===-1)break;let i=s.indexOf(n,o);if(i===-1){console.warn("\u26A0\uFE0F Found project section without end marker, skipping...");break}let a=s.substring(o,i+n.length),c=Ef(a);c&&e.push({projectId:c,startIndex:o,endIndex:i+n.length,content:a}),r=i+n.length}return e}function ux(s){let e="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",t="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->",n=s.indexOf(e),r=s.indexOf(t);return n!==-1&&r!==-1&&r>n?s.substring(n,r+t.length):null}async function Af(s,e,t){if(!t.includes("<!-- prjct-project:start"))throw new Error("New content must include project section markers");let n=Ef(t);if(n!==e)throw new Error(`ProjectId mismatch: expected ${e}, got ${n||"none"}`);await Jr.mkdir(cx.dirname(s),{recursive:!0});let r="";try{r=await Jr.readFile(s,"utf-8")}catch(d){if(d.code!=="ENOENT")throw d}if(!r.trim()){await Tf(s,t);return}let o=ux(r),i=lx(r),a=i.findIndex(d=>d.projectId===e),c;a!==-1?(c=[...i],c[a]={projectId:e,startIndex:0,endIndex:0,content:t}):c=[...i,{projectId:e,startIndex:0,endIndex:0,content:t}];let u="";o&&(u+=`${o}
|
|
1196
1196
|
|
|
1197
1197
|
`);for(let d of c)u+=d.content,d!==c[c.length-1]&&(u+=`
|
|
1198
1198
|
|
|
1199
|
-
`);await
|
|
1199
|
+
`);await Tf(s,u)}async function Tf(s,e){let t=`${s}.tmp.${Date.now()}`;try{await Jr.writeFile(t,e,"utf-8"),await Jr.rename(t,s)}catch(n){try{await Jr.unlink(t)}catch{}throw n}}var Rf=k(()=>{"use strict";l(Ef,"extractProjectId");l(lx,"findProjectSections");l(ux,"extractGlobalSection");l(Af,"updateProjectSection");l(Tf,"writeFileAtomic")});import iu from"node:fs/promises";import au from"node:path";async function Df(s,e,t,n=Hs){let r=[];for(let o of n){let i=Pf(o);if(!i){r.push({toolId:o,outputFile:"",outputPath:"",success:!1,error:`Unknown tool: ${o}`});continue}let a=await dx(s,i,e,t);r.push(a)}return r}async function dx(s,e,t,n){let r=bf(e.id);if(!r)return{toolId:e.id,outputFile:e.outputFile,outputPath:"",success:!1,error:`No formatter for: ${e.id}`};try{let o=r(s,e),i;if(e.outputPath==="repo")i=au.join(n,e.outputFile);else{let a=Cf(e.id);a?i=a:i=au.join(t,"context",e.outputFile)}if(await iu.mkdir(au.dirname(i),{recursive:!0}),e.outputPath==="global")await Af(i,s.projectId,o);else{try{let a=await iu.readFile(i,"utf-8"),c=Qa(a);if(!c.valid){console.warn(`\u26A0\uFE0F ${e.outputFile} has invalid preserve blocks:`);for(let u of c.errors)console.warn(` ${u}`)}o=Ya(o,a)}catch{}await iu.writeFile(i,o,"utf-8")}return{toolId:e.id,outputFile:e.outputFile,outputPath:i,success:!0}}catch(o){return{toolId:e.id,outputFile:e.outputFile,outputPath:"",success:!1,error:y(o)}}}var jf=k(()=>{"use strict";L();Za();ru();ou();Rf();l(Df,"generateAIToolContexts");l(dx,"generateForTool")});var If=k(()=>{"use strict";ru();jf();ou()});async function $f(s){try{let e=E.getDb(s),t=e.prepare(`
|
|
1200
1200
|
SELECT description, completed_at, branch
|
|
1201
1201
|
FROM tasks
|
|
1202
1202
|
WHERE status = 'done' OR status = 'shipped'
|
|
@@ -1209,31 +1209,31 @@ ${r.learnings.shippedFeatures.length>0?r.learnings.shippedFeatures.map(n=>`- **$
|
|
|
1209
1209
|
AND (status = 'done' OR status = 'shipped')
|
|
1210
1210
|
ORDER BY completed_at DESC
|
|
1211
1211
|
LIMIT 5
|
|
1212
|
-
`).all(),
|
|
1212
|
+
`).all(),r=e.prepare(`
|
|
1213
1213
|
SELECT name, description, version
|
|
1214
1214
|
FROM shipped_features
|
|
1215
1215
|
ORDER BY shipped_at DESC
|
|
1216
1216
|
LIMIT 5
|
|
1217
|
-
`).all();return{completedTasks:t.map(o=>({description:o.description,completedAt:o.completed_at||"unknown",branch:o.branch})),resolvedBugs:n.map(o=>({description:o.description,resolution:o.resolution||"completed"})),shippedFeatures:
|
|
1218
|
-
`)}},
|
|
1219
|
-
${
|
|
1220
|
-
`)}`;return
|
|
1217
|
+
`).all();return{completedTasks:t.map(o=>({description:o.description,completedAt:o.completed_at||"unknown",branch:o.branch})),resolvedBugs:n.map(o=>({description:o.description,resolution:o.resolution||"completed"})),shippedFeatures:r.map(o=>({name:o.name,description:o.description||"",version:o.version})),patterns:[]}}catch{return{completedTasks:[],resolvedBugs:[],shippedFeatures:[],patterns:[]}}}var Mf=k(()=>{"use strict";oe();l($f,"extractLearningsFromDB")});import Wi from"node:fs/promises";import zi from"node:path";var cu,lu,Of,Ff=k(()=>{"use strict";L();cu=".prjct/.prjct-state.md",lu=class{static{l(this,"LocalStateGenerator")}async generate(e,t){let n=zi.join(e,cu);await Wi.mkdir(zi.dirname(n),{recursive:!0});let r=this.toMarkdown(t);await Wi.writeFile(n,r,"utf-8")}async remove(e){try{await Wi.unlink(zi.join(e,cu))}catch(t){if(!C(t))throw t}}async exists(e){let t=zi.join(e,cu);try{return await Wi.access(t),!0}catch{return!1}}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 n=e.currentTask;if(t.push("## Current Task"),t.push(""),t.push(`**${n.description}**`),t.push(""),t.push(`- Started: ${n.startedAt}`),n.linearId&&t.push(`- Linear: ${n.linearId}`),n.branch&&t.push(`- Branch: ${n.branch}`),t.push(`- Status: ${n.status||"active"}`),t.push(""),n.subtasks&&n.subtasks.length>0){t.push("### Subtasks"),t.push(""),n.subtasks.forEach((a,c)=>{let u=a.status==="completed"?"\u2705":a.status==="in_progress"?"\u25B6\uFE0F":"\u23F3",d=c===n.currentSubtaskIndex?" \u2190 **Active**":"";t.push(`${c+1}. ${u} ${a.description}${d}`)}),t.push("");let r=n.subtasks.filter(a=>a.status==="completed").length,o=n.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 n=e.previousTask;t.push("---"),t.push(""),t.push("## Previous Task"),t.push(""),t.push(`**${n.description}**`),t.push(""),t.push(`- Status: ${n.status}`),n.prUrl&&t.push(`- PR: ${n.prUrl}`),t.push("")}return t.push("---"),t.push(`*Last updated: ${e.lastUpdated||new Date().toISOString()}*`),t.push(""),t.join(`
|
|
1218
|
+
`)}},Of=new lu});import uu from"node:fs/promises";import px from"node:os";import _f from"node:path";function du(){return _f.join(px.homedir(),".prjct-cli","skills",mx)}function gx(){return{version:1,generatedAt:new Date().toISOString(),skills:{}}}async function qr(){try{let s=await uu.readFile(du(),"utf-8");return JSON.parse(s)}catch{return gx()}}async function pu(s){let e=du();await uu.mkdir(_f.dirname(e),{recursive:!0}),s.generatedAt=new Date().toISOString(),await uu.writeFile(e,JSON.stringify(s,null,2),"utf-8")}async function fx(s){let e=await qr();e.skills[s.name]=s,await pu(e)}async function hx(s){let e=await qr();return s in e.skills?(delete e.skills[s],await pu(e),!0):!1}async function yx(s){return(await qr()).skills[s]||null}async function wx(){return(await qr()).skills}function Sx(){return du()}var mx,Kr,Nf=k(()=>{"use strict";mx=".skill-lock.json";l(du,"getLockFilePath");l(gx,"createEmptyLockFile");l(qr,"read");l(pu,"write");l(fx,"addEntry");l(hx,"removeEntry");l(yx,"getEntry");l(wx,"getAll");l(Sx,"getPath");Kr={read:qr,write:pu,addEntry:fx,removeEntry:hx,getEntry:yx,getAll:wx,getPath:Sx}});import{exec as kx}from"node:child_process";import dn from"node:fs/promises";import gu from"node:os";import ut from"node:path";import{promisify as bx}from"node:util";import{glob as Lf}from"glob";function Hf(s){if(s.startsWith("./")||s.startsWith("/")||s.startsWith("~")){let n=s.startsWith("~")?ut.join(gu.homedir(),s.slice(1)):ut.resolve(s);return{type:"local",localPath:n,url:n}}let e=s.indexOf("@");if(e>0){let n=s.slice(0,e),r=s.slice(e+1),[o,i]=n.split("/");if(o&&i)return{type:"github",owner:o,repo:i,skillName:r,url:`https://github.com/${o}/${i}`}}let t=s.split("/");if(t.length===2&&t[0]&&t[1])return{type:"github",owner:t[0],repo:t[1],url:`https://github.com/${t[0]}/${t[1]}`};throw new Error(`Invalid source format: "${s}". Expected "owner/repo", "owner/repo@skill-name", or "./local-path"`)}async function Gf(s){let e=[];try{let r=ut.join(s,"SKILL.md");await dn.access(r);let o=ut.basename(s);e.push({name:o,filePath:r})}catch{}let t=await Lf("*/SKILL.md",{cwd:s,absolute:!0});for(let r of t){let o=ut.basename(ut.dirname(r));e.some(i=>i.name===o)||e.push({name:o,filePath:r})}let n=await Lf("skills/*/SKILL.md",{cwd:s,absolute:!0});for(let r of n){let o=ut.basename(ut.dirname(r));e.some(i=>i.name===o)||e.push({name:o,filePath:r})}return e}function vx(s,e,t){let n=new Date().toISOString(),r=["_prjct:",` sourceUrl: ${e.url}`,` sourceType: ${e.type}`,` installedAt: ${n}`];t&&r.push(` sha: ${t}`);let o=/^---\s*\n([\s\S]*?)\n---/,i=s.match(o);if(i){let a=i[1];a=a.replace(/\n?_prjct:[\s\S]*?(?=\n[a-zA-Z]|\n---|\s*$)/g,"");let c=`${a.trimEnd()}
|
|
1219
|
+
${r.join(`
|
|
1220
|
+
`)}`;return s.replace(o,`---
|
|
1221
1221
|
${c}
|
|
1222
1222
|
---`)}return`---
|
|
1223
|
-
${
|
|
1223
|
+
${r.join(`
|
|
1224
1224
|
`)}
|
|
1225
1225
|
---
|
|
1226
1226
|
|
|
1227
|
-
${
|
|
1227
|
+
${s}`}function fu(){return ut.join(gu.homedir(),".claude","skills")}async function mu(s,e,t,n){let r=fu(),o=ut.join(r,e),i=ut.join(o,"SKILL.md"),a=await dn.readFile(s,"utf-8"),c=vx(a,t,n);return await dn.mkdir(o,{recursive:!0}),await dn.writeFile(i,c,"utf-8"),{name:e,filePath:i,source:t,sha:n}}async function Px(s){let e={installed:[],skipped:[],errors:[]};if(!Es.isAvailable("git")){let n=Es.checkTool("git");return e.errors.push(`Cannot install from GitHub: git is not available. ${n.error?.hint||"Install git and try again."}`),e}let t=ut.join(gu.tmpdir(),`prjct-skill-${Date.now()}`);try{let n=`https://github.com/${s.owner}/${s.repo}.git`;await Uf(`git clone --depth 1 ${n} ${t}`,{timeout:Ts("GIT_CLONE")});let r;try{let{stdout:a}=await Uf("git rev-parse HEAD",{cwd:t,timeout:Ts("TOOL_CHECK")});r=a.trim()}catch{}let o=await Gf(t);if(o.length===0)return e.errors.push(`No SKILL.md files found in ${s.owner}/${s.repo}`),e;let i=s.skillName?o.filter(a=>a.name===s.skillName):o;if(s.skillName&&i.length===0)return e.errors.push(`Skill "${s.skillName}" not found in ${s.owner}/${s.repo}`),e;for(let a of i)try{let c=await mu(a.filePath,a.name,s,r),u={name:a.name,source:{type:"github",url:`${s.owner}/${s.repo}`,sha:r},installedAt:new Date().toISOString(),filePath:c.filePath};await Kr.addEntry(u),e.installed.push(c)}catch(c){e.errors.push(`Failed to install ${a.name}: ${y(c)}`)}}finally{try{await dn.rm(t,{recursive:!0,force:!0})}catch{}}return e}async function Cx(s){let e={installed:[],skipped:[],errors:[]},t=s.localPath;try{await dn.access(t)}catch{return e.errors.push(`Local path not found: ${t}`),e}if((await dn.stat(t)).isFile()){let r=ut.basename(ut.dirname(t));try{let o=await mu(t,r,s),i={name:r,source:{type:"local",url:t},installedAt:new Date().toISOString(),filePath:o.filePath};await Kr.addEntry(i),e.installed.push(o)}catch(o){e.errors.push(`Failed to install from ${t}: ${y(o)}`)}}else{let r=await Gf(t);if(r.length===0)return e.errors.push(`No SKILL.md files found in ${t}`),e;for(let o of r)try{let i=await mu(o.filePath,o.name,s),a={name:o.name,source:{type:"local",url:t},installedAt:new Date().toISOString(),filePath:i.filePath};await Kr.addEntry(a),e.installed.push(i)}catch(i){e.errors.push(`Failed to install ${o.name}: ${y(i)}`)}}return e}async function xx(s){let e=fu(),t=ut.join(e,s);try{await dn.rm(t,{recursive:!0,force:!0})}catch{}let n=ut.join(e,`${s}.md`);try{await dn.rm(n,{force:!0})}catch{}return Kr.removeEntry(s)}async function Tx(s){let e=Hf(s);switch(e.type){case"github":return Px(e);case"local":return Cx(e);default:return{installed:[],skipped:[],errors:[`Unsupported source type: ${e.type}`]}}}var Uf,Wf,zf=k(()=>{"use strict";L();Cn();Ko();Nf();Uf=bx(kx);l(Hf,"parseSource");l(Gf,"discoverSkills");l(vx,"injectSourceMetadata");l(fu,"getInstallDir");l(mu,"installSkillFile");l(Px,"installFromGitHub");l(Cx,"installFromLocal");l(xx,"remove");l(Tx,"install");Wf={install:Tx,remove:xx,parseSource:Hf,getInstallDir:fu}});import Mt from"node:fs/promises";import Ex from"node:os";import Et from"node:path";async function Vf(s,e,t,n){let r=[],o=Et.join(s,"agents");try{let c=await Mt.readdir(o);for(let u of c)u.endsWith(".md")&&await Mt.unlink(Et.join(o,u))}catch(c){H.debug("Failed to purge old agents",{path:o,error:Z(c)})}let i=["prjct-workflow","prjct-planner","prjct-shipper"];await Promise.all(i.map(c=>Ax(c,o)));for(let c of i)r.push({name:c,type:"workflow"});let a=[];e.hasFrontend&&(a.push({name:"frontend",skill:"javascript-typescript"}),a.push({name:"uxui",skill:"frontend-design"})),e.hasBackend&&a.push({name:"backend",skill:"javascript-typescript"}),e.hasDatabase&&a.push({name:"database"}),e.hasTesting&&a.push({name:"testing",skill:"developer-kit"}),e.hasDocker&&a.push({name:"devops",skill:"developer-kit"}),await Promise.all(a.map(c=>Rx(c.name,o,t,e,n)));for(let c of a)r.push({name:c.name,type:"domain",skill:c.skill});return r}async function Bf(s){let e=Et.join(s,"agents"),t=[];try{let n=await Mt.readdir(e),r=new Set(["prjct-workflow","prjct-planner","prjct-shipper"]);for(let o of n){if(!o.endsWith(".md"))continue;let i=o.replace(".md",""),a=r.has(i)?"workflow":"domain";t.push({name:i,type:a})}}catch{return[]}return t}async function Jf(s){let e=/\{\{>\s*([\w-]+)\s*\}\}/g,t=[...s.matchAll(e)];if(t.length===0)return s;let n=s;for(let r of t){let o=r[1],i=he(`subagents/${o}.md`);if(!i){let a=Et.join(__dirname,"..","..","templates","subagents",`${o}.md`);try{i=await Mt.readFile(a,"utf-8")}catch{n=n.replace(r[0],`<!-- partial "${o}" not found -->`);continue}}n=n.replace(r[0],i.trim())}return n}async function Ax(s,e){let t="";try{let n=Et.join(__dirname,"..","..","templates","subagents","workflow",`${s}.md`);t=await Mt.readFile(n,"utf-8"),t=await Jf(t)}catch(n){H.debug("Workflow agent template not found, generating minimal",{name:s,error:Z(n)}),t=jx(s)}await Mt.writeFile(Et.join(e,`${s}.md`),t,"utf-8")}async function Rx(s,e,t,n,r){let o="";try{let i=Et.join(__dirname,"..","..","templates","subagents","domain",`${s}.md`);o=await Mt.readFile(i,"utf-8"),o=await Jf(o),o=o.replace("{projectName}",t.name),o=o.replace("{frameworks}",n.frameworks.join(", ")||"None detected"),o=o.replace("{ecosystem}",t.ecosystem)}catch(i){H.debug("Domain agent template not found, generating minimal",{name:s,error:Z(i)}),o=Ix(s,t,n)}o=Dx(o,s,r),await Mt.writeFile(Et.join(e,`${s}.md`),o,"utf-8")}function Dx(s,e,t){if(!t)return s;let{patternsDiscovered:n,knownGotchas:r,agentAccuracy:o}=t,i=o.filter(u=>u.agent===`${e}.md`||u.agent===e);if(!(n.length>0||r.length>0||i.length>0))return s;let c=[`
|
|
1228
1228
|
## Recent Learnings (from completed tasks)
|
|
1229
|
-
`];if(n.length>0){c.push("### Discovered Patterns");for(let u of n)c.push(`- ${u}`);c.push("")}if(
|
|
1230
|
-
`)}function
|
|
1231
|
-
name: ${
|
|
1232
|
-
description: ${{"prjct-workflow":"Task lifecycle: now, done, pause, resume","prjct-planner":"Planning: task, prd, spec, bug","prjct-shipper":"Shipping: ship, merge, review"}[
|
|
1229
|
+
`];if(n.length>0){c.push("### Discovered Patterns");for(let u of n)c.push(`- ${u}`);c.push("")}if(r.length>0){c.push("### Known Gotchas");for(let u of r)c.push(`- ${u}`);c.push("")}if(i.length>0){c.push("### Agent Accuracy Notes");for(let u of i){let d=u.note?` \u2014 ${u.note}`:"";c.push(`- ${u.rating}${d}`)}c.push("")}return s+c.join(`
|
|
1230
|
+
`)}function jx(s){return`---
|
|
1231
|
+
name: ${s}
|
|
1232
|
+
description: ${{"prjct-workflow":"Task lifecycle: now, done, pause, resume","prjct-planner":"Planning: task, prd, spec, bug","prjct-shipper":"Shipping: ship, merge, review"}[s]||"Workflow agent"}
|
|
1233
1233
|
tools: Read, Write, Glob
|
|
1234
1234
|
---
|
|
1235
1235
|
|
|
1236
|
-
# ${
|
|
1236
|
+
# ${s.toUpperCase()}
|
|
1237
1237
|
|
|
1238
1238
|
Workflow agent for prjct operations.
|
|
1239
1239
|
|
|
@@ -1243,16 +1243,16 @@ When invoked:
|
|
|
1243
1243
|
1. Read \`.prjct/prjct.config.json\` \u2192 extract \`projectId\`
|
|
1244
1244
|
2. Read \`~/.prjct-cli/projects/{projectId}/storage/state.json\`
|
|
1245
1245
|
3. Execute requested operation
|
|
1246
|
-
`}function
|
|
1247
|
-
name: ${
|
|
1248
|
-
description: ${
|
|
1246
|
+
`}function Ix(s,e,t){return`---
|
|
1247
|
+
name: ${s}
|
|
1248
|
+
description: ${s.charAt(0).toUpperCase()+s.slice(1)} specialist for ${e.name}
|
|
1249
1249
|
tools: Read, Write, Glob, Grep
|
|
1250
1250
|
skills: []
|
|
1251
1251
|
---
|
|
1252
1252
|
|
|
1253
|
-
# ${
|
|
1253
|
+
# ${s.toUpperCase()} AGENT
|
|
1254
1254
|
|
|
1255
|
-
Domain specialist for ${
|
|
1255
|
+
Domain specialist for ${s} tasks.
|
|
1256
1256
|
|
|
1257
1257
|
## Project Context
|
|
1258
1258
|
|
|
@@ -1262,57 +1262,57 @@ Domain specialist for ${r} tasks.
|
|
|
1262
1262
|
|
|
1263
1263
|
## Your Role
|
|
1264
1264
|
|
|
1265
|
-
You are the ${
|
|
1266
|
-
`}function
|
|
1267
|
-
`).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
|
|
1268
|
-
`).filter(Boolean).map(u=>{let[d,m,p]=u.split("|");return{hash:d,message:m,date:p}});let{stdout:c}=await ls('git log --oneline --since="1 week ago" | wc -l',{cwd:r});e.weeklyCommits=parseInt(c.trim(),10)||0}catch(t){H.debug("Git analysis failed (not a git repo?)",{error:Z(t)})}return e}async function an(r,e){try{return await dh.access(Eu.join(r,e)),!0}catch(t){return H.debug("File not found",{filename:e,error:Z(t)}),!1}}async function mh(r){let e={fileCount:0,version:"0.0.0",name:Eu.basename(r),ecosystem:"unknown",projectType:"simple",languages:[],frameworks:[]};try{let{stdout:t}=await ls('find . -type f \\( -name "*.js" -o -name "*.ts" -o -name "*.tsx" -o -name "*.py" -o -name "*.go" -o -name "*.rs" \\) -not -path "./node_modules/*" -not -path "./.git/*" | wc -l',{cwd:r});e.fileCount=parseInt(t.trim(),10)||0}catch(t){H.debug("File count failed",{path:r,error:Z(t)}),e.fileCount=0}try{let t=Eu.join(r,"package.json"),n=JSON.parse(await dh.readFile(t,"utf-8"));e.version=n.version||"0.0.0",e.name=n.name||e.name,e.ecosystem="JavaScript";let s={...n.dependencies,...n.devDependencies};(s.react||s["react-dom"])&&e.frameworks.push("React"),s.next&&e.frameworks.push("Next.js"),s.vue&&e.frameworks.push("Vue"),s.express&&e.frameworks.push("Express"),s.hono&&e.frameworks.push("Hono"),s["@angular/core"]&&e.frameworks.push("Angular"),s.svelte&&e.frameworks.push("Svelte"),n.devDependencies?.typescript||await an(r,"tsconfig.json")?e.languages.push("TypeScript"):e.languages.push("JavaScript")}catch(t){H.debug("No package.json found",{path:r,error:Z(t)})}return await an(r,"Cargo.toml")&&(e.ecosystem="Rust",e.languages.push("Rust")),await an(r,"go.mod")&&(e.ecosystem="Go",e.languages.push("Go")),(await an(r,"requirements.txt")||await an(r,"pyproject.toml"))&&(e.ecosystem="Python",e.languages.push("Python")),e.fileCount>300||e.frameworks.length>=3?e.projectType="enterprise":(e.fileCount>50||e.frameworks.length>=2)&&(e.projectType="complex"),e}async function gh(r){let e={install:"npm install",run:"npm run",test:"npm test",build:"npm run build",dev:"npm run dev",lint:"npm run lint",format:"npm run format"};return await an(r,"bun.lockb")?(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 an(r,"pnpm-lock.yaml")?(e.install="pnpm install",e.run="pnpm run",e.test="pnpm test",e.build="pnpm run build",e.dev="pnpm run dev",e.lint="pnpm run lint",e.format="pnpm run format"):await an(r,"yarn.lock")&&(e.install="yarn",e.run="yarn",e.test="yarn test",e.build="yarn build",e.dev="yarn dev",e.lint="yarn lint",e.format="yarn format"),await an(r,"Cargo.toml")&&(e.install="cargo build",e.run="cargo run",e.test="cargo test",e.build="cargo build --release",e.dev="cargo run",e.lint="cargo clippy",e.format="cargo fmt"),await an(r,"go.mod")&&(e.install="go mod download",e.run="go run .",e.test="go test ./...",e.build="go build",e.dev="go run .",e.lint="golangci-lint run",e.format="go fmt ./..."),e}function fh(r,e){let t=cs(),s={JavaScript:"package.json",Rust:"Cargo.toml",Go:"go.mod",Python:"pyproject.toml"}[r.ecosystem]||"filesystem",o=l(a=>({file:a,type:"detected"}),"detected"),i=l(a=>({file:a,type:"inferred"}),"inferred");return t.ecosystem=o(s),t.name=o(s),t.version=o(s),t.languages=o(s),t.frameworks=o(s),e.install.startsWith("bun")?t.commands=o("bun.lockb"):e.install.startsWith("pnpm")?t.commands=o("pnpm-lock.yaml"):e.install==="yarn"?t.commands=o("yarn.lock"):e.install.startsWith("cargo")?t.commands=o("Cargo.toml"):e.install.startsWith("go")?t.commands=o("go.mod"):t.commands=o("package.json"),t.projectType=i("file count + frameworks"),t.git=o("git"),t}async function hh(r){return new Xi(r).detect()}var ls,yh=k(()=>{"use strict";un();mu();Dn();uh();ls=Bx(Vx);l(ph,"analyzeGit");l(an,"fileExists");l(mh,"gatherStats");l(gh,"detectCommands");l(fh,"buildSources");l(hh,"detectStack")});import{exec as Jx}from"node:child_process";import Au from"node:fs/promises";import Yi from"node:path";import{promisify as qx}from"node:util";var Kx,Iu,Ru,wh,Sh=k(()=>{"use strict";nn();F();Kx=qx(Jx),Iu={async contextFilesExist(r){let e=Date.now(),t=["context/CLAUDE.md"],n=[];for(let s of t){let o=Yi.join(r,s);try{await Au.access(o)}catch{n.push(s)}}return{name:"Context files exist",passed:n.length===0,output:n.length===0?`${t.length} files verified`:void 0,error:n.length>0?`Missing: ${n.join(", ")}`:void 0,durationMs:Date.now()-e}},async jsonFilesValid(r){let e=Date.now(),t=[],n=Yi.basename(r);try{await L.read(n)}catch(s){P(s)||t.push(`state: ${w(s)}`)}return{name:"State data valid",passed:t.length===0,output:t.length===0?"1 store validated":void 0,error:t.length>0?t.join("; "):void 0,durationMs:Date.now()-e}},async noSensitiveData(r){let e=Date.now(),t=Yi.join(r,"context"),n=[/(?:api[_-]?key|apikey)\s*[:=]\s*['"][^'"]{10,}/i,/(?:password|passwd|pwd)\s*[:=]\s*['"][^'"]{4,}/i,/(?:secret|token)\s*[:=]\s*['"][^'"]{10,}/i],s=[];try{let o=await Au.readdir(t);for(let i of o){if(!i.endsWith(".md"))continue;let a=await Au.readFile(Yi.join(t,i),"utf-8");for(let c of n)if(c.test(a)){s.push(`${i}: potential sensitive data detected`);break}}}catch(o){if(!P(o))return{name:"No sensitive data",passed:!1,error:`Could not scan: ${w(o)}`,durationMs:Date.now()-e}}return{name:"No sensitive data",passed:s.length===0,output:s.length===0?"No sensitive patterns found":void 0,error:s.length>0?s.join("; "):void 0,durationMs:Date.now()-e}}},Ru=class{static{l(this,"SyncVerifier")}async verify(e,t,n){let s=Date.now(),o=[],i=n?.failFast??!1,a=0,c=[Iu.contextFilesExist(t),Iu.jsonFilesValid(t),Iu.noSensitiveData(t)];for(let p of c){let g=await p;if(o.push(g),!g.passed&&i){a=n?.checks?.filter(f=>f.enabled!==!1).length??0;break}}if((!i||o.every(p=>p.passed))&&n?.checks)for(let p of n.checks){if(p.enabled===!1){a++;continue}let g=await this.runCustomCheck(p,e);if(o.push(g),!g.passed&&i){let f=n.checks.slice(n.checks.indexOf(p)+1);a+=f.filter(S=>S.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()-s,failedCount:d,passedCount:m,skippedCount:a}}async runCustomCheck(e,t){let n=Date.now(),s=e.command||(e.script?`sh ${e.script}`:null);if(!s)return{name:e.name,passed:!1,error:"No command or script specified",durationMs:Date.now()-n};try{let{stdout:o,stderr:i}=await Kx(s,{cwd:t,timeout:3e4});return{name:e.name,passed:!0,output:(o.trim()||i.trim()).slice(0,200)||void 0,durationMs:Date.now()-n}}catch(o){let i=o;return{name:e.name,passed:!1,error:(i.stderr?.trim()||i.message).slice(0,200),durationMs:Date.now()-n}}}},wh=new Ru});import Qi from"node:fs/promises";import Zi from"node:path";var ea,On,Du=k(()=>{"use strict";Pr();su();gf();yf();bf();ou();un();qe();dn();xt();Pe();zi();$r();In();se();Or();ci();ui();Ms();Fr();Os();zf();Vf();ce();Dn();yl();wl();As();Jf();Mc();Hc();ah();yh();Sh();ea=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 n=Date.now(),s;if(!t.aiTools||t.aiTools.length===0){let i=await Ji(e),a=i.filter(u=>zs.includes(u)||u==="codex"),c=i.filter(u=>!zs.includes(u)&&u!=="codex");s=[...a.length>0?a:zs,...c],s=Array.from(new Set(s))}else t.aiTools[0]==="auto"?(s=await Ji(e),s.length===0&&(s=["claude"])):t.aiTools[0]==="all"?s=await _f("all",e):s=t.aiTools;let o={installed:!1,verified:!1,configPath:"",message:""};try{if(this.projectId=await M.getProjectId(e),!this.projectId)return{success:!1,projectId:"",cliVersion:"",git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),agents:[],skills:[],skillsInstalled:[],contextFiles:[],aiTools:[],context7:{installed:!1,verified:!1},error:"No prjct project. Run p. init first."};if(this.globalPath=A.getGlobalProjectPath(this.projectId),this.cliVersion=await this.getCliVersion(),(await Un()).installed){let _=await Gi({autoRepair:!0});_.verified||H.warn(`Codex p. router not ready: ${_.message||"verification failed"}`)}try{o=await pn.ensureReady()}catch(_){return{success:!1,projectId:this.projectId,cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),agents:[],skills:[],skillsInstalled:[],contextFiles:[],aiTools:[],context7:{installed:o.installed,verified:!1,message:Z(_)},error:`Context7 MCP is required but not ready: ${Z(_)}. Run 'prjct start' to repair.`}}await this.ensureDirectories(),await _r(this.projectId);try{let _=await li(this.projectId);_>0&&H.info("Swept legacy JSON files into SQLite",{swept:_})}catch(_){H.debug("Legacy JSON sweep failed (non-critical)",{error:Z(_)})}let[c,u,d,m]=await Promise.all([ph(this.projectPath),mh(this.projectPath),gh(this.projectPath),hh(this.projectPath)]),p=t.full===!0,g,f=!0,S=!0,y=new Set;if(!p&&hf(this.projectId))try{let{diff:_,currentHashes:Ey}=await cu(this.projectPath,this.projectId),ad=_.added.length+_.modified.length+_.deleted.length;if(ad===0&&!t.changedFiles?.length)f=!1,S=!1,g={isIncremental:!0,filesChanged:0,filesUnchanged:_.unchanged.length,indexesRebuilt:!1,agentsRegenerated:!1,affectedDomains:[]};else{let xa=pf(_,this.projectId);y=mf(xa.allAffected);let Ay=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]);f=xa.allAffected.some(Nn=>{let Iy=Nn.substring(Nn.lastIndexOf("."));return Ay.has(Iy)}),S=xa.directlyChanged.some(Nn=>Nn==="package.json"||Nn==="tsconfig.json"||Nn.includes("Dockerfile")||Nn.includes("docker-compose")),g={isIncremental:!0,filesChanged:ad,filesUnchanged:_.unchanged.length,indexesRebuilt:f,agentsRegenerated:S,affectedDomains:Array.from(y)}}au(this.projectId,Ey)}catch(_){H.debug("Incremental detection failed, falling back to full sync",{error:Z(_)})}else try{let{currentHashes:_}=await cu(this.projectPath,this.projectId);au(this.projectId,_)}catch(_){H.debug("Hash computation failed (non-critical)",{error:Z(_)})}if(f)try{await Promise.all([of(this.projectPath,this.projectId),df(this.projectPath,this.projectId),kf(this.projectPath,this.projectId)])}catch(_){H.debug("File ranking index build failed (non-critical)",{error:Z(_)})}let C;if(S)try{let _=await L.getAggregatedFeedback(this.projectId);(_.patternsDiscovered.length>0||_.knownGotchas.length>0||_.agentAccuracy.length>0)&&(C=_)}catch{}let E=S?await nh(this.globalPath,m,u,C):await sh(this.globalPath),N=oh(E,this.projectId,this.globalPath),ne=S?await ih(E):[],oe=fh(u,d),be=[],v;try{let _=await Je.getActive(this.projectId);(_?.patterns?.length||_?.antiPatterns?.length)&&(v={patterns:_.patterns??[],antiPatterns:_.antiPatterns??[],packageManager:_.packageManager,sourceDir:_.sourceDir,testDir:_.testDir})}catch{}let $;try{$=await Wf(this.projectId)}catch{}let _e={projectId:this.projectId,name:u.name,version:u.version,ecosystem:u.ecosystem,projectType:u.projectType,languages:u.languages,frameworks:u.frameworks,repoPath:this.projectPath,branch:c.branch,fileCount:u.fileCount,commits:c.commits,hasChanges:c.hasChanges,commands:d,agents:{workflow:E.filter(_=>_.type==="workflow").map(_=>_.name),domain:E.filter(_=>_.type==="domain").map(_=>_.name)},sources:oe,analysis:v,learnings:$},dr=await Hf(_e,this.globalPath,this.projectPath,s);await Promise.all([this.updateProjectJson(c,u),this.updateStateJson(u,m),this.logToMemory(c,u),this.saveDraftAnalysis(c,u,m,o.verified)]);let pr=await Je.getActive(this.projectId),va={patterns:pr?.patterns?.length||0,antiPatterns:pr?.antiPatterns?.length||0,criticalAntiPatterns:pr?.antiPatterns?.filter(_=>_.severity==="high").length||0},Pa=Date.now()-n,Ca=await this.recordSyncMetrics(u,be,E,Pa);await this.archiveStaleData(),await this.autoLearnFromHistory(),await je.installGlobalConfig(),await je.syncCommands();let ht;try{let _=await M.readConfig(this.projectPath);ht=await wh.verify(this.projectPath,this.globalPath,_?.verification)}catch(_){H.debug("Verification failed (non-critical)",{error:Z(_)})}return{success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:c,stats:u,commands:d,stack:m,agents:E,skills:N,skillsInstalled:ne,contextFiles:be,aiTools:dr.map(_=>({toolId:_.toolId,outputFile:_.outputFile,success:_.success})),context7:{installed:o.installed,verified:o.verified,message:o.message},analysisSummary:va,syncMetrics:Ca,verification:ht,incremental:g}}catch(i){return{success:!1,projectId:this.projectId||"",cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),agents:[],skills:[],skillsInstalled:[],contextFiles:[],aiTools:[],context7:{installed:o.installed,verified:o.verified,message:o.message},error:Z(i)}}}async ensureDirectories(){let e=["storage","context","agents","memory","analysis","config","sync"];await Promise.all(e.map(t=>Qi.mkdir(Zi.join(this.globalPath,t),{recursive:!0})))}async updateProjectJson(e,t){let n=T.getDoc(this.projectId,"project")||{},s={...n,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:n.createdAt||b(),lastSync:b(),lastSyncCommit:e.recentCommits[0]?.hash||null,lastSyncBranch:e.branch};T.setDoc(this.projectId,"project",s)}async updateStateJson(e,t){let s={...await L.read(this.projectId)};s.projectId=this.projectId,s.stack={language:e.languages[0]||"Unknown",framework:e.frameworks[0]||null},s.domains={hasFrontend:t.hasFrontend,hasBackend:t.hasBackend,hasDatabase:t.hasDatabase,hasTesting:t.hasTesting,hasDocker:t.hasDocker},s.projectType=e.projectType,s.metrics={totalFiles:e.fileCount},s.lastSync=b(),s.lastUpdated=b(),s.context={...s.context||{},lastSession:b(),lastAction:"Synced project",nextAction:'Run `p. task "description"` to start working'},await L.write(this.projectId,s);try{await Bf.generate(this.projectPath,s)}catch(o){H.debug("Local state generation failed (optional)",{error:Z(o)})}}async logToMemory(e,t){T.appendEvent(this.projectId,"sync",{branch:e.branch,uncommitted:e.hasChanges,fileCount:t.fileCount,commitCount:e.commits})}async recordSyncMetrics(e,t,n,s){let i=0;for(let m of t)try{let p=Zi.join(this.globalPath,m),g=await Qi.readFile(p,"utf-8");i+=g.length}catch(p){H.debug("Context file not found for metrics",{file:m,error:Z(p)})}for(let m of n)try{let p=Zi.join(this.globalPath,"agents",`${m.name}.md`),g=await Qi.readFile(p,"utf-8");i+=g.length}catch(p){H.debug("Agent file not found for metrics",{agent:m.name,error:Z(p)})}let a=Math.floor(i/4),u=e.fileCount*500,d=u>0?Math.max(0,(u-a)/u):0;try{await Yn.recordSync(this.projectId,{originalSize:u,filteredSize:a,duration:s,isWatch:!1,agents:n.filter(m=>m.type==="domain").map(m=>m.name)})}catch(m){H.debug("Failed to record sync metrics",{error:Z(m)})}return{duration:s,originalSize:u,filteredSize:a,compressionRate:d}}async saveDraftAnalysis(e,t,n,s){try{let o=e.recentCommits[0]?.hash||null,i=[],a=[],c;try{c=await L.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 im.extract({projectId:this.projectId,projectPath:this.projectPath,languages:t.languages,frameworks:Array.from(new Set([...t.frameworks,...n.frameworks])),feedback:c,context7Verified:s});i=u.patterns,a=u.antiPatterns,await Je.saveDraft(this.projectId,{projectId:this.projectId,languages:t.languages,frameworks:t.frameworks,configFiles:[],fileCount:t.fileCount,patterns:i,antiPatterns:a,analyzedAt:b(),status:"draft",commitHash:o??void 0})}catch(o){H.debug("Failed to save draft analysis (non-critical)",{error:Z(o)})}}async archiveStaleData(){if(this.projectId)try{let[e,t,n,s,o]=await Promise.all([St.archiveOldShipped(this.projectId).catch(()=>0),tt.markDormantIdeas(this.projectId).catch(()=>0),ke.removeStaleCompleted(this.projectId).catch(()=>0),L.archiveStalePausedTasks(this.projectId).catch(()=>[]),wt.capEntries(this.projectId).catch(()=>0)]),i=e+t+n+s.length+o;if(i>0){H.info("Archived stale data",{shipped:e,dormant:t,staleQueue:n,stalePaused:s.length,memoryCapped:o,total:i});let a=Tt.getStats(this.projectId);H.debug("Archive stats",a)}}catch(e){H.debug("Archival failed (non-critical)",{error:Z(e)})}}async autoLearnFromHistory(){if(this.projectId)try{let e=await L.getTaskHistory(this.projectId);if(e.length===0)return;let t=new Gn,n=await hl.learnFromTaskHistory(this.projectId,e,t);try{let s=await Rm.getFeatureOutcomes(this.projectId);s.length>0&&await hl.learnFromOutcomes(this.projectId,s,t)}catch{}n.memoriesInjected>0&&H.info("Auto-learned from task history",{patternsExtracted:n.patternsExtracted,memoriesInjected:n.memoriesInjected,patternsSkipped:n.patternsSkipped})}catch(e){H.debug("Auto-learning failed (non-critical)",{error:Z(e)})}}async getCliVersion(){try{let e=Zi.join(__dirname,"..","..","package.json");return JSON.parse(await Qi.readFile(e,"utf-8")).version||"0.0.0"}catch(e){return H.debug("Failed to read CLI version",{error:Z(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:[]}}},On=new ea});var bh,vh,Ph,us,kh,Ch,xh,Xx,Yx,ju=k(()=>{"use strict";es();bh=[1,2,3,5,8,13,21],vh={1:{min:5,max:15,typical:10},2:{min:15,max:30,typical:20},3:{min:30,max:60,typical:45},5:{min:60,max:120,typical:90},8:{min:120,max:240,typical:180},13:{min:240,max:480,typical:360},21:{min:480,max:960,typical:720}},Ph=l(r=>bh.includes(r),"isValidPoint"),us=l(r=>vh[r],"pointsToMinutes"),kh=l(r=>{if(r<60)return`${r}m`;let e=Math.floor(r/60),t=r%60;return t>0?`${e}h ${t}m`:`${e}h`},"formatMinutes"),Ch=l(r=>{let e=us(r);return`${kh(e.min)}\u2013${kh(e.max)}`},"pointsToTimeRange"),xh=l(async(r,e)=>{let n=(await ft.getAll(r)).filter(a=>a.tags?.includes(e));if(n.length<3)return null;let o=n.reduce((a,c)=>a+Yx(c.actualDuration),0)/n.length;return{points:Xx(o),basedOn:n.length}},"suggestFromHistory"),Xx=l(r=>{let e=1,t=Number.POSITIVE_INFINITY;for(let n of bh){let s=Math.abs(vh[n].typical-r);s<t&&(t=s,e=n)}return e},"findClosestPoint"),Yx=l(r=>{let e=0,t=r.match(/(\d+)h/);t&&(e+=Number.parseInt(t[1],10)*60);let n=r.match(/(\d+)m/);return n&&(e+=Number.parseInt(n[1],10)),e},"parseDuration")});function Qx(r){switch(r){case"low":return 2;case"medium":return 5;case"high":return 8}}async function Th(r,e){let t=Bn.detectTaskType(e),n=await xh(r,t);if(n){let a=us(n.points);return{taskType:t,estimatedPoints:n.points,estimatedMinutes:a.typical,source:"history"}}let s=Bn.estimateComplexity(e),o=Qx(s.level),i=us(o);return{taskType:t,estimatedPoints:o,estimatedMinutes:i.typical,source:"heuristic"}}var $u,Mu=k(()=>{"use strict";ju();wc();l(Qx,"complexityToPoints");l(Th,"estimateTaskForStart");$u=Th});import{exec as Zx}from"node:child_process";import Ws from"node:path";import{promisify as eT}from"node:util";function Ah(r){return/^\d+\.\d+\.\d+/.test(r)}function Vs(r){let e=r.match(/^(\d+)\.(\d+)\.(\d+)/);if(!e)return r;let[,t,n,s]=e;return`${t}.${n}.${Number(s)+1}`}function tT(r){let e=r.match(/\[package\]([\s\S]*?)(?=\n\[|\n*$)/);return e?e[1].match(/^\s*version\s*=\s*"([^"]+)"/m)?.[1]??null:null}function nT(r){let e=r.match(/\[project\]([\s\S]*?)(?=\n\[|\n*$)/);if(e){let n=e[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(n)return n[1]}let t=r.match(/\[tool\.poetry\]([\s\S]*?)(?=\n\[|\n*$)/);if(t){let n=t[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(n)return n[1]}return null}function sT(r){return r.match(/<Version>([^<]+)<\/Version>/)?.[1]?.trim()??null}var Eh,eo,Ih=k(()=>{"use strict";Ue();Eh=eT(Zx),eo=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 n=await t();if(n)return n}return this.createFallbackVersion()}async bump(){let e=await this.detect();return await this.writeVersion(e),e.next}async fromPackageJson(){let e=Ws.join(this.projectPath,"package.json"),t=await Kt(e,null);return t?.version?{current:t.version,next:Vs(t.version),file:e,format:"json"}:null}async fromCargoToml(){let e=Ws.join(this.projectPath,"Cargo.toml"),t=await it(e,"");if(!t)return null;let n=tT(t);return n?{current:n,next:Vs(n),file:e,format:"toml"}:null}async fromPyprojectToml(){let e=Ws.join(this.projectPath,"pyproject.toml"),t=await it(e,"");if(!t)return null;let n=nT(t);return n?{current:n,next:Vs(n),file:e,format:"toml"}:null}async fromCsproj(){let e=await ln(this.projectPath,{extension:".csproj"});if(e.length===0)return null;let t=Ws.join(this.projectPath,e[0]),n=await it(t,"");if(!n)return null;let s=sT(n);return s?{current:s,next:Vs(s),file:t,format:"xml"}:null}async fromVersionFile(e){let t=Ws.join(this.projectPath,e),n=await it(t,"");if(!n)return null;let s=n.trim();return Ah(s)?{current:s,next:Vs(s),file:t,format:"plaintext"}:null}async fromGitTag(){try{let{stdout:e}=await Eh("git tag --sort=-v:refname",{cwd:this.projectPath}),t=e.trim().split(`
|
|
1269
|
-
`);for(let n of t){let
|
|
1270
|
-
`),{current:"0.1.0",next:"0.1.1",file:e,format:"plaintext"}}async writeVersion(e){if(!e.file){e.format==="git-tag"&&await
|
|
1271
|
-
`);break}}async writeJsonVersion(e,t){let n=await
|
|
1272
|
-
// ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):n.push({path:a.path,content:u.slice(0,
|
|
1273
|
-
`),t=[],n=null;for(let
|
|
1274
|
-
${o}`)}return n&&(n.endLine=e.length-1,t.push(n)),t}function
|
|
1275
|
-
`).length});for(let a of n){let c=a.name.toLowerCase(),u=o.get(c);u?u.content.trim()!==a.content.trim()&&(
|
|
1276
|
-
`).length}),
|
|
1277
|
-
`).length}),
|
|
1278
|
-
`).length}),
|
|
1279
|
-
`);if(n.push(""),n.push(c("\u{1F4CB} Changes to context files:")),n.push(""),
|
|
1280
|
-
`)}function
|
|
1281
|
-
`))n.push(
|
|
1265
|
+
You are the ${s} expert for this project. Apply best practices for the detected stack.
|
|
1266
|
+
`}function qf(s,e,t){let n=[];for(let o of s)o.skill&&n.push({agent:o.name,skill:o.skill});let r={projectId:e,syncedAt:b(),skills:n.map(o=>({name:o.skill,linkedAgents:[o.agent]})),agentSkillMap:Object.fromEntries(n.map(o=>[o.agent,o.skill]))};return Mt.writeFile(Et.join(t,"config","skills.json"),JSON.stringify(r,null,2),"utf-8").catch(o=>{H.debug("Failed to write skills.json",{error:Z(o)})}),n}async function Kf(s){let e=[];try{let t=Et.join(__dirname,"..","..","templates","config","skill-mappings.json"),n=await Mt.readFile(t,"utf-8"),o=JSON.parse(n).agentToSkillMap||{},i=[];for(let c of s){let u=o[c.name];if(u?.packages)for(let d of u.packages)i.push({pkg:d,agent:c.name})}if(i.length===0)return e;let a=Et.join(Ex.homedir(),".claude","skills");for(let{pkg:c,agent:u}of i){let d=c.split("/").pop()||c,m=Et.join(a,d,"SKILL.md"),p=Et.join(a,`${d}.md`),g=!1;try{await Mt.access(m),g=!0}catch{try{await Mt.access(p),g=!0}catch{}}if(g){e.push({name:d,agent:u,status:"skipped"});continue}try{let f=c.split("/"),S;f.length===3?S=`${f[0]}/${f[1]}@${f[2]}`:S=c;let w=await Wf.install(S);w.installed.length>0?(e.push({name:d,agent:u,status:"installed"}),H.info(`Installed skill: ${d} for agent: ${u}`)):w.errors.length>0?(e.push({name:d,agent:u,status:"error"}),H.debug(`Failed to install skill ${d}`,{errors:w.errors})):e.push({name:d,agent:u,status:"skipped"})}catch(f){e.push({name:d,agent:u,status:"error"}),H.debug(`Skill install error for ${d}`,{error:Z(f)})}}}catch(t){H.debug("Skill auto-installation failed (non-critical)",{error:Z(t)})}return e}var Xf=k(()=>{"use strict";qt();rn();ce();En();zf();l(Vf,"generateAgents");l(Bf,"loadExistingAgents");l(Jf,"resolveTemplateIncludes");l(Ax,"generateWorkflowAgent");l(Rx,"generateDomainAgent");l(Dx,"injectFeedbackSection");l(jx,"generateMinimalWorkflowAgent");l(Ix,"generateMinimalDomainAgent");l(qf,"configureSkills");l(Kf,"autoInstallSkills")});import Yf from"node:fs/promises";import Qf from"node:path";var Vi,Zf=k(()=>{"use strict";Vi=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 n={...t.dependencies,...t.devDependencies};this.detectFrontend(n,e),this.detectBackend(n,e),this.detectDatabase(n,e),this.detectTesting(n,t,e),this.collectFrameworks(n,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,n){["jest","vitest","mocha","@testing-library/react","@testing-library/vue","cypress","playwright","@playwright/test","ava","tap","bun-types"].some(o=>e[o]||t.devDependencies?.[o])&&(n.hasTesting=!0)}async detectDocker(){let e=["Dockerfile","docker-compose.yml","docker-compose.yaml",".dockerignore"];for(let t of e)if(await this.fileExists(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=Qf.join(this.projectPath,"package.json"),t=await Yf.readFile(e,"utf-8");return JSON.parse(t)}catch{return null}}async fileExists(e){try{return await Yf.access(Qf.join(this.projectPath,e)),!0}catch{return!1}}}});import{exec as $x}from"node:child_process";import eh from"node:fs/promises";import hu from"node:path";import{promisify as Mx}from"node:util";async function th(s){let e={branch:"main",commits:0,contributors:0,hasChanges:!1,stagedFiles:[],modifiedFiles:[],untrackedFiles:[],recentCommits:[],weeklyCommits:0};try{let{stdout:t}=await os("git branch --show-current",{cwd:s});e.branch=t.trim()||"main";let{stdout:n}=await os("git rev-list --count HEAD",{cwd:s});e.commits=parseInt(n.trim(),10)||0;let{stdout:r}=await os("git shortlog -sn --all | wc -l",{cwd:s});e.contributors=parseInt(r.trim(),10)||0;let{stdout:o}=await os("git status --porcelain",{cwd:s}),i=o.trim().split(`
|
|
1267
|
+
`).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 os('git log --oneline -20 --pretty=format:"%h|%s|%ad" --date=short',{cwd:s});e.recentCommits=a.split(`
|
|
1268
|
+
`).filter(Boolean).map(u=>{let[d,m,p]=u.split("|");return{hash:d,message:m,date:p}});let{stdout:c}=await os('git log --oneline --since="1 week ago" | wc -l',{cwd:s});e.weeklyCommits=parseInt(c.trim(),10)||0}catch(t){H.debug("Git analysis failed (not a git repo?)",{error:Z(t)})}return e}async function tn(s,e){try{return await eh.access(hu.join(s,e)),!0}catch(t){return H.debug("File not found",{filename:e,error:Z(t)}),!1}}async function nh(s){let e={fileCount:0,version:"0.0.0",name:hu.basename(s),ecosystem:"unknown",projectType:"simple",languages:[],frameworks:[]};try{let{stdout:t}=await os('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:s});e.fileCount=parseInt(t.trim(),10)||0}catch(t){H.debug("File count failed",{path:s,error:Z(t)}),e.fileCount=0}try{let t=hu.join(s,"package.json"),n=JSON.parse(await eh.readFile(t,"utf-8"));e.version=n.version||"0.0.0",e.name=n.name||e.name,e.ecosystem="JavaScript";let r={...n.dependencies,...n.devDependencies};(r.react||r["react-dom"])&&e.frameworks.push("React"),r.next&&e.frameworks.push("Next.js"),r.vue&&e.frameworks.push("Vue"),r.express&&e.frameworks.push("Express"),r.hono&&e.frameworks.push("Hono"),r["@angular/core"]&&e.frameworks.push("Angular"),r.svelte&&e.frameworks.push("Svelte"),n.devDependencies?.typescript||await tn(s,"tsconfig.json")?e.languages.push("TypeScript"):e.languages.push("JavaScript")}catch(t){H.debug("No package.json found",{path:s,error:Z(t)})}return await tn(s,"Cargo.toml")&&(e.ecosystem="Rust",e.languages.push("Rust")),await tn(s,"go.mod")&&(e.ecosystem="Go",e.languages.push("Go")),(await tn(s,"requirements.txt")||await tn(s,"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 sh(s){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 tn(s,"bun.lockb")?(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 tn(s,"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 tn(s,"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 tn(s,"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 tn(s,"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}function rh(s,e){let t=rs(),r={JavaScript:"package.json",Rust:"Cargo.toml",Go:"go.mod",Python:"pyproject.toml"}[s.ecosystem]||"filesystem",o=l(a=>({file:a,type:"detected"}),"detected"),i=l(a=>({file:a,type:"inferred"}),"inferred");return t.ecosystem=o(r),t.name=o(r),t.version=o(r),t.languages=o(r),t.frameworks=o(r),e.install.startsWith("bun")?t.commands=o("bun.lockb"):e.install.startsWith("pnpm")?t.commands=o("pnpm-lock.yaml"):e.install==="yarn"?t.commands=o("yarn.lock"):e.install.startsWith("cargo")?t.commands=o("Cargo.toml"):e.install.startsWith("go")?t.commands=o("go.mod"):t.commands=o("package.json"),t.projectType=i("file count + frameworks"),t.git=o("git"),t}async function oh(s){return new Vi(s).detect()}var os,ih=k(()=>{"use strict";rn();nu();En();Zf();os=Mx($x);l(th,"analyzeGit");l(tn,"fileExists");l(nh,"gatherStats");l(sh,"detectCommands");l(rh,"buildSources");l(oh,"detectStack")});import{exec as Ox}from"node:child_process";import yu from"node:fs/promises";import Bi from"node:path";import{promisify as Fx}from"node:util";var _x,wu,Su,ah,ch=k(()=>{"use strict";Yt();L();_x=Fx(Ox),wu={async contextFilesExist(s){let e=Date.now(),t=["context/CLAUDE.md"],n=[];for(let r of t){let o=Bi.join(s,r);try{await yu.access(o)}catch{n.push(r)}}return{name:"Context files exist",passed:n.length===0,output:n.length===0?`${t.length} files verified`:void 0,error:n.length>0?`Missing: ${n.join(", ")}`:void 0,durationMs:Date.now()-e}},async jsonFilesValid(s){let e=Date.now(),t=[],n=Bi.basename(s);try{await N.read(n)}catch(r){C(r)||t.push(`state: ${y(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(s){let e=Date.now(),t=Bi.join(s,"context"),n=[/(?: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 yu.readdir(t);for(let i of o){if(!i.endsWith(".md"))continue;let a=await yu.readFile(Bi.join(t,i),"utf-8");for(let c of n)if(c.test(a)){r.push(`${i}: potential sensitive data detected`);break}}}catch(o){if(!C(o))return{name:"No sensitive data",passed:!1,error:`Could not scan: ${y(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}}},Su=class{static{l(this,"SyncVerifier")}async verify(e,t,n){let r=Date.now(),o=[],i=n?.failFast??!1,a=0,c=[wu.contextFilesExist(t),wu.jsonFilesValid(t),wu.noSensitiveData(t)];for(let p of c){let g=await p;if(o.push(g),!g.passed&&i){a=n?.checks?.filter(f=>f.enabled!==!1).length??0;break}}if((!i||o.every(p=>p.passed))&&n?.checks)for(let p of n.checks){if(p.enabled===!1){a++;continue}let g=await this.runCustomCheck(p,e);if(o.push(g),!g.passed&&i){let f=n.checks.slice(n.checks.indexOf(p)+1);a+=f.filter(S=>S.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 n=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()-n};try{let{stdout:o,stderr:i}=await _x(r,{cwd:t,timeout:3e4});return{name:e.name,passed:!0,output:(o.trim()||i.trim()).slice(0,200)||void 0,durationMs:Date.now()-n}}catch(o){let i=o;return{name:e.name,passed:!1,error:(i.stderr?.trim()||i.message).slice(0,200),durationMs:Date.now()-n}}}},ah=new Su});import Ji from"node:fs/promises";import qi from"node:path";var Ki,jn,ku=k(()=>{"use strict";wr();Bl();nf();of();uf();ql();rn();qe();on();Pt();ve();Ni();Ar();xn();oe();Dr();ri();ii();Ir();$r();Is();If();Mf();ce();En();il();al();xs();Ff();vc();Rc();Xf();ih();ch();Ki=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 n=Date.now(),r;if(!t.aiTools||t.aiTools.length===0){let i=await Gi(e),a=i.filter(u=>Hs.includes(u)||u==="codex"),c=i.filter(u=>!Hs.includes(u)&&u!=="codex");r=[...a.length>0?a:Hs,...c],r=Array.from(new Set(r))}else t.aiTools[0]==="auto"?(r=await Gi(e),r.length===0&&(r=["claude"])):t.aiTools[0]==="all"?r=await xf("all",e):r=t.aiTools;let o={installed:!1,verified:!1,configPath:"",message:""};try{if(this.projectId=await M.getProjectId(e),!this.projectId)return{success:!1,projectId:"",cliVersion:"",git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),agents:[],skills:[],skillsInstalled:[],contextFiles:[],aiTools:[],context7:{installed:!1,verified:!1},error:"No prjct project. Run p. init first."};if(this.globalPath=A.getGlobalProjectPath(this.projectId),this.cliVersion=await this.getCliVersion(),(await Fn()).installed){let F=await _i({autoRepair:!0});F.verified||H.warn(`Codex p. router not ready: ${F.message||"verification failed"}`)}try{o=await an.ensureReady()}catch(F){return{success:!1,projectId:this.projectId,cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),agents:[],skills:[],skillsInstalled:[],contextFiles:[],aiTools:[],context7:{installed:o.installed,verified:!1,message:Z(F)},error:`Context7 MCP is required but not ready: ${Z(F)}. Run 'prjct start' to repair.`}}await this.ensureDirectories(),await jr(this.projectId);try{let F=await oi(this.projectId);F>0&&H.info("Swept legacy JSON files into SQLite",{swept:F})}catch(F){H.debug("Legacy JSON sweep failed (non-critical)",{error:Z(F)})}let[c,u,d,m]=await Promise.all([th(this.projectPath),nh(this.projectPath),sh(this.projectPath),oh(this.projectPath)]),p=t.full===!0,g,f=!0,S=!0,w=new Set;if(!p&&rf(this.projectId))try{let{diff:F,currentHashes:fy}=await Yl(this.projectPath,this.projectId),Xu=F.added.length+F.modified.length+F.deleted.length;if(Xu===0&&!t.changedFiles?.length)f=!1,S=!1,g={isIncremental:!0,filesChanged:0,filesUnchanged:F.unchanged.length,indexesRebuilt:!1,agentsRegenerated:!1,affectedDomains:[]};else{let ga=ef(F,this.projectId);w=tf(ga.allAffected);let hy=new Set([".ts",".tsx",".js",".jsx",".mjs",".cjs"]);f=ga.allAffected.some(Mn=>{let yy=Mn.substring(Mn.lastIndexOf("."));return hy.has(yy)}),S=ga.directlyChanged.some(Mn=>Mn==="package.json"||Mn==="tsconfig.json"||Mn.includes("Dockerfile")||Mn.includes("docker-compose")),g={isIncremental:!0,filesChanged:Xu,filesUnchanged:F.unchanged.length,indexesRebuilt:f,agentsRegenerated:S,affectedDomains:Array.from(w)}}Xl(this.projectId,fy)}catch(F){H.debug("Incremental detection failed, falling back to full sync",{error:Z(F)})}else try{let{currentHashes:F}=await Yl(this.projectPath,this.projectId);Xl(this.projectId,F)}catch(F){H.debug("Hash computation failed (non-critical)",{error:Z(F)})}if(f)try{await Promise.all([qg(this.projectPath,this.projectId),Zg(this.projectPath,this.projectId),lf(this.projectPath,this.projectId)])}catch(F){H.debug("File ranking index build failed (non-critical)",{error:Z(F)})}let v;if(S)try{let F=await N.getAggregatedFeedback(this.projectId);(F.patternsDiscovered.length>0||F.knownGotchas.length>0||F.agentAccuracy.length>0)&&(v=F)}catch{}let T=S?await Vf(this.globalPath,m,u,v):await Bf(this.globalPath),_=qf(T,this.projectId,this.globalPath),ne=S?await Kf(T):[],re=rh(u,d),ke=[],P;try{let F=await Je.getActive(this.projectId);(F?.patterns?.length||F?.antiPatterns?.length)&&(P={patterns:F.patterns??[],antiPatterns:F.antiPatterns??[],packageManager:F.packageManager,sourceDir:F.sourceDir,testDir:F.testDir})}catch{}let $;try{$=await $f(this.projectId)}catch{}let Fe={projectId:this.projectId,name:u.name,version:u.version,ecosystem:u.ecosystem,projectType:u.projectType,languages:u.languages,frameworks:u.frameworks,repoPath:this.projectPath,branch:c.branch,fileCount:u.fileCount,commits:c.commits,hasChanges:c.hasChanges,commands:d,agents:{workflow:T.filter(F=>F.type==="workflow").map(F=>F.name),domain:T.filter(F=>F.type==="domain").map(F=>F.name)},sources:re,analysis:P,learnings:$},ir=await Df(Fe,this.globalPath,this.projectPath,r);await Promise.all([this.updateProjectJson(c,u),this.updateStateJson(u,m),this.logToMemory(c,u),this.saveDraftAnalysis(c,u,m,o.verified)]);let ar=await Je.getActive(this.projectId),da={patterns:ar?.patterns?.length||0,antiPatterns:ar?.antiPatterns?.length||0,criticalAntiPatterns:ar?.antiPatterns?.filter(F=>F.severity==="high").length||0},pa=Date.now()-n,ma=await this.recordSyncMetrics(u,ke,T,pa);await this.archiveStaleData(),await this.autoLearnFromHistory(),await je.installGlobalConfig(),await je.syncCommands();let ft;try{let F=await M.readConfig(this.projectPath);ft=await ah.verify(this.projectPath,this.globalPath,F?.verification)}catch(F){H.debug("Verification failed (non-critical)",{error:Z(F)})}return{success:!0,projectId:this.projectId,cliVersion:this.cliVersion,git:c,stats:u,commands:d,stack:m,agents:T,skills:_,skillsInstalled:ne,contextFiles:ke,aiTools:ir.map(F=>({toolId:F.toolId,outputFile:F.outputFile,success:F.success})),context7:{installed:o.installed,verified:o.verified,message:o.message},analysisSummary:da,syncMetrics:ma,verification:ft,incremental:g}}catch(i){return{success:!1,projectId:this.projectId||"",cliVersion:this.cliVersion,git:this.emptyGitData(),stats:this.emptyStats(),commands:this.emptyCommands(),stack:this.emptyStack(),agents:[],skills:[],skillsInstalled:[],contextFiles:[],aiTools:[],context7:{installed:o.installed,verified:o.verified,message:o.message},error:Z(i)}}}async ensureDirectories(){let e=["storage","context","agents","memory","analysis","config","sync"];await Promise.all(e.map(t=>Ji.mkdir(qi.join(this.globalPath,t),{recursive:!0})))}async updateProjectJson(e,t){let n=E.getDoc(this.projectId,"project")||{},r={...n,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:n.createdAt||b(),lastSync:b(),lastSyncCommit:e.recentCommits[0]?.hash||null,lastSyncBranch:e.branch};E.setDoc(this.projectId,"project",r)}async updateStateJson(e,t){let r={...await N.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=b(),r.lastUpdated=b(),r.context={...r.context||{},lastSession:b(),lastAction:"Synced project",nextAction:'Run `p. task "description"` to start working'},await N.write(this.projectId,r);try{await Of.generate(this.projectPath,r)}catch(o){H.debug("Local state generation failed (optional)",{error:Z(o)})}}async logToMemory(e,t){E.appendEvent(this.projectId,"sync",{branch:e.branch,uncommitted:e.hasChanges,fileCount:t.fileCount,commitCount:e.commits})}async recordSyncMetrics(e,t,n,r){let i=0;for(let m of t)try{let p=qi.join(this.globalPath,m),g=await Ji.readFile(p,"utf-8");i+=g.length}catch(p){H.debug("Context file not found for metrics",{file:m,error:Z(p)})}for(let m of n)try{let p=qi.join(this.globalPath,"agents",`${m.name}.md`),g=await Ji.readFile(p,"utf-8");i+=g.length}catch(p){H.debug("Agent file not found for metrics",{agent:m.name,error:Z(p)})}let a=Math.floor(i/4),u=e.fileCount*500,d=u>0?Math.max(0,(u-a)/u):0;try{await Jn.recordSync(this.projectId,{originalSize:u,filteredSize:a,duration:r,isWatch:!1,agents:n.filter(m=>m.type==="domain").map(m=>m.name)})}catch(m){H.debug("Failed to record sync metrics",{error:Z(m)})}return{duration:r,originalSize:u,filteredSize:a,compressionRate:d}}async saveDraftAnalysis(e,t,n,r){try{let o=e.recentCommits[0]?.hash||null,i=[],a=[],c;try{c=await N.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 Kp.extract({projectId:this.projectId,projectPath:this.projectPath,languages:t.languages,frameworks:Array.from(new Set([...t.frameworks,...n.frameworks])),feedback:c,context7Verified:r});i=u.patterns,a=u.antiPatterns,await Je.saveDraft(this.projectId,{projectId:this.projectId,languages:t.languages,frameworks:t.frameworks,configFiles:[],fileCount:t.fileCount,patterns:i,antiPatterns:a,analyzedAt:b(),status:"draft",commitHash:o??void 0})}catch(o){H.debug("Failed to save draft analysis (non-critical)",{error:Z(o)})}}async archiveStaleData(){if(this.projectId)try{let[e,t,n,r,o]=await Promise.all([wt.archiveOldShipped(this.projectId).catch(()=>0),tt.markDormantIdeas(this.projectId).catch(()=>0),Ie.removeStaleCompleted(this.projectId).catch(()=>0),N.archiveStalePausedTasks(this.projectId).catch(()=>[]),yt.capEntries(this.projectId).catch(()=>0)]),i=e+t+n+r.length+o;if(i>0){H.info("Archived stale data",{shipped:e,dormant:t,staleQueue:n,stalePaused:r.length,memoryCapped:o,total:i});let a=Ct.getStats(this.projectId);H.debug("Archive stats",a)}}catch(e){H.debug("Archival failed (non-critical)",{error:Z(e)})}}async autoLearnFromHistory(){if(this.projectId)try{let e=await N.getTaskHistory(this.projectId);if(e.length===0)return;let t=new Nn,n=await ol.learnFromTaskHistory(this.projectId,e,t);try{let r=await Sm.getFeatureOutcomes(this.projectId);r.length>0&&await ol.learnFromOutcomes(this.projectId,r,t)}catch{}n.memoriesInjected>0&&H.info("Auto-learned from task history",{patternsExtracted:n.patternsExtracted,memoriesInjected:n.memoriesInjected,patternsSkipped:n.patternsSkipped})}catch(e){H.debug("Auto-learning failed (non-critical)",{error:Z(e)})}}async getCliVersion(){try{let e=qi.join(__dirname,"..","..","package.json");return JSON.parse(await Ji.readFile(e,"utf-8")).version||"0.0.0"}catch(e){return H.debug("Failed to read CLI version",{error:Z(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:[]}}},jn=new Ki});var uh,dh,ph,is,lh,mh,gh,Nx,Lx,bu=k(()=>{"use strict";Xn();uh=[1,2,3,5,8,13,21],dh={1:{min:5,max:15,typical:10},2:{min:15,max:30,typical:20},3:{min:30,max:60,typical:45},5:{min:60,max:120,typical:90},8:{min:120,max:240,typical:180},13:{min:240,max:480,typical:360},21:{min:480,max:960,typical:720}},ph=l(s=>uh.includes(s),"isValidPoint"),is=l(s=>dh[s],"pointsToMinutes"),lh=l(s=>{if(s<60)return`${s}m`;let e=Math.floor(s/60),t=s%60;return t>0?`${e}h ${t}m`:`${e}h`},"formatMinutes"),mh=l(s=>{let e=is(s);return`${lh(e.min)}\u2013${lh(e.max)}`},"pointsToTimeRange"),gh=l(async(s,e)=>{let n=(await gt.getAll(s)).filter(a=>a.tags?.includes(e));if(n.length<3)return null;let o=n.reduce((a,c)=>a+Lx(c.actualDuration),0)/n.length;return{points:Nx(o),basedOn:n.length}},"suggestFromHistory"),Nx=l(s=>{let e=1,t=Number.POSITIVE_INFINITY;for(let n of uh){let r=Math.abs(dh[n].typical-s);r<t&&(t=r,e=n)}return e},"findClosestPoint"),Lx=l(s=>{let e=0,t=s.match(/(\d+)h/);t&&(e+=Number.parseInt(t[1],10)*60);let n=s.match(/(\d+)m/);return n&&(e+=Number.parseInt(n[1],10)),e},"parseDuration")});function Ux(s){switch(s){case"low":return 2;case"medium":return 5;case"high":return 8}}async function fh(s,e){let t=Gn.detectTaskType(e),n=await gh(s,t);if(n){let a=is(n.points);return{taskType:t,estimatedPoints:n.points,estimatedMinutes:a.typical,source:"history"}}let r=Gn.estimateComplexity(e),o=Ux(r.level),i=is(o);return{taskType:t,estimatedPoints:o,estimatedMinutes:i.typical,source:"heuristic"}}var vu,Pu=k(()=>{"use strict";bu();ic();l(Ux,"complexityToPoints");l(fh,"estimateTaskForStart");vu=fh});import{exec as Hx}from"node:child_process";import Gs from"node:path";import{promisify as Gx}from"node:util";function yh(s){return/^\d+\.\d+\.\d+/.test(s)}function Ws(s){let e=s.match(/^(\d+)\.(\d+)\.(\d+)/);if(!e)return s;let[,t,n,r]=e;return`${t}.${n}.${Number(r)+1}`}function Wx(s){let e=s.match(/\[package\]([\s\S]*?)(?=\n\[|\n*$)/);return e?e[1].match(/^\s*version\s*=\s*"([^"]+)"/m)?.[1]??null:null}function zx(s){let e=s.match(/\[project\]([\s\S]*?)(?=\n\[|\n*$)/);if(e){let n=e[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(n)return n[1]}let t=s.match(/\[tool\.poetry\]([\s\S]*?)(?=\n\[|\n*$)/);if(t){let n=t[1].match(/^\s*version\s*=\s*"([^"]+)"/m);if(n)return n[1]}return null}function Vx(s){return s.match(/<Version>([^<]+)<\/Version>/)?.[1]?.trim()??null}var hh,Xr,wh=k(()=>{"use strict";We();hh=Gx(Hx),Xr=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 n=await t();if(n)return n}return this.createFallbackVersion()}async bump(){let e=await this.detect();return await this.writeVersion(e),e.next}async fromPackageJson(){let e=Gs.join(this.projectPath,"package.json"),t=await zt(e,null);return t?.version?{current:t.version,next:Ws(t.version),file:e,format:"json"}:null}async fromCargoToml(){let e=Gs.join(this.projectPath,"Cargo.toml"),t=await ot(e,"");if(!t)return null;let n=Wx(t);return n?{current:n,next:Ws(n),file:e,format:"toml"}:null}async fromPyprojectToml(){let e=Gs.join(this.projectPath,"pyproject.toml"),t=await ot(e,"");if(!t)return null;let n=zx(t);return n?{current:n,next:Ws(n),file:e,format:"toml"}:null}async fromCsproj(){let e=await sn(this.projectPath,{extension:".csproj"});if(e.length===0)return null;let t=Gs.join(this.projectPath,e[0]),n=await ot(t,"");if(!n)return null;let r=Vx(n);return r?{current:r,next:Ws(r),file:t,format:"xml"}:null}async fromVersionFile(e){let t=Gs.join(this.projectPath,e),n=await ot(t,"");if(!n)return null;let r=n.trim();return yh(r)?{current:r,next:Ws(r),file:t,format:"plaintext"}:null}async fromGitTag(){try{let{stdout:e}=await hh("git tag --sort=-v:refname",{cwd:this.projectPath}),t=e.trim().split(`
|
|
1269
|
+
`);for(let n of t){let r=n.trim().replace(/^v/,"");if(yh(r))return{current:r,next:Ws(r),file:null,format:"git-tag"}}}catch{}return null}async createFallbackVersion(){let e=Gs.join(this.projectPath,"VERSION");return await Vt(e,`0.1.0
|
|
1270
|
+
`),{current:"0.1.0",next:"0.1.1",file:e,format:"plaintext"}}async writeVersion(e){if(!e.file){e.format==="git-tag"&&await hh(`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 Vt(e.file,`${e.next}
|
|
1271
|
+
`);break}}async writeJsonVersion(e,t){let n=await zt(e,{});n&&(n.version=t,await On(e,n))}async writeTomlVersion(e,t){let n=await ot(e,"");if(!n)return;let r=n.replace(/^(\s*version\s*=\s*")([^"]+)(")/m,`$1${t}$3`);await Vt(e,r)}async writeXmlVersion(e,t){let n=await ot(e,"");if(!n)return;let r=n.replace(/(<Version>)([^<]+)(<\/Version>)/,`$1${t}$3`);await Vt(e,r)}};l(yh,"isSemver");l(Ws,"bumpPatch");l(Wx,"parseTomlVersion");l(zx,"parsePyprojectVersion");l(Vx,"parseCsprojVersion")});var ln=k(()=>{"use strict";Sp();Ap();ic();Dp();Mp();xs();Hp();fc();zp();vc();Vp();Tc();Rc();Xp();Fg();Hg();ku();Pu();wh()});var Cu,Bx,zs,xu=k(()=>{"use strict";ce();oe();Cu=class{static{l(this,"LLMAnalysisStorage")}save(e,t){let n=E.getDb(e),r=b();n.transaction(()=>{n.prepare("UPDATE llm_analysis SET status = 'superseded', superseded_at = ? WHERE status = 'active'").run(r),n.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=E.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?E.get(e,"SELECT commit_hash FROM llm_analysis WHERE status = 'active' LIMIT 1")?.commit_hash===t:!1}getHistory(e,t=10){return E.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}})}},Bx=new Cu,zs=Bx});import Sh from"node:fs/promises";import kh from"node:path";async function bh(s,e,t,n){let[r,o,i,a]=await Promise.all([Kx(s,e,n),Xx(s),Yx(s),Qx(s)]);return{project:{name:n.name,ecosystem:n.ecosystem,languages:n.languages,frameworks:n.frameworks,fileCount:n.fileCount,projectType:n.projectType},git:{branch:t.branch,recentCommits:t.recentCommits.slice(0,Jx).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 Kx(s,e,t){let n=[],r=[...t.frameworks.map(a=>a.toLowerCase()),"config","router","middleware","service","model","schema","database","api","auth"].join(" "),o=Kg(s,r,Tu*2);for(let a of o){if(n.length>=Tu)break;try{let c=kh.join(e,a.path),u=await Sh.readFile(c,"utf-8");u.length>Xi*3?n.push({path:a.path,content:`${u.slice(0,Xi)}
|
|
1272
|
+
// ... truncated`,reason:`BM25 score: ${a.score.toFixed(2)} (truncated, ${u.length} chars)`}):n.push({path:a.path,content:u.slice(0,Xi),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(n.length>=Tu)break;if(!n.some(c=>c.path===a))try{let c=kh.join(e,a),u=await Sh.readFile(c,"utf-8");n.push({path:a,content:u.slice(0,Xi),reason:"entry point"})}catch{}}return n}async function Xx(s){try{let e=await Je.getActive(s);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 Yx(s){try{return(await N.getTaskHistory(s)).slice(0,qx).map(t=>({description:t.title,status:t.classification,branch:t.branchName}))}catch{return[]}}function Qx(s){try{let e=zs.getActiveSummary(s);return Promise.resolve(e)}catch(e){return H.debug("Failed to get previous LLM analysis summary",{error:e}),Promise.resolve(null)}}var Xi,Tu,Jx,qx,vh=k(()=>{"use strict";Bl();Ar();xu();Is();En();Xi=3e3,Tu=15,Jx=15,qx=10;l(bh,"buildAnalysisPayload");l(Kx,"selectCodeSamples");l(Xx,"getExistingPatterns");l(Yx,"getTaskHistory");l(Qx,"getPreviousAnalysisSummary")});import pn from"chalk";function Ph(s){return Math.ceil(s.length/Zx)}function Ch(s){let e=s.split(`
|
|
1273
|
+
`),t=[],n=null;for(let r=0;r<e.length;r++){let o=e[r],i=o.match(/^(#{1,3})\s+(.+)$/);i?(n&&(n.endLine=r-1,t.push(n)),n={name:i[2].trim(),content:o,startLine:r,endLine:r}):n&&(n.content+=`
|
|
1274
|
+
${o}`)}return n&&(n.endLine=e.length-1,t.push(n)),t}function Eu(s){return s.includes("<!-- prjct:preserve")}function xh(s,e){let t=Ch(s),n=Ch(e),r={hasChanges:!1,added:[],modified:[],removed:[],preserved:[],tokensBefore:Ph(s),tokensAfter:Ph(e),tokenDelta:0};r.tokenDelta=r.tokensAfter-r.tokensBefore;let o=new Map(t.map(a=>[a.name.toLowerCase(),a])),i=new Map(n.map(a=>[a.name.toLowerCase(),a]));for(let a of t)Eu(a.content)&&r.preserved.push({name:a.name,lineCount:a.content.split(`
|
|
1275
|
+
`).length});for(let a of n){let c=a.name.toLowerCase(),u=o.get(c);u?u.content.trim()!==a.content.trim()&&(Eu(u.content)||(r.modified.push({name:a.name,type:"modified",before:u.content,after:a.content,lineCount:a.content.split(`
|
|
1276
|
+
`).length}),r.hasChanges=!0)):(r.added.push({name:a.name,type:"added",after:a.content,lineCount:a.content.split(`
|
|
1277
|
+
`).length}),r.hasChanges=!0)}for(let a of t){let c=a.name.toLowerCase();!i.has(c)&&!Eu(a.content)&&(r.removed.push({name:a.name,type:"removed",before:a.content,lineCount:a.content.split(`
|
|
1278
|
+
`).length}),r.hasChanges=!0)}return r}function Th(s,e={}){let{colorize:t=!0}=e,n=[],r=t?pn.green:p=>p,o=t?pn.red:p=>p,i=t?pn.yellow:p=>p,a=t?pn.dim:p=>p,c=t?pn.bold:p=>p;if(!s.hasChanges)return n.push(a("No changes detected (context is up to date)")),n.join(`
|
|
1279
|
+
`);if(n.push(""),n.push(c("\u{1F4CB} Changes to context files:")),n.push(""),s.added.length>0)for(let p of s.added)n.push(r(`+ \u2502 + ${p.name} (new)`));if(s.modified.length>0)for(let p of s.modified)n.push(i(`~ \u2502 ${p.name} (modified)`));if(s.removed.length>0)for(let p of s.removed)n.push(o(`- \u2502 - ${p.name} (removed)`));if(s.preserved.length>0){n.push(""),n.push(a(" ## Your Customizations"));for(let p of s.preserved)n.push(a(` \u2502 \u2713 ${p.name} (${p.lineCount} lines preserved)`))}n.push(""),n.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=[];s.added.length>0&&u.push(r(`+${s.added.length} added`)),s.modified.length>0&&u.push(i(`~${s.modified.length} modified`)),s.removed.length>0&&u.push(o(`-${s.removed.length} removed`)),n.push(`Summary: ${u.join(", ")||"no changes"}`);let d=s.tokenDelta>=0?"+":"",m=s.tokenDelta>=0?r:o;return n.push(`Tokens: ${s.tokensBefore.toLocaleString()} \u2192 ${s.tokensAfter.toLocaleString()} (${m(d+s.tokenDelta.toLocaleString())})`),n.push(""),n.join(`
|
|
1280
|
+
`)}function Eh(s,e={}){let{colorize:t=!0}=e,n=[],r=t?pn.green:c=>c,o=t?pn.red:c=>c,i=t?pn.cyan:c=>c,a=t?pn.dim:c=>c;for(let c of s.added){if(n.push(i(`@@ +${c.name} @@`)),c.after)for(let u of c.after.split(`
|
|
1281
|
+
`))n.push(r(`+ ${u}`));n.push("")}for(let c of s.modified){if(n.push(i(`@@ ${c.name} @@`)),c.before){for(let u of c.before.split(`
|
|
1282
1282
|
`).slice(0,5))n.push(o(`- ${u}`));c.before.split(`
|
|
1283
1283
|
`).length>5&&n.push(a(` ... ${c.before.split(`
|
|
1284
1284
|
`).length-5} more lines`))}if(c.after){for(let u of c.after.split(`
|
|
1285
|
-
`).slice(0,5))n.push(
|
|
1285
|
+
`).slice(0,5))n.push(r(`+ ${u}`));c.after.split(`
|
|
1286
1286
|
`).length>5&&n.push(a(` ... ${c.after.split(`
|
|
1287
|
-
`).length-5} more lines`))}n.push("")}for(let c of
|
|
1287
|
+
`).length-5} more lines`))}n.push("")}for(let c of s.removed){if(n.push(i(`@@ -${c.name} @@`)),c.before){for(let u of c.before.split(`
|
|
1288
1288
|
`).slice(0,5))n.push(o(`- ${u}`));c.before.split(`
|
|
1289
1289
|
`).length>5&&n.push(a(` ... ${c.before.split(`
|
|
1290
1290
|
`).length-5} more lines`))}n.push("")}return n.join(`
|
|
1291
|
-
`)}var
|
|
1292
|
-
`));let u=[];
|
|
1293
|
-
`)}function
|
|
1291
|
+
`)}var Zx,Ah=k(()=>{"use strict";Zx=4;l(Ph,"estimateTokens");l(Ch,"parseMarkdownSections");l(Eu,"isPreservedSection");l(xh,"generateSyncDiff");l(Th,"formatDiffPreview");l(Eh,"formatFullDiff")});import eT from"node:path";async function Au(s,e){let t=Date.now()-e,n=s.contextFiles.length+(s.aiTools?.filter(p=>p.success).length||0),r=s.agents.length,o=s.agents.filter(p=>p.type==="domain").length;await je.installGlobalConfig(),h.done(`Synced ${s.stats.name||"project"} (${(t/1e3).toFixed(1)}s)`),console.log("");let i=s.syncMetrics?.compressionRate?Math.round(s.syncMetrics.compressionRate*100):0,a=s.stats.frameworks.length>0?` (${s.stats.frameworks[0]})`:"",c=[`${s.stats.fileCount} files \u2192 ${n} context | ${r} agents${i>10?` | ${i}% reduction`:""}`,`Stack: ${s.stats.ecosystem}${a} | Branch: ${s.git.branch}`];h.box("Sync Summary",c.join(`
|
|
1292
|
+
`));let u=[];s.contextFiles.length>0&&u.push(`${s.contextFiles.length} context files`);let d=s.aiTools?.filter(p=>p.success)||[];if(d.length>0&&u.push(`AI tools: ${d.map(p=>p.toolId).join(", ")}`),r>0){let p=o>0?`${r} agents (${o} domain)`:`${r} agents`;u.push(p)}if(s.skills.length>0){let p=s.skills.length===1?"skill":"skills";u.push(`${s.skills.length} ${p}`)}let m=s.skillsInstalled?.filter(p=>p.status==="installed")||[];if(m.length>0){let p=m.length===1?"skill":"skills";u.push(`${m.length} ${p} auto-installed`)}if(s.context7&&u.push(`Context7: ${s.context7.verified?"verified":`not ready${s.context7.message?` (${s.context7.message})`:""}`}`),s.analysisSummary&&u.push(`Analysis: ${s.analysisSummary.patterns} patterns | ${s.analysisSummary.antiPatterns} anti-patterns (${s.analysisSummary.criticalAntiPatterns} critical)`),h.section("Generated"),h.list(u,{bullet:"\u2713"}),console.log(""),s.git.hasChanges&&(h.warn("Uncommitted changes detected"),console.log("")),s.verification){let p=s.verification;if(p.passed){let g=p.checks.map(f=>`${f.name} (${f.durationMs}ms)`);h.section("Verified"),h.list(g,{bullet:"\u2713"})}else{h.section("Verification");let g=p.checks.map(f=>f.passed?`\u2713 ${f.name}`:`\u2717 ${f.name}${f.error?` \u2014 ${f.error}`:""}`);h.list(g),p.skippedCount>0&&h.warn(`${p.skippedCount} check(s) skipped (fail-fast)`)}console.log("")}return Tt("sync"),{success:!0,data:s,metrics:{elapsed:t,contextFilesCount:n,agentCount:r,fileCount:s.stats.fileCount}}}async function Rh(s){try{let e=await yt.getRecentEvents(s,100),t=new Date().toISOString().split("T")[0],n=e.filter(u=>(u.timestamp||u.ts)?.startsWith(t)),r=null;if(n.length>=2){let u=n.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=B.formatDuration(d)}}let o=n.filter(u=>u.action==="task_completed").length,i=n.filter(u=>u.action==="feature_shipped").length,a=new Map;for(let u of n)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 Yr(s){return s>=1e6?`${(s/1e6).toFixed(1)}M`:s>=1e3?`${(s/1e3).toFixed(1)}K`:s.toLocaleString()}function Ru(s){return s<1e3?`${Math.round(s)}ms`:`${(s/1e3).toFixed(1)}s`}function Dh(s){if(s.length===0)return"";let e="\u2581\u2582\u2583\u2584\u2585\u2586\u2587\u2588",t=s.map(r=>r.tokensSaved),n=Math.max(...t,1);return t.map(r=>{let o=Math.min(Math.floor(r/n*(e.length-1)),e.length-1);return e[o]}).join("")}function jh(s,e,t,n,r,o){let i=[];if(i.push(`# ${t} - Stats Dashboard`),i.push(""),i.push(`_Generated: ${new Date().toLocaleString()} | Tracking since: ${n}_`),i.push(""),r){if(i.push("## \u{1F3AF} 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("## \u{1F9E0} Patterns Learned"),i.push(""),i.push("| Type | Count |"),i.push("|------|-------|"),i.push(`| Decisions | ${o.learnedDecisions} confirmed (${o.decisions} total) |`),i.push(`| Preferences | ${o.preferences} |`),i.push(`| Workflows | ${o.workflows} |`),i.push("")),i.push("## \u{1F4B0} Token Savings"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Total saved | ${Yr(s.totalTokensSaved)} tokens |`),i.push(`| Compression | ${(s.compressionRate*100).toFixed(0)}% |`),i.push(`| Cost saved | ${Ao(s.estimatedCostSaved)} |`),i.push(""),i.push("## \u26A1 Performance"),i.push(""),i.push("| Metric | Value |"),i.push("|--------|-------|"),i.push(`| Syncs | ${s.syncCount} |`),i.push(`| Avg time | ${Ru(s.avgSyncDuration)} |`),i.push(""),s.topAgents.length>0){i.push("## \u{1F916} Agent Usage"),i.push(""),i.push("| Agent | Usage |"),i.push("|-------|-------|");let a=s.topAgents.reduce((c,u)=>c+u.usageCount,0);for(let c of s.topAgents){let u=a>0?(c.usageCount/a*100).toFixed(0):0;i.push(`| ${c.agentName} | ${u}% (${c.usageCount}) |`)}i.push("")}if(i.push("## \u{1F4C8} 30-Day Trend"),i.push(""),i.push(`- Tokens saved: ${Yr(s.last30DaysTokens)}`),s.trend!==0){let a=s.trend>0?"+":"";i.push(`- Trend: ${a}${s.trend.toFixed(0)}% vs previous period`)}return i.push(""),i.push("---"),i.push(""),i.push("_Generated with [prjct-cli](https://prjct.app)_"),i.join(`
|
|
1293
|
+
`)}function Ih(s,e){let t=[];t.push(`# Repository Analysis
|
|
1294
1294
|
`),t.push(`Generated: ${new Date().toLocaleString()}
|
|
1295
|
-
`);let n=
|
|
1295
|
+
`);let n=eT.basename(e);if(t.push(`## Project: ${n}
|
|
1296
1296
|
`),t.push(`## Stack Detected
|
|
1297
|
-
`),
|
|
1298
|
-
`),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)`:""}`)}
|
|
1297
|
+
`),s.packageJson){let i=s.packageJson;if(t.push(`### JavaScript/TypeScript
|
|
1298
|
+
`),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)`:""}`)}s.hasNextConfig&&t.push("- **Framework**: Next.js detected"),s.hasViteConfig&&t.push("- **Build Tool**: Vite detected"),s.hasTsconfig&&t.push("- **Language**: TypeScript"),t.push("")}s.cargoToml&&(t.push(`### Rust
|
|
1299
1299
|
`),t.push("- **Package Manager**: Cargo"),t.push(`- **Language**: Rust
|
|
1300
|
-
`)),
|
|
1300
|
+
`)),s.goMod&&(t.push(`### Go
|
|
1301
1301
|
`),t.push("- **Package Manager**: Go modules"),t.push(`- **Language**: Go
|
|
1302
|
-
`)),
|
|
1302
|
+
`)),s.requirements&&(t.push(`### Python
|
|
1303
1303
|
`),t.push("- **Package Manager**: pip"),t.push(`- **Language**: Python
|
|
1304
|
-
`));let s
|
|
1305
|
-
`),t.push(`- **Total Files**: ${
|
|
1306
|
-
`),t.push(`- **Total Commits**: ${o?.totalCommits||0}`),t.push(`- **Contributors**: ${o?.contributors||0}`),t.push(`- **Age**: ${o?.age||"unknown"}`),t.push(""),
|
|
1307
|
-
`),
|
|
1304
|
+
`));let r=s.directories;t.push(`## Structure
|
|
1305
|
+
`),t.push(`- **Total Files**: ${s.fileCount}`),t.push(`- **Directories**: ${r?.slice(0,15).join(", ")||"none"}${(r?.length||0)>15?` (+${(r?.length||0)-15} more)`:""}`),s.hasDockerfile&&t.push("- **Docker**: Detected"),s.hasDockerCompose&&t.push("- **Docker Compose**: Detected"),s.hasReadme&&t.push("- **Documentation**: README.md found"),t.push("");let o=s.gitStats;return t.push(`## Git Statistics
|
|
1306
|
+
`),t.push(`- **Total Commits**: ${o?.totalCommits||0}`),t.push(`- **Contributors**: ${o?.contributors||0}`),t.push(`- **Age**: ${o?.age||"unknown"}`),t.push(""),s.gitLog&&(t.push(`## Recent Activity
|
|
1307
|
+
`),s.gitLog.split(`
|
|
1308
1308
|
`).slice(0,5).forEach(a=>{if(a.trim()){let[c,,u,d]=a.split("|");t.push(`- \`${c}\` ${d} (${u})`)}}),t.push("")),t.push(`## Recommendations
|
|
1309
1309
|
`),t.push("Based on detected stack, consider generating specialized agents using `/p:sync`.\n"),t.push(`---
|
|
1310
1310
|
`),t.push("*This analysis was generated automatically. For updated information, run `/p:analyze` again.*\n"),t.join(`
|
|
1311
|
-
`)}var
|
|
1312
|
-
`),Xe.init(t);let n=await
|
|
1311
|
+
`)}var $h=k(()=>{"use strict";on();Ro();ln();Ms();Bn();lt();l(Au,"showSyncResult");l(Rh,"getSessionActivity");l(Yr,"formatTokens");l(Ru,"formatDuration");l(Dh,"generateSparkline");l(jh,"generateStatsMarkdown");l(Ih,"generateAnalysisSummary")});var Og={};hn(Og,{AnalysisCommands:()=>cs});import Du from"node:fs/promises";import Mh from"node:path";import*as as from"@clack/prompts";var cs,Di=k(()=>{"use strict";wr();ap();on();Ro();ln();$c();vh();Ah();Ar();oe();xu();ri();L();$s();Ms();Bn();$h();lt();cs=class extends Ce{static{l(this,"AnalysisCommands")}async analyze(e={},t=process.cwd()){try{await this.initializeAgent(),console.log(`\u{1F50D} Analyzing repository...
|
|
1312
|
+
`),Xe.init(t);let n=await kt.build(t,e),r={packageJson:await Xe.readPackageJson(),cargoToml:await Xe.readCargoToml(),goMod:await Xe.readGoMod(),requirements:await Xe.readRequirements(),directories:await Xe.listDirectories(),fileCount:await Xe.countFiles(),gitStats:await Xe.getGitStats(),gitLog:await Xe.getGitLog(20),hasDockerfile:await Xe.fileExists("Dockerfile"),hasDockerCompose:await Xe.fileExists("docker-compose.yml"),hasReadme:await Xe.fileExists("README.md"),hasTsconfig:await Xe.fileExists("tsconfig.json"),hasViteConfig:await Xe.fileExists("vite.config.ts")||await Xe.fileExists("vite.config.js"),hasNextConfig:await Xe.fileExists("next.config.js")||await Xe.fileExists("next.config.mjs")},o=Ih(r,t),i=await M.getProjectId(t),a=n.paths.analysis||A.getFilePath(i,"analysis","repo-summary.md");await rt.get("Write")(a,o),await this.logToMemory(t,"repository_analyzed",{timestamp:B.getTimestamp(),fileCount:r.fileCount,gitCommits:r.gitStats.totalCommits});let u=await(qe(),ht(pt)).getActiveProvider(),d=await je.installGlobalConfig();return d.success&&console.log(`\u{1F4DD} Updated ${A.getDisplayPath(d.path)}`),console.log(`\u2705 Analysis complete!
|
|
1313
1313
|
`),console.log(`\u{1F4C4} Full report: ${A.getDisplayPath(a)}`),console.log(`\u{1F4DD} Context: ~/.prjct-cli/projects/${i}/${u.contextFile}
|
|
1314
|
-
`),console.log("Next steps:"),console.log("\u2022 /p:sync \u2192 Generate agents based on stack"),console.log("\u2022 /p:feature \u2192 Add a new feature"),{success:!0,summaryPath:a,data:
|
|
1315
|
-
${
|
|
1314
|
+
`),console.log("Next steps:"),console.log("\u2022 /p:sync \u2192 Generate agents based on stack"),console.log("\u2022 /p:feature \u2192 Add a new feature"),{success:!0,summaryPath:a,data:r}}catch(n){return console.error("\u274C Error:",y(n)),{success:!1,error:y(n)}}}async sync(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=A.getGlobalProjectPath(r),i=Date.now();if(t.package){let m=await A.detectMonorepo(e);if(!m.isMonorepo)return{success:!1,error:"Not a monorepo. --package flag only works in monorepos."};let p=m.packages.find(f=>f.name===t.package||f.relativePath===t.package);if(!p){let f=m.packages.map(S=>S.name).join(", ");return{success:!1,error:`Package "${t.package}" not found. Available: ${f}`}}let g=await jn.sync(e,{aiTools:t.aiTools,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(U(Se(`Synced package: ${p.name}`))):h.done(`Synced package: ${p.name}`),{success:g.success}}let a=Mh.join(o,"context","CLAUDE.md"),c=null;try{c=await Du.readFile(a,"utf-8")}catch{}let u=!process.stdin.isTTY||t.json||t.md;if(c&&!t.yes&&!u){u||h.spin("Analyzing changes...");let m=await jn.sync(e,{aiTools:t.aiTools,full:t.full});if(!m.success)return t.md?(console.log(U("## \u274C Sync Failed",`> ${m.error||"Unknown error"}`)),{success:!1,error:m.error}):u?(console.log(JSON.stringify({success:!1,error:m.error||"Sync failed"})),{success:!1,error:m.error}):(h.fail(m.error||"Sync failed"),{success:!1,error:m.error});let p;try{p=await Du.readFile(a,"utf-8")}catch{p=""}let g=xh(c,p);if(u||h.stop(),!g.hasChanges)return t.md?(console.log(U(Se("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"}):(h.done("No changes detected (context is up to date)"),{success:!0,message:"No changes"});let f=l(async()=>{c!=null&&await Du.writeFile(a,c,"utf-8")},"restoreOriginal");if(t.md){await f();let w=[];for(let T of g.added)w.push(`Added: ${T.name} (${T.lineCount} lines)`);for(let T of g.modified)w.push(`Modified: ${T.name} (${T.lineCount} lines)`);for(let T of g.removed)w.push(`Removed: ${T.name} (${T.lineCount} lines)`);let v=U("## \u26A1 Sync Preview",w.length>0?ee("Changes",Ae(w)):"No section changes.",St({"Tokens before":g.tokensBefore,"Tokens after":g.tokensAfter,"Token delta":g.tokenDelta>0?`+${g.tokenDelta}`:String(g.tokenDelta)}),"> Run `prjct sync --yes` to apply changes.");return console.log(v),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(u){await f();let w={added:g.added.map(v=>({name:v.name,lineCount:v.lineCount})),modified:g.modified.map(v=>({name:v.name,lineCount:v.lineCount})),removed:g.removed.map(v=>({name:v.name,lineCount:v.lineCount})),preserved:g.preserved,tokensBefore:g.tokensBefore,tokensAfter:g.tokensAfter,tokenDelta:g.tokenDelta};return console.log(JSON.stringify({success:!0,action:"confirm_required",message:"Changes detected. Confirmation required to apply.",diff:w,fullDiff:t.preview?{added:g.added,modified:g.modified,removed:g.removed}:void 0,hint:"Run `prjct sync --yes` to apply changes"})),{success:!0,isPreview:!0,diff:g,message:"Preview complete (awaiting confirmation)"}}if(console.log(Th(g)),t.preview)return await f(),{success:!0,isPreview:!0,diff:g,message:"Preview complete (no changes applied)"};let S=await as.select({message:"Apply these changes?",options:[{label:"Yes, apply changes",value:"apply"},{label:"No, cancel",value:"cancel"},{label:"Show full diff",value:"diff"}]});if(as.isCancel(S)||S==="cancel")return await f(),h.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"};if(S==="diff"){console.log(`
|
|
1315
|
+
${Eh(g)}`);let w=await as.confirm({message:"Apply these changes?",initialValue:!0});if(as.isCancel(w)||!w)return await f(),h.warn("Sync cancelled \u2014 no changes applied"),{success:!1,message:"Cancelled by user"}}return h.done("Changes applied"),Au(m,i)}t.md||h.spin("Syncing project...");let d=await jn.sync(e,{aiTools:t.aiTools,full:t.full});if(!d.success)return t.md?console.log(U("## \u274C Sync Failed",`> ${d.error||"Unknown error"}`)):h.fail(d.error||"Sync failed"),{success:!1,error:d.error};if(t.md||h.stop(),t.md){let m=Date.now()-i,p=d.contextFiles.length+(d.aiTools?.filter(T=>T.success).length||0),g=d.agents.length,f=null;try{let T=await Je.diff(r);T?.hasChanges&&(f=Ic(T))}catch{}let S=`## LLM Analysis (hybrid pipeline)
|
|
1316
1316
|
|
|
1317
1317
|
After sync, run the analysis payload builder:
|
|
1318
1318
|
\`\`\`bash
|
|
@@ -1346,42 +1346,42 @@ Otherwise, analyze the JSON payload and produce a structured \`LLMAnalysis\` JSO
|
|
|
1346
1346
|
Save the analysis:
|
|
1347
1347
|
\`\`\`bash
|
|
1348
1348
|
prjct analysis-save-llm '<your JSON here>' --md
|
|
1349
|
-
\`\`\``,y=di("sync"),C=U(Se("Sync Complete"),kt({Duration:`${(m/1e3).toFixed(1)}s`,Agents:`${g} generated`,"Files indexed":d.stats.fileCount,"Context files":p}),f,d.git.hasChanges?Pm("Uncommitted changes detected"):null,S,de(y.map(E=>({label:E.desc,command:E.cmd}))));return console.log(C),{success:!0,data:d,metrics:{elapsed:m,contextFilesCount:p,agentCount:g,fileCount:d.stats.fileCount}}}return Lu(d,i)}catch(n){return t.md?console.log(U("## \u274C Sync Failed",`> ${w(n)}`)):h.fail(w(n)),{success:!1,error:w(n)}}}async analysisPayload(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return{success:!1,error:"No project ID found"};let o=await On.sync(e,{aiTools:[]});if(!o.success)return{success:!1,error:o.error||"Failed to gather project data"};let i=o.git.recentCommits[0]?.hash??null;if(i&&Bs.isCurrent(s,i))return t.md?console.log(U(Se("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 jh(s,e,o.git,o.stats);return t.md?console.log(U("## \u{1F50D} Analysis Payload","> Analyze this project data and produce structured findings.","","```json",JSON.stringify(a,null,2),"```","","> After analyzing, call: `prjct analysis save-llm --json '{...}'`")):console.log(JSON.stringify({success:!0,payload:a})),{success:!0,data:a}}catch(n){return{success:!1,error:w(n)}}}async saveLlmAnalysis(e,t=process.cwd(),n={}){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let o=await M.getProjectId(t);if(!o)return{success:!1,error:"No project ID found"};let i=JSON.parse(e);return!i.version||!i.architecture||!i.patterns?{success:!1,error:"Invalid LLM analysis format. Missing required fields."}:(Bs.save(o,i),n.md?console.log(U(Se("LLM Analysis Saved"),kt({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(s){return{success:!1,error:w(s)}}}async getLlmAnalysis(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return{success:!1,error:"No project ID found"};let o=Bs.getActive(s);if(!o)return t.md?console.log(U("## No LLM Analysis","> Run `prjct sync` to generate.")):console.log(JSON.stringify({success:!1,message:"No LLM analysis found"})),{success:!1,message:"No LLM analysis found"};if(t.md){let i=[Se(`LLM Analysis (${o.architecture.style})`),""];o.architecture.insights.length>0&&i.push(ee("Architecture Insights",Ie(o.architecture.insights))),o.patterns.length>0&&i.push(ee("Patterns",Ie(o.patterns.map(a=>`**${a.name}** \u2014 ${a.description} (${a.category})`)))),o.antiPatterns.length>0&&i.push(ee("Anti-Patterns",Ie(o.antiPatterns.map(a=>`[${a.severity}] ${a.issue} \u2014 ${a.suggestion}`)))),o.techDebt.length>0&&i.push(ee("Tech Debt",Ie(o.techDebt.map(a=>`[${a.priority}/${a.effort}] ${a.description}`)))),o.conventions.length>0&&i.push(ee("Conventions",Ie(o.conventions.map(a=>`**${a.category}**: ${a.rule}`)))),console.log(U(...i))}else console.log(JSON.stringify({success:!0,analysis:o}));return{success:!0,data:o}}catch(n){return{success:!1,error:w(n)}}}async stats(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return{success:!1,error:"No project ID found"};let o=await Yn.getSummary(s),i=await Yn.getDailyStats(s,30),a=await Uh(s),c=await ct.getPatternsSummary(s);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,last30DaysTokens:o.last30DaysTokens,trend:o.trend,dailyStats:i};return console.log(JSON.stringify(p,null,2)),{success:!0,data:p}}let u="Unknown";try{u=T.getDoc(s,"project")?.name||"Unknown"}catch{}let d=await Yn.read(s),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: ${to(o.totalTokensSaved)} tokens`),console.log(` Compression: ${(o.compressionRate*100).toFixed(0)}% average reduction`),console.log(` Estimated cost: ${Do(o.estimatedCostSaved)} saved`),console.log(""),console.log("\u26A1 PERFORMANCE"),console.log(` Syncs completed: ${o.syncCount.toLocaleString()}`),console.log(` Avg sync time: ${Uu(o.avgSyncDuration)}`),console.log(""),o.topAgents.length>0){console.log("\u{1F916} AGENT USAGE (all time)");let p=o.topAgents.reduce((g,f)=>g+f.usageCount,0);for(let g of o.topAgents){let f=p>0?(g.usageCount/p*100).toFixed(0):0;console.log(` ${g.agentName.padEnd(12)}: ${f}% (${g.usageCount} uses)`)}console.log("")}if(i.length>0){console.log("\u{1F4C8} TREND (last 30 days)");let p=Hh(i);if(console.log(` ${p} ${to(o.last30DaysTokens)} tokens saved`),o.trend!==0){let g=o.trend>0?"\u2191":"\u2193",f=o.trend>0?"+":"";console.log(` ${g} ${f}${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=Gh(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(n){return console.error("\u274C Error:",w(n)),{success:!1,error:w(n)}}}async status(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):h.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=qr(e),i=await o.check(s),a=await o.getSessionInfo(s),c=await Je.getStatus(s);if(t.json)return console.log(JSON.stringify({success:!0,...i,session:a,analysis:c})),{success:!0,data:{...i,session:a,analysis:c}};if(t.md){let u=Vh.basename(e),d=i.isStale?"stale":"fresh",m=i.daysSinceSync>0?`${i.daysSinceSync} day${i.daysSinceSync!==1?"s":""} ago`:"today",p=[];c.hasSealed&&p.push(`Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&p.push(`Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&p.push(`Previous: ${c.previousSealedCommit} (rollback available)`);let g=U(`## \u26A1 Status: ${u}`,kt({Staleness:d,"Last sync":m,"Commits since sync":i.commitsSinceSync,Reason:i.reason}),p.length>0?ee("Analysis",Ie(p)):null);return console.log(g),{success:!0,data:{...i,session:a,analysis:c}}}return console.log(""),console.log(o.formatStatus(i)),console.log(""),console.log(o.formatSessionInfo(a)),(c.hasSealed||c.hasDraft)&&(console.log(""),console.log("Analysis:"),c.hasSealed&&console.log(` Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&console.log(` Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&console.log(` Previous: ${c.previousSealedCommit} (rollback available)`)),console.log(""),{success:!0,data:{...i,session:a,analysis:c}}}catch(n){let s=w(n);return t.json?console.log(JSON.stringify({success:!1,error:s})):h.fail(s),{success:!1,error:s}}}async diff(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await Je.diff(s);if(!o){let i="Cannot compute diff: need both a sealed and a draft analysis. Run `p. sync` to create a draft.";return t.json?console.log(JSON.stringify({success:!1,error:i})):t.md?console.log(U("## Analysis Diff",`> ${i}`)):h.warn(i),{success:!1,error:i}}if(t.json)return console.log(JSON.stringify({success:!0,...o})),{success:!0,data:o};if(t.md)return console.log(U(Wc(o))),{success:!0,data:o};if(!o.hasChanges)h.done("No changes between draft and sealed analysis");else{h.section("Analysis Diff"),console.log(dm(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`),h.done(i.join(", "))}return console.log(""),{success:!0,data:o}}catch(n){let s=w(n);return t.json?console.log(JSON.stringify({success:!1,error:s})):t.md?console.log(U("## \u274C Diff Failed",`> ${s}`)):h.fail(s),{success:!1,error:s}}}async seal(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await Je.seal(s);return t.json?(console.log(JSON.stringify({success:o.success,signature:o.signature,error:o.error})),{success:o.success,error:o.error}):o.success?(h.done("Analysis sealed"),console.log(` Signature: ${o.signature?.substring(0,16)}...`),console.log(""),{success:!0,data:{signature:o.signature}}):(h.fail(o.error||"Seal failed"),{success:!1,error:o.error})}catch(n){let s=w(n);return t.json?console.log(JSON.stringify({success:!1,error:s})):h.fail(s),{success:!1,error:s}}}async rollback(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return t.json&&console.log(JSON.stringify({success:!1,error:"No project ID found"})),{success:!1,error:"No project ID found"};let o=await Je.rollback(s);return t.json?(console.log(JSON.stringify({success:o.success,restoredSignature:o.restoredSignature,error:o.error})),{success:o.success,error:o.error}):t.md?o.success?(console.log(U(Se("Analysis Rolled Back"),kt({"Restored signature":`${o.restoredSignature?.substring(0,16)}...`,Note:"Previous sealed version is now active. Current version moved to draft."}))),{success:!0,data:{restoredSignature:o.restoredSignature}}):(console.log(U("## \u274C Rollback Failed",`> ${o.error}`)),{success:!1,error:o.error}):o.success?(h.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}}):(h.fail(o.error||"Rollback failed"),{success:!1,error:o.error})}catch(n){let s=w(n);return t.json?console.log(JSON.stringify({success:!1,error:s})):t.md?console.log(U("## \u274C Rollback Failed",`> ${s}`)):h.fail(s),{success:!1,error:s}}}async verify(e=process.cwd(),t={}){if(t.semantic)return this.semanticVerify(e,t);try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return{success:!1,error:"No project ID found"};let o=await Je.verify(s);return t.json?(console.log(JSON.stringify(o)),{success:o.valid}):(o.valid?h.done(o.message):h.fail(o.message),console.log(""),{success:o.valid,data:o})}catch(n){let s=w(n);return h.fail(s),{success:!1,error:s}}}async semanticVerify(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):h.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=e;try{o=T.getDoc(s,"project")?.repoPath||e}catch{}let i=await Je.semanticVerify(s,o);if(t.json)return console.log(JSON.stringify(i)),{success:i.passed,data:i};console.log(""),i.passed?(h.done("Semantic verification passed"),console.log(` ${i.passedCount}/${i.checks.length} checks passed (${i.totalMs}ms)`)):(h.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(n){let s=w(n);return t.json?console.log(JSON.stringify({success:!1,error:s})):h.fail(s),{success:!1,error:s}}}}});function no(r){return Buffer.from(`${JSON.stringify(r)}
|
|
1350
|
-
`)}var
|
|
1351
|
-
`);if(u!==-1){let d=o.slice(0,u);o=o.slice(u+1);try{let m=JSON.parse(d);i=!0,clearTimeout(a),
|
|
1349
|
+
\`\`\``,w=ai("sync"),v=U(Se("Sync Complete"),St({Duration:`${(m/1e3).toFixed(1)}s`,Agents:`${g} generated`,"Files indexed":d.stats.fileCount,"Context files":p}),f,d.git.hasChanges?pm("Uncommitted changes detected"):null,S,de(w.map(T=>({label:T.desc,command:T.cmd}))));return console.log(v),{success:!0,data:d,metrics:{elapsed:m,contextFilesCount:p,agentCount:g,fileCount:d.stats.fileCount}}}return Au(d,i)}catch(n){return t.md?console.log(U("## \u274C Sync Failed",`> ${y(n)}`)):h.fail(y(n)),{success:!1,error:y(n)}}}async analysisPayload(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await jn.sync(e,{aiTools:[]});if(!o.success)return{success:!1,error:o.error||"Failed to gather project data"};let i=o.git.recentCommits[0]?.hash??null;if(i&&zs.isCurrent(r,i))return t.md?console.log(U(Se("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 bh(r,e,o.git,o.stats);return t.md?console.log(U("## \u{1F50D} Analysis Payload","> Analyze this project data and produce structured findings.","","```json",JSON.stringify(a,null,2),"```","","> After analyzing, call: `prjct analysis save-llm --json '{...}'`")):console.log(JSON.stringify({success:!0,payload:a})),{success:!0,data:a}}catch(n){return{success:!1,error:y(n)}}}async saveLlmAnalysis(e,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return{success:!1,error:"No project ID found"};let i=JSON.parse(e);return!i.version||!i.architecture||!i.patterns?{success:!1,error:"Invalid LLM analysis format. Missing required fields."}:(zs.save(o,i),n.md?console.log(U(Se("LLM Analysis Saved"),St({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:y(r)}}}async getLlmAnalysis(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=zs.getActive(r);if(!o)return t.md?console.log(U("## No LLM Analysis","> Run `prjct sync` to generate.")):console.log(JSON.stringify({success:!1,message:"No LLM analysis found"})),{success:!1,message:"No LLM analysis found"};if(t.md){let i=[Se(`LLM Analysis (${o.architecture.style})`),""];o.architecture.insights.length>0&&i.push(ee("Architecture Insights",Ae(o.architecture.insights))),o.patterns.length>0&&i.push(ee("Patterns",Ae(o.patterns.map(a=>`**${a.name}** \u2014 ${a.description} (${a.category})`)))),o.antiPatterns.length>0&&i.push(ee("Anti-Patterns",Ae(o.antiPatterns.map(a=>`[${a.severity}] ${a.issue} \u2014 ${a.suggestion}`)))),o.techDebt.length>0&&i.push(ee("Tech Debt",Ae(o.techDebt.map(a=>`[${a.priority}/${a.effort}] ${a.description}`)))),o.conventions.length>0&&i.push(ee("Conventions",Ae(o.conventions.map(a=>`**${a.category}**: ${a.rule}`)))),console.log(U(...i))}else console.log(JSON.stringify({success:!0,analysis:o}));return{success:!0,data:o}}catch(n){return{success:!1,error:y(n)}}}async stats(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await Jn.getSummary(r),i=await Jn.getDailyStats(r,30),a=await Rh(r),c=await at.getPatternsSummary(r);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,last30DaysTokens:o.last30DaysTokens,trend:o.trend,dailyStats:i};return console.log(JSON.stringify(p,null,2)),{success:!0,data:p}}let u="Unknown";try{u=E.getDoc(r,"project")?.name||"Unknown"}catch{}let d=await Jn.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: ${Yr(o.totalTokensSaved)} tokens`),console.log(` Compression: ${(o.compressionRate*100).toFixed(0)}% average reduction`),console.log(` Estimated cost: ${Ao(o.estimatedCostSaved)} saved`),console.log(""),console.log("\u26A1 PERFORMANCE"),console.log(` Syncs completed: ${o.syncCount.toLocaleString()}`),console.log(` Avg sync time: ${Ru(o.avgSyncDuration)}`),console.log(""),o.topAgents.length>0){console.log("\u{1F916} AGENT USAGE (all time)");let p=o.topAgents.reduce((g,f)=>g+f.usageCount,0);for(let g of o.topAgents){let f=p>0?(g.usageCount/p*100).toFixed(0):0;console.log(` ${g.agentName.padEnd(12)}: ${f}% (${g.usageCount} uses)`)}console.log("")}if(i.length>0){console.log("\u{1F4C8} TREND (last 30 days)");let p=Dh(i);if(console.log(` ${p} ${Yr(o.last30DaysTokens)} tokens saved`),o.trend!==0){let g=o.trend>0?"\u2191":"\u2193",f=o.trend>0?"+":"";console.log(` ${g} ${f}${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=jh(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(n){return console.error("\u274C Error:",y(n)),{success:!1,error:y(n)}}}async status(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):h.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=zr(e),i=await o.check(r),a=await o.getSessionInfo(r),c=await Je.getStatus(r);if(t.json)return console.log(JSON.stringify({success:!0,...i,session:a,analysis:c})),{success:!0,data:{...i,session:a,analysis:c}};if(t.md){let u=Mh.basename(e),d=i.isStale?"stale":"fresh",m=i.daysSinceSync>0?`${i.daysSinceSync} day${i.daysSinceSync!==1?"s":""} ago`:"today",p=[];c.hasSealed&&p.push(`Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&p.push(`Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&p.push(`Previous: ${c.previousSealedCommit} (rollback available)`);let g=U(`## \u26A1 Status: ${u}`,St({Staleness:d,"Last sync":m,"Commits since sync":i.commitsSinceSync,Reason:i.reason}),p.length>0?ee("Analysis",Ae(p)):null);return console.log(g),{success:!0,data:{...i,session:a,analysis:c}}}return console.log(""),console.log(o.formatStatus(i)),console.log(""),console.log(o.formatSessionInfo(a)),(c.hasSealed||c.hasDraft)&&(console.log(""),console.log("Analysis:"),c.hasSealed&&console.log(` Sealed: ${c.sealedCommit} (${c.sealedAt})`),c.hasDraft&&console.log(` Draft: ${c.draftCommit} (pending seal)`),c.hasPreviousSealed&&console.log(` Previous: ${c.previousSealedCommit} (rollback available)`)),console.log(""),{success:!0,data:{...i,session:a,analysis:c}}}catch(n){let r=y(n);return t.json?console.log(JSON.stringify({success:!1,error:r})):h.fail(r),{success:!1,error:r}}}async diff(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.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 Je.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(U("## Analysis Diff",`> ${i}`)):h.warn(i),{success:!1,error:i}}if(t.json)return console.log(JSON.stringify({success:!0,...o})),{success:!0,data:o};if(t.md)return console.log(U(Ic(o))),{success:!0,data:o};if(!o.hasChanges)h.done("No changes between draft and sealed analysis");else{h.section("Analysis Diff"),console.log(em(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`),h.done(i.join(", "))}return console.log(""),{success:!0,data:o}}catch(n){let r=y(n);return t.json?console.log(JSON.stringify({success:!1,error:r})):t.md?console.log(U("## \u274C Diff Failed",`> ${r}`)):h.fail(r),{success:!1,error:r}}}async seal(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.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 Je.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?(h.done("Analysis sealed"),console.log(` Signature: ${o.signature?.substring(0,16)}...`),console.log(""),{success:!0,data:{signature:o.signature}}):(h.fail(o.error||"Seal failed"),{success:!1,error:o.error})}catch(n){let r=y(n);return t.json?console.log(JSON.stringify({success:!1,error:r})):h.fail(r),{success:!1,error:r}}}async rollback(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.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 Je.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(U(Se("Analysis Rolled Back"),St({"Restored signature":`${o.restoredSignature?.substring(0,16)}...`,Note:"Previous sealed version is now active. Current version moved to draft."}))),{success:!0,data:{restoredSignature:o.restoredSignature}}):(console.log(U("## \u274C Rollback Failed",`> ${o.error}`)),{success:!1,error:o.error}):o.success?(h.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}}):(h.fail(o.error||"Rollback failed"),{success:!1,error:o.error})}catch(n){let r=y(n);return t.json?console.log(JSON.stringify({success:!1,error:r})):t.md?console.log(U("## \u274C Rollback Failed",`> ${r}`)):h.fail(r),{success:!1,error:r}}}async verify(e=process.cwd(),t={}){if(t.semantic)return this.semanticVerify(e,t);try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return{success:!1,error:"No project ID found"};let o=await Je.verify(r);return t.json?(console.log(JSON.stringify(o)),{success:o.valid}):(o.valid?h.done(o.message):h.fail(o.message),console.log(""),{success:o.valid,data:o})}catch(n){let r=y(n);return h.fail(r),{success:!1,error:r}}}async semanticVerify(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return t.json?console.log(JSON.stringify({success:!1,error:"No project ID found"})):h.fail("No project ID found"),{success:!1,error:"No project ID found"};let o=e;try{o=E.getDoc(r,"project")?.repoPath||e}catch{}let i=await Je.semanticVerify(r,o);if(t.json)return console.log(JSON.stringify(i)),{success:i.passed,data:i};console.log(""),i.passed?(h.done("Semantic verification passed"),console.log(` ${i.passedCount}/${i.checks.length} checks passed (${i.totalMs}ms)`)):(h.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(n){let r=y(n);return t.json?console.log(JSON.stringify({success:!1,error:r})):h.fail(r),{success:!1,error:r}}}}});function Zr(s){return Buffer.from(`${JSON.stringify(s)}
|
|
1350
|
+
`)}var Ge,Wh,zu=k(()=>{"use strict";Ge={runDir:l(()=>`${process.env.HOME||fn("node:os").homedir()}/.prjct-cli/run`,"runDir"),socket:l(()=>`${Ge.runDir()}/daemon.sock`,"socket"),pid:l(()=>`${Ge.runDir()}/daemon.pid`,"pid"),log:l(()=>`${Ge.runDir()}/daemon.log`,"log")},Wh=1800*1e3;l(Zr,"encodeMessage")});var Bh={};hn(Bh,{executeViaDaemon:()=>mT,forceKillDaemon:()=>fT,getDaemonStatus:()=>pT,isDaemonRunning:()=>zh,sendRequest:()=>eo,spawnDaemon:()=>Vh,stopDaemon:()=>gT});import sa from"node:crypto";import Ye from"node:fs";import{connect as dT}from"node:net";async function zh(){let s=Ge.socket();if(!Ye.existsSync(s))return!1;try{return(await eo({id:sa.randomUUID(),command:"__ping",args:[],options:{},cwd:process.cwd()})).success}catch{try{Ye.unlinkSync(s)}catch{}return!1}}async function pT(){let s=Ge.socket(),e=Ge.pid();if(!Ye.existsSync(s))return{running:!1};try{let t=await eo({id:sa.randomUUID(),command:"daemon",args:["status"],options:{},cwd:process.cwd()});if(t.success&&t.result)return t.result}catch{}return Ye.existsSync(e)?{running:!1,pid:parseInt(Ye.readFileSync(e,"utf-8").trim(),10),socketPath:s}:{running:!1}}function eo(s){return new Promise((e,t)=>{let n=Ge.socket(),r=dT(n),o="",i=!1,a=setTimeout(()=>{i||(i=!0,r.destroy(),t(new Error("Daemon request timed out")))},3e4);r.on("connect",()=>{r.write(Zr(s))}),r.on("data",c=>{o+=c.toString();let u=o.indexOf(`
|
|
1351
|
+
`);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 mT(s,e,t,n,r,o=!0){let i=Ge.socket();if(!Ye.existsSync(i))return o&&Vh().catch(()=>{}),null;try{return await eo({id:sa.randomUUID(),command:s,args:e,options:t,cwd:n,perfStartNs:r})}catch{return null}}async function gT(){try{return(await eo({id:sa.randomUUID(),command:"daemon",args:["stop"],options:{},cwd:process.cwd()})).success}catch{return!1}}function fT(){let s=Ge.pid(),e=Ge.socket(),t=!1;if(Ye.existsSync(s)){let n=parseInt(Ye.readFileSync(s,"utf-8").trim(),10);if(!Number.isNaN(n))try{process.kill(n,"SIGKILL"),t=!0}catch{}}try{Ye.existsSync(s)&&Ye.unlinkSync(s)}catch{}try{Ye.existsSync(e)&&Ye.unlinkSync(e)}catch{}return t}async function Vh(){let{spawn:s}=await import("node:child_process"),e=await import("node:path"),t=e.join(__dirname,"entry.ts"),n=e.join(__dirname,"..","daemon","entry.mjs"),r=e.join(__dirname,"..","dist","daemon","entry.mjs"),o,i;if(Ye.existsSync(t))o=t,i="bun";else if(Ye.existsSync(n))o=n,i="node";else if(Ye.existsSync(r))o=r,i="node";else return!1;let a=Ge.runDir();Ye.mkdirSync(a,{recursive:!0});let c=Ge.log(),u=Ye.openSync(c,"a");return s(i,[o],{detached:!0,stdio:["ignore",u,u],env:{...process.env,PRJCT_DAEMON:"1"}}).unref(),Ye.closeSync(u),await new Promise(m=>setTimeout(m,500)),zh()}var Jh=k(()=>{"use strict";zu();l(zh,"isDaemonRunning");l(pT,"getDaemonStatus");l(eo,"sendRequest");l(mT,"executeViaDaemon");l(gT,"stopDaemon");l(fT,"forceKillDaemon");l(Vh,"spawnDaemon")});import Qe from"node:fs";import{createServer as uE}from"node:net";ha();Di();ln();Yt();L();$s();lt();import tT from"node:path";Pt();ve();L();ce();var Yi=class{static{l(this,"CommandRegistry")}handlers=new Map;handlerFns=new Map;metadata=new Map;categories=new Map;noProjectCommands=new Set(["init","setup","start","migrateAll","sessions"]);register(e,t){this.handlers.set(e.name,e),this.setMeta(e.name,t)}registerFn(e,t,n){this.handlerFns.set(e,t),this.setMeta(e,n)}setMeta(e,t){let n=t?.requiresProject??!this.noProjectCommands.has(e);this.metadata.set(e,{name:e,group:t?.group??"unknown",description:t?.description??"",requiresProject:n,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,n,r){let o=t[n];if(typeof o!="function")throw new Error(`${String(n)} 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 n of this.categories.keys())t[n]=e.filter(r=>r.group===n).length;return{total:e.length,implemented:e.filter(n=>n.implemented).length,withTemplates:e.filter(n=>n.hasTemplate).length,claudeOnly:e.filter(n=>n.usage.claude&&!n.usage.terminal).length,terminalOnly:e.filter(n=>!n.usage.claude&&n.usage.terminal).length,both:e.filter(n=>n.usage.claude&&n.usage.terminal).length,requiresInit:e.filter(n=>n.requiresProject).length,byCategory:t}}validate(){let e=[],t=this.getAll(),n=t.map(a=>a.name),r=n.filter((a,c)=>n.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 M.getProjectId(e);if(!t)throw new Error("No prjct project found. Run /p:init first.");return{projectId:t,projectPath:e,globalPath:A.getGlobalProjectPath(t),timestamp:b()}}async execute(e,t,n=process.cwd()){let r=this.metadata.get(e),o;if(r?.requiresProject===!1)o={projectId:"",projectPath:n,globalPath:"",timestamp:b()};else try{o=await this.buildContext(n)}catch(c){return{success:!1,error:y(c)}}let i=this.handlers.get(e);if(i)return i.execute(t,o);let a=this.handlerFns.get(e);return a?a(t,o):{success:!1,error:`Command not found: ${e}`}}async executeWithoutProject(e,t,n=process.cwd()){let r=this.handlers.get(e);if(r){let i={projectId:"",projectPath:n,globalPath:"",timestamp:b()};return r.execute(t,i)}let o=this.handlerFns.get(e);if(o){let i={projectId:"",projectPath:n,globalPath:"",timestamp:b()};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()}},V=new Yi;var Vs=class extends Ce{static{l(this,"AnalyticsCommands")}async dash(e="default",t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=tT.basename(t),a=await N.getCurrentTask(o),c=await Ie.getActiveTasks(o),u=await wt.getRecent(o,5),d=await tt.getPending(o);if(e==="compact"){let m=a?`\u{1F3AF} ${a.description.slice(0,30)}`:"\u{1F4A4} idle",p=`\u{1F4CB} ${c.length}`,g=`\u{1F680} ${u.length}`;return h.done(`${m} | ${p} | ${g}`),{success:!0,view:"compact"}}if(e==="week"||e==="month"){let m=e==="week"?7:30,p=B.getDaysAgo(m),g=[];try{let w=p.toISOString();g=E.query(o,"SELECT data, timestamp FROM events WHERE type LIKE ? AND timestamp >= ? ORDER BY id DESC","memory.%",w).map(T=>({...JSON.parse(T.data),timestamp:T.timestamp}))}catch{g=[]}let f={tasksCompleted:g.filter(w=>w.action==="task_completed").length,featuresShipped:g.filter(w=>w.action==="feature_shipped").length,totalActions:g.length};console.log(`
|
|
1352
1352
|
\u{1F4CA} ${e.toUpperCase()} PROGRESS - ${i}
|
|
1353
1353
|
`),console.log("\u2550".repeat(50)),console.log(` Tasks completed: ${f.tasksCompleted}`),console.log(` Features shipped: ${f.featuresShipped}`),console.log(` Total actions: ${f.totalActions}`),console.log("\u2550".repeat(50));let S=this._generateSparkline(g,m);return console.log(`
|
|
1354
1354
|
Activity: ${S}
|
|
1355
|
-
`),{success:!0,view:e,metrics:f}}if(e==="roadmap"){let m=await
|
|
1355
|
+
`),{success:!0,view:e,metrics:f}}if(e==="roadmap"){let m=await kt.build(t),p=await rt.get("Read")(m.paths.roadmap);if(console.log(`
|
|
1356
1356
|
\u{1F5FA}\uFE0F ROADMAP - ${i}
|
|
1357
1357
|
`),console.log("\u2550".repeat(50)),!p||p.trim()==="# ROADMAP")console.log(" No features planned yet."),console.log(` Use /p:feature to add features.
|
|
1358
|
-
`);else{let g=p.split("##").filter(f=>f.trim()&&!f.includes("ROADMAP"));g.slice(0,5).forEach((f,S)=>{let
|
|
1359
|
-
`)[0].trim();console.log(` ${S+1}. ${
|
|
1360
|
-
`),{success:!0,view:"roadmap"}}if(n.md){let m=a?`${a.description}${a.startedAt?` (started ${
|
|
1358
|
+
`);else{let g=p.split("##").filter(f=>f.trim()&&!f.includes("ROADMAP"));g.slice(0,5).forEach((f,S)=>{let w=f.split(`
|
|
1359
|
+
`)[0].trim();console.log(` ${S+1}. ${w}`)}),g.length>5&&console.log(` ... and ${g.length-5} more`)}return console.log(`${"\u2550".repeat(50)}
|
|
1360
|
+
`),{success:!0,view:"roadmap"}}if(n.md){let m=a?`${a.description}${a.startedAt?` (started ${B.calculateDuration(new Date(a.startedAt))} ago)`:""}`:"No active task",p=c.length>0?c.slice(0,5).map(S=>{let w=S.priority?` [${S.priority}]`:"";return`${S.description}${w}`}):["Queue is empty"],g=u.length>0?u.slice(0,5).map(S=>{let w=S.shippedAt?new Date(S.shippedAt).toLocaleDateString():"";return`${S.name}${w?` (${w})`:""}`}):["Nothing shipped yet"],f=U(`## \u26A1 Dashboard: ${i}`,ee("Current Focus",m),ee(`Queue (${c.length})`,Ae(p,!0)),ee("Recent Ships",Ae(g)),ee("Ideas",`${d.length} pending`),de([{label:"Start task",command:"p. task"},{label:"Complete",command:"p. done"},{label:"Ship",command:"p. ship"}]));console.log(f)}else{console.log(`
|
|
1361
1361
|
\u{1F4CA} DASHBOARD - ${i}
|
|
1362
|
-
`),console.log("\u2550".repeat(50));let m=
|
|
1362
|
+
`),console.log("\u2550".repeat(50));let m=zr(t),p=await m.check(o),g=m.getWarning(p);if(g&&console.log(`
|
|
1363
1363
|
${g}`),console.log(`
|
|
1364
|
-
\u{1F3AF} CURRENT FOCUS`),a){if(console.log(` ${a.description}`),a.startedAt){let f=
|
|
1365
|
-
\u{1F4CB} QUEUE`),c.length===0?console.log(" Queue is empty"):(c.slice(0,3).forEach((f,S)=>{let
|
|
1364
|
+
\u{1F3AF} CURRENT FOCUS`),a){if(console.log(` ${a.description}`),a.startedAt){let f=B.calculateDuration(new Date(a.startedAt));console.log(` Started: ${f} ago`)}}else console.log(" No active task. Use /p:work to start.");console.log(`
|
|
1365
|
+
\u{1F4CB} QUEUE`),c.length===0?console.log(" Queue is empty"):(c.slice(0,3).forEach((f,S)=>{let w=f.priority?`[${f.priority}]`:"";console.log(` ${S+1}. ${f.description.slice(0,40)} ${w}`)}),c.length>3&&console.log(` ... and ${c.length-3} more`)),console.log(`
|
|
1366
1366
|
\u{1F680} RECENT SHIPS`),u.length===0?console.log(" Nothing shipped yet"):u.slice(0,3).forEach(f=>{let S=f.shippedAt?new Date(f.shippedAt).toLocaleDateString():"";console.log(` \u2022 ${f.name} ${S?`(${S})`:""}`)}),console.log(`
|
|
1367
1367
|
\u{1F4A1} IDEAS`),console.log(` ${d.length} pending ideas`),console.log(`
|
|
1368
1368
|
${"\u2550".repeat(50)}`),console.log(`\u{1F4A1} /p:work to start | /p:done to complete | /p:ship to ship
|
|
1369
|
-
`)}return await this.logToMemory(t,"dash_viewed",{view:e,timestamp:
|
|
1369
|
+
`)}return await this.logToMemory(t,"dash_viewed",{view:e,timestamp:B.getTimestamp()}),{success:!0,view:"default",stats:{currentTask:a?.description||null,queueCount:c.length,shippedCount:u.length,ideasCount:d.length}}}catch(r){return h.fail(y(r)),{success:!1,error:y(r)}}}async help(e="",t=process.cwd()){try{if(!e){console.log(`
|
|
1370
1370
|
PRJCT COMMANDS
|
|
1371
|
-
`),console.log("=".repeat(50));let i=
|
|
1371
|
+
`),console.log("=".repeat(50));let i=V.getAllCategories(),a=V.getAll(),c={};return a.forEach(u=>{u.deprecated||(c[u.group]||(c[u.group]=[]),c[u.group].push(u))}),Object.entries(c).forEach(([u,d])=>{let m=i.get(u);console.log(`
|
|
1372
1372
|
${m?.title||u}:`),d.forEach(p=>{let g=p.params?` ${p.params}`:"";console.log(` ${p.name}${g}`),console.log(` ${p.description}`)})}),console.log(`
|
|
1373
1373
|
${"\u2550".repeat(50)}`),console.log(`\u{1F4A1} Use /p:help <command> for detailed help
|
|
1374
|
-
`),{success:!0,topic:"overview"}}let n=
|
|
1374
|
+
`),{success:!0,topic:"overview"}}let n=V.getByName(e);if(n){if(console.log(`
|
|
1375
1375
|
\u{1F4DA} HELP: /p:${n.name}
|
|
1376
1376
|
`),console.log("\u2550".repeat(50)),console.log(`Description: ${n.description}`),n.params&&console.log(`Parameters: ${n.params}`),n.usage&&(console.log(`
|
|
1377
1377
|
Usage:`),n.usage.claude&&console.log(` Claude: ${n.usage.claude}`),n.usage.terminal&&console.log(` Terminal: ${n.usage.terminal}`)),n.features){console.log(`
|
|
1378
1378
|
Features:`);for(let i of n.features)console.log(` \u2022 ${i}`)}return console.log(`
|
|
1379
1379
|
${"\u2550".repeat(50)}
|
|
1380
|
-
`),{success:!0,topic:e,command:n}}let
|
|
1380
|
+
`),{success:!0,topic:e,command:n}}let r={start:{command:"work",hint:"Start working on a task"},begin:{command:"work",hint:"Start working on a task"},finish:{command:"done",hint:"Mark current task complete"},complete:{command:"done",hint:"Mark current task complete"},deploy:{command:"ship",hint:"Ship a feature"},release:{command:"ship",hint:"Ship a feature"},status:{command:"dash",hint:"View project dashboard"},overview:{command:"dash",hint:"View project dashboard"},queue:{command:"next",hint:"View task queue"},tasks:{command:"next",hint:"View task queue"},add:{command:"feature",hint:"Add a new feature"},new:{command:"feature",hint:"Add a new feature"},break:{command:"pause",hint:"Pause current task"},stop:{command:"pause",hint:"Pause current task"},continue:{command:"resume",hint:"Resume paused task"},back:{command:"resume",hint:"Resume paused task"}},o=e.toLowerCase();for(let[i,a]of Object.entries(r))if(o.includes(i))return console.log(`
|
|
1381
1381
|
\u{1F4A1} Did you mean /p:${a.command}?`),console.log(` ${a.hint}
|
|
1382
1382
|
`),{success:!0,topic:e,suggestion:a.command};return console.log(`
|
|
1383
1383
|
\u2753 Unknown topic: ${e}`),console.log(` Use /p:help to see all commands
|
|
1384
|
-
`),{success:!1,error:`Unknown topic: ${e}`}}catch(n){return h.fail(
|
|
1384
|
+
`),{success:!1,error:`Unknown topic: ${e}`}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}_generateSparkline(e,t){let n=["\u2581","\u2582","\u2583","\u2584","\u2585","\u2586","\u2587","\u2588"],r=new Date,o=[];for(let a=t-1;a>=0;a--){let c=new Date(r);c.setDate(c.getDate()-a);let u=new Date(c.setHours(0,0,0,0)),d=new Date(c.setHours(23,59,59,999)),m=e.filter(p=>{let g=new Date(p.timestamp);return g>=u&&g<=d}).length;o.push(m)}let i=Math.max(...o,1);return o.map(a=>n[Math.floor(a/i*(n.length-1))]).join("")}};xl();Pt();ve();Yt();L();import nT from"node:fs/promises";import sT from"node:path";var ls=class{static{l(this,"ContextCommands")}async context(e=null,t=process.cwd()){try{let n=(e||"").trim().split(/\s+/),r=n[0]||"task",o=n.slice(1).join(" "),i=await M.readConfig(t);if(!i||!i.projectId)return console.log(JSON.stringify({projectId:"",globalPath:"",currentTask:null,domains:[],primaryDomain:null,agents:[],subtasks:null,repoAnalysis:{ecosystem:"unknown",frameworks:[],hasTests:!1,technologies:[]}},null,2)),{success:!1,message:"No prjct project. Run `p. init` first."};let a=i.projectId,c=A.getGlobalProjectPath(a),u=await N.read(a),d=u?.currentTask?{id:u.currentTask.id,description:u.currentTask.description,startedAt:u.currentTask.startedAt,subtasks:u.currentTask.subtasks?.map(f=>({id:f.id,description:f.description,status:f.status,domain:f.domain})),currentSubtaskIndex:u.currentTask.currentSubtaskIndex}:null,m=null;if(o)try{m=await ki.execute(r,o,t)}catch(f){console.error(`Warning: Orchestrator failed: ${y(f)}`)}let p=await this.loadRepoAnalysis(c),g={projectId:a,globalPath:c,currentTask:d,domains:m?.detectedDomains||[],primaryDomain:m?.primaryDomain||null,agents:m?.agents.map(f=>({name:f.name,domain:f.domain,filePath:f.filePath,skills:f.skills,preview:f.content.substring(0,500)}))||[],subtasks:m?.subtasks?.map(f=>({id:f.id,description:f.description,domain:f.domain,agent:f.agent,status:f.status,order:f.order}))||null,repoAnalysis:{ecosystem:p?.ecosystem||"unknown",frameworks:p?.frameworks||[],hasTests:p?.hasTests||!1,technologies:p?.technologies||[]}};return console.log(JSON.stringify(g,null,2)),{success:!0,message:""}}catch(n){return{success:!1,message:`Context error: ${y(n)}`}}}async loadRepoAnalysis(e){try{let t=sT.join(e,"analysis","repo-analysis.json"),n=await nT.readFile(t,"utf-8"),r=JSON.parse(n);return{ecosystem:r.ecosystem||"unknown",frameworks:r.frameworks||[],hasTests:r.hasTests??!1,technologies:r.technologies||[]}}catch(t){return C(t),null}}},VW=new ls;Si();lt();ln();Yt();oe();L();lt();async function Qi(s){let e=await M.getProjectId(s),t={rotated:[],totalSize:0,freedSpace:0};if(!e)return{success:!0,results:t};let r=G.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(r>500){let o=r-500;G.run(e,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",o),t.rotated.push("memory-events"),t.freedSpace=o}return{success:!0,results:t}}l(Qi,"cleanupMemory");async function Zi(s){let e=await M.getProjectId(s);if(!e)return;let n=G.get(e,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(n>500){let r=n-500;G.run(e,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",r)}}l(Zi,"cleanupMemoryInternal");async function ju(s={},e=process.cwd()){try{if(s.memory===!0||s.type==="memory"){h.spin("cleaning memory...");let a=await Qi(e);return h.done("memory cleaned"),a}h.spin("cleaning up...");let n=await M.getProjectId(e);if(!n)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let r=[],i=G.get(n,"SELECT COUNT(*) as cnt FROM events WHERE type LIKE 'memory.%'")?.cnt??0;if(i>100){let a=i-100;G.run(n,"DELETE FROM events WHERE id IN (SELECT id FROM events WHERE type LIKE 'memory.%' ORDER BY id ASC LIMIT ?)",a),r.push(`Memory: ${a} old entries removed`)}else r.push("Memory: No cleanup needed");try{let a=await tt.cleanup(n);a.removed>0?r.push(`Ideas: ${a.removed} old archived ideas removed`):r.push("Ideas: No cleanup needed")}catch(a){r.push(`Ideas: Error - ${y(a)}`)}try{let c=(await Ie.getActiveTasks(n)).filter(u=>u.completed).length;c>0?r.push(`Queue: ${c} completed tasks found (not removed - use /p:done to clear)`):r.push("Queue: No completed tasks")}catch(a){r.push(`Queue: Error - ${y(a)}`)}return await Zi(e),await yt.log(e,"cleanup_performed",{items:r.length,timestamp:B.getTimestamp()}),h.done(`${r.length} items cleaned`),{success:!0,cleaned:r}}catch(t){return h.fail(y(t)),{success:!1,error:y(t)}}}l(ju,"cleanup");ln();L();lt();import Oh from"node:path";async function Iu(s=null,e={},t=process.cwd()){try{let n=e.type||"architecture";if(!["architecture","api","component","database","flow"].includes(n))return h.fail(`invalid type: ${n}`),{success:!1,error:"Invalid design type"};let o=s||"system";h.spin(`designing ${n}...`);let i=await M.getProjectId(t),a=Oh.join(A.getGlobalProjectPath(i),"planning","designs");await Te.ensureDir(a);let c="";switch(n){case"architecture":c=`# Architecture Design: ${o}
|
|
1385
1385
|
|
|
1386
1386
|
*Use templates/design/architecture.md for full design*
|
|
1387
1387
|
`;break;case"api":c=`# API Design: ${o}
|
|
@@ -1396,68 +1396,46 @@ ${"\u2550".repeat(50)}
|
|
|
1396
1396
|
`;break;case"flow":c=`# Flow Design: ${o}
|
|
1397
1397
|
|
|
1398
1398
|
*Use templates/design/flow.md for full design*
|
|
1399
|
-
`;break}let u=`${n}-${o.toLowerCase().replace(/\s+/g,"-")}.md`,d=
|
|
1400
|
-
`),c=(i[i.length-2]||"").match(/(\d+) files? changed(?:, (\d+) insertions?)?(?:, (\d+) deletions?)?/);c&&(t.filesChanged=parseInt(c[1],10)||0,t.linesAdded=parseInt(c[2],10)||0,t.linesRemoved=parseInt(c[3],10)||0)}catch(n){
|
|
1401
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,e.id,e.projectId,e.task,e.status,e.startedAt,e.pausedAt??null,e.completedAt??null,e.duration,JSON.stringify(e.metrics),JSON.stringify(e.timeline))}async getHistory(e=10){return this.initialized||await this.initialize(),
|
|
1399
|
+
`;break}let u=`${n}-${o.toLowerCase().replace(/\s+/g,"-")}.md`,d=Oh.join(a,u);return await Te.writeFile(d,c),await yt.log(t,"design_created",{type:n,target:o,timestamp:B.getTimestamp()}),h.done(`${n} design created`),{success:!0,designPath:d,type:n,target:o}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}l(Iu,"design");ln();import Bs from"node:path";si();Pt();oe();L();import{exec as rT}from"node:child_process";import{promisify as oT}from"node:util";Rt();var Fh=me;function ea(s){let e=0,t=null;for(let n of s.timeline)n.type==="start"||n.type==="resume"?t=new Date(n.at):(n.type==="pause"||n.type==="complete")&&t&&(e+=new Date(n.at).getTime()-t.getTime(),t=null);return t&&s.status==="active"&&(e+=Date.now()-t.getTime()),Math.round(e/1e3)}l(ea,"calculateDuration");function _h(s){if(s<60)return`${s}s`;if(s<3600)return`${Math.round(s/60)}m`;let e=Math.floor(s/3600),t=Math.round(s%3600/60);return t===0?`${e}h`:`${e}h ${t}m`}l(_h,"formatDuration");var Nh=oT(rT);function Lh(s){return{id:s.id,projectId:s.project_id,task:s.task,status:s.status,startedAt:s.started_at,pausedAt:s.paused_at,completedAt:s.completed_at,duration:s.duration,metrics:JSON.parse(s.metrics),timeline:JSON.parse(s.timeline)}}l(Lh,"rowToSession");var ta=class{static{l(this,"TaskSessionManager")}projectPath;projectId;initialized;constructor(e){this.projectPath=e,this.projectId=null,this.initialized=!1}async initialize(){if(this.projectId=await M.getProjectId(this.projectPath),!this.projectId)throw new Error("No prjct project found. Run /p:init first.");E.getDb(this.projectId),this.initialized=!0}generateId(){return Fh()}async getCurrent(){this.initialized||await this.initialize();let e=E.get(this.projectId,"SELECT * FROM sessions WHERE project_id = ? AND status IN ('active', 'paused') ORDER BY started_at DESC LIMIT 1",this.projectId);return e?Lh(e):null}async create(e){this.initialized||await this.initialize();let t=await this.getCurrent();if(t&&t.status==="active")throw new Error(`Session already active: "${t.task}". Use /p:done or /p:pause first.`);let n=new Date().toISOString(),r={id:this.generateId(),projectId:this.projectId,task:e,status:"active",startedAt:n,pausedAt:null,completedAt:null,duration:0,metrics:{filesCreated:0,filesChanged:0,filesModified:0,linesAdded:0,linesRemoved:0,commits:0,snapshots:[]},timeline:[{type:"start",at:n}]};return this.saveSession(r),await this.logEvent("session_started",{sessionId:r.id,task:e}),await Ds.sessionStarted({sessionId:r.id,task:e,projectId:this.projectId}),r}async resume(e=null){this.initialized||await this.initialize();let t=await this.getCurrent();if(e&&(!t||t.task!==e))return this.create(e);if(!t){if(!e)throw new Error("No active session. Provide a task to start one.");return this.create(e)}if(t.status==="active")return t;let n=new Date().toISOString();return t.status="active",t.timeline.push({type:"resume",at:n}),this.saveSession(t),await this.logEvent("session_resumed",{sessionId:t.id}),await Ds.sessionResumed({sessionId:t.id,task:t.task,projectId:this.projectId}),t}async pause(){this.initialized||await this.initialize();let e=await this.getCurrent();if(!e)throw new Error("No active session to pause.");if(e.status==="paused")return e;let t=new Date().toISOString();return e.status="paused",e.pausedAt=t,e.duration=ea(e),e.timeline.push({type:"pause",at:t}),this.saveSession(e),await this.logEvent("session_paused",{sessionId:e.id,duration:e.duration}),await Ds.sessionPaused({sessionId:e.id,task:e.task,duration:e.duration,projectId:this.projectId}),e}async complete(){this.initialized||await this.initialize();let e=await this.getCurrent();if(!e)throw new Error("No active session to complete.");let t=new Date().toISOString();return e.status="completed",e.completedAt=t,e.duration=ea(e),e.metrics=await this.calculateMetrics(e),e.timeline.push({type:"complete",at:t}),this.saveSession(e),await this.logEvent("session_completed",{sessionId:e.id,task:e.task,duration:e.duration,metrics:e.metrics}),await Ds.sessionCompleted({sessionId:e.id,task:e.task,duration:e.duration,metrics:e.metrics,projectId:this.projectId}),e}calculateDuration(e){return ea(e)}async calculateMetrics(e){let t={...e.metrics};try{let n=e.startedAt.split("T")[0],{stdout:r}=await Nh(`git rev-list --count --since="${n}" HEAD 2>/dev/null || echo "0"`,{cwd:this.projectPath});t.commits=parseInt(r.trim(),10)||0;let{stdout:o}=await Nh(`git diff --stat HEAD~${Math.max(t.commits,1)} 2>/dev/null || echo ""`,{cwd:this.projectPath}),i=o.split(`
|
|
1400
|
+
`),c=(i[i.length-2]||"").match(/(\d+) files? changed(?:, (\d+) insertions?)?(?:, (\d+) deletions?)?/);c&&(t.filesChanged=parseInt(c[1],10)||0,t.linesAdded=parseInt(c[2],10)||0,t.linesRemoved=parseInt(c[3],10)||0)}catch(n){C(n)||console.error(`Metrics calculation warning: ${y(n)}`)}return t}saveSession(e){E.run(this.projectId,`INSERT OR REPLACE INTO sessions (id, project_id, task, status, started_at, paused_at, completed_at, duration, metrics, timeline)
|
|
1401
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,e.id,e.projectId,e.task,e.status,e.startedAt,e.pausedAt??null,e.completedAt??null,e.duration,JSON.stringify(e.metrics),JSON.stringify(e.timeline))}async getHistory(e=10){return this.initialized||await this.initialize(),E.query(this.projectId,"SELECT * FROM sessions WHERE project_id = ? AND status = 'completed' ORDER BY completed_at DESC LIMIT ?",this.projectId,e).map(Lh)}async logEvent(e,t){try{E.appendEvent(this.projectId,`session.${e}`,t)}catch{}}static formatDuration(e){return _h(e)}};L();lt();async function $u(s=process.cwd()){try{if(!await M.getProjectId(s))return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};h.spin("checking for abandoned sessions...");let n=await new ta(s).getCurrent(),r=n?{task:n.task,startedAt:n.startedAt}:null;if(!r||!r.task)return h.warn("no abandoned session found"),{success:!0,message:"No abandoned session found"};if(console.log(`
|
|
1402
1402
|
Found abandoned session:
|
|
1403
|
-
`),console.log(` Task: ${
|
|
1403
|
+
`),console.log(` Task: ${r.task}`),r.startedAt){let o=B.calculateDuration(new Date(r.startedAt));console.log(` Started: ${o} ago`)}return r.context&&console.log(` Context: ${r.context.slice(0,100)}...`),console.log(`
|
|
1404
1404
|
Options:`),console.log(" 1. Use /p:work to resume working"),console.log(" 2. Use /p:done to mark as complete"),console.log(` 3. Delete session file to discard
|
|
1405
|
-
`),{success:!0,session:
|
|
1406
|
-
`).find(c=>c.includes("prjct-undo-"))?(o("git stash pop",{cwd:
|
|
1405
|
+
`),{success:!0,session:r}}catch(e){return h.fail(y(e)),{success:!1,error:y(e)}}}l($u,"recover");async function Mu(s=process.cwd()){try{h.spin("creating undo point...");let e=await M.getProjectId(s);if(!e)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=Bs.join(A.getGlobalProjectPath(e),"snapshots");await Te.ensureDir(t);let{execSync:n}=await import("node:child_process");try{if(!n("git status --porcelain",{cwd:s,encoding:"utf-8"}).trim())return h.warn("nothing to undo (no changes)"),{success:!0,message:"No changes to undo"};let i=`prjct-undo-${new Date().toISOString().replace(/[:.]/g,"-")}`;n(`git stash push -m "${i}"`,{cwd:s,encoding:"utf-8"});let a=Bs.join(t,"history.json"),c={snapshots:[],current:-1};try{let u=await Te.readFile(a);c=JSON.parse(u)}catch(u){if(!C(u)&&!(u instanceof SyntaxError))throw u}return c.snapshots.push({id:i,timestamp:new Date().toISOString(),message:i}),c.current=c.snapshots.length-1,await Te.writeFile(a,JSON.stringify(c,null,2)),await yt.log(s,"undo_performed",{snapshotId:i,timestamp:B.getTimestamp()}),h.done("changes stashed (use /p:redo to restore)"),{success:!0,snapshotId:i}}catch(r){return h.failWithHint("GIT_OPERATION_FAILED"),{success:!1,error:y(r)}}}catch(e){return h.fail(y(e)),{success:!1,error:y(e)}}}l(Mu,"undo");async function Ou(s=process.cwd()){try{h.spin("restoring changes...");let e=await M.getProjectId(s);if(!e)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=Bs.join(A.getGlobalProjectPath(e),"snapshots"),n=Bs.join(t,"history.json"),r;try{let i=await Te.readFile(n);r=JSON.parse(i)}catch(i){if(C(i)||i instanceof SyntaxError)return h.warn("no undo history found"),{success:!1,message:"No undo history found"};throw i}if(r.snapshots.length===0)return h.warn("nothing to redo"),{success:!1,message:"Nothing to redo"};let{execSync:o}=await import("node:child_process");try{let i=o("git stash list",{cwd:s,encoding:"utf-8"}).trim();return i?i.split(`
|
|
1406
|
+
`).find(c=>c.includes("prjct-undo-"))?(o("git stash pop",{cwd:s,encoding:"utf-8"}),r.snapshots.pop(),r.current=Math.max(0,r.current-1),await Te.writeFile(n,JSON.stringify(r,null,2)),await yt.log(s,"redo_performed",{timestamp:B.getTimestamp()}),h.done("changes restored"),{success:!0}):(h.warn("no prjct undo point found"),{success:!1,message:"No prjct undo point found"}):(h.warn("no stashed changes"),{success:!1,message:"No stashed changes found"})}catch(i){return h.failWithHint("GIT_OPERATION_FAILED"),{success:!1,error:y(i)}}}catch(e){return h.fail(y(e)),{success:!1,error:y(e)}}}l(Ou,"redo");async function Fu(s=process.cwd()){try{let e=await M.getProjectId(s);if(!e)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let t=Bs.join(A.getGlobalProjectPath(e),"snapshots"),n=Bs.join(t,"history.json"),r;try{let o=await Te.readFile(n);r=JSON.parse(o)}catch(o){if(C(o)||o instanceof SyntaxError)return console.log(`
|
|
1407
1407
|
SNAPSHOT HISTORY
|
|
1408
1408
|
`),console.log("=".repeat(50)),console.log(" No snapshots yet."),console.log(` Use /p:undo to create a snapshot.
|
|
1409
1409
|
`),{success:!0,snapshots:[]};throw o}return console.log(`
|
|
1410
1410
|
SNAPSHOT HISTORY
|
|
1411
|
-
`),console.log("=".repeat(50)),
|
|
1412
|
-
`)):(
|
|
1411
|
+
`),console.log("=".repeat(50)),r.snapshots.length===0?(console.log(" No snapshots yet."),console.log(` Use /p:undo to create a snapshot.
|
|
1412
|
+
`)):(r.snapshots.forEach((o,i)=>{let a=i===r.current?">":" ",c=new Date(o.timestamp).toLocaleString();console.log(` ${a} ${i+1}. ${c}`)}),console.log(""),console.log(` ${r.snapshots.length} snapshot(s) available`),console.log(` Use /p:redo to restore the latest
|
|
1413
1413
|
`)),console.log(`${"=".repeat(50)}
|
|
1414
|
-
`),{success:!0,snapshots:
|
|
1414
|
+
`),{success:!0,snapshots:r.snapshots,current:r.current}}catch(e){return h.fail(y(e)),{success:!1,error:y(e)}}}l(Fu,"history");var Js=class extends Ce{static{l(this,"MaintenanceCommands")}_cleanupMemory=Qi;_cleanupMemoryInternal=Zi;async cleanup(e={},t=process.cwd()){let n=await this.ensureProjectInit(t);return n.success?ju(e,t):n}async design(e=null,t={},n=process.cwd()){let r=await this.ensureProjectInit(n);return r.success?Iu(e,t,n):r}async recover(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?$u(e):t}async undo(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Mu(e):t}async redo(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Ou(e):t}async history(e=process.cwd()){let t=await this.ensureProjectInit(e);return t.success?Fu(e):t}async enrich(e=null,t=process.cwd(),n={}){let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=e?.trim();if(!o)return{success:!1,error:"Missing issue ID or description",message:'Usage: prjct enrich "<issue-id-or-description>" --md'};let i=o.match(/\b[A-Z]+-\d+\b/)?.[0]||null,a=await Ns(o,t,{maxFiles:10,minScore:.1,includeTests:!0}),c={success:!0,mode:"mcp",issueId:i,query:o,files:a.files.map(u=>({path:u.path,score:Number(u.score.toFixed(3)),reasons:u.reasons})),publish:{linear:"Use your AI client Linear MCP tools to update description/comment.",jira:"Use your AI client Jira MCP tools to update description/comment."}};if(n.json)return console.log(JSON.stringify(c,null,2)),{success:!0};if(n.md){let u=[];if(u.push("## Enrichment Context"),u.push(""),u.push(`- Query: ${o}`),i&&u.push(`- Issue ID: ${i}`),u.push(`- Candidate files: ${c.files.length}`),u.push(""),u.push("### Suggested Files"),u.push(""),c.files.length===0)u.push("- No relevant files found.");else for(let d of c.files)u.push(`- \`${d.path}\` (${d.score})`);return u.push(""),u.push("### Publish"),u.push(""),u.push("- Update description via MCP"),u.push("- Add enrichment as comment via MCP"),u.push("- Or keep local only"),console.log(u.join(`
|
|
1415
|
+
`)),{success:!0}}return{success:!0,message:`Prepared enrichment context (${c.files.length} files).`}}};import Me from"chalk";oe();var _u=class{static{l(this,"PerformanceTracker")}marks=new Map;markStart(e){this.marks.set(e,process.hrtime.bigint())}markEnd(e){let t=this.marks.get(e);if(t===void 0)return null;let n=process.hrtime.bigint();return this.marks.delete(e),Number(n-t)/1e6}recordTiming(e,t,n,r){G.appendEvent(e,`perf.${t}`,{metric:t,value:Math.round(n*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 n=this.snapshotMemory(),r=[{metric:"heap_used",value:n.heapUsed,unit:"bytes"},{metric:"heap_total",value:n.heapTotal,unit:"bytes"},{metric:"rss",value:n.rss,unit:"bytes"},{metric:"external_memory",value:n.external,unit:"bytes"}];for(let o of r)G.appendEvent(e,`perf.${o.metric}`,{metric:o.metric,value:o.value,unit:o.unit,context:t});return n}recordContextCorrectness(e,t){G.appendEvent(e,"perf.context_correctness",{metric:"context_correctness",...t})}recordSubtaskHandoff(e,t){G.appendEvent(e,"perf.subtask_handoff",{metric:"subtask_handoff",...t})}getMetrics(e,t){t||(t=new Date,t.setDate(t.getDate()-7));let n=t.toISOString();return G.query(e,"SELECT data, timestamp FROM events WHERE type LIKE ? AND timestamp >= ? ORDER BY id DESC","perf.%",n).map(o=>({...JSON.parse(o.data),timestamp:o.timestamp}))}getReport(e,t=7){let n=new Date;n.setDate(n.getDate()-t),n.setHours(0,0,0,0);let r=this.getMetrics(e,n),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,f)=>g+f,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(S=>Math.round(S/1048576*10)/10,"toMB"),g=a.map(S=>S.value),f=c.map(S=>S.value);o.memory={avgHeapMB:p(g.reduce((S,w)=>S+w,0)/g.length),peakHeapMB:p(Math.max(...g)),avgRssMB:f.length>0?p(f.reduce((S,w)=>S+w,0)/f.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 f=g.context?.command||"unknown";p[f]||(p[f]=[]),p[f].push(g.value)}o.commandDurations={};for(let[g,f]of Object.entries(p))o.commandDurations[g]={avg:Math.round(f.reduce((S,w)=>S+w,0)/f.length),min:Math.min(...f),max:Math.max(...f),count:f.length,unit:"ms"}}return o}},iT=new _u,Uh=iT;L();lt();var In={startup:{max:500,unit:"ms"},heapMB:{max:80,unit:"MB"},contextRate:{min:100,unit:"%"},handoffRate:{min:100,unit:"%"}};function na(s,e,t){return t==="below"?s<=e?Me.green("\u2713"):Me.yellow("\u26A0"):s>=e?Me.green("\u2713"):Me.yellow("\u26A0")}l(na,"statusIcon");var qs=class extends Ce{static{l(this,"PerformanceCommands")}async perf(e="7",t=process.cwd()){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let r=await M.getProjectId(t);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=parseInt(e,10)||7,i=await Uh.getReport(r,o);if(!(i.startup||i.memory||i.contextCorrectness||i.subtaskHandoff||i.commandDurations))return console.log(`
|
|
1415
1416
|
${Me.dim("No performance data yet.")}`),console.log(`${Me.dim("Metrics are collected automatically as you use the CLI.")}
|
|
1416
1417
|
`),{success:!0,message:"No data"};if(console.log(`
|
|
1417
|
-
${Me.cyan("Performance Report")} ${Me.dim(`(last ${o} days)`)}`),console.log("\u2550".repeat(55)),i.startup){let c=
|
|
1418
|
-
${Me.dim("Command Durations:")}`);for(let[c,u]of Object.entries(i.commandDurations))console.log(` ${c.padEnd(12)} avg ${Me.bold(`${u.avg}ms`)} ${Me.dim(`(min ${u.min}, max ${u.max}, n=${u.count})`)}`)}return console.log("\u2550".repeat(55)),console.log(""),{success:!0}}catch(n){return h.fail(
|
|
1419
|
-
`),!
|
|
1418
|
+
${Me.cyan("Performance Report")} ${Me.dim(`(last ${o} days)`)}`),console.log("\u2550".repeat(55)),i.startup){let c=na(i.startup.avg,In.startup.max,"below");console.log(` Startup: avg ${Me.bold(`${i.startup.avg}ms`)} ${Me.dim(`(min ${i.startup.min}, max ${i.startup.max}, n=${i.startup.count})`)} ${c} ${Me.dim(`target: <${In.startup.max}ms`)}`)}if(i.memory){let c=na(i.memory.peakHeapMB,In.heapMB.max,"below");console.log(` Memory: avg ${Me.bold(`${i.memory.avgHeapMB}MB`)} heap, peak ${i.memory.peakHeapMB}MB, rss ${i.memory.avgRssMB}MB ${c} ${Me.dim(`target: <${In.heapMB.max}MB`)}`)}if(i.contextCorrectness){let c=na(i.contextCorrectness.rate,In.contextRate.min,"above");console.log(` Context: ${Me.bold(`${i.contextCorrectness.rate}%`)} tasks received sync ${Me.dim(`(${i.contextCorrectness.receivedSync}/${i.contextCorrectness.total})`)} ${c} ${Me.dim(`target: ${In.contextRate.min}%`)}`)}if(i.subtaskHandoff){let c=na(i.subtaskHandoff.rate,In.handoffRate.min,"above");console.log(` Handoff: ${Me.bold(`${i.subtaskHandoff.rate}%`)} subtasks with output ${Me.dim(`(${i.subtaskHandoff.outputPopulated}/${i.subtaskHandoff.total})`)} ${c} ${Me.dim(`target: ${In.handoffRate.min}%`)}`)}if(i.commandDurations&&Object.keys(i.commandDurations).length>0){console.log(`
|
|
1419
|
+
${Me.dim("Command Durations:")}`);for(let[c,u]of Object.entries(i.commandDurations))console.log(` ${c.padEnd(12)} avg ${Me.bold(`${u.avg}ms`)} ${Me.dim(`(min ${u.min}, max ${u.max}, n=${u.count})`)}`)}return console.log("\u2550".repeat(55)),console.log(""),{success:!0}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}};Ri();on();ve();xs();L();We();import Gu from"node:fs/promises";import cT from"node:path";import pe from"chalk";L();import Nu from"node:fs/promises";import Hh from"node:os";import Lu from"node:path";var Uu={linear:{command:"npx",args:["-y","mcp-remote","https://mcp.linear.app/mcp"],description:"Linear MCP server (OAuth)"},jira:{command:"npx",args:["-y","mcp-remote","https://mcp.atlassian.com/v1/mcp"],description:"Atlassian MCP server for Jira (OAuth)"}};function mn(){return process.env.PRJCT_TEST_MODE==="1"?Lu.join(Hh.tmpdir(),"prjct-context7-test","mcp.json"):Lu.join(Hh.homedir(),".claude","mcp.json")}l(mn,"getClaudeMcpConfigPath");async function Gh(s=mn()){try{let e=await Nu.readFile(s,"utf-8");return JSON.parse(e)}catch(e){let t=y(e).toLowerCase();if(t.includes("no such file")||t.includes("enoent"))return{};throw new Error(`Failed to read MCP config at ${s}: ${y(e)}`)}}l(Gh,"readMcpConfig");async function aT(s,e=mn()){await Nu.mkdir(Lu.dirname(e),{recursive:!0}),await Nu.writeFile(e,JSON.stringify(s,null,2),"utf-8")}l(aT,"writeMcpConfig");async function Hu(s,e,t=mn()){let n=await Gh(t),r={...n.mcpServers||{}},o=r[s];r[s]=e,n.mcpServers=r;let i=JSON.stringify(o)!==JSON.stringify(e);return await aT(n,t),{path:t,changed:i}}l(Hu,"upsertMcpServer");async function Qr(s,e=mn()){return!!(await Gh(e)).mcpServers?.[s]}l(Qr,"hasMcpServer");Dt();lt();var Ks=class extends Ce{static{l(this,"SetupCommands")}async start(){let e=await je.checkInstallation(),t=(qe(),ht(pt)),n=await t.detectCodex(),r=e.providerDetected,o=r?await t.getActiveProvider():null,i=r?o.displayName:"OpenAI Codex";if(console.log(`\u{1F680} Setting up prjct for ${i}...
|
|
1420
|
+
`),!r&&!n.installed)return{success:!1,message:`\u274C No supported AI provider detected.
|
|
1420
1421
|
|
|
1421
1422
|
Please install one first:
|
|
1422
1423
|
- Claude Code: https://docs.anthropic.com/claude-code
|
|
1423
1424
|
- Gemini CLI: https://geminicli.com/docs
|
|
1424
|
-
- OpenAI Codex: https://github.com/openai/codex`};if(
|
|
1425
|
+
- OpenAI Codex: https://github.com/openai/codex`};if(r){console.log("\u{1F4E6} Installing /p:* commands...");let a=await je.installCommands();if(!a.success)return{success:!1,message:`\u274C Installation failed: ${a.error}`};if(console.log(`
|
|
1425
1426
|
\u2705 Installed ${a.installed?.length??0} commands to:
|
|
1426
1427
|
${A.getDisplayPath(a.path||"")}`),(a.errors?.length??0)>0){console.log(`
|
|
1427
|
-
\u26A0\uFE0F ${a.errors?.length??0} errors:`);for(let c of a.errors??[])console.log(` - ${c.file}: ${c.error}`)}}if(n.installed){let{installCodexSkill:a,verifyCodexPRouterReady:c}=await Promise.resolve().then(()=>(
|
|
1428
|
-
|
|
1429
|
-
${u.message||"router verification failed"}
|
|
1430
|
-
|
|
1431
|
-
Fix:
|
|
1432
|
-
1. Run: prjct setup
|
|
1433
|
-
2. Re-run: prjct start`};console.log("\u2705 Installed Codex skill: ~/.codex/skills/prjct/SKILL.md"),console.log("\u2705 Codex p. router ready")}try{await pn.ensureReady(),console.log("\u2705 Context7 MCP ready")}catch(a){return{success:!1,message:`\u274C Context7 MCP is required but not ready.
|
|
1434
|
-
|
|
1435
|
-
${w(a)}
|
|
1436
|
-
|
|
1437
|
-
Fix:
|
|
1438
|
-
1. Ensure Node+npx is installed
|
|
1439
|
-
2. Re-run: prjct start`}}return console.log(`
|
|
1428
|
+
\u26A0\uFE0F ${a.errors?.length??0} errors:`);for(let c of a.errors??[])console.log(` - ${c.file}: ${c.error}`)}}if(n.installed)try{let{installCodexSkill:a,verifyCodexPRouterReady:c}=await Promise.resolve().then(()=>(Ni(),tu));await a();let u=await c({autoRepair:!0});u.verified?(console.log("\u2705 Installed Codex skill: ~/.codex/skills/prjct/SKILL.md"),console.log("\u2705 Codex p. router ready")):(console.log(`\u26A0\uFE0F Codex skill setup incomplete: ${u.message||"router verification failed"}`),console.log(" Run `prjct setup` to retry Codex configuration."))}catch(a){console.log(`\u26A0\uFE0F Codex skill setup failed (non-blocking): ${y(a)}`)}return await this.setupMcpServers(),console.log(`
|
|
1440
1429
|
\u{1F389} Setup complete!`),console.log(`
|
|
1441
1430
|
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...
|
|
1442
1431
|
`),e.force&&(console.log("\u{1F5D1}\uFE0F Removing existing installation..."),await je.uninstallCommands()),console.log("\u{1F4E6} Installing /p:* commands...");let t=await je.installCommands();if(!t.success)return{success:!1,message:`\u274C Setup failed: ${t.error}`};if(console.log(`
|
|
1443
1432
|
\u2705 Installed ${t.installed?.length??0} commands`),(t.errors?.length??0)>0){console.log(`
|
|
1444
1433
|
\u26A0\uFE0F ${t.errors?.length??0} errors:`);for(let c of t.errors??[])console.log(` - ${c.file}: ${c.error}`)}console.log(`
|
|
1445
|
-
\u{1F4DD} Installing global configuration...`);let n=await je.installGlobalConfig(),
|
|
1446
|
-
\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){let{installCodexSkill:c,verifyCodexPRouterReady:u}=await Promise.resolve().then(()=>(
|
|
1447
|
-
|
|
1448
|
-
${d.message||"router verification failed"}
|
|
1449
|
-
|
|
1450
|
-
Fix:
|
|
1451
|
-
1. Run: prjct start
|
|
1452
|
-
2. Re-run: prjct setup`};console.log("\u2705 Codex skill installed"),console.log("\u2705 Codex p. router ready")}try{await pn.ensureReady(),console.log("\u2705 Context7 MCP ready")}catch(c){return{success:!1,message:`\u274C Context7 MCP is required but not ready.
|
|
1453
|
-
|
|
1454
|
-
${w(c)}
|
|
1455
|
-
|
|
1456
|
-
Fix:
|
|
1457
|
-
1. Ensure Node+npx is installed
|
|
1458
|
-
2. Re-run: prjct setup`}}return console.log(`
|
|
1434
|
+
\u{1F4DD} Installing global configuration...`);let n=await je.installGlobalConfig(),r=n.path?A.getDisplayPath(n.path):"global config";n.success?n.action==="created"?console.log(`\u2705 Created ${r}`):n.action==="updated"?console.log(`\u2705 Updated ${r}`):n.action==="appended"&&console.log(`\u2705 Added prjct config to ${r}`):console.log(`\u26A0\uFE0F ${n.error}`);let o=(qe(),ht(pt)),i=await o.getActiveProvider(),a=await o.detectCodex();if(i.name==="claude"){console.log(`
|
|
1435
|
+
\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(()=>(Ni(),tu));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): ${y(c)}`)}return await this.setupMcpServers(),console.log(`
|
|
1459
1436
|
\u{1F389} Setup complete!
|
|
1460
|
-
`),this.showAsciiArt(),{success:!0,message:""}}async
|
|
1437
|
+
`),this.showAsciiArt(),{success:!0,message:""}}async setupMcpServers(){console.log(`
|
|
1438
|
+
\u{1F50C} Configuring MCP servers...`);try{await an.install();let e=await an.verify();e.verified?console.log("\u2705 Context7 MCP ready (framework API lookups)"):(console.log(`\u26A0\uFE0F Context7 configured but not yet verified: ${e.message||""}`),console.log(" It will activate on the next time you open your AI client."))}catch(e){console.log(`\u26A0\uFE0F Context7 MCP setup failed: ${y(e)}`),console.log(" Run `prjct start` again to retry.")}try{let e=mn();await Qr("linear",e)?console.log("\u2705 Linear MCP already configured"):(await Hu("linear",Uu.linear),console.log("\u2705 Linear MCP added to mcp.json"),console.log(" \u2192 Open your AI client and run any Linear command to complete OAuth."))}catch(e){console.log(`\u26A0\uFE0F Linear MCP setup failed: ${y(e)}`),console.log(" Run `prjct linear setup` to configure manually.")}try{let e=mn();await Qr("jira",e)?console.log("\u2705 Jira MCP already configured"):(await Hu("jira",Uu.jira),console.log("\u2705 Jira MCP added to mcp.json"),console.log(" \u2192 Open your AI client and run any Jira command to complete OAuth."))}catch(e){console.log(`\u26A0\uFE0F Jira MCP setup failed: ${y(e)}`),console.log(" Run `prjct jira setup` to configure manually.")}}async installStatusLine(){try{let e=A.getClaudeDir(),t=A.getClaudeSettingsPath(),n=cT.join(e,"prjct-statusline.sh"),r=`#!/bin/bash
|
|
1461
1439
|
# prjct Status Line for Claude Code
|
|
1462
1440
|
# Shows version update notifications and current task
|
|
1463
1441
|
|
|
@@ -1513,25 +1491,25 @@ fi
|
|
|
1513
1491
|
|
|
1514
1492
|
# Default: show prjct branding
|
|
1515
1493
|
echo "\u26A1 prjct"
|
|
1516
|
-
`;await
|
|
1517
|
-
${
|
|
1518
|
-
${
|
|
1519
|
-
`,
|
|
1520
|
-
${
|
|
1521
|
-
${
|
|
1522
|
-
${
|
|
1494
|
+
`;await Gu.writeFile(n,r,{mode:493});let o={};if(await j(t))try{o=JSON.parse(await Gu.readFile(t,"utf8"))}catch{}return o.statusLine={type:"command",command:n},await Gu.writeFile(t,JSON.stringify(o,null,2)),{success:!0}}catch(e){return{success:!1,error:y(e)}}}showAsciiArt(){console.log(pe.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(pe.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(pe.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(pe.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(pe.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(pe.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(pe.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(` ${pe.bold.cyan("prjct")}${pe.magenta("/")}${pe.green("cli")} ${pe.dim.white(`v${De} installed`)}`),console.log(""),console.log(` ${pe.yellow("\u26A1")} Ship faster with zero friction`),console.log(` ${pe.green("\u{1F4DD}")} From idea to technical tasks in minutes`),console.log(` ${pe.cyan("\u{1F916}")} Perfect context for AI agents`),console.log(""),console.log(pe.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(pe.bold.cyan("\u{1F680} Quick Start")),console.log(pe.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(` ${pe.bold("1.")} Initialize your project:`),console.log(` ${pe.green("cd your-project && prjct init")}`),console.log(""),console.log(` ${pe.bold("2.")} Start your first task:`),console.log(` ${pe.green('prjct task "build auth"')}`),console.log(""),console.log(` ${pe.bold("3.")} Ship & celebrate:`),console.log(` ${pe.green('prjct ship "user login"')}`),console.log(""),console.log(pe.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(` ${pe.dim("Documentation:")} ${pe.cyan("https://prjct.app")}`),console.log(` ${pe.dim("Report issues:")} ${pe.cyan("https://github.com/jlopezlira/prjct-cli/issues")}`),console.log(""),console.log(pe.bold.magenta("Happy shipping! \u{1F680}")),console.log("")}};wr();ln();ku();Yt();L();$s();Ms();Or();L();import{exec as lT}from"node:child_process";import{promisify as uT}from"node:util";import At from"chalk";var Wu=uT(lT);async function Wt(s,e,t,n={}){let r={success:!0,gatesFailed:[],hooksFailed:[],stepsRun:[],instructions:[],output:""};if(n.skipRules)return r;let i=Ee.getRulesForCommand(s,e).filter(m=>m.position===t),a=i.filter(m=>m.type==="gate");for(let m of a){let p=m.description||m.action;console.log(`
|
|
1495
|
+
${At.dim(`[gate] ${t}-${e}: ${m.action}`)}`);try{let g=Date.now();await Wu(m.action,{timeout:m.timeoutMs,cwd:n.projectPath||process.cwd(),env:{...process.env}});let f=Date.now()-g,S=f>1e3?`${(f/1e3).toFixed(1)}s`:`${f}ms`;console.log(`${At.green("\u2713")} ${At.dim(`gate passed (${S})`)}`)}catch(g){return console.log(`${At.red("\u2717")} gate failed: ${p}`),r.gatesFailed.push(p),r.success=!1,r.output+=`Gate failed: ${p}
|
|
1496
|
+
${y(g)}
|
|
1497
|
+
`,r}}let c=i.filter(m=>m.type==="instruction");for(let m of c){let p=m.description||m.action;console.log(`
|
|
1498
|
+
${At.dim(`[instruction] ${t}-${e}: ${p}`)}`),r.instructions.push(m.action)}let u=i.filter(m=>m.type==="hook");for(let m of u){console.log(`
|
|
1499
|
+
${At.dim(`[hook] ${t}-${e}: ${m.action}`)}`);try{let p=Date.now();await Wu(m.action,{timeout:m.timeoutMs,cwd:n.projectPath||process.cwd(),env:{...process.env}});let g=Date.now()-p,f=g>1e3?`${(g/1e3).toFixed(1)}s`:`${g}ms`;console.log(`${At.green("\u2713")} ${At.dim(`(${f})`)}`)}catch(p){console.log(`${At.yellow("\u26A0")} hook failed (non-blocking): ${m.action}`),r.hooksFailed.push(m.description||m.action),r.output+=`Hook failed: ${m.action}
|
|
1500
|
+
${y(p)}
|
|
1523
1501
|
`}}let d=i.filter(m=>m.type==="step");for(let m of d){console.log(`
|
|
1524
|
-
${
|
|
1525
|
-
${
|
|
1526
|
-
`,
|
|
1502
|
+
${At.dim(`[step] ${e}: ${m.action}`)}`);try{let p=Date.now();await Wu(m.action,{timeout:m.timeoutMs,cwd:n.projectPath||process.cwd(),env:{...process.env}});let g=Date.now()-p,f=g>1e3?`${(g/1e3).toFixed(1)}s`:`${g}ms`;console.log(`${At.green("\u2713")} ${At.dim(`step passed (${f})`)}`),r.stepsRun.push(m.description||m.action)}catch(p){return console.log(`${At.red("\u2717")} step failed: ${m.action}`),r.gatesFailed.push(m.description||m.action),r.success=!1,r.output+=`Step failed: ${m.action}
|
|
1503
|
+
${y(p)}
|
|
1504
|
+
`,r}}return r}l(Wt,"executeWorkflowRules");lt();var Xs=class extends Ce{static{l(this,"ShippingCommands")}async ship(e,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e,a=await N.getCurrentTask(o);a&&(i||(i=a.description||"current work"),await N.completeTask(o)),i||(i="current work");let c=await Wt(o,"ship","before",{projectPath:t,skipRules:n.skipHooks});if(!c.success)return{success:!1,error:c.gatesFailed.length>0?`Blocked: ${c.gatesFailed.join(", ")}`:`Step failed: ${c.gatesFailed.join(", ")}`};n.md||h.step(1,4,"Bumping version...");let d=await new Xr(t).bump();n.md||h.step(2,4,"Updating changelog..."),await new Cr(t).addFeature(d,i),n.md||h.step(3,4,"Committing...");let p=await this._createShipCommit(i,t),g="skipped";if(p.success){let w=await this._gitPush(t);g=w.success?"pushed":w.message}await wt.addShipped(o,{name:i,version:d}),await this.logToMemory(t,"feature_shipped",{feature:i,version:d,timestamp:B.getTimestamp()}),await at.learnDecision(o,"commit_footer","prjct","ship"),await at.recordWorkflow(o,"ship_completed",{description:"Ship with workflow rules",feature:i,version:d});let f=await Wt(o,"ship","after",{projectPath:t,skipRules:n.skipHooks}),S=[...c.instructions,...f.instructions];try{n.md||h.step(4,4,"Updating AI context..."),await jn.sync(t),n.md||h.done("\u2713 AI context updated")}catch(w){console.warn("\u26A0\uFE0F Failed to sync AI context after shipping:",y(w))}if(n.md){let w=ai("ship"),v=U(Se(`Shipped: ${i}`,`Version: ${d}`),ee("Results",Ae([`Version: ${d}`,`Commit: ${p.success?"created":p.message}`,`Push: ${g}`,`Workflow steps: ${c.stepsRun.length>0?c.stepsRun.join(", "):"none"}`])),S.length>0?ee("Agent Instructions",Ae(S)):null,de(w.map(T=>({label:T.desc,command:T.cmd}))));console.log(v)}else h.done(`v${d} shipped`),Tt("ship");return{success:!0,feature:i,version:d}}catch(r){return h.fail(y(r)),{success:!1,error:y(r)}}}async _createShipCommit(e,t){try{await rt.get("Bash")("git add .");let n=`feat: ${e}
|
|
1527
1505
|
|
|
1528
|
-
Generated with [p/](https://www.prjct.app/)`;return await rt.get("Bash")(`git commit -m "${n.replace(/"/g,'\\"')}"`),{success:!0,message:"Committed"}}catch(n){return
|
|
1529
|
-
`)),{success:n,message:t?"Dry run complete":n?"System updated":"Updated with errors"}}async getAllProjectIds(){let e=
|
|
1506
|
+
Generated with [p/](https://www.prjct.app/)`;return await rt.get("Bash")(`git commit -m "${n.replace(/"/g,'\\"')}"`),{success:!0,message:"Committed"}}catch(n){return C(n)?{success:!1,message:"Git not found"}:{success:!1,message:"No changes to commit"}}}async _gitPush(e){try{return await rt.get("Bash")("git push"),{success:!0,message:"Pushed to remote"}}catch(t){return C(t)?{success:!1,message:"Git not found"}:{success:!1,message:"Push failed (no remote or auth issue)"}}}};on();Zl();ve();Gl();ii();L();Bn();Dt();lt();import{execSync as no}from"node:child_process";import hT from"node:fs/promises";import yT from"node:path";import to from"chalk";function qh(){try{return!!no("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})}catch{return!1}}l(qh,"isHomebrewInstall");function Kh(){try{let e=no("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).match(/prjct-cli@([\d.]+)/);return e?e[1]:null}catch{return null}}l(Kh,"getCurrentVersion");var Ys=class extends Ce{static{l(this,"UpdateCommands")}async update(e={},t=process.cwd()){let n=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||h.step(1,3,"Updating package..."),o.phase1=await this.phasePackageUpdate(n),r||h.stop(),r||h.step(2,3,"Cleaning up all projects..."),o.phase2=await this.phaseGlobalCleanup(n),r||h.stop(),r||h.step(3,3,"Restarting daemon..."),o.phase3=await this.phaseDaemonRestart(n),r||h.stop(),!n){try{await Oi.updateVersion(De)}catch{}try{await new Ai().writeCache({lastCheck:0,latestVersion:""})}catch{}}return r?this.formatMdOutput(o,n):this.formatTerminalOutput(o,n)}catch(i){return r||h.stop(),h.fail(y(i)),{success:!1,error:y(i)}}}async phasePackageUpdate(e){let t={success:!0,details:[],errors:[]},n=Kh();if(e)return qh()?(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(qh()){try{no("brew uninstall prjct-cli 2>/dev/null",{stdio:"pipe"}),t.details.push("Uninstalled homebrew formula")}catch{t.details.push("Homebrew uninstall skipped (not found)")}no("npm install -g prjct-cli",{stdio:"pipe"}),t.details.push("Installed via npm")}else no("npm update -g prjct-cli",{stdio:"pipe"}),t.details.push("npm update complete");let o=Kh();n&&o&&n!==o?t.details.push(`${n} \u2192 ${o}`):o&&t.details.push(`v${o} (already latest)`)}catch(r){t.success=!1,t.errors.push(y(r))}return t}async phaseGlobalCleanup(e){let t={success:!0,details:[],errors:[]},n=await this.getAllProjectIds();if(n.length===0)t.details.push("No projects found");else{let r=0,o=0;for(let i of n)if(!e)try{let a=await jr(i),c=await oi(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)}: ${y(a)}`)}if(e)t.details.push(`Would migrate ${n.length} project(s)`);else{let i=[`${n.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 reinstall editor commands"),t.details.push("Would reinstall global config");else{try{let o=await new bs().installCommands();t.details.push(`Editor commands reinstalled (${o.installed?.length||0} providers)`)}catch(r){t.errors.push(`Commands: ${y(r)}`)}try{await new bs().installGlobalConfig(),t.details.push("Global config reinstalled")}catch(r){t.errors.push(`Global config: ${y(r)}`)}}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:n,stopDaemon:r,forceKillDaemon:o,spawnDaemon:i}=await Promise.resolve().then(()=>(Jh(),Bh));await n()?(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.success=!1,t.errors.push("Failed to restart daemon"))}catch(n){t.success=!1,t.errors.push(y(n))}return t}formatTerminalOutput(e,t){let n=e.phase1.success&&e.phase2.success&&e.phase3.success,r=[...e.phase1.errors,...e.phase2.errors,...e.phase3.errors];console.log("");let o=[{label:"Package",result:e.phase1},{label:"Cleanup",result:e.phase2},{label:"Daemon",result:e.phase3}];for(let{label:i,result:a}of o){let c=a.success?to.green("\u2713"):to.red("\u2717");console.log(` ${c} ${to.bold(i)}`);for(let u of a.details)console.log(` ${to.dim(u)}`);for(let u of a.errors)console.log(` ${to.yellow("\u26A0")} ${u}`)}return console.log(""),t?h.done("Dry run complete \u2014 no changes made"):n?h.done("System updated"):h.warn(`Updated with ${r.length} error(s)`),{success:n,message:t?"Dry run complete":n?"System updated":"Updated with errors"}}formatMdOutput(e,t){let n=e.phase1.success&&e.phase2.success&&e.phase3.success,r=[];r.push(t?"# Update (Dry Run)":"# System Update"),r.push("");let o=[{label:"Package Update",result:e.phase1},{label:"Global Cleanup",result:e.phase2},{label:"Daemon Restart",result:e.phase3}];for(let{label:i,result:a}of o){let c=a.success?"\u2705":"\u274C";r.push(`## ${c} ${i}`);for(let u of a.details)r.push(`- ${u}`);for(let u of a.errors)r.push(`- \u26A0\uFE0F ${u}`);r.push("")}return t||r.push(n?"**Status:** All phases completed successfully.":"**Status:** Completed with errors."),console.log(r.join(`
|
|
1507
|
+
`)),{success:n,message:t?"Dry run complete":n?"System updated":"Updated with errors"}}async getAllProjectIds(){let e=yT.join(A.getGlobalBasePath(),"projects");try{return(await hT.readdir(e,{withFileTypes:!0})).filter(n=>n.isDirectory()&&!n.name.startsWith(".")).map(n=>n.name)}catch{return[]}}};yl();ys();Kc();L();Xn();lt();import Oe from"chalk";var Qs=class extends Ce{static{l(this,"VelocityCommands")}async velocity(e="0",t=process.cwd()){try{let n=await this.ensureProjectInit(t);if(!n.success)return n;let r=await M.getProjectId(t);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await this.loadVelocityConfig(t),i=await gt.getAll(r);if(i.length===0)return console.log(`
|
|
1530
1508
|
${Oe.dim("No velocity data yet.")}`),console.log(`${Oe.dim("Complete tasks with estimates to build velocity history.")}
|
|
1531
|
-
`),{success:!0,message:"No data"};let a=
|
|
1509
|
+
`),{success:!0,message:"No data"};let a=yi(i,o);await qc.saveMetrics(r,a),console.log(`
|
|
1532
1510
|
${Oe.cyan("Sprint Velocity")} ${Oe.dim(`(last ${o.windowSize??6} sprints)`)}`),console.log("\u2550".repeat(60));let c=a.sprints.slice(-(o.windowSize??6));for(let m of c){let p=m.estimationAccuracy>=80?Oe.green:m.estimationAccuracy>=60?Oe.yellow:Oe.red;console.log(` Sprint ${String(m.sprintNumber).padStart(2)}: ${Oe.bold(`${m.pointsCompleted} pts`)} | ${m.tasksCompleted} tasks | accuracy: ${p(`${m.estimationAccuracy}%`)}`)}console.log("");let u=a.velocityTrend==="improving"?Oe.green("\u2191"):a.velocityTrend==="declining"?Oe.red("\u2193"):Oe.dim("\u2192");if(console.log(` Average: ${Oe.bold(`${a.averageVelocity} pts/sprint`)} | Trend: ${u} ${a.velocityTrend}`),console.log(` Estimation accuracy: ${Oe.bold(`${a.estimationAccuracy}%`)} ${Oe.dim(`(\xB1${o.accuracyTolerance??20}% tolerance)`)}`),a.underEstimated.length>0||a.overEstimated.length>0){console.log(`
|
|
1533
|
-
${Oe.dim("Patterns:")}`);for(let m of a.underEstimated)console.log(` ${Oe.yellow("\u26A0")} ${m.category} tasks underestimated by avg ${Oe.bold(`${m.avgVariance}%`)}`);for(let m of a.overEstimated)console.log(` ${Oe.green("\u2713")} ${m.category} tasks estimated within ${Oe.bold(`${m.avgVariance}%`)}`)}let d=parseInt(e,10);if(d>0&&a.averageVelocity>0){let m=
|
|
1534
|
-
${Oe.dim("Projection:")}`),console.log(` Backlog: ${Oe.bold(`${d} pts`)} remaining`),console.log(` At current velocity: ~${m.sprints} sprints (${m.sprints*(o.sprintLengthDays??7)} days)`),console.log(` Estimated completion: ${Oe.bold(p)}`)}return console.log("\u2550".repeat(60)),console.log(""),{success:!0}}catch(n){return h.fail(
|
|
1511
|
+
${Oe.dim("Patterns:")}`);for(let m of a.underEstimated)console.log(` ${Oe.yellow("\u26A0")} ${m.category} tasks underestimated by avg ${Oe.bold(`${m.avgVariance}%`)}`);for(let m of a.overEstimated)console.log(` ${Oe.green("\u2713")} ${m.category} tasks estimated within ${Oe.bold(`${m.avgVariance}%`)}`)}let d=parseInt(e,10);if(d>0&&a.averageVelocity>0){let m=Gm(d,a.averageVelocity,o),p=m.estimatedDate?new Date(m.estimatedDate).toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}):"unknown";console.log(`
|
|
1512
|
+
${Oe.dim("Projection:")}`),console.log(` Backlog: ${Oe.bold(`${d} pts`)} remaining`),console.log(` At current velocity: ~${m.sprints} sprints (${m.sprints*(o.sprintLengthDays??7)} days)`),console.log(` Estimated completion: ${Oe.bold(p)}`)}return console.log("\u2550".repeat(60)),console.log(""),{success:!0}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}async loadVelocityConfig(e){try{let n=await M.readConfig(e);if(n?.velocity&&typeof n.velocity=="object")return{...bn,...n.velocity}}catch{}return bn}};Ll();Ml();bu();ve();import vT from"node:fs/promises";import PT from"node:path";L();import ra from"node:fs/promises";import wT from"node:os";import oa from"node:path";var Vu=class{static{l(this,"TemplateGenerator")}commandsPath;constructor(){this.commandsPath=oa.join(wT.homedir(),".claude","commands","p")}async generateWorkflowTemplate(e,t){try{await ra.mkdir(this.commandsPath,{recursive:!0});let n=oa.join(this.commandsPath,`${e}.md`),r=this.buildTemplateContent(e,t);return await ra.writeFile(n,r,"utf-8"),{success:!0,path:n}}catch(n){return{success:!1,error:y(n)}}}async deleteWorkflowTemplate(e){try{let t=oa.join(this.commandsPath,`${e}.md`);return await ra.unlink(t),{success:!0}}catch(t){return C(t)?{success:!0}:{success:!1,error:y(t)}}}async templateExists(e){try{let t=oa.join(this.commandsPath,`${e}.md`);return await ra.access(t),!0}catch{return!1}}buildTemplateContent(e,t){return`---
|
|
1535
1513
|
allowed-tools: [Bash, Read, Write, Edit, Glob, Grep, Task, AskUserQuestion]
|
|
1536
1514
|
---
|
|
1537
1515
|
|
|
@@ -1567,37 +1545,37 @@ Suggest relevant actions based on the workflow results:
|
|
|
1567
1545
|
- View rules: \`prjct workflow ${e} --md\`
|
|
1568
1546
|
- Add rules: \`prjct workflow add "command" before ${e} --md\`
|
|
1569
1547
|
- Run again: \`p. ${e}\`
|
|
1570
|
-
`}},Zu=new Qu;ai();var da=300*1e3,ot=new zt({ttl:da,maxSize:100}),qt=new zt({ttl:da,maxSize:10}),tr=new zt({ttl:da,maxSize:5}),nr=new zt({ttl:da,maxSize:5});function ed(){ot.clear(),qt.clear(),tr.clear(),nr.clear()}l(ed,"clearLinearCache");function td(){return{issues:ot.stats(),assignedIssues:qt.stats(),teams:tr.stats(),projects:nr.stats()}}l(td,"getLinearCacheStats");F();nd();var MT={backlog:"backlog",unstarted:"todo",started:"in_progress",completed:"done",canceled:"cancelled",cancelled:"cancelled"},OT={0:"none",1:"urgent",2:"high",3:"medium",4:"low"},iy={none:0,urgent:1,high:2,medium:3,low:4},ma=class{static{l(this,"LinearProvider")}name="linear";displayName="Linear";sdk=null;config=null;isConfigured(){return this.sdk!==null&&this.config?.enabled===!0}async initialize(e){this.config=e;let t=e.apiKey||await pa("linear-api-key");if(!t)throw new Error("LINEAR_API_KEY not configured. Run `p. linear setup` to configure.");let{LinearClient:n}=await import("@linear/sdk");this.sdk=new n({apiKey:t});try{await this.sdk.viewer}catch(s){throw this.sdk=null,new Error(`Linear connection failed: ${w(s)}`)}}async fetchAssignedIssues(e){if(!this.sdk)throw new Error("Linear not initialized");let t=await this.sdk.viewer,n={};e?.includeCompleted||(n.state={type:{nin:["completed","canceled"]}}),this.config?.defaultTeamId&&(n.team={id:{eq:this.config.defaultTeamId}});let s=await t.assignedIssues({first:e?.limit||50,filter:Object.keys(n).length>0?n:void 0});return Promise.all(s.nodes.map(o=>this.mapIssue(o)))}async fetchTeamIssues(e,t){if(!this.sdk)throw new Error("Linear not initialized");let s=await(await this.sdk.team(e)).issues({first:t?.limit||50,filter:t?.includeCompleted?void 0:{state:{type:{nin:["completed","canceled"]}}}});return Promise.all(s.nodes.map(o=>this.mapIssue(o)))}async fetchIssue(e){if(!this.sdk)throw new Error("Linear not initialized");try{if(e.includes("-")&&/^[A-Z]+-\d+$/.test(e)){let n=e.match(/^([A-Z]+)-(\d+)$/);if(!n)return null;let[,s,o]=n,i=parseInt(o,10),c=(await this.sdk.teams({first:50})).nodes.find(d=>d.key===s);if(!c)return null;let u=await c.issues({first:1,filter:{number:{eq:i}}});return u.nodes.length>0?this.mapIssue(u.nodes[0]):null}let t=await this.sdk.issue(e);return this.mapIssue(t)}catch{return null}}async createIssue(e){if(!this.sdk)throw new Error("Linear not initialized");let t=e.teamId||this.config?.defaultTeamId;if(!t)throw new Error("Team ID required for creating issues");let s=await(await this.sdk.createIssue({teamId:t,title:e.title,description:e.description,priority:e.priority?iy[e.priority]:void 0,projectId:e.projectId||this.config?.defaultProjectId,assigneeId:e.assigneeId,labelIds:e.labels?await this.resolveLabelIds(t,e.labels):void 0})).issue;if(!s)throw new Error("Failed to create issue");return this.mapIssue(s)}async updateIssue(e,t){if(!this.sdk)throw new Error("Linear not initialized");let n=await this.fetchIssue(e);if(!n)throw new Error(`Issue ${e} not found`);let s={};t.title!==void 0&&(s.title=t.title),t.description!==void 0&&(s.description=t.description),t.priority!==void 0&&(s.priority=iy[t.priority]),t.assigneeId!==void 0&&(s.assigneeId=t.assigneeId),t.stateId!==void 0&&(s.stateId=t.stateId),t.projectId!==void 0&&(s.projectId=t.projectId),t.labels!==void 0&&n.team&&(s.labelIds=await this.resolveLabelIds(n.team.id,t.labels)),await this.sdk.updateIssue(n.id,s);let o=await this.fetchIssue(n.id);if(!o)throw new Error("Failed to fetch updated issue");return o}async markInProgress(e){if(!this.sdk)throw new Error("Linear not initialized");let t=await this.fetchIssue(e);if(!t)throw new Error(`Issue ${e} not found`);let s=await(await this.sdk.issue(t.id)).team;if(!s)throw new Error("Issue has no team");let i=(await s.states()).nodes.find(a=>a.type==="started");i&&await this.sdk.updateIssue(t.id,{stateId:i.id})}async markDone(e){if(!this.sdk)throw new Error("Linear not initialized");let t=await this.fetchIssue(e);if(!t)throw new Error(`Issue ${e} not found`);let s=await(await this.sdk.issue(t.id)).team;if(!s)throw new Error("Issue has no team");let i=(await s.states()).nodes.find(a=>a.type==="completed");i&&await this.sdk.updateIssue(t.id,{stateId:i.id})}async addComment(e,t){if(!this.sdk)throw new Error("Linear not initialized");let n=await this.fetchIssue(e);if(!n)throw new Error(`Issue ${e} not found`);await this.sdk.createComment({issueId:n.id,body:t})}async getTeams(){if(!this.sdk)throw new Error("Linear not initialized");return(await this.sdk.teams({first:50})).nodes.map(t=>({id:t.id,name:t.name,key:t.key}))}async getProjects(){if(!this.sdk)throw new Error("Linear not initialized");return(await this.sdk.projects({first:50})).nodes.map(t=>({id:t.id,name:t.name}))}async mapIssue(e){let t=await e.state,n=await e.assignee,s=await e.team,o=await e.project,i=await e.labels();return{id:e.id,externalId:e.identifier,provider:"linear",title:e.title,description:e.description||void 0,status:MT[t?.type||"backlog"]||"backlog",priority:OT[e.priority]||"none",type:this.inferType(e.title,i.nodes.map(a=>a.name)),assignee:n?{id:n.id,name:n.name,email:n.email}:void 0,labels:i.nodes.map(a=>a.name),team:s?{id:s.id,name:s.name,key:s.key}:void 0,project:o?{id:o.id,name:o.name}:void 0,url:e.url,createdAt:e.createdAt.toISOString(),updatedAt:e.updatedAt.toISOString(),raw:e}}inferType(e,t){let n=e.toLowerCase(),s=t.map(o=>o.toLowerCase());return s.includes("bug")||n.includes("fix")||n.includes("bug")?"bug":s.includes("feature")||n.includes("add")||n.includes("implement")?"feature":s.includes("improvement")||n.includes("improve")||n.includes("enhance")?"improvement":s.includes("chore")||n.includes("chore")||n.includes("deps")?"chore":"task"}async resolveLabelIds(e,t){return this.sdk?(await(await this.sdk.team(e)).labels()).nodes.filter(o=>t.includes(o.name)).map(o=>o.id):[]}},vt=new ma;var ga=class{static{l(this,"LinearService")}initialized=!1;userId=null;isReady(){return this.initialized&&vt.isConfigured()}async initialize(e){this.initialized||(await vt.initialize(e),this.initialized=!0)}async initializeFromApiKey(e,t){let n={enabled:!0,provider:"linear",apiKey:e,defaultTeamId:t,syncOn:{task:!0,done:!0,ship:!0},enrichment:{enabled:!0,updateProvider:!0}};await this.initialize(n)}async fetchAssignedIssues(e){this.ensureInitialized();let t=`assigned:${this.userId||"me"}`,n=qt.get(t);if(n)return n;let s=await vt.fetchAssignedIssues(e);qt.set(t,s);for(let o of s)ot.set(`issue:${o.id}`,o),ot.set(`issue:${o.externalId}`,o);return s}async fetchTeamIssues(e,t){this.ensureInitialized();let n=`team:${e}`,s=qt.get(n);if(s)return s;let o=await vt.fetchTeamIssues(e,t);qt.set(n,o);for(let i of o)ot.set(`issue:${i.id}`,i),ot.set(`issue:${i.externalId}`,i);return o}async fetchIssue(e){this.ensureInitialized();let t=`issue:${e}`,n=ot.get(t);if(n)return n;let s=await vt.fetchIssue(e);return s&&(ot.set(`issue:${s.id}`,s),ot.set(`issue:${s.externalId}`,s)),s}async createIssue(e){this.ensureInitialized();let t=await vt.createIssue(e);return ot.set(`issue:${t.id}`,t),ot.set(`issue:${t.externalId}`,t),qt.clear(),t}async updateIssue(e,t){this.ensureInitialized();let n=await vt.updateIssue(e,t);return ot.set(`issue:${n.id}`,n),ot.set(`issue:${n.externalId}`,n),n}async markInProgress(e){this.ensureInitialized(),await vt.markInProgress(e),ot.delete(`issue:${e}`),qt.clear()}async markDone(e){this.ensureInitialized(),await vt.markDone(e),ot.delete(`issue:${e}`),qt.clear()}async addComment(e,t){this.ensureInitialized(),await vt.addComment(e,t)}async getTeams(){this.ensureInitialized();let e=tr.get("teams");if(e)return e;let t=await vt.getTeams();return tr.set("teams",t),t}async getProjects(){this.ensureInitialized();let e=nr.get("projects");if(e)return e;let t=await vt.getProjects();return nr.set("projects",t),t}clearCache(){ed()}getCacheStats(){return td()}ensureInitialized(){if(!this.initialized)throw new Error("Linear service not initialized. Call linearService.initialize() first or run `p. linear setup`.")}},Ft=new ga;Ba();se();Ms();F();var _T=/\b[A-Z]+-\d+\b/,ay=1800*1e3,fa=class{static{l(this,"LinearSync")}async pullAll(e){let t=new Date().toISOString(),n=[];try{let s=await Ft.fetchAssignedIssues({limit:100}),o={};for(let a of s)try{o[a.externalId]=this.toCachedIssue(a,t)}catch(c){n.push({issueId:a.externalId||a.id,error:w(c)})}let i={provider:"linear",lastSync:t,staleAfter:ay,issues:o};return T.setDoc(e,"issues",i),{provider:"linear",fetched:s.length,updated:Object.keys(o).length,errors:n,timestamp:t}}catch(s){return n.push({issueId:"all",error:w(s)}),{provider:"linear",fetched:0,updated:0,errors:n,timestamp:t}}}async getIssue(e,t){let n=this.loadIssues(e);if(n?.issues[t]){let s=n.issues[t],o=new Date(s.fetchedAt).getTime(),i=Date.now(),a=600*1e3;if(i-o<a)return s}try{let s=await Ft.fetchIssue(t);if(!s)return null;let o=new Date().toISOString(),i=this.toCachedIssue(s,o);return this.updateIssueInCache(e,t,i),i}catch{return n?.issues[t]?n.issues[t]:null}}async getIssueLocal(e,t){return this.loadIssues(e)?.issues[t]||null}async pushStatus(e,t,n){n==="in_progress"?await Ft.markInProgress(t):n==="done"&&await Ft.markDone(t);let s=this.loadIssues(e);if(s?.issues[t]){let o=n==="done"?"done":"in_progress";s.issues[t].status=o,s.issues[t].fetchedAt=new Date().toISOString(),this.saveIssues(e,s)}}async isStale(e){let t=this.loadIssues(e);if(!t||!t.lastSync)return!0;let n=new Date(t.lastSync).getTime(),s=Date.now(),o=t.staleAfter||ay;return s-n>o}async getSyncStatus(e){let t=this.loadIssues(e);return t?{hasCache:!0,lastSync:t.lastSync||null,issueCount:Object.keys(t.issues).length,isStale:await this.isStale(e)}:{hasCache:!1,lastSync:null,issueCount:0,isStale:!0}}async listCachedIssues(e){let t=this.loadIssues(e);return t?Object.values(t.issues):[]}async reconcileQueue(e){let t=this.loadIssues(e);if(!t)return 0;let n=new Set;for(let[i,a]of Object.entries(t.issues))(a.status==="done"||a.status==="in_review")&&n.add(i);if(n.size===0)return 0;let s=await ke.getTasks(e),o=0;for(let i of s){if(i.completed)continue;let a=i.description.match(_T);a&&n.has(a[0])&&(await ke.completeTask(e,i.id),o++)}return o}loadIssues(e){try{return T.getDoc(e,"issues")}catch{return null}}saveIssues(e,t){T.setDoc(e,"issues",t)}updateIssueInCache(e,t,n){let s=this.loadIssues(e);s||(s=Gd("linear")),s.issues[t]=n,this.saveIssues(e,s)}toCachedIssue(e,t){return{id:e.id,identifier:e.externalId,title:e.title,description:e.description,status:e.status,priority:e.priority,type:e.type,assignee:e.assignee,labels:e.labels,team:e.team,project:e.project,url:e.url,createdAt:e.createdAt,updatedAt:e.updatedAt,fetchedAt:t}}},FT=new fa;Dt();As();Mu();Pe();se();ce();import{exec as NT}from"node:child_process";import{promisify as LT}from"node:util";var cy=LT(NT),sr="session-snapshot",UT=30,sd=class{static{l(this,"SessionSnapshotManager")}async capture(e,t,n){let s=await this.getGitBranch(t),o=await this.getModifiedFiles(t),i=n.startedAt?Math.round((Date.now()-new Date(n.startedAt).getTime())/1e3):void 0,a=t.split("/").pop()||t,c=this.generateResumeHint(n,i),u={sessionId:n.sessionId,projectId:e,projectPath:t,projectName:a,taskDescription:n.taskDescription,taskStatus:n.taskStatus,activeSubtaskIndex:n.activeSubtaskIndex,subtaskCount:n.subtaskCount,branch:s,linearId:n.linearId,filesModified:o,durationWorkedSec:i,timestamp:b(),resumeHint:c};return T.setDoc(e,sr,u),u}getSnapshot(e){try{return T.getDoc(e,sr)}catch{return null}}clearSnapshot(e){try{T.deleteDoc(e,sr)}catch{}}async listAllSnapshots(){let e=await A.listProjects(),t=[];for(let n of e)try{if(!T.exists(n))continue;let s=T.getDoc(n,sr);s&&t.push(s)}catch{}return t.sort((n,s)=>new Date(s.timestamp).getTime()-new Date(n.timestamp).getTime()),t}async cleanup(e=UT){let t=await A.listProjects(),n=Date.now()-e*24*60*60*1e3,s=0;for(let o of t)try{if(!T.exists(o))continue;let i=T.getDoc(o,sr);i&&new Date(i.timestamp).getTime()<n&&(T.deleteDoc(o,sr),s++)}catch{}return s}formatContinuityContext(e){let n=["Session Continuity",`- Last session: ${cn(Date.now()-new Date(e.timestamp).getTime())} ago`,`- Task: ${e.taskDescription}`,`- Status: ${e.taskStatus}`];if(e.subtaskCount&&e.activeSubtaskIndex!==void 0&&n.push(`- Progress: subtask ${e.activeSubtaskIndex+1}/${e.subtaskCount}`),e.branch&&n.push(`- Branch: ${e.branch}`),e.filesModified&&e.filesModified.length>0){let s=e.filesModified.slice(0,5).join(", "),o=e.filesModified.length>5?` (+${e.filesModified.length-5} more)`:"";n.push(`- Modified files: ${s}${o}`)}return e.durationWorkedSec&&n.push(`- Time worked: ${cn(e.durationWorkedSec*1e3)}`),n.push(`- Resume hint: ${e.resumeHint}`),n.join(`
|
|
1571
|
-
`)}generateResumeHint(e,t){let n=[];return e.taskStatus==="paused"?n.push("Task was paused"):n.push("Task was in progress"),e.subtaskCount&&e.activeSubtaskIndex!==void 0&&n.push(`on subtask ${e.activeSubtaskIndex+1} of ${e.subtaskCount}`),t&&t>60&&n.push(`after ${
|
|
1572
|
-
`).filter(n=>n.length>0).slice(0,20)}catch{return[]}}},Fn=new sd;nn();cl();Lr();Rl();F();_s();Fs();ml();F();Ue();nd();import HT from"node:fs/promises";import GT from"node:os";import zT from"node:path";function WT(r){return zT.join(GT.homedir(),".prjct-cli","projects",r,"config","credentials.json")}l(WT,"getCredentialsPath");async function ha(r){let e=WT(r);if(!await D(e))return{};try{return JSON.parse(await HT.readFile(e,"utf-8"))}catch(t){return console.error("[project-credentials] Failed to read credentials:",w(t)),{}}}l(ha,"getProjectCredentials");async function rd(r){let e=await ha(r);return e.linear?.apiKey?e.linear.apiKey:pa("linear-api-key")}l(rd,"getLinearApiKey");es();ut();var JT=[{type:"help",patterns:/^(?:help|ayuda|c[oó]mo|how)\b/i},{type:"add",patterns:/^add\b/i},{type:"gate",patterns:/^gate\b/i},{type:"instruction",patterns:/^instruction\b/i},{type:"remove",patterns:/^rm\b/i},{type:"reset",patterns:/^reset\b/i},{type:"init",patterns:/^init\b/i},{type:"create",patterns:/^(?:create|crear|new|nuevo)\b/i},{type:"list",patterns:/^(?:list|listar|show all|mostrar todos)\b/i},{type:"delete",patterns:/^(?:delete|borrar|remove workflow)\b/i},{type:"run",patterns:/^run\b/i},{type:"view",patterns:/^(?:muestra|show|ver|display|mostrar)\b/i},{type:"add",patterns:/^(?:a[nñ]ade|agrega|pon|nueva?)\b/i},{type:"remove",patterns:/^(?:quita|remove|elimina|borra|borrar)\b/i},{type:"disable",patterns:/^(?:deshabilita|disable|no\s+corras|apaga|turn\s+off|desactiva)\b/i},{type:"gate",patterns:/^(?:bloquea|block|protect|protege)\b/i}],rr=class extends xe{static{l(this,"WorkflowCommands")}async now(e=null,t=process.cwd(),n={}){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let o=await M.getProjectId(t);if(!o)return n.md?console.log("> No project ID found. Run `prjct init` first."):h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(e){let i=await Jt(o,"task","before",{projectPath:t,skipRules:n.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a,c=e;if(/^[A-Z]+-\d+$/.test(e))try{let f=await ha(o),S=await rd(o);if(S&&f.linear?.teamId){await Ft.initializeFromApiKey(S,f.linear.teamId);let y=await Ft.fetchIssue(e);y&&(a=e,c=`${e}: ${y.title}`,await Ft.markInProgress(e))}}catch{}if(n.md){try{await pn.ensureReady()}catch(ht){return $t("blocked","context7_not_ready",[{label:"Fix Context7 now",command:"prjct start"},{label:"Retry task after fix",command:`prjct task "${c}" --md`},{label:"Cancel"}],{error:w(ht)}),{success:!1,error:w(ht)}}let f=await $u(o,c),S=await L.getCurrentTask(o);if(S)return $t("blocked","task_already_active",[{label:"Complete current task first",command:"prjct done --md"},{label:"Pause current and start this one",command:"prjct pause --md"},{label:"Cancel"}],{current_task:S.description,requested_task:c}),{success:!0,message:"Task already active",currentTask:S};await L.startTask(o,{id:me(),description:c,sessionId:me(),linearId:a,type:f.taskType,estimatedPoints:f.estimatedPoints,estimatedMinutes:f.estimatedMinutes});let y=A.getGlobalProjectPath(o),C=Il(c),E;try{E=Mr.getHistoricalBoosts(o,C),E.size===0&&(E=void 0)}catch{}let[N,ne,oe,be]=await Promise.all([qT(),Je.getActive(o).catch(()=>null),KT(y),Pi(c,t,{maxFiles:8,minScore:.15,historicalBoosts:E}).catch(()=>({files:[],metrics:{filesScanned:0,filesReturned:0,scanDuration:0}}))]),v=null;try{let ht=Fn.getSnapshot(o);ht&&(v=Fn.formatContinuityContext(ht),Fn.clearSnapshot(o))}catch{}let $=pl({description:c,branch:N,linearId:a}),_e=XT(ne,oe),dr=bm(be.files.map(ht=>({path:ht.path,description:ht.reasons.join(", ")}))),pr=YT(oe),va=QT(ne),Pa=ZT(c,be.files,ne),Ca=de([{label:"Find relevant files",command:`prjct context files "${e}"`},{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(U(v,$,Pa,_e,dr,pr,va,Ca));try{let ht=await L.getCurrentTask(o);ht&&Mr.recordSuggestions(o,ht.id,C,be.files.map(_=>_.path))}catch{}return await this.logToMemory(t,"task_started",{task:e,timestamp:V.getTimestamp()}),await Jt(o,"task","after",{projectPath:t,skipRules:n.skipHooks}),{success:!0,task:e,taskDescription:c}}let d=await Di.execute("task",{task:e},t);if(!d.success)return h.fail(d.error||"Failed to execute task"),{success:!1,error:d.error};let m=await $u(o,c);await L.startTask(o,{id:me(),description:c,sessionId:me(),linearId:a,type:m.taskType,estimatedPoints:m.estimatedPoints,estimatedMinutes:m.estimatedMinutes});let p=await Vl.getAvailableAgents(t),g=d.orchestratorContext?.agents?.length||p.length;return h.done(`${e}`,{agents:g>0?g:void 0}),Hr("working"),At("task"),await this.logToMemory(t,"task_started",{task:e,agenticMode:!0,availableAgents:p,orchestratorContext:d.orchestratorContext,timestamp:V.getTimestamp()}),await Jt(o,"task","after",{projectPath:t,skipRules:n.skipHooks}),{...d,success:!0,task:e,agenticMode:!0,availableAgents:p,fibonacci:{isValidPoint:Ph,pointsToMinutes:us,pointsToTimeRange:Ch,storeEstimate:l(async f=>{let S=us(f);return await L.updateCurrentTask(o,{estimatedPoints:f,estimatedMinutes:S.typical}),S},"storeEstimate")}}}else{let i=await L.getCurrentTask(o);if(!i)return n.md?$t("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):h.warn("no active task"),{success:!0,message:"No active task"};if(n.md){let a=i.startedAt?V.calculateDuration(new Date(i.startedAt)):void 0,c=pl({description:i.description,status:"active",branch:i.branch,linearId:i.linearId,type:i.type,duration:a}),u=i.subtasks||[],d=i.currentSubtaskIndex,m=u.length>0?km(u,d):"",p=de([{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(U(c,m,p))}else h.done(`working on: ${i.description}`);return{success:!0,task:i.description,currentTask:i}}}catch(s){let o=w(s);return n.md?o.includes("Cannot run")||o.includes("working state")?$t("blocked","state_conflict",[{label:"Complete current task",command:"prjct done --md"},{label:"Pause current task",command:"prjct pause --md"}],{error:o.split(".")[0]}):console.log(JSON.stringify({status:"error",error:o})):h.fail(o),{success:!1,error:o}}}async done(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await L.getCurrentTask(s);if(!o)return t.md?$t("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):h.warn("no active task"),{success:!0,message:"No active task to complete"};let i=await Jt(s,"done","before",{projectPath:e,skipRules:t.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a=o.description,c="",u=0;if(o.startedAt){let y=new Date(o.startedAt);c=V.calculateDuration(y),u=Math.round((Date.now()-y.getTime())/6e4)}let d=o.estimatedMinutes,m=o.estimatedPoints,p=o.type||"feature",g=o.linearId;try{await ft.record(s,{sessionId:o.sessionId,command:"done",task:a,startedAt:o.startedAt,completedAt:V.getTimestamp(),estimatedDuration:d?ly(d):"0m",actualDuration:c||"0m",variance:d?nE(u-d):"+0m",completedAsPlanned:!0,qualityScore:3,tags:[p,g].filter(Boolean)})}catch{}let f="";if(m&&d){let y=u-d,C=d>0?Math.round((u-d)/d*100):0,E=y>=0?"+":"";f=` | est: ${m}pt (${ly(d)}) \u2192 ${E}${C}%`}try{let y=await tE(e,o.startedAt);y.length>0&&Mr.completeFeedback(s,o.id,y)}catch{}await L.completeTask(s,t.feedback);try{Fn.clearSnapshot(s)}catch{}let S=o.linearId;if(S)try{let y=await ha(s),C=await rd(s);C&&y.linear?.teamId&&(await Ft.initializeFromApiKey(C,y.linear.teamId),await Ft.markDone(S))}catch{}if(t.md){let y=c?` (${c})`:"";console.log(U(Se("Completed",`${a}${y}`),kt({Duration:c||"unknown",...f?{Variance:f.replace(" | ","")}:{}}),de([{label:"Complete next subtask",command:"p. done"},{label:"Ship when ready",command:"p. ship"}])))}else{let y=c?` (${c}${f})`:"";S?h.done(`${a}${y} \u2192 Linear \u2713`):h.done(`${a}${y}`),Hr("completed"),At("done")}return await this.logToMemory(e,"task_completed",{task:a,duration:c,estimatedPoints:m,estimatedMinutes:d,actualMinutes:u,timestamp:V.getTimestamp()}),await Jt(s,"done","after",{projectPath:e,skipRules:t.skipHooks}),{success:!0,task:a,duration:c}}catch(n){return h.fail(w(n)),{success:!1,error:w(n)}}}async next(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let s=await M.getProjectId(e);if(!s)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await ke.getActiveTasks(s);if(o.length===0)return t.md?$t("empty","queue_empty",[{label:"Add a task",command:'prjct task "description" --md'},{label:"Add a bug",command:'prjct bug "description" --md'}]):h.warn("queue empty"),{success:!0,message:"Queue is empty"};if(t.md){let i=o.map(a=>{let c=a.type?` [${a.type}]`:"",u=a.priority?` ${a.priority}`:"";return`${a.description}${c}${u}`});console.log(U(ee("Queue",`${o.length} task${o.length!==1?"s":""}`),Ie(i,!0),de([{label:"Start working",command:`p. task "${o[0].description}"`}])))}else h.done(`${o.length} task${o.length!==1?"s":""} queued`),At("next");return{success:!0,tasks:o,count:o.length}}catch(n){return h.fail(w(n)),{success:!1,error:w(n)}}}async pause(e="",t=process.cwd(),n={}){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let o=await M.getProjectId(t);if(!o)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await L.getCurrentTask(o);if(!i)return n.md?$t("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'}]):h.warn("no active task to pause"),{success:!0,message:"No active task to pause"};let a="";i.startedAt&&(a=V.calculateDuration(new Date(i.startedAt))),await L.pauseTask(o,e);try{await Fn.capture(o,t,{taskDescription:i.description,taskStatus:"paused",sessionId:i.sessionId,activeSubtaskIndex:i.currentSubtaskIndex,subtaskCount:i.subtasks?.length,linearId:i.linearId,startedAt:i.startedAt})}catch{}if(n.md)console.log(U(Se("Task Paused",`**Paused:** ${i.description}`),kt({Reason:e||void 0,"Duration worked":a||void 0}),de([{label:"Resume this task",command:"p. resume"},{label:"Start something new",command:"p. task"}])));else{let c=i.description.slice(0,40);h.done(`paused: ${c}${e?` (${e})`:""}`),Hr("paused"),At("pause")}return await this.logToMemory(t,"task_paused",{task:i.description,reason:e,timestamp:V.getTimestamp()}),{success:!0,task:i.description,reason:e}}catch(s){return h.fail(w(s)),{success:!1,error:w(s)}}}async resume(e=null,t=process.cwd(),n={}){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let o=await M.getProjectId(t);if(!o)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await L.getCurrentTask(o);if(i)return n.md?$t("blocked","task_already_active",[{label:"Continue working",command:"prjct done --md"},{label:"Pause and switch",command:"prjct pause --md"}],{current_task:i.description}):h.warn("already working on a task"),{success:!0,message:`Already working on: ${i.description}`};let a=await L.resumeTask(o);return a?(n.md?console.log(U(Se("Task Resumed",`**Resumed:** ${a.description}`),de([{label:"Continue working, then finish",command:"p. done"}]))):(h.done(`resumed: ${a.description.slice(0,40)}`),Hr("working"),At("resume")),await this.logToMemory(t,"task_resumed",{task:a.description,timestamp:V.getTimestamp()}),{success:!0,task:a.description}):(n.md?$t("idle","no_paused_task",[{label:"Start a new task",command:'prjct task "description" --md'}]):h.warn("no paused task to resume"),{success:!0,message:"No paused task found"})}catch(s){return h.fail(w(s)),{success:!1,error:w(s)}}}async workflow(e=null,t=process.cwd(),n={}){try{let s=await this.ensureProjectInit(t);if(!s.success)return s;let o=await M.getProjectId(t);if(!o)return n.md?console.log("> No project ID found. Run `prjct init` first."):h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e?.trim()??"";if(!i)return this._workflowShow(null,o,n);let a=this._detectIntent(i);switch(a.type){case"add":return this._workflowAdd(a.args,o,n);case"gate":return this._workflowGate(a.args,o,n);case"instruction":return this._workflowInstruction(a.args,o,n);case"remove":return this._workflowRm(a.args,o,n);case"disable":return this._workflowDisable(a.args,o,n);case"reset":return this._workflowReset(o,n);case"init":return this._workflowInit(o,t,n);case"help":return this._workflowHelp(n);case"create":return this._workflowCreate(a.args,o,t,n);case"list":return this._workflowList(o,n);case"delete":return this._workflowDelete(a.args,o,n);case"run":return this.run(a.args,t,n);case"view":return this._workflowShow(a.args||null,o,n);default:return this._workflowShow(i.split(/\s+/)[0]?.toLowerCase()||null,o,n)}}catch(s){return n.md?console.log(`> Error: ${w(s)}`):h.fail(w(s)),{success:!1,error:w(s)}}}_detectIntent(e){let t=e.trim();for(let{type:n,patterns:s}of JT){let o=t.match(s);if(o){let i=o[0],a=t.slice(i.length).trim(),c=/^(?:add|gate|rm|reset|init|help)\b/i.test(i);return{type:n,args:a,confidence:c?"exact":"fuzzy"}}}return{type:"view",args:t,confidence:"fuzzy"}}_searchRules(e,t){let n=t.toLowerCase();return e.filter(s=>s.action.toLowerCase().includes(n)||(s.description?.toLowerCase().includes(n)??!1)||s.command.toLowerCase().includes(n)||String(s.id)===n)}_parseAction(e){let t=e.trim();if(t.startsWith('"')){let s=t.indexOf('"',1);return s===-1?[t.slice(1),""]:[t.slice(1,s),t.slice(s+1).trim()]}if(t.startsWith("'")){let s=t.indexOf("'",1);return s===-1?[t.slice(1),""]:[t.slice(1,s),t.slice(s+1).trim()]}let n=t.match(/^(.+?)\s+(before|after)\s+/i);return n?[n[1].trim(),t.slice(n[1].length).trim()]:[t,""]}async _workflowAdd(e,t,n){let[s,o]=this._parseAction(e);if(!s||!o){let m='Usage: prjct workflow add "command" before|after <task|done|ship|sync>';return n.md?console.log(`> ${m}`):h.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 n.md?console.log(`> ${m}`):h.warn(m),{success:!1,error:m}}let u=nt.getWorkflow(t,c||"");if(!c||!u||!u.enabled){let p=nt.getAllWorkflows(t).map(f=>f.name).join(", "),g=`Workflow '${c}' not found. Available: ${p}`;return n.md?console.log(`> ${g}`):h.warn(g),{success:!1,error:g}}let d=Ae.addRule(t,{type:"hook",command:c,position:a,action:s,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return n.md?console.log(U(Se("Rule Added",`#${d} [hook] ${a} ${c} \u2192 \`${s}\``),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${d} --md`}]))):h.done(`rule #${d} added: [hook] ${a} ${c} \u2192 ${s}`),{success:!0,ruleId:d}}async _workflowGate(e,t,n){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=nt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let m=nt.getAllWorkflows(t).map(g=>g.name).join(", "),p=`Workflow '${o}' not found. Available: ${m}`;return n.md?console.log(`> ${p}`):h.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 n.md?console.log(`> ${d}`):h.warn(d),{success:!1,error:d}}let u=Ae.addRule(t,{type:"gate",command:o,position:"before",action:c,description:null,enabled:!0,timeoutMs:6e4,createdAt:new Date().toISOString(),sortOrder:0});return n.md?console.log(U(Se("Gate Added",`#${u} [gate] before ${o} \u2192 \`${c}\``),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this gate",command:`prjct workflow rm ${u} --md`}]))):h.done(`gate #${u} added: before ${o} \u2192 ${c}`),{success:!0,ruleId:u}}async _workflowInstruction(e,t,n){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=nt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let f=nt.getAllWorkflows(t).map(y=>y.name).join(", "),S=`Workflow '${o}' not found. Available: ${f}`;return n.md?console.log(`> ${S}`):h.warn(S),{success:!1,error:S}}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 n.md?console.log(`> ${g}`):h.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 n.md?console.log(`> ${g}`):h.warn(g),{success:!1,error:g}}let p=Ae.addRule(t,{type:"instruction",command:o,position:u,action:m,description:null,enabled:!0,timeoutMs:0,createdAt:new Date().toISOString(),sortOrder:0});return n.md?console.log(U(Se("Instruction Added",`#${p} [instruction] ${u} ${o} \u2192 \`${m}\``),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${p} --md`}]))):h.done(`instruction #${p} added: ${u} ${o} \u2192 ${m}`),{success:!0,ruleId:p}}async _workflowRm(e,t,n){let s=parseInt(e.trim(),10);if(Number.isNaN(s)){let i="Usage: prjct workflow rm <rule-id>";return n.md?console.log(`> ${i}`):h.warn(i),{success:!1,error:i}}if(!Ae.removeRule(t,s)){let i=`Rule #${s} not found`;return n.md?console.log(`> ${i}`):h.warn(i),{success:!1,error:i}}return n.md?console.log(U(Se("Rule Removed",`Removed rule #${s}`))):h.done(`removed rule #${s}`),{success:!0}}async _workflowReset(e,t){let n=Ae.resetRules(e);return t.md?console.log(U(Se("Rules Reset",`Removed ${n} rule${n!==1?"s":""}`))):h.done(`reset: removed ${n} rule${n!==1?"s":""}`),{success:!0,count:n}}async _workflowDisable(e,t,n){let s=e.trim(),o=parseInt(s,10);if(!Number.isNaN(o)){let c=Ae.getRuleById(t,o);if(!c){let u=`Rule #${o} not found`;return n.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}if(!c.enabled){let u=`Rule #${o} is already disabled`;return n.md?console.log(`> ${u}`):h.warn(u),{success:!0,message:u}}return Ae.updateRule(t,o,{enabled:!1}),n.md?console.log(U(Se("Rule Disabled",`#${o} [${c.type}] ${c.action}`),de([{label:"Re-enable this rule",command:`prjct workflow enable ${o} --md`},{label:"View all rules",command:"prjct workflow --md"}]))):h.done(`disabled rule #${o}: ${c.action}`),{success:!0,ruleId:o}}let i=Ae.getAllRules(t),a=this._searchRules(i,s);if(a.length===0){let c=`No rules matching "${s}"`;return n.md?console.log(`> ${c}`):h.warn(c),{success:!1,error:c}}if(a.length===1){let c=a[0];return Ae.updateRule(t,c.id,{enabled:!1}),n.md?console.log(U(Se("Rule Disabled",`#${c.id} [${c.type}] ${c.action}`))):h.done(`disabled rule #${c.id}: ${c.action}`),{success:!0,ruleId:c.id}}if(n.md){let c=a.map(u=>`#${u.id} [${u.type}] ${u.position} ${u.command} -> \`${u.action}\``);console.log(U(ee("Multiple matches",`${a.length} rules match "${s}"`),Ie(c),de(a.map(u=>({label:`Disable #${u.id}`,command:`prjct workflow disable ${u.id} --md`})))))}else{h.warn(`${a.length} rules match "${s}" \u2014 specify an ID:`);for(let c of a)console.log(` #${c.id} [${c.type}] ${c.position} ${c.command} -> ${c.action}`)}return{success:!0,matches:a.map(c=>c.id)}}async _workflowHelp(e){return e.md?console.log(U(ee("Workflow Help","Manage hooks, gates, and steps for your workflow"),ee("Commands",Ie(["`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"])),ee("Natural Language (EN/ES)",Ie(['`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,n){let s=["task","done","ship","sync"],o;if(e&&s.includes(e)?o=Ae.getRulesForCommand(t,e):o=Ae.getAllRules(t),o.length===0)return n.md?console.log(U(ee("Workflow Rules","No rules configured"),de([{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'}]))):(h.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(n.md){let i=e?[e]:s,a=[];for(let d of i){let m=o.filter(p=>p.command===d);m.length!==0&&a.push(eE(d,m))}let c=e?`Workflow: ${e}`:"Workflow Rules",u=`${o.length} rule${o.length!==1?"s":""}`;console.log(U(ee(c,u),a.length>0?Sm(a.join(`
|
|
1548
|
+
`}},Bu=new Vu;Rt();xs();Pu();ve();oe();ce();import{exec as ST}from"node:child_process";import{promisify as kT}from"node:util";var Xh=kT(ST),Zs="session-snapshot",bT=30,Ju=class{static{l(this,"SessionSnapshotManager")}async capture(e,t,n){let r=await this.getGitBranch(t),o=await this.getModifiedFiles(t),i=n.startedAt?Math.round((Date.now()-new Date(n.startedAt).getTime())/1e3):void 0,a=t.split("/").pop()||t,c=this.generateResumeHint(n,i),u={sessionId:n.sessionId,projectId:e,projectPath:t,projectName:a,taskDescription:n.taskDescription,taskStatus:n.taskStatus,activeSubtaskIndex:n.activeSubtaskIndex,subtaskCount:n.subtaskCount,branch:r,linearId:n.linearId,filesModified:o,durationWorkedSec:i,timestamp:b(),resumeHint:c};return E.setDoc(e,Zs,u),u}getSnapshot(e){try{return E.getDoc(e,Zs)}catch{return null}}clearSnapshot(e){try{E.deleteDoc(e,Zs)}catch{}}async listAllSnapshots(){let e=await A.listProjects(),t=[];for(let n of e)try{if(!E.exists(n))continue;let r=E.getDoc(n,Zs);r&&t.push(r)}catch{}return t.sort((n,r)=>new Date(r.timestamp).getTime()-new Date(n.timestamp).getTime()),t}async cleanup(e=bT){let t=await A.listProjects(),n=Date.now()-e*24*60*60*1e3,r=0;for(let o of t)try{if(!E.exists(o))continue;let i=E.getDoc(o,Zs);i&&new Date(i.timestamp).getTime()<n&&(E.deleteDoc(o,Zs),r++)}catch{}return r}formatContinuityContext(e){let n=["Session Continuity",`- Last session: ${nn(Date.now()-new Date(e.timestamp).getTime())} ago`,`- Task: ${e.taskDescription}`,`- Status: ${e.taskStatus}`];if(e.subtaskCount&&e.activeSubtaskIndex!==void 0&&n.push(`- Progress: subtask ${e.activeSubtaskIndex+1}/${e.subtaskCount}`),e.branch&&n.push(`- Branch: ${e.branch}`),e.filesModified&&e.filesModified.length>0){let r=e.filesModified.slice(0,5).join(", "),o=e.filesModified.length>5?` (+${e.filesModified.length-5} more)`:"";n.push(`- Modified files: ${r}${o}`)}return e.durationWorkedSec&&n.push(`- Time worked: ${nn(e.durationWorkedSec*1e3)}`),n.push(`- Resume hint: ${e.resumeHint}`),n.join(`
|
|
1549
|
+
`)}generateResumeHint(e,t){let n=[];return e.taskStatus==="paused"?n.push("Task was paused"):n.push("Task was in progress"),e.subtaskCount&&e.activeSubtaskIndex!==void 0&&n.push(`on subtask ${e.activeSubtaskIndex+1} of ${e.subtaskCount}`),t&&t>60&&n.push(`after ${nn(t*1e3)} of work`),n.join(" ")}async getGitBranch(e){try{let{stdout:t}=await Xh("git branch --show-current",{cwd:e});return t.trim()||void 0}catch{return}}async getModifiedFiles(e){try{let{stdout:t}=await Xh("git diff --name-only HEAD 2>/dev/null || git diff --name-only 2>/dev/null",{cwd:e});return t.trim().split(`
|
|
1550
|
+
`).filter(n=>n.length>0).slice(0,20)}catch{return[]}}},$n=new Ju;Yt();Yc();Or();Si();L();$s();Ms();nl();Xn();lt();var CT=[{type:"help",patterns:/^(?:help|ayuda|c[oó]mo|how)\b/i},{type:"add",patterns:/^add\b/i},{type:"gate",patterns:/^gate\b/i},{type:"instruction",patterns:/^instruction\b/i},{type:"remove",patterns:/^rm\b/i},{type:"reset",patterns:/^reset\b/i},{type:"init",patterns:/^init\b/i},{type:"create",patterns:/^(?:create|crear|new|nuevo)\b/i},{type:"list",patterns:/^(?:list|listar|show all|mostrar todos)\b/i},{type:"delete",patterns:/^(?:delete|borrar|remove workflow)\b/i},{type:"run",patterns:/^run\b/i},{type:"view",patterns:/^(?:muestra|show|ver|display|mostrar)\b/i},{type:"add",patterns:/^(?:a[nñ]ade|agrega|pon|nueva?)\b/i},{type:"remove",patterns:/^(?:quita|remove|elimina|borra|borrar)\b/i},{type:"disable",patterns:/^(?:deshabilita|disable|no\s+corras|apaga|turn\s+off|desactiva)\b/i},{type:"gate",patterns:/^(?:bloquea|block|protect|protege)\b/i}],er=class extends Ce{static{l(this,"WorkflowCommands")}async now(e=null,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return n.md?console.log("> No project ID found. Run `prjct init` first."):h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};if(e){let i=await Wt(o,"task","before",{projectPath:t,skipRules:n.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a,c=e;if(/^[A-Z]+-\d+$/.test(e)&&(a=e),n.md){try{await an.ensureReady()}catch(ft){return jt("blocked","context7_not_ready",[{label:"Fix Context7 now",command:"prjct start"},{label:"Retry task after fix",command:`prjct task "${c}" --md`},{label:"Cancel"}],{error:y(ft)}),{success:!1,error:y(ft)}}let f=await vu(o,c),S=await N.getCurrentTask(o);if(S)return jt("blocked","task_already_active",[{label:"Complete current task first",command:"prjct done --md"},{label:"Pause current and start this one",command:"prjct pause --md"},{label:"Cancel"}],{current_task:S.description,requested_task:c}),{success:!0,message:"Task already active",currentTask:S};await N.startTask(o,{id:me(),description:c,sessionId:me(),linearId:a,type:f.taskType,estimatedPoints:f.estimatedPoints,estimatedMinutes:f.estimatedMinutes});let w=A.getGlobalProjectPath(o),v=wl(c),T;try{T=Rr.getHistoricalBoosts(o,v),T.size===0&&(T=void 0)}catch{}let[_,ne,re,ke]=await Promise.all([xT(),Je.getActive(o).catch(()=>null),TT(w),Ns(c,t,{maxFiles:8,minScore:.15,historicalBoosts:T}).catch(()=>({files:[],metrics:{filesScanned:0,filesReturned:0,scanDuration:0}}))]),P=null;try{let ft=$n.getSnapshot(o);ft&&(P=$n.formatContinuityContext(ft),$n.clearSnapshot(o))}catch{}let $=tl({description:c,branch:_,linearId:a}),Fe=ET(ne,re),ir=um(ke.files.map(ft=>({path:ft.path,description:ft.reasons.join(", ")}))),ar=AT(re),da=RT(ne),pa=DT(c,ke.files,ne),ma=de([{label:"Find relevant files",command:`prjct context files "${e}"`},{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(U(P,$,pa,Fe,ir,ar,da,ma));try{let ft=await N.getCurrentTask(o);ft&&Rr.recordSuggestions(o,ft.id,v,ke.files.map(F=>F.path))}catch{}return await this.logToMemory(t,"task_started",{task:e,timestamp:B.getTimestamp()}),await Wt(o,"task","after",{projectPath:t,skipRules:n.skipHooks}),{success:!0,task:e,taskDescription:c}}let d=await Ti.execute("task",{task:e},t);if(!d.success)return h.fail(d.error||"Failed to execute task"),{success:!1,error:d.error};let m=await vu(o,c);await N.startTask(o,{id:me(),description:c,sessionId:me(),linearId:a,type:m.taskType,estimatedPoints:m.estimatedPoints,estimatedMinutes:m.estimatedMinutes});let p=await $l.getAvailableAgents(t),g=d.orchestratorContext?.agents?.length||p.length;return h.done(`${e}`,{agents:g>0?g:void 0}),_r("working"),Tt("task"),await this.logToMemory(t,"task_started",{task:e,agenticMode:!0,availableAgents:p,orchestratorContext:d.orchestratorContext,timestamp:B.getTimestamp()}),await Wt(o,"task","after",{projectPath:t,skipRules:n.skipHooks}),{...d,success:!0,task:e,agenticMode:!0,availableAgents:p,fibonacci:{isValidPoint:ph,pointsToMinutes:is,pointsToTimeRange:mh,storeEstimate:l(async f=>{let S=is(f);return await N.updateCurrentTask(o,{estimatedPoints:f,estimatedMinutes:S.typical}),S},"storeEstimate")}}}else{let i=await N.getCurrentTask(o);if(!i)return n.md?jt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):h.warn("no active task"),{success:!0,message:"No active task"};if(n.md){let a=i.startedAt?B.calculateDuration(new Date(i.startedAt)):void 0,c=tl({description:i.description,status:"active",branch:i.branch,linearId:i.linearId,type:i.type,duration:a}),u=i.subtasks||[],d=i.currentSubtaskIndex,m=u.length>0?lm(u,d):"",p=de([{label:"Complete subtask",command:"prjct done --md"},{label:"Pause task",command:"prjct pause --md"}]);console.log(U(c,m,p))}else h.done(`working on: ${i.description}`);return{success:!0,task:i.description,currentTask:i}}}catch(r){let o=y(r);return n.md?o.includes("Cannot run")||o.includes("working state")?jt("blocked","state_conflict",[{label:"Complete current task",command:"prjct done --md"},{label:"Pause current task",command:"prjct pause --md"}],{error:o.split(".")[0]}):console.log(JSON.stringify({status:"error",error:o})):h.fail(o),{success:!1,error:o}}}async done(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await N.getCurrentTask(r);if(!o)return t.md?jt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'},{label:"Check queue",command:"prjct next --md"}]):h.warn("no active task"),{success:!0,message:"No active task to complete"};let i=await Wt(r,"done","before",{projectPath:e,skipRules:t.skipHooks});if(!i.success)return{success:!1,error:i.gatesFailed.length>0?`Blocked: ${i.gatesFailed.join(", ")}`:`Hook failed: ${i.hooksFailed.join(", ")}`};let a=o.description,c="",u=0;if(o.startedAt){let v=new Date(o.startedAt);c=B.calculateDuration(v),u=Math.round((Date.now()-v.getTime())/6e4)}let d=o.estimatedMinutes,m=o.estimatedPoints,p=o.type||"feature",g=o.linearId;try{await gt.record(r,{sessionId:o.sessionId,command:"done",task:a,startedAt:o.startedAt,completedAt:B.getTimestamp(),estimatedDuration:d?Yh(d):"0m",actualDuration:c||"0m",variance:d?$T(u-d):"+0m",completedAsPlanned:!0,qualityScore:3,tags:[p,g].filter(Boolean)})}catch{}let f="";if(m&&d){let v=u-d,T=d>0?Math.round((u-d)/d*100):0,_=v>=0?"+":"";f=` | est: ${m}pt (${Yh(d)}) \u2192 ${_}${T}%`}try{let v=await IT(e,o.startedAt);v.length>0&&Rr.completeFeedback(r,o.id,v)}catch{}await N.completeTask(r,t.feedback);try{$n.clearSnapshot(r)}catch{}let S=o.linearId,w=S!=null?await Qr("linear",mn()).catch(()=>!1):!1;if(t.md){let v=c?` (${c})`:"";console.log(U(Se("Completed",`${a}${v}`),St({Duration:c||"unknown",...f?{Variance:f.replace(" | ","")}:{}}),de([{label:"Complete next subtask",command:"p. done"},{label:"Ship when ready",command:"p. ship"}])))}else{let v=c?` (${c}${f})`:"";S&&w?h.done(`${a}${v} \u2192 Linear linked (update via MCP)`):h.done(`${a}${v}`),_r("completed"),Tt("done")}return await this.logToMemory(e,"task_completed",{task:a,duration:c,estimatedPoints:m,estimatedMinutes:d,actualMinutes:u,timestamp:B.getTimestamp()}),await Wt(r,"done","after",{projectPath:e,skipRules:t.skipHooks}),{success:!0,task:a,duration:c}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}async next(e=process.cwd(),t={}){try{let n=await this.ensureProjectInit(e);if(!n.success)return n;let r=await M.getProjectId(e);if(!r)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let o=await Ie.getActiveTasks(r);if(o.length===0)return t.md?jt("empty","queue_empty",[{label:"Add a task",command:'prjct task "description" --md'},{label:"Add a bug",command:'prjct bug "description" --md'}]):h.warn("queue empty"),{success:!0,message:"Queue is empty"};if(t.md){let i=o.map(a=>{let c=a.type?` [${a.type}]`:"",u=a.priority?` ${a.priority}`:"";return`${a.description}${c}${u}`});console.log(U(ee("Queue",`${o.length} task${o.length!==1?"s":""}`),Ae(i,!0),de([{label:"Start working",command:`p. task "${o[0].description}"`}])))}else h.done(`${o.length} task${o.length!==1?"s":""} queued`),Tt("next");return{success:!0,tasks:o,count:o.length}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}async pause(e="",t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await N.getCurrentTask(o);if(!i)return n.md?jt("idle","no_active_task",[{label:"Start a task",command:'prjct task "description" --md'}]):h.warn("no active task to pause"),{success:!0,message:"No active task to pause"};let a="";i.startedAt&&(a=B.calculateDuration(new Date(i.startedAt))),await N.pauseTask(o,e);try{await $n.capture(o,t,{taskDescription:i.description,taskStatus:"paused",sessionId:i.sessionId,activeSubtaskIndex:i.currentSubtaskIndex,subtaskCount:i.subtasks?.length,linearId:i.linearId,startedAt:i.startedAt})}catch{}if(n.md)console.log(U(Se("Task Paused",`**Paused:** ${i.description}`),St({Reason:e||void 0,"Duration worked":a||void 0}),de([{label:"Resume this task",command:"p. resume"},{label:"Start something new",command:"p. task"}])));else{let c=i.description.slice(0,40);h.done(`paused: ${c}${e?` (${e})`:""}`),_r("paused"),Tt("pause")}return await this.logToMemory(t,"task_paused",{task:i.description,reason:e,timestamp:B.getTimestamp()}),{success:!0,task:i.description,reason:e}}catch(r){return h.fail(y(r)),{success:!1,error:y(r)}}}async resume(e=null,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=await N.getCurrentTask(o);if(i)return n.md?jt("blocked","task_already_active",[{label:"Continue working",command:"prjct done --md"},{label:"Pause and switch",command:"prjct pause --md"}],{current_task:i.description}):h.warn("already working on a task"),{success:!0,message:`Already working on: ${i.description}`};let a=await N.resumeTask(o);return a?(n.md?console.log(U(Se("Task Resumed",`**Resumed:** ${a.description}`),de([{label:"Continue working, then finish",command:"p. done"}]))):(h.done(`resumed: ${a.description.slice(0,40)}`),_r("working"),Tt("resume")),await this.logToMemory(t,"task_resumed",{task:a.description,timestamp:B.getTimestamp()}),{success:!0,task:a.description}):(n.md?jt("idle","no_paused_task",[{label:"Start a new task",command:'prjct task "description" --md'}]):h.warn("no paused task to resume"),{success:!0,message:"No paused task found"})}catch(r){return h.fail(y(r)),{success:!1,error:y(r)}}}async workflow(e=null,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return n.md?console.log("> No project ID found. Run `prjct init` first."):h.failWithHint("NO_PROJECT_ID"),{success:!1,error:"No project ID found"};let i=e?.trim()??"";if(!i)return this._workflowShow(null,o,n);let a=this._detectIntent(i);switch(a.type){case"add":return this._workflowAdd(a.args,o,n);case"gate":return this._workflowGate(a.args,o,n);case"instruction":return this._workflowInstruction(a.args,o,n);case"remove":return this._workflowRm(a.args,o,n);case"disable":return this._workflowDisable(a.args,o,n);case"reset":return this._workflowReset(o,n);case"init":return this._workflowInit(o,t,n);case"help":return this._workflowHelp(n);case"create":return this._workflowCreate(a.args,o,t,n);case"list":return this._workflowList(o,n);case"delete":return this._workflowDelete(a.args,o,n);case"run":return this.run(a.args,t,n);case"view":return this._workflowShow(a.args||null,o,n);default:return this._workflowShow(i.split(/\s+/)[0]?.toLowerCase()||null,o,n)}}catch(r){return n.md?console.log(`> Error: ${y(r)}`):h.fail(y(r)),{success:!1,error:y(r)}}}_detectIntent(e){let t=e.trim();for(let{type:n,patterns:r}of CT){let o=t.match(r);if(o){let i=o[0],a=t.slice(i.length).trim(),c=/^(?:add|gate|rm|reset|init|help)\b/i.test(i);return{type:n,args:a,confidence:c?"exact":"fuzzy"}}}return{type:"view",args:t,confidence:"fuzzy"}}_searchRules(e,t){let n=t.toLowerCase();return e.filter(r=>r.action.toLowerCase().includes(n)||(r.description?.toLowerCase().includes(n)??!1)||r.command.toLowerCase().includes(n)||String(r.id)===n)}_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 n=t.match(/^(.+?)\s+(before|after)\s+/i);return n?[n[1].trim(),t.slice(n[1].length).trim()]:[t,""]}async _workflowAdd(e,t,n){let[r,o]=this._parseAction(e);if(!r||!o){let m='Usage: prjct workflow add "command" before|after <task|done|ship|sync>';return n.md?console.log(`> ${m}`):h.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 n.md?console.log(`> ${m}`):h.warn(m),{success:!1,error:m}}let u=nt.getWorkflow(t,c||"");if(!c||!u||!u.enabled){let p=nt.getAllWorkflows(t).map(f=>f.name).join(", "),g=`Workflow '${c}' not found. Available: ${p}`;return n.md?console.log(`> ${g}`):h.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 n.md?console.log(U(Se("Rule Added",`#${d} [hook] ${a} ${c} \u2192 \`${r}\``),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${d} --md`}]))):h.done(`rule #${d} added: [hook] ${a} ${c} \u2192 ${r}`),{success:!0,ruleId:d}}async _workflowGate(e,t,n){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=nt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let m=nt.getAllWorkflows(t).map(g=>g.name).join(", "),p=`Workflow '${o}' not found. Available: ${m}`;return n.md?console.log(`> ${p}`):h.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 n.md?console.log(`> ${d}`):h.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 n.md?console.log(U(Se("Gate Added",`#${u} [gate] before ${o} \u2192 \`${c}\``),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this gate",command:`prjct workflow rm ${u} --md`}]))):h.done(`gate #${u} added: before ${o} \u2192 ${c}`),{success:!0,ruleId:u}}async _workflowInstruction(e,t,n){let o=e.trim().split(/\s+/)[0]?.toLowerCase(),i=nt.getWorkflow(t,o||"");if(!o||!i||!i.enabled){let f=nt.getAllWorkflows(t).map(w=>w.name).join(", "),S=`Workflow '${o}' not found. Available: ${f}`;return n.md?console.log(`> ${S}`):h.warn(S),{success:!1,error:S}}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 n.md?console.log(`> ${g}`):h.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 n.md?console.log(`> ${g}`):h.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 n.md?console.log(U(Se("Instruction Added",`#${p} [instruction] ${u} ${o} \u2192 \`${m}\``),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Remove this rule",command:`prjct workflow rm ${p} --md`}]))):h.done(`instruction #${p} added: ${u} ${o} \u2192 ${m}`),{success:!0,ruleId:p}}async _workflowRm(e,t,n){let r=parseInt(e.trim(),10);if(Number.isNaN(r)){let i="Usage: prjct workflow rm <rule-id>";return n.md?console.log(`> ${i}`):h.warn(i),{success:!1,error:i}}if(!Ee.removeRule(t,r)){let i=`Rule #${r} not found`;return n.md?console.log(`> ${i}`):h.warn(i),{success:!1,error:i}}return n.md?console.log(U(Se("Rule Removed",`Removed rule #${r}`))):h.done(`removed rule #${r}`),{success:!0}}async _workflowReset(e,t){let n=Ee.resetRules(e);return t.md?console.log(U(Se("Rules Reset",`Removed ${n} rule${n!==1?"s":""}`))):h.done(`reset: removed ${n} rule${n!==1?"s":""}`),{success:!0,count:n}}async _workflowDisable(e,t,n){let r=e.trim(),o=parseInt(r,10);if(!Number.isNaN(o)){let c=Ee.getRuleById(t,o);if(!c){let u=`Rule #${o} not found`;return n.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}if(!c.enabled){let u=`Rule #${o} is already disabled`;return n.md?console.log(`> ${u}`):h.warn(u),{success:!0,message:u}}return Ee.updateRule(t,o,{enabled:!1}),n.md?console.log(U(Se("Rule Disabled",`#${o} [${c.type}] ${c.action}`),de([{label:"Re-enable this rule",command:`prjct workflow enable ${o} --md`},{label:"View all rules",command:"prjct workflow --md"}]))):h.done(`disabled rule #${o}: ${c.action}`),{success:!0,ruleId:o}}let i=Ee.getAllRules(t),a=this._searchRules(i,r);if(a.length===0){let c=`No rules matching "${r}"`;return n.md?console.log(`> ${c}`):h.warn(c),{success:!1,error:c}}if(a.length===1){let c=a[0];return Ee.updateRule(t,c.id,{enabled:!1}),n.md?console.log(U(Se("Rule Disabled",`#${c.id} [${c.type}] ${c.action}`))):h.done(`disabled rule #${c.id}: ${c.action}`),{success:!0,ruleId:c.id}}if(n.md){let c=a.map(u=>`#${u.id} [${u.type}] ${u.position} ${u.command} -> \`${u.action}\``);console.log(U(ee("Multiple matches",`${a.length} rules match "${r}"`),Ae(c),de(a.map(u=>({label:`Disable #${u.id}`,command:`prjct workflow disable ${u.id} --md`})))))}else{h.warn(`${a.length} rules match "${r}" \u2014 specify an ID:`);for(let c of a)console.log(` #${c.id} [${c.type}] ${c.position} ${c.command} -> ${c.action}`)}return{success:!0,matches:a.map(c=>c.id)}}async _workflowHelp(e){return e.md?console.log(U(ee("Workflow Help","Manage hooks, gates, and steps for your workflow"),ee("Commands",Ae(["`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"])),ee("Natural Language (EN/ES)",Ae(['`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,n){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 n.md?console.log(U(ee("Workflow Rules","No rules configured"),de([{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'}]))):(h.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(n.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(jT(d,m))}let c=e?`Workflow: ${e}`:"Workflow Rules",u=`${o.length} rule${o.length!==1?"s":""}`;console.log(U(ee(c,u),a.length>0?cm(a.join(`
|
|
1573
1551
|
|
|
1574
|
-
`),""):null,de([{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,n){let
|
|
1575
|
-
Run with: p. ${i}`)),{success:!0,workflowId:u,name:i,templatePath:d.path}}catch(u){let d=
|
|
1552
|
+
`),""):null,de([{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,n){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 n.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}let o=await ci(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(n.md)console.log(U(Se("Workflow Initialized",`Added ${a.length} default ship rules`),Ae(a),de([{label:"View all rules",command:"prjct workflow --md"},{label:"Ship your work",command:"prjct ship --md"}])));else{h.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,n,r){let o=e.match(/^(\S+)\s+"([^"]+)"/);if(!o){let u='Usage: prjct workflow create <name> "description"';return r.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}let[,i,a]=o;if(!nt.isValidName(i)){let u='Workflow name must be lowercase alphanumeric + hyphens (e.g., "qa", "deploy-prod")';return r.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}if(nt.isReservedName(i)){let u=`Workflow name '${i}' is reserved`;return r.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}if(nt.getWorkflow(t,i)){let u=`Workflow '${i}' already exists`;return r.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}try{let u=nt.createWorkflow(t,{name:i,description:a}),d=await Bu.generateWorkflowTemplate(i,a);if(!d.success){nt.deleteWorkflow(t,i);let m=`Failed to generate template: ${d.error}`;return r.md?console.log(`> Error: ${m}`):h.fail(m),{success:!1,error:m}}return r.md?console.log(U(Se("Workflow Created",`Created workflow: ${i}`),ee("Description",a),ee("Template",`Installed at ${d.path}`),de([{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}`}]))):(h.done(`created workflow: ${i}`),console.log(` ${a}`),console.log(` Template: ${d.path}`),console.log(`
|
|
1553
|
+
Run with: p. ${i}`)),{success:!0,workflowId:u,name:i,templatePath:d.path}}catch(u){let d=y(u);return r.md?console.log(`> Error: ${d}`):h.fail(d),{success:!1,error:d}}}async _workflowList(e,t){let n=nt.getAllWorkflows(e);if(n.length===0){let i="No workflows found";return t.md?console.log(`> ${i}`):h.warn(i),{success:!0,workflows:[]}}let r=n.filter(i=>i.isBuiltin),o=n.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(ee("Built-in Workflows",a.join(`
|
|
1576
1554
|
`)))}if(o.length>0){let a=o.map(c=>`- **${c.name}** \u2014 ${c.description}`);i.push(ee("Custom Workflows",a.join(`
|
|
1577
|
-
`)))}console.log(U(...i,de([{label:"Create workflow",command:'prjct workflow create <name> "description" --md'},{label:"View workflow",command:"prjct workflow <name> --md"}])))}else{if(h.done(`${n.length} workflow${n.length!==1?"s":""}`),
|
|
1578
|
-
Built-in:`);for(let i of
|
|
1579
|
-
Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:n}}async _workflowDelete(e,t,n){let
|
|
1580
|
-
${
|
|
1555
|
+
`)))}console.log(U(...i,de([{label:"Create workflow",command:'prjct workflow create <name> "description" --md'},{label:"View workflow",command:"prjct workflow <name> --md"}])))}else{if(h.done(`${n.length} workflow${n.length!==1?"s":""}`),r.length>0){console.log(`
|
|
1556
|
+
Built-in:`);for(let i of r)console.log(` ${i.name} \u2014 ${i.description}`)}if(o.length>0){console.log(`
|
|
1557
|
+
Custom:`);for(let i of o)console.log(` ${i.name} \u2014 ${i.description}`)}}return{success:!0,workflows:n}}async _workflowDelete(e,t,n){let r=e.trim();if(!r){let o="Usage: prjct workflow delete <name>";return n.md?console.log(`> ${o}`):h.warn(o),{success:!1,error:o}}try{if(!nt.deleteWorkflow(t,r)){let i=`Workflow '${r}' not found`;return n.md?console.log(`> ${i}`):h.warn(i),{success:!1,error:i}}return await Bu.deleteWorkflowTemplate(r),n.md?console.log(U(Se("Workflow Deleted",`Deleted workflow: ${r}`))):h.done(`deleted workflow: ${r}`),{success:!0}}catch(o){let i=y(o);return n.md?console.log(`> Error: ${i}`):h.fail(i),{success:!1,error:i}}}async run(e,t=process.cwd(),n={}){try{let r=await this.ensureProjectInit(t);if(!r.success)return r;let o=await M.getProjectId(t);if(!o)return n.md?console.log("> No project ID found. Run `prjct init` first."):h.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 n.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}let a=nt.getWorkflow(o,i);if(!a||!a.enabled){let u=`Workflow '${i}' not found`;return n.md?console.log(`> ${u}`):h.warn(u),{success:!1,error:u}}let c=await Wt(o,i,"before",{projectPath:t});if(!c.success){if(n.md)jt("failed","workflow_gates_failed",[{label:"View rules",command:`prjct workflow ${i} --md`}]);else if(h.fail("Workflow gates failed"),c.gatesFailed)for(let u of c.gatesFailed)console.log(` \u2717 ${u}`);return{success:!1,error:"Workflow gates failed",gatesFailed:c.gatesFailed}}return await Wt(o,i,"after",{projectPath:t}),n.md?console.log(U(Se(`Workflow: ${i}`,a.description||""),de([{label:"View rules",command:`prjct workflow ${i} --md`},{label:"Run again",command:`p. ${i}`}]))):h.done(`${i} completed successfully`),{success:!0,workflow:i}}catch(r){let o=y(r);return n.md?console.log(`> Error: ${o}`):h.fail(o),{success:!1,error:o}}}async sessions(e=process.cwd(),t={}){try{if(t.cleanup){let r=await $n.cleanup();return t.md?console.log(Se("Cleanup",`Removed ${r} stale snapshot${r!==1?"s":""}`)):h.done(`cleaned ${r} stale snapshot${r!==1?"s":""}`),{success:!0,cleaned:r}}let n=await $n.listAllSnapshots();if(n.length===0)return t.md?jt("empty","no_sessions",[{label:"Start a task",command:'prjct task "description" --md'}]):h.warn("no recent sessions found"),{success:!0,message:"No recent sessions"};if(t.md){let r=n.map(o=>{let i=B.formatDuration(Date.now()-new Date(o.timestamp).getTime()),a=o.projectName||o.projectId.slice(0,8),c=o.subtaskCount&&o.activeSubtaskIndex!==void 0?` (${o.activeSubtaskIndex+1}/${o.subtaskCount})`:"";return`[${o.taskStatus}] **${a}** \u2014 ${o.taskDescription}${c} (${i} ago)`});console.log(U(ee("Recent Sessions",`${n.length} session${n.length!==1?"s":""} across projects`),Ae(r),de([{label:"Resume a session",command:"prjct resume --md"},{label:"Clean old sessions",command:"prjct sessions --cleanup --md"}])))}else{h.done(`${n.length} recent session${n.length!==1?"s":""}`);for(let r of n){let o=B.formatDuration(Date.now()-new Date(r.timestamp).getTime()),i=r.projectName||r.projectId.slice(0,8);console.log(` [${r.taskStatus}] ${i} \u2014 ${r.taskDescription} (${o} ago)`)}}return{success:!0,snapshots:n,count:n.length}}catch(n){return h.fail(y(n)),{success:!1,error:y(n)}}}};function Yh(s){if(s<60)return`${s}m`;let e=Math.floor(s/60),t=s%60;return t>0?`${e}h ${t}m`:`${e}h`}l(Yh,"formatMinutesToDuration");async function xT(){try{let{execSync:s}=await import("node:child_process");return s("git branch --show-current",{encoding:"utf-8"}).trim()||void 0}catch{return}}l(xT,"getGitBranch");async function TT(s){try{let e=PT.join(s,"analysis","repo-analysis.json"),t=await vT.readFile(e,"utf-8");return JSON.parse(t)}catch(e){return C(e),null}}l(TT,"loadRepoAnalysis");function ET(s,e){if(!s&&!e)return null;let t=e?.ecosystem||null,n=s?.languages?.join(", ")||null,r=s?.frameworks?.join(", ")||null,o=s?.packageManager||null,i=s?.sourceDir||e?.structure?.srcDir||null,a=s?.testDir||e?.structure?.testDir||null,c={};if(t&&(c.Ecosystem=t),n&&(c.Languages=n),r&&(c.Frameworks=r),o&&(c["Package manager"]=o),i||a){let g=[];i&&g.push(`${i}`),a&&g.push(`Tests: ${a}`),c.Source=g.join(" | ")}let u=St(c),d=e?.commands,m=null;if(d&&Object.keys(d).length>0){let g=Object.entries(d).map(([f,S])=>`${f.charAt(0).toUpperCase()+f.slice(1)}: \`${S}\``);m=`### Commands
|
|
1558
|
+
${Ae(g)}`}return[u?`### Project
|
|
1581
1559
|
${u}`:null,m].filter(Boolean).join(`
|
|
1582
1560
|
|
|
1583
|
-
`)||null}l(
|
|
1584
|
-
${
|
|
1585
|
-
`)}`)}let n=
|
|
1561
|
+
`)||null}l(ET,"buildProjectContext");function AT(s){let e=["All commits must include footer: Generated with [p/](https://www.prjct.app/)","Never commit directly to main/master"],t=s?.rules;if(Array.isArray(t))for(let n of t)typeof n=="string"&&!e.some(r=>r.toLowerCase()===n.toLowerCase())&&e.push(n);return dm(e)}l(AT,"buildRules");function RT(s){if(!s)return null;let e=[],t=s.patterns;if(Array.isArray(t)&&t.length>0){let r=t.slice(0,8).map(o=>{let i=o.location?` \u2014 \`${o.location}\``:"",a=o.source?` [${o.source}]`:"";return`- **${o.name}**${a}: ${o.description}${i}`});e.push(`### Patterns (follow these)
|
|
1562
|
+
${r.join(`
|
|
1563
|
+
`)}`)}let n=s.antiPatterns;if(Array.isArray(n)&&n.length>0){let r={high:0,medium:1,low:2},i=[...n].sort((a,c)=>{let u=r[a.severity||"low"]??2,d=r[c.severity||"low"]??2;return u-d}).slice(0,8).map(a=>{let c=(a.severity||"low").toUpperCase(),u=a.source?` [${a.source}]`:"";return`- **[${c}] ${a.issue}**${u} \u2014 \`${a.file}\` \u2192 ${a.suggestion}`});e.push(`### Anti-patterns (avoid these)
|
|
1586
1564
|
${i.join(`
|
|
1587
1565
|
`)}`)}return e.length>0?e.join(`
|
|
1588
1566
|
|
|
1589
|
-
`):null}l(
|
|
1590
|
-
`)}l(
|
|
1591
|
-
`)}l(
|
|
1592
|
-
`)){let a=i.trim();a&&n.add(a)}}catch{}try{let o=t("git diff --cached --name-only",
|
|
1593
|
-
`)){let a=i.trim();a&&n.add(a)}}catch{}try{let o=t("git diff --name-only",
|
|
1594
|
-
`)){let a=i.trim();a&&n.add(a)}}catch{}return[...n]}l(tE,"getFilesModifiedSinceTaskStart");function nE(r){let e=r>=0?"+":"-",t=Math.abs(r);if(t>=60){let n=Math.floor(t/60),s=t%60;return s>0?`${e}${n}h ${s}m`:`${e}${n}h`}return`${e}${t}m`}l(nE,"formatVariance");var gs=class{static{l(this,"PrjctCommands")}workflow;planning;shipping;analytics;performanceCmds;maintenance;analysis;setupCmds;updateCmds;velocityCmds;contextCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new rr,this.planning=new is,this.shipping=new Qs,this.analytics=new Js,this.performanceCmds=new Xs,this.maintenance=new Ks,this.analysis=new ps,this.setupCmds=new Ys,this.updateCmds=new Zs,this.velocityCmds=new er,this.contextCmds=new ms,this.agent=null,this.agentInfo=null,this.currentAuthor=null,this.prjctDir=".prjct"}async task(e=null,t=process.cwd(),n={}){return this.workflow.now(e,t,n)}async done(e=process.cwd(),t={}){return this.workflow.done(e,t)}async next(e=process.cwd(),t={}){return this.workflow.next(e,t)}async pause(e="",t=process.cwd(),n={}){return this.workflow.pause(e,t,n)}async resume(e=null,t=process.cwd(),n={}){return this.workflow.resume(e,t,n)}async workflowPrefs(e=null,t=process.cwd(),n={}){return this.workflow.workflow(e,t,n)}async sessions(e=process.cwd(),t={}){return this.workflow.sessions(e,t)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async bug(e,t=process.cwd(),n={}){return this.planning.bug(e,t,n)}async idea(e,t=process.cwd(),n={}){return this.planning.idea(e,t,n)}async spec(e=null,t=process.cwd()){return this.planning.spec(e,t)}async ship(e,t=process.cwd(),n={}){return this.shipping.ship(e,t,{...n})}async dash(e="default",t=process.cwd(),n={}){return this.analytics.dash(e,t,n)}async help(e="",t=process.cwd()){return this.analytics.help(e,t)}async perf(e="7",t=process.cwd()){return this.performanceCmds.perf(e,t)}async velocity(e="0",t=process.cwd()){return this.velocityCmds.velocity(e,t)}async cleanup(e={},t=process.cwd()){return this.maintenance.cleanup(e,t)}async design(e=null,t={},n=process.cwd()){return this.maintenance.design(e,t,n)}async recover(e=process.cwd()){return this.maintenance.recover(e)}async undo(e=process.cwd()){return this.maintenance.undo(e)}async redo(e=process.cwd()){return this.maintenance.redo(e)}async history(e=process.cwd()){return this.maintenance.history(e)}async analyze(e={},t=process.cwd()){return this.analysis.analyze(e,t)}async sync(e=process.cwd(),t={}){return this.analysis.sync(e,t)}async stats(e=process.cwd(),t={}){return this.analysis.stats(e,t)}async status(e=process.cwd(),t={}){return this.analysis.status(e,t)}async diff(e=process.cwd(),t={}){return this.analysis.diff(e,t)}async seal(e=process.cwd(),t={}){return this.analysis.seal(e,t)}async rollback(e=process.cwd(),t={}){return this.analysis.rollback(e,t)}async verify(e=process.cwd(),t={}){return this.analysis.verify(e,t)}async analysisPayload(e=process.cwd(),t={}){return this.analysis.analysisPayload(e,t)}async saveLlmAnalysis(e,t=process.cwd(),n={}){return this.analysis.saveLlmAnalysis(e,t,n)}async getLlmAnalysis(e=process.cwd(),t={}){return this.analysis.getLlmAnalysis(e,t)}async context(e=null,t=process.cwd()){return this.contextCmds.context(e,t)}async 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,n){return this.workflow.logToMemory(e,t,n)}},QJ=new gs;Oi();var uy={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}},dy=[{name:"init",group:"core",description:"Deep project analysis and initialization",usage:{claude:'/p:init "[idea]"',terminal:'prjct init "[idea]"'},params:"[idea]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0,features:["Architect mode for blank projects","Auto tech stack recommendation","Analyzes existing codebases"]},{name:"idea",group:"core",description:"Transform ideas into complete technical architectures",usage:{claude:'/p:idea "build a CRM"',terminal:'prjct idea "build a CRM"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Simple ideas -> Quick capture","Complex ideas -> Full architecture"]},{name:"task",group:"core",description:"Start task with agentic classification and 7-phase workflow",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Agentic type classification","7-phase workflow","Git branch management","Task breakdown"]},{name:"spec",group:"core",description:"Create detailed specifications for complex features",usage:{claude:'/p:spec "Dark Mode"',terminal:'prjct spec "Dark Mode"'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"pause",group:"core",description:"Pause active task to handle interruption",usage:{claude:'/p:pause ["reason"]',terminal:'prjct pause ["reason"]'},params:"[reason]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,blockingRules:{check:"Active task exists",message:"No active task to pause"}},{name:"resume",group:"core",description:"Resume paused task or recover abandoned session",usage:{claude:"/p:resume",terminal:"prjct resume"},params:"[task_id]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"next",group:"core",description:"Show priority queue or roadmap view",usage:{claude:"/p:next",terminal:"prjct next"},params:"[roadmap]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"done",group:"core",description:"Mark current task as complete",usage:{claude:"/p:done",terminal:"prjct done"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"ship",group:"core",description:"Commit, push, and celebrate shipped feature",usage:{claude:'/p:ship "feature"',terminal:'prjct ship "feature"'},params:"<feature>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"bug",group:"core",description:"Report and track bugs with priority",usage:{claude:'/p:bug "description"',terminal:'prjct bug "description"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"dash",group:"core",description:"Unified dashboard - status, progress, and roadmap",usage:{claude:"/p:dash [view]",terminal:"prjct dash [view]"},params:"[week|month|roadmap|compact]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"stats",group:"core",description:"Value dashboard - token savings, performance, and impact",usage:{claude:"/p:stats",terminal:"prjct stats"},params:"[--json] [--export]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Token savings tracking","Compression metrics","Cost estimates","30-day trends"]},{name:"sync",group:"core",description:"Sync project state and update workflow agents",usage:{claude:"/p:sync",terminal:"prjct sync [--package=<name>] [--full]"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Incremental sync: only re-analyzes changed files (default)","Force full sync: --full bypasses incremental cache","Monorepo support: --package=<name> for single package sync","Nested PRJCT.md inheritance","Per-package CLAUDE.md generation"]},{name:"perf",group:"core",description:"Performance dashboard - startup, memory, context, and handoff metrics",usage:{claude:"/p:perf",terminal:"prjct perf [days]"},params:"[days]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Startup time tracking","Memory usage snapshots","Context correctness rate","Subtask handoff rate","Command duration breakdown"]},{name:"velocity",group:"core",description:"Sprint-based velocity dashboard with trend detection and projections",usage:{claude:"/p:velocity",terminal:"prjct velocity [backlogPoints]"},params:"[backlogPoints]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Sprint-by-sprint velocity breakdown","Trend detection (improving/stable/declining)","Estimation accuracy tracking","Over/under estimation pattern detection","Completion projections for backlog"]},{name:"sessions",group:"core",description:"Show recent sessions across all projects with resume context",usage:{claude:"/p:sessions",terminal:"prjct sessions [--cleanup]"},params:"[--cleanup]",implemented:!0,hasTemplate:!1,requiresProject:!1,requiresLlm:!0,features:["Cross-project session listing","Resume context with LLM hints","Auto-cleanup of stale snapshots"]},{name:"suggest",group:"core",description:"Smart recommendations based on project state",usage:{claude:"/p:suggest",terminal:"prjct suggest"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"status",group:"core",description:"Check if CLAUDE.md context is stale and needs resync",usage:{claude:"/p:status",terminal:"prjct status"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares current HEAD with last sync commit","Counts commits and days since sync","Detects significant file changes","Configurable staleness thresholds"]},{name:"diff",group:"core",description:"Show diff between draft and sealed analysis runs",usage:{claude:"/p:diff",terminal:"prjct diff"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares draft vs sealed analysis field-by-field","Shows languages, frameworks, patterns, file count changes","Markdown and JSON output modes"]},{name:"seal",group:"core",description:"Seal the current draft analysis with a commit-hash signature",usage:{claude:"/p:seal",terminal:"prjct seal"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Locks draft analysis with SHA-256 signature","Only sealed analysis feeds task context","Detects staleness when HEAD moves past sealed commit"]},{name:"rollback",group:"core",description:"Rollback to the previous sealed analysis version",usage:{claude:"/p:rollback",terminal:"prjct rollback"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Restores previous sealed version as active","Current sealed moves to draft (recoverable)","One level of rollback supported"]},{name:"verify",group:"core",description:"Verify integrity of sealed analysis",usage:{claude:"/p:verify",terminal:"prjct verify"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Recomputes SHA-256 signature and compares","Detects if sealed analysis was modified"]},{name:"help",group:"core",description:"Contextual help and guidance",usage:{claude:"/p:help [topic]",terminal:"prjct help [topic]"},params:"[topic]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"design",group:"optional",description:"Design system architecture, APIs, and components",usage:{claude:"/p:design [target]",terminal:"prjct design [target]"},params:"[target] --type architecture|api|component",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"cleanup",group:"optional",description:"Clean up temp files and old entries",usage:{claude:"/p:cleanup",terminal:"prjct cleanup"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"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:"undo",group:"optional",description:"Revert to previous snapshot",usage:{claude:"/p:undo",terminal:"prjct undo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Git-based snapshots","Preserves redo history"]},{name:"redo",group:"optional",description:"Redo previously undone changes",usage:{claude:"/p:redo",terminal:"prjct redo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"history",group:"optional",description:"View snapshot history",usage:{claude:"/p:history",terminal:"prjct history"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"recover",group:"optional",description:"Recover abandoned session with context",usage:{claude:"/p:recover",terminal:"prjct recover"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"git",group:"optional",description:"Smart git operations with context",usage:{claude:"/p:git [op]",terminal:"prjct git [op]"},params:"[operation]",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"test",group:"optional",description:"Run tests with auto-fix",usage:{claude:"/p:test",terminal:"prjct test"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"workflow",group:"optional",description:"Configure workflow hooks via natural language",usage:{claude:'/p:workflow ["config"]',terminal:'prjct workflow ["config"]'},params:'["natural language config"]',implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Natural language configuration","Before/after hooks for task, done, ship, sync","Permanent, session, or one-time preferences"]},{name:"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:"auth",group:"setup",description:"Manage cloud authentication",usage:{claude:"/p:auth [action]",terminal:"prjct auth [action]"},params:"[login|logout|status]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0},{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"]}];Mi();dn();Pe();F();Ue();ut();import{execSync as ya}from"node:child_process";import Pt from"node:fs/promises";import sE from"node:os";import wn from"node:path";import rE from"node:readline";import Te from"chalk";var wa="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",io="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";async function my(r){let e=0;try{let t=await Pt.readdir(r,{withFileTypes:!0});for(let n of t){let s=wn.join(r,n.name);if(n.isDirectory())e+=await my(s);else try{let o=await Pt.stat(s);e+=o.size}catch{}}}catch{}return e}l(my,"getDirectorySize");function py(r){if(r===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));return`${(r/1024**t).toFixed(1)} ${e[t]}`}l(py,"formatSize");async function oE(r){try{return(await Pt.readdir(r,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}l(oE,"countDirectoryItems");function iE(){let r={homebrew:!1,npm:!1};try{ya("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(r.homebrew=!0,r.homebrewFormula="prjct-cli")}catch{}try{ya("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(r.npm=!0)}catch{}return r}l(iE,"detectInstallation");async function aE(){let r=[],e=vp(),t=A.getGlobalBasePath(),n=await D(t),s=n?await oE(wn.join(t,"projects")):0,o=n?await my(t):0;r.push({path:t,type:"directory",description:`All project data${s>0?`, ${s} project${s>1?"s":""}`:""}`,size:o,count:s,exists:n});let i=wn.join(e.claude.config,"CLAUDE.md"),a=await D(i),c=!1;if(a)try{let E=await Pt.readFile(i,"utf-8");c=E.includes(wa)&&E.includes(io)}catch{}r.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&c});let u=e.claude.router,d=await D(u);r.push({path:u,type:"file",description:"Claude router",exists:d});let m=wn.join(e.claude.config,"prjct-statusline.sh"),p=await D(m);r.push({path:m,type:"file",description:"Status line script",exists:p});let g=e.gemini.router,f=await D(g);r.push({path:g,type:"file",description:"Gemini router",exists:f});let S=wn.join(e.gemini.config,"GEMINI.md"),y=await D(S),C=!1;if(y)try{let E=await Pt.readFile(S,"utf-8");C=E.includes(wa)&&E.includes(io)}catch{}return y&&C&&r.push({path:S,type:"section",description:"prjct section in GEMINI.md",exists:!0}),r}l(aE,"gatherUninstallItems");async function cE(r){try{let e=await Pt.readFile(r,"utf-8");if(!e.includes(wa)||!e.includes(io))return!1;let t=e.indexOf(wa),n=e.indexOf(io)+io.length,s=e.substring(0,t)+e.substring(n);return s=s.replace(/\n{3,}/g,`
|
|
1595
|
-
|
|
1596
|
-
`).trim(),!
|
|
1597
|
-
`,"utf-8"),!0}catch{return!1}}l(
|
|
1598
|
-
No prjct installation found.`)),{success:!0,message:"Nothing to uninstall"};let o=
|
|
1599
|
-
Uninstall cancelled.`)),{success:!1,message:"Uninstall cancelled by user"};console.log(""),console.log(
|
|
1600
|
-
${a.length} errors:`));for(let c of a)console.log(Te.red(` - ${c}`))}return console.log(""),console.log(Te.green("prjct has been uninstalled.")),console.log(Te.dim("Thanks for using prjct! We hope to see you again.")),console.log(""),{success:a.length===0,message:`Removed ${i.length} items`,deleted:i,errors:a.length>0?a:void 0}}l(pE,"uninstall");var Sa=class extends xe{static{l(this,"UninstallCommands")}async uninstall(e={},t=process.cwd()){return pE(e,t)}};var fs=new rr,ka=new is,mE=new Qs,fy=new Js,gE=new Xs,or=new Ks,ir=new ps,hy=new Ys,fE=new ms,hE=new er,yE=new Sa,wE=new Zs;function SE(){for(let[r,e]of Object.entries(uy))B.registerCategory(r,e)}l(SE,"registerCategories");function yy(){if(B.has("work"))return;SE();let r=l(e=>dy.find(t=>t.name===e),"getMeta");B.registerMethod("task",fs,"now",r("task")),B.registerMethod("done",fs,"done",r("done")),B.registerMethod("next",fs,"next",r("next")),B.registerMethod("pause",fs,"pause",r("pause")),B.registerMethod("resume",fs,"resume",r("resume")),B.registerMethod("workflow",fs,"workflow",r("workflow")),B.registerMethod("sessions",fs,"sessions",r("sessions")),B.registerMethod("init",ka,"init",r("init")),B.registerMethod("bug",ka,"bug",r("bug")),B.registerMethod("idea",ka,"idea",r("idea")),B.registerMethod("spec",ka,"spec",r("spec")),B.registerMethod("ship",mE,"ship",r("ship")),B.registerMethod("dash",fy,"dash",r("dash")),B.registerMethod("help",fy,"help",r("help")),B.registerMethod("perf",gE,"perf",r("perf")),B.registerMethod("velocity",hE,"velocity",r("velocity")),B.registerMethod("cleanup",or,"cleanup",r("cleanup")),B.registerMethod("design",or,"design",r("design")),B.registerMethod("recover",or,"recover",r("recover")),B.registerMethod("undo",or,"undo",r("undo")),B.registerMethod("redo",or,"redo",r("redo")),B.registerMethod("history",or,"history",r("history")),B.registerMethod("analyze",ir,"analyze",r("analyze")),B.registerMethod("sync",ir,"sync",r("sync")),B.registerMethod("stats",ir,"stats",r("stats")),B.registerMethod("status",ir,"status",r("status")),B.registerMethod("seal",ir,"seal",r("seal")),B.registerMethod("verify",ir,"verify",r("verify")),B.registerMethod("start",hy,"start",r("start")),B.registerMethod("setup",hy,"setup",r("setup")),B.registerMethod("uninstall",yE,"uninstall",r("uninstall")),B.registerMethod("update",wE,"update",r("update")),B.registerMethod("context",fE,"context",r("context"))}l(yy,"registerAllCommands");yy();xt();Fa();jt();import{Hono as RE}from"hono";import{cors as DE}from"hono/cors";import{logger as jE}from"hono/logger";Pe();se();Or();Ms();Fr();Os();F();Dn();import kE from"node:fs/promises";import bE from"node:path";import{Hono as vE}from"hono";function PE(r){return A.getGlobalProjectPath(r)}l(PE,"getProjectDataPath");function wy(r,e){let t=new vE,n=PE(r);return t.get("/state",async s=>{let o=await L.read(r);return s.json(o)}),t.get("/queue",async s=>{let o=await ke.read(r);return s.json(o)}),t.get("/ideas",async s=>{let o=await tt.read(r);return s.json(o)}),t.get("/roadmap",async s=>{let o=T.getDoc(r,"roadmap");return o?s.json(o):s.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async s=>{let o=await St.read(r);return s.json(o)}),t.get("/dashboard",async s=>{let[o,i,a,c]=await Promise.all([L.read(r),ke.read(r),tt.read(r),St.read(r)]),u=T.getDoc(r,"roadmap");return s.json({projectId:r,state:o,queue:i,ideas:a,roadmap:u||{features:[],backlog:[],lastUpdated:""},shipped:c,timestamp:new Date().toISOString()})}),t.post("/state",async s=>{try{let o=await s.req.json();return await L.write(r,o),s.json({success:!0})}catch(o){return s.json({success:!1,error:String(o)},400)}}),t.get("/context/:name",async s=>{let o=s.req.param("name");if(!["now","next","ideas","shipped"].includes(o))return s.json({error:"Invalid context file"},400);try{let a=bE.join(n,"context",`${o}.md`),c=await kE.readFile(a,"utf-8");return s.text(c,200,{"Content-Type":"text/markdown"})}catch(a){return P(a)||H.error(`Context read error: ${w(a)}`),s.text("",200,{"Content-Type":"text/markdown"})}}),t}l(wy,"createRoutes");Pe();se();Or();Ms();Fr();Os();import ar from"node:fs/promises";import CE from"node:path";import{Hono as xE}from"hono";var TE=A.getGlobalBasePath(),cr=CE.join(TE,"projects");function ba(r){return T.getDoc(r,"project")}l(ba,"getProjectConfig");async function od(r){if(!r)return"";let e=new Date(r),n=new Date().getTime()-e.getTime(),s=Math.floor(n/(1e3*60*60)),o=Math.floor(n%(1e3*60*60)/(1e3*60));return s>0?`${s}h ${o}m`:`${o}m`}l(od,"calculateDuration");function Sy(){let r=new xE;return r.get("/projects",async e=>{try{await ar.mkdir(cr,{recursive:!0});let n=(await ar.readdir(cr,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),s=await Promise.all(n.map(async o=>{let i=ba(o),a=await L.read(o),c=await ke.read(o),u=await tt.read(o),d=await St.read(o),m=a?.currentTask,p=await od(m?.startedAt);return{id:o,name:i?.name||o.slice(0,8),path:i?.path||null,currentTask:m?{...m,duration:p}:null,pausedTask:a?.previousTask||null,stats:{queueCount:c?.tasks?.filter(g=>!g.completed)?.length||0,ideasCount:u?.ideas?.filter(g=>g.status==="pending")?.length||0,shippedCount:d?.shipped?.length||0}}}));return s.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:(o.name||"").localeCompare(i.name||"")),e.json({projects:s})}catch(t){return e.json({projects:[],error:String(t)},500)}}),r.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[n,s,o,i,a]=await Promise.all([Promise.resolve(ba(t)),L.read(t),ke.read(t),tt.read(t),St.read(t)]),c=T.getDoc(t,"roadmap");s?.currentTask?.startedAt&&(s.currentTask.duration=await od(s.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(f=>!f.completed||!f.completedAt?!1:new Date(f.completedAt)>=d)?.length||0,g=o?.tasks?.filter(f=>!f.completed||!f.completedAt?!1:new Date(f.completedAt)>=m)?.length||0;return e.json({id:t,name:n?.name||t,path:n?.path,state:s||{currentTask:null,previousTask:null,lastUpdated:""},queue:o||{tasks:[],lastUpdated:""},ideas:i||{ideas:[],lastUpdated:""},shipped:a||{shipped:[],lastUpdated:""},roadmap:c||{features:[],backlog:[],lastUpdated:""},stats:{tasksToday:p,tasksThisWeek:g,queueCount:o?.tasks?.filter(f=>!f.completed)?.length||0,ideasCount:i?.ideas?.filter(f=>f.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch(n){return e.json({error:String(n)},500)}}),r.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let n=await L.read(t);if(!n?.currentTask)return e.json({success:!1,error:"No active task"},400);let s=n.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await L.write(t,o),e.json({success:!0,completedTask:s,message:`Completed: ${s.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),r.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let s=(await e.req.json().catch(()=>({}))).reason,o=await L.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:s},a={currentTask:null,previousTask:i,lastUpdated:new Date().toISOString()};return await L.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),r.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let n=await L.read(t);if(!n?.previousTask)return e.json({success:!1,error:"No paused task"},400);let s={id:n.previousTask.id,description:n.previousTask.description,status:"active",startedAt:new Date().toISOString(),sessionId:`sess_${Date.now().toString(36)}`},o={currentTask:s,previousTask:null,lastUpdated:new Date().toISOString()};return await L.write(t,o),e.json({success:!0,resumedTask:s,message:`Resumed: ${s.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),r.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let n=await e.req.json(),{taskId:s}=n;if(!s)return e.json({success:!1,error:"taskId required"},400);let[o,i]=await Promise.all([L.read(t),ke.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===s);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 L.write(t,u),e.json({success:!0,task:c,message:`Started: ${c.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),r.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let n=await e.req.json(),{text:s,priority:o="medium",tags:i=[]}=n;if(!s)return e.json({success:!1,error:"text required"},400);let a=await tt.addIdea(t,s,{priority:o||"medium",tags:i});return e.json({success:!0,idea:a,message:`Captured: ${s.slice(0,50)}...`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),r.get("/stats/global",async e=>{try{await ar.mkdir(cr,{recursive:!0});let n=(await ar.readdir(cr,{withFileTypes:!0})).filter(c=>c.isDirectory()).map(c=>c.name),s=0,o=0,i=0,a=0;for(let c of n){let u=await L.read(c),d=await ke.read(c),m=await tt.read(c),p=await St.read(c);u?.currentTask&&a++,s+=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:n.length,activeProjects:a,totalTasks:s,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),r.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await ar.mkdir(cr,{recursive:!0});let s=(await ar.readdir(cr,{withFileTypes:!0})).filter(d=>d.isDirectory()).map(d=>d.name),o=null;if(t)for(let d of s){let m=ba(d),p=m?.repoPath||m?.path;if(p&&t.startsWith(p)){o=d;break}}let i=null,a=null,c=null,u=o?[o]:s;for(let d of u){let m=await L.read(d),p=ba(d);if(m?.currentTask){i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},a={...m.currentTask,duration:await od(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:s.length,filtered:!!o,cwd:t||null,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),r}l(Sy,"createExtendedRoutes");Ta();import{streamSSE as EE}from"hono/streaming";var ky=3600*1e3,AE=300*1e3,IE=3e4;function by(){let r=new Map,e=null;function t(o){let i=r.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),r.delete(o))}l(t,"removeClient");function n(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of r)o-new Date(a.client.connectedAt).getTime()>ky&&t(i)},AE),e&&typeof e=="object"&&"unref"in e&&e.unref())}l(n,"startReaper");function s(){e&&(clearInterval(e),e=null)}return l(s,"stopReaper"),n(),{handleConnection(o){return EE(o,async i=>{let a=crypto.randomUUID(),c=new Date().toISOString(),u=new AbortController,d={id:a,connectedAt:c,send:l((g,f)=>{i.writeSSE({event:g,data:JSON.stringify(f)})},"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)}},IE),p=setTimeout(()=>{t(a)},ky);typeof m=="object"&&"unref"in m&&m.unref(),typeof p=="object"&&"unref"in p&&p.unref(),r.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 r)try{u.client.send(o,a)}catch{t(c)}},getClientCount(){return r.size},shutdown(){s();for(let o of[...r.keys()])t(o)}}}l(by,"createSSEManager");function vy(r){let e=new RE,t=by();r.enableCors!==!1&&e.use("*",DE({origin:"*",allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type","Authorization"]})),r.enableLogging!==!1&&e.use("*",jE()),e.get("/health",i=>i.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/",i=>i.json({name:"prjct-cli",version:De,projectId:r.projectId,endpoints:{health:"/health",state:"/api/state",queue:"/api/queue",ideas:"/api/ideas",roadmap:"/api/roadmap",shipped:"/api/shipped",events:"/api/events",projects:"/api/projects",projectFull:"/api/projects/:id/full",statusBarCompact:"/api/status-bar/compact",globalStats:"/api/stats/global"}}));let n=wy(r.projectId,r.projectPath);e.route("/api",n);let s=Sy();e.route("/api",s),e.get("/api/events",i=>t.handleConnection(i));let o=null;return{app:e,async start(){let i=r.port,a=r.host||"0.0.0.0";if(hr())o=Bun.serve({port:i,hostname:a,fetch:e.fetch});else{let{serve:c}=await import("@hono/node-server"),u=c({fetch:e.fetch,port:i,hostname:a});o={stop:l(()=>u.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${a}:${i}`),console.log(` Project: ${r.projectId}`),console.log(` Runtime: ${hr()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${i}`)},stop(){t.shutdown(),o&&(o.stop(),o=null,console.log("Server stopped"))},broadcast(i,a){t.broadcast(i,a)}}}l(vy,"createServer");var Py=3478;Yu();var lr=null,ao=null,we=null,Re=null;async function Cy(r){let e=ze.socket(),t=ze.pid(),n=ze.runDir();if(Qe.mkdirSync(n,{recursive:!0}),Qe.existsSync(t)){let i=parseInt(Qe.readFileSync(t,"utf-8").trim(),10);NE(i)&&(console.error(`Daemon already running (PID ${i})`),process.exit(1)),Qe.unlinkSync(t)}Qe.existsSync(e)&&Qe.unlinkSync(e);let s=LE(),o=null;if(s)try{o=Qe.statSync(s).mtimeMs}catch{}if(Re={startedAt:Date.now(),commandsServed:0,lastActivity:Date.now(),idleTimeoutMs:Qh,idleTimer:null,entryPath:s,entryMtime:o},we=new gs,lr=$E(i=>ME(i)),lr.listen(e,()=>{Qe.chmodSync(e,384),Qe.writeFileSync(t,String(process.pid)),console.log(`prjct daemon started (PID ${process.pid})`),console.log(` Socket: ${e}`),s&&console.log(` Watching: ${s}`),xy()}),lr.on("error",i=>{console.error("Daemon socket error:",i.message),ur(1)}),!r.noHttp)try{let i=process.cwd(),a=await M.getProjectId(i);if(a){let c=r.port||Py;ao=vy({port:c,projectId:a,projectPath:i,enableLogging:!1}),await ao.start()}}catch{}if(process.on("SIGTERM",()=>ur(0)),process.on("SIGINT",()=>ur(0)),process.on("SIGHUP",()=>{we=new gs,console.log("Daemon reloaded (SIGHUP)")}),!r.foreground)try{process.stdin?.unref?.()}catch{}}l(Cy,"startDaemon");function ME(r){let e="";r.on("data",async t=>{e+=t.toString();let n;for(;(n=e.indexOf(`
|
|
1601
|
-
`))!==-1;){let
|
|
1567
|
+
`):null}l(RT,"buildPatterns");function DT(s,e,t){let n=e.slice(0,4).map(c=>`\`${c.path}\``),r=(t?.patterns||[]).slice(0,3).map(c=>c.name),o=l(c=>c==="high"?0:c==="medium"?1:2,"severityWeight"),i=(t?.antiPatterns||[]).sort((c,u)=>o(c.severity)-o(u.severity)).slice(0,3).map(c=>`${c.issue} (${c.file})`);return["### Context Contract",`- Goal: ${s}`,`- Key files: ${n.length>0?n.join(", "):"Run `prjct sync` to improve file targeting"}`,`- Patterns: ${r.length>0?r.join(" | "):"No patterns yet (run `prjct sync`)"}`,`- Must avoid: ${i.length>0?i.join(" | "):"No anti-patterns yet (run `prjct sync`)"}`,"- Do now: confirm approach, follow patterns, avoid anti-patterns before editing"].join(`
|
|
1568
|
+
`)}l(DT,"buildContextContract");function jT(s,e){let t=e.filter(p=>p.type==="gate"&&p.position==="before"),n=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,f)=>{let S=g.map(_=>` ${_.enabled?f:"o"} #${_.id} ${_.action}`),w=[p,...S],T=Math.max(...w.map(_=>_.length))+2;u.push(`+${"-".repeat(T)}+`);for(let _ of w)u.push(`| ${_.padEnd(T-1)}|`);u.push(`+${"-".repeat(T)}+`)},"drawBox"),m=l(p=>{p.push(" |"),p.push(" v")},"arrow");return t.length>0&&(d("GATES (must pass)",t,"#"),m(u)),n.length>0&&(d("INSTRUCTIONS (before)",n,"\u{1F4CB}"),m(u)),r.length>0&&(d("HOOKS (before)",r,">"),m(u)),o.length>0&&(d("STEPS (before)",o,">"),m(u)),u.push(` [ ${s.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(`
|
|
1569
|
+
`)}l(jT,"buildFlowDiagram");async function IT(s,e){let{execSync:t}=await import("node:child_process"),n=new Set,r={cwd:s,encoding:"utf-8"};try{let o=t(`git log --since="${e}" --name-only --pretty=format:""`,r);for(let i of o.split(`
|
|
1570
|
+
`)){let a=i.trim();a&&n.add(a)}}catch{}try{let o=t("git diff --cached --name-only",r);for(let i of o.split(`
|
|
1571
|
+
`)){let a=i.trim();a&&n.add(a)}}catch{}try{let o=t("git diff --name-only",r);for(let i of o.split(`
|
|
1572
|
+
`)){let a=i.trim();a&&n.add(a)}}catch{}return[...n]}l(IT,"getFilesModifiedSinceTaskStart");function $T(s){let e=s>=0?"+":"-",t=Math.abs(s);if(t>=60){let n=Math.floor(t/60),r=t%60;return r>0?`${e}${n}h ${r}m`:`${e}${n}h`}return`${e}${t}m`}l($T,"formatVariance");var us=class{static{l(this,"PrjctCommands")}workflow;planning;shipping;analytics;performanceCmds;maintenance;analysis;setupCmds;updateCmds;velocityCmds;contextCmds;agent;agentInfo;currentAuthor;prjctDir;constructor(){this.workflow=new er,this.planning=new ns,this.shipping=new Xs,this.analytics=new Vs,this.performanceCmds=new qs,this.maintenance=new Js,this.analysis=new cs,this.setupCmds=new Ks,this.updateCmds=new Ys,this.velocityCmds=new Qs,this.contextCmds=new ls,this.agent=null,this.agentInfo=null,this.currentAuthor=null,this.prjctDir=".prjct"}async task(e=null,t=process.cwd(),n={}){return this.workflow.now(e,t,n)}async done(e=process.cwd(),t={}){return this.workflow.done(e,t)}async next(e=process.cwd(),t={}){return this.workflow.next(e,t)}async pause(e="",t=process.cwd(),n={}){return this.workflow.pause(e,t,n)}async resume(e=null,t=process.cwd(),n={}){return this.workflow.resume(e,t,n)}async workflowPrefs(e=null,t=process.cwd(),n={}){return this.workflow.workflow(e,t,n)}async sessions(e=process.cwd(),t={}){return this.workflow.sessions(e,t)}async init(e=null,t=process.cwd()){return this.planning.init(e,t)}async bug(e,t=process.cwd(),n={}){return this.planning.bug(e,t,n)}async idea(e,t=process.cwd(),n={}){return this.planning.idea(e,t,n)}async spec(e=null,t=process.cwd()){return this.planning.spec(e,t)}async ship(e,t=process.cwd(),n={}){return this.shipping.ship(e,t,{...n})}async dash(e="default",t=process.cwd(),n={}){return this.analytics.dash(e,t,n)}async help(e="",t=process.cwd()){return this.analytics.help(e,t)}async perf(e="7",t=process.cwd()){return this.performanceCmds.perf(e,t)}async velocity(e="0",t=process.cwd()){return this.velocityCmds.velocity(e,t)}async cleanup(e={},t=process.cwd()){return this.maintenance.cleanup(e,t)}async design(e=null,t={},n=process.cwd()){return this.maintenance.design(e,t,n)}async recover(e=process.cwd()){return this.maintenance.recover(e)}async undo(e=process.cwd()){return this.maintenance.undo(e)}async redo(e=process.cwd()){return this.maintenance.redo(e)}async history(e=process.cwd()){return this.maintenance.history(e)}async enrich(e=null,t=process.cwd(),n={}){return this.maintenance.enrich(e,t,n)}async analyze(e={},t=process.cwd()){return this.analysis.analyze(e,t)}async sync(e=process.cwd(),t={}){return this.analysis.sync(e,t)}async stats(e=process.cwd(),t={}){return this.analysis.stats(e,t)}async status(e=process.cwd(),t={}){return this.analysis.status(e,t)}async diff(e=process.cwd(),t={}){return this.analysis.diff(e,t)}async seal(e=process.cwd(),t={}){return this.analysis.seal(e,t)}async rollback(e=process.cwd(),t={}){return this.analysis.rollback(e,t)}async verify(e=process.cwd(),t={}){return this.analysis.verify(e,t)}async analysisPayload(e=process.cwd(),t={}){return this.analysis.analysisPayload(e,t)}async saveLlmAnalysis(e,t=process.cwd(),n={}){return this.analysis.saveLlmAnalysis(e,t,n)}async getLlmAnalysis(e=process.cwd(),t={}){return this.analysis.getLlmAnalysis(e,t)}async context(e=null,t=process.cwd()){return this.contextCmds.context(e,t)}async 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,n){return this.workflow.logToMemory(e,t,n)}},eJ=new us;Di();var Qh={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}},Zh=[{name:"init",group:"core",description:"Deep project analysis and initialization",usage:{claude:'/p:init "[idea]"',terminal:'prjct init "[idea]"'},params:"[idea]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0,features:["Architect mode for blank projects","Auto tech stack recommendation","Analyzes existing codebases"]},{name:"idea",group:"core",description:"Transform ideas into complete technical architectures",usage:{claude:'/p:idea "build a CRM"',terminal:'prjct idea "build a CRM"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Simple ideas -> Quick capture","Complex ideas -> Full architecture"]},{name:"task",group:"core",description:"Start task with agentic classification and 7-phase workflow",usage:{claude:'/p:task "<description>"',terminal:'prjct task "<description>"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Agentic type classification","7-phase workflow","Git branch management","Task breakdown"]},{name:"spec",group:"core",description:"Create detailed specifications for complex features",usage:{claude:'/p:spec "Dark Mode"',terminal:'prjct spec "Dark Mode"'},params:"[feature]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"pause",group:"core",description:"Pause active task to handle interruption",usage:{claude:'/p:pause ["reason"]',terminal:'prjct pause ["reason"]'},params:"[reason]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,blockingRules:{check:"Active task exists",message:"No active task to pause"}},{name:"resume",group:"core",description:"Resume paused task or recover abandoned session",usage:{claude:"/p:resume",terminal:"prjct resume"},params:"[task_id]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"next",group:"core",description:"Show priority queue or roadmap view",usage:{claude:"/p:next",terminal:"prjct next"},params:"[roadmap]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"done",group:"core",description:"Mark current task as complete",usage:{claude:"/p:done",terminal:"prjct done"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"ship",group:"core",description:"Commit, push, and celebrate shipped feature",usage:{claude:'/p:ship "feature"',terminal:'prjct ship "feature"'},params:"<feature>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"bug",group:"core",description:"Report and track bugs with priority",usage:{claude:'/p:bug "description"',terminal:'prjct bug "description"'},params:"<description>",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"dash",group:"core",description:"Unified dashboard - status, progress, and roadmap",usage:{claude:"/p:dash [view]",terminal:"prjct dash [view]"},params:"[week|month|roadmap|compact]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"stats",group:"core",description:"Value dashboard - token savings, performance, and impact",usage:{claude:"/p:stats",terminal:"prjct stats"},params:"[--json] [--export]",implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Token savings tracking","Compression metrics","Cost estimates","30-day trends"]},{name:"sync",group:"core",description:"Sync project state and update workflow agents",usage:{claude:"/p:sync",terminal:"prjct sync [--package=<name>] [--full]"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0,features:["Incremental sync: only re-analyzes changed files (default)","Force full sync: --full bypasses incremental cache","Monorepo support: --package=<name> for single package sync","Nested PRJCT.md inheritance","Per-package CLAUDE.md generation"]},{name:"perf",group:"core",description:"Performance dashboard - startup, memory, context, and handoff metrics",usage:{claude:"/p:perf",terminal:"prjct perf [days]"},params:"[days]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Startup time tracking","Memory usage snapshots","Context correctness rate","Subtask handoff rate","Command duration breakdown"]},{name:"velocity",group:"core",description:"Sprint-based velocity dashboard with trend detection and projections",usage:{claude:"/p:velocity",terminal:"prjct velocity [backlogPoints]"},params:"[backlogPoints]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Sprint-by-sprint velocity breakdown","Trend detection (improving/stable/declining)","Estimation accuracy tracking","Over/under estimation pattern detection","Completion projections for backlog"]},{name:"sessions",group:"core",description:"Show recent sessions across all projects with resume context",usage:{claude:"/p:sessions",terminal:"prjct sessions [--cleanup]"},params:"[--cleanup]",implemented:!0,hasTemplate:!1,requiresProject:!1,requiresLlm:!0,features:["Cross-project session listing","Resume context with LLM hints","Auto-cleanup of stale snapshots"]},{name:"suggest",group:"core",description:"Smart recommendations based on project state",usage:{claude:"/p:suggest",terminal:"prjct suggest"},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"status",group:"core",description:"Check if CLAUDE.md context is stale and needs resync",usage:{claude:"/p:status",terminal:"prjct status"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares current HEAD with last sync commit","Counts commits and days since sync","Detects significant file changes","Configurable staleness thresholds"]},{name:"diff",group:"core",description:"Show diff between draft and sealed analysis runs",usage:{claude:"/p:diff",terminal:"prjct diff"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Compares draft vs sealed analysis field-by-field","Shows languages, frameworks, patterns, file count changes","Markdown and JSON output modes"]},{name:"seal",group:"core",description:"Seal the current draft analysis with a commit-hash signature",usage:{claude:"/p:seal",terminal:"prjct seal"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Locks draft analysis with SHA-256 signature","Only sealed analysis feeds task context","Detects staleness when HEAD moves past sealed commit"]},{name:"rollback",group:"core",description:"Rollback to the previous sealed analysis version",usage:{claude:"/p:rollback",terminal:"prjct rollback"},params:"[--json] [--md]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Restores previous sealed version as active","Current sealed moves to draft (recoverable)","One level of rollback supported"]},{name:"verify",group:"core",description:"Verify integrity of sealed analysis",usage:{claude:"/p:verify",terminal:"prjct verify"},params:"[--json]",implemented:!0,hasTemplate:!1,requiresProject:!0,requiresLlm:!0,features:["Recomputes SHA-256 signature and compares","Detects if sealed analysis was modified"]},{name:"help",group:"core",description:"Contextual help and guidance",usage:{claude:"/p:help [topic]",terminal:"prjct help [topic]"},params:"[topic]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"design",group:"optional",description:"Design system architecture, APIs, and components",usage:{claude:"/p:design [target]",terminal:"prjct design [target]"},params:"[target] --type architecture|api|component",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"cleanup",group:"optional",description:"Clean up temp files and old entries",usage:{claude:"/p:cleanup",terminal:"prjct cleanup"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"analyze",group:"optional",description:"Analyze repository and sync tasks",usage:{claude:"/p:analyze",terminal:"prjct analyze"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"enrich",group:"optional",description:"Build enrichment context for an issue or request",usage:{claude:'/p:enrich "<issue-or-description>"',terminal:'prjct enrich "<input>"'},params:"<issue_or_description>",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"undo",group:"optional",description:"Revert to previous snapshot",usage:{claude:"/p:undo",terminal:"prjct undo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Git-based snapshots","Preserves redo history"]},{name:"redo",group:"optional",description:"Redo previously undone changes",usage:{claude:"/p:redo",terminal:"prjct redo"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"history",group:"optional",description:"View snapshot history",usage:{claude:"/p:history",terminal:"prjct history"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"recover",group:"optional",description:"Recover abandoned session with context",usage:{claude:"/p:recover",terminal:"prjct recover"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"git",group:"optional",description:"Smart git operations with context",usage:{claude:"/p:git [op]",terminal:"prjct git [op]"},params:"[operation]",implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"test",group:"optional",description:"Run tests with auto-fix",usage:{claude:"/p:test",terminal:"prjct test"},implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0},{name:"workflow",group:"optional",description:"Configure workflow hooks via natural language",usage:{claude:'/p:workflow ["config"]',terminal:'prjct workflow ["config"]'},params:'["natural language config"]',implemented:!0,hasTemplate:!0,requiresProject:!0,isOptional:!0,requiresLlm:!0,features:["Natural language configuration","Before/after hooks for task, done, ship, sync","Permanent, session, or one-time preferences"]},{name:"linear",group:"optional",description:"Linear integration via MCP (setup/status + delegated operations)",usage:{claude:"/p:linear [command]",terminal:"prjct linear [command]"},params:"[setup|status|sync|list|get|create|update|start|done|comment|teams|projects]",implemented:!0,hasTemplate:!0,requiresProject:!1,isOptional:!0,requiresLlm:!0},{name:"jira",group:"optional",description:"Jira integration via MCP (setup/status + delegated operations)",usage:{claude:"/p:jira [command]",terminal:"prjct jira [command]"},params:"[setup|status|sync|list|get|create|update|start|done|transition|comment|projects|boards]",implemented:!0,hasTemplate:!0,requiresProject:!1,isOptional:!0,requiresLlm:!0},{name:"start",group:"setup",description:"First-time setup (install commands to editors)",usage:{claude:null,terminal:"prjct start"},implemented:!0,hasTemplate:!1,requiresProject:!1},{name:"setup",group:"setup",description:"Reconfigure editor installations",usage:{claude:"/p:setup",terminal:"prjct setup"},params:"[--force] [--editor <name>]",implemented:!0,hasTemplate:!0,requiresProject:!1},{name:"migrate",group:"setup",description:"Migrate project to UUID format + sync",usage:{claude:"/p:migrate",terminal:null},implemented:!0,hasTemplate:!0,requiresProject:!0,requiresLlm:!0},{name:"auth",group:"setup",description:"Manage cloud authentication",usage:{claude:"/p:auth [action]",terminal:"prjct auth [action]"},params:"[login|logout|status]",implemented:!0,hasTemplate:!0,requiresProject:!1,requiresLlm:!0},{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"]}];Ri();on();ve();L();We();lt();import{execSync as ia}from"node:child_process";import bt from"node:fs/promises";import MT from"node:os";import gn from"node:path";import OT from"node:readline";import xe from"chalk";var aa="<!-- prjct:start - DO NOT REMOVE THIS MARKER -->",so="<!-- prjct:end - DO NOT REMOVE THIS MARKER -->";async function ty(s){let e=0;try{let t=await bt.readdir(s,{withFileTypes:!0});for(let n of t){let r=gn.join(s,n.name);if(n.isDirectory())e+=await ty(r);else try{let o=await bt.stat(r);e+=o.size}catch{}}}catch{}return e}l(ty,"getDirectorySize");function ey(s){if(s===0)return"0 B";let e=["B","KB","MB","GB"],t=Math.floor(Math.log(s)/Math.log(1024));return`${(s/1024**t).toFixed(1)} ${e[t]}`}l(ey,"formatSize");async function FT(s){try{return(await bt.readdir(s,{withFileTypes:!0})).filter(t=>t.isDirectory()).length}catch{return 0}}l(FT,"countDirectoryItems");function _T(){let s={homebrew:!1,npm:!1};try{ia("brew list prjct-cli 2>/dev/null",{encoding:"utf-8"})&&(s.homebrew=!0,s.homebrewFormula="prjct-cli")}catch{}try{ia("npm list -g prjct-cli --depth=0 2>/dev/null",{encoding:"utf-8"}).includes("prjct-cli")&&(s.npm=!0)}catch{}return s}l(_T,"detectInstallation");async function NT(){let s=[],e=dp(),t=A.getGlobalBasePath(),n=await j(t),r=n?await FT(gn.join(t,"projects")):0,o=n?await ty(t):0;s.push({path:t,type:"directory",description:`All project data${r>0?`, ${r} project${r>1?"s":""}`:""}`,size:o,count:r,exists:n});let i=gn.join(e.claude.config,"CLAUDE.md"),a=await j(i),c=!1;if(a)try{let T=await bt.readFile(i,"utf-8");c=T.includes(aa)&&T.includes(so)}catch{}s.push({path:i,type:"section",description:"prjct section in CLAUDE.md",exists:a&&c});let u=e.claude.router,d=await j(u);s.push({path:u,type:"file",description:"Claude router",exists:d});let m=gn.join(e.claude.config,"prjct-statusline.sh"),p=await j(m);s.push({path:m,type:"file",description:"Status line script",exists:p});let g=e.gemini.router,f=await j(g);s.push({path:g,type:"file",description:"Gemini router",exists:f});let S=gn.join(e.gemini.config,"GEMINI.md"),w=await j(S),v=!1;if(w)try{let T=await bt.readFile(S,"utf-8");v=T.includes(aa)&&T.includes(so)}catch{}return w&&v&&s.push({path:S,type:"section",description:"prjct section in GEMINI.md",exists:!0}),s}l(NT,"gatherUninstallItems");async function LT(s){try{let e=await bt.readFile(s,"utf-8");if(!e.includes(aa)||!e.includes(so))return!1;let t=e.indexOf(aa),n=e.indexOf(so)+so.length,r=e.substring(0,t)+e.substring(n);return r=r.replace(/\n{3,}/g,`
|
|
1573
|
+
|
|
1574
|
+
`).trim(),!r||r.trim().length===0?await bt.unlink(s):await bt.writeFile(s,`${r}
|
|
1575
|
+
`,"utf-8"),!0}catch{return!1}}l(LT,"removePrjctSection");async function UT(){let s=MT.homedir(),e=new Date().toISOString().replace(/[:.]/g,"-").substring(0,19),t=gn.join(s,`.prjct-backup-${e}`);try{await bt.mkdir(t,{recursive:!0});let n=A.getGlobalBasePath();return await j(n)&&await ny(n,gn.join(t,".prjct-cli")),t}catch{return null}}l(UT,"createBackup");async function ny(s,e){await bt.mkdir(e,{recursive:!0});let t=await bt.readdir(s,{withFileTypes:!0});for(let n of t){let r=gn.join(s,n.name),o=gn.join(e,n.name);n.isDirectory()?await ny(r,o):await bt.copyFile(r,o)}}l(ny,"copyDirectory");async function HT(s,e,t){let n=[],r=[];for(let o of s)if(o.exists)try{o.type==="section"?await LT(o.path)&&n.push(o.path):o.type==="directory"?(await bt.rm(o.path,{recursive:!0,force:!0}),n.push(o.path)):o.type==="file"&&(await bt.unlink(o.path),n.push(o.path))}catch(i){r.push(`${o.path}: ${y(i)}`)}if(!t.keepPackage){if(e.homebrew&&e.homebrewFormula)try{t.dryRun||ia(`brew uninstall ${e.homebrewFormula}`,{stdio:"pipe"}),n.push("Homebrew: prjct-cli")}catch(o){r.push(`Homebrew: ${y(o)}`)}if(e.npm)try{t.dryRun||ia("npm uninstall -g prjct-cli",{stdio:"pipe"}),n.push("npm: prjct-cli")}catch(o){r.push(`npm: ${y(o)}`)}}return{deleted:n,errors:r}}l(HT,"performUninstall");async function GT(s){let e=OT.createInterface({input:process.stdin,output:process.stdout});return new Promise(t=>{e.question(s,n=>{e.close(),t(n.toLowerCase()==="uninstall")})})}l(GT,"promptConfirmation");async function WT(s={},e=process.cwd()){let t=await NT(),n=_T(),r=t.filter(c=>c.exists);if(r.length===0&&!n.homebrew&&!n.npm)return console.log(xe.yellow(`
|
|
1576
|
+
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(xe.red.bold(" WARNING: This action is DANGEROUS and IRREVERSIBLE")),console.log(""),console.log(xe.white("The following will be permanently deleted:")),console.log("");for(let c of r){let u=A.getDisplayPath(c.path),d="";c.type==="section"?d=xe.dim("(section only)"):c.size&&(d=xe.dim(`(${ey(c.size)})`)),console.log(` ${xe.cyan(u.padEnd(35))} ${d}`),console.log(` ${xe.dim(c.description)}`),console.log("")}if(n.homebrew&&(console.log(` ${xe.cyan("Homebrew".padEnd(35))} ${xe.dim("prjct-cli formula")}`),console.log("")),n.npm&&(console.log(` ${xe.cyan("npm global".padEnd(35))} ${xe.dim("prjct-cli package")}`),console.log("")),o>0&&(console.log(xe.dim(` Total size: ${ey(o)}`)),console.log("")),s.dryRun)return console.log(xe.yellow("Dry run - no changes made")),{success:!0,message:"Dry run complete",itemsFound:r.length};if(s.backup){console.log(xe.blue("Creating backup..."));let c=await UT();c?(console.log(xe.green(`Backup created: ${A.getDisplayPath(c)}`)),console.log("")):console.log(xe.yellow("Failed to create backup, continuing..."))}if(!s.force&&(console.log(xe.yellow('Type "uninstall" to confirm:')),!await GT("> ")))return console.log(xe.yellow(`
|
|
1577
|
+
Uninstall cancelled.`)),{success:!1,message:"Uninstall cancelled by user"};console.log(""),console.log(xe.blue("Removing prjct..."));let{deleted:i,errors:a}=await HT(t,n,s);if(console.log(""),i.length>0&&console.log(xe.green(`Removed ${i.length} items`)),a.length>0){console.log(xe.yellow(`
|
|
1578
|
+
${a.length} errors:`));for(let c of a)console.log(xe.red(` - ${c}`))}return console.log(""),console.log(xe.green("prjct has been uninstalled.")),console.log(xe.dim("Thanks for using prjct! We hope to see you again.")),console.log(""),{success:a.length===0,message:`Removed ${i.length} items`,deleted:i,errors:a.length>0?a:void 0}}l(WT,"uninstall");var ca=class extends Ce{static{l(this,"UninstallCommands")}async uninstall(e={},t=process.cwd()){return WT(e,t)}};var ds=new er,la=new ns,zT=new Xs,sy=new Vs,VT=new qs,ps=new Js,tr=new cs,ry=new Ks,BT=new ls,JT=new Qs,qT=new ca,KT=new Ys;function XT(){for(let[s,e]of Object.entries(Qh))V.registerCategory(s,e)}l(XT,"registerCategories");function oy(){if(V.has("work"))return;XT();let s=l(e=>Zh.find(t=>t.name===e),"getMeta");V.registerMethod("task",ds,"now",s("task")),V.registerMethod("done",ds,"done",s("done")),V.registerMethod("next",ds,"next",s("next")),V.registerMethod("pause",ds,"pause",s("pause")),V.registerMethod("resume",ds,"resume",s("resume")),V.registerMethod("workflow",ds,"workflow",s("workflow")),V.registerMethod("sessions",ds,"sessions",s("sessions")),V.registerMethod("init",la,"init",s("init")),V.registerMethod("bug",la,"bug",s("bug")),V.registerMethod("idea",la,"idea",s("idea")),V.registerMethod("spec",la,"spec",s("spec")),V.registerMethod("ship",zT,"ship",s("ship")),V.registerMethod("dash",sy,"dash",s("dash")),V.registerMethod("help",sy,"help",s("help")),V.registerMethod("perf",VT,"perf",s("perf")),V.registerMethod("velocity",JT,"velocity",s("velocity")),V.registerMethod("cleanup",ps,"cleanup",s("cleanup")),V.registerMethod("design",ps,"design",s("design")),V.registerMethod("recover",ps,"recover",s("recover")),V.registerMethod("undo",ps,"undo",s("undo")),V.registerMethod("redo",ps,"redo",s("redo")),V.registerMethod("history",ps,"history",s("history")),V.registerMethod("enrich",ps,"enrich",s("enrich")),V.registerMethod("analyze",tr,"analyze",s("analyze")),V.registerMethod("sync",tr,"sync",s("sync")),V.registerMethod("stats",tr,"stats",s("stats")),V.registerMethod("status",tr,"status",s("status")),V.registerMethod("seal",tr,"seal",s("seal")),V.registerMethod("verify",tr,"verify",s("verify")),V.registerMethod("start",ry,"start",s("start")),V.registerMethod("setup",ry,"setup",s("setup")),V.registerMethod("uninstall",qT,"uninstall",s("uninstall")),V.registerMethod("update",KT,"update",s("update")),V.registerMethod("context",BT,"context",s("context"))}l(oy,"registerAllCommands");oy();Pt();Ta();Dt();import{Hono as aE}from"hono";import{cors as cE}from"hono/cors";import{logger as lE}from"hono/logger";ve();oe();Dr();Ir();$r();Is();L();En();import YT from"node:fs/promises";import QT from"node:path";import{Hono as ZT}from"hono";function eE(s){return A.getGlobalProjectPath(s)}l(eE,"getProjectDataPath");function iy(s,e){let t=new ZT,n=eE(s);return t.get("/state",async r=>{let o=await N.read(s);return r.json(o)}),t.get("/queue",async r=>{let o=await Ie.read(s);return r.json(o)}),t.get("/ideas",async r=>{let o=await tt.read(s);return r.json(o)}),t.get("/roadmap",async r=>{let o=E.getDoc(s,"roadmap");return o?r.json(o):r.json({features:[],backlog:[],lastUpdated:""})}),t.get("/shipped",async r=>{let o=await wt.read(s);return r.json(o)}),t.get("/dashboard",async r=>{let[o,i,a,c]=await Promise.all([N.read(s),Ie.read(s),tt.read(s),wt.read(s)]),u=E.getDoc(s,"roadmap");return r.json({projectId:s,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();return await N.write(s,o),r.json({success:!0})}catch(o){return r.json({success:!1,error:String(o)},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=QT.join(n,"context",`${o}.md`),c=await YT.readFile(a,"utf-8");return r.text(c,200,{"Content-Type":"text/markdown"})}catch(a){return C(a)||H.error(`Context read error: ${y(a)}`),r.text("",200,{"Content-Type":"text/markdown"})}}),t}l(iy,"createRoutes");ve();oe();Dr();Ir();$r();Is();import nr from"node:fs/promises";import tE from"node:path";import{Hono as nE}from"hono";var sE=A.getGlobalBasePath(),sr=tE.join(sE,"projects");function ua(s){return E.getDoc(s,"project")}l(ua,"getProjectConfig");async function qu(s){if(!s)return"";let e=new Date(s),n=new Date().getTime()-e.getTime(),r=Math.floor(n/(1e3*60*60)),o=Math.floor(n%(1e3*60*60)/(1e3*60));return r>0?`${r}h ${o}m`:`${o}m`}l(qu,"calculateDuration");function ay(){let s=new nE;return s.get("/projects",async e=>{try{await nr.mkdir(sr,{recursive:!0});let n=(await nr.readdir(sr,{withFileTypes:!0})).filter(o=>o.isDirectory()).map(o=>o.name),r=await Promise.all(n.map(async o=>{let i=ua(o),a=await N.read(o),c=await Ie.read(o),u=await tt.read(o),d=await wt.read(o),m=a?.currentTask,p=await qu(m?.startedAt);return{id:o,name:i?.name||o.slice(0,8),path:i?.path||null,currentTask:m?{...m,duration:p}:null,pausedTask:a?.previousTask||null,stats:{queueCount:c?.tasks?.filter(g=>!g.completed)?.length||0,ideasCount:u?.ideas?.filter(g=>g.status==="pending")?.length||0,shippedCount:d?.shipped?.length||0}}}));return r.sort((o,i)=>o.currentTask&&!i.currentTask?-1:!o.currentTask&&i.currentTask?1:(o.name||"").localeCompare(i.name||"")),e.json({projects:r})}catch(t){return e.json({projects:[],error:String(t)},500)}}),s.get("/projects/:id/full",async e=>{let t=e.req.param("id");try{let[n,r,o,i,a]=await Promise.all([Promise.resolve(ua(t)),N.read(t),Ie.read(t),tt.read(t),wt.read(t)]),c=E.getDoc(t,"roadmap");r?.currentTask?.startedAt&&(r.currentTask.duration=await qu(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(f=>!f.completed||!f.completedAt?!1:new Date(f.completedAt)>=d)?.length||0,g=o?.tasks?.filter(f=>!f.completed||!f.completedAt?!1:new Date(f.completedAt)>=m)?.length||0;return e.json({id:t,name:n?.name||t,path:n?.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:""},stats:{tasksToday:p,tasksThisWeek:g,queueCount:o?.tasks?.filter(f=>!f.completed)?.length||0,ideasCount:i?.ideas?.filter(f=>f.status==="pending")?.length||0,shippedCount:a?.shipped?.length||0},timestamp:new Date().toISOString()})}catch(n){return e.json({error:String(n)},500)}}),s.post("/projects/:id/task/complete",async e=>{let t=e.req.param("id");try{let n=await N.read(t);if(!n?.currentTask)return e.json({success:!1,error:"No active task"},400);let r=n.currentTask,o={currentTask:null,previousTask:null,lastUpdated:new Date().toISOString()};return await N.write(t,o),e.json({success:!0,completedTask:r,message:`Completed: ${r.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),s.post("/projects/:id/task/pause",async e=>{let t=e.req.param("id");try{let r=(await e.req.json().catch(()=>({}))).reason,o=await N.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 N.write(t,a),e.json({success:!0,pausedTask:i,message:`Paused: ${i.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),s.post("/projects/:id/task/resume",async e=>{let t=e.req.param("id");try{let n=await N.read(t);if(!n?.previousTask)return e.json({success:!1,error:"No paused task"},400);let r={id:n.previousTask.id,description:n.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 N.write(t,o),e.json({success:!0,resumedTask:r,message:`Resumed: ${r.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),s.post("/projects/:id/queue/start",async e=>{let t=e.req.param("id");try{let n=await e.req.json(),{taskId:r}=n;if(!r)return e.json({success:!1,error:"taskId required"},400);let[o,i]=await Promise.all([N.read(t),Ie.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 N.write(t,u),e.json({success:!0,task:c,message:`Started: ${c.description}`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),s.post("/projects/:id/ideas",async e=>{let t=e.req.param("id");try{let n=await e.req.json(),{text:r,priority:o="medium",tags:i=[]}=n;if(!r)return e.json({success:!1,error:"text required"},400);let a=await tt.addIdea(t,r,{priority:o||"medium",tags:i});return e.json({success:!0,idea:a,message:`Captured: ${r.slice(0,50)}...`})}catch(n){return e.json({success:!1,error:String(n)},500)}}),s.get("/stats/global",async e=>{try{await nr.mkdir(sr,{recursive:!0});let n=(await nr.readdir(sr,{withFileTypes:!0})).filter(c=>c.isDirectory()).map(c=>c.name),r=0,o=0,i=0,a=0;for(let c of n){let u=await N.read(c),d=await Ie.read(c),m=await tt.read(c),p=await wt.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:n.length,activeProjects:a,totalTasks:r,totalIdeas:o,totalShipped:i,timestamp:new Date().toISOString()})}catch(t){return e.json({error:String(t)},500)}}),s.get("/status-bar/compact",async e=>{try{let t=e.req.query("cwd");await nr.mkdir(sr,{recursive:!0});let r=(await nr.readdir(sr,{withFileTypes:!0})).filter(d=>d.isDirectory()).map(d=>d.name),o=null;if(t)for(let d of r){let m=ua(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 N.read(d),p=ua(d);if(m?.currentTask){i={id:d,name:p?.name||d,path:p?.repoPath||p?.path},a={...m.currentTask,duration:await qu(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(t){return e.json({error:String(t)},500)}}),s}l(ay,"createExtendedRoutes");fa();import{streamSSE as rE}from"hono/streaming";var cy=3600*1e3,oE=300*1e3,iE=3e4;function ly(){let s=new Map,e=null;function t(o){let i=s.get(o);i&&(clearInterval(i.heartbeatInterval),clearTimeout(i.ttlTimeout),i.abortController.abort(),s.delete(o))}l(t,"removeClient");function n(){e||(e=setInterval(()=>{let o=Date.now();for(let[i,a]of s)o-new Date(a.client.connectedAt).getTime()>cy&&t(i)},oE),e&&typeof e=="object"&&"unref"in e&&e.unref())}l(n,"startReaper");function r(){e&&(clearInterval(e),e=null)}return l(r,"stopReaper"),n(),{handleConnection(o){return rE(o,async i=>{let a=crypto.randomUUID(),c=new Date().toISOString(),u=new AbortController,d={id:a,connectedAt:c,send:l((g,f)=>{i.writeSSE({event:g,data:JSON.stringify(f)})},"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)}},iE),p=setTimeout(()=>{t(a)},cy);typeof m=="object"&&"unref"in m&&m.unref(),typeof p=="object"&&"unref"in p&&p.unref(),s.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 s)try{u.client.send(o,a)}catch{t(c)}},getClientCount(){return s.size},shutdown(){r();for(let o of[...s.keys()])t(o)}}}l(ly,"createSSEManager");function uy(s){let e=new aE,t=ly();s.enableCors!==!1&&e.use("*",cE({origin:"*",allowMethods:["GET","POST","PUT","DELETE","OPTIONS"],allowHeaders:["Content-Type","Authorization"]})),s.enableLogging!==!1&&e.use("*",lE()),e.get("/health",i=>i.json({status:"ok",timestamp:new Date().toISOString()})),e.get("/",i=>i.json({name:"prjct-cli",version:De,projectId:s.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 n=iy(s.projectId,s.projectPath);e.route("/api",n);let r=ay();e.route("/api",r),e.get("/api/events",i=>t.handleConnection(i));let o=null;return{app:e,async start(){let i=s.port,a=s.host||"0.0.0.0";if(dr())o=Bun.serve({port:i,hostname:a,fetch:e.fetch});else{let{serve:c}=await import("@hono/node-server"),u=c({fetch:e.fetch,port:i,hostname:a});o={stop:l(()=>u.close(),"stop")}}console.log(`\u{1F680} prjct server running at http://${a}:${i}`),console.log(` Project: ${s.projectId}`),console.log(` Runtime: ${dr()?"Bun":"Node.js"}`),console.log(` Dashboard: http://localhost:${i}`)},stop(){t.shutdown(),o&&(o.stop(),o=null,console.log("Server stopped"))},broadcast(i,a){t.broadcast(i,a)}}}l(uy,"createServer");var dy=3478;zu();var rr=null,ro=null,we=null,Re=null;async function py(s){let e=Ge.socket(),t=Ge.pid(),n=Ge.runDir();if(Qe.mkdirSync(n,{recursive:!0}),Qe.existsSync(t)){let i=parseInt(Qe.readFileSync(t,"utf-8").trim(),10);fE(i)&&(console.error(`Daemon already running (PID ${i})`),process.exit(1)),Qe.unlinkSync(t)}Qe.existsSync(e)&&Qe.unlinkSync(e);let r=hE(),o=null;if(r)try{o=Qe.statSync(r).mtimeMs}catch{}if(Re={startedAt:Date.now(),commandsServed:0,lastActivity:Date.now(),idleTimeoutMs:Wh,idleTimer:null,entryPath:r,entryMtime:o},we=new us,rr=uE(i=>dE(i)),rr.listen(e,()=>{Qe.chmodSync(e,384),Qe.writeFileSync(t,String(process.pid)),console.log(`prjct daemon started (PID ${process.pid})`),console.log(` Socket: ${e}`),r&&console.log(` Watching: ${r}`),my()}),rr.on("error",i=>{console.error("Daemon socket error:",i.message),or(1)}),!s.noHttp)try{let i=process.cwd(),a=await M.getProjectId(i);if(a){let c=s.port||dy;ro=uy({port:c,projectId:a,projectPath:i,enableLogging:!1}),await ro.start()}}catch{}if(process.on("SIGTERM",()=>or(0)),process.on("SIGINT",()=>or(0)),process.on("SIGHUP",()=>{we=new us,console.log("Daemon reloaded (SIGHUP)")}),!s.foreground)try{process.stdin?.unref?.()}catch{}}l(py,"startDaemon");function dE(s){let e="";s.on("data",async t=>{e+=t.toString();let n;for(;(n=e.indexOf(`
|
|
1579
|
+
`))!==-1;){let r=e.slice(0,n);if(e=e.slice(n+1),!!r.trim())try{let o=JSON.parse(r),i=await pE(o);s.write(Zr(i))}catch(o){let i={id:"unknown",success:!1,exitCode:1,stderr:`Protocol error: ${o.message}`};s.write(Zr(i))}}}),s.on("error",()=>{})}l(dE,"handleConnection");async function pE(s){if(!Re||!we)return{id:s.id,success:!1,exitCode:1,stderr:"Daemon not initialized"};if(my(),Re.commandsServed++,Re.lastActivity=Date.now(),gy()&&(console.log("Build changed detected \u2014 daemon will restart after this request"),setTimeout(()=>{console.log("Daemon shutting down for code reload..."),or(0)},200)),s.command==="daemon")return gE(s);if(s.command==="__ping")return{id:s.id,success:!0,exitCode:0,result:{pong:!0,pid:process.pid}};try{let e=[],t=[],n=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 mE(s);return{id:s.id,success:o.success,exitCode:o.success?0:1,stdout:e.join(`
|
|
1602
1580
|
`)||o.message||void 0,stderr:t.join(`
|
|
1603
|
-
`)||o.error||void 0,result:o}}finally{console.log=n,console.error=
|
|
1581
|
+
`)||o.error||void 0,result:o}}finally{console.log=n,console.error=r}}catch(e){return{id:s.id,success:!1,exitCode:1,stderr:e.message}}}l(pE,"handleRequest");async function mE(s){let e=s.args.join(" ")||null,t=s.options,n=t.md===!0;switch(s.command){case"sync":return we.sync(s.cwd,{aiTools:t.agents?String(t.agents).split(","):void 0,preview:t.preview===!0||t["dry-run"]===!0,yes:t.yes===!0,json:t.json===!0,md:n,package:t.package?String(t.package):void 0,full:t.full===!0});case"status":return we.status(s.cwd,{json:t.json===!0,md:n});case"stats":return we.stats(s.cwd,{json:t.json===!0,export:t.export===!0});case"diff":return we.diff(s.cwd,{json:t.json===!0,md:n});case"seal":return we.seal(s.cwd,{json:t.json===!0});case"rollback":return we.rollback(s.cwd,{json:t.json===!0,md:n});case"verify":return we.verify(s.cwd,{json:t.json===!0,semantic:t.semantic===!0});case"task":return we.task(e,s.cwd,{md:n});case"done":return we.done(s.cwd,{md:n});case"next":return we.next(s.cwd,{md:n});case"pause":return we.pause(e||"",s.cwd,{md:n});case"resume":return we.resume(e,s.cwd,{md:n});case"bug":return we.bug(e||"",s.cwd,{md:n});case"idea":return we.idea(e||"",s.cwd,{md:n});case"ship":return we.ship(e,s.cwd,{md:n});case"dash":return we.dash(e||"default",s.cwd,{md:n});case"workflow":return we.workflowPrefs(e,s.cwd,{md:n});case"sessions":return we.sessions(s.cwd,{md:n,cleanup:t.cleanup===!0});case"design":return we.design(e||"",t,s.cwd);case"analysis-payload":return we.analysisPayload(s.cwd,{json:t.json===!0,md:n});case"analysis-save-llm":return we.saveLlmAnalysis(e||"",s.cwd,{md:n});case"analysis-llm":return we.getLlmAnalysis(s.cwd,{json:t.json===!0,md:n});case"analyze":return we.analyze(t,s.cwd);case"cleanup":return we.cleanup(t,s.cwd);default:return V.execute(s.command,e,s.cwd)}}l(mE,"executeCommand");function gE(s){let e=s.args[0];if(e==="status")return{id:s.id,success:!0,exitCode:0,result:{running:!0,pid:process.pid,socketPath:Ge.socket(),uptime:Re?Date.now()-Re.startedAt:0,commandsServed:Re?.commandsServed??0,lastActivity:Re?new Date(Re.lastActivity).toISOString():null,registeredCommands:V.list().length,stale:gy()}};if(e==="stop"){let t={id:s.id,success:!0,exitCode:0,stdout:"Daemon stopping..."};return setTimeout(()=>or(0),100),t}return{id:s.id,success:!1,exitCode:1,stderr:`Unknown daemon command: ${e}. Use: status, stop`}}l(gE,"handleDaemonCommand");function my(){Re&&(Re.idleTimer&&clearTimeout(Re.idleTimer),Re.idleTimer=setTimeout(()=>{console.log(`Daemon idle for ${Re.idleTimeoutMs/1e3/60} minutes, shutting down`),or(0)},Re.idleTimeoutMs),Re.idleTimer.unref&&Re.idleTimer.unref())}l(my,"resetIdleTimer");function or(s){console.log("Daemon shutting down..."),Re?.idleTimer&&clearTimeout(Re.idleTimer),ro&&(ro.stop(),ro=null),rr&&(rr.close(),rr=null);let e=Ge.socket(),t=Ge.pid();try{Qe.existsSync(e)&&Qe.unlinkSync(e)}catch{}try{Qe.existsSync(t)&&Qe.unlinkSync(t)}catch{}process.exit(s)}l(or,"shutdown");function fE(s){try{return process.kill(s,0),!0}catch{return!1}}l(fE,"isProcessRunning");function hE(){let s=fn("node:path"),e=__dirname;for(let r=0;r<5;r++){if(Qe.existsSync(s.join(e,"package.json"))){let o=s.join(e,"dist","daemon","entry.mjs");if(Qe.existsSync(o))return o;break}e=s.dirname(e)}let t=[s.join(__dirname,"..","daemon","entry.mjs"),s.join(__dirname,"..","dist","daemon","entry.mjs")];for(let r of t)if(Qe.existsSync(r))return r;let n=process.argv[1];return n&&Qe.existsSync(n)?n:null}l(hE,"resolveEntryPath");function gy(){if(!Re?.entryPath||Re.entryMtime===null)return!1;try{return Qe.statSync(Re.entryPath).mtimeMs!==Re.entryMtime}catch{return!1}}l(gy,"isCodeStale");var Ku=process.argv.slice(2),yE=parseInt(Ku.find(s=>s.startsWith("--port="))?.split("=")[1]||"",10)||void 0,wE=Ku.includes("--no-http"),SE=Ku.includes("--foreground");py({port:yE,noHttp:wE,foreground:SE}).catch(s=>{console.error("Failed to start daemon:",s.message),process.exit(1)});
|