@visulima/vis 1.0.0-alpha.30 → 1.0.0-alpha.32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/dist/bin.js +1 -1
  3. package/dist/binx.js +1 -1
  4. package/dist/packem_chunks/bin.js +290 -290
  5. package/dist/packem_chunks/bloom-status.js +1 -1
  6. package/dist/packem_chunks/bloom-sync.js +1 -1
  7. package/dist/packem_chunks/config.js +15 -15
  8. package/dist/packem_chunks/doctor-probe.js +1 -1
  9. package/dist/packem_chunks/fix.js +1 -1
  10. package/dist/packem_chunks/handler14.js +1 -1
  11. package/dist/packem_chunks/handler15.js +1 -1
  12. package/dist/packem_chunks/handler16.js +1 -1
  13. package/dist/packem_chunks/handler21.js +1 -1
  14. package/dist/packem_chunks/handler22.js +1 -1
  15. package/dist/packem_chunks/handler23.js +1 -1
  16. package/dist/packem_chunks/handler25.js +1 -1
  17. package/dist/packem_chunks/handler27.js +1 -1
  18. package/dist/packem_chunks/handler29.js +1 -1
  19. package/dist/packem_chunks/handler32.js +1 -1
  20. package/dist/packem_chunks/handler35.js +1 -1
  21. package/dist/packem_chunks/handler36.js +1 -1
  22. package/dist/packem_chunks/handler37.js +1 -1
  23. package/dist/packem_chunks/handler38.js +1 -1
  24. package/dist/packem_chunks/handler39.js +1 -1
  25. package/dist/packem_chunks/handler4.js +1 -1
  26. package/dist/packem_chunks/handler42.js +1 -1
  27. package/dist/packem_chunks/handler43.js +1 -1
  28. package/dist/packem_chunks/handler44.js +1 -1
  29. package/dist/packem_chunks/handler45.js +1 -1
  30. package/dist/packem_chunks/handler46.js +1 -1
  31. package/dist/packem_chunks/handler47.js +1 -1
  32. package/dist/packem_chunks/handler48.js +1 -1
  33. package/dist/packem_chunks/handler49.js +1 -1
  34. package/dist/packem_chunks/handler50.js +1 -1
  35. package/dist/packem_chunks/handler51.js +37 -37
  36. package/dist/packem_chunks/handler52.js +1 -1
  37. package/dist/packem_chunks/heal.js +1 -1
  38. package/dist/packem_chunks/help-command.js +1 -1
  39. package/dist/packem_chunks/keys-refresh.js +1 -1
  40. package/dist/packem_chunks/prune.js +1 -1
  41. package/dist/packem_chunks/status.js +1 -1
  42. package/dist/packem_chunks/sync.js +1 -1
  43. package/dist/packem_chunks/verify-lockfile.js +1 -1
  44. package/dist/packem_shared/Table-3pFgIUZ2-DABgc6rj.js +12 -0
  45. package/dist/packem_shared/{advisories-BxXiKFbL.js → advisories-CGKZo9Rx.js} +1 -1
  46. package/dist/packem_shared/{cyclonedx-BpGVHqSW.js → cyclonedx-BilSFCNY.js} +1 -1
  47. package/dist/packem_shared/{docker-CTE3s4LW.js → docker-EJiTY0Sz.js} +1 -1
  48. package/dist/packem_shared/{index-D1xC1Y_R.js → index-BnANMQ7k.js} +1 -1
  49. package/dist/packem_shared/{index-hoWfZmNo.js → index-K8aQuMvx.js} +1 -1
  50. package/dist/packem_shared/{lifecycle-CXaqPGAQ.js → lifecycle-Buigdp7P.js} +2 -2
  51. package/dist/packem_shared/{osv-bloom-DSZcHLsM.js → osv-bloom-0Vu8YRhg.js} +1 -1
  52. package/dist/packem_shared/{provenance-DkCA8BrN.js → provenance-D8vU1u2L.js} +1 -1
  53. package/dist/packem_shared/{registry-keys-Mixm4eAY.js → registry-keys-E3cZn4FI.js} +1 -1
  54. package/dist/packem_shared/{resolve-explicit-D5E72FfN.js → resolve-explicit-cPzwdiEE.js} +1 -1
  55. package/dist/packem_shared/{s1ngularity-Qxc6tRRI.js → s1ngularity-DBcjspCC.js} +1 -1
  56. package/dist/packem_shared/{scan-progress-DVtCtI2z.js → scan-progress-CTVVf9WW.js} +1 -1
  57. package/dist/packem_shared/{signatures-byuFrtAH.js → signatures-ChTfrQvT.js} +1 -1
  58. package/dist/packem_shared/{typosquats-BiDxQj7R.js → typosquats-acxQ7blw.js} +1 -1
  59. package/dist/packem_shared/{watch-loop-C31Ar7BX.js → watch-loop-BpA_pxU9.js} +1 -1
  60. package/index.d.ts +201 -201
  61. package/index.js +52 -52
  62. package/package.json +10 -10
  63. package/dist/packem_shared/Table-DoSoazT6-DwnyTUsA.js +0 -12
@@ -1,2 +1,2 @@
1
- var T=Object.defineProperty;var k=(o,e)=>T(o,"name",{value:e,configurable:!0});import{createRequire as F}from"node:module";import{p as c,M as A,C as H,O as P,P as U,Q as L,U as O}from"./bin.js";import{c as D,r as z,s as C,S as G,a as $,b as M,d as q,p as B,i as b,e as V}from"../packem_shared/lifecycle-CXaqPGAQ.js";const _=F(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,I=k(o=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[e,r]=m.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return m.getBuiltinModule(o)}return _(o)},"__cjs_getBuiltinModule"),{stat:y,open:R,watch:N}=I("node:fs/promises");var W=Object.defineProperty,g=k((o,e)=>W(o,"name",{value:e,configurable:!0}),"f");const h=g(async o=>{const e=o?.plugins;if(!e||e.length===0)return;const r=D();return await z(r,e),{callHook:g(async(d,...s)=>{try{await r.callHook(d,...s)}catch(t){const n=t instanceof Error?t.message:String(t);c.warn(`Plugin error in ${d}: ${n}`)}},"callHook")}},"loadServiceHooks"),J=g(o=>{const e=o.trim(),r=e.lastIndexOf(":");if(!(r<=0||r===e.length-1))return{project:e.slice(0,r),target:e.slice(r+1)}},"splitTargetId"),j=g(async(o,e,r)=>{const d=J(r);if(!d){c.error(`Invalid target id "${r}". Expected "<project>:<target>", e.g. "@my/api:db".`);return}const s=await A(o),{projectOptions:t,workspace:n}=H(o,e,s),i=n.projects[d.project],a=t.get(d.project)?.[d.target];if(!i||!a){c.error(`Target "${r}" not found in this workspace.`);return}const p=a.options?.service;if(!p){c.error(`Target "${r}" is not a service. Add an \`options.service\` block to make it eligible for \`vis service\`.`);return}if(!a.command){c.error(`Target "${r}" has no command — services must be runnable.`);return}const f=P(o,i.root,a.options?.runFromWorkspaceRoot===!0),v=a.options?.envFile?U(f,a.options.envFile):{};return{command:a.command,cwd:f,env:{...v,...p.env},service:p,target:a,targetId:r}},"resolveTarget"),w=g(o=>{if(!o)throw new Error("Could not determine workspace root. Run `vis service` inside a workspace.");return o},"requireWorkspace"),oe=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service start <project>:<target>"),process.exitCode=1;return}const n=await j(s,r,t);if(!n){process.exitCode=1;return}try{const{entry:i}=await C({command:n.command,config:n.service,cwd:n.cwd,env:n.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await(await h(r))?.callHook("service:start",i),c.success(`Started ${t} (pid ${String(i.pid)})`),c.info(` log: ${i.logFile}`)}catch(i){const a=i instanceof Error?i.message:String(i);i instanceof G?c.error(`Readiness probe failed for ${t}: ${a}`):c.error(`Failed to start ${t}: ${a}`),process.exitCode=1}},"serviceStartExecute"),S=g(async({graceMs:o,hookSink:e,id:r,workspaceRoot:d})=>{const s=await $(d,r),{stopped:t}=await M({graceMs:o,id:r,workspaceRoot:d});return t?(s&&await e?.callHook("service:stop",s),c.success(`Stopped ${r}`),!0):(c.info(`No running service registered for ${r}`),!1)},"stopOne"),se=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),{graceMs:t}=e,n=o[0]?.trim(),i=await h(r);if(e.all===!0){if(n){c.error("Cannot combine --all with a target id. Use one or the other."),process.exitCode=1;return}const a=await q(s);if(a.length===0){c.info("No running services registered for this workspace.");return}for(const p of a)await S({graceMs:t,hookSink:i,id:p.id,workspaceRoot:s});return}if(!n){c.error("Missing target id. Usage: vis service stop <project>:<target> | --all"),process.exitCode=1;return}await S({graceMs:t,hookSink:i,id:n,workspaceRoot:s})||(process.exitCode=1)},"serviceStopExecute"),Q=g(o=>{const e=o.config.readiness?.tcp.port??o.config.port;return e===void 0?"—":String(e)},"formatPort"),E=new Set(["json","table"]),ie=g(async({logger:o,options:e,workspaceRoot:r})=>{const d=w(r),s=e.format??"table";if(!E.has(s)){c.error(`Invalid --format "${s}". Expected one of: ${[...E].sort().join(", ")}.`),process.exitCode=1;return}const{surviving:t}=await B(d);if(s==="json"){const l=Date.now();process.stdout.write(`${JSON.stringify(t.map(u=>{const x=Date.parse(u.startedAt);return{ageMs:Number.isFinite(x)?l-x:null,alive:b(u.pid),command:u.command,cwd:u.cwd,env:u.env,id:u.id,logFile:u.logFile,pid:u.pid,port:u.config.readiness?.tcp.port??u.config.port??null,startedAt:u.startedAt,visVersion:u.visVersion}}),void 0,2)}
1
+ var T=Object.defineProperty;var k=(o,e)=>T(o,"name",{value:e,configurable:!0});import{createRequire as F}from"node:module";import{p as c,M as A,C as H,O as P,P as U,Q as L,U as O}from"./bin.js";import{c as D,r as z,s as C,S as G,a as $,b as M,d as q,p as B,i as b,e as V}from"../packem_shared/lifecycle-Buigdp7P.js";const _=F(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,I=k(o=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[e,r]=m.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return m.getBuiltinModule(o)}return _(o)},"__cjs_getBuiltinModule"),{stat:y,open:R,watch:N}=I("node:fs/promises");var W=Object.defineProperty,g=k((o,e)=>W(o,"name",{value:e,configurable:!0}),"f");const h=g(async o=>{const e=o?.plugins;if(!e||e.length===0)return;const r=D();return await z(r,e),{callHook:g(async(d,...s)=>{try{await r.callHook(d,...s)}catch(t){const n=t instanceof Error?t.message:String(t);c.warn(`Plugin error in ${d}: ${n}`)}},"callHook")}},"loadServiceHooks"),J=g(o=>{const e=o.trim(),r=e.lastIndexOf(":");if(!(r<=0||r===e.length-1))return{project:e.slice(0,r),target:e.slice(r+1)}},"splitTargetId"),j=g(async(o,e,r)=>{const d=J(r);if(!d){c.error(`Invalid target id "${r}". Expected "<project>:<target>", e.g. "@my/api:db".`);return}const s=await A(o),{projectOptions:t,workspace:n}=H(o,e,s),i=n.projects[d.project],a=t.get(d.project)?.[d.target];if(!i||!a){c.error(`Target "${r}" not found in this workspace.`);return}const p=a.options?.service;if(!p){c.error(`Target "${r}" is not a service. Add an \`options.service\` block to make it eligible for \`vis service\`.`);return}if(!a.command){c.error(`Target "${r}" has no command — services must be runnable.`);return}const f=P(o,i.root,a.options?.runFromWorkspaceRoot===!0),v=a.options?.envFile?U(f,a.options.envFile):{};return{command:a.command,cwd:f,env:{...v,...p.env},service:p,target:a,targetId:r}},"resolveTarget"),w=g(o=>{if(!o)throw new Error("Could not determine workspace root. Run `vis service` inside a workspace.");return o},"requireWorkspace"),oe=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service start <project>:<target>"),process.exitCode=1;return}const n=await j(s,r,t);if(!n){process.exitCode=1;return}try{const{entry:i}=await C({command:n.command,config:n.service,cwd:n.cwd,env:n.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await(await h(r))?.callHook("service:start",i),c.success(`Started ${t} (pid ${String(i.pid)})`),c.info(` log: ${i.logFile}`)}catch(i){const a=i instanceof Error?i.message:String(i);i instanceof G?c.error(`Readiness probe failed for ${t}: ${a}`):c.error(`Failed to start ${t}: ${a}`),process.exitCode=1}},"serviceStartExecute"),S=g(async({graceMs:o,hookSink:e,id:r,workspaceRoot:d})=>{const s=await $(d,r),{stopped:t}=await M({graceMs:o,id:r,workspaceRoot:d});return t?(s&&await e?.callHook("service:stop",s),c.success(`Stopped ${r}`),!0):(c.info(`No running service registered for ${r}`),!1)},"stopOne"),se=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),{graceMs:t}=e,n=o[0]?.trim(),i=await h(r);if(e.all===!0){if(n){c.error("Cannot combine --all with a target id. Use one or the other."),process.exitCode=1;return}const a=await q(s);if(a.length===0){c.info("No running services registered for this workspace.");return}for(const p of a)await S({graceMs:t,hookSink:i,id:p.id,workspaceRoot:s});return}if(!n){c.error("Missing target id. Usage: vis service stop <project>:<target> | --all"),process.exitCode=1;return}await S({graceMs:t,hookSink:i,id:n,workspaceRoot:s})||(process.exitCode=1)},"serviceStopExecute"),Q=g(o=>{const e=o.config.readiness?.tcp.port??o.config.port;return e===void 0?"—":String(e)},"formatPort"),E=new Set(["json","table"]),ie=g(async({logger:o,options:e,workspaceRoot:r})=>{const d=w(r),s=e.format??"table";if(!E.has(s)){c.error(`Invalid --format "${s}". Expected one of: ${[...E].sort().join(", ")}.`),process.exitCode=1;return}const{surviving:t}=await B(d);if(s==="json"){const l=Date.now();process.stdout.write(`${JSON.stringify(t.map(u=>{const x=Date.parse(u.startedAt);return{ageMs:Number.isFinite(x)?l-x:null,alive:b(u.pid),command:u.command,cwd:u.cwd,env:u.env,id:u.id,logFile:u.logFile,pid:u.pid,port:u.config.readiness?.tcp.port??u.config.port??null,startedAt:u.startedAt,visVersion:u.visVersion}}),void 0,2)}
2
2
  `);return}if(t.length===0){c.info("No running services registered for this workspace.");return}const n=Date.now(),i=t.map(l=>{const u=Date.parse(l.startedAt);return{age:Number.isFinite(u)?L(u,n):"?",id:l.id,log:l.logFile,pid:String(l.pid),port:Q(l)}}),a=Math.max(2,...i.map(l=>l.id.length)),p=Math.max(3,...i.map(l=>l.pid.length)),f=Math.max(4,...i.map(l=>l.port.length)),v=Math.max(3,...i.map(l=>l.age.length));o.info(` ${"id".padEnd(a)} ${"pid".padEnd(p)} ${"port".padEnd(f)} ${"age".padEnd(v)} log`),o.info(` ${"-".repeat(a)} ${"-".repeat(p)} ${"-".repeat(f)} ${"-".repeat(v)} ---`);for(const l of i)o.info(` ${l.id.padEnd(a)} ${l.pid.padEnd(p)} ${l.port.padEnd(f)} ${l.age.padEnd(v)} ${l.log}`)},"serviceListExecute"),ae=g(async({argument:o,options:e,workspaceRoot:r})=>{const d=w(r),s=o[0]?.trim();if(!s){c.error("Missing target id. Usage: vis service status <project>:<target>"),process.exitCode=1;return}const t=await $(d,s);if(!t){c.error(`No service registered for ${s}.`),process.exitCode=1;return}if(!b(t.pid)){c.error(`Service ${s} is not running (pid ${String(t.pid)} is dead). Run \`vis service start ${s}\` to recover.`),process.exitCode=1;return}try{await V(t.config,{timeoutMs:e.timeout}),c.success(`${s} healthy (pid ${String(t.pid)})`)}catch(n){const i=n instanceof Error?n.message:String(n);c.error(`${s} probe failed: ${i}`),process.exitCode=1}},"serviceStatusExecute"),ne=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service restart <project>:<target>"),process.exitCode=1;return}const n=await h(r),i=await $(s,t);(await M({graceMs:e.graceMs,id:t,workspaceRoot:s})).stopped&&i&&await n?.callHook("service:stop",i);const a=await j(s,r,t);if(!a){process.exitCode=1;return}try{const{entry:p}=await C({command:a.command,config:a.service,cwd:a.cwd,env:a.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await n?.callHook("service:start",p),c.success(`Restarted ${t} (pid ${String(p.pid)})`)}catch(p){const f=p instanceof Error?p.message:String(p);c.error(`Failed to restart ${t}: ${f}`),process.exitCode=1}},"serviceRestartExecute"),K=200,X=1024*1024,Y=g(async o=>{let e=0;try{e=(await y(o)).size}catch{e=0}const r=new AbortController;let d=!1;const s=g(()=>{d=!0,r.abort()},"onSigint"),t=g(()=>{r.abort()},"onSigterm");process.on("SIGINT",s),process.on("SIGTERM",t);let n=!1;const i=g(async()=>{if(!n){n=!0;try{const a=await y(o).catch(()=>{});if(!a||(a.size<e&&(e=0),a.size===e))return;const p=a.size-e,f=Math.min(p,X),v=await R(o,"r");try{const l=Buffer.alloc(f);await v.read(l,0,f,e),process.stdout.write(l),e+=f}finally{await v.close().catch(()=>{})}}finally{n=!1}}},"tickOnce");try{const a=(async()=>{try{const p=N(o,{signal:r.signal});for(;!(await p.next()).done;)await i()}catch{}})();for(;!r.signal.aborted;)await i(),await new Promise(p=>{const f=setTimeout(p,K);r.signal.addEventListener("abort",()=>{clearTimeout(f),p()},{once:!0})});await a.catch(()=>{}),await i().catch(()=>{})}finally{process.off("SIGINT",s),process.off("SIGTERM",t)}d&&(process.exitCode=130)},"tailLog"),ce=g(async({argument:o,options:e,workspaceRoot:r})=>{const d=w(r),s=o[0]?.trim();if(!s){c.error("Missing target id. Usage: vis service logs <project>:<target>"),process.exitCode=1;return}const t=await $(d,s);if(!t){c.error(`No service registered for ${s}.`),process.exitCode=1;return}if(!await O(t.logFile)){c.warn(`Log file is missing for ${s}: ${t.logFile}`),process.exitCode=1;return}if(e.follow===!0){await Y(t.logFile);return}const n=await R(t.logFile,"r");try{const i=n.createReadStream();await new Promise((a,p)=>{i.on("end",a),i.on("error",p),i.pipe(process.stdout,{end:!1})})}finally{await n.close().catch(()=>{})}},"serviceLogsExecute");export{ie as serviceListExecute,ce as serviceLogsExecute,ne as serviceRestartExecute,oe as serviceStartExecute,ae as serviceStatusExecute,se as serviceStopExecute};
@@ -1 +1 @@
1
- var R=Object.defineProperty;var $=(e,t)=>R(e,"name",{value:t,configurable:!0});import{createRequire as T}from"node:module";import{I as f,T as b,E as x,e as _}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{l as V,M as F}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{s as I}from"./config.js";import{enforceProjectConstraints as P}from"@visulima/task-runner";import{C as z,S as A,W as B,A as E}from"./bin.js";import{c as J}from"../packem_shared/runtime-check-CilFOqUU.js";const w=T(import.meta.url),n=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,M=$(e=>{if(typeof n<"u"&&n.versions&&n.versions.node){const[t,i]=n.versions.node.split(".").map(Number);if(t>22||t===22&&i>=3||t===20&&i>=16)return n.getBuiltinModule(e)}return w(e)},"__cjs_getBuiltinModule"),{readdirSync:q}=M("node:fs");var K=Object.defineProperty,v=$((e,t)=>K(e,"name",{value:t,configurable:!0}),"h");const r=v(e=>e?f("✓"):b("✗"),"icon"),X=v(async({logger:e,options:t,visConfig:i,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root.");const{config:j,packageJsons:C,workspace:u}=z(s,i),O=A(s,u,C),y=Object.keys(u.projects).length,S=new Set(Object.values(u.projects).flatMap(p=>Object.keys(p.targets??{}))).size,a=J(s);let o=0;j.constraints&&(o=P(O,j.constraints).length);const c=B(s,{minRuns:2});let l;const g=E(s);if(V(g)){const p=q(g).filter(h=>h.endsWith(".json")).sort();let m=0,k=0;for(const h of p.slice(-20))try{const d=I(F(g,h));d.stats&&(m+=d.stats.total??0,k+=d.stats.cached??0)}catch{continue}m>0&&(l=`${(k/m*100).toFixed(0)}%`)}if(t.json){e.info(JSON.stringify({cacheHitRate:l??null,constraintViolations:o,flakyTasks:c.length,projects:y,runtimeIssues:a.length,targets:S},null,2));return}e.info(""),e.info(` ${x("VIS STATUS")}`),e.info(""),e.info(` ${r(!0)} ${String(y)} projects · ${String(S)} unique targets`),e.info(` ${r(a.length===0)} Runtime: ${a.length===0?f("OK"):_(`${String(a.length)} issue(s)`)}`),e.info(` ${r(o===0)} Constraints: ${o===0?f("OK"):b(`${String(o)} violation(s)`)}`),e.info(` ${r(c.length===0)} Flaky tasks: ${c.length===0?f("none"):_(String(c.length))}`),l&&e.info(` ${r(!0)} Cache hit rate: ${l} (last 20 runs)`),e.info("")},"execute");export{X as default};
1
+ var R=Object.defineProperty;var $=(e,t)=>R(e,"name",{value:t,configurable:!0});import{createRequire as T}from"node:module";import{I as f,T as b,E as x,e as _}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{l as V,M as F}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{s as I}from"./config.js";import{enforceProjectConstraints as P}from"@visulima/task-runner";import{C as z,S as A,W as B,A as E}from"./bin.js";import{c as J}from"../packem_shared/runtime-check-CilFOqUU.js";const w=T(import.meta.url),n=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,M=$(e=>{if(typeof n<"u"&&n.versions&&n.versions.node){const[t,i]=n.versions.node.split(".").map(Number);if(t>22||t===22&&i>=3||t===20&&i>=16)return n.getBuiltinModule(e)}return w(e)},"__cjs_getBuiltinModule"),{readdirSync:q}=M("node:fs");var K=Object.defineProperty,v=$((e,t)=>K(e,"name",{value:t,configurable:!0}),"h");const r=v(e=>e?f("✓"):b("✗"),"icon"),X=v(async({logger:e,options:t,visConfig:i,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root.");const{config:j,packageJsons:C,workspace:u}=z(s,i),O=A(s,u,C),y=Object.keys(u.projects).length,S=new Set(Object.values(u.projects).flatMap(p=>Object.keys(p.targets??{}))).size,a=J(s);let o=0;j.constraints&&(o=P(O,j.constraints).length);const c=B(s,{minRuns:2});let l;const g=E(s);if(V(g)){const p=q(g).filter(h=>h.endsWith(".json")).sort();let m=0,k=0;for(const h of p.slice(-20))try{const d=I(F(g,h));d.stats&&(m+=d.stats.total??0,k+=d.stats.cached??0)}catch{continue}m>0&&(l=`${(k/m*100).toFixed(0)}%`)}if(t.json){e.info(JSON.stringify({cacheHitRate:l??null,constraintViolations:o,flakyTasks:c.length,projects:y,runtimeIssues:a.length,targets:S},null,2));return}e.info(""),e.info(` ${x("VIS STATUS")}`),e.info(""),e.info(` ${r(!0)} ${String(y)} projects · ${String(S)} unique targets`),e.info(` ${r(a.length===0)} Runtime: ${a.length===0?f("OK"):_(`${String(a.length)} issue(s)`)}`),e.info(` ${r(o===0)} Constraints: ${o===0?f("OK"):b(`${String(o)} violation(s)`)}`),e.info(` ${r(c.length===0)} Flaky tasks: ${c.length===0?f("none"):_(String(c.length))}`),l&&e.info(` ${r(!0)} Cache hit rate: ${l} (last 20 runs)`),e.info("")},"execute");export{X as default};
@@ -1,4 +1,4 @@
1
- var P=Object.defineProperty;var x=(e,n)=>P(e,"name",{value:n,configurable:!0});import{createRequire as I}from"node:module";import{I as W,T as A,e as N,E as d}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{M as B}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{p as o}from"./bin.js";import{S as w,g as E,w as k,b as q,p as H,f as M,a as j,c as O,u as C,d as K,e as L,h as D}from"../packem_shared/toolchain-DoG6b_G_.js";const S=I(import.meta.url),$=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,b=x(e=>{if(typeof $<"u"&&$.versions&&$.versions.node){const[n,t]=$.versions.node.split(".").map(Number);if(n>22||n===22&&t>=3||n===20&&t>=16)return $.getBuiltinModule(e)}return S(e)},"__cjs_getBuiltinModule"),{spawnSync:F}=b("node:child_process"),{writeFileSync:U}=b("node:fs");var G=Object.defineProperty,u=x((e,n)=>G(e,"name",{value:n,configurable:!0}),"u");const y=["aube","bun","deno","go","node","npm","pnpm","python","ruby","rust","yarn"],J=u(e=>y.includes(e),"isKnownTool"),v=u(e=>e?W("✓"):A("✗"),"icon"),R=N("⚠"),z=u(e=>{if(e.installed){const n=e.version?` v${e.version}`:"",t=e.configFiles.length>0?` (${e.configFiles.join(", ")})`:"";return`${v(!0)} ${e.name}${n}${t}`}return`${R} ${e.name} — referenced by ${e.configFiles.join(", ")} but not installed`},"renderManagerLine"),Q=u(e=>{if(e.matches)return"";const{manager:n}=e;return n.name==="none"?d("→ (no manager)"):n.name==="self-activate"?"":n.installed?d(`→ ${n.name}`):d(`→ ${n.name} (missing)`)},"renderToolManager"),V=u(e=>e.matches?v(!0):e.actual?R:v(!1),"toolIcon"),X=u(e=>{if(o.info(""),o.info(d("── Toolchain ───────────────────────")),e.detected.length===0)o.info(` ${v(!1)} No version manager detected`),o.notice(` Install one of: ${w.join(", ")}`);else for(const n of e.detected)o.info(` ${z(n)}`);if(o.info(""),e.tools.length===0){o.info(` ${d("No tool pins found — add engines.node, .nvmrc, or a manager config file.")}`);return}o.info(d("── Tools ───────────────────────────"));for(const n of e.tools){const t=`${n.expected.tool} ${n.expected.version}`,a=n.actual?`actual ${n.actual}`:"not installed",i=n.matches?"":d(` [${n.expected.source}]`),s=Q(n),f=s===""?"":` ${s}`;o.info(` ${V(n)} ${t} — ${a}${i}${f}`),n.manager.note&&o.notice(` ${n.manager.note}`)}},"printStatus"),Y=u((e,n,t)=>{const a=E(e,n);if(t.json){process.stdout.write(`${JSON.stringify({detected:a.detected.map(s=>({binPath:s.binPath??null,configFiles:s.configFiles,installed:s.installed,name:s.name,version:s.version??null})),tools:a.tools.map(s=>({actual:s.actual??null,expected:s.expected.version,manager:s.manager.name,managerInstalled:s.manager.installed,matches:s.matches,note:s.manager.note??null,source:s.expected.source,tool:s.expected.tool}))},void 0,2)}
1
+ var P=Object.defineProperty;var x=(e,n)=>P(e,"name",{value:n,configurable:!0});import{createRequire as I}from"node:module";import{I as W,T as A,e as N,E as d}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{M as B}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{p as o}from"./bin.js";import{S as w,g as E,w as k,b as q,p as H,f as M,a as j,c as O,u as C,d as K,e as L,h as D}from"../packem_shared/toolchain-DoG6b_G_.js";const S=I(import.meta.url),$=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,b=x(e=>{if(typeof $<"u"&&$.versions&&$.versions.node){const[n,t]=$.versions.node.split(".").map(Number);if(n>22||n===22&&t>=3||n===20&&t>=16)return $.getBuiltinModule(e)}return S(e)},"__cjs_getBuiltinModule"),{spawnSync:F}=b("node:child_process"),{writeFileSync:U}=b("node:fs");var G=Object.defineProperty,u=x((e,n)=>G(e,"name",{value:n,configurable:!0}),"u");const y=["aube","bun","deno","go","node","npm","pnpm","python","ruby","rust","yarn"],J=u(e=>y.includes(e),"isKnownTool"),v=u(e=>e?W("✓"):A("✗"),"icon"),R=N("⚠"),z=u(e=>{if(e.installed){const n=e.version?` v${e.version}`:"",t=e.configFiles.length>0?` (${e.configFiles.join(", ")})`:"";return`${v(!0)} ${e.name}${n}${t}`}return`${R} ${e.name} — referenced by ${e.configFiles.join(", ")} but not installed`},"renderManagerLine"),Q=u(e=>{if(e.matches)return"";const{manager:n}=e;return n.name==="none"?d("→ (no manager)"):n.name==="self-activate"?"":n.installed?d(`→ ${n.name}`):d(`→ ${n.name} (missing)`)},"renderToolManager"),V=u(e=>e.matches?v(!0):e.actual?R:v(!1),"toolIcon"),X=u(e=>{if(o.info(""),o.info(d("── Toolchain ───────────────────────")),e.detected.length===0)o.info(` ${v(!1)} No version manager detected`),o.notice(` Install one of: ${w.join(", ")}`);else for(const n of e.detected)o.info(` ${z(n)}`);if(o.info(""),e.tools.length===0){o.info(` ${d("No tool pins found — add engines.node, .nvmrc, or a manager config file.")}`);return}o.info(d("── Tools ───────────────────────────"));for(const n of e.tools){const t=`${n.expected.tool} ${n.expected.version}`,a=n.actual?`actual ${n.actual}`:"not installed",i=n.matches?"":d(` [${n.expected.source}]`),s=Q(n),f=s===""?"":` ${s}`;o.info(` ${V(n)} ${t} — ${a}${i}${f}`),n.manager.note&&o.notice(` ${n.manager.note}`)}},"printStatus"),Y=u((e,n,t)=>{const a=E(e,n);if(t.json){process.stdout.write(`${JSON.stringify({detected:a.detected.map(s=>({binPath:s.binPath??null,configFiles:s.configFiles,installed:s.installed,name:s.name,version:s.version??null})),tools:a.tools.map(s=>({actual:s.actual??null,expected:s.expected.version,manager:s.manager.name,managerInstalled:s.manager.installed,matches:s.matches,note:s.manager.note??null,source:s.expected.source,tool:s.expected.tool}))},void 0,2)}
2
2
  `);return}X(a);const i=a.tools.filter(s=>!s.matches);i.length>0&&(o.info(""),o.notice(" Run `vis toolchain install` to install pinned versions.")),t.exitCode&&i.length>0&&(process.exitCode=1)},"executeStatus"),Z=u(e=>{const n=new Map;for(const t of e){const a=n.get(t.manager.name);a?a.push(t):n.set(t.manager.name,[t])}return n},"groupByManager"),T=u((e,n,t)=>F(e,n,{cwd:t,stdio:"inherit"}).status??1,"runInvocation"),ee=u((e,n,t)=>{const a=E(e,n),i=a.tools.filter(c=>!c.matches);if(i.length===0){o.success("Everything already matches — nothing to install.");return}const s=i.some(c=>c.manager.name!=="self-activate"&&c.manager.name!=="none");if(a.detected.length===0&&s){o.error(`No version manager detected. Install one of: ${w.join(", ")}.`),process.exitCode=1;return}const f=Z(i);let l=!1,g=0;for(const[c,m]of f){if(c==="self-activate"){for(const{expected:r}of m){if(r.source==="packageManager")o.info(`${d("$")} (${r.tool} will self-activate from packageManager on next invocation)`);else if(o.info(`${d("$")} Writing packageManager=${r.tool}@${r.version}`),t.dryRun)l=!0;else try{k(e,r),l=!0}catch(h){o.error(h.message),g=1}o.notice(` ${r.tool} ${r.version} — no install needed`)}continue}if(c==="none"){for(const{expected:r}of m)o.warn(`Cannot install ${r.tool} ${r.version} — no manager can handle it.`);g=1;continue}if(!a.detected.find(r=>r.name===c)?.installed){o.error(`${c} is referenced but not on PATH — install it first, then rerun \`vis toolchain install\`.`),g=1;continue}const _=m.map(r=>q(c,r.expected)).filter(Boolean);for(const r of _){if(!r)continue;if(r.bin==="nvm"&&r.args.length===0){o.error("nvm is a shell function — run `nvm install` in your shell, then rerun `vis toolchain install`."),r.hint&&o.notice(` ${r.hint}`),g=1;continue}if(o.info(`${d("$")} ${r.bin} ${r.args.join(" ")}`),r.hint&&o.notice(` ${r.hint}`),t.dryRun){l=!0;continue}const h=T(r.bin,r.args,e);if(l=!0,h!==0){g=h;break}}}if(g!==0){process.exitCode=g;return}l&&o.success("Toolchain installed.")},"executeInstall"),ne=u((e,n,t,a)=>{if(!t)throw new Error("Usage: vis toolchain use <tool>@<version> (e.g. vis toolchain use node@22.13.0)");const i=H(t);if(!i)throw new Error(`Could not parse "${t}". Expected "<tool>@<version>" where <tool> is one of ${y.join(", ")}.`);const s=M(e),f=j(i,s,n);if(f.name==="none"){o.error(`No manager can pin ${i.tool}. Install one of: ${w.join(", ")}.`),process.exitCode=1;return}if(!f.installed){o.error(`The best manager for ${i.tool} (${f.name}) is not on PATH. ${f.note??""}`),process.exitCode=1;return}const l=O(f.name,i);if(!l){o.error(`${f.name} cannot pin ${i.tool}. Use a different manager, or set \`toolchain.tools.${i.tool}\` in vis.config.ts.`),process.exitCode=1;return}if(f.name==="self-activate"){if(o.info(`${d("→")} Writing packageManager field to package.json...`),a.dryRun){o.notice(` Would set packageManager: "${i.tool}@${i.version}"`);return}try{const c=k(e,i);if(!c){o.error(`Refusing to pin non-package-manager tool ${i.tool} via the packageManager field.`),process.exitCode=1;return}if(o.success(`Set packageManager: "${c}" — ${i.tool} will activate this version on next invocation.`),a.engines!==!1){const m=C(e,i);m&&o.success(`Updated package.json engines.${i.tool} → ${m}.`)}}catch(c){o.error(c.message),process.exitCode=1}return}if(l.args.length===0&&f.name==="nvm"&&i.tool==="node"){const c=B(e,".nvmrc");if(o.info(`${d("→")} Writing ${c}...`),a.dryRun){o.notice(` Would write ${i.version} to .nvmrc`);return}try{U(c,`${i.version}
3
3
  `)}catch(m){o.error(`Failed to write .nvmrc: ${m.message}`),process.exitCode=1;return}o.success(`Wrote ${i.version} to .nvmrc.`),o.notice(" nvm is a shell function — run `nvm use` to activate it in this shell.");return}if(l.args.length===0){o.error(`${f.name} cannot pin ${i.tool} from a subprocess. ${l.configChange?.hint??""}`),l.configChange&&o.notice(` Edit ${l.configChange.file} by hand and rerun \`vis toolchain status\` to verify.`),process.exitCode=1;return}if(o.info(`${d("$")} ${l.bin} ${l.args.join(" ")}`),l.configChange&&o.notice(` Will update ${l.configChange.file} — ${l.configChange.hint}`),a.dryRun)return;const g=T(l.bin,l.args,e);if(g!==0){process.exitCode=g;return}if(o.success(`Pinned ${i.tool} to ${i.version}.`),a.engines!==!1)try{const c=C(e,i);c&&o.success(`Updated package.json engines.${i.tool} → ${c}.`)}catch(c){o.warn(`Could not update engines.${i.tool}: ${c.message}`)}},"executeUse"),oe=u((e,n,t)=>{if(!t)throw new Error("Usage: vis toolchain which <tool> (e.g. vis toolchain which node)");const a=t.toLowerCase();if(!J(a))throw new Error(`Unknown tool "${t}". Known: ${y.join(", ")}.`);const i=M(e),s=j({source:"vis.config.ts",tool:a,version:"*"},i,n),f=s.installed&&s.name!=="self-activate"&&s.name!=="none"?i.find(g=>g.name===s.name):void 0,l=f?K(f,a):L(a);if(!l){o.error(`${t} not found in PATH${f?` or via ${f.name}`:""}.`),process.exitCode=1;return}process.stdout.write(`${l}
4
4
  `)},"executeWhich"),te=u((e,n)=>{const t=D(e,n);process.stdout.write(`${t.name}
@@ -1,3 +1,3 @@
1
- var a=Object.defineProperty;var s=(n,e)=>a(n,"name",{value:e,configurable:!0});import{createRequire as f}from"node:module";import{m as v}from"../packem_shared/index-hoWfZmNo.js";const d=f(import.meta.url),t=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,l=s(n=>{if(typeof t<"u"&&t.versions&&t.versions.node){const[e,r]=t.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return t.getBuiltinModule(n)}return d(n)},"__cjs_getBuiltinModule"),{execSync:p,spawnSync:m}=l("node:child_process");var g=Object.defineProperty,y=s((n,e)=>g(n,"name",{value:e,configurable:!0}),"r");const w=y(async({argument:n,logger:e,options:r})=>{const c=n?.[0];e.info("info: checking for updates...");const o=v.version;let i;try{const u=p("npm view @visulima/vis version",{encoding:"utf8"}).trim();i=c??u}catch{throw new Error("Failed to query npm registry. Check your network connection.")}if(o===i&&!r.force){e.info(`
1
+ var a=Object.defineProperty;var s=(n,e)=>a(n,"name",{value:e,configurable:!0});import{createRequire as f}from"node:module";import{m as v}from"../packem_shared/index-K8aQuMvx.js";const d=f(import.meta.url),t=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,l=s(n=>{if(typeof t<"u"&&t.versions&&t.versions.node){const[e,r]=t.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return t.getBuiltinModule(n)}return d(n)},"__cjs_getBuiltinModule"),{execSync:p,spawnSync:m}=l("node:child_process");var g=Object.defineProperty,y=s((n,e)=>g(n,"name",{value:e,configurable:!0}),"r");const w=y(async({argument:n,logger:e,options:r})=>{const c=n?.[0];e.info("info: checking for updates...");const o=v.version;let i;try{const u=p("npm view @visulima/vis version",{encoding:"utf8"}).trim();i=c??u}catch{throw new Error("Failed to query npm registry. Check your network connection.")}if(o===i&&!r.force){e.info(`
2
2
  ✓ Already up to date (${o})`);return}if(r.check){o===i?e.info(`✓ Already up to date (${o})`):e.info(`info: found @visulima/vis@${i} (current: ${o})`);return}if(e.info(`info: found @visulima/vis@${i} (current: ${o})`),e.info("info: installing..."),m("npm",["install","-g",`@visulima/vis@${i}`],{encoding:"utf8",stdio:"inherit"}).status!==0)throw new Error("Failed to update. Try running with sudo or fix npm permissions.");e.info(`
3
3
  ✓ Updated @visulima/vis from ${o} → ${i}`)},"execute");export{w as default};
@@ -1,4 +1,4 @@
1
- var x=Object.defineProperty;var l=(e,o)=>x(e,"name",{value:o,configurable:!0});import{b as h,h as E,_ as S,R as v}from"../packem_shared/ai-analysis-KP8b5lc0.js";import{d as w,R as D,y as P}from"./bin.js";import{j as I,E as d,q as R,I as j,e as N}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";var C=Object.defineProperty,u=l((e,o)=>C(e,"name",{value:o,configurable:!0}),"s");const f={command:"ai",description:"AI-assisted commands: provider detection, cache management, and failure-fix proposals."},O=u(e=>{if(typeof e!="function")return String(e);const{name:o}=e;return o==="Boolean"?"boolean":o==="Number"?"number":o==="String"?"string":o??"unknown"},"typeName"),A=u(e=>{const o=[...e.commandPath??[],e.name].join(" "),i=(e.examples??[]).map(([a,s])=>({command:a??"",description:s??""})),t=(e.options??[]).map(a=>({defaultValue:a.defaultValue,description:a.description,name:a.name,type:O(a.type)}));return{argument:e.argument?{description:e.argument.description,name:e.argument.name}:void 0,description:e.description??"",examples:i,name:e.name,options:t,path:o}},"buildSubcommand"),g=u((e,o=f)=>({command:o.command,description:o.description,subcommands:e.map(i=>A(i))}),"buildDiscoveryPayload"),J=u((e,o=f)=>`${JSON.stringify(g(e,o),void 0,2)}
1
+ var x=Object.defineProperty;var l=(e,o)=>x(e,"name",{value:o,configurable:!0});import{b as h,h as E,_ as S,R as v}from"../packem_shared/ai-analysis-KP8b5lc0.js";import{d as w,R as D,y as P}from"./bin.js";import{j as I,E as d,q as R,I as j,e as N}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";var C=Object.defineProperty,u=l((e,o)=>C(e,"name",{value:o,configurable:!0}),"s");const f={command:"ai",description:"AI-assisted commands: provider detection, cache management, and failure-fix proposals."},O=u(e=>{if(typeof e!="function")return String(e);const{name:o}=e;return o==="Boolean"?"boolean":o==="Number"?"number":o==="String"?"string":o??"unknown"},"typeName"),A=u(e=>{const o=[...e.commandPath??[],e.name].join(" "),i=(e.examples??[]).map(([a,s])=>({command:a??"",description:s??""})),t=(e.options??[]).map(a=>({defaultValue:a.defaultValue,description:a.description,name:a.name,type:O(a.type)}));return{argument:e.argument?{description:e.argument.description,name:e.argument.name}:void 0,description:e.description??"",examples:i,name:e.name,options:t,path:o}},"buildSubcommand"),g=u((e,o=f)=>({command:o.command,description:o.description,subcommands:e.map(i=>A(i))}),"buildDiscoveryPayload"),J=u((e,o=f)=>`${JSON.stringify(g(e,o),void 0,2)}
2
2
  `,"renderDiscoveryJson"),T=u((e,o=f)=>{const i=g(e,o),t=[I(`vis ${i.command} — ${i.description}`),"",d("Subcommands:")];for(const a of i.subcommands){const s=a.argument?` ${R(`<${a.argument.name}>`)}`:"";if(t.push(""),t.push(` ${j(`vis ${a.path}`)}${s}`),a.description&&t.push(` ${a.description}`),a.options.length>0){const n=a.options.map(c=>`--${c.name}${c.type==="boolean"?"":`=<${c.type}>`}`).join(", ");t.push(d(` options: ${n}`))}if(a.examples.length>0){t.push(d(" examples:"));for(const n of a.examples){const c=n.description?d(` — ${n.description}`):"";t.push(` ${N(n.command)}${c}`)}}}return t.push(""),t.push(d(`Run \`vis ${i.command} discover-help\` for the machine-readable JSON catalogue (designed for AI agents).`)),t.push(d(`Run \`vis ${i.command} <subcommand> --help\` for full usage of a specific subcommand.`)),`${t.join(`
3
3
  `)}
4
4
  `},"renderDiscoveryText");var F=Object.defineProperty,p=l((e,o)=>F(e,"name",{value:o,configurable:!0}),"r");const y=p(async()=>{const{default:e}=await import("./bin.js").then(o=>o.c6);return e.filter(o=>o.name!=="ai")},"loadDiscoverableSubcommands"),q=p(async()=>{const e=await y();process.stderr.write(T(e))},"aiRootExecute"),B=p(async()=>{const e=await y();process.stdout.write(J(e))},"aiDiscoverHelpExecute"),K=p(async({logger:e,visConfig:o})=>{const i=o?.ai,t=h(i);if(!t){e.error("No AI provider available to test."),process.exitCode=1;return}e.info(`Testing ${t.name}...`);try{const a=await E(t,"Reply with exactly: OK",{timeoutMs:3e4});e.info(`Provider ${t.name} responded: ${a.stdout.trim().slice(0,200)}`)}catch(a){const s=a instanceof Error?a.message:String(a);e.error(`Provider ${t.name} failed: ${s}`),process.exitCode=1}},"aiTestExecute"),L=p(({logger:e,options:o,visConfig:i})=>{const t=o.format??"table",a=i?.ai,s=S(),n=h(a);if(t==="json"){const r=s.map(m=>({available:m.available,method:m.detectionMethod,name:m.name,path:m.path,priority:v[m.name]??0,selected:m.name===n?.name,version:m.version}));process.stdout.write(`${JSON.stringify(r,void 0,2)}
@@ -1,4 +1,4 @@
1
- var m=Object.defineProperty;var g=(e,t)=>m(e,"name",{value:t,configurable:!0});import{E as v}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{M as w}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";var $=Object.defineProperty,u=g((e,t)=>$(e,"name",{value:t,configurable:!0}),"c");const h={docker:".dockerignore",npm:".npmignore",slug:".slugignore",vercel:".vercelignore"},E=[".git",".gitattributes",".gitignore",".editorconfig",".vscode/",".idea/",".DS_Store","*.md","LICENSE*","LICENCE*","CHANGELOG*","CONTRIBUTING*","AUTHORS*","docs/","doc/","examples/","example/",".github/",".gitlab-ci.yml",".circleci/","appveyor.yml",".eslintrc*","eslint.config.*",".prettierrc*","prettier.config.*","*.log","npm-debug.log*","*.d.ts","*.map","*.flow","tsconfig*.json","__tests__/","__mocks__/","test/","tests/","*.test.*","*.spec.*","coverage/",".nyc_output/"],_={docker:["node_modules",".vis/","Dockerfile*",".dockerignore"],npm:[],slug:["node_modules"],vercel:["node_modules",".vercel/"]},y=u(e=>{const t=new Set,o=[];for(const r of[...E,..._[e]])t.has(r)||(t.add(r),o.push(r));return o},"buildIgnorePatterns"),I=u(e=>e.trim(),"normalizeLine"),b="# Added by vis ignore",k=u((e,t)=>{const o=new Set;for(const n of e.split(/\r?\n/u)){const c=I(n);c!==""&&!c.startsWith("#")&&o.add(c)}const r=[];for(const n of t)o.has(n)||(o.add(n),r.push(n));if(r.length===0)return{added:r,content:e};const s=e.includes(`\r
1
+ var m=Object.defineProperty;var g=(e,t)=>m(e,"name",{value:t,configurable:!0});import{E as v}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{M as w}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";var $=Object.defineProperty,u=g((e,t)=>$(e,"name",{value:t,configurable:!0}),"c");const h={docker:".dockerignore",npm:".npmignore",slug:".slugignore",vercel:".vercelignore"},E=[".git",".gitattributes",".gitignore",".editorconfig",".vscode/",".idea/",".DS_Store","*.md","LICENSE*","LICENCE*","CHANGELOG*","CONTRIBUTING*","AUTHORS*","docs/","doc/","examples/","example/",".github/",".gitlab-ci.yml",".circleci/","appveyor.yml",".eslintrc*","eslint.config.*",".prettierrc*","prettier.config.*","*.log","npm-debug.log*","*.d.ts","*.map","*.flow","tsconfig*.json","__tests__/","__mocks__/","test/","tests/","*.test.*","*.spec.*","coverage/",".nyc_output/"],_={docker:["node_modules",".vis/","Dockerfile*",".dockerignore"],npm:[],slug:["node_modules"],vercel:["node_modules",".vercel/"]},y=u(e=>{const t=new Set,o=[];for(const r of[...E,..._[e]])t.has(r)||(t.add(r),o.push(r));return o},"buildIgnorePatterns"),I=u(e=>e.trim(),"normalizeLine"),b="# Added by vis ignore",k=u((e,t)=>{const o=new Set;for(const n of e.split(/\r?\n/u)){const c=I(n);c!==""&&!c.startsWith("#")&&o.add(c)}const r=[];for(const n of t)o.has(n)||(o.add(n),r.push(n));if(r.length===0)return{added:r,content:e};const s=e.includes(`\r
2
2
  `)?`\r
3
3
  `:`
4
4
  `,d=[b,...r].join(s);if(e.trim()==="")return{added:r,content:`${d}${s}`};const i=e.endsWith(`
@@ -1,4 +1,4 @@
1
- var X=Object.defineProperty;var w=(e,o)=>X(e,"name",{value:o,configurable:!0});import{createRequire as Q}from"node:module";import{q as S,E as m,j as R,e as F,T as H,I as E}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{M as b,a as M,l as ee}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{m as B,s as oe,C as q,S as te}from"./bin.js";import{d as ne}from"../packem_shared/lockfile-Cu2BH6bl.js";import{s as re,p as se}from"../packem_shared/docker-CTE3s4LW.js";import{d as ue}from"./config.js";const Z=Q(import.meta.url),x=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,N=w(e=>{if(typeof x<"u"&&x.versions&&x.versions.node){const[o,t]=x.versions.node.split(".").map(Number);if(o>22||o===22&&t>=3||o===20&&t>=16)return x.getBuiltinModule(e)}return Z(e)},"__cjs_getBuiltinModule"),{createInterface:L}=N("node:readline"),{spawn:ie}=N("node:child_process"),{createHash:ae}=N("node:crypto"),{existsSync:V,writeFileSync:le,chmodSync:ce}=N("node:fs");var de=Object.defineProperty,$=w((e,o)=>de(e,"name",{value:o,configurable:!0}),"n$1");const C={aube:{base:["RUN corepack enable"],build:$(e=>e?`RUN aube run --filter ${e} build`:"RUN aube run build","build"),install:"RUN aube install --frozen-lockfile"},bun:{base:["RUN npm install -g bun"],build:$(e=>e?`RUN bun run --filter ${e} build`:"RUN bun run build","build"),install:"RUN --mount=type=cache,target=/root/.bun/install/cache bun install --frozen-lockfile"},npm:{base:[],build:$(e=>e?`RUN npm run build --workspace ${e}`:"RUN npm run build","build"),install:"RUN --mount=type=cache,target=/root/.npm npm ci"},pnpm:{base:["ENV PNPM_HOME=/pnpm","ENV PATH=$PNPM_HOME:$PATH","RUN corepack enable"],build:$(e=>e?`RUN pnpm --filter ${e} build`:"RUN pnpm build","build"),install:"RUN --mount=type=cache,id=pnpm,target=/pnpm/store pnpm install --frozen-lockfile"},yarn:{base:["RUN corepack enable"],build:$(e=>e?`RUN yarn workspace ${e} build`:"RUN yarn build","build"),install:"RUN --mount=type=cache,target=/usr/local/share/.cache/yarn yarn install --immutable"}},fe=$(e=>{const{focus:o,manager:t,nodeVersion:r}=e,n=C[t]??C.npm;return["# syntax=docker/dockerfile:1","","# Generated by 'vis docker init'. Before building, scaffold the context:",`# vis docker scaffold${o?` --focus=${o}`:""} --include-sources`,"# then build with BuildKit enabled (DOCKER_BUILDKIT=1).","",`FROM node:${r}-slim AS base`,"WORKDIR /app",...n.base,"","# --- install dependencies from the scaffolded manifests only ---","FROM base AS deps","COPY .vis/docker/workspace/ ./",n.install,"","# --- build the focus project, then drop unfocused workspace projects ---","FROM deps AS build","COPY .vis/docker/sources/ ./",n.build(o),"RUN npx vis docker prune --context=.vis/docker","","# --- minimal runtime image ---",`FROM node:${r}-slim AS runtime`,"WORKDIR /app","ENV NODE_ENV=production","COPY --from=build /app ./","USER node","# TODO: point this at your app's entrypoint",'CMD ["node", "index.js"]',""].join(`
1
+ var X=Object.defineProperty;var w=(e,o)=>X(e,"name",{value:o,configurable:!0});import{createRequire as Q}from"node:module";import{q as S,E as m,j as R,e as F,T as H,I as E}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{M as b,a as M,l as ee}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{m as B,s as oe,C as q,S as te}from"./bin.js";import{d as ne}from"../packem_shared/lockfile-Cu2BH6bl.js";import{s as re,p as se}from"../packem_shared/docker-EJiTY0Sz.js";import{b as ue}from"./config.js";const Z=Q(import.meta.url),x=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,N=w(e=>{if(typeof x<"u"&&x.versions&&x.versions.node){const[o,t]=x.versions.node.split(".").map(Number);if(o>22||o===22&&t>=3||o===20&&t>=16)return x.getBuiltinModule(e)}return Z(e)},"__cjs_getBuiltinModule"),{createInterface:L}=N("node:readline"),{spawn:ie}=N("node:child_process"),{createHash:ae}=N("node:crypto"),{existsSync:V,writeFileSync:le,chmodSync:ce}=N("node:fs");var de=Object.defineProperty,$=w((e,o)=>de(e,"name",{value:o,configurable:!0}),"n$1");const C={aube:{base:["RUN corepack enable"],build:$(e=>e?`RUN aube run --filter ${e} build`:"RUN aube run build","build"),install:"RUN aube install --frozen-lockfile"},bun:{base:["RUN npm install -g bun"],build:$(e=>e?`RUN bun run --filter ${e} build`:"RUN bun run build","build"),install:"RUN --mount=type=cache,target=/root/.bun/install/cache bun install --frozen-lockfile"},npm:{base:[],build:$(e=>e?`RUN npm run build --workspace ${e}`:"RUN npm run build","build"),install:"RUN --mount=type=cache,target=/root/.npm npm ci"},pnpm:{base:["ENV PNPM_HOME=/pnpm","ENV PATH=$PNPM_HOME:$PATH","RUN corepack enable"],build:$(e=>e?`RUN pnpm --filter ${e} build`:"RUN pnpm build","build"),install:"RUN --mount=type=cache,id=pnpm,target=/pnpm/store pnpm install --frozen-lockfile"},yarn:{base:["RUN corepack enable"],build:$(e=>e?`RUN yarn workspace ${e} build`:"RUN yarn build","build"),install:"RUN --mount=type=cache,target=/usr/local/share/.cache/yarn yarn install --immutable"}},fe=$(e=>{const{focus:o,manager:t,nodeVersion:r}=e,n=C[t]??C.npm;return["# syntax=docker/dockerfile:1","","# Generated by 'vis docker init'. Before building, scaffold the context:",`# vis docker scaffold${o?` --focus=${o}`:""} --include-sources`,"# then build with BuildKit enabled (DOCKER_BUILDKIT=1).","",`FROM node:${r}-slim AS base`,"WORKDIR /app",...n.base,"","# --- install dependencies from the scaffolded manifests only ---","FROM base AS deps","COPY .vis/docker/workspace/ ./",n.install,"","# --- build the focus project, then drop unfocused workspace projects ---","FROM deps AS build","COPY .vis/docker/sources/ ./",n.build(o),"RUN npx vis docker prune --context=.vis/docker","","# --- minimal runtime image ---",`FROM node:${r}-slim AS runtime`,"WORKDIR /app","ENV NODE_ENV=production","COPY --from=build /app ./","USER node","# TODO: point this at your app's entrypoint",'CMD ["node", "index.js"]',""].join(`
2
2
  `)},"generateDockerfile");var pe=Object.defineProperty,g=w((e,o)=>pe(e,"name",{value:o,configurable:!0}),"i$1");const D="v2.14.0",U=`https://github.com/hadolint/hadolint/releases/download/${D}`,me=g((e=process.platform,o=process.arch)=>{const t=e==="darwin"?"macos":e==="linux"?"linux":e==="win32"?"windows":void 0;if(t===void 0)return;const r=o==="arm64"?"arm64":o==="x64"?"x86_64":void 0;if(t==="windows")return"hadolint-windows-x86_64.exe";if(r!==void 0)return`hadolint-${t}-${r}`},"resolveHadolintAsset"),K=g(e=>b(B(),"hadolint",D,e.endsWith(".exe")?"hadolint.exe":"hadolint"),"cachedBinaryPath"),ge=g(()=>{const e=process.platform==="win32"?"hadolint.exe":"hadolint",o=(process.env.PATH??"").split(process.platform==="win32"?";":":");for(const t of o)if(t!==""&&V(b(t,e)))return e},"findOnPath"),he=g(e=>e.trim().split(/\s+/u)[0]??"","parseSha256Sidecar"),A=g(async e=>{const o=await fetch(e,{redirect:"follow"});if(!o.ok)throw new Error(`download failed (${String(o.status)} ${o.statusText}) for ${e}`);return Buffer.from(await o.arrayBuffer())},"fetchBuffer"),we=g(async e=>{const o=K(e),[t,r]=await Promise.all([A(`${U}/${e}`),A(`${U}/${e}.sha256`)]),n=he(r.toString("utf8")).toLowerCase(),s=ae("sha256").update(t).digest("hex");if(n==="")throw new Error("hadolint checksum sidecar was empty or unparseable. Refusing to use the download.");if(n!==s)throw new Error(`hadolint checksum mismatch (expected ${n}, got ${s}). Refusing to use the download.`);return ue(b(B(),"hadolint",D)),le(o,t),process.platform!=="win32"&&ce(o,493),o},"downloadHadolint"),be=g(async()=>{const e=L({input:process.stdin,output:process.stderr}),o=await new Promise(t=>{e.question(` Download hadolint ${S(D)} now? ${m("[y/N]")} `,r=>{t(r.trim().toLowerCase())})});return e.close(),o==="y"||o==="yes"},"confirmInstall"),$e=g(async e=>{const{autoInstall:o=!1,log:t}=e,r=ge();if(r!==void 0)return r;const n=me();if(n===void 0){t(`hadolint has no prebuilt binary for ${process.platform}/${process.arch}. Install it manually: https://github.com/hadolint/hadolint`);return}const s=K(n);if(V(s))return s;if(!o){if(!(process.stdin.isTTY&&!oe)){t(`hadolint is not installed. Re-run with ${R("--install")} (or install hadolint on PATH) to enable Dockerfile linting.`);return}if(t(`${R("hadolint")} is required to lint Dockerfiles but was not found on your PATH.`),!await be()){t(`Skipped. Install it yourself or re-run with ${R("--install")}.`);return}}t(`Downloading hadolint ${D} (${n})…`);try{const i=await we(n);return t(`Installed hadolint to ${m(i)}`),i}catch(i){t(`Failed to download hadolint: ${i.message}`);return}},"ensureHadolint"),_=g(async(e,o,t)=>{if(o.length===0)return[];const r=["--format","json","--no-fail",...t!==void 0&&t!==""?["--config",t]:[],...o],n=await new Promise((i,c)=>{const a=ie(e,r,{shell:process.platform==="win32",stdio:["ignore","pipe","pipe"],windowsHide:!0});let u="",d="";a.stdout?.on("data",l=>{u+=l.toString("utf8")}),a.stderr?.on("data",l=>{d+=l.toString("utf8")}),a.on("error",c),a.on("close",()=>{if(u.trim()===""&&d.trim()!==""){c(new Error(d.trim()));return}i(u)})});if(n.trim()==="")return[];let s;try{s=JSON.parse(n)}catch{throw new Error("Could not parse hadolint JSON output.")}return Array.isArray(s)?s:[]},"runHadolint");var ye=Object.defineProperty,y=w((e,o)=>ye(e,"name",{value:o,configurable:!0}),"n");const T=y((e,o,t)=>{if(!(!/\bapt-get\b/u.test(e)||!/\binstall\b/u.test(e)||t.test(e)))return e.replace(/\binstall\b/u,`install ${o}`)},"addAptGetInstallFlag"),j={DL3014:y(e=>T(e,"-y",/(?:^|\s)(?:-y|--yes|--assume-yes|-qq?)\b/u),"DL3014"),DL3015:y(e=>T(e,"--no-install-recommends",/--no-install-recommends\b/u),"DL3015"),DL3020:y(e=>/^\s*ADD\b/u.test(e)?e.replace(/^(\s*)ADD\b/u,"$1COPY"):void 0,"DL3020"),DL3027:y(e=>/(?:^|\s)apt\s/u.test(e)&&!/\bapt-get\b/u.test(e)?e.replace(/(^|\s)apt(\s)/u,"$1apt-get$2"):void 0,"DL3027")},Y=new Set(Object.keys(j)),ke=y((e,o)=>{const t=e.includes(`\r
3
3
  `)?`\r
4
4
  `:`
@@ -1,3 +1,3 @@
1
- var Q=Object.defineProperty;var p=(t,e)=>Q(t,"name",{value:e,configurable:!0});import{createRequire as X}from"node:module";import{I as _,q as ee,j as N,E as T}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{z as G}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{aL as y,aM as te}from"./bin.js";import{d as M,f as P,r as re,b as se,a as ie,c as ne,e as ae,g as oe,s as ce,h as de,i as fe,j as le,k as ue,l as pe,m as ge,n as me,o as he,p as xe,q as be,t as ve}from"../packem_shared/watch-loop-C31Ar7BX.js";const Y=X(import.meta.url),j=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,Z=p(t=>{if(typeof j<"u"&&j.versions&&j.versions.node){const[e,r]=j.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return j.getBuiltinModule(t)}return Y(t)},"__cjs_getBuiltinModule"),{createHash:O}=Z("node:crypto");var ke=Object.defineProperty,I=p((t,e)=>ke(t,"name",{value:e,configurable:!0}),"o");const ye=I(t=>t.startsWith("/")||/^[a-z]:[\\/]/i.test(t),"isAbsolutePath"),R=I((t,e)=>ye(e)?e:`${t}/${e}`,"resolveFile");var we=Object.defineProperty,g=p((t,e)=>we(t,"name",{value:e,configurable:!0}),"n$1");const je={argsCheck:g((t,e)=>z(t,e,"check"),"argsCheck"),argsFix:g((t,e)=>z(t,e,"fix"),"argsFix"),bin:g(()=>["pnpm","exec","dprint"],"bin"),cacheKey:g((t,e)=>{const r=["dprint",t.declaredVersion??"unknown",t.configFile??"no-config",e.quiet?"q":"",...e.extraArgs??[]];return O("sha256").update(r.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:g((t,e)=>{const r=M(e,y.dprint.packageNames[0]),s=P(t,y.dprint.configFiles);if(!(!r&&!s))return{adapter:"dprint",configFile:s,declared:!!r,declaredVersion:r,root:t}},"detect"),extensions:["cjs","css","cts","dockerfile","html","js","json","jsonc","jsx","md","mdx","mjs","mts","toml","ts","tsx","yaml","yml"],id:"dprint",kind:"fmt",parse:g((t,e)=>{if(t.exitCode===0)return[];const r=[];for(const s of t.stdout.split(/\r?\n/)){const i=s.trim();!i||i.startsWith("[")||i.startsWith("Checked ")||i.startsWith("Error:")||r.push({adapter:"dprint",file:R(e.root,i),fixable:!0,message:"Code style issues would be auto-fixed",severity:"info"})}return r},"parse")},z=g((t,e,r)=>{const s=r==="fix"?["fmt"]:["check","--list-different"];return e.extraArgs?.length&&s.push(...e.extraArgs),s.push(...t),s},"buildArgs");var Fe=Object.defineProperty,m=p((t,e)=>Fe(t,"name",{value:e,configurable:!0}),"n");const Ae={argsCheck:m((t,e)=>H(t,e,"check"),"argsCheck"),argsFix:m((t,e)=>H(t,e,"fix"),"argsFix"),bin:m(()=>["pnpm","exec","oxfmt"],"bin"),cacheKey:m((t,e)=>{const r=["oxfmt",t.declaredVersion??"unknown",t.configFile??"no-config",e.quiet?"q":"",...e.extraArgs??[]];return O("sha256").update(r.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:m((t,e)=>{const r=M(e,y.oxfmt.packageNames[0]),s=P(t,y.oxfmt.configFiles);if(!(!r&&!s))return{adapter:"oxfmt",configFile:s,declared:!!r,declaredVersion:r,root:t}},"detect"),extensions:["cjs","cts","js","json","jsonc","jsx","mjs","mts","ts","tsx"],id:"oxfmt",kind:"fmt",parse:m((t,e)=>{if(t.exitCode===0)return[];const r=[];for(const s of t.stdout.split(/\r?\n/)){const i=s.trim();!i||i.startsWith("[")||r.push({adapter:"oxfmt",file:R(e.root,i),fixable:!0,message:"Code style issues would be auto-fixed",severity:"info"})}return r},"parse")},H=m((t,e,r)=>{const s=r==="fix"?["--write"]:["--list-different"];return e.extraArgs?.length&&s.push(...e.extraArgs),s.push(...t),s},"buildArgs");var Ce=Object.defineProperty,h=p((t,e)=>Ce(t,"name",{value:e,configurable:!0}),"s");const $e={argsCheck:h((t,e)=>L(t,e,"check"),"argsCheck"),argsFix:h((t,e)=>L(t,e,"fix"),"argsFix"),bin:h(()=>["pnpm","exec","prettier"],"bin"),cacheKey:h((t,e)=>{const r=["prettier",t.declaredVersion??"unknown",t.configFile??"no-config",e.quiet?"q":"",...e.extraArgs??[]];return O("sha256").update(r.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:h((t,e)=>{const r=M(e,y.prettier.packageNames[0]),s=P(t,y.prettier.configFiles);if(!(!r&&!s))return{adapter:"prettier",configFile:s,declared:!!r,declaredVersion:r,root:t}},"detect"),extensions:["cjs","css","cts","html","js","json","jsx","less","md","mdx","mjs","mts","scss","ts","tsx","vue","yaml","yml"],id:"prettier",kind:"fmt",parse:h((t,e)=>{if(t.exitCode===0)return[];const r=[];for(const s of t.stdout.split(/\r?\n/)){const i=s.trim();i&&(i.startsWith("[")||r.push({adapter:"prettier",file:R(e.root,i),fixable:!0,message:"Code style issues would be auto-fixed",severity:"info"}))}return r},"parse")},L=h((t,e,r)=>{const s=r==="fix"?["--write"]:["--list-different"];return e.quiet&&s.push("--log-level","warn"),e.extraArgs?.length&&s.push(...e.extraArgs),s.push(...t),s},"buildArgs");var qe=Object.defineProperty,x=p((t,e)=>qe(t,"name",{value:e,configurable:!0}),"c");const _e=[Ae,se,je,$e,ie,ne],Be=x(async({logger:t,options:e,visConfig:r,workspaceRoot:s})=>{const i=s??process.cwd(),b=r?.fmt,F=re(_e,b?.order),J=ae(i,F),w=oe(J,F,"fmt").filter(({adapter:l})=>b?.adapters?.[l.id]?.enabled!==!1);if(w.length===0){t.warn("vis fmt: no formatter detected in this workspace (looked for: oxfmt, biome, dprint, prettier, ruff, deno-fmt).");return}const S=x(l=>{const a=b?.adapters?.[l]?.extraArgs;return a&&a.length>0?[...a]:void 0},"baseExtraArgs"),$={quiet:e.quiet??!1},W=Me(e),A=e.check?"check":"fix";let c;if(e.staged){if(c=ce(i),c===void 0)t.warn("vis fmt: could not resolve --staged (not a git repo or git unavailable). Falling back to a workspace-wide run.");else if(c.length===0){t.info(_("✓ fmt: no staged files"));return}}else if(typeof e.since=="string"&&e.since.length>0){if(c=de(i,e.since),c===void 0)t.warn(`vis fmt: could not resolve --since ${e.since} (not a git repo or unknown ref). Falling back to a workspace-wide run.`);else if(c.length===0){t.info(_(`✓ fmt: no files changed since ${e.since}`));return}}const U=te(i,void 0,void 0,!0),q=e.format??"human";q==="human"&&e.output!==void 0&&t.warn("vis fmt: --output is ignored for the human format; pass --format json|minimal|sarif|junit|github to redirect findings to a file.");const E=x(async l=>{const a=W.length>0?W:l,v=[];if(a){const n=fe(a,w,b?.extensionOverrides);for(const{adapter:o,presence:d}of w){const f=n.get(o.id);if(!f||f.length===0)continue;const V=S(o.id),B={adapter:o,files:f,presence:d};V&&(B.options={...$,extraArgs:V}),v.push(B)}}else for(const{adapter:n,presence:o}of w){const d=S(n.id),f={adapter:n,files:["."],presence:o};d&&(f.options={...$,extraArgs:d}),v.push(f)}if(v.length===0)return;const D=await le(v,$,A,{cacheRoot:U}),C=v.map((n,o)=>{const d=D[o],f=n.adapter.parse(d,n.presence);return{adapter:n.adapter,durationMs:d.durationMs,exitCode:d.exitCode,findings:f}}),u=ue(C.map(n=>({adapter:n.adapter.id,durationMs:n.durationMs,exitCode:n.exitCode,findingCount:n.findings.length,findings:n.findings}))),k=q==="human"?void 0:pe({cwd:i,target:e.output});try{switch(q){case"github":{k.write(he({runs:C.map(n=>({findings:n.findings})),workspaceRoot:i}));break}case"json":{k.write(`${JSON.stringify({findings:u.findings,mode:A,runs:u.runs},null,2)}
1
+ var Q=Object.defineProperty;var p=(t,e)=>Q(t,"name",{value:e,configurable:!0});import{createRequire as X}from"node:module";import{I as _,q as ee,j as N,E as T}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{z as G}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{aL as y,aM as te}from"./bin.js";import{d as M,f as P,r as re,b as se,a as ie,c as ne,e as ae,g as oe,s as ce,h as de,i as fe,j as le,k as ue,l as pe,m as ge,n as me,o as he,p as xe,q as be,t as ve}from"../packem_shared/watch-loop-BpA_pxU9.js";const Y=X(import.meta.url),j=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,Z=p(t=>{if(typeof j<"u"&&j.versions&&j.versions.node){const[e,r]=j.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return j.getBuiltinModule(t)}return Y(t)},"__cjs_getBuiltinModule"),{createHash:O}=Z("node:crypto");var ke=Object.defineProperty,I=p((t,e)=>ke(t,"name",{value:e,configurable:!0}),"o");const ye=I(t=>t.startsWith("/")||/^[a-z]:[\\/]/i.test(t),"isAbsolutePath"),R=I((t,e)=>ye(e)?e:`${t}/${e}`,"resolveFile");var we=Object.defineProperty,g=p((t,e)=>we(t,"name",{value:e,configurable:!0}),"n$1");const je={argsCheck:g((t,e)=>z(t,e,"check"),"argsCheck"),argsFix:g((t,e)=>z(t,e,"fix"),"argsFix"),bin:g(()=>["pnpm","exec","dprint"],"bin"),cacheKey:g((t,e)=>{const r=["dprint",t.declaredVersion??"unknown",t.configFile??"no-config",e.quiet?"q":"",...e.extraArgs??[]];return O("sha256").update(r.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:g((t,e)=>{const r=M(e,y.dprint.packageNames[0]),s=P(t,y.dprint.configFiles);if(!(!r&&!s))return{adapter:"dprint",configFile:s,declared:!!r,declaredVersion:r,root:t}},"detect"),extensions:["cjs","css","cts","dockerfile","html","js","json","jsonc","jsx","md","mdx","mjs","mts","toml","ts","tsx","yaml","yml"],id:"dprint",kind:"fmt",parse:g((t,e)=>{if(t.exitCode===0)return[];const r=[];for(const s of t.stdout.split(/\r?\n/)){const i=s.trim();!i||i.startsWith("[")||i.startsWith("Checked ")||i.startsWith("Error:")||r.push({adapter:"dprint",file:R(e.root,i),fixable:!0,message:"Code style issues would be auto-fixed",severity:"info"})}return r},"parse")},z=g((t,e,r)=>{const s=r==="fix"?["fmt"]:["check","--list-different"];return e.extraArgs?.length&&s.push(...e.extraArgs),s.push(...t),s},"buildArgs");var Fe=Object.defineProperty,m=p((t,e)=>Fe(t,"name",{value:e,configurable:!0}),"n");const Ae={argsCheck:m((t,e)=>H(t,e,"check"),"argsCheck"),argsFix:m((t,e)=>H(t,e,"fix"),"argsFix"),bin:m(()=>["pnpm","exec","oxfmt"],"bin"),cacheKey:m((t,e)=>{const r=["oxfmt",t.declaredVersion??"unknown",t.configFile??"no-config",e.quiet?"q":"",...e.extraArgs??[]];return O("sha256").update(r.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:m((t,e)=>{const r=M(e,y.oxfmt.packageNames[0]),s=P(t,y.oxfmt.configFiles);if(!(!r&&!s))return{adapter:"oxfmt",configFile:s,declared:!!r,declaredVersion:r,root:t}},"detect"),extensions:["cjs","cts","js","json","jsonc","jsx","mjs","mts","ts","tsx"],id:"oxfmt",kind:"fmt",parse:m((t,e)=>{if(t.exitCode===0)return[];const r=[];for(const s of t.stdout.split(/\r?\n/)){const i=s.trim();!i||i.startsWith("[")||r.push({adapter:"oxfmt",file:R(e.root,i),fixable:!0,message:"Code style issues would be auto-fixed",severity:"info"})}return r},"parse")},H=m((t,e,r)=>{const s=r==="fix"?["--write"]:["--list-different"];return e.extraArgs?.length&&s.push(...e.extraArgs),s.push(...t),s},"buildArgs");var Ce=Object.defineProperty,h=p((t,e)=>Ce(t,"name",{value:e,configurable:!0}),"s");const $e={argsCheck:h((t,e)=>L(t,e,"check"),"argsCheck"),argsFix:h((t,e)=>L(t,e,"fix"),"argsFix"),bin:h(()=>["pnpm","exec","prettier"],"bin"),cacheKey:h((t,e)=>{const r=["prettier",t.declaredVersion??"unknown",t.configFile??"no-config",e.quiet?"q":"",...e.extraArgs??[]];return O("sha256").update(r.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:h((t,e)=>{const r=M(e,y.prettier.packageNames[0]),s=P(t,y.prettier.configFiles);if(!(!r&&!s))return{adapter:"prettier",configFile:s,declared:!!r,declaredVersion:r,root:t}},"detect"),extensions:["cjs","css","cts","html","js","json","jsx","less","md","mdx","mjs","mts","scss","ts","tsx","vue","yaml","yml"],id:"prettier",kind:"fmt",parse:h((t,e)=>{if(t.exitCode===0)return[];const r=[];for(const s of t.stdout.split(/\r?\n/)){const i=s.trim();i&&(i.startsWith("[")||r.push({adapter:"prettier",file:R(e.root,i),fixable:!0,message:"Code style issues would be auto-fixed",severity:"info"}))}return r},"parse")},L=h((t,e,r)=>{const s=r==="fix"?["--write"]:["--list-different"];return e.quiet&&s.push("--log-level","warn"),e.extraArgs?.length&&s.push(...e.extraArgs),s.push(...t),s},"buildArgs");var qe=Object.defineProperty,x=p((t,e)=>qe(t,"name",{value:e,configurable:!0}),"c");const _e=[Ae,se,je,$e,ie,ne],Be=x(async({logger:t,options:e,visConfig:r,workspaceRoot:s})=>{const i=s??process.cwd(),b=r?.fmt,F=re(_e,b?.order),J=ae(i,F),w=oe(J,F,"fmt").filter(({adapter:l})=>b?.adapters?.[l.id]?.enabled!==!1);if(w.length===0){t.warn("vis fmt: no formatter detected in this workspace (looked for: oxfmt, biome, dprint, prettier, ruff, deno-fmt).");return}const S=x(l=>{const a=b?.adapters?.[l]?.extraArgs;return a&&a.length>0?[...a]:void 0},"baseExtraArgs"),$={quiet:e.quiet??!1},W=Me(e),A=e.check?"check":"fix";let c;if(e.staged){if(c=ce(i),c===void 0)t.warn("vis fmt: could not resolve --staged (not a git repo or git unavailable). Falling back to a workspace-wide run.");else if(c.length===0){t.info(_("✓ fmt: no staged files"));return}}else if(typeof e.since=="string"&&e.since.length>0){if(c=de(i,e.since),c===void 0)t.warn(`vis fmt: could not resolve --since ${e.since} (not a git repo or unknown ref). Falling back to a workspace-wide run.`);else if(c.length===0){t.info(_(`✓ fmt: no files changed since ${e.since}`));return}}const U=te(i,void 0,void 0,!0),q=e.format??"human";q==="human"&&e.output!==void 0&&t.warn("vis fmt: --output is ignored for the human format; pass --format json|minimal|sarif|junit|github to redirect findings to a file.");const E=x(async l=>{const a=W.length>0?W:l,v=[];if(a){const n=fe(a,w,b?.extensionOverrides);for(const{adapter:o,presence:d}of w){const f=n.get(o.id);if(!f||f.length===0)continue;const V=S(o.id),B={adapter:o,files:f,presence:d};V&&(B.options={...$,extraArgs:V}),v.push(B)}}else for(const{adapter:n,presence:o}of w){const d=S(n.id),f={adapter:n,files:["."],presence:o};d&&(f.options={...$,extraArgs:d}),v.push(f)}if(v.length===0)return;const D=await le(v,$,A,{cacheRoot:U}),C=v.map((n,o)=>{const d=D[o],f=n.adapter.parse(d,n.presence);return{adapter:n.adapter,durationMs:d.durationMs,exitCode:d.exitCode,findings:f}}),u=ue(C.map(n=>({adapter:n.adapter.id,durationMs:n.durationMs,exitCode:n.exitCode,findingCount:n.findings.length,findings:n.findings}))),k=q==="human"?void 0:pe({cwd:i,target:e.output});try{switch(q){case"github":{k.write(he({runs:C.map(n=>({findings:n.findings})),workspaceRoot:i}));break}case"json":{k.write(`${JSON.stringify({findings:u.findings,mode:A,runs:u.runs},null,2)}
2
2
  `);break}case"junit":{k.write(me({runs:C.map(n=>({adapter:n.adapter.id,durationMs:n.durationMs,findings:n.findings})),workspaceRoot:i}));break}case"minimal":{Oe(u.findings,i,k);break}case"sarif":{k.write(ge({runs:C.map(n=>({adapter:n.adapter.id,findings:n.findings,presence:v.find(o=>o.adapter.id===n.adapter.id)?.presence})),workspaceRoot:i}));break}default:Pe(u.findings,i,A,t)}}finally{k?.close()}const K=A==="fix"?u.hadProcessFailure?1:0:xe({...u,maxSeverity:u.findings.length>0?"error":void 0});K!==0&&(process.exitCode=K)},"runCycle");if(e.watch){const l=[...new Set(w.flatMap(({adapter:a})=>a.extensions))];await be({extensions:l,initialFiles:c,label:"fmt",log:x(a=>{t.info(a)},"log"),runCycle:E,workspaceRoot:i});return}await E(c)},"execute"),Me=x(t=>{const e=t;return[...e._??e.args??[]]},"collectPositional"),Pe=x((t,e,r,s)=>{if(t.length===0){s.info(_(r==="fix"?"✓ fmt: nothing to change":"✓ fmt: all files already formatted"));return}const i=ve(t),b=r==="fix"?ee(N("Formatted:")):N("Would change:");s.info(b);for(const F of i.keys())s.info(` ${T("·")} ${G(e,F)}`);r==="check"&&(s.info(""),s.info(T(`Run \`vis fmt\` to apply changes (${String(i.size)} file${i.size===1?"":"s"}).`)))},"printHuman"),Oe=x((t,e,r)=>{for(const s of t)r.write(`${s.adapter} ${G(e,s.file)}
3
3
  `)},"printMinimal");export{Be as default};
@@ -1,4 +1,4 @@
1
- var ae=Object.defineProperty;var j=(t,e)=>ae(t,"name",{value:e,configurable:!0});import{createRequire as ce}from"node:module";import{E as p,j as b,q as T}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{l as _,M as E,K as Y,a as L,z as Q,y as pe,C as fe}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{an as X,p as l}from"./bin.js";import{f as $e}from"../packem_shared/giget-CcEy_Elm.js";import{d as Z,E as ye}from"./config.js";const le=ce(import.meta.url),x=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,P=j(t=>{if(typeof x<"u"&&x.versions&&x.versions.node){const[e,r]=x.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return x.getBuiltinModule(t)}return le(t)},"__cjs_getBuiltinModule"),{fileURLToPath:ue}=P("node:url"),{createInterface:de}=P("node:readline"),{mkdtempSync:me,rmSync:he}=P("node:fs"),{tmpdir:ge}=P("node:os"),{spawnSync:we}=P("node:child_process");var ve=Object.defineProperty,y=j((t,e)=>ve(t,"name",{value:e,configurable:!0}),"i");const ee=[".ts",".mts",".cts",".js",".mjs",".cjs"],be="template.yml",Te=[".d",".test",".spec",".config",".bench",".stories"],Se=[".d.ts",".d.mts",".d.cts",".js.map",".mjs.map",".cjs.map",".ts.map"],te=y(t=>{for(const e of ee)if(t.endsWith(e))return t.slice(0,-e.length);return t},"stripExtension"),Oe=y(t=>{if(Se.some(r=>t.endsWith(r))||!ee.some(r=>t.endsWith(r)))return!1;const e=te(t);return!Te.some(r=>e.endsWith(r))},"isNativeFile"),J=y((t,e)=>{const r=[];if(!_(t))return r;for(const s of X(t,{includeDirs:!1,includeSymlinks:!1,maxDepth:1})){if(!Oe(s.name))continue;const n=te(s.name);r.push({load:y(()=>Ee(s.path),"load"),name:n,path:s.path,source:e})}return r},"scanNativeDirectory"),B=y((t,e)=>{const r=[];if(!_(t))return r;for(const s of X(t,{includeFiles:!1,includeSymlinks:!1,maxDepth:1})){if(s.path===t)continue;const n=E(s.path,be);_(n)&&r.push({load:y(()=>Ne(s.path,s.name),"load"),name:s.name,path:s.path,source:e})}return r},"scanMoonDirectory"),je=y(()=>{try{const t=ue(import.meta.url),e=E(Y(t),"..","..","templates");return _(e)?e:void 0}catch{return}},"resolveBuiltinTemplatesDirectory"),I=y(t=>{const{extraDirectories:e=[],onWarning:r,workspaceRoot:s}=t,n=[...J(E(s,".vis","templates"),"native"),...B(E(s,".vis","templates"),"moon"),...B(E(s,".moon","templates"),"moon")];for(const o of e)n.push(...B(o,"config")),n.push(...J(o,"config"));const i=je();i&&n.push(...B(i,"builtin"));const a=new Map;for(const o of n){const c=a.get(o.name);if(!c){a.set(o.name,o);continue}r&&r(`Template "${o.name}" exists in multiple sources — using ${c.source} (${c.path}), ignoring ${o.source} (${o.path}).`)}return[...a.values()].sort((o,c)=>o.name.localeCompare(c.name))},"discoverTemplates"),Ee=y(async t=>{const{loadNativeTemplate:e}=await import("./loader2.js");return e(t)},"loadNativeFromPath"),Ne=y(async(t,e)=>{const{loadMoonTemplate:r}=await import("./index.js");return r(t,e)},"loadMoonFromPath");var Re=Object.defineProperty,v=j((t,e)=>Re(t,"name",{value:e,configurable:!0}),"c");const M=v((t,e)=>new Promise(r=>{t.question(e,s=>{r(s.trim())})}),"ask"),ke=v(async(t,e,r)=>{const s=await M(t,` ${e} ${p(r?"[Y/n]":"[y/N]")} `);return s===""?r:s.toLowerCase()==="y"||s.toLowerCase()==="yes"},"confirm"),xe=v(async(t,e,r,s)=>{process.stderr.write(` ${e}
1
+ var ae=Object.defineProperty;var j=(t,e)=>ae(t,"name",{value:e,configurable:!0});import{createRequire as ce}from"node:module";import{E as p,j as b,q as T}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{l as _,M as E,K as Y,a as L,z as Q,y as pe,C as fe}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{an as X,p as l}from"./bin.js";import{f as $e}from"../packem_shared/giget-CcEy_Elm.js";import{b as Z,E as ye}from"./config.js";const le=ce(import.meta.url),x=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,P=j(t=>{if(typeof x<"u"&&x.versions&&x.versions.node){const[e,r]=x.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return x.getBuiltinModule(t)}return le(t)},"__cjs_getBuiltinModule"),{fileURLToPath:ue}=P("node:url"),{createInterface:de}=P("node:readline"),{mkdtempSync:me,rmSync:he}=P("node:fs"),{tmpdir:ge}=P("node:os"),{spawnSync:we}=P("node:child_process");var ve=Object.defineProperty,y=j((t,e)=>ve(t,"name",{value:e,configurable:!0}),"i");const ee=[".ts",".mts",".cts",".js",".mjs",".cjs"],be="template.yml",Te=[".d",".test",".spec",".config",".bench",".stories"],Se=[".d.ts",".d.mts",".d.cts",".js.map",".mjs.map",".cjs.map",".ts.map"],te=y(t=>{for(const e of ee)if(t.endsWith(e))return t.slice(0,-e.length);return t},"stripExtension"),Oe=y(t=>{if(Se.some(r=>t.endsWith(r))||!ee.some(r=>t.endsWith(r)))return!1;const e=te(t);return!Te.some(r=>e.endsWith(r))},"isNativeFile"),J=y((t,e)=>{const r=[];if(!_(t))return r;for(const s of X(t,{includeDirs:!1,includeSymlinks:!1,maxDepth:1})){if(!Oe(s.name))continue;const n=te(s.name);r.push({load:y(()=>Ee(s.path),"load"),name:n,path:s.path,source:e})}return r},"scanNativeDirectory"),B=y((t,e)=>{const r=[];if(!_(t))return r;for(const s of X(t,{includeFiles:!1,includeSymlinks:!1,maxDepth:1})){if(s.path===t)continue;const n=E(s.path,be);_(n)&&r.push({load:y(()=>Ne(s.path,s.name),"load"),name:s.name,path:s.path,source:e})}return r},"scanMoonDirectory"),je=y(()=>{try{const t=ue(import.meta.url),e=E(Y(t),"..","..","templates");return _(e)?e:void 0}catch{return}},"resolveBuiltinTemplatesDirectory"),I=y(t=>{const{extraDirectories:e=[],onWarning:r,workspaceRoot:s}=t,n=[...J(E(s,".vis","templates"),"native"),...B(E(s,".vis","templates"),"moon"),...B(E(s,".moon","templates"),"moon")];for(const o of e)n.push(...B(o,"config")),n.push(...J(o,"config"));const i=je();i&&n.push(...B(i,"builtin"));const a=new Map;for(const o of n){const c=a.get(o.name);if(!c){a.set(o.name,o);continue}r&&r(`Template "${o.name}" exists in multiple sources — using ${c.source} (${c.path}), ignoring ${o.source} (${o.path}).`)}return[...a.values()].sort((o,c)=>o.name.localeCompare(c.name))},"discoverTemplates"),Ee=y(async t=>{const{loadNativeTemplate:e}=await import("./loader2.js");return e(t)},"loadNativeFromPath"),Ne=y(async(t,e)=>{const{loadMoonTemplate:r}=await import("./index.js");return r(t,e)},"loadMoonFromPath");var Re=Object.defineProperty,v=j((t,e)=>Re(t,"name",{value:e,configurable:!0}),"c");const M=v((t,e)=>new Promise(r=>{t.question(e,s=>{r(s.trim())})}),"ask"),ke=v(async(t,e,r)=>{const s=await M(t,` ${e} ${p(r?"[Y/n]":"[y/N]")} `);return s===""?r:s.toLowerCase()==="y"||s.toLowerCase()==="yes"},"confirm"),xe=v(async(t,e,r,s)=>{process.stderr.write(` ${e}
2
2
  `);for(const[n,i]of r.entries()){const a=b(T(` ${String(n+1)}.`)),o=i===s?p(" (default)"):"";process.stderr.write(`${a} ${i}${o}
3
3
  `)}for(;;){const n=await M(t,`
4
4
  ${p(`Enter choice (1-${String(r.length)}):`)} `);if(n===""&&s!==void 0)return s;const i=Number.parseInt(n,10);if(Number.isInteger(i)&&i>=1&&i<=r.length)return r[i-1];const a=r.find(o=>o===n);if(a)return a;process.stderr.write(` ${p("Invalid choice. Try again.")}
@@ -1,4 +1,4 @@
1
- var H=Object.defineProperty;var j=(e,t)=>H(e,"name",{value:t,configurable:!0});import{createRequire as K}from"node:module";import{d as V,E as A,f as Y}from"./config.js";import{B as X,K as D,z as T,M as C}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{o as Z}from"../packem_shared/index-DH-5hsrC.js";import{aN as P,C as ee,aO as te,a3 as oe}from"./bin.js";import{r as re}from"../packem_shared/glob-D_7bct6p-D8itOHsr.js";import{n as ne}from"../packem_shared/manifests-BzWpKW8F.js";const z=K(import.meta.url),O=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,Q=j(e=>{if(typeof O<"u"&&O.versions&&O.versions.node){const[t,o]=O.versions.node.split(".").map(Number);if(t>22||t===22&&o>=3||t===20&&o>=16)return O.getBuiltinModule(e)}return z(e)},"__cjs_getBuiltinModule"),{readFileSync:F}=Q("node:fs");var se=Object.defineProperty,y=j((e,t)=>se(e,"name",{value:t,configurable:!0}),"c");const ie=y((e,t)=>{const o=t.replace(/^\.?\//,"");return o===""||o==="."?`/${e}/`:e===""||e==="."?`/${o}`:`/${e}/${o}`},"toWorkspacePath"),_=y((e,t,o=[])=>{const s=[],r=new Set;for(const[i,n]of Object.entries(t?.globalPaths??{}))s.push({owners:n,path:i,source:"project-json"}),r.add(i);for(const[i,n]of Object.entries(e.projects)){const a=n.owners??[];for(const c of a){const l=ie(n.root??i,c.path);s.push({channel:c.channel,owners:c.owners,path:l,projectId:i,source:"project-json"}),r.add(l)}}for(const i of o)r.has(i.path)||(s.push(i),r.add(i.path));return(t?.orderBy??"file-source")==="project-id"?s.sort((i,n)=>(i.projectId??"").localeCompare(n.projectId??"")||i.path.localeCompare(n.path)):s.sort((i,n)=>i.path.localeCompare(n.path)),s},"buildCodeownersLines"),ae="Update each project's project.json `owners` field and re-run the command.",ce=y(e=>["# CODEOWNERS — generated by `vis sync codeowners`. Do not edit by hand.",e?`# Re-run with: ${e}`:`# ${ae}`,""],"buildHeader"),M=y(e=>{const t=[];for(const o of e){const s=o.owners.join(" "),r=o.channel?` # notify: ${o.channel}`:"";t.push(`${o.path} ${s}${r}`)}return t},"renderEntries"),de=y((e,t={})=>[...ce(t.regenerationCommand),...M(e),""].join(`
1
+ var H=Object.defineProperty;var j=(e,t)=>H(e,"name",{value:t,configurable:!0});import{createRequire as K}from"node:module";import{b as V,E as A,d as Y}from"./config.js";import{B as X,K as D,z as T,M as C}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{o as Z}from"../packem_shared/index-DH-5hsrC.js";import{aN as P,C as ee,aO as te,a3 as oe}from"./bin.js";import{r as re}from"../packem_shared/glob-D_7bct6p-D8itOHsr.js";import{n as ne}from"../packem_shared/manifests-BzWpKW8F.js";const z=K(import.meta.url),O=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,Q=j(e=>{if(typeof O<"u"&&O.versions&&O.versions.node){const[t,o]=O.versions.node.split(".").map(Number);if(t>22||t===22&&o>=3||t===20&&o>=16)return O.getBuiltinModule(e)}return z(e)},"__cjs_getBuiltinModule"),{readFileSync:F}=Q("node:fs");var se=Object.defineProperty,y=j((e,t)=>se(e,"name",{value:t,configurable:!0}),"c");const ie=y((e,t)=>{const o=t.replace(/^\.?\//,"");return o===""||o==="."?`/${e}/`:e===""||e==="."?`/${o}`:`/${e}/${o}`},"toWorkspacePath"),_=y((e,t,o=[])=>{const s=[],r=new Set;for(const[i,n]of Object.entries(t?.globalPaths??{}))s.push({owners:n,path:i,source:"project-json"}),r.add(i);for(const[i,n]of Object.entries(e.projects)){const a=n.owners??[];for(const c of a){const l=ie(n.root??i,c.path);s.push({channel:c.channel,owners:c.owners,path:l,projectId:i,source:"project-json"}),r.add(l)}}for(const i of o)r.has(i.path)||(s.push(i),r.add(i.path));return(t?.orderBy??"file-source")==="project-id"?s.sort((i,n)=>(i.projectId??"").localeCompare(n.projectId??"")||i.path.localeCompare(n.path)):s.sort((i,n)=>i.path.localeCompare(n.path)),s},"buildCodeownersLines"),ae="Update each project's project.json `owners` field and re-run the command.",ce=y(e=>["# CODEOWNERS — generated by `vis sync codeowners`. Do not edit by hand.",e?`# Re-run with: ${e}`:`# ${ae}`,""],"buildHeader"),M=y(e=>{const t=[];for(const o of e){const s=o.owners.join(" "),r=o.channel?` # notify: ${o.channel}`:"";t.push(`${o.path} ${s}${r}`)}return t},"renderEntries"),de=y((e,t={})=>[...ce(t.regenerationCommand),...M(e),""].join(`
2
2
  `),"renderCodeowners"),S={begin:"# BEGIN vis-codeowners",end:"# END vis-codeowners"},le=y((e,t=S,o={})=>{const s=o.regenerationCommand?`# Generated by vis sync codeowners — re-run with: ${o.regenerationCommand}`:"# Generated by `vis sync codeowners` — do not edit by hand.";return[t.begin,s,...M(e),t.end].join(`
3
3
  `)},"renderCodeownersBlock"),ue=y((e,t,o=S)=>{const s=e.indexOf(o.begin),r=e.indexOf(o.end);if(s!==-1&&r!==-1&&r>s){const n=e.slice(0,s),a=r+o.end.length,c=e.slice(a);return`${n}${t}${c}`}const i=e.replace(/\s+$/u,"");return`${i.length===0?"":`${i}
4
4
 
@@ -1,3 +1,3 @@
1
- var Z=Object.defineProperty;var x=(e,r)=>Z(e,"name",{value:r,configurable:!0});import{createRequire as ee}from"node:module";import{I as L,j as ne,E as R,T as G,e as U,q as ie}from"../packem_shared/Table-DoSoazT6-DwnyTUsA.js";import{z as D}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{aL as c,aM as se}from"./bin.js";import{d as j,f as C,r as ae,b as oe,u as le,v as ce,e as de,g as ue,s as ge,h as fe,w as pe,j as me,k as he,l as xe,m as ve,n as we,o as ye,p as ke,q as be,t as $e}from"../packem_shared/watch-loop-C31Ar7BX.js";const re=ee(import.meta.url),F=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,te=x(e=>{if(typeof F<"u"&&F.versions&&F.versions.node){const[r,t]=F.versions.node.split(".").map(Number);if(r>22||r===22&&t>=3||r===20&&t>=16)return F.getBuiltinModule(e)}return re(e)},"__cjs_getBuiltinModule"),{createHash:S}=te("node:crypto");var Ae=Object.defineProperty,v=x((e,r)=>Ae(e,"name",{value:r,configurable:!0}),"s$1");const Fe={1:"warning",2:"error"},je={argsCheck:v((e,r)=>T(e,r,!1),"argsCheck"),argsFix:v((e,r)=>T(e,r,!0),"argsFix"),bin:v(()=>["pnpm","exec","eslint"],"bin"),cacheKey:v((e,r)=>{const t=["eslint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:v((e,r)=>{const t=j(r,c.eslint.packageNames[0]),n=C(e,c.eslint.configFiles);if(!(!t&&!n))return{adapter:"eslint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["cjs","cts","js","jsx","mjs","mts","ts","tsx","vue"],id:"eslint",kind:"lint",parse:v((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"eslint",file:r.root,fixable:!1,message:`eslint output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t)for(const s of i.messages)n.push({adapter:"eslint",column:s.column,endColumn:s.endColumn,endLine:s.endLine,file:i.filePath,fixable:!!s.fix,line:s.line,message:s.message,ruleId:s.ruleId??void 0,severity:s.fatal?"error":Fe[s.severity]??"warning"});return n},"parse")},T=v((e,r,t)=>{const n=["--format","json","--no-error-on-unmatched-pattern"];return t&&n.push("--fix"),r.quiet&&n.push("--quiet"),typeof r.maxWarnings=="number"&&n.push("--max-warnings",String(r.maxWarnings)),r.extraArgs?.length&&n.push(...r.extraArgs),n.push(...e),n},"buildArgs");var Ce=Object.defineProperty,g=x((e,r)=>Ce(e,"name",{value:r,configurable:!0}),"s");const Se=/^([^:]+):(\d+)(?::(\d+))?\s+([\w/-]+)\s+(.+)$/,qe=g(e=>{const r=Se.exec(e);if(!r)return;const[,t,n,i,s,o]=r;return{column:i===void 0?void 0:Number(i),file:t,line:Number(n),message:o,ruleId:s}},"tryParseFindingLine"),We=g(e=>e.startsWith("/")||/^[a-z]:[\\/]/i.test(e),"isAbsolutePath"),Oe={argsCheck:g((e,r)=>E(e,r,!1),"argsCheck"),argsFix:g((e,r)=>E(e,r,!0),"argsFix"),bin:g(()=>["pnpm","exec","markdownlint-cli2"],"bin"),cacheKey:g((e,r)=>{const t=["markdownlint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:g((e,r)=>{const t=c.markdownlint.packageNames.map(i=>j(r,i)).find(i=>i!==void 0),n=C(e,c.markdownlint.configFiles);if(!(!t&&!n))return{adapter:"markdownlint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["markdown","md"],id:"markdownlint",kind:"lint",parse:g((e,r)=>{const t=(e.stderr||e.stdout||"").trim();if(!t)return[];const n=[];for(const i of t.split(/\r?\n/)){const s=qe(i.trim());s&&n.push({adapter:"markdownlint",column:s.column,file:We(s.file)?s.file:`${r.root}/${s.file}`,fixable:!0,line:s.line,message:s.message,ruleId:s.ruleId,severity:"warning"})}return n},"parse")},E=g((e,r,t)=>{const n=[];return t&&n.push("--fix"),r.extraArgs?.length&&n.push(...r.extraArgs),e.length===0?n.push("**/*.md"):n.push(...e),n},"buildArgs");var Ne=Object.defineProperty,w=x((e,r)=>Ne(e,"name",{value:r,configurable:!0}),"t");const Pe={advice:"info",error:"error",warning:"warning"},_e={argsCheck:w((e,r)=>B(e,r,!1),"argsCheck"),argsFix:w((e,r)=>B(e,r,!0),"argsFix"),bin:w(()=>["pnpm","exec","oxlint"],"bin"),cacheKey:w((e,r)=>{const t=["oxlint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:w((e,r)=>{const t=j(r,c.oxlint.packageNames[0]),n=C(e,c.oxlint.configFiles);if(!(!t&&!n))return{adapter:"oxlint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["astro","cjs","cts","js","jsx","mjs","mts","svelte","ts","tsx","vue"],id:"oxlint",kind:"lint",parse:w((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"oxlint",file:r.root,fixable:!1,message:`oxlint output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t.diagnostics??[]){const s=i.labels?.[0]?.span;n.push({adapter:"oxlint",column:s?.column,file:i.filename??r.root,fixable:!1,line:s?.line,message:i.message??"",ruleId:i.code,severity:Pe[i.severity??""]??"warning"})}return n},"parse")},B=w((e,r,t)=>{const n=["--format","json"];return t&&n.push("--fix"),r.quiet&&n.push("--quiet"),typeof r.maxWarnings=="number"&&n.push(`--max-warnings=${String(r.maxWarnings)}`),r.extraArgs?.length&&n.push(...r.extraArgs),n.push(...e),n},"buildArgs");var Ie=Object.defineProperty,f=x((e,r)=>Ie(e,"name",{value:r,configurable:!0}),"i$1");const Le={error:"error",info:"info",style:"info",warning:"warning"},Ke=f(e=>e.startsWith("/")||/^[a-z]:[\\/]/i.test(e),"isAbsolutePath"),Me=f((e,r)=>e?Ke(e)?e:`${r}/${e}`:r,"resolveFilename"),Ve={argsCheck:f((e,r)=>z(e,r),"argsCheck"),argsFix:f((e,r)=>z(e,r),"argsFix"),bin:f(()=>["shellcheck"],"bin"),cacheKey:f((e,r)=>{const t=["shellcheck",e.declaredVersion??"unknown",e.configFile??"no-config",r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:f((e,r)=>{const t=j(r,c.shellcheck.packageNames[0]),n=C(e,c.shellcheck.configFiles);if(!(!t&&!n))return{adapter:"shellcheck",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["bash","ksh","sh"],id:"shellcheck",kind:"lint",parse:f((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"shellcheck",file:r.root,fixable:!1,message:`shellcheck output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t.comments??[])n.push({adapter:"shellcheck",column:i.column,endColumn:i.endColumn,endLine:i.endLine,file:Me(i.file,r.root),fixable:!!i.fix,line:i.line,message:i.message??"",ruleId:i.code===void 0?void 0:`SC${String(i.code)}`,severity:Le[i.level??""]??"warning"});return n},"parse")},z=f((e,r)=>{const t=["--format=json1"];return r.extraArgs?.length&&t.push(...r.extraArgs),t.push(...e),t},"buildArgs");var Je=Object.defineProperty,y=x((e,r)=>Je(e,"name",{value:r,configurable:!0}),"i");const Re={error:"error",warning:"warning"},Te={argsCheck:y((e,r)=>H(e,r,!1),"argsCheck"),argsFix:y((e,r)=>H(e,r,!0),"argsFix"),bin:y(()=>["pnpm","exec","stylelint"],"bin"),cacheKey:y((e,r)=>{const t=["stylelint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:y((e,r)=>{const t=j(r,c.stylelint.packageNames[0]),n=C(e,c.stylelint.configFiles);if(!(!t&&!n))return{adapter:"stylelint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["astro","css","less","sass","scss","svelte","vue"],id:"stylelint",kind:"lint",parse:y((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"stylelint",file:r.root,fixable:!1,message:`stylelint output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t)for(const s of i.warnings??[])n.push({adapter:"stylelint",column:s.column,endColumn:s.endColumn,endLine:s.endLine,file:i.source,fixable:!1,line:s.line,message:s.text??"",ruleId:s.rule,severity:Re[s.severity??""]??"warning"});return n},"parse")},H=y((e,r,t)=>{const n=["--formatter","json"];return t&&n.push("--fix"),r.quiet&&n.push("--quiet"),typeof r.maxWarnings=="number"&&n.push("--max-warnings",String(r.maxWarnings)),r.extraArgs?.length&&n.push(...r.extraArgs),n.push(...e),n},"buildArgs");var Ee=Object.defineProperty,p=x((e,r)=>Ee(e,"name",{value:r,configurable:!0}),"a");const Be=[_e,oe,je,Te,le,Oe,Ve,ce],tr=p(async({logger:e,options:r,visConfig:t,workspaceRoot:n})=>{const i=n??process.cwd(),s=t?.lint,o=ae(Be,s?.order),P=de(i,o),d=ue(P,o,"lint").filter(({adapter:l})=>s?.adapters?.[l.id]?.enabled!==!1);if(d.length===0){e.warn("vis lint: no linter detected in this workspace (looked for: oxlint, biome, eslint, stylelint, ruff, markdownlint, shellcheck, deno).");return}const _=p(l=>{const u=s?.adapters?.[l]?.extraArgs;return u&&u.length>0?[...u]:void 0},"baseExtraArgs"),q={extraArgs:void 0,maxWarnings:typeof r.maxWarnings=="number"?r.maxWarnings:void 0,quiet:r.quiet??!1},W=ze(r),Q=r.fix?"fix":"check";let m;if(r.staged){if(m=ge(i),m===void 0)e.warn("vis lint: could not resolve --staged (not a git repo or git unavailable). Falling back to a workspace-wide run.");else if(m.length===0){e.info(L("✓ lint: no staged files"));return}}else if(typeof r.since=="string"&&r.since.length>0){if(m=fe(i,r.since),m===void 0)e.warn(`vis lint: could not resolve --since ${r.since} (not a git repo or unknown ref). Falling back to a workspace-wide run.`);else if(m.length===0){e.info(L(`✓ lint: no files changed since ${r.since}`));return}}const K=W.length>0?W:void 0,X=se(i,void 0,void 0,!0),I=r.format??"human";I==="human"&&r.output!==void 0&&e.warn("vis lint: --output is ignored for the human format; pass --format json|minimal|sarif|junit|github to redirect findings to a file.");const M=p(async l=>{const u=l!==void 0&&l.length>0&&K===void 0,b=[];for(const{adapter:a,presence:A}of d){let h;if(u){if(h=pe(l,a.extensions),h.length===0)continue}else h=K??l??["."];const N=_(a.id),J={adapter:a,files:h,presence:A};N&&(J.options={...q,extraArgs:N}),b.push(J)}if(b.length===0)return;const Y=await me(b,q,Q,{cacheRoot:X}),O=b.map((a,A)=>{const h=Y[A],N=a.adapter.parse(h,a.presence);return{adapter:a.adapter,durationMs:h.durationMs,exitCode:h.exitCode,findings:N}}),$=he(O.map(a=>({adapter:a.adapter.id,durationMs:a.durationMs,exitCode:a.exitCode,findingCount:a.findings.length,findings:a.findings}))),k=I==="human"?void 0:xe({cwd:i,target:r.output});try{switch(I){case"github":{k.write(ye({runs:O.map(a=>({findings:a.findings})),workspaceRoot:i}));break}case"json":{k.write(`${JSON.stringify({findings:$.findings,runs:$.runs},null,2)}
1
+ var Z=Object.defineProperty;var x=(e,r)=>Z(e,"name",{value:r,configurable:!0});import{createRequire as ee}from"node:module";import{I as L,j as ne,E as R,T as G,e as U,q as ie}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{z as D}from"../packem_shared/readFileSync-DseCu8sg-DEq4Fn3a.js";import{aL as c,aM as se}from"./bin.js";import{d as j,f as C,r as ae,b as oe,u as le,v as ce,e as de,g as ue,s as ge,h as fe,w as pe,j as me,k as he,l as xe,m as ve,n as we,o as ye,p as ke,q as be,t as $e}from"../packem_shared/watch-loop-BpA_pxU9.js";const re=ee(import.meta.url),F=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,te=x(e=>{if(typeof F<"u"&&F.versions&&F.versions.node){const[r,t]=F.versions.node.split(".").map(Number);if(r>22||r===22&&t>=3||r===20&&t>=16)return F.getBuiltinModule(e)}return re(e)},"__cjs_getBuiltinModule"),{createHash:S}=te("node:crypto");var Ae=Object.defineProperty,v=x((e,r)=>Ae(e,"name",{value:r,configurable:!0}),"s$1");const Fe={1:"warning",2:"error"},je={argsCheck:v((e,r)=>T(e,r,!1),"argsCheck"),argsFix:v((e,r)=>T(e,r,!0),"argsFix"),bin:v(()=>["pnpm","exec","eslint"],"bin"),cacheKey:v((e,r)=>{const t=["eslint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:v((e,r)=>{const t=j(r,c.eslint.packageNames[0]),n=C(e,c.eslint.configFiles);if(!(!t&&!n))return{adapter:"eslint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["cjs","cts","js","jsx","mjs","mts","ts","tsx","vue"],id:"eslint",kind:"lint",parse:v((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"eslint",file:r.root,fixable:!1,message:`eslint output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t)for(const s of i.messages)n.push({adapter:"eslint",column:s.column,endColumn:s.endColumn,endLine:s.endLine,file:i.filePath,fixable:!!s.fix,line:s.line,message:s.message,ruleId:s.ruleId??void 0,severity:s.fatal?"error":Fe[s.severity]??"warning"});return n},"parse")},T=v((e,r,t)=>{const n=["--format","json","--no-error-on-unmatched-pattern"];return t&&n.push("--fix"),r.quiet&&n.push("--quiet"),typeof r.maxWarnings=="number"&&n.push("--max-warnings",String(r.maxWarnings)),r.extraArgs?.length&&n.push(...r.extraArgs),n.push(...e),n},"buildArgs");var Ce=Object.defineProperty,g=x((e,r)=>Ce(e,"name",{value:r,configurable:!0}),"s");const Se=/^([^:]+):(\d+)(?::(\d+))?\s+([\w/-]+)\s+(.+)$/,qe=g(e=>{const r=Se.exec(e);if(!r)return;const[,t,n,i,s,o]=r;return{column:i===void 0?void 0:Number(i),file:t,line:Number(n),message:o,ruleId:s}},"tryParseFindingLine"),We=g(e=>e.startsWith("/")||/^[a-z]:[\\/]/i.test(e),"isAbsolutePath"),Oe={argsCheck:g((e,r)=>E(e,r,!1),"argsCheck"),argsFix:g((e,r)=>E(e,r,!0),"argsFix"),bin:g(()=>["pnpm","exec","markdownlint-cli2"],"bin"),cacheKey:g((e,r)=>{const t=["markdownlint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:g((e,r)=>{const t=c.markdownlint.packageNames.map(i=>j(r,i)).find(i=>i!==void 0),n=C(e,c.markdownlint.configFiles);if(!(!t&&!n))return{adapter:"markdownlint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["markdown","md"],id:"markdownlint",kind:"lint",parse:g((e,r)=>{const t=(e.stderr||e.stdout||"").trim();if(!t)return[];const n=[];for(const i of t.split(/\r?\n/)){const s=qe(i.trim());s&&n.push({adapter:"markdownlint",column:s.column,file:We(s.file)?s.file:`${r.root}/${s.file}`,fixable:!0,line:s.line,message:s.message,ruleId:s.ruleId,severity:"warning"})}return n},"parse")},E=g((e,r,t)=>{const n=[];return t&&n.push("--fix"),r.extraArgs?.length&&n.push(...r.extraArgs),e.length===0?n.push("**/*.md"):n.push(...e),n},"buildArgs");var Ne=Object.defineProperty,w=x((e,r)=>Ne(e,"name",{value:r,configurable:!0}),"t");const Pe={advice:"info",error:"error",warning:"warning"},_e={argsCheck:w((e,r)=>B(e,r,!1),"argsCheck"),argsFix:w((e,r)=>B(e,r,!0),"argsFix"),bin:w(()=>["pnpm","exec","oxlint"],"bin"),cacheKey:w((e,r)=>{const t=["oxlint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:w((e,r)=>{const t=j(r,c.oxlint.packageNames[0]),n=C(e,c.oxlint.configFiles);if(!(!t&&!n))return{adapter:"oxlint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["astro","cjs","cts","js","jsx","mjs","mts","svelte","ts","tsx","vue"],id:"oxlint",kind:"lint",parse:w((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"oxlint",file:r.root,fixable:!1,message:`oxlint output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t.diagnostics??[]){const s=i.labels?.[0]?.span;n.push({adapter:"oxlint",column:s?.column,file:i.filename??r.root,fixable:!1,line:s?.line,message:i.message??"",ruleId:i.code,severity:Pe[i.severity??""]??"warning"})}return n},"parse")},B=w((e,r,t)=>{const n=["--format","json"];return t&&n.push("--fix"),r.quiet&&n.push("--quiet"),typeof r.maxWarnings=="number"&&n.push(`--max-warnings=${String(r.maxWarnings)}`),r.extraArgs?.length&&n.push(...r.extraArgs),n.push(...e),n},"buildArgs");var Ie=Object.defineProperty,f=x((e,r)=>Ie(e,"name",{value:r,configurable:!0}),"i$1");const Le={error:"error",info:"info",style:"info",warning:"warning"},Ke=f(e=>e.startsWith("/")||/^[a-z]:[\\/]/i.test(e),"isAbsolutePath"),Me=f((e,r)=>e?Ke(e)?e:`${r}/${e}`:r,"resolveFilename"),Ve={argsCheck:f((e,r)=>z(e,r),"argsCheck"),argsFix:f((e,r)=>z(e,r),"argsFix"),bin:f(()=>["shellcheck"],"bin"),cacheKey:f((e,r)=>{const t=["shellcheck",e.declaredVersion??"unknown",e.configFile??"no-config",r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:f((e,r)=>{const t=j(r,c.shellcheck.packageNames[0]),n=C(e,c.shellcheck.configFiles);if(!(!t&&!n))return{adapter:"shellcheck",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["bash","ksh","sh"],id:"shellcheck",kind:"lint",parse:f((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"shellcheck",file:r.root,fixable:!1,message:`shellcheck output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t.comments??[])n.push({adapter:"shellcheck",column:i.column,endColumn:i.endColumn,endLine:i.endLine,file:Me(i.file,r.root),fixable:!!i.fix,line:i.line,message:i.message??"",ruleId:i.code===void 0?void 0:`SC${String(i.code)}`,severity:Le[i.level??""]??"warning"});return n},"parse")},z=f((e,r)=>{const t=["--format=json1"];return r.extraArgs?.length&&t.push(...r.extraArgs),t.push(...e),t},"buildArgs");var Je=Object.defineProperty,y=x((e,r)=>Je(e,"name",{value:r,configurable:!0}),"i");const Re={error:"error",warning:"warning"},Te={argsCheck:y((e,r)=>H(e,r,!1),"argsCheck"),argsFix:y((e,r)=>H(e,r,!0),"argsFix"),bin:y(()=>["pnpm","exec","stylelint"],"bin"),cacheKey:y((e,r)=>{const t=["stylelint",e.declaredVersion??"unknown",e.configFile??"no-config",r.maxWarnings===void 0?"":`mw=${r.maxWarnings}`,r.quiet?"q":"",...r.extraArgs??[]];return S("sha256").update(t.join("|")).digest("hex").slice(0,16)},"cacheKey"),detect:y((e,r)=>{const t=j(r,c.stylelint.packageNames[0]),n=C(e,c.stylelint.configFiles);if(!(!t&&!n))return{adapter:"stylelint",configFile:n,declared:!!t,declaredVersion:t,root:e}},"detect"),extensions:["astro","css","less","sass","scss","svelte","vue"],id:"stylelint",kind:"lint",parse:y((e,r)=>{if(!e.stdout.trim())return[];let t;try{t=JSON.parse(e.stdout)}catch{return[{adapter:"stylelint",file:r.root,fixable:!1,message:`stylelint output was not valid JSON (exit ${e.exitCode})`,severity:"error"}]}const n=[];for(const i of t)for(const s of i.warnings??[])n.push({adapter:"stylelint",column:s.column,endColumn:s.endColumn,endLine:s.endLine,file:i.source,fixable:!1,line:s.line,message:s.text??"",ruleId:s.rule,severity:Re[s.severity??""]??"warning"});return n},"parse")},H=y((e,r,t)=>{const n=["--formatter","json"];return t&&n.push("--fix"),r.quiet&&n.push("--quiet"),typeof r.maxWarnings=="number"&&n.push("--max-warnings",String(r.maxWarnings)),r.extraArgs?.length&&n.push(...r.extraArgs),n.push(...e),n},"buildArgs");var Ee=Object.defineProperty,p=x((e,r)=>Ee(e,"name",{value:r,configurable:!0}),"a");const Be=[_e,oe,je,Te,le,Oe,Ve,ce],tr=p(async({logger:e,options:r,visConfig:t,workspaceRoot:n})=>{const i=n??process.cwd(),s=t?.lint,o=ae(Be,s?.order),P=de(i,o),d=ue(P,o,"lint").filter(({adapter:l})=>s?.adapters?.[l.id]?.enabled!==!1);if(d.length===0){e.warn("vis lint: no linter detected in this workspace (looked for: oxlint, biome, eslint, stylelint, ruff, markdownlint, shellcheck, deno).");return}const _=p(l=>{const u=s?.adapters?.[l]?.extraArgs;return u&&u.length>0?[...u]:void 0},"baseExtraArgs"),q={extraArgs:void 0,maxWarnings:typeof r.maxWarnings=="number"?r.maxWarnings:void 0,quiet:r.quiet??!1},W=ze(r),Q=r.fix?"fix":"check";let m;if(r.staged){if(m=ge(i),m===void 0)e.warn("vis lint: could not resolve --staged (not a git repo or git unavailable). Falling back to a workspace-wide run.");else if(m.length===0){e.info(L("✓ lint: no staged files"));return}}else if(typeof r.since=="string"&&r.since.length>0){if(m=fe(i,r.since),m===void 0)e.warn(`vis lint: could not resolve --since ${r.since} (not a git repo or unknown ref). Falling back to a workspace-wide run.`);else if(m.length===0){e.info(L(`✓ lint: no files changed since ${r.since}`));return}}const K=W.length>0?W:void 0,X=se(i,void 0,void 0,!0),I=r.format??"human";I==="human"&&r.output!==void 0&&e.warn("vis lint: --output is ignored for the human format; pass --format json|minimal|sarif|junit|github to redirect findings to a file.");const M=p(async l=>{const u=l!==void 0&&l.length>0&&K===void 0,b=[];for(const{adapter:a,presence:A}of d){let h;if(u){if(h=pe(l,a.extensions),h.length===0)continue}else h=K??l??["."];const N=_(a.id),J={adapter:a,files:h,presence:A};N&&(J.options={...q,extraArgs:N}),b.push(J)}if(b.length===0)return;const Y=await me(b,q,Q,{cacheRoot:X}),O=b.map((a,A)=>{const h=Y[A],N=a.adapter.parse(h,a.presence);return{adapter:a.adapter,durationMs:h.durationMs,exitCode:h.exitCode,findings:N}}),$=he(O.map(a=>({adapter:a.adapter.id,durationMs:a.durationMs,exitCode:a.exitCode,findingCount:a.findings.length,findings:a.findings}))),k=I==="human"?void 0:xe({cwd:i,target:r.output});try{switch(I){case"github":{k.write(ye({runs:O.map(a=>({findings:a.findings})),workspaceRoot:i}));break}case"json":{k.write(`${JSON.stringify({findings:$.findings,runs:$.runs},null,2)}
2
2
  `);break}case"junit":{k.write(we({runs:O.map(a=>({adapter:a.adapter.id,durationMs:a.durationMs,findings:a.findings})),workspaceRoot:i}));break}case"minimal":{Ge($.findings,i,k);break}case"sarif":{k.write(ve({runs:O.map(a=>({adapter:a.adapter.id,findings:a.findings,presence:b.find(A=>A.adapter.id===a.adapter.id)?.presence})),workspaceRoot:i}));break}default:He($.findings,i,e)}}finally{k?.close()}const V=ke($);V!==0&&(process.exitCode=V)},"runCycle");if(r.watch){const l=[...new Set(d.flatMap(({adapter:u})=>u.extensions))];await be({extensions:l,initialFiles:m,label:"lint",log:p(u=>{e.info(u)},"log"),runCycle:M,workspaceRoot:i});return}await M(m)},"execute"),ze=p(e=>{const r=e;return[...r._??r.args??[]]},"collectPositional"),He=p((e,r,t)=>{if(e.length===0){t.info(L("✓ lint: no findings"));return}const n=$e(e);for(const[o,P]of n){t.info(ne(D(r,o)));for(const d of P){const _=Ue(d),q=De(d.severity),W=d.ruleId?R(` ${d.ruleId}`):"";t.info(` ${R(_)} ${q} ${d.message}${W}`)}}const i=e.filter(o=>o.severity==="error").length,s=e.filter(o=>o.severity==="warning").length;t.info(""),t.info(`${G(`${String(i)} error${i===1?"":"s"}`)}, ${U(`${String(s)} warning${s===1?"":"s"}`)}`)},"printHuman"),Ge=p((e,r,t)=>{for(const n of e){const i=D(r,n.file),s=n.line??"",o=n.column??"";t.write(`${n.adapter} ${i} ${String(s)} ${String(o)} ${n.severity} ${n.ruleId??""} ${n.message}
3
3
  `)}},"printMinimal"),Ue=p(e=>e.line===void 0?"":e.column===void 0?String(e.line):`${String(e.line)}:${String(e.column)}`,"formatLocation"),De=p(e=>e==="error"?G("error"):e==="warning"?U("warn "):ie("info "),"severityChipFor");export{tr as default};
@@ -1,4 +1,4 @@
1
- var $=Object.defineProperty;var w=(s,e)=>$(s,"name",{value:e,configurable:!0});import{createRequire as _}from"node:module";import{d as R,R as I,y as C}from"./bin.js";import{A as P}from"../packem_shared/pm-runner-DmKT2FqF.js";import{l as T}from"../packem_shared/dependency-scan-BUbOcMwX.js";import{r as D}from"../packem_shared/provenance-DkCA8BrN.js";import{r as x}from"../packem_shared/signatures-byuFrtAH.js";import{loadOptionalSigstore as q}from"./loader.js";const N=_(import.meta.url),d=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,y=w(s=>{if(typeof d<"u"&&d.versions&&d.versions.node){const[e,o]=d.versions.node.split(".").map(Number);if(e>22||e===22&&o>=3||e===20&&o>=16)return d.getBuiltinModule(s)}return N(s)},"__cjs_getBuiltinModule"),{createHash:O}=y("node:crypto"),{readFileSync:E,writeFileSync:j}=y("node:fs"),{isAbsolute:k,resolve:S,basename:v}=y("node:path");var J=Object.defineProperty,u=w((s,e)=>J(s,"name",{value:e,configurable:!0}),"d");const U=u(s=>(s??"").split(",").map(e=>e.trim()).filter(e=>e.length>0),"splitList"),W=u(async({logger:s,options:e,workspaceRoot:o})=>{if(!o)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");const i=e.format??"table",p=e.prodOnly??!1,m=e.failOn==="error"?"error":"warning",n=U(e.allowlist),h=P(o),l=T(o,h.name,{includeDev:!p}).map(({name:t,version:r})=>({name:t,version:r})),[g,c]=await Promise.all([D(l,{allowlist:n,workspaceRoot:o}),x(l,{allowlist:n,workspaceRoot:o})]),a=[...g.map(t=>({code:"provenance-regression",message:`Resolved ${t.packageName}@${t.version} has no published provenance attestation, but ${t.packageName}@${t.priorVersionWithProvenance} did — a provenance regression.`,packageName:t.packageName,severity:"warning",version:t.version})),...c.map(t=>({code:t.code,message:t.message,packageName:t.packageName,severity:t.severity,version:t.version}))],f=a.filter(t=>m==="error"?t.severity==="error":!0);if(i==="json")process.stdout.write(`${JSON.stringify({findings:a,ok:f.length===0},void 0,2)}
1
+ var $=Object.defineProperty;var w=(s,e)=>$(s,"name",{value:e,configurable:!0});import{createRequire as _}from"node:module";import{d as R,R as I,y as C}from"./bin.js";import{A as P}from"../packem_shared/pm-runner-DmKT2FqF.js";import{l as T}from"../packem_shared/dependency-scan-BUbOcMwX.js";import{r as D}from"../packem_shared/provenance-D8vU1u2L.js";import{r as x}from"../packem_shared/signatures-ChTfrQvT.js";import{loadOptionalSigstore as q}from"./loader.js";const N=_(import.meta.url),d=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,y=w(s=>{if(typeof d<"u"&&d.versions&&d.versions.node){const[e,o]=d.versions.node.split(".").map(Number);if(e>22||e===22&&o>=3||e===20&&o>=16)return d.getBuiltinModule(s)}return N(s)},"__cjs_getBuiltinModule"),{createHash:O}=y("node:crypto"),{readFileSync:E,writeFileSync:j}=y("node:fs"),{isAbsolute:k,resolve:S,basename:v}=y("node:path");var J=Object.defineProperty,u=w((s,e)=>J(s,"name",{value:e,configurable:!0}),"d");const U=u(s=>(s??"").split(",").map(e=>e.trim()).filter(e=>e.length>0),"splitList"),W=u(async({logger:s,options:e,workspaceRoot:o})=>{if(!o)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");const i=e.format??"table",p=e.prodOnly??!1,m=e.failOn==="error"?"error":"warning",n=U(e.allowlist),h=P(o),l=T(o,h.name,{includeDev:!p}).map(({name:t,version:r})=>({name:t,version:r})),[g,c]=await Promise.all([D(l,{allowlist:n,workspaceRoot:o}),x(l,{allowlist:n,workspaceRoot:o})]),a=[...g.map(t=>({code:"provenance-regression",message:`Resolved ${t.packageName}@${t.version} has no published provenance attestation, but ${t.packageName}@${t.priorVersionWithProvenance} did — a provenance regression.`,packageName:t.packageName,severity:"warning",version:t.version})),...c.map(t=>({code:t.code,message:t.message,packageName:t.packageName,severity:t.severity,version:t.version}))],f=a.filter(t=>m==="error"?t.severity==="error":!0);if(i==="json")process.stdout.write(`${JSON.stringify({findings:a,ok:f.length===0},void 0,2)}
2
2
  `);else if(i==="ndjson")for(const t of a)process.stdout.write(`${JSON.stringify(t)}
3
3
  `);else if(a.length===0)s.info(`No provenance regressions or signature problems across ${String(l.length)} locked packages.`);else{const t=process.stdout.columns||80;s.info(R(I.createElement(C,{data:a.map(r=>({code:r.code,package:`${r.packageName}@${r.version}`,severity:r.severity}))}),{columns:t}));for(const r of a)s.warn(`${r.packageName}@${r.version}: ${r.message}`)}f.length>0&&(process.exitCode=1)},"attestVerifyExecute"),A=u(()=>process.env.CI==="true"||typeof process.env.ACTIONS_ID_TOKEN_REQUEST_URL=="string"||typeof process.env.SIGSTORE_ID_TOKEN=="string","detectAmbientOidc"),B=u((s,e,o)=>({_type:"https://in-toto.io/Statement/v1",predicate:{buildDefinition:{buildType:"https://visulima.com/vis/attest/v1",externalParameters:{workspaceRoot:o},internalParameters:{},resolvedDependencies:[]},runDetails:{builder:{id:"https://visulima.com/vis"},metadata:{invocationId:process.env.GITHUB_RUN_ID??"",startedOn:new Date().toISOString()}}},predicateType:"https://slsa.dev/provenance/v1",subject:[{digest:{sha256:e},name:s}]}),"buildSlsaStatement"),z=u(async({argument:s,logger:e,options:o,workspaceRoot:i})=>{if(!i)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");const p=s[0];if(!p)throw new Error("Missing subject. Usage: vis attest <path-to-artifact>");const m=o.predicate??"slsaProvenance";if(m!=="slsaProvenance")throw new Error(`Unsupported predicate '${m}'. Only 'slsaProvenance' is supported.`);const n=k(p)?p:S(i,p),h=o.requireSigning??!1,l=o.format??"table";let g;try{g=E(n)}catch{throw new Error(`Cannot read subject artifact at ${n}.`)}const c=O("sha256").update(g).digest("hex");if(!A()){const b="No ambient OIDC token (not running in CI). Keyless signing needs a Fulcio identity from CI OIDC.";if(h)throw new Error(`${b} Re-run in CI or drop --require-signing.`);if(l==="json"){process.stdout.write(`${JSON.stringify({ok:!1,reason:"no-ambient-oidc",sha256:c,skipped:!0,subject:v(n)},void 0,2)}
4
4
  `);return}e.warn(`${b} Skipping signing (subject sha256: ${c}). Pass --require-signing to make this fatal.`);return}const a=B(v(n),c,i),f=Buffer.from(JSON.stringify(a)),t=await(await q({workspaceRoot:i})).attest(f,"application/vnd.in-toto+json"),r=o.output?k(o.output)?o.output:S(i,o.output):`${n}.sigstore`;if(j(r,`${JSON.stringify(t,void 0,2)}