aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/webglframebuffer.rs
diff options
context:
space:
mode:
authorJosh Matthews <josh@joshmatthews.net>2018-08-24 13:43:32 -0400
committerJosh Matthews <josh@joshmatthews.net>2018-09-10 16:31:29 -0400
commit1b08dd523274b1fb346b413cb986cd47409f3aa7 (patch)
treed0ce47aa92454438e98b8b1ac0f29906c0c994a2 /components/script/dom/webglframebuffer.rs
parentdf8e36aa783b9f6a50a5a16a39f7dcbd65ffde76 (diff)
downloadservo-1b08dd523274b1fb346b413cb986cd47409f3aa7.tar.gz
servo-1b08dd523274b1fb346b413cb986cd47409f3aa7.zip
webgl: Move framebuffer initialization logic to WebGL thread.
Diffstat (limited to 'components/script/dom/webglframebuffer.rs')
-rw-r--r--components/script/dom/webglframebuffer.rs22
1 files changed, 14 insertions, 8 deletions
diff --git a/components/script/dom/webglframebuffer.rs b/components/script/dom/webglframebuffer.rs
index 09a1cbea7cc..277b8b2fcba 100644
--- a/components/script/dom/webglframebuffer.rs
+++ b/components/script/dom/webglframebuffer.rs
@@ -34,10 +34,17 @@ enum WebGLFramebufferAttachment {
impl WebGLFramebufferAttachment {
fn needs_initialization(&self) -> bool {
match *self {
- WebGLFramebufferAttachment::Renderbuffer(_) => true,
+ WebGLFramebufferAttachment::Renderbuffer(ref r) => !r.is_initialized(),
WebGLFramebufferAttachment::Texture { .. } => false,
}
}
+
+ fn mark_initialized(&self) {
+ match *self {
+ WebGLFramebufferAttachment::Renderbuffer(ref r) => r.mark_initialized(),
+ WebGLFramebufferAttachment::Texture { .. } => ()
+ }
+ }
}
#[derive(Clone, JSTraceable, MallocSizeOf)]
@@ -239,15 +246,14 @@ impl WebGLFramebuffer {
];
let mut clear_bits = 0;
for &(attachment, bits) in &attachments {
- if attachment.borrow().as_ref().map_or(false, |att| att.needs_initialization()) {
- clear_bits |= bits;
+ if let Some(ref att) = *attachment.borrow() {
+ if att.needs_initialization() {
+ att.mark_initialized();
+ clear_bits |= bits;
+ }
}
}
- if clear_bits != 0 {
- self.upcast::<WebGLObject>().context().send_command(
- WebGLCommand::Clear(clear_bits)
- );
- }
+ self.upcast::<WebGLObject>().context().initialize_framebuffer(clear_bits);
self.is_initialized.set(true);
}