From c81039a0c9fb86a34c1d887875330103d7f56ba4 Mon Sep 17 00:00:00 2001 From: Dzmitry Malyshau Date: Tue, 30 Jan 2018 13:39:40 -0500 Subject: [PATCH] Nicer Entry implementation --- ash/src/entry.rs | 39 +++++++++++++++++---------------------- 1 file changed, 17 insertions(+), 22 deletions(-) diff --git a/ash/src/entry.rs b/ash/src/entry.rs index d9511e5..74c686f 100644 --- a/ash/src/entry.rs +++ b/ash/src/entry.rs @@ -93,10 +93,10 @@ pub trait EntryV1_0 { return Err(InstanceError::VkError(err_code)); } let instance_fp = - <::Fp as FunctionPointers>::InstanceFp::load( + ::InstanceFp::load( &self.static_fn(), instance, - ).map_err(|err| InstanceError::LoadError(err))?; + ).map_err(InstanceError::LoadError)?; Ok(Instance::from_raw(instance, instance_fp)) } @@ -159,28 +159,23 @@ impl EntryV1_0 for Entry { } impl Entry { - pub fn new() -> Result, LoadingError> { - let static_fn = match *VK_LIB { - Ok(ref lib) => { - let static_fn = - vk::StaticFn::load(|name| unsafe { - let name = name.to_str().unwrap(); - let f = match lib.symbol(name) { - Ok(s) => s, - Err(_) => ptr::null(), - }; - f - }).map_err(|err| LoadingError::StaticLoadError(err))?; - Ok(static_fn) - } - Err(ref err) => Err(LoadingError::LibraryLoadError(err.clone())), - }?; + pub fn new() -> Result { + let lib = VK_LIB + .as_ref() + .map_err(|err| LoadingError::LibraryLoadError(err.clone()))?; + + let static_fn = vk::StaticFn::load(|name| unsafe { + lib.symbol(name.to_str().unwrap()) + .unwrap_or(ptr::null_mut()) + }).map_err(LoadingError::StaticLoadError)?; + let entry_fn = unsafe { - V::EntryFp::load(&static_fn).map_err(|err| LoadingError::EntryLoadError(err))? - }; + V::EntryFp::load(&static_fn) + }.map_err(LoadingError::EntryLoadError)?; + Ok(Entry { - static_fn: static_fn, - entry_fn: entry_fn, + static_fn, + entry_fn, }) } }