use utils::vk_traits::*;
#[derive(Debug, Clone)]
pub struct VkPeerMemoryFeatureFlags {
pub copy_src: bool,
pub copy_dst: bool,
pub generic_src: bool,
pub generic_dst: bool,
}
#[doc(hidden)]
pub type RawVkPeerMemoryFeatureFlags = u32;
impl VkWrappedType<RawVkPeerMemoryFeatureFlags> for VkPeerMemoryFeatureFlags {
fn vk_to_raw(src: &VkPeerMemoryFeatureFlags, dst: &mut RawVkPeerMemoryFeatureFlags) {
*dst = 0;
if src.copy_src { *dst |= 0x00000001; }
if src.copy_dst { *dst |= 0x00000002; }
if src.generic_src { *dst |= 0x00000004; }
if src.generic_dst { *dst |= 0x00000008; }
}
}
impl VkRawType<VkPeerMemoryFeatureFlags> for RawVkPeerMemoryFeatureFlags {
fn vk_to_wrapped(src: &RawVkPeerMemoryFeatureFlags) -> VkPeerMemoryFeatureFlags {
VkPeerMemoryFeatureFlags {
copy_src: (src & 0x00000001) != 0,
copy_dst: (src & 0x00000002) != 0,
generic_src: (src & 0x00000004) != 0,
generic_dst: (src & 0x00000008) != 0,
}
}
}
impl Default for VkPeerMemoryFeatureFlags {
fn default() -> VkPeerMemoryFeatureFlags {
VkPeerMemoryFeatureFlags {
copy_src: false,
copy_dst: false,
generic_src: false,
generic_dst: false,
}
}
}
impl VkPeerMemoryFeatureFlags {
pub fn none() -> Self {
VkPeerMemoryFeatureFlags {
copy_src: false,
copy_dst: false,
generic_src: false,
generic_dst: false,
}
}
pub fn all() -> Self {
VkPeerMemoryFeatureFlags {
copy_src: true,
copy_dst: true,
generic_src: true,
generic_dst: true,
}
}
pub fn to_u32(&self) -> u32 {
0
+ if self.copy_src { 0x00000001 } else { 0 }
+ if self.copy_dst { 0x00000002 } else { 0 }
+ if self.generic_src { 0x00000004 } else { 0 }
+ if self.generic_dst { 0x00000008 } else { 0 }
}
pub fn from_u32(value: u32) -> Self {
VkPeerMemoryFeatureFlags {
copy_src: value & 0x00000001 > 0,
copy_dst: value & 0x00000002 > 0,
generic_src: value & 0x00000004 > 0,
generic_dst: value & 0x00000008 > 0,
}
}
}
#[doc(hidden)]
#[macro_export]
macro_rules! VkPeerMemoryFeatureFlags {
( $( $x:ident ),* ) => {
VkPeerMemoryFeatureFlags {
$($x: true,)*
..VkPeerMemoryFeatureFlags::none()
}
}
}