vkgen 0.1.1

Generates Rust source code from vk.xml
vkgen-0.1.1 is not a library.
Visit the last successful build: vkgen-2.2.1

vkgen

Generates Rust source code from vk.xml

Usage

$ vkgen <input file> <output file>

  • input file should be the Vulkan registry (vk.xml)
  • output file will be created if it does not exist

To use the generated file one has to add libloading to cargo.toml:

[dependencies]
libloading = "0.5.0"

This is required to load vkGetInstanceProcAddr from a shared library. All other functions are loaded dynamically via vkGetInstanceProcAddr and vkGetDeviceProcAddr to avoid additional overhead.

Examples

This simple example demonstrates how to load libvulkan on linux and output the instance version (1.1.0). vk.rs is a file containing the generated rust source code. The location of libvulkan.so/vulkan.dll may vary depending on the OS.

mod vk;

use self::vk::*;

fn main() {
	unsafe { vkLoad("/usr/lib/x86_64-linux-gnu/libvulkan.so.1.1.92"); }

	let mut v: u32 = 0;
	vkEnumerateInstanceVersion(&mut v as *mut u32);
	println!("vulkan instance version is {}.{}.{}", VK_VERSION_MAJOR(v), VK_VERSION_MINOR(v), VK_VERSION_PATCH(v));
}

Known Issues

  • type aliases are generated for C++ types (uint32_t, uint64_t, ...)
  • some type aliases are not generated
  • enum aliases are not generated