sokol-d 0.1.7

D bindings for sokol


To use this package, run the following command in your project's root directory:

Manual usage
Put the following dependency into your project's dependences section:

CI Build

Auto-generated D bindings for the sokol headers.

Targets
  • Native
  • Wasm (-Dtarget=wasm32-emscripten-none) - LTO enabled on release-mode.

By default, the backend 3D API will be selected based on the target platform:

  • macOS: Metal
  • Windows: D3D11
  • Linux: GL

BUILD

Required

  • zig v0.13.0 or master
  • ldc v1.40.0 or latest-CI (nightly)

Supported platforms are: Windows, macOS, Linux (with X11)

On Linux install the following packages: libglu1-mesa-dev, mesa-common-dev, xorg-dev, libasound-dev (or generally: the dev packages required for X11, GL and ALSA development)

# build sokol library + all examples [default: static library]
zig build

# build sokol shared library + all examples
zig build -Dshared

# build sokol library only
zig build -Dartifact

# Run Examples
zig build run-blend
zig build run-bufferoffsets
zig build run-clear
zig build run-cube
zig build run-debugtext
zig build run-mrt
zig build run-saudio
zig build run-instancing
zig build run-offscreen
zig build run-sgl_context
zig build run-sgl_points
zig build run-user_data
zig build run-noninterleaved
zig build run-texcube
zig build run-quad
zig build run-triangle
zig build run-shapes
zig build run-vertexpull
zig build run-imgui -Dimgui # optional: -Dimgui-version=docking
zig build run-droptest -Dimgui # optional: -Dimgui-version=docking

zig build --help
# Project-Specific Options:
#   -Dgl=[bool]                  Force OpenGL (default: false)
#   -Dgles3=[bool]               Force OpenGL ES3 (default: false)
#   -Dwgpu=[bool]                Force WebGPU (default: false, web only)
#   -Dx11=[bool]                 Force X11 (default: true, Linux only)
#   -Dwayland=[bool]             Force Wayland (default: false, Linux only, not supported in main-line headers)
#   -Degl=[bool]                 Force EGL (default: false, Linux only)
#   -Dimgui=[bool]               Add support for sokol_imgui.h bindings
#   -Dartifact=[bool]            Build artifacts (default: false)
#   -DbetterC=[bool]             Omit generating some runtime information and helper functions (default: false)
#   -DzigCC=[bool]               Use zig cc as compiler and linker (default: false)
#   -Dtarget=[string]            The CPU architecture, OS, and ABI to build for
#   -Dcpu=[string]               Target CPU features to add or subtract
#   -Ddynamic-linker=[string]    Path to interpreter on the target system
#   -Doptimize=[enum]            Prioritize performance, safety, or binary size
#                                  Supported Values:
#                                    Debug
#                                    ReleaseSafe
#                                    ReleaseFast
#                                    ReleaseSmall
#   -Dshared=[bool]              Build sokol dynamic library (default: static)
#   -Dubsan=[bool]               Enable undefined behavior sanitizer
#   -Dtsan=[bool]                Enable thread sanitizer
#   -Dimgui-version=[enum]       Select ImGui version to use
#                                  Supported Values:
#                                    default
#                                    docking

(also run zig build -l to get a list of build targets)

Shaders

Checkout sokol-tools for a sokol shader pipeline! It supports these D bindings and all shaders in the examples folder here have been compiled using it with -f sokol_d!

zig build shaders # (re)generate D bindings from shaders.


License and attributions

<sub> This code is released under the zlib license (see LICENSE for info). Parts of gen_d.py have been copied and modified from the zig-bindings (https://github.com/floooh/sokol-zig/) and rust-bindings (https://github.com/floooh/sokol-rust/) for sokol. </sub>

<sub> The sokol headers are created by Andre Weissflog (floooh) and sokol is released under its own license here: https://github.com/floooh/sokol/blob/master/LICENSE </sub> </br>

Authors:
  • Matheus Catarino França
  • Andre Weissflog
Sub packages:
sokol-d:clear, sokol-d:offscreen, sokol-d:sgl_context, sokol-d:sgl_points, sokol-d:debugtext, sokol-d:triangle, sokol-d:blend, sokol-d:saudio, sokol-d:mrt, sokol-d:cube, sokol-d:texcube, sokol-d:user_data, sokol-d:quad, sokol-d:noninterleaved, sokol-d:vertexpull, sokol-d:bufferoffsets, sokol-d:instancing, sokol-d:shapes, sokol-d:imgui, sokol-d:droptest
Dependencies:
none
Versions:
0.1.7 2024-Dec-29
0.1.6 2024-Dec-07
0.1.5 2024-Nov-07
0.1.4 2024-Sep-24
0.1.3 2024-Aug-14
Show all 8 versions
Download Stats:
  • 0 downloads today

  • 0 downloads this week

  • 1 downloads this month

  • 24 downloads total

Score:
1.3
Short URL:
sokol-d.dub.pm