web-app-template
lightningcss
web-app-template | lightningcss | |
---|---|---|
2 | 11 | |
5 | 5,979 | |
- | 2.2% | |
0.0 | 8.7 | |
over 1 year ago | 17 days ago | |
TypeScript | Rust | |
MIT License | Mozilla Public License 2.0 |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
web-app-template
-
Parcel CSS: A new CSS parser, compiler, and minifier
I have been using esbuild for a while, and I can say that it's looking like a huge improvement over webpack, snowpack, vite, etc.
I made a web app starter that uses esbuild to bundle a react-redux app [0] and my experience was very positive of the bundler.
[0] https://github.com/samhuk/tree-starter
-
I created an esbuild version of one of my existing webpack-using projects.
So I recently created a new version of that which uses esbuild instead, and I was able to get it up and running in <1 day (with 0 esbuild experience): https://github.com/samhuk/tree-starter
lightningcss
-
I'm fed up with it, so I'm writing a browser
Would you consider using some libraries in your project? There are lots of good ones in the Rust ecosystem, and many of them are not part of any existing browsers.
For example:
- https://github.com/servo/html5ever (HTML parsing - note: this is used in Servo)
- https://github.com/parcel-bundler/lightningcss (CSS parsing)
- https://github.com/DioxusLabs/taffy (web layout)
- https://github.com/pop-os/cosmic-text (text layout and rendering)
Obviously you should be free to work on whatever you like, but just as a benchmark on the scope of your project: I spent ~6 months implementing just the CSS Grid algorithm in Taffy last year. An entire browser from literal scratch is probably a 10 year project for one person.
- LightningCSS Benchmark
-
We're building a browser when it's supposed to be impossible
Libraries for a lot of this stuff exist (albeit in many cases not very mature yet):
- https://github.com/pop-os/cosmic-text does text layout (which Taffy explicitly considers out of scope)
- https://github.com/AccessKit/accesskit does accessibility
- https://github.com/servo/rust-cssparser does value-agnostic CSS parsing (it will parse the general syntax but leaves value parsing up to the user, meaning you can easily add support for whatever properties you what). Libraries like https://github.com/parcel-bundler/lightningcss implement parsing for the standard css properties.
- There are crates like https://github.com/BurntSushi/bstr and https://docs.rs/wtf8/latest/wtf8/ for working with non-unicode text
We are planning to add a C API to Taffy, but tbh I feel like C is not very good for this kind of modularised approach. You really want to be able to expose complex APIs with enforced type safety and this isn't possible with C.
-
Help with "returns a value referencing data owned by the current function"
Background: I encountered this problem using lightningcss.
-
On Using Rust in Parcel and Vitest
You can do it - that's actually exactly what my project is doing. I have a single repository with a Rust project, that builds the .wasm file (+ .d.ts + .js) using wasm-pack, and a Node.js project, that uses this .wasm file. There's no problem in packing that and exposing as a npm package. See parcel-bundler/lightningcss for a full blown example (it's not using wasm-pack but builds the Rust project directly).
- An fast CSS parser, transformer, bundler, and minifier written in Rust
- Parcel-Css - A CSS parser, transformer, and minifier written in Rust.
- ParcelCSS – A CSS parser, transformer, and minifier written in Rust
-
Parcel CSS: A new CSS parser, compiler, and minifier
Initial commit, 9 Oct 2021. That is pretty new.
What are some alternatives?
hound - Lightning fast code searching made easy
PostCSS - Transforming styles with JS plugins
capitalympics-api - API for capitalympics
swc - Rust-based platform for the Web
dropcss - An exceptionally fast, thorough and tiny unused-CSS cleaner
rust-cssparser - Rust implementation of CSS Syntax Level 3
MSEdgeExplainers - Home for explainer documents originated by the Microsoft Edge team
parse5 - HTML parsing/serialization toolset for Node.js. WHATWG HTML Living Standard (aka HTML5)-compliant.
purifycss - Remove unused CSS. Also works with single-page apps.
x-ray - The next web scraper. See through the <html> noise.
icss - Interoperable CSS — a standard for loadable, linkable CSS
excel-stream