use utils::c_bindings::*;
use utils::vk_traits::*;
use utils::vk_ptr::*;
use utils::vk_convert::*;
use std::os::raw::c_char;
use std::ops::Drop;
use std::ptr;
use std::mem;
use std::cmp;
use std::slice;
use vulkan::*;
use vulkan::vk::*;
#[doc(hidden)]
pub type RawVkPipelineCache = u64;
#[derive(Debug, Clone, Copy)]
pub struct VkPipelineCache {
_handle: RawVkPipelineCache,
_fn_table: *mut VkFunctionTable
}
impl VkRawType<VkPipelineCache> for RawVkPipelineCache {
fn vk_to_wrapped(src: &RawVkPipelineCache) -> VkPipelineCache {
VkPipelineCache {
_handle: *src,
_fn_table: ptr::null_mut()
}
}
}
impl VkWrappedType<RawVkPipelineCache> for VkPipelineCache {
fn vk_to_raw(src: &VkPipelineCache, dst: &mut RawVkPipelineCache) {
*dst = src._handle
}
}
impl Default for VkPipelineCache {
fn default() -> VkPipelineCache {
VkPipelineCache {
_handle: 0,
_fn_table: ptr::null_mut()
}
}
}
impl PartialEq for VkPipelineCache {
fn eq(&self, other: &VkPipelineCache) -> bool {
self._handle == other._handle
}
}
impl VkSetup for VkPipelineCache {
fn vk_setup(&mut self, fn_table: *mut VkFunctionTable) {
self._fn_table = fn_table;
}
}
impl VkPipelineCache {
pub fn vk_handle(&self) -> u64 {
self._handle
}
pub fn is_null(&self) -> bool {
self._handle == 0
}
pub fn null() -> Self {
Self {
_handle: 0,
_fn_table: ptr::null_mut()
}
}
pub fn destroy(&self) {
unsafe {
((&*self._fn_table).vkDestroyPipelineCache)((*self._fn_table).device, self._handle, ptr::null());
}
}
pub fn get_data(&self) -> LavaResult<Vec<c_void>> {
unsafe {
let mut vk_result = 0;
let mut raw_data : *mut c_void = ptr::null_mut();
let raw_data_size = &mut mem::zeroed() as *mut usize;
vk_result = ((&*self._fn_table).vkGetPipelineCacheData)((*self._fn_table).device, self._handle, raw_data_size, raw_data);
raw_data = calloc(*raw_data_size as usize, mem::size_of::<c_void>()) as *mut c_void;
vk_result = ((&*self._fn_table).vkGetPipelineCacheData)((*self._fn_table).device, self._handle, raw_data_size, raw_data);
let data = Vec::from_raw_parts(raw_data, *raw_data_size, *raw_data_size);
if vk_result == 0 { Ok(data) } else { Err((RawVkResult::vk_to_wrapped(&vk_result), data)) }
}
}
pub fn merge(&self, src_caches: Vec<VkPipelineCache>) -> LavaResult<()> {
unsafe {
let raw_src_cache_count = src_caches.len() as u32;
let raw_src_caches = new_ptr_vk_array(&src_caches);
let vk_result = ((&*self._fn_table).vkMergePipelineCaches)((*self._fn_table).device, self._handle, raw_src_cache_count, raw_src_caches);
free_ptr(raw_src_caches);
if vk_result == 0 { Ok(()) } else { Err((RawVkResult::vk_to_wrapped(&vk_result), ())) }
}
}
}