diff options
author | Imanol Fernandez <mortimergoro@gmail.com> | 2017-10-27 17:06:53 +0200 |
---|---|---|
committer | Imanol Fernandez <mortimergoro@gmail.com> | 2017-10-31 21:38:39 +0100 |
commit | f2f5817f5630c0c7adce8269068bc1d58312137a (patch) | |
tree | e70de67b4101c7d323d7ab7757168e6eff5d1610 /components/script | |
parent | d21657a9e5cfdb858c1a99a246001ceac05bb982 (diff) | |
download | servo-f2f5817f5630c0c7adce8269068bc1d58312137a.tar.gz servo-f2f5817f5630c0c7adce8269068bc1d58312137a.zip |
Add support for filtering WebGL extensions based on WebGL version
Diffstat (limited to 'components/script')
12 files changed, 86 insertions, 24 deletions
diff --git a/components/script/dom/webgl_extensions/ext/mod.rs b/components/script/dom/webgl_extensions/ext/mod.rs index 38f642fb74b..1c3994fba40 100644 --- a/components/script/dom/webgl_extensions/ext/mod.rs +++ b/components/script/dom/webgl_extensions/ext/mod.rs @@ -3,7 +3,7 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ use dom::bindings::codegen::Bindings::WebGLRenderingContextBinding::WebGLRenderingContextConstants as constants; -use super::{ext_constants, WebGLExtension, WebGLExtensions}; +use super::{ext_constants, WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; pub mod oesstandardderivatives; pub mod oestexturefloat; diff --git a/components/script/dom/webgl_extensions/ext/oesstandardderivatives.rs b/components/script/dom/webgl_extensions/ext/oesstandardderivatives.rs index 6ede450e621..70de0f0dada 100644 --- a/components/script/dom/webgl_extensions/ext/oesstandardderivatives.rs +++ b/components/script/dom/webgl_extensions/ext/oesstandardderivatives.rs @@ -2,13 +2,14 @@ * 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/. */ +use canvas_traits::webgl::WebGLVersion; use dom::bindings::codegen::Bindings::OESStandardDerivativesBinding; use dom::bindings::codegen::Bindings::OESStandardDerivativesBinding::OESStandardDerivativesConstants; use dom::bindings::reflector::{DomObject, Reflector, reflect_dom_object}; use dom::bindings::root::DomRoot; use dom::webglrenderingcontext::WebGLRenderingContext; use dom_struct::dom_struct; -use super::{WebGLExtension, WebGLExtensions}; +use super::{WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; #[dom_struct] pub struct OESStandardDerivatives { @@ -31,6 +32,10 @@ impl WebGLExtension for OESStandardDerivatives { OESStandardDerivativesBinding::Wrap) } + fn spec() -> WebGLExtensionSpec { + WebGLExtensionSpec::Specific(WebGLVersion::WebGL1) + } + fn is_supported(ext: &WebGLExtensions) -> bool { if cfg!(any(target_os = "android", target_os = "ios")) { return ext.supports_any_gl_extension(&["GL_OES_standard_derivatives"]); diff --git a/components/script/dom/webgl_extensions/ext/oestexturefloat.rs b/components/script/dom/webgl_extensions/ext/oestexturefloat.rs index 53233905857..a7eb655947f 100644 --- a/components/script/dom/webgl_extensions/ext/oestexturefloat.rs +++ b/components/script/dom/webgl_extensions/ext/oestexturefloat.rs @@ -2,12 +2,13 @@ * 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/. */ +use canvas_traits::webgl::WebGLVersion; use dom::bindings::codegen::Bindings::OESTextureFloatBinding; use dom::bindings::reflector::{DomObject, Reflector, reflect_dom_object}; use dom::bindings::root::DomRoot; use dom::webglrenderingcontext::WebGLRenderingContext; use dom_struct::dom_struct; -use super::{constants as webgl, ext_constants as gl, WebGLExtension, WebGLExtensions}; +use super::{constants as webgl, ext_constants as gl, WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; #[dom_struct] pub struct OESTextureFloat { @@ -30,6 +31,10 @@ impl WebGLExtension for OESTextureFloat { OESTextureFloatBinding::Wrap) } + fn spec() -> WebGLExtensionSpec { + WebGLExtensionSpec::Specific(WebGLVersion::WebGL1) + } + fn is_supported(ext: &WebGLExtensions) -> bool { ext.supports_any_gl_extension(&["GL_OES_texture_float", "GL_ARB_texture_float", diff --git a/components/script/dom/webgl_extensions/ext/oestexturefloatlinear.rs b/components/script/dom/webgl_extensions/ext/oestexturefloatlinear.rs index ec7a02b34bb..7ce5cb3533a 100644 --- a/components/script/dom/webgl_extensions/ext/oestexturefloatlinear.rs +++ b/components/script/dom/webgl_extensions/ext/oestexturefloatlinear.rs @@ -7,7 +7,7 @@ use dom::bindings::reflector::{DomObject, Reflector, reflect_dom_object}; use dom::bindings::root::DomRoot; use dom::webglrenderingcontext::WebGLRenderingContext; use dom_struct::dom_struct; -use super::{constants as webgl, WebGLExtension, WebGLExtensions}; +use super::{constants as webgl, WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; #[dom_struct] pub struct OESTextureFloatLinear { @@ -30,6 +30,10 @@ impl WebGLExtension for OESTextureFloatLinear { OESTextureFloatLinearBinding::Wrap) } + fn spec() -> WebGLExtensionSpec { + WebGLExtensionSpec::All + } + fn is_supported(ext: &WebGLExtensions) -> bool { ext.supports_any_gl_extension(&["GL_OES_texture_float_linear", "GL_ARB_texture_float"]) diff --git a/components/script/dom/webgl_extensions/ext/oestexturehalffloat.rs b/components/script/dom/webgl_extensions/ext/oestexturehalffloat.rs index a9e32c7a8f5..df35ee66c5e 100644 --- a/components/script/dom/webgl_extensions/ext/oestexturehalffloat.rs +++ b/components/script/dom/webgl_extensions/ext/oestexturehalffloat.rs @@ -2,12 +2,13 @@ * 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/. */ +use canvas_traits::webgl::WebGLVersion; use dom::bindings::codegen::Bindings::OESTextureHalfFloatBinding::{self, OESTextureHalfFloatConstants}; use dom::bindings::reflector::{DomObject, Reflector, reflect_dom_object}; use dom::bindings::root::DomRoot; use dom::webglrenderingcontext::WebGLRenderingContext; use dom_struct::dom_struct; -use super::{constants as webgl, ext_constants as gl, WebGLExtension, WebGLExtensions}; +use super::{constants as webgl, ext_constants as gl, WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; #[dom_struct] pub struct OESTextureHalfFloat { @@ -30,6 +31,10 @@ impl WebGLExtension for OESTextureHalfFloat { OESTextureHalfFloatBinding::Wrap) } + fn spec() -> WebGLExtensionSpec { + WebGLExtensionSpec::Specific(WebGLVersion::WebGL1) + } + fn is_supported(ext: &WebGLExtensions) -> bool { ext.supports_any_gl_extension(&["GL_OES_texture_half_float", "GL_ARB_half_float_pixel", diff --git a/components/script/dom/webgl_extensions/ext/oestexturehalffloatlinear.rs b/components/script/dom/webgl_extensions/ext/oestexturehalffloatlinear.rs index a94702321eb..dad96a32f93 100644 --- a/components/script/dom/webgl_extensions/ext/oestexturehalffloatlinear.rs +++ b/components/script/dom/webgl_extensions/ext/oestexturehalffloatlinear.rs @@ -8,7 +8,7 @@ use dom::bindings::reflector::{DomObject, Reflector, reflect_dom_object}; use dom::bindings::root::DomRoot; use dom::webglrenderingcontext::WebGLRenderingContext; use dom_struct::dom_struct; -use super::{WebGLExtension, WebGLExtensions}; +use super::{WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; #[dom_struct] pub struct OESTextureHalfFloatLinear { @@ -31,6 +31,10 @@ impl WebGLExtension for OESTextureHalfFloatLinear { OESTextureHalfFloatLinearBinding::Wrap) } + fn spec() -> WebGLExtensionSpec { + WebGLExtensionSpec::All + } + fn is_supported(ext: &WebGLExtensions) -> bool { ext.supports_any_gl_extension(&["GL_OES_texture_float_linear", "GL_ARB_half_float_pixel", diff --git a/components/script/dom/webgl_extensions/ext/oesvertexarrayobject.rs b/components/script/dom/webgl_extensions/ext/oesvertexarrayobject.rs index 9ba3f4709ab..f80cd7385e7 100644 --- a/components/script/dom/webgl_extensions/ext/oesvertexarrayobject.rs +++ b/components/script/dom/webgl_extensions/ext/oesvertexarrayobject.rs @@ -2,7 +2,7 @@ * 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/. */ -use canvas_traits::webgl::{webgl_channel, WebGLCommand, WebGLError}; +use canvas_traits::webgl::{webgl_channel, WebGLCommand, WebGLError, WebGLVersion}; use dom::bindings::codegen::Bindings::OESVertexArrayObjectBinding::{self, OESVertexArrayObjectMethods}; use dom::bindings::codegen::Bindings::OESVertexArrayObjectBinding::OESVertexArrayObjectConstants; use dom::bindings::reflector::{DomObject, Reflector, reflect_dom_object}; @@ -14,7 +14,7 @@ use js::conversions::ToJSValConvertible; use js::jsapi::JSContext; use js::jsval::{JSVal, NullValue}; use std::iter; -use super::{WebGLExtension, WebGLExtensions}; +use super::{WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; #[dom_struct] pub struct OESVertexArrayObject { @@ -138,6 +138,10 @@ impl WebGLExtension for OESVertexArrayObject { OESVertexArrayObjectBinding::Wrap) } + fn spec() -> WebGLExtensionSpec { + WebGLExtensionSpec::Specific(WebGLVersion::WebGL1) + } + fn is_supported(ext: &WebGLExtensions) -> bool { ext.supports_any_gl_extension(&["GL_OES_vertex_array_object", "GL_ARB_vertex_array_object", diff --git a/components/script/dom/webgl_extensions/extension.rs b/components/script/dom/webgl_extensions/extension.rs index 6b4a2815347..1f8c770aaa3 100644 --- a/components/script/dom/webgl_extensions/extension.rs +++ b/components/script/dom/webgl_extensions/extension.rs @@ -2,6 +2,7 @@ * 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/. */ +use canvas_traits::webgl::WebGLVersion; use dom::bindings::reflector::DomObject; use dom::bindings::root::DomRoot; use dom::bindings::trace::JSTraceable; @@ -15,6 +16,9 @@ pub trait WebGLExtension: Sized where Self::Extension: DomObject + JSTraceable { /// Creates the DOM object of the WebGL extension. fn new(ctx: &WebGLRenderingContext) -> DomRoot<Self::Extension>; + /// Returns which WebGL spec is this extension written against. + fn spec() -> WebGLExtensionSpec; + /// Checks if the extension is supported. fn is_supported(ext: &WebGLExtensions) -> bool; @@ -24,3 +28,10 @@ pub trait WebGLExtension: Sized where Self::Extension: DomObject + JSTraceable { /// Name of the WebGL Extension. fn name() -> &'static str; } + +pub enum WebGLExtensionSpec { + /// Extensions written against both WebGL and WebGL2 specs. + All, + /// Extensions writen against a specific WebGL version spec. + Specific(WebGLVersion) +} diff --git a/components/script/dom/webgl_extensions/extensions.rs b/components/script/dom/webgl_extensions/extensions.rs index 85559612471..e599df7a25c 100644 --- a/components/script/dom/webgl_extensions/extensions.rs +++ b/components/script/dom/webgl_extensions/extensions.rs @@ -2,7 +2,7 @@ * 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/. */ -use canvas_traits::webgl::WebGLError; +use canvas_traits::webgl::{WebGLError, WebGLVersion}; use dom::bindings::cell::DomRefCell; use dom::bindings::codegen::Bindings::OESStandardDerivativesBinding::OESStandardDerivativesConstants; use dom::bindings::codegen::Bindings::OESTextureHalfFloatBinding::OESTextureHalfFloatConstants; @@ -20,13 +20,13 @@ use ref_filter_map::ref_filter_map; use std::cell::Ref; use std::collections::HashMap; use std::iter::FromIterator; -use super::{ext, WebGLExtension}; +use super::{ext, WebGLExtension, WebGLExtensionSpec}; use super::wrapper::{WebGLExtensionWrapper, TypedWebGLExtensionWrapper}; -// Data types that are implemented for texImage2D and texSubImage2D in WebGLRenderingContext +// Data types that are implemented for texImage2D and texSubImage2D in a WebGL 1.0 context // but must trigger a InvalidValue error until the related WebGL Extensions are enabled. // Example: https://www.khronos.org/registry/webgl/extensions/OES_texture_float/ -const DEFAULT_DISABLED_TEX_TYPES: [GLenum; 2] = [ +const DEFAULT_DISABLED_TEX_TYPES_WEBGL1: [GLenum; 2] = [ constants::FLOAT, OESTextureHalfFloatConstants::HALF_FLOAT_OES ]; @@ -37,10 +37,10 @@ const DEFAULT_NOT_FILTERABLE_TEX_TYPES: [GLenum; 2] = [ constants::FLOAT, OESTextureHalfFloatConstants::HALF_FLOAT_OES ]; -// Param names that are implemented for getParameter WebGL function +// Param names that are implemented for glGetParameter in a WebGL 1.0 context // but must trigger a InvalidEnum error until the related WebGL Extensions are enabled. // Example: https://www.khronos.org/registry/webgl/extensions/OES_standard_derivatives/ -const DEFAULT_DISABLED_GET_PARAMETER_NAMES: [GLenum; 1] = [ +const DEFAULT_DISABLED_GET_PARAMETER_NAMES_WEBGL1: [GLenum; 1] = [ OESStandardDerivativesConstants::FRAGMENT_SHADER_DERIVATIVE_HINT_OES ]; @@ -58,16 +58,25 @@ struct WebGLExtensionFeatures { disabled_get_parameter_names: FnvHashSet<GLenum>, } -impl Default for WebGLExtensionFeatures { - fn default() -> WebGLExtensionFeatures { - WebGLExtensionFeatures { +impl WebGLExtensionFeatures { + fn new(webgl_version: WebGLVersion) -> Self { + let (disabled_tex_types, disabled_get_parameter_names) = match webgl_version { + WebGLVersion::WebGL1 => { + (DEFAULT_DISABLED_TEX_TYPES_WEBGL1.iter().cloned().collect(), + DEFAULT_DISABLED_GET_PARAMETER_NAMES_WEBGL1.iter().cloned().collect()) + }, + WebGLVersion::WebGL2 => { + (Default::default(), Default::default()) + } + }; + Self { gl_extensions: Default::default(), - disabled_tex_types: DEFAULT_DISABLED_TEX_TYPES.iter().cloned().collect(), + disabled_tex_types, not_filterable_tex_types: DEFAULT_NOT_FILTERABLE_TEX_TYPES.iter().cloned().collect(), effective_tex_internal_formats: Default::default(), query_parameter_handlers: Default::default(), hint_targets: Default::default(), - disabled_get_parameter_names: DEFAULT_DISABLED_GET_PARAMETER_NAMES.iter().cloned().collect(), + disabled_get_parameter_names, } } } @@ -78,13 +87,15 @@ impl Default for WebGLExtensionFeatures { pub struct WebGLExtensions { extensions: DomRefCell<HashMap<String, Box<WebGLExtensionWrapper>>>, features: DomRefCell<WebGLExtensionFeatures>, + webgl_version: WebGLVersion, } impl WebGLExtensions { - pub fn new() -> WebGLExtensions { + pub fn new(webgl_version: WebGLVersion) -> WebGLExtensions { Self { extensions: DomRefCell::new(HashMap::new()), - features: DomRefCell::new(Default::default()) + features: DomRefCell::new(WebGLExtensionFeatures::new(webgl_version)), + webgl_version } } @@ -104,7 +115,14 @@ impl WebGLExtensions { pub fn get_suported_extensions(&self) -> Vec<&'static str> { self.extensions.borrow().iter() - .filter(|ref v| v.1.is_supported(&self)) + .filter(|ref v| { + if let WebGLExtensionSpec::Specific(version) = v.1.spec() { + if self.webgl_version != version { + return false; + } + } + v.1.is_supported(&self) + }) .map(|ref v| v.1.name()) .collect() } diff --git a/components/script/dom/webgl_extensions/mod.rs b/components/script/dom/webgl_extensions/mod.rs index c9a468274a3..3e90d4a7c8d 100644 --- a/components/script/dom/webgl_extensions/mod.rs +++ b/components/script/dom/webgl_extensions/mod.rs @@ -22,4 +22,5 @@ pub mod ext_constants { } pub use self::extension::WebGLExtension; +pub use self::extension::WebGLExtensionSpec; pub use self::extensions::WebGLExtensions; diff --git a/components/script/dom/webgl_extensions/wrapper.rs b/components/script/dom/webgl_extensions/wrapper.rs index 1c10e692f51..8af48a6d93e 100644 --- a/components/script/dom/webgl_extensions/wrapper.rs +++ b/components/script/dom/webgl_extensions/wrapper.rs @@ -9,7 +9,7 @@ use dom::bindings::trace::JSTraceable; use dom::webglrenderingcontext::WebGLRenderingContext; use malloc_size_of::MallocSizeOf; use std::any::Any; -use super::{WebGLExtension, WebGLExtensions}; +use super::{WebGLExtension, WebGLExtensions, WebGLExtensionSpec}; /// Trait used internally by WebGLExtensions to store and /// handle the different WebGL extensions in a common list. @@ -18,6 +18,7 @@ pub trait WebGLExtensionWrapper: JSTraceable + MallocSizeOf { ctx: &WebGLRenderingContext, ext: &WebGLExtensions) -> NonNullJSObjectPtr; + fn spec(&self) -> WebGLExtensionSpec; fn is_supported(&self, &WebGLExtensions) -> bool; fn is_enabled(&self) -> bool; fn enable(&self, ext: &WebGLExtensions); @@ -61,6 +62,10 @@ impl<T> WebGLExtensionWrapper for TypedWebGLExtensionWrapper<T> } } + fn spec(&self) -> WebGLExtensionSpec { + T::spec() + } + fn is_supported(&self, ext: &WebGLExtensions) -> bool { self.is_enabled() || T::is_supported(ext) } diff --git a/components/script/dom/webglrenderingcontext.rs b/components/script/dom/webglrenderingcontext.rs index 6a5cd9248db..aa5f942410f 100644 --- a/components/script/dom/webglrenderingcontext.rs +++ b/components/script/dom/webglrenderingcontext.rs @@ -252,7 +252,7 @@ impl WebGLRenderingContext { current_vertex_attrib_0: Cell::new((0f32, 0f32, 0f32, 1f32)), current_scissor: Cell::new((0, 0, size.width, size.height)), current_clear_color: Cell::new((0.0, 0.0, 0.0, 0.0)), - extension_manager: WebGLExtensions::new() + extension_manager: WebGLExtensions::new(webgl_version) } }) } |