gecko-dev/gfx/wr
Martin Robinson 31ff1d38e5 Bug 1884403 - WebRender should only depend on glean when building for Gecko r=jrmuizel
Make glean an optional dependency that is only enabled when building
WebRender for Gecko.

Differential Revision: https://phabricator.services.mozilla.com/D204059
2024-03-09 15:30:27 +00:00
..
ci-scripts Bug 1854162 - Use taskcluster-built python for webrender task r=glandium,taskgraph-reviewers,ahal 2023-10-05 06:30:49 +00:00
example-compositor
examples
fog
glsl-to-cxx
peek-poke Bug 1882070 - Make peek-poke generate unnamed constants. r=gfx-reviewers,gw 2024-02-28 08:16:54 +00:00
swgl Bug 1872776 - Avoid multiplying by NaN in draw_perspective. r=gfx-reviewers,ahale 2024-01-17 07:22:29 +00:00
webrender Bug 1884403 - WebRender should only depend on glean when building for Gecko r=jrmuizel 2024-03-09 15:30:27 +00:00
webrender_api Bug 1883572 - Add enough support for iOS to webrender so that it builds. r=gfx-reviewers,gw 2024-03-05 21:04:12 +00:00
webrender_build Bug 1882414 - Remove cs_clip_image shader and related code r=gfx-reviewers,lsalzman 2024-02-28 01:49:28 +00:00
wr_glyph_rasterizer Bug 1883572 - Add enough support for iOS to webrender so that it builds. r=gfx-reviewers,gw 2024-03-05 21:04:12 +00:00
wr_malloc_size_of
wrench Bug 1873677 - GeckoView Android API 34 (Android 14) r=jgraham,jonalmeida 2024-01-16 08:21:36 +00:00
.gitignore
.taskcluster.yml
Cargo.lock Bug 1882615 - Vendor Glean SDK to v58.0.0 r=perry.mcmanis,supply-chain-reviewers,mach-reviewers 2024-03-01 15:13:21 +00:00
Cargo.toml
LICENSE
README.md
rustfmt.toml
servo-tidy.toml Bug 1855870 - Upgrade webrender to bitflags 2. r=gfx-reviewers,gw 2023-09-29 08:20:59 +00:00

WebRender

Version

WebRender is a GPU-based 2D rendering engine written in Rust. Firefox, the research web browser Servo, and other GUI frameworks draw with it. It currently uses the OpenGL API internally.

Note that the canonical home for this code is in gfx/wr folder of the mozilla-central repository at https://hg.mozilla.org/mozilla-central. The Github repository at https://github.com/servo/webrender should be considered a downstream mirror, although it contains additional metadata (such as Github wiki pages) that do not exist in mozilla-central. Pull requests against the Github repository are still being accepted, although once reviewed, they will be landed on mozilla-central first and then mirrored back. If you are familiar with the mozilla-central contribution workflow, filing bugs in Bugzilla and submitting patches there would be preferred.

Update as a Dependency

After updating shaders in WebRender, go to servo and:

  • Go to the servo directory and do ./mach update-cargo -p webrender
  • Create a pull request to servo

Use WebRender with Servo

To use a local copy of WebRender with servo, go to your servo build directory and:

  • Edit Cargo.toml
  • Add at the end of the file:
[patch."https://github.com/servo/webrender"]
"webrender" = { path = "<path>/webrender" }
"webrender_api" = { path = "<path>/webrender_api" }

where <path> is the path to your local copy of WebRender.

  • Build as normal

Documentation

The Wiki has a few pages describing the internals and conventions of WebRender.

Testing

Tests run using OSMesa to get consistent rendering across platforms.

Still there may be differences depending on font libraries on your system, for example.

See this gist for how to make the text tests useful in Fedora, for example.