node-version-use 2.1.5 → 2.1.7
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.
- package/assets/installBinaries.cjs +284 -0
- package/assets/postinstall.cjs +11 -404
- package/dist/cjs/assets/installBinaries.cjs +284 -0
- package/dist/cjs/assets/installBinaries.cjs.map +1 -0
- package/dist/cjs/assets/installBinaries.d.cts +1 -0
- package/dist/cjs/assets/postinstall.cjs +11 -404
- package/dist/cjs/assets/postinstall.cjs.map +1 -1
- package/dist/cjs/commands/default.js.map +1 -1
- package/dist/cjs/commands/index.js +2 -3
- package/dist/cjs/commands/index.js.map +1 -1
- package/dist/cjs/commands/list.js.map +1 -1
- package/dist/cjs/commands/setup.js +23 -41
- package/dist/cjs/commands/setup.js.map +1 -1
- package/dist/cjs/commands/teardown.js +2 -1
- package/dist/cjs/commands/teardown.js.map +1 -1
- package/dist/cjs/commands/uninstall.js.map +1 -1
- package/dist/cjs/commands/which.js.map +1 -1
- package/dist/cjs/compat.d.cts +1 -0
- package/dist/cjs/compat.d.ts +1 -0
- package/dist/cjs/compat.js +11 -4
- package/dist/cjs/compat.js.map +1 -1
- package/dist/cjs/lib/findInstalledVersions.js.map +1 -1
- package/dist/esm/assets/installBinaries.cjs +282 -0
- package/dist/esm/assets/installBinaries.cjs.map +1 -0
- package/dist/esm/assets/installBinaries.d.cts +1 -0
- package/dist/esm/assets/postinstall.cjs +11 -404
- package/dist/esm/assets/postinstall.cjs.map +1 -1
- package/dist/esm/commands/default.js +8 -8
- package/dist/esm/commands/default.js.map +1 -1
- package/dist/esm/commands/index.js +2 -3
- package/dist/esm/commands/index.js.map +1 -1
- package/dist/esm/commands/list.js +3 -3
- package/dist/esm/commands/list.js.map +1 -1
- package/dist/esm/commands/setup.js +39 -57
- package/dist/esm/commands/setup.js.map +1 -1
- package/dist/esm/commands/teardown.js +2 -1
- package/dist/esm/commands/teardown.js.map +1 -1
- package/dist/esm/commands/uninstall.js +12 -12
- package/dist/esm/commands/uninstall.js.map +1 -1
- package/dist/esm/commands/which.js +5 -5
- package/dist/esm/commands/which.js.map +1 -1
- package/dist/esm/compat.d.ts +1 -0
- package/dist/esm/compat.js +17 -13
- package/dist/esm/compat.js.map +1 -1
- package/dist/esm/lib/findInstalledVersions.js +19 -19
- package/dist/esm/lib/findInstalledVersions.js.map +1 -1
- package/package.json +24 -19
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/index.ts"],"sourcesContent":["import defaultCmd from './default.ts';\nimport installCmd from './install.ts';\nimport listCmd from './list.ts';\nimport localCmd from './local.ts';\nimport setupCmd from './setup.ts';\nimport teardownCmd from './teardown.ts';\nimport uninstallCmd from './uninstall.ts';\nimport whichCmd from './which.ts';\n\nexport const commands: Record<string, (args: string[]) => void> = {\n default: defaultCmd,\n local: localCmd,\n list: listCmd,\n which: whichCmd,\n install: installCmd,\n uninstall: uninstallCmd,\n setup: setupCmd,\n teardown: teardownCmd,\n};\n\nexport function isCommand(name: string): boolean {\n return name in commands;\n}\n\nexport function runCommand(name: string, args: string[]): void {\n const cmd = commands[name];\n if (cmd)
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/index.ts"],"sourcesContent":["import defaultCmd from './default.ts';\nimport installCmd from './install.ts';\nimport listCmd from './list.ts';\nimport localCmd from './local.ts';\nimport setupCmd from './setup.ts';\nimport teardownCmd from './teardown.ts';\nimport uninstallCmd from './uninstall.ts';\nimport whichCmd from './which.ts';\n\nexport const commands: Record<string, (args: string[]) => void> = {\n default: defaultCmd,\n local: localCmd,\n list: listCmd,\n which: whichCmd,\n install: installCmd,\n uninstall: uninstallCmd,\n setup: setupCmd,\n teardown: teardownCmd,\n};\n\nexport function isCommand(name: string): boolean {\n return name in commands;\n}\n\nexport function runCommand(name: string, args: string[]): void {\n const cmd = commands[name];\n if (cmd) cmd(args);\n else console.error(`Unknown command: ${name}`);\n}\n"],"names":["defaultCmd","installCmd","listCmd","localCmd","setupCmd","teardownCmd","uninstallCmd","whichCmd","commands","default","local","list","which","install","uninstall","setup","teardown","isCommand","name","runCommand","args","cmd","console","error"],"mappings":"AAAA,OAAOA,gBAAgB,eAAe;AACtC,OAAOC,gBAAgB,eAAe;AACtC,OAAOC,aAAa,YAAY;AAChC,OAAOC,cAAc,aAAa;AAClC,OAAOC,cAAc,aAAa;AAClC,OAAOC,iBAAiB,gBAAgB;AACxC,OAAOC,kBAAkB,iBAAiB;AAC1C,OAAOC,cAAc,aAAa;AAElC,OAAO,MAAMC,WAAqD;IAChEC,SAAST;IACTU,OAAOP;IACPQ,MAAMT;IACNU,OAAOL;IACPM,SAASZ;IACTa,WAAWR;IACXS,OAAOX;IACPY,UAAUX;AACZ,EAAE;AAEF,OAAO,SAASY,UAAUC,IAAY;IACpC,OAAOA,QAAQV;AACjB;AAEA,OAAO,SAASW,WAAWD,IAAY,EAAEE,IAAc;IACrD,MAAMC,MAAMb,QAAQ,CAACU,KAAK;IAC1B,IAAIG,KAAKA,IAAID;SACRE,QAAQC,KAAK,CAAC,CAAC,iBAAiB,EAAEL,MAAM;AAC/C"}
|
|
@@ -8,7 +8,7 @@ import { storagePath } from '../constants.js';
|
|
|
8
8
|
*
|
|
9
9
|
* List all installed Node versions.
|
|
10
10
|
*/ export default function listCmd(_args) {
|
|
11
|
-
|
|
11
|
+
const versionsPath = path.join(storagePath, 'installed');
|
|
12
12
|
// Check if versions directory exists
|
|
13
13
|
if (!fs.existsSync(versionsPath)) {
|
|
14
14
|
console.log('No Node versions installed.');
|
|
@@ -17,8 +17,8 @@ import { storagePath } from '../constants.js';
|
|
|
17
17
|
return;
|
|
18
18
|
}
|
|
19
19
|
// Read all directories in versions folder
|
|
20
|
-
|
|
21
|
-
|
|
20
|
+
const entries = readdirWithTypes(versionsPath);
|
|
21
|
+
const versions = entries.filter((entry)=>entry.isDirectory()).map((entry)=>entry.name);
|
|
22
22
|
if (versions.length === 0) {
|
|
23
23
|
console.log('No Node versions installed.');
|
|
24
24
|
console.log('Install a version: nvu install <version>');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/list.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport path from 'path';\nimport { readdirWithTypes } from '../compat.ts';\nimport { storagePath } from '../constants.ts';\n\n/**\n * nvu list\n *\n * List all installed Node versions.\n */\nexport default function listCmd(_args: string[]): void {\n
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/list.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport path from 'path';\nimport { readdirWithTypes } from '../compat.ts';\nimport { storagePath } from '../constants.ts';\n\n/**\n * nvu list\n *\n * List all installed Node versions.\n */\nexport default function listCmd(_args: string[]): void {\n const versionsPath = path.join(storagePath, 'installed');\n\n // Check if versions directory exists\n if (!fs.existsSync(versionsPath)) {\n console.log('No Node versions installed.');\n console.log('Install a version: nvu install <version>');\n exit(0);\n return;\n }\n\n // Read all directories in versions folder\n const entries = readdirWithTypes(versionsPath);\n const versions = entries.filter((entry) => entry.isDirectory()).map((entry) => entry.name);\n\n if (versions.length === 0) {\n console.log('No Node versions installed.');\n console.log('Install a version: nvu install <version>');\n exit(0);\n return;\n }\n\n // Get the current default\n const defaultFilePath = path.join(storagePath, 'default');\n let defaultVersion = '';\n if (fs.existsSync(defaultFilePath)) {\n defaultVersion = fs.readFileSync(defaultFilePath, 'utf8').trim();\n }\n\n // Sort versions (simple string sort, could be improved with semver)\n versions.sort((a, b) => {\n const aParts = a.split('.').map((n) => parseInt(n, 10) || 0);\n const bParts = b.split('.').map((n) => parseInt(n, 10) || 0);\n for (let i = 0; i < Math.max(aParts.length, bParts.length); i++) {\n const aVal = aParts[i] || 0;\n const bVal = bParts[i] || 0;\n if (aVal !== bVal) return bVal - aVal; // Descending order\n }\n return 0;\n });\n\n console.log('Installed Node versions:');\n for (let i = 0; i < versions.length; i++) {\n const version = versions[i];\n const isDefault = version === defaultVersion || `v${version}` === defaultVersion || version === `v${defaultVersion}`;\n const marker = isDefault ? ' (default)' : '';\n console.log(` ${version}${marker}`);\n }\n exit(0);\n}\n"],"names":["exit","fs","path","readdirWithTypes","storagePath","listCmd","_args","versionsPath","join","existsSync","console","log","entries","versions","filter","entry","isDirectory","map","name","length","defaultFilePath","defaultVersion","readFileSync","trim","sort","a","b","aParts","split","n","parseInt","bParts","i","Math","max","aVal","bVal","version","isDefault","marker"],"mappings":"AAAA,OAAOA,UAAU,cAAc;AAC/B,OAAOC,QAAQ,KAAK;AACpB,OAAOC,UAAU,OAAO;AACxB,SAASC,gBAAgB,QAAQ,eAAe;AAChD,SAASC,WAAW,QAAQ,kBAAkB;AAE9C;;;;CAIC,GACD,eAAe,SAASC,QAAQC,KAAe;IAC7C,MAAMC,eAAeL,KAAKM,IAAI,CAACJ,aAAa;IAE5C,qCAAqC;IACrC,IAAI,CAACH,GAAGQ,UAAU,CAACF,eAAe;QAChCG,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;QACZX,KAAK;QACL;IACF;IAEA,0CAA0C;IAC1C,MAAMY,UAAUT,iBAAiBI;IACjC,MAAMM,WAAWD,QAAQE,MAAM,CAAC,CAACC,QAAUA,MAAMC,WAAW,IAAIC,GAAG,CAAC,CAACF,QAAUA,MAAMG,IAAI;IAEzF,IAAIL,SAASM,MAAM,KAAK,GAAG;QACzBT,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;QACZX,KAAK;QACL;IACF;IAEA,0BAA0B;IAC1B,MAAMoB,kBAAkBlB,KAAKM,IAAI,CAACJ,aAAa;IAC/C,IAAIiB,iBAAiB;IACrB,IAAIpB,GAAGQ,UAAU,CAACW,kBAAkB;QAClCC,iBAAiBpB,GAAGqB,YAAY,CAACF,iBAAiB,QAAQG,IAAI;IAChE;IAEA,oEAAoE;IACpEV,SAASW,IAAI,CAAC,CAACC,GAAGC;QAChB,MAAMC,SAASF,EAAEG,KAAK,CAAC,KAAKX,GAAG,CAAC,CAACY,IAAMC,SAASD,GAAG,OAAO;QAC1D,MAAME,SAASL,EAAEE,KAAK,CAAC,KAAKX,GAAG,CAAC,CAACY,IAAMC,SAASD,GAAG,OAAO;QAC1D,IAAK,IAAIG,IAAI,GAAGA,IAAIC,KAAKC,GAAG,CAACP,OAAOR,MAAM,EAAEY,OAAOZ,MAAM,GAAGa,IAAK;YAC/D,MAAMG,OAAOR,MAAM,CAACK,EAAE,IAAI;YAC1B,MAAMI,OAAOL,MAAM,CAACC,EAAE,IAAI;YAC1B,IAAIG,SAASC,MAAM,OAAOA,OAAOD,MAAM,mBAAmB;QAC5D;QACA,OAAO;IACT;IAEAzB,QAAQC,GAAG,CAAC;IACZ,IAAK,IAAIqB,IAAI,GAAGA,IAAInB,SAASM,MAAM,EAAEa,IAAK;QACxC,MAAMK,UAAUxB,QAAQ,CAACmB,EAAE;QAC3B,MAAMM,YAAYD,YAAYhB,kBAAkB,CAAC,CAAC,EAAEgB,SAAS,KAAKhB,kBAAkBgB,YAAY,CAAC,CAAC,EAAEhB,gBAAgB;QACpH,MAAMkB,SAASD,YAAY,eAAe;QAC1C5B,QAAQC,GAAG,CAAC,CAAC,EAAE,EAAE0B,UAAUE,QAAQ;IACrC;IACAvC,KAAK;AACP"}
|
|
@@ -1,101 +1,83 @@
|
|
|
1
|
-
import { execSync } from 'child_process';
|
|
2
1
|
import exit from 'exit-compat';
|
|
3
2
|
import fs from 'fs';
|
|
3
|
+
import getopts from 'getopts-compat';
|
|
4
|
+
import Module from 'module';
|
|
4
5
|
import path from 'path';
|
|
5
|
-
import
|
|
6
|
-
import { mkdirpSync, readdirWithTypes } from '../compat.js';
|
|
6
|
+
import { readdirWithTypes } from '../compat.js';
|
|
7
7
|
import { storagePath } from '../constants.js';
|
|
8
8
|
import { findInstalledVersions } from '../lib/findInstalledVersions.js';
|
|
9
|
-
|
|
9
|
+
const _require = typeof require === 'undefined' ? Module.createRequire(import.meta.url) : require;
|
|
10
|
+
const { installBinaries, printInstructions } = _require('../assets/installBinaries.cjs');
|
|
10
11
|
/**
|
|
11
12
|
* nvu setup [--shims]
|
|
12
13
|
*
|
|
13
14
|
* Install/reinstall nvu binaries to ~/.nvu/bin
|
|
14
15
|
* With --shims: create shims for existing global packages
|
|
15
16
|
*/ export default function setupCmd(args) {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
for(var i = 0; i < args.length; i++){
|
|
27
|
-
if (args[i] === '--shims') {
|
|
28
|
-
hasShimsFlag = true;
|
|
29
|
-
break;
|
|
17
|
+
const options = getopts(args, {
|
|
18
|
+
boolean: [
|
|
19
|
+
'force'
|
|
20
|
+
]
|
|
21
|
+
});
|
|
22
|
+
installBinaries(options, (err, installed)=>{
|
|
23
|
+
if (err) {
|
|
24
|
+
console.error(`Setup failed: ${err.message || err}`);
|
|
25
|
+
exit(1);
|
|
26
|
+
return;
|
|
30
27
|
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
var postinstallPath = path.join(__dirname, '..', '..', '..', 'scripts', 'postinstall.cjs');
|
|
38
|
-
if (fs.existsSync(postinstallPath)) {
|
|
39
|
-
// Run the postinstall script
|
|
40
|
-
try {
|
|
41
|
-
execSync(`node "${postinstallPath}"`, {
|
|
42
|
-
stdio: 'inherit'
|
|
43
|
-
});
|
|
44
|
-
} catch (_err) {
|
|
45
|
-
// postinstall handles its own errors gracefully
|
|
28
|
+
printInstructions();
|
|
29
|
+
if (!installed) console.log('Use --force to reinstall.');
|
|
30
|
+
if (options.force) {
|
|
31
|
+
const binDir = path.join(storagePath, 'bin');
|
|
32
|
+
createShimsForGlobalPackages(binDir);
|
|
33
|
+
return;
|
|
46
34
|
}
|
|
47
|
-
}
|
|
48
|
-
console.log('Setup script not found.');
|
|
49
|
-
console.log('Try reinstalling: npm install -g node-version-use');
|
|
50
|
-
exit(1);
|
|
51
|
-
}
|
|
35
|
+
});
|
|
52
36
|
}
|
|
53
37
|
/**
|
|
54
38
|
* Create shims for all global packages in the default Node version
|
|
55
39
|
*/ function createShimsForGlobalPackages(binDir) {
|
|
56
40
|
// Read default version
|
|
57
|
-
|
|
41
|
+
const defaultPath = path.join(storagePath, 'default');
|
|
58
42
|
if (!fs.existsSync(defaultPath)) {
|
|
59
43
|
console.log('No default Node version set.');
|
|
60
44
|
console.log('Set one with: nvu default <version>');
|
|
61
45
|
exit(1);
|
|
62
46
|
return;
|
|
63
47
|
}
|
|
64
|
-
|
|
65
|
-
|
|
48
|
+
const defaultVersion = fs.readFileSync(defaultPath, 'utf8').trim();
|
|
49
|
+
const versionsDir = path.join(storagePath, 'installed');
|
|
66
50
|
// Resolve to exact version
|
|
67
|
-
|
|
51
|
+
const matches = findInstalledVersions(versionsDir, defaultVersion);
|
|
68
52
|
if (matches.length === 0) {
|
|
69
53
|
console.log(`Default version ${defaultVersion} is not installed.`);
|
|
70
54
|
exit(1);
|
|
71
55
|
return;
|
|
72
56
|
}
|
|
73
|
-
|
|
74
|
-
|
|
57
|
+
const resolvedVersion = matches[matches.length - 1];
|
|
58
|
+
const nodeBinDir = path.join(versionsDir, resolvedVersion, 'bin');
|
|
75
59
|
if (!fs.existsSync(nodeBinDir)) {
|
|
76
60
|
console.log(`No bin directory found for ${resolvedVersion}`);
|
|
77
61
|
exit(1);
|
|
78
62
|
return;
|
|
79
63
|
}
|
|
80
64
|
// Get the node shim to copy from
|
|
81
|
-
|
|
65
|
+
const nodeShim = path.join(binDir, 'node');
|
|
82
66
|
if (!fs.existsSync(nodeShim)) {
|
|
83
67
|
console.log('Node shim not found. Run: nvu setup');
|
|
84
68
|
exit(1);
|
|
85
69
|
return;
|
|
86
70
|
}
|
|
87
71
|
// Scan binaries in Node's bin directory
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
for(
|
|
92
|
-
|
|
93
|
-
|
|
72
|
+
const entries = readdirWithTypes(nodeBinDir);
|
|
73
|
+
let created = 0;
|
|
74
|
+
let skipped = 0;
|
|
75
|
+
for(let i = 0; i < entries.length; i++){
|
|
76
|
+
const entry = entries[i];
|
|
77
|
+
const name = entry.name;
|
|
94
78
|
// Skip our routing shims (node/npm/npx) - don't overwrite them
|
|
95
|
-
if (name === 'node' || name === 'npm' || name === 'npx')
|
|
96
|
-
|
|
97
|
-
}
|
|
98
|
-
var shimPath = path.join(binDir, name);
|
|
79
|
+
if (name === 'node' || name === 'npm' || name === 'npx') continue;
|
|
80
|
+
const shimPath = path.join(binDir, name);
|
|
99
81
|
// Skip if shim already exists
|
|
100
82
|
if (fs.existsSync(shimPath)) {
|
|
101
83
|
skipped++;
|
|
@@ -103,7 +85,7 @@ var __dirname = path.dirname(typeof __filename !== 'undefined' ? __filename : ur
|
|
|
103
85
|
}
|
|
104
86
|
// Copy the node shim
|
|
105
87
|
try {
|
|
106
|
-
|
|
88
|
+
const shimContent = fs.readFileSync(nodeShim);
|
|
107
89
|
fs.writeFileSync(shimPath, shimContent);
|
|
108
90
|
fs.chmodSync(shimPath, 493); // 0755
|
|
109
91
|
console.log(`Created shim: ${name}`);
|
|
@@ -113,6 +95,6 @@ var __dirname = path.dirname(typeof __filename !== 'undefined' ? __filename : ur
|
|
|
113
95
|
}
|
|
114
96
|
}
|
|
115
97
|
console.log('');
|
|
116
|
-
console.log(`Done. Created ${created} shims, skipped ${skipped} (already
|
|
98
|
+
console.log(`Done. Created ${created} shims, skipped ${skipped} (already exists).`);
|
|
117
99
|
exit(0);
|
|
118
100
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/setup.ts"],"sourcesContent":["import
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/setup.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport getopts from 'getopts-compat';\nimport Module from 'module';\nimport path from 'path';\nimport { readdirWithTypes } from '../compat.ts';\nimport { storagePath } from '../constants.ts';\nimport { findInstalledVersions } from '../lib/findInstalledVersions.ts';\n\nconst _require = typeof require === 'undefined' ? Module.createRequire(import.meta.url) : require;\nconst { installBinaries, printInstructions } = _require('../assets/installBinaries.cjs');\n\n/**\n * nvu setup [--shims]\n *\n * Install/reinstall nvu binaries to ~/.nvu/bin\n * With --shims: create shims for existing global packages\n */\nexport default function setupCmd(args: string[]): void {\n const options = getopts(args, { boolean: ['force'] });\n\n installBinaries(options, (err, installed) => {\n if (err) {\n console.error(`Setup failed: ${err.message || err}`);\n exit(1);\n return;\n }\n\n printInstructions();\n if (!installed) console.log('Use --force to reinstall.');\n\n if (options.force) {\n const binDir = path.join(storagePath, 'bin');\n createShimsForGlobalPackages(binDir);\n return;\n }\n });\n}\n\n/**\n * Create shims for all global packages in the default Node version\n */\nfunction createShimsForGlobalPackages(binDir: string): void {\n // Read default version\n const defaultPath = path.join(storagePath, 'default');\n if (!fs.existsSync(defaultPath)) {\n console.log('No default Node version set.');\n console.log('Set one with: nvu default <version>');\n exit(1);\n return;\n }\n\n const defaultVersion = fs.readFileSync(defaultPath, 'utf8').trim();\n const versionsDir = path.join(storagePath, 'installed');\n\n // Resolve to exact version\n const matches = findInstalledVersions(versionsDir, defaultVersion);\n if (matches.length === 0) {\n console.log(`Default version ${defaultVersion} is not installed.`);\n exit(1);\n return;\n }\n\n const resolvedVersion = matches[matches.length - 1];\n const nodeBinDir = path.join(versionsDir, resolvedVersion, 'bin');\n\n if (!fs.existsSync(nodeBinDir)) {\n console.log(`No bin directory found for ${resolvedVersion}`);\n exit(1);\n return;\n }\n\n // Get the node shim to copy from\n const nodeShim = path.join(binDir, 'node');\n if (!fs.existsSync(nodeShim)) {\n console.log('Node shim not found. Run: nvu setup');\n exit(1);\n return;\n }\n\n // Scan binaries in Node's bin directory\n const entries = readdirWithTypes(nodeBinDir);\n let created = 0;\n let skipped = 0;\n\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i];\n const name = entry.name;\n\n // Skip our routing shims (node/npm/npx) - don't overwrite them\n if (name === 'node' || name === 'npm' || name === 'npx') continue;\n const shimPath = path.join(binDir, name);\n\n // Skip if shim already exists\n if (fs.existsSync(shimPath)) {\n skipped++;\n continue;\n }\n\n // Copy the node shim\n try {\n const shimContent = fs.readFileSync(nodeShim);\n fs.writeFileSync(shimPath, shimContent);\n fs.chmodSync(shimPath, 493); // 0755\n console.log(`Created shim: ${name}`);\n created++;\n } catch (err) {\n console.error(`Failed to create shim for ${name}: ${(err as Error).message}`);\n }\n }\n\n console.log('');\n console.log(`Done. Created ${created} shims, skipped ${skipped} (already exists).`);\n exit(0);\n}\n"],"names":["exit","fs","getopts","Module","path","readdirWithTypes","storagePath","findInstalledVersions","_require","require","createRequire","url","installBinaries","printInstructions","setupCmd","args","options","boolean","err","installed","console","error","message","log","force","binDir","join","createShimsForGlobalPackages","defaultPath","existsSync","defaultVersion","readFileSync","trim","versionsDir","matches","length","resolvedVersion","nodeBinDir","nodeShim","entries","created","skipped","i","entry","name","shimPath","shimContent","writeFileSync","chmodSync"],"mappings":"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"}
|
|
@@ -3,6 +3,7 @@ import fs from 'fs';
|
|
|
3
3
|
import { rmSync } from 'fs-remove-compat';
|
|
4
4
|
import path from 'path';
|
|
5
5
|
import { storagePath } from '../constants.js';
|
|
6
|
+
const isWindows = process.platform === 'win32' || /^(msys|cygwin)$/.test(process.env.OSTYPE);
|
|
6
7
|
/**
|
|
7
8
|
* nvu teardown
|
|
8
9
|
*
|
|
@@ -14,7 +15,7 @@ import { storagePath } from '../constants.js';
|
|
|
14
15
|
'npm',
|
|
15
16
|
'npx'
|
|
16
17
|
];
|
|
17
|
-
const ext =
|
|
18
|
+
const ext = isWindows ? '.exe' : '';
|
|
18
19
|
let removed = 0;
|
|
19
20
|
for(let i = 0; i < binaries.length; i++){
|
|
20
21
|
const binaryPath = path.join(binDir, binaries[i] + ext);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/teardown.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport { rmSync } from 'fs-remove-compat';\nimport path from 'path';\nimport { storagePath } from '../constants.ts';\n\n/**\n * nvu teardown\n *\n * Remove nvu binaries from ~/.nvu/bin\n */\nexport default function teardownCmd(_args: string[]): void {\n const binDir = path.join(storagePath, 'bin');\n\n const binaries = ['node', 'npm', 'npx'];\n const ext =
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/teardown.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport { rmSync } from 'fs-remove-compat';\nimport path from 'path';\nimport { storagePath } from '../constants.ts';\n\nconst isWindows = process.platform === 'win32' || /^(msys|cygwin)$/.test(process.env.OSTYPE);\n\n/**\n * nvu teardown\n *\n * Remove nvu binaries from ~/.nvu/bin\n */\nexport default function teardownCmd(_args: string[]): void {\n const binDir = path.join(storagePath, 'bin');\n\n const binaries = ['node', 'npm', 'npx'];\n const ext = isWindows ? '.exe' : '';\n\n let removed = 0;\n for (let i = 0; i < binaries.length; i++) {\n const binaryPath = path.join(binDir, binaries[i] + ext);\n if (fs.existsSync(binaryPath)) {\n rmSync(binaryPath, { force: true });\n removed++;\n }\n }\n\n if (removed > 0) {\n console.log(`Removed ${removed} binary(s) from ${binDir}`);\n console.log('');\n console.log('You may also want to remove ~/.nvu/bin from your PATH.');\n } else {\n console.log('No binaries found to remove.');\n }\n\n exit(0);\n}\n"],"names":["exit","fs","rmSync","path","storagePath","isWindows","process","platform","test","env","OSTYPE","teardownCmd","_args","binDir","join","binaries","ext","removed","i","length","binaryPath","existsSync","force","console","log"],"mappings":"AAAA,OAAOA,UAAU,cAAc;AAC/B,OAAOC,QAAQ,KAAK;AACpB,SAASC,MAAM,QAAQ,mBAAmB;AAC1C,OAAOC,UAAU,OAAO;AACxB,SAASC,WAAW,QAAQ,kBAAkB;AAE9C,MAAMC,YAAYC,QAAQC,QAAQ,KAAK,WAAW,kBAAkBC,IAAI,CAACF,QAAQG,GAAG,CAACC,MAAM;AAE3F;;;;CAIC,GACD,eAAe,SAASC,YAAYC,KAAe;IACjD,MAAMC,SAASV,KAAKW,IAAI,CAACV,aAAa;IAEtC,MAAMW,WAAW;QAAC;QAAQ;QAAO;KAAM;IACvC,MAAMC,MAAMX,YAAY,SAAS;IAEjC,IAAIY,UAAU;IACd,IAAK,IAAIC,IAAI,GAAGA,IAAIH,SAASI,MAAM,EAAED,IAAK;QACxC,MAAME,aAAajB,KAAKW,IAAI,CAACD,QAAQE,QAAQ,CAACG,EAAE,GAAGF;QACnD,IAAIf,GAAGoB,UAAU,CAACD,aAAa;YAC7BlB,OAAOkB,YAAY;gBAAEE,OAAO;YAAK;YACjCL;QACF;IACF;IAEA,IAAIA,UAAU,GAAG;QACfM,QAAQC,GAAG,CAAC,CAAC,QAAQ,EAAEP,QAAQ,gBAAgB,EAAEJ,QAAQ;QACzDU,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;IACd,OAAO;QACLD,QAAQC,GAAG,CAAC;IACd;IAEAxB,KAAK;AACP"}
|
|
@@ -16,10 +16,10 @@ import { findInstalledVersions, getAllInstalledVersions } from '../lib/findInsta
|
|
|
16
16
|
exit(1);
|
|
17
17
|
return;
|
|
18
18
|
}
|
|
19
|
-
|
|
20
|
-
|
|
19
|
+
const version = args[0].trim();
|
|
20
|
+
const versionsPath = path.join(storagePath, 'installed');
|
|
21
21
|
// Find all matching installed versions
|
|
22
|
-
|
|
22
|
+
const matches = findInstalledVersions(versionsPath, version);
|
|
23
23
|
if (matches.length === 0) {
|
|
24
24
|
console.log(`Node ${version} is not installed.`);
|
|
25
25
|
console.log('');
|
|
@@ -30,7 +30,7 @@ import { findInstalledVersions, getAllInstalledVersions } from '../lib/findInsta
|
|
|
30
30
|
}
|
|
31
31
|
if (matches.length > 1) {
|
|
32
32
|
console.log(`Multiple versions match "${version}":`);
|
|
33
|
-
for(
|
|
33
|
+
for(let i = 0; i < matches.length; i++){
|
|
34
34
|
console.log(` ${matches[i]}`);
|
|
35
35
|
}
|
|
36
36
|
console.log('');
|
|
@@ -38,15 +38,15 @@ import { findInstalledVersions, getAllInstalledVersions } from '../lib/findInsta
|
|
|
38
38
|
exit(1);
|
|
39
39
|
return;
|
|
40
40
|
}
|
|
41
|
-
|
|
42
|
-
|
|
41
|
+
const installedVersion = matches[0];
|
|
42
|
+
const versionPath = path.join(versionsPath, installedVersion);
|
|
43
43
|
// Check if this is the current default (exact match since we store exact versions)
|
|
44
|
-
|
|
44
|
+
const defaultPath = path.join(storagePath, 'default');
|
|
45
45
|
if (fs.existsSync(defaultPath)) {
|
|
46
|
-
|
|
46
|
+
const defaultVersion = fs.readFileSync(defaultPath, 'utf8').trim();
|
|
47
47
|
// Normalize both for comparison
|
|
48
|
-
|
|
49
|
-
|
|
48
|
+
const normalizedDefault = defaultVersion.replace(/^v/, '');
|
|
49
|
+
const normalizedInstalled = installedVersion.replace(/^v/, '');
|
|
50
50
|
if (normalizedInstalled === normalizedDefault) {
|
|
51
51
|
console.error(`Cannot uninstall default version ${installedVersion}.`);
|
|
52
52
|
console.error('');
|
|
@@ -70,11 +70,11 @@ import { findInstalledVersions, getAllInstalledVersions } from '../lib/findInsta
|
|
|
70
70
|
/**
|
|
71
71
|
* List installed versions for user reference
|
|
72
72
|
*/ function listInstalledVersions(versionsPath) {
|
|
73
|
-
|
|
73
|
+
const versions = getAllInstalledVersions(versionsPath);
|
|
74
74
|
if (versions.length === 0) {
|
|
75
75
|
console.log(' (none)');
|
|
76
76
|
} else {
|
|
77
|
-
for(
|
|
77
|
+
for(let i = 0; i < versions.length; i++){
|
|
78
78
|
console.log(` ${versions[i]}`);
|
|
79
79
|
}
|
|
80
80
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/uninstall.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport path from 'path';\nimport { rmSync } from '../compat.ts';\nimport { storagePath } from '../constants.ts';\nimport { findInstalledVersions, getAllInstalledVersions } from '../lib/findInstalledVersions.ts';\n\n/**\n * nvu uninstall <version>\n *\n * Remove an installed Node version.\n */\nexport default function uninstallCmd(args: string[]): void {\n if (args.length === 0) {\n console.log('Usage: nvu uninstall <version>');\n console.log('Example: nvu uninstall 20');\n console.log(' nvu uninstall v20.19.6');\n exit(1);\n return;\n }\n\n
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/uninstall.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport path from 'path';\nimport { rmSync } from '../compat.ts';\nimport { storagePath } from '../constants.ts';\nimport { findInstalledVersions, getAllInstalledVersions } from '../lib/findInstalledVersions.ts';\n\n/**\n * nvu uninstall <version>\n *\n * Remove an installed Node version.\n */\nexport default function uninstallCmd(args: string[]): void {\n if (args.length === 0) {\n console.log('Usage: nvu uninstall <version>');\n console.log('Example: nvu uninstall 20');\n console.log(' nvu uninstall v20.19.6');\n exit(1);\n return;\n }\n\n const version = args[0].trim();\n const versionsPath = path.join(storagePath, 'installed');\n\n // Find all matching installed versions\n const matches = findInstalledVersions(versionsPath, version);\n\n if (matches.length === 0) {\n console.log(`Node ${version} is not installed.`);\n console.log('');\n console.log('Installed versions:');\n listInstalledVersions(versionsPath);\n exit(1);\n return;\n }\n\n if (matches.length > 1) {\n console.log(`Multiple versions match \"${version}\":`);\n for (let i = 0; i < matches.length; i++) {\n console.log(` ${matches[i]}`);\n }\n console.log('');\n console.log('Please specify the exact version to uninstall.');\n exit(1);\n return;\n }\n\n const installedVersion = matches[0];\n const versionPath = path.join(versionsPath, installedVersion);\n\n // Check if this is the current default (exact match since we store exact versions)\n const defaultPath = path.join(storagePath, 'default');\n if (fs.existsSync(defaultPath)) {\n const defaultVersion = fs.readFileSync(defaultPath, 'utf8').trim();\n\n // Normalize both for comparison\n const normalizedDefault = defaultVersion.replace(/^v/, '');\n const normalizedInstalled = installedVersion.replace(/^v/, '');\n\n if (normalizedInstalled === normalizedDefault) {\n console.error(`Cannot uninstall default version ${installedVersion}.`);\n console.error('');\n console.error('Change your default first:');\n console.error(' nvu default <version>');\n exit(1);\n return;\n }\n }\n\n // Remove the version directory\n try {\n rmSync(versionPath);\n console.log(`Removed Node ${installedVersion}`);\n } catch (err) {\n console.error(`Failed to remove Node ${installedVersion}:`, (err as Error).message);\n exit(1);\n return;\n }\n\n exit(0);\n}\n\n/**\n * List installed versions for user reference\n */\nfunction listInstalledVersions(versionsPath: string): void {\n const versions = getAllInstalledVersions(versionsPath);\n\n if (versions.length === 0) {\n console.log(' (none)');\n } else {\n for (let i = 0; i < versions.length; i++) {\n console.log(` ${versions[i]}`);\n }\n }\n}\n"],"names":["exit","fs","path","rmSync","storagePath","findInstalledVersions","getAllInstalledVersions","uninstallCmd","args","length","console","log","version","trim","versionsPath","join","matches","listInstalledVersions","i","installedVersion","versionPath","defaultPath","existsSync","defaultVersion","readFileSync","normalizedDefault","replace","normalizedInstalled","error","err","message","versions"],"mappings":"AAAA,OAAOA,UAAU,cAAc;AAC/B,OAAOC,QAAQ,KAAK;AACpB,OAAOC,UAAU,OAAO;AACxB,SAASC,MAAM,QAAQ,eAAe;AACtC,SAASC,WAAW,QAAQ,kBAAkB;AAC9C,SAASC,qBAAqB,EAAEC,uBAAuB,QAAQ,kCAAkC;AAEjG;;;;CAIC,GACD,eAAe,SAASC,aAAaC,IAAc;IACjD,IAAIA,KAAKC,MAAM,KAAK,GAAG;QACrBC,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;QACZX,KAAK;QACL;IACF;IAEA,MAAMY,UAAUJ,IAAI,CAAC,EAAE,CAACK,IAAI;IAC5B,MAAMC,eAAeZ,KAAKa,IAAI,CAACX,aAAa;IAE5C,uCAAuC;IACvC,MAAMY,UAAUX,sBAAsBS,cAAcF;IAEpD,IAAII,QAAQP,MAAM,KAAK,GAAG;QACxBC,QAAQC,GAAG,CAAC,CAAC,KAAK,EAAEC,QAAQ,kBAAkB,CAAC;QAC/CF,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;QACZM,sBAAsBH;QACtBd,KAAK;QACL;IACF;IAEA,IAAIgB,QAAQP,MAAM,GAAG,GAAG;QACtBC,QAAQC,GAAG,CAAC,CAAC,yBAAyB,EAAEC,QAAQ,EAAE,CAAC;QACnD,IAAK,IAAIM,IAAI,GAAGA,IAAIF,QAAQP,MAAM,EAAES,IAAK;YACvCR,QAAQC,GAAG,CAAC,CAAC,EAAE,EAAEK,OAAO,CAACE,EAAE,EAAE;QAC/B;QACAR,QAAQC,GAAG,CAAC;QACZD,QAAQC,GAAG,CAAC;QACZX,KAAK;QACL;IACF;IAEA,MAAMmB,mBAAmBH,OAAO,CAAC,EAAE;IACnC,MAAMI,cAAclB,KAAKa,IAAI,CAACD,cAAcK;IAE5C,mFAAmF;IACnF,MAAME,cAAcnB,KAAKa,IAAI,CAACX,aAAa;IAC3C,IAAIH,GAAGqB,UAAU,CAACD,cAAc;QAC9B,MAAME,iBAAiBtB,GAAGuB,YAAY,CAACH,aAAa,QAAQR,IAAI;QAEhE,gCAAgC;QAChC,MAAMY,oBAAoBF,eAAeG,OAAO,CAAC,MAAM;QACvD,MAAMC,sBAAsBR,iBAAiBO,OAAO,CAAC,MAAM;QAE3D,IAAIC,wBAAwBF,mBAAmB;YAC7Cf,QAAQkB,KAAK,CAAC,CAAC,iCAAiC,EAAET,iBAAiB,CAAC,CAAC;YACrET,QAAQkB,KAAK,CAAC;YACdlB,QAAQkB,KAAK,CAAC;YACdlB,QAAQkB,KAAK,CAAC;YACd5B,KAAK;YACL;QACF;IACF;IAEA,+BAA+B;IAC/B,IAAI;QACFG,OAAOiB;QACPV,QAAQC,GAAG,CAAC,CAAC,aAAa,EAAEQ,kBAAkB;IAChD,EAAE,OAAOU,KAAK;QACZnB,QAAQkB,KAAK,CAAC,CAAC,sBAAsB,EAAET,iBAAiB,CAAC,CAAC,EAAE,AAACU,IAAcC,OAAO;QAClF9B,KAAK;QACL;IACF;IAEAA,KAAK;AACP;AAEA;;CAEC,GACD,SAASiB,sBAAsBH,YAAoB;IACjD,MAAMiB,WAAWzB,wBAAwBQ;IAEzC,IAAIiB,SAAStB,MAAM,KAAK,GAAG;QACzBC,QAAQC,GAAG,CAAC;IACd,OAAO;QACL,IAAK,IAAIO,IAAI,GAAGA,IAAIa,SAAStB,MAAM,EAAES,IAAK;YACxCR,QAAQC,GAAG,CAAC,CAAC,EAAE,EAAEoB,QAAQ,CAACb,EAAE,EAAE;QAChC;IACF;AACF"}
|
|
@@ -22,9 +22,9 @@ import { findInstalledVersions } from '../lib/findInstalledVersions.js';
|
|
|
22
22
|
return;
|
|
23
23
|
}
|
|
24
24
|
// Resolve partial version to exact installed version
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
25
|
+
const versionsPath = path.join(storagePath, 'installed');
|
|
26
|
+
const matches = findInstalledVersions(versionsPath, version);
|
|
27
|
+
const resolvedVersion = matches.length > 0 ? matches[matches.length - 1] : null;
|
|
28
28
|
// Display version (show resolution if different)
|
|
29
29
|
if (resolvedVersion && resolvedVersion !== version && resolvedVersion !== `v${version}`) {
|
|
30
30
|
console.log(`Version: ${version} \u2192 ${resolvedVersion}`);
|
|
@@ -33,8 +33,8 @@ import { findInstalledVersions } from '../lib/findInstalledVersions.js';
|
|
|
33
33
|
}
|
|
34
34
|
console.log(`Source: ${getVersionSource(cwd)}`);
|
|
35
35
|
if (resolvedVersion) {
|
|
36
|
-
|
|
37
|
-
|
|
36
|
+
const actualVersionPath = path.join(versionsPath, resolvedVersion);
|
|
37
|
+
const nodePath = path.join(actualVersionPath, 'bin', 'node');
|
|
38
38
|
console.log(`Binary: ${nodePath}`);
|
|
39
39
|
if (fs.existsSync(nodePath)) {
|
|
40
40
|
console.log('Status: Installed');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/which.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport path from 'path';\nimport { storagePath } from '../constants.ts';\nimport { findInstalledVersions } from '../lib/findInstalledVersions.ts';\n\n/**\n * nvu which\n *\n * Show which Node binary would be used based on current directory.\n * This simulates what the nvu binary would do.\n */\nexport default function whichCmd(_args: string[]): void {\n const cwd = process.cwd();\n\n // Resolve version using the same logic as the nvu binary\n const version = resolveVersion(cwd);\n\n if (!version) {\n console.log('No Node version configured for this directory.');\n console.log('');\n console.log('To configure a version:');\n console.log(' nvu local <version> - Set version for this project');\n console.log(' nvu default <version> - Set global default');\n exit(1);\n return;\n }\n\n // Resolve partial version to exact installed version\n
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/commands/which.ts"],"sourcesContent":["import exit from 'exit-compat';\nimport fs from 'fs';\nimport path from 'path';\nimport { storagePath } from '../constants.ts';\nimport { findInstalledVersions } from '../lib/findInstalledVersions.ts';\n\n/**\n * nvu which\n *\n * Show which Node binary would be used based on current directory.\n * This simulates what the nvu binary would do.\n */\nexport default function whichCmd(_args: string[]): void {\n const cwd = process.cwd();\n\n // Resolve version using the same logic as the nvu binary\n const version = resolveVersion(cwd);\n\n if (!version) {\n console.log('No Node version configured for this directory.');\n console.log('');\n console.log('To configure a version:');\n console.log(' nvu local <version> - Set version for this project');\n console.log(' nvu default <version> - Set global default');\n exit(1);\n return;\n }\n\n // Resolve partial version to exact installed version\n const versionsPath = path.join(storagePath, 'installed');\n const matches = findInstalledVersions(versionsPath, version);\n const resolvedVersion = matches.length > 0 ? matches[matches.length - 1] : null;\n\n // Display version (show resolution if different)\n if (resolvedVersion && resolvedVersion !== version && resolvedVersion !== `v${version}`) {\n console.log(`Version: ${version} \\u2192 ${resolvedVersion}`);\n } else {\n console.log(`Version: ${resolvedVersion || version}`);\n }\n console.log(`Source: ${getVersionSource(cwd)}`);\n\n if (resolvedVersion) {\n const actualVersionPath = path.join(versionsPath, resolvedVersion);\n const nodePath = path.join(actualVersionPath, 'bin', 'node');\n console.log(`Binary: ${nodePath}`);\n if (fs.existsSync(nodePath)) {\n console.log('Status: Installed');\n } else {\n console.log('Status: Directory exists but binary not found');\n }\n } else {\n console.log(`Status: Not installed (run: nvu install ${version})`);\n }\n\n exit(0);\n}\n\n/**\n * Resolve version from config files (mirrors nvu binary logic)\n */\nfunction resolveVersion(cwd: string): string | null {\n // Walk up directories looking for .nvurc or .nvmrc\n let dir = cwd;\n while (true) {\n // Check .nvurc first\n const nvurcPath = path.join(dir, '.nvurc');\n if (fs.existsSync(nvurcPath)) {\n return fs.readFileSync(nvurcPath, 'utf8').trim();\n }\n\n // Check .nvmrc\n const nvmrcPath = path.join(dir, '.nvmrc');\n if (fs.existsSync(nvmrcPath)) {\n return fs.readFileSync(nvmrcPath, 'utf8').trim();\n }\n\n // Move to parent\n const parent = path.dirname(dir);\n if (parent === dir) break;\n dir = parent;\n }\n\n // Check global default\n const defaultPath = path.join(storagePath, 'default');\n if (fs.existsSync(defaultPath)) {\n return fs.readFileSync(defaultPath, 'utf8').trim();\n }\n\n return null;\n}\n\n/**\n * Determine the source of the version (for display)\n */\nfunction getVersionSource(cwd: string): string {\n let dir = cwd;\n while (true) {\n const nvurcPath = path.join(dir, '.nvurc');\n if (fs.existsSync(nvurcPath)) {\n return nvurcPath;\n }\n\n const nvmrcPath = path.join(dir, '.nvmrc');\n if (fs.existsSync(nvmrcPath)) {\n return nvmrcPath;\n }\n\n const parent = path.dirname(dir);\n if (parent === dir) break;\n dir = parent;\n }\n\n const defaultPath = path.join(storagePath, 'default');\n if (fs.existsSync(defaultPath)) {\n return `${defaultPath} (global default)`;\n }\n\n return 'none';\n}\n"],"names":["exit","fs","path","storagePath","findInstalledVersions","whichCmd","_args","cwd","process","version","resolveVersion","console","log","versionsPath","join","matches","resolvedVersion","length","getVersionSource","actualVersionPath","nodePath","existsSync","dir","nvurcPath","readFileSync","trim","nvmrcPath","parent","dirname","defaultPath"],"mappings":"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"}
|
package/dist/esm/compat.d.ts
CHANGED
package/dist/esm/compat.js
CHANGED
|
@@ -6,44 +6,48 @@ import _Module from 'module';
|
|
|
6
6
|
import os from 'os';
|
|
7
7
|
import path from 'path';
|
|
8
8
|
// Use existing require in CJS, or createRequire in ESM (Node 12.2+)
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
const _require = typeof require === 'undefined' ? _Module.createRequire(import.meta.url) : require;
|
|
10
|
+
const hasHomedir = typeof os.homedir === 'function';
|
|
11
11
|
export function homedir() {
|
|
12
|
-
if (hasHomedir)
|
|
13
|
-
|
|
14
|
-
}
|
|
15
|
-
var home = _require('homedir-polyfill');
|
|
12
|
+
if (hasHomedir) return os.homedir();
|
|
13
|
+
const home = require('homedir-polyfill');
|
|
16
14
|
return home();
|
|
17
15
|
}
|
|
16
|
+
const hasTmpdir = typeof os.tmpdir === 'function';
|
|
17
|
+
export function tmpdir() {
|
|
18
|
+
if (hasTmpdir) return os.tmpdir();
|
|
19
|
+
const osShim = require('os-shim');
|
|
20
|
+
return osShim.tmpdir();
|
|
21
|
+
}
|
|
18
22
|
/**
|
|
19
23
|
* String.prototype.endsWith wrapper for Node.js 0.8+
|
|
20
24
|
* - Uses native endsWith on Node 4.0+ / ES2015+
|
|
21
25
|
* - Falls back to lastIndexOf on Node 0.8-3.x
|
|
22
|
-
*/
|
|
26
|
+
*/ const hasEndsWith = typeof String.prototype.endsWith === 'function';
|
|
23
27
|
export function stringEndsWith(str, search, position) {
|
|
24
28
|
if (hasEndsWith) {
|
|
25
29
|
return str.endsWith(search, position);
|
|
26
30
|
}
|
|
27
|
-
|
|
31
|
+
const len = position === undefined ? str.length : position;
|
|
28
32
|
return str.lastIndexOf(search) === len - search.length;
|
|
29
33
|
}
|
|
30
34
|
/**
|
|
31
35
|
* Recursive mkdir for Node.js 0.8+
|
|
32
36
|
*/ export function mkdirpSync(dir) {
|
|
33
|
-
|
|
37
|
+
const mkdirp = _require('mkdirp-classic');
|
|
34
38
|
mkdirp.sync(dir);
|
|
35
39
|
}
|
|
36
40
|
/**
|
|
37
41
|
* Recursive rm for Node.js 0.8+
|
|
38
42
|
*/ export function rmSync(dir) {
|
|
39
|
-
|
|
43
|
+
const safeRmSync = _require('fs-remove-compat').safeRmSync;
|
|
40
44
|
safeRmSync(dir);
|
|
41
45
|
}
|
|
42
46
|
export function readdirWithTypes(dir) {
|
|
43
|
-
|
|
47
|
+
const names = fs.readdirSync(dir);
|
|
44
48
|
return names.map((name)=>{
|
|
45
|
-
|
|
46
|
-
|
|
49
|
+
const fullPath = path.join(dir, name);
|
|
50
|
+
let stat;
|
|
47
51
|
try {
|
|
48
52
|
stat = fs.statSync(fullPath);
|
|
49
53
|
} catch (_e) {
|
package/dist/esm/compat.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/compat.ts"],"sourcesContent":["/**\n * Compatibility Layer for Node.js 0.8+\n * Local to this package - contains only needed functions.\n */\nimport fs from 'fs';\nimport _Module from 'module';\nimport os from 'os';\nimport path from 'path';\n\n// Use existing require in CJS, or createRequire in ESM (Node 12.2+)\
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/OpenSource/node-version/node-version-use/src/compat.ts"],"sourcesContent":["/**\n * Compatibility Layer for Node.js 0.8+\n * Local to this package - contains only needed functions.\n */\nimport fs from 'fs';\nimport _Module from 'module';\nimport os from 'os';\nimport path from 'path';\n\n// Use existing require in CJS, or createRequire in ESM (Node 12.2+)\nconst _require = typeof require === 'undefined' ? _Module.createRequire(import.meta.url) : require;\n\nconst hasHomedir = typeof os.homedir === 'function';\nexport function homedir(): string {\n if (hasHomedir) return os.homedir();\n const home = require('homedir-polyfill');\n return home();\n}\n\nconst hasTmpdir = typeof os.tmpdir === 'function';\nexport function tmpdir(): string {\n if (hasTmpdir) return os.tmpdir();\n const osShim = require('os-shim');\n return osShim.tmpdir();\n}\n\n/**\n * String.prototype.endsWith wrapper for Node.js 0.8+\n * - Uses native endsWith on Node 4.0+ / ES2015+\n * - Falls back to lastIndexOf on Node 0.8-3.x\n */\nconst hasEndsWith = typeof String.prototype.endsWith === 'function';\n\nexport function stringEndsWith(str: string, search: string, position?: number): boolean {\n if (hasEndsWith) {\n return str.endsWith(search, position);\n }\n const len = position === undefined ? str.length : position;\n return str.lastIndexOf(search) === len - search.length;\n}\n\n/**\n * Recursive mkdir for Node.js 0.8+\n */\nexport function mkdirpSync(dir: string): void {\n const mkdirp = _require('mkdirp-classic');\n mkdirp.sync(dir);\n}\n\n/**\n * Recursive rm for Node.js 0.8+\n */\nexport function rmSync(dir: string): void {\n const safeRmSync = _require('fs-remove-compat').safeRmSync;\n safeRmSync(dir);\n}\n\n/**\n * Read directory entries with types for Node.js 0.8+\n * Returns array of {name, isDirectory()}\n */\nexport interface DirEntry {\n name: string;\n isDirectory(): boolean;\n}\n\nexport function readdirWithTypes(dir: string): DirEntry[] {\n const names = fs.readdirSync(dir);\n return names.map((name) => {\n const fullPath = path.join(dir, name);\n let stat: fs.Stats;\n try {\n stat = fs.statSync(fullPath);\n } catch (_e) {\n // If stat fails, treat as non-directory\n return { name: name, isDirectory: () => false };\n }\n return {\n name: name,\n isDirectory: () => stat.isDirectory(),\n };\n });\n}\n"],"names":["fs","_Module","os","path","_require","require","createRequire","url","hasHomedir","homedir","home","hasTmpdir","tmpdir","osShim","hasEndsWith","String","prototype","endsWith","stringEndsWith","str","search","position","len","undefined","length","lastIndexOf","mkdirpSync","dir","mkdirp","sync","rmSync","safeRmSync","readdirWithTypes","names","readdirSync","map","name","fullPath","join","stat","statSync","_e","isDirectory"],"mappings":"AAAA;;;CAGC,GACD,OAAOA,QAAQ,KAAK;AACpB,OAAOC,aAAa,SAAS;AAC7B,OAAOC,QAAQ,KAAK;AACpB,OAAOC,UAAU,OAAO;AAExB,oEAAoE;AACpE,MAAMC,WAAW,OAAOC,YAAY,cAAcJ,QAAQK,aAAa,CAAC,YAAYC,GAAG,IAAIF;AAE3F,MAAMG,aAAa,OAAON,GAAGO,OAAO,KAAK;AACzC,OAAO,SAASA;IACd,IAAID,YAAY,OAAON,GAAGO,OAAO;IACjC,MAAMC,OAAOL,QAAQ;IACrB,OAAOK;AACT;AAEA,MAAMC,YAAY,OAAOT,GAAGU,MAAM,KAAK;AACvC,OAAO,SAASA;IACd,IAAID,WAAW,OAAOT,GAAGU,MAAM;IAC/B,MAAMC,SAASR,QAAQ;IACvB,OAAOQ,OAAOD,MAAM;AACtB;AAEA;;;;CAIC,GACD,MAAME,cAAc,OAAOC,OAAOC,SAAS,CAACC,QAAQ,KAAK;AAEzD,OAAO,SAASC,eAAeC,GAAW,EAAEC,MAAc,EAAEC,QAAiB;IAC3E,IAAIP,aAAa;QACf,OAAOK,IAAIF,QAAQ,CAACG,QAAQC;IAC9B;IACA,MAAMC,MAAMD,aAAaE,YAAYJ,IAAIK,MAAM,GAAGH;IAClD,OAAOF,IAAIM,WAAW,CAACL,YAAYE,MAAMF,OAAOI,MAAM;AACxD;AAEA;;CAEC,GACD,OAAO,SAASE,WAAWC,GAAW;IACpC,MAAMC,SAASxB,SAAS;IACxBwB,OAAOC,IAAI,CAACF;AACd;AAEA;;CAEC,GACD,OAAO,SAASG,OAAOH,GAAW;IAChC,MAAMI,aAAa3B,SAAS,oBAAoB2B,UAAU;IAC1DA,WAAWJ;AACb;AAWA,OAAO,SAASK,iBAAiBL,GAAW;IAC1C,MAAMM,QAAQjC,GAAGkC,WAAW,CAACP;IAC7B,OAAOM,MAAME,GAAG,CAAC,CAACC;QAChB,MAAMC,WAAWlC,KAAKmC,IAAI,CAACX,KAAKS;QAChC,IAAIG;QACJ,IAAI;YACFA,OAAOvC,GAAGwC,QAAQ,CAACH;QACrB,EAAE,OAAOI,IAAI;YACX,wCAAwC;YACxC,OAAO;gBAAEL,MAAMA;gBAAMM,aAAa,IAAM;YAAM;QAChD;QACA,OAAO;YACLN,MAAMA;YACNM,aAAa,IAAMH,KAAKG,WAAW;QACrC;IACF;AACF"}
|
|
@@ -5,12 +5,12 @@ import { readdirWithTypes } from '../compat.js';
|
|
|
5
5
|
* Compare two semver version strings (e.g., "20.19.0" vs "20.9.1")
|
|
6
6
|
* Returns: negative if a < b, positive if a > b, 0 if equal
|
|
7
7
|
*/ function compareVersions(a, b) {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
for(
|
|
12
|
-
|
|
13
|
-
|
|
8
|
+
const aParts = a.replace(/^v/, '').split('.');
|
|
9
|
+
const bParts = b.replace(/^v/, '').split('.');
|
|
10
|
+
const len = Math.max(aParts.length, bParts.length);
|
|
11
|
+
for(let i = 0; i < len; i++){
|
|
12
|
+
const aNum = parseInt(aParts[i], 10) || 0;
|
|
13
|
+
const bNum = parseInt(bParts[i], 10) || 0;
|
|
14
14
|
if (aNum !== bNum) {
|
|
15
15
|
return aNum - bNum;
|
|
16
16
|
}
|
|
@@ -24,17 +24,17 @@ import { readdirWithTypes } from '../compat.js';
|
|
|
24
24
|
if (!fs.existsSync(versionsPath)) {
|
|
25
25
|
return [];
|
|
26
26
|
}
|
|
27
|
-
|
|
28
|
-
|
|
27
|
+
const normalizedVersion = version.replace(/^v/, '');
|
|
28
|
+
const matches = [];
|
|
29
29
|
// Try exact matches first
|
|
30
|
-
|
|
30
|
+
const exactMatches = [
|
|
31
31
|
version,
|
|
32
32
|
`v${normalizedVersion}`,
|
|
33
33
|
normalizedVersion
|
|
34
34
|
];
|
|
35
|
-
for(
|
|
36
|
-
|
|
37
|
-
|
|
35
|
+
for(let i = 0; i < exactMatches.length; i++){
|
|
36
|
+
const v = exactMatches[i];
|
|
37
|
+
const versionPath = path.join(versionsPath, v);
|
|
38
38
|
if (fs.existsSync(versionPath) && fs.statSync(versionPath).isDirectory()) {
|
|
39
39
|
if (matches.indexOf(v) === -1) {
|
|
40
40
|
matches.push(v);
|
|
@@ -46,11 +46,11 @@ import { readdirWithTypes } from '../compat.js';
|
|
|
46
46
|
return matches;
|
|
47
47
|
}
|
|
48
48
|
// Try partial match (e.g., "20" matches "v20.19.6")
|
|
49
|
-
|
|
50
|
-
for(
|
|
51
|
-
|
|
49
|
+
const entries = readdirWithTypes(versionsPath);
|
|
50
|
+
for(let j = 0; j < entries.length; j++){
|
|
51
|
+
const entry = entries[j];
|
|
52
52
|
if (!entry.isDirectory()) continue;
|
|
53
|
-
|
|
53
|
+
const dirVersion = entry.name.replace(/^v/, '');
|
|
54
54
|
if (dirVersion.indexOf(`${normalizedVersion}.`) === 0) {
|
|
55
55
|
matches.push(entry.name);
|
|
56
56
|
}
|
|
@@ -65,9 +65,9 @@ import { readdirWithTypes } from '../compat.js';
|
|
|
65
65
|
if (!fs.existsSync(versionsPath)) {
|
|
66
66
|
return [];
|
|
67
67
|
}
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
for(
|
|
68
|
+
const entries = readdirWithTypes(versionsPath);
|
|
69
|
+
const versions = [];
|
|
70
|
+
for(let i = 0; i < entries.length; i++){
|
|
71
71
|
if (entries[i].isDirectory()) {
|
|
72
72
|
versions.push(entries[i].name);
|
|
73
73
|
}
|