@xuanwo/xurl 0.0.26-win32-arm64 → 0.0.26
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/bin/xurl.js +141 -0
- package/package.json +16 -10
- package/vendor/aarch64-pc-windows-msvc/xurl/xurl.exe +0 -0
package/bin/xurl.js
ADDED
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
// Unified entry point for the xurl CLI.
|
|
3
|
+
|
|
4
|
+
import { spawn } from "node:child_process";
|
|
5
|
+
import { existsSync } from "node:fs";
|
|
6
|
+
import { createRequire } from "node:module";
|
|
7
|
+
import path from "node:path";
|
|
8
|
+
import { fileURLToPath } from "node:url";
|
|
9
|
+
|
|
10
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
11
|
+
const __dirname = path.dirname(__filename);
|
|
12
|
+
const require = createRequire(import.meta.url);
|
|
13
|
+
|
|
14
|
+
const PLATFORM_PACKAGE_BY_TARGET = {
|
|
15
|
+
"x86_64-unknown-linux-gnu": "@xuanwo/xurl-linux-x64",
|
|
16
|
+
"aarch64-unknown-linux-gnu": "@xuanwo/xurl-linux-arm64",
|
|
17
|
+
"x86_64-apple-darwin": "@xuanwo/xurl-darwin-x64",
|
|
18
|
+
"aarch64-apple-darwin": "@xuanwo/xurl-darwin-arm64",
|
|
19
|
+
"x86_64-pc-windows-msvc": "@xuanwo/xurl-win32-x64",
|
|
20
|
+
"aarch64-pc-windows-msvc": "@xuanwo/xurl-win32-arm64",
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
function detectTargetTriple(platformName, archName) {
|
|
24
|
+
switch (platformName) {
|
|
25
|
+
case "linux":
|
|
26
|
+
if (archName === "x64") {
|
|
27
|
+
return "x86_64-unknown-linux-gnu";
|
|
28
|
+
}
|
|
29
|
+
if (archName === "arm64") {
|
|
30
|
+
return "aarch64-unknown-linux-gnu";
|
|
31
|
+
}
|
|
32
|
+
break;
|
|
33
|
+
case "darwin":
|
|
34
|
+
if (archName === "x64") {
|
|
35
|
+
return "x86_64-apple-darwin";
|
|
36
|
+
}
|
|
37
|
+
if (archName === "arm64") {
|
|
38
|
+
return "aarch64-apple-darwin";
|
|
39
|
+
}
|
|
40
|
+
break;
|
|
41
|
+
case "win32":
|
|
42
|
+
if (archName === "x64") {
|
|
43
|
+
return "x86_64-pc-windows-msvc";
|
|
44
|
+
}
|
|
45
|
+
if (archName === "arm64") {
|
|
46
|
+
return "aarch64-pc-windows-msvc";
|
|
47
|
+
}
|
|
48
|
+
break;
|
|
49
|
+
default:
|
|
50
|
+
break;
|
|
51
|
+
}
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function detectPackageManager() {
|
|
56
|
+
const userAgent = process.env.npm_config_user_agent || "";
|
|
57
|
+
if (/\bbun\//.test(userAgent)) {
|
|
58
|
+
return "bun";
|
|
59
|
+
}
|
|
60
|
+
return userAgent ? "npm" : null;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const targetTriple = detectTargetTriple(process.platform, process.arch);
|
|
64
|
+
if (!targetTriple) {
|
|
65
|
+
throw new Error(`Unsupported platform: ${process.platform} (${process.arch})`);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
const platformPackage = PLATFORM_PACKAGE_BY_TARGET[targetTriple];
|
|
69
|
+
if (!platformPackage) {
|
|
70
|
+
throw new Error(`Unsupported target triple: ${targetTriple}`);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const binaryName = process.platform === "win32" ? "xurl.exe" : "xurl";
|
|
74
|
+
const localVendorRoot = path.join(__dirname, "..", "vendor");
|
|
75
|
+
const localBinaryPath = path.join(localVendorRoot, targetTriple, "xurl", binaryName);
|
|
76
|
+
|
|
77
|
+
let vendorRoot;
|
|
78
|
+
try {
|
|
79
|
+
const packageJsonPath = require.resolve(`${platformPackage}/package.json`);
|
|
80
|
+
vendorRoot = path.join(path.dirname(packageJsonPath), "vendor");
|
|
81
|
+
} catch {
|
|
82
|
+
if (existsSync(localBinaryPath)) {
|
|
83
|
+
vendorRoot = localVendorRoot;
|
|
84
|
+
} else {
|
|
85
|
+
const manager = detectPackageManager();
|
|
86
|
+
const updateCommand =
|
|
87
|
+
manager === "bun"
|
|
88
|
+
? "bun install -g @xuanwo/xurl@latest"
|
|
89
|
+
: "npm install -g @xuanwo/xurl@latest";
|
|
90
|
+
throw new Error(
|
|
91
|
+
`Missing optional dependency ${platformPackage}. Reinstall xurl: ${updateCommand}`,
|
|
92
|
+
);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const binaryPath = path.join(vendorRoot, targetTriple, "xurl", binaryName);
|
|
97
|
+
const env = { ...process.env };
|
|
98
|
+
env[detectPackageManager() === "bun" ? "XURL_MANAGED_BY_BUN" : "XURL_MANAGED_BY_NPM"] =
|
|
99
|
+
"1";
|
|
100
|
+
|
|
101
|
+
const child = spawn(binaryPath, process.argv.slice(2), {
|
|
102
|
+
stdio: "inherit",
|
|
103
|
+
env,
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
child.on("error", (err) => {
|
|
107
|
+
// eslint-disable-next-line no-console
|
|
108
|
+
console.error(err);
|
|
109
|
+
process.exit(1);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
const forwardSignal = (signal) => {
|
|
113
|
+
if (child.killed) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
try {
|
|
117
|
+
child.kill(signal);
|
|
118
|
+
} catch {
|
|
119
|
+
// Ignore errors when the child already exited.
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
["SIGINT", "SIGTERM", "SIGHUP"].forEach((signal) => {
|
|
124
|
+
process.on(signal, () => forwardSignal(signal));
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
const childResult = await new Promise((resolve) => {
|
|
128
|
+
child.on("exit", (code, signal) => {
|
|
129
|
+
if (signal) {
|
|
130
|
+
resolve({ type: "signal", signal });
|
|
131
|
+
} else {
|
|
132
|
+
resolve({ type: "code", exitCode: code ?? 1 });
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
if (childResult.type === "signal") {
|
|
138
|
+
process.kill(process.pid, childResult.signal);
|
|
139
|
+
} else {
|
|
140
|
+
process.exit(childResult.exitCode);
|
|
141
|
+
}
|
package/package.json
CHANGED
|
@@ -1,21 +1,27 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xuanwo/xurl",
|
|
3
|
-
"version": "0.0.26
|
|
3
|
+
"version": "0.0.26",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
|
-
"
|
|
6
|
-
"
|
|
7
|
-
|
|
8
|
-
"
|
|
9
|
-
|
|
10
|
-
|
|
5
|
+
"bin": {
|
|
6
|
+
"xurl": "bin/xurl.js"
|
|
7
|
+
},
|
|
8
|
+
"type": "module",
|
|
9
|
+
"engines": {
|
|
10
|
+
"node": ">=16"
|
|
11
|
+
},
|
|
11
12
|
"files": [
|
|
12
|
-
"
|
|
13
|
+
"bin"
|
|
13
14
|
],
|
|
14
15
|
"repository": {
|
|
15
16
|
"type": "git",
|
|
16
17
|
"url": "git+https://github.com/Xuanwo/xurl.git"
|
|
17
18
|
},
|
|
18
|
-
"
|
|
19
|
-
"
|
|
19
|
+
"optionalDependencies": {
|
|
20
|
+
"@xuanwo/xurl-linux-x64": "npm:@xuanwo/xurl@0.0.26-linux-x64",
|
|
21
|
+
"@xuanwo/xurl-linux-arm64": "npm:@xuanwo/xurl@0.0.26-linux-arm64",
|
|
22
|
+
"@xuanwo/xurl-darwin-x64": "npm:@xuanwo/xurl@0.0.26-darwin-x64",
|
|
23
|
+
"@xuanwo/xurl-darwin-arm64": "npm:@xuanwo/xurl@0.0.26-darwin-arm64",
|
|
24
|
+
"@xuanwo/xurl-win32-x64": "npm:@xuanwo/xurl@0.0.26-win32-x64",
|
|
25
|
+
"@xuanwo/xurl-win32-arm64": "npm:@xuanwo/xurl@0.0.26-win32-arm64"
|
|
20
26
|
}
|
|
21
27
|
}
|
|
Binary file
|