aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/webgl2renderingcontext.rs
diff options
context:
space:
mode:
authorAnthony Ramine <n.oxyde@gmail.com>2018-04-03 12:22:32 +0200
committerAnthony Ramine <n.oxyde@gmail.com>2018-04-03 12:22:32 +0200
commit866a523914029089f3a4ce17ec70b88f1307ecd4 (patch)
treec828b73fbc335c16ed7da54a0899758458efc93e /components/script/dom/webgl2renderingcontext.rs
parent088ebcb095cef24d85a4f5d1d7c525b198333fbf (diff)
downloadservo-866a523914029089f3a4ce17ec70b88f1307ecd4.tar.gz
servo-866a523914029089f3a4ce17ec70b88f1307ecd4.zip
Properly use Float32List and Int32List for WebGL uniform methods
Diffstat (limited to 'components/script/dom/webgl2renderingcontext.rs')
-rw-r--r--components/script/dom/webgl2renderingcontext.rs192
1 files changed, 68 insertions, 124 deletions
diff --git a/components/script/dom/webgl2renderingcontext.rs b/components/script/dom/webgl2renderingcontext.rs
index bce11fba2a5..1f6bc4f853a 100644
--- a/components/script/dom/webgl2renderingcontext.rs
+++ b/components/script/dom/webgl2renderingcontext.rs
@@ -9,7 +9,9 @@ use dom::bindings::codegen::Bindings::WebGL2RenderingContextBinding::WebGL2Rende
use dom::bindings::codegen::Bindings::WebGLRenderingContextBinding::WebGLContextAttributes;
use dom::bindings::codegen::Bindings::WebGLRenderingContextBinding::WebGLRenderingContextMethods;
use dom::bindings::codegen::UnionTypes::ArrayBufferViewOrArrayBuffer;
+use dom::bindings::codegen::UnionTypes::Float32ArrayOrUnrestrictedFloatSequence;
use dom::bindings::codegen::UnionTypes::ImageDataOrHTMLImageElementOrHTMLCanvasElementOrHTMLVideoElement;
+use dom::bindings::codegen::UnionTypes::Int32ArrayOrLongSequence;
use dom::bindings::error::{ErrorResult, Fallible};
use dom::bindings::reflector::{reflect_dom_object, Reflector};
use dom::bindings::root::{Dom, DomRoot, LayoutDom};
@@ -32,7 +34,7 @@ use euclid::Size2D;
use js::jsapi::{JSContext, JSObject};
use js::jsval::JSVal;
use js::rust::CustomAutoRooterGuard;
-use js::typedarray::{ArrayBufferView, Float32Array, Int32Array};
+use js::typedarray::ArrayBufferView;
use offscreen_gl_context::GLContextAttributes;
use script_layout_interface::HTMLCanvasDataSource;
use std::ptr::NonNull;
@@ -610,29 +612,23 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform1iv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Int32Array>) {
+ fn Uniform1iv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Int32ArrayOrLongSequence,
+ ) {
self.base.Uniform1iv(location, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform1iv_(&self, location: Option<&WebGLUniformLocation>, v: Vec<i32>) {
- self.base.Uniform1iv_(location, v);
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform1fv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Float32Array>) {
+ fn Uniform1fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
self.base.Uniform1fv(location, v);
}
- // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform1fv_(&self, location: Option<&WebGLUniformLocation>, v: Vec<f32>) {
- self.base.Uniform1fv_(location, v);
- }
-
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn Uniform2f(&self,
location: Option<&WebGLUniformLocation>,
@@ -641,15 +637,12 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform2fv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Float32Array>) {
- self.base.Uniform2fv(location, v)
- }
-
- // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform2fv_(&self, location: Option<&WebGLUniformLocation>, v: Vec<f32>) {
- self.base.Uniform2fv_(location, v);
+ fn Uniform2fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
+ self.base.Uniform2fv(location, v);
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
@@ -660,18 +653,15 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform2iv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Int32Array>) {
+ fn Uniform2iv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Int32ArrayOrLongSequence,
+ ) {
self.base.Uniform2iv(location, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform2iv_(&self, location: Option<&WebGLUniformLocation>, v: Vec<i32>) {
- self.base.Uniform2iv_(location, v);
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn Uniform3f(&self,
location: Option<&WebGLUniformLocation>,
x: f32, y: f32, z: f32) {
@@ -679,15 +669,12 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform3fv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Float32Array>) {
- self.base.Uniform3fv(location, v)
- }
-
- // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform3fv_(&self, location: Option<&WebGLUniformLocation>, v: Vec<f32>) {
- self.base.Uniform3fv_(location, v);
+ fn Uniform3fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
+ self.base.Uniform3fv(location, v);
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
@@ -698,42 +685,31 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform3iv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Int32Array>) {
+ fn Uniform3iv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Int32ArrayOrLongSequence,
+ ) {
self.base.Uniform3iv(location, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform3iv_(&self,
- location: Option<&WebGLUniformLocation>,
- v: Vec<i32>) {
- self.base.Uniform3iv_(location, v)
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn Uniform4i(&self,
location: Option<&WebGLUniformLocation>,
x: i32, y: i32, z: i32, w: i32) {
self.base.Uniform4i(location, x, y, z, w)
}
-
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform4iv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Int32Array>) {
+ fn Uniform4iv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Int32ArrayOrLongSequence,
+ ) {
self.base.Uniform4iv(location, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform4iv_(&self,
- location: Option<&WebGLUniformLocation>,
- v: Vec<i32>) {
- self.base.Uniform4iv_(location, v)
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn Uniform4f(&self,
location: Option<&WebGLUniformLocation>,
x: f32, y: f32, z: f32, w: f32) {
@@ -741,56 +717,44 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform4fv(&self,
- location: Option<&WebGLUniformLocation>,
- v: CustomAutoRooterGuard<Float32Array>) {
- self.base.Uniform4fv(location, v)
- }
-
- // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn Uniform4fv_(&self, location: Option<&WebGLUniformLocation>, v: Vec<f32>) {
- self.base.Uniform4fv_(location, v);
+ fn Uniform4fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
+ self.base.Uniform4fv(location, v);
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn UniformMatrix2fv(&self,
- location: Option<&WebGLUniformLocation>,
- transpose: bool,
- v: CustomAutoRooterGuard<Float32Array>) {
+ fn UniformMatrix2fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ transpose: bool,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
self.base.UniformMatrix2fv(location, transpose, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn UniformMatrix2fv_(&self, location: Option<&WebGLUniformLocation>, transpose: bool, value: Vec<f32>) {
- self.base.UniformMatrix2fv_(location, transpose, value);
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn UniformMatrix3fv(&self,
- location: Option<&WebGLUniformLocation>,
- transpose: bool,
- v: CustomAutoRooterGuard<Float32Array>) {
+ fn UniformMatrix3fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ transpose: bool,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
self.base.UniformMatrix3fv(location, transpose, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn UniformMatrix3fv_(&self, location: Option<&WebGLUniformLocation>, transpose: bool, value: Vec<f32>) {
- self.base.UniformMatrix3fv_(location, transpose, value);
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn UniformMatrix4fv(&self,
- location: Option<&WebGLUniformLocation>,
- transpose: bool,
- v: CustomAutoRooterGuard<Float32Array>) {
+ fn UniformMatrix4fv(
+ &self,
+ location: Option<&WebGLUniformLocation>,
+ transpose: bool,
+ v: Float32ArrayOrUnrestrictedFloatSequence,
+ ) {
self.base.UniformMatrix4fv(location, transpose, v)
}
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn UniformMatrix4fv_(&self, location: Option<&WebGLUniformLocation>, transpose: bool, value: Vec<f32>) {
- self.base.UniformMatrix4fv_(location, transpose, value);
- }
-
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.9
fn UseProgram(&self, program: Option<&WebGLProgram>) {
self.base.UseProgram(program)
@@ -807,61 +771,41 @@ impl WebGL2RenderingContextMethods for WebGL2RenderingContext {
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib1fv(&self, indx: u32, v: CustomAutoRooterGuard<Float32Array>) {
+ fn VertexAttrib1fv(&self, indx: u32, v: Float32ArrayOrUnrestrictedFloatSequence) {
self.base.VertexAttrib1fv(indx, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib1fv_(&self, indx: u32, v: Vec<f32>) {
- self.base.VertexAttrib1fv_(indx, v)
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn VertexAttrib2f(&self, indx: u32, x: f32, y: f32) {
self.base.VertexAttrib2f(indx, x, y)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib2fv(&self, indx: u32, v: CustomAutoRooterGuard<Float32Array>) {
+ fn VertexAttrib2fv(&self, indx: u32, v: Float32ArrayOrUnrestrictedFloatSequence) {
self.base.VertexAttrib2fv(indx, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib2fv_(&self, indx: u32, v: Vec<f32>) {
- self.base.VertexAttrib2fv_(indx, v)
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn VertexAttrib3f(&self, indx: u32, x: f32, y: f32, z: f32) {
self.base.VertexAttrib3f(indx, x, y, z)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib3fv(&self, indx: u32, v: CustomAutoRooterGuard<Float32Array>) {
+ fn VertexAttrib3fv(&self, indx: u32, v: Float32ArrayOrUnrestrictedFloatSequence) {
self.base.VertexAttrib3fv(indx, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib3fv_(&self, indx: u32, v: Vec<f32>) {
- self.base.VertexAttrib3fv_(indx, v)
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn VertexAttrib4f(&self, indx: u32, x: f32, y: f32, z: f32, w: f32) {
self.base.VertexAttrib4f(indx, x, y, z, w)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib4fv(&self, indx: u32, v: CustomAutoRooterGuard<Float32Array>) {
+ fn VertexAttrib4fv(&self, indx: u32, v: Float32ArrayOrUnrestrictedFloatSequence) {
self.base.VertexAttrib4fv(indx, v)
}
/// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
- fn VertexAttrib4fv_(&self, indx: u32, v: Vec<f32>) {
- self.base.VertexAttrib4fv_(indx, v)
- }
-
- /// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14.10
fn VertexAttribPointer(&self, attrib_id: u32, size: i32, data_type: u32,
normalized: bool, stride: i32, offset: i64) {
self.base.VertexAttribPointer(attrib_id, size, data_type, normalized, stride, offset)