diff options
author | bors-servo <lbergstrom+bors@mozilla.com> | 2018-06-22 08:11:33 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-22 08:11:33 -0400 |
commit | 728ebcc932e33b36f0fb76e6e794ef1c1dc15e32 (patch) | |
tree | c1e04726ab05293134290950115c882ef465464d /components/script/dom/webgl_extensions/extensions.rs | |
parent | 6a4bd8d3fa8c0c8fe4a85a04fe8405673dbd8513 (diff) | |
parent | 02b8766e7533d7318a3588e59bde78f3d639a89b (diff) | |
download | servo-728ebcc932e33b36f0fb76e6e794ef1c1dc15e32.tar.gz servo-728ebcc932e33b36f0fb76e6e794ef1c1dc15e32.zip |
Auto merge of #21080 - servo:webgl, r=emilio
Implement EXT_blend_minmax
<!-- Reviewable:start -->
This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/21080)
<!-- Reviewable:end -->
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 |