From c49d66b04e0014f6b3be8346e4e4906d6807eb2d Mon Sep 17 00:00:00 2001 From: "bsalomon@google.com" Date: Wed, 3 Aug 2011 14:22:30 +0000 Subject: [PATCH] Add glReadBuffer to GrGLInterface. Review URL: http://codereview.appspot.com/4841048/ git-svn-id: http://skia.googlecode.com/svn/trunk@2034 2bbb7eff-a529-9590-31e7-b0007b416f81 --- gpu/include/GrGLInterface.h | 2 ++ gpu/src/GrGLInterface.cpp | 3 ++- gpu/src/android/GrGLDefaultInterface_android.cpp | 1 + gpu/src/ios/GrGLDefaultInterface_iOS.cpp | 1 + gpu/src/mac/GrGLDefaultInterface_mac.cpp | 1 + gpu/src/mesa/GrGLDefaultInterface_mesa.cpp | 1 + gpu/src/unix/GrGLDefaultInterface_unix.cpp | 1 + gpu/src/win/GrGLDefaultInterface_win.cpp | 1 + 8 files changed, 10 insertions(+), 1 deletion(-) diff --git a/gpu/include/GrGLInterface.h b/gpu/include/GrGLInterface.h index 63ebca524..0e0c5666b 100644 --- a/gpu/include/GrGLInterface.h +++ b/gpu/include/GrGLInterface.h @@ -136,6 +136,7 @@ extern "C" { typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLMatrixModeProc)(GrGLenum mode); typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLPixelStoreiProc)(GrGLenum pname, GrGLint param); typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLPointSizeProc)(GrGLfloat size); + typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLReadBufferProc)(GrGLenum src); typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLReadPixelsProc)(GrGLint x, GrGLint y, GrGLsizei width, GrGLsizei height, GrGLenum format, GrGLenum type, GrGLvoid* pixels); typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLScissorProc)(GrGLint x, GrGLint y, GrGLsizei width, GrGLsizei height); typedef GrGLvoid (GR_GL_FUNCTION_TYPE *GrGLShadeModelProc)(GrGLenum mode); @@ -291,6 +292,7 @@ struct GrGLInterface { GrGLMatrixModeProc fMatrixMode; GrGLPixelStoreiProc fPixelStorei; GrGLPointSizeProc fPointSize; + GrGLReadBufferProc fReadBuffer; GrGLReadPixelsProc fReadPixels; GrGLScissorProc fScissor; GrGLShadeModelProc fShadeModel; diff --git a/gpu/src/GrGLInterface.cpp b/gpu/src/GrGLInterface.cpp index 9822dcbec..2a8ffaaeb 100644 --- a/gpu/src/GrGLInterface.cpp +++ b/gpu/src/GrGLInterface.cpp @@ -313,7 +313,8 @@ bool GrGLInterface::validate(GrEngine engine) const { if (kDesktop_GrGLBinding == fBindingsExported && (NULL == fLineWidth || NULL == fGetTexLevelParameteriv || - NULL == fDrawBuffer)) { + NULL == fDrawBuffer || + NULL == fReadBuffer)) { return false; } diff --git a/gpu/src/android/GrGLDefaultInterface_android.cpp b/gpu/src/android/GrGLDefaultInterface_android.cpp index b402176de..033a93cd2 100644 --- a/gpu/src/android/GrGLDefaultInterface_android.cpp +++ b/gpu/src/android/GrGLDefaultInterface_android.cpp @@ -77,6 +77,7 @@ void GrGLSetDefaultGLInterface() { NULL, // glMatrixMode glPixelStorei, NULL, // glPointSize + NULL, // glReadBuffer glReadPixels, glScissor, NULL, // glShadeModel diff --git a/gpu/src/ios/GrGLDefaultInterface_iOS.cpp b/gpu/src/ios/GrGLDefaultInterface_iOS.cpp index 8bc9fc523..7bdbcc707 100644 --- a/gpu/src/ios/GrGLDefaultInterface_iOS.cpp +++ b/gpu/src/ios/GrGLDefaultInterface_iOS.cpp @@ -76,6 +76,7 @@ void GrGLSetDefaultGLInterface() { gDefaultInterface.fMatrixMode = glMatrixMode; gDefaultInterface.fPointSize = glPointSize; gDefaultInterface.fPixelStorei = glPixelStorei; + gDefaultInterface.fReadBuffer = NULL; gDefaultInterface.fReadPixels = glReadPixels; gDefaultInterface.fScissor = glScissor; gDefaultInterface.fShadeModel = glShadeModel; diff --git a/gpu/src/mac/GrGLDefaultInterface_mac.cpp b/gpu/src/mac/GrGLDefaultInterface_mac.cpp index 16d29388d..293f14c11 100644 --- a/gpu/src/mac/GrGLDefaultInterface_mac.cpp +++ b/gpu/src/mac/GrGLDefaultInterface_mac.cpp @@ -77,6 +77,7 @@ void GrGLSetDefaultGLInterface() { gDefaultInterface.fMatrixMode = glMatrixMode; gDefaultInterface.fPointSize = glPointSize; gDefaultInterface.fPixelStorei = glPixelStorei; + gDefaultInterface.fReadBuffer = glReadBuffer; gDefaultInterface.fReadPixels = glReadPixels; gDefaultInterface.fScissor = glScissor; gDefaultInterface.fShadeModel = glShadeModel; diff --git a/gpu/src/mesa/GrGLDefaultInterface_mesa.cpp b/gpu/src/mesa/GrGLDefaultInterface_mesa.cpp index 56f2cf73f..c6be2dfe9 100644 --- a/gpu/src/mesa/GrGLDefaultInterface_mesa.cpp +++ b/gpu/src/mesa/GrGLDefaultInterface_mesa.cpp @@ -91,6 +91,7 @@ void GrGLSetDefaultGLInterface() { gDefaultInterface.fMatrixMode = glMatrixMode; gDefaultInterface.fPointSize = glPointSize; gDefaultInterface.fPixelStorei = glPixelStorei; + gDefaultInterface.fReadBuffer = glReadBuffer; gDefaultInterface.fReadPixels = glReadPixels; gDefaultInterface.fScissor = glScissor; gDefaultInterface.fShadeModel = glShadeModel; diff --git a/gpu/src/unix/GrGLDefaultInterface_unix.cpp b/gpu/src/unix/GrGLDefaultInterface_unix.cpp index e38a76b33..01725b9db 100644 --- a/gpu/src/unix/GrGLDefaultInterface_unix.cpp +++ b/gpu/src/unix/GrGLDefaultInterface_unix.cpp @@ -93,6 +93,7 @@ void GrGLSetDefaultGLInterface() { gDefaultInterface.fMatrixMode = glMatrixMode; gDefaultInterface.fPointSize = glPointSize; gDefaultInterface.fPixelStorei = glPixelStorei; + gDefaultInterface.fReadBuffer = glReadBuffer; gDefaultInterface.fReadPixels = glReadPixels; gDefaultInterface.fScissor = glScissor; gDefaultInterface.fShadeModel = glShadeModel; diff --git a/gpu/src/win/GrGLDefaultInterface_win.cpp b/gpu/src/win/GrGLDefaultInterface_win.cpp index 05f541404..1bf04578c 100644 --- a/gpu/src/win/GrGLDefaultInterface_win.cpp +++ b/gpu/src/win/GrGLDefaultInterface_win.cpp @@ -72,6 +72,7 @@ void GrGLSetDefaultGLInterface() { gDefaultInterface.fMatrixMode = glMatrixMode; gDefaultInterface.fPixelStorei = glPixelStorei; gDefaultInterface.fPointSize = glPointSize; + gDefaultInterface.fReadBuffer = glReadBuffer; gDefaultInterface.fReadPixels = glReadPixels; gDefaultInterface.fScissor = glScissor; gDefaultInterface.fShadeModel = glShadeModel;