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/webgl_extensions/extensions.rs | |
parent | 6a4bd8d3fa8c0c8fe4a85a04fe8405673dbd8513 (diff) | |
download | servo-02b8766e7533d7318a3588e59bde78f3d639a89b.tar.gz servo-02b8766e7533d7318a3588e59bde78f3d639a89b.zip |
Implement EXT_blend_minmax
Diffstat (limited to 'components/script/dom/webgl_extensions/extensions.rs')
-rw-r--r-- | components/script/dom/webgl_extensions/extensions.rs | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/components/script/dom/webgl_extensions/extensions.rs b/components/script/dom/webgl_extensions/extensions.rs index ca81e2d10e8..c5413ea1eb2 100644 --- a/components/script/dom/webgl_extensions/extensions.rs +++ b/components/script/dom/webgl_extensions/extensions.rs @@ -70,6 +70,8 @@ struct WebGLExtensionFeatures { disabled_get_tex_parameter_names: FnvHashSet<GLenum>, /// WebGL OES_element_index_uint extension. element_index_uint_enabled: bool, + /// WebGL EXT_blend_minmax extension. + blend_minmax_enabled: bool, } impl WebGLExtensionFeatures { @@ -79,6 +81,7 @@ impl WebGLExtensionFeatures { disabled_get_parameter_names, disabled_get_tex_parameter_names, element_index_uint_enabled, + blend_minmax_enabled, ) = match webgl_version { WebGLVersion::WebGL1 => { ( @@ -86,10 +89,11 @@ impl WebGLExtensionFeatures { DEFAULT_DISABLED_GET_PARAMETER_NAMES_WEBGL1.iter().cloned().collect(), DEFAULT_DISABLED_GET_TEX_PARAMETER_NAMES_WEBGL1.iter().cloned().collect(), false, + false, ) }, WebGLVersion::WebGL2 => { - (Default::default(), Default::default(), Default::default(), true) + (Default::default(), Default::default(), Default::default(), true, true) } }; Self { @@ -102,6 +106,7 @@ impl WebGLExtensionFeatures { disabled_get_parameter_names, disabled_get_tex_parameter_names, element_index_uint_enabled, + blend_minmax_enabled, } } } @@ -265,6 +270,7 @@ impl WebGLExtensions { } fn register_all_extensions(&self) { + self.register::<ext::extblendminmax::EXTBlendMinmax>(); self.register::<ext::extshadertexturelod::EXTShaderTextureLod>(); self.register::<ext::exttexturefilteranisotropic::EXTTextureFilterAnisotropic>(); self.register::<ext::oeselementindexuint::OESElementIndexUint>(); @@ -283,6 +289,14 @@ impl WebGLExtensions { pub fn is_element_index_uint_enabled(&self) -> bool { self.features.borrow().element_index_uint_enabled } + + pub fn enable_blend_minmax(&self) { + self.features.borrow_mut().blend_minmax_enabled = true; + } + + pub fn is_blend_minmax_enabled(&self) -> bool { + self.features.borrow().blend_minmax_enabled + } } // Helper structs |