f6ba5b8298
845: Finish error model refactor r=kvark a=GabrielMajeri **Connections** I think this is the last part of #638. I've reviewed all the remaining `unwrap`s and `assert`s in the code, and these should be the last ones left which ought to return errors (the remaining ones seem to uphold internal invariants). **Description** Implements error handling for various conditions, which are then returned to the caller. Including, but not limited to: - running out of memory when creating a command pool - running out of memory when creating a frame buffer for a render pass - invalid dimensions when creating a texture **Testing** Tested with core and player. Co-authored-by: Gabriel Majeri <gabriel.majeri6@gmail.com> |
||
---|---|---|
.github | ||
dummy | ||
player | ||
wgpu-core | ||
wgpu-types | ||
.gitignore | ||
.monocodus | ||
bors.toml | ||
Cargo.lock | ||
Cargo.toml | ||
CHANGELOG.md | ||
LICENSE | ||
logo.png | ||
README.md | ||
rustfmt.toml |
This is an active GitHub mirror of the WebGPU implementation in Rust, which now lives in "gfx/wgpu" of Mozilla-central. Issues and pull requests are accepted, but some bidirectional synchronization may be involved.
WebGPU
This is the core logic of an experimental WebGPU implementation. It's written in Rust and is based on gfx-hal with help of gfx-extras. See the upstream WebGPU specification (work in progress).
The implementation consists of the following parts:
- - internal Rust API for WebGPU implementations to use
- - Rust types shared between
wgpu-core
,wgpu-native
, andwgpu-rs
player
- standalone application for replaying the API traces, useswinit
This repository contains the core of wgpu
, and is not usable directly by applications.
If you are looking for the user-facing Rust API, you need wgpu-rs.
If you are looking for the native implementation or bindings to the API in other languages, you need wgpu-native.
Supported Platforms
API | Windows 7/10 | Linux & Android | macOS & iOS |
---|---|---|---|
DX11 | ✅ | ||
DX12 | ✔️ | ||
Vulkan | ✔️ | ✔️ | |
Metal | ✔️ | ||
OpenGL | 🚧 | 🚧 | 🚧 |
✔️ = Primary support — ✅ = Secondary support — 🚧 = Unsupported, but support in progress