Refactor layer selection logic for more flexibility
Some checks failed
Build legacy Nix package on Ubuntu / build (push) Failing after 0s
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:
parent
da0be47b14
commit
b7d0abb9ed
3 changed files with 45 additions and 28 deletions
|
@ -1,17 +1,29 @@
|
||||||
use std::ffi::CString;
|
use std::ffi::CString;
|
||||||
|
|
||||||
|
pub enum LayersSelector<'a> {
|
||||||
|
Nothing,
|
||||||
|
SpecificLayers(Vec<&'a str>),
|
||||||
|
All
|
||||||
|
}
|
||||||
|
|
||||||
pub fn use_layers(
|
pub fn use_layers(
|
||||||
entry: &ash::Entry,
|
entry: &ash::Entry,
|
||||||
layers_to_select: Vec<&str>,
|
selector: LayersSelector,
|
||||||
) -> Vec<CString> {
|
) -> Vec<CString> {
|
||||||
let layers_available = get_layers_available(entry);
|
let layers_available = get_layers_available(entry)
|
||||||
|
|
||||||
let selected_layers = select_layers(&layers_available, &layers_to_select);
|
|
||||||
|
|
||||||
selected_layers
|
|
||||||
.iter()
|
.iter()
|
||||||
.map(|sl| CString::new(sl.clone().as_bytes()).unwrap())
|
.filter_map(|layer| {
|
||||||
.collect::<Vec<_>>()
|
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> {
|
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(
|
fn select_layers(
|
||||||
layers_available: &[ash::vk::LayerProperties],
|
layers_available: &Vec<CString>,
|
||||||
layers_to_select: &[&str],
|
layers_to_select: &[&str],
|
||||||
) -> Vec<String> {
|
) -> Vec<CString> {
|
||||||
layers_available
|
layers_to_select
|
||||||
.iter()
|
.iter()
|
||||||
.filter_map(|l| {
|
.filter_map(|layer_name| {
|
||||||
let layer_name = l
|
if layers_available.iter().any(|layer_available| {
|
||||||
.layer_name_as_c_str()
|
layer_available.to_str()
|
||||||
.unwrap_or_default()
|
.and_then(|layer_available| Ok(layer_available.eq(*layer_name)))
|
||||||
.to_string_lossy();
|
.unwrap_or(false)
|
||||||
layers_to_select
|
}) {
|
||||||
.iter()
|
CString::new(*layer_name).ok()
|
||||||
.find(|&&ln| ln == layer_name)
|
} else {
|
||||||
.map(|_| layer_name.into_owned())
|
None
|
||||||
|
}
|
||||||
})
|
})
|
||||||
.collect()
|
.collect::<Vec<_>>()
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
mod layers;
|
mod layers;
|
||||||
pub use layers::use_layers;
|
pub use layers::{use_layers, LayersSelector};
|
||||||
|
|
||||||
pub fn print_version(version: u32) -> String {
|
pub fn print_version(version: u32) -> String {
|
||||||
format!(
|
format!(
|
||||||
|
|
|
@ -3,7 +3,7 @@ use std::fmt::{Display, Formatter};
|
||||||
use ash::{Instance, vk, Entry};
|
use ash::{Instance, vk, Entry};
|
||||||
use ash::khr::surface;
|
use ash::khr::surface;
|
||||||
use winit::raw_window_handle::{HasDisplayHandle, HasWindowHandle};
|
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::vk_surface::VkSurface;
|
||||||
use crate::vulkan::VkPhysicalDevice;
|
use crate::vulkan::VkPhysicalDevice;
|
||||||
|
|
||||||
|
@ -19,11 +19,15 @@ impl VkInstance {
|
||||||
let entry = Entry::linked();
|
let entry = Entry::linked();
|
||||||
|
|
||||||
// Layers
|
// Layers
|
||||||
let layers = use_layers(&entry, vec![
|
let layers = use_layers(
|
||||||
"VK_LAYER_KHRONOS_validation",
|
&entry,
|
||||||
"VK_LAYER_MANGOHUD_overlay_x86_64",
|
LayersSelector::SpecificLayers(vec![
|
||||||
"VK_LAYER_NV_optimus"
|
"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<_>>();
|
let layers_raw = layers.iter().map(|s| s.as_ptr()).collect::<Vec<_>>();
|
||||||
|
|
||||||
// App Info
|
// App Info
|
||||||
|
|
Loading…
Reference in a new issue