All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.lwjgl.opengl.GL20 Maven / Gradle / Ivy

Go to download

The most widely adopted 2D and 3D graphics API in the industry, bringing thousands of applications to a wide variety of computer platforms.

There is a newer version: 3.3.5
Show newest version
/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.opengl;

import java.nio.*;

import org.lwjgl.*;

import org.lwjgl.system.*;

import static org.lwjgl.system.Checks.*;
import static org.lwjgl.system.JNI.*;
import static org.lwjgl.system.MemoryStack.*;
import static org.lwjgl.system.MemoryUtil.*;

/**
 * The core OpenGL 2.0 functionality.
 * 
 * 

Extensions promoted to core in this release:

* * */ public class GL20 { /** Accepted by the {@code name} parameter of GetString. */ public static final int GL_SHADING_LANGUAGE_VERSION = 0x8B8C; /** Accepted by the {@code pname} parameter of GetInteger. */ public static final int GL_CURRENT_PROGRAM = 0x8B8D; /** Accepted by the {@code pname} parameter of GetShaderiv. */ public static final int GL_SHADER_TYPE = 0x8B4F, GL_DELETE_STATUS = 0x8B80, GL_COMPILE_STATUS = 0x8B81, GL_LINK_STATUS = 0x8B82, GL_VALIDATE_STATUS = 0x8B83, GL_INFO_LOG_LENGTH = 0x8B84, GL_ATTACHED_SHADERS = 0x8B85, GL_ACTIVE_UNIFORMS = 0x8B86, GL_ACTIVE_UNIFORM_MAX_LENGTH = 0x8B87, GL_ACTIVE_ATTRIBUTES = 0x8B89, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH = 0x8B8A, GL_SHADER_SOURCE_LENGTH = 0x8B88; /** Returned by the {@code type} parameter of GetActiveUniform. */ public static final int GL_FLOAT_VEC2 = 0x8B50, GL_FLOAT_VEC3 = 0x8B51, GL_FLOAT_VEC4 = 0x8B52, GL_INT_VEC2 = 0x8B53, GL_INT_VEC3 = 0x8B54, GL_INT_VEC4 = 0x8B55, GL_BOOL = 0x8B56, GL_BOOL_VEC2 = 0x8B57, GL_BOOL_VEC3 = 0x8B58, GL_BOOL_VEC4 = 0x8B59, GL_FLOAT_MAT2 = 0x8B5A, GL_FLOAT_MAT3 = 0x8B5B, GL_FLOAT_MAT4 = 0x8B5C, GL_SAMPLER_1D = 0x8B5D, GL_SAMPLER_2D = 0x8B5E, GL_SAMPLER_3D = 0x8B5F, GL_SAMPLER_CUBE = 0x8B60, GL_SAMPLER_1D_SHADOW = 0x8B61, GL_SAMPLER_2D_SHADOW = 0x8B62; /** Accepted by the {@code type} argument of CreateShader and returned by the {@code params} parameter of GetShaderiv. */ public static final int GL_VERTEX_SHADER = 0x8B31; /** Accepted by the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and GetDoublev. */ public static final int GL_MAX_VERTEX_UNIFORM_COMPONENTS = 0x8B4A, GL_MAX_VARYING_FLOATS = 0x8B4B, GL_MAX_VERTEX_ATTRIBS = 0x8869, GL_MAX_TEXTURE_IMAGE_UNITS = 0x8872, GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS = 0x8B4C, GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS = 0x8B4D, GL_MAX_TEXTURE_COORDS = 0x8871; /** * Accepted by the {@code cap} parameter of Disable, Enable, and IsEnabled, and by the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and * GetDoublev. */ public static final int GL_VERTEX_PROGRAM_POINT_SIZE = 0x8642, GL_VERTEX_PROGRAM_TWO_SIDE = 0x8643; /** Accepted by the {@code pname} parameter of GetVertexAttrib{dfi}v. */ public static final int GL_VERTEX_ATTRIB_ARRAY_ENABLED = 0x8622, GL_VERTEX_ATTRIB_ARRAY_SIZE = 0x8623, GL_VERTEX_ATTRIB_ARRAY_STRIDE = 0x8624, GL_VERTEX_ATTRIB_ARRAY_TYPE = 0x8625, GL_VERTEX_ATTRIB_ARRAY_NORMALIZED = 0x886A, GL_CURRENT_VERTEX_ATTRIB = 0x8626; /** Accepted by the {@code pname} parameter of GetVertexAttribPointerv. */ public static final int GL_VERTEX_ATTRIB_ARRAY_POINTER = 0x8645; /** Accepted by the {@code type} argument of CreateShader and returned by the {@code params} parameter of GetShaderiv. */ public static final int GL_FRAGMENT_SHADER = 0x8B30; /** Accepted by the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and GetDoublev. */ public static final int GL_MAX_FRAGMENT_UNIFORM_COMPONENTS = 0x8B49; /** Accepted by the {@code target} parameter of Hint and the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and GetDoublev. */ public static final int GL_FRAGMENT_SHADER_DERIVATIVE_HINT = 0x8B8B; /** Accepted by the {@code pname} parameters of GetIntegerv, GetFloatv, and GetDoublev. */ public static final int GL_MAX_DRAW_BUFFERS = 0x8824, GL_DRAW_BUFFER0 = 0x8825, GL_DRAW_BUFFER1 = 0x8826, GL_DRAW_BUFFER2 = 0x8827, GL_DRAW_BUFFER3 = 0x8828, GL_DRAW_BUFFER4 = 0x8829, GL_DRAW_BUFFER5 = 0x882A, GL_DRAW_BUFFER6 = 0x882B, GL_DRAW_BUFFER7 = 0x882C, GL_DRAW_BUFFER8 = 0x882D, GL_DRAW_BUFFER9 = 0x882E, GL_DRAW_BUFFER10 = 0x882F, GL_DRAW_BUFFER11 = 0x8830, GL_DRAW_BUFFER12 = 0x8831, GL_DRAW_BUFFER13 = 0x8832, GL_DRAW_BUFFER14 = 0x8833, GL_DRAW_BUFFER15 = 0x8834; /** * Accepted by the {@code cap} parameter of Enable, Disable, and IsEnabled, by the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and * GetDoublev, and by the {@code target} parameter of TexEnvi, TexEnviv, TexEnvf, TexEnvfv, GetTexEnviv, and GetTexEnvfv. */ public static final int GL_POINT_SPRITE = 0x8861; /** * When the {@code target} parameter of TexEnvf, TexEnvfv, TexEnvi, TexEnviv, GetTexEnvfv, or GetTexEnviv is POINT_SPRITE, then the value of * {@code pname} may be. */ public static final int GL_COORD_REPLACE = 0x8862; /** Accepted by the {@code pname} parameter of PointParameter{if}v. */ public static final int GL_POINT_SPRITE_COORD_ORIGIN = 0x8CA0; /** Accepted by the {@code param} parameter of PointParameter{if}v. */ public static final int GL_LOWER_LEFT = 0x8CA1, GL_UPPER_LEFT = 0x8CA2; /** Accepted by the {@code pname} parameter of GetBooleanv, GetIntegerv, GetFloatv, and GetDoublev. */ public static final int GL_BLEND_EQUATION_RGB = 0x8009, GL_BLEND_EQUATION_ALPHA = 0x883D; /** Accepted by the {@code pname} parameter of GetIntegerv. */ public static final int GL_STENCIL_BACK_FUNC = 0x8800, GL_STENCIL_BACK_FAIL = 0x8801, GL_STENCIL_BACK_PASS_DEPTH_FAIL = 0x8802, GL_STENCIL_BACK_PASS_DEPTH_PASS = 0x8803, GL_STENCIL_BACK_REF = 0x8CA3, GL_STENCIL_BACK_VALUE_MASK = 0x8CA4, GL_STENCIL_BACK_WRITEMASK = 0x8CA5; static { GL.initialize(); } protected GL20() { throw new UnsupportedOperationException(); } static boolean isAvailable(GLCapabilities caps) { return checkFunctions( caps.glCreateProgram, caps.glDeleteProgram, caps.glIsProgram, caps.glCreateShader, caps.glDeleteShader, caps.glIsShader, caps.glAttachShader, caps.glDetachShader, caps.glShaderSource, caps.glCompileShader, caps.glLinkProgram, caps.glUseProgram, caps.glValidateProgram, caps.glUniform1f, caps.glUniform2f, caps.glUniform3f, caps.glUniform4f, caps.glUniform1i, caps.glUniform2i, caps.glUniform3i, caps.glUniform4i, caps.glUniform1fv, caps.glUniform2fv, caps.glUniform3fv, caps.glUniform4fv, caps.glUniform1iv, caps.glUniform2iv, caps.glUniform3iv, caps.glUniform4iv, caps.glUniformMatrix2fv, caps.glUniformMatrix3fv, caps.glUniformMatrix4fv, caps.glGetShaderiv, caps.glGetProgramiv, caps.glGetShaderInfoLog, caps.glGetProgramInfoLog, caps.glGetAttachedShaders, caps.glGetUniformLocation, caps.glGetActiveUniform, caps.glGetUniformfv, caps.glGetUniformiv, caps.glGetShaderSource, caps.glVertexAttrib1f, caps.glVertexAttrib1s, caps.glVertexAttrib1d, caps.glVertexAttrib2f, caps.glVertexAttrib2s, caps.glVertexAttrib2d, caps.glVertexAttrib3f, caps.glVertexAttrib3s, caps.glVertexAttrib3d, caps.glVertexAttrib4f, caps.glVertexAttrib4s, caps.glVertexAttrib4d, caps.glVertexAttrib4Nub, caps.glVertexAttrib1fv, caps.glVertexAttrib1sv, caps.glVertexAttrib1dv, caps.glVertexAttrib2fv, caps.glVertexAttrib2sv, caps.glVertexAttrib2dv, caps.glVertexAttrib3fv, caps.glVertexAttrib3sv, caps.glVertexAttrib3dv, caps.glVertexAttrib4fv, caps.glVertexAttrib4sv, caps.glVertexAttrib4dv, caps.glVertexAttrib4iv, caps.glVertexAttrib4bv, caps.glVertexAttrib4ubv, caps.glVertexAttrib4usv, caps.glVertexAttrib4uiv, caps.glVertexAttrib4Nbv, caps.glVertexAttrib4Nsv, caps.glVertexAttrib4Niv, caps.glVertexAttrib4Nubv, caps.glVertexAttrib4Nusv, caps.glVertexAttrib4Nuiv, caps.glVertexAttribPointer, caps.glEnableVertexAttribArray, caps.glDisableVertexAttribArray, caps.glBindAttribLocation, caps.glGetActiveAttrib, caps.glGetAttribLocation, caps.glGetVertexAttribiv, caps.glGetVertexAttribfv, caps.glGetVertexAttribdv, caps.glGetVertexAttribPointerv, caps.glDrawBuffers, caps.glBlendEquationSeparate, caps.glStencilOpSeparate, caps.glStencilFuncSeparate, caps.glStencilMaskSeparate ); } // --- [ glCreateProgram ] --- /** *

Reference Page

* * Creates a program object. */ @NativeType("GLuint") public static native int glCreateProgram(); // --- [ glDeleteProgram ] --- /** *

Reference Page

* * Deletes a program object. * * @param program the program object to be deleted */ public static native void glDeleteProgram(@NativeType("GLuint") int program); // --- [ glIsProgram ] --- /** *

Reference Page

* * Returns {@link GL11#GL_TRUE TRUE} if {@code program} is the name of a program object. If {@code program} is zero, or a non-zero value that is not the name of a program * object, IsProgram returns {@link GL11#GL_FALSE FALSE}. No error is generated if program is not a valid program object name. * * @param program the program object name to query */ @NativeType("GLboolean") public static native boolean glIsProgram(@NativeType("GLuint") int program); // --- [ glCreateShader ] --- /** *

Reference Page

* * Creates a shader object. * * @param type the type of shader to be created. One of:
{@link #GL_VERTEX_SHADER VERTEX_SHADER}{@link #GL_FRAGMENT_SHADER FRAGMENT_SHADER}{@link GL32#GL_GEOMETRY_SHADER GEOMETRY_SHADER}{@link GL40#GL_TESS_CONTROL_SHADER TESS_CONTROL_SHADER}
{@link GL40#GL_TESS_EVALUATION_SHADER TESS_EVALUATION_SHADER}
*/ @NativeType("GLuint") public static native int glCreateShader(@NativeType("GLenum") int type); // --- [ glDeleteShader ] --- /** *

Reference Page

* * Deletes a shader object. * * @param shader the shader object to be deleted */ public static native void glDeleteShader(@NativeType("GLuint") int shader); // --- [ glIsShader ] --- /** *

Reference Page

* * Returns {@link GL11#GL_TRUE TRUE} if {@code shader} is the name of a shader object. If {@code shader} is zero, or a nonzero value that is not the name of a shader * object, IsShader returns {@link GL11#GL_FALSE FALSE}. No error is generated if shader is not a valid shader object name. * * @param shader the shader object name to query */ @NativeType("GLboolean") public static native boolean glIsShader(@NativeType("GLuint") int shader); // --- [ glAttachShader ] --- /** *

Reference Page

* * Attaches a shader object to a program object. * *

In order to create a complete shader program, there must be a way to specify the list of things that will be linked together. Program objects provide * this mechanism. Shaders that are to be linked together in a program object must first be attached to that program object. glAttachShader attaches the * shader object specified by shader to the program object specified by program. This indicates that shader will be included in link operations that will * be performed on program.

* *

All operations that can be performed on a shader object are valid whether or not the shader object is attached to a program object. It is permissible to * attach a shader object to a program object before source code has been loaded into the shader object or before the shader object has been compiled. It * is permissible to attach multiple shader objects of the same type because each may contain a portion of the complete shader. It is also permissible to * attach a shader object to more than one program object. If a shader object is deleted while it is attached to a program object, it will be flagged for * deletion, and deletion will not occur until glDetachShader is called to detach it from all program objects to which it is attached.

* * @param program the program object to which a shader object will be attached * @param shader the shader object that is to be attached */ public static native void glAttachShader(@NativeType("GLuint") int program, @NativeType("GLuint") int shader); // --- [ glDetachShader ] --- /** *

Reference Page

* * Detaches a shader object from a program object to which it is attached. * * @param program the program object from which to detach the shader object * @param shader the shader object to be detached */ public static native void glDetachShader(@NativeType("GLuint") int program, @NativeType("GLuint") int shader); // --- [ glShaderSource ] --- /** * Unsafe version of: {@link #glShaderSource ShaderSource} * * @param count the number of elements in the string and length arrays */ public static native void nglShaderSource(int shader, int count, long strings, long length); /** *

Reference Page

* * Sets the source code in {@code shader} to the source code in the array of strings specified by {@code strings}. Any source code previously stored in the * shader object is completely replaced. The number of strings in the array is specified by {@code count}. If {@code length} is {@code NULL}, each string is * assumed to be null terminated. If {@code length} is a value other than {@code NULL}, it points to an array containing a string length for each of the * corresponding elements of {@code strings}. Each element in the length array may contain the length of the corresponding string (the null character is not * counted as part of the string length) or a value less than 0 to indicate that the string is null terminated. The source code strings are not scanned or * parsed at this time; they are simply copied into the specified shader object. * * @param shader the shader object whose source code is to be replaced * @param strings an array of pointers to strings containing the source code to be loaded into the shader * @param length an array of string lengths */ public static void glShaderSource(@NativeType("GLuint") int shader, @NativeType("const GLchar **") PointerBuffer strings, @NativeType("const GLint *") IntBuffer length) { if (CHECKS) { checkSafe(length, strings.remaining()); } nglShaderSource(shader, strings.remaining(), memAddress(strings), memAddressSafe(length)); } /** *

Reference Page

* * Sets the source code in {@code shader} to the source code in the array of strings specified by {@code strings}. Any source code previously stored in the * shader object is completely replaced. The number of strings in the array is specified by {@code count}. If {@code length} is {@code NULL}, each string is * assumed to be null terminated. If {@code length} is a value other than {@code NULL}, it points to an array containing a string length for each of the * corresponding elements of {@code strings}. Each element in the length array may contain the length of the corresponding string (the null character is not * counted as part of the string length) or a value less than 0 to indicate that the string is null terminated. The source code strings are not scanned or * parsed at this time; they are simply copied into the specified shader object. * * @param shader the shader object whose source code is to be replaced * @param strings an array of pointers to strings containing the source code to be loaded into the shader */ public static void glShaderSource(@NativeType("GLuint") int shader, @NativeType("const GLchar **") CharSequence... strings) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { long stringsAddress = org.lwjgl.system.APIUtil.apiArrayi(stack, MemoryUtil::memUTF8, strings); nglShaderSource(shader, strings.length, stringsAddress, stringsAddress - (strings.length << 2)); org.lwjgl.system.APIUtil.apiArrayFree(stringsAddress, strings.length); } finally { stack.setPointer(stackPointer); } } /** *

Reference Page

* * Sets the source code in {@code shader} to the source code in the array of strings specified by {@code strings}. Any source code previously stored in the * shader object is completely replaced. The number of strings in the array is specified by {@code count}. If {@code length} is {@code NULL}, each string is * assumed to be null terminated. If {@code length} is a value other than {@code NULL}, it points to an array containing a string length for each of the * corresponding elements of {@code strings}. Each element in the length array may contain the length of the corresponding string (the null character is not * counted as part of the string length) or a value less than 0 to indicate that the string is null terminated. The source code strings are not scanned or * parsed at this time; they are simply copied into the specified shader object. * * @param shader the shader object whose source code is to be replaced */ public static void glShaderSource(@NativeType("GLuint") int shader, @NativeType("const GLchar **") CharSequence string) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { long stringsAddress = org.lwjgl.system.APIUtil.apiArrayi(stack, MemoryUtil::memUTF8, string); nglShaderSource(shader, 1, stringsAddress, stringsAddress - 4); org.lwjgl.system.APIUtil.apiArrayFree(stringsAddress, 1); } finally { stack.setPointer(stackPointer); } } // --- [ glCompileShader ] --- /** *

Reference Page

* * Compiles a shader object. * * @param shader the shader object to be compiled */ public static native void glCompileShader(@NativeType("GLuint") int shader); // --- [ glLinkProgram ] --- /** *

Reference Page

* * Links a program object. * * @param program the program object to be linked */ public static native void glLinkProgram(@NativeType("GLuint") int program); // --- [ glUseProgram ] --- /** *

Reference Page

* * Installs a program object as part of current rendering state. * * @param program the program object whose executables are to be used as part of current rendering state */ public static native void glUseProgram(@NativeType("GLuint") int program); // --- [ glValidateProgram ] --- /** *

Reference Page

* * Validates a program object. * * @param program the program object to be validated */ public static native void glValidateProgram(@NativeType("GLuint") int program); // --- [ glUniform1f ] --- /** *

Reference Page

* * Specifies the value of a float uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform value */ public static native void glUniform1f(@NativeType("GLint") int location, @NativeType("GLfloat") float v0); // --- [ glUniform2f ] --- /** *

Reference Page

* * Specifies the value of a vec2 uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform x value * @param v1 the uniform y value */ public static native void glUniform2f(@NativeType("GLint") int location, @NativeType("GLfloat") float v0, @NativeType("GLfloat") float v1); // --- [ glUniform3f ] --- /** *

Reference Page

* * Specifies the value of a vec3 uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform x value * @param v1 the uniform y value * @param v2 the uniform z value */ public static native void glUniform3f(@NativeType("GLint") int location, @NativeType("GLfloat") float v0, @NativeType("GLfloat") float v1, @NativeType("GLfloat") float v2); // --- [ glUniform4f ] --- /** *

Reference Page

* * Specifies the value of a vec4 uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform x value * @param v1 the uniform y value * @param v2 the uniform z value * @param v3 the uniform w value */ public static native void glUniform4f(@NativeType("GLint") int location, @NativeType("GLfloat") float v0, @NativeType("GLfloat") float v1, @NativeType("GLfloat") float v2, @NativeType("GLfloat") float v3); // --- [ glUniform1i ] --- /** *

Reference Page

* * Specifies the value of an int uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform value */ public static native void glUniform1i(@NativeType("GLint") int location, @NativeType("GLint") int v0); // --- [ glUniform2i ] --- /** *

Reference Page

* * Specifies the value of an ivec2 uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform x value * @param v1 the uniform y value */ public static native void glUniform2i(@NativeType("GLint") int location, @NativeType("GLint") int v0, @NativeType("GLint") int v1); // --- [ glUniform3i ] --- /** *

Reference Page

* * Specifies the value of an ivec3 uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform x value * @param v1 the uniform y value * @param v2 the uniform z value */ public static native void glUniform3i(@NativeType("GLint") int location, @NativeType("GLint") int v0, @NativeType("GLint") int v1, @NativeType("GLint") int v2); // --- [ glUniform4i ] --- /** *

Reference Page

* * Specifies the value of an ivec4 uniform variable for the current program object. * * @param location the location of the uniform variable to be modified * @param v0 the uniform x value * @param v1 the uniform y value * @param v2 the uniform z value * @param v3 the uniform w value */ public static native void glUniform4i(@NativeType("GLint") int location, @NativeType("GLint") int v0, @NativeType("GLint") int v1, @NativeType("GLint") int v2, @NativeType("GLint") int v3); // --- [ glUniform1fv ] --- /** * Unsafe version of: {@link #glUniform1fv Uniform1fv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform1fv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single float uniform variable or a float uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform1fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") FloatBuffer value) { nglUniform1fv(location, value.remaining(), memAddress(value)); } // --- [ glUniform2fv ] --- /** * Unsafe version of: {@link #glUniform2fv Uniform2fv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform2fv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single vec2 uniform variable or a vec2 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform2fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") FloatBuffer value) { nglUniform2fv(location, value.remaining() >> 1, memAddress(value)); } // --- [ glUniform3fv ] --- /** * Unsafe version of: {@link #glUniform3fv Uniform3fv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform3fv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single vec3 uniform variable or a vec3 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform3fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") FloatBuffer value) { nglUniform3fv(location, value.remaining() / 3, memAddress(value)); } // --- [ glUniform4fv ] --- /** * Unsafe version of: {@link #glUniform4fv Uniform4fv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform4fv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single vec4 uniform variable or a vec4 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform4fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") FloatBuffer value) { nglUniform4fv(location, value.remaining() >> 2, memAddress(value)); } // --- [ glUniform1iv ] --- /** * Unsafe version of: {@link #glUniform1iv Uniform1iv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform1iv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single int uniform variable or a int uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform1iv(@NativeType("GLint") int location, @NativeType("const GLint *") IntBuffer value) { nglUniform1iv(location, value.remaining(), memAddress(value)); } // --- [ glUniform2iv ] --- /** * Unsafe version of: {@link #glUniform2iv Uniform2iv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform2iv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single ivec2 uniform variable or an ivec2 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform2iv(@NativeType("GLint") int location, @NativeType("const GLint *") IntBuffer value) { nglUniform2iv(location, value.remaining() >> 1, memAddress(value)); } // --- [ glUniform3iv ] --- /** * Unsafe version of: {@link #glUniform3iv Uniform3iv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform3iv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single ivec3 uniform variable or an ivec3 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform3iv(@NativeType("GLint") int location, @NativeType("const GLint *") IntBuffer value) { nglUniform3iv(location, value.remaining() / 3, memAddress(value)); } // --- [ glUniform4iv ] --- /** * Unsafe version of: {@link #glUniform4iv Uniform4iv} * * @param count the number of elements that are to be modified. This should be 1 if the targeted uniform variable is not an array, and 1 or more if it is an array. */ public static native void nglUniform4iv(int location, int count, long value); /** *

Reference Page

* * Specifies the value of a single ivec4 uniform variable or an ivec4 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniform4iv(@NativeType("GLint") int location, @NativeType("const GLint *") IntBuffer value) { nglUniform4iv(location, value.remaining() >> 2, memAddress(value)); } // --- [ glUniformMatrix2fv ] --- /** * Unsafe version of: {@link #glUniformMatrix2fv UniformMatrix2fv} * * @param count the number of matrices that are to be modified. This should be 1 if the targeted uniform variable is not an array of matrices, and 1 or more if it is an array of matrices. */ public static native void nglUniformMatrix2fv(int location, int count, boolean transpose, long value); /** *

Reference Page

* * Specifies the value of a single mat2 uniform variable or a mat2 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param transpose whether to transpose the matrix as the values are loaded into the uniform variable * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniformMatrix2fv(@NativeType("GLint") int location, @NativeType("GLboolean") boolean transpose, @NativeType("const GLfloat *") FloatBuffer value) { nglUniformMatrix2fv(location, value.remaining() >> 2, transpose, memAddress(value)); } // --- [ glUniformMatrix3fv ] --- /** * Unsafe version of: {@link #glUniformMatrix3fv UniformMatrix3fv} * * @param count the number of matrices that are to be modified. This should be 1 if the targeted uniform variable is not an array of matrices, and 1 or more if it is an array of matrices. */ public static native void nglUniformMatrix3fv(int location, int count, boolean transpose, long value); /** *

Reference Page

* * Specifies the value of a single mat3 uniform variable or a mat3 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param transpose whether to transpose the matrix as the values are loaded into the uniform variable * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniformMatrix3fv(@NativeType("GLint") int location, @NativeType("GLboolean") boolean transpose, @NativeType("const GLfloat *") FloatBuffer value) { nglUniformMatrix3fv(location, value.remaining() / 9, transpose, memAddress(value)); } // --- [ glUniformMatrix4fv ] --- /** * Unsafe version of: {@link #glUniformMatrix4fv UniformMatrix4fv} * * @param count the number of matrices that are to be modified. This should be 1 if the targeted uniform variable is not an array of matrices, and 1 or more if it is an array of matrices. */ public static native void nglUniformMatrix4fv(int location, int count, boolean transpose, long value); /** *

Reference Page

* * Specifies the value of a single mat4 uniform variable or a mat4 uniform variable array for the current program object. * * @param location the location of the uniform variable to be modified * @param transpose whether to transpose the matrix as the values are loaded into the uniform variable * @param value a pointer to an array of {@code count} values that will be used to update the specified uniform variable */ public static void glUniformMatrix4fv(@NativeType("GLint") int location, @NativeType("GLboolean") boolean transpose, @NativeType("const GLfloat *") FloatBuffer value) { nglUniformMatrix4fv(location, value.remaining() >> 4, transpose, memAddress(value)); } // --- [ glGetShaderiv ] --- /** Unsafe version of: {@link #glGetShaderiv GetShaderiv} */ public static native void nglGetShaderiv(int shader, int pname, long params); /** *

Reference Page

* * Returns a parameter from a shader object. * * @param shader the shader object to be queried * @param pname the object parameter. One of:
{@link #GL_SHADER_TYPE SHADER_TYPE}{@link #GL_DELETE_STATUS DELETE_STATUS}{@link #GL_COMPILE_STATUS COMPILE_STATUS}{@link #GL_INFO_LOG_LENGTH INFO_LOG_LENGTH}{@link #GL_SHADER_SOURCE_LENGTH SHADER_SOURCE_LENGTH}
* @param params the requested object parameter */ public static void glGetShaderiv(@NativeType("GLuint") int shader, @NativeType("GLenum") int pname, @NativeType("GLint *") IntBuffer params) { if (CHECKS) { check(params, 1); } nglGetShaderiv(shader, pname, memAddress(params)); } /** *

Reference Page

* * Returns a parameter from a shader object. * * @param shader the shader object to be queried * @param pname the object parameter. One of:
{@link #GL_SHADER_TYPE SHADER_TYPE}{@link #GL_DELETE_STATUS DELETE_STATUS}{@link #GL_COMPILE_STATUS COMPILE_STATUS}{@link #GL_INFO_LOG_LENGTH INFO_LOG_LENGTH}{@link #GL_SHADER_SOURCE_LENGTH SHADER_SOURCE_LENGTH}
*/ @NativeType("void") public static int glGetShaderi(@NativeType("GLuint") int shader, @NativeType("GLenum") int pname) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer params = stack.callocInt(1); nglGetShaderiv(shader, pname, memAddress(params)); return params.get(0); } finally { stack.setPointer(stackPointer); } } // --- [ glGetProgramiv ] --- /** Unsafe version of: {@link #glGetProgramiv GetProgramiv} */ public static native void nglGetProgramiv(int program, int pname, long params); /** *

Reference Page

* * Returns a parameter from a program object. * * @param program the program object to be queried * @param pname the object parameter. One of:
{@link #GL_DELETE_STATUS DELETE_STATUS}{@link #GL_LINK_STATUS LINK_STATUS}{@link #GL_VALIDATE_STATUS VALIDATE_STATUS}
{@link #GL_INFO_LOG_LENGTH INFO_LOG_LENGTH}{@link #GL_ATTACHED_SHADERS ATTACHED_SHADERS}{@link #GL_ACTIVE_ATTRIBUTES ACTIVE_ATTRIBUTES}
{@link #GL_ACTIVE_ATTRIBUTE_MAX_LENGTH ACTIVE_ATTRIBUTE_MAX_LENGTH}{@link #GL_ACTIVE_UNIFORMS ACTIVE_UNIFORMS}{@link #GL_ACTIVE_UNIFORM_MAX_LENGTH ACTIVE_UNIFORM_MAX_LENGTH}
{@link GL30#GL_TRANSFORM_FEEDBACK_BUFFER_MODE TRANSFORM_FEEDBACK_BUFFER_MODE}{@link GL30#GL_TRANSFORM_FEEDBACK_VARYINGS TRANSFORM_FEEDBACK_VARYINGS}{@link GL30#GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH}
{@link GL31#GL_ACTIVE_UNIFORM_BLOCKS ACTIVE_UNIFORM_BLOCKS}{@link GL31#GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH}{@link GL32#GL_GEOMETRY_VERTICES_OUT GEOMETRY_VERTICES_OUT}
{@link GL32#GL_GEOMETRY_INPUT_TYPE GEOMETRY_INPUT_TYPE}{@link GL32#GL_GEOMETRY_OUTPUT_TYPE GEOMETRY_OUTPUT_TYPE}{@link GL41#GL_PROGRAM_BINARY_LENGTH PROGRAM_BINARY_LENGTH}
{@link GL42#GL_ACTIVE_ATOMIC_COUNTER_BUFFERS ACTIVE_ATOMIC_COUNTER_BUFFERS}{@link GL43#GL_COMPUTE_WORK_GROUP_SIZE COMPUTE_WORK_GROUP_SIZE}
* @param params the requested object parameter */ public static void glGetProgramiv(@NativeType("GLuint") int program, @NativeType("GLenum") int pname, @NativeType("GLint *") IntBuffer params) { if (CHECKS) { check(params, 1); } nglGetProgramiv(program, pname, memAddress(params)); } /** *

Reference Page

* * Returns a parameter from a program object. * * @param program the program object to be queried * @param pname the object parameter. One of:
{@link #GL_DELETE_STATUS DELETE_STATUS}{@link #GL_LINK_STATUS LINK_STATUS}{@link #GL_VALIDATE_STATUS VALIDATE_STATUS}
{@link #GL_INFO_LOG_LENGTH INFO_LOG_LENGTH}{@link #GL_ATTACHED_SHADERS ATTACHED_SHADERS}{@link #GL_ACTIVE_ATTRIBUTES ACTIVE_ATTRIBUTES}
{@link #GL_ACTIVE_ATTRIBUTE_MAX_LENGTH ACTIVE_ATTRIBUTE_MAX_LENGTH}{@link #GL_ACTIVE_UNIFORMS ACTIVE_UNIFORMS}{@link #GL_ACTIVE_UNIFORM_MAX_LENGTH ACTIVE_UNIFORM_MAX_LENGTH}
{@link GL30#GL_TRANSFORM_FEEDBACK_BUFFER_MODE TRANSFORM_FEEDBACK_BUFFER_MODE}{@link GL30#GL_TRANSFORM_FEEDBACK_VARYINGS TRANSFORM_FEEDBACK_VARYINGS}{@link GL30#GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH}
{@link GL31#GL_ACTIVE_UNIFORM_BLOCKS ACTIVE_UNIFORM_BLOCKS}{@link GL31#GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH}{@link GL32#GL_GEOMETRY_VERTICES_OUT GEOMETRY_VERTICES_OUT}
{@link GL32#GL_GEOMETRY_INPUT_TYPE GEOMETRY_INPUT_TYPE}{@link GL32#GL_GEOMETRY_OUTPUT_TYPE GEOMETRY_OUTPUT_TYPE}{@link GL41#GL_PROGRAM_BINARY_LENGTH PROGRAM_BINARY_LENGTH}
{@link GL42#GL_ACTIVE_ATOMIC_COUNTER_BUFFERS ACTIVE_ATOMIC_COUNTER_BUFFERS}{@link GL43#GL_COMPUTE_WORK_GROUP_SIZE COMPUTE_WORK_GROUP_SIZE}
*/ @NativeType("void") public static int glGetProgrami(@NativeType("GLuint") int program, @NativeType("GLenum") int pname) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer params = stack.callocInt(1); nglGetProgramiv(program, pname, memAddress(params)); return params.get(0); } finally { stack.setPointer(stackPointer); } } // --- [ glGetShaderInfoLog ] --- /** * Unsafe version of: {@link #glGetShaderInfoLog GetShaderInfoLog} * * @param maxLength the size of the character buffer for storing the returned information log */ public static native void nglGetShaderInfoLog(int shader, int maxLength, long length, long infoLog); /** *

Reference Page

* * Returns the information log for a shader object. * * @param shader the shader object whose information log is to be queried * @param length the length of the string returned in {@code infoLog} (excluding the null terminator) * @param infoLog an array of characters that is used to return the information log */ public static void glGetShaderInfoLog(@NativeType("GLuint") int shader, @NativeType("GLsizei *") IntBuffer length, @NativeType("GLchar *") ByteBuffer infoLog) { if (CHECKS) { checkSafe(length, 1); } nglGetShaderInfoLog(shader, infoLog.remaining(), memAddressSafe(length), memAddress(infoLog)); } /** *

Reference Page

* * Returns the information log for a shader object. * * @param shader the shader object whose information log is to be queried * @param maxLength the size of the character buffer for storing the returned information log */ @NativeType("void") public static String glGetShaderInfoLog(@NativeType("GLuint") int shader, @NativeType("GLsizei") int maxLength) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); ByteBuffer infoLog = memAlloc(maxLength); try { IntBuffer length = stack.ints(0); nglGetShaderInfoLog(shader, maxLength, memAddress(length), memAddress(infoLog)); return memUTF8(infoLog, length.get(0)); } finally { memFree(infoLog); stack.setPointer(stackPointer); } } /** *

Reference Page

* * Returns the information log for a shader object. * * @param shader the shader object whose information log is to be queried */ @NativeType("void") public static String glGetShaderInfoLog(@NativeType("GLuint") int shader) { return glGetShaderInfoLog(shader, glGetShaderi(shader, GL_INFO_LOG_LENGTH)); } // --- [ glGetProgramInfoLog ] --- /** * Unsafe version of: {@link #glGetProgramInfoLog GetProgramInfoLog} * * @param maxLength the size of the character buffer for storing the returned information log */ public static native void nglGetProgramInfoLog(int program, int maxLength, long length, long infoLog); /** *

Reference Page

* * Returns the information log for a program object. * * @param program the program object whose information log is to be queried * @param length the length of the string returned in {@code infoLog} (excluding the null terminator) * @param infoLog an array of characters that is used to return the information log */ public static void glGetProgramInfoLog(@NativeType("GLuint") int program, @NativeType("GLsizei *") IntBuffer length, @NativeType("GLchar *") ByteBuffer infoLog) { if (CHECKS) { checkSafe(length, 1); } nglGetProgramInfoLog(program, infoLog.remaining(), memAddressSafe(length), memAddress(infoLog)); } /** *

Reference Page

* * Returns the information log for a program object. * * @param program the program object whose information log is to be queried * @param maxLength the size of the character buffer for storing the returned information log */ @NativeType("void") public static String glGetProgramInfoLog(@NativeType("GLuint") int program, @NativeType("GLsizei") int maxLength) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); ByteBuffer infoLog = memAlloc(maxLength); try { IntBuffer length = stack.ints(0); nglGetProgramInfoLog(program, maxLength, memAddress(length), memAddress(infoLog)); return memUTF8(infoLog, length.get(0)); } finally { memFree(infoLog); stack.setPointer(stackPointer); } } /** *

Reference Page

* * Returns the information log for a program object. * * @param program the program object whose information log is to be queried */ @NativeType("void") public static String glGetProgramInfoLog(@NativeType("GLuint") int program) { return glGetProgramInfoLog(program, glGetProgrami(program, GL_INFO_LOG_LENGTH)); } // --- [ glGetAttachedShaders ] --- /** * Unsafe version of: {@link #glGetAttachedShaders GetAttachedShaders} * * @param maxCount the size of the array for storing the returned object names */ public static native void nglGetAttachedShaders(int program, int maxCount, long count, long shaders); /** *

Reference Page

* * Returns the shader objects attached to a program object. * * @param program the program object to be queried * @param count the number of names actually returned in {@code shaders} * @param shaders an array that is used to return the names of attached shader objects */ public static void glGetAttachedShaders(@NativeType("GLuint") int program, @NativeType("GLsizei *") IntBuffer count, @NativeType("GLuint *") IntBuffer shaders) { if (CHECKS) { checkSafe(count, 1); } nglGetAttachedShaders(program, shaders.remaining(), memAddressSafe(count), memAddress(shaders)); } // --- [ glGetUniformLocation ] --- /** Unsafe version of: {@link #glGetUniformLocation GetUniformLocation} */ public static native int nglGetUniformLocation(int program, long name); /** *

Reference Page

* * Returns the location of a uniform variable. * * @param program the program object to be queried * @param name a null terminated string containing the name of the uniform variable whose location is to be queried */ @NativeType("GLint") public static int glGetUniformLocation(@NativeType("GLuint") int program, @NativeType("const GLchar *") ByteBuffer name) { if (CHECKS) { checkNT1(name); } return nglGetUniformLocation(program, memAddress(name)); } /** *

Reference Page

* * Returns the location of a uniform variable. * * @param program the program object to be queried * @param name a null terminated string containing the name of the uniform variable whose location is to be queried */ @NativeType("GLint") public static int glGetUniformLocation(@NativeType("GLuint") int program, @NativeType("const GLchar *") CharSequence name) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { ByteBuffer nameEncoded = stack.ASCII(name); return nglGetUniformLocation(program, memAddress(nameEncoded)); } finally { stack.setPointer(stackPointer); } } // --- [ glGetActiveUniform ] --- /** * Unsafe version of: {@link #glGetActiveUniform GetActiveUniform} * * @param maxLength the maximum number of characters OpenGL is allowed to write in the character buffer indicated by {@code name} */ public static native void nglGetActiveUniform(int program, int index, int maxLength, long length, long size, long type, long name); /** *

Reference Page

* * Returns information about an active uniform variable for the specified program object. * * @param program the program object to be queried * @param index the index of the uniform variable to be queried * @param length the number of characters actually written by OpenGL in the string indicated by {@code name} (excluding the null terminator) if a value other than NULL is passed * @param size the size of the uniform variable * @param type the data type of the uniform variable * @param name a null terminated string containing the name of the uniform variable */ public static void glGetActiveUniform(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLsizei *") IntBuffer length, @NativeType("GLint *") IntBuffer size, @NativeType("GLenum *") IntBuffer type, @NativeType("GLchar *") ByteBuffer name) { if (CHECKS) { checkSafe(length, 1); check(size, 1); check(type, 1); } nglGetActiveUniform(program, index, name.remaining(), memAddressSafe(length), memAddress(size), memAddress(type), memAddress(name)); } /** *

Reference Page

* * Returns information about an active uniform variable for the specified program object. * * @param program the program object to be queried * @param index the index of the uniform variable to be queried * @param maxLength the maximum number of characters OpenGL is allowed to write in the character buffer indicated by {@code name} * @param size the size of the uniform variable * @param type the data type of the uniform variable */ @NativeType("void") public static String glGetActiveUniform(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLsizei") int maxLength, @NativeType("GLint *") IntBuffer size, @NativeType("GLenum *") IntBuffer type) { if (CHECKS) { check(size, 1); check(type, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer length = stack.ints(0); ByteBuffer name = stack.malloc(maxLength); nglGetActiveUniform(program, index, maxLength, memAddress(length), memAddress(size), memAddress(type), memAddress(name)); return memASCII(name, length.get(0)); } finally { stack.setPointer(stackPointer); } } /** *

Reference Page

* * Returns information about an active uniform variable for the specified program object. * * @param program the program object to be queried * @param index the index of the uniform variable to be queried * @param size the size of the uniform variable * @param type the data type of the uniform variable */ @NativeType("void") public static String glGetActiveUniform(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLint *") IntBuffer size, @NativeType("GLenum *") IntBuffer type) { return glGetActiveUniform(program, index, glGetProgrami(program, GL_ACTIVE_UNIFORM_MAX_LENGTH), size, type); } // --- [ glGetUniformfv ] --- /** Unsafe version of: {@link #glGetUniformfv GetUniformfv} */ public static native void nglGetUniformfv(int program, int location, long params); /** *

Reference Page

* * Returns the float value(s) of a uniform variable. * * @param program the program object to be queried * @param location the location of the uniform variable to be queried * @param params the value of the specified uniform variable */ public static void glGetUniformfv(@NativeType("GLuint") int program, @NativeType("GLint") int location, @NativeType("GLfloat *") FloatBuffer params) { if (CHECKS) { check(params, 1); } nglGetUniformfv(program, location, memAddress(params)); } /** *

Reference Page

* * Returns the float value(s) of a uniform variable. * * @param program the program object to be queried * @param location the location of the uniform variable to be queried */ @NativeType("void") public static float glGetUniformf(@NativeType("GLuint") int program, @NativeType("GLint") int location) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { FloatBuffer params = stack.callocFloat(1); nglGetUniformfv(program, location, memAddress(params)); return params.get(0); } finally { stack.setPointer(stackPointer); } } // --- [ glGetUniformiv ] --- /** Unsafe version of: {@link #glGetUniformiv GetUniformiv} */ public static native void nglGetUniformiv(int program, int location, long params); /** *

Reference Page

* * Returns the int value(s) of a uniform variable. * * @param program the program object to be queried * @param location the location of the uniform variable to be queried * @param params the value of the specified uniform variable */ public static void glGetUniformiv(@NativeType("GLuint") int program, @NativeType("GLint") int location, @NativeType("GLint *") IntBuffer params) { if (CHECKS) { check(params, 1); } nglGetUniformiv(program, location, memAddress(params)); } /** *

Reference Page

* * Returns the int value(s) of a uniform variable. * * @param program the program object to be queried * @param location the location of the uniform variable to be queried */ @NativeType("void") public static int glGetUniformi(@NativeType("GLuint") int program, @NativeType("GLint") int location) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer params = stack.callocInt(1); nglGetUniformiv(program, location, memAddress(params)); return params.get(0); } finally { stack.setPointer(stackPointer); } } // --- [ glGetShaderSource ] --- /** * Unsafe version of: {@link #glGetShaderSource GetShaderSource} * * @param maxLength the size of the character buffer for storing the returned source code string */ public static native void nglGetShaderSource(int shader, int maxLength, long length, long source); /** *

Reference Page

* * Returns the source code string from a shader object. * * @param shader the shader object to be queried * @param length the length of the string returned in source (excluding the null terminator) * @param source an array of characters that is used to return the source code string */ public static void glGetShaderSource(@NativeType("GLuint") int shader, @NativeType("GLsizei *") IntBuffer length, @NativeType("GLchar *") ByteBuffer source) { if (CHECKS) { checkSafe(length, 1); } nglGetShaderSource(shader, source.remaining(), memAddressSafe(length), memAddress(source)); } /** *

Reference Page

* * Returns the source code string from a shader object. * * @param shader the shader object to be queried * @param maxLength the size of the character buffer for storing the returned source code string */ @NativeType("void") public static String glGetShaderSource(@NativeType("GLuint") int shader, @NativeType("GLsizei") int maxLength) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); ByteBuffer source = memAlloc(maxLength); try { IntBuffer length = stack.ints(0); nglGetShaderSource(shader, maxLength, memAddress(length), memAddress(source)); return memUTF8(source, length.get(0)); } finally { memFree(source); stack.setPointer(stackPointer); } } /** *

Reference Page

* * Returns the source code string from a shader object. * * @param shader the shader object to be queried */ @NativeType("void") public static String glGetShaderSource(@NativeType("GLuint") int shader) { return glGetShaderSource(shader, glGetShaderi(shader, GL_SHADER_SOURCE_LENGTH)); } // --- [ glVertexAttrib1f ] --- /** *

Reference Page

* * Specifies the value of a generic vertex attribute. The y and z components are implicitly set to 0.0f and w to 1.0f. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component */ public static native void glVertexAttrib1f(@NativeType("GLuint") int index, @NativeType("GLfloat") float v0); // --- [ glVertexAttrib1s ] --- /** *

Reference Page

* * Short version of {@link #glVertexAttrib1f VertexAttrib1f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component */ public static native void glVertexAttrib1s(@NativeType("GLuint") int index, @NativeType("GLshort") short v0); // --- [ glVertexAttrib1d ] --- /** *

Reference Page

* * Double version of {@link #glVertexAttrib1f VertexAttrib1f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component */ public static native void glVertexAttrib1d(@NativeType("GLuint") int index, @NativeType("GLdouble") double v0); // --- [ glVertexAttrib2f ] --- /** *

Reference Page

* * Specifies the value of a generic vertex attribute. The y component is implicitly set to 0.0f and w to 1.0f. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component */ public static native void glVertexAttrib2f(@NativeType("GLuint") int index, @NativeType("GLfloat") float v0, @NativeType("GLfloat") float v1); // --- [ glVertexAttrib2s ] --- /** *

Reference Page

* * Short version of {@link #glVertexAttrib2f VertexAttrib2f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component */ public static native void glVertexAttrib2s(@NativeType("GLuint") int index, @NativeType("GLshort") short v0, @NativeType("GLshort") short v1); // --- [ glVertexAttrib2d ] --- /** *

Reference Page

* * Double version of {@link #glVertexAttrib2f VertexAttrib2f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component */ public static native void glVertexAttrib2d(@NativeType("GLuint") int index, @NativeType("GLdouble") double v0, @NativeType("GLdouble") double v1); // --- [ glVertexAttrib3f ] --- /** *

Reference Page

* * Specifies the value of a generic vertex attribute. The w is implicitly set to 1.0f. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component * @param v2 the vertex attribute z component */ public static native void glVertexAttrib3f(@NativeType("GLuint") int index, @NativeType("GLfloat") float v0, @NativeType("GLfloat") float v1, @NativeType("GLfloat") float v2); // --- [ glVertexAttrib3s ] --- /** *

Reference Page

* * Short version of {@link #glVertexAttrib3f VertexAttrib3f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component * @param v2 the vertex attribute z component */ public static native void glVertexAttrib3s(@NativeType("GLuint") int index, @NativeType("GLshort") short v0, @NativeType("GLshort") short v1, @NativeType("GLshort") short v2); // --- [ glVertexAttrib3d ] --- /** *

Reference Page

* * Double version of {@link #glVertexAttrib3f VertexAttrib3f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component * @param v2 the vertex attribute z component */ public static native void glVertexAttrib3d(@NativeType("GLuint") int index, @NativeType("GLdouble") double v0, @NativeType("GLdouble") double v1, @NativeType("GLdouble") double v2); // --- [ glVertexAttrib4f ] --- /** *

Reference Page

* * Specifies the value of a generic vertex attribute. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component * @param v2 the vertex attribute z component * @param v3 the vertex attribute w component */ public static native void glVertexAttrib4f(@NativeType("GLuint") int index, @NativeType("GLfloat") float v0, @NativeType("GLfloat") float v1, @NativeType("GLfloat") float v2, @NativeType("GLfloat") float v3); // --- [ glVertexAttrib4s ] --- /** *

Reference Page

* * Short version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component * @param v2 the vertex attribute z component * @param v3 the vertex attribute w component */ public static native void glVertexAttrib4s(@NativeType("GLuint") int index, @NativeType("GLshort") short v0, @NativeType("GLshort") short v1, @NativeType("GLshort") short v2, @NativeType("GLshort") short v3); // --- [ glVertexAttrib4d ] --- /** *

Reference Page

* * Double version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v0 the vertex attribute x component * @param v1 the vertex attribute y component * @param v2 the vertex attribute z component * @param v3 the vertex attribute w component */ public static native void glVertexAttrib4d(@NativeType("GLuint") int index, @NativeType("GLdouble") double v0, @NativeType("GLdouble") double v1, @NativeType("GLdouble") double v2, @NativeType("GLdouble") double v3); // --- [ glVertexAttrib4Nub ] --- /** *

Reference Page

* * Normalized unsigned byte version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param x the vertex attribute x component * @param y the vertex attribute y component * @param z the vertex attribute z component * @param w the vertex attribute w component */ public static native void glVertexAttrib4Nub(@NativeType("GLuint") int index, @NativeType("GLubyte") byte x, @NativeType("GLubyte") byte y, @NativeType("GLubyte") byte z, @NativeType("GLubyte") byte w); // --- [ glVertexAttrib1fv ] --- /** Unsafe version of: {@link #glVertexAttrib1fv VertexAttrib1fv} */ public static native void nglVertexAttrib1fv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib1f VertexAttrib1f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib1fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") FloatBuffer v) { if (CHECKS) { check(v, 1); } nglVertexAttrib1fv(index, memAddress(v)); } // --- [ glVertexAttrib1sv ] --- /** Unsafe version of: {@link #glVertexAttrib1sv VertexAttrib1sv} */ public static native void nglVertexAttrib1sv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib1s VertexAttrib1s}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib1sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") ShortBuffer v) { if (CHECKS) { check(v, 1); } nglVertexAttrib1sv(index, memAddress(v)); } // --- [ glVertexAttrib1dv ] --- /** Unsafe version of: {@link #glVertexAttrib1dv VertexAttrib1dv} */ public static native void nglVertexAttrib1dv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib1d VertexAttrib1d}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib1dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") DoubleBuffer v) { if (CHECKS) { check(v, 1); } nglVertexAttrib1dv(index, memAddress(v)); } // --- [ glVertexAttrib2fv ] --- /** Unsafe version of: {@link #glVertexAttrib2fv VertexAttrib2fv} */ public static native void nglVertexAttrib2fv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib2f VertexAttrib2f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib2fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") FloatBuffer v) { if (CHECKS) { check(v, 2); } nglVertexAttrib2fv(index, memAddress(v)); } // --- [ glVertexAttrib2sv ] --- /** Unsafe version of: {@link #glVertexAttrib2sv VertexAttrib2sv} */ public static native void nglVertexAttrib2sv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib2s VertexAttrib2s}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib2sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") ShortBuffer v) { if (CHECKS) { check(v, 2); } nglVertexAttrib2sv(index, memAddress(v)); } // --- [ glVertexAttrib2dv ] --- /** Unsafe version of: {@link #glVertexAttrib2dv VertexAttrib2dv} */ public static native void nglVertexAttrib2dv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib2d VertexAttrib2d}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib2dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") DoubleBuffer v) { if (CHECKS) { check(v, 2); } nglVertexAttrib2dv(index, memAddress(v)); } // --- [ glVertexAttrib3fv ] --- /** Unsafe version of: {@link #glVertexAttrib3fv VertexAttrib3fv} */ public static native void nglVertexAttrib3fv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib3f VertexAttrib3f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib3fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") FloatBuffer v) { if (CHECKS) { check(v, 3); } nglVertexAttrib3fv(index, memAddress(v)); } // --- [ glVertexAttrib3sv ] --- /** Unsafe version of: {@link #glVertexAttrib3sv VertexAttrib3sv} */ public static native void nglVertexAttrib3sv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib3s VertexAttrib3s}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib3sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") ShortBuffer v) { if (CHECKS) { check(v, 3); } nglVertexAttrib3sv(index, memAddress(v)); } // --- [ glVertexAttrib3dv ] --- /** Unsafe version of: {@link #glVertexAttrib3dv VertexAttrib3dv} */ public static native void nglVertexAttrib3dv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib3d VertexAttrib3d}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib3dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") DoubleBuffer v) { if (CHECKS) { check(v, 3); } nglVertexAttrib3dv(index, memAddress(v)); } // --- [ glVertexAttrib4fv ] --- /** Unsafe version of: {@link #glVertexAttrib4fv VertexAttrib4fv} */ public static native void nglVertexAttrib4fv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") FloatBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4fv(index, memAddress(v)); } // --- [ glVertexAttrib4sv ] --- /** Unsafe version of: {@link #glVertexAttrib4sv VertexAttrib4sv} */ public static native void nglVertexAttrib4sv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib4s VertexAttrib4s}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") ShortBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4sv(index, memAddress(v)); } // --- [ glVertexAttrib4dv ] --- /** Unsafe version of: {@link #glVertexAttrib4dv VertexAttrib4dv} */ public static native void nglVertexAttrib4dv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib4d VertexAttrib4d}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") DoubleBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4dv(index, memAddress(v)); } // --- [ glVertexAttrib4iv ] --- /** Unsafe version of: {@link #glVertexAttrib4iv VertexAttrib4iv} */ public static native void nglVertexAttrib4iv(int index, long v); /** *

Reference Page

* * Integer pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4iv(@NativeType("GLuint") int index, @NativeType("const GLint *") IntBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4iv(index, memAddress(v)); } // --- [ glVertexAttrib4bv ] --- /** Unsafe version of: {@link #glVertexAttrib4bv VertexAttrib4bv} */ public static native void nglVertexAttrib4bv(int index, long v); /** *

Reference Page

* * Byte pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4bv(@NativeType("GLuint") int index, @NativeType("const GLbyte *") ByteBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4bv(index, memAddress(v)); } // --- [ glVertexAttrib4ubv ] --- /** Unsafe version of: {@link #glVertexAttrib4ubv VertexAttrib4ubv} */ public static native void nglVertexAttrib4ubv(int index, long v); /** *

Reference Page

* * Pointer version of {@link #glVertexAttrib4Nub VertexAttrib4Nub}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4ubv(@NativeType("GLuint") int index, @NativeType("const GLubyte *") ByteBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4ubv(index, memAddress(v)); } // --- [ glVertexAttrib4usv ] --- /** Unsafe version of: {@link #glVertexAttrib4usv VertexAttrib4usv} */ public static native void nglVertexAttrib4usv(int index, long v); /** *

Reference Page

* * Unsigned short pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4usv(@NativeType("GLuint") int index, @NativeType("const GLushort *") ShortBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4usv(index, memAddress(v)); } // --- [ glVertexAttrib4uiv ] --- /** Unsafe version of: {@link #glVertexAttrib4uiv VertexAttrib4uiv} */ public static native void nglVertexAttrib4uiv(int index, long v); /** *

Reference Page

* * Unsigned int pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4uiv(@NativeType("GLuint") int index, @NativeType("const GLuint *") IntBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4uiv(index, memAddress(v)); } // --- [ glVertexAttrib4Nbv ] --- /** Unsafe version of: {@link #glVertexAttrib4Nbv VertexAttrib4Nbv} */ public static native void nglVertexAttrib4Nbv(int index, long v); /** *

Reference Page

* * Normalized byte pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4Nbv(@NativeType("GLuint") int index, @NativeType("const GLbyte *") ByteBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4Nbv(index, memAddress(v)); } // --- [ glVertexAttrib4Nsv ] --- /** Unsafe version of: {@link #glVertexAttrib4Nsv VertexAttrib4Nsv} */ public static native void nglVertexAttrib4Nsv(int index, long v); /** *

Reference Page

* * Normalized short pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4Nsv(@NativeType("GLuint") int index, @NativeType("const GLshort *") ShortBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4Nsv(index, memAddress(v)); } // --- [ glVertexAttrib4Niv ] --- /** Unsafe version of: {@link #glVertexAttrib4Niv VertexAttrib4Niv} */ public static native void nglVertexAttrib4Niv(int index, long v); /** *

Reference Page

* * Normalized int pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4Niv(@NativeType("GLuint") int index, @NativeType("const GLint *") IntBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4Niv(index, memAddress(v)); } // --- [ glVertexAttrib4Nubv ] --- /** Unsafe version of: {@link #glVertexAttrib4Nubv VertexAttrib4Nubv} */ public static native void nglVertexAttrib4Nubv(int index, long v); /** *

Reference Page

* * Normalized unsigned byte pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4Nubv(@NativeType("GLuint") int index, @NativeType("const GLubyte *") ByteBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4Nubv(index, memAddress(v)); } // --- [ glVertexAttrib4Nusv ] --- /** Unsafe version of: {@link #glVertexAttrib4Nusv VertexAttrib4Nusv} */ public static native void nglVertexAttrib4Nusv(int index, long v); /** *

Reference Page

* * Normalized unsigned short pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4Nusv(@NativeType("GLuint") int index, @NativeType("const GLushort *") ShortBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4Nusv(index, memAddress(v)); } // --- [ glVertexAttrib4Nuiv ] --- /** Unsafe version of: {@link #glVertexAttrib4Nuiv VertexAttrib4Nuiv} */ public static native void nglVertexAttrib4Nuiv(int index, long v); /** *

Reference Page

* * Normalized unsigned int pointer version of {@link #glVertexAttrib4f VertexAttrib4f}. * * @param index the index of the generic vertex attribute to be modified * @param v the vertex attribute buffer */ public static void glVertexAttrib4Nuiv(@NativeType("GLuint") int index, @NativeType("const GLuint *") IntBuffer v) { if (CHECKS) { check(v, 4); } nglVertexAttrib4Nuiv(index, memAddress(v)); } // --- [ glVertexAttribPointer ] --- /** Unsafe version of: {@link #glVertexAttribPointer VertexAttribPointer} */ public static native void nglVertexAttribPointer(int index, int size, int type, boolean normalized, int stride, long pointer); /** *

Reference Page

* * Specifies the location and organization of a vertex attribute array. * * @param index the index of the generic vertex attribute to be modified * @param size the number of values per vertex that are stored in the array. The initial value is 4. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the data type of each component in the array. The initial value is GL_FLOAT. One of:
{@link GL11#GL_BYTE BYTE}{@link GL11#GL_UNSIGNED_BYTE UNSIGNED_BYTE}{@link GL11#GL_SHORT SHORT}{@link GL11#GL_UNSIGNED_SHORT UNSIGNED_SHORT}{@link GL11#GL_INT INT}{@link GL11#GL_UNSIGNED_INT UNSIGNED_INT}{@link GL30#GL_HALF_FLOAT HALF_FLOAT}{@link GL11#GL_FLOAT FLOAT}
{@link GL11#GL_DOUBLE DOUBLE}{@link GL12#GL_UNSIGNED_INT_2_10_10_10_REV UNSIGNED_INT_2_10_10_10_REV}{@link GL33#GL_INT_2_10_10_10_REV INT_2_10_10_10_REV}{@link GL41#GL_FIXED FIXED}
* @param normalized whether fixed-point data values should be normalized or converted directly as fixed-point values when they are accessed * @param stride the byte offset between consecutive generic vertex attributes. If stride is 0, the generic vertex attributes are understood to be tightly packed in * the array. The initial value is 0. * @param pointer the vertex attribute data or the offset of the first component of the first generic vertex attribute in the array in the data store of the buffer * currently bound to the {@link GL15#GL_ARRAY_BUFFER ARRAY_BUFFER} target. The initial value is 0. */ public static void glVertexAttribPointer(@NativeType("GLuint") int index, @NativeType("GLint") int size, @NativeType("GLenum") int type, @NativeType("GLboolean") boolean normalized, @NativeType("GLsizei") int stride, @NativeType("const void *") ByteBuffer pointer) { nglVertexAttribPointer(index, size, type, normalized, stride, memAddress(pointer)); } /** *

Reference Page

* * Specifies the location and organization of a vertex attribute array. * * @param index the index of the generic vertex attribute to be modified * @param size the number of values per vertex that are stored in the array. The initial value is 4. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the data type of each component in the array. The initial value is GL_FLOAT. One of:
{@link GL11#GL_BYTE BYTE}{@link GL11#GL_UNSIGNED_BYTE UNSIGNED_BYTE}{@link GL11#GL_SHORT SHORT}{@link GL11#GL_UNSIGNED_SHORT UNSIGNED_SHORT}{@link GL11#GL_INT INT}{@link GL11#GL_UNSIGNED_INT UNSIGNED_INT}{@link GL30#GL_HALF_FLOAT HALF_FLOAT}{@link GL11#GL_FLOAT FLOAT}
{@link GL11#GL_DOUBLE DOUBLE}{@link GL12#GL_UNSIGNED_INT_2_10_10_10_REV UNSIGNED_INT_2_10_10_10_REV}{@link GL33#GL_INT_2_10_10_10_REV INT_2_10_10_10_REV}{@link GL41#GL_FIXED FIXED}
* @param normalized whether fixed-point data values should be normalized or converted directly as fixed-point values when they are accessed * @param stride the byte offset between consecutive generic vertex attributes. If stride is 0, the generic vertex attributes are understood to be tightly packed in * the array. The initial value is 0. * @param pointer the vertex attribute data or the offset of the first component of the first generic vertex attribute in the array in the data store of the buffer * currently bound to the {@link GL15#GL_ARRAY_BUFFER ARRAY_BUFFER} target. The initial value is 0. */ public static void glVertexAttribPointer(@NativeType("GLuint") int index, @NativeType("GLint") int size, @NativeType("GLenum") int type, @NativeType("GLboolean") boolean normalized, @NativeType("GLsizei") int stride, @NativeType("const void *") long pointer) { nglVertexAttribPointer(index, size, type, normalized, stride, pointer); } /** *

Reference Page

* * Specifies the location and organization of a vertex attribute array. * * @param index the index of the generic vertex attribute to be modified * @param size the number of values per vertex that are stored in the array. The initial value is 4. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the data type of each component in the array. The initial value is GL_FLOAT. One of:
{@link GL11#GL_BYTE BYTE}{@link GL11#GL_UNSIGNED_BYTE UNSIGNED_BYTE}{@link GL11#GL_SHORT SHORT}{@link GL11#GL_UNSIGNED_SHORT UNSIGNED_SHORT}{@link GL11#GL_INT INT}{@link GL11#GL_UNSIGNED_INT UNSIGNED_INT}{@link GL30#GL_HALF_FLOAT HALF_FLOAT}{@link GL11#GL_FLOAT FLOAT}
{@link GL11#GL_DOUBLE DOUBLE}{@link GL12#GL_UNSIGNED_INT_2_10_10_10_REV UNSIGNED_INT_2_10_10_10_REV}{@link GL33#GL_INT_2_10_10_10_REV INT_2_10_10_10_REV}{@link GL41#GL_FIXED FIXED}
* @param normalized whether fixed-point data values should be normalized or converted directly as fixed-point values when they are accessed * @param stride the byte offset between consecutive generic vertex attributes. If stride is 0, the generic vertex attributes are understood to be tightly packed in * the array. The initial value is 0. * @param pointer the vertex attribute data or the offset of the first component of the first generic vertex attribute in the array in the data store of the buffer * currently bound to the {@link GL15#GL_ARRAY_BUFFER ARRAY_BUFFER} target. The initial value is 0. */ public static void glVertexAttribPointer(@NativeType("GLuint") int index, @NativeType("GLint") int size, @NativeType("GLenum") int type, @NativeType("GLboolean") boolean normalized, @NativeType("GLsizei") int stride, @NativeType("const void *") ShortBuffer pointer) { nglVertexAttribPointer(index, size, type, normalized, stride, memAddress(pointer)); } /** *

Reference Page

* * Specifies the location and organization of a vertex attribute array. * * @param index the index of the generic vertex attribute to be modified * @param size the number of values per vertex that are stored in the array. The initial value is 4. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the data type of each component in the array. The initial value is GL_FLOAT. One of:
{@link GL11#GL_BYTE BYTE}{@link GL11#GL_UNSIGNED_BYTE UNSIGNED_BYTE}{@link GL11#GL_SHORT SHORT}{@link GL11#GL_UNSIGNED_SHORT UNSIGNED_SHORT}{@link GL11#GL_INT INT}{@link GL11#GL_UNSIGNED_INT UNSIGNED_INT}{@link GL30#GL_HALF_FLOAT HALF_FLOAT}{@link GL11#GL_FLOAT FLOAT}
{@link GL11#GL_DOUBLE DOUBLE}{@link GL12#GL_UNSIGNED_INT_2_10_10_10_REV UNSIGNED_INT_2_10_10_10_REV}{@link GL33#GL_INT_2_10_10_10_REV INT_2_10_10_10_REV}{@link GL41#GL_FIXED FIXED}
* @param normalized whether fixed-point data values should be normalized or converted directly as fixed-point values when they are accessed * @param stride the byte offset between consecutive generic vertex attributes. If stride is 0, the generic vertex attributes are understood to be tightly packed in * the array. The initial value is 0. * @param pointer the vertex attribute data or the offset of the first component of the first generic vertex attribute in the array in the data store of the buffer * currently bound to the {@link GL15#GL_ARRAY_BUFFER ARRAY_BUFFER} target. The initial value is 0. */ public static void glVertexAttribPointer(@NativeType("GLuint") int index, @NativeType("GLint") int size, @NativeType("GLenum") int type, @NativeType("GLboolean") boolean normalized, @NativeType("GLsizei") int stride, @NativeType("const void *") IntBuffer pointer) { nglVertexAttribPointer(index, size, type, normalized, stride, memAddress(pointer)); } /** *

Reference Page

* * Specifies the location and organization of a vertex attribute array. * * @param index the index of the generic vertex attribute to be modified * @param size the number of values per vertex that are stored in the array. The initial value is 4. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the data type of each component in the array. The initial value is GL_FLOAT. One of:
{@link GL11#GL_BYTE BYTE}{@link GL11#GL_UNSIGNED_BYTE UNSIGNED_BYTE}{@link GL11#GL_SHORT SHORT}{@link GL11#GL_UNSIGNED_SHORT UNSIGNED_SHORT}{@link GL11#GL_INT INT}{@link GL11#GL_UNSIGNED_INT UNSIGNED_INT}{@link GL30#GL_HALF_FLOAT HALF_FLOAT}{@link GL11#GL_FLOAT FLOAT}
{@link GL11#GL_DOUBLE DOUBLE}{@link GL12#GL_UNSIGNED_INT_2_10_10_10_REV UNSIGNED_INT_2_10_10_10_REV}{@link GL33#GL_INT_2_10_10_10_REV INT_2_10_10_10_REV}{@link GL41#GL_FIXED FIXED}
* @param normalized whether fixed-point data values should be normalized or converted directly as fixed-point values when they are accessed * @param stride the byte offset between consecutive generic vertex attributes. If stride is 0, the generic vertex attributes are understood to be tightly packed in * the array. The initial value is 0. * @param pointer the vertex attribute data or the offset of the first component of the first generic vertex attribute in the array in the data store of the buffer * currently bound to the {@link GL15#GL_ARRAY_BUFFER ARRAY_BUFFER} target. The initial value is 0. */ public static void glVertexAttribPointer(@NativeType("GLuint") int index, @NativeType("GLint") int size, @NativeType("GLenum") int type, @NativeType("GLboolean") boolean normalized, @NativeType("GLsizei") int stride, @NativeType("const void *") FloatBuffer pointer) { nglVertexAttribPointer(index, size, type, normalized, stride, memAddress(pointer)); } // --- [ glEnableVertexAttribArray ] --- /** *

Reference Page

* * Enables a generic vertex attribute array. * * @param index the index of the generic vertex attribute to be enabled */ public static native void glEnableVertexAttribArray(@NativeType("GLuint") int index); // --- [ glDisableVertexAttribArray ] --- /** *

Reference Page

* * Disables a generic vertex attribute array. * * @param index the index of the generic vertex attribute to be disabled */ public static native void glDisableVertexAttribArray(@NativeType("GLuint") int index); // --- [ glBindAttribLocation ] --- /** Unsafe version of: {@link #glBindAttribLocation BindAttribLocation} */ public static native void nglBindAttribLocation(int program, int index, long name); /** *

Reference Page

* * Associates a generic vertex attribute index with a named attribute variable. * * @param program the program object in which the association is to be made * @param index the index of the generic vertex attribute to be bound * @param name a null terminated string containing the name of the vertex shader attribute variable to which {@code index} is to be bound */ public static void glBindAttribLocation(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("const GLchar *") ByteBuffer name) { if (CHECKS) { checkNT1(name); } nglBindAttribLocation(program, index, memAddress(name)); } /** *

Reference Page

* * Associates a generic vertex attribute index with a named attribute variable. * * @param program the program object in which the association is to be made * @param index the index of the generic vertex attribute to be bound * @param name a null terminated string containing the name of the vertex shader attribute variable to which {@code index} is to be bound */ public static void glBindAttribLocation(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("const GLchar *") CharSequence name) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { ByteBuffer nameEncoded = stack.ASCII(name); nglBindAttribLocation(program, index, memAddress(nameEncoded)); } finally { stack.setPointer(stackPointer); } } // --- [ glGetActiveAttrib ] --- /** * Unsafe version of: {@link #glGetActiveAttrib GetActiveAttrib} * * @param maxLength the maximum number of characters OpenGL is allowed to write in the character buffer indicated by {@code name} */ public static native void nglGetActiveAttrib(int program, int index, int maxLength, long length, long size, long type, long name); /** *

Reference Page

* * Returns information about an active attribute variable for the specified program object. * * @param program the program object to be queried * @param index the index of the attribute variable to be queried * @param length the number of characters actually written by OpenGL in the string indicated by {@code name} (excluding the null terminator) if a value other than * {@code NULL} is passed * @param size the size of the attribute variable * @param type the data type of the attribute variable * @param name a null terminated string containing the name of the attribute variable */ public static void glGetActiveAttrib(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLsizei *") IntBuffer length, @NativeType("GLint *") IntBuffer size, @NativeType("GLenum *") IntBuffer type, @NativeType("GLchar *") ByteBuffer name) { if (CHECKS) { checkSafe(length, 1); check(size, 1); check(type, 1); } nglGetActiveAttrib(program, index, name.remaining(), memAddressSafe(length), memAddress(size), memAddress(type), memAddress(name)); } /** *

Reference Page

* * Returns information about an active attribute variable for the specified program object. * * @param program the program object to be queried * @param index the index of the attribute variable to be queried * @param maxLength the maximum number of characters OpenGL is allowed to write in the character buffer indicated by {@code name} * @param size the size of the attribute variable * @param type the data type of the attribute variable */ @NativeType("void") public static String glGetActiveAttrib(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLsizei") int maxLength, @NativeType("GLint *") IntBuffer size, @NativeType("GLenum *") IntBuffer type) { if (CHECKS) { check(size, 1); check(type, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer length = stack.ints(0); ByteBuffer name = stack.malloc(maxLength); nglGetActiveAttrib(program, index, maxLength, memAddress(length), memAddress(size), memAddress(type), memAddress(name)); return memASCII(name, length.get(0)); } finally { stack.setPointer(stackPointer); } } /** *

Reference Page

* * Returns information about an active attribute variable for the specified program object. * * @param program the program object to be queried * @param index the index of the attribute variable to be queried * @param size the size of the attribute variable * @param type the data type of the attribute variable */ @NativeType("void") public static String glGetActiveAttrib(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLint *") IntBuffer size, @NativeType("GLenum *") IntBuffer type) { return glGetActiveAttrib(program, index, glGetProgrami(program, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH), size, type); } // --- [ glGetAttribLocation ] --- /** Unsafe version of: {@link #glGetAttribLocation GetAttribLocation} */ public static native int nglGetAttribLocation(int program, long name); /** *

Reference Page

* * Returns the location of an attribute variable. * * @param program the program object to be queried * @param name a null terminated string containing the name of the attribute variable whose location is to be queried */ @NativeType("GLint") public static int glGetAttribLocation(@NativeType("GLuint") int program, @NativeType("const GLchar *") ByteBuffer name) { if (CHECKS) { checkNT1(name); } return nglGetAttribLocation(program, memAddress(name)); } /** *

Reference Page

* * Returns the location of an attribute variable. * * @param program the program object to be queried * @param name a null terminated string containing the name of the attribute variable whose location is to be queried */ @NativeType("GLint") public static int glGetAttribLocation(@NativeType("GLuint") int program, @NativeType("const GLchar *") CharSequence name) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { ByteBuffer nameEncoded = stack.ASCII(name); return nglGetAttribLocation(program, memAddress(nameEncoded)); } finally { stack.setPointer(stackPointer); } } // --- [ glGetVertexAttribiv ] --- /** Unsafe version of: {@link #glGetVertexAttribiv GetVertexAttribiv} */ public static native void nglGetVertexAttribiv(int index, int pname, long params); /** *

Reference Page

* * Returns the integer value of a generic vertex attribute parameter. * * @param index the generic vertex attribute parameter to be queried * @param pname the symbolic name of the vertex attribute parameter to be queried. One of:
{@link GL15#GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING VERTEX_ATTRIB_ARRAY_BUFFER_BINDING}{@link #GL_VERTEX_ATTRIB_ARRAY_ENABLED VERTEX_ATTRIB_ARRAY_ENABLED}
{@link #GL_VERTEX_ATTRIB_ARRAY_SIZE VERTEX_ATTRIB_ARRAY_SIZE}{@link #GL_VERTEX_ATTRIB_ARRAY_STRIDE VERTEX_ATTRIB_ARRAY_STRIDE}
{@link #GL_VERTEX_ATTRIB_ARRAY_TYPE VERTEX_ATTRIB_ARRAY_TYPE}{@link #GL_VERTEX_ATTRIB_ARRAY_NORMALIZED VERTEX_ATTRIB_ARRAY_NORMALIZED}
{@link #GL_CURRENT_VERTEX_ATTRIB CURRENT_VERTEX_ATTRIB}{@link GL30#GL_VERTEX_ATTRIB_ARRAY_INTEGER VERTEX_ATTRIB_ARRAY_INTEGER}
{@link GL33#GL_VERTEX_ATTRIB_ARRAY_DIVISOR VERTEX_ATTRIB_ARRAY_DIVISOR}
* @param params returns the requested data */ public static void glGetVertexAttribiv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLint *") IntBuffer params) { if (CHECKS) { check(params, 1); } nglGetVertexAttribiv(index, pname, memAddress(params)); } /** *

Reference Page

* * Returns the integer value of a generic vertex attribute parameter. * * @param index the generic vertex attribute parameter to be queried * @param pname the symbolic name of the vertex attribute parameter to be queried. One of:
{@link GL15#GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING VERTEX_ATTRIB_ARRAY_BUFFER_BINDING}{@link #GL_VERTEX_ATTRIB_ARRAY_ENABLED VERTEX_ATTRIB_ARRAY_ENABLED}
{@link #GL_VERTEX_ATTRIB_ARRAY_SIZE VERTEX_ATTRIB_ARRAY_SIZE}{@link #GL_VERTEX_ATTRIB_ARRAY_STRIDE VERTEX_ATTRIB_ARRAY_STRIDE}
{@link #GL_VERTEX_ATTRIB_ARRAY_TYPE VERTEX_ATTRIB_ARRAY_TYPE}{@link #GL_VERTEX_ATTRIB_ARRAY_NORMALIZED VERTEX_ATTRIB_ARRAY_NORMALIZED}
{@link #GL_CURRENT_VERTEX_ATTRIB CURRENT_VERTEX_ATTRIB}{@link GL30#GL_VERTEX_ATTRIB_ARRAY_INTEGER VERTEX_ATTRIB_ARRAY_INTEGER}
{@link GL33#GL_VERTEX_ATTRIB_ARRAY_DIVISOR VERTEX_ATTRIB_ARRAY_DIVISOR}
*/ @NativeType("void") public static int glGetVertexAttribi(@NativeType("GLuint") int index, @NativeType("GLenum") int pname) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer params = stack.callocInt(1); nglGetVertexAttribiv(index, pname, memAddress(params)); return params.get(0); } finally { stack.setPointer(stackPointer); } } // --- [ glGetVertexAttribfv ] --- /** Unsafe version of: {@link #glGetVertexAttribfv GetVertexAttribfv} */ public static native void nglGetVertexAttribfv(int index, int pname, long params); /** *

Reference Page

* * Float version of {@link #glGetVertexAttribiv GetVertexAttribiv}. * * @param index the generic vertex attribute parameter to be queried * @param pname the symbolic name of the vertex attribute parameter to be queried * @param params returns the requested data */ public static void glGetVertexAttribfv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLfloat *") FloatBuffer params) { if (CHECKS) { check(params, 4); } nglGetVertexAttribfv(index, pname, memAddress(params)); } // --- [ glGetVertexAttribdv ] --- /** Unsafe version of: {@link #glGetVertexAttribdv GetVertexAttribdv} */ public static native void nglGetVertexAttribdv(int index, int pname, long params); /** *

Reference Page

* * Double version of {@link #glGetVertexAttribiv GetVertexAttribiv}. * * @param index the generic vertex attribute parameter to be queried * @param pname the symbolic name of the vertex attribute parameter to be queried * @param params returns the requested data */ public static void glGetVertexAttribdv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLdouble *") DoubleBuffer params) { if (CHECKS) { check(params, 4); } nglGetVertexAttribdv(index, pname, memAddress(params)); } // --- [ glGetVertexAttribPointerv ] --- /** Unsafe version of: {@link #glGetVertexAttribPointerv GetVertexAttribPointerv} */ public static native void nglGetVertexAttribPointerv(int index, int pname, long pointer); /** *

Reference Page

* * Returns the address of the specified generic vertex attribute pointer. * * @param index the generic vertex attribute parameter to be queried * @param pname the symbolic name of the generic vertex attribute parameter to be returned. Must be:
{@link #GL_VERTEX_ATTRIB_ARRAY_POINTER VERTEX_ATTRIB_ARRAY_POINTER}
* @param pointer the pointer value */ public static void glGetVertexAttribPointerv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("void **") PointerBuffer pointer) { if (CHECKS) { check(pointer, 1); } nglGetVertexAttribPointerv(index, pname, memAddress(pointer)); } /** *

Reference Page

* * Returns the address of the specified generic vertex attribute pointer. * * @param index the generic vertex attribute parameter to be queried * @param pname the symbolic name of the generic vertex attribute parameter to be returned. Must be:
{@link #GL_VERTEX_ATTRIB_ARRAY_POINTER VERTEX_ATTRIB_ARRAY_POINTER}
*/ @NativeType("void") public static long glGetVertexAttribPointer(@NativeType("GLuint") int index, @NativeType("GLenum") int pname) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { PointerBuffer pointer = stack.callocPointer(1); nglGetVertexAttribPointerv(index, pname, memAddress(pointer)); return pointer.get(0); } finally { stack.setPointer(stackPointer); } } // --- [ glDrawBuffers ] --- /** * Unsafe version of: {@link #glDrawBuffers DrawBuffers} * * @param n the number of buffers in {@code bufs} */ public static native void nglDrawBuffers(int n, long bufs); /** *

Reference Page

* * Specifies a list of color buffers to be drawn into. * * @param bufs an array of symbolic constants specifying the buffers into which fragment colors or data values will be written. One of:
{@link GL11#GL_NONE NONE}{@link GL11#GL_FRONT_LEFT FRONT_LEFT}{@link GL11#GL_FRONT_RIGHT FRONT_RIGHT}{@link GL11#GL_BACK_LEFT BACK_LEFT}{@link GL11#GL_BACK_RIGHT BACK_RIGHT}{@link GL11#GL_AUX0 AUX0}{@link GL11#GL_AUX1 AUX1}{@link GL11#GL_AUX2 AUX2}
{@link GL11#GL_AUX3 AUX3}{@link GL30#GL_COLOR_ATTACHMENT0 COLOR_ATTACHMENT0}GL30.GL_COLOR_ATTACHMENT[1-15]
*/ public static void glDrawBuffers(@NativeType("const GLenum *") IntBuffer bufs) { nglDrawBuffers(bufs.remaining(), memAddress(bufs)); } /** *

Reference Page

* * Specifies a list of color buffers to be drawn into. */ public static void glDrawBuffers(@NativeType("const GLenum *") int buf) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { IntBuffer bufs = stack.ints(buf); nglDrawBuffers(1, memAddress(bufs)); } finally { stack.setPointer(stackPointer); } } // --- [ glBlendEquationSeparate ] --- /** *

Reference Page

* * Sets the RGB blend equation and the alpha blend equation separately. * * @param modeRGB the RGB blend equation, how the red, green, and blue components of the source and destination colors are combined. One of:
{@link GL14#GL_FUNC_ADD FUNC_ADD}{@link GL14#GL_FUNC_SUBTRACT FUNC_SUBTRACT}{@link GL14#GL_FUNC_REVERSE_SUBTRACT FUNC_REVERSE_SUBTRACT}{@link GL14#GL_MIN MIN}{@link GL14#GL_MAX MAX}
* @param modeAlpha the alpha blend equation, how the alpha component of the source and destination colors are combined */ public static native void glBlendEquationSeparate(@NativeType("GLenum") int modeRGB, @NativeType("GLenum") int modeAlpha); // --- [ glStencilOpSeparate ] --- /** *

Reference Page

* * Sets front and/or back stencil test actions. * * @param face whether front and/or back stencil state is updated. One of:
{@link GL11#GL_FRONT FRONT}{@link GL11#GL_BACK BACK}{@link GL11#GL_FRONT_AND_BACK FRONT_AND_BACK}
* @param sfail the action to take when the stencil test fails. The initial value is GL_KEEP. One of:
{@link GL11#GL_KEEP KEEP}{@link GL11#GL_ZERO ZERO}{@link GL11#GL_REPLACE REPLACE}{@link GL11#GL_INCR INCR}{@link GL14#GL_INCR_WRAP INCR_WRAP}{@link GL11#GL_DECR DECR}{@link GL14#GL_DECR_WRAP DECR_WRAP}{@link GL11#GL_INVERT INVERT}
* @param dpfail the stencil action when the stencil test passes, but the depth test fails. The initial value is GL_KEEP * @param dppass the stencil action when both the stencil test and the depth test pass, or when the stencil test passes and either there is no depth buffer or depth * testing is not enabled. The initial value is GL_KEEP */ public static native void glStencilOpSeparate(@NativeType("GLenum") int face, @NativeType("GLenum") int sfail, @NativeType("GLenum") int dpfail, @NativeType("GLenum") int dppass); // --- [ glStencilFuncSeparate ] --- /** *

Reference Page

* * Sets front and/or back function and reference value for stencil testing. * * @param face whether front and/or back stencil state is updated. One of:
{@link GL11#GL_FRONT FRONT}{@link GL11#GL_BACK BACK}{@link GL11#GL_FRONT_AND_BACK FRONT_AND_BACK}
* @param func the test function. The initial value is GL_ALWAYS. One of:
{@link GL11#GL_NEVER NEVER}{@link GL11#GL_LESS LESS}{@link GL11#GL_LEQUAL LEQUAL}{@link GL11#GL_GREATER GREATER}{@link GL11#GL_GEQUAL GEQUAL}{@link GL11#GL_EQUAL EQUAL}{@link GL11#GL_NOTEQUAL NOTEQUAL}{@link GL11#GL_ALWAYS ALWAYS}
* @param ref the reference value for the stencil test. {@code ref} is clamped to the range [0, 2n – 1], where {@code n} is the number of bitplanes in the stencil * buffer. The initial value is 0. * @param mask a mask that is ANDed with both the reference value and the stored stencil value when the test is done. The initial value is all 1's. */ public static native void glStencilFuncSeparate(@NativeType("GLenum") int face, @NativeType("GLenum") int func, @NativeType("GLint") int ref, @NativeType("GLuint") int mask); // --- [ glStencilMaskSeparate ] --- /** *

Reference Page

* * Controls the front and/or back writing of individual bits in the stencil planes. * * @param face whether front and/or back stencil writemask is updated. One of:
{@link GL11#GL_FRONT FRONT}{@link GL11#GL_BACK BACK}{@link GL11#GL_FRONT_AND_BACK FRONT_AND_BACK}
* @param mask a bit mask to enable and disable writing of individual bits in the stencil planes. Initially, the mask is all 1's. */ public static native void glStencilMaskSeparate(@NativeType("GLenum") int face, @NativeType("GLuint") int mask); /** *

Reference Page

* * Array version of: {@link #glShaderSource ShaderSource} */ public static void glShaderSource(@NativeType("GLuint") int shader, @NativeType("const GLchar **") PointerBuffer strings, @NativeType("const GLint *") int[] length) { long __functionAddress = GL.getICD().glShaderSource; if (CHECKS) { check(__functionAddress); checkSafe(length, strings.remaining()); } callPPV(__functionAddress, shader, strings.remaining(), memAddress(strings), length); } /** *

Reference Page

* * Array version of: {@link #glUniform1fv Uniform1fv} */ public static void glUniform1fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniform1fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length, value); } /** *

Reference Page

* * Array version of: {@link #glUniform2fv Uniform2fv} */ public static void glUniform2fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniform2fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length >> 1, value); } /** *

Reference Page

* * Array version of: {@link #glUniform3fv Uniform3fv} */ public static void glUniform3fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniform3fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length / 3, value); } /** *

Reference Page

* * Array version of: {@link #glUniform4fv Uniform4fv} */ public static void glUniform4fv(@NativeType("GLint") int location, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniform4fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length >> 2, value); } /** *

Reference Page

* * Array version of: {@link #glUniform1iv Uniform1iv} */ public static void glUniform1iv(@NativeType("GLint") int location, @NativeType("const GLint *") int[] value) { long __functionAddress = GL.getICD().glUniform1iv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length, value); } /** *

Reference Page

* * Array version of: {@link #glUniform2iv Uniform2iv} */ public static void glUniform2iv(@NativeType("GLint") int location, @NativeType("const GLint *") int[] value) { long __functionAddress = GL.getICD().glUniform2iv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length >> 1, value); } /** *

Reference Page

* * Array version of: {@link #glUniform3iv Uniform3iv} */ public static void glUniform3iv(@NativeType("GLint") int location, @NativeType("const GLint *") int[] value) { long __functionAddress = GL.getICD().glUniform3iv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length / 3, value); } /** *

Reference Page

* * Array version of: {@link #glUniform4iv Uniform4iv} */ public static void glUniform4iv(@NativeType("GLint") int location, @NativeType("const GLint *") int[] value) { long __functionAddress = GL.getICD().glUniform4iv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length >> 2, value); } /** *

Reference Page

* * Array version of: {@link #glUniformMatrix2fv UniformMatrix2fv} */ public static void glUniformMatrix2fv(@NativeType("GLint") int location, @NativeType("GLboolean") boolean transpose, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniformMatrix2fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length >> 2, transpose, value); } /** *

Reference Page

* * Array version of: {@link #glUniformMatrix3fv UniformMatrix3fv} */ public static void glUniformMatrix3fv(@NativeType("GLint") int location, @NativeType("GLboolean") boolean transpose, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniformMatrix3fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length / 9, transpose, value); } /** *

Reference Page

* * Array version of: {@link #glUniformMatrix4fv UniformMatrix4fv} */ public static void glUniformMatrix4fv(@NativeType("GLint") int location, @NativeType("GLboolean") boolean transpose, @NativeType("const GLfloat *") float[] value) { long __functionAddress = GL.getICD().glUniformMatrix4fv; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, location, value.length >> 4, transpose, value); } /** *

Reference Page

* * Array version of: {@link #glGetShaderiv GetShaderiv} */ public static void glGetShaderiv(@NativeType("GLuint") int shader, @NativeType("GLenum") int pname, @NativeType("GLint *") int[] params) { long __functionAddress = GL.getICD().glGetShaderiv; if (CHECKS) { check(__functionAddress); check(params, 1); } callPV(__functionAddress, shader, pname, params); } /** *

Reference Page

* * Array version of: {@link #glGetProgramiv GetProgramiv} */ public static void glGetProgramiv(@NativeType("GLuint") int program, @NativeType("GLenum") int pname, @NativeType("GLint *") int[] params) { long __functionAddress = GL.getICD().glGetProgramiv; if (CHECKS) { check(__functionAddress); check(params, 1); } callPV(__functionAddress, program, pname, params); } /** *

Reference Page

* * Array version of: {@link #glGetShaderInfoLog GetShaderInfoLog} */ public static void glGetShaderInfoLog(@NativeType("GLuint") int shader, @NativeType("GLsizei *") int[] length, @NativeType("GLchar *") ByteBuffer infoLog) { long __functionAddress = GL.getICD().glGetShaderInfoLog; if (CHECKS) { check(__functionAddress); checkSafe(length, 1); } callPPV(__functionAddress, shader, infoLog.remaining(), length, memAddress(infoLog)); } /** *

Reference Page

* * Array version of: {@link #glGetProgramInfoLog GetProgramInfoLog} */ public static void glGetProgramInfoLog(@NativeType("GLuint") int program, @NativeType("GLsizei *") int[] length, @NativeType("GLchar *") ByteBuffer infoLog) { long __functionAddress = GL.getICD().glGetProgramInfoLog; if (CHECKS) { check(__functionAddress); checkSafe(length, 1); } callPPV(__functionAddress, program, infoLog.remaining(), length, memAddress(infoLog)); } /** *

Reference Page

* * Array version of: {@link #glGetAttachedShaders GetAttachedShaders} */ public static void glGetAttachedShaders(@NativeType("GLuint") int program, @NativeType("GLsizei *") int[] count, @NativeType("GLuint *") int[] shaders) { long __functionAddress = GL.getICD().glGetAttachedShaders; if (CHECKS) { check(__functionAddress); checkSafe(count, 1); } callPPV(__functionAddress, program, shaders.length, count, shaders); } /** *

Reference Page

* * Array version of: {@link #glGetActiveUniform GetActiveUniform} */ public static void glGetActiveUniform(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLsizei *") int[] length, @NativeType("GLint *") int[] size, @NativeType("GLenum *") int[] type, @NativeType("GLchar *") ByteBuffer name) { long __functionAddress = GL.getICD().glGetActiveUniform; if (CHECKS) { check(__functionAddress); checkSafe(length, 1); check(size, 1); check(type, 1); } callPPPPV(__functionAddress, program, index, name.remaining(), length, size, type, memAddress(name)); } /** *

Reference Page

* * Array version of: {@link #glGetUniformfv GetUniformfv} */ public static void glGetUniformfv(@NativeType("GLuint") int program, @NativeType("GLint") int location, @NativeType("GLfloat *") float[] params) { long __functionAddress = GL.getICD().glGetUniformfv; if (CHECKS) { check(__functionAddress); check(params, 1); } callPV(__functionAddress, program, location, params); } /** *

Reference Page

* * Array version of: {@link #glGetUniformiv GetUniformiv} */ public static void glGetUniformiv(@NativeType("GLuint") int program, @NativeType("GLint") int location, @NativeType("GLint *") int[] params) { long __functionAddress = GL.getICD().glGetUniformiv; if (CHECKS) { check(__functionAddress); check(params, 1); } callPV(__functionAddress, program, location, params); } /** *

Reference Page

* * Array version of: {@link #glGetShaderSource GetShaderSource} */ public static void glGetShaderSource(@NativeType("GLuint") int shader, @NativeType("GLsizei *") int[] length, @NativeType("GLchar *") ByteBuffer source) { long __functionAddress = GL.getICD().glGetShaderSource; if (CHECKS) { check(__functionAddress); checkSafe(length, 1); } callPPV(__functionAddress, shader, source.remaining(), length, memAddress(source)); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib1fv VertexAttrib1fv} */ public static void glVertexAttrib1fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") float[] v) { long __functionAddress = GL.getICD().glVertexAttrib1fv; if (CHECKS) { check(__functionAddress); check(v, 1); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib1sv VertexAttrib1sv} */ public static void glVertexAttrib1sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib1sv; if (CHECKS) { check(__functionAddress); check(v, 1); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib1dv VertexAttrib1dv} */ public static void glVertexAttrib1dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") double[] v) { long __functionAddress = GL.getICD().glVertexAttrib1dv; if (CHECKS) { check(__functionAddress); check(v, 1); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib2fv VertexAttrib2fv} */ public static void glVertexAttrib2fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") float[] v) { long __functionAddress = GL.getICD().glVertexAttrib2fv; if (CHECKS) { check(__functionAddress); check(v, 2); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib2sv VertexAttrib2sv} */ public static void glVertexAttrib2sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib2sv; if (CHECKS) { check(__functionAddress); check(v, 2); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib2dv VertexAttrib2dv} */ public static void glVertexAttrib2dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") double[] v) { long __functionAddress = GL.getICD().glVertexAttrib2dv; if (CHECKS) { check(__functionAddress); check(v, 2); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib3fv VertexAttrib3fv} */ public static void glVertexAttrib3fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") float[] v) { long __functionAddress = GL.getICD().glVertexAttrib3fv; if (CHECKS) { check(__functionAddress); check(v, 3); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib3sv VertexAttrib3sv} */ public static void glVertexAttrib3sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib3sv; if (CHECKS) { check(__functionAddress); check(v, 3); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib3dv VertexAttrib3dv} */ public static void glVertexAttrib3dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") double[] v) { long __functionAddress = GL.getICD().glVertexAttrib3dv; if (CHECKS) { check(__functionAddress); check(v, 3); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4fv VertexAttrib4fv} */ public static void glVertexAttrib4fv(@NativeType("GLuint") int index, @NativeType("const GLfloat *") float[] v) { long __functionAddress = GL.getICD().glVertexAttrib4fv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4sv VertexAttrib4sv} */ public static void glVertexAttrib4sv(@NativeType("GLuint") int index, @NativeType("const GLshort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib4sv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4dv VertexAttrib4dv} */ public static void glVertexAttrib4dv(@NativeType("GLuint") int index, @NativeType("const GLdouble *") double[] v) { long __functionAddress = GL.getICD().glVertexAttrib4dv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4iv VertexAttrib4iv} */ public static void glVertexAttrib4iv(@NativeType("GLuint") int index, @NativeType("const GLint *") int[] v) { long __functionAddress = GL.getICD().glVertexAttrib4iv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4usv VertexAttrib4usv} */ public static void glVertexAttrib4usv(@NativeType("GLuint") int index, @NativeType("const GLushort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib4usv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4uiv VertexAttrib4uiv} */ public static void glVertexAttrib4uiv(@NativeType("GLuint") int index, @NativeType("const GLuint *") int[] v) { long __functionAddress = GL.getICD().glVertexAttrib4uiv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4Nsv VertexAttrib4Nsv} */ public static void glVertexAttrib4Nsv(@NativeType("GLuint") int index, @NativeType("const GLshort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib4Nsv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4Niv VertexAttrib4Niv} */ public static void glVertexAttrib4Niv(@NativeType("GLuint") int index, @NativeType("const GLint *") int[] v) { long __functionAddress = GL.getICD().glVertexAttrib4Niv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4Nusv VertexAttrib4Nusv} */ public static void glVertexAttrib4Nusv(@NativeType("GLuint") int index, @NativeType("const GLushort *") short[] v) { long __functionAddress = GL.getICD().glVertexAttrib4Nusv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glVertexAttrib4Nuiv VertexAttrib4Nuiv} */ public static void glVertexAttrib4Nuiv(@NativeType("GLuint") int index, @NativeType("const GLuint *") int[] v) { long __functionAddress = GL.getICD().glVertexAttrib4Nuiv; if (CHECKS) { check(__functionAddress); check(v, 4); } callPV(__functionAddress, index, v); } /** *

Reference Page

* * Array version of: {@link #glGetActiveAttrib GetActiveAttrib} */ public static void glGetActiveAttrib(@NativeType("GLuint") int program, @NativeType("GLuint") int index, @NativeType("GLsizei *") int[] length, @NativeType("GLint *") int[] size, @NativeType("GLenum *") int[] type, @NativeType("GLchar *") ByteBuffer name) { long __functionAddress = GL.getICD().glGetActiveAttrib; if (CHECKS) { check(__functionAddress); checkSafe(length, 1); check(size, 1); check(type, 1); } callPPPPV(__functionAddress, program, index, name.remaining(), length, size, type, memAddress(name)); } /** *

Reference Page

* * Array version of: {@link #glGetVertexAttribiv GetVertexAttribiv} */ public static void glGetVertexAttribiv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLint *") int[] params) { long __functionAddress = GL.getICD().glGetVertexAttribiv; if (CHECKS) { check(__functionAddress); check(params, 1); } callPV(__functionAddress, index, pname, params); } /** *

Reference Page

* * Array version of: {@link #glGetVertexAttribfv GetVertexAttribfv} */ public static void glGetVertexAttribfv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLfloat *") float[] params) { long __functionAddress = GL.getICD().glGetVertexAttribfv; if (CHECKS) { check(__functionAddress); check(params, 4); } callPV(__functionAddress, index, pname, params); } /** *

Reference Page

* * Array version of: {@link #glGetVertexAttribdv GetVertexAttribdv} */ public static void glGetVertexAttribdv(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLdouble *") double[] params) { long __functionAddress = GL.getICD().glGetVertexAttribdv; if (CHECKS) { check(__functionAddress); check(params, 4); } callPV(__functionAddress, index, pname, params); } /** *

Reference Page

* * Array version of: {@link #glDrawBuffers DrawBuffers} */ public static void glDrawBuffers(@NativeType("const GLenum *") int[] bufs) { long __functionAddress = GL.getICD().glDrawBuffers; if (CHECKS) { check(__functionAddress); } callPV(__functionAddress, bufs.length, bufs); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy