Rust-based platform for the Web
Go to file
2022-07-17 12:48:21 +00:00
.cargo feat(node-swc): Add libc field in Linux platform packages (#4046) 2022-03-16 18:58:24 +09:00
.github test(es/plugin): Build plugins for e2e testing (#5210) 2022-07-15 02:10:13 +00:00
.husky fix(es): Remove wrong debug assertion (#4445) 2022-04-26 14:16:38 +00:00
.vscode chore(repo): Configure prettier (#4523) 2022-05-04 14:25:28 +00:00
crates feat(html/ast): Add raw to doctype (#5198) 2022-07-17 12:48:21 +00:00
docs/adr feat(visit): Add path-aware variants (#5073) 2022-07-05 04:38:27 +00:00
node-swc feat(node): Use wasm as a fallback (#5233) 2022-07-17 09:33:51 +00:00
packages/swc-helpers feat(es/modules): Support node interop (#5069) 2022-07-01 03:28:03 +00:00
scripts feat(visit): Add index to AstKind (#5138) 2022-07-09 10:15:12 +00:00
.gitattributes feat(html): Prepare processing system (#4358) 2022-04-22 20:20:47 +09:00
.gitignore build(node): Use explicit list for package files (#5229) 2022-07-17 03:18:22 +00:00
.gitmodules fix(html/parser): Fix bugs (#4502) 2022-05-03 02:49:06 +00:00
.kodiak.toml refactor(common): Cleanup & rustfmt (#3495) 2022-02-09 06:33:32 +00:00
.mocha.setup.js chore(repo): Configure prettier (#4523) 2022-05-04 14:25:28 +00:00
.mocharc.js chore(repo): Configure prettier (#4523) 2022-05-04 14:25:28 +00:00
.prettierignore test(es/minifier): Add snapshots for the mangler (#4823) 2022-05-27 07:32:23 +00:00
.prettierrc chore(repo): Configure prettier (#4523) 2022-05-04 14:25:28 +00:00
.prettierrc.json chore(repo): Configure prettier (#4523) 2022-05-04 14:25:28 +00:00
.rustfmt.toml refactor(common): Cleanup & rustfmt (#3495) 2022-02-09 06:33:32 +00:00
ARCHITECTURE.md feat(swc): Add IsModule (#2601) 2021-11-16 10:31:02 +00:00
Cargo.lock chore: Publish crates 2022-07-17 11:24:28 +00:00
Cargo.toml refactor(webpack-ast): Remove (#5026) 2022-06-22 04:25:27 +00:00
CHANGELOG.md chore: Publish crates 2022-07-17 11:24:28 +00:00
cliff.toml feat(node-swc): Add libc field in Linux platform packages (#4046) 2022-03-16 18:58:24 +09:00
clippy.toml feat(node-swc): Add libc field in Linux platform packages (#4046) 2022-03-16 18:58:24 +09:00
CONTRIBUTING.md doc(contributing): Add --features memory_cache to test steps (#5074) 2022-06-30 16:38:23 +00:00
cspell.json build(repo): Update rustc (#4667) 2022-05-15 09:03:54 +00:00
deny.toml feat(node-swc): Add libc field in Linux platform packages (#4046) 2022-03-16 18:58:24 +09:00
LICENSE chore(node): Publish v1.2.121 2021-12-19 14:14:12 +09:00
package.json feat(node): Use wasm as a fallback (#5233) 2022-07-17 09:33:51 +00:00
postinstall.js feat(node): Use wasm as a fallback (#5233) 2022-07-17 09:33:51 +00:00
README.md feat(visit): Add path-aware variants (#5073) 2022-07-05 04:38:27 +00:00
rust-toolchain chore(ci): Fix publish build on Windows (#4970) 2022-06-14 15:58:10 +00:00
tsconfig.json chore(repo): Configure prettier (#4523) 2022-05-04 14:25:28 +00:00
yarn.lock test(plugin): Setup e2e fixture testing for plugins (#5192) 2022-07-13 06:39:08 +00:00

babel

Make the web (development) faster.

npm Downloads undefined GitHub release (latest SemVer)

GitHub code size in bytes CI Status node-current (scoped)

Discord

SWC (stands for Speedy Web Compiler) is a super-fast TypeScript / JavaScript compiler written in Rust. It's a library for Rust and JavaScript at the same time. If you are using SWC from Rust, see rustdoc and for most users, your entry point for using the library will be parser.

Also, SWC tries to ensure that

If you select the latest version of each crates, it will work

for rust users. Without such guarantee, using SWC would be too hard as SWC is a large, modular project and typically you have to use many modules.


If you are using SWC from JavaScript, please refer to docs on the website.

Documentation

Check out the documentation in the website.

Features

Please see comparison with babel.

Performance

Please see benchmark results on the website.

Supporting swc

Backers on Open Collective Gold sponsors on Open Collective Silver sponsors on Open Collective Bronze sponsors on Open Collective

SWC is a community-driven project, and is maintained by a group of volunteers. If you'd like to help support the future of the project, please consider:

Contributing

See CONTRIBUTING.md. You may also find the architecture documentation useful (ARCHITECTURE.md).

License

SWC is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT for details.