@constellationdev/cli 1.2.0 → 1.3.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 (3) hide show
  1. package/README.md +3 -1
  2. package/dist/main.js +68 -67
  3. package/package.json +3 -2
package/dist/main.js CHANGED
@@ -1,18 +1,18 @@
1
1
  #!/usr/bin/env node
2
- import {bold,blue,gray,green,red,dim,yellow,blueBright,cyan}from'yoctocolors';import*as $e from'os';import $e__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 as z$1}from'zod';import {Readable,Transform}from'stream';import {base32}from'@scure/base';import*as Le from'fs';import {readFileSync,existsSync,realpathSync}from'fs';import {buffer}from'stream/consumers';import {pipeline}from'stream/promises';import*as _n from'zlib';import _n__default from'zlib';import {Agent,fetch as fetch$1}from'undici';import*as R from'path';import R__default,{dirname,join}from'path';import {fileURLToPath,pathToFileURL}from'url';import*as Q from'fs/promises';import Q__default from'fs/promises';import {findAll,find,parse}from'tsconfck';import Wc from'tree-sitter-go';import Hc from'tree-sitter-javascript';import zc from'tree-sitter-python';import Kc from'tree-sitter-typescript';import Op from'tree-sitter';import Fo from'ignore';import {performance}from'perf_hooks';import Kp from'yocto-spinner';import {parseDocument,isMap,isSeq,stringify}from'yaml';import {simpleGit}from'simple-git';import {Command}from'commander';var ca=Object.defineProperty;var g=(i,e)=>()=>(i&&(e=i(i=0)),e);var li=(i,e)=>{for(var t in e)ca(i,t,{get:e[t],enumerable:true});};var Dt,Vr=g(()=>{Dt=["help","--help","-h","--version","-V","-v"];});function ui(){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 di(){let i=process.env;if(i.NO_COLOR)return false;if(i.FORCE_COLOR==="3")return true;let e=i.COLORTERM?.toLowerCase();if(e==="truecolor"||e==="24bit"||i.WT_SESSION)return true;let t=i.TERM?.toLowerCase()??"";return !!(t.includes("truecolor")||t.includes("24bit")||t==="xterm-kitty"||t==="alacritty"||t==="wezterm")}function pi(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 ae(i,e=0,t=false){if(ui()&&!di())return blueBright(i);let r=[],o=0;for(let u of i.matchAll(ga))u.index>o&&r.push({ansi:false,value:i.slice(o,u.index)}),r.push({ansi:true,value:u[0]}),o=u.index+u[0].length;o<i.length&&r.push({ansi:false,value:i.slice(o)});let a=[...r.filter(u=>!u.ansi).map(u=>u.value).join("")],l=dt.length,c=a.length,p=0;return r.map(u=>u.ansi?u.value:[...u.value].map(d=>{let m=p++;if(d===" ")return d;let f,h,S;if(t){let v=(m+e)%l/l*(l-1),y=Math.floor(v),C=Math.min(y+1,l-1),P=v-y;[f,h,S]=pi(dt[y],dt[C],P);}else {let v=(c>1?m/(c-1):0)*(l-1),y=Math.floor(v),C=Math.min(y+1,l-1),P=v-y;[f,h,S]=pi(dt[y],dt[C],P);}return ma(f,h,S,d)}).join("")).join("")}var X,dt,ma,ga,Be=g(()=>{X={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)},dt=[[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]];ma=(i,e,t,r)=>!ui()||!di()?r:`\x1B[38;2;${i};${e};${t}m${r}\x1B[0m`;ga=/\x1b\[[0-9;]*m/g;});function fa(){return process.env.CONSTELLATION_ASCII_MODE==="1"?false:process.env.CI?true:$e.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 ha,ya,va,ba,Sa,wa,xa,Ca,Ea,_a,Pa,Ia,We,E,le,M,de,Se,Yr,z=g(()=>{Be();ha="\u2714",ya="\u2717",va="\u26A0",ba="\u2139",Sa="\u26A1",wa="\u29D7",xa="[OK]",Ca="[ERR]",Ea="[WARN]",_a="[INFO]",Pa="[>>]",Ia="[WAIT]",We=fa(),E=X.success(We?ha:xa),le=X.error(We?ya:Ca),M=X.warn(We?va:Ea),de=X.info(We?ba:_a),Se=X.warn(We?Sa:Pa),Yr=X.info(We?wa:Ia);});var U,Ut=g(()=>{Be();z();U={prefix:{idle:blue("\u25C6"),done:E},style:{highlight:i=>blue(i),answer:i=>green(i),error:i=>red(`${le} ${i}`),help:i=>gray(i)},icon:{checked:green("\u25FC"),unchecked:gray("\u25FB"),cursor:blue("\u276F")}};});async function gi(i){if(!i.startsWith("http://")&&!i.startsWith("https://"))return false;try{switch(process.platform){case "darwin":return await Xr("open",[i]),!0;case "linux":return await Xr("xdg-open",[i]),!0;case "win32":return await Xr("cmd",["/c","start","",i]),!0;default:return !1}}catch{return false}}var Xr,fi=g(()=>{Xr=promisify(execFile);});function ja(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 hi(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,p=3e5){return new Promise((u,d)=>{s=setTimeout(()=>{s=void 0,a=true,o.close(),o.closeAllConnections(),d(new Error("Authentication timed out"));},p),o.on("request",(m,f)=>{let h=new URL(m.url??"/",`http://127.0.0.1:${l.port}`);if(h.pathname!=="/callback"){f.writeHead(404,{"Content-Type":"text/plain"}),f.end("Not found");return}let S=h.searchParams.get("key");if(h.searchParams.get("state")!==c){f.writeHead(400,{"Content-Type":"text/plain"}),f.end("Invalid state parameter");return}if(!S||!La.test(S)){f.writeHead(400,{"Content-Type":"text/plain"}),f.end("Invalid key format");return}if(a)return;a=true;let y=h.searchParams.get("return_url");y&&ja(y,e)?(f.writeHead(302,{Location:y}),f.end()):(f.writeHead(200,{"Content-Type":"text/html; charset=utf-8"}),f.end(ka)),s&&(clearTimeout(s),s=void 0),o.close(),o.closeAllConnections(),u(S);});})}});}),o.on("error",l=>{r(l);});})}var La,ka,yi=g(()=>{La=/^ak:[0-9a-f]{32}$/i,ka=`<!DOCTYPE html>
2
+ import {bold,blue,gray,green,red,dim,yellow,blueBright,cyan}from'yoctocolors';import*as He from'os';import He__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 as z$1}from'zod';import {Readable,Transform}from'stream';import {base32}from'@scure/base';import*as De from'fs';import {readFileSync,existsSync,realpathSync}from'fs';import {buffer}from'stream/consumers';import {pipeline}from'stream/promises';import*as Gn from'zlib';import Gn__default from'zlib';import {Agent,fetch as fetch$1}from'undici';import*as k from'path';import k__default,{dirname,join}from'path';import {fileURLToPath,pathToFileURL}from'url';import*as se from'fs/promises';import se__default from'fs/promises';import {findAll,find,parse}from'tsconfck';import Mp from'tree-sitter-c-sharp';import Up from'tree-sitter-go';import Gp from'tree-sitter-javascript';import Bp from'tree-sitter-python';import Hp from'tree-sitter-typescript';import Ku from'tree-sitter';import hs from'ignore';import {performance}from'perf_hooks';import ed from'yocto-spinner';import {parseDocument,isMap,isSeq,stringify}from'yaml';import {simpleGit}from'simple-git';import {Command}from'commander';var Ka=Object.defineProperty;var f=(n,e)=>()=>(n&&(e=n(n=0)),e);var Ii=(n,e)=>{for(var t in e)Ka(n,t,{get:e[t],enumerable:true});};var Vt,nn=f(()=>{Vt=["help","--help","-h","--version","-V","-v"];});function Ti(){let n=process.env;return n.FORCE_COLOR&&n.FORCE_COLOR!=="0"&&n.FORCE_COLOR!=="false"?true:n.NO_COLOR?false:!!process.stdout.isTTY}function Li(){let n=process.env;if(n.NO_COLOR)return false;if(n.FORCE_COLOR==="3")return true;let e=n.COLORTERM?.toLowerCase();if(e==="truecolor"||e==="24bit"||n.WT_SESSION)return true;let t=n.TERM?.toLowerCase()??"";return !!(t.includes("truecolor")||t.includes("24bit")||t==="xterm-kitty"||t==="alacritty"||t==="wezterm")}function Ni(n,e,t){return [Math.round(n[0]+(e[0]-n[0])*t),Math.round(n[1]+(e[1]-n[1])*t),Math.round(n[2]+(e[2]-n[2])*t)]}function fe(n,e=0,t=false){if(Ti()&&!Li())return blueBright(n);let r=[],o=0;for(let p of n.matchAll(Xa))p.index>o&&r.push({ansi:false,value:n.slice(o,p.index)}),r.push({ansi:true,value:p[0]}),o=p.index+p[0].length;o<n.length&&r.push({ansi:false,value:n.slice(o)});let a=[...r.filter(p=>!p.ansi).map(p=>p.value).join("")],l=xt.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 g,h,b;if(t){let y=(m+e)%l/l*(l-1),S=Math.floor(y),E=Math.min(S+1,l-1),T=y-S;[g,h,b]=Ni(xt[S],xt[E],T);}else {let y=(c>1?m/(c-1):0)*(l-1),S=Math.floor(y),E=Math.min(S+1,l-1),T=y-S;[g,h,b]=Ni(xt[S],xt[E],T);}return Ya(g,h,b,d)}).join("")).join("")}var ie,xt,Ya,Xa,qe=f(()=>{ie={info:n=>blue(n),success:n=>green(n),warn:n=>yellow(n),error:n=>red(n),accent:n=>bold(blue(n)),muted:n=>gray(n),dim:n=>dim(n)},xt=[[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]];Ya=(n,e,t,r)=>!Ti()||!Li()?r:`\x1B[38;2;${n};${e};${t}m${r}\x1B[0m`;Xa=/\x1b\[[0-9;]*m/g;});function Qa(){return process.env.CONSTELLATION_ASCII_MODE==="1"?false:process.env.CI?true:He.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 Za,el,tl,rl,nl,il,ol,sl,al,ll,cl,pl,Ye,x,ge,z,ve,Ee,Yt,q=f(()=>{qe();Za="\u2714",el="\u2717",tl="\u26A0",rl="\u2139",nl="\u26A1",il="\u29D7",ol="[OK]",sl="[ERR]",al="[WARN]",ll="[INFO]",cl="[>>]",pl="[WAIT]",Ye=Qa(),x=ie.success(Ye?Za:ol),ge=ie.error(Ye?el:sl),z=ie.warn(Ye?tl:al),ve=ie.info(Ye?rl:ll),Ee=ie.warn(Ye?nl:cl),Yt=ie.info(Ye?il:pl);});var B,Xt=f(()=>{qe();q();B={prefix:{idle:blue("\u25C6"),done:x},style:{highlight:n=>blue(n),answer:n=>green(n),error:n=>red(`${ge} ${n}`),help:n=>gray(n)},icon:{checked:green("\u25FC"),unchecked:gray("\u25FB"),cursor:blue("\u276F")}};});async function ji(n){if(!n.startsWith("http://")&&!n.startsWith("https://"))return false;try{switch(process.platform){case "darwin":return await an("open",[n]),!0;case "linux":return await an("xdg-open",[n]),!0;case "win32":return await an("cmd",["/c","start","",n]),!0;default:return !1}}catch{return false}}var an,Ai=f(()=>{an=promisify(execFile);});function hl(n,e){if(!e)return false;let t,r;try{t=new URL(e),r=new URL(n);}catch{return false}return r.protocol!=="http:"&&r.protocol!=="https:"?false:r.origin===t.origin}function Fi(n={}){let e=n.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,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||!fl.test(b)){g.writeHead(400,{"Content-Type":"text/plain"}),g.end("Invalid key format");return}if(a)return;a=true;let S=h.searchParams.get("return_url");S&&hl(S,e)?(g.writeHead(302,{Location:S}),g.end()):(g.writeHead(200,{"Content-Type":"text/html; charset=utf-8"}),g.end(gl)),s&&(clearTimeout(s),s=void 0),o.close(),o.closeAllConnections(),p(b);});})}});}),o.on("error",l=>{r(l);});})}var fl,gl,$i=f(()=>{fl=/^ak:[0-9a-f]{32}$/i,gl=`<!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 Qr(i){process.stdout.write(i+`
5
- `);}function Gt(i,e){let t=`${i} \u203A ${e}`;Qr(`${ae("\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
- ${ae("\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
- ${ae("\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
- ${ae("\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
- ${ae("\u2502 CONSTELLATIONDEV.IO \u2502")}`),e&&e.length>0?Qr(`${ae(`\u251C\u2500${"\u2500".repeat(t.length)}\u2500\u252C\u2500${"\u2500".repeat(78-t.length)}\u256F`)}
10
- ${ae(`\u2502 ${bold(t)} \u2502${" ".repeat(80-t.length)}`)}
11
- ${ae(`\u2570\u2500${"\u2500".repeat(t.length)}\u2500\u256F${" ".repeat(80-t.length)}`)}
12
- `):Qr(ae("\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 vi=g(()=>{Be();});var we,bi,Bt=g(()=>{vi();we="CONSTELLATION_ACCESS_KEY",bi="CONSTELLATION_WEB_URL";});var xe,Wt=g(()=>{xe=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 Oa(i){return Da.test(i)}function Ma(i){return i.replace(/ak:[0-9a-f]{32}/gi,"[REDACTED]")}var Da,mt,wi=g(()=>{Ut();fi();yi();Bt();z();Wt();Da=/^ak:[0-9a-f]{32}$/i;mt=class extends xe{async run(e){try{if(!this.env)throw new Error("Environment manager not initialized");if(this.reporter.log(`${Se} Configuring access key authentication...
4
+ <body><h1>Authentication successful! You can close this tab.</h1></body></html>`;});function ln(n){process.stdout.write(n+`
5
+ `);}function Qt(n,e){let t=`${n} \u203A ${e}`;ln(`${fe("\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
+ ${fe("\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
+ ${fe("\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
+ ${fe("\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
+ ${fe("\u2502 CONSTELLATIONDEV.IO \u2502")}`),e&&e.length>0?ln(`${fe(`\u251C\u2500${"\u2500".repeat(t.length)}\u2500\u252C\u2500${"\u2500".repeat(78-t.length)}\u256F`)}
10
+ ${fe(`\u2502 ${bold(t)} \u2502${" ".repeat(80-t.length)}`)}
11
+ ${fe(`\u2570\u2500${"\u2500".repeat(t.length)}\u2500\u256F${" ".repeat(80-t.length)}`)}
12
+ `):ln(fe("\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 Di=f(()=>{qe();});var Pe,Oi,Zt=f(()=>{Di();Pe="CONSTELLATION_ACCESS_KEY",Oi="CONSTELLATION_WEB_URL";});var Ie,er=f(()=>{Ie=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 wl(n){return Sl.test(n)}function _l(n){return n.replace(/ak:[0-9a-f]{32}/gi,"[REDACTED]")}var Sl,Ct,Ui=f(()=>{Xt();Ai();$i();Zt();q();er();Sl=/^ak:[0-9a-f]{32}$/i;Ct=class extends Ie{async run(e){try{if(!this.env)throw new Error("Environment manager not initialized");if(this.reporter.log(`${Ee} Configuring access key authentication...
13
13
  `),this.env.isCI()){this.reporter.error(`Cannot configure authentication in CI/CD environments
14
14
 
15
- The ${we} environment variable must be configured
15
+ The ${Pe} 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,48 +20,49 @@ ${ae(`\u2570\u2500${"\u2500".repeat(t.length)}\u2500\u256F${" ".repeat(80-t.leng
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(we)&&!await confirm({message:"Replace existing Constellation access key?",default:!1,theme:U})){this.reporter.log(`${E} 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=Ma(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:U})).trim(),!e){this.reporter.warn("Access key cannot be empty."),t++;continue}if(!Oa(e)){if(t++,t<r)this.reporter.warn(`Invalid access key format. Expected format: ak:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
23
+ `);return}if(await this.env.getKey(Pe)&&!await confirm({message:"Replace existing Constellation access key?",default:!1,theme:B})){this.reporter.log(`${x} 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=_l(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:B})).trim(),!e){this.reporter.warn("Access key cannot be empty."),t++;continue}if(!wl(e)){if(t++,t<r)this.reporter.warn(`Invalid access key format. Expected format: ak:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
25
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[bi]||"https://app.constellationdev.io",{port:r,waitForCallback:o}=await hi({allowedOrigin:t}),s=`${t}/auth/cli?callback_port=${r}&state=${e}`;this.reporter.info("Opening browser for authentication..."),await gi(s)||this.reporter.warn(`Could not open browser automatically.
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[Oi]||"https://app.constellationdev.io",{port:r,waitForCallback:o}=await Fi({allowedOrigin:t}),s=`${t}/auth/cli?callback_port=${r}&state=${e}`;this.reporter.info("Opening browser for authentication..."),await ji(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(we,e),this.reporter.log(`${E} Stored access key in ${we} 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(Pe,e),this.reporter.log(`${x} Stored access key in ${Pe} 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.`),$e.platform()==="darwin"&&this.reporter.info("Already-running desktop apps (Claude Desktop, Codex, etc.) must be quit and relaunched to see the new value.");}};});var Ua,me,gt,Ga,He,ft,Ba,Wa,Ha,ht,za,Ka,Va,Ja,qa,Ya,Xa,Qa,Za,el,tl,rl,nl,il,ol,sl,al,ll,cl,xi,pl,ul,dl,ml,gl,fl,hl,yl,vl,bl,Sl,wl,xl,Cl,El,_l,Ei,Pl,Il,en,Rl,Nl,Tl,Ll,yt,kl,jl,Al,Fl,$l,_i,Dl,Ol,Ht,Zr,Ci,Ml,Ul,Gl,tn,Pi,Bl,Wl,Hl,zl,rn,Kl,Vl,Jl,ql,Yl,Xl,Ii,Ri,Ni,Ti,Ql,Zl,ec,Li,ki,tc,rc,nc,ic,vt=g(()=>{Ua=z$1.object({total:z$1.number().int().nonnegative(),returned:z$1.number().int().nonnegative(),hasMore:z$1.boolean(),nextOffset:z$1.number().int().nonnegative().optional(),currentOffset:z$1.number().int().nonnegative().optional()}),z$1.object({overall:z$1.number().min(0).max(1),factors:z$1.object({dataFreshness:z$1.number().min(0).max(1).optional(),coverageComplete:z$1.number().min(0).max(1).optional(),heuristicAccuracy:z$1.number().min(0).max(1).optional(),semanticAnalysisDepth:z$1.number().min(0).max(1).optional(),patternMatchQuality:z$1.number().min(0).max(1).optional()}).optional(),warnings:z$1.array(z$1.string()).optional(),recommendations:z$1.array(z$1.string()).optional()}),z$1.object({qualityScore:z$1.number().min(0).max(100).optional(),lastUpdated:z$1.string().optional(),cached:z$1.boolean().optional(),executionTime:z$1.number().nonnegative().optional(),coveragePercentage:z$1.number().min(0).max(100).optional(),issues:z$1.array(z$1.string()).optional()}),me=z$1.object({language:z$1.string(),features:z$1.array(z$1.string()).optional(),visibility:z$1.string().optional(),decorators:z$1.array(z$1.string()).optional(),typeInfo:z$1.any().optional(),custom:z$1.record(z$1.string(),z$1.any()).optional()}),z$1.enum(["function","class","interface","type","variable","constant","enum","module","namespace","method","property","parameter","constructor","decorator","trait","struct","macro","unknown"]),gt=z$1.enum(["low","medium","high","critical"]),Ga=z$1.enum(["low","moderate","high","very_high"]),He=z$1.object({cyclomaticComplexity:z$1.number().int().nonnegative(),complexityRisk:Ga}),ft=z$1.object({filePath:z$1.string(),line:z$1.number().int().positive().optional(),lineStart:z$1.number().int().positive().optional(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative().optional()}),ft.extend({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),symbolKind:z$1.string().optional()}),z$1.object({outgoing:z$1.array(z$1.string()),incoming:z$1.array(z$1.string())}),Ba=z$1.object({id:z$1.string(),name:z$1.string(),type:z$1.string(),properties:z$1.record(z$1.string(),z$1.any()).optional()}),Wa=z$1.object({from:z$1.string(),to:z$1.string(),type:z$1.string().optional(),weight:z$1.number().optional(),properties:z$1.record(z$1.string(),z$1.any()).optional()}),Ha=z$1.object({nodes:z$1.array(Ba),edges:z$1.array(Wa),metadata:z$1.object({nodeCount:z$1.number().int().nonnegative(),edgeCount:z$1.number().int().nonnegative(),directed:z$1.boolean(),hasCycles:z$1.boolean().optional()}).optional()}),ht=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$1.object({success:z$1.literal(false),error:z$1.object({code:z$1.string(),message:z$1.string(),details:z$1.any().optional()})}),z$1.object({query:z$1.string().max(200),filterByKind:z$1.array(z$1.string()).optional(),filterByVisibility:z$1.array(z$1.string()).optional(),isExported:z$1.boolean().optional(),filterByFile:z$1.string().optional(),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0),includeUsageCount:z$1.boolean().optional(),includeDocumentation:z$1.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"]}),za=ft.extend({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),signature:z$1.string().optional(),documentation:z$1.string().optional(),visibility:z$1.string().optional(),isExported:z$1.boolean(),usageCount:z$1.number().int().nonnegative().optional(),complexity:He.optional(),languageMetadata:me.optional()}),z$1.object({symbols:z$1.array(za),pagination:Ua.optional()}),z$1.object({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),includeReferences:z$1.boolean().optional(),includeRelationships:z$1.boolean().optional(),includeImpactScore:z$1.boolean().optional()}),Ka=ft.extend({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),signature:z$1.string().optional(),documentation:z$1.string().optional(),visibility:z$1.string().optional(),modifiers:z$1.array(z$1.string()).optional(),typeInfo:z$1.any().optional(),decorators:z$1.array(z$1.string()).optional(),isExported:z$1.boolean(),isDeprecated:z$1.boolean(),complexity:He.optional(),languageMetadata:me.optional()}),Va=ft.extend({usageType:z$1.string(),context:z$1.string().optional(),aliasName:z$1.string().optional()}),Ja=z$1.object({calls:z$1.array(z$1.string()),calledBy:z$1.array(z$1.string()),inheritsFrom:z$1.array(z$1.string()),inheritedBy:z$1.array(z$1.string()),children:z$1.array(z$1.string())}),qa=z$1.object({directUsage:z$1.number().int().nonnegative(),transitiveImpact:z$1.number().int().nonnegative(),riskScore:z$1.number().min(0).max(100),riskLevel:gt}),z$1.object({symbol:Ka,references:z$1.array(Va).optional(),relationships:Ja.optional(),impactScore:qa.optional()}),z$1.object({filePath:z$1.string().min(1),depth:z$1.number().int().nonnegative().max(10).optional(),includePackages:z$1.boolean().optional(),includeSymbols:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(20),offset:z$1.number().int().nonnegative().default(0)}),Ya=z$1.object({type:z$1.enum(["file","module"]),filePath:z$1.string().nullable(),moduleName:z$1.string().nullable().optional(),importedSymbols:z$1.array(z$1.string()).optional(),isDefault:z$1.boolean(),isNamespace:z$1.boolean()}),Xa=z$1.object({filePath:z$1.string(),distance:z$1.number().int().positive(),path:z$1.array(z$1.string())}),Qa=z$1.object({name:z$1.string(),version:z$1.string().optional(),type:z$1.string()}),z$1.object({totalFiles:z$1.number().int().nonnegative(),totalPackages:z$1.number().int().nonnegative(),maxDepth:z$1.number().int().nonnegative()}),z$1.object({file:z$1.string(),directDependencies:z$1.array(Ya),transitiveDependencies:z$1.array(Xa).optional(),packages:z$1.array(Qa).optional()}),z$1.object({filePath:z$1.string().min(1),depth:z$1.number().int().nonnegative().max(10).optional(),includeSymbols:z$1.boolean().optional(),includeImpactMetrics:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(20),offset:z$1.number().int().nonnegative().default(0)}),Za=z$1.object({filePath:z$1.string(),usedSymbols:z$1.array(z$1.string()).optional()}),el=z$1.object({filePath:z$1.string(),distance:z$1.number().int().positive(),path:z$1.array(z$1.string())}),z$1.object({totalFiles:z$1.number().int().nonnegative(),maxDepth:z$1.number().int().nonnegative(),riskLevel:gt}),z$1.object({file:z$1.string(),directDependents:z$1.array(Za),transitiveDependents:z$1.array(el).optional(),detailedMetrics:z$1.object({byDepth:z$1.record(z$1.string(),z$1.number()),criticalPaths:z$1.array(z$1.array(z$1.string())),mostImpactedFiles:z$1.array(z$1.string())}).optional()}),z$1.object({filePath:z$1.string().min(1).optional(),minCycleLength:z$1.number().int().min(2).max(10).optional(),maxCycleLength:z$1.number().int().min(2).max(10).optional(),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0),includeImpactScore:z$1.boolean().optional(),includeConfidence:z$1.boolean().optional()}),tl=z$1.object({files:z$1.array(z$1.string()),length:z$1.number().int().positive(),impactScore:z$1.number().min(0).max(100).optional(),severity:gt}),z$1.object({cycles:z$1.array(tl)}),z$1.object({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),filterByUsageType:z$1.array(z$1.string()).optional(),filterByRelationshipType:z$1.array(z$1.string()).optional(),includeTransitive:z$1.boolean().optional(),includeContext:z$1.boolean().optional(),excludeTests:z$1.boolean().optional(),excludeGenerated:z$1.boolean().optional(),includeImportanceWeight:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0)}),rl=z$1.object({name:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),lineEnd:z$1.number().int().positive().optional(),complexity:He.optional(),languageMetadata:me.optional()}),nl=z$1.object({filePath:z$1.string(),usageType:z$1.string(),relationshipType:z$1.string(),line:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative().optional(),enclosingSymbol:z$1.object({name:z$1.string(),kind:z$1.string()}).optional(),context:z$1.string().optional(),aliasName:z$1.string().optional(),isTest:z$1.boolean().optional(),isGenerated:z$1.boolean().optional(),importanceWeight:z$1.number().min(0).max(1).optional()}),il=z$1.object({filePath:z$1.string(),distance:z$1.number().int().positive(),chain:z$1.array(z$1.string())}),ol=z$1.object({limit:z$1.number().int().positive(),offset:z$1.number().int().nonnegative(),returned:z$1.number().int().nonnegative(),hasMore:z$1.boolean()}),sl=z$1.object({totalUsages:z$1.number().int().nonnegative(),usagesByType:z$1.record(z$1.string(),z$1.number().int().nonnegative()),filesAffected:z$1.number().int().nonnegative(),transitiveImpact:z$1.number().int().nonnegative(),pageInfo:ol}),z$1.object({symbol:rl,directUsages:z$1.array(nl),transitiveUsages:z$1.array(il).optional(),summary:sl}),z$1.object({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),direction:z$1.enum(["callers","callees","both"]).default("both"),depth:z$1.number().int().positive().max(10).default(3),excludeExternal:z$1.boolean().optional(),includeGraph:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(25),offset:z$1.number().int().nonnegative().default(0)}),al=z$1.object({symbolId:z$1.string(),name:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),complexity:He.optional(),languageMetadata:me.optional()}),ll=z$1.object({symbolId:z$1.string(),name:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),depth:z$1.number().int().nonnegative(),complexity:He.optional(),languageMetadata:me.optional()}),cl=z$1.object({symbolId:z$1.string(),name:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),isAsync:z$1.boolean(),depth:z$1.number().int().nonnegative(),complexity:He.optional(),languageMetadata:me.optional()}),z$1.object({root:al,callers:z$1.array(ll).optional(),callees:z$1.array(cl).optional(),graph:Ha.optional()}),z$1.object({symbolId:z$1.string().optional(),qualifiedName:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),includeDirectDependents:z$1.boolean().default(true),includeTransitiveDependents:z$1.boolean().default(true),depth:z$1.number().int().min(1).max(5).default(3),excludeTests:z$1.boolean().default(true),excludeGenerated:z$1.boolean().default(true),analyzeBreakingChanges:z$1.boolean().default(true)}),xi=ft.extend({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),relationshipType:z$1.string(),depth:z$1.number().int().positive(),isExported:z$1.boolean().optional(),transitiveImpactCount:z$1.number().int().nonnegative().optional(),languageMetadata:me.optional()}),pl=z$1.object({filePath:z$1.string(),symbolCount:z$1.number().int().positive(),isTest:z$1.boolean().optional(),isGenerated:z$1.boolean().optional(),symbols:z$1.array(z$1.object({id:z$1.string(),name:z$1.string(),kind:z$1.string(),line:z$1.number().int().positive()}))}),ul=z$1.object({riskLevel:gt,factors:z$1.array(z$1.object({factor:z$1.string(),severity:z$1.enum(["low","medium","high"]),description:z$1.string()})),recommendations:z$1.array(z$1.string())}),z$1.object({symbol:z$1.object({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),isExported:z$1.boolean().optional(),languageMetadata:me.optional()}),directDependents:z$1.array(xi).optional(),transitiveDependents:z$1.array(xi).optional(),impactedFiles:z$1.array(pl),breakingChangeRisk:ul.optional(),summary:z$1.object({directDependentCount:z$1.number().int().nonnegative(),transitiveDependentCount:z$1.number().int().nonnegative(),impactedFileCount:z$1.number().int().nonnegative(),testFileCount:z$1.number().int().nonnegative(),productionFileCount:z$1.number().int().nonnegative(),maxDepth:z$1.number().int().nonnegative()})}),z$1.object({filePattern:z$1.string().optional(),filterByKind:z$1.array(z$1.string()).optional(),exportedOnly:z$1.boolean().optional(),excludeTests:z$1.boolean().default(true),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0),includeConfidence:z$1.boolean().optional()}),dl=z$1.object({symbolId:z$1.string(),name:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),lineEnd:z$1.number().int().positive().optional(),isExported:z$1.boolean(),reason:z$1.string(),confidence:z$1.number().min(0).max(1),languageMetadata:me.optional()}),ml=z$1.object({filePath:z$1.string(),reason:z$1.string(),lastUpdated:z$1.string(),confidence:z$1.number().min(0).max(1)}),z$1.object({orphanedSymbols:z$1.array(dl),orphanedFiles:z$1.array(ml)}),z$1.object({includeMetrics:z$1.boolean().default(false),includeModuleGraph:z$1.boolean().default(false),includePackages:z$1.boolean().default(true)}),gl=z$1.object({language:z$1.string(),fileCount:z$1.number().int().nonnegative(),percentage:z$1.number().min(0).max(100)}),fl=z$1.object({name:z$1.string(),version:z$1.string().optional(),confidence:z$1.enum(["high","medium","low"]),evidence:z$1.array(z$1.string())}),hl=z$1.object({languages:z$1.array(gl),frameworks:z$1.array(fl),primaryLanguage:z$1.string(),totalFiles:z$1.number().int().nonnegative(),totalLines:z$1.number().int().nonnegative().optional()}),yl=z$1.object({files:z$1.object({total:z$1.number().int().nonnegative(),byType:z$1.record(z$1.string(),z$1.number()),byParadigm:z$1.record(z$1.string(),z$1.number())}),symbols:z$1.object({total:z$1.number().int().nonnegative(),byKind:z$1.record(z$1.string(),z$1.number()),exported:z$1.number().int().nonnegative(),public:z$1.number().int().nonnegative()}),modules:z$1.object({total:z$1.number().int().nonnegative(),averageSize:z$1.number().nonnegative(),largest:z$1.string()})}),vl=z$1.object({internal:z$1.object({totalConnections:z$1.number().int().nonnegative(),averagePerFile:z$1.number().nonnegative(),mostConnectedFiles:z$1.array(z$1.object({path:z$1.string(),incomingCount:z$1.number().int().nonnegative(),outgoingCount:z$1.number().int().nonnegative()}))}),external:z$1.object({totalPackages:z$1.number().int().nonnegative(),directDependencies:z$1.number().int().nonnegative(),topPackages:z$1.array(z$1.object({name:z$1.string(),usageCount:z$1.number().int().nonnegative()}))})}),bl=z$1.object({complexity:z$1.object({average:z$1.number().nonnegative(),high:z$1.number().int().nonnegative()}),maintainability:z$1.object({score:z$1.number().min(0).max(100),issues:z$1.array(z$1.string())}),testCoverage:z$1.object({percentage:z$1.number().min(0).max(100),testedFiles:z$1.number().int().nonnegative(),totalFiles:z$1.number().int().nonnegative()}).optional()}),Sl=z$1.object({id:z$1.string(),name:z$1.string(),fileCount:z$1.number().int().nonnegative(),type:z$1.string()}),wl=z$1.object({from:z$1.string(),to:z$1.string(),weight:z$1.number().int().nonnegative()}),xl=z$1.object({nodes:z$1.array(Sl),edges:z$1.array(wl)}),z$1.object({metadata:hl,structure:yl,dependencies:vl,metrics:bl.optional(),moduleGraph:xl.optional()}),z$1.object({}).strict(),z$1.object({pong:z$1.literal(true)}),Cl=z$1.enum(["relative","workspace","alias","external","builtin"]),El=z$1.object({source:z$1.string(),resolvedPath:z$1.string().optional(),isExternal:z$1.boolean(),importType:Cl}),_l=z$1.record(z$1.string(),El),Ei=z$1.enum(["call","read","write","type","instantiate","import-use","declaration"]),Pl=Ei.exclude(["import-use","declaration"]),Il=z$1.object({line:z$1.number().int().nonnegative(),column:z$1.number().int().nonnegative(),referenceType:Ei}).strict(),en=z$1.object({filePath:z$1.string().min(1),entries:z$1.array(Il).max(1e5)}).strict(),z$1.object({file:z$1.string().min(1),language:z$1.string().min(1),commit:z$1.string().min(1),timestamp:z$1.string().datetime(),ast:z$1.string().min(1),importResolutions:_l.optional(),classificationMap:en.optional()}).strict(),Rl=z$1.object({file:z$1.string(),error:z$1.string()}),Nl=z$1.object({file:z$1.string(),failedCount:z$1.number().int().nonnegative(),createdCount:z$1.number().int().nonnegative(),isTransient:z$1.boolean()}),Tl=z$1.object({totalCreated:z$1.number().int().nonnegative(),totalFailed:z$1.number().int().nonnegative(),filesWithFailures:z$1.array(Nl)}),z$1.object({processed:z$1.number().int().nonnegative(),failed:z$1.number().int().nonnegative(),projectId:z$1.string(),branchName:z$1.string(),failedFiles:z$1.array(Rl).optional(),relationships:Tl}),z$1.object({projectId:z$1.string(),projectName:z$1.string(),branch:z$1.string(),latestCommit:z$1.string().nullable(),fileCount:z$1.number().int().nonnegative(),lastIndexedAt:z$1.string().nullable(),languages:z$1.array(z$1.string())}),Ll=z$1.object({local:z$1.string(),original:z$1.string().optional(),isDefault:z$1.boolean(),isNamespace:z$1.boolean()}),z$1.object({source:z$1.string(),specifiers:z$1.array(Ll),isType:z$1.boolean(),isDynamic:z$1.boolean(),isConditional:z$1.boolean().optional(),isLazy:z$1.boolean().optional(),isWildcard:z$1.boolean().optional(),line:z$1.number(),column:z$1.number()}),z$1.object({referencerId:z$1.string(),referencedName:z$1.string(),referenceType:Pl,line:z$1.number(),column:z$1.number(),scope:z$1.string().optional(),objectContext:z$1.string().optional(),language:z$1.string().optional()}),z$1.enum(["processing","completed","failed","cancelled","queued","superseded","cleaned_up"]),z$1.enum(["acquired","current","duplicate","superseded","queued"]),yt={branchName:z$1.string().optional(),effectiveBranchName:z$1.string().optional(),remapped:z$1.boolean().optional()},kl=z$1.object({status:z$1.literal("acquired"),attemptId:z$1.string().uuid(),...yt}),jl=z$1.object({status:z$1.literal("current"),...yt}),Al=z$1.object({status:z$1.literal("duplicate"),...yt}),Fl=z$1.object({status:z$1.literal("superseded"),activeCommit:z$1.string().optional(),...yt}),$l=z$1.object({status:z$1.literal("queued"),queuedAttemptId:z$1.string().uuid(),...yt}),_i=z$1.discriminatedUnion("status",[kl,jl,Al,Fl,$l]),z$1.object({"x-attempt-id":z$1.string().uuid(),"x-project-id":z$1.string(),"x-branch-name":z$1.string(),"x-commit-hash":z$1.string().length(40),"x-constellation-dirty":z$1.union([z$1.literal("true"),z$1.literal("false")]).optional()}),Dl=z$1.enum(["pass1","pass2","pass2b","pass3"]),Ol=z$1.object({phase:Dl,durationMs:z$1.number().int().nonnegative(),fileCount:z$1.number().int().nonnegative(),symbolCount:z$1.number().int().nonnegative().optional(),relationshipCount:z$1.number().int().nonnegative().optional(),throughputPerSec:z$1.number().nonnegative(),deadlockRetryCount:z$1.number().int().nonnegative().optional()}),Ht=z$1.array(Ol),Zr=z$1.object({filePath:z$1.string().min(1),line:z$1.number().int().positive(),column:z$1.number().int().nonnegative()}).strict(),Ci=Zr.extend({name:z$1.string().min(1)}).strict(),Ml=z$1.object({resolvedType:z$1.string().min(1),returnType:z$1.string().optional(),documentation:z$1.string().max(16384).optional()}).strict(),Ul=z$1.object({name:z$1.string().min(1),line:z$1.number().int().positive(),column:z$1.number().int().nonnegative(),kind:z$1.string().min(1),typeInfo:Ml.optional(),references:z$1.object({count:z$1.number().int().nonnegative(),locations:z$1.array(Zr).max(100)}).optional(),callHierarchy:z$1.object({incomingCalls:z$1.array(Ci).max(200),outgoingCalls:z$1.array(Ci).max(200)}).optional(),implementations:z$1.array(Zr).max(200).optional()}).strict(),z$1.object({filePath:z$1.string().min(1),language:z$1.string().min(1),symbols:z$1.array(Ul).max(1e4)}).strict(),z$1.object({projectId:z$1.string().min(1),branch:z$1.string().min(1),commit:z$1.string().regex(/^[0-9a-f]{40}$/),timestamp:z$1.string().datetime()}).strict(),Gl=z$1.enum(["pending","processing","completed","failed","skipped"]),tn=z$1.object({status:Gl,filesProcessed:z$1.number().int().nonnegative().nullable(),completedAt:z$1.union([z$1.string().datetime({offset:true}),z$1.date()]).nullable()}),z$1.enum(["current","processing","stale","failed"]),Pi=z$1.union([z$1.string().datetime({offset:true}),z$1.date()]),Bl=z$1.object({status:z$1.literal("processing"),commitHash:z$1.string().nullable().optional(),startedAt:Pi.optional(),phaseMetrics:Ht.optional()}).passthrough(),Wl=z$1.object({status:z$1.literal("current"),commitHash:z$1.string().nullable().optional(),completedAt:Pi.nullable().optional(),enrichment:tn.optional(),phaseMetrics:Ht.optional()}).passthrough(),Hl=z$1.object({status:z$1.literal("stale"),currentCommit:z$1.string().nullable().optional(),requestedCommit:z$1.string().optional(),enrichment:tn.optional(),phaseMetrics:Ht.optional()}).passthrough(),zl=z$1.object({status:z$1.literal("failed"),currentCommit:z$1.string().nullable().optional(),requestedCommit:z$1.string().optional(),enrichment:tn.optional(),phaseMetrics:Ht.optional()}).passthrough(),rn=z$1.discriminatedUnion("status",[Bl,Wl,Hl,zl]),Kl=z$1.enum(["function","class","variable","import","module","interface","type","constant","export"]),Vl=z$1.enum(["calls","imports","extends","inherits","implements","uses","references","exports","contains"]),Jl=z$1.object({id:z$1.string(),label:z$1.string(),type:Kl,data:z$1.object({filePath:z$1.string(),lineNumber:z$1.number().int().nonnegative(),module:z$1.string(),visibility:z$1.string(),isExported:z$1.boolean()})}),ql=z$1.object({id:z$1.string(),source:z$1.string(),target:z$1.string(),type:Vl,label:z$1.string().optional()}),Yl=z$1.object({totalNodes:z$1.number().int().nonnegative(),totalEdges:z$1.number().int().nonnegative(),toolName:z$1.string(),query:z$1.string(),riskLevel:gt.optional()}),Xl=z$1.object({projectName:z$1.string(),branch:z$1.string(),asOfCommit:z$1.string(),lastIndexedAt:z$1.string().datetime()}),z$1.object({nodes:z$1.array(Jl),edges:z$1.array(ql),summary:Yl,metadata:Xl,features:z$1.record(z$1.string(),z$1.boolean()).optional()}),Ii=z$1.object({projectId:z$1.string(),projectName:z$1.string(),defaultBranch:z$1.string(),lastIndexedAt:z$1.string().datetime().optional(),fileCount:z$1.number().int().nonnegative().optional(),languages:z$1.array(z$1.string()).optional()}),z$1.object({projects:z$1.array(Ii)}),Ii.pick({projectId:true,projectName:true,defaultBranch:true}),Ri=z$1.enum(["unresolved","resolved","archived"]),Ni=z$1.enum(["succeeded","failed"]),Ti=z$1.enum(["full","incremental"]),Ql=z$1.enum(["info","warn","error"]),Zl=z$1.object({type:z$1.string(),message:z$1.string(),phase:z$1.string(),filePath:z$1.string().optional(),stack:z$1.string().optional()}),ec=z$1.object({type:z$1.string(),message:z$1.string(),phase:z$1.string(),filePath:z$1.string().optional()}),Li=z$1.object({errors:z$1.array(Zl),warnings:z$1.array(ec)}),ki=z$1.object({level:Ql,message:z$1.string(),timestamp:z$1.string().datetime()}),z$1.object({errorSummary:z$1.string().max(500),errorData:Li,logEntries:z$1.array(ki),cliVersion:z$1.string(),outcome:Ni,indexType:Ti}),z$1.object({status:Ri.exclude(["archived"])}),z$1.object({id:z$1.string(),organizationId:z$1.string(),userId:z$1.string(),projectId:z$1.string(),branchName:z$1.string(),commitHash:z$1.string().nullable(),indexType:Ti,status:Ri,outcome:Ni,errorSummary:z$1.string(),errorData:Li,logEntries:z$1.array(ki),cliVersion:z$1.string(),resolvedAt:z$1.string().nullable(),resolvedBy:z$1.string().nullable(),createdAt:z$1.string(),updatedAt:z$1.string(),organizationName:z$1.string().optional(),projectName:z$1.string().optional(),userEmail:z$1.string().optional(),resolvedByEmail:z$1.string().optional()}),z$1.object({unresolvedCount:z$1.number(),failedRunCount:z$1.number(),resolvedLast30d:z$1.number(),avgResolutionDays:z$1.number().nullable(),affectedOrgCount:z$1.number()}),tc=["org-admin-v1","developer-v1","constellation-admin-v1"],rc=z$1.enum(tc),nc=["eligible","completed","dismissed","ineligible"],ic=z$1.enum(nc),z$1.object({tourId:rc,status:ic,lastStepReached:z$1.string().max(64).optional()}),z$1.object({stepId:z$1.string().min(1).max(64)});});var nn,bt=g(()=>{nn=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 on(i){return i.length>zt&&(i[zt]=ji),i}function Ai(){let i=false,e=0;return new Transform({transform(t,r,o){if(i){o(null,t);return}if(e+t.length>zt){let s=zt-e;t[s]=ji,i=true;}e+=t.length,o(null,t);}})}var zt,ji,sn=g(()=>{zt=9,ji=255;});function Fi(i){return base32.encode(Buffer.from(i))}var $i=g(()=>{});function Di(i,e,t){let r=`${i}:${e}${t?`:${t}`:""}`;return Fi(r)}var Oi=g(()=>{$i();});var Kt,Mi=g(()=>{Kt=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 Gi(){return Ui.some(i=>!!process.env[i])}function Bi(){return !!process.stdout.isTTY}function Wi(){let i=Ui.find(e=>!!process.env[e]);return i?lc[i]:void 0}var Ui,lc,an=g(()=>{Ui=["GITHUB_ACTIONS","GITLAB_CI","JENKINS_URL","CIRCLECI","TRAVIS","BUILDKITE","DRONE","CI"],lc={GITHUB_ACTIONS:"github-actions",GITLAB_CI:"gitlab",JENKINS_URL:"jenkins",CIRCLECI:"circleci",TRAVIS:"travis",BUILDKITE:"buildkite",DRONE:"drone",CI:"unknown"};});function cc(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 pc(i,e){return i==="darwin"?`Darwin ${e}`:e}function uc(){let i=globalThis.__constellationVersion;return typeof i=="string"&&i.length>0?i:"unknown"}function dc(i={}){let e=i.platform??process.platform,t=i.arch??process.arch,r=(i.nodeVersion??process.version).replace(/^v/,""),o=i.osRelease??$e.release(),s=uc(),a=cc(e),l=pc(e,o),c=`constellation-cli/${s} (${a}; ${l}; ${t}) Node/${r}`,p=Wi();return p&&(c+=` CI/${p}`),c}var St,zi=g(()=>{an();St=dc();});function hc(i){switch(i){case "PROJECT_NOT_REGISTERED":return "PROJECT_NOT_REGISTERED";case "PROJECT_INACTIVE":return "PROJECT_INACTIVE";case "INVALID_PROJECT_ID":return "INVALID_PROJECT_ID";default:return "PROJECT_VALIDATION_FAILED"}}var Vt,Jt,D,Ce,ge,Ne,Ee,pn=g(()=>{vt();z();bt();sn();Oi();Mi();zi();Vt=class i{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 ge(t?.message||"Project not registered",r,this.config.projectId);case "PROJECT_INACTIVE":throw new ge(t?.message||"Project is inactive",r,this.config.projectId);case "INVALID_PROJECT_ID":throw new ge(t?.message||"Invalid project ID format",r,this.config.projectId);case "PROJECT_NOT_FOUND":throw new Ce("Project not found - no previous index exists");default:throw e.status===404?new Ce("Project not found - no previous index exists"):new Error(`Unexpected API response (${e.status}): ${t?.message||e.statusText}`)}}catch(t){throw t instanceof ge||t instanceof Ce?t:e.status===404?new Ce("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=rn.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 D)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 D("Authentication failed");if(!a.ok){let p=await this.formatErrorBody(a);throw new Error(`Failed to claim indexing lock: ${a.status}${p?` \u2014 ${p}`:""}`)}let l=await a.json(),c=_i.safeParse(l);if(!c.success)throw new Error(`Invalid lock response from server: ${c.error.issues.map(p=>p.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 D("Authentication failed during index status polling");if(c.status===403||c.status===404)return !1;if(c.ok){let p=await c.json(),u=rn.safeParse(p);if(u.success){if(u.data.status==="current")return !0;if(u.data.status==="stale"||u.data.status==="failed")return !1}}}catch(c){if(c instanceof D)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":St,"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=_n.gzipSync(Buffer.from(e,"utf8")),l=new Agent({headersTimeout:0,bodyTimeout:0});try{for(let c=0;c<=s.length;c++)try{let p=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":St,"x-project-id":t,"x-branch-name":r,"x-commit-hash":o,"x-constellation-dirty":this.dirty?"true":"false"},body:a,dispatcher:l});if(p.status===401)throw new D("Authentication failed during enrichment upload");if(p.status===409){if((await p.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 p.ok||p.status===202?!0:(this.reporter?.warn(`Enrichment upload failed with status ${p.status}`),!1)}catch(p){if(p instanceof D)throw p;if(c<s.length){this.reporter?.warn(`Enrichment upload network error (attempt ${c+1}/${s.length+1}): ${p instanceof Error?p.message:String(p)}`),await new Promise(u=>setTimeout(u,s[c]));continue}return this.reporter?.warn(`Enrichment upload error: ${p instanceof Error?p.message:String(p)}`),!1}return !1}finally{l.destroy().catch(()=>{});}}async deleteFiles(e){for(let t of e){let r=Di(this.config.projectId,this.config.branch,t);await this.delete(`/ast/${r}`);}}retryableStatusCodes=[500,502,503,504];static RETRYABLE_NETWORK_ERROR_CODES=new Set(["UND_ERR_SOCKET","UND_ERR_SOCKET_ERROR","UND_ERR_CONNECT_TIMEOUT","UND_ERR_HEADERS_TIMEOUT","UND_ERR_BODY_TIMEOUT","ECONNRESET","EPIPE","ETIMEDOUT","EAI_AGAIN"]);isRetryableNetworkError(e){if(!e||typeof e!="object")return false;let t=e,r=typeof t.code=="string"?t.code:typeof t.cause?.code=="string"?t.cause.code:void 0;return r?i.RETRYABLE_NETWORK_ERROR_CODES.has(r):false}shortNetworkErrorReason(e){if(!e||typeof e!="object")return String(e);let t=e,r=typeof t.cause?.code=="string"?t.cause.code:typeof t.code=="string"?t.code:void 0,o=typeof t.message=="string"&&t.message.length>0?t.message:"network error";return r?`${o} (${r})`:o}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 Ne(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 c=new Kt(e),p=await buffer(c),u=process.env.CAPTURE_PAYLOAD_PATH;if(u)try{await pipeline(Readable.from(p),_n.createGzip(),Ai(),Le.createWriteStream(u));}catch(f){this.reporter?.warn(`[constellation] capture tap failed: ${f instanceof Error?f.message:String(f)}`);}let d=[1e3,2e3,4e3],m;for(let f=0;f<=d.length;f++){let h=new Agent({headersTimeout:0,bodyTimeout:0});try{let S=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/${t}`,{method:"POST",headers:{"Content-Type":"application/x-ndjson; charset=utf-8","Content-Length":String(p.byteLength),"User-Agent":St,"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:p,dispatcher:h});if(S.status===401)throw new D("Authentication failed");if(S.status===409)throw await this.parseIndexingConflict(S);if(S.status===200)try{let y=await S.json();if(y?.status==="current")return this.reporter?.summary(`${E} Index already up to date for ${o} at commit ${y.commitHash||"unknown"}`),!0}catch{}if(S.ok||S.status===202)return !0;let v=`Server returned ${S.status}`;try{let y=await S.json();y?.message&&(v=Array.isArray(y.message)?y.message.join("; "):y.message);}catch{}throw new Error(v)}catch(S){if(S instanceof D||S instanceof Ne)throw S;if(this.isRetryableNetworkError(S)&&f<d.length){let v=Math.floor(Math.random()*250),y=d[f]+v;this.reporter?.warn(`Upload network error (attempt ${f+1}/${d.length+1}): ${this.shortNetworkErrorReason(S)} \u2014 retrying in ${y}ms`),m=S,await new Promise(C=>setTimeout(C,y));continue}throw S}finally{h.destroy().catch(()=>{});}}throw m??new Error("Upload failed after exhausting retry budget")}catch(c){if(c instanceof D||c instanceof Ne)throw c;let p=c instanceof Error?c:new Error(String(c)),u="";if(p.message==="fetch failed"||c.code){let m=[],f=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}`);}f==="ERR_INVALID_ARG_VALUE"?u="Invalid argument value - check stream/body format and duplex option":f==="ECONNREFUSED"?u="Connection refused - service may be down or unreachable":f==="ENOTFOUND"?u="DNS lookup failed - check service URL":f==="ETIMEDOUT"?u="Connection timeout - service not responding":f==="ECONNRESET"?u="Connection reset by server":f==="EHOSTUNREACH"?u="Host unreachable - check network connectivity":u="Network failure",m.length>0&&(u+=` (${m.join(", ")})`);}else u=p.message;let d=new Error(`Failed to upload data to Constellation Service: ${u}`);throw d.cause=p,d.stack=`${d.stack}
36
- Caused by: ${p.stack}`,d}}async sendRequest(e,t,r,o={},s=0,a=3,l=1e3,c=250){for(let p=1;p<=a;p++){let u;try{let d=new AbortController;s>0&&(u=setTimeout(()=>d.abort(),s));let m={...o,"Content-Type":"application/json; charset=utf-8",Accepts:"application/json; charset=utf-8","User-Agent":St,Authorization:`Bearer ${this.accessKey}`},f=await fetch(`${this.config.apiUrl}/${this.apiVersion}/${e}`,{method:r,headers:m,body:t?JSON.stringify(t):void 0,signal:d.signal});if(u&&clearTimeout(u),f.status===401)throw new D("Authentication failed");if(!f.ok&&this.retryableStatusCodes.includes(f.status))throw new Jt(`${f.statusText} (${f.status})`);return f}catch(d){if(u&&clearTimeout(u),!(d instanceof D)){let m=d instanceof Error?`${d.message}${d.cause?` (Cause: ${d.cause})`:""}`:String(d);this.reporter?.warn(`HTTP request attempt ${p}/${a} failed: ${m}`);}if(p<a&&d instanceof Jt){let m=l+Math.floor(Math.random()*c);await new Promise(f=>setTimeout(f,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}`)}},Jt=class extends Error{constructor(e){super(e),this.name="RetryableError";}},D=class extends Error{errorCode="AUTH_FAILURE";constructor(e){super(e),this.name="AuthenticationError";}},Ce=class extends Error{constructor(e){super(e),this.name="NotFoundError";}},ge=class extends Error{constructor(t,r,o){super(t);this.code=r;this.projectId=o;this.name="ProjectValidationError",this.errorCode=hc(r);}errorCode};Ne=class extends Error{constructor(t,r){super(t);this.branchName=r;this.name="IndexingInProgressError";}errorCode="CONCURRENT_INDEXING"},Ee=class extends Error{constructor(t,r){super(t);this.errorCode=r;this.name="GitValidationError";}};});function K(i){return i.replace(/\\/g,"/")}function Yt(i){return K(i).replace(/^\.?\//,"")}function V(i,e){return K(R.relative(i,e))}var fe=g(()=>{});var ze,dn=g(()=>{ze=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 p=o++,u=s,d=this.processItem(e[u],u,t).then(m=>({result:m!==null?m.result:null,index:u,promiseId:p}));r.set(p,d),s++;}for(;r.size>0;){let p=await Promise.race(r.values());if(r.delete(p.promiseId),this.options.preserveOrder)for(p.result!==null?a.set(p.index,p.result):l.add(p.index);c<e.length&&(a.has(c)||l.has(c));){if(a.has(c)){let u=a.get(c);a.delete(c),yield u;}else l.delete(c);c++;}else p.result!==null&&(yield p.result);if(s<e.length){let u=o++,d=s,m=this.processItem(e[d],d,t).then(f=>({result:f!==null?f.result:null,index:d,promiseId:u}));r.set(u,m),s++;}}}async processItem(e,t,r){try{return {result:await r(e,t),index:t}}catch{return null}}};});var bc,Sc,Xt,wc,Qt,qi=g(()=>{fe();dn();bc={function:{hover:true,references:true,callHierarchy:true,implementation:false},method:{hover:true,references:true,callHierarchy:true,implementation:true},class:{hover:false,references:true,callHierarchy:false,implementation:true},interface:{hover:false,references:true,callHierarchy:false,implementation:true},struct:{hover:false,references:true,callHierarchy:false,implementation:true},variable:{hover:true,references:true,callHierarchy:false,implementation:false},property:{hover:true,references:true,callHierarchy:false,implementation:false},import:{hover:true,references:false,callHierarchy:false,implementation:false}},Sc={hover:true,references:true,callHierarchy:false,implementation:false},Xt=1e4,wc=1200*1e3,Qt=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},p=false,u=new Set,d=new Set;return await Promise.all([...e.entries()].map(async([m,f])=>{let h=r.get(m);if(!h)return;let S=f.length,v=S>1e4?8:S>5e3?10:16,y=new ze(v),C=()=>{u.add(m),d.has(h.serverId)||(d.add(h.serverId),c.lspProcessCrashes++,c.firstLspCrashLanguage||(c.firstLspCrashLanguage=m)),this.reporter?.warn(`[LSP:${m}] Process exited mid-enrichment (concurrency=${v}); halting subsequent ${m} files.`);},P=h.onCrash(C),b=0,_=y.run(f,async w=>{try{if(p||Date.now()-l>wc)return p=!0,null;if(u.has(m))return null;let I=await this.openFile(h,w,c,o?.get(w));if(!I)return null;let{uri:A}=I;try{let k=t.get(w)??[];if(k.length===0&&(k=await this.discoverSymbols(h,w,A,c),k.length===0))return c.filesNoSymbols++,null;let H=await this.enrichOpenFile(h,w,A,k,c);return H.length>0?{filePath:w,language:m,symbols:H}:null}finally{this.closeFile(h,A);}}finally{b++,s?.(m,b,S);}});try{for await(let w of _)w&&a.push(w);}finally{P();}})),p&&this.reporter?.info("Enrichment timeout reached. Uploading partial results."),this.logDiagnostics(c),a}async openFile(e,t,r,o){let s=R.resolve(this.projectRoot,t),a=pathToFileURL(s).href,l=o;if(l===void 0)try{l=await Le.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 p=a[c];if(p.status==="fulfilled")p.value&&l.push(p.value);else if(s.symbolQueryErrors++,!s.firstSymbolError){let u=o[c];s.firstSymbolError=`${u.name} in ${t}: ${p.reason instanceof Error?p.reason.message:String(p.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=bc[s]||Sc,c=!r.isExported&&(s==="function"||s==="method")?{...a,callHierarchy:false}:a,p={line:r.line-1,character:r.column},u={textDocument:{uri:t},position:p},d={name:r.name,line:r.line,column:r.column,kind:r.kind},m=false,[f,h,S]=await Promise.allSettled([c.hover?e.sendRequest("textDocument/hover",u,Xt):null,c.references?e.sendRequest("textDocument/references",{...u,context:{includeDeclaration:false}},Xt):null,c.implementation?e.sendRequest("textDocument/implementation",u,Xt):null]);for(let v of [f,h])v.status==="rejected"&&o.queryRejections++;if(f.status==="fulfilled"&&f.value?.contents){let v=f.value,y=typeof v.contents=="string"?v.contents:v.contents.value||"";y&&(d.typeInfo={resolvedType:y},m=true);}if(h.status==="fulfilled"&&h.value){let v=h.value;if(v.length>0){let y=v.slice(0,100).map(C=>({filePath:V(this.projectRoot,this.uriToPath(C.uri||"")),line:(C.range?.start?.line??0)+1,column:C.range?.start?.character??0}));d.references={count:v.length,locations:y},m=true;}}if(c.implementation&&S.status==="fulfilled"){let v=S.value,C=(Array.isArray(v)?v:v?[v]:[]).slice(0,200).map(P=>{let b=P.targetUri??P.uri??"",_=P.targetSelectionRange??P.targetRange??P.range??null;return {filePath:V(this.projectRoot,this.uriToPath(b)),line:(_?.start?.line??0)+1,column:_?.start?.character??0}});d.implementations=C,C.length>0&&(m=true);}if(c.callHierarchy)try{let v=await e.sendRequest("textDocument/prepareCallHierarchy",u,Xt);if(v&&v.length>0){let y=v[0],[C,P]=await Promise.all([e.sendRequest("callHierarchy/incomingCalls",{item:y}).catch(()=>[]),e.sendRequest("callHierarchy/outgoingCalls",{item:y}).catch(()=>[])]),b=200,_=[];for(let I of C||[]){let A=Array.isArray(I.fromRanges)?I.fromRanges:[];if(A.length===0)continue;let k=V(this.projectRoot,this.uriToPath(I.from?.uri||"")),H=I.from?.name||"";for(let T of A){if(_.length>=b)break;_.push({name:H,filePath:k,line:(T?.start?.line??0)+1,column:T?.start?.character??0});}if(_.length>=b)break}let w=[];for(let I of P||[]){let A=Array.isArray(I.fromRanges)?I.fromRanges:[];if(A.length===0)continue;let k=V(this.projectRoot,this.uriToPath(I.to?.uri||"")),H=I.to?.name||"";for(let T of A){if(w.length>=b)break;w.push({name:H,filePath:k,line:(T?.start?.line??0)+1,column:T?.start?.character??0});}if(w.length>=b)break}(_.length>0||w.length>0)&&(d.callHierarchy={incomingCalls:_,outgoingCalls:w},m=!0);}}catch{o.queryRejections++;}if(!m){let v=r.kind.toLowerCase();o.symbolsWithNoEnrichment[v]=(o.symbolsWithNoEnrichment[v]??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,t=null){let r=[],o={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"},s=new Set([null,2,3,5,6,9,10,11,12,23]),a=new Set([2,3,5,6,9,10,11,12,23,26]);for(let l of e){let c=o[l.kind]||"variable",p=l.selectionRange||l.range||l.location?.range,u=l.kind;p!=null&&(u!==void 0&&a.has(u)||s.has(t))&&r.push({name:l.name,line:(p.start?.line??0)+1,column:p.start?.character??0,kind:c,isExported:true}),l.children&&Array.isArray(l.children)&&r.push(...this.flattenDocumentSymbols(l.children,l.kind??null));}return r}uriToPath(e){try{return fileURLToPath(new URL(e))}catch{return e.replace(/^file:\/\//,"")}}getLanguageId(e){let t=R.extname(e).toLowerCase();return {".ts":"typescript",".tsx":"typescriptreact",".js":"javascript",".jsx":"javascriptreact",".py":"python",".pyi":"python"}[t]||"plaintext"}};});function Yi(i){return i.map(e=>JSON.stringify(e)).join(`
34
+ New terminal sessions will load it automatically.`),He.platform()==="darwin"&&this.reporter.info("Already-running desktop apps (Claude Desktop, Codex, etc.) must be quit and relaunched to see the new value.");}};});var Hi,be,Et,xl,Xe,Pt,Cl,El,Pl,It,Il,Rl,Nl,Tl,Ll,kl,jl,Al,Fl,$l,Dl,Ol,Ml,Ul,Gl,Bl,Hl,zl,Wl,Kl,Gi,Vl,Jl,ql,Yl,Xl,Ql,Zl,ec,tc,rc,nc,ic,oc,sc,ac,lc,cc,zi,pc,uc,pn,dc,mc,fc,gc,Rt,hc,yc,vc,bc,Sc,Wi,wc,_c,tr,cn,Bi,xc,Cc,Ec,un,Ki,Pc,Ic,Rc,Nc,dn,Tc,Lc,kc,jc,Ac,Fc,Vi,Ji,qi,Yi,$c,Dc,Oc,Xi,Qi,Mc,Uc,Gc,Bc,Nt=f(()=>{Hi=z$1.object({total:z$1.number().int().nonnegative(),returned:z$1.number().int().nonnegative(),hasMore:z$1.boolean(),nextOffset:z$1.number().int().nonnegative().optional(),currentOffset:z$1.number().int().nonnegative().optional()}),z$1.object({overall:z$1.number().min(0).max(1),factors:z$1.object({dataFreshness:z$1.number().min(0).max(1).optional(),coverageComplete:z$1.number().min(0).max(1).optional(),heuristicAccuracy:z$1.number().min(0).max(1).optional(),semanticAnalysisDepth:z$1.number().min(0).max(1).optional(),patternMatchQuality:z$1.number().min(0).max(1).optional()}).optional(),warnings:z$1.array(z$1.string()).optional(),recommendations:z$1.array(z$1.string()).optional()}),z$1.object({qualityScore:z$1.number().min(0).max(100).optional(),lastUpdated:z$1.string().optional(),cached:z$1.boolean().optional(),executionTime:z$1.number().nonnegative().optional(),coveragePercentage:z$1.number().min(0).max(100).optional(),issues:z$1.array(z$1.string()).optional()}),be=z$1.object({language:z$1.string(),features:z$1.array(z$1.string()).optional(),visibility:z$1.string().optional(),decorators:z$1.array(z$1.string()).optional(),typeInfo:z$1.any().optional(),custom:z$1.record(z$1.string(),z$1.any()).optional()}),z$1.enum(["function","class","interface","type","variable","constant","enum","module","namespace","method","property","parameter","constructor","decorator","trait","struct","record","delegate","event","indexer","operator","destructor","local_function","attribute","generic_type_parameter","macro","unknown"]),Et=z$1.enum(["low","medium","high","critical"]),xl=z$1.enum(["low","moderate","high","very_high"]),Xe=z$1.object({cyclomaticComplexity:z$1.number().int().nonnegative(),complexityRisk:xl}),Pt=z$1.object({filePath:z$1.string(),line:z$1.number().int().positive().optional(),lineStart:z$1.number().int().positive().optional(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative().optional()}),Pt.extend({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),symbolKind:z$1.string().optional()}),z$1.object({outgoing:z$1.array(z$1.string()),incoming:z$1.array(z$1.string())}),Cl=z$1.object({id:z$1.string(),name:z$1.string(),type:z$1.string(),properties:z$1.record(z$1.string(),z$1.any()).optional()}),El=z$1.object({from:z$1.string(),to:z$1.string(),type:z$1.string().optional(),weight:z$1.number().optional(),properties:z$1.record(z$1.string(),z$1.any()).optional()}),Pl=z$1.object({nodes:z$1.array(Cl),edges:z$1.array(El),metadata:z$1.object({nodeCount:z$1.number().int().nonnegative(),edgeCount:z$1.number().int().nonnegative(),directed:z$1.boolean(),hasCycles:z$1.boolean().optional()}).optional()}),It=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$1.object({success:z$1.literal(false),error:z$1.object({code:z$1.string(),message:z$1.string(),details:z$1.any().optional()})}),z$1.object({query:z$1.string().max(200),filterByKind:z$1.array(z$1.string()).optional(),filterByVisibility:z$1.array(z$1.string()).optional(),isExported:z$1.boolean().optional(),filterByFile:z$1.string().optional(),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0),includeUsageCount:z$1.boolean().optional(),includeDocumentation:z$1.boolean().optional()}).refine(n=>n.query.length>0||n.filterByKind&&n.filterByKind.length>0||n.filterByVisibility&&n.filterByVisibility.length>0||n.isExported!==void 0||n.filterByFile!==void 0,{message:"Either query must be non-empty or at least one filter (filterByKind, filterByVisibility, isExported, filterByFile) must be provided",path:["query"]}),Il=Pt.extend({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),signature:z$1.string().optional(),documentation:z$1.string().optional(),visibility:z$1.string().optional(),isExported:z$1.boolean(),usageCount:z$1.number().int().nonnegative().optional(),complexity:Xe.optional(),languageMetadata:be.optional()}),z$1.object({symbols:z$1.array(Il),pagination:Hi.optional()}),z$1.object({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),includeReferences:z$1.boolean().optional(),includeRelationships:z$1.boolean().optional(),includeImpactScore:z$1.boolean().optional()}),Rl=Pt.extend({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),signature:z$1.string().optional(),documentation:z$1.string().optional(),visibility:z$1.string().optional(),modifiers:z$1.array(z$1.string()).optional(),typeInfo:z$1.any().optional(),decorators:z$1.array(z$1.string()).optional(),isExported:z$1.boolean(),isDeprecated:z$1.boolean(),complexity:Xe.optional(),languageMetadata:be.optional()}),Nl=Pt.extend({usageType:z$1.string(),context:z$1.string().optional(),aliasName:z$1.string().optional()}),Tl=z$1.object({calls:z$1.array(z$1.string()),calledBy:z$1.array(z$1.string()),inheritsFrom:z$1.array(z$1.string()),inheritedBy:z$1.array(z$1.string()),children:z$1.array(z$1.string())}),Ll=z$1.object({directUsage:z$1.number().int().nonnegative(),transitiveImpact:z$1.number().int().nonnegative(),riskScore:z$1.number().min(0).max(100),riskLevel:Et}),z$1.object({symbol:Rl,references:z$1.array(Nl).optional(),relationships:Tl.optional(),impactScore:Ll.optional()}),z$1.object({filePath:z$1.string().min(1),depth:z$1.number().int().nonnegative().max(10).optional(),includePackages:z$1.boolean().optional(),includeSymbols:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(20),offset:z$1.number().int().nonnegative().default(0)}),kl=z$1.object({type:z$1.enum(["file","module"]),filePath:z$1.string().nullable(),moduleName:z$1.string().nullable().optional(),importedSymbols:z$1.array(z$1.string()).optional(),isDefault:z$1.boolean(),isNamespace:z$1.boolean()}),jl=z$1.object({filePath:z$1.string(),distance:z$1.number().int().positive(),path:z$1.array(z$1.string())}),Al=z$1.object({name:z$1.string(),version:z$1.string().optional(),type:z$1.string()}),z$1.object({totalFiles:z$1.number().int().nonnegative(),totalPackages:z$1.number().int().nonnegative(),maxDepth:z$1.number().int().nonnegative()}),z$1.object({file:z$1.string(),directDependencies:z$1.array(kl),transitiveDependencies:z$1.array(jl).optional(),packages:z$1.array(Al).optional()}),z$1.object({filePath:z$1.string().min(1),depth:z$1.number().int().nonnegative().max(10).optional(),includeSymbols:z$1.boolean().optional(),includeImpactMetrics:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(20),offset:z$1.number().int().nonnegative().default(0)}),Fl=z$1.object({filePath:z$1.string(),usedSymbols:z$1.array(z$1.string()).optional()}),$l=z$1.object({filePath:z$1.string(),distance:z$1.number().int().positive(),path:z$1.array(z$1.string())}),z$1.object({totalFiles:z$1.number().int().nonnegative(),maxDepth:z$1.number().int().nonnegative(),riskLevel:Et}),z$1.object({file:z$1.string(),directDependents:z$1.array(Fl),transitiveDependents:z$1.array($l).optional(),detailedMetrics:z$1.object({byDepth:z$1.record(z$1.string(),z$1.number()),criticalPaths:z$1.array(z$1.array(z$1.string())),mostImpactedFiles:z$1.array(z$1.string())}).optional()}),z$1.object({filePath:z$1.string().min(1).optional(),minCycleLength:z$1.number().int().min(2).max(10).optional(),maxCycleLength:z$1.number().int().min(2).max(10).optional(),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0),includeImpactScore:z$1.boolean().optional(),includeConfidence:z$1.boolean().optional()}),Dl=z$1.object({files:z$1.array(z$1.string()),length:z$1.number().int().positive(),impactScore:z$1.number().min(0).max(100).optional(),severity:Et}),z$1.object({cycles:z$1.array(Dl)}),z$1.object({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),filterByUsageType:z$1.array(z$1.string()).optional(),filterByRelationshipType:z$1.array(z$1.string()).optional(),includeTransitive:z$1.boolean().optional(),includeContext:z$1.boolean().optional(),excludeTests:z$1.boolean().optional(),excludeGenerated:z$1.boolean().optional(),includeImportanceWeight:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0)}),Ol=z$1.object({name:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),lineEnd:z$1.number().int().positive().optional(),complexity:Xe.optional(),languageMetadata:be.optional()}),Ml=z$1.object({filePath:z$1.string(),usageType:z$1.string(),relationshipType:z$1.string(),line:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative().optional(),enclosingSymbol:z$1.object({name:z$1.string(),kind:z$1.string()}).optional(),context:z$1.string().optional(),aliasName:z$1.string().optional(),isTest:z$1.boolean().optional(),isGenerated:z$1.boolean().optional(),importanceWeight:z$1.number().min(0).max(1).optional()}),Ul=z$1.object({filePath:z$1.string(),distance:z$1.number().int().positive(),chain:z$1.array(z$1.string())}),Gl=z$1.object({limit:z$1.number().int().positive(),offset:z$1.number().int().nonnegative(),returned:z$1.number().int().nonnegative(),hasMore:z$1.boolean()}),Bl=z$1.object({totalUsages:z$1.number().int().nonnegative(),usagesByType:z$1.record(z$1.string(),z$1.number().int().nonnegative()),filesAffected:z$1.number().int().nonnegative(),transitiveImpact:z$1.number().int().nonnegative(),pageInfo:Gl}),z$1.object({symbol:Ol,directUsages:z$1.array(Ml),transitiveUsages:z$1.array(Ul).optional(),summary:Bl}),Hl=z$1.preprocess(n=>n==="callers"?"incoming":n==="callees"?"outgoing":n,z$1.enum(["incoming","outgoing","both"])).describe("Direction of traversal for getCallGraph. Use 'incoming' | 'outgoing' | 'both'. Legacy aliases 'callers' (\u2192 'incoming') and 'callees' (\u2192 'outgoing') are deprecated and will be removed in a future release."),z$1.object({symbolId:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),direction:Hl.default("both"),depth:z$1.number().int().positive().max(10).default(3),excludeExternal:z$1.boolean().optional(),includeGraph:z$1.boolean().optional(),limit:z$1.number().int().positive().max(100).default(25),offset:z$1.number().int().nonnegative().default(0)}),zl=z$1.object({symbolId:z$1.string(),name:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),complexity:Xe.optional(),languageMetadata:be.optional()}),Wl=z$1.object({symbolId:z$1.string(),name:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),depth:z$1.number().int().nonnegative(),complexity:Xe.optional(),languageMetadata:be.optional()}),Kl=z$1.object({symbolId:z$1.string(),name:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),isAsync:z$1.boolean(),depth:z$1.number().int().nonnegative(),complexity:Xe.optional(),languageMetadata:be.optional()}),z$1.object({root:zl,callers:z$1.array(Wl).optional(),callees:z$1.array(Kl).optional(),graph:Pl.optional()}),z$1.object({symbolId:z$1.string().optional(),qualifiedName:z$1.string().optional(),symbolName:z$1.string().optional(),filePath:z$1.string().optional(),includeDirectDependents:z$1.boolean().default(true),includeTransitiveDependents:z$1.boolean().default(true),depth:z$1.number().int().min(1).max(5).default(2),excludeTests:z$1.boolean().default(true),excludeGenerated:z$1.boolean().default(true),analyzeBreakingChanges:z$1.boolean().default(true)}),Gi=Pt.extend({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),relationshipType:z$1.string(),depth:z$1.number().int().positive(),isExported:z$1.boolean().optional(),transitiveImpactCount:z$1.number().int().nonnegative().optional(),languageMetadata:be.optional()}),Vl=z$1.object({filePath:z$1.string(),symbolCount:z$1.number().int().positive(),isTest:z$1.boolean().optional(),isGenerated:z$1.boolean().optional(),symbols:z$1.array(z$1.object({id:z$1.string(),name:z$1.string(),kind:z$1.string(),line:z$1.number().int().positive()}))}),Jl=z$1.object({riskLevel:Et,factors:z$1.array(z$1.object({factor:z$1.string(),severity:z$1.enum(["low","medium","high"]),description:z$1.string()})),recommendations:z$1.array(z$1.string())}),z$1.object({symbol:z$1.object({id:z$1.string(),name:z$1.string(),qualifiedName:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),line:z$1.number().int().positive(),lineEnd:z$1.number().int().positive().optional(),column:z$1.number().int().nonnegative(),isExported:z$1.boolean().optional(),languageMetadata:be.optional()}),directDependents:z$1.array(Gi).optional(),transitiveDependents:z$1.array(Gi).optional(),impactedFiles:z$1.array(Vl),breakingChangeRisk:Jl.optional(),summary:z$1.object({directDependentCount:z$1.number().int().nonnegative(),transitiveDependentCount:z$1.number().int().nonnegative(),impactedFileCount:z$1.number().int().nonnegative(),testFileCount:z$1.number().int().nonnegative(),productionFileCount:z$1.number().int().nonnegative(),maxDepth:z$1.number().int().nonnegative()})}),z$1.object({filePattern:z$1.string().optional(),filterByKind:z$1.array(z$1.string()).optional(),exportedOnly:z$1.boolean().optional(),excludeTests:z$1.boolean().default(true),limit:z$1.number().int().positive().max(100).default(50),offset:z$1.number().int().nonnegative().default(0),includeConfidence:z$1.boolean().optional()}),ql=z$1.object({symbolId:z$1.string(),name:z$1.string(),kind:z$1.string(),visibility:z$1.string().optional(),filePath:z$1.string(),lineEnd:z$1.number().int().positive().optional(),isExported:z$1.boolean(),reason:z$1.string(),confidence:z$1.number().min(0).max(1),languageMetadata:be.optional()}),Yl=z$1.object({filePath:z$1.string(),reason:z$1.string(),lastUpdated:z$1.string().optional(),confidence:z$1.number().min(0).max(1)}),Xl=z$1.object({totalOrphanedSymbols:z$1.number().int().nonnegative(),totalOrphanedFiles:z$1.number().int().nonnegative(),potentialDeletions:z$1.number().int().nonnegative(),filesTruncated:z$1.boolean().optional()}),z$1.object({orphanedSymbols:z$1.array(ql),orphanedFiles:z$1.array(Yl),summary:Xl.optional(),pagination:Hi.optional()}),z$1.object({includeMetrics:z$1.boolean().default(false),includeModuleGraph:z$1.boolean().default(false),includePackages:z$1.boolean().default(true)}),Ql=z$1.object({language:z$1.string(),fileCount:z$1.number().int().nonnegative(),percentage:z$1.number().min(0).max(100)}),Zl=z$1.object({name:z$1.string(),version:z$1.string().optional(),confidence:z$1.enum(["high","medium","low"]),evidence:z$1.array(z$1.string())}),ec=z$1.object({languages:z$1.array(Ql),frameworks:z$1.array(Zl),primaryLanguage:z$1.string(),totalFiles:z$1.number().int().nonnegative(),totalLines:z$1.number().int().nonnegative().optional()}),tc=z$1.object({files:z$1.object({total:z$1.number().int().nonnegative(),byType:z$1.record(z$1.string(),z$1.number()),byParadigm:z$1.record(z$1.string(),z$1.number())}),symbols:z$1.object({total:z$1.number().int().nonnegative(),byKind:z$1.record(z$1.string(),z$1.number()),exported:z$1.number().int().nonnegative(),public:z$1.number().int().nonnegative()}),modules:z$1.object({total:z$1.number().int().nonnegative(),averageSize:z$1.number().nonnegative(),largest:z$1.string()})}),rc=z$1.object({internal:z$1.object({totalConnections:z$1.number().int().nonnegative(),averagePerFile:z$1.number().nonnegative(),mostConnectedFiles:z$1.array(z$1.object({path:z$1.string(),incomingCount:z$1.number().int().nonnegative(),outgoingCount:z$1.number().int().nonnegative()}))}),external:z$1.object({totalPackages:z$1.number().int().nonnegative(),directDependencies:z$1.number().int().nonnegative(),topPackages:z$1.array(z$1.object({name:z$1.string(),usageCount:z$1.number().int().nonnegative()}))})}),nc=z$1.object({complexity:z$1.object({average:z$1.number().nonnegative(),high:z$1.number().int().nonnegative()}),maintainability:z$1.object({score:z$1.number().min(0).max(100),issues:z$1.array(z$1.string())}),testCoverage:z$1.object({percentage:z$1.number().min(0).max(100),testedFiles:z$1.number().int().nonnegative(),totalFiles:z$1.number().int().nonnegative()}).optional()}),ic=z$1.object({id:z$1.string(),name:z$1.string(),fileCount:z$1.number().int().nonnegative(),type:z$1.string()}),oc=z$1.object({from:z$1.string(),to:z$1.string(),weight:z$1.number().int().nonnegative()}),sc=z$1.object({nodes:z$1.array(ic),edges:z$1.array(oc)}),z$1.object({metadata:ec,structure:tc,dependencies:rc,metrics:nc.optional(),moduleGraph:sc.optional()}),z$1.object({}).strict(),z$1.object({pong:z$1.literal(true)}),ac=z$1.enum(["relative","workspace","alias","external","builtin"]),lc=z$1.object({source:z$1.string(),resolvedPath:z$1.string().optional(),isExternal:z$1.boolean(),importType:ac}),cc=z$1.record(z$1.string(),lc),zi=z$1.enum(["call","read","write","type","instantiate","import-use","declaration"]),pc=zi.exclude(["import-use","declaration"]),uc=z$1.object({line:z$1.number().int().nonnegative(),column:z$1.number().int().nonnegative(),referenceType:zi}).strict(),pn=z$1.object({filePath:z$1.string().min(1),entries:z$1.array(uc).max(1e5)}).strict(),z$1.object({file:z$1.string().min(1),language:z$1.string().min(1),commit:z$1.string().min(1),timestamp:z$1.string().datetime(),ast:z$1.string().min(1),importResolutions:cc.optional(),classificationMap:pn.optional()}).strict(),dc=z$1.object({file:z$1.string(),error:z$1.string()}),mc=z$1.object({file:z$1.string(),failedCount:z$1.number().int().nonnegative(),createdCount:z$1.number().int().nonnegative(),isTransient:z$1.boolean()}),fc=z$1.object({totalCreated:z$1.number().int().nonnegative(),totalFailed:z$1.number().int().nonnegative(),filesWithFailures:z$1.array(mc)}),z$1.object({processed:z$1.number().int().nonnegative(),failed:z$1.number().int().nonnegative(),projectId:z$1.string(),branchName:z$1.string(),failedFiles:z$1.array(dc).optional(),relationships:fc}),z$1.object({projectId:z$1.string(),projectName:z$1.string(),branch:z$1.string(),latestCommit:z$1.string().nullable(),fileCount:z$1.number().int().nonnegative(),lastIndexedAt:z$1.string().nullable(),languages:z$1.array(z$1.string())}),gc=z$1.object({local:z$1.string(),original:z$1.string().optional(),isDefault:z$1.boolean(),isNamespace:z$1.boolean()}),z$1.object({source:z$1.string(),specifiers:z$1.array(gc),isType:z$1.boolean(),isDynamic:z$1.boolean(),isConditional:z$1.boolean().optional(),isLazy:z$1.boolean().optional(),isWildcard:z$1.boolean().optional(),line:z$1.number(),column:z$1.number()}),z$1.object({referencerId:z$1.string(),referencedName:z$1.string(),referenceType:pc,line:z$1.number(),column:z$1.number(),scope:z$1.string().optional(),objectContext:z$1.string().optional(),language:z$1.string().optional()}),z$1.enum(["processing","completed","failed","cancelled","queued","superseded","cleaned_up"]),z$1.enum(["acquired","current","duplicate","superseded","queued"]),Rt={branchName:z$1.string().optional(),effectiveBranchName:z$1.string().optional(),remapped:z$1.boolean().optional()},hc=z$1.object({status:z$1.literal("acquired"),attemptId:z$1.string().uuid(),...Rt}),yc=z$1.object({status:z$1.literal("current"),...Rt}),vc=z$1.object({status:z$1.literal("duplicate"),...Rt}),bc=z$1.object({status:z$1.literal("superseded"),activeCommit:z$1.string().optional(),...Rt}),Sc=z$1.object({status:z$1.literal("queued"),queuedAttemptId:z$1.string().uuid(),...Rt}),Wi=z$1.discriminatedUnion("status",[hc,yc,vc,bc,Sc]),z$1.object({"x-attempt-id":z$1.string().uuid(),"x-project-id":z$1.string(),"x-branch-name":z$1.string(),"x-commit-hash":z$1.string().length(40),"x-constellation-dirty":z$1.union([z$1.literal("true"),z$1.literal("false")]).optional()}),wc=z$1.enum(["pass1","pass2","pass2b","pass3"]),_c=z$1.object({phase:wc,durationMs:z$1.number().int().nonnegative(),fileCount:z$1.number().int().nonnegative(),symbolCount:z$1.number().int().nonnegative().optional(),relationshipCount:z$1.number().int().nonnegative().optional(),throughputPerSec:z$1.number().nonnegative(),deadlockRetryCount:z$1.number().int().nonnegative().optional()}),tr=z$1.array(_c),cn=z$1.object({filePath:z$1.string().min(1),line:z$1.number().int().positive(),column:z$1.number().int().nonnegative()}).strict(),Bi=cn.extend({name:z$1.string().min(1)}).strict(),xc=z$1.object({resolvedType:z$1.string().min(1),returnType:z$1.string().optional(),documentation:z$1.string().max(16384).optional()}).strict(),Cc=z$1.object({name:z$1.string().min(1),line:z$1.number().int().positive(),column:z$1.number().int().nonnegative(),kind:z$1.string().min(1),typeInfo:xc.optional(),references:z$1.object({count:z$1.number().int().nonnegative(),locations:z$1.array(cn).max(100)}).optional(),callHierarchy:z$1.object({incomingCalls:z$1.array(Bi).max(200),outgoingCalls:z$1.array(Bi).max(200)}).optional(),implementations:z$1.array(cn).max(200).optional()}).strict(),z$1.object({filePath:z$1.string().min(1),language:z$1.string().min(1),symbols:z$1.array(Cc).max(1e4)}).strict(),z$1.object({projectId:z$1.string().min(1),branch:z$1.string().min(1),commit:z$1.string().regex(/^[0-9a-f]{40}$/),timestamp:z$1.string().datetime()}).strict(),Ec=z$1.enum(["pending","processing","completed","failed","skipped"]),un=z$1.object({status:Ec,filesProcessed:z$1.number().int().nonnegative().nullable(),completedAt:z$1.union([z$1.string().datetime({offset:true}),z$1.date()]).nullable()}),z$1.enum(["current","processing","stale","failed"]),Ki=z$1.union([z$1.string().datetime({offset:true}),z$1.date()]),Pc=z$1.object({status:z$1.literal("processing"),commitHash:z$1.string().nullable().optional(),startedAt:Ki.optional(),phaseMetrics:tr.optional()}).passthrough(),Ic=z$1.object({status:z$1.literal("current"),commitHash:z$1.string().nullable().optional(),completedAt:Ki.nullable().optional(),enrichment:un.optional(),phaseMetrics:tr.optional()}).passthrough(),Rc=z$1.object({status:z$1.literal("stale"),currentCommit:z$1.string().nullable().optional(),requestedCommit:z$1.string().optional(),enrichment:un.optional(),phaseMetrics:tr.optional()}).passthrough(),Nc=z$1.object({status:z$1.literal("failed"),currentCommit:z$1.string().nullable().optional(),requestedCommit:z$1.string().optional(),enrichment:un.optional(),phaseMetrics:tr.optional()}).passthrough(),dn=z$1.discriminatedUnion("status",[Pc,Ic,Rc,Nc]),Tc=z$1.enum(["function","class","variable","import","module","interface","type","constant","export"]),Lc=z$1.enum(["calls","imports","extends","inherits","implements","uses","references","exports","contains"]),kc=z$1.object({id:z$1.string(),label:z$1.string(),type:Tc,data:z$1.object({filePath:z$1.string(),lineNumber:z$1.number().int().nonnegative(),module:z$1.string(),visibility:z$1.string(),isExported:z$1.boolean()})}),jc=z$1.object({id:z$1.string(),source:z$1.string(),target:z$1.string(),type:Lc,label:z$1.string().optional()}),Ac=z$1.object({totalNodes:z$1.number().int().nonnegative(),totalEdges:z$1.number().int().nonnegative(),toolName:z$1.string(),query:z$1.string(),riskLevel:Et.optional()}),Fc=z$1.object({projectName:z$1.string(),branch:z$1.string(),asOfCommit:z$1.string(),lastIndexedAt:z$1.string().datetime()}),z$1.object({nodes:z$1.array(kc),edges:z$1.array(jc),summary:Ac,metadata:Fc,features:z$1.record(z$1.string(),z$1.boolean()).optional()}),Vi=z$1.object({projectId:z$1.string(),projectName:z$1.string(),defaultBranch:z$1.string(),lastIndexedAt:z$1.string().datetime().optional(),fileCount:z$1.number().int().nonnegative().optional(),languages:z$1.array(z$1.string()).optional()}),z$1.object({projects:z$1.array(Vi)}),Vi.pick({projectId:true,projectName:true,defaultBranch:true}),Ji=z$1.enum(["unresolved","resolved","archived"]),qi=z$1.enum(["succeeded","failed"]),Yi=z$1.enum(["full","incremental"]),$c=z$1.enum(["info","warn","error"]),Dc=z$1.object({type:z$1.string(),message:z$1.string(),phase:z$1.string(),filePath:z$1.string().optional(),stack:z$1.string().optional()}),Oc=z$1.object({type:z$1.string(),message:z$1.string(),phase:z$1.string(),filePath:z$1.string().optional()}),Xi=z$1.object({errors:z$1.array(Dc),warnings:z$1.array(Oc)}),Qi=z$1.object({level:$c,message:z$1.string(),timestamp:z$1.string().datetime()}),z$1.object({errorSummary:z$1.string().max(500),errorData:Xi,logEntries:z$1.array(Qi),cliVersion:z$1.string(),outcome:qi,indexType:Yi}),z$1.object({status:Ji.exclude(["archived"])}),z$1.object({id:z$1.string(),organizationId:z$1.string(),userId:z$1.string(),projectId:z$1.string(),branchName:z$1.string(),commitHash:z$1.string().nullable(),indexType:Yi,status:Ji,outcome:qi,errorSummary:z$1.string(),errorData:Xi,logEntries:z$1.array(Qi),cliVersion:z$1.string(),resolvedAt:z$1.string().nullable(),resolvedBy:z$1.string().nullable(),createdAt:z$1.string(),updatedAt:z$1.string(),organizationName:z$1.string().optional(),projectName:z$1.string().optional(),userEmail:z$1.string().optional(),resolvedByEmail:z$1.string().optional()}),z$1.object({unresolvedCount:z$1.number(),failedRunCount:z$1.number(),resolvedLast30d:z$1.number(),avgResolutionDays:z$1.number().nullable(),affectedOrgCount:z$1.number()}),Mc=["org-admin-v1","developer-v1","constellation-admin-v1"],Uc=z$1.enum(Mc),Gc=["eligible","completed","dismissed","ineligible"],Bc=z$1.enum(Gc),z$1.object({tourId:Uc,status:Bc,lastStepReached:z$1.string().max(64).optional()}),z$1.object({stepId:z$1.string().min(1).max(64)});});var mn,Tt=f(()=>{mn=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 fn(n){return n.length>rr&&(n[rr]=Zi),n}function eo(){let n=false,e=0;return new Transform({transform(t,r,o){if(n){o(null,t);return}if(e+t.length>rr){let s=rr-e;t[s]=Zi,n=true;}e+=t.length,o(null,t);}})}var rr,Zi,gn=f(()=>{rr=9,Zi=255;});function to(n){return base32.encode(Buffer.from(n))}var ro=f(()=>{});function no(n,e,t){let r=`${n}:${e}${t?`:${t}`:""}`;return to(r)}var io=f(()=>{ro();});var nr,oo=f(()=>{nr=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 ao(){return so.some(n=>!!process.env[n])}function lo(){return !!process.stdout.isTTY}function co(){let n=so.find(e=>!!process.env[e]);return n?Kc[n]:void 0}var so,Kc,hn=f(()=>{so=["GITHUB_ACTIONS","GITLAB_CI","JENKINS_URL","CIRCLECI","TRAVIS","BUILDKITE","DRONE","CI"],Kc={GITHUB_ACTIONS:"github-actions",GITLAB_CI:"gitlab",JENKINS_URL:"jenkins",CIRCLECI:"circleci",TRAVIS:"travis",BUILDKITE:"buildkite",DRONE:"drone",CI:"unknown"};});function Vc(n){switch(n){case "darwin":return "Macintosh";case "win32":return "Windows";case "linux":return "Linux";case "freebsd":return "FreeBSD";default:return n.charAt(0).toUpperCase()+n.slice(1)}}function Jc(n,e){return n==="darwin"?`Darwin ${e}`:e}function qc(){let n=globalThis.__constellationVersion;return typeof n=="string"&&n.length>0?n:"unknown"}function Yc(n={}){let e=n.platform??process.platform,t=n.arch??process.arch,r=(n.nodeVersion??process.version).replace(/^v/,""),o=n.osRelease??He.release(),s=qc(),a=Vc(e),l=Jc(e,o),c=`constellation-cli/${s} (${a}; ${l}; ${t}) Node/${r}`,u=co();return u&&(c+=` CI/${u}`),c}var Lt,uo=f(()=>{hn();Lt=Yc();});function ep(n){switch(n){case "PROJECT_NOT_REGISTERED":return "PROJECT_NOT_REGISTERED";case "PROJECT_INACTIVE":return "PROJECT_INACTIVE";case "INVALID_PROJECT_ID":return "INVALID_PROJECT_ID";default:return "PROJECT_VALIDATION_FAILED"}}var ir,or,H,Re,Se,je,Ne,bn=f(()=>{Nt();q();Tt();gn();io();oo();uo();ir=class n{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 Re("Project not found - no previous index exists");default:throw e.status===404?new Re("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 Re?t:e.status===404?new Re("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=dn.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 H)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 H("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=Wi.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 H("Authentication failed during index status polling");if(c.status===403||c.status===404)return !1;if(c.ok){let u=await c.json(),p=dn.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 H)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":Lt,"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=Gn.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":Lt,"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 H("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 H)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=no(this.config.projectId,this.config.branch,t);await this.delete(`/ast/${r}`);}}retryableStatusCodes=[500,502,503,504];static RETRYABLE_NETWORK_ERROR_CODES=new Set(["UND_ERR_SOCKET","UND_ERR_SOCKET_ERROR","UND_ERR_CONNECT_TIMEOUT","UND_ERR_HEADERS_TIMEOUT","UND_ERR_BODY_TIMEOUT","ECONNRESET","EPIPE","ETIMEDOUT","EAI_AGAIN"]);isRetryableNetworkError(e){if(!e||typeof e!="object")return false;let t=e,r=typeof t.code=="string"?t.code:typeof t.cause?.code=="string"?t.cause.code:void 0;return r?n.RETRYABLE_NETWORK_ERROR_CODES.has(r):false}shortNetworkErrorReason(e){if(!e||typeof e!="object")return String(e);let t=e,r=typeof t.cause?.code=="string"?t.cause.code:typeof t.code=="string"?t.code:void 0,o=typeof t.message=="string"&&t.message.length>0?t.message:"network error";return r?`${o} (${r})`:o}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 je(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 c=new nr(e),u=await buffer(c),p=process.env.CAPTURE_PAYLOAD_PATH;if(p)try{await pipeline(Readable.from(u),Gn.createGzip(),eo(),De.createWriteStream(p));}catch(g){this.reporter?.warn(`[constellation] capture tap failed: ${g instanceof Error?g.message:String(g)}`);}let d=[1e3,2e3,4e3],m;for(let g=0;g<=d.length;g++){let h=new Agent({headersTimeout:0,bodyTimeout:0});try{let b=await fetch$1(`${this.config.apiUrl}/${this.apiVersion}/${t}`,{method:"POST",headers:{"Content-Type":"application/x-ndjson; charset=utf-8","Content-Length":String(u.byteLength),"User-Agent":Lt,"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:u,dispatcher:h});if(b.status===401)throw new H("Authentication failed");if(b.status===409)throw await this.parseIndexingConflict(b);if(b.status===200)try{let S=await b.json();if(S?.status==="current")return this.reporter?.summary(`${x} Index already up to date for ${o} at commit ${S.commitHash||"unknown"}`),!0}catch{}if(b.ok||b.status===202)return !0;let y=`Server returned ${b.status}`;try{let S=await b.json();S?.message&&(y=Array.isArray(S.message)?S.message.join("; "):S.message);}catch{}throw new Error(y)}catch(b){if(b instanceof H||b instanceof je)throw b;if(this.isRetryableNetworkError(b)&&g<d.length){let y=Math.floor(Math.random()*250),S=d[g]+y;this.reporter?.warn(`Upload network error (attempt ${g+1}/${d.length+1}): ${this.shortNetworkErrorReason(b)} \u2014 retrying in ${S}ms`),m=b,await new Promise(E=>setTimeout(E,S));continue}throw b}finally{h.destroy().catch(()=>{});}}throw m??new Error("Upload failed after exhausting retry budget")}catch(c){if(c instanceof H||c instanceof je)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,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":Lt,Authorization:`Bearer ${this.accessKey}`},g=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),g.status===401)throw new H("Authentication failed");if(!g.ok&&this.retryableStatusCodes.includes(g.status))throw new or(`${g.statusText} (${g.status})`);return g}catch(d){if(p&&clearTimeout(p),!(d instanceof H)){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 or){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"},r=await this.sendRequest(e,void 0,"DELETE",t);if(r&&!r.ok)throw new Error(`Failed sending HTTP DELETE to ${e}`)}},or=class extends Error{constructor(e){super(e),this.name="RetryableError";}},H=class extends Error{errorCode="AUTH_FAILURE";constructor(e){super(e),this.name="AuthenticationError";}},Re=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",this.errorCode=ep(r);}errorCode};je=class extends Error{constructor(t,r){super(t);this.branchName=r;this.name="IndexingInProgressError";}errorCode="CONCURRENT_INDEXING"},Ne=class extends Error{constructor(t,r){super(t);this.errorCode=r;this.name="GitValidationError";}};});function F(n){return n.replace(/\\/g,"/")}function ar(n){return F(n).replace(/^\.?\//,"")}function Y(n,e){return F(k.relative(n,e))}var oe=f(()=>{});var Qe,wn=f(()=>{Qe=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(g=>({result:g!==null?g.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}}};});function np(n){if(!n)return false;let e=k.sep;return n.includes(`${e}obj${e}`)||n.includes(`${e}bin${e}`)||n.includes("/obj/")||n.includes("/bin/")}var ip,op,Ze,sp,lr,ho=f(()=>{oe();wn();ip={function:{hover:true,references:true,callHierarchy:true,implementation:false},method:{hover:true,references:true,callHierarchy:true,implementation:true},constructor:{hover:true,references:true,callHierarchy:true,implementation:false},class:{hover:false,references:true,callHierarchy:false,implementation:true},interface:{hover:false,references:true,callHierarchy:false,implementation:true},struct:{hover:false,references:true,callHierarchy:false,implementation:true},variable:{hover:true,references:true,callHierarchy:false,implementation:false},property:{hover:true,references:true,callHierarchy:false,implementation:false},import:{hover:true,references:false,callHierarchy:false,implementation:false}},op={hover:true,references:true,callHierarchy:false,implementation:false},Ze=1e4,sp=1200*1e3,lr=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,g])=>{let h=r.get(m);if(!h)return;let b=g.length,y=b>1e4?8:b>5e3?10:16,S=new Qe(y),E=()=>{p.add(m),d.has(h.serverId)||(d.add(h.serverId),c.lspProcessCrashes++,c.firstLspCrashLanguage||(c.firstLspCrashLanguage=m)),this.reporter?.warn(`[LSP:${m}] Process exited mid-enrichment (concurrency=${y}); halting subsequent ${m} files.`,{verboseOnly:true});},T=h.onCrash(E),w=0,P=S.run(g,async N=>{try{if(u||Date.now()-l>sp)return u=!0,null;if(p.has(m))return null;let I=await this.openFile(h,N,c,o?.get(N));if(!I)return null;let{uri:v}=I;try{let R=t.get(N)??[];if(R.length===0&&(R=await this.discoverSymbols(h,N,v,c),R.length===0))return c.filesNoSymbols++,null;let _=await this.enrichOpenFile(h,N,v,R,c);return _.length>0?{filePath:N,language:m,symbols:_}:null}finally{this.closeFile(h,v);}}finally{w++,s?.(m,w,b);}});try{for await(let N of P)N&&a.push(N);}finally{T();}})),u&&this.reporter?.info("Enrichment timeout reached. Uploading partial results."),this.logDiagnostics(c),a}async openFile(e,t,r,o){let s=k.resolve(this.projectRoot,t),a=pathToFileURL(s).href,l=o;if(l===void 0)try{l=await De.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=ip[s]||op,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,[g,h,b]=await Promise.allSettled([c.hover?e.sendRequest("textDocument/hover",p,Ze):null,c.references?e.sendRequest("textDocument/references",{...p,context:{includeDeclaration:false}},Ze):null,c.implementation?e.sendRequest("textDocument/implementation",p,Ze):null]);for(let y of [g,h])y.status==="rejected"&&o.queryRejections++;if(g.status==="fulfilled"&&g.value?.contents){let y=g.value.contents,S="";typeof y=="string"?S=y:Array.isArray(y)?S=y.map(E=>typeof E=="string"?E:E?.value??"").filter(Boolean).join(`
37
+ `):y&&typeof y=="object"&&(S=y.value||""),S&&(d.typeInfo={resolvedType:S},m=true);}if(h.status==="fulfilled"&&h.value){let y=h.value.filter(S=>{let E=this.uriToPath(S.uri||"");return !np(E)});if(y.length>0){let S=y.slice(0,100).map(E=>({filePath:Y(this.projectRoot,this.uriToPath(E.uri||"")),line:(E.range?.start?.line??0)+1,column:E.range?.start?.character??0}));d.references={count:y.length,locations:S},m=true;}}if(c.implementation&&b.status==="fulfilled"){let y=b.value,E=(Array.isArray(y)?y:y?[y]:[]).slice(0,200).map(T=>{let w=T.targetUri??T.uri??"",P=T.targetSelectionRange??T.targetRange??T.range??null;return {filePath:Y(this.projectRoot,this.uriToPath(w)),line:(P?.start?.line??0)+1,column:P?.start?.character??0}});d.implementations=E,E.length>0&&(m=true);}if(c.callHierarchy)try{let y=await e.sendRequest("textDocument/prepareCallHierarchy",p,Ze);if(y&&y.length>0){let S=y[0],[E,T]=await Promise.all([e.sendRequest("callHierarchy/incomingCalls",{item:S},Ze).catch(()=>[]),e.sendRequest("callHierarchy/outgoingCalls",{item:S},Ze).catch(()=>[])]),w=200,P=[];for(let I of E||[]){let v=Array.isArray(I.fromRanges)?I.fromRanges:[];if(v.length===0)continue;let R=Y(this.projectRoot,this.uriToPath(I.from?.uri||"")),_=I.from?.name||"";for(let O of v){if(P.length>=w)break;P.push({name:_,filePath:R,line:(O?.start?.line??0)+1,column:O?.start?.character??0});}if(P.length>=w)break}let N=[];for(let I of T||[]){let v=Array.isArray(I.fromRanges)?I.fromRanges:[];if(v.length===0)continue;let R=Y(this.projectRoot,this.uriToPath(I.to?.uri||"")),_=I.to?.name||"";for(let O of v){if(N.length>=w)break;N.push({name:_,filePath:R,line:(O?.start?.line??0)+1,column:O?.start?.character??0});}if(N.length>=w)break}(P.length>0||N.length>0)&&(d.callHierarchy={incomingCalls:P,outgoingCalls:N},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,t=null){let r=[],o={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"},s=new Set([null,2,3,5,6,9,10,11,12,23]),a=new Set([2,3,5,6,9,10,11,12,23,26]);for(let l of e){let c=o[l.kind]||"variable",u=l.selectionRange||l.range||l.location?.range,p=l.kind;u!=null&&(p!==void 0&&a.has(p)||s.has(t))&&r.push({name:l.name,line:(u.start?.line??0)+1,column:u.start?.character??0,kind:c,isExported:true}),l.children&&Array.isArray(l.children)&&r.push(...this.flattenDocumentSymbols(l.children,l.kind??null));}return r}uriToPath(e){try{return fileURLToPath(new URL(e))}catch{return e.replace(/^file:\/\//,"")}}getLanguageId(e){let t=k.extname(e).toLowerCase();return {".ts":"typescript",".tsx":"typescriptreact",".js":"javascript",".jsx":"javascriptreact",".py":"python",".pyi":"python",".cs":"csharp",".csx":"csharp"}[t]||"plaintext"}};});function yo(n){return n.map(e=>JSON.stringify(e)).join(`
37
38
  `)+`
38
- `}var Xi=g(()=>{});function he(i){try{return execFileSync(process.platform==="win32"?"where":"which",[i],{stdio:"ignore"}),!0}catch{return false}}var x,ce=g(()=>{x={async directoryExists(i){try{return (await Q__default.stat(i)).isDirectory()}catch{return false}},async fileIsReadable(i){try{return await Q__default.access(i,Q__default.constants.R_OK),!0}catch{return false}},async readFile(i,e="utf-8"){let t=await Q__default.readFile(i,{encoding:e,flag:Q__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 Q__default.writeFile(i,r,{encoding:t,flag:Q__default.constants.O_WRONLY|Q__default.constants.O_CREAT|Q__default.constants.O_TRUNC});},async getFileStats(i){return await Q__default.stat(i)},async getFileHandle(i,e,t){return await Q__default.open(i,e,t)}};});var er,Qi=g(()=>{er=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
+ `}var vo=f(()=>{});function ae(n){try{return execFileSync(process.platform==="win32"?"where":"which",[n],{stdio:"ignore"}),!0}catch{return false}}var C,le=f(()=>{C={async directoryExists(n){try{return (await se__default.stat(n)).isDirectory()}catch{return false}},async fileIsReadable(n){try{return await se__default.access(n,se__default.constants.R_OK),!0}catch{return false}},async readFile(n,e="utf-8"){let t=await se__default.readFile(n,{encoding:e,flag:se__default.constants.O_RDONLY});return t.charCodeAt(0)===65279&&(t=t.slice(1)),t},async writeFile(n,e,t="utf-8"){let r=Buffer.from(e,t);await se__default.writeFile(n,r,{encoding:t,flag:se__default.constants.O_WRONLY|se__default.constants.O_CREAT|se__default.constants.O_TRUNC});},async getFileStats(n){return await se__default.stat(n)},async getFileHandle(n,e,t){return await se__default.open(n,e,t)}};});var cr,bo=f(()=>{cr=class n{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
40
  \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
+ `);nextId=1;pendingRequests=new Map;notificationHandlers=new Map;pendingNotifications=new Set;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);}onNotification(e,t){if(this.disposed)return ()=>{};let r=this.notificationHandlers.get(e);return r||(r=new Set,this.notificationHandlers.set(e,r)),r.add(t),()=>{r.delete(t),r.size===0&&this.notificationHandlers.delete(e);}}waitForNotification(e,t){return this.disposed?Promise.reject(new Error("LspClient disposed")):new Promise((r,o)=>{let s,a={timer:setTimeout(()=>{this.pendingNotifications.delete(a),s?.(),o(new Error(`Timed out waiting for notification '${e}' after ${t}ms`));},t),reject:o};this.pendingNotifications.add(a),s=this.onNotification(e,l=>{clearTimeout(a.timer),this.pendingNotifications.delete(a),s?.(),r(l);});})}dispose(){this.disposed=true;for(let[,e]of this.pendingRequests)clearTimeout(e.timer),e.reject(new Error("LspClient disposed"));this.pendingRequests.clear();for(let e of this.pendingNotifications)clearTimeout(e.timer),e.reject(new Error("LspClient disposed"));this.pendingNotifications.clear(),this.notificationHandlers.clear(),this.stdout.removeAllListeners("data");}writeMessage(e){let t=JSON.stringify(e),o=`Content-Length: ${Buffer.byteLength(t,"utf-8")}\r
41
42
  \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 Ke,rr,_e,xt=g(()=>{Ke=R.join($e.homedir(),".constellation","lsp-servers"),rr=R.join(Ke,"node_modules",".bin"),_e=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"]}],["go",{command:"gopls",args:["serve"],npmPackages:[],testCommand:["version"],manualInstall:{requires:"Go (https://go.dev/dl/)",command:"go install golang.org/x/tools/gopls@latest",pathNote:"After install, ensure $GOPATH/bin (or ~/go/bin) is on your PATH.",autoInstall:{prerequisite:"go",argv:["go","install","golang.org/x/tools/gopls@latest"],env:{GOBIN:R.join(Ke,"bin")},installedBinaryPath:R.join(Ke,"bin",$e.platform()==="win32"?"gopls.exe":"gopls")}}}]]);});function eo(i){return i.replace(/\\/g,"/")}function _c(i){let e=eo(i);return R.posix.basename(e).toLowerCase().replace(/\.(exe|com|bat|cmd|ps1)$/i,"")}function to(i,e){if(!i||i.trim().length===0)return {classification:"denied",reason:"LSP command is empty"};let t=eo(i);if(Ec.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=_c(i);if(Cc.has(r))return {classification:"denied",reason:`LSP command resolves to a shell or interpreter ('${r}')`};for(let[,o]of _e)if(r===o.command.toLowerCase())return {classification:"known-safe"};return {classification:"custom-untrusted"}}var Cc,Ec,ro=g(()=>{xt();Cc=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())),Ec=/[;&|`$<>\n\r\0"']/;});function no(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 Pc(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 Ve,mn=g(()=>{Ve=class{constructor(e){this.trustFilePath=e;}async isTrusted(e,t,r){return (await this.load()).entries.some(s=>no(s,e,t,r))}async recordTrust(e,t,r){let o=await this.load();if(o.entries.some(l=>no(l,e,t,r)))return;o.entries.push({projectRoot:e,command:t,args:[...r],trustedAt:new Date().toISOString()}),await Q.mkdir(R.dirname(this.trustFilePath),{recursive:true});let a=`${this.trustFilePath}.${process.pid}.tmp`;try{await Q.writeFile(a,JSON.stringify(o,null,2)+`
44
- `,"utf-8"),await Q.rename(a,this.trustFilePath);}catch(l){throw await Q.rm(a,{force:true}).catch(()=>{}),l}}async load(){try{let e=await Q.readFile(this.trustFilePath,"utf-8"),t=JSON.parse(e);return t&&typeof t=="object"&&Array.isArray(t.entries)?{entries:t.entries.filter(Pc)}:{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 nr,oo=g(()=>{ro();mn();nr=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??Ve.isCIEnvironment;}async authorize(e,t,r){let{classification:o,reason:s}=to(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?
43
+ `;this.stdin.write(o+t);}handleData(e){for(this.buffer=Buffer.concat([this.buffer,e]);;){let t=this.buffer.indexOf(n.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.handleMessage(c);}catch{this.loggedMalformedJson||(this.loggedMalformedJson=true,this.reporter?.error("[LSP] Received malformed JSON from language server",{verboseOnly:true}));}}}handleMessage(e){"id"in e&&e.id!==void 0&&e.id!==null?this.handleResponse(e):"method"in e&&this.handleNotification(e);}handleResponse(e){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));}handleNotification(e){let t=this.notificationHandlers.get(e.method);if(t)for(let r of t)try{let o=r(e.params);o&&typeof o.catch=="function"&&o.catch(()=>{});}catch{}}};});function _n(n){return n.includes("roslyn-language-server")}var tt,rt,Te,nt=f(()=>{tt=k.join(He.homedir(),".constellation","lsp-servers"),rt=k.join(tt,"node_modules",".bin"),Te=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"]}],["c-sharp",{command:"roslyn-language-server",args:["--stdio","--autoLoadProjects"],npmPackages:[],testCommand:["--version"],manualInstall:{requires:".NET 10 SDK or later (https://dotnet.microsoft.com/download)",command:"dotnet tool install --global roslyn-language-server --prerelease",pathNote:He.platform()==="win32"?"After install, ensure %USERPROFILE%\\.dotnet\\tools is on your PATH.":"After install, ensure ~/.dotnet/tools is on your PATH.",verifyToolchain:{command:"dotnet",versionArgs:["--version"],minVersion:"10.0"}}}],["go",{command:"gopls",args:["serve"],npmPackages:[],testCommand:["version"],manualInstall:{requires:"Go (https://go.dev/dl/)",command:"go install golang.org/x/tools/gopls@latest",pathNote:"After install, ensure $GOPATH/bin (or ~/go/bin) is on your PATH.",autoInstall:{prerequisite:"go",argv:["go","install","golang.org/x/tools/gopls@latest"],env:{GOBIN:k.join(tt,"bin")},installedBinaryPath:k.join(tt,"bin",He.platform()==="win32"?"gopls.exe":"gopls")}}}]]);});function Cn(n){let e=He.homedir();if(!e)return null;let t=process.platform==="win32"?`${n}.exe`:n,r=k.join(e,".dotnet","tools",t);try{let o=realpathSync(r),s=k.resolve(e);return o!==s&&!o.startsWith(s+k.sep)?null:o}catch{return null}}function En(n){if(ae(n.command))return n.command;let e=k.join(rt,n.command);return existsSync(e)?e:Cn(n.command)}function So(n){let e=/(\d+)(?:\.(\d+))?/.exec(n);return e?[Number(e[1]),e[2]?Number(e[2]):0]:null}function mp(n,e){let t=So(e);if(!t)return true;let r=So(n);return r?r[0]!==t[0]?r[0]>t[0]:r[1]>=t[1]:true}function _o(n){let e;try{e=execFileSync(n.command,[...n.versionArgs],{stdio:["ignore","pipe","pipe"],timeout:pp,maxBuffer:up,cwd:He.homedir()||void 0}).toString();}catch{return {ok:false,reason:"missing"}}let t=e.trim().split(/\r?\n/)[0]?.trim()??"";return n.minVersion&&!mp(t,n.minVersion)?{ok:false,reason:"too-old",detected:t||"unknown",required:n.minVersion}:{ok:true,version:t}}function xo(n){let e=n.manualInstall?.command;if(!e)return {ok:false,spawnError:"no manualInstall.command configured"};let[t,...r]=e.split(/\s+/).filter(Boolean);if(!t)return {ok:false,spawnError:"empty manualInstall.command"};try{return execFileSync(t,r,{stdio:"pipe",timeout:dp}),{ok:!0}}catch(o){let s=o,a=s.stderr?.toString().trim()??"";return typeof s.status=="number"||s.signal?{ok:false,exitCode:s.status??null,stderr:a}:{ok:false,spawnError:s.message??String(o)}}}var pp,up,dp,Pn=f(()=>{le();nt();pp=5e3,up=4096,dp=300*1e3;});function Eo(n){return n.replace(/\\/g,"/")}function hp(n){let e=Eo(n);return k.posix.basename(e).toLowerCase().replace(/\.(exe|com|bat|cmd|ps1)$/i,"")}function Po(n,e){if(!n||n.trim().length===0)return {classification:"denied",reason:"LSP command is empty"};let t=Eo(n);if(gp.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(`
44
+ `)||o.includes("\r"))return {classification:"denied",reason:"LSP argument contains newline/carriage-return"}}let r=hp(n);if(fp.has(r))return {classification:"denied",reason:`LSP command resolves to a shell or interpreter ('${r}')`};for(let[,o]of Te)if(r===o.command.toLowerCase())return {classification:"known-safe"};return {classification:"custom-untrusted"}}var fp,gp,Io=f(()=>{nt();fp=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(n=>n.toLowerCase())),gp=/[;&|`$<>\n\r\0"']/;});function Ro(n,e,t,r){return n.projectRoot===e&&n.command===t&&n.args.length===r.length&&n.args.every((o,s)=>o===r[s])}function yp(n){if(!n||typeof n!="object")return false;let e=n;return typeof e.projectRoot=="string"&&typeof e.command=="string"&&Array.isArray(e.args)&&e.args.every(t=>typeof t=="string")}var it,In=f(()=>{it=class{constructor(e){this.trustFilePath=e;}async isTrusted(e,t,r){return (await this.load()).entries.some(s=>Ro(s,e,t,r))}async recordTrust(e,t,r){let o=await this.load();if(o.entries.some(l=>Ro(l,e,t,r)))return;o.entries.push({projectRoot:e,command:t,args:[...r],trustedAt:new Date().toISOString()}),await se.mkdir(k.dirname(this.trustFilePath),{recursive:true});let a=`${this.trustFilePath}.${process.pid}.tmp`;try{await se.writeFile(a,JSON.stringify(o,null,2)+`
45
+ `,"utf-8"),await se.rename(a,this.trustFilePath);}catch(l){throw await se.rm(a,{force:true}).catch(()=>{}),l}}async load(){try{let e=await se.readFile(this.trustFilePath,"utf-8"),t=JSON.parse(e);return t&&typeof t=="object"&&Array.isArray(t.entries)?{entries:t.entries.filter(yp)}:{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 pr,To=f(()=>{Io();In();pr=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??it.isCIEnvironment;}async authorize(e,t,r){let{classification:o,reason:s}=Po(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
46
  ${t}${a}
46
47
 
47
48
  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,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 Tc,Lc,ir,ao=g(()=>{ce();Qi();xt();oo();mn();Tc={log:i=>process.stderr.write(i+`
49
- `),warn:i=>process.stderr.write(i+`
50
- `),error:i=>process.stderr.write(i+`
51
- `)},Lc=R.join($e.homedir(),".constellation","lsp-trust.json"),ir=class{constructor(e,t,r){this.projectRoot=e;this.logger=t??Tc,this.policy=r??this.buildDefaultPolicy();}serversByKey=new Map;languageToServerKey=new Map;unavailableLanguages=new Set;unavailableServerKeys=new Set;nextId=1;logger;policy;buildDefaultPolicy(){return new nr({projectRoot:this.projectRoot,logger:this.logger,trustStore:new Ve(Lc),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 p=this.serversByKey.get(c);if(p)return p.languages.add(e),this.languageToServerKey.set(e,c),this.toConnection(p,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((S,v)=>{d.once("spawn",S),d.once("error",v);}),d.stderr?.on("data",S=>{let v=S.toString().trim();v.toLowerCase().includes("error")&&this.logger.warn(`[LSP:${e}] ${v}`);});let m=new er(d.stdin,d.stdout,12e4),f=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,crashHandlers:new Set,intentionalShutdown:!1};return this.serversByKey.set(c,h),this.languageToServerKey.set(e,c),d.on("exit",(S,v)=>{let y=this.serversByKey.get(c);if(y){if(y.intentionalShutdown)y.crashHandlers.clear();else {let C=[...y.crashHandlers];y.crashHandlers.clear();for(let P of C)try{P();}catch(b){this.logger.warn(`[LSP:${y.language}] crash handler threw: ${b instanceof Error?b.message:String(b)}`);}this.logUnexpectedExit(e,S,v);}y.client.dispose(),this.serversByKey.delete(c);for(let[C,P]of this.languageToServerKey.entries())P===c&&this.languageToServerKey.delete(C);}}),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)}`,f=d?.code;return f==="ENOENT"||f==="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=_e.get(e);if(!r)return null;let o=R.join(rr,r.command);return existsSync(o)?{command:o,args:r.args}:he(r.command)?{command:r.command,args:r.args}:null}getServerKey(e,t){return `${e}\0${t.join("\0")}`}logUnexpectedExit(e,t,r){if(t!==null&&t!==0){this.logger.warn(`[LSP:${e}] Server exited unexpectedly with code ${t}`);return}if(t===0)return;if(r==="SIGKILL"){this.logger.warn(`[LSP:${e}] Server killed by SIGKILL (possibly OOM-killed \u2014 check \`dmesg | tail\` or system memory pressure)`);return}if(r!==null){this.logger.warn(`[LSP:${e}] Server exited unexpectedly via signal ${r}`);return}let o=process.platform==="win32"?"external termination (e.g. Task Manager / taskkill)":"unknown cause (no exit code or signal reported)";this.logger.warn(`[LSP:${e}] Server exited unexpectedly \u2014 ${o}`);}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 ue,Ct=g(()=>{ue=class{getBuildConfigManager(e,t){return null}getImportResolver(e,t){return null}preflightLsp(e){return Promise.resolve({skip:false})}};});var Je,fn=g(()=>{z();Je=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(`${M} 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(`${M} Failed to parse ${r}: ${o}`),console.warn(`${M} Path alias resolution will be skipped for files using this config`);}else r||console.warn(`${M} Failed to parse config for ${e}:`,t instanceof Error?t.message:t);}};});var or,co=g(()=>{fe();or=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?R.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=R.resolve(r,a),c=await this.findEntryPoint(l);c&&(e[o]=c);}return e}async loadFromPackageJsonWorkspaces(){let e={};try{let t=R.join(this.projectRoot,"package.json"),r=await Q.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 p of c){let u=await this.loadWorkspacePackage(p);u&&Object.assign(e,u);}}}catch{}return e}async findWorkspaceDirs(e){let t=[];if(e.endsWith("/*")){let r=e.slice(0,-2),o=R.join(this.projectRoot,r);try{let s=await Q.readdir(o,{withFileTypes:!0});for(let a of s)a.isDirectory()&&t.push(R.join(o,a.name));}catch{}}else {let r=R.join(this.projectRoot,e);try{(await Q.stat(r)).isDirectory()&&t.push(r);}catch{}}return t}async loadWorkspacePackage(e){try{let t=R.join(e,"package.json"),r=await Q.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 R.join(e,o);if(typeof o=="object"){let s=o["."]||o["./index"];if(typeof s=="string")return R.join(e,s);if(typeof s=="object"){let a=s.import||s.default||s.require;if(a)return R.join(e,a)}}}if(t.main)return R.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=R.join(e,o);try{if((await Q.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=R.join(e,r);try{if((await Q.stat(o)).isFile())return o}catch{}}try{if((await Q.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")?R.dirname(e):R.dirname(e),o=[R.join(r,t+".ts"),R.join(r,t+".tsx"),R.join(r,t+".js"),R.join(r,t+".jsx"),R.join(r,t+".d.ts"),R.join(r,t,"index.ts"),R.join(r,t,"index.tsx"),R.join(r,t,"index.js"),R.join(r,t,"index.jsx")];for(let s of o)try{if((await Q.stat(s)).isFile())return s}catch{}return null}toProjectRelative(e){let t=V(this.projectRoot,e);return t.startsWith("./")?t:`./${t}`}};});var qe,hn=g(()=>{fe();co();qe=class{baseUrl=null;paths={};sourceDir;tsconfigDir;projectRoot;extensions;packageImports={};packageJsonDir=null;sourceFilePath;workspaceResolver;constructor(e,t){this.sourceFilePath=e,this.sourceDir=R.dirname(e),this.projectRoot=process.cwd(),this.workspaceResolver=new or(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=R.dirname(t.tsconfigFile);let a=t.tsconfig?.compilerOptions;a&&(a.baseUrl&&(this.baseUrl=R.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=R.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=V(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=R.resolve(this.tsconfigDir,s);return await this.findFileWithExtensions(a)}async resolveWithBaseUrl(e){if(!this.baseUrl)return null;let t=R.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=R.join(s,`index${a}`);if(await this.fileExists(l))return await this.resolveSymlink(l)}return null}async fileExists(e){try{return (await Q.stat(e)).isFile()}catch{return false}}async resolveSymlink(e){try{return await Q.realpath(e)}catch{return e}}async findPackageJson(e){let t=e;for(;t.startsWith(this.projectRoot);){let r=R.join(t,"package.json");try{if((await Q.stat(r)).isFile())return r}catch{}let o=R.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 Q.readFile(e,"utf-8"),r=JSON.parse(t);this.packageJsonDir=R.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=R.resolve(this.packageJsonDir,r);return await this.findFileWithExtensions(o)}};});var sr,po=g(()=>{Ct();fn();hn();sr=class extends ue{language="typescript";extensions=[".ts",".tsx",".d.ts"];getBuildConfigManager(e,t){return new Je(e,t)}getImportResolver(e,t){return new qe(e,t)}};});var ar,uo=g(()=>{Ct();fn();hn();ar=class extends ue{language="javascript";extensions=[".js",".jsx",".mjs",".cjs"];getBuildConfigManager(e,t){return new Je(e,t)}getImportResolver(e,t){return new qe(e,t)}};});async function ee(i,e,t,r,o,s=[]){let a=await t.resolve(i),l=mo(i,a),c=o(i,a,l),p=l?void 0:Yt(a);r[e.toString()]={source:i,resolvedPath:p,isExternal:l,importType:c,specifiers:s};}function mo(i,e){return i===e?true:!(!e.startsWith(".")&&!e.startsWith("/")||e.startsWith("./")||e.startsWith("../"))}var yn,Ye=g(()=>{fe();yn=(i,e,t)=>t?i.startsWith("node:")?"builtin":"external":i.startsWith("./")||i.startsWith("../")?"relative":i.startsWith("@")?"workspace":"alias";});async function Fc(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 ee(s,i.startPosition.row,e,t,r,[a]);}function $c(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 Dc(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 p=i.child(c);if(p){if(p.type==="relative_import"){l=p.text;break}(p.type==="."||p.type==="import_prefix")&&(l+=p.text);}}o=l||".";}let a=$c(i,!!s);await ee(o,i.startPosition.row,e,t,r,a);}async function Oc(i,e,t,r){await ee("__future__",i.startPosition.row,e,t,r,[]);}function vn(){return {language:"python",handlers:new Map([["import_statement",Fc],["import_from_statement",Dc],["future_import_statement",Oc]]),classifyImportType:Ac}}var Ac,lr=g(()=>{vt();Ye();vt();Ac=(i,e,t)=>{if(t)return "external";if(/^\.+/.test(i))return "relative";let r=i.split(".")[0];return ht.has(r)?"builtin":"alias"};});var cr,go=g(()=>{lr();cr=class{sourceDir;projectRoot;constructor(e,t){this.sourceDir=R.dirname(e),this.projectRoot=t;}async resolve(e){let t=e.split(".")[0];if(ht.has(t))return e;if(e.startsWith("."))return this.resolveRelative(e);let r=e.replace(/\./g,"/"),o=await this.tryResolveFile(R.resolve(this.projectRoot,r));return o?R.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=R.resolve(this.sourceDir,s),l=await this.tryResolveFile(a);return l?R.relative(this.projectRoot,l).replace(/\\/g,"/"):e}async tryResolveFile(e){let t=[`${e}.py`,`${e}.pyi`,`${e}.pyw`,R.join(e,"__init__.py"),R.join(e,"__init__.pyi")];for(let r of t)try{return await Le.promises.access(r,Le.constants.F_OK),r}catch{continue}return null}};});var ur,fo=g(()=>{Ct();go();ur=class extends ue{language="python";extensions=[".py",".pyi",".pyw"];getBuildConfigManager(e,t){return null}getImportResolver(e,t){return new cr(e,process.cwd())}};});function ho(i){return i.replace(/\/\/[^\n]*/g,"")}function Xe(i){return i.startsWith('"')&&i.endsWith('"')||i.startsWith("'")&&i.endsWith("'")?i.slice(1,-1):i}function Mc(i,e){let t=[],r=/^\s*replace\s*\(\s*([\s\S]*?)\)/gm,o=[];for(let l of i.matchAll(r))o.push(l[1]);let s=i.replace(r,l=>" ".repeat(l.length)),a=/^\s*replace\s+(?!\()(.+?)\s*$/gm;for(let l of s.matchAll(a))o.push(l[1]);for(let l of o)for(let c of l.split(`
52
- `)){let p=c.trim();if(!p)continue;let u=Uc(p,e);u&&t.push(u);}return t}function Uc(i,e){let t=i.indexOf("=>");if(t===-1)return null;let r=i.slice(0,t).trim().split(/\s+/).filter(Boolean),o=i.slice(t+2).trim().split(/\s+/).filter(Boolean);if(r.length===0||o.length===0)return null;let s=Xe(r[0]),a=r.length>=2?Xe(r[1]):void 0,l=Xe(o[0]);if(!Gc(l))return null;let c=R.isAbsolute(l)?l:R.resolve(e,l);return {originalModulePath:s,originalVersion:a,localDir:c}}function Gc(i){return i==="."||i===".."||i.startsWith("./")||i.startsWith("../")||R.isAbsolute(i)}var ke,yo=g(()=>{fe();ke=class i{constructor(e,t=true){this.projectRoot=e;this.enabled=t;}cache=new Map;discovered=[];initialized=false;goWorkPath=null;warnings=[];isEnabled(){return this.enabled}clearCache(){this.cache.clear(),this.discovered=[],this.initialized=false,this.goWorkPath=null,this.warnings=[];}consumeWarnings(){let e=this.warnings;return this.warnings=[],e}async initialize(){if(this.initialized)return this.configFilesPaths();if(this.goWorkPath=i.findGoWorkAncestor(this.projectRoot),this.goWorkPath!==null){let e=await this.parseGoWork(this.goWorkPath),t=await Promise.all(e.map(async r=>{let o=R.join(r,"go.mod"),s=await this.parseGoMod(o);return {useDir:r,modPath:o,info:s}}));for(let{useDir:r,modPath:o,info:s}of t)s?(this.discovered.push(s),this.cache.set(K(s.rootDir),s)):this.warnings.push(`go.work: use directive ${K(r)} has no parseable go.mod at ${K(o)}`);}else {let e=await this.findGoModFiles(this.projectRoot,0,6),t=await Promise.all(e.map(r=>this.parseGoMod(r)));for(let r of t)r&&(this.discovered.push(r),this.cache.set(K(r.rootDir),r));}return this.initialized=true,this.configFilesPaths()}configFilesPaths(){let e=this.discovered.map(t=>K(R.join(t.rootDir,"go.mod")));return this.goWorkPath!==null&&e.unshift(K(this.goWorkPath)),e}async getConfigForFile(e){this.initialized||await this.initialize();let t=R.isAbsolute(e)?e:R.resolve(this.projectRoot,e),r=this.goWorkPath!==null?R.dirname(this.goWorkPath):this.projectRoot,o=R.dirname(t);for(;;){let s=this.cache.get(K(o));if(s!==void 0)return s;let a=R.dirname(o),l=o===r||o.startsWith(r+R.sep);if(a===o||!l)return null;o=a;}}getAllModules(){return this.discovered}static hasGoModAncestor(e){let t=R.resolve(e);for(;;){if(Le.existsSync(R.join(t,"go.mod")))return true;let r=R.dirname(t);if(r===t)return false;t=r;}}static findGoWorkAncestor(e){let t=R.resolve(e);for(;;){let r=R.join(t,"go.work");if(Le.existsSync(r))return r;let o=R.dirname(t);if(o===t)return null;t=o;}}async findGoModFiles(e,t,r){if(t>r)return [];let o=[],s;try{s=await Le.promises.readdir(e,{withFileTypes:!0});}catch{return o}for(let a of s){if(a.name==="node_modules"||a.name==="vendor"||a.name.startsWith("."))continue;let l=R.join(e,a.name);if(a.isFile()&&a.name==="go.mod")o.push(l);else if(a.isDirectory()){let c=await this.findGoModFiles(l,t+1,r);o.push(...c);}}return o}async parseGoWork(e){let t;try{t=await Le.promises.readFile(e,"utf8");}catch{return []}let r=R.dirname(e),o=[],s=ho(t),a=/^\s*use\s*\(\s*([\s\S]*?)\)/gm;for(let p of s.matchAll(a))for(let u of p[1].split(`
53
- `)){let d=Xe(u.trim());d&&o.push(R.resolve(r,d));}let l=s.replace(a,p=>" ".repeat(p.length)),c=/^\s*use\s+(?!\()(\S.*?)\s*$/gm;for(let p of l.matchAll(c)){let u=Xe(p[1].trim());u&&o.push(R.resolve(r,u));}return o}async parseGoMod(e){let t;try{t=await Le.promises.readFile(e,"utf8");}catch{return null}let r=ho(t),o=r.match(/^\s*module\s+(\S+)\s*$/m);if(!o)return null;let s=r.match(/^\s*go\s+(\d+\.\d+(?:\.\d+)?)\s*$/m),a=R.dirname(e);return {modulePath:Xe(o[1]),goVersion:s?.[1],rootDir:a,replaces:Mc(r,a)}}};});function Bc(i){let e=i.trim();return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}var mr,dr,gr=g(()=>{fe();mr=new Set(["archive","bufio","builtin","bytes","cmp","compress","container","context","crypto","database","debug","embed","encoding","errors","expvar","flag","fmt","go","hash","html","image","index","io","iter","log","maps","math","mime","net","os","path","plugin","reflect","regexp","runtime","slices","sort","strconv","strings","sync","syscall","testing","text","time","unicode","unique","unsafe"]),dr=class{constructor(e,t,r=[]){this.sourceFilePath=e;this.projectRoot=t;this.modules=r;}async resolve(e){let t=Bc(e);if(!t)return e;let r=t.split("/")[0];if(!r.includes(".")&&mr.has(r))return t;let o=this.findReplaceForSpecifier(t);if(o){let a=t.slice(o.originalModulePath.length),l=R.join(o.localDir,a.startsWith("/")?a.slice(1):a);if(await this.directoryHasGoFiles(l))return K(R.relative(this.projectRoot,l))}let s=this.findModuleForSpecifier(t);if(s){let a=t.slice(s.modulePath.length),l=R.join(s.rootDir,a.startsWith("/")?a.slice(1):a);if(await this.directoryHasGoFiles(l))return K(R.relative(this.projectRoot,l))}return t}findModuleForSpecifier(e){let t;for(let r of this.modules)(e===r.modulePath||e.startsWith(r.modulePath+"/"))&&(!t||r.modulePath.length>t.modulePath.length)&&(t=r);return t}findReplaceForSpecifier(e){let t;for(let r of this.modules)for(let o of r.replaces)(e===o.originalModulePath||e.startsWith(o.originalModulePath+"/"))&&(!t||o.originalModulePath.length>t.originalModulePath.length)&&(t=o);return t}async directoryHasGoFiles(e){try{return (await Le.promises.readdir(e,{withFileTypes:!0})).some(r=>r.isFile()&&r.name.endsWith(".go")&&!r.name.endsWith("_test.go"))}catch{return false}}};});var fr,bo=g(()=>{Ct();yo();gr();fr=class extends ue{language="go";extensions=[".go"];manager=null;getBuildConfigManager(e,t){return this.manager=new ke(e),this.manager}getImportResolver(e,t){let r;if(Array.isArray(t))r=t;else {let o=this.manager?.getAllModules()??[];o.length>0?r=o:t?r=[t]:r=[];}return new dr(e,process.cwd(),r)}async preflightLsp(e){return this.manager??=new ke(e),await this.manager.initialize(),this.manager.getAllModules().length>0?{skip:false}:ke.hasGoModAncestor(e)?{skip:false}:ke.findGoWorkAncestor(e)!==null?{skip:false}:{skip:true,message:"No go.mod found within the project tree or any ancestor directory \u2014 Go files will be indexed without cross-file reference and interface edges. Run `go mod init <module-path>` in your project root (e.g. `go mod init github.com/your-org/your-repo`) to enable LSP enrichment for Go."}}};});function Pe(i){return Vc[i]??i.charAt(0).toUpperCase()+i.slice(1)}var Vc,Ze,hr,yr=g(()=>{po();uo();fo();bo();Vc={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"};Ze={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"]},hr=class{constructor(e){this.config=e;this.registerPlugin(new sr),this.registerPlugin(new ar),this.registerPlugin(new ur),this.registerPlugin(new fr);}plugins=new Map;registerPlugin(e){this.plugins.set(e.language,e);}getPlugin(e){return this.plugins.get(e)}javascript={language:()=>Hc,fileExtensions:()=>this.config?.languages.javascript?.fileExtensions??Ze.javascript};typescript={language:()=>Kc.typescript,fileExtensions:()=>this.config?.languages.typescript?.fileExtensions??Ze.typescript};python={language:()=>zc,fileExtensions:()=>this.config?.languages.python?.fileExtensions??Ze.python};php;json;java;go={language:()=>Wc,fileExtensions:()=>this.config?.languages.go?.fileExtensions??Ze.go};cpp;"c-sharp";c;bash;ruby};});function et(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 vr,bn=g(()=>{vr=Object.freeze(new Set(["program","statement_block","function_declaration","function_expression","generator_function_declaration","generator_function","arrow_function","method_definition","class_body"]));});function Sn(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&&Jc(t,e);}for(let t of i.namedChildren)t&&Sn(t,e);}function Jc(i,e){if(i.type==="identifier"||i.type==="type_identifier"){e.set(je(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(je(t.startPosition.row,t.startPosition.column),"call");}}var So=g(()=>{Et();});function tt(i,e){i.rootNode&&(xo(i.rootNode,e),Sn(i.rootNode,e));}function xo(i,e){if(qc.has(i.type)){let t=Yc(i);t!==null&&e.set(je(i.startPosition.row,i.startPosition.column),t);}for(let t of i.namedChildren)t&&xo(t,e);}function Yc(i){if(Qc(i))return "declaration";if(lp(i))return "read";if(sp(i))return "type";let e=et(i,t=>t.type==="decorator");return e!==null&&tp(i,e)?"call":ep(i)?"instantiate":Zc(i)?"call":rp(i)||np(i)||ip(i)||hp(i)||fp(i)?"write":cp(i)?"import-use":"read"}function Qc(i){let e=i.parent;return e===null?false:!!(Xc.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 Zc(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 ep(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 tp(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 rp(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||vr.has(t.type))return false;e=t;}return false}function np(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 ip(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||vr.has(t.type))return false;e=t;}return false}function sp(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||ap(r,i)}if(op.has(e.type))return true;if(vr.has(e.type))return false;t=e,e=e.parent;}return false}function ap(i,e){let t=e;for(;t!==null;){if(t===i)return true;t=t.parent;}return false}function lp(i){return et(i,t=>t.type==="type_query")!==null}function cp(i){let e=i.parent;if(e?.type!=="member_expression"||e.childForFieldName("object")!==i)return false;let t=i.text,r=mp(i);return gp(r,t)?!up(i,t):false}function up(i,e){let t=i.parent;for(;t!==null;){if(pp.has(t.type)&&dp(t,e))return true;t=t.parent;}return false}function dp(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 mp(i){let e=i;for(;e.parent!==null;)e=e.parent;return e}function gp(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 fp(i){let e=i.parent;return e?.type==="for_in_statement"&&e.childForFieldName("left")===i}function hp(i){let e=i.parent;if(e===null||!wo.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(!wo.has(r.type))return false;t=r;}return false}var qc,Xc,op,pp,wo,br=g(()=>{Et();bn();So();qc=Object.freeze(new Set(["identifier","type_identifier","property_identifier","private_property_identifier","shorthand_property_identifier","shorthand_property_identifier_pattern"]));Xc=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"]));op=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"]));pp=Object.freeze(new Set(["statement_block","function_declaration","function_expression","arrow_function","method_definition","generator_function","generator_function_declaration","for_statement","for_in_statement"]));wo=Object.freeze(new Set(["object_pattern","array_pattern","pair_pattern","rest_pattern","object_assignment_pattern","assignment_pattern"]));});function Co(i,e){tt(i,e);}var Eo=g(()=>{br();});function _o(i,e){tt(i,e);}var Po=g(()=>{br();});function Io(i,e){if(!i.rootNode)return;let t=Dp(i.rootNode);Ro(i.rootNode,e,t);}function Ro(i,e,t){if(yp.has(i.type)){let r=vp(i,t);r!==null&&e.set(je(i.startPosition.row,i.startPosition.column),r);}for(let r of i.namedChildren)r&&Ro(r,e,t);}function vp(i,e){if(bp(i))return "declaration";if(xp(i))return "read";if(wp(i))return "declaration";if(Cp(i))return "type";let t=et(i,r=>r.type==="decorator");return t!==null&&Ep(i,t)||_p(i)?"call":Pp(i)||Ip(i)||Rp(i)||Tp(i)||kp(i)?"write":jp(i,e)?"import-use":"read"}function bp(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"||Sp(i))}function Sp(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 wp(i){let e=i.parent;for(;e!==null;){if(e.type==="import_statement"||e.type==="import_from_statement")return true;if(wn.has(e.type))return false;e=e.parent;}return false}function xp(i){let e=i.parent;return e?.type==="global_statement"||e?.type==="nonlocal_statement"}function Cp(i){return et(i,t=>t.type==="type")!==null}function Ep(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 _p(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 Pp(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||wn.has(t.type))return false;e=t;}return false}function Ip(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 Rp(i){let e=i.parent;return e?.type==="named_expression"&&e.childForFieldName("name")===i}function Tp(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(Np.has(t.type)){e=t;continue}if(wn.has(t.type))return false;e=t;}return false}function kp(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(!Lp.has(t.type))return false;e=t;}return false}function jp(i,e){let t=i.parent;if(t?.type!=="attribute"||t.childForFieldName("object")!==i)return false;let r=i.text;return e.has(r)?!Fp(i,r):false}function Fp(i,e){let t=i.parent;for(;t!==null;){if(Ap.has(t.type)&&$p(t,e))return true;t=t.parent;}return false}function $p(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 Dp(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 yp,wn,Np,Lp,Ap,No=g(()=>{Et();bn();yp=Object.freeze(new Set(["identifier"])),wn=Object.freeze(new Set(["module","block","function_definition","class_definition","lambda"]));Np=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern","list_splat_pattern"]));Lp=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern"]));Ap=Object.freeze(new Set(["block","function_definition","class_definition","lambda"]));});function Lo(i,e){let t=new Map;switch(e){case "typescript":tt(i,t);break;case "tsx":Co(i,t);break;case "javascript":_o(i,t);break;case "python":Io(i,t);break}return t}function je(i,e){return `${i}:${e}`}var To,Et=g(()=>{br();Eo();Po();No();To=Object.freeze(new Set(["typescript","javascript","python"]));});function Up(i,e){return To.has(i)?i==="typescript"?e.toLowerCase().endsWith(".tsx")?"tsx":"typescript":i:null}function Gp(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 Sr,Ao=g(()=>{Et();ce();Sr=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=Kc.tsx);let s=new Op;s.setLanguage(o);let a=await x.getFileStats(e),l=25*1024*1024,c,p;if(a.size<=l){let f=await x.readFile(e);p=f;let h={bufferSize:1024*1024};c=s.parse(f,void 0,h);}else c=await this.parseWithStream(s,e,a.size);let u=Up(t,e),d=u===null?[]:Gp(Lo(c,u));return {tree:c,classificationMap:{filePath:e,entries:d},content:p}}async parseWithStream(e,t,r){let o=null;try{o=await Q.open(t,"r");let s=o.fd,a=64*1024,l=Buffer.alloc(a),c=0;return e.parse(u=>{if(r>50*1024*1024){let m=Math.round(u/r*100);m>c+10&&(process.stderr.write(` Parsing large file: ${m}%...
54
- `),c=m);}let d=Le.readSync(s,l,0,a,u);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)}
55
- `);}throw s}finally{if(o)try{await o.close();}catch{}}}};});var wr,$o=g(()=>{ce();fe();z();wr=class{rootPath;constructor(e){this.rootPath=e||process.cwd();}async scanFiles(e){let t=Fo();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=Fo().add(t.exclude));let s=await Q__default.realpath(this.rootPath);for(let a of e)try{let l=R__default.isAbsolute(a)?a:R__default.join(this.rootPath,a),c=await Q__default.lstat(l);if(c.isSymbolicLink()){let p=await Q__default.realpath(l);if(!p.startsWith(s+R__default.sep)&&p!==s){console.warn(`${M} Skipping symlink pointing outside project: ${a} -> ${p}`);continue}let u=await Q__default.stat(l);if(!u.isFile())continue;let d=V(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:u.size});}else if(c.isFile()){let p=V(this.rootPath,l);if(o&&o.ignores(p))continue;let u=this.detectLanguage(p,t.languages);if(!u)continue;r.push({path:l,relativePath:p,language:u,size:c.size});}}catch{console.warn(`${M} Skipping inaccessible file: ${a}`);}return r}async loadGitignoreRules(e,t){let r=[],o=t;for(;;){let s=R__default.join(o,".gitignore");await x.fileIsReadable(s)&&r.unshift(s);let a=R__default.dirname(o);if(a===o)break;o=a;let l=R__default.join(o,".git");if(await x.directoryExists(l)){let c=R__default.join(o,".gitignore");await x.fileIsReadable(c)&&!r.includes(c)&&r.unshift(c);break}}for(let s of r)try{let a=await x.readFile(s);e.add(a);}catch{console.warn(`${M} Failed to load .gitignore: ${s}`);}e.add(".git");}async walkDirectory(e,t,r,o){let s=[],a=t||e,l=r||await Q__default.realpath(this.rootPath),c=o||new Set([l]);try{let p=(await Q__default.readdir(e,{withFileTypes:!0})).map(u=>(u.name=u.name.normalize("NFC"),u)).sort((u,d)=>u.name<d.name?-1:u.name>d.name?1:0);for(let u of p){let d=R__default.join(e,u.name),m=V(a,d);if(u.isDirectory()){if(u.name.startsWith("."))continue;let f=await this.walkDirectory(d,a,l,c);s.push(...f);}else if(u.isFile()){let f=await Q__default.stat(d);s.push({path:d,relativePath:m,language:"",size:f.size});}else if(u.isSymbolicLink())try{let f=await Q__default.realpath(d);if(!f.startsWith(l+R__default.sep)&&f!==l){console.warn(`${M} Skipping symlink pointing outside project: ${d} -> ${f}`);continue}let h=await Q__default.stat(d);if(h.isDirectory()){if(u.name.startsWith(".")||c.has(f))continue;c.add(f);let S=await this.walkDirectory(d,a,l,c);s.push(...S);}else h.isFile()&&s.push({path:d,relativePath:m,language:"",size:h.size});}catch{console.warn(`${M} Skipping invalid symlink: ${d}`);}}}catch(p){console.error(`${le} Error walking directory ${e}:`,p);}return s}matchesLanguageExtension(e,t){let r=R__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=R__default.extname(e).toLowerCase();for(let[o,s]of Object.entries(t))if(s.fileExtensions.includes(r))return o;return null}};});var Bp,Wp,Hp,Do,Oo=g(()=>{vt();Bp=z$1.object({local:z$1.string(),original:z$1.string().optional(),isDefault:z$1.boolean(),isNamespace:z$1.boolean()}),Wp=z$1.object({source:z$1.string().min(1,"Import source cannot be empty"),resolvedPath:z$1.string().optional(),isExternal:z$1.boolean(),importType:z$1.enum(["relative","workspace","alias","external","builtin"]),specifiers:z$1.array(Bp).optional()}),Hp=z$1.record(z$1.string(),Wp),Do=z$1.object({file:z$1.string().min(1,"File path cannot be empty").max(1e3,"File path too long"),language:z$1.string().regex(/^(bash|c|c-sharp|cpp|go|java|javascript|json|php|python|ruby|typescript)$/,"Invalid language identifier"),commit:z$1.string().regex(/^[a-f0-9]{40}$/,"Invalid git commit hash"),timestamp:z$1.string().datetime({message:"Invalid ISO timestamp"}),ast:z$1.string().min(1,"Index data cannot be empty").max(1e7,"Index data exceeds 10MB limit"),importResolutions:Hp.optional(),classificationMap:en.optional()});});function zp(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 Mo(){let i=performance.now();return {elapsed:()=>zp(performance.now()-i),reset:()=>{i=performance.now();},ms:()=>performance.now()-i}}var Uo=g(()=>{});function xn(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 Cr,Go=g(()=>{bt();Cr=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(xn).join(" ")),timestamp:new Date().toISOString()}),this.originalLog.apply(console,e);},console.warn=(...e)=>{this.entries.push({level:"warn",message:stripVTControlCharacters(e.map(xn).join(" ")),timestamp:new Date().toISOString()}),this.originalWarn.apply(console,e);},console.error=(...e)=>{this.entries.push({level:"error",message:stripVTControlCharacters(e.map(xn).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||!nn.has(e.code)))}hasReportableErrors(){return this.entries.some(e=>e.level==="error"&&(!e.code||!nn.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 Ae(i){if(i&&typeof i=="object")try{i.alreadyReported=!0;}catch{}}function ve(i){return !!(i&&typeof i=="object"&&i.alreadyReported)}function Cn(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 Bo,Vp,Jp,Er,En=g(()=>{Be();Uo();Go();z();Bo=Math.floor(1e3/15),Vp={interval:100,frames:["\u280B","\u2819","\u281A","\u2813"]},Jp=new Set(["EPIPE","ENOTCONN","EBADF"]);Er=class i{static activeInstance=null;mode;stream;logCollector=new Cr;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),Ae(s),s}}start(e){this.currentPhaseLabel=e,this.currentPhaseTracker=Mo(),this.mode==="spinner"?(this.spinner?this.spinner.text=this.composeSpinnerText(e):this.spinner=Kp({text:this.composeSpinnerText(e),stream:this.stream,spinner:Vp}),this.paused||this.spinner.start()):(this.mode==="verbose"||this.mode==="plain")&&this.writeLine(`${de} ${e}\u2026`);}update(e){if(!this.currentPhaseLabel)return;if(this.currentPhaseLabel=e,this.mode==="verbose"){this.writeLine(`${de} ${e}`);return}if(this.mode!=="spinner")return;let t=Date.now();this.pendingUpdate=e;let r=t-this.lastUpdateAt;r>=Bo?this.flushPendingUpdate():this.pendingUpdateTimer||(this.pendingUpdateTimer=setTimeout(()=>this.flushPendingUpdate(),Bo-r),this.pendingUpdateTimer.unref?.());}succeed(e){this.flushPendingUpdate();let t=e??this.currentPhaseLabel??"",r=`${E} ${t}`;this.terminatePhase(r,"info");}fail(e,t){this.flushPendingUpdate();let r=e??this.currentPhaseLabel??"",o=`${le} ${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(`${de} ${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(`${M} ${e}`);}error(e,t){this.logCollector.record("error",e,t?.code),this.writeLine(`${le} ${e}`);}detail(e){this.logCollector.record("info",e),this.mode==="verbose"&&this.writeLine(` ${X.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"?E:e==="fail"?le:X.muted("-")} ${e==="skip"?X.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(`${M} ${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(`${M} ${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+`
49
+ 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 wp,_p,ur,ko=f(()=>{le();bo();nt();Pn();To();In();wp={log:n=>process.stderr.write(n+`
50
+ `),warn:n=>process.stderr.write(n+`
51
+ `),error:n=>process.stderr.write(n+`
52
+ `)},_p=k.join(He.homedir(),".constellation","lsp-trust.json"),ur=class{constructor(e,t,r){this.projectRoot=e;this.logger=t??wp,this.policy=r??this.buildDefaultPolicy();}serversByKey=new Map;languageToServerKey=new Map;unavailableLanguages=new Set;unavailableServerKeys=new Set;nextId=1;logger;policy;buildDefaultPolicy(){return new pr({projectRoot:this.projectRoot,logger:this.logger,trustStore:new it(_p),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;let d,m;try{d=spawn(a,l,{stdio:["pipe","pipe","pipe"],cwd:this.projectRoot});let g=d;await new Promise((T,w)=>{g.once("spawn",T),g.once("error",w);}),g.stderr?.on("data",T=>{this.handleServerDiagnostics(e,T.toString());}),m=new cr(g.stdin,g.stdout,12e4);let h=m,b=_n(a)?{background_analysis:{dotnet_analyzer_diagnostics_scope:"none",dotnet_compiler_diagnostics_scope:"openFiles"}}:void 0,y=pathToFileURL(this.projectRoot).href,S=await h.sendRequest("initialize",{processId:process.pid,rootUri:y,workspaceFolders:[{uri:y,name:k.basename(this.projectRoot)}],capabilities:{textDocument:{hover:{contentFormat:["plaintext"]},references:{},callHierarchy:{},implementation:{},documentSymbol:{hierarchicalDocumentSymbolSupport:!0}}},...b&&{initializationOptions:b}},12e4);if(h.sendNotification("initialized",{}),_n(a)){this.logger.log(`[LSP:${e}] Roslyn: waiting for project initialization (auto-load)\u2026`);let T=h.waitForNotification("workspace/projectInitializationComplete",18e4),w=new Promise((P,N)=>{let I=(v,R)=>{N(new Error(`Roslyn server exited during project initialization (code=${v}, signal=${R})`));};g.once("exit",I),T.finally(()=>g.removeListener("exit",I));});await Promise.race([T,w]),T.catch(()=>{}),w.catch(()=>{}),this.logger.log(`[LSP:${e}] Roslyn project initialization complete`);}let E={key:c,language:e,languages:new Set([e]),process:g,client:h,crashHandlers:new Set,intentionalShutdown:!1};return this.serversByKey.set(c,E),this.languageToServerKey.set(e,c),g.on("exit",(T,w)=>{let P=this.serversByKey.get(c);if(P){if(P.intentionalShutdown)P.crashHandlers.clear();else {let N=[...P.crashHandlers];P.crashHandlers.clear();for(let I of N)try{I();}catch(v){this.logger.warn(`[LSP:${P.language}] crash handler threw: ${v instanceof Error?v.message:String(v)}`);}this.logUnexpectedExit(e,T,w);}P.client.dispose(),this.serversByKey.delete(c);for(let[N,I]of this.languageToServerKey.entries())I===c&&this.languageToServerKey.delete(N);}}),this.toConnection(E,e)}catch(g){try{m?.dispose();}catch{}try{d?.kill();}catch{}this.unavailableLanguages.add(e),this.unavailableServerKeys.add(c);let h=`[LSP:${e}] Failed to start: ${g instanceof Error?g.message:String(g)}`,b=g?.code;return b==="ENOENT"||b==="EACCES"?this.logger.warn(h):this.logger.error(h),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();}handleServerDiagnostics(e,t){}resolveCommand(e,t){if(t?.command)return {command:t.command,args:[...t.args||[]]};let r=Te.get(e);if(!r)return null;let o=k.join(rt,r.command);if(existsSync(o))return {command:o,args:[...r.args]};if(ae(r.command))return {command:r.command,args:[...r.args]};let s=Cn(r.command);return s?{command:s,args:[...r.args]}:null}getServerKey(e,t){return `${e}\0${t.join("\0")}`}logUnexpectedExit(e,t,r){if(t!==null&&t!==0){this.logger.warn(`[LSP:${e}] Server exited unexpectedly with code ${t}`);return}if(t===0)return;if(r==="SIGKILL"){this.logger.warn(`[LSP:${e}] Server killed by SIGKILL (possibly OOM-killed \u2014 check \`dmesg | tail\` or system memory pressure)`);return}if(r!==null){this.logger.warn(`[LSP:${e}] Server exited unexpectedly via signal ${r}`);return}let o=process.platform==="win32"?"external termination (e.g. Task Manager / taskkill)":"unknown cause (no exit code or signal reported)";this.logger.warn(`[LSP:${e}] Server exited unexpectedly \u2014 ${o}`);}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),onNotification:(o,s)=>e.client.onNotification(o,s),onCrash:o=>(e.crashHandlers.add(o),()=>e.crashHandlers.delete(o))}}};});var Z,ot=f(()=>{Z=class{getBuildConfigManager(e,t){return null}getImportResolver(e,t){return null}preflightLsp(e){return Promise.resolve({skip:false})}};});var st,Rn=f(()=>{q();st=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(`${z} 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(`${z} Failed to parse ${r}: ${o}`),console.warn(`${z} Path alias resolution will be skipped for files using this config`);}else r||console.warn(`${z} Failed to parse config for ${e}:`,t instanceof Error?t.message:t);}};});var dr,Ao=f(()=>{oe();dr=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?k.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=k.resolve(r,a),c=await this.findEntryPoint(l);c&&(e[o]=c);}return e}async loadFromPackageJsonWorkspaces(){let e={};try{let t=k.join(this.projectRoot,"package.json"),r=await se.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=k.join(this.projectRoot,r);try{let s=await se.readdir(o,{withFileTypes:!0});for(let a of s)a.isDirectory()&&t.push(k.join(o,a.name));}catch{}}else {let r=k.join(this.projectRoot,e);try{(await se.stat(r)).isDirectory()&&t.push(r);}catch{}}return t}async loadWorkspacePackage(e){try{let t=k.join(e,"package.json"),r=await se.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 k.join(e,o);if(typeof o=="object"){let s=o["."]||o["./index"];if(typeof s=="string")return k.join(e,s);if(typeof s=="object"){let a=s.import||s.default||s.require;if(a)return k.join(e,a)}}}if(t.main)return k.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=k.join(e,o);try{if((await se.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=k.join(e,r);try{if((await se.stat(o)).isFile())return o}catch{}}try{if((await se.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")?k.dirname(e):k.dirname(e),o=[k.join(r,t+".ts"),k.join(r,t+".tsx"),k.join(r,t+".js"),k.join(r,t+".jsx"),k.join(r,t+".d.ts"),k.join(r,t,"index.ts"),k.join(r,t,"index.tsx"),k.join(r,t,"index.js"),k.join(r,t,"index.jsx")];for(let s of o)try{if((await se.stat(s)).isFile())return s}catch{}return null}toProjectRelative(e){let t=Y(this.projectRoot,e);return t.startsWith("./")?t:`./${t}`}};});var at,Nn=f(()=>{oe();Ao();at=class{baseUrl=null;paths={};sourceDir;tsconfigDir;projectRoot;extensions;packageImports={};packageJsonDir=null;sourceFilePath;workspaceResolver;constructor(e,t){this.sourceFilePath=e,this.sourceDir=k.dirname(e),this.projectRoot=process.cwd(),this.workspaceResolver=new dr(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=k.dirname(t.tsconfigFile);let a=t.tsconfig?.compilerOptions;a&&(a.baseUrl&&(this.baseUrl=k.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=k.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=Y(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=k.resolve(this.tsconfigDir,s);return await this.findFileWithExtensions(a)}async resolveWithBaseUrl(e){if(!this.baseUrl)return null;let t=k.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=k.join(s,`index${a}`);if(await this.fileExists(l))return await this.resolveSymlink(l)}return null}async fileExists(e){try{return (await se.stat(e)).isFile()}catch{return false}}async resolveSymlink(e){try{return await se.realpath(e)}catch{return e}}async findPackageJson(e){let t=e;for(;t.startsWith(this.projectRoot);){let r=k.join(t,"package.json");try{if((await se.stat(r)).isFile())return r}catch{}let o=k.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 se.readFile(e,"utf-8"),r=JSON.parse(t);this.packageJsonDir=k.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=k.resolve(this.packageJsonDir,r);return await this.findFileWithExtensions(o)}};});var mr,Fo=f(()=>{ot();Rn();Nn();mr=class extends Z{language="typescript";extensions=[".ts",".tsx",".d.ts"];getBuildConfigManager(e,t){return new st(e,t)}getImportResolver(e,t){return new at(e,t)}};});var fr,$o=f(()=>{ot();Rn();Nn();fr=class extends Z{language="javascript";extensions=[".js",".jsx",".mjs",".cjs"];getBuildConfigManager(e,t){return new st(e,t)}getImportResolver(e,t){return new at(e,t)}};});async function X(n,e,t,r,o,s=[]){let a=await t.resolve(n),l=Do(n,a),c=o(n,a,l),u=l?void 0:ar(a);r[e.toString()]={source:n,resolvedPath:u,isExternal:l,importType:c,specifiers:s};}function Do(n,e){return n===e?true:!(!e.startsWith(".")&&!e.startsWith("/")||e.startsWith("./")||e.startsWith("../"))}var Tn,$e=f(()=>{oe();Tn=(n,e,t)=>t?n.startsWith("node:")?"builtin":"external":n.startsWith("./")||n.startsWith("../")?"relative":n.startsWith("@")?"workspace":"alias";});async function Pp(n,e,t,r){let o=n.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 X(s,n.startPosition.row,e,t,r,[a]);}function Ip(n,e){if(!e)return [];let t=[],r=n.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<n.childCount;s++){let a=n.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 Rp(n,e,t,r){let o,s=n.childForFieldName("module_name");if(s)o=s.text;else {let l="";for(let c=0;c<n.childCount;c++){let u=n.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=Ip(n,!!s);await X(o,n.startPosition.row,e,t,r,a);}async function Np(n,e,t,r){await X("__future__",n.startPosition.row,e,t,r,[]);}function Ln(){return {language:"python",handlers:new Map([["import_statement",Pp],["import_from_statement",Rp],["future_import_statement",Np]]),classifyImportType:Ep}}var Ep,gr=f(()=>{Nt();$e();Nt();Ep=(n,e,t)=>{if(t)return "external";if(/^\.+/.test(n))return "relative";let r=n.split(".")[0];return It.has(r)?"builtin":"alias"};});var hr,Oo=f(()=>{gr();hr=class{sourceDir;projectRoot;constructor(e,t){this.sourceDir=k.dirname(e),this.projectRoot=t;}async resolve(e){let t=e.split(".")[0];if(It.has(t))return e;if(e.startsWith("."))return this.resolveRelative(e);let r=e.replace(/\./g,"/"),o=await this.tryResolveFile(k.resolve(this.projectRoot,r));return o?k.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=k.resolve(this.sourceDir,s),l=await this.tryResolveFile(a);return l?k.relative(this.projectRoot,l).replace(/\\/g,"/"):e}async tryResolveFile(e){let t=[`${e}.py`,`${e}.pyi`,`${e}.pyw`,k.join(e,"__init__.py"),k.join(e,"__init__.pyi")];for(let r of t)try{return await De.promises.access(r,De.constants.F_OK),r}catch{continue}return null}};});var vr,Mo=f(()=>{ot();Oo();vr=class extends Z{language="python";extensions=[".py",".pyi",".pyw"];getBuildConfigManager(e,t){return null}getImportResolver(e,t){return new hr(e,process.cwd())}};});function Uo(n){return n.replace(/\/\/[^\n]*/g,"")}function lt(n){return n.startsWith('"')&&n.endsWith('"')||n.startsWith("'")&&n.endsWith("'")?n.slice(1,-1):n}function Tp(n,e){let t=[],r=/^\s*replace\s*\(\s*([\s\S]*?)\)/gm,o=[];for(let l of n.matchAll(r))o.push(l[1]);let s=n.replace(r,l=>" ".repeat(l.length)),a=/^\s*replace\s+(?!\()(.+?)\s*$/gm;for(let l of s.matchAll(a))o.push(l[1]);for(let l of o)for(let c of l.split(`
53
+ `)){let u=c.trim();if(!u)continue;let p=Lp(u,e);p&&t.push(p);}return t}function Lp(n,e){let t=n.indexOf("=>");if(t===-1)return null;let r=n.slice(0,t).trim().split(/\s+/).filter(Boolean),o=n.slice(t+2).trim().split(/\s+/).filter(Boolean);if(r.length===0||o.length===0)return null;let s=lt(r[0]),a=r.length>=2?lt(r[1]):void 0,l=lt(o[0]);if(!kp(l))return null;let c=k.isAbsolute(l)?l:k.resolve(e,l);return {originalModulePath:s,originalVersion:a,localDir:c}}function kp(n){return n==="."||n===".."||n.startsWith("./")||n.startsWith("../")||k.isAbsolute(n)}var Oe,Go=f(()=>{oe();Oe=class n{constructor(e,t=true){this.projectRoot=e;this.enabled=t;}cache=new Map;discovered=[];initialized=false;goWorkPath=null;warnings=[];isEnabled(){return this.enabled}clearCache(){this.cache.clear(),this.discovered=[],this.initialized=false,this.goWorkPath=null,this.warnings=[];}consumeWarnings(){let e=this.warnings;return this.warnings=[],e}async initialize(){if(this.initialized)return this.configFilesPaths();if(this.goWorkPath=n.findGoWorkAncestor(this.projectRoot),this.goWorkPath!==null){let e=await this.parseGoWork(this.goWorkPath),t=await Promise.all(e.map(async r=>{let o=k.join(r,"go.mod"),s=await this.parseGoMod(o);return {useDir:r,modPath:o,info:s}}));for(let{useDir:r,modPath:o,info:s}of t)s?(this.discovered.push(s),this.cache.set(F(s.rootDir),s)):this.warnings.push(`go.work: use directive ${F(r)} has no parseable go.mod at ${F(o)}`);}else {let e=await this.findGoModFiles(this.projectRoot,0,6),t=await Promise.all(e.map(r=>this.parseGoMod(r)));for(let r of t)r&&(this.discovered.push(r),this.cache.set(F(r.rootDir),r));}return this.initialized=true,this.configFilesPaths()}configFilesPaths(){let e=this.discovered.map(t=>F(k.join(t.rootDir,"go.mod")));return this.goWorkPath!==null&&e.unshift(F(this.goWorkPath)),e}async getConfigForFile(e){this.initialized||await this.initialize();let t=k.isAbsolute(e)?e:k.resolve(this.projectRoot,e),r=this.goWorkPath!==null?k.dirname(this.goWorkPath):this.projectRoot,o=k.dirname(t);for(;;){let s=this.cache.get(F(o));if(s!==void 0)return s;let a=k.dirname(o),l=o===r||o.startsWith(r+k.sep);if(a===o||!l)return null;o=a;}}getAllModules(){return this.discovered}static hasGoModAncestor(e){let t=k.resolve(e);for(;;){if(De.existsSync(k.join(t,"go.mod")))return true;let r=k.dirname(t);if(r===t)return false;t=r;}}static findGoWorkAncestor(e){let t=k.resolve(e);for(;;){let r=k.join(t,"go.work");if(De.existsSync(r))return r;let o=k.dirname(t);if(o===t)return null;t=o;}}async findGoModFiles(e,t,r){if(t>r)return [];let o=[],s;try{s=await De.promises.readdir(e,{withFileTypes:!0});}catch{return o}for(let a of s){if(a.name==="node_modules"||a.name==="vendor"||a.name.startsWith("."))continue;let l=k.join(e,a.name);if(a.isFile()&&a.name==="go.mod")o.push(l);else if(a.isDirectory()){let c=await this.findGoModFiles(l,t+1,r);o.push(...c);}}return o}async parseGoWork(e){let t;try{t=await De.promises.readFile(e,"utf8");}catch{return []}let r=k.dirname(e),o=[],s=Uo(t),a=/^\s*use\s*\(\s*([\s\S]*?)\)/gm;for(let u of s.matchAll(a))for(let p of u[1].split(`
54
+ `)){let d=lt(p.trim());d&&o.push(k.resolve(r,d));}let l=s.replace(a,u=>" ".repeat(u.length)),c=/^\s*use\s+(?!\()(\S.*?)\s*$/gm;for(let u of l.matchAll(c)){let p=lt(u[1].trim());p&&o.push(k.resolve(r,p));}return o}async parseGoMod(e){let t;try{t=await De.promises.readFile(e,"utf8");}catch{return null}let r=Uo(t),o=r.match(/^\s*module\s+(\S+)\s*$/m);if(!o)return null;let s=r.match(/^\s*go\s+(\d+\.\d+(?:\.\d+)?)\s*$/m),a=k.dirname(e);return {modulePath:lt(o[1]),goVersion:s?.[1],rootDir:a,replaces:Tp(r,a)}}};});function jp(n){let e=n.trim();return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}var Sr,br,wr=f(()=>{oe();Sr=new Set(["archive","bufio","builtin","bytes","cmp","compress","container","context","crypto","database","debug","embed","encoding","errors","expvar","flag","fmt","go","hash","html","image","index","io","iter","log","maps","math","mime","net","os","path","plugin","reflect","regexp","runtime","slices","sort","strconv","strings","sync","syscall","testing","text","time","unicode","unique","unsafe"]),br=class{constructor(e,t,r=[]){this.sourceFilePath=e;this.projectRoot=t;this.modules=r;}async resolve(e){let t=jp(e);if(!t)return e;let r=t.split("/")[0];if(!r.includes(".")&&Sr.has(r))return t;let o=this.findReplaceForSpecifier(t);if(o){let a=t.slice(o.originalModulePath.length),l=k.join(o.localDir,a.startsWith("/")?a.slice(1):a);if(await this.directoryHasGoFiles(l))return F(k.relative(this.projectRoot,l))}let s=this.findModuleForSpecifier(t);if(s){let a=t.slice(s.modulePath.length),l=k.join(s.rootDir,a.startsWith("/")?a.slice(1):a);if(await this.directoryHasGoFiles(l))return F(k.relative(this.projectRoot,l))}return t}findModuleForSpecifier(e){let t;for(let r of this.modules)(e===r.modulePath||e.startsWith(r.modulePath+"/"))&&(!t||r.modulePath.length>t.modulePath.length)&&(t=r);return t}findReplaceForSpecifier(e){let t;for(let r of this.modules)for(let o of r.replaces)(e===o.originalModulePath||e.startsWith(o.originalModulePath+"/"))&&(!t||o.originalModulePath.length>t.originalModulePath.length)&&(t=o);return t}async directoryHasGoFiles(e){try{return (await De.promises.readdir(e,{withFileTypes:!0})).some(r=>r.isFile()&&r.name.endsWith(".go")&&!r.name.endsWith("_test.go"))}catch{return false}}};});var _r,Ho=f(()=>{ot();Go();wr();_r=class extends Z{language="go";extensions=[".go"];manager=null;getBuildConfigManager(e,t){return this.manager=new Oe(e),this.manager}getImportResolver(e,t){let r;if(Array.isArray(t))r=t;else {let o=this.manager?.getAllModules()??[];o.length>0?r=o:t?r=[t]:r=[];}return new br(e,process.cwd(),r)}async preflightLsp(e){return this.manager??=new Oe(e),await this.manager.initialize(),this.manager.getAllModules().length>0?{skip:false}:Oe.hasGoModAncestor(e)?{skip:false}:Oe.findGoWorkAncestor(e)!==null?{skip:false}:{skip:true,message:"No go.mod found within the project tree or any ancestor directory \u2014 Go files will be indexed without cross-file reference and interface edges. Run `go mod init <module-path>` in your project root (e.g. `go mod init github.com/your-org/your-repo`) to enable LSP enrichment for Go."}}};});async function Ko(n){let e=false,t=false,r=async o=>{if(e&&t)return;let s;try{s=await De.promises.readdir(o,{withFileTypes:!0});}catch{return}for(let a of s){if(e&&t)return;if(a.isFile())!e&&(a.name.endsWith(".sln")||a.name.endsWith(".csproj"))?e=true:!t&&a.name==="project.assets.json"&&(t=true);else if(a.isDirectory()){if(Ap.has(a.name)||a.name.startsWith("."))continue;await r(k.join(o,a.name));}}};return await r(n),{hasProjects:e,restored:t}}var Ap,Vo=f(()=>{Ap=new Set(["node_modules",".git","bin"]);});function jn(n,e){let t=new RegExp(`<${e}[^>]*>([^<]+)<\\/${e}>`,"i"),r=n.match(t);return r?r[1].trim():void 0}function Fp(n){let e=jn(n,"ImplicitUsings");return e?e.toLowerCase()==="enable"||e.toLowerCase()==="true":false}function $p(n){let e=[],t=/<PackageReference\s[^>]*Include\s*=\s*"([^"]+)"/gi;for(let r of n.matchAll(t))e.push(r[1].trim());return e}function Dp(n,e,t){let r=n.replace(/\/\*[\s\S]*?\*\//g,"").replace(/\/\/[^\n]*/g,""),o=/\bnamespace\s+([a-zA-Z_][\w]*(?:\.[a-zA-Z_][\w]*)*)\s*(?:[{;])/g;for(let a of r.matchAll(o)){let l=a[1].trim();l&&kn(t,l,e,false);}let s=/\busing\s+([a-zA-Z_][\w]*)\s*=\s*([a-zA-Z_][\w]*(?:\.[a-zA-Z_][\w]*)*)\s*;/g;for(let a of r.matchAll(s)){let l=a[1].trim(),c=a[2].trim();l&&kn(t,l,e,true),c&&kn(t,c,e,false);}}function kn(n,e,t,r){let o=n.get(e);(!o||F(t)<F(o.filePath))&&n.set(e,{filePath:t,isAlias:r});}var Cr,Jo=f(()=>{oe();Cr=class{constructor(e,t=true){this.projectRoot=e;this.enabled=t;}cache=new Map;discovered=[];initialized=false;namespaceIndex=new Map;isEnabled(){return this.enabled}clearCache(){this.cache.clear(),this.discovered=[],this.initialized=false,this.namespaceIndex=new Map;}async initialize(){if(this.initialized)return this.configFilePaths();let{projectFiles:e,csFiles:t}=await this.findBuildArtifacts(this.projectRoot),r=await Promise.all(e.map(o=>this.parseProjectFile(o)));for(let o of r){if(!o)continue;this.discovered.push(o);let s=F(o.rootDir),a=this.cache.get(s),l=o.configFilePath.endsWith(".csproj"),c=a?.configFilePath.endsWith(".csproj")??false;(!a||l&&!c)&&this.cache.set(s,o);}return await Promise.all(t.map(async o=>{let s;try{s=await De.promises.readFile(o,"utf8");}catch{return}Dp(s,o,this.namespaceIndex);})),this.initialized=true,this.configFilePaths()}getNamespaceIndex(){return this.namespaceIndex}configFilePaths(){return this.discovered.map(e=>F(e.configFilePath))}async getConfigForFile(e){this.initialized||await this.initialize();let t=k.isAbsolute(e)?e:k.resolve(this.projectRoot,e),r=k.dirname(t);for(;;){let o=this.cache.get(F(r));if(o!==void 0)return o;let s=k.dirname(r),a=r===this.projectRoot||r.startsWith(this.projectRoot+k.sep);if(s===r||!a)return null;r=s;}}getAllProjects(){return this.discovered}getAllPackageReferences(){let e=new Set;for(let t of this.discovered)for(let r of t.packageReferences)e.add(r);return e}async findBuildArtifacts(e){let t=[],r=[],o;try{o=await De.promises.readdir(e,{withFileTypes:!0});}catch{return {projectFiles:t,csFiles:r}}for(let s of o){if(s.name==="node_modules"||s.name==="bin"||s.name==="obj"||s.name.startsWith("."))continue;let a=k.join(e,s.name);if(s.isFile())s.name.endsWith(".csproj")||s.name==="Directory.Build.props"?t.push(a):(s.name.endsWith(".cs")||s.name.endsWith(".csx"))&&r.push(a);else if(s.isDirectory()){let l=await this.findBuildArtifacts(a);t.push(...l.projectFiles),r.push(...l.csFiles);}}return {projectFiles:t,csFiles:r}}async parseProjectFile(e){let t;try{t=await De.promises.readFile(e,"utf8");}catch{return null}let r=k.dirname(e);return {configFilePath:e,rootDir:r,langVersion:jn(t,"LangVersion"),nullable:jn(t,"Nullable"),implicitUsings:Fp(t),packageReferences:$p(t)}}};});function Op(n){let e=[];for(let t=0;t<n.length;t++){let r=n[t];(r==="."||r===":"&&n[t+1]===":")&&e.push(n.slice(0,t));}return e}var Er,qo=f(()=>{oe();Er=class{constructor(e,t){this.projectRoot=e;this.index=t;}index;async resolve(e){if(!e)return e;let t=this.index.get(e);if(t)return F(k.relative(this.projectRoot,t.filePath));let r=Op(e);for(let o=r.length-1;o>=0;o--){let s=this.index.get(r[o]);if(s)return F(k.relative(this.projectRoot,s.filePath))}return e}};});var Pr,Yo=f(()=>{ot();Vo();Jo();qo();Pr=class extends Z{language="c-sharp";extensions=[".cs",".csx"];manager=null;getBuildConfigManager(e,t){return this.manager=new Cr(e),this.manager}getImportResolver(e,t){let r=this.manager?t?.rootDir??this.manager.getAllProjects()[0]?.rootDir??process.cwd():process.cwd(),o=this.manager?.getNamespaceIndex()??new Map;return new Er(r,o)}async preflightLsp(e){let t;try{t=await Ko(e);}catch{return {skip:false}}return !t.hasProjects||t.restored?{skip:false}:{skip:true,message:"C# enrichment skipped: the solution is not restored (no project.assets.json found). Run `dotnet restore` in the project root, then re-index. Skipping avoids empty results caused by unresolved analyzer references."}}};});function te(n){return zp[n]??n.charAt(0).toUpperCase()+n.slice(1)}var zp,Me,Ir,Rr=f(()=>{Fo();$o();Mo();Ho();Yo();zp={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"};Me={bash:[".sh",".bash"],c:[".c",".h"],"c-sharp":[".cs",".csx"],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"]},Ir=class{constructor(e){this.config=e;this.registerPlugin(new mr),this.registerPlugin(new fr),this.registerPlugin(new vr),this.registerPlugin(new _r),this.registerPlugin(new Pr);}plugins=new Map;registerPlugin(e){this.plugins.set(e.language,e);}getPlugin(e){return this.plugins.get(e)}javascript={language:()=>Gp,fileExtensions:()=>this.config?.languages.javascript?.fileExtensions??Me.javascript};typescript={language:()=>Hp.typescript,fileExtensions:()=>this.config?.languages.typescript?.fileExtensions??Me.typescript};python={language:()=>Bp,fileExtensions:()=>this.config?.languages.python?.fileExtensions??Me.python};php;json;java;go={language:()=>Up,fileExtensions:()=>this.config?.languages.go?.fileExtensions??Me.go};cpp;"c-sharp"={language:()=>Mp,fileExtensions:()=>this.config?.languages["c-sharp"]?.fileExtensions??Me["c-sharp"]};c;bash;ruby};});function pt(n,e,t=32){let r=n.parent,o=0;for(;r!==null&&o<t;){if(e(r))return r;r=r.parent,o++;}return null}var Nr,Fn=f(()=>{Nr=Object.freeze(new Set(["program","statement_block","function_declaration","function_expression","generator_function_declaration","generator_function","arrow_function","method_definition","class_body"]));});function $n(n,e){if(n.type==="jsx_opening_element"||n.type==="jsx_self_closing_element"||n.type==="jsx_closing_element"){let t=n.childForFieldName("name");t!==null&&Wp(t,e);}for(let t of n.namedChildren)t&&$n(t,e);}function Wp(n,e){if(n.type==="identifier"||n.type==="type_identifier"){e.set(we(n.startPosition.row,n.startPosition.column),"call");return}if(n.type==="member_expression"||n.type==="nested_identifier"){let t=n.childForFieldName("property");t!==null&&e.set(we(t.startPosition.row,t.startPosition.column),"call");}}var Xo=f(()=>{ut();});function dt(n,e){n.rootNode&&(Zo(n.rootNode,e),$n(n.rootNode,e));}function Zo(n,e){if(Kp.has(n.type)){let t=Vp(n);t!==null&&e.set(we(n.startPosition.row,n.startPosition.column),t);}for(let t of n.namedChildren)t&&Zo(t,e);}function Vp(n){if(qp(n))return "declaration";if(ou(n))return "read";if(nu(n))return "type";let e=pt(n,t=>t.type==="decorator");return e!==null&&Qp(n,e)?"call":Xp(n)?"instantiate":Yp(n)?"call":Zp(n)||eu(n)||tu(n)||mu(n)||du(n)?"write":su(n)?"import-use":"read"}function qp(n){let e=n.parent;return e===null?false:!!(Jp.has(e.type)&&(e.childForFieldName("name")===n||e.childForFieldName("property")===n)||(e.type==="required_parameter"||e.type==="optional_parameter")&&e.childForFieldName("pattern")===n||e.type==="import_specifier"&&(e.childForFieldName("name")===n||e.childForFieldName("alias")===n)||e.type==="namespace_import"||e.type==="import_clause"&&e.namedChild(0)===n&&n.type==="identifier"||e.type==="catch_clause"&&e.childForFieldName("parameter")===n||e.type==="enum_body")}function Yp(n){let e=n.parent;if(e===null)return false;if(e.type==="call_expression"&&e.childForFieldName("function")===n)return true;if(e.type==="member_expression"&&e.childForFieldName("property")===n){let t=e.parent;if(t!==null&&t.type==="call_expression"&&t.childForFieldName("function")===e)return true}return false}function Xp(n){let e=n.parent;if(e===null)return false;if(e.type==="new_expression"&&e.childForFieldName("constructor")===n)return true;if(e.type==="member_expression"&&e.childForFieldName("property")===n){let t=e.parent;if(t!==null&&t.type==="new_expression"&&t.childForFieldName("constructor")===e)return true}return false}function Qp(n,e){let t=e.namedChild(0);if(t===null)return false;if(t===n)return true;if(t.type==="call_expression"){let r=t.childForFieldName("function");if(r===n||r?.type==="member_expression"&&r.childForFieldName("property")===n)return true}return t.type==="member_expression"&&t.childForFieldName("property")===n}function Zp(n){let e=n;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||Nr.has(t.type))return false;e=t;}return false}function eu(n){let e=n.parent;if(e?.type==="update_expression"&&e.childForFieldName("argument")===n)return true;if(e?.type==="member_expression"&&e.childForFieldName("property")===n){let t=e.parent;if(t?.type==="update_expression"&&t.childForFieldName("argument")===e)return true}return false}function tu(n){let e=n;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||Nr.has(t.type))return false;e=t;}return false}function nu(n){let e=n.parent,t=n;for(;e!==null;){if(e.type==="as_expression"||e.type==="satisfies_expression"){let r=e.namedChild(1);return r===null?false:r===t||iu(r,n)}if(ru.has(e.type))return true;if(Nr.has(e.type))return false;t=e,e=e.parent;}return false}function iu(n,e){let t=e;for(;t!==null;){if(t===n)return true;t=t.parent;}return false}function ou(n){return pt(n,t=>t.type==="type_query")!==null}function su(n){let e=n.parent;if(e?.type!=="member_expression"||e.childForFieldName("object")!==n)return false;let t=n.text,r=pu(n);return uu(r,t)?!lu(n,t):false}function lu(n,e){let t=n.parent;for(;t!==null;){if(au.has(t.type)&&cu(t,e))return true;t=t.parent;}return false}function cu(n,e){for(let t of n.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 pu(n){let e=n;for(;e.parent!==null;)e=e.parent;return e}function uu(n,e){for(let t of n.descendantsOfType("namespace_import")){let r=t.namedChild(0);if(r!==null&&r.text===e)return true}return false}function du(n){let e=n.parent;return e?.type==="for_in_statement"&&e.childForFieldName("left")===n}function mu(n){let e=n.parent;if(e===null||!Qo.has(e.type)||e.type==="pair_pattern"&&e.childForFieldName("key")===n||(e.type==="object_assignment_pattern"||e.type==="assignment_pattern")&&e.namedChild(0)!==n)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(!Qo.has(r.type))return false;t=r;}return false}var Kp,Jp,ru,au,Qo,Tr=f(()=>{ut();Fn();Xo();Kp=Object.freeze(new Set(["identifier","type_identifier","property_identifier","private_property_identifier","shorthand_property_identifier","shorthand_property_identifier_pattern"]));Jp=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"]));ru=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"]));au=Object.freeze(new Set(["statement_block","function_declaration","function_expression","arrow_function","method_definition","generator_function","generator_function_declaration","for_statement","for_in_statement"]));Qo=Object.freeze(new Set(["object_pattern","array_pattern","pair_pattern","rest_pattern","object_assignment_pattern","assignment_pattern"]));});function es(n,e){dt(n,e);}var ts=f(()=>{Tr();});function rs(n,e){dt(n,e);}var ns=f(()=>{Tr();});function is(n,e){if(!n.rootNode)return;let t=Au(n.rootNode);os(n.rootNode,e,t);}function os(n,e,t){if(fu.has(n.type)){let r=gu(n,t);r!==null&&e.set(we(n.startPosition.row,n.startPosition.column),r);}for(let r of n.namedChildren)r&&os(r,e,t);}function gu(n,e){if(hu(n))return "declaration";if(bu(n))return "read";if(vu(n))return "declaration";if(Su(n))return "type";let t=pt(n,r=>r.type==="decorator");return t!==null&&wu(n,t)||_u(n)?"call":xu(n)||Cu(n)||Eu(n)||Iu(n)||Nu(n)?"write":Tu(n,e)?"import-use":"read"}function hu(n){let e=n.parent;if(e===null)return false;if((e.type==="function_definition"||e.type==="class_definition")&&e.childForFieldName("name")===n||e.type==="parameters"||e.type==="lambda_parameters"||(e.type==="typed_parameter"||e.type==="typed_default_parameter"||e.type==="default_parameter")&&e.namedChild(0)===n)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"||yu(n))}function yu(n){let e=n.parent;if(e?.type!=="type")return false;let t=e.parent;return t?.type!=="type_alias_statement"?false:t.namedChild(0)===e}function vu(n){let e=n.parent;for(;e!==null;){if(e.type==="import_statement"||e.type==="import_from_statement")return true;if(Dn.has(e.type))return false;e=e.parent;}return false}function bu(n){let e=n.parent;return e?.type==="global_statement"||e?.type==="nonlocal_statement"}function Su(n){return pt(n,t=>t.type==="type")!==null}function wu(n,e){let t=e.namedChild(0);if(t===null)return false;if(t===n)return true;if(t.type==="call"){let r=t.childForFieldName("function");if(r===n||r?.type==="attribute"&&r.childForFieldName("attribute")===n)return true}return t.type==="attribute"&&t.childForFieldName("attribute")===n}function _u(n){let e=n.parent;if(e?.type==="call"&&e.childForFieldName("function")===n)return true;if(e?.type==="attribute"&&e.childForFieldName("attribute")===n){let t=e.parent;if(t?.type==="call"&&t.childForFieldName("function")===e)return true}return false}function xu(n){let e=n;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||Dn.has(t.type))return false;e=t;}return false}function Cu(n){let e=n.parent;if(e?.type==="augmented_assignment"&&e.childForFieldName("left")===n)return true;if(e?.type==="attribute"&&e.childForFieldName("attribute")===n){let t=e.parent;if(t?.type==="augmented_assignment"&&t.childForFieldName("left")===e)return true}return false}function Eu(n){let e=n.parent;return e?.type==="named_expression"&&e.childForFieldName("name")===n}function Iu(n){let e=n;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(Pu.has(t.type)){e=t;continue}if(Dn.has(t.type))return false;e=t;}return false}function Nu(n){let e=n;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(!Ru.has(t.type))return false;e=t;}return false}function Tu(n,e){let t=n.parent;if(t?.type!=="attribute"||t.childForFieldName("object")!==n)return false;let r=n.text;return e.has(r)?!ku(n,r):false}function ku(n,e){let t=n.parent;for(;t!==null;){if(Lu.has(t.type)&&ju(t,e))return true;t=t.parent;}return false}function ju(n,e){for(let t of n.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 Au(n){let e=new Set;for(let t of n.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 fu,Dn,Pu,Ru,Lu,ss=f(()=>{ut();Fn();fu=Object.freeze(new Set(["identifier"])),Dn=Object.freeze(new Set(["module","block","function_definition","class_definition","lambda"]));Pu=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern","list_splat_pattern"]));Ru=Object.freeze(new Set(["pattern_list","tuple_pattern","list_pattern"]));Lu=Object.freeze(new Set(["block","function_definition","class_definition","lambda"]));});function ls(n,e){n.rootNode&&cs(n.rootNode,e);}function cs(n,e){if(Fu.has(n.type)){let t=Ou(n);t!==null&&e.set(we(n.startPosition.row,n.startPosition.column),t);}for(let t of n.namedChildren)t&&cs(t,e);}function Ou(n){return Mu(n)?"declaration":Uu(n)?"type":Gu(n)?"call":Bu(n)?"instantiate":Hu(n)?"call":zu(n)||Wu(n)?"write":"read"}function Mu(n){let e=n.parent;return e===null?false:!!($u.has(e.type)&&e.childForFieldName("name")===n||e.type==="foreach_statement"&&e.childForFieldName("left")===n||e.type==="declaration_pattern"&&e.childForFieldName("name")===n)}function Uu(n){let e=n,t=n.parent;for(;t!==null;){if(Du.has(t.type)||t.type==="variable_declaration"&&t.childForFieldName("type")===e||t.type==="parameter"&&t.childForFieldName("type")===e||t.type==="method_declaration"&&t.childForFieldName("returns")===e||t.type==="property_declaration"&&t.childForFieldName("type")===e||t.type==="cast_expression"&&t.childForFieldName("type")===e||t.type==="as_expression"&&t.childForFieldName("right")===e||t.type==="is_expression"&&t.childForFieldName("right")===e||t.type==="typeof_expression"&&t.childForFieldName("type")===e||t.type==="default_expression"&&t.childForFieldName("type")===e||t.type==="foreach_statement"&&t.childForFieldName("type")===e||t.type==="catch_declaration"&&t.childForFieldName("type")===e||t.type==="local_function_statement"&&t.childForFieldName("type")===e||t.type==="delegate_declaration"&&t.childForFieldName("type")===e||t.type==="declaration_pattern"&&t.childForFieldName("type")===e)return true;if(t.type==="is_pattern_expression")return t.namedChild(0)!==e;if(as.has(t.type))return false;e=t,t=t.parent;}return false}function Gu(n){let e=n.parent;return e!==null&&e.type==="attribute"&&e.childForFieldName("name")===n}function Bu(n){let e=n.parent;return e===null?false:e.type==="object_creation_expression"&&e.childForFieldName("type")===n}function Hu(n){let e=n.parent;if(e===null)return false;if(e.type==="invocation_expression"&&e.childForFieldName("function")===n)return true;if(e.type==="member_access_expression"&&e.childForFieldName("name")===n){let t=e.parent;if(t!==null&&t.type==="invocation_expression"&&t.childForFieldName("function")===e)return true}return false}function zu(n){let e=n;for(;e!==null;){let t=e.parent;if(t===null)return false;if(t.type==="assignment_expression"&&t.childForFieldName("left")===e)return true;if(t.type==="member_access_expression"&&t.childForFieldName("expression")===e||as.has(t.type))return false;e=t;}return false}function Wu(n){let e=n.parent;if(e===null)return false;if(e.type==="postfix_unary_expression"||e.type==="prefix_unary_expression"){let t=e.text;if(t.startsWith("++")||t.startsWith("--")||t.endsWith("++")||t.endsWith("--"))return true}return false}var Fu,as,$u,Du,ps=f(()=>{ut();Fu=Object.freeze(new Set(["identifier","generic_name"])),as=Object.freeze(new Set(["compilation_unit","namespace_declaration","file_scoped_namespace_declaration","class_declaration","struct_declaration","interface_declaration","record_declaration","enum_declaration","method_declaration","constructor_declaration","block"])),$u=Object.freeze(new Set(["class_declaration","interface_declaration","struct_declaration","record_declaration","enum_declaration","delegate_declaration","method_declaration","constructor_declaration","property_declaration","event_declaration","local_function_statement","namespace_declaration","enum_member_declaration","variable_declarator","parameter","catch_declaration"])),Du=Object.freeze(new Set(["base_list","type_argument_list","type_parameter","type_parameter_list","type_parameter_constraints_clause","type_constraint"]));});function ds(n,e){let t=new Map;switch(e){case "typescript":dt(n,t);break;case "tsx":es(n,t);break;case "javascript":rs(n,t);break;case "python":is(n,t);break;case "c-sharp":ls(n,t);break}return t}function we(n,e){return `${n}:${e}`}var us,ut=f(()=>{Tr();ts();ns();ss();ps();us=Object.freeze(new Set(["typescript","javascript","python","c-sharp"]));});function Ju(n,e){return us.has(n)?n==="typescript"?e.toLowerCase().endsWith(".tsx")?"tsx":"typescript":n:null}function qu(n){let e=[];for(let[t,r]of n.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 Lr,gs=f(()=>{ut();le();Lr=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=Hp.tsx);let s=new Ku;s.setLanguage(o);let a=await C.getFileStats(e),l=25*1024*1024,c,u;if(a.size<=l){let g=await C.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=Ju(t,e),d=p===null?[]:qu(ds(c,p));return {tree:c,classificationMap:{filePath:e,entries:d},content:u}}async parseWithStream(e,t,r){let o=null;try{o=await se.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}%...
55
+ `),c=m);}let d=De.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)}
56
+ `);}throw s}finally{if(o)try{await o.close();}catch{}}}};});var kr,ys=f(()=>{le();oe();q();kr=class{rootPath;constructor(e){this.rootPath=e||process.cwd();}async scanFiles(e){let t=hs();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=hs().add(t.exclude));let s=await se__default.realpath(this.rootPath);for(let a of e)try{let l=k__default.isAbsolute(a)?a:k__default.join(this.rootPath,a),c=await se__default.lstat(l);if(c.isSymbolicLink()){let u=await se__default.realpath(l);if(!u.startsWith(s+k__default.sep)&&u!==s){console.warn(`${z} Skipping symlink pointing outside project: ${a} -> ${u}`);continue}let p=await se__default.stat(l);if(!p.isFile())continue;let d=Y(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=Y(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(`${z} Skipping inaccessible file: ${a}`);}return r}async loadGitignoreRules(e,t){let r=[],o=t;for(;;){let s=k__default.join(o,".gitignore");await C.fileIsReadable(s)&&r.unshift(s);let a=k__default.dirname(o);if(a===o)break;o=a;let l=k__default.join(o,".git");if(await C.directoryExists(l)){let c=k__default.join(o,".gitignore");await C.fileIsReadable(c)&&!r.includes(c)&&r.unshift(c);break}}for(let s of r)try{let a=await C.readFile(s);e.add(a);}catch{console.warn(`${z} Failed to load .gitignore: ${s}`);}e.add(".git");}async walkDirectory(e,t,r,o){let s=[],a=t||e,l=r||await se__default.realpath(this.rootPath),c=o||new Set([l]);try{let u=(await se__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=k__default.join(e,p.name),m=Y(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 se__default.stat(d);s.push({path:d,relativePath:m,language:"",size:g.size});}else if(p.isSymbolicLink())try{let g=await se__default.realpath(d);if(!g.startsWith(l+k__default.sep)&&g!==l){console.warn(`${z} Skipping symlink pointing outside project: ${d} -> ${g}`);continue}let h=await se__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(`${z} Skipping invalid symlink: ${d}`);}}}catch(u){console.error(`${ge} Error walking directory ${e}:`,u);}return s}matchesLanguageExtension(e,t){let r=k__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=k__default.extname(e).toLowerCase();for(let[o,s]of Object.entries(t))if(s.fileExtensions.includes(r))return o;return null}};});var Yu,Xu,Qu,vs,bs=f(()=>{Nt();Yu=z$1.object({local:z$1.string(),original:z$1.string().optional(),isDefault:z$1.boolean(),isNamespace:z$1.boolean()}),Xu=z$1.object({source:z$1.string().min(1,"Import source cannot be empty"),resolvedPath:z$1.string().optional(),isExternal:z$1.boolean(),importType:z$1.enum(["relative","workspace","alias","external","builtin"]),specifiers:z$1.array(Yu).optional()}),Qu=z$1.record(z$1.string(),Xu),vs=z$1.object({file:z$1.string().min(1,"File path cannot be empty").max(1e3,"File path too long"),language:z$1.string().regex(/^(bash|c|c-sharp|cpp|go|java|javascript|json|php|python|ruby|typescript)$/,"Invalid language identifier"),commit:z$1.string().regex(/^[a-f0-9]{40}$/,"Invalid git commit hash"),timestamp:z$1.string().datetime({message:"Invalid ISO timestamp"}),ast:z$1.string().min(1,"Index data cannot be empty").max(1e7,"Index data exceeds 10MB limit"),importResolutions:Qu.optional(),classificationMap:pn.optional()});});function Zu(n){let e=Math.max(0,n)/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 Ss(){let n=performance.now();return {elapsed:()=>Zu(performance.now()-n),reset:()=>{n=performance.now();},ms:()=>performance.now()-n}}var ws=f(()=>{});function On(n){if(typeof n=="string")return n;if(n instanceof Error)return n.message;if(typeof n=="object"&&n!==null)try{return JSON.stringify(n)}catch{return String(n)}return String(n)}var Ar,_s=f(()=>{Tt();Ar=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(On).join(" ")),timestamp:new Date().toISOString()}),this.originalLog.apply(console,e);},console.warn=(...e)=>{this.entries.push({level:"warn",message:stripVTControlCharacters(e.map(On).join(" ")),timestamp:new Date().toISOString()}),this.originalWarn.apply(console,e);},console.error=(...e)=>{this.entries.push({level:"error",message:stripVTControlCharacters(e.map(On).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||!mn.has(e.code)))}hasReportableErrors(){return this.entries.some(e=>e.level==="error"&&(!e.code||!mn.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 Ue(n){if(n&&typeof n=="object")try{n.alreadyReported=!0;}catch{}}function xe(n){return !!(n&&typeof n=="object"&&n.alreadyReported)}function Mn(n){if(typeof n=="string")return n;if(n instanceof Error)return n.message;if(typeof n=="object"&&n!==null)try{return JSON.stringify(n)}catch{return String(n)}return String(n)}var xs,td,rd,Fr,Un=f(()=>{qe();ws();_s();q();xs=Math.floor(1e3/15),td={interval:100,frames:["\u280B","\u2819","\u281A","\u2813"]},rd=new Set(["EPIPE","ENOTCONN","EBADF"]);Fr=class n{static activeInstance=null;mode;stream;logCollector=new Ar;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(n.activeInstance&&!n.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,n.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),Ue(s),s}}start(e){this.currentPhaseLabel=e,this.currentPhaseTracker=Ss(),this.mode==="spinner"?(this.spinner?this.spinner.text=this.composeSpinnerText(e):this.spinner=ed({text:this.composeSpinnerText(e),stream:this.stream,spinner:td}),this.paused||this.spinner.start()):(this.mode==="verbose"||this.mode==="plain")&&this.writeLine(`${ve} ${e}\u2026`);}update(e){if(!this.currentPhaseLabel)return;if(this.currentPhaseLabel=e,this.mode==="verbose"){this.writeLine(`${ve} ${e}`);return}if(this.mode!=="spinner")return;let t=Date.now();this.pendingUpdate=e;let r=t-this.lastUpdateAt;r>=xs?this.flushPendingUpdate():this.pendingUpdateTimer||(this.pendingUpdateTimer=setTimeout(()=>this.flushPendingUpdate(),xs-r),this.pendingUpdateTimer.unref?.());}succeed(e){this.flushPendingUpdate();let t=e??this.currentPhaseLabel??"",r=`${x} ${t}`;this.terminatePhase(r,"info");}fail(e,t){this.flushPendingUpdate();let r=e??this.currentPhaseLabel??"",o=`${ge} ${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(`${ve} ${e}`);}warn(e,t){if(this.logCollector.record("warn",e,t?.code),!(t?.verboseOnly&&this.mode!=="verbose")){if(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(`${z} ${e}`);}}error(e,t){this.logCollector.record("error",e,t?.code),!(t?.verboseOnly&&this.mode!=="verbose")&&this.writeLine(`${ge} ${e}`);}detail(e){this.logCollector.record("info",e),this.mode==="verbose"&&this.writeLine(` ${ie.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"?x:e==="fail"?ge:ie.muted("-")} ${e==="skip"?ie.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(),n.activeInstance===this&&(n.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(`${z} ${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(`${z} ${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+`
56
57
  `),this.spinner.text=this.spinner.text):this.stream.write(e+`
57
- `);}catch(t){let r=t?.code;if(r&&Jp.has(r))return;try{process.stderr.write(`reporter write failed: ${String(t)}
58
- `);}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(Cn).join(" ");this.logCollector.record("info",t),this.writeLine(t);},console.warn=(...e)=>{let t=e.map(Cn).join(" ");this.logCollector.record("warn",t),this.writeLine(t);},console.error=(...e)=>{let t=e.map(Cn).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 Yp,_r,zo=g(()=>{sn();Yp=promisify(_n__default.gunzip),_r=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=_n__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,on(Buffer.concat(t)).toString("base64")}async compress(e){let t=[],r=_n__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,on(Buffer.concat(t)).toString("base64")}async decompress(e){let t=Buffer.from(e,"base64"),r=await Yp(t);return JSON.parse(r.toString("utf-8"))}};});function Xp(i){try{return process.kill(i,0),!0}catch(e){return e.code==="EPERM"}}function Ko(i){let e=JSON.stringify(i);try{return Le.writeFileSync(rt,e,{flag:"wx",mode:384}),!0}catch(t){if(t.code==="EEXIST")return false;throw t}}function Pn(){let i;try{i=Le.readFileSync(rt,"utf8");}catch{return null}try{let e=JSON.parse(i);return typeof e.pid!="number"||typeof e.projectPath!="string"||typeof e.startTime!="string"?null:e}catch{return null}}function Yo(i){Le.mkdirSync(qo,{recursive:true,mode:448});let e={pid:process.pid,projectPath:R.resolve(i),startTime:new Date().toISOString()};if(Ko(e))return {ok:true,release:Vo(e)};let t=Pn();if(t===null||!Xp(t.pid)){try{Le.unlinkSync(rt);}catch(o){if(o.code!=="ENOENT")throw o}if(Ko(e))return {ok:true,release:Vo(e)};let r=Pn();return r!==null?{ok:false,reason:"held",holder:r}:{ok:false,reason:"indeterminate"}}return {ok:false,reason:"held",holder:t}}function Vo(i){let e=false;return ()=>{if(e)return;e=true;let t=Pn();if(!(t?.pid!==i.pid||t?.startTime!==i.startTime))try{Le.unlinkSync(rt);}catch(r){if(r.code!=="ENOENT")throw r}}}function Xo(i){let e=Date.now()-new Date(i.startTime).getTime(),t=Qp(e);return `Another \`constellation index\` is already running (pid ${i.pid}, project ${i.projectPath}, started ${t} ago).
59
- Wait for it to finish, or kill it, then retry.`}function Qp(i){let e=Math.max(0,i);if(e<1e3)return `${e}ms`;let t=Math.round(e/1e3);if(t<60)return `${t}s`;let r=Math.floor(t/60),o=t%60;if(r<60)return o===0?`${r}m`:`${r}m${o}s`;let s=Math.floor(r/60),a=r%60;return a===0?`${s}h`:`${s}h${a}m`}var qo,rt,Qo=g(()=>{qo=R.join($e.homedir(),".constellation","locks"),rt=R.join(qo,"index.lock");});function nt(i,e){let t=e??i;return {line:t.startPosition.row+1,column:t.startPosition.column}}function it(i){return i?i.text:null}function Pr(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 es(i){let e=new Set,t=r=>{if(r.type==="export_statement"&&!Zp(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 Zp(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 is(){return {language:"javascript",handlers:new Map(ns)}}function os(){return {language:"typescript",handlers:new Map([...ns,["interface_declaration",tu],["public_field_definition",Zo],["property_signature",Zo],["function_signature",ts],["method_signature",rs]])}}var ts,eu,tu,rs,Zo,ru,ns,In=g(()=>{ts=(i,e)=>{let t=i.childForFieldName("name"),r=it(t);r&&e.symbols.push({name:r,kind:"function",...nt(i,t),isExported:Pr(i,r,e)});},eu=(i,e)=>{let t=i.childForFieldName("name"),r=it(t);if(!r)return;let o=Pr(i,r,e);return e.symbols.push({name:r,kind:"class",...nt(i,t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},tu=(i,e)=>{let t=i.childForFieldName("name"),r=it(t);if(!r)return;let o=Pr(i,r,e);return e.symbols.push({name:r,kind:"interface",...nt(i,t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},rs=(i,e)=>{let t=i.childForFieldName("name"),r=it(t);r&&e.symbols.push({name:r,kind:"method",...nt(i,t),isExported:e.enclosingExported??false});},Zo=(i,e)=>{let t=i.childForFieldName("name"),r=it(t);r&&e.symbols.push({name:r,kind:"property",...nt(i,t),isExported:e.enclosingExported??false});},ru=(i,e)=>{let t=i.childForFieldName("name"),r=it(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",...nt(i,t),isExported:Pr(i,r,e)});},ns=[["function_declaration",ts],["class_declaration",eu],["method_definition",rs],["variable_declarator",ru]];});function Rn(i){return {line:i.startPosition.row+1,column:i.startPosition.column}}function Nn(i){return !i.startsWith("_")}function ss(){return {language:"python",handlers:new Map([["function_definition",nu],["class_definition",iu],["assignment",ou]])}}var nu,iu,ou,as=g(()=>{nu=(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});},iu=(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}},ou=(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 ls,cs=g(()=>{In();as();ls=[is(),os(),ss()];});var Ir,ps=g(()=>{cs();In();Ir=class{languageHandlers;constructor(e){this.languageHandlers=new Map;for(let t of e??ls)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"?es(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 su(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,p=l?l.text:c,u=c==="default";e.push({local:p,original:c,isDefault:u,isNamespace:false});}}}return e}async function au(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?su(l):[];await ee(a,s,e,t,r,c);}async function lu(i,e,t,r){let o=i.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,"");await ee(a,s,e,t,r,[]);}async function cu(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 p=a.child(1);l=p?.type==="string_fragment"&&p.text?p.text:"<dynamic>";}else l="<dynamic>";if(!l)return;let c=i.startPosition.row;await ee(l,c,e,t,r,[]);}function Rr(){return {language:"javascript",handlers:new Map([["import_statement",au],["export_statement",lu],["call_expression",cu]])}}function Tn(){let i=Rr();return {language:"typescript",handlers:new Map(i.handlers)}}var Ln=g(()=>{Ye();});function uu(i){let e=i.trim();return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}function du(i,e){let t=i.childForFieldName("name");if(t){let o=t.text,s=t.type==="dot"||o===".";return {local:o,original:e,isDefault:false,isNamespace:s}}return {local:e.split("/").pop()??e,original:e,isDefault:false,isNamespace:false}}async function us(i,e,t,r){let o=i.childForFieldName("path");if(!o)return;let s=uu(o.text);if(!s)return;let a=du(i,s);await ee(s,i.startPosition.row,e,t,r,a?[a]:[]);}async function mu(i,e,t,r){for(let o=0;o<i.namedChildCount;o++){let s=i.namedChild(o);if(s){if(s.type==="import_spec")await us(s,e,t,r);else if(s.type==="import_spec_list")for(let a=0;a<s.namedChildCount;a++){let l=s.namedChild(a);l&&l.type==="import_spec"&&await us(l,e,t,r);}}}}function kn(){return {language:"go",handlers:new Map([["import_declaration",mu]]),classifyImportType:pu}}var pu,jn=g(()=>{gr();Ye();gr();pu=(i,e,t)=>{if(t){let r=i.split("/")[0];return !r.includes(".")&&mr.has(r)?"builtin":"external"}return "alias"};});var ds,ms=g(()=>{Ln();lr();jn();Ye();Ln();lr();jn();ds=[Rr(),Tn(),vn(),kn()];});var gs={};li(gs,{ImportExtractor:()=>An});var An,fs=g(()=>{ms();Ye();An=class{languageHandlers;classifiers;constructor(e){this.languageHandlers=new Map,this.classifiers=new Map;for(let t of e??ds)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)??yn,l={};return await this.walkAST(e.rootNode,async c=>{let p=s.get(c.type);p&&await p(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 It,hs,Fn,ys,vs,Nr=g(()=>{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"]),hs=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"]),Fn={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"]},ys={language:"javascript",textIncludedTypes:hs,fieldNames:Fn},vs={language:"typescript",textIncludedTypes:hs,fieldNames:Fn};});var gu,bs,Ss,$n=g(()=>{gu=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"]),bs={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"]},Ss={language:"python",textIncludedTypes:gu,fieldNames:bs,shouldIncludeText:i=>{if(i.type==="string"&&i.childCount>0)return false}};});var fu,Tr,ws,Lr=g(()=>{fu=new Set(["package_identifier","field_identifier","type_identifier","predeclared_identifier","blank_identifier","label_name","nil","true","false","iota","dot"]),Tr={package_clause:[],import_declaration:[],import_spec:["name","path"],function_declaration:["name","parameters","result","body","type_parameters"],method_declaration:["receiver","name","parameters","result","body"],method_elem:["name","parameters","result"],type_declaration:[],type_spec:["name","type","type_parameters"],type_alias:["name","type"],struct_type:[],interface_type:[],field_declaration:["name","type","tag"],parameter_declaration:["name","type"],variadic_parameter_declaration:["name","type"],type_parameter_declaration:["name","type"],channel_type:["value"],pointer_type:[],slice_type:["element"],array_type:["length","element"],map_type:["key","value"],function_type:["parameters","result"],qualified_type:["package","name"],generic_type:["type","type_arguments"],var_declaration:[],const_declaration:[],var_spec:["name","type","value"],const_spec:["name","type","value"],short_var_declaration:["left","right"],assignment_statement:["left","right"],call_expression:["function","type_arguments","arguments"],selector_expression:["operand","field"],index_expression:["operand","index"],type_assertion_expression:["operand","type"],type_conversion_expression:["type","operand"],type_instantiation_expression:["type"],composite_literal:["type","body"],keyed_element:[],unary_expression:["operand"],binary_expression:["left","right"],parenthesized_expression:[],func_literal:["parameters","result","body"],if_statement:["initializer","condition","consequence","alternative"],for_statement:["body"],for_clause:["initializer","condition","update"],range_clause:["left","right"],expression_switch_statement:["initializer","value"],type_switch_statement:["initializer","alias","value"],expression_case:["value"],type_case:["type"],default_case:[],select_statement:[],communication_case:["communication"],send_statement:["channel","value"],receive_statement:["left","right"],return_statement:[],go_statement:[],defer_statement:[],break_statement:[],continue_statement:[],goto_statement:[],labeled_statement:["label"]},ws={language:"go",textIncludedTypes:fu,fieldNames:Tr,shouldIncludeText:i=>{switch(i.type){case "interpreted_string_literal":case "raw_string_literal":case "rune_literal":case "int_literal":case "float_literal":case "imaginary_literal":case "comment":return false;default:return}}};});function xs(i){return Rt.get(i)}function Cs(i){if(!i)return It;let e=Rt.get(i);if(!e)return It;let t=new Set(It);for(let r of e.textIncludedTypes)t.add(r);return t}function Dn(i){if(!i){let t=Array.from(Rt.values()).map(r=>r.fieldNames);return Nt(...t)}let e=Rt.get(i);if(!e){let t=Array.from(Rt.values()).map(r=>r.fieldNames);return Nt(...t)}return e.fieldNames}var Rt,Es=g(()=>{On();Nr();$n();Lr();Nr();Nr();$n();Lr();Rt=new Map([["javascript",ys],["typescript",vs],["python",Ss],["go",ws]]);});var Ns={};li(Ns,{COMMON_FIELD_NAMES:()=>Gn,JS_TS_FIELD_NAMES:()=>Is,PYTHON_FIELD_NAMES:()=>Rs,TEXT_INCLUDED_TYPES:()=>_s,mergeFieldMaps:()=>Nt,serializeAST:()=>yu,serializeASTStream:()=>hu});function*hu(i,e,t){yield*Un(i,e,t);}function*Un(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)}`),Ps(i,t)&&(yield `,"text":${JSON.stringify(i.text)}`),i.childCount>0){yield ',"children":[';let o=(t?Dn(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*Un(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*Un(c,void 0,t));}yield "]";}yield "}";}async function yu(i,e,t){let r=Mn(i,e,t),o=t?Dn(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 p=a.treeNode.childForFieldName(c);if(p){a.fieldChildren.add(p);let u=Mn(p,c,t);a.serializedNode.children||(a.serializedNode.children=[]),a.serializedNode.children.push(u),s.push({treeNode:p,serializedNode:u,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=Mn(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 Mn(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 Ps(i,t)&&(r.text=i.text),r}function Ps(i,e){if(e){let r=xs(e);if(r?.shouldIncludeText){let s=r.shouldIncludeText(i);if(s===false)return false;if(s===true)return true}return Cs(e).has(i.type)||i.type.endsWith("_keyword")||i.type.endsWith("_operator")}return i.type==="string"&&i.childCount>0?false:_s.has(i.type)||i.type.endsWith("_keyword")||i.type.endsWith("_operator")}function Nt(...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 _s,Is,Rs,Gn,On=g(()=>{Es();Lr();_s=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"]);Is={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"]},Rs={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=Nt(Is,Rs,Tr);});var Tt,Ls=g(()=>{pn();qi();Xi();ao();xt();yr();Ao();$o();Oo();En();z();zo();Bt();bt();Qo();fe();dn();ps();Wt();Tt=class extends xe{scanner;parser;apiClient;compressor;buildConfigManagers=new Map;discoveredFiles=[];parseSymbols=new Map;parseContent=new Map;symbolExtractor=new Ir;constructor(e){if(super(e),!this.config||!this.langRegistry)throw new Error("index command requires a valid configuration");this.scanner=new wr(process.cwd()),this.parser=new Sr(this.langRegistry),this.compressor=new _r;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=Yo(process.cwd());if(!o.ok){let d=o.reason==="held"?Xo(o.holder):`Another \`constellation index\` may be running, but the lock file is in an indeterminate state. Re-run; if this persists, manually remove ${rt} and retry.`;this.reporter.error(d);let m=new Error(d);throw Ae(m),m}let s=o.release,a=()=>s(),l=d=>()=>{s(),process.exit(d==="SIGINT"?130:143);},c=l("SIGINT"),p=l("SIGTERM");process.on("exit",a),process.on("SIGINT",c),process.on("SIGTERM",p);let u="failed";try{let d=await this.getAccessKey();this.apiClient=new Vt(this.config,d,t,this.reporter),this.reporter.log(`${Se} Starting indexing procedure...
60
- `);let m=performance.now();await this.reporter.phase("Pre-flight checks",async j=>{let oe=j.step("Project access");await this.validateProject(),oe.ok("Project access validated");let $=j.step("Git branch");t?$.skip("Git branch validation skipped (--dirty)"):(await this.validateGitBranch(),$.ok("Git branch validated"));let se=j.step("Git status");t?se.skip("Git status validation skipped (--dirty)"):(await this.validateGitStatus(),se.ok("Working tree clean"));let ut=j.step("Repo sync");if(t?ut.skip("Repository sync skipped (--dirty)"):(await this.synchronizeChanges(),ut.ok("Repository synchronized")),this.buildConfigManagers.size>0){let Kr=j.step("Build configs"),L=0;for(let[,B]of this.buildConfigManagers.entries()){let O=await B.initialize();L+=O.length;}Kr.ok(L>0?`${L} build config(s) discovered`:"No build configs discovered");}},{successText:"Pre-flight checks complete"});let f=await this.reporter.phase("Determining index scope",()=>this.determineIndexScope(e),{successText:e?"Full index":"Index scope determined"}),h=await this.git.getLatestCommitHash(),S=await this.git.getCommitTimestamp();if(f.upToDate){this.reporter.summary(`${E} Index is already up-to-date for ${this.config.projectId} on ${this.config.branch} commit ${h.substring(0,8)}`),u="succeeded";return}let v=await this.reporter.phase("Claiming indexing lock",()=>this.apiClient.claimAstLock(this.config.projectId,this.config.branch,f.isIncremental,h,S),{successText:"Indexing lock claimed"});switch(v.remapped===!0&&(v.effectiveBranchName?this.reporter.warn(`--dirty: server is indexing as default branch "${v.effectiveBranchName}" (transmitted "${this.config.branch}").`):this.reporter.warn("--dirty: server reported a branch remap but did not include the effective branch name.")),v.status){case "current":this.reporter.summary(`${E} Index already up to date for branch ${this.config.branch} at commit ${h?.substring(0,8)||"unknown"}`),u="succeeded";return;case "duplicate":this.reporter.summary(`${E} Index for this commit is already in progress on the server.`),u="succeeded";return;case "superseded":this.reporter.summary(`${E} A newer commit is already being indexed; nothing to do.`),u="succeeded";return;case "queued":if(!v.queuedAttemptId)throw new Error("Server returned queued status without an attempt ID");await this.handleQueuedUpload(v.queuedAttemptId,f.isIncremental,h,S),u="succeeded";return;default:break}let y=!1,C=()=>{y||this.reporter.detail("Uploading metadata, processing, and indexing...");},P,b,_=new Promise((j,oe)=>{P=j,b=oe;}),w=new AbortController,I=()=>{},A=this.createIndexPipeline(f.isIncremental,S,C,P,(j,oe)=>I(j,oe)),k=null;try{let[,j]=await this.reporter.phase("Indexing files",async oe=>{let $=null,se=new Map,ut=()=>{let L=[];if($&&$.total>0){let B=Math.min(100,Math.round($.processed/$.total*100));if(B===100)L.push(`${E} Baseline index complete (${$.processed}/${$.total})`);else {let O=se?.size>0?`${Yr} `:"";L.push(`${O}Baseline index ${B}% (${$.processed}/${$.total})`);}}else L.push(`${E} Baseline index complete (${$?.processed}/${$?.total})`);for(let[B,O]of se){if(O.total<=0)continue;let ai=Math.min(100,Math.round(O.processed/O.total*100));ai===100?L.push(`${E} ${Pe(B)} enrichment complete (${O.processed}/${O.total})`):L.push(`${Yr} ${Pe(B)} enrichment ${ai}% (${O.processed}/${O.total})`);}oe.update(L.join(`
61
- `));};I=(L,B)=>{$={processed:L,total:B},ut();};let Kr=(L,B,O)=>{se.set(L,{processed:B,total:O}),ut();};return Promise.all([this.uploadToAPI(A,f.isIncremental,h,v.attemptId).then(L=>(y=!0,L)).catch(L=>{throw w.abort(L),b(L),y=!0,L}),_.then(L=>{let B=this.getEnrichmentEligibleLanguages(r,L);return B?(v.attemptId&&this.apiClient.startEnrichment(v.attemptId,this.config.projectId,this.config.branch),this.runLspEnrichment(L,B,this.parseSymbols,this.parseContent,w.signal,Kr).catch(O=>(w.signal.aborted||this.reporter.warn(`Index enrichment failed: ${O instanceof Error?O.message:String(O)}`,{code:"ENRICHMENT_FAILED"}),null))):null}).catch(()=>null)])},{successText:"Index baseline data uploaded"});k=j;}catch(j){throw y=!0,j}k&&k.length>0&&await this.reporter.phase("Enrichment upload",async()=>{try{let j=Yi(k);this.reporter.detail(`Uploading enrichment data (${k.length} files)...`);let oe=!1,$=null;try{oe=await this.apiClient.uploadEnrichment(j,this.config.projectId,this.config.branch,h);}catch(se){$=se;}if(oe)this.reporter.detail("Enrichment data uploaded to Constellation Service, index enhancement in progress");else {let se=$ instanceof Error?`: ${$.message}`:"";this.reporter.warn(`Enrichment upload failed${se} \u2014 re-run 'constellation index --full' after the server finishes baseline index processing to retry.`,{code:"ENRICHMENT_FAILED"});}}catch(j){this.reporter.warn(`Enrichment upload failed: ${j instanceof Error?j.message:String(j)}`,{code:"ENRICHMENT_FAILED"});}},{successText:"Index enrichment data uploaded"});let Oe=(performance.now()-m)/1e3,G=Math.floor(Oe/60),Y=(Oe%60).toFixed(3),zr=G>0?`${G}m ${Y}s`:`${Y}s`;this.reporter.summary(`
62
- ${E} Upload completed in ${zr}! Server indexing in progress.`),u="succeeded";}catch(d){if(d instanceof ge)throw d;if(d instanceof Ne){this.logIndexingInProgress(d.branchName||this.config?.branch),u="succeeded";return}if(d instanceof D)throw ve(d)||(this.reporter.error("Authentication failed.",{code:"AUTH_FAILURE"}),this.reporter.info(`Your access key may be invalid or expired. Run 'constellation auth'
63
- to set or update your access key.`),Ae(d)),d;if(d instanceof Ee)throw d;if(d instanceof Error&&d.message==="Access key not configured")throw Ae(d),d;if(ve(d))throw d;let m=d instanceof Error?d.message:"An unexpected error occurred";throw this.reporter.error(`Indexing failed: ${m}`),Ae(d),d}finally{s(),process.removeListener("SIGINT",c),process.removeListener("SIGTERM",p),process.removeListener("exit",a),this.parseSymbols.clear(),this.parseContent.clear();try{let m=process.env.CONSTELLATION_ERROR_REPORTING?.toLowerCase()==="false",f=this.apiClient?.isFeatureEnabled("cli_error_reporting")??!1,h=this.reporter.getReportableErrors();if(!m&&f&&h.length>0){let S=this.reporter.getEntries(),v=h.map(I=>({type:"CLI_ERROR",message:I.message,phase:"indexing"})).slice(0,100),y=S.filter(I=>I.level==="warn").map(I=>({type:"CLI_WARNING",message:I.message,phase:"indexing"})).slice(0,100),C=v.length,P=y.length,b=[];C>0&&b.push(`${C} error${C!==1?"s":""}`),P>0&&b.push(`${P} warning${P!==1?"s":""}`);let _=b.join(", "),w=globalThis.__constellationVersion??"unknown";await this.apiClient.reportErrors({errorSummary:_,errorData:{errors:v,warnings:y},logEntries:S.slice(0,1e3),cliVersion:w,outcome:u,indexType:e?"full":"incremental"});}}catch{}}}async getAccessKey(){let e=await this.env.getKey(we);if(!e)throw this.reporter.error("Access key not found.",{code:"ACCESS_KEY_MISSING"}),this.reporter.info(`Set the ${we} environment variable or run
64
- '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 ge)throw this.displayProjectValidationError(e),Ae(e),e;if(e instanceof Ce){this.reporter.detail("Project validated (first index)");return}if(e instanceof D)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.
58
+ `);}catch(t){let r=t?.code;if(r&&rd.has(r))return;try{process.stderr.write(`reporter write failed: ${String(t)}
59
+ `);}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(Mn).join(" ");this.logCollector.record("info",t),this.writeLine(t);},console.warn=(...e)=>{let t=e.map(Mn).join(" ");this.logCollector.record("warn",t),this.writeLine(t);},console.error=(...e)=>{let t=e.map(Mn).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 id,$r,Ps=f(()=>{gn();id=promisify(Gn__default.gunzip),$r=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=Gn__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,fn(Buffer.concat(t)).toString("base64")}async compress(e){let t=[],r=Gn__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,fn(Buffer.concat(t)).toString("base64")}async decompress(e){let t=Buffer.from(e,"base64"),r=await id(t);return JSON.parse(r.toString("utf-8"))}};});function od(n){try{return process.kill(n,0),!0}catch(e){return e.code==="EPERM"}}function Is(n){let e=JSON.stringify(n);try{return De.writeFileSync(mt,e,{flag:"wx",mode:384}),!0}catch(t){if(t.code==="EEXIST")return false;throw t}}function Bn(){let n;try{n=De.readFileSync(mt,"utf8");}catch{return null}try{let e=JSON.parse(n);return typeof e.pid!="number"||typeof e.projectPath!="string"||typeof e.startTime!="string"?null:e}catch{return null}}function Ls(n){De.mkdirSync(Ts,{recursive:true,mode:448});let e={pid:process.pid,projectPath:k.resolve(n),startTime:new Date().toISOString()};if(Is(e))return {ok:true,release:Rs(e)};let t=Bn();if(t===null||!od(t.pid)){try{De.unlinkSync(mt);}catch(o){if(o.code!=="ENOENT")throw o}if(Is(e))return {ok:true,release:Rs(e)};let r=Bn();return r!==null?{ok:false,reason:"held",holder:r}:{ok:false,reason:"indeterminate"}}return {ok:false,reason:"held",holder:t}}function Rs(n){let e=false;return ()=>{if(e)return;e=true;let t=Bn();if(!(t?.pid!==n.pid||t?.startTime!==n.startTime))try{De.unlinkSync(mt);}catch(r){if(r.code!=="ENOENT")throw r}}}function ks(n){let e=Date.now()-new Date(n.startTime).getTime(),t=sd(e);return `Another \`constellation index\` is already running (pid ${n.pid}, project ${n.projectPath}, started ${t} ago).
60
+ Wait for it to finish, or kill it, then retry.`}function sd(n){let e=Math.max(0,n);if(e<1e3)return `${e}ms`;let t=Math.round(e/1e3);if(t<60)return `${t}s`;let r=Math.floor(t/60),o=t%60;if(r<60)return o===0?`${r}m`:`${r}m${o}s`;let s=Math.floor(r/60),a=r%60;return a===0?`${s}h`:`${s}h${a}m`}var Ts,mt,js=f(()=>{Ts=k.join(He.homedir(),".constellation","locks"),mt=k.join(Ts,"index.lock");});function ft(n,e){let t=e??n;return {line:t.startPosition.row+1,column:t.startPosition.column}}function gt(n){return n?n.text:null}function Dr(n,e,t){for(let r=n.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 Fs(n){let e=new Set,t=r=>{if(r.type==="export_statement"&&!ad(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(n),e}function ad(n){for(let e=0;e<n.childCount;e++){let t=n.child(e)?.type;if(t==="from"||t==="string")return true}return false}function Ms(){return {language:"javascript",handlers:new Map(Os)}}function Us(){return {language:"typescript",handlers:new Map([...Os,["interface_declaration",cd],["public_field_definition",As],["property_signature",As],["function_signature",$s],["method_signature",Ds]])}}var $s,ld,cd,Ds,As,pd,Os,Hn=f(()=>{$s=(n,e)=>{let t=n.childForFieldName("name"),r=gt(t);r&&e.symbols.push({name:r,kind:"function",...ft(n,t),isExported:Dr(n,r,e)});},ld=(n,e)=>{let t=n.childForFieldName("name"),r=gt(t);if(!r)return;let o=Dr(n,r,e);return e.symbols.push({name:r,kind:"class",...ft(n,t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},cd=(n,e)=>{let t=n.childForFieldName("name"),r=gt(t);if(!r)return;let o=Dr(n,r,e);return e.symbols.push({name:r,kind:"interface",...ft(n,t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},Ds=(n,e)=>{let t=n.childForFieldName("name"),r=gt(t);r&&e.symbols.push({name:r,kind:"method",...ft(n,t),isExported:e.enclosingExported??false});},As=(n,e)=>{let t=n.childForFieldName("name"),r=gt(t);r&&e.symbols.push({name:r,kind:"property",...ft(n,t),isExported:e.enclosingExported??false});},pd=(n,e)=>{let t=n.childForFieldName("name"),r=gt(t);if(!r)return;let o=n.childForFieldName("value"),s=o?.type==="arrow_function"||o?.type==="function"||o?.type==="function_expression";e.symbols.push({name:r,kind:s?"function":"variable",...ft(n,t),isExported:Dr(n,r,e)});},Os=[["function_declaration",$s],["class_declaration",ld],["method_definition",Ds],["variable_declarator",pd]];});function zn(n){return {line:n.startPosition.row+1,column:n.startPosition.column}}function Wn(n){return !n.startsWith("_")}function Gs(){return {language:"python",handlers:new Map([["function_definition",ud],["class_definition",dd],["assignment",md]])}}var ud,dd,md,Bs=f(()=>{ud=(n,e)=>{let t=n.childForFieldName("name");if(!t)return;let r=t.text,o=e.enclosingType?"method":"function",s=Wn(r),a=o==="method"?(e.enclosingExported??false)&&s:s;e.symbols.push({name:r,kind:o,...zn(t),isExported:a});},dd=(n,e)=>{let t=n.childForFieldName("name");if(!t)return;let r=t.text,o=Wn(r);return e.symbols.push({name:r,kind:"class",...zn(t),isExported:o}),{...e,enclosingType:r,enclosingExported:o}},md=(n,e)=>{let t=n.childForFieldName("left");if(!t||t.type!=="identifier")return;let r=t.text,o=e.enclosingType?"property":"variable",s=Wn(r),a=o==="property"?(e.enclosingExported??false)&&s:s;e.symbols.push({name:r,kind:o,...zn(t),isExported:a});};});var Hs,zs=f(()=>{Hn();Bs();Hs=[Ms(),Us(),Gs()];});var Or,Ws=f(()=>{zs();Hn();Or=class{languageHandlers;constructor(e){this.languageHandlers=new Map;for(let t of e??Hs)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"?Fs(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 fd(n){let e=[];for(let t=0;t<n.childCount;t++){let r=n.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 gd(n,e,t,r){let o=n.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,""),l=n.childForFieldName("import_clause"),c=l?fd(l):[];await X(a,s,e,t,r,c);}async function hd(n,e,t,r){let o=n.childForFieldName("source");if(!o)return;let s=o.startPosition.row,a=o.text.replace(/['"]/g,"");await X(a,s,e,t,r,[]);}async function yd(n,e,t,r){let o=n.childForFieldName("function");if(!o||o.type!=="import")return;let s=n.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=n.startPosition.row;await X(l,c,e,t,r,[]);}function Mr(){return {language:"javascript",handlers:new Map([["import_statement",gd],["export_statement",hd],["call_expression",yd]])}}function Kn(){let n=Mr();return {language:"typescript",handlers:new Map(n.handlers)}}var Vn=f(()=>{$e();});function bd(n){let e=n.trim();return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}function Sd(n,e){let t=n.childForFieldName("name");if(t){let o=t.text,s=t.type==="dot"||o===".";return {local:o,original:e,isDefault:false,isNamespace:s}}return {local:e.split("/").pop()??e,original:e,isDefault:false,isNamespace:false}}async function Ks(n,e,t,r){let o=n.childForFieldName("path");if(!o)return;let s=bd(o.text);if(!s)return;let a=Sd(n,s);await X(s,n.startPosition.row,e,t,r,a?[a]:[]);}async function wd(n,e,t,r){for(let o=0;o<n.namedChildCount;o++){let s=n.namedChild(o);if(s){if(s.type==="import_spec")await Ks(s,e,t,r);else if(s.type==="import_spec_list")for(let a=0;a<s.namedChildCount;a++){let l=s.namedChild(a);l&&l.type==="import_spec"&&await Ks(l,e,t,r);}}}}function Jn(){return {language:"go",handlers:new Map([["import_declaration",wd]]),classifyImportType:vd}}var vd,qn=f(()=>{wr();$e();wr();vd=(n,e,t)=>{if(t){let r=n.split("/")[0];return !r.includes(".")&&Sr.has(r)?"builtin":"external"}return "alias"};});function xd(n){for(let e of _d)if(n===e||n.startsWith(e+"."))return true;return false}function Ed(n,e){let t=n.childForFieldName("name");return t?{local:t.text.trim(),original:e,isDefault:false,isNamespace:true}:{local:e.split(".").pop()??e,original:e,isDefault:false,isNamespace:true}}function Pd(n){let e=null;for(let r=n.childCount-1;r>=0;r--){let o=n.child(r);if(o&&o.isNamed){e=o;break}}return e&&e.text.trim()||null}function Yn(){return {language:"c-sharp",handlers:new Map([["using_directive",Id]]),classifyImportType:Cd}}var _d,Cd,Id,Xn=f(()=>{$e();_d=["System","Microsoft.CSharp","Microsoft.VisualBasic","Microsoft.Win32"];Cd=(n,e,t)=>t?xd(n)?"builtin":"external":n.startsWith("./")||n.startsWith("../")?"relative":"alias";Id=async(n,e,t,r)=>{let o=Pd(n);if(!o)return;let s=Ed(n,o);await X(o,n.startPosition.row,e,t,r,[s]);};});var Vs,Js=f(()=>{Vn();gr();qn();Xn();$e();Vn();gr();qn();Xn();Vs=[Mr(),Kn(),Ln(),Jn(),Yn()];});var qs={};Ii(qs,{ImportExtractor:()=>Qn});var Qn,Ys=f(()=>{Js();$e();Qn=class{languageHandlers;classifiers;constructor(e){this.languageHandlers=new Map,this.classifiers=new Map;for(let t of e??Vs)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)??Tn,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 Dt,Xs,Zn,Qs,Zs,Ur=f(()=>{Dt=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"]),Xs=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"]),Zn={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"]},Qs={language:"javascript",textIncludedTypes:Xs,fieldNames:Zn},Zs={language:"typescript",textIncludedTypes:Xs,fieldNames:Zn};});var Rd,ea,ta,ei=f(()=>{Rd=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"]),ea={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"]},ta={language:"python",textIncludedTypes:Rd,fieldNames:ea,shouldIncludeText:n=>{if(n.type==="string"&&n.childCount>0)return false}};});var Nd,Gr,ra,Br=f(()=>{Nd=new Set(["package_identifier","field_identifier","type_identifier","predeclared_identifier","blank_identifier","label_name","nil","true","false","iota","dot"]),Gr={package_clause:[],import_declaration:[],import_spec:["name","path"],function_declaration:["name","parameters","result","body","type_parameters"],method_declaration:["receiver","name","parameters","result","body"],method_elem:["name","parameters","result"],type_declaration:[],type_spec:["name","type","type_parameters"],type_alias:["name","type"],struct_type:[],interface_type:[],field_declaration:["name","type","tag"],parameter_declaration:["name","type"],variadic_parameter_declaration:["name","type"],type_parameter_declaration:["name","type"],channel_type:["value"],pointer_type:[],slice_type:["element"],array_type:["length","element"],map_type:["key","value"],function_type:["parameters","result"],qualified_type:["package","name"],generic_type:["type","type_arguments"],var_declaration:[],const_declaration:[],var_spec:["name","type","value"],const_spec:["name","type","value"],short_var_declaration:["left","right"],assignment_statement:["left","right"],call_expression:["function","type_arguments","arguments"],selector_expression:["operand","field"],index_expression:["operand","index"],type_assertion_expression:["operand","type"],type_conversion_expression:["type","operand"],type_instantiation_expression:["type"],composite_literal:["type","body"],keyed_element:[],unary_expression:["operand"],binary_expression:["left","right"],parenthesized_expression:[],func_literal:["parameters","result","body"],if_statement:["initializer","condition","consequence","alternative"],for_statement:["body"],for_clause:["initializer","condition","update"],range_clause:["left","right"],expression_switch_statement:["initializer","value"],type_switch_statement:["initializer","alias","value"],expression_case:["value"],type_case:["type"],default_case:[],select_statement:[],communication_case:["communication"],send_statement:["channel","value"],receive_statement:["left","right"],return_statement:[],go_statement:[],defer_statement:[],break_statement:[],continue_statement:[],goto_statement:[],labeled_statement:["label"]},ra={language:"go",textIncludedTypes:Nd,fieldNames:Gr,shouldIncludeText:n=>{switch(n.type){case "interpreted_string_literal":case "raw_string_literal":case "rune_literal":case "int_literal":case "float_literal":case "imaginary_literal":case "comment":return false;default:return}}};});var Td,na,ia,ti=f(()=>{Td=new Set(["identifier","type_identifier","name_equals","qualified_name","predefined_type","null_literal","true","false","this_expression","base_expression","modifier"]),na={compilation_unit:[],extern_alias_directive:["name"],using_directive:["name"],namespace_declaration:["body","name"],file_scoped_namespace_declaration:["name"],global_statement:[],class_declaration:["body","name"],interface_declaration:["body","name","type_parameters"],struct_declaration:["body","name"],record_declaration:["body","name"],enum_declaration:["body","name"],delegate_declaration:["name","parameters","type","type_parameters"],method_declaration:["body","name","parameters","returns","type_parameters"],constructor_declaration:["body","name","parameters"],destructor_declaration:["body","name","parameters"],operator_declaration:["body","operator","parameters","type"],conversion_operator_declaration:["body","parameters","type"],property_declaration:["accessors","name","type","value"],indexer_declaration:["accessors","parameters","type","value"],event_declaration:["accessors","name","type"],event_field_declaration:[],field_declaration:[],enum_member_declaration:["name","value"],local_function_statement:["body","name","parameters","type","type_parameters"],variable_declaration:["type"],variable_declarator:["name"],parameter:["name","type"],parameter_list:[],bracketed_parameter_list:[],type_parameter:["name"],type_parameter_list:[],type_parameter_constraints_clause:[],generic_name:[],predefined_type:[],nullable_type:[],array_type:[],pointer_type:["type"],tuple_type:[],qualified_name:["name","qualifier"],alias_qualified_name:["alias","name"],attribute_list:[],attribute:["name"],attribute_argument:[],invocation_expression:["arguments","function"],member_access_expression:["expression","name"],element_access_expression:["expression","subscript"],conditional_access_expression:["condition"],object_creation_expression:["arguments","initializer","type"],implicit_object_creation_expression:[],cast_expression:["type","value"],lambda_expression:["body","parameters"],anonymous_method_expression:["parameters"],as_expression:["left","right"],is_expression:["left","right"],binary_expression:["left","operator","right"],prefix_unary_expression:[],postfix_unary_expression:[],assignment_expression:["left","operator","right"],conditional_expression:["alternative","condition","consequence"],is_pattern_expression:["expression","pattern"],switch_expression:[],from_clause:["name","type"],join_clause:["type"],declaration_pattern:["name","type"],constant_pattern:[],relational_pattern:[],type_pattern:["type"],property_pattern_clause:[],positional_pattern_clause:[],if_statement:["alternative","condition","consequence"],switch_statement:["body","value"],switch_section:[],for_statement:["body","condition","initializer","update"],foreach_statement:["body","left","right","type"],while_statement:["body","condition"],do_statement:["body","condition"],try_statement:["body"],catch_clause:["body"],catch_declaration:["name","type"],finally_clause:[],using_statement:[],lock_statement:[],checked_statement:[],unsafe_statement:[],fixed_statement:[],yield_statement:[],return_statement:[],throw_statement:[],throw_expression:[],break_statement:[],continue_statement:[],goto_statement:[],labeled_statement:[],initializer_expression:[],tuple_expression:[],accessor_list:[],accessor_declaration:["body","name"],arrow_expression_clause:[]},ia={language:"c-sharp",textIncludedTypes:Td,fieldNames:na,shouldIncludeText:n=>{switch(n.type){case "string_literal":case "verbatim_string_literal":case "interpolated_string_expression":case "interpolated_string_text":case "interpolated_verbatim_string_text":case "interpolation_text":case "raw_string_literal":case "character_literal":case "integer_literal":case "real_literal":case "comment":return false;default:return}}};});function oa(n){return Ot.get(n)}function sa(n){if(!n)return Dt;let e=Ot.get(n);if(!e)return Dt;let t=new Set(Dt);for(let r of e.textIncludedTypes)t.add(r);return t}function ri(n){if(!n){let t=Array.from(Ot.values()).map(r=>r.fieldNames);return Mt(...t)}let e=Ot.get(n);if(!e){let t=Array.from(Ot.values()).map(r=>r.fieldNames);return Mt(...t)}return e.fieldNames}var Ot,aa=f(()=>{ni();Ur();ei();Br();ti();Ur();Ur();ei();Br();ti();Ot=new Map([["javascript",Qs],["typescript",Zs],["python",ta],["go",ra],["c-sharp",ia]]);});var da={};Ii(da,{COMMON_FIELD_NAMES:()=>si,JS_TS_FIELD_NAMES:()=>pa,PYTHON_FIELD_NAMES:()=>ua,TEXT_INCLUDED_TYPES:()=>la,mergeFieldMaps:()=>Mt,serializeAST:()=>kd,serializeASTStream:()=>Ld});function*Ld(n,e,t){yield*oi(n,e,t);}function*oi(n,e,t){if(yield "{",yield `"type":${JSON.stringify(n.type)}`,yield `,"startPosition":${JSON.stringify({row:n.startPosition.row,column:n.startPosition.column})}`,yield `,"endPosition":${JSON.stringify({row:n.endPosition.row,column:n.endPosition.column})}`,e&&(yield `,"fieldName":${JSON.stringify(e)}`),ca(n,t)&&(yield `,"text":${JSON.stringify(n.text)}`),n.childCount>0){yield ',"children":[';let o=(t?ri(t):si)[n.type]||[],s=new Set,a=true;for(let l of o){let c=n.childForFieldName(l);c&&(a||(yield ","),a=false,s.add(c),yield*oi(c,l,t));}for(let l=0;l<n.childCount;l++){let c=n.child(l);c&&!s.has(c)&&(a||(yield ","),a=false,yield*oi(c,void 0,t));}yield "]";}yield "}";}async function kd(n,e,t){let r=ii(n,e,t),o=t?ri(t):si,s=[{treeNode:n,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=ii(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=ii(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 ii(n,e,t){let r={type:n.type,startPosition:{row:n.startPosition.row,column:n.startPosition.column},endPosition:{row:n.endPosition.row,column:n.endPosition.column},...e&&{fieldName:e}};return ca(n,t)&&(r.text=n.text),r}function ca(n,e){if(e){let r=oa(e);if(r?.shouldIncludeText){let s=r.shouldIncludeText(n);if(s===false)return false;if(s===true)return true}return sa(e).has(n.type)||n.type.endsWith("_keyword")||n.type.endsWith("_operator")}return n.type==="string"&&n.childCount>0?false:la.has(n.type)||n.type.endsWith("_keyword")||n.type.endsWith("_operator")}function Mt(...n){let e={};for(let t of n)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 la,pa,ua,si,ni=f(()=>{aa();Br();la=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"]);pa={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"]},ua={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"]};si=Mt(pa,ua,Gr);});var Ut,fa=f(()=>{bn();ho();vo();ko();nt();Rr();gs();ys();bs();Un();q();Ps();Zt();Tt();js();oe();wn();Ws();er();Ut=class extends Ie{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 kr(process.cwd()),this.parser=new Lr(this.langRegistry),this.compressor=new $r;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=Ls(process.cwd());if(!o.ok){let d=o.reason==="held"?ks(o.holder):`Another \`constellation index\` may be running, but the lock file is in an indeterminate state. Re-run; if this persists, manually remove ${mt} and retry.`;this.reporter.error(d);let m=new Error(d);throw Ue(m),m}let s=o.release,a=()=>s(),l=d=>()=>{s(),process.exit(d==="SIGINT"?130:143);},c=l("SIGINT"),u=l("SIGTERM");process.on("exit",a),process.on("SIGINT",c),process.on("SIGTERM",u);let p="failed";try{let d=await this.getAccessKey();this.apiClient=new ir(this.config,d,t,this.reporter),this.reporter.log(`${Ee} Starting indexing procedure...
61
+ `);let m=performance.now();await this.reporter.phase("Pre-flight checks",async $=>{let D=$.step("Project access");await this.validateProject(),D.ok("Project access validated");let A=$.step("Git branch");t?A.skip("Git branch validation skipped (--dirty)"):(await this.validateGitBranch(),A.ok("Git branch validated"));let ne=$.step("Git status");t?ne.skip("Git status validation skipped (--dirty)"):(await this.validateGitStatus(),ne.ok("Working tree clean"));let We=$.step("Repo sync");if(t?We.skip("Repository sync skipped (--dirty)"):(await this.synchronizeChanges(),We.ok("Repository synchronized")),this.buildConfigManagers.size>0){let wt=$.step("Build configs"),_t=0;for(let[,rn]of this.buildConfigManagers.entries()){let L=await rn.initialize();_t+=L.length;}wt.ok(_t>0?`${_t} build config(s) discovered`:"No build configs discovered");}},{successText:"Pre-flight checks complete"});let g=await this.reporter.phase("Determining index scope",()=>this.determineIndexScope(e),{successText:e?"Full index":"Index scope determined"}),h=await this.git.getLatestCommitHash(),b=await this.git.getCommitTimestamp();if(g.upToDate){this.reporter.summary(`${x} Index is already up-to-date for ${this.config.projectId} on ${this.config.branch} commit ${h.substring(0,8)}`),p="succeeded";return}let y=await this.reporter.phase("Claiming indexing lock",()=>this.apiClient.claimAstLock(this.config.projectId,this.config.branch,g.isIncremental,h,b),{successText:"Indexing lock claimed"});switch(y.remapped===!0&&(y.effectiveBranchName?this.reporter.warn(`--dirty: server is indexing as default branch "${y.effectiveBranchName}" (transmitted "${this.config.branch}").`):this.reporter.warn("--dirty: server reported a branch remap but did not include the effective branch name.")),y.status){case "current":this.reporter.summary(`${x} Index already up to date for branch ${this.config.branch} at commit ${h?.substring(0,8)||"unknown"}`),p="succeeded";return;case "duplicate":this.reporter.summary(`${x} Index for this commit is already in progress on the server.`),p="succeeded";return;case "superseded":this.reporter.summary(`${x} A newer commit is already being indexed; nothing to do.`),p="succeeded";return;case "queued":if(!y.queuedAttemptId)throw new Error("Server returned queued status without an attempt ID");await this.handleQueuedUpload(y.queuedAttemptId,g.isIncremental,h,b),p="succeeded";return;default:break}let S=!1,E=()=>{S||this.reporter.detail("Uploading metadata, processing, and indexing...");},T,w,P=new Promise(($,D)=>{T=$,w=D;}),N=new AbortController,I=()=>{},v=this.createIndexPipeline(g.isIncremental,b,E,T,($,D)=>I($,D)),R=null;try{let[,$]=await this.reporter.phase("Indexing files",async D=>{let A=null,ne=new Map,We=new Set,wt=()=>{let L=[];if(A&&A.total>0){let G=Math.min(100,Math.round(A.processed/A.total*100));if(G===100)L.push(`${x} Baseline index complete (${A.processed}/${A.total})`);else {let W=ne?.size>0?`${Yt} `:"";L.push(`${W}Baseline index ${G}% (${A.processed}/${A.total})`);}}else L.push(`${x} Baseline index complete (${A?.processed}/${A?.total})`);for(let[G,W]of ne){if(W.total<=0)continue;let Pi=Math.min(100,Math.round(W.processed/W.total*100));Pi===100?L.push(`${x} ${te(G)} enrichment complete (${W.processed}/${W.total})`):L.push(`${Yt} ${te(G)} enrichment ${Pi}% (${W.processed}/${W.total})`);}for(let G of We)ne.has(G)||L.push(`${Yt} LSP (${te(G)}) initializing\u2026`);D.update(L.join(`
62
+ `));};I=(L,G)=>{A={processed:L,total:G},wt();};let _t=(L,G,W)=>{ne.set(L,{processed:G,total:W}),wt();},rn=(L,G)=>{G==="initializing"?We.add(L):(We.delete(L),G==="ready"&&D.step(`LSP (${te(L)}) initialized`).ok()),wt();};return Promise.all([this.uploadToAPI(v,g.isIncremental,h,y.attemptId).then(L=>(S=!0,L)).catch(L=>{throw N.abort(L),w(L),S=!0,L}),P.then(L=>{let G=this.getEnrichmentEligibleLanguages(r,L);return G?(y.attemptId&&this.apiClient.startEnrichment(y.attemptId,this.config.projectId,this.config.branch),this.runLspEnrichment(L,G,this.parseSymbols,this.parseContent,N.signal,_t,rn).catch(W=>(N.signal.aborted||this.reporter.warn(`Index enrichment failed: ${W instanceof Error?W.message:String(W)}`,{code:"ENRICHMENT_FAILED"}),null))):null}).catch(L=>(N.signal.aborted||this.reporter.warn(`Index enrichment setup failed: ${L instanceof Error?L.message:String(L)}`,{code:"ENRICHMENT_FAILED"}),null))])},{successText:"Index baseline data uploaded"});R=$;}catch($){throw S=!0,$}R&&R.length>0&&await this.reporter.phase("Enrichment upload",async()=>{try{let $=yo(R);this.reporter.detail(`Uploading enrichment data (${R.length} files)...`);let D=!1,A=null;try{D=await this.apiClient.uploadEnrichment($,this.config.projectId,this.config.branch,h);}catch(ne){A=ne;}if(D)this.reporter.detail("Enrichment data uploaded to Constellation Service, index enhancement in progress");else {let ne=A instanceof Error?`: ${A.message}`:"";this.reporter.warn(`Enrichment upload failed${ne} \u2014 re-run 'constellation index --full' after the server finishes baseline index processing to retry.`,{code:"ENRICHMENT_FAILED"});}}catch($){this.reporter.warn(`Enrichment upload failed: ${$ instanceof Error?$.message:String($)}`,{code:"ENRICHMENT_FAILED"});}},{successText:"Index enrichment data uploaded"});let K=(performance.now()-m)/1e3,ye=Math.floor(K/60),J=(K%60).toFixed(3),M=ye>0?`${ye}m ${J}s`:`${J}s`;this.reporter.summary(`
63
+ ${x} Upload completed in ${M}! Server indexing in progress.`),p="succeeded";}catch(d){if(d instanceof Se)throw d;if(d instanceof je){this.logIndexingInProgress(d.branchName||this.config?.branch),p="succeeded";return}if(d instanceof H)throw xe(d)||(this.reporter.error("Authentication failed.",{code:"AUTH_FAILURE"}),this.reporter.info(`Your access key may be invalid or expired. Run 'constellation auth'
64
+ to set or update your access key.`),Ue(d)),d;if(d instanceof Ne)throw d;if(d instanceof Error&&d.message==="Access key not configured")throw Ue(d),d;if(xe(d))throw d;let m=d instanceof Error?d.message:"An unexpected error occurred";throw this.reporter.error(`Indexing failed: ${m}`),Ue(d),d}finally{s(),process.removeListener("SIGINT",c),process.removeListener("SIGTERM",u),process.removeListener("exit",a),this.parseSymbols.clear(),this.parseContent.clear();try{let m=process.env.CONSTELLATION_ERROR_REPORTING?.toLowerCase()==="false",g=this.apiClient?.isFeatureEnabled("cli_error_reporting")??!1,h=this.reporter.getReportableErrors();if(!m&&g&&h.length>0){let b=this.reporter.getEntries(),y=h.map(I=>({type:"CLI_ERROR",message:I.message,phase:"indexing"})).slice(0,100),S=b.filter(I=>I.level==="warn").map(I=>({type:"CLI_WARNING",message:I.message,phase:"indexing"})).slice(0,100),E=y.length,T=S.length,w=[];E>0&&w.push(`${E} error${E!==1?"s":""}`),T>0&&w.push(`${T} warning${T!==1?"s":""}`);let P=w.join(", "),N=globalThis.__constellationVersion??"unknown";await this.apiClient.reportErrors({errorSummary:P,errorData:{errors:y,warnings:S},logEntries:b.slice(0,1e3),cliVersion:N,outcome:p,indexType:e?"full":"incremental"});}}catch{}}}async getAccessKey(){let e=await this.env.getKey(Pe);if(!e)throw this.reporter.error("Access key not found.",{code:"ACCESS_KEY_MISSING"}),this.reporter.info(`Set the ${Pe} environment variable or run
65
+ '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),Ue(e),e;if(e instanceof Re){this.reporter.detail("Project validated (first index)");return}if(e instanceof H)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.
65
66
  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.
66
67
  `),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
67
68
  `);break;case "PROJECT_INACTIVE":this.reporter.error("Project is inactive",{code:"PROJECT_INACTIVE"}),this.reporter.log(` The project "${r}" has been deactivated.
@@ -70,7 +71,7 @@ ${E} Upload completed in ${zr}! Server indexing in progress.`),u="succeeded";}ca
70
71
  `),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
71
72
  `);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"}.
72
73
  Your index is up to date with the current operation.
73
- 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 Ee(`Outstanding changes detected.
74
+ 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 Ne(`Outstanding changes detected.
74
75
  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(`
75
76
  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
76
77
  `)):e.message.includes("merge conflicts")?(this.reporter.log(`
@@ -79,34 +80,34 @@ To resolve:`),this.reporter.log(" 1. Fix the conflicted files manually"),this.r
79
80
  Please check your internet connection and try again
80
81
  `):e.message.includes("Authentication")&&this.reporter.log(`
81
82
  Please check your git credentials and try again
82
- `)),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 D)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,p=c>0?`${de} Removing ${l} deleted file(s) and ${c} renamed file(s) from graph`:`${de} Removing ${l} deleted file(s) from graph`;this.reporter.log(p),await this.apiClient.deleteFiles(a);}}}catch(r){if(r instanceof D)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(),p=s>1e4?5:s>5e3?7:10;p<10&&this.reporter.detail(`Large project detected, using concurrency of ${p} to optimize memory usage`);let d=new ze(p,{preserveOrder:true}).run(e,async(m,f)=>{let h=Math.round((f+1)/s*100);this.reporter.detail(`Analyzing file ${m.path.replace(process.cwd()+"/","")} (${h}%)...`);try{let{tree:S,classificationMap:v,content:y}=await this.parser.parseFile(m.path,m.language),C=this.symbolExtractor.extract(S,m.language);C.length>0&&this.parseSymbols.set(this.normalizePathToCanonical(m.relativePath),C),y!==void 0&&this.parseContent.set(this.normalizePathToCanonical(m.relativePath),y),v.entries.length>5e4&&this.reporter.warn(`Large classification map for ${m.relativePath}: ${v.entries.length} entries`);let b=this.langRegistry.getPlugin(m.language),_;if(b?.getImportResolver){let Oe=this.buildConfigManagers.get(m.language),G=Oe?await Oe.getConfigForFile(m.path):null,Y=b.getImportResolver(m.path,G);if(Y){let{ImportExtractor:zr}=await Promise.resolve().then(()=>(fs(),gs));_=await new zr().extractImportResolutions(S,m.path,m.language,Y);}}let{serializeASTStream:w}=await Promise.resolve().then(()=>(On(),Ns)),I=w(S.rootNode,void 0,m.language),A=await this.compressor.compressStream(I),k=this.normalizePathToCanonical(m.relativePath),H={file:k,language:m.language,commit:c,timestamp:t,ast:A,importResolutions:_,classificationMap:{filePath:k,entries:v.entries}},T=Do.safeParse(H);if(!T.success)throw new Error(`Index validation failed: ${T.error.issues[0].message}`);return a++,o?.(a,s),T.data}catch(S){throw l++,o?.(a+l,s),this.reporter.warn(`Failed to parse ${m.relativePath}: ${S.message}`,{code:"PARSE_FAILURE"}),S}});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 Yt(e)}isLanguageLspEligible(e){let t=this.config.languages[e];return t?.lspEnrichment===false?false:!!t?.lsp||_e.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(Pe).join(", ")}`),new Set(o))}async runLspEnrichment(e,t,r,o,s,a){let l=new ir(process.cwd(),this.reporter);try{if(s?.aborted)return null;this.reporter.detail("Starting index enrichment...");let c=new Map,p=new Map;for(let y of e){if(!t.has(y.language))continue;let C=c.get(y.language)||[];C.push(this.normalizePathToCanonical(y.relativePath)),c.set(y.language,C);}let u=c.size,d=!1;for(let y of [...c.keys()]){if(s?.aborted)return null;let C=this.langRegistry?.getPlugin(y);if(!C?.preflightLsp)continue;let P;try{P=await C.preflightLsp(process.cwd());}catch(b){let _=b instanceof Error?b.message:String(b);this.reporter.warn(`LSP pre-flight failed for ${Pe(y)} (${_}); proceeding without skip.`);continue}P.skip&&(this.reporter.warn(P.message),c.delete(y),d=!0);}let m=d&&c.size===0&&u>0;for(let y of c.keys()){if(p.has(y))continue;let P=this.config.languages[y]?.lsp,b=await l.startServer(y,P);b&&p.set(y,b);}if(p.size===0)return m||this.reporter.warn("No language servers started, index enrichment skipped"),null;if(s?.aborted)return l.destroyAll(),null;this.reporter.detail(`Language servers started: ${[...p.keys()].map(Pe).join(", ")}`);let f=new Qt(process.cwd(),this.reporter),h=s?new Promise((y,C)=>{s.addEventListener("abort",()=>{l.destroyAll(),C(s.reason||new Error("Indexing aborted"));},{once:!0});}):null,S=await(h?Promise.race([f.enrich(c,r,p,o,a),h]):f.enrich(c,r,p,o,a)),v=S.reduce((y,C)=>y+C.symbols.length,0);return this.reporter.detail(`Index enrichment analysis completed: ${v} symbols across ${S.length} files`),S.length>0?S: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 Bn(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 kr(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 jr(i){let{includeEntry:e,job:t}=kr(i);return stringify({include:[e],"constellation-index":t},{lineWidth:0})}var Wn=g(()=>{});var Lt,As=g(()=>{ce();Wn();Lt=class{constructor(e){this.gitRoot=e;}async detectPlatforms(){let e=[],[t,r]=await Promise.all([x.directoryExists(R__default.join(this.gitRoot,".github","workflows")),x.fileIsReadable(R__default.join(this.gitRoot,".gitlab-ci.yml"))]);return t&&e.push("github"),r&&e.push("gitlab"),e}async githubWorkflowExists(){return x.fileIsReadable(R__default.join(this.gitRoot,".github","workflows","constellation-index.yml"))}async gitlabJobExists(){let e=R__default.join(this.gitRoot,".gitlab-ci.yml");if(!await x.fileIsReadable(e))return false;try{let r=await x.readFile(e),s=parseDocument(r).contents;return isMap(s)&&s.has("constellation-index")}catch{return false}}async createGitHubWorkflow(e){let t=R__default.join(this.gitRoot,".github","workflows");await Q__default.mkdir(t,{recursive:true});let r=R__default.join(t,"constellation-index.yml");return await x.writeFile(r,Bn(e)),r}async createOrMergeGitLabCI(e){let t=R__default.join(this.gitRoot,".gitlab-ci.yml");if(!await x.fileIsReadable(t))return await x.writeFile(t,jr(e)),t;let o=await x.readFile(t),s=parseDocument(o);if(!isMap(s.contents))return await x.writeFile(t,jr(e)),t;let{includeEntry:a,job:l}=kr(e);return this.mergeIncludeEntry(s,a),s.set("constellation-index",l),await x.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 Fs=g(()=>{As();Wn();});function zn(i){if(i.installedBinaryPath!==void 0)return existsSync(i.installedBinaryPath)?{ok:true,path:i.installedBinaryPath}:{ok:false,reason:"not-installed"};if(!he(i.prerequisite))return {ok:false,reason:"not-installed"};let e;try{e=execFileSync(i.verifyCommand[0],[...i.verifyCommand.slice(1)],{stdio:["ignore","pipe","pipe"],timeout:Eu,maxBuffer:Cu}).toString();}catch{return {ok:false,reason:"not-installed"}}let t=e.trim().split(/\r?\n/)[0]?.trim()??"";if(!t||!R.isAbsolute(t))return {ok:false,reason:"invalid-stdout"};let r=R.resolve(i.allowedRootPrefix),o;try{o=realpathSync(t);}catch{return {ok:false,reason:"not-installed"}}return o!==r&&!o.startsWith(r+R.sep)?{ok:false,reason:"untrusted-path"}:{ok:true,path:o}}var Cu,Eu,$s=g(()=>{ce();Cu=4096,Eu=1e4;});function Ds(i,e){let t=$e__default.homedir(),r=process.platform,o=Pu[i];switch(r){case "darwin":return R__default.join(t,"Library/Application Support",o,"User/globalStorage",e);case "win32":return R__default.join(process.env.APPDATA||R__default.join(t,"AppData/Roaming"),o,"User/globalStorage",e);default:return R__default.join(t,".config",o,"User/globalStorage",e)}}function Os(){let i="saoudrizwan.claude-dev";return ["stable","insiders"].map(t=>({variant:t,displayName:t==="stable"?"VS Code":"VS Code Insiders",settingsPath:R__default.join(Ds(t,i),"settings","cline_mcp_settings.json")}))}function Ms(){return R__default.join(Ds("stable","saoudrizwan.claude-dev"),"settings","cline_mcp_settings.json")}var Pu,Us=g(()=>{Pu={stable:"Code",insiders:"Code - Insiders"};});function Bs(i){return Kn.find(e=>e.id===i)}var Gs,Iu,Kn,Vn=g(()=>{Us();Gs={command:"npx",args:["-y","@constellationdev/mcp@latest"]},Iu={extraKnownMarketplaces:{"constellation-plugins":{source:{source:"github",repo:"ShiftinBits/constellation-claude"},autoUpdate:true}},enabledPlugins:{"constellation@constellation-plugins":true}},Kn=[{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:Iu},mcpServersKeyPath:["mcpServers"]},{id:"cline",displayName:"Cline",configPath:Ms(),isGlobalConfig:true,getGlobalConfigPaths:Os,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 Ws(){if(!Jn)try{let i=await import('@iarna/toml');Jn={parse:i.parse,stringify:i.stringify};}catch{throw new Error("TOML support requires @iarna/toml package. Install with: npm install @iarna/toml")}return Jn}function Tu(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]!==`
83
- `;)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 Jn,Ar,Hs=g(()=>{ce();Vn();Jn=null;Ar=class{cwd;constructor(e=process.cwd()){this.cwd=e;}async configureTool(e){try{let t=R__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=R__default.join(this.cwd,e.permissionsConfig.filePath):e.marketplaceConfig?o=R__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=R__default.dirname(e);await Q__default.mkdir(t,{recursive:true});}async readConfig(e,t){try{if(!await x.fileIsReadable(e))return {};let o=await x.readFile(e);return t==="json"?JSON.parse(o):t==="jsonc"?JSON.parse(Tu(o)):(await Ws()).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??Gs,l={...a};if(t.mcpServerExtras&&Object.assign(l,t.mcpServerExtras),t.mcpEnv){let c=t.mcpEnvKey??"env",p=a[c];l[c]={...p,...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 Ws()).stringify(t),o=o.replace(/\r\n/g,`
83
+ `)),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 H)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?`${ve} Removing ${l} deleted file(s) and ${c} renamed file(s) from graph`:`${ve} Removing ${l} deleted file(s) from graph`;this.reporter.log(u),await this.apiClient.deleteFiles(a);}}}catch(r){if(r instanceof H)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 Qe(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:S}=await this.parser.parseFile(m.path,m.language),E=this.symbolExtractor.extract(b,m.language);E.length>0&&this.parseSymbols.set(this.normalizePathToCanonical(m.relativePath),E),S!==void 0&&this.parseContent.set(this.normalizePathToCanonical(m.relativePath),S),y.entries.length>5e4&&this.reporter.warn(`Large classification map for ${m.relativePath}: ${y.entries.length} entries`);let w=this.langRegistry.getPlugin(m.language),P;if(w?.getImportResolver){let K=this.buildConfigManagers.get(m.language),ye=K?await K.getConfigForFile(m.path):null,J=w.getImportResolver(m.path,ye);if(J){let{ImportExtractor:M}=await Promise.resolve().then(()=>(Ys(),qs));P=await new M().extractImportResolutions(b,m.path,m.language,J);}}let{serializeASTStream:N}=await Promise.resolve().then(()=>(ni(),da)),I=N(b.rootNode,void 0,m.language),v=await this.compressor.compressStream(I),R=this.normalizePathToCanonical(m.relativePath),_={file:R,language:m.language,commit:c,timestamp:t,ast:v,importResolutions:P,classificationMap:{filePath:R,entries:y.entries}},O=vs.safeParse(_);if(!O.success)throw new Error(`Index validation failed: ${O.error.issues[0].message}`);return a++,o?.(a,s),O.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"),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 ar(e)}isLanguageLspEligible(e){let t=this.config.languages[e];return t?.lspEnrichment===false?false:!!t?.lsp||Te.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 r=new Set(t.map(s=>s.language)),o=[...r].filter(s=>this.isLanguageLspEligible(s));if(o.length===0){let s=[...r].filter(a=>a).map(te).join(", ");return this.reporter.detail(s?`Index enrichment skipped: no LSP enrichment configured for scanned language(s): ${s}`:"Index enrichment skipped: no language-tagged files were found to enrich"),null}return this.reporter.detail(`Index enrichment enabled for: ${o.map(te).join(", ")}`),new Set(o)}async runLspEnrichment(e,t,r,o,s,a,l){let c=this.reporter,u={log:d=>c.detail(d),warn:d=>c.warn(d,{verboseOnly:true}),error:d=>c.error(d,{verboseOnly:true})},p=new ur(process.cwd(),u);try{if(s?.aborted)return null;this.reporter.detail("Starting index enrichment...");let d=new Map,m=new Map;for(let w of e){if(!t.has(w.language))continue;let P=d.get(w.language)||[];P.push(this.normalizePathToCanonical(w.relativePath)),d.set(w.language,P);}let g=d.size,h=!1;for(let w of [...d.keys()]){if(s?.aborted)return null;let P=this.langRegistry?.getPlugin(w);if(!P?.preflightLsp)continue;let N;try{N=await P.preflightLsp(process.cwd());}catch(I){let v=I instanceof Error?I.message:String(I);this.reporter.warn(`LSP pre-flight failed for ${te(w)} (${v}); proceeding without skip.`);continue}N.skip&&(this.reporter.warn(N.message),d.delete(w),h=!0);}let b=h&&d.size===0&&g>0;for(let w of d.keys()){if(m.has(w))continue;let N=this.config.languages[w]?.lsp;l?.(w,"initializing");let I=null;try{I=await p.startServer(w,N),I&&m.set(w,I);}finally{l?.(w,I?"ready":"failed");}}if(m.size===0)return b||this.reporter.warn("No language servers started, index enrichment skipped"),null;if(s?.aborted)return p.destroyAll(),null;this.reporter.detail(`Language servers started: ${[...m.keys()].map(te).join(", ")}`);let y=new lr(process.cwd(),this.reporter),S=s?new Promise((w,P)=>{s.addEventListener("abort",()=>{p.destroyAll(),P(s.reason||new Error("Indexing aborted"));},{once:!0});}):null,E=await(S?Promise.race([y.enrich(d,r,m,o,a),S]):y.enrich(d,r,m,o,a)),T=E.reduce((w,P)=>w+P.symbols.length,0);return this.reporter.detail(`Index enrichment analysis completed: ${T} symbols across ${E.length} files`),E.length>0?E:null}catch(d){return this.reporter.warn(`Index enrichment failed: ${d instanceof Error?d.message:String(d)}`,{code:"ENRICHMENT_FAILED"}),null}finally{await p.shutdownAll();}}};});function ai(n){return stringify({name:"Constellation Index",on:{push:{branches:[n]}},permissions:{contents:"read"},jobs:{index:{"runs-on":"ubuntu-latest",steps:[{uses:"actions/checkout@v4",with:{"fetch-depth":0}},{uses:"ShiftinBits/constellation-github@v1",with:{"access-key":"${{ secrets.CONSTELLATION_ACCESS_KEY }}"}}]}}},{lineWidth:0})}function Hr(n){return {includeEntry:{component:"gitlab.com/shiftinbits/constellation-gitlab/constellation-index@1",inputs:{access_key:"$CONSTELLATION_ACCESS_KEY"}},job:{variables:{GIT_DEPTH:"0"},rules:[{if:`$CI_COMMIT_BRANCH == "${n}"`}]}}}function zr(n){let{includeEntry:e,job:t}=Hr(n);return stringify({include:[e],"constellation-index":t},{lineWidth:0})}var li=f(()=>{});var Gt,ya=f(()=>{le();li();Gt=class{constructor(e){this.gitRoot=e;}async detectPlatforms(){let e=[],[t,r]=await Promise.all([C.directoryExists(k__default.join(this.gitRoot,".github","workflows")),C.fileIsReadable(k__default.join(this.gitRoot,".gitlab-ci.yml"))]);return t&&e.push("github"),r&&e.push("gitlab"),e}async githubWorkflowExists(){return C.fileIsReadable(k__default.join(this.gitRoot,".github","workflows","constellation-index.yml"))}async gitlabJobExists(){let e=k__default.join(this.gitRoot,".gitlab-ci.yml");if(!await C.fileIsReadable(e))return false;try{let r=await C.readFile(e),s=parseDocument(r).contents;return isMap(s)&&s.has("constellation-index")}catch{return false}}async createGitHubWorkflow(e){let t=k__default.join(this.gitRoot,".github","workflows");await se__default.mkdir(t,{recursive:true});let r=k__default.join(t,"constellation-index.yml");return await C.writeFile(r,ai(e)),r}async createOrMergeGitLabCI(e){let t=k__default.join(this.gitRoot,".gitlab-ci.yml");if(!await C.fileIsReadable(t))return await C.writeFile(t,zr(e)),t;let o=await C.readFile(t),s=parseDocument(o);if(!isMap(s.contents))return await C.writeFile(t,zr(e)),t;let{includeEntry:a,job:l}=Hr(e);return this.mergeIncludeEntry(s,a),s.set("constellation-index",l),await C.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 va=f(()=>{ya();li();});function pi(n){if(n.installedBinaryPath!==void 0)return existsSync(n.installedBinaryPath)?{ok:true,path:n.installedBinaryPath}:{ok:false,reason:"not-installed"};if(!ae(n.prerequisite))return {ok:false,reason:"not-installed"};let e;try{e=execFileSync(n.verifyCommand[0],[...n.verifyCommand.slice(1)],{stdio:["ignore","pipe","pipe"],timeout:Md,maxBuffer:Od}).toString();}catch{return {ok:false,reason:"not-installed"}}let t=e.trim().split(/\r?\n/)[0]?.trim()??"";if(!t||!k.isAbsolute(t))return {ok:false,reason:"invalid-stdout"};let r=k.resolve(n.allowedRootPrefix),o;try{o=realpathSync(t);}catch{return {ok:false,reason:"not-installed"}}return o!==r&&!o.startsWith(r+k.sep)?{ok:false,reason:"untrusted-path"}:{ok:true,path:o}}var Od,Md,ba=f(()=>{le();Od=4096,Md=1e4;});function Sa(n,e){let t=He__default.homedir(),r=process.platform,o=Gd[n];switch(r){case "darwin":return k__default.join(t,"Library/Application Support",o,"User/globalStorage",e);case "win32":return k__default.join(process.env.APPDATA||k__default.join(t,"AppData/Roaming"),o,"User/globalStorage",e);default:return k__default.join(t,".config",o,"User/globalStorage",e)}}function wa(){let n="saoudrizwan.claude-dev";return ["stable","insiders"].map(t=>({variant:t,displayName:t==="stable"?"VS Code":"VS Code Insiders",settingsPath:k__default.join(Sa(t,n),"settings","cline_mcp_settings.json")}))}function _a(){return k__default.join(Sa("stable","saoudrizwan.claude-dev"),"settings","cline_mcp_settings.json")}var Gd,xa=f(()=>{Gd={stable:"Code",insiders:"Code - Insiders"};});function Ea(n){return ui.find(e=>e.id===n)}var Ca,Bd,ui,di=f(()=>{xa();Ca={command:"npx",args:["-y","@constellationdev/mcp@latest"]},Bd={extraKnownMarketplaces:{"constellation-plugins":{source:{source:"github",repo:"ShiftinBits/constellation-claude"},autoUpdate:true}},enabledPlugins:{"constellation@constellation-plugins":true}},ui=[{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:Bd},mcpServersKeyPath:["mcpServers"]},{id:"cline",displayName:"Cline",configPath:_a(),isGlobalConfig:true,getGlobalConfigPaths:wa,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 Pa(){if(!mi)try{let n=await import('@iarna/toml');mi={parse:n.parse,stringify:n.stringify};}catch{throw new Error("TOML support requires @iarna/toml package. Install with: npm install @iarna/toml")}return mi}function Wd(n){let e="",t=0,r=n.length;for(;t<r;)if(n[t]==='"'){for(e+='"',t++;t<r&&n[t]!=='"';)n[t]==="\\"?(e+=n[t++],t<r&&(e+=n[t++])):e+=n[t++];t<r&&(e+=n[t++]);}else if(n[t]==="/"&&t+1<r&&n[t+1]==="/")for(t+=2;t<r&&n[t]!==`
84
+ `;)t++;else if(n[t]==="/"&&t+1<r&&n[t+1]==="*"){for(t+=2;t<r&&!(n[t]==="*"&&t+1<r&&n[t+1]==="/");)t++;t<r&&(t+=2);}else e+=n[t++];return e.replace(/,(\s*[}\]])/g,"$1")}var mi,Wr,Ia=f(()=>{le();di();mi=null;Wr=class{cwd;constructor(e=process.cwd()){this.cwd=e;}async configureTool(e){try{let t=k__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=k__default.join(this.cwd,e.permissionsConfig.filePath):e.marketplaceConfig?o=k__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=k__default.dirname(e);await se__default.mkdir(t,{recursive:true});}async readConfig(e,t){try{if(!await C.fileIsReadable(e))return {};let o=await C.readFile(e);return t==="json"?JSON.parse(o):t==="jsonc"?JSON.parse(Wd(o)):(await Pa()).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??Ca,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 Pa()).stringify(t),o=o.replace(/\r\n/g,`
84
85
  `),o.endsWith(`
85
86
  `)||(o+=`
86
- `),await x.writeFile(e,o);}async configurePermissions(e){let t=R__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let r={};try{if(await x.fileIsReadable(t)){let c=await x.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 x.writeFile(t,JSON.stringify(r,null," ")+`
87
- `);}async configureMarketplace(e){let t=R__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let r={};try{if(await x.fileIsReadable(t)){let s=await x.readFile(t);r=JSON.parse(s);}}catch{}r=this.deepMerge(r,e.config),await x.writeFile(t,JSON.stringify(r,null," ")+`
88
- `);}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(/^~/,$e__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 Fr(i,e){let t=R__default.normalize(i),r=R__default.normalize(e);return t.startsWith(r+R__default.sep)?R__default.relative(e,i):i}var Fu,kt,Js=g(()=>{Fs();xt();$s();yr();Hs();Vn();ce();z();Wt();Ut();Fu=promisify(execFile);kt=class extends xe{async run(e={}){try{if(this.reporter.log(`${Se} Initializing project configuration...
89
- `),!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=R__default.join(process.cwd(),"constellation.json"),o=null,s=await x.fileIsReadable(r);if(s)try{let b=await x.readFile(r);o=JSON.parse(b),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,p]=await Promise.all([this.git.status(),this.git.listBranches()]),{currentBranch:u}=c,d=p.filter(b=>b!==u),m=u?[u,...d]:d,f=await input({message:"Constellation Project ID:",default:o?.projectId??"",validate:b=>b.trim().length>0||"Project ID is required",theme:U}),h=await select({message:"Branch to index:",choices:m.map(b=>({name:b,value:b})),default:o?.branch??m[0],theme:U}),v=(await checkbox({message:"Select Language(s):",choices:this.buildLanguageChoices(o),required:!0,theme:U})).reduce((b,_)=>(b[_]={fileExtensions:Ze[_]||[]},b),{});this.reporter.log(""),this.reporter.info("Checking for LSP servers...");for(let[b,_]of Object.entries(v)){let w=_e.get(b);if(!w)continue;let I=!1,A="";if(he(w.command)&&(I=!0,A="system"),!I){let T=R__default.join(rr,w.command);existsSync(T)&&(I=!0,A="managed");}let k=w.manualInstall?.autoInstall,H;if(!I&&k){let T=zn(k);T.ok&&(H=T.path,I=!0,A="managed");}if(I)this.reporter.log(`${E} ${b}: Found ${w.command} (${A})`),_.lsp={command:A==="managed"&&H!==void 0?H:w.command,args:w.args};else if(w.npmPackages.length===0&&w.manualInstall){let T=w.manualInstall.autoInstall;if(T&&he(T.prerequisite)){if(T.installedBinaryPath!==void 0){let G=R__default.resolve(Ke),Y=R__default.resolve(T.installedBinaryPath);if(!Y.startsWith(G+R__default.sep)){this.reporter.error(`${b}: installedBinaryPath (${Y}) is outside the managed directory; refusing to install. Report this as a bug.`),_.lspEnrichment=!1;continue}}if(await confirm({message:`${b}: ${w.command} not found. Install via \`${w.manualInstall.command}\`?`,default:!0,theme:U}))try{this.reporter.info(`${b}: Installing ${w.command} via \`${T.argv.join(" ")}\` (this may take a minute)...`),execFileSync(T.argv[0],[...T.argv.slice(1)],{stdio:"pipe",env:{...process.env,...T.env??{}}});let G=zn(T);G.ok?(this.reporter.log(`${E} ${b}: Installed ${w.command} (${G.path})`),_.lsp={command:G.path,args:w.args}):G.reason==="untrusted-path"?(this.reporter.error(`${b}: Install completed but the resolved binary path is outside the allowed prefix; refusing to wire it. Report this as a bug.`),_.lspEnrichment=!1):G.reason==="invalid-stdout"?(this.reporter.error(`${b}: Install completed but the verify command produced no usable absolute path. Try running manually: \`${w.manualInstall.command}\`.`),_.lspEnrichment=!1):(this.reporter.error(`${b}: Install command exited 0 but ${w.command} wasn't found afterwards. Try running manually: \`${w.manualInstall.command}\`.`),_.lspEnrichment=!1);}catch(G){let Y=G.stderr?.toString().trim();this.reporter.error(`${b}: Installation failed${Y?`: ${Y}`:""}`),_.lspEnrichment=!1;}else this.reporter.info(`${b}: To install manually: \`${w.manualInstall.command}\``),this.reporter.info(`${b}: Indexing will continue without LSP enrichment.`),_.lspEnrichment=!1;}else this.reporter.info(`${b}: ${w.command} not found. Requires ${w.manualInstall.requires}. Install with: ${w.manualInstall.command}`),w.manualInstall.pathNote&&this.reporter.info(`${b}: ${w.manualInstall.pathNote}`),this.reporter.info(`${b}: Indexing will continue without LSP enrichment.`),_.lspEnrichment=!1;}else if(await confirm({message:`${b}: ${w.command} not found. Install to ~/.constellation/lsp-servers/?`,default:!0,theme:U}))try{this.reporter.info(`Installing ${w.npmPackages.join(", ")}...`),execFileSync("npm",["install","--prefix",Ke,...w.npmPackages],{stdio:"pipe"}),this.reporter.log(`${E} ${b}: Installed ${w.command}`),_.lsp={command:w.command,args:w.args};}catch{this.reporter.error(`${b}: Installation failed`),_.lspEnrichment=!1;}else _.lspEnrichment=!1;}let y=Object.entries(v).filter(([,b])=>b.lspEnrichment!==!1).map(([b])=>b);y.length>0?this.reporter.log(`${E} Index enrichment enabled for: ${y.map(Pe).join(", ")}`):this.reporter.warn("No language servers configured. Index enrichment will be skipped.");let C={projectId:f.trim(),branch:h,languages:{...v},...y.length>0&&{lspEnrichment:!0}},P=JSON.stringify(C,void 0,2);await x.writeFile(r,P),this.reporter.log(`${E} ${s?"Updated":"Initialized"} configuration file at ${Fr(r,process.cwd())}`),await this.git.stageFile(r),this.reporter.log(`${E} 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 r=t.message??"An unexpected error occurred";this.reporter.error(`Failed to initialize configuration file.
90
- ${r}`);}}async configureMCPServers(){if(!await confirm({message:"Automatically configure Constellation for AI coding assistants?",default:true,theme:U}))return;let t=await checkbox({message:"Select AI coding assistants to configure:",choices:Kn.map(u=>({name:u.displayName,value:u.id})),required:true,theme:U}),r=new Ar(process.cwd()),o=[];for(let u of t){let d=Bs(u);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(`${E} ${d.displayName} plugin installed successfully`):this.reporter.warn(`${d.displayName}: ${m.error}`);}else if(d.isGlobalConfig&&d.getGlobalConfigPaths){let m=await r.configureGlobalTool(d),f=false;for(let h of m)o.push(h),h.success?(f=true,this.reporter.log(`${E} ${h.tool.displayName} configured at ${Fr(h.configuredPath,process.cwd())}`)):h.error&&this.reporter.warn(`${h.tool.displayName}: ${h.error}`);if(f){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 r.configureTool(d);o.push(m),m.success?(this.reporter.log(`${E} ${d.displayName} configured at ${Fr(m.configuredPath,process.cwd())}`),d.permissionsConfig&&this.reporter.log(`${E} ${d.displayName} permissions set in ${d.permissionsConfig.filePath}`)):this.reporter.warn(`${d.displayName}: ${m.error}`);}}if(o.find(u=>u.tool.id==="claude-code"&&u.success)){let u=R__default.join(process.cwd(),".claude/settings.json");try{await this.git.stageFile(u),this.reporter.log(`${E} Added .claude/settings.json to staged changes in git`);}catch{this.reporter.warn("Could not stage .claude/settings.json in git");}}if(o.find(u=>u.tool.id==="codex-cli"&&u.success)){let u=R__default.join(process.cwd(),".codex/config.toml");try{await this.git.stageFile(u),this.reporter.log(`${E} Added .codex/config.toml to staged changes in git`);}catch{}}if(o.find(u=>u.tool.id==="opencode"&&u.success)){let u=R__default.join(process.cwd(),"opencode.jsonc");try{await this.git.stageFile(u),this.reporter.log(`${E} Added opencode.jsonc to staged changes in git`);}catch{}}let c=o.filter(u=>u.success).length,p=o.filter(u=>!u.success).length;this.reporter.log(`${E} Plugin + MCP configuration complete: ${c} configured`),p>0&&this.reporter.warn(`${p} 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 Fu(e.command,e.args,{timeout:3e4,env:process.env});}isAlreadyInstalledError(e){let t=`${e.message??""}
91
- ${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:U}))return;let o=new Lt(t),s=await o.detectPlatforms(),a;if(s.length===1){let u=s[0]==="github"?"GitHub Actions":"GitLab CI";if(!await confirm({message:`Detected ${u}. Configure Constellation CI/CD for this platform?`,default:true,theme:U}))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:U});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:U})){this.reporter.info("Skipping CI/CD configuration");return}let c;try{c=a==="github"?await o.createGitHubWorkflow(e):await o.createOrMergeGitLabCI(e);}catch(u){this.reporter.warn(`Failed to configure CI/CD pipeline: ${u.message}`);return}let p=Fr(c,process.cwd());a==="github"?this.reporter.log(`${E} Created ${p}`):this.reporter.log(`${E} ${l?"Updated":"Created"} ${p} with Constellation indexing`);try{await this.git.stageFile(c),this.reporter.log(`${E} Added ${p} to staged changes in git`);}catch{this.reporter.warn(`Could not stage ${p} in git`);}a==="github"?this.reporter.info(`Add your access key as a repository secret:
87
+ `),await C.writeFile(e,o);}async configurePermissions(e){let t=k__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let r={};try{if(await C.fileIsReadable(t)){let c=await C.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 C.writeFile(t,JSON.stringify(r,null," ")+`
88
+ `);}async configureMarketplace(e){let t=k__default.join(this.cwd,e.filePath);await this.ensureDirectoryExists(t);let r={};try{if(await C.fileIsReadable(t)){let s=await C.readFile(t);r=JSON.parse(s);}}catch{}r=this.deepMerge(r,e.config),await C.writeFile(t,JSON.stringify(r,null," ")+`
89
+ `);}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(/^~/,He__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 Kr(n,e){let t=k__default.normalize(n),r=k__default.normalize(e);return t.startsWith(r+k__default.sep)?k__default.relative(e,n):n}var Yd,Bt,La=f(()=>{va();nt();ba();Pn();Rr();Ia();di();le();q();er();Xt();Yd=promisify(execFile);Bt=class extends Ie{async run(e={}){try{if(this.reporter.log(`${Ee} Initializing project configuration...
90
+ `),!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=k__default.join(process.cwd(),"constellation.json"),o=null,s=await C.fileIsReadable(r);if(s)try{let v=await C.readFile(r);o=JSON.parse(v),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(v=>v!==p),m=p?[p,...d]:d,g=await input({message:"Constellation Project ID:",default:o?.projectId??"",validate:v=>v.trim().length>0||"Project ID is required",theme:B}),h=await select({message:"Branch to index:",choices:m.map(v=>({name:v,value:v})),default:o?.branch??m[0],theme:B}),y=(await checkbox({message:"Select Language(s):",choices:this.buildLanguageChoices(o),required:!0,theme:B})).reduce((v,R)=>(v[R]={fileExtensions:Me[R]||[]},v),{});this.reporter.log(""),this.reporter.info("Checking for LSP servers...");let S=(await this.env?.getKey("CONSTELLATION_AUTO_INSTALL_LSP")??"").trim().toLowerCase(),E=["1","true","yes","on"].includes(S),T=this.env?.isCI()??!1,w=[];for(let[v,R]of Object.entries(y)){let _=Te.get(v);if(!_)continue;let O=!1,K="";if(ae(_.command)&&(O=!0,K="system"),!O){let M=k__default.join(rt,_.command);existsSync(M)&&(O=!0,K="managed");}let ye=_.manualInstall?.autoInstall,J;if(!O&&ye){let M=pi(ye);M.ok&&(J=M.path,O=!0,K="managed");}if(O)this.reporter.log(`${x} ${v}: Found ${_.command} (${K})`),R.lsp={command:K==="managed"&&J!==void 0?J:_.command,args:_.args};else if(_.npmPackages.length===0&&_.manualInstall){let M=_.manualInstall.autoInstall;if(M&&ae(M.prerequisite)){if(M.installedBinaryPath!==void 0){let D=k__default.resolve(tt),A=k__default.resolve(M.installedBinaryPath);if(!A.startsWith(D+k__default.sep)){this.reporter.error(`${v}: installedBinaryPath (${A}) is outside the managed directory; refusing to install. Report this as a bug.`),R.lspEnrichment=!1;continue}}if(await confirm({message:`${v}: ${_.command} not found. Install via \`${_.manualInstall.command}\`?`,default:!0,theme:B}))try{this.reporter.info(`${v}: Installing ${_.command} via \`${M.argv.join(" ")}\` (this may take a minute)...`),execFileSync(M.argv[0],[...M.argv.slice(1)],{stdio:"pipe",env:{...process.env,...M.env??{}}});let D=pi(M);D.ok?(this.reporter.log(`${x} ${v}: Installed ${_.command} (${D.path})`),R.lsp={command:D.path,args:_.args}):D.reason==="untrusted-path"?(this.reporter.error(`${v}: Install completed but the resolved binary path is outside the allowed prefix; refusing to wire it. Report this as a bug.`),R.lspEnrichment=!1):D.reason==="invalid-stdout"?(this.reporter.error(`${v}: Install completed but the verify command produced no usable absolute path. Try running manually: \`${_.manualInstall.command}\`.`),R.lspEnrichment=!1):(this.reporter.error(`${v}: Install command exited 0 but ${_.command} wasn't found afterwards. Try running manually: \`${_.manualInstall.command}\`.`),R.lspEnrichment=!1);}catch(D){let A=D.stderr?.toString().trim();this.reporter.error(`${v}: Installation failed${A?`: ${A}`:""}`),R.lspEnrichment=!1;}else this.reporter.info(`${v}: To install manually: \`${_.manualInstall.command}\``),this.reporter.info(`${v}: Indexing will continue without LSP enrichment.`),R.lspEnrichment=!1;}else _.manualInstall.verifyToolchain?await this.installManualOnlyServer(v,R,_,_.manualInstall,_.manualInstall.verifyToolchain,{autoInstall:E,nonInteractive:T},w):(this.reporter.info(`${v}: ${_.command} not found. Requires ${_.manualInstall.requires}. Install with: ${_.manualInstall.command}`),_.manualInstall.pathNote&&this.reporter.info(`${v}: ${_.manualInstall.pathNote}`),this.reporter.info(`${v}: Indexing will continue without LSP enrichment.`),R.lspEnrichment=!1);}else if(await confirm({message:`${v}: ${_.command} not found. Install to ~/.constellation/lsp-servers/?`,default:!0,theme:B}))try{this.reporter.info(`Installing ${_.npmPackages.join(", ")}...`),execFileSync("npm",["install","--prefix",tt,..._.npmPackages],{stdio:"pipe"}),this.reporter.log(`${x} ${v}: Installed ${_.command}`),R.lsp={command:_.command,args:_.args};}catch{this.reporter.error(`${v}: Installation failed`),R.lspEnrichment=!1;}else R.lspEnrichment=!1;}if(w.length>0){let v=ye=>w.filter(J=>ye.includes(J.outcome)).map(J=>J.command).join(", "),R=v(["installed","installed-pathnote"]),_=v(["already-installed"]),O=v(["prereq-missing","prereq-too-old","declined","ci-skipped"]),K=v(["failed"]);R&&this.reporter.info(`LSP servers installed: ${R}`),_&&this.reporter.info(`LSP servers already present: ${_}`),O&&this.reporter.info(`LSP servers skipped: ${O}`),K&&this.reporter.warn(`LSP servers failed to install: ${K}`);}let P=Object.entries(y).filter(([,v])=>v.lspEnrichment!==!1).map(([v])=>v);P.length>0?this.reporter.log(`${x} Index enrichment enabled for: ${P.map(te).join(", ")}`):this.reporter.warn("No language servers configured. Index enrichment will be skipped.");let N={projectId:g.trim(),branch:h,languages:{...y},...P.length>0&&{lspEnrichment:!0}},I=JSON.stringify(N,void 0,2);await C.writeFile(r,I),this.reporter.log(`${x} ${s?"Updated":"Initialized"} configuration file at ${Kr(r,process.cwd())}`),await this.git.stageFile(r),this.reporter.log(`${x} 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 r=t.message??"An unexpected error occurred";this.reporter.error(`Failed to initialize configuration file.
91
+ ${r}`);}}async installManualOnlyServer(e,t,r,o,s,a,l){let c=h=>l.push({lang:e,command:r.command,outcome:h}),u=En(r);if(u){this.reporter.log(`${x} ${e}: Already installed ${r.command}`),t.lsp={command:u,args:r.args},c("already-installed");return}let p=_o(s);if(!p.ok){if(p.reason==="missing"){this.reporter.info(`${e}: ${r.command} install skipped \u2014 ${o.requires} required (not detected). Install it, then re-run \`constellation init\`.`),t.lspEnrichment=false,c("prereq-missing");return}if(p.reason==="too-old"){this.reporter.info(`${e}: ${r.command} install skipped \u2014 detected ${p.detected}, requires ${p.required} or later.`),t.lspEnrichment=false,c("prereq-too-old");return}t.lspEnrichment=false,c("prereq-missing");return}if(a.nonInteractive&&!a.autoInstall){this.reporter.info(`${e}: ${r.command} not installed \u2014 non-interactive run cannot prompt. Install manually with \`${o.command}\` or set CONSTELLATION_AUTO_INSTALL_LSP=1 to bypass the prompt.`),c("ci-skipped");return}if(!(a.autoInstall||await confirm({message:`${e}: ${r.command} not found. Required for ${te(e)} LSP enrichment. Install with \`${o.command}\`?`,default:true,theme:B}))){this.reporter.info(`${e}: skipped \u2014 indexing will continue without LSP enrichment.`),t.lspEnrichment=false,c("declined");return}this.reporter.info(`${e}: Installing ${r.command} via \`${o.command}\`...`);let m=xo(r);if(!m.ok){"exitCode"in m?(this.reporter.error(`${e}: ${r.command} install failed (exit ${m.exitCode??"unknown"}). Run \`${o.command}\` manually for details.`),m.stderr&&this.reporter.detail(`${e}: install stderr: ${m.stderr}`)):(this.reporter.error(`${e}: ${r.command} install failed to start. Run \`${o.command}\` manually for details.`),this.reporter.detail(`${e}: install error: ${m.spawnError}`)),t.lspEnrichment=false,c("failed");return}let g=En(r);if(g){this.reporter.log(`${x} ${e}: Installed ${r.command} (${g})`),t.lsp={command:g,args:r.args},c("installed");return}this.reporter.info(`${e}: ${r.command} installed but not yet on PATH.`),o.pathNote&&this.reporter.info(`${e}: ${o.pathNote}`),c("installed-pathnote");}async configureMCPServers(){if(!await confirm({message:"Automatically configure Constellation for AI coding assistants?",default:true,theme:B}))return;let t=await checkbox({message:"Select AI coding assistants to configure:",choices:ui.map(p=>({name:p.displayName,value:p.id})),required:true,theme:B}),r=new Wr(process.cwd()),o=[];for(let p of t){let d=Ea(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(`${x} ${d.displayName} plugin installed successfully`):this.reporter.warn(`${d.displayName}: ${m.error}`);}else if(d.isGlobalConfig&&d.getGlobalConfigPaths){let m=await r.configureGlobalTool(d),g=false;for(let h of m)o.push(h),h.success?(g=true,this.reporter.log(`${x} ${h.tool.displayName} configured at ${Kr(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 r.configureTool(d);o.push(m),m.success?(this.reporter.log(`${x} ${d.displayName} configured at ${Kr(m.configuredPath,process.cwd())}`),d.permissionsConfig&&this.reporter.log(`${x} ${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=k__default.join(process.cwd(),".claude/settings.json");try{await this.git.stageFile(p),this.reporter.log(`${x} 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=k__default.join(process.cwd(),".codex/config.toml");try{await this.git.stageFile(p),this.reporter.log(`${x} Added .codex/config.toml to staged changes in git`);}catch{}}if(o.find(p=>p.tool.id==="opencode"&&p.success)){let p=k__default.join(process.cwd(),"opencode.jsonc");try{await this.git.stageFile(p),this.reporter.log(`${x} 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(`${x} 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 Yd(e.command,e.args,{timeout:3e4,env:process.env});}isAlreadyInstalledError(e){let t=`${e.message??""}
92
+ ${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:B}))return;let o=new Gt(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:B}))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:B});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:B})){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=Kr(c,process.cwd());a==="github"?this.reporter.log(`${x} Created ${u}`):this.reporter.log(`${x} ${l?"Updated":"Created"} ${u} with Constellation indexing`);try{await this.git.stageFile(c),this.reporter.log(`${x} 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:
92
93
  Settings \u2192 Secrets and variables \u2192 Actions \u2192 New repository secret
93
94
  Name: CONSTELLATION_ACCESS_KEY`):this.reporter.info(`Add your access key as a CI/CD variable:
94
95
  Settings \u2192 CI/CD \u2192 Variables \u2192 Add variable
95
- Key: CONSTELLATION_ACCESS_KEY`);}buildLanguageChoices(e){let t=e?.languages?Object.keys(e.languages):[];return [{name:"Go",value:"go"},{name:"JavaScript",value:"javascript"},{name:"Python",value:"python"},{name:"TypeScript",value:"typescript"}].map(r=>({...r,checked:t.includes(r.value)}))}};});var $r,qs=g(()=>{pn();bt();ce();z();$r=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 x.fileIsReadable(e)){let r=await x.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(`${le} 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 Ee("Not on a Git branch (detached HEAD state)","BRANCH_NOT_CONFIGURED");if(this.branch!==e)throw new Ee(`Current branch "${e}" does not match configured branch "${this.branch}". Update constellation.json or switch to "${this.branch}" branch.`,"BRANCH_NOT_CONFIGURED")}};});var Or,qn,Mr,Yn,Xn,Qn,Ur,Ys=g(()=>{ce();Or=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(`
96
- `)||t.includes("\r"))throw new Error("Value cannot contain newline characters")}escapeShellValue(e){return e.replace(/[\\'\"$`]/g,"\\$&")}},qn=class extends Or{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.
97
- 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="",p="";l.stdout?.on("data",u=>{c+=u.toString();}),l.stderr?.on("data",u=>{p+=u.toString();}),l.on("close",u=>{u===0?s(c):a(new Error(`reg query failed: ${p}`));}),l.on("error",u=>{a(u);});})).match(/REG_(?:SZ|EXPAND_SZ)\s+(.+?)(?:\r?\n|$)/);return o?o[1].trim():void 0}catch{return}}},Mr=class extends Or{userConfigFiles;constructor(){super(),this.userConfigFiles=[R.join($e.homedir(),".zshenv"),R.join($e.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.
98
- 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 x.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()+`
96
+ Key: CONSTELLATION_ACCESS_KEY`);}buildLanguageChoices(e){let t=e?.languages?Object.keys(e.languages):[];return [{name:"C#",value:"c-sharp"},{name:"Go",value:"go"},{name:"JavaScript",value:"javascript"},{name:"Python",value:"python"},{name:"TypeScript",value:"typescript"}].map(r=>({...r,checked:t.includes(r.value)}))}};});var Vr,ka=f(()=>{bn();Tt();le();q();Vr=class n{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 C.fileIsReadable(e)){let r=await C.readFile(e),o=JSON.parse(r),s=new n(o.branch,o.languages,o.projectId,o.exclude,o.lspEnrichment);return s.validate(),s}else throw new Error(`${ge} 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 Ne("Not on a Git branch (detached HEAD state)","BRANCH_NOT_CONFIGURED");if(this.branch!==e)throw new Ne(`Current branch "${e}" does not match configured branch "${this.branch}". Update constellation.json or switch to "${this.branch}" branch.`,"BRANCH_NOT_CONFIGURED")}};});var qr,fi,Yr,gi,hi,yi,Xr,ja=f(()=>{le();qr=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(`
97
+ `)||t.includes("\r"))throw new Error("Value cannot contain newline characters")}escapeShellValue(e){return e.replace(/[\\'\"$`]/g,"\\$&")}},fi=class extends qr{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.
98
+ 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}}},Yr=class extends qr{userConfigFiles;constructor(){super(),this.userConfigFiles=[k.join(He.homedir(),".zshenv"),k.join(He.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.
99
+ 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 C.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()+`
99
100
  `+r+`
100
- `,await x.writeFile(e,o);}async assertSafeWriteTarget(e){try{let t=await Q__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}}},Yn=class i extends Mr{static LAUNCH_AGENT_LABEL="io.constellationdev.env";launchAgentDir;launchAgentScriptDir;launchAgentLogDir;launchAgentPlistPath;launchAgentScriptPath;launchAgentStderrPath;constructor(){super();let e=$e.homedir();this.launchAgentDir=R.join(e,"Library","LaunchAgents"),this.launchAgentScriptDir=R.join(e,"Library","Application Support","Constellation"),this.launchAgentLogDir=R.join(e,"Library","Logs","Constellation"),this.launchAgentPlistPath=R.join(this.launchAgentDir,`${i.LAUNCH_AGENT_LABEL}.plist`),this.launchAgentScriptPath=R.join(this.launchAgentScriptDir,"launchd-env.sh"),this.launchAgentStderrPath=R.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 Q__default.mkdir(this.launchAgentDir,{recursive:true}),await Q__default.mkdir(this.launchAgentScriptDir,{recursive:true}),await Q__default.mkdir(this.launchAgentLogDir,{recursive:true}),await Q__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 x.readFile(this.launchAgentScriptPath,"utf-8");}catch{}s||(s=`#!/bin/bash
101
+ `,await C.writeFile(e,o);}async assertSafeWriteTarget(e){try{let t=await se__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}}},gi=class n extends Yr{static LAUNCH_AGENT_LABEL="io.constellationdev.env";launchAgentDir;launchAgentScriptDir;launchAgentLogDir;launchAgentPlistPath;launchAgentScriptPath;launchAgentStderrPath;constructor(){super();let e=He.homedir();this.launchAgentDir=k.join(e,"Library","LaunchAgents"),this.launchAgentScriptDir=k.join(e,"Library","Application Support","Constellation"),this.launchAgentLogDir=k.join(e,"Library","Logs","Constellation"),this.launchAgentPlistPath=k.join(this.launchAgentDir,`${n.LAUNCH_AGENT_LABEL}.plist`),this.launchAgentScriptPath=k.join(this.launchAgentScriptDir,"launchd-env.sh"),this.launchAgentStderrPath=k.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 se__default.mkdir(this.launchAgentDir,{recursive:true}),await se__default.mkdir(this.launchAgentScriptDir,{recursive:true}),await se__default.mkdir(this.launchAgentLogDir,{recursive:true}),await se__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 C.readFile(this.launchAgentScriptPath,"utf-8");}catch{}s||(s=`#!/bin/bash
101
102
  # Managed by Constellation CLI - do not edit manually
102
103
  `);let a=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),l=new RegExp(`^launchctl setenv ${a} .*$`,"gm");l.test(s)?s=s.replace(l,o):s=s.trimEnd()+`
103
104
  `+o+`
104
- `,await this.assertSafeWriteTarget(this.launchAgentScriptPath),await Q__default.writeFile(this.launchAgentScriptPath,s,{mode:448}),await Q__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"?>
105
+ `,await this.assertSafeWriteTarget(this.launchAgentScriptPath),await se__default.writeFile(this.launchAgentScriptPath,s,{mode:448}),await se__default.chmod(this.launchAgentScriptPath,448);}async ensureLaunchAgentPlist(){let e=n.escapeXml(this.launchAgentScriptPath),t=n.escapeXml(this.launchAgentStderrPath),o=`<?xml version="1.0" encoding="UTF-8"?>
105
106
  <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
106
107
  <plist version="1.0">
107
108
  <dict>
108
109
  <key>Label</key>
109
- <string>${i.LAUNCH_AGENT_LABEL}</string>
110
+ <string>${n.LAUNCH_AGENT_LABEL}</string>
110
111
  <key>ProgramArguments</key>
111
112
  <array>
112
113
  <string>/bin/bash</string>
@@ -120,18 +121,18 @@ ${e.stderr??""}`.toLowerCase();return t.includes("already installed")||t.include
120
121
  <string>${t}</string>
121
122
  </dict>
122
123
  </plist>
123
- `;await this.assertSafeWriteTarget(this.launchAgentPlistPath),await x.writeFile(this.launchAgentPlistPath,o),await Q__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}
124
- 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 Mr{static ENV_D_FILENAME="io.constellationdev.env.conf";envDDir;envDFilePath;constructor(){super(),this.envDDir=R.join($e.homedir(),".config","environment.d"),this.envDFilePath=R.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 Q__default.mkdir(this.envDDir,{recursive:true});}async updateEnvironmentDFile(e,t){let r=i.escapeEnvironmentDValue(t),o=`${e}=${r}`,s="";try{s=await x.readFile(this.envDFilePath,"utf-8");}catch{}s||(s=`# Managed by Constellation CLI - do not edit manually
124
+ `;await this.assertSafeWriteTarget(this.launchAgentPlistPath),await C.writeFile(this.launchAgentPlistPath,o),await se__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}
125
+ 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}/${n.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);}}},hi=class n extends Yr{static ENV_D_FILENAME="io.constellationdev.env.conf";envDDir;envDFilePath;constructor(){super(),this.envDDir=k.join(He.homedir(),".config","environment.d"),this.envDFilePath=k.join(this.envDDir,n.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 se__default.mkdir(this.envDDir,{recursive:true});}async updateEnvironmentDFile(e,t){let r=n.escapeEnvironmentDValue(t),o=`${e}=${r}`,s="";try{s=await C.readFile(this.envDFilePath,"utf-8");}catch{}s||(s=`# Managed by Constellation CLI - do not edit manually
125
126
  `);let a=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),l=new RegExp(`^${a}=.*$`,"gm");l.test(s)?s=s.replace(l,o):s=s.trimEnd()+`
126
127
  `+o+`
127
- `,await this.assertSafeWriteTarget(this.envDFilePath),await Q__default.writeFile(this.envDFilePath,s,{mode:384}),await Q__default.chmod(this.envDFilePath,384);}async importToSystemdUser(e,t){if(he("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}
128
- Shell environments still updated; log out and back in if systemd-launched apps don't see the value.`);}},Qn=class{static create(){let e=$e.platform();switch(e){case "win32":return new qn;case "darwin":return new Yn;case "linux":return new Xn;default:throw new Error(`Unsupported platform: ${e}`)}}},Ur=class{manager;constructor(){this.manager=Qn.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 Gr,Xs=g(()=>{Gr=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=R__default.extname(e).toLowerCase();return this.extensionToLanguageMap.get(t)||null}};});function Qs(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.
129
- `);}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=Gi(),s=Bi();return o||!s?"plain":"spinner"}var Zs=g(()=>{an();});function Du(){let i=$e.platform();if(i==="darwin")return R.join($e.homedir(),"Library","Caches","constellation");if(i==="win32"){let e=process.env.LOCALAPPDATA||R.join($e.homedir(),"AppData","Local");return R.join(e,"constellation","cache")}else {let e=process.env.XDG_CACHE_HOME||R.join($e.homedir(),".cache");return R.join(e,"constellation")}}var Ou,Mu,Uu,jt,Zn=g(()=>{Ou=Du(),Mu="update-state.json",Uu=1440*60*1e3,jt=class{state=null;stateDir;stateFile;constructor(e){this.stateDir=e??Ou,this.stateFile=R.join(this.stateDir,Mu);}async load(){if(this.state)return this.state;try{let e=await Q.readFile(this.stateFile,"utf-8");return this.state=JSON.parse(e),this.state}catch{return {lastCheckTimestamp:0}}}async save(e){try{await Q.mkdir(this.stateDir,{recursive:!0}),await Q.writeFile(this.stateFile,JSON.stringify(e,null,2)),this.state=e;}catch{}}async shouldCheck(){let e=await this.load();return Date.now()-e.lastCheckTimestamp>Uu}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 Q.unlink(this.stateFile),this.state=null;}catch{}}};});var At,ei=g(()=>{At=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 Ft,ti=g(()=>{Be();z();Ut();Ft=class{async promptForUpdate(e,t,r){console.log(""),console.log(cyan("\u2501".repeat(60))),console.log(`${Se} ${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:U})}catch{return false}}};});async function ri(i){return new Wr().check(i)}var Wu,Br,Hu,Wr,ea=g(()=>{z();Zn();ei();ti();Wu="https://registry.npmjs.org",Br="@constellationdev/cli",Hu=5e3,Wr=class{cache;packageManager;prompter;constructor(){this.cache=new jt,this.packageManager=new At,this.prompter=new Ft;}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(),Hu);try{let o=await fetch(`${Wu}/${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(`
130
- ${de} Updating ${Br}...
131
- `),await this.packageManager.executeUpdate(Br)?(console.log(`
132
- ${E} Update complete! Please re-run your command.
128
+ `,await this.assertSafeWriteTarget(this.envDFilePath),await se__default.writeFile(this.envDFilePath,s,{mode:384}),await se__default.chmod(this.envDFilePath,384);}async importToSystemdUser(e,t){if(ae("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}
129
+ Shell environments still updated; log out and back in if systemd-launched apps don't see the value.`);}},yi=class{static create(){let e=He.platform();switch(e){case "win32":return new fi;case "darwin":return new gi;case "linux":return new hi;default:throw new Error(`Unsupported platform: ${e}`)}}},Xr=class{manager;constructor(){this.manager=yi.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 Qr,Aa=f(()=>{Qr=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=k__default.extname(e).toLowerCase();return this.extensionToLanguageMap.get(t)||null}};});function Fa(n=process.argv,e=process.env){let t=n.includes("--verbose"),r=n.includes("--quiet")||n.includes("-q")||n.includes("-Q");if(t&&r){try{process.stderr.write(`note: --verbose and --quiet are mutually exclusive; --verbose wins.
130
+ `);}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=ao(),s=lo();return o||!s?"plain":"spinner"}var $a=f(()=>{hn();});function Qd(){let n=He.platform();if(n==="darwin")return k.join(He.homedir(),"Library","Caches","constellation");if(n==="win32"){let e=process.env.LOCALAPPDATA||k.join(He.homedir(),"AppData","Local");return k.join(e,"constellation","cache")}else {let e=process.env.XDG_CACHE_HOME||k.join(He.homedir(),".cache");return k.join(e,"constellation")}}var Zd,em,tm,Ht,vi=f(()=>{Zd=Qd(),em="update-state.json",tm=1440*60*1e3,Ht=class{state=null;stateDir;stateFile;constructor(e){this.stateDir=e??Zd,this.stateFile=k.join(this.stateDir,em);}async load(){if(this.state)return this.state;try{let e=await se.readFile(this.stateFile,"utf-8");return this.state=JSON.parse(e),this.state}catch{return {lastCheckTimestamp:0}}}async save(e){try{await se.mkdir(this.stateDir,{recursive:!0}),await se.writeFile(this.stateFile,JSON.stringify(e,null,2)),this.state=e;}catch{}}async shouldCheck(){let e=await this.load();return Date.now()-e.lastCheckTimestamp>tm}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 se.unlink(this.stateFile),this.state=null;}catch{}}};});var zt,bi=f(()=>{zt=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 Wt,Si=f(()=>{qe();q();Xt();Wt=class{async promptForUpdate(e,t,r){console.log(""),console.log(cyan("\u2501".repeat(60))),console.log(`${Ee} ${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:B})}catch{return false}}};});async function wi(n){return new en().check(n)}var im,Zr,om,en,Da=f(()=>{q();vi();bi();Si();im="https://registry.npmjs.org",Zr="@constellationdev/cli",om=5e3,en=class{cache;packageManager;prompter;constructor(){this.cache=new Ht,this.packageManager=new zt,this.prompter=new Wt;}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(),om);try{let o=await fetch(`${im}/${Zr}/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(`
131
+ ${ve} Updating ${Zr}...
132
+ `),await this.packageManager.executeUpdate(Zr)?(console.log(`
133
+ ${x} Update complete! Please re-run your command.
133
134
  `),true):(console.log(`
134
- ${M} Update failed. You can try updating manually:`),console.log(` ${this.packageManager.getUpdateCommandString(Br)}
135
- `),false)}};});var ta=g(()=>{Zn();ei();ti();ea();});var $t,ra=g(()=>{z();$t=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.
136
- 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(`${E} 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 ia,na=g(()=>{ia={"tree-sitter":"0.21.1","tree-sitter-typescript":"0.21.2","tree-sitter-javascript":"0.21.4","tree-sitter-python":"0.21.0"};});function oa(){let i={};for(let e of Vu){let t=ia[e];if(typeof t!="string"||t.length===0)throw new Error(`grammar-versions.json missing entry for ${e}`);i[e]=t;}return i}var Vu,sa=g(()=>{na();Vu=["tree-sitter","tree-sitter-typescript","tree-sitter-javascript","tree-sitter-python"];});var Zu={};var J,Re,aa,ni,Xu,Qu,ii,oi,pt,la=g(async()=>{wi();Ls();Js();qs();Ys();Xs();yr();Zs();En();ta();Vr();Bt();ra();sa();J=new Er({mode:Qs(process.argv)}),Re=()=>{try{J.stop();}catch{}};process.on("exit",Re);process.on("uncaughtException",i=>{i instanceof Error&&i.code==="ERR_USE_AFTER_CLOSE"&&(Re(),process.exit(0)),ve(i)||J.error(i?.message??String(i)),Re(),process.exit(1);});aa=globalThis.__constellationVersion??(()=>{let i=R__default.dirname(fileURLToPath(import.meta.url)),e=R__default.join(i,"..","package.json");return JSON.parse(readFileSync(e,"utf-8")).version})(),ni=(()=>{let i=process.argv[1];return i&&R__default.basename(i).replace(/\.(c|m)?js$/i,"")==="const"?"const":"constellation"})(),Xu=new Set(["print-grammar-versions"]),Qu=Xu.has(process.argv[2]);if(J.mode!=="quiet"&&!Qu){let i=process.argv[2];["auth","help","init","index"].includes(i)?Gt(ni,i):Gt(ni),Dt.includes(i)||await ri(aa)&&(Re(),process.exit(0));}ii=process.cwd(),oi=new Ur,pt=new Command;pt.name(ni).description("Connecting stars in your code into intelligent patterns").version(aa).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.");pt.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 $t(ii,J),Reporter:J};await new kt(t).run({skipMcp:i.skipMcp,skipCi:i.skipCi});}catch(e){ve(e)||J.error(e instanceof Error?e.message:String(e)),Re(),process.exit(1);}});pt.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:oi,Reporter:J};await new mt(e).run(i.manual);}catch(e){ve(e)||J.error(e instanceof Error?e.message:String(e)),Re(),process.exit(1);}});pt.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 $r.loadFromFile(R__default.join(ii,"constellation.json")),t=new $t(ii,J),r=new hr(e),o=new Gr(e),s={GitClient:t,Config:e,LanguageRegistry:r,LanguageDetector:o,Environment:oi,Reporter:J},a=oi.isCI(),l=i.full||!i.incremental&&a,c=i.dirty||!1,p=!0;!i.full&&!i.incremental&&a&&J.info("CI environment detected \u2014 defaulting to full index. Use --incremental to override."),await new Tt(s).run(l,c,p);}catch(e){ve(e)||J.error(e instanceof Error?e.message:String(e)),Re(),process.exit(1);}});pt.command("print-grammar-versions",{hidden:true}).description("Emit installed tree-sitter grammar versions as JSON").action(()=>{try{process.stdout.write(JSON.stringify(oa())+`
137
- `);}catch(i){ve(i)||J.error(i instanceof Error?i.message:String(i)),Re(),process.exit(1);}});pt.parse();});var pa=/^>=\s*\d+\.\d+\.\d+$/;function ci(i,e=process.version){if(!pa.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,p=s[l]||0;if(p>c)break;if(p<c){a=false;break}}return {compatible:a,current:e,required:i}}Vr();var id=dirname(fileURLToPath(import.meta.url)),od=join(id,"..","package.json"),si=JSON.parse(readFileSync(od,"utf-8")),sd=process.argv[2];if(!Dt.includes(sd)&&si.engines?.node){let i=ci(si.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=si.version;await la().then(()=>Zu);
135
+ ${z} Update failed. You can try updating manually:`),console.log(` ${this.packageManager.getUpdateCommandString(Zr)}
136
+ `),false)}};});var Oa=f(()=>{vi();bi();Si();Da();});var Kt,Ma=f(()=>{q();Kt=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.
137
+ 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(`${x} 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 Ga,Ua=f(()=>{Ga={"tree-sitter":"0.21.1","tree-sitter-typescript":"0.21.2","tree-sitter-javascript":"0.21.4","tree-sitter-python":"0.21.0"};});function Ba(){let n={};for(let e of lm){let t=Ga[e];if(typeof t!="string"||t.length===0)throw new Error(`grammar-versions.json missing entry for ${e}`);n[e]=t;}return n}var lm,Ha=f(()=>{Ua();lm=["tree-sitter","tree-sitter-typescript","tree-sitter-javascript","tree-sitter-python"];});var fm={};var Q,ke,za,_i,dm,mm,xi,Ci,St,Wa=f(async()=>{Ui();fa();La();ka();ja();Aa();Rr();$a();Un();Oa();nn();Zt();Ma();Ha();Q=new Fr({mode:Fa(process.argv)}),ke=()=>{try{Q.stop();}catch{}};process.on("exit",ke);process.on("uncaughtException",n=>{n instanceof Error&&n.code==="ERR_USE_AFTER_CLOSE"&&(ke(),process.exit(0)),xe(n)||Q.error(n?.message??String(n)),ke(),process.exit(1);});za=globalThis.__constellationVersion??(()=>{let n=k__default.dirname(fileURLToPath(import.meta.url)),e=k__default.join(n,"..","package.json");return JSON.parse(readFileSync(e,"utf-8")).version})(),_i=(()=>{let n=process.argv[1];return n&&k__default.basename(n).replace(/\.(c|m)?js$/i,"")==="const"?"const":"constellation"})(),dm=new Set(["print-grammar-versions"]),mm=dm.has(process.argv[2]);if(Q.mode!=="quiet"&&!mm){let n=process.argv[2];["auth","help","init","index"].includes(n)?Qt(_i,n):Qt(_i),Vt.includes(n)||await wi(za)&&(ke(),process.exit(0));}xi=process.cwd(),Ci=new Xr,St=new Command;St.name(_i).description("Connecting stars in your code into intelligent patterns").version(za).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.");St.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 n=>{try{let t={GitClient:new Kt(xi,Q),Reporter:Q};await new Bt(t).run({skipMcp:n.skipMcp,skipCi:n.skipCi});}catch(e){xe(e)||Q.error(e instanceof Error?e.message:String(e)),ke(),process.exit(1);}});St.command("auth").description("Configure authentication for the Constellation CLI").option("--manual","Use manual access key entry instead of browser-based authentication").action(async n=>{try{let e={Environment:Ci,Reporter:Q};await new Ct(e).run(n.manual);}catch(e){xe(e)||Q.error(e instanceof Error?e.message:String(e)),ke(),process.exit(1);}});St.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 n=>{try{let e=await Vr.loadFromFile(k__default.join(xi,"constellation.json")),t=new Kt(xi,Q),r=new Ir(e),o=new Qr(e),s={GitClient:t,Config:e,LanguageRegistry:r,LanguageDetector:o,Environment:Ci,Reporter:Q},a=Ci.isCI(),l=n.full||!n.incremental&&a,c=n.dirty||!1,u=!0;!n.full&&!n.incremental&&a&&Q.info("CI environment detected \u2014 defaulting to full index. Use --incremental to override."),await new Ut(s).run(l,c,u);}catch(e){xe(e)||Q.error(e instanceof Error?e.message:String(e)),ke(),process.exit(1);}});St.command("print-grammar-versions",{hidden:true}).description("Emit installed tree-sitter grammar versions as JSON").action(()=>{try{process.stdout.write(JSON.stringify(Ba())+`
138
+ `);}catch(n){xe(n)||Q.error(n instanceof Error?n.message:String(n)),ke(),process.exit(1);}});St.parse();});var Va=/^>=\s*\d+\.\d+\.\d+$/;function Ri(n,e=process.version){if(!Va.test(n))return {compatible:true,current:e,required:n};let t=n.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:n}}nn();var bm=dirname(fileURLToPath(import.meta.url)),Sm=join(bm,"..","package.json"),Ei=JSON.parse(readFileSync(Sm,"utf-8")),wm=process.argv[2];if(!Vt.includes(wm)&&Ei.engines?.node){let n=Ri(Ei.engines.node);n.compatible||(console.error(`Error: Constellation CLI requires Node.js ${n.required} (current: ${n.current})`),console.error(" Please upgrade to the latest LTS version: https://nodejs.org"),process.exit(1));}globalThis.__constellationVersion=Ei.version;await Wa().then(()=>fm);