/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* This Source Code Form is subject to the terms of the Mozilla Public * 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/. */ #ifndef WEBGL2CONTEXT_H_ #define WEBGL2CONTEXT_H_ #include "WebGLContext.h" namespace mozilla { class ErrorResult; class WebGLSampler; class WebGLSync; class WebGLTransformFeedback; class WebGLVertexArrayObject; namespace dom { class OwningUnsignedLongOrUint32ArrayOrBoolean; class OwningWebGLBufferOrLongLong; } // namespace dom class WebGL2Context : public WebGLContext { public: virtual ~WebGL2Context(); static bool IsSupported(); static WebGL2Context* Create(); virtual bool IsWebGL2() const override { return true; } // ------------------------------------------------------------------------- // IMPLEMENT nsWrapperCache virtual JSObject* WrapObject(JSContext* cx, JS::Handle givenProto) override; // ------------------------------------------------------------------------- // Buffer objects - WebGL2ContextBuffers.cpp void CopyBufferSubData(GLenum readTarget, GLenum writeTarget, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); private: template void GetBufferSubDataT(GLenum target, GLintptr offset, const BufferT& data); public: void GetBufferSubData(GLenum target, GLintptr offset, const dom::Nullable& maybeData); void GetBufferSubData(GLenum target, GLintptr offset, const dom::SharedArrayBuffer& data); void ReadPixels(GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, WebGLsizeiptr offset, ErrorResult& out_error); void ReadPixels(GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, const dom::Nullable& pixels, ErrorResult& out_error) { WebGLContext::ReadPixels(x, y, width, height, format, type, pixels, out_error); } // ------------------------------------------------------------------------- // Framebuffer objects - WebGL2ContextFramebuffers.cpp void BlitFramebuffer(GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); void FramebufferTextureLayer(GLenum target, GLenum attachment, WebGLTexture* texture, GLint level, GLint layer); virtual JS::Value GetFramebufferAttachmentParameter(JSContext* cx, GLenum target, GLenum attachment, GLenum pname, ErrorResult& rv) override; void InvalidateFramebuffer(GLenum target, const dom::Sequence& attachments, ErrorResult& rv); void InvalidateSubFramebuffer (GLenum target, const dom::Sequence& attachments, GLint x, GLint y, GLsizei width, GLsizei height, ErrorResult& rv); void ReadBuffer(GLenum mode); // ------------------------------------------------------------------------- // Renderbuffer objects - WebGL2ContextRenderbuffers.cpp void GetInternalformatParameter(JSContext*, GLenum target, GLenum internalformat, GLenum pname, JS::MutableHandleValue retval, ErrorResult& rv); void RenderbufferStorageMultisample(GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); // ------------------------------------------------------------------------- // Texture objects - WebGL2ContextTextures.cpp void TexStorage2D(GLenum target, GLsizei levels, GLenum internalFormat, GLsizei width, GLsizei height); void TexStorage3D(GLenum target, GLsizei levels, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth); void TexImage3D(GLenum target, GLint level, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum unpackFormat, GLenum unpackType, const dom::Nullable& pixels); void TexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLsizei width, GLsizei height, GLsizei depth, GLenum unpackFormat, GLenum unpackType, const dom::Nullable& pixels, ErrorResult& out_rv); void TexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLenum unpackFormat, GLenum unpackType, dom::ImageData* data, ErrorResult& out_rv); protected: void TexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLenum unpackFormat, GLenum unpackType, dom::Element* elem, ErrorResult* const out_rv); public: template inline void TexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLenum unpackFormat, GLenum unpackType, T& any, ErrorResult& out_rv) { TexSubImage3D(target, level, xOffset, yOffset, zOffset, unpackFormat, unpackType, &any, &out_rv); } void CopyTexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLint x, GLint y, GLsizei width, GLsizei height); void CompressedTexImage3D(GLenum target, GLint level, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, const dom::ArrayBufferView& data); void CompressedTexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLsizei width, GLsizei height, GLsizei depth, GLenum sizedUnpackFormat, const dom::ArrayBufferView& data); //////////////// // Texture PBOs void TexImage2D(GLenum texImageTarget, GLint level, GLenum internalFormat, GLsizei width, GLsizei height, GLint border, GLenum unpackFormat, GLenum unpackType, WebGLsizeiptr offset, ErrorResult&); void TexSubImage2D(GLenum texImageTarget, GLint level, GLint xOffset, GLint yOffset, GLsizei width, GLsizei height, GLenum unpackFormat, GLenum unpackType, WebGLsizeiptr offset, ErrorResult&); void TexImage3D(GLenum target, GLint level, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum unpackFormat, GLenum unpackType, WebGLsizeiptr offset); void TexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLsizei width, GLsizei height, GLsizei depth, GLenum unpackFormat, GLenum unpackType, WebGLsizeiptr offset, ErrorResult&); //////////////// // WebGL1 overloads void TexImage2D(GLenum texImageTarget, GLint level, GLenum internalFormat, GLsizei width, GLsizei height, GLint border, GLenum unpackFormat, GLenum unpackType, const dom::Nullable& pixels, ErrorResult& out_rv) { WebGLContext::TexImage2D(texImageTarget, level, internalFormat, width, height, border, unpackFormat, unpackType, pixels, out_rv); } template void TexImage2D(GLenum texImageTarget, GLint level, GLenum internalFormat, GLenum unpackFormat, GLenum unpackType, T& any, ErrorResult& out_rv) { WebGLContext::TexImage2D(texImageTarget, level, internalFormat, unpackFormat, unpackType, any, out_rv); } void TexSubImage2D(GLenum texImageTarget, GLint level, GLint xOffset, GLint yOffset, GLsizei width, GLsizei height, GLenum unpackFormat, GLenum unpackType, const dom::Nullable& pixels, ErrorResult& out_rv) { WebGLContext::TexSubImage2D(texImageTarget, level, xOffset, yOffset, width, height, unpackFormat, unpackType, pixels, out_rv); } template inline void TexSubImage2D(GLenum texImageTarget, GLint level, GLint xOffset, GLint yOffset, GLenum unpackFormat, GLenum unpackType, T& any, ErrorResult& out_rv) { WebGLContext::TexSubImage2D(texImageTarget, level, xOffset, yOffset, unpackFormat, unpackType, any, out_rv); } // ------------------------------------------------------------------------- // Programs and shaders - WebGL2ContextPrograms.cpp GLint GetFragDataLocation(WebGLProgram* program, const nsAString& name); // ------------------------------------------------------------------------- // Uniforms and attributes - WebGL2ContextUniforms.cpp void VertexAttribIPointer(GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); // GL 3.0 & ES 3.0 void Uniform1ui(WebGLUniformLocation* loc, GLuint v0); void Uniform2ui(WebGLUniformLocation* loc, GLuint v0, GLuint v1); void Uniform3ui(WebGLUniformLocation* loc, GLuint v0, GLuint v1, GLuint v2); void Uniform4ui(WebGLUniformLocation* loc, GLuint v0, GLuint v1, GLuint v2, GLuint v3); //////////////// protected: typedef Arr UintArr; void UniformNuiv(const char* funcName, uint8_t N, WebGLUniformLocation* loc, const UintArr& arr); ////// public: template void Uniform1uiv(WebGLUniformLocation* loc, const T& arr) { UniformNuiv("uniform1uiv", 1, loc, UintArr(arr)); } template void Uniform2uiv(WebGLUniformLocation* loc, const T& arr) { UniformNuiv("uniform2uiv", 2, loc, UintArr(arr)); } template void Uniform3uiv(WebGLUniformLocation* loc, const T& arr) { UniformNuiv("uniform3uiv", 3, loc, UintArr(arr)); } template void Uniform4uiv(WebGLUniformLocation* loc, const T& arr) { UniformNuiv("uniform4uiv", 4, loc, UintArr(arr)); } ////// template void UniformMatrix2x3fv(WebGLUniformLocation* loc, bool transpose, const T& arr) { UniformMatrixAxBfv("uniformMatrix2x3fv", 2, 3, loc, transpose, FloatArr(arr)); } template void UniformMatrix2x4fv(WebGLUniformLocation* loc, bool transpose, const T& arr) { UniformMatrixAxBfv("uniformMatrix2x4fv", 2, 4, loc, transpose, FloatArr(arr)); } template void UniformMatrix3x2fv(WebGLUniformLocation* loc, bool transpose, const T& arr) { UniformMatrixAxBfv("uniformMatrix3x2fv", 3, 2, loc, transpose, FloatArr(arr)); } template void UniformMatrix3x4fv(WebGLUniformLocation* loc, bool transpose, const T& arr) { UniformMatrixAxBfv("uniformMatrix3x4fv", 3, 4, loc, transpose, FloatArr(arr)); } template void UniformMatrix4x2fv(WebGLUniformLocation* loc, bool transpose, const T& arr) { UniformMatrixAxBfv("uniformMatrix4x2fv", 4, 2, loc, transpose, FloatArr(arr)); } template void UniformMatrix4x3fv(WebGLUniformLocation* loc, bool transpose, const T& arr) { UniformMatrixAxBfv("uniformMatrix4x3fv", 4, 3, loc, transpose, FloatArr(arr)); } //////////////// private: void VertexAttribI4iv(GLuint index, size_t length, const GLint* v); void VertexAttribI4uiv(GLuint index, size_t length, const GLuint* v); public: // GL 3.0 & ES 3.0 void VertexAttribI4i(GLuint index, GLint x, GLint y, GLint z, GLint w); void VertexAttribI4iv(GLuint index, const dom::Sequence& v); void VertexAttribI4ui(GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); void VertexAttribI4uiv(GLuint index, const dom::Sequence& v); // ------------------------------------------------------------------------- // Writing to the drawing buffer // TODO(djg): Implemented in WebGLContext /* void VertexAttribDivisor(GLuint index, GLuint divisor); void DrawArraysInstanced(GLenum mode, GLint first, GLsizei count, GLsizei instanceCount); void DrawElementsInstanced(GLenum mode, GLsizei count, GLenum type, GLintptr offset, GLsizei instanceCount); */ void DrawRangeElements(GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, GLintptr offset); // ------------------------------------------------------------------------ // Multiple Render Targets - WebGL2ContextMRTs.cpp // TODO(djg): Implemented in WebGLContext /* void DrawBuffers(const dom::Sequence& buffers); */ void ClearBufferiv_base(GLenum buffer, GLint drawbuffer, const GLint* value); void ClearBufferuiv_base(GLenum buffer, GLint drawbuffer, const GLuint* value); void ClearBufferfv_base(GLenum buffer, GLint drawbuffer, const GLfloat* value); void ClearBufferiv(GLenum buffer, GLint drawbuffer, const dom::Int32Array& value); void ClearBufferiv(GLenum buffer, GLint drawbuffer, const dom::Sequence& value); void ClearBufferuiv(GLenum buffer, GLint drawbuffer, const dom::Uint32Array& value); void ClearBufferuiv(GLenum buffer, GLint drawbuffer, const dom::Sequence& value); void ClearBufferfv(GLenum buffer, GLint drawbuffer, const dom::Float32Array& value); void ClearBufferfv(GLenum buffer, GLint drawbuffer, const dom::Sequence& value); void ClearBufferfi(GLenum buffer, GLint drawbuffer, GLfloat depth, GLint stencil); bool ValidateClearBuffer(const char* info, GLenum buffer, GLint drawbuffer, size_t elemCount); // ------------------------------------------------------------------------- // Query Objects - WebGL2ContextQueries.cpp already_AddRefed CreateQuery(); void DeleteQuery(WebGLQuery* query); bool IsQuery(WebGLQuery* query); void BeginQuery(GLenum target, WebGLQuery* query); void EndQuery(GLenum target); already_AddRefed GetQuery(GLenum target, GLenum pname); void GetQueryParameter(JSContext*, WebGLQuery* query, GLenum pname, JS::MutableHandleValue retval); // ------------------------------------------------------------------------- // Sampler Objects - WebGL2ContextSamplers.cpp already_AddRefed CreateSampler(); void DeleteSampler(WebGLSampler* sampler); bool IsSampler(WebGLSampler* sampler); void BindSampler(GLuint unit, WebGLSampler* sampler); void SamplerParameteri(WebGLSampler* sampler, GLenum pname, GLint param); void SamplerParameteriv(WebGLSampler* sampler, GLenum pname, const dom::Int32Array& param); void SamplerParameteriv(WebGLSampler* sampler, GLenum pname, const dom::Sequence& param); void SamplerParameterf(WebGLSampler* sampler, GLenum pname, GLfloat param); void SamplerParameterfv(WebGLSampler* sampler, GLenum pname, const dom::Float32Array& param); void SamplerParameterfv(WebGLSampler* sampler, GLenum pname, const dom::Sequence& param); void GetSamplerParameter(JSContext*, WebGLSampler* sampler, GLenum pname, JS::MutableHandleValue retval); // ------------------------------------------------------------------------- // Sync objects - WebGL2ContextSync.cpp already_AddRefed FenceSync(GLenum condition, GLbitfield flags); bool IsSync(WebGLSync* sync); void DeleteSync(WebGLSync* sync); GLenum ClientWaitSync(WebGLSync* sync, GLbitfield flags, GLuint64 timeout); void WaitSync(WebGLSync* sync, GLbitfield flags, GLuint64 timeout); void GetSyncParameter(JSContext*, WebGLSync* sync, GLenum pname, JS::MutableHandleValue retval); // ------------------------------------------------------------------------- // Transform Feedback - WebGL2ContextTransformFeedback.cpp already_AddRefed CreateTransformFeedback(); void DeleteTransformFeedback(WebGLTransformFeedback* tf); bool IsTransformFeedback(WebGLTransformFeedback* tf); void BindTransformFeedback(GLenum target, WebGLTransformFeedback* tf); void BeginTransformFeedback(GLenum primitiveMode); void EndTransformFeedback(); void PauseTransformFeedback(); void ResumeTransformFeedback(); void TransformFeedbackVaryings(WebGLProgram* program, const dom::Sequence& varyings, GLenum bufferMode); already_AddRefed GetTransformFeedbackVarying(WebGLProgram* program, GLuint index); // ------------------------------------------------------------------------- // Uniform Buffer Objects and Transform Feedback Buffers - WebGL2ContextUniforms.cpp // TODO(djg): Implemented in WebGLContext /* void BindBufferBase(GLenum target, GLuint index, WebGLBuffer* buffer); void BindBufferRange(GLenum target, GLuint index, WebGLBuffer* buffer, GLintptr offset, GLsizeiptr size); */ virtual JS::Value GetParameter(JSContext* cx, GLenum pname, ErrorResult& rv) override; void GetIndexedParameter(GLenum target, GLuint index, dom::Nullable& retval); void GetUniformIndices(WebGLProgram* program, const dom::Sequence& uniformNames, dom::Nullable< nsTArray >& retval); void GetActiveUniforms(JSContext* cx, WebGLProgram* program, const dom::Sequence& uniformIndices, GLenum pname, JS::MutableHandleValue retval); GLuint GetUniformBlockIndex(WebGLProgram* program, const nsAString& uniformBlockName); void GetActiveUniformBlockParameter(JSContext*, WebGLProgram* program, GLuint uniformBlockIndex, GLenum pname, dom::Nullable& retval, ErrorResult& rv); void GetActiveUniformBlockName(WebGLProgram* program, GLuint uniformBlockIndex, nsAString& retval); void UniformBlockBinding(WebGLProgram* program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); // ------------------------------------------------------------------------- // Vertex Array Object - WebGL2ContextVAOs.cpp // TODO(djg): Implemented in WebGLContext /* already_AddRefed CreateVertexArray(); void DeleteVertexArray(WebGLVertexArrayObject* vertexArray); bool IsVertexArray(WebGLVertexArrayObject* vertexArray); void BindVertexArray(WebGLVertexArrayObject* vertexArray); */ private: WebGL2Context(); virtual UniquePtr CreateFormatUsage(gl::GLContext* gl) const override; virtual bool IsTexParamValid(GLenum pname) const override; void UpdateBoundQuery(GLenum target, WebGLQuery* query); // CreateVertexArrayImpl is assumed to be infallible. virtual WebGLVertexArray* CreateVertexArrayImpl() override; virtual bool ValidateAttribPointerType(bool integerMode, GLenum type, uint32_t* alignment, const char* info) override; virtual bool ValidateBufferTarget(GLenum target, const char* info) override; virtual bool ValidateBufferIndexedTarget(GLenum target, const char* info) override; virtual bool ValidateBufferUsageEnum(GLenum usage, const char* info) override; virtual bool ValidateQueryTarget(GLenum target, const char* info) override; virtual bool ValidateUniformMatrixTranspose(bool transpose, const char* info) override; }; } // namespace mozilla #endif