@visulima/vis 0.0.1 → 1.0.0-alpha.10

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 (86) hide show
  1. package/CHANGELOG.md +360 -0
  2. package/LICENSE.md +91 -0
  3. package/README.md +364 -29
  4. package/dist/bin.js +2 -0
  5. package/dist/errors/index.d.ts +26 -0
  6. package/dist/errors/index.js +1 -0
  7. package/dist/generate/index.d.ts +157 -0
  8. package/dist/generate/index.js +1 -0
  9. package/dist/packem_chunks/bin.js +87 -0
  10. package/dist/packem_chunks/config.js +2 -0
  11. package/dist/packem_chunks/fix.js +53 -0
  12. package/dist/packem_chunks/handler.js +1 -0
  13. package/dist/packem_chunks/handler10.js +1 -0
  14. package/dist/packem_chunks/handler11.js +1 -0
  15. package/dist/packem_chunks/handler12.js +2 -0
  16. package/dist/packem_chunks/handler13.js +1 -0
  17. package/dist/packem_chunks/handler14.js +5 -0
  18. package/dist/packem_chunks/handler15.js +1 -0
  19. package/dist/packem_chunks/handler16.js +20 -0
  20. package/dist/packem_chunks/handler17.js +1 -0
  21. package/dist/packem_chunks/handler18.js +1 -0
  22. package/dist/packem_chunks/handler19.js +1 -0
  23. package/dist/packem_chunks/handler2.js +1 -0
  24. package/dist/packem_chunks/handler20.js +1 -0
  25. package/dist/packem_chunks/handler21.js +1 -0
  26. package/dist/packem_chunks/handler22.js +5 -0
  27. package/dist/packem_chunks/handler23.js +1 -0
  28. package/dist/packem_chunks/handler24.js +1 -0
  29. package/dist/packem_chunks/handler25.js +5 -0
  30. package/dist/packem_chunks/handler26.js +1 -0
  31. package/dist/packem_chunks/handler27.js +3 -0
  32. package/dist/packem_chunks/handler28.js +1 -0
  33. package/dist/packem_chunks/handler29.js +7 -0
  34. package/dist/packem_chunks/handler3.js +2 -0
  35. package/dist/packem_chunks/handler30.js +23 -0
  36. package/dist/packem_chunks/handler31.js +3 -0
  37. package/dist/packem_chunks/handler32.js +2 -0
  38. package/dist/packem_chunks/handler33.js +24 -0
  39. package/dist/packem_chunks/handler34.js +2 -0
  40. package/dist/packem_chunks/handler35.js +19 -0
  41. package/dist/packem_chunks/handler36.js +428 -0
  42. package/dist/packem_chunks/handler37.js +22 -0
  43. package/dist/packem_chunks/handler38.js +22 -0
  44. package/dist/packem_chunks/handler39.js +22 -0
  45. package/dist/packem_chunks/handler4.js +4 -0
  46. package/dist/packem_chunks/handler40.js +3 -0
  47. package/dist/packem_chunks/handler41.js +10 -0
  48. package/dist/packem_chunks/handler42.js +153 -0
  49. package/dist/packem_chunks/handler43.js +42 -0
  50. package/dist/packem_chunks/handler44.js +3 -0
  51. package/dist/packem_chunks/handler45.js +27 -0
  52. package/dist/packem_chunks/handler5.js +2 -0
  53. package/dist/packem_chunks/handler6.js +13 -0
  54. package/dist/packem_chunks/handler7.js +8 -0
  55. package/dist/packem_chunks/handler8.js +1 -0
  56. package/dist/packem_chunks/handler9.js +1 -0
  57. package/dist/packem_chunks/index.js +7 -0
  58. package/dist/packem_chunks/loader.js +1 -0
  59. package/dist/packem_shared/VisConfigCycleError-CAYNC7d-.js +1 -0
  60. package/dist/packem_shared/VisConfigError-B5LP1zRf.js +1 -0
  61. package/dist/packem_shared/VisConfigLoadError-CeqBSd2Z.js +2 -0
  62. package/dist/packem_shared/VisConfigNotFoundError-DZ9KC527.js +5 -0
  63. package/dist/packem_shared/VisUpdateApp-D-L4_-Iu.js +1 -0
  64. package/dist/packem_shared/_commonjsHelpers-D6W6KoPK.js +1 -0
  65. package/dist/packem_shared/ai-analysis-CGuy7dfE.js +67 -0
  66. package/dist/packem_shared/ai-cache-Bynt6Y9x.js +1 -0
  67. package/dist/packem_shared/cache-directory-D72ZEag2.js +1 -0
  68. package/dist/packem_shared/catalog-BVPerCwG.js +12 -0
  69. package/dist/packem_shared/dependency-scan-Du0tBu64.js +2 -0
  70. package/dist/packem_shared/docker-BcfqH4Av.js +2 -0
  71. package/dist/packem_shared/failure-log-DqYen0LC.js +2 -0
  72. package/dist/packem_shared/flakiness-DSIHZGBT.js +1 -0
  73. package/dist/packem_shared/run-summary-utils-C24Aaf9E.js +1 -0
  74. package/dist/packem_shared/runtime-check-CGHal8SO.js +1 -0
  75. package/dist/packem_shared/selectors-CfH9ZY08.js +3 -0
  76. package/dist/packem_shared/symbols-CQmER5MT.js +1 -0
  77. package/dist/packem_shared/target-merge-DNa-6eWu.js +1 -0
  78. package/dist/packem_shared/toolchain-DQfTQY8E.js +5 -0
  79. package/dist/packem_shared/typosquats-DOR8izpX.js +1 -0
  80. package/dist/packem_shared/use-measured-height-DjYgUOKk.js +1 -0
  81. package/dist/packem_shared/utils-DrNg0XTR.js +1 -0
  82. package/dist/packem_shared/xxh3-DrAUNq4n.js +1 -0
  83. package/index.js +601 -0
  84. package/package.json +124 -7
  85. package/schemas/project.schema.json +422 -0
  86. package/schemas/vis-config.schema.json +377 -0
