diff options
author | Bo Hu <bohu@google.com> | 2014-12-17 20:23:36 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2014-12-17 20:23:37 +0000 |
commit | 28a1a16e736d196b2b076f7a8402d365bee28511 (patch) | |
tree | 5acbb0eb60df1f43d343041b94cac9b00218e6b5 /opengl/system/GLESv2_enc/GL2Encoder.cpp | |
parent | ba8d44b1ae7f5d39992dc0b59aecf56f8c81ee2a (diff) | |
parent | 8a44ff60e60a40d0da5f326c483c12079612f3cc (diff) | |
download | android_device_generic_goldfish-28a1a16e736d196b2b076f7a8402d365bee28511.tar.gz android_device_generic_goldfish-28a1a16e736d196b2b076f7a8402d365bee28511.tar.bz2 android_device_generic_goldfish-28a1a16e736d196b2b076f7a8402d365bee28511.zip |
Merge "Add parameters validation to glShaderSource() API"
Diffstat (limited to 'opengl/system/GLESv2_enc/GL2Encoder.cpp')
-rwxr-xr-x[-rw-r--r--] | opengl/system/GLESv2_enc/GL2Encoder.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/opengl/system/GLESv2_enc/GL2Encoder.cpp b/opengl/system/GLESv2_enc/GL2Encoder.cpp index 80a2cda..90aa61d 100644..100755 --- a/opengl/system/GLESv2_enc/GL2Encoder.cpp +++ b/opengl/system/GLESv2_enc/GL2Encoder.cpp @@ -656,7 +656,9 @@ void GL2Encoder::s_glShaderSource(void *self, GLuint shader, GLsizei count, cons { GL2Encoder* ctx = (GL2Encoder*)self; ShaderData* shaderData = ctx->m_shared->getShaderData(shader); - SET_ERROR_IF(!shaderData, GL_INVALID_VALUE); + SET_ERROR_IF(!ctx->m_shared->isObject(shader), GL_INVALID_VALUE); + SET_ERROR_IF(!shaderData, GL_INVALID_OPERATION); + SET_ERROR_IF((count<0), GL_INVALID_VALUE); int len = glUtilsCalcShaderSourceLen((char**)string, (GLint*)length, count); char *str = new char[len + 1]; |