# parcel-css A WIP CSS parser, transformer, and minifier written in Rust. ## Features - **Extremely fast** – Parsing and minifying large files is completed in milliseconds, often with significantly smaller output than other tools. See benchmarks below. - **Typed property values** – many other CSS parsers treat property values as an untyped series of tokens. This means that each transformer that wants to do something with these values must interpret them itself, leading to duplicate work and inconsistencies. `parcel-css` parses all values using the grammar from the CSS specification, and exposes a specific value type for each property. - **Minification** – One of the main purposes of `parcel-css` is to minify CSS to make it smaller. This includes many optimizations including: - Combining longhand properties into shorthands where possible. - Merging adjacent rules with the same selectors or declarations when it is safe to do so. - Combining CSS transforms into a single matrix or visa versa when smaller. - Removing vendor prefixes that are not needed, based on the provided browser targets. - Reducing `calc()` expressions where possible. - Converting colors to shorter hex notation where possible. - Minifying gradients. - Normalizing property value order. - Removing default property sub-values which will be inferred by browsers. - Many micro-optimizations, e.g. converting to shorter units, removing unnecessary quotation marks, etc. - **Vendor prefixing** – `parcel-css` accepts a list of browser targets, and automatically adds (and removes) vendor prefixes. - **Syntax lowering** – `parcel-css` parses modern CSS syntax, and generates more compatible output where needed, based on browser targets. - CSS Level 4 Color syntax - Space separated components in `rgb` and `hsl` functions - Hex with alpha syntax - `hwb()` color syntax - Percent syntax for opacity - Double position gradient stops (e.g. `red 40% 80%`) - `clamp()` function - Alignment shorthands (e.g. `place-items`) - Two-value `overflow` shorthand - Media query range syntax (e.g. `@media (width <= 100px)` or `@media (100px < width < 500px)`) - **CSS modules** – TODO ## Benchmarks ``` $ node bench.js bootstrap-4.css cssnano: 542.956ms 159636 bytes esbuild: 17.411ms 160332 bytes parcel-css: 4.961ms 143662 bytes $ node bench.js animate.css cssnano: 283.105ms 71723 bytes esbuild: 11.858ms 72183 bytes parcel-css: 2.039ms 23707 bytes $ node bench.js tailwind.css cssnano: 2.198s 1925626 bytes esbuild: 107.668ms 1961642 bytes parcel-css: 42.568ms 1905068 bytes ```