gecko-dev/gfx/wr
Nicolas Silva b95d39dd98 Bug 1612440 - Send some messages directly to the scene builder thread. r=gw
This change allows the api to talk directly to the scene builder thread. This avoids unpredictable and sometimes large latency caused by scene builder requests sitting in a busy render backend's event loop.

Differential Revision: https://phabricator.services.mozilla.com/D74055
2020-09-09 17:07:01 +00:00
..
ci-scripts
debugger
direct-composition Bug 1662827 - Move the api senders to the webrender crate. r=gw 2020-09-09 12:45:00 +00:00
example-compositor Bug 1656820 - Remove content_size from scene pipeline. r=nical 2020-08-03 20:57:30 +00:00
examples Bug 1662827 - Move the api senders to the webrender crate. r=gw 2020-09-09 12:45:00 +00:00
glsl-to-cxx
peek-poke Bug 1656236 - Update to euclid 0.22. r=kvark 2020-08-18 22:09:27 +00:00
swgl Bug 1661427 - Allow SWGL SwCompositor to split up compositing work between SwComposite and render threads. r=mattwoodrow 2020-08-31 18:26:20 +00:00
tileview Bug 1662827 - Move the api senders to the webrender crate. r=gw 2020-09-09 12:45:00 +00:00
webrender Bug 1612440 - Send some messages directly to the scene builder thread. r=gw 2020-09-09 17:07:01 +00:00
webrender_api Bug 1662827 - Move the api senders to the webrender crate. r=gw 2020-09-09 12:45:00 +00:00
webrender_build
wr_malloc_size_of Bug 1656236 - Update to euclid 0.22. r=kvark 2020-08-18 22:09:27 +00:00
wrench Bug 1662827 - Move the api senders to the webrender crate. r=gw 2020-09-09 12:45:00 +00:00
.gitignore
.taskcluster.yml
Cargo.lock Bug 1662827 - Move the api senders to the webrender crate. r=gw 2020-09-09 12:45:00 +00:00
Cargo.toml
LICENSE
README.md
rustfmt.toml
servo-tidy.toml

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.