diff options
author | Anthony Ramine <n.oxyde@gmail.com> | 2018-06-22 11:30:10 +0200 |
---|---|---|
committer | Anthony Ramine <n.oxyde@gmail.com> | 2018-06-22 14:10:56 +0200 |
commit | 02b8766e7533d7318a3588e59bde78f3d639a89b (patch) | |
tree | c1e04726ab05293134290950115c882ef465464d /components/script/dom/webglrenderingcontext.rs | |
parent | 6a4bd8d3fa8c0c8fe4a85a04fe8405673dbd8513 (diff) | |
download | servo-02b8766e7533d7318a3588e59bde78f3d639a89b.tar.gz servo-02b8766e7533d7318a3588e59bde78f3d639a89b.zip |
Implement EXT_blend_minmax
Diffstat (limited to 'components/script/dom/webglrenderingcontext.rs')
-rw-r--r-- | components/script/dom/webglrenderingcontext.rs | 40 |
1 files changed, 20 insertions, 20 deletions
diff --git a/components/script/dom/webglrenderingcontext.rs b/components/script/dom/webglrenderingcontext.rs index d712b8cc58a..7079bbcc76b 100644 --- a/components/script/dom/webglrenderingcontext.rs +++ b/components/script/dom/webglrenderingcontext.rs @@ -12,6 +12,7 @@ use canvas_traits::webgl::{WebGLResult, WebGLSLVersion, WebGLVersion}; use canvas_traits::webgl::{WebVRCommand, webgl_channel}; use canvas_traits::webgl::WebGLError::*; use dom::bindings::cell::DomRefCell; +use dom::bindings::codegen::Bindings::EXTBlendMinmaxBinding::EXTBlendMinmaxConstants; use dom::bindings::codegen::Bindings::WebGLRenderingContextBinding::{self, WebGLContextAttributes}; use dom::bindings::codegen::Bindings::WebGLRenderingContextBinding::WebGLRenderingContextConstants as constants; use dom::bindings::codegen::Bindings::WebGLRenderingContextBinding::WebGLRenderingContextMethods; @@ -1193,6 +1194,21 @@ impl WebGLRenderingContext { _ => Err(WebGLError::InvalidEnum), } } + + fn validate_blend_mode(&self, mode: u32) -> WebGLResult<()> { + match mode { + constants::FUNC_ADD | + constants::FUNC_SUBTRACT | + constants::FUNC_REVERSE_SUBTRACT => { + Ok(()) + } + EXTBlendMinmaxConstants::MIN_EXT | + EXTBlendMinmaxConstants::MAX_EXT if self.extension_manager.is_blend_minmax_enabled() => { + Ok(()) + } + _ => Err(InvalidEnum), + } + } } impl Drop for WebGLRenderingContext { @@ -1547,30 +1563,14 @@ impl WebGLRenderingContextMethods for WebGLRenderingContext { // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.3 fn BlendEquation(&self, mode: u32) { - match mode { - constants::FUNC_ADD | - constants::FUNC_SUBTRACT | - constants::FUNC_REVERSE_SUBTRACT => { - self.send_command(WebGLCommand::BlendEquation(mode)) - } - _ => self.webgl_error(InvalidEnum), - } + handle_potential_webgl_error!(self, self.validate_blend_mode(mode), return); + self.send_command(WebGLCommand::BlendEquation(mode)) } // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.3 fn BlendEquationSeparate(&self, mode_rgb: u32, mode_alpha: u32) { - match mode_rgb { - constants::FUNC_ADD | - constants::FUNC_SUBTRACT | - constants::FUNC_REVERSE_SUBTRACT => {}, - _ => return self.webgl_error(InvalidEnum), - } - match mode_alpha { - constants::FUNC_ADD | - constants::FUNC_SUBTRACT | - constants::FUNC_REVERSE_SUBTRACT => {}, - _ => return self.webgl_error(InvalidEnum), - } + handle_potential_webgl_error!(self, self.validate_blend_mode(mode_rgb), return); + handle_potential_webgl_error!(self, self.validate_blend_mode(mode_alpha), return); self.send_command(WebGLCommand::BlendEquationSeparate(mode_rgb, mode_alpha)); } |