@nftrs/core 0.2.0

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 (4) hide show
  1. package/cli.js +95 -0
  2. package/index.d.ts +52 -0
  3. package/index.js +590 -0
  4. package/package.json +60 -0
package/cli.js ADDED
@@ -0,0 +1,95 @@
1
+ #!/usr/bin/env node
2
+ // CLI for @nftrs/core — a drop-in equivalent of @vercel/nft's `nft` CLI.
3
+ // Ports the `print` / `build` / `size` actions from src/cli.ts. The `why`
4
+ // action depends on the `reasons` graph (not yet returned — see issue #21).
5
+
6
+ 'use strict';
7
+
8
+ const { join, dirname, isAbsolute, relative, sep } = require('node:path');
9
+ const fs = require('node:fs');
10
+ const { nodeFileTrace } = require('./index.js');
11
+
12
+ // Print the `file` and recursively its parents (ports nft's `printStack`).
13
+ function printStack(file, reasons, stdout, seen = new Set()) {
14
+ if (seen.has(file)) return;
15
+ seen.add(file);
16
+ stdout.push(file);
17
+ const reason = reasons[file];
18
+ if (!reason || !reason.parents || reason.parents.length === 0) return;
19
+ for (const parent of reason.parents) printStack(parent, reasons, stdout, seen);
20
+ }
21
+
22
+ async function cli(
23
+ action = process.argv[2],
24
+ entrypoint = process.argv[3],
25
+ exitpoint = process.argv[4],
26
+ outputDir = 'dist',
27
+ cwd = process.cwd(),
28
+ ) {
29
+ const usage = [
30
+ '△ nftrs',
31
+ '',
32
+ 'Usage:',
33
+ '',
34
+ ' $ nftrs [command] <file>',
35
+ '',
36
+ 'Commands:',
37
+ '',
38
+ ' build [entrypoint] trace and copy to the dist directory',
39
+ ' print [entrypoint] trace and print the file list to stdout',
40
+ ' size [entrypoint] trace and print the total size in bytes',
41
+ ' why [entrypoint] [file] trace and print why <file> was included',
42
+ ];
43
+
44
+ if (!entrypoint || !['print', 'build', 'size', 'why'].includes(action)) {
45
+ return usage.join('\n');
46
+ }
47
+
48
+ const { fileList, esmFileList, warnings, reasons } = await nodeFileTrace(
49
+ [entrypoint],
50
+ { ts: true, base: cwd, mixedModules: true },
51
+ );
52
+ const allFiles = [...fileList].concat([...esmFileList]).sort();
53
+ const stdout = [];
54
+
55
+ if (action === 'print') {
56
+ stdout.push('FILELIST:', ...allFiles, '');
57
+ if (warnings && warnings.length > 0) {
58
+ stdout.push('WARNINGS:', ...warnings.map(String));
59
+ }
60
+ } else if (action === 'build') {
61
+ fs.rmSync(join(cwd, outputDir), { recursive: true, force: true });
62
+ for (const f of allFiles) {
63
+ const dest = join(cwd, outputDir, f);
64
+ fs.mkdirSync(dirname(dest), { recursive: true });
65
+ fs.copyFileSync(join(cwd, f), dest);
66
+ }
67
+ stdout.push(`Copied ${allFiles.length} files to ${outputDir}/`);
68
+ } else if (action === 'size') {
69
+ let bytes = 0;
70
+ for (const f of allFiles) {
71
+ const lstat = fs.lstatSync(f);
72
+ bytes += lstat.isSymbolicLink() ? lstat.size : fs.statSync(f).size;
73
+ }
74
+ stdout.push(`${bytes} bytes total`);
75
+ } else if (action === 'why') {
76
+ if (!exitpoint) {
77
+ throw new Error('Expected an additional <file> argument for the "why" command.');
78
+ }
79
+ const target = (isAbsolute(exitpoint) ? relative(cwd, exitpoint) : exitpoint).replace(
80
+ /[/\\]/g,
81
+ sep,
82
+ );
83
+ printStack(target, reasons, stdout);
84
+ }
85
+ return stdout.join('\n');
86
+ }
87
+
88
+ if (require.main === module) {
89
+ cli().then(console.log).catch((e) => {
90
+ console.error(e.message || e);
91
+ process.exit(1);
92
+ });
93
+ }
94
+
95
+ module.exports = cli;
package/index.d.ts ADDED
@@ -0,0 +1,52 @@
1
+ /* auto-generated by NAPI-RS */
2
+ /* eslint-disable */
3
+ /**
4
+ * Trace the runtime file dependencies of the given entry `files`.
5
+ *
6
+ * Takes the options as a raw object so the `resolve` / `ignore` callbacks
7
+ * (JS functions, which can't live in a `#[napi(object)]` struct) can be
8
+ * pulled out and invoked synchronously during the trace.
9
+ */
10
+ export declare function nodeFileTrace(files: Array<string>, options?: {
11
+ base?: string
12
+ processCwd?: string
13
+ depth?: number
14
+ ts?: boolean
15
+ analysis?: boolean
16
+ conditions?: Array<string>
17
+ exportsOnly?: boolean
18
+ moduleSyncCatchall?: boolean
19
+ paths?: Record<string, string>
20
+ resolve?: (specifier: string, parent: string, cjs: boolean) => string | Array<string> | false | undefined
21
+ ignore?: (path: string) => boolean
22
+ }): NodeFileTraceResult
23
+
24
+ /**
25
+ * Why a file is included: its reason `type`s and parent files. Mirrors a
26
+ * `@vercel/nft` `NodeFileTraceReasons` entry.
27
+ */
28
+ export interface NodeFileTraceReason {
29
+ /** Reason types: `initial` / `dependency` / `asset` / `resolve` / `sharedlib`. */
30
+ type: Array<string>
31
+ /** The files (relative to `base`) that referenced this one. */
32
+ parents: Array<string>
33
+ }
34
+
35
+ /**
36
+ * Result of [`node_file_trace`], matching `@vercel/nft`'s
37
+ * `NodeFileTraceResult` shape (`fileList` / `esmFileList` / `reasons` /
38
+ * `warnings`).
39
+ */
40
+ export interface NodeFileTraceResult {
41
+ /** All files (relative to `base`) needed at runtime. */
42
+ fileList: Array<string>
43
+ /** The subset of `file_list` that is ESM. */
44
+ esmFileList: Array<string>
45
+ /** Non-fatal warnings encountered during tracing. */
46
+ warnings: Array<string>
47
+ /** The reasons graph: file (relative to `base`) → why it's included. */
48
+ reasons: Record<string, NodeFileTraceReason>
49
+ }
50
+
51
+ /** The `@nftrs/core` package version. */
52
+ export declare function version(): string
package/index.js ADDED
@@ -0,0 +1,590 @@
1
+ // prettier-ignore
2
+ /* eslint-disable */
3
+ // @ts-nocheck
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ const { readFileSync } = require('node:fs')
7
+ let nativeBinding = null
8
+ const loadErrors = []
9
+
10
+ const isMusl = () => {
11
+ let musl = false
12
+ if (process.platform === 'linux') {
13
+ musl = isMuslFromFilesystem()
14
+ if (musl === null) {
15
+ musl = isMuslFromReport()
16
+ }
17
+ if (musl === null) {
18
+ musl = isMuslFromChildProcess()
19
+ }
20
+ }
21
+ return musl
22
+ }
23
+
24
+ const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-')
25
+
26
+ const isMuslFromFilesystem = () => {
27
+ try {
28
+ return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl')
29
+ } catch {
30
+ return null
31
+ }
32
+ }
33
+
34
+ const isMuslFromReport = () => {
35
+ let report = null
36
+ if (typeof process.report?.getReport === 'function') {
37
+ process.report.excludeNetwork = true
38
+ report = process.report.getReport()
39
+ }
40
+ if (!report) {
41
+ return null
42
+ }
43
+ if (report.header && report.header.glibcVersionRuntime) {
44
+ return false
45
+ }
46
+ if (Array.isArray(report.sharedObjects)) {
47
+ if (report.sharedObjects.some(isFileMusl)) {
48
+ return true
49
+ }
50
+ }
51
+ return false
52
+ }
53
+
54
+ const isMuslFromChildProcess = () => {
55
+ try {
56
+ return require('child_process').execSync('ldd --version', { encoding: 'utf8' }).includes('musl')
57
+ } catch (e) {
58
+ // If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false
59
+ return false
60
+ }
61
+ }
62
+
63
+ function requireNative() {
64
+ if (process.env.NAPI_RS_NATIVE_LIBRARY_PATH) {
65
+ try {
66
+ return require(process.env.NAPI_RS_NATIVE_LIBRARY_PATH);
67
+ } catch (err) {
68
+ loadErrors.push(err)
69
+ }
70
+ } else if (process.platform === 'android') {
71
+ if (process.arch === 'arm64') {
72
+ try {
73
+ return require('./nftrs.android-arm64.node')
74
+ } catch (e) {
75
+ loadErrors.push(e)
76
+ }
77
+ try {
78
+ const binding = require('@nftrs/binding-android-arm64')
79
+ const bindingPackageVersion = require('@nftrs/binding-android-arm64/package.json').version
80
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
81
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
82
+ }
83
+ return binding
84
+ } catch (e) {
85
+ loadErrors.push(e)
86
+ }
87
+ } else if (process.arch === 'arm') {
88
+ try {
89
+ return require('./nftrs.android-arm-eabi.node')
90
+ } catch (e) {
91
+ loadErrors.push(e)
92
+ }
93
+ try {
94
+ const binding = require('@nftrs/binding-android-arm-eabi')
95
+ const bindingPackageVersion = require('@nftrs/binding-android-arm-eabi/package.json').version
96
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
97
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
98
+ }
99
+ return binding
100
+ } catch (e) {
101
+ loadErrors.push(e)
102
+ }
103
+ } else {
104
+ loadErrors.push(new Error(`Unsupported architecture on Android ${process.arch}`))
105
+ }
106
+ } else if (process.platform === 'win32') {
107
+ if (process.arch === 'x64') {
108
+ if (process.config?.variables?.shlib_suffix === 'dll.a' || process.config?.variables?.node_target_type === 'shared_library') {
109
+ try {
110
+ return require('./nftrs.win32-x64-gnu.node')
111
+ } catch (e) {
112
+ loadErrors.push(e)
113
+ }
114
+ try {
115
+ const binding = require('@nftrs/binding-win32-x64-gnu')
116
+ const bindingPackageVersion = require('@nftrs/binding-win32-x64-gnu/package.json').version
117
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
118
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
119
+ }
120
+ return binding
121
+ } catch (e) {
122
+ loadErrors.push(e)
123
+ }
124
+ } else {
125
+ try {
126
+ return require('./nftrs.win32-x64-msvc.node')
127
+ } catch (e) {
128
+ loadErrors.push(e)
129
+ }
130
+ try {
131
+ const binding = require('@nftrs/binding-win32-x64-msvc')
132
+ const bindingPackageVersion = require('@nftrs/binding-win32-x64-msvc/package.json').version
133
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
134
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
135
+ }
136
+ return binding
137
+ } catch (e) {
138
+ loadErrors.push(e)
139
+ }
140
+ }
141
+ } else if (process.arch === 'ia32') {
142
+ try {
143
+ return require('./nftrs.win32-ia32-msvc.node')
144
+ } catch (e) {
145
+ loadErrors.push(e)
146
+ }
147
+ try {
148
+ const binding = require('@nftrs/binding-win32-ia32-msvc')
149
+ const bindingPackageVersion = require('@nftrs/binding-win32-ia32-msvc/package.json').version
150
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
151
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
152
+ }
153
+ return binding
154
+ } catch (e) {
155
+ loadErrors.push(e)
156
+ }
157
+ } else if (process.arch === 'arm64') {
158
+ try {
159
+ return require('./nftrs.win32-arm64-msvc.node')
160
+ } catch (e) {
161
+ loadErrors.push(e)
162
+ }
163
+ try {
164
+ const binding = require('@nftrs/binding-win32-arm64-msvc')
165
+ const bindingPackageVersion = require('@nftrs/binding-win32-arm64-msvc/package.json').version
166
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
167
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
168
+ }
169
+ return binding
170
+ } catch (e) {
171
+ loadErrors.push(e)
172
+ }
173
+ } else {
174
+ loadErrors.push(new Error(`Unsupported architecture on Windows: ${process.arch}`))
175
+ }
176
+ } else if (process.platform === 'darwin') {
177
+ try {
178
+ return require('./nftrs.darwin-universal.node')
179
+ } catch (e) {
180
+ loadErrors.push(e)
181
+ }
182
+ try {
183
+ const binding = require('@nftrs/binding-darwin-universal')
184
+ const bindingPackageVersion = require('@nftrs/binding-darwin-universal/package.json').version
185
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
186
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
187
+ }
188
+ return binding
189
+ } catch (e) {
190
+ loadErrors.push(e)
191
+ }
192
+ if (process.arch === 'x64') {
193
+ try {
194
+ return require('./nftrs.darwin-x64.node')
195
+ } catch (e) {
196
+ loadErrors.push(e)
197
+ }
198
+ try {
199
+ const binding = require('@nftrs/binding-darwin-x64')
200
+ const bindingPackageVersion = require('@nftrs/binding-darwin-x64/package.json').version
201
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
202
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
203
+ }
204
+ return binding
205
+ } catch (e) {
206
+ loadErrors.push(e)
207
+ }
208
+ } else if (process.arch === 'arm64') {
209
+ try {
210
+ return require('./nftrs.darwin-arm64.node')
211
+ } catch (e) {
212
+ loadErrors.push(e)
213
+ }
214
+ try {
215
+ const binding = require('@nftrs/binding-darwin-arm64')
216
+ const bindingPackageVersion = require('@nftrs/binding-darwin-arm64/package.json').version
217
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
218
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
219
+ }
220
+ return binding
221
+ } catch (e) {
222
+ loadErrors.push(e)
223
+ }
224
+ } else {
225
+ loadErrors.push(new Error(`Unsupported architecture on macOS: ${process.arch}`))
226
+ }
227
+ } else if (process.platform === 'freebsd') {
228
+ if (process.arch === 'x64') {
229
+ try {
230
+ return require('./nftrs.freebsd-x64.node')
231
+ } catch (e) {
232
+ loadErrors.push(e)
233
+ }
234
+ try {
235
+ const binding = require('@nftrs/binding-freebsd-x64')
236
+ const bindingPackageVersion = require('@nftrs/binding-freebsd-x64/package.json').version
237
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
238
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
239
+ }
240
+ return binding
241
+ } catch (e) {
242
+ loadErrors.push(e)
243
+ }
244
+ } else if (process.arch === 'arm64') {
245
+ try {
246
+ return require('./nftrs.freebsd-arm64.node')
247
+ } catch (e) {
248
+ loadErrors.push(e)
249
+ }
250
+ try {
251
+ const binding = require('@nftrs/binding-freebsd-arm64')
252
+ const bindingPackageVersion = require('@nftrs/binding-freebsd-arm64/package.json').version
253
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
254
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
255
+ }
256
+ return binding
257
+ } catch (e) {
258
+ loadErrors.push(e)
259
+ }
260
+ } else {
261
+ loadErrors.push(new Error(`Unsupported architecture on FreeBSD: ${process.arch}`))
262
+ }
263
+ } else if (process.platform === 'linux') {
264
+ if (process.arch === 'x64') {
265
+ if (isMusl()) {
266
+ try {
267
+ return require('./nftrs.linux-x64-musl.node')
268
+ } catch (e) {
269
+ loadErrors.push(e)
270
+ }
271
+ try {
272
+ const binding = require('@nftrs/binding-linux-x64-musl')
273
+ const bindingPackageVersion = require('@nftrs/binding-linux-x64-musl/package.json').version
274
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
275
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
276
+ }
277
+ return binding
278
+ } catch (e) {
279
+ loadErrors.push(e)
280
+ }
281
+ } else {
282
+ try {
283
+ return require('./nftrs.linux-x64-gnu.node')
284
+ } catch (e) {
285
+ loadErrors.push(e)
286
+ }
287
+ try {
288
+ const binding = require('@nftrs/binding-linux-x64-gnu')
289
+ const bindingPackageVersion = require('@nftrs/binding-linux-x64-gnu/package.json').version
290
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
291
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
292
+ }
293
+ return binding
294
+ } catch (e) {
295
+ loadErrors.push(e)
296
+ }
297
+ }
298
+ } else if (process.arch === 'arm64') {
299
+ if (isMusl()) {
300
+ try {
301
+ return require('./nftrs.linux-arm64-musl.node')
302
+ } catch (e) {
303
+ loadErrors.push(e)
304
+ }
305
+ try {
306
+ const binding = require('@nftrs/binding-linux-arm64-musl')
307
+ const bindingPackageVersion = require('@nftrs/binding-linux-arm64-musl/package.json').version
308
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
309
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
310
+ }
311
+ return binding
312
+ } catch (e) {
313
+ loadErrors.push(e)
314
+ }
315
+ } else {
316
+ try {
317
+ return require('./nftrs.linux-arm64-gnu.node')
318
+ } catch (e) {
319
+ loadErrors.push(e)
320
+ }
321
+ try {
322
+ const binding = require('@nftrs/binding-linux-arm64-gnu')
323
+ const bindingPackageVersion = require('@nftrs/binding-linux-arm64-gnu/package.json').version
324
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
325
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
326
+ }
327
+ return binding
328
+ } catch (e) {
329
+ loadErrors.push(e)
330
+ }
331
+ }
332
+ } else if (process.arch === 'arm') {
333
+ if (isMusl()) {
334
+ try {
335
+ return require('./nftrs.linux-arm-musleabihf.node')
336
+ } catch (e) {
337
+ loadErrors.push(e)
338
+ }
339
+ try {
340
+ const binding = require('@nftrs/binding-linux-arm-musleabihf')
341
+ const bindingPackageVersion = require('@nftrs/binding-linux-arm-musleabihf/package.json').version
342
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
343
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
344
+ }
345
+ return binding
346
+ } catch (e) {
347
+ loadErrors.push(e)
348
+ }
349
+ } else {
350
+ try {
351
+ return require('./nftrs.linux-arm-gnueabihf.node')
352
+ } catch (e) {
353
+ loadErrors.push(e)
354
+ }
355
+ try {
356
+ const binding = require('@nftrs/binding-linux-arm-gnueabihf')
357
+ const bindingPackageVersion = require('@nftrs/binding-linux-arm-gnueabihf/package.json').version
358
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
359
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
360
+ }
361
+ return binding
362
+ } catch (e) {
363
+ loadErrors.push(e)
364
+ }
365
+ }
366
+ } else if (process.arch === 'loong64') {
367
+ if (isMusl()) {
368
+ try {
369
+ return require('./nftrs.linux-loong64-musl.node')
370
+ } catch (e) {
371
+ loadErrors.push(e)
372
+ }
373
+ try {
374
+ const binding = require('@nftrs/binding-linux-loong64-musl')
375
+ const bindingPackageVersion = require('@nftrs/binding-linux-loong64-musl/package.json').version
376
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
377
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
378
+ }
379
+ return binding
380
+ } catch (e) {
381
+ loadErrors.push(e)
382
+ }
383
+ } else {
384
+ try {
385
+ return require('./nftrs.linux-loong64-gnu.node')
386
+ } catch (e) {
387
+ loadErrors.push(e)
388
+ }
389
+ try {
390
+ const binding = require('@nftrs/binding-linux-loong64-gnu')
391
+ const bindingPackageVersion = require('@nftrs/binding-linux-loong64-gnu/package.json').version
392
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
393
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
394
+ }
395
+ return binding
396
+ } catch (e) {
397
+ loadErrors.push(e)
398
+ }
399
+ }
400
+ } else if (process.arch === 'riscv64') {
401
+ if (isMusl()) {
402
+ try {
403
+ return require('./nftrs.linux-riscv64-musl.node')
404
+ } catch (e) {
405
+ loadErrors.push(e)
406
+ }
407
+ try {
408
+ const binding = require('@nftrs/binding-linux-riscv64-musl')
409
+ const bindingPackageVersion = require('@nftrs/binding-linux-riscv64-musl/package.json').version
410
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
411
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
412
+ }
413
+ return binding
414
+ } catch (e) {
415
+ loadErrors.push(e)
416
+ }
417
+ } else {
418
+ try {
419
+ return require('./nftrs.linux-riscv64-gnu.node')
420
+ } catch (e) {
421
+ loadErrors.push(e)
422
+ }
423
+ try {
424
+ const binding = require('@nftrs/binding-linux-riscv64-gnu')
425
+ const bindingPackageVersion = require('@nftrs/binding-linux-riscv64-gnu/package.json').version
426
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
427
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
428
+ }
429
+ return binding
430
+ } catch (e) {
431
+ loadErrors.push(e)
432
+ }
433
+ }
434
+ } else if (process.arch === 'ppc64') {
435
+ try {
436
+ return require('./nftrs.linux-ppc64-gnu.node')
437
+ } catch (e) {
438
+ loadErrors.push(e)
439
+ }
440
+ try {
441
+ const binding = require('@nftrs/binding-linux-ppc64-gnu')
442
+ const bindingPackageVersion = require('@nftrs/binding-linux-ppc64-gnu/package.json').version
443
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
444
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
445
+ }
446
+ return binding
447
+ } catch (e) {
448
+ loadErrors.push(e)
449
+ }
450
+ } else if (process.arch === 's390x') {
451
+ try {
452
+ return require('./nftrs.linux-s390x-gnu.node')
453
+ } catch (e) {
454
+ loadErrors.push(e)
455
+ }
456
+ try {
457
+ const binding = require('@nftrs/binding-linux-s390x-gnu')
458
+ const bindingPackageVersion = require('@nftrs/binding-linux-s390x-gnu/package.json').version
459
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
460
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
461
+ }
462
+ return binding
463
+ } catch (e) {
464
+ loadErrors.push(e)
465
+ }
466
+ } else {
467
+ loadErrors.push(new Error(`Unsupported architecture on Linux: ${process.arch}`))
468
+ }
469
+ } else if (process.platform === 'openharmony') {
470
+ if (process.arch === 'arm64') {
471
+ try {
472
+ return require('./nftrs.openharmony-arm64.node')
473
+ } catch (e) {
474
+ loadErrors.push(e)
475
+ }
476
+ try {
477
+ const binding = require('@nftrs/binding-openharmony-arm64')
478
+ const bindingPackageVersion = require('@nftrs/binding-openharmony-arm64/package.json').version
479
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
480
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
481
+ }
482
+ return binding
483
+ } catch (e) {
484
+ loadErrors.push(e)
485
+ }
486
+ } else if (process.arch === 'x64') {
487
+ try {
488
+ return require('./nftrs.openharmony-x64.node')
489
+ } catch (e) {
490
+ loadErrors.push(e)
491
+ }
492
+ try {
493
+ const binding = require('@nftrs/binding-openharmony-x64')
494
+ const bindingPackageVersion = require('@nftrs/binding-openharmony-x64/package.json').version
495
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
496
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
497
+ }
498
+ return binding
499
+ } catch (e) {
500
+ loadErrors.push(e)
501
+ }
502
+ } else if (process.arch === 'arm') {
503
+ try {
504
+ return require('./nftrs.openharmony-arm.node')
505
+ } catch (e) {
506
+ loadErrors.push(e)
507
+ }
508
+ try {
509
+ const binding = require('@nftrs/binding-openharmony-arm')
510
+ const bindingPackageVersion = require('@nftrs/binding-openharmony-arm/package.json').version
511
+ if (bindingPackageVersion !== '0.0.0' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
512
+ throw new Error(`Native binding package version mismatch, expected 0.0.0 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
513
+ }
514
+ return binding
515
+ } catch (e) {
516
+ loadErrors.push(e)
517
+ }
518
+ } else {
519
+ loadErrors.push(new Error(`Unsupported architecture on OpenHarmony: ${process.arch}`))
520
+ }
521
+ } else {
522
+ loadErrors.push(new Error(`Unsupported OS: ${process.platform}, architecture: ${process.arch}`))
523
+ }
524
+ }
525
+
526
+ nativeBinding = requireNative()
527
+
528
+ // NAPI_RS_FORCE_WASI is a tri-state flag:
529
+ // unset / any other value → native binding preferred, WASI is only a fallback
530
+ // 'true' → force WASI fallback even if native loaded
531
+ // 'error' → force WASI and throw if no WASI binding is found
532
+ // Treating any non-empty string as truthy (the historical behavior) meant
533
+ // NAPI_RS_FORCE_WASI=false, NAPI_RS_FORCE_WASI=0, etc. inadvertently triggered
534
+ // the WASI path, causing ENOENT for packages shipped without a .wasi.cjs file.
535
+ const forceWasi =
536
+ process.env.NAPI_RS_FORCE_WASI === 'true' || process.env.NAPI_RS_FORCE_WASI === 'error'
537
+
538
+ if (!nativeBinding || forceWasi) {
539
+ let wasiBinding = null
540
+ let wasiBindingError = null
541
+ try {
542
+ wasiBinding = require('./nftrs.wasi.cjs')
543
+ nativeBinding = wasiBinding
544
+ } catch (err) {
545
+ if (forceWasi) {
546
+ wasiBindingError = err
547
+ }
548
+ }
549
+ if (!nativeBinding || forceWasi) {
550
+ try {
551
+ wasiBinding = require('@nftrs/binding-wasm32-wasi')
552
+ nativeBinding = wasiBinding
553
+ } catch (err) {
554
+ if (forceWasi) {
555
+ if (!wasiBindingError) {
556
+ wasiBindingError = err
557
+ } else {
558
+ wasiBindingError.cause = err
559
+ }
560
+ loadErrors.push(err)
561
+ }
562
+ }
563
+ }
564
+ if (process.env.NAPI_RS_FORCE_WASI === 'error' && !wasiBinding) {
565
+ const error = new Error('WASI binding not found and NAPI_RS_FORCE_WASI is set to error')
566
+ error.cause = wasiBindingError
567
+ throw error
568
+ }
569
+ }
570
+
571
+ if (!nativeBinding) {
572
+ if (loadErrors.length > 0) {
573
+ throw new Error(
574
+ `Cannot find native binding. ` +
575
+ `npm has a bug related to optional dependencies (https://github.com/npm/cli/issues/4828). ` +
576
+ 'Please try `npm i` again after removing both package-lock.json and node_modules directory.',
577
+ {
578
+ cause: loadErrors.reduce((err, cur) => {
579
+ cur.cause = err
580
+ return cur
581
+ }),
582
+ },
583
+ )
584
+ }
585
+ throw new Error(`Failed to load native binding`)
586
+ }
587
+
588
+ module.exports = nativeBinding
589
+ module.exports.nodeFileTrace = nativeBinding.nodeFileTrace
590
+ module.exports.version = nativeBinding.version
package/package.json ADDED
@@ -0,0 +1,60 @@
1
+ {
2
+ "name": "@nftrs/core",
3
+ "version": "0.2.0",
4
+ "description": "Node.js dependency tracing (a Rust + OXC rewrite of @vercel/nft). Drop-in nodeFileTrace.",
5
+ "keywords": [
6
+ "dependency",
7
+ "napi",
8
+ "nft",
9
+ "node",
10
+ "oxc",
11
+ "rust",
12
+ "trace"
13
+ ],
14
+ "license": "MIT",
15
+ "author": "ubugeeei",
16
+ "repository": {
17
+ "type": "git",
18
+ "url": "git+https://github.com/ubugeeei-prod/nftrs.git",
19
+ "directory": "crates/nftrs_napi"
20
+ },
21
+ "files": [
22
+ "cli.js",
23
+ "index.js",
24
+ "index.d.ts"
25
+ ],
26
+ "main": "index.js",
27
+ "types": "index.d.ts",
28
+ "publishConfig": {
29
+ "access": "public",
30
+ "provenance": true
31
+ },
32
+ "scripts": {
33
+ "build": "napi build --release",
34
+ "build:debug": "napi build"
35
+ },
36
+ "devDependencies": {
37
+ "@napi-rs/cli": "^3.7.0"
38
+ },
39
+ "napi": {
40
+ "binaryName": "nftrs",
41
+ "packageName": "@nftrs/binding",
42
+ "targets": [
43
+ "x86_64-apple-darwin",
44
+ "aarch64-apple-darwin",
45
+ "x86_64-unknown-linux-gnu",
46
+ "aarch64-unknown-linux-gnu",
47
+ "x86_64-pc-windows-msvc"
48
+ ]
49
+ },
50
+ "bin": {
51
+ "nftrs": "cli.js"
52
+ },
53
+ "optionalDependencies": {
54
+ "@nftrs/binding-darwin-x64": "0.2.0",
55
+ "@nftrs/binding-darwin-arm64": "0.2.0",
56
+ "@nftrs/binding-linux-x64-gnu": "0.2.0",
57
+ "@nftrs/binding-linux-arm64-gnu": "0.2.0",
58
+ "@nftrs/binding-win32-x64-msvc": "0.2.0"
59
+ }
60
+ }