use super::*;
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
load_all_functions(&mut load_fn)
}
unsafe fn load_all_functions(
load_fn: &mut dyn FnMut(*const c_char) -> *const c_void,
) {
ActiveTexture::load_with(&mut *load_fn);
AttachShader::load_with(&mut *load_fn);
BeginQuery::load_with(&mut *load_fn);
BeginTransformFeedback::load_with(&mut *load_fn);
BindAttribLocation::load_with(&mut *load_fn);
BindBuffer::load_with(&mut *load_fn);
BindBufferBase::load_with(&mut *load_fn);
BindBufferRange::load_with(&mut *load_fn);
BindFramebuffer::load_with(&mut *load_fn);
BindRenderbuffer::load_with(&mut *load_fn);
BindSampler::load_with(&mut *load_fn);
BindTexture::load_with(&mut *load_fn);
BindTransformFeedback::load_with(&mut *load_fn);
BindVertexArray::load_with(&mut *load_fn);
BlendColor::load_with(&mut *load_fn);
BlendEquation::load_with(&mut *load_fn);
BlendEquationSeparate::load_with(&mut *load_fn);
BlendFunc::load_with(&mut *load_fn);
BlendFuncSeparate::load_with(&mut *load_fn);
BlitFramebuffer::load_with(&mut *load_fn);
BufferData::load_with(&mut *load_fn);
BufferSubData::load_with(&mut *load_fn);
CheckFramebufferStatus::load_with(&mut *load_fn);
Clear::load_with(&mut *load_fn);
ClearBufferfi::load_with(&mut *load_fn);
ClearBufferfv::load_with(&mut *load_fn);
ClearBufferiv::load_with(&mut *load_fn);
ClearBufferuiv::load_with(&mut *load_fn);
ClearColor::load_with(&mut *load_fn);
ClearDepthf::load_with(&mut *load_fn);
ClearStencil::load_with(&mut *load_fn);
ClientWaitSync::load_with(&mut *load_fn);
ColorMask::load_with(&mut *load_fn);
CompileShader::load_with(&mut *load_fn);
CompressedTexImage2D::load_with(&mut *load_fn);
CompressedTexImage3D::load_with(&mut *load_fn);
CompressedTexSubImage2D::load_with(&mut *load_fn);
CompressedTexSubImage3D::load_with(&mut *load_fn);
CopyBufferSubData::load_with(&mut *load_fn);
CopyTexImage2D::load_with(&mut *load_fn);
CopyTexSubImage2D::load_with(&mut *load_fn);
CopyTexSubImage3D::load_with(&mut *load_fn);
CreateProgram::load_with(&mut *load_fn);
CreateShader::load_with(&mut *load_fn);
CullFace::load_with(&mut *load_fn);
DeleteBuffers::load_with(&mut *load_fn);
DeleteFramebuffers::load_with(&mut *load_fn);
DeleteProgram::load_with(&mut *load_fn);
DeleteQueries::load_with(&mut *load_fn);
DeleteRenderbuffers::load_with(&mut *load_fn);
DeleteSamplers::load_with(&mut *load_fn);
DeleteShader::load_with(&mut *load_fn);
DeleteSync::load_with(&mut *load_fn);
DeleteTextures::load_with(&mut *load_fn);
DeleteTransformFeedbacks::load_with(&mut *load_fn);
DeleteVertexArrays::load_with(&mut *load_fn);
DepthFunc::load_with(&mut *load_fn);
DepthMask::load_with(&mut *load_fn);
DepthRangef::load_with(&mut *load_fn);
DetachShader::load_with(&mut *load_fn);
Disable::load_with(&mut *load_fn);
DisableVertexAttribArray::load_with(&mut *load_fn);
DrawArrays::load_with(&mut *load_fn);
DrawArraysInstanced::load_with(&mut *load_fn);
DrawBuffers::load_with(&mut *load_fn);
DrawElements::load_with(&mut *load_fn);
DrawElementsInstanced::load_with(&mut *load_fn);
DrawRangeElements::load_with(&mut *load_fn);
Enable::load_with(&mut *load_fn);
EnableVertexAttribArray::load_with(&mut *load_fn);
EndQuery::load_with(&mut *load_fn);
EndTransformFeedback::load_with(&mut *load_fn);
FenceSync::load_with(&mut *load_fn);
Finish::load_with(&mut *load_fn);
Flush::load_with(&mut *load_fn);
FlushMappedBufferRange::load_with(&mut *load_fn);
FramebufferRenderbuffer::load_with(&mut *load_fn);
FramebufferTexture2D::load_with(&mut *load_fn);
FramebufferTextureLayer::load_with(&mut *load_fn);
FrontFace::load_with(&mut *load_fn);
GenBuffers::load_with(&mut *load_fn);
GenFramebuffers::load_with(&mut *load_fn);
GenQueries::load_with(&mut *load_fn);
GenRenderbuffers::load_with(&mut *load_fn);
GenSamplers::load_with(&mut *load_fn);
GenTextures::load_with(&mut *load_fn);
GenTransformFeedbacks::load_with(&mut *load_fn);
GenVertexArrays::load_with(&mut *load_fn);
GenerateMipmap::load_with(&mut *load_fn);
GetActiveAttrib::load_with(&mut *load_fn);
GetActiveUniform::load_with(&mut *load_fn);
GetActiveUniformBlockName::load_with(&mut *load_fn);
GetActiveUniformBlockiv::load_with(&mut *load_fn);
GetActiveUniformsiv::load_with(&mut *load_fn);
GetAttachedShaders::load_with(&mut *load_fn);
GetAttribLocation::load_with(&mut *load_fn);
GetBooleanv::load_with(&mut *load_fn);
GetBufferParameteri64v::load_with(&mut *load_fn);
GetBufferParameteriv::load_with(&mut *load_fn);
GetBufferPointerv::load_with(&mut *load_fn);
GetError::load_with(&mut *load_fn);
GetFloatv::load_with(&mut *load_fn);
GetFragDataLocation::load_with(&mut *load_fn);
GetFramebufferAttachmentParameteriv::load_with(&mut *load_fn);
GetInteger64i_v::load_with(&mut *load_fn);
GetInteger64v::load_with(&mut *load_fn);
GetIntegeri_v::load_with(&mut *load_fn);
GetIntegerv::load_with(&mut *load_fn);
GetInternalformativ::load_with(&mut *load_fn);
GetProgramBinary::load_with(&mut *load_fn);
GetProgramInfoLog::load_with(&mut *load_fn);
GetProgramiv::load_with(&mut *load_fn);
GetQueryObjectuiv::load_with(&mut *load_fn);
GetQueryiv::load_with(&mut *load_fn);
GetRenderbufferParameteriv::load_with(&mut *load_fn);
GetSamplerParameterfv::load_with(&mut *load_fn);
GetSamplerParameteriv::load_with(&mut *load_fn);
GetShaderInfoLog::load_with(&mut *load_fn);
GetShaderPrecisionFormat::load_with(&mut *load_fn);
GetShaderSource::load_with(&mut *load_fn);
GetShaderiv::load_with(&mut *load_fn);
GetString::load_with(&mut *load_fn);
GetStringi::load_with(&mut *load_fn);
GetSynciv::load_with(&mut *load_fn);
GetTexParameterfv::load_with(&mut *load_fn);
GetTexParameteriv::load_with(&mut *load_fn);
GetTransformFeedbackVarying::load_with(&mut *load_fn);
GetUniformBlockIndex::load_with(&mut *load_fn);
GetUniformIndices::load_with(&mut *load_fn);
GetUniformLocation::load_with(&mut *load_fn);
GetUniformfv::load_with(&mut *load_fn);
GetUniformiv::load_with(&mut *load_fn);
GetUniformuiv::load_with(&mut *load_fn);
GetVertexAttribIiv::load_with(&mut *load_fn);
GetVertexAttribIuiv::load_with(&mut *load_fn);
GetVertexAttribPointerv::load_with(&mut *load_fn);
GetVertexAttribfv::load_with(&mut *load_fn);
GetVertexAttribiv::load_with(&mut *load_fn);
Hint::load_with(&mut *load_fn);
InvalidateFramebuffer::load_with(&mut *load_fn);
InvalidateSubFramebuffer::load_with(&mut *load_fn);
IsBuffer::load_with(&mut *load_fn);
IsEnabled::load_with(&mut *load_fn);
IsFramebuffer::load_with(&mut *load_fn);
IsProgram::load_with(&mut *load_fn);
IsQuery::load_with(&mut *load_fn);
IsRenderbuffer::load_with(&mut *load_fn);
IsSampler::load_with(&mut *load_fn);
IsShader::load_with(&mut *load_fn);
IsSync::load_with(&mut *load_fn);
IsTexture::load_with(&mut *load_fn);
IsTransformFeedback::load_with(&mut *load_fn);
IsVertexArray::load_with(&mut *load_fn);
LineWidth::load_with(&mut *load_fn);
LinkProgram::load_with(&mut *load_fn);
MapBufferRange::load_with(&mut *load_fn);
PauseTransformFeedback::load_with(&mut *load_fn);
PixelStorei::load_with(&mut *load_fn);
PolygonOffset::load_with(&mut *load_fn);
ProgramBinary::load_with(&mut *load_fn);
ProgramParameteri::load_with(&mut *load_fn);
ReadBuffer::load_with(&mut *load_fn);
ReadPixels::load_with(&mut *load_fn);
ReleaseShaderCompiler::load_with(&mut *load_fn);
RenderbufferStorage::load_with(&mut *load_fn);
RenderbufferStorageMultisample::load_with(&mut *load_fn);
ResumeTransformFeedback::load_with(&mut *load_fn);
SampleCoverage::load_with(&mut *load_fn);
SamplerParameterf::load_with(&mut *load_fn);
SamplerParameterfv::load_with(&mut *load_fn);
SamplerParameteri::load_with(&mut *load_fn);
SamplerParameteriv::load_with(&mut *load_fn);
Scissor::load_with(&mut *load_fn);
ShaderBinary::load_with(&mut *load_fn);
ShaderSource::load_with(&mut *load_fn);
StencilFunc::load_with(&mut *load_fn);
StencilFuncSeparate::load_with(&mut *load_fn);
StencilMask::load_with(&mut *load_fn);
StencilMaskSeparate::load_with(&mut *load_fn);
StencilOp::load_with(&mut *load_fn);
StencilOpSeparate::load_with(&mut *load_fn);
TexImage2D::load_with(&mut *load_fn);
TexImage3D::load_with(&mut *load_fn);
TexParameterf::load_with(&mut *load_fn);
TexParameterfv::load_with(&mut *load_fn);
TexParameteri::load_with(&mut *load_fn);
TexParameteriv::load_with(&mut *load_fn);
TexStorage2D::load_with(&mut *load_fn);
TexStorage3D::load_with(&mut *load_fn);
TexSubImage2D::load_with(&mut *load_fn);
TexSubImage3D::load_with(&mut *load_fn);
TransformFeedbackVaryings::load_with(&mut *load_fn);
Uniform1f::load_with(&mut *load_fn);
Uniform1fv::load_with(&mut *load_fn);
Uniform1i::load_with(&mut *load_fn);
Uniform1iv::load_with(&mut *load_fn);
Uniform1ui::load_with(&mut *load_fn);
Uniform1uiv::load_with(&mut *load_fn);
Uniform2f::load_with(&mut *load_fn);
Uniform2fv::load_with(&mut *load_fn);
Uniform2i::load_with(&mut *load_fn);
Uniform2iv::load_with(&mut *load_fn);
Uniform2ui::load_with(&mut *load_fn);
Uniform2uiv::load_with(&mut *load_fn);
Uniform3f::load_with(&mut *load_fn);
Uniform3fv::load_with(&mut *load_fn);
Uniform3i::load_with(&mut *load_fn);
Uniform3iv::load_with(&mut *load_fn);
Uniform3ui::load_with(&mut *load_fn);
Uniform3uiv::load_with(&mut *load_fn);
Uniform4f::load_with(&mut *load_fn);
Uniform4fv::load_with(&mut *load_fn);
Uniform4i::load_with(&mut *load_fn);
Uniform4iv::load_with(&mut *load_fn);
Uniform4ui::load_with(&mut *load_fn);
Uniform4uiv::load_with(&mut *load_fn);
UniformBlockBinding::load_with(&mut *load_fn);
UniformMatrix2fv::load_with(&mut *load_fn);
UniformMatrix2x3fv::load_with(&mut *load_fn);
UniformMatrix2x4fv::load_with(&mut *load_fn);
UniformMatrix3fv::load_with(&mut *load_fn);
UniformMatrix3x2fv::load_with(&mut *load_fn);
UniformMatrix3x4fv::load_with(&mut *load_fn);
UniformMatrix4fv::load_with(&mut *load_fn);
UniformMatrix4x2fv::load_with(&mut *load_fn);
UniformMatrix4x3fv::load_with(&mut *load_fn);
UnmapBuffer::load_with(&mut *load_fn);
UseProgram::load_with(&mut *load_fn);
ValidateProgram::load_with(&mut *load_fn);
VertexAttrib1f::load_with(&mut *load_fn);
VertexAttrib1fv::load_with(&mut *load_fn);
VertexAttrib2f::load_with(&mut *load_fn);
VertexAttrib2fv::load_with(&mut *load_fn);
VertexAttrib3f::load_with(&mut *load_fn);
VertexAttrib3fv::load_with(&mut *load_fn);
VertexAttrib4f::load_with(&mut *load_fn);
VertexAttrib4fv::load_with(&mut *load_fn);
VertexAttribDivisor::load_with(&mut *load_fn);
VertexAttribI4i::load_with(&mut *load_fn);
VertexAttribI4iv::load_with(&mut *load_fn);
VertexAttribI4ui::load_with(&mut *load_fn);
VertexAttribI4uiv::load_with(&mut *load_fn);
VertexAttribIPointer::load_with(&mut *load_fn);
VertexAttribPointer::load_with(&mut *load_fn);
Viewport::load_with(&mut *load_fn);
WaitSync::load_with(&mut *load_fn);
}
fn fn_ptr_ok(p: *const c_void) -> bool {
let p_u = p as usize;
(p_u >= 8) && (p_u != (-1_isize) as usize)
}
unsafe fn meta_loader(
loader: &mut dyn FnMut(*const c_char) -> *const c_void,
names: &[&[u8]],
) -> OptVoidPtr {
for name in names.iter() {
debug_assert!(*name.iter().last().unwrap() == 0_u8);
let p = loader(name.as_ptr() as *const c_char);
if fn_ptr_ok(p) {
return NonNull::new(p as *mut c_void);
}
}
None
}
pub use types::*;
pub mod types {
use super::*;
pub type GLenum = c_uint;
pub type GLboolean = c_uchar;
pub type GLbitfield = c_uint;
pub type GLvoid = c_void;
pub type GLbyte = c_char;
pub type GLshort = c_short;
pub type GLint = c_int;
pub type GLclampx = c_int;
pub type GLubyte = c_uchar;
pub type GLushort = c_ushort;
pub type GLuint = c_uint;
pub type GLsizei = c_int;
pub type GLfloat = c_float;
pub type GLclampf = c_float;
pub type GLdouble = c_double;
pub type GLclampd = c_double;
pub type GLeglImageOES = *const c_void;
pub type GLchar = c_char;
pub type GLcharARB = c_char;
#[cfg(target_os = "macos")]
pub type GLhandleARB = *const c_void;
#[cfg(not(target_os = "macos"))]
pub type GLhandleARB = c_uint;
pub type GLhalfARB = c_ushort;
pub type GLhalf = c_ushort;
pub type GLfixed = GLint;
pub type GLintptr = isize;
pub type GLsizeiptr = isize;
pub type GLint64 = i64;
pub type GLuint64 = u64;
pub type GLintptrARB = isize;
pub type GLsizeiptrARB = isize;
pub type GLint64EXT = i64;
pub type GLuint64EXT = u64;
pub enum __GLsync {}
pub type GLsync = *const __GLsync;
pub enum _cl_context {}
pub enum _cl_event {}
pub type GLDEBUGPROC = Option<
extern "system" fn(
source: GLenum,
gltype: GLenum,
id: GLuint,
severity: GLenum,
length: GLsizei,
message: *const GLchar,
userParam: *mut c_void,
),
>;
pub type GLDEBUGPROCARB = Option<
extern "system" fn(
source: GLenum,
gltype: GLenum,
id: GLuint,
severity: GLenum,
length: GLsizei,
message: *const GLchar,
userParam: *mut c_void,
),
>;
pub type GLDEBUGPROCKHR = Option<
extern "system" fn(
source: GLenum,
gltype: GLenum,
id: GLuint,
severity: GLenum,
length: GLsizei,
message: *const GLchar,
userParam: *mut c_void,
),
>;
pub type GLDEBUGPROCAMD = Option<
extern "system" fn(
id: GLuint,
category: GLenum,
severity: GLenum,
length: GLsizei,
message: *const GLchar,
userParam: *mut c_void,
),
>;
pub type GLhalfNV = c_ushort;
pub type GLvdpauSurfaceNV = GLintptr;
}
pub use consts::*;
pub mod consts {
use super::*;
pub const ACTIVE_ATTRIBUTES: GLenum = 0x8B89;
pub const ACTIVE_ATTRIBUTE_MAX_LENGTH: GLenum = 0x8B8A;
pub const ACTIVE_TEXTURE: GLenum = 0x84E0;
pub const ACTIVE_UNIFORMS: GLenum = 0x8B86;
pub const ACTIVE_UNIFORM_BLOCKS: GLenum = 0x8A36;
pub const ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH: GLenum = 0x8A35;
pub const ACTIVE_UNIFORM_MAX_LENGTH: GLenum = 0x8B87;
pub const ALIASED_LINE_WIDTH_RANGE: GLenum = 0x846E;
pub const ALIASED_POINT_SIZE_RANGE: GLenum = 0x846D;
pub const ALPHA: GLenum = 0x1906;
pub const ALPHA_BITS: GLenum = 0x0D55;
pub const ALREADY_SIGNALED: GLenum = 0x911A;
pub const ALWAYS: GLenum = 0x0207;
pub const ANY_SAMPLES_PASSED: GLenum = 0x8C2F;
pub const ANY_SAMPLES_PASSED_CONSERVATIVE: GLenum = 0x8D6A;
pub const ARRAY_BUFFER: GLenum = 0x8892;
pub const ARRAY_BUFFER_BINDING: GLenum = 0x8894;
pub const ATTACHED_SHADERS: GLenum = 0x8B85;
pub const BACK: GLenum = 0x0405;
pub const BLEND: GLenum = 0x0BE2;
pub const BLEND_COLOR: GLenum = 0x8005;
pub const BLEND_DST_ALPHA: GLenum = 0x80CA;
pub const BLEND_DST_RGB: GLenum = 0x80C8;
pub const BLEND_EQUATION: GLenum = 0x8009;
pub const BLEND_EQUATION_ALPHA: GLenum = 0x883D;
pub const BLEND_EQUATION_RGB: GLenum = 0x8009;
pub const BLEND_SRC_ALPHA: GLenum = 0x80CB;
pub const BLEND_SRC_RGB: GLenum = 0x80C9;
pub const BLUE: GLenum = 0x1905;
pub const BLUE_BITS: GLenum = 0x0D54;
pub const BOOL: GLenum = 0x8B56;
pub const BOOL_VEC2: GLenum = 0x8B57;
pub const BOOL_VEC3: GLenum = 0x8B58;
pub const BOOL_VEC4: GLenum = 0x8B59;
pub const BUFFER_ACCESS_FLAGS: GLenum = 0x911F;
pub const BUFFER_MAPPED: GLenum = 0x88BC;
pub const BUFFER_MAP_LENGTH: GLenum = 0x9120;
pub const BUFFER_MAP_OFFSET: GLenum = 0x9121;
pub const BUFFER_MAP_POINTER: GLenum = 0x88BD;
pub const BUFFER_SIZE: GLenum = 0x8764;
pub const BUFFER_USAGE: GLenum = 0x8765;
pub const BYTE: GLenum = 0x1400;
pub const CCW: GLenum = 0x0901;
pub const CLAMP_TO_EDGE: GLenum = 0x812F;
pub const COLOR: GLenum = 0x1800;
pub const COLOR_ATTACHMENT0: GLenum = 0x8CE0;
pub const COLOR_ATTACHMENT1: GLenum = 0x8CE1;
pub const COLOR_ATTACHMENT10: GLenum = 0x8CEA;
pub const COLOR_ATTACHMENT11: GLenum = 0x8CEB;
pub const COLOR_ATTACHMENT12: GLenum = 0x8CEC;
pub const COLOR_ATTACHMENT13: GLenum = 0x8CED;
pub const COLOR_ATTACHMENT14: GLenum = 0x8CEE;
pub const COLOR_ATTACHMENT15: GLenum = 0x8CEF;
pub const COLOR_ATTACHMENT16: GLenum = 0x8CF0;
pub const COLOR_ATTACHMENT17: GLenum = 0x8CF1;
pub const COLOR_ATTACHMENT18: GLenum = 0x8CF2;
pub const COLOR_ATTACHMENT19: GLenum = 0x8CF3;
pub const COLOR_ATTACHMENT2: GLenum = 0x8CE2;
pub const COLOR_ATTACHMENT20: GLenum = 0x8CF4;
pub const COLOR_ATTACHMENT21: GLenum = 0x8CF5;
pub const COLOR_ATTACHMENT22: GLenum = 0x8CF6;
pub const COLOR_ATTACHMENT23: GLenum = 0x8CF7;
pub const COLOR_ATTACHMENT24: GLenum = 0x8CF8;
pub const COLOR_ATTACHMENT25: GLenum = 0x8CF9;
pub const COLOR_ATTACHMENT26: GLenum = 0x8CFA;
pub const COLOR_ATTACHMENT27: GLenum = 0x8CFB;
pub const COLOR_ATTACHMENT28: GLenum = 0x8CFC;
pub const COLOR_ATTACHMENT29: GLenum = 0x8CFD;
pub const COLOR_ATTACHMENT3: GLenum = 0x8CE3;
pub const COLOR_ATTACHMENT30: GLenum = 0x8CFE;
pub const COLOR_ATTACHMENT31: GLenum = 0x8CFF;
pub const COLOR_ATTACHMENT4: GLenum = 0x8CE4;
pub const COLOR_ATTACHMENT5: GLenum = 0x8CE5;
pub const COLOR_ATTACHMENT6: GLenum = 0x8CE6;
pub const COLOR_ATTACHMENT7: GLenum = 0x8CE7;
pub const COLOR_ATTACHMENT8: GLenum = 0x8CE8;
pub const COLOR_ATTACHMENT9: GLenum = 0x8CE9;
pub const COLOR_BUFFER_BIT: GLenum = 0x00004000;
pub const COLOR_CLEAR_VALUE: GLenum = 0x0C22;
pub const COLOR_WRITEMASK: GLenum = 0x0C23;
pub const COMPARE_REF_TO_TEXTURE: GLenum = 0x884E;
pub const COMPILE_STATUS: GLenum = 0x8B81;
pub const COMPRESSED_R11_EAC: GLenum = 0x9270;
pub const COMPRESSED_RG11_EAC: GLenum = 0x9272;
pub const COMPRESSED_RGB8_ETC2: GLenum = 0x9274;
pub const COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2: GLenum = 0x9276;
pub const COMPRESSED_RGBA8_ETC2_EAC: GLenum = 0x9278;
pub const COMPRESSED_SIGNED_R11_EAC: GLenum = 0x9271;
pub const COMPRESSED_SIGNED_RG11_EAC: GLenum = 0x9273;
pub const COMPRESSED_SRGB8_ALPHA8_ETC2_EAC: GLenum = 0x9279;
pub const COMPRESSED_SRGB8_ETC2: GLenum = 0x9275;
pub const COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2: GLenum = 0x9277;
pub const COMPRESSED_TEXTURE_FORMATS: GLenum = 0x86A3;
pub const CONDITION_SATISFIED: GLenum = 0x911C;
pub const CONSTANT_ALPHA: GLenum = 0x8003;
pub const CONSTANT_COLOR: GLenum = 0x8001;
pub const COPY_READ_BUFFER: GLenum = 0x8F36;
pub const COPY_READ_BUFFER_BINDING: GLenum = 0x8F36;
pub const COPY_WRITE_BUFFER: GLenum = 0x8F37;
pub const COPY_WRITE_BUFFER_BINDING: GLenum = 0x8F37;
pub const CULL_FACE: GLenum = 0x0B44;
pub const CULL_FACE_MODE: GLenum = 0x0B45;
pub const CURRENT_PROGRAM: GLenum = 0x8B8D;
pub const CURRENT_QUERY: GLenum = 0x8865;
pub const CURRENT_VERTEX_ATTRIB: GLenum = 0x8626;
pub const CW: GLenum = 0x0900;
pub const DECR: GLenum = 0x1E03;
pub const DECR_WRAP: GLenum = 0x8508;
pub const DELETE_STATUS: GLenum = 0x8B80;
pub const DEPTH: GLenum = 0x1801;
pub const DEPTH24_STENCIL8: GLenum = 0x88F0;
pub const DEPTH32F_STENCIL8: GLenum = 0x8CAD;
pub const DEPTH_ATTACHMENT: GLenum = 0x8D00;
pub const DEPTH_BITS: GLenum = 0x0D56;
pub const DEPTH_BUFFER_BIT: GLenum = 0x00000100;
pub const DEPTH_CLEAR_VALUE: GLenum = 0x0B73;
pub const DEPTH_COMPONENT: GLenum = 0x1902;
pub const DEPTH_COMPONENT16: GLenum = 0x81A5;
pub const DEPTH_COMPONENT24: GLenum = 0x81A6;
pub const DEPTH_COMPONENT32F: GLenum = 0x8CAC;
pub const DEPTH_FUNC: GLenum = 0x0B74;
pub const DEPTH_RANGE: GLenum = 0x0B70;
pub const DEPTH_STENCIL: GLenum = 0x84F9;
pub const DEPTH_STENCIL_ATTACHMENT: GLenum = 0x821A;
pub const DEPTH_TEST: GLenum = 0x0B71;
pub const DEPTH_WRITEMASK: GLenum = 0x0B72;
pub const DITHER: GLenum = 0x0BD0;
pub const DONT_CARE: GLenum = 0x1100;
pub const DRAW_BUFFER0: GLenum = 0x8825;
pub const DRAW_BUFFER1: GLenum = 0x8826;
pub const DRAW_BUFFER10: GLenum = 0x882F;
pub const DRAW_BUFFER11: GLenum = 0x8830;
pub const DRAW_BUFFER12: GLenum = 0x8831;
pub const DRAW_BUFFER13: GLenum = 0x8832;
pub const DRAW_BUFFER14: GLenum = 0x8833;
pub const DRAW_BUFFER15: GLenum = 0x8834;
pub const DRAW_BUFFER2: GLenum = 0x8827;
pub const DRAW_BUFFER3: GLenum = 0x8828;
pub const DRAW_BUFFER4: GLenum = 0x8829;
pub const DRAW_BUFFER5: GLenum = 0x882A;
pub const DRAW_BUFFER6: GLenum = 0x882B;
pub const DRAW_BUFFER7: GLenum = 0x882C;
pub const DRAW_BUFFER8: GLenum = 0x882D;
pub const DRAW_BUFFER9: GLenum = 0x882E;
pub const DRAW_FRAMEBUFFER: GLenum = 0x8CA9;
pub const DRAW_FRAMEBUFFER_BINDING: GLenum = 0x8CA6;
pub const DST_ALPHA: GLenum = 0x0304;
pub const DST_COLOR: GLenum = 0x0306;
pub const DYNAMIC_COPY: GLenum = 0x88EA;
pub const DYNAMIC_DRAW: GLenum = 0x88E8;
pub const DYNAMIC_READ: GLenum = 0x88E9;
pub const ELEMENT_ARRAY_BUFFER: GLenum = 0x8893;
pub const ELEMENT_ARRAY_BUFFER_BINDING: GLenum = 0x8895;
pub const EQUAL: GLenum = 0x0202;
pub const EXTENSIONS: GLenum = 0x1F03;
pub const FALSE: GLboolean = 0;
pub const FASTEST: GLenum = 0x1101;
pub const FIXED: GLenum = 0x140C;
pub const FLOAT: GLenum = 0x1406;
pub const FLOAT_32_UNSIGNED_INT_24_8_REV: GLenum = 0x8DAD;
pub const FLOAT_MAT2: GLenum = 0x8B5A;
pub const FLOAT_MAT2x3: GLenum = 0x8B65;
pub const FLOAT_MAT2x4: GLenum = 0x8B66;
pub const FLOAT_MAT3: GLenum = 0x8B5B;
pub const FLOAT_MAT3x2: GLenum = 0x8B67;
pub const FLOAT_MAT3x4: GLenum = 0x8B68;
pub const FLOAT_MAT4: GLenum = 0x8B5C;
pub const FLOAT_MAT4x2: GLenum = 0x8B69;
pub const FLOAT_MAT4x3: GLenum = 0x8B6A;
pub const FLOAT_VEC2: GLenum = 0x8B50;
pub const FLOAT_VEC3: GLenum = 0x8B51;
pub const FLOAT_VEC4: GLenum = 0x8B52;
pub const FRAGMENT_SHADER: GLenum = 0x8B30;
pub const FRAGMENT_SHADER_DERIVATIVE_HINT: GLenum = 0x8B8B;
pub const FRAMEBUFFER: GLenum = 0x8D40;
pub const FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE: GLenum = 0x8215;
pub const FRAMEBUFFER_ATTACHMENT_BLUE_SIZE: GLenum = 0x8214;
pub const FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING: GLenum = 0x8210;
pub const FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE: GLenum = 0x8211;
pub const FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE: GLenum = 0x8216;
pub const FRAMEBUFFER_ATTACHMENT_GREEN_SIZE: GLenum = 0x8213;
pub const FRAMEBUFFER_ATTACHMENT_OBJECT_NAME: GLenum = 0x8CD1;
pub const FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE: GLenum = 0x8CD0;
pub const FRAMEBUFFER_ATTACHMENT_RED_SIZE: GLenum = 0x8212;
pub const FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE: GLenum = 0x8217;
pub const FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE: GLenum = 0x8CD3;
pub const FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER: GLenum = 0x8CD4;
pub const FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL: GLenum = 0x8CD2;
pub const FRAMEBUFFER_BINDING: GLenum = 0x8CA6;
pub const FRAMEBUFFER_COMPLETE: GLenum = 0x8CD5;
pub const FRAMEBUFFER_DEFAULT: GLenum = 0x8218;
pub const FRAMEBUFFER_INCOMPLETE_ATTACHMENT: GLenum = 0x8CD6;
pub const FRAMEBUFFER_INCOMPLETE_DIMENSIONS: GLenum = 0x8CD9;
pub const FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: GLenum = 0x8CD7;
pub const FRAMEBUFFER_INCOMPLETE_MULTISAMPLE: GLenum = 0x8D56;
pub const FRAMEBUFFER_UNDEFINED: GLenum = 0x8219;
pub const FRAMEBUFFER_UNSUPPORTED: GLenum = 0x8CDD;
pub const FRONT: GLenum = 0x0404;
pub const FRONT_AND_BACK: GLenum = 0x0408;
pub const FRONT_FACE: GLenum = 0x0B46;
pub const FUNC_ADD: GLenum = 0x8006;
pub const FUNC_REVERSE_SUBTRACT: GLenum = 0x800B;
pub const FUNC_SUBTRACT: GLenum = 0x800A;
pub const GENERATE_MIPMAP_HINT: GLenum = 0x8192;
pub const GEQUAL: GLenum = 0x0206;
pub const GREATER: GLenum = 0x0204;
pub const GREEN: GLenum = 0x1904;
pub const GREEN_BITS: GLenum = 0x0D53;
pub const HALF_FLOAT: GLenum = 0x140B;
pub const HIGH_FLOAT: GLenum = 0x8DF2;
pub const HIGH_INT: GLenum = 0x8DF5;
pub const IMPLEMENTATION_COLOR_READ_FORMAT: GLenum = 0x8B9B;
pub const IMPLEMENTATION_COLOR_READ_TYPE: GLenum = 0x8B9A;
pub const INCR: GLenum = 0x1E02;
pub const INCR_WRAP: GLenum = 0x8507;
pub const INFO_LOG_LENGTH: GLenum = 0x8B84;
pub const INT: GLenum = 0x1404;
pub const INTERLEAVED_ATTRIBS: GLenum = 0x8C8C;
pub const INT_2_10_10_10_REV: GLenum = 0x8D9F;
pub const INT_SAMPLER_2D: GLenum = 0x8DCA;
pub const INT_SAMPLER_2D_ARRAY: GLenum = 0x8DCF;
pub const INT_SAMPLER_3D: GLenum = 0x8DCB;
pub const INT_SAMPLER_CUBE: GLenum = 0x8DCC;
pub const INT_VEC2: GLenum = 0x8B53;
pub const INT_VEC3: GLenum = 0x8B54;
pub const INT_VEC4: GLenum = 0x8B55;
pub const INVALID_ENUM: GLenum = 0x0500;
pub const INVALID_FRAMEBUFFER_OPERATION: GLenum = 0x0506;
pub const INVALID_INDEX: GLuint = 0xFFFFFFFF;
pub const INVALID_OPERATION: GLenum = 0x0502;
pub const INVALID_VALUE: GLenum = 0x0501;
pub const INVERT: GLenum = 0x150A;
pub const KEEP: GLenum = 0x1E00;
pub const LEQUAL: GLenum = 0x0203;
pub const LESS: GLenum = 0x0201;
pub const LINEAR: GLenum = 0x2601;
pub const LINEAR_MIPMAP_LINEAR: GLenum = 0x2703;
pub const LINEAR_MIPMAP_NEAREST: GLenum = 0x2701;
pub const LINES: GLenum = 0x0001;
pub const LINE_LOOP: GLenum = 0x0002;
pub const LINE_STRIP: GLenum = 0x0003;
pub const LINE_WIDTH: GLenum = 0x0B21;
pub const LINK_STATUS: GLenum = 0x8B82;
pub const LOW_FLOAT: GLenum = 0x8DF0;
pub const LOW_INT: GLenum = 0x8DF3;
pub const LUMINANCE: GLenum = 0x1909;
pub const LUMINANCE_ALPHA: GLenum = 0x190A;
pub const MAJOR_VERSION: GLenum = 0x821B;
pub const MAP_FLUSH_EXPLICIT_BIT: GLenum = 0x0010;
pub const MAP_INVALIDATE_BUFFER_BIT: GLenum = 0x0008;
pub const MAP_INVALIDATE_RANGE_BIT: GLenum = 0x0004;
pub const MAP_READ_BIT: GLenum = 0x0001;
pub const MAP_UNSYNCHRONIZED_BIT: GLenum = 0x0020;
pub const MAP_WRITE_BIT: GLenum = 0x0002;
pub const MAX: GLenum = 0x8008;
pub const MAX_3D_TEXTURE_SIZE: GLenum = 0x8073;
pub const MAX_ARRAY_TEXTURE_LAYERS: GLenum = 0x88FF;
pub const MAX_COLOR_ATTACHMENTS: GLenum = 0x8CDF;
pub const MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS: GLenum = 0x8A33;
pub const MAX_COMBINED_TEXTURE_IMAGE_UNITS: GLenum = 0x8B4D;
pub const MAX_COMBINED_UNIFORM_BLOCKS: GLenum = 0x8A2E;
pub const MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS: GLenum = 0x8A31;
pub const MAX_CUBE_MAP_TEXTURE_SIZE: GLenum = 0x851C;
pub const MAX_DRAW_BUFFERS: GLenum = 0x8824;
pub const MAX_ELEMENTS_INDICES: GLenum = 0x80E9;
pub const MAX_ELEMENTS_VERTICES: GLenum = 0x80E8;
pub const MAX_ELEMENT_INDEX: GLenum = 0x8D6B;
pub const MAX_FRAGMENT_INPUT_COMPONENTS: GLenum = 0x9125;
pub const MAX_FRAGMENT_UNIFORM_BLOCKS: GLenum = 0x8A2D;
pub const MAX_FRAGMENT_UNIFORM_COMPONENTS: GLenum = 0x8B49;
pub const MAX_FRAGMENT_UNIFORM_VECTORS: GLenum = 0x8DFD;
pub const MAX_PROGRAM_TEXEL_OFFSET: GLenum = 0x8905;
pub const MAX_RENDERBUFFER_SIZE: GLenum = 0x84E8;
pub const MAX_SAMPLES: GLenum = 0x8D57;
pub const MAX_SERVER_WAIT_TIMEOUT: GLenum = 0x9111;
pub const MAX_TEXTURE_IMAGE_UNITS: GLenum = 0x8872;
pub const MAX_TEXTURE_LOD_BIAS: GLenum = 0x84FD;
pub const MAX_TEXTURE_SIZE: GLenum = 0x0D33;
pub const MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS: GLenum = 0x8C8A;
pub const MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS: GLenum = 0x8C8B;
pub const MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS: GLenum = 0x8C80;
pub const MAX_UNIFORM_BLOCK_SIZE: GLenum = 0x8A30;
pub const MAX_UNIFORM_BUFFER_BINDINGS: GLenum = 0x8A2F;
pub const MAX_VARYING_COMPONENTS: GLenum = 0x8B4B;
pub const MAX_VARYING_VECTORS: GLenum = 0x8DFC;
pub const MAX_VERTEX_ATTRIBS: GLenum = 0x8869;
pub const MAX_VERTEX_OUTPUT_COMPONENTS: GLenum = 0x9122;
pub const MAX_VERTEX_TEXTURE_IMAGE_UNITS: GLenum = 0x8B4C;
pub const MAX_VERTEX_UNIFORM_BLOCKS: GLenum = 0x8A2B;
pub const MAX_VERTEX_UNIFORM_COMPONENTS: GLenum = 0x8B4A;
pub const MAX_VERTEX_UNIFORM_VECTORS: GLenum = 0x8DFB;
pub const MAX_VIEWPORT_DIMS: GLenum = 0x0D3A;
pub const MEDIUM_FLOAT: GLenum = 0x8DF1;
pub const MEDIUM_INT: GLenum = 0x8DF4;
pub const MIN: GLenum = 0x8007;
pub const MINOR_VERSION: GLenum = 0x821C;
pub const MIN_PROGRAM_TEXEL_OFFSET: GLenum = 0x8904;
pub const MIRRORED_REPEAT: GLenum = 0x8370;
pub const NEAREST: GLenum = 0x2600;
pub const NEAREST_MIPMAP_LINEAR: GLenum = 0x2702;
pub const NEAREST_MIPMAP_NEAREST: GLenum = 0x2700;
pub const NEVER: GLenum = 0x0200;
pub const NICEST: GLenum = 0x1102;
pub const NONE: GLenum = 0;
pub const NOTEQUAL: GLenum = 0x0205;
pub const NO_ERROR: GLenum = 0;
pub const NUM_COMPRESSED_TEXTURE_FORMATS: GLenum = 0x86A2;
pub const NUM_EXTENSIONS: GLenum = 0x821D;
pub const NUM_PROGRAM_BINARY_FORMATS: GLenum = 0x87FE;
pub const NUM_SAMPLE_COUNTS: GLenum = 0x9380;
pub const NUM_SHADER_BINARY_FORMATS: GLenum = 0x8DF9;
pub const OBJECT_TYPE: GLenum = 0x9112;
pub const ONE: GLenum = 1;
pub const ONE_MINUS_CONSTANT_ALPHA: GLenum = 0x8004;
pub const ONE_MINUS_CONSTANT_COLOR: GLenum = 0x8002;
pub const ONE_MINUS_DST_ALPHA: GLenum = 0x0305;
pub const ONE_MINUS_DST_COLOR: GLenum = 0x0307;
pub const ONE_MINUS_SRC_ALPHA: GLenum = 0x0303;
pub const ONE_MINUS_SRC_COLOR: GLenum = 0x0301;
pub const OUT_OF_MEMORY: GLenum = 0x0505;
pub const PACK_ALIGNMENT: GLenum = 0x0D05;
pub const PACK_ROW_LENGTH: GLenum = 0x0D02;
pub const PACK_SKIP_PIXELS: GLenum = 0x0D04;
pub const PACK_SKIP_ROWS: GLenum = 0x0D03;
pub const PIXEL_PACK_BUFFER: GLenum = 0x88EB;
pub const PIXEL_PACK_BUFFER_BINDING: GLenum = 0x88ED;
pub const PIXEL_UNPACK_BUFFER: GLenum = 0x88EC;
pub const PIXEL_UNPACK_BUFFER_BINDING: GLenum = 0x88EF;
pub const POINTS: GLenum = 0x0000;
pub const POLYGON_OFFSET_FACTOR: GLenum = 0x8038;
pub const POLYGON_OFFSET_FILL: GLenum = 0x8037;
pub const POLYGON_OFFSET_UNITS: GLenum = 0x2A00;
pub const PRIMITIVE_RESTART_FIXED_INDEX: GLenum = 0x8D69;
pub const PROGRAM_BINARY_FORMATS: GLenum = 0x87FF;
pub const PROGRAM_BINARY_LENGTH: GLenum = 0x8741;
pub const PROGRAM_BINARY_RETRIEVABLE_HINT: GLenum = 0x8257;
pub const QUERY_RESULT: GLenum = 0x8866;
pub const QUERY_RESULT_AVAILABLE: GLenum = 0x8867;
pub const R11F_G11F_B10F: GLenum = 0x8C3A;
pub const R16F: GLenum = 0x822D;
pub const R16I: GLenum = 0x8233;
pub const R16UI: GLenum = 0x8234;
pub const R32F: GLenum = 0x822E;
pub const R32I: GLenum = 0x8235;
pub const R32UI: GLenum = 0x8236;
pub const R8: GLenum = 0x8229;
pub const R8I: GLenum = 0x8231;
pub const R8UI: GLenum = 0x8232;
pub const R8_SNORM: GLenum = 0x8F94;
pub const RASTERIZER_DISCARD: GLenum = 0x8C89;
pub const READ_BUFFER: GLenum = 0x0C02;
pub const READ_FRAMEBUFFER: GLenum = 0x8CA8;
pub const READ_FRAMEBUFFER_BINDING: GLenum = 0x8CAA;
pub const RED: GLenum = 0x1903;
pub const RED_BITS: GLenum = 0x0D52;
pub const RED_INTEGER: GLenum = 0x8D94;
pub const RENDERBUFFER: GLenum = 0x8D41;
pub const RENDERBUFFER_ALPHA_SIZE: GLenum = 0x8D53;
pub const RENDERBUFFER_BINDING: GLenum = 0x8CA7;
pub const RENDERBUFFER_BLUE_SIZE: GLenum = 0x8D52;
pub const RENDERBUFFER_DEPTH_SIZE: GLenum = 0x8D54;
pub const RENDERBUFFER_GREEN_SIZE: GLenum = 0x8D51;
pub const RENDERBUFFER_HEIGHT: GLenum = 0x8D43;
pub const RENDERBUFFER_INTERNAL_FORMAT: GLenum = 0x8D44;
pub const RENDERBUFFER_RED_SIZE: GLenum = 0x8D50;
pub const RENDERBUFFER_SAMPLES: GLenum = 0x8CAB;
pub const RENDERBUFFER_STENCIL_SIZE: GLenum = 0x8D55;
pub const RENDERBUFFER_WIDTH: GLenum = 0x8D42;
pub const RENDERER: GLenum = 0x1F01;
pub const REPEAT: GLenum = 0x2901;
pub const REPLACE: GLenum = 0x1E01;
pub const RG: GLenum = 0x8227;
pub const RG16F: GLenum = 0x822F;
pub const RG16I: GLenum = 0x8239;
pub const RG16UI: GLenum = 0x823A;
pub const RG32F: GLenum = 0x8230;
pub const RG32I: GLenum = 0x823B;
pub const RG32UI: GLenum = 0x823C;
pub const RG8: GLenum = 0x822B;
pub const RG8I: GLenum = 0x8237;
pub const RG8UI: GLenum = 0x8238;
pub const RG8_SNORM: GLenum = 0x8F95;
pub const RGB: GLenum = 0x1907;
pub const RGB10_A2: GLenum = 0x8059;
pub const RGB10_A2UI: GLenum = 0x906F;
pub const RGB16F: GLenum = 0x881B;
pub const RGB16I: GLenum = 0x8D89;
pub const RGB16UI: GLenum = 0x8D77;
pub const RGB32F: GLenum = 0x8815;
pub const RGB32I: GLenum = 0x8D83;
pub const RGB32UI: GLenum = 0x8D71;
pub const RGB565: GLenum = 0x8D62;
pub const RGB5_A1: GLenum = 0x8057;
pub const RGB8: GLenum = 0x8051;
pub const RGB8I: GLenum = 0x8D8F;
pub const RGB8UI: GLenum = 0x8D7D;
pub const RGB8_SNORM: GLenum = 0x8F96;
pub const RGB9_E5: GLenum = 0x8C3D;
pub const RGBA: GLenum = 0x1908;
pub const RGBA16F: GLenum = 0x881A;
pub const RGBA16I: GLenum = 0x8D88;
pub const RGBA16UI: GLenum = 0x8D76;
pub const RGBA32F: GLenum = 0x8814;
pub const RGBA32I: GLenum = 0x8D82;
pub const RGBA32UI: GLenum = 0x8D70;
pub const RGBA4: GLenum = 0x8056;
pub const RGBA8: GLenum = 0x8058;
pub const RGBA8I: GLenum = 0x8D8E;
pub const RGBA8UI: GLenum = 0x8D7C;
pub const RGBA8_SNORM: GLenum = 0x8F97;
pub const RGBA_INTEGER: GLenum = 0x8D99;
pub const RGB_INTEGER: GLenum = 0x8D98;
pub const RG_INTEGER: GLenum = 0x8228;
pub const SAMPLER_2D: GLenum = 0x8B5E;
pub const SAMPLER_2D_ARRAY: GLenum = 0x8DC1;
pub const SAMPLER_2D_ARRAY_SHADOW: GLenum = 0x8DC4;
pub const SAMPLER_2D_SHADOW: GLenum = 0x8B62;
pub const SAMPLER_3D: GLenum = 0x8B5F;
pub const SAMPLER_BINDING: GLenum = 0x8919;
pub const SAMPLER_CUBE: GLenum = 0x8B60;
pub const SAMPLER_CUBE_SHADOW: GLenum = 0x8DC5;
pub const SAMPLES: GLenum = 0x80A9;
pub const SAMPLE_ALPHA_TO_COVERAGE: GLenum = 0x809E;
pub const SAMPLE_BUFFERS: GLenum = 0x80A8;
pub const SAMPLE_COVERAGE: GLenum = 0x80A0;
pub const SAMPLE_COVERAGE_INVERT: GLenum = 0x80AB;
pub const SAMPLE_COVERAGE_VALUE: GLenum = 0x80AA;
pub const SCISSOR_BOX: GLenum = 0x0C10;
pub const SCISSOR_TEST: GLenum = 0x0C11;
pub const SEPARATE_ATTRIBS: GLenum = 0x8C8D;
pub const SHADER_BINARY_FORMATS: GLenum = 0x8DF8;
pub const SHADER_COMPILER: GLenum = 0x8DFA;
pub const SHADER_SOURCE_LENGTH: GLenum = 0x8B88;
pub const SHADER_TYPE: GLenum = 0x8B4F;
pub const SHADING_LANGUAGE_VERSION: GLenum = 0x8B8C;
pub const SHORT: GLenum = 0x1402;
pub const SIGNALED: GLenum = 0x9119;
pub const SIGNED_NORMALIZED: GLenum = 0x8F9C;
pub const SRC_ALPHA: GLenum = 0x0302;
pub const SRC_ALPHA_SATURATE: GLenum = 0x0308;
pub const SRC_COLOR: GLenum = 0x0300;
pub const SRGB: GLenum = 0x8C40;
pub const SRGB8: GLenum = 0x8C41;
pub const SRGB8_ALPHA8: GLenum = 0x8C43;
pub const STATIC_COPY: GLenum = 0x88E6;
pub const STATIC_DRAW: GLenum = 0x88E4;
pub const STATIC_READ: GLenum = 0x88E5;
pub const STENCIL: GLenum = 0x1802;
pub const STENCIL_ATTACHMENT: GLenum = 0x8D20;
pub const STENCIL_BACK_FAIL: GLenum = 0x8801;
pub const STENCIL_BACK_FUNC: GLenum = 0x8800;
pub const STENCIL_BACK_PASS_DEPTH_FAIL: GLenum = 0x8802;
pub const STENCIL_BACK_PASS_DEPTH_PASS: GLenum = 0x8803;
pub const STENCIL_BACK_REF: GLenum = 0x8CA3;
pub const STENCIL_BACK_VALUE_MASK: GLenum = 0x8CA4;
pub const STENCIL_BACK_WRITEMASK: GLenum = 0x8CA5;
pub const STENCIL_BITS: GLenum = 0x0D57;
pub const STENCIL_BUFFER_BIT: GLenum = 0x00000400;
pub const STENCIL_CLEAR_VALUE: GLenum = 0x0B91;
pub const STENCIL_FAIL: GLenum = 0x0B94;
pub const STENCIL_FUNC: GLenum = 0x0B92;
pub const STENCIL_INDEX8: GLenum = 0x8D48;
pub const STENCIL_PASS_DEPTH_FAIL: GLenum = 0x0B95;
pub const STENCIL_PASS_DEPTH_PASS: GLenum = 0x0B96;
pub const STENCIL_REF: GLenum = 0x0B97;
pub const STENCIL_TEST: GLenum = 0x0B90;
pub const STENCIL_VALUE_MASK: GLenum = 0x0B93;
pub const STENCIL_WRITEMASK: GLenum = 0x0B98;
pub const STREAM_COPY: GLenum = 0x88E2;
pub const STREAM_DRAW: GLenum = 0x88E0;
pub const STREAM_READ: GLenum = 0x88E1;
pub const SUBPIXEL_BITS: GLenum = 0x0D50;
pub const SYNC_CONDITION: GLenum = 0x9113;
pub const SYNC_FENCE: GLenum = 0x9116;
pub const SYNC_FLAGS: GLenum = 0x9115;
pub const SYNC_FLUSH_COMMANDS_BIT: GLenum = 0x00000001;
pub const SYNC_GPU_COMMANDS_COMPLETE: GLenum = 0x9117;
pub const SYNC_STATUS: GLenum = 0x9114;
pub const TEXTURE: GLenum = 0x1702;
pub const TEXTURE0: GLenum = 0x84C0;
pub const TEXTURE1: GLenum = 0x84C1;
pub const TEXTURE10: GLenum = 0x84CA;
pub const TEXTURE11: GLenum = 0x84CB;
pub const TEXTURE12: GLenum = 0x84CC;
pub const TEXTURE13: GLenum = 0x84CD;
pub const TEXTURE14: GLenum = 0x84CE;
pub const TEXTURE15: GLenum = 0x84CF;
pub const TEXTURE16: GLenum = 0x84D0;
pub const TEXTURE17: GLenum = 0x84D1;
pub const TEXTURE18: GLenum = 0x84D2;
pub const TEXTURE19: GLenum = 0x84D3;
pub const TEXTURE2: GLenum = 0x84C2;
pub const TEXTURE20: GLenum = 0x84D4;
pub const TEXTURE21: GLenum = 0x84D5;
pub const TEXTURE22: GLenum = 0x84D6;
pub const TEXTURE23: GLenum = 0x84D7;
pub const TEXTURE24: GLenum = 0x84D8;
pub const TEXTURE25: GLenum = 0x84D9;
pub const TEXTURE26: GLenum = 0x84DA;
pub const TEXTURE27: GLenum = 0x84DB;
pub const TEXTURE28: GLenum = 0x84DC;
pub const TEXTURE29: GLenum = 0x84DD;
pub const TEXTURE3: GLenum = 0x84C3;
pub const TEXTURE30: GLenum = 0x84DE;
pub const TEXTURE31: GLenum = 0x84DF;
pub const TEXTURE4: GLenum = 0x84C4;
pub const TEXTURE5: GLenum = 0x84C5;
pub const TEXTURE6: GLenum = 0x84C6;
pub const TEXTURE7: GLenum = 0x84C7;
pub const TEXTURE8: GLenum = 0x84C8;
pub const TEXTURE9: GLenum = 0x84C9;
pub const TEXTURE_2D: GLenum = 0x0DE1;
pub const TEXTURE_2D_ARRAY: GLenum = 0x8C1A;
pub const TEXTURE_3D: GLenum = 0x806F;
pub const TEXTURE_BASE_LEVEL: GLenum = 0x813C;
pub const TEXTURE_BINDING_2D: GLenum = 0x8069;
pub const TEXTURE_BINDING_2D_ARRAY: GLenum = 0x8C1D;
pub const TEXTURE_BINDING_3D: GLenum = 0x806A;
pub const TEXTURE_BINDING_CUBE_MAP: GLenum = 0x8514;
pub const TEXTURE_COMPARE_FUNC: GLenum = 0x884D;
pub const TEXTURE_COMPARE_MODE: GLenum = 0x884C;
pub const TEXTURE_CUBE_MAP: GLenum = 0x8513;
pub const TEXTURE_CUBE_MAP_NEGATIVE_X: GLenum = 0x8516;
pub const TEXTURE_CUBE_MAP_NEGATIVE_Y: GLenum = 0x8518;
pub const TEXTURE_CUBE_MAP_NEGATIVE_Z: GLenum = 0x851A;
pub const TEXTURE_CUBE_MAP_POSITIVE_X: GLenum = 0x8515;
pub const TEXTURE_CUBE_MAP_POSITIVE_Y: GLenum = 0x8517;
pub const TEXTURE_CUBE_MAP_POSITIVE_Z: GLenum = 0x8519;
pub const TEXTURE_IMMUTABLE_FORMAT: GLenum = 0x912F;
pub const TEXTURE_IMMUTABLE_LEVELS: GLenum = 0x82DF;
pub const TEXTURE_MAG_FILTER: GLenum = 0x2800;
pub const TEXTURE_MAX_LEVEL: GLenum = 0x813D;
pub const TEXTURE_MAX_LOD: GLenum = 0x813B;
pub const TEXTURE_MIN_FILTER: GLenum = 0x2801;
pub const TEXTURE_MIN_LOD: GLenum = 0x813A;
pub const TEXTURE_SWIZZLE_A: GLenum = 0x8E45;
pub const TEXTURE_SWIZZLE_B: GLenum = 0x8E44;
pub const TEXTURE_SWIZZLE_G: GLenum = 0x8E43;
pub const TEXTURE_SWIZZLE_R: GLenum = 0x8E42;
pub const TEXTURE_WRAP_R: GLenum = 0x8072;
pub const TEXTURE_WRAP_S: GLenum = 0x2802;
pub const TEXTURE_WRAP_T: GLenum = 0x2803;
pub const TIMEOUT_EXPIRED: GLenum = 0x911B;
pub const TIMEOUT_IGNORED: GLuint64 = 0xFFFFFFFFFFFFFFFF;
pub const TRANSFORM_FEEDBACK: GLenum = 0x8E22;
pub const TRANSFORM_FEEDBACK_ACTIVE: GLenum = 0x8E24;
pub const TRANSFORM_FEEDBACK_BINDING: GLenum = 0x8E25;
pub const TRANSFORM_FEEDBACK_BUFFER: GLenum = 0x8C8E;
pub const TRANSFORM_FEEDBACK_BUFFER_BINDING: GLenum = 0x8C8F;
pub const TRANSFORM_FEEDBACK_BUFFER_MODE: GLenum = 0x8C7F;
pub const TRANSFORM_FEEDBACK_BUFFER_SIZE: GLenum = 0x8C85;
pub const TRANSFORM_FEEDBACK_BUFFER_START: GLenum = 0x8C84;
pub const TRANSFORM_FEEDBACK_PAUSED: GLenum = 0x8E23;
pub const TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN: GLenum = 0x8C88;
pub const TRANSFORM_FEEDBACK_VARYINGS: GLenum = 0x8C83;
pub const TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH: GLenum = 0x8C76;
pub const TRIANGLES: GLenum = 0x0004;
pub const TRIANGLE_FAN: GLenum = 0x0006;
pub const TRIANGLE_STRIP: GLenum = 0x0005;
pub const TRUE: GLboolean = 1;
pub const UNIFORM_ARRAY_STRIDE: GLenum = 0x8A3C;
pub const UNIFORM_BLOCK_ACTIVE_UNIFORMS: GLenum = 0x8A42;
pub const UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES: GLenum = 0x8A43;
pub const UNIFORM_BLOCK_BINDING: GLenum = 0x8A3F;
pub const UNIFORM_BLOCK_DATA_SIZE: GLenum = 0x8A40;
pub const UNIFORM_BLOCK_INDEX: GLenum = 0x8A3A;
pub const UNIFORM_BLOCK_NAME_LENGTH: GLenum = 0x8A41;
pub const UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER: GLenum = 0x8A46;
pub const UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER: GLenum = 0x8A44;
pub const UNIFORM_BUFFER: GLenum = 0x8A11;
pub const UNIFORM_BUFFER_BINDING: GLenum = 0x8A28;
pub const UNIFORM_BUFFER_OFFSET_ALIGNMENT: GLenum = 0x8A34;
pub const UNIFORM_BUFFER_SIZE: GLenum = 0x8A2A;
pub const UNIFORM_BUFFER_START: GLenum = 0x8A29;
pub const UNIFORM_IS_ROW_MAJOR: GLenum = 0x8A3E;
pub const UNIFORM_MATRIX_STRIDE: GLenum = 0x8A3D;
pub const UNIFORM_NAME_LENGTH: GLenum = 0x8A39;
pub const UNIFORM_OFFSET: GLenum = 0x8A3B;
pub const UNIFORM_SIZE: GLenum = 0x8A38;
pub const UNIFORM_TYPE: GLenum = 0x8A37;
pub const UNPACK_ALIGNMENT: GLenum = 0x0CF5;
pub const UNPACK_IMAGE_HEIGHT: GLenum = 0x806E;
pub const UNPACK_ROW_LENGTH: GLenum = 0x0CF2;
pub const UNPACK_SKIP_IMAGES: GLenum = 0x806D;
pub const UNPACK_SKIP_PIXELS: GLenum = 0x0CF4;
pub const UNPACK_SKIP_ROWS: GLenum = 0x0CF3;
pub const UNSIGNALED: GLenum = 0x9118;
pub const UNSIGNED_BYTE: GLenum = 0x1401;
pub const UNSIGNED_INT: GLenum = 0x1405;
pub const UNSIGNED_INT_10F_11F_11F_REV: GLenum = 0x8C3B;
pub const UNSIGNED_INT_24_8: GLenum = 0x84FA;
pub const UNSIGNED_INT_2_10_10_10_REV: GLenum = 0x8368;
pub const UNSIGNED_INT_5_9_9_9_REV: GLenum = 0x8C3E;
pub const UNSIGNED_INT_SAMPLER_2D: GLenum = 0x8DD2;
pub const UNSIGNED_INT_SAMPLER_2D_ARRAY: GLenum = 0x8DD7;
pub const UNSIGNED_INT_SAMPLER_3D: GLenum = 0x8DD3;
pub const UNSIGNED_INT_SAMPLER_CUBE: GLenum = 0x8DD4;
pub const UNSIGNED_INT_VEC2: GLenum = 0x8DC6;
pub const UNSIGNED_INT_VEC3: GLenum = 0x8DC7;
pub const UNSIGNED_INT_VEC4: GLenum = 0x8DC8;
pub const UNSIGNED_NORMALIZED: GLenum = 0x8C17;
pub const UNSIGNED_SHORT: GLenum = 0x1403;
pub const UNSIGNED_SHORT_4_4_4_4: GLenum = 0x8033;
pub const UNSIGNED_SHORT_5_5_5_1: GLenum = 0x8034;
pub const UNSIGNED_SHORT_5_6_5: GLenum = 0x8363;
pub const VALIDATE_STATUS: GLenum = 0x8B83;
pub const VENDOR: GLenum = 0x1F00;
pub const VERSION: GLenum = 0x1F02;
pub const VERTEX_ARRAY_BINDING: GLenum = 0x85B5;
pub const VERTEX_ATTRIB_ARRAY_BUFFER_BINDING: GLenum = 0x889F;
pub const VERTEX_ATTRIB_ARRAY_DIVISOR: GLenum = 0x88FE;
pub const VERTEX_ATTRIB_ARRAY_ENABLED: GLenum = 0x8622;
pub const VERTEX_ATTRIB_ARRAY_INTEGER: GLenum = 0x88FD;
pub const VERTEX_ATTRIB_ARRAY_NORMALIZED: GLenum = 0x886A;
pub const VERTEX_ATTRIB_ARRAY_POINTER: GLenum = 0x8645;
pub const VERTEX_ATTRIB_ARRAY_SIZE: GLenum = 0x8623;
pub const VERTEX_ATTRIB_ARRAY_STRIDE: GLenum = 0x8624;
pub const VERTEX_ATTRIB_ARRAY_TYPE: GLenum = 0x8625;
pub const VERTEX_SHADER: GLenum = 0x8B31;
pub const VIEWPORT: GLenum = 0x0BA2;
pub const WAIT_FAILED: GLenum = 0x911D;
pub const ZERO: GLenum = 0;
}
pub use functions::*;
pub mod functions {
use super::*;
#[inline]
pub unsafe fn ActiveTexture(texture: GLenum) {
trace!("ActiveTexture");
let p: *mut c_void = {
let temp_p = storage::ActiveTexture.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ActiveTexture")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(texture);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ActiveTexture({:?}): {}", texture, err);
}
}
out
}
#[inline]
pub unsafe fn AttachShader(program: GLuint, shader: GLuint) {
trace!("AttachShader");
let p: *mut c_void = {
let temp_p = storage::AttachShader.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("AttachShader")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLuint)>(p)(
program, shader,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("AttachShader({:?}, {:?}): {}", program, shader, err);
}
}
out
}
#[inline]
pub unsafe fn BeginQuery(target: GLenum, id: GLuint) {
trace!("BeginQuery");
let p: *mut c_void = {
let temp_p = storage::BeginQuery.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BeginQuery")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
target, id,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BeginQuery({:?}, {:?}): {}", target, id, err);
}
}
out
}
#[inline]
pub unsafe fn BeginTransformFeedback(primitiveMode: GLenum) {
trace!("BeginTransformFeedback");
let p: *mut c_void = {
let temp_p = storage::BeginTransformFeedback.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BeginTransformFeedback")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(primitiveMode);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BeginTransformFeedback({:?}): {}", primitiveMode, err);
}
}
out
}
#[inline]
pub unsafe fn BindAttribLocation(
program: GLuint,
index: GLuint,
name: *const GLchar,
) {
trace!("BindAttribLocation");
let p: *mut c_void = {
let temp_p = storage::BindAttribLocation.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindAttribLocation")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLuint, *const GLchar),
>(p)(program, index, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BindAttribLocation({:?}, {:?}, {:?}): {}",
program, index, name, err
);
}
}
out
}
#[inline]
pub unsafe fn BindBuffer(target: GLenum, buffer: GLuint) {
trace!("BindBuffer");
let p: *mut c_void = {
let temp_p = storage::BindBuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindBuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
target, buffer,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindBuffer({:?}, {:?}): {}", target, buffer, err);
}
}
out
}
#[inline]
pub unsafe fn BindBufferBase(target: GLenum, index: GLuint, buffer: GLuint) {
trace!("BindBufferBase");
let p: *mut c_void = {
let temp_p = storage::BindBufferBase.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindBufferBase")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLuint, GLuint),
>(p)(target, index, buffer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BindBufferBase({:?}, {:?}, {:?}): {}",
target, index, buffer, err
);
}
}
out
}
#[inline]
pub unsafe fn BindBufferRange(
target: GLenum,
index: GLuint,
buffer: GLuint,
offset: GLintptr,
size: GLsizeiptr,
) {
trace!("BindBufferRange");
let p: *mut c_void = {
let temp_p = storage::BindBufferRange.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindBufferRange")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLuint, GLuint, GLintptr, GLsizeiptr),
>(p)(target, index, buffer, offset, size);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BindBufferRange({:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, index, buffer, offset, size, err
);
}
}
out
}
#[inline]
pub unsafe fn BindFramebuffer(target: GLenum, framebuffer: GLuint) {
trace!("BindFramebuffer");
let p: *mut c_void = {
let temp_p = storage::BindFramebuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindFramebuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
target,
framebuffer,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindFramebuffer({:?}, {:?}): {}", target, framebuffer, err);
}
}
out
}
#[inline]
pub unsafe fn BindRenderbuffer(target: GLenum, renderbuffer: GLuint) {
trace!("BindRenderbuffer");
let p: *mut c_void = {
let temp_p = storage::BindRenderbuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindRenderbuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
target,
renderbuffer,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindRenderbuffer({:?}, {:?}): {}", target, renderbuffer, err);
}
}
out
}
#[inline]
pub unsafe fn BindSampler(unit: GLuint, sampler: GLuint) {
trace!("BindSampler");
let p: *mut c_void = {
let temp_p = storage::BindSampler.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindSampler")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLuint)>(p)(
unit, sampler,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindSampler({:?}, {:?}): {}", unit, sampler, err);
}
}
out
}
#[inline]
pub unsafe fn BindTexture(target: GLenum, texture: GLuint) {
trace!("BindTexture");
let p: *mut c_void = {
let temp_p = storage::BindTexture.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindTexture")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
target, texture,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindTexture({:?}, {:?}): {}", target, texture, err);
}
}
out
}
#[inline]
pub unsafe fn BindTransformFeedback(target: GLenum, id: GLuint) {
trace!("BindTransformFeedback");
let p: *mut c_void = {
let temp_p = storage::BindTransformFeedback.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindTransformFeedback")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
target, id,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindTransformFeedback({:?}, {:?}): {}", target, id, err);
}
}
out
}
#[inline]
pub unsafe fn BindVertexArray(array: GLuint) {
trace!("BindVertexArray");
let p: *mut c_void = {
let temp_p = storage::BindVertexArray.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BindVertexArray")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(array);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BindVertexArray({:?}): {}", array, err);
}
}
out
}
#[inline]
pub unsafe fn BlendColor(
red: GLfloat,
green: GLfloat,
blue: GLfloat,
alpha: GLfloat,
) {
trace!("BlendColor");
let p: *mut c_void = {
let temp_p = storage::BlendColor.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BlendColor")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLfloat, GLfloat, GLfloat, GLfloat),
>(p)(red, green, blue, alpha);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BlendColor({:?}, {:?}, {:?}, {:?}): {}",
red, green, blue, alpha, err
);
}
}
out
}
#[inline]
pub unsafe fn BlendEquation(mode: GLenum) {
trace!("BlendEquation");
let p: *mut c_void = {
let temp_p = storage::BlendEquation.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BlendEquation")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(mode);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BlendEquation({:?}): {}", mode, err);
}
}
out
}
#[inline]
pub unsafe fn BlendEquationSeparate(modeRGB: GLenum, modeAlpha: GLenum) {
trace!("BlendEquationSeparate");
let p: *mut c_void = {
let temp_p = storage::BlendEquationSeparate.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BlendEquationSeparate")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLenum)>(p)(
modeRGB, modeAlpha,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BlendEquationSeparate({:?}, {:?}): {}",
modeRGB, modeAlpha, err
);
}
}
out
}
#[inline]
pub unsafe fn BlendFunc(sfactor: GLenum, dfactor: GLenum) {
trace!("BlendFunc");
let p: *mut c_void = {
let temp_p = storage::BlendFunc.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BlendFunc")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLenum)>(p)(
sfactor, dfactor,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BlendFunc({:?}, {:?}): {}", sfactor, dfactor, err);
}
}
out
}
#[inline]
pub unsafe fn BlendFuncSeparate(
sfactorRGB: GLenum,
dfactorRGB: GLenum,
sfactorAlpha: GLenum,
dfactorAlpha: GLenum,
) {
trace!("BlendFuncSeparate");
let p: *mut c_void = {
let temp_p = storage::BlendFuncSeparate.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BlendFuncSeparate")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum, GLenum),
>(p)(sfactorRGB, dfactorRGB, sfactorAlpha, dfactorAlpha);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BlendFuncSeparate({:?}, {:?}, {:?}, {:?}): {}",
sfactorRGB, dfactorRGB, sfactorAlpha, dfactorAlpha, err
);
}
}
out
}
#[inline]
pub unsafe fn BlitFramebuffer(
srcX0: GLint,
srcY0: GLint,
srcX1: GLint,
srcY1: GLint,
dstX0: GLint,
dstY0: GLint,
dstX1: GLint,
dstY1: GLint,
mask: GLbitfield,
filter: GLenum,
) {
trace!("BlitFramebuffer");
let p: *mut c_void = {
let temp_p = storage::BlitFramebuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BlitFramebuffer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLint,
GLint,
GLint,
GLint,
GLint,
GLint,
GLint,
GLint,
GLbitfield,
GLenum,
),
>(p)(
srcX0, srcY0, srcX1, srcY1, dstX0, dstY0, dstX1, dstY1, mask, filter,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("BlitFramebuffer({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", srcX0, srcY0, srcX1, srcY1, dstX0, dstY0, dstX1, dstY1, mask, filter, err);
}
}
out
}
#[inline]
pub unsafe fn BufferData(
target: GLenum,
size: GLsizeiptr,
data: *const c_void,
usage: GLenum,
) {
trace!("BufferData");
let p: *mut c_void = {
let temp_p = storage::BufferData.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BufferData")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizeiptr, *const c_void, GLenum),
>(p)(target, size, data, usage);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BufferData({:?}, {:?}, {:?}, {:?}): {}",
target, size, data, usage, err
);
}
}
out
}
#[inline]
pub unsafe fn BufferSubData(
target: GLenum,
offset: GLintptr,
size: GLsizeiptr,
data: *const c_void,
) {
trace!("BufferSubData");
let p: *mut c_void = {
let temp_p = storage::BufferSubData.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("BufferSubData")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLintptr, GLsizeiptr, *const c_void),
>(p)(target, offset, size, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"BufferSubData({:?}, {:?}, {:?}, {:?}): {}",
target, offset, size, data, err
);
}
}
out
}
#[inline]
pub unsafe fn CheckFramebufferStatus(target: GLenum) -> GLenum {
trace!("CheckFramebufferStatus");
let p: *mut c_void = {
let temp_p = storage::CheckFramebufferStatus.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CheckFramebufferStatus")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLenum) -> GLenum>(p)(target);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CheckFramebufferStatus({:?}): {}", target, err);
}
}
out
}
#[inline]
pub unsafe fn Clear(mask: GLbitfield) {
trace!("Clear");
let p: *mut c_void = {
let temp_p = storage::Clear.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Clear")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLbitfield)>(p)(mask);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Clear({:?}): {}", mask, err);
}
}
out
}
#[inline]
pub unsafe fn ClearBufferfi(
buffer: GLenum,
drawbuffer: GLint,
depth: GLfloat,
stencil: GLint,
) {
trace!("ClearBufferfi");
let p: *mut c_void = {
let temp_p = storage::ClearBufferfi.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearBufferfi")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLint, GLfloat, GLint),
>(p)(buffer, drawbuffer, depth, stencil);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ClearBufferfi({:?}, {:?}, {:?}, {:?}): {}",
buffer, drawbuffer, depth, stencil, err
);
}
}
out
}
#[inline]
pub unsafe fn ClearBufferfv(
buffer: GLenum,
drawbuffer: GLint,
value: *const GLfloat,
) {
trace!("ClearBufferfv");
let p: *mut c_void = {
let temp_p = storage::ClearBufferfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearBufferfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLint, *const GLfloat),
>(p)(buffer, drawbuffer, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ClearBufferfv({:?}, {:?}, {:?}): {}",
buffer, drawbuffer, value, err
);
}
}
out
}
#[inline]
pub unsafe fn ClearBufferiv(
buffer: GLenum,
drawbuffer: GLint,
value: *const GLint,
) {
trace!("ClearBufferiv");
let p: *mut c_void = {
let temp_p = storage::ClearBufferiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearBufferiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLint, *const GLint),
>(p)(buffer, drawbuffer, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ClearBufferiv({:?}, {:?}, {:?}): {}",
buffer, drawbuffer, value, err
);
}
}
out
}
#[inline]
pub unsafe fn ClearBufferuiv(
buffer: GLenum,
drawbuffer: GLint,
value: *const GLuint,
) {
trace!("ClearBufferuiv");
let p: *mut c_void = {
let temp_p = storage::ClearBufferuiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearBufferuiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLint, *const GLuint),
>(p)(buffer, drawbuffer, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ClearBufferuiv({:?}, {:?}, {:?}): {}",
buffer, drawbuffer, value, err
);
}
}
out
}
#[inline]
pub unsafe fn ClearColor(
red: GLfloat,
green: GLfloat,
blue: GLfloat,
alpha: GLfloat,
) {
trace!("ClearColor");
let p: *mut c_void = {
let temp_p = storage::ClearColor.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearColor")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLfloat, GLfloat, GLfloat, GLfloat),
>(p)(red, green, blue, alpha);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ClearColor({:?}, {:?}, {:?}, {:?}): {}",
red, green, blue, alpha, err
);
}
}
out
}
#[inline]
pub unsafe fn ClearDepthf(d: GLfloat) {
trace!("ClearDepthf");
let p: *mut c_void = {
let temp_p = storage::ClearDepthf.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearDepthf")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLfloat)>(p)(d);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ClearDepthf({:?}): {}", d, err);
}
}
out
}
#[inline]
pub unsafe fn ClearStencil(s: GLint) {
trace!("ClearStencil");
let p: *mut c_void = {
let temp_p = storage::ClearStencil.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClearStencil")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLint)>(p)(s);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ClearStencil({:?}): {}", s, err);
}
}
out
}
#[inline]
pub unsafe fn ClientWaitSync(
sync: GLsync,
flags: GLbitfield,
timeout: GLuint64,
) -> GLenum {
trace!("ClientWaitSync");
let p: *mut c_void = {
let temp_p = storage::ClientWaitSync.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ClientWaitSync")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsync, GLbitfield, GLuint64) -> GLenum,
>(p)(sync, flags, timeout);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ClientWaitSync({:?}, {:?}, {:?}): {}",
sync, flags, timeout, err
);
}
}
out
}
#[inline]
pub unsafe fn ColorMask(
red: GLboolean,
green: GLboolean,
blue: GLboolean,
alpha: GLboolean,
) {
trace!("ColorMask");
let p: *mut c_void = {
let temp_p = storage::ColorMask.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ColorMask")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLboolean, GLboolean, GLboolean, GLboolean),
>(p)(red, green, blue, alpha);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ColorMask({:?}, {:?}, {:?}, {:?}): {}",
red, green, blue, alpha, err
);
}
}
out
}
#[inline]
pub unsafe fn CompileShader(shader: GLuint) {
trace!("CompileShader");
let p: *mut c_void = {
let temp_p = storage::CompileShader.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CompileShader")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(shader);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CompileShader({:?}): {}", shader, err);
}
}
out
}
#[inline]
pub unsafe fn CompressedTexImage2D(
target: GLenum,
level: GLint,
internalformat: GLenum,
width: GLsizei,
height: GLsizei,
border: GLint,
imageSize: GLsizei,
data: *const c_void,
) {
trace!("CompressedTexImage2D");
let p: *mut c_void = {
let temp_p = storage::CompressedTexImage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CompressedTexImage2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLenum,
GLsizei,
GLsizei,
GLint,
GLsizei,
*const c_void,
),
>(p)(
target,
level,
internalformat,
width,
height,
border,
imageSize,
data,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CompressedTexImage2D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, internalformat, width, height, border, imageSize, data, err);
}
}
out
}
#[inline]
pub unsafe fn CompressedTexImage3D(
target: GLenum,
level: GLint,
internalformat: GLenum,
width: GLsizei,
height: GLsizei,
depth: GLsizei,
border: GLint,
imageSize: GLsizei,
data: *const c_void,
) {
trace!("CompressedTexImage3D");
let p: *mut c_void = {
let temp_p = storage::CompressedTexImage3D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CompressedTexImage3D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLenum,
GLsizei,
GLsizei,
GLsizei,
GLint,
GLsizei,
*const c_void,
),
>(p)(
target,
level,
internalformat,
width,
height,
depth,
border,
imageSize,
data,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CompressedTexImage3D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, internalformat, width, height, depth, border, imageSize, data, err);
}
}
out
}
#[inline]
pub unsafe fn CompressedTexSubImage2D(
target: GLenum,
level: GLint,
xoffset: GLint,
yoffset: GLint,
width: GLsizei,
height: GLsizei,
format: GLenum,
imageSize: GLsizei,
data: *const c_void,
) {
trace!("CompressedTexSubImage2D");
let p: *mut c_void = {
let temp_p = storage::CompressedTexSubImage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CompressedTexSubImage2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLint,
GLsizei,
GLsizei,
GLenum,
GLsizei,
*const c_void,
),
>(p)(
target, level, xoffset, yoffset, width, height, format, imageSize, data,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CompressedTexSubImage2D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, xoffset, yoffset, width, height, format, imageSize, data, err);
}
}
out
}
#[inline]
pub unsafe fn CompressedTexSubImage3D(
target: GLenum,
level: GLint,
xoffset: GLint,
yoffset: GLint,
zoffset: GLint,
width: GLsizei,
height: GLsizei,
depth: GLsizei,
format: GLenum,
imageSize: GLsizei,
data: *const c_void,
) {
trace!("CompressedTexSubImage3D");
let p: *mut c_void = {
let temp_p = storage::CompressedTexSubImage3D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CompressedTexSubImage3D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLint,
GLint,
GLsizei,
GLsizei,
GLsizei,
GLenum,
GLsizei,
*const c_void,
),
>(p)(
target, level, xoffset, yoffset, zoffset, width, height, depth, format,
imageSize, data,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CompressedTexSubImage3D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, xoffset, yoffset, zoffset, width, height, depth, format, imageSize, data, err);
}
}
out
}
#[inline]
pub unsafe fn CopyBufferSubData(
readTarget: GLenum,
writeTarget: GLenum,
readOffset: GLintptr,
writeOffset: GLintptr,
size: GLsizeiptr,
) {
trace!("CopyBufferSubData");
let p: *mut c_void = {
let temp_p = storage::CopyBufferSubData.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CopyBufferSubData")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLintptr, GLintptr, GLsizeiptr),
>(p)(readTarget, writeTarget, readOffset, writeOffset, size);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"CopyBufferSubData({:?}, {:?}, {:?}, {:?}, {:?}): {}",
readTarget, writeTarget, readOffset, writeOffset, size, err
);
}
}
out
}
#[inline]
pub unsafe fn CopyTexImage2D(
target: GLenum,
level: GLint,
internalformat: GLenum,
x: GLint,
y: GLint,
width: GLsizei,
height: GLsizei,
border: GLint,
) {
trace!("CopyTexImage2D");
let p: *mut c_void = {
let temp_p = storage::CopyTexImage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CopyTexImage2D")
}
temp_p
};
let out =
transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLenum,
GLint,
GLint,
GLsizei,
GLsizei,
GLint,
),
>(p)(target, level, internalformat, x, y, width, height, border);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"CopyTexImage2D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, level, internalformat, x, y, width, height, border, err
);
}
}
out
}
#[inline]
pub unsafe fn CopyTexSubImage2D(
target: GLenum,
level: GLint,
xoffset: GLint,
yoffset: GLint,
x: GLint,
y: GLint,
width: GLsizei,
height: GLsizei,
) {
trace!("CopyTexSubImage2D");
let p: *mut c_void = {
let temp_p = storage::CopyTexSubImage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CopyTexSubImage2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLint,
GLint,
GLint,
GLsizei,
GLsizei,
),
>(p)(target, level, xoffset, yoffset, x, y, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CopyTexSubImage2D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, xoffset, yoffset, x, y, width, height, err);
}
}
out
}
#[inline]
pub unsafe fn CopyTexSubImage3D(
target: GLenum,
level: GLint,
xoffset: GLint,
yoffset: GLint,
zoffset: GLint,
x: GLint,
y: GLint,
width: GLsizei,
height: GLsizei,
) {
trace!("CopyTexSubImage3D");
let p: *mut c_void = {
let temp_p = storage::CopyTexSubImage3D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CopyTexSubImage3D")
}
temp_p
};
let out =
transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLint,
GLint,
GLint,
GLint,
GLsizei,
GLsizei,
),
>(p)(target, level, xoffset, yoffset, zoffset, x, y, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CopyTexSubImage3D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, xoffset, yoffset, zoffset, x, y, width, height, err);
}
}
out
}
#[inline]
pub unsafe fn CreateProgram() -> GLuint {
trace!("CreateProgram");
let p: *mut c_void = {
let temp_p = storage::CreateProgram.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CreateProgram")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn() -> GLuint>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CreateProgram(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn CreateShader(type_: GLenum) -> GLuint {
trace!("CreateShader");
let p: *mut c_void = {
let temp_p = storage::CreateShader.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CreateShader")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLenum) -> GLuint>(p)(type_);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CreateShader({:?}): {}", type_, err);
}
}
out
}
#[inline]
pub unsafe fn CullFace(mode: GLenum) {
trace!("CullFace");
let p: *mut c_void = {
let temp_p = storage::CullFace.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("CullFace")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(mode);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("CullFace({:?}): {}", mode, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteBuffers(n: GLsizei, buffers: *const GLuint) {
trace!("DeleteBuffers");
let p: *mut c_void = {
let temp_p = storage::DeleteBuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteBuffers")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, buffers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteBuffers({:?}, {:?}): {}", n, buffers, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteFramebuffers(n: GLsizei, framebuffers: *const GLuint) {
trace!("DeleteFramebuffers");
let p: *mut c_void = {
let temp_p = storage::DeleteFramebuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteFramebuffers")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, framebuffers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteFramebuffers({:?}, {:?}): {}", n, framebuffers, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteProgram(program: GLuint) {
trace!("DeleteProgram");
let p: *mut c_void = {
let temp_p = storage::DeleteProgram.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteProgram")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(program);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteProgram({:?}): {}", program, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteQueries(n: GLsizei, ids: *const GLuint) {
trace!("DeleteQueries");
let p: *mut c_void = {
let temp_p = storage::DeleteQueries.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteQueries")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, ids);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteQueries({:?}, {:?}): {}", n, ids, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteRenderbuffers(n: GLsizei, renderbuffers: *const GLuint) {
trace!("DeleteRenderbuffers");
let p: *mut c_void = {
let temp_p = storage::DeleteRenderbuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteRenderbuffers")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, renderbuffers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteRenderbuffers({:?}, {:?}): {}", n, renderbuffers, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteSamplers(count: GLsizei, samplers: *const GLuint) {
trace!("DeleteSamplers");
let p: *mut c_void = {
let temp_p = storage::DeleteSamplers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteSamplers")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(count, samplers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteSamplers({:?}, {:?}): {}", count, samplers, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteShader(shader: GLuint) {
trace!("DeleteShader");
let p: *mut c_void = {
let temp_p = storage::DeleteShader.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteShader")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(shader);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteShader({:?}): {}", shader, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteSync(sync: GLsync) {
trace!("DeleteSync");
let p: *mut c_void = {
let temp_p = storage::DeleteSync.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteSync")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsync)>(p)(sync);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteSync({:?}): {}", sync, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteTextures(n: GLsizei, textures: *const GLuint) {
trace!("DeleteTextures");
let p: *mut c_void = {
let temp_p = storage::DeleteTextures.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteTextures")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, textures);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteTextures({:?}, {:?}): {}", n, textures, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteTransformFeedbacks(n: GLsizei, ids: *const GLuint) {
trace!("DeleteTransformFeedbacks");
let p: *mut c_void = {
let temp_p = storage::DeleteTransformFeedbacks.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteTransformFeedbacks")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, ids);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteTransformFeedbacks({:?}, {:?}): {}", n, ids, err);
}
}
out
}
#[inline]
pub unsafe fn DeleteVertexArrays(n: GLsizei, arrays: *const GLuint) {
trace!("DeleteVertexArrays");
let p: *mut c_void = {
let temp_p = storage::DeleteVertexArrays.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DeleteVertexArrays")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLuint),
>(p)(n, arrays);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DeleteVertexArrays({:?}, {:?}): {}", n, arrays, err);
}
}
out
}
#[inline]
pub unsafe fn DepthFunc(func: GLenum) {
trace!("DepthFunc");
let p: *mut c_void = {
let temp_p = storage::DepthFunc.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DepthFunc")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(func);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DepthFunc({:?}): {}", func, err);
}
}
out
}
#[inline]
pub unsafe fn DepthMask(flag: GLboolean) {
trace!("DepthMask");
let p: *mut c_void = {
let temp_p = storage::DepthMask.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DepthMask")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLboolean)>(p)(flag);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DepthMask({:?}): {}", flag, err);
}
}
out
}
#[inline]
pub unsafe fn DepthRangef(n: GLfloat, f: GLfloat) {
trace!("DepthRangef");
let p: *mut c_void = {
let temp_p = storage::DepthRangef.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DepthRangef")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLfloat, GLfloat)>(p)(n, f);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DepthRangef({:?}, {:?}): {}", n, f, err);
}
}
out
}
#[inline]
pub unsafe fn DetachShader(program: GLuint, shader: GLuint) {
trace!("DetachShader");
let p: *mut c_void = {
let temp_p = storage::DetachShader.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DetachShader")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLuint)>(p)(
program, shader,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DetachShader({:?}, {:?}): {}", program, shader, err);
}
}
out
}
#[inline]
pub unsafe fn Disable(cap: GLenum) {
trace!("Disable");
let p: *mut c_void = {
let temp_p = storage::Disable.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Disable")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(cap);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Disable({:?}): {}", cap, err);
}
}
out
}
#[inline]
pub unsafe fn DisableVertexAttribArray(index: GLuint) {
trace!("DisableVertexAttribArray");
let p: *mut c_void = {
let temp_p = storage::DisableVertexAttribArray.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DisableVertexAttribArray")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(index);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DisableVertexAttribArray({:?}): {}", index, err);
}
}
out
}
#[inline]
pub unsafe fn DrawArrays(mode: GLenum, first: GLint, count: GLsizei) {
trace!("DrawArrays");
let p: *mut c_void = {
let temp_p = storage::DrawArrays.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DrawArrays")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLint, GLsizei),
>(p)(mode, first, count);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DrawArrays({:?}, {:?}, {:?}): {}", mode, first, count, err);
}
}
out
}
#[inline]
pub unsafe fn DrawArraysInstanced(
mode: GLenum,
first: GLint,
count: GLsizei,
instancecount: GLsizei,
) {
trace!("DrawArraysInstanced");
let p: *mut c_void = {
let temp_p = storage::DrawArraysInstanced.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DrawArraysInstanced")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLint, GLsizei, GLsizei),
>(p)(mode, first, count, instancecount);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"DrawArraysInstanced({:?}, {:?}, {:?}, {:?}): {}",
mode, first, count, instancecount, err
);
}
}
out
}
#[inline]
pub unsafe fn DrawBuffers(n: GLsizei, bufs: *const GLenum) {
trace!("DrawBuffers");
let p: *mut c_void = {
let temp_p = storage::DrawBuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DrawBuffers")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsizei, *const GLenum),
>(p)(n, bufs);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("DrawBuffers({:?}, {:?}): {}", n, bufs, err);
}
}
out
}
#[inline]
pub unsafe fn DrawElements(
mode: GLenum,
count: GLsizei,
type_: GLenum,
indices: *const c_void,
) {
trace!("DrawElements");
let p: *mut c_void = {
let temp_p = storage::DrawElements.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DrawElements")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizei, GLenum, *const c_void),
>(p)(mode, count, type_, indices);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"DrawElements({:?}, {:?}, {:?}, {:?}): {}",
mode, count, type_, indices, err
);
}
}
out
}
#[inline]
pub unsafe fn DrawElementsInstanced(
mode: GLenum,
count: GLsizei,
type_: GLenum,
indices: *const c_void,
instancecount: GLsizei,
) {
trace!("DrawElementsInstanced");
let p: *mut c_void = {
let temp_p = storage::DrawElementsInstanced.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DrawElementsInstanced")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizei, GLenum, *const c_void, GLsizei),
>(p)(mode, count, type_, indices, instancecount);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"DrawElementsInstanced({:?}, {:?}, {:?}, {:?}, {:?}): {}",
mode, count, type_, indices, instancecount, err
);
}
}
out
}
#[inline]
pub unsafe fn DrawRangeElements(
mode: GLenum,
start: GLuint,
end: GLuint,
count: GLsizei,
type_: GLenum,
indices: *const c_void,
) {
trace!("DrawRangeElements");
let p: *mut c_void = {
let temp_p = storage::DrawRangeElements.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("DrawRangeElements")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLuint,
GLuint,
GLsizei,
GLenum,
*const c_void,
),
>(p)(mode, start, end, count, type_, indices);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"DrawRangeElements({:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
mode, start, end, count, type_, indices, err
);
}
}
out
}
#[inline]
pub unsafe fn Enable(cap: GLenum) {
trace!("Enable");
let p: *mut c_void = {
let temp_p = storage::Enable.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Enable")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(cap);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Enable({:?}): {}", cap, err);
}
}
out
}
#[inline]
pub unsafe fn EnableVertexAttribArray(index: GLuint) {
trace!("EnableVertexAttribArray");
let p: *mut c_void = {
let temp_p = storage::EnableVertexAttribArray.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("EnableVertexAttribArray")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(index);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("EnableVertexAttribArray({:?}): {}", index, err);
}
}
out
}
#[inline]
pub unsafe fn EndQuery(target: GLenum) {
trace!("EndQuery");
let p: *mut c_void = {
let temp_p = storage::EndQuery.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("EndQuery")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(target);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("EndQuery({:?}): {}", target, err);
}
}
out
}
#[inline]
pub unsafe fn EndTransformFeedback() {
trace!("EndTransformFeedback");
let p: *mut c_void = {
let temp_p = storage::EndTransformFeedback.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("EndTransformFeedback")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn()>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("EndTransformFeedback(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn FenceSync(condition: GLenum, flags: GLbitfield) -> GLsync {
trace!("FenceSync");
let p: *mut c_void = {
let temp_p = storage::FenceSync.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("FenceSync")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLbitfield) -> GLsync,
>(p)(condition, flags);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("FenceSync({:?}, {:?}): {}", condition, flags, err);
}
}
out
}
#[inline]
pub unsafe fn Finish() {
trace!("Finish");
let p: *mut c_void = {
let temp_p = storage::Finish.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Finish")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn()>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Finish(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn Flush() {
trace!("Flush");
let p: *mut c_void = {
let temp_p = storage::Flush.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Flush")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn()>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Flush(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn FlushMappedBufferRange(
target: GLenum,
offset: GLintptr,
length: GLsizeiptr,
) {
trace!("FlushMappedBufferRange");
let p: *mut c_void = {
let temp_p = storage::FlushMappedBufferRange.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("FlushMappedBufferRange")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLintptr, GLsizeiptr),
>(p)(target, offset, length);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"FlushMappedBufferRange({:?}, {:?}, {:?}): {}",
target, offset, length, err
);
}
}
out
}
#[inline]
pub unsafe fn FramebufferRenderbuffer(
target: GLenum,
attachment: GLenum,
renderbuffertarget: GLenum,
renderbuffer: GLuint,
) {
trace!("FramebufferRenderbuffer");
let p: *mut c_void = {
let temp_p = storage::FramebufferRenderbuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("FramebufferRenderbuffer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum, GLuint),
>(p)(target, attachment, renderbuffertarget, renderbuffer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"FramebufferRenderbuffer({:?}, {:?}, {:?}, {:?}): {}",
target, attachment, renderbuffertarget, renderbuffer, err
);
}
}
out
}
#[inline]
pub unsafe fn FramebufferTexture2D(
target: GLenum,
attachment: GLenum,
textarget: GLenum,
texture: GLuint,
level: GLint,
) {
trace!("FramebufferTexture2D");
let p: *mut c_void = {
let temp_p = storage::FramebufferTexture2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("FramebufferTexture2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum, GLuint, GLint),
>(p)(target, attachment, textarget, texture, level);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"FramebufferTexture2D({:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, attachment, textarget, texture, level, err
);
}
}
out
}
#[inline]
pub unsafe fn FramebufferTextureLayer(
target: GLenum,
attachment: GLenum,
texture: GLuint,
level: GLint,
layer: GLint,
) {
trace!("FramebufferTextureLayer");
let p: *mut c_void = {
let temp_p = storage::FramebufferTextureLayer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("FramebufferTextureLayer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLuint, GLint, GLint),
>(p)(target, attachment, texture, level, layer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"FramebufferTextureLayer({:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, attachment, texture, level, layer, err
);
}
}
out
}
#[inline]
pub unsafe fn FrontFace(mode: GLenum) {
trace!("FrontFace");
let p: *mut c_void = {
let temp_p = storage::FrontFace.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("FrontFace")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(mode);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("FrontFace({:?}): {}", mode, err);
}
}
out
}
#[inline]
pub unsafe fn GenBuffers(n: GLsizei, buffers: *mut GLuint) {
trace!("GenBuffers");
let p: *mut c_void = {
let temp_p = storage::GenBuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenBuffers")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, buffers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenBuffers({:?}, {:?}): {}", n, buffers, err);
}
}
out
}
#[inline]
pub unsafe fn GenFramebuffers(n: GLsizei, framebuffers: *mut GLuint) {
trace!("GenFramebuffers");
let p: *mut c_void = {
let temp_p = storage::GenFramebuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenFramebuffers")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, framebuffers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenFramebuffers({:?}, {:?}): {}", n, framebuffers, err);
}
}
out
}
#[inline]
pub unsafe fn GenQueries(n: GLsizei, ids: *mut GLuint) {
trace!("GenQueries");
let p: *mut c_void = {
let temp_p = storage::GenQueries.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenQueries")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, ids);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenQueries({:?}, {:?}): {}", n, ids, err);
}
}
out
}
#[inline]
pub unsafe fn GenRenderbuffers(n: GLsizei, renderbuffers: *mut GLuint) {
trace!("GenRenderbuffers");
let p: *mut c_void = {
let temp_p = storage::GenRenderbuffers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenRenderbuffers")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, renderbuffers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenRenderbuffers({:?}, {:?}): {}", n, renderbuffers, err);
}
}
out
}
#[inline]
pub unsafe fn GenSamplers(count: GLsizei, samplers: *mut GLuint) {
trace!("GenSamplers");
let p: *mut c_void = {
let temp_p = storage::GenSamplers.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenSamplers")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(count, samplers);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenSamplers({:?}, {:?}): {}", count, samplers, err);
}
}
out
}
#[inline]
pub unsafe fn GenTextures(n: GLsizei, textures: *mut GLuint) {
trace!("GenTextures");
let p: *mut c_void = {
let temp_p = storage::GenTextures.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenTextures")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, textures);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenTextures({:?}, {:?}): {}", n, textures, err);
}
}
out
}
#[inline]
pub unsafe fn GenTransformFeedbacks(n: GLsizei, ids: *mut GLuint) {
trace!("GenTransformFeedbacks");
let p: *mut c_void = {
let temp_p = storage::GenTransformFeedbacks.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenTransformFeedbacks")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, ids);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenTransformFeedbacks({:?}, {:?}): {}", n, ids, err);
}
}
out
}
#[inline]
pub unsafe fn GenVertexArrays(n: GLsizei, arrays: *mut GLuint) {
trace!("GenVertexArrays");
let p: *mut c_void = {
let temp_p = storage::GenVertexArrays.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenVertexArrays")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsizei, *mut GLuint)>(
p,
)(n, arrays);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenVertexArrays({:?}, {:?}): {}", n, arrays, err);
}
}
out
}
#[inline]
pub unsafe fn GenerateMipmap(target: GLenum) {
trace!("GenerateMipmap");
let p: *mut c_void = {
let temp_p = storage::GenerateMipmap.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GenerateMipmap")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(target);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GenerateMipmap({:?}): {}", target, err);
}
}
out
}
#[inline]
pub unsafe fn GetActiveAttrib(
program: GLuint,
index: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
size: *mut GLint,
type_: *mut GLenum,
name: *mut GLchar,
) {
trace!("GetActiveAttrib");
let p: *mut c_void = {
let temp_p = storage::GetActiveAttrib.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetActiveAttrib")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLuint,
GLuint,
GLsizei,
*mut GLsizei,
*mut GLint,
*mut GLenum,
*mut GLchar,
),
>(p)(program, index, bufSize, length, size, type_, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetActiveAttrib({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
program, index, bufSize, length, size, type_, name, err
);
}
}
out
}
#[inline]
pub unsafe fn GetActiveUniform(
program: GLuint,
index: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
size: *mut GLint,
type_: *mut GLenum,
name: *mut GLchar,
) {
trace!("GetActiveUniform");
let p: *mut c_void = {
let temp_p = storage::GetActiveUniform.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetActiveUniform")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLuint,
GLuint,
GLsizei,
*mut GLsizei,
*mut GLint,
*mut GLenum,
*mut GLchar,
),
>(p)(program, index, bufSize, length, size, type_, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetActiveUniform({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
program, index, bufSize, length, size, type_, name, err
);
}
}
out
}
#[inline]
pub unsafe fn GetActiveUniformBlockName(
program: GLuint,
uniformBlockIndex: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
uniformBlockName: *mut GLchar,
) {
trace!("GetActiveUniformBlockName");
let p: *mut c_void = {
let temp_p = storage::GetActiveUniformBlockName.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetActiveUniformBlockName")
}
temp_p
};
let out =
transmute::<
*mut c_void,
extern "system" fn(GLuint, GLuint, GLsizei, *mut GLsizei, *mut GLchar),
>(p)(program, uniformBlockIndex, bufSize, length, uniformBlockName);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetActiveUniformBlockName({:?}, {:?}, {:?}, {:?}, {:?}): {}",
program, uniformBlockIndex, bufSize, length, uniformBlockName, err
);
}
}
out
}
#[inline]
pub unsafe fn GetActiveUniformBlockiv(
program: GLuint,
uniformBlockIndex: GLuint,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetActiveUniformBlockiv");
let p: *mut c_void = {
let temp_p = storage::GetActiveUniformBlockiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetActiveUniformBlockiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLuint, GLenum, *mut GLint),
>(p)(program, uniformBlockIndex, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetActiveUniformBlockiv({:?}, {:?}, {:?}, {:?}): {}",
program, uniformBlockIndex, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetActiveUniformsiv(
program: GLuint,
uniformCount: GLsizei,
uniformIndices: *const GLuint,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetActiveUniformsiv");
let p: *mut c_void = {
let temp_p = storage::GetActiveUniformsiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetActiveUniformsiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *const GLuint, GLenum, *mut GLint),
>(p)(program, uniformCount, uniformIndices, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetActiveUniformsiv({:?}, {:?}, {:?}, {:?}, {:?}): {}",
program, uniformCount, uniformIndices, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetAttachedShaders(
program: GLuint,
maxCount: GLsizei,
count: *mut GLsizei,
shaders: *mut GLuint,
) {
trace!("GetAttachedShaders");
let p: *mut c_void = {
let temp_p = storage::GetAttachedShaders.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetAttachedShaders")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *mut GLsizei, *mut GLuint),
>(p)(program, maxCount, count, shaders);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetAttachedShaders({:?}, {:?}, {:?}, {:?}): {}",
program, maxCount, count, shaders, err
);
}
}
out
}
#[inline]
pub unsafe fn GetAttribLocation(
program: GLuint,
name: *const GLchar,
) -> GLint {
trace!("GetAttribLocation");
let p: *mut c_void = {
let temp_p = storage::GetAttribLocation.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetAttribLocation")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLchar) -> GLint,
>(p)(program, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetAttribLocation({:?}, {:?}): {}", program, name, err);
}
}
out
}
#[inline]
pub unsafe fn GetBooleanv(pname: GLenum, data: *mut GLboolean) {
trace!("GetBooleanv");
let p: *mut c_void = {
let temp_p = storage::GetBooleanv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetBooleanv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, *mut GLboolean),
>(p)(pname, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetBooleanv({:?}, {:?}): {}", pname, data, err);
}
}
out
}
#[inline]
pub unsafe fn GetBufferParameteri64v(
target: GLenum,
pname: GLenum,
params: *mut GLint64,
) {
trace!("GetBufferParameteri64v");
let p: *mut c_void = {
let temp_p = storage::GetBufferParameteri64v.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetBufferParameteri64v")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLint64),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetBufferParameteri64v({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetBufferParameteriv(
target: GLenum,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetBufferParameteriv");
let p: *mut c_void = {
let temp_p = storage::GetBufferParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetBufferParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLint),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetBufferParameteriv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetBufferPointerv(
target: GLenum,
pname: GLenum,
params: *const *mut c_void,
) {
trace!("GetBufferPointerv");
let p: *mut c_void = {
let temp_p = storage::GetBufferPointerv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetBufferPointerv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *const *mut c_void),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetBufferPointerv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetError() -> GLenum {
trace!("GetError");
let p: *mut c_void = {
let temp_p = storage::GetError.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetError")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn() -> GLenum>(p)();
out
}
#[inline]
pub unsafe fn GetFloatv(pname: GLenum, data: *mut GLfloat) {
trace!("GetFloatv");
let p: *mut c_void = {
let temp_p = storage::GetFloatv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetFloatv")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, *mut GLfloat)>(
p,
)(pname, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetFloatv({:?}, {:?}): {}", pname, data, err);
}
}
out
}
#[inline]
pub unsafe fn GetFragDataLocation(
program: GLuint,
name: *const GLchar,
) -> GLint {
trace!("GetFragDataLocation");
let p: *mut c_void = {
let temp_p = storage::GetFragDataLocation.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetFragDataLocation")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLchar) -> GLint,
>(p)(program, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetFragDataLocation({:?}, {:?}): {}", program, name, err);
}
}
out
}
#[inline]
pub unsafe fn GetFramebufferAttachmentParameteriv(
target: GLenum,
attachment: GLenum,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetFramebufferAttachmentParameteriv");
let p: *mut c_void = {
let temp_p =
storage::GetFramebufferAttachmentParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetFramebufferAttachmentParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum, *mut GLint),
>(p)(target, attachment, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetFramebufferAttachmentParameteriv({:?}, {:?}, {:?}, {:?}): {}",
target, attachment, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetInteger64i_v(
target: GLenum,
index: GLuint,
data: *mut GLint64,
) {
trace!("GetInteger64i_v");
let p: *mut c_void = {
let temp_p = storage::GetInteger64i_v.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetInteger64i_v")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLuint, *mut GLint64),
>(p)(target, index, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetInteger64i_v({:?}, {:?}, {:?}): {}",
target, index, data, err
);
}
}
out
}
#[inline]
pub unsafe fn GetInteger64v(pname: GLenum, data: *mut GLint64) {
trace!("GetInteger64v");
let p: *mut c_void = {
let temp_p = storage::GetInteger64v.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetInteger64v")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, *mut GLint64)>(
p,
)(pname, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetInteger64v({:?}, {:?}): {}", pname, data, err);
}
}
out
}
#[inline]
pub unsafe fn GetIntegeri_v(target: GLenum, index: GLuint, data: *mut GLint) {
trace!("GetIntegeri_v");
let p: *mut c_void = {
let temp_p = storage::GetIntegeri_v.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetIntegeri_v")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLuint, *mut GLint),
>(p)(target, index, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetIntegeri_v({:?}, {:?}, {:?}): {}", target, index, data, err);
}
}
out
}
#[inline]
pub unsafe fn GetIntegerv(pname: GLenum, data: *mut GLint) {
trace!("GetIntegerv");
let p: *mut c_void = {
let temp_p = storage::GetIntegerv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetIntegerv")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, *mut GLint)>(
p,
)(pname, data);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetIntegerv({:?}, {:?}): {}", pname, data, err);
}
}
out
}
#[inline]
pub unsafe fn GetInternalformativ(
target: GLenum,
internalformat: GLenum,
pname: GLenum,
bufSize: GLsizei,
params: *mut GLint,
) {
trace!("GetInternalformativ");
let p: *mut c_void = {
let temp_p = storage::GetInternalformativ.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetInternalformativ")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum, GLsizei, *mut GLint),
>(p)(target, internalformat, pname, bufSize, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetInternalformativ({:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, internalformat, pname, bufSize, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetProgramBinary(
program: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
binaryFormat: *mut GLenum,
binary: *mut c_void,
) {
trace!("GetProgramBinary");
let p: *mut c_void = {
let temp_p = storage::GetProgramBinary.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetProgramBinary")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLuint,
GLsizei,
*mut GLsizei,
*mut GLenum,
*mut c_void,
),
>(p)(program, bufSize, length, binaryFormat, binary);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetProgramBinary({:?}, {:?}, {:?}, {:?}, {:?}): {}",
program, bufSize, length, binaryFormat, binary, err
);
}
}
out
}
#[inline]
pub unsafe fn GetProgramInfoLog(
program: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
infoLog: *mut GLchar,
) {
trace!("GetProgramInfoLog");
let p: *mut c_void = {
let temp_p = storage::GetProgramInfoLog.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetProgramInfoLog")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *mut GLsizei, *mut GLchar),
>(p)(program, bufSize, length, infoLog);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetProgramInfoLog({:?}, {:?}, {:?}, {:?}): {}",
program, bufSize, length, infoLog, err
);
}
}
out
}
#[inline]
pub unsafe fn GetProgramiv(
program: GLuint,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetProgramiv");
let p: *mut c_void = {
let temp_p = storage::GetProgramiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetProgramiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLint),
>(p)(program, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetProgramiv({:?}, {:?}, {:?}): {}",
program, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetQueryObjectuiv(
id: GLuint,
pname: GLenum,
params: *mut GLuint,
) {
trace!("GetQueryObjectuiv");
let p: *mut c_void = {
let temp_p = storage::GetQueryObjectuiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetQueryObjectuiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLuint),
>(p)(id, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetQueryObjectuiv({:?}, {:?}, {:?}): {}",
id, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetQueryiv(target: GLenum, pname: GLenum, params: *mut GLint) {
trace!("GetQueryiv");
let p: *mut c_void = {
let temp_p = storage::GetQueryiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetQueryiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLint),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetQueryiv({:?}, {:?}, {:?}): {}", target, pname, params, err);
}
}
out
}
#[inline]
pub unsafe fn GetRenderbufferParameteriv(
target: GLenum,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetRenderbufferParameteriv");
let p: *mut c_void = {
let temp_p = storage::GetRenderbufferParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetRenderbufferParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLint),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetRenderbufferParameteriv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetSamplerParameterfv(
sampler: GLuint,
pname: GLenum,
params: *mut GLfloat,
) {
trace!("GetSamplerParameterfv");
let p: *mut c_void = {
let temp_p = storage::GetSamplerParameterfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetSamplerParameterfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLfloat),
>(p)(sampler, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetSamplerParameterfv({:?}, {:?}, {:?}): {}",
sampler, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetSamplerParameteriv(
sampler: GLuint,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetSamplerParameteriv");
let p: *mut c_void = {
let temp_p = storage::GetSamplerParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetSamplerParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLint),
>(p)(sampler, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetSamplerParameteriv({:?}, {:?}, {:?}): {}",
sampler, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetShaderInfoLog(
shader: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
infoLog: *mut GLchar,
) {
trace!("GetShaderInfoLog");
let p: *mut c_void = {
let temp_p = storage::GetShaderInfoLog.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetShaderInfoLog")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *mut GLsizei, *mut GLchar),
>(p)(shader, bufSize, length, infoLog);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetShaderInfoLog({:?}, {:?}, {:?}, {:?}): {}",
shader, bufSize, length, infoLog, err
);
}
}
out
}
#[inline]
pub unsafe fn GetShaderPrecisionFormat(
shadertype: GLenum,
precisiontype: GLenum,
range: *mut GLint,
precision: *mut GLint,
) {
trace!("GetShaderPrecisionFormat");
let p: *mut c_void = {
let temp_p = storage::GetShaderPrecisionFormat.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetShaderPrecisionFormat")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLint, *mut GLint),
>(p)(shadertype, precisiontype, range, precision);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetShaderPrecisionFormat({:?}, {:?}, {:?}, {:?}): {}",
shadertype, precisiontype, range, precision, err
);
}
}
out
}
#[inline]
pub unsafe fn GetShaderSource(
shader: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
source: *mut GLchar,
) {
trace!("GetShaderSource");
let p: *mut c_void = {
let temp_p = storage::GetShaderSource.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetShaderSource")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *mut GLsizei, *mut GLchar),
>(p)(shader, bufSize, length, source);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetShaderSource({:?}, {:?}, {:?}, {:?}): {}",
shader, bufSize, length, source, err
);
}
}
out
}
#[inline]
pub unsafe fn GetShaderiv(shader: GLuint, pname: GLenum, params: *mut GLint) {
trace!("GetShaderiv");
let p: *mut c_void = {
let temp_p = storage::GetShaderiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetShaderiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLint),
>(p)(shader, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetShaderiv({:?}, {:?}, {:?}): {}", shader, pname, params, err);
}
}
out
}
#[inline]
pub unsafe fn GetString(name: GLenum) -> *const GLubyte {
trace!("GetString");
let p: *mut c_void = {
let temp_p = storage::GetString.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetString")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum) -> *const GLubyte,
>(p)(name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetString({:?}): {}", name, err);
}
}
out
}
#[inline]
pub unsafe fn GetStringi(name: GLenum, index: GLuint) -> *const GLubyte {
trace!("GetStringi");
let p: *mut c_void = {
let temp_p = storage::GetStringi.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetStringi")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLuint) -> *const GLubyte,
>(p)(name, index);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetStringi({:?}, {:?}): {}", name, index, err);
}
}
out
}
#[inline]
pub unsafe fn GetSynciv(
sync: GLsync,
pname: GLenum,
bufSize: GLsizei,
length: *mut GLsizei,
values: *mut GLint,
) {
trace!("GetSynciv");
let p: *mut c_void = {
let temp_p = storage::GetSynciv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetSynciv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsync, GLenum, GLsizei, *mut GLsizei, *mut GLint),
>(p)(sync, pname, bufSize, length, values);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetSynciv({:?}, {:?}, {:?}, {:?}, {:?}): {}",
sync, pname, bufSize, length, values, err
);
}
}
out
}
#[inline]
pub unsafe fn GetTexParameterfv(
target: GLenum,
pname: GLenum,
params: *mut GLfloat,
) {
trace!("GetTexParameterfv");
let p: *mut c_void = {
let temp_p = storage::GetTexParameterfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetTexParameterfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLfloat),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetTexParameterfv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetTexParameteriv(
target: GLenum,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetTexParameteriv");
let p: *mut c_void = {
let temp_p = storage::GetTexParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetTexParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *mut GLint),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetTexParameteriv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetTransformFeedbackVarying(
program: GLuint,
index: GLuint,
bufSize: GLsizei,
length: *mut GLsizei,
size: *mut GLsizei,
type_: *mut GLenum,
name: *mut GLchar,
) {
trace!("GetTransformFeedbackVarying");
let p: *mut c_void = {
let temp_p = storage::GetTransformFeedbackVarying.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetTransformFeedbackVarying")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLuint,
GLuint,
GLsizei,
*mut GLsizei,
*mut GLsizei,
*mut GLenum,
*mut GLchar,
),
>(p)(program, index, bufSize, length, size, type_, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetTransformFeedbackVarying({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", program, index, bufSize, length, size, type_, name, err);
}
}
out
}
#[inline]
pub unsafe fn GetUniformBlockIndex(
program: GLuint,
uniformBlockName: *const GLchar,
) -> GLuint {
trace!("GetUniformBlockIndex");
let p: *mut c_void = {
let temp_p = storage::GetUniformBlockIndex.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetUniformBlockIndex")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLchar) -> GLuint,
>(p)(program, uniformBlockName);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetUniformBlockIndex({:?}, {:?}): {}",
program, uniformBlockName, err
);
}
}
out
}
#[inline]
pub unsafe fn GetUniformIndices(
program: GLuint,
uniformCount: GLsizei,
uniformNames: *const *const GLchar,
uniformIndices: *mut GLuint,
) {
trace!("GetUniformIndices");
let p: *mut c_void = {
let temp_p = storage::GetUniformIndices.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetUniformIndices")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *const *const GLchar, *mut GLuint),
>(p)(program, uniformCount, uniformNames, uniformIndices);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetUniformIndices({:?}, {:?}, {:?}, {:?}): {}",
program, uniformCount, uniformNames, uniformIndices, err
);
}
}
out
}
#[inline]
pub unsafe fn GetUniformLocation(
program: GLuint,
name: *const GLchar,
) -> GLint {
trace!("GetUniformLocation");
let p: *mut c_void = {
let temp_p = storage::GetUniformLocation.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetUniformLocation")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLchar) -> GLint,
>(p)(program, name);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("GetUniformLocation({:?}, {:?}): {}", program, name, err);
}
}
out
}
#[inline]
pub unsafe fn GetUniformfv(
program: GLuint,
location: GLint,
params: *mut GLfloat,
) {
trace!("GetUniformfv");
let p: *mut c_void = {
let temp_p = storage::GetUniformfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetUniformfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLint, *mut GLfloat),
>(p)(program, location, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetUniformfv({:?}, {:?}, {:?}): {}",
program, location, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetUniformiv(
program: GLuint,
location: GLint,
params: *mut GLint,
) {
trace!("GetUniformiv");
let p: *mut c_void = {
let temp_p = storage::GetUniformiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetUniformiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLint, *mut GLint),
>(p)(program, location, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetUniformiv({:?}, {:?}, {:?}): {}",
program, location, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetUniformuiv(
program: GLuint,
location: GLint,
params: *mut GLuint,
) {
trace!("GetUniformuiv");
let p: *mut c_void = {
let temp_p = storage::GetUniformuiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetUniformuiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLint, *mut GLuint),
>(p)(program, location, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetUniformuiv({:?}, {:?}, {:?}): {}",
program, location, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetVertexAttribIiv(
index: GLuint,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetVertexAttribIiv");
let p: *mut c_void = {
let temp_p = storage::GetVertexAttribIiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetVertexAttribIiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLint),
>(p)(index, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetVertexAttribIiv({:?}, {:?}, {:?}): {}",
index, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetVertexAttribIuiv(
index: GLuint,
pname: GLenum,
params: *mut GLuint,
) {
trace!("GetVertexAttribIuiv");
let p: *mut c_void = {
let temp_p = storage::GetVertexAttribIuiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetVertexAttribIuiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLuint),
>(p)(index, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetVertexAttribIuiv({:?}, {:?}, {:?}): {}",
index, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetVertexAttribPointerv(
index: GLuint,
pname: GLenum,
pointer: *const *mut c_void,
) {
trace!("GetVertexAttribPointerv");
let p: *mut c_void = {
let temp_p = storage::GetVertexAttribPointerv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetVertexAttribPointerv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *const *mut c_void),
>(p)(index, pname, pointer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetVertexAttribPointerv({:?}, {:?}, {:?}): {}",
index, pname, pointer, err
);
}
}
out
}
#[inline]
pub unsafe fn GetVertexAttribfv(
index: GLuint,
pname: GLenum,
params: *mut GLfloat,
) {
trace!("GetVertexAttribfv");
let p: *mut c_void = {
let temp_p = storage::GetVertexAttribfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetVertexAttribfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLfloat),
>(p)(index, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetVertexAttribfv({:?}, {:?}, {:?}): {}",
index, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn GetVertexAttribiv(
index: GLuint,
pname: GLenum,
params: *mut GLint,
) {
trace!("GetVertexAttribiv");
let p: *mut c_void = {
let temp_p = storage::GetVertexAttribiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("GetVertexAttribiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *mut GLint),
>(p)(index, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"GetVertexAttribiv({:?}, {:?}, {:?}): {}",
index, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn Hint(target: GLenum, mode: GLenum) {
trace!("Hint");
let p: *mut c_void = {
let temp_p = storage::Hint.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Hint")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLenum)>(p)(
target, mode,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Hint({:?}, {:?}): {}", target, mode, err);
}
}
out
}
#[inline]
pub unsafe fn InvalidateFramebuffer(
target: GLenum,
numAttachments: GLsizei,
attachments: *const GLenum,
) {
trace!("InvalidateFramebuffer");
let p: *mut c_void = {
let temp_p = storage::InvalidateFramebuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("InvalidateFramebuffer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizei, *const GLenum),
>(p)(target, numAttachments, attachments);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"InvalidateFramebuffer({:?}, {:?}, {:?}): {}",
target, numAttachments, attachments, err
);
}
}
out
}
#[inline]
pub unsafe fn InvalidateSubFramebuffer(
target: GLenum,
numAttachments: GLsizei,
attachments: *const GLenum,
x: GLint,
y: GLint,
width: GLsizei,
height: GLsizei,
) {
trace!("InvalidateSubFramebuffer");
let p: *mut c_void = {
let temp_p = storage::InvalidateSubFramebuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("InvalidateSubFramebuffer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLsizei,
*const GLenum,
GLint,
GLint,
GLsizei,
GLsizei,
),
>(p)(target, numAttachments, attachments, x, y, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("InvalidateSubFramebuffer({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, numAttachments, attachments, x, y, width, height, err);
}
}
out
}
#[inline]
pub unsafe fn IsBuffer(buffer: GLuint) -> GLboolean {
trace!("IsBuffer");
let p: *mut c_void = {
let temp_p = storage::IsBuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsBuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(buffer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsBuffer({:?}): {}", buffer, err);
}
}
out
}
#[inline]
pub unsafe fn IsEnabled(cap: GLenum) -> GLboolean {
trace!("IsEnabled");
let p: *mut c_void = {
let temp_p = storage::IsEnabled.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsEnabled")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLenum) -> GLboolean>(p)(cap);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsEnabled({:?}): {}", cap, err);
}
}
out
}
#[inline]
pub unsafe fn IsFramebuffer(framebuffer: GLuint) -> GLboolean {
trace!("IsFramebuffer");
let p: *mut c_void = {
let temp_p = storage::IsFramebuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsFramebuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(framebuffer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsFramebuffer({:?}): {}", framebuffer, err);
}
}
out
}
#[inline]
pub unsafe fn IsProgram(program: GLuint) -> GLboolean {
trace!("IsProgram");
let p: *mut c_void = {
let temp_p = storage::IsProgram.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsProgram")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(program);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsProgram({:?}): {}", program, err);
}
}
out
}
#[inline]
pub unsafe fn IsQuery(id: GLuint) -> GLboolean {
trace!("IsQuery");
let p: *mut c_void = {
let temp_p = storage::IsQuery.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsQuery")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(p)(id);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsQuery({:?}): {}", id, err);
}
}
out
}
#[inline]
pub unsafe fn IsRenderbuffer(renderbuffer: GLuint) -> GLboolean {
trace!("IsRenderbuffer");
let p: *mut c_void = {
let temp_p = storage::IsRenderbuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsRenderbuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(renderbuffer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsRenderbuffer({:?}): {}", renderbuffer, err);
}
}
out
}
#[inline]
pub unsafe fn IsSampler(sampler: GLuint) -> GLboolean {
trace!("IsSampler");
let p: *mut c_void = {
let temp_p = storage::IsSampler.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsSampler")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(sampler);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsSampler({:?}): {}", sampler, err);
}
}
out
}
#[inline]
pub unsafe fn IsShader(shader: GLuint) -> GLboolean {
trace!("IsShader");
let p: *mut c_void = {
let temp_p = storage::IsShader.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsShader")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(shader);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsShader({:?}): {}", shader, err);
}
}
out
}
#[inline]
pub unsafe fn IsSync(sync: GLsync) -> GLboolean {
trace!("IsSync");
let p: *mut c_void = {
let temp_p = storage::IsSync.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsSync")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLsync) -> GLboolean>(
p,
)(sync);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsSync({:?}): {}", sync, err);
}
}
out
}
#[inline]
pub unsafe fn IsTexture(texture: GLuint) -> GLboolean {
trace!("IsTexture");
let p: *mut c_void = {
let temp_p = storage::IsTexture.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsTexture")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(texture);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsTexture({:?}): {}", texture, err);
}
}
out
}
#[inline]
pub unsafe fn IsTransformFeedback(id: GLuint) -> GLboolean {
trace!("IsTransformFeedback");
let p: *mut c_void = {
let temp_p = storage::IsTransformFeedback.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsTransformFeedback")
}
temp_p
};
let out =
transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(p)(id);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsTransformFeedback({:?}): {}", id, err);
}
}
out
}
#[inline]
pub unsafe fn IsVertexArray(array: GLuint) -> GLboolean {
trace!("IsVertexArray");
let p: *mut c_void = {
let temp_p = storage::IsVertexArray.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("IsVertexArray")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint) -> GLboolean>(
p,
)(array);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("IsVertexArray({:?}): {}", array, err);
}
}
out
}
#[inline]
pub unsafe fn LineWidth(width: GLfloat) {
trace!("LineWidth");
let p: *mut c_void = {
let temp_p = storage::LineWidth.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("LineWidth")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLfloat)>(p)(width);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("LineWidth({:?}): {}", width, err);
}
}
out
}
#[inline]
pub unsafe fn LinkProgram(program: GLuint) {
trace!("LinkProgram");
let p: *mut c_void = {
let temp_p = storage::LinkProgram.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("LinkProgram")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(program);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("LinkProgram({:?}): {}", program, err);
}
}
out
}
#[inline]
pub unsafe fn MapBufferRange(
target: GLenum,
offset: GLintptr,
length: GLsizeiptr,
access: GLbitfield,
) -> *mut c_void {
trace!("MapBufferRange");
let p: *mut c_void = {
let temp_p = storage::MapBufferRange.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("MapBufferRange")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLintptr,
GLsizeiptr,
GLbitfield,
) -> *mut c_void,
>(p)(target, offset, length, access);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"MapBufferRange({:?}, {:?}, {:?}, {:?}): {}",
target, offset, length, access, err
);
}
}
out
}
#[inline]
pub unsafe fn PauseTransformFeedback() {
trace!("PauseTransformFeedback");
let p: *mut c_void = {
let temp_p = storage::PauseTransformFeedback.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("PauseTransformFeedback")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn()>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("PauseTransformFeedback(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn PixelStorei(pname: GLenum, param: GLint) {
trace!("PixelStorei");
let p: *mut c_void = {
let temp_p = storage::PixelStorei.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("PixelStorei")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLint)>(p)(
pname, param,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("PixelStorei({:?}, {:?}): {}", pname, param, err);
}
}
out
}
#[inline]
pub unsafe fn PolygonOffset(factor: GLfloat, units: GLfloat) {
trace!("PolygonOffset");
let p: *mut c_void = {
let temp_p = storage::PolygonOffset.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("PolygonOffset")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLfloat, GLfloat)>(p)(
factor, units,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("PolygonOffset({:?}, {:?}): {}", factor, units, err);
}
}
out
}
#[inline]
pub unsafe fn ProgramBinary(
program: GLuint,
binaryFormat: GLenum,
binary: *const c_void,
length: GLsizei,
) {
trace!("ProgramBinary");
let p: *mut c_void = {
let temp_p = storage::ProgramBinary.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ProgramBinary")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *const c_void, GLsizei),
>(p)(program, binaryFormat, binary, length);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ProgramBinary({:?}, {:?}, {:?}, {:?}): {}",
program, binaryFormat, binary, length, err
);
}
}
out
}
#[inline]
pub unsafe fn ProgramParameteri(
program: GLuint,
pname: GLenum,
value: GLint,
) {
trace!("ProgramParameteri");
let p: *mut c_void = {
let temp_p = storage::ProgramParameteri.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ProgramParameteri")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLenum, GLint)>(
p,
)(program, pname, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ProgramParameteri({:?}, {:?}, {:?}): {}",
program, pname, value, err
);
}
}
out
}
#[inline]
pub unsafe fn ReadBuffer(src: GLenum) {
trace!("ReadBuffer");
let p: *mut c_void = {
let temp_p = storage::ReadBuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ReadBuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum)>(p)(src);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ReadBuffer({:?}): {}", src, err);
}
}
out
}
#[inline]
pub unsafe fn ReadPixels(
x: GLint,
y: GLint,
width: GLsizei,
height: GLsizei,
format: GLenum,
type_: GLenum,
pixels: *mut c_void,
) {
trace!("ReadPixels");
let p: *mut c_void = {
let temp_p = storage::ReadPixels.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ReadPixels")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLint,
GLint,
GLsizei,
GLsizei,
GLenum,
GLenum,
*mut c_void,
),
>(p)(x, y, width, height, format, type_, pixels);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ReadPixels({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
x, y, width, height, format, type_, pixels, err
);
}
}
out
}
#[inline]
pub unsafe fn ReleaseShaderCompiler() {
trace!("ReleaseShaderCompiler");
let p: *mut c_void = {
let temp_p = storage::ReleaseShaderCompiler.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ReleaseShaderCompiler")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn()>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ReleaseShaderCompiler(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn RenderbufferStorage(
target: GLenum,
internalformat: GLenum,
width: GLsizei,
height: GLsizei,
) {
trace!("RenderbufferStorage");
let p: *mut c_void = {
let temp_p = storage::RenderbufferStorage.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("RenderbufferStorage")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLsizei, GLsizei),
>(p)(target, internalformat, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"RenderbufferStorage({:?}, {:?}, {:?}, {:?}): {}",
target, internalformat, width, height, err
);
}
}
out
}
#[inline]
pub unsafe fn RenderbufferStorageMultisample(
target: GLenum,
samples: GLsizei,
internalformat: GLenum,
width: GLsizei,
height: GLsizei,
) {
trace!("RenderbufferStorageMultisample");
let p: *mut c_void = {
let temp_p =
storage::RenderbufferStorageMultisample.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("RenderbufferStorageMultisample")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizei, GLenum, GLsizei, GLsizei),
>(p)(target, samples, internalformat, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"RenderbufferStorageMultisample({:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, samples, internalformat, width, height, err
);
}
}
out
}
#[inline]
pub unsafe fn ResumeTransformFeedback() {
trace!("ResumeTransformFeedback");
let p: *mut c_void = {
let temp_p = storage::ResumeTransformFeedback.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ResumeTransformFeedback")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn()>(p)();
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ResumeTransformFeedback(): {}", err);
}
}
out
}
#[inline]
pub unsafe fn SampleCoverage(value: GLfloat, invert: GLboolean) {
trace!("SampleCoverage");
let p: *mut c_void = {
let temp_p = storage::SampleCoverage.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("SampleCoverage")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLfloat, GLboolean)>(
p,
)(value, invert);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("SampleCoverage({:?}, {:?}): {}", value, invert, err);
}
}
out
}
#[inline]
pub unsafe fn SamplerParameterf(
sampler: GLuint,
pname: GLenum,
param: GLfloat,
) {
trace!("SamplerParameterf");
let p: *mut c_void = {
let temp_p = storage::SamplerParameterf.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("SamplerParameterf")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, GLfloat),
>(p)(sampler, pname, param);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"SamplerParameterf({:?}, {:?}, {:?}): {}",
sampler, pname, param, err
);
}
}
out
}
#[inline]
pub unsafe fn SamplerParameterfv(
sampler: GLuint,
pname: GLenum,
param: *const GLfloat,
) {
trace!("SamplerParameterfv");
let p: *mut c_void = {
let temp_p = storage::SamplerParameterfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("SamplerParameterfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *const GLfloat),
>(p)(sampler, pname, param);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"SamplerParameterfv({:?}, {:?}, {:?}): {}",
sampler, pname, param, err
);
}
}
out
}
#[inline]
pub unsafe fn SamplerParameteri(
sampler: GLuint,
pname: GLenum,
param: GLint,
) {
trace!("SamplerParameteri");
let p: *mut c_void = {
let temp_p = storage::SamplerParameteri.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("SamplerParameteri")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLenum, GLint)>(
p,
)(sampler, pname, param);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"SamplerParameteri({:?}, {:?}, {:?}): {}",
sampler, pname, param, err
);
}
}
out
}
#[inline]
pub unsafe fn SamplerParameteriv(
sampler: GLuint,
pname: GLenum,
param: *const GLint,
) {
trace!("SamplerParameteriv");
let p: *mut c_void = {
let temp_p = storage::SamplerParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("SamplerParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLenum, *const GLint),
>(p)(sampler, pname, param);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"SamplerParameteriv({:?}, {:?}, {:?}): {}",
sampler, pname, param, err
);
}
}
out
}
#[inline]
pub unsafe fn Scissor(x: GLint, y: GLint, width: GLsizei, height: GLsizei) {
trace!("Scissor");
let p: *mut c_void = {
let temp_p = storage::Scissor.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Scissor")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLint, GLsizei, GLsizei),
>(p)(x, y, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Scissor({:?}, {:?}, {:?}, {:?}): {}", x, y, width, height, err);
}
}
out
}
#[inline]
pub unsafe fn ShaderBinary(
count: GLsizei,
shaders: *const GLuint,
binaryformat: GLenum,
binary: *const c_void,
length: GLsizei,
) {
trace!("ShaderBinary");
let p: *mut c_void = {
let temp_p = storage::ShaderBinary.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ShaderBinary")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLsizei,
*const GLuint,
GLenum,
*const c_void,
GLsizei,
),
>(p)(count, shaders, binaryformat, binary, length);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ShaderBinary({:?}, {:?}, {:?}, {:?}, {:?}): {}",
count, shaders, binaryformat, binary, length, err
);
}
}
out
}
#[inline]
pub unsafe fn ShaderSource(
shader: GLuint,
count: GLsizei,
string: *const *const GLchar,
length: *const GLint,
) {
trace!("ShaderSource");
let p: *mut c_void = {
let temp_p = storage::ShaderSource.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ShaderSource")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *const *const GLchar, *const GLint),
>(p)(shader, count, string, length);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"ShaderSource({:?}, {:?}, {:?}, {:?}): {}",
shader, count, string, length, err
);
}
}
out
}
#[inline]
pub unsafe fn StencilFunc(func: GLenum, ref_: GLint, mask: GLuint) {
trace!("StencilFunc");
let p: *mut c_void = {
let temp_p = storage::StencilFunc.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("StencilFunc")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLint, GLuint)>(
p,
)(func, ref_, mask);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("StencilFunc({:?}, {:?}, {:?}): {}", func, ref_, mask, err);
}
}
out
}
#[inline]
pub unsafe fn StencilFuncSeparate(
face: GLenum,
func: GLenum,
ref_: GLint,
mask: GLuint,
) {
trace!("StencilFuncSeparate");
let p: *mut c_void = {
let temp_p = storage::StencilFuncSeparate.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("StencilFuncSeparate")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLint, GLuint),
>(p)(face, func, ref_, mask);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"StencilFuncSeparate({:?}, {:?}, {:?}, {:?}): {}",
face, func, ref_, mask, err
);
}
}
out
}
#[inline]
pub unsafe fn StencilMask(mask: GLuint) {
trace!("StencilMask");
let p: *mut c_void = {
let temp_p = storage::StencilMask.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("StencilMask")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(mask);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("StencilMask({:?}): {}", mask, err);
}
}
out
}
#[inline]
pub unsafe fn StencilMaskSeparate(face: GLenum, mask: GLuint) {
trace!("StencilMaskSeparate");
let p: *mut c_void = {
let temp_p = storage::StencilMaskSeparate.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("StencilMaskSeparate")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLuint)>(p)(
face, mask,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("StencilMaskSeparate({:?}, {:?}): {}", face, mask, err);
}
}
out
}
#[inline]
pub unsafe fn StencilOp(fail: GLenum, zfail: GLenum, zpass: GLenum) {
trace!("StencilOp");
let p: *mut c_void = {
let temp_p = storage::StencilOp.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("StencilOp")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum),
>(p)(fail, zfail, zpass);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("StencilOp({:?}, {:?}, {:?}): {}", fail, zfail, zpass, err);
}
}
out
}
#[inline]
pub unsafe fn StencilOpSeparate(
face: GLenum,
sfail: GLenum,
dpfail: GLenum,
dppass: GLenum,
) {
trace!("StencilOpSeparate");
let p: *mut c_void = {
let temp_p = storage::StencilOpSeparate.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("StencilOpSeparate")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLenum, GLenum),
>(p)(face, sfail, dpfail, dppass);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"StencilOpSeparate({:?}, {:?}, {:?}, {:?}): {}",
face, sfail, dpfail, dppass, err
);
}
}
out
}
#[inline]
pub unsafe fn TexImage2D(
target: GLenum,
level: GLint,
internalformat: GLint,
width: GLsizei,
height: GLsizei,
border: GLint,
format: GLenum,
type_: GLenum,
pixels: *const c_void,
) {
trace!("TexImage2D");
let p: *mut c_void = {
let temp_p = storage::TexImage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexImage2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLsizei,
GLsizei,
GLint,
GLenum,
GLenum,
*const c_void,
),
>(p)(
target,
level,
internalformat,
width,
height,
border,
format,
type_,
pixels,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("TexImage2D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, internalformat, width, height, border, format, type_, pixels, err);
}
}
out
}
#[inline]
pub unsafe fn TexImage3D(
target: GLenum,
level: GLint,
internalformat: GLint,
width: GLsizei,
height: GLsizei,
depth: GLsizei,
border: GLint,
format: GLenum,
type_: GLenum,
pixels: *const c_void,
) {
trace!("TexImage3D");
let p: *mut c_void = {
let temp_p = storage::TexImage3D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexImage3D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLsizei,
GLsizei,
GLsizei,
GLint,
GLenum,
GLenum,
*const c_void,
),
>(p)(
target,
level,
internalformat,
width,
height,
depth,
border,
format,
type_,
pixels,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("TexImage3D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, internalformat, width, height, depth, border, format, type_, pixels, err);
}
}
out
}
#[inline]
pub unsafe fn TexParameterf(target: GLenum, pname: GLenum, param: GLfloat) {
trace!("TexParameterf");
let p: *mut c_void = {
let temp_p = storage::TexParameterf.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexParameterf")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, GLfloat),
>(p)(target, pname, param);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TexParameterf({:?}, {:?}, {:?}): {}",
target, pname, param, err
);
}
}
out
}
#[inline]
pub unsafe fn TexParameterfv(
target: GLenum,
pname: GLenum,
params: *const GLfloat,
) {
trace!("TexParameterfv");
let p: *mut c_void = {
let temp_p = storage::TexParameterfv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexParameterfv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *const GLfloat),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TexParameterfv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn TexParameteri(target: GLenum, pname: GLenum, param: GLint) {
trace!("TexParameteri");
let p: *mut c_void = {
let temp_p = storage::TexParameteri.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexParameteri")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum, GLenum, GLint)>(
p,
)(target, pname, param);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TexParameteri({:?}, {:?}, {:?}): {}",
target, pname, param, err
);
}
}
out
}
#[inline]
pub unsafe fn TexParameteriv(
target: GLenum,
pname: GLenum,
params: *const GLint,
) {
trace!("TexParameteriv");
let p: *mut c_void = {
let temp_p = storage::TexParameteriv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexParameteriv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLenum, *const GLint),
>(p)(target, pname, params);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TexParameteriv({:?}, {:?}, {:?}): {}",
target, pname, params, err
);
}
}
out
}
#[inline]
pub unsafe fn TexStorage2D(
target: GLenum,
levels: GLsizei,
internalformat: GLenum,
width: GLsizei,
height: GLsizei,
) {
trace!("TexStorage2D");
let p: *mut c_void = {
let temp_p = storage::TexStorage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexStorage2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizei, GLenum, GLsizei, GLsizei),
>(p)(target, levels, internalformat, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TexStorage2D({:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, levels, internalformat, width, height, err
);
}
}
out
}
#[inline]
pub unsafe fn TexStorage3D(
target: GLenum,
levels: GLsizei,
internalformat: GLenum,
width: GLsizei,
height: GLsizei,
depth: GLsizei,
) {
trace!("TexStorage3D");
let p: *mut c_void = {
let temp_p = storage::TexStorage3D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexStorage3D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLenum, GLsizei, GLenum, GLsizei, GLsizei, GLsizei),
>(p)(target, levels, internalformat, width, height, depth);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TexStorage3D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
target, levels, internalformat, width, height, depth, err
);
}
}
out
}
#[inline]
pub unsafe fn TexSubImage2D(
target: GLenum,
level: GLint,
xoffset: GLint,
yoffset: GLint,
width: GLsizei,
height: GLsizei,
format: GLenum,
type_: GLenum,
pixels: *const c_void,
) {
trace!("TexSubImage2D");
let p: *mut c_void = {
let temp_p = storage::TexSubImage2D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexSubImage2D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLint,
GLsizei,
GLsizei,
GLenum,
GLenum,
*const c_void,
),
>(p)(
target, level, xoffset, yoffset, width, height, format, type_, pixels,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("TexSubImage2D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, xoffset, yoffset, width, height, format, type_, pixels, err);
}
}
out
}
#[inline]
pub unsafe fn TexSubImage3D(
target: GLenum,
level: GLint,
xoffset: GLint,
yoffset: GLint,
zoffset: GLint,
width: GLsizei,
height: GLsizei,
depth: GLsizei,
format: GLenum,
type_: GLenum,
pixels: *const c_void,
) {
trace!("TexSubImage3D");
let p: *mut c_void = {
let temp_p = storage::TexSubImage3D.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TexSubImage3D")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLenum,
GLint,
GLint,
GLint,
GLint,
GLsizei,
GLsizei,
GLsizei,
GLenum,
GLenum,
*const c_void,
),
>(p)(
target, level, xoffset, yoffset, zoffset, width, height, depth, format,
type_, pixels,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("TexSubImage3D({:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}", target, level, xoffset, yoffset, zoffset, width, height, depth, format, type_, pixels, err);
}
}
out
}
#[inline]
pub unsafe fn TransformFeedbackVaryings(
program: GLuint,
count: GLsizei,
varyings: *const *const GLchar,
bufferMode: GLenum,
) {
trace!("TransformFeedbackVaryings");
let p: *mut c_void = {
let temp_p = storage::TransformFeedbackVaryings.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("TransformFeedbackVaryings")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLsizei, *const *const GLchar, GLenum),
>(p)(program, count, varyings, bufferMode);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"TransformFeedbackVaryings({:?}, {:?}, {:?}, {:?}): {}",
program, count, varyings, bufferMode, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform1f(location: GLint, v0: GLfloat) {
trace!("Uniform1f");
let p: *mut c_void = {
let temp_p = storage::Uniform1f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform1f")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLint, GLfloat)>(p)(
location, v0,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform1f({:?}, {:?}): {}", location, v0, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform1fv(
location: GLint,
count: GLsizei,
value: *const GLfloat,
) {
trace!("Uniform1fv");
let p: *mut c_void = {
let temp_p = storage::Uniform1fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform1fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLfloat),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform1fv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform1i(location: GLint, v0: GLint) {
trace!("Uniform1i");
let p: *mut c_void = {
let temp_p = storage::Uniform1i.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform1i")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLint, GLint)>(p)(
location, v0,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform1i({:?}, {:?}): {}", location, v0, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform1iv(
location: GLint,
count: GLsizei,
value: *const GLint,
) {
trace!("Uniform1iv");
let p: *mut c_void = {
let temp_p = storage::Uniform1iv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform1iv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform1iv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform1ui(location: GLint, v0: GLuint) {
trace!("Uniform1ui");
let p: *mut c_void = {
let temp_p = storage::Uniform1ui.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform1ui")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLint, GLuint)>(p)(
location, v0,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform1ui({:?}, {:?}): {}", location, v0, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform1uiv(
location: GLint,
count: GLsizei,
value: *const GLuint,
) {
trace!("Uniform1uiv");
let p: *mut c_void = {
let temp_p = storage::Uniform1uiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform1uiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLuint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform1uiv({:?}, {:?}, {:?}): {}",
location, count, value, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform2f(location: GLint, v0: GLfloat, v1: GLfloat) {
trace!("Uniform2f");
let p: *mut c_void = {
let temp_p = storage::Uniform2f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform2f")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLfloat, GLfloat),
>(p)(location, v0, v1);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform2f({:?}, {:?}, {:?}): {}", location, v0, v1, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform2fv(
location: GLint,
count: GLsizei,
value: *const GLfloat,
) {
trace!("Uniform2fv");
let p: *mut c_void = {
let temp_p = storage::Uniform2fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform2fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLfloat),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform2fv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform2i(location: GLint, v0: GLint, v1: GLint) {
trace!("Uniform2i");
let p: *mut c_void = {
let temp_p = storage::Uniform2i.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform2i")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLint, GLint, GLint)>(
p,
)(location, v0, v1);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform2i({:?}, {:?}, {:?}): {}", location, v0, v1, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform2iv(
location: GLint,
count: GLsizei,
value: *const GLint,
) {
trace!("Uniform2iv");
let p: *mut c_void = {
let temp_p = storage::Uniform2iv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform2iv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform2iv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform2ui(location: GLint, v0: GLuint, v1: GLuint) {
trace!("Uniform2ui");
let p: *mut c_void = {
let temp_p = storage::Uniform2ui.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform2ui")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLint, GLuint, GLuint)>(
p,
)(location, v0, v1);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform2ui({:?}, {:?}, {:?}): {}", location, v0, v1, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform2uiv(
location: GLint,
count: GLsizei,
value: *const GLuint,
) {
trace!("Uniform2uiv");
let p: *mut c_void = {
let temp_p = storage::Uniform2uiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform2uiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLuint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform2uiv({:?}, {:?}, {:?}): {}",
location, count, value, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform3f(
location: GLint,
v0: GLfloat,
v1: GLfloat,
v2: GLfloat,
) {
trace!("Uniform3f");
let p: *mut c_void = {
let temp_p = storage::Uniform3f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform3f")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLfloat, GLfloat, GLfloat),
>(p)(location, v0, v1, v2);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform3f({:?}, {:?}, {:?}, {:?}): {}",
location, v0, v1, v2, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform3fv(
location: GLint,
count: GLsizei,
value: *const GLfloat,
) {
trace!("Uniform3fv");
let p: *mut c_void = {
let temp_p = storage::Uniform3fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform3fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLfloat),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform3fv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform3i(location: GLint, v0: GLint, v1: GLint, v2: GLint) {
trace!("Uniform3i");
let p: *mut c_void = {
let temp_p = storage::Uniform3i.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform3i")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLint, GLint, GLint),
>(p)(location, v0, v1, v2);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform3i({:?}, {:?}, {:?}, {:?}): {}",
location, v0, v1, v2, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform3iv(
location: GLint,
count: GLsizei,
value: *const GLint,
) {
trace!("Uniform3iv");
let p: *mut c_void = {
let temp_p = storage::Uniform3iv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform3iv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform3iv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform3ui(
location: GLint,
v0: GLuint,
v1: GLuint,
v2: GLuint,
) {
trace!("Uniform3ui");
let p: *mut c_void = {
let temp_p = storage::Uniform3ui.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform3ui")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLuint, GLuint, GLuint),
>(p)(location, v0, v1, v2);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform3ui({:?}, {:?}, {:?}, {:?}): {}",
location, v0, v1, v2, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform3uiv(
location: GLint,
count: GLsizei,
value: *const GLuint,
) {
trace!("Uniform3uiv");
let p: *mut c_void = {
let temp_p = storage::Uniform3uiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform3uiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLuint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform3uiv({:?}, {:?}, {:?}): {}",
location, count, value, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform4f(
location: GLint,
v0: GLfloat,
v1: GLfloat,
v2: GLfloat,
v3: GLfloat,
) {
trace!("Uniform4f");
let p: *mut c_void = {
let temp_p = storage::Uniform4f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform4f")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLfloat, GLfloat, GLfloat, GLfloat),
>(p)(location, v0, v1, v2, v3);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform4f({:?}, {:?}, {:?}, {:?}, {:?}): {}",
location, v0, v1, v2, v3, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform4fv(
location: GLint,
count: GLsizei,
value: *const GLfloat,
) {
trace!("Uniform4fv");
let p: *mut c_void = {
let temp_p = storage::Uniform4fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform4fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLfloat),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform4fv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform4i(
location: GLint,
v0: GLint,
v1: GLint,
v2: GLint,
v3: GLint,
) {
trace!("Uniform4i");
let p: *mut c_void = {
let temp_p = storage::Uniform4i.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform4i")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLint, GLint, GLint, GLint),
>(p)(location, v0, v1, v2, v3);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform4i({:?}, {:?}, {:?}, {:?}, {:?}): {}",
location, v0, v1, v2, v3, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform4iv(
location: GLint,
count: GLsizei,
value: *const GLint,
) {
trace!("Uniform4iv");
let p: *mut c_void = {
let temp_p = storage::Uniform4iv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform4iv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("Uniform4iv({:?}, {:?}, {:?}): {}", location, count, value, err);
}
}
out
}
#[inline]
pub unsafe fn Uniform4ui(
location: GLint,
v0: GLuint,
v1: GLuint,
v2: GLuint,
v3: GLuint,
) {
trace!("Uniform4ui");
let p: *mut c_void = {
let temp_p = storage::Uniform4ui.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform4ui")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLuint, GLuint, GLuint, GLuint),
>(p)(location, v0, v1, v2, v3);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform4ui({:?}, {:?}, {:?}, {:?}, {:?}): {}",
location, v0, v1, v2, v3, err
);
}
}
out
}
#[inline]
pub unsafe fn Uniform4uiv(
location: GLint,
count: GLsizei,
value: *const GLuint,
) {
trace!("Uniform4uiv");
let p: *mut c_void = {
let temp_p = storage::Uniform4uiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Uniform4uiv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, *const GLuint),
>(p)(location, count, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Uniform4uiv({:?}, {:?}, {:?}): {}",
location, count, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformBlockBinding(
program: GLuint,
uniformBlockIndex: GLuint,
uniformBlockBinding: GLuint,
) {
trace!("UniformBlockBinding");
let p: *mut c_void = {
let temp_p = storage::UniformBlockBinding.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformBlockBinding")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLuint, GLuint),
>(p)(program, uniformBlockIndex, uniformBlockBinding);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformBlockBinding({:?}, {:?}, {:?}): {}",
program, uniformBlockIndex, uniformBlockBinding, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix2fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix2fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix2fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix2fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix2fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix2x3fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix2x3fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix2x3fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix2x3fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix2x3fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix2x4fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix2x4fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix2x4fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix2x4fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix2x4fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix3fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix3fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix3fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix3fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix3fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix3x2fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix3x2fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix3x2fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix3x2fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix3x2fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix3x4fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix3x4fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix3x4fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix3x4fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix3x4fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix4fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix4fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix4fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix4fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix4fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix4x2fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix4x2fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix4x2fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix4x2fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix4x2fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UniformMatrix4x3fv(
location: GLint,
count: GLsizei,
transpose: GLboolean,
value: *const GLfloat,
) {
trace!("UniformMatrix4x3fv");
let p: *mut c_void = {
let temp_p = storage::UniformMatrix4x3fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UniformMatrix4x3fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLsizei, GLboolean, *const GLfloat),
>(p)(location, count, transpose, value);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"UniformMatrix4x3fv({:?}, {:?}, {:?}, {:?}): {}",
location, count, transpose, value, err
);
}
}
out
}
#[inline]
pub unsafe fn UnmapBuffer(target: GLenum) -> GLboolean {
trace!("UnmapBuffer");
let p: *mut c_void = {
let temp_p = storage::UnmapBuffer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UnmapBuffer")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLenum) -> GLboolean>(
p,
)(target);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("UnmapBuffer({:?}): {}", target, err);
}
}
out
}
#[inline]
pub unsafe fn UseProgram(program: GLuint) {
trace!("UseProgram");
let p: *mut c_void = {
let temp_p = storage::UseProgram.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("UseProgram")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(program);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("UseProgram({:?}): {}", program, err);
}
}
out
}
#[inline]
pub unsafe fn ValidateProgram(program: GLuint) {
trace!("ValidateProgram");
let p: *mut c_void = {
let temp_p = storage::ValidateProgram.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("ValidateProgram")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint)>(p)(program);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("ValidateProgram({:?}): {}", program, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib1f(index: GLuint, x: GLfloat) {
trace!("VertexAttrib1f");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib1f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib1f")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLfloat)>(p)(
index, x,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttrib1f({:?}, {:?}): {}", index, x, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib1fv(index: GLuint, v: *const GLfloat) {
trace!("VertexAttrib1fv");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib1fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib1fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLfloat),
>(p)(index, v);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttrib1fv({:?}, {:?}): {}", index, v, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib2f(index: GLuint, x: GLfloat, y: GLfloat) {
trace!("VertexAttrib2f");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib2f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib2f")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLfloat, GLfloat),
>(p)(index, x, y);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttrib2f({:?}, {:?}, {:?}): {}", index, x, y, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib2fv(index: GLuint, v: *const GLfloat) {
trace!("VertexAttrib2fv");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib2fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib2fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLfloat),
>(p)(index, v);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttrib2fv({:?}, {:?}): {}", index, v, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib3f(
index: GLuint,
x: GLfloat,
y: GLfloat,
z: GLfloat,
) {
trace!("VertexAttrib3f");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib3f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib3f")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLfloat, GLfloat, GLfloat),
>(p)(index, x, y, z);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"VertexAttrib3f({:?}, {:?}, {:?}, {:?}): {}",
index, x, y, z, err
);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib3fv(index: GLuint, v: *const GLfloat) {
trace!("VertexAttrib3fv");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib3fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib3fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLfloat),
>(p)(index, v);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttrib3fv({:?}, {:?}): {}", index, v, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib4f(
index: GLuint,
x: GLfloat,
y: GLfloat,
z: GLfloat,
w: GLfloat,
) {
trace!("VertexAttrib4f");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib4f.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib4f")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLfloat, GLfloat, GLfloat, GLfloat),
>(p)(index, x, y, z, w);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"VertexAttrib4f({:?}, {:?}, {:?}, {:?}, {:?}): {}",
index, x, y, z, w, err
);
}
}
out
}
#[inline]
pub unsafe fn VertexAttrib4fv(index: GLuint, v: *const GLfloat) {
trace!("VertexAttrib4fv");
let p: *mut c_void = {
let temp_p = storage::VertexAttrib4fv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttrib4fv")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, *const GLfloat),
>(p)(index, v);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttrib4fv({:?}, {:?}): {}", index, v, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribDivisor(index: GLuint, divisor: GLuint) {
trace!("VertexAttribDivisor");
let p: *mut c_void = {
let temp_p = storage::VertexAttribDivisor.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribDivisor")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, GLuint)>(p)(
index, divisor,
);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttribDivisor({:?}, {:?}): {}", index, divisor, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribI4i(
index: GLuint,
x: GLint,
y: GLint,
z: GLint,
w: GLint,
) {
trace!("VertexAttribI4i");
let p: *mut c_void = {
let temp_p = storage::VertexAttribI4i.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribI4i")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLint, GLint, GLint, GLint),
>(p)(index, x, y, z, w);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"VertexAttribI4i({:?}, {:?}, {:?}, {:?}, {:?}): {}",
index, x, y, z, w, err
);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribI4iv(index: GLuint, v: *const GLint) {
trace!("VertexAttribI4iv");
let p: *mut c_void = {
let temp_p = storage::VertexAttribI4iv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribI4iv")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, *const GLint)>(
p,
)(index, v);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttribI4iv({:?}, {:?}): {}", index, v, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribI4ui(
index: GLuint,
x: GLuint,
y: GLuint,
z: GLuint,
w: GLuint,
) {
trace!("VertexAttribI4ui");
let p: *mut c_void = {
let temp_p = storage::VertexAttribI4ui.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribI4ui")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLuint, GLuint, GLuint, GLuint),
>(p)(index, x, y, z, w);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"VertexAttribI4ui({:?}, {:?}, {:?}, {:?}, {:?}): {}",
index, x, y, z, w, err
);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribI4uiv(index: GLuint, v: *const GLuint) {
trace!("VertexAttribI4uiv");
let p: *mut c_void = {
let temp_p = storage::VertexAttribI4uiv.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribI4uiv")
}
temp_p
};
let out = transmute::<*mut c_void, extern "system" fn(GLuint, *const GLuint)>(
p,
)(index, v);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("VertexAttribI4uiv({:?}, {:?}): {}", index, v, err);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribIPointer(
index: GLuint,
size: GLint,
type_: GLenum,
stride: GLsizei,
pointer: *const c_void,
) {
trace!("VertexAttribIPointer");
let p: *mut c_void = {
let temp_p = storage::VertexAttribIPointer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribIPointer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLuint, GLint, GLenum, GLsizei, *const c_void),
>(p)(index, size, type_, stride, pointer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"VertexAttribIPointer({:?}, {:?}, {:?}, {:?}, {:?}): {}",
index, size, type_, stride, pointer, err
);
}
}
out
}
#[inline]
pub unsafe fn VertexAttribPointer(
index: GLuint,
size: GLint,
type_: GLenum,
normalized: GLboolean,
stride: GLsizei,
pointer: *const c_void,
) {
trace!("VertexAttribPointer");
let p: *mut c_void = {
let temp_p = storage::VertexAttribPointer.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("VertexAttribPointer")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(
GLuint,
GLint,
GLenum,
GLboolean,
GLsizei,
*const c_void,
),
>(p)(index, size, type_, normalized, stride, pointer);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"VertexAttribPointer({:?}, {:?}, {:?}, {:?}, {:?}, {:?}): {}",
index, size, type_, normalized, stride, pointer, err
);
}
}
out
}
#[inline]
pub unsafe fn Viewport(x: GLint, y: GLint, width: GLsizei, height: GLsizei) {
trace!("Viewport");
let p: *mut c_void = {
let temp_p = storage::Viewport.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("Viewport")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLint, GLint, GLsizei, GLsizei),
>(p)(x, y, width, height);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!(
"Viewport({:?}, {:?}, {:?}, {:?}): {}",
x, y, width, height, err
);
}
}
out
}
#[inline]
pub unsafe fn WaitSync(sync: GLsync, flags: GLbitfield, timeout: GLuint64) {
trace!("WaitSync");
let p: *mut c_void = {
let temp_p = storage::WaitSync.load(Ordering::Relaxed);
if temp_p.is_null() {
panic!("WaitSync")
}
temp_p
};
let out = transmute::<
*mut c_void,
extern "system" fn(GLsync, GLbitfield, GLuint64),
>(p)(sync, flags, timeout);
if cfg!(debug_assertions) {
let err = GetError();
if err != NO_ERROR {
error!("WaitSync({:?}, {:?}, {:?}): {}", sync, flags, timeout, err);
}
}
out
}
}
mod storage {
use super::*;
pub static ActiveTexture: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static AttachShader: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BeginQuery: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BeginTransformFeedback: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static BindAttribLocation: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindBuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindBufferBase: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindBufferRange: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindFramebuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindRenderbuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindSampler: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindTexture: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BindTransformFeedback: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static BindVertexArray: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BlendColor: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BlendEquation: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BlendEquationSeparate: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static BlendFunc: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BlendFuncSeparate: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BlitFramebuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BufferData: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static BufferSubData: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CheckFramebufferStatus: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static Clear: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearBufferfi: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearBufferfv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearBufferiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearBufferuiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearColor: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearDepthf: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClearStencil: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ClientWaitSync: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ColorMask: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CompileShader: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CompressedTexImage2D: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static CompressedTexImage3D: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static CompressedTexSubImage2D: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static CompressedTexSubImage3D: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static CopyBufferSubData: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CopyTexImage2D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CopyTexSubImage2D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CopyTexSubImage3D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CreateProgram: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CreateShader: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static CullFace: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteBuffers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteFramebuffers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteProgram: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteQueries: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteRenderbuffers: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static DeleteSamplers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteShader: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteSync: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteTextures: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DeleteTransformFeedbacks: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static DeleteVertexArrays: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DepthFunc: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DepthMask: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DepthRangef: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DetachShader: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Disable: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DisableVertexAttribArray: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static DrawArrays: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DrawArraysInstanced: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static DrawBuffers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DrawElements: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static DrawElementsInstanced: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static DrawRangeElements: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Enable: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static EnableVertexAttribArray: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static EndQuery: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static EndTransformFeedback: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static FenceSync: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Finish: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Flush: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static FlushMappedBufferRange: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static FramebufferRenderbuffer: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static FramebufferTexture2D: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static FramebufferTextureLayer: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static FrontFace: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenBuffers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenFramebuffers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenQueries: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenRenderbuffers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenSamplers: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenTextures: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenTransformFeedbacks: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GenVertexArrays: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GenerateMipmap: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetActiveAttrib: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetActiveUniform: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetActiveUniformBlockName: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetActiveUniformBlockiv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetActiveUniformsiv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetAttachedShaders: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetAttribLocation: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetBooleanv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetBufferParameteri64v: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetBufferParameteriv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetBufferPointerv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetError: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetFloatv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetFragDataLocation: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetFramebufferAttachmentParameteriv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetInteger64i_v: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetInteger64v: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetIntegeri_v: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetIntegerv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetInternalformativ: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetProgramBinary: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetProgramInfoLog: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetProgramiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetQueryObjectuiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetQueryiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetRenderbufferParameteriv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetSamplerParameterfv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetSamplerParameteriv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetShaderInfoLog: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetShaderPrecisionFormat: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetShaderSource: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetShaderiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetString: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetStringi: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetSynciv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetTexParameterfv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetTexParameteriv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetTransformFeedbackVarying: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetUniformBlockIndex: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetUniformIndices: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetUniformLocation: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetUniformfv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetUniformiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetUniformuiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetVertexAttribIiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetVertexAttribIuiv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetVertexAttribPointerv: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static GetVertexAttribfv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static GetVertexAttribiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Hint: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static InvalidateFramebuffer: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static InvalidateSubFramebuffer: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static IsBuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsEnabled: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsFramebuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsProgram: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsQuery: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsRenderbuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsSampler: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsShader: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsSync: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsTexture: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static IsTransformFeedback: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static IsVertexArray: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static LineWidth: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static LinkProgram: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static MapBufferRange: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static PauseTransformFeedback: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static PixelStorei: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static PolygonOffset: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ProgramBinary: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ProgramParameteri: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ReadBuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ReadPixels: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ReleaseShaderCompiler: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static RenderbufferStorage: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static RenderbufferStorageMultisample: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static ResumeTransformFeedback: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static SampleCoverage: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static SamplerParameterf: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static SamplerParameterfv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static SamplerParameteri: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static SamplerParameteriv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Scissor: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ShaderBinary: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ShaderSource: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static StencilFunc: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static StencilFuncSeparate: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static StencilMask: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static StencilMaskSeparate: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static StencilOp: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static StencilOpSeparate: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexImage2D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexImage3D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexParameterf: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexParameterfv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexParameteri: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexParameteriv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexStorage2D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexStorage3D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexSubImage2D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TexSubImage3D: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static TransformFeedbackVaryings: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static Uniform1f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform1fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform1i: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform1iv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform1ui: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform1uiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform2f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform2fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform2i: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform2iv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform2ui: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform2uiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform3f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform3fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform3i: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform3iv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform3ui: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform3uiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform4f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform4fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform4i: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform4iv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform4ui: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static Uniform4uiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformBlockBinding: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static UniformMatrix2fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix2x3fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix2x4fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix3fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix3x2fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix3x4fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix4fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix4x2fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UniformMatrix4x3fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UnmapBuffer: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static UseProgram: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static ValidateProgram: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib1f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib1fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib2f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib2fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib3f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib3fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib4f: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttrib4fv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttribDivisor: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static VertexAttribI4i: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttribI4iv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttribI4ui: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttribI4uiv: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static VertexAttribIPointer: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static VertexAttribPointer: AtomicPtr<c_void> =
AtomicPtr::new(null_mut());
pub static Viewport: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
pub static WaitSync: AtomicPtr<c_void> = AtomicPtr::new(null_mut());
}
pub mod ActiveTexture {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ActiveTexture.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glActiveTexture\0", b"glActiveTextureARB\0"],
) {
storage::ActiveTexture.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod AttachShader {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::AttachShader.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glAttachShader\0", b"glAttachObjectARB\0"])
{
storage::AttachShader.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BeginQuery {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BeginQuery.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glBeginQuery\0", b"glBeginQueryARB\0"])
{
storage::BeginQuery.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BeginTransformFeedback {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BeginTransformFeedback.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glBeginTransformFeedback\0",
b"glBeginTransformFeedbackEXT\0",
b"glBeginTransformFeedbackNV\0",
],
) {
storage::BeginTransformFeedback.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindAttribLocation {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindAttribLocation.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glBindAttribLocation\0", b"glBindAttribLocationARB\0"],
) {
storage::BindAttribLocation.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindBuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindBuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glBindBuffer\0", b"glBindBufferARB\0"])
{
storage::BindBuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindBufferBase {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindBufferBase.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glBindBufferBase\0",
b"glBindBufferBaseEXT\0",
b"glBindBufferBaseNV\0",
],
) {
storage::BindBufferBase.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindBufferRange {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindBufferRange.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glBindBufferRange\0",
b"glBindBufferRangeEXT\0",
b"glBindBufferRangeNV\0",
],
) {
storage::BindBufferRange.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindFramebuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindFramebuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glBindFramebuffer\0"]) {
storage::BindFramebuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindRenderbuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindRenderbuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glBindRenderbuffer\0"]) {
storage::BindRenderbuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindSampler {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindSampler.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glBindSampler\0"]) {
storage::BindSampler.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindTexture {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindTexture.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glBindTexture\0", b"glBindTextureEXT\0"])
{
storage::BindTexture.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindTransformFeedback {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindTransformFeedback.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glBindTransformFeedback\0"])
{
storage::BindTransformFeedback.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BindVertexArray {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BindVertexArray.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glBindVertexArray\0", b"glBindVertexArrayOES\0"],
) {
storage::BindVertexArray.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BlendColor {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BlendColor.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glBlendColor\0", b"glBlendColorEXT\0"])
{
storage::BlendColor.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BlendEquation {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BlendEquation.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glBlendEquation\0", b"glBlendEquationEXT\0"],
) {
storage::BlendEquation.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BlendEquationSeparate {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BlendEquationSeparate.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glBlendEquationSeparate\0", b"glBlendEquationSeparateEXT\0"],
) {
storage::BlendEquationSeparate.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BlendFunc {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BlendFunc.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glBlendFunc\0"]) {
storage::BlendFunc.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BlendFuncSeparate {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BlendFuncSeparate.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glBlendFuncSeparate\0",
b"glBlendFuncSeparateEXT\0",
b"glBlendFuncSeparateINGR\0",
],
) {
storage::BlendFuncSeparate.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BlitFramebuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BlitFramebuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glBlitFramebuffer\0",
b"glBlitFramebufferEXT\0",
b"glBlitFramebufferNV\0",
],
) {
storage::BlitFramebuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BufferData {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BufferData.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glBufferData\0", b"glBufferDataARB\0"])
{
storage::BufferData.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod BufferSubData {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::BufferSubData.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glBufferSubData\0", b"glBufferSubDataARB\0"],
) {
storage::BufferSubData.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CheckFramebufferStatus {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CheckFramebufferStatus.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCheckFramebufferStatus\0", b"glCheckFramebufferStatusEXT\0"],
) {
storage::CheckFramebufferStatus.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Clear {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Clear.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClear\0"]) {
storage::Clear.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearBufferfi {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearBufferfi.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClearBufferfi\0"]) {
storage::ClearBufferfi.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearBufferfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearBufferfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClearBufferfv\0"]) {
storage::ClearBufferfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearBufferiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearBufferiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClearBufferiv\0"]) {
storage::ClearBufferiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearBufferuiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearBufferuiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClearBufferuiv\0"]) {
storage::ClearBufferuiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearColor {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearColor.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClearColor\0"]) {
storage::ClearColor.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearDepthf {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearDepthf.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glClearDepthf\0", b"glClearDepthfOES\0"])
{
storage::ClearDepthf.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClearStencil {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClearStencil.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glClearStencil\0"]) {
storage::ClearStencil.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ClientWaitSync {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ClientWaitSync.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glClientWaitSync\0", b"glClientWaitSyncAPPLE\0"],
) {
storage::ClientWaitSync.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ColorMask {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ColorMask.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glColorMask\0"]) {
storage::ColorMask.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CompileShader {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CompileShader.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCompileShader\0", b"glCompileShaderARB\0"],
) {
storage::CompileShader.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CompressedTexImage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CompressedTexImage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCompressedTexImage2D\0", b"glCompressedTexImage2DARB\0"],
) {
storage::CompressedTexImage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CompressedTexImage3D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CompressedTexImage3D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCompressedTexImage3D\0", b"glCompressedTexImage3DARB\0"],
) {
storage::CompressedTexImage3D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CompressedTexSubImage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CompressedTexSubImage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCompressedTexSubImage2D\0", b"glCompressedTexSubImage2DARB\0"],
) {
storage::CompressedTexSubImage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CompressedTexSubImage3D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CompressedTexSubImage3D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCompressedTexSubImage3D\0", b"glCompressedTexSubImage3DARB\0"],
) {
storage::CompressedTexSubImage3D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CopyBufferSubData {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CopyBufferSubData.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCopyBufferSubData\0", b"glCopyBufferSubDataNV\0"],
) {
storage::CopyBufferSubData.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CopyTexImage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CopyTexImage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCopyTexImage2D\0", b"glCopyTexImage2DEXT\0"],
) {
storage::CopyTexImage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CopyTexSubImage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CopyTexSubImage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCopyTexSubImage2D\0", b"glCopyTexSubImage2DEXT\0"],
) {
storage::CopyTexSubImage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CopyTexSubImage3D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CopyTexSubImage3D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCopyTexSubImage3D\0", b"glCopyTexSubImage3DEXT\0"],
) {
storage::CopyTexSubImage3D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CreateProgram {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CreateProgram.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCreateProgram\0", b"glCreateProgramObjectARB\0"],
) {
storage::CreateProgram.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CreateShader {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CreateShader.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glCreateShader\0", b"glCreateShaderObjectARB\0"],
) {
storage::CreateShader.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod CullFace {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::CullFace.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glCullFace\0"]) {
storage::CullFace.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteBuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteBuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDeleteBuffers\0", b"glDeleteBuffersARB\0"],
) {
storage::DeleteBuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteFramebuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteFramebuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDeleteFramebuffers\0", b"glDeleteFramebuffersEXT\0"],
) {
storage::DeleteFramebuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteProgram {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteProgram.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDeleteProgram\0"]) {
storage::DeleteProgram.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteQueries {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteQueries.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDeleteQueries\0", b"glDeleteQueriesARB\0"],
) {
storage::DeleteQueries.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteRenderbuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteRenderbuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDeleteRenderbuffers\0", b"glDeleteRenderbuffersEXT\0"],
) {
storage::DeleteRenderbuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteSamplers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteSamplers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDeleteSamplers\0"]) {
storage::DeleteSamplers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteShader {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteShader.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDeleteShader\0"]) {
storage::DeleteShader.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteSync {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteSync.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glDeleteSync\0", b"glDeleteSyncAPPLE\0"])
{
storage::DeleteSync.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteTextures {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteTextures.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDeleteTextures\0"]) {
storage::DeleteTextures.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteTransformFeedbacks {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteTransformFeedbacks.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDeleteTransformFeedbacks\0", b"glDeleteTransformFeedbacksNV\0"],
) {
storage::DeleteTransformFeedbacks.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DeleteVertexArrays {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DeleteVertexArrays.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glDeleteVertexArrays\0",
b"glDeleteVertexArraysAPPLE\0",
b"glDeleteVertexArraysOES\0",
],
) {
storage::DeleteVertexArrays.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DepthFunc {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DepthFunc.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDepthFunc\0"]) {
storage::DepthFunc.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DepthMask {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DepthMask.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDepthMask\0"]) {
storage::DepthMask.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DepthRangef {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DepthRangef.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glDepthRangef\0", b"glDepthRangefOES\0"])
{
storage::DepthRangef.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DetachShader {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DetachShader.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glDetachShader\0", b"glDetachObjectARB\0"])
{
storage::DetachShader.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Disable {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Disable.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDisable\0"]) {
storage::Disable.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DisableVertexAttribArray {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DisableVertexAttribArray.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDisableVertexAttribArray\0", b"glDisableVertexAttribArrayARB\0"],
) {
storage::DisableVertexAttribArray.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DrawArrays {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DrawArrays.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glDrawArrays\0", b"glDrawArraysEXT\0"])
{
storage::DrawArrays.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DrawArraysInstanced {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DrawArraysInstanced.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glDrawArraysInstanced\0",
b"glDrawArraysInstancedANGLE\0",
b"glDrawArraysInstancedARB\0",
b"glDrawArraysInstancedEXT\0",
b"glDrawArraysInstancedNV\0",
],
) {
storage::DrawArraysInstanced.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DrawBuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DrawBuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glDrawBuffers\0",
b"glDrawBuffersARB\0",
b"glDrawBuffersATI\0",
b"glDrawBuffersEXT\0",
],
) {
storage::DrawBuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DrawElements {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DrawElements.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glDrawElements\0"]) {
storage::DrawElements.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DrawElementsInstanced {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DrawElementsInstanced.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glDrawElementsInstanced\0",
b"glDrawElementsInstancedANGLE\0",
b"glDrawElementsInstancedARB\0",
b"glDrawElementsInstancedEXT\0",
b"glDrawElementsInstancedNV\0",
],
) {
storage::DrawElementsInstanced.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod DrawRangeElements {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::DrawRangeElements.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glDrawRangeElements\0", b"glDrawRangeElementsEXT\0"],
) {
storage::DrawRangeElements.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Enable {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Enable.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glEnable\0"]) {
storage::Enable.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod EnableVertexAttribArray {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::EnableVertexAttribArray.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glEnableVertexAttribArray\0", b"glEnableVertexAttribArrayARB\0"],
) {
storage::EnableVertexAttribArray.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod EndQuery {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::EndQuery.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glEndQuery\0", b"glEndQueryARB\0"])
{
storage::EndQuery.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod EndTransformFeedback {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::EndTransformFeedback.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glEndTransformFeedback\0",
b"glEndTransformFeedbackEXT\0",
b"glEndTransformFeedbackNV\0",
],
) {
storage::EndTransformFeedback.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod FenceSync {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::FenceSync.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glFenceSync\0", b"glFenceSyncAPPLE\0"])
{
storage::FenceSync.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Finish {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Finish.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glFinish\0"]) {
storage::Finish.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Flush {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Flush.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glFlush\0"]) {
storage::Flush.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod FlushMappedBufferRange {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::FlushMappedBufferRange.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glFlushMappedBufferRange\0",
b"glFlushMappedBufferRangeAPPLE\0",
b"glFlushMappedBufferRangeEXT\0",
],
) {
storage::FlushMappedBufferRange.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod FramebufferRenderbuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::FramebufferRenderbuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glFramebufferRenderbuffer\0", b"glFramebufferRenderbufferEXT\0"],
) {
storage::FramebufferRenderbuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod FramebufferTexture2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::FramebufferTexture2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glFramebufferTexture2D\0", b"glFramebufferTexture2DEXT\0"],
) {
storage::FramebufferTexture2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod FramebufferTextureLayer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::FramebufferTextureLayer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glFramebufferTextureLayer\0",
b"glFramebufferTextureLayerARB\0",
b"glFramebufferTextureLayerEXT\0",
],
) {
storage::FramebufferTextureLayer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod FrontFace {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::FrontFace.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glFrontFace\0"]) {
storage::FrontFace.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenBuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenBuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGenBuffers\0", b"glGenBuffersARB\0"])
{
storage::GenBuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenFramebuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenFramebuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGenFramebuffers\0", b"glGenFramebuffersEXT\0"],
) {
storage::GenFramebuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenQueries {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenQueries.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGenQueries\0", b"glGenQueriesARB\0"])
{
storage::GenQueries.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenRenderbuffers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenRenderbuffers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGenRenderbuffers\0", b"glGenRenderbuffersEXT\0"],
) {
storage::GenRenderbuffers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenSamplers {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenSamplers.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGenSamplers\0"]) {
storage::GenSamplers.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenTextures {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenTextures.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGenTextures\0"]) {
storage::GenTextures.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenTransformFeedbacks {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenTransformFeedbacks.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGenTransformFeedbacks\0", b"glGenTransformFeedbacksNV\0"],
) {
storage::GenTransformFeedbacks.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenVertexArrays {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenVertexArrays.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGenVertexArrays\0",
b"glGenVertexArraysAPPLE\0",
b"glGenVertexArraysOES\0",
],
) {
storage::GenVertexArrays.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GenerateMipmap {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GenerateMipmap.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGenerateMipmap\0", b"glGenerateMipmapEXT\0"],
) {
storage::GenerateMipmap.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetActiveAttrib {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetActiveAttrib.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetActiveAttrib\0", b"glGetActiveAttribARB\0"],
) {
storage::GetActiveAttrib.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetActiveUniform {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetActiveUniform.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetActiveUniform\0", b"glGetActiveUniformARB\0"],
) {
storage::GetActiveUniform.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetActiveUniformBlockName {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetActiveUniformBlockName.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetActiveUniformBlockName\0"])
{
storage::GetActiveUniformBlockName.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetActiveUniformBlockiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetActiveUniformBlockiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetActiveUniformBlockiv\0"])
{
storage::GetActiveUniformBlockiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetActiveUniformsiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetActiveUniformsiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetActiveUniformsiv\0"]) {
storage::GetActiveUniformsiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetAttachedShaders {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetAttachedShaders.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetAttachedShaders\0"]) {
storage::GetAttachedShaders.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetAttribLocation {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetAttribLocation.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetAttribLocation\0", b"glGetAttribLocationARB\0"],
) {
storage::GetAttribLocation.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetBooleanv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetBooleanv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetBooleanv\0"]) {
storage::GetBooleanv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetBufferParameteri64v {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetBufferParameteri64v.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetBufferParameteri64v\0"])
{
storage::GetBufferParameteri64v.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetBufferParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetBufferParameteriv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetBufferParameteriv\0", b"glGetBufferParameterivARB\0"],
) {
storage::GetBufferParameteriv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetBufferPointerv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetBufferPointerv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetBufferPointerv\0",
b"glGetBufferPointervARB\0",
b"glGetBufferPointervOES\0",
],
) {
storage::GetBufferPointerv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetError {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetError.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetError\0"]) {
storage::GetError.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetFloatv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetFloatv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetFloatv\0"]) {
storage::GetFloatv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetFragDataLocation {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetFragDataLocation.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetFragDataLocation\0", b"glGetFragDataLocationEXT\0"],
) {
storage::GetFragDataLocation.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetFramebufferAttachmentParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetFramebufferAttachmentParameteriv
.load(Ordering::Relaxed)
.is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetFramebufferAttachmentParameteriv\0",
b"glGetFramebufferAttachmentParameterivEXT\0",
],
) {
storage::GetFramebufferAttachmentParameteriv
.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetInteger64i_v {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetInteger64i_v.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetInteger64i_v\0"]) {
storage::GetInteger64i_v.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetInteger64v {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetInteger64v.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetInteger64v\0", b"glGetInteger64vAPPLE\0"],
) {
storage::GetInteger64v.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetIntegeri_v {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetIntegeri_v.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetIntegeri_v\0", b"glGetIntegerIndexedvEXT\0"],
) {
storage::GetIntegeri_v.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetIntegerv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetIntegerv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetIntegerv\0"]) {
storage::GetIntegerv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetInternalformativ {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetInternalformativ.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetInternalformativ\0"]) {
storage::GetInternalformativ.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetProgramBinary {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetProgramBinary.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetProgramBinary\0", b"glGetProgramBinaryOES\0"],
) {
storage::GetProgramBinary.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetProgramInfoLog {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetProgramInfoLog.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetProgramInfoLog\0"]) {
storage::GetProgramInfoLog.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetProgramiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetProgramiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetProgramiv\0"]) {
storage::GetProgramiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetQueryObjectuiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetQueryObjectuiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetQueryObjectuiv\0", b"glGetQueryObjectuivARB\0"],
) {
storage::GetQueryObjectuiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetQueryiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetQueryiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetQueryiv\0", b"glGetQueryivARB\0"])
{
storage::GetQueryiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetRenderbufferParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetRenderbufferParameteriv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetRenderbufferParameteriv\0",
b"glGetRenderbufferParameterivEXT\0",
],
) {
storage::GetRenderbufferParameteriv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetSamplerParameterfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetSamplerParameterfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetSamplerParameterfv\0"])
{
storage::GetSamplerParameterfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetSamplerParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetSamplerParameteriv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetSamplerParameteriv\0"])
{
storage::GetSamplerParameteriv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetShaderInfoLog {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetShaderInfoLog.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetShaderInfoLog\0"]) {
storage::GetShaderInfoLog.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetShaderPrecisionFormat {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetShaderPrecisionFormat.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetShaderPrecisionFormat\0"])
{
storage::GetShaderPrecisionFormat.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetShaderSource {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetShaderSource.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetShaderSource\0", b"glGetShaderSourceARB\0"],
) {
storage::GetShaderSource.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetShaderiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetShaderiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetShaderiv\0"]) {
storage::GetShaderiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetString {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetString.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetString\0"]) {
storage::GetString.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetStringi {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetStringi.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetStringi\0"]) {
storage::GetStringi.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetSynciv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetSynciv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetSynciv\0", b"glGetSyncivAPPLE\0"])
{
storage::GetSynciv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetTexParameterfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetTexParameterfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetTexParameterfv\0"]) {
storage::GetTexParameterfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetTexParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetTexParameteriv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetTexParameteriv\0"]) {
storage::GetTexParameteriv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetTransformFeedbackVarying {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetTransformFeedbackVarying.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetTransformFeedbackVarying\0",
b"glGetTransformFeedbackVaryingEXT\0",
],
) {
storage::GetTransformFeedbackVarying.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetUniformBlockIndex {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetUniformBlockIndex.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetUniformBlockIndex\0"]) {
storage::GetUniformBlockIndex.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetUniformIndices {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetUniformIndices.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glGetUniformIndices\0"]) {
storage::GetUniformIndices.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetUniformLocation {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetUniformLocation.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetUniformLocation\0", b"glGetUniformLocationARB\0"],
) {
storage::GetUniformLocation.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetUniformfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetUniformfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetUniformfv\0", b"glGetUniformfvARB\0"])
{
storage::GetUniformfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetUniformiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetUniformiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glGetUniformiv\0", b"glGetUniformivARB\0"])
{
storage::GetUniformiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetUniformuiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetUniformuiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetUniformuiv\0", b"glGetUniformuivEXT\0"],
) {
storage::GetUniformuiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetVertexAttribIiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetVertexAttribIiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetVertexAttribIiv\0", b"glGetVertexAttribIivEXT\0"],
) {
storage::GetVertexAttribIiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetVertexAttribIuiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetVertexAttribIuiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glGetVertexAttribIuiv\0", b"glGetVertexAttribIuivEXT\0"],
) {
storage::GetVertexAttribIuiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetVertexAttribPointerv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetVertexAttribPointerv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetVertexAttribPointerv\0",
b"glGetVertexAttribPointervARB\0",
b"glGetVertexAttribPointervNV\0",
],
) {
storage::GetVertexAttribPointerv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetVertexAttribfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetVertexAttribfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetVertexAttribfv\0",
b"glGetVertexAttribfvARB\0",
b"glGetVertexAttribfvNV\0",
],
) {
storage::GetVertexAttribfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod GetVertexAttribiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::GetVertexAttribiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glGetVertexAttribiv\0",
b"glGetVertexAttribivARB\0",
b"glGetVertexAttribivNV\0",
],
) {
storage::GetVertexAttribiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Hint {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Hint.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glHint\0"]) {
storage::Hint.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod InvalidateFramebuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::InvalidateFramebuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glInvalidateFramebuffer\0"])
{
storage::InvalidateFramebuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod InvalidateSubFramebuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::InvalidateSubFramebuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glInvalidateSubFramebuffer\0"])
{
storage::InvalidateSubFramebuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsBuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsBuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glIsBuffer\0", b"glIsBufferARB\0"])
{
storage::IsBuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsEnabled {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsEnabled.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glIsEnabled\0"]) {
storage::IsEnabled.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsFramebuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsFramebuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glIsFramebuffer\0", b"glIsFramebufferEXT\0"],
) {
storage::IsFramebuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsProgram {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsProgram.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glIsProgram\0"]) {
storage::IsProgram.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsQuery {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsQuery.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glIsQuery\0", b"glIsQueryARB\0"])
{
storage::IsQuery.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsRenderbuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsRenderbuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glIsRenderbuffer\0", b"glIsRenderbufferEXT\0"],
) {
storage::IsRenderbuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsSampler {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsSampler.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glIsSampler\0"]) {
storage::IsSampler.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsShader {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsShader.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glIsShader\0"]) {
storage::IsShader.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsSync {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsSync.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glIsSync\0", b"glIsSyncAPPLE\0"])
{
storage::IsSync.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsTexture {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsTexture.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glIsTexture\0"]) {
storage::IsTexture.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsTransformFeedback {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsTransformFeedback.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glIsTransformFeedback\0", b"glIsTransformFeedbackNV\0"],
) {
storage::IsTransformFeedback.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod IsVertexArray {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::IsVertexArray.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glIsVertexArray\0",
b"glIsVertexArrayAPPLE\0",
b"glIsVertexArrayOES\0",
],
) {
storage::IsVertexArray.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod LineWidth {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::LineWidth.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glLineWidth\0"]) {
storage::LineWidth.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod LinkProgram {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::LinkProgram.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glLinkProgram\0", b"glLinkProgramARB\0"])
{
storage::LinkProgram.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod MapBufferRange {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::MapBufferRange.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glMapBufferRange\0", b"glMapBufferRangeEXT\0"],
) {
storage::MapBufferRange.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod PauseTransformFeedback {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::PauseTransformFeedback.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glPauseTransformFeedback\0", b"glPauseTransformFeedbackNV\0"],
) {
storage::PauseTransformFeedback.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod PixelStorei {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::PixelStorei.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glPixelStorei\0"]) {
storage::PixelStorei.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod PolygonOffset {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::PolygonOffset.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glPolygonOffset\0"]) {
storage::PolygonOffset.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ProgramBinary {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ProgramBinary.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glProgramBinary\0", b"glProgramBinaryOES\0"],
) {
storage::ProgramBinary.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ProgramParameteri {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ProgramParameteri.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glProgramParameteri\0",
b"glProgramParameteriARB\0",
b"glProgramParameteriEXT\0",
],
) {
storage::ProgramParameteri.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ReadBuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ReadBuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glReadBuffer\0"]) {
storage::ReadBuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ReadPixels {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ReadPixels.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glReadPixels\0"]) {
storage::ReadPixels.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ReleaseShaderCompiler {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ReleaseShaderCompiler.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glReleaseShaderCompiler\0"])
{
storage::ReleaseShaderCompiler.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod RenderbufferStorage {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::RenderbufferStorage.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glRenderbufferStorage\0", b"glRenderbufferStorageEXT\0"],
) {
storage::RenderbufferStorage.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod RenderbufferStorageMultisample {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::RenderbufferStorageMultisample.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glRenderbufferStorageMultisample\0",
b"glRenderbufferStorageMultisampleEXT\0",
b"glRenderbufferStorageMultisampleNV\0",
],
) {
storage::RenderbufferStorageMultisample
.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ResumeTransformFeedback {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ResumeTransformFeedback.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glResumeTransformFeedback\0", b"glResumeTransformFeedbackNV\0"],
) {
storage::ResumeTransformFeedback.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod SampleCoverage {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::SampleCoverage.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glSampleCoverage\0", b"glSampleCoverageARB\0"],
) {
storage::SampleCoverage.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod SamplerParameterf {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::SamplerParameterf.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glSamplerParameterf\0"]) {
storage::SamplerParameterf.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod SamplerParameterfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::SamplerParameterfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glSamplerParameterfv\0"]) {
storage::SamplerParameterfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod SamplerParameteri {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::SamplerParameteri.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glSamplerParameteri\0"]) {
storage::SamplerParameteri.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod SamplerParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::SamplerParameteriv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glSamplerParameteriv\0"]) {
storage::SamplerParameteriv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Scissor {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Scissor.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glScissor\0"]) {
storage::Scissor.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ShaderBinary {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ShaderBinary.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glShaderBinary\0"]) {
storage::ShaderBinary.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ShaderSource {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ShaderSource.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glShaderSource\0", b"glShaderSourceARB\0"])
{
storage::ShaderSource.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod StencilFunc {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::StencilFunc.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glStencilFunc\0"]) {
storage::StencilFunc.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod StencilFuncSeparate {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::StencilFuncSeparate.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glStencilFuncSeparate\0"]) {
storage::StencilFuncSeparate.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod StencilMask {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::StencilMask.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glStencilMask\0"]) {
storage::StencilMask.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod StencilMaskSeparate {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::StencilMaskSeparate.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glStencilMaskSeparate\0"]) {
storage::StencilMaskSeparate.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod StencilOp {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::StencilOp.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glStencilOp\0"]) {
storage::StencilOp.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod StencilOpSeparate {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::StencilOpSeparate.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glStencilOpSeparate\0", b"glStencilOpSeparateATI\0"],
) {
storage::StencilOpSeparate.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexImage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexImage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glTexImage2D\0"]) {
storage::TexImage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexImage3D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexImage3D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glTexImage3D\0", b"glTexImage3DEXT\0"])
{
storage::TexImage3D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexParameterf {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexParameterf.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glTexParameterf\0"]) {
storage::TexParameterf.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexParameterfv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexParameterfv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glTexParameterfv\0"]) {
storage::TexParameterfv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexParameteri {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexParameteri.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glTexParameteri\0"]) {
storage::TexParameteri.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexParameteriv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexParameteriv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glTexParameteriv\0"]) {
storage::TexParameteriv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexStorage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexStorage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glTexStorage2D\0", b"glTexStorage2DEXT\0"])
{
storage::TexStorage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexStorage3D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexStorage3D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glTexStorage3D\0", b"glTexStorage3DEXT\0"])
{
storage::TexStorage3D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexSubImage2D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexSubImage2D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glTexSubImage2D\0", b"glTexSubImage2DEXT\0"],
) {
storage::TexSubImage2D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TexSubImage3D {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TexSubImage3D.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glTexSubImage3D\0", b"glTexSubImage3DEXT\0"],
) {
storage::TexSubImage3D.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod TransformFeedbackVaryings {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::TransformFeedbackVaryings.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glTransformFeedbackVaryings\0", b"glTransformFeedbackVaryingsEXT\0"],
) {
storage::TransformFeedbackVaryings.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform1f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform1f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform1f\0", b"glUniform1fARB\0"])
{
storage::Uniform1f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform1fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform1fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform1fv\0", b"glUniform1fvARB\0"])
{
storage::Uniform1fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform1i {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform1i.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform1i\0", b"glUniform1iARB\0"])
{
storage::Uniform1i.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform1iv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform1iv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform1iv\0", b"glUniform1ivARB\0"])
{
storage::Uniform1iv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform1ui {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform1ui.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform1ui\0", b"glUniform1uiEXT\0"])
{
storage::Uniform1ui.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform1uiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform1uiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform1uiv\0", b"glUniform1uivEXT\0"])
{
storage::Uniform1uiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform2f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform2f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform2f\0", b"glUniform2fARB\0"])
{
storage::Uniform2f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform2fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform2fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform2fv\0", b"glUniform2fvARB\0"])
{
storage::Uniform2fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform2i {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform2i.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform2i\0", b"glUniform2iARB\0"])
{
storage::Uniform2i.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform2iv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform2iv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform2iv\0", b"glUniform2ivARB\0"])
{
storage::Uniform2iv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform2ui {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform2ui.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform2ui\0", b"glUniform2uiEXT\0"])
{
storage::Uniform2ui.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform2uiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform2uiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform2uiv\0", b"glUniform2uivEXT\0"])
{
storage::Uniform2uiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform3f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform3f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform3f\0", b"glUniform3fARB\0"])
{
storage::Uniform3f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform3fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform3fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform3fv\0", b"glUniform3fvARB\0"])
{
storage::Uniform3fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform3i {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform3i.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform3i\0", b"glUniform3iARB\0"])
{
storage::Uniform3i.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform3iv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform3iv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform3iv\0", b"glUniform3ivARB\0"])
{
storage::Uniform3iv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform3ui {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform3ui.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform3ui\0", b"glUniform3uiEXT\0"])
{
storage::Uniform3ui.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform3uiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform3uiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform3uiv\0", b"glUniform3uivEXT\0"])
{
storage::Uniform3uiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform4f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform4f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform4f\0", b"glUniform4fARB\0"])
{
storage::Uniform4f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform4fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform4fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform4fv\0", b"glUniform4fvARB\0"])
{
storage::Uniform4fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform4i {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform4i.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform4i\0", b"glUniform4iARB\0"])
{
storage::Uniform4i.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform4iv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform4iv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform4iv\0", b"glUniform4ivARB\0"])
{
storage::Uniform4iv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform4ui {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform4ui.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform4ui\0", b"glUniform4uiEXT\0"])
{
storage::Uniform4ui.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Uniform4uiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Uniform4uiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glUniform4uiv\0", b"glUniform4uivEXT\0"])
{
storage::Uniform4uiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformBlockBinding {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformBlockBinding.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glUniformBlockBinding\0"]) {
storage::UniformBlockBinding.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix2fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix2fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix2fv\0", b"glUniformMatrix2fvARB\0"],
) {
storage::UniformMatrix2fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix2x3fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix2x3fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix2x3fv\0", b"glUniformMatrix2x3fvNV\0"],
) {
storage::UniformMatrix2x3fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix2x4fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix2x4fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix2x4fv\0", b"glUniformMatrix2x4fvNV\0"],
) {
storage::UniformMatrix2x4fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix3fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix3fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix3fv\0", b"glUniformMatrix3fvARB\0"],
) {
storage::UniformMatrix3fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix3x2fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix3x2fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix3x2fv\0", b"glUniformMatrix3x2fvNV\0"],
) {
storage::UniformMatrix3x2fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix3x4fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix3x4fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix3x4fv\0", b"glUniformMatrix3x4fvNV\0"],
) {
storage::UniformMatrix3x4fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix4fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix4fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix4fv\0", b"glUniformMatrix4fvARB\0"],
) {
storage::UniformMatrix4fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix4x2fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix4x2fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix4x2fv\0", b"glUniformMatrix4x2fvNV\0"],
) {
storage::UniformMatrix4x2fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UniformMatrix4x3fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UniformMatrix4x3fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUniformMatrix4x3fv\0", b"glUniformMatrix4x3fvNV\0"],
) {
storage::UniformMatrix4x3fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UnmapBuffer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UnmapBuffer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUnmapBuffer\0", b"glUnmapBufferARB\0", b"glUnmapBufferOES\0"],
) {
storage::UnmapBuffer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod UseProgram {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::UseProgram.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glUseProgram\0", b"glUseProgramObjectARB\0"],
) {
storage::UseProgram.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod ValidateProgram {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::ValidateProgram.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glValidateProgram\0", b"glValidateProgramARB\0"],
) {
storage::ValidateProgram.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib1f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib1f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib1f\0",
b"glVertexAttrib1fARB\0",
b"glVertexAttrib1fNV\0",
],
) {
storage::VertexAttrib1f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib1fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib1fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib1fv\0",
b"glVertexAttrib1fvARB\0",
b"glVertexAttrib1fvNV\0",
],
) {
storage::VertexAttrib1fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib2f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib2f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib2f\0",
b"glVertexAttrib2fARB\0",
b"glVertexAttrib2fNV\0",
],
) {
storage::VertexAttrib2f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib2fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib2fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib2fv\0",
b"glVertexAttrib2fvARB\0",
b"glVertexAttrib2fvNV\0",
],
) {
storage::VertexAttrib2fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib3f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib3f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib3f\0",
b"glVertexAttrib3fARB\0",
b"glVertexAttrib3fNV\0",
],
) {
storage::VertexAttrib3f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib3fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib3fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib3fv\0",
b"glVertexAttrib3fvARB\0",
b"glVertexAttrib3fvNV\0",
],
) {
storage::VertexAttrib3fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib4f {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib4f.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib4f\0",
b"glVertexAttrib4fARB\0",
b"glVertexAttrib4fNV\0",
],
) {
storage::VertexAttrib4f.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttrib4fv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttrib4fv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttrib4fv\0",
b"glVertexAttrib4fvARB\0",
b"glVertexAttrib4fvNV\0",
],
) {
storage::VertexAttrib4fv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribDivisor {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribDivisor.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[
b"glVertexAttribDivisor\0",
b"glVertexAttribDivisorANGLE\0",
b"glVertexAttribDivisorARB\0",
b"glVertexAttribDivisorEXT\0",
b"glVertexAttribDivisorNV\0",
],
) {
storage::VertexAttribDivisor.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribI4i {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribI4i.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glVertexAttribI4i\0", b"glVertexAttribI4iEXT\0"],
) {
storage::VertexAttribI4i.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribI4iv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribI4iv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glVertexAttribI4iv\0", b"glVertexAttribI4ivEXT\0"],
) {
storage::VertexAttribI4iv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribI4ui {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribI4ui.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glVertexAttribI4ui\0", b"glVertexAttribI4uiEXT\0"],
) {
storage::VertexAttribI4ui.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribI4uiv {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribI4uiv.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glVertexAttribI4uiv\0", b"glVertexAttribI4uivEXT\0"],
) {
storage::VertexAttribI4uiv.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribIPointer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribIPointer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glVertexAttribIPointer\0", b"glVertexAttribIPointerEXT\0"],
) {
storage::VertexAttribIPointer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod VertexAttribPointer {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::VertexAttribPointer.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(
&mut load_fn,
&[b"glVertexAttribPointer\0", b"glVertexAttribPointerARB\0"],
) {
storage::VertexAttribPointer.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod Viewport {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::Viewport.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) = meta_loader(&mut load_fn, &[b"glViewport\0"]) {
storage::Viewport.store(p.as_ptr(), Ordering::SeqCst);
};
}
}
pub mod WaitSync {
use super::*;
#[inline]
pub fn is_loaded() -> bool {
!storage::WaitSync.load(Ordering::Relaxed).is_null()
}
pub unsafe fn load_with<F>(mut load_fn: F)
where
F: FnMut(*const c_char) -> *const c_void,
{
if let Some(p) =
meta_loader(&mut load_fn, &[b"glWaitSync\0", b"glWaitSyncAPPLE\0"])
{
storage::WaitSync.store(p.as_ptr(), Ordering::SeqCst);
};
}
}