Refactor layer selection logic for more flexibility
Some checks failed
Build legacy Nix package on Ubuntu / build (push) Failing after 0s

Updated the layer selection logic to utilize an enum, LayersSelector, which supports selecting no layers, specific layers, or all available layers. This refactor enhances code clarity and allows for more flexible layer management.
This commit is contained in:
Florian RICHER 2024-11-10 19:10:16 +01:00
parent da0be47b14
commit b7d0abb9ed
Signed by: florian.richer
GPG key ID: C73D37CBED7BFC77
3 changed files with 45 additions and 28 deletions

View file

@ -1,17 +1,29 @@
use std::ffi::CString;
pub enum LayersSelector<'a> {
Nothing,
SpecificLayers(Vec<&'a str>),
All
}
pub fn use_layers(
entry: &ash::Entry,
layers_to_select: Vec<&str>,
selector: LayersSelector,
) -> Vec<CString> {
let layers_available = get_layers_available(entry);
let selected_layers = select_layers(&layers_available, &layers_to_select);
selected_layers
let layers_available = get_layers_available(entry)
.iter()
.map(|sl| CString::new(sl.clone().as_bytes()).unwrap())
.collect::<Vec<_>>()
.filter_map(|layer| {
layer.layer_name_as_c_str()
.and_then(|layer_name| Ok(CString::from(layer_name)))
.ok()
})
.collect::<Vec<_>>();
match selector {
LayersSelector::Nothing => Vec::new(),
LayersSelector::SpecificLayers(layers) => select_layers(&layers_available, &layers),
LayersSelector::All => layers_available,
}
}
fn get_layers_available(entry: &ash::Entry) -> Vec<ash::vk::LayerProperties> {
@ -19,20 +31,21 @@ fn get_layers_available(entry: &ash::Entry) -> Vec<ash::vk::LayerProperties> {
}
fn select_layers(
layers_available: &[ash::vk::LayerProperties],
layers_available: &Vec<CString>,
layers_to_select: &[&str],
) -> Vec<String> {
layers_available
.iter()
.filter_map(|l| {
let layer_name = l
.layer_name_as_c_str()
.unwrap_or_default()
.to_string_lossy();
) -> Vec<CString> {
layers_to_select
.iter()
.find(|&&ln| ln == layer_name)
.map(|_| layer_name.into_owned())
})
.collect()
.filter_map(|layer_name| {
if layers_available.iter().any(|layer_available| {
layer_available.to_str()
.and_then(|layer_available| Ok(layer_available.eq(*layer_name)))
.unwrap_or(false)
}) {
CString::new(*layer_name).ok()
} else {
None
}
})
.collect::<Vec<_>>()
}

View file

@ -1,5 +1,5 @@
mod layers;
pub use layers::use_layers;
pub use layers::{use_layers, LayersSelector};
pub fn print_version(version: u32) -> String {
format!(

View file

@ -3,7 +3,7 @@ use std::fmt::{Display, Formatter};
use ash::{Instance, vk, Entry};
use ash::khr::surface;
use winit::raw_window_handle::{HasDisplayHandle, HasWindowHandle};
use crate::vulkan::utils::use_layers;
use crate::vulkan::utils::{use_layers, LayersSelector};
use crate::vulkan::vk_surface::VkSurface;
use crate::vulkan::VkPhysicalDevice;
@ -19,11 +19,15 @@ impl VkInstance {
let entry = Entry::linked();
// Layers
let layers = use_layers(&entry, vec![
let layers = use_layers(
&entry,
LayersSelector::SpecificLayers(vec![
"VK_LAYER_KHRONOS_validation",
"VK_LAYER_MANGOHUD_overlay_x86_64",
"VK_LAYER_NV_optimus"
]);
])
);
log::info!("{:?}", layers);
let layers_raw = layers.iter().map(|s| s.as_ptr()).collect::<Vec<_>>();
// App Info