@@ -0,0 +1,2 @@
1
+ var x=Object.defineProperty;var m=(e,t)=>x(e,"name",{value:t,configurable:!0});import{createRequire as A}from"node:module";import{findCacheDirSync as D}from"@visulima/find-cache-dir";import{isAccessibleSync as d,ensureDirSync as y,readJsonSync as V,writeJsonSync as T}from"@visulima/fs";import{join as f,dirname as v,isAbsolute as B}from"@visulima/path";import{createJiti as b}from"jiti";import{m as J}from"../packem_shared/target-merge-DNa-6eWu.js";import{VisConfigCycleError as L}from"../packem_shared/VisConfigCycleError-CAYNC7d-.js";import{VisConfigLoadError as S}from"../packem_shared/VisConfigLoadError-CeqBSd2Z.js";import{VisConfigNotFoundError as C}from"../packem_shared/VisConfigNotFoundError-DZ9KC527.js";const R=A(import.meta.url),l=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,g=m(e=>{if(typeof l<"u"&&l.versions&&l.versions.node){const[t,s]=l.versions.node.split(".").map(Number);if(t>22||t===22&&s>=3||t===20&&s>=16)return l.getBuiltinModule(e)}return R(e)},"__cjs_getBuiltinModule"),{createHash:j}=g("node:crypto"),{readdirSync:_,copyFileSync:I,unlinkSync:P,readFileSync:$}=g("node:fs"),{createRequire:q}=g("node:module"),{tmpdir:N}=g("node:os");var M=Object.defineProperty,n=m((e,t)=>M(e,"name",{value:t,configurable:!0}),"r");const F=["vis.config.ts","vis.config.mts","vis.config.cts","vis.config.js","vis.config.mjs","vis.config.cjs"],U=new Set(F),G=["vis.task.ts","vis.task.mts","vis.task.cts","vis.task.js","vis.task.mjs","vis.task.cjs"],W=new Set(G),z={blockExoticSubdeps:!0,strictDepBuilds:!0,trustPolicy:"no-downgrade",trustPolicyIgnoreAfter:43200},H=n(e=>({...z,...e}),"mergeSecurityDefaults"),k=n(e=>({...e,security:H(e.security),update:{security:!0,target:"minor",...e.update}}),"applyDefaults"),K=n(e=>{let t;try{t=_(e)}catch{return}const s=new Set(t.filter(r=>U.has(r)));for(const r of F)if(s.has(r))return f(e,r)},"findVisConfigFile"),Y=n(e=>{let t;try{t=_(e)}catch{return}const s=new Set(t.filter(r=>W.has(r)));for(const r of G)if(s.has(r))return f(e,r)},"findVisTaskConfigFile"),w=n(e=>j("sha256").update($(e)).digest("hex"),"hashFileContents"),Q=n(e=>{const t=j("sha256"),s=[...e].sort();for(const r of s)t.update(r),t.update(":"),t.update(w(r)),t.update(`
2
+ `);return t.digest("hex")},"hashConfigChain"),X=n(e=>{const t=f(e,"node_modules");if(d(t)){const r=f(t,".cache","vis");return y(r),f(r,"vis-config-cache.json")}const s=D("vis",{create:!0,cwd:e});return s?f(s,"vis-config-cache.json"):void 0},"getConfigCachePath"),Z=n((e,t)=>{if(d(e))try{const s=V(e);if(s.hash===t)return s.config}catch{}},"readConfigCache"),ee=n((e,t,s)=>{try{y(v(e)),T(e,{config:s,hash:t})}catch{}},"writeConfigCache"),te=n(e=>e===void 0?[]:Array.isArray(e)?e:[e],"normalizeExtends"),se=n((e,t,s)=>{if(B(e))throw new C(e,[...s,t],["Absolute paths in `extends` are not supported. Use a relative path or an npm package name."]);const r=[];if(e.startsWith("./")||e.startsWith("../")){const o=v(t),i=f(o,e);if(r.push(i),d(i))return i;throw new C(e,[...s,t],r)}try{return q(t).resolve(e)}catch{throw r.push(`require.resolve("${e}") from ${t}`),new C(e,[...s,t],r)}},"resolveExtendsSpecifier"),E=n(async(e,t,s)=>{const r=w(t),o=t.slice(t.lastIndexOf(".")),i=f(N(),`vis-config-${r}${o}`);I(t,i);let c;try{c=await e.import(i,{default:!0,try:!0})??{}}catch(a){throw new S(t,s,a)}finally{try{P(i)}catch{}}try{return(typeof c=="function"?await c()??{}:c)??{}}catch(a){throw new S(t,s,a)}},"loadRawConfig"),re=n((e,t)=>{const s={...e,...t};if(e.targetDefaults||t.targetDefaults){const r=new Set([...Object.keys(e.targetDefaults??{}),...Object.keys(t.targetDefaults??{})]),o={};for(const i of r)o[i]=J(e.targetDefaults?.[i],t.targetDefaults?.[i]);s.targetDefaults=o}return(e.taskDefaults||t.taskDefaults)&&(s.taskDefaults=[...e.taskDefaults??[],...t.taskDefaults??[]]),(e.fileGroups||t.fileGroups)&&(s.fileGroups={...e.fileGroups,...t.fileGroups}),(e.taskGroups||t.taskGroups)&&(s.taskGroups={...e.taskGroups,...t.taskGroups}),(e.security||t.security)&&(s.security={...e.security,...t.security}),(e.update||t.update)&&(s.update={...e.update,...t.update}),(e.taskRunnerOptions||t.taskRunnerOptions)&&(s.taskRunnerOptions={...e.taskRunnerOptions,...t.taskRunnerOptions}),delete s.extends,s},"mergeVisConfigs"),O=n(async(e,t,s,r,o,i)=>{if(r.has(t))throw new L(t,s);if(!o.has(t)){r.add(t);try{const c=await E(e,t,s),a=te(c.extends);for(const u of a){const p=se(u,t,s);await O(e,p,[...s,t],r,o,i)}o.set(t,c),i.push(t)}finally{r.delete(t)}}},"resolveConfigChain"),Ce=n(async e=>{const t=K(e);if(!t)return k({});const s=b(e,{fsCache:!1,moduleCache:!1}),r=new Set,o=new Map,i=[];await O(s,t,[],r,o,i);const c=Q(i),a=X(e);if(a){const h=Z(a,c);if(h)return h}let u={};for(const h of i)u=re(u,o.get(h));const p=k(u);return a&&ee(a,c,p),p},"loadVisConfig"),ie=n(e=>e.replaceAll(/[^\w.-]+/g,"_"),"sanitizeProjectName"),ne=n((e,t)=>{const s=f(e,"node_modules"),r=ie(t);if(d(s)){const i=f(s,".cache","vis","task-configs");return y(i),f(i,`${r}.json`)}const o=D("vis",{create:!0,cwd:e});return o?f(o,"task-configs",`${r}.json`):void 0},"getVisTaskCachePath"),oe=n((e,t)=>{if(d(e))try{const s=V(e);if(s.hash===t)return s.config}catch{}},"readVisTaskCache"),ae=n((e,t,s)=>{try{y(v(e)),T(e,{config:s,hash:t})}catch{}},"writeVisTaskCache"),ke=n(async(e,t,s)=>{const r=Y(t);if(!r)return;const o=w(r),i=ne(e,s);if(i){const u=oe(i,o);if(u)return u}const c=b(t,{fsCache:!1,moduleCache:!1}),a=await E(c,r,[]);return i&&ae(i,o,a),a},"loadVisTaskConfig");n(e=>e,"defineTaskConfig");n(e=>k(e),"defineConfig");n(e=>e,"definePlugin");export{F as CONFIG_FILES,z as SECURITY_DEFAULTS,G as TASK_CONFIG_FILES,k as applyDefaults,K as findVisConfigFile,Y as findVisTaskConfigFile,Ce as loadVisConfig,ke as loadVisTaskConfig};
@@ -0,0 +1,53 @@
1
+ var J=Object.defineProperty;var y=(t,e)=>J(t,"name",{value:e,configurable:!0});import{createRequire as L}from"node:module";import{bold as P,dim as O,yellow as j,cyan as K,red as E,green as M}from"@visulima/colorize";import{isAbsolute as B,resolve as T,join as z,relative as F}from"@visulima/path";import{readLastRunSummary as G}from"@visulima/task-runner";import{l as Q,a as N}from"../packem_shared/failure-log-DqYen0LC.js";import{r as V,f as R,a as X,d as Z}from"../packem_shared/run-summary-utils-C24Aaf9E.js";import{w as rt,b as at,r as it}from"../packem_shared/ai-analysis-CGuy7dfE.js";import{M as ot,N as st,O as nt}from"../packem_shared/ai-cache-Bynt6Y9x.js";import{p as d}from"./bin.js";const U=L(import.meta.url),$=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,_=y(t=>{if(typeof $<"u"&&$.versions&&$.versions.node){const[e,r]=$.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return $.getBuiltinModule(t)}return U(t)},"__cjs_getBuiltinModule"),{createInterface:Y}=_("node:readline"),{readFile:tt,writeFile:et}=_("node:fs/promises");var ut=Object.defineProperty,k=y((t,e)=>ut(t,"name",{value:e,configurable:!0}),"u");const ct=32*1024,pt=k((t,e)=>{if(t.length<=e)return t;const r=t.slice(-e),a=t.length-r.length;return`[…${String(a)} bytes truncated from head…]
2
+ ${r}`},"truncateHead"),lt=k(async(t,e)=>e===void 0?G(t):V(t,e),"loadSummary"),dt=k(async(t,e,r={})=>{const a=r.terminalOutputLimit??ct,[o,s]=await Promise.all([Q(t,e),lt(t,r.runId)]),i=s?R(s,e):void 0;if(!o&&!i)return;let n,u;if(s&&i){const c=await X(t,s.id),h=c?R(c,e):void 0;n=Z(i.hashDetails,h?.hashDetails),u=c?.id}const l=o?.terminalOutput??"";return{command:o?.command??void 0,cwd:o?.cwd??void 0,dependencies:i?.dependencies??[],duration:i?.duration,exitCode:o?.exitCode??i?.exitCode,hash:i?.hash??o?.hash,hashDetails:i?.hashDetails,hashDiff:n,previousRunId:u,project:i?.target.project,runId:s?.id??o?.runId,status:o?.status??(i?ht(i):void 0),target:i?.target.target,taskId:e,terminalOutput:pt(l,a),terminalOutputCaptured:!!o,timestamp:o?.timestamp??i?.endTime??i?.startTime}},"aggregateFailureContext"),ht=k(t=>{if(t.exitCode!==void 0&&t.exitCode!==0)return"failure";switch(t.cacheStatus){case"HIT":return"local-cache";case"REMOTE_HIT":return"remote-cache";case"SKIPPED":return"skipped";default:return t.exitCode===0?"success":void 0}},"mapCacheStatusToTaskStatus");var ft=Object.defineProperty,p=y((t,e)=>ft(t,"name",{value:e,configurable:!0}),"a");const mt=3600*1e3,D=80,gt=new Set(["high","low","medium"]),wt=p(()=>`You are an expert software engineer helping fix a failing build/test/lint task.
3
+
4
+ You will be given:
5
+ - The terminal output (stdout/stderr) from the failed task.
6
+ - Optional metadata: command, working directory, project, task hash, and a diff describing what changed in the task's hash inputs since the previous run that did not fail.
7
+
8
+ Your job:
9
+ 1. Identify the root cause from the terminal output.
10
+ 2. Propose a minimal set of source-file patches that fix the cause.
11
+ 3. If you cannot determine a safe fix, set "cannotFix" with a clear, actionable explanation.
12
+
13
+ Constraints:
14
+ - Patches MUST be exact string replacements. The "oldString" must appear verbatim in the named file. Paths are relative to the working directory.
15
+ - Each "oldString" must be unique within its file. Include surrounding context so the match is unambiguous.
16
+ - Do NOT include unrelated cleanup, formatting changes, or speculative refactors.
17
+ - If the failure is environmental (missing tool, network) or requires running commands, prefer "cannotFix" over a guess.
18
+ - Keep "explanation" short (1-3 sentences). Reserve "reason" on each patch for why that specific edit fixes the cause.
19
+
20
+ Respond ONLY with valid JSON in this exact structure:
21
+ {
22
+ "explanation": "Brief root-cause analysis and what the fix does.",
23
+ "confidence": "low|medium|high",
24
+ "patches": [
25
+ {
26
+ "file": "path/relative/to/cwd.ts",
27
+ "oldString": "exact text to find",
28
+ "newString": "exact replacement text",
29
+ "reason": "why this change fixes it"
30
+ }
31
+ ],
32
+ "cannotFix": "optional — set when no safe patch can be proposed"
33
+ }`,"buildSystemPrompt"),C=p((t,e)=>{const r=[];if(e.added.length>0&&r.push(` added: ${e.added.join(", ")}`),e.changed.length>0&&r.push(` changed: ${e.changed.join(", ")}`),e.removed.length>0&&r.push(` removed: ${e.removed.join(", ")}`),r.length!==0)return`- ${t}:
34
+ ${r.join(`
35
+ `)}`},"formatBucket"),vt=p(t=>{if(!t.hashDiff)return"No hash-diff available — there is no previous run to compare against.";const e=[];t.hashDiff.commandChanged&&e.push("- command line changed since previous run");const r=C("file inputs",t.hashDiff.nodes),a=C("implicit deps",t.hashDiff.implicitDeps),o=C("runtime/env",t.hashDiff.runtime);return r&&e.push(r),a&&e.push(a),o&&e.push(o),e.length===0?"No detectable changes between this run and the previous run.":e.join(`
36
+ `)},"buildHashDiffSummary"),xt=p(t=>{const e=[];return e.push(`Task: ${t.taskId}`),t.project&&e.push(`Project: ${t.project}`),t.target&&e.push(`Target: ${t.target}`),t.command&&e.push(`Command: ${t.command}`),t.cwd&&e.push(`CWD: ${t.cwd}`),t.exitCode!==void 0&&e.push(`Exit code: ${String(t.exitCode)}`),t.hash&&e.push(`Task hash: ${t.hash}`),e.push("","Hash-diff since previous run:",vt(t),""),t.terminalOutputCaptured?e.push("Terminal output:","```",t.terminalOutput,"```"):e.push("Terminal output: <no failure log was captured for this task>",'Set "cannotFix" and tell the user to re-run with `vis run` so logs can be captured.'),e.join(`
37
+ `)},"buildUserPrompt"),yt=p(t=>`${wt()}
38
+
39
+ ${xt(t)}`,"buildFixPrompt"),$t=p((t,e)=>{const r=Array.isArray(t.patches)?t.patches:[],a=[];for(const s of r)typeof s.file!="string"||s.file.length===0||typeof s.oldString!="string"||s.oldString.length===0||typeof s.newString=="string"&&a.push({file:s.file,newString:s.newString,oldString:s.oldString,reason:typeof s.reason=="string"&&s.reason.length>0?s.reason:void 0});const o=typeof t.cannotFix=="string"&&t.cannotFix.length>0?t.cannotFix:void 0;return{cannotFix:o,confidence:gt.has(t.confidence)?t.confidence:"low",explanation:typeof t.explanation=="string"?t.explanation:"",patches:o?[]:a,provider:e}},"normalizeFixProposal"),bt=p((t,e)=>{const r=rt(t);return!r||typeof r!="object"?{cannotFix:"AI response was not valid JSON.",confidence:"low",explanation:"Failed to parse AI response.",patches:[],provider:e}:$t(r,e)},"parseFixResponse"),St=p((t,e)=>ot({cwd:e.cwd??null,flow:"ai-fix",hash:e.hash??null,provider:t,taskId:e.taskId,terminalOutput:e.terminalOutput,terminalOutputCaptured:e.terminalOutputCaptured}),"buildFixCacheKey"),Pt=p(async(t,e,r={})=>{const a=at(r.config);if(!a){e.warn(`No AI provider available — install one of: claude, gemini, copilot, codex.
40
+ `);return}const o=r.cache!==!1,s=St(a.name,t);if(o){const i=st(s);if(i)return e.info(`Using cached fix proposal from ${i.provider}.
41
+ `),i}e.info(`Generating fix proposal with ${a.name}...
42
+ `);try{const i=await it(a,yt(t)),n=bt(i,a.name);return o&&n.patches.length>0&&!n.cannotFix&&nt(s,n,mt),n}catch(i){const n=i instanceof Error?i.message:String(i);e.warn(`AI fix proposal failed (${n}).
43
+ `);return}},"runFixAnalysis"),W=p((t,e,r)=>B(r)?T(r):T(z(e??t,r)),"resolvePatchPath"),kt=p((t,e)=>{const r=F(t,e);return r===""?!0:!r.startsWith("..")&&!B(r)},"isInsideWorkspace"),Ct=p((t,e,r)=>{const a=t.indexOf(e),o=Math.max(0,a-D),s=Math.min(t.length,a+e.length+D),i=t.slice(o,s);return{previewAfter:`${t.slice(o,a)}${r}${t.slice(a+e.length,s)}`,previewBefore:i}},"buildPreview"),S=p(async(t,e,r,a={})=>{const o=a.dryRun===!0,s=new Map,i=[];for(const n of r.patches){const u=W(t,e,n.file);if(!kt(t,u)){i.push({absolutePath:u,patch:n,status:"outside-workspace"});continue}let l=s.get(u);if(l===void 0){try{l=await tt(u,"utf8")}catch(m){const f=m.code;i.push({absolutePath:u,error:f==="ENOENT"?void 0:m.message,patch:n,status:f==="ENOENT"?"missing-file":"error"});continue}s.set(u,l)}const c=l.indexOf(n.oldString);if(c===-1){i.push({absolutePath:u,patch:n,status:"no-match"});continue}if(l.indexOf(n.oldString,c+n.oldString.length)!==-1){i.push({absolutePath:u,patch:n,status:"ambiguous-match"});continue}const{previewAfter:h,previewBefore:b}=Ct(l,n.oldString,n.newString),w=`${l.slice(0,c)}${n.newString}${l.slice(c+n.oldString.length)}`;if(!o)try{await et(u,w,"utf8")}catch(m){s.delete(u),i.push({absolutePath:u,error:m.message,patch:n,status:"error"});continue}s.set(u,w),i.push({absolutePath:u,patch:n,previewAfter:h,previewBefore:b,status:"applied"})}return i},"applyFixProposal");var It=Object.defineProperty,g=y((t,e)=>It(t,"name",{value:e,configurable:!0}),"c");const Ft={"ambiguous-match":"ambiguous match",applied:"applied",error:"error","missing-file":"missing file","no-match":"no match","outside-workspace":"outside workspace"},q=g((t,e,r)=>{const a=W(t,e,r),o=F(t,a);return o===""||o.startsWith("..")?a:o},"formatDisplayPath"),Ot=g((t,e,r)=>{const a=[];if(a.push(P(`Fix proposal (${t.provider}, confidence: ${t.confidence})`)),a.push(""),a.push(t.explanation||O("<no explanation>")),t.cannotFix)return a.push(""),a.push(j(`Cannot fix automatically: ${t.cannotFix}`)),a.join(`
44
+ `);if(t.patches.length===0)return a.push(""),a.push(j("No patches were proposed.")),a.join(`
45
+ `);a.push(""),a.push(P(`Patches (${String(t.patches.length)}):`));for(const[o,s]of t.patches.entries()){const i=q(e,r,s.file);a.push(""),a.push(K(`[${String(o+1)}] ${i}`)),s.reason&&a.push(O(` reason: ${s.reason}`));for(const n of s.oldString.split(`
46
+ `))a.push(E(` - ${n}`));for(const n of s.newString.split(`
47
+ `))a.push(M(` + ${n}`))}return a.join(`
48
+ `)},"formatProposalText"),A=g((t,e,r)=>{const a=[];for(const o of t){const s=o.absolutePath?F(e,o.absolutePath)||o.absolutePath:q(e,r,o.patch.file),i=Ft[o.status];o.status==="applied"?a.push(M(` ✓ ${s}: ${i}`)):a.push(E(` ✗ ${s}: ${i}${o.error?` (${o.error})`:""}`))}return a.join(`
49
+ `)},"formatPatchResultsText"),I=g(t=>{let e=0,r=0;for(const a of t)a.status==="applied"?e+=1:r+=1;return{applied:e,failed:r}},"summarizePatchResults"),jt=g(t=>new Promise(e=>{const r=Y({input:process.stdin,output:process.stderr});r.question(`${t} (y/N) `,a=>{r.close();const o=a.trim().toLowerCase();e(o==="y"||o==="yes")})}),"confirmPrompt"),Tt=g(t=>t??process.cwd(),"resolveWorkspaceRoot"),Ht=g(async({argument:t,logger:e,options:r,visConfig:a,workspaceRoot:o})=>{const s=t[0],i=Tt(o),n=(r.format??"text")==="json";if(!s){if(n){const v=N(i);process.stdout.write(`${JSON.stringify({availableTasks:v,error:"No task ID specified"},void 0,2)}
50
+ `)}else{d.error("No task ID specified. Usage: vis ai fix <project>:<target>");const v=N(i);if(v.length>0){d.info("Tasks with captured failure logs:");for(const x of v)d.info(` - ${x}`)}else d.notice("No failure logs found. Re-run a failing task with `vis run` to capture logs.")}process.exitCode=1;return}const u=await dt(i,s,{runId:r.run});if(!u){n?process.stdout.write(`${JSON.stringify({error:"No failure log or run summary found",taskId:s},void 0,2)}
51
+ `):(d.error(`No failure log or run summary found for task "${s}".`),d.notice("Re-run the task with `vis run` so its terminal output and run metadata are captured.")),process.exitCode=1;return}u.terminalOutputCaptured||d.warn(`No captured terminal output for "${s}". Re-run with \`vis run\` for a better fix proposal.`);const l=a?.ai,c=await Pt(u,e,{cache:r.noCache!==!0,config:l});if(!c){n&&process.stdout.write(`${JSON.stringify({error:"AI fix proposal failed or no provider available",taskId:s},void 0,2)}
52
+ `),process.exitCode=1;return}const h=r.apply===!0;if(n){const v=h?void 0:await S(i,u.cwd,c,{dryRun:!0}),x=h?await S(i,u.cwd,c):void 0;if(process.stdout.write(`${JSON.stringify({appliedResults:x,dryRunResults:v,failureContext:{cwd:u.cwd,hash:u.hash,runId:u.runId,taskId:u.taskId,terminalOutputCaptured:u.terminalOutputCaptured},proposal:c},void 0,2)}
53
+ `),h&&x){const{failed:H}=I(x);H>0&&(process.exitCode=1)}return}if(e.info(Ot(c,i,u.cwd)),c.cannotFix||c.patches.length===0)return;const b=await S(i,u.cwd,c,{dryRun:!0}),w=I(b);if(e.info(""),e.info(P("Patch validation:")),e.info(A(b,i,u.cwd)),!h){e.info(""),d.info("Re-run with --apply to write these patches to disk.");return}if(w.applied===0){d.error("No patches can be applied (every patch failed validation)."),process.exitCode=1;return}if(r.yes!==!0&&(e.info(""),!await jt(`Apply ${String(w.applied)} patch${w.applied===1?"":"es"} to disk?`))){d.notice("Aborted. Nothing written.");return}const m=await S(i,u.cwd,c),f=I(m);e.info(""),e.info(P("Apply results:")),e.info(A(m,i,u.cwd)),e.info(""),f.failed===0?d.success(`Applied ${String(f.applied)} patch${f.applied===1?"":"es"}.`):(d.warn(`${String(f.applied)} applied, ${String(f.failed)} failed.`),process.exitCode=1)},"aiFix");export{Ht as aiFix};
@@ -0,0 +1 @@
1
+ var O=Object.defineProperty;var w=(o,e)=>O(o,"name",{value:e,configurable:!0});import{createTaskGraph as b}from"@visulima/task-runner";import{r as E,s as R}from"./bin.js";import{r as x,f as G}from"../packem_shared/selectors-CfH9ZY08.js";var J=Object.defineProperty,m=w((o,e)=>J(o,"name",{value:e,configurable:!0}),"u");const P=m((o,e,n)=>{const c=[],t=new Set,l=m((r,f)=>{if(t.has(r))return;t.add(r);const s=e[r]??[];for(const i of s)l(i,f+1);const d=n[r],u=" ".repeat(f);c.push(`${u}${r}${d?.cache===!1?" (no-cache)":""}`)},"walk");for(const r of o)l(r,0);return c},"renderPlan"),S=m((o,e,n)=>({roots:o,tasks:Object.fromEntries(Object.entries(n).map(([c,t])=>[c,{cache:t.cache,dependsOn:e[c]??[],outputs:t.outputs,parallelism:t.parallelism,projectRoot:t.projectRoot,target:t.target}]))}),"toJson"),T=m(async({argument:o,logger:e,options:n,visConfig:c,workspaceRoot:t})=>{const l=o[0];if(!l)throw new Error("Missing selector. Usage: vis action-graph <selector>");if(!t)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{config:r,packageJsons:f,workspace:s}=E(t,c),d=R(t,s,f),u=await x(l,s,process.cwd(),t),{target:i}=u;let h=u.projects;n.query&&(h=G(h,s,n.query));const j=h.filter(p=>s.projects[p]?.targets?.[i]!==void 0);if(j.length===0){e.info(`No projects have a "${i}" target.`);return}const v=j.map(p=>{const k=s.projects[p],g=k.targets?.[i],$={project:p,target:i};return{cache:g?.cache,id:`${p}:${i}`,outputs:g?.outputs??[],overrides:{command:g?.command},parallelism:g?.parallelism,projectRoot:k.root,target:$}}),a=b(v,{projectGraph:d,targetDefaults:r.targetDefaults,workspace:s});if(n.json){e.info(JSON.stringify(S(a.roots,a.dependencies,a.tasks),null,2));return}const y=P(a.roots,a.dependencies,a.tasks);e.info(`Execution plan (${Object.keys(a.tasks).length} task(s), ${a.roots.length} root(s)):`),e.info("");for(const p of y)e.info(p)},"execute");export{T as default};
@@ -0,0 +1 @@
1
+ var i=Object.defineProperty;var n=(e,o)=>i(e,"name",{value:o,configurable:!0});import{J as p,n as d}from"./bin.js";var f=Object.defineProperty,l=n((e,o)=>f(e,"name",{value:o,configurable:!0}),"t");const k=l(async({logger:e,options:o,visConfig:s,workspaceRoot:t})=>{const c=t??process.cwd(),r=p(c,{configBackend:s?.install?.backend}),a=d(r,o.check||!1,c,e);a!==0&&(process.exitCode=a)},"execute");export{k as default};
@@ -0,0 +1 @@
1
+ var k=Object.defineProperty;var n=(e,s)=>k(e,"name",{value:s,configurable:!0});import{J as f,o as u}from"./bin.js";var v=Object.defineProperty,h=n((e,s)=>v(e,"name",{value:s,configurable:!0}),"n");const x=h(async({argument:e,logger:s,options:a,visConfig:i,workspaceRoot:t})=>{const o=e;if(!o||o.length===0)throw new Error("No package specified. Usage: vis dlx <package[@version]> [args...]");const[g,...l]=o,r=t??process.cwd(),p=f(r,{configBackend:i?.install?.backend}),d=a.package?Array.isArray(a.package)?a.package:[a.package]:[],c=u(p,{additionalPackages:d,args:l,package:g,shellMode:a.shellMode||!1,silent:a.silent||!1},r,s);c!==0&&(process.exitCode=c)},"execute");export{x as default};
@@ -0,0 +1,2 @@
1
+ var g=Object.defineProperty;var p=(t,o)=>g(t,"name",{value:o,configurable:!0});import{join as d}from"@visulima/path";import{r as k,s as v}from"./bin.js";import{s as h,p as j}from"../packem_shared/docker-BcfqH4Av.js";var x=Object.defineProperty,E=p((t,o)=>x(t,"name",{value:o,configurable:!0}),"m");const P=E(async({argument:t,logger:o,options:s,visConfig:l,workspaceRoot:e})=>{const n=t[0];if(!n)throw new Error("Missing subcommand. Usage: vis docker <scaffold|prune>");if(!e)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{packageJsons:m,workspace:c}=k(e,l);if(n==="scaffold"){const a=v(e,c,m),r=s.focus;if(!r)throw new Error("Missing --focus. Pass one or more project names, comma-separated.");const i=r.split(",").map(w=>w.trim()).filter(Boolean);if(i.length===0)throw new Error("--focus resolved to an empty list. Provide at least one project name.");const f=d(e,s.out??".vis/docker"),{projects:u}=h({focus:i,includeSources:!!s.includeSources,outDir:f,projectGraph:a,workspace:c,workspaceRoot:e});o.info(`Scaffolded ${u.length} project(s) into ${f}`),o.info(`Focus closure: ${u.sort().join(", ")}`);return}if(n==="prune"){const a=d(e,s.context??".vis/docker"),{removed:r}=j({contextRoot:a,workspace:c,workspaceRoot:e});o.info(`Pruned ${r.length} unfocused project(s)`),r.length>0&&o.debug?.(r.join(`
2
+ `));return}throw new Error(`Unknown subcommand: "${n}". Expected scaffold or prune.`)},"execute");export{P as default};
@@ -0,0 +1 @@
1
+ var p=Object.defineProperty;var c=(o,r)=>p(o,"name",{value:r,configurable:!0});import{J as m,l as g}from"./bin.js";import{o as u}from"../packem_shared/utils-DrNg0XTR.js";var v=Object.defineProperty,w=c((o,r)=>v(o,"name",{value:r,configurable:!0}),"l");const b=w(async({argument:o,logger:r,options:e,visConfig:t,workspaceRoot:n})=>{const s=o;if(!s||s.length===0)throw new Error("No command specified. Usage: vis exec <command> [args...]");const[i,...f]=s,a=n??process.cwd(),d=m(a,{configBackend:t?.install?.backend}),l=g(d,{args:f,command:i,filter:u(e.filter),parallel:e.parallel||!1,recursive:e.recursive||!1,reverse:e.reverse||!1,shellMode:e.shellMode||!1,workspaceRoot:e.workspaceRoot||!1},a,r);l!==0&&(process.exitCode=l)},"execute");export{b as default};
@@ -0,0 +1,5 @@
1
+ var g=Object.defineProperty;var a=(e,i)=>g(e,"name",{value:i,configurable:!0});import{createRequire as y}from"node:module";import{isAccessibleSync as u,readFileSync as p,writeFileSync as j}from"@visulima/fs";import{join as r}from"@visulima/path";const _=y(import.meta.url),c=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,d=a(e=>{if(typeof c<"u"&&c.versions&&c.versions.node){const[i,o]=c.versions.node.split(".").map(Number);if(i>22||i===22&&o>=3||i===20&&o>=16)return c.getBuiltinModule(e)}return _(e)},"__cjs_getBuiltinModule"),{rmSync:b}=d("node:fs"),{homedir:s}=d("node:os"),{createInterface:w}=d("node:readline");var S=Object.defineProperty,m=a((e,i)=>S(e,"name",{value:i,configurable:!0}),"l");const f=r(s(),".vis"),h=[r(s(),".zshrc"),r(s(),".zshenv"),r(s(),".bashrc"),r(s(),".bash_profile"),r(s(),".profile"),r(s(),".config","fish","config.fish")],T=m(e=>{const i=[];for(const o of h)if(u(o))try{const l=p(o).split(`
2
+ `),n=l.filter(t=>!t.includes(".vis/bin")&&!t.includes("VIS_HOME")&&!t.includes("# vis "));n.length!==l.length&&(j(o,n.join(`
3
+ `)),i.push(o))}catch{e.warn(`warning: could not clean ${o}`)}return i},"cleanShellProfiles"),F=m(async({logger:e,options:i})=>{if(!u(f)){e.info("vis is not installed (no ~/.vis directory found).");return}e.info("This will remove:"),e.info(` ${f}/`);const o=h.filter(n=>u(n)&&p(n).includes(".vis"));for(const n of o)e.info(` Lines in ${n}`);if(!i.yes){if(!process.stdin.isTTY)throw new Error("Non-interactive terminal. Use --yes to confirm.");const n=w({input:process.stdin,output:process.stdout}),t=await new Promise(v=>{n.question(`
4
+ Type "uninstall" to confirm: `,v)});if(n.close(),t.trim()!=="uninstall"){e.info("Aborted.");return}}const l=T(e);for(const n of l)e.info(`Cleaned ${n}`);try{b(f,{force:!0,recursive:!0}),e.info(`
5
+ ✓ Removed ${f}`)}catch(n){throw new Error(`Failed to remove ${f}: ${n instanceof Error?n.message:String(n)}`)}e.info("✓ vis has been uninstalled.")},"execute");export{F as default};
@@ -0,0 +1 @@
1
+ var g=Object.defineProperty;var n=(e,a)=>g(e,"name",{value:a,configurable:!0});import{J as l,e as d}from"./bin.js";var k=Object.defineProperty,u=n((e,a)=>k(e,"name",{value:a,configurable:!0}),"c");const w=u(async({argument:e,logger:a,options:c,visConfig:r,workspaceRoot:i})=>{if(!e||e.length===0)throw new Error("No package specified. Usage: vis info <package> [field...]");const[t,...f]=e,s=i??process.cwd(),p=l(s,{configBackend:r?.install?.backend}),o=d(p,{fields:f,json:c.json||!1,package:t},s,a);o!==0&&o!==1&&(process.exitCode=o)},"execute");export{w as default};
@@ -0,0 +1,20 @@
1
+ var _=Object.defineProperty;var v=(s,e)=>_(s,"name",{value:e,configurable:!0});import{createRequire as C}from"node:module";import{isAccessibleSync as g,writeFileSync as b}from"@visulima/fs";import{join as $}from"@visulima/path";import{findVisConfigFile as B}from"./config.js";import{p as t,I as E,T as x,c as R}from"./bin.js";const I=C(import.meta.url),p=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,j=v(s=>{if(typeof p<"u"&&p.versions&&p.versions.node){const[e,o]=p.versions.node.split(".").map(Number);if(e>22||e===22&&o>=3||e===20&&o>=16)return p.getBuiltinModule(s)}return I(s)},"__cjs_getBuiltinModule"),{execSync:T}=j("node:child_process"),{createInterface:O}=j("node:readline");var N=Object.defineProperty,f=v((s,e)=>N(s,"name",{value:e,configurable:!0}),"l");const M=f(s=>{const e=[];return g($(s,"turbo.json"))&&e.push("turborepo"),g($(s,"nx.json"))&&e.push("nx"),g($(s,".moon"))&&e.push("moon"),e},"detectExistingTools"),P=f((s,e)=>new Promise(o=>{s.question(e,n=>{o(n.trim())})}),"ask"),d=f(async(s,e,o=!0)=>{const n=await P(s,`${e} ${o?"[Y/n]":"[y/N]"} `);return n===""?o:n.toLowerCase()==="y"||n.toLowerCase()==="yes"},"confirm"),w=f((s,e)=>{const o=[],n=Object.entries(e.allowBuilds).filter(([,c])=>c).map(([c])=>` "${c}": true,`).join(`
2
+ `);let i=` allowBuilds: ${n?`{
3
+ ${n}
4
+ }`:"{}"},`;return e.enableSocket&&(i+=`
5
+ socket: { enabled: true },`),o.push(` security: {
6
+ ${i}
7
+ },`),e.staged&&o.push(` staged: {
8
+ "*.{ts,tsx}": "eslint --fix",
9
+ "*.{ts,tsx,js,jsx,json,md}": "prettier --write",
10
+ },`),`import { defineConfig } from "@visulima/vis/config";
11
+
12
+ export default defineConfig({
13
+ ${o.join(`
14
+
15
+ `)}
16
+ });
17
+ `},"generateConfigContent"),q=f(async(s,e,o)=>{const n=O({input:process.stdin,output:process.stdout});t.info(`
18
+ vis init — interactive setup
19
+ `);const i=await d(n," Enable Socket.dev security scanning?");i&&(t.success(" Socket.dev enabled — scores, alerts, and supply chain data active."),process.env.VIS_SOCKET_TOKEN||t.notice(" Set VIS_SOCKET_TOKEN for a custom API token (optional).")),t.info("");const c=await d(n," Scan for packages with build scripts?"),l={};if(c){t.info(" Scanning node_modules...");const a=E(s,{});if(a.length>0){t.info(` Found ${String(a.length)} package${a.length===1?"":"s"} with build scripts:
20
+ `);for(const r of a){const u=await d(n,` Allow ${r}?`,!1),S=r.split(" (")[0]??r;l[S]=u,u&&t.success(` ✓ ${S} approved`)}}else t.info(" No packages with build scripts found.")}t.info("");const y=await d(n," Set up pre-commit hooks (lint-staged)?",!1);let h=!1;(e.name==="pnpm"||e.name==="yarn"||e.name==="npm"||e.name==="bun")&&(t.info(""),h=await d(n,` Sync security settings to ${e.name} config?`));const m=M(s);if(m.length>0&&(t.info(""),t.info(` Detected existing tools: ${m.join(", ")}`),await d(n,` Run \`vis migrate\` for ${m.join(", ")}?`,!1))){n.close();const a=e.name==="pnpm"?"pnpm exec":e.name==="yarn"?"yarn exec":e.name==="bun"?"bunx":"npx";for(const r of m){t.info(` Migrating from ${r}...`);try{T(`${a} vis migrate ${r}`,{cwd:s,stdio:"inherit"})}catch{t.warn(` Migration from ${r} had issues — run \`vis migrate ${r}\` manually.`)}}if(g(o))t.success(`Migrated config written to ${o}`);else{const r=w(e.name,{allowBuilds:l,enableSocket:i,staged:y});b(o,r),t.success(`Created ${o}`)}t.notice(" Run 'vis doctor' to see your project's full health status.");return}n.close(),t.info("");const k=w(e.name,{allowBuilds:l,enableSocket:i,staged:y});if(b(o,k),t.success(`Created ${o}`),h){const a=Object.fromEntries(Object.entries(l).filter(([,u])=>u)),r=x(e.name,s,a);for(const u of r)t.success(` ${u}`)}t.info(""),t.info(" Setup complete. Your config:"),t.info(` Security: ${i?"Socket.dev enabled":"defaults only"}`),t.info(` Build scripts: ${Object.values(l).filter(Boolean).length} approved`),t.info(` Git hooks: ${y?"lint-staged configured":"not configured"}`),t.info(` PM sync: ${h?"done":"skipped"}`),t.info(""),t.notice(" Run 'vis doctor' to see your project's full health status."),t.info("")},"runInteractiveInit"),K=f((s,e,o,n)=>{const i=w(e.name,{allowBuilds:{},enableSocket:!1,staged:!1});if(b(n,i),t.success(`Created ${n}`),t.info(" Secure defaults applied automatically by defineConfig()."),o.syncNative){const c=x(e.name,s,{});for(const l of c)t.success(` ${l}`)}t.info(""),t.notice("Run 'vis doctor' for a full health check, or 'vis init' in a terminal for guided setup.")},"runStaticInit"),G=f(async({options:s,workspaceRoot:e})=>{const o=e??process.cwd(),n=R(o),i=B(o);if(i&&!s.force){t.warn(`Config already exists: ${i}`),t.notice("Use --force to overwrite, or edit the existing file.");return}const c=i??$(o,"vis.config.ts");process.stdin.isTTY&&s.interactive!==!1&&!s.noInteractive?await q(o,n,c):K(o,n,s,c)},"execute");export{G as default};
@@ -0,0 +1 @@
1
+ var x=Object.defineProperty;var f=(o,e)=>x(o,"name",{value:e,configurable:!0});import{createRequire as C}from"node:module";import{isAccessibleSync as R}from"@visulima/fs";import{join as y,dirname as T,parse as z}from"@visulima/path";import{p as t,c as $,J as L,G as A,g as B}from"./bin.js";import{s as D}from"../packem_shared/typosquats-DOR8izpX.js";import{o as E}from"../packem_shared/utils-DrNg0XTR.js";const O=C(import.meta.url),i=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,S=f(o=>{if(typeof i<"u"&&i.versions&&i.versions.node){const[e,r]=i.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return i.getBuiltinModule(o)}return O(o)},"__cjs_getBuiltinModule"),{rmSync:q}=S("node:fs");var F=Object.defineProperty,b=f((o,e)=>F(o,"name",{value:e,configurable:!0}),"f");const M=["pnpm-lock.yaml","yarn.lock","package-lock.json","npm-shrinkwrap.json","bun.lock","bun.lockb"],P=b(o=>{let e=o;for(;;){for(const c of M)if(R(y(e,c)))return!0;const r=T(e);if(r===e||z(e).root===e)return!1;e=r}},"hasLockfile"),g=new Set(["aube","auto","bun","npm","pnpm","yarn"]),U=b(async({logger:o,options:e,visConfig:r,workspaceRoot:c})=>{const s=c??process.cwd();if(!e.noTyposquatCheck&&!await D(s,r?.security?.typosquatAllowlist)){process.exitCode=1;return}const l=e.installer;if(l&&!g.has(l)){t.error(`Invalid --installer value: "${l}". Expected one of: ${[...g].join(", ")}.`),process.exitCode=1;return}const v=l,_=e.noAube||!1;let a;try{a=_?$(s):L(s,{backend:v,configBackend:r?.install?.backend})}catch(n){t.error(n instanceof Error?n.message:String(n)),process.exitCode=1;return}const p=A(s,a);p&&t.warn(p);const w=E(e.filter),u=e.ci||!1,d=e.frozenLockfile||u,j=e.noFrozenLockfile||e.force||e.lockfileOnly,h=P(s),m=d||!j&&h;if(!d&&m&&!e.silent&&t.info("Defaulting to frozen lockfile (pass --no-frozen-lockfile to allow lockfile updates)."),u){t.info("Clean install: removing node_modules...");try{q(y(s,"node_modules"),{force:!0,recursive:!0})}catch(n){t.error(`Failed to remove node_modules: ${n instanceof Error?n.message:String(n)}`),process.exitCode=1;return}}const k=B(a,{dev:e.dev||!1,filter:w,force:e.force||!1,frozenLockfile:m,ignoreScripts:!e.runScripts,lockfileOnly:e.lockfileOnly||!1,noOptional:e.noOptional||!1,offline:e.offline||!1,prod:e.prod||!1,recursive:e.recursive||!1,silent:e.silent||!1,workspaceRoot:e.workspaceRoot||!1},s,o,{preferOffline:e.preferOffline||!1});k!==0&&(process.exitCode=k)},"execute");export{U as default};
@@ -0,0 +1 @@
1
+ var l=Object.defineProperty;var c=(e,o)=>l(e,"name",{value:o,configurable:!0});import{J as u,t as d}from"./bin.js";var f=Object.defineProperty,g=c((e,o)=>f(e,"name",{value:o,configurable:!0}),"s");const v=g(async({argument:e,logger:o,visConfig:n,workspaceRoot:r})=>{const s=e?.[0]??null,t=r??process.cwd(),i=u(t,{configBackend:n?.install?.backend}),a=d(i,s,t,o);a!==0&&(process.exitCode=a)},"execute");export{v as default};
@@ -0,0 +1 @@
1
+ var b=Object.defineProperty;var u=(r,n)=>b(r,"name",{value:n,configurable:!0});import{r as O}from"./bin.js";import{f as T}from"../packem_shared/selectors-CfH9ZY08.js";var w=Object.defineProperty,d=u((r,n)=>w(r,"name",{value:n,configurable:!0}),"f");const S=d(async({logger:r,options:n,visConfig:h,workspaceRoot:l})=>{if(!l)throw new Error("Could not determine workspace root.");const{projectOptions:k,workspace:s}=O(l,h);let a=Object.keys(s.projects).sort();if(n.query&&(a=T(a,s,n.query)),a.length===0){r.info("No projects found.");return}if(n.json){const o=a.map(e=>{const t=s.projects[e],p=k.get(e)??{},g=Object.entries(t.targets??{}).map(([y])=>{const i=p[y];return{aliases:i?.aliases??[],command:i?.command,description:i?.description,name:y,type:i?.type}});return{language:t.language,layer:t.layer,name:e,root:t.root,stack:t.stack,tags:t.tags??[],targets:g,type:t.projectType??"library"}});r.info(JSON.stringify(o,null,2));return}const f=["Project","Type","Layer","Tags","Targets"],j=a.map(o=>{const e=s.projects[o],t=Object.keys(e.targets??{});return[o,e.projectType??"library",e.layer??"—",(e.tags??[]).join(", ")||"—",t.length>4?`${t.slice(0,4).join(", ")}… (${String(t.length)})`:t.join(", ")||"—"]}),c=f.map((o,e)=>{const t=j.reduce((p,g)=>Math.max(p,(g[e]??"").length),0);return Math.max(o.length,t)}),m=d((o,e)=>o.padEnd(e),"pad");r.info(f.map((o,e)=>m(o,c[e])).join(" ")),r.info(c.map(o=>"─".repeat(o)).join("──"));for(const o of j)r.info(o.map((e,t)=>m(e,c[t])).join(" "));r.info(""),r.info(`${String(a.length)} project(s)`)},"execute");export{S as default};
@@ -0,0 +1 @@
1
+ var S=Object.defineProperty;var v=(s,i)=>S(s,"name",{value:i,configurable:!0});import{createRequire as b}from"node:module";import{dim as j,red as T,yellow as q,green as M}from"@visulima/colorize";import{coerce as P}from"semver";import{B as x,S as k,q as L,p as c,N as y,R as A,Q as N,U,V as B,b as D,J as I,Y as O}from"./bin.js";import{r as V}from"../packem_shared/typosquats-DOR8izpX.js";import{d as $,o as Y}from"../packem_shared/utils-DrNg0XTR.js";const C=b(import.meta.url),h=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,_=v(s=>{if(typeof h<"u"&&h.versions&&h.versions.node){const[i,e]=h.versions.node.split(".").map(Number);if(i>22||i===22&&e>=3||i===20&&e>=16)return h.getBuiltinModule(s)}return C(s)},"__cjs_getBuiltinModule"),{createInterface:R}=_("node:readline");var z=Object.defineProperty,d=v((s,i)=>z(s,"name",{value:i,configurable:!0}),"d");const E=d(async(s,i=1e4)=>{const e=new Map,p=new AbortController,n=setTimeout(()=>{p.abort()},i);try{const o=s.map(async u=>{try{const t=await fetch(`https://registry.npmjs.org/${u}/latest`,{headers:{Accept:"application/json"},signal:p.signal});if(t.ok){const l=await t.json();l.version&&e.set(u,l.version)}}catch{}});await Promise.all(o)}finally{clearTimeout(n)}return e},"resolveLatestVersions"),F=d((s,i,e)=>{const p=[];for(const n of s.values()){const{overall:o}=n.score,u=x(o),t=`${String(Math.round(o*100))}%`,l=n.alerts.length,m=k(n),f=L(m,n.version,e),r=u==="red"?T:u==="yellow"?q:M;if(f?c.info(` ${r(t)} ${y(n)} ${j(`[accepted: ${f.reason}]`)}`):c.info(` ${r(t)} ${y(n)}`),l>0){const a=n.alerts.filter(g=>g.severity==="critical"||g.severity==="high").length;a>0&&c.warn(` ${String(a)} critical/high alert${a===1?"":"s"}`)}o<i&&!f&&p.push(n)}return p},"displaySecurityReports"),H=d(async(s,i)=>{const e=R({input:process.stdin,output:process.stdout}),p=d(t=>new Promise(l=>{e.question(t,m=>{l(m.trim())})}),"ask"),n=String(Math.round(i*100));c.warn(""),c.warn(`${String(s.length)} package${s.length===1?"":"s"} scored below the minimum threshold (${n}%):`);for(const t of s){const l=k(t),m=`${String(Math.round(t.score.overall*100))}%`;c.warn(` • ${l}@${t.version} — score: ${m} (${A(t.score.overall)})`)}c.warn("");const o=await p("Continue adding these packages? [y/N] ");if(o.toLowerCase()!=="y"&&o.toLowerCase()!=="yes")return e.close(),!1;const u=await p("Remember this decision? (prints config snippet) [y/N] ");if(e.close(),u.toLowerCase()==="y"||u.toLowerCase()==="yes"){c.notice(""),c.notice("Add the following to security.socket.acceptedRisks in vis.config.ts:"),c.notice("");for(const t of s){const l=k(t),m=N(l,t.version,t.score.overall,"Reviewed and accepted");c.notice(m)}c.notice("")}return!0},"confirmLowScorePackages"),J=d(async(s,i,e,p)=>{const n=s.map($),o=new Map;for(const r of n)if(r.versionSpec){const a=P(r.versionSpec);a&&o.set(r.name,a.version)}const u=n.filter(r=>!o.has(r.name)).map(r=>r.name),t=u.length>0?await E(u):new Map,l=[];for(const r of n){const a=o.get(r.name)??t.get(r.name);a&&l.push({name:r.name,version:a})}if(l.length===0)return!0;c.info(""),c.info("Socket.dev security check:");const m=await U(l,i);if(m.size===0)return c.info(" Could not fetch security data. Proceeding."),!0;const f=F(m,e,p);return f.length===0?(c.info(""),!0):process.stdin.isTTY?H(f,e):(c.warn(`Aborting: ${String(f.length)} package${f.length===1?"":"s"} below minimum score. Use --no-socket-check to skip.`),!1)},"runSocketPreCheck"),oe=d(async({argument:s,logger:i,options:e,visConfig:p,workspaceRoot:n})=>{let o=s;if(!o||o.length===0)throw new Error("No packages specified. Usage: vis add <packages...>");if(!e.noTyposquatCheck){const f=o.map(a=>$(a)),r=await V(f.map(a=>a.name),p?.security?.typosquatAllowlist);if(!r.ok){process.exitCode=1;return}o=f.map((a,g)=>{const w=r.packages[g];return w!==a.name?a.versionSpec?`${w}@${a.versionSpec}`:w??"":o[g]??""})}if(!e.noSocketCheck){const f=B(p?.security?.socket);if(f){const r=f.minimumScore??D;if(!await J(o,f,r,p?.security?.socket?.acceptedRisks)){process.exitCode=1;return}}}const u=process.cwd(),t=I(n??u,{configBackend:p?.install?.backend}),l=!e.runScripts,m=O(t,{exact:e.exact||!1,filter:Y(e.filter),global:e.global||!1,optional:e.saveOptional||!1,packages:o,peer:e.savePeer||!1,saveDev:e.saveDev||!1,workspace:e.workspace||!1,workspaceRoot:e.workspaceRoot||!1},u,i,{ignoreScripts:l});m!==0&&(process.exitCode=m)},"execute");export{oe as default};
@@ -0,0 +1 @@
1
+ var d=Object.defineProperty;var c=(e,o)=>d(e,"name",{value:o,configurable:!0});import{J as g,u as p}from"./bin.js";var f=Object.defineProperty,b=c((e,o)=>f(e,"name",{value:o,configurable:!0}),"n");const h=b(async({argument:e,logger:o,visConfig:r,workspaceRoot:i})=>{const a=e;if(!a||a.length===0)throw new Error("No subcommand specified. Available: cache, publish, audit, list, view, config, whoami, login, logout, pack, owner, dist-tag, search, fund, ping, token, deprecate, rebuild, prune");const[s,...l]=a,n=i??process.cwd(),u=g(n,{configBackend:r?.install?.backend}),t=p(u,s,l,n,o);t!==0&&(process.exitCode=t)},"execute");export{h as default};
@@ -0,0 +1 @@
1
+ var f=Object.defineProperty;var t=(e,o)=>f(e,"name",{value:o,configurable:!0});import{J as p,Z as g}from"./bin.js";import{o as v}from"../packem_shared/utils-DrNg0XTR.js";var d=Object.defineProperty,k=t((e,o)=>d(e,"name",{value:o,configurable:!0}),"t");const b=k(async({argument:e,logger:o,options:a,visConfig:i,workspaceRoot:l})=>{const s=e;if(!s||s.length===0)throw new Error("No packages specified. Usage: vis remove <packages...>");const r=process.cwd(),n=p(l??r,{configBackend:i?.install?.backend}),c=g(n,{filter:v(a.filter),global:a.global||!1,packages:s,recursive:a.recursive||!1,saveDev:a.saveDev||!1,workspaceRoot:a.workspaceRoot||!1},r,o);c!==0&&(process.exitCode=c)},"execute");export{b as default};
@@ -0,0 +1,5 @@
1
+ var _=Object.defineProperty;var $=(e,r)=>_(e,"name",{value:r,configurable:!0});import{createRequire as N}from"node:module";import{isAccessibleSync as w,readFileSync as b}from"@visulima/fs";import{resolve as J,join as y,relative as F,basename as I}from"@visulima/path";import P from"zeptomatch";import{sortPackageJsonStringWithOptions as C}from"#native";import{D as M,f as k,p as d}from"./bin.js";import{f as O}from"../packem_shared/utils-DrNg0XTR.js";const A=N(import.meta.url),g=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,x=$(e=>{if(typeof g<"u"&&g.versions&&g.versions.node){const[r,s]=g.versions.node.split(".").map(Number);if(r>22||r===22&&s>=3||r===20&&s>=16)return g.getBuiltinModule(e)}return A(e)},"__cjs_getBuiltinModule"),{writeFileSync:E}=x("node:fs");var T=Object.defineProperty,a=$((e,r)=>T(e,"name",{value:r,configurable:!0}),"c");const q=a(e=>{const r=new Set,s=[],i=a(n=>{const o=J(n);!r.has(o)&&w(o)&&(r.add(o),s.push(o))},"addFile");i(y(e,"package.json"));const t=M(e);if(t){const n=k(e,t);for(const o of n)i(y(e,o,"package.json"))}else{const n=y(e,"package.json");if(w(n)){const o=JSON.parse(b(n)),l=Array.isArray(o.workspaces)?o.workspaces:o.workspaces?.packages;if(l){const m=k(e,l);for(const f of m)i(y(e,f,"package.json"))}}}return s},"findPackageJsonFiles"),B=a(e=>/\n([ \t]+)/.exec(e)?.[1]??" ","detectIndent"),D=a(e=>{if(!(e===void 0||e===""))return e==="tab"||e===String.raw`\t`?" ":/^\d+$/.test(e)?" ".repeat(Number.parseInt(e,10)):e},"resolveIndentOverride"),j=a(e=>e===void 0?[]:(Array.isArray(e)?e:[e]).flatMap(r=>r.split(",")).map(r=>r.trim()).filter(r=>r.length>0),"splitList"),L=a(e=>e.includes(`\r
2
+ `)?"crlf":"lf","detectLineEnding"),R=new Set(["auto","crlf","lf"]),W=a(e=>{if(e===void 0||e==="")return"auto";if(R.has(e))return e;d.error(`--line-ending must be one of: auto, lf, crlf (got "${e}")`),process.exit(2)},"validateLineEnding"),z=a((e,r,s)=>r.length===0?e:e.filter(i=>{const t=F(s,i),n=I(i);return!r.some(o=>{const l=o.includes("/")?t:n;return P(o,l)})}),"filterByIgnore"),U=a((e,r)=>{if(r.length===0)return e;const s={},i=new Set;for(const t of r)Object.hasOwn(e,t)&&(s[t]=e[t],i.add(t));for(const t of Object.keys(e))i.has(t)||(s[t]=e[t]);return s},"applySortOrder"),G=a((e,r,s)=>{if(s.length===0)return e;const i={...e};for(const t of s)Object.hasOwn(r,t)&&(i[t]=r[t]);return i},"restoreUnsortedSections"),H=a((e,r)=>{const s=r.indent??B(e),i=r.lineEnding==="auto"?L(e):r.lineEnding,t=C(e,{pretty:!1,sortScripts:r.sortScripts});let n=JSON.parse(t);if(r.unsorted.length>0){const l=JSON.parse(e);n=G(n,l,r.unsorted)}n=U(n,r.sortOrder);let o=JSON.stringify(n,null,s);return r.finalNewline&&(o+=`
3
+ `),i==="crlf"&&(o=o.replaceAll(`
4
+ `,`\r
5
+ `)),o},"sortContents"),te=a(async({options:e,visConfig:r,workspaceRoot:s})=>{const i=s??process.cwd(),t=r?.sortPackageJson,n=e.check||!1,o={finalNewline:e.finalNewline??t?.finalNewline??!0,ignore:[...j(e.ignore),...t?.ignore??[]],indent:D(e.indent??t?.indent),lineEnding:W(e.lineEnding??t?.lineEnding),sortOrder:[...j(e.sortOrder),...t?.sortOrder??[]],sortScripts:e.sortScripts||t?.sortScripts||!1,unsorted:[...j(e.unsorted),...t?.unsorted??[]]},l=q(i),m=z(l,o.ignore,i);if(m.length===0){d.info(l.length===0?"No package.json files found.":"All package.json files were excluded by --ignore.");return}let f=0,p=0,u=0;for(const c of m)try{const h=b(c);let S;try{S=H(h,o)}catch(v){d.error(`${c}: ${O(v)}`),u++;continue}if(h===S){p++;continue}f++,n?d.warn(`${c} is not sorted`):(E(c,S,"utf8"),d.success(`Sorted ${c}`))}catch(h){d.error(`${c}: ${O(h)}`),u++}if(n)f>0?(d.info(`${f} file${f===1?"":"s"} not sorted, ${p} already sorted`),process.exitCode=1):d.info(`All ${p} package.json file${p===1?" is":"s are"} sorted`);else{const c=[];f>0&&c.push(`sorted ${f} file${f===1?"":"s"}`),p>0&&c.push(`${p} already sorted`),u>0&&c.push(`${u} error${u===1?"":"s"}`),d.info(c.join(", "))}u>0&&(process.exitCode=1)},"execute");export{te as default};
@@ -0,0 +1 @@
1
+ var T=Object.defineProperty;var j=(e,t)=>T(e,"name",{value:t,configurable:!0});import{createRequire as C}from"node:module";import{green as f,red as v,dim as J,yellow as _}from"@visulima/colorize";import{isAccessibleSync as M,readJsonSync as P}from"@visulima/fs";import{join as b}from"@visulima/path";import{enforceProjectConstraints as V}from"@visulima/task-runner";import{r as z,s as A}from"./bin.js";import{a as B}from"../packem_shared/flakiness-DSIHZGBT.js";import{c as I}from"../packem_shared/runtime-check-CGHal8SO.js";const q=C(import.meta.url),n=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,x=j(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 q(e)},"__cjs_getBuiltinModule"),{readdirSync:F}=x("node:fs");var K=Object.defineProperty,O=j((e,t)=>K(e,"name",{value:t,configurable:!0}),"h");const r=O(e=>e?f("✓"):v("✗"),"icon"),X=O(async({logger:e,options:t,visConfig:i,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root.");const{config:y,packageJsons:w,workspace:u}=z(s,i),R=A(s,u,w),$=Object.keys(u.projects).length,k=new Set(Object.values(u.projects).flatMap(p=>Object.keys(p.targets??{}))).size,a=I(s);let o=0;y.constraints&&(o=V(R,y.constraints).length);const c=B(s,{minRuns:2});let l;const g=b(s,".task-runner","runs");if(M(g)){const p=F(g).filter(d=>d.endsWith(".json")).sort();let m=0,S=0;for(const d of p.slice(-20))try{const h=P(b(g,d));h.stats&&(m+=h.stats.total??0,S+=h.stats.cached??0)}catch{continue}m>0&&(l=`${(S/m*100).toFixed(0)}%`)}if(t.json){e.info(JSON.stringify({cacheHitRate:l??null,constraintViolations:o,flakyTasks:c.length,projects:$,runtimeIssues:a.length,targets:k},null,2));return}e.info(""),e.info(` ${J("VIS STATUS")}`),e.info(""),e.info(` ${r(!0)} ${String($)} projects · ${String(k)} 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"):v(`${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};
@@ -0,0 +1 @@
1
+ var b=Object.defineProperty;var j=(t,e)=>b(t,"name",{value:e,configurable:!0});import{createTaskGraph as v}from"@visulima/task-runner";import{r as y,s as E}from"./bin.js";var T=Object.defineProperty,w=j((t,e)=>T(t,"name",{value:e,configurable:!0}),"h");const O=w((t,e)=>{const s=new Map;for(const[i,r]of Object.entries(t.dependencies))for(const f of r){const c=s.get(f)??[];c.push(i),s.set(f,c)}if(!t.tasks[e])return;const a=new Set([e]),o=[{node:e,path:[e]}];for(;o.length>0;){const i=o.shift();if(t.roots.includes(i.node))return i.path;for(const r of s.get(i.node)??[])a.has(r)||(a.add(r),o.push({node:r,path:[r,...i.path]}))}return[e]},"findShortestPathToRoot"),x=w((t,e)=>{const s=[];for(const[a,o]of Object.entries(t.dependencies))o.includes(e)&&s.push(a);return s.sort()},"collectParents"),I=w(async({argument:t,logger:e,visConfig:s,workspaceRoot:a})=>{if(!a)throw new Error("Could not determine workspace root.");const o=t[0];if(!o)throw new Error("No task ID specified. Usage: vis task-why <project>:<target>");if(!o.includes(":"))throw new Error(`Invalid task ID "${o}" — expected format "project:target".`);const{packageJsons:i,workspace:r}=y(a,s),f=E(a,r,i),[c,k]=o.split(":",2),$=r.projects[c];if(!$)throw new Error(`Unknown project "${c}".`);if(!$.targets?.[k])throw new Error(`Project "${c}" has no target "${k}".`);const m=Object.entries(r.projects).flatMap(([n,u])=>Object.keys(u.targets??{}).map(h=>({id:`${n}:${h}`,outputs:[],overrides:{},target:{project:n,target:h}}))),p=v(m,{projectGraph:f,workspace:r});if(!p.tasks[o])throw new Error(`Task "${o}" is not reachable in the graph.`);const d=O(p,o),g=x(p,o);if(e.info(""),e.info(`Why ${o}?`),e.info(""),d&&d.length>1){e.info("Shortest path from a root to this task:");for(const[n,u]of d.entries()){const h=n===0?" ":`${" ".repeat(n+1)}└─ `;e.info(`${h}${u}`)}e.info("")}else e.info(" This task is itself a root — nothing upstream depends on it."),e.info("");if(g.length>0){e.info(`Directly depended on by ${g.length} task(s):`);for(const n of g)e.info(` - ${n}`);e.info("")}const l=p.dependencies[o]??[];if(l.length>0){e.info(`This task depends on ${l.length} task(s):`);for(const n of[...l].sort())e.info(` - ${n}`);e.info("")}},"execute");export{I as default};
@@ -0,0 +1,5 @@
1
+ var P=Object.defineProperty;var v=(e,n)=>P(e,"name",{value:n,configurable:!0});import{createRequire as R}from"node:module";import{green as S,red as W,yellow as A,dim as d}from"@visulima/colorize";import{join as N}from"@visulima/path";import{p as o}from"./bin.js";import{S as w,g as C,w as j,b as B,p as q,f as k,a as M,c as H,u as y,d as K,e as O,h as D}from"../packem_shared/toolchain-DQfTQY8E.js";const I=R(import.meta.url),$=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,b=v(e=>{if(typeof $<"u"&&$.versions&&$.versions.node){const[n,i]=$.versions.node.split(".").map(Number);if(n>22||n===22&&i>=3||n===20&&i>=16)return $.getBuiltinModule(e)}return I(e)},"__cjs_getBuiltinModule"),{spawnSync:U}=b("node:child_process"),{writeFileSync:F}=b("node:fs");var L=Object.defineProperty,f=v((e,n)=>L(e,"name",{value:n,configurable:!0}),"d");const x=["bun","deno","go","node","npm","pnpm","python","ruby","rust","yarn"],G=f(e=>x.includes(e),"isKnownTool"),p=f(e=>e?S("✓"):W("✗"),"icon"),T=A("⚠"),J=f(e=>{if(e.installed){const n=e.version?` v${e.version}`:"",i=e.configFiles.length>0?` (${e.configFiles.join(", ")})`:"";return`${p(!0)} ${e.name}${n}${i}`}return`${T} ${e.name} — referenced by ${e.configFiles.join(", ")} but not installed`},"renderManagerLine"),z=f(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"),Q=f(e=>e.matches?p(!0):e.actual?T:p(!1),"toolIcon"),V=f(e=>{if(o.info(""),o.info(d("── Toolchain ───────────────────────")),e.detected.length===0)o.info(` ${p(!1)} No version manager detected`),o.notice(` Install one of: ${w.join(", ")}`);else for(const n of e.detected)o.info(` ${J(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 i=`${n.expected.tool} ${n.expected.version}`,s=n.actual?`actual ${n.actual}`:"not installed",t=n.matches?"":d(` [${n.expected.source}]`),r=z(n),u=r===""?"":` ${r}`;o.info(` ${Q(n)} ${i} — ${s}${t}${u}`),n.manager.note&&o.notice(` ${n.manager.note}`)}},"printStatus"),X=f((e,n,i)=>{const s=C(e,n);if(i.json){process.stdout.write(`${JSON.stringify({detected:s.detected.map(r=>({binPath:r.binPath??null,configFiles:r.configFiles,installed:r.installed,name:r.name,version:r.version??null})),tools:s.tools.map(r=>({actual:r.actual??null,expected:r.expected.version,manager:r.manager.name,managerInstalled:r.manager.installed,matches:r.matches,note:r.manager.note??null,source:r.expected.source,tool:r.expected.tool}))},void 0,2)}
2
+ `);return}V(s);const t=s.tools.filter(r=>!r.matches);t.length>0&&(o.info(""),o.notice(" Run `vis toolchain install` to install pinned versions.")),i.exitCode&&t.length>0&&(process.exitCode=1)},"executeStatus"),Y=f(e=>{const n=new Map;for(const i of e){const s=n.get(i.manager.name);s?s.push(i):n.set(i.manager.name,[i])}return n},"groupByManager"),_=f((e,n,i)=>U(e,n,{cwd:i,stdio:"inherit"}).status??1,"runInvocation"),Z=f((e,n,i)=>{const s=C(e,n),t=s.tools.filter(c=>!c.matches);if(t.length===0){o.success("Everything already matches — nothing to install.");return}const r=t.some(c=>c.manager.name!=="self-activate"&&c.manager.name!=="none");if(s.detected.length===0&&r){o.error(`No version manager detected. Install one of: ${w.join(", ")}.`),process.exitCode=1;return}const u=Y(t);let l=!1,g=0;for(const[c,m]of u){if(c==="self-activate"){for(const{expected:a}of m){if(a.source==="packageManager")o.info(`${d("$")} (${a.tool} will self-activate from packageManager on next invocation)`);else if(o.info(`${d("$")} Writing packageManager=${a.tool}@${a.version}`),i.dryRun)l=!0;else try{j(e,a),l=!0}catch(h){o.error(h.message),g=1}o.notice(` ${a.tool} ${a.version} — no install needed`)}continue}if(c==="none"){for(const{expected:a}of m)o.warn(`Cannot install ${a.tool} ${a.version} — no manager can handle it.`);g=1;continue}if(!s.detected.find(a=>a.name===c)?.installed){o.error(`${c} is referenced but not on PATH — install it first, then rerun \`vis toolchain install\`.`),g=1;continue}const E=m.map(a=>B(c,a.expected)).filter(Boolean);for(const a of E){if(!a)continue;if(a.bin==="nvm"&&a.args.length===0){o.error("nvm is a shell function — run `nvm install` in your shell, then rerun `vis toolchain install`."),a.hint&&o.notice(` ${a.hint}`),g=1;continue}if(o.info(`${d("$")} ${a.bin} ${a.args.join(" ")}`),a.hint&&o.notice(` ${a.hint}`),i.dryRun){l=!0;continue}const h=_(a.bin,a.args,e);if(l=!0,h!==0){g=h;break}}}if(g!==0){process.exitCode=g;return}l&&o.success("Toolchain installed.")},"executeInstall"),ee=f((e,n,i,s)=>{if(!i)throw new Error("Usage: vis toolchain use <tool>@<version> (e.g. vis toolchain use node@22.13.0)");const t=q(i);if(!t)throw new Error(`Could not parse "${i}". Expected "<tool>@<version>" where <tool> is one of ${x.join(", ")}.`);const r=k(e),u=M(t,r,n);if(u.name==="none"){o.error(`No manager can pin ${t.tool}. Install one of: ${w.join(", ")}.`),process.exitCode=1;return}if(!u.installed){o.error(`The best manager for ${t.tool} (${u.name}) is not on PATH. ${u.note??""}`),process.exitCode=1;return}const l=H(u.name,t);if(!l){o.error(`${u.name} cannot pin ${t.tool}. Use a different manager, or set \`toolchain.tools.${t.tool}\` in vis.config.ts.`),process.exitCode=1;return}if(u.name==="self-activate"){if(o.info(`${d("→")} Writing packageManager field to package.json...`),s.dryRun){o.notice(` Would set packageManager: "${t.tool}@${t.version}"`);return}try{const c=j(e,t);if(!c){o.error(`Refusing to pin non-package-manager tool ${t.tool} via the packageManager field.`),process.exitCode=1;return}if(o.success(`Set packageManager: "${c}" — ${t.tool} will activate this version on next invocation.`),s.engines!==!1){const m=y(e,t);m&&o.success(`Updated package.json engines.${t.tool} → ${m}.`)}}catch(c){o.error(c.message),process.exitCode=1}return}if(l.args.length===0&&u.name==="nvm"&&t.tool==="node"){const c=N(e,".nvmrc");if(o.info(`${d("→")} Writing ${c}...`),s.dryRun){o.notice(` Would write ${t.version} to .nvmrc`);return}try{F(c,`${t.version}
3
+ `)}catch(m){o.error(`Failed to write .nvmrc: ${m.message}`),process.exitCode=1;return}o.success(`Wrote ${t.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(`${u.name} cannot pin ${t.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}`),s.dryRun)return;const g=_(l.bin,l.args,e);if(g!==0){process.exitCode=g;return}if(o.success(`Pinned ${t.tool} to ${t.version}.`),s.engines!==!1)try{const c=y(e,t);c&&o.success(`Updated package.json engines.${t.tool} → ${c}.`)}catch(c){o.warn(`Could not update engines.${t.tool}: ${c.message}`)}},"executeUse"),ne=f((e,n,i)=>{if(!i)throw new Error("Usage: vis toolchain which <tool> (e.g. vis toolchain which node)");const s=i.toLowerCase();if(!G(s))throw new Error(`Unknown tool "${i}". Known: ${x.join(", ")}.`);const t=k(e),r=M({source:"vis.config.ts",tool:s,version:"*"},t,n),u=r.installed&&r.name!=="self-activate"&&r.name!=="none"?t.find(g=>g.name===r.name):void 0,l=u?K(u,s):O(s);if(!l){o.error(`${i} not found in PATH${u?` or via ${u.name}`:""}.`),process.exitCode=1;return}process.stdout.write(`${l}
4
+ `)},"executeWhich"),oe=f((e,n)=>{const i=D(e,n);process.stdout.write(`${i.name}
5
+ `)},"executeDetect"),le=f(async({argument:e,options:n,visConfig:i,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root. Run inside a monorepo.");const t=e[0]??"status",r=i?.toolchain;switch(t){case"detect":{oe(s,r);return}case"install":{Z(s,r,n);return}case"status":{X(s,r,n);return}case"use":{ee(s,r,e[1],n);return}case"which":{ne(s,r,e[1]);return}default:throw new Error(`Unknown toolchain action "${t}". Known: status, detect, install, use, which.`)}},"execute");export{le as default};
@@ -0,0 +1 @@
1
+ var f=Object.defineProperty;var s=(e,o)=>f(e,"name",{value:o,configurable:!0});import{J as p,h as u}from"./bin.js";var d=Object.defineProperty,g=s((e,o)=>d(e,"name",{value:o,configurable:!0}),"c");const x=g(async({argument:e,logger:o,options:c,visConfig:n,workspaceRoot:t})=>{const i=e||[],a=t??process.cwd(),l=p(a,{configBackend:n?.install?.backend}),r=u(l,i,c.recursive||!1,a,o);r!==0&&(process.exitCode=r)},"execute");export{x as default};
@@ -0,0 +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"./bin.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
+ ✓ 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
+ ✓ Updated @visulima/vis from ${o} → ${i}`)},"execute");export{w as default};
@@ -0,0 +1 @@
1
+ var p=Object.defineProperty;var t=(o,a)=>p(o,"name",{value:a,configurable:!0});import{J as f,i as d}from"./bin.js";import{o as g}from"../packem_shared/utils-DrNg0XTR.js";var v=Object.defineProperty,u=t((o,a)=>v(o,"name",{value:a,configurable:!0}),"c");const k=u(async({argument:o,logger:a,options:e,visConfig:n,workspaceRoot:i})=>{const s=o;if(!s||s.length===0)throw new Error("No packages specified. Usage: vis why <package...>");const l=i??process.cwd(),c=f(l,{configBackend:n?.install?.backend}),r=d(c,{depth:e.depth===void 0?void 0:Number(e.depth),dev:e.dev||!1,filter:g(e.filter),global:e.global||!1,json:e.json||!1,long:e.long||!1,noOptional:e.noOptional||!1,packages:s,parseable:e.parseable||!1,prod:e.prod||!1,recursive:e.recursive||!1},l,a);r!==0&&r!==1&&(process.exitCode=r)},"execute");export{k as default};
@@ -0,0 +1,7 @@
1
+ var $=Object.defineProperty;var l=(e,o)=>$(e,"name",{value:o,configurable:!0});import{runProvider as x,detectAllProviders as P}from"@visulima/find-ai-runner";import{renderToString as S,Table as w}from"@visulima/tui";import E from"react";import{b as h,R as f}from"../packem_shared/ai-analysis-CGuy7dfE.js";import{bold as j,dim as p,cyan as I,green as T,yellow as A}from"@visulima/colorize";var D=Object.defineProperty,d=l((e,o)=>D(e,"name",{value:o,configurable:!0}),"i");const v={command:"ai",description:"AI-assisted commands: provider detection, cache management, and failure-fix proposals."},N=d(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"),C=d(e=>{const o=[...e.commandPath??[],e.name].join(" "),a=(e.examples??[]).map(([n,s])=>({command:n??"",description:s??""})),t=(e.options??[]).map(n=>({defaultValue:n.defaultValue,description:n.description,name:n.name,type:N(n.type)}));return{argument:e.argument?{description:e.argument.description,name:e.argument.name}:void 0,description:e.description??"",examples:a,name:e.name,options:t,path:o}},"buildSubcommand"),g=d((e,o=v)=>({command:o.command,description:o.description,subcommands:e.map(a=>C(a))}),"buildDiscoveryPayload"),O=d((e,o=v)=>`${JSON.stringify(g(e,o),void 0,2)}
2
+ `,"renderDiscoveryJson"),R=d((e,o=v)=>{const a=g(e,o),t=[];t.push(j(`vis ${a.command} — ${a.description}`)),t.push(""),t.push(p("Subcommands:"));for(const n of a.subcommands){const s=n.argument?` ${I(`<${n.argument.name}>`)}`:"";if(t.push(""),t.push(` ${T(`vis ${n.path}`)}${s}`),n.description&&t.push(` ${n.description}`),n.options.length>0){const i=n.options.map(m=>`--${m.name}${m.type==="boolean"?"":`=<${m.type}>`}`).join(", ");t.push(p(` options: ${i}`))}if(n.examples.length>0){t.push(p(" examples:"));for(const i of n.examples){const m=i.description?p(` — ${i.description}`):"";t.push(` ${A(i.command)}${m}`)}}}return t.push(""),t.push(p("Pass --format=json for machine-readable output (designed for AI agents).")),t.push(p(`Run \`vis ${a.command} <subcommand> --help\` for full usage of a specific subcommand.`)),`${t.join(`
3
+ `)}
4
+ `},"renderDiscoveryText");var J=Object.defineProperty,u=l((e,o)=>J(e,"name",{value:o,configurable:!0}),"m");const L=u(async({options:e})=>{const{default:o}=await import("./bin.js").then(t=>t.ac),a=o.filter(t=>t.name!=="ai");if((e.format??"text")==="json"){process.stdout.write(O(a));return}process.stderr.write(R(a))},"aiRootExecute"),q=u(async({logger:e,visConfig:o})=>{const a=o?.ai,t=h(a);if(!t){e.error("No AI provider available to test."),process.exitCode=1;return}e.info(`Testing ${t.name}...`);try{const n=await x(t,"Reply with exactly: OK",{timeoutMs:3e4});e.info(`Provider ${t.name} responded: ${n.stdout.trim().slice(0,200)}`)}catch(n){const s=n instanceof Error?n.message:String(n);e.error(`Provider ${t.name} failed: ${s}`),process.exitCode=1}},"aiTestExecute"),z=u(({logger:e,options:o,visConfig:a})=>{const t=o.format??"table",n=a?.ai,s=P(),i=h(n);if(t==="json"){const r=s.map(c=>({available:c.available,method:c.detectionMethod,name:c.name,path:c.path,priority:f[c.name]??0,selected:c.name===i?.name,version:c.version}));process.stdout.write(`${JSON.stringify(r,void 0,2)}
5
+ `);return}const m=s.map(r=>({method:r.detectionMethod??"-",path:r.path??"-",priority:String(f[r.name]??0),provider:r.name,selected:r.name===i?.name?">>>":"",status:r.available?"available":"not found",version:r.version??"-"})),y=process.stdout.columns||80,b=S(E.createElement(w,{data:m}),{columns:y});e.info(b),i?e.info(`
6
+ Selected provider: ${i.name} (priority ${String(f[i.name]??0)})`):e.info(`
7
+ No AI provider available. Install one of the supported AI CLI tools.`)},"aiProvidersExecute"),G=u(async e=>{const{aiFix:o}=await import("./fix.js");await o(e)},"aiFixExecute");export{G as aiFixExecute,z as aiProvidersExecute,L as aiRootExecute,q as aiTestExecute};
@@ -0,0 +1,2 @@
1
+ var y=Object.defineProperty;var l=(t,r)=>y(t,"name",{value:r,configurable:!0});import{getAffectedProjects as v}from"@visulima/task-runner";import{r as E,s as F}from"./bin.js";import{f as b}from"../packem_shared/selectors-CfH9ZY08.js";var S=Object.defineProperty,$=l((t,r)=>S(t,"name",{value:r,configurable:!0}),"m");const A=$(async({argument:t,logger:r,options:e,runtime:h,visConfig:g,workspaceRoot:f})=>{const d=t[0];if(!d)throw new Error("Missing target. Usage: vis affected <target>");if(!f)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");const s=f,{packageJsons:m,workspace:i}=E(s,g),w=F(s,i,m),u=new Set(["deep","direct","none"]),c=e.downstream??"deep",p=e.upstream??"none";if(!u.has(c))throw new Error(`Invalid --downstream value: "${c}". Must be "none", "direct", or "deep".`);if(!u.has(p))throw new Error(`Invalid --upstream value: "${p}". Must be "none", "direct", or "deep".`);const j={base:e.base,downstream:c,head:e.head,projectGraph:w,projects:i.projects,upstream:p,workspaceRoot:s},o=await v(j);if(o.changedFiles.length===0){r.info("No files changed. Nothing to run.");return}if(o.affectedProjects.length===0){r.info("No projects affected by the changes.");return}let{affectedProjects:n}=o;if(e.query&&(n=b(n,i,e.query),n.length===0)){r.info(`Query "${String(e.query)}" matched no affected projects.`);return}r.info(`Affected projects: ${n.join(", ")}`),o.changedFiles.length>0&&(process.env.VIS_AFFECTED_FILES=o.changedFiles.join(`
2
+ `));const a=[d,`--projects=${n.join(",")}`];e.parallel!==void 0&&a.push(`--parallel=${String(e.parallel)}`),e.cache||a.push("--no-cache"),e.dryRun&&a.push("--dry-run"),e.partition&&a.push(`--partition=${String(e.partition)}`);try{await h.runCommand("run",{argv:a})}finally{delete process.env.VIS_AFFECTED_FILES}},"execute");export{A as default};
@@ -0,0 +1,23 @@
1
+ var re=Object.defineProperty;var V=(t,n)=>re(t,"name",{value:n,configurable:!0});import{dim as b,yellow as Y,cyan as Z,magenta as _,red as ee}from"@visulima/colorize";import{isAccessibleSync as G,readFileSync as B,writeFileSync as Q}from"@visulima/fs";import{readYamlSync as se}from"@visulima/fs/yaml";import{join as H}from"@visulima/path";import{S as oe,R as ae,c as ce,p as a,V as le,U as de,q as ue,b as W}from"./bin.js";import{l as ge,f as fe,s as pe}from"../packem_shared/dependency-scan-Du0tBu64.js";import{m as he}from"../packem_shared/catalog-BVPerCwG.js";var me=Object.defineProperty,S=V((t,n)=>me(t,"name",{value:n,configurable:!0}),"o");const L=S(t=>Array.isArray(t)?t.filter(n=>typeof n=="string"):[],"toStringArray"),K=S((t,n)=>{for(const r of n)if(r===t||r.endsWith("*")&&t.startsWith(r.slice(0,-1)))return!0;return!1},"matchesGlobList"),te=S(t=>{const n=H(t,"pnpm-workspace.yaml");if(!G(n))return{excludedPackages:[],ignoredAdvisories:[]};try{const r=se(n);return{excludedPackages:[],ignoredAdvisories:[...L(r?.auditConfig?.ignoreCves),...L(r?.auditConfig?.ignoreGhsas)]}}catch{return{excludedPackages:[],ignoredAdvisories:[]}}},"readPnpmAuditExclusions"),ne=S(t=>{const n=H(t,".yarnrc.yml");if(!G(n))return{excludedPackages:[],ignoredAdvisories:[]};try{const r=se(n);return{excludedPackages:L(r?.npmAuditExcludePackages),ignoredAdvisories:L(r?.npmAuditIgnoreAdvisories)}}catch{return{excludedPackages:[],ignoredAdvisories:[]}}},"readYarnAuditExclusions"),ve=S((t,n)=>{switch(n){case"pnpm":return te(t);case"yarn":return ne(t);default:return{excludedPackages:[],ignoredAdvisories:[]}}},"readNativeAuditExclusions"),X=S((t,n,r)=>{if(K(t,n.ignoredAdvisories))return!0;if(r){for(const l of r)if(K(l,n.ignoredAdvisories))return!0}return!1},"isAdvisoryExcluded"),$e=S((t,n)=>K(t,n.excludedPackages),"isPackageExcluded"),ke=S((t,n,r)=>{if(r.length===0)return["No advisory IDs to sync."];const l=[];switch(t){case"bun":{l.push(`bun has no audit config file. Use CLI flags: bun audit ${r.map(f=>`--ignore ${f}`).join(" ")}`);break}case"npm":{l.push("npm has no native audit exclusion config. vis accepted risks are the only layer.");break}case"pnpm":{const f=H(n,"pnpm-workspace.yaml");if(!G(f)){l.push("pnpm-workspace.yaml not found. Cannot sync.");break}const h=te(n),k=new Set(h.ignoredAdvisories.filter(c=>c.startsWith("CVE-"))),v=new Set(h.ignoredAdvisories.filter(c=>c.startsWith("GHSA-"))),y=r.filter(c=>c.startsWith("CVE-")),$=r.filter(c=>c.startsWith("GHSA-")),p=[...new Set([...k,...y])],d=[...new Set([...v,...$])],m=y.filter(c=>!k.has(c)).length,w=$.filter(c=>!v.has(c)).length;if(m===0&&w===0){l.push("All advisory IDs already present in pnpm-workspace.yaml.");break}let g=B(f);if(p.length>0){const c=` ignoreCves:
2
+ ${p.map(x=>` - ${x}`).join(`
3
+ `)}
4
+ `;/auditConfig:/.test(g)?g=/ignoreCves:/.test(g)?g.replace(/ignoreCves:\s*\n(?:\s+-\s+(?:\S.*|[\t\v\f \u00A0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF])\n)*/,c):g.replace(/auditConfig:\s*\n/,`auditConfig:
5
+ ${c}`):g=`${g.trimEnd()}
6
+
7
+ auditConfig:
8
+ ${c}`,m>0&&l.push(`Added ${String(m)} new CVE${m===1?"":"s"} to pnpm-workspace.yaml (${String(p.length)} total)`)}if(d.length>0){const c=` ignoreGhsas:
9
+ ${d.map(x=>` - ${x}`).join(`
10
+ `)}
11
+ `;/auditConfig:/.test(g)&&(g=/ignoreGhsas:/.test(g)?g.replace(/ignoreGhsas:\s*\n(?:\s+-\s+(?:\S.*|[\t\v\f \u00A0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF])\n)*/,c):g.replace(/(auditConfig:[\s\S]*?)(\n\S|\n?$)/m,`$1${c}$2`)),w>0&&l.push(`Added ${String(w)} new GHSA${w===1?"":"s"} to pnpm-workspace.yaml (${String(d.length)} total)`)}Q(f,g);break}case"yarn":{const f=H(n,".yarnrc.yml");if(!G(f)){l.push(".yarnrc.yml not found. Cannot sync.");break}const h=ne(n),k=new Set(h.ignoredAdvisories),v=[...new Set([...k,...r])],y=r.filter(d=>!k.has(d)).length;if(y===0){l.push("All advisory IDs already present in .yarnrc.yml.");break}let $=B(f);const p=`npmAuditIgnoreAdvisories:
12
+ ${v.map(d=>` - "${d}"`).join(`
13
+ `)}
14
+ `;$=/npmAuditIgnoreAdvisories:/.test($)?$.replace(/npmAuditIgnoreAdvisories:\s*\n(?:\s+-\s+(?:\S.*|[\t\v\f \u00A0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF])\n)*/,p):`${$.trimEnd()}
15
+
16
+ ${p}`,Q(f,$),l.push(`Synced ${String(y)} advisor${y===1?"y":"ies"} to .yarnrc.yml (${String(v.length)} total)`);break}default:l.push(`Unknown package manager: ${t}`)}return l},"syncAcceptedRisksToNativeConfig");var ye=Object.defineProperty,R=V((t,n)=>ye(t,"name",{value:n,configurable:!0}),"m");const U={CRITICAL:0,HIGH:1,LOW:3,MODERATE:2,UNKNOWN:4},Ae={critical:ee,high:_,low:Z,medium:Y},j=R((t,n)=>{const r=U[n.toUpperCase()]??U.MODERATE??2;return(U[t.toUpperCase()]??4)<=r},"severityPassesFilter"),Se={CRITICAL:ee,HIGH:_,LOW:Z,MODERATE:Y,UNKNOWN:b},we=R((t,n,r,l)=>{const f=Se[r.severity]??b,h=l?` ${b("[acknowledged]")}`:"",k=r.fixedVersions??[],v=k.length>0?` (fix: ${k.join(", ")})`:"";return` ${f(r.severity)} ${r.id} — ${t}@${n}${h}
17
+ ${r.summary}${v}`},"formatVulnLine"),Ce=R((t,n)=>{const r=oe(t),l=`${String(Math.round(t.score.overall*100))}%`,f=n?` ${b("[acknowledged]")}`:"",h=t.alerts.length>0?`, ${String(t.alerts.length)} alert${t.alerts.length===1?"":"s"}`:"";return` ${l} ${r}@${t.version} (${ae(t.score.overall)}${h})${f}`},"formatSocketLine"),Re=R(async(t,n,r,l)=>{const f=n.severity??"low",h=n.format==="json"||!!n.json,k=!!n.fix,v=!!n.showAccepted,y=r?.security?.socket,$=y?.acceptedRisks,p=ce(t),d=ve(t,p.name);(d.ignoredAdvisories.length>0||d.excludedPackages.length>0)&&a.info(`Loaded ${String(d.ignoredAdvisories.length)} ignored advisor${d.ignoredAdvisories.length===1?"y":"ies"} and ${String(d.excludedPackages.length)} excluded package${d.excludedPackages.length===1?"":"s"} from ${p.name} config.`);const m=ge(t,p.name);if(m.length===0){a.info(`No ${p.name} lockfile entries found. Run ${p.name} install first.`);return}h||a.info(`Scanning ${String(m.length)} installed packages…`);const w=m.map(e=>({name:e.name,version:e.version})),g=le(y),c=fe(t,p.name),x=[{id:"vulnerabilities",label:"Known vulnerabilities (OSV)"},...g?[{id:"socket",label:"Socket.dev supply-chain reports"}]:[]],C=pe(x,{live:!h}),ie=Date.now(),E=R(e=>{const s=Date.now()-e;return s>=1e3?`${(s/1e3).toFixed(1)}s`:`${String(Math.round(s))}ms`},"fmtElapsed");let q,J;try{const e=Date.now(),s=Date.now();C.start("vulnerabilities"),g&&C.start("socket"),[q,J]=await Promise.all([he(w).then(i=>{let o=0;for(const u of i.values())o+=u.length;return C.finish("vulnerabilities",o>0?"warn":"ok",o>0?`${String(o)} found · ${E(e)}`:`none found · ${E(e)}`),i}).catch(i=>{const o=i instanceof Error?i.message:String(i);return C.finish("vulnerabilities","error",o),new Map}),g?de(w,g).then(i=>{let o=0,u=0;for(const D of i.values())o+=D.alerts.length,D.score.overall<W&&(u+=1);const O=o+u;return C.finish("socket",O>0?"warn":"ok",O>0?`${String(o)} alert${o===1?"":"s"}, ${String(u)} low-score · ${E(s)}`:`clean · ${E(s)}`),i}).catch(i=>{const o=i instanceof Error?i.message:String(i);return C.finish("socket","error",o),new Map}):Promise.resolve(new Map)])}finally{C.stop()}h||a.info(b(`Scan completed in ${E(ie)}`));const M=[];for(const e of m){if($e(e.name,d))continue;const s=q.get(e.name)??[],i=J.get(`${e.name}@${e.version}`),o=ue(e.name,e.version,$),u=s.length>0,O=i?i.score.overall<W:!1,D=i?i.alerts.length>0:!1;(u||O||D)&&M.push({acceptedRisk:o,name:e.name,socketReport:i,version:e.version,vulnerabilities:s})}const A=M.filter(e=>{const s=e.vulnerabilities.some(u=>j(u.severity,f)),i=e.socketReport?.alerts.some(u=>j(u.severity==="medium"?"MODERATE":u.severity.toUpperCase(),f)),o=e.socketReport&&e.socketReport.score.overall<W;return s||i||o});if(h){const e={duplicates:c.map(s=>({name:s.name,versionCount:s.versions.length,versions:s.versions})),packages:m.length,results:A.map(s=>({acceptedRisk:s.acceptedRisk??null,name:s.name,socketAlerts:s.socketReport?.alerts??[],socketScore:s.socketReport?.score.overall??null,version:s.version,vulnerabilities:s.vulnerabilities})),summary:{accepted:A.filter(s=>s.acceptedRisk).length,duplicatePackages:c.length,issues:A.filter(s=>!s.acceptedRisk).length,total:A.length}};process.stdout.write(`${JSON.stringify(e,void 0,2)}
18
+ `),n.exitCode&&e.summary.issues>0&&(process.exitCode=1);return}if(A.length===0){a.success(`No security issues found across ${String(m.length)} packages.`);return}const I={CRITICAL:[],HIGH:[],LOW:[],MODERATE:[]};for(const e of A)for(const s of e.vulnerabilities)if(j(s.severity,f)){const i=s.severity==="UNKNOWN"?"LOW":s.severity;I[i]?.push({entry:e,vuln:s})}let F=0,T=0;for(const e of["CRITICAL","HIGH","MODERATE","LOW"]){const s=I[e];if(!(!s||s.length===0)){a.info(`
19
+ ── ${e} (${String(s.length)}) ──`);for(const{entry:i,vuln:o}of s){const u=!!i.acceptedRisk||X(o.id,d,o.aliases);u&&(T++,!v)||(F++,a.info(we(i.name,i.version,o,u)),k&&(o.fixedVersions??[]).length>0&&a.notice(` Fix: update to ${o.fixedVersions.at(-1)}`))}}}const P=A.filter(e=>e.socketReport&&(e.socketReport.score.overall<W||e.socketReport.alerts.length>0));if(P.length>0){a.info(`
20
+ ── Socket.dev Supply Chain (${String(P.length)}) ──`);for(const e of P){if(!e.socketReport)continue;const s=!!e.acceptedRisk;if(!(s&&!v)){a.info(Ce(e.socketReport,s));for(const i of e.socketReport.alerts){const o=Ae[i.severity]??b;a.info(` ${o(`[${i.severity.toUpperCase()}]`)} ${i.type} — ${i.category}`)}}}}if(c.length>0){a.info(`
21
+ ── Duplicate Dependencies (${String(c.length)}) ──`);for(const e of c){const s=e.versions.join(", ");a.info(` ${e.name} — ${String(e.versions.length)} versions: ${Y(s)}`)}}const N=R(e=>!!e.acceptedRisk||e.vulnerabilities.length>0&&e.vulnerabilities.every(s=>X(s.id,d,s.aliases)),"isEntryExcluded"),z=A.filter(e=>!N(e)).length;if(a.info(""),a.info("─ Audit Summary"),a.info(` ${String(m.length)} packages scanned`),d.ignoredAdvisories.length>0&&a.info(` ${String(d.ignoredAdvisories.length)} ${p.name} audit exclusion${d.ignoredAdvisories.length===1?"":"s"} applied`),F>0){const e=I.CRITICAL?.filter(i=>!N(i.entry)).length??0,s=I.HIGH?.filter(i=>!N(i.entry)).length??0;a.error(` ${String(F)} vulnerabilit${F===1?"y":"ies"} found`),e>0&&a.error(` ${String(e)} critical`),s>0&&a.warn(` ${String(s)} high`)}else a.success(" No vulnerabilities found");if(P.length>0){const e=P.filter(s=>!N(s)).length;a.warn(` ${String(e)} package${e===1?"":"s"} with Socket.dev supply chain issues`)}if(c.length>0&&(a.warn(` ${String(c.length)} package${c.length===1?"":"s"} with duplicate versions`),a.notice(" Run 'vis dedupe' or your package manager's dedupe command to reduce duplicates.")),T>0&&(a.info(` ${String(T)} acknowledged (accepted risks)`),v||a.notice(" Use --show-accepted to see acknowledged issues.")),z===0&&a.success(`
22
+ All issues are acknowledged. No action required.`),n.sync&&$){const e=new Set;for(const i of M)if(i.acceptedRisk){for(const o of i.vulnerabilities)if((o.id.startsWith("CVE-")||o.id.startsWith("GHSA-"))&&e.add(o.id),o.aliases)for(const u of o.aliases)(u.startsWith("CVE-")||u.startsWith("GHSA-"))&&e.add(u)}const s=[...e];if(s.length>0){a.info("");const i=ke(p.name,t,s);for(const o of i)a.success(` ${o}`)}else a.info(`
23
+ No advisory IDs to sync to native PM config.`)}n.exitCode&&z>0&&(process.exitCode=1)},"executeAudit"),De=R(async({logger:t,options:n,visConfig:r,workspaceRoot:l})=>{if(!l)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");await Re(l,n,r,t)},"execute");export{De as default};
@@ -0,0 +1,3 @@
1
+ var I=Object.defineProperty;var w=(e,t)=>I(e,"name",{value:t,configurable:!0});import{createRequire as D}from"node:module";import{getAffectedProjects as G}from"@visulima/task-runner";import{r as q,s as L}from"./bin.js";const T=D(import.meta.url),h=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,A=w(e=>{if(typeof h<"u"&&h.versions&&h.versions.node){const[t,r]=h.versions.node.split(".").map(Number);if(t>22||t===22&&r>=3||t===20&&r>=16)return h.getBuiltinModule(e)}return T(e)},"__cjs_getBuiltinModule"),{execFile:N}=A("node:child_process"),{promisify:U}=A("node:util");var V=Object.defineProperty,i=w((e,t)=>V(e,"name",{value:t,configurable:!0}),"t");const M=U(N),J=["[skip ci]","[ci skip]","[no ci]","[vis skip]","[nx skip]"],z=["[vis deploy]","[nx deploy]"],W=["vis","nx"],Z=["CACHED_COMMIT_REF","VERCEL_GIT_PREVIOUS_SHA","GITHUB_BASE_REF","CI_COMMIT_BEFORE_SHA"],K=/^[\w./~^@{}][\w.\-/~^@{}]*$/,Q=i((e=process.env)=>{for(const t of Z){const r=e[t];if(r&&r.trim().length>0)return r.trim()}},"resolveCiBaseSha"),R=i(e=>{if(!K.test(e))throw new Error(`Invalid git ref: "${e}". Refs must start with an alphanumeric character or one of _ . / ~ ^ @ { } and may only contain letters, digits, dots, dashes, underscores, slashes, tildes, carets, @, and braces.`)},"validateGitRef"),X=i(async(e,t)=>{try{return await M("git",["rev-parse","--verify",`${t}^{commit}`],{cwd:e}),!0}catch{return!1}},"isRefReachable"),Y=i(async e=>{try{const{stdout:t}=await M("git",["log","-1","--pretty=%B"],{cwd:e});return t}catch{return""}},"readLastCommitMessage"),B=i((e,t,r)=>W.some(a=>e.includes(`[${a} ${t} ${r}]`)),"matchesPerProjectToken"),ee=i((e,t)=>J.some(r=>e.includes(r))||B(e,"skip",t),"commitHasSkipMessage"),te=i((e,t)=>z.some(r=>e.includes(r))||B(e,"deploy",t),"commitHasForceDeployMessage"),l=i((e,t,r,a)=>({action:"build",message:r,project:e,reason:t,...a}),"decideBuild"),k=i((e,t,r,a)=>({action:"skip",message:r,project:e,reason:t,...a}),"decideSkip"),re=i(e=>`${e.action==="skip"?"🛑":"✅"} ${e.message}`,"formatDecisionLine"),oe=i((e,t)=>e.action==="skip"||t?0:1,"exitCodeFor");var se=Object.defineProperty,_=w((e,t)=>se(e,"name",{value:t,configurable:!0}),"u");const S=new Set(["deep","direct","none"]),de=_(async({argument:e,logger:t,options:r,visConfig:a,workspaceRoot:p})=>{const o=e[0]??"",E=!!r.json,C=!!r.verbose,O=!!(r["exit-zero-on-build"]??r.exitZeroOnBuild),u=_(s=>{C&&!E&&t.info(`❱ ${s}`)},"debug"),n=_(s=>{E?process.stdout.write(`${JSON.stringify(s)}
2
+ `):t.info(re(s)),process.exit(oe(s,O))},"emit");if(!o)return n(l("","missing-project-argument","Missing project argument. Usage: vis ignore <project>"));if(!p)return n(l(o,"workspace-error","Could not determine workspace root — building defensively"));const g=await Y(p),y=g.trim().split(`
3
+ `)[0]??"";if(u(`commit: ${y}`),g&&te(g,o))return n(l(o,"commit-force-deploy",`Force-deploy keyword in commit: "${y}"`));if(g&&ee(g,o))return n(k(o,"commit-skip",`Skip keyword in commit: "${y}"`));let $,P;try{({packageJsons:P,workspace:$}=q(p,a))}catch(s){const d=s instanceof Error?s.message:String(s);return n(l(o,"workspace-error",`Workspace discovery failed (${d}) — building defensively`))}if(!Object.hasOwn($.projects,o))return n(l(o,"project-unknown",`Project "${o}" not found in workspace — building defensively`));try{const s=r.base?.trim(),d=Q();let c=s||d||"HEAD~1";const m=r.head?.trim()||"HEAD";R(c),R(m),u(`resolved base ref: ${c} (source: ${s?"flag":d?"ci-env":"default"})`);const x=X(p,c),F=L(p,$,P);await x||(u(`base ref ${c} not reachable — falling back to HEAD~1`),c="HEAD~1"),u(`comparing ${c}...${m}`);const j=r.downstream??"deep",b=r.upstream??"none";if(!S.has(j))throw new Error(`Invalid --downstream value: "${j}". Must be "none", "direct", or "deep".`);if(!S.has(b))throw new Error(`Invalid --upstream value: "${b}". Must be "none", "direct", or "deep".`);const H={base:c,downstream:j,head:m,projectGraph:F,projects:$.projects,upstream:b,workspaceRoot:p},f=await G(H);u(`changed files: ${f.changedFiles.length}`),u(`affected projects: ${f.affectedProjects.join(", ")||"(none)"}`);const v={base:c,head:m};return f.changedFiles.length===0?n(k(o,"no-changes",`No files changed between ${c}...${m}`,{...v,affectedProjects:[]})):f.affectedProjects.includes(o)?n(l(o,"project-affected",`Build ${o}: affected by ${f.changedFiles.length} changed file(s)`,{...v,affectedProjects:f.affectedProjects})):n(k(o,"project-not-affected",`Skip ${o}: not affected by changes between ${c}...${m}`,{...v,affectedProjects:f.affectedProjects}))}catch(s){const d=s instanceof Error?s.message:String(s);return t.error(`Affected detection failed: ${d}`),n(l(o,"workspace-error",`Affected detection failed (${d}) — building defensively`))}},"execute");export{de as default};
@@ -0,0 +1,2 @@
1
+ var m=Object.defineProperty;var d=(r,o)=>m(r,"name",{value:o,configurable:!0});import{createRequire as g}from"node:module";import{writeFileSync as $}from"@visulima/fs";import{join as w}from"@visulima/path";import{r as v}from"./bin.js";const j=g(import.meta.url),a=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,y=d(r=>{if(typeof a<"u"&&a.versions&&a.versions.node){const[o,e]=a.versions.node.split(".").map(Number);if(o>22||o===22&&e>=3||o===20&&e>=16)return a.getBuiltinModule(r)}return j(r)},"__cjs_getBuiltinModule"),{readFileSync:b}=y("node:fs");var k=Object.defineProperty,f=d((r,o)=>k(r,"name",{value:o,configurable:!0}),"i");const C=f((r,o)=>{const e=o.replace(/^\.?\//,"");return e===""||e==="."?`/${r}/`:r===""||r==="."?`/${e}`:`/${r}/${e}`},"toWorkspacePath"),_=f((r,o)=>{const e=[];for(const[n,t]of Object.entries(o?.globalPaths??{}))e.push({owners:t,path:n});for(const[n,t]of Object.entries(r.projects)){const s=t.owners??[];for(const c of s)e.push({channel:c.channel,owners:c.owners,path:C(t.root??n,c.path),projectId:n})}return(o?.orderBy??"file-source")==="project-id"?e.sort((n,t)=>(n.projectId??"").localeCompare(t.projectId??"")||n.path.localeCompare(t.path)):e.sort((n,t)=>n.path.localeCompare(t.path)),e},"buildCodeownersLines"),E=["# CODEOWNERS — generated by `vis sync codeowners`. Do not edit by hand.","# Update each project's project.json `owners` field and re-run the command.",""],O=f((r,o="github")=>{const e=[...E];for(const n of r){const t=n.owners.join(" "),s=n.channel?` # notify: ${n.channel}`:"";e.push(`${n.path} ${t}${s}`)}return e.push(""),e.join(`
2
+ `)},"renderCodeowners");var N=Object.defineProperty,R=d((r,o)=>N(r,"name",{value:o,configurable:!0}),"p");const x=R(async({argument:r,logger:o,options:e,visConfig:n,workspaceRoot:t})=>{const s=r[0];if(!s)throw new Error("Missing sync kind. Usage: vis sync <kind> (known kinds: codeowners)");if(!t)throw new Error("Could not determine workspace root. Run inside a monorepo.");if(s!=="codeowners")throw new Error(`Unknown sync kind: "${s}". Known kinds: codeowners.`);const{workspace:c}=v(t,n),p=_(c,n?.codeowners);if(p.length===0){o.info("No `owners` entries found in any project. Nothing to sync.");return}const l=O(p,n?.codeowners?.provider??"github"),i=e.out?w(t,e.out):w(t,"CODEOWNERS");if(e.check){let u="";try{u=b(i,"utf8")}catch(h){if(h.code==="ENOENT")u="";else throw h}if(u.trim()!==l.trim()){o.error(`${i} is out of date. Run \`vis sync codeowners\` to update it.`),process.exitCode=1;return}o.info(`${i} is up to date.`);return}$(i,l),o.info(`Wrote ${p.length} entries to ${i}`)},"execute");export{x as default};
@@ -0,0 +1,24 @@
1
+ var ue=Object.defineProperty;var M=(e,t)=>ue(e,"name",{value:t,configurable:!0});import{createRequire as de}from"node:module";import{yellow as D,red as fe}from"@visulima/colorize";import{isAccessibleSync as G,readJsonSync as he}from"@visulima/fs";import{readYamlSync as $e}from"@visulima/fs/yaml";import{findPackageManagerSync as ke,getPackageManagerVersion as ve}from"@visulima/package";import{join as H}from"@visulima/path";import{render as K,renderToString as W,Text as b}from"@visulima/tui";import{k as we,V as ye,B as be,d as Se,J as Re}from"./bin.js";import $ from"react";import{z as Ce,e as Ae,Z as Q}from"../packem_shared/ai-analysis-CGuy7dfE.js";import{r as Ee,s as Te}from"../packem_shared/typosquats-DOR8izpX.js";import{U as xe,B as je,f as X}from"../packem_shared/VisUpdateApp-D-L4_-Iu.js";import{N as A,C as Ue,O as Ne,T as _e,v as re,V as Be,L as ae,o as Oe,a as qe,w as Me,c as Pe,E as Fe,S as Ve,s as ze}from"../packem_shared/catalog-BVPerCwG.js";import{d as Ye}from"../packem_shared/utils-DrNg0XTR.js";const ge=de(import.meta.url),_=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,me=M(e=>{if(typeof _<"u"&&_.versions&&_.versions.node){const[t,n]=_.versions.node.split(".").map(Number);if(t>22||t===22&&n>=3||t===20&&n>=16)return _.getBuiltinModule(e)}return ge(e)},"__cjs_getBuiltinModule"),{execSync:oe}=me("node:child_process");var Le=Object.defineProperty,E=M((e,t)=>Le(e,"name",{value:t,configurable:!0}),"s");const We=E(e=>{const t=[];for(const n of e.filters)t.push("--filter",n);return e.workspaceRoot&&t.push("--filter","."),t.push("update"),e.latest&&t.push("--latest"),e.recursive&&t.push("--recursive"),e.interactive&&t.push("--interactive"),e.dev&&t.push("--dev"),e.prod&&t.push("--prod"),e.noOptional&&t.push("--no-optional"),e.noSave&&t.push("--no-save"),t.push(...e.packages),{args:t,bin:"pnpm"}},"resolvePnpm"),De=E(e=>{const t=[];return e.filters.length>0&&t.push("workspace",e.filters[0]),t.push("upgrade"),e.latest&&t.push("--latest"),t.push(...e.packages),{args:t,bin:"yarn"}},"resolveYarnV1"),Ie=E(e=>{const t=[];if(e.filters.length>0||e.recursive){t.push("workspaces","foreach","--all");for(const n of e.filters)t.push("--include",n)}return t.push("up"),e.interactive&&t.push("--interactive"),t.push(...e.packages),{args:t,bin:"yarn"}},"resolveYarnBerry"),Je=E((e,t)=>{const n=["update"];e.latest&&t.push("npm does not support --latest flag. Packages will be updated within their semver range."),e.interactive&&t.push("npm does not support --interactive mode.");for(const o of e.filters)n.push("--workspace",o);return e.recursive&&n.push("--workspaces"),e.workspaceRoot&&n.push("--include-workspace-root"),e.dev&&n.push("--dev"),e.prod&&n.push("--production"),e.noOptional&&n.push("--no-optional"),e.noSave&&n.push("--no-save"),n.push(...e.packages),{args:n,bin:"npm"}},"resolveNpm"),Ze=E(e=>{const t=["update"];e.latest&&t.push("--latest");for(const n of e.filters)t.push("--filter",n);return t.push(...e.packages),{args:t,bin:"bun"}},"resolveBun"),Ge=E((e,t,n)=>{const o=[];if(n.global&&e!=="aube")return{command:{args:["update","--global",...n.packages],bin:"npm"},warnings:o};let l;switch(e){case"aube":{const r=we(n);l={args:r.args,bin:r.bin},o.push(...r.warnings);break}case"bun":{l=Ze(n);break}case"npm":{l=Je(n,o);break}case"pnpm":{l=We(n);break}case"yarn":{l=t.startsWith("1.")?De(n):Ie(n);break}default:{const r=e;throw new Error(`Unsupported package manager: ${String(r)}`)}}return{command:l,warnings:o}},"resolveUpdateCommand");var He=Object.defineProperty,S=M((e,t)=>He(e,"name",{value:t,configurable:!0}),"w");const Ke=S((e,t)=>{try{if(t==="pnpm"){const n=H(e,"pnpm-workspace.yaml");if(G(n)){const o=$e(n);if(typeof o?.minimumReleaseAge=="number")return o.minimumReleaseAge}}else if(t==="bun"){const n=H(e,"package.json");if(G(n)){const o=he(n);if(typeof o.minimumReleaseAge=="number")return o.minimumReleaseAge}}}catch{}},"readPmNativeMinimumReleaseAge"),Qe=S((e,t,n)=>{const o=e.latest?"latest":e.target??t.target??"latest";if(!["latest","minor","patch"].includes(o))throw new Error(`Invalid target "${o}". Use: latest, minor, or patch.`);return{exclude:[...A(e.exclude),...A(t.exclude)],ignore:A(t.ignore),include:[...A(e.include),...A(t.include),...n],includeLocked:e.includeLocked||t.includeLocked||!1,includePrerelease:e.prerelease||t.prerelease||!1,minimumReleaseAge:t.minimumReleaseAge,minimumReleaseAgeExclude:t.minimumReleaseAgeExclude,packageMode:t.packageMode,security:e.security||e.ai||t.security||!1,target:o}},"buildCatalogCheckOptions"),ee=S((e,t)=>{if(e.length!==0){t.info(`
2
+ ${D("⚠")} ${String(e.length)} package${e.length===1?"":"s"} skipped by target constraint (use --target latest to include):`);for(const n of e)t.info(` ${n.packageName} ${n.currentRange} → ${n.newRange} (${n.updateType})`)}},"logFilteredByTarget"),te=S((e,t,n,o)=>{n==="json"?process.stdout.write(`${Ue({checkedCount:0,failed:t,filteredByTarget:[],ignored:[],outdated:e})}
3
+ `):n==="minimal"?process.stdout.write(`${Ne(e)}
4
+ `):(_e(e,o),o.info(re(e)))},"writeFormattedOutput"),ne=S(async(e,t,n,o,l)=>{const r=Be(e,n,t),s=t==="pnpm"?"pnpm-workspace.yaml":"package.json";if(l.info(`
5
+ Updated ${s}`),r&&l.info(`Backup saved to ${r}`),o.changelog){l.info(`
6
+ Fetching changelogs...`);const u=await ae(n);for(const c of u){const f=c.releaseUrl??c.repoUrl??c.npmUrl;l.info(` ${c.packageName}: ${f}`)}}if(o.install??!0){const u={bun:"bun install",npm:"npm install",pnpm:"pnpm install",yarn:"yarn install"}[t]??`${t} install`;l.info(`Running ${u}...
7
+ `);try{oe(u,{cwd:e,env:process.env,stdio:"inherit"})}catch{l.warn(`${u} failed. You may need to run it manually.`)}}},"applyCatalogAndInstall"),Xe=S(async(e,t,n,o,l,r)=>{const s=n.update??{},u=[["global","--global is not supported in catalog mode"],["recursive","--recursive is not needed in catalog mode (catalogs are workspace-level)"],["filter","--filter is not supported in catalog mode (use --include/--exclude instead)"],["no-save","--no-save is not supported in catalog mode"],["workspace-root","--workspace-root is not needed in catalog mode"],["no-optional","--no-optional is not supported in catalog mode"]];for(const[a,h]of u)o[a]&&r.warn(`${D("⚠")} ${h}, ignoring.`);const c=Ke(e,t),f=s.minimumReleaseAge??c;if(s.minimumReleaseAge!==void 0&&c!==void 0&&s.minimumReleaseAge!==c){const a=t==="pnpm"?"pnpm-workspace.yaml":"package.json";r.warn(`${D("⚠")} minimumReleaseAge mismatch: vis config = ${String(s.minimumReleaseAge)} min, ${a} = ${String(c)} min. Consider keeping them in sync.`)}const w=Oe(e),p=qe(e,t,{depFields:s.depFields,dev:o.dev,prod:o.prod});if(p.size===0){r.info("No catalogs found.");return}const B={...s,minimumReleaseAge:f},T=Qe(o,B,l);let P=0;for(const a of p.values())P+=a.size;const O=!!process.stdout.isTTY&&!Se;let C;const se=O?(a,h)=>{C?C.rerender($.createElement(X,{current:a,total:h})):C=K($.createElement(X,{current:a,total:h}),{interactive:!0,patchConsole:!1})}:(a,h)=>{r.info(`Checking ${String(a)}/${String(h)} dependencies...`)};O||r.info(`Checking ${String(P)} catalog dependencies...
8
+ `);const ie=ye(n.security?.socket),{checkedCount:k,failed:v,filteredByTarget:g,ignored:x,outdated:d}=await Me(p,T,w,se,e,ie,n.security?.socket?.acceptedRisks);C&&(C.clear(),C.unmount());const I=k-d.length-v.length;if(v.length>0&&r.warn(`Failed to fetch: ${v.join(", ")}`),x.length>0&&r.info(`Skipped ${String(x.length)} ignored package${x.length===1?"":"s"}: ${x.join(", ")}`),!O&&k>d.length){const a=[...p.values()].reduce((N,V)=>N+V.size,0),h=a>k?` (${String(a)} catalog entries, ${String(a-k)} duplicates)`:"";r.info(`Checked ${String(k)} unique packages${h}: ${String(d.length)} outdated, ${String(I)} up-to-date${v.length>0?`, ${String(v.length)} failed`:""}${g.length>0?`, ${String(g.length)} skipped by target`:""}`)}if(d.length===0){g.length>0?r.info(`All catalog dependencies are up to date within the current target.
9
+ ${String(g.length)} package${g.length===1?" has":"s have"} newer versions available with --target latest:
10
+ ${g.map(a=>` ${a.packageName} ${a.currentRange} → ${a.newRange} (${a.updateType})`).join(`
11
+ `)}`):r.info("All catalog dependencies are up to date.");return}const j=o.format??s.format??"table";let y;if(o.ai){const a=Ce(o.aiType??"impact");y=await Ae(d,r,n.ai,a)}const F=!!o.dryRun;if(O&&j==="table"){const a=new xe(d,y??null);let h;if(o.changelog){r.info("Fetching changelogs...");const i=await ae(d);h=new Map;for(const m of i){const R=m.releaseUrl??m.repoUrl??m.npmUrl;R&&h.set(m.packageName,R)}}const N=n.tui?.autoExit??!1,V=N===!0?3:typeof N=="number"?N:0,J=await K($.createElement(je,{autoExitSeconds:V,changelogUrls:h,checkedCount:k,filteredOutEntries:g,isDryRun:F,store:a,totalCatalogEntries:P}),{alternateScreen:!0,exitOnCtrlC:!1,interactive:!0,patchConsole:!0}).waitUntilExit(),z=process.stdout.columns||80;process.stdout.write(`
12
+ `);for(const i of d){const m=i.vulnerabilities?.length||i.socketReport&&i.socketReport.alerts.length>0,R=!!i.acceptedRisk,L=m?R?"✓":"⚠":"✓",ce=R?"gray":i.updateType==="major"?"red":i.updateType==="minor"?"yellow":"green",q=i.socketReport?.score.overall,pe=q===void 0?"":` [${String(Math.round(q*100))}%]`,Z=q===void 0?void 0:be(q);process.stdout.write(`${W($.createElement(b,null," ",$.createElement(b,{color:ce},L),` ${i.packageName} ${i.currentRange} → ${i.newRange}`,$.createElement(b,{dimColor:!0},` ${i.updateType}`),Z?$.createElement(b,{color:Z},pe):null),{columns:z})}
13
+ `)}if(process.stdout.write(`
14
+ `),r.info(re(d)),k>d.length){const i=[...p.values()].reduce((R,L)=>R+L.size,0),m=i>k?` (${String(i)} catalog entries, ${String(i-k)} duplicates)`:"";r.info(` Checked ${String(k)} unique packages${m}: ${String(I)} up-to-date${v.length>0?`, ${String(v.length)} failed`:""}`)}if(g.length>0){process.stdout.write(`
15
+ `);const i=`${String(g.length)} package${g.length===1?"":"s"} skipped by target constraint (use --target latest to include):`;process.stdout.write(`${W($.createElement(b,{color:"yellow"},` ${i}`),{columns:z})}
16
+ `);for(const m of g)process.stdout.write(`${W($.createElement(b,null," ",$.createElement(b,{dimColor:!0},m.packageName),` ${m.currentRange} → ${m.newRange}`,$.createElement(b,{dimColor:!0},` ${m.updateType}`)),{columns:z})}
17
+ `)}const Y=Array.isArray(J)?J:[];if(Y.length>0&&!F){r.info(`
18
+ Applying ${String(Y.length)} updates...
19
+ `);const i={...o,install:o.install??s.install};await ne(e,t,Y,i,r)}return}if(F){if(j==="json"){const a={failed:v,filteredByTarget:g,ignored:x,outdated:d};y&&(a.aiAnalysis=y),process.stdout.write(`${JSON.stringify(a,void 0,2)}
20
+ `)}else r.info(`Would update ${String(d.length)} dependencies:
21
+ `),te(d,v,j,r),y&&(r.info(""),r.info(Q(y))),ee(g,r);return}y&&j!=="json"&&(r.info(Q(y)),r.info(""));let U=d;if(o.interactive&&(U=await Pe(d),U.length===0)){r.info("No updates selected.");return}r.info(`Updating ${String(U.length)} catalog dependencies...
22
+ `),te(U,[],j,r),ee(g,r);const le={...o,install:o.install??s.install};await ne(e,t,U,le,r)},"executeCatalogUpdate"),et=S((e,t,n,o,l,r)=>{const s={dev:o.dev,filters:A(o.filter),global:o.global,interactive:o.interactive,latest:o.latest||o.target==="latest",noOptional:o.noOptional,noSave:o.noSave,packages:l,prod:o.prod,recursive:o.recursive,workspaceRoot:o.workspaceRoot},{command:u,warnings:c}=Ge(t,n,s);for(const w of c)r.warn(w);const f=`${u.bin} ${u.args.join(" ")}`.trim();if(o.dryRun){r.info(`Would run: ${f}`);return}r.info(`Running: ${f}`);try{oe(f,{cwd:e,env:process.env,stdio:"inherit"})}catch(w){const p=w.status??1;r.error(`
23
+ ${fe("✖")} Update failed (exit code ${String(p)})`),r.error(` Command: ${f}`),r.error(` Directory: ${e}
24
+ `),process.exitCode=p}},"executePmWrapper"),ht=S(async({argument:e,logger:t,options:n,visConfig:o,workspaceRoot:l})=>{if(!l)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");let r=e;const s=l,{packageManager:u}=ke(s);if(!n.noTyposquatCheck){if(r.length>0){const c=r.map(p=>Ye(p)),f=o?.security?.typosquatAllowlist,w=await Ee(c.map(p=>p.name),f);if(!w.ok){process.exitCode=1;return}r=c.map((p,B)=>{const T=w.packages[B];return T!==p.name?p.versionSpec?`${T}@${p.versionSpec}`:T??"":r[B]??""})}else if(!await Te(s,o?.security?.typosquatAllowlist)){process.exitCode=1;return}}if(n.rollback){if(!Fe(s,u)){t.info("No backup found. Run 'vis update' first to create a backup.");return}if(Ve(s,u))t.info("Restored from backup.");else throw new Error("Failed to restore from backup.");return}if(!n.noCatalog&&ze(s,u))await Xe(s,u,o??{},n,r,t);else{const c=Re(s,{configBackend:o?.install?.backend}),f=c.name==="aube"?"":ve(c.name);et(s,c.name,f,n,r,t)}},"execute");export{ht as default};
@@ -0,0 +1,2 @@
1
+ var v=Object.defineProperty;var u=(e,o)=>v(e,"name",{value:o,configurable:!0});import{createRequire as R}from"node:module";import{v as h,$ as x,w as C,x as s,y as E,z as j,A as $,C as M,E as S,F as I,K as T,L as _}from"./bin.js";import{isAccessibleSync as d,readFileSync as k}from"@visulima/fs";import{join as m}from"@visulima/path";const w=R(import.meta.url),p=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,b=u(e=>{if(typeof p<"u"&&p.versions&&p.versions.node){const[o,r]=p.versions.node.split(".").map(Number);if(o>22||o===22&&r>=3||o===20&&r>=16)return p.getBuiltinModule(e)}return w(e)},"__cjs_getBuiltinModule"),{stdin:y,stdout:D}=p,{createInterface:N}=b("node:readline/promises");var O=Object.defineProperty,P=u((e,o)=>O(e,"name",{value:o,configurable:!0}),"o");const F=P(async e=>{if(!y.isTTY)return!0;const o=N({input:y,output:D});try{const r=(await o.question(`${e} [Y/n] `)).trim().toLowerCase();return r===""||r==="y"||r==="yes"}finally{o.close()}},"confirm");var L=Object.defineProperty,f=u((e,o)=>L(e,"name",{value:o,configurable:!0}),"c$1");const q=[".husky/pre-commit",".vis-hooks/pre-commit",".git/hooks/pre-commit"],B=[".secretlintrc",".secretlintrc.json",".secretlintrc.js",".secretlintrc.mjs",".secretlintrc.cjs",".secretlintrc.yml",".secretlintrc.yaml"],K=f(e=>{const o=m(e,"package.json");if(!d(o))return[];let r;try{r=JSON.parse(k(o))}catch{return[]}const i=[];if(r.scripts)for(const[t,l]of Object.entries(r.scripts))typeof l=="string"&&(/\bgitleaks\b/.test(l)&&i.push({detail:`Script "${t}" still invokes gitleaks: ${l}`,kind:"script",location:"package.json"}),/\bsecretlint\b/.test(l)&&i.push({detail:`Script "${t}" still invokes secretlint: ${l}`,kind:"script",location:"package.json"}));if(r.devDependencies)for(const t of Object.keys(r.devDependencies))(t==="gitleaks"||t==="@gitleaks/cli")&&i.push({detail:`devDependency \`${t}\` is still installed`,kind:"devDep",location:"package.json"}),(t==="secretlint"||t.startsWith("@secretlint/"))&&i.push({detail:`devDependency \`${t}\` is still installed`,kind:"devDep",location:"package.json"});return i},"scanPackageJson"),A=f(e=>{const o=[];for(const r of q){const i=m(e,r);if(!d(i))continue;const t=k(i);/\bgitleaks\b/.test(t)&&o.push({detail:"gitleaks invocation still present in hook",kind:"hook",location:r}),/\bsecretlint\b/.test(t)&&o.push({detail:"secretlint invocation still present in hook",kind:"hook",location:r})}return o},"scanHooks"),G=f(e=>{const o=[];for(const r of B)d(m(e,r))&&o.push({detail:"secretlint config should be removed after migration",kind:"config",location:r});return o},"scanConfigs"),J=f((e,o)=>{const r=[...K(e),...A(e),...G(e)];if(r.length===0)return o.info("✓ No unmigrated gitleaks/secretlint references found."),[];o.warn(`Found ${String(r.length)} unmigrated reference(s):`);for(const i of r)o.warn(` [${i.kind}] ${i.location} — ${i.detail}`);return r},"verifyMigration");var Q=Object.defineProperty,n=u((e,o)=>Q(e,"name",{value:o,configurable:!0}),"r");const a=n(e=>{const o=e.workspaceRoot??process.cwd();return{config:e.visConfig??{},dryRun:!!e.options.dryRun,logger:e.logger,packageManager:x(o),report:h(),root:o}},"buildContext"),c=n(async(e,o,r)=>{if(o.yes||o.dryRun)return!0;const i=await F(`This will edit files, scripts, and hooks for "${e}". Backups (.bak) will be created. Continue?`);return i||r.info("Aborted."),i},"maybeConfirm"),g=n(e=>{e.dryRun&&e.logger.info(`Running in dry-run mode — no changes will be made.
2
+ `)},"announceDryRun"),V=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("deps",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating dependencies and scripts ──"),C(t.root,t.packageManager,t.config,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateDepsExecuteImpl"),W=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("lint-staged",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating lint-staged ──"),E(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateLintStagedExecuteImpl"),Y=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("nano-staged",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating nano-staged ──"),j(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateNanoStagedExecuteImpl"),z=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("turborepo",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating turborepo ──"),$(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateTurborepoExecuteImpl"),H=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("nx",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating nx ──"),M(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateNxExecuteImpl"),U=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("moon",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating moon ──"),S(t.root,{copyTemplates:!!o.copyTemplates,dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateMoonExecuteImpl"),X=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("gitleaks",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating gitleaks ──"),I(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateGitleaksExecuteImpl"),Z=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("kingfisher",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating Kingfisher ──"),T(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateKingfisherExecuteImpl"),ee=n(async({logger:e,options:o,visConfig:r,workspaceRoot:i})=>{if(!await c("secretlint",o,e))return;const t=a({logger:e,options:o,visConfig:r,workspaceRoot:i});g(t),e.info("── Migrating secretlint ──"),_(t.root,{dryRun:t.dryRun},e,t.report),e.info(""),s(t.report,e)},"migrateSecretlintExecuteImpl"),te=n(({logger:e,workspaceRoot:o})=>{const r=o??process.cwd();J(r,e).length>0&&(process.exitCode=1)},"migrateVerifyExecuteImpl"),ae=V,ce=W,ge=Y,pe=z,le=H,ue=U,fe=X,de=Z,me=ee,ye=te;export{ae as migrateDepsExecute,fe as migrateGitleaksExecute,de as migrateKingfisherExecute,ce as migrateLintStagedExecute,ue as migrateMoonExecute,ge as migrateNanoStagedExecute,le as migrateNxExecute,me as migrateSecretlintExecute,pe as migrateTurborepoExecute,ye as migrateVerifyExecute};
@@ -0,0 +1,19 @@
1
+ var ne=Object.defineProperty;var v=(t,e)=>ne(t,"name",{value:e,configurable:!0});import{createRequire as ie}from"node:module";import{dim as l,bold as b,cyan as S}from"@visulima/colorize";import{join as k,isAbsolute as C,relative as z,sep as ce,dirname as le,resolve as fe}from"@visulima/path";import{isAccessibleSync as D,walkSync as J,ensureDirSync as Q,writeFileSync as pe}from"@visulima/fs";import{downloadTemplate as ge}from"giget";import{p as f}from"./bin.js";const ae=ie(import.meta.url),j=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,I=v(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 ae(t)},"__cjs_getBuiltinModule"),{createInterface:ue}=I("node:readline"),{mkdtempSync:de,rmSync:me}=I("node:fs"),{tmpdir:he}=I("node:os"),{spawnSync:we}=I("node:child_process");var $e=Object.defineProperty,w=v((t,e)=>$e(t,"name",{value:e,configurable:!0}),"i");const X=[".ts",".mts",".cts",".js",".mjs",".cjs"],ye="template.yml",ve=[".d",".test",".spec",".config",".bench",".stories"],be=[".d.ts",".d.mts",".d.cts",".js.map",".mjs.map",".cjs.map",".ts.map"],Z=w(t=>{for(const e of X)if(t.endsWith(e))return t.slice(0,-e.length);return t},"stripExtension"),Se=w(t=>{if(be.some(r=>t.endsWith(r))||!X.some(r=>t.endsWith(r)))return!1;const e=Z(t);return!ve.some(r=>e.endsWith(r))},"isNativeFile"),U=w((t,e)=>{const r=[];if(!D(t))return r;for(const s of J(t,{includeDirs:!1,includeSymlinks:!1,maxDepth:1})){if(!Se(s.name))continue;const o=Z(s.name);r.push({load:w(()=>Te(s.path),"load"),name:o,path:s.path,source:e})}return r},"scanNativeDirectory"),M=w((t,e)=>{const r=[];if(!D(t))return r;for(const s of J(t,{includeFiles:!1,includeSymlinks:!1,maxDepth:1})){if(s.path===t)continue;const o=k(s.path,ye);D(o)&&r.push({load:w(()=>Oe(s.path,s.name),"load"),name:s.name,path:s.path,source:e})}return r},"scanMoonDirectory"),q=w(t=>{const{extraDirectories:e=[],onWarning:r,workspaceRoot:s}=t,o=[];o.push(...U(k(s,".vis","templates"),"native")),o.push(...M(k(s,".vis","templates"),"moon")),o.push(...M(k(s,".moon","templates"),"moon"));for(const n of e)o.push(...M(n,"config")),o.push(...U(n,"config"));const a=new Map;for(const n of o){const i=a.get(n.name);if(!i){a.set(n.name,n);continue}r&&r(`Template "${n.name}" exists in multiple sources — using ${i.source} (${i.path}), ignoring ${n.source} (${n.path}).`)}return[...a.values()].sort((n,i)=>n.name.localeCompare(i.name))},"discoverTemplates"),Te=w(async t=>{const{loadNativeTemplate:e}=await import("./loader.js");return e(t)},"loadNativeFromPath"),Oe=w(async(t,e)=>{const{loadMoonTemplate:r}=await import("./index.js");return r(t,e)},"loadMoonFromPath");var ke=Object.defineProperty,g=v((t,e)=>ke(t,"name",{value:e,configurable:!0}),"c");const W=g((t,e)=>new Promise(r=>{t.question(e,s=>{r(s.trim())})}),"ask"),Re=g(async(t,e,r)=>{const s=await W(t,` ${e} ${l(r?"[Y/n]":"[y/N]")} `);return s===""?r:s.toLowerCase()==="y"||s.toLowerCase()==="yes"},"confirm"),Ee=g(async(t,e,r,s)=>{process.stderr.write(` ${e}
2
+ `);for(const[o,a]of r.entries()){const n=b(S(` ${String(o+1)}.`)),i=a===s?l(" (default)"):"";process.stderr.write(`${n} ${a}${i}
3
+ `)}for(;;){const o=await W(t,`
4
+ ${l(`Enter choice (1-${String(r.length)}):`)} `);if(o===""&&s!==void 0)return s;const a=Number.parseInt(o,10);if(Number.isInteger(a)&&a>=1&&a<=r.length)return r[a-1];const n=r.find(i=>i===o);if(n)return n;process.stderr.write(` ${l("Invalid choice. Try again.")}
5
+ `)}},"selectOne"),Ne=g(async(t,e,r,s)=>{process.stderr.write(` ${e} ${l("(comma-separated numbers)")}
6
+ `);for(const[o,a]of r.entries()){const n=b(S(` ${String(o+1)}.`)),i=s.includes(a)?l(" (default)"):"";process.stderr.write(`${n} ${a}${i}
7
+ `)}for(;;){const o=await W(t,`
8
+ ${l("Enter choices:")} `);if(o===""&&s.length>0)return s;const a=o.split(",").map(n=>Number.parseInt(n.trim(),10)).filter(n=>Number.isInteger(n)&&n>=1&&n<=r.length);if(a.length>0)return a.map(n=>r[n-1]);process.stderr.write(` ${l("Invalid choice. Try again.")}
9
+ `)}},"selectMany"),je=g(t=>` ${l(`${t}:`)} `,"promptText"),xe=g((t,e)=>e.prompt??t,"variableLabel"),_e=g(t=>Object.entries(t).sort(([e,r],[s,o])=>{const a=r.order??0,n=o.order??0;return a!==n?a-n:e.localeCompare(s)}),"sortVariables"),Y=g((t,e)=>{switch(t.type){case"array":return e.split(",").map(r=>r.trim()).filter(Boolean);case"boolean":return e==="true"||e==="1"||e==="yes"||e==="y";case"enum":return t.multiple?e.split(",").map(r=>r.trim()).filter(Boolean):e;case"number":{const r=Number(e);if(Number.isNaN(r))throw new TypeError(`Expected a number, got "${e}"`);return r}default:return e}},"parseValue"),F=g((t,e,r)=>{if(e.type==="enum"){const s=Array.isArray(r)?r:[r];for(const o of s)if(typeof o!="string"||!e.values.includes(o))throw new Error(`Variable "${t}" must be one of: ${e.values.join(", ")} (got "${String(o)}")`)}},"validateValue"),Pe=g(async t=>{const{defaults:e,interactive:r,overrides:s,variables:o}=t,a={},n=r?ue({input:process.stdin,output:process.stderr}):null;try{for(const[i,c]of _e(o)){if(Object.hasOwn(s,i)){const h=Y(c,s[i]??"");F(i,c,h),a[i]=h;continue}if(e||!r||c.internal){if(c.default!==void 0){F(i,c,c.default),a[i]=c.default;continue}if(c.required)throw new Error(`Required variable "${i}" not provided. Pass --${i}=<value> or remove --defaults.`);continue}const m=xe(i,c);let p;if(c.type==="boolean")p=await Re(n,m,!!(c.default??!1));else if(c.type==="enum")if(c.multiple){const h=Array.isArray(c.default)?c.default:[];p=await Ne(n,m,c.values,h)}else{const h=typeof c.default=="string"?c.default:void 0;p=await Ee(n,m,c.values,h)}else{const h=c.default===void 0?"":` (${String(c.default)})`,$=await W(n,je(`${m}${h}`));if($===""&&c.default!==void 0)p=c.default;else if($===""){if(c.required)throw new Error(`Variable "${i}" is required`);continue}else p=Y(c,$)}F(i,c,p),a[i]=p}return a}finally{n?.close()}},"collectOptions");var De=Object.defineProperty,L=v((t,e)=>De(t,"name",{value:e,configurable:!0}),"o");const Ie=["git://","npm://","https://","github:","gitlab:","bitbucket:","sourcehut:"],We=L(t=>Ie.some(e=>t.startsWith(e)),"isRemoteSource"),Be=L(async(t,e={})=>{const r=e.targetDirectory===void 0,s=e.targetDirectory??de(k(he(),"vis-generate-")),o=L(()=>{if(r)try{me(s,{force:!0,recursive:!0})}catch{}},"cleanup");f.info(`Downloading ${t}…`);try{const a=await ge(t,{auth:e.auth||process.env.GIGET_AUTH||process.env.GITHUB_TOKEN||process.env.GH_TOKEN||void 0,dir:s,force:!0,preferOffline:e.preferOffline});return{cleanup:o,directory:a.dir}}catch(a){o();const n=a instanceof Error?a.message:String(a);throw f.warn(`Failed to download template: ${n}`),a}},"fetchRemoteTemplate");var Ae=Object.defineProperty,T=v((t,e)=>Ae(t,"name",{value:e,configurable:!0}),"a");const ee=T((t,e="")=>{const r=[];for(const[s,o]of Object.entries(t)){const a=e?`${e}/${s}`:s;typeof o=="string"||Buffer.isBuffer(o)?r.push({content:o,path:a}):o&&typeof o=="object"&&r.push(...ee(o,a))}return r},"flattenTree"),Me=T(t=>t<1024?`${t} B`:t<1024*1024?`${(t/1024).toFixed(1)} KB`:`${(t/(1024*1024)).toFixed(1)} MB`,"formatSize"),qe=T((t,e)=>{if(C(e))throw new Error(`Refusing to write outside destination: template produced absolute path "${e}".`);const r=k(t,e),s=z(t,r);if(s===".."||s.startsWith(`..${ce}`)||C(s))throw new Error(`Refusing to write outside destination: "${e}" resolves to "${r}" which escapes "${t}".`);return r},"safeJoinDestination"),Fe=T((t,e)=>{Q(le(t)),pe(t,e)},"writeOne"),Ce=T((t,e,r=!1)=>{const s=typeof t=="string"?[t]:t.commands,o=typeof t=="string"?r:t.silent??r;for(const a of s){o||f.info(`$ ${a}`);const n=we(a,{cwd:e,shell:!0,stdio:o?"ignore":"inherit"});if(n.status!==0)return f.warn(`Script failed (exit ${String(n.status)}): ${a}`),!1}return!0},"runScript"),Le=T(t=>{const e=new Map;for(const r of t){const s=typeof r=="string"?0:r.phase??0,o=e.get(s);o?o.push(r):e.set(s,[r])}return[...e.entries()].sort(([r],[s])=>r-s)},"groupByPhase"),Ve=T(async(t,e)=>{const r={builtins:{dest_dir:e.destination,dest_rel_dir:z(e.workspaceRoot,e.destination)||".",working_dir:e.cwd,workspace_root:e.workspaceRoot},options:e.options},s=await t.produce(r),o=s.files?ee(s.files):[],a=s.filesMeta??{},n=[];for(const i of o){const c=qe(e.destination,i.path);n.push({file:i,meta:a[i.path]??{},target:c})}if(e.dryRun){f.info(`${b(S("Plan"))} ${l("(dry-run, no files written)")}`);for(const i of n){const c=Buffer.isBuffer(i.file.content)?i.file.content.length:Buffer.byteLength(i.file.content,"utf8");process.stderr.write(` ${l("write")} ${i.file.path} ${l(`(${Me(c)})`)}
10
+ `)}}else{Q(e.destination);let i=0,c=0;for(const m of n){const{file:p,meta:h,target:$}=m,B=D($),y=e.force||h.force===!0;if(B&&!y){f.warn(`Skipped existing file: ${p.path} (use --force or set frontmatter force: true to overwrite)`),c+=1;continue}Fe($,p.content),i+=1}f.success(`Wrote ${String(i)} file${i===1?"":"s"}${c>0?`, skipped ${String(c)}`:""}`)}if(!e.dryRun&&!e.skipScripts&&s.scripts&&s.scripts.length>0){const i=Le(s.scripts);f.info(`Running ${String(s.scripts.length)} script${s.scripts.length===1?"":"s"} across ${String(i.length)} phase${i.length===1?"":"s"}…`);for(const[,c]of i)if((await Promise.all(c.map(m=>Promise.resolve(Ce(m,e.destination))))).includes(!1))throw new Error("Script failed — aborting.")}if(s.suggestions&&s.suggestions.length>0){process.stderr.write(`
11
+ `),f.notice("Next steps:");for(const i of s.suggestions)process.stderr.write(` ${l("•")} ${i}
12
+ `)}},"runTemplate");var Ge=Object.defineProperty,R=v((t,e)=>Ge(t,"name",{value:e,configurable:!0}),"p");const He=R(t=>{if(t.length===0){f.info("No templates found."),f.notice("Create one at .vis/templates/<name>.ts (programmatic) or .vis/templates/<name>/ (moon-format with template.yml).");return}f.info("Available templates:");for(const e of t){const r=l(`(${e.source})`);process.stderr.write(` ${b(S(e.name))} ${r}
13
+ `)}},"printList"),Ke=R(t=>{const e={},r=[];for(const s of t){if(!s.startsWith("--")){r.push(s);continue}const o=s.indexOf("=");if(o===-1){const i=s.slice(2);i.startsWith("no-")?e[i.slice(3)]="false":e[i]="true";continue}const a=s.slice(2,o),n=s.slice(o+1);e[a]=n}return{overrides:e,remaining:r}},"parsePassthroughOverrides"),Ue=R(async t=>{const{createInterface:e}=await import("node:readline"),r=e({input:process.stdin,output:process.stderr});try{process.stderr.write(` ${b(S("vis generate"))} ${l("— pick a template")}
14
+
15
+ `);for(const[s,o]of t.entries()){const a=b(S(` ${String(s+1)}.`));process.stderr.write(`${a} ${o.name} ${l(`(${o.source})`)}
16
+ `)}return new Promise((s,o)=>{r.question(`
17
+ ${l(`Enter choice (1-${String(t.length)}):`)} `,a=>{const n=Number.parseInt(a.trim(),10);Number.isInteger(n)&&n>=1&&n<=t.length?s(t[n-1].name):o(new Error("Invalid choice."))})})}finally{r.close()}},"pickInteractive"),tt=R(async({argument:t,options:e,rawUnknown:r,visConfig:s,workspaceRoot:o})=>{const a=e.cwd||o||process.cwd(),n=o??a,i=s?.generator,c=Array.isArray(t)?t:t?[t]:[];if(e.list){const d=q({extraDirectories:i?.templates??[],onWarning:R(u=>{f.warn(u)},"onWarning"),workspaceRoot:n});He(d);return}let m=[...r??[]];if(m.length===0){const d=process.argv.slice(2),u=d.indexOf("--");u!==-1&&(m=d.slice(u+1))}const p=c.indexOf("--"),h=p===-1?[]:c.slice(p+1),$=p===-1?c:c.slice(0,p),{overrides:B}=Ke([...h,...m]);let y,x,_;const E=$[0];let P;if(E&&We(E)){const d=await Be(E,{auth:i?.auth,preferOffline:!!e.preferOffline||i?.preferOffline});P=d.cleanup;try{const u=q({extraDirectories:[d.directory],workspaceRoot:n}).find(N=>N.path.startsWith(d.directory));if(!u)throw new Error(`Downloaded template at ${d.directory} contains no template.yml or *.ts entrypoint.`);y=await u.load(),x=u.name,_=y.destination}catch(u){throw P(),P=void 0,u}}else{const d=q({extraDirectories:i?.templates??[],onWarning:R(A=>{f.warn(A)},"onWarning"),workspaceRoot:n});if(d.length===0)throw new Error("No templates found. Create one at .vis/templates/<name>.ts or .vis/templates/<name>/template.yml.");let u;if(E)u=E;else{if(e.noInteractive||!process.stdin.isTTY)throw new Error("No template specified. Pass a template name (see `vis generate --list`) or run interactively in a terminal.");u=await Ue(d)}const N=d.find(A=>A.name===u);if(!N)throw new Error(`Template "${u}" not found. Run 'vis generate --list' to see available templates.`);y=await N.load(),x=N.name,_=y.destination}const V=e.to,G=!!e.dryRun,te=!!e.force,H=!!e.defaults,re=!!e.skipScripts,se=!e.noInteractive&&!!process.stdin.isTTY&&!H;let O;V?O=V:_?O=_:O=".";const K=C(O)?O:fe(a,O);f.info(`Template: ${b(S(x))}`),f.info(`Target: ${l(K)}`),process.stderr.write(`
18
+ `);const oe=await Pe({defaults:H,interactive:se,overrides:B,variables:y.options??{}});try{await Ve(y,{cwd:a,destination:K,dryRun:G,force:te,options:oe,skipScripts:re,workspaceRoot:n}),G||(process.stderr.write(`
19
+ `),f.success(`Template '${x}' applied.`))}finally{P?.()}},"execute");export{tt as default};