pub struct PipelineCache { /* private fields */ }
Expand description

Opaque cache that contains pipeline objects.

See the documentation of the module for more info.

Implementations§

source§

impl PipelineCache

source

pub unsafe fn new( device: Arc<Device>, create_info: PipelineCacheCreateInfo ) -> Result<Arc<PipelineCache>, Validated<VulkanError>>

Builds a new pipeline cache.

Safety
  • The data in create_info.initial_data must be valid data that was previously retrieved using get_data.
Examples

This example loads a cache from a file, if it exists. See get_data for how to store the data in a file.

use std::fs::File;
use std::io::Read;
use vulkano::pipeline::cache::{PipelineCache, PipelineCacheCreateInfo};

let initial_data = {
    let file = File::open("pipeline_cache.bin");
    if let Ok(mut file) = file {
        let mut data = Vec::new();
        if let Ok(_) = file.read_to_end(&mut data) {
            data
        } else {
            Vec::new()
        }
    } else {
        Vec::new()
    }
};

// This is unsafe because there is no way to be sure that the file contains valid data.
let cache = unsafe {
    PipelineCache::new(
        device.clone(),
        PipelineCacheCreateInfo {
            initial_data,
            ..Default::default()
        }
    ).unwrap()
};
source

pub unsafe fn from_handle( device: Arc<Device>, handle: PipelineCache, create_info: PipelineCacheCreateInfo ) -> Arc<PipelineCache>

Creates a new PipelineCache from a raw object handle.

Safety
  • handle must be a valid Vulkan object handle created from device.
  • create_info must match the info used to create the object.
source

pub fn flags(&self) -> PipelineCacheCreateFlags

Returns the flags that the pipeline cache was created with.

source

pub fn get_data(&self) -> Result<Vec<u8>, VulkanError>

Obtains the data from the cache.

This data can be stored and then reloaded and passed to PipelineCache::new.

Examples
use std::fs;
use std::fs::File;
use std::io::Write;

// If an error happens (eg. no permission for the file) we simply skip storing the cache.
if let Ok(data) = cache.get_data() {
    if let Ok(mut file) = File::create("pipeline_cache.bin.tmp") {
        if let Ok(_) = file.write_all(&data) {
            let _ = fs::rename("pipeline_cache.bin.tmp", "pipeline_cache.bin");
        } else {
            let _ = fs::remove_file("pipeline_cache.bin.tmp");
        }
    }
}
source

pub fn merge<'a>( &self, src_caches: impl IntoIterator<Item = &'a PipelineCache> ) -> Result<(), Validated<VulkanError>>

Merges other pipeline caches into this one.

It is self that is modified here. The pipeline caches passed as parameter are untouched.

Trait Implementations§

source§

impl Debug for PipelineCache

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl DeviceOwned for PipelineCache

source§

fn device(&self) -> &Arc<Device>

Returns the device that owns self.
source§

impl Drop for PipelineCache

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl Hash for PipelineCache

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl PartialEq for PipelineCache

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl VulkanObject for PipelineCache

§

type Handle = PipelineCache

The type of the object.
source§

fn handle(&self) -> Self::Handle

Returns the raw Vulkan handle of the object.
source§

impl Eq for PipelineCache

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> DeviceOwnedVulkanObject for Twhere T: DeviceOwned + VulkanObject,

source§

fn set_debug_utils_object_name( &self, object_name: Option<&str> ) -> Result<(), VulkanError>

Assigns a human-readable name to the object for debugging purposes. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.