Rust library for build scripts to compile ISPC code into a Rust library
Clone or download
Failed to load latest commit information.
examples deps, update travis to run examples Nov 11, 2018
src skip nightly w/ clippy Nov 11, 2018
.gitignore gitignores Jun 4, 2018
.travis.yml skip nightly w/ clippy Nov 11, 2018
Cargo.toml skip nightly w/ clippy Nov 11, 2018 Working on readme Apr 16, 2016 update version Nov 11, 2018


A small library meant to be used as a build dependency with Cargo for easily integrating ISPC code into Rust projects. Build Status


Rust doc can be found here, ISPC documentation can be found here.

Using ispc-rs

You'll want to add a build script to your crate (, tell Cargo about it and add this crate as a build dependency and optionally as a runtime dependency if you plan to use the ispc_module macro or ISPC tasks.

# Cargo.toml
# ...
build = ""

ispc = "0.3.8"

ispc = "0.3.8"

Now you can use ispc to compile your code into a static library:

extern crate ispc;

fn main() {
	// Compile our ISPC library, this call will exit with EXIT_FAILURE if
	// compilation fails
	ispc::compile_library("simple", &["src/simple.ispc"]);

Running cargo build should now build your ISPC files into a library and link your Rust application with it. For extra convenience the ispc_module macro is provided to import bindings to the library generated with rust-bindgen into a module of the same name. Note that all the functions imported will be unsafe as they're the raw C bindings to your lib.

extern crate ispc;

// Functions exported from simple will be callable under simple::*

Some more complete examples can be found in the examples/ folder.

Compile-time Requirements

Both the ISPC compiler and libclang (for rust-bindgen) must be available in your path.

Windows Users

You'll need Visual Studio and will have to use the MSVC ABI version of Rust since ISPC and Clang link with MSVC on Windows. For bindgen to find libclang you'll need to copy libclang.lib to clang.lib and place it in your path.