Merge pull request #132 from Ralith/error-handling

Expose suboptimal results from swapchain operations
This commit is contained in:
Maik Klein 2018-11-11 14:55:20 +01:00 committed by GitHub
commit 52fe1c9714
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 10 additions and 6 deletions

View file

@ -43,13 +43,14 @@ impl Swapchain {
);
}
/// On success, returns the next image's index and whether the swapchain is suboptimal for the surface.
pub unsafe fn acquire_next_image_khr(
&self,
swapchain: vk::SwapchainKHR,
timeout: u64,
semaphore: vk::Semaphore,
fence: vk::Fence,
) -> VkResult<u32> {
) -> VkResult<(u32, bool)> {
let mut index = mem::uninitialized();
let err_code = self.swapchain_fn.acquire_next_image_khr(
self.handle,
@ -60,7 +61,8 @@ impl Swapchain {
&mut index,
);
match err_code {
vk::Result::SUCCESS => Ok(index),
vk::Result::SUCCESS => Ok((index, false)),
vk::Result::SUBOPTIMAL_KHR => Ok((index, true)),
_ => Err(err_code),
}
}
@ -83,14 +85,16 @@ impl Swapchain {
}
}
/// On success, returns whether the swapchain is suboptimal for the surface.
pub unsafe fn queue_present_khr(
&self,
queue: vk::Queue,
create_info: &vk::PresentInfoKHR,
) -> VkResult<()> {
) -> VkResult<bool> {
let err_code = self.swapchain_fn.queue_present_khr(queue, create_info);
match err_code {
vk::Result::SUCCESS => Ok(()),
vk::Result::SUCCESS => Ok(false),
vk::Result::SUBOPTIMAL_KHR => Ok(true),
_ => Err(err_code),
}
}

View file

@ -875,7 +875,7 @@ fn main() {
let graphic_pipeline = graphics_pipelines[0];
base.render_loop(|| {
let present_index = base
let (present_index, _) = base
.swapchain_loader
.acquire_next_image_khr(
base.swapchain,

View file

@ -460,7 +460,7 @@ fn main() {
let graphic_pipeline = graphics_pipelines[0];
base.render_loop(|| {
let present_index = base
let (present_index, _) = base
.swapchain_loader
.acquire_next_image_khr(
base.swapchain,