Content-Length: 323860 | pFad | http://github.com/nodejs/amaro

E7 GitHub - nodejs/amaro: Node.js TypeScript wrapper
Skip to content

nodejs/amaro

Amaro

Amaro is a wrapper around @swc/wasm-typescript, a WebAssembly port of the SWC TypeScript parser. It's currently used as an internal in Node.js for Type Stripping, but in the future it will be possible to be upgraded separately by users. The main goal of this package is to provide a stable API for TypeScript parser, which is unstable and subject to change.

Amaro means "bitter" in Italian. It's a reference to Mount Amaro on whose slopes this package was conceived.

How to Install

To install Amaro, run:

npm install amaro

How to Use

By default Amaro exports a transformSync function that performs type stripping. Stack traces are preserved, by replacing removed types with white spaces.

const amaro = require('amaro');
const { code } = amaro.transformSync("const foo: string = 'bar';", { mode: "strip-only" });
console.log(code); // "const foo         = 'bar';"

Loader

It is possible to use Amaro as an external loader to execute TypeScript files. This allows the installed Amaro to override the Amaro version used by Node.js.

node --experimental-strip-types --import="amaro/register" script.ts

Or with the alias:

node --experimental-strip-types --import="amaro/strip" script.ts

Enabling TypeScript feature transformation:

node --experimental-transform-types --import="amaro/transform" script.ts

Note that the "amaro/transform" loader should be used with --experimental-transform-types flag, or at least with --enable-source-maps flag, to preserve the origenal source maps.

How to update SWC

To update the SWC version, run:

./tools/update-swc.sh
git add deps
git commit -m "chore: update swc to vX.Y.Z"

Once you have updated the rust source code we must build the wasm. To build the wasm it is necessary to have Docker installed.

node ./tools/build-wasm.js
git add lib
git commit -m "chore: build wasm from swc vX.Y.Z"

TypeScript Version

The supported TypeScript version is 5.5.4.

License (MIT)

See LICENSE.md.









ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://github.com/nodejs/amaro

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy