Implemented safe VBO indices (phew)
This commit is contained in:
parent
e6cca3fda8
commit
35a1538f82
|
@ -128,25 +128,6 @@ public final class Sys {
|
||||||
setTime(0);
|
setTime(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a buffer representing an integer index. Use it with functions that in C can take
|
|
||||||
* both a pointer and an integer argument, like the ARB_vertex_buffer_object extension specifies
|
|
||||||
* gl*Pointer to do (among others).
|
|
||||||
*
|
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* ByteBuffer b = Sys.createIndexBuffer(0);
|
|
||||||
* gl.glVertexPointer(3, GL.GL_INT, 0, b);
|
|
||||||
*
|
|
||||||
* is equivalent to the C call:
|
|
||||||
*
|
|
||||||
* glVertexPointer(3, GL.GL_INT, 0, 0);
|
|
||||||
*
|
|
||||||
* @param index The index to represent
|
|
||||||
* @return a ByteBuffer representing the index
|
|
||||||
*/
|
|
||||||
public static native ByteBuffer createIndexBuffer(int index);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Obtains the number of ticks that the hires timer does in a second.
|
* Obtains the number of ticks that the hires timer does in a second.
|
||||||
*
|
*
|
||||||
|
|
|
@ -87,12 +87,19 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
public static native void glCopyTexImage1D(int target, int level, int internalFormat, int x, int y, int width, int border);
|
public static native void glCopyTexImage1D(int target, int level, int internalFormat, int x, int y, int width, int border);
|
||||||
public static native void glCopyPixels(int x, int y, int width, int height, int type);
|
public static native void glCopyPixels(int x, int y, int width, int height, int type);
|
||||||
public static void glColorPointer(int size, boolean unsigned, int stride, ByteBuffer pointer) {
|
public static void glColorPointer(int size, boolean unsigned, int stride, ByteBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglColorPointer(size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, pointer, pointer.position());
|
nglColorPointer(size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, pointer, pointer.position());
|
||||||
}
|
}
|
||||||
public static void glColorPointer(int size, int stride, FloatBuffer pointer) {
|
public static void glColorPointer(int size, int stride, FloatBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglColorPointer(size, GL_FLOAT, stride, pointer, pointer.position() << 2);
|
nglColorPointer(size, GL_FLOAT, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglColorPointer(int size, int type, int stride, Buffer pointer, int pointer_offset);
|
private static native void nglColorPointer(int size, int type, int stride, Buffer pointer, int pointer_offset);
|
||||||
|
public static void glColorPointer(int size, int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglColorPointerVBO(size, type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglColorPointerVBO(int size, int type, int stride, int buffer_offset);
|
||||||
public static native void glColorMaterial(int face, int mode);
|
public static native void glColorMaterial(int face, int mode);
|
||||||
public static native void glColorMask(boolean red, boolean green, boolean blue, boolean alpha);
|
public static native void glColorMask(boolean red, boolean green, boolean blue, boolean alpha);
|
||||||
public static native void glColor3b(byte red, byte green, byte blue);
|
public static native void glColor3b(byte red, byte green, byte blue);
|
||||||
|
@ -118,9 +125,15 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
public static native void glEnable(int cap);
|
public static native void glEnable(int cap);
|
||||||
public static native void glDisable(int cap);
|
public static native void glDisable(int cap);
|
||||||
public static void glEdgeFlagPointer(int stride, ByteBuffer pointer) {
|
public static void glEdgeFlagPointer(int stride, ByteBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglEdgeFlagPointer(stride, pointer, pointer.position());
|
nglEdgeFlagPointer(stride, pointer, pointer.position());
|
||||||
}
|
}
|
||||||
private static native void nglEdgeFlagPointer(int stride, Buffer pointer, int pointer_offset);
|
private static native void nglEdgeFlagPointer(int stride, Buffer pointer, int pointer_offset);
|
||||||
|
public static void glEdgeFlagPointer(int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglEdgeFlagPointerVBO(stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglEdgeFlagPointerVBO(int stride, int buffer_offset);
|
||||||
public static native void glEdgeFlag(boolean flag);
|
public static native void glEdgeFlag(boolean flag);
|
||||||
public static void glDrawPixels(int width, int height, int format, int type, ByteBuffer pixels) {
|
public static void glDrawPixels(int width, int height, int format, int type, ByteBuffer pixels) {
|
||||||
nglDrawPixels(width, height, format, type, pixels, pixels.position());
|
nglDrawPixels(width, height, format, type, pixels, pixels.position());
|
||||||
|
@ -133,15 +146,23 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
}
|
}
|
||||||
private static native void nglDrawPixels(int width, int height, int format, int type, Buffer pixels, int pixels_offset);
|
private static native void nglDrawPixels(int width, int height, int format, int type, Buffer pixels, int pixels_offset);
|
||||||
public static void glDrawElements(int mode, ByteBuffer indices) {
|
public static void glDrawElements(int mode, ByteBuffer indices) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglDrawElements(mode, indices.remaining(), GL_UNSIGNED_BYTE, indices, indices.position());
|
nglDrawElements(mode, indices.remaining(), GL_UNSIGNED_BYTE, indices, indices.position());
|
||||||
}
|
}
|
||||||
public static void glDrawElements(int mode, ShortBuffer indices) {
|
public static void glDrawElements(int mode, ShortBuffer indices) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglDrawElements(mode, indices.remaining(), GL_UNSIGNED_SHORT, indices, indices.position() << 1);
|
nglDrawElements(mode, indices.remaining(), GL_UNSIGNED_SHORT, indices, indices.position() << 1);
|
||||||
}
|
}
|
||||||
public static void glDrawElements(int mode, IntBuffer indices) {
|
public static void glDrawElements(int mode, IntBuffer indices) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglDrawElements(mode, indices.remaining(), GL_UNSIGNED_INT, indices, indices.position() << 2);
|
nglDrawElements(mode, indices.remaining(), GL_UNSIGNED_INT, indices, indices.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglDrawElements(int mode, int count, int type, Buffer indices, int indices_offset);
|
private static native void nglDrawElements(int mode, int count, int type, Buffer indices, int indices_offset);
|
||||||
|
public static void glDrawElements(int mode, int count, int type, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglDrawElementsVBO(mode, count, type, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglDrawElementsVBO(int mode, int count, int type, int buffer_offset);
|
||||||
public static native void glDrawBuffer(int mode);
|
public static native void glDrawBuffer(int mode);
|
||||||
public static native void glDrawArrays(int mode, int first, int count);
|
public static native void glDrawArrays(int mode, int first, int count);
|
||||||
public static native void glDepthRange(double zNear, double zFar);
|
public static native void glDepthRange(double zNear, double zFar);
|
||||||
|
@ -237,18 +258,27 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
public static native ByteBuffer glGetPointerv(int pname, int size);
|
public static native ByteBuffer glGetPointerv(int pname, int size);
|
||||||
public static native boolean glIsEnabled(int cap);
|
public static native boolean glIsEnabled(int cap);
|
||||||
public static void glInterleavedArrays(int format, int stride, ByteBuffer pointer) {
|
public static void glInterleavedArrays(int format, int stride, ByteBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglInterleavedArrays(format, stride, pointer, pointer.position());
|
nglInterleavedArrays(format, stride, pointer, pointer.position());
|
||||||
}
|
}
|
||||||
public static void glInterleavedArrays(int format, int stride, ShortBuffer pointer) {
|
public static void glInterleavedArrays(int format, int stride, ShortBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglInterleavedArrays(format, stride, pointer, pointer.position() << 1);
|
nglInterleavedArrays(format, stride, pointer, pointer.position() << 1);
|
||||||
}
|
}
|
||||||
public static void glInterleavedArrays(int format, int stride, IntBuffer pointer) {
|
public static void glInterleavedArrays(int format, int stride, IntBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglInterleavedArrays(format, stride, pointer, pointer.position() << 2);
|
nglInterleavedArrays(format, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
public static void glInterleavedArrays(int format, int stride, FloatBuffer pointer) {
|
public static void glInterleavedArrays(int format, int stride, FloatBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglInterleavedArrays(format, stride, pointer, pointer.position() << 2);
|
nglInterleavedArrays(format, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglInterleavedArrays(int format, int stride, Buffer pointer, int pointer_offset);
|
private static native void nglInterleavedArrays(int format, int stride, Buffer pointer, int pointer_offset);
|
||||||
|
public static void glInterleavedArrays(int format, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglInterleavedArraysVBO(format, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglInterleavedArraysVBO(int format, int stride, int buffer_offset);
|
||||||
public static native void glInitNames();
|
public static native void glInitNames();
|
||||||
public static native void glHint(int target, int mode);
|
public static native void glHint(int target, int mode);
|
||||||
public static void glGetTexParameter(int target, int pname, FloatBuffer params) {
|
public static void glGetTexParameter(int target, int pname, FloatBuffer params) {
|
||||||
|
@ -377,15 +407,23 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
public static native void glPassThrough(float token);
|
public static native void glPassThrough(float token);
|
||||||
public static native void glOrtho(double left, double right, double bottom, double top, double zNear, double zFar);
|
public static native void glOrtho(double left, double right, double bottom, double top, double zNear, double zFar);
|
||||||
public static void glNormalPointer(int stride, ByteBuffer pointer) {
|
public static void glNormalPointer(int stride, ByteBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglNormalPointer(GL_BYTE, stride, pointer, pointer.position());
|
nglNormalPointer(GL_BYTE, stride, pointer, pointer.position());
|
||||||
}
|
}
|
||||||
public static void glNormalPointer(int stride, IntBuffer pointer) {
|
public static void glNormalPointer(int stride, IntBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglNormalPointer(GL_INT, stride, pointer, pointer.position() << 2);
|
nglNormalPointer(GL_INT, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
public static void glNormalPointer(int stride, FloatBuffer pointer) {
|
public static void glNormalPointer(int stride, FloatBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglNormalPointer(GL_FLOAT, stride, pointer, pointer.position() << 2);
|
nglNormalPointer(GL_FLOAT, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglNormalPointer(int type, int stride, Buffer pointer, int pointer_offset);
|
private static native void nglNormalPointer(int type, int stride, Buffer pointer, int pointer_offset);
|
||||||
|
public static void glNormalPointer(int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglNormalPointerVBO(type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglNormalPointerVBO(int type, int stride, int buffer_offset);
|
||||||
public static native void glNormal3b(byte nx, byte ny, byte nz);
|
public static native void glNormal3b(byte nx, byte ny, byte nz);
|
||||||
public static native void glNormal3f(float nx, float ny, float nz);
|
public static native void glNormal3f(float nx, float ny, float nz);
|
||||||
public static native void glNormal3i(int nx, int ny, int nz);
|
public static native void glNormal3i(int nx, int ny, int nz);
|
||||||
|
@ -427,18 +465,41 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
public static native void glPopName();
|
public static native void glPopName();
|
||||||
public static native void glPushMatrix();
|
public static native void glPushMatrix();
|
||||||
public static native void glPopMatrix();
|
public static native void glPopMatrix();
|
||||||
public static native void glPushClientAttrib(int mask);
|
public static void glPushClientAttrib(int mask) {
|
||||||
public static native void glPopClientAttrib();
|
VBOTracker.getClientAttribStack().pushState();
|
||||||
|
VBOTracker.getClientAttribStack().setState(mask);
|
||||||
|
if ((mask & GL_CLIENT_VERTEX_ARRAY_BIT) != 0) {
|
||||||
|
VBOTracker.getVBOArrayStack().pushState();
|
||||||
|
VBOTracker.getVBOElementStack().pushState();
|
||||||
|
}
|
||||||
|
nglPushClientAttrib(mask);
|
||||||
|
}
|
||||||
|
private static native void nglPushClientAttrib(int mask);
|
||||||
|
public static void glPopClientAttrib() {
|
||||||
|
if ((VBOTracker.getClientAttribStack().popState() & GL_CLIENT_VERTEX_ARRAY_BIT) != 0) {
|
||||||
|
VBOTracker.getVBOArrayStack().popState();
|
||||||
|
VBOTracker.getVBOElementStack().popState();
|
||||||
|
}
|
||||||
|
nglPopClientAttrib();
|
||||||
|
}
|
||||||
|
private static native void nglPopClientAttrib();
|
||||||
public static native void glPushAttrib(int mask);
|
public static native void glPushAttrib(int mask);
|
||||||
public static native void glPopAttrib();
|
public static native void glPopAttrib();
|
||||||
public static native void glStencilFunc(int func, int ref, int mask);
|
public static native void glStencilFunc(int func, int ref, int mask);
|
||||||
public static void glVertexPointer(int size, int stride, FloatBuffer pointer) {
|
public static void glVertexPointer(int size, int stride, FloatBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglVertexPointer(size, GL_FLOAT, stride, pointer, pointer.position() << 2);
|
nglVertexPointer(size, GL_FLOAT, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
public static void glVertexPointer(int size, int stride, IntBuffer pointer) {
|
public static void glVertexPointer(int size, int stride, IntBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglVertexPointer(size, GL_INT, stride, pointer, pointer.position() << 2);
|
nglVertexPointer(size, GL_INT, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglVertexPointer(int size, int type, int stride, Buffer pointer, int pointer_offset);
|
private static native void nglVertexPointer(int size, int type, int stride, Buffer pointer, int pointer_offset);
|
||||||
|
public static void glVertexPointer(int size, int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglVertexPointerVBO(size, type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglVertexPointerVBO(int size, int type, int stride, int buffer_offset);
|
||||||
public static native void glVertex2f(float x, float y);
|
public static native void glVertex2f(float x, float y);
|
||||||
public static native void glVertex2i(int x, int y);
|
public static native void glVertex2i(int x, int y);
|
||||||
public static native void glVertex3f(float x, float y, float z);
|
public static native void glVertex3f(float x, float y, float z);
|
||||||
|
@ -509,9 +570,15 @@ public abstract class CoreGL11 implements CoreGL11Constants {
|
||||||
}
|
}
|
||||||
private static native void nglTexEnviv(int target, int pname, IntBuffer params, int params_offset);
|
private static native void nglTexEnviv(int target, int pname, IntBuffer params, int params_offset);
|
||||||
public static void glTexCoordPointer(int size, int stride, FloatBuffer pointer) {
|
public static void glTexCoordPointer(int size, int stride, FloatBuffer pointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglTexCoordPointer(size, GL_FLOAT, stride, pointer, pointer.position() << 2);
|
nglTexCoordPointer(size, GL_FLOAT, stride, pointer, pointer.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglTexCoordPointer(int size, int type, int stride, Buffer pointer, int pointer_offset);
|
private static native void nglTexCoordPointer(int size, int type, int stride, Buffer pointer, int pointer_offset);
|
||||||
|
public static void glTexCoordPointer(int size, int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglTexCoordPointerVBO(size, type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglTexCoordPointerVBO(int size, int type, int stride, int buffer_offset);
|
||||||
public static native void glTexCoord1f(float s);
|
public static native void glTexCoord1f(float s);
|
||||||
public static native void glTexCoord2f(float s, float t);
|
public static native void glTexCoord2f(float s, float t);
|
||||||
public static native void glTexCoord3f(float s, float t, float r);
|
public static native void glTexCoord3f(float s, float t, float r);
|
||||||
|
|
|
@ -191,15 +191,23 @@ public abstract class CoreGL12 extends CoreGL11 implements CoreGL12Constants {
|
||||||
}
|
}
|
||||||
private static native void nglGetSeparableFilter(int target, int format, int type, Buffer row, int row_offset, Buffer column, int column_offset, Buffer span, int span_offset);
|
private static native void nglGetSeparableFilter(int target, int format, int type, Buffer row, int row_offset, Buffer column, int column_offset, Buffer span, int span_offset);
|
||||||
public static void glDrawRangeElements(int mode, int start, int end, ByteBuffer indices) {
|
public static void glDrawRangeElements(int mode, int start, int end, ByteBuffer indices) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglDrawRangeElements(mode, start, end, indices.remaining(), GL_UNSIGNED_BYTE, indices, indices.position());
|
nglDrawRangeElements(mode, start, end, indices.remaining(), GL_UNSIGNED_BYTE, indices, indices.position());
|
||||||
}
|
}
|
||||||
public static void glDrawRangeElements(int mode, int start, int end, ShortBuffer indices) {
|
public static void glDrawRangeElements(int mode, int start, int end, ShortBuffer indices) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglDrawRangeElements(mode, start, end, indices.remaining(), GL_UNSIGNED_SHORT, indices, indices.position() << 1);
|
nglDrawRangeElements(mode, start, end, indices.remaining(), GL_UNSIGNED_SHORT, indices, indices.position() << 1);
|
||||||
}
|
}
|
||||||
public static void glDrawRangeElements(int mode, int start, int end, IntBuffer indices) {
|
public static void glDrawRangeElements(int mode, int start, int end, IntBuffer indices) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglDrawRangeElements(mode, start, end, indices.remaining(), GL_UNSIGNED_INT, indices, indices.position() << 2);
|
nglDrawRangeElements(mode, start, end, indices.remaining(), GL_UNSIGNED_INT, indices, indices.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglDrawRangeElements(int mode, int start, int end, int count, int type, Buffer indices, int indices_offset);
|
private static native void nglDrawRangeElements(int mode, int start, int end, int count, int type, Buffer indices, int indices_offset);
|
||||||
|
public static void glDrawRangeElements(int mode, int start, int end, int count, int type, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOElementStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglDrawRangeElementsVBO(mode, start, end, count, type, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglDrawRangeElementsVBO(int mode, int start, int end, int count, int type, int buffer_offset);
|
||||||
public static void glTexImage3D(int target, int level, int internalFormat, int width, int height, int depth, int border, int format, int type, ByteBuffer pixels) {
|
public static void glTexImage3D(int target, int level, int internalFormat, int width, int height, int depth, int border, int format, int type, ByteBuffer pixels) {
|
||||||
nglTexImage3D(target, level, internalFormat, width, height, depth, border, format, type, pixels, pixels.position());
|
nglTexImage3D(target, level, internalFormat, width, height, depth, border, format, type, pixels, pixels.position());
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,11 +46,17 @@ import java.nio.Buffer;
|
||||||
* @version $Revision: 1.23 $
|
* @version $Revision: 1.23 $
|
||||||
*/
|
*/
|
||||||
public abstract class CoreGL14 extends CoreGL13 implements CoreGL14Constants {
|
public abstract class CoreGL14 extends CoreGL13 implements CoreGL14Constants {
|
||||||
public static native void glFogCoordf (float coord);
|
public static native void glFogCoordf(float coord);
|
||||||
public static void glFogCoordPointer (int stride, FloatBuffer data) {
|
public static void glFogCoordPointer(int stride, FloatBuffer data) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglFogCoordPointer(GL_FLOAT, stride, data, data.position() << 2);
|
nglFogCoordPointer(GL_FLOAT, stride, data, data.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglFogCoordPointer (int type, int stride, Buffer data, int data_offset);
|
private static native void nglFogCoordPointer(int type, int stride, Buffer data, int data_offset);
|
||||||
|
public static void glFogCoordPointer(int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglFogCoordPointerVBO(type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglFogCoordPointerVBO(int type, int stride, int buffer_offset);
|
||||||
public static void glMultiDrawArrays(int mode, IntBuffer piFirst, IntBuffer piCount) {
|
public static void glMultiDrawArrays(int mode, IntBuffer piFirst, IntBuffer piCount) {
|
||||||
assert piFirst.remaining() == piCount.remaining(): "piFirst.remaining() != piCount.remaining()";
|
assert piFirst.remaining() == piCount.remaining(): "piFirst.remaining() != piCount.remaining()";
|
||||||
nglMultiDrawArrays(mode, piFirst, piFirst.position(), piCount, piCount.position(), piFirst.remaining());
|
nglMultiDrawArrays(mode, piFirst, piFirst.position(), piCount, piCount.position(), piFirst.remaining());
|
||||||
|
@ -65,13 +71,20 @@ public abstract class CoreGL14 extends CoreGL13 implements CoreGL14Constants {
|
||||||
public static native void glSecondaryColor3b (byte red, byte green, byte blue);
|
public static native void glSecondaryColor3b (byte red, byte green, byte blue);
|
||||||
public static native void glSecondaryColor3f (float red, float green, float blue);
|
public static native void glSecondaryColor3f (float red, float green, float blue);
|
||||||
public static native void glSecondaryColor3ub (byte red, byte green, byte blue);
|
public static native void glSecondaryColor3ub (byte red, byte green, byte blue);
|
||||||
public static void glSecondaryColorPointer (int size, boolean unsigned, int stride, ByteBuffer data) {
|
public static void glSecondaryColorPointer(int size, boolean unsigned, int stride, ByteBuffer data) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglSecondaryColorPointer(size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, data, data.position());
|
nglSecondaryColorPointer(size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, data, data.position());
|
||||||
}
|
}
|
||||||
public static void glSecondaryColorPointer (int size, int stride, FloatBuffer data) {
|
public static void glSecondaryColorPointer(int size, int stride, FloatBuffer data) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglSecondaryColorPointer(size, GL_FLOAT, stride, data, data.position() << 2);
|
nglSecondaryColorPointer(size, GL_FLOAT, stride, data, data.position() << 2);
|
||||||
}
|
}
|
||||||
private static native void nglSecondaryColorPointer (int size, int type, int stride, Buffer data, int data_offset);
|
private static native void nglSecondaryColorPointer (int size, int type, int stride, Buffer data, int data_offset);
|
||||||
|
public static void glSecondaryColorPointer(int size, int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglSecondaryColorPointerVBO(size, type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglSecondaryColorPointerVBO(int size, int type, int stride, int buffer_offset);
|
||||||
public static native void glBlendFuncSeparate (int sfactorRGB, int dfactorRGB, int sfactorAlpha, int dfactorAlpha);
|
public static native void glBlendFuncSeparate (int sfactorRGB, int dfactorRGB, int sfactorAlpha, int dfactorAlpha);
|
||||||
public static native void glWindowPos2f (float x, float y);
|
public static native void glWindowPos2f (float x, float y);
|
||||||
public static native void glWindowPos2i (int x, int y);
|
public static native void glWindowPos2i (int x, int y);
|
||||||
|
|
|
@ -1149,19 +1149,27 @@ public abstract class GL extends CoreGL14 implements GLConstants {
|
||||||
private static native void nglVertexAttrib4usvARB(int index, ShortBuffer psV, int psV_offset);
|
private static native void nglVertexAttrib4usvARB(int index, ShortBuffer psV, int psV_offset);
|
||||||
|
|
||||||
public static void glVertexAttribPointerARB(int index, int size, boolean unsigned, boolean normalized, int stride, ByteBuffer pPointer) {
|
public static void glVertexAttribPointerARB(int index, int size, boolean unsigned, boolean normalized, int stride, ByteBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglVertexAttribPointerARB(index, size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, normalized, stride, pPointer, pPointer.position());
|
nglVertexAttribPointerARB(index, size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, normalized, stride, pPointer, pPointer.position());
|
||||||
}
|
}
|
||||||
public static void glVertexAttribPointerARB(int index, int size, boolean unsigned, boolean normalized, int stride, ShortBuffer pPointer) {
|
public static void glVertexAttribPointerARB(int index, int size, boolean unsigned, boolean normalized, int stride, ShortBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglVertexAttribPointerARB(index, size, unsigned ? GL_UNSIGNED_SHORT : GL_SHORT, normalized, stride, pPointer, pPointer.position()<<1);
|
nglVertexAttribPointerARB(index, size, unsigned ? GL_UNSIGNED_SHORT : GL_SHORT, normalized, stride, pPointer, pPointer.position()<<1);
|
||||||
}
|
}
|
||||||
public static void glVertexAttribPointerARB(int index, int size, boolean normalized, int stride, FloatBuffer pPointer) {
|
public static void glVertexAttribPointerARB(int index, int size, boolean normalized, int stride, FloatBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglVertexAttribPointerARB(index, size, GL_FLOAT, normalized, stride, pPointer, pPointer.position()<<2);
|
nglVertexAttribPointerARB(index, size, GL_FLOAT, normalized, stride, pPointer, pPointer.position()<<2);
|
||||||
}
|
}
|
||||||
public static void glVertexAttribPointerARB(int index, int size, boolean unsigned, boolean normalized, int stride, IntBuffer pPointer) {
|
public static void glVertexAttribPointerARB(int index, int size, boolean unsigned, boolean normalized, int stride, IntBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglVertexAttribPointerARB(index, size, unsigned ? GL_UNSIGNED_INT : GL_INT, normalized, stride, pPointer, pPointer.position()<<2);
|
nglVertexAttribPointerARB(index, size, unsigned ? GL_UNSIGNED_INT : GL_INT, normalized, stride, pPointer, pPointer.position()<<2);
|
||||||
}
|
}
|
||||||
private static native void nglVertexAttribPointerARB(int index, int size, int type, boolean normalized, int stride, Buffer pPointer, int pPointer_offset);
|
private static native void nglVertexAttribPointerARB(int index, int size, int type, boolean normalized, int stride, Buffer pPointer, int pPointer_offset);
|
||||||
|
public static void glVertexAttribPointerARB(int index, int size, int type, boolean normalized, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglVertexAttribPointerARBVBO(index, size, type, normalized, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglVertexAttribPointerARBVBO(int index, int size, int type, boolean normalized, int stride, int buffer_offset);
|
||||||
public static void glVertexAttribPointerNV(int index, int size, boolean unsigned, int stride, ByteBuffer pPointer) {
|
public static void glVertexAttribPointerNV(int index, int size, boolean unsigned, int stride, ByteBuffer pPointer) {
|
||||||
nglVertexAttribPointerNV(index, size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, pPointer, pPointer.position());
|
nglVertexAttribPointerNV(index, size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, pPointer, pPointer.position());
|
||||||
}
|
}
|
||||||
|
@ -1283,18 +1291,27 @@ public abstract class GL extends CoreGL14 implements GLConstants {
|
||||||
private static native void nglWeightivARB(int size, IntBuffer piWeights, int piWeights_offset);
|
private static native void nglWeightivARB(int size, IntBuffer piWeights, int piWeights_offset);
|
||||||
|
|
||||||
public static void glWeightPointerARB(int size, boolean unsigned, int stride, ByteBuffer pPointer) {
|
public static void glWeightPointerARB(int size, boolean unsigned, int stride, ByteBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglWeightPointerARB(size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, pPointer, pPointer.position());
|
nglWeightPointerARB(size, unsigned ? GL_UNSIGNED_BYTE : GL_BYTE, stride, pPointer, pPointer.position());
|
||||||
}
|
}
|
||||||
public static void glWeightPointerARB(int size, boolean unsigned, int stride, ShortBuffer pPointer) {
|
public static void glWeightPointerARB(int size, boolean unsigned, int stride, ShortBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglWeightPointerARB(size, unsigned ? GL_UNSIGNED_SHORT : GL_SHORT, stride, pPointer, pPointer.position()<<1);
|
nglWeightPointerARB(size, unsigned ? GL_UNSIGNED_SHORT : GL_SHORT, stride, pPointer, pPointer.position()<<1);
|
||||||
}
|
}
|
||||||
public static void glWeightPointerARB(int size, int stride, FloatBuffer pPointer) {
|
public static void glWeightPointerARB(int size, int stride, FloatBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglWeightPointerARB(size, GL_FLOAT, stride, pPointer, pPointer.position()<<2);
|
nglWeightPointerARB(size, GL_FLOAT, stride, pPointer, pPointer.position()<<2);
|
||||||
}
|
}
|
||||||
public static void glWeightPointerARB(int size, boolean unsigned, int stride, IntBuffer pPointer) {
|
public static void glWeightPointerARB(int size, boolean unsigned, int stride, IntBuffer pPointer) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() == 0: "Cannot use Buffers when VBO is enabled";
|
||||||
nglWeightPointerARB(size, unsigned ? GL_UNSIGNED_INT : GL_INT, stride, pPointer, pPointer.position()<<2);
|
nglWeightPointerARB(size, unsigned ? GL_UNSIGNED_INT : GL_INT, stride, pPointer, pPointer.position()<<2);
|
||||||
}
|
}
|
||||||
private static native void nglWeightPointerARB(int size, int type, int stride, Buffer pPointer, int pPointer_offset);
|
private static native void nglWeightPointerARB(int size, int type, int stride, Buffer pPointer, int pPointer_offset);
|
||||||
|
public static void glWeightPointerARB(int size, int type, int stride, int buffer_offset) {
|
||||||
|
assert VBOTracker.getVBOArrayStack().getState() != 0: "Cannot use int offsets when VBO is disabled";
|
||||||
|
nglWeightPointerARBVBO(size, type, stride, buffer_offset);
|
||||||
|
}
|
||||||
|
private static native void nglWeightPointerARBVBO(int size, int type, int stride, int buffer_offset);
|
||||||
|
|
||||||
public static void glWeightARB(ShortBuffer psWeights) {
|
public static void glWeightARB(ShortBuffer psWeights) {
|
||||||
nglWeightsvARB(psWeights.remaining(), psWeights, psWeights.position());
|
nglWeightsvARB(psWeights.remaining(), psWeights, psWeights.position());
|
||||||
|
@ -1444,8 +1461,27 @@ public abstract class GL extends CoreGL14 implements GLConstants {
|
||||||
int outZ,
|
int outZ,
|
||||||
int outW);
|
int outW);
|
||||||
|
|
||||||
public static native void glBindBufferARB(int target, int buffer);
|
public static void glBindBufferARB(int target, int buffer) {
|
||||||
|
switch (target) {
|
||||||
|
case GL_ELEMENT_ARRAY_BUFFER_ARB:
|
||||||
|
VBOTracker.getVBOElementStack().setState(buffer);
|
||||||
|
break;
|
||||||
|
case GL_ARRAY_BUFFER_ARB:
|
||||||
|
VBOTracker.getVBOArrayStack().setState(buffer);
|
||||||
|
break;
|
||||||
|
default: assert false: "Unsupported VBO target " + target;
|
||||||
|
}
|
||||||
|
nglBindBufferARB(target, buffer);
|
||||||
|
}
|
||||||
|
private static native void nglBindBufferARB(int target, int buffer);
|
||||||
public static void glDeleteBuffersARB(IntBuffer buffers) {
|
public static void glDeleteBuffersARB(IntBuffer buffers) {
|
||||||
|
for (int i = buffers.position(); i < buffers.limit(); i++) {
|
||||||
|
int buffer_handle = buffers.get(i);
|
||||||
|
if (VBOTracker.getVBOElementStack().getState() == buffer_handle)
|
||||||
|
VBOTracker.getVBOElementStack().setState(0);
|
||||||
|
if (VBOTracker.getVBOArrayStack().getState() == buffer_handle)
|
||||||
|
VBOTracker.getVBOArrayStack().setState(0);
|
||||||
|
}
|
||||||
nglDeleteBuffersARB(buffers.remaining(), buffers, buffers.position());
|
nglDeleteBuffersARB(buffers.remaining(), buffers, buffers.position());
|
||||||
}
|
}
|
||||||
private static native void nglDeleteBuffersARB(int n, IntBuffer buffers, int buffers_offset);
|
private static native void nglDeleteBuffersARB(int n, IntBuffer buffers, int buffers_offset);
|
||||||
|
|
|
@ -50,16 +50,19 @@ import org.lwjgl.*;
|
||||||
public class Pbuffer {
|
public class Pbuffer {
|
||||||
public final static int PBUFFER_SUPPORTED = 1;
|
public final static int PBUFFER_SUPPORTED = 1;
|
||||||
|
|
||||||
|
/** Current Pbuffer */
|
||||||
|
private static Pbuffer currentBuffer = null;
|
||||||
|
|
||||||
|
/** Handle to the native GL rendering context */
|
||||||
|
private final int handle;
|
||||||
|
|
||||||
|
/** Tracks VBO state */
|
||||||
|
private final VBOTracker vbo_tracker;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
System.loadLibrary(Sys.getLibraryName());
|
System.loadLibrary(Sys.getLibraryName());
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Handle to the native GL rendering context */
|
|
||||||
protected final int handle;
|
|
||||||
|
|
||||||
/** Current Pbuffer */
|
|
||||||
private static Pbuffer currentBuffer = null;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct an instance of a Pbuffer. If this fails then an Exception will be thrown.
|
* Construct an instance of a Pbuffer. If this fails then an Exception will be thrown.
|
||||||
* The buffer is single-buffered.
|
* The buffer is single-buffered.
|
||||||
|
@ -81,6 +84,7 @@ public class Pbuffer {
|
||||||
*/
|
*/
|
||||||
public Pbuffer(int width, int height, int bpp, int alpha, int depth, int stencil) throws Exception {
|
public Pbuffer(int width, int height, int bpp, int alpha, int depth, int stencil) throws Exception {
|
||||||
handle = nCreate(width, height, bpp, alpha, depth, stencil);
|
handle = nCreate(width, height, bpp, alpha, depth, stencil);
|
||||||
|
vbo_tracker = new VBOTracker();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -88,6 +92,7 @@ public class Pbuffer {
|
||||||
*/
|
*/
|
||||||
public static void releaseContext() {
|
public static void releaseContext() {
|
||||||
currentBuffer = null;
|
currentBuffer = null;
|
||||||
|
VBOTracker.releaseCurrent();
|
||||||
nReleaseContext();
|
nReleaseContext();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,6 +124,7 @@ public class Pbuffer {
|
||||||
*/
|
*/
|
||||||
public void makeCurrent() {
|
public void makeCurrent() {
|
||||||
currentBuffer = this;
|
currentBuffer = this;
|
||||||
|
VBOTracker.setCurrent(vbo_tracker);
|
||||||
nMakeCurrent(handle);
|
nMakeCurrent(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -150,7 +156,8 @@ public class Pbuffer {
|
||||||
* Destroys the Pbuffer. The buffer must not be current.
|
* Destroys the Pbuffer. The buffer must not be current.
|
||||||
*/
|
*/
|
||||||
public void destroy() {
|
public void destroy() {
|
||||||
assert currentBuffer != this : "Pbuffers must not be current when releasing it";
|
if (currentBuffer == this)
|
||||||
|
releaseContext();
|
||||||
nDestroy(handle);
|
nDestroy(handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,64 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2002 Lightweight Java Game Library Project
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are
|
||||||
|
* met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* * Neither the name of 'Light Weight Java Game Library' nor the names of
|
||||||
|
* its contributors may be used to endorse or promote products derived
|
||||||
|
* from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||||||
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.lwjgl.opengl;
|
||||||
|
|
||||||
|
public class StateStack {
|
||||||
|
/** Only int state is tracked */
|
||||||
|
private final int[] state_stack;
|
||||||
|
private int stack_pos;
|
||||||
|
|
||||||
|
public int getState() {
|
||||||
|
return state_stack[stack_pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setState(int new_state) {
|
||||||
|
state_stack[stack_pos] = new_state;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void pushState() {
|
||||||
|
stack_pos++;
|
||||||
|
state_stack[stack_pos] = state_stack[stack_pos - 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
public int popState() {
|
||||||
|
int result = state_stack[stack_pos];
|
||||||
|
stack_pos--;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StateStack(int stack_size, int initial_value) {
|
||||||
|
state_stack = new int[stack_size];
|
||||||
|
stack_pos = 0;
|
||||||
|
state_stack[stack_pos] = initial_value;
|
||||||
|
}
|
||||||
|
}
|
|
@ -40,6 +40,7 @@ import java.nio.*;
|
||||||
* @version $Revision$
|
* @version $Revision$
|
||||||
*/
|
*/
|
||||||
abstract class Util {
|
abstract class Util {
|
||||||
|
private final static IntBuffer int_buffer = ByteBuffer.allocateDirect(4).order(ByteOrder.nativeOrder()).asIntBuffer();
|
||||||
/**
|
/**
|
||||||
* A helper function which is used to get the byte offset in an arbitrary buffer
|
* A helper function which is used to get the byte offset in an arbitrary buffer
|
||||||
* based on its position
|
* based on its position
|
||||||
|
@ -55,4 +56,9 @@ abstract class Util {
|
||||||
else
|
else
|
||||||
return buffer.position();
|
return buffer.position();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int getGLInteger(int enum) {
|
||||||
|
CoreGL11.glGetInteger(enum, int_buffer);
|
||||||
|
return int_buffer.get(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2002 Lightweight Java Game Library Project
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are
|
||||||
|
* met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* * Neither the name of 'Light Weight Java Game Library' nor the names of
|
||||||
|
* its contributors may be used to endorse or promote products derived
|
||||||
|
* from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||||||
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.lwjgl.opengl;
|
||||||
|
|
||||||
|
public class VBOTracker {
|
||||||
|
private static VBOTracker default_tracker = new VBOTracker();
|
||||||
|
private static VBOTracker current_tracker = default_tracker;
|
||||||
|
|
||||||
|
private final StateStack vbo_array_stack;
|
||||||
|
private final StateStack vbo_element_stack;
|
||||||
|
private final StateStack attrib_stack;
|
||||||
|
|
||||||
|
public static void setCurrent(VBOTracker tracker) {
|
||||||
|
current_tracker = tracker;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void releaseCurrent() {
|
||||||
|
current_tracker = default_tracker;
|
||||||
|
}
|
||||||
|
|
||||||
|
public VBOTracker() {
|
||||||
|
int stack_size = Util.getGLInteger(CoreGL11Constants.GL_MAX_CLIENT_ATTRIB_STACK_DEPTH);
|
||||||
|
vbo_array_stack = new StateStack(stack_size, 0);
|
||||||
|
vbo_element_stack = new StateStack(stack_size, 0);
|
||||||
|
attrib_stack = new StateStack(stack_size, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StateStack getVBOArrayStack() {
|
||||||
|
return current_tracker.vbo_array_stack;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StateStack getVBOElementStack() {
|
||||||
|
return current_tracker.vbo_element_stack;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StateStack getClientAttribStack() {
|
||||||
|
return current_tracker.attrib_stack;
|
||||||
|
}
|
||||||
|
}
|
|
@ -66,6 +66,9 @@ public final class Window {
|
||||||
/** Fullscreen */
|
/** Fullscreen */
|
||||||
private static boolean fullscreen;
|
private static boolean fullscreen;
|
||||||
|
|
||||||
|
/** Tracks VBO state for the window context */
|
||||||
|
private static VBOTracker vbo_tracker;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a Window. Some OSs may not support non-fullscreen windows; in
|
* Construct a Window. Some OSs may not support non-fullscreen windows; in
|
||||||
* which case the window will be fullscreen regardless.
|
* which case the window will be fullscreen regardless.
|
||||||
|
@ -232,8 +235,7 @@ public final class Window {
|
||||||
Window.title = title;
|
Window.title = title;
|
||||||
Window.width = Display.getWidth();
|
Window.width = Display.getWidth();
|
||||||
Window.height = Display.getHeight();
|
Window.height = Display.getHeight();
|
||||||
nCreate(title, x, y, width, height, fullscreen, color, alpha, depth, stencil);
|
createWindow();
|
||||||
created = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -268,8 +270,7 @@ public final class Window {
|
||||||
Window.stencil = stencil;
|
Window.stencil = stencil;
|
||||||
Window.fullscreen = false;
|
Window.fullscreen = false;
|
||||||
Window.title = title;
|
Window.title = title;
|
||||||
nCreate(title, x, y, width, height, fullscreen, color, alpha, depth, stencil);
|
createWindow();
|
||||||
created = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -289,6 +290,11 @@ public final class Window {
|
||||||
int stencil)
|
int stencil)
|
||||||
throws Exception;
|
throws Exception;
|
||||||
|
|
||||||
|
private static void createWindow() throws Exception {
|
||||||
|
nCreate(title, x, y, width, height, fullscreen, color, alpha, depth, stencil);
|
||||||
|
created = true;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Destroy the window.
|
* Destroy the window.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -0,0 +1,242 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2002 Lightweight Java Game Library Project
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are
|
||||||
|
* met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* * Neither the name of 'Light Weight Java Game Library' nor the names of
|
||||||
|
* its contributors may be used to endorse or promote products derived
|
||||||
|
* from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||||||
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
* Simple java test program.
|
||||||
|
*
|
||||||
|
* @author elias_naur <elias_naur@users.sourceforge.net>
|
||||||
|
* @version $Revision$
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.lwjgl.test.opengl;
|
||||||
|
|
||||||
|
import org.lwjgl.*;
|
||||||
|
import org.lwjgl.opengl.*;
|
||||||
|
import org.lwjgl.input.*;
|
||||||
|
|
||||||
|
import java.nio.*;
|
||||||
|
|
||||||
|
public final class VBOIndexTest {
|
||||||
|
static {
|
||||||
|
try {
|
||||||
|
//find first display mode that allows us 640*480*16
|
||||||
|
int mode = -1;
|
||||||
|
DisplayMode[] modes = Display.getAvailableDisplayModes();
|
||||||
|
for (int i = 0; i < modes.length; i++) {
|
||||||
|
if (modes[i].width == 640
|
||||||
|
&& modes[i].height == 480
|
||||||
|
&& modes[i].bpp >= 16) {
|
||||||
|
mode = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mode != -1) {
|
||||||
|
//select above found displaymode
|
||||||
|
System.out.println("Setting display mode to "+modes[mode]);
|
||||||
|
Display.setDisplayMode(modes[mode]);
|
||||||
|
System.out.println("Created display.");
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println("Failed to create display due to " + e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static {
|
||||||
|
try {
|
||||||
|
Window.create("LWJGL Game Example", 16, 0, 0,0);
|
||||||
|
System.out.println("Created OpenGL.");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println("Failed to create OpenGL due to "+e);
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Is the game finished? */
|
||||||
|
private static boolean finished;
|
||||||
|
|
||||||
|
/** A rotating square! */
|
||||||
|
private static float angle;
|
||||||
|
private static int buffer_id;
|
||||||
|
private static int indices_buffer_id;
|
||||||
|
private static FloatBuffer vertices;
|
||||||
|
private static ByteBuffer mapped_buffer = null;
|
||||||
|
private static FloatBuffer mapped_float_buffer = null;
|
||||||
|
private static IntBuffer indices;
|
||||||
|
private static ByteBuffer mapped_indices_buffer = null;
|
||||||
|
private static IntBuffer mapped_indices_int_buffer = null;
|
||||||
|
|
||||||
|
public static void main(String[] arguments) {
|
||||||
|
try {
|
||||||
|
init();
|
||||||
|
while (!finished) {
|
||||||
|
Window.tick();
|
||||||
|
|
||||||
|
if (Window.isMinimized())
|
||||||
|
Thread.sleep(200);
|
||||||
|
else if (Window.isCloseRequested())
|
||||||
|
System.exit(0);
|
||||||
|
|
||||||
|
Keyboard.poll();
|
||||||
|
mainLoop();
|
||||||
|
render();
|
||||||
|
Window.paint();
|
||||||
|
}
|
||||||
|
} catch (Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
} finally {
|
||||||
|
cleanup();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* All calculations are done in here
|
||||||
|
*/
|
||||||
|
private static void mainLoop() {
|
||||||
|
angle += 1f;
|
||||||
|
if (angle > 360.0f)
|
||||||
|
angle = 0.0f;
|
||||||
|
|
||||||
|
Mouse.poll();
|
||||||
|
if (Mouse.dx != 0 || Mouse.dy != 0 || Mouse.dwheel != 0)
|
||||||
|
System.out.println("Mouse moved " + Mouse.dx + " " + Mouse.dy + " " + Mouse.dwheel);
|
||||||
|
for (int i = 0; i < Mouse.buttonCount; i++)
|
||||||
|
if (Mouse.isButtonDown(i))
|
||||||
|
System.out.println("Button " + i + " down");
|
||||||
|
/* Keyboard.poll();
|
||||||
|
if (Keyboard.isKeyDown(Keyboard.KEY_ESCAPE))
|
||||||
|
finished = true;*/
|
||||||
|
Keyboard.read();
|
||||||
|
for (int i = 0; i < Keyboard.getNumKeyboardEvents(); i++) {
|
||||||
|
Keyboard.next();
|
||||||
|
if (Keyboard.key == Keyboard.KEY_ESCAPE && Keyboard.state)
|
||||||
|
finished = true;
|
||||||
|
if (Keyboard.key == Keyboard.KEY_T && Keyboard.state)
|
||||||
|
System.out.println("Current time: " + Sys.getTime());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* All rendering is done in here
|
||||||
|
*/
|
||||||
|
private static void render() {
|
||||||
|
GL.glClear(GL.GL_COLOR_BUFFER_BIT);
|
||||||
|
GL.glPushMatrix();
|
||||||
|
GL.glTranslatef(Display.getWidth() / 2, Display.getHeight() / 2, 0.0f);
|
||||||
|
GL.glRotatef(angle, 0, 0, 1.0f);
|
||||||
|
|
||||||
|
|
||||||
|
ByteBuffer new_mapped_buffer = GL.glMapBufferARB(GL.GL_ARRAY_BUFFER_ARB, GL.GL_WRITE_ONLY_ARB, 2*4*4, mapped_buffer);
|
||||||
|
if (new_mapped_buffer != mapped_buffer)
|
||||||
|
mapped_float_buffer = new_mapped_buffer.order(ByteOrder.nativeOrder()).asFloatBuffer();
|
||||||
|
mapped_buffer = new_mapped_buffer;
|
||||||
|
|
||||||
|
new_mapped_buffer = GL.glMapBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, GL.GL_WRITE_ONLY_ARB, 4*4, mapped_indices_buffer);
|
||||||
|
if (new_mapped_buffer != mapped_indices_buffer)
|
||||||
|
mapped_indices_int_buffer = new_mapped_buffer.order(ByteOrder.nativeOrder()).asIntBuffer();
|
||||||
|
|
||||||
|
mapped_float_buffer.rewind();
|
||||||
|
vertices.rewind();
|
||||||
|
mapped_float_buffer.put(vertices);
|
||||||
|
|
||||||
|
mapped_indices_int_buffer.rewind();
|
||||||
|
indices.rewind();
|
||||||
|
mapped_indices_int_buffer.put(indices);
|
||||||
|
if (GL.glUnmapBufferARB(GL.GL_ARRAY_BUFFER_ARB) && GL.glUnmapBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB)) {
|
||||||
|
GL.glDrawElements(GL.GL_QUADS, 4, GL.GL_UNSIGNED_INT, 0);
|
||||||
|
}
|
||||||
|
GL.glPopMatrix();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize
|
||||||
|
*/
|
||||||
|
private static void init() throws Exception {
|
||||||
|
Keyboard.create();
|
||||||
|
Keyboard.enableBuffer();
|
||||||
|
Mouse.create();
|
||||||
|
Sys.setTime(0);
|
||||||
|
Sys.setProcessPriority(Sys.HIGH_PRIORITY);
|
||||||
|
System.out.println("Timer resolution: " + Sys.getTimerResolution());
|
||||||
|
// Go into orthographic projection mode.
|
||||||
|
GLCaps.determineAvailableExtensions();
|
||||||
|
GL.glMatrixMode(GL.GL_PROJECTION);
|
||||||
|
GL.glLoadIdentity();
|
||||||
|
GLU.gluOrtho2D(0, Display.getWidth(), 0, Display.getHeight());
|
||||||
|
GL.glMatrixMode(GL.GL_MODELVIEW);
|
||||||
|
GL.glLoadIdentity();
|
||||||
|
GL.glViewport(0, 0, Display.getWidth(), Display.getHeight());
|
||||||
|
if (!GLCaps.GL_ARB_vertex_buffer_object) {
|
||||||
|
System.out.println("ARB VBO not supported!");
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
IntBuffer int_buffer = ByteBuffer.allocateDirect(8).order(ByteOrder.nativeOrder()).asIntBuffer();
|
||||||
|
GL.glGenBuffersARB(int_buffer);
|
||||||
|
buffer_id = int_buffer.get(0);
|
||||||
|
indices_buffer_id = int_buffer.get(1);
|
||||||
|
GL.glBindBufferARB(GL.GL_ARRAY_BUFFER_ARB, buffer_id);
|
||||||
|
GL.glBindBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, indices_buffer_id);
|
||||||
|
vertices = ByteBuffer.allocateDirect(2*4*4).order(ByteOrder.nativeOrder()).asFloatBuffer();
|
||||||
|
vertices.put(-50).put(-50).put(50).put(-50).put(50).put(50).put(-50).put(50);
|
||||||
|
vertices.rewind();
|
||||||
|
indices = ByteBuffer.allocateDirect(4*4).order(ByteOrder.nativeOrder()).asIntBuffer();
|
||||||
|
indices.put(0).put(1).put(2).put(3);
|
||||||
|
indices.rewind();
|
||||||
|
GL.glBufferDataARB(GL.GL_ARRAY_BUFFER_ARB, 2*4*4, (ByteBuffer)null, GL.GL_STREAM_DRAW_ARB);
|
||||||
|
GL.glBufferDataARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, 4*4, (ByteBuffer)null, GL.GL_STREAM_DRAW_ARB);
|
||||||
|
GL.glEnableClientState(GL.GL_VERTEX_ARRAY);
|
||||||
|
GL.glVertexPointer(2, GL.GL_FLOAT, 0, 0);
|
||||||
|
GL.glGetInteger(GL.GL_MAX_TEXTURE_UNITS_ARB, int_buffer);
|
||||||
|
System.out.println("Number of texture units: " + int_buffer.get(0));
|
||||||
|
// Fix the refresh rate to the display frequency.
|
||||||
|
// gl.wglSwapIntervalEXT(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cleanup
|
||||||
|
*/
|
||||||
|
private static void cleanup() {
|
||||||
|
IntBuffer int_buffer = ByteBuffer.allocateDirect(8).order(ByteOrder.nativeOrder()).asIntBuffer();
|
||||||
|
int_buffer.put(0, buffer_id);
|
||||||
|
int_buffer.put(1, indices_buffer_id);
|
||||||
|
GL.glDeleteBuffersARB(int_buffer);
|
||||||
|
Keyboard.destroy();
|
||||||
|
Mouse.destroy();
|
||||||
|
Window.destroy();
|
||||||
|
try {
|
||||||
|
Display.resetDisplayMode();
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -191,9 +191,8 @@ public final class VBOTest {
|
||||||
vertices = ByteBuffer.allocateDirect(2*4*4).order(ByteOrder.nativeOrder()).asFloatBuffer();
|
vertices = ByteBuffer.allocateDirect(2*4*4).order(ByteOrder.nativeOrder()).asFloatBuffer();
|
||||||
vertices.put(-50).put(-50).put(50).put(-50).put(50).put(50).put(-50).put(50);
|
vertices.put(-50).put(-50).put(50).put(-50).put(50).put(50).put(-50).put(50);
|
||||||
GL.glBufferDataARB(GL.GL_ARRAY_BUFFER_ARB, 2*4*4, (ByteBuffer)null, GL.GL_STREAM_DRAW_ARB);
|
GL.glBufferDataARB(GL.GL_ARRAY_BUFFER_ARB, 2*4*4, (ByteBuffer)null, GL.GL_STREAM_DRAW_ARB);
|
||||||
ByteBuffer index_buffer = Sys.createIndexBuffer(0);
|
|
||||||
GL.glEnableClientState(GL.GL_VERTEX_ARRAY);
|
GL.glEnableClientState(GL.GL_VERTEX_ARRAY);
|
||||||
GL.glVertexPointer(2, 0, index_buffer.asFloatBuffer());
|
GL.glVertexPointer(2, GL.GL_FLOAT, 0, 0);
|
||||||
GL.glGetInteger(GL.GL_MAX_TEXTURE_UNITS_ARB, int_buffer);
|
GL.glGetInteger(GL.GL_MAX_TEXTURE_UNITS_ARB, int_buffer);
|
||||||
System.out.println("Number of texture units: " + int_buffer.get(0));
|
System.out.println("Number of texture units: " + int_buffer.get(0));
|
||||||
// Fix the refresh rate to the display frequency.
|
// Fix the refresh rate to the display frequency.
|
||||||
|
|
|
@ -2625,7 +2625,7 @@ typedef void (APIENTRY * glSecondaryColor3uiPROC) (GLuint red, GLuint green, GLu
|
||||||
typedef void (APIENTRY * glSecondaryColor3uivPROC) (const GLuint *v);
|
typedef void (APIENTRY * glSecondaryColor3uivPROC) (const GLuint *v);
|
||||||
typedef void (APIENTRY * glSecondaryColor3usPROC) (GLushort red, GLushort green, GLushort blue);
|
typedef void (APIENTRY * glSecondaryColor3usPROC) (GLushort red, GLushort green, GLushort blue);
|
||||||
typedef void (APIENTRY * glSecondaryColor3usvPROC) (const GLushort *v);
|
typedef void (APIENTRY * glSecondaryColor3usvPROC) (const GLushort *v);
|
||||||
typedef void (APIENTRY * glSecondaryColorPointerPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer);
|
typedef void (APIENTRY * glSecondaryColorPointerPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer);
|
||||||
typedef void (APIENTRY * glBlendFuncSeparatePROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha);
|
typedef void (APIENTRY * glBlendFuncSeparatePROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha);
|
||||||
typedef void (APIENTRY * glWindowPos2dPROC) (GLdouble x, GLdouble y);
|
typedef void (APIENTRY * glWindowPos2dPROC) (GLdouble x, GLdouble y);
|
||||||
typedef void (APIENTRY * glWindowPos2fPROC) (GLfloat x, GLfloat y);
|
typedef void (APIENTRY * glWindowPos2fPROC) (GLfloat x, GLfloat y);
|
||||||
|
@ -4078,7 +4078,7 @@ typedef void (APIENTRY * glWeightdvARBPROC) (GLint size, GLdouble *weights);
|
||||||
typedef void (APIENTRY * glWeightubvARBPROC) (GLint size, GLubyte *weights);
|
typedef void (APIENTRY * glWeightubvARBPROC) (GLint size, GLubyte *weights);
|
||||||
typedef void (APIENTRY * glWeightusvARBPROC) (GLint size, GLushort *weights);
|
typedef void (APIENTRY * glWeightusvARBPROC) (GLint size, GLushort *weights);
|
||||||
typedef void (APIENTRY * glWeightuivARBPROC) (GLint size, GLuint *weights);
|
typedef void (APIENTRY * glWeightuivARBPROC) (GLint size, GLuint *weights);
|
||||||
typedef void (APIENTRY * glWeightPointerARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer);
|
typedef void (APIENTRY * glWeightPointerARBPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer);
|
||||||
typedef void (APIENTRY * glVertexBlendARBPROC) (GLint count);
|
typedef void (APIENTRY * glVertexBlendARBPROC) (GLint count);
|
||||||
|
|
||||||
extern glWeightbvARBPROC glWeightbvARB;
|
extern glWeightbvARBPROC glWeightbvARB;
|
||||||
|
|
|
@ -20,14 +20,6 @@ extern "C" {
|
||||||
/* Inaccessible static: DEBUG */
|
/* Inaccessible static: DEBUG */
|
||||||
/* Inaccessible static: _debug */
|
/* Inaccessible static: _debug */
|
||||||
/* Inaccessible static: class_00024org_00024lwjgl_00024Sys */
|
/* Inaccessible static: class_00024org_00024lwjgl_00024Sys */
|
||||||
/*
|
|
||||||
* Class: org_lwjgl_Sys
|
|
||||||
* Method: createIndexBuffer
|
|
||||||
* Signature: (I)Ljava/nio/ByteBuffer;
|
|
||||||
*/
|
|
||||||
JNIEXPORT jobject JNICALL Java_org_lwjgl_Sys_createIndexBuffer
|
|
||||||
(JNIEnv *, jclass, jint);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_Sys
|
* Class: org_lwjgl_Sys
|
||||||
* Method: getTimerResolution
|
* Method: getTimerResolution
|
||||||
|
|
|
@ -54,6 +54,10 @@ static inline jobject newBuffer(JNIEnv *env, void *p, int size) {
|
||||||
return env->NewDirectByteBuffer(p, size);
|
return env->NewDirectByteBuffer(p, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline const void *offsetToPointer(jint offset) {
|
||||||
|
return (const char *)NULL + offset;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glAccum
|
* Method: glAccum
|
||||||
|
@ -277,7 +281,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glCopyPixels(JNIEnv * env,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glColorPointer
|
* Method: nglColorPointer
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint buffer_offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint buffer_offset)
|
||||||
{
|
{
|
||||||
|
@ -286,6 +290,16 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointer(JNIEnv * e
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglColorPointerVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointerVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glColorPointer((GLint) p0, (GLint) p1, (GLint) p2, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glColorMaterial
|
* Method: glColorMaterial
|
||||||
|
@ -493,15 +507,25 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glDisable(JNIEnv * env, jc
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glEdgeFlagPointer
|
* Method: nglEdgeFlagPointer
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglEdgeFlagPointer(JNIEnv * env, jclass clazz, jint p0, jobject buffer, int offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglEdgeFlagPointer(JNIEnv * env, jclass clazz, jint p0, jobject buffer, jint offset)
|
||||||
{
|
{
|
||||||
const GLbyte *address = offset + (const GLbyte *)env->GetDirectBufferAddress(buffer);
|
const GLbyte *address = offset + (const GLbyte *)env->GetDirectBufferAddress(buffer);
|
||||||
glEdgeFlagPointer((GLint) p0, (const void *)address);
|
glEdgeFlagPointer((GLint) p0, (const void *)address);
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglEdgeFlagPointerVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglEdgeFlagPointerVBO(JNIEnv * env, jclass clazz, jint p0, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glEdgeFlagPointer((GLint) p0, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glEdgeFlag
|
* Method: glEdgeFlag
|
||||||
|
@ -524,7 +548,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawPixels(JNIEnv * env
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glDrawElements
|
* Method: nglDrawElements
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElements(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElements(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint offset)
|
||||||
{
|
{
|
||||||
|
@ -533,6 +557,16 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElements(JNIEnv * e
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglDrawElementsVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElementsVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glDrawElements((GLint) p0, (GLint) p1, (GLint) p2, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glDrawBuffer
|
* Method: glDrawBuffer
|
||||||
|
@ -888,7 +922,7 @@ JNIEXPORT jboolean JNICALL Java_org_lwjgl_opengl_CoreGL11_glIsEnabled(JNIEnv * e
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glInterleavedArrays
|
* Method: nglInterleavedArrays
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArrays(JNIEnv * env, jclass clazz, jint p0, jint p1, jobject buffer, jint offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArrays(JNIEnv * env, jclass clazz, jint p0, jint p1, jobject buffer, jint offset)
|
||||||
{
|
{
|
||||||
|
@ -897,6 +931,16 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArrays(JNIEn
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglInterleavedArraysVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArraysVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glInterleavedArrays((GLint) p0, (GLint) p1, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glInitNames
|
* Method: glInitNames
|
||||||
|
@ -1452,7 +1496,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glOrtho(JNIEnv * env, jcla
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glNormalPointer
|
* Method: nglNormalPointer
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jobject buffer, jint offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jobject buffer, jint offset)
|
||||||
{
|
{
|
||||||
|
@ -1461,6 +1505,16 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointer(JNIEnv *
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglNormalPointerVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointerVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glNormalPointer((GLint) p0, (GLint) p1, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glNormal3b
|
* Method: glNormal3b
|
||||||
|
@ -1735,9 +1789,9 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPopMatrix(JNIEnv * env,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glPushClientAttrib
|
* Method: nglPushClientAttrib
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPushClientAttrib(JNIEnv * env, jclass clazz, jint p0)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglPushClientAttrib(JNIEnv * env, jclass clazz, jint p0)
|
||||||
{
|
{
|
||||||
glPushClientAttrib((GLint) p0);
|
glPushClientAttrib((GLint) p0);
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
|
@ -1745,9 +1799,9 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPushClientAttrib(JNIEnv
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glPopClientAttrib
|
* Method: nglPopClientAttrib
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPopClientAttrib(JNIEnv * env, jclass clazz)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglPopClientAttrib(JNIEnv * env, jclass clazz)
|
||||||
{
|
{
|
||||||
glPopClientAttrib();
|
glPopClientAttrib();
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
|
@ -1785,7 +1839,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glStencilFunc(JNIEnv * env
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glVertexPointer
|
* Method: nglVertexPointer
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint offset)
|
||||||
{
|
{
|
||||||
|
@ -1794,6 +1848,15 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointer(JNIEnv *
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglVertexPointerVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointerVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glVertexPointer((GLint) p0, (GLint) p1, (GLint) p2, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
@ -2017,7 +2080,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexEnviv(JNIEnv * env,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glTexCoordPointer
|
* Method: nglTexCoordPointer
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint offset)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointer(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jobject buffer, jint offset)
|
||||||
{
|
{
|
||||||
|
@ -2026,6 +2089,16 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointer(JNIEnv
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglTexCoordPointerVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointerVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jint buffer_offset)
|
||||||
|
{
|
||||||
|
glTexCoordPointer((GLint) p0, (GLint) p1, (GLint) p2, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glTexCoord1f
|
* Method: glTexCoord1f
|
||||||
|
|
|
@ -7,6 +7,8 @@
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL11 */
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glAccum
|
* Method: glAccum
|
||||||
|
@ -191,6 +193,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glCopyPixels
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointer
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglColorPointerVBO
|
||||||
|
* Signature: (IIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglColorPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glColorMaterial
|
* Method: glColorMaterial
|
||||||
|
@ -367,6 +377,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glDisable
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglEdgeFlagPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglEdgeFlagPointer
|
||||||
(JNIEnv *, jclass, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglEdgeFlagPointerVBO
|
||||||
|
* Signature: (II)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglEdgeFlagPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glEdgeFlag
|
* Method: glEdgeFlag
|
||||||
|
@ -391,6 +409,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawPixels
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElements
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElements
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglDrawElementsVBO
|
||||||
|
* Signature: (IIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglDrawElementsVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glDrawBuffer
|
* Method: glDrawBuffer
|
||||||
|
@ -663,6 +689,14 @@ JNIEXPORT jboolean JNICALL Java_org_lwjgl_opengl_CoreGL11_glIsEnabled
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArrays
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArrays
|
||||||
(JNIEnv *, jclass, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglInterleavedArraysVBO
|
||||||
|
* Signature: (III)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglInterleavedArraysVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glInitNames
|
* Method: glInitNames
|
||||||
|
@ -1087,6 +1121,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glOrtho
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointer
|
||||||
(JNIEnv *, jclass, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglNormalPointerVBO
|
||||||
|
* Signature: (III)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglNormalPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glNormal3b
|
* Method: glNormal3b
|
||||||
|
@ -1297,18 +1339,18 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPopMatrix
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glPushClientAttrib
|
* Method: nglPushClientAttrib
|
||||||
* Signature: (I)V
|
* Signature: (I)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPushClientAttrib
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglPushClientAttrib
|
||||||
(JNIEnv *, jclass, jint);
|
(JNIEnv *, jclass, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glPopClientAttrib
|
* Method: nglPopClientAttrib
|
||||||
* Signature: ()V
|
* Signature: ()V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glPopClientAttrib
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglPopClientAttrib
|
||||||
(JNIEnv *, jclass);
|
(JNIEnv *, jclass);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1343,6 +1385,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_glStencilFunc
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointer
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglVertexPointerVBO
|
||||||
|
* Signature: (IIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglVertexPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glVertex2f
|
* Method: glVertex2f
|
||||||
|
@ -1519,6 +1569,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexEnviv
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointer
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
|
* Method: nglTexCoordPointerVBO
|
||||||
|
* Signature: (IIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL11_nglTexCoordPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL11
|
* Class: org_lwjgl_opengl_CoreGL11
|
||||||
* Method: glTexCoord1f
|
* Method: glTexCoord1f
|
||||||
|
|
|
@ -47,6 +47,10 @@
|
||||||
#include "checkGLerror.h"
|
#include "checkGLerror.h"
|
||||||
#include "extgl.h"
|
#include "extgl.h"
|
||||||
|
|
||||||
|
static inline const void *offsetToPointer(jint offset) {
|
||||||
|
return (const char *)NULL + offset;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL12
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
* Method: glColorTable
|
* Method: glColorTable
|
||||||
|
@ -518,7 +522,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglGetSeparableFilter
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL12
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
* Method: glDrawRangeElements
|
* Method: nglDrawRangeElements
|
||||||
* Signature: (IIIIII)V
|
* Signature: (IIIIII)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElements
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElements
|
||||||
|
@ -530,6 +534,19 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElements
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
|
* Method: nglDrawRangeElementsVBO
|
||||||
|
* Signature: (IIIIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElementsVBO
|
||||||
|
(JNIEnv *env, jclass clazz, jint mode, jint start, jint end, jint count, jint type, jint buffer_offset)
|
||||||
|
{
|
||||||
|
CHECK_EXISTS(glDrawRangeElements)
|
||||||
|
glDrawRangeElements(mode, start, end, count, type, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL12
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
* Method: glTexImage3D
|
* Method: glTexImage3D
|
||||||
|
|
|
@ -7,6 +7,10 @@
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL11 */
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL12 */
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL12
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
* Method: nglColorTable
|
* Method: nglColorTable
|
||||||
|
@ -287,6 +291,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglGetSeparableFilter
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElements
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElements
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
|
* Method: nglDrawRangeElementsVBO
|
||||||
|
* Signature: (IIIIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL12_nglDrawRangeElementsVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL12
|
* Class: org_lwjgl_opengl_CoreGL12
|
||||||
* Method: nglTexImage3D
|
* Method: nglTexImage3D
|
||||||
|
|
|
@ -47,6 +47,10 @@
|
||||||
#include "checkGLerror.h"
|
#include "checkGLerror.h"
|
||||||
#include "extgl.h"
|
#include "extgl.h"
|
||||||
|
|
||||||
|
static inline const void *offsetToPointer(jint offset) {
|
||||||
|
return (const char *)NULL + offset;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: glFogCoordf
|
* Method: glFogCoordf
|
||||||
|
@ -61,7 +65,7 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_glFogCoordf
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: glFogCoordPointer
|
* Method: nglFogCoordPointer
|
||||||
* Signature: (IILjava/nio/Buffer;)V
|
* Signature: (IILjava/nio/Buffer;)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointer
|
||||||
|
@ -72,6 +76,18 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointer
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
|
* Method: nglFogCoordPointerVBO
|
||||||
|
* Signature: (IILjava/nio/Buffer;)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointerVBO
|
||||||
|
(JNIEnv *env, jclass clazz, jint p1, jint p2, jint buffer_offset) {
|
||||||
|
CHECK_EXISTS(glFogCoordPointer)
|
||||||
|
glFogCoordPointer(p1, p2, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: glMultiDrawArrays
|
* Method: glMultiDrawArrays
|
||||||
|
@ -163,17 +179,29 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_glSecondaryColor3ub
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: glSecondaryColorPointer
|
* Method: nglSecondaryColorPointer
|
||||||
* Signature: (IIILjava/nio/Buffer;)V
|
* Signature: (IIILjava/nio/Buffer;)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglSecondaryColorPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglSecondaryColorPointer
|
||||||
(JNIEnv *env, jclass clazz, jint p1, jint p2, jint p3, jobject buffer, jint offset) {
|
(JNIEnv *env, jclass clazz, jint p1, jint p2, jint p3, jobject buffer, jint offset) {
|
||||||
CHECK_EXISTS(glSecondaryColorPointer)
|
CHECK_EXISTS(glSecondaryColorPointer)
|
||||||
GLvoid *address = (GLvoid *)(offset + (GLbyte *)env->GetDirectBufferAddress(buffer));
|
const GLvoid *address = (const GLvoid *)(offset + (GLbyte *)env->GetDirectBufferAddress(buffer));
|
||||||
glSecondaryColorPointer(p1, p2, p3, address);
|
glSecondaryColorPointer(p1, p2, p3, address);
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
|
* Method: nglSecondaryColorPointerVBO
|
||||||
|
* Signature: (IIILjava/nio/Buffer;)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglSecondaryColorPointerVBO
|
||||||
|
(JNIEnv *env, jclass clazz, jint p1, jint p2, jint p3, jint buffer_offset) {
|
||||||
|
CHECK_EXISTS(glSecondaryColorPointer)
|
||||||
|
glSecondaryColorPointer(p1, p2, p3, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: glBlendFuncSeparate
|
* Method: glBlendFuncSeparate
|
||||||
|
|
|
@ -8,6 +8,10 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
/* Inaccessible static: _00024assertionsDisabled */
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL11 */
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL12 */
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL14 */
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL14 */
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
|
@ -25,6 +29,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_glFogCoordf
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointer
|
||||||
(JNIEnv *, jclass, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
|
* Method: nglFogCoordPointerVBO
|
||||||
|
* Signature: (III)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglFogCoordPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: nglMultiDrawArrays
|
* Method: nglMultiDrawArrays
|
||||||
|
@ -81,6 +93,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_glSecondaryColor3ub
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglSecondaryColorPointer
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglSecondaryColorPointer
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
|
* Method: nglSecondaryColorPointerVBO
|
||||||
|
* Signature: (IIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_CoreGL14_nglSecondaryColorPointerVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_CoreGL14
|
* Class: org_lwjgl_opengl_CoreGL14
|
||||||
* Method: glBlendFuncSeparate
|
* Method: glBlendFuncSeparate
|
||||||
|
|
|
@ -65,6 +65,10 @@ static inline jobject safeNewBuffer(JNIEnv *env, void *p, int size) {
|
||||||
return env->NewDirectByteBuffer(p, size);
|
return env->NewDirectByteBuffer(p, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline const void *offsetToPointer(jint offset) {
|
||||||
|
return (const char *)NULL + offset;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: glActiveStencilFaceEXT
|
* Method: glActiveStencilFaceEXT
|
||||||
|
@ -2711,6 +2715,17 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglVertexAttribPointerARB(JNIEnv
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_GL
|
||||||
|
* Method: nglVertexAttribPointerARBVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglVertexAttribPointerARBVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jboolean p3, jint p4, jint buffer_offset)
|
||||||
|
{
|
||||||
|
CHECK_EXISTS(glVertexAttribPointerARB)
|
||||||
|
glVertexAttribPointerARB((GLuint) p0, (GLint) p1, (GLuint) p2, (GLboolean) p3, (GLint) p4, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: nglVertexAttribPointerNV
|
* Method: nglVertexAttribPointerNV
|
||||||
|
@ -3021,6 +3036,17 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglWeightPointerARB(JNIEnv * env
|
||||||
CHECK_GL_ERROR
|
CHECK_GL_ERROR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_GL
|
||||||
|
* Method: nglWeightPointerARBVBO
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglWeightPointerARBVBO(JNIEnv * env, jclass clazz, jint p0, jint p1, jint p2, jint buffer_offset)
|
||||||
|
{
|
||||||
|
CHECK_EXISTS(glWeightPointerARB)
|
||||||
|
glWeightPointerARB((GLint) p0, (GLuint) p1, (GLint) p2, offsetToPointer(buffer_offset));
|
||||||
|
CHECK_GL_ERROR
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: nglWeightsvARB
|
* Method: nglWeightsvARB
|
||||||
|
@ -3544,10 +3570,10 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_glWriteMaskEXT(JNIEnv * env, jcl
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: glBindBufferARB
|
* Method: nglBindBufferARB
|
||||||
* Signature: (II)V
|
* Signature: (II)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_glBindBufferARB(JNIEnv *env, jclass clazz, jint target, jint buffer)
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglBindBufferARB(JNIEnv *env, jclass clazz, jint target, jint buffer)
|
||||||
{
|
{
|
||||||
CHECK_EXISTS(glBindBufferARB)
|
CHECK_EXISTS(glBindBufferARB)
|
||||||
glBindBufferARB((GLenum) target, (GLuint) buffer);
|
glBindBufferARB((GLenum) target, (GLuint) buffer);
|
||||||
|
|
|
@ -8,9 +8,13 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
/* Inaccessible static: _00024assertionsDisabled */
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
/* Inaccessible static: class_000240 */
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL11 */
|
||||||
/* Inaccessible static: _00024assertionsDisabled */
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
/* Inaccessible static: class_000240 */
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL12 */
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024CoreGL14 */
|
||||||
|
/* Inaccessible static: _00024assertionsDisabled */
|
||||||
|
/* Inaccessible static: class_00024org_00024lwjgl_00024opengl_00024GL */
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: glActiveStencilFaceEXT
|
* Method: glActiveStencilFaceEXT
|
||||||
|
@ -1859,6 +1863,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglVertexAttrib4usvARB
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglVertexAttribPointerARB
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglVertexAttribPointerARB
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jboolean, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jboolean, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_GL
|
||||||
|
* Method: nglVertexAttribPointerARBVBO
|
||||||
|
* Signature: (IIIZII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglVertexAttribPointerARBVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jboolean, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: nglVertexAttribPointerNV
|
* Method: nglVertexAttribPointerNV
|
||||||
|
@ -2083,6 +2095,14 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglWeightivARB
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglWeightPointerARB
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglWeightPointerARB
|
||||||
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
(JNIEnv *, jclass, jint, jint, jint, jobject, jint);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_lwjgl_opengl_GL
|
||||||
|
* Method: nglWeightPointerARBVBO
|
||||||
|
* Signature: (IIII)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglWeightPointerARBVBO
|
||||||
|
(JNIEnv *, jclass, jint, jint, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: nglWeightsvARB
|
* Method: nglWeightsvARB
|
||||||
|
@ -2261,10 +2281,10 @@ JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_glWriteMaskEXT
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_opengl_GL
|
* Class: org_lwjgl_opengl_GL
|
||||||
* Method: glBindBufferARB
|
* Method: nglBindBufferARB
|
||||||
* Signature: (II)V
|
* Signature: (II)V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_glBindBufferARB
|
JNIEXPORT void JNICALL Java_org_lwjgl_opengl_GL_nglBindBufferARB
|
||||||
(JNIEnv *, jclass, jint, jint);
|
(JNIEnv *, jclass, jint, jint);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -49,17 +49,6 @@ long int hires_timer_start; // Hires timer start
|
||||||
long int hires_timer; // Hires timer current time
|
long int hires_timer; // Hires timer current time
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_Sys
|
|
||||||
* Method: createIndexBuffer
|
|
||||||
* Signature: (I)Ljava/nio/ByteBuffer;
|
|
||||||
*/
|
|
||||||
JNIEXPORT jobject JNICALL Java_org_lwjgl_Sys_createIndexBuffer
|
|
||||||
(JNIEnv *env, jclass clazz, jint index)
|
|
||||||
{
|
|
||||||
void *p = (char *)NULL + index;
|
|
||||||
return env->NewDirectByteBuffer(p, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_Sys
|
* Class: org_lwjgl_Sys
|
||||||
* Method: getTimerResolution
|
* Method: getTimerResolution
|
||||||
|
|
|
@ -49,18 +49,6 @@ __int64 hires_timer_freq; // Hires timer frequency
|
||||||
__int64 hires_timer_start; // Hires timer start
|
__int64 hires_timer_start; // Hires timer start
|
||||||
__int64 hires_timer; // Hires timer current time
|
__int64 hires_timer; // Hires timer current time
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: org_lwjgl_Sys
|
|
||||||
* Method: createIndexBuffer
|
|
||||||
* Signature: (I)Ljava/nio/ByteBuffer;
|
|
||||||
*/
|
|
||||||
JNIEXPORT jobject JNICALL Java_org_lwjgl_Sys_createIndexBuffer
|
|
||||||
(JNIEnv *env, jclass clazz, jint index)
|
|
||||||
{
|
|
||||||
void *p = (char *)NULL + index;
|
|
||||||
return env->NewDirectByteBuffer(p, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: org_lwjgl_Sys
|
* Class: org_lwjgl_Sys
|
||||||
* Method: getTimerResolution
|
* Method: getTimerResolution
|
||||||
|
|
Loading…
Reference in New Issue