summaryrefslogtreecommitdiffstats
path: root/ppapi
diff options
context:
space:
mode:
Diffstat (limited to 'ppapi')
-rw-r--r--ppapi/GLES2/gl2.h607
-rw-r--r--ppapi/GLES2/khrplatform.h269
-rw-r--r--ppapi/c/dev/ppb_graphics_3d_dev.h8
-rw-r--r--ppapi/c/dev/ppb_opengles_dev.h397
-rw-r--r--ppapi/cpp/dev/graphics_3d_dev.cc38
-rw-r--r--ppapi/cpp/dev/graphics_3d_dev.h5
-rw-r--r--ppapi/lib/gl/gles2/gl2ext_ppapi.c44
-rw-r--r--ppapi/lib/gl/gles2/gl2ext_ppapi.h8
-rw-r--r--ppapi/lib/gl/gles2/gles2.c265
-rw-r--r--ppapi/ppapi.gypi28
10 files changed, 555 insertions, 1114 deletions
diff --git a/ppapi/GLES2/gl2.h b/ppapi/GLES2/gl2.h
deleted file mode 100644
index c4ca2da..0000000
--- a/ppapi/GLES2/gl2.h
+++ /dev/null
@@ -1,607 +0,0 @@
-// Copyright (c 2010 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef __gl2_h_
-#define __gl2_h_
-
-#include "ppapi/c/dev/ppb_opengles_dev.h"
-/*
- * This document is licensed under the SGI Free Software B License Version
- * 2.0. For details, see http://oss.sgi.com/projects/FreeB/ .
- */
-
-/* OpenGL ES core versions */
-#define GL_ES_VERSION_2_0 1
-
-/* ClearBufferMask */
-#define GL_DEPTH_BUFFER_BIT 0x00000100
-#define GL_STENCIL_BUFFER_BIT 0x00000400
-#define GL_COLOR_BUFFER_BIT 0x00004000
-
-/* Boolean */
-#define GL_FALSE 0
-#define GL_TRUE 1
-
-/* BeginMode */
-#define GL_POINTS 0x0000
-#define GL_LINES 0x0001
-#define GL_LINE_LOOP 0x0002
-#define GL_LINE_STRIP 0x0003
-#define GL_TRIANGLES 0x0004
-#define GL_TRIANGLE_STRIP 0x0005
-#define GL_TRIANGLE_FAN 0x0006
-
-/* AlphaFunction (not supported in ES20 */
-/* GL_NEVER */
-/* GL_LESS */
-/* GL_EQUAL */
-/* GL_LEQUAL */
-/* GL_GREATER */
-/* GL_NOTEQUAL */
-/* GL_GEQUAL */
-/* GL_ALWAYS */
-
-/* BlendingFactorDest */
-#define GL_ZERO 0
-#define GL_ONE 1
-#define GL_SRC_COLOR 0x0300
-#define GL_ONE_MINUS_SRC_COLOR 0x0301
-#define GL_SRC_ALPHA 0x0302
-#define GL_ONE_MINUS_SRC_ALPHA 0x0303
-#define GL_DST_ALPHA 0x0304
-#define GL_ONE_MINUS_DST_ALPHA 0x0305
-
-/* BlendingFactorSrc */
-/* GL_ZERO */
-/* GL_ONE */
-#define GL_DST_COLOR 0x0306
-#define GL_ONE_MINUS_DST_COLOR 0x0307
-#define GL_SRC_ALPHA_SATURATE 0x0308
-/* GL_SRC_ALPHA */
-/* GL_ONE_MINUS_SRC_ALPHA */
-/* GL_DST_ALPHA */
-/* GL_ONE_MINUS_DST_ALPHA */
-
-/* BlendEquationSeparate */
-#define GL_FUNC_ADD 0x8006
-#define GL_BLEND_EQUATION 0x8009
-#define GL_BLEND_EQUATION_RGB 0x8009 /* same as BLEND_EQUATION */
-#define GL_BLEND_EQUATION_ALPHA 0x883D
-
-/* BlendSubtract */
-#define GL_FUNC_SUBTRACT 0x800A
-#define GL_FUNC_REVERSE_SUBTRACT 0x800B
-
-/* Separate Blend Functions */
-#define GL_BLEND_DST_RGB 0x80C8
-#define GL_BLEND_SRC_RGB 0x80C9
-#define GL_BLEND_DST_ALPHA 0x80CA
-#define GL_BLEND_SRC_ALPHA 0x80CB
-#define GL_CONSTANT_COLOR 0x8001
-#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002
-#define GL_CONSTANT_ALPHA 0x8003
-#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004
-#define GL_BLEND_COLOR 0x8005
-
-/* Buffer Objects */
-#define GL_ARRAY_BUFFER 0x8892
-#define GL_ELEMENT_ARRAY_BUFFER 0x8893
-#define GL_ARRAY_BUFFER_BINDING 0x8894
-#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895
-
-#define GL_STREAM_DRAW 0x88E0
-#define GL_STATIC_DRAW 0x88E4
-#define GL_DYNAMIC_DRAW 0x88E8
-
-#define GL_BUFFER_SIZE 0x8764
-#define GL_BUFFER_USAGE 0x8765
-
-#define GL_CURRENT_VERTEX_ATTRIB 0x8626
-
-/* CullFaceMode */
-#define GL_FRONT 0x0404
-#define GL_BACK 0x0405
-#define GL_FRONT_AND_BACK 0x0408
-
-/* DepthFunction */
-/* GL_NEVER */
-/* GL_LESS */
-/* GL_EQUAL */
-/* GL_LEQUAL */
-/* GL_GREATER */
-/* GL_NOTEQUAL */
-/* GL_GEQUAL */
-/* GL_ALWAYS */
-
-/* EnableCap */
-#define GL_TEXTURE_2D 0x0DE1
-#define GL_CULL_FACE 0x0B44
-#define GL_BLEND 0x0BE2
-#define GL_DITHER 0x0BD0
-#define GL_STENCIL_TEST 0x0B90
-#define GL_DEPTH_TEST 0x0B71
-#define GL_SCISSOR_TEST 0x0C11
-#define GL_POLYGON_OFFSET_FILL 0x8037
-#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E
-#define GL_SAMPLE_COVERAGE 0x80A0
-
-/* ErrorCode */
-#define GL_NO_ERROR 0
-#define GL_INVALID_ENUM 0x0500
-#define GL_INVALID_VALUE 0x0501
-#define GL_INVALID_OPERATION 0x0502
-#define GL_OUT_OF_MEMORY 0x0505
-#define GL_CONTEXT_LOST 0x300E // TODO(gman: What value?
-
-/* FrontFaceDirection */
-#define GL_CW 0x0900
-#define GL_CCW 0x0901
-
-/* GetPName */
-#define GL_LINE_WIDTH 0x0B21
-#define GL_ALIASED_POINT_SIZE_RANGE 0x846D
-#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E
-#define GL_CULL_FACE_MODE 0x0B45
-#define GL_FRONT_FACE 0x0B46
-#define GL_DEPTH_RANGE 0x0B70
-#define GL_DEPTH_WRITEMASK 0x0B72
-#define GL_DEPTH_CLEAR_VALUE 0x0B73
-#define GL_DEPTH_FUNC 0x0B74
-#define GL_STENCIL_CLEAR_VALUE 0x0B91
-#define GL_STENCIL_FUNC 0x0B92
-#define GL_STENCIL_FAIL 0x0B94
-#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95
-#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96
-#define GL_STENCIL_REF 0x0B97
-#define GL_STENCIL_VALUE_MASK 0x0B93
-#define GL_STENCIL_WRITEMASK 0x0B98
-#define GL_STENCIL_BACK_FUNC 0x8800
-#define GL_STENCIL_BACK_FAIL 0x8801
-#define GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802
-#define GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803
-#define GL_STENCIL_BACK_REF 0x8CA3
-#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4
-#define GL_STENCIL_BACK_WRITEMASK 0x8CA5
-#define GL_VIEWPORT 0x0BA2
-#define GL_SCISSOR_BOX 0x0C10
-/* GL_SCISSOR_TEST */
-#define GL_COLOR_CLEAR_VALUE 0x0C22
-#define GL_COLOR_WRITEMASK 0x0C23
-#define GL_UNPACK_ALIGNMENT 0x0CF5
-#define GL_PACK_ALIGNMENT 0x0D05
-#define GL_MAX_TEXTURE_SIZE 0x0D33
-#define GL_MAX_VIEWPORT_DIMS 0x0D3A
-#define GL_SUBPIXEL_BITS 0x0D50
-#define GL_RED_BITS 0x0D52
-#define GL_GREEN_BITS 0x0D53
-#define GL_BLUE_BITS 0x0D54
-#define GL_ALPHA_BITS 0x0D55
-#define GL_DEPTH_BITS 0x0D56
-#define GL_STENCIL_BITS 0x0D57
-#define GL_POLYGON_OFFSET_UNITS 0x2A00
-/* GL_POLYGON_OFFSET_FILL */
-#define GL_POLYGON_OFFSET_FACTOR 0x8038
-#define GL_TEXTURE_BINDING_2D 0x8069
-#define GL_SAMPLE_BUFFERS 0x80A8
-#define GL_SAMPLES 0x80A9
-#define GL_SAMPLE_COVERAGE_VALUE 0x80AA
-#define GL_SAMPLE_COVERAGE_INVERT 0x80AB
-
-/* GetTextureParameter */
-/* GL_TEXTURE_MAG_FILTER */
-/* GL_TEXTURE_MIN_FILTER */
-/* GL_TEXTURE_WRAP_S */
-/* GL_TEXTURE_WRAP_T */
-
-#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2
-#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3
-
-/* HintMode */
-#define GL_DONT_CARE 0x1100
-#define GL_FASTEST 0x1101
-#define GL_NICEST 0x1102
-
-/* HintTarget */
-#define GL_GENERATE_MIPMAP_HINT 0x8192
-
-/* DataType */
-#define GL_BYTE 0x1400
-#define GL_UNSIGNED_BYTE 0x1401
-#define GL_SHORT 0x1402
-#define GL_UNSIGNED_SHORT 0x1403
-#define GL_INT 0x1404
-#define GL_UNSIGNED_INT 0x1405
-#define GL_FLOAT 0x1406
-#define GL_FIXED 0x140C
-
-/* PixelFormat */
-#define GL_DEPTH_COMPONENT 0x1902
-#define GL_ALPHA 0x1906
-#define GL_RGB 0x1907
-#define GL_RGBA 0x1908
-#define GL_LUMINANCE 0x1909
-#define GL_LUMINANCE_ALPHA 0x190A
-
-/* PixelType */
-/* GL_UNSIGNED_BYTE */
-#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033
-#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034
-#define GL_UNSIGNED_SHORT_5_6_5 0x8363
-
-/* Shaders */
-#define GL_FRAGMENT_SHADER 0x8B30
-#define GL_VERTEX_SHADER 0x8B31
-#define GL_MAX_VERTEX_ATTRIBS 0x8869
-#define GL_MAX_VERTEX_UNIFORM_VECTORS 0x8DFB
-#define GL_MAX_VARYING_VECTORS 0x8DFC
-#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D
-#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C
-#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872
-#define GL_MAX_FRAGMENT_UNIFORM_VECTORS 0x8DFD
-#define GL_SHADER_TYPE 0x8B4F
-#define GL_DELETE_STATUS 0x8B80
-#define GL_LINK_STATUS 0x8B82
-#define GL_VALIDATE_STATUS 0x8B83
-#define GL_ATTACHED_SHADERS 0x8B85
-#define GL_ACTIVE_UNIFORMS 0x8B86
-#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87
-#define GL_ACTIVE_ATTRIBUTES 0x8B89
-#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A
-#define GL_SHADING_LANGUAGE_VERSION 0x8B8C
-#define GL_CURRENT_PROGRAM 0x8B8D
-
-/* StencilFunction */
-#define GL_NEVER 0x0200
-#define GL_LESS 0x0201
-#define GL_EQUAL 0x0202
-#define GL_LEQUAL 0x0203
-#define GL_GREATER 0x0204
-#define GL_NOTEQUAL 0x0205
-#define GL_GEQUAL 0x0206
-#define GL_ALWAYS 0x0207
-
-/* StencilOp */
-/* GL_ZERO */
-#define GL_KEEP 0x1E00
-#define GL_REPLACE 0x1E01
-#define GL_INCR 0x1E02
-#define GL_DECR 0x1E03
-#define GL_INVERT 0x150A
-#define GL_INCR_WRAP 0x8507
-#define GL_DECR_WRAP 0x8508
-
-/* StringName */
-#define GL_VENDOR 0x1F00
-#define GL_RENDERER 0x1F01
-#define GL_VERSION 0x1F02
-#define GL_EXTENSIONS 0x1F03
-
-/* TextureMagFilter */
-#define GL_NEAREST 0x2600
-#define GL_LINEAR 0x2601
-
-/* TextureMinFilter */
-/* GL_NEAREST */
-/* GL_LINEAR */
-#define GL_NEAREST_MIPMAP_NEAREST 0x2700
-#define GL_LINEAR_MIPMAP_NEAREST 0x2701
-#define GL_NEAREST_MIPMAP_LINEAR 0x2702
-#define GL_LINEAR_MIPMAP_LINEAR 0x2703
-
-/* TextureParameterName */
-#define GL_TEXTURE_MAG_FILTER 0x2800
-#define GL_TEXTURE_MIN_FILTER 0x2801
-#define GL_TEXTURE_WRAP_S 0x2802
-#define GL_TEXTURE_WRAP_T 0x2803
-
-/* TextureTarget */
-/* GL_TEXTURE_2D */
-#define GL_TEXTURE 0x1702
-
-#define GL_TEXTURE_CUBE_MAP 0x8513
-#define GL_TEXTURE_BINDING_CUBE_MAP 0x8514
-#define GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515
-#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516
-#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517
-#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518
-#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519
-#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A
-#define GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C
-
-/* TextureUnit */
-#define GL_TEXTURE0 0x84C0
-#define GL_TEXTURE1 0x84C1
-#define GL_TEXTURE2 0x84C2
-#define GL_TEXTURE3 0x84C3
-#define GL_TEXTURE4 0x84C4
-#define GL_TEXTURE5 0x84C5
-#define GL_TEXTURE6 0x84C6
-#define GL_TEXTURE7 0x84C7
-#define GL_TEXTURE8 0x84C8
-#define GL_TEXTURE9 0x84C9
-#define GL_TEXTURE10 0x84CA
-#define GL_TEXTURE11 0x84CB
-#define GL_TEXTURE12 0x84CC
-#define GL_TEXTURE13 0x84CD
-#define GL_TEXTURE14 0x84CE
-#define GL_TEXTURE15 0x84CF
-#define GL_TEXTURE16 0x84D0
-#define GL_TEXTURE17 0x84D1
-#define GL_TEXTURE18 0x84D2
-#define GL_TEXTURE19 0x84D3
-#define GL_TEXTURE20 0x84D4
-#define GL_TEXTURE21 0x84D5
-#define GL_TEXTURE22 0x84D6
-#define GL_TEXTURE23 0x84D7
-#define GL_TEXTURE24 0x84D8
-#define GL_TEXTURE25 0x84D9
-#define GL_TEXTURE26 0x84DA
-#define GL_TEXTURE27 0x84DB
-#define GL_TEXTURE28 0x84DC
-#define GL_TEXTURE29 0x84DD
-#define GL_TEXTURE30 0x84DE
-#define GL_TEXTURE31 0x84DF
-#define GL_ACTIVE_TEXTURE 0x84E0
-
-/* TextureWrapMode */
-#define GL_REPEAT 0x2901
-#define GL_CLAMP_TO_EDGE 0x812F
-#define GL_MIRRORED_REPEAT 0x8370
-
-/* Uniform Types */
-#define GL_FLOAT_VEC2 0x8B50
-#define GL_FLOAT_VEC3 0x8B51
-#define GL_FLOAT_VEC4 0x8B52
-#define GL_INT_VEC2 0x8B53
-#define GL_INT_VEC3 0x8B54
-#define GL_INT_VEC4 0x8B55
-#define GL_BOOL 0x8B56
-#define GL_BOOL_VEC2 0x8B57
-#define GL_BOOL_VEC3 0x8B58
-#define GL_BOOL_VEC4 0x8B59
-#define GL_FLOAT_MAT2 0x8B5A
-#define GL_FLOAT_MAT3 0x8B5B
-#define GL_FLOAT_MAT4 0x8B5C
-#define GL_SAMPLER_2D 0x8B5E
-#define GL_SAMPLER_CUBE 0x8B60
-
-/* Vertex Arrays */
-#define GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622
-#define GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623
-#define GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624
-#define GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625
-#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A
-#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645
-#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F
-
-/* Read Format */
-#define GL_IMPLEMENTATION_COLOR_READ_TYPE 0x8B9A
-#define GL_IMPLEMENTATION_COLOR_READ_FORMAT 0x8B9B
-
-/* Shader Source */
-#define GL_COMPILE_STATUS 0x8B81
-#define GL_INFO_LOG_LENGTH 0x8B84
-#define GL_SHADER_SOURCE_LENGTH 0x8B88
-#define GL_SHADER_COMPILER 0x8DFA
-
-/* Shader Binary */
-#define GL_SHADER_BINARY_FORMATS 0x8DF8
-#define GL_NUM_SHADER_BINARY_FORMATS 0x8DF9
-
-/* Shader Precision-Specified Types */
-#define GL_LOW_FLOAT 0x8DF0
-#define GL_MEDIUM_FLOAT 0x8DF1
-#define GL_HIGH_FLOAT 0x8DF2
-#define GL_LOW_INT 0x8DF3
-#define GL_MEDIUM_INT 0x8DF4
-#define GL_HIGH_INT 0x8DF5
-
-/* Framebuffer Object. */
-#define GL_FRAMEBUFFER 0x8D40
-#define GL_RENDERBUFFER 0x8D41
-
-#define GL_RGBA4 0x8056
-#define GL_RGB5_A1 0x8057
-#define GL_RGB565 0x8D62
-#define GL_DEPTH_COMPONENT16 0x81A5
-#define GL_STENCIL_INDEX 0x1901
-#define GL_STENCIL_INDEX8 0x8D48
-
-#define GL_RENDERBUFFER_WIDTH 0x8D42
-#define GL_RENDERBUFFER_HEIGHT 0x8D43
-#define GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44
-#define GL_RENDERBUFFER_RED_SIZE 0x8D50
-#define GL_RENDERBUFFER_GREEN_SIZE 0x8D51
-#define GL_RENDERBUFFER_BLUE_SIZE 0x8D52
-#define GL_RENDERBUFFER_ALPHA_SIZE 0x8D53
-#define GL_RENDERBUFFER_DEPTH_SIZE 0x8D54
-#define GL_RENDERBUFFER_STENCIL_SIZE 0x8D55
-
-#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE 0x8CD0
-#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME 0x8CD1
-#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL 0x8CD2
-#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE 0x8CD3
-
-#define GL_COLOR_ATTACHMENT0 0x8CE0
-#define GL_DEPTH_ATTACHMENT 0x8D00
-#define GL_STENCIL_ATTACHMENT 0x8D20
-
-#define GL_NONE 0
-
-#define GL_FRAMEBUFFER_COMPLETE 0x8CD5
-#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6
-#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7
-#define GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS 0x8CD9
-#define GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD
-
-#define GL_FRAMEBUFFER_BINDING 0x8CA6
-#define GL_RENDERBUFFER_BINDING 0x8CA7
-#define GL_MAX_RENDERBUFFER_SIZE 0x84E8
-
-#define GL_INVALID_FRAMEBUFFER_OPERATION 0x0506
-
-
-/*-------------------------------------------------------------------------
- * GL core functions.
- *-----------------------------------------------------------------------*/
-#undef GL_APICALL
-#define GL_APICALL
-#undef GL_APIENTRY
-#define GL_APIENTRY
-
-// The client must set this to point to the Pepper OpenGLES interface once it
-// is obtained. PPAPI C++ wrappers will do this for you.
-#ifdef __cplusplus
-extern "C" {
-#endif
-extern const struct PPB_OpenGLES_Dev* pepper_opengl_interface;
-#ifdef __cplusplus
-}
-#endif
-
-#define glActiveTexture pepper_opengl_interface->ActiveTexture
-#define glAttachShader pepper_opengl_interface->AttachShader
-#define glBindAttribLocation pepper_opengl_interface->BindAttribLocation
-#define glBindBuffer pepper_opengl_interface->BindBuffer
-#define glBindFramebuffer pepper_opengl_interface->BindFramebuffer
-#define glBindRenderbuffer pepper_opengl_interface->BindRenderbuffer
-#define glBindTexture pepper_opengl_interface->BindTexture
-#define glBlendColor pepper_opengl_interface->BlendColor
-#define glBlendEquation pepper_opengl_interface->BlendEquation
-#define glBlendEquationSeparate pepper_opengl_interface->BlendEquationSeparate
-#define glBlendFunc pepper_opengl_interface->BlendFunc
-#define glBlendFuncSeparate pepper_opengl_interface->BlendFuncSeparate
-#define glBufferData pepper_opengl_interface->BufferData
-#define glBufferSubData pepper_opengl_interface->BufferSubData
-#define glCheckFramebufferStatus pepper_opengl_interface->CheckFramebufferStatus
-#define glClear pepper_opengl_interface->Clear
-#define glClearColor pepper_opengl_interface->ClearColor
-#define glClearDepthf pepper_opengl_interface->ClearDepthf
-#define glClearStencil pepper_opengl_interface->ClearStencil
-#define glColorMask pepper_opengl_interface->ColorMask
-#define glCompileShader pepper_opengl_interface->CompileShader
-#define glCompressedTexImage2D pepper_opengl_interface->CompressedTexImage2D
-#define glCompressedTexSubImage2D pepper_opengl_interface->CompressedTexSubImage2D
-#define glCopyTexImage2D pepper_opengl_interface->CopyTexImage2D
-#define glCopyTexSubImage2D pepper_opengl_interface->CopyTexSubImage2D
-#define glCreateProgram pepper_opengl_interface->CreateProgram
-#define glCreateShader pepper_opengl_interface->CreateShader
-#define glCullFace pepper_opengl_interface->CullFace
-#define glDeleteBuffers pepper_opengl_interface->DeleteBuffers
-#define glDeleteFramebuffers pepper_opengl_interface->DeleteFramebuffers
-#define glDeleteProgram pepper_opengl_interface->DeleteProgram
-#define glDeleteRenderbuffers pepper_opengl_interface->DeleteRenderbuffers
-#define glDeleteShader pepper_opengl_interface->DeleteShader
-#define glDeleteTextures pepper_opengl_interface->DeleteTextures
-#define glDepthFunc pepper_opengl_interface->DepthFunc
-#define glDepthMask pepper_opengl_interface->DepthMask
-#define glDepthRangef pepper_opengl_interface->DepthRangef
-#define glDetachShader pepper_opengl_interface->DetachShader
-#define glDisable pepper_opengl_interface->Disable
-#define glDisableVertexAttribArray pepper_opengl_interface->DisableVertexAttribArray
-#define glDrawArrays pepper_opengl_interface->DrawArrays
-#define glDrawElements pepper_opengl_interface->DrawElements
-#define glEnable pepper_opengl_interface->Enable
-#define glEnableVertexAttribArray pepper_opengl_interface->EnableVertexAttribArray
-#define glFinish pepper_opengl_interface->Finish
-#define glFlush pepper_opengl_interface->Flush
-#define glFramebufferRenderbuffer pepper_opengl_interface->FramebufferRenderbuffer
-#define glFramebufferTexture2D pepper_opengl_interface->FramebufferTexture2D
-#define glFrontFace pepper_opengl_interface->FrontFace
-#define glGenBuffers pepper_opengl_interface->GenBuffers
-#define glGenerateMipmap pepper_opengl_interface->GenerateMipmap
-#define glGenFramebuffers pepper_opengl_interface->GenFramebuffers
-#define glGenRenderbuffers pepper_opengl_interface->GenRenderbuffers
-#define glGenTextures pepper_opengl_interface->GenTextures
-#define glGetActiveAttrib pepper_opengl_interface->GetActiveAttrib
-#define glGetActiveUniform pepper_opengl_interface->GetActiveUniform
-#define glGetAttachedShaders pepper_opengl_interface->GetAttachedShaders
-#define glGetAttribLocation pepper_opengl_interface->GetAttribLocation
-#define glGetBooleanv pepper_opengl_interface->GetBooleanv
-#define glGetBufferParameteriv pepper_opengl_interface->GetBufferParameteriv
-#define glGetError pepper_opengl_interface->GetError
-#define glGetFloatv pepper_opengl_interface->GetFloatv
-#define glGetFramebufferAttachmentParameteriv pepper_opengl_interface->GetFramebufferAttachmentParameteriv
-#define glGetIntegerv pepper_opengl_interface->GetIntegerv
-#define glGetProgramiv pepper_opengl_interface->GetProgramiv
-#define glGetProgramInfoLog pepper_opengl_interface->GetProgramInfoLog
-#define glGetRenderbufferParameteriv pepper_opengl_interface->GetRenderbufferParameteriv
-#define glGetShaderiv pepper_opengl_interface->GetShaderiv
-#define glGetShaderInfoLog pepper_opengl_interface->GetShaderInfoLog
-#define glGetShaderPrecisionFormat pepper_opengl_interface->GetShaderPrecisionFormat
-#define glGetShaderSource pepper_opengl_interface->GetShaderSource
-#define glGetString pepper_opengl_interface->GetString
-#define glGetTexParameterfv pepper_opengl_interface->GetTexParameterfv
-#define glGetTexParameteriv pepper_opengl_interface->GetTexParameteriv
-#define glGetUniformfv pepper_opengl_interface->GetUniformfv
-#define glGetUniformiv pepper_opengl_interface->GetUniformiv
-#define glGetUniformLocation pepper_opengl_interface->GetUniformLocation
-#define glGetVertexAttribfv pepper_opengl_interface->GetVertexAttribfv
-#define glGetVertexAttribiv pepper_opengl_interface->GetVertexAttribiv
-#define glGetVertexAttribPointerv pepper_opengl_interface->GetVertexAttribPointerv
-#define glHint pepper_opengl_interface->Hint
-#define glIsBuffer pepper_opengl_interface->IsBuffer
-#define glIsEnabled pepper_opengl_interface->IsEnabled
-#define glIsFramebuffer pepper_opengl_interface->IsFramebuffer
-#define glIsProgram pepper_opengl_interface->IsProgram
-#define glIsRenderbuffer pepper_opengl_interface->IsRenderbuffer
-#define glIsShader pepper_opengl_interface->IsShader
-#define glIsTexture pepper_opengl_interface->IsTexture
-#define glLineWidth pepper_opengl_interface->LineWidth
-#define glLinkProgram pepper_opengl_interface->LinkProgram
-#define glPixelStorei pepper_opengl_interface->PixelStorei
-#define glPolygonOffset pepper_opengl_interface->PolygonOffset
-#define glReadPixels pepper_opengl_interface->ReadPixels
-#define glReleaseShaderCompiler pepper_opengl_interface->ReleaseShaderCompiler
-#define glRenderbufferStorage pepper_opengl_interface->RenderbufferStorage
-#define glSampleCoverage pepper_opengl_interface->SampleCoverage
-#define glScissor pepper_opengl_interface->Scissor
-#define glShaderBinary pepper_opengl_interface->ShaderBinary
-#define glShaderSource pepper_opengl_interface->ShaderSource
-#define glStencilFunc pepper_opengl_interface->StencilFunc
-#define glStencilFuncSeparate pepper_opengl_interface->StencilFuncSeparate
-#define glStencilMask pepper_opengl_interface->StencilMask
-#define glStencilMaskSeparate pepper_opengl_interface->StencilMaskSeparate
-#define glStencilOp pepper_opengl_interface->StencilOp
-#define glStencilOpSeparate pepper_opengl_interface->StencilOpSeparate
-#define glTexImage2D pepper_opengl_interface->TexImage2D
-#define glTexParameterf pepper_opengl_interface->TexParameterf
-#define glTexParameterfv pepper_opengl_interface->TexParameterfv
-#define glTexParameteri pepper_opengl_interface->TexParameteri
-#define glTexParameteriv pepper_opengl_interface->TexParameteriv
-#define glTexSubImage2D pepper_opengl_interface->TexSubImage2D
-#define glUniform1f pepper_opengl_interface->Uniform1f
-#define glUniform1fv pepper_opengl_interface->Uniform1fv
-#define glUniform1i pepper_opengl_interface->Uniform1i
-#define glUniform1iv pepper_opengl_interface->Uniform1iv
-#define glUniform2f pepper_opengl_interface->Uniform2f
-#define glUniform2fv pepper_opengl_interface->Uniform2fv
-#define glUniform2i pepper_opengl_interface->Uniform2i
-#define glUniform2iv pepper_opengl_interface->Uniform2iv
-#define glUniform3f pepper_opengl_interface->Uniform3f
-#define glUniform3fv pepper_opengl_interface->Uniform3fv
-#define glUniform3i pepper_opengl_interface->Uniform3i
-#define glUniform3iv pepper_opengl_interface->Uniform3iv
-#define glUniform4f pepper_opengl_interface->Uniform4f
-#define glUniform4fv pepper_opengl_interface->Uniform4fv
-#define glUniform4i pepper_opengl_interface->Uniform4i
-#define glUniform4iv pepper_opengl_interface->Uniform4iv
-#define glUniformMatrix2fv pepper_opengl_interface->UniformMatrix2fv
-#define glUniformMatrix3fv pepper_opengl_interface->UniformMatrix3fv
-#define glUniformMatrix4fv pepper_opengl_interface->UniformMatrix4fv
-#define glUseProgram pepper_opengl_interface->UseProgram
-#define glValidateProgram pepper_opengl_interface->ValidateProgram
-#define glVertexAttrib1f pepper_opengl_interface->VertexAttrib1f
-#define glVertexAttrib1fv pepper_opengl_interface->VertexAttrib1fv
-#define glVertexAttrib2f pepper_opengl_interface->VertexAttrib2f
-#define glVertexAttrib2fv pepper_opengl_interface->VertexAttrib2fv
-#define glVertexAttrib3f pepper_opengl_interface->VertexAttrib3f
-#define glVertexAttrib3fv pepper_opengl_interface->VertexAttrib3fv
-#define glVertexAttrib4f pepper_opengl_interface->VertexAttrib4f
-#define glVertexAttrib4fv pepper_opengl_interface->VertexAttrib4fv
-#define glVertexAttribPointer pepper_opengl_interface->VertexAttribPointer
-#define glViewport pepper_opengl_interface->Viewport
-
-#endif /* __gl2_h_ */
-
diff --git a/ppapi/GLES2/khrplatform.h b/ppapi/GLES2/khrplatform.h
deleted file mode 100644
index 8341f71b..0000000
--- a/ppapi/GLES2/khrplatform.h
+++ /dev/null
@@ -1,269 +0,0 @@
-#ifndef __khrplatform_h_
-#define __khrplatform_h_
-
-/*
-** Copyright (c) 2008-2009 The Khronos Group Inc.
-**
-** Permission is hereby granted, free of charge, to any person obtaining a
-** copy of this software and/or associated documentation files (the
-** "Materials"), to deal in the Materials without restriction, including
-** without limitation the rights to use, copy, modify, merge, publish,
-** distribute, sublicense, and/or sell copies of the Materials, and to
-** permit persons to whom the Materials are furnished to do so, subject to
-** the following conditions:
-**
-** The above copyright notice and this permission notice shall be included
-** in all copies or substantial portions of the Materials.
-**
-** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
-** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
-** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
-** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
-** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
-*/
-
-/* Khronos platform-specific types and definitions.
- *
- * $Revision: 7820 $ on $Date: 2009-04-03 13:46:26 -0700 (Fri, 03 Apr 2009) $
- *
- * Adopters may modify this file to suit their platform. Adopters are
- * encouraged to submit platform specific modifications to the Khronos
- * group so that they can be included in future versions of this file.
- * Please submit changes by sending them to the public Khronos Bugzilla
- * (http://khronos.org/bugzilla) by filing a bug against product
- * "Khronos (general)" component "Registry".
- *
- * A predefined template which fills in some of the bug fields can be
- * reached using http://tinyurl.com/khrplatform-h-bugreport, but you
- * must create a Bugzilla login first.
- *
- *
- * See the Implementer's Guidelines for information about where this file
- * should be located on your system and for more details of its use:
- * http://www.khronos.org/registry/implementers_guide.pdf
- *
- * This file should be included as
- * #include <KHR/khrplatform.h>
- * by Khronos client API header files that use its types and defines.
- *
- * The types in khrplatform.h should only be used to define API-specific types.
- *
- * Types defined in khrplatform.h:
- * khronos_int8_t signed 8 bit
- * khronos_uint8_t unsigned 8 bit
- * khronos_int16_t signed 16 bit
- * khronos_uint16_t unsigned 16 bit
- * khronos_int32_t signed 32 bit
- * khronos_uint32_t unsigned 32 bit
- * khronos_int64_t signed 64 bit
- * khronos_uint64_t unsigned 64 bit
- * khronos_intptr_t signed same number of bits as a pointer
- * khronos_uintptr_t unsigned same number of bits as a pointer
- * khronos_ssize_t signed size
- * khronos_usize_t unsigned size
- * khronos_float_t signed 32 bit floating point
- * khronos_time_ns_t unsigned 64 bit time in nanoseconds
- * khronos_utime_nanoseconds_t unsigned time interval or absolute time in
- * nanoseconds
- * khronos_stime_nanoseconds_t signed time interval in nanoseconds
- * khronos_boolean_enum_t enumerated boolean type. This should
- * only be used as a base type when a client API's boolean type is
- * an enum. Client APIs which use an integer or other type for
- * booleans cannot use this as the base type for their boolean.
- *
- * Tokens defined in khrplatform.h:
- *
- * KHRONOS_FALSE, KHRONOS_TRUE Enumerated boolean false/true values.
- *
- * KHRONOS_SUPPORT_INT64 is 1 if 64 bit integers are supported; otherwise 0.
- * KHRONOS_SUPPORT_FLOAT is 1 if floats are supported; otherwise 0.
- *
- * Calling convention macros defined in this file:
- * KHRONOS_APICALL
- * KHRONOS_APIENTRY
- * KHRONOS_APIATTRIBUTES
- *
- * These may be used in function prototypes as:
- *
- * KHRONOS_APICALL void KHRONOS_APIENTRY funcname(
- * int arg1,
- * int arg2) KHRONOS_APIATTRIBUTES;
- */
-
-/*-------------------------------------------------------------------------
- * Definition of KHRONOS_APICALL
- *-------------------------------------------------------------------------
- * This precedes the return type of the function in the function prototype.
- */
-#if defined(_WIN32) && !defined(__SCITECH_SNAP__)
-# define KHRONOS_APICALL __declspec(dllimport)
-#elif defined (__SYMBIAN32__)
-# define KHRONOS_APICALL IMPORT_C
-#else
-# define KHRONOS_APICALL
-#endif
-
-/*-------------------------------------------------------------------------
- * Definition of KHRONOS_APIENTRY
- *-------------------------------------------------------------------------
- * This follows the return type of the function and precedes the function
- * name in the function prototype.
- */
-#if defined(_WIN32) && !defined(_WIN32_WCE) && !defined(__SCITECH_SNAP__)
- /* Win32 but not WinCE */
-# define KHRONOS_APIENTRY __stdcall
-#else
-# define KHRONOS_APIENTRY
-#endif
-
-/*-------------------------------------------------------------------------
- * Definition of KHRONOS_APIATTRIBUTES
- *-------------------------------------------------------------------------
- * This follows the closing parenthesis of the function prototype arguments.
- */
-#if defined (__ARMCC_2__)
-#define KHRONOS_APIATTRIBUTES __softfp
-#else
-#define KHRONOS_APIATTRIBUTES
-#endif
-
-/*-------------------------------------------------------------------------
- * basic type definitions
- *-----------------------------------------------------------------------*/
-#if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) || defined(__GNUC__) || defined(__SCO__) || defined(__USLC__)
-
-
-/*
- * Using <stdint.h>
- */
-#include <stdint.h>
-typedef int32_t khronos_int32_t;
-typedef uint32_t khronos_uint32_t;
-typedef int64_t khronos_int64_t;
-typedef uint64_t khronos_uint64_t;
-#define KHRONOS_SUPPORT_INT64 1
-#define KHRONOS_SUPPORT_FLOAT 1
-
-#elif defined(__VMS ) || defined(__sgi)
-
-/*
- * Using <inttypes.h>
- */
-#include <inttypes.h>
-typedef int32_t khronos_int32_t;
-typedef uint32_t khronos_uint32_t;
-typedef int64_t khronos_int64_t;
-typedef uint64_t khronos_uint64_t;
-#define KHRONOS_SUPPORT_INT64 1
-#define KHRONOS_SUPPORT_FLOAT 1
-
-#elif defined(_WIN32) && !defined(__SCITECH_SNAP__)
-
-/*
- * Win32
- */
-typedef __int32 khronos_int32_t;
-typedef unsigned __int32 khronos_uint32_t;
-typedef __int64 khronos_int64_t;
-typedef unsigned __int64 khronos_uint64_t;
-#define KHRONOS_SUPPORT_INT64 1
-#define KHRONOS_SUPPORT_FLOAT 1
-
-#elif defined(__sun__) || defined(__digital__)
-
-/*
- * Sun or Digital
- */
-typedef int khronos_int32_t;
-typedef unsigned int khronos_uint32_t;
-#if defined(__arch64__) || defined(_LP64)
-typedef long int khronos_int64_t;
-typedef unsigned long int khronos_uint64_t;
-#else
-typedef long long int khronos_int64_t;
-typedef unsigned long long int khronos_uint64_t;
-#endif /* __arch64__ */
-#define KHRONOS_SUPPORT_INT64 1
-#define KHRONOS_SUPPORT_FLOAT 1
-
-#elif 0
-
-/*
- * Hypothetical platform with no float or int64 support
- */
-typedef int khronos_int32_t;
-typedef unsigned int khronos_uint32_t;
-#define KHRONOS_SUPPORT_INT64 0
-#define KHRONOS_SUPPORT_FLOAT 0
-
-#else
-
-/*
- * Generic fallback
- */
-#include <stdint.h>
-typedef int32_t khronos_int32_t;
-typedef uint32_t khronos_uint32_t;
-typedef int64_t khronos_int64_t;
-typedef uint64_t khronos_uint64_t;
-#define KHRONOS_SUPPORT_INT64 1
-#define KHRONOS_SUPPORT_FLOAT 1
-
-#endif
-
-
-/*
- * Types that are (so far) the same on all platforms
- */
-typedef signed char khronos_int8_t;
-typedef unsigned char khronos_uint8_t;
-typedef signed short int khronos_int16_t;
-typedef unsigned short int khronos_uint16_t;
-typedef signed long int khronos_intptr_t;
-typedef unsigned long int khronos_uintptr_t;
-typedef signed long int khronos_ssize_t;
-typedef unsigned long int khronos_usize_t;
-
-#if KHRONOS_SUPPORT_FLOAT
-/*
- * Float type
- */
-typedef float khronos_float_t;
-#endif
-
-#if KHRONOS_SUPPORT_INT64
-/* Time types
- *
- * These types can be used to represent a time interval in nanoseconds or
- * an absolute Unadjusted System Time. Unadjusted System Time is the number
- * of nanoseconds since some arbitrary system event (e.g. since the last
- * time the system booted). The Unadjusted System Time is an unsigned
- * 64 bit value that wraps back to 0 every 584 years. Time intervals
- * may be either signed or unsigned.
- */
-typedef khronos_uint64_t khronos_utime_nanoseconds_t;
-typedef khronos_int64_t khronos_stime_nanoseconds_t;
-#endif
-
-/*
- * Dummy value used to pad enum types to 32 bits.
- */
-#ifndef KHRONOS_MAX_ENUM
-#define KHRONOS_MAX_ENUM 0x7FFFFFFF
-#endif
-
-/*
- * Enumerated boolean type
- *
- * Values other than zero should be considered to be true. Therefore
- * comparisons should not be made against KHRONOS_TRUE.
- */
-typedef enum {
- KHRONOS_FALSE = 0,
- KHRONOS_TRUE = 1,
- KHRONOS_BOOLEAN_ENUM_FORCE_SIZE = KHRONOS_MAX_ENUM
-} khronos_boolean_enum_t;
-
-#endif /* __khrplatform_h_ */
diff --git a/ppapi/c/dev/ppb_graphics_3d_dev.h b/ppapi/c/dev/ppb_graphics_3d_dev.h
index dc77571..cb67d46 100644
--- a/ppapi/c/dev/ppb_graphics_3d_dev.h
+++ b/ppapi/c/dev/ppb_graphics_3d_dev.h
@@ -78,14 +78,6 @@ struct PPB_Graphics3D_Dev {
// Any thread.
void* (*GetProcAddress)(const char* name);
- // Make a particular context current of the calling thread. Returns PP_TRUE
- // on success, PP_FALSE on failure.
- PP_Bool (*MakeCurent)(PP_Resource context);
-
- // Returns the calling thread's current context or NULL if no context is
- // current.
- PP_Resource (*GetCurrentContext)();
-
// Snapshots the rendered frame and makes it available for composition with
// the rest of the page. The alpha channel is used for translucency effects.
// One means fully opaque. Zero means fully transparent. Any thread.
diff --git a/ppapi/c/dev/ppb_opengles_dev.h b/ppapi/c/dev/ppb_opengles_dev.h
index 250c7a6..76baa89 100644
--- a/ppapi/c/dev/ppb_opengles_dev.h
+++ b/ppapi/c/dev/ppb_opengles_dev.h
@@ -4,20 +4,16 @@
// This file is auto-generated. DO NOT EDIT!
-// This interface is used to access common and lite profile OpenGL ES 2.0
-// functions.
+// OpenGL ES interface.
#ifndef PPAPI_C_DEV_PPB_OPENGLES_DEV_H_
#define PPAPI_C_DEV_PPB_OPENGLES_DEV_H_
-#include "ppapi/GLES2/khrplatform.h"
-
-#define PPB_OPENGLES_DEV_INTERFACE "PPB_OpenGLES(Dev);2.0"
-
+#ifndef __gl2_h_
typedef unsigned int GLenum;
typedef void GLvoid;
-typedef khronos_intptr_t GLintptr;
+typedef long int GLintptr;
typedef int GLsizei;
-typedef khronos_ssize_t GLsizeiptr;
+typedef long int GLsizeiptr;
typedef int GLint;
typedef unsigned char GLboolean;
typedef unsigned int GLuint;
@@ -30,204 +26,275 @@ typedef unsigned char GLubyte;
typedef int GLfixed;
typedef unsigned short GLushort;
typedef int GLclampx;
+#endif // __gl2_h_
-struct PPB_OpenGLES_Dev {
- void (*ActiveTexture)(GLenum texture);
- void (*AttachShader)(GLuint program, GLuint shader);
- void (*BindAttribLocation)(GLuint program, GLuint index, const char* name);
- void (*BindBuffer)(GLenum target, GLuint buffer);
- void (*BindFramebuffer)(GLenum target, GLuint framebuffer);
- void (*BindRenderbuffer)(GLenum target, GLuint renderbuffer);
- void (*BindTexture)(GLenum target, GLuint texture);
+#define PPB_OPENGLES2_DEV_INTERFACE "PPB_OpenGLES(Dev);2.0"
+
+struct PPB_OpenGLES2_Dev {
+ void (*ActiveTexture)(PP_Resource context, GLenum texture);
+ void (*AttachShader)(PP_Resource context, GLuint program, GLuint shader);
+ void (*BindAttribLocation)(
+ PP_Resource context, GLuint program, GLuint index, const char* name);
+ void (*BindBuffer)(PP_Resource context, GLenum target, GLuint buffer);
+ void (*BindFramebuffer)(
+ PP_Resource context, GLenum target, GLuint framebuffer);
+ void (*BindRenderbuffer)(
+ PP_Resource context, GLenum target, GLuint renderbuffer);
+ void (*BindTexture)(PP_Resource context, GLenum target, GLuint texture);
void (*BlendColor)(
- GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha);
- void (*BlendEquation)(GLenum mode);
- void (*BlendEquationSeparate)(GLenum modeRGB, GLenum modeAlpha);
- void (*BlendFunc)(GLenum sfactor, GLenum dfactor);
+ PP_Resource context, GLclampf red, GLclampf green, GLclampf blue,
+ GLclampf alpha);
+ void (*BlendEquation)(PP_Resource context, GLenum mode);
+ void (*BlendEquationSeparate)(
+ PP_Resource context, GLenum modeRGB, GLenum modeAlpha);
+ void (*BlendFunc)(PP_Resource context, GLenum sfactor, GLenum dfactor);
void (*BlendFuncSeparate)(
- GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha);
+ PP_Resource context, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha,
+ GLenum dstAlpha);
void (*BufferData)(
- GLenum target, GLsizeiptr size, const void* data, GLenum usage);
+ PP_Resource context, GLenum target, GLsizeiptr size, const void* data,
+ GLenum usage);
void (*BufferSubData)(
- GLenum target, GLintptr offset, GLsizeiptr size, const void* data);
- GLenum (*CheckFramebufferStatus)(GLenum target);
- void (*Clear)(GLbitfield mask);
+ PP_Resource context, GLenum target, GLintptr offset, GLsizeiptr size,
+ const void* data);
+ GLenum (*CheckFramebufferStatus)(PP_Resource context, GLenum target);
+ void (*Clear)(PP_Resource context, GLbitfield mask);
void (*ClearColor)(
- GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha);
- void (*ClearDepthf)(GLclampf depth);
- void (*ClearStencil)(GLint s);
+ PP_Resource context, GLclampf red, GLclampf green, GLclampf blue,
+ GLclampf alpha);
+ void (*ClearDepthf)(PP_Resource context, GLclampf depth);
+ void (*ClearStencil)(PP_Resource context, GLint s);
void (*ColorMask)(
- GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha);
- void (*CompileShader)(GLuint shader);
+ PP_Resource context, GLboolean red, GLboolean green, GLboolean blue,
+ GLboolean alpha);
+ void (*CompileShader)(PP_Resource context, GLuint shader);
void (*CompressedTexImage2D)(
- GLenum target, GLint level, GLenum internalformat, GLsizei width,
- GLsizei height, GLint border, GLsizei imageSize, const void* data);
+ PP_Resource context, GLenum target, GLint level, GLenum internalformat,
+ GLsizei width, GLsizei height, GLint border, GLsizei imageSize,
+ const void* data);
void (*CompressedTexSubImage2D)(
- GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width,
- GLsizei height, GLenum format, GLsizei imageSize, const void* data);
+ PP_Resource context, GLenum target, GLint level, GLint xoffset,
+ GLint yoffset, GLsizei width, GLsizei height, GLenum format,
+ GLsizei imageSize, const void* data);
void (*CopyTexImage2D)(
- GLenum target, GLint level, GLenum internalformat, GLint x, GLint y,
- GLsizei width, GLsizei height, GLint border);
+ PP_Resource context, GLenum target, GLint level, GLenum internalformat,
+ GLint x, GLint y, GLsizei width, GLsizei height, GLint border);
void (*CopyTexSubImage2D)(
- GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x,
- GLint y, GLsizei width, GLsizei height);
- GLuint (*CreateProgram)();
- GLuint (*CreateShader)(GLenum type);
- void (*CullFace)(GLenum mode);
- void (*DeleteBuffers)(GLsizei n, const GLuint* buffers);
- void (*DeleteFramebuffers)(GLsizei n, const GLuint* framebuffers);
- void (*DeleteProgram)(GLuint program);
- void (*DeleteRenderbuffers)(GLsizei n, const GLuint* renderbuffers);
- void (*DeleteShader)(GLuint shader);
- void (*DeleteTextures)(GLsizei n, const GLuint* textures);
- void (*DepthFunc)(GLenum func);
- void (*DepthMask)(GLboolean flag);
- void (*DepthRangef)(GLclampf zNear, GLclampf zFar);
- void (*DetachShader)(GLuint program, GLuint shader);
- void (*Disable)(GLenum cap);
- void (*DisableVertexAttribArray)(GLuint index);
- void (*DrawArrays)(GLenum mode, GLint first, GLsizei count);
+ PP_Resource context, GLenum target, GLint level, GLint xoffset,
+ GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height);
+ GLuint (*CreateProgram)(PP_Resource context);
+ GLuint (*CreateShader)(PP_Resource context, GLenum type);
+ void (*CullFace)(PP_Resource context, GLenum mode);
+ void (*DeleteBuffers)(PP_Resource context, GLsizei n, const GLuint* buffers);
+ void (*DeleteFramebuffers)(
+ PP_Resource context, GLsizei n, const GLuint* framebuffers);
+ void (*DeleteProgram)(PP_Resource context, GLuint program);
+ void (*DeleteRenderbuffers)(
+ PP_Resource context, GLsizei n, const GLuint* renderbuffers);
+ void (*DeleteShader)(PP_Resource context, GLuint shader);
+ void (*DeleteTextures)(
+ PP_Resource context, GLsizei n, const GLuint* textures);
+ void (*DepthFunc)(PP_Resource context, GLenum func);
+ void (*DepthMask)(PP_Resource context, GLboolean flag);
+ void (*DepthRangef)(PP_Resource context, GLclampf zNear, GLclampf zFar);
+ void (*DetachShader)(PP_Resource context, GLuint program, GLuint shader);
+ void (*Disable)(PP_Resource context, GLenum cap);
+ void (*DisableVertexAttribArray)(PP_Resource context, GLuint index);
+ void (*DrawArrays)(
+ PP_Resource context, GLenum mode, GLint first, GLsizei count);
void (*DrawElements)(
- GLenum mode, GLsizei count, GLenum type, const void* indices);
- void (*Enable)(GLenum cap);
- void (*EnableVertexAttribArray)(GLuint index);
- void (*Finish)();
- void (*Flush)();
+ PP_Resource context, GLenum mode, GLsizei count, GLenum type,
+ const void* indices);
+ void (*Enable)(PP_Resource context, GLenum cap);
+ void (*EnableVertexAttribArray)(PP_Resource context, GLuint index);
+ void (*Finish)(PP_Resource context);
+ void (*Flush)(PP_Resource context);
void (*FramebufferRenderbuffer)(
- GLenum target, GLenum attachment, GLenum renderbuffertarget,
- GLuint renderbuffer);
+ PP_Resource context, GLenum target, GLenum attachment,
+ GLenum renderbuffertarget, GLuint renderbuffer);
void (*FramebufferTexture2D)(
- GLenum target, GLenum attachment, GLenum textarget, GLuint texture,
- GLint level);
- void (*FrontFace)(GLenum mode);
- void (*GenBuffers)(GLsizei n, GLuint* buffers);
- void (*GenerateMipmap)(GLenum target);
- void (*GenFramebuffers)(GLsizei n, GLuint* framebuffers);
- void (*GenRenderbuffers)(GLsizei n, GLuint* renderbuffers);
- void (*GenTextures)(GLsizei n, GLuint* textures);
+ PP_Resource context, GLenum target, GLenum attachment, GLenum textarget,
+ GLuint texture, GLint level);
+ void (*FrontFace)(PP_Resource context, GLenum mode);
+ void (*GenBuffers)(PP_Resource context, GLsizei n, GLuint* buffers);
+ void (*GenerateMipmap)(PP_Resource context, GLenum target);
+ void (*GenFramebuffers)(
+ PP_Resource context, GLsizei n, GLuint* framebuffers);
+ void (*GenRenderbuffers)(
+ PP_Resource context, GLsizei n, GLuint* renderbuffers);
+ void (*GenTextures)(PP_Resource context, GLsizei n, GLuint* textures);
void (*GetActiveAttrib)(
- GLuint program, GLuint index, GLsizei bufsize, GLsizei* length,
- GLint* size, GLenum* type, char* name);
+ PP_Resource context, GLuint program, GLuint index, GLsizei bufsize,
+ GLsizei* length, GLint* size, GLenum* type, char* name);
void (*GetActiveUniform)(
- GLuint program, GLuint index, GLsizei bufsize, GLsizei* length,
- GLint* size, GLenum* type, char* name);
+ PP_Resource context, GLuint program, GLuint index, GLsizei bufsize,
+ GLsizei* length, GLint* size, GLenum* type, char* name);
void (*GetAttachedShaders)(
- GLuint program, GLsizei maxcount, GLsizei* count, GLuint* shaders);
- GLint (*GetAttribLocation)(GLuint program, const char* name);
- void (*GetBooleanv)(GLenum pname, GLboolean* params);
- void (*GetBufferParameteriv)(GLenum target, GLenum pname, GLint* params);
- GLenum (*GetError)();
- void (*GetFloatv)(GLenum pname, GLfloat* params);
+ PP_Resource context, GLuint program, GLsizei maxcount, GLsizei* count,
+ GLuint* shaders);
+ GLint (*GetAttribLocation)(
+ PP_Resource context, GLuint program, const char* name);
+ void (*GetBooleanv)(PP_Resource context, GLenum pname, GLboolean* params);
+ void (*GetBufferParameteriv)(
+ PP_Resource context, GLenum target, GLenum pname, GLint* params);
+ GLenum (*GetError)(PP_Resource context);
+ void (*GetFloatv)(PP_Resource context, GLenum pname, GLfloat* params);
void (*GetFramebufferAttachmentParameteriv)(
- GLenum target, GLenum attachment, GLenum pname, GLint* params);
- void (*GetIntegerv)(GLenum pname, GLint* params);
- void (*GetProgramiv)(GLuint program, GLenum pname, GLint* params);
+ PP_Resource context, GLenum target, GLenum attachment, GLenum pname,
+ GLint* params);
+ void (*GetIntegerv)(PP_Resource context, GLenum pname, GLint* params);
+ void (*GetProgramiv)(
+ PP_Resource context, GLuint program, GLenum pname, GLint* params);
void (*GetProgramInfoLog)(
- GLuint program, GLsizei bufsize, GLsizei* length, char* infolog);
+ PP_Resource context, GLuint program, GLsizei bufsize, GLsizei* length,
+ char* infolog);
void (*GetRenderbufferParameteriv)(
- GLenum target, GLenum pname, GLint* params);
- void (*GetShaderiv)(GLuint shader, GLenum pname, GLint* params);
+ PP_Resource context, GLenum target, GLenum pname, GLint* params);
+ void (*GetShaderiv)(
+ PP_Resource context, GLuint shader, GLenum pname, GLint* params);
void (*GetShaderInfoLog)(
- GLuint shader, GLsizei bufsize, GLsizei* length, char* infolog);
+ PP_Resource context, GLuint shader, GLsizei bufsize, GLsizei* length,
+ char* infolog);
void (*GetShaderPrecisionFormat)(
- GLenum shadertype, GLenum precisiontype, GLint* range, GLint* precision);
+ PP_Resource context, GLenum shadertype, GLenum precisiontype,
+ GLint* range, GLint* precision);
void (*GetShaderSource)(
- GLuint shader, GLsizei bufsize, GLsizei* length, char* source);
- const GLubyte* (*GetString)(GLenum name);
- void (*GetTexParameterfv)(GLenum target, GLenum pname, GLfloat* params);
- void (*GetTexParameteriv)(GLenum target, GLenum pname, GLint* params);
- void (*GetUniformfv)(GLuint program, GLint location, GLfloat* params);
- void (*GetUniformiv)(GLuint program, GLint location, GLint* params);
- GLint (*GetUniformLocation)(GLuint program, const char* name);
- void (*GetVertexAttribfv)(GLuint index, GLenum pname, GLfloat* params);
- void (*GetVertexAttribiv)(GLuint index, GLenum pname, GLint* params);
- void (*GetVertexAttribPointerv)(GLuint index, GLenum pname, void** pointer);
- void (*Hint)(GLenum target, GLenum mode);
- GLboolean (*IsBuffer)(GLuint buffer);
- GLboolean (*IsEnabled)(GLenum cap);
- GLboolean (*IsFramebuffer)(GLuint framebuffer);
- GLboolean (*IsProgram)(GLuint program);
- GLboolean (*IsRenderbuffer)(GLuint renderbuffer);
- GLboolean (*IsShader)(GLuint shader);
- GLboolean (*IsTexture)(GLuint texture);
- void (*LineWidth)(GLfloat width);
- void (*LinkProgram)(GLuint program);
- void (*PixelStorei)(GLenum pname, GLint param);
- void (*PolygonOffset)(GLfloat factor, GLfloat units);
+ PP_Resource context, GLuint shader, GLsizei bufsize, GLsizei* length,
+ char* source);
+ const GLubyte* (*GetString)(PP_Resource context, GLenum name);
+ void (*GetTexParameterfv)(
+ PP_Resource context, GLenum target, GLenum pname, GLfloat* params);
+ void (*GetTexParameteriv)(
+ PP_Resource context, GLenum target, GLenum pname, GLint* params);
+ void (*GetUniformfv)(
+ PP_Resource context, GLuint program, GLint location, GLfloat* params);
+ void (*GetUniformiv)(
+ PP_Resource context, GLuint program, GLint location, GLint* params);
+ GLint (*GetUniformLocation)(
+ PP_Resource context, GLuint program, const char* name);
+ void (*GetVertexAttribfv)(
+ PP_Resource context, GLuint index, GLenum pname, GLfloat* params);
+ void (*GetVertexAttribiv)(
+ PP_Resource context, GLuint index, GLenum pname, GLint* params);
+ void (*GetVertexAttribPointerv)(
+ PP_Resource context, GLuint index, GLenum pname, void** pointer);
+ void (*Hint)(PP_Resource context, GLenum target, GLenum mode);
+ GLboolean (*IsBuffer)(PP_Resource context, GLuint buffer);
+ GLboolean (*IsEnabled)(PP_Resource context, GLenum cap);
+ GLboolean (*IsFramebuffer)(PP_Resource context, GLuint framebuffer);
+ GLboolean (*IsProgram)(PP_Resource context, GLuint program);
+ GLboolean (*IsRenderbuffer)(PP_Resource context, GLuint renderbuffer);
+ GLboolean (*IsShader)(PP_Resource context, GLuint shader);
+ GLboolean (*IsTexture)(PP_Resource context, GLuint texture);
+ void (*LineWidth)(PP_Resource context, GLfloat width);
+ void (*LinkProgram)(PP_Resource context, GLuint program);
+ void (*PixelStorei)(PP_Resource context, GLenum pname, GLint param);
+ void (*PolygonOffset)(PP_Resource context, GLfloat factor, GLfloat units);
void (*ReadPixels)(
- GLint x, GLint y, GLsizei width, GLsizei height, GLenum format,
- GLenum type, void* pixels);
- void (*ReleaseShaderCompiler)();
+ PP_Resource context, GLint x, GLint y, GLsizei width, GLsizei height,
+ GLenum format, GLenum type, void* pixels);
+ void (*ReleaseShaderCompiler)(PP_Resource context);
void (*RenderbufferStorage)(
- GLenum target, GLenum internalformat, GLsizei width, GLsizei height);
- void (*SampleCoverage)(GLclampf value, GLboolean invert);
- void (*Scissor)(GLint x, GLint y, GLsizei width, GLsizei height);
+ PP_Resource context, GLenum target, GLenum internalformat, GLsizei width,
+ GLsizei height);
+ void (*SampleCoverage)(
+ PP_Resource context, GLclampf value, GLboolean invert);
+ void (*Scissor)(
+ PP_Resource context, GLint x, GLint y, GLsizei width, GLsizei height);
void (*ShaderBinary)(
- GLsizei n, const GLuint* shaders, GLenum binaryformat, const void* binary,
- GLsizei length);
+ PP_Resource context, GLsizei n, const GLuint* shaders,
+ GLenum binaryformat, const void* binary, GLsizei length);
void (*ShaderSource)(
- GLuint shader, GLsizei count, const char** str, const GLint* length);
- void (*StencilFunc)(GLenum func, GLint ref, GLuint mask);
+ PP_Resource context, GLuint shader, GLsizei count, const char** str,
+ const GLint* length);
+ void (*StencilFunc)(
+ PP_Resource context, GLenum func, GLint ref, GLuint mask);
void (*StencilFuncSeparate)(
- GLenum face, GLenum func, GLint ref, GLuint mask);
- void (*StencilMask)(GLuint mask);
- void (*StencilMaskSeparate)(GLenum face, GLuint mask);
- void (*StencilOp)(GLenum fail, GLenum zfail, GLenum zpass);
+ PP_Resource context, GLenum face, GLenum func, GLint ref, GLuint mask);
+ void (*StencilMask)(PP_Resource context, GLuint mask);
+ void (*StencilMaskSeparate)(PP_Resource context, GLenum face, GLuint mask);
+ void (*StencilOp)(
+ PP_Resource context, GLenum fail, GLenum zfail, GLenum zpass);
void (*StencilOpSeparate)(
- GLenum face, GLenum fail, GLenum zfail, GLenum zpass);
+ PP_Resource context, GLenum face, GLenum fail, GLenum zfail,
+ GLenum zpass);
void (*TexImage2D)(
- GLenum target, GLint level, GLint internalformat, GLsizei width,
- GLsizei height, GLint border, GLenum format, GLenum type,
+ PP_Resource context, GLenum target, GLint level, GLint internalformat,
+ GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type,
const void* pixels);
- void (*TexParameterf)(GLenum target, GLenum pname, GLfloat param);
- void (*TexParameterfv)(GLenum target, GLenum pname, const GLfloat* params);
- void (*TexParameteri)(GLenum target, GLenum pname, GLint param);
- void (*TexParameteriv)(GLenum target, GLenum pname, const GLint* params);
+ void (*TexParameterf)(
+ PP_Resource context, GLenum target, GLenum pname, GLfloat param);
+ void (*TexParameterfv)(
+ PP_Resource context, GLenum target, GLenum pname, const GLfloat* params);
+ void (*TexParameteri)(
+ PP_Resource context, GLenum target, GLenum pname, GLint param);
+ void (*TexParameteriv)(
+ PP_Resource context, GLenum target, GLenum pname, const GLint* params);
void (*TexSubImage2D)(
- GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width,
- GLsizei height, GLenum format, GLenum type, const void* pixels);
- void (*Uniform1f)(GLint location, GLfloat x);
- void (*Uniform1fv)(GLint location, GLsizei count, const GLfloat* v);
- void (*Uniform1i)(GLint location, GLint x);
- void (*Uniform1iv)(GLint location, GLsizei count, const GLint* v);
- void (*Uniform2f)(GLint location, GLfloat x, GLfloat y);
- void (*Uniform2fv)(GLint location, GLsizei count, const GLfloat* v);
- void (*Uniform2i)(GLint location, GLint x, GLint y);
- void (*Uniform2iv)(GLint location, GLsizei count, const GLint* v);
- void (*Uniform3f)(GLint location, GLfloat x, GLfloat y, GLfloat z);
- void (*Uniform3fv)(GLint location, GLsizei count, const GLfloat* v);
- void (*Uniform3i)(GLint location, GLint x, GLint y, GLint z);
- void (*Uniform3iv)(GLint location, GLsizei count, const GLint* v);
+ PP_Resource context, GLenum target, GLint level, GLint xoffset,
+ GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type,
+ const void* pixels);
+ void (*Uniform1f)(PP_Resource context, GLint location, GLfloat x);
+ void (*Uniform1fv)(
+ PP_Resource context, GLint location, GLsizei count, const GLfloat* v);
+ void (*Uniform1i)(PP_Resource context, GLint location, GLint x);
+ void (*Uniform1iv)(
+ PP_Resource context, GLint location, GLsizei count, const GLint* v);
+ void (*Uniform2f)(PP_Resource context, GLint location, GLfloat x, GLfloat y);
+ void (*Uniform2fv)(
+ PP_Resource context, GLint location, GLsizei count, const GLfloat* v);
+ void (*Uniform2i)(PP_Resource context, GLint location, GLint x, GLint y);
+ void (*Uniform2iv)(
+ PP_Resource context, GLint location, GLsizei count, const GLint* v);
+ void (*Uniform3f)(
+ PP_Resource context, GLint location, GLfloat x, GLfloat y, GLfloat z);
+ void (*Uniform3fv)(
+ PP_Resource context, GLint location, GLsizei count, const GLfloat* v);
+ void (*Uniform3i)(
+ PP_Resource context, GLint location, GLint x, GLint y, GLint z);
+ void (*Uniform3iv)(
+ PP_Resource context, GLint location, GLsizei count, const GLint* v);
void (*Uniform4f)(
- GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w);
- void (*Uniform4fv)(GLint location, GLsizei count, const GLfloat* v);
- void (*Uniform4i)(GLint location, GLint x, GLint y, GLint z, GLint w);
- void (*Uniform4iv)(GLint location, GLsizei count, const GLint* v);
+ PP_Resource context, GLint location, GLfloat x, GLfloat y, GLfloat z,
+ GLfloat w);
+ void (*Uniform4fv)(
+ PP_Resource context, GLint location, GLsizei count, const GLfloat* v);
+ void (*Uniform4i)(
+ PP_Resource context, GLint location, GLint x, GLint y, GLint z, GLint w);
+ void (*Uniform4iv)(
+ PP_Resource context, GLint location, GLsizei count, const GLint* v);
void (*UniformMatrix2fv)(
- GLint location, GLsizei count, GLboolean transpose,
+ PP_Resource context, GLint location, GLsizei count, GLboolean transpose,
const GLfloat* value);
void (*UniformMatrix3fv)(
- GLint location, GLsizei count, GLboolean transpose,
+ PP_Resource context, GLint location, GLsizei count, GLboolean transpose,
const GLfloat* value);
void (*UniformMatrix4fv)(
- GLint location, GLsizei count, GLboolean transpose,
+ PP_Resource context, GLint location, GLsizei count, GLboolean transpose,
const GLfloat* value);
- void (*UseProgram)(GLuint program);
- void (*ValidateProgram)(GLuint program);
- void (*VertexAttrib1f)(GLuint indx, GLfloat x);
- void (*VertexAttrib1fv)(GLuint indx, const GLfloat* values);
- void (*VertexAttrib2f)(GLuint indx, GLfloat x, GLfloat y);
- void (*VertexAttrib2fv)(GLuint indx, const GLfloat* values);
- void (*VertexAttrib3f)(GLuint indx, GLfloat x, GLfloat y, GLfloat z);
- void (*VertexAttrib3fv)(GLuint indx, const GLfloat* values);
+ void (*UseProgram)(PP_Resource context, GLuint program);
+ void (*ValidateProgram)(PP_Resource context, GLuint program);
+ void (*VertexAttrib1f)(PP_Resource context, GLuint indx, GLfloat x);
+ void (*VertexAttrib1fv)(
+ PP_Resource context, GLuint indx, const GLfloat* values);
+ void (*VertexAttrib2f)(
+ PP_Resource context, GLuint indx, GLfloat x, GLfloat y);
+ void (*VertexAttrib2fv)(
+ PP_Resource context, GLuint indx, const GLfloat* values);
+ void (*VertexAttrib3f)(
+ PP_Resource context, GLuint indx, GLfloat x, GLfloat y, GLfloat z);
+ void (*VertexAttrib3fv)(
+ PP_Resource context, GLuint indx, const GLfloat* values);
void (*VertexAttrib4f)(
- GLuint indx, GLfloat x, GLfloat y, GLfloat z, GLfloat w);
- void (*VertexAttrib4fv)(GLuint indx, const GLfloat* values);
+ PP_Resource context, GLuint indx, GLfloat x, GLfloat y, GLfloat z,
+ GLfloat w);
+ void (*VertexAttrib4fv)(
+ PP_Resource context, GLuint indx, const GLfloat* values);
void (*VertexAttribPointer)(
- GLuint indx, GLint size, GLenum type, GLboolean normalized,
- GLsizei stride, const void* ptr);
- void (*Viewport)(GLint x, GLint y, GLsizei width, GLsizei height);
- void (*SwapBuffers)();
+ PP_Resource context, GLuint indx, GLint size, GLenum type,
+ GLboolean normalized, GLsizei stride, const void* ptr);
+ void (*Viewport)(
+ PP_Resource context, GLint x, GLint y, GLsizei width, GLsizei height);
};
#endif // PPAPI_C_DEV_PPB_OPENGLES_DEV_H_
diff --git a/ppapi/cpp/dev/graphics_3d_dev.cc b/ppapi/cpp/dev/graphics_3d_dev.cc
index 8f03697..579b610 100644
--- a/ppapi/cpp/dev/graphics_3d_dev.cc
+++ b/ppapi/cpp/dev/graphics_3d_dev.cc
@@ -10,10 +10,6 @@
#include "ppapi/cpp/module.h"
#include "ppapi/cpp/module_impl.h"
-extern "C" {
-const PPB_OpenGLES_Dev* pepper_opengl_interface = NULL;
-}
-
namespace pp {
namespace {
@@ -22,13 +18,8 @@ template <> const char* interface_name<PPB_Graphics3D_Dev>() {
return PPB_GRAPHICS_3D_DEV_INTERFACE;
}
-template <> const char* interface_name<PPB_OpenGLES_Dev>() {
- return PPB_OPENGLES_DEV_INTERFACE;
-}
-
-inline void InitializeOpenGLCInterface() {
- if (!pepper_opengl_interface)
- pepper_opengl_interface = get_interface<PPB_OpenGLES_Dev>();
+template <> const char* interface_name<PPB_OpenGLES2_Dev>() {
+ return PPB_OPENGLES2_DEV_INTERFACE;
}
} // namespace
@@ -84,26 +75,14 @@ Graphics3D_Dev Graphics3D_Dev::FromResource(PP_Resource resource_id) {
return Graphics3D_Dev();
}
-bool Graphics3D_Dev::ResetCurrent() {
- return has_interface<PPB_Graphics3D_Dev>() &&
- get_interface<PPB_Graphics3D_Dev>()->MakeCurent(0);
-}
-
-Graphics3D_Dev Graphics3D_Dev::GetCurrentContext() {
- if (has_interface<PPB_Graphics3D_Dev>())
- return FromResource(
- get_interface<PPB_Graphics3D_Dev>()->GetCurrentContext());
- return Graphics3D_Dev();
-}
-
uint32_t Graphics3D_Dev::GetError() {
if (has_interface<PPB_Graphics3D_Dev>())
return get_interface<PPB_Graphics3D_Dev>()->GetError();
return PP_GRAPHICS_3D_ERROR_NOT_INITIALIZED;
}
-const PPB_OpenGLES_Dev* Graphics3D_Dev::GetImplementation() {
- return get_interface<PPB_OpenGLES_Dev>();
+const PPB_OpenGLES2_Dev* Graphics3D_Dev::GetImplementation() {
+ return get_interface<PPB_OpenGLES2_Dev>();
}
Graphics3D_Dev::Graphics3D_Dev(const Instance& instance,
@@ -111,19 +90,12 @@ Graphics3D_Dev::Graphics3D_Dev(const Instance& instance,
int32_t share_context,
const int32_t* attrib_list) {
if (has_interface<PPB_Graphics3D_Dev>() &&
- has_interface<PPB_OpenGLES_Dev>()) {
- InitializeOpenGLCInterface();
+ has_interface<PPB_OpenGLES2_Dev>()) {
PassRefFromConstructor(get_interface<PPB_Graphics3D_Dev>()->CreateContext(
instance.pp_instance(), config, share_context, attrib_list));
}
}
-bool Graphics3D_Dev::MakeCurrent() const {
- InitializeOpenGLCInterface();
- return has_interface<PPB_Graphics3D_Dev>() &&
- get_interface<PPB_Graphics3D_Dev>()->MakeCurent(pp_resource());
-}
-
bool Graphics3D_Dev::SwapBuffers() const {
return has_interface<PPB_Graphics3D_Dev>() &&
get_interface<PPB_Graphics3D_Dev>()->SwapBuffers(pp_resource());
diff --git a/ppapi/cpp/dev/graphics_3d_dev.h b/ppapi/cpp/dev/graphics_3d_dev.h
index 88fe47d..43bd0b0 100644
--- a/ppapi/cpp/dev/graphics_3d_dev.h
+++ b/ppapi/cpp/dev/graphics_3d_dev.h
@@ -27,10 +27,8 @@ class Graphics3D_Dev : public Resource {
static void* GetProcAddress(const char* name);
- static bool ResetCurrent();
- static Graphics3D_Dev GetCurrentContext();
static uint32_t GetError();
- static const PPB_OpenGLES_Dev* GetImplementation();
+ static const PPB_OpenGLES2_Dev* GetImplementation();
// Creates an is_null() Graphics3D object.
Graphics3D_Dev() {}
@@ -40,7 +38,6 @@ class Graphics3D_Dev : public Resource {
int32_t share_context,
const int32_t* attrib_list);
- bool MakeCurrent() const;
bool SwapBuffers() const;
protected:
diff --git a/ppapi/lib/gl/gles2/gl2ext_ppapi.c b/ppapi/lib/gl/gles2/gl2ext_ppapi.c
index ce2d130..1759413 100644
--- a/ppapi/lib/gl/gles2/gl2ext_ppapi.c
+++ b/ppapi/lib/gl/gles2/gl2ext_ppapi.c
@@ -4,26 +4,52 @@
#include "ppapi/lib/gl/gles2/gl2ext_ppapi.h"
-static const struct PPB_OpenGLES_Dev* g_gles2_interface;
-
-int GL_APIENTRY glInitializePPAPI(
- PP_Module module,
+#ifndef GL_FALSE
+#define GL_FALSE 0
+#endif // GL_FALSE
+
+#ifndef GL_TRUE
+#define GL_TRUE 1
+#endif // GL_TRUE
+
+#if defined(__GNUC__) && !defined(__APPLE__)
+#define PP_TLS __thread
+#elif defined(_MSC_VER)
+#define PP_TLS __declspec(thread)
+#else
+// TODO(alokp): Fix all other platforms.
+#define PP_TLS
+#endif
+
+// TODO(alokp): This will need to be thread-safe if we build gles2 as a
+// shared library.
+static const struct PPB_OpenGLES2_Dev* g_gles2_interface = NULL;
+
+// TODO(alokp): Make sure PP_TLS works on all supported platforms.
+static PP_TLS PP_Resource g_current_context = 0;
+
+GLboolean GL_APIENTRY glInitializePPAPI(
PPB_GetInterface get_browser_interface) {
- return 0;
+ if (!g_gles2_interface) {
+ g_gles2_interface = get_browser_interface(PPB_OPENGLES2_DEV_INTERFACE);
+ }
+ return g_gles2_interface ? GL_TRUE : GL_FALSE;
}
-int GL_APIENTRY glTerminatePPAPI() {
- return 0;
+GLboolean GL_APIENTRY glTerminatePPAPI() {
+ g_gles2_interface = NULL;
+ return GL_TRUE;
}
void GL_APIENTRY glSetCurrentContextPPAPI(PP_Resource context) {
+ g_current_context = context;
}
PP_Resource GL_APIENTRY glGetCurrentContextPPAPI() {
- return 0;
+ return g_current_context;
}
-const struct PPB_OpenGLES_Dev* GL_APIENTRY glGetInterfacePPAPI() {
+const struct PPB_OpenGLES2_Dev* GL_APIENTRY glGetInterfacePPAPI() {
return g_gles2_interface;
}
diff --git a/ppapi/lib/gl/gles2/gl2ext_ppapi.h b/ppapi/lib/gl/gles2/gl2ext_ppapi.h
index 63b2b32..97953ce 100644
--- a/ppapi/lib/gl/gles2/gl2ext_ppapi.h
+++ b/ppapi/lib/gl/gles2/gl2ext_ppapi.h
@@ -9,7 +9,6 @@
#include <GLES2/gl2platform.h>
-#include "ppapi/c/pp_module.h"
#include "ppapi/c/pp_resource.h"
#include "ppapi/c/ppb.h"
#include "ppapi/c/dev/ppb_opengles_dev.h"
@@ -21,13 +20,12 @@ extern "C" {
// Initializes OpenGL ES 2.0 library.
// Must be called once before making any gl calls.
// GL_FALSE is returned on failure, GL_TRUE otherwise.
-GL_APICALL int GL_APIENTRY glInitializePPAPI(
- PP_Module module,
+GL_APICALL GLboolean GL_APIENTRY glInitializePPAPI(
PPB_GetInterface get_browser_interface);
// Terminates OpenGL ES 2.0 library.
// GL_FALSE is returned on failure, GL_TRUE otherwise.
-GL_APICALL int GL_APIENTRY glTerminatePPAPI();
+GL_APICALL GLboolean GL_APIENTRY glTerminatePPAPI();
// Sets context to be used for rendering in the current thread.
GL_APICALL void GL_APIENTRY glSetCurrentContextPPAPI(PP_Resource context);
@@ -37,7 +35,7 @@ GL_APICALL void GL_APIENTRY glSetCurrentContextPPAPI(PP_Resource context);
GL_APICALL PP_Resource GL_APIENTRY glGetCurrentContextPPAPI();
// Returns OpenGL ES 2.0 interface.
-GL_APICALL const struct PPB_OpenGLES_Dev* GL_APIENTRY glGetInterfacePPAPI();
+GL_APICALL const struct PPB_OpenGLES2_Dev* GL_APIENTRY glGetInterfacePPAPI();
#ifdef __cplusplus
}
diff --git a/ppapi/lib/gl/gles2/gles2.c b/ppapi/lib/gl/gles2/gles2.c
index 69c4de8..fe27e1b 100644
--- a/ppapi/lib/gl/gles2/gles2.c
+++ b/ppapi/lib/gl/gles2/gles2.c
@@ -5,512 +5,749 @@
// This file is auto-generated. DO NOT EDIT!
#include <GLES2/gl2.h>
+#include "ppapi/lib/gl/gles2/gl2ext_ppapi.h"
void GL_APIENTRY glActiveTexture(GLenum texture) {
+ glGetInterfacePPAPI()->ActiveTexture(glGetCurrentContextPPAPI(), texture);
}
void GL_APIENTRY glAttachShader(GLuint program, GLuint shader) {
+ glGetInterfacePPAPI()->AttachShader(
+ glGetCurrentContextPPAPI(), program, shader);
}
void GL_APIENTRY glBindAttribLocation(
GLuint program, GLuint index, const char* name) {
+ glGetInterfacePPAPI()->BindAttribLocation(
+ glGetCurrentContextPPAPI(), program, index, name);
}
void GL_APIENTRY glBindBuffer(GLenum target, GLuint buffer) {
+ glGetInterfacePPAPI()->BindBuffer(
+ glGetCurrentContextPPAPI(), target, buffer);
}
void GL_APIENTRY glBindFramebuffer(GLenum target, GLuint framebuffer) {
+ glGetInterfacePPAPI()->BindFramebuffer(
+ glGetCurrentContextPPAPI(), target, framebuffer);
}
void GL_APIENTRY glBindRenderbuffer(GLenum target, GLuint renderbuffer) {
+ glGetInterfacePPAPI()->BindRenderbuffer(
+ glGetCurrentContextPPAPI(), target, renderbuffer);
}
void GL_APIENTRY glBindTexture(GLenum target, GLuint texture) {
+ glGetInterfacePPAPI()->BindTexture(
+ glGetCurrentContextPPAPI(), target, texture);
}
void GL_APIENTRY glBlendColor(
GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha) {
+ glGetInterfacePPAPI()->BlendColor(
+ glGetCurrentContextPPAPI(), red, green, blue, alpha);
}
void GL_APIENTRY glBlendEquation(GLenum mode) {
+ glGetInterfacePPAPI()->BlendEquation(glGetCurrentContextPPAPI(), mode);
}
void GL_APIENTRY glBlendEquationSeparate(GLenum modeRGB, GLenum modeAlpha) {
+ glGetInterfacePPAPI()->BlendEquationSeparate(
+ glGetCurrentContextPPAPI(), modeRGB, modeAlpha);
}
void GL_APIENTRY glBlendFunc(GLenum sfactor, GLenum dfactor) {
+ glGetInterfacePPAPI()->BlendFunc(
+ glGetCurrentContextPPAPI(), sfactor, dfactor);
}
void GL_APIENTRY glBlendFuncSeparate(
GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha) {
+ glGetInterfacePPAPI()->BlendFuncSeparate(
+ glGetCurrentContextPPAPI(), srcRGB, dstRGB, srcAlpha, dstAlpha);
}
void GL_APIENTRY glBufferData(
GLenum target, GLsizeiptr size, const void* data, GLenum usage) {
+ glGetInterfacePPAPI()->BufferData(
+ glGetCurrentContextPPAPI(), target, size, data, usage);
}
void GL_APIENTRY glBufferSubData(
GLenum target, GLintptr offset, GLsizeiptr size, const void* data) {
+ glGetInterfacePPAPI()->BufferSubData(
+ glGetCurrentContextPPAPI(), target, offset, size, data);
}
GLenum GL_APIENTRY glCheckFramebufferStatus(GLenum target) {
- return 0;
+ return glGetInterfacePPAPI()->CheckFramebufferStatus(
+ glGetCurrentContextPPAPI(), target);
}
void GL_APIENTRY glClear(GLbitfield mask) {
+ glGetInterfacePPAPI()->Clear(glGetCurrentContextPPAPI(), mask);
}
void GL_APIENTRY glClearColor(
GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha) {
+ glGetInterfacePPAPI()->ClearColor(
+ glGetCurrentContextPPAPI(), red, green, blue, alpha);
}
void GL_APIENTRY glClearDepthf(GLclampf depth) {
+ glGetInterfacePPAPI()->ClearDepthf(glGetCurrentContextPPAPI(), depth);
}
void GL_APIENTRY glClearStencil(GLint s) {
+ glGetInterfacePPAPI()->ClearStencil(glGetCurrentContextPPAPI(), s);
}
void GL_APIENTRY glColorMask(
GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha) {
+ glGetInterfacePPAPI()->ColorMask(
+ glGetCurrentContextPPAPI(), red, green, blue, alpha);
}
void GL_APIENTRY glCompileShader(GLuint shader) {
+ glGetInterfacePPAPI()->CompileShader(glGetCurrentContextPPAPI(), shader);
}
void GL_APIENTRY glCompressedTexImage2D(
GLenum target, GLint level, GLenum internalformat, GLsizei width,
GLsizei height, GLint border, GLsizei imageSize, const void* data) {
+ glGetInterfacePPAPI()->CompressedTexImage2D(
+ glGetCurrentContextPPAPI(), target, level, internalformat, width, height,
+ border, imageSize, data);
}
void GL_APIENTRY glCompressedTexSubImage2D(
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width,
GLsizei height, GLenum format, GLsizei imageSize, const void* data) {
+ glGetInterfacePPAPI()->CompressedTexSubImage2D(
+ glGetCurrentContextPPAPI(), target, level, xoffset, yoffset, width,
+ height, format, imageSize, data);
}
void GL_APIENTRY glCopyTexImage2D(
GLenum target, GLint level, GLenum internalformat, GLint x, GLint y,
GLsizei width, GLsizei height, GLint border) {
+ glGetInterfacePPAPI()->CopyTexImage2D(
+ glGetCurrentContextPPAPI(), target, level, internalformat, x, y, width,
+ height, border);
}
void GL_APIENTRY glCopyTexSubImage2D(
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y,
GLsizei width, GLsizei height) {
+ glGetInterfacePPAPI()->CopyTexSubImage2D(
+ glGetCurrentContextPPAPI(), target, level, xoffset, yoffset, x, y, width,
+ height);
}
GLuint GL_APIENTRY glCreateProgram() {
- return 0;
+ return glGetInterfacePPAPI()->CreateProgram(glGetCurrentContextPPAPI());
}
GLuint GL_APIENTRY glCreateShader(GLenum type) {
- return 0;
+ return glGetInterfacePPAPI()->CreateShader(glGetCurrentContextPPAPI(), type);
}
void GL_APIENTRY glCullFace(GLenum mode) {
+ glGetInterfacePPAPI()->CullFace(glGetCurrentContextPPAPI(), mode);
}
void GL_APIENTRY glDeleteBuffers(GLsizei n, const GLuint* buffers) {
+ glGetInterfacePPAPI()->DeleteBuffers(glGetCurrentContextPPAPI(), n, buffers);
}
void GL_APIENTRY glDeleteFramebuffers(GLsizei n, const GLuint* framebuffers) {
+ glGetInterfacePPAPI()->DeleteFramebuffers(
+ glGetCurrentContextPPAPI(), n, framebuffers);
}
void GL_APIENTRY glDeleteProgram(GLuint program) {
+ glGetInterfacePPAPI()->DeleteProgram(glGetCurrentContextPPAPI(), program);
}
void GL_APIENTRY glDeleteRenderbuffers(
GLsizei n, const GLuint* renderbuffers) {
+ glGetInterfacePPAPI()->DeleteRenderbuffers(
+ glGetCurrentContextPPAPI(), n, renderbuffers);
}
void GL_APIENTRY glDeleteShader(GLuint shader) {
+ glGetInterfacePPAPI()->DeleteShader(glGetCurrentContextPPAPI(), shader);
}
void GL_APIENTRY glDeleteTextures(GLsizei n, const GLuint* textures) {
+ glGetInterfacePPAPI()->DeleteTextures(
+ glGetCurrentContextPPAPI(), n, textures);
}
void GL_APIENTRY glDepthFunc(GLenum func) {
+ glGetInterfacePPAPI()->DepthFunc(glGetCurrentContextPPAPI(), func);
}
void GL_APIENTRY glDepthMask(GLboolean flag) {
+ glGetInterfacePPAPI()->DepthMask(glGetCurrentContextPPAPI(), flag);
}
void GL_APIENTRY glDepthRangef(GLclampf zNear, GLclampf zFar) {
+ glGetInterfacePPAPI()->DepthRangef(glGetCurrentContextPPAPI(), zNear, zFar);
}
void GL_APIENTRY glDetachShader(GLuint program, GLuint shader) {
+ glGetInterfacePPAPI()->DetachShader(
+ glGetCurrentContextPPAPI(), program, shader);
}
void GL_APIENTRY glDisable(GLenum cap) {
+ glGetInterfacePPAPI()->Disable(glGetCurrentContextPPAPI(), cap);
}
void GL_APIENTRY glDisableVertexAttribArray(GLuint index) {
+ glGetInterfacePPAPI()->DisableVertexAttribArray(
+ glGetCurrentContextPPAPI(), index);
}
void GL_APIENTRY glDrawArrays(GLenum mode, GLint first, GLsizei count) {
+ glGetInterfacePPAPI()->DrawArrays(
+ glGetCurrentContextPPAPI(), mode, first, count);
}
void GL_APIENTRY glDrawElements(
GLenum mode, GLsizei count, GLenum type, const void* indices) {
+ glGetInterfacePPAPI()->DrawElements(
+ glGetCurrentContextPPAPI(), mode, count, type, indices);
}
void GL_APIENTRY glEnable(GLenum cap) {
+ glGetInterfacePPAPI()->Enable(glGetCurrentContextPPAPI(), cap);
}
void GL_APIENTRY glEnableVertexAttribArray(GLuint index) {
+ glGetInterfacePPAPI()->EnableVertexAttribArray(
+ glGetCurrentContextPPAPI(), index);
}
void GL_APIENTRY glFinish() {
+ glGetInterfacePPAPI()->Finish(glGetCurrentContextPPAPI());
}
void GL_APIENTRY glFlush() {
+ glGetInterfacePPAPI()->Flush(glGetCurrentContextPPAPI());
}
void GL_APIENTRY glFramebufferRenderbuffer(
GLenum target, GLenum attachment, GLenum renderbuffertarget,
GLuint renderbuffer) {
+ glGetInterfacePPAPI()->FramebufferRenderbuffer(
+ glGetCurrentContextPPAPI(), target, attachment, renderbuffertarget,
+ renderbuffer);
}
void GL_APIENTRY glFramebufferTexture2D(
GLenum target, GLenum attachment, GLenum textarget, GLuint texture,
GLint level) {
+ glGetInterfacePPAPI()->FramebufferTexture2D(
+ glGetCurrentContextPPAPI(), target, attachment, textarget, texture,
+ level);
}
void GL_APIENTRY glFrontFace(GLenum mode) {
+ glGetInterfacePPAPI()->FrontFace(glGetCurrentContextPPAPI(), mode);
}
void GL_APIENTRY glGenBuffers(GLsizei n, GLuint* buffers) {
+ glGetInterfacePPAPI()->GenBuffers(glGetCurrentContextPPAPI(), n, buffers);
}
void GL_APIENTRY glGenerateMipmap(GLenum target) {
+ glGetInterfacePPAPI()->GenerateMipmap(glGetCurrentContextPPAPI(), target);
}
void GL_APIENTRY glGenFramebuffers(GLsizei n, GLuint* framebuffers) {
+ glGetInterfacePPAPI()->GenFramebuffers(
+ glGetCurrentContextPPAPI(), n, framebuffers);
}
void GL_APIENTRY glGenRenderbuffers(GLsizei n, GLuint* renderbuffers) {
+ glGetInterfacePPAPI()->GenRenderbuffers(
+ glGetCurrentContextPPAPI(), n, renderbuffers);
}
void GL_APIENTRY glGenTextures(GLsizei n, GLuint* textures) {
+ glGetInterfacePPAPI()->GenTextures(glGetCurrentContextPPAPI(), n, textures);
}
void GL_APIENTRY glGetActiveAttrib(
GLuint program, GLuint index, GLsizei bufsize, GLsizei* length, GLint* size,
GLenum* type, char* name) {
+ glGetInterfacePPAPI()->GetActiveAttrib(
+ glGetCurrentContextPPAPI(), program, index, bufsize, length, size, type,
+ name);
}
void GL_APIENTRY glGetActiveUniform(
GLuint program, GLuint index, GLsizei bufsize, GLsizei* length, GLint* size,
GLenum* type, char* name) {
+ glGetInterfacePPAPI()->GetActiveUniform(
+ glGetCurrentContextPPAPI(), program, index, bufsize, length, size, type,
+ name);
}
void GL_APIENTRY glGetAttachedShaders(
GLuint program, GLsizei maxcount, GLsizei* count, GLuint* shaders) {
+ glGetInterfacePPAPI()->GetAttachedShaders(
+ glGetCurrentContextPPAPI(), program, maxcount, count, shaders);
}
GLint GL_APIENTRY glGetAttribLocation(GLuint program, const char* name) {
- return 0;
+ return glGetInterfacePPAPI()->GetAttribLocation(
+ glGetCurrentContextPPAPI(), program, name);
}
void GL_APIENTRY glGetBooleanv(GLenum pname, GLboolean* params) {
+ glGetInterfacePPAPI()->GetBooleanv(
+ glGetCurrentContextPPAPI(), pname, params);
}
void GL_APIENTRY glGetBufferParameteriv(
GLenum target, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetBufferParameteriv(
+ glGetCurrentContextPPAPI(), target, pname, params);
}
GLenum GL_APIENTRY glGetError() {
- return 0;
+ return glGetInterfacePPAPI()->GetError(glGetCurrentContextPPAPI());
}
void GL_APIENTRY glGetFloatv(GLenum pname, GLfloat* params) {
+ glGetInterfacePPAPI()->GetFloatv(glGetCurrentContextPPAPI(), pname, params);
}
void GL_APIENTRY glGetFramebufferAttachmentParameteriv(
GLenum target, GLenum attachment, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetFramebufferAttachmentParameteriv(
+ glGetCurrentContextPPAPI(), target, attachment, pname, params);
}
void GL_APIENTRY glGetIntegerv(GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetIntegerv(
+ glGetCurrentContextPPAPI(), pname, params);
}
void GL_APIENTRY glGetProgramiv(GLuint program, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetProgramiv(
+ glGetCurrentContextPPAPI(), program, pname, params);
}
void GL_APIENTRY glGetProgramInfoLog(
GLuint program, GLsizei bufsize, GLsizei* length, char* infolog) {
+ glGetInterfacePPAPI()->GetProgramInfoLog(
+ glGetCurrentContextPPAPI(), program, bufsize, length, infolog);
}
void GL_APIENTRY glGetRenderbufferParameteriv(
GLenum target, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetRenderbufferParameteriv(
+ glGetCurrentContextPPAPI(), target, pname, params);
}
void GL_APIENTRY glGetShaderiv(GLuint shader, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetShaderiv(
+ glGetCurrentContextPPAPI(), shader, pname, params);
}
void GL_APIENTRY glGetShaderInfoLog(
GLuint shader, GLsizei bufsize, GLsizei* length, char* infolog) {
+ glGetInterfacePPAPI()->GetShaderInfoLog(
+ glGetCurrentContextPPAPI(), shader, bufsize, length, infolog);
}
void GL_APIENTRY glGetShaderPrecisionFormat(
GLenum shadertype, GLenum precisiontype, GLint* range, GLint* precision) {
+ glGetInterfacePPAPI()->GetShaderPrecisionFormat(
+ glGetCurrentContextPPAPI(), shadertype, precisiontype, range, precision);
}
void GL_APIENTRY glGetShaderSource(
GLuint shader, GLsizei bufsize, GLsizei* length, char* source) {
+ glGetInterfacePPAPI()->GetShaderSource(
+ glGetCurrentContextPPAPI(), shader, bufsize, length, source);
}
const GLubyte* GL_APIENTRY glGetString(GLenum name) {
- return 0;
+ return glGetInterfacePPAPI()->GetString(glGetCurrentContextPPAPI(), name);
}
void GL_APIENTRY glGetTexParameterfv(
GLenum target, GLenum pname, GLfloat* params) {
+ glGetInterfacePPAPI()->GetTexParameterfv(
+ glGetCurrentContextPPAPI(), target, pname, params);
}
void GL_APIENTRY glGetTexParameteriv(
GLenum target, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetTexParameteriv(
+ glGetCurrentContextPPAPI(), target, pname, params);
}
void GL_APIENTRY glGetUniformfv(
GLuint program, GLint location, GLfloat* params) {
+ glGetInterfacePPAPI()->GetUniformfv(
+ glGetCurrentContextPPAPI(), program, location, params);
}
void GL_APIENTRY glGetUniformiv(
GLuint program, GLint location, GLint* params) {
+ glGetInterfacePPAPI()->GetUniformiv(
+ glGetCurrentContextPPAPI(), program, location, params);
}
GLint GL_APIENTRY glGetUniformLocation(GLuint program, const char* name) {
- return 0;
+ return glGetInterfacePPAPI()->GetUniformLocation(
+ glGetCurrentContextPPAPI(), program, name);
}
void GL_APIENTRY glGetVertexAttribfv(
GLuint index, GLenum pname, GLfloat* params) {
+ glGetInterfacePPAPI()->GetVertexAttribfv(
+ glGetCurrentContextPPAPI(), index, pname, params);
}
void GL_APIENTRY glGetVertexAttribiv(
GLuint index, GLenum pname, GLint* params) {
+ glGetInterfacePPAPI()->GetVertexAttribiv(
+ glGetCurrentContextPPAPI(), index, pname, params);
}
void GL_APIENTRY glGetVertexAttribPointerv(
GLuint index, GLenum pname, void** pointer) {
+ glGetInterfacePPAPI()->GetVertexAttribPointerv(
+ glGetCurrentContextPPAPI(), index, pname, pointer);
}
void GL_APIENTRY glHint(GLenum target, GLenum mode) {
+ glGetInterfacePPAPI()->Hint(glGetCurrentContextPPAPI(), target, mode);
}
GLboolean GL_APIENTRY glIsBuffer(GLuint buffer) {
- return 0;
+ return glGetInterfacePPAPI()->IsBuffer(glGetCurrentContextPPAPI(), buffer);
}
GLboolean GL_APIENTRY glIsEnabled(GLenum cap) {
- return 0;
+ return glGetInterfacePPAPI()->IsEnabled(glGetCurrentContextPPAPI(), cap);
}
GLboolean GL_APIENTRY glIsFramebuffer(GLuint framebuffer) {
- return 0;
+ return glGetInterfacePPAPI()->IsFramebuffer(
+ glGetCurrentContextPPAPI(), framebuffer);
}
GLboolean GL_APIENTRY glIsProgram(GLuint program) {
- return 0;
+ return glGetInterfacePPAPI()->IsProgram(glGetCurrentContextPPAPI(), program);
}
GLboolean GL_APIENTRY glIsRenderbuffer(GLuint renderbuffer) {
- return 0;
+ return glGetInterfacePPAPI()->IsRenderbuffer(
+ glGetCurrentContextPPAPI(), renderbuffer);
}
GLboolean GL_APIENTRY glIsShader(GLuint shader) {
- return 0;
+ return glGetInterfacePPAPI()->IsShader(glGetCurrentContextPPAPI(), shader);
}
GLboolean GL_APIENTRY glIsTexture(GLuint texture) {
- return 0;
+ return glGetInterfacePPAPI()->IsTexture(glGetCurrentContextPPAPI(), texture);
}
void GL_APIENTRY glLineWidth(GLfloat width) {
+ glGetInterfacePPAPI()->LineWidth(glGetCurrentContextPPAPI(), width);
}
void GL_APIENTRY glLinkProgram(GLuint program) {
+ glGetInterfacePPAPI()->LinkProgram(glGetCurrentContextPPAPI(), program);
}
void GL_APIENTRY glPixelStorei(GLenum pname, GLint param) {
+ glGetInterfacePPAPI()->PixelStorei(glGetCurrentContextPPAPI(), pname, param);
}
void GL_APIENTRY glPolygonOffset(GLfloat factor, GLfloat units) {
+ glGetInterfacePPAPI()->PolygonOffset(
+ glGetCurrentContextPPAPI(), factor, units);
}
void GL_APIENTRY glReadPixels(
GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type,
void* pixels) {
+ glGetInterfacePPAPI()->ReadPixels(
+ glGetCurrentContextPPAPI(), x, y, width, height, format, type, pixels);
}
void GL_APIENTRY glReleaseShaderCompiler() {
+ glGetInterfacePPAPI()->ReleaseShaderCompiler(glGetCurrentContextPPAPI());
}
void GL_APIENTRY glRenderbufferStorage(
GLenum target, GLenum internalformat, GLsizei width, GLsizei height) {
+ glGetInterfacePPAPI()->RenderbufferStorage(
+ glGetCurrentContextPPAPI(), target, internalformat, width, height);
}
void GL_APIENTRY glSampleCoverage(GLclampf value, GLboolean invert) {
+ glGetInterfacePPAPI()->SampleCoverage(
+ glGetCurrentContextPPAPI(), value, invert);
}
void GL_APIENTRY glScissor(GLint x, GLint y, GLsizei width, GLsizei height) {
+ glGetInterfacePPAPI()->Scissor(
+ glGetCurrentContextPPAPI(), x, y, width, height);
}
void GL_APIENTRY glShaderBinary(
GLsizei n, const GLuint* shaders, GLenum binaryformat, const void* binary,
GLsizei length) {
+ glGetInterfacePPAPI()->ShaderBinary(
+ glGetCurrentContextPPAPI(), n, shaders, binaryformat, binary, length);
}
void GL_APIENTRY glShaderSource(
GLuint shader, GLsizei count, const char** str, const GLint* length) {
+ glGetInterfacePPAPI()->ShaderSource(
+ glGetCurrentContextPPAPI(), shader, count, str, length);
}
void GL_APIENTRY glStencilFunc(GLenum func, GLint ref, GLuint mask) {
+ glGetInterfacePPAPI()->StencilFunc(
+ glGetCurrentContextPPAPI(), func, ref, mask);
}
void GL_APIENTRY glStencilFuncSeparate(
GLenum face, GLenum func, GLint ref, GLuint mask) {
+ glGetInterfacePPAPI()->StencilFuncSeparate(
+ glGetCurrentContextPPAPI(), face, func, ref, mask);
}
void GL_APIENTRY glStencilMask(GLuint mask) {
+ glGetInterfacePPAPI()->StencilMask(glGetCurrentContextPPAPI(), mask);
}
void GL_APIENTRY glStencilMaskSeparate(GLenum face, GLuint mask) {
+ glGetInterfacePPAPI()->StencilMaskSeparate(
+ glGetCurrentContextPPAPI(), face, mask);
}
void GL_APIENTRY glStencilOp(GLenum fail, GLenum zfail, GLenum zpass) {
+ glGetInterfacePPAPI()->StencilOp(
+ glGetCurrentContextPPAPI(), fail, zfail, zpass);
}
void GL_APIENTRY glStencilOpSeparate(
GLenum face, GLenum fail, GLenum zfail, GLenum zpass) {
+ glGetInterfacePPAPI()->StencilOpSeparate(
+ glGetCurrentContextPPAPI(), face, fail, zfail, zpass);
}
void GL_APIENTRY glTexImage2D(
GLenum target, GLint level, GLint internalformat, GLsizei width,
GLsizei height, GLint border, GLenum format, GLenum type,
const void* pixels) {
+ glGetInterfacePPAPI()->TexImage2D(
+ glGetCurrentContextPPAPI(), target, level, internalformat, width, height,
+ border, format, type, pixels);
}
void GL_APIENTRY glTexParameterf(GLenum target, GLenum pname, GLfloat param) {
+ glGetInterfacePPAPI()->TexParameterf(
+ glGetCurrentContextPPAPI(), target, pname, param);
}
void GL_APIENTRY glTexParameterfv(
GLenum target, GLenum pname, const GLfloat* params) {
+ glGetInterfacePPAPI()->TexParameterfv(
+ glGetCurrentContextPPAPI(), target, pname, params);
}
void GL_APIENTRY glTexParameteri(GLenum target, GLenum pname, GLint param) {
+ glGetInterfacePPAPI()->TexParameteri(
+ glGetCurrentContextPPAPI(), target, pname, param);
}
void GL_APIENTRY glTexParameteriv(
GLenum target, GLenum pname, const GLint* params) {
+ glGetInterfacePPAPI()->TexParameteriv(
+ glGetCurrentContextPPAPI(), target, pname, params);
}
void GL_APIENTRY glTexSubImage2D(
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width,
GLsizei height, GLenum format, GLenum type, const void* pixels) {
+ glGetInterfacePPAPI()->TexSubImage2D(
+ glGetCurrentContextPPAPI(), target, level, xoffset, yoffset, width,
+ height, format, type, pixels);
}
void GL_APIENTRY glUniform1f(GLint location, GLfloat x) {
+ glGetInterfacePPAPI()->Uniform1f(glGetCurrentContextPPAPI(), location, x);
}
void GL_APIENTRY glUniform1fv(
GLint location, GLsizei count, const GLfloat* v) {
+ glGetInterfacePPAPI()->Uniform1fv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform1i(GLint location, GLint x) {
+ glGetInterfacePPAPI()->Uniform1i(glGetCurrentContextPPAPI(), location, x);
}
void GL_APIENTRY glUniform1iv(GLint location, GLsizei count, const GLint* v) {
+ glGetInterfacePPAPI()->Uniform1iv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform2f(GLint location, GLfloat x, GLfloat y) {
+ glGetInterfacePPAPI()->Uniform2f(glGetCurrentContextPPAPI(), location, x, y);
}
void GL_APIENTRY glUniform2fv(
GLint location, GLsizei count, const GLfloat* v) {
+ glGetInterfacePPAPI()->Uniform2fv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform2i(GLint location, GLint x, GLint y) {
+ glGetInterfacePPAPI()->Uniform2i(glGetCurrentContextPPAPI(), location, x, y);
}
void GL_APIENTRY glUniform2iv(GLint location, GLsizei count, const GLint* v) {
+ glGetInterfacePPAPI()->Uniform2iv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform3f(GLint location, GLfloat x, GLfloat y, GLfloat z) {
+ glGetInterfacePPAPI()->Uniform3f(
+ glGetCurrentContextPPAPI(), location, x, y, z);
}
void GL_APIENTRY glUniform3fv(
GLint location, GLsizei count, const GLfloat* v) {
+ glGetInterfacePPAPI()->Uniform3fv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform3i(GLint location, GLint x, GLint y, GLint z) {
+ glGetInterfacePPAPI()->Uniform3i(
+ glGetCurrentContextPPAPI(), location, x, y, z);
}
void GL_APIENTRY glUniform3iv(GLint location, GLsizei count, const GLint* v) {
+ glGetInterfacePPAPI()->Uniform3iv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform4f(
GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w) {
+ glGetInterfacePPAPI()->Uniform4f(
+ glGetCurrentContextPPAPI(), location, x, y, z, w);
}
void GL_APIENTRY glUniform4fv(
GLint location, GLsizei count, const GLfloat* v) {
+ glGetInterfacePPAPI()->Uniform4fv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniform4i(
GLint location, GLint x, GLint y, GLint z, GLint w) {
+ glGetInterfacePPAPI()->Uniform4i(
+ glGetCurrentContextPPAPI(), location, x, y, z, w);
}
void GL_APIENTRY glUniform4iv(GLint location, GLsizei count, const GLint* v) {
+ glGetInterfacePPAPI()->Uniform4iv(
+ glGetCurrentContextPPAPI(), location, count, v);
}
void GL_APIENTRY glUniformMatrix2fv(
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) {
+ glGetInterfacePPAPI()->UniformMatrix2fv(
+ glGetCurrentContextPPAPI(), location, count, transpose, value);
}
void GL_APIENTRY glUniformMatrix3fv(
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) {
+ glGetInterfacePPAPI()->UniformMatrix3fv(
+ glGetCurrentContextPPAPI(), location, count, transpose, value);
}
void GL_APIENTRY glUniformMatrix4fv(
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value) {
+ glGetInterfacePPAPI()->UniformMatrix4fv(
+ glGetCurrentContextPPAPI(), location, count, transpose, value);
}
void GL_APIENTRY glUseProgram(GLuint program) {
+ glGetInterfacePPAPI()->UseProgram(glGetCurrentContextPPAPI(), program);
}
void GL_APIENTRY glValidateProgram(GLuint program) {
+ glGetInterfacePPAPI()->ValidateProgram(glGetCurrentContextPPAPI(), program);
}
void GL_APIENTRY glVertexAttrib1f(GLuint indx, GLfloat x) {
+ glGetInterfacePPAPI()->VertexAttrib1f(glGetCurrentContextPPAPI(), indx, x);
}
void GL_APIENTRY glVertexAttrib1fv(GLuint indx, const GLfloat* values) {
+ glGetInterfacePPAPI()->VertexAttrib1fv(
+ glGetCurrentContextPPAPI(), indx, values);
}
void GL_APIENTRY glVertexAttrib2f(GLuint indx, GLfloat x, GLfloat y) {
+ glGetInterfacePPAPI()->VertexAttrib2f(
+ glGetCurrentContextPPAPI(), indx, x, y);
}
void GL_APIENTRY glVertexAttrib2fv(GLuint indx, const GLfloat* values) {
+ glGetInterfacePPAPI()->VertexAttrib2fv(
+ glGetCurrentContextPPAPI(), indx, values);
}
void GL_APIENTRY glVertexAttrib3f(
GLuint indx, GLfloat x, GLfloat y, GLfloat z) {
+ glGetInterfacePPAPI()->VertexAttrib3f(
+ glGetCurrentContextPPAPI(), indx, x, y, z);
}
void GL_APIENTRY glVertexAttrib3fv(GLuint indx, const GLfloat* values) {
+ glGetInterfacePPAPI()->VertexAttrib3fv(
+ glGetCurrentContextPPAPI(), indx, values);
}
void GL_APIENTRY glVertexAttrib4f(
GLuint indx, GLfloat x, GLfloat y, GLfloat z, GLfloat w) {
+ glGetInterfacePPAPI()->VertexAttrib4f(
+ glGetCurrentContextPPAPI(), indx, x, y, z, w);
}
void GL_APIENTRY glVertexAttrib4fv(GLuint indx, const GLfloat* values) {
+ glGetInterfacePPAPI()->VertexAttrib4fv(
+ glGetCurrentContextPPAPI(), indx, values);
}
void GL_APIENTRY glVertexAttribPointer(
GLuint indx, GLint size, GLenum type, GLboolean normalized, GLsizei stride,
const void* ptr) {
+ glGetInterfacePPAPI()->VertexAttribPointer(
+ glGetCurrentContextPPAPI(), indx, size, type, normalized, stride, ptr);
}
void GL_APIENTRY glViewport(GLint x, GLint y, GLsizei width, GLsizei height) {
+ glGetInterfacePPAPI()->Viewport(
+ glGetCurrentContextPPAPI(), x, y, width, height);
}
diff --git a/ppapi/ppapi.gypi b/ppapi/ppapi.gypi
new file mode 100644
index 0000000..25d787e
--- /dev/null
+++ b/ppapi/ppapi.gypi
@@ -0,0 +1,28 @@
+# Copyright (c) 2010 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+{
+ 'variables': {
+ #
+ # ppp_entrypoints_sources is a set of source files that provide
+ # a default implementation of plugin entry-points as defined in
+ # ppp.h. Note that these source files assume that plugin is dependent
+ # on ppapi_cpp_objects target defined in ppapi.gyp.
+ #
+ # Note that we cannot compile these source files into a static library
+ # because the entry points need to be exported from the plugin.
+ #
+ 'ppp_entrypoints_sources': [
+ '<(DEPTH)/ppapi/cpp/module_embedder.h',
+ '<(DEPTH)/ppapi/cpp/ppp_entrypoints.cc',
+ ],
+ },
+}
+
+# Local Variables:
+# tab-width:2
+# indent-tabs-mode:nil
+# End:
+# vim: set expandtab tabstop=2 shiftwidth=2:
+