ts-pantry 0.9.13 → 0.9.18

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.
@@ -0,0 +1 @@
1
+ import{Aa as b,Ba as c,Ca as d,Da as e,Ea as f,Fa as g,Ga as h,Ha as i,Ia as j,za as a}from"./chunk-mcz89rzg.js";import"./chunk-z5kje5x9.js";export{j as updateApp,g as scanInstalledApps,h as queryBrewCaskVersions,d as isNewerVersion,e as guessCaskToken,f as getCaskToken,i as checkAppUpdates,b as SYSTEM_APPS,c as MAS_APPS,a as APP_CASK_MAP};
@@ -1,4 +1,4 @@
1
- import{fb as k,gb as c,hb as p}from"./chunk-xxpems7r.js";import{Bb as h,Cb as GQ}from"./chunk-jywhngj7.js";import{Db as $Q,Eb as qQ}from"./chunk-04eamjdw.js";import{Jb as QQ}from"./chunk-sd8qadhd.js";import H from"node:fs";import w from"node:path";import I from"node:process";GQ();var JQ=async(...Q)=>null;function m(Q,K){let G=Q.replace(/^v/,"").split("."),$=K.replace(/^v/,"").split(".");for(let q=0;q<Math.max(G.length,$.length);q++){let Z=Number.parseInt(G[q]||"0",10),X=Number.parseInt($[q]||"0",10);if(!Number.isNaN(Z)&&!Number.isNaN(X)){if(Z!==X)return X-Z}else{let Y=($[q]||"").localeCompare(G[q]||"");if(Y!==0)return Y}}return 0}function a(Q){if(Q.includes("/")){let[K,...G]=Q.split("/"),$=G.join("/"),q=K.replace(/\./g,"");if(K.includes("github.com")){let X=$.split("/");return X[X.length-1].replace(/[.-]/g,"").toLowerCase()}let Z=$.replace(/[/.-]/g,"");return`${q}${Z}`.toLowerCase()}return Q.replace(/\./g,"").toLowerCase()}function YQ(Q,K){switch(Q){case"versions":if(Array.isArray(K)&&K.length>0)return` /**
1
+ import{jb as k,kb as c,lb as p}from"./chunk-rkak2mvz.js";import{Fb as h,Gb as GQ}from"./chunk-cxg0wv4z.js";import{Hb as $Q,Ib as qQ}from"./chunk-9yep1cys.js";import{Nb as QQ}from"./chunk-z5kje5x9.js";import H from"node:fs";import w from"node:path";import I from"node:process";GQ();var JQ=async(...Q)=>null;function m(Q,K){let G=Q.replace(/^v/,"").split("."),$=K.replace(/^v/,"").split(".");for(let q=0;q<Math.max(G.length,$.length);q++){let Z=Number.parseInt(G[q]||"0",10),X=Number.parseInt($[q]||"0",10);if(!Number.isNaN(Z)&&!Number.isNaN(X)){if(Z!==X)return X-Z}else{let Y=($[q]||"").localeCompare(G[q]||"");if(Y!==0)return Y}}return 0}function a(Q){if(Q.includes("/")){let[K,...G]=Q.split("/"),$=G.join("/"),q=K.replace(/\./g,"");if(K.includes("github.com")){let X=$.split("/");return X[X.length-1].replace(/[.-]/g,"").toLowerCase()}let Z=$.replace(/[/.-]/g,"");return`${q}${Z}`.toLowerCase()}return Q.replace(/\./g,"").toLowerCase()}function YQ(Q,K){switch(Q){case"versions":if(Array.isArray(K)&&K.length>0)return` /**
2
2
  * Available versions from newest to oldest.
3
3
  * @see https://ts-pantry.netlify.app/usage for installation instructions
4
4
  */`;break;case"programs":if(Array.isArray(K)&&K.length>0)return` /**
@@ -31,12 +31,12 @@ import{fb as k,gb as c,hb as p}from"./chunk-xxpems7r.js";import{Bb as h,Cb as GQ
31
31
  export const ${Z} = ${Y}
32
32
 
33
33
  export type ${Z.charAt(0).toUpperCase()+Z.slice(1)} = typeof ${Z}
34
- `}function r(Q){let K=Q.replace(/\{\{[^}]*\}\}/g,"").replace(/-{2,}/g,"-").replace(/^-+|-+$/g,"");if(!K||K.length===0)return"package";let G=K.replace(/[^\w.-]/g,"-");if(G.length>200)G=`${G.substring(0,150)}...${G.substring(G.length-45)}`;return G}function N(Q,K,G){if(!H.existsSync(Q))H.mkdirSync(Q,{recursive:!0});let $;if(K.includes("/")){let X=K.split("/"),Y=X[0],W=X.slice(1),J=w.join(Q,Y,...W.slice(0,-1));if(!H.existsSync(J))H.mkdirSync(J,{recursive:!0});let B=r(W[W.length-1]);$=w.join(J,`${B}.ts`)}else{let X=K.replace(/\./g,"");$=w.join(Q,`${X}.ts`)}let q={...G};delete q.fetchedAt;let Z=zQ(q,K);return H.writeFileSync($,Z),$}function AQ(Q,K){if(!H.existsSync(Q))return[];let G=new Set;for(let X of K)if(X.includes("/")){let Y=X.split("/"),W=Y[0],J=Y.slice(1),B=r(J[J.length-1]);G.add(w.resolve(Q,W,...J.slice(0,-1),`${B}.ts`))}else{let Y=X.replace(/\./g,"");G.add(w.resolve(Q,`${Y}.ts`))}let $=new Set(["index.ts","aliases.ts","types.ts"]),q=[];function Z(X){if(!H.existsSync(X))return;for(let Y of H.readdirSync(X,{withFileTypes:!0})){let W=w.join(X,Y.name);if(Y.isDirectory()){if(Z(W),H.existsSync(W)&&H.readdirSync(W).length===0)H.rmdirSync(W)}else if(Y.name.endsWith(".ts")&&!$.has(Y.name)){if(!G.has(w.resolve(W)))H.unlinkSync(W),q.push(W)}}}return Z(Q),q}function _Q(Q,K={}){try{let G=K.cacheDir||k;if(K.cache===!1)return console.log(`Cache disabled for ${Q}, skipping cache check`),null;let q=(h[Q]||Q).replace(/\//g,"-"),Z=w.join(G,`${q}.json`);if(console.log(`Checking for cache file: ${Z}`),!H.existsSync(Z))return null;let X=JSON.parse(H.readFileSync(Z,"utf-8"));if(!X.fetchedAt)return console.log(`Cache for ${Q} missing fetchedAt timestamp, invalidating`),null;if(["Crafters of fine Open Source products","Go home.","Package information for","pkgx package","Loading...","Please wait..."].some((A)=>X.description&&X.description.includes(A)))return console.log(`Cache for ${Q} has generic description "${X.description}", invalidating`),null;if(!X.versions||X.versions.length===0)return console.log(`Cache for ${Q} has no versions, invalidating`),null;let B=(K.cacheExpirationMinutes||c)*60*1000,C=Date.now();if(C-X.fetchedAt>B)return console.log(`Cache for ${Q} has expired (age: ${Math.round((C-X.fetchedAt)/60000)} minutes)`),null;return console.log(`Using cached data for ${Q} (age: ${Math.round((C-X.fetchedAt)/60000)} minutes)`),{packageInfo:X,filePath:Z}}catch(G){return console.error(`Error reading cache for ${Q}:`,G),null}}function jQ(Q,K,G={}){let $={...K,fetchedAt:Date.now()},q=G.cacheDir||k;if(!H.existsSync(q))H.mkdirSync(q,{recursive:!0});let Z=Q.replace(/\//g,"-"),X=w.join(q,`${Z}.json`);H.writeFileSync(X,JSON.stringify($,null,2));let Y=G.outputDir||"packages";if(!H.existsSync(Y))H.mkdirSync(Y,{recursive:!0});let W=N(Y,Q,K);return{cachePath:X,outputPath:W}}function KQ(){return Promise.resolve()}async function SQ(Q={}){let K=Q.apiUrl||"https://api.github.com/repos/pkgxdev/pantry/contents/projects";try{console.log(`Fetching projects from GitHub API: ${K}`);let G=await fetch(K,{headers:{Accept:"application/vnd.github.v3+json"}});if(!G.ok)throw Error(`Failed to fetch from GitHub API: ${G.statusText}`);let q=(await G.json()).filter((Z)=>Z.type==="dir").map((Z)=>({name:Z.name,url:Z.html_url}));return console.log(`Retrieved ${q.length} projects from GitHub API`),q.sort((Z,X)=>Z.name.localeCompare(X.name)),q}catch(G){throw console.error("Error fetching projects from GitHub API:",G),G}}async function t(Q,K={}){let G=Q,$=Q;if(Q.includes("/")){let[q,Z]=Q.split("/");console.log(`Identified nested package: domain=${q}, name=${Z}`)}if(h[Q])console.log(`'${Q}' is an alias for '${h[Q]}', redirecting...`),$=h[Q],Q=h[Q];try{let q=K.timeout||p,Z=await JQ(Q,{timeout:q,useClientSideScraper:!0}),X={name:Z.displayName||Z.name||Q.split("/").pop()||Q,domain:Z.domain||Q,description:Z.description||Z.brief||"",packageYmlUrl:`https://github.com/pkgxdev/pantry/tree/main/projects/${Q}/package.yml`,homepageUrl:Z.homepage||"",githubUrl:Z.github||"",installCommand:`pantry install ${Q}`,pkgxInstallCommand:`sh <(curl https://pkgx.sh) +${Q} -- $SHELL -i`,pantryInstallCommand:`pantry install ${Q}`,programs:Z.provides||[],companions:Array.isArray(Z.companions)?Z.companions:[],dependencies:Array.isArray(Z.dependencies)?Z.dependencies:[],buildDependencies:Z.buildDependencies||[],versions:Z.versions||[],aliases:[]};if(!X.versions||X.versions.length===0){let Y=X.domain||Q;if(!["apache.org","breakfastquay.com","catb.org","bloomreach.com","cairographics.org","certifi.io","charm.sh","aws.amazon.com","google.com","microsoft.com","mozilla.org","freedesktop.org","gnome.org","kde.org","sourceforge.net","sf.net"].some((J)=>Y.startsWith(J)))try{let J=X.domain||Q,B=await HQ(J);X.versions=B}catch(J){console.warn(`Failed to fetch versions for ${Q} from GitHub API:`,J),X.versions=[]}}if(X.versions&&X.versions.length>0)try{X.versions.sort((Y,W)=>{try{return-1*Bun.semver.order(Y,W)}catch{return m(Y,W)}})}catch(Y){console.warn(`Warning: Failed to sort versions for ${Q} using semver:`,Y)}return X.name=X.name||G,X.domain=X.domain||$,X.programs=X.programs||[],X.companions=X.companions||[],X.dependencies=X.dependencies||[],X.versions=X.versions||[],{packageInfo:X,originalName:G,fullDomainName:$}}catch(q){return console.error(`Error in fetchPantryPackage for ${Q}:`,q),RQ(Q,G,$)}}async function HQ(Q){try{let{shouldProceedWithGitHubRequest:K,saveRateLimitInfo:G}=await import("./chunk-g70t2h3c.js");if(!K())return console.warn("Skipping GitHub API request for versions due to rate limiting"),[];let $=await fetch(`https://api.github.com/repos/pkgxdev/pantry/contents/projects/${Q}`,{headers:{Accept:"application/vnd.github.v3+json","User-Agent":"ts-pantry"},signal:AbortSignal.timeout(15000)});if(G($.headers),$.status===403){let Z=$.headers.get("X-RateLimit-Remaining"),X=$.headers.get("X-RateLimit-Reset"),Y=X?new Date(Number(X)*1000).toLocaleString():"unknown";return console.warn(`GitHub API rate limit exceeded. Remaining: ${Z||0}, Reset: ${Y}`),[]}if(!$.ok)throw Error(`GitHub API responded with ${$.status}: ${$.statusText}`);return(await $.json()).filter((Z)=>Z.name.match(/^v\d+/)).map((Z)=>Z.name)}catch(K){return console.error("Error fetching versions from GitHub:",K),[]}}var LQ=300000,l=null;function UQ(){let Q=async(K)=>{if(console.log(`
35
- Received ${K} signal. Cleaning up resources...`),l)clearInterval(l);await KQ(),console.log("Resources cleaned up. Exiting."),setTimeout(()=>{console.log("Forcing process exit..."),I.exit(0)},5000)};I.on("SIGINT",()=>Q("SIGINT")),I.on("SIGTERM",()=>Q("SIGTERM")),I.on("uncaughtException",(K)=>{console.error("Uncaught exception:",K),Q("uncaughtException")})}UQ();I.on("uncaughtException",(Q)=>{let K=String(Q);if(console.error("Uncaught exception caught:",Q.message),Q.message.includes("No target found for targetId")||Q.message.includes("Assertion error")||Q.message.includes("Target page, context or browser has been closed")||Q.message.includes("Failed to connect")||Q.message.includes("Connection closed")||Q.message.includes("Protocol error")||K.includes("WebSocket connection closed")||Q.message.includes("Browser has been closed")){console.error("Browser/network connection error detected, continuing execution...");return}console.error("Non-browser error, exiting..."),I.exit(1)});I.on("unhandledRejection",(Q,K)=>{let G=String(Q);if(console.error("Unhandled rejection caught:",G),G.includes("No target found for targetId")||G.includes("Assertion error")||G.includes("Target page, context or browser has been closed")||G.includes("Failed to connect")||G.includes("Connection closed")||G.includes("Protocol error")||G.includes("WebSocket connection closed")||G.includes("Browser has been closed")){console.error("Browser/network connection error in promise, continuing execution...");return}console.error("Non-browser promise rejection, exiting..."),I.exit(1)});function yQ(){if(l)clearInterval(l);l=setInterval(()=>{console.log("Running periodic browser resource cleanup..."),KQ().then(()=>console.log("Periodic cleanup completed")).catch((Q)=>console.error("Error during periodic cleanup:",Q))},LQ)}async function vQ(Q={}){let K=Q.timeout||p,G=Q.outputDir||"packages",$=Q.cacheDir||k,q=Q.cache!==!1,Z=Q.cacheExpirationMinutes||c,X=Math.min(Q.concurrency||6,8),Y=Q.pantryDir||"src/pantry";if(!Q.outputJson)console.log(`Starting bulk fetch with concurrency: ${X}, timeout: ${K}ms`);let W=Date.now(),J=[];try{if(!Q.outputJson)console.log("Scanning local pantry for packages...");try{if(J=await OQ(Y),!Q.outputJson)console.log(`Found ${J.length} packages in local pantry`)}catch(j){if(!Q.outputJson)console.warn("Failed to scan local pantry, falling back to consts:",j);try{let{ALL_KNOWN_PACKAGES:z}=await import("./chunk-v54492f4.js");if(J=[...z].filter((L)=>L&&L!=="undefined"&&L!=="aliases"&&L!=="index"),!Q.outputJson)console.log(`Using comprehensive package list: ${J.length} packages`)}catch(z){if(!Q.outputJson)console.warn("Failed to load consts, falling back to GitHub API:",z);try{let L=await fetch("https://api.github.com/repos/pkgxdev/pantry/contents/projects",{headers:{"User-Agent":"ts-pantry-fetcher",Accept:"application/vnd.github.v3+json"}});if(L.ok){let U=(await L.json()).filter((V)=>V.type==="dir").map((V)=>V.name).sort();if(!Q.outputJson)console.log(`Retrieved ${U.length} projects from GitHub API`);J=U}else throw Error(`GitHub API returned ${L.status}`)}catch(L){if(!Q.outputJson)console.warn("Failed to fetch from GitHub API, falling back to local discovery:",L);if(H.existsSync(G))J=H.readdirSync(G).filter((U)=>U.endsWith(".ts")).map((U)=>w.basename(U,".ts")),console.log(`Found ${J.length} existing packages`)}}}if(J.length===0)return console.error("No packages found to process"),[];let B=["android.com","apache.org","akuity.io","alsa-project.org","anchore.com","aomedia.googlesource.com","apollographql.com","facebook.com","google.com","microsoft.com","mozilla.org","sourceforge.net","x.org","xiph.org","yui.github.io","crates.io","gitlab.com","github.com"],C=new Set,A=J.filter((j)=>j.startsWith("github.com/"));for(let j of A){let z=j.split("/");if(z.length>2){let L=z.slice(0,2).join("/");C.add(L)}}if(J=J.filter((j)=>{if(j.endsWith("/.pkgroot"))return console.log(`Filtering out .pkgroot marker: ${j}`),!1;if(j.endsWith("/README.rst"))return console.log(`Filtering out README.rst documentation: ${j}`),!1;if(j==="agwa.name")return console.log("Filtering out standalone agwa.name - only agwa.name/git-crypt is valid"),!1;if(B.includes(j))return console.log(`Filtering out parent domain ${j} - only has nested packages`),!1;if(C.has(j))return console.log(`Filtering out GitHub parent path ${j} - only has nested packages`),!1;if(j==="undefined"||j==="aliases"||j==="index")return!1;return!0}),console.log(`Found ${J.length} packages to process`),Q.limit&&Q.limit>0)J=J.slice(0,Q.limit),console.log(`Limited to ${J.length} packages`);let F=[],E=[],x=0,_=Math.min(X,6),O=[];for(let j=0;j<J.length;j+=_)O.push(J.slice(j,j+_));if(!Q.outputJson)console.log(`Processing ${J.length} packages in ${O.length} batches...`);for(let j=0;j<O.length;j++){let z=O[j];if(!Q.outputJson)console.log(`Processing batch ${j+1}/${O.length} (${z.length} packages)`);let L=z.map(async(R)=>{try{let S=w.join($,`${R.replace(/\//g,"-")}.json`);if(q&&H.existsSync(S)){let d=H.statSync(S),u=(Date.now()-d.mtime.getTime())/60000;if(u<Z){if(!Q.outputJson)console.log(`Using cached data for ${R} (age: ${Math.round(u)} minutes)`);try{let g=JSON.parse(H.readFileSync(S,"utf-8"));delete g.fetchedAt;let f=N(G,R,g);if(!Q.outputJson)console.log(`Using cached data for ${R} (saved to ${f})`);return{success:!0,packageName:R}}catch{console.warn(`Cache file corrupted for ${R}, will refetch`)}}}let v=await VQ(R,{...Q,pantryDir:Y,timeout:K,cache:q,cacheDir:$,cacheExpirationMinutes:Z});if(v){let{outputPath:d}=jQ(R,v.packageInfo,{cacheDir:$,outputDir:G,cache:q});if(!Q.outputJson)console.log(`Successfully processed ${R} (saved to ${d})`);return{success:!0,packageName:R}}else return console.warn(`Failed to fetch ${R}`),{success:!1,packageName:R}}catch(S){return console.error(`Error processing ${R}:`,S),{success:!1,packageName:R}}}),M=await Promise.allSettled(L);for(let R of M)if(x++,R.status==="fulfilled")if(R.value.success)F.push(R.value.packageName);else E.push(R.value.packageName);else console.error("Batch promise rejected:",R.reason),E.push("unknown");let U=Math.round((Date.now()-W)/1000),V=Math.round(x/U*10)/10,y=Math.round((J.length-x)/V);if(!Q.outputJson)console.log(`Batch ${j+1}/${O.length} complete. Progress: ${x}/${J.length} (${Math.round(x/J.length*100)}%) | Success: ${F.length} | Failed: ${E.length} | Rate: ${V}/s | ETA: ${y}s`);if(j<O.length-1)await new Promise((R)=>setTimeout(R,1000))}let T=Math.round((Date.now()-W)/1000);if(!Q.outputJson){if(console.log(`
34
+ `}function r(Q){let K=Q.replace(/\{\{[^}]*\}\}/g,"").replace(/-{2,}/g,"-").replace(/^-+|-+$/g,"");if(!K||K.length===0)return"package";let G=K.replace(/[^\w.-]/g,"-");if(G.length>200)G=`${G.substring(0,150)}...${G.substring(G.length-45)}`;return G}function N(Q,K,G){if(!H.existsSync(Q))H.mkdirSync(Q,{recursive:!0});let $;if(K.includes("/")){let X=K.split("/"),Y=X[0],W=X.slice(1),J=w.join(Q,Y,...W.slice(0,-1));if(!H.existsSync(J))H.mkdirSync(J,{recursive:!0});let B=r(W[W.length-1]);$=w.join(J,`${B}.ts`)}else{let X=K.replace(/\./g,"");$=w.join(Q,`${X}.ts`)}let q={...G};delete q.fetchedAt;let Z=zQ(q,K);return H.writeFileSync($,Z),$}function AQ(Q,K){if(!H.existsSync(Q))return[];let G=new Set;for(let X of K)if(X.includes("/")){let Y=X.split("/"),W=Y[0],J=Y.slice(1),B=r(J[J.length-1]);G.add(w.resolve(Q,W,...J.slice(0,-1),`${B}.ts`))}else{let Y=X.replace(/\./g,"");G.add(w.resolve(Q,`${Y}.ts`))}let $=new Set(["index.ts","aliases.ts","types.ts"]),q=[];function Z(X){if(!H.existsSync(X))return;for(let Y of H.readdirSync(X,{withFileTypes:!0})){let W=w.join(X,Y.name);if(Y.isDirectory()){if(Z(W),H.existsSync(W)&&H.readdirSync(W).length===0)H.rmdirSync(W)}else if(Y.name.endsWith(".ts")&&!$.has(Y.name)){if(!G.has(w.resolve(W)))H.unlinkSync(W),q.push(W)}}}return Z(Q),q}function _Q(Q,K={}){try{let G=K.cacheDir||k;if(K.cache===!1)return console.log(`Cache disabled for ${Q}, skipping cache check`),null;let q=(h[Q]||Q).replace(/\//g,"-"),Z=w.join(G,`${q}.json`);if(console.log(`Checking for cache file: ${Z}`),!H.existsSync(Z))return null;let X=JSON.parse(H.readFileSync(Z,"utf-8"));if(!X.fetchedAt)return console.log(`Cache for ${Q} missing fetchedAt timestamp, invalidating`),null;if(["Crafters of fine Open Source products","Go home.","Package information for","pkgx package","Loading...","Please wait..."].some((A)=>X.description&&X.description.includes(A)))return console.log(`Cache for ${Q} has generic description "${X.description}", invalidating`),null;if(!X.versions||X.versions.length===0)return console.log(`Cache for ${Q} has no versions, invalidating`),null;let B=(K.cacheExpirationMinutes||c)*60*1000,C=Date.now();if(C-X.fetchedAt>B)return console.log(`Cache for ${Q} has expired (age: ${Math.round((C-X.fetchedAt)/60000)} minutes)`),null;return console.log(`Using cached data for ${Q} (age: ${Math.round((C-X.fetchedAt)/60000)} minutes)`),{packageInfo:X,filePath:Z}}catch(G){return console.error(`Error reading cache for ${Q}:`,G),null}}function jQ(Q,K,G={}){let $={...K,fetchedAt:Date.now()},q=G.cacheDir||k;if(!H.existsSync(q))H.mkdirSync(q,{recursive:!0});let Z=Q.replace(/\//g,"-"),X=w.join(q,`${Z}.json`);H.writeFileSync(X,JSON.stringify($,null,2));let Y=G.outputDir||"packages";if(!H.existsSync(Y))H.mkdirSync(Y,{recursive:!0});let W=N(Y,Q,K);return{cachePath:X,outputPath:W}}function KQ(){return Promise.resolve()}async function SQ(Q={}){let K=Q.apiUrl||"https://api.github.com/repos/pkgxdev/pantry/contents/projects";try{console.log(`Fetching projects from GitHub API: ${K}`);let G=await fetch(K,{headers:{Accept:"application/vnd.github.v3+json"}});if(!G.ok)throw Error(`Failed to fetch from GitHub API: ${G.statusText}`);let q=(await G.json()).filter((Z)=>Z.type==="dir").map((Z)=>({name:Z.name,url:Z.html_url}));return console.log(`Retrieved ${q.length} projects from GitHub API`),q.sort((Z,X)=>Z.name.localeCompare(X.name)),q}catch(G){throw console.error("Error fetching projects from GitHub API:",G),G}}async function t(Q,K={}){let G=Q,$=Q;if(Q.includes("/")){let[q,Z]=Q.split("/");console.log(`Identified nested package: domain=${q}, name=${Z}`)}if(h[Q])console.log(`'${Q}' is an alias for '${h[Q]}', redirecting...`),$=h[Q],Q=h[Q];try{let q=K.timeout||p,Z=await JQ(Q,{timeout:q,useClientSideScraper:!0}),X={name:Z.displayName||Z.name||Q.split("/").pop()||Q,domain:Z.domain||Q,description:Z.description||Z.brief||"",packageYmlUrl:`https://github.com/pkgxdev/pantry/tree/main/projects/${Q}/package.yml`,homepageUrl:Z.homepage||"",githubUrl:Z.github||"",installCommand:`pantry install ${Q}`,pkgxInstallCommand:`sh <(curl https://pkgx.sh) +${Q} -- $SHELL -i`,pantryInstallCommand:`pantry install ${Q}`,programs:Z.provides||[],companions:Array.isArray(Z.companions)?Z.companions:[],dependencies:Array.isArray(Z.dependencies)?Z.dependencies:[],buildDependencies:Z.buildDependencies||[],versions:Z.versions||[],aliases:[]};if(!X.versions||X.versions.length===0){let Y=X.domain||Q;if(!["apache.org","breakfastquay.com","catb.org","bloomreach.com","cairographics.org","certifi.io","charm.sh","aws.amazon.com","google.com","microsoft.com","mozilla.org","freedesktop.org","gnome.org","kde.org","sourceforge.net","sf.net"].some((J)=>Y.startsWith(J)))try{let J=X.domain||Q,B=await HQ(J);X.versions=B}catch(J){console.warn(`Failed to fetch versions for ${Q} from GitHub API:`,J),X.versions=[]}}if(X.versions&&X.versions.length>0)try{X.versions.sort((Y,W)=>{try{return-1*Bun.semver.order(Y,W)}catch{return m(Y,W)}})}catch(Y){console.warn(`Warning: Failed to sort versions for ${Q} using semver:`,Y)}return X.name=X.name||G,X.domain=X.domain||$,X.programs=X.programs||[],X.companions=X.companions||[],X.dependencies=X.dependencies||[],X.versions=X.versions||[],{packageInfo:X,originalName:G,fullDomainName:$}}catch(q){return console.error(`Error in fetchPantryPackage for ${Q}:`,q),RQ(Q,G,$)}}async function HQ(Q){try{let{shouldProceedWithGitHubRequest:K,saveRateLimitInfo:G}=await import("./chunk-3kd72v8e.js");if(!K())return console.warn("Skipping GitHub API request for versions due to rate limiting"),[];let $=await fetch(`https://api.github.com/repos/pkgxdev/pantry/contents/projects/${Q}`,{headers:{Accept:"application/vnd.github.v3+json","User-Agent":"ts-pantry"},signal:AbortSignal.timeout(15000)});if(G($.headers),$.status===403){let Z=$.headers.get("X-RateLimit-Remaining"),X=$.headers.get("X-RateLimit-Reset"),Y=X?new Date(Number(X)*1000).toLocaleString():"unknown";return console.warn(`GitHub API rate limit exceeded. Remaining: ${Z||0}, Reset: ${Y}`),[]}if(!$.ok)throw Error(`GitHub API responded with ${$.status}: ${$.statusText}`);return(await $.json()).filter((Z)=>Z.name.match(/^v\d+/)).map((Z)=>Z.name)}catch(K){return console.error("Error fetching versions from GitHub:",K),[]}}var LQ=300000,l=null;function UQ(){let Q=async(K)=>{if(console.log(`
35
+ Received ${K} signal. Cleaning up resources...`),l)clearInterval(l);await KQ(),console.log("Resources cleaned up. Exiting."),setTimeout(()=>{console.log("Forcing process exit..."),I.exit(0)},5000)};I.on("SIGINT",()=>Q("SIGINT")),I.on("SIGTERM",()=>Q("SIGTERM")),I.on("uncaughtException",(K)=>{console.error("Uncaught exception:",K),Q("uncaughtException")})}UQ();I.on("uncaughtException",(Q)=>{let K=String(Q);if(console.error("Uncaught exception caught:",Q.message),Q.message.includes("No target found for targetId")||Q.message.includes("Assertion error")||Q.message.includes("Target page, context or browser has been closed")||Q.message.includes("Failed to connect")||Q.message.includes("Connection closed")||Q.message.includes("Protocol error")||K.includes("WebSocket connection closed")||Q.message.includes("Browser has been closed")){console.error("Browser/network connection error detected, continuing execution...");return}console.error("Non-browser error, exiting..."),I.exit(1)});I.on("unhandledRejection",(Q,K)=>{let G=String(Q);if(console.error("Unhandled rejection caught:",G),G.includes("No target found for targetId")||G.includes("Assertion error")||G.includes("Target page, context or browser has been closed")||G.includes("Failed to connect")||G.includes("Connection closed")||G.includes("Protocol error")||G.includes("WebSocket connection closed")||G.includes("Browser has been closed")){console.error("Browser/network connection error in promise, continuing execution...");return}console.error("Non-browser promise rejection, exiting..."),I.exit(1)});function yQ(){if(l)clearInterval(l);l=setInterval(()=>{console.log("Running periodic browser resource cleanup..."),KQ().then(()=>console.log("Periodic cleanup completed")).catch((Q)=>console.error("Error during periodic cleanup:",Q))},LQ)}async function vQ(Q={}){let K=Q.timeout||p,G=Q.outputDir||"packages",$=Q.cacheDir||k,q=Q.cache!==!1,Z=Q.cacheExpirationMinutes||c,X=Math.min(Q.concurrency||6,8),Y=Q.pantryDir||"src/pantry";if(!Q.outputJson)console.log(`Starting bulk fetch with concurrency: ${X}, timeout: ${K}ms`);let W=Date.now(),J=[];try{if(!Q.outputJson)console.log("Scanning local pantry for packages...");try{if(J=await OQ(Y),!Q.outputJson)console.log(`Found ${J.length} packages in local pantry`)}catch(j){if(!Q.outputJson)console.warn("Failed to scan local pantry, falling back to consts:",j);try{let{ALL_KNOWN_PACKAGES:z}=await import("./chunk-1e0qbphx.js");if(J=[...z].filter((L)=>L&&L!=="undefined"&&L!=="aliases"&&L!=="index"),!Q.outputJson)console.log(`Using comprehensive package list: ${J.length} packages`)}catch(z){if(!Q.outputJson)console.warn("Failed to load consts, falling back to GitHub API:",z);try{let L=await fetch("https://api.github.com/repos/pkgxdev/pantry/contents/projects",{headers:{"User-Agent":"ts-pantry-fetcher",Accept:"application/vnd.github.v3+json"}});if(L.ok){let U=(await L.json()).filter((V)=>V.type==="dir").map((V)=>V.name).sort();if(!Q.outputJson)console.log(`Retrieved ${U.length} projects from GitHub API`);J=U}else throw Error(`GitHub API returned ${L.status}`)}catch(L){if(!Q.outputJson)console.warn("Failed to fetch from GitHub API, falling back to local discovery:",L);if(H.existsSync(G))J=H.readdirSync(G).filter((U)=>U.endsWith(".ts")).map((U)=>w.basename(U,".ts")),console.log(`Found ${J.length} existing packages`)}}}if(J.length===0)return console.error("No packages found to process"),[];let B=["android.com","apache.org","akuity.io","alsa-project.org","anchore.com","aomedia.googlesource.com","apollographql.com","facebook.com","google.com","microsoft.com","mozilla.org","sourceforge.net","x.org","xiph.org","yui.github.io","crates.io","gitlab.com","github.com"],C=new Set,A=J.filter((j)=>j.startsWith("github.com/"));for(let j of A){let z=j.split("/");if(z.length>2){let L=z.slice(0,2).join("/");C.add(L)}}if(J=J.filter((j)=>{if(j.endsWith("/.pkgroot"))return console.log(`Filtering out .pkgroot marker: ${j}`),!1;if(j.endsWith("/README.rst"))return console.log(`Filtering out README.rst documentation: ${j}`),!1;if(j==="agwa.name")return console.log("Filtering out standalone agwa.name - only agwa.name/git-crypt is valid"),!1;if(B.includes(j))return console.log(`Filtering out parent domain ${j} - only has nested packages`),!1;if(C.has(j))return console.log(`Filtering out GitHub parent path ${j} - only has nested packages`),!1;if(j==="undefined"||j==="aliases"||j==="index")return!1;return!0}),console.log(`Found ${J.length} packages to process`),Q.limit&&Q.limit>0)J=J.slice(0,Q.limit),console.log(`Limited to ${J.length} packages`);let F=[],E=[],x=0,_=Math.min(X,6),O=[];for(let j=0;j<J.length;j+=_)O.push(J.slice(j,j+_));if(!Q.outputJson)console.log(`Processing ${J.length} packages in ${O.length} batches...`);for(let j=0;j<O.length;j++){let z=O[j];if(!Q.outputJson)console.log(`Processing batch ${j+1}/${O.length} (${z.length} packages)`);let L=z.map(async(R)=>{try{let S=w.join($,`${R.replace(/\//g,"-")}.json`);if(q&&H.existsSync(S)){let d=H.statSync(S),u=(Date.now()-d.mtime.getTime())/60000;if(u<Z){if(!Q.outputJson)console.log(`Using cached data for ${R} (age: ${Math.round(u)} minutes)`);try{let g=JSON.parse(H.readFileSync(S,"utf-8"));delete g.fetchedAt;let f=N(G,R,g);if(!Q.outputJson)console.log(`Using cached data for ${R} (saved to ${f})`);return{success:!0,packageName:R}}catch{console.warn(`Cache file corrupted for ${R}, will refetch`)}}}let v=await VQ(R,{...Q,pantryDir:Y,timeout:K,cache:q,cacheDir:$,cacheExpirationMinutes:Z});if(v){let{outputPath:d}=jQ(R,v.packageInfo,{cacheDir:$,outputDir:G,cache:q});if(!Q.outputJson)console.log(`Successfully processed ${R} (saved to ${d})`);return{success:!0,packageName:R}}else return console.warn(`Failed to fetch ${R}`),{success:!1,packageName:R}}catch(S){return console.error(`Error processing ${R}:`,S),{success:!1,packageName:R}}}),M=await Promise.allSettled(L);for(let R of M)if(x++,R.status==="fulfilled")if(R.value.success)F.push(R.value.packageName);else E.push(R.value.packageName);else console.error("Batch promise rejected:",R.reason),E.push("unknown");let U=Math.round((Date.now()-W)/1000),V=Math.round(x/U*10)/10,y=Math.round((J.length-x)/V);if(!Q.outputJson)console.log(`Batch ${j+1}/${O.length} complete. Progress: ${x}/${J.length} (${Math.round(x/J.length*100)}%) | Success: ${F.length} | Failed: ${E.length} | Rate: ${V}/s | ETA: ${y}s`);if(j<O.length-1)await new Promise((R)=>setTimeout(R,1000))}let T=Math.round((Date.now()-W)/1000);if(!Q.outputJson){if(console.log(`
36
36
  Completed in ${T}s. Successfully processed: ${F.length}, Failed: ${E.length}`),E.length>0)console.log(`Failed packages: ${E.slice(0,10).join(", ")}${E.length>10?` ... and ${E.length-10} more`:""}`)}return F}catch(B){return console.error("Error in fetchAndSaveAllPackages:",B),[]}}function RQ(Q,K,G){let $=Q.split("/"),q=$[0];return{packageInfo:{name:($.length>1?$.slice(1).join("/"):null)||Q,domain:q,description:`Package information for ${Q}`,packageYmlUrl:"",homepageUrl:"",githubUrl:"",installCommand:`pantry install ${Q}`,pkgxInstallCommand:`sh <(curl https://pkgx.sh) +${Q} -- $SHELL -i`,pantryInstallCommand:`pantry install ${Q}`,programs:[],companions:[],dependencies:[],versions:[]},originalName:K,fullDomainName:G}}async function EQ(Q,K,G,$=!1,q=1,Z=3,X=!1,Y={}){try{let W=Y.cache!==!1,J=Y.cacheDir||k;if(!W)console.log(`Cache disabled for ${Q}, will fetch directly`);else{let E=_Q(Q,{cacheDir:J,cacheExpirationMinutes:Y.cacheExpirationMinutes,cache:Y.cache});if(E){let{packageInfo:x}=E,_=x.domain||Q,O=x.aliases||[],T=N(K,Q,x);return console.log(`Using cached data for ${Q} (saved to ${T})`),{success:!0,fullDomainName:_,aliases:O,filePath:T}}}let C=G+(q-1)*1e4;console.log(`Using timeout for ${Q} (attempt ${q}): ${C}ms`);let A=C,F=new Promise((E,x)=>{setTimeout(()=>{console.error(`Operation timeout for ${Q} after ${A}ms`),x(Error(`Operation timeout after ${A}ms`))},A)});if(Q.includes("/")){let E=Q.split("/"),x=E[0],_=E.slice(1).join("/");console.log(`Processing nested package: domain=${x}, subPath=${_}`);try{let O=t(`${x}/${_}`,{timeout:C,browser:Y.browser}),T=await Promise.race([O,F]),{packageInfo:j,originalName:z,fullDomainName:L}=T;if(j.versions&&j.versions.length>0)try{j.versions.sort((S,v)=>{try{return-1*Bun.semver.order(S,v)}catch{return m(S,v)}})}catch(S){console.warn(`Warning: Failed to sort versions for ${Q} using semver:`,S)}let M=L.replace(/\//g,"-"),U=[];if(j.aliases&&j.aliases.length>0)U.push(...j.aliases);for(let[S,v]of Object.entries(h))if(v===L&&!U.includes(S))U.push(S);if(z!==L&&!U.includes(z))U.push(z);let V=["cli","app","tool","server","client","api","lib","core"];if(!U.includes(_)&&!V.includes(_.toLowerCase()))U.push(_);let y={...j,fullPath:Q,aliases:U.length>0?U:[]};if(W){let S=w.join(J,`${M}.json`),v={...y,fetchedAt:Date.now()};if(!H.existsSync(J))H.mkdirSync(J,{recursive:!0});H.writeFileSync(S,JSON.stringify(v,null,2)),console.log(`Saved package data to cache: ${S}`)}let R=N(K,L,y);return console.log(`Successfully saved nested package ${Q} to ${R} with aliases: ${U.join(", ")||"none"}`),{success:!0,fullDomainName:L,aliases:U,filePath:R}}catch(O){if(O.toString().includes("404")||O.toString().includes("Not Found"))return console.error(`Package ${Q} returned 404 Not Found.`),console.error(`Skipping ${Q} to avoid overwriting existing files.`),{success:!1,fullDomainName:Q};throw O}}else try{let E=t(Q,{timeout:C,browser:Y.browser}),x=await Promise.race([E,F]),{packageInfo:_,originalName:O,fullDomainName:T}=x,j=_.description&&_.description.trim()!=="",z=_.versions&&_.versions.length>0,L=_.programs&&_.programs.length>0,M=_.packageYmlUrl&&_.packageYmlUrl.length>0,U=_.dependencies&&_.dependencies.length>0,V=_.companions&&_.companions.length>0,y=j&&(_.description.toLowerCase().trim()==="go home."||_.description.toLowerCase().trim()==="page not found"||_.description.toLowerCase().trim()==="not found"||_.description.toLowerCase().trim()==="404"||_.description.toLowerCase().trim()==="error"),R=j&&!y,S=z||L||M||U||V,v=_.domain&&_.domain.includes(".");if(!(R||S||v))return console.error(`Package ${Q} appears to have no meaningful data. Skipping to avoid creating empty files.`),{success:!1,fullDomainName:Q};let u=_.name&&_.name!==T&&_.name!==T.split("/")[0]&&_.name.length>1&&!_.name.includes("/")?r(_.name):null,g=T.replace(/\//g,"-"),f=u?w.join(K,`${u}.ts`):w.join(K,`${g}.ts`);if(H.existsSync(f)){let b=H.readFileSync(f,"utf-8"),D=b.includes("dependencies: [")&&!b.includes("dependencies: [] as const"),i=_.dependencies.length===0,n=!b.includes("description: 'Package information for")&&!b.includes("description: '' as const"),e=_.description.includes("Package information for")||_.description.trim()==="";if(D&&i||n&&e)return console.warn(`⚠️ Existing file ${f} has better data than new fetch. Skipping to prevent data loss.`),console.warn(` Existing deps: ${D}, New deps: ${!i}`),console.warn(` Existing desc: ${n}, New desc: ${!e}`),{success:!1,fullDomainName:Q}}if(_.versions&&_.versions.length>0)try{_.versions.sort((b,D)=>{try{return-1*Bun.semver.order(b,D)}catch{return m(b,D)}})}catch(b){console.warn(`Warning: Failed to sort versions for ${Q} using semver:`,b)}let XQ=T.replace(/\//g,"-"),P=[];if(_.aliases&&_.aliases.length>0)P.push(..._.aliases);for(let[b,D]of Object.entries(h))if(D===T&&!P.includes(b))P.push(b);if(O!==T&&!P.includes(O))P.push(O);let s={..._,fullPath:Q,aliases:P.length>0?P:[]};if(W){let b=w.join(J,`${XQ}.json`),D={...s,fetchedAt:Date.now()};if(!H.existsSync(J))H.mkdirSync(J,{recursive:!0});H.writeFileSync(b,JSON.stringify(D,null,2)),console.log(`Saved package data to cache: ${b}`)}let o=N(K,T,s);return console.log(`Successfully saved ${Q} to ${o} with aliases: ${P.join(", ")||"none"}`),{success:!0,fullDomainName:T,aliases:P,filePath:o}}catch(E){if(E.toString().includes("404")||E.toString().includes("Not Found"))return console.error(`Package ${Q} returned 404 Not Found. Skipping to avoid overwriting existing files.`),{success:!1,fullDomainName:Q};throw E}}catch(W){let J=String(W),B=J.includes("Operation timed out after")||J.includes("Operation timeout after")||J.includes("timeout")||J.includes("Timeout")||J.includes("Navigation timeout"),C=J.includes("No target found")||J.includes("targetId")||J.includes("Target page, context or browser has been closed")||J.includes("Protocol error")||J.includes("Connection closed")||J.includes("Assertion error")||J.includes("Browser has been closed")||J.includes("Target closed")||J.includes("Session closed")||J.includes("WebSocket connection closed");if(B)console.error(`Timeout error for ${Q}:`,J.substring(0,200)),await new Promise((F)=>setTimeout(F,1000*q));else if(C){if(console.error(`Browser connection error for ${Q}:`,J.substring(0,200)),Y.browser)try{await Y.browser.close().catch(()=>{})}catch{}await new Promise((F)=>setTimeout(F,3000*q))}if(q>=Z){if(console.error(`Failed to fetch package ${Q} after ${q} attempts:`,W),X){let F=w.join(I.cwd(),`${Q.replace(/\//g,"-")}-error.txt`);H.writeFileSync(F,`Error fetching ${Q}:
37
37
  ${W.toString()}
38
38
 
39
39
  Stack:
40
40
  ${W.stack||"No stack trace available"}`),console.error(`Saved error details to ${F}`)}return console.error(`Skipping ${Q} after ${q} failed attempts to avoid overwriting existing files.`),{success:!1,fullDomainName:Q}}console.error(`Attempt ${q} failed for ${Q}, retrying...`,W);let A=500*q;if(C)A=2000*q;else if(B)A=1000*q;return await new Promise((F)=>setTimeout(F,A)),EQ(Q,K,G,$,q+1,Z,X,Y)}}async function OQ(Q="src/pantry"){if(!H.existsSync(Q))throw Error(`Pantry directory not found: ${Q}. Please run 'bun ./bin/cli.ts update-pantry' first.`);let K=[];function G($,q=""){let Z=H.readdirSync($,{withFileTypes:!0}),X=w.join($,"package.yml");if(q&&H.existsSync(X))K.push(q);for(let Y of Z)if(Y.isDirectory()&&!Y.name.startsWith(".")){let W=q?`${q}/${Y.name}`:Y.name,J=w.join($,Y.name);G(J,W)}}return G(Q),console.log(`Found ${K.length} packages in pantry`),K.sort()}async function BQ(Q,K="src/pantry"){let G=w.join(K,Q,"package.yml");if(!H.existsSync(G))return console.warn(`Package.yml not found for ${Q}`),null;try{let $=H.readFileSync(G,"utf-8"),q=[],Z=[],X=$.split(`
41
41
  `),Y=!1,W=!1,J=!1,B="";for(let z of X){if(z.match(/^dependencies:\s*$/)){Y=!0,W=!1,J=!1;continue}if(z.match(/^\s{2}dependencies:\s*$/)){W=!0,Y=!1,J=!1;continue}if(Y||W){if(z.match(/^\s*$/)||Y&&z.match(/^\S/)||W&&!z.match(/^\s{4,}/)){Y=!1,W=!1,J=!1;continue}let L=z.match(/^\s{2}(linux|darwin|windows):\s*$/);if(L){J=!0,B=L[1];continue}if(J){let M=z.match(/^\s{4,}([^\s:]+):\s*['"]?([^'"]+)['"]?/);if(M){let U=M[1],V=M[2].trim(),y=`${B}:`;if(V&&V!=="*"){let R=/^[~^>=<@]/.test(V),S=/^[\d.]+$/.test(V)&&/^\d/.test(V),d=`${y}${U}${R?"":S?"@":"^"}${V}`;if(W)Z.push(d);else q.push(d)}else{let R=`${y}${U}`;if(W)Z.push(R);else q.push(R)}}else if(!z.match(/^\s{4,}/)&&!z.match(/^\s*$/))J=!1,B=""}else{let M=z.match(/^\s{2,3}([^\s:]+):\s*['"]?([^'"]+)['"]?/);if(M){let U=M[1],V=M[2].trim();if(["linux","darwin","windows"].includes(U))continue;if(V&&V!=="*"){let y=/^[~^>=<@]/.test(V),R=/^[\d.]+$/.test(V)&&/^\d/.test(V),v=`${U}${y?"":R?"@":"^"}${V}`;if(W)Z.push(v);else q.push(v)}else{let y=U;if(W)Z.push(y);else q.push(y)}}}}}let C=[],A=!1;for(let z of X){if(z.match(/^runtime:\s*$/)){A=!0;continue}if(A){if(z.match(/^\s*$/)||z.match(/^\S/)){A=!1;continue}if(z.match(/^\s+env:\s*$/))continue;if(z.match(/^\s+[A-Z_]+:\s*\$\{\{/))continue;let L=z.match(/^\s+([^\s:]+):\s*['"]?([^'"]+)['"]?/);if(L){let M=L[1],U=L[2].trim();if(/^[A-Z_]+$/.test(M))continue;if(U&&U!=="*"){let V=/^[~^>=<@]/.test(U),y=/^[\d.]+$/.test(U)&&/^\d/.test(U),R=V?"":y?"@":"^";C.push(`${M}${R}${U}`)}else C.push(M)}}}let F="",E="",x=$.match(/distributable:[\t\v\f\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]*\n\s*url:\s*(.+)/);if(x){let z=x[1].trim();if(z.includes("github.com")){let L=z.match(/git\+https:\/\/github\.com\/([^/]+\/[^.]+)/);if(L){if(E=`https://github.com/${L[1]}`,L[1]==="python-attrs/attrs")F="https://www.attrs.org/"}}}let _=[],O=!1,T=!1;for(let z of X){if(z.match(/^provides:\s*$/)){O=!0,T=!1;continue}if(O){if(z.match(/^\S/)&&!z.match(/^\s*$/)){O=!1;continue}if(z.match(/^\s+(darwin|linux|windows):\s*$/)){T=!0;continue}let L=z.match(/^\s+-\s+(?:bin|sbin)\/(.+)/);if(L){let M=L[1].trim();if(!_.includes(M))_.push(M)}}}return{name:Q.split("/").pop()||Q,domain:Q,dependencies:q,buildDependencies:Z,companions:C,programs:_,homepageUrl:F,githubUrl:E}}catch($){return console.warn(`Error reading package.yml for ${Q}:`,$),null}}async function VQ(Q,K={}){let G=K.pantryDir||"src/pantry";try{let $=await BQ(Q,G);try{let q=await t(Q,K),Z=$?.domain||q.packageInfo.domain,X=$Q(Z),Y=q.packageInfo.aliases||[];if(X.length>0)if(qQ(Z))Y=X;else Y=[...new Set([...Y,...X])];let W=[],J=[],B="",C="",A=q.packageInfo.versions||[],F=q.packageInfo.programs||[],E=$?.programs||[];if(A.length===0||F.length===0&&E.length===0){let _=K.outputDir||"src/packages",O=Q.split("/"),T=O.length>1?w.join(_,...O.slice(0,-1),`${O[O.length-1]}.ts`):w.join(_,`${Q.replace(/\./g,"")}.ts`);if(H.existsSync(T))try{let j=H.readFileSync(T,"utf-8");if(A.length===0){let z=j.match(/versions:\s*\[([\s\S]*?)\]\s*as\s*const/);if(z&&z[1].trim())W=z[1].match(/'([^']+)'/g)?.map((L)=>L.replace(/'/g,""))||[]}if(F.length===0&&E.length===0){let z=j.match(/programs:\s*\[([\s\S]*?)\]\s*as\s*const/);if(z&&z[1].trim())J=z[1].match(/'([^']+)'/g)?.map((L)=>L.replace(/'/g,""))||[]}if(!q.packageInfo.description){let z=j.match(/description:\s*'([^']*)'\s*as\s*const/);if(z&&z[1])B=z[1]}if(!q.packageInfo.homepageUrl&&!$?.homepageUrl){let z=j.match(/homepageUrl:\s*'([^']*)'\s*as\s*const/);if(z&&z[1])C=z[1]}}catch{}}return{packageInfo:{...q.packageInfo,dependencies:$?.dependencies&&$.dependencies.length>0?$.dependencies:q.packageInfo.dependencies,buildDependencies:$?.buildDependencies&&$.buildDependencies.length>0?$.buildDependencies:q.packageInfo.buildDependencies,companions:$?.companions&&$.companions.length>0?$.companions:q.packageInfo.companions,programs:F.length>0?F:E.length>0?E:J.length>0?J:[],versions:A.length>0?A:W,domain:$?.domain||q.packageInfo.domain,description:q.packageInfo.description||B||"",name:q.packageInfo.name||$?.name||Q.split("/").pop()||Q,homepageUrl:$?.homepageUrl||q.packageInfo.homepageUrl||C,githubUrl:$?.githubUrl||q.packageInfo.githubUrl,aliases:Y},originalName:q.originalName,fullDomainName:q.fullDomainName}}catch(q){if(!$)return console.warn(`No pantry or web data available for ${Q}:`,q),null;console.warn(`Failed to fetch web metadata for ${Q}, using pantry data only:`,q);let Z=[],X=[],Y="",W="",J=K.outputDir||"src/packages",B=Q.split("/"),C=B.length>1?w.join(J,...B.slice(0,-1),`${B[B.length-1]}.ts`):w.join(J,`${Q.replace(/\./g,"")}.ts`);if(H.existsSync(C))try{let E=H.readFileSync(C,"utf-8"),x=E.match(/versions:\s*\[([\s\S]*?)\]\s*as\s*const/);if(x&&x[1].trim())Z=x[1].match(/'([^']+)'/g)?.map((j)=>j.replace(/'/g,""))||[];let _=E.match(/programs:\s*\[([\s\S]*?)\]\s*as\s*const/);if(_&&_[1].trim())X=_[1].match(/'([^']+)'/g)?.map((j)=>j.replace(/'/g,""))||[];let O=E.match(/description:\s*'([^']*)'\s*as\s*const/);if(O&&O[1])Y=O[1];let T=E.match(/homepageUrl:\s*'([^']*)'\s*as\s*const/);if(T&&T[1])W=T[1]}catch{}let A=$.programs&&$.programs.length>0?$.programs:X;return{packageInfo:{name:$.name||Q.split("/").pop()||Q,domain:$.domain||Q,description:Y||"",installCommand:`pantry install ${Q}`,pkgxInstallCommand:`sh <(curl https://pkgx.sh) +${Q} -- $SHELL -i`,pantryInstallCommand:`pantry install ${Q}`,programs:A,companions:$.companions||[],dependencies:$.dependencies||[],versions:Z,buildDependencies:$.buildDependencies||[],packageYmlUrl:`https://github.com/pkgxdev/pantry/tree/main/projects/${Q}/package.yml`,homepageUrl:W||$.homepageUrl||"",githubUrl:$.githubUrl||""},originalName:Q,fullDomainName:Q}}}catch($){return console.error(`Error processing pantry package ${Q}:`,$),null}}
42
- export{N as Fa,AQ as Ga,_Q as Ha,jQ as Ia,KQ as Ja,SQ as Ka,t as La,UQ as Ma,yQ as Na,vQ as Oa,EQ as Pa,OQ as Qa,BQ as Ra,VQ as Sa};
42
+ export{N as Ja,AQ as Ka,_Q as La,jQ as Ma,KQ as Na,SQ as Oa,t as Pa,UQ as Qa,yQ as Ra,vQ as Sa,EQ as Ta,OQ as Ua,BQ as Va,VQ as Wa};
@@ -1 +1 @@
1
- import{kb as a,lb as b,mb as c,nb as d,ob as e,pb as f,qb as g,rb as h,sb as i,tb as j,ub as k,vb as l,wb as m}from"./chunk-mtvbvxsd.js";import"./chunk-5kvy4he0.js";import"./chunk-jywhngj7.js";import"./chunk-sd8qadhd.js";export{l as validatePackageSpec,h as searchPackages,m as resolveVersionFromMetadata,e as resolveVersion,g as resolvePackageDomain,d as isVersionAvailable,j as getPopularPackages,c as getPhpVersionsForWorkflow,i as getPackagesByPattern,f as getPackageInfo,a as getLatestVersion,b as getAvailableVersions,k as getActivePackages};
1
+ import{Ab as m,ob as a,pb as b,qb as c,rb as d,sb as e,tb as f,ub as g,vb as h,wb as i,xb as j,yb as k,zb as l}from"./chunk-25sbj7mh.js";import"./chunk-dmcn6rf1.js";import"./chunk-cxg0wv4z.js";import"./chunk-z5kje5x9.js";export{l as validatePackageSpec,h as searchPackages,m as resolveVersionFromMetadata,e as resolveVersion,g as resolvePackageDomain,d as isVersionAvailable,j as getPopularPackages,c as getPhpVersionsForWorkflow,i as getPackagesByPattern,f as getPackageInfo,a as getLatestVersion,b as getAvailableVersions,k as getActivePackages};
@@ -0,0 +1 @@
1
+ import{Bb as b,Cb as c,Eb as d}from"./chunk-dmcn6rf1.js";import{Fb as a}from"./chunk-cxg0wv4z.js";import"./chunk-z5kje5x9.js";d();export{b as pantry,c as packages,a as aliases};
@@ -1,3 +1,3 @@
1
1
  import{execSync as $}from"node:child_process";import z from"node:fs";var O={Arc:"arc","Brave Browser":"brave-browser",Firefox:"firefox","Google Chrome":"google-chrome","Microsoft Edge":"microsoft-edge",Opera:"opera",Vivaldi:"vivaldi","Zen Browser":"zen-browser",Orion:"orion",Chromium:"chromium","Tor Browser":"tor-browser","Visual Studio Code":"visual-studio-code",Cursor:"cursor",Zed:"zed","Sublime Text":"sublime-text","Sublime Merge":"sublime-merge",Nova:"nova",BBEdit:"bbedit",CotEditor:"coteditor","IntelliJ IDEA":"intellij-idea","IntelliJ IDEA CE":"intellij-idea-ce",PhpStorm:"phpstorm",WebStorm:"webstorm",PyCharm:"pycharm","PyCharm CE":"pycharm-ce",RubyMine:"rubymine",CLion:"clion",GoLand:"goland",DataGrip:"datagrip",Rider:"rider","Android Studio":"android-studio",Fleet:"jetbrains-fleet",iTerm:"iterm2",Ghostty:"ghostty",Warp:"warp",Alacritty:"alacritty",Kitty:"kitty",Hyper:"hyper","GitHub Desktop":"github",GitKraken:"gitkraken",Tower:"tower",Fork:"fork",Tinkerwell:"tinkerwell",TablePlus:"tableplus","Sequel Pro":"sequel-pro","Sequel Ace":"sequel-ace",Postman:"postman",Insomnia:"insomnia",Proxyman:"proxyman",Docker:"docker",OrbStack:"orbstack",Dynobase:"dynobase",HTTPie:"httpie",Charles:"charles",Paw:"paw",Dash:"dash",SourceTree:"sourcetree",WhatsApp:"whatsapp",Slack:"slack",Discord:"discord",Telegram:"telegram","Microsoft Teams":"microsoft-teams",Zoom:"zoom",Signal:"signal",Skype:"skype",Lark:"lark",Claude:"claude",ChatGPT:"chatgpt",Obsidian:"obsidian",Notion:"notion",Bear:"bear",Craft:"craft",Logseq:"logseq",Typora:"typora",Joplin:"joplin",Things3:"things",Things:"things",Todoist:"todoist",TickTick:"ticktick",Fantastical:"fantastical",Spark:"readdle-spark","1Password":"1password","1Password 7":"1password",Raycast:"raycast",Alfred:"alfred",BetterTouchTool:"bettertouchtool",Bartender:"bartender",Setapp:"setapp","Grammarly Desktop":"grammarly-desktop",Spotify:"spotify",IINA:"iina",VLC:"vlc",HandBrake:"handbrake",Kap:"kap",OBS:"obs","DaVinci Resolve":"davinci-resolve",Plex:"plex",Audacity:"audacity","Elmedia Player":"elmedia-player",Figma:"figma",Sketch:"sketch","Affinity Designer":"affinity-designer","Affinity Designer 2":"affinity-designer","Affinity Photo":"affinity-photo","Affinity Photo 2":"affinity-photo","Affinity Publisher":"affinity-publisher","Affinity Publisher 2":"affinity-publisher",ImageOptim:"imageoptim","Pixelmator Pro":"pixelmator-pro",Canva:"canva",AppCleaner:"appcleaner",Pearcleaner:"pearcleaner",CleanMyMac:"cleanmymac","CleanMyMac X":"cleanmymac",Caffeine:"caffeine",KeepingYouAwake:"keepingyouawake",Muzzle:"muzzle",Rectangle:"rectangle",Magnet:"magnet",MonitorControl:"monitorcontrol","iStat Menus":"istat-menus","CleanShot X":"cleanshot",Shottr:"shottr","Karabiner-Elements":"karabiner-elements","Logi Options+":"logi-options-plus",logioptionsplus:"logi-options-plus","Logi Options Plus":"logi-options-plus",Transmit:"transmit",Cyberduck:"cyberduck","The Unarchiver":"the-unarchiver",Keka:"keka",ForkLift:"forklift","Mountain Duck":"mountain-duck","Parallels Desktop":"parallels","VMware Fusion":"vmware-fusion",UTM:"utm",Steam:"steam","Epic Games Launcher":"epic-games",Tailscale:"tailscale",WireGuard:"wireguard-go",NordVPN:"nordvpn","Mullvad VPN":"mullvad-vpn","MongoDB Compass":"mongodb-compass","Redis Insight":"redisinsight","Robo 3T":"robo-3t",Numi:"numi",Maccy:"maccy",Camo:"camo",Linear:"linear-linear",Loom:"loom",Dropbox:"dropbox","Google Drive":"google-drive",OneDrive:"onedrive",MediaInfo:"mediainfo"},C=new Set(["Safari","Numbers","Pages","Keynote","GarageBand","iMovie","Color Picker","Simulator","Simulator (Watch)","Preview","TextEdit","Automator","Font Book","Migration Assistant","Photo Booth","System Preferences","System Settings","Disk Utility","Terminal","Activity Monitor","Console","Grapher","Script Editor","Time Machine","Photos","Mail","Calendar","Contacts","Reminders","Notes","Maps","Messages","FaceTime","Books","News","Stocks","Weather","Home","Podcasts","Music","TV","Voice Memos","Freeform","Shortcuts","Chess","Dictionary","Stickies","Image Capture","Xcode"]),D=new Set(["Xcode","Numbers","Pages","Keynote","GarageBand","iMovie","Things3","Grammarly for Safari","AdBlock","HP Smart","Audible","CleanMyMac_5_MAS","Mini Motorways","Snake.io+","Numbers Creator Studio"]);function E(F,G){if(!F||!G||F===G)return!1;if(G==="?")return!!F;let Q=(L)=>L.replace(/[,+].*/g,"").replace(/-.*$/,"").split(".").map((R)=>Number.parseInt(R,10)||0),J=Q(F),X=Q(G);for(let L=0;L<Math.max(J.length,X.length);L++){let R=J[L]||0,j=X[L]||0;if(R>j)return!0;if(R<j)return!1}return!1}function I(F){if(/[+()_]/.test(F))return null;if(F.length<2)return null;return F.toLowerCase().replace(/[^a-z0-9\s-]/g,"").replace(/\s+/g,"-").trim()||null}function w(F){if(O[F])return O[F];return I(F)}function V(F="/Applications"){let G=[];if(!z.existsSync(F))return G;let Q=z.readdirSync(F).filter((J)=>J.endsWith(".app"));for(let J of Q){let X=J.replace(/\.app$/,""),L=`${F}/${J}`,R="?",j;try{let H=`${L}/Contents/Info.plist`;if(z.existsSync(H)){let W=$(`/usr/libexec/PlistBuddy -c "Print :CFBundleShortVersionString" "${H}" 2>/dev/null`,{timeout:5000,encoding:"utf-8"}).trim();if(W)R=W;try{j=$(`/usr/libexec/PlistBuddy -c "Print :CFBundleIdentifier" "${H}" 2>/dev/null`,{timeout:5000,encoding:"utf-8"}).trim()||void 0}catch{}}}catch{}G.push({name:X,version:R,path:L,bundleId:j})}return G}function _(F){let G=new Map;if(F.length===0)return G;let Q=20;for(let J=0;J<F.length;J+=Q){let X=F.slice(J,J+Q);try{let L=$(`brew info --cask --json=v2 ${X.join(" ")} 2>/dev/null`,{timeout:60000,encoding:"utf-8",maxBuffer:10485760});if(!L)continue;let R=JSON.parse(L);for(let j of R.casks||[]){let H=[];for(let W of j.artifacts||[])if(W.app){for(let Z of W.app)if(typeof Z==="string")H.push(Z.replace(/\.app$/,""))}G.set(j.token,{token:j.token,version:(j.version||"").split(",")[0],autoUpdates:j.auto_updates||!1,appNames:H})}}catch{for(let L of X)try{let R=$(`brew info --cask --json=v2 ${L} 2>/dev/null`,{timeout:15000,encoding:"utf-8"});if(!R)continue;let H=JSON.parse(R).casks?.[0];if(H){let W=[];for(let Z of H.artifacts||[])if(Z.app){for(let q of Z.app)if(typeof q==="string")W.push(q.replace(/\.app$/,""))}G.set(H.token,{token:H.token,version:(H.version||"").split(",")[0],autoUpdates:H.auto_updates||!1,appNames:W})}}catch{}}}return G}function M(F){let G=F||V(),Q=[],J=new Map,X=new Map;for(let j of G){if(C.has(j.name))continue;let H=w(j.name);if(H){X.set(j.name,H);let W=J.get(H)||[];W.push(j),J.set(H,W)}}let L=Array.from(J.keys()),R=_(L);for(let j of G){let H=C.has(j.name),W=D.has(j.name),Z=X.get(j.name)||null,q=Z?R.get(Z):null,B="unknown",K=null,Y=!1,U=!1;if(H)B="system";else if(W)B="mas";else if(q)if(K=q.version,U=q.autoUpdates,U)B="self-updating",Y=E(K,j.version);else B="brew-cask",Y=E(K,j.version);Q.push({name:j.name,currentVersion:j.version,latestVersion:K,updateAvailable:Y,source:B,caskToken:Z,autoUpdates:U})}return Q.sort((j,H)=>{if(j.updateAvailable&&!H.updateAvailable)return-1;if(!j.updateAvailable&&H.updateAvailable)return 1;return j.name.localeCompare(H.name)}),Q}async function h(F){try{try{$(`brew upgrade --cask ${F} 2>&1`,{timeout:120000,encoding:"utf-8"});let G=$(`brew info --cask --json=v2 ${F} 2>/dev/null`,{timeout:15000,encoding:"utf-8"});return{success:!0,version:JSON.parse(G).casks?.[0]?.version?.split(",")?.[0]||"latest"}}catch(G){let Q=G.stderr?.toString()||G.message||"";if(Q.includes("not installed")||Q.includes("No available")){$(`brew install --cask ${F} 2>&1`,{timeout:120000,encoding:"utf-8"});let J=$(`brew info --cask --json=v2 ${F} 2>/dev/null`,{timeout:15000,encoding:"utf-8"});return{success:!0,version:JSON.parse(J).casks?.[0]?.version?.split(",")?.[0]||"latest"}}throw G}}catch(G){return{success:!1,error:(G.stderr?.toString()||G.stdout?.toString()||G.message||"Update failed").trim().split(`
2
2
  `).pop()||"Update failed"}}}
3
- export{O as va,C as wa,D as xa,E as ya,I as za,w as Aa,V as Ba,_ as Ca,M as Da,h as Ea};
3
+ export{O as za,C as Aa,D as Ba,E as Ca,I as Da,w as Ea,V as Fa,_ as Ga,M as Ha,h as Ia};
@@ -0,0 +1,275 @@
1
+ import{cb as k,eb as Zw}from"./chunk-cret7mf0.js";import{ob as dw,pb as gw,sb as mw,tb as Kw,vb as lw,xb as cw,yb as pw,zb as Uw}from"./chunk-25sbj7mh.js";import{Eb as Q6}from"./chunk-dmcn6rf1.js";import{Fb as t,Gb as zQ}from"./chunk-cxg0wv4z.js";import{Jb as tw}from"./chunk-9yep1cys.js";import{Nb as c}from"./chunk-z5kje5x9.js";import KQ from"node:process";zQ();import hw from"node:process";function vw(w){return w in t}function JQ(w){return w.includes(".")}function X6(w){return vw(w)||JQ(w)}function Z6(w){return["darwin","linux","windows"].includes(w)}function q6(w){return["x86_64","aarch64","armv7l","i686"].includes(w)}function fw(){return Object.keys(t)}function H6(){return Object.values(t)}function Y6(w){if(vw(w))return{originalName:w,resolvedDomain:t[w],isAlias:!0};return{originalName:w,resolvedDomain:w,isAlias:!1}}function W6(w){let Q=w.lastIndexOf("@");if(Q===-1)return{name:w};let $=w.slice(0,Q),R=w.slice(Q+1);return{name:$,version:R,versionSpec:R}}function z6(w,Q){return Q?`${w}@${Q}`:w}function e(){let w=hw.platform,Q=hw.arch,$,R,X=!0;switch(w){case"darwin":$="darwin";break;case"linux":$="linux";break;case"win32":$="windows";break;default:$="linux",X=!1}switch(Q){case"x64":R="x86_64";break;case"arm64":R="aarch64";break;case"arm":R="armv7l";break;case"ia32":R="i686";break;default:R="x86_64",X=!1}return{platform:$,architecture:R,isSupported:X}}function J6(w,Q="latest",$){let R=$||e(),X;switch(R.platform){case"darwin":X="tar.xz";break;case"linux":X="tar.xz";break;case"windows":X="zip";break;default:X="tar.xz"}return{packageName:w,version:Q,platform:R.platform,architecture:R.architecture,format:X}}var K6={LATEST:"latest",ANY:"*"},kw={RUNTIME:["nodejs.org","python.org","go.dev","rust-lang.org"],BUILD_TOOLS:["cmake.org","ninja-build.org","gradle.org","maven.apache.org"],DATABASES:["postgresql.org","mysql.com","redis.io","mongodb.com"],EDITORS:["neovim.io","vim.org","code.visualstudio.com"],CLI_TOOLS:["cli.github.com","curl.se","wget.gnu.org","jq.dev"]};function U6(w){return kw[w]}function G6(w,Q){return kw[Q].includes(w)}function B6(w){return w}function _6(w,Q){return[w,Q]}function O6(w){return w}async function M6(w){try{let Q=await Kw(w);if(!Q)return{success:!1,error:`Package '${w}' not found. Use 'search' to find available packages.`};return{success:!0,data:Q}}catch(Q){return{success:!1,error:`Failed to get package info: ${Q}`}}}async function C6(w){try{if(!w||w.trim().length===0)return{success:!1,error:"Search term cannot be empty"};return{success:!0,data:await lw(w.trim())}}catch(Q){return{success:!1,error:`Search failed: ${Q}`}}}async function I6(w=20){try{return{success:!0,data:(await cw(5)).slice(0,w)}}catch(Q){return{success:!1,error:`Failed to list popular packages: ${Q}`}}}async function S6(w=20){try{return{success:!0,data:await pw(w)}}catch(Q){return{success:!1,error:`Failed to list active packages: ${Q}`}}}function b6(){try{return{success:!0,data:fw()}}catch(w){return{success:!1,error:`Failed to list aliases: ${w}`}}}async function F6(w){try{let Q=await Uw(w);if(!Q.isValid)return{success:!1,error:Q.error};return{success:!0,data:{packageName:Q.packageName,version:Q.version,isValid:!0}}}catch(Q){return{success:!1,error:`Validation failed: ${Q}`}}}async function A6(w){try{let Q=await Uw(w);if(!Q.isValid)return{success:!1,error:Q.error};let $=Q.packageName,R=Q.version||"latest",X=await mw($,R);if(!X)return{success:!1,error:`Could not resolve version '${R}' for package '${$}'`};let H=await Kw($);if(!H)return{success:!1,error:`Package '${$}' not found`};let q=e(),Z={packageName:$,resolvedVersion:X,platform:q.platform,architecture:q.architecture,dependencies:H.dependencies,companions:H.companions,installCommand:`pkgx install ${$}@${X}`},Y=[];if(!q.isSupported)Y.push(`Platform ${q.platform}/${q.architecture} may not be fully supported`);if(H.dependencies.length>0)Y.push(`This package has ${H.dependencies.length} dependencies that will also be installed`);return{success:!0,data:Z,warnings:Y.length>0?Y:void 0}}catch(Q){return{success:!1,error:`Failed to create install plan: ${Q}`}}}async function x6(w){try{let Q=await dw(w);if(!Q)return{success:!1,error:`Package '${w}' not found`};let $=await gw(w);return{success:!0,data:{latest:Q,total:$.length,versions:$}}}catch(Q){return{success:!1,error:`Failed to get version info: ${Q}`}}}function V6(w){let Q=[`Package: ${w.name}`,`Domain: ${w.domain}`,`Description: ${w.description}`,`Latest Version: ${w.latestVersion}`,`Total Versions: ${w.totalVersions}`];if(w.programs.length>0)Q.push(`Programs: ${w.programs.join(", ")}`);if(w.dependencies.length>0)Q.push(`Dependencies: ${w.dependencies.join(", ")}`);if(w.companions.length>0)Q.push(`Companions: ${w.companions.join(", ")}`);return Q.join(`
2
+ `)}function y6(w){if(w.length===0)return"No packages found matching your search.";let Q=[`Found ${w.length} package(s):
3
+ `];for(let $ of w)Q.push(`${$.name} (${$.domain})`),Q.push(` ${$.description}`),Q.push(` Latest: ${$.latestVersion} (${$.totalVersions} versions available)`),Q.push("");return Q.join(`
4
+ `)}function N6(w){let Q=[`Installation Plan for ${w.packageName}@${w.resolvedVersion}`,`Platform: ${w.platform}/${w.architecture}`,`Command: ${w.installCommand}`];if(w.dependencies.length>0)Q.push(`Dependencies: ${w.dependencies.join(", ")}`);if(w.companions.length>0)Q.push(`Companions: ${w.companions.join(", ")}`);return Q.join(`
5
+ `)}function u6(){try{let w=e();return{success:!0,data:{platform:w.platform,architecture:w.architecture,isSupported:w.isSupported,nodeVersion:KQ.version}}}catch(w){return{success:!1,error:`Failed to get system info: ${w}`}}}import m from"node:fs";import Qw from"node:path";function $w(w){if(!m.existsSync(w))throw Error(`Dependency file not found: ${w}`);let Q=m.readFileSync(w,"utf-8"),$=[],R=Q.split(`
6
+ `),X=!1,H=!1,q=0;for(let Z of R){let Y=Z.trim();if(!Y||Y.startsWith("#"))continue;if(Z.match(/^(dependencies|deps):\s*$/)){X=!0,H=!1,q=Z.search(/\S/);continue}if(Z.match(/^global:\s*true\s*$/)||Z.match(/^global:\s*$/)&&!X){H=!0;continue}if(Z.match(/^\w+:/)&&!Z.includes(" ")&&X&&q===0){X=!1;continue}if(X||H){if(Z.match(/^\s+(dependencies|deps):\s*$/))continue;let J=Z.indexOf(":");if(J>0){let z=Z.substring(0,J).trim(),j=Z.substring(J+1).trim();if(z&&j){let T=z,O=j.replace(/^['"]|['"]$/g,"");if(T==="global"||T==="dependencies"||T==="deps")continue;let W=O,U=O;if(O.startsWith("^"))W=O.substring(1),U=O;else if(O.startsWith("~"))W=O.substring(1),U=O;else if(O.startsWith(">=")||O.startsWith("<=")||O.startsWith(">")||O.startsWith("<")){let B=/^([><=]+)/.exec(O);if(B){let K=B[1];W=O.substring(K.length).trim(),U=O}}else if(O==="*"||O==="latest")W="latest",U="*";else W=O,U=`@${O}`;$.push({name:T,version:W,constraint:U,isOsSpecific:!1})}}}}return $}function UQ(w){if(!m.existsSync(w))throw Error(`Dependency file not found: ${w}`);let Q=m.readFileSync(w,"utf-8"),$=$w(w),R;try{let X=typeof Bun<"u"&&Bun.YAML?Bun.YAML.parse(Q):GQ(Q);if(X?.services){let H=Array.isArray(X.services.autoStart)?X.services.autoStart.map((q)=>String(q)):[];if(H.length>0)R={enabled:X.services.enabled===!0,autoStart:H}}}catch{}return{dependencies:$,services:R}}function GQ(w){let Q={},$=w.split(`
7
+ `),R=!1,X=!1,H=[],q=!1;for(let Z of $){let Y=Z.trim();if(!Y||Y.startsWith("#"))continue;if(Z.match(/^services:\s*$/)){R=!0,X=!1;continue}if(R&&!Z.startsWith(" ")&&!Z.startsWith("\t")&&!Y.startsWith("-")){if(Y!=="services:"){R=!1,X=!1;continue}}if(R){if(Y.startsWith("enabled:")){q=Y.includes("true");continue}if(Y.match(/^autoStart:\s*$/)){X=!0;continue}if(X&&Y.startsWith("- ")){let J=Y.slice(2).trim();if(J)H.push(J)}}}if(H.length>0)Q.services={enabled:q,autoStart:H};return Q}async function v6(w,Q="src/packages"){try{let $;if(w.includes("/"))$=Qw.join(Q,`${w}.ts`);else{let z=`${w.replace(/\./g,"")}.ts`;$=Qw.join(Q,z)}if(!m.existsSync($))return[];let R=m.readFileSync($,"utf-8"),X=R.indexOf("versions:");if(X===-1)return[];let H=R.substring(X),q=H.indexOf("["),Z=H.indexOf("] as const");if(q===-1||Z===-1)return[];let J=H.substring(q+1,Z).match(/'([^']+)'/g);if(!J)return[];return J.map((z)=>z.replace(/'/g,""))}catch{return[]}}async function BQ(w){try{let{packages:Q}=await import("./chunk-h75t6wv0.js").catch(()=>import("./src/index.js")),$=w.replace(/[^a-z0-9]/gi,"").toLowerCase(),R=Q[$];if(!R)R=Object.values(Q).find((H)=>H.domain===w);if(!R)R=Object.values(Q).find((H)=>Array.isArray(H.aliases)&&H.aliases.includes(w));if(R&&R.versions&&Array.isArray(R.versions))return R.versions;return[]}catch{return[]}}async function ow(w,Q){let $=await BQ(w);if($.length===0)return Q.split("#")[0].trim().replace(/^[@^~>=<]+/,"")||"latest";let R=Q.split("#")[0].trim();if(R==="*"||R==="latest")return $[0];if(R.startsWith("@")){let H=R.slice(1);return $.includes(H)?H:$[0]}return _Q($,R)||$[0]}function _Q(w,Q){if(Q.startsWith("^")){let $=Q.slice(1),[R]=l($);return w.filter((H)=>{let[q]=l(H);return q===R&&g(H,$)>=0})[0]||null}if(Q.startsWith("~")){let $=Q.slice(1),[R,X]=l($);return w.filter((q)=>{let[Z,Y]=l(q);return Z===R&&Y===X&&g(q,$)>=0})[0]||null}if(Q.startsWith(">=")){let $=Q.slice(2).trim();return w.filter((X)=>g(X,$)>=0)[0]||null}if(Q.startsWith(">")){let $=Q.slice(1).trim();return w.filter((X)=>g(X,$)>0)[0]||null}if(Q.startsWith("<=")){let $=Q.slice(2).trim();return w.filter((X)=>g(X,$)<=0)[0]||null}if(Q.startsWith("<")){let $=Q.slice(1).trim();return w.filter((X)=>g(X,$)<0)[0]||null}if(Q.startsWith("=")){let $=Q.slice(1).trim();return w.includes($)?$:null}return w.includes(Q)?Q:null}function l(w){let Q=w.split(".").map(($)=>{let R=$.match(/^\d+/);return R?Number.parseInt(R[0],10):0});return[Q[0]||0,Q[1]||0,Q[2]||0]}function g(w,Q){if(w==="latest"&&Q!=="latest")return 1;if(Q==="latest"&&w!=="latest")return-1;if(w==="latest"&&Q==="latest")return 0;let $=w.split("#")[0].trim(),R=Q.split("#")[0].trim(),[X,H,q]=l($),[Z,Y,J]=l(R);if(X>Z)return 1;if(X<Z)return-1;if(H>Y)return 1;if(H<Y)return-1;if(q>J)return 1;if(q<J)return-1;return 0}var ww=null;async function OQ(){if(ww)return ww;return ww=(await import("./chunk-h75t6wv0.js").catch(()=>import("./src/index.js"))).packages,ww}async function jQ(w){try{let Q=await OQ(),$=Q[w];if($)return{dependencies:$.dependencies||[],companions:$.companions||[]};let R=w.replace(/[^a-z0-9]/gi,"").toLowerCase(),X=Q[R];if(X)return{dependencies:X.dependencies||[],companions:X.companions||[]};let q=Object.values(Q).find((Z)=>Z.domain===w);if(q)return{dependencies:q.dependencies||[],companions:q.companions||[]};return null}catch(Q){return console.warn(`Failed to load package data for ${w}: ${Q}`),null}}async function Rw(w,Q={},$=new Set,R=0){let{maxDepth:X=10,verbose:H=!1,targetOs:q,includeOsSpecific:Z=!0}=Q;if(R>X||$.has(w))return[];if($.add(w),H)console.log(`${" ".repeat(R)}Resolving dependencies for: ${w}`);let Y=[];try{let z=function(W){let U=W.match(/^(linux|darwin|windows):(.+)$/),B=!!U,K=U?U[2]:W,S=U?U[1]:void 0;if(B&&(!Z||q&&S!==q))return null;let _=K,M="latest",G="*",E=K.match(/^([^@^~>=<]+)([@^~>=<].+)?$/);if(E){if(_=E[1],E[2]){let I=E[2];if(I.startsWith("@"))M=I.substring(1),G=I;else G=I,M=I.replace(/^\D*/,"")}}return{dep:{name:_,version:M,constraint:G,isOsSpecific:B,os:S},pkgName:_}},J=await jQ(w),T=[...J?.dependencies||[],...J?.companions||[]].map(z).filter((W)=>W!==null);for(let{dep:W}of T)Y.push(W);let O=await Promise.all(T.map(({pkgName:W})=>Rw(W,Q,$,R+1)));for(let W of O)Y.push(...W)}catch(J){if(H)console.warn(`${" ".repeat(R)}Warning: Could not resolve dependencies for ${w}: ${J}`)}return Y}async function Gw(w,Q={}){let $=new Map,R=[],X={linux:[],darwin:[],windows:[]};for(let Z of w){if(!$.has(Z.name))$.set(Z.name,[]);if($.get(Z.name).push(Z),Z.isOsSpecific&&Z.os)X[Z.os].push(Z)}let H=[],q=[];for(let[Z,Y]of $)if(Y.length===1){let J=await ow(Z,Y[0].constraint),z={...Y[0],version:J};H.push(z),q.push(Z)}else{let J=Y.map((W)=>W.version),z=[...new Set(J)];if(z.length>1)R.push({package:Z,versions:z});let j=await Promise.all(Y.map(async(W)=>({...W,resolvedVersion:await ow(Z,W.constraint)}))),T=j[0];for(let W of j.slice(1))if(T.constraint==="*"&&W.constraint!=="*")T=W;else if(T.constraint!=="*"&&W.constraint==="*");else if(g(W.resolvedVersion,T.resolvedVersion)>0)T=W;let O={...T,version:T.resolvedVersion};delete O.resolvedVersion,H.push(O),q.push(Z)}return{allDependencies:H,uniquePackages:q,conflicts:R,osSpecificDeps:X}}async function sw(w,Q={}){let{verbose:$=!1}=Q;if($)console.log(`Parsing dependency file: ${w}`);let R=$w(w);if($)console.log(`Found ${R.length} direct dependencies`);let X=[...R],H=await Promise.all(R.map(async(Y)=>{if($)console.log(`Resolving transitive dependencies for: ${Y.name}`);return Rw(Y.name,Q)}));for(let Y of H)X.push(...Y);if($)console.log(`Total dependencies found (before deduplication): ${X.length}`);let q=await Gw(X,Q);if($){if(console.log(`Unique packages after deduplication: ${q.uniquePackages.length}`),q.conflicts.length>0)console.log(`Version conflicts found: ${q.conflicts.length}`)}let Z=Qw.extname(w);if(Z===".yaml"||Z===".yml"){let Y=UQ(w);if(Y.services)q.services=Y.services}return q}function f6(w){let Q=["deps.yaml","deps.yml","dependencies.yaml","dependencies.yml","pkgx.yaml","pkgx.yml",".deps.yaml",".deps.yml"],$=[];for(let R of Q){let X=Qw.join(w,R);if(m.existsSync(X))$.push(X)}return $}import F from"node:fs";import L from"node:path";import y from"node:process";var Bw=L.join(y.cwd(),"src","packages"),_w=L.join(y.cwd(),"docs");var o={};async function Ew(w){try{let Q=w||L.join(y.cwd(),"src","packages"),$=L.join(Q,"index.ts");if(F.existsSync($)){console.log("Using generated index file for package mapping...");let H=await import(L.resolve($)),q=H.pantry||H.packages;if(q)return console.log(`Successfully loaded ${Object.keys(q).length} packages from index`),q}console.log("Index file not found, falling back to direct file reading...");let R={};if(!F.existsSync(Q))return console.log(`Packages directory does not exist: ${Q}`),R;let X=[];try{let H=function(q,Z=""){let Y=[],J=F.readdirSync(q,{withFileTypes:!0});for(let z of J)if(z.isFile()&&z.name.endsWith(".ts")&&z.name!=="index.ts"&&z.name!=="aliases.ts")Y.push(L.join(q,z.name));else if(z.isDirectory()&&!z.name.startsWith(".")){let j=L.join(q,z.name),T=Z?`${Z}/${z.name}`:z.name;Y.push(...H(j,T))}return Y};X=H(Q),console.log(`Found ${X.length} package files`)}catch(H){console.error(`Error reading packages directory ${Q}:`,H),X=[]}console.log(`Reading package data from ${X.length} files...`);for(let H of X)try{let q=L.isAbsolute(H)?H:L.join(Q,H),Z=F.readFileSync(q,"utf-8"),Y=L.basename(H,".ts"),J=Z.match(/domain:\s*['"]([^'"]*)['"]\s*as const/),z=J?J[1]:Zw(Y),j=k(z),T=TQ(Z,z);if(T)R[j]=T,console.log(`Loaded package data for ${z} -> ${j}`)}catch(q){console.error(`Error processing file ${H}:`,q)}return console.log(`Successfully loaded ${Object.keys(R).length} packages`),R}catch(Q){return console.error("Error importing pantry:",Q),{}}}function TQ(w,Q){try{let $=w.match(/domain:\s*['"]([^'"]*)['"]\s*as const/),R=$?$[1]:Q;if(!w.match(/export const \w+Package = \{([\s\S]*?)\}/))return console.warn(`Could not find package object in file for ${R}`),null;let H=(G)=>{let E=new RegExp(`${G}:\\s*\\[(.*?)\\]\\s*as const`,"s"),I=w.match(E);if(!I)return[];let C=I[1],b=C.match(/'([^']*)'/g);if(b)return b.map((x)=>x.replace(/'/g,""));if(b=C.match(/"([^"]*)"/g),b)return b.map((x)=>x.replace(/"/g,""));return[]},q=(G)=>{let I=new RegExp(`${G}:\\s*'([^']*)'\\s*as const`),C=w.match(I);if(C)return C[1].replace(/\\'/g,"'").replace(/\\\\/g,"\\");if(I=new RegExp(`${G}:\\s*'([^']*)'`),C=w.match(I),C)return C[1].replace(/\\'/g,"'").replace(/\\\\/g,"\\");return""},Z=q("name")||R,Y=q("description")||`A package from ${R}`,J=q("packageYmlUrl")||"",z=q("homepageUrl")||"",j=q("githubUrl")||"",T=q("installCommand")||"",O=q("pkgxInstallCommand")||`sh <(curl https://pkgx.sh) +${R} -- $SHELL -i`,W=q("pantryInstallCommand")||`pantry install ${R}`,U=q("fullPath")||R,B=H("programs"),K=H("companions"),S=H("dependencies"),_=H("versions"),M=H("aliases");return{name:Z,domain:R,description:Y,packageYmlUrl:J,homepageUrl:z,githubUrl:j,installCommand:T,pkgxInstallCommand:O,pantryInstallCommand:W,programs:B,companions:K,dependencies:S,versions:_,fullPath:U,aliases:M}}catch($){return console.error(`Error extracting package data for ${Q}:`,$),null}}function LQ(w,Q){let $=["cli","app","tool","server","client","api","lib","core","sdk","dev","bin"];if($.includes(w.toLowerCase()))return!1;if(w===Q)return!1;let R=Q.replace(/\./g,"");if(w===R)return!1;if(w.includes("--")||w.includes("$SHELL")||w.includes("curl")||w.includes("sh <("))return!1;if(w.includes(" -- ")||w.includes(" -i")||w.includes("+")&&w.includes(" "))return!1;if(Q.includes("/")){let H=Q.split("/"),q=H[H.length-1];if($.includes(q.toLowerCase())&&w===q)return!1}let X=["go","js","py","rb","sh","vi","cc","gc","jq","awk","sed","mc","gh"];if(w.length<3&&!X.includes(w.toLowerCase()))return!1;if(/^[\d.]+$/.test(w)&&/^\d/.test(w))return!1;if(!/[a-z]/i.test(w))return!1;if(w.includes("{{")||w.includes("}}"))return!1;if(w.includes("version.major")||w.includes("version.minor")||w.includes("version"))return!1;return!0}function rw(){return{"Programming Languages":["node","python","go","rust","ruby","julia","lua","luajit","php","crystal","nim","kotlin","scala","swift","zig","v","dart","ghc","ocaml","clojure","erl","elixir","R","perl","tcl","dmd","tinygo"],"Artificial Intelligence":["ollama","huggingface","openai","f2py","kaggle","jupyter","llm","stable-diffusion-webui","open-interpreter","interpreter","GPT Engineer","gPTEngineer","auto-gpt","autogpt","metagpt","MetaGPT","elizaOS","eliza","openplayground","chatblade","aichat"],Databases:["psql","mysql","mongod","mongos","mongosh","redis","sqlite3","duckdb","surreal","etcd","turso","mariadb","influx","clickhouse","neo4j","cassandra","couchdb","elasticsearch","opensearch","memcached","valkey","postgrest","litecli","edgedb","dgraph"],"Web Development":["vite","next","astro","vitepress","laravel","symfony","django","flask","fastapi","rails","spring","express","tailwindcss","svelte","ng","react","vue","nx","nuxt"],DevOps:["docker","compose","podman","kubectl","minikube","kustomize","helm","terraform","terragrunt","jenkins-lts","vault","consul","nomad","packer","ansible","ansible-lint","argocd","flux","lima","k3d","kind","tofu","atlantis","terratag","tflint","tfupdate","cfn-lint","infracost"],"Container & Kubernetes Tools":["docker","podman","kubectl","minikube","kustomize","helm","helmfile","stern","hubble","cilium","kube-linter","kubeshark","kubectl-cnpg","k9s","kubectx","kubecm","kubectl-krew","skaffold","tilt","linkerd","vcluster","istioctl","velero","kubeconform","kubebuilder","operator-sdk"],"Monitoring & Observability":["prometheus","grafana","datadog","newrelic","kibana","jaeger","zipkin","sentry","steampipe","logdy","loki","tempo","allure"],"Build Tools & Automation":["cmake","ninja","meson","scons","make","bazel","gradle","mvn","ant","task","just","autoconf","automake","pkg-config","vcpkg","buildctl","buildkit","earthly","buildifier","pants","scie-pants"],"Package Managers":["npm","npx","yarn","pnpm","bun","pip","pipenv","poetry","conda","bundler","cargo","composer","pod","nuget","brew","port","pkgx","mise","asdf","nixpacks","corepack","luarocks","rye","pdm"],"Editors & IDEs":["nvim","vim","emacs","code","vscode cli","micro","nano","alacritty","wezterm","helix"],"CLI Tools & Utilities":["ripgrep","rg","tree-sitter","fzf","bat","lsd","exa","eza","fd","fd-find","sed","awk","grep","find","jq","yq","tree","watch","htop","btop","bottom","tmux","screen","starship","oh-my-posh","fish","zsh","bash","curl","wget","ripgrep-all","rga","hyperfine","dust","du-dust","duf","ncdu","tokei","loc","delta","git-delta","difftastic","diff-so-fancy","gdu","procs","bandwhich","grex","choose","sd","dog","drill","xh","httpie","curlie"],Networking:["nginx","httpd","caddy","traefik","curl","wget","httpie","cloudflared","openssh","rsync","mosh"],"Security & Cryptography":["OpenSSL","gpg","gpg-tui","vault","bw","op","1Password CLI","1password_cli","mkcert","certbot","age","yubikey-agent","snyk","trivy","tfsec","checkov","git-crypt"],Multimedia:["ffmpeg","vips","mpv","yt-dlp","streamlink","gifsicle","exiftool","optipng","imagemagick"],"Graphics Libraries":["libsdlorg","libsdlorgsdl_image","openglorg","vulkanlunarcom","mesa3dorg","freeglutfileio","glewsourceforge","glmgtrucnet","cairographicsorg","opencvorg","vtkorg","ogre3dorg","irrlichtorg"],"Gaming & Game Development":["unitycom","unrealenginecom","godotengineorg","libsdlorg","love2dorg","rayliborg","allegro5org","defoldcom","constructnet","gamemakerio","cocos2dxorg","lutrisnet","steampipecom","epicgamescom"],"Cloud Platforms":["awsamazoncom","cloudgooglecom","azuremicrosoftcom","digitaloceancom","linodecom","vultrcom","hetznercom","cloudflarecom","netlifycom","vercelcom","herokucom","railwayapp","rendercom","flyio","planetscalecom","supabasecomcli","firebasecom","localstackcloudcli"],"Mobile Development":["reactnativedev","flutterdev","xamarincom","ionicio","cordovaapacheorg","capacitorjscom","nativescriptorg","expodev","fastlanetools","appiumio","androidcomcmdlinetools","gradleorg"],Testing:["jestjsio","mochajsorg","cypressio","seleniumdev","playwrightdev","puppeteerdev","testcafeio","pytestorg","unittestpythonorg","rspecinfo","junitorg","testngorg","webdriverio","vitestdev","avajs","jasminegjscom","karmatestrunnerorg"],Cryptocurrency:["bitcoinorg","ethereumorg","solanacom","getfoundrysh","racoonorg","elementsprojectorg","githubcom10gicvanitygenplusplus","ghostscriptcom","polkadotnetwork","avalanchenetwork","chainlinkcom","cardanoorg"],"Financial Tools":["raccoinorg","gnucashorg","ledgercliorg","beancountgooglecodecom","plaintextaccountingorg","quickencom","mintcom","ynabcom"],"Documentation & Text Processing":["pandocorg","texliveorg","latexprojectorg","asciidocorg","asciidoctororg","sphinxdocorg","mkdocsorg","gitbookcom","githubiohugohugorg","jekyllrb","docsifyjs","rustlangorgmdbook","typstapp","tectonic_typesettinggithubio","maaslalanicomslides"],"System Administration":["systemdio","crongnuorg","rsyncsambaorg","opensshcom","sudows","tmuxgithubcom","gnuorgscreen","htopdev","iostat","psmisc","procpsng","straceio","ltraceorg","lsofio","tcpdumporg","logrotateorg","monitoringpluginsorg"],"Scientific Computing":["numpyorg","scipyorg","pandasdataorg","matplotliborg","seabornpydataorg","plotlycom","jupyterorg","anacondacom","rorg","rstudiocom","octaveorg","matlabcom","mathematicawolframcom","sagemath","maxima","gnuplotorg","paravieworg","vtk"],"Embedded & IoT":["arduino","platformio","espressifcom","raspberrypiorg","mbed","freedosorg","qemuorg","openocdorg","stlink","jlinkorg","modbus","zigbeeorg","gpiozeropythonorg"],"Version Control":["git","gh","gitlab"],"Other Utilities":[]}}function iw(w){if(o[w])return o[w];return w.replace(/\W/g,"_")}function aw(w){return w.toLowerCase()}function Xw(w,Q,$){try{let R=Q||Bw,X=$||L.join(R,`${w}.ts`),H=F.readFileSync(X,"utf-8"),q=H.match(/export const (\w+) = \{/),Z=q?q[1]:`${w.replace(/\W/g,"")}Package`,Y=H.match(/export type (\w+) = typeof/),J=Y?Y[1]:`${Z.charAt(0).toUpperCase()}${Z.slice(1)}`;return{packageVarName:Z,typeName:J}}catch(R){console.warn(`Could not read package file ${$||`${w}.ts`}, using fallback naming:`,R);let X=MQ(w),H=EQ(w);return{packageVarName:X,typeName:H}}}function EQ(w){if(o[w]){let R=o[w];return`${R.charAt(0).toUpperCase()}${R.slice(1)}Package`}let $=aw(w).replace(/\W/g,"");return`${$.charAt(0).toUpperCase()}${$.slice(1)}Package`}function MQ(w){if(o[w])return`${o[w]}Package`;return`${aw(w).replace(/\W/g,"")}Package`}function CQ(w,Q){let{typeName:$}=Xw(w,Q);return $}function IQ(w,Q){let{packageVarName:$}=Xw(w,Q);return $}async function Ow(w){try{console.log("\uD83D\uDD27 Generating package index..."),console.log(`DEBUG generateIndex START: packagesDir=${w}`),console.log(`DEBUG generateIndex START: process.cwd()=${y.cwd()}`);let Q=w||Bw,$=L.resolve(Q,"index.ts");if(console.log(`DEBUG generateIndex: packagesDir=${w}`),console.log(`DEBUG generateIndex: PACKAGES_DIR=${Bw}`),console.log(`DEBUG generateIndex: targetPackagesDir=${Q}`),console.log(`DEBUG generateIndex: targetIndexFile=${$}`),console.log(`DEBUG generateIndex: path.isAbsolute(targetIndexFile)=${L.isAbsolute($)}`),!F.existsSync(Q))console.log(`Creating packages directory: ${Q}`),F.mkdirSync(Q,{recursive:!0});if(!F.existsSync(Q))return console.error(`Failed to create packages directory: ${Q}`),null;let R=[];try{let H=function(q,Z=""){let Y=[],J=F.readdirSync(q,{withFileTypes:!0});for(let z of J)if(z.isFile()&&z.name.endsWith(".ts")&&z.name!=="index.ts"&&z.name!=="aliases.ts")Y.push(L.join(q,z.name));else if(z.isDirectory()&&!z.name.startsWith(".")){let j=L.join(q,z.name),T=Z?`${Z}/${z.name}`:z.name;Y.push(...H(j,T))}return Y};R=H(Q),console.log(`Found ${R.length} package files`)}catch(H){console.error(`Error reading packages directory ${Q}:`,H),R=[]}let X=`// Auto-generated package index
8
+ // Do not edit this file directly
9
+
10
+ export interface Pantry {
11
+ }
12
+
13
+ export type Packages = Pantry
14
+
15
+ export const pantry: Pantry = {
16
+ }
17
+
18
+ export const packages: Packages = pantry
19
+ `;if(R.length>0){console.log(`Processing ${R.length} package files...`);let H=`// Auto-generated package index
20
+ // Do not edit this file directly
21
+
22
+ `,q=`export interface Pantry {
23
+ `,Z=`export const pantry: Pantry = {
24
+ `,Y=new Set,J=new Set,z=R.sort();for(let U of z)try{let B=L.basename(U,".ts"),K=iw(B),_=L.relative(Q,U).replace(/\.ts$/,"").replace(/\\/g,"/"),{packageVarName:M}=Xw(B,Q,U),G=M,E=1;while(J.has(G))G=`${M}${E}`,E++;if(J.add(G),G===M)H+=`import { ${M} } from './${_}'
25
+ `;else H+=`import { ${M} as ${G} } from './${_}'
26
+ `;let I=K,C=1;while(Y.has(I))I=`${K}${C}`,C++;Y.add(I);let b=/^\d/.test(I)||!/^[a-z_$][\w$]*$/i.test(I)?`'${I}'`:I;q+=` ${b}: typeof ${G}
27
+ `,Z+=` ${b}: ${G},
28
+ `;let V=F.readFileSync(U,"utf-8").match(/domain:\s*['"]([^'"]*)['"]\s*as const/),v=V?V[1]:"";if(v){let P=k(v);if(P!==I){let D=P,u=1;while(Y.has(D))D=`${P}${u}`,u++;Y.add(D);let f=/^\d/.test(D)||!/^[a-z_$][\w$]*$/i.test(D)?`'${D}'`:D;q+=` ${f}: typeof ${G}
29
+ `,Z+=` ${f}: ${G},
30
+ `}}}catch(B){console.error(`Error processing file ${U}:`,B)}let j=await qw(Q),T=new Map;for(let U of z)try{let K=F.readFileSync(U,"utf-8").match(/domain:\s*['"]([^'"]*)['"]\s*as const/),S=K?K[1]:"";if(S){let _=L.basename(U,".ts"),{packageVarName:M}=Xw(_,Q,U),G=M,E=1;while(J.has(G)&&G!==M)G=`${M}${E}`,E++;T.set(S,G)}}catch(B){console.error(`Error processing file for alias mapping ${U}:`,B)}for(let[U,B]of Object.entries(j)){let K=T.get(B);if(K){let S=/^\d/.test(U)||!/^[a-z_$][\w$]*$/i.test(U)?`'${U}'`:U;if(Y.has(U)){let _=S.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),M=new RegExp(`^\\s*${_}:\\s*typeof\\s+\\w+\\s*$`,"gm"),G=new RegExp(`^\\s*${_}:\\s*\\w+,\\s*$`,"gm");q=q.replace(M,""),Z=Z.replace(G,"")}q+=` ${S}: typeof ${K}
31
+ `,Z+=` ${S}: ${K},
32
+ `,Y.add(U)}}q+=`}
33
+
34
+ `,Z+=`}
35
+
36
+ `,X=`${H}
37
+ ${q}export type Packages = Pantry
38
+
39
+ ${Z}export const packages: Packages = pantry
40
+
41
+ export * from './aliases'
42
+ `}try{F.writeFileSync($,X),console.log(`Successfully generated ${$}`)}catch(H){return console.error(`Error writing index file ${$}:`,H),null}if(!F.existsSync($))return console.error(`Index file was not created: ${$}`),null;return console.log(`DEBUG generateIndex: returning ${$}`),console.log(`DEBUG generateIndex: return value isAbsolute=${L.isAbsolute($)}`),console.log(`DEBUG generateIndex: return value type=${typeof $}`),$}catch(Q){return console.error("Error generating index file:",Q),null}}async function qw(w){let Q={};console.log("Generating aliases from package files (avoiding circular dependency)");let $=w||L.join(y.cwd(),"src","packages");if(!F.existsSync($))return console.log(`Packages directory does not exist: ${$}`),Q;function R(q,Z=""){let Y=[],J=F.readdirSync(q,{withFileTypes:!0});for(let z of J)if(z.isFile()&&z.name.endsWith(".ts")&&z.name!=="index.ts"&&z.name!=="aliases.ts")Y.push(L.join(q,z.name));else if(z.isDirectory()&&!z.name.startsWith(".")){let j=L.join(q,z.name),T=Z?`${Z}/${z.name}`:z.name;Y.push(...R(j,T))}return Y}let X=R($);console.log(`Found ${X.length} package files`);for(let q of X)try{let Z=q,Y=F.readFileSync(Z,"utf-8"),J=L.basename(q,".ts"),z=Y.match(/domain:\s*['"]([^'"]*)['"]\s*as const/),j=z?z[1]:Zw(J),T=Y.match(/name:\s*['"]([^'"]*)['"]\s*as const/),O=T?T[1]:"";if(O&&O!==j&&LQ(O,j))if(!Q[O])Q[O]=j,console.log(`Auto-generated alias: ${O} -> ${j}`);else console.log(`Skipped auto-generated alias ${O} -> ${j} (already exists as ${Q[O]})`);let W=Y.match(/aliases:\s*\[([\s\S]*?)\]/);if(W&&W[1]){let U=W[1].match(/["']([^"']*)["']/g);if(U)for(let B of U){let K=B.replace(/["']/g,"");if(!(!K||K.includes("--")||K.includes("$SHELL")||K.includes("curl")||K.includes("sh <(")||K.includes(" -- ")||K.includes(" -i")||K.includes("+")&&K.includes(" ")||K.includes("{{")||K.includes("}}")||K.includes("version.major")||K.includes("version.minor")||K===j))if(!Q[K])Q[K]=j,console.log(`Found explicit alias ${K} -> ${j}`);else console.log(`Skipped explicit alias ${K} -> ${j} (already exists as ${Q[K]})`);else console.log(`Filtered out invalid alias: ${K} for ${j}`)}}if(j==="aws.amazon.com/cli"){if(!Q.aws)Q.aws=j,console.log(`Added AWS CLI alias: aws -> ${j}`);if(!Q["aws/cli"])Q["aws/cli"]=j,console.log(`Added AWS CLI path alias: aws/cli -> ${j}`)}if(j==="aws.amazon.com/cdk"){if(!Q["aws/cdk"])Q["aws/cdk"]=j,console.log(`Added AWS CDK path alias: aws/cdk -> ${j}`)}}catch(Z){console.error(`Error extracting aliases from ${q}:`,Z)}let H=tw();for(let[q,Z]of Object.entries(H))if(!Q[q])Q[q]=Z,console.log(`Added alias override: ${q} -> ${Z}`);else{let Y=Q[q];Q[q]=Z,console.log(`Overrode alias ${q}: ${Y} -> ${Z}`)}return Q}async function jw(w){try{console.log(`DEBUG generateAliases START: packagesDir=${w}`),console.log(`DEBUG generateAliases START: process.cwd()=${y.cwd()}`);let Q=await qw(w),$=w?L.resolve(w):L.resolve(y.cwd(),"src","packages"),R=L.resolve($,"aliases.ts");console.log(`DEBUG generateAliases: targetPackagesDir=${$}`),console.log(`DEBUG generateAliases: aliasesFile=${R}`),console.log(`DEBUG generateAliases: path.isAbsolute(aliasesFile)=${L.isAbsolute(R)}`);let X=L.dirname(R);if(!F.existsSync(X))F.mkdirSync(X,{recursive:!0});let H=Q,q=`/**
43
+ * Auto-generated aliases for pkgx packages
44
+ */
45
+
46
+ `;q+=`export const aliases: Record<string, string> = {
47
+ `;let Z=Object.entries(H).sort((Y,J)=>Y[0].localeCompare(J[0]));for(let[Y,J]of Z)q+=` '${Y}': '${J}',
48
+ `;return q+=`}
49
+ `,F.writeFileSync(R,q),console.log(`Successfully generated ${R} with ${Z.length} aliases`),console.log(`DEBUG generateAliases: returning ${R}`),console.log(`DEBUG generateAliases: return value isAbsolute=${L.isAbsolute(R)}`),console.log(`DEBUG generateAliases: return value type=${typeof R}`),R}catch(Q){return console.error("Error generating aliases file:",Q),""}}function SQ(w){let Q=w.split(`
50
+ `).map(($)=>$.trimEnd()).join(`
51
+ `);return Q=bQ(Q),Q=Q.replace(/\n{3,}/g,`
52
+
53
+ `),Q=`${Q.trimEnd()}
54
+ `,Q}function Mw(w){return SQ(w)}function bQ(w){let Q=w.split(`
55
+ `),$=!1;return Q.map((R)=>{if(R.trimStart().startsWith("```"))return $=!$,R;if($)return R;return R.replace(/(?<!\]\()(?<!\()(?<!<)(https?:\/\/[^\s)>\]]+)/g,(X,H,q)=>{if(q>0&&R[q-1]==="<")return X;let Z=R.slice(0,q);if(/\]\($/.test(Z))return X;if((Z.match(/`/g)||[]).length%2===1)return X;return`<${X}>`})}).join(`
56
+ `)}function FQ(w){if(["undefined","null","true","false","var","let","const","function","class","if","else","for","while","do","switch","case","default","break","continue","return","try","catch","finally","throw","new","this","super","import","export","from","as","typeof","instanceof","in","of","delete","void","async","await","yield","static","extends","implements","interface","type","enum","namespace","module","declare","abstract","public","private","protected","readonly","get","set"].includes(w.toLowerCase()))return!1;let $=["go","rust","zig","nim","dart","julia","scala","kotlin","swift","node","bun"];if(!w.includes(".")&&!$.includes(w.toLowerCase()))return!1;if(!w||w.trim().length===0)return!1;if(!/^[\w.\-/]+$/.test(w))return!1;return!0}function AQ(w){if(/^[A-Z][A-Z0-9_]*(?:\^|$)/.test(w))return!0;return[/^linux$/,/^darwin$/,/^ompi_.*flags/i,/^perl5lib/i,/^gsettings-desktop-schemas$/,/^curl\.se\/ca-certs$/,/^openssh\.com$/].some(($)=>$.test(w))}function p(w){if(!FQ(w.domain))return!0;if(!w.description)return!0;return["Go home.","Crafters of fine Open Source products","Package information for","pkgx package","Loading...","Please wait...","Package information available on pkgx.dev"].some(($)=>w.description.includes($))}function ew(w){let Q=(R)=>{if(!w.versions||w.versions.length===0)return R.replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;");let X=w.versions[0],H=X.split("."),q=H[0]||"",Z=H[1]||"",Y=H[2]||"",J=Z?`${q}.${Z}`:q;return R.replace(/\{\{\s*version\.marketing\s*\}\}/g,J).replace(/\{\{\s*version\.major\s*\}\}/g,q).replace(/\{\{\s*version\.minor\s*\}\}/g,Z).replace(/\{\{\s*version\.patch\s*\}\}/g,Y).replace(/\{\{\s*version\.raw\s*\}\}/g,X).replace(/\{\{\s*version\s*\}\}/g,X).replace(/\{\{(?![^}]*\}\})/g,"&lbrace;&lbrace;")};if(w.pantryInstallCommand){let R=w.pantryInstallCommand.match(/pantry install (.+)/);if(R){let X=R[1];if(w.aliases&&w.aliases.length>0){let H=[...w.aliases].sort((Z,Y)=>Z.length-Y.length);return`pantry install ${Q(H[0])}`}if(w.aliases&&w.aliases.some((H)=>H.toLowerCase()===X.toLowerCase()))return`pantry install ${Q(X.toLowerCase())}`;return Q(w.pantryInstallCommand)}}if(w.installCommand)return Q(w.installCommand);let $=w.domain;if(w.aliases&&w.aliases.length>0)$=[...w.aliases].sort((X,H)=>X.length-H.length)[0];return $=Q($),`pantry install ${$}`}async function xQ(w,Q){let $=await Ew(Q),R=await qw(Q),X=rw(),H=L.resolve(w,"package-catalog.md"),q={},Z=0;for(let[W,U]of Object.entries($))if(!p(U))q[W]=U;else Z++,console.log(`Excluding package ${U.domain||W} (placeholder data)`);console.log(`Filtered out ${Z} packages with placeholder data`);let Y=new Set,J=new Map;for(let[W,U]of Object.entries(q)){let B=U.domain;if(!Y.has(B))J.set(B,U),Y.add(B)}let z=new Set;Object.values(X).forEach((W)=>{W.forEach((U)=>z.add(U))});let j=[];if(J.forEach((W,U)=>{if(!z.has(U))j.push(U)}),j.length>0)X["Other Utilities"]=j;let T=`# Package Catalog
57
+
58
+ This comprehensive catalog lists all ${J.size}+ packages available in ts-pantry, organized by category.
59
+
60
+ Each package can be accessed using \`getPackage(name)\` or directly via \`pantry.domain\`.
61
+
62
+ ## Quick Stats
63
+
64
+ - **Total Packages**: ${J.size}
65
+ - **Categories**: ${Object.keys(X).length}
66
+ - **Last Updated**: ${new Date().toISOString()}
67
+
68
+ ## Table of Contents
69
+
70
+ `,O=(W)=>{if($[W])return{domainVarName:W,pkg:$[W]};let U=R[W];if(U){let B=k(U);if($[B])return{domainVarName:B,pkg:$[B]}}return null};Object.keys(X).forEach((W)=>{let U=W.toLowerCase().replace(/[^a-z0-9]+/g,"-"),B=X[W],K=new Map;B.forEach((_)=>{let M=O(_);if(M&&!p(M.pkg)){let G=M.pkg.domain||M.pkg.fullPath||"unknown";if(!K.has(G))K.set(G,M);else{let E=K.get(G);if(M.domainVarName.length<E.domainVarName.length||M.domainVarName.length===E.domainVarName.length&&M.domainVarName<E.domainVarName)K.set(G,M)}}});let S=K.size;if(S>0)T+=`- [${W}](#${U}) (${S} packages)
71
+ `}),T+=`
72
+ `;for(let[W,U]of Object.entries(X)){let B=new Map;U.forEach((S)=>{let _=O(S);if(_&&!p(_.pkg)){let M=_.pkg.domain||_.pkg.fullPath||"unknown";if(!B.has(M))B.set(M,_);else{let G=B.get(M);if(_.domainVarName.length<G.domainVarName.length||_.domainVarName.length===G.domainVarName.length&&_.domainVarName<G.domainVarName)B.set(M,_)}}});let K=Array.from(B.values()).sort((S,_)=>(S.pkg.domain||S.domainVarName).localeCompare(_.pkg.domain||_.domainVarName));if(K.length===0)continue;T+=`## ${W}
73
+
74
+ `,T+=`${K.length} packages in this category
75
+
76
+ `,T+=`| Package | Description | Programs | Versions | Install |
77
+ `,T+=`|---------|-------------|----------|----------|----------|
78
+ `;for(let{domainVarName:S,pkg:_}of K)try{let M=_.domain||_.fullPath||"unknown",G=_.aliases?` (${_.aliases.map((u)=>u.replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;")).join(", ")})`:"",E=_.programs.slice(0,3).map((u)=>u.replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;")).join(", ");if(_.programs.length>3)E+=`, ... (+${_.programs.length-3})`;if(_.programs.length===0)E="-";let I=_.versions?.length||0,C=_.versions?.[0]||"latest",b=I>0?`${C} (+${I-1})`:"latest",x=_.description.replace(/\s+/g," ").replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;").replace(/\x27/g,"&#39;").replace(/"/g,"&quot;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/\|/g,"\\|");if(x.length>100)x=`${x.substring(0,97)}...`;let V=_.name||M;if(_.aliases&&_.aliases.length>0)V=[..._.aliases].sort((f,h)=>f.length-h.length)[0];V=V.replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;");let v=`\`pkgx ${V}\``,P;if(M.includes("."))if(M.startsWith("github.com/")&&M.includes("/")){let f=M.replace("github.com/","").split("/");if(f.length>=2){let h=f[0],WQ=f.slice(1).join("-");P=`./packages/github.com/${h}/${WQ}.md`}else{let h=S.toLowerCase();if(/^\d/.test(h))h=`pkg-${h}`;h=h.replace(/[^\w-]/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""),P=`./packages/${h}.md`}}else P=`./packages/${M}/index.md`;else{let u=S.toLowerCase();if(/^\d/.test(u))u=`pkg-${u}`;u=u.replace(/[^\w-]/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""),P=`./packages/${u}.md`}let D=`| **[${M}](${P})**${G} | ${x} | ${E} | ${b} | ${v} |`.replace(/\r?\n/g," ").replace(/\s+/g," ");T+=`${D}
79
+ `}catch(M){let G=_.domain||_.fullPath||"unknown";console.error(`Error processing ${G}:`,M),T+=`| **${G}** | Error retrieving package information | - | - | - |
80
+ `}T+=`
81
+ `}return T+=`## Usage Examples
82
+
83
+ ### Basic Usage
84
+
85
+ \`\`\`typescript
86
+ import { getPackage, pantry } from 'ts-pkgx'
87
+
88
+ // Get a package by domain
89
+ const nodePackage = pantry.nodejsorg
90
+
91
+ // Get a package by alias
92
+ const nodeByAlias = getPackage('node')
93
+
94
+ // Access package properties
95
+ console.log(\`Package: \${nodePackage.name} - \${nodePackage.description}\`)
96
+ console.log(\`Install: \${nodePackage.installCommand}\`)
97
+ console.log(\`Programs: \${nodePackage.programs.join(', ')}\`)
98
+ \`\`\`
99
+
100
+ ### Advanced Usage
101
+
102
+ \`\`\`typescript
103
+ // Find packages by category
104
+ const databases = [
105
+ pantry.postgresqlorg,
106
+ pantry.mysqlcom,
107
+ pantry.redisio,
108
+ pantry.mongodbcom
109
+ ]
110
+
111
+ // Get all available versions
112
+ const nodeVersions = pantry.nodejsorg.versions
113
+ console.log(\`Node.js versions: \${nodeVersions.slice(0, 5).join(', ')}...\`)
114
+
115
+ // Check dependencies
116
+ const nodeDeps = pantry.nodejsorg.dependencies
117
+ console.log(\`Node.js dependencies: \${nodeDeps.join(', ')}\`)
118
+ \`\`\`
119
+
120
+ ### Installation Examples
121
+
122
+ \`\`\`bash
123
+ # Install using pkgx
124
+ pkgx node
125
+ pkgx python
126
+ pkgx rust
127
+
128
+ # Install specific versions
129
+ pkgx node@20
130
+ pkgx python@3.11
131
+
132
+ # Install multiple packages
133
+ pkgx node python rust
134
+ \`\`\`
135
+
136
+ ## Package Information
137
+
138
+ Each package includes:
139
+
140
+ - **Name**: Short identifier for the package
141
+ - **Domain**: Full domain identifier
142
+ - **Description**: What the package does
143
+ - **Programs**: Executable programs provided
144
+ - **Versions**: Available versions
145
+ - **Dependencies**: Required dependencies
146
+ - **Companions**: Related packages
147
+ - **Install Command**: How to install with pkgx
148
+
149
+ ## Contributing
150
+
151
+ To add or update packages, see the pkgx [contribution guide](https://docs.pkgx.sh/appendix/packaging/pantry).
152
+ `,await F.promises.writeFile(H,Mw(T)),H}function nw(w,Q,$){if(w.includes("."))if(w.startsWith("github.com/")){let X=w.replace("github.com/","").split("/");if(X.length>=2){let H=X[0],q=X.slice(1).join("-");return L.join($,"github.com",H,`${q}.md`)}else{let H=X[0];return L.join($,"github.com",H,"index.md")}}else return L.join($,w,"index.md");else{let R=Q.toLowerCase();if(/^\d/.test(R))R=`pkg-${R}`;return R=R.replace(/[^\w-]/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""),L.join($,`${R}.md`)}}async function VQ(w,Q){let $=await Ew(Q),R=L.join(w,"packages");if(!F.existsSync(R))F.mkdirSync(R,{recursive:!0});let X=[],H=new Map;for(let[q,Z]of Object.entries($)){if(p(Z)){console.log(`Skipping package page for ${Z.domain||q} (placeholder data)`);continue}let Y=Z.domain;if(!H.has(Y))H.set(Y,{domainVarName:q,pkg:Z});else{let J=H.get(Y);if(q.length<J.domainVarName.length||q.length===J.domainVarName.length&&q<J.domainVarName)H.set(Y,{domainVarName:q,pkg:Z}),console.log(`Replaced ${J.domainVarName} with ${q} for domain ${Y}`)}}for(let{domainVarName:q,pkg:Z}of H.values())try{let Y=Z.domain||Z.fullPath||q,J;if(Y.includes("."))if(Y.startsWith("github.com/")){let E=Y.replace("github.com/","").split("/");if(E.length>=2){let I=E[0],C=E.slice(1).join("-"),b=L.join(R,"github.com",I);if(!F.existsSync(b))F.mkdirSync(b,{recursive:!0});J=L.join(b,`${C}.md`)}else{let I=E[0],C=L.join(R,"github.com",I);if(!F.existsSync(C))F.mkdirSync(C,{recursive:!0});J=L.join(C,"index.md")}}else{let G=L.join(R,Y);if(!F.existsSync(G))F.mkdirSync(G,{recursive:!0});J=L.join(G,"index.md")}else{let G=q.toLowerCase();if(/^\d/.test(G))G=`pkg-${G}`;G=G.replace(/[^\w-]/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""),J=L.join(R,`${G}.md`)}let z=Z.description||"",j=(G)=>{if(!Z.versions||Z.versions.length===0)return G.replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;");let E=Z.versions[0],I=E.split("."),C=I[0]||"",b=I[1]||"",x=I[2]||"",V=b?`${C}.${b}`:C;return G.replace(/\{\{\s*version\.marketing\s*\}\}/g,V).replace(/\{\{\s*version\.major\s*\}\}/g,C).replace(/\{\{\s*version\.minor\s*\}\}/g,b).replace(/\{\{\s*version\.patch\s*\}\}/g,x).replace(/\{\{\s*version\.raw\s*\}\}/g,E).replace(/\{\{\s*version\s*\}\}/g,E).replace(/\{\{(?![^}]*\}\})/g,"&lbrace;&lbrace;")},T=j(Z.name||Y),O=j(z).replace(/\s+/g," "),W=`# ${T}
153
+
154
+ ${O?`> ${O}`:""}
155
+
156
+ ## Package Information
157
+
158
+ - **Domain**: \`${Y}\`
159
+ - **Name**: \`${T}\`
160
+ - **Homepage**: ${Z.homepageUrl||"Not specified"}
161
+ - **Source**: [View on GitHub](${Z.packageYmlUrl||`https://github.com/pkgxdev/pantry/tree/main/projects/${Y}/package.yml`})
162
+
163
+ ## Installation
164
+
165
+ \`\`\`bash
166
+ # Install with pantry
167
+ ${ew(Z)}
168
+ \`\`\`
169
+
170
+ ## Programs
171
+
172
+ This package provides the following executable programs:
173
+
174
+ `;if(Z.programs&&Z.programs.length>0)Z.programs.forEach((G)=>{let E=j(G);W+=`- \`${E}\`
175
+ `});else W+=`No programs specified.
176
+ `;if(Z.aliases&&Z.aliases.length>0)W+=`
177
+ ## Aliases
178
+
179
+ This package can also be accessed using these aliases:
180
+
181
+ `,Z.aliases.forEach((G)=>{let E=j(G);W+=`- \`${E}\`
182
+ `});if(Z.versions&&Z.versions.length>0){W+=`
183
+ ## Available Versions
184
+
185
+ <details>
186
+ <summary>Show all ${Z.versions.length} versions</summary>
187
+
188
+ `;let G=new Map,E=[];Z.versions.forEach((I)=>{let C=I.split("."),b=C.length>=2?`${C[0]}.${C[1]}`:C[0];if(!G.has(b))G.set(b,[]),E.push(b);G.get(b).push(I)}),E.forEach((I)=>{let C=G.get(I);W+=`- ${C.map((b)=>`\`${b}\``).join(", ")}
189
+ `}),W+=`
190
+ </details>
191
+
192
+ **Latest Version**: \`${Z.versions[0]}\`
193
+
194
+ ### Install Specific Version
195
+
196
+ \`\`\`bash
197
+ # Install specific version
198
+ ${Z.pkgxInstallCommand?j(Z.pkgxInstallCommand.replace(`+${Y}`,`+${Y}@${Z.versions[0]}`)):`sh <(curl https://pkgx.sh) +${Y}@${Z.versions[0]} -- $SHELL -i`}
199
+ \`\`\`
200
+ `}if(Z.dependencies&&Z.dependencies.length>0)W+=`
201
+ ## Dependencies
202
+
203
+ This package depends on:
204
+
205
+ `,Z.dependencies.forEach((G)=>{W+=`- \`${G}\`
206
+ `});if(Z.companions&&Z.companions.length>0){let G=Z.companions.filter((E)=>!AQ(E));if(G.length>0)W+=`
207
+ ## Related Packages
208
+
209
+ These packages work well with ${Z.name||Y}:
210
+
211
+ `,G.forEach((E)=>{let I=k(E),C=$[I];if(C&&!p(C)){let b=nw(E,I,R),x=L.relative(L.dirname(J),b).replace(/\\/g,"/"),V=C.description?.trim();if(V)W+=`- [\`${E}\`](${x}) - ${V}
212
+ `;else W+=`- [\`${E}\`](${x})
213
+ `}else{let b=nw(E,I,R),x=L.relative(L.dirname(J),b).replace(/\\/g,"/"),V=C?.description?.trim()||"Package not available";if(V&&V!=="Package not available")W+=`- [\`${E}\`](${x}) - ${V}
214
+ `;else W+=`- [\`${E}\`](${x})
215
+ `}})}let U=L.dirname(R),K=`${L.relative(L.dirname(J),U)}/package-catalog.md`.replace(/\\/g,"/"),S=Z.aliases&&Z.aliases.length>0?Z.aliases[0]:Z.name||k(Y),M=/[^\w$]/.test(S)||/^\d/.test(S)?`pantry['${S}']`:`pantry.${S}`;W+=`
216
+ ## Usage Examples
217
+
218
+ \`\`\`typescript
219
+ import { pantry } from 'ts-pkgx'
220
+
221
+ // Access this package
222
+ const pkg = ${M}
223
+
224
+ console.log(\`Package: \${pkg.name}\`)
225
+ console.log(\`Description: \${pkg.description}\`)
226
+ console.log(\`Programs: \${pkg.programs.join(', ')}\`)
227
+ \`\`\`
228
+
229
+ ## Links
230
+
231
+ - [Package Source](${Z.packageYmlUrl||`https://github.com/pkgxdev/pantry/tree/main/projects/${Y}/package.yml`})
232
+ - [Homepage](${Z.homepageUrl||"#"})
233
+ - [Back to Package Catalog](${K})
234
+
235
+ ---
236
+
237
+ > Auto-generated from package data.
238
+ `,await F.promises.writeFile(J,Mw(W)),X.push(J)}catch(Y){console.error(`Error generating page for ${q}:`,Y)}return X}async function yQ(w,Q){let $=await Ew(Q),R=await qw(Q),X=rw(),H=L.join(w,"categories");if(!F.existsSync(H))F.mkdirSync(H,{recursive:!0});let q=[],Z=(Y)=>{if($[Y])return{domainVarName:Y,pkg:$[Y]};if(R[Y]){let J=R[Y],z=k(J);if($[z])return{domainVarName:z,pkg:$[z]}}return null};for(let[Y,J]of Object.entries(X)){let z=new Map;J.forEach((U)=>{let B=Z(U);if(B&&!p(B.pkg)){let K=B.pkg.domain||B.pkg.fullPath||"unknown";if(!z.has(K))z.set(K,B);else{let S=z.get(K);if(B.domainVarName.length<S.domainVarName.length||B.domainVarName.length===S.domainVarName.length&&B.domainVarName<S.domainVarName)z.set(K,B)}}});let j=Array.from(z.values()).sort((U,B)=>(U.pkg.domain||U.domainVarName).localeCompare(B.pkg.domain||B.domainVarName));if(j.length===0)continue;let T=`${Y.toLowerCase().replace(/[^a-z0-9]+/g,"-")}.md`,O=L.join(H,T),W=`# ${Y}
239
+
240
+ ${j.length} packages in this category
241
+
242
+ ${Y==="Programming Languages"?"Popular programming languages and their runtimes available through pkgx.":Y==="Databases"?"Database systems and data storage solutions.":Y==="Development Tools"?"Development environments, editors, and programming tools.":Y==="Build Tools"?"Build systems, compilers, and development infrastructure.":Y==="DevOps"?"Tools for deployment, orchestration, and infrastructure management.":Y==="Multimedia"?"Audio, video, and image processing tools.":Y==="Security"?"Security tools, encryption, and authentication systems.":Y==="Networking"?"Network tools, protocols, and communication software.":Y==="CLI Tools & Utilities"?"Command-line utilities and system tools.":`Packages related to ${Y.toLowerCase()}.`}
243
+
244
+ ## Packages
245
+
246
+ `;j.forEach(({domainVarName:U,pkg:B})=>{let K=B.domain||B.fullPath||"unknown",S=(C)=>{if(!B.versions||B.versions.length===0)return C.replace(/\{\{/g,"&lbrace;&lbrace;").replace(/\}\}/g,"&rbrace;&rbrace;");let b=B.versions[0],x=b.split("."),V=x[0]||"",v=x[1]||"",P=x[2]||"",D=v?`${V}.${v}`:V;return C.replace(/\{\{\s*version\.marketing\s*\}\}/g,D).replace(/\{\{\s*version\.major\s*\}\}/g,V).replace(/\{\{\s*version\.minor\s*\}\}/g,v).replace(/\{\{\s*version\.patch\s*\}\}/g,P).replace(/\{\{\s*version\.raw\s*\}\}/g,b).replace(/\{\{\s*version\s*\}\}/g,b).replace(/\{\{(?![^}]*\}\})/g,"&lbrace;&lbrace;")},_=[];if(B.name&&B.name!==K)_.push(B.name);if(B.aliases&&B.aliases.length>0)_.push(...B.aliases);let M=_.length>0?` (${_.join(", ")})`:"",G=B.description||"",E=S(G).replace(/\s+/g," "),I;if(K.includes("."))if(K.startsWith("github.com/")&&K.includes("/")){let b=K.replace("github.com/","").split("/");if(b.length>=2){let x=b[0],V=b.slice(1).join("-");I=`../packages/github.com/${x}/${V}.md`}else{let x=U.toLowerCase();if(/^\d/.test(x))x=`pkg-${x}`;x=x.replace(/[^\w-]/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""),I=`../packages/${x}.md`}}else I=`../packages/${K}/index.md`;else{let C=U.toLowerCase();if(/^\d/.test(C))C=`pkg-${C}`;C=C.replace(/[^\w-]/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""),I=`../packages/${C}.md`}W+=`### [${K}](${I})${M}
247
+
248
+ ${E?`${E}`:""}
249
+
250
+ **Programs**: ${B.programs&&B.programs.length>0?B.programs.map((C)=>S(C)).join(", "):"None specified"}
251
+
252
+ **Install**: \`${ew(B)}\`
253
+
254
+ ---
255
+
256
+ `}),W+=`[← Back to Package Catalog](../package-catalog.md)
257
+ `,await F.promises.writeFile(O,Mw(W)),q.push(O)}return q}async function Tw(w=_w,Q){console.log("\uD83D\uDE80 Generating comprehensive package documentation...");try{if(!F.existsSync(w))F.mkdirSync(w,{recursive:!0});console.log("\uD83D\uDCDA Generating package catalog...");let $=await xQ(w,Q);console.log(`✅ Generated: ${$}`),console.log("\uD83D\uDCC4 Generating individual package pages...");let R=await VQ(w,Q);console.log(`✅ Generated ${R.length} package pages`),console.log("\uD83D\uDCC2 Generating category pages...");let X=await yQ(w,Q);console.log(`✅ Generated ${X.length} category pages`),console.log(`
258
+ \uD83C\uDF89 Documentation generation complete!`),console.log(`\uD83D\uDCCD Output directory: ${w}`),console.log(`\uD83D\uDCCA Total files generated: ${1+R.length+X.length}`),console.log(`
259
+ Files generated:`),console.log(`- Package catalog: ${$}`),console.log(`- Package pages: ${R.length} files in docs/packages/`),console.log(`- Category pages: ${X.length} files in docs/categories/`)}catch($){throw console.error("❌ Error generating documentation:",$),$}}async function Lw(){try{console.log("\uD83C\uDFAF Updating Dependencies type timestamp...");let w=L.join(y.cwd(),"src","dependencies.ts");if(!F.existsSync(w)){console.log("dependencies.ts not found, skipping update");return}let Q=F.readFileSync(w,"utf-8"),$=new Date().toISOString(),R=Q.replace(/\/\/ Auto-generated precise dependency types/,`// Auto-generated precise dependency types
260
+ // Last updated: ${$}`);F.writeFileSync(w,R),console.log("✅ Updated dependencies.ts timestamp")}catch(w){console.error("Error updating dependencies.ts:",w)}}async function NQ(){try{let w=y.argv.slice(2);switch(w[0]||"index"){case"index":{if(console.log("\uD83D\uDD27 Generating package index..."),!await Ow())console.error("❌ Failed to generate index"),y.exit(1);if(console.log("\uD83C\uDFF7️ Generating aliases..."),!await jw())console.error("❌ Failed to generate aliases"),y.exit(1);console.log("\uD83C\uDFAF Updating PackageVersionMap..."),await Lw(),console.log("✨ Index and aliases generation completed successfully!");break}case"docs":{let $=w[1]||_w;console.log(`\uD83D\uDCDA Generating documentation to ${$}...`),await Tw($),console.log("✨ Documentation generation completed successfully!");break}case"all":{if(console.log("\uD83D\uDE80 Generating everything..."),console.log("\uD83D\uDD27 Generating package index..."),!await Ow())console.error("❌ Failed to generate index"),y.exit(1);if(console.log("\uD83C\uDFF7️ Generating aliases..."),!await jw())console.error("❌ Failed to generate aliases"),y.exit(1);console.log("\uD83C\uDFAF Updating PackageVersionMap..."),await Lw();let X=w[1]||_w;console.log(`\uD83D\uDCDA Generating documentation to ${X}...`),await Tw(X),console.log("✨ All generation completed successfully!");break}default:console.log(`
261
+ Usage: bun run src/generate.ts [command] [options]
262
+
263
+ Commands:
264
+ index Generate package index and aliases (default)
265
+ docs [output-dir] Generate documentation (default: ./docs)
266
+ all [output-dir] Generate everything (index, aliases, and docs)
267
+
268
+ Examples:
269
+ bun run src/generate.ts
270
+ bun run src/generate.ts index
271
+ bun run src/generate.ts docs
272
+ bun run src/generate.ts docs ./custom-docs
273
+ bun run src/generate.ts all
274
+ bun run src/generate.ts all ./custom-docs
275
+ `);break}}catch(w){console.error("\uD83D\uDCA5 Error during generation:",w),y.exit(1)}}var uQ=import.meta.url===`file://${y.argv[1]}`||import.meta.url===`file:///${y.argv[1]}`;if(uQ)NQ();import s from"node:fs";import r from"node:path";import i from"node:process";async function PQ(w,Q={}){let{targetOs:$=i.platform==="darwin"?"darwin":i.platform==="win32"?"windows":"linux",includeOsSpecific:R=!0,maxDepth:X=10,verbose:H=!1}=Q,q=await sw(w,{targetOs:$,includeOsSpecific:R,maxDepth:X,verbose:H}),Z=$w(w),Y=q.allDependencies.map((O)=>({name:O.name,version:O.version,constraint:O.constraint,isOsSpecific:O.isOsSpecific,os:O.os})),J=Z.map((O)=>O.name),z=`pkgx install ${J.join(" ")}`,j=`pantry install ${J.join(" ")}`,T=q.conflicts.map((O)=>{let W=Y.find((U)=>U.name===O.package);return{package:O.package,versions:O.versions,resolved:W?.version||"latest"}});return{packages:Y,directCount:Z.length,totalCount:Y.length,conflicts:T,pkgxCommand:z,pantryCommand:j}}async function i6(w,Q={}){let $=r.join(i.cwd(),`.temp-deps-${Date.now()}.yaml`);try{return s.writeFileSync($,w,"utf-8"),await PQ($,Q)}finally{if(s.existsSync($))s.unlinkSync($)}}async function a6(w,Q={}){let{targetOs:$=i.platform==="darwin"?"darwin":i.platform==="win32"?"windows":"linux",includeOsSpecific:R=!0,maxDepth:X=10}=Q,H=await Rw(w,{targetOs:$,includeOsSpecific:R,maxDepth:X});return H.unshift({name:w,version:"latest",constraint:"*",isOsSpecific:!1}),(await Gw(H,{targetOs:$,includeOsSpecific:R,maxDepth:X})).allDependencies.map((Z)=>({name:Z.name,version:Z.version,constraint:Z.constraint,isOsSpecific:Z.isOsSpecific,os:Z.os}))}function e6(w,Q="pantry"){if(Q==="pkgx")return`pkgx install ${w.join(" ")}`;return`pantry install ${w.join(" ")}`}function w$(w){let Q=[],$=r.join(w,"pantry");try{let H=s.readdirSync($,{withFileTypes:!0});for(let q of H){if(!q.isDirectory())continue;if(q.name.startsWith("@")){let Z=r.join($,q.name);try{let Y=s.readdirSync(Z,{withFileTypes:!0});for(let J of Y){if(!J.isDirectory())continue;let z=`${q.name}/${J.name}`,j=r.join(Z,J.name,"package.json"),T=wQ(j);Q.push({name:z,version:T,isWorkspace:z.startsWith("@stacksjs/"),isScoped:!0})}}catch{}}else{let Z=r.join($,q.name,"package.json"),Y=wQ(Z);Q.push({name:q.name,version:Y,isWorkspace:!1,isScoped:!1})}}}catch{}Q.sort((H,q)=>H.name.localeCompare(q.name));let R=Q.filter((H)=>H.isWorkspace).length,X=Q.length-R;return{packages:Q,thirdPartyCount:X,workspaceCount:R,totalCount:Q.length}}function wQ(w){try{let Q=s.readFileSync(w,"utf-8");return JSON.parse(Q).version||"0.0.0"}catch{return"0.0.0"}}Q6();function $$(w){return w}function R$(w){return w}var X$={baseUrl:"https://dist.pkgx.dev"};function Z$(w){return w}import{execSync as Cw}from"node:child_process";var a=new Set,QQ=!1;function DQ(){if(QQ)return;QQ=!0;let w=()=>{for(let Q of a)try{Cw(`pantry stop ${Q}`,{stdio:"ignore",timeout:1e4})}catch{}a.clear()};process.on("exit",w),process.on("SIGINT",()=>{w(),process.exit(130)}),process.on("SIGTERM",()=>{w(),process.exit(143)})}function Hw(w,Q=!1){let $={encoding:"utf-8",timeout:30000,stdio:Q?"pipe":["pipe","pipe","pipe"]};return Cw(`pantry ${w}`,$)}function hQ(w){let Q=w.match(/Name:\s+(\S+)/)?.[1]??"",$=/Status:\s+running/i.test(w),R=w.match(/Port:\s+(\d+)/),X=w.match(/PID:\s+(\d+)/),H=w.match(/Data Dir:\s+(.+)/);return{name:Q,running:$,port:R?Number.parseInt(R[1],10):null,pid:X?Number.parseInt(X[1],10):null,dataDir:H?H[1].trim():null}}class d{config;_startedByUs=!1;constructor(w){this.config={name:w.name,port:w.port??0,readyTimeoutMs:w.readyTimeoutMs??15000,pollIntervalMs:w.pollIntervalMs??200,quiet:w.quiet??!0}}static isAvailable(){try{return Cw("pantry --version",{stdio:"ignore",timeout:5000}),!0}catch{return!1}}status(){try{let w=Hw(`inspect ${this.config.name}`,!0);return hQ(w)}catch{return{name:this.config.name,running:!1,port:null,pid:null,dataDir:null}}}isRunning(){return this.status().running}getPort(){return this.status().port}async start(){if(DQ(),this.isRunning())return this.status();return Hw(`start ${this.config.name}`,this.config.quiet),this._startedByUs=!0,a.add(this.config.name),await this.waitReady(),this.status()}async stop(){if(!this._startedByUs)return;try{Hw(`stop ${this.config.name}`,this.config.quiet)}catch{}a.delete(this.config.name),this._startedByUs=!1}async forceStop(){try{Hw(`stop ${this.config.name}`,this.config.quiet)}catch{}a.delete(this.config.name),this._startedByUs=!1}async ensureRunning(){if(this.isRunning())return this.status();return this.start()}async waitReady(){let w=Date.now()+this.config.readyTimeoutMs;while(Date.now()<w){if(this.isRunning())return;await new Promise((Q)=>setTimeout(Q,this.config.pollIntervalMs))}throw Error(`Service '${this.config.name}' did not become ready within ${this.config.readyTimeoutMs}ms`)}}var $Q=new d({name:"postgres"});async function Iw(w){let Q=await $Q.ensureRunning();return{port:w?.port??Q.port??5432,host:w?.host??"localhost",database:w?.database??"postgres",username:w?.username??process.env.USER??"postgres"}}async function Sw(){await $Q.stop()}function vQ(w){let Q=null;return{get connection(){if(!Q)throw Error("Postgres not started. Ensure beforeAll has run.");return Q},beforeAll:async()=>{Q=await Iw(w)},afterAll:async()=>{await Sw(),Q=null}}}async function fQ(w,Q){let $=await Iw(Q);try{return await w($)}finally{if(Q?.stopAfter!==!1)await Sw()}}var RQ=new d({name:"redis"});async function bw(w){let Q=await RQ.ensureRunning(),$=w?.port??Q.port??6379,R=w?.host??"localhost";return{port:$,host:R,url:`redis://${R}:${$}`}}async function Fw(){await RQ.stop()}function kQ(w){let Q=null;return{get connection(){if(!Q)throw Error("Redis not started. Ensure beforeAll has run.");return Q},beforeAll:async()=>{Q=await bw(w)},afterAll:async()=>{await Fw(),Q=null}}}async function dQ(w,Q){let $=await bw(Q);try{return await w($)}finally{if(Q?.stopAfter!==!1)await Fw()}}var XQ=new d({name:"mysql"});async function Aw(w){let Q=await XQ.ensureRunning();return{port:w?.port??Q.port??3306,host:w?.host??"localhost",database:w?.database??"test",username:w?.username??"root"}}async function xw(){await XQ.stop()}function gQ(w){let Q=null;return{get connection(){if(!Q)throw Error("MySQL not started. Ensure beforeAll has run.");return Q},beforeAll:async()=>{Q=await Aw(w)},afterAll:async()=>{await xw(),Q=null}}}async function mQ(w,Q){let $=await Aw(Q);try{return await w($)}finally{if(Q?.stopAfter!==!1)await xw()}}import{existsSync as Vw,mkdirSync as qQ,mkdtempSync as lQ,rmSync as HQ,writeFileSync as cQ}from"node:fs";import{tmpdir as pQ}from"node:os";import{join as yw}from"node:path";var Yw=new Set,ZQ=!1;function oQ(){if(ZQ)return;ZQ=!0;let w=()=>{for(let Q of Yw)try{if(Vw(Q))HQ(Q,{recursive:!0,force:!0})}catch{}Yw.clear()};process.on("exit",w),process.on("SIGINT",()=>{w(),process.exit(130)}),process.on("SIGTERM",()=>{w(),process.exit(143)})}function Nw(w="pantry-test-"){oQ();let Q=lQ(yw(pQ(),w));return Yw.add(Q),Q}function uw(w){Yw.delete(w);try{if(Vw(w))HQ(w,{recursive:!0,force:!0})}catch{}}async function sQ(w,Q){let $=Nw(w);try{return await Q($)}finally{uw($)}}function nQ(w,Q){let $=Nw(w);try{return Q($)}finally{uw($)}}function tQ(w,Q,$){let R=yw(w,Q),X=R.substring(0,R.lastIndexOf("/"));if(X&&!Vw(X))qQ(X,{recursive:!0});return cQ(R,$),R}function rQ(w,Q){let $=yw(w,Q);return qQ($,{recursive:!0}),$}import*as A from"node:fs";import*as N from"node:path";import*as n from"node:os";import*as Pw from"node:https";import*as Dw from"node:http";import{execSync as Ww}from"node:child_process";function iQ(){let w=n.platform(),Q=n.arch();return{os:w==="darwin"?"darwin":w==="win32"?"windows":"linux",arch:Q==="arm64"?"aarch64":"x86_64"}}var Jw={"ziglang.org":{getDownloadUrl(w,Q){let $={x86_64:"x86_64",aarch64:"aarch64"},R={darwin:"macos",linux:"linux",windows:"windows"},X=$[Q.arch],H=R[Q.os],q=Q.os==="windows"?"zip":"tar.xz";if(w.includes("-dev"))return`https://ziglang.org/builds/zig-${X}-${H}-${w}.${q}`;return`https://ziglang.org/download/${w}/zig-${X}-${H}-${w}.${q}`},getArchiveFormat(w){return w.os==="windows"?"zip":"tar.xz"},getBinaries(w){return w.os==="windows"?["zig.exe"]:["zig"]},getArchivePrefix(w,Q){let $={x86_64:"x86_64",aarch64:"aarch64"},R={darwin:"macos",linux:"linux",windows:"windows"};return`zig-${$[Q.arch]}-${R[Q.os]}-${w}`}},"bun.sh":{getDownloadUrl(w,Q){let $={"darwin-aarch64":"darwin-aarch64","darwin-x86_64":"darwin-x64","linux-aarch64":"linux-aarch64","linux-x86_64":"linux-x64","windows-x86_64":"windows-x64"},R=`${Q.os}-${Q.arch}`,X=$[R]||"linux-x64";return`https://github.com/oven-sh/bun/releases/download/bun-v${w}/bun-${X}.zip`},getArchiveFormat(){return"zip"},getBinaries(w){return w.os==="windows"?["bun.exe"]:["bun","bunx"]},getArchivePrefix(w,Q){return{"darwin-aarch64":"bun-darwin-aarch64","darwin-x86_64":"bun-darwin-x64","linux-aarch64":"bun-linux-aarch64","linux-x86_64":"bun-linux-x64","windows-x86_64":"bun-windows-x64"}[`${Q.os}-${Q.arch}`]||"bun-linux-x64"}},"nodejs.org":{getDownloadUrl(w,Q){let $={darwin:"darwin",linux:"linux",windows:"win"},R={x86_64:"x64",aarch64:"arm64"},X=Q.os==="windows"?"zip":"tar.xz";return`https://nodejs.org/dist/v${w}/node-v${w}-${$[Q.os]}-${R[Q.arch]}.${X}`},getArchiveFormat(w){return w.os==="windows"?"zip":"tar.xz"},getBinaries(w){return w.os==="windows"?["node.exe","npm.cmd","npx.cmd"]:["node","npm","npx"]},getArchivePrefix(w,Q){let $={darwin:"darwin",linux:"linux",windows:"win"},R={x86_64:"x64",aarch64:"arm64"};return`node-v${w}-${$[Q.os]}-${R[Q.arch]}`}}};async function aQ(w,Q,$={}){let R=iQ(),X=Jw[w];if(!X)throw Error(`Unknown package: ${w}. Supported: ${Object.keys(Jw).join(", ")}`);let H=$.installDir||N.join(process.cwd(),"pantry"),q=N.join(H,".bin"),Z=N.join(H,w.replace(/\./g,"-"),Q),Y=X.getBinaries(R),J=N.join(Z,Y[0]);if(A.existsSync(J)){if(!$.quiet)console.log(` ✓ ${w}@${Q} (cached)`);return{name:w,version:Q,installPath:Z,binaries:Y}}let z=X.getDownloadUrl(Q,R),j=X.getArchiveFormat(R);if(!$.quiet)console.log(` → ${w}@${Q} from ${new URL(z).hostname}`);let T=A.mkdtempSync(N.join(n.tmpdir(),"pantry-")),O=N.join(T,`archive.${j}`);try{await YQ(z,O);let W=N.join(T,"extracted");A.mkdirSync(W,{recursive:!0}),await eQ(O,W,j);let U=W,B=X.getArchivePrefix?.(Q,R);if(B){let K=N.join(W,B);if(A.existsSync(K))U=K;else{let _=A.readdirSync(W).find((M)=>A.statSync(N.join(W,M)).isDirectory());if(_)U=N.join(W,_)}}if(A.mkdirSync(Z,{recursive:!0}),w6(U,Z),R.os!=="windows")for(let K of Y){let S=N.join(Z,K);if(A.existsSync(S))A.chmodSync(S,493);let _=N.join(Z,"bin",K);if(A.existsSync(_))A.chmodSync(_,493)}if($.createBinLinks!==!1){A.mkdirSync(q,{recursive:!0});for(let K of Y){let S=N.join(Z,K);if(!A.existsSync(S))S=N.join(Z,"bin",K);if(!A.existsSync(S))continue;let _=N.join(q,K);try{A.unlinkSync(_)}catch{}if(R.os==="windows")A.copyFileSync(S,_);else A.symlinkSync(S,_)}}if(!$.quiet)console.log(` ✓ ${w}@${Q}`);return{name:w,version:Q,installPath:Z,binaries:Y}}finally{try{A.rmSync(T,{recursive:!0,force:!0})}catch{}}}async function b$(w,Q={}){return Promise.all(w.map(($)=>aQ($.domain,$.version,Q)))}async function F$(w){if(w==="bun.sh")return((await zw("https://api.github.com/repos/oven-sh/bun/releases/latest")).tag_name||"").replace(/^bun-v/,"");if(w==="ziglang.org")return(await zw("https://ziglang.org/download/index.json")).master?.version||"";if(w==="nodejs.org"){let $=await zw("https://nodejs.org/dist/index.json");return($.find((X)=>X.lts)?.version||$[0]?.version||"").replace(/^v/,"")}throw Error(`Cannot resolve latest version for ${w}`)}function YQ(w,Q){return new Promise(($,R)=>{let X=A.createWriteStream(Q);(w.startsWith("https")?Pw.get:Dw.get)(w,(q)=>{if(q.statusCode&&q.statusCode>=300&&q.statusCode<400&&q.headers.location)return X.close(),A.unlinkSync(Q),YQ(q.headers.location,Q).then($,R);if(q.statusCode&&q.statusCode>=400)return X.close(),R(Error(`HTTP ${q.statusCode} downloading ${w}`));q.pipe(X),X.on("finish",()=>{X.close(),$()}),X.on("error",R)}).on("error",(q)=>{X.close(),R(q)})})}async function eQ(w,Q,$){if($==="zip")if(process.platform==="win32")Ww(`powershell -NoProfile -Command "Expand-Archive -Path '${w}' -DestinationPath '${Q}' -Force"`,{stdio:"pipe"});else Ww(`unzip -o -q "${w}" -d "${Q}"`,{stdio:"pipe"});else if($==="tar.xz")Ww(`tar xf "${w}" -C "${Q}"`,{stdio:"pipe"});else if($==="tar.gz")Ww(`tar xzf "${w}" -C "${Q}"`,{stdio:"pipe"});else throw Error(`Unsupported archive format: ${$}`)}function w6(w,Q){A.cpSync(w,Q,{recursive:!0})}function zw(w){return new Promise((Q,$)=>{(w.startsWith("https")?Pw.get:Dw.get)(w,{headers:{"User-Agent":"pantry-installer"}},(X)=>{if(X.statusCode&&X.statusCode>=300&&X.statusCode<400&&X.headers.location)return zw(X.headers.location).then(Q,$);let H="";X.on("data",(q)=>H+=q),X.on("end",()=>{try{Q(JSON.parse(H))}catch(q){$(q)}})}).on("error",$)})}function A$(w){return w in Jw}function x$(){return Object.keys(Jw)}export{vw as a,JQ as b,X6 as c,Z6 as d,q6 as e,fw as f,H6 as g,Y6 as h,W6 as i,z6 as j,J6 as k,K6 as l,kw as m,U6 as n,G6 as o,B6 as p,_6 as q,O6 as r,M6 as s,C6 as t,I6 as u,S6 as v,b6 as w,F6 as x,A6 as y,x6 as z,V6 as A,y6 as B,N6 as C,u6 as D,$w as E,UQ as F,v6 as G,ow as H,g as I,Rw as J,Gw as K,sw as L,f6 as M,iw as N,CQ as O,IQ as P,Ow as Q,jw as R,Tw as S,Lw as T,PQ as U,i6 as V,a6 as W,e6 as X,w$ as Y,$$ as Z,R$ as _,X$ as $,Z$ as aa,d as ba,Iw as ca,Sw as da,vQ as ea,fQ as fa,bw as ga,Fw as ha,kQ as ia,dQ as ja,Aw as ka,xw as la,gQ as ma,mQ as na,Nw as oa,uw as pa,sQ as qa,nQ as ra,tQ as sa,rQ as ta,aQ as ua,b$ as va,F$ as wa,A$ as xa,x$ as ya};
@@ -1 +1 @@
1
- import{Fa as a,Ga as b,Ha as c,Ia as d,Ja as e,Ka as f,La as g,Ma as h,Na as i,Oa as j,Pa as k,Qa as l,Ra as m,Sa as n}from"./chunk-h2pyrnjr.js";import"./chunk-xxpems7r.js";import"./chunk-jywhngj7.js";import"./chunk-04eamjdw.js";import"./chunk-sd8qadhd.js";export{i as startPeriodicCleanup,h as setupCleanupHandlers,l as scanPantryPackages,d as saveToCacheAndOutput,a as savePackageAsTypeScript,m as readPantryPackageInfo,c as getValidCachedPackage,f as fetchPkgxProjects,n as fetchPantryPackageWithMetadata,g as fetchPantryPackage,k as fetchAndSavePackage,j as fetchAndSaveAllPackages,e as cleanupBrowserResources,b as cleanStaleOutputFiles};
1
+ import{Ja as a,Ka as b,La as c,Ma as d,Na as e,Oa as f,Pa as g,Qa as h,Ra as i,Sa as j,Ta as k,Ua as l,Va as m,Wa as n}from"./chunk-f5n4jscp.js";import"./chunk-rkak2mvz.js";import"./chunk-cxg0wv4z.js";import"./chunk-9yep1cys.js";import"./chunk-z5kje5x9.js";export{i as startPeriodicCleanup,h as setupCleanupHandlers,l as scanPantryPackages,d as saveToCacheAndOutput,a as savePackageAsTypeScript,m as readPantryPackageInfo,c as getValidCachedPackage,f as fetchPkgxProjects,n as fetchPantryPackageWithMetadata,g as fetchPantryPackage,k as fetchAndSavePackage,j as fetchAndSaveAllPackages,e as cleanupBrowserResources,b as cleanStaleOutputFiles};