Cross-platform, safe, pure-rust graphics api.
Go to file
2019-07-29 22:40:25 +02:00
examples add framework files 2019-07-27 14:30:20 +02:00
ffi Make PresentMode configurable 2019-07-11 18:58:44 +02:00
wgpu-native Run-time lock protection against double root 2019-07-23 23:46:32 -04:00
wgpu-remote Add some more comments about Access and Token' 2019-07-04 23:02:22 -04:00
.clang-format Reduce left indentation for nested structs 2019-03-08 07:15:36 -07:00
.gitignore Range merging unit tests 2019-06-13 11:08:53 -04:00
.travis.yml Debug tracking derives and regular optimization 2019-06-14 14:05:27 -04:00
bors.toml CI scripts 2018-09-14 11:39:24 -04:00
Cargo.lock Rebind with proper dynamic offsets 2019-07-22 00:16:29 -04:00
Cargo.toml Remove Rust wrapper and examples 2019-05-10 20:40:42 -04:00
CHANGELOG.md Fix typos. 2019-05-24 14:46:37 +07:00
LICENSE Initial commit 2018-09-13 15:18:51 -04:00
Makefile streamline Makefile 2019-07-29 22:40:25 +02:00
README.md add framework files 2019-07-27 14:30:20 +02:00
rustfmt.toml Enforce the HUB lock order 2019-07-04 14:43:54 -04:00

This is an active GitHub mirror of the WebGPU native implementation in Rust, which now lives in Mozilla-central. Issues and pull requests are accepted, but we merge them in m-c manually and then sync to GitHub instead of landing directly here.


WebGPU

Build Status Crates.io Gitter

This is an experimental WebGPU implementation as a native static library. It's written in Rust and is based on gfx-hal and Rendy libraries. The corresponding WebIDL specification can be found at gpuweb project.

The implementation consists of the following parts:

  1. wgpu-native - the native implementation of WebGPU as a C API library
  2. wgpu-remote - remoting layer to work with WebGPU across the process boundary
  3. ffi - the C headers generated by cbindgen for both of the libraries

Supported platforms:

  • Vulkan on Windows and Linux
  • D3D12 and D3D11 on Windows
  • Metal on macOS and iOS

Usage

This repository contains C-language examples that link to the native library targets and perform basic rendering and computation.

Prerequisites

  • C compiler
  • GLFW 3
  • Rust nightly toolchain
      rustup toolchain install nightly  
    
  • Cbindgen
      cargo install cbindgen 
    

Running an example

The examples are located under the examples directory. We are using a Makefile for running the examples.

Triangle

make example-triangle

Compute

make example-compute

Remote

make example-remote

The idiomatic Rust wrapper lives in https://github.com/gfx-rs/wgpu-rs and provides a number of more complex examples to get a feel of the API.