Rust-based platform for the Web
Go to file
2022-08-05 05:13:40 +00:00
.cargo fix(es/visit): Disable serde by default (#5273) 2022-07-23 13:54:39 +00:00
.github feat(es/minifier): Remove duplicate var declarations (#5373) 2022-08-03 13:05:56 +09: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 chore: Publish crates 2022-08-05 05:13:40 +00:00
docs/adr feat(visit): Add path-aware variants (#5073) 2022-07-05 04:38:27 +00:00
node-swc feat(swc_core): Expand features to support node bindings (#5387) 2022-08-05 14:11:40 +09:00
packages/swc-helpers feat(es/modules): Support node interop (#5069) 2022-07-01 03:28:03 +00:00
scripts build(node): Include fallback binding as a dependency (#5322) 2022-07-28 03:10:08 +00:00
.gitattributes feat(html): Prepare processing system (#4358) 2022-04-22 20:20:47 +09:00
.gitignore chore: Publish v1.2.219 2022-07-27 14:45:02 +09: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 feat(wasm): Expose async facade interfaces (#5352) 2022-08-01 03:00:28 +00:00
.taplo.toml chore: Update toml formatting (#5368) 2022-08-03 03:07:28 +00:00
.yarnrc.yml chore: Publish v1.2.219 2022-07-27 14:45:02 +09:00
ARCHITECTURE.md feat(swc): Add IsModule (#2601) 2021-11-16 10:31:02 +00:00
Cargo.lock chore: Publish crates 2022-08-05 05:13:40 +00:00
Cargo.toml feat(swc_core): Introduce package (#5364) 2022-08-02 07:25:59 +00:00
CHANGELOG.md chore: Publish crates 2022-08-05 05:13:40 +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 chore: Publish v1.2.223 2022-08-03 19:25:28 +09: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 perf(es/minifier): Make name mangler faster (#5336) 2022-07-29 08:05:23 +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.