context-mode 1.0.160 → 1.0.162
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/.claude-plugin/marketplace.json +2 -2
- package/.claude-plugin/plugin.json +1 -1
- package/.codex-plugin/plugin.json +1 -1
- package/.openclaw-plugin/openclaw.plugin.json +1 -1
- package/.openclaw-plugin/package.json +1 -1
- package/build/session/analytics.d.ts +7 -7
- package/build/session/analytics.js +13 -12
- package/build/session/db.d.ts +1 -0
- package/build/session/db.js +14 -1
- package/build/session/extract.d.ts +46 -0
- package/build/session/extract.js +756 -13
- package/build/session/project-attribution.js +14 -0
- package/cli.bundle.mjs +10 -6
- package/hooks/session-db.bundle.mjs +11 -7
- package/hooks/session-extract.bundle.mjs +2 -2
- package/hooks/session-loaders.mjs +8 -5
- package/hooks/sessionstart.mjs +16 -2
- package/hooks/userpromptsubmit.mjs +9 -2
- package/openclaw.plugin.json +1 -1
- package/package.json +1 -1
- package/server.bundle.mjs +9 -5
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
function i(t){return t==null?"":String(t)}function
|
|
2
|
-
response: ${i(r)}`:"";return[{type:"mcp",category:"mcp",data:i(`${s}${u}${c}`),priority:3}]}var M=2048;function B(t,e){if(Buffer.byteLength(t,"utf8")<=e)return{value:t,truncated:!1};let n=Buffer.from(t,"utf8"),r=e;for(;r>0&&(n[r]&192)===128;)r--;return{value:n.subarray(0,r).toString("utf8"),truncated:!0}}var W=/(authorization|auth_token|access_token|refresh_token|bearer|token|secret|password|passwd|pwd|api[-_]?key|apikey|cookie|set-cookie|signature|private[-_]?key|client[-_]?secret|x[-_]?api[-_]?key)/i,j="[REDACTED]";function y(t,e=new WeakSet){if(t==null||typeof t!="object")return t;if(e.has(t))return"[CIRCULAR]";e.add(t);let n;if(Array.isArray(t))n=t.map(r=>y(r,e));else{let r={};for(let[o,s]of Object.entries(t))W.test(o)?r[o]=j:r[o]=y(s,e);n=r}return e.delete(t),n}function D(t){let{tool_name:e,tool_input:n}=t;if(!e.startsWith("mcp__"))return[];let r=y(n??{}),o;try{o=JSON.stringify(r)}catch{o="{}"}let{value:s,truncated:a}=B(o,M),u=a?`{"tool_name":${JSON.stringify(e)},"params_raw":${JSON.stringify(s)},"truncated":true}`:`{"tool_name":${JSON.stringify(e)},"params":${s}}`;return[{type:"mcp_tool_call",category:"mcp_tool_call",data:i(u),priority:4}]}function F(t){if(t.tool_name!=="AskUserQuestion")return[];let e=t.tool_input.questions,n=Array.isArray(e)&&e.length>0?String(e[0].question??""):"",r=String(t.tool_response??""),o="";try{let c=JSON.parse(r)?.answers;if(c&&typeof c=="object"){let g=f=>typeof f=="string"?f:Array.isArray(f)?f.filter(h=>typeof h=="string").join(" | "):"",m=n?g(c[n]):"";m?o=m:o=Object.values(c).map(g).filter(h=>h.length>0).join(" | ")}}catch{}let s=i(o),a=n?`Q: ${i(n)} \u2192 A: ${s}`:`answer: ${s}`;return[{type:"decision_question",category:"decision",data:i(a),priority:2}]}function U(t){if(t.tool_name!=="Agent")return[];if(!t.tool_response||t.tool_response.length===0)return[];let e=t.tool_response.length>500?t.tool_response.slice(0,500):t.tool_response;return[{type:"agent_finding",category:"agent-finding",data:i(e),priority:2}]}function G(t){let e=[E(t.tool_input),i(t.tool_response)].join(" ");if(e.length===0)return[];let n=new Set,r=e.match(/https?:\/\/[^\s)]+/g);if(r)for(let c of r)c=c.replace(/["'})\],;.]+$/,""),/localhost|127\.0\.0\.1/i.test(c)||n.add(c);let o=e.match(/(?<!\w)#(\d+)/g);if(o)for(let c of o)n.add(c);if(n.size===0)return[];let s,a=i(t.tool_response).match(/Fetched and indexed[^\(]*\(([\d.]+)\s*KB\)/i);if(a){let c=Number(a[1]);Number.isFinite(c)&&c>0&&(s=Math.round(c*1024))}let u={type:"external_ref",category:"external-ref",data:i(Array.from(n).join(", ")),priority:3};return s!==void 0&&(u.bytes_avoided=s),[u]}function K(t){if(t.tool_name!=="EnterWorktree")return[];let e=String(t.tool_input.name??"unnamed");return[{type:"worktree",category:"env",data:i(`entered worktree: ${e}`),priority:2}]}var v=/[,;,;、،]/u,J=15,q=500;function z(t){if(_.test(t)||!b.test(t)||!v.test(t))return!1;let e=[...t].length;return e>=J&&e<=q}function Q(t){let e=t.trim();return z(e)?[{type:"decision",category:"decision",data:i(t),priority:2}]:[]}var V=8,X=120,Y=new RegExp("\\p{L}+\\s+\\p{L}+","u"),Z=new RegExp("\\p{L}{6,}","u");function tt(t){let e=t.split(/[.!\n。!]/u)[0].trim();if(_.test(e)||v.test(e)||!b.test(e))return!1;let n=[...e].length;return n<V||n>X?!1:Y.test(e)||Z.test(e)}function et(t){let e=t.trim();return tt(e)?[{type:"role",category:"role",data:i(t),priority:3}]:[]}var _=/[??؟¿]/u,b=new RegExp("\\p{L}","u"),nt=60;function rt(t){if(_.test(t)||!b.test(t))return!1;let e=[...t].length;return e>0&&e<nt}function ot(t){let e=t.trim();if(!e)return[];let n;return _.test(e)?n="investigate":rt(e)&&(n="implement"),n?[{type:"intent",category:"intent",data:i(n),priority:4}]:[]}var st=/^(?:\/goal\s+|(?:goal|objective)\s*:\s*)(.+)$/is;function it(t){let e=t.trim();if(!e)return[];let n=e.match(st);if(!n)return[];let r=n[1].trim();return r?[{type:"goal",category:"goal",data:i(r),priority:4}]:[]}var at=/(?:\bError\s*:|\bException\s*:|\bTraceback\b|\bat\s+\S+\s*\([^)]*:\d+:\d+\))/u,ct=/[✓✔✅☑🎉]/u,lt=/^\s*(?:fixed|resolved)\s*:/iu;function pt(t){let e=[];return ct.test(t)||lt.test(t)?(e.push({type:"blocker_resolved",category:"blocked-on",data:i(t),priority:2}),e):(at.test(t)&&e.push({type:"blocker",category:"blocked-on",data:i(t),priority:2}),e)}function ut(t){return t.length<=1024?[]:[{type:"data",category:"data",data:i(t),priority:4}]}var l=null;function ft(t){let{tool_name:e,tool_response:n}=t,r=String(n??"");if(d(t))return l={tool:e,error:r.slice(0,200),callsSince:0},[];if(!l)return[];if(l.callsSince++,l.callsSince>10)return l=null,[];if(!!d(t))return[];let s=e===l.tool,a=l.tool==="Read"&&(e==="Edit"||e==="Write"||e==="apply_patch");if(s||a){let u={type:"error_resolved",category:"error-resolution",data:i(`Error in ${l.tool}: ${l.error} \u2192 Fixed`),priority:2};return l=null,[u]}return[]}function yt(){l=null}var p=[];function dt(t){return`${t.length}:${t.slice(0,20)}`}function gt(t){let{tool_name:e,tool_input:n}=t,r=dt(JSON.stringify(n).slice(0,200));if(p.push({tool:e,inputHash:r}),p.length>50&&p.splice(0,p.length-50),p.length<3)return[];let o=0;for(let s=p.length-1;s>=0&&(p[s].tool===e&&p[s].inputHash===r);s--)o++;return o>=3?(p.splice(p.length-o),[{type:"retry_detected",category:"iteration-loop",data:i(`${e} called ${o} times with similar input`),priority:2}]):[]}function bt(){p.length=0}var _t={run_shell_command:"Bash",read_file:"Read",read_many_files:"Read",grep_search:"Grep",search_file_content:"Grep",web_fetch:"WebFetch",write_file:"Write",edit:"Edit",glob:"Glob",todo_write:"TodoWrite",ask_user_question:"AskUserQuestion",list_directory:"LS",save_memory:"Memory",skill:"Skill",exit_plan_mode:"ExitPlanMode",agent:"Agent",bash:"Bash",view:"Read",grep:"Grep",fetch:"WebFetch",shell:"Bash",shell_command:"Bash",exec_command:"Bash","container.exec":"Bash",local_shell:"Bash",grep_files:"Grep"};function ht(t){let e=_t[t.tool_name];return!e||e===t.tool_name?t:{...t,tool_name:e}}function mt(t){try{let e=ht(t),n=[];return n.push(...A(e)),n.push(...R(e)),n.push(...T(e)),n.push(...w(e)),n.push(...L(e)),n.push(...I(e)),n.push(...N(e)),n.push(...$(e)),n.push(...O(e)),n.push(...P(e)),n.push(...D(e)),n.push(...F(e)),n.push(...H(e)),n.push(...K(e)),n.push(...U(e)),n.push(...G(e)),n.push(...ft(e)),n.push(...gt(e)),n}catch{return[]}}function St(t){try{let e=[];return e.push(...Q(t)),e.push(...et(t)),e.push(...ot(t)),e.push(...it(t)),e.push(...pt(t)),e.push(...ut(t)),e}catch{return[]}}export{mt as extractEvents,St as extractUserEvents,yt as resetErrorResolutionState,bt as resetIterationLoopState};
|
|
1
|
+
function i(t){return t==null?"":String(t)}function v(t){return t==null?"":typeof t=="string"?t:JSON.stringify(t)}function _(t){let e=String(t.tool_response??""),n=String(t.tool_input?.command??"");if(e.startsWith("context-mode:")||n.startsWith('echo "context-mode:')||n.startsWith("echo 'context-mode:"))return!1;let r=t.tool_output?.isError===!0||t.tool_output?.is_error===!0;return t.tool_name==="Bash"&&/exit code [1-9]|error:|Error:|FAIL|failed/i.test(e)||r}function R(t){if(!t)return[];let e=[];for(let r of t.split(/\r?\n/)){if(r.startsWith("*** Add File: ")){e.push({path:r.slice(14).trim(),type:"file_write"});continue}if(r.startsWith("*** Update File: ")){e.push({path:r.slice(17).trim(),type:"file_edit"});continue}if(r.startsWith("*** Delete File: ")){e.push({path:r.slice(17).trim(),type:"file_edit"});continue}r.startsWith("*** Move to: ")&&e.push({path:r.slice(13).trim(),type:"file_edit"})}let n=new Set;return e.filter(r=>{if(!r.path)return!1;let o=`${r.type}:${r.path}`;return n.has(o)?!1:(n.add(o),!0)})}function S(t){return/(?:^|[/\\])\.claude[/\\]plans[/\\]/.test(t)}function $(t){let{tool_name:e,tool_input:n,tool_response:r}=t,o=[];if(e==="Read"){let s=String(n.file_path??"");return(/(?:CLAUDE|AGENTS(?:\.override)?|GEMINI|QWEN|KIRO)\.md$/i.test(s)||/\/copilot-instructions\.md$/i.test(s)||/\/context-mode\.mdc$/i.test(s)||/\.claude[\\/]/i.test(s)||/[\\/]memor(?:y|ies)[\\/][^\\/]+\.md$/i.test(s))&&(o.push({type:"rule",category:"rule",data:i(s),priority:1}),r&&r.length>0&&o.push({type:"rule_content",category:"rule",data:i(r),priority:1})),o.push({type:"file_read",category:"file",data:i(s),priority:1}),o}if(e==="Edit"){let s=String(n.file_path??"");return o.push({type:"file_edit",category:"file",data:i(s),priority:1}),o}if(e==="NotebookEdit"){let s=String(n.notebook_path??"");return o.push({type:"file_edit",category:"file",data:i(s),priority:1}),o}if(e==="Write"){let s=String(n.file_path??"");return o.push({type:"file_write",category:"file",data:i(s),priority:1}),o}if(e==="apply_patch"){if(_(t))return[];let s=R(String(n.command??n.patch??""));for(let a of s)o.push({type:a.type,category:"file",data:i(a.path),priority:1});return o}if(e==="Glob"){let s=String(n.pattern??"");return o.push({type:"file_glob",category:"file",data:i(s),priority:3}),o}if(e==="Grep"){let s=String(n.pattern??""),a=String(n.path??"");return o.push({type:"file_search",category:"file",data:i(`${s} in ${a}`),priority:3}),o}return o}function I(t){if(t.tool_name!=="Bash")return[];let n=String(t.tool_input.command??"").match(/\bcd\s+("([^"]+)"|'([^']+)'|(\S+))/);if(!n)return[];let r=n[2]??n[3]??n[4]??"";return[{type:"cwd",category:"cwd",data:i(r),priority:2}]}function C(t){let{tool_response:e}=t,n=String(e??"");return _(t)?[{type:"error_tool",category:"error",data:i(n),priority:2}]:[]}var E=[{pattern:/\bgit\s+checkout\b/,operation:"branch"},{pattern:/\bgit\s+commit\b/,operation:"commit"},{pattern:/\bgit\s+merge\s+\S+/,operation:"merge"},{pattern:/\bgit\s+rebase\b/,operation:"rebase"},{pattern:/\bgit\s+stash\b/,operation:"stash"},{pattern:/\bgit\s+push\b/,operation:"push"},{pattern:/\bgit\s+pull\b/,operation:"pull"},{pattern:/\bgit\s+log\b/,operation:"log"},{pattern:/\bgit\s+diff\b/,operation:"diff"},{pattern:/\bgit\s+status\b/,operation:"status"},{pattern:/\bgit\s+branch\b/,operation:"branch"},{pattern:/\bgit\s+reset\b/,operation:"reset"},{pattern:/\bgit\s+add\b/,operation:"add"},{pattern:/\bgit\s+cherry-pick\b/,operation:"cherry-pick"},{pattern:/\bgit\s+tag\b/,operation:"tag"},{pattern:/\bgit\s+fetch\b/,operation:"fetch"},{pattern:/\bgit\s+clone\b/,operation:"clone"},{pattern:/\bgit\s+worktree\b/,operation:"worktree"}];function H(t){if(t.tool_name!=="Bash")return[];let e=String(t.tool_input.command??""),n=P(e),r;if(n&&n.operation&&(r=E.find(s=>s.operation===n.operation)),r||(r=E.find(s=>s.pattern.test(e))),!r)return[];let o=[];if(n?.scopedDir&&o.push({type:"cwd",category:"cwd",data:i(n.scopedDir),priority:2}),r.operation==="commit"){let s=N(e);if(s)return o.push({type:"git_commit",category:"git",data:i(s),priority:2}),o}return o.push({type:"git",category:"git",data:i(r.operation),priority:2}),o}function O(t){return typeof t!="string"||t.length===0?t:t==="~"?w():t.startsWith("~/")?w()+t.slice(1):t}function w(){try{return process.env.HOME||process.env.USERPROFILE||(process.env.HOMEDRIVE&&process.env.HOMEPATH?process.env.HOMEDRIVE+process.env.HOMEPATH:"")||"~"}catch{return"~"}}function P(t){let e=x(t),n=0;for(;n<e.length&&M(e[n]);)n++;for(;n<e.length&&e[n]!=="git"&&!e[n].endsWith("/git")&&L(e[n]);)n++;if(n>=e.length||e[n]!=="git"&&!e[n].endsWith("/git"))return null;n++;let r=null,o=null;for(;n<e.length;){let s=e[n];if(s==="-C"||s==="--directory"){r=e[n+1]??null,n+=2;continue}if(s.startsWith("--directory=")){r=s.slice(12),n++;continue}if(s.length>0&&s[0]==="-"){n++;continue}o=s;break}return r&&(r=O(r)),{scopedDir:r,operation:o}}function M(t){if(t.length===0)return!1;let e=!1;for(let n=0;n<t.length;n++){let r=t.charCodeAt(n);if(n===0){if(!(r>=65&&r<=90||r===95))return!1}else if(r===61){e=!0;break}else if(!(r>=65&&r<=90||r>=48&&r<=57||r===95))return!1}return e}function L(t){switch(t){case"sudo":case"doas":case"env":case"exec":case"time":return!0;default:return!1}}function x(t){let e=[],n=t.length,r=0;for(;r<n;){for(;r<n&&(t[r]===" "||t[r]===" ");)r++;if(r>=n)break;let o="";for(;r<n&&t[r]!==" "&&t[r]!==" ";){let s=t[r];if(s==='"'||s==="'"){let a=s;for(r++;r<n&&t[r]!==a;)t[r]==="\\"&&r+1<n?(o+=t[r+1],r+=2):(o+=t[r],r++);r<n&&r++}else s==="\\"&&r+1<n?(o+=t[r+1],r+=2):(o+=s,r++)}e.push(o)}return e}function N(t){let e=x(t),n="--message=";for(let r=0;r<e.length;r++){let o=e[r];if(o.length>n.length&&o.startsWith(n)){let s=o.slice(n.length);return s.length>0?s:null}if(o==="--message"){let s=e[r+1];return s&&s.length>0?s:null}if(o.length>=2&&o[0]==="-"&&o[1]!=="-"&&o[o.length-1]==="m"&&j(o,1)){let s=e[r+1];return s&&s.length>0?s:null}}return null}function j(t,e){if(e>=t.length)return!1;for(let n=e;n<t.length;n++){let r=t.charCodeAt(n);if(r<97||r>122)return!1}return!0}function W(t){return new Set(["TodoWrite","TaskCreate","TaskUpdate"]).has(t.tool_name)?[{type:t.tool_name==="TaskUpdate"?"task_update":t.tool_name==="TaskCreate"?"task_create":"task",category:"task",data:i(JSON.stringify(t.tool_input)),priority:1}]:[]}function D(t){let e=2166136261;for(let n=0;n<t.length;n++)e^=t.charCodeAt(n),e=Math.imul(e,16777619);return(e>>>0).toString(16).padStart(8,"0")}function B(t){let e=t.tool_input.plan;if(typeof e=="string"&&e.length>0)return e;let n=t.tool_response;if(typeof n=="string"&&n.length>0)try{let r=JSON.parse(n);if(r&&typeof r=="object"&&typeof r.plan=="string")return r.plan}catch{}return null}function F(t){if(t.tool_name==="EnterPlanMode")return[{type:"plan_enter",category:"plan",data:"entered plan mode",priority:2}];if(t.tool_name==="ExitPlanMode"){let e=[],n=t.tool_input.allowedPrompts,r=Array.isArray(n)&&n.length>0?`exited plan mode (allowed: ${v(n.map(a=>typeof a=="object"&&a!==null&&"prompt"in a?String(a.prompt):String(a)).join(", "))})`:"exited plan mode",o=B(t);typeof o=="string"&&o.length>0&&(r+=` plan_bytes:${o.length} plan_hash:${D(o)}`),e.push({type:"plan_exit",category:"plan",data:i(r),priority:2});let s=String(t.tool_response??"").toLowerCase();return s.includes("approved")||s.includes("approve")?e.push({type:"plan_approved",category:"plan",data:"plan approved by user",priority:1}):(s.includes("rejected")||s.includes("decline")||s.includes("denied"))&&e.push({type:"plan_rejected",category:"plan",data:i(`plan rejected: ${t.tool_response??""}`),priority:2}),e}if(t.tool_name==="Write"||t.tool_name==="Edit"){let e=String(t.tool_input.file_path??"");if(S(e))return[{type:"plan_file_write",category:"plan",data:i(`plan file: ${e.split(/[/\\]/).pop()??e}`),priority:2}]}return t.tool_name==="apply_patch"?_(t)?[]:R(String(t.tool_input.command??t.tool_input.patch??"")).filter(n=>S(n.path)).map(n=>({type:"plan_file_write",category:"plan",data:i(`plan file: ${n.path.split(/[/\\]/).pop()??n.path}`),priority:2})):[]}var U=[/\bsource\s+\S*activate\b/,/\bexport\s+\w+=/,/\bnvm\s+use\b/,/\bpyenv\s+(shell|local|global)\b/,/\bconda\s+activate\b/,/\brbenv\s+(shell|local|global)\b/,/\bnpm\s+install\b/,/\bnpm\s+ci\b/,/\bpip\s+install\b/,/\bbun\s+install\b/,/\byarn\s+(add|install)\b/,/\bpnpm\s+(add|install)\b/,/\bcargo\s+(install|add)\b/,/\bgo\s+(install|get)\b/,/\brustup\b/,/\basdf\b/,/\bvolta\b/,/\bdeno\s+install\b/];function G(t){if(t.tool_name!=="Bash")return[];let e=String(t.tool_input.command??"");if(!U.some(o=>o.test(e)))return[];let r=e.replace(/\bexport\s+(\w+)=\S*/g,"export $1=***");return[{type:"env",category:"env",data:i(r),priority:2}]}function K(t){if(t.tool_name!=="Skill")return[];let e=String(t.tool_input.skill??"");return[{type:"skill",category:"skill",data:i(e),priority:2}]}function J(t){if(!t.tool_response?.includes("Error")&&!t.tool_output?.isError)return[];let e=String(t.tool_response||""),n=[/not supported/i,/cannot/i,/does not support/i,/FAIL/i,/refused/i,/permission denied/i,/incompatible/i];for(let r of n){let o=e.match(r);if(o){let s=e.toLowerCase().indexOf(o[0].toLowerCase()),a=e.slice(Math.max(0,s-50),Math.min(e.length,s+200)).trim();return[{type:"constraint_discovered",category:"constraint",data:i(a),priority:2}]}}return[]}function q(t){if(t.tool_name!=="Agent")return[];let e=i(String(t.tool_input.prompt??t.tool_input.description??"")),n=t.tool_response?i(String(t.tool_response)):"",r=n.length>0;return[{type:r?"subagent_completed":"subagent_launched",category:"subagent",data:i(r?`[completed] ${e} \u2192 ${n}`:`[launched] ${e}`),priority:r?2:3}]}function z(t){let{tool_name:e,tool_input:n,tool_response:r}=t;if(!e.startsWith("mcp__"))return[];let o=e.split("__"),s=o[o.length-1]||e,a=Object.values(n).find(l=>typeof l=="string"),p=a?`: ${i(String(a))}`:"",c=r&&r.length>0?`
|
|
2
|
+
response: ${i(r)}`:"";return[{type:"mcp",category:"mcp",data:i(`${s}${p}${c}`),priority:3}]}var V=2048;function Q(t,e){if(Buffer.byteLength(t,"utf8")<=e)return{value:t,truncated:!1};let n=Buffer.from(t,"utf8"),r=e;for(;r>0&&(n[r]&192)===128;)r--;return{value:n.subarray(0,r).toString("utf8"),truncated:!0}}var X=/(authorization|auth_token|access_token|refresh_token|bearer|token|secret|password|passwd|pwd|api[-_]?key|apikey|cookie|set-cookie|signature|private[-_]?key|client[-_]?secret|x[-_]?api[-_]?key)/i,Y="[REDACTED]";function b(t,e=new WeakSet){if(t==null||typeof t!="object")return t;if(e.has(t))return"[CIRCULAR]";e.add(t);let n;if(Array.isArray(t))n=t.map(r=>b(r,e));else{let r={};for(let[o,s]of Object.entries(t))X.test(o)?r[o]=Y:r[o]=b(s,e);n=r}return e.delete(t),n}function Z(t){let{tool_name:e,tool_input:n}=t;if(!e.startsWith("mcp__"))return[];let r=b(n??{}),o;try{o=JSON.stringify(r)}catch{o="{}"}let{value:s,truncated:a}=Q(o,V),p=a?`{"tool_name":${JSON.stringify(e)},"params_raw":${JSON.stringify(s)},"truncated":true}`:`{"tool_name":${JSON.stringify(e)},"params":${s}}`;return[{type:"mcp_tool_call",category:"mcp_tool_call",data:i(p),priority:4}]}function tt(t){if(t.tool_name!=="AskUserQuestion")return[];let e=t.tool_input.questions,n=Array.isArray(e)&&e.length>0?String(e[0].question??""):"",r=String(t.tool_response??""),o="";try{let c=JSON.parse(r)?.answers;if(c&&typeof c=="object"){let l=g=>typeof g=="string"?g:Array.isArray(g)?g.filter(h=>typeof h=="string").join(" | "):"",u=n?l(c[n]):"";u?o=u:o=Object.values(c).map(l).filter(h=>h.length>0).join(" | ")}}catch{}let s=i(o),a=n?`Q: ${i(n)} \u2192 A: ${s}`:`answer: ${s}`;return[{type:"decision_question",category:"decision",data:i(a),priority:2}]}function et(t){if(t.tool_name!=="Agent")return[];if(!t.tool_response||t.tool_response.length===0)return[];let e=t.tool_response.length>500?t.tool_response.slice(0,500):t.tool_response;return[{type:"agent_finding",category:"agent-finding",data:i(e),priority:2}]}function nt(t){let e=[v(t.tool_input),i(t.tool_response)].join(" ");if(e.length===0)return[];let n=new Set,r=e.match(/https?:\/\/[^\s)]+/g);if(r)for(let c of r)c=c.replace(/["'})\],;.]+$/,""),/localhost|127\.0\.0\.1/i.test(c)||n.add(c);let o=e.match(/(?<!\w)#(\d+)/g);if(o)for(let c of o)n.add(c);if(n.size===0)return[];let s,a=i(t.tool_response).match(/Fetched and indexed[^\(]*\(([\d.]+)\s*KB\)/i);if(a){let c=Number(a[1]);Number.isFinite(c)&&c>0&&(s=Math.round(c*1024))}let p={type:"external_ref",category:"external-ref",data:i(Array.from(n).join(", ")),priority:3};return s!==void 0&&(p.bytes_avoided=s),[p]}function rt(t){if(t.tool_name==="EnterWorktree"){let e=String(t.tool_input.name??"unnamed");return[{type:"worktree",category:"env",data:i(`entered worktree: ${e}`),priority:2}]}if(t.tool_name==="ExitWorktree"){let e=!!t.tool_input.discard_changes;return[{type:"worktree_exit",category:"env",data:i(`exited worktree (discard_changes:${e})`),priority:2}]}return[]}function ot(t){if(typeof t!="string"||t.length===0)return null;let e=t.indexOf("://");if(e<0)return null;let n=e+3;if(n>=t.length)return null;let r=t.length;for(let s=n;s<t.length;s++){let a=t.charCodeAt(s);if(a===47||a===63||a===35){r=s;break}}let o=t.slice(n,r);return o.length>0?o:null}function st(t){if(t.tool_name!=="WebFetch")return[];let e=t.tool_response;if(typeof e!="string"||e.length===0)return[];let n;try{n=JSON.parse(e)}catch{return[]}if(!n||typeof n!="object")return[];let r=n,o=[];if(typeof r.code=="number"&&o.push(`code:${r.code}`),typeof r.bytes=="number"&&o.push(`bytes:${r.bytes}`),typeof r.durationMs=="number"&&o.push(`durMs:${r.durationMs}`),typeof r.url=="string"){let s=ot(r.url);s&&o.push(`host:${s}`)}return o.length===0?[]:[{type:"webfetch_metadata",category:"data",data:i(o.join(" ")),priority:3}]}function it(t){if(t.tool_name!=="Bash")return[];let e=t.tool_response;if(typeof e!="string"||e.length===0)return[];let n;try{n=JSON.parse(e)}catch{return[]}if(!n||typeof n!="object")return[];let r=n;if(!(typeof r.interrupted=="boolean"||typeof r.stderr=="string"||typeof r.returnCodeInterpretation=="string"))return[];let s=[];return typeof r.interrupted=="boolean"&&s.push(`interrupted:${r.interrupted}`),typeof r.returnCodeInterpretation=="string"&&s.push(`rcInterp:${r.returnCodeInterpretation.slice(0,80)}`),typeof r.stderr=="string"&&s.push(`stderrBytes:${r.stderr.length}`),[{type:"bash_outcome",category:"data",data:i(s.join(" ")),priority:3}]}function at(t){if(t.tool_name!=="Read")return[];let e=t.tool_response;if(typeof e!="string"||e.length===0)return[];let n;try{n=JSON.parse(e)}catch{return[]}if(!n||typeof n!="object")return[];let r=n,o=r.type;if(o!=="text"&&o!=="image")return[];let s=[`type:${o}`];if(o==="text")typeof r.numLines=="number"&&s.push(`lines:${r.numLines}`),typeof r.totalLines=="number"&&s.push(`totalLines:${r.totalLines}`),typeof r.startLine=="number"&&s.push(`start:${r.startLine}`);else{typeof r.originalSize=="number"&&s.push(`origSize:${r.originalSize}`);let a=r.dimensions;if(a&&typeof a=="object"){let p=a;typeof p.width=="number"&&typeof p.height=="number"&&s.push(`dims:${p.width}x${p.height}`)}}return[{type:"file_read_metadata",category:"data",data:i(s.join(" ")),priority:3}]}var y={"claude-opus-4-8":{input:5,output:25,cache_write:6.25,cache_read:.5},"claude-opus-4-7":{input:5,output:25,cache_write:6.25,cache_read:.5},"claude-sonnet-4-6":{input:3,output:15,cache_write:3.75,cache_read:.3},"claude-haiku-4-5":{input:1,output:5,cache_write:1.25,cache_read:.1},default:{input:3,output:15,cache_write:3.75,cache_read:.3}};function ct(t,e){let n=[t.tool_input?.model,t.model,e.model],r=Object.keys(y).filter(o=>o!=="default");for(let o of n)if(!(typeof o!="string"||o.length===0)){if(o in y)return o;for(let s of r)if(o.startsWith(s))return s}return"default"}function pt(t,e,n,r,o){let s=y[t]??y.default;return(e*s.input+n*s.output+r*s.cache_write+o*s.cache_read)/1e6}function lt(t){if(t.tool_name!=="Task")return[];let e=t.tool_response;if(typeof e!="string"||e.length===0)return[];let n;try{n=JSON.parse(e)}catch{return[]}if(!n||typeof n!="object")return[];let r=n,o=r.usage&&typeof r.usage=="object"?r.usage:{};if(!(typeof r.totalTokens=="number"||typeof r.totalDurationMs=="number"||typeof o.input_tokens=="number"||typeof o.output_tokens=="number"||typeof o.service_tier=="string"))return[];let a=[];typeof r.totalTokens=="number"&&a.push(`totalTokens:${r.totalTokens}`),typeof r.totalDurationMs=="number"&&a.push(`totalDurMs:${r.totalDurationMs}`),typeof o.input_tokens=="number"&&a.push(`tokens_in:${o.input_tokens}`),typeof o.output_tokens=="number"&&a.push(`tokens_out:${o.output_tokens}`),typeof o.cache_creation_input_tokens=="number"&&a.push(`cache_create:${o.cache_creation_input_tokens}`),typeof o.cache_read_input_tokens=="number"&&a.push(`cache_read:${o.cache_read_input_tokens}`),typeof o.service_tier=="string"&&a.push(`tier:${o.service_tier.slice(0,32)}`);let p=typeof o.input_tokens=="number"?o.input_tokens:0,c=typeof o.output_tokens=="number"?o.output_tokens:0,l=typeof o.cache_creation_input_tokens=="number"?o.cache_creation_input_tokens:0,u=typeof o.cache_read_input_tokens=="number"?o.cache_read_input_tokens:0;if(p>0||c>0||l>0||u>0){let h=ct(t,r),A=pt(h,p,c,l,u);a.push(`cost_usd:${A.toFixed(6).replace(/0+$/,"").replace(/\.$/,".0")}`)}return[{type:"agent_usage",category:"cost",data:i(a.join(" ")),priority:2}]}var T=/[,;,;、،]/u,ut=15,ft=500;function dt(t){if(m.test(t)||!k.test(t)||!T.test(t))return!1;let e=[...t].length;return e>=ut&&e<=ft}function gt(t){let e=t.trim();return dt(e)?[{type:"decision",category:"decision",data:i(t),priority:2}]:[]}var ht=8,_t=120,yt=new RegExp("\\p{L}+\\s+\\p{L}+","u"),mt=new RegExp("\\p{L}{6,}","u");function bt(t){let e=t.split(/[.!\n。!]/u)[0].trim();if(m.test(e)||T.test(e)||!k.test(e))return!1;let n=[...e].length;return n<ht||n>_t?!1:yt.test(e)||mt.test(e)}function kt(t){let e=t.trim();return bt(e)?[{type:"role",category:"role",data:i(t),priority:3}]:[]}var m=/[??؟¿]/u,k=new RegExp("\\p{L}","u"),St=60;function Et(t){if(m.test(t)||!k.test(t))return!1;let e=[...t].length;return e>0&&e<St}function wt(t){let e=t.trim();if(!e)return[];let n;return m.test(e)?n="investigate":Et(e)&&(n="implement"),n?[{type:"intent",category:"intent",data:i(n),priority:4}]:[]}var vt=/^(?:\/goal\s+|(?:goal|objective)\s*:\s*)(.+)$/is;function Rt(t){let e=t.trim();if(!e)return[];let n=e.match(vt);if(!n)return[];let r=n[1].trim();return r?[{type:"goal",category:"goal",data:i(r),priority:4}]:[]}var xt=/(?:\bError\s*:|\bException\s*:|\bTraceback\b|\bat\s+\S+\s*\([^)]*:\d+:\d+\))/u,Tt=/[✓✔✅☑🎉]/u,At=/^\s*(?:fixed|resolved)\s*:/iu;function $t(t){let e=[];return Tt.test(t)||At.test(t)?(e.push({type:"blocker_resolved",category:"blocked-on",data:i(t),priority:2}),e):(xt.test(t)&&e.push({type:"blocker",category:"blocked-on",data:i(t),priority:2}),e)}function It(t){return t.length<=1024?[]:[{type:"data",category:"data",data:i(t),priority:4}]}var f=null;function Ct(t){let{tool_name:e,tool_response:n}=t,r=String(n??"");if(_(t))return f={tool:e,error:r.slice(0,200),callsSince:0},[];if(!f)return[];if(f.callsSince++,f.callsSince>10)return f=null,[];if(!!_(t))return[];let s=e===f.tool,a=f.tool==="Read"&&(e==="Edit"||e==="Write"||e==="apply_patch");if(s||a){let p={type:"error_resolved",category:"error-resolution",data:i(`Error in ${f.tool}: ${f.error} \u2192 Fixed`),priority:2};return f=null,[p]}return[]}function Wt(){f=null}var d=[];function Ht(t){return`${t.length}:${t.slice(0,20)}`}function Ot(t){let{tool_name:e,tool_input:n}=t,r=Ht(JSON.stringify(n).slice(0,200));if(d.push({tool:e,inputHash:r}),d.length>50&&d.splice(0,d.length-50),d.length<3)return[];let o=0;for(let s=d.length-1;s>=0&&(d[s].tool===e&&d[s].inputHash===r);s--)o++;return o>=3?(d.splice(d.length-o),[{type:"retry_detected",category:"iteration-loop",data:i(`${e} called ${o} times with similar input`),priority:2}]):[]}function Dt(){d.length=0}var Pt={run_shell_command:"Bash",read_file:"Read",read_many_files:"Read",grep_search:"Grep",search_file_content:"Grep",web_fetch:"WebFetch",write_file:"Write",edit:"Edit",glob:"Glob",todo_write:"TodoWrite",ask_user_question:"AskUserQuestion",list_directory:"LS",save_memory:"Memory",skill:"Skill",exit_plan_mode:"ExitPlanMode",agent:"Agent",bash:"Bash",view:"Read",grep:"Grep",fetch:"WebFetch",shell:"Bash",shell_command:"Bash",exec_command:"Bash","container.exec":"Bash",local_shell:"Bash",grep_files:"Grep"};function Mt(t){let e=Pt[t.tool_name];return!e||e===t.tool_name?t:{...t,tool_name:e}}function Bt(t){try{let e=Mt(t),n=[];return n.push(...$(e)),n.push(...I(e)),n.push(...C(e)),n.push(...H(e)),n.push(...G(e)),n.push(...W(e)),n.push(...F(e)),n.push(...K(e)),n.push(...q(e)),n.push(...z(e)),n.push(...Z(e)),n.push(...tt(e)),n.push(...J(e)),n.push(...rt(e)),n.push(...st(e)),n.push(...it(e)),n.push(...at(e)),n.push(...lt(e)),n.push(...et(e)),n.push(...nt(e)),n.push(...Ct(e)),n.push(...Ot(e)),n}catch{return[]}}function Ft(t){try{let e=[];return e.push(...jt(t)),e.push(...gt(t)),e.push(...kt(t)),e.push(...wt(t)),e.push(...Rt(t)),e.push(...$t(t)),e.push(...It(t)),e}catch{return[]}}function Ut(t){if(!t||typeof t!="object")return[];let e=t,n=[],r=e.mcp_servers,o=null;return r&&typeof r=="object"&&!Array.isArray(r)&&(o=Object.keys(r),n.push(`mcp_count:${o.length}`),o.length>0&&n.push(`mcp_servers:${o.slice(0,8).join(",")}`)),typeof e.model=="string"&&n.push(`model:${e.model.slice(0,64)}`),typeof e.permission_mode=="string"&&n.push(`permission_mode:${e.permission_mode.slice(0,32)}`),n.length===0?[]:[{type:"session_settings_snapshot",category:"env",data:i(n.join(" ")),priority:2}]}var Lt=["Latin","Cyrillic","Arabic","Han","Hangul","Hiragana","Katakana","Devanagari","Hebrew","Thai","Greek"],Nt={prompt_length:0,prompt_word_count:0,prompt_uppercase_ratio:0,prompt_file_ref_count:0,prompt_path_ref_count:0,prompt_script_primary:null,prompt_script_count:0,prompt_question_glyph_count:0,prompt_code_block_count:0,prompt_url_count:0,prompt_word_tokens:[]};function Gt(t){if(typeof t!="string"||t.length===0)return{...Nt,prompt_word_tokens:[]};let e=t.match(new RegExp("\\p{L}+","gu"))??[],n=(t.match(new RegExp("\\p{Lu}","gu"))??[]).length,r=e.join("").length,o=(t.match(/```/g)??[]).length,s={};for(let l of Lt){let u=new RegExp(`\\p{Script=${l}}`,"gu"),g=(t.match(u)??[]).length;g>0&&(s[l]=g)}let a=Object.entries(s).sort((l,u)=>u[1]-l[1])[0]?.[0]??null,p=new Set,c=[];for(let l of e){if(l.length<3)continue;let u=l.toLowerCase();p.has(u)||(p.add(u),c.push(u))}return{prompt_length:t.length,prompt_word_count:e.length,prompt_uppercase_ratio:r===0?0:n/r,prompt_file_ref_count:(t.match(/(\w+\/)+\w+\.\w+/g)??[]).length,prompt_path_ref_count:(t.match(/\.{0,2}\/[\w\/.-]+/g)??[]).length,prompt_script_primary:a,prompt_script_count:Object.keys(s).length,prompt_question_glyph_count:(t.match(/[??؟]/gu)??[]).length,prompt_code_block_count:Math.floor(o/2),prompt_url_count:(t.match(/https?:\/\/[^\s]+/gu)??[]).length,prompt_word_tokens:c}}function jt(t){if(typeof t!="string"||t.length===0)return[];let e=0;for(;e<t.length;){let o=t.charCodeAt(e);if(o!==32&&o!==9)break;e++}if(e+5>t.length)return[];if(t.slice(e,e+5)!=="/plan")return[];if(e+5<t.length){let o=t.charCodeAt(e+5);if(!(o===32||o===9||o===10||o===13))return[]}let n=t.slice(e+5).trim(),r=n.length>0?`plan via /plan slash: ${n.slice(0,120)}`:"plan via /plan slash";return[{type:"plan_enter",category:"plan",data:i(r),priority:2}]}export{Bt as extractEvents,Ut as extractSessionSettings,Ft as extractUserEvents,Gt as extractUserPromptFeatures,Wt as resetErrorResolutionState,Dt as resetIterationLoopState};
|
|
@@ -195,11 +195,14 @@ function enrichEventForPlatform(event, attribution) {
|
|
|
195
195
|
if (event?.type === "blocker") enriched.blocker_status = "open";
|
|
196
196
|
else if (event?.type === "blocker_resolved") enriched.blocker_status = "resolved";
|
|
197
197
|
|
|
198
|
-
//
|
|
199
|
-
//
|
|
200
|
-
//
|
|
201
|
-
//
|
|
202
|
-
|
|
198
|
+
// v1.0.161 (Bug 2): gate per-event commit_message + has_commit on
|
|
199
|
+
// type='git_commit', NOT category='git'. Non-commit git operations
|
|
200
|
+
// (push/diff/status) used to inflate commit_message with the operation
|
|
201
|
+
// name and falsely raise has_commit on rows that should have remained
|
|
202
|
+
// commit-neutral. The rollup spread now stamps both fields symmetrically
|
|
203
|
+
// from the session's latest actual commit — see SessionDB.getSessionRollup
|
|
204
|
+
// and src/session/extract.ts:extractGit type discriminator.
|
|
205
|
+
if (event?.type === "git_commit" && dataStr.length > 0) {
|
|
203
206
|
enriched.commit_message = dataStr.slice(0, 500);
|
|
204
207
|
enriched.has_commit = 1;
|
|
205
208
|
}
|
package/hooks/sessionstart.mjs
CHANGED
|
@@ -50,7 +50,7 @@ await runHook(async () => {
|
|
|
50
50
|
|
|
51
51
|
// Resolve absolute path for imports (fileURLToPath for Windows compat)
|
|
52
52
|
const HOOK_DIR = dirname(fileURLToPath(import.meta.url));
|
|
53
|
-
const { loadSessionDB, loadProjectAttribution } = createSessionLoaders(HOOK_DIR);
|
|
53
|
+
const { loadSessionDB, loadProjectAttribution, loadExtract } = createSessionLoaders(HOOK_DIR);
|
|
54
54
|
|
|
55
55
|
// Emit a `session_start` canonical event at the boundary of each session
|
|
56
56
|
// lifecycle transition (startup / resume / compact). The platform's insight
|
|
@@ -71,10 +71,24 @@ await runHook(async () => {
|
|
|
71
71
|
}),
|
|
72
72
|
priority: 1,
|
|
73
73
|
};
|
|
74
|
+
|
|
75
|
+
// PRD #4 — emit session_settings_snapshot alongside lifecycle when
|
|
76
|
+
// the SessionStart envelope carries any of mcp_servers / model /
|
|
77
|
+
// permission_mode. Best-effort: missing fields → no snapshot.
|
|
78
|
+
const eventsToEmit = [lifecycleEvent];
|
|
79
|
+
try {
|
|
80
|
+
const extract = await loadExtract();
|
|
81
|
+
if (typeof extract.extractSessionSettings === "function") {
|
|
82
|
+
eventsToEmit.push(...extract.extractSessionSettings(input));
|
|
83
|
+
}
|
|
84
|
+
} catch {
|
|
85
|
+
// settings snapshot is opportunistic — never block lifecycle on it
|
|
86
|
+
}
|
|
87
|
+
|
|
74
88
|
attributeAndInsertEvents(
|
|
75
89
|
db,
|
|
76
90
|
sessionId,
|
|
77
|
-
|
|
91
|
+
eventsToEmit,
|
|
78
92
|
input,
|
|
79
93
|
projectDir,
|
|
80
94
|
"SessionStart",
|
|
@@ -44,7 +44,7 @@ await runHook(async () => {
|
|
|
44
44
|
|
|
45
45
|
if (trimmed.length > 0 && !isSystemMessage) {
|
|
46
46
|
const { SessionDB } = await loadSessionDB();
|
|
47
|
-
const { extractUserEvents } = await loadExtract();
|
|
47
|
+
const { extractUserEvents, extractUserPromptFeatures } = await loadExtract();
|
|
48
48
|
const { resolveProjectAttributions } = await loadProjectAttribution();
|
|
49
49
|
const dbPath = getSessionDBPath();
|
|
50
50
|
const db = new SessionDB({ dbPath });
|
|
@@ -52,12 +52,19 @@ await runHook(async () => {
|
|
|
52
52
|
|
|
53
53
|
db.ensureSession(sessionId, projectDir);
|
|
54
54
|
|
|
55
|
-
// 1. Always save the raw prompt
|
|
55
|
+
// 1. Always save the raw prompt with F1 §2 features attached.
|
|
56
|
+
// Features attach to the existing user_prompt event payload alongside
|
|
57
|
+
// the raw `data` field (do NOT remove `data`). Platform Zod envelope
|
|
58
|
+
// is forward-compatible; new fields persist as typed columns.
|
|
59
|
+
const promptFeatures = typeof extractUserPromptFeatures === "function"
|
|
60
|
+
? extractUserPromptFeatures(trimmed)
|
|
61
|
+
: {};
|
|
56
62
|
const promptEvent = {
|
|
57
63
|
type: "user_prompt",
|
|
58
64
|
category: "user-prompt",
|
|
59
65
|
data: prompt,
|
|
60
66
|
priority: 1,
|
|
67
|
+
...promptFeatures,
|
|
61
68
|
};
|
|
62
69
|
const promptAttributions = attributeAndInsertEvents(
|
|
63
70
|
db, sessionId, [promptEvent], input, projectDir, "UserPromptSubmit", resolveProjectAttributions,
|
package/openclaw.plugin.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"name": "Context Mode",
|
|
4
4
|
"kind": "tool",
|
|
5
5
|
"description": "OpenClaw plugin that saves 98% of your context window. Sandboxed code execution in 11 languages, FTS5 knowledge base with BM25 ranking, and intent-driven search.",
|
|
6
|
-
"version": "1.0.
|
|
6
|
+
"version": "1.0.162",
|
|
7
7
|
"sandbox": {
|
|
8
8
|
"mode": "permissive",
|
|
9
9
|
"filesystem_access": "full",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "context-mode",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.162",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "MCP plugin that saves 98% of your context window. Works with Claude Code, Gemini CLI, VS Code Copilot, OpenCode, and Codex CLI. Sandboxed code execution, FTS5 knowledge base, and intent-driven search.",
|
|
6
6
|
"author": "Mert Koseoğlu",
|
package/server.bundle.mjs
CHANGED
|
@@ -9,7 +9,7 @@ var Uw=Object.create;var Mu=Object.defineProperty;var Fw=Object.getOwnPropertyDe
|
|
|
9
9
|
deps: ${r}}`};var aN={keyword:"dependencies",type:"object",schemaType:"object",error:gr.error,code(t){let[e,r]=cN(t);rv(t,e),nv(t,r)}};function cN({schema:t}){let e={},r={};for(let n in t){if(n==="__proto__")continue;let o=Array.isArray(t[n])?e:r;o[n]=t[n]}return[e,r]}function rv(t,e=t.schema){let{gen:r,data:n,it:o}=t;if(Object.keys(e).length===0)return;let s=r.let("missing");for(let i in e){let a=e[i];if(a.length===0)continue;let c=(0,Si.propertyInData)(r,n,i,o.opts.ownProperties);t.setParams({property:i,depsCount:a.length,deps:a.join(", ")}),o.allErrors?r.if(c,()=>{for(let u of a)(0,Si.checkReportMissingProp)(t,u)}):(r.if((0,Mf._)`${c} && (${(0,Si.checkMissingProp)(t,a,s)})`),(0,Si.reportMissingProp)(t,s),r.else())}}gr.validatePropertyDeps=rv;function nv(t,e=t.schema){let{gen:r,data:n,keyword:o,it:s}=t,i=r.name("valid");for(let a in e)(0,iN.alwaysValidSchema)(s,e[a])||(r.if((0,Si.propertyInData)(r,n,a,s.opts.ownProperties),()=>{let c=t.subschema({keyword:o,schemaProp:a},i);t.mergeValidEvaluated(c,i)},()=>r.var(i,!0)),t.ok(i))}gr.validateSchemaDeps=nv;gr.default=aN});var iv=N(jf=>{"use strict";Object.defineProperty(jf,"__esModule",{value:!0});var sv=Q(),uN=ue(),lN={message:"property name must be valid",params:({params:t})=>(0,sv._)`{propertyName: ${t.propertyName}}`},dN={keyword:"propertyNames",type:"object",schemaType:["object","boolean"],error:lN,code(t){let{gen:e,schema:r,data:n,it:o}=t;if((0,uN.alwaysValidSchema)(o,r))return;let s=e.name("valid");e.forIn("key",n,i=>{t.setParams({propertyName:i}),t.subschema({keyword:"propertyNames",data:i,dataTypes:["string"],propertyName:i,compositeRule:!0},s),e.if((0,sv.not)(s),()=>{t.error(!0),o.allErrors||e.break()})}),t.ok(s)}};jf.default=dN});var Lf=N(zf=>{"use strict";Object.defineProperty(zf,"__esModule",{value:!0});var Sc=Mt(),tr=Q(),pN=Or(),vc=ue(),fN={message:"must NOT have additional properties",params:({params:t})=>(0,tr._)`{additionalProperty: ${t.additionalProperty}}`},mN={keyword:"additionalProperties",type:["object"],schemaType:["boolean","object"],allowUndefined:!0,trackErrors:!0,error:fN,code(t){let{gen:e,schema:r,parentSchema:n,data:o,errsCount:s,it:i}=t;if(!s)throw new Error("ajv implementation error");let{allErrors:a,opts:c}=i;if(i.props=!0,c.removeAdditional!=="all"&&(0,vc.alwaysValidSchema)(i,r))return;let u=(0,Sc.allSchemaProperties)(n.properties),l=(0,Sc.allSchemaProperties)(n.patternProperties);d(),t.ok((0,tr._)`${s} === ${pN.default.errors}`);function d(){e.forIn("key",o,g=>{!u.length&&!l.length?p(g):e.if(f(g),()=>p(g))})}function f(g){let y;if(u.length>8){let _=(0,vc.schemaRefOrVal)(i,n.properties,"properties");y=(0,Sc.isOwnProperty)(e,_,g)}else u.length?y=(0,tr.or)(...u.map(_=>(0,tr._)`${g} === ${_}`)):y=tr.nil;return l.length&&(y=(0,tr.or)(y,...l.map(_=>(0,tr._)`${(0,Sc.usePattern)(t,_)}.test(${g})`))),(0,tr.not)(y)}function h(g){e.code((0,tr._)`delete ${o}[${g}]`)}function p(g){if(c.removeAdditional==="all"||c.removeAdditional&&r===!1){h(g);return}if(r===!1){t.setParams({additionalProperty:g}),t.error(),a||e.break();return}if(typeof r=="object"&&!(0,vc.alwaysValidSchema)(i,r)){let y=e.name("valid");c.removeAdditional==="failing"?(m(g,y,!1),e.if((0,tr.not)(y),()=>{t.reset(),h(g)})):(m(g,y),a||e.if((0,tr.not)(y),()=>e.break()))}}function m(g,y,_){let x={keyword:"additionalProperties",dataProp:g,dataPropType:vc.Type.Str};_===!1&&Object.assign(x,{compositeRule:!0,createErrors:!1,allErrors:!1}),t.subschema(x,y)}}};zf.default=mN});var uv=N(Uf=>{"use strict";Object.defineProperty(Uf,"__esModule",{value:!0});var hN=ii(),av=Mt(),Hf=ue(),cv=Lf(),gN={keyword:"properties",type:"object",schemaType:"object",code(t){let{gen:e,schema:r,parentSchema:n,data:o,it:s}=t;s.opts.removeAdditional==="all"&&n.additionalProperties===void 0&&cv.default.code(new hN.KeywordCxt(s,cv.default,"additionalProperties"));let i=(0,av.allSchemaProperties)(r);for(let d of i)s.definedProperties.add(d);s.opts.unevaluated&&i.length&&s.props!==!0&&(s.props=Hf.mergeEvaluated.props(e,(0,Hf.toHash)(i),s.props));let a=i.filter(d=>!(0,Hf.alwaysValidSchema)(s,r[d]));if(a.length===0)return;let c=e.name("valid");for(let d of a)u(d)?l(d):(e.if((0,av.propertyInData)(e,o,d,s.opts.ownProperties)),l(d),s.allErrors||e.else().var(c,!0),e.endIf()),t.it.definedProperties.add(d),t.ok(c);function u(d){return s.opts.useDefaults&&!s.compositeRule&&r[d].default!==void 0}function l(d){t.subschema({keyword:"properties",schemaProp:d,dataProp:d},c)}}};Uf.default=gN});var fv=N(Ff=>{"use strict";Object.defineProperty(Ff,"__esModule",{value:!0});var lv=Mt(),bc=Q(),dv=ue(),pv=ue(),yN={keyword:"patternProperties",type:"object",schemaType:"object",code(t){let{gen:e,schema:r,data:n,parentSchema:o,it:s}=t,{opts:i}=s,a=(0,lv.allSchemaProperties)(r),c=a.filter(m=>(0,dv.alwaysValidSchema)(s,r[m]));if(a.length===0||c.length===a.length&&(!s.opts.unevaluated||s.props===!0))return;let u=i.strictSchema&&!i.allowMatchingProperties&&o.properties,l=e.name("valid");s.props!==!0&&!(s.props instanceof bc.Name)&&(s.props=(0,pv.evaluatedPropsToName)(e,s.props));let{props:d}=s;f();function f(){for(let m of a)u&&h(m),s.allErrors?p(m):(e.var(l,!0),p(m),e.if(l))}function h(m){for(let g in u)new RegExp(m).test(g)&&(0,dv.checkStrictMode)(s,`property ${g} matches pattern ${m} (use allowMatchingProperties)`)}function p(m){e.forIn("key",n,g=>{e.if((0,bc._)`${(0,lv.usePattern)(t,m)}.test(${g})`,()=>{let y=c.includes(m);y||t.subschema({keyword:"patternProperties",schemaProp:m,dataProp:g,dataPropType:pv.Type.Str},l),s.opts.unevaluated&&d!==!0?e.assign((0,bc._)`${d}[${g}]`,!0):!y&&!s.allErrors&&e.if((0,bc.not)(l),()=>e.break())})})}}};Ff.default=yN});var mv=N(Zf=>{"use strict";Object.defineProperty(Zf,"__esModule",{value:!0});var _N=ue(),xN={keyword:"not",schemaType:["object","boolean"],trackErrors:!0,code(t){let{gen:e,schema:r,it:n}=t;if((0,_N.alwaysValidSchema)(n,r)){t.fail();return}let o=e.name("valid");t.subschema({keyword:"not",compositeRule:!0,createErrors:!1,allErrors:!1},o),t.failResult(o,()=>t.reset(),()=>t.error())},error:{message:"must NOT be valid"}};Zf.default=xN});var hv=N(qf=>{"use strict";Object.defineProperty(qf,"__esModule",{value:!0});var SN=Mt(),vN={keyword:"anyOf",schemaType:"array",trackErrors:!0,code:SN.validateUnion,error:{message:"must match a schema in anyOf"}};qf.default=vN});var gv=N(Bf=>{"use strict";Object.defineProperty(Bf,"__esModule",{value:!0});var kc=Q(),bN=ue(),kN={message:"must match exactly one schema in oneOf",params:({params:t})=>(0,kc._)`{passingSchemas: ${t.passing}}`},EN={keyword:"oneOf",schemaType:"array",trackErrors:!0,error:kN,code(t){let{gen:e,schema:r,parentSchema:n,it:o}=t;if(!Array.isArray(r))throw new Error("ajv implementation error");if(o.opts.discriminator&&n.discriminator)return;let s=r,i=e.let("valid",!1),a=e.let("passing",null),c=e.name("_valid");t.setParams({passing:a}),e.block(u),t.result(i,()=>t.reset(),()=>t.error(!0));function u(){s.forEach((l,d)=>{let f;(0,bN.alwaysValidSchema)(o,l)?e.var(c,!0):f=t.subschema({keyword:"oneOf",schemaProp:d,compositeRule:!0},c),d>0&&e.if((0,kc._)`${c} && ${i}`).assign(i,!1).assign(a,(0,kc._)`[${a}, ${d}]`).else(),e.if(c,()=>{e.assign(i,!0),e.assign(a,d),f&&t.mergeEvaluated(f,kc.Name)})})}}};Bf.default=EN});var yv=N(Vf=>{"use strict";Object.defineProperty(Vf,"__esModule",{value:!0});var wN=ue(),TN={keyword:"allOf",schemaType:"array",code(t){let{gen:e,schema:r,it:n}=t;if(!Array.isArray(r))throw new Error("ajv implementation error");let o=e.name("valid");r.forEach((s,i)=>{if((0,wN.alwaysValidSchema)(n,s))return;let a=t.subschema({keyword:"allOf",schemaProp:i},o);t.ok(o),t.mergeEvaluated(a)})}};Vf.default=TN});var Sv=N(Wf=>{"use strict";Object.defineProperty(Wf,"__esModule",{value:!0});var Ec=Q(),xv=ue(),PN={message:({params:t})=>(0,Ec.str)`must match "${t.ifClause}" schema`,params:({params:t})=>(0,Ec._)`{failingKeyword: ${t.ifClause}}`},RN={keyword:"if",schemaType:["object","boolean"],trackErrors:!0,error:PN,code(t){let{gen:e,parentSchema:r,it:n}=t;r.then===void 0&&r.else===void 0&&(0,xv.checkStrictMode)(n,'"if" without "then" and "else" is ignored');let o=_v(n,"then"),s=_v(n,"else");if(!o&&!s)return;let i=e.let("valid",!0),a=e.name("_valid");if(c(),t.reset(),o&&s){let l=e.let("ifClause");t.setParams({ifClause:l}),e.if(a,u("then",l),u("else",l))}else o?e.if(a,u("then")):e.if((0,Ec.not)(a),u("else"));t.pass(i,()=>t.error(!0));function c(){let l=t.subschema({keyword:"if",compositeRule:!0,createErrors:!1,allErrors:!1},a);t.mergeEvaluated(l)}function u(l,d){return()=>{let f=t.subschema({keyword:l},a);e.assign(i,a),t.mergeValidEvaluated(f,i),d?e.assign(d,(0,Ec._)`${l}`):t.setParams({ifClause:l})}}}};function _v(t,e){let r=t.schema[e];return r!==void 0&&!(0,xv.alwaysValidSchema)(t,r)}Wf.default=RN});var vv=N(Kf=>{"use strict";Object.defineProperty(Kf,"__esModule",{value:!0});var $N=ue(),CN={keyword:["then","else"],schemaType:["object","boolean"],code({keyword:t,parentSchema:e,it:r}){e.if===void 0&&(0,$N.checkStrictMode)(r,`"${t}" without "if" is ignored`)}};Kf.default=CN});var bv=N(Gf=>{"use strict";Object.defineProperty(Gf,"__esModule",{value:!0});var ON=Of(),IN=YS(),AN=If(),NN=ev(),DN=tv(),MN=ov(),jN=iv(),zN=Lf(),LN=uv(),HN=fv(),UN=mv(),FN=hv(),ZN=gv(),qN=yv(),BN=Sv(),VN=vv();function WN(t=!1){let e=[UN.default,FN.default,ZN.default,qN.default,BN.default,VN.default,jN.default,zN.default,MN.default,LN.default,HN.default];return t?e.push(IN.default,NN.default):e.push(ON.default,AN.default),e.push(DN.default),e}Gf.default=WN});var kv=N(Jf=>{"use strict";Object.defineProperty(Jf,"__esModule",{value:!0});var ze=Q(),KN={message:({schemaCode:t})=>(0,ze.str)`must match format "${t}"`,params:({schemaCode:t})=>(0,ze._)`{format: ${t}}`},GN={keyword:"format",type:["number","string"],schemaType:"string",$data:!0,error:KN,code(t,e){let{gen:r,data:n,$data:o,schema:s,schemaCode:i,it:a}=t,{opts:c,errSchemaPath:u,schemaEnv:l,self:d}=a;if(!c.validateFormats)return;o?f():h();function f(){let p=r.scopeValue("formats",{ref:d.formats,code:c.code.formats}),m=r.const("fDef",(0,ze._)`${p}[${i}]`),g=r.let("fType"),y=r.let("format");r.if((0,ze._)`typeof ${m} == "object" && !(${m} instanceof RegExp)`,()=>r.assign(g,(0,ze._)`${m}.type || "string"`).assign(y,(0,ze._)`${m}.validate`),()=>r.assign(g,(0,ze._)`"string"`).assign(y,m)),t.fail$data((0,ze.or)(_(),x()));function _(){return c.strictSchema===!1?ze.nil:(0,ze._)`${i} && !${y}`}function x(){let S=l.$async?(0,ze._)`(${m}.async ? await ${y}(${n}) : ${y}(${n}))`:(0,ze._)`${y}(${n})`,k=(0,ze._)`(typeof ${y} == "function" ? ${S} : ${y}.test(${n}))`;return(0,ze._)`${y} && ${y} !== true && ${g} === ${e} && !${k}`}}function h(){let p=d.formats[s];if(!p){_();return}if(p===!0)return;let[m,g,y]=x(p);m===e&&t.pass(S());function _(){if(c.strictSchema===!1){d.logger.warn(k());return}throw new Error(k());function k(){return`unknown format "${s}" ignored in schema at path "${u}"`}}function x(k){let R=k instanceof RegExp?(0,ze.regexpCode)(k):c.code.formats?(0,ze._)`${c.code.formats}${(0,ze.getProperty)(s)}`:void 0,$=r.scopeValue("formats",{key:s,ref:k,code:R});return typeof k=="object"&&!(k instanceof RegExp)?[k.type||"string",k.validate,(0,ze._)`${$}.validate`]:["string",k,$]}function S(){if(typeof p=="object"&&!(p instanceof RegExp)&&p.async){if(!l.$async)throw new Error("async format in sync schema");return(0,ze._)`await ${y}(${n})`}return typeof g=="function"?(0,ze._)`${y}(${n})`:(0,ze._)`${y}.test(${n})`}}}};Jf.default=GN});var Ev=N(Xf=>{"use strict";Object.defineProperty(Xf,"__esModule",{value:!0});var JN=kv(),XN=[JN.default];Xf.default=XN});var wv=N(qo=>{"use strict";Object.defineProperty(qo,"__esModule",{value:!0});qo.contentVocabulary=qo.metadataVocabulary=void 0;qo.metadataVocabulary=["title","description","default","deprecated","readOnly","writeOnly","examples"];qo.contentVocabulary=["contentMediaType","contentEncoding","contentSchema"]});var Pv=N(Yf=>{"use strict";Object.defineProperty(Yf,"__esModule",{value:!0});var YN=NS(),QN=KS(),eD=bv(),tD=Ev(),Tv=wv(),rD=[YN.default,QN.default,(0,eD.default)(),tD.default,Tv.metadataVocabulary,Tv.contentVocabulary];Yf.default=rD});var $v=N(wc=>{"use strict";Object.defineProperty(wc,"__esModule",{value:!0});wc.DiscrError=void 0;var Rv;(function(t){t.Tag="tag",t.Mapping="mapping"})(Rv||(wc.DiscrError=Rv={}))});var Ov=N(em=>{"use strict";Object.defineProperty(em,"__esModule",{value:!0});var Bo=Q(),Qf=$v(),Cv=ac(),nD=ai(),oD=ue(),sD={message:({params:{discrError:t,tagName:e}})=>t===Qf.DiscrError.Tag?`tag "${e}" must be string`:`value of tag "${e}" must be in oneOf`,params:({params:{discrError:t,tag:e,tagName:r}})=>(0,Bo._)`{error: ${t}, tag: ${r}, tagValue: ${e}}`},iD={keyword:"discriminator",type:"object",schemaType:"object",error:sD,code(t){let{gen:e,data:r,schema:n,parentSchema:o,it:s}=t,{oneOf:i}=o;if(!s.opts.discriminator)throw new Error("discriminator: requires discriminator option");let a=n.propertyName;if(typeof a!="string")throw new Error("discriminator: requires propertyName");if(n.mapping)throw new Error("discriminator: mapping is not supported");if(!i)throw new Error("discriminator: requires oneOf keyword");let c=e.let("valid",!1),u=e.const("tag",(0,Bo._)`${r}${(0,Bo.getProperty)(a)}`);e.if((0,Bo._)`typeof ${u} == "string"`,()=>l(),()=>t.error(!1,{discrError:Qf.DiscrError.Tag,tag:u,tagName:a})),t.ok(c);function l(){let h=f();e.if(!1);for(let p in h)e.elseIf((0,Bo._)`${u} === ${p}`),e.assign(c,d(h[p]));e.else(),t.error(!1,{discrError:Qf.DiscrError.Mapping,tag:u,tagName:a}),e.endIf()}function d(h){let p=e.name("valid"),m=t.subschema({keyword:"oneOf",schemaProp:h},p);return t.mergeEvaluated(m,Bo.Name),p}function f(){var h;let p={},m=y(o),g=!0;for(let S=0;S<i.length;S++){let k=i[S];if(k?.$ref&&!(0,oD.schemaHasRulesButRef)(k,s.self.RULES)){let $=k.$ref;if(k=Cv.resolveRef.call(s.self,s.schemaEnv.root,s.baseId,$),k instanceof Cv.SchemaEnv&&(k=k.schema),k===void 0)throw new nD.default(s.opts.uriResolver,s.baseId,$)}let R=(h=k?.properties)===null||h===void 0?void 0:h[a];if(typeof R!="object")throw new Error(`discriminator: oneOf subschemas (or referenced schemas) must have "properties/${a}"`);g=g&&(m||y(k)),_(R,S)}if(!g)throw new Error(`discriminator: "${a}" must be required`);return p;function y({required:S}){return Array.isArray(S)&&S.includes(a)}function _(S,k){if(S.const)x(S.const,k);else if(S.enum)for(let R of S.enum)x(R,k);else throw new Error(`discriminator: "properties/${a}" must have "const" or "enum"`)}function x(S,k){if(typeof S!="string"||S in p)throw new Error(`discriminator: "${a}" values must be unique strings`);p[S]=k}}}};em.default=iD});var Iv=N((r2,aD)=>{aD.exports={$schema:"http://json-schema.org/draft-07/schema#",$id:"http://json-schema.org/draft-07/schema#",title:"Core schema meta-schema",definitions:{schemaArray:{type:"array",minItems:1,items:{$ref:"#"}},nonNegativeInteger:{type:"integer",minimum:0},nonNegativeIntegerDefault0:{allOf:[{$ref:"#/definitions/nonNegativeInteger"},{default:0}]},simpleTypes:{enum:["array","boolean","integer","null","number","object","string"]},stringArray:{type:"array",items:{type:"string"},uniqueItems:!0,default:[]}},type:["object","boolean"],properties:{$id:{type:"string",format:"uri-reference"},$schema:{type:"string",format:"uri"},$ref:{type:"string",format:"uri-reference"},$comment:{type:"string"},title:{type:"string"},description:{type:"string"},default:!0,readOnly:{type:"boolean",default:!1},examples:{type:"array",items:!0},multipleOf:{type:"number",exclusiveMinimum:0},maximum:{type:"number"},exclusiveMaximum:{type:"number"},minimum:{type:"number"},exclusiveMinimum:{type:"number"},maxLength:{$ref:"#/definitions/nonNegativeInteger"},minLength:{$ref:"#/definitions/nonNegativeIntegerDefault0"},pattern:{type:"string",format:"regex"},additionalItems:{$ref:"#"},items:{anyOf:[{$ref:"#"},{$ref:"#/definitions/schemaArray"}],default:!0},maxItems:{$ref:"#/definitions/nonNegativeInteger"},minItems:{$ref:"#/definitions/nonNegativeIntegerDefault0"},uniqueItems:{type:"boolean",default:!1},contains:{$ref:"#"},maxProperties:{$ref:"#/definitions/nonNegativeInteger"},minProperties:{$ref:"#/definitions/nonNegativeIntegerDefault0"},required:{$ref:"#/definitions/stringArray"},additionalProperties:{$ref:"#"},definitions:{type:"object",additionalProperties:{$ref:"#"},default:{}},properties:{type:"object",additionalProperties:{$ref:"#"},default:{}},patternProperties:{type:"object",additionalProperties:{$ref:"#"},propertyNames:{format:"regex"},default:{}},dependencies:{type:"object",additionalProperties:{anyOf:[{$ref:"#"},{$ref:"#/definitions/stringArray"}]}},propertyNames:{$ref:"#"},const:!0,enum:{type:"array",items:!0,minItems:1,uniqueItems:!0},type:{anyOf:[{$ref:"#/definitions/simpleTypes"},{type:"array",items:{$ref:"#/definitions/simpleTypes"},minItems:1,uniqueItems:!0}]},format:{type:"string"},contentMediaType:{type:"string"},contentEncoding:{type:"string"},if:{$ref:"#"},then:{$ref:"#"},else:{$ref:"#"},allOf:{$ref:"#/definitions/schemaArray"},anyOf:{$ref:"#/definitions/schemaArray"},oneOf:{$ref:"#/definitions/schemaArray"},not:{$ref:"#"}},default:!0}});var rm=N((Te,tm)=>{"use strict";Object.defineProperty(Te,"__esModule",{value:!0});Te.MissingRefError=Te.ValidationError=Te.CodeGen=Te.Name=Te.nil=Te.stringify=Te.str=Te._=Te.KeywordCxt=Te.Ajv=void 0;var cD=RS(),uD=Pv(),lD=Ov(),Av=Iv(),dD=["/properties"],Tc="http://json-schema.org/draft-07/schema",Vo=class extends cD.default{_addVocabularies(){super._addVocabularies(),uD.default.forEach(e=>this.addVocabulary(e)),this.opts.discriminator&&this.addKeyword(lD.default)}_addDefaultMetaSchema(){if(super._addDefaultMetaSchema(),!this.opts.meta)return;let e=this.opts.$data?this.$dataMetaSchema(Av,dD):Av;this.addMetaSchema(e,Tc,!1),this.refs["http://json-schema.org/schema"]=Tc}defaultMeta(){return this.opts.defaultMeta=super.defaultMeta()||(this.getSchema(Tc)?Tc:void 0)}};Te.Ajv=Vo;tm.exports=Te=Vo;tm.exports.Ajv=Vo;Object.defineProperty(Te,"__esModule",{value:!0});Te.default=Vo;var pD=ii();Object.defineProperty(Te,"KeywordCxt",{enumerable:!0,get:function(){return pD.KeywordCxt}});var Wo=Q();Object.defineProperty(Te,"_",{enumerable:!0,get:function(){return Wo._}});Object.defineProperty(Te,"str",{enumerable:!0,get:function(){return Wo.str}});Object.defineProperty(Te,"stringify",{enumerable:!0,get:function(){return Wo.stringify}});Object.defineProperty(Te,"nil",{enumerable:!0,get:function(){return Wo.nil}});Object.defineProperty(Te,"Name",{enumerable:!0,get:function(){return Wo.Name}});Object.defineProperty(Te,"CodeGen",{enumerable:!0,get:function(){return Wo.CodeGen}});var fD=sc();Object.defineProperty(Te,"ValidationError",{enumerable:!0,get:function(){return fD.default}});var mD=ai();Object.defineProperty(Te,"MissingRefError",{enumerable:!0,get:function(){return mD.default}})});var Uv=N(_r=>{"use strict";Object.defineProperty(_r,"__esModule",{value:!0});_r.formatNames=_r.fastFormats=_r.fullFormats=void 0;function yr(t,e){return{validate:t,compare:e}}_r.fullFormats={date:yr(jv,im),time:yr(om(!0),am),"date-time":yr(Nv(!0),Lv),"iso-time":yr(om(),zv),"iso-date-time":yr(Nv(),Hv),duration:/^P(?!$)((\d+Y)?(\d+M)?(\d+D)?(T(?=\d)(\d+H)?(\d+M)?(\d+S)?)?|(\d+W)?)$/,uri:SD,"uri-reference":/^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'"()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?(?:\?(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i,"uri-template":/^(?:(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2})|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i,url:/^(?:https?|ftp):\/\/(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z0-9\u{00a1}-\u{ffff}]+-)*[a-z0-9\u{00a1}-\u{ffff}]+)(?:\.(?:[a-z0-9\u{00a1}-\u{ffff}]+-)*[a-z0-9\u{00a1}-\u{ffff}]+)*(?:\.(?:[a-z\u{00a1}-\u{ffff}]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$/iu,email:/^[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$/i,hostname:/^(?=.{1,253}\.?$)[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[-0-9a-z]{0,61}[0-9a-z])?)*\.?$/i,ipv4:/^(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)\.){3}(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)$/,ipv6:/^((([0-9a-f]{1,4}:){7}([0-9a-f]{1,4}|:))|(([0-9a-f]{1,4}:){6}(:[0-9a-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9a-f]{1,4}:){5}(((:[0-9a-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9a-f]{1,4}:){4}(((:[0-9a-f]{1,4}){1,3})|((:[0-9a-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9a-f]{1,4}:){3}(((:[0-9a-f]{1,4}){1,4})|((:[0-9a-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9a-f]{1,4}:){2}(((:[0-9a-f]{1,4}){1,5})|((:[0-9a-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9a-f]{1,4}:){1}(((:[0-9a-f]{1,4}){1,6})|((:[0-9a-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9a-f]{1,4}){1,7})|((:[0-9a-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))$/i,regex:PD,uuid:/^(?:urn:uuid:)?[0-9a-f]{8}-(?:[0-9a-f]{4}-){3}[0-9a-f]{12}$/i,"json-pointer":/^(?:\/(?:[^~/]|~0|~1)*)*$/,"json-pointer-uri-fragment":/^#(?:\/(?:[a-z0-9_\-.!$&'()*+,;:=@]|%[0-9a-f]{2}|~0|~1)*)*$/i,"relative-json-pointer":/^(?:0|[1-9][0-9]*)(?:#|(?:\/(?:[^~/]|~0|~1)*)*)$/,byte:vD,int32:{type:"number",validate:ED},int64:{type:"number",validate:wD},float:{type:"number",validate:Mv},double:{type:"number",validate:Mv},password:!0,binary:!0};_r.fastFormats={..._r.fullFormats,date:yr(/^\d\d\d\d-[0-1]\d-[0-3]\d$/,im),time:yr(/^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i,am),"date-time":yr(/^\d\d\d\d-[0-1]\d-[0-3]\dt(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i,Lv),"iso-time":yr(/^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)?$/i,zv),"iso-date-time":yr(/^\d\d\d\d-[0-1]\d-[0-3]\d[t\s](?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)?$/i,Hv),uri:/^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/)?[^\s]*$/i,"uri-reference":/^(?:(?:[a-z][a-z0-9+\-.]*:)?\/?\/)?(?:[^\\\s#][^\s#]*)?(?:#[^\\\s]*)?$/i,email:/^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i};_r.formatNames=Object.keys(_r.fullFormats);function hD(t){return t%4===0&&(t%100!==0||t%400===0)}var gD=/^(\d\d\d\d)-(\d\d)-(\d\d)$/,yD=[0,31,28,31,30,31,30,31,31,30,31,30,31];function jv(t){let e=gD.exec(t);if(!e)return!1;let r=+e[1],n=+e[2],o=+e[3];return n>=1&&n<=12&&o>=1&&o<=(n===2&&hD(r)?29:yD[n])}function im(t,e){if(t&&e)return t>e?1:t<e?-1:0}var nm=/^(\d\d):(\d\d):(\d\d(?:\.\d+)?)(z|([+-])(\d\d)(?::?(\d\d))?)?$/i;function om(t){return function(r){let n=nm.exec(r);if(!n)return!1;let o=+n[1],s=+n[2],i=+n[3],a=n[4],c=n[5]==="-"?-1:1,u=+(n[6]||0),l=+(n[7]||0);if(u>23||l>59||t&&!a)return!1;if(o<=23&&s<=59&&i<60)return!0;let d=s-l*c,f=o-u*c-(d<0?1:0);return(f===23||f===-1)&&(d===59||d===-1)&&i<61}}function am(t,e){if(!(t&&e))return;let r=new Date("2020-01-01T"+t).valueOf(),n=new Date("2020-01-01T"+e).valueOf();if(r&&n)return r-n}function zv(t,e){if(!(t&&e))return;let r=nm.exec(t),n=nm.exec(e);if(r&&n)return t=r[1]+r[2]+r[3],e=n[1]+n[2]+n[3],t>e?1:t<e?-1:0}var sm=/t|\s/i;function Nv(t){let e=om(t);return function(n){let o=n.split(sm);return o.length===2&&jv(o[0])&&e(o[1])}}function Lv(t,e){if(!(t&&e))return;let r=new Date(t).valueOf(),n=new Date(e).valueOf();if(r&&n)return r-n}function Hv(t,e){if(!(t&&e))return;let[r,n]=t.split(sm),[o,s]=e.split(sm),i=im(r,o);if(i!==void 0)return i||am(n,s)}var _D=/\/|:/,xD=/^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;function SD(t){return _D.test(t)&&xD.test(t)}var Dv=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/gm;function vD(t){return Dv.lastIndex=0,Dv.test(t)}var bD=-(2**31),kD=2**31-1;function ED(t){return Number.isInteger(t)&&t<=kD&&t>=bD}function wD(t){return Number.isInteger(t)}function Mv(){return!0}var TD=/[^\\]\\Z/;function PD(t){if(TD.test(t))return!1;try{return new RegExp(t),!0}catch{return!1}}});var Fv=N(Ko=>{"use strict";Object.defineProperty(Ko,"__esModule",{value:!0});Ko.formatLimitDefinition=void 0;var RD=rm(),rr=Q(),cn=rr.operators,Pc={formatMaximum:{okStr:"<=",ok:cn.LTE,fail:cn.GT},formatMinimum:{okStr:">=",ok:cn.GTE,fail:cn.LT},formatExclusiveMaximum:{okStr:"<",ok:cn.LT,fail:cn.GTE},formatExclusiveMinimum:{okStr:">",ok:cn.GT,fail:cn.LTE}},$D={message:({keyword:t,schemaCode:e})=>(0,rr.str)`should be ${Pc[t].okStr} ${e}`,params:({keyword:t,schemaCode:e})=>(0,rr._)`{comparison: ${Pc[t].okStr}, limit: ${e}}`};Ko.formatLimitDefinition={keyword:Object.keys(Pc),type:"string",schemaType:"string",$data:!0,error:$D,code(t){let{gen:e,data:r,schemaCode:n,keyword:o,it:s}=t,{opts:i,self:a}=s;if(!i.validateFormats)return;let c=new RD.KeywordCxt(s,a.RULES.all.format.definition,"format");c.$data?u():l();function u(){let f=e.scopeValue("formats",{ref:a.formats,code:i.code.formats}),h=e.const("fmt",(0,rr._)`${f}[${c.schemaCode}]`);t.fail$data((0,rr.or)((0,rr._)`typeof ${h} != "object"`,(0,rr._)`${h} instanceof RegExp`,(0,rr._)`typeof ${h}.compare != "function"`,d(h)))}function l(){let f=c.schema,h=a.formats[f];if(!h||h===!0)return;if(typeof h!="object"||h instanceof RegExp||typeof h.compare!="function")throw new Error(`"${o}": format "${f}" does not define "compare" function`);let p=e.scopeValue("formats",{key:f,ref:h,code:i.code.formats?(0,rr._)`${i.code.formats}${(0,rr.getProperty)(f)}`:void 0});t.fail$data(d(p))}function d(f){return(0,rr._)`${f}.compare(${r}, ${n}) ${Pc[o].fail} 0`}},dependencies:["format"]};var CD=t=>(t.addKeyword(Ko.formatLimitDefinition),t);Ko.default=CD});var Vv=N((vi,Bv)=>{"use strict";Object.defineProperty(vi,"__esModule",{value:!0});var Go=Uv(),OD=Fv(),cm=Q(),Zv=new cm.Name("fullFormats"),ID=new cm.Name("fastFormats"),um=(t,e={keywords:!0})=>{if(Array.isArray(e))return qv(t,e,Go.fullFormats,Zv),t;let[r,n]=e.mode==="fast"?[Go.fastFormats,ID]:[Go.fullFormats,Zv],o=e.formats||Go.formatNames;return qv(t,o,r,n),e.keywords&&(0,OD.default)(t),t};um.get=(t,e="full")=>{let n=(e==="fast"?Go.fastFormats:Go.fullFormats)[t];if(!n)throw new Error(`Unknown format "${t}"`);return n};function qv(t,e,r,n){var o,s;(o=(s=t.opts.code).formats)!==null&&o!==void 0||(s.formats=(0,cm._)`require("ajv-formats/dist/formats").${n}`);for(let i of e)t.addFormat(i,r[i])}Bv.exports=vi=um;Object.defineProperty(vi,"__esModule",{value:!0});vi.default=um});function ki(t,e){let r=process.execPath.replace(/\\/g,"/");if(Mc(e?.platform)){let o=r.split("/").pop().replace(/\.exe$/i,"");fm.has(o)||(r=e?.jsRuntime?.replace(/\\/g,"/")??"node")}let n=t.replace(/\\/g,"/");return`"${r}" "${n}"`}function Ze(t,e){if(Mc(e?.platform))return ki(t,e);let n=ib().path.replace(/\\/g,"/"),o=t.replace(/\\/g,"/");return`"${n}" "${o}"`}function Dc(t){if(typeof t!="string"||t.length===0)return null;let e=t.match(/^"([^"]+)"\s+"([^"]+)"\s*$/);return e?{nodePath:e[1],scriptPath:e[2]}:null}function Mc(t){return!!t&&HD.has(t)}var fm,HD,Nr=ne(()=>{"use strict";jc();fm=new Set(["node","bun","deno"]),HD=new Set(["opencode","kilo"])});import{execFileSync as gm,execSync as Jo}from"node:child_process";import{existsSync as zc}from"node:fs";function hm(t){let e=t.split(/[\\/]/);return e[e.length-1]??t}function FD(t){return UD.test(hm(t))}function ZD(t){let e=t.toLowerCase().replace(/\//g,"\\");return/\\windows\\(?:system32|sysnative)\\bash\.exe$/.test(e)||/\\microsoft\\windowsapps\\bash\.exe$/.test(e)}function Be(t){try{let e=Ei?`where ${t}`:`command -v ${t}`;return Jo(e,{stdio:"pipe"}),!0}catch{return!1}}function mm(t){if(Ei)try{let r=Jo(`where ${t}`,{encoding:"utf-8",stdio:"pipe"}).trim().split(/\r?\n/).map(o=>o.trim()).filter(Boolean);if(r.length===0||r.filter(o=>!/\\Microsoft\\WindowsApps\\/i.test(o)).length===0)return!1}catch{return!1}else if(!Be(t))return!1;try{return Ei?Jo(`"${t}" --version`,{stdio:"pipe",timeout:5e3}):gm(t,["--version"],{stdio:"pipe",timeout:1500}),!0}catch{return!1}}function ym(){if(Be("bun"))return!0;for(let t of ub())if(zc(t))return!0;return!1}function cb(){for(let e of ub())if(zc(e))return e;if(Be("bun"))return"bun";let t=process.env.HOME??process.env.USERPROFILE??"";return Ei?`${t}\\.bun\\bin\\bun.exe`:`${t}/.bun/bin/bun`}function ub(){let t=process.env.HOME??process.env.USERPROFILE??"";if(Ei){let e=process.env.LOCALAPPDATA??"",r=process.env.APPDATA??"";return[...t?[`${t}\\.bun\\bin\\bun.exe`]:[],...e?[`${e}\\bun\\bin\\bun.exe`]:[],...r?[`${r}\\npm\\node_modules\\bun\\bin\\bun.exe`]:[]]}return t?[`${t}/.bun/bin/bun`]:[]}function qD(){let t=["C:\\Program Files\\Git\\usr\\bin\\bash.exe","C:\\Program Files (x86)\\Git\\usr\\bin\\bash.exe"];for(let e of t)if(zc(e))return e;try{let r=Jo("where bash",{encoding:"utf-8",stdio:"pipe"}).trim().split(/\r?\n/).map(n=>n.trim()).filter(Boolean);for(let n of r){let o=n.toLowerCase();if(!(o.includes("system32")||o.includes("windowsapps")))return n}return null}catch{return null}}function Lt(t,e=["--version"]){try{if(process.platform==="win32"){let r=[t,...e].map(n=>/[\s"&|<>^()%!]/.test(n)?JSON.stringify(n):n).join(" ");return Jo(r,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}).trim().split(/\r?\n/)[0]}else return gm(t,e,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3}).trim().split(/\r?\n/)[0]}catch{return"unknown"}}function BD(t,e={}){if(t)return t;let r=e.execPath??process.execPath,n=e.commandExists??Be,o=r.split(/[\\/]/).pop().replace(/\.exe$/i,"");return fm.has(o)?r:n("node")?"node":null}function Lc(){let e=ym()?cb():null,r=process.env.SHELL,n=process.platform==="win32",o=r&&zc(r)&&FD(r)&&!(n&&ZD(r))?r:null;return{javascript:BD(e),typescript:e||(Be("tsx")?"tsx":Be("ts-node")?"ts-node":null),python:mm("python3")?"python3":mm("python")?"python":mm("py")?"py":null,shell:o??(n?qD()??(Be("sh")?"sh":Be("powershell")?"powershell":"cmd.exe"):Be("bash")?"bash":"sh"),ruby:Be("ruby")?"ruby":null,go:Be("go")?"go":null,rust:Be("rustc")?"rustc":null,php:Be("php")?"php":null,perl:Be("perl")?"perl":null,r:Be("Rscript")?"Rscript":Be("r")?"r":null,elixir:Be("elixir")?"elixir":null,csharp:Be("dotnet-script")?"dotnet-script":null}}function Hc(){return ym()}function VD(t){let e=t.trim(),r=/^(\d+)\.(\d+)\.(\d+)/.exec(e);if(!r)return!1;let n=Number(r[1]);return Number.isFinite(n)&&n>=1}function ib(){if(Ht)return Ht;let t={path:process.execPath,isBun:!1};try{if(!ym())return Ht=t,Ht;let e=cb(),r;try{if(process.platform==="win32"){let n=Jo(`"${e}" --version`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3});r=String(n)}else{let n=gm(e,["--version"],{encoding:"utf-8",stdio:["pipe","pipe","pipe"],timeout:5e3});r=String(n)}}catch{return Ht=t,Ht}return VD(r)?(Ht={path:e,isBun:!0},Ht):(Ht=t,Ht)}catch{return Ht=t,Ht}}function lb(t){let e=[],r=t.javascript?.endsWith("bun")??!1;return t.javascript?e.push(` JavaScript: ${t.javascript} (${Lt(t.javascript)})${r?" \u26A1":""}`):e.push(" JavaScript: not available (install node or bun \u2014 host process is not a JS runtime)"),t.typescript?e.push(` TypeScript: ${t.typescript} (${Lt(t.typescript)})`):e.push(" TypeScript: not available (install bun, tsx, or ts-node)"),t.python?e.push(` Python: ${t.python} (${Lt(t.python)})`):e.push(" Python: not available"),e.push(` Shell: ${t.shell} (${Lt(t.shell)})`),t.ruby&&e.push(` Ruby: ${t.ruby} (${Lt(t.ruby)})`),t.go&&e.push(` Go: ${t.go} (${Lt(t.go,["version"])})`),t.rust&&e.push(` Rust: ${t.rust} (${Lt(t.rust)})`),t.php&&e.push(` PHP: ${t.php} (${Lt(t.php)})`),t.perl&&e.push(` Perl: ${t.perl} (${Lt(t.perl)})`),t.r&&e.push(` R: ${t.r} (${Lt(t.r)})`),t.elixir&&e.push(` Elixir: ${t.elixir} (${Lt(t.elixir)})`),t.csharp&&e.push(` C#: ${t.csharp} (${Lt(t.csharp)})`),r||(e.push(""),e.push(" Tip: Install Bun for 3-5x faster JS/TS execution \u2192 https://bun.sh")),e.join(`
|
|
10
10
|
`)}function db(t){let e=["javascript","shell"];return t.typescript&&e.push("typescript"),t.python&&e.push("python"),t.ruby&&e.push("ruby"),t.go&&e.push("go"),t.rust&&e.push("rust"),t.php&&e.push("php"),t.perl&&e.push("perl"),t.r&&e.push("r"),t.elixir&&e.push("elixir"),t.csharp&&e.push("csharp"),e}function pb(t,e,r){switch(e){case"javascript":if(!t.javascript)throw new Error("No JavaScript runtime available. Install Node.js or Bun on PATH (the host process is not itself a JS runtime).");return ab.test(hm(t.javascript))?[t.javascript,"run",r]:[t.javascript,r];case"typescript":if(!t.typescript)throw new Error("No TypeScript runtime available. Install one of: bun (recommended), tsx (npm i -g tsx), or ts-node.");return ab.test(hm(t.typescript))?[t.typescript,"run",r]:t.typescript==="tsx"?["tsx",r]:["ts-node",r];case"python":if(!t.python)throw new Error("No Python runtime available. Install python3 or python.");return[t.python,r];case"shell":{if(process.platform==="win32"){let o=t.shell.toLowerCase();if(o.includes("bash")||o.endsWith("/sh")||o.endsWith("\\sh.exe")){let i=r.replace(/'/g,"'\\''");return[t.shell,"-c",`source '${i}'`]}if(o.includes("powershell")||o.includes("pwsh"))return[t.shell,"-NoProfile","-ExecutionPolicy","Bypass","-File",r];let s=o.split(/[\\/]/).pop()??o;if(s==="cmd"||s==="cmd.exe")return[t.shell,"/d","/s","/c",r]}return[t.shell,r]}case"ruby":if(!t.ruby)throw new Error("Ruby not available. Install ruby.");return[t.ruby,r];case"go":if(!t.go)throw new Error("Go not available. Install go.");return["go","run",r];case"rust":{if(!t.rust)throw new Error("Rust not available. Install rustc via https://rustup.rs");return["__rust_compile_run__",r]}case"php":if(!t.php)throw new Error("PHP not available. Install php.");return["php",r];case"perl":if(!t.perl)throw new Error("Perl not available. Install perl.");return["perl",r];case"r":if(!t.r)throw new Error("R not available. Install R / Rscript.");return[t.r,r];case"elixir":if(!t.elixir)throw new Error("Elixir not available. Install elixir.");return["elixir",r];case"csharp":if(!t.csharp)throw new Error("C# not available. Install dotnet-script via `dotnet tool install -g dotnet-script`.");return[t.csharp,r]}}var UD,ab,Ei,Ht,jc=ne(()=>{"use strict";Nr();UD=/^(bash|sh|zsh|dash|pwsh|powershell|cmd)(\.exe)?$/i,ab=/^bun(\.exe)?$/i;Ei=process.platform==="win32";Ht=null});import{createRequire as nM}from"node:module";import{existsSync as oM,unlinkSync as xb,renameSync as sM}from"node:fs";import{tmpdir as iM}from"node:os";import{join as aM}from"node:path";function cM(t){let e=null;try{return e=new t(":memory:"),e.exec("CREATE VIRTUAL TABLE __fts5_probe USING fts5(x)"),!0}catch{return!1}finally{try{e?.close()}catch{}}}function uM(t,e){let r=e!==void 0?e:globalThis.Bun;if(typeof r<"u"&&r!==null)return!0;let n=t??process.versions,[o,s]=(n.node??"0.0.0").split("."),i=Number(o),a=Number(s);return!Number.isFinite(i)||!Number.isFinite(a)?!1:i>22||i===22&&a>=5}function Ye(){if(!Xo){let t=nM(import.meta.url);if(globalThis.Bun){let e=t(["bun","sqlite"].join(":")).Database;Xo=function(n,o){let s=new e(n,{readonly:o?.readonly,create:!0}),i=new vm(s);return o?.timeout&&i.pragma(`busy_timeout = ${o.timeout}`),i}}else if(uM()){let e=null;try{({DatabaseSync:e}=t(["node","sqlite"].join(":")))}catch{e=null}e&&cM(e)?Xo=function(n,o){let s=new e(n,{readOnly:o?.readonly??!1}),i=new bm(s);return o?.timeout&&i.pragma(`busy_timeout = ${o.timeout}`),i}:Xo=t("better-sqlite3")}else Xo=t("better-sqlite3")}return Xo}function Pi(t){t.pragma("journal_mode = WAL"),t.pragma("synchronous = NORMAL");try{t.pragma("mmap_size = 268435456")}catch{}}function Ri(t){if(!oM(t))for(let e of["-wal","-shm"])try{xb(t+e)}catch{}}function km(t){for(let e of["","-wal","-shm"])try{xb(t+e)}catch{}}function $i(t){try{t.pragma("wal_checkpoint(TRUNCATE)")}catch{}try{t.close()}catch{}}function Sb(t="context-mode"){return aM(iM(),`${t}-${process.pid}.db`)}function Jn(t,e=[100,500,2e3]){let r;for(let n=0;n<=e.length;n++)try{return t()}catch(o){let s=o instanceof Error?o.message:String(o);if(!s.includes("SQLITE_BUSY")&&!s.includes("database is locked"))throw o;if(r=o instanceof Error?o:new Error(s),n<e.length){let i=e[n],a=Date.now();for(;Date.now()-a<i;);}}throw new Error(`SQLITE_BUSY: database is locked after ${e.length} retries. Original error: ${r?.message}`)}function Em(t){return t.includes("SQLITE_CORRUPT")||t.includes("SQLITE_NOTADB")||t.includes("database disk image is malformed")||t.includes("file is not a database")}function lM(t){let e=Date.now();for(let r of["","-wal","-shm"])try{sM(t+r,`${t}${r}.corrupt-${e}`)}catch{}}var vm,bm,Xo,Ti,Sm,Fc,Yo=ne(()=>{"use strict";vm=class{#e;constructor(e){this.#e=e}pragma(e){let n=this.#e.prepare(`PRAGMA ${e}`).all();if(!n||n.length===0)return;if(n.length>1)return n;let o=Object.values(n[0]);return o.length===1?o[0]:n[0]}exec(e){let r="",n=null;for(let s=0;s<e.length;s++){let i=e[s];if(n)r+=i,i===n&&(n=null);else if(i==="'"||i==='"')r+=i,n=i;else if(i===";"){let a=r.trim();a&&this.#e.prepare(a).run(),r=""}else r+=i}let o=r.trim();return o&&this.#e.prepare(o).run(),this}prepare(e){let r=this.#e.prepare(e);return{run:(...n)=>r.run(...n),get:(...n)=>{let o=r.get(...n);return o===null?void 0:o},all:(...n)=>r.all(...n),iterate:(...n)=>r.iterate(...n)}}transaction(e){return this.#e.transaction(e)}close(){this.#e.close()}},bm=class{#e;constructor(e){this.#e=e}pragma(e){let n=this.#e.prepare(`PRAGMA ${e}`).all();if(!n||n.length===0)return;if(n.length>1)return n;let o=Object.values(n[0]);return o.length===1?o[0]:n[0]}exec(e){return this.#e.exec(e),this}prepare(e){let r=this.#e.prepare(e);return{run:(...n)=>r.run(...n),get:(...n)=>r.get(...n),all:(...n)=>r.all(...n),iterate:(...n)=>typeof r.iterate=="function"?r.iterate(...n):r.all(...n)[Symbol.iterator]()}}transaction(e){return(...r)=>{this.#e.exec("BEGIN");try{let n=e(...r);return this.#e.exec("COMMIT"),n}catch(n){throw this.#e.exec("ROLLBACK"),n}}}close(){this.#e.close()}},Xo=null;Ti=Symbol.for("__context_mode_live_dbs_v3__"),Sm=(()=>{let t=globalThis;return t[Ti]||(t[Ti]=new Set,process.on("exit",()=>{for(let e of t[Ti])$i(e);t[Ti].clear()})),t[Ti]})(),Fc=class{#e;#t;constructor(e){let r=Ye();this.#e=e,Ri(e);let n;try{n=new r(e,{timeout:3e4}),Pi(n)}catch(o){let s=o instanceof Error?o.message:String(o);if(Em(s)){lM(e),Ri(e);try{n=new r(e,{timeout:3e4}),Pi(n)}catch(i){throw new Error(`Failed to create fresh DB after renaming corrupt file: ${i instanceof Error?i.message:String(i)}`)}}else throw o}this.#t=n,Sm.add(this.#t),this.initSchema(),this.prepareStatements()}get db(){return this.#t}get dbPath(){return this.#e}close(){Sm.delete(this.#t),$i(this.#t)}withRetry(e){return Jn(e)}cleanup(){Sm.delete(this.#t),$i(this.#t),km(this.#e)}}});var Db,Mb=ne(()=>{"use strict";Db={"claude-code":"claude-code","gemini-cli-mcp-client":"gemini-cli","antigravity-client":"antigravity","cursor-vscode":"cursor","Visual-Studio-Code":"vscode-copilot","JetBrains Client":"jetbrains-copilot","IntelliJ IDEA":"jetbrains-copilot",PyCharm:"jetbrains-copilot",Codex:"codex","codex-mcp-client":"codex","Kilo Code":"kilo","Kiro CLI":"kiro","Pi CLI":"pi","Pi Coding Agent":"pi","omp-coding-agent":"omp",Zed:"zed",zed:"zed","qwen-code":"qwen-code","qwen-cli-mcp-client":"qwen-code","kimi-code":"kimi",kimi:"kimi","Kimi Code":"kimi"}});import{createHash as Oi}from"node:crypto";import{execFileSync as AM}from"node:child_process";import{accessSync as NM,constants as DM,existsSync as Vc,mkdirSync as MM,realpathSync as jM,renameSync as Im}from"node:fs";import{homedir as Fb}from"node:os";import{dirname as zM,isAbsolute as Zb,join as ln,resolve as es}from"node:path";function Am(t){let e=t.env??process.env,r=t.legacySessionDirEnv,n=r?e[r]?.trim():void 0;return n&&r?(t.onLegacySessionDir?.(r,n),n):ln(LM(t.configDir,t.configDirEnv,e),"context-mode","sessions")}function LM(t,e,r){let n=e?r[e]:void 0;return n&&n.trim()!==""?zb(n.trim()):zb(t,Fb())}function zb(t,e){return t.startsWith("~")?es(Fb(),t.replace(/^~[/\\]?/,"")):Zb(t)?es(t):e?es(e,t):es(t)}function HM(t,e,r){return new dn(t,e,xr,void 0,[`Invalid ${xr} for context-mode ${t} directory: ${r}`,Kb()].join(`
|
|
11
11
|
`))}function Bb(t){let e=process.env[xr];if(e===void 0)return{kind:"unset"};let r=e.trim();if(!r)return{kind:"ignored-empty",ignoredEnvVar:xr,ignoredReason:"empty"};if(!Zb(r))throw HM(t,r,`${xr} must be an absolute path.`);return{kind:"override",root:es(r)}}function UM(t){return t.kind==="ignored-empty"?{ignoredEnvVar:t.ignoredEnvVar,ignoredReason:t.ignoredReason}:{}}function Vb(t,e){let r=Bb(t);return r.kind!=="override"?null:{kind:t,path:ln(r.root,e),envVar:xr,source:"override"}}function FM(t,e,r){return{kind:t,path:es(e()),envVar:null,source:"default",...r}}function Ii(t){let e=Bb("session");return e.kind==="override"?{kind:"session",path:ln(e.root,qb),envVar:xr,source:"override"}:FM("session",t,UM(e))}function Nm(t){let e=Vb("content",jb);if(e)return e;let r=Ii(t);return{kind:"content",path:ln(zM(r.path),jb),envVar:r.envVar,source:r.source,ignoredEnvVar:r.ignoredEnvVar,ignoredReason:r.ignoredReason}}function Dm(t){let e=Vb("stats",qb);if(e)return e;let r=Ii(t);return{kind:"stats",path:r.path,envVar:r.envVar,source:r.source,ignoredEnvVar:r.ignoredEnvVar,ignoredReason:r.ignoredReason}}function Wb(t){return t.message}function Wc(t){return t.source==="override"&&t.envVar?`via ${t.envVar}`:t.ignoredEnvVar&&t.ignoredReason==="empty"?`default; ignored empty ${t.ignoredEnvVar}`:"default"}function Kc(t){let e=[t.kind,t.path,t.source,t.envVar??"",t.ignoredEnvVar??"",t.ignoredReason??""].join("\0"),r=Om.get(e);if(r instanceof dn)throw r;if(r===t.path)return r;try{return MM(t.path,{recursive:!0}),NM(t.path,DM.W_OK),Om.set(e,t.path),t.path}catch(n){let o=new dn(t.kind,BM(n)??t.path,xr,n,void 0,{ignoredEnvVar:t.ignoredEnvVar,ignoredReason:t.ignoredReason});throw Om.set(e,o),o}}function ZM(t,e,r={}){return[`context-mode ${t} directory is not writable: ${e}`,qM(r),Kb()].filter(Boolean).join(`
|
|
12
|
-
`)}function qM(t){return t.ignoredEnvVar&&t.ignoredReason==="empty"?`Ignored empty ${t.ignoredEnvVar}; using adapter default.`:null}function Kb(){return`Set ${xr} to a writable absolute path.`}function BM(t){if(!t||typeof t!="object")return null;let e=t.path;return typeof e=="string"&&e.length>0?e:null}function Ai(t){let e=t.replace(/\\/g,"/");return/^\/+$/.test(e)?"/":/^[A-Za-z]:\/+$/.test(e)?`${e.slice(0,2)}/`:e.replace(/\/+$/,"")}function Lb(t){let e=t;try{e=jM.native(t)}catch{}let r=Ai(e);return process.platform==="win32"||process.platform==="darwin"?r.toLowerCase():r}function Gb(t,e){return AM("git",["-C",t,...e],{encoding:"utf-8",timeout:2e3,stdio:["ignore","pipe","ignore"]}).trim()}function VM(t){let e=Gb(t,["rev-parse","--show-toplevel"]);return e.length>0?Ai(e):null}function WM(t){let e=Gb(t,["worktree","list","--porcelain"]).split(/\r?\n/).find(r=>r.startsWith("worktree "))?.replace("worktree ","")?.trim();return e?Ai(e):null}function Gc(t=process.cwd()){let e=process.env.CONTEXT_MODE_SESSION_SUFFIX;if(Ci&&Ci.projectDir===t&&Ci.envSuffix===e)return Ci.suffix;let r="";if(e!==void 0)r=e?`__${e}`:"";else try{let n=VM(t),o=WM(t);if(n&&o){let s=Lb(n),i=Lb(o);s!==i&&(r=`__${Oi("sha256").update(s).digest("hex").slice(0,8)}`)}}catch{}return Ci={projectDir:t,envSuffix:e,suffix:r},r}function Dr(t){return Oi("sha256").update(Ai(t)).digest("hex").slice(0,16)}function Qe(t){let e=Ai(t),r=process.platform==="darwin"||process.platform==="win32"?e.toLowerCase():e;return Oi("sha256").update(r).digest("hex").slice(0,16)}function Jb(t){let{projectDir:e,contentDir:r}=t,n=Qe(e),o=ln(r,`${n}.db`);if(Vc(o))return o;let s=Dr(e);if(s===n)return o;let i=ln(r,`${s}.db`);if(Vc(i))try{Im(i,o);for(let a of["-wal","-shm"])try{Im(i+a,o+a)}catch{}}catch{}return o}function Ni(t){return KM({...t,ext:".db"})}function KM(t){let{projectDir:e,sessionsDir:r,ext:n}=t,o=t.suffix??Gc(e),s=Qe(e),i=ln(r,`${s}${o}${n}`);if(Vc(i))return i;let a=Dr(e);if(a===s)return i;let c=ln(r,`${a}${o}${n}`);if(Vc(c))try{Im(c,i)}catch{}return i}function Bc(t){let e=Number(t);return!Number.isFinite(e)||e<=0?0:Math.floor(e)}function Xb(t){let e=t.pragma("table_xinfo(session_events)"),r=new Set(e.map(o=>o.name)),n=!1;for(let[o,s]of GM)r.has(o)||(t.exec(`ALTER TABLE session_events ADD COLUMN ${o} ${s}`),n=!0);return n&&t.exec("CREATE INDEX IF NOT EXISTS idx_session_events_project ON session_events(session_id, project_dir)"),n}function Yb(t,e){let r=null;try{r=new e(t),Xb(r)}catch{}finally{try{r?.close()}catch{}}}var xr,qb,jb,dn,Om,Ci,Hb,Ub,j,GM,nr,Sr=ne(()=>{"use strict";Yo();xr="CONTEXT_MODE_DIR",qb="sessions",jb="content",dn=class extends Error{kind;path;overrideEnvVar;ignoredEnvVar;ignoredReason;constructor(e,r,n=xr,o,s,i={}){super(s??ZM(e,r,i),{cause:o}),this.name="StorageDirectoryError",this.kind=e,this.path=r,this.overrideEnvVar=n,this.ignoredEnvVar=i.ignoredEnvVar,this.ignoredReason=i.ignoredReason}},Om=new Map;Hb=1e3,Ub=5;j={insertEvent:"insertEvent",getEvents:"getEvents",getEventsByType:"getEventsByType",getEventsByPriority:"getEventsByPriority",getEventsByTypeAndPriority:"getEventsByTypeAndPriority",getEventCount:"getEventCount",getLatestAttributedProject:"getLatestAttributedProject",checkDuplicate:"checkDuplicate",evictLowestPriority:"evictLowestPriority",updateMetaLastEvent:"updateMetaLastEvent",ensureSession:"ensureSession",getSessionStats:"getSessionStats",getSessionRollup:"getSessionRollup",getMaxFileEdits:"getMaxFileEdits",incrementCompactCount:"incrementCompactCount",upsertResume:"upsertResume",getResume:"getResume",markResumeConsumed:"markResumeConsumed",claimLatestUnconsumedResume:"claimLatestUnconsumedResume",deleteEvents:"deleteEvents",deleteMeta:"deleteMeta",deleteResume:"deleteResume",getOldSessions:"getOldSessions",searchEvents:"searchEvents",incrementToolCall:"incrementToolCall",getToolCallTotals:"getToolCallTotals",getToolCallByTool:"getToolCallByTool",getEventBytesSummary:"getEventBytesSummary"},GM=[["project_dir","TEXT NOT NULL DEFAULT ''"],["attribution_source","TEXT NOT NULL DEFAULT 'unknown'"],["attribution_confidence","REAL NOT NULL DEFAULT 0"],["bytes_avoided","INTEGER NOT NULL DEFAULT 0"],["bytes_returned","INTEGER NOT NULL DEFAULT 0"]];nr=class extends Fc{constructor(e){super(e?.dbPath??Sb("session"))}stmt(e){return this.stmts.get(e)}initSchema(){try{let r=this.db.pragma("table_xinfo(session_events)").find(n=>n.name==="data_hash");r&&r.hidden!==0&&this.db.exec("DROP TABLE session_events")}catch{}this.db.exec(`
|
|
12
|
+
`)}function qM(t){return t.ignoredEnvVar&&t.ignoredReason==="empty"?`Ignored empty ${t.ignoredEnvVar}; using adapter default.`:null}function Kb(){return`Set ${xr} to a writable absolute path.`}function BM(t){if(!t||typeof t!="object")return null;let e=t.path;return typeof e=="string"&&e.length>0?e:null}function Ai(t){let e=t.replace(/\\/g,"/");return/^\/+$/.test(e)?"/":/^[A-Za-z]:\/+$/.test(e)?`${e.slice(0,2)}/`:e.replace(/\/+$/,"")}function Lb(t){let e=t;try{e=jM.native(t)}catch{}let r=Ai(e);return process.platform==="win32"||process.platform==="darwin"?r.toLowerCase():r}function Gb(t,e){return AM("git",["-C",t,...e],{encoding:"utf-8",timeout:2e3,stdio:["ignore","pipe","ignore"]}).trim()}function VM(t){let e=Gb(t,["rev-parse","--show-toplevel"]);return e.length>0?Ai(e):null}function WM(t){let e=Gb(t,["worktree","list","--porcelain"]).split(/\r?\n/).find(r=>r.startsWith("worktree "))?.replace("worktree ","")?.trim();return e?Ai(e):null}function Gc(t=process.cwd()){let e=process.env.CONTEXT_MODE_SESSION_SUFFIX;if(Ci&&Ci.projectDir===t&&Ci.envSuffix===e)return Ci.suffix;let r="";if(e!==void 0)r=e?`__${e}`:"";else try{let n=VM(t),o=WM(t);if(n&&o){let s=Lb(n),i=Lb(o);s!==i&&(r=`__${Oi("sha256").update(s).digest("hex").slice(0,8)}`)}}catch{}return Ci={projectDir:t,envSuffix:e,suffix:r},r}function Dr(t){return Oi("sha256").update(Ai(t)).digest("hex").slice(0,16)}function Qe(t){let e=Ai(t),r=process.platform==="darwin"||process.platform==="win32"?e.toLowerCase():e;return Oi("sha256").update(r).digest("hex").slice(0,16)}function Jb(t){let{projectDir:e,contentDir:r}=t,n=Qe(e),o=ln(r,`${n}.db`);if(Vc(o))return o;let s=Dr(e);if(s===n)return o;let i=ln(r,`${s}.db`);if(Vc(i))try{Im(i,o);for(let a of["-wal","-shm"])try{Im(i+a,o+a)}catch{}}catch{}return o}function Ni(t){return KM({...t,ext:".db"})}function KM(t){let{projectDir:e,sessionsDir:r,ext:n}=t,o=t.suffix??Gc(e),s=Qe(e),i=ln(r,`${s}${o}${n}`);if(Vc(i))return i;let a=Dr(e);if(a===s)return i;let c=ln(r,`${a}${o}${n}`);if(Vc(c))try{Im(c,i)}catch{}return i}function Bc(t){let e=Number(t);return!Number.isFinite(e)||e<=0?0:Math.floor(e)}function Xb(t){let e=t.pragma("table_xinfo(session_events)"),r=new Set(e.map(o=>o.name)),n=!1;for(let[o,s]of GM)r.has(o)||(t.exec(`ALTER TABLE session_events ADD COLUMN ${o} ${s}`),n=!0);return n&&t.exec("CREATE INDEX IF NOT EXISTS idx_session_events_project ON session_events(session_id, project_dir)"),n}function Yb(t,e){let r=null;try{r=new e(t),Xb(r)}catch{}finally{try{r?.close()}catch{}}}var xr,qb,jb,dn,Om,Ci,Hb,Ub,j,GM,nr,Sr=ne(()=>{"use strict";Yo();xr="CONTEXT_MODE_DIR",qb="sessions",jb="content",dn=class extends Error{kind;path;overrideEnvVar;ignoredEnvVar;ignoredReason;constructor(e,r,n=xr,o,s,i={}){super(s??ZM(e,r,i),{cause:o}),this.name="StorageDirectoryError",this.kind=e,this.path=r,this.overrideEnvVar=n,this.ignoredEnvVar=i.ignoredEnvVar,this.ignoredReason=i.ignoredReason}},Om=new Map;Hb=1e3,Ub=5;j={insertEvent:"insertEvent",getEvents:"getEvents",getEventsByType:"getEventsByType",getEventsByPriority:"getEventsByPriority",getEventsByTypeAndPriority:"getEventsByTypeAndPriority",getEventCount:"getEventCount",getLatestAttributedProject:"getLatestAttributedProject",checkDuplicate:"checkDuplicate",evictLowestPriority:"evictLowestPriority",updateMetaLastEvent:"updateMetaLastEvent",ensureSession:"ensureSession",getSessionStats:"getSessionStats",getSessionRollup:"getSessionRollup",getMaxFileEdits:"getMaxFileEdits",getLatestCommitMessage:"getLatestCommitMessage",incrementCompactCount:"incrementCompactCount",upsertResume:"upsertResume",getResume:"getResume",markResumeConsumed:"markResumeConsumed",claimLatestUnconsumedResume:"claimLatestUnconsumedResume",deleteEvents:"deleteEvents",deleteMeta:"deleteMeta",deleteResume:"deleteResume",getOldSessions:"getOldSessions",searchEvents:"searchEvents",incrementToolCall:"incrementToolCall",getToolCallTotals:"getToolCallTotals",getToolCallByTool:"getToolCallByTool",getEventBytesSummary:"getEventBytesSummary"},GM=[["project_dir","TEXT NOT NULL DEFAULT ''"],["attribution_source","TEXT NOT NULL DEFAULT 'unknown'"],["attribution_confidence","REAL NOT NULL DEFAULT 0"],["bytes_avoided","INTEGER NOT NULL DEFAULT 0"],["bytes_returned","INTEGER NOT NULL DEFAULT 0"]];nr=class extends Fc{constructor(e){super(e?.dbPath??Sb("session"))}stmt(e){return this.stmts.get(e)}initSchema(){try{let r=this.db.pragma("table_xinfo(session_events)").find(n=>n.name==="data_hash");r&&r.hidden!==0&&this.db.exec("DROP TABLE session_events")}catch{}this.db.exec(`
|
|
13
13
|
CREATE TABLE IF NOT EXISTS session_events (
|
|
14
14
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
15
15
|
session_id TEXT NOT NULL,
|
|
@@ -101,7 +101,7 @@ var Uw=Object.create;var Mu=Object.defineProperty;var Fw=Object.getOwnPropertyDe
|
|
|
101
101
|
COALESCE(SUM(CASE WHEN category = 'error' THEN 1 ELSE 0 END), 0) AS errors,
|
|
102
102
|
COUNT(DISTINCT type) AS unique_tools,
|
|
103
103
|
COUNT(DISTINCT CASE WHEN category = 'file' THEN data END) AS unique_files,
|
|
104
|
-
CASE WHEN SUM(CASE WHEN
|
|
104
|
+
CASE WHEN SUM(CASE WHEN type = 'git_commit' THEN 1 ELSE 0 END) > 0 THEN 1 ELSE 0 END AS has_commit,
|
|
105
105
|
CAST(COALESCE((MAX(strftime('%s', created_at)) - MIN(strftime('%s', created_at))) / 60.0, 0) AS INTEGER) AS duration_min,
|
|
106
106
|
COALESCE(SUM(CASE WHEN type = 'external_ref' THEN 1 ELSE 0 END), 0) AS sources_indexed,
|
|
107
107
|
CAST(COALESCE(SUM(bytes_avoided) / 1024.0, 0) AS INTEGER) AS total_chunks,
|
|
@@ -113,7 +113,11 @@ var Uw=Object.create;var Mu=Object.defineProperty;var Fw=Object.getOwnPropertyDe
|
|
|
113
113
|
FROM session_events
|
|
114
114
|
WHERE session_id = ? AND category = 'file' AND type IN ('file_edit', 'file_write')
|
|
115
115
|
GROUP BY data
|
|
116
|
-
)`),e(j.
|
|
116
|
+
)`),e(j.getLatestCommitMessage,`SELECT data
|
|
117
|
+
FROM session_events
|
|
118
|
+
WHERE session_id = ? AND type = 'git_commit'
|
|
119
|
+
ORDER BY id DESC
|
|
120
|
+
LIMIT 1`),e(j.incrementCompactCount,"UPDATE session_meta SET compact_count = compact_count + 1 WHERE session_id = ?"),e(j.upsertResume,`INSERT INTO session_resume (session_id, snapshot, event_count)
|
|
117
121
|
VALUES (?, ?, ?)
|
|
118
122
|
ON CONFLICT(session_id) DO UPDATE SET
|
|
119
123
|
snapshot = excluded.snapshot,
|
|
@@ -146,7 +150,7 @@ var Uw=Object.create;var Mu=Object.defineProperty;var Fw=Object.getOwnPropertyDe
|
|
|
146
150
|
COALESCE(SUM(bytes_returned), 0) AS bytes_returned
|
|
147
151
|
FROM session_events WHERE session_id = ?`)}insertEvent(e,r,n="PostToolUse",o,s){let i=Oi("sha256").update(r.data).digest("hex").slice(0,16).toUpperCase(),a=String(o?.projectDir??r.project_dir??this._getSessionProjectDir(e)).trim(),c=String(o?.source??r.attribution_source??"unknown"),u=Number(o?.confidence??r.attribution_confidence??0),l=Number.isFinite(u)?Math.max(0,Math.min(1,u)):0,d=Bc(s?.bytesAvoided),f=Bc(s?.bytesReturned),h=this.db.transaction(()=>{if(this.stmt(j.checkDuplicate).get(e,Ub,r.type,i))return;this.stmt(j.getEventCount).get(e).cnt>=Hb&&this.stmt(j.evictLowestPriority).run(e),this.stmt(j.insertEvent).run(e,r.type,r.category,r.priority,r.data,a,c,l,d,f,n,i),this.stmt(j.updateMetaLastEvent).run(e)});this.withRetry(()=>h())}bulkInsertEvents(e,r,n="PostToolUse",o,s){if(!r||r.length===0)return;if(r.length===1){this.insertEvent(e,r[0],n,o?.[0],s?.[0]);return}let i=r.map((c,u)=>{let l=Oi("sha256").update(c.data).digest("hex").slice(0,16).toUpperCase(),d=o?.[u],f=String(d?.projectDir??c.project_dir??this._getSessionProjectDir(e)??"").trim(),h=String(d?.source??c.attribution_source??"unknown"),p=Number(d?.confidence??c.attribution_confidence??0),m=Number.isFinite(p)?Math.max(0,Math.min(1,p)):0,g=s?.[u],y=Bc(g?.bytesAvoided),_=Bc(g?.bytesReturned);return{event:c,dataHash:l,projectDir:f,attributionSource:h,attributionConfidence:m,bytesAvoided:y,bytesReturned:_}}),a=this.db.transaction(()=>{let c=this.stmt(j.getEventCount).get(e).cnt;for(let u of i)this.stmt(j.checkDuplicate).get(e,Ub,u.event.type,u.dataHash)||(c>=Hb?this.stmt(j.evictLowestPriority).run(e):c++,this.stmt(j.insertEvent).run(e,u.event.type,u.event.category,u.event.priority,u.event.data,u.projectDir,u.attributionSource,u.attributionConfidence,u.bytesAvoided,u.bytesReturned,n,u.dataHash));this.stmt(j.updateMetaLastEvent).run(e)});this.withRetry(()=>a())}getEvents(e,r){let n=r?.limit??1e3,o=r?.type,s=r?.minPriority;return o&&s!==void 0?this.stmt(j.getEventsByTypeAndPriority).all(e,o,s,n):o?this.stmt(j.getEventsByType).all(e,o,n):s!==void 0?this.stmt(j.getEventsByPriority).all(e,s,n):this.stmt(j.getEvents).all(e,n)}getEventCount(e){return this.stmt(j.getEventCount).get(e).cnt}getEventBytesSummary(e){let r=this.stmt(j.getEventBytesSummary).get(e);return{bytesAvoided:Number(r?.bytes_avoided??0),bytesReturned:Number(r?.bytes_returned??0)}}getLatestAttributedProjectDir(e){return this.stmt(j.getLatestAttributedProject).get(e)?.project_dir||null}_getSessionProjectDir(e){try{return this.db.prepare("SELECT project_dir FROM session_meta WHERE session_id = ?").get(e)?.project_dir||""}catch{return""}}searchEvents(e,r,n,o){try{let s=e.replace(/[%_]/g,a=>"\\"+a),i=o??null;return this.stmt(j.searchEvents).all(n,s,s,i,i,r)}catch{return[]}}getSessionIdsForProject(e){try{return this.db.prepare(`SELECT DISTINCT session_id
|
|
148
152
|
FROM session_events
|
|
149
|
-
WHERE project_dir = ?`).all(e).map(n=>n.session_id)}catch{return[]}}ensureSession(e,r){this.stmt(j.ensureSession).run(e,r)}getSessionStats(e){return this.stmt(j.getSessionStats).get(e)??null}getSessionRollup(e){let r=this.stmt(j.getSessionRollup).get(e),n=this.stmt(j.getMaxFileEdits).get(e),o=this.
|
|
153
|
+
WHERE project_dir = ?`).all(e).map(n=>n.session_id)}catch{return[]}}ensureSession(e,r){this.stmt(j.ensureSession).run(e,r)}getSessionStats(e){return this.stmt(j.getSessionStats).get(e)??null}getSessionRollup(e){let r=this.stmt(j.getSessionRollup).get(e),n=this.stmt(j.getMaxFileEdits).get(e),o=this.stmt(j.getLatestCommitMessage).get(e),s=this.getSessionStats(e),i=(r?.tool_calls??0)>0?r?.unique_files??0:0,a=r?.errors??0,c=Math.min(i,a);return{tool_calls:r?.tool_calls??0,errors:r?.errors??0,unique_tools:r?.unique_tools??0,unique_files:r?.unique_files??0,max_file_edits:n?.max_file_edits??0,has_commit:r?.has_commit??0,commit_message:o?.data??"",edit_test_cycles:c,duration_min:r?.duration_min??0,compact_count:s?.compact_count??0,sources_indexed:r?.sources_indexed??0,total_chunks:r?.total_chunks??0,search_queries:r?.search_queries??0}}incrementCompactCount(e){this.stmt(j.incrementCompactCount).run(e)}upsertResume(e,r,n){this.stmt(j.upsertResume).run(e,r,n??0)}getResume(e){return this.stmt(j.getResume).get(e)??null}markResumeConsumed(e){this.stmt(j.markResumeConsumed).run(e)}claimLatestUnconsumedResume(e){let r=this.stmt(j.claimLatestUnconsumedResume).get(e);return r?{sessionId:r.session_id,snapshot:r.snapshot}:null}getLatestSessionId(){try{return this.db.prepare("SELECT session_id FROM session_meta ORDER BY started_at DESC LIMIT 1").get()?.session_id??null}catch{return null}}incrementToolCall(e,r,n=0){let o=Number.isFinite(n)&&n>0?Math.round(n):0;try{this.stmt(j.incrementToolCall).run(e,r,o)}catch{}}getToolCallStats(e){try{let r=this.stmt(j.getToolCallTotals).get(e),n=this.stmt(j.getToolCallByTool).all(e),o={};for(let s of n)o[s.tool]={calls:s.calls,bytesReturned:s.bytes_returned};return{totalCalls:r?.calls??0,totalBytesReturned:r?.bytes_returned??0,byTool:o}}catch{return{totalCalls:0,totalBytesReturned:0,byTool:{}}}}deleteSession(e){this.db.transaction(()=>{this.stmt(j.deleteEvents).run(e),this.stmt(j.deleteResume).run(e),this.stmt(j.deleteMeta).run(e)})()}cleanupOldSessions(e=7){let r=`-${e}`,n=this.stmt(j.getOldSessions).all(r);for(let{session_id:o}of n)this.deleteSession(o);return n.length}pruneOrphanedEvents(){let e=this.db.prepare("DELETE FROM session_events WHERE session_id NOT IN (SELECT session_id FROM session_meta)").run();return Number(e.changes??0)}}});import{join as ts,resolve as Qb}from"node:path";import{accessSync as JM,copyFileSync as XM,constants as YM,mkdirSync as QM}from"node:fs";import{homedir as Mm}from"node:os";function St(t=process.env){let e=t.CONTEXT_MODE_DATA_DIR;return!e||e.trim()===""?null:e.startsWith("~")?Qb(Mm(),e.replace(/^~[/\\]?/,"")):Qb(e)}var ge,st=ne(()=>{"use strict";Sr();ge=class{constructor(e){this.sessionDirSegments=e}sessionDirSegments;getSessionDir(){let e=St(),r=e?ts(e,"context-mode","sessions"):ts(Mm(),...this.sessionDirSegments,"context-mode","sessions");return QM(r,{recursive:!0}),r}getConfigDir(e){return ts(Mm(),...this.sessionDirSegments)}getInstructionFiles(){return["CLAUDE.md"]}getMemoryDir(e){let r=St(),n=r?ts(r,"context-mode","memory"):ts(this.getConfigDir(),"memory");return e?ts(n,Qe(e)):n}backupSettings(){let e=this.getSettingsPath();try{JM(e,YM.R_OK);let r=e+".bak";return XM(e,r),r}catch{return null}}}});var rs,jm=ne(()=>{"use strict";st();rs=class extends ge{parsePreToolUseInput(e){let r=e;return{toolName:r.tool_name??"",toolInput:r.tool_input??{},sessionId:this.extractSessionId(r),projectDir:process.env[this.projectDirEnvVar]??process.cwd(),raw:e}}parsePostToolUseInput(e){let r=e;return{toolName:r.tool_name??"",toolInput:r.tool_input??{},toolOutput:r.tool_output,isError:r.is_error,sessionId:this.extractSessionId(r),projectDir:process.env[this.projectDirEnvVar]??process.cwd(),raw:e}}parsePreCompactInput(e){let r=e;return{sessionId:this.extractSessionId(r),projectDir:process.env[this.projectDirEnvVar]??process.cwd(),raw:e}}parseSessionStartInput(e){let r=e,n=r.source??"startup",o;switch(n){case"compact":o="compact";break;case"resume":o="resume";break;case"clear":o="clear";break;default:o="startup"}return{sessionId:this.extractSessionId(r),source:o,projectDir:process.env[this.projectDirEnvVar]??process.cwd(),raw:e}}formatPreToolUseResponse(e){if(e.decision==="deny")return{permissionDecision:"deny",reason:e.reason??"Blocked by context-mode hook"};if(e.decision==="modify"&&e.updatedInput)return{updatedInput:e.updatedInput};if(e.decision==="context"&&e.additionalContext)return{additionalContext:e.additionalContext};if(e.decision==="ask")return{permissionDecision:"ask"}}formatPostToolUseResponse(e){let r={};return e.additionalContext&&(r.additionalContext=e.additionalContext),e.updatedOutput&&(r.updatedMCPToolOutput=e.updatedOutput),Object.keys(r).length>0?r:void 0}formatPreCompactResponse(e){return e.context??""}formatSessionStartResponse(e){return e.context??""}}});import{existsSync as zm}from"node:fs";import{join as Lm}from"node:path";async function ej(){if(ns)return ns;if(os)return null;try{let t=[new URL("../../scripts/plugin-cache-integrity.mjs",import.meta.url),new URL("./scripts/plugin-cache-integrity.mjs",import.meta.url)],e=null;for(let r of t)try{let n=await import(r.href);if(typeof n?.assertPluginCacheIntegrity=="function")return ns=n,ns}catch(n){e=n}return os=e instanceof Error?e.message:String(e??"not found"),null}catch(t){return os=t instanceof Error?t.message:String(t),null}}function tj(t){let e=[];return zm(Lm(t,"start.mjs"))||e.push("start.mjs"),!zm(Lm(t,"server.bundle.mjs"))&&!zm(Lm(t,"build","server.js"))&&e.push("server.bundle.mjs (or build/server.js)"),e}function ek(t){if(ns){let e=ns.assertPluginCacheIntegrity({pluginRoot:t});return e.ok?{status:"OK",detail:`${t} (all required runtime siblings present)`}:{status:"FAIL",detail:`missing: ${e.missing.join(", ")}`}}if(os){let e=tj(t);return e.length>0?{status:"FAIL",detail:`partial install \u2014 critical launch files missing: ${e.join(", ")} (integrity helper also missing: ${os}); the MCP server cannot start. Reinstall: npm install -g context-mode@latest`}:{status:"FAIL",detail:`integrity helper unavailable: ${os}`}}return{status:"FAIL",detail:"integrity helper not yet loaded"}}var ns,os,tk=ne(()=>{"use strict";ns=null,os=null;ej()});function Di(t,e){let r=Xn[e],n=Um(e);return t.hooks?.some(o=>o.command?.includes(r)||o.command?.includes(n))??!1}function Um(t,e){if(e){let r=Xn[t];return Ze(`${e}/hooks/${r}`)}return`context-mode hook claude-code ${t.toLowerCase()}`}function Fm(t){let e=Dc(t);if(e)return e.scriptPath.endsWith(".mjs")?e.scriptPath:null;let r=t.match(/^\s*node\s+"([^"]+\.mjs)"\s*$/);if(r)return r[1];let n=t.match(/^\s*node\s+(\S+\.mjs)\s*$/);return n?n[1]:null}function ok(t){let e=Object.values(Xn);return t.hooks?.some(r=>r.command!=null&&(e.some(n=>r.command.includes(n))||r.command.includes("context-mode hook")))??!1}var or,rj,Hm,rk,nj,A4,Xn,nk,N4,sk=ne(()=>{"use strict";Nr();or={PRE_TOOL_USE:"PreToolUse",POST_TOOL_USE:"PostToolUse",PRE_COMPACT:"PreCompact",SESSION_START:"SessionStart",USER_PROMPT_SUBMIT:"UserPromptSubmit"},rj="mcp__",Hm=["Bash","WebFetch","Read","Grep","Agent","mcp__plugin_context-mode_context-mode__ctx_execute","mcp__plugin_context-mode_context-mode__ctx_execute_file","mcp__plugin_context-mode_context-mode__ctx_batch_execute",rj],rk=Hm.join("|"),nj=["Bash","Read","Write","Edit","NotebookEdit","Glob","Grep","TodoWrite","TaskCreate","TaskUpdate","EnterPlanMode","ExitPlanMode","Skill","Agent","AskUserQuestion","EnterWorktree","mcp__"],A4=nj.join("|"),Xn={PreToolUse:"pretooluse.mjs",PostToolUse:"posttooluse.mjs",PreCompact:"precompact.mjs",SessionStart:"sessionstart.mjs",UserPromptSubmit:"userpromptsubmit.mjs"},nk=[or.PRE_TOOL_USE,or.SESSION_START],N4=[or.POST_TOOL_USE,or.PRE_COMPACT,or.USER_PROMPT_SUBMIT]});var qm={};He(qm,{ClaudeCodeAdapter:()=>Zm});import{readFileSync as Jc,writeFileSync as ik,existsSync as ak,readdirSync as oj,chmodSync as sj,accessSync as ij,mkdirSync as aj,constants as cj}from"node:fs";import{resolve as Xc,join as pn}from"node:path";import{homedir as ck}from"node:os";var Zm,Bm=ne(()=>{"use strict";jm();st();Yn();tk();Nr();sk();Zm=class extends rs{constructor(){super([".claude"])}name="Claude Code";paradigm="json-stdio";projectDirEnvVar="CLAUDE_PROJECT_DIR";capabilities={preToolUse:!0,postToolUse:!0,preCompact:!0,sessionStart:!0,canModifyArgs:!0,canModifyOutput:!0,canInjectSessionContext:!0};getConfigDir(e){return wt()}getSessionDir(){let e=St(),r=e?pn(e,"context-mode","sessions"):pn(this.getConfigDir(),"context-mode","sessions");return aj(r,{recursive:!0}),r}getSettingsPath(){return pn(this.getConfigDir(),"settings.json")}generateHookConfig(e){let r=Ze(`${e}/hooks/pretooluse.mjs`);return{PreToolUse:[...Hm].map(o=>({matcher:o,hooks:[{type:"command",command:r}]})),PostToolUse:[{matcher:"",hooks:[{type:"command",command:Ze(`${e}/hooks/posttooluse.mjs`)}]}],PreCompact:[{matcher:"",hooks:[{type:"command",command:Ze(`${e}/hooks/precompact.mjs`)}]}],UserPromptSubmit:[{matcher:"",hooks:[{type:"command",command:Ze(`${e}/hooks/userpromptsubmit.mjs`)}]}],SessionStart:[{matcher:"",hooks:[{type:"command",command:Ze(`${e}/hooks/sessionstart.mjs`)}]}]}}readSettings(){try{let e=Jc(this.getSettingsPath(),"utf-8");return JSON.parse(e)}catch{return null}}writeSettings(e){ik(this.getSettingsPath(),JSON.stringify(e,null,2)+`
|
|
150
154
|
`,"utf-8")}validateHooks(e){let r=[],n=this.readSettings();if(!n)return r.push({check:"PreToolUse hook",status:"fail",message:`Could not read ${this.getSettingsPath()}`,fix:"context-mode upgrade"}),r;let o=n.hooks,s=this.readPluginHooks(e),i=this.checkHookType(o,s,or.PRE_TOOL_USE);r.push({check:"PreToolUse hook",status:i?"pass":"fail",message:i?"PreToolUse hook configured":"No PreToolUse hooks found",fix:i?void 0:"context-mode upgrade"});let a=this.checkHookType(o,s,or.SESSION_START);return r.push({check:"SessionStart hook",status:a?"pass":"fail",message:a?"SessionStart hook configured":"No SessionStart hooks found",fix:a?void 0:"context-mode upgrade"}),r}getHealthChecks(e){let r=Object.entries(Xn).map(([o,s])=>{let i=pn(e,"hooks",s);return{name:`Hook script: ${o} (${s})`,check:()=>ak(i)?{status:"OK",detail:i}:{status:"FAIL",detail:`not found at ${i}`}}}),n={name:"Plugin cache integrity",check:()=>ek(e)};return[...r,n]}readPluginHooks(e){let r=[pn(e,"hooks","hooks.json"),pn(e,".claude-plugin","hooks","hooks.json")];for(let n of r)try{let o=Jc(n,"utf-8"),s=JSON.parse(o);if(s.hooks)return s.hooks}catch{}}checkHookType(e,r,n){let o=e?.[n];if(o&&o.length>0&&o.some(i=>Di(i,n)))return!0;let s=r?.[n];return!!(s&&s.length>0&&s.some(i=>Di(i,n)))}checkPluginRegistration(){let e=this.readSettings();if(!e)return{check:"Plugin registration",status:"warn",message:"Could not read settings.json"};let r=e.enabledPlugins;if(!r)return{check:"Plugin registration",status:"warn",message:"No enabledPlugins section found (might be using standalone MCP mode)"};let n=Object.keys(r).find(o=>o.startsWith("context-mode"));return n&&r[n]?{check:"Plugin registration",status:"pass",message:`Plugin enabled: ${n}`}:{check:"Plugin registration",status:"warn",message:"context-mode not in enabledPlugins (might be using standalone MCP mode)"}}getInstalledVersion(){try{let r=pn(this.getConfigDir(),"plugins","installed_plugins.json"),o=JSON.parse(Jc(r,"utf-8")).plugins??{};for(let[s,i]of Object.entries(o)){if(!s.toLowerCase().includes("context-mode"))continue;let a=i;if(a.length>0&&typeof a[0].version=="string")return a[0].version}}catch{}let e=Array.from(new Set([this.getConfigDir(),wt(),Xc(ck(),".claude"),Xc(ck(),".config","claude")]));for(let r of e){let n=Xc(r,"plugins","cache","context-mode","context-mode");try{let s=oj(n).filter(i=>/^\d+\.\d+\.\d+/.test(i)).sort((i,a)=>{let c=i.split(".").map(Number),u=a.split(".").map(Number);for(let l=0;l<3;l++)if((c[l]??0)!==(u[l]??0))return(c[l]??0)-(u[l]??0);return 0});if(s.length>0)return s[s.length-1]}catch{}}return"not installed"}configureAllHooks(e){let r=this.readSettings()??{},n=r.hooks??{},o=[];for(let a of Object.keys(n)){let c=n[a];if(!Array.isArray(c))continue;let u=c.filter(d=>{let f=d;if(!ok(f))return!0;let h=f.hooks??[];return h.every(m=>!m.command||!Fm(m.command))?!0:h.every(m=>{let g=m.command?Fm(m.command):null;return g?ak(g):!0})}),l=c.length-u.length;l>0&&(n[a]=u,o.push(`Removed ${l} stale ${a} hook(s)`))}let s=this.readPluginHooks(e);if(s&&nk.every(c=>this.checkHookType(void 0,s,c))){let c=Object.values(Xn),u=l=>l!=null&&(c.some(d=>l.includes(d))||l.includes("context-mode hook"));for(let l of Object.keys(n)){let d=n[l];if(!Array.isArray(d))continue;let f=0;for(let p of d){let m=p,g=m.hooks??[],y=g.length;m.hooks=g.filter(_=>!u(_.command)),f+=y-m.hooks.length}let h=d.filter(p=>{let m=p.hooks;return Array.isArray(m)&&m.length>0});(f>0||h.length!==d.length)&&(n[l]=h,f>0&&o.push(`Removed ${f} duplicate ${l} hook(s) \u2014 covered by plugin hooks.json`))}return r.hooks=n,this.writeSettings(r),o.push("Skipped settings.json registration \u2014 plugin hooks.json is sufficient"),o}let i=[or.PRE_TOOL_USE,or.SESSION_START];for(let a of i){let c=Um(a,e);if(a===or.PRE_TOOL_USE){let u={matcher:rk,hooks:[{type:"command",command:c}]},l=n.PreToolUse;if(l&&Array.isArray(l)){let d=l.findIndex(f=>Di(f,a));d>=0?(l[d]=u,o.push(`Updated existing ${a} hook entry`)):(l.push(u),o.push(`Added ${a} hook entry`)),n.PreToolUse=l}else n.PreToolUse=[u],o.push(`Created ${a} hooks section`)}else{let u={matcher:"",hooks:[{type:"command",command:c}]},l=n[a];if(l&&Array.isArray(l)){let d=l.findIndex(f=>Di(f,a));d>=0?(l[d]=u,o.push(`Updated existing ${a} hook entry`)):(l.push(u),o.push(`Added ${a} hook entry`)),n[a]=l}else n[a]=[u],o.push(`Created ${a} hooks section`)}}return r.hooks=n,this.writeSettings(r),o}setHookPermissions(e){let r=[];for(let[,n]of Object.entries(Xn)){let o=Xc(e,"hooks",n);try{ij(o,cj.R_OK),sj(o,493),r.push(o)}catch{}}return r}updatePluginRegistry(e,r){try{let n=pn(this.getConfigDir(),"plugins","installed_plugins.json"),o=JSON.parse(Jc(n,"utf-8"));for(let[s,i]of Object.entries(o.plugins||{}))if(s.toLowerCase().includes("context-mode"))for(let a of i)a.installPath=e,a.version=r,a.lastUpdated=new Date().toISOString();ik(n,JSON.stringify(o,null,2)+`
|
|
151
155
|
`,"utf-8")}catch{}}extractSessionId(e){if(e.transcript_path){let r=e.transcript_path.match(/([a-f0-9-]{36})\.jsonl$/);if(r)return r[1]}return e.session_id?e.session_id:process.env.CLAUDE_SESSION_ID?process.env.CLAUDE_SESSION_ID:`pid-${process.ppid}`}}});function Qn(t,e){let r=Yc[t];return e&&r?Ze(`${e}/hooks/gemini-cli/${r}`):`context-mode hook gemini-cli ${t.toLowerCase()}`}var Pe,uk,Yc,V4,W4,lk=ne(()=>{"use strict";Nr();Pe={BEFORE_AGENT:"BeforeAgent",BEFORE_TOOL:"BeforeTool",AFTER_TOOL:"AfterTool",PRE_COMPRESS:"PreCompress",SESSION_START:"SessionStart"},uk="mcp__(?!.*context-mode)",Yc={[Pe.BEFORE_AGENT]:"beforeagent.mjs",[Pe.BEFORE_TOOL]:"beforetool.mjs",[Pe.AFTER_TOOL]:"aftertool.mjs",[Pe.PRE_COMPRESS]:"precompress.mjs",[Pe.SESSION_START]:"sessionstart.mjs"},V4=[Pe.BEFORE_TOOL,Pe.SESSION_START],W4=[Pe.AFTER_TOOL,Pe.PRE_COMPRESS]});var fk={};He(fk,{GeminiCLIAdapter:()=>Wm});import{readFileSync as Vm,writeFileSync as dk,mkdirSync as uj,accessSync as lj,chmodSync as dj,existsSync as pj,constants as fj}from"node:fs";import{resolve as Mi,join as pk}from"node:path";import{homedir as Qc}from"node:os";var Wm,mk=ne(()=>{"use strict";st();lk();Wm=class extends ge{constructor(){super([".gemini"])}name="Gemini CLI";paradigm="json-stdio";capabilities={preToolUse:!0,postToolUse:!0,preCompact:!0,sessionStart:!0,canModifyArgs:!0,canModifyOutput:!0,canInjectSessionContext:!0};parsePreToolUseInput(e){let r=e;return{toolName:r.tool_name??"",toolInput:r.tool_input??{},sessionId:this.extractSessionId(r),projectDir:this.getProjectDir(r),raw:e}}parsePostToolUseInput(e){let r=e;return{toolName:r.tool_name??"",toolInput:r.tool_input??{},toolOutput:r.tool_output,isError:r.is_error,sessionId:this.extractSessionId(r),projectDir:this.getProjectDir(r),raw:e}}parsePreCompactInput(e){let r=e;return{sessionId:this.extractSessionId(r),projectDir:this.getProjectDir(r),raw:e}}parseSessionStartInput(e){let r=e,n=r.source??"startup",o;switch(n){case"compact":o="compact";break;case"resume":o="resume";break;case"clear":o="clear";break;default:o="startup"}return{sessionId:this.extractSessionId(r),source:o,projectDir:this.getProjectDir(r),raw:e}}formatPreToolUseResponse(e){if(e.decision==="deny")return{decision:"deny",reason:e.reason??"Blocked by context-mode hook"};if(e.decision==="modify"&&e.updatedInput)return{hookSpecificOutput:{tool_input:e.updatedInput}};if(e.decision==="context"&&e.additionalContext)return{hookSpecificOutput:{additionalContext:e.additionalContext}};if(e.decision==="ask")return{decision:"deny",reason:e.reason??"Action requires user confirmation (security policy)"}}formatPostToolUseResponse(e){if(e.updatedOutput)return{decision:"deny",reason:e.updatedOutput};if(e.additionalContext)return{hookSpecificOutput:{additionalContext:e.additionalContext}}}formatPreCompactResponse(e){return e.context??""}formatSessionStartResponse(e){return e.context??""}getSettingsPath(){return Mi(Qc(),".gemini","settings.json")}getInstructionFiles(){return["GEMINI.md"]}generateHookConfig(e){return{[Pe.BEFORE_AGENT]:[{matcher:"",hooks:[{type:"command",command:Qn(Pe.BEFORE_AGENT,e)}]}],[Pe.BEFORE_TOOL]:[{matcher:`run_shell_command|read_file|read_many_files|grep_search|search_file_content|web_fetch|activate_skill|mcp__plugin_context-mode|mcp__context-mode|${uk}`,hooks:[{type:"command",command:Qn(Pe.BEFORE_TOOL,e)}]}],[Pe.AFTER_TOOL]:[{matcher:"",hooks:[{type:"command",command:Qn(Pe.AFTER_TOOL,e)}]}],[Pe.PRE_COMPRESS]:[{matcher:"",hooks:[{type:"command",command:Qn(Pe.PRE_COMPRESS,e)}]}],[Pe.SESSION_START]:[{matcher:"",hooks:[{type:"command",command:Qn(Pe.SESSION_START,e)}]}]}}readSettings(){try{let e=Vm(this.getSettingsPath(),"utf-8");return JSON.parse(e)}catch{return null}}writeSettings(e){let r=Mi(Qc(),".gemini");uj(r,{recursive:!0}),dk(this.getSettingsPath(),JSON.stringify(e,null,2)+`
|
|
152
156
|
`,"utf-8")}validateHooks(e){let r=[],n=this.readSettings();if(!n)return r.push({check:"BeforeTool hook",status:"fail",message:"Could not read ~/.gemini/settings.json",fix:"context-mode upgrade"}),r;let o=n.hooks,s=o?.[Pe.BEFORE_TOOL];if(s&&s.length>0){let a=s.some(c=>c.hooks?.some(u=>u.command?.includes("context-mode")));r.push({check:"BeforeTool hook",status:a?"pass":"fail",message:a?"BeforeTool hook configured":"BeforeTool exists but does not point to context-mode",fix:a?void 0:"context-mode upgrade"})}else r.push({check:"BeforeTool hook",status:"fail",message:"No BeforeTool hooks found",fix:"context-mode upgrade"});let i=o?.[Pe.SESSION_START];if(i&&i.length>0){let a=i.some(c=>c.hooks?.some(u=>u.command?.includes("context-mode")));r.push({check:"SessionStart hook",status:a?"pass":"fail",message:a?"SessionStart hook configured":"SessionStart exists but does not point to context-mode",fix:a?void 0:"context-mode upgrade"})}else r.push({check:"SessionStart hook",status:"fail",message:"No SessionStart hooks found",fix:"context-mode upgrade"});return r}getHealthChecks(e){return Object.entries(Yc).map(([r,n])=>{let o=pk(e,"hooks","gemini-cli",n);return{name:`Hook script: ${r} (${n})`,check:()=>pj(o)?{status:"OK",detail:o}:{status:"FAIL",detail:`not found at ${o}`}}})}checkPluginRegistration(){let e=this.readSettings();if(!e)return{check:"Plugin registration",status:"warn",message:"Could not read ~/.gemini/settings.json"};let r=e.extensions;return r&&(Array.isArray(r)?r.some(o=>typeof o=="string"&&o.includes("context-mode")):Object.keys(r).some(o=>o.includes("context-mode")))?{check:"Plugin registration",status:"pass",message:"context-mode found in extensions"}:{check:"Plugin registration",status:"warn",message:"context-mode not found in extensions (might be using standalone MCP mode)"}}getInstalledVersion(){try{let e=Mi(Qc(),".gemini","extensions","context-mode","package.json"),r=JSON.parse(Vm(e,"utf-8"));if(typeof r.version=="string")return r.version}catch{}return"not installed"}configureAllHooks(e){let r=this.readSettings()??{},n=r.hooks??{},o=[],s=[{name:Pe.BEFORE_AGENT},{name:Pe.BEFORE_TOOL},{name:Pe.SESSION_START}];for(let i of s){let c={matcher:"",hooks:[{type:"command",command:Qn(i.name,e)}]},u=n[i.name];if(u&&Array.isArray(u)){let l=u.findIndex(d=>d.hooks?.some(h=>h.command?.includes("context-mode")));l>=0?(u[l]=c,o.push(`Updated existing ${i.name} hook entry`)):(u.push(c),o.push(`Added ${i.name} hook entry`)),n[i.name]=u}else n[i.name]=[c],o.push(`Created ${i.name} hooks section`)}return r.hooks=n,this.writeSettings(r),o}setHookPermissions(e){let r=[],n=pk(e,"hooks","gemini-cli");for(let o of Object.values(Yc)){let s=Mi(n,o);try{lj(s,fj.R_OK),dj(s,493),r.push(s)}catch{}}return r}updatePluginRegistry(e,r){try{let n=Mi(Qc(),".gemini","extensions","context-mode","package.json"),o=JSON.parse(Vm(n,"utf-8"));o.version=r,o.installPath=e,o.lastUpdated=new Date().toISOString(),dk(n,JSON.stringify(o,null,2)+`
|
|
@@ -588,7 +592,7 @@ ${o}`}}import{execFileSync as Xz}from"node:child_process";function Yz(){if(proce
|
|
|
588
592
|
COALESCE(SUM(LENGTH(data)), 0) AS data_bytes,
|
|
589
593
|
COALESCE(SUM(bytes_avoided), 0) AS bytes_avoided,
|
|
590
594
|
COALESCE(SUM(bytes_returned), 0) AS bytes_returned
|
|
591
|
-
FROM session_events`).get();p&&(s+=Number(p.data_bytes??0),i+=Number(p.bytes_avoided??0),a+=Number(p.bytes_returned??0));try{let m=h.prepare("SELECT COALESCE(SUM(LENGTH(snapshot)), 0) AS bytes FROM session_resume").get();m?.bytes&&(c+=Number(m.bytes))}catch{}}}finally{h.close()}}catch{}}let u=0;t.sessionId&&t.contentDbPath&&(u=bL(t.sessionId,t.contentDbPath,{loadDatabase:t.loadDatabase}),i+=u);let l=Math.floor((s+i+c)/4);return{eventDataBytes:s,bytesAvoided:i,bytesReturned:a,snapshotBytes:c,contentBytes:u,totalSavedTokens:l}}var kL={minEvents:100,minProjects:5,recencyMs:30*864e5,minAvgBytes:50};function EL(t,e,r){let n={name:t.name,eventCount:0,sessionCount:0,dataBytes:0,rescueBytes:0,contentBytes:0,uuidConvs:0,projectDirs:[],firstMs:Number.POSITIVE_INFINITY,lastMs:0,isReal:!1};if(!Hr(t.sessionsDir))return n;let o=[];try{o=fs(t.sessionsDir).filter(l=>l.endsWith(".db"))}catch{return n}if(o.length===0)return n;let s=null;try{s=e()}catch{return n}if(!s)return n;let i=new Set,a=new Set;for(let l of o){let d=Tt(t.sessionsDir,l);try{let f=new s(d,{readonly:!0});try{let h=f.prepare("SELECT COUNT(*) AS cnt, COALESCE(SUM(LENGTH(data)), 0) AS bytes FROM session_events").get();h&&(n.eventCount+=Number(h.cnt??0),n.dataBytes+=Number(h.bytes??0));try{let p=f.prepare("SELECT COUNT(*) AS cnt FROM session_meta").get();n.sessionCount+=Number(p?.cnt??0)}catch{}try{let p=f.prepare("SELECT COALESCE(SUM(length(snapshot)), 0) AS bytes FROM session_resume WHERE consumed = 1").get();p?.bytes&&(n.rescueBytes+=Number(p.bytes))}catch{}try{let p=f.prepare("SELECT MIN(created_at) AS mn, MAX(created_at) AS mx FROM session_events").get();if(p?.mn){let m=Date.parse(p.mn+(p.mn.endsWith("Z")?"":"Z"));Number.isFinite(m)&&m<n.firstMs&&(n.firstMs=m)}if(p?.mx){let m=Date.parse(p.mx+(p.mx.endsWith("Z")?"":"Z"));Number.isFinite(m)&&m>n.lastMs&&(n.lastMs=m)}}catch{}try{let p=f.prepare("SELECT DISTINCT project_dir AS p FROM session_events WHERE project_dir != ''").all();for(let m of p)m.p&&i.add(m.p)}catch{}try{let p=f.prepare("SELECT DISTINCT session_id AS s FROM session_events").all();for(let m of p)m.s&&a.add(m.s)}catch{}}finally{f.close()}}catch{}}n.projectDirs=Array.from(i),n.uuidConvs=a.size;let c=n.eventCount>0?n.dataBytes/n.eventCount:0,u=n.lastMs>0&&r.nowMs-n.lastMs<=r.recencyMs;return n.isReal=n.eventCount>=r.minEvents&&i.size>=r.minProjects&&u&&c>=r.minAvgBytes,n}function xu(t){let e=SL({home:t?.home}),r=t?.loadDatabase??Ye,n={...kL,...t?.filter??{},nowMs:t?.filter?.nowMs??Date.now()},o=[],s=0,i=0,a=0;for(let c of e){if(!Hr(c.sessionsDir))continue;let u=EL(c,r,n);o.push(u),s+=u.eventCount,i+=u.sessionCount,a+=u.dataBytes+u.rescueBytes}return{totalEvents:s,totalSessions:i,totalBytes:a,perAdapter:o}}var cw={project:"What you're building",feedback:"How you work",user:"Who you are",reference:"Where to look",memory:"Long-term context",other:"Other notes"},wL={"claude-code":"Claude Code","gemini-cli":"Gemini CLI",antigravity:"Antigravity",openclaw:"Openclaw",codex:"Codex CLI",cursor:"Cursor","vscode-copilot":"VS Code Copilot",kiro:"Kiro",pi:"Pi",omp:"OMP","qwen-code":"Qwen Code",kilo:"Kilo",opencode:"OpenCode",zed:"Zed","jetbrains-copilot":"JetBrains"};function gu(t){return wL[t]??t}function et(t){if(!Number.isFinite(t)||t<=0)return"0 B";if(t<1024)return`${Math.round(t)} B`;let e=t/1024;if(e<1024)return e<100?`${e.toFixed(1)} KB`:`${Math.round(e)} KB`;let r=e/1024;if(r<1024)return r<100?`${r.toFixed(1)} MB`:`${Math.round(r)} MB`;let n=r/1024;return n<100?`${n.toFixed(2)} GB`:`${n.toFixed(1)} GB`}function TL(t){let e=parseFloat(t);if(isNaN(e)||e<1)return"< 1 min";if(e<60)return`${Math.round(e)} min`;let r=Math.floor(e/60),n=Math.round(e%60);return n>0?`${r}h ${n}m`:`${r}h`}function mu(t){if(!t)return!1;try{return Intl.DateTimeFormat.supportedLocalesOf(t).length===0?!1:(new Intl.DateTimeFormat(t),!0)}catch{return!1}}function PL(){let t=process.env??{},e=t.CONTEXT_MODE_LOCALE??"";if(e&&!mu(e)&&(e=""),!e){if(process.platform==="darwin"){try{let n=gL("defaults",["read","-g","AppleLocale"],{encoding:"utf8",timeout:500}).trim();n&&(e=n.replace(/_/g,"-"))}catch{}e&&!mu(e)&&(e="")}if(!e&&(t.LC_TIME||t.LANG)){let n=(t.LC_TIME||t.LANG||"").split(".")[0];n&&(e=n.replace(/_/g,"-")),e&&!mu(e)&&(e="")}if(!e)try{e=new Intl.DateTimeFormat().resolvedOptions().locale}catch{e="en-US"}}let r=t.CONTEXT_MODE_TZ??"";if(!r)try{r=new Intl.DateTimeFormat().resolvedOptions().timeZone}catch{r="UTC"}return mu(e)||(e="en-US"),{locale:e,tz:r||"UTC"}}function YE(t){let e=_u();return e?t===e?"~":t.startsWith(e+_L)?"~"+t.slice(e.length):t:t}function RL(t,e,r){if(!Number.isFinite(e)||e<=0)return[];let n=e*Vi(),o=(y,_=2)=>y.toFixed(_),s=Math.round(n/20),i=(n/200).toFixed(1),a=Math.round(n/73.67),c=Math.round(n*10),u=r>0?Math.round(n*10/r*365):0,l=(e*3/1e6).toFixed(2),d=(e*2.5/1e6).toFixed(2),f=(e*1.25/1e6).toFixed(2),h=(e*.8/1e6).toFixed(2),p=process.env.PI_CONTEXT_MODE_PRICE_OUTPUT_PER_TOKEN!==void 0,m=process.env.PI_CONTEXT_MODE_MODEL_ID,g=[];return p&&m?g.push(` $${o(n)} of ${m} tokens your team didn't burn.`):p?g.push(` $${o(n)} of tokens your team didn't burn.`):g.push(` $${o(n)} of Opus 4 tokens your team didn't burn.`),g.push(` context-mode kept ${et(t)} out of context \u2014 that's ${s} months of Cursor Pro paid for itself.`),c>0&&u>0&&(g.push(""),g.push(` Scale across a 10-dev team and that's ~$${u.toLocaleString("en-US")}/year saved.`)),p||(g.push(""),g.push(" (Opus rates shown for context. On cheaper models the dollar number drops; the savings ratio holds.)")),g}function $L(t){let{conversation:e,lifetime:r,multiAdapter:n,realBytes:o,cwd:s,locale:i,tz:a,now:c,version:u,latestVersion:l}=t,d=[],f=e.events*nw,h=Math.round((e.snapshotBytes??0)/4),p=f+h,m=o?.conversation?.totalSavedTokens??0,g=Math.max(p,m),y=(r?.totalEvents??0)*nw,_=Math.round((r?.rescueBytes??0)/4),x=y+_,S=o?.lifetime?.totalSavedTokens??0,k=Math.max(x,S),R=o?.lifetime?.bytesReturned??0,$=o?.lifetime?.bytesAvoided??0,C=R+$>0?Math.max(1,Math.floor(R/4)):Math.max(1,Math.round(k*.02)),A=n?.totalBytes&&n.totalBytes>0?n.totalBytes:k*4,W=o?.conversation?o.conversation.eventDataBytes+o.conversation.bytesAvoided+o.conversation.snapshotBytes:g*4,T=e.daysAlive>=1?`${e.daysAlive.toFixed(1)} days alive \xB7 still going`:`${Math.max(1,Math.round(e.daysAlive*24))} hr alive \xB7 still going`,E=r?.firstEventMs??n?.perAdapter?.[0]?.firstMs??0,H=E>0?Math.max(1,Math.round((c-E)/864e5)):0,pe=n?.totalSessions??r?.totalSessions??1,dt=n?.perAdapter.filter(Me=>Me.isReal).length??0,gn;if(n&&dt>=2)gn=`across ${dt} AI tools`;else if(n&&dt===1){let Me=n.perAdapter.find(Vt=>Vt.isReal);gn=`in ${Me?gu(Me.name):"Claude Code"}`}else gn="in Claude Code";H>0?d.push(` Across ${H} days you ran ${sr(pe)} conversations ${gn}.`):d.push(` You ran ${sr(pe)} conversations ${gn}.`);let Aw=H>0?A/H:0;d.push(` context-mode kept ${et(A)} out of your context window \u2014 about ${et(Aw)} every single day.`),d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 1. Where you are now \u2500\u2500\u2500"),d.push("");let ig=e.firstEventMs&&e.firstEventMs>0?QE(e.firstEventMs,i,a):"";if(ig?d.push(` This conversation started ${ig} in ${YE(s)}.`):d.push(` This conversation lives in ${YE(s)}.`),d.push(` ${T}.`),e.snapshotsConsumed>0&&e.snapshotBytes>0){let Me=e.lastRescueMs&&e.lastRescueMs>0?QE(e.lastRescueMs,i,a):"",Vt=Math.round(e.snapshotBytes/1024);Me?d.push(` On ${Me}, /compact fired \u2014 ${Vt} KB rescued from snapshot.`):d.push(` /compact fired \u2014 ${Vt} KB rescued from snapshot.`),d.push(" Without that, you'd be re-explaining everything to a blank model right now.")}d.push("");let ag=o?.conversation,cg=ag?.bytesAvoided??0,Nu=ag?.bytesReturned??0;if(cg+Nu===0)d.push(" No measurable redirect activity captured yet \u2014 bars will appear once context-mode diverts its first payload."),d.push("");else{let Me=cg+Nu,Vt=Math.max(1,Nu),Wt=Math.max(1,Math.floor(Me/4)),kr=Math.max(1,Math.floor(Vt/4)),Du=hn(Wt,Wt,32),zw=hn(kr,Wt,32),Lw=(1-kr/Wt)*100,Hw=Math.max(1,Math.round(Wt/kr));d.push(` Without context-mode ${et(Me).padStart(8)} ${Du} ${sr(Wt).padStart(7)} tokens`),d.push(` With context-mode ${et(Vt).padStart(8)} ${zw} ${sr(kr).padStart(7)} tokens`),d.push(` ${Lw.toFixed(0)}% kept out of context \xB7 your AI ran ${Hw}\xD7 longer before /compact fired`),d.push("")}if(e.byDay&&e.byDay.length>0){let Me=e.lastEventMs&&e.firstEventMs?Math.max(1,Math.round((e.lastEventMs-e.firstEventMs)/864e5)+1):e.byDay.length;d.push(` How that ${et(W)} built up \u2014 ${Me} days, ${e.byDay.length} active:`),d.push(""),d.push(...OL(e.byDay,i,a))}d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 2. What this chat captured (used when you --continue or /resume here) \u2500\u2500\u2500"),d.push("");let Nw=e.byCategory.reduce((Me,Vt)=>Me+Vt.count,0).toLocaleString(i);d.push(` ${Nw} things \u2014 files, errors, decisions, agent runs:`),d.push("");let Dw=e.byCategory[0]?.count??1;for(let Me of e.byCategory)d.push(` ${Me.label.padEnd(26)} ${String(Me.count).padStart(5)} ${hn(Me.count,Dw,28)}`);d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 3. The scope, getting wider \u2500\u2500\u2500"),d.push("");let ug=e.firstEventMs&&e.firstEventMs>0?new Intl.DateTimeFormat(i,{timeZone:a,year:"numeric",month:"short",day:"numeric"}).format(new Date(e.firstEventMs)):"",lg=E>0?new Intl.DateTimeFormat(i,{timeZone:a,year:"numeric",month:"short",day:"numeric"}).format(new Date(E)):"",dg=r?.distinctProjects??0,Mw=r?.totalEvents??n?.totalEvents??0;if(d.push(` This chat: ${et(W)} kept out \xB7 ${e.events.toLocaleString(i)} captures${ug?` \xB7 started ${ug}`:""}.`),d.push(` All your work: ${et(A)} kept out \xB7 ${Mw.toLocaleString(i)} captures across ${dg} project${dg===1?"":"s"}${lg?` \xB7 since ${lg}`:""}.`),d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 4. The bottom line \u2500\u2500\u2500"),d.push(""),d.push(...RL(A,k,H)),d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 5. What context-mode learned about how you work \u2500\u2500\u2500"),d.push(""),r&&r.autoMemoryCount>0){d.push(` ${r.autoMemoryCount} preferences picked up across ${r.autoMemoryProjects} project${r.autoMemoryProjects===1?"":"s"}:`);let Me=Object.entries(r.autoMemoryByPrefix).sort((Wt,kr)=>kr[1]-Wt[1]),Vt=Me.length>0?Me[0][1]:1;for(let[Wt,kr]of Me){let Du=cw[Wt]??Wt;d.push(` ${Du.padEnd(26)} ${String(kr).padStart(2)} ${hn(kr,Vt,20)}`)}}else d.push(" No preferences learned yet \u2014 context-mode picks them up automatically.");d.push(""),d.push(""),d.push(" Your AI talks less, remembers more, costs less."),d.push(` Locale ${i} \xB7 timezone ${a} \xB7 pricing examples for illustration only.`),d.push("");let jw=u?`v${u}`:"context-mode";return d.push(` ${jw}`),u&&l&&l!=="unknown"&&sw(l,u)&&d.push(` Update available: v${u} -> v${l} | ctx_upgrade`),CL(d)}function CL(t){let e=[],r=0;for(let n of t)n===""?(r++,r<=2&&e.push(n)):(r=0,e.push(n));for(;e.length>0&&e[e.length-1]==="";)e.pop();return e}function OL(t,e,r){if(t.length===0)return[];let n=[...t].sort((f,h)=>f.ms-h.ms),o=n[0],s=n[n.length-1],i=Math.max(1,s.ms-o.ms),a=n[0];for(let f of n)f.count>a.count&&(a=f);let c=56,u=Array.from({length:c},()=>"\u2500");for(let f of n){let h=Math.round((f.ms-o.ms)/i*(c-1)),p="\u25CF";f===a&&(p="\u2588"),(f.rescueBytes??0)>0&&(p="\u25C6"),u[h]=p}let l=f=>{let h=new Intl.DateTimeFormat(e,{timeZone:r,month:"short",day:"numeric"}).formatToParts(new Date(f)),p=(h.find(g=>g.type==="month")?.value??"").toLowerCase(),m=h.find(g=>g.type==="day")?.value??"";return`${p} ${m}`},d=[];d.push(` ${l(o.ms)} ${u.join("")} ${l(s.ms)}`),d.push("");for(let f of n){let h=l(f.ms).padEnd(7),p=`${f.count} captures`,m=f===a?" \u2190 peak":"",g=(f.rescueBytes??0)>0?` \u25C6 /compact rescued ${Math.round((f.rescueBytes??0)/1024)} KB`:"";d.push(` ${h} ${p}${m}${g}`)}return d.push(""),d.push(" \u25CF active day \u2588 peak day \u25C6 /compact rescue"),d}function QE(t,e,r){if(!Number.isFinite(t)||t<=0)return"";let n=new Date(t);if(Number.isNaN(n.getTime()))return"";let o=new Intl.DateTimeFormat(e,{timeZone:r,year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit",hour12:!1}).formatToParts(n),s=d=>o.find(f=>f.type===d)?.value??"",i=s("day"),a=s("month"),c=s("year"),u=s("hour"),l=s("minute");return u==="24"&&(u="00"),`${i} ${a} ${c} at ${u}:${l} (${r})`}function sr(t){return t>=1e6?`${(t/1e6).toFixed(1)}M`:t>=1e3?`${(t/1e3).toFixed(1)}K`:String(t)}function Vi(){let t=process.env.PI_CONTEXT_MODE_PRICE_OUTPUT_PER_TOKEN;if(t!==void 0&&t!==""){let e=Number(t);if(Number.isFinite(e)&&e>0)return e}return 15/1e6}var UW=15/1e6;function yu(t){return`$${((Number.isFinite(t)&&t>0?t:0)*Vi()).toFixed(2)}`}function hn(t,e,r=40){if(e<=0)return"\u2591".repeat(r);let n=Math.max(1,Math.round(t/e*r));return"\u2588".repeat(Math.min(n,r))+"\u2591".repeat(Math.max(0,r-n))}function ew(t,e){let r=e?.sessionTokensSaved??0;if(t.total_events===0&&(e?.lifetime?.totalEvents??0)===0&&r===0&&(e?.multiAdapter?.totalEvents??0)===0)return[];let n=e?.topN??Number.POSITIVE_INFINITY,o=[];o.push("");let s=e?.multiAdapter,i=s?.perAdapter.filter(m=>m.isReal).length??0,a=s?.totalEvents??e?.lifetime?.totalEvents??t.total_events,c=s?.totalSessions??e?.lifetime?.totalSessions??t.session_count,u=e?.lifetime?.distinctProjects;if(a>0&&u&&u>0){let m=i>=2?" everywhere":"";o.push(` All your work${m} \xB7 ${sr(a)} events captured across ${u} project${u===1?"":"s"} \xB7 ${sr(c)} conversations`)}else{o.push("Persistent memory \u2713 preserved across compact, restart & upgrade");let m=c===0&&r>0?1:c,g=m===1?"1 session":`${sr(m)} sessions`,y=a*256+r;o.push(` ${sr(a)} events \xB7 ${g} \xB7 ~${yu(y)} saved lifetime`)}o.push("");let l=e?.lifetime?.categoryCounts,d;l&&Object.keys(l).length>0?d=Object.entries(l).filter(([,m])=>m>0).map(([m,g])=>({category:m,count:g,label:hu[m]||m})).sort((m,g)=>g.count-m.count):d=(t.by_category??[]).filter(m=>m&&m.count>0);let f=d.slice(0,n),h=f.length>0?f[0].count:1;for(let m of f)o.push(` ${m.label.padEnd(26)} ${String(m.count).padStart(5)} ${hn(m.count,h,30)}`);let p=Math.max(0,d.length-n);return p>0&&o.push(` ... ${p} more categor${p===1?"y":"ies"}`),o}function tw(t){if(!t||t.autoMemoryCount===0)return[];let e=[];e.push(""),e.push(` Preferences learned \xB7 ${t.autoMemoryCount} across ${t.autoMemoryProjects} project${t.autoMemoryProjects===1?"":"s"}`);let r=Object.entries(t.autoMemoryByPrefix).sort((o,s)=>s[1]-o[1]).slice(0,6),n=r.length>0?r[0][1]:1;for(let[o,s]of r){let i=cw[o]??o;e.push(` ${i.padEnd(26)} ${String(s).padStart(2)} ${hn(s,n,20)}`)}return e}function rw(t,e){let r=[],n=yu(t),o=(e?.totalEvents??0)*256+t,s=yu(o);return r.push(""),r.push("\u2500".repeat(65)),r.push("Your AI talks less, remembers more, costs less."),r.push(`${n} this session \xB7 ${s} lifetime`),r.push("\u2500".repeat(65)),r}var nw=256;function ow(t){if(!t)return[];let e=[],r=[];for(let o of t.perAdapter)(o.isReal?e:r).push(o);if(e.length===0&&r.length===0)return[];let n=[];if(e.length>0){n.push(""),n.push("Where it came from (tools you actually used \u2014 fixtures + probes filtered):"),n.push("");let o=16,s=10,i=10,a=16;n.push(` ${"Tool".padEnd(o)}${"Captures".padStart(s)}${"Indexed".padStart(i)}${"Total kept out".padStart(a)}`);let c=[...e].sort((u,l)=>l.dataBytes+l.rescueBytes-(u.dataBytes+u.rescueBytes));for(let u of c){let l=u.dataBytes+u.rescueBytes,d=u.eventCount>0?sr(u.eventCount):"\u2014",f=et(u.dataBytes),h=et(l);n.push(` ${gu(u.name).padEnd(o)}${d.padStart(s)}${f.padStart(i)}${h.padStart(a)}`)}}if(r.length>0){e.length>0&&n.push("");let o=r.map(s=>gu(s.name)).join(", ");n.push(` Skipped (${r.length}): ${o}`),n.push(" These adapters have DBs on disk but only test fixtures, dev skeletons,"),n.push(" or detection probes \u2014 no real chat activity.")}return n}function Su(t,e,r,n){let o=[],s=TL(t.session.uptime_min),i=n?.lifetime,a=n?.mcpUsage,c=n?.conversation,u=n?.realBytes,l=n?.multiAdapter,d=l?.perAdapter.filter(R=>R.isReal).length??0;if(l&&d>0){let R=l.totalSessions||i?.totalSessions||0,$=i?.firstEventMs??0,C=$>0?Math.max(1,Math.round((Date.now()-$)/864e5)):0,A=C>0?`Across ${C} day${C===1?"":"s"} `:"",W=R>0?`you ran ${sr(R)} conversation${R===1?"":"s"} `:"you ran ",T;if(d>=2)T=`across ${d} AI tools`;else{let E=l.perAdapter.find(H=>H.isReal);T=`in ${E?gu(E.name):"Claude Code"}`}o.push(`${A}${W}${T}.`),o.push("")}if(c&&c.events>0){o.length>0&&(o.length=0);let R=PL(),$=n?.cwd??process.cwd(),C=n?.now??Date.now(),A=n?.locale??R.locale,W=n?.tz??R.tz;return o.push(...$L({conversation:c,lifetime:i,multiAdapter:l,realBytes:u,cwd:$,locale:A,tz:W,now:C,version:e,latestVersion:r})),o.join(`
|
|
595
|
+
FROM session_events`).get();p&&(s+=Number(p.data_bytes??0),i+=Number(p.bytes_avoided??0),a+=Number(p.bytes_returned??0));try{let m=h.prepare("SELECT COALESCE(SUM(LENGTH(snapshot)), 0) AS bytes FROM session_resume").get();m?.bytes&&(c+=Number(m.bytes))}catch{}}}finally{h.close()}}catch{}}let u=0;t.sessionId&&t.contentDbPath&&(u=bL(t.sessionId,t.contentDbPath,{loadDatabase:t.loadDatabase}),i+=u);let l=Math.floor((s+i+c)/4);return{eventDataBytes:s,bytesAvoided:i,bytesReturned:a,snapshotBytes:c,contentBytes:u,totalSavedTokens:l}}var kL={minEvents:100,minProjects:5,recencyMs:30*864e5,minAvgBytes:50};function EL(t,e,r){let n={name:t.name,eventCount:0,sessionCount:0,dataBytes:0,rescueBytes:0,contentBytes:0,uuidConvs:0,projectDirs:[],firstMs:Number.POSITIVE_INFINITY,lastMs:0,isReal:!1};if(!Hr(t.sessionsDir))return n;let o=[];try{o=fs(t.sessionsDir).filter(l=>l.endsWith(".db"))}catch{return n}if(o.length===0)return n;let s=null;try{s=e()}catch{return n}if(!s)return n;let i=new Set,a=new Set;for(let l of o){let d=Tt(t.sessionsDir,l);try{let f=new s(d,{readonly:!0});try{let h=f.prepare("SELECT COUNT(*) AS cnt, COALESCE(SUM(LENGTH(data)), 0) AS bytes FROM session_events").get();h&&(n.eventCount+=Number(h.cnt??0),n.dataBytes+=Number(h.bytes??0));try{let p=f.prepare("SELECT COUNT(*) AS cnt FROM session_meta").get();n.sessionCount+=Number(p?.cnt??0)}catch{}try{let p=f.prepare("SELECT COALESCE(SUM(length(snapshot)), 0) AS bytes FROM session_resume WHERE consumed = 1").get();p?.bytes&&(n.rescueBytes+=Number(p.bytes))}catch{}try{let p=f.prepare("SELECT MIN(created_at) AS mn, MAX(created_at) AS mx FROM session_events").get();if(p?.mn){let m=Date.parse(p.mn+(p.mn.endsWith("Z")?"":"Z"));Number.isFinite(m)&&m<n.firstMs&&(n.firstMs=m)}if(p?.mx){let m=Date.parse(p.mx+(p.mx.endsWith("Z")?"":"Z"));Number.isFinite(m)&&m>n.lastMs&&(n.lastMs=m)}}catch{}try{let p=f.prepare("SELECT DISTINCT project_dir AS p FROM session_events WHERE project_dir != ''").all();for(let m of p)m.p&&i.add(m.p)}catch{}try{let p=f.prepare("SELECT DISTINCT session_id AS s FROM session_events").all();for(let m of p)m.s&&a.add(m.s)}catch{}}finally{f.close()}}catch{}}n.projectDirs=Array.from(i),n.uuidConvs=a.size;let c=n.eventCount>0?n.dataBytes/n.eventCount:0,u=n.lastMs>0&&r.nowMs-n.lastMs<=r.recencyMs;return n.isReal=n.eventCount>=r.minEvents&&i.size>=r.minProjects&&u&&c>=r.minAvgBytes,n}function xu(t){let e=SL({home:t?.home}),r=t?.loadDatabase??Ye,n={...kL,...t?.filter??{},nowMs:t?.filter?.nowMs??Date.now()},o=[],s=0,i=0,a=0;for(let c of e){if(!Hr(c.sessionsDir))continue;let u=EL(c,r,n);o.push(u),s+=u.eventCount,i+=u.sessionCount,a+=u.dataBytes+u.rescueBytes}return{totalEvents:s,totalSessions:i,totalBytes:a,perAdapter:o}}var cw={project:"What you're building",feedback:"How you work",user:"Who you are",reference:"Where to look",memory:"Long-term context",other:"Other notes"},wL={"claude-code":"Claude Code","gemini-cli":"Gemini CLI",antigravity:"Antigravity",openclaw:"Openclaw",codex:"Codex CLI",cursor:"Cursor","vscode-copilot":"VS Code Copilot",kiro:"Kiro",pi:"Pi",omp:"OMP","qwen-code":"Qwen Code",kilo:"Kilo",opencode:"OpenCode",zed:"Zed","jetbrains-copilot":"JetBrains"};function gu(t){return wL[t]??t}function et(t){if(!Number.isFinite(t)||t<=0)return"0 B";if(t<1024)return`${Math.round(t)} B`;let e=t/1024;if(e<1024)return e<100?`${e.toFixed(1)} KB`:`${Math.round(e)} KB`;let r=e/1024;if(r<1024)return r<100?`${r.toFixed(1)} MB`:`${Math.round(r)} MB`;let n=r/1024;return n<100?`${n.toFixed(2)} GB`:`${n.toFixed(1)} GB`}function TL(t){let e=parseFloat(t);if(isNaN(e)||e<1)return"< 1 min";if(e<60)return`${Math.round(e)} min`;let r=Math.floor(e/60),n=Math.round(e%60);return n>0?`${r}h ${n}m`:`${r}h`}function mu(t){if(!t)return!1;try{return Intl.DateTimeFormat.supportedLocalesOf(t).length===0?!1:(new Intl.DateTimeFormat(t),!0)}catch{return!1}}function PL(){let t=process.env??{},e=t.CONTEXT_MODE_LOCALE??"";if(e&&!mu(e)&&(e=""),!e){if(process.platform==="darwin"){try{let n=gL("defaults",["read","-g","AppleLocale"],{encoding:"utf8",timeout:500}).trim();n&&(e=n.replace(/_/g,"-"))}catch{}e&&!mu(e)&&(e="")}if(!e&&(t.LC_TIME||t.LANG)){let n=(t.LC_TIME||t.LANG||"").split(".")[0];n&&(e=n.replace(/_/g,"-")),e&&!mu(e)&&(e="")}if(!e)try{e=new Intl.DateTimeFormat().resolvedOptions().locale}catch{e="en-US"}}let r=t.CONTEXT_MODE_TZ??"";if(!r)try{r=new Intl.DateTimeFormat().resolvedOptions().timeZone}catch{r="UTC"}return mu(e)||(e="en-US"),{locale:e,tz:r||"UTC"}}function YE(t){let e=_u();return e?t===e?"~":t.startsWith(e+_L)?"~"+t.slice(e.length):t:t}function RL(t,e,r){if(!Number.isFinite(e)||e<=0)return[];let n=e*Vi(),o=(y,_=2)=>y.toFixed(_),s=Math.round(n/20),i=(n/200).toFixed(1),a=Math.round(n/73.67),c=Math.round(n*10),u=r>0?Math.round(n*10/r*365):0,l=(e*3/1e6).toFixed(2),d=(e*2.5/1e6).toFixed(2),f=(e*1.25/1e6).toFixed(2),h=(e*1/1e6).toFixed(2),p=process.env.PI_CONTEXT_MODE_PRICE_OUTPUT_PER_TOKEN!==void 0,m=process.env.PI_CONTEXT_MODE_MODEL_ID,g=[];return p&&m?g.push(` $${o(n)} of ${m} tokens your team didn't burn.`):p?g.push(` $${o(n)} of tokens your team didn't burn.`):g.push(` $${o(n)} of Opus 4.7 tokens your team didn't burn.`),g.push(` context-mode kept ${et(t)} out of context \u2014 that's ${s} months of Cursor Pro paid for itself.`),c>0&&u>0&&(g.push(""),g.push(` Scale across a 10-dev team and that's ~$${u.toLocaleString("en-US")}/year saved.`)),p||(g.push(""),g.push(" (Opus rates shown for context. On cheaper models the dollar number drops; the savings ratio holds.)")),g}function $L(t){let{conversation:e,lifetime:r,multiAdapter:n,realBytes:o,cwd:s,locale:i,tz:a,now:c,version:u,latestVersion:l}=t,d=[],f=e.events*nw,h=Math.round((e.snapshotBytes??0)/4),p=f+h,m=o?.conversation?.totalSavedTokens??0,g=Math.max(p,m),y=(r?.totalEvents??0)*nw,_=Math.round((r?.rescueBytes??0)/4),x=y+_,S=o?.lifetime?.totalSavedTokens??0,k=Math.max(x,S),R=o?.lifetime?.bytesReturned??0,$=o?.lifetime?.bytesAvoided??0,C=R+$>0?Math.max(1,Math.floor(R/4)):Math.max(1,Math.round(k*.02)),A=n?.totalBytes&&n.totalBytes>0?n.totalBytes:k*4,W=o?.conversation?o.conversation.eventDataBytes+o.conversation.bytesAvoided+o.conversation.snapshotBytes:g*4,T=e.daysAlive>=1?`${e.daysAlive.toFixed(1)} days alive \xB7 still going`:`${Math.max(1,Math.round(e.daysAlive*24))} hr alive \xB7 still going`,E=r?.firstEventMs??n?.perAdapter?.[0]?.firstMs??0,H=E>0?Math.max(1,Math.round((c-E)/864e5)):0,pe=n?.totalSessions??r?.totalSessions??1,dt=n?.perAdapter.filter(Me=>Me.isReal).length??0,gn;if(n&&dt>=2)gn=`across ${dt} AI tools`;else if(n&&dt===1){let Me=n.perAdapter.find(Vt=>Vt.isReal);gn=`in ${Me?gu(Me.name):"Claude Code"}`}else gn="in Claude Code";H>0?d.push(` Across ${H} days you ran ${sr(pe)} conversations ${gn}.`):d.push(` You ran ${sr(pe)} conversations ${gn}.`);let Aw=H>0?A/H:0;d.push(` context-mode kept ${et(A)} out of your context window \u2014 about ${et(Aw)} every single day.`),d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 1. Where you are now \u2500\u2500\u2500"),d.push("");let ig=e.firstEventMs&&e.firstEventMs>0?QE(e.firstEventMs,i,a):"";if(ig?d.push(` This conversation started ${ig} in ${YE(s)}.`):d.push(` This conversation lives in ${YE(s)}.`),d.push(` ${T}.`),e.snapshotsConsumed>0&&e.snapshotBytes>0){let Me=e.lastRescueMs&&e.lastRescueMs>0?QE(e.lastRescueMs,i,a):"",Vt=Math.round(e.snapshotBytes/1024);Me?d.push(` On ${Me}, /compact fired \u2014 ${Vt} KB rescued from snapshot.`):d.push(` /compact fired \u2014 ${Vt} KB rescued from snapshot.`),d.push(" Without that, you'd be re-explaining everything to a blank model right now.")}d.push("");let ag=o?.conversation,cg=ag?.bytesAvoided??0,Nu=ag?.bytesReturned??0;if(cg+Nu===0)d.push(" No measurable redirect activity captured yet \u2014 bars will appear once context-mode diverts its first payload."),d.push("");else{let Me=cg+Nu,Vt=Math.max(1,Nu),Wt=Math.max(1,Math.floor(Me/4)),kr=Math.max(1,Math.floor(Vt/4)),Du=hn(Wt,Wt,32),zw=hn(kr,Wt,32),Lw=(1-kr/Wt)*100,Hw=Math.max(1,Math.round(Wt/kr));d.push(` Without context-mode ${et(Me).padStart(8)} ${Du} ${sr(Wt).padStart(7)} tokens`),d.push(` With context-mode ${et(Vt).padStart(8)} ${zw} ${sr(kr).padStart(7)} tokens`),d.push(` ${Lw.toFixed(0)}% kept out of context \xB7 your AI ran ${Hw}\xD7 longer before /compact fired`),d.push("")}if(e.byDay&&e.byDay.length>0){let Me=e.lastEventMs&&e.firstEventMs?Math.max(1,Math.round((e.lastEventMs-e.firstEventMs)/864e5)+1):e.byDay.length;d.push(` How that ${et(W)} built up \u2014 ${Me} days, ${e.byDay.length} active:`),d.push(""),d.push(...OL(e.byDay,i,a))}d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 2. What this chat captured (used when you --continue or /resume here) \u2500\u2500\u2500"),d.push("");let Nw=e.byCategory.reduce((Me,Vt)=>Me+Vt.count,0).toLocaleString(i);d.push(` ${Nw} things \u2014 files, errors, decisions, agent runs:`),d.push("");let Dw=e.byCategory[0]?.count??1;for(let Me of e.byCategory)d.push(` ${Me.label.padEnd(26)} ${String(Me.count).padStart(5)} ${hn(Me.count,Dw,28)}`);d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 3. The scope, getting wider \u2500\u2500\u2500"),d.push("");let ug=e.firstEventMs&&e.firstEventMs>0?new Intl.DateTimeFormat(i,{timeZone:a,year:"numeric",month:"short",day:"numeric"}).format(new Date(e.firstEventMs)):"",lg=E>0?new Intl.DateTimeFormat(i,{timeZone:a,year:"numeric",month:"short",day:"numeric"}).format(new Date(E)):"",dg=r?.distinctProjects??0,Mw=r?.totalEvents??n?.totalEvents??0;if(d.push(` This chat: ${et(W)} kept out \xB7 ${e.events.toLocaleString(i)} captures${ug?` \xB7 started ${ug}`:""}.`),d.push(` All your work: ${et(A)} kept out \xB7 ${Mw.toLocaleString(i)} captures across ${dg} project${dg===1?"":"s"}${lg?` \xB7 since ${lg}`:""}.`),d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 4. The bottom line \u2500\u2500\u2500"),d.push(""),d.push(...RL(A,k,H)),d.push(""),d.push(""),d.push(" \u2500\u2500\u2500 5. What context-mode learned about how you work \u2500\u2500\u2500"),d.push(""),r&&r.autoMemoryCount>0){d.push(` ${r.autoMemoryCount} preferences picked up across ${r.autoMemoryProjects} project${r.autoMemoryProjects===1?"":"s"}:`);let Me=Object.entries(r.autoMemoryByPrefix).sort((Wt,kr)=>kr[1]-Wt[1]),Vt=Me.length>0?Me[0][1]:1;for(let[Wt,kr]of Me){let Du=cw[Wt]??Wt;d.push(` ${Du.padEnd(26)} ${String(kr).padStart(2)} ${hn(kr,Vt,20)}`)}}else d.push(" No preferences learned yet \u2014 context-mode picks them up automatically.");d.push(""),d.push(""),d.push(" Your AI talks less, remembers more, costs less."),d.push(` Locale ${i} \xB7 timezone ${a} \xB7 pricing examples for illustration only.`),d.push("");let jw=u?`v${u}`:"context-mode";return d.push(` ${jw}`),u&&l&&l!=="unknown"&&sw(l,u)&&d.push(` Update available: v${u} -> v${l} | ctx_upgrade`),CL(d)}function CL(t){let e=[],r=0;for(let n of t)n===""?(r++,r<=2&&e.push(n)):(r=0,e.push(n));for(;e.length>0&&e[e.length-1]==="";)e.pop();return e}function OL(t,e,r){if(t.length===0)return[];let n=[...t].sort((f,h)=>f.ms-h.ms),o=n[0],s=n[n.length-1],i=Math.max(1,s.ms-o.ms),a=n[0];for(let f of n)f.count>a.count&&(a=f);let c=56,u=Array.from({length:c},()=>"\u2500");for(let f of n){let h=Math.round((f.ms-o.ms)/i*(c-1)),p="\u25CF";f===a&&(p="\u2588"),(f.rescueBytes??0)>0&&(p="\u25C6"),u[h]=p}let l=f=>{let h=new Intl.DateTimeFormat(e,{timeZone:r,month:"short",day:"numeric"}).formatToParts(new Date(f)),p=(h.find(g=>g.type==="month")?.value??"").toLowerCase(),m=h.find(g=>g.type==="day")?.value??"";return`${p} ${m}`},d=[];d.push(` ${l(o.ms)} ${u.join("")} ${l(s.ms)}`),d.push("");for(let f of n){let h=l(f.ms).padEnd(7),p=`${f.count} captures`,m=f===a?" \u2190 peak":"",g=(f.rescueBytes??0)>0?` \u25C6 /compact rescued ${Math.round((f.rescueBytes??0)/1024)} KB`:"";d.push(` ${h} ${p}${m}${g}`)}return d.push(""),d.push(" \u25CF active day \u2588 peak day \u25C6 /compact rescue"),d}function QE(t,e,r){if(!Number.isFinite(t)||t<=0)return"";let n=new Date(t);if(Number.isNaN(n.getTime()))return"";let o=new Intl.DateTimeFormat(e,{timeZone:r,year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit",hour12:!1}).formatToParts(n),s=d=>o.find(f=>f.type===d)?.value??"",i=s("day"),a=s("month"),c=s("year"),u=s("hour"),l=s("minute");return u==="24"&&(u="00"),`${i} ${a} ${c} at ${u}:${l} (${r})`}function sr(t){return t>=1e6?`${(t/1e6).toFixed(1)}M`:t>=1e3?`${(t/1e3).toFixed(1)}K`:String(t)}function Vi(){let t=process.env.PI_CONTEXT_MODE_PRICE_OUTPUT_PER_TOKEN;if(t!==void 0&&t!==""){let e=Number(t);if(Number.isFinite(e)&&e>0)return e}return 5/1e6}var UW=5/1e6;function yu(t){return`$${((Number.isFinite(t)&&t>0?t:0)*Vi()).toFixed(2)}`}function hn(t,e,r=40){if(e<=0)return"\u2591".repeat(r);let n=Math.max(1,Math.round(t/e*r));return"\u2588".repeat(Math.min(n,r))+"\u2591".repeat(Math.max(0,r-n))}function ew(t,e){let r=e?.sessionTokensSaved??0;if(t.total_events===0&&(e?.lifetime?.totalEvents??0)===0&&r===0&&(e?.multiAdapter?.totalEvents??0)===0)return[];let n=e?.topN??Number.POSITIVE_INFINITY,o=[];o.push("");let s=e?.multiAdapter,i=s?.perAdapter.filter(m=>m.isReal).length??0,a=s?.totalEvents??e?.lifetime?.totalEvents??t.total_events,c=s?.totalSessions??e?.lifetime?.totalSessions??t.session_count,u=e?.lifetime?.distinctProjects;if(a>0&&u&&u>0){let m=i>=2?" everywhere":"";o.push(` All your work${m} \xB7 ${sr(a)} events captured across ${u} project${u===1?"":"s"} \xB7 ${sr(c)} conversations`)}else{o.push("Persistent memory \u2713 preserved across compact, restart & upgrade");let m=c===0&&r>0?1:c,g=m===1?"1 session":`${sr(m)} sessions`,y=a*256+r;o.push(` ${sr(a)} events \xB7 ${g} \xB7 ~${yu(y)} saved lifetime`)}o.push("");let l=e?.lifetime?.categoryCounts,d;l&&Object.keys(l).length>0?d=Object.entries(l).filter(([,m])=>m>0).map(([m,g])=>({category:m,count:g,label:hu[m]||m})).sort((m,g)=>g.count-m.count):d=(t.by_category??[]).filter(m=>m&&m.count>0);let f=d.slice(0,n),h=f.length>0?f[0].count:1;for(let m of f)o.push(` ${m.label.padEnd(26)} ${String(m.count).padStart(5)} ${hn(m.count,h,30)}`);let p=Math.max(0,d.length-n);return p>0&&o.push(` ... ${p} more categor${p===1?"y":"ies"}`),o}function tw(t){if(!t||t.autoMemoryCount===0)return[];let e=[];e.push(""),e.push(` Preferences learned \xB7 ${t.autoMemoryCount} across ${t.autoMemoryProjects} project${t.autoMemoryProjects===1?"":"s"}`);let r=Object.entries(t.autoMemoryByPrefix).sort((o,s)=>s[1]-o[1]).slice(0,6),n=r.length>0?r[0][1]:1;for(let[o,s]of r){let i=cw[o]??o;e.push(` ${i.padEnd(26)} ${String(s).padStart(2)} ${hn(s,n,20)}`)}return e}function rw(t,e){let r=[],n=yu(t),o=(e?.totalEvents??0)*256+t,s=yu(o);return r.push(""),r.push("\u2500".repeat(65)),r.push("Your AI talks less, remembers more, costs less."),r.push(`${n} this session \xB7 ${s} lifetime`),r.push("\u2500".repeat(65)),r}var nw=256;function ow(t){if(!t)return[];let e=[],r=[];for(let o of t.perAdapter)(o.isReal?e:r).push(o);if(e.length===0&&r.length===0)return[];let n=[];if(e.length>0){n.push(""),n.push("Where it came from (tools you actually used \u2014 fixtures + probes filtered):"),n.push("");let o=16,s=10,i=10,a=16;n.push(` ${"Tool".padEnd(o)}${"Captures".padStart(s)}${"Indexed".padStart(i)}${"Total kept out".padStart(a)}`);let c=[...e].sort((u,l)=>l.dataBytes+l.rescueBytes-(u.dataBytes+u.rescueBytes));for(let u of c){let l=u.dataBytes+u.rescueBytes,d=u.eventCount>0?sr(u.eventCount):"\u2014",f=et(u.dataBytes),h=et(l);n.push(` ${gu(u.name).padEnd(o)}${d.padStart(s)}${f.padStart(i)}${h.padStart(a)}`)}}if(r.length>0){e.length>0&&n.push("");let o=r.map(s=>gu(s.name)).join(", ");n.push(` Skipped (${r.length}): ${o}`),n.push(" These adapters have DBs on disk but only test fixtures, dev skeletons,"),n.push(" or detection probes \u2014 no real chat activity.")}return n}function Su(t,e,r,n){let o=[],s=TL(t.session.uptime_min),i=n?.lifetime,a=n?.mcpUsage,c=n?.conversation,u=n?.realBytes,l=n?.multiAdapter,d=l?.perAdapter.filter(R=>R.isReal).length??0;if(l&&d>0){let R=l.totalSessions||i?.totalSessions||0,$=i?.firstEventMs??0,C=$>0?Math.max(1,Math.round((Date.now()-$)/864e5)):0,A=C>0?`Across ${C} day${C===1?"":"s"} `:"",W=R>0?`you ran ${sr(R)} conversation${R===1?"":"s"} `:"you ran ",T;if(d>=2)T=`across ${d} AI tools`;else{let E=l.perAdapter.find(H=>H.isReal);T=`in ${E?gu(E.name):"Claude Code"}`}o.push(`${A}${W}${T}.`),o.push("")}if(c&&c.events>0){o.length>0&&(o.length=0);let R=PL(),$=n?.cwd??process.cwd(),C=n?.now??Date.now(),A=n?.locale??R.locale,W=n?.tz??R.tz;return o.push(...$L({conversation:c,lifetime:i,multiAdapter:l,realBytes:u,cwd:$,locale:A,tz:W,now:C,version:e,latestVersion:r})),o.join(`
|
|
592
596
|
`)}let f=t.savings.kept_out+(t.cache?t.cache.bytes_saved:0),h=t.savings.total_bytes_returned,p=t.savings.total_calls,m=f+h,g=m>0?f/m*100:0,y=Math.round(f/4),_=h>0?Math.max(1,Math.round(m/Math.max(h,1))):0;if(f===0){o.push(`context-mode ${s} ${p} calls`),o.push(""),p===0?o.push("No tool calls yet. Use batch_execute or execute to start saving tokens."):o.push(`${et(h)} entered context | 0 tokens saved`),o.push(...ew(t.projectMemory,{lifetime:i,multiAdapter:l,sessionTokensSaved:0})),o.push(...ow(l)),o.push(...tw(i)),o.push(...rw(0,i)),o.push("");let R=e?`v${e}`:"context-mode";return o.push(R),e&&r&&r!=="unknown"&&sw(r,e)&&o.push(`Update available: v${e} -> v${r} | ctx_upgrade`),o.join(`
|
|
593
597
|
`)}o.push(`${sr(y)} tokens saved \xB7 ${g.toFixed(1)}% reduction \xB7 ${s} \xB7 ~${yu(y)} saved (Opus)`),o.push(""),o.push(`Without context-mode |${hn(m,m)}| ${et(m)}`),o.push(`With context-mode |${hn(h,m)}| ${et(h)}`),o.push(""),_>=2?o.push(`${et(f)} kept out of your conversation \u2014 ${_}\xD7 longer sessions before compact.`):o.push(`${et(f)} kept out of your conversation. Never entered context.`),o.push("");let x=[`${p} calls`];t.cache&&t.cache.hits>0&&x.push(`${t.cache.hits} cache hits (+${et(t.cache.bytes_saved)})`),o.push(x.join(" \xB7 "));let S=t.savings.by_tool.filter(R=>R.calls>0);if(S.length>=2){o.push("");let R=S.map($=>{let C=$.context_kb*1024,A=g<100?C/(1-g/100):C,W=Math.max(0,A-C);return{...$,returnedBytes:C,estimatedSaved:W}}).sort(($,C)=>C.estimatedSaved-$.estimatedSaved);for(let $ of R){let C=$.tool.length>22?$.tool.slice(0,19)+"...":$.tool;o.push(` ${C.padEnd(22)} ${String($.calls).padStart(4)} calls ${et($.estimatedSaved).padStart(8)} saved`)}}if(a&&a.length>0){let R=a.filter($=>$.median_concurrency!=null&&($.max_concurrency??1)>1);if(R.length>0){o.push(""),o.push("Parallel I/O \u2713 one call did the work of many \u2014 faster runs, lower bill, same answer.");for(let $ of R){let C=$.tool_name.replace(/^mcp__.*?__/,"");o.push(` ${C.padEnd(22)} ${$.calls} batches \xB7 ${$.median_concurrency} typical, ${$.max_concurrency} peak`)}}}o.push(...ew(t.projectMemory,{lifetime:i,multiAdapter:l,sessionTokensSaved:y})),o.push(...ow(l)),o.push(...tw(i)),o.push(...rw(y,i)),o.push("");let k=e?`v${e}`:"context-mode";return o.push(k),e&&r&&r!=="unknown"&&r!==e&&o.push(`Update available: v${e} -> v${r} | ctx_upgrade`),o.join(`
|
|
594
598
|
`)}var Rt=Pt(jL(import.meta.url)),Fr=(()=>{for(let t of["../package.json","./package.json"]){let e=je(Rt,t);if(_e(e))try{return JSON.parse(Gi(e,"utf8")).version}catch{}}return"unknown"})();process.env.CONTEXT_MODE_EMBEDDED_PLUGIN_TOOLS!=="1"&&(process.on("unhandledRejection",t=>{process.stderr.write(`[context-mode] unhandledRejection: ${t}
|