@constellationdev/cli 0.8.1 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/main.js +66 -65
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -1,18 +1,18 @@
1
1
  #!/usr/bin/env node
2
- import {bold,blue,gray,green,red,dim,yellow,cyan}from'yoctocolors';import*as Ce from'os';import Ce__default from'os';import {execFile,execFileSync,spawn}from'child_process';import {promisify,stripVTControlCharacters}from'util';import {createServer}from'http';import {randomBytes}from'crypto';import {confirm,password,input,select,checkbox}from'@inquirer/prompts';import {z}from'zod';import {Readable,Transform}from'stream';import {base32}from'@scure/base';import*as Bt from'fs';import {readFileSync,existsSync}from'fs';import {pipeline}from'stream/promises';import*as Wr from'zlib';import Wr__default from'zlib';import {Agent,fetch as fetch$1}from'undici';import*as E from'path';import E__default,{dirname,join}from'path';import {fileURLToPath,pathToFileURL}from'url';import*as G from'fs/promises';import G__default from'fs/promises';import {findAll,find,parse}from'tsconfck';import Il from'tree-sitter-javascript';import Nl from'tree-sitter-python';import Tl from'tree-sitter-typescript';import wc from'tree-sitter';import Gi from'ignore';import {performance}from'perf_hooks';import Mc from'yocto-spinner';import {parseDocument,isMap,isSeq,stringify}from'yaml';import {simpleGit}from'simple-git';import {Command}from'commander';var us=Object.defineProperty;var f=(i,e)=>()=>(i&&(e=i(i=0)),e);var _n=(i,e)=>{for(var t in e)us(i,t,{get:e[t],enumerable:true});};var ht,yr=f(()=>{ht=["help","--help","-h","--version","-V","-v"];});function gs(){let i=process.env;return i.FORCE_COLOR&&i.FORCE_COLOR!=="0"&&i.FORCE_COLOR!=="false"?true:i.NO_COLOR?false:!!process.stdout.isTTY}function In(i,e,t){return [Math.round(i[0]+(e[0]-i[0])*t),Math.round(i[1]+(e[1]-i[1])*t),Math.round(i[2]+(e[2]-i[2])*t)]}function J(i,e=0,t=false){let n=[],o=0;for(let p of i.matchAll(hs))p.index>o&&n.push({ansi:false,value:i.slice(o,p.index)}),n.push({ansi:true,value:p[0]}),o=p.index+p[0].length;o<i.length&&n.push({ansi:false,value:i.slice(o)});let a=[...n.filter(p=>!p.ansi).map(p=>p.value).join("")],l=We.length,c=a.length,u=0;return n.map(p=>p.ansi?p.value:[...p.value].map(d=>{let m=u++;if(d===" ")return d;let g,h,b;if(t){let y=(m+e)%l/l*(l-1),v=Math.floor(y),x=Math.min(v+1,l-1),j=y-v;[g,h,b]=In(We[v],We[x],j);}else {let y=(c>1?m/(c-1):0)*(l-1),v=Math.floor(y),x=Math.min(v+1,l-1),j=y-v;[g,h,b]=In(We[v],We[x],j);}return fs(g,h,b,d)}).join("")).join("")}var V,We,fs,hs,Ie=f(()=>{V={info:i=>blue(i),success:i=>green(i),warn:i=>yellow(i),error:i=>red(i),accent:i=>bold(blue(i)),muted:i=>gray(i),dim:i=>dim(i)},We=[[142,68,173],[100,110,205],[74,144,226],[90,160,235],[110,180,245],[130,200,250],[110,180,245],[90,160,235],[74,144,226],[100,110,205],[142,68,173]];fs=(i,e,t,n)=>gs()?`\x1B[38;2;${i};${e};${t}m${n}\x1B[0m`:n;hs=/\x1b\[[0-9;]*m/g;});function ys(){return process.env.CONSTELLATION_ASCII_MODE==="1"?false:process.env.CI?true:Ce.platform()==="win32"?!!(process.env.WT_SESSION||process.env.TERM_PROGRAM==="vscode"||process.env.TERM_PROGRAM==="Hyper"||process.env.TERM&&process.env.TERM!=="cygwin"&&process.env.TERM!=="dumb"):true}var vs,bs,Ss,ws,Cs,xs,Es,_s,Ps,Is,He,w,q,T,Z,ae,O=f(()=>{Ie();vs="\u2714",bs="\u2717",Ss="\u26A0",ws="\u2139",Cs="\u26A1",xs="[OK]",Es="[ERR]",_s="[WARN]",Ps="[INFO]",Is="[>>]",He=ys(),w=V.success(He?vs:xs),q=V.error(He?bs:Es),T=V.warn(He?Ss:_s),Z=V.info(He?ws:Ps),ae=V.warn(He?Cs:Is);});var L,bt=f(()=>{Ie();O();L={prefix:{idle:blue("\u25C6"),done:w},style:{highlight:i=>blue(i),answer:i=>green(i),error:i=>red(`${q} ${i}`),help:i=>gray(i)},icon:{checked:green("\u25FC"),unchecked:gray("\u25FB"),cursor:blue("\u276F")}};});async function Tn(i){if(!i.startsWith("http://")&&!i.startsWith("https://"))return false;try{switch(process.platform){case "darwin":return await Sr("open",[i]),!0;case "linux":return await Sr("xdg-open",[i]),!0;case "win32":return await Sr("cmd",["/c","start","",i]),!0;default:return !1}}catch{return false}}var Sr,Rn=f(()=>{Sr=promisify(execFile);});function As(i,e){if(!e)return false;let t,n;try{t=new URL(e),n=new URL(i);}catch{return false}return n.protocol!=="http:"&&n.protocol!=="https:"?false:n.origin===t.origin}function jn(i={}){let e=i.allowedOrigin;return new Promise((t,n)=>{let o=createServer(),s,a=false;o.listen(0,"127.0.0.1",()=>{let l=o.address();if(!l||typeof l=="string"){o.close(),n(new Error("Failed to bind callback server"));return}t({port:l.port,close(){s&&(clearTimeout(s),s=void 0),o.close(),o.closeAllConnections();},waitForCallback(c,u=3e5){return new Promise((p,d)=>{s=setTimeout(()=>{s=void 0,a=true,o.close(),o.closeAllConnections(),d(new Error("Authentication timed out"));},u),o.on("request",(m,g)=>{let h=new URL(m.url??"/",`http://127.0.0.1:${l.port}`);if(h.pathname!=="/callback"){g.writeHead(404,{"Content-Type":"text/plain"}),g.end("Not found");return}let b=h.searchParams.get("key");if(h.searchParams.get("state")!==c){g.writeHead(400,{"Content-Type":"text/plain"}),g.end("Invalid state parameter");return}if(!b||!js.test(b)){g.writeHead(400,{"Content-Type":"text/plain"}),g.end("Invalid key format");return}if(a)return;a=true;let v=h.searchParams.get("return_url");v&&As(v,e)?(g.writeHead(302,{Location:v}),g.end()):(g.writeHead(200,{"Content-Type":"text/html; charset=utf-8"}),g.end(Ls)),s&&(clearTimeout(s),s=void 0),o.close(),o.closeAllConnections(),p(b);});})}});}),o.on("error",l=>{n(l);});})}var js,Ls,Ln=f(()=>{js=/^ak:[0-9a-f]{32}$/i,Ls=`<!DOCTYPE html>
2
+ import {bold,blue,gray,green,red,dim,yellow,cyan}from'yoctocolors';import*as Pe from'os';import Pe__default from'os';import {execFile,execFileSync,spawn}from'child_process';import {promisify,stripVTControlCharacters}from'util';import {createServer}from'http';import {randomBytes}from'crypto';import {confirm,password,input,select,checkbox}from'@inquirer/prompts';import {z}from'zod';import {Readable,Transform}from'stream';import {base32}from'@scure/base';import*as zt from'fs';import {readFileSync,existsSync}from'fs';import {pipeline}from'stream/promises';import*as en from'zlib';import en__default from'zlib';import {Agent,fetch as fetch$1}from'undici';import*as E from'path';import E__default,{dirname,join}from'path';import {fileURLToPath,pathToFileURL}from'url';import*as J from'fs/promises';import J__default from'fs/promises';import {findAll,find,parse}from'tsconfck';import Wl from'tree-sitter-javascript';import zl from'tree-sitter-python';import Kl from'tree-sitter-typescript';import Oc from'tree-sitter';import ro from'ignore';import {performance}from'perf_hooks';import Kc from'yocto-spinner';import {parseDocument,isMap,isSeq,stringify}from'yaml';import {simpleGit}from'simple-git';import {Command}from'commander';var xs=Object.defineProperty;var f=(i,e)=>()=>(i&&(e=i(i=0)),e);var kn=(i,e)=>{for(var t in e)xs(i,t,{get:e[t],enumerable:true});};var vt,wr=f(()=>{vt=["help","--help","-h","--version","-V","-v"];});function Ps(){let i=process.env;return i.FORCE_COLOR&&i.FORCE_COLOR!=="0"&&i.FORCE_COLOR!=="false"?true:i.NO_COLOR?false:!!process.stdout.isTTY}function $n(i,e,t){return [Math.round(i[0]+(e[0]-i[0])*t),Math.round(i[1]+(e[1]-i[1])*t),Math.round(i[2]+(e[2]-i[2])*t)]}function te(i,e=0,t=false){let r=[],o=0;for(let p of i.matchAll(Ns))p.index>o&&r.push({ansi:false,value:i.slice(o,p.index)}),r.push({ansi:true,value:p[0]}),o=p.index+p[0].length;o<i.length&&r.push({ansi:false,value:i.slice(o)});let a=[...r.filter(p=>!p.ansi).map(p=>p.value).join("")],l=qe.length,c=a.length,u=0;return r.map(p=>p.ansi?p.value:[...p.value].map(d=>{let m=u++;if(d===" ")return d;let h,g,y;if(t){let b=(m+e)%l/l*(l-1),v=Math.floor(b),T=Math.min(v+1,l-1),N=b-v;[h,g,y]=$n(qe[v],qe[T],N);}else {let b=(c>1?m/(c-1):0)*(l-1),v=Math.floor(b),T=Math.min(v+1,l-1),N=b-v;[h,g,y]=$n(qe[v],qe[T],N);}return Is(h,g,y,d)}).join("")).join("")}var V,qe,Is,Ns,Le=f(()=>{V={info:i=>blue(i),success:i=>green(i),warn:i=>yellow(i),error:i=>red(i),accent:i=>bold(blue(i)),muted:i=>gray(i),dim:i=>dim(i)},qe=[[142,68,173],[100,110,205],[74,144,226],[90,160,235],[110,180,245],[130,200,250],[110,180,245],[90,160,235],[74,144,226],[100,110,205],[142,68,173]];Is=(i,e,t,r)=>Ps()?`\x1B[38;2;${i};${e};${t}m${r}\x1B[0m`:r;Ns=/\x1b\[[0-9;]*m/g;});function Rs(){return process.env.CONSTELLATION_ASCII_MODE==="1"?false:process.env.CI?true:Pe.platform()==="win32"?!!(process.env.WT_SESSION||process.env.TERM_PROGRAM==="vscode"||process.env.TERM_PROGRAM==="Hyper"||process.env.TERM&&process.env.TERM!=="cygwin"&&process.env.TERM!=="dumb"):true}var Ts,Ls,js,As,ks,Fs,$s,Ds,Os,Ms,Us,Gs,je,w,re,A,ie,de,Er,M=f(()=>{Le();Ts="\u2714",Ls="\u2717",js="\u26A0",As="\u2139",ks="\u26A1",Fs="\u29D7",$s="[OK]",Ds="[ERR]",Os="[WARN]",Ms="[INFO]",Us="[>>]",Gs="[WAIT]",je=Rs(),w=V.success(je?Ts:$s),re=V.error(je?Ls:Ds),A=V.warn(je?js:Os),ie=V.info(je?As:Ms),de=V.warn(je?ks:Us),Er=V.info(je?Fs:Gs);});var F,Ct=f(()=>{Le();M();F={prefix:{idle:blue("\u25C6"),done:w},style:{highlight:i=>blue(i),answer:i=>green(i),error:i=>red(`${re} ${i}`),help:i=>gray(i)},icon:{checked:green("\u25FC"),unchecked:gray("\u25FB"),cursor:blue("\u276F")}};});async function On(i){if(!i.startsWith("http://")&&!i.startsWith("https://"))return false;try{switch(process.platform){case "darwin":return await _r("open",[i]),!0;case "linux":return await _r("xdg-open",[i]),!0;case "win32":return await _r("cmd",["/c","start","",i]),!0;default:return !1}}catch{return false}}var _r,Mn=f(()=>{_r=promisify(execFile);});function Vs(i,e){if(!e)return false;let t,r;try{t=new URL(e),r=new URL(i);}catch{return false}return r.protocol!=="http:"&&r.protocol!=="https:"?false:r.origin===t.origin}function Un(i={}){let e=i.allowedOrigin;return new Promise((t,r)=>{let o=createServer(),s,a=false;o.listen(0,"127.0.0.1",()=>{let l=o.address();if(!l||typeof l=="string"){o.close(),r(new Error("Failed to bind callback server"));return}t({port:l.port,close(){s&&(clearTimeout(s),s=void 0),o.close(),o.closeAllConnections();},waitForCallback(c,u=3e5){return new Promise((p,d)=>{s=setTimeout(()=>{s=void 0,a=true,o.close(),o.closeAllConnections(),d(new Error("Authentication timed out"));},u),o.on("request",(m,h)=>{let g=new URL(m.url??"/",`http://127.0.0.1:${l.port}`);if(g.pathname!=="/callback"){h.writeHead(404,{"Content-Type":"text/plain"}),h.end("Not found");return}let y=g.searchParams.get("key");if(g.searchParams.get("state")!==c){h.writeHead(400,{"Content-Type":"text/plain"}),h.end("Invalid state parameter");return}if(!y||!zs.test(y)){h.writeHead(400,{"Content-Type":"text/plain"}),h.end("Invalid key format");return}if(a)return;a=true;let v=g.searchParams.get("return_url");v&&Vs(v,e)?(h.writeHead(302,{Location:v}),h.end()):(h.writeHead(200,{"Content-Type":"text/html; charset=utf-8"}),h.end(Ks)),s&&(clearTimeout(s),s=void 0),o.close(),o.closeAllConnections(),p(y);});})}});}),o.on("error",l=>{r(l);});})}var zs,Ks,Gn=f(()=>{zs=/^ak:[0-9a-f]{32}$/i,Ks=`<!DOCTYPE html>
3
3
  <html><head><title>Authentication Successful</title></head>
4
- <body><h1>Authentication successful! You can close this tab.</h1></body></html>`;});function wr(i){process.stdout.write(i+`
5
- `);}function St(i,e){let t=`${i} \u203A ${e}`;wr(`${J("\u256D\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256E")}
6
- ${J("\u2502 \u2580\u2584 \u2588\u2580\u2580 \u2588\u2580\u2588 \u2588\u2580\u2588 \u2588\u2580\u2580 \u2580\u2588\u2580 \u2588\u2580\u2580 \u2588 \u2588 \u2588\u2580\u2588 \u2580\u2588\u2580 \u2580\u2588\u2580 \u2588\u2580\u2588 \u2588\u2580\u2588 \u2584 \u2584 \u2588\u2580\u2580 \u2588 \u2580\u2588\u2580 \u2502")}
7
- ${J("\u2502 \u2584\u2580 \u2588 \u2588 \u2588 \u2588 \u2588 \u2580\u2580\u2588 \u2588 \u2588\u2580 \u2588 \u2588 \u2588\u2580\u2588 \u2588 \u2588 \u2588 \u2588 \u2588 \u2588 \u2580 \u2584\u2580 \u2584\u2580 \u2588 \u2588 \u2588 \u2502")}
8
- ${J("\u2502 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580 \u2580 \u2580\u2580\u2580 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580 \u2580 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580 \u2580 \u2580 \u2580 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2502")}
9
- ${J("\u2502 CONSTELLATIONDEV.IO \u2502")}`),e&&e.length>0?wr(`${J(`\u251C\u2500${"\u2500".repeat(t.length)}\u2500\u252C\u2500${"\u2500".repeat(78-t.length)}\u256F`)}
10
- ${J(`\u2502 ${bold(t)} \u2502${" ".repeat(80-t.length)}`)}
11
- ${J(`\u2570\u2500${"\u2500".repeat(t.length)}\u2500\u256F${" ".repeat(80-t.length)}`)}
12
- `):wr(J("\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256F"));}var An=f(()=>{Ie();});var le,kn,wt=f(()=>{An();le="CONSTELLATION_ACCESS_KEY",kn="CONSTELLATION_WEB_URL";});var ce,Ct=f(()=>{ce=class{git;config;langRegistry;env;reporter;constructor(e){this.git=e.GitClient,this.config=e.Config,this.langRegistry=e.LanguageRegistry,this.env=e.Environment,this.reporter=e.Reporter;}};});function Os(i){return Ds.test(i)}function Ms(i){return i.replace(/ak:[0-9a-f]{32}/gi,"[REDACTED]")}var Ds,Ke,$n=f(()=>{bt();Rn();Ln();wt();O();Ct();Ds=/^ak:[0-9a-f]{32}$/i;Ke=class extends ce{async run(e){try{if(!this.env)throw new Error("Environment manager not initialized");if(this.reporter.log(`${ae} Configuring access key authentication...
4
+ <body><h1>Authentication successful! You can close this tab.</h1></body></html>`;});function Pr(i){process.stdout.write(i+`
5
+ `);}function xt(i,e){let t=`${i} \u203A ${e}`;Pr(`${te("\u256D\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256E")}
6
+ ${te("\u2502 \u2580\u2584 \u2588\u2580\u2580 \u2588\u2580\u2588 \u2588\u2580\u2588 \u2588\u2580\u2580 \u2580\u2588\u2580 \u2588\u2580\u2580 \u2588 \u2588 \u2588\u2580\u2588 \u2580\u2588\u2580 \u2580\u2588\u2580 \u2588\u2580\u2588 \u2588\u2580\u2588 \u2584 \u2584 \u2588\u2580\u2580 \u2588 \u2580\u2588\u2580 \u2502")}
7
+ ${te("\u2502 \u2584\u2580 \u2588 \u2588 \u2588 \u2588 \u2588 \u2580\u2580\u2588 \u2588 \u2588\u2580 \u2588 \u2588 \u2588\u2580\u2588 \u2588 \u2588 \u2588 \u2588 \u2588 \u2588 \u2580 \u2584\u2580 \u2584\u2580 \u2588 \u2588 \u2588 \u2502")}
8
+ ${te("\u2502 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580 \u2580 \u2580\u2580\u2580 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580 \u2580 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580 \u2580 \u2580 \u2580 \u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2580\u2580\u2580 \u2502")}
9
+ ${te("\u2502 CONSTELLATIONDEV.IO \u2502")}`),e&&e.length>0?Pr(`${te(`\u251C\u2500${"\u2500".repeat(t.length)}\u2500\u252C\u2500${"\u2500".repeat(78-t.length)}\u256F`)}
10
+ ${te(`\u2502 ${bold(t)} \u2502${" ".repeat(80-t.length)}`)}
11
+ ${te(`\u2570\u2500${"\u2500".repeat(t.length)}\u2500\u256F${" ".repeat(80-t.length)}`)}
12
+ `):Pr(te("\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256F"));}var Bn=f(()=>{Le();});var me,Hn,Et=f(()=>{Bn();me="CONSTELLATION_ACCESS_KEY",Hn="CONSTELLATION_WEB_URL";});var ge,_t=f(()=>{ge=class{git;config;langRegistry;env;reporter;constructor(e){this.git=e.GitClient,this.config=e.Config,this.langRegistry=e.LanguageRegistry,this.env=e.Environment,this.reporter=e.Reporter;}};});function Qs(i){return Xs.test(i)}function Zs(i){return i.replace(/ak:[0-9a-f]{32}/gi,"[REDACTED]")}var Xs,Ye,zn=f(()=>{Ct();Mn();Gn();Et();M();_t();Xs=/^ak:[0-9a-f]{32}$/i;Ye=class extends ge{async run(e){try{if(!this.env)throw new Error("Environment manager not initialized");if(this.reporter.log(`${de} Configuring access key authentication...
13
13
  `),this.env.isCI()){this.reporter.error(`Cannot configure authentication in CI/CD environments
14
14
 
15
- The ${le} environment variable must be configured
15
+ The ${me} environment variable must be configured
16
16
  directly in your pipeline settings:
17
17
 
18
18
  - GitHub Actions: Repository Settings -> Secrets and variables -> Actions
@@ -20,54 +20,55 @@ ${J(`\u2570\u2500${"\u2500".repeat(t.length)}\u2500\u256F${" ".repeat(80-t.lengt
20
20
  - Azure DevOps: Pipelines -> Library -> Variable groups
21
21
  - Jenkins: Manage Jenkins -> Credentials
22
22
  - CircleCI: Project Settings -> Environment Variables
23
- `);return}if(await this.env.getKey(le)&&!await confirm({message:"Replace existing Constellation access key?",default:!1,theme:L})){this.reporter.log(`${w} Keeping existing Constellation access key`);return}e?await this.manualAuthFlow():await this.browserAuthFlow();}catch(t){if(t instanceof Error&&t.name==="ExitPromptError")return;let n=t.message??"An unexpected error occurred",o=Ms(n);this.reporter.error(`Failed to store Constellation access key
24
- ${o}`);}}async manualAuthFlow(){let e,t=0,n=3;for(;t<n;){if(e=(await password({message:"Constellation Access Key:",theme:L})).trim(),!e){this.reporter.warn("Access key cannot be empty."),t++;continue}if(!Os(e)){if(t++,t<n)this.reporter.warn(`Invalid access key format. Expected format: ak:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
25
- Attempts remaining: ${n-t}`);else {this.reporter.error(`Invalid access key format after ${n} attempts.
26
- Please verify your access key and try again.`);return}continue}break}await this.storeKey(e);}async browserAuthFlow(){let e=randomBytes(16).toString("hex"),t=process.env[kn]||"https://app.constellationdev.io",{port:n,waitForCallback:o}=await jn({allowedOrigin:t}),s=`${t}/auth/cli?callback_port=${n}&state=${e}`;this.reporter.info("Opening browser for authentication..."),await Tn(s)||this.reporter.warn(`Could not open browser automatically.
23
+ `);return}if(await this.env.getKey(me)&&!await confirm({message:"Replace existing Constellation access key?",default:!1,theme:F})){this.reporter.log(`${w} Keeping existing Constellation access key`);return}e?await this.manualAuthFlow():await this.browserAuthFlow();}catch(t){if(t instanceof Error&&t.name==="ExitPromptError")return;let r=t.message??"An unexpected error occurred",o=Zs(r);this.reporter.error(`Failed to store Constellation access key
24
+ ${o}`);}}async manualAuthFlow(){let e,t=0,r=3;for(;t<r;){if(e=(await password({message:"Constellation Access Key:",theme:F})).trim(),!e){this.reporter.warn("Access key cannot be empty."),t++;continue}if(!Qs(e)){if(t++,t<r)this.reporter.warn(`Invalid access key format. Expected format: ak:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
25
+ Attempts remaining: ${r-t}`);else {this.reporter.error(`Invalid access key format after ${r} attempts.
26
+ Please verify your access key and try again.`);return}continue}break}await this.storeKey(e);}async browserAuthFlow(){let e=randomBytes(16).toString("hex"),t=process.env[Hn]||"https://app.constellationdev.io",{port:r,waitForCallback:o}=await Un({allowedOrigin:t}),s=`${t}/auth/cli?callback_port=${r}&state=${e}`;this.reporter.info("Opening browser for authentication..."),await On(s)||this.reporter.warn(`Could not open browser automatically.
27
27
  Please open this URL manually:
28
28
 
29
29
  ${s}
30
- `),this.reporter.info("Waiting for authentication... (press Ctrl+C to cancel)");try{let l=await o(e);await this.storeKey(l);}catch{this.reporter.error("Authentication timed out.\n Try again or use `constellation auth --manual` to paste your key directly.");}}async storeKey(e){await this.env.setKey(le,e),this.reporter.log(`${w} Stored access key in ${le} user environment variable`);let t=this.env.getSourceFile();t&&this.reporter.info(`To activate in this session, run:
30
+ `),this.reporter.info("Waiting for authentication... (press Ctrl+C to cancel)");try{let l=await o(e);await this.storeKey(l);}catch{this.reporter.error("Authentication timed out.\n Try again or use `constellation auth --manual` to paste your key directly.");}}async storeKey(e){await this.env.setKey(me,e),this.reporter.log(`${w} Stored access key in ${me} user environment variable`);let t=this.env.getSourceFile();t&&this.reporter.info(`To activate in this session, run:
31
31
 
32
32
  source ${t}
33
33
 
34
- New terminal sessions will load it automatically.`),Ce.platform()==="darwin"&&this.reporter.info("Already-running desktop apps (Claude Desktop, Codex, etc.) must be quit and relaunched to see the new value.");}};});var Us,ee,Ve,Gs,Ne,Je,Bs,zs,Ws,qe,Hs,Ks,Vs,Js,qs,Ys,Xs,Qs,Zs,ea,ta,ra,na,ia,oa,sa,aa,Dn,la,ca,pa,ua,da,ma,ga,fa,ha,ya,va,ba,Sa,wa,Ca,xa,Mn,Ea,_a,Cr,Pa,Ia,Na,Ta,Ye,Ra,ja,La,Aa,ka,Un,Fa,$a,xt,Gn,On,Da,Oa,Ma,xr,Bn,Ua,Ga,Ba,za,Er,Wa,Ha,Ka,Va,Ja,qa,zn,Wn,Hn,Kn,Ya,Xa,Qa,Vn,Jn,Xe=f(()=>{Us=z.object({total:z.number().int().nonnegative(),returned:z.number().int().nonnegative(),hasMore:z.boolean(),nextOffset:z.number().int().nonnegative().optional(),currentOffset:z.number().int().nonnegative().optional()}),z.object({overall:z.number().min(0).max(1),factors:z.object({dataFreshness:z.number().min(0).max(1).optional(),coverageComplete:z.number().min(0).max(1).optional(),heuristicAccuracy:z.number().min(0).max(1).optional(),semanticAnalysisDepth:z.number().min(0).max(1).optional(),patternMatchQuality:z.number().min(0).max(1).optional()}).optional(),warnings:z.array(z.string()).optional(),recommendations:z.array(z.string()).optional()}),z.object({qualityScore:z.number().min(0).max(100).optional(),lastUpdated:z.string().optional(),cached:z.boolean().optional(),executionTime:z.number().nonnegative().optional(),coveragePercentage:z.number().min(0).max(100).optional(),issues:z.array(z.string()).optional()}),ee=z.object({language:z.string(),features:z.array(z.string()).optional(),visibility:z.string().optional(),decorators:z.array(z.string()).optional(),typeInfo:z.any().optional(),custom:z.record(z.string(),z.any()).optional()}),z.enum(["function","class","interface","type","variable","constant","enum","module","namespace","method","property","parameter","constructor","decorator","trait","struct","macro","unknown"]),Ve=z.enum(["low","medium","high","critical"]),Gs=z.enum(["low","moderate","high","very_high"]),Ne=z.object({cyclomaticComplexity:z.number().int().nonnegative(),complexityRisk:Gs}),Je=z.object({filePath:z.string(),line:z.number().int().positive().optional(),lineStart:z.number().int().positive().optional(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative().optional()}),Je.extend({symbolId:z.string().optional(),symbolName:z.string().optional(),symbolKind:z.string().optional()}),z.object({outgoing:z.array(z.string()),incoming:z.array(z.string())}),Bs=z.object({id:z.string(),name:z.string(),type:z.string(),properties:z.record(z.string(),z.any()).optional()}),zs=z.object({from:z.string(),to:z.string(),type:z.string().optional(),weight:z.number().optional(),properties:z.record(z.string(),z.any()).optional()}),Ws=z.object({nodes:z.array(Bs),edges:z.array(zs),metadata:z.object({nodeCount:z.number().int().nonnegative(),edgeCount:z.number().int().nonnegative(),directed:z.boolean(),hasCycles:z.boolean().optional()}).optional()}),qe=new Set(["abc","aifc","argparse","array","ast","asynchat","asyncio","asyncore","atexit","audioop","base64","bdb","binascii","bisect","builtins","bz2","cProfile","calendar","cgi","cgitb","chunk","cmath","cmd","code","codecs","codeop","collections","colorsys","compileall","concurrent","configparser","contextlib","contextvars","copy","copyreg","crypt","csv","ctypes","curses","dataclasses","datetime","dbm","decimal","difflib","dis","distutils","doctest","email","encodings","ensurepip","enum","errno","faulthandler","fcntl","filecmp","fileinput","fnmatch","fractions","ftplib","functools","gc","getopt","getpass","gettext","glob","graphlib","grp","gzip","hashlib","heapq","hmac","html","http","idlelib","imaplib","imghdr","imp","importlib","inspect","io","ipaddress","itertools","json","keyword","lib2to3","linecache","locale","logging","lzma","mailbox","mailcap","marshal","math","mimetypes","mmap","modulefinder","msilib","msvcrt","multiprocessing","netrc","nis","nntplib","numbers","operator","optparse","os","ossaudiodev","pathlib","pdb","pickle","pickletools","pipes","pkgutil","platform","plistlib","poplib","posix","posixpath","pprint","profile","pstats","pty","pwd","py_compile","pyclbr","pydoc","queue","quopri","random","re","readline","reprlib","resource","rlcompleter","runpy","sched","secrets","select","selectors","shelve","shlex","shutil","signal","site","sitecustomize","smtpd","smtplib","sndhdr","socket","socketserver","spwd","sqlite3","ssl","stat","statistics","string","stringprep","struct","subprocess","sunau","symtable","sys","sysconfig","syslog","tabnanny","tarfile","telnetlib","tempfile","termios","test","textwrap","threading","time","timeit","tkinter","token","tokenize","tomllib","trace","traceback","tracemalloc","tty","turtle","turtledemo","types","typing","unicodedata","unittest","urllib","usercustomize","uu","uuid","venv","warnings","wave","weakref","webbrowser","winreg","winsound","wsgiref","xdrlib","xml","xmlrpc","zipapp","zipfile","zipimport","zlib","zoneinfo","_thread","_tkinter","__future__","__main__"]),z.object({success:z.literal(false),error:z.object({code:z.string(),message:z.string(),details:z.any().optional()})}),z.object({query:z.string().max(200),filterByKind:z.array(z.string()).optional(),filterByVisibility:z.array(z.string()).optional(),isExported:z.boolean().optional(),filterByFile:z.string().optional(),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0),includeUsageCount:z.boolean().optional(),includeDocumentation:z.boolean().optional()}).refine(i=>i.query.length>0||i.filterByKind&&i.filterByKind.length>0||i.filterByVisibility&&i.filterByVisibility.length>0||i.isExported!==void 0||i.filterByFile!==void 0,{message:"Either query must be non-empty or at least one filter (filterByKind, filterByVisibility, isExported, filterByFile) must be provided",path:["query"]}),Hs=Je.extend({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),signature:z.string().optional(),documentation:z.string().optional(),visibility:z.string().optional(),isExported:z.boolean(),usageCount:z.number().int().nonnegative().optional(),complexity:Ne.optional(),languageMetadata:ee.optional()}),z.object({symbols:z.array(Hs),pagination:Us.optional()}),z.object({symbolId:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),includeReferences:z.boolean().optional(),includeRelationships:z.boolean().optional(),includeImpactScore:z.boolean().optional()}),Ks=Je.extend({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),signature:z.string().optional(),documentation:z.string().optional(),visibility:z.string().optional(),modifiers:z.array(z.string()).optional(),typeInfo:z.any().optional(),decorators:z.array(z.string()).optional(),isExported:z.boolean(),isDeprecated:z.boolean(),complexity:Ne.optional(),languageMetadata:ee.optional()}),Vs=Je.extend({usageType:z.string(),context:z.string().optional(),aliasName:z.string().optional()}),Js=z.object({calls:z.array(z.string()),calledBy:z.array(z.string()),inheritsFrom:z.array(z.string()),inheritedBy:z.array(z.string()),children:z.array(z.string())}),qs=z.object({directUsage:z.number().int().nonnegative(),transitiveImpact:z.number().int().nonnegative(),riskScore:z.number().min(0).max(100),riskLevel:Ve}),z.object({symbol:Ks,references:z.array(Vs).optional(),relationships:Js.optional(),impactScore:qs.optional()}),z.object({filePath:z.string().min(1),depth:z.number().int().nonnegative().max(10).optional(),includePackages:z.boolean().optional(),includeSymbols:z.boolean().optional(),limit:z.number().int().positive().max(100).default(20),offset:z.number().int().nonnegative().default(0)}),Ys=z.object({type:z.enum(["file","module"]),filePath:z.string().nullable(),moduleName:z.string().nullable().optional(),importedSymbols:z.array(z.string()).optional(),isDefault:z.boolean(),isNamespace:z.boolean()}),Xs=z.object({filePath:z.string(),distance:z.number().int().positive(),path:z.array(z.string())}),Qs=z.object({name:z.string(),version:z.string().optional(),type:z.string()}),z.object({totalFiles:z.number().int().nonnegative(),totalPackages:z.number().int().nonnegative(),maxDepth:z.number().int().nonnegative()}),z.object({file:z.string(),directDependencies:z.array(Ys),transitiveDependencies:z.array(Xs).optional(),packages:z.array(Qs).optional()}),z.object({filePath:z.string().min(1),depth:z.number().int().nonnegative().max(10).optional(),includeSymbols:z.boolean().optional(),includeImpactMetrics:z.boolean().optional(),limit:z.number().int().positive().max(100).default(20),offset:z.number().int().nonnegative().default(0)}),Zs=z.object({filePath:z.string(),usedSymbols:z.array(z.string()).optional()}),ea=z.object({filePath:z.string(),distance:z.number().int().positive(),path:z.array(z.string())}),z.object({totalFiles:z.number().int().nonnegative(),maxDepth:z.number().int().nonnegative(),riskLevel:Ve}),z.object({file:z.string(),directDependents:z.array(Zs),transitiveDependents:z.array(ea).optional(),detailedMetrics:z.object({byDepth:z.record(z.string(),z.number()),criticalPaths:z.array(z.array(z.string())),mostImpactedFiles:z.array(z.string())}).optional()}),z.object({filePath:z.string().min(1).optional(),minCycleLength:z.number().int().min(2).max(10).optional(),maxCycleLength:z.number().int().min(2).max(10).optional(),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0),includeImpactScore:z.boolean().optional(),includeConfidence:z.boolean().optional()}),ta=z.object({files:z.array(z.string()),length:z.number().int().positive(),impactScore:z.number().min(0).max(100).optional(),severity:Ve}),z.object({cycles:z.array(ta)}),z.object({symbolId:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),filterByUsageType:z.array(z.string()).optional(),filterByRelationshipType:z.array(z.string()).optional(),includeTransitive:z.boolean().optional(),includeContext:z.boolean().optional(),excludeTests:z.boolean().optional(),excludeGenerated:z.boolean().optional(),includeImportanceWeight:z.boolean().optional(),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0)}),ra=z.object({name:z.string(),kind:z.string(),visibility:z.string().optional(),filePath:z.string(),lineEnd:z.number().int().positive().optional(),complexity:Ne.optional(),languageMetadata:ee.optional()}),na=z.object({filePath:z.string(),usageType:z.string(),relationshipType:z.string(),line:z.number().int().positive().optional(),column:z.number().int().nonnegative().optional(),enclosingSymbol:z.object({name:z.string(),kind:z.string()}).optional(),context:z.string().optional(),aliasName:z.string().optional(),isTest:z.boolean().optional(),isGenerated:z.boolean().optional(),importanceWeight:z.number().min(0).max(1).optional()}),ia=z.object({filePath:z.string(),distance:z.number().int().positive(),chain:z.array(z.string())}),z.object({symbol:ra,directUsages:z.array(na),transitiveUsages:z.array(ia).optional()}),z.object({symbolId:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),direction:z.enum(["callers","callees","both"]).default("both"),depth:z.number().int().positive().max(10).default(3),excludeExternal:z.boolean().optional(),includeGraph:z.boolean().optional(),limit:z.number().int().positive().max(100).default(25),offset:z.number().int().nonnegative().default(0)}),oa=z.object({symbolId:z.string(),name:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),complexity:Ne.optional(),languageMetadata:ee.optional()}),sa=z.object({symbolId:z.string(),name:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),depth:z.number().int().nonnegative(),complexity:Ne.optional(),languageMetadata:ee.optional()}),aa=z.object({symbolId:z.string(),name:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),isAsync:z.boolean(),depth:z.number().int().nonnegative(),complexity:Ne.optional(),languageMetadata:ee.optional()}),z.object({root:oa,callers:z.array(sa).optional(),callees:z.array(aa).optional(),graph:Ws.optional()}),z.object({symbolId:z.string().optional(),qualifiedName:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),includeDirectDependents:z.boolean().default(true),includeTransitiveDependents:z.boolean().default(true),depth:z.number().int().min(1).max(5).default(3),excludeTests:z.boolean().default(true),excludeGenerated:z.boolean().default(true),analyzeBreakingChanges:z.boolean().default(true)}),Dn=Je.extend({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),visibility:z.string().optional(),relationshipType:z.string(),depth:z.number().int().positive(),isExported:z.boolean().optional(),transitiveImpactCount:z.number().int().nonnegative().optional(),languageMetadata:ee.optional()}),la=z.object({filePath:z.string(),symbolCount:z.number().int().positive(),isTest:z.boolean().optional(),isGenerated:z.boolean().optional(),symbols:z.array(z.object({id:z.string(),name:z.string(),kind:z.string(),line:z.number().int().positive()}))}),ca=z.object({riskLevel:Ve,factors:z.array(z.object({factor:z.string(),severity:z.enum(["low","medium","high"]),description:z.string()})),recommendations:z.array(z.string())}),z.object({symbol:z.object({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),isExported:z.boolean().optional(),languageMetadata:ee.optional()}),directDependents:z.array(Dn).optional(),transitiveDependents:z.array(Dn).optional(),impactedFiles:z.array(la),breakingChangeRisk:ca.optional(),summary:z.object({directDependentCount:z.number().int().nonnegative(),transitiveDependentCount:z.number().int().nonnegative(),impactedFileCount:z.number().int().nonnegative(),testFileCount:z.number().int().nonnegative(),productionFileCount:z.number().int().nonnegative(),maxDepth:z.number().int().nonnegative()})}),z.object({filePattern:z.string().optional(),filterByKind:z.array(z.string()).optional(),exportedOnly:z.boolean().optional(),excludeTests:z.boolean().default(true),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0),includeConfidence:z.boolean().optional()}),pa=z.object({symbolId:z.string(),name:z.string(),kind:z.string(),visibility:z.string().optional(),filePath:z.string(),lineEnd:z.number().int().positive().optional(),isExported:z.boolean(),reason:z.string(),confidence:z.number().min(0).max(1),languageMetadata:ee.optional()}),ua=z.object({filePath:z.string(),reason:z.string(),lastUpdated:z.string(),confidence:z.number().min(0).max(1)}),z.object({orphanedSymbols:z.array(pa),orphanedFiles:z.array(ua)}),z.object({includeMetrics:z.boolean().default(false),includeModuleGraph:z.boolean().default(false),includePackages:z.boolean().default(true)}),da=z.object({language:z.string(),fileCount:z.number().int().nonnegative(),percentage:z.number().min(0).max(100)}),ma=z.object({name:z.string(),version:z.string().optional(),confidence:z.enum(["high","medium","low"]),evidence:z.array(z.string())}),ga=z.object({languages:z.array(da),frameworks:z.array(ma),primaryLanguage:z.string(),totalFiles:z.number().int().nonnegative(),totalLines:z.number().int().nonnegative().optional()}),fa=z.object({files:z.object({total:z.number().int().nonnegative(),byType:z.record(z.string(),z.number()),byParadigm:z.record(z.string(),z.number())}),symbols:z.object({total:z.number().int().nonnegative(),byKind:z.record(z.string(),z.number()),exported:z.number().int().nonnegative(),public:z.number().int().nonnegative()}),modules:z.object({total:z.number().int().nonnegative(),averageSize:z.number().nonnegative(),largest:z.string()})}),ha=z.object({internal:z.object({totalConnections:z.number().int().nonnegative(),averagePerFile:z.number().nonnegative(),mostConnectedFiles:z.array(z.object({path:z.string(),incomingCount:z.number().int().nonnegative(),outgoingCount:z.number().int().nonnegative()}))}),external:z.object({totalPackages:z.number().int().nonnegative(),directDependencies:z.number().int().nonnegative(),topPackages:z.array(z.object({name:z.string(),usageCount:z.number().int().nonnegative()}))})}),ya=z.object({complexity:z.object({average:z.number().nonnegative(),high:z.number().int().nonnegative()}),maintainability:z.object({score:z.number().min(0).max(100),issues:z.array(z.string())}),testCoverage:z.object({percentage:z.number().min(0).max(100),testedFiles:z.number().int().nonnegative(),totalFiles:z.number().int().nonnegative()}).optional()}),va=z.object({id:z.string(),name:z.string(),fileCount:z.number().int().nonnegative(),type:z.string()}),ba=z.object({from:z.string(),to:z.string(),weight:z.number().int().nonnegative()}),Sa=z.object({nodes:z.array(va),edges:z.array(ba)}),z.object({metadata:ga,structure:fa,dependencies:ha,metrics:ya.optional(),moduleGraph:Sa.optional()}),z.object({}).strict(),z.object({pong:z.literal(true)}),wa=z.enum(["relative","workspace","alias","external","builtin"]),Ca=z.object({source:z.string(),resolvedPath:z.string().optional(),isExternal:z.boolean(),importType:wa}),xa=z.record(z.string(),Ca),Mn=z.enum(["call","read","write","type","instantiate","import-use","declaration"]),Ea=Mn.exclude(["import-use","declaration"]),_a=z.object({line:z.number().int().nonnegative(),column:z.number().int().nonnegative(),referenceType:Mn}).strict(),Cr=z.object({filePath:z.string().min(1),entries:z.array(_a).max(1e5)}).strict(),z.object({file:z.string().min(1),language:z.string().min(1),commit:z.string().min(1),timestamp:z.string().datetime(),ast:z.string().min(1),importResolutions:xa.optional(),classificationMap:Cr.optional()}).strict(),Pa=z.object({file:z.string(),error:z.string()}),Ia=z.object({file:z.string(),failedCount:z.number().int().nonnegative(),createdCount:z.number().int().nonnegative(),isTransient:z.boolean()}),Na=z.object({totalCreated:z.number().int().nonnegative(),totalFailed:z.number().int().nonnegative(),filesWithFailures:z.array(Ia)}),z.object({processed:z.number().int().nonnegative(),failed:z.number().int().nonnegative(),projectId:z.string(),branchName:z.string(),failedFiles:z.array(Pa).optional(),relationships:Na}),z.object({projectId:z.string(),projectName:z.string(),branch:z.string(),latestCommit:z.string().nullable(),fileCount:z.number().int().nonnegative(),lastIndexedAt:z.string().nullable(),languages:z.array(z.string())}),Ta=z.object({local:z.string(),original:z.string().optional(),isDefault:z.boolean(),isNamespace:z.boolean()}),z.object({source:z.string(),specifiers:z.array(Ta),isType:z.boolean(),isDynamic:z.boolean(),isConditional:z.boolean().optional(),isLazy:z.boolean().optional(),isWildcard:z.boolean().optional(),line:z.number(),column:z.number()}),z.object({referencerId:z.string(),referencedName:z.string(),referenceType:Ea,line:z.number(),column:z.number(),scope:z.string().optional(),objectContext:z.string().optional(),language:z.string().optional()}),z.enum(["processing","completed","failed","cancelled","queued","superseded","cleaned_up"]),z.enum(["acquired","current","duplicate","superseded","queued"]),Ye={branchName:z.string().optional(),effectiveBranchName:z.string().optional(),remapped:z.boolean().optional()},Ra=z.object({status:z.literal("acquired"),attemptId:z.string().uuid(),...Ye}),ja=z.object({status:z.literal("current"),...Ye}),La=z.object({status:z.literal("duplicate"),...Ye}),Aa=z.object({status:z.literal("superseded"),activeCommit:z.string().optional(),...Ye}),ka=z.object({status:z.literal("queued"),queuedAttemptId:z.string().uuid(),...Ye}),Un=z.discriminatedUnion("status",[Ra,ja,La,Aa,ka]),z.object({"x-attempt-id":z.string().uuid(),"x-project-id":z.string(),"x-branch-name":z.string(),"x-commit-hash":z.string().length(40),"x-constellation-dirty":z.union([z.literal("true"),z.literal("false")]).optional()}),Fa=z.enum(["pass1","pass2","pass2b","pass3"]),$a=z.object({phase:Fa,durationMs:z.number().int().nonnegative(),fileCount:z.number().int().nonnegative(),symbolCount:z.number().int().nonnegative().optional(),relationshipCount:z.number().int().nonnegative().optional(),throughputPerSec:z.number().nonnegative(),deadlockRetryCount:z.number().int().nonnegative().optional()}),xt=z.array($a),Gn=z.object({filePath:z.string().min(1),line:z.number().int().positive(),column:z.number().int().nonnegative()}).strict(),On=Gn.extend({name:z.string().min(1)}).strict(),Da=z.object({resolvedType:z.string().min(1),returnType:z.string().optional(),documentation:z.string().max(16384).optional()}).strict(),Oa=z.object({name:z.string().min(1),line:z.number().int().positive(),column:z.number().int().nonnegative(),kind:z.string().min(1),typeInfo:Da.optional(),references:z.object({count:z.number().int().nonnegative(),locations:z.array(Gn).max(100)}).optional(),callHierarchy:z.object({incomingCalls:z.array(On).max(200),outgoingCalls:z.array(On).max(200)}).optional()}).strict(),z.object({filePath:z.string().min(1),language:z.string().min(1),symbols:z.array(Oa).max(1e4)}).strict(),z.object({projectId:z.string().min(1),branch:z.string().min(1),commit:z.string().regex(/^[0-9a-f]{40}$/),timestamp:z.string().datetime()}).strict(),Ma=z.enum(["pending","processing","completed","failed","skipped"]),xr=z.object({status:Ma,filesProcessed:z.number().int().nonnegative().nullable(),completedAt:z.union([z.string().datetime({offset:true}),z.date()]).nullable()}),z.enum(["current","processing","stale","failed"]),Bn=z.union([z.string().datetime({offset:true}),z.date()]),Ua=z.object({status:z.literal("processing"),commitHash:z.string().nullable().optional(),startedAt:Bn.optional(),phaseMetrics:xt.optional()}).passthrough(),Ga=z.object({status:z.literal("current"),commitHash:z.string().nullable().optional(),completedAt:Bn.nullable().optional(),enrichment:xr.optional(),phaseMetrics:xt.optional()}).passthrough(),Ba=z.object({status:z.literal("stale"),currentCommit:z.string().nullable().optional(),requestedCommit:z.string().optional(),enrichment:xr.optional(),phaseMetrics:xt.optional()}).passthrough(),za=z.object({status:z.literal("failed"),currentCommit:z.string().nullable().optional(),requestedCommit:z.string().optional(),enrichment:xr.optional(),phaseMetrics:xt.optional()}).passthrough(),Er=z.discriminatedUnion("status",[Ua,Ga,Ba,za]),Wa=z.enum(["function","class","variable","import","module","interface","type","constant","export"]),Ha=z.enum(["calls","imports","extends","inherits","implements","uses","references","exports","contains"]),Ka=z.object({id:z.string(),label:z.string(),type:Wa,data:z.object({filePath:z.string(),lineNumber:z.number().int().nonnegative(),module:z.string(),visibility:z.string(),isExported:z.boolean()})}),Va=z.object({id:z.string(),source:z.string(),target:z.string(),type:Ha,label:z.string().optional()}),Ja=z.object({totalNodes:z.number().int().nonnegative(),totalEdges:z.number().int().nonnegative(),toolName:z.string(),query:z.string(),riskLevel:Ve.optional()}),qa=z.object({projectName:z.string(),branch:z.string(),asOfCommit:z.string(),lastIndexedAt:z.string().datetime()}),z.object({nodes:z.array(Ka),edges:z.array(Va),summary:Ja,metadata:qa,features:z.record(z.string(),z.boolean()).optional()}),zn=z.object({projectId:z.string(),projectName:z.string(),defaultBranch:z.string(),lastIndexedAt:z.string().datetime().optional(),fileCount:z.number().int().nonnegative().optional(),languages:z.array(z.string()).optional()}),z.object({projects:z.array(zn)}),zn.pick({projectId:true,projectName:true,defaultBranch:true}),Wn=z.enum(["unresolved","resolved","archived"]),Hn=z.enum(["succeeded","failed"]),Kn=z.enum(["full","incremental"]),Ya=z.enum(["info","warn","error"]),Xa=z.object({type:z.string(),message:z.string(),phase:z.string(),filePath:z.string().optional(),stack:z.string().optional()}),Qa=z.object({type:z.string(),message:z.string(),phase:z.string(),filePath:z.string().optional()}),Vn=z.object({errors:z.array(Xa),warnings:z.array(Qa)}),Jn=z.object({level:Ya,message:z.string(),timestamp:z.string().datetime()}),z.object({errorSummary:z.string().max(500),errorData:Vn,logEntries:z.array(Jn),cliVersion:z.string(),outcome:Hn,indexType:Kn}),z.object({status:Wn.exclude(["archived"])}),z.object({id:z.string(),organizationId:z.string(),userId:z.string(),projectId:z.string(),branchName:z.string(),commitHash:z.string().nullable(),indexType:Kn,status:Wn,outcome:Hn,errorSummary:z.string(),errorData:Vn,logEntries:z.array(Jn),cliVersion:z.string(),resolvedAt:z.string().nullable(),resolvedBy:z.string().nullable(),createdAt:z.string(),updatedAt:z.string(),organizationName:z.string().optional(),projectName:z.string().optional(),userEmail:z.string().optional(),resolvedByEmail:z.string().optional()}),z.object({unresolvedCount:z.number(),failedRunCount:z.number(),resolvedLast30d:z.number(),avgResolutionDays:z.number().nullable(),affectedOrgCount:z.number()});});function _r(i){return i.length>Et&&(i[Et]=qn),i}function Yn(){let i=false,e=0;return new Transform({transform(t,n,o){if(i){o(null,t);return}if(e+t.length>Et){let s=Et-e;t[s]=qn,i=true;}e+=t.length,o(null,t);}})}var Et,qn,Pr=f(()=>{Et=9,qn=255;});function Xn(i){return base32.encode(Buffer.from(i))}var Qn=f(()=>{});function Zn(i,e,t){let n=`${i}:${e}${t?`:${t}`:""}`;return Xn(n)}var ei=f(()=>{Qn();});var _t,ti=f(()=>{_t=class extends Readable{dataSource;sourceIterator;reading=false;constructor(e){super(),this.dataSource=e,this.sourceIterator=this.dataSource[Symbol.asyncIterator]();}async _read(){if(!this.reading){this.reading=true;try{for(;;){let{value:e,done:t}=await this.sourceIterator.next();if(t){this.push(null);break}let n=JSON.stringify(e)+`
35
- `,o=Buffer.from(n,"utf8");if(!this.push(o))break}}catch(e){this.destroy(e);}finally{this.reading=false;}}}_destroy(e,t){this.dataSource.return?this.dataSource.return(null).then(()=>t(e),n=>t(e||n)):t(e);}};});var Pt,It,R,pe,te,Te,ue,Tr=f(()=>{Xe();O();Pr();ei();ti();Pt=class{constructor(e,t,n=false,o){this.config=e;this.accessKey=t;this.dirty=n;this.reporter=o;}apiVersion="intel/v1";features={};isFeatureEnabled(e){return this.features[e]===true}parseFeatureHeader(e){if(Object.keys(this.features).length>0)return;let t=e.headers.get("X-Features");if(t)for(let n of t.split(",")){let[o,s]=n.split("=");o&&s!==void 0&&(this.features[o]=s==="true");}}async getProjectState(){let e={"Content-Type":"application/x-ndjson; charset=utf-8","x-project-id":this.config.projectId,"x-branch-name":this.config.branch,"x-constellation-dirty":this.dirty?"true":"false",Authorization:`Bearer ${this.accessKey}`},t=await this.sendRequest("project",void 0,"GET",e);return t&&!t.ok&&await this.handleProjectStateError(t),this.parseFeatureHeader(t),t.json()}async handleProjectStateError(e){try{let t=await e.json(),n=t?.code;switch(n){case "PROJECT_NOT_REGISTERED":throw new te(t?.message||"Project not registered",n,this.config.projectId);case "PROJECT_INACTIVE":throw new te(t?.message||"Project is inactive",n,this.config.projectId);case "INVALID_PROJECT_ID":throw new te(t?.message||"Invalid project ID format",n,this.config.projectId);case "PROJECT_NOT_FOUND":throw new pe("Project not found - no previous index exists");default:throw e.status===404?new pe("Project not found - no previous index exists"):new Error(`Unexpected API response (${e.status}): ${t?.message||e.statusText}`)}}catch(t){throw t instanceof te||t instanceof pe?t:e.status===404?new pe("Project not found - no previous index exists"):new Error(`Unexpected API response (${e.status})`)}}async getIndexStatus(e,t){let n=new URLSearchParams({branch:e});t&&n.set("commit",t);let o=`projects/${encodeURIComponent(this.config.projectId)}/index-status?${n.toString()}`;try{let s=await this.sendRequest(o,null,"GET");if(!s||!s.ok)return null;let a=await s.json(),l=Er.safeParse(a);return l.success?l.data:(this.reporter?.warn(`[constellation] getIndexStatus: unrecognized response shape \u2014 ${l.error.issues.map(c=>c.message).join("; ")}`),null)}catch(s){if(s instanceof R)throw s;return null}}async claimAstLock(e,t,n,o,s){let a=await this.sendRequest("ast/lock",null,"POST",{"x-project-id":e,"x-branch-name":t,"x-constellation-index":n?"incremental":"full","x-commit-hash":o,"x-commit-timestamp":s,"x-constellation-dirty":this.dirty?"true":"false"});if(!a)throw new Error("Failed to claim indexing lock: no response");if(a.status===409)throw await this.parseIndexingConflict(a);if(a.status===401)throw new R("Authentication failed");if(!a.ok){let u=await this.formatErrorBody(a);throw new Error(`Failed to claim indexing lock: ${a.status}${u?` \u2014 ${u}`:""}`)}let l=await a.json(),c=Un.safeParse(l);if(!c.success)throw new Error(`Invalid lock response from server: ${c.error.issues.map(u=>u.message).join("; ")}`);return c.data}async pollIndexStatus(e,t,n,o=300*1e3){let s=Date.now(),a=2e3,l=3e4;for(;Date.now()-s<o;){try{let c=await this.sendRequest(`projects/${encodeURIComponent(e)}/index-status?branch=${encodeURIComponent(t)}&commit=${encodeURIComponent(n)}`,null,"GET",{"x-constellation-dirty":this.dirty?"true":"false"});if(!c)continue;if(c.status===401)throw new R("Authentication failed during index status polling");if(c.status===403||c.status===404)return !1;if(c.ok){let u=await c.json(),p=Er.safeParse(u);if(p.success){if(p.data.status==="current")return !0;if(p.data.status==="stale"||p.data.status==="failed")return !1}}}catch(c){if(c instanceof R)throw c}await new Promise(c=>setTimeout(c,a)),a=Math.min(a*2,l);}return false}async uploadToQueue(e,t,n,o,s){return this.streamToApi(e,"ast/queue",t,n,true,o,s)}async startEnrichment(e,t,n){let o=new Agent({headersTimeout:1e4,bodyTimeout:1e4});try{let s=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/enrichment/start`,{method:"POST",headers:{Authorization:`Bearer ${this.accessKey}`,"Content-Type":"application/json; charset=utf-8","x-project-id":t,"x-branch-name":n,"x-attempt-id":e,"x-constellation-dirty":this.dirty?"true":"false"},dispatcher:o});if(s.ok)return !0;let a=`status ${s.status}`;try{let l=await s.json();l?.message?a=Array.isArray(l.message)?l.message.join("; "):String(l.message):l?.code&&(a=`status ${s.status} (${String(l.code)})`);}catch{}return this.reporter?.warn(`Enrichment start heartbeat rejected: ${a}`),!1}catch(s){return this.reporter?.warn(`Enrichment start heartbeat failed: ${s instanceof Error?s.message:String(s)}`),false}finally{o.destroy().catch(()=>{});}}async uploadEnrichment(e,t,n,o){let s=[5e3,1e4,2e4],a=Wr.gzipSync(Buffer.from(e,"utf8")),l=new Agent({headersTimeout:0,bodyTimeout:0});try{for(let c=0;c<=s.length;c++)try{let u=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/enrichment`,{method:"POST",headers:{Authorization:`Bearer ${this.accessKey}`,"Content-Type":"application/x-ndjson; charset=utf-8","Content-Encoding":"gzip","x-project-id":t,"x-branch-name":n,"x-commit-hash":o,"x-constellation-dirty":this.dirty?"true":"false"},body:a,dispatcher:l});if(u.status===401)throw new R("Authentication failed during enrichment upload");if(u.status===409){if((await u.json().catch(()=>({})))?.code==="COMMIT_MISMATCH")return this.reporter?.warn("Enrichment skipped: index state changed since AST upload"),!1;if(c<s.length){await new Promise(d=>setTimeout(d,s[c]));continue}return this.reporter?.warn("Enrichment skipped: indexing still in progress after retries"),!1}return u.ok||u.status===202?!0:(this.reporter?.warn(`Enrichment upload failed with status ${u.status}`),!1)}catch(u){if(u instanceof R)throw u;if(c<s.length){this.reporter?.warn(`Enrichment upload network error (attempt ${c+1}/${s.length+1}): ${u instanceof Error?u.message:String(u)}`),await new Promise(p=>setTimeout(p,s[c]));continue}return this.reporter?.warn(`Enrichment upload error: ${u instanceof Error?u.message:String(u)}`),!1}return !1}finally{l.destroy().catch(()=>{});}}async deleteFiles(e){for(let t of e){let n=Zn(this.config.projectId,this.config.branch,t);await this.delete(`/ast/${n}`);}}retryableStatusCodes=[500,502,503,504];async parseIndexingConflict(e){let t="Indexing already in progress",n;try{let o=await e.json();t=o?.message||t,n=o?.details?.branchName;}catch{}return new Te(t,n)}async formatErrorBody(e){try{let t=await e.json();if(typeof t?.message=="string"){let n=typeof t.code=="string"&&t.code.length>0?` [${t.code}]`:"";return `${t.message}${n}`}if(Array.isArray(t?.message))return t.message.join("; ");if(typeof t?.code=="string")return t.code}catch{}return ""}async streamToApi(e,t,n,o,s,a,l){try{let{Readable:c}=await import('stream'),u=new _t(e),p=process.env.CAPTURE_PAYLOAD_PATH,d=null,m=c.toWeb(u);if(p){let[h,b]=m.tee(),y=Bt.createWriteStream(p);d=pipeline(c.fromWeb(b),Wr.createGzip(),Yn(),y).catch(v=>{this.reporter?.warn(`[constellation] capture tap failed: ${v instanceof Error?v.message:String(v)}`);}),m=h;}let g=new Agent({headersTimeout:0,bodyTimeout:0});try{let h=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/${t}`,{method:"POST",headers:{"Content-Type":"application/x-ndjson; charset=utf-8","x-project-id":n,"x-branch-name":o,"x-constellation-index":s?"incremental":"full","x-constellation-dirty":this.dirty?"true":"false",Authorization:`Bearer ${this.accessKey}`,...a&&{"x-commit-hash":a},...l&&{"x-attempt-id":l}},body:m,duplex:"half",dispatcher:g});if(!h.ok&&typeof u.destroy=="function"&&u.destroy(),h.status===401)throw new R("Authentication failed");if(h.status===409)throw await this.parseIndexingConflict(h);if(h.status===200)try{let y=await h.json();if(y?.status==="current")return this.reporter?.summary(`${w} Index already up to date for ${o} at commit ${y.commitHash||"unknown"}`),!0}catch{}if(h.ok||h.status===202)return !0;let b=`Server returned ${h.status}`;try{let y=await h.json();y?.message&&(b=Array.isArray(y.message)?y.message.join("; "):y.message);}catch{}throw new Error(b)}finally{d&&await d;}}catch(c){if(c instanceof R||c instanceof Te)throw c;let u=c instanceof Error?c:new Error(String(c)),p="";if(u.message==="fetch failed"||c.code){let m=[],g=c.code||c.cause?.code;if(c.code&&m.push(`Error Code: ${c.code}`),c.cause){let h=c.cause;h.code&&m.push(`Cause Code: ${h.code}`),h.errno&&m.push(`Errno: ${h.errno}`),h.syscall&&m.push(`System Call: ${h.syscall}`),h.address&&m.push(`Address: ${h.address}`),h.port&&m.push(`Port: ${h.port}`);}g==="ERR_INVALID_ARG_VALUE"?p="Invalid argument value - check stream/body format and duplex option":g==="ECONNREFUSED"?p="Connection refused - service may be down or unreachable":g==="ENOTFOUND"?p="DNS lookup failed - check service URL":g==="ETIMEDOUT"?p="Connection timeout - service not responding":g==="ECONNRESET"?p="Connection reset by server":g==="EHOSTUNREACH"?p="Host unreachable - check network connectivity":p="Network failure",m.length>0&&(p+=` (${m.join(", ")})`);}else p=u.message;let d=new Error(`Failed to upload data to Constellation Service: ${p}`);throw d.cause=u,d.stack=`${d.stack}
36
- Caused by: ${u.stack}`,d}}async sendRequest(e,t,n,o={},s=0,a=3,l=1e3,c=250){for(let u=1;u<=a;u++){let p;try{let d=new AbortController;s>0&&(p=setTimeout(()=>d.abort(),s));let m={...o,"Content-Type":"application/json; charset=utf-8",Accepts:"application/json; charset=utf-8",Authorization:`Bearer ${this.accessKey}`},g=await fetch(`${this.config.apiUrl}/${this.apiVersion}/${e}`,{method:n,headers:m,body:t?JSON.stringify(t):void 0,signal:d.signal});if(p&&clearTimeout(p),g.status===401)throw new R("Authentication failed");if(!g.ok&&this.retryableStatusCodes.includes(g.status))throw new It(`${g.statusText} (${g.status})`);return g}catch(d){if(p&&clearTimeout(p),!(d instanceof R)){let m=d instanceof Error?`${d.message}${d.cause?` (Cause: ${d.cause})`:""}`:String(d);this.reporter?.warn(`HTTP request attempt ${u}/${a} failed: ${m}`);}if(u<a&&d instanceof It){let m=l+Math.floor(Math.random()*c);await new Promise(g=>setTimeout(g,m));}else throw d}}}async reportErrors(e){try{let t=await this.sendRequest("error-reports",e,"POST",{"x-project-id":this.config.projectId,"x-branch-name":this.config.branch,"x-constellation-dirty":this.dirty?"true":"false"},1e4,1,0,0);if(!t){this.reporter?.warn("Failed to upload error report: no response received");return}if(t.status===403){this.reporter?.warn("Error reporting is not available on your current plan");return}t.ok||this.reporter?.warn(`Failed to upload error report: ${t.statusText} (${t.status})`);}catch(t){this.reporter?.warn(`Failed to upload error report: ${t?.message||"Unknown error"}`);}}async delete(e){let t={"x-project-id":this.config.projectId,"x-branch-name":this.config.branch,"x-constellation-dirty":this.dirty?"true":"false"},n=await this.sendRequest(e,void 0,"DELETE",t);if(n&&!n.ok)throw new Error(`Failed sending HTTP DELETE to ${e}`)}},It=class extends Error{constructor(e){super(e),this.name="RetryableError";}},R=class extends Error{constructor(e){super(e),this.name="AuthenticationError";}},pe=class extends Error{constructor(e){super(e),this.name="NotFoundError";}},te=class extends Error{constructor(t,n,o){super(t);this.code=n;this.projectId=o;this.name="ProjectValidationError";}},Te=class extends Error{constructor(t,n){super(t);this.branchName=n;this.name="IndexingInProgressError";}},ue=class extends Error{constructor(t,n){super(t);this.errorCode=n;this.name="GitValidationError";}};});function ni(i){return i.replace(/\\/g,"/")}function Tt(i){return ni(i).replace(/^\.?\//,"")}function U(i,e){return ni(E.relative(i,e))}var ve=f(()=>{});var Re,jr=f(()=>{Re=class{constructor(e=10,t={}){this.concurrency=e;this.options=t;if(e<1)throw new Error("Concurrency must be at least 1")}async*run(e,t){if(e.length===0)return;let n=new Map,o=0,s=0,a=new Map,l=new Set,c=0;for(;s<e.length&&n.size<this.concurrency;){let u=o++,p=s,d=this.processItem(e[p],p,t).then(m=>({result:m!==null?m.result:null,index:p,promiseId:u}));n.set(u,d),s++;}for(;n.size>0;){let u=await Promise.race(n.values());if(n.delete(u.promiseId),this.options.preserveOrder)for(u.result!==null?a.set(u.index,u.result):l.add(u.index);c<e.length&&(a.has(c)||l.has(c));){if(a.has(c)){let p=a.get(c);a.delete(c),yield p;}else l.delete(c);c++;}else u.result!==null&&(yield u.result);if(s<e.length){let p=o++,d=s,m=this.processItem(e[d],d,t).then(g=>({result:g!==null?g.result:null,index:d,promiseId:p}));n.set(p,m),s++;}}}async processItem(e,t,n){try{return {result:await n(e,t),index:t}}catch{return null}}};});var ol,sl,Lr,al,ll,cl,Rt,oi=f(()=>{ve();jr();ol={function:{hover:true,references:true,callHierarchy:true},method:{hover:true,references:true,callHierarchy:true},class:{hover:false,references:true,callHierarchy:false},interface:{hover:false,references:true,callHierarchy:false},variable:{hover:true,references:true,callHierarchy:false},property:{hover:true,references:true,callHierarchy:false},import:{hover:true,references:false,callHierarchy:false}},sl={hover:true,references:true,callHierarchy:false},Lr=1e4,al=1200*1e3,ll=50,cl={typescript:"TypeScript",javascript:"JavaScript",python:"Python"},Rt=class{constructor(e,t){this.projectRoot=e;this.reporter=t;}async enrich(e,t,n,o){let s=[],a=Date.now(),l={filesUnreadable:0,filesOpenFailed:0,filesNoSymbols:0,symbolQueryErrors:0,discoveryErrors:0,queryRejections:0,symbolsWithNoEnrichment:{},firstFileError:null,firstOpenError:null,firstSymbolError:null,firstDiscoveryError:null},c=false;return await Promise.all([...e.entries()].map(async([u,p])=>{let d=n.get(u);if(!d)return;let m=p.length,g=m>1e4?4:m>5e3?6:8,h=new Re(g),b=0,y=h.run(p,async v=>{try{if(c||Date.now()-a>al)return c=!0,null;let x=await this.openFile(d,v,l,o?.get(v));if(!x)return null;let{uri:j}=x;try{let C=t.get(v)??[];if(C.length===0&&(C=await this.discoverSymbols(d,v,j,l),C.length===0))return l.filesNoSymbols++,null;let A=await this.enrichOpenFile(d,v,j,C,l);return A.length>0?{filePath:v,language:u,symbols:A}:null}finally{this.closeFile(d,j);}}finally{if(b++,b%ll===0){let x=Math.round(b/m*100);this.reporter?.info(`${cl[u]??u} index enrichment: ${x}% (${b}/${m} files)`);}}});for await(let v of y)v&&s.push(v);})),c&&this.reporter?.info("Enrichment timeout reached. Uploading partial results."),this.logDiagnostics(l),s}async openFile(e,t,n,o){let s=E.resolve(this.projectRoot,t),a=pathToFileURL(s).href,l=o;if(l===void 0)try{l=Bt.readFileSync(s,"utf-8");}catch(c){return n.filesUnreadable++,n.firstFileError||(n.firstFileError=`${t}: ${c instanceof Error?c.message:String(c)}`),null}try{e.sendNotification("textDocument/didOpen",{textDocument:{uri:a,languageId:this.getLanguageId(t),version:1,text:l}});}catch(c){return n.filesOpenFailed++,n.firstOpenError||(n.firstOpenError=`${t}: ${c instanceof Error?c.message:String(c)}`),null}return {uri:a,content:l}}closeFile(e,t){try{e.sendNotification("textDocument/didClose",{textDocument:{uri:t}});}catch{}}async enrichOpenFile(e,t,n,o,s){let a=await Promise.allSettled(o.map(c=>this.querySymbol(e,n,c,s))),l=[];for(let c=0;c<a.length;c++){let u=a[c];if(u.status==="fulfilled")u.value&&l.push(u.value);else if(s.symbolQueryErrors++,!s.firstSymbolError){let p=o[c];s.firstSymbolError=`${p.name} in ${t}: ${u.reason instanceof Error?u.reason.message:String(u.reason)}`;}}return l}logDiagnostics(e){let t=[];e.filesUnreadable>0&&t.push(`${e.filesUnreadable} files unreadable`),e.filesOpenFailed>0&&t.push(`${e.filesOpenFailed} files failed to open in language server`),e.filesNoSymbols>0&&t.push(`${e.filesNoSymbols} files had no discoverable symbols`),e.discoveryErrors>0&&t.push(`${e.discoveryErrors} symbol discovery failures`),e.symbolQueryErrors>0&&t.push(`${e.symbolQueryErrors} symbol query failures`),e.queryRejections>0&&t.push(`${e.queryRejections} individual LSP query rejections`);let n=Object.entries(e.symbolsWithNoEnrichment).filter(([,o])=>o>0).sort(([,o],[,s])=>s-o);if(n.length>0){let o=n.reduce((a,[,l])=>a+l,0),s=n.map(([a,l])=>`${l} ${a}`).join(", ");t.push(`${o} symbols yielded no enrichment (${s})`);}t.length!==0&&(this.reporter?.warn(`Enrichment issues: ${t.join(", ")}`),e.firstFileError&&this.reporter?.warn(`First file read error: ${e.firstFileError}`),e.firstOpenError&&this.reporter?.warn(`First didOpen error: ${e.firstOpenError}`),e.firstDiscoveryError&&this.reporter?.warn(`First discovery error: ${e.firstDiscoveryError}`),e.firstSymbolError&&this.reporter?.warn(`First symbol query error: ${e.firstSymbolError}`));}async querySymbol(e,t,n,o){let s=ol[n.kind.toLowerCase()]||sl,a={line:n.line-1,character:n.column},l={textDocument:{uri:t},position:a},c={name:n.name,line:n.line,column:n.column,kind:n.kind},u=false,[p,d]=await Promise.allSettled([s.hover?e.sendRequest("textDocument/hover",l,Lr):null,s.references?e.sendRequest("textDocument/references",{...l,context:{includeDeclaration:false}},Lr):null]);for(let m of [p,d])m.status==="rejected"&&o.queryRejections++;if(p.status==="fulfilled"&&p.value?.contents){let m=p.value,g=typeof m.contents=="string"?m.contents:m.contents.value||"";g&&(c.typeInfo={resolvedType:g},u=true);}if(d.status==="fulfilled"&&d.value){let m=d.value;if(m.length>0){let g=m.slice(0,100).map(h=>({filePath:U(this.projectRoot,this.uriToPath(h.uri||"")),line:(h.range?.start?.line??0)+1,column:h.range?.start?.character??0}));c.references={count:m.length,locations:g},u=true;}}if(s.callHierarchy)try{let m=await e.sendRequest("textDocument/prepareCallHierarchy",l,Lr);if(m&&m.length>0){let g=m[0],[h,b]=await Promise.all([e.sendRequest("callHierarchy/incomingCalls",{item:g}).catch(()=>[]),e.sendRequest("callHierarchy/outgoingCalls",{item:g}).catch(()=>[])]),y=(h||[]).slice(0,200).map(x=>({name:x.from?.name||"",filePath:U(this.projectRoot,this.uriToPath(x.from?.uri||"")),line:(x.from?.range?.start?.line??0)+1,column:x.from?.selectionRange?.start?.character??x.from?.range?.start?.character??0})),v=(b||[]).slice(0,200).map(x=>({name:x.to?.name||"",filePath:U(this.projectRoot,this.uriToPath(x.to?.uri||"")),line:(x.to?.range?.start?.line??0)+1,column:x.to?.selectionRange?.start?.character??x.to?.range?.start?.character??0}));(y.length>0||v.length>0)&&(c.callHierarchy={incomingCalls:y,outgoingCalls:v},u=!0);}}catch{o.queryRejections++;}if(!u){let m=n.kind.toLowerCase();o.symbolsWithNoEnrichment[m]=(o.symbolsWithNoEnrichment[m]??0)+1;}return u?c:null}async discoverSymbols(e,t,n,o){try{let s=await e.sendRequest("textDocument/documentSymbol",{textDocument:{uri:n}});return !s||!Array.isArray(s)?[]:this.flattenDocumentSymbols(s)}catch(s){return o.discoveryErrors++,o.firstDiscoveryError||(o.firstDiscoveryError=`${t}: ${s instanceof Error?s.message:String(s)}`),[]}}flattenDocumentSymbols(e){let t=[],n={1:"file",2:"module",3:"namespace",4:"package",5:"class",6:"method",7:"property",8:"field",9:"constructor",10:"enum",11:"interface",12:"function",13:"variable",14:"constant",15:"string",16:"number",17:"boolean",18:"array",19:"object",20:"key",21:"null",22:"enumMember",23:"struct",24:"event",25:"operator",26:"typeParameter"};for(let o of e){let s=n[o.kind]||"variable",a=o.selectionRange||o.range||o.location?.range;a&&t.push({name:o.name,line:(a.start?.line??0)+1,column:a.start?.character??0,kind:s}),o.children&&Array.isArray(o.children)&&t.push(...this.flattenDocumentSymbols(o.children));}return t}uriToPath(e){try{return fileURLToPath(new URL(e))}catch{return e.replace(/^file:\/\//,"")}}getLanguageId(e){let t=E.extname(e).toLowerCase();return {".ts":"typescript",".tsx":"typescriptreact",".js":"javascript",".jsx":"javascriptreact",".py":"python",".pyi":"python"}[t]||"plaintext"}};});function si(i){return i.map(e=>JSON.stringify(e)).join(`
34
+ New terminal sessions will load it automatically.`),Pe.platform()==="darwin"&&this.reporter.info("Already-running desktop apps (Claude Desktop, Codex, etc.) must be quit and relaunched to see the new value.");}};});var ea,oe,Xe,ta,Ae,Qe,ra,na,ia,Ze,oa,sa,aa,la,ca,pa,ua,da,ma,ga,fa,ha,ya,ba,va,Sa,wa,Kn,Ca,xa,Ea,_a,Pa,Ia,Na,Ra,Ta,La,ja,Aa,ka,Fa,$a,Da,Jn,Oa,Ma,Ir,Ua,Ga,Ba,Ha,et,Wa,za,Ka,Va,Ja,qn,qa,Ya,Pt,Yn,Vn,Xa,Qa,Za,Nr,Xn,el,tl,rl,nl,Rr,il,ol,sl,al,ll,cl,Qn,Zn,ei,ti,pl,ul,dl,ri,ni,tt=f(()=>{ea=z.object({total:z.number().int().nonnegative(),returned:z.number().int().nonnegative(),hasMore:z.boolean(),nextOffset:z.number().int().nonnegative().optional(),currentOffset:z.number().int().nonnegative().optional()}),z.object({overall:z.number().min(0).max(1),factors:z.object({dataFreshness:z.number().min(0).max(1).optional(),coverageComplete:z.number().min(0).max(1).optional(),heuristicAccuracy:z.number().min(0).max(1).optional(),semanticAnalysisDepth:z.number().min(0).max(1).optional(),patternMatchQuality:z.number().min(0).max(1).optional()}).optional(),warnings:z.array(z.string()).optional(),recommendations:z.array(z.string()).optional()}),z.object({qualityScore:z.number().min(0).max(100).optional(),lastUpdated:z.string().optional(),cached:z.boolean().optional(),executionTime:z.number().nonnegative().optional(),coveragePercentage:z.number().min(0).max(100).optional(),issues:z.array(z.string()).optional()}),oe=z.object({language:z.string(),features:z.array(z.string()).optional(),visibility:z.string().optional(),decorators:z.array(z.string()).optional(),typeInfo:z.any().optional(),custom:z.record(z.string(),z.any()).optional()}),z.enum(["function","class","interface","type","variable","constant","enum","module","namespace","method","property","parameter","constructor","decorator","trait","struct","macro","unknown"]),Xe=z.enum(["low","medium","high","critical"]),ta=z.enum(["low","moderate","high","very_high"]),Ae=z.object({cyclomaticComplexity:z.number().int().nonnegative(),complexityRisk:ta}),Qe=z.object({filePath:z.string(),line:z.number().int().positive().optional(),lineStart:z.number().int().positive().optional(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative().optional()}),Qe.extend({symbolId:z.string().optional(),symbolName:z.string().optional(),symbolKind:z.string().optional()}),z.object({outgoing:z.array(z.string()),incoming:z.array(z.string())}),ra=z.object({id:z.string(),name:z.string(),type:z.string(),properties:z.record(z.string(),z.any()).optional()}),na=z.object({from:z.string(),to:z.string(),type:z.string().optional(),weight:z.number().optional(),properties:z.record(z.string(),z.any()).optional()}),ia=z.object({nodes:z.array(ra),edges:z.array(na),metadata:z.object({nodeCount:z.number().int().nonnegative(),edgeCount:z.number().int().nonnegative(),directed:z.boolean(),hasCycles:z.boolean().optional()}).optional()}),Ze=new Set(["abc","aifc","argparse","array","ast","asynchat","asyncio","asyncore","atexit","audioop","base64","bdb","binascii","bisect","builtins","bz2","cProfile","calendar","cgi","cgitb","chunk","cmath","cmd","code","codecs","codeop","collections","colorsys","compileall","concurrent","configparser","contextlib","contextvars","copy","copyreg","crypt","csv","ctypes","curses","dataclasses","datetime","dbm","decimal","difflib","dis","distutils","doctest","email","encodings","ensurepip","enum","errno","faulthandler","fcntl","filecmp","fileinput","fnmatch","fractions","ftplib","functools","gc","getopt","getpass","gettext","glob","graphlib","grp","gzip","hashlib","heapq","hmac","html","http","idlelib","imaplib","imghdr","imp","importlib","inspect","io","ipaddress","itertools","json","keyword","lib2to3","linecache","locale","logging","lzma","mailbox","mailcap","marshal","math","mimetypes","mmap","modulefinder","msilib","msvcrt","multiprocessing","netrc","nis","nntplib","numbers","operator","optparse","os","ossaudiodev","pathlib","pdb","pickle","pickletools","pipes","pkgutil","platform","plistlib","poplib","posix","posixpath","pprint","profile","pstats","pty","pwd","py_compile","pyclbr","pydoc","queue","quopri","random","re","readline","reprlib","resource","rlcompleter","runpy","sched","secrets","select","selectors","shelve","shlex","shutil","signal","site","sitecustomize","smtpd","smtplib","sndhdr","socket","socketserver","spwd","sqlite3","ssl","stat","statistics","string","stringprep","struct","subprocess","sunau","symtable","sys","sysconfig","syslog","tabnanny","tarfile","telnetlib","tempfile","termios","test","textwrap","threading","time","timeit","tkinter","token","tokenize","tomllib","trace","traceback","tracemalloc","tty","turtle","turtledemo","types","typing","unicodedata","unittest","urllib","usercustomize","uu","uuid","venv","warnings","wave","weakref","webbrowser","winreg","winsound","wsgiref","xdrlib","xml","xmlrpc","zipapp","zipfile","zipimport","zlib","zoneinfo","_thread","_tkinter","__future__","__main__"]),z.object({success:z.literal(false),error:z.object({code:z.string(),message:z.string(),details:z.any().optional()})}),z.object({query:z.string().max(200),filterByKind:z.array(z.string()).optional(),filterByVisibility:z.array(z.string()).optional(),isExported:z.boolean().optional(),filterByFile:z.string().optional(),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0),includeUsageCount:z.boolean().optional(),includeDocumentation:z.boolean().optional()}).refine(i=>i.query.length>0||i.filterByKind&&i.filterByKind.length>0||i.filterByVisibility&&i.filterByVisibility.length>0||i.isExported!==void 0||i.filterByFile!==void 0,{message:"Either query must be non-empty or at least one filter (filterByKind, filterByVisibility, isExported, filterByFile) must be provided",path:["query"]}),oa=Qe.extend({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),signature:z.string().optional(),documentation:z.string().optional(),visibility:z.string().optional(),isExported:z.boolean(),usageCount:z.number().int().nonnegative().optional(),complexity:Ae.optional(),languageMetadata:oe.optional()}),z.object({symbols:z.array(oa),pagination:ea.optional()}),z.object({symbolId:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),includeReferences:z.boolean().optional(),includeRelationships:z.boolean().optional(),includeImpactScore:z.boolean().optional()}),sa=Qe.extend({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),signature:z.string().optional(),documentation:z.string().optional(),visibility:z.string().optional(),modifiers:z.array(z.string()).optional(),typeInfo:z.any().optional(),decorators:z.array(z.string()).optional(),isExported:z.boolean(),isDeprecated:z.boolean(),complexity:Ae.optional(),languageMetadata:oe.optional()}),aa=Qe.extend({usageType:z.string(),context:z.string().optional(),aliasName:z.string().optional()}),la=z.object({calls:z.array(z.string()),calledBy:z.array(z.string()),inheritsFrom:z.array(z.string()),inheritedBy:z.array(z.string()),children:z.array(z.string())}),ca=z.object({directUsage:z.number().int().nonnegative(),transitiveImpact:z.number().int().nonnegative(),riskScore:z.number().min(0).max(100),riskLevel:Xe}),z.object({symbol:sa,references:z.array(aa).optional(),relationships:la.optional(),impactScore:ca.optional()}),z.object({filePath:z.string().min(1),depth:z.number().int().nonnegative().max(10).optional(),includePackages:z.boolean().optional(),includeSymbols:z.boolean().optional(),limit:z.number().int().positive().max(100).default(20),offset:z.number().int().nonnegative().default(0)}),pa=z.object({type:z.enum(["file","module"]),filePath:z.string().nullable(),moduleName:z.string().nullable().optional(),importedSymbols:z.array(z.string()).optional(),isDefault:z.boolean(),isNamespace:z.boolean()}),ua=z.object({filePath:z.string(),distance:z.number().int().positive(),path:z.array(z.string())}),da=z.object({name:z.string(),version:z.string().optional(),type:z.string()}),z.object({totalFiles:z.number().int().nonnegative(),totalPackages:z.number().int().nonnegative(),maxDepth:z.number().int().nonnegative()}),z.object({file:z.string(),directDependencies:z.array(pa),transitiveDependencies:z.array(ua).optional(),packages:z.array(da).optional()}),z.object({filePath:z.string().min(1),depth:z.number().int().nonnegative().max(10).optional(),includeSymbols:z.boolean().optional(),includeImpactMetrics:z.boolean().optional(),limit:z.number().int().positive().max(100).default(20),offset:z.number().int().nonnegative().default(0)}),ma=z.object({filePath:z.string(),usedSymbols:z.array(z.string()).optional()}),ga=z.object({filePath:z.string(),distance:z.number().int().positive(),path:z.array(z.string())}),z.object({totalFiles:z.number().int().nonnegative(),maxDepth:z.number().int().nonnegative(),riskLevel:Xe}),z.object({file:z.string(),directDependents:z.array(ma),transitiveDependents:z.array(ga).optional(),detailedMetrics:z.object({byDepth:z.record(z.string(),z.number()),criticalPaths:z.array(z.array(z.string())),mostImpactedFiles:z.array(z.string())}).optional()}),z.object({filePath:z.string().min(1).optional(),minCycleLength:z.number().int().min(2).max(10).optional(),maxCycleLength:z.number().int().min(2).max(10).optional(),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0),includeImpactScore:z.boolean().optional(),includeConfidence:z.boolean().optional()}),fa=z.object({files:z.array(z.string()),length:z.number().int().positive(),impactScore:z.number().min(0).max(100).optional(),severity:Xe}),z.object({cycles:z.array(fa)}),z.object({symbolId:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),filterByUsageType:z.array(z.string()).optional(),filterByRelationshipType:z.array(z.string()).optional(),includeTransitive:z.boolean().optional(),includeContext:z.boolean().optional(),excludeTests:z.boolean().optional(),excludeGenerated:z.boolean().optional(),includeImportanceWeight:z.boolean().optional(),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0)}),ha=z.object({name:z.string(),kind:z.string(),visibility:z.string().optional(),filePath:z.string(),lineEnd:z.number().int().positive().optional(),complexity:Ae.optional(),languageMetadata:oe.optional()}),ya=z.object({filePath:z.string(),usageType:z.string(),relationshipType:z.string(),line:z.number().int().positive().optional(),column:z.number().int().nonnegative().optional(),enclosingSymbol:z.object({name:z.string(),kind:z.string()}).optional(),context:z.string().optional(),aliasName:z.string().optional(),isTest:z.boolean().optional(),isGenerated:z.boolean().optional(),importanceWeight:z.number().min(0).max(1).optional()}),ba=z.object({filePath:z.string(),distance:z.number().int().positive(),chain:z.array(z.string())}),z.object({symbol:ha,directUsages:z.array(ya),transitiveUsages:z.array(ba).optional()}),z.object({symbolId:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),direction:z.enum(["callers","callees","both"]).default("both"),depth:z.number().int().positive().max(10).default(3),excludeExternal:z.boolean().optional(),includeGraph:z.boolean().optional(),limit:z.number().int().positive().max(100).default(25),offset:z.number().int().nonnegative().default(0)}),va=z.object({symbolId:z.string(),name:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),complexity:Ae.optional(),languageMetadata:oe.optional()}),Sa=z.object({symbolId:z.string(),name:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),depth:z.number().int().nonnegative(),complexity:Ae.optional(),languageMetadata:oe.optional()}),wa=z.object({symbolId:z.string(),name:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),isAsync:z.boolean(),depth:z.number().int().nonnegative(),complexity:Ae.optional(),languageMetadata:oe.optional()}),z.object({root:va,callers:z.array(Sa).optional(),callees:z.array(wa).optional(),graph:ia.optional()}),z.object({symbolId:z.string().optional(),qualifiedName:z.string().optional(),symbolName:z.string().optional(),filePath:z.string().optional(),includeDirectDependents:z.boolean().default(true),includeTransitiveDependents:z.boolean().default(true),depth:z.number().int().min(1).max(5).default(3),excludeTests:z.boolean().default(true),excludeGenerated:z.boolean().default(true),analyzeBreakingChanges:z.boolean().default(true)}),Kn=Qe.extend({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),visibility:z.string().optional(),relationshipType:z.string(),depth:z.number().int().positive(),isExported:z.boolean().optional(),transitiveImpactCount:z.number().int().nonnegative().optional(),languageMetadata:oe.optional()}),Ca=z.object({filePath:z.string(),symbolCount:z.number().int().positive(),isTest:z.boolean().optional(),isGenerated:z.boolean().optional(),symbols:z.array(z.object({id:z.string(),name:z.string(),kind:z.string(),line:z.number().int().positive()}))}),xa=z.object({riskLevel:Xe,factors:z.array(z.object({factor:z.string(),severity:z.enum(["low","medium","high"]),description:z.string()})),recommendations:z.array(z.string())}),z.object({symbol:z.object({id:z.string(),name:z.string(),qualifiedName:z.string(),kind:z.string(),visibility:z.string().optional(),filePath:z.string(),line:z.number().int().positive(),lineEnd:z.number().int().positive().optional(),column:z.number().int().nonnegative(),isExported:z.boolean().optional(),languageMetadata:oe.optional()}),directDependents:z.array(Kn).optional(),transitiveDependents:z.array(Kn).optional(),impactedFiles:z.array(Ca),breakingChangeRisk:xa.optional(),summary:z.object({directDependentCount:z.number().int().nonnegative(),transitiveDependentCount:z.number().int().nonnegative(),impactedFileCount:z.number().int().nonnegative(),testFileCount:z.number().int().nonnegative(),productionFileCount:z.number().int().nonnegative(),maxDepth:z.number().int().nonnegative()})}),z.object({filePattern:z.string().optional(),filterByKind:z.array(z.string()).optional(),exportedOnly:z.boolean().optional(),excludeTests:z.boolean().default(true),limit:z.number().int().positive().max(100).default(50),offset:z.number().int().nonnegative().default(0),includeConfidence:z.boolean().optional()}),Ea=z.object({symbolId:z.string(),name:z.string(),kind:z.string(),visibility:z.string().optional(),filePath:z.string(),lineEnd:z.number().int().positive().optional(),isExported:z.boolean(),reason:z.string(),confidence:z.number().min(0).max(1),languageMetadata:oe.optional()}),_a=z.object({filePath:z.string(),reason:z.string(),lastUpdated:z.string(),confidence:z.number().min(0).max(1)}),z.object({orphanedSymbols:z.array(Ea),orphanedFiles:z.array(_a)}),z.object({includeMetrics:z.boolean().default(false),includeModuleGraph:z.boolean().default(false),includePackages:z.boolean().default(true)}),Pa=z.object({language:z.string(),fileCount:z.number().int().nonnegative(),percentage:z.number().min(0).max(100)}),Ia=z.object({name:z.string(),version:z.string().optional(),confidence:z.enum(["high","medium","low"]),evidence:z.array(z.string())}),Na=z.object({languages:z.array(Pa),frameworks:z.array(Ia),primaryLanguage:z.string(),totalFiles:z.number().int().nonnegative(),totalLines:z.number().int().nonnegative().optional()}),Ra=z.object({files:z.object({total:z.number().int().nonnegative(),byType:z.record(z.string(),z.number()),byParadigm:z.record(z.string(),z.number())}),symbols:z.object({total:z.number().int().nonnegative(),byKind:z.record(z.string(),z.number()),exported:z.number().int().nonnegative(),public:z.number().int().nonnegative()}),modules:z.object({total:z.number().int().nonnegative(),averageSize:z.number().nonnegative(),largest:z.string()})}),Ta=z.object({internal:z.object({totalConnections:z.number().int().nonnegative(),averagePerFile:z.number().nonnegative(),mostConnectedFiles:z.array(z.object({path:z.string(),incomingCount:z.number().int().nonnegative(),outgoingCount:z.number().int().nonnegative()}))}),external:z.object({totalPackages:z.number().int().nonnegative(),directDependencies:z.number().int().nonnegative(),topPackages:z.array(z.object({name:z.string(),usageCount:z.number().int().nonnegative()}))})}),La=z.object({complexity:z.object({average:z.number().nonnegative(),high:z.number().int().nonnegative()}),maintainability:z.object({score:z.number().min(0).max(100),issues:z.array(z.string())}),testCoverage:z.object({percentage:z.number().min(0).max(100),testedFiles:z.number().int().nonnegative(),totalFiles:z.number().int().nonnegative()}).optional()}),ja=z.object({id:z.string(),name:z.string(),fileCount:z.number().int().nonnegative(),type:z.string()}),Aa=z.object({from:z.string(),to:z.string(),weight:z.number().int().nonnegative()}),ka=z.object({nodes:z.array(ja),edges:z.array(Aa)}),z.object({metadata:Na,structure:Ra,dependencies:Ta,metrics:La.optional(),moduleGraph:ka.optional()}),z.object({}).strict(),z.object({pong:z.literal(true)}),Fa=z.enum(["relative","workspace","alias","external","builtin"]),$a=z.object({source:z.string(),resolvedPath:z.string().optional(),isExternal:z.boolean(),importType:Fa}),Da=z.record(z.string(),$a),Jn=z.enum(["call","read","write","type","instantiate","import-use","declaration"]),Oa=Jn.exclude(["import-use","declaration"]),Ma=z.object({line:z.number().int().nonnegative(),column:z.number().int().nonnegative(),referenceType:Jn}).strict(),Ir=z.object({filePath:z.string().min(1),entries:z.array(Ma).max(1e5)}).strict(),z.object({file:z.string().min(1),language:z.string().min(1),commit:z.string().min(1),timestamp:z.string().datetime(),ast:z.string().min(1),importResolutions:Da.optional(),classificationMap:Ir.optional()}).strict(),Ua=z.object({file:z.string(),error:z.string()}),Ga=z.object({file:z.string(),failedCount:z.number().int().nonnegative(),createdCount:z.number().int().nonnegative(),isTransient:z.boolean()}),Ba=z.object({totalCreated:z.number().int().nonnegative(),totalFailed:z.number().int().nonnegative(),filesWithFailures:z.array(Ga)}),z.object({processed:z.number().int().nonnegative(),failed:z.number().int().nonnegative(),projectId:z.string(),branchName:z.string(),failedFiles:z.array(Ua).optional(),relationships:Ba}),z.object({projectId:z.string(),projectName:z.string(),branch:z.string(),latestCommit:z.string().nullable(),fileCount:z.number().int().nonnegative(),lastIndexedAt:z.string().nullable(),languages:z.array(z.string())}),Ha=z.object({local:z.string(),original:z.string().optional(),isDefault:z.boolean(),isNamespace:z.boolean()}),z.object({source:z.string(),specifiers:z.array(Ha),isType:z.boolean(),isDynamic:z.boolean(),isConditional:z.boolean().optional(),isLazy:z.boolean().optional(),isWildcard:z.boolean().optional(),line:z.number(),column:z.number()}),z.object({referencerId:z.string(),referencedName:z.string(),referenceType:Oa,line:z.number(),column:z.number(),scope:z.string().optional(),objectContext:z.string().optional(),language:z.string().optional()}),z.enum(["processing","completed","failed","cancelled","queued","superseded","cleaned_up"]),z.enum(["acquired","current","duplicate","superseded","queued"]),et={branchName:z.string().optional(),effectiveBranchName:z.string().optional(),remapped:z.boolean().optional()},Wa=z.object({status:z.literal("acquired"),attemptId:z.string().uuid(),...et}),za=z.object({status:z.literal("current"),...et}),Ka=z.object({status:z.literal("duplicate"),...et}),Va=z.object({status:z.literal("superseded"),activeCommit:z.string().optional(),...et}),Ja=z.object({status:z.literal("queued"),queuedAttemptId:z.string().uuid(),...et}),qn=z.discriminatedUnion("status",[Wa,za,Ka,Va,Ja]),z.object({"x-attempt-id":z.string().uuid(),"x-project-id":z.string(),"x-branch-name":z.string(),"x-commit-hash":z.string().length(40),"x-constellation-dirty":z.union([z.literal("true"),z.literal("false")]).optional()}),qa=z.enum(["pass1","pass2","pass2b","pass3"]),Ya=z.object({phase:qa,durationMs:z.number().int().nonnegative(),fileCount:z.number().int().nonnegative(),symbolCount:z.number().int().nonnegative().optional(),relationshipCount:z.number().int().nonnegative().optional(),throughputPerSec:z.number().nonnegative(),deadlockRetryCount:z.number().int().nonnegative().optional()}),Pt=z.array(Ya),Yn=z.object({filePath:z.string().min(1),line:z.number().int().positive(),column:z.number().int().nonnegative()}).strict(),Vn=Yn.extend({name:z.string().min(1)}).strict(),Xa=z.object({resolvedType:z.string().min(1),returnType:z.string().optional(),documentation:z.string().max(16384).optional()}).strict(),Qa=z.object({name:z.string().min(1),line:z.number().int().positive(),column:z.number().int().nonnegative(),kind:z.string().min(1),typeInfo:Xa.optional(),references:z.object({count:z.number().int().nonnegative(),locations:z.array(Yn).max(100)}).optional(),callHierarchy:z.object({incomingCalls:z.array(Vn).max(200),outgoingCalls:z.array(Vn).max(200)}).optional()}).strict(),z.object({filePath:z.string().min(1),language:z.string().min(1),symbols:z.array(Qa).max(1e4)}).strict(),z.object({projectId:z.string().min(1),branch:z.string().min(1),commit:z.string().regex(/^[0-9a-f]{40}$/),timestamp:z.string().datetime()}).strict(),Za=z.enum(["pending","processing","completed","failed","skipped"]),Nr=z.object({status:Za,filesProcessed:z.number().int().nonnegative().nullable(),completedAt:z.union([z.string().datetime({offset:true}),z.date()]).nullable()}),z.enum(["current","processing","stale","failed"]),Xn=z.union([z.string().datetime({offset:true}),z.date()]),el=z.object({status:z.literal("processing"),commitHash:z.string().nullable().optional(),startedAt:Xn.optional(),phaseMetrics:Pt.optional()}).passthrough(),tl=z.object({status:z.literal("current"),commitHash:z.string().nullable().optional(),completedAt:Xn.nullable().optional(),enrichment:Nr.optional(),phaseMetrics:Pt.optional()}).passthrough(),rl=z.object({status:z.literal("stale"),currentCommit:z.string().nullable().optional(),requestedCommit:z.string().optional(),enrichment:Nr.optional(),phaseMetrics:Pt.optional()}).passthrough(),nl=z.object({status:z.literal("failed"),currentCommit:z.string().nullable().optional(),requestedCommit:z.string().optional(),enrichment:Nr.optional(),phaseMetrics:Pt.optional()}).passthrough(),Rr=z.discriminatedUnion("status",[el,tl,rl,nl]),il=z.enum(["function","class","variable","import","module","interface","type","constant","export"]),ol=z.enum(["calls","imports","extends","inherits","implements","uses","references","exports","contains"]),sl=z.object({id:z.string(),label:z.string(),type:il,data:z.object({filePath:z.string(),lineNumber:z.number().int().nonnegative(),module:z.string(),visibility:z.string(),isExported:z.boolean()})}),al=z.object({id:z.string(),source:z.string(),target:z.string(),type:ol,label:z.string().optional()}),ll=z.object({totalNodes:z.number().int().nonnegative(),totalEdges:z.number().int().nonnegative(),toolName:z.string(),query:z.string(),riskLevel:Xe.optional()}),cl=z.object({projectName:z.string(),branch:z.string(),asOfCommit:z.string(),lastIndexedAt:z.string().datetime()}),z.object({nodes:z.array(sl),edges:z.array(al),summary:ll,metadata:cl,features:z.record(z.string(),z.boolean()).optional()}),Qn=z.object({projectId:z.string(),projectName:z.string(),defaultBranch:z.string(),lastIndexedAt:z.string().datetime().optional(),fileCount:z.number().int().nonnegative().optional(),languages:z.array(z.string()).optional()}),z.object({projects:z.array(Qn)}),Qn.pick({projectId:true,projectName:true,defaultBranch:true}),Zn=z.enum(["unresolved","resolved","archived"]),ei=z.enum(["succeeded","failed"]),ti=z.enum(["full","incremental"]),pl=z.enum(["info","warn","error"]),ul=z.object({type:z.string(),message:z.string(),phase:z.string(),filePath:z.string().optional(),stack:z.string().optional()}),dl=z.object({type:z.string(),message:z.string(),phase:z.string(),filePath:z.string().optional()}),ri=z.object({errors:z.array(ul),warnings:z.array(dl)}),ni=z.object({level:pl,message:z.string(),timestamp:z.string().datetime()}),z.object({errorSummary:z.string().max(500),errorData:ri,logEntries:z.array(ni),cliVersion:z.string(),outcome:ei,indexType:ti}),z.object({status:Zn.exclude(["archived"])}),z.object({id:z.string(),organizationId:z.string(),userId:z.string(),projectId:z.string(),branchName:z.string(),commitHash:z.string().nullable(),indexType:ti,status:Zn,outcome:ei,errorSummary:z.string(),errorData:ri,logEntries:z.array(ni),cliVersion:z.string(),resolvedAt:z.string().nullable(),resolvedBy:z.string().nullable(),createdAt:z.string(),updatedAt:z.string(),organizationName:z.string().optional(),projectName:z.string().optional(),userEmail:z.string().optional(),resolvedByEmail:z.string().optional()}),z.object({unresolvedCount:z.number(),failedRunCount:z.number(),resolvedLast30d:z.number(),avgResolutionDays:z.number().nullable(),affectedOrgCount:z.number()});});function Tr(i){return i.length>It&&(i[It]=ii),i}function oi(){let i=false,e=0;return new Transform({transform(t,r,o){if(i){o(null,t);return}if(e+t.length>It){let s=It-e;t[s]=ii,i=true;}e+=t.length,o(null,t);}})}var It,ii,Lr=f(()=>{It=9,ii=255;});function si(i){return base32.encode(Buffer.from(i))}var ai=f(()=>{});function li(i,e,t){let r=`${i}:${e}${t?`:${t}`:""}`;return si(r)}var ci=f(()=>{ai();});var Nt,pi=f(()=>{Nt=class extends Readable{dataSource;sourceIterator;reading=false;constructor(e){super(),this.dataSource=e,this.sourceIterator=this.dataSource[Symbol.asyncIterator]();}async _read(){if(!this.reading){this.reading=true;try{for(;;){let{value:e,done:t}=await this.sourceIterator.next();if(t){this.push(null);break}let r=JSON.stringify(e)+`
35
+ `,o=Buffer.from(r,"utf8");if(!this.push(o))break}}catch(e){this.destroy(e);}finally{this.reading=false;}}}_destroy(e,t){this.dataSource.return?this.dataSource.return(null).then(()=>t(e),r=>t(e||r)):t(e);}};});function di(){return ui.some(i=>!!process.env[i])}function mi(){return !!process.stdout.isTTY}function gi(){let i=ui.find(e=>!!process.env[e]);return i?hl[i]:void 0}var ui,hl,jr=f(()=>{ui=["GITHUB_ACTIONS","GITLAB_CI","JENKINS_URL","CIRCLECI","TRAVIS","BUILDKITE","DRONE","CI"],hl={GITHUB_ACTIONS:"github-actions",GITLAB_CI:"gitlab",JENKINS_URL:"jenkins",CIRCLECI:"circleci",TRAVIS:"travis",BUILDKITE:"buildkite",DRONE:"drone",CI:"unknown"};});function yl(i){switch(i){case "darwin":return "Macintosh";case "win32":return "Windows";case "linux":return "Linux";case "freebsd":return "FreeBSD";default:return i.charAt(0).toUpperCase()+i.slice(1)}}function bl(i,e){return i==="darwin"?`Darwin ${e}`:e}function vl(){let i=globalThis.__constellationVersion;return typeof i=="string"&&i.length>0?i:"unknown"}function Sl(i={}){let e=i.platform??process.platform,t=i.arch??process.arch,r=(i.nodeVersion??process.version).replace(/^v/,""),o=i.osRelease??Pe.release(),s=vl(),a=yl(e),l=bl(e,o),c=`constellation-cli/${s} (${a}; ${l}; ${t}) Node/${r}`,u=gi();return u&&(c+=` CI/${u}`),c}var rt,hi=f(()=>{jr();rt=Sl();});var Rt,Tt,k,fe,se,ke,he,Fr=f(()=>{tt();M();Lr();ci();pi();hi();Rt=class{constructor(e,t,r=false,o){this.config=e;this.accessKey=t;this.dirty=r;this.reporter=o;}apiVersion="intel/v1";features={};isFeatureEnabled(e){return this.features[e]===true}parseFeatureHeader(e){if(Object.keys(this.features).length>0)return;let t=e.headers.get("X-Features");if(t)for(let r of t.split(",")){let[o,s]=r.split("=");o&&s!==void 0&&(this.features[o]=s==="true");}}async getProjectState(){let e={"Content-Type":"application/x-ndjson; charset=utf-8","x-project-id":this.config.projectId,"x-branch-name":this.config.branch,"x-constellation-dirty":this.dirty?"true":"false",Authorization:`Bearer ${this.accessKey}`},t=await this.sendRequest("project",void 0,"GET",e);return t&&!t.ok&&await this.handleProjectStateError(t),this.parseFeatureHeader(t),t.json()}async handleProjectStateError(e){try{let t=await e.json(),r=t?.code;switch(r){case "PROJECT_NOT_REGISTERED":throw new se(t?.message||"Project not registered",r,this.config.projectId);case "PROJECT_INACTIVE":throw new se(t?.message||"Project is inactive",r,this.config.projectId);case "INVALID_PROJECT_ID":throw new se(t?.message||"Invalid project ID format",r,this.config.projectId);case "PROJECT_NOT_FOUND":throw new fe("Project not found - no previous index exists");default:throw e.status===404?new fe("Project not found - no previous index exists"):new Error(`Unexpected API response (${e.status}): ${t?.message||e.statusText}`)}}catch(t){throw t instanceof se||t instanceof fe?t:e.status===404?new fe("Project not found - no previous index exists"):new Error(`Unexpected API response (${e.status})`)}}async getIndexStatus(e,t){let r=new URLSearchParams({branch:e});t&&r.set("commit",t);let o=`projects/${encodeURIComponent(this.config.projectId)}/index-status?${r.toString()}`;try{let s=await this.sendRequest(o,null,"GET");if(!s||!s.ok)return null;let a=await s.json(),l=Rr.safeParse(a);return l.success?l.data:(this.reporter?.warn(`[constellation] getIndexStatus: unrecognized response shape \u2014 ${l.error.issues.map(c=>c.message).join("; ")}`),null)}catch(s){if(s instanceof k)throw s;return null}}async claimAstLock(e,t,r,o,s){let a=await this.sendRequest("ast/lock",null,"POST",{"x-project-id":e,"x-branch-name":t,"x-constellation-index":r?"incremental":"full","x-commit-hash":o,"x-commit-timestamp":s,"x-constellation-dirty":this.dirty?"true":"false"});if(!a)throw new Error("Failed to claim indexing lock: no response");if(a.status===409)throw await this.parseIndexingConflict(a);if(a.status===401)throw new k("Authentication failed");if(!a.ok){let u=await this.formatErrorBody(a);throw new Error(`Failed to claim indexing lock: ${a.status}${u?` \u2014 ${u}`:""}`)}let l=await a.json(),c=qn.safeParse(l);if(!c.success)throw new Error(`Invalid lock response from server: ${c.error.issues.map(u=>u.message).join("; ")}`);return c.data}async pollIndexStatus(e,t,r,o=300*1e3){let s=Date.now(),a=2e3,l=3e4;for(;Date.now()-s<o;){try{let c=await this.sendRequest(`projects/${encodeURIComponent(e)}/index-status?branch=${encodeURIComponent(t)}&commit=${encodeURIComponent(r)}`,null,"GET",{"x-constellation-dirty":this.dirty?"true":"false"});if(!c)continue;if(c.status===401)throw new k("Authentication failed during index status polling");if(c.status===403||c.status===404)return !1;if(c.ok){let u=await c.json(),p=Rr.safeParse(u);if(p.success){if(p.data.status==="current")return !0;if(p.data.status==="stale"||p.data.status==="failed")return !1}}}catch(c){if(c instanceof k)throw c}await new Promise(c=>setTimeout(c,a)),a=Math.min(a*2,l);}return false}async uploadToQueue(e,t,r,o,s){return this.streamToApi(e,"ast/queue",t,r,true,o,s)}async startEnrichment(e,t,r){let o=new Agent({headersTimeout:1e4,bodyTimeout:1e4});try{let s=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/enrichment/start`,{method:"POST",headers:{Authorization:`Bearer ${this.accessKey}`,"Content-Type":"application/json; charset=utf-8","User-Agent":rt,"x-project-id":t,"x-branch-name":r,"x-attempt-id":e,"x-constellation-dirty":this.dirty?"true":"false"},dispatcher:o});if(s.ok)return !0;let a=`status ${s.status}`;try{let l=await s.json();l?.message?a=Array.isArray(l.message)?l.message.join("; "):String(l.message):l?.code&&(a=`status ${s.status} (${String(l.code)})`);}catch{}return this.reporter?.warn(`Enrichment start heartbeat rejected: ${a}`),!1}catch(s){return this.reporter?.warn(`Enrichment start heartbeat failed: ${s instanceof Error?s.message:String(s)}`),false}finally{o.destroy().catch(()=>{});}}async uploadEnrichment(e,t,r,o){let s=[5e3,1e4,2e4],a=en.gzipSync(Buffer.from(e,"utf8")),l=new Agent({headersTimeout:0,bodyTimeout:0});try{for(let c=0;c<=s.length;c++)try{let u=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/enrichment`,{method:"POST",headers:{Authorization:`Bearer ${this.accessKey}`,"Content-Type":"application/x-ndjson; charset=utf-8","Content-Encoding":"gzip","User-Agent":rt,"x-project-id":t,"x-branch-name":r,"x-commit-hash":o,"x-constellation-dirty":this.dirty?"true":"false"},body:a,dispatcher:l});if(u.status===401)throw new k("Authentication failed during enrichment upload");if(u.status===409){if((await u.json().catch(()=>({})))?.code==="COMMIT_MISMATCH")return this.reporter?.warn("Enrichment skipped: index state changed since upload"),!1;if(c<s.length){await new Promise(d=>setTimeout(d,s[c]));continue}return this.reporter?.warn("Enrichment skipped: indexing still in progress after retries"),!1}return u.ok||u.status===202?!0:(this.reporter?.warn(`Enrichment upload failed with status ${u.status}`),!1)}catch(u){if(u instanceof k)throw u;if(c<s.length){this.reporter?.warn(`Enrichment upload network error (attempt ${c+1}/${s.length+1}): ${u instanceof Error?u.message:String(u)}`),await new Promise(p=>setTimeout(p,s[c]));continue}return this.reporter?.warn(`Enrichment upload error: ${u instanceof Error?u.message:String(u)}`),!1}return !1}finally{l.destroy().catch(()=>{});}}async deleteFiles(e){for(let t of e){let r=li(this.config.projectId,this.config.branch,t);await this.delete(`/ast/${r}`);}}retryableStatusCodes=[500,502,503,504];async parseIndexingConflict(e){let t="Indexing already in progress",r;try{let o=await e.json();t=o?.message||t,r=o?.details?.branchName;}catch{}return new ke(t,r)}async formatErrorBody(e){try{let t=await e.json();if(typeof t?.message=="string"){let r=typeof t.code=="string"&&t.code.length>0?` [${t.code}]`:"";return `${t.message}${r}`}if(Array.isArray(t?.message))return t.message.join("; ");if(typeof t?.code=="string")return t.code}catch{}return ""}async streamToApi(e,t,r,o,s,a,l){try{let{Readable:c}=await import('stream'),u=new Nt(e),p=process.env.CAPTURE_PAYLOAD_PATH,d=null,m=c.toWeb(u);if(p){let[g,y]=m.tee(),b=zt.createWriteStream(p);d=pipeline(c.fromWeb(y),en.createGzip(),oi(),b).catch(v=>{this.reporter?.warn(`[constellation] capture tap failed: ${v instanceof Error?v.message:String(v)}`);}),m=g;}let h=new Agent({headersTimeout:0,bodyTimeout:0});try{let g=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/${t}`,{method:"POST",headers:{"Content-Type":"application/x-ndjson; charset=utf-8","User-Agent":rt,"x-project-id":r,"x-branch-name":o,"x-constellation-index":s?"incremental":"full","x-constellation-dirty":this.dirty?"true":"false",Authorization:`Bearer ${this.accessKey}`,...a&&{"x-commit-hash":a},...l&&{"x-attempt-id":l}},body:m,duplex:"half",dispatcher:h});if(!g.ok&&typeof u.destroy=="function"&&u.destroy(),g.status===401)throw new k("Authentication failed");if(g.status===409)throw await this.parseIndexingConflict(g);if(g.status===200)try{let b=await g.json();if(b?.status==="current")return this.reporter?.summary(`${w} Index already up to date for ${o} at commit ${b.commitHash||"unknown"}`),!0}catch{}if(g.ok||g.status===202)return !0;let y=`Server returned ${g.status}`;try{let b=await g.json();b?.message&&(y=Array.isArray(b.message)?b.message.join("; "):b.message);}catch{}throw new Error(y)}finally{d&&await d;}}catch(c){if(c instanceof k||c instanceof ke)throw c;let u=c instanceof Error?c:new Error(String(c)),p="";if(u.message==="fetch failed"||c.code){let m=[],h=c.code||c.cause?.code;if(c.code&&m.push(`Error Code: ${c.code}`),c.cause){let g=c.cause;g.code&&m.push(`Cause Code: ${g.code}`),g.errno&&m.push(`Errno: ${g.errno}`),g.syscall&&m.push(`System Call: ${g.syscall}`),g.address&&m.push(`Address: ${g.address}`),g.port&&m.push(`Port: ${g.port}`);}h==="ERR_INVALID_ARG_VALUE"?p="Invalid argument value - check stream/body format and duplex option":h==="ECONNREFUSED"?p="Connection refused - service may be down or unreachable":h==="ENOTFOUND"?p="DNS lookup failed - check service URL":h==="ETIMEDOUT"?p="Connection timeout - service not responding":h==="ECONNRESET"?p="Connection reset by server":h==="EHOSTUNREACH"?p="Host unreachable - check network connectivity":p="Network failure",m.length>0&&(p+=` (${m.join(", ")})`);}else p=u.message;let d=new Error(`Failed to upload data to Constellation Service: ${p}`);throw d.cause=u,d.stack=`${d.stack}
36
+ Caused by: ${u.stack}`,d}}async sendRequest(e,t,r,o={},s=0,a=3,l=1e3,c=250){for(let u=1;u<=a;u++){let p;try{let d=new AbortController;s>0&&(p=setTimeout(()=>d.abort(),s));let m={...o,"Content-Type":"application/json; charset=utf-8",Accepts:"application/json; charset=utf-8","User-Agent":rt,Authorization:`Bearer ${this.accessKey}`},h=await fetch(`${this.config.apiUrl}/${this.apiVersion}/${e}`,{method:r,headers:m,body:t?JSON.stringify(t):void 0,signal:d.signal});if(p&&clearTimeout(p),h.status===401)throw new k("Authentication failed");if(!h.ok&&this.retryableStatusCodes.includes(h.status))throw new Tt(`${h.statusText} (${h.status})`);return h}catch(d){if(p&&clearTimeout(p),!(d instanceof k)){let m=d instanceof Error?`${d.message}${d.cause?` (Cause: ${d.cause})`:""}`:String(d);this.reporter?.warn(`HTTP request attempt ${u}/${a} failed: ${m}`);}if(u<a&&d instanceof Tt){let m=l+Math.floor(Math.random()*c);await new Promise(h=>setTimeout(h,m));}else throw d}}}async reportErrors(e){try{let t=await this.sendRequest("error-reports",e,"POST",{"x-project-id":this.config.projectId,"x-branch-name":this.config.branch,"x-constellation-dirty":this.dirty?"true":"false"},1e4,1,0,0);if(!t){this.reporter?.warn("Failed to upload error report: no response received");return}if(t.status===403){this.reporter?.warn("Error reporting is not available on your current plan");return}t.ok||this.reporter?.warn(`Failed to upload error report: ${t.statusText} (${t.status})`);}catch(t){this.reporter?.warn(`Failed to upload error report: ${t?.message||"Unknown error"}`);}}async delete(e){let t={"x-project-id":this.config.projectId,"x-branch-name":this.config.branch,"x-constellation-dirty":this.dirty?"true":"false"},r=await this.sendRequest(e,void 0,"DELETE",t);if(r&&!r.ok)throw new Error(`Failed sending HTTP DELETE to ${e}`)}},Tt=class extends Error{constructor(e){super(e),this.name="RetryableError";}},k=class extends Error{constructor(e){super(e),this.name="AuthenticationError";}},fe=class extends Error{constructor(e){super(e),this.name="NotFoundError";}},se=class extends Error{constructor(t,r,o){super(t);this.code=r;this.projectId=o;this.name="ProjectValidationError";}},ke=class extends Error{constructor(t,r){super(t);this.branchName=r;this.name="IndexingInProgressError";}},he=class extends Error{constructor(t,r){super(t);this.errorCode=r;this.name="GitValidationError";}};});function bi(i){return i.replace(/\\/g,"/")}function jt(i){return bi(i).replace(/^\.?\//,"")}function W(i,e){return bi(E.relative(i,e))}var we=f(()=>{});var Fe,Dr=f(()=>{Fe=class{constructor(e=10,t={}){this.concurrency=e;this.options=t;if(e<1)throw new Error("Concurrency must be at least 1")}async*run(e,t){if(e.length===0)return;let r=new Map,o=0,s=0,a=new Map,l=new Set,c=0;for(;s<e.length&&r.size<this.concurrency;){let u=o++,p=s,d=this.processItem(e[p],p,t).then(m=>({result:m!==null?m.result:null,index:p,promiseId:u}));r.set(u,d),s++;}for(;r.size>0;){let u=await Promise.race(r.values());if(r.delete(u.promiseId),this.options.preserveOrder)for(u.result!==null?a.set(u.index,u.result):l.add(u.index);c<e.length&&(a.has(c)||l.has(c));){if(a.has(c)){let p=a.get(c);a.delete(c),yield p;}else l.delete(c);c++;}else u.result!==null&&(yield u.result);if(s<e.length){let p=o++,d=s,m=this.processItem(e[d],d,t).then(h=>({result:h!==null?h.result:null,index:d,promiseId:p}));r.set(p,m),s++;}}}async processItem(e,t,r){try{return {result:await r(e,t),index:t}}catch{return null}}};});var El,_l,Or,Pl,At,Si=f(()=>{we();Dr();El={function:{hover:true,references:true,callHierarchy:true},method:{hover:true,references:true,callHierarchy:true},class:{hover:false,references:true,callHierarchy:false},interface:{hover:false,references:true,callHierarchy:false},variable:{hover:true,references:true,callHierarchy:false},property:{hover:true,references:true,callHierarchy:false},import:{hover:true,references:false,callHierarchy:false}},_l={hover:true,references:true,callHierarchy:false},Or=1e4,Pl=1200*1e3,At=class{constructor(e,t){this.projectRoot=e;this.reporter=t;}async enrich(e,t,r,o,s){let a=[],l=Date.now(),c={filesUnreadable:0,filesOpenFailed:0,filesNoSymbols:0,symbolQueryErrors:0,discoveryErrors:0,queryRejections:0,lspProcessCrashes:0,symbolsWithNoEnrichment:{},firstFileError:null,firstOpenError:null,firstSymbolError:null,firstDiscoveryError:null,firstLspCrashLanguage:null},u=false,p=new Set,d=new Set;return await Promise.all([...e.entries()].map(async([m,h])=>{let g=r.get(m);if(!g)return;let y=h.length,b=y>1e4?8:y>5e3?10:16,v=new Fe(b),T=()=>{p.add(m),d.has(g.serverId)||(d.add(g.serverId),c.lspProcessCrashes++,c.firstLspCrashLanguage||(c.firstLspCrashLanguage=m)),this.reporter?.warn(`[LSP:${m}] Process exited mid-enrichment (concurrency=${b}); halting subsequent ${m} files.`);},N=g.onCrash(T),C=0,_=v.run(h,async x=>{try{if(u||Date.now()-l>Pl)return u=!0,null;if(p.has(m))return null;let G=await this.openFile(g,x,c,o?.get(x));if(!G)return null;let{uri:B}=G;try{let H=t.get(x)??[];if(H.length===0&&(H=await this.discoverSymbols(g,x,B,c),H.length===0))return c.filesNoSymbols++,null;let P=await this.enrichOpenFile(g,x,B,H,c);return P.length>0?{filePath:x,language:m,symbols:P}:null}finally{this.closeFile(g,B);}}finally{C++,s?.(m,C,y);}});try{for await(let x of _)x&&a.push(x);}finally{N();}})),u&&this.reporter?.info("Enrichment timeout reached. Uploading partial results."),this.logDiagnostics(c),a}async openFile(e,t,r,o){let s=E.resolve(this.projectRoot,t),a=pathToFileURL(s).href,l=o;if(l===void 0)try{l=await zt.promises.readFile(s,"utf-8");}catch(c){return r.filesUnreadable++,r.firstFileError||(r.firstFileError=`${t}: ${c instanceof Error?c.message:String(c)}`),null}try{e.sendNotification("textDocument/didOpen",{textDocument:{uri:a,languageId:this.getLanguageId(t),version:1,text:l}});}catch(c){return r.filesOpenFailed++,r.firstOpenError||(r.firstOpenError=`${t}: ${c instanceof Error?c.message:String(c)}`),null}return {uri:a,content:l}}closeFile(e,t){try{e.sendNotification("textDocument/didClose",{textDocument:{uri:t}});}catch{}}async enrichOpenFile(e,t,r,o,s){let a=await Promise.allSettled(o.map(c=>this.querySymbol(e,r,c,s))),l=[];for(let c=0;c<a.length;c++){let u=a[c];if(u.status==="fulfilled")u.value&&l.push(u.value);else if(s.symbolQueryErrors++,!s.firstSymbolError){let p=o[c];s.firstSymbolError=`${p.name} in ${t}: ${u.reason instanceof Error?u.reason.message:String(u.reason)}`;}}return l}logDiagnostics(e){let t=[];e.filesUnreadable>0&&t.push(`${e.filesUnreadable} files unreadable`),e.filesOpenFailed>0&&t.push(`${e.filesOpenFailed} files failed to open in language server`),e.filesNoSymbols>0&&t.push(`${e.filesNoSymbols} files had no discoverable symbols`),e.discoveryErrors>0&&t.push(`${e.discoveryErrors} symbol discovery failures`),e.symbolQueryErrors>0&&t.push(`${e.symbolQueryErrors} symbol query failures`),e.queryRejections>0&&t.push(`${e.queryRejections} individual LSP query rejections`),e.lspProcessCrashes>0&&t.push(`${e.lspProcessCrashes} LSP process crashes`);let r=Object.entries(e.symbolsWithNoEnrichment).filter(([,o])=>o>0).sort(([,o],[,s])=>s-o);if(r.length>0){let o=r.reduce((a,[,l])=>a+l,0),s=r.map(([a,l])=>`${l} ${a}`).join(", ");t.push(`${o} symbols yielded no enrichment (${s})`);}t.length!==0&&(this.reporter?.warn(`Enrichment issues: ${t.join(", ")}`),e.firstFileError&&this.reporter?.warn(`First file read error: ${e.firstFileError}`),e.firstOpenError&&this.reporter?.warn(`First didOpen error: ${e.firstOpenError}`),e.firstDiscoveryError&&this.reporter?.warn(`First discovery error: ${e.firstDiscoveryError}`),e.firstSymbolError&&this.reporter?.warn(`First symbol query error: ${e.firstSymbolError}`));}async querySymbol(e,t,r,o){let s=r.kind.toLowerCase(),a=El[s]||_l,c=!r.isExported&&(s==="function"||s==="method")?{...a,callHierarchy:false}:a,u={line:r.line-1,character:r.column},p={textDocument:{uri:t},position:u},d={name:r.name,line:r.line,column:r.column,kind:r.kind},m=false,[h,g]=await Promise.allSettled([c.hover?e.sendRequest("textDocument/hover",p,Or):null,c.references?e.sendRequest("textDocument/references",{...p,context:{includeDeclaration:false}},Or):null]);for(let y of [h,g])y.status==="rejected"&&o.queryRejections++;if(h.status==="fulfilled"&&h.value?.contents){let y=h.value,b=typeof y.contents=="string"?y.contents:y.contents.value||"";b&&(d.typeInfo={resolvedType:b},m=true);}if(g.status==="fulfilled"&&g.value){let y=g.value;if(y.length>0){let b=y.slice(0,100).map(v=>({filePath:W(this.projectRoot,this.uriToPath(v.uri||"")),line:(v.range?.start?.line??0)+1,column:v.range?.start?.character??0}));d.references={count:y.length,locations:b},m=true;}}if(c.callHierarchy)try{let y=await e.sendRequest("textDocument/prepareCallHierarchy",p,Or);if(y&&y.length>0){let b=y[0],[v,T]=await Promise.all([e.sendRequest("callHierarchy/incomingCalls",{item:b}).catch(()=>[]),e.sendRequest("callHierarchy/outgoingCalls",{item:b}).catch(()=>[])]),N=(v||[]).slice(0,200).map(_=>({name:_.from?.name||"",filePath:W(this.projectRoot,this.uriToPath(_.from?.uri||"")),line:(_.from?.range?.start?.line??0)+1,column:_.from?.selectionRange?.start?.character??_.from?.range?.start?.character??0})),C=(T||[]).slice(0,200).map(_=>({name:_.to?.name||"",filePath:W(this.projectRoot,this.uriToPath(_.to?.uri||"")),line:(_.to?.range?.start?.line??0)+1,column:_.to?.selectionRange?.start?.character??_.to?.range?.start?.character??0}));(N.length>0||C.length>0)&&(d.callHierarchy={incomingCalls:N,outgoingCalls:C},m=!0);}}catch{o.queryRejections++;}if(!m){let y=r.kind.toLowerCase();o.symbolsWithNoEnrichment[y]=(o.symbolsWithNoEnrichment[y]??0)+1;}return m?d:null}async discoverSymbols(e,t,r,o){try{let s=await e.sendRequest("textDocument/documentSymbol",{textDocument:{uri:r}});return !s||!Array.isArray(s)?[]:this.flattenDocumentSymbols(s)}catch(s){return o.discoveryErrors++,o.firstDiscoveryError||(o.firstDiscoveryError=`${t}: ${s instanceof Error?s.message:String(s)}`),[]}}flattenDocumentSymbols(e){let t=[],r={1:"file",2:"module",3:"namespace",4:"package",5:"class",6:"method",7:"property",8:"field",9:"constructor",10:"enum",11:"interface",12:"function",13:"variable",14:"constant",15:"string",16:"number",17:"boolean",18:"array",19:"object",20:"key",21:"null",22:"enumMember",23:"struct",24:"event",25:"operator",26:"typeParameter"};for(let o of e){let s=r[o.kind]||"variable",a=o.selectionRange||o.range||o.location?.range;a&&t.push({name:o.name,line:(a.start?.line??0)+1,column:a.start?.character??0,kind:s,isExported:true}),o.children&&Array.isArray(o.children)&&t.push(...this.flattenDocumentSymbols(o.children));}return t}uriToPath(e){try{return fileURLToPath(new URL(e))}catch{return e.replace(/^file:\/\//,"")}}getLanguageId(e){let t=E.extname(e).toLowerCase();return {".ts":"typescript",".tsx":"typescriptreact",".js":"javascript",".jsx":"javascriptreact",".py":"python",".pyi":"python"}[t]||"plaintext"}};});function wi(i){return i.map(e=>JSON.stringify(e)).join(`
37
37
  `)+`
38
- `}var ai=f(()=>{});function je(i){try{return execFileSync(process.platform==="win32"?"where":"which",[i],{stdio:"ignore"}),!0}catch{return false}}var S,re=f(()=>{S={async directoryExists(i){try{return (await G__default.stat(i)).isDirectory()}catch{return false}},async fileIsReadable(i){try{return await G__default.access(i,G__default.constants.R_OK),!0}catch{return false}},async readFile(i,e="utf-8"){let t=await G__default.readFile(i,{encoding:e,flag:G__default.constants.O_RDONLY});return t.charCodeAt(0)===65279&&(t=t.slice(1)),t},async writeFile(i,e,t="utf-8"){let n=Buffer.from(e,t);await G__default.writeFile(i,n,{encoding:t,flag:G__default.constants.O_WRONLY|G__default.constants.O_CREAT|G__default.constants.O_TRUNC});},async getFileStats(i){return await G__default.stat(i)},async getFileHandle(i,e,t){return await G__default.open(i,e,t)}};});var Lt,li=f(()=>{Lt=class i{constructor(e,t,n=1e4,o){this.stdin=e;this.stdout=t;this.defaultTimeoutMs=n;this.reporter=o;this.stdout.on("data",s=>this.handleData(s)),this.stdin.on("error",()=>{});}static HEADER_SEPARATOR=Buffer.from(`\r
38
+ `}var Ci=f(()=>{});function $e(i){try{return execFileSync(process.platform==="win32"?"where":"which",[i],{stdio:"ignore"}),!0}catch{return false}}var S,ae=f(()=>{S={async directoryExists(i){try{return (await J__default.stat(i)).isDirectory()}catch{return false}},async fileIsReadable(i){try{return await J__default.access(i,J__default.constants.R_OK),!0}catch{return false}},async readFile(i,e="utf-8"){let t=await J__default.readFile(i,{encoding:e,flag:J__default.constants.O_RDONLY});return t.charCodeAt(0)===65279&&(t=t.slice(1)),t},async writeFile(i,e,t="utf-8"){let r=Buffer.from(e,t);await J__default.writeFile(i,r,{encoding:t,flag:J__default.constants.O_WRONLY|J__default.constants.O_CREAT|J__default.constants.O_TRUNC});},async getFileStats(i){return await J__default.stat(i)},async getFileHandle(i,e,t){return await J__default.open(i,e,t)}};});var Ft,xi=f(()=>{Ft=class i{constructor(e,t,r=1e4,o){this.stdin=e;this.stdout=t;this.defaultTimeoutMs=r;this.reporter=o;this.stdout.on("data",s=>this.handleData(s)),this.stdin.on("error",()=>{});}static HEADER_SEPARATOR=Buffer.from(`\r
39
39
  \r
40
- `);nextId=1;pendingRequests=new Map;buffer=Buffer.alloc(0);disposed=false;loggedMalformedJson=false;sendRequest(e,t,n){if(this.disposed)return Promise.reject(new Error("LspClient disposed"));let o=this.nextId++,s={jsonrpc:"2.0",id:o,method:e,...t!==void 0&&{params:t}};return new Promise((a,l)=>{let c=setTimeout(()=>{this.pendingRequests.delete(o),l(new Error(`LSP request '${e}' timed out after ${n??this.defaultTimeoutMs}ms`));},n??this.defaultTimeoutMs);this.pendingRequests.set(o,{resolve:a,reject:l,timer:c}),this.writeMessage(s);})}sendNotification(e,t){if(this.disposed)return;let n={jsonrpc:"2.0",method:e,...t!==void 0&&{params:t}};this.writeMessage(n);}dispose(){this.disposed=true;for(let[,e]of this.pendingRequests)clearTimeout(e.timer),e.reject(new Error("LspClient disposed"));this.pendingRequests.clear(),this.stdout.removeAllListeners("data");}writeMessage(e){let t=JSON.stringify(e),o=`Content-Length: ${Buffer.byteLength(t,"utf-8")}\r
40
+ `);nextId=1;pendingRequests=new Map;buffer=Buffer.alloc(0);disposed=false;loggedMalformedJson=false;sendRequest(e,t,r){if(this.disposed)return Promise.reject(new Error("LspClient disposed"));let o=this.nextId++,s={jsonrpc:"2.0",id:o,method:e,...t!==void 0&&{params:t}};return new Promise((a,l)=>{let c=setTimeout(()=>{this.pendingRequests.delete(o),l(new Error(`LSP request '${e}' timed out after ${r??this.defaultTimeoutMs}ms`));},r??this.defaultTimeoutMs);this.pendingRequests.set(o,{resolve:a,reject:l,timer:c}),this.writeMessage(s);})}sendNotification(e,t){if(this.disposed)return;let r={jsonrpc:"2.0",method:e,...t!==void 0&&{params:t}};this.writeMessage(r);}dispose(){this.disposed=true;for(let[,e]of this.pendingRequests)clearTimeout(e.timer),e.reject(new Error("LspClient disposed"));this.pendingRequests.clear(),this.stdout.removeAllListeners("data");}writeMessage(e){let t=JSON.stringify(e),o=`Content-Length: ${Buffer.byteLength(t,"utf-8")}\r
41
41
  \r
42
- `;this.stdin.write(o+t);}handleData(e){for(this.buffer=Buffer.concat([this.buffer,e]);;){let t=this.buffer.indexOf(i.HEADER_SEPARATOR);if(t===-1)break;let o=this.buffer.subarray(0,t).toString("utf-8").match(/Content-Length:\s*(\d+)/i);if(!o){this.buffer=this.buffer.subarray(t+4);continue}let s=parseInt(o[1],10),a=t+4;if(this.buffer.length-a<s)break;let l=this.buffer.subarray(a,a+s).toString("utf-8");this.buffer=this.buffer.subarray(a+s);try{let c=JSON.parse(l);this.handleResponse(c);}catch{this.loggedMalformedJson||(this.loggedMalformedJson=true,this.reporter?.error("[LSP] Received malformed JSON from language server"));}}}handleResponse(e){if(e.id===void 0||e.id===null)return;let t=this.pendingRequests.get(e.id);t&&(this.pendingRequests.delete(e.id),clearTimeout(t.timer),e.error?t.reject(new Error(`LSP error ${e.error.code}: ${e.error.message}`)):t.resolve(e.result));}};});var kr,At,de,Qe=f(()=>{kr=E.join(Ce.homedir(),".constellation","lsp-servers"),At=E.join(kr,"node_modules",".bin"),de=new Map([["typescript",{command:"typescript-language-server",args:["--stdio"],npmPackages:["typescript-language-server","typescript"],testCommand:["--version"]}],["javascript",{command:"typescript-language-server",args:["--stdio"],npmPackages:["typescript-language-server","typescript"],testCommand:["--version"]}],["python",{command:"pyright-langserver",args:["--stdio"],npmPackages:["pyright"],testCommand:["--version"]}]]);});function ui(i){return i.replace(/\\/g,"/")}function ml(i){let e=ui(i);return E.posix.basename(e).toLowerCase().replace(/\.(exe|com|bat|cmd|ps1)$/i,"")}function di(i,e){if(!i||i.trim().length===0)return {classification:"denied",reason:"LSP command is empty"};let t=ui(i);if(dl.test(t))return {classification:"denied",reason:"LSP command contains shell metacharacters"};for(let o of e){if(typeof o!="string")return {classification:"denied",reason:"LSP argument is not a string"};if(o.includes("\0"))return {classification:"denied",reason:"LSP argument contains a null byte"};if(o.includes(`
43
- `)||o.includes("\r"))return {classification:"denied",reason:"LSP argument contains newline/carriage-return"}}let n=ml(i);if(ul.has(n))return {classification:"denied",reason:`LSP command resolves to a shell or interpreter ('${n}')`};for(let[,o]of de)if(n===o.command.toLowerCase())return {classification:"known-safe"};return {classification:"custom-untrusted"}}var ul,dl,mi=f(()=>{Qe();ul=new Set(["sh","bash","zsh","zsh5","fish","dash","ash","ksh","csh","tcsh","rc","yash","cmd","command","powershell","pwsh","node","nodejs","deno","bun","python","python2","python3","pypy","pypy3","perl","ruby","php","lua","luajit","tclsh","wish","osascript","wscript","cscript","mshta","rundll32","sudo","su","doas","pkexec","runas","gsudo","env","xargs","exec","nohup","timeout","setsid"].map(i=>i.toLowerCase())),dl=/[;&|`$<>\n\r\0"']/;});function gi(i,e,t,n){return i.projectRoot===e&&i.command===t&&i.args.length===n.length&&i.args.every((o,s)=>o===n[s])}function gl(i){if(!i||typeof i!="object")return false;let e=i;return typeof e.projectRoot=="string"&&typeof e.command=="string"&&Array.isArray(e.args)&&e.args.every(t=>typeof t=="string")}var Le,Fr=f(()=>{Le=class{constructor(e){this.trustFilePath=e;}async isTrusted(e,t,n){return (await this.load()).entries.some(s=>gi(s,e,t,n))}async recordTrust(e,t,n){let o=await this.load();if(o.entries.some(l=>gi(l,e,t,n)))return;o.entries.push({projectRoot:e,command:t,args:[...n],trustedAt:new Date().toISOString()}),await G.mkdir(E.dirname(this.trustFilePath),{recursive:true});let a=`${this.trustFilePath}.${process.pid}.tmp`;try{await G.writeFile(a,JSON.stringify(o,null,2)+`
44
- `,"utf-8"),await G.rename(a,this.trustFilePath);}catch(l){throw await G.rm(a,{force:true}).catch(()=>{}),l}}async load(){try{let e=await G.readFile(this.trustFilePath,"utf-8"),t=JSON.parse(e);return t&&typeof t=="object"&&Array.isArray(t.entries)?{entries:t.entries.filter(gl)}:{entries:[]}}catch{return {entries:[]}}}static isCIEnvironment(){return !!(process.env.CI||process.env.GITHUB_ACTIONS||process.env.GITLAB_CI||process.env.JENKINS_URL||process.env.CIRCLECI||process.env.TRAVIS||process.env.BUILDKITE||process.env.DRONE||process.env.TF_BUILD||process.env.BITBUCKET_BUILD_NUMBER||process.env.TEAMCITY_VERSION||process.env.CODEBUILD_BUILD_ID)}};});var kt,hi=f(()=>{mi();Fr();kt=class{projectRoot;logger;trustStore;prompt;isCI;constructor(e){this.projectRoot=e.projectRoot,this.logger=e.logger,this.trustStore=e.trustStore,this.prompt=e.prompt,this.isCI=e.isCI??Le.isCIEnvironment;}async authorize(e,t,n){let{classification:o,reason:s}=di(t,n);if(o==="denied")return this.logger.error(`[LSP:${e}] Refusing unsafe LSP command '${t}': ${s??"denied"}.`),false;if(o==="known-safe"||await this.trustStore.isTrusted(this.projectRoot,t,n))return true;if(this.isCI())return this.logger.warn(`[LSP:${e}] Skipping untrusted custom LSP command '${t}' in CI. Run 'constellation index' interactively once to approve it, or set the 'lsp' field to a known binary.`),false;let a=n.length>0?` ${n.join(" ")}`:"",l=`Trust custom LSP command for this project?
42
+ `;this.stdin.write(o+t);}handleData(e){for(this.buffer=Buffer.concat([this.buffer,e]);;){let t=this.buffer.indexOf(i.HEADER_SEPARATOR);if(t===-1)break;let o=this.buffer.subarray(0,t).toString("utf-8").match(/Content-Length:\s*(\d+)/i);if(!o){this.buffer=this.buffer.subarray(t+4);continue}let s=parseInt(o[1],10),a=t+4;if(this.buffer.length-a<s)break;let l=this.buffer.subarray(a,a+s).toString("utf-8");this.buffer=this.buffer.subarray(a+s);try{let c=JSON.parse(l);this.handleResponse(c);}catch{this.loggedMalformedJson||(this.loggedMalformedJson=true,this.reporter?.error("[LSP] Received malformed JSON from language server"));}}}handleResponse(e){if(e.id===void 0||e.id===null)return;let t=this.pendingRequests.get(e.id);t&&(this.pendingRequests.delete(e.id),clearTimeout(t.timer),e.error?t.reject(new Error(`LSP error ${e.error.code}: ${e.error.message}`)):t.resolve(e.result));}};});var Ur,$t,ye,nt=f(()=>{Ur=E.join(Pe.homedir(),".constellation","lsp-servers"),$t=E.join(Ur,"node_modules",".bin"),ye=new Map([["typescript",{command:"typescript-language-server",args:["--stdio"],npmPackages:["typescript-language-server","typescript"],testCommand:["--version"]}],["javascript",{command:"typescript-language-server",args:["--stdio"],npmPackages:["typescript-language-server","typescript"],testCommand:["--version"]}],["python",{command:"pyright-langserver",args:["--stdio"],npmPackages:["pyright"],testCommand:["--version"]}]]);});function Pi(i){return i.replace(/\\/g,"/")}function Tl(i){let e=Pi(i);return E.posix.basename(e).toLowerCase().replace(/\.(exe|com|bat|cmd|ps1)$/i,"")}function Ii(i,e){if(!i||i.trim().length===0)return {classification:"denied",reason:"LSP command is empty"};let t=Pi(i);if(Rl.test(t))return {classification:"denied",reason:"LSP command contains shell metacharacters"};for(let o of e){if(typeof o!="string")return {classification:"denied",reason:"LSP argument is not a string"};if(o.includes("\0"))return {classification:"denied",reason:"LSP argument contains a null byte"};if(o.includes(`
43
+ `)||o.includes("\r"))return {classification:"denied",reason:"LSP argument contains newline/carriage-return"}}let r=Tl(i);if(Nl.has(r))return {classification:"denied",reason:`LSP command resolves to a shell or interpreter ('${r}')`};for(let[,o]of ye)if(r===o.command.toLowerCase())return {classification:"known-safe"};return {classification:"custom-untrusted"}}var Nl,Rl,Ni=f(()=>{nt();Nl=new Set(["sh","bash","zsh","zsh5","fish","dash","ash","ksh","csh","tcsh","rc","yash","cmd","command","powershell","pwsh","node","nodejs","deno","bun","python","python2","python3","pypy","pypy3","perl","ruby","php","lua","luajit","tclsh","wish","osascript","wscript","cscript","mshta","rundll32","sudo","su","doas","pkexec","runas","gsudo","env","xargs","exec","nohup","timeout","setsid"].map(i=>i.toLowerCase())),Rl=/[;&|`$<>\n\r\0"']/;});function Ri(i,e,t,r){return i.projectRoot===e&&i.command===t&&i.args.length===r.length&&i.args.every((o,s)=>o===r[s])}function Ll(i){if(!i||typeof i!="object")return false;let e=i;return typeof e.projectRoot=="string"&&typeof e.command=="string"&&Array.isArray(e.args)&&e.args.every(t=>typeof t=="string")}var De,Gr=f(()=>{De=class{constructor(e){this.trustFilePath=e;}async isTrusted(e,t,r){return (await this.load()).entries.some(s=>Ri(s,e,t,r))}async recordTrust(e,t,r){let o=await this.load();if(o.entries.some(l=>Ri(l,e,t,r)))return;o.entries.push({projectRoot:e,command:t,args:[...r],trustedAt:new Date().toISOString()}),await J.mkdir(E.dirname(this.trustFilePath),{recursive:true});let a=`${this.trustFilePath}.${process.pid}.tmp`;try{await J.writeFile(a,JSON.stringify(o,null,2)+`
44
+ `,"utf-8"),await J.rename(a,this.trustFilePath);}catch(l){throw await J.rm(a,{force:true}).catch(()=>{}),l}}async load(){try{let e=await J.readFile(this.trustFilePath,"utf-8"),t=JSON.parse(e);return t&&typeof t=="object"&&Array.isArray(t.entries)?{entries:t.entries.filter(Ll)}:{entries:[]}}catch{return {entries:[]}}}static isCIEnvironment(){return !!(process.env.CI||process.env.GITHUB_ACTIONS||process.env.GITLAB_CI||process.env.JENKINS_URL||process.env.CIRCLECI||process.env.TRAVIS||process.env.BUILDKITE||process.env.DRONE||process.env.TF_BUILD||process.env.BITBUCKET_BUILD_NUMBER||process.env.TEAMCITY_VERSION||process.env.CODEBUILD_BUILD_ID)}};});var Dt,Li=f(()=>{Ni();Gr();Dt=class{projectRoot;logger;trustStore;prompt;isCI;constructor(e){this.projectRoot=e.projectRoot,this.logger=e.logger,this.trustStore=e.trustStore,this.prompt=e.prompt,this.isCI=e.isCI??De.isCIEnvironment;}async authorize(e,t,r){let{classification:o,reason:s}=Ii(t,r);if(o==="denied")return this.logger.error(`[LSP:${e}] Refusing unsafe LSP command '${t}': ${s??"denied"}.`),false;if(o==="known-safe"||await this.trustStore.isTrusted(this.projectRoot,t,r))return true;if(this.isCI())return this.logger.warn(`[LSP:${e}] Skipping untrusted custom LSP command '${t}' in CI. Run 'constellation index' interactively once to approve it, or set the 'lsp' field to a known binary.`),false;let a=r.length>0?` ${r.join(" ")}`:"",l=`Trust custom LSP command for this project?
45
45
  ${t}${a}
46
46
 
47
47
  Only approve commands you recognize. Untrusted commands can execute arbitrary code.
48
- Approve?`,c=false;try{c=await this.prompt(l);}catch{c=false;}return c?(await this.trustStore.recordTrust(this.projectRoot,t,n),this.logger.log(`[LSP:${e}] Trusted custom LSP command '${t}' for this project.`),true):(this.logger.warn(`[LSP:${e}] User declined to trust LSP command '${t}'. Skipping enrichment for this language.`),false)}};});var vl,bl,Ft,vi=f(()=>{re();li();Qe();hi();Fr();vl={log:i=>process.stderr.write(i+`
48
+ Approve?`,c=false;try{c=await this.prompt(l);}catch{c=false;}return c?(await this.trustStore.recordTrust(this.projectRoot,t,r),this.logger.log(`[LSP:${e}] Trusted custom LSP command '${t}' for this project.`),true):(this.logger.warn(`[LSP:${e}] User declined to trust LSP command '${t}'. Skipping enrichment for this language.`),false)}};});var Fl,$l,Ot,Ai=f(()=>{ae();xi();nt();Li();Gr();Fl={log:i=>process.stderr.write(i+`
49
49
  `),warn:i=>process.stderr.write(i+`
50
50
  `),error:i=>process.stderr.write(i+`
51
- `)},bl=E.join(Ce.homedir(),".constellation","lsp-trust.json"),Ft=class{constructor(e,t,n){this.projectRoot=e;this.logger=t??vl,this.policy=n??this.buildDefaultPolicy();}serversByKey=new Map;languageToServerKey=new Map;unavailableLanguages=new Set;unavailableServerKeys=new Set;nextId=1;logger;policy;buildDefaultPolicy(){return new kt({projectRoot:this.projectRoot,logger:this.logger,trustStore:new Le(bl),prompt:async e=>{let{confirm:t}=await import('@inquirer/prompts');try{return await t({message:e,default:!1})}catch{return false}}})}async startServer(e,t){if(t===false||this.unavailableLanguages.has(e))return null;let n=this.languageToServerKey.get(e),o=n?this.serversByKey.get(n):void 0;if(o)return this.toConnection(o,e);let s=this.resolveCommand(e,t);if(!s)return this.unavailableLanguages.add(e),null;let{command:a,args:l}=s,c=this.getServerKey(a,l);if(this.unavailableServerKeys.has(c))return this.unavailableLanguages.add(e),null;let u=this.serversByKey.get(c);if(u)return u.languages.add(e),this.languageToServerKey.set(e,c),this.toConnection(u,e);if(!await this.policy.authorize(e,a,l))return this.unavailableLanguages.add(e),this.unavailableServerKeys.add(c),null;try{let d=spawn(a,l,{stdio:["pipe","pipe","pipe"],cwd:this.projectRoot});await new Promise((b,y)=>{d.once("spawn",b),d.once("error",y);}),d.stderr?.on("data",b=>{let y=b.toString().trim();y.toLowerCase().includes("error")&&this.logger.warn(`[LSP:${e}] ${y}`);});let m=new Lt(d.stdin,d.stdout,12e4),g=await m.sendRequest("initialize",{processId:process.pid,rootUri:pathToFileURL(this.projectRoot).href,capabilities:{textDocument:{hover:{contentFormat:["plaintext"]},references:{},callHierarchy:{},implementation:{},documentSymbol:{hierarchicalDocumentSymbolSupport:!0}}}},12e4);m.sendNotification("initialized",{});let h={key:c,language:e,languages:new Set([e]),process:d,client:m};return this.serversByKey.set(c,h),this.languageToServerKey.set(e,c),d.on("exit",b=>{let y=this.serversByKey.get(c);if(y){y.client.dispose(),this.serversByKey.delete(c);for(let[v,x]of this.languageToServerKey.entries())x===c&&this.languageToServerKey.delete(v);}b!==0&&b!==null&&this.logger.warn(`[LSP:${e}] Server exited unexpectedly with code ${b}`);}),this.toConnection(h,e)}catch(d){this.unavailableLanguages.add(e),this.unavailableServerKeys.add(c);let m=`[LSP:${e}] Failed to start: ${d instanceof Error?d.message:String(d)}`,g=d?.code;return g==="ENOENT"||g==="EACCES"?this.logger.warn(m):this.logger.error(m),null}}async shutdown(e){let t=this.languageToServerKey.get(e);if(!t)return;this.languageToServerKey.delete(e);let n=this.serversByKey.get(t);n&&(n.languages.delete(e),!(n.languages.size>0)&&await this.shutdownByKey(t));}async shutdownByKey(e){let t=this.serversByKey.get(e);if(t)try{await t.client.sendRequest("shutdown",null,5e3),t.client.sendNotification("exit",null),await new Promise(n=>{let o=setTimeout(()=>{t.process.kill("SIGKILL"),n();},3e3);t.process.on("exit",()=>{clearTimeout(o),n();});});}catch(n){this.logger.warn(`[LSP:${t.language}] Graceful shutdown failed, force killing: ${n instanceof Error?n.message:String(n)}`),t.process.kill("SIGKILL");}finally{t.client.dispose(),this.serversByKey.delete(e);for(let[n,o]of this.languageToServerKey.entries())o===e&&this.languageToServerKey.delete(n);}}async shutdownAll(){let e=[...this.serversByKey.keys()];await Promise.allSettled(e.map(t=>this.shutdownByKey(t)));}destroyAll(){for(let e of this.serversByKey.values()){try{e.process.kill("SIGKILL");}catch{}try{e.client.dispose();}catch{}}this.serversByKey.clear(),this.languageToServerKey.clear();}resolveCommand(e,t){if(t?.command)return {command:t.command,args:t.args||[]};let n=de.get(e);if(!n)return null;let o=E.join(At,n.command);return existsSync(o)?{command:o,args:n.args}:je(n.command)?{command:n.command,args:n.args}:null}getServerKey(e,t){return `${e}\0${t.join("\0")}`}toConnection(e,t){let n=`lsp-${t}-${this.nextId++}`;return {language:t,process:e.process,id:n,sendRequest:(o,s,a)=>e.client.sendRequest(o,s,a),sendNotification:(o,s)=>e.client.sendNotification(o,s)}}};});var me,$t=f(()=>{me=class{getBuildConfigManager(e,t){return null}getImportResolver(e,t){return null}};});var Ae,Dr=f(()=>{O();Ae=class{configPaths=[];parseCache=new Map;failedConfigFiles=new Set;initialized=false;isTypeScriptEnabled;isJavaScriptEnabled;isPathResolutionEnabled;projectRoot;constructor(e,t){this.projectRoot=e,this.isTypeScriptEnabled="typescript"in t,this.isJavaScriptEnabled="javascript"in t,this.isPathResolutionEnabled=this.isTypeScriptEnabled||this.isJavaScriptEnabled;}async initialize(){if(this.initialized)return this.configPaths;if(this.initialized=true,!this.isPathResolutionEnabled)return [];try{let e=[];if(this.isTypeScriptEnabled){let t=await findAll(this.projectRoot,{skip:n=>n==="node_modules"||n===".git",configNames:["tsconfig.json"]});e.push(...t);}if(this.isJavaScriptEnabled){let t=await findAll(this.projectRoot,{skip:n=>n==="node_modules"||n===".git",configNames:["jsconfig.json"]});e.push(...t);}return this.configPaths=e,this.configPaths}catch(e){return console.warn(`${T} Failed to discover config files:`,e),[]}}async getConfigForFile(e){if(this.parseCache.has(e))return this.parseCache.get(e);if(!this.isPathResolutionEnabled)return this.parseCache.set(e,null),null;try{let t=e.endsWith(".ts")||e.endsWith(".tsx")||e.endsWith(".d.ts"),n=e.endsWith(".js")||e.endsWith(".jsx")||e.endsWith(".mjs");if(t&&this.isTypeScriptEnabled){let o=await this.findAndParse(e,"tsconfig.json");return this.parseCache.set(e,o),o}if(n){if(this.isJavaScriptEnabled)try{let o=await this.findAndParse(e,"jsconfig.json");return this.parseCache.set(e,o),o}catch(o){if(this.isTypeScriptEnabled){let s=await this.findAndParse(e,"tsconfig.json");return this.parseCache.set(e,s),s}throw o}if(this.isTypeScriptEnabled){let o=await this.findAndParse(e,"tsconfig.json");return this.parseCache.set(e,o),o}}return this.parseCache.set(e,null),null}catch(t){return this.handleConfigError(e,t),this.parseCache.set(e,null),null}}isEnabled(){return this.isPathResolutionEnabled}getConfigPaths(){return [...this.configPaths]}getTsconfigPaths(){return this.getConfigPaths()}clearCache(){this.parseCache.clear(),this.failedConfigFiles.clear();}async findAndParse(e,t){let n=await find(e,{root:this.projectRoot,configName:t});return !n||this.failedConfigFiles.has(n)?null:parse(e,{root:this.projectRoot,configName:t})}handleConfigError(e,t){let n=t&&typeof t=="object"&&"tsconfigFile"in t?t.tsconfigFile:null;if(n&&!this.failedConfigFiles.has(n)){this.failedConfigFiles.add(n);let o=t instanceof Error?t.message:String(t);console.warn(`${T} Failed to parse ${n}: ${o}`),console.warn(`${T} Path alias resolution will be skipped for files using this config`);}else n||console.warn(`${T} Failed to parse config for ${e}:`,t instanceof Error?t.message:t);}};});var Dt,Si=f(()=>{ve();Dt=class{constructor(e,t){this.projectRoot=e;this.tsconfigResult=t;}workspacePackages={};initialized=false;async initialize(){if(this.initialized)return;this.initialized=true;let e={},t=await this.loadFromPackageJsonWorkspaces();Object.assign(e,t);let n=await this.loadFromTsConfig();Object.assign(e,n),this.workspacePackages=e;}async resolve(e){if(await this.initialize(),this.workspacePackages[e])return this.toProjectRelative(this.workspacePackages[e]);for(let[t,n]of Object.entries(this.workspacePackages))if(e.startsWith(t+"/")){let o=e.substring(t.length+1),s=await this.resolveSubPath(n,o);if(s)return this.toProjectRelative(s)}return null}async isWorkspacePackage(e){return await this.resolve(e)!==null}async loadFromTsConfig(){let e={};if(!this.tsconfigResult?.tsconfig?.compilerOptions?.paths)return e;let t=this.tsconfigResult.tsconfig.compilerOptions.paths,n=this.tsconfigResult.tsconfigFile?E.dirname(this.tsconfigResult.tsconfigFile):this.projectRoot;for(let[o,s]of Object.entries(t)){if(o.includes("*")||!Array.isArray(s))continue;let a=s[0];if(!a)continue;let l=E.resolve(n,a),c=await this.findEntryPoint(l);c&&(e[o]=c);}return e}async loadFromPackageJsonWorkspaces(){let e={};try{let t=E.join(this.projectRoot,"package.json"),n=await G.readFile(t,"utf-8"),s=JSON.parse(n).workspaces;if(!s)return e;let a=Array.isArray(s)?s:s.packages||[];for(let l of a){let c=await this.findWorkspaceDirs(l);for(let u of c){let p=await this.loadWorkspacePackage(u);p&&Object.assign(e,p);}}}catch{}return e}async findWorkspaceDirs(e){let t=[];if(e.endsWith("/*")){let n=e.slice(0,-2),o=E.join(this.projectRoot,n);try{let s=await G.readdir(o,{withFileTypes:!0});for(let a of s)a.isDirectory()&&t.push(E.join(o,a.name));}catch{}}else {let n=E.join(this.projectRoot,e);try{(await G.stat(n)).isDirectory()&&t.push(n);}catch{}}return t}async loadWorkspacePackage(e){try{let t=E.join(e,"package.json"),n=await G.readFile(t,"utf-8"),o=JSON.parse(n),s=o.name;if(!s)return null;let a=await this.findPackageEntryPoint(e,o);return a?{[s]:a}:null}catch{return null}}async findPackageEntryPoint(e,t){if(t.exports){let o=t.exports;if(typeof o=="string")return E.join(e,o);if(typeof o=="object"){let s=o["."]||o["./index"];if(typeof s=="string")return E.join(e,s);if(typeof s=="object"){let a=s.import||s.default||s.require;if(a)return E.join(e,a)}}}if(t.main)return E.join(e,t.main);let n=["src/index.ts","src/index.tsx","src/index.js","src/index.jsx","index.ts","index.tsx","index.js","index.jsx"];for(let o of n){let s=E.join(e,o);try{if((await G.stat(s)).isFile())return s}catch{}}return null}async findEntryPoint(e){let t=["index.ts","index.tsx","index.js","index.jsx","index.d.ts"];for(let n of t){let o=E.join(e,n);try{if((await G.stat(o)).isFile())return o}catch{}}try{if((await G.stat(e)).isFile())return e}catch{}return null}async resolveSubPath(e,t){let n=e.endsWith("index.ts")||e.endsWith("index.tsx")||e.endsWith("index.js")||e.endsWith("index.jsx")?E.dirname(e):E.dirname(e),o=[E.join(n,t+".ts"),E.join(n,t+".tsx"),E.join(n,t+".js"),E.join(n,t+".jsx"),E.join(n,t+".d.ts"),E.join(n,t,"index.ts"),E.join(n,t,"index.tsx"),E.join(n,t,"index.js"),E.join(n,t,"index.jsx")];for(let s of o)try{if((await G.stat(s)).isFile())return s}catch{}return null}toProjectRelative(e){let t=U(this.projectRoot,e);return t.startsWith("./")?t:`./${t}`}};});var ke,Or=f(()=>{ve();Si();ke=class{baseUrl=null;paths={};sourceDir;tsconfigDir;projectRoot;extensions;packageImports={};packageJsonDir=null;sourceFilePath;workspaceResolver;constructor(e,t){this.sourceFilePath=e,this.sourceDir=E.dirname(e),this.projectRoot=process.cwd(),this.workspaceResolver=new Dt(this.projectRoot,t);let n=e.toLowerCase(),o=n.endsWith(".ts")||n.endsWith(".tsx")||n.endsWith(".d.ts"),s=n.endsWith(".js")||n.endsWith(".jsx")||n.endsWith(".mjs")||n.endsWith(".cjs");if(o?this.extensions=[".ts",".tsx",".d.ts"]:s?this.extensions=[".js",".jsx",".mjs",".cjs"]:this.extensions=[".ts",".tsx",".d.ts"],!t?.tsconfigFile){this.tsconfigDir=this.sourceDir;return}this.tsconfigDir=E.dirname(t.tsconfigFile);let a=t.tsconfig?.compilerOptions;a&&(a.baseUrl&&(this.baseUrl=E.resolve(this.tsconfigDir,a.baseUrl)),a.paths&&typeof a.paths=="object"&&(this.paths=a.paths));}async resolve(e){if(e.startsWith("./")||e.startsWith("../")){let n=E.resolve(this.sourceDir,e),o=await this.findFileWithExtensions(n);return o?this.toProjectRelative(o):e}if(e.startsWith("#")){let n=await this.resolveWithPackageImports(e);return n?this.toProjectRelative(n):e}let t=await this.workspaceResolver.resolve(e);if(t)return t;if(!e.startsWith("@")&&!e.startsWith("~")&&(!e.includes("/")||!this.baseUrl))return e;if(Object.keys(this.paths).length>0){let n=await this.resolveWithPaths(e);if(n)return this.toProjectRelative(n)}if(this.baseUrl){let n=await this.resolveWithBaseUrl(e);if(n)return this.toProjectRelative(n)}return e}toProjectRelative(e){let t=U(this.projectRoot,e);return t.startsWith("./")?t:`./${t}`}async resolveWithPaths(e){for(let[t,n]of Object.entries(this.paths)){let o=this.matchPathPattern(e,t);if(o!==null)for(let s of n){let a=await this.trySubstitution(e,t,s,o);if(a)return a}}return null}matchPathPattern(e,t){if(!t.includes("*"))return e===t?"":null;let[n,o]=t.split("*");if(!e.startsWith(n)||o&&!e.endsWith(o))return null;let s=n.length,a=o?e.length-o.length:e.length;return e.substring(s,a)}async trySubstitution(e,t,n,o){let s=n.replaceAll("*",o),a=E.resolve(this.tsconfigDir,s);return await this.findFileWithExtensions(a)}async resolveWithBaseUrl(e){if(!this.baseUrl)return null;let t=E.resolve(this.baseUrl,e);return await this.findFileWithExtensions(t)}async findFileWithExtensions(e){let t=this.extensions.some(a=>e.endsWith(a));if(t&&await this.fileExists(e))return await this.resolveSymlink(e);let n=[".js",".jsx",".mjs",".cjs"],o=n.some(a=>e.endsWith(a)),s=e;if(o&&!t){for(let a of n)if(e.endsWith(a)){s=e.slice(0,-a.length);break}}if(!t)for(let a of this.extensions){let l=s+a;if(await this.fileExists(l))return await this.resolveSymlink(l)}for(let a of this.extensions){let l=E.join(s,`index${a}`);if(await this.fileExists(l))return await this.resolveSymlink(l)}return null}async fileExists(e){try{return (await G.stat(e)).isFile()}catch{return false}}async resolveSymlink(e){try{return await G.realpath(e)}catch{return e}}async findPackageJson(e){let t=e;for(;t.startsWith(this.projectRoot);){let n=E.join(t,"package.json");try{if((await G.stat(n)).isFile())return n}catch{}let o=E.dirname(t);if(o===t)break;t=o;}return null}async loadPackageImports(){if(this.packageJsonDir!==null)return;let e=await this.findPackageJson(this.sourceDir);if(!e){this.packageJsonDir="";return}try{let t=await G.readFile(e,"utf-8"),n=JSON.parse(t);this.packageJsonDir=E.dirname(e),n.imports&&typeof n.imports=="object"&&(this.packageImports=n.imports);}catch{this.packageJsonDir="";}}async resolveWithPackageImports(e){if(await this.loadPackageImports(),!this.packageJsonDir||Object.keys(this.packageImports).length===0)return null;for(let[t,n]of Object.entries(this.packageImports)){let o=this.matchPathPattern(e,t);if(o!==null){if(typeof n=="string"){let s=await this.tryPackageImportSubstitution(n,o);if(s)return s}if(Array.isArray(n)){for(let s of n)if(typeof s=="string"){let a=await this.tryPackageImportSubstitution(s,o);if(a)return a}}}}return null}async tryPackageImportSubstitution(e,t){if(!this.packageJsonDir)return null;let n=e.replaceAll("*",t),o=E.resolve(this.packageJsonDir,n);return await this.findFileWithExtensions(o)}};});var Ot,wi=f(()=>{$t();Dr();Or();Ot=class extends me{language="typescript";extensions=[".ts",".tsx",".d.ts"];getBuildConfigManager(e,t){return new Ae(e,t)}getImportResolver(e,t){return new ke(e,t)}};});var Mt,Ci=f(()=>{$t();Dr();Or();Mt=class extends me{language="javascript";extensions=[".js",".jsx",".mjs",".cjs"];getBuildConfigManager(e,t){return new Ae(e,t)}getImportResolver(e,t){return new ke(e,t)}};});async function ge(i,e,t,n,o,s=[]){let a=await t.resolve(i),l=xi(i,a),c=o(i,a,l),u=l?void 0:Tt(a);n[e.toString()]={source:i,resolvedPath:u,isExternal:l,importType:c,specifiers:s};}function xi(i,e){return i===e?true:!(!e.startsWith(".")&&!e.startsWith("/")||e.startsWith("./")||e.startsWith("../"))}var Mr,Ze=f(()=>{ve();Mr=(i,e,t)=>t?i.startsWith("node:")?"builtin":"external":i.startsWith("./")||i.startsWith("../")?"relative":i.startsWith("@")?"workspace":"alias";});async function xl(i,e,t,n){let o=i.childForFieldName("name");if(!o)return;let s,a;if(o.type==="aliased_import"){let l=o.childForFieldName("name"),c=o.childForFieldName("alias");s=l?l.text:o.text,a={local:c?c.text:s.split(".")[0],original:s,isDefault:false,isNamespace:false};}else s=o.text,a={local:s.split(".")[0],original:s,isDefault:false,isNamespace:false};await ge(s,i.startPosition.row,e,t,n,[a]);}function El(i,e){if(!e)return [];let t=[],n=i.childForFieldName("name");if(n){if(n.type==="aliased_import"){let s=n.childForFieldName("name"),a=n.childForFieldName("alias");s&&t.push({local:a?a.text:s.text,original:s.text,isDefault:false,isNamespace:false});}else t.push({local:n.text,original:n.text,isDefault:false,isNamespace:false});return t}let o=false;for(let s=0;s<i.childCount;s++){let a=i.child(s);if(a){if(a.type==="import"){o=true;continue}if(o){if(a.type==="dotted_name"||a.type==="identifier")t.push({local:a.text,original:a.text,isDefault:false,isNamespace:false});else if(a.type==="aliased_import"){let l=a.childForFieldName("name"),c=a.childForFieldName("alias");l&&t.push({local:c?c.text:l.text,original:l.text,isDefault:false,isNamespace:false});}}}}return t}async function _l(i,e,t,n){let o,s=i.childForFieldName("module_name");if(s)o=s.text;else {let l="";for(let c=0;c<i.childCount;c++){let u=i.child(c);if(u){if(u.type==="relative_import"){l=u.text;break}(u.type==="."||u.type==="import_prefix")&&(l+=u.text);}}o=l||".";}let a=El(i,!!s);await ge(o,i.startPosition.row,e,t,n,a);}async function Pl(i,e,t,n){await ge("__future__",i.startPosition.row,e,t,n,[]);}function Ur(){return {language:"python",handlers:new Map([["import_statement",xl],["import_from_statement",_l],["future_import_statement",Pl]]),classifyImportType:Cl}}var Cl,Ut=f(()=>{Xe();Ze();Xe();Cl=(i,e,t)=>{if(t)return "external";if(/^\.+/.test(i))return "relative";let n=i.split(".")[0];return qe.has(n)?"builtin":"alias"};});var Gt,Ei=f(()=>{Ut();Gt=class{sourceDir;projectRoot;constructor(e,t){this.sourceDir=E.dirname(e),this.projectRoot=t;}async resolve(e){let t=e.split(".")[0];if(qe.has(t))return e;if(e.startsWith("."))return this.resolveRelative(e);let n=e.replace(/\./g,"/"),o=await this.tryResolveFile(E.resolve(this.projectRoot,n));return o?E.relative(this.projectRoot,o).replace(/\\/g,"/"):e}async resolveRelative(e){let t=0;for(;t<e.length&&e[t]===".";)t++;let n=e.slice(t),o=t<=1?"":"../".repeat(t-1),s=n?o+n.replace(/\./g,"/"):o.slice(0,-1)||".",a=E.resolve(this.sourceDir,s),l=await this.tryResolveFile(a);return l?E.relative(this.projectRoot,l).replace(/\\/g,"/"):e}async tryResolveFile(e){let t=[`${e}.py`,`${e}.pyi`,`${e}.pyw`,E.join(e,"__init__.py"),E.join(e,"__init__.pyi")];for(let n of t)try{return await Bt.promises.access(n,Bt.constants.F_OK),n}catch{continue}return null}};});var zt,_i=f(()=>{$t();Ei();zt=class extends me{language="python";extensions=[".py",".pyi",".pyw"];getBuildConfigManager(e,t){return null}getImportResolver(e,t){return new Gt(e,process.cwd())}};});function tt(i){return Rl[i]??i.charAt(0).toUpperCase()+i.slice(1)}var Rl,et,Wt,Ht=f(()=>{wi();Ci();_i();Rl={bash:"Bash",c:"C","c-sharp":"C#",cpp:"C++",go:"Go",java:"Java",javascript:"JavaScript",json:"JSON",php:"PHP",python:"Python",ruby:"Ruby",typescript:"TypeScript"};et={bash:[".sh",".bash"],c:[".c",".h"],"c-sharp":[".cs"],cpp:[".cpp",".cc",".cxx",".hpp",".hh",".hxx"],go:[".go"],java:[".java"],javascript:[".js",".jsx"],json:[".json"],php:[".php"],python:[".py",".pyi",".pyw"],ruby:[".rb"],typescript:[".ts",".tsx"]},Wt=class{constructor(e){this.config=e;this.registerPlugin(new Ot),this.registerPlugin(new Mt),this.registerPlugin(new zt);}plugins=new Map;registerPlugin(e){this.plugins.set(e.language,e);}getPlugin(e){return this.plugins.get(e)}javascript={language:()=>Il,fileExtensions:()=>this.config?.languages.javascript?.fileExtensions??et.javascript};typescript={language:()=>Tl.typescript,fileExtensions:()=>this.config?.languages.typescript?.fileExtensions??et.typescript};python={language:()=>Nl,fileExtensions:()=>this.config?.languages.python?.fileExtensions??et.python};php;json;java;go;cpp;"c-sharp";c;bash;ruby};});function Fe(i,e,t=32){let n=i.parent,o=0;for(;n!==null&&o<t;){if(e(n))return n;n=n.parent,o++;}return null}var Kt,Gr=f(()=>{Kt=Object.freeze(new Set(["program","statement_block","function_declaration","function_expression","generator_function_declaration","generator_function","arrow_function","method_definition","class_body"]));});function Br(i,e){if(i.type==="jsx_opening_element"||i.type==="jsx_self_closing_element"||i.type==="jsx_closing_element"){let t=i.childForFieldName("name");t!==null&&jl(t,e);}for(let t of i.namedChildren)t&&Br(t,e);}function jl(i,e){if(i.type==="identifier"||i.type==="type_identifier"){e.set(Se(i.startPosition.row,i.startPosition.column),"call");return}if(i.type==="member_expression"||i.type==="nested_identifier"){let t=i.childForFieldName("property");t!==null&&e.set(Se(t.startPosition.row,t.startPosition.column),"call");}}var Pi=f(()=>{rt();});function $e(i,e){i.rootNode&&(Ni(i.rootNode,e),Br(i.rootNode,e));}function Ni(i,e){if(Ll.has(i.type)){let t=Al(i);t!==null&&e.set(Se(i.startPosition.row,i.startPosition.column),t);}for(let t of i.namedChildren)t&&Ni(t,e);}function Al(i){if(Fl(i))return "declaration";if(Hl(i))return "read";if(zl(i))return "type";let e=Fe(i,t=>t.type==="decorator");return e!==null&&Ol(i,e)?"call":Dl(i)?"instantiate":$l(i)?"call":Ml(i)||Ul(i)||Gl(i)||Zl(i)||Ql(i)?"write":Kl(i)?"import-use":"read"}function Fl(i){let e=i.parent;return e===null?false:!!(kl.has(e.type)&&(e.childForFieldName("name")===i||e.childForFieldName("property")===i)||(e.type==="required_parameter"||e.type==="optional_parameter")&&e.childForFieldName("pattern")===i||e.type==="import_specifier"&&(e.childForFieldName("name")===i||e.childForFieldName("alias")===i)||e.type==="namespace_import"||e.type==="import_clause"&&e.namedChild(0)===i&&i.type==="identifier"||e.type==="catch_clause"&&e.childForFieldName("parameter")===i||e.type==="enum_body")}function $l(i){let e=i.parent;if(e===null)return false;if(e.type==="call_expression"&&e.childForFieldName("function")===i)return true;if(e.type==="member_expression"&&e.childForFieldName("property")===i){let t=e.parent;if(t!==null&&t.type==="call_expression"&&t.childForFieldName("function")===e)return true}return false}function Dl(i){let e=i.parent;if(e===null)return false;if(e.type==="new_expression"&&e.childForFieldName("constructor")===i)return true;if(e.type==="member_expression"&&e.childForFieldName("property")===i){let t=e.parent;if(t!==null&&t.type==="new_expression"&&t.childForFieldName("constructor")===e)return true}return false}function Ol(i,e){let t=e.namedChild(0);if(t===null)return false;if(t===i)return true;if(t.type==="call_expression"){let n=t.childForFieldName("function");if(n===i||n?.type==="member_expression"&&n.childForFieldName("property")===i)return true}return t.type==="member_expression"&&t.childForFieldName("property")===i}function Ml(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="unary_expression")return t.child(0)?.type==="delete";if(t.type==="member_expression"&&t.childForFieldName("object")===e||Kt.has(t.type))return false;e=t;}return false}function Ul(i){let e=i.parent;if(e?.type==="update_expression"&&e.childForFieldName("argument")===i)return true;if(e?.type==="member_expression"&&e.childForFieldName("property")===i){let t=e.parent;if(t?.type==="update_expression"&&t.childForFieldName("argument")===e)return true}return false}function Gl(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if((t.type==="assignment_expression"||t.type==="augmented_assignment_expression")&&t.childForFieldName("left")===e)return true;if(t.type==="member_expression"&&t.childForFieldName("object")===e||t.type==="subscript_expression"&&t.childForFieldName("object")!==e||Kt.has(t.type))return false;e=t;}return false}function zl(i){let e=i.parent,t=i;for(;e!==null;){if(e.type==="as_expression"||e.type==="satisfies_expression"){let n=e.namedChild(1);return n===null?false:n===t||Wl(n,i)}if(Bl.has(e.type))return true;if(Kt.has(e.type))return false;t=e,e=e.parent;}return false}function Wl(i,e){let t=e;for(;t!==null;){if(t===i)return true;t=t.parent;}return false}function Hl(i){return Fe(i,t=>t.type==="type_query")!==null}function Kl(i){let e=i.parent;if(e?.type!=="member_expression"||e.childForFieldName("object")!==i)return false;let t=i.text,n=Yl(i);return Xl(n,t)?!Jl(i,t):false}function Jl(i,e){let t=i.parent;for(;t!==null;){if(Vl.has(t.type)&&ql(t,e))return true;t=t.parent;}return false}function ql(i,e){for(let t of i.namedChildren){if(t.type==="lexical_declaration"||t.type==="variable_declaration")for(let n of t.namedChildren){if(n.type!=="variable_declarator")continue;if(n.childForFieldName("name")?.text===e)return true}if(t.type==="formal_parameters")for(let n of t.namedChildren){if(n.type!=="required_parameter"&&n.type!=="optional_parameter")continue;let o=n.childForFieldName("pattern");if(o?.type==="identifier"&&o.text===e)return true}}return false}function Yl(i){let e=i;for(;e.parent!==null;)e=e.parent;return e}function Xl(i,e){for(let t of i.descendantsOfType("namespace_import")){let n=t.namedChild(0);if(n!==null&&n.text===e)return true}return false}function Ql(i){let e=i.parent;return e?.type==="for_in_statement"&&e.childForFieldName("left")===i}function Zl(i){let e=i.parent;if(e===null||!Ii.has(e.type)||e.type==="pair_pattern"&&e.childForFieldName("key")===i||(e.type==="object_assignment_pattern"||e.type==="assignment_pattern")&&e.namedChild(0)!==i)return false;let t=e;for(;t!==null;){let n=t.parent;if(n===null)return false;if(n.type==="variable_declarator"&&n.childForFieldName("name")===t||(n.type==="assignment_expression"||n.type==="augmented_assignment_expression")&&n.childForFieldName("left")===t||(n.type==="required_parameter"||n.type==="optional_parameter")&&n.childForFieldName("pattern")===t||n.type==="formal_parameters"||n.type==="for_in_statement"&&n.childForFieldName("left")===t)return true;if(!Ii.has(n.type))return false;t=n;}return false}var Ll,kl,Bl,Vl,Ii,Vt=f(()=>{rt();Gr();Pi();Ll=Object.freeze(new Set(["identifier","type_identifier","property_identifier","private_property_identifier","shorthand_property_identifier","shorthand_property_identifier_pattern"]));kl=Object.freeze(new Set(["variable_declarator","function_declaration","function_signature","generator_function_declaration","class_declaration","abstract_class_declaration","interface_declaration","type_alias_declaration","enum_declaration","enum_assignment","method_signature","abstract_method_signature","method_definition","public_field_definition","field_definition","property_signature"]));Bl=Object.freeze(new Set(["type_annotation","type_arguments","type_parameter","type_parameters","type_alias_declaration","interface_declaration","generic_type","type_predicate","type_query","conditional_type","union_type","intersection_type","tuple_type","mapped_type_clause","implements_clause","extends_type_clause"]));Vl=Object.freeze(new Set(["statement_block","function_declaration","function_expression","arrow_function","method_definition","generator_function","generator_function_declaration","for_statement","for_in_statement"]));Ii=Object.freeze(new Set(["object_pattern","array_pattern","pair_pattern","rest_pattern","object_assignment_pattern","assignment_pattern"]));});function Ti(i,e){$e(i,e);}var Ri=f(()=>{Vt();});function ji(i,e){$e(i,e);}var Li=f(()=>{Vt();});function Ai(i,e){if(!i.rootNode)return;let t=Sc(i.rootNode);ki(i.rootNode,e,t);}function ki(i,e,t){if(ec.has(i.type)){let n=tc(i,t);n!==null&&e.set(Se(i.startPosition.row,i.startPosition.column),n);}for(let n of i.namedChildren)n&&ki(n,e,t);}function tc(i,e){if(rc(i))return "declaration";if(oc(i))return "read";if(ic(i))return "declaration";if(sc(i))return "type";let t=Fe(i,n=>n.type==="decorator");return t!==null&&ac(i,t)||lc(i)?"call":cc(i)||pc(i)||uc(i)||mc(i)||fc(i)?"write":hc(i,e)?"import-use":"read"}function rc(i){let e=i.parent;if(e===null)return false;if((e.type==="function_definition"||e.type==="class_definition")&&e.childForFieldName("name")===i||e.type==="parameters"||e.type==="lambda_parameters"||(e.type==="typed_parameter"||e.type==="typed_default_parameter"||e.type==="default_parameter")&&e.namedChild(0)===i)return true;if(e.type==="list_splat_pattern"||e.type==="dictionary_splat_pattern"){let t=e.parent;if(t?.type==="parameters"||t?.type==="lambda_parameters")return true}return !!(e.type==="as_pattern_target"||nc(i))}function nc(i){let e=i.parent;if(e?.type!=="type")return false;let t=e.parent;return t?.type!=="type_alias_statement"?false:t.namedChild(0)===e}function ic(i){let e=i.parent;for(;e!==null;){if(e.type==="import_statement"||e.type==="import_from_statement")return true;if(zr.has(e.type))return false;e=e.parent;}return false}function oc(i){let e=i.parent;return e?.type==="global_statement"||e?.type==="nonlocal_statement"}function sc(i){return Fe(i,t=>t.type==="type")!==null}function ac(i,e){let t=e.namedChild(0);if(t===null)return false;if(t===i)return true;if(t.type==="call"){let n=t.childForFieldName("function");if(n===i||n?.type==="attribute"&&n.childForFieldName("attribute")===i)return true}return t.type==="attribute"&&t.childForFieldName("attribute")===i}function lc(i){let e=i.parent;if(e?.type==="call"&&e.childForFieldName("function")===i)return true;if(e?.type==="attribute"&&e.childForFieldName("attribute")===i){let t=e.parent;if(t?.type==="call"&&t.childForFieldName("function")===e)return true}return false}function cc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="delete_statement")return true;if(t.type==="attribute"&&t.childForFieldName("object")===e||zr.has(t.type))return false;e=t;}return false}function pc(i){let e=i.parent;if(e?.type==="augmented_assignment"&&e.childForFieldName("left")===i)return true;if(e?.type==="attribute"&&e.childForFieldName("attribute")===i){let t=e.parent;if(t?.type==="augmented_assignment"&&t.childForFieldName("left")===e)return true}return false}function uc(i){let e=i.parent;return e?.type==="named_expression"&&e.childForFieldName("name")===i}function mc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="assignment"&&t.childForFieldName("left")===e)return true;if(t.type==="attribute"&&t.childForFieldName("object")===e||t.type==="subscript"&&t.childForFieldName("value")!==e)return false;if(dc.has(t.type)){e=t;continue}if(zr.has(t.type))return false;e=t;}return false}function fc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if((t.type==="for_statement"||t.type==="for_in_clause")&&t.childForFieldName("left")===e)return true;if(!gc.has(t.type))return false;e=t;}return false}function hc(i,e){let t=i.parent;if(t?.type!=="attribute"||t.childForFieldName("object")!==i)return false;let n=i.text;return e.has(n)?!vc(i,n):false}function vc(i,e){let t=i.parent;for(;t!==null;){if(yc.has(t.type)&&bc(t,e))return true;t=t.parent;}return false}function bc(i,e){for(let t of i.namedChildren){if(t.type==="expression_statement"){let n=t.namedChild(0);if(n?.type==="assignment"){let o=n.childForFieldName("left");if(o?.type==="identifier"&&o.text===e)return true}}if(t.type==="parameters"){for(let n of t.namedChildren)if(n.type==="identifier"&&n.text===e||(n.type==="typed_parameter"||n.type==="typed_default_parameter"||n.type==="default_parameter")&&n.namedChild(0)?.type==="identifier"&&n.namedChild(0)?.text===e)return true}}return false}function Sc(i){let e=new Set;for(let t of i.descendantsOfType("import_statement"))for(let n of t.namedChildren)if(n.type==="dotted_name"&&e.add(n.text),n.type==="aliased_import"){let o=n.childForFieldName("alias");o&&e.add(o.text);}return e}var ec,zr,dc,gc,yc,Fi=f(()=>{rt();Gr();ec=Object.freeze(new Set(["identifier"])),zr=Object.freeze(new Set(["module","block","function_definition","class_definition","lambda"]));dc=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern","list_splat_pattern"]));gc=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern"]));yc=Object.freeze(new Set(["block","function_definition","class_definition","lambda"]));});function Di(i,e){let t=new Map;switch(e){case "typescript":$e(i,t);break;case "tsx":Ti(i,t);break;case "javascript":ji(i,t);break;case "python":Ai(i,t);break}return t}function Se(i,e){return `${i}:${e}`}var $i,rt=f(()=>{Vt();Ri();Li();Fi();$i=Object.freeze(new Set(["typescript","javascript","python"]));});function xc(i,e){return $i.has(i)?i==="typescript"?e.toLowerCase().endsWith(".tsx")?"tsx":"typescript":i:null}function Ec(i){let e=[];for(let[t,n]of i.entries()){let o=t.indexOf(":");if(o<0)continue;let s=Number(t.slice(0,o)),a=Number(t.slice(o+1));!Number.isFinite(s)||!Number.isFinite(a)||e.push({line:s,column:a,referenceType:n});}return e.sort((t,n)=>t.line-n.line||t.column-n.column),e}var Jt,Ui=f(()=>{rt();re();Jt=class{constructor(e){this.langRegistry=e;}async parseFile(e,t){let n=this.langRegistry[t]?.language;if(!n)throw new Error(`Unsupported language: ${t}`);let o=await n();if(!o)throw new Error(`Failed to load language: ${t}`);t==="typescript"&&e.toLowerCase().endsWith(".tsx")&&(o=Tl.tsx);let s=new wc;s.setLanguage(o);let a=await S.getFileStats(e),l=10*1024*1024,c,u;if(a.size<=l){let g=await S.readFile(e);u=g;let h={bufferSize:1024*1024};c=s.parse(g,void 0,h);}else c=await this.parseWithStream(s,e,a.size);let p=xc(t,e),d=p===null?[]:Ec(Di(c,p));return {tree:c,classificationMap:{filePath:e,entries:d},content:u}}async parseWithStream(e,t,n){let o=null;try{o=await G.open(t,"r");let s=o.fd,a=64*1024,l=Buffer.alloc(a),c=0;return e.parse(p=>{if(n>50*1024*1024){let m=Math.round(p/n*100);m>c+10&&(process.stderr.write(` Parsing large file: ${m}%...
52
- `),c=m);}let d=Bt.readSync(s,l,0,a,p);return d===0?null:l.subarray(0,d).toString("utf-8")})}catch(s){if(o)try{await o.close();}catch(a){process.stderr.write(`Warning: Failed to close file handle for ${t}: ${String(a)}
53
- `);}throw s}finally{if(o)try{await o.close();}catch{}}}};});var qt,Bi=f(()=>{re();ve();O();qt=class{rootPath;constructor(e){this.rootPath=e||process.cwd();}async scanFiles(e){let t=Gi();return await this.loadGitignoreRules(t,this.rootPath),e.exclude&&e.exclude.length>0&&t.add(e.exclude),(await this.walkDirectory(this.rootPath)).filter(s=>!t.ignores(s.relativePath)&&this.matchesLanguageExtension(s,e.languages))}async scanSpecificFiles(e,t){let n=[],o=null;t.exclude&&t.exclude.length>0&&(o=Gi().add(t.exclude));let s=await G__default.realpath(this.rootPath);for(let a of e)try{let l=E__default.isAbsolute(a)?a:E__default.join(this.rootPath,a),c=await G__default.lstat(l);if(c.isSymbolicLink()){let u=await G__default.realpath(l);if(!u.startsWith(s+E__default.sep)&&u!==s){console.warn(`${T} Skipping symlink pointing outside project: ${a} -> ${u}`);continue}let p=await G__default.stat(l);if(!p.isFile())continue;let d=U(this.rootPath,l);if(o&&o.ignores(d))continue;let m=this.detectLanguage(d,t.languages);if(!m)continue;n.push({path:l,relativePath:d,language:m,size:p.size});}else if(c.isFile()){let u=U(this.rootPath,l);if(o&&o.ignores(u))continue;let p=this.detectLanguage(u,t.languages);if(!p)continue;n.push({path:l,relativePath:u,language:p,size:c.size});}}catch{console.warn(`${T} Skipping inaccessible file: ${a}`);}return n}async loadGitignoreRules(e,t){let n=[],o=t;for(;;){let s=E__default.join(o,".gitignore");await S.fileIsReadable(s)&&n.unshift(s);let a=E__default.dirname(o);if(a===o)break;o=a;let l=E__default.join(o,".git");if(await S.directoryExists(l)){let c=E__default.join(o,".gitignore");await S.fileIsReadable(c)&&!n.includes(c)&&n.unshift(c);break}}for(let s of n)try{let a=await S.readFile(s);e.add(a);}catch{console.warn(`${T} Failed to load .gitignore: ${s}`);}e.add(".git");}async walkDirectory(e,t,n,o){let s=[],a=t||e,l=n||await G__default.realpath(this.rootPath),c=o||new Set([l]);try{let u=(await G__default.readdir(e,{withFileTypes:!0})).map(p=>(p.name=p.name.normalize("NFC"),p)).sort((p,d)=>p.name<d.name?-1:p.name>d.name?1:0);for(let p of u){let d=E__default.join(e,p.name),m=U(a,d);if(p.isDirectory()){if(p.name.startsWith("."))continue;let g=await this.walkDirectory(d,a,l,c);s.push(...g);}else if(p.isFile()){let g=await G__default.stat(d);s.push({path:d,relativePath:m,language:"",size:g.size});}else if(p.isSymbolicLink())try{let g=await G__default.realpath(d);if(!g.startsWith(l+E__default.sep)&&g!==l){console.warn(`${T} Skipping symlink pointing outside project: ${d} -> ${g}`);continue}let h=await G__default.stat(d);if(h.isDirectory()){if(p.name.startsWith(".")||c.has(g))continue;c.add(g);let b=await this.walkDirectory(d,a,l,c);s.push(...b);}else h.isFile()&&s.push({path:d,relativePath:m,language:"",size:h.size});}catch{console.warn(`${T} Skipping invalid symlink: ${d}`);}}}catch(u){console.error(`${q} Error walking directory ${e}:`,u);}return s}matchesLanguageExtension(e,t){let n=E__default.extname(e.path).toLowerCase();for(let[o,s]of Object.entries(t))if(s.fileExtensions.includes(n))return e.language=o,true;return false}detectLanguage(e,t){let n=E__default.extname(e).toLowerCase();for(let[o,s]of Object.entries(t))if(s.fileExtensions.includes(n))return o;return null}};});var _c,Pc,Ic,zi,Wi=f(()=>{Xe();_c=z.object({local:z.string(),original:z.string().optional(),isDefault:z.boolean(),isNamespace:z.boolean()}),Pc=z.object({source:z.string().min(1,"Import source cannot be empty"),resolvedPath:z.string().optional(),isExternal:z.boolean(),importType:z.enum(["relative","workspace","alias","external","builtin"]),specifiers:z.array(_c).optional()}),Ic=z.record(z.string(),Pc),zi=z.object({file:z.string().min(1,"File path cannot be empty").max(1e3,"File path too long"),language:z.string().regex(/^(bash|c|c-sharp|cpp|go|java|javascript|json|php|python|ruby|typescript)$/,"Invalid language identifier"),commit:z.string().regex(/^[a-f0-9]{40}$/,"Invalid git commit hash"),timestamp:z.string().datetime({message:"Invalid ISO timestamp"}),ast:z.string().min(1,"AST data cannot be empty").max(1e7,"AST data exceeds 10MB limit"),importResolutions:Ic.optional(),classificationMap:Cr.optional()});});var Tc,Yt,Vi=f(()=>{Pr();Tc=promisify(Wr__default.gunzip),Yt=class{*serializeASTChunks(e){if(yield "{",yield `"type":"${e.type}"`,yield `,"startPosition":${JSON.stringify(e.startPosition)}`,yield `,"endPosition":${JSON.stringify(e.endPosition)}`,e.fieldName!==void 0&&(yield `,"fieldName":"${e.fieldName}"`),e.text!==void 0&&(yield `,"text":${JSON.stringify(e.text)}`),e.children&&e.children.length>0){yield ',"children":[';for(let t=0;t<e.children.length;t++)t>0&&(yield ","),yield*this.serializeASTChunks(e.children[t]);yield "]";}yield "}";}async compressStream(e){let t=[],n=Wr__default.createGzip();n.on("data",a=>t.push(a));let o=new Promise((a,l)=>{n.on("end",a),n.on("error",l);}),s=Readable.from(e);return await pipeline(s,n),await o,_r(Buffer.concat(t)).toString("base64")}async compress(e){let t=[],n=Wr__default.createGzip();n.on("data",a=>t.push(a));let o=new Promise((a,l)=>{n.on("end",a),n.on("error",l);}),s=Readable.from(this.serializeASTChunks(e));return await pipeline(s,n),await o,_r(Buffer.concat(t)).toString("base64")}async decompress(e){let t=Buffer.from(e,"base64"),n=await Tc(t);return JSON.parse(n.toString("utf-8"))}};});function qi(i){let n=i>=5e4?27e5:i>=1e4?18e5:9e5,o=process.env.CONSTELLATION_AST_WAIT_MAX_MS,s=n;if(o!==void 0&&o!==""){let a=Number(o);Number.isFinite(a)&&Number.isInteger(a)&&a>0?s=a:Ji||(process.stderr.write(`[constellation] Ignoring invalid CONSTELLATION_AST_WAIT_MAX_MS=${o}; using default tier cap.
54
- `),Ji=true);}return Math.min(12e4+i*1e3,s)}var Ji,Yi=f(()=>{Ji=false;});var Hr,Xt=f(()=>{Hr=new Set(["ACCESS_KEY_MISSING","AUTH_FAILURE","PROJECT_NOT_REGISTERED","PROJECT_INACTIVE","INVALID_PROJECT_ID","DIRTY_WORKTREE","CONCURRENT_INDEXING","GIT_SYNC_FAILURE","BRANCH_NOT_CONFIGURED","ENRICHMENT_FAILED"]);});function De(i,e){let t=e??i;return {line:t.startPosition.row+1,column:t.startPosition.column}}function Oe(i){return i?i.text:null}function Zi(){return {language:"javascript",handlers:new Map(Qi)}}function eo(){return {language:"typescript",handlers:new Map([...Qi,["interface_declaration",Lc],["public_field_definition",Xi],["property_signature",Xi]])}}var Rc,jc,Lc,Ac,Xi,kc,Qi,to=f(()=>{Rc=(i,e)=>{let t=i.childForFieldName("name"),n=Oe(t);n&&e.symbols.push({name:n,kind:"function",...De(i,t)});},jc=(i,e)=>{let t=i.childForFieldName("name"),n=Oe(t);if(n)return e.symbols.push({name:n,kind:"class",...De(i,t)}),{...e,enclosingType:n}},Lc=(i,e)=>{let t=i.childForFieldName("name"),n=Oe(t);if(n)return e.symbols.push({name:n,kind:"interface",...De(i,t)}),{...e,enclosingType:n}},Ac=(i,e)=>{let t=i.childForFieldName("name"),n=Oe(t);n&&e.symbols.push({name:n,kind:"method",...De(i,t)});},Xi=(i,e)=>{let t=i.childForFieldName("name"),n=Oe(t);n&&e.symbols.push({name:n,kind:"property",...De(i,t)});},kc=(i,e)=>{let t=i.childForFieldName("name"),n=Oe(t);if(!n)return;let o=i.childForFieldName("value"),s=o?.type==="arrow_function"||o?.type==="function"||o?.type==="function_expression";e.symbols.push({name:n,kind:s?"function":"variable",...De(i,t)});},Qi=[["function_declaration",Rc],["class_declaration",jc],["method_definition",Ac],["variable_declarator",kc]];});function Kr(i){return {line:i.startPosition.row+1,column:i.startPosition.column}}function ro(){return {language:"python",handlers:new Map([["function_definition",Fc],["class_definition",$c],["assignment",Dc]])}}var Fc,$c,Dc,no=f(()=>{Fc=(i,e)=>{let t=i.childForFieldName("name");if(!t)return;let n=e.enclosingType?"method":"function";e.symbols.push({name:t.text,kind:n,...Kr(t)});},$c=(i,e)=>{let t=i.childForFieldName("name");if(t)return e.symbols.push({name:t.text,kind:"class",...Kr(t)}),{...e,enclosingType:t.text}},Dc=(i,e)=>{let t=i.childForFieldName("left");if(!t||t.type!=="identifier")return;let n=e.enclosingType?"property":"variable";e.symbols.push({name:t.text,kind:n,...Kr(t)});};});var io,oo=f(()=>{to();no();io=[Zi(),eo(),ro()];});var Qt,so=f(()=>{oo();Qt=class{languageHandlers;constructor(e){this.languageHandlers=new Map;for(let t of e??io)this.languageHandlers.set(t.language,t.handlers);}extract(e,t){let n=this.languageHandlers.get(t);if(!n)return [];let o={symbols:[]};return this.walk(e.rootNode,o,n),o.symbols}walk(e,t,n){let s=n.get(e.type)?.(e,t)??t;for(let a=0;a<e.childCount;a++){let l=e.child(a);l&&this.walk(l,s,n);}}};});function Oc(i){let e=Math.max(0,i)/1e3;if(e<60)return `(${e.toFixed(1)}s)`;let t=Math.floor(e/60),n=Math.floor(e%60);return `(${t}m ${n}s)`}function ao(){let i=performance.now();return {elapsed:()=>Oc(performance.now()-i),reset:()=>{i=performance.now();},ms:()=>performance.now()-i}}var lo=f(()=>{});function Vr(i){if(typeof i=="string")return i;if(i instanceof Error)return i.message;if(typeof i=="object"&&i!==null)try{return JSON.stringify(i)}catch{return String(i)}return String(i)}var er,co=f(()=>{Xt();er=class{entries=[];originalLog;originalWarn;originalError;capturing=false;start(){this.capturing||(this.capturing=true,this.originalLog=console.log,this.originalWarn=console.warn,this.originalError=console.error,console.log=(...e)=>{this.entries.push({level:"info",message:stripVTControlCharacters(e.map(Vr).join(" ")),timestamp:new Date().toISOString()}),this.originalLog.apply(console,e);},console.warn=(...e)=>{this.entries.push({level:"warn",message:stripVTControlCharacters(e.map(Vr).join(" ")),timestamp:new Date().toISOString()}),this.originalWarn.apply(console,e);},console.error=(...e)=>{this.entries.push({level:"error",message:stripVTControlCharacters(e.map(Vr).join(" ")),timestamp:new Date().toISOString()}),this.originalError.apply(console,e);});}stop(){this.capturing&&(this.capturing=false,console.log=this.originalLog,console.warn=this.originalWarn,console.error=this.originalError);}log(e){this.capture("info",e);}warn(e,t){this.capture("warn",e,t?.code);}error(e,t){this.capture("error",e,t?.code);}record(e,t,n){this.entries.push({level:e,message:stripVTControlCharacters(t),timestamp:new Date().toISOString(),code:n});}getEntries(){return [...this.entries]}hasErrors(){return this.entries.some(e=>e.level==="error")}hasWarnings(){return this.entries.some(e=>e.level==="warn")}getReportableErrors(){return this.entries.filter(e=>e.level==="error"&&(!e.code||!Hr.has(e.code)))}hasReportableErrors(){return this.entries.some(e=>e.level==="error"&&(!e.code||!Hr.has(e.code)))}capture(e,t,n){this.entries.push({level:e,message:stripVTControlCharacters(t),timestamp:new Date().toISOString(),code:n});let o=e==="info"?this.originalLog:e==="warn"?this.originalWarn:this.originalError;this.capturing?o.call(console,t):console[e==="info"?"log":e](t);}};});function Me(i){if(i&&typeof i=="object")try{i.alreadyReported=!0;}catch{}}function ie(i){return !!(i&&typeof i=="object"&&i.alreadyReported)}function Jr(i){if(typeof i=="string")return i;if(i instanceof Error)return i.message;if(typeof i=="object"&&i!==null)try{return JSON.stringify(i)}catch{return String(i)}return String(i)}var po,Uc,Gc,tr,qr=f(()=>{Ie();lo();co();O();po=Math.floor(1e3/15),Uc={interval:100,frames:["\u280B","\u2819","\u281A","\u2813"]},Gc=new Set(["EPIPE","ENOTCONN","EBADF"]);tr=class i{static activeInstance=null;mode;stream;logCollector=new er;spinner=null;currentPhaseLabel=null;currentPhaseTracker=null;lastUpdateAt=0;pendingUpdate=null;pendingUpdateTimer=null;paused=false;originalConsole=null;intercepting=false;warningBucket=new Map;stopped=false;constructor(e){if(i.activeInstance&&!i.activeInstance.stopped)throw new Error("Reporter is a singleton \u2014 only one instance may be active at a time. Call stop() on the existing Reporter before constructing another.");this.mode=e.mode,this.stream=e.stream??process.stderr,i.activeInstance=this,this.installConsoleInterception();}async phase(e,t,n){this.start(e);let o=this.makePhaseContext();try{let s=await t(o);return this.flushPendingUpdate(),this.flushAggregatedWarnings(),this.succeed(n?.successText??e),s}catch(s){this.flushPendingUpdate(),this.flushAggregatedWarnings();let a=n?.failText??`${e} failed: ${s instanceof Error?s.message:String(s)}`;throw this.fail(a),Me(s),s}}start(e){this.currentPhaseLabel=e,this.currentPhaseTracker=ao(),this.mode==="spinner"?(this.spinner?this.spinner.text=this.composeSpinnerText(e):this.spinner=Mc({text:this.composeSpinnerText(e),stream:this.stream,spinner:Uc}),this.paused||this.spinner.start()):(this.mode==="verbose"||this.mode==="plain")&&this.writeLine(`${Z} ${e}\u2026`);}update(e){if(!this.currentPhaseLabel)return;if(this.currentPhaseLabel=e,this.mode==="verbose"){this.writeLine(`${Z} ${e}`);return}if(this.mode!=="spinner")return;let t=Date.now();this.pendingUpdate=e;let n=t-this.lastUpdateAt;n>=po?this.flushPendingUpdate():this.pendingUpdateTimer||(this.pendingUpdateTimer=setTimeout(()=>this.flushPendingUpdate(),po-n),this.pendingUpdateTimer.unref?.());}succeed(e){this.flushPendingUpdate();let t=e??this.currentPhaseLabel??"",n=`${w} ${t}`;this.terminatePhase(n,"info");}fail(e){this.flushPendingUpdate();let t=e??this.currentPhaseLabel??"",n=`${q} ${t}`;this.terminatePhase(n,"error");}info(e){if(this.mode==="quiet"){this.logCollector.record("info",e);return}this.logCollector.record("info",e),this.writeLine(`${Z} ${e}`);}warn(e,t){if(this.logCollector.record("warn",e,t?.code),this.currentPhaseLabel&&t?.code){let n=this.warningBucket.get(t.code);n?(n.count+=1,n.samples.length<3&&n.samples.push(e)):this.warningBucket.set(t.code,{code:t.code,count:1,samples:[e]});return}this.writeLine(`${T} ${e}`);}error(e,t){this.logCollector.record("error",e,t?.code),this.writeLine(`${q} ${e}`);}detail(e){this.logCollector.record("info",e),this.mode==="verbose"&&this.writeLine(` ${V.muted(e)}`);}log(e){this.logCollector.record("info",e),this.mode!=="quiet"&&this.writeLine(e);}summary(e){this.logCollector.record("info",e),this.writeLine(e);}step(e){let t=this;return {ok(n){t.renderSubStep("ok",n??e);},fail(n){t.renderSubStep("fail",n??e);},skip(n){t.renderSubStep("skip",n??e);}}}renderSubStep(e,t){let o=`${e==="ok"?w:e==="fail"?q:V.muted("-")} ${e==="skip"?V.muted(t):t}`,s=e==="fail"?"error":"info";this.logCollector.record(s,t),!(this.mode==="quiet"&&e!=="fail")&&this.writeLine(o);}pause(){this.paused||(this.paused=true,this.spinner?.isSpinning&&this.spinner.stop());}resume(){this.paused&&(this.paused=false,this.mode==="spinner"&&this.currentPhaseLabel&&this.spinner&&(this.spinner.text=this.composeSpinnerText(this.currentPhaseLabel),this.spinner.start()));}getEntries(){return this.logCollector.getEntries()}getReportableErrors(){return this.logCollector.getReportableErrors()}hasErrors(){return this.logCollector.hasErrors()}hasWarnings(){return this.logCollector.hasWarnings()}hasReportableErrors(){return this.logCollector.hasReportableErrors()}stop(){this.stopped||(this.stopped=true,this.pendingUpdateTimer&&(clearTimeout(this.pendingUpdateTimer),this.pendingUpdateTimer=null),this.flushAggregatedWarnings(),this.spinner?.isSpinning&&this.spinner.stop(),this.spinner=null,this.uninstallConsoleInterception(),i.activeInstance===this&&(i.activeInstance=null));}composeSpinnerText(e){return e}flushPendingUpdate(){if(this.pendingUpdateTimer&&(clearTimeout(this.pendingUpdateTimer),this.pendingUpdateTimer=null),this.pendingUpdate===null||!this.spinner){this.pendingUpdate=null;return}this.spinner.text=this.composeSpinnerText(this.pendingUpdate),this.pendingUpdate=null,this.lastUpdateAt=Date.now();}terminatePhase(e,t){this.logCollector.record(t,e),this.spinner?.isSpinning&&this.spinner.stop(),this.mode!=="quiet"&&this.writeLine(e),this.currentPhaseLabel=null,this.currentPhaseTracker=null;}flushAggregatedWarnings(){if(this.warningBucket.size!==0){for(let{code:e,count:t,samples:n}of this.warningBucket.values()){if(t===1){this.writeLine(`${T} ${n[0]}`);continue}let o=`${t} ${e} warnings (showing ${Math.min(n.length,3)}): ${n.slice(0,3).join(" | ")}. Use --verbose to see all.`;this.logCollector.record("warn",o,e),this.writeLine(`${T} ${o}`);}this.warningBucket.clear();}}makePhaseContext(){return {update:e=>this.update(e),detail:e=>this.detail(e),step:e=>this.step(e),warn:(e,t)=>this.warn(e,t),elapsed:()=>this.currentPhaseTracker?.elapsed()??"(0.0s)"}}writeLine(e){try{this.mode==="spinner"&&this.spinner?.isSpinning?(this.spinner.clear(),this.stream.write(e+`
51
+ `)},$l=E.join(Pe.homedir(),".constellation","lsp-trust.json"),Ot=class{constructor(e,t,r){this.projectRoot=e;this.logger=t??Fl,this.policy=r??this.buildDefaultPolicy();}serversByKey=new Map;languageToServerKey=new Map;unavailableLanguages=new Set;unavailableServerKeys=new Set;nextId=1;logger;policy;buildDefaultPolicy(){return new Dt({projectRoot:this.projectRoot,logger:this.logger,trustStore:new De($l),prompt:async e=>{let{confirm:t}=await import('@inquirer/prompts');try{return await t({message:e,default:!1})}catch{return false}}})}async startServer(e,t){if(t===false||this.unavailableLanguages.has(e))return null;let r=this.languageToServerKey.get(e),o=r?this.serversByKey.get(r):void 0;if(o)return this.toConnection(o,e);let s=this.resolveCommand(e,t);if(!s)return this.unavailableLanguages.add(e),null;let{command:a,args:l}=s,c=this.getServerKey(a,l);if(this.unavailableServerKeys.has(c))return this.unavailableLanguages.add(e),null;let u=this.serversByKey.get(c);if(u)return u.languages.add(e),this.languageToServerKey.set(e,c),this.toConnection(u,e);if(!await this.policy.authorize(e,a,l))return this.unavailableLanguages.add(e),this.unavailableServerKeys.add(c),null;try{let d=spawn(a,l,{stdio:["pipe","pipe","pipe"],cwd:this.projectRoot});await new Promise((y,b)=>{d.once("spawn",y),d.once("error",b);}),d.stderr?.on("data",y=>{let b=y.toString().trim();b.toLowerCase().includes("error")&&this.logger.warn(`[LSP:${e}] ${b}`);});let m=new Ft(d.stdin,d.stdout,12e4),h=await m.sendRequest("initialize",{processId:process.pid,rootUri:pathToFileURL(this.projectRoot).href,capabilities:{textDocument:{hover:{contentFormat:["plaintext"]},references:{},callHierarchy:{},implementation:{},documentSymbol:{hierarchicalDocumentSymbolSupport:!0}}}},12e4);m.sendNotification("initialized",{});let g={key:c,language:e,languages:new Set([e]),process:d,client:m,crashHandlers:new Set,intentionalShutdown:!1};return this.serversByKey.set(c,g),this.languageToServerKey.set(e,c),d.on("exit",y=>{let b=this.serversByKey.get(c);if(b){if(b.intentionalShutdown)b.crashHandlers.clear();else {let v=[...b.crashHandlers];b.crashHandlers.clear();for(let T of v)try{T();}catch(N){this.logger.warn(`[LSP:${b.language}] crash handler threw: ${N instanceof Error?N.message:String(N)}`);}}b.client.dispose(),this.serversByKey.delete(c);for(let[v,T]of this.languageToServerKey.entries())T===c&&this.languageToServerKey.delete(v);}y!==0&&y!==null&&this.logger.warn(`[LSP:${e}] Server exited unexpectedly with code ${y}`);}),this.toConnection(g,e)}catch(d){this.unavailableLanguages.add(e),this.unavailableServerKeys.add(c);let m=`[LSP:${e}] Failed to start: ${d instanceof Error?d.message:String(d)}`,h=d?.code;return h==="ENOENT"||h==="EACCES"?this.logger.warn(m):this.logger.error(m),null}}async shutdown(e){let t=this.languageToServerKey.get(e);if(!t)return;this.languageToServerKey.delete(e);let r=this.serversByKey.get(t);r&&(r.languages.delete(e),!(r.languages.size>0)&&await this.shutdownByKey(t));}async shutdownByKey(e){let t=this.serversByKey.get(e);if(t){t.intentionalShutdown=true;try{await t.client.sendRequest("shutdown",null,5e3),t.client.sendNotification("exit",null),await new Promise(r=>{let o=setTimeout(()=>{t.process.kill("SIGKILL"),r();},3e3);t.process.on("exit",()=>{clearTimeout(o),r();});});}catch(r){this.logger.warn(`[LSP:${t.language}] Graceful shutdown failed, force killing: ${r instanceof Error?r.message:String(r)}`),t.process.kill("SIGKILL");}finally{t.client.dispose(),this.serversByKey.delete(e);for(let[r,o]of this.languageToServerKey.entries())o===e&&this.languageToServerKey.delete(r);}}}async shutdownAll(){let e=[...this.serversByKey.keys()];await Promise.allSettled(e.map(t=>this.shutdownByKey(t)));}destroyAll(){for(let e of this.serversByKey.values()){e.intentionalShutdown=true;try{e.process.kill("SIGKILL");}catch{}try{e.client.dispose();}catch{}}this.serversByKey.clear(),this.languageToServerKey.clear();}resolveCommand(e,t){if(t?.command)return {command:t.command,args:t.args||[]};let r=ye.get(e);if(!r)return null;let o=E.join($t,r.command);return existsSync(o)?{command:o,args:r.args}:$e(r.command)?{command:r.command,args:r.args}:null}getServerKey(e,t){return `${e}\0${t.join("\0")}`}toConnection(e,t){let r=`lsp-${t}-${this.nextId++}`;return {language:t,process:e.process,id:r,serverId:e.key,sendRequest:(o,s,a)=>e.client.sendRequest(o,s,a),sendNotification:(o,s)=>e.client.sendNotification(o,s),onCrash:o=>(e.crashHandlers.add(o),()=>e.crashHandlers.delete(o))}}};});var be,Mt=f(()=>{be=class{getBuildConfigManager(e,t){return null}getImportResolver(e,t){return null}};});var Oe,Hr=f(()=>{M();Oe=class{configPaths=[];parseCache=new Map;failedConfigFiles=new Set;initialized=false;isTypeScriptEnabled;isJavaScriptEnabled;isPathResolutionEnabled;projectRoot;constructor(e,t){this.projectRoot=e,this.isTypeScriptEnabled="typescript"in t,this.isJavaScriptEnabled="javascript"in t,this.isPathResolutionEnabled=this.isTypeScriptEnabled||this.isJavaScriptEnabled;}async initialize(){if(this.initialized)return this.configPaths;if(this.initialized=true,!this.isPathResolutionEnabled)return [];try{let e=[];if(this.isTypeScriptEnabled){let t=await findAll(this.projectRoot,{skip:r=>r==="node_modules"||r===".git",configNames:["tsconfig.json"]});e.push(...t);}if(this.isJavaScriptEnabled){let t=await findAll(this.projectRoot,{skip:r=>r==="node_modules"||r===".git",configNames:["jsconfig.json"]});e.push(...t);}return this.configPaths=e,this.configPaths}catch(e){return console.warn(`${A} Failed to discover config files:`,e),[]}}async getConfigForFile(e){if(this.parseCache.has(e))return this.parseCache.get(e);if(!this.isPathResolutionEnabled)return this.parseCache.set(e,null),null;try{let t=e.endsWith(".ts")||e.endsWith(".tsx")||e.endsWith(".d.ts"),r=e.endsWith(".js")||e.endsWith(".jsx")||e.endsWith(".mjs");if(t&&this.isTypeScriptEnabled){let o=await this.findAndParse(e,"tsconfig.json");return this.parseCache.set(e,o),o}if(r){if(this.isJavaScriptEnabled)try{let o=await this.findAndParse(e,"jsconfig.json");return this.parseCache.set(e,o),o}catch(o){if(this.isTypeScriptEnabled){let s=await this.findAndParse(e,"tsconfig.json");return this.parseCache.set(e,s),s}throw o}if(this.isTypeScriptEnabled){let o=await this.findAndParse(e,"tsconfig.json");return this.parseCache.set(e,o),o}}return this.parseCache.set(e,null),null}catch(t){return this.handleConfigError(e,t),this.parseCache.set(e,null),null}}isEnabled(){return this.isPathResolutionEnabled}getConfigPaths(){return [...this.configPaths]}getTsconfigPaths(){return this.getConfigPaths()}clearCache(){this.parseCache.clear(),this.failedConfigFiles.clear();}async findAndParse(e,t){let r=await find(e,{root:this.projectRoot,configName:t});return !r||this.failedConfigFiles.has(r)?null:parse(e,{root:this.projectRoot,configName:t})}handleConfigError(e,t){let r=t&&typeof t=="object"&&"tsconfigFile"in t?t.tsconfigFile:null;if(r&&!this.failedConfigFiles.has(r)){this.failedConfigFiles.add(r);let o=t instanceof Error?t.message:String(t);console.warn(`${A} Failed to parse ${r}: ${o}`),console.warn(`${A} Path alias resolution will be skipped for files using this config`);}else r||console.warn(`${A} Failed to parse config for ${e}:`,t instanceof Error?t.message:t);}};});var Ut,Fi=f(()=>{we();Ut=class{constructor(e,t){this.projectRoot=e;this.tsconfigResult=t;}workspacePackages={};initialized=false;async initialize(){if(this.initialized)return;this.initialized=true;let e={},t=await this.loadFromPackageJsonWorkspaces();Object.assign(e,t);let r=await this.loadFromTsConfig();Object.assign(e,r),this.workspacePackages=e;}async resolve(e){if(await this.initialize(),this.workspacePackages[e])return this.toProjectRelative(this.workspacePackages[e]);for(let[t,r]of Object.entries(this.workspacePackages))if(e.startsWith(t+"/")){let o=e.substring(t.length+1),s=await this.resolveSubPath(r,o);if(s)return this.toProjectRelative(s)}return null}async isWorkspacePackage(e){return await this.resolve(e)!==null}async loadFromTsConfig(){let e={};if(!this.tsconfigResult?.tsconfig?.compilerOptions?.paths)return e;let t=this.tsconfigResult.tsconfig.compilerOptions.paths,r=this.tsconfigResult.tsconfigFile?E.dirname(this.tsconfigResult.tsconfigFile):this.projectRoot;for(let[o,s]of Object.entries(t)){if(o.includes("*")||!Array.isArray(s))continue;let a=s[0];if(!a)continue;let l=E.resolve(r,a),c=await this.findEntryPoint(l);c&&(e[o]=c);}return e}async loadFromPackageJsonWorkspaces(){let e={};try{let t=E.join(this.projectRoot,"package.json"),r=await J.readFile(t,"utf-8"),s=JSON.parse(r).workspaces;if(!s)return e;let a=Array.isArray(s)?s:s.packages||[];for(let l of a){let c=await this.findWorkspaceDirs(l);for(let u of c){let p=await this.loadWorkspacePackage(u);p&&Object.assign(e,p);}}}catch{}return e}async findWorkspaceDirs(e){let t=[];if(e.endsWith("/*")){let r=e.slice(0,-2),o=E.join(this.projectRoot,r);try{let s=await J.readdir(o,{withFileTypes:!0});for(let a of s)a.isDirectory()&&t.push(E.join(o,a.name));}catch{}}else {let r=E.join(this.projectRoot,e);try{(await J.stat(r)).isDirectory()&&t.push(r);}catch{}}return t}async loadWorkspacePackage(e){try{let t=E.join(e,"package.json"),r=await J.readFile(t,"utf-8"),o=JSON.parse(r),s=o.name;if(!s)return null;let a=await this.findPackageEntryPoint(e,o);return a?{[s]:a}:null}catch{return null}}async findPackageEntryPoint(e,t){if(t.exports){let o=t.exports;if(typeof o=="string")return E.join(e,o);if(typeof o=="object"){let s=o["."]||o["./index"];if(typeof s=="string")return E.join(e,s);if(typeof s=="object"){let a=s.import||s.default||s.require;if(a)return E.join(e,a)}}}if(t.main)return E.join(e,t.main);let r=["src/index.ts","src/index.tsx","src/index.js","src/index.jsx","index.ts","index.tsx","index.js","index.jsx"];for(let o of r){let s=E.join(e,o);try{if((await J.stat(s)).isFile())return s}catch{}}return null}async findEntryPoint(e){let t=["index.ts","index.tsx","index.js","index.jsx","index.d.ts"];for(let r of t){let o=E.join(e,r);try{if((await J.stat(o)).isFile())return o}catch{}}try{if((await J.stat(e)).isFile())return e}catch{}return null}async resolveSubPath(e,t){let r=e.endsWith("index.ts")||e.endsWith("index.tsx")||e.endsWith("index.js")||e.endsWith("index.jsx")?E.dirname(e):E.dirname(e),o=[E.join(r,t+".ts"),E.join(r,t+".tsx"),E.join(r,t+".js"),E.join(r,t+".jsx"),E.join(r,t+".d.ts"),E.join(r,t,"index.ts"),E.join(r,t,"index.tsx"),E.join(r,t,"index.js"),E.join(r,t,"index.jsx")];for(let s of o)try{if((await J.stat(s)).isFile())return s}catch{}return null}toProjectRelative(e){let t=W(this.projectRoot,e);return t.startsWith("./")?t:`./${t}`}};});var Me,Wr=f(()=>{we();Fi();Me=class{baseUrl=null;paths={};sourceDir;tsconfigDir;projectRoot;extensions;packageImports={};packageJsonDir=null;sourceFilePath;workspaceResolver;constructor(e,t){this.sourceFilePath=e,this.sourceDir=E.dirname(e),this.projectRoot=process.cwd(),this.workspaceResolver=new Ut(this.projectRoot,t);let r=e.toLowerCase(),o=r.endsWith(".ts")||r.endsWith(".tsx")||r.endsWith(".d.ts"),s=r.endsWith(".js")||r.endsWith(".jsx")||r.endsWith(".mjs")||r.endsWith(".cjs");if(o?this.extensions=[".ts",".tsx",".d.ts"]:s?this.extensions=[".js",".jsx",".mjs",".cjs"]:this.extensions=[".ts",".tsx",".d.ts"],!t?.tsconfigFile){this.tsconfigDir=this.sourceDir;return}this.tsconfigDir=E.dirname(t.tsconfigFile);let a=t.tsconfig?.compilerOptions;a&&(a.baseUrl&&(this.baseUrl=E.resolve(this.tsconfigDir,a.baseUrl)),a.paths&&typeof a.paths=="object"&&(this.paths=a.paths));}async resolve(e){if(e.startsWith("./")||e.startsWith("../")){let r=E.resolve(this.sourceDir,e),o=await this.findFileWithExtensions(r);return o?this.toProjectRelative(o):e}if(e.startsWith("#")){let r=await this.resolveWithPackageImports(e);return r?this.toProjectRelative(r):e}let t=await this.workspaceResolver.resolve(e);if(t)return t;if(!e.startsWith("@")&&!e.startsWith("~")&&(!e.includes("/")||!this.baseUrl))return e;if(Object.keys(this.paths).length>0){let r=await this.resolveWithPaths(e);if(r)return this.toProjectRelative(r)}if(this.baseUrl){let r=await this.resolveWithBaseUrl(e);if(r)return this.toProjectRelative(r)}return e}toProjectRelative(e){let t=W(this.projectRoot,e);return t.startsWith("./")?t:`./${t}`}async resolveWithPaths(e){for(let[t,r]of Object.entries(this.paths)){let o=this.matchPathPattern(e,t);if(o!==null)for(let s of r){let a=await this.trySubstitution(e,t,s,o);if(a)return a}}return null}matchPathPattern(e,t){if(!t.includes("*"))return e===t?"":null;let[r,o]=t.split("*");if(!e.startsWith(r)||o&&!e.endsWith(o))return null;let s=r.length,a=o?e.length-o.length:e.length;return e.substring(s,a)}async trySubstitution(e,t,r,o){let s=r.replaceAll("*",o),a=E.resolve(this.tsconfigDir,s);return await this.findFileWithExtensions(a)}async resolveWithBaseUrl(e){if(!this.baseUrl)return null;let t=E.resolve(this.baseUrl,e);return await this.findFileWithExtensions(t)}async findFileWithExtensions(e){let t=this.extensions.some(a=>e.endsWith(a));if(t&&await this.fileExists(e))return await this.resolveSymlink(e);let r=[".js",".jsx",".mjs",".cjs"],o=r.some(a=>e.endsWith(a)),s=e;if(o&&!t){for(let a of r)if(e.endsWith(a)){s=e.slice(0,-a.length);break}}if(!t)for(let a of this.extensions){let l=s+a;if(await this.fileExists(l))return await this.resolveSymlink(l)}for(let a of this.extensions){let l=E.join(s,`index${a}`);if(await this.fileExists(l))return await this.resolveSymlink(l)}return null}async fileExists(e){try{return (await J.stat(e)).isFile()}catch{return false}}async resolveSymlink(e){try{return await J.realpath(e)}catch{return e}}async findPackageJson(e){let t=e;for(;t.startsWith(this.projectRoot);){let r=E.join(t,"package.json");try{if((await J.stat(r)).isFile())return r}catch{}let o=E.dirname(t);if(o===t)break;t=o;}return null}async loadPackageImports(){if(this.packageJsonDir!==null)return;let e=await this.findPackageJson(this.sourceDir);if(!e){this.packageJsonDir="";return}try{let t=await J.readFile(e,"utf-8"),r=JSON.parse(t);this.packageJsonDir=E.dirname(e),r.imports&&typeof r.imports=="object"&&(this.packageImports=r.imports);}catch{this.packageJsonDir="";}}async resolveWithPackageImports(e){if(await this.loadPackageImports(),!this.packageJsonDir||Object.keys(this.packageImports).length===0)return null;for(let[t,r]of Object.entries(this.packageImports)){let o=this.matchPathPattern(e,t);if(o!==null){if(typeof r=="string"){let s=await this.tryPackageImportSubstitution(r,o);if(s)return s}if(Array.isArray(r)){for(let s of r)if(typeof s=="string"){let a=await this.tryPackageImportSubstitution(s,o);if(a)return a}}}}return null}async tryPackageImportSubstitution(e,t){if(!this.packageJsonDir)return null;let r=e.replaceAll("*",t),o=E.resolve(this.packageJsonDir,r);return await this.findFileWithExtensions(o)}};});var Gt,$i=f(()=>{Mt();Hr();Wr();Gt=class extends be{language="typescript";extensions=[".ts",".tsx",".d.ts"];getBuildConfigManager(e,t){return new Oe(e,t)}getImportResolver(e,t){return new Me(e,t)}};});var Bt,Di=f(()=>{Mt();Hr();Wr();Bt=class extends be{language="javascript";extensions=[".js",".jsx",".mjs",".cjs"];getBuildConfigManager(e,t){return new Oe(e,t)}getImportResolver(e,t){return new Me(e,t)}};});async function le(i,e,t,r,o,s=[]){let a=await t.resolve(i),l=Oi(i,a),c=o(i,a,l),u=l?void 0:jt(a);r[e.toString()]={source:i,resolvedPath:u,isExternal:l,importType:c,specifiers:s};}function Oi(i,e){return i===e?true:!(!e.startsWith(".")&&!e.startsWith("/")||e.startsWith("./")||e.startsWith("../"))}var zr,it=f(()=>{we();zr=(i,e,t)=>t?i.startsWith("node:")?"builtin":"external":i.startsWith("./")||i.startsWith("../")?"relative":i.startsWith("@")?"workspace":"alias";});async function Ul(i,e,t,r){let o=i.childForFieldName("name");if(!o)return;let s,a;if(o.type==="aliased_import"){let l=o.childForFieldName("name"),c=o.childForFieldName("alias");s=l?l.text:o.text,a={local:c?c.text:s.split(".")[0],original:s,isDefault:false,isNamespace:false};}else s=o.text,a={local:s.split(".")[0],original:s,isDefault:false,isNamespace:false};await le(s,i.startPosition.row,e,t,r,[a]);}function Gl(i,e){if(!e)return [];let t=[],r=i.childForFieldName("name");if(r){if(r.type==="aliased_import"){let s=r.childForFieldName("name"),a=r.childForFieldName("alias");s&&t.push({local:a?a.text:s.text,original:s.text,isDefault:false,isNamespace:false});}else t.push({local:r.text,original:r.text,isDefault:false,isNamespace:false});return t}let o=false;for(let s=0;s<i.childCount;s++){let a=i.child(s);if(a){if(a.type==="import"){o=true;continue}if(o){if(a.type==="dotted_name"||a.type==="identifier")t.push({local:a.text,original:a.text,isDefault:false,isNamespace:false});else if(a.type==="aliased_import"){let l=a.childForFieldName("name"),c=a.childForFieldName("alias");l&&t.push({local:c?c.text:l.text,original:l.text,isDefault:false,isNamespace:false});}}}}return t}async function Bl(i,e,t,r){let o,s=i.childForFieldName("module_name");if(s)o=s.text;else {let l="";for(let c=0;c<i.childCount;c++){let u=i.child(c);if(u){if(u.type==="relative_import"){l=u.text;break}(u.type==="."||u.type==="import_prefix")&&(l+=u.text);}}o=l||".";}let a=Gl(i,!!s);await le(o,i.startPosition.row,e,t,r,a);}async function Hl(i,e,t,r){await le("__future__",i.startPosition.row,e,t,r,[]);}function Kr(){return {language:"python",handlers:new Map([["import_statement",Ul],["import_from_statement",Bl],["future_import_statement",Hl]]),classifyImportType:Ml}}var Ml,Ht=f(()=>{tt();it();tt();Ml=(i,e,t)=>{if(t)return "external";if(/^\.+/.test(i))return "relative";let r=i.split(".")[0];return Ze.has(r)?"builtin":"alias"};});var Wt,Mi=f(()=>{Ht();Wt=class{sourceDir;projectRoot;constructor(e,t){this.sourceDir=E.dirname(e),this.projectRoot=t;}async resolve(e){let t=e.split(".")[0];if(Ze.has(t))return e;if(e.startsWith("."))return this.resolveRelative(e);let r=e.replace(/\./g,"/"),o=await this.tryResolveFile(E.resolve(this.projectRoot,r));return o?E.relative(this.projectRoot,o).replace(/\\/g,"/"):e}async resolveRelative(e){let t=0;for(;t<e.length&&e[t]===".";)t++;let r=e.slice(t),o=t<=1?"":"../".repeat(t-1),s=r?o+r.replace(/\./g,"/"):o.slice(0,-1)||".",a=E.resolve(this.sourceDir,s),l=await this.tryResolveFile(a);return l?E.relative(this.projectRoot,l).replace(/\\/g,"/"):e}async tryResolveFile(e){let t=[`${e}.py`,`${e}.pyi`,`${e}.pyw`,E.join(e,"__init__.py"),E.join(e,"__init__.pyi")];for(let r of t)try{return await zt.promises.access(r,zt.constants.F_OK),r}catch{continue}return null}};});var Kt,Ui=f(()=>{Mt();Mi();Kt=class extends be{language="python";extensions=[".py",".pyi",".pyw"];getBuildConfigManager(e,t){return null}getImportResolver(e,t){return new Wt(e,process.cwd())}};});function xe(i){return Vl[i]??i.charAt(0).toUpperCase()+i.slice(1)}var Vl,ot,Vt,Jt=f(()=>{$i();Di();Ui();Vl={bash:"Bash",c:"C","c-sharp":"C#",cpp:"C++",go:"Go",java:"Java",javascript:"JavaScript",json:"JSON",php:"PHP",python:"Python",ruby:"Ruby",typescript:"TypeScript"};ot={bash:[".sh",".bash"],c:[".c",".h"],"c-sharp":[".cs"],cpp:[".cpp",".cc",".cxx",".hpp",".hh",".hxx"],go:[".go"],java:[".java"],javascript:[".js",".jsx"],json:[".json"],php:[".php"],python:[".py",".pyi",".pyw"],ruby:[".rb"],typescript:[".ts",".tsx"]},Vt=class{constructor(e){this.config=e;this.registerPlugin(new Gt),this.registerPlugin(new Bt),this.registerPlugin(new Kt);}plugins=new Map;registerPlugin(e){this.plugins.set(e.language,e);}getPlugin(e){return this.plugins.get(e)}javascript={language:()=>Wl,fileExtensions:()=>this.config?.languages.javascript?.fileExtensions??ot.javascript};typescript={language:()=>Kl.typescript,fileExtensions:()=>this.config?.languages.typescript?.fileExtensions??ot.typescript};python={language:()=>zl,fileExtensions:()=>this.config?.languages.python?.fileExtensions??ot.python};php;json;java;go;cpp;"c-sharp";c;bash;ruby};});function Ue(i,e,t=32){let r=i.parent,o=0;for(;r!==null&&o<t;){if(e(r))return r;r=r.parent,o++;}return null}var qt,Vr=f(()=>{qt=Object.freeze(new Set(["program","statement_block","function_declaration","function_expression","generator_function_declaration","generator_function","arrow_function","method_definition","class_body"]));});function Jr(i,e){if(i.type==="jsx_opening_element"||i.type==="jsx_self_closing_element"||i.type==="jsx_closing_element"){let t=i.childForFieldName("name");t!==null&&Jl(t,e);}for(let t of i.namedChildren)t&&Jr(t,e);}function Jl(i,e){if(i.type==="identifier"||i.type==="type_identifier"){e.set(Ee(i.startPosition.row,i.startPosition.column),"call");return}if(i.type==="member_expression"||i.type==="nested_identifier"){let t=i.childForFieldName("property");t!==null&&e.set(Ee(t.startPosition.row,t.startPosition.column),"call");}}var Gi=f(()=>{st();});function Ge(i,e){i.rootNode&&(Hi(i.rootNode,e),Jr(i.rootNode,e));}function Hi(i,e){if(ql.has(i.type)){let t=Yl(i);t!==null&&e.set(Ee(i.startPosition.row,i.startPosition.column),t);}for(let t of i.namedChildren)t&&Hi(t,e);}function Yl(i){if(Ql(i))return "declaration";if(lc(i))return "read";if(sc(i))return "type";let e=Ue(i,t=>t.type==="decorator");return e!==null&&tc(i,e)?"call":ec(i)?"instantiate":Zl(i)?"call":rc(i)||nc(i)||ic(i)||hc(i)||fc(i)?"write":cc(i)?"import-use":"read"}function Ql(i){let e=i.parent;return e===null?false:!!(Xl.has(e.type)&&(e.childForFieldName("name")===i||e.childForFieldName("property")===i)||(e.type==="required_parameter"||e.type==="optional_parameter")&&e.childForFieldName("pattern")===i||e.type==="import_specifier"&&(e.childForFieldName("name")===i||e.childForFieldName("alias")===i)||e.type==="namespace_import"||e.type==="import_clause"&&e.namedChild(0)===i&&i.type==="identifier"||e.type==="catch_clause"&&e.childForFieldName("parameter")===i||e.type==="enum_body")}function Zl(i){let e=i.parent;if(e===null)return false;if(e.type==="call_expression"&&e.childForFieldName("function")===i)return true;if(e.type==="member_expression"&&e.childForFieldName("property")===i){let t=e.parent;if(t!==null&&t.type==="call_expression"&&t.childForFieldName("function")===e)return true}return false}function ec(i){let e=i.parent;if(e===null)return false;if(e.type==="new_expression"&&e.childForFieldName("constructor")===i)return true;if(e.type==="member_expression"&&e.childForFieldName("property")===i){let t=e.parent;if(t!==null&&t.type==="new_expression"&&t.childForFieldName("constructor")===e)return true}return false}function tc(i,e){let t=e.namedChild(0);if(t===null)return false;if(t===i)return true;if(t.type==="call_expression"){let r=t.childForFieldName("function");if(r===i||r?.type==="member_expression"&&r.childForFieldName("property")===i)return true}return t.type==="member_expression"&&t.childForFieldName("property")===i}function rc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="unary_expression")return t.child(0)?.type==="delete";if(t.type==="member_expression"&&t.childForFieldName("object")===e||qt.has(t.type))return false;e=t;}return false}function nc(i){let e=i.parent;if(e?.type==="update_expression"&&e.childForFieldName("argument")===i)return true;if(e?.type==="member_expression"&&e.childForFieldName("property")===i){let t=e.parent;if(t?.type==="update_expression"&&t.childForFieldName("argument")===e)return true}return false}function ic(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if((t.type==="assignment_expression"||t.type==="augmented_assignment_expression")&&t.childForFieldName("left")===e)return true;if(t.type==="member_expression"&&t.childForFieldName("object")===e||t.type==="subscript_expression"&&t.childForFieldName("object")!==e||qt.has(t.type))return false;e=t;}return false}function sc(i){let e=i.parent,t=i;for(;e!==null;){if(e.type==="as_expression"||e.type==="satisfies_expression"){let r=e.namedChild(1);return r===null?false:r===t||ac(r,i)}if(oc.has(e.type))return true;if(qt.has(e.type))return false;t=e,e=e.parent;}return false}function ac(i,e){let t=e;for(;t!==null;){if(t===i)return true;t=t.parent;}return false}function lc(i){return Ue(i,t=>t.type==="type_query")!==null}function cc(i){let e=i.parent;if(e?.type!=="member_expression"||e.childForFieldName("object")!==i)return false;let t=i.text,r=mc(i);return gc(r,t)?!uc(i,t):false}function uc(i,e){let t=i.parent;for(;t!==null;){if(pc.has(t.type)&&dc(t,e))return true;t=t.parent;}return false}function dc(i,e){for(let t of i.namedChildren){if(t.type==="lexical_declaration"||t.type==="variable_declaration")for(let r of t.namedChildren){if(r.type!=="variable_declarator")continue;if(r.childForFieldName("name")?.text===e)return true}if(t.type==="formal_parameters")for(let r of t.namedChildren){if(r.type!=="required_parameter"&&r.type!=="optional_parameter")continue;let o=r.childForFieldName("pattern");if(o?.type==="identifier"&&o.text===e)return true}}return false}function mc(i){let e=i;for(;e.parent!==null;)e=e.parent;return e}function gc(i,e){for(let t of i.descendantsOfType("namespace_import")){let r=t.namedChild(0);if(r!==null&&r.text===e)return true}return false}function fc(i){let e=i.parent;return e?.type==="for_in_statement"&&e.childForFieldName("left")===i}function hc(i){let e=i.parent;if(e===null||!Bi.has(e.type)||e.type==="pair_pattern"&&e.childForFieldName("key")===i||(e.type==="object_assignment_pattern"||e.type==="assignment_pattern")&&e.namedChild(0)!==i)return false;let t=e;for(;t!==null;){let r=t.parent;if(r===null)return false;if(r.type==="variable_declarator"&&r.childForFieldName("name")===t||(r.type==="assignment_expression"||r.type==="augmented_assignment_expression")&&r.childForFieldName("left")===t||(r.type==="required_parameter"||r.type==="optional_parameter")&&r.childForFieldName("pattern")===t||r.type==="formal_parameters"||r.type==="for_in_statement"&&r.childForFieldName("left")===t)return true;if(!Bi.has(r.type))return false;t=r;}return false}var ql,Xl,oc,pc,Bi,Yt=f(()=>{st();Vr();Gi();ql=Object.freeze(new Set(["identifier","type_identifier","property_identifier","private_property_identifier","shorthand_property_identifier","shorthand_property_identifier_pattern"]));Xl=Object.freeze(new Set(["variable_declarator","function_declaration","function_signature","generator_function_declaration","class_declaration","abstract_class_declaration","interface_declaration","type_alias_declaration","enum_declaration","enum_assignment","method_signature","abstract_method_signature","method_definition","public_field_definition","field_definition","property_signature"]));oc=Object.freeze(new Set(["type_annotation","type_arguments","type_parameter","type_parameters","type_alias_declaration","interface_declaration","generic_type","type_predicate","type_query","conditional_type","union_type","intersection_type","tuple_type","mapped_type_clause","implements_clause","extends_type_clause"]));pc=Object.freeze(new Set(["statement_block","function_declaration","function_expression","arrow_function","method_definition","generator_function","generator_function_declaration","for_statement","for_in_statement"]));Bi=Object.freeze(new Set(["object_pattern","array_pattern","pair_pattern","rest_pattern","object_assignment_pattern","assignment_pattern"]));});function Wi(i,e){Ge(i,e);}var zi=f(()=>{Yt();});function Ki(i,e){Ge(i,e);}var Vi=f(()=>{Yt();});function Ji(i,e){if(!i.rootNode)return;let t=Dc(i.rootNode);qi(i.rootNode,e,t);}function qi(i,e,t){if(yc.has(i.type)){let r=bc(i,t);r!==null&&e.set(Ee(i.startPosition.row,i.startPosition.column),r);}for(let r of i.namedChildren)r&&qi(r,e,t);}function bc(i,e){if(vc(i))return "declaration";if(Cc(i))return "read";if(wc(i))return "declaration";if(xc(i))return "type";let t=Ue(i,r=>r.type==="decorator");return t!==null&&Ec(i,t)||_c(i)?"call":Pc(i)||Ic(i)||Nc(i)||Tc(i)||jc(i)?"write":Ac(i,e)?"import-use":"read"}function vc(i){let e=i.parent;if(e===null)return false;if((e.type==="function_definition"||e.type==="class_definition")&&e.childForFieldName("name")===i||e.type==="parameters"||e.type==="lambda_parameters"||(e.type==="typed_parameter"||e.type==="typed_default_parameter"||e.type==="default_parameter")&&e.namedChild(0)===i)return true;if(e.type==="list_splat_pattern"||e.type==="dictionary_splat_pattern"){let t=e.parent;if(t?.type==="parameters"||t?.type==="lambda_parameters")return true}return !!(e.type==="as_pattern_target"||Sc(i))}function Sc(i){let e=i.parent;if(e?.type!=="type")return false;let t=e.parent;return t?.type!=="type_alias_statement"?false:t.namedChild(0)===e}function wc(i){let e=i.parent;for(;e!==null;){if(e.type==="import_statement"||e.type==="import_from_statement")return true;if(qr.has(e.type))return false;e=e.parent;}return false}function Cc(i){let e=i.parent;return e?.type==="global_statement"||e?.type==="nonlocal_statement"}function xc(i){return Ue(i,t=>t.type==="type")!==null}function Ec(i,e){let t=e.namedChild(0);if(t===null)return false;if(t===i)return true;if(t.type==="call"){let r=t.childForFieldName("function");if(r===i||r?.type==="attribute"&&r.childForFieldName("attribute")===i)return true}return t.type==="attribute"&&t.childForFieldName("attribute")===i}function _c(i){let e=i.parent;if(e?.type==="call"&&e.childForFieldName("function")===i)return true;if(e?.type==="attribute"&&e.childForFieldName("attribute")===i){let t=e.parent;if(t?.type==="call"&&t.childForFieldName("function")===e)return true}return false}function Pc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="delete_statement")return true;if(t.type==="attribute"&&t.childForFieldName("object")===e||qr.has(t.type))return false;e=t;}return false}function Ic(i){let e=i.parent;if(e?.type==="augmented_assignment"&&e.childForFieldName("left")===i)return true;if(e?.type==="attribute"&&e.childForFieldName("attribute")===i){let t=e.parent;if(t?.type==="augmented_assignment"&&t.childForFieldName("left")===e)return true}return false}function Nc(i){let e=i.parent;return e?.type==="named_expression"&&e.childForFieldName("name")===i}function Tc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="assignment"&&t.childForFieldName("left")===e)return true;if(t.type==="attribute"&&t.childForFieldName("object")===e||t.type==="subscript"&&t.childForFieldName("value")!==e)return false;if(Rc.has(t.type)){e=t;continue}if(qr.has(t.type))return false;e=t;}return false}function jc(i){let e=i;for(;e!==null;){let t=e.parent;if(t===null)return false;if((t.type==="for_statement"||t.type==="for_in_clause")&&t.childForFieldName("left")===e)return true;if(!Lc.has(t.type))return false;e=t;}return false}function Ac(i,e){let t=i.parent;if(t?.type!=="attribute"||t.childForFieldName("object")!==i)return false;let r=i.text;return e.has(r)?!Fc(i,r):false}function Fc(i,e){let t=i.parent;for(;t!==null;){if(kc.has(t.type)&&$c(t,e))return true;t=t.parent;}return false}function $c(i,e){for(let t of i.namedChildren){if(t.type==="expression_statement"){let r=t.namedChild(0);if(r?.type==="assignment"){let o=r.childForFieldName("left");if(o?.type==="identifier"&&o.text===e)return true}}if(t.type==="parameters"){for(let r of t.namedChildren)if(r.type==="identifier"&&r.text===e||(r.type==="typed_parameter"||r.type==="typed_default_parameter"||r.type==="default_parameter")&&r.namedChild(0)?.type==="identifier"&&r.namedChild(0)?.text===e)return true}}return false}function Dc(i){let e=new Set;for(let t of i.descendantsOfType("import_statement"))for(let r of t.namedChildren)if(r.type==="dotted_name"&&e.add(r.text),r.type==="aliased_import"){let o=r.childForFieldName("alias");o&&e.add(o.text);}return e}var yc,qr,Rc,Lc,kc,Yi=f(()=>{st();Vr();yc=Object.freeze(new Set(["identifier"])),qr=Object.freeze(new Set(["module","block","function_definition","class_definition","lambda"]));Rc=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern","list_splat_pattern"]));Lc=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern"]));kc=Object.freeze(new Set(["block","function_definition","class_definition","lambda"]));});function Qi(i,e){let t=new Map;switch(e){case "typescript":Ge(i,t);break;case "tsx":Wi(i,t);break;case "javascript":Ki(i,t);break;case "python":Ji(i,t);break}return t}function Ee(i,e){return `${i}:${e}`}var Xi,st=f(()=>{Yt();zi();Vi();Yi();Xi=Object.freeze(new Set(["typescript","javascript","python"]));});function Uc(i,e){return Xi.has(i)?i==="typescript"?e.toLowerCase().endsWith(".tsx")?"tsx":"typescript":i:null}function Gc(i){let e=[];for(let[t,r]of i.entries()){let o=t.indexOf(":");if(o<0)continue;let s=Number(t.slice(0,o)),a=Number(t.slice(o+1));!Number.isFinite(s)||!Number.isFinite(a)||e.push({line:s,column:a,referenceType:r});}return e.sort((t,r)=>t.line-r.line||t.column-r.column),e}var Xt,to=f(()=>{st();ae();Xt=class{constructor(e){this.langRegistry=e;}async parseFile(e,t){let r=this.langRegistry[t]?.language;if(!r)throw new Error(`Unsupported language: ${t}`);let o=await r();if(!o)throw new Error(`Failed to load language: ${t}`);t==="typescript"&&e.toLowerCase().endsWith(".tsx")&&(o=Kl.tsx);let s=new Oc;s.setLanguage(o);let a=await S.getFileStats(e),l=25*1024*1024,c,u;if(a.size<=l){let h=await S.readFile(e);u=h;let g={bufferSize:1024*1024};c=s.parse(h,void 0,g);}else c=await this.parseWithStream(s,e,a.size);let p=Uc(t,e),d=p===null?[]:Gc(Qi(c,p));return {tree:c,classificationMap:{filePath:e,entries:d},content:u}}async parseWithStream(e,t,r){let o=null;try{o=await J.open(t,"r");let s=o.fd,a=64*1024,l=Buffer.alloc(a),c=0;return e.parse(p=>{if(r>50*1024*1024){let m=Math.round(p/r*100);m>c+10&&(process.stderr.write(` Parsing large file: ${m}%...
52
+ `),c=m);}let d=zt.readSync(s,l,0,a,p);return d===0?null:l.subarray(0,d).toString("utf-8")})}catch(s){if(o)try{await o.close();}catch(a){process.stderr.write(`Warning: Failed to close file handle for ${t}: ${String(a)}
53
+ `);}throw s}finally{if(o)try{await o.close();}catch{}}}};});var Qt,no=f(()=>{ae();we();M();Qt=class{rootPath;constructor(e){this.rootPath=e||process.cwd();}async scanFiles(e){let t=ro();return await this.loadGitignoreRules(t,this.rootPath),e.exclude&&e.exclude.length>0&&t.add(e.exclude),(await this.walkDirectory(this.rootPath)).filter(s=>!t.ignores(s.relativePath)&&this.matchesLanguageExtension(s,e.languages))}async scanSpecificFiles(e,t){let r=[],o=null;t.exclude&&t.exclude.length>0&&(o=ro().add(t.exclude));let s=await J__default.realpath(this.rootPath);for(let a of e)try{let l=E__default.isAbsolute(a)?a:E__default.join(this.rootPath,a),c=await J__default.lstat(l);if(c.isSymbolicLink()){let u=await J__default.realpath(l);if(!u.startsWith(s+E__default.sep)&&u!==s){console.warn(`${A} Skipping symlink pointing outside project: ${a} -> ${u}`);continue}let p=await J__default.stat(l);if(!p.isFile())continue;let d=W(this.rootPath,l);if(o&&o.ignores(d))continue;let m=this.detectLanguage(d,t.languages);if(!m)continue;r.push({path:l,relativePath:d,language:m,size:p.size});}else if(c.isFile()){let u=W(this.rootPath,l);if(o&&o.ignores(u))continue;let p=this.detectLanguage(u,t.languages);if(!p)continue;r.push({path:l,relativePath:u,language:p,size:c.size});}}catch{console.warn(`${A} Skipping inaccessible file: ${a}`);}return r}async loadGitignoreRules(e,t){let r=[],o=t;for(;;){let s=E__default.join(o,".gitignore");await S.fileIsReadable(s)&&r.unshift(s);let a=E__default.dirname(o);if(a===o)break;o=a;let l=E__default.join(o,".git");if(await S.directoryExists(l)){let c=E__default.join(o,".gitignore");await S.fileIsReadable(c)&&!r.includes(c)&&r.unshift(c);break}}for(let s of r)try{let a=await S.readFile(s);e.add(a);}catch{console.warn(`${A} Failed to load .gitignore: ${s}`);}e.add(".git");}async walkDirectory(e,t,r,o){let s=[],a=t||e,l=r||await J__default.realpath(this.rootPath),c=o||new Set([l]);try{let u=(await J__default.readdir(e,{withFileTypes:!0})).map(p=>(p.name=p.name.normalize("NFC"),p)).sort((p,d)=>p.name<d.name?-1:p.name>d.name?1:0);for(let p of u){let d=E__default.join(e,p.name),m=W(a,d);if(p.isDirectory()){if(p.name.startsWith("."))continue;let h=await this.walkDirectory(d,a,l,c);s.push(...h);}else if(p.isFile()){let h=await J__default.stat(d);s.push({path:d,relativePath:m,language:"",size:h.size});}else if(p.isSymbolicLink())try{let h=await J__default.realpath(d);if(!h.startsWith(l+E__default.sep)&&h!==l){console.warn(`${A} Skipping symlink pointing outside project: ${d} -> ${h}`);continue}let g=await J__default.stat(d);if(g.isDirectory()){if(p.name.startsWith(".")||c.has(h))continue;c.add(h);let y=await this.walkDirectory(d,a,l,c);s.push(...y);}else g.isFile()&&s.push({path:d,relativePath:m,language:"",size:g.size});}catch{console.warn(`${A} Skipping invalid symlink: ${d}`);}}}catch(u){console.error(`${re} Error walking directory ${e}:`,u);}return s}matchesLanguageExtension(e,t){let r=E__default.extname(e.path).toLowerCase();for(let[o,s]of Object.entries(t))if(s.fileExtensions.includes(r))return e.language=o,true;return false}detectLanguage(e,t){let r=E__default.extname(e).toLowerCase();for(let[o,s]of Object.entries(t))if(s.fileExtensions.includes(r))return o;return null}};});var Bc,Hc,Wc,io,oo=f(()=>{tt();Bc=z.object({local:z.string(),original:z.string().optional(),isDefault:z.boolean(),isNamespace:z.boolean()}),Hc=z.object({source:z.string().min(1,"Import source cannot be empty"),resolvedPath:z.string().optional(),isExternal:z.boolean(),importType:z.enum(["relative","workspace","alias","external","builtin"]),specifiers:z.array(Bc).optional()}),Wc=z.record(z.string(),Hc),io=z.object({file:z.string().min(1,"File path cannot be empty").max(1e3,"File path too long"),language:z.string().regex(/^(bash|c|c-sharp|cpp|go|java|javascript|json|php|python|ruby|typescript)$/,"Invalid language identifier"),commit:z.string().regex(/^[a-f0-9]{40}$/,"Invalid git commit hash"),timestamp:z.string().datetime({message:"Invalid ISO timestamp"}),ast:z.string().min(1,"Index data cannot be empty").max(1e7,"Index data exceeds 10MB limit"),importResolutions:Wc.optional(),classificationMap:Ir.optional()});});function zc(i){let e=Math.max(0,i)/1e3;if(e<60)return `(${e.toFixed(1)}s)`;let t=Math.floor(e/60),r=Math.floor(e%60);return `(${t}m ${r}s)`}function so(){let i=performance.now();return {elapsed:()=>zc(performance.now()-i),reset:()=>{i=performance.now();},ms:()=>performance.now()-i}}var ao=f(()=>{});var Yr,er=f(()=>{Yr=new Set(["ACCESS_KEY_MISSING","AUTH_FAILURE","PROJECT_NOT_REGISTERED","PROJECT_INACTIVE","INVALID_PROJECT_ID","DIRTY_WORKTREE","CONCURRENT_INDEXING","GIT_SYNC_FAILURE","BRANCH_NOT_CONFIGURED","ENRICHMENT_FAILED"]);});function Xr(i){if(typeof i=="string")return i;if(i instanceof Error)return i.message;if(typeof i=="object"&&i!==null)try{return JSON.stringify(i)}catch{return String(i)}return String(i)}var tr,lo=f(()=>{er();tr=class{entries=[];originalLog;originalWarn;originalError;capturing=false;start(){this.capturing||(this.capturing=true,this.originalLog=console.log,this.originalWarn=console.warn,this.originalError=console.error,console.log=(...e)=>{this.entries.push({level:"info",message:stripVTControlCharacters(e.map(Xr).join(" ")),timestamp:new Date().toISOString()}),this.originalLog.apply(console,e);},console.warn=(...e)=>{this.entries.push({level:"warn",message:stripVTControlCharacters(e.map(Xr).join(" ")),timestamp:new Date().toISOString()}),this.originalWarn.apply(console,e);},console.error=(...e)=>{this.entries.push({level:"error",message:stripVTControlCharacters(e.map(Xr).join(" ")),timestamp:new Date().toISOString()}),this.originalError.apply(console,e);});}stop(){this.capturing&&(this.capturing=false,console.log=this.originalLog,console.warn=this.originalWarn,console.error=this.originalError);}log(e){this.capture("info",e);}warn(e,t){this.capture("warn",e,t?.code);}error(e,t){this.capture("error",e,t?.code);}record(e,t,r){this.entries.push({level:e,message:stripVTControlCharacters(t),timestamp:new Date().toISOString(),code:r});}getEntries(){return [...this.entries]}hasErrors(){return this.entries.some(e=>e.level==="error")}hasWarnings(){return this.entries.some(e=>e.level==="warn")}getReportableErrors(){return this.entries.filter(e=>e.level==="error"&&(!e.code||!Yr.has(e.code)))}hasReportableErrors(){return this.entries.some(e=>e.level==="error"&&(!e.code||!Yr.has(e.code)))}capture(e,t,r){this.entries.push({level:e,message:stripVTControlCharacters(t),timestamp:new Date().toISOString(),code:r});let o=e==="info"?this.originalLog:e==="warn"?this.originalWarn:this.originalError;this.capturing?o.call(console,t):console[e==="info"?"log":e](t);}};});function Be(i){if(i&&typeof i=="object")try{i.alreadyReported=!0;}catch{}}function pe(i){return !!(i&&typeof i=="object"&&i.alreadyReported)}function Qr(i){if(typeof i=="string")return i;if(i instanceof Error)return i.message;if(typeof i=="object"&&i!==null)try{return JSON.stringify(i)}catch{return String(i)}return String(i)}var co,Vc,Jc,rr,Zr=f(()=>{Le();ao();lo();M();co=Math.floor(1e3/15),Vc={interval:100,frames:["\u280B","\u2819","\u281A","\u2813"]},Jc=new Set(["EPIPE","ENOTCONN","EBADF"]);rr=class i{static activeInstance=null;mode;stream;logCollector=new tr;spinner=null;currentPhaseLabel=null;currentPhaseTracker=null;lastUpdateAt=0;pendingUpdate=null;pendingUpdateTimer=null;paused=false;originalConsole=null;intercepting=false;warningBucket=new Map;stopped=false;constructor(e){if(i.activeInstance&&!i.activeInstance.stopped)throw new Error("Reporter is a singleton \u2014 only one instance may be active at a time. Call stop() on the existing Reporter before constructing another.");this.mode=e.mode,this.stream=e.stream??process.stderr,i.activeInstance=this,this.installConsoleInterception();}async phase(e,t,r){this.start(e);let o=this.makePhaseContext();try{let s=await t(o);return this.flushPendingUpdate(),this.flushAggregatedWarnings(),this.succeed(r?.successText??e),s}catch(s){this.flushPendingUpdate(),this.flushAggregatedWarnings();let a=r?.failText??`${e} failed: ${s instanceof Error?s.message:String(s)}`,l=s&&typeof s=="object"&&"errorCode"in s?s.errorCode:void 0;throw this.fail(a,l?{code:l}:void 0),Be(s),s}}start(e){this.currentPhaseLabel=e,this.currentPhaseTracker=so(),this.mode==="spinner"?(this.spinner?this.spinner.text=this.composeSpinnerText(e):this.spinner=Kc({text:this.composeSpinnerText(e),stream:this.stream,spinner:Vc}),this.paused||this.spinner.start()):(this.mode==="verbose"||this.mode==="plain")&&this.writeLine(`${ie} ${e}\u2026`);}update(e){if(!this.currentPhaseLabel)return;if(this.currentPhaseLabel=e,this.mode==="verbose"){this.writeLine(`${ie} ${e}`);return}if(this.mode!=="spinner")return;let t=Date.now();this.pendingUpdate=e;let r=t-this.lastUpdateAt;r>=co?this.flushPendingUpdate():this.pendingUpdateTimer||(this.pendingUpdateTimer=setTimeout(()=>this.flushPendingUpdate(),co-r),this.pendingUpdateTimer.unref?.());}succeed(e){this.flushPendingUpdate();let t=e??this.currentPhaseLabel??"",r=`${w} ${t}`;this.terminatePhase(r,"info");}fail(e,t){this.flushPendingUpdate();let r=e??this.currentPhaseLabel??"",o=`${re} ${r}`;this.terminatePhase(o,"error",t?.code);}info(e){if(this.mode==="quiet"){this.logCollector.record("info",e);return}this.logCollector.record("info",e),this.writeLine(`${ie} ${e}`);}warn(e,t){if(this.logCollector.record("warn",e,t?.code),this.currentPhaseLabel&&t?.code){let r=this.warningBucket.get(t.code);r?(r.count+=1,r.samples.length<3&&r.samples.push(e)):this.warningBucket.set(t.code,{code:t.code,count:1,samples:[e]});return}this.writeLine(`${A} ${e}`);}error(e,t){this.logCollector.record("error",e,t?.code),this.writeLine(`${re} ${e}`);}detail(e){this.logCollector.record("info",e),this.mode==="verbose"&&this.writeLine(` ${V.muted(e)}`);}log(e){this.logCollector.record("info",e),this.mode!=="quiet"&&this.writeLine(e);}summary(e){this.logCollector.record("info",e),this.writeLine(e);}step(e){let t=this;return {ok(r){t.renderSubStep("ok",r??e);},fail(r,o){t.renderSubStep("fail",r??e,o?.code);},skip(r){t.renderSubStep("skip",r??e);}}}renderSubStep(e,t,r){let s=`${e==="ok"?w:e==="fail"?re:V.muted("-")} ${e==="skip"?V.muted(t):t}`,a=e==="fail"?"error":"info";this.logCollector.record(a,t,r),!(this.mode==="quiet"&&e!=="fail")&&this.writeLine(s);}pause(){this.paused||(this.paused=true,this.spinner?.isSpinning&&this.spinner.stop());}resume(){this.paused&&(this.paused=false,this.mode==="spinner"&&this.currentPhaseLabel&&this.spinner&&(this.spinner.text=this.composeSpinnerText(this.currentPhaseLabel),this.spinner.start()));}getEntries(){return this.logCollector.getEntries()}getReportableErrors(){return this.logCollector.getReportableErrors()}hasErrors(){return this.logCollector.hasErrors()}hasWarnings(){return this.logCollector.hasWarnings()}hasReportableErrors(){return this.logCollector.hasReportableErrors()}stop(){this.stopped||(this.stopped=true,this.pendingUpdateTimer&&(clearTimeout(this.pendingUpdateTimer),this.pendingUpdateTimer=null),this.flushAggregatedWarnings(),this.spinner?.isSpinning&&this.spinner.stop(),this.spinner=null,this.uninstallConsoleInterception(),i.activeInstance===this&&(i.activeInstance=null));}composeSpinnerText(e){return e}flushPendingUpdate(){if(this.pendingUpdateTimer&&(clearTimeout(this.pendingUpdateTimer),this.pendingUpdateTimer=null),this.pendingUpdate===null||!this.spinner){this.pendingUpdate=null;return}this.spinner.text=this.composeSpinnerText(this.pendingUpdate),this.pendingUpdate=null,this.lastUpdateAt=Date.now();}terminatePhase(e,t,r){this.logCollector.record(t,e,r),this.spinner?.isSpinning&&this.spinner.stop(),this.mode!=="quiet"&&this.writeLine(e),this.currentPhaseLabel=null,this.currentPhaseTracker=null;}flushAggregatedWarnings(){if(this.warningBucket.size!==0){for(let{code:e,count:t,samples:r}of this.warningBucket.values()){if(t===1){this.writeLine(`${A} ${r[0]}`);continue}let o=`${t} ${e} warnings (showing ${Math.min(r.length,3)}): ${r.slice(0,3).join(" | ")}. Use --verbose to see all.`;this.logCollector.record("warn",o,e),this.writeLine(`${A} ${o}`);}this.warningBucket.clear();}}makePhaseContext(){return {update:e=>this.update(e),detail:e=>this.detail(e),step:e=>this.step(e),warn:(e,t)=>this.warn(e,t),elapsed:()=>this.currentPhaseTracker?.elapsed()??"(0.0s)"}}writeLine(e){try{this.mode==="spinner"&&this.spinner?.isSpinning?(this.spinner.clear(),this.stream.write(e+`
55
54
  `),this.spinner.text=this.spinner.text):this.stream.write(e+`
56
- `);}catch(t){let n=t?.code;if(n&&Gc.has(n))return;try{process.stderr.write(`reporter write failed: ${String(t)}
57
- `);}catch{}}}installConsoleInterception(){this.intercepting||(this.intercepting=true,this.originalConsole={log:console.log,warn:console.warn,error:console.error},console.log=(...e)=>{let t=e.map(Jr).join(" ");this.logCollector.record("info",t),this.writeLine(t);},console.warn=(...e)=>{let t=e.map(Jr).join(" ");this.logCollector.record("warn",t),this.writeLine(t);},console.error=(...e)=>{let t=e.map(Jr).join(" ");this.logCollector.record("error",t),this.writeLine(t);});}uninstallConsoleInterception(){!this.intercepting||!this.originalConsole||(this.intercepting=false,console.log=this.originalConsole.log,console.warn=this.originalConsole.warn,console.error=this.originalConsole.error,this.originalConsole=null);}};});function Bc(i){let e=[];for(let t=0;t<i.childCount;t++){let n=i.child(t);if(n){if(n.type==="identifier")e.push({local:n.text,original:"default",isDefault:true,isNamespace:false});else if(n.type==="namespace_import"){let o;for(let s=0;s<n.childCount;s++){let a=n.child(s);if(a?.type==="identifier"){o=a.text;break}}o!==void 0&&e.push({local:o,original:void 0,isDefault:false,isNamespace:true});}else if(n.type==="named_imports")for(let o=0;o<n.childCount;o++){let s=n.child(o);if(!s||s.type!=="import_specifier")continue;let a=s.childForFieldName("name"),l=s.childForFieldName("alias");if(!a)continue;let c=a.text,u=l?l.text:c,p=c==="default";e.push({local:u,original:c,isDefault:p,isNamespace:false});}}}return e}async function zc(i,e,t,n){let o=i.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,""),l=i.childForFieldName("import_clause"),c=l?Bc(l):[];await ge(a,s,e,t,n,c);}async function Wc(i,e,t,n){let o=i.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,"");await ge(a,s,e,t,n,[]);}function rr(){return {language:"javascript",handlers:new Map([["import_statement",zc],["export_statement",Wc]])}}function Yr(){return {...rr(),language:"typescript"}}var Xr=f(()=>{Ze();});var uo,mo=f(()=>{Xr();Ut();Ze();Xr();Ut();uo=[rr(),Yr(),Ur()];});var go={};_n(go,{ImportExtractor:()=>Qr});var Qr,fo=f(()=>{mo();Ze();Qr=class{languageHandlers;classifiers;constructor(e){this.languageHandlers=new Map,this.classifiers=new Map;for(let t of e??uo)this.languageHandlers.set(t.language,t.handlers),t.classifyImportType&&this.classifiers.set(t.language,t.classifyImportType);}async extractImportResolutions(e,t,n,o){if(!o)return {};let s=this.languageHandlers.get(n);if(!s)return {};let a=this.classifiers.get(n)??Mr,l={};return await this.walkAST(e.rootNode,async c=>{let u=s.get(c.type);u&&await u(c,o,l,a);}),l}async walkAST(e,t){await t(e);for(let n=0;n<e.childCount;n++){let o=e.child(n);o&&await this.walkAST(o,t);}}};});var it,ho,Zr,yo,vo,nr=f(()=>{it=new Set(["identifier","property_identifier","type_identifier","shorthand_property_identifier","string","string_literal","template_string","number","import_specifier","export_specifier","accessibility_modifier","readonly","static","async","await","const","let","var","decorator","=","=>","...","?","!","string_content"]),ho=new Set(["true","false","null","undefined","predefined_type","type_predicate","type_predicate_annotation","type_alias","type_annotation","return_type","type_arguments","type_parameters","array_type","union_type","intersection_type","generic_type","tuple_type","function_type","object_type","mapped_type","conditional_type","infer_type"]),Zr={function_declaration:["name","parameters","body","return_type","type_parameters"],function_expression:["name","parameters","body","return_type","type_parameters"],arrow_function:["parameters","body","return_type","type_parameters"],method_definition:["name","parameters","body","return_type","type_parameters"],method_signature:["name","parameters","return_type","type_parameters"],function_signature:["name","parameters","return_type","type_parameters"],type_predicate:["name","type"],class_declaration:["name","body","type_parameters","heritage"],interface_declaration:["name","body","type_parameters"],type_alias_declaration:["name","type_parameters","value"],property_signature:["name","type"],field_definition:["name","type","value"],public_field_definition:["name","type","value"],private_field_definition:["name","type","value"],required_parameter:["pattern","type","value"],optional_parameter:["pattern","type","value"],rest_parameter:["pattern","type"],variable_declarator:["name","type","value"],lexical_declaration:["kind"],call_expression:["function","arguments","type_arguments"],new_expression:["constructor","arguments","type_arguments"],member_expression:["object","property"],assignment_expression:["left","right"],binary_expression:["left","right","operator"],unary_expression:["operator","argument"],ternary_expression:["condition","consequence","alternative"],import_statement:["source","import"],import_specifier:["name","alias"],export_specifier:["name","alias"],export_statement:["source","declaration","value"],if_statement:["condition","consequence","alternative"],for_statement:["init","condition","update","body"],for_in_statement:["left","right","body"],while_statement:["condition","body"],do_statement:["body","condition"],switch_statement:["value","body"],try_statement:["body","handler","finalizer"],catch_clause:["parameter","body"],return_statement:["value"],throw_statement:["value"],type_annotation:["type"],type_parameter:["name","constraint","default"],generic_type:["name","type_arguments"]},yo={language:"javascript",textIncludedTypes:ho,fieldNames:Zr},vo={language:"typescript",textIncludedTypes:ho,fieldNames:Zr};});var Hc,bo,So,en=f(()=>{Hc=new Set(["true","false","none","None","True","False","yield","pass","continue","break","ellipsis","dotted_name","aliased_import","not_operator","boolean_operator","comparison_operator","type","subscript","attribute","list","tuple","binary_operator","union_type","generic_type"]),bo={function_definition:["name","parameters","return_type","body","type_parameters"],async_function_definition:["name","parameters","return_type","body","type_parameters"],class_definition:["name","superclasses","body","type_parameters"],decorated_definition:["definition"],lambda:["parameters","body"],import_statement:["name"],import_from_statement:["module_name","name"],aliased_import:["name","alias"],assignment:["left","right","type"],augmented_assignment:["left","right"],type_alias_statement:["name","type_parameters","value"],annotated_assignment:["left","right","type"],except_clause:["cause"],except_group_clause:["cause"],return_statement:["value"],assert_statement:["condition","message"],delete_statement:["target"],global_statement:["name"],nonlocal_statement:["name"],typed_parameter:["name","type"],default_parameter:["name","value"],typed_default_parameter:["name","type","value"],list_splat_pattern:[],dictionary_splat_pattern:[],call:["function","arguments"],attribute:["object","attribute"],binary_operator:["left","right"],unary_operator:["argument"],not_operator:["argument"],boolean_operator:["left","right"],comparison_operator:["operators"],named_expression:["name","value"],conditional_expression:["condition","consequence","alternative"],keyword_argument:["name","value"],if_statement:["condition","consequence","alternative"],while_statement:["condition","body","alternative"],for_statement:["left","right","body"],try_statement:["body"],with_statement:["body"],with_item:["value"],finally_clause:["body"],else_clause:["body"],match_statement:["subject","body"],case_clause:["pattern","guard"],raise_statement:["cause"],list_comprehension:["body"],dictionary_comprehension:["body","key","value"],set_comprehension:["body"],generator_expression:["body"],for_in_clause:["left","right"],if_clause:["condition"],pair:["key","value"],subscript:["value","subscript"],slice:["start","stop","step"]},So={language:"python",textIncludedTypes:Hc,fieldNames:bo,shouldIncludeText:i=>{if(i.type==="string"&&i.childCount>0)return false}};});function wo(i){return ot.get(i)}function Co(i){if(!i)return it;let e=ot.get(i);if(!e)return it;let t=new Set(it);for(let n of e.textIncludedTypes)t.add(n);return t}function tn(i){if(!i){let t=Array.from(ot.values()).map(n=>n.fieldNames);return st(...t)}let e=ot.get(i);if(!e){let t=Array.from(ot.values()).map(n=>n.fieldNames);return st(...t)}return e.fieldNames}var ot,xo=f(()=>{rn();nr();en();nr();nr();en();ot=new Map([["javascript",yo],["typescript",vo],["python",So]]);});var No={};_n(No,{COMMON_FIELD_NAMES:()=>sn,JS_TS_FIELD_NAMES:()=>Po,PYTHON_FIELD_NAMES:()=>Io,TEXT_INCLUDED_TYPES:()=>Eo,mergeFieldMaps:()=>st,serializeAST:()=>Vc,serializeASTStream:()=>Kc});function*Kc(i,e,t){yield*on(i,e,t);}function*on(i,e,t){if(yield "{",yield `"type":${JSON.stringify(i.type)}`,yield `,"startPosition":${JSON.stringify({row:i.startPosition.row,column:i.startPosition.column})}`,yield `,"endPosition":${JSON.stringify({row:i.endPosition.row,column:i.endPosition.column})}`,e&&(yield `,"fieldName":${JSON.stringify(e)}`),_o(i,t)&&(yield `,"text":${JSON.stringify(i.text)}`),i.childCount>0){yield ',"children":[';let o=(t?tn(t):sn)[i.type]||[],s=new Set,a=true;for(let l of o){let c=i.childForFieldName(l);c&&(a||(yield ","),a=false,s.add(c),yield*on(c,l,t));}for(let l=0;l<i.childCount;l++){let c=i.child(l);c&&!s.has(c)&&(a||(yield ","),a=false,yield*on(c,void 0,t));}yield "]";}yield "}";}async function Vc(i,e,t){let n=nn(i,e,t),o=t?tn(t):sn,s=[{treeNode:i,serializedNode:n,fieldName:e,childIndex:0,fieldChildren:new Set}];for(;s.length>0;){let a=s[s.length-1];if(a.childIndex===0&&a.treeNode.childCount>0){let l=o[a.treeNode.type]||[];for(let c of l){let u=a.treeNode.childForFieldName(c);if(u){a.fieldChildren.add(u);let p=nn(u,c,t);a.serializedNode.children||(a.serializedNode.children=[]),a.serializedNode.children.push(p),s.push({treeNode:u,serializedNode:p,fieldName:c,childIndex:0,fieldChildren:new Set});}}}if(a.childIndex<a.treeNode.childCount){let l=a.treeNode.child(a.childIndex);if(a.childIndex++,l&&!a.fieldChildren.has(l)){let c=nn(l,void 0,t);a.serializedNode.children||(a.serializedNode.children=[]),a.serializedNode.children.push(c),s.push({treeNode:l,serializedNode:c,childIndex:0,fieldChildren:new Set});}}else s.pop();}return n}function nn(i,e,t){let n={type:i.type,startPosition:{row:i.startPosition.row,column:i.startPosition.column},endPosition:{row:i.endPosition.row,column:i.endPosition.column},...e&&{fieldName:e}};return _o(i,t)&&(n.text=i.text),n}function _o(i,e){if(e){let n=wo(e);if(n?.shouldIncludeText){let s=n.shouldIncludeText(i);if(s===false)return false;if(s===true)return true}return Co(e).has(i.type)||i.type.endsWith("_keyword")||i.type.endsWith("_operator")}return i.type==="string"&&i.childCount>0?false:Eo.has(i.type)||i.type.endsWith("_keyword")||i.type.endsWith("_operator")}function st(...i){let e={};for(let t of i)for(let[n,o]of Object.entries(t)){let a=[...e[n]||[]];for(let l of o)a.includes(l)||a.push(l);e[n]=a;}return e}var Eo,Po,Io,sn,rn=f(()=>{xo();Eo=new Set(["identifier","property_identifier","type_identifier","shorthand_property_identifier","string","string_literal","string_fragment","number","true","false","null","undefined","import_specifier","export_specifier","predefined_type","type_predicate","type_predicate_annotation","type_alias","type_annotation","return_type","type_arguments","type_parameters","array_type","union_type","intersection_type","generic_type","tuple_type","function_type","object_type","mapped_type","conditional_type","infer_type","accessibility_modifier","readonly","static","async","await","const","let","var","decorator","=","=>","...","?","!","dotted_name","aliased_import","not_operator","boolean_operator","comparison_operator","yield","pass","continue","break","None","none","True","False","ellipsis","type","string_content"]);Po={function_declaration:["name","parameters","body","return_type","type_parameters"],function_expression:["name","parameters","body","return_type","type_parameters"],arrow_function:["parameters","body","return_type","type_parameters"],method_definition:["name","parameters","body","return_type","type_parameters"],method_signature:["name","parameters","return_type","type_parameters"],function_signature:["name","parameters","return_type","type_parameters"],type_predicate:["name","type"],class_declaration:["name","body","type_parameters","heritage"],interface_declaration:["name","body","type_parameters"],type_alias_declaration:["name","type_parameters","value"],property_signature:["name","type"],field_definition:["name","type","value"],public_field_definition:["name","type","value"],private_field_definition:["name","type","value"],required_parameter:["pattern","type","value"],optional_parameter:["pattern","type","value"],rest_parameter:["pattern","type"],variable_declarator:["name","type","value"],lexical_declaration:["kind"],call_expression:["function","arguments","type_arguments"],new_expression:["constructor","arguments","type_arguments"],member_expression:["object","property"],assignment_expression:["left","right"],binary_expression:["left","right","operator"],unary_expression:["operator","argument"],ternary_expression:["condition","consequence","alternative"],import_statement:["source","import"],import_specifier:["name","alias"],export_specifier:["name","alias"],export_statement:["source","declaration","value"],if_statement:["condition","consequence","alternative"],for_statement:["init","condition","update","body"],for_in_statement:["left","right","body"],while_statement:["condition","body"],do_statement:["body","condition"],switch_statement:["value","body"],try_statement:["body","handler","finalizer"],catch_clause:["parameter","body"],return_statement:["value"],throw_statement:["value"],type_annotation:["type"],type_parameter:["name","constraint","default"],generic_type:["name","type_arguments"]},Io={function_definition:["name","parameters","return_type","body","type_parameters"],async_function_definition:["name","parameters","return_type","body","type_parameters"],class_definition:["name","superclasses","body","type_parameters"],decorated_definition:["definition"],lambda:["parameters","body"],import_statement:["name"],import_from_statement:["module_name","name"],aliased_import:["name","alias"],assignment:["left","right","type"],augmented_assignment:["left","right"],type_alias_statement:["name","type_parameters","value"],annotated_assignment:["left","right","type"],except_clause:["cause"],except_group_clause:["cause"],return_statement:["value"],assert_statement:["condition","message"],delete_statement:["target"],global_statement:["name"],nonlocal_statement:["name"],typed_parameter:["name","type"],default_parameter:["name","value"],typed_default_parameter:["name","type","value"],call:["function","arguments"],attribute:["object","attribute"],binary_operator:["left","right"],unary_operator:["argument"],not_operator:["argument"],boolean_operator:["left","right"],comparison_operator:["operators"],named_expression:["name","value"],conditional_expression:["condition","consequence","alternative"],keyword_argument:["name","value"],if_statement:["condition","consequence","alternative"],while_statement:["condition","body","alternative"],for_statement:["left","right","body"],try_statement:["body"],with_statement:["body"],with_item:["value"],finally_clause:["body"],else_clause:["body"],match_statement:["subject","body"],case_clause:["pattern","guard"],raise_statement:["cause"],list_comprehension:["body"],dictionary_comprehension:["body","key","value"],set_comprehension:["body"],generator_expression:["body"],for_in_clause:["left","right"],if_clause:["condition"],pair:["key","value"],subscript:["value","subscript"],slice:["start","stop","step"]};sn=st(Po,Io);});var at,Ro=f(()=>{Tr();oi();ai();vi();Qe();Ht();Ui();Bi();Wi();Vi();Yi();wt();Xt();ve();jr();so();qr();O();Ct();at=class extends ce{scanner;parser;apiClient;compressor;buildConfigManagers=new Map;discoveredFiles=[];parseSymbols=new Map;parseContent=new Map;symbolExtractor=new Qt;constructor(e){if(super(e),!this.config||!this.langRegistry)throw new Error("index command requires a valid configuration");this.scanner=new qt(process.cwd()),this.parser=new Jt(this.langRegistry),this.compressor=new Yt;for(let t of Object.keys(this.config.languages)){let n=this.langRegistry.getPlugin(t);if(n?.getBuildConfigManager){let o=n.getBuildConfigManager(process.cwd(),this.config.languages);o&&this.buildConfigManagers.set(t,o);}}}async run(e=false,t=false,n=false){if(!this.reporter)throw new Error("IndexCommand requires a Reporter dependency");let o="failed";try{let s=await this.getAccessKey();this.apiClient=new Pt(this.config,s,t,this.reporter),this.reporter.log(`${ae} Starting indexing procedure...
58
- `);let a=performance.now();await this.reporter.phase("Pre-flight checks",async _=>{let k=_.step("Project access");await this.validateProject(),k.ok("Project access validated");let P=_.step("Git branch");t?P.skip("Git branch validation skipped (--dirty)"):(await this.validateGitBranch(),P.ok("Git branch validated"));let D=_.step("Git status");t?D.skip("Git status validation skipped (--dirty)"):(await this.validateGitStatus(),D.ok("Working tree clean"));let F=_.step("Repo sync");if(t?F.skip("Repository sync skipped (--dirty)"):(await this.synchronizeChanges(),F.ok("Repository synchronized")),this.buildConfigManagers.size>0){let Q=_.step("Build configs"),ft=0;for(let[,cs]of this.buildConfigManagers.entries()){let ps=await cs.initialize();ft+=ps.length;}Q.ok(ft>0?`${ft} build config(s) discovered`:"No build configs discovered");}},{successText:"Pre-flight checks complete"});let l=await this.reporter.phase("Determining index scope",()=>this.determineIndexScope(e),{successText:e?"Full index":"Index scope determined"}),c=await this.git.getLatestCommitHash(),u=await this.git.getCommitTimestamp();if(l.upToDate){this.reporter.summary(`${w} Index is already up-to-date for ${this.config.projectId} on ${this.config.branch} commit ${c.substring(0,8)}`),o="succeeded";return}let p=await this.reporter.phase("Claiming indexing lock",()=>this.apiClient.claimAstLock(this.config.projectId,this.config.branch,l.isIncremental,c,u),{successText:"Indexing lock claimed"});switch(p.remapped===!0&&(p.effectiveBranchName?this.reporter.warn(`--dirty: server is indexing as default branch "${p.effectiveBranchName}" (transmitted "${this.config.branch}").`):this.reporter.warn("--dirty: server reported a branch remap but did not include the effective branch name.")),p.status){case "current":this.reporter.summary(`${w} Index already up to date for branch ${this.config.branch} at commit ${c?.substring(0,8)||"unknown"}`),o="succeeded";return;case "duplicate":this.reporter.summary(`${w} Index for this commit is already in progress on the server.`),o="succeeded";return;case "superseded":this.reporter.summary(`${w} A newer commit is already being indexed; nothing to do.`),o="succeeded";return;case "queued":if(!p.queuedAttemptId)throw new Error("Server returned queued status without an attempt ID");await this.handleQueuedUpload(p.queuedAttemptId,l.isIncremental,c,u),o="succeeded";return;default:break}let d=!1,m=()=>{d||this.reporter.detail("Uploading metadata, processing, and indexing...");},g,h,b=new Promise((_,k)=>{g=_,h=k;}),y=new AbortController,v=()=>{},x=this.createIndexPipeline(l.isIncremental,u,m,g,(_,k)=>v(_,k)),j=null;try{let[,_]=await this.reporter.phase("Indexing files",async k=>(v=(P,D)=>{if(D<=0)return;let F=Math.min(100,Math.round(P/D*100));k.update(`Indexing files ${F}% (${P}/${D})`);},Promise.all([this.uploadToAPI(x,l.isIncremental,c,p.attemptId).then(P=>(d=!0,P)).catch(P=>{throw y.abort(P),h(P),d=!0,P}),b.then(P=>{let D=this.getEnrichmentEligibleLanguages(n,P);return D?(p.attemptId&&this.apiClient.startEnrichment(p.attemptId,this.config.projectId,this.config.branch),this.runLspEnrichment(P,D,this.parseSymbols,this.parseContent,y.signal).catch(F=>(y.signal.aborted||this.reporter.warn(`Index enrichment failed: ${F instanceof Error?F.message:String(F)}`,{code:"ENRICHMENT_FAILED"}),null))):null}).catch(()=>null)])),{successText:"Files indexed and uploaded"});j=_;}catch(_){throw d=!0,_}j&&j.length>0&&await this.reporter.phase("Server processing & enrichment upload",async()=>{try{let _=this.discoveredFiles.length,k=qi(_),P=Math.round(k/1e3);this.reporter.detail(`Waiting for server to finish syntax tree processing (${_} files, timeout ${P}s)...`);let D=await this.apiClient.pollIndexStatus(this.config.projectId,this.config.branch,c,k),F=si(j);if(D){this.reporter.detail(`Uploading enrichment data (${j.length} files)...`);let Q=!1;try{Q=await this.apiClient.uploadEnrichment(F,this.config.projectId,this.config.branch,c);}catch{}Q?this.reporter.detail("Enrichment data uploaded to Constellation Service, index enhancement in progress"):this.reporter.warn("Enrichment upload failed \u2014 re-run 'constellation index --full' after the server finishes AST processing to retry.",{code:"ENRICHMENT_FAILED"});}else {this.reporter.warn(`AST processing not complete after ${P}s \u2014 attempting enrichment upload anyway.`);let Q=!1;try{Q=await this.apiClient.uploadEnrichment(F,this.config.projectId,this.config.branch,c);}catch{}Q?this.reporter.detail("Enrichment data uploaded to Constellation Service, index enhancement in progress"):this.reporter.warn("Enrichment upload failed \u2014 re-run 'constellation index --full' after the server finishes AST processing to retry.",{code:"ENRICHMENT_FAILED"});}}catch(_){this.reporter.warn(`Enrichment upload failed: ${_ instanceof Error?_.message:String(_)}`,{code:"ENRICHMENT_FAILED"});}},{successText:"Server processing complete"});let N=(performance.now()-a)/1e3,X=Math.floor(N/60),se=(N%60).toFixed(3),ye=X>0?`${X}m ${se}s`:`${se}s`;this.reporter.summary(`
59
- ${w} Upload completed in ${ye}! Server indexing in progress.`),o="succeeded";}catch(s){if(s instanceof te)throw s;if(s instanceof Te){this.logIndexingInProgress(s.branchName||this.config?.branch),o="succeeded";return}if(s instanceof R)throw ie(s)||(this.reporter.error("Authentication failed.",{code:"AUTH_FAILURE"}),this.reporter.info(`Your access key may be invalid or expired. Run 'constellation auth'
60
- to set or update your access key.`),Me(s)),s;if(s instanceof ue)throw s;if(s instanceof Error&&s.message==="Access key not configured")throw Me(s),s;if(ie(s))throw s;let a=s instanceof Error?s.message:"An unexpected error occurred";throw this.reporter.error(`Indexing failed: ${a}`),Me(s),s}finally{this.parseSymbols.clear(),this.parseContent.clear();try{let a=process.env.CONSTELLATION_ERROR_REPORTING?.toLowerCase()==="false",l=this.apiClient?.isFeatureEnabled("cli_error_reporting")??!1,c=this.reporter.getReportableErrors();if(!a&&l&&c.length>0){let u=this.reporter.getEntries(),p=c.map(v=>({type:"CLI_ERROR",message:v.message,phase:"indexing"})).slice(0,100),d=u.filter(v=>v.level==="warn").map(v=>({type:"CLI_WARNING",message:v.message,phase:"indexing"})).slice(0,100),m=p.length,g=d.length,h=[];m>0&&h.push(`${m} error${m!==1?"s":""}`),g>0&&h.push(`${g} warning${g!==1?"s":""}`);let b=h.join(", "),y=globalThis.__constellationVersion??"unknown";await this.apiClient.reportErrors({errorSummary:b,errorData:{errors:p,warnings:d},logEntries:u.slice(0,1e3),cliVersion:y,outcome:o,indexType:e?"full":"incremental"});}}catch{}}}async getAccessKey(){let e=await this.env.getKey(le);if(!e)throw this.reporter.error("Access key not found.",{code:"ACCESS_KEY_MISSING"}),this.reporter.info(`Set the ${le} environment variable or run
61
- 'constellation auth' to configure your access key.`),new Error("Access key not configured");return e}async validateProject(){this.reporter.detail("Validating project access...");try{await this.apiClient.getProjectState(),this.reporter.detail("Project validated successfully");}catch(e){if(e instanceof te)throw this.displayProjectValidationError(e),Me(e),e;if(e instanceof pe){this.reporter.detail("Project validated (first index)");return}if(e instanceof R)throw e;let t=e instanceof Error?e.message:String(e);throw t==="fetch failed"||t.includes("ECONNREFUSED")||t.includes("ENOTFOUND")||t.includes("ETIMEDOUT")||t.includes("EHOSTUNREACH")||t.includes("ECONNRESET")?new Error(`Unable to connect to the Constellation service.
62
- Verify your network connection and that the API URL is correct.`):e}}displayProjectValidationError(e){let t=e.projectId||this.config.projectId,n=t.length>40?t.substring(0,37)+"...":t;switch(e.code){case "PROJECT_NOT_REGISTERED":this.reporter.error("Project not registered",{code:"PROJECT_NOT_REGISTERED"}),this.reporter.log(` The project ID "${n}" in constellation.json`),this.reporter.log(` is not associated with your Constellation account.
55
+ `);}catch(t){let r=t?.code;if(r&&Jc.has(r))return;try{process.stderr.write(`reporter write failed: ${String(t)}
56
+ `);}catch{}}}installConsoleInterception(){this.intercepting||(this.intercepting=true,this.originalConsole={log:console.log,warn:console.warn,error:console.error},console.log=(...e)=>{let t=e.map(Qr).join(" ");this.logCollector.record("info",t),this.writeLine(t);},console.warn=(...e)=>{let t=e.map(Qr).join(" ");this.logCollector.record("warn",t),this.writeLine(t);},console.error=(...e)=>{let t=e.map(Qr).join(" ");this.logCollector.record("error",t),this.writeLine(t);});}uninstallConsoleInterception(){!this.intercepting||!this.originalConsole||(this.intercepting=false,console.log=this.originalConsole.log,console.warn=this.originalConsole.warn,console.error=this.originalConsole.error,this.originalConsole=null);}};});var Yc,nr,mo=f(()=>{Lr();Yc=promisify(en__default.gunzip),nr=class{*serializeASTChunks(e){if(yield "{",yield `"type":"${e.type}"`,yield `,"startPosition":${JSON.stringify(e.startPosition)}`,yield `,"endPosition":${JSON.stringify(e.endPosition)}`,e.fieldName!==void 0&&(yield `,"fieldName":"${e.fieldName}"`),e.text!==void 0&&(yield `,"text":${JSON.stringify(e.text)}`),e.children&&e.children.length>0){yield ',"children":[';for(let t=0;t<e.children.length;t++)t>0&&(yield ","),yield*this.serializeASTChunks(e.children[t]);yield "]";}yield "}";}async compressStream(e){let t=[],r=en__default.createGzip();r.on("data",a=>t.push(a));let o=new Promise((a,l)=>{r.on("end",a),r.on("error",l);}),s=Readable.from(e);return await pipeline(s,r),await o,Tr(Buffer.concat(t)).toString("base64")}async compress(e){let t=[],r=en__default.createGzip();r.on("data",a=>t.push(a));let o=new Promise((a,l)=>{r.on("end",a),r.on("error",l);}),s=Readable.from(this.serializeASTChunks(e));return await pipeline(s,r),await o,Tr(Buffer.concat(t)).toString("base64")}async decompress(e){let t=Buffer.from(e,"base64"),r=await Yc(t);return JSON.parse(r.toString("utf-8"))}};});function fo(i){let r=i>=5e4?27e5:i>=1e4?18e5:9e5,o=process.env.CONSTELLATION_AST_WAIT_MAX_MS,s=r;if(o!==void 0&&o!==""){let a=Number(o);Number.isFinite(a)&&Number.isInteger(a)&&a>0?s=a:go||(process.stderr.write(`[constellation] Ignoring invalid CONSTELLATION_AST_WAIT_MAX_MS=${o}; using default tier cap.
57
+ `),go=true);}return Math.min(12e4+i*1e3,s)}var go,ho=f(()=>{go=false;});function He(i,e){let t=e??i;return {line:t.startPosition.row+1,column:t.startPosition.column}}function We(i){return i?i.text:null}function ir(i,e,t){for(let r=i.parent;r;r=r.parent){if(r.type==="export_statement")return true;if(r.type==="internal_module")break}return t.exportedNames?.has(e)??false}function bo(i){let e=new Set,t=r=>{if(r.type==="export_statement"&&!Xc(r))for(let o=0;o<r.childCount;o++){let s=r.child(o);if(s)if(s.type==="export_clause")for(let a=0;a<s.childCount;a++){let l=s.child(a);if(l?.type!=="export_specifier")continue;let c=l.child(0);c?.type==="identifier"&&e.add(c.text);}else s.type==="identifier"&&e.add(s.text);}for(let o=0;o<r.childCount;o++){let s=r.child(o);s&&t(s);}};return t(i),e}function Xc(i){for(let e=0;e<i.childCount;e++){let t=i.child(e)?.type;if(t==="from"||t==="string")return true}return false}function Co(){return {language:"javascript",handlers:new Map(wo)}}function xo(){return {language:"typescript",handlers:new Map([...wo,["interface_declaration",Zc],["public_field_definition",yo],["property_signature",yo],["function_signature",vo],["method_signature",So]])}}var vo,Qc,Zc,So,yo,ep,wo,tn=f(()=>{vo=(i,e)=>{let t=i.childForFieldName("name"),r=We(t);r&&e.symbols.push({name:r,kind:"function",...He(i,t),isExported:ir(i,r,e)});},Qc=(i,e)=>{let t=i.childForFieldName("name"),r=We(t);if(!r)return;let o=ir(i,r,e);return e.symbols.push({name:r,kind:"class",...He(i,t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},Zc=(i,e)=>{let t=i.childForFieldName("name"),r=We(t);if(!r)return;let o=ir(i,r,e);return e.symbols.push({name:r,kind:"interface",...He(i,t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},So=(i,e)=>{let t=i.childForFieldName("name"),r=We(t);r&&e.symbols.push({name:r,kind:"method",...He(i,t),isExported:e.enclosingExported??false});},yo=(i,e)=>{let t=i.childForFieldName("name"),r=We(t);r&&e.symbols.push({name:r,kind:"property",...He(i,t),isExported:e.enclosingExported??false});},ep=(i,e)=>{let t=i.childForFieldName("name"),r=We(t);if(!r)return;let o=i.childForFieldName("value"),s=o?.type==="arrow_function"||o?.type==="function"||o?.type==="function_expression";e.symbols.push({name:r,kind:s?"function":"variable",...He(i,t),isExported:ir(i,r,e)});},wo=[["function_declaration",vo],["class_declaration",Qc],["method_definition",So],["variable_declarator",ep]];});function rn(i){return {line:i.startPosition.row+1,column:i.startPosition.column}}function nn(i){return !i.startsWith("_")}function Eo(){return {language:"python",handlers:new Map([["function_definition",tp],["class_definition",rp],["assignment",np]])}}var tp,rp,np,_o=f(()=>{tp=(i,e)=>{let t=i.childForFieldName("name");if(!t)return;let r=t.text,o=e.enclosingType?"method":"function",s=nn(r),a=o==="method"?(e.enclosingExported??false)&&s:s;e.symbols.push({name:r,kind:o,...rn(t),isExported:a});},rp=(i,e)=>{let t=i.childForFieldName("name");if(!t)return;let r=t.text,o=nn(r);return e.symbols.push({name:r,kind:"class",...rn(t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},np=(i,e)=>{let t=i.childForFieldName("left");if(!t||t.type!=="identifier")return;let r=t.text,o=e.enclosingType?"property":"variable",s=nn(r),a=o==="property"?(e.enclosingExported??false)&&s:s;e.symbols.push({name:r,kind:o,...rn(t),isExported:a});};});var Po,Io=f(()=>{tn();_o();Po=[Co(),xo(),Eo()];});var or,No=f(()=>{Io();tn();or=class{languageHandlers;constructor(e){this.languageHandlers=new Map;for(let t of e??Po)this.languageHandlers.set(t.language,t.handlers);}extract(e,t){let r=this.languageHandlers.get(t);if(!r)return [];let o=t==="typescript"||t==="javascript"?bo(e.rootNode):void 0,s={symbols:[],exportedNames:o};return this.walk(e.rootNode,s,r),s.symbols}walk(e,t,r){let s=r.get(e.type)?.(e,t)??t;for(let a=0;a<e.childCount;a++){let l=e.child(a);l&&this.walk(l,s,r);}}};});function ip(i){let e=[];for(let t=0;t<i.childCount;t++){let r=i.child(t);if(r){if(r.type==="identifier")e.push({local:r.text,original:"default",isDefault:true,isNamespace:false});else if(r.type==="namespace_import"){let o;for(let s=0;s<r.childCount;s++){let a=r.child(s);if(a?.type==="identifier"){o=a.text;break}}o!==void 0&&e.push({local:o,original:void 0,isDefault:false,isNamespace:true});}else if(r.type==="named_imports")for(let o=0;o<r.childCount;o++){let s=r.child(o);if(!s||s.type!=="import_specifier")continue;let a=s.childForFieldName("name"),l=s.childForFieldName("alias");if(!a)continue;let c=a.text,u=l?l.text:c,p=c==="default";e.push({local:u,original:c,isDefault:p,isNamespace:false});}}}return e}async function op(i,e,t,r){let o=i.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,""),l=i.childForFieldName("import_clause"),c=l?ip(l):[];await le(a,s,e,t,r,c);}async function sp(i,e,t,r){let o=i.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,"");await le(a,s,e,t,r,[]);}async function ap(i,e,t,r){let o=i.childForFieldName("function");if(!o||o.type!=="import")return;let s=i.childForFieldName("arguments");if(!s)return;let a=s.child(1);if(!a)return;let l;if(a.type==="string")l=a.text.slice(1,-1);else if(a.type==="template_string"){let u=a.child(1);l=u?.type==="string_fragment"&&u.text?u.text:"<dynamic>";}else l="<dynamic>";if(!l)return;let c=i.startPosition.row;await le(l,c,e,t,r,[]);}function sr(){return {language:"javascript",handlers:new Map([["import_statement",op],["export_statement",sp],["call_expression",ap]])}}function on(){let i=sr();return {language:"typescript",handlers:new Map(i.handlers)}}var sn=f(()=>{it();});var Ro,To=f(()=>{sn();Ht();it();sn();Ht();Ro=[sr(),on(),Kr()];});var Lo={};kn(Lo,{ImportExtractor:()=>an});var an,jo=f(()=>{To();it();an=class{languageHandlers;classifiers;constructor(e){this.languageHandlers=new Map,this.classifiers=new Map;for(let t of e??Ro)this.languageHandlers.set(t.language,t.handlers),t.classifyImportType&&this.classifiers.set(t.language,t.classifyImportType);}async extractImportResolutions(e,t,r,o){if(!o)return {};let s=this.languageHandlers.get(r);if(!s)return {};let a=this.classifiers.get(r)??zr,l={};return await this.walkAST(e.rootNode,async c=>{let u=s.get(c.type);u&&await u(c,o,l,a);}),l}async walkAST(e,t){await t(e);for(let r=0;r<e.childCount;r++){let o=e.child(r);o&&await this.walkAST(o,t);}}};});var lt,Ao,ln,ko,Fo,ar=f(()=>{lt=new Set(["identifier","property_identifier","type_identifier","shorthand_property_identifier","string","string_literal","template_string","number","import_specifier","export_specifier","accessibility_modifier","readonly","static","async","await","const","let","var","decorator","=","=>","...","?","!","string_content"]),Ao=new Set(["true","false","null","undefined","predefined_type","type_predicate","type_predicate_annotation","type_alias","type_annotation","return_type","type_arguments","type_parameters","array_type","union_type","intersection_type","generic_type","tuple_type","function_type","object_type","mapped_type","conditional_type","infer_type"]),ln={function_declaration:["name","parameters","body","return_type","type_parameters"],function_expression:["name","parameters","body","return_type","type_parameters"],arrow_function:["parameters","body","return_type","type_parameters"],method_definition:["name","parameters","body","return_type","type_parameters"],method_signature:["name","parameters","return_type","type_parameters"],function_signature:["name","parameters","return_type","type_parameters"],type_predicate:["name","type"],class_declaration:["name","body","type_parameters","heritage"],interface_declaration:["name","body","type_parameters"],type_alias_declaration:["name","type_parameters","value"],property_signature:["name","type"],field_definition:["name","type","value"],public_field_definition:["name","type","value"],private_field_definition:["name","type","value"],required_parameter:["pattern","type","value"],optional_parameter:["pattern","type","value"],rest_parameter:["pattern","type"],variable_declarator:["name","type","value"],lexical_declaration:["kind"],call_expression:["function","arguments","type_arguments"],new_expression:["constructor","arguments","type_arguments"],member_expression:["object","property"],assignment_expression:["left","right"],binary_expression:["left","right","operator"],unary_expression:["operator","argument"],ternary_expression:["condition","consequence","alternative"],import_statement:["source","import"],import_specifier:["name","alias"],export_specifier:["name","alias"],export_statement:["source","declaration","value"],if_statement:["condition","consequence","alternative"],for_statement:["init","condition","update","body"],for_in_statement:["left","right","body"],while_statement:["condition","body"],do_statement:["body","condition"],switch_statement:["value","body"],try_statement:["body","handler","finalizer"],catch_clause:["parameter","body"],return_statement:["value"],throw_statement:["value"],type_annotation:["type"],type_parameter:["name","constraint","default"],generic_type:["name","type_arguments"]},ko={language:"javascript",textIncludedTypes:Ao,fieldNames:ln},Fo={language:"typescript",textIncludedTypes:Ao,fieldNames:ln};});var lp,$o,Do,cn=f(()=>{lp=new Set(["true","false","none","None","True","False","yield","pass","continue","break","ellipsis","dotted_name","aliased_import","not_operator","boolean_operator","comparison_operator","type","subscript","attribute","list","tuple","binary_operator","union_type","generic_type"]),$o={function_definition:["name","parameters","return_type","body","type_parameters"],async_function_definition:["name","parameters","return_type","body","type_parameters"],class_definition:["name","superclasses","body","type_parameters"],decorated_definition:["definition"],lambda:["parameters","body"],import_statement:["name"],import_from_statement:["module_name","name"],aliased_import:["name","alias"],assignment:["left","right","type"],augmented_assignment:["left","right"],type_alias_statement:["name","type_parameters","value"],annotated_assignment:["left","right","type"],except_clause:["cause"],except_group_clause:["cause"],return_statement:["value"],assert_statement:["condition","message"],delete_statement:["target"],global_statement:["name"],nonlocal_statement:["name"],typed_parameter:["name","type"],default_parameter:["name","value"],typed_default_parameter:["name","type","value"],list_splat_pattern:[],dictionary_splat_pattern:[],call:["function","arguments"],attribute:["object","attribute"],binary_operator:["left","right"],unary_operator:["argument"],not_operator:["argument"],boolean_operator:["left","right"],comparison_operator:["operators"],named_expression:["name","value"],conditional_expression:["condition","consequence","alternative"],keyword_argument:["name","value"],if_statement:["condition","consequence","alternative"],while_statement:["condition","body","alternative"],for_statement:["left","right","body"],try_statement:["body"],with_statement:["body"],with_item:["value"],finally_clause:["body"],else_clause:["body"],match_statement:["subject","body"],case_clause:["pattern","guard"],raise_statement:["cause"],list_comprehension:["body"],dictionary_comprehension:["body","key","value"],set_comprehension:["body"],generator_expression:["body"],for_in_clause:["left","right"],if_clause:["condition"],pair:["key","value"],subscript:["value","subscript"],slice:["start","stop","step"]},Do={language:"python",textIncludedTypes:lp,fieldNames:$o,shouldIncludeText:i=>{if(i.type==="string"&&i.childCount>0)return false}};});function Oo(i){return ct.get(i)}function Mo(i){if(!i)return lt;let e=ct.get(i);if(!e)return lt;let t=new Set(lt);for(let r of e.textIncludedTypes)t.add(r);return t}function pn(i){if(!i){let t=Array.from(ct.values()).map(r=>r.fieldNames);return pt(...t)}let e=ct.get(i);if(!e){let t=Array.from(ct.values()).map(r=>r.fieldNames);return pt(...t)}return e.fieldNames}var ct,Uo=f(()=>{un();ar();cn();ar();ar();cn();ct=new Map([["javascript",ko],["typescript",Fo],["python",Do]]);});var zo={};kn(zo,{COMMON_FIELD_NAMES:()=>gn,JS_TS_FIELD_NAMES:()=>Ho,PYTHON_FIELD_NAMES:()=>Wo,TEXT_INCLUDED_TYPES:()=>Go,mergeFieldMaps:()=>pt,serializeAST:()=>pp,serializeASTStream:()=>cp});function*cp(i,e,t){yield*mn(i,e,t);}function*mn(i,e,t){if(yield "{",yield `"type":${JSON.stringify(i.type)}`,yield `,"startPosition":${JSON.stringify({row:i.startPosition.row,column:i.startPosition.column})}`,yield `,"endPosition":${JSON.stringify({row:i.endPosition.row,column:i.endPosition.column})}`,e&&(yield `,"fieldName":${JSON.stringify(e)}`),Bo(i,t)&&(yield `,"text":${JSON.stringify(i.text)}`),i.childCount>0){yield ',"children":[';let o=(t?pn(t):gn)[i.type]||[],s=new Set,a=true;for(let l of o){let c=i.childForFieldName(l);c&&(a||(yield ","),a=false,s.add(c),yield*mn(c,l,t));}for(let l=0;l<i.childCount;l++){let c=i.child(l);c&&!s.has(c)&&(a||(yield ","),a=false,yield*mn(c,void 0,t));}yield "]";}yield "}";}async function pp(i,e,t){let r=dn(i,e,t),o=t?pn(t):gn,s=[{treeNode:i,serializedNode:r,fieldName:e,childIndex:0,fieldChildren:new Set}];for(;s.length>0;){let a=s[s.length-1];if(a.childIndex===0&&a.treeNode.childCount>0){let l=o[a.treeNode.type]||[];for(let c of l){let u=a.treeNode.childForFieldName(c);if(u){a.fieldChildren.add(u);let p=dn(u,c,t);a.serializedNode.children||(a.serializedNode.children=[]),a.serializedNode.children.push(p),s.push({treeNode:u,serializedNode:p,fieldName:c,childIndex:0,fieldChildren:new Set});}}}if(a.childIndex<a.treeNode.childCount){let l=a.treeNode.child(a.childIndex);if(a.childIndex++,l&&!a.fieldChildren.has(l)){let c=dn(l,void 0,t);a.serializedNode.children||(a.serializedNode.children=[]),a.serializedNode.children.push(c),s.push({treeNode:l,serializedNode:c,childIndex:0,fieldChildren:new Set});}}else s.pop();}return r}function dn(i,e,t){let r={type:i.type,startPosition:{row:i.startPosition.row,column:i.startPosition.column},endPosition:{row:i.endPosition.row,column:i.endPosition.column},...e&&{fieldName:e}};return Bo(i,t)&&(r.text=i.text),r}function Bo(i,e){if(e){let r=Oo(e);if(r?.shouldIncludeText){let s=r.shouldIncludeText(i);if(s===false)return false;if(s===true)return true}return Mo(e).has(i.type)||i.type.endsWith("_keyword")||i.type.endsWith("_operator")}return i.type==="string"&&i.childCount>0?false:Go.has(i.type)||i.type.endsWith("_keyword")||i.type.endsWith("_operator")}function pt(...i){let e={};for(let t of i)for(let[r,o]of Object.entries(t)){let a=[...e[r]||[]];for(let l of o)a.includes(l)||a.push(l);e[r]=a;}return e}var Go,Ho,Wo,gn,un=f(()=>{Uo();Go=new Set(["identifier","property_identifier","type_identifier","shorthand_property_identifier","string","string_literal","string_fragment","number","true","false","null","undefined","import_specifier","export_specifier","predefined_type","type_predicate","type_predicate_annotation","type_alias","type_annotation","return_type","type_arguments","type_parameters","array_type","union_type","intersection_type","generic_type","tuple_type","function_type","object_type","mapped_type","conditional_type","infer_type","accessibility_modifier","readonly","static","async","await","const","let","var","decorator","=","=>","...","?","!","dotted_name","aliased_import","not_operator","boolean_operator","comparison_operator","yield","pass","continue","break","None","none","True","False","ellipsis","type","string_content"]);Ho={function_declaration:["name","parameters","body","return_type","type_parameters"],function_expression:["name","parameters","body","return_type","type_parameters"],arrow_function:["parameters","body","return_type","type_parameters"],method_definition:["name","parameters","body","return_type","type_parameters"],method_signature:["name","parameters","return_type","type_parameters"],function_signature:["name","parameters","return_type","type_parameters"],type_predicate:["name","type"],class_declaration:["name","body","type_parameters","heritage"],interface_declaration:["name","body","type_parameters"],type_alias_declaration:["name","type_parameters","value"],property_signature:["name","type"],field_definition:["name","type","value"],public_field_definition:["name","type","value"],private_field_definition:["name","type","value"],required_parameter:["pattern","type","value"],optional_parameter:["pattern","type","value"],rest_parameter:["pattern","type"],variable_declarator:["name","type","value"],lexical_declaration:["kind"],call_expression:["function","arguments","type_arguments"],new_expression:["constructor","arguments","type_arguments"],member_expression:["object","property"],assignment_expression:["left","right"],binary_expression:["left","right","operator"],unary_expression:["operator","argument"],ternary_expression:["condition","consequence","alternative"],import_statement:["source","import"],import_specifier:["name","alias"],export_specifier:["name","alias"],export_statement:["source","declaration","value"],if_statement:["condition","consequence","alternative"],for_statement:["init","condition","update","body"],for_in_statement:["left","right","body"],while_statement:["condition","body"],do_statement:["body","condition"],switch_statement:["value","body"],try_statement:["body","handler","finalizer"],catch_clause:["parameter","body"],return_statement:["value"],throw_statement:["value"],type_annotation:["type"],type_parameter:["name","constraint","default"],generic_type:["name","type_arguments"]},Wo={function_definition:["name","parameters","return_type","body","type_parameters"],async_function_definition:["name","parameters","return_type","body","type_parameters"],class_definition:["name","superclasses","body","type_parameters"],decorated_definition:["definition"],lambda:["parameters","body"],import_statement:["name"],import_from_statement:["module_name","name"],aliased_import:["name","alias"],assignment:["left","right","type"],augmented_assignment:["left","right"],type_alias_statement:["name","type_parameters","value"],annotated_assignment:["left","right","type"],except_clause:["cause"],except_group_clause:["cause"],return_statement:["value"],assert_statement:["condition","message"],delete_statement:["target"],global_statement:["name"],nonlocal_statement:["name"],typed_parameter:["name","type"],default_parameter:["name","value"],typed_default_parameter:["name","type","value"],call:["function","arguments"],attribute:["object","attribute"],binary_operator:["left","right"],unary_operator:["argument"],not_operator:["argument"],boolean_operator:["left","right"],comparison_operator:["operators"],named_expression:["name","value"],conditional_expression:["condition","consequence","alternative"],keyword_argument:["name","value"],if_statement:["condition","consequence","alternative"],while_statement:["condition","body","alternative"],for_statement:["left","right","body"],try_statement:["body"],with_statement:["body"],with_item:["value"],finally_clause:["body"],else_clause:["body"],match_statement:["subject","body"],case_clause:["pattern","guard"],raise_statement:["cause"],list_comprehension:["body"],dictionary_comprehension:["body","key","value"],set_comprehension:["body"],generator_expression:["body"],for_in_clause:["left","right"],if_clause:["condition"],pair:["key","value"],subscript:["value","subscript"],slice:["start","stop","step"]};gn=pt(Ho,Wo);});var ut,Vo=f(()=>{Fr();Si();Ci();Ai();nt();Jt();to();no();oo();Zr();M();mo();ho();Et();er();we();Dr();No();_t();ut=class extends ge{scanner;parser;apiClient;compressor;buildConfigManagers=new Map;discoveredFiles=[];parseSymbols=new Map;parseContent=new Map;symbolExtractor=new or;constructor(e){if(super(e),!this.config||!this.langRegistry)throw new Error("index command requires a valid configuration");this.scanner=new Qt(process.cwd()),this.parser=new Xt(this.langRegistry),this.compressor=new nr;for(let t of Object.keys(this.config.languages)){let r=this.langRegistry.getPlugin(t);if(r?.getBuildConfigManager){let o=r.getBuildConfigManager(process.cwd(),this.config.languages);o&&this.buildConfigManagers.set(t,o);}}}async run(e=false,t=false,r=false){if(!this.reporter)throw new Error("IndexCommand requires a Reporter dependency");let o="failed";try{let s=await this.getAccessKey();this.apiClient=new Rt(this.config,s,t,this.reporter),this.reporter.log(`${de} Starting indexing procedure...
58
+ `);let a=performance.now();await this.reporter.phase("Pre-flight checks",async P=>{let $=P.step("Project access");await this.validateProject(),$.ok("Project access validated");let L=P.step("Git branch");t?L.skip("Git branch validation skipped (--dirty)"):(await this.validateGitBranch(),L.ok("Git branch validated"));let ee=P.step("Git status");t?ee.skip("Git status validation skipped (--dirty)"):(await this.validateGitStatus(),ee.ok("Working tree clean"));let z=P.step("Repo sync");if(t?z.skip("Repository sync skipped (--dirty)"):(await this.synchronizeChanges(),z.ok("Repository synchronized")),this.buildConfigManagers.size>0){let K=P.step("Build configs"),I=0;for(let[,O]of this.buildConfigManagers.entries()){let j=await O.initialize();I+=j.length;}K.ok(I>0?`${I} build config(s) discovered`:"No build configs discovered");}},{successText:"Pre-flight checks complete"});let l=await this.reporter.phase("Determining index scope",()=>this.determineIndexScope(e),{successText:e?"Full index":"Index scope determined"}),c=await this.git.getLatestCommitHash(),u=await this.git.getCommitTimestamp();if(l.upToDate){this.reporter.summary(`${w} Index is already up-to-date for ${this.config.projectId} on ${this.config.branch} commit ${c.substring(0,8)}`),o="succeeded";return}let p=await this.reporter.phase("Claiming indexing lock",()=>this.apiClient.claimAstLock(this.config.projectId,this.config.branch,l.isIncremental,c,u),{successText:"Indexing lock claimed"});switch(p.remapped===!0&&(p.effectiveBranchName?this.reporter.warn(`--dirty: server is indexing as default branch "${p.effectiveBranchName}" (transmitted "${this.config.branch}").`):this.reporter.warn("--dirty: server reported a branch remap but did not include the effective branch name.")),p.status){case "current":this.reporter.summary(`${w} Index already up to date for branch ${this.config.branch} at commit ${c?.substring(0,8)||"unknown"}`),o="succeeded";return;case "duplicate":this.reporter.summary(`${w} Index for this commit is already in progress on the server.`),o="succeeded";return;case "superseded":this.reporter.summary(`${w} A newer commit is already being indexed; nothing to do.`),o="succeeded";return;case "queued":if(!p.queuedAttemptId)throw new Error("Server returned queued status without an attempt ID");await this.handleQueuedUpload(p.queuedAttemptId,l.isIncremental,c,u),o="succeeded";return;default:break}let d=!1,m=()=>{d||this.reporter.detail("Uploading metadata, processing, and indexing...");},h,g,y=new Promise((P,$)=>{h=P,g=$;}),b=new AbortController,v=()=>{},T=this.createIndexPipeline(l.isIncremental,u,m,h,(P,$)=>v(P,$)),N=null;try{let[,P]=await this.reporter.phase("Indexing files",async $=>{let L=null,ee=new Map,z=()=>{let I=[];if(L&&L.total>0){let O=ee?.size>0?`${Er} `:"",j=Math.min(100,Math.round(L.processed/L.total*100));I.push(`${O}Baseline index ${j}% (${L.processed}/${L.total})`);}else I.push(`${w} Baseline index complete (${L?.processed}/${L?.total})`);for(let[O,j]of ee){if(j.total<=0)continue;let An=Math.min(100,Math.round(j.processed/j.total*100));An===100?I.push(`${w} ${xe(O)} enrichment complete (${j.processed}/${j.total})`):I.push(`${Er} ${xe(O)} enrichment ${An}% (${j.processed}/${j.total})`);}$.update(I.join(`
59
+ `));};v=(I,O)=>{L={processed:I,total:O},z();};let K=(I,O,j)=>{ee.set(I,{processed:O,total:j}),z();};return Promise.all([this.uploadToAPI(T,l.isIncremental,c,p.attemptId).then(I=>(d=!0,I)).catch(I=>{throw b.abort(I),g(I),d=!0,I}),y.then(I=>{let O=this.getEnrichmentEligibleLanguages(r,I);return O?(p.attemptId&&this.apiClient.startEnrichment(p.attemptId,this.config.projectId,this.config.branch),this.runLspEnrichment(I,O,this.parseSymbols,this.parseContent,b.signal,K).catch(j=>(b.signal.aborted||this.reporter.warn(`Index enrichment failed: ${j instanceof Error?j.message:String(j)}`,{code:"ENRICHMENT_FAILED"}),null))):null}).catch(()=>null)])},{successText:"Index baseline data uploaded"});N=P;}catch(P){throw d=!0,P}N&&N.length>0&&await this.reporter.phase("Server processing & enrichment upload",async()=>{try{let P=this.discoveredFiles.length,$=fo(P),L=Math.round($/1e3);this.reporter.detail(`Waiting for server to finish syntax tree processing (${P} files, timeout ${L}s)...`);let ee=await this.apiClient.pollIndexStatus(this.config.projectId,this.config.branch,c,$),z=wi(N);if(ee){this.reporter.detail(`Uploading enrichment data (${N.length} files)...`);let K=!1;try{K=await this.apiClient.uploadEnrichment(z,this.config.projectId,this.config.branch,c);}catch{}K?this.reporter.detail("Enrichment data uploaded to Constellation Service, index enhancement in progress"):this.reporter.warn("Enrichment upload failed \u2014 re-run 'constellation index --full' after the server finishes baseline index processing to retry.",{code:"ENRICHMENT_FAILED"});}else {this.reporter.warn(`Index processing not complete after ${L}s \u2014 attempting enrichment upload anyway.`);let K=!1;try{K=await this.apiClient.uploadEnrichment(z,this.config.projectId,this.config.branch,c);}catch{}K?this.reporter.detail("Enrichment data uploaded to Constellation Service, index enhancement in progress"):this.reporter.warn("Enrichment upload failed \u2014 re-run 'constellation index --full' after the server finishes baseline index processing to retry.",{code:"ENRICHMENT_FAILED"});}}catch(P){this.reporter.warn(`Enrichment upload failed: ${P instanceof Error?P.message:String(P)}`,{code:"ENRICHMENT_FAILED"});}},{successText:"Index enrichment data uploaded"});let x=(performance.now()-a)/1e3,G=Math.floor(x/60),B=(x%60).toFixed(3),H=G>0?`${G}m ${B}s`:`${B}s`;this.reporter.summary(`
60
+ ${w} Upload completed in ${H}! Server indexing in progress.`),o="succeeded";}catch(s){if(s instanceof se)throw s;if(s instanceof ke){this.logIndexingInProgress(s.branchName||this.config?.branch),o="succeeded";return}if(s instanceof k)throw pe(s)||(this.reporter.error("Authentication failed.",{code:"AUTH_FAILURE"}),this.reporter.info(`Your access key may be invalid or expired. Run 'constellation auth'
61
+ to set or update your access key.`),Be(s)),s;if(s instanceof he)throw s;if(s instanceof Error&&s.message==="Access key not configured")throw Be(s),s;if(pe(s))throw s;let a=s instanceof Error?s.message:"An unexpected error occurred";throw this.reporter.error(`Indexing failed: ${a}`),Be(s),s}finally{this.parseSymbols.clear(),this.parseContent.clear();try{let a=process.env.CONSTELLATION_ERROR_REPORTING?.toLowerCase()==="false",l=this.apiClient?.isFeatureEnabled("cli_error_reporting")??!1,c=this.reporter.getReportableErrors();if(!a&&l&&c.length>0){let u=this.reporter.getEntries(),p=c.map(v=>({type:"CLI_ERROR",message:v.message,phase:"indexing"})).slice(0,100),d=u.filter(v=>v.level==="warn").map(v=>({type:"CLI_WARNING",message:v.message,phase:"indexing"})).slice(0,100),m=p.length,h=d.length,g=[];m>0&&g.push(`${m} error${m!==1?"s":""}`),h>0&&g.push(`${h} warning${h!==1?"s":""}`);let y=g.join(", "),b=globalThis.__constellationVersion??"unknown";await this.apiClient.reportErrors({errorSummary:y,errorData:{errors:p,warnings:d},logEntries:u.slice(0,1e3),cliVersion:b,outcome:o,indexType:e?"full":"incremental"});}}catch{}}}async getAccessKey(){let e=await this.env.getKey(me);if(!e)throw this.reporter.error("Access key not found.",{code:"ACCESS_KEY_MISSING"}),this.reporter.info(`Set the ${me} environment variable or run
62
+ 'constellation auth' to configure your access key.`),new Error("Access key not configured");return e}async validateProject(){this.reporter.detail("Validating project access...");try{await this.apiClient.getProjectState(),this.reporter.detail("Project validated successfully");}catch(e){if(e instanceof se)throw this.displayProjectValidationError(e),Be(e),e;if(e instanceof fe){this.reporter.detail("Project validated (first index)");return}if(e instanceof k)throw e;let t=e instanceof Error?e.message:String(e);throw t==="fetch failed"||t.includes("ECONNREFUSED")||t.includes("ENOTFOUND")||t.includes("ETIMEDOUT")||t.includes("EHOSTUNREACH")||t.includes("ECONNRESET")?new Error(`Unable to connect to the Constellation service.
63
+ Verify your network connection and that the API URL is correct.`):e}}displayProjectValidationError(e){let t=e.projectId||this.config.projectId,r=t.length>40?t.substring(0,37)+"...":t;switch(e.code){case "PROJECT_NOT_REGISTERED":this.reporter.error("Project not registered",{code:"PROJECT_NOT_REGISTERED"}),this.reporter.log(` The project ID "${r}" in constellation.json`),this.reporter.log(` is not associated with your Constellation account.
63
64
  `),this.reporter.log(" To resolve this:"),this.reporter.log(" 1. Verify the project exists at https://app.constellationdev.io"),this.reporter.log(" 2. Check that the project ID in constellation.json is correct"),this.reporter.log(` 3. Run 'constellation index' again
64
- `);break;case "PROJECT_INACTIVE":this.reporter.error("Project is inactive",{code:"PROJECT_INACTIVE"}),this.reporter.log(` The project "${n}" has been deactivated.
65
+ `);break;case "PROJECT_INACTIVE":this.reporter.error("Project is inactive",{code:"PROJECT_INACTIVE"}),this.reporter.log(` The project "${r}" has been deactivated.
65
66
  `),this.reporter.log(" To resolve this:"),this.reporter.log(" 1. Reactivate the project at https://app.constellationdev.io"),this.reporter.log(` 2. Run 'constellation index' again
66
- `);break;case "INVALID_PROJECT_ID":this.reporter.error("Invalid project ID",{code:"INVALID_PROJECT_ID"}),this.reporter.log(` The project ID "${n}" in constellation.json`),this.reporter.log(` is not a valid Constellation project identifier.
67
+ `);break;case "INVALID_PROJECT_ID":this.reporter.error("Invalid project ID",{code:"INVALID_PROJECT_ID"}),this.reporter.log(` The project ID "${r}" in constellation.json`),this.reporter.log(` is not a valid Constellation project identifier.
67
68
  `),this.reporter.log(" To resolve this:"),this.reporter.log(" 1. Get your project ID from https://app.constellationdev.io"),this.reporter.log(" 2. Update the projectId field in constellation.json"),this.reporter.log(` 3. Run 'constellation index' again
68
69
  `);break;default:this.reporter.error(`Project validation failed: ${e.message}`,{code:"PROJECT_VALIDATION_FAILED"});}}logIndexingInProgress(e){this.reporter.info(`Another indexing operation is already in progress for branch ${e||"unknown"}.
69
70
  Your index is up to date with the current operation.
70
- Re-run this command after the current operation completes if you have newer changes.`);}async validateGitBranch(){this.reporter.detail("Validating Git repository and branch...");let t=(await this.git.status()).currentBranch;this.config.validateBranch(t),this.reporter.detail(`Current branch "${t}" is configured for indexing`);}async validateGitStatus(){if(this.reporter.detail("Validating Git status..."),!(await this.git.status()).clean)throw new ue(`Outstanding changes detected.
71
+ Re-run this command after the current operation completes if you have newer changes.`);}async validateGitBranch(){this.reporter.detail("Validating Git repository and branch...");let t=(await this.git.status()).currentBranch;this.config.validateBranch(t),this.reporter.detail(`Current branch "${t}" is configured for indexing`);}async validateGitStatus(){if(this.reporter.detail("Validating Git status..."),!(await this.git.status()).clean)throw new he(`Outstanding changes detected.
71
72
  Commit or stash changes first to ensure consistent indexing.`,"DIRTY_WORKTREE");this.reporter.detail("Working tree clean");}async synchronizeChanges(){this.reporter.detail("Synchronizing latest changes...");try{this.reporter.pause(),await this.git.pull()&&this.reporter.detail("Repository synchronized successfully");}catch(e){throw this.reporter.error("Failed to synchronize repository",{code:"GIT_SYNC_FAILURE"}),e instanceof Error&&(e.message.includes("uncommitted changes")?(this.reporter.log(`
72
73
  To resolve:`),this.reporter.log(' 1. Commit your changes: git add . && git commit -m "your message"'),this.reporter.log(" 2. Or stash them: git stash"),this.reporter.log(` 3. Then run the index command again
73
74
  `)):e.message.includes("merge conflicts")?(this.reporter.log(`
@@ -76,29 +77,29 @@ To resolve:`),this.reporter.log(" 1. Fix the conflicted files manually"),this.r
76
77
  Please check your internet connection and try again
77
78
  `):e.message.includes("Authentication")&&this.reporter.log(`
78
79
  Please check your git credentials and try again
79
- `)),e}finally{this.reporter.resume();}}async determineIndexScope(e){if(e)return {isIncremental:false,upToDate:false};this.reporter.detail("Determining index scope...");try{let n=(await this.apiClient.getProjectState())?.latestCommit;if(!n)return this.reporter.detail("No previous index found, performing full index"),{isIncremental:!1,upToDate:!1};let o=await this.git.getLatestCommitHash();return n===o?(this.reporter.detail("Already up to date"),{isIncremental:!0,upToDate:!0}):(this.reporter.detail(`Last indexed commit: ${n.substring(0,8)}`),this.reporter.detail(`Current commit: ${o.substring(0,8)}`),this.reporter.detail(`Performing incremental index starting from commit ${n.substring(0,8)}`),{isIncremental:!0,upToDate:!1})}catch(t){if(t instanceof R)throw t;return this.reporter.warn(`Could not determine last index (${t instanceof Error?t.message:"unknown error"}), performing full index`),{isIncremental:false,upToDate:false}}}async discoverFiles(e){this.reporter.detail("Analyzing codebase...");let t;if(e)try{let n=await this.apiClient.getProjectState();if(!n?.latestCommit)this.reporter.warn("Cannot determine changes (no latestCommit in project state), falling back to full scan"),t=await this.scanner.scanFiles(this.config);else {let o=await this.git.getChangedFiles(n.latestCommit),s=[...o.added,...o.modified,...o.renamed.map(l=>l.to)];this.reporter.detail(`Found ${s.length} changed files`),t=await this.scanner.scanSpecificFiles(s,this.config);let a=[...o.deleted,...o.renamed.map(l=>l.from)];if(a.length>0){let l=o.deleted.length,c=o.renamed.length,u=c>0?`${Z} Removing ${l} deleted file(s) and ${c} renamed file(s) from graph`:`${Z} Removing ${l} deleted file(s) from graph`;this.reporter.log(u),await this.apiClient.deleteFiles(a);}}}catch(n){if(n instanceof R)throw n;this.reporter.warn(`Cannot determine changes (${n instanceof Error?n.message:"unknown"}), falling back to full scan`),t=await this.scanner.scanFiles(this.config);}else this.reporter.detail("Scanning all project files..."),t=await this.scanner.scanFiles(this.config);return this.reporter.detail(`Found ${t.length} files to index`),t}async*generateASTs(e,t,n,o){let s=e.length,a=0,l=0;o?.(0,s),this.reporter.detail(`Processing ${s} files...`);let c=await this.git.getLatestCommitHash(),u=s>1e4?5:s>5e3?7:10;u<10&&this.reporter.detail(`Large project detected, using concurrency of ${u} to optimize memory usage`);let d=new Re(u,{preserveOrder:true}).run(e,async(m,g)=>{let h=Math.round((g+1)/s*100);this.reporter.detail(`Analyzing file ${m.path.replace(process.cwd()+"/","")} (${h}%)...`);try{let{tree:b,classificationMap:y,content:v}=await this.parser.parseFile(m.path,m.language),x=this.symbolExtractor.extract(b,m.language);x.length>0&&this.parseSymbols.set(this.normalizePathToCanonical(m.relativePath),x),v!==void 0&&this.parseContent.set(this.normalizePathToCanonical(m.relativePath),v),y.entries.length>5e4&&this.reporter.warn(`Large classification map for ${m.relativePath}: ${y.entries.length} entries`);let C=this.langRegistry.getPlugin(m.language),A;if(C?.getImportResolver){let P=this.buildConfigManagers.get(m.language),D=P?await P.getConfigForFile(m.path):null,F=C.getImportResolver(m.path,D);if(F){let{ImportExtractor:Q}=await Promise.resolve().then(()=>(fo(),go));A=await new Q().extractImportResolutions(b,m.path,m.language,F);}}let{serializeASTStream:N}=await Promise.resolve().then(()=>(rn(),No)),X=N(b.rootNode,void 0,m.language),se=await this.compressor.compressStream(X),ye=this.normalizePathToCanonical(m.relativePath),_={file:ye,language:m.language,commit:c,timestamp:t,ast:se,importResolutions:A,classificationMap:{filePath:ye,entries:y.entries}},k=zi.safeParse(_);if(!k.success)throw new Error(`AST validation failed: ${k.error.issues[0].message}`);return a++,o?.(a,s),k.data}catch(b){throw l++,o?.(a+l,s),this.reporter.warn(`Failed to parse ${m.relativePath}: ${b.message}`,{code:"PARSE_FAILURE"}),b}});for await(let m of d)yield m;l>0?this.reporter.warn(`Completed parsing with ${l} parsing errors`):this.reporter.detail("All files analyzed successfully"),n&&n();}async uploadToAPI(e,t,n,o){if(!await this.apiClient.streamToApi(e,"ast",this.config.projectId,this.config.branch,t,n,o))throw new Error("Failed to upload data to Constellation Service");this.reporter.detail("Data uploaded to Constellation Service, indexing in progress");}async*createIndexPipeline(e,t,n,o,s){let a=await this.discoverFiles(e);this.discoveredFiles=a,o(a),yield*this.generateASTs(a,t,n,s);}async handleQueuedUpload(e,t,n,o){this.reporter.log("Generating AST data for queue upload...");let s=this.createIndexPipeline(t,o,()=>{},()=>{});await this.apiClient.uploadToQueue(s,this.config.projectId,this.config.branch,n,e),this.reporter.detail("Changes queued for indexing behind the current operation.");}normalizePathToCanonical(e){return Tt(e)}isLanguageLspEligible(e){let t=this.config.languages[e];return t?.lspEnrichment===false?false:!!t?.lsp||de.has(e)}getEnrichmentEligibleLanguages(e,t){if(e)return this.reporter.detail("Index enrichment skipped"),null;if(this.config.lspEnrichment===false)return this.reporter.detail("Index enrichment disabled in constellation.json"),null;let o=[...new Set(t.map(s=>s.language))].filter(s=>this.isLanguageLspEligible(s));return o.length===0?null:(this.reporter.detail(`Index enrichment enabled for: ${o.map(tt).join(", ")}`),new Set(o))}async runLspEnrichment(e,t,n,o,s){let a=new Ft(process.cwd(),this.reporter);try{if(s?.aborted)return null;this.reporter.detail("Starting index enrichment...");let l=new Map,c=new Map;for(let g of e){if(!t.has(g.language))continue;let h=l.get(g.language)||[];h.push(this.normalizePathToCanonical(g.relativePath)),l.set(g.language,h);}for(let g of l.keys()){if(c.has(g))continue;let b=this.config.languages[g]?.lsp,y=await a.startServer(g,b);y&&c.set(g,y);}if(c.size===0)return this.reporter.warn("No language servers started, index enrichment skipped"),null;if(s?.aborted)return a.destroyAll(),null;this.reporter.detail(`Language servers started: ${[...c.keys()].map(tt).join(", ")}`);let u=new Rt(process.cwd(),this.reporter),p=s?new Promise((g,h)=>{s.addEventListener("abort",()=>{a.destroyAll(),h(s.reason||new Error("Indexing aborted"));},{once:!0});}):null,d=await(p?Promise.race([u.enrich(l,n,c,o),p]):u.enrich(l,n,c,o)),m=d.reduce((g,h)=>g+h.symbols.length,0);return this.reporter.detail(`Index enrichment analysis completed: ${m} symbols across ${d.length} files`),d.length>0?d:null}catch(l){return this.reporter.warn(`Index enrichment failed: ${l instanceof Error?l.message:String(l)}`,{code:"ENRICHMENT_FAILED"}),null}finally{await a.shutdownAll();}}};});function an(i){return stringify({name:"Constellation Index",on:{push:{branches:[i]}},permissions:{contents:"read"},jobs:{index:{"runs-on":"ubuntu-latest",steps:[{uses:"actions/checkout@v4"},{uses:"ShiftinBits/constellation-github@v1",with:{"access-key":"${{ secrets.CONSTELLATION_ACCESS_KEY }}"}}]}}},{lineWidth:0})}function ir(i){return {includeEntry:{component:"gitlab.com/shiftinbits/constellation-gitlab/constellation-index@1",inputs:{access_key:"$CONSTELLATION_ACCESS_KEY"}},job:{rules:[{if:`$CI_COMMIT_BRANCH == "${i}"`}]}}}function or(i){let{includeEntry:e,job:t}=ir(i);return stringify({include:[e],"constellation-index":t},{lineWidth:0})}var ln=f(()=>{});var lt,Ao=f(()=>{re();ln();lt=class{constructor(e){this.gitRoot=e;}async detectPlatforms(){let e=[],[t,n]=await Promise.all([S.directoryExists(E__default.join(this.gitRoot,".github","workflows")),S.fileIsReadable(E__default.join(this.gitRoot,".gitlab-ci.yml"))]);return t&&e.push("github"),n&&e.push("gitlab"),e}async githubWorkflowExists(){return S.fileIsReadable(E__default.join(this.gitRoot,".github","workflows","constellation-index.yml"))}async gitlabJobExists(){let e=E__default.join(this.gitRoot,".gitlab-ci.yml");if(!await S.fileIsReadable(e))return false;try{let n=await S.readFile(e),s=parseDocument(n).contents;return isMap(s)&&s.has("constellation-index")}catch{return false}}async createGitHubWorkflow(e){let t=E__default.join(this.gitRoot,".github","workflows");await G__default.mkdir(t,{recursive:true});let n=E__default.join(t,"constellation-index.yml");return await S.writeFile(n,an(e)),n}async createOrMergeGitLabCI(e){let t=E__default.join(this.gitRoot,".gitlab-ci.yml");if(!await S.fileIsReadable(t))return await S.writeFile(t,or(e)),t;let o=await S.readFile(t),s=parseDocument(o);if(!isMap(s.contents))return await S.writeFile(t,or(e)),t;let{includeEntry:a,job:l}=ir(e);return this.mergeIncludeEntry(s,a),s.set("constellation-index",l),await S.writeFile(t,s.toString()),t}mergeIncludeEntry(e,t){let n=e.get("include");if(!n){e.set("include",[t]);return}if(isSeq(n)){let o=n.items.filter(s=>{if(isMap(s)){let a=s.get("component");return typeof a!="string"||!a.includes("constellation-gitlab")}return true});n.items=o,n.items.push(e.createNode(t));return}e.set("include",[n,t]);}};});var ko=f(()=>{Ao();ln();});function Fo(i,e){let t=Ce__default.homedir(),n=process.platform,o=Qc[i];switch(n){case "darwin":return E__default.join(t,"Library/Application Support",o,"User/globalStorage",e);case "win32":return E__default.join(process.env.APPDATA||E__default.join(t,"AppData/Roaming"),o,"User/globalStorage",e);default:return E__default.join(t,".config",o,"User/globalStorage",e)}}function $o(){let i="saoudrizwan.claude-dev";return ["stable","insiders"].map(t=>({variant:t,displayName:t==="stable"?"VS Code":"VS Code Insiders",settingsPath:E__default.join(Fo(t,i),"settings","cline_mcp_settings.json")}))}function Do(){return E__default.join(Fo("stable","saoudrizwan.claude-dev"),"settings","cline_mcp_settings.json")}var Qc,Oo=f(()=>{Qc={stable:"Code",insiders:"Code - Insiders"};});function Uo(i){return pn.find(e=>e.id===i)}var Mo,Zc,pn,un=f(()=>{Oo();Mo={command:"npx",args:["-y","@constellationdev/mcp@latest"]},Zc={extraKnownMarketplaces:{"constellation-plugins":{source:{source:"github",repo:"ShiftinBits/constellation-claude"},autoUpdate:true}},enabledPlugins:{"constellation@constellation-plugins":true}},pn=[{id:"claude-code",displayName:"Claude Code",configPath:".mcp.json",format:"json",skipMcpServer:true,permissionsConfig:{filePath:".claude/settings.json",allowKeyPath:["permissions","allow"],allowValue:"mcp__plugin_constellation_*"},marketplaceConfig:{filePath:".claude/settings.json",config:Zc},mcpServersKeyPath:["mcpServers"]},{id:"cline",displayName:"Cline",configPath:Do(),isGlobalConfig:true,getGlobalConfigPaths:$o,format:"json",mcpServersKeyPath:["mcpServers"],mcpServerExtras:{alwaysAllow:["code_intel"],disabled:false}},{id:"codex-cli",displayName:"Codex CLI",configPath:".codex/config.toml",format:"toml",mcpServersKeyPath:["mcp_servers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"$CONSTELLATION_ACCESS_KEY"},mcpServerExtras:{enabled_tools:["code_intel"]},envPolicyConfig:{includeOnlyKeyPath:["shell_environment_policy","include_only"],envVarsToAllow:["CONSTELLATION_ACCESS_KEY"],globalConfigPath:"~/.codex/config.toml"}},{id:"copilot-cli",displayName:"Copilot CLI",configPath:"",format:"json",mcpServersKeyPath:[],skipMcpServer:true,pluginInstallCommand:{command:"copilot",args:["plugin","marketplace","add","ShiftinBits/constellation-copilot"]},pluginPostInstallCommands:[{command:"copilot",args:["plugin","install","constellation@constellation-plugins"]}]},{id:"cursor",displayName:"Cursor",configPath:".cursor/mcp.json",format:"json",mcpServersKeyPath:["mcpServers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"${env:CONSTELLATION_ACCESS_KEY}"}},{id:"gemini-cli",displayName:"Gemini CLI",configPath:"",format:"json",mcpServersKeyPath:[],skipMcpServer:true,pluginInstallCommand:{command:"gemini",args:["extensions","install","https://github.com/ShiftinBits/constellation-gemini"]},pluginUpdateCommand:{command:"gemini",args:["extensions","update","constellation"]},pluginPostInstallCommands:[{command:"gemini",args:["extensions","disable","--scope","user","constellation"]},{command:"gemini",args:["extensions","enable","--scope","workspace","constellation"]}]},{id:"jetbrains-ai",displayName:"JetBrains",configPath:".ai/mcp/mcp.json",format:"json",mcpServersKeyPath:["mcpServers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"CONSTELLATION_ACCESS_KEY"},mcpServerExtras:{tools:["code_intel"]}},{id:"kilo-code",displayName:"Kilo Code",configPath:".kilocode/mcp.json",format:"json",permissionsConfig:{filePath:".kilocode/mcp.json",allowKeyPath:["mcpServers","constellation","alwaysAllow"],allowValue:"code_intel"},mcpServersKeyPath:["mcpServers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"${env:CONSTELLATION_ACCESS_KEY}"}},{id:"opencode",displayName:"OpenCode",configPath:"opencode.jsonc",format:"jsonc",mcpServersKeyPath:["mcp"],skipMcpServer:true,pluginConfig:{pluginKeyPath:["plugin"],pluginValue:"@constellationdev/opencode"},configDefaults:{$schema:"https://opencode.ai/config.json"}},{id:"tabnine",displayName:"Tabnine",configPath:".tabnine/mcp_servers.json",format:"json",mcpServersKeyPath:["mcpServers"]},{id:"vscode-copilot",displayName:"VSCode",configPath:".vscode/mcp.json",format:"json",mcpServersKeyPath:["servers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"CONSTELLATION_ACCESS_KEY"},mcpServerExtras:{tools:["code_intel"]}}];});async function Go(){if(!dn)try{let i=await import('@iarna/toml');dn={parse:i.parse,stringify:i.stringify};}catch{throw new Error("TOML support requires @iarna/toml package. Install with: npm install @iarna/toml")}return dn}function rp(i){let e="",t=0,n=i.length;for(;t<n;)if(i[t]==='"'){for(e+='"',t++;t<n&&i[t]!=='"';)i[t]==="\\"?(e+=i[t++],t<n&&(e+=i[t++])):e+=i[t++];t<n&&(e+=i[t++]);}else if(i[t]==="/"&&t+1<n&&i[t+1]==="/")for(t+=2;t<n&&i[t]!==`
80
- `;)t++;else if(i[t]==="/"&&t+1<n&&i[t+1]==="*"){for(t+=2;t<n&&!(i[t]==="*"&&t+1<n&&i[t+1]==="/");)t++;t<n&&(t+=2);}else e+=i[t++];return e.replace(/,(\s*[}\]])/g,"$1")}var dn,sr,Bo=f(()=>{re();un();dn=null;sr=class{cwd;constructor(e=process.cwd()){this.cwd=e;}async configureTool(e){try{let t=E__default.join(this.cwd,e.configPath),n=!e.skipMcpServer||!!e.pluginConfig||!!e.configDefaults;if(n){await this.ensureDirectoryExists(t);let s=await this.readConfig(t,e.format);if(e.configDefaults)for(let[a,l]of Object.entries(e.configDefaults))a in s||(s[a]=l);e.pluginConfig&&(s=this.addPluginToArray(s,e.pluginConfig)),e.skipMcpServer||(s=this.addConstellationServer(s,e),await this.configureEnvPolicy(s,e)),await this.writeConfig(t,s,e.format);}e.permissionsConfig&&await this.configurePermissions(e.permissionsConfig),e.marketplaceConfig&&await this.configureMarketplace(e.marketplaceConfig);let o;return n?o=t:e.permissionsConfig?o=E__default.join(this.cwd,e.permissionsConfig.filePath):e.marketplaceConfig?o=E__default.join(this.cwd,e.marketplaceConfig.filePath):o=t,{tool:e,success:!0,configuredPath:o}}catch(t){return {tool:e,success:false,error:t instanceof Error?t.message:String(t)}}}async configureGlobalTool(e){if(!e.getGlobalConfigPaths)return [{tool:e,success:false,error:"No global config paths defined"}];let t=e.getGlobalConfigPaths(),n=[];for(let{displayName:o,settingsPath:s}of t)try{await this.ensureDirectoryExists(s);let a=await this.readConfig(s,e.format);a=this.addConstellationServer(a,e),await this.writeConfig(s,a,e.format),n.push({tool:{...e,displayName:`${e.displayName} (${o})`},success:!0,configuredPath:s});}catch(a){let l=a instanceof Error?a.message:String(a);l.includes("ENOENT")||l.includes("no such file")||n.push({tool:{...e,displayName:`${e.displayName} (${o})`},success:false,error:l});}return n}async ensureDirectoryExists(e){let t=E__default.dirname(e);await G__default.mkdir(t,{recursive:true});}async readConfig(e,t){try{if(!await S.fileIsReadable(e))return {};let o=await S.readFile(e);return t==="json"?JSON.parse(o):t==="jsonc"?JSON.parse(rp(o)):(await Go()).parse(o)}catch{return {}}}addConstellationServer(e,t){let n=e;for(let a=0;a<t.mcpServersKeyPath.length-1;a++){let l=t.mcpServersKeyPath[a];(!n[l]||typeof n[l]!="object")&&(n[l]={}),n=n[l];}let o=t.mcpServersKeyPath[t.mcpServersKeyPath.length-1];(!n[o]||typeof n[o]!="object")&&(n[o]={});let s=n[o];if(!s.constellation){let a=t.mcpServerConfigOverride??Mo,l={...a};if(t.mcpServerExtras&&Object.assign(l,t.mcpServerExtras),t.mcpEnv){let c=t.mcpEnvKey??"env",u=a[c];l[c]={...u,...t.mcpEnv};}s.constellation=l;}return e}async writeConfig(e,t,n){let o;n==="json"||n==="jsonc"?o=JSON.stringify(t,null,2):o=(await Go()).stringify(t),o=o.replace(/\r\n/g,`
80
+ `)),e}finally{this.reporter.resume();}}async determineIndexScope(e){if(e)return {isIncremental:false,upToDate:false};this.reporter.detail("Determining index scope...");try{let r=(await this.apiClient.getProjectState())?.latestCommit;if(!r)return this.reporter.detail("No previous index found, performing full index"),{isIncremental:!1,upToDate:!1};let o=await this.git.getLatestCommitHash();return r===o?(this.reporter.detail("Already up to date"),{isIncremental:!0,upToDate:!0}):(this.reporter.detail(`Last indexed commit: ${r.substring(0,8)}`),this.reporter.detail(`Current commit: ${o.substring(0,8)}`),this.reporter.detail(`Performing incremental index starting from commit ${r.substring(0,8)}`),{isIncremental:!0,upToDate:!1})}catch(t){if(t instanceof k)throw t;return this.reporter.warn(`Could not determine last index (${t instanceof Error?t.message:"unknown error"}), performing full index`),{isIncremental:false,upToDate:false}}}async discoverFiles(e){this.reporter.detail("Analyzing codebase...");let t;if(e)try{let r=await this.apiClient.getProjectState();if(!r?.latestCommit)this.reporter.warn("Cannot determine changes (no latestCommit in project state), falling back to full scan"),t=await this.scanner.scanFiles(this.config);else {let o=await this.git.getChangedFiles(r.latestCommit),s=[...o.added,...o.modified,...o.renamed.map(l=>l.to)];this.reporter.detail(`Found ${s.length} changed files`),t=await this.scanner.scanSpecificFiles(s,this.config);let a=[...o.deleted,...o.renamed.map(l=>l.from)];if(a.length>0){let l=o.deleted.length,c=o.renamed.length,u=c>0?`${ie} Removing ${l} deleted file(s) and ${c} renamed file(s) from graph`:`${ie} Removing ${l} deleted file(s) from graph`;this.reporter.log(u),await this.apiClient.deleteFiles(a);}}}catch(r){if(r instanceof k)throw r;this.reporter.warn(`Cannot determine changes (${r instanceof Error?r.message:"unknown"}), falling back to full scan`),t=await this.scanner.scanFiles(this.config);}else this.reporter.detail("Scanning all project files..."),t=await this.scanner.scanFiles(this.config);return this.reporter.detail(`Found ${t.length} files to index`),t}async*generateASTs(e,t,r,o){let s=e.length,a=0,l=0;o?.(0,s),this.reporter.detail(`Processing ${s} files...`);let c=await this.git.getLatestCommitHash(),u=s>1e4?5:s>5e3?7:10;u<10&&this.reporter.detail(`Large project detected, using concurrency of ${u} to optimize memory usage`);let d=new Fe(u,{preserveOrder:true}).run(e,async(m,h)=>{let g=Math.round((h+1)/s*100);this.reporter.detail(`Analyzing file ${m.path.replace(process.cwd()+"/","")} (${g}%)...`);try{let{tree:y,classificationMap:b,content:v}=await this.parser.parseFile(m.path,m.language),T=this.symbolExtractor.extract(y,m.language);T.length>0&&this.parseSymbols.set(this.normalizePathToCanonical(m.relativePath),T),v!==void 0&&this.parseContent.set(this.normalizePathToCanonical(m.relativePath),v),b.entries.length>5e4&&this.reporter.warn(`Large classification map for ${m.relativePath}: ${b.entries.length} entries`);let C=this.langRegistry.getPlugin(m.language),_;if(C?.getImportResolver){let L=this.buildConfigManagers.get(m.language),ee=L?await L.getConfigForFile(m.path):null,z=C.getImportResolver(m.path,ee);if(z){let{ImportExtractor:K}=await Promise.resolve().then(()=>(jo(),Lo));_=await new K().extractImportResolutions(y,m.path,m.language,z);}}let{serializeASTStream:x}=await Promise.resolve().then(()=>(un(),zo)),G=x(y.rootNode,void 0,m.language),B=await this.compressor.compressStream(G),H=this.normalizePathToCanonical(m.relativePath),P={file:H,language:m.language,commit:c,timestamp:t,ast:B,importResolutions:_,classificationMap:{filePath:H,entries:b.entries}},$=io.safeParse(P);if(!$.success)throw new Error(`Index validation failed: ${$.error.issues[0].message}`);return a++,o?.(a,s),$.data}catch(y){throw l++,o?.(a+l,s),this.reporter.warn(`Failed to parse ${m.relativePath}: ${y.message}`,{code:"PARSE_FAILURE"}),y}});for await(let m of d)yield m;l>0?this.reporter.warn(`Completed parsing with ${l} parsing errors`):this.reporter.detail("All files analyzed successfully"),r&&r();}async uploadToAPI(e,t,r,o){if(!await this.apiClient.streamToApi(e,"ast",this.config.projectId,this.config.branch,t,r,o))throw new Error("Failed to upload data to Constellation Service");this.reporter.detail("Data uploaded to Constellation Service, indexing in progress");}async*createIndexPipeline(e,t,r,o,s){let a=await this.discoverFiles(e);this.discoveredFiles=a,o(a),yield*this.generateASTs(a,t,r,s);}async handleQueuedUpload(e,t,r,o){this.reporter.log("Generating index data for queue upload...");let s=this.createIndexPipeline(t,o,()=>{},()=>{});await this.apiClient.uploadToQueue(s,this.config.projectId,this.config.branch,r,e),this.reporter.detail("Changes queued for indexing behind the current operation.");}normalizePathToCanonical(e){return jt(e)}isLanguageLspEligible(e){let t=this.config.languages[e];return t?.lspEnrichment===false?false:!!t?.lsp||ye.has(e)}getEnrichmentEligibleLanguages(e,t){if(e)return this.reporter.detail("Index enrichment skipped"),null;if(this.config.lspEnrichment===false)return this.reporter.detail("Index enrichment disabled in constellation.json"),null;let o=[...new Set(t.map(s=>s.language))].filter(s=>this.isLanguageLspEligible(s));return o.length===0?null:(this.reporter.detail(`Index enrichment enabled for: ${o.map(xe).join(", ")}`),new Set(o))}async runLspEnrichment(e,t,r,o,s,a){let l=new Ot(process.cwd(),this.reporter);try{if(s?.aborted)return null;this.reporter.detail("Starting index enrichment...");let c=new Map,u=new Map;for(let g of e){if(!t.has(g.language))continue;let y=c.get(g.language)||[];y.push(this.normalizePathToCanonical(g.relativePath)),c.set(g.language,y);}for(let g of c.keys()){if(u.has(g))continue;let b=this.config.languages[g]?.lsp,v=await l.startServer(g,b);v&&u.set(g,v);}if(u.size===0)return this.reporter.warn("No language servers started, index enrichment skipped"),null;if(s?.aborted)return l.destroyAll(),null;this.reporter.detail(`Language servers started: ${[...u.keys()].map(xe).join(", ")}`);let p=new At(process.cwd(),this.reporter),d=s?new Promise((g,y)=>{s.addEventListener("abort",()=>{l.destroyAll(),y(s.reason||new Error("Indexing aborted"));},{once:!0});}):null,m=await(d?Promise.race([p.enrich(c,r,u,o,a),d]):p.enrich(c,r,u,o,a)),h=m.reduce((g,y)=>g+y.symbols.length,0);return this.reporter.detail(`Index enrichment analysis completed: ${h} symbols across ${m.length} files`),m.length>0?m:null}catch(c){return this.reporter.warn(`Index enrichment failed: ${c instanceof Error?c.message:String(c)}`,{code:"ENRICHMENT_FAILED"}),null}finally{await l.shutdownAll();}}};});function fn(i){return stringify({name:"Constellation Index",on:{push:{branches:[i]}},permissions:{contents:"read"},jobs:{index:{"runs-on":"ubuntu-latest",steps:[{uses:"actions/checkout@v4"},{uses:"ShiftinBits/constellation-github@v1",with:{"access-key":"${{ secrets.CONSTELLATION_ACCESS_KEY }}"}}]}}},{lineWidth:0})}function lr(i){return {includeEntry:{component:"gitlab.com/shiftinbits/constellation-gitlab/constellation-index@1",inputs:{access_key:"$CONSTELLATION_ACCESS_KEY"}},job:{rules:[{if:`$CI_COMMIT_BRANCH == "${i}"`}]}}}function cr(i){let{includeEntry:e,job:t}=lr(i);return stringify({include:[e],"constellation-index":t},{lineWidth:0})}var hn=f(()=>{});var dt,Yo=f(()=>{ae();hn();dt=class{constructor(e){this.gitRoot=e;}async detectPlatforms(){let e=[],[t,r]=await Promise.all([S.directoryExists(E__default.join(this.gitRoot,".github","workflows")),S.fileIsReadable(E__default.join(this.gitRoot,".gitlab-ci.yml"))]);return t&&e.push("github"),r&&e.push("gitlab"),e}async githubWorkflowExists(){return S.fileIsReadable(E__default.join(this.gitRoot,".github","workflows","constellation-index.yml"))}async gitlabJobExists(){let e=E__default.join(this.gitRoot,".gitlab-ci.yml");if(!await S.fileIsReadable(e))return false;try{let r=await S.readFile(e),s=parseDocument(r).contents;return isMap(s)&&s.has("constellation-index")}catch{return false}}async createGitHubWorkflow(e){let t=E__default.join(this.gitRoot,".github","workflows");await J__default.mkdir(t,{recursive:true});let r=E__default.join(t,"constellation-index.yml");return await S.writeFile(r,fn(e)),r}async createOrMergeGitLabCI(e){let t=E__default.join(this.gitRoot,".gitlab-ci.yml");if(!await S.fileIsReadable(t))return await S.writeFile(t,cr(e)),t;let o=await S.readFile(t),s=parseDocument(o);if(!isMap(s.contents))return await S.writeFile(t,cr(e)),t;let{includeEntry:a,job:l}=lr(e);return this.mergeIncludeEntry(s,a),s.set("constellation-index",l),await S.writeFile(t,s.toString()),t}mergeIncludeEntry(e,t){let r=e.get("include");if(!r){e.set("include",[t]);return}if(isSeq(r)){let o=r.items.filter(s=>{if(isMap(s)){let a=s.get("component");return typeof a!="string"||!a.includes("constellation-gitlab")}return true});r.items=o,r.items.push(e.createNode(t));return}e.set("include",[r,t]);}};});var Xo=f(()=>{Yo();hn();});function Qo(i,e){let t=Pe__default.homedir(),r=process.platform,o=fp[i];switch(r){case "darwin":return E__default.join(t,"Library/Application Support",o,"User/globalStorage",e);case "win32":return E__default.join(process.env.APPDATA||E__default.join(t,"AppData/Roaming"),o,"User/globalStorage",e);default:return E__default.join(t,".config",o,"User/globalStorage",e)}}function Zo(){let i="saoudrizwan.claude-dev";return ["stable","insiders"].map(t=>({variant:t,displayName:t==="stable"?"VS Code":"VS Code Insiders",settingsPath:E__default.join(Qo(t,i),"settings","cline_mcp_settings.json")}))}function es(){return E__default.join(Qo("stable","saoudrizwan.claude-dev"),"settings","cline_mcp_settings.json")}var fp,ts=f(()=>{fp={stable:"Code",insiders:"Code - Insiders"};});function ns(i){return bn.find(e=>e.id===i)}var rs,hp,bn,vn=f(()=>{ts();rs={command:"npx",args:["-y","@constellationdev/mcp@latest"]},hp={extraKnownMarketplaces:{"constellation-plugins":{source:{source:"github",repo:"ShiftinBits/constellation-claude"},autoUpdate:true}},enabledPlugins:{"constellation@constellation-plugins":true}},bn=[{id:"claude-code",displayName:"Claude Code",configPath:".mcp.json",format:"json",skipMcpServer:true,permissionsConfig:{filePath:".claude/settings.json",allowKeyPath:["permissions","allow"],allowValue:"mcp__plugin_constellation_*"},marketplaceConfig:{filePath:".claude/settings.json",config:hp},mcpServersKeyPath:["mcpServers"]},{id:"cline",displayName:"Cline",configPath:es(),isGlobalConfig:true,getGlobalConfigPaths:Zo,format:"json",mcpServersKeyPath:["mcpServers"],mcpServerExtras:{alwaysAllow:["code_intel"],disabled:false}},{id:"codex-cli",displayName:"Codex CLI",configPath:".codex/config.toml",format:"toml",mcpServersKeyPath:["mcp_servers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"$CONSTELLATION_ACCESS_KEY"},mcpServerExtras:{enabled_tools:["code_intel"]},envPolicyConfig:{includeOnlyKeyPath:["shell_environment_policy","include_only"],envVarsToAllow:["CONSTELLATION_ACCESS_KEY"],globalConfigPath:"~/.codex/config.toml"}},{id:"copilot-cli",displayName:"Copilot CLI",configPath:"",format:"json",mcpServersKeyPath:[],skipMcpServer:true,pluginInstallCommand:{command:"copilot",args:["plugin","marketplace","add","ShiftinBits/constellation-copilot"]},pluginPostInstallCommands:[{command:"copilot",args:["plugin","install","constellation@constellation-plugins"]}]},{id:"cursor",displayName:"Cursor",configPath:".cursor/mcp.json",format:"json",mcpServersKeyPath:["mcpServers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"${env:CONSTELLATION_ACCESS_KEY}"}},{id:"gemini-cli",displayName:"Gemini CLI",configPath:"",format:"json",mcpServersKeyPath:[],skipMcpServer:true,pluginInstallCommand:{command:"gemini",args:["extensions","install","https://github.com/ShiftinBits/constellation-gemini"]},pluginUpdateCommand:{command:"gemini",args:["extensions","update","constellation"]},pluginPostInstallCommands:[{command:"gemini",args:["extensions","disable","--scope","user","constellation"]},{command:"gemini",args:["extensions","enable","--scope","workspace","constellation"]}]},{id:"jetbrains-ai",displayName:"JetBrains",configPath:".ai/mcp/mcp.json",format:"json",mcpServersKeyPath:["mcpServers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"CONSTELLATION_ACCESS_KEY"},mcpServerExtras:{tools:["code_intel"]}},{id:"kilo-code",displayName:"Kilo Code",configPath:".kilocode/mcp.json",format:"json",permissionsConfig:{filePath:".kilocode/mcp.json",allowKeyPath:["mcpServers","constellation","alwaysAllow"],allowValue:"code_intel"},mcpServersKeyPath:["mcpServers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"${env:CONSTELLATION_ACCESS_KEY}"}},{id:"opencode",displayName:"OpenCode",configPath:"opencode.jsonc",format:"jsonc",mcpServersKeyPath:["mcp"],skipMcpServer:true,pluginConfig:{pluginKeyPath:["plugin"],pluginValue:"@constellationdev/opencode"},configDefaults:{$schema:"https://opencode.ai/config.json"}},{id:"tabnine",displayName:"Tabnine",configPath:".tabnine/mcp_servers.json",format:"json",mcpServersKeyPath:["mcpServers"]},{id:"vscode-copilot",displayName:"VSCode",configPath:".vscode/mcp.json",format:"json",mcpServersKeyPath:["servers"],mcpEnv:{CONSTELLATION_ACCESS_KEY:"CONSTELLATION_ACCESS_KEY"},mcpServerExtras:{tools:["code_intel"]}}];});async function is(){if(!Sn)try{let i=await import('@iarna/toml');Sn={parse:i.parse,stringify:i.stringify};}catch{throw new Error("TOML support requires @iarna/toml package. Install with: npm install @iarna/toml")}return Sn}function vp(i){let e="",t=0,r=i.length;for(;t<r;)if(i[t]==='"'){for(e+='"',t++;t<r&&i[t]!=='"';)i[t]==="\\"?(e+=i[t++],t<r&&(e+=i[t++])):e+=i[t++];t<r&&(e+=i[t++]);}else if(i[t]==="/"&&t+1<r&&i[t+1]==="/")for(t+=2;t<r&&i[t]!==`
81
+ `;)t++;else if(i[t]==="/"&&t+1<r&&i[t+1]==="*"){for(t+=2;t<r&&!(i[t]==="*"&&t+1<r&&i[t+1]==="/");)t++;t<r&&(t+=2);}else e+=i[t++];return e.replace(/,(\s*[}\]])/g,"$1")}var Sn,pr,os=f(()=>{ae();vn();Sn=null;pr=class{cwd;constructor(e=process.cwd()){this.cwd=e;}async configureTool(e){try{let t=E__default.join(this.cwd,e.configPath),r=!e.skipMcpServer||!!e.pluginConfig||!!e.configDefaults;if(r){await this.ensureDirectoryExists(t);let s=await this.readConfig(t,e.format);if(e.configDefaults)for(let[a,l]of Object.entries(e.configDefaults))a in s||(s[a]=l);e.pluginConfig&&(s=this.addPluginToArray(s,e.pluginConfig)),e.skipMcpServer||(s=this.addConstellationServer(s,e),await this.configureEnvPolicy(s,e)),await this.writeConfig(t,s,e.format);}e.permissionsConfig&&await this.configurePermissions(e.permissionsConfig),e.marketplaceConfig&&await this.configureMarketplace(e.marketplaceConfig);let o;return r?o=t:e.permissionsConfig?o=E__default.join(this.cwd,e.permissionsConfig.filePath):e.marketplaceConfig?o=E__default.join(this.cwd,e.marketplaceConfig.filePath):o=t,{tool:e,success:!0,configuredPath:o}}catch(t){return {tool:e,success:false,error:t instanceof Error?t.message:String(t)}}}async configureGlobalTool(e){if(!e.getGlobalConfigPaths)return [{tool:e,success:false,error:"No global config paths defined"}];let t=e.getGlobalConfigPaths(),r=[];for(let{displayName:o,settingsPath:s}of t)try{await this.ensureDirectoryExists(s);let a=await this.readConfig(s,e.format);a=this.addConstellationServer(a,e),await this.writeConfig(s,a,e.format),r.push({tool:{...e,displayName:`${e.displayName} (${o})`},success:!0,configuredPath:s});}catch(a){let l=a instanceof Error?a.message:String(a);l.includes("ENOENT")||l.includes("no such file")||r.push({tool:{...e,displayName:`${e.displayName} (${o})`},success:false,error:l});}return r}async ensureDirectoryExists(e){let t=E__default.dirname(e);await J__default.mkdir(t,{recursive:true});}async readConfig(e,t){try{if(!await S.fileIsReadable(e))return {};let o=await S.readFile(e);return t==="json"?JSON.parse(o):t==="jsonc"?JSON.parse(vp(o)):(await is()).parse(o)}catch{return {}}}addConstellationServer(e,t){let r=e;for(let a=0;a<t.mcpServersKeyPath.length-1;a++){let l=t.mcpServersKeyPath[a];(!r[l]||typeof r[l]!="object")&&(r[l]={}),r=r[l];}let o=t.mcpServersKeyPath[t.mcpServersKeyPath.length-1];(!r[o]||typeof r[o]!="object")&&(r[o]={});let s=r[o];if(!s.constellation){let a=t.mcpServerConfigOverride??rs,l={...a};if(t.mcpServerExtras&&Object.assign(l,t.mcpServerExtras),t.mcpEnv){let c=t.mcpEnvKey??"env",u=a[c];l[c]={...u,...t.mcpEnv};}s.constellation=l;}return e}async writeConfig(e,t,r){let o;r==="json"||r==="jsonc"?o=JSON.stringify(t,null,2):o=(await is()).stringify(t),o=o.replace(/\r\n/g,`
81
82
  `),o.endsWith(`
82
83
  `)||(o+=`
83
- `),await S.writeFile(e,o);}async configurePermissions(e){let t=E__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let n={};try{if(await S.fileIsReadable(t)){let c=await S.readFile(t);n=JSON.parse(c);}}catch{}let o=n;for(let l=0;l<e.allowKeyPath.length-1;l++){let c=e.allowKeyPath[l];(!o[c]||typeof o[c]!="object")&&(o[c]={}),o=o[c];}let s=e.allowKeyPath[e.allowKeyPath.length-1];Array.isArray(o[s])||(o[s]=[]);let a=o[s];a.includes(e.allowValue)||a.push(e.allowValue),await S.writeFile(t,JSON.stringify(n,null," ")+`
84
- `);}async configureMarketplace(e){let t=E__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let n={};try{if(await S.fileIsReadable(t)){let s=await S.readFile(t);n=JSON.parse(s);}}catch{}n=this.deepMerge(n,e.config),await S.writeFile(t,JSON.stringify(n,null," ")+`
85
- `);}deepMerge(e,t){let n={...e};for(let o of Object.keys(t)){let s=t[o],a=e[o];s&&typeof s=="object"&&!Array.isArray(s)&&a&&typeof a=="object"&&!Array.isArray(a)?n[o]=this.deepMerge(a,s):n[o]=s;}return n}addPluginToArray(e,t){let n=e;for(let a=0;a<t.pluginKeyPath.length-1;a++){let l=t.pluginKeyPath[a];(!n[l]||typeof n[l]!="object")&&(n[l]={}),n=n[l];}let o=t.pluginKeyPath[t.pluginKeyPath.length-1];Array.isArray(n[o])||(n[o]=[]);let s=n[o];return s.includes(t.pluginValue)||s.push(t.pluginValue),e}async configureEnvPolicy(e,t){if(!t.envPolicyConfig)return;let{includeOnlyKeyPath:n,envVarsToAllow:o,globalConfigPath:s}=t.envPolicyConfig;this.addToEnvPolicyWhitelist(e,n,o),s&&await this.updateGlobalEnvPolicy(s,n,o,t.format);}addToEnvPolicyWhitelist(e,t,n){let o=e;for(let l=0;l<t.length-1;l++){let c=t[l];if(!o[c]||typeof o[c]!="object")return;o=o[c];}let s=t[t.length-1];if(!Array.isArray(o[s]))return;let a=o[s];for(let l of n)a.includes(l)||a.push(l);}async updateGlobalEnvPolicy(e,t,n,o){let s=e.replace(/^~/,Ce__default.homedir()),a=await this.readConfig(s,o);if(Object.keys(a).length===0)return;let l=JSON.stringify(a);this.addToEnvPolicyWhitelist(a,t,n);let c=JSON.stringify(a);l!==c&&await this.writeConfig(s,a,o);}};});function ar(i,e){let t=E__default.normalize(i),n=E__default.normalize(e);return t.startsWith(n+E__default.sep)?E__default.relative(e,i):i}var lp,pt,Ho=f(()=>{ko();Qe();Ht();Bo();un();re();O();Ct();bt();lp=promisify(execFile);pt=class extends ce{async run(e={}){try{if(this.reporter.log(`${ae} Initializing project configuration...
86
- `),!await this.git.isGitAvailable())throw new Error("Could not find git client installation. Constellation requires git \u2014 install it from https://git-scm.com/downloads and try again.");let n=E__default.join(process.cwd(),"constellation.json"),o=null,s=await S.fileIsReadable(n);if(s)try{let C=await S.readFile(n);o=JSON.parse(C),this.reporter.info("Found existing constellation.json, current values will be used as defaults.");}catch{this.reporter.warn("Existing constellation.json is invalid, starting fresh.");}if(!await this.git.isGitRepository())throw new Error("Current directory is not a git repository. Run this command from the root directory of a git repository.");let l=await this.git.getRootDir(),[c,u]=await Promise.all([this.git.status(),this.git.listBranches()]),{currentBranch:p}=c,d=u.filter(C=>C!==p),m=p?[p,...d]:d,g=await input({message:"Constellation Project ID:",default:o?.projectId??"",validate:C=>C.trim().length>0||"Project ID is required",theme:L}),h=await select({message:"Branch to index:",choices:m.map(C=>({name:C,value:C})),default:o?.branch??m[0],theme:L}),y=(await checkbox({message:"Select Language(s):",choices:this.buildLanguageChoices(o),required:!0,theme:L})).reduce((C,A)=>(C[A]={fileExtensions:et[A]||[]},C),{});this.reporter.log(""),this.reporter.info("Checking for LSP servers...");for(let[C,A]of Object.entries(y)){let N=de.get(C);if(!N)continue;let X=!1,se="";if(je(N.command)&&(X=!0,se="system"),!X){let ye=E__default.join(At,N.command);existsSync(ye)&&(X=!0,se="managed");}if(X)this.reporter.log(`${w} ${C}: Found ${N.command} (${se})`),A.lsp={command:N.command,args:N.args};else if(await confirm({message:`${C}: ${N.command} not found. Install to ~/.constellation/lsp-servers/?`,default:!0,theme:L}))try{this.reporter.info(`Installing ${N.npmPackages.join(", ")}...`),execFileSync("npm",["install","--prefix",kr,...N.npmPackages],{stdio:"pipe"}),this.reporter.log(`${w} ${C}: Installed ${N.command}`),A.lsp={command:N.command,args:N.args};}catch{this.reporter.error(`${C}: Installation failed`),A.lspEnrichment=!1;}else A.lspEnrichment=!1;}let v=Object.entries(y).filter(([,C])=>C.lspEnrichment!==!1).map(([C])=>C);v.length>0?this.reporter.log(`${w} Index enrichment enabled for: ${v.map(tt).join(", ")}`):this.reporter.warn("No language servers configured. Index enrichment will be skipped.");let x={projectId:g.trim(),branch:h,languages:{...y},...v.length>0&&{lspEnrichment:!0}},j=JSON.stringify(x,void 0,2);await S.writeFile(n,j),this.reporter.log(`${w} ${s?"Updated":"Initialized"} configuration file at ${ar(n,process.cwd())}`),await this.git.stageFile(n),this.reporter.log(`${w} Added constellation.json to staged changes in git`),e.skipMcp||await this.configureMCPServers(),!e.skipCi&&l&&await this.configureCICD(h,l);}catch(t){if(t instanceof Error&&t.name==="ExitPromptError")return;let n=t.message??"An unexpected error occurred";this.reporter.error(`Failed to initialize configuration file.
87
- ${n}`);}}async configureMCPServers(){if(!await confirm({message:"Automatically configure Constellation for AI coding assistants?",default:true,theme:L}))return;let t=await checkbox({message:"Select AI coding assistants to configure:",choices:pn.map(p=>({name:p.displayName,value:p.id})),required:true,theme:L}),n=new sr(process.cwd()),o=[];for(let p of t){let d=Uo(p);if(d)if(this.reporter.info(`Configuring ${d.displayName}...`),d.pluginInstallCommand){let m=await this.executePluginInstall(d);o.push(m),m.success?this.reporter.log(`${w} ${d.displayName} plugin installed successfully`):this.reporter.warn(`${d.displayName}: ${m.error}`);}else if(d.isGlobalConfig&&d.getGlobalConfigPaths){let m=await n.configureGlobalTool(d),g=false;for(let h of m)o.push(h),h.success?(g=true,this.reporter.log(`${w} ${h.tool.displayName} configured at ${ar(h.configuredPath,process.cwd())}`)):h.error&&this.reporter.warn(`${h.tool.displayName}: ${h.error}`);if(g){let h=d.id==="cline"?"global VS Code settings":"global settings";this.reporter.info(`Note: ${d.displayName} uses ${h} (not project-level)`);}if(m.length===0){let h=d.id==="cline"?"No VS Code installations found":"Configuration directory not found";this.reporter.warn(`${d.displayName}: ${h}`);}}else {let m=await n.configureTool(d);o.push(m),m.success?(this.reporter.log(`${w} ${d.displayName} configured at ${ar(m.configuredPath,process.cwd())}`),d.permissionsConfig&&this.reporter.log(`${w} ${d.displayName} permissions set in ${d.permissionsConfig.filePath}`)):this.reporter.warn(`${d.displayName}: ${m.error}`);}}if(o.find(p=>p.tool.id==="claude-code"&&p.success)){let p=E__default.join(process.cwd(),".claude/settings.json");try{await this.git.stageFile(p),this.reporter.log(`${w} Added .claude/settings.json to staged changes in git`);}catch{this.reporter.warn("Could not stage .claude/settings.json in git");}}if(o.find(p=>p.tool.id==="codex-cli"&&p.success)){let p=E__default.join(process.cwd(),".codex/config.toml");try{await this.git.stageFile(p),this.reporter.log(`${w} Added .codex/config.toml to staged changes in git`);}catch{}}if(o.find(p=>p.tool.id==="opencode"&&p.success)){let p=E__default.join(process.cwd(),"opencode.jsonc");try{await this.git.stageFile(p),this.reporter.log(`${w} Added opencode.jsonc to staged changes in git`);}catch{}}let c=o.filter(p=>p.success).length,u=o.filter(p=>!p.success).length;this.reporter.log(`${w} Plugin + MCP configuration complete: ${c} configured`),u>0&&this.reporter.warn(`${u} tool(s) could not be configured`),this.reporter.info("Some tools may require restart to pick up new configuration.");}async executePluginInstall(e){let t=e.pluginInstallCommand;try{await this.runPluginCommand(t);}catch(n){let o=n;if(e.pluginUpdateCommand&&this.isAlreadyInstalledError(o)){this.reporter.info(`${e.displayName} extension already installed, attempting update...`);try{await this.runPluginCommand(e.pluginUpdateCommand);}catch(s){let a=s;return {tool:e,success:false,error:this.formatPluginCommandError(e.pluginUpdateCommand.command,a)}}}else if(this.isAlreadyInstalledError(o)&&(e.pluginPostInstallCommands?.length??0)>0)this.reporter.info(`${e.displayName} plugin source already configured, continuing...`);else return {tool:e,success:false,error:this.formatPluginCommandError(t.command,o)}}for(let n of e.pluginPostInstallCommands??[])try{await this.runPluginCommand(n);}catch(o){let s=o;return {tool:e,success:false,error:this.formatPluginCommandError(n.command,s)}}return {tool:e,success:true}}async runPluginCommand(e){await lp(e.command,e.args,{timeout:3e4,env:process.env});}isAlreadyInstalledError(e){let t=`${e.message??""}
88
- ${e.stderr??""}`.toLowerCase();return t.includes("already installed")||t.includes("already exists")||t.includes("already registered")}formatPluginCommandError(e,t){return t.code==="ENOENT"?`${e} not found. Is ${e} installed and on your PATH?`:t.killed?"Plugin installation timed out after 30 seconds":t.stderr?`Plugin installation failed: ${t.stderr.trim()}`:`Plugin installation failed: ${t.message}`}async configureCICD(e,t){if(!await confirm({message:"Set up a CI/CD pipeline to automatically index your project?",default:true,theme:L}))return;let o=new lt(t),s=await o.detectPlatforms(),a;if(s.length===1){let p=s[0]==="github"?"GitHub Actions":"GitLab CI";if(!await confirm({message:`Detected ${p}. Configure Constellation CI/CD for this platform?`,default:true,theme:L}))return;a=s[0];}else a=await select({message:"Select CI/CD platform:",choices:[{name:"GitHub Actions",value:"github"},{name:"GitLab CI",value:"gitlab"}],theme:L});let l=a==="github"?await o.githubWorkflowExists():await o.gitlabJobExists();if(l&&!await confirm({message:"Constellation CI/CD configuration already exists. Overwrite?",default:false,theme:L})){this.reporter.info("Skipping CI/CD configuration");return}let c;try{c=a==="github"?await o.createGitHubWorkflow(e):await o.createOrMergeGitLabCI(e);}catch(p){this.reporter.warn(`Failed to configure CI/CD pipeline: ${p.message}`);return}let u=ar(c,process.cwd());a==="github"?this.reporter.log(`${w} Created ${u}`):this.reporter.log(`${w} ${l?"Updated":"Created"} ${u} with Constellation indexing`);try{await this.git.stageFile(c),this.reporter.log(`${w} Added ${u} to staged changes in git`);}catch{this.reporter.warn(`Could not stage ${u} in git`);}a==="github"?this.reporter.info(`Add your access key as a repository secret:
84
+ `),await S.writeFile(e,o);}async configurePermissions(e){let t=E__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let r={};try{if(await S.fileIsReadable(t)){let c=await S.readFile(t);r=JSON.parse(c);}}catch{}let o=r;for(let l=0;l<e.allowKeyPath.length-1;l++){let c=e.allowKeyPath[l];(!o[c]||typeof o[c]!="object")&&(o[c]={}),o=o[c];}let s=e.allowKeyPath[e.allowKeyPath.length-1];Array.isArray(o[s])||(o[s]=[]);let a=o[s];a.includes(e.allowValue)||a.push(e.allowValue),await S.writeFile(t,JSON.stringify(r,null," ")+`
85
+ `);}async configureMarketplace(e){let t=E__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let r={};try{if(await S.fileIsReadable(t)){let s=await S.readFile(t);r=JSON.parse(s);}}catch{}r=this.deepMerge(r,e.config),await S.writeFile(t,JSON.stringify(r,null," ")+`
86
+ `);}deepMerge(e,t){let r={...e};for(let o of Object.keys(t)){let s=t[o],a=e[o];s&&typeof s=="object"&&!Array.isArray(s)&&a&&typeof a=="object"&&!Array.isArray(a)?r[o]=this.deepMerge(a,s):r[o]=s;}return r}addPluginToArray(e,t){let r=e;for(let a=0;a<t.pluginKeyPath.length-1;a++){let l=t.pluginKeyPath[a];(!r[l]||typeof r[l]!="object")&&(r[l]={}),r=r[l];}let o=t.pluginKeyPath[t.pluginKeyPath.length-1];Array.isArray(r[o])||(r[o]=[]);let s=r[o];return s.includes(t.pluginValue)||s.push(t.pluginValue),e}async configureEnvPolicy(e,t){if(!t.envPolicyConfig)return;let{includeOnlyKeyPath:r,envVarsToAllow:o,globalConfigPath:s}=t.envPolicyConfig;this.addToEnvPolicyWhitelist(e,r,o),s&&await this.updateGlobalEnvPolicy(s,r,o,t.format);}addToEnvPolicyWhitelist(e,t,r){let o=e;for(let l=0;l<t.length-1;l++){let c=t[l];if(!o[c]||typeof o[c]!="object")return;o=o[c];}let s=t[t.length-1];if(!Array.isArray(o[s]))return;let a=o[s];for(let l of r)a.includes(l)||a.push(l);}async updateGlobalEnvPolicy(e,t,r,o){let s=e.replace(/^~/,Pe__default.homedir()),a=await this.readConfig(s,o);if(Object.keys(a).length===0)return;let l=JSON.stringify(a);this.addToEnvPolicyWhitelist(a,t,r);let c=JSON.stringify(a);l!==c&&await this.writeConfig(s,a,o);}};});function ur(i,e){let t=E__default.normalize(i),r=E__default.normalize(e);return t.startsWith(r+E__default.sep)?E__default.relative(e,i):i}var _p,gt,ls=f(()=>{Xo();nt();Jt();os();vn();ae();M();_t();Ct();_p=promisify(execFile);gt=class extends ge{async run(e={}){try{if(this.reporter.log(`${de} Initializing project configuration...
87
+ `),!await this.git.isGitAvailable())throw new Error("Could not find git client installation. Constellation requires git \u2014 install it from https://git-scm.com/downloads and try again.");let r=E__default.join(process.cwd(),"constellation.json"),o=null,s=await S.fileIsReadable(r);if(s)try{let C=await S.readFile(r);o=JSON.parse(C),this.reporter.info("Found existing constellation.json, current values will be used as defaults.");}catch{this.reporter.warn("Existing constellation.json is invalid, starting fresh.");}if(!await this.git.isGitRepository())throw new Error("Current directory is not a git repository. Run this command from the root directory of a git repository.");let l=await this.git.getRootDir(),[c,u]=await Promise.all([this.git.status(),this.git.listBranches()]),{currentBranch:p}=c,d=u.filter(C=>C!==p),m=p?[p,...d]:d,h=await input({message:"Constellation Project ID:",default:o?.projectId??"",validate:C=>C.trim().length>0||"Project ID is required",theme:F}),g=await select({message:"Branch to index:",choices:m.map(C=>({name:C,value:C})),default:o?.branch??m[0],theme:F}),b=(await checkbox({message:"Select Language(s):",choices:this.buildLanguageChoices(o),required:!0,theme:F})).reduce((C,_)=>(C[_]={fileExtensions:ot[_]||[]},C),{});this.reporter.log(""),this.reporter.info("Checking for LSP servers...");for(let[C,_]of Object.entries(b)){let x=ye.get(C);if(!x)continue;let G=!1,B="";if($e(x.command)&&(G=!0,B="system"),!G){let H=E__default.join($t,x.command);existsSync(H)&&(G=!0,B="managed");}if(G)this.reporter.log(`${w} ${C}: Found ${x.command} (${B})`),_.lsp={command:x.command,args:x.args};else if(await confirm({message:`${C}: ${x.command} not found. Install to ~/.constellation/lsp-servers/?`,default:!0,theme:F}))try{this.reporter.info(`Installing ${x.npmPackages.join(", ")}...`),execFileSync("npm",["install","--prefix",Ur,...x.npmPackages],{stdio:"pipe"}),this.reporter.log(`${w} ${C}: Installed ${x.command}`),_.lsp={command:x.command,args:x.args};}catch{this.reporter.error(`${C}: Installation failed`),_.lspEnrichment=!1;}else _.lspEnrichment=!1;}let v=Object.entries(b).filter(([,C])=>C.lspEnrichment!==!1).map(([C])=>C);v.length>0?this.reporter.log(`${w} Index enrichment enabled for: ${v.map(xe).join(", ")}`):this.reporter.warn("No language servers configured. Index enrichment will be skipped.");let T={projectId:h.trim(),branch:g,languages:{...b},...v.length>0&&{lspEnrichment:!0}},N=JSON.stringify(T,void 0,2);await S.writeFile(r,N),this.reporter.log(`${w} ${s?"Updated":"Initialized"} configuration file at ${ur(r,process.cwd())}`),await this.git.stageFile(r),this.reporter.log(`${w} Added constellation.json to staged changes in git`),e.skipMcp||await this.configureMCPServers(),!e.skipCi&&l&&await this.configureCICD(g,l);}catch(t){if(t instanceof Error&&t.name==="ExitPromptError")return;let r=t.message??"An unexpected error occurred";this.reporter.error(`Failed to initialize configuration file.
88
+ ${r}`);}}async configureMCPServers(){if(!await confirm({message:"Automatically configure Constellation for AI coding assistants?",default:true,theme:F}))return;let t=await checkbox({message:"Select AI coding assistants to configure:",choices:bn.map(p=>({name:p.displayName,value:p.id})),required:true,theme:F}),r=new pr(process.cwd()),o=[];for(let p of t){let d=ns(p);if(d)if(this.reporter.info(`Configuring ${d.displayName}...`),d.pluginInstallCommand){let m=await this.executePluginInstall(d);o.push(m),m.success?this.reporter.log(`${w} ${d.displayName} plugin installed successfully`):this.reporter.warn(`${d.displayName}: ${m.error}`);}else if(d.isGlobalConfig&&d.getGlobalConfigPaths){let m=await r.configureGlobalTool(d),h=false;for(let g of m)o.push(g),g.success?(h=true,this.reporter.log(`${w} ${g.tool.displayName} configured at ${ur(g.configuredPath,process.cwd())}`)):g.error&&this.reporter.warn(`${g.tool.displayName}: ${g.error}`);if(h){let g=d.id==="cline"?"global VS Code settings":"global settings";this.reporter.info(`Note: ${d.displayName} uses ${g} (not project-level)`);}if(m.length===0){let g=d.id==="cline"?"No VS Code installations found":"Configuration directory not found";this.reporter.warn(`${d.displayName}: ${g}`);}}else {let m=await r.configureTool(d);o.push(m),m.success?(this.reporter.log(`${w} ${d.displayName} configured at ${ur(m.configuredPath,process.cwd())}`),d.permissionsConfig&&this.reporter.log(`${w} ${d.displayName} permissions set in ${d.permissionsConfig.filePath}`)):this.reporter.warn(`${d.displayName}: ${m.error}`);}}if(o.find(p=>p.tool.id==="claude-code"&&p.success)){let p=E__default.join(process.cwd(),".claude/settings.json");try{await this.git.stageFile(p),this.reporter.log(`${w} Added .claude/settings.json to staged changes in git`);}catch{this.reporter.warn("Could not stage .claude/settings.json in git");}}if(o.find(p=>p.tool.id==="codex-cli"&&p.success)){let p=E__default.join(process.cwd(),".codex/config.toml");try{await this.git.stageFile(p),this.reporter.log(`${w} Added .codex/config.toml to staged changes in git`);}catch{}}if(o.find(p=>p.tool.id==="opencode"&&p.success)){let p=E__default.join(process.cwd(),"opencode.jsonc");try{await this.git.stageFile(p),this.reporter.log(`${w} Added opencode.jsonc to staged changes in git`);}catch{}}let c=o.filter(p=>p.success).length,u=o.filter(p=>!p.success).length;this.reporter.log(`${w} Plugin + MCP configuration complete: ${c} configured`),u>0&&this.reporter.warn(`${u} tool(s) could not be configured`),this.reporter.info("Some tools may require restart to pick up new configuration.");}async executePluginInstall(e){let t=e.pluginInstallCommand;try{await this.runPluginCommand(t);}catch(r){let o=r;if(e.pluginUpdateCommand&&this.isAlreadyInstalledError(o)){this.reporter.info(`${e.displayName} extension already installed, attempting update...`);try{await this.runPluginCommand(e.pluginUpdateCommand);}catch(s){let a=s;return {tool:e,success:false,error:this.formatPluginCommandError(e.pluginUpdateCommand.command,a)}}}else if(this.isAlreadyInstalledError(o)&&(e.pluginPostInstallCommands?.length??0)>0)this.reporter.info(`${e.displayName} plugin source already configured, continuing...`);else return {tool:e,success:false,error:this.formatPluginCommandError(t.command,o)}}for(let r of e.pluginPostInstallCommands??[])try{await this.runPluginCommand(r);}catch(o){let s=o;return {tool:e,success:false,error:this.formatPluginCommandError(r.command,s)}}return {tool:e,success:true}}async runPluginCommand(e){await _p(e.command,e.args,{timeout:3e4,env:process.env});}isAlreadyInstalledError(e){let t=`${e.message??""}
89
+ ${e.stderr??""}`.toLowerCase();return t.includes("already installed")||t.includes("already exists")||t.includes("already registered")}formatPluginCommandError(e,t){return t.code==="ENOENT"?`${e} not found. Is ${e} installed and on your PATH?`:t.killed?"Plugin installation timed out after 30 seconds":t.stderr?`Plugin installation failed: ${t.stderr.trim()}`:`Plugin installation failed: ${t.message}`}async configureCICD(e,t){if(!await confirm({message:"Set up a CI/CD pipeline to automatically index your project?",default:true,theme:F}))return;let o=new dt(t),s=await o.detectPlatforms(),a;if(s.length===1){let p=s[0]==="github"?"GitHub Actions":"GitLab CI";if(!await confirm({message:`Detected ${p}. Configure Constellation CI/CD for this platform?`,default:true,theme:F}))return;a=s[0];}else a=await select({message:"Select CI/CD platform:",choices:[{name:"GitHub Actions",value:"github"},{name:"GitLab CI",value:"gitlab"}],theme:F});let l=a==="github"?await o.githubWorkflowExists():await o.gitlabJobExists();if(l&&!await confirm({message:"Constellation CI/CD configuration already exists. Overwrite?",default:false,theme:F})){this.reporter.info("Skipping CI/CD configuration");return}let c;try{c=a==="github"?await o.createGitHubWorkflow(e):await o.createOrMergeGitLabCI(e);}catch(p){this.reporter.warn(`Failed to configure CI/CD pipeline: ${p.message}`);return}let u=ur(c,process.cwd());a==="github"?this.reporter.log(`${w} Created ${u}`):this.reporter.log(`${w} ${l?"Updated":"Created"} ${u} with Constellation indexing`);try{await this.git.stageFile(c),this.reporter.log(`${w} Added ${u} to staged changes in git`);}catch{this.reporter.warn(`Could not stage ${u} in git`);}a==="github"?this.reporter.info(`Add your access key as a repository secret:
89
90
  Settings \u2192 Secrets and variables \u2192 Actions \u2192 New repository secret
90
91
  Name: CONSTELLATION_ACCESS_KEY`):this.reporter.info(`Add your access key as a CI/CD variable:
91
92
  Settings \u2192 CI/CD \u2192 Variables \u2192 Add variable
92
- Key: CONSTELLATION_ACCESS_KEY`);}buildLanguageChoices(e){let t=e?.languages?Object.keys(e.languages):[];return [{name:"JavaScript",value:"javascript"},{name:"Python",value:"python"},{name:"TypeScript",value:"typescript"}].map(n=>({...n,checked:t.includes(n.value)}))}};});var lr,Ko=f(()=>{Tr();Xt();re();O();lr=class i{constructor(e,t,n,o,s){this.branch=e;this.languages=t;this.projectId=n;this.exclude=o;this.lspEnrichment=s;this.apiUrl=process.env.CONSTELLATION_API_URL||"https://api.constellationdev.io";}apiUrl;static async loadFromFile(e){if(await S.fileIsReadable(e)){let n=await S.readFile(e),o=JSON.parse(n),s=new i(o.branch,o.languages,o.projectId,o.exclude,o.lspEnrichment);return s.validate(),s}else throw new Error(`${q} Unable to find constellation config at ${e}`)}validate(){if(!this.apiUrl)throw new Error("Invalid configuration: apiUrl is missing");if(!this.branch)throw new Error("Invalid configuration: branch is missing");if(!this.languages||Object.keys(this.languages).length===0)throw new Error("Invalid configuration: no languages configured");if(!this.projectId)throw new Error("Invalid configuration: projectId is missing");try{new URL(this.apiUrl);}catch{throw new Error(`Invalid configuration: apiUrl "${this.apiUrl}" is not a valid URL`)}for(let[e,t]of Object.entries(this.languages)){if(!t.fileExtensions||t.fileExtensions.length===0)throw new Error(`Invalid configuration: language "${e}" has no file extensions`);for(let n of t.fileExtensions)if(!n.startsWith("."))throw new Error(`Invalid configuration: file extension "${n}" for language "${e}" must start with a dot`)}if(this.exclude&&this.exclude.length>0){if(!Array.isArray(this.exclude))throw new Error("Invalid configuration: exclude must be an array of strings");for(let e of this.exclude)if(typeof e!="string")throw new Error("Invalid configuration: exclude patterns must be strings")}}validateBranch(e){if(!e)throw new ue("Not on a Git branch (detached HEAD state)","BRANCH_NOT_CONFIGURED");if(this.branch!==e)throw new ue(`Current branch "${e}" does not match configured branch "${this.branch}". Update constellation.json or switch to "${this.branch}" branch.`,"BRANCH_NOT_CONFIGURED")}};});var pr,mn,ur,gn,fn,hn,dr,Vo=f(()=>{re();pr=class{getVariable(e){return Promise.resolve(process.env[e])}getSourceFile(){}isCIEnvironment(){return this.isCI()}isCI(){return !!(process.env.CI||process.env.GITHUB_ACTIONS||process.env.GITLAB_CI||process.env.JENKINS_URL||process.env.CIRCLECI||process.env.TRAVIS||process.env.BUILDKITE||process.env.DRONE||process.env.TF_BUILD||process.env.BITBUCKET_BUILD_NUMBER||process.env.TEAMCITY_VERSION||process.env.CODEBUILD_BUILD_ID)}validateInput(e,t){if(!e||typeof e!="string")throw new Error("Invalid key provided");if(t==null)throw new Error("Invalid value provided");if(!/^[A-Z_][A-Z0-9_]*$/i.test(e))throw new Error("Environment variable name must contain only letters, numbers, and underscores");if(t.includes("\0"))throw new Error("Value contains invalid characters");if(t.includes(`
93
- `)||t.includes("\r"))throw new Error("Value cannot contain newline characters")}escapeShellValue(e){return e.replace(/[\\'\"$`]/g,"\\$&")}},mn=class extends pr{async getVariable(e){try{let t=await this.queryRegistry("HKCU\\Environment",e);if(t)return process.env[e]=t,t;delete process.env[e];return}catch{return}}async setVariable(e,t){if(this.validateInput(e,t),this.isCI())throw new Error(`Cannot set environment variables in CI/CD environments.
94
- Configure CONSTELLATION_ACCESS_KEY directly in your pipeline settings.`);try{await new Promise((n,o)=>{let s=spawn("setx",[e,t],{shell:!1,windowsHide:!0}),a="";s.stderr?.on("data",l=>{a+=l.toString();}),s.on("close",l=>{l===0?n():o(new Error(`setx failed with code ${l}: ${a}`));}),s.on("error",l=>{o(l);});}),process.env[e]=t;}catch(n){throw new Error(`Failed to set environment variable ${e}: ${n}`)}}async queryRegistry(e,t){try{let o=(await new Promise((s,a)=>{let l=spawn("reg",["query",e,"/v",t],{shell:!1,windowsHide:!0}),c="",u="";l.stdout?.on("data",p=>{c+=p.toString();}),l.stderr?.on("data",p=>{u+=p.toString();}),l.on("close",p=>{p===0?s(c):a(new Error(`reg query failed: ${u}`));}),l.on("error",p=>{a(p);});})).match(/REG_(?:SZ|EXPAND_SZ)\s+(.+?)(?:\r?\n|$)/);return o?o[1].trim():void 0}catch{return}}},ur=class extends pr{userConfigFiles;constructor(){super(),this.userConfigFiles=[E.join(Ce.homedir(),".zshenv"),E.join(Ce.homedir(),".profile")];}getSourceFile(){let e=process.env.SHELL??"";return e.endsWith("/zsh")||e.endsWith("/zsh5")?this.userConfigFiles.find(t=>t.endsWith(".zshenv")):this.userConfigFiles.find(t=>t.endsWith(".profile"))}async setVariable(e,t){if(this.validateInput(e,t),this.isCI())throw new Error(`Cannot set environment variables in CI/CD environments.
95
- Configure CONSTELLATION_ACCESS_KEY directly in your pipeline settings.`);let n=this.escapeShellValue(t),o=`export ${e}="${n}"`;try{for(let s of this.userConfigFiles)await this.writeToConfigFile(s,e,o);process.env[e]=t;}catch(s){throw new Error(`Failed to set environment variable ${e}: ${s}`)}}async writeToConfigFile(e,t,n){let o="";try{o=await S.readFile(e,"utf-8");}catch{}let s=t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),a=new RegExp(`^export ${s}=.*$`,"gm");a.test(o)?o=o.replace(a,n):o=o.trimEnd()+`
96
- `+n+`
97
- `,await S.writeFile(e,o);}async assertSafeWriteTarget(e){try{let t=await G__default.lstat(e);if(!t.isFile()){let o=t.isSymbolicLink()?"symlink":"special file";throw new Error(`refusing to overwrite ${e}: existing path is a ${o}`)}let n=process.getuid?.();if(n!==void 0&&t.uid!==n)throw new Error(`refusing to overwrite ${e}: file is owned by uid ${t.uid}, not the current user`)}catch(t){if(t.code==="ENOENT")return;throw t}}},gn=class i extends ur{static LAUNCH_AGENT_LABEL="io.constellationdev.env";launchAgentDir;launchAgentScriptDir;launchAgentLogDir;launchAgentPlistPath;launchAgentScriptPath;launchAgentStderrPath;constructor(){super();let e=Ce.homedir();this.launchAgentDir=E.join(e,"Library","LaunchAgents"),this.launchAgentScriptDir=E.join(e,"Library","Application Support","Constellation"),this.launchAgentLogDir=E.join(e,"Library","Logs","Constellation"),this.launchAgentPlistPath=E.join(this.launchAgentDir,`${i.LAUNCH_AGENT_LABEL}.plist`),this.launchAgentScriptPath=E.join(this.launchAgentScriptDir,"launchd-env.sh"),this.launchAgentStderrPath=E.join(this.launchAgentLogDir,"launchd-env.err");}async setVariable(e,t){await super.setVariable(e,t);try{await this.ensureLaunchAgentDirs();}catch(n){this.warnLaunchd("create LaunchAgent directories",n);return}try{await this.updateLaunchAgentScript(e,t);}catch(n){this.warnLaunchd("write launchd-env.sh wrapper script",n);return}try{await this.ensureLaunchAgentPlist();}catch(n){this.warnLaunchd("write LaunchAgent plist",n);return}await this.reloadLaunchAgent(),await this.setLaunchctlEnv(e,t);}async ensureLaunchAgentDirs(){await G__default.mkdir(this.launchAgentDir,{recursive:true}),await G__default.mkdir(this.launchAgentScriptDir,{recursive:true}),await G__default.mkdir(this.launchAgentLogDir,{recursive:true}),await G__default.chmod(this.launchAgentScriptDir,448);}static escapeXml(e){return e.replace(/[&<>"']/g,t=>{switch(t){case "&":return "&amp;";case "<":return "&lt;";case ">":return "&gt;";case '"':return "&quot;";case "'":return "&apos;";default:return t}})}async updateLaunchAgentScript(e,t){let n=this.escapeShellValue(t),o=`launchctl setenv ${e} "${n}"`,s="";try{s=await S.readFile(this.launchAgentScriptPath,"utf-8");}catch{}s||(s=`#!/bin/bash
93
+ Key: CONSTELLATION_ACCESS_KEY`);}buildLanguageChoices(e){let t=e?.languages?Object.keys(e.languages):[];return [{name:"JavaScript",value:"javascript"},{name:"Python",value:"python"},{name:"TypeScript",value:"typescript"}].map(r=>({...r,checked:t.includes(r.value)}))}};});var dr,cs=f(()=>{Fr();er();ae();M();dr=class i{constructor(e,t,r,o,s){this.branch=e;this.languages=t;this.projectId=r;this.exclude=o;this.lspEnrichment=s;this.apiUrl=process.env.CONSTELLATION_API_URL||"https://api.constellationdev.io";}apiUrl;static async loadFromFile(e){if(await S.fileIsReadable(e)){let r=await S.readFile(e),o=JSON.parse(r),s=new i(o.branch,o.languages,o.projectId,o.exclude,o.lspEnrichment);return s.validate(),s}else throw new Error(`${re} Unable to find constellation config at ${e}`)}validate(){if(!this.apiUrl)throw new Error("Invalid configuration: apiUrl is missing");if(!this.branch)throw new Error("Invalid configuration: branch is missing");if(!this.languages||Object.keys(this.languages).length===0)throw new Error("Invalid configuration: no languages configured");if(!this.projectId)throw new Error("Invalid configuration: projectId is missing");try{new URL(this.apiUrl);}catch{throw new Error(`Invalid configuration: apiUrl "${this.apiUrl}" is not a valid URL`)}for(let[e,t]of Object.entries(this.languages)){if(!t.fileExtensions||t.fileExtensions.length===0)throw new Error(`Invalid configuration: language "${e}" has no file extensions`);for(let r of t.fileExtensions)if(!r.startsWith("."))throw new Error(`Invalid configuration: file extension "${r}" for language "${e}" must start with a dot`)}if(this.exclude&&this.exclude.length>0){if(!Array.isArray(this.exclude))throw new Error("Invalid configuration: exclude must be an array of strings");for(let e of this.exclude)if(typeof e!="string")throw new Error("Invalid configuration: exclude patterns must be strings")}}validateBranch(e){if(!e)throw new he("Not on a Git branch (detached HEAD state)","BRANCH_NOT_CONFIGURED");if(this.branch!==e)throw new he(`Current branch "${e}" does not match configured branch "${this.branch}". Update constellation.json or switch to "${this.branch}" branch.`,"BRANCH_NOT_CONFIGURED")}};});var gr,wn,fr,Cn,xn,En,hr,ps=f(()=>{ae();gr=class{getVariable(e){return Promise.resolve(process.env[e])}getSourceFile(){}isCIEnvironment(){return this.isCI()}isCI(){return !!(process.env.CI||process.env.GITHUB_ACTIONS||process.env.GITLAB_CI||process.env.JENKINS_URL||process.env.CIRCLECI||process.env.TRAVIS||process.env.BUILDKITE||process.env.DRONE||process.env.TF_BUILD||process.env.BITBUCKET_BUILD_NUMBER||process.env.TEAMCITY_VERSION||process.env.CODEBUILD_BUILD_ID)}validateInput(e,t){if(!e||typeof e!="string")throw new Error("Invalid key provided");if(t==null)throw new Error("Invalid value provided");if(!/^[A-Z_][A-Z0-9_]*$/i.test(e))throw new Error("Environment variable name must contain only letters, numbers, and underscores");if(t.includes("\0"))throw new Error("Value contains invalid characters");if(t.includes(`
94
+ `)||t.includes("\r"))throw new Error("Value cannot contain newline characters")}escapeShellValue(e){return e.replace(/[\\'\"$`]/g,"\\$&")}},wn=class extends gr{async getVariable(e){try{let t=await this.queryRegistry("HKCU\\Environment",e);if(t)return process.env[e]=t,t;delete process.env[e];return}catch{return}}async setVariable(e,t){if(this.validateInput(e,t),this.isCI())throw new Error(`Cannot set environment variables in CI/CD environments.
95
+ Configure CONSTELLATION_ACCESS_KEY directly in your pipeline settings.`);try{await new Promise((r,o)=>{let s=spawn("setx",[e,t],{shell:!1,windowsHide:!0}),a="";s.stderr?.on("data",l=>{a+=l.toString();}),s.on("close",l=>{l===0?r():o(new Error(`setx failed with code ${l}: ${a}`));}),s.on("error",l=>{o(l);});}),process.env[e]=t;}catch(r){throw new Error(`Failed to set environment variable ${e}: ${r}`)}}async queryRegistry(e,t){try{let o=(await new Promise((s,a)=>{let l=spawn("reg",["query",e,"/v",t],{shell:!1,windowsHide:!0}),c="",u="";l.stdout?.on("data",p=>{c+=p.toString();}),l.stderr?.on("data",p=>{u+=p.toString();}),l.on("close",p=>{p===0?s(c):a(new Error(`reg query failed: ${u}`));}),l.on("error",p=>{a(p);});})).match(/REG_(?:SZ|EXPAND_SZ)\s+(.+?)(?:\r?\n|$)/);return o?o[1].trim():void 0}catch{return}}},fr=class extends gr{userConfigFiles;constructor(){super(),this.userConfigFiles=[E.join(Pe.homedir(),".zshenv"),E.join(Pe.homedir(),".profile")];}getSourceFile(){let e=process.env.SHELL??"";return e.endsWith("/zsh")||e.endsWith("/zsh5")?this.userConfigFiles.find(t=>t.endsWith(".zshenv")):this.userConfigFiles.find(t=>t.endsWith(".profile"))}async setVariable(e,t){if(this.validateInput(e,t),this.isCI())throw new Error(`Cannot set environment variables in CI/CD environments.
96
+ Configure CONSTELLATION_ACCESS_KEY directly in your pipeline settings.`);let r=this.escapeShellValue(t),o=`export ${e}="${r}"`;try{for(let s of this.userConfigFiles)await this.writeToConfigFile(s,e,o);process.env[e]=t;}catch(s){throw new Error(`Failed to set environment variable ${e}: ${s}`)}}async writeToConfigFile(e,t,r){let o="";try{o=await S.readFile(e,"utf-8");}catch{}let s=t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),a=new RegExp(`^export ${s}=.*$`,"gm");a.test(o)?o=o.replace(a,r):o=o.trimEnd()+`
97
+ `+r+`
98
+ `,await S.writeFile(e,o);}async assertSafeWriteTarget(e){try{let t=await J__default.lstat(e);if(!t.isFile()){let o=t.isSymbolicLink()?"symlink":"special file";throw new Error(`refusing to overwrite ${e}: existing path is a ${o}`)}let r=process.getuid?.();if(r!==void 0&&t.uid!==r)throw new Error(`refusing to overwrite ${e}: file is owned by uid ${t.uid}, not the current user`)}catch(t){if(t.code==="ENOENT")return;throw t}}},Cn=class i extends fr{static LAUNCH_AGENT_LABEL="io.constellationdev.env";launchAgentDir;launchAgentScriptDir;launchAgentLogDir;launchAgentPlistPath;launchAgentScriptPath;launchAgentStderrPath;constructor(){super();let e=Pe.homedir();this.launchAgentDir=E.join(e,"Library","LaunchAgents"),this.launchAgentScriptDir=E.join(e,"Library","Application Support","Constellation"),this.launchAgentLogDir=E.join(e,"Library","Logs","Constellation"),this.launchAgentPlistPath=E.join(this.launchAgentDir,`${i.LAUNCH_AGENT_LABEL}.plist`),this.launchAgentScriptPath=E.join(this.launchAgentScriptDir,"launchd-env.sh"),this.launchAgentStderrPath=E.join(this.launchAgentLogDir,"launchd-env.err");}async setVariable(e,t){await super.setVariable(e,t);try{await this.ensureLaunchAgentDirs();}catch(r){this.warnLaunchd("create LaunchAgent directories",r);return}try{await this.updateLaunchAgentScript(e,t);}catch(r){this.warnLaunchd("write launchd-env.sh wrapper script",r);return}try{await this.ensureLaunchAgentPlist();}catch(r){this.warnLaunchd("write LaunchAgent plist",r);return}await this.reloadLaunchAgent(),await this.setLaunchctlEnv(e,t);}async ensureLaunchAgentDirs(){await J__default.mkdir(this.launchAgentDir,{recursive:true}),await J__default.mkdir(this.launchAgentScriptDir,{recursive:true}),await J__default.mkdir(this.launchAgentLogDir,{recursive:true}),await J__default.chmod(this.launchAgentScriptDir,448);}static escapeXml(e){return e.replace(/[&<>"']/g,t=>{switch(t){case "&":return "&amp;";case "<":return "&lt;";case ">":return "&gt;";case '"':return "&quot;";case "'":return "&apos;";default:return t}})}async updateLaunchAgentScript(e,t){let r=this.escapeShellValue(t),o=`launchctl setenv ${e} "${r}"`,s="";try{s=await S.readFile(this.launchAgentScriptPath,"utf-8");}catch{}s||(s=`#!/bin/bash
98
99
  # Managed by Constellation CLI - do not edit manually
99
100
  `);let a=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),l=new RegExp(`^launchctl setenv ${a} .*$`,"gm");l.test(s)?s=s.replace(l,o):s=s.trimEnd()+`
100
101
  `+o+`
101
- `,await this.assertSafeWriteTarget(this.launchAgentScriptPath),await G__default.writeFile(this.launchAgentScriptPath,s,{mode:448}),await G__default.chmod(this.launchAgentScriptPath,448);}async ensureLaunchAgentPlist(){let e=i.escapeXml(this.launchAgentScriptPath),t=i.escapeXml(this.launchAgentStderrPath),o=`<?xml version="1.0" encoding="UTF-8"?>
102
+ `,await this.assertSafeWriteTarget(this.launchAgentScriptPath),await J__default.writeFile(this.launchAgentScriptPath,s,{mode:448}),await J__default.chmod(this.launchAgentScriptPath,448);}async ensureLaunchAgentPlist(){let e=i.escapeXml(this.launchAgentScriptPath),t=i.escapeXml(this.launchAgentStderrPath),o=`<?xml version="1.0" encoding="UTF-8"?>
102
103
  <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
103
104
  <plist version="1.0">
104
105
  <dict>
@@ -117,18 +118,18 @@ ${e.stderr??""}`.toLowerCase();return t.includes("already installed")||t.include
117
118
  <string>${t}</string>
118
119
  </dict>
119
120
  </plist>
120
- `;await this.assertSafeWriteTarget(this.launchAgentPlistPath),await S.writeFile(this.launchAgentPlistPath,o),await G__default.chmod(this.launchAgentPlistPath,384);}warnLaunchd(e,t){let n=t instanceof Error?t.message:String(t);console.warn(`Warning: failed to ${e} for GUI apps: ${n}
121
- Shell environments still updated; log out and back in if GUI apps don't see the value.`);}runLaunchctl(e,t){return new Promise((n,o)=>{let s=spawn("/bin/launchctl",e,{shell:false}),a="";s.stderr?.on("data",l=>{a+=l.toString();}),s.on("close",l=>{l===0||t?n():o(new Error(`launchctl ${e[0]} failed (code ${l}): ${a.trim()}`));}),s.on("error",l=>{t?n():o(l);});})}async reloadLaunchAgent(){let e=process.getuid?.();if(e!==void 0)try{await this.runLaunchctl(["bootout",`gui/${e}/${i.LAUNCH_AGENT_LABEL}`],!0),await this.runLaunchctl(["bootstrap",`gui/${e}`,this.launchAgentPlistPath],!1);}catch(t){this.warnLaunchd("register LaunchAgent for next login",t);}}async setLaunchctlEnv(e,t){try{await this.runLaunchctl(["setenv",e,t],!0);}catch(n){this.warnLaunchd("run launchctl setenv",n);}}},fn=class i extends ur{static ENV_D_FILENAME="io.constellationdev.env.conf";envDDir;envDFilePath;constructor(){super(),this.envDDir=E.join(Ce.homedir(),".config","environment.d"),this.envDFilePath=E.join(this.envDDir,i.ENV_D_FILENAME);}async setVariable(e,t){await super.setVariable(e,t);try{await this.ensureEnvironmentDDir();}catch(n){this.warnSystemd("create environment.d directory",n);return}try{await this.updateEnvironmentDFile(e,t);}catch(n){this.warnSystemd("write environment.d conf file",n);return}await this.importToSystemdUser(e,t);}async ensureEnvironmentDDir(){await G__default.mkdir(this.envDDir,{recursive:true});}async updateEnvironmentDFile(e,t){let n=i.escapeEnvironmentDValue(t),o=`${e}=${n}`,s="";try{s=await S.readFile(this.envDFilePath,"utf-8");}catch{}s||(s=`# Managed by Constellation CLI - do not edit manually
121
+ `;await this.assertSafeWriteTarget(this.launchAgentPlistPath),await S.writeFile(this.launchAgentPlistPath,o),await J__default.chmod(this.launchAgentPlistPath,384);}warnLaunchd(e,t){let r=t instanceof Error?t.message:String(t);console.warn(`Warning: failed to ${e} for GUI apps: ${r}
122
+ Shell environments still updated; log out and back in if GUI apps don't see the value.`);}runLaunchctl(e,t){return new Promise((r,o)=>{let s=spawn("/bin/launchctl",e,{shell:false}),a="";s.stderr?.on("data",l=>{a+=l.toString();}),s.on("close",l=>{l===0||t?r():o(new Error(`launchctl ${e[0]} failed (code ${l}): ${a.trim()}`));}),s.on("error",l=>{t?r():o(l);});})}async reloadLaunchAgent(){let e=process.getuid?.();if(e!==void 0)try{await this.runLaunchctl(["bootout",`gui/${e}/${i.LAUNCH_AGENT_LABEL}`],!0),await this.runLaunchctl(["bootstrap",`gui/${e}`,this.launchAgentPlistPath],!1);}catch(t){this.warnLaunchd("register LaunchAgent for next login",t);}}async setLaunchctlEnv(e,t){try{await this.runLaunchctl(["setenv",e,t],!0);}catch(r){this.warnLaunchd("run launchctl setenv",r);}}},xn=class i extends fr{static ENV_D_FILENAME="io.constellationdev.env.conf";envDDir;envDFilePath;constructor(){super(),this.envDDir=E.join(Pe.homedir(),".config","environment.d"),this.envDFilePath=E.join(this.envDDir,i.ENV_D_FILENAME);}async setVariable(e,t){await super.setVariable(e,t);try{await this.ensureEnvironmentDDir();}catch(r){this.warnSystemd("create environment.d directory",r);return}try{await this.updateEnvironmentDFile(e,t);}catch(r){this.warnSystemd("write environment.d conf file",r);return}await this.importToSystemdUser(e,t);}async ensureEnvironmentDDir(){await J__default.mkdir(this.envDDir,{recursive:true});}async updateEnvironmentDFile(e,t){let r=i.escapeEnvironmentDValue(t),o=`${e}=${r}`,s="";try{s=await S.readFile(this.envDFilePath,"utf-8");}catch{}s||(s=`# Managed by Constellation CLI - do not edit manually
122
123
  `);let a=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),l=new RegExp(`^${a}=.*$`,"gm");l.test(s)?s=s.replace(l,o):s=s.trimEnd()+`
123
124
  `+o+`
124
- `,await this.assertSafeWriteTarget(this.envDFilePath),await G__default.writeFile(this.envDFilePath,s,{mode:384}),await G__default.chmod(this.envDFilePath,384);}async importToSystemdUser(e,t){if(je("systemctl")&&process.env.XDG_RUNTIME_DIR)try{await this.runSystemctl(["--user","set-environment",`${e}=${t}`],!1);}catch(n){this.warnSystemd("run systemctl --user set-environment",n);}}runSystemctl(e,t){return new Promise((n,o)=>{let s=spawn("systemctl",e,{shell:false}),a="";s.stderr?.on("data",l=>{a+=l.toString();}),s.on("close",l=>{l===0||t?n():o(new Error(`systemctl ${e.slice(0,2).join(" ")} failed (code ${l}): ${a.trim()}`));}),s.on("error",l=>{t?n():o(l);});})}static escapeEnvironmentDValue(e){return e.replace(/\\/g,"\\\\").replace(/\$/g,"$$$$")}warnSystemd(e,t){let n=t instanceof Error?t.message:String(t);console.warn(`Warning: failed to ${e} for systemd user services: ${n}
125
- Shell environments still updated; log out and back in if systemd-launched apps don't see the value.`);}},hn=class{static create(){let e=Ce.platform();switch(e){case "win32":return new mn;case "darwin":return new gn;case "linux":return new fn;default:throw new Error(`Unsupported platform: ${e}`)}}},dr=class{manager;constructor(){this.manager=hn.create();}async setKey(e,t){await this.manager.setVariable(e.toUpperCase(),t);}async getKey(e){return this.manager.getVariable(e.toUpperCase())}isCI(){return this.manager.isCIEnvironment()}getSourceFile(){return this.manager.getSourceFile()}};});var mr,Jo=f(()=>{mr=class{extensionToLanguageMap;constructor(e){this.extensionToLanguageMap=new Map;for(let[t,n]of Object.entries(e.languages))for(let o of n.fileExtensions)this.extensionToLanguageMap.set(o,t);}detectLanguage(e){let t=E__default.extname(e).toLowerCase();return this.extensionToLanguageMap.get(t)||null}};});function qo(){return pp.some(i=>!!process.env[i])}function Yo(){return !!process.stdout.isTTY}var pp,Xo=f(()=>{pp=["CI","GITHUB_ACTIONS","GITLAB_CI","JENKINS_URL","CIRCLECI","TRAVIS","BUILDKITE","DRONE"];});function Qo(i=process.argv,e=process.env){let t=i.includes("--verbose"),n=i.includes("--quiet")||i.includes("-q")||i.includes("-Q");if(t&&n){try{process.stderr.write(`note: --verbose and --quiet are mutually exclusive; --verbose wins.
126
- `);}catch{}return "verbose"}if(t)return "verbose";if(n)return "quiet";if(e.CONSTELLATION_REPORTER_MODE){let a=e.CONSTELLATION_REPORTER_MODE;if(a==="spinner"||a==="verbose"||a==="quiet"||a==="plain")return a}let o=qo(),s=Yo();return o||!s?"plain":"spinner"}var Zo=f(()=>{Xo();});function up(){let i=Ce.platform();if(i==="darwin")return E.join(Ce.homedir(),"Library","Caches","constellation");if(i==="win32"){let e=process.env.LOCALAPPDATA||E.join(Ce.homedir(),"AppData","Local");return E.join(e,"constellation","cache")}else {let e=process.env.XDG_CACHE_HOME||E.join(Ce.homedir(),".cache");return E.join(e,"constellation")}}var dp,mp,gp,ut,yn=f(()=>{dp=up(),mp="update-state.json",gp=1440*60*1e3,ut=class{state=null;stateDir;stateFile;constructor(e){this.stateDir=e??dp,this.stateFile=E.join(this.stateDir,mp);}async load(){if(this.state)return this.state;try{let e=await G.readFile(this.stateFile,"utf-8");return this.state=JSON.parse(e),this.state}catch{return {lastCheckTimestamp:0}}}async save(e){try{await G.mkdir(this.stateDir,{recursive:!0}),await G.writeFile(this.stateFile,JSON.stringify(e,null,2)),this.state=e;}catch{}}async shouldCheck(){let e=await this.load();return Date.now()-e.lastCheckTimestamp>gp}async recordCheck(){let e=await this.load();e.lastCheckTimestamp=Date.now(),await this.save(e);}async recordDecline(e){let t=await this.load();t.lastDeclinedVersion=e,t.lastDeclinedTimestamp=Date.now(),await this.save(t);}async wasVersionDeclined(e){return (await this.load()).lastDeclinedVersion===e}async clear(){try{await G.unlink(this.stateFile),this.state=null;}catch{}}};});var dt,vn=f(()=>{dt=class{detectedManager=null;detect(){if(this.detectedManager)return this.detectedManager;let e=process.env.npm_config_user_agent;return e?e.startsWith("yarn")?this.detectedManager="yarn":e.startsWith("pnpm")?this.detectedManager="pnpm":e.startsWith("bun")?this.detectedManager="bun":this.detectedManager="npm":this.detectedManager="npm",this.detectedManager}getUpdateCommand(e){switch(this.detect()){case "yarn":return ["yarn","global","add",`${e}@latest`];case "pnpm":return ["pnpm","add","-g",`${e}@latest`];case "bun":return ["bun","add","-g",`${e}@latest`];default:return ["npm","install","-g",`${e}@latest`]}}getUpdateCommandString(e){return this.getUpdateCommand(e).join(" ")}async executeUpdate(e){let[t,...n]=this.getUpdateCommand(e);return new Promise(o=>{let s=spawn(t,n,{stdio:"inherit",shell:process.platform==="win32"});s.on("close",a=>{o(a===0);}),s.on("error",()=>{o(false);});})}};});var mt,bn=f(()=>{Ie();O();bt();mt=class{async promptForUpdate(e,t,n){console.log(""),console.log(cyan("\u2501".repeat(60))),console.log(`${ae} ${bold("Update Available!")}`),console.log(""),console.log(` Current version: ${dim(e)}`),console.log(` Latest version: ${bold(green(t))}`),console.log(""),console.log(` ${dim(`Package manager: ${n}`)}`),console.log(cyan("\u2501".repeat(60))),console.log("");try{return await confirm({message:"Would you like to update now?",default:!0,theme:L})}catch{return false}}};});async function Sn(i){return new fr().check(i)}var yp,gr,vp,fr,es=f(()=>{O();yn();vn();bn();yp="https://registry.npmjs.org",gr="@constellationdev/cli",vp=5e3,fr=class{cache;packageManager;prompter;constructor(){this.cache=new ut,this.packageManager=new dt,this.prompter=new mt;}async check(e){if(!await this.cache.shouldCheck())return false;try{let t=await this.fetchLatestVersion(e);return await this.cache.recordCheck(),!t.hasUpdate||await this.cache.wasVersionDeclined(t.latest)?!1:await this.prompter.promptForUpdate(t.current,t.latest,this.packageManager.detect())?await this.performUpdate():(await this.cache.recordDecline(t.latest),!1)}catch{return false}}async fetchLatestVersion(e){let t=new AbortController,n=setTimeout(()=>t.abort(),vp);try{let o=await fetch(`${yp}/${gr}/latest`,{signal:t.signal,headers:{Accept:"application/json"}});if(!o.ok)throw new Error(`Registry returned ${o.status}`);let a=(await o.json()).version;return {current:e,latest:a,hasUpdate:this.isNewerVersion(a,e)}}finally{clearTimeout(n);}}isNewerVersion(e,t){let n=a=>a.split("-")[0],o=n(e).split(".").map(Number),s=n(t).split(".").map(Number);for(let a=0;a<3;a++){let l=o[a]||0,c=s[a]||0;if(l>c)return true;if(l<c)return false}return false}async performUpdate(){return console.log(`
127
- ${Z} Updating ${gr}...
128
- `),await this.packageManager.executeUpdate(gr)?(console.log(`
125
+ `,await this.assertSafeWriteTarget(this.envDFilePath),await J__default.writeFile(this.envDFilePath,s,{mode:384}),await J__default.chmod(this.envDFilePath,384);}async importToSystemdUser(e,t){if($e("systemctl")&&process.env.XDG_RUNTIME_DIR)try{await this.runSystemctl(["--user","set-environment",`${e}=${t}`],!1);}catch(r){this.warnSystemd("run systemctl --user set-environment",r);}}runSystemctl(e,t){return new Promise((r,o)=>{let s=spawn("systemctl",e,{shell:false}),a="";s.stderr?.on("data",l=>{a+=l.toString();}),s.on("close",l=>{l===0||t?r():o(new Error(`systemctl ${e.slice(0,2).join(" ")} failed (code ${l}): ${a.trim()}`));}),s.on("error",l=>{t?r():o(l);});})}static escapeEnvironmentDValue(e){return e.replace(/\\/g,"\\\\").replace(/\$/g,"$$$$")}warnSystemd(e,t){let r=t instanceof Error?t.message:String(t);console.warn(`Warning: failed to ${e} for systemd user services: ${r}
126
+ Shell environments still updated; log out and back in if systemd-launched apps don't see the value.`);}},En=class{static create(){let e=Pe.platform();switch(e){case "win32":return new wn;case "darwin":return new Cn;case "linux":return new xn;default:throw new Error(`Unsupported platform: ${e}`)}}},hr=class{manager;constructor(){this.manager=En.create();}async setKey(e,t){await this.manager.setVariable(e.toUpperCase(),t);}async getKey(e){return this.manager.getVariable(e.toUpperCase())}isCI(){return this.manager.isCIEnvironment()}getSourceFile(){return this.manager.getSourceFile()}};});var yr,us=f(()=>{yr=class{extensionToLanguageMap;constructor(e){this.extensionToLanguageMap=new Map;for(let[t,r]of Object.entries(e.languages))for(let o of r.fileExtensions)this.extensionToLanguageMap.set(o,t);}detectLanguage(e){let t=E__default.extname(e).toLowerCase();return this.extensionToLanguageMap.get(t)||null}};});function ds(i=process.argv,e=process.env){let t=i.includes("--verbose"),r=i.includes("--quiet")||i.includes("-q")||i.includes("-Q");if(t&&r){try{process.stderr.write(`note: --verbose and --quiet are mutually exclusive; --verbose wins.
127
+ `);}catch{}return "verbose"}if(t)return "verbose";if(r)return "quiet";if(e.CONSTELLATION_REPORTER_MODE){let a=e.CONSTELLATION_REPORTER_MODE;if(a==="spinner"||a==="verbose"||a==="quiet"||a==="plain")return a}let o=di(),s=mi();return o||!s?"plain":"spinner"}var ms=f(()=>{jr();});function Ip(){let i=Pe.platform();if(i==="darwin")return E.join(Pe.homedir(),"Library","Caches","constellation");if(i==="win32"){let e=process.env.LOCALAPPDATA||E.join(Pe.homedir(),"AppData","Local");return E.join(e,"constellation","cache")}else {let e=process.env.XDG_CACHE_HOME||E.join(Pe.homedir(),".cache");return E.join(e,"constellation")}}var Np,Rp,Tp,ft,_n=f(()=>{Np=Ip(),Rp="update-state.json",Tp=1440*60*1e3,ft=class{state=null;stateDir;stateFile;constructor(e){this.stateDir=e??Np,this.stateFile=E.join(this.stateDir,Rp);}async load(){if(this.state)return this.state;try{let e=await J.readFile(this.stateFile,"utf-8");return this.state=JSON.parse(e),this.state}catch{return {lastCheckTimestamp:0}}}async save(e){try{await J.mkdir(this.stateDir,{recursive:!0}),await J.writeFile(this.stateFile,JSON.stringify(e,null,2)),this.state=e;}catch{}}async shouldCheck(){let e=await this.load();return Date.now()-e.lastCheckTimestamp>Tp}async recordCheck(){let e=await this.load();e.lastCheckTimestamp=Date.now(),await this.save(e);}async recordDecline(e){let t=await this.load();t.lastDeclinedVersion=e,t.lastDeclinedTimestamp=Date.now(),await this.save(t);}async wasVersionDeclined(e){return (await this.load()).lastDeclinedVersion===e}async clear(){try{await J.unlink(this.stateFile),this.state=null;}catch{}}};});var ht,Pn=f(()=>{ht=class{detectedManager=null;detect(){if(this.detectedManager)return this.detectedManager;let e=process.env.npm_config_user_agent;return e?e.startsWith("yarn")?this.detectedManager="yarn":e.startsWith("pnpm")?this.detectedManager="pnpm":e.startsWith("bun")?this.detectedManager="bun":this.detectedManager="npm":this.detectedManager="npm",this.detectedManager}getUpdateCommand(e){switch(this.detect()){case "yarn":return ["yarn","global","add",`${e}@latest`];case "pnpm":return ["pnpm","add","-g",`${e}@latest`];case "bun":return ["bun","add","-g",`${e}@latest`];default:return ["npm","install","-g",`${e}@latest`]}}getUpdateCommandString(e){return this.getUpdateCommand(e).join(" ")}async executeUpdate(e){let[t,...r]=this.getUpdateCommand(e);return new Promise(o=>{let s=spawn(t,r,{stdio:"inherit",shell:process.platform==="win32"});s.on("close",a=>{o(a===0);}),s.on("error",()=>{o(false);});})}};});var yt,In=f(()=>{Le();M();Ct();yt=class{async promptForUpdate(e,t,r){console.log(""),console.log(cyan("\u2501".repeat(60))),console.log(`${de} ${bold("Update Available!")}`),console.log(""),console.log(` Current version: ${dim(e)}`),console.log(` Latest version: ${bold(green(t))}`),console.log(""),console.log(` ${dim(`Package manager: ${r}`)}`),console.log(cyan("\u2501".repeat(60))),console.log("");try{return await confirm({message:"Would you like to update now?",default:!0,theme:F})}catch{return false}}};});async function Nn(i){return new vr().check(i)}var Ap,br,kp,vr,gs=f(()=>{M();_n();Pn();In();Ap="https://registry.npmjs.org",br="@constellationdev/cli",kp=5e3,vr=class{cache;packageManager;prompter;constructor(){this.cache=new ft,this.packageManager=new ht,this.prompter=new yt;}async check(e){if(!await this.cache.shouldCheck())return false;try{let t=await this.fetchLatestVersion(e);return await this.cache.recordCheck(),!t.hasUpdate||await this.cache.wasVersionDeclined(t.latest)?!1:await this.prompter.promptForUpdate(t.current,t.latest,this.packageManager.detect())?await this.performUpdate():(await this.cache.recordDecline(t.latest),!1)}catch{return false}}async fetchLatestVersion(e){let t=new AbortController,r=setTimeout(()=>t.abort(),kp);try{let o=await fetch(`${Ap}/${br}/latest`,{signal:t.signal,headers:{Accept:"application/json"}});if(!o.ok)throw new Error(`Registry returned ${o.status}`);let a=(await o.json()).version;return {current:e,latest:a,hasUpdate:this.isNewerVersion(a,e)}}finally{clearTimeout(r);}}isNewerVersion(e,t){let r=a=>a.split("-")[0],o=r(e).split(".").map(Number),s=r(t).split(".").map(Number);for(let a=0;a<3;a++){let l=o[a]||0,c=s[a]||0;if(l>c)return true;if(l<c)return false}return false}async performUpdate(){return console.log(`
128
+ ${ie} Updating ${br}...
129
+ `),await this.packageManager.executeUpdate(br)?(console.log(`
129
130
  ${w} Update complete! Please re-run your command.
130
131
  `),true):(console.log(`
131
- ${T} Update failed. You can try updating manually:`),console.log(` ${this.packageManager.getUpdateCommandString(gr)}
132
- `),false)}};});var ts=f(()=>{yn();vn();bn();es();});var gt,rs=f(()=>{O();gt=class{constructor(e,t){this.reporter=t;let n={baseDir:e,maxConcurrentProcesses:6};this.git=simpleGit(n);}git;async getLatestCommitHash(){let e=await this.git.log({maxCount:1});if(!e.latest)throw new Error("No commits found in repository");return e.latest.hash}async getCommitTimestamp(){let t=(await this.git.raw(["log","-1","--format=%aI"])).trim();if(!t)throw new Error("No commits found in repository");let n=new Date(t);if(Number.isNaN(n.getTime()))throw new Error(`Could not parse commit timestamp: ${t}`);return n.toISOString()}async getChangedFiles(e){let t=await this.git.diff(["--name-status",e,"HEAD"]),n={added:[],modified:[],deleted:[],renamed:[]},o=t.split(/\r?\n/).map(s=>s.trim()).filter(Boolean);for(let s of o){let a=s.split(" ");if(a.length<2)continue;let l=a[0];l==="A"?n.added.push(a[1]):l==="M"?n.modified.push(a[1]):l==="D"?n.deleted.push(a[1]):l.startsWith("R")&&a.length>=3&&n.renamed.push({from:a[1],to:a[2]});}return n}async getRemoteOriginUrl(){let t=(await this.git.getRemotes(true)).find(n=>n.name==="origin");if(!t||!t.refs.fetch)throw new Error("Remote origin URL not found or has no fetch URL");return t.refs.fetch}async getRootDir(){try{return (await this.git.revparse(["--show-toplevel"])).trim()}catch{return null}}async isGitAvailable(){try{return await this.git.version(),!0}catch{return false}}async isGitRepository(){try{return await this.git.checkIsRepo()}catch{return false}}async listBranches(){return (await this.git.branchLocal()).all}async stageFile(e){await this.git.add(e);}async status(){let e=await this.git.status(),t=e.files?.length===0,n=e.current;return {clean:t,currentBranch:n}}async pull(){try{let e=await this.git.status();if(!e.isClean()){let o={modified:e.modified.length,created:e.created.length,deleted:e.deleted.length,conflicted:e.conflicted.length,staged:e.staged.length};throw this.reporter?.error("Cannot pull: Working directory has uncommitted changes"),this.reporter?.detail(`Details: ${JSON.stringify(o,null,2)}`),e.conflicted.length>0&&this.reporter?.warn(`Conflicted files: ${e.conflicted.join(", ")}`),new Error(`Cannot pull with uncommitted changes. Please commit or stash your changes first.
133
- Modified: ${o.modified}, Created: ${o.created}, Deleted: ${o.deleted}, Conflicted: ${o.conflicted}, Staged: ${o.staged}`)}let t=await this.git.pull();if(t.summary.changes===0&&t.summary.insertions===0&&t.summary.deletions===0){let o=await this.git.status();if(o.conflicted.length>0)throw this.reporter?.error("Pull failed: Merge conflicts detected"),this.reporter?.detail(`Conflicted files: ${o.conflicted.join(", ")}`),this.reporter?.detail("Please resolve conflicts manually and commit the result"),new Error(`Pull resulted in merge conflicts in ${o.conflicted.length} file(s): ${o.conflicted.join(", ")}`)}t.summary.changes>0&&this.reporter?.log(`${w} Pull successful: ${t.summary.changes} files changed, ${t.summary.insertions} insertions(+), ${t.summary.deletions} deletions(-)`);let n=await this.git.status();if(n.conflicted.length>0)throw this.reporter?.error("Unexpected conflicts after pull:"),this.reporter?.detail(`Conflicted files: ${n.conflicted.join(", ")}`),new Error(`Unexpected merge conflicts detected after pull: ${n.conflicted.join(", ")}`);return !0}catch(e){throw e instanceof Error?(e.message.includes("CONFLICT")?(this.reporter?.error("Pull failed due to merge conflicts"),this.reporter?.detail('Run "git status" to see conflicted files'),this.reporter?.detail('Resolve conflicts, then run "git add" and "git commit"')):e.message.includes("not a git repository")?this.reporter?.error("Pull failed: Not in a git repository"):e.message.includes("Could not resolve host")||e.message.includes("unable to access")?this.reporter?.error("Pull failed: Network error - unable to reach remote repository"):e.message.includes("Authentication failed")?this.reporter?.error("Pull failed: Authentication error - check your credentials"):e.message.includes("uncommitted changes")&&this.reporter?.error("Pull failed: Uncommitted changes in working directory"),new Error(`Git pull operation failed: ${e.message}`,{cause:e})):new Error(`Git pull operation failed: ${String(e)}`)}}};});var is,ns=f(()=>{is={"tree-sitter":"0.21.1","tree-sitter-typescript":"0.21.2","tree-sitter-javascript":"0.21.4","tree-sitter-python":"0.21.0"};});function os(){let i={};for(let e of wp){let t=is[e];if(typeof t!="string"||t.length===0)throw new Error(`grammar-versions.json missing entry for ${e}`);i[e]=t;}return i}var wp,ss=f(()=>{ns();wp=["tree-sitter","tree-sitter-typescript","tree-sitter-javascript","tree-sitter-python"];});var Ip={};var M,he,as,wn,_p,Pp,Cn,xn,ze,ls=f(async()=>{$n();Ro();Ho();Ko();Vo();Jo();Ht();Zo();qr();ts();yr();wt();rs();ss();M=new tr({mode:Qo(process.argv)}),he=()=>{try{M.stop();}catch{}};process.on("exit",he);process.on("uncaughtException",i=>{i instanceof Error&&i.code==="ERR_USE_AFTER_CLOSE"&&(he(),process.exit(0)),ie(i)||M.error(i?.message??String(i)),he(),process.exit(1);});as=globalThis.__constellationVersion??(()=>{let i=E__default.dirname(fileURLToPath(import.meta.url)),e=E__default.join(i,"..","package.json");return JSON.parse(readFileSync(e,"utf-8")).version})(),wn=(()=>{let i=process.argv[1];return i&&E__default.basename(i).replace(/\.(c|m)?js$/i,"")==="const"?"const":"constellation"})(),_p=new Set(["print-grammar-versions"]),Pp=_p.has(process.argv[2]);if(M.mode!=="quiet"&&!Pp){let i=process.argv[2];["auth","help","init","index"].includes(i)?St(wn,i):St(wn),ht.includes(i)||await Sn(as)&&(he(),process.exit(0));}Cn=process.cwd(),xn=new dr,ze=new Command;ze.name(wn).description("Connecting stars in your code into intelligent patterns").version(as).option("--verbose","Print every step (no spinner). Useful for CI logs and debugging.").option("-q, --quiet","Suppress phase output. Print only warnings, errors, and a final summary.");ze.command("init").description("Initialize a new constellation project configuration").option("--skip-mcp","Skip MCP server configuration for AI coding tools").option("--skip-ci","Skip CI/CD pipeline configuration").action(async i=>{try{let t={GitClient:new gt(Cn,M),Reporter:M};await new pt(t).run({skipMcp:i.skipMcp,skipCi:i.skipCi});}catch(e){ie(e)||M.error(e instanceof Error?e.message:String(e)),he(),process.exit(1);}});ze.command("auth").description("Configure authentication for the Constellation CLI").option("--manual","Use manual access key entry instead of browser-based authentication").action(async i=>{try{let e={Environment:xn,Reporter:M};await new Ke(e).run(i.manual);}catch(e){ie(e)||M.error(e instanceof Error?e.message:String(e)),he(),process.exit(1);}});ze.command("index").description("Create or update the Constellation data indices for the current project").option("--full","Conduct a full project re-index").option("--incremental","Conduct an incremental project index update").option("--dirty","Skip git validation checks (branch and working tree status)").option("--no-enrich","Skip LSP enrichment (only perform parse tree indexing)").action(async i=>{try{let e=await lr.loadFromFile(E__default.join(Cn,"constellation.json")),t=new gt(Cn,M),n=new Wt(e),o=new mr(e),s={GitClient:t,Config:e,LanguageRegistry:n,LanguageDetector:o,Environment:xn,Reporter:M},a=xn.isCI(),l=i.full||!i.incremental&&a,c=i.dirty||!1,u=!0;!i.full&&!i.incremental&&a&&M.info("CI environment detected \u2014 defaulting to full index. Use --incremental to override."),await new at(s).run(l,c,u);}catch(e){ie(e)||M.error(e instanceof Error?e.message:String(e)),he(),process.exit(1);}});ze.command("print-grammar-versions",{hidden:true}).description("Emit installed tree-sitter grammar versions as JSON").action(()=>{try{process.stdout.write(JSON.stringify(os())+`
134
- `);}catch(i){ie(i)||M.error(i instanceof Error?i.message:String(i)),he(),process.exit(1);}});ze.parse();});var ds=/^>=\s*\d+\.\d+\.\d+$/;function Pn(i,e=process.version){if(!ds.test(i))return {compatible:true,current:e,required:i};let t=i.replace(/^>=\s*/,""),n=e.replace(/^v/,""),o=t.split(".").map(Number),s=n.split(".").map(Number),a=true;for(let l=0;l<3;l++){let c=o[l]||0,u=s[l]||0;if(u>c)break;if(u<c){a=false;break}}return {compatible:a,current:e,required:i}}yr();var Lp=dirname(fileURLToPath(import.meta.url)),Ap=join(Lp,"..","package.json"),En=JSON.parse(readFileSync(Ap,"utf-8")),kp=process.argv[2];if(!ht.includes(kp)&&En.engines?.node){let i=Pn(En.engines.node);i.compatible||(console.error(`Error: Constellation CLI requires Node.js ${i.required} (current: ${i.current})`),console.error(" Please upgrade to the latest LTS version: https://nodejs.org"),process.exit(1));}globalThis.__constellationVersion=En.version;await ls().then(()=>Ip);
132
+ ${A} Update failed. You can try updating manually:`),console.log(` ${this.packageManager.getUpdateCommandString(br)}
133
+ `),false)}};});var fs=f(()=>{_n();Pn();In();gs();});var bt,hs=f(()=>{M();bt=class{constructor(e,t){this.reporter=t;let r={baseDir:e,maxConcurrentProcesses:6};this.git=simpleGit(r);}git;async getLatestCommitHash(){let e=await this.git.log({maxCount:1});if(!e.latest)throw new Error("No commits found in repository");return e.latest.hash}async getCommitTimestamp(){let t=(await this.git.raw(["log","-1","--format=%aI"])).trim();if(!t)throw new Error("No commits found in repository");let r=new Date(t);if(Number.isNaN(r.getTime()))throw new Error(`Could not parse commit timestamp: ${t}`);return r.toISOString()}async getChangedFiles(e){let t=await this.git.diff(["--name-status",e,"HEAD"]),r={added:[],modified:[],deleted:[],renamed:[]},o=t.split(/\r?\n/).map(s=>s.trim()).filter(Boolean);for(let s of o){let a=s.split(" ");if(a.length<2)continue;let l=a[0];l==="A"?r.added.push(a[1]):l==="M"?r.modified.push(a[1]):l==="D"?r.deleted.push(a[1]):l.startsWith("R")&&a.length>=3&&r.renamed.push({from:a[1],to:a[2]});}return r}async getRemoteOriginUrl(){let t=(await this.git.getRemotes(true)).find(r=>r.name==="origin");if(!t||!t.refs.fetch)throw new Error("Remote origin URL not found or has no fetch URL");return t.refs.fetch}async getRootDir(){try{return (await this.git.revparse(["--show-toplevel"])).trim()}catch{return null}}async isGitAvailable(){try{return await this.git.version(),!0}catch{return false}}async isGitRepository(){try{return await this.git.checkIsRepo()}catch{return false}}async listBranches(){return (await this.git.branchLocal()).all}async stageFile(e){await this.git.add(e);}async status(){let e=await this.git.status(),t=e.files?.length===0,r=e.current;return {clean:t,currentBranch:r}}async pull(){try{let e=await this.git.status();if(!e.isClean()){let o={modified:e.modified.length,created:e.created.length,deleted:e.deleted.length,conflicted:e.conflicted.length,staged:e.staged.length};throw this.reporter?.error("Cannot pull: Working directory has uncommitted changes"),this.reporter?.detail(`Details: ${JSON.stringify(o,null,2)}`),e.conflicted.length>0&&this.reporter?.warn(`Conflicted files: ${e.conflicted.join(", ")}`),new Error(`Cannot pull with uncommitted changes. Please commit or stash your changes first.
134
+ Modified: ${o.modified}, Created: ${o.created}, Deleted: ${o.deleted}, Conflicted: ${o.conflicted}, Staged: ${o.staged}`)}let t=await this.git.pull();if(t.summary.changes===0&&t.summary.insertions===0&&t.summary.deletions===0){let o=await this.git.status();if(o.conflicted.length>0)throw this.reporter?.error("Pull failed: Merge conflicts detected"),this.reporter?.detail(`Conflicted files: ${o.conflicted.join(", ")}`),this.reporter?.detail("Please resolve conflicts manually and commit the result"),new Error(`Pull resulted in merge conflicts in ${o.conflicted.length} file(s): ${o.conflicted.join(", ")}`)}t.summary.changes>0&&this.reporter?.log(`${w} Pull successful: ${t.summary.changes} files changed, ${t.summary.insertions} insertions(+), ${t.summary.deletions} deletions(-)`);let r=await this.git.status();if(r.conflicted.length>0)throw this.reporter?.error("Unexpected conflicts after pull:"),this.reporter?.detail(`Conflicted files: ${r.conflicted.join(", ")}`),new Error(`Unexpected merge conflicts detected after pull: ${r.conflicted.join(", ")}`);return !0}catch(e){throw e instanceof Error?(e.message.includes("CONFLICT")?(this.reporter?.error("Pull failed due to merge conflicts"),this.reporter?.detail('Run "git status" to see conflicted files'),this.reporter?.detail('Resolve conflicts, then run "git add" and "git commit"')):e.message.includes("not a git repository")?this.reporter?.error("Pull failed: Not in a git repository"):e.message.includes("Could not resolve host")||e.message.includes("unable to access")?this.reporter?.error("Pull failed: Network error - unable to reach remote repository"):e.message.includes("Authentication failed")?this.reporter?.error("Pull failed: Authentication error - check your credentials"):e.message.includes("uncommitted changes")&&this.reporter?.error("Pull failed: Uncommitted changes in working directory"),new Error(`Git pull operation failed: ${e.message}`,{cause:e})):new Error(`Git pull operation failed: ${String(e)}`)}}};});var bs,ys=f(()=>{bs={"tree-sitter":"0.21.1","tree-sitter-typescript":"0.21.2","tree-sitter-javascript":"0.21.4","tree-sitter-python":"0.21.0"};});function vs(){let i={};for(let e of Dp){let t=bs[e];if(typeof t!="string"||t.length===0)throw new Error(`grammar-versions.json missing entry for ${e}`);i[e]=t;}return i}var Dp,Ss=f(()=>{ys();Dp=["tree-sitter","tree-sitter-typescript","tree-sitter-javascript","tree-sitter-python"];});var Hp={};var U,Se,ws,Rn,Gp,Bp,Tn,Ln,Je,Cs=f(async()=>{zn();Vo();ls();cs();ps();us();Jt();ms();Zr();fs();wr();Et();hs();Ss();U=new rr({mode:ds(process.argv)}),Se=()=>{try{U.stop();}catch{}};process.on("exit",Se);process.on("uncaughtException",i=>{i instanceof Error&&i.code==="ERR_USE_AFTER_CLOSE"&&(Se(),process.exit(0)),pe(i)||U.error(i?.message??String(i)),Se(),process.exit(1);});ws=globalThis.__constellationVersion??(()=>{let i=E__default.dirname(fileURLToPath(import.meta.url)),e=E__default.join(i,"..","package.json");return JSON.parse(readFileSync(e,"utf-8")).version})(),Rn=(()=>{let i=process.argv[1];return i&&E__default.basename(i).replace(/\.(c|m)?js$/i,"")==="const"?"const":"constellation"})(),Gp=new Set(["print-grammar-versions"]),Bp=Gp.has(process.argv[2]);if(U.mode!=="quiet"&&!Bp){let i=process.argv[2];["auth","help","init","index"].includes(i)?xt(Rn,i):xt(Rn),vt.includes(i)||await Nn(ws)&&(Se(),process.exit(0));}Tn=process.cwd(),Ln=new hr,Je=new Command;Je.name(Rn).description("Connecting stars in your code into intelligent patterns").version(ws).option("--verbose","Print every step (no spinner). Useful for CI logs and debugging.").option("-q, --quiet","Suppress phase output. Print only warnings, errors, and a final summary.");Je.command("init").description("Initialize a new constellation project configuration").option("--skip-mcp","Skip MCP server configuration for AI coding tools").option("--skip-ci","Skip CI/CD pipeline configuration").action(async i=>{try{let t={GitClient:new bt(Tn,U),Reporter:U};await new gt(t).run({skipMcp:i.skipMcp,skipCi:i.skipCi});}catch(e){pe(e)||U.error(e instanceof Error?e.message:String(e)),Se(),process.exit(1);}});Je.command("auth").description("Configure authentication for the Constellation CLI").option("--manual","Use manual access key entry instead of browser-based authentication").action(async i=>{try{let e={Environment:Ln,Reporter:U};await new Ye(e).run(i.manual);}catch(e){pe(e)||U.error(e instanceof Error?e.message:String(e)),Se(),process.exit(1);}});Je.command("index").description("Create or update the Constellation data indices for the current project").option("--full","Conduct a full project re-index").option("--incremental","Conduct an incremental project index update").option("--dirty","Skip git validation checks (branch and working tree status)").option("--no-enrich","Skip LSP enrichment (only perform parse tree indexing)").action(async i=>{try{let e=await dr.loadFromFile(E__default.join(Tn,"constellation.json")),t=new bt(Tn,U),r=new Vt(e),o=new yr(e),s={GitClient:t,Config:e,LanguageRegistry:r,LanguageDetector:o,Environment:Ln,Reporter:U},a=Ln.isCI(),l=i.full||!i.incremental&&a,c=i.dirty||!1,u=!0;!i.full&&!i.incremental&&a&&U.info("CI environment detected \u2014 defaulting to full index. Use --incremental to override."),await new ut(s).run(l,c,u);}catch(e){pe(e)||U.error(e instanceof Error?e.message:String(e)),Se(),process.exit(1);}});Je.command("print-grammar-versions",{hidden:true}).description("Emit installed tree-sitter grammar versions as JSON").action(()=>{try{process.stdout.write(JSON.stringify(vs())+`
135
+ `);}catch(i){pe(i)||U.error(i instanceof Error?i.message:String(i)),Se(),process.exit(1);}});Je.parse();});var Es=/^>=\s*\d+\.\d+\.\d+$/;function Fn(i,e=process.version){if(!Es.test(i))return {compatible:true,current:e,required:i};let t=i.replace(/^>=\s*/,""),r=e.replace(/^v/,""),o=t.split(".").map(Number),s=r.split(".").map(Number),a=true;for(let l=0;l<3;l++){let c=o[l]||0,u=s[l]||0;if(u>c)break;if(u<c){a=false;break}}return {compatible:a,current:e,required:i}}wr();var Jp=dirname(fileURLToPath(import.meta.url)),qp=join(Jp,"..","package.json"),jn=JSON.parse(readFileSync(qp,"utf-8")),Yp=process.argv[2];if(!vt.includes(Yp)&&jn.engines?.node){let i=Fn(jn.engines.node);i.compatible||(console.error(`Error: Constellation CLI requires Node.js ${i.required} (current: ${i.current})`),console.error(" Please upgrade to the latest LTS version: https://nodejs.org"),process.exit(1));}globalThis.__constellationVersion=jn.version;await Cs().then(()=>Hp);