/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ // https://www.khronos.org/registry/webgl/specs/latest/1.0/webgl.idl use dom::bindings::codegen::Bindings::WebGLBufferBinding; use dom::bindings::global::GlobalRef; use dom::bindings::js::Root; use dom::bindings::utils::reflect_dom_object; use dom::webglobject::WebGLObject; use canvas_traits::{CanvasMsg, CanvasWebGLMsg}; use std::sync::mpsc::{channel, Sender}; use std::cell::Cell; #[dom_struct] pub struct WebGLBuffer { webgl_object: WebGLObject, id: u32, is_deleted: Cell, renderer: Sender, } impl WebGLBuffer { fn new_inherited(renderer: Sender, id: u32) -> WebGLBuffer { WebGLBuffer { webgl_object: WebGLObject::new_inherited(), id: id, is_deleted: Cell::new(false), renderer: renderer, } } pub fn maybe_new(global: GlobalRef, renderer: Sender) -> Option> { let (sender, receiver) = channel(); renderer.send(CanvasMsg::WebGL(CanvasWebGLMsg::CreateBuffer(sender))).unwrap(); receiver.recv().unwrap() .map(|buffer_id| WebGLBuffer::new(global, renderer, *buffer_id)) } pub fn new(global: GlobalRef, renderer: Sender, id: u32) -> Root { reflect_dom_object(box WebGLBuffer::new_inherited(renderer, id), global, WebGLBufferBinding::Wrap) } } pub trait WebGLBufferHelpers { fn id(self) -> u32; fn bind(self, target: u32); fn delete(self); } impl<'a> WebGLBufferHelpers for &'a WebGLBuffer { fn id(self) -> u32 { self.id } fn bind(self, target: u32) { self.renderer.send(CanvasMsg::WebGL(CanvasWebGLMsg::BindBuffer(target, self.id))).unwrap(); } fn delete(self) { if !self.is_deleted.get() { self.is_deleted.set(true); self.renderer.send(CanvasMsg::WebGL(CanvasWebGLMsg::DeleteBuffer(self.id))).unwrap(); } } }