prjct-cli 1.56.2 → 1.56.6
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 +23 -0
- package/bin/prjct +13 -5
- package/dist/bin/prjct-core.mjs +238 -238
- package/dist/cli/jira.mjs +4 -4
- package/dist/cli/linear.mjs +4 -4
- package/dist/daemon/entry.mjs +204 -204
- package/dist/mcp/server.mjs +2 -2
- package/package.json +19 -19
package/dist/mcp/server.mjs
CHANGED
|
@@ -6,7 +6,7 @@ var require = __createRequire(import.meta.url);
|
|
|
6
6
|
var __filename = __fileURLToPath(import.meta.url);
|
|
7
7
|
var __dirname = __pathDirname(__filename);
|
|
8
8
|
var Ot=Object.defineProperty;var cs=Object.getOwnPropertyDescriptor;var us=Object.getOwnPropertyNames;var ls=Object.prototype.hasOwnProperty;var l=(i,t)=>Ot(i,"name",{value:t,configurable:!0}),fn=(i=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(i,{get:(t,e)=>(typeof require<"u"?require:t)[e]}):i)(function(i){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+i+'" is not supported')});var $=(i,t)=>()=>(i&&(t=i(i=0)),t);var Lt=(i,t)=>{for(var e in t)Ot(i,e,{get:t[e],enumerable:!0})},ps=(i,t,e,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of us(t))!ls.call(i,n)&&n!==e&&Ot(i,n,{get:()=>t[n],enumerable:!(r=cs(t,n))||r.enumerable});return i};var ae=i=>ps(Ot({},"__esModule",{value:!0}),i);var hn,yn,Tn,ce=$(()=>{"use strict";hn=new Set(["node_modules",".git","dist","build","out",".next",".nuxt","coverage",".cache",".turbo",".vercel",".parcel-cache","__pycache__",".pytest_cache","target","vendor",".venv","venv","eggs","*.egg-info",".prjct"]),yn=["",".ts",".tsx",".js",".jsx","/index.ts","/index.js"],Tn=/(?:import|from)\s+['"]([^'"]+)['"]/g});import{formatDistanceToNowStrict as Bi}from"date-fns";function wn(i){return{year:i.getFullYear().toString(),month:(i.getMonth()+1).toString().padStart(2,"0"),day:i.getDate().toString().padStart(2,"0")}}function f(){return new Date().toISOString()}function $t(i){let t=new Date;return t.setDate(t.getDate()-i),t}function bn(i){let t=i.match(/^([+-])(\d+)([mh])$/);if(!t)return 0;let e=t[1]==="-"?-1:1,r=Number.parseInt(t[2],10),n=t[3];return e*(n==="h"?r*60:r)}function gt(i){let t=0,e=i.match(/(\d+)h/);e&&(t+=Number.parseInt(e[1],10)*60);let r=i.match(/(\d+)m/);return r&&(t+=Number.parseInt(r[1],10)),i.match(/(\d+)s/)&&t===0&&(t=1),t}var W=$(()=>{"use strict";l(wn,"getYearMonthDay");l(f,"getTimestamp");l($t,"getDaysAgo");l(bn,"parseVarianceMinutes");l(gt,"parseDurationMinutes")});function ms(i){return i instanceof Error&&"code"in i}function B(i){return ms(i)&&i.code==="ENOENT"}function En(i){return i instanceof Error?i.message:typeof i=="string"?i:"Unknown error"}var ft=$(()=>{"use strict";l(ms,"isNodeError");l(B,"isNotFoundError");l(En,"getErrorMessage")});import xn from"node:fs/promises";async function _n(i,t){let e;try{e=await xn.readFile(i,"utf-8")}catch(s){if(B(s))return null;throw s}let r;try{r=JSON.parse(e)}catch{return await kn(i,e),Sn(i,"Malformed JSON"),null}let n=t.safeParse(r);return n.success?r:(await kn(i,e),Sn(i,gs(n.error)),null)}async function kn(i,t){let e=`${i}.backup`;try{await xn.writeFile(e,t,"utf-8")}catch{}}function Sn(i,t){console.error(`[prjct] Warning: Corrupted storage file: ${i}`),console.error(`[prjct] Reason: ${t}`),console.error("[prjct] A .backup file has been created. Returning defaults.")}function gs(i){return i.issues.slice(0,3).map(t=>`${t.path.join(".")}: ${t.message}`).join("; ")}var vn=$(()=>{"use strict";ft();l(_n,"safeRead");l(kn,"createBackup");l(Sn,"logCorruption");l(gs,"formatZodError")});import K from"node:fs/promises";import Ft from"node:path";async function Pn(i,t={}){let e=[],r=t.maxFiles??1/0,n=t.dotfileAllowlist?new Set(t.dotfileAllowlist):null;async function s(o){if(e.length>=r)return;let a=await K.readdir(o,{withFileTypes:!0}).catch(()=>[]);for(let c of a){if(e.length>=r)break;let u=String(c.name);if(hn.has(u)||t.skipDotfiles&&u.startsWith(".")&&(!n||!n.has(u)))continue;let p=Ft.join(o,u);c.isDirectory()?await s(p):c.isFile()&&e.push(Ft.relative(i,p))}}return l(s,"walk"),await s(i),e}async function jn(i,t,e){let r=[];for(let n=0;n<i.length;n+=t){let s=await Promise.all(i.slice(n,n+t).map(e));for(let o of s)o!==null&&r.push(o)}return r}async function Ut(i,t=null,e){if(e)return await _n(i,e)??t;try{let r=await K.readFile(i,"utf-8");return JSON.parse(r)}catch(r){if(B(r))return t;throw r}}async function rt(i,t,e=2){let r=Ft.dirname(i);await K.mkdir(r,{recursive:!0});let n=JSON.stringify(t,null,e);await K.writeFile(i,n,"utf-8")}async function ue(i,t=""){try{return await K.readFile(i,"utf-8")}catch(e){if(B(e))return t;throw e}}async function Rn(i,t){let e=Ft.dirname(i);await K.mkdir(e,{recursive:!0}),await K.appendFile(i,`${t}
|
|
9
|
-
`,"utf-8")}async function N(i){try{return await K.access(i),!0}catch(t){if(B(t))return!1;throw t}}async function le(i){try{return(await K.stat(i)).isDirectory()}catch(t){if(B(t))return!1;throw t}}async function J(i){await K.mkdir(i,{recursive:!0})}var st=$(()=>{"use strict";ce();vn();ft();l(Pn,"walkDir");l(jn,"batchProcess");l(Ut,"readJson");l(rt,"writeJson");l(ue,"readFile");l(Rn,"appendLine");l(N,"fileExists");l(le,"dirExists");l(J,"ensureDir")});var Dn=$(()=>{"use strict"});import{z as Q}from"zod";function An(i,t){let e=i.split(".").map(Number),r=t.split(".").map(Number);for(let n=0;n<3;n++){let s=e[n]??0,o=r[n]??0;if(s<o)return-1;if(s>o)return 1}return 0}var oa,ia,aa,Wt,ca,de=$(()=>{"use strict";oa=Q.enum(["opus","sonnet","haiku"]),ia=Q.enum(["2.5-pro","2.5-flash","2.0-flash"]),aa=Q.string().min(1),Wt=Q.object({provider:Q.string(),model:Q.string(),cliVersion:Q.string().optional(),recordedAt:Q.string()}),ca=Q.object({preferredModel:Q.string().optional(),lastAnalysisModel:Wt.optional()});l(An,"compareSemver")});import{exec as fs,execFile as hs}from"node:child_process";import{promisify as Cn}from"node:util";var R,ma,ht=$(()=>{"use strict";R=Cn(fs),ma=Cn(hs)});function Nn(i,t){let e=typeof i=="string"?new Date(i).getTime():i;return Date.now()-e>t}var Xt,me=$(()=>{"use strict";l(Nn,"isExpired");Xt=class{static{l(this,"TTLCache")}cache=new Map;ttl;maxSize;constructor(t={}){this.ttl=t.ttl??5e3,this.maxSize=t.maxSize??50}isValid(t){let e=this.cache.get(t);return e?Date.now()-e.timestamp<this.ttl:!1}get(t){let e=this.cache.get(t);return e?this.isValid(t)?e.data:(this.cache.delete(t),null):null}set(t,e){this.cache.set(t,{data:e,timestamp:Date.now()}),this.evictOldEntries()}delete(t){this.cache.delete(t)}clear(){this.cache.clear()}has(t){return this.cache.has(t)}get size(){return this.cache.size}evictOldEntries(){if(this.cache.size<=this.maxSize)return;let e=Array.from(this.cache.entries()).sort((r,n)=>r[1].timestamp-n[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[r]of e)this.cache.delete(r)}stats(){return{size:this.cache.size,maxSize:this.maxSize,ttl:this.ttl}}prune(){let t=0;for(let e of this.cache.keys())this.isValid(e)||(this.cache.delete(e),t++);return t}}});import ys from"node:fs/promises";import Ts from"node:os";import In from"node:path";async function On(){try{let i=await ys.readFile(Mn,"utf-8"),t=JSON.parse(i);return!t.timestamp||!t.detection||!t.detection.claude||!t.detection.gemini||!t.detection.codex||Nn(t.timestamp,bs)?null:t.detection}catch{return null}}async function Ln(i){let t={timestamp:new Date().toISOString(),detection:i};await rt(Mn,t)}var ws,Mn,bs,$n=$(()=>{"use strict";me();st();ws=In.join(Ts.homedir(),".prjct-cli","cache"),Mn=In.join(ws,"providers.json"),bs=600*1e3;l(On,"readProviderCache");l(Ln,"writeProviderCache")});var Ht={};Lt(Ht,{AntigravityProvider:()=>he,ClaudeProvider:()=>Bt,CodexProvider:()=>ye,CursorProvider:()=>Un,GeminiProvider:()=>fe,Providers:()=>Y,WindsurfProvider:()=>Wn,detectAllProviders:()=>Te,detectAntigravity:()=>Rs,detectCodex:()=>qn,detectCursorProject:()=>Hn,detectProvider:()=>ge,detectWindsurfProject:()=>Gn,getActiveProvider:()=>xs,getCapabilities:()=>ks,getCommandsDir:()=>Ns,getGlobalContextPath:()=>Ds,getGlobalSettingsPath:()=>As,getProjectCommandsPath:()=>Is,getProviderBranding:()=>vs,getSkillsPath:()=>Cs,hasProviderConfig:()=>_s,needsCursorRouterRegeneration:()=>Ps,needsWindsurfRouterRegeneration:()=>js,selectProvider:()=>Ms,validateCliVersion:()=>Bn});import ut from"node:os";import O from"node:path";function ks(i,t){return{...Es[i],...t}}async function Xn(i){try{let{stdout:t}=await R(`which ${i}`,{timeout:2e3});return t.trim()}catch{return null}}async function Ss(i){try{let{stdout:t}=await R(`${i} --version`,{timeout:2e3}),e=t.match(/\d+\.\d+\.\d+/);return e?e[0]:t.trim()}catch{return null}}async function ge(i){let t=Y[i];if(!t.cliCommand)return{installed:!1};let e=await Xn(t.cliCommand);if(!e)return{installed:!1};let r=await Ss(t.cliCommand),n=Bn(i,r||void 0);return{installed:!0,version:r||void 0,path:e,versionWarning:n||void 0}}function Bn(i,t){let e=Y[i];return!e.minCliVersion||!t?null:An(t,e.minCliVersion)<0?`\u26A0\uFE0F ${e.displayName} v${t} is below minimum v${e.minCliVersion}. Some features may not work correctly.`:null}async function Te(i=!1){if(!i){let o=await On();if(o)return o}let[t,e,r]=await Promise.all([ge("claude"),ge("gemini"),qn()]),n={installed:r.installed},s={claude:t,gemini:e,codex:n};return await Ln(s).catch(()=>{}),s}async function xs(i){if(i&&Y[i])return Y[i];let t=await Te();return t.claude.installed&&!t.gemini.installed?Bt:t.gemini.installed&&!t.claude.installed?fe:Bt}async function _s(i){let t=Y[i];return t.configDir?N(t.configDir):!1}function vs(i){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"}[i]||"\u26A1 prjct"}}async function Hn(i){let t=O.join(i,".cursor"),e=O.join(t,"rules"),r=O.join(e,"prjct.mdc"),[n,s]=await Promise.all([N(t),N(r)]);return{detected:n,routerInstalled:s,projectRoot:n?i:void 0}}async function Ps(i){let t=await Hn(i);return t.detected&&!t.routerInstalled}async function Gn(i){let t=O.join(i,".windsurf"),e=O.join(t,"rules"),r=O.join(e,"prjct.md"),[n,s]=await Promise.all([N(t),N(r)]);return{detected:n,routerInstalled:s,projectRoot:n?i:void 0}}async function js(i){let t=await Gn(i);return t.detected&&!t.routerInstalled}async function Rs(){let i=he.configDir;if(!i)return{installed:!1,skillInstalled:!1};let t=O.join(i,"skills","prjct","SKILL.md"),[e,r]=await Promise.all([N(i),N(t)]);return{installed:e,skillInstalled:r,configPath:e?i:void 0}}async function qn(){let i=ye.configDir;if(!i)return{installed:!1,skillInstalled:!1};let t=await Xn("codex"),e=O.join(i,"skills","prjct","SKILL.md"),r=await N(e),n=!!t;return{installed:n,skillInstalled:r,configPath:n?i:void 0}}function Ds(i){let t=Y[i];return t.configDir?O.join(t.configDir,t.contextFile):null}function As(i){let t=Y[i];return!t.configDir||!t.settingsFile?null:O.join(t.configDir,t.settingsFile)}function Cs(i){return Y[i].skillsDir}function Ns(i){return Y[i].commandsDir}function Is(i,t){let e=Y[i];return O.join(t,e.commandsDir)}async function Ms(){let i=await Te(),t=i.claude.installed,e=i.gemini.installed;return!t&&!e?{provider:"claude",userSelected:!1,detection:i}:t&&!e?{provider:"claude",userSelected:!1,detection:i}:e&&!t?{provider:"gemini",userSelected:!1,detection:i}:{provider:"claude",userSelected:!0,detection:i}}var Es,Bt,fe,he,Un,Wn,ye,Y,Gt=$(()=>{"use strict";Dn();de();ht();st();$n();Es={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(ks,"getCapabilities");Bt={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:O.join(ut.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:O.join(ut.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"},fe={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:O.join(ut.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:O.join(ut.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"},he={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:O.join(ut.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:O.join(ut.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"},Un={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"},Wn={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"},ye={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:O.join(ut.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:O.join(ut.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"},Y={claude:Bt,gemini:fe,cursor:Un,antigravity:he,windsurf:Wn,codex:ye};l(Xn,"whichCommand");l(Ss,"getCliVersion");l(ge,"detectProvider");l(Bn,"validateCliVersion");l(Te,"detectAllProviders");l(xs,"getActiveProvider");l(_s,"hasProviderConfig");l(vs,"getProviderBranding");l(Hn,"detectCursorProject");l(Ps,"needsCursorRouterRegeneration");l(Gn,"detectWindsurfProject");l(js,"needsWindsurfRouterRegeneration");l(Rs,"detectAntigravity");l(qn,"detectCodex");l(Ds,"getGlobalContextPath");l(As,"getGlobalSettingsPath");l(Cs,"getSkillsPath");l(Ns,"getCommandsDir");l(Is,"getProjectCommandsPath");l(Ms,"selectProvider")});var er,Se=$(()=>{"use strict";er={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6}});import je from"node:fs";import zt from"node:path";function ir(){if(Rt)return Rt;let i=__dirname;for(let t=0;t<5;t++){let e=zt.join(i,"package.json");if(je.existsSync(e))try{if(JSON.parse(je.readFileSync(e,"utf-8")).name==="prjct-cli")return Rt=i,i}catch{}i=zt.dirname(i)}return Rt=zt.join(__dirname,"..","..",".."),Rt}function Re(){if(qt)return qt;try{let i=zt.join(ir(),"package.json"),t=JSON.parse(je.readFileSync(i,"utf-8"));return qt=t.version,to=t,qt}catch(i){return console.error("Failed to read version from package.json:",En(i)),"0.0.0"}}var qt,to,Rt,De,Ec,Ae=$(()=>{"use strict";ft();qt=null,to=null,Rt=null;l(ir,"getPackageRoot");l(Re,"getVersion");De=Re(),Ec=ir()});var lr={};Lt(lr,{default:()=>oo,worktreeService:()=>ur});import Ce from"node:fs/promises";import tt from"node:path";var cr,Ne,ur,oo,pr=$(()=>{"use strict";ht();st();cr=".worktrees",Ne=class{static{l(this,"WorktreeService")}async create(t,e,r={}){let n=await this.getMainWorktree(t),s=tt.join(n,cr,e),o=r.branch||`feat/${e}`;await Ce.mkdir(tt.join(n,cr),{recursive:!0});let a=r.baseBranch?` ${r.baseBranch}`:"";await R(`git worktree add "${s}" -b "${o}"${a}`,{cwd:n});let{stdout:c}=await R("git rev-parse HEAD",{cwd:s});return{path:s,branch:o,commit:c.trim(),isMain:!1,slug:e}}async remove(t,e=!1){let r=await this.getMainWorktree(t),n;if(e)try{let{stdout:s}=await R("git rev-parse --abbrev-ref HEAD",{cwd:t});n=s.trim()}catch{}if(await R(`git worktree remove "${t}" --force`,{cwd:r}),e&&n&&n!=="main"&&n!=="master")try{await R(`git branch -D "${n}"`,{cwd:r})}catch{}}async list(t){let e=await this.getMainWorktree(t),{stdout:r}=await R("git worktree list --porcelain",{cwd:e});return this.parsePorcelainOutput(r,e)}async detect(t){try{let{stdout:e}=await R("git rev-parse --git-common-dir",{cwd:t}),{stdout:r}=await R("git rev-parse --git-dir",{cwd:t}),n=tt.resolve(t,e.trim()),s=tt.resolve(t,r.trim());if(n!==s){let{stdout:o}=await R("git rev-parse --abbrev-ref HEAD",{cwd:t}),{stdout:a}=await R("git rev-parse HEAD",{cwd:t}),{stdout:c}=await R("git rev-parse --show-toplevel",{cwd:t}),u=c.trim(),p=tt.basename(u);return{path:u,branch:o.trim(),commit:a.trim(),isMain:!1,slug:p}}return null}catch{return null}}async getMainWorktree(t){try{let{stdout:r}=await R("git worktree list --porcelain",{cwd:t}),n=r.split(`
|
|
9
|
+
`,"utf-8")}async function N(i){try{return await K.access(i),!0}catch(t){if(B(t))return!1;throw t}}async function le(i){try{return(await K.stat(i)).isDirectory()}catch(t){if(B(t))return!1;throw t}}async function J(i){await K.mkdir(i,{recursive:!0})}var st=$(()=>{"use strict";ce();vn();ft();l(Pn,"walkDir");l(jn,"batchProcess");l(Ut,"readJson");l(rt,"writeJson");l(ue,"readFile");l(Rn,"appendLine");l(N,"fileExists");l(le,"dirExists");l(J,"ensureDir")});var Dn=$(()=>{"use strict"});import{z as Q}from"zod";function An(i,t){let e=i.split(".").map(Number),r=t.split(".").map(Number);for(let n=0;n<3;n++){let s=e[n]??0,o=r[n]??0;if(s<o)return-1;if(s>o)return 1}return 0}var oa,ia,aa,Wt,ca,de=$(()=>{"use strict";oa=Q.enum(["opus","sonnet","haiku"]),ia=Q.enum(["2.5-pro","2.5-flash","2.0-flash"]),aa=Q.string().min(1),Wt=Q.object({provider:Q.string(),model:Q.string(),cliVersion:Q.string().optional(),recordedAt:Q.string()}),ca=Q.object({preferredModel:Q.string().optional(),lastAnalysisModel:Wt.optional()});l(An,"compareSemver")});import{exec as fs,execFile as hs}from"node:child_process";import{promisify as Cn}from"node:util";var R,ma,ht=$(()=>{"use strict";R=Cn(fs),ma=Cn(hs)});function Nn(i,t){let e=typeof i=="string"?new Date(i).getTime():i;return Date.now()-e>t}var Xt,me=$(()=>{"use strict";l(Nn,"isExpired");Xt=class{static{l(this,"TTLCache")}cache=new Map;ttl;maxSize;constructor(t={}){this.ttl=t.ttl??5e3,this.maxSize=t.maxSize??50}isValid(t){let e=this.cache.get(t);return e?Date.now()-e.timestamp<this.ttl:!1}get(t){let e=this.cache.get(t);return e?this.isValid(t)?e.data:(this.cache.delete(t),null):null}set(t,e){this.cache.set(t,{data:e,timestamp:Date.now()}),this.evictOldEntries()}delete(t){this.cache.delete(t)}clear(){this.cache.clear()}has(t){return this.cache.has(t)}get size(){return this.cache.size}evictOldEntries(){if(this.cache.size<=this.maxSize)return;let e=Array.from(this.cache.entries()).sort((r,n)=>r[1].timestamp-n[1].timestamp).slice(0,this.cache.size-this.maxSize);for(let[r]of e)this.cache.delete(r)}stats(){return{size:this.cache.size,maxSize:this.maxSize,ttl:this.ttl}}prune(){let t=0;for(let e of this.cache.keys())this.isValid(e)||(this.cache.delete(e),t++);return t}}});import ys from"node:fs/promises";import Ts from"node:os";import In from"node:path";async function On(){try{let i=await ys.readFile(Mn,"utf-8"),t=JSON.parse(i);return!t.timestamp||!t.detection||!t.detection.claude||!t.detection.gemini||!t.detection.codex||Nn(t.timestamp,bs)?null:t.detection}catch{return null}}async function Ln(i){let t={timestamp:new Date().toISOString(),detection:i};await rt(Mn,t)}var ws,Mn,bs,$n=$(()=>{"use strict";me();st();ws=In.join(Ts.homedir(),".prjct-cli","cache"),Mn=In.join(ws,"providers.json"),bs=10*60*1e3;l(On,"readProviderCache");l(Ln,"writeProviderCache")});var Ht={};Lt(Ht,{AntigravityProvider:()=>he,ClaudeProvider:()=>Bt,CodexProvider:()=>ye,CursorProvider:()=>Un,GeminiProvider:()=>fe,Providers:()=>Y,WindsurfProvider:()=>Wn,detectAllProviders:()=>Te,detectAntigravity:()=>Rs,detectCodex:()=>qn,detectCursorProject:()=>Hn,detectProvider:()=>ge,detectWindsurfProject:()=>Gn,getActiveProvider:()=>xs,getCapabilities:()=>ks,getCommandsDir:()=>Ns,getGlobalContextPath:()=>Ds,getGlobalSettingsPath:()=>As,getProjectCommandsPath:()=>Is,getProviderBranding:()=>vs,getSkillsPath:()=>Cs,hasProviderConfig:()=>_s,needsCursorRouterRegeneration:()=>Ps,needsWindsurfRouterRegeneration:()=>js,selectProvider:()=>Ms,validateCliVersion:()=>Bn});import ut from"node:os";import O from"node:path";function ks(i,t){return{...Es[i],...t}}async function Xn(i){try{let{stdout:t}=await R(`which ${i}`,{timeout:2e3});return t.trim()}catch{return null}}async function Ss(i){try{let{stdout:t}=await R(`${i} --version`,{timeout:2e3}),e=t.match(/\d+\.\d+\.\d+/);return e?e[0]:t.trim()}catch{return null}}async function ge(i){let t=Y[i];if(!t.cliCommand)return{installed:!1};let e=await Xn(t.cliCommand);if(!e)return{installed:!1};let r=await Ss(t.cliCommand),n=Bn(i,r||void 0);return{installed:!0,version:r||void 0,path:e,versionWarning:n||void 0}}function Bn(i,t){let e=Y[i];return!e.minCliVersion||!t?null:An(t,e.minCliVersion)<0?`\u26A0\uFE0F ${e.displayName} v${t} is below minimum v${e.minCliVersion}. Some features may not work correctly.`:null}async function Te(i=!1){if(!i){let o=await On();if(o)return o}let[t,e,r]=await Promise.all([ge("claude"),ge("gemini"),qn()]),n={installed:r.installed},s={claude:t,gemini:e,codex:n};return await Ln(s).catch(()=>{}),s}async function xs(i){if(i&&Y[i])return Y[i];let t=await Te();return t.claude.installed&&!t.gemini.installed?Bt:t.gemini.installed&&!t.claude.installed?fe:Bt}async function _s(i){let t=Y[i];return t.configDir?N(t.configDir):!1}function vs(i){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"}[i]||"\u26A1 prjct"}}async function Hn(i){let t=O.join(i,".cursor"),e=O.join(t,"rules"),r=O.join(e,"prjct.mdc"),[n,s]=await Promise.all([N(t),N(r)]);return{detected:n,routerInstalled:s,projectRoot:n?i:void 0}}async function Ps(i){let t=await Hn(i);return t.detected&&!t.routerInstalled}async function Gn(i){let t=O.join(i,".windsurf"),e=O.join(t,"rules"),r=O.join(e,"prjct.md"),[n,s]=await Promise.all([N(t),N(r)]);return{detected:n,routerInstalled:s,projectRoot:n?i:void 0}}async function js(i){let t=await Gn(i);return t.detected&&!t.routerInstalled}async function Rs(){let i=he.configDir;if(!i)return{installed:!1,skillInstalled:!1};let t=O.join(i,"skills","prjct","SKILL.md"),[e,r]=await Promise.all([N(i),N(t)]);return{installed:e,skillInstalled:r,configPath:e?i:void 0}}async function qn(){let i=ye.configDir;if(!i)return{installed:!1,skillInstalled:!1};let t=await Xn("codex"),e=O.join(i,"skills","prjct","SKILL.md"),r=await N(e),n=!!t;return{installed:n,skillInstalled:r,configPath:n?i:void 0}}function Ds(i){let t=Y[i];return t.configDir?O.join(t.configDir,t.contextFile):null}function As(i){let t=Y[i];return!t.configDir||!t.settingsFile?null:O.join(t.configDir,t.settingsFile)}function Cs(i){return Y[i].skillsDir}function Ns(i){return Y[i].commandsDir}function Is(i,t){let e=Y[i];return O.join(t,e.commandsDir)}async function Ms(){let i=await Te(),t=i.claude.installed,e=i.gemini.installed;return!t&&!e?{provider:"claude",userSelected:!1,detection:i}:t&&!e?{provider:"claude",userSelected:!1,detection:i}:e&&!t?{provider:"gemini",userSelected:!1,detection:i}:{provider:"claude",userSelected:!0,detection:i}}var Es,Bt,fe,he,Un,Wn,ye,Y,Gt=$(()=>{"use strict";Dn();de();ht();st();$n();Es={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(ks,"getCapabilities");Bt={name:"claude",displayName:"Claude Code",cliCommand:"claude",configDir:O.join(ut.homedir(),".claude"),contextFile:"CLAUDE.md",skillsDir:O.join(ut.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"},fe={name:"gemini",displayName:"Gemini CLI",cliCommand:"gemini",configDir:O.join(ut.homedir(),".gemini"),contextFile:"GEMINI.md",skillsDir:O.join(ut.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"},he={name:"antigravity",displayName:"Google Antigravity",cliCommand:null,configDir:O.join(ut.homedir(),".gemini","antigravity"),contextFile:"ANTIGRAVITY.md",skillsDir:O.join(ut.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"},Un={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"},Wn={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"},ye={name:"codex",displayName:"OpenAI Codex",cliCommand:"codex",configDir:O.join(ut.homedir(),".codex"),contextFile:"AGENTS.md",skillsDir:O.join(ut.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"},Y={claude:Bt,gemini:fe,cursor:Un,antigravity:he,windsurf:Wn,codex:ye};l(Xn,"whichCommand");l(Ss,"getCliVersion");l(ge,"detectProvider");l(Bn,"validateCliVersion");l(Te,"detectAllProviders");l(xs,"getActiveProvider");l(_s,"hasProviderConfig");l(vs,"getProviderBranding");l(Hn,"detectCursorProject");l(Ps,"needsCursorRouterRegeneration");l(Gn,"detectWindsurfProject");l(js,"needsWindsurfRouterRegeneration");l(Rs,"detectAntigravity");l(qn,"detectCodex");l(Ds,"getGlobalContextPath");l(As,"getGlobalSettingsPath");l(Cs,"getSkillsPath");l(Ns,"getCommandsDir");l(Is,"getProjectCommandsPath");l(Ms,"selectProvider")});var er,Se=$(()=>{"use strict";er={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6}});import je from"node:fs";import zt from"node:path";function ir(){if(Rt)return Rt;let i=__dirname;for(let t=0;t<5;t++){let e=zt.join(i,"package.json");if(je.existsSync(e))try{if(JSON.parse(je.readFileSync(e,"utf-8")).name==="prjct-cli")return Rt=i,i}catch{}i=zt.dirname(i)}return Rt=zt.join(__dirname,"..","..",".."),Rt}function Re(){if(qt)return qt;try{let i=zt.join(ir(),"package.json"),t=JSON.parse(je.readFileSync(i,"utf-8"));return qt=t.version,to=t,qt}catch(i){return console.error("Failed to read version from package.json:",En(i)),"0.0.0"}}var qt,to,Rt,De,Ec,Ae=$(()=>{"use strict";ft();qt=null,to=null,Rt=null;l(ir,"getPackageRoot");l(Re,"getVersion");De=Re(),Ec=ir()});var lr={};Lt(lr,{default:()=>oo,worktreeService:()=>ur});import Ce from"node:fs/promises";import tt from"node:path";var cr,Ne,ur,oo,pr=$(()=>{"use strict";ht();st();cr=".worktrees",Ne=class{static{l(this,"WorktreeService")}async create(t,e,r={}){let n=await this.getMainWorktree(t),s=tt.join(n,cr,e),o=r.branch||`feat/${e}`;await Ce.mkdir(tt.join(n,cr),{recursive:!0});let a=r.baseBranch?` ${r.baseBranch}`:"";await R(`git worktree add "${s}" -b "${o}"${a}`,{cwd:n});let{stdout:c}=await R("git rev-parse HEAD",{cwd:s});return{path:s,branch:o,commit:c.trim(),isMain:!1,slug:e}}async remove(t,e=!1){let r=await this.getMainWorktree(t),n;if(e)try{let{stdout:s}=await R("git rev-parse --abbrev-ref HEAD",{cwd:t});n=s.trim()}catch{}if(await R(`git worktree remove "${t}" --force`,{cwd:r}),e&&n&&n!=="main"&&n!=="master")try{await R(`git branch -D "${n}"`,{cwd:r})}catch{}}async list(t){let e=await this.getMainWorktree(t),{stdout:r}=await R("git worktree list --porcelain",{cwd:e});return this.parsePorcelainOutput(r,e)}async detect(t){try{let{stdout:e}=await R("git rev-parse --git-common-dir",{cwd:t}),{stdout:r}=await R("git rev-parse --git-dir",{cwd:t}),n=tt.resolve(t,e.trim()),s=tt.resolve(t,r.trim());if(n!==s){let{stdout:o}=await R("git rev-parse --abbrev-ref HEAD",{cwd:t}),{stdout:a}=await R("git rev-parse HEAD",{cwd:t}),{stdout:c}=await R("git rev-parse --show-toplevel",{cwd:t}),u=c.trim(),p=tt.basename(u);return{path:u,branch:o.trim(),commit:a.trim(),isMain:!1,slug:p}}return null}catch{return null}}async getMainWorktree(t){try{let{stdout:r}=await R("git worktree list --porcelain",{cwd:t}),n=r.split(`
|
|
10
10
|
`)[0];if(n?.startsWith("worktree "))return n.replace("worktree ","").trim()}catch{}let{stdout:e}=await R("git rev-parse --show-toplevel",{cwd:t});return e.trim()}async setup(t,e){let r=tt.join(e,".env");await N(r)&&await Ce.copyFile(r,tt.join(t,".env"));let n=tt.join(e,".prjct"),s=tt.join(t,".prjct");await N(n)&&!await N(s)&&await Ce.symlink(n,s,"dir")}async teardown(t){}async clean(t){let e=await this.list(t),r=[],n=await this.getMainWorktree(t);await R("git worktree prune",{cwd:n});for(let s of e)s.isMain||await N(s.path)||r.push(s.slug);return r}parsePorcelainOutput(t,e){let r=[],n=t.trim().split(`
|
|
11
11
|
|
|
12
12
|
`);for(let s of n){if(!s.trim())continue;let o=s.trim().split(`
|
|
@@ -620,7 +620,7 @@ ${o.join(`
|
|
|
620
620
|
### Agent Accuracy`);for(let a of n.agentAccuracy)s.push(`- ${a.agent}: ${a.rating}${a.note?` \u2014 ${a.note}`:""}`)}if(n.issuesEncountered.length>0){s.push(`
|
|
621
621
|
### Issues Encountered`);for(let a of n.issuesEncountered)s.push(`- ${a}`)}return n.stackConfirmed.length===0&&n.patternsDiscovered.length===0&&n.knownGotchas.length===0&&s.push(`
|
|
622
622
|
No task feedback recorded yet.`),{content:[{type:"text",text:s.join(`
|
|
623
|
-
`)}]}}))}l(Nr,"registerMemoryTools");import Gr from"node:path";import{z as A}from"zod";import M from"node:fs/promises";import E from"node:path";var Ir={critical:0,high:1,medium:2,low:3},Mr={active:0,previously_active:1,backlog:2};function Or(i){return[...i].sort((t,e)=>{let r=Mr[t.section]-Mr[e.section];return r!==0?r:Ir[t.priority]-Ir[e.priority]})}l(Or,"sortBySectionAndPriority");W();var Qe=class extends pt{static{l(this,"QueueStorage")}constructor(){super("queue.json",Er)}getDefault(){return{tasks:[],lastUpdated:""}}getEventType(t){return`queue.${t}d`}async getTasks(t){return(await this.read(t)).tasks}async getActiveTasks(t){return(await this.read(t)).tasks.filter(r=>r.section==="active"&&!r.completed)}async getBacklog(t){return(await this.read(t)).tasks.filter(r=>r.section==="backlog"&&!r.completed)}async getNextTask(t){let e=await this.getActiveTasks(t);return Or(e)[0]||null}async addTask(t,e){let r={...e,id:F(),createdAt:f(),completed:!1};return await this.update(t,n=>({tasks:[...n.tasks,r],lastUpdated:f()})),await this.publishEvent(t,"queue.task_added",{taskId:r.id,description:r.description,priority:r.priority,section:r.section}),r}async addTasks(t,e){let r=f(),n=e.map(s=>({...s,id:F(),createdAt:r,completed:!1}));return await this.update(t,s=>({tasks:[...s.tasks,...n],lastUpdated:r})),await this.publishEvent(t,"queue.tasks_added",{count:n.length,tasks:n.map(s=>({id:s.id,description:s.description}))}),n}async removeTask(t,e){await this.update(t,r=>({tasks:r.tasks.filter(n=>n.id!==e),lastUpdated:f()})),await this.publishEvent(t,"queue.task_removed",{taskId:e})}async completeTask(t,e){let r=null;if(await this.update(t,n=>({tasks:n.tasks.map(o=>o.id===e?(r={...o,completed:!0,completedAt:f()},r):o),lastUpdated:f()})),r){let n=r;await this.publishEvent(t,"queue.task_completed",{taskId:e,description:n.description,completedAt:n.completedAt})}return r}async moveToSection(t,e,r){await this.update(t,n=>({tasks:n.tasks.map(s=>s.id===e?{...s,section:r}:s),lastUpdated:f()}))}async setPriority(t,e,r){await this.update(t,n=>({tasks:n.tasks.map(s=>s.id===e?{...s,priority:r}:s),lastUpdated:f()}))}async getTask(t,e){return(await this.read(t)).tasks.find(n=>n.id===e)||null}async updateTask(t,e,r){let n=null;return await this.update(t,s=>({tasks:s.tasks.map(o=>o.id===e?(n={...o,...r},n):o),lastUpdated:f()})),n&&await this.publishEvent(t,"queue.task_updated",{taskId:e}),n}async clearCompleted(t){let r=(await this.read(t)).tasks.filter(n=>n.completed).length;return await this.update(t,n=>({tasks:n.tasks.filter(s=>!s.completed),lastUpdated:f()})),r}async removeStaleCompleted(t){let e=await this.read(t),r=$t(ee.QUEUE_COMPLETED_DAYS),n=e.tasks.filter(o=>o.completed&&o.completedAt&&new Date(o.completedAt)<r);if(n.length===0)return 0;St.archiveMany(t,n.map(o=>({entityType:"queue_task",entityId:o.id,entityData:o,summary:o.description,reason:"age"})));let s=new Set(n.map(o=>o.id));return await this.update(t,o=>({tasks:o.tasks.filter(a=>!s.has(a.id)),lastUpdated:f()})),await this.publishEvent(t,"queue.stale_removed",{count:n.length}),n.length}},Nt=new Qe;import{z as v}from"zod";var Vo=v.enum(["feature","fix","improvement","refactor"]),Lr=v.enum(["pass","warning","fail","skipped"]),Yo=v.enum(["added","changed","fixed","removed"]),Ko=v.object({hours:v.number(),minutes:v.number(),totalMinutes:v.number()}),Jo=v.object({filesChanged:v.number().nullable().optional(),linesAdded:v.number().nullable().optional(),linesRemoved:v.number().nullable().optional(),commits:v.number().nullable().optional()}),Qo=v.object({description:v.string(),type:Yo.optional()}),Zo=v.object({lintStatus:Lr.nullable().optional(),lintDetails:v.string().optional(),testStatus:Lr.nullable().optional(),testDetails:v.string().optional()}),ti=v.object({hash:v.string().optional(),message:v.string().optional(),branch:v.string().optional()}),ei=v.object({id:v.string(),name:v.string(),version:v.string().nullable().optional(),type:Vo,agent:v.string().optional(),description:v.string().optional(),changes:v.array(Qo).optional(),codeSnippets:v.array(v.string()).optional(),commit:ti.optional(),codeMetrics:Jo.optional(),qualityMetrics:Zo.optional(),quantitativeImpact:v.string().optional(),duration:Ko.optional(),tasksCompleted:v.number().nullable().optional(),shippedAt:v.string(),featureId:v.string().optional()}),$r=v.object({shipped:v.array(ei),lastUpdated:v.string()});W();var Ze=class extends pt{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",$r)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(t){return`shipped.${t}d`}async getAll(t){return(await this.read(t)).shipped}async getRecent(t,e=5){return(await this.read(t)).shipped.sort((n,s)=>new Date(s.shippedAt).getTime()-new Date(n.shippedAt).getTime()).slice(0,e)}async addShipped(t,e){let r={...e,id:F(),shippedAt:f()};return await this.update(t,n=>({shipped:[r,...n.shipped],lastUpdated:f()})),await this.publishEvent(t,"feature.shipped",{shipId:r.id,name:r.name,version:r.version,shippedAt:r.shippedAt}),r}async getByVersion(t,e){return(await this.read(t)).shipped.find(n=>n.version===e)}async getCount(t){return(await this.read(t)).shipped.length}async getByDateRange(t,e,r){return(await this.read(t)).shipped.filter(s=>{let o=new Date(s.shippedAt);return o>=e&&o<=r})}async getStats(t,e="month"){let r=new Date,n;switch(e){case"week":n=new Date(r.getTime()-
|
|
623
|
+
`)}]}}))}l(Nr,"registerMemoryTools");import Gr from"node:path";import{z as A}from"zod";import M from"node:fs/promises";import E from"node:path";var Ir={critical:0,high:1,medium:2,low:3},Mr={active:0,previously_active:1,backlog:2};function Or(i){return[...i].sort((t,e)=>{let r=Mr[t.section]-Mr[e.section];return r!==0?r:Ir[t.priority]-Ir[e.priority]})}l(Or,"sortBySectionAndPriority");W();var Qe=class extends pt{static{l(this,"QueueStorage")}constructor(){super("queue.json",Er)}getDefault(){return{tasks:[],lastUpdated:""}}getEventType(t){return`queue.${t}d`}async getTasks(t){return(await this.read(t)).tasks}async getActiveTasks(t){return(await this.read(t)).tasks.filter(r=>r.section==="active"&&!r.completed)}async getBacklog(t){return(await this.read(t)).tasks.filter(r=>r.section==="backlog"&&!r.completed)}async getNextTask(t){let e=await this.getActiveTasks(t);return Or(e)[0]||null}async addTask(t,e){let r={...e,id:F(),createdAt:f(),completed:!1};return await this.update(t,n=>({tasks:[...n.tasks,r],lastUpdated:f()})),await this.publishEvent(t,"queue.task_added",{taskId:r.id,description:r.description,priority:r.priority,section:r.section}),r}async addTasks(t,e){let r=f(),n=e.map(s=>({...s,id:F(),createdAt:r,completed:!1}));return await this.update(t,s=>({tasks:[...s.tasks,...n],lastUpdated:r})),await this.publishEvent(t,"queue.tasks_added",{count:n.length,tasks:n.map(s=>({id:s.id,description:s.description}))}),n}async removeTask(t,e){await this.update(t,r=>({tasks:r.tasks.filter(n=>n.id!==e),lastUpdated:f()})),await this.publishEvent(t,"queue.task_removed",{taskId:e})}async completeTask(t,e){let r=null;if(await this.update(t,n=>({tasks:n.tasks.map(o=>o.id===e?(r={...o,completed:!0,completedAt:f()},r):o),lastUpdated:f()})),r){let n=r;await this.publishEvent(t,"queue.task_completed",{taskId:e,description:n.description,completedAt:n.completedAt})}return r}async moveToSection(t,e,r){await this.update(t,n=>({tasks:n.tasks.map(s=>s.id===e?{...s,section:r}:s),lastUpdated:f()}))}async setPriority(t,e,r){await this.update(t,n=>({tasks:n.tasks.map(s=>s.id===e?{...s,priority:r}:s),lastUpdated:f()}))}async getTask(t,e){return(await this.read(t)).tasks.find(n=>n.id===e)||null}async updateTask(t,e,r){let n=null;return await this.update(t,s=>({tasks:s.tasks.map(o=>o.id===e?(n={...o,...r},n):o),lastUpdated:f()})),n&&await this.publishEvent(t,"queue.task_updated",{taskId:e}),n}async clearCompleted(t){let r=(await this.read(t)).tasks.filter(n=>n.completed).length;return await this.update(t,n=>({tasks:n.tasks.filter(s=>!s.completed),lastUpdated:f()})),r}async removeStaleCompleted(t){let e=await this.read(t),r=$t(ee.QUEUE_COMPLETED_DAYS),n=e.tasks.filter(o=>o.completed&&o.completedAt&&new Date(o.completedAt)<r);if(n.length===0)return 0;St.archiveMany(t,n.map(o=>({entityType:"queue_task",entityId:o.id,entityData:o,summary:o.description,reason:"age"})));let s=new Set(n.map(o=>o.id));return await this.update(t,o=>({tasks:o.tasks.filter(a=>!s.has(a.id)),lastUpdated:f()})),await this.publishEvent(t,"queue.stale_removed",{count:n.length}),n.length}},Nt=new Qe;import{z as v}from"zod";var Vo=v.enum(["feature","fix","improvement","refactor"]),Lr=v.enum(["pass","warning","fail","skipped"]),Yo=v.enum(["added","changed","fixed","removed"]),Ko=v.object({hours:v.number(),minutes:v.number(),totalMinutes:v.number()}),Jo=v.object({filesChanged:v.number().nullable().optional(),linesAdded:v.number().nullable().optional(),linesRemoved:v.number().nullable().optional(),commits:v.number().nullable().optional()}),Qo=v.object({description:v.string(),type:Yo.optional()}),Zo=v.object({lintStatus:Lr.nullable().optional(),lintDetails:v.string().optional(),testStatus:Lr.nullable().optional(),testDetails:v.string().optional()}),ti=v.object({hash:v.string().optional(),message:v.string().optional(),branch:v.string().optional()}),ei=v.object({id:v.string(),name:v.string(),version:v.string().nullable().optional(),type:Vo,agent:v.string().optional(),description:v.string().optional(),changes:v.array(Qo).optional(),codeSnippets:v.array(v.string()).optional(),commit:ti.optional(),codeMetrics:Jo.optional(),qualityMetrics:Zo.optional(),quantitativeImpact:v.string().optional(),duration:Ko.optional(),tasksCompleted:v.number().nullable().optional(),shippedAt:v.string(),featureId:v.string().optional()}),$r=v.object({shipped:v.array(ei),lastUpdated:v.string()});W();var Ze=class extends pt{static{l(this,"ShippedStorage")}constructor(){super("shipped.json",$r)}getDefault(){return{shipped:[],lastUpdated:""}}getEventType(t){return`shipped.${t}d`}async getAll(t){return(await this.read(t)).shipped}async getRecent(t,e=5){return(await this.read(t)).shipped.sort((n,s)=>new Date(s.shippedAt).getTime()-new Date(n.shippedAt).getTime()).slice(0,e)}async addShipped(t,e){let r={...e,id:F(),shippedAt:f()};return await this.update(t,n=>({shipped:[r,...n.shipped],lastUpdated:f()})),await this.publishEvent(t,"feature.shipped",{shipId:r.id,name:r.name,version:r.version,shippedAt:r.shippedAt}),r}async getByVersion(t,e){return(await this.read(t)).shipped.find(n=>n.version===e)}async getCount(t){return(await this.read(t)).shipped.length}async getByDateRange(t,e,r){return(await this.read(t)).shipped.filter(s=>{let o=new Date(s.shippedAt);return o>=e&&o<=r})}async getStats(t,e="month"){let r=new Date,n;switch(e){case"week":n=new Date(r.getTime()-7*24*60*60*1e3);break;case"month":n=new Date(r.getFullYear(),r.getMonth(),1);break;case"year":n=new Date(r.getFullYear(),0,1);break}return{count:(await this.getByDateRange(t,n,r)).length,period:e}}async archiveOldShipped(t){let e=await this.read(t),r=$t(ee.SHIPPED_RETENTION_DAYS),n=e.shipped.filter(o=>new Date(o.shippedAt)<r);if(n.length===0)return 0;St.archiveMany(t,n.map(o=>({entityType:"shipped",entityId:o.id,entityData:o,summary:`${o.name} v${o.version}`,reason:"age"})));let s=new Set(e.shipped.filter(o=>new Date(o.shippedAt)>=r).map(o=>o.id));return await this.update(t,o=>({shipped:o.shipped.filter(a=>s.has(a.id)),lastUpdated:f()})),await this.publishEvent(t,"shipped.archived",{count:n.length,oldestShippedAt:n[n.length-1]?.shippedAt}),n.length}},Fr=new Ze;tn();var en=class i{static{l(this,"ObsidianExporter")}getProjectPath(t,e){let r=t.projectFolder||e;return E.join(t.vaultPath,"projects",r)}async exportAll(t,e,r){let n=this.getProjectPath(r,e),s=[],o={success:!0,projectFolder:n,exported:{board:0,queue:0,shipped:0,roadmap:0,daily:!1},errors:s};await this.ensureStructure(n);try{o.exported.board=await this.exportBoard(t,n)}catch(a){s.push(`board: ${a instanceof Error?a.message:String(a)}`)}try{o.exported.queue=await this.exportQueue(t,n)}catch(a){s.push(`queue: ${a instanceof Error?a.message:String(a)}`)}try{o.exported.shipped=await this.exportShipped(t,n)}catch(a){s.push(`shipped: ${a instanceof Error?a.message:String(a)}`)}try{o.exported.roadmap=await this.exportRoadmap(t,n)}catch(a){s.push(`roadmap: ${a instanceof Error?a.message:String(a)}`)}try{o.exported.daily=await this.exportDaily(t,n)}catch(a){s.push(`daily: ${a instanceof Error?a.message:String(a)}`)}try{await this.exportIndex(e,n)}catch(a){s.push(`index: ${a instanceof Error?a.message:String(a)}`)}return o.success=s.length===0,o}async ensureStructure(t){let e=["board","queue","shipped","roadmap","architecture","design","research","meetings","notes","daily","retros"];for(let r of e)await M.mkdir(E.join(t,r),{recursive:!0})}async writeLink(t,e,r){let n=[`projectId: ${e}`,`projectPath: ${r}`,`linkedAt: ${new Date().toISOString()}`].join(`
|
|
624
624
|
`);await M.writeFile(E.join(t,".prjct-link.yml"),n,"utf-8")}async exportBoard(t,e){let r=await X.read(t),n=E.join(e,"board"),s=0;if(r.currentTask){let c=r.currentTask,u=c.subtasks||[],p=c.currentSubtaskIndex??0,d={prjct_id:c.id,prjct_type:"task",status:"in_progress",type:c.type||"feature",description:c.description,branch:c.branch,linear_id:c.linearId,estimated_points:c.estimatedPoints,started_at:c.startedAt,updated_at:new Date().toISOString()},g=u.map((k,I)=>{let z=k.status==="completed"?"x":" ",V=I===p&&k.status!=="completed"?" <- current":"";return`- [${z}] ${k.description}${V}`}),h=u.filter(k=>k.status==="completed").length,j=u.length>0?`${h}/${u.length} (${Math.round(h/u.length*100)}%)`:"",w=ct(d,c.description,g.length>0?`## Subtasks
|
|
625
625
|
${g.join(`
|
|
626
626
|
`)}`:null,j?`## Progress
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "prjct-cli",
|
|
3
|
-
"version": "1.56.
|
|
3
|
+
"version": "1.56.6",
|
|
4
4
|
"description": "Context layer for AI agents. Project context for Claude Code, Gemini CLI, and more.",
|
|
5
5
|
"main": "dist/bin/prjct.mjs",
|
|
6
6
|
"bin": {
|
|
@@ -51,26 +51,26 @@
|
|
|
51
51
|
"author": "prjct.app",
|
|
52
52
|
"license": "MIT",
|
|
53
53
|
"dependencies": {
|
|
54
|
-
"@clack/prompts": "
|
|
55
|
-
"@hono/node-server": "
|
|
56
|
-
"@modelcontextprotocol/sdk": "
|
|
57
|
-
"better-sqlite3": "
|
|
58
|
-
"chalk": "
|
|
59
|
-
"chokidar": "
|
|
60
|
-
"date-fns": "
|
|
61
|
-
"glob": "
|
|
62
|
-
"hono": "
|
|
63
|
-
"jsonc-parser": "
|
|
64
|
-
"zod": "
|
|
54
|
+
"@clack/prompts": "1.0.0",
|
|
55
|
+
"@hono/node-server": "1.13.7",
|
|
56
|
+
"@modelcontextprotocol/sdk": "1.28.0",
|
|
57
|
+
"better-sqlite3": "12.6.2",
|
|
58
|
+
"chalk": "4.1.2",
|
|
59
|
+
"chokidar": "5.0.0",
|
|
60
|
+
"date-fns": "4.1.0",
|
|
61
|
+
"glob": "13.0.1",
|
|
62
|
+
"hono": "4.11.3",
|
|
63
|
+
"jsonc-parser": "3.3.1",
|
|
64
|
+
"zod": "3.24.1"
|
|
65
65
|
},
|
|
66
66
|
"devDependencies": {
|
|
67
|
-
"@biomejs/biome": "
|
|
68
|
-
"@types/better-sqlite3": "
|
|
67
|
+
"@biomejs/biome": "2.3.13",
|
|
68
|
+
"@types/better-sqlite3": "7.6.13",
|
|
69
69
|
"@types/bun": "latest",
|
|
70
|
-
"@types/chokidar": "
|
|
71
|
-
"esbuild": "
|
|
72
|
-
"lefthook": "
|
|
73
|
-
"typescript": "
|
|
70
|
+
"@types/chokidar": "2.1.7",
|
|
71
|
+
"esbuild": "0.25.0",
|
|
72
|
+
"lefthook": "2.1.0",
|
|
73
|
+
"typescript": "5.9.3"
|
|
74
74
|
},
|
|
75
75
|
"repository": {
|
|
76
76
|
"type": "git",
|
|
@@ -83,7 +83,7 @@
|
|
|
83
83
|
"packageManager": "bun@1.2.23",
|
|
84
84
|
"engines": {
|
|
85
85
|
"bun": ">=1.0.0",
|
|
86
|
-
"node": ">=
|
|
86
|
+
"node": ">=22.22.2"
|
|
87
87
|
},
|
|
88
88
|
"files": [
|
|
89
89
|
"assets/",
|