aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/webglrenderingcontext.rs
diff options
context:
space:
mode:
authorAnthony Ramine <n.oxyde@gmail.com>2018-06-22 11:30:10 +0200
committerAnthony Ramine <n.oxyde@gmail.com>2018-06-22 14:10:56 +0200
commit02b8766e7533d7318a3588e59bde78f3d639a89b (patch)
treec1e04726ab05293134290950115c882ef465464d /components/script/dom/webglrenderingcontext.rs
parent6a4bd8d3fa8c0c8fe4a85a04fe8405673dbd8513 (diff)
downloadservo-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.rs40
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));
}