1214 releases (6 major breaking)

6.0.1 Dec 4, 2024
5.0.1 Nov 25, 2024
4.0.0 Nov 1, 2024
3.0.0 Oct 29, 2024
0.16.1 Jul 31, 2021

#1227 in Web programming

Download history 4713/week @ 2024-08-25 4882/week @ 2024-09-01 5476/week @ 2024-09-08 5034/week @ 2024-09-15 5440/week @ 2024-09-22 6674/week @ 2024-09-29 5606/week @ 2024-10-06 5115/week @ 2024-10-13 6368/week @ 2024-10-20 5587/week @ 2024-10-27 6510/week @ 2024-11-03 4818/week @ 2024-11-10 4435/week @ 2024-11-17 5353/week @ 2024-11-24 7030/week @ 2024-12-01 8457/week @ 2024-12-08

25,702 downloads per month
Used in 76 crates (18 directly)

Apache-2.0

9MB
233K SLoC

Minifier

EcmaScript minifier for the SWC project. This is basically a port of terser.

Note

Currently name mangler is very simple. To focus on creating a MVP, I (kdy1) will use simple logic for name mangler and implement the content-aware name mangler after publishing first non-beta version.

Debugging tips

If the output contains variables named e, t, n it typically means the original library is published in a minified form and the input contains eval. The current swc name mangler does not do anything if eval is used.

Profiling the minifier

From mac os x, run

./scripts/instrument/all.sh path/to/input/dir

Contributing

Testing

Please prefer execution tests over unit tests. Execution tests are more useful because there's no chance of human error while reviewing.

Execution tests

You can add a test to ./tests/exec.rs

You can run ./scripts/exec.sh from ./crates/swc_ecma_minifier to run execution tests of SWC minifier. exec.sh runs the cargo test with --features debug, and it makes the cargo test print lots of debug logging. You can search for "change", and you can know the code responsible the optimization. The minifier has report_change! macro, and it prints the location of the relevant code.

Fixture tests

You can add a test to ./tests/fixture. You can select any directory, but please prefer to use the issues directory. You can run ./scripts/test.sh from ./crates/swc_ecma_minifier to run fixture tests. You can run it like ./scripts/test.sh foo to run test cases only with foo in the file path. If you want to get location of change, you can do ./scripts/test.sh foo --features debug.

Dependencies

~13–23MB
~329K SLoC