Transpile JavaScript/TypeScript code with swc.
npm install @rollup/plugin-swc[npm]: https://img.shields.io/npm/v/@rollup/plugin-swc
[npm-url]: https://www.npmjs.com/package/@rollup/plugin-swc
[size]: https://packagephobia.now.sh/badge?p=@rollup/plugin-swc
[size-url]: https://packagephobia.now.sh/result?p=@rollup/plugin-swc
[![npm][npm]][npm-url]
[![size][size]][size-url]

š£ A Rollup plugin to transpile TypeScript/JavaScript with the speedy-web-compiler (swc).
The plugin makes it possible to avoid the usage of @rollup/plugin-babel and @rollup/plugin-typescript.
It is also blazingly fast š„ (between 20 - 70 times faster than Babel depending on how many cpu cores are used).
This plugin requires an LTS Node version (v14.0.0+) and Rollup v3.0+.
Using npm:
``console`
npm install @swc/core @rollup/plugin-swc --save-dev
Create a rollup.config.js configuration file and import the plugin:
`typescript
import swc from '@rollup/plugin-swc';
export default {
input: 'src/index.js',
output: {
dir: 'output',
format: 'cjs'
},
plugins: [swc()]
};
`
Then call rollup either via the CLI or the API.
The plugin accepts an object as input parameter to modify the default behaviour.
- Type: Options
- Default: undefined
`typescript
import type { Options as SWCOptions } from '@swc/core';
declare type Options = {
swc?: SWCOptions;
};
`
- Type: String | Array[...String]null
- Default:
A picomatch pattern,
or array of patterns, which specifies the files in the build the plugin should _ignore_. By default no files are ignored.
- Type: String | Array[...String]null`
- Default:
A picomatch pattern,
or array of patterns, which specifies the files in the build the plugin should operate on. By default all files are targeted.
Alternative transpiler/transformer, which are also officially offered, are Babel and Sucrase.
Both Babel and Sucrase are written in JavaScript, whereas the core of SWC is written in Rust. In addition, Sucrase transforms code to ES6+, whereas babel and SWC also support ES3 upwards.