This is a pragmatic binding to different OpenGL versions.
It uses the official OpenGL Registry by Khronos to generate the Zig code.
Right now, it does minimal adjustments like removing the gl prefix from functions or the GL_ prefix from constants. Everything else is the same as the C API.
There is a single non-OpenGL function exported:
pub fn load(load_ctx: anytype, get_proc_address: fn(@TypeOf(load_ctx), [:0]const u8) ?*FunctionPointer) !void {This function will load all OpenGL entry points with the help of get_proc_address. It receives the load_ctx as well as the function name.
NOTE: Please do not reference zig-opengl as a submodule or a package. Generate a binding and copy the output of that into your repository and update the file on demand. The OpenGL Registry is just too huge to be used conveniently.
Cloning submodules is required, so use --recursive:
git clone --recursive https://github.com/ikskuh/zig-opengl.gitThis example uses ZWL by @Aransentin.
const zwl = @import("zwl");
const Platform = zwl.Platform(…);
pub fn initAndDraw(window: Platform.Window) !void {
  try gl.load(window.platform, Platform.getOpenGlProcAddress);
  while(true) {
    gl.clearColor(1, 0, 1, 1);
    gl.clear(gl.COLOR_BUFFER_BIT);
    try window.present();
  }
}There is an example of mach-glfw + zig-opengl usage available here: https://github.com/hexops/mach-glfw-opengl-example
This repository contains pre-generated bindings for all extension-free OpenGL versions.
To generate your own loader, you have to clone this repository and build the generator with dotnet:
user@machine:~/zig-opengl$ dotnet run
Usage: generator <registry> <result> <api_version> [<extension>] [<extension>] ...
user@machine:~/zig-opengl$ dotnet run OpenGL-Registry/xml/gl.xml gl3v3.zig GL_VERSION_3_3
Final API has 344 commands and 818 enums types.
user@machine:~/zig-opengl$dotnet run \
  OpenGL-Registry/xml/gl.xml \ # path to the opengl registry
  my_binding.zig             \ # path to the generated file
  GL_VERSION_3_3             \ # feature level, options listed below
  …                            # Add your extensions here, each as a single arg. Or let them out, you don't need extensionsPossible feature levels (at the time of writing) are:
GL_VERSION_1_0GL_VERSION_1_1GL_VERSION_1_2GL_VERSION_1_3GL_VERSION_1_4GL_VERSION_1_5GL_VERSION_2_0GL_VERSION_2_1GL_VERSION_3_0GL_VERSION_3_1GL_VERSION_3_2GL_VERSION_3_3GL_VERSION_4_0GL_VERSION_4_1GL_VERSION_4_2GL_VERSION_4_3GL_VERSION_4_4GL_VERSION_4_5GL_VERSION_4_6GL_VERSION_ES_CM_1_0GL_ES_VERSION_2_0GL_ES_VERSION_3_0GL_ES_VERSION_3_1GL_ES_VERSION_3_2GL_SC_VERSION_2_0This library uses a small C# script that generates the Zig bindings. It is located in src/Generator.cs
core or compatibility profile.