@@ -352,6 +352,105 @@ changes:
352
352
Register a module that exports [hooks][] that customize Node.js module
353
353
resolution and loading behavior. See [Customization hooks][].
354
354
355
+ ## ` module.stripTypeScriptTypes(code[, options])`
356
+
357
+ <!-- YAML
358
+ added: REPLACEME
359
+ -->
360
+
361
+ > Stability: 1.0 - Early development
362
+
363
+ * ` code ` {string} The code to strip type annotations from.
364
+ * ` options` {Object}
365
+ * ` mode` {string} **Default:** ` ' strip' ` . Possible values are:
366
+ * ` ' strip' ` Only strip type annotations without performing the transformation of TypeScript features.
367
+ * ` ' transform' ` Strip type annotations and transform TypeScript features to JavaScript.
368
+ * ` sourceMap` {boolean} **Default:** ` false` . Only when ` mode` is ` ' transform' ` , if ` true` , a source map
369
+ will be generated for the transformed code.
370
+ * ` sourceUrl` {string} Specifies the source url used in the source map.
371
+ * Returns: {string} The code with type annotations stripped.
372
+ ` module .stripTypeScriptTypes ()` removes type annotations from TypeScript code. It
373
+ can be used to strip type annotations from TypeScript code before running it
374
+ with ` vm.runInContext()` or ` vm.compileFunction()` .
375
+ By default, it will throw an error if the code contains TypeScript features
376
+ that require transformation such as ` Enums` ,
377
+ see [type-stripping][] for more information.
378
+ When mode is ` ' transform' ` , it also transforms TypeScript features to JavaScript,
379
+ see [transform TypeScript features][] for more information.
380
+ When mode is ` ' strip' ` , source maps are not generated, because locations are preserved.
381
+ If ` sourceMap` is provided, when mode is ` ' strip' ` , an error will be thrown.
382
+
383
+ _WARNING_: The output of this function should not be considered stable across Node.js versions,
384
+ due to changes in the TypeScript parser.
385
+
386
+ ` ` ` mjs
387
+ import { stripTypeScriptTypes } from ' node:module' ;
388
+ const code = ' const a: number = 1;' ;
389
+ const strippedCode = stripTypeScriptTypes (code);
390
+ console .log (strippedCode);
391
+ // Prints: const a = 1;
392
+ ` ` `
393
+
394
+ ` ` ` cjs
395
+ const { stripTypeScriptTypes } = require (' node:module' );
396
+ const code = ' const a: number = 1;' ;
397
+ const strippedCode = stripTypeScriptTypes (code);
398
+ console .log (strippedCode);
399
+ // Prints: const a = 1;
400
+ ` ` `
401
+
402
+ If ` sourceUrl` is provided, it will be used appended as a comment at the end of the output:
403
+
404
+ ` ` ` mjs
405
+ import { stripTypeScriptTypes } from ' node:module' ;
406
+ const code = ' const a: number = 1;' ;
407
+ const strippedCode = stripTypeScriptTypes (code, { mode: ' strip' , sourceUrl: ' source.ts' });
408
+ console .log (strippedCode);
409
+ // Prints: const a = 1\n\n//# sourceURL=source.ts;
410
+ ` ` `
411
+
412
+ ` ` ` cjs
413
+ const { stripTypeScriptTypes } = require (' node:module' );
414
+ const code = ' const a: number = 1;' ;
415
+ const strippedCode = stripTypeScriptTypes (code, { mode: ' strip' , sourceUrl: ' source.ts' });
416
+ console .log (strippedCode);
417
+ // Prints: const a = 1\n\n//# sourceURL=source.ts;
418
+ ` ` `
419
+
420
+ When ` mode` is ` ' transform' ` , the code is transformed to JavaScript:
421
+
422
+ ` ` ` mjs
423
+ import { stripTypeScriptTypes } from ' node:module' ;
424
+ const code = `
425
+ namespace MathUtil {
426
+ export const add = (a: number, b: number) => a + b;
427
+ }` ;
428
+ const strippedCode = stripTypeScriptTypes (code, { mode: ' transform' , sourceMap: true });
429
+ console .log (strippedCode);
430
+ // Prints:
431
+ // var MathUtil;
432
+ // (function(MathUtil) {
433
+ // MathUtil.add = (a, b)=>a + b;
434
+ // })(MathUtil || (MathUtil = {}));
435
+ // # sourceMappingURL=data:application/json;base64, ...
436
+ ` ` `
437
+
438
+ ` ` ` cjs
439
+ const { stripTypeScriptTypes } = require (' node:module' );
440
+ const code = `
441
+ namespace MathUtil {
442
+ export const add = (a: number, b: number) => a + b;
443
+ }` ;
444
+ const strippedCode = stripTypeScriptTypes (code, { mode: ' transform' , sourceMap: true });
445
+ console .log (strippedCode);
446
+ // Prints:
447
+ // var MathUtil;
448
+ // (function(MathUtil) {
449
+ // MathUtil.add = (a, b)=>a + b;
450
+ // })(MathUtil || (MathUtil = {}));
451
+ // # sourceMappingURL=data:application/json;base64, ...
452
+ ` ` `
453
+
355
454
### ` module .syncBuiltinESMExports ()`
356
455
357
456
<!-- YAML
@@ -1333,3 +1432,5 @@ returned object contains the following keys:
1333
1432
[realm]: https://tc39.es/ecma262/#realm
1334
1433
[source map include directives]: https://sourcemaps.info/spec.html#h.lmz475t4mvbx
1335
1434
[transferrable objects]: worker_threads.md#portpostmessagevalue-transferlist
1435
+ [transform TypeScript features]: typescript.md#typescript-features
1436
+ [type-stripping]: typescript.md#type-stripping
0 commit comments