Use a reflection-based approach to call checkError() after every call to the openGL API to reduce Code Duplication and increase Maintainability, while also fixing the regression caused by GLDebugDesktop extending from GLDebugES and thus making the Renderer think it is on mobile.
parent
ab96460853
commit
12481c08f6
@ -1,147 +0,0 @@ |
|||||||
package com.jme3.renderer.opengl; |
|
||||||
|
|
||||||
import java.nio.ByteBuffer; |
|
||||||
import java.nio.IntBuffer; |
|
||||||
|
|
||||||
public class GLDebugDesktop extends GLDebugES implements GL2, GL3, GL4 { |
|
||||||
|
|
||||||
private final GL2 gl2; |
|
||||||
private final GL3 gl3; |
|
||||||
private final GL4 gl4; |
|
||||||
|
|
||||||
public GLDebugDesktop(GL gl, GLExt glext, GLFbo glfbo) { |
|
||||||
super(gl, glext, glfbo); |
|
||||||
this.gl2 = gl instanceof GL2 ? (GL2) gl : null; |
|
||||||
this.gl3 = gl instanceof GL3 ? (GL3) gl : null; |
|
||||||
this.gl4 = gl instanceof GL4 ? (GL4) gl : null; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glAlphaFunc(int func, float ref) { |
|
||||||
gl2.glAlphaFunc(func, ref); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPointSize(float size) { |
|
||||||
gl2.glPointSize(size); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPolygonMode(int face, int mode) { |
|
||||||
gl2.glPolygonMode(face, mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawBuffer(int mode) { |
|
||||||
gl2.glDrawBuffer(mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glReadBuffer(int mode) { |
|
||||||
gl2.glReadBuffer(mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompressedTexImage3D(int target, int level, int internalformat, int width, int height, int depth, int border, ByteBuffer data) { |
|
||||||
gl2.glCompressedTexImage3D(target, level, internalformat, width, height, depth, border, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompressedTexSubImage3D(int target, int level, int xoffset, int yoffset, int zoffset, int width, int height, int depth, int format, ByteBuffer data) { |
|
||||||
gl2.glCompressedTexSubImage3D(target, level, xoffset, yoffset, zoffset, width, height, depth, format, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexImage3D(int target, int level, int internalFormat, int width, int height, int depth, int border, int format, int type, ByteBuffer data) { |
|
||||||
gl2.glTexImage3D(target, level, internalFormat, width, height, depth, border, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexSubImage3D(int target, int level, int xoffset, int yoffset, int zoffset, int width, int height, int depth, int format, int type, ByteBuffer data) { |
|
||||||
gl2.glTexSubImage3D(target, level, xoffset, yoffset, zoffset, width, height, depth, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindFragDataLocation(int param1, int param2, String param3) { |
|
||||||
gl3.glBindFragDataLocation(param1, param2, param3); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindVertexArray(int param1) { |
|
||||||
gl3.glBindVertexArray(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenVertexArrays(IntBuffer param1) { |
|
||||||
gl3.glGenVertexArrays(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public String glGetString(int param1, int param2) { |
|
||||||
String result = gl3.glGetString(param1, param2); |
|
||||||
checkError(); |
|
||||||
return result; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glGetUniformBlockIndex(final int program, final String uniformBlockName) { |
|
||||||
final int result = gl3.glGetUniformBlockIndex(program, uniformBlockName); |
|
||||||
checkError(); |
|
||||||
return result; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindBufferBase(final int target, final int index, final int buffer) { |
|
||||||
gl3.glBindBufferBase(target, index, buffer); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteVertexArrays(IntBuffer arrays) { |
|
||||||
gl3.glDeleteVertexArrays(arrays); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPatchParameter(int count) { |
|
||||||
gl4.glPatchParameter(count); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glGetProgramResourceIndex(int program, int programInterface, String name) { |
|
||||||
final int result = gl4.glGetProgramResourceIndex(program, programInterface, name); |
|
||||||
checkError(); |
|
||||||
return result; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glShaderStorageBlockBinding(int program, int storageBlockIndex, int storageBlockBinding) { |
|
||||||
gl4.glShaderStorageBlockBinding(program, storageBlockIndex, storageBlockBinding); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBlendEquationSeparate(int colorMode, int alphaMode) { |
|
||||||
gl.glBlendEquationSeparate(colorMode, alphaMode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniformBlockBinding(final int program, final int uniformBlockIndex, final int uniformBlockBinding) { |
|
||||||
gl3.glUniformBlockBinding(program, uniformBlockIndex, uniformBlockBinding); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
} |
|
@ -1,773 +0,0 @@ |
|||||||
package com.jme3.renderer.opengl; |
|
||||||
|
|
||||||
import java.nio.ByteBuffer; |
|
||||||
import java.nio.FloatBuffer; |
|
||||||
import java.nio.IntBuffer; |
|
||||||
import java.nio.ShortBuffer; |
|
||||||
|
|
||||||
public class GLDebugES extends GLDebug implements GL, GL2, GLES_30, GLFbo, GLExt { |
|
||||||
|
|
||||||
private final GLFbo glfbo; |
|
||||||
private final GLExt glext; |
|
||||||
|
|
||||||
public GLDebugES(GL gl, GLExt glext, GLFbo glfbo) { |
|
||||||
this.gl = gl; |
|
||||||
this.glext = glext; |
|
||||||
this.glfbo = glfbo; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void resetStats() { |
|
||||||
gl.resetStats(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glActiveTexture(int texture) { |
|
||||||
gl.glActiveTexture(texture); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glAttachShader(int program, int shader) { |
|
||||||
gl.glAttachShader(program, shader); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBeginQuery(int target, int query) { |
|
||||||
gl.glBeginQuery(target, query); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindBuffer(int target, int buffer) { |
|
||||||
gl.glBindBuffer(target, buffer); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindTexture(int target, int texture) { |
|
||||||
gl.glBindTexture(target, texture); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBlendFunc(int sfactor, int dfactor) { |
|
||||||
gl.glBlendFunc(sfactor, dfactor); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBlendFuncSeparate(int sfactorRGB, int dfactorRGB, int sfactorAlpha, int dFactorAlpha) |
|
||||||
{ |
|
||||||
gl.glBlendFuncSeparate(sfactorRGB, dfactorRGB, sfactorAlpha, dFactorAlpha); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferData(int target, FloatBuffer data, int usage) { |
|
||||||
gl.glBufferData(target, data, usage); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferData(int target, ShortBuffer data, int usage) { |
|
||||||
gl.glBufferData(target, data, usage); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferData(int target, ByteBuffer data, int usage) { |
|
||||||
gl.glBufferData(target, data, usage); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferSubData(int target, long offset, FloatBuffer data) { |
|
||||||
gl.glBufferSubData(target, offset, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferSubData(int target, long offset, ShortBuffer data) { |
|
||||||
gl.glBufferSubData(target, offset, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferSubData(int target, long offset, ByteBuffer data) { |
|
||||||
gl.glBufferSubData(target, offset, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glClear(int mask) { |
|
||||||
gl.glClear(mask); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glClearColor(float red, float green, float blue, float alpha) { |
|
||||||
gl.glClearColor(red, green, blue, alpha); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glColorMask(boolean red, boolean green, boolean blue, boolean alpha) { |
|
||||||
gl.glColorMask(red, green, blue, alpha); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompileShader(int shader) { |
|
||||||
gl.glCompileShader(shader); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompressedTexImage2D(int target, int level, int internalformat, int width, int height, int border, ByteBuffer data) { |
|
||||||
gl.glCompressedTexImage2D(target, level, internalformat, width, height, border, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompressedTexSubImage2D(int target, int level, int xoffset, int yoffset, int width, int height, int format, ByteBuffer data) { |
|
||||||
gl.glCompressedTexSubImage2D(target, level, xoffset, yoffset, width, height, format, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glCreateProgram() { |
|
||||||
int program = gl.glCreateProgram(); |
|
||||||
checkError(); |
|
||||||
return program; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glCreateShader(int shaderType) { |
|
||||||
int shader = gl.glCreateShader(shaderType); |
|
||||||
checkError(); |
|
||||||
return shader; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCullFace(int mode) { |
|
||||||
gl.glCullFace(mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteBuffers(IntBuffer buffers) { |
|
||||||
gl.glDeleteBuffers(buffers); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteProgram(int program) { |
|
||||||
gl.glDeleteProgram(program); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteShader(int shader) { |
|
||||||
gl.glDeleteShader(shader); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteTextures(IntBuffer textures) { |
|
||||||
gl.glDeleteTextures(textures); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDepthFunc(int func) { |
|
||||||
gl.glDepthFunc(func); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDepthMask(boolean flag) { |
|
||||||
gl.glDepthMask(flag); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDepthRange(double nearVal, double farVal) { |
|
||||||
gl.glDepthRange(nearVal, farVal); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDetachShader(int program, int shader) { |
|
||||||
gl.glDetachShader(program, shader); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDisable(int cap) { |
|
||||||
gl.glDisable(cap); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDisableVertexAttribArray(int index) { |
|
||||||
gl.glDisableVertexAttribArray(index); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawArrays(int mode, int first, int count) { |
|
||||||
gl.glDrawArrays(mode, first, count); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawRangeElements(int mode, int start, int end, int count, int type, long indices) { |
|
||||||
gl.glDrawRangeElements(mode, start, end, count, type, indices); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glEnable(int cap) { |
|
||||||
gl.glEnable(cap); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glEnableVertexAttribArray(int index) { |
|
||||||
gl.glEnableVertexAttribArray(index); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glEndQuery(int target) { |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenBuffers(IntBuffer buffers) { |
|
||||||
gl.glGenBuffers(buffers); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenTextures(IntBuffer textures) { |
|
||||||
gl.glGenTextures(textures); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenQueries(int num, IntBuffer ids) { |
|
||||||
glGenQueries(num, ids); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glGetAttribLocation(int program, String name) { |
|
||||||
int location = gl.glGetAttribLocation(program, name); |
|
||||||
checkError(); |
|
||||||
return location; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGetBoolean(int pname, ByteBuffer params) { |
|
||||||
gl.glGetBoolean(pname, params); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glGetError() { |
|
||||||
// No need to check for error here? Haha
|
|
||||||
return gl.glGetError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGetInteger(int pname, IntBuffer params) { |
|
||||||
gl.glGetInteger(pname, params); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGetProgram(int program, int pname, IntBuffer params) { |
|
||||||
gl.glGetProgram(program, pname, params); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public String glGetProgramInfoLog(int program, int maxSize) { |
|
||||||
String infoLog = gl.glGetProgramInfoLog(program, maxSize); |
|
||||||
checkError(); |
|
||||||
return infoLog; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public long glGetQueryObjectui64(int query, int pname) { |
|
||||||
long res = gl.glGetQueryObjectui64(query, pname); |
|
||||||
checkError(); |
|
||||||
return res; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glGetQueryObjectiv(int query, int pname) { |
|
||||||
int res = gl.glGetQueryObjectiv(query, pname); |
|
||||||
checkError(); |
|
||||||
return res; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGetShader(int shader, int pname, IntBuffer params) { |
|
||||||
gl.glGetShader(shader, pname, params); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public String glGetShaderInfoLog(int shader, int maxSize) { |
|
||||||
String infoLog = gl.glGetShaderInfoLog(shader, maxSize); |
|
||||||
checkError(); |
|
||||||
return infoLog; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public String glGetString(int name) { |
|
||||||
String string = gl.glGetString(name); |
|
||||||
checkError(); |
|
||||||
return string; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glGetUniformLocation(int program, String name) { |
|
||||||
int location = gl.glGetUniformLocation(program, name); |
|
||||||
checkError(); |
|
||||||
return location; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public boolean glIsEnabled(int cap) { |
|
||||||
boolean enabled = gl.glIsEnabled(cap); |
|
||||||
checkError(); |
|
||||||
return enabled; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glLineWidth(float width) { |
|
||||||
gl.glLineWidth(width); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glLinkProgram(int program) { |
|
||||||
gl.glLinkProgram(program); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPixelStorei(int pname, int param) { |
|
||||||
gl.glPixelStorei(pname, param); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPolygonOffset(float factor, float units) { |
|
||||||
gl.glPolygonOffset(factor, units); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glReadPixels(int x, int y, int width, int height, int format, int type, ByteBuffer data) { |
|
||||||
gl.glReadPixels(x, y, width, height, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glReadPixels(int x, int y, int width, int height, int format, int type, long offset) { |
|
||||||
gl.glReadPixels(x, y, width, height, format, type, offset); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glScissor(int x, int y, int width, int height) { |
|
||||||
gl.glScissor(x, y, width, height); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glShaderSource(int shader, String[] string, IntBuffer length) { |
|
||||||
gl.glShaderSource(shader, string, length); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glStencilFuncSeparate(int face, int func, int ref, int mask) { |
|
||||||
gl.glStencilFuncSeparate(face, func, ref, mask); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glStencilOpSeparate(int face, int sfail, int dpfail, int dppass) { |
|
||||||
gl.glStencilOpSeparate(face, sfail, dpfail, dppass); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexImage2D(int target, int level, int internalFormat, int width, int height, int border, int format, int type, ByteBuffer data) { |
|
||||||
gl.glTexImage2D(target, level, internalFormat, width, height, border, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexParameterf(int target, int pname, float param) { |
|
||||||
gl.glTexParameterf(target, pname, param); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexParameteri(int target, int pname, int param) { |
|
||||||
gl.glTexParameteri(target, pname, param); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexSubImage2D(int target, int level, int xoffset, int yoffset, int width, int height, int format, int type, ByteBuffer data) { |
|
||||||
gl.glTexSubImage2D(target, level, xoffset, yoffset, width, height, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform1(int location, FloatBuffer value) { |
|
||||||
gl.glUniform1(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform1(int location, IntBuffer value) { |
|
||||||
gl.glUniform1(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform1f(int location, float v0) { |
|
||||||
gl.glUniform1f(location, v0); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform1i(int location, int v0) { |
|
||||||
gl.glUniform1i(location, v0); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform2(int location, IntBuffer value) { |
|
||||||
gl.glUniform2(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform2(int location, FloatBuffer value) { |
|
||||||
gl.glUniform2(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform2f(int location, float v0, float v1) { |
|
||||||
gl.glUniform2f(location, v0, v1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform3(int location, IntBuffer value) { |
|
||||||
gl.glUniform3(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform3(int location, FloatBuffer value) { |
|
||||||
gl.glUniform3(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform3f(int location, float v0, float v1, float v2) { |
|
||||||
gl.glUniform3f(location, v0, v1, v2); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform4(int location, FloatBuffer value) { |
|
||||||
gl.glUniform4(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform4(int location, IntBuffer value) { |
|
||||||
gl.glUniform4(location, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniform4f(int location, float v0, float v1, float v2, float v3) { |
|
||||||
gl.glUniform4f(location, v0, v1, v2, v3); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniformMatrix3(int location, boolean transpose, FloatBuffer value) { |
|
||||||
gl.glUniformMatrix3(location, transpose, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUniformMatrix4(int location, boolean transpose, FloatBuffer value) { |
|
||||||
gl.glUniformMatrix4(location, transpose, value); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glUseProgram(int program) { |
|
||||||
gl.glUseProgram(program); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glVertexAttribPointer(int index, int size, int type, boolean normalized, int stride, long pointer) { |
|
||||||
gl.glVertexAttribPointer(index, size, type, normalized, stride, pointer); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glViewport(int x, int y, int width, int height) { |
|
||||||
gl.glViewport(x, y, width, height); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindFramebufferEXT(int param1, int param2) { |
|
||||||
glfbo.glBindFramebufferEXT(param1, param2); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBindRenderbufferEXT(int param1, int param2) { |
|
||||||
glfbo.glBindRenderbufferEXT(param1, param2); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glCheckFramebufferStatusEXT(int param1) { |
|
||||||
int result = glfbo.glCheckFramebufferStatusEXT(param1); |
|
||||||
checkError(); |
|
||||||
return result; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteFramebuffersEXT(IntBuffer param1) { |
|
||||||
glfbo.glDeleteFramebuffersEXT(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteRenderbuffersEXT(IntBuffer param1) { |
|
||||||
glfbo.glDeleteRenderbuffersEXT(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glFramebufferRenderbufferEXT(int param1, int param2, int param3, int param4) { |
|
||||||
glfbo.glFramebufferRenderbufferEXT(param1, param2, param3, param4); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glFramebufferTexture2DEXT(int param1, int param2, int param3, int param4, int param5) { |
|
||||||
glfbo.glFramebufferTexture2DEXT(param1, param2, param3, param4, param5); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenFramebuffersEXT(IntBuffer param1) { |
|
||||||
glfbo.glGenFramebuffersEXT(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenRenderbuffersEXT(IntBuffer param1) { |
|
||||||
glfbo.glGenRenderbuffersEXT(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGenerateMipmapEXT(int param1) { |
|
||||||
glfbo.glGenerateMipmapEXT(param1); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glRenderbufferStorageEXT(int param1, int param2, int param3, int param4) { |
|
||||||
glfbo.glRenderbufferStorageEXT(param1, param2, param3, param4); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBlitFramebufferEXT(int srcX0, int srcY0, int srcX1, int srcY1, int dstX0, int dstY0, int dstX1, int dstY1, int mask, int filter) { |
|
||||||
glfbo.glBlitFramebufferEXT(srcX0, srcY0, srcX1, srcY1, dstX0, dstY0, dstX1, dstY1, mask, filter); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferData(int target, long data_size, int usage) { |
|
||||||
gl.glBufferData(target, data_size, usage); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGetBufferSubData(int target, long offset, ByteBuffer data) { |
|
||||||
gl.glGetBufferSubData(target, offset, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferData(int target, IntBuffer data, int usage) { |
|
||||||
glext.glBufferData(target, data, usage); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBufferSubData(int target, long offset, IntBuffer data) { |
|
||||||
glext.glBufferSubData(target, offset, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawArraysInstancedARB(int mode, int first, int count, int primcount) { |
|
||||||
glext.glDrawArraysInstancedARB(mode, first, count, primcount); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawBuffers(IntBuffer bufs) { |
|
||||||
glext.glDrawBuffers(bufs); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawElementsInstancedARB(int mode, int indices_count, int type, long indices_buffer_offset, int primcount) { |
|
||||||
glext.glDrawElementsInstancedARB(mode, indices_count, type, indices_buffer_offset, primcount); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glGetMultisample(int pname, int index, FloatBuffer val) { |
|
||||||
glext.glGetMultisample(pname, index, val); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glRenderbufferStorageMultisampleEXT(int target, int samples, int internalformat, int width, int height) { |
|
||||||
glfbo.glRenderbufferStorageMultisampleEXT(target, samples, internalformat, width, height); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexImage2DMultisample(int target, int samples, int internalformat, int width, int height, boolean fixedsamplelocations) { |
|
||||||
glext.glTexImage2DMultisample(target, samples, internalformat, width, height, fixedsamplelocations); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glVertexAttribDivisorARB(int index, int divisor) { |
|
||||||
glext.glVertexAttribDivisorARB(index, divisor); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public int glClientWaitSync(Object sync, int flags, long timeout) { |
|
||||||
int result = glext.glClientWaitSync(sync, flags, timeout); |
|
||||||
checkError(); |
|
||||||
return result; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDeleteSync(Object sync) { |
|
||||||
glext.glDeleteSync(sync); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public Object glFenceSync(int condition, int flags) { |
|
||||||
Object sync = glext.glFenceSync(condition, flags); |
|
||||||
checkError(); |
|
||||||
return sync; |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glBlendEquationSeparate(int colorMode, int alphaMode) { |
|
||||||
gl.glBlendEquationSeparate(colorMode, alphaMode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glFramebufferTextureLayerEXT(int param1, int param2, int param3, int param4, int param5) { |
|
||||||
glfbo.glFramebufferTextureLayerEXT(param1, param2, param3, param4, param5); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glAlphaFunc(int func, float ref) { |
|
||||||
((GL2)gl).glAlphaFunc(func, ref); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPointSize(float size) { |
|
||||||
((GL2)gl).glPointSize(size); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glPolygonMode(int face, int mode) { |
|
||||||
((GL2)gl).glPolygonMode(face, mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glDrawBuffer(int mode) { |
|
||||||
((GL2)gl).glDrawBuffer(mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glReadBuffer(int mode) { |
|
||||||
((GL2)gl).glReadBuffer(mode); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompressedTexImage3D(int target, int level, int internalFormat, int width, int height, int depth, |
|
||||||
int border, ByteBuffer data) { |
|
||||||
((GL2)gl).glCompressedTexImage3D(target, level, internalFormat, width, height, depth, border, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glCompressedTexSubImage3D(int target, int level, int xoffset, int yoffset, int zoffset, int width, |
|
||||||
int height, int depth, int format, ByteBuffer data) { |
|
||||||
((GL2)gl).glCompressedTexSubImage3D(target, level, xoffset, yoffset, zoffset, width, height, depth, format, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexImage3D(int target, int level, int internalFormat, int width, int height, int depth, int border, |
|
||||||
int format, int type, ByteBuffer data) { |
|
||||||
((GL2)gl).glTexImage3D(target, level, internalFormat, width, height, depth, border, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
@Override |
|
||||||
public void glTexSubImage3D(int target, int level, int xoffset, int yoffset, int zoffset, int width, int height, |
|
||||||
int depth, int format, int type, ByteBuffer data) { |
|
||||||
((GL2)gl).glTexSubImage3D(target, level, xoffset, yoffset, zoffset, width, height, depth, format, type, data); |
|
||||||
checkError(); |
|
||||||
} |
|
||||||
|
|
||||||
} |
|
Loading…
Reference in new issue