Update the readme
This commit is contained in:
parent
8373f43e23
commit
4bf5888b15
25
README.md
25
README.md
|
@ -14,7 +14,8 @@ A very lightweight wrapper around Vulkan
|
||||||
## Overview
|
## Overview
|
||||||
- [x] A true Vulkan API without compromises
|
- [x] A true Vulkan API without compromises
|
||||||
- [x] Convenience features that don't limit the functionality
|
- [x] Convenience features that don't limit the functionality
|
||||||
- [x] Function pointer loading
|
- [x] Additional type safety
|
||||||
|
- [x] Device local function pointer loading
|
||||||
- [x] No validation, everything is **unsafe**
|
- [x] No validation, everything is **unsafe**
|
||||||
- [x] Generated from `vk.xml`
|
- [x] Generated from `vk.xml`
|
||||||
|
|
||||||
|
@ -31,7 +32,7 @@ let instance = entry.create_instance(&create_info, None)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### Returns a `Vec<T>` (*when possible*) for functions that output multiple values.
|
### `Vec<T>` instead of mutable slices
|
||||||
|
|
||||||
```Rust
|
```Rust
|
||||||
pub fn get_swapchain_images_khr(&self,
|
pub fn get_swapchain_images_khr(&self,
|
||||||
|
@ -39,8 +40,9 @@ pub fn get_swapchain_images_khr(&self,
|
||||||
-> VkResult<Vec<vk::Image>>;
|
-> VkResult<Vec<vk::Image>>;
|
||||||
let present_images = swapchain_loader.get_swapchain_images_khr(swapchain).unwrap();
|
let present_images = swapchain_loader.get_swapchain_images_khr(swapchain).unwrap();
|
||||||
```
|
```
|
||||||
|
*Note*: Functions don't return `Vec<T>` if this would limit the functionality. See `p_next`.
|
||||||
|
|
||||||
### Slices in functions
|
### Slices
|
||||||
```Rust
|
```Rust
|
||||||
pub fn cmd_pipeline_barrier(&self,
|
pub fn cmd_pipeline_barrier(&self,
|
||||||
command_buffer: vk::CommandBuffer,
|
command_buffer: vk::CommandBuffer,
|
||||||
|
@ -72,12 +74,13 @@ let pipeline_vertex_input_state_create_info = vk::PipelineVertexInputStateCreate
|
||||||
### Flags and constants as associated constants
|
### Flags and constants as associated constants
|
||||||
|
|
||||||
```Rust
|
```Rust
|
||||||
dst_access_mask: vk::AccessFlags::COLOR_ATTACHMENT_READ
|
// Bitflag
|
||||||
| vk::AccessFlags::COLOR_ATTACHMENT_WRITE,
|
vk::AccessFlags::COLOR_ATTACHMENT_READ | vk::AccessFlags::COLOR_ATTACHMENT_WRITE
|
||||||
```
|
```
|
||||||
|
|
||||||
```Rust
|
```Rust
|
||||||
pipeline_bind_point: vk::PipelineBindPoint::GRAPHICS,
|
// Constant
|
||||||
|
vk::PipelineBindPoint::GRAPHICS,
|
||||||
```
|
```
|
||||||
### Debug/Display for Flags
|
### Debug/Display for Flags
|
||||||
|
|
||||||
|
@ -92,7 +95,7 @@ println!("Display: {}", flag);
|
||||||
```
|
```
|
||||||
|
|
||||||
### Interop
|
### Interop
|
||||||
|
Vulkan objects inside Ash can be constructed from raw values with `Object::from:raw`. Useful if you need to interact with a C library.
|
||||||
```Rust
|
```Rust
|
||||||
PipelineBindPoint::from_raw(bindpoint);
|
PipelineBindPoint::from_raw(bindpoint);
|
||||||
```
|
```
|
||||||
|
@ -108,6 +111,14 @@ let swapchain_loader = Swapchain::new(&instance, &device);
|
||||||
let swapchain = swapchain_loader.create_swapchain_khr(&swapchain_create_info).unwrap();
|
let swapchain = swapchain_loader.create_swapchain_khr(&swapchain_create_info).unwrap();
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Raw function pointers
|
||||||
|
|
||||||
|
Raw function pointers are available, if something hasn't been exposed yet in the higher level API. Please open an issue if anything is missing.
|
||||||
|
|
||||||
|
```Rust
|
||||||
|
device.fp_v1_0().destroy_device(...);
|
||||||
|
```
|
||||||
|
|
||||||
### Support for extension names
|
### Support for extension names
|
||||||
```Rust
|
```Rust
|
||||||
use ash::extensions::{Swapchain, XlibSurface, Surface, DebugReport};
|
use ash::extensions::{Swapchain, XlibSurface, Surface, DebugReport};
|
||||||
|
|
Loading…
Reference in a new issue