-
-
Notifications
You must be signed in to change notification settings - Fork 84
Description
Source maps are always being configured as inline when using a .swcrc file. This causes incorrect line numbers to be reported in stack traces because source-map-support requires the hookRequire option to be set to true to process inline source maps, however @swc-node/sourcemap-support does not set this option and there is no way to configure it to do so.
Reproduction
tsconfig.json
{
"compilerOptions": {
"module": "CommonJS",
"sourceMap": true
}
}
.swcrc
{
"jsc": {
"parser": {
"syntax": "typescript",
},
},
"sourceMaps": true,
"module": {
"type": "commonjs",
}
}
index.ts
throw new Error();
When running node -r @swc-node/register ./index.ts, the line number (1) in the first line of error's stack trace is correct:
$ node -r @swc-node/register ./index.ts
/swc-node/test/index.ts:2
throw new Error();
^
Error:
at Object.<anonymous> (/swc-node/test/index.ts:1:7)
at Module._compile (node:internal/modules/cjs/loader:1241:14)
at Module._compile (/swc-node/node_modules/.pnpm/pirates@4.0.5/node_modules/pirates/lib/index.js:136:24)
at Module._extensions..js (node:internal/modules/cjs/loader:1295:10)
at Object.newLoader [as .ts] (/swc-node/node_modules/.pnpm/pirates@4.0.5/node_modules/pirates/lib/index.js:141:7)
at Module.load (node:internal/modules/cjs/loader:1091:32)
at Function.Module._load (node:internal/modules/cjs/loader:938:12)
at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:83:12)
at node:internal/main/run_main_module:23:47
Node.js v20.9.0
However, when using the .swcrc file with SWCRC=true node -r @swc-node/register ./index.ts, the line number (2) in the first line of the stack trace is incorrect:
$ SWCRC=true node -r @swc-node/register ./index.ts
/swc-node/test/index.ts:2
throw new Error();
^
Error:
at Object.<anonymous> (/swc-node/test/index.ts:2:7)
at Module._compile (node:internal/modules/cjs/loader:1241:14)
at Module._compile (/swc-node/node_modules/.pnpm/pirates@4.0.5/node_modules/pirates/lib/index.js:136:24)
at Module._extensions..js (node:internal/modules/cjs/loader:1295:10)
at Object.newLoader [as .ts] (/swc-node/node_modules/.pnpm/pirates@4.0.5/node_modules/pirates/lib/index.js:141:7)
at Module.load (node:internal/modules/cjs/loader:1091:32)
at Function.Module._load (node:internal/modules/cjs/loader:938:12)
at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:83:12)
at node:internal/main/run_main_module:23:47
Node.js v20.9.0
Although the sourceMaps config option can take the values true | "inline" | false, the value in the .swcrc file is ignored and it is always being being set as "inline" in the options passed to SWC. This causes sourcemaps to not be handled correctly by source-map-support, since inline sourcemaps support requires setting the hookRequire option.