Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mbrubeck/robinson
A toy web rendering engine
https://github.com/mbrubeck/robinson
Last synced: 3 days ago
JSON representation
A toy web rendering engine
- Host: GitHub
- URL: https://github.com/mbrubeck/robinson
- Owner: mbrubeck
- License: mit
- Created: 2014-07-03T21:43:14.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-07-16T23:41:43.000Z (6 months ago)
- Last Synced: 2025-01-02T19:03:12.791Z (10 days ago)
- Language: Rust
- Homepage: http://limpet.net/mbrubeck/2014/08/08/toy-layout-engine-1.html
- Size: 221 KB
- Stars: 1,569
- Watchers: 35
- Forks: 133
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rust-zh - Robinson - 玩具Web渲染引擎
- awesome-web-browsers - Robinson - a toy web browser implemented in rust from scratch
README
Robinson
========A toy web rendering engine written in the Rust language, by Matt Brubeck
([email protected]).I'm writing this code purely for educational purposes. My goal is to create an
incomplete but extremely simple engine as a way to learn more about basic
implementation techniques, *without* worrying about complications like:* Real-world usability
* Standards compliance
* Performance and efficiency
* InteroperabilityThese are all important goals, but there are other projects working on them.
By ignoring them completely, this project can focus on being as simple and
easy-to-understand as possible.Why create a simple—but useless—toy rendering engine? Mostly because I
personally want to learn how to do it. If I succeed, I also hope that other
people can learn from my code by reading or modifying it, or learn from my
experience as they set out to build their own toy browser engines.For more details see [Let's build a browser engine!][blog], a series of
how-to articles based on this project.[blog]: http://limpet.net/mbrubeck/2014/08/08/toy-layout-engine-1.html
Status
------Currently implemented:
* Parse a small subset of HTML and build a DOM tree.
* Parse a small subset of CSS.
* Perform selector matching to apply styles to elements.
* Basic block layout.Coming soon, I hope:
* Inline layout.
* Paint text and boxes.
* Load resources from network or filesystem.Instructions
------------1. [Install Rust 1.0 beta or newer.](http://www.rust-lang.org/install.html)
2. Clone the robinson source code from https://github.com/mbrubeck/robinson
3. Run `cargo build` to build robinson, and `cargo run` to run it.
To build and run with optimizations enabled, use `cargo build --release` and
`cargo run --release`.By default, robinson will load test.html and test.css from the `examples`
directory. You can use the `--html` and `--css` arguments to the robinson
executable to change the input files:./target/debug/robinson --html examples/test.html --css examples/test.css
The rendered page will be saved to a file named `output.png`. To change the
output filename, use the `-o` option. To switch to PDF output, use add
`--format pdf`.