5 releases

2023.12.14+0b7073b.1 Nov 21, 2024
0.1.4+2024.11.22-df583a3.1 Dec 16, 2024
0.1.2+2024.11.22-df583a3.1 Nov 28, 2024

#52 in Windows APIs

Download history 418/week @ 2024-11-21 1203/week @ 2024-11-28 761/week @ 2024-12-05 2040/week @ 2024-12-12

4,422 downloads per month

MIT license

19KB
329 lines

mach-dxcompiler-rs

Crates.io Docs.rs

This library allows for statically linking prebuilt binaries from mach-dxcompiler into a Rust project. The mach-dxcompiler repository is a fork of Microsoft's DirectXShaderCompiler that replaces the CMake build system with Zig. This allows for building the project statically and linking it into existing applications - but the core logic comes from the original DXC library.

Usage

The curl.exe and tar.exe command line utilities are required for this crate's build script. They should be installed by default in Windows 10 and 11.

First, add this crate to the project: cargo add mach-dxcompiler-rs

Next, use the DxcCreateInstance function to create DXC COM objects. Once created, these objects are usable with the normal COM windows API.

use windows::Win32::Graphics::Direct3D::Dxc;

let mut dxcompiler = std::ptr::null_mut();
mach_dxcompiler_rs::DxcCreateInstance(&Dxc::CLSID_DxcCompiler, &Dxc::IDxcCompiler3::IID, &mut dxcompiler);
// ... use the shader compiler ...

Visual Studio Requirement

For MSVC users, ensure that your version of Visual Studio is at least 17.11 or higher. This is necessary for compatibility with the build tools and libraries used in this project.

No runtime deps

~0–540KB