mirror of
https://github.com/servo/servo.git
synced 2025-08-05 05:30:08 +01:00
constellation: Make setting up the WebGL state fallible.
This fixes a regression caused by the glutin update. We now are creating EGL contexts in Linux Wayland, instead of X context, so the GLContextFactory assumption of one GL back-end per platform is broken. This just works around it, for now, but in general I think not relying on available WebGL state is a good thing, and we do that already for WebVR anyway.
This commit is contained in:
parent
3fc5bf87d3
commit
21df4014db
8 changed files with 48 additions and 31 deletions
|
@ -224,8 +224,12 @@ impl WebGLRenderingContext {
|
|||
return Err("WebGL context creation error forced by pref `webgl.testing.context_creation_error`".into());
|
||||
}
|
||||
|
||||
let webgl_chan = match window.webgl_chan() {
|
||||
Some(chan) => chan,
|
||||
None => return Err("WebGL initialization failed early on".into()),
|
||||
};
|
||||
|
||||
let (sender, receiver) = webgl_channel().unwrap();
|
||||
let webgl_chan = window.webgl_chan();
|
||||
webgl_chan.send(WebGLMsg::CreateContext(webgl_version, size, attrs, sender))
|
||||
.unwrap();
|
||||
let result = receiver.recv().unwrap();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue