Remove device error

This commit is contained in:
Maik Klein 2018-11-04 09:38:39 +01:00
parent 35d6bdf144
commit b9c5f56084
2 changed files with 8 additions and 33 deletions

View file

@ -1,8 +1,6 @@
#![allow(dead_code)] #![allow(dead_code)]
use device::Device; use device::Device;
use prelude::*; use prelude::*;
use std::error::Error;
use std::fmt;
use std::mem; use std::mem;
use std::os::raw::c_char; use std::os::raw::c_char;
use std::ptr; use std::ptr;
@ -11,31 +9,6 @@ use version::{FunctionPointers, V1_0, V1_1};
use vk; use vk;
use RawPtr; use RawPtr;
#[derive(Debug)]
pub enum DeviceError {
LoadError(Vec<&'static str>),
VkError(vk::Result),
}
impl fmt::Display for DeviceError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "DeviceError::{:?}", self)
}
}
impl Error for DeviceError {
fn description(&self) -> &str {
"DeviceErrorr"
}
fn cause(&self) -> Option<&Error> {
if let &DeviceError::VkError(ref err) = self {
return err.cause();
}
None
}
}
#[derive(Clone)] #[derive(Clone)]
pub struct Instance<V: FunctionPointers> { pub struct Instance<V: FunctionPointers> {
handle: vk::Instance, handle: vk::Instance,
@ -87,7 +60,9 @@ impl<V: FunctionPointers> Instance<V> {
pub trait InstanceV1_1: InstanceV1_0 { pub trait InstanceV1_1: InstanceV1_0 {
fn fp_v1_1(&self) -> &vk::InstanceFnV1_1; fn fp_v1_1(&self) -> &vk::InstanceFnV1_1;
unsafe fn enumerate_physical_device_groups(&self) -> VkResult<Vec<vk::PhysicalDeviceGroupProperties>> { unsafe fn enumerate_physical_device_groups(
&self,
) -> VkResult<Vec<vk::PhysicalDeviceGroupProperties>> {
let mut group_count = mem::uninitialized(); let mut group_count = mem::uninitialized();
self.fp_v1_1().enumerate_physical_device_groups( self.fp_v1_1().enumerate_physical_device_groups(
self.handle(), self.handle(),
@ -134,7 +109,7 @@ pub trait InstanceV1_1: InstanceV1_0 {
&self, &self,
physical_device: vk::PhysicalDevice, physical_device: vk::PhysicalDevice,
format_info: &vk::PhysicalDeviceImageFormatInfo2, format_info: &vk::PhysicalDeviceImageFormatInfo2,
image_format_prop: &mut vk::ImageFormatProperties2 image_format_prop: &mut vk::ImageFormatProperties2,
) -> VkResult<()> { ) -> VkResult<()> {
let err_code = self.fp_v1_1().get_physical_device_image_format_properties2( let err_code = self.fp_v1_1().get_physical_device_image_format_properties2(
physical_device, physical_device,
@ -164,7 +139,7 @@ pub trait InstanceV1_1: InstanceV1_0 {
unsafe fn get_physical_device_queue_family_properties2( unsafe fn get_physical_device_queue_family_properties2(
&self, &self,
physical_device: vk::PhysicalDevice, physical_device: vk::PhysicalDevice,
queue_family_props: &mut [vk::QueueFamilyProperties2] queue_family_props: &mut [vk::QueueFamilyProperties2],
) { ) {
let mut queue_count = queue_family_props.len() as u32; let mut queue_count = queue_family_props.len() as u32;
self.fp_v1_1().get_physical_device_queue_family_properties2( self.fp_v1_1().get_physical_device_queue_family_properties2(
@ -265,7 +240,7 @@ pub trait InstanceV1_0 {
physical_device: vk::PhysicalDevice, physical_device: vk::PhysicalDevice,
create_info: &vk::DeviceCreateInfo, create_info: &vk::DeviceCreateInfo,
allocation_callbacks: Option<&vk::AllocationCallbacks>, allocation_callbacks: Option<&vk::AllocationCallbacks>,
) -> Result<Device<Self::Fp>, DeviceError> { ) -> Result<Device<Self::Fp>, vk::Result> {
let mut device: vk::Device = mem::uninitialized(); let mut device: vk::Device = mem::uninitialized();
let err_code = self.fp_v1_0().create_device( let err_code = self.fp_v1_0().create_device(
physical_device, physical_device,
@ -274,7 +249,7 @@ pub trait InstanceV1_0 {
&mut device, &mut device,
); );
if err_code != vk::Result::SUCCESS { if err_code != vk::Result::SUCCESS {
return Err(DeviceError::VkError(err_code)); return Err(err_code);
} }
let device_fn = <<Self as InstanceV1_0>::Fp as FunctionPointers>::DeviceFp::load( let device_fn = <<Self as InstanceV1_0>::Fp as FunctionPointers>::DeviceFp::load(
self.fp_v1_0(), self.fp_v1_0(),

View file

@ -3,7 +3,7 @@ extern crate lazy_static;
extern crate shared_library; extern crate shared_library;
pub use device::Device; pub use device::Device;
pub use entry::{Entry, InstanceError, LoadingError}; pub use entry::{Entry, InstanceError, LoadingError};
pub use instance::{DeviceError, Instance}; pub use instance::Instance;
mod device; mod device;
mod entry; mod entry;