pub struct TextureUses(pub(crate) <TextureUses as PublicFlags>::Internal);
Expand description
Similar to TextureUsages
, but used only for CommandEncoder::transition_resources
.
Tuple Fields§
§0: <TextureUses as PublicFlags>::Internal
Implementations§
Source§impl TextureUses
impl TextureUses
Sourcepub const UNINITIALIZED: TextureUses
pub const UNINITIALIZED: TextureUses
The texture is in unknown state.
Sourcepub const PRESENT: TextureUses
pub const PRESENT: TextureUses
Ready to present image to the surface.
Sourcepub const COPY_SRC: TextureUses
pub const COPY_SRC: TextureUses
The source of a hardware copy. cbindgen:ignore
Sourcepub const COPY_DST: TextureUses
pub const COPY_DST: TextureUses
The destination of a hardware copy. cbindgen:ignore
Sourcepub const RESOURCE: TextureUses
pub const RESOURCE: TextureUses
Read-only sampled or fetched resource.
Sourcepub const COLOR_TARGET: TextureUses
pub const COLOR_TARGET: TextureUses
The color target of a renderpass.
Sourcepub const DEPTH_STENCIL_READ: TextureUses
pub const DEPTH_STENCIL_READ: TextureUses
Read-only depth stencil usage.
Sourcepub const DEPTH_STENCIL_WRITE: TextureUses
pub const DEPTH_STENCIL_WRITE: TextureUses
Read-write depth stencil usage
Sourcepub const STORAGE_READ_ONLY: TextureUses
pub const STORAGE_READ_ONLY: TextureUses
Read-only storage texture usage. Corresponds to a UAV in d3d, so is exclusive, despite being read only. cbindgen:ignore
Sourcepub const STORAGE_WRITE_ONLY: TextureUses
pub const STORAGE_WRITE_ONLY: TextureUses
Write-only storage texture usage. cbindgen:ignore
Sourcepub const STORAGE_READ_WRITE: TextureUses
pub const STORAGE_READ_WRITE: TextureUses
Read-write storage texture usage. cbindgen:ignore
Sourcepub const STORAGE_ATOMIC: TextureUses
pub const STORAGE_ATOMIC: TextureUses
Image atomic enabled storage. cbindgen:ignore
Sourcepub const INCLUSIVE: TextureUses
pub const INCLUSIVE: TextureUses
The combination of states that a texture may be in at the same time. cbindgen:ignore
Sourcepub const EXCLUSIVE: TextureUses
pub const EXCLUSIVE: TextureUses
The combination of states that a texture must exclusively be in. cbindgen:ignore
Sourcepub const ORDERED: TextureUses
pub const ORDERED: TextureUses
The combination of all usages that the are guaranteed to be be ordered by the hardware. If a usage is ordered, then if the texture state doesn’t change between draw calls, there are no barriers needed for synchronization. cbindgen:ignore
Sourcepub const COMPLEX: TextureUses
pub const COMPLEX: TextureUses
Flag used by the wgpu-core texture tracker to say a texture is in different states for every sub-resource
Sourcepub const UNKNOWN: TextureUses
pub const UNKNOWN: TextureUses
Flag used by the wgpu-core texture tracker to say that the tracker does not know the state of the sub-resource. This is different from UNINITIALIZED as that says the tracker does know, but the texture has not been initialized.
Source§impl TextureUses
impl TextureUses
Sourcepub const fn empty() -> TextureUses
pub const fn empty() -> TextureUses
Get a flags value with all bits unset.
Sourcepub const fn all() -> TextureUses
pub const fn all() -> TextureUses
Get a flags value with all known bits set.
Sourcepub const fn bits(&self) -> u16
pub const fn bits(&self) -> u16
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
Sourcepub const fn from_bits(bits: u16) -> Option<TextureUses>
pub const fn from_bits(bits: u16) -> Option<TextureUses>
Convert from a bits value.
This method will return None
if any unknown bits are set.
Sourcepub const fn from_bits_truncate(bits: u16) -> TextureUses
pub const fn from_bits_truncate(bits: u16) -> TextureUses
Convert from a bits value, unsetting any unknown bits.
Sourcepub const fn from_bits_retain(bits: u16) -> TextureUses
pub const fn from_bits_retain(bits: u16) -> TextureUses
Convert from a bits value exactly.
Sourcepub fn from_name(name: &str) -> Option<TextureUses>
pub fn from_name(name: &str) -> Option<TextureUses>
Get a flags value with the bits of a flag with the given name set.
This method will return None
if name
is empty or doesn’t
correspond to any named flag.
Sourcepub const fn intersects(&self, other: TextureUses) -> bool
pub const fn intersects(&self, other: TextureUses) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
Sourcepub const fn contains(&self, other: TextureUses) -> bool
pub const fn contains(&self, other: TextureUses) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
Sourcepub fn insert(&mut self, other: TextureUses)
pub fn insert(&mut self, other: TextureUses)
The bitwise or (|
) of the bits in two flags values.
Sourcepub fn remove(&mut self, other: TextureUses)
pub fn remove(&mut self, other: TextureUses)
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
remove
won’t truncate other
, but the !
operator will.
Sourcepub fn toggle(&mut self, other: TextureUses)
pub fn toggle(&mut self, other: TextureUses)
The bitwise exclusive-or (^
) of the bits in two flags values.
Sourcepub fn set(&mut self, other: TextureUses, value: bool)
pub fn set(&mut self, other: TextureUses, value: bool)
Call insert
when value
is true
or remove
when value
is false
.
Sourcepub const fn intersection(self, other: TextureUses) -> TextureUses
pub const fn intersection(self, other: TextureUses) -> TextureUses
The bitwise and (&
) of the bits in two flags values.
Sourcepub const fn union(self, other: TextureUses) -> TextureUses
pub const fn union(self, other: TextureUses) -> TextureUses
The bitwise or (|
) of the bits in two flags values.
Sourcepub const fn difference(self, other: TextureUses) -> TextureUses
pub const fn difference(self, other: TextureUses) -> TextureUses
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
difference
won’t truncate other
, but the !
operator will.
Sourcepub const fn symmetric_difference(self, other: TextureUses) -> TextureUses
pub const fn symmetric_difference(self, other: TextureUses) -> TextureUses
The bitwise exclusive-or (^
) of the bits in two flags values.
Sourcepub const fn complement(self) -> TextureUses
pub const fn complement(self) -> TextureUses
The bitwise negation (!
) of the bits in a flags value, truncating the result.
Source§impl TextureUses
impl TextureUses
Sourcepub const fn iter(&self) -> Iter<TextureUses>
pub const fn iter(&self) -> Iter<TextureUses>
Yield a set of contained flags values.
Each yielded flags value will correspond to a defined named flag. Any unknown bits will be yielded together as a final flags value.
Sourcepub const fn iter_names(&self) -> IterNames<TextureUses>
pub const fn iter_names(&self) -> IterNames<TextureUses>
Yield a set of contained named flags values.
This method is like iter
, except only yields bits in contained named flags.
Any unknown bits, or bits not corresponding to a contained flag will not be yielded.
Trait Implementations§
Source§impl Binary for TextureUses
impl Binary for TextureUses
Source§impl BitAnd for TextureUses
impl BitAnd for TextureUses
Source§fn bitand(self, other: TextureUses) -> TextureUses
fn bitand(self, other: TextureUses) -> TextureUses
The bitwise and (&
) of the bits in two flags values.
Source§type Output = TextureUses
type Output = TextureUses
&
operator.Source§impl BitAndAssign for TextureUses
impl BitAndAssign for TextureUses
Source§fn bitand_assign(&mut self, other: TextureUses)
fn bitand_assign(&mut self, other: TextureUses)
The bitwise and (&
) of the bits in two flags values.
Source§impl BitOr for TextureUses
impl BitOr for TextureUses
Source§fn bitor(self, other: TextureUses) -> TextureUses
fn bitor(self, other: TextureUses) -> TextureUses
The bitwise or (|
) of the bits in two flags values.
Source§type Output = TextureUses
type Output = TextureUses
|
operator.Source§impl BitOrAssign for TextureUses
impl BitOrAssign for TextureUses
Source§fn bitor_assign(&mut self, other: TextureUses)
fn bitor_assign(&mut self, other: TextureUses)
The bitwise or (|
) of the bits in two flags values.
Source§impl BitXor for TextureUses
impl BitXor for TextureUses
Source§fn bitxor(self, other: TextureUses) -> TextureUses
fn bitxor(self, other: TextureUses) -> TextureUses
The bitwise exclusive-or (^
) of the bits in two flags values.
Source§type Output = TextureUses
type Output = TextureUses
^
operator.Source§impl BitXorAssign for TextureUses
impl BitXorAssign for TextureUses
Source§fn bitxor_assign(&mut self, other: TextureUses)
fn bitxor_assign(&mut self, other: TextureUses)
The bitwise exclusive-or (^
) of the bits in two flags values.
Source§impl Clone for TextureUses
impl Clone for TextureUses
Source§fn clone(&self) -> TextureUses
fn clone(&self) -> TextureUses
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for TextureUses
impl Debug for TextureUses
Source§impl Extend<TextureUses> for TextureUses
impl Extend<TextureUses> for TextureUses
Source§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = TextureUses>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = TextureUses>,
The bitwise or (|
) of the bits in each flags value.
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one
)Source§impl Flags for TextureUses
impl Flags for TextureUses
Source§const FLAGS: &'static [Flag<TextureUses>]
const FLAGS: &'static [Flag<TextureUses>]
Source§fn from_bits_retain(bits: u16) -> TextureUses
fn from_bits_retain(bits: u16) -> TextureUses
§fn contains_unknown_bits(&self) -> bool
fn contains_unknown_bits(&self) -> bool
true
if any unknown bits are set.§fn from_bits_truncate(bits: Self::Bits) -> Self
fn from_bits_truncate(bits: Self::Bits) -> Self
§fn from_name(name: &str) -> Option<Self>
fn from_name(name: &str) -> Option<Self>
§fn iter_names(&self) -> IterNames<Self>
fn iter_names(&self) -> IterNames<Self>
§fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
§fn contains(&self, other: Self) -> boolwhere
Self: Sized,
fn contains(&self, other: Self) -> boolwhere
Self: Sized,
§fn insert(&mut self, other: Self)where
Self: Sized,
fn insert(&mut self, other: Self)where
Self: Sized,
|
) of the bits in two flags values.§fn remove(&mut self, other: Self)where
Self: Sized,
fn remove(&mut self, other: Self)where
Self: Sized,
&!
). Read more§fn toggle(&mut self, other: Self)where
Self: Sized,
fn toggle(&mut self, other: Self)where
Self: Sized,
^
) of the bits in two flags values.§fn set(&mut self, other: Self, value: bool)where
Self: Sized,
fn set(&mut self, other: Self, value: bool)where
Self: Sized,
Flags::insert
] when value
is true
or [Flags::remove
] when value
is false
.§fn intersection(self, other: Self) -> Self
fn intersection(self, other: Self) -> Self
&
) of the bits in two flags values.§fn difference(self, other: Self) -> Self
fn difference(self, other: Self) -> Self
&!
). Read more§fn symmetric_difference(self, other: Self) -> Self
fn symmetric_difference(self, other: Self) -> Self
^
) of the bits in two flags values.§fn complement(self) -> Self
fn complement(self) -> Self
!
) of the bits in a flags value, truncating the result.Source§impl FromIterator<TextureUses> for TextureUses
impl FromIterator<TextureUses> for TextureUses
Source§fn from_iter<T>(iterator: T) -> TextureUseswhere
T: IntoIterator<Item = TextureUses>,
fn from_iter<T>(iterator: T) -> TextureUseswhere
T: IntoIterator<Item = TextureUses>,
The bitwise or (|
) of the bits in each flags value.
Source§impl Hash for TextureUses
impl Hash for TextureUses
Source§impl IntoIterator for TextureUses
impl IntoIterator for TextureUses
Source§type Item = TextureUses
type Item = TextureUses
Source§type IntoIter = Iter<TextureUses>
type IntoIter = Iter<TextureUses>
Source§fn into_iter(self) -> <TextureUses as IntoIterator>::IntoIter
fn into_iter(self) -> <TextureUses as IntoIterator>::IntoIter
Source§impl LowerHex for TextureUses
impl LowerHex for TextureUses
Source§impl Not for TextureUses
impl Not for TextureUses
Source§fn not(self) -> TextureUses
fn not(self) -> TextureUses
The bitwise negation (!
) of the bits in a flags value, truncating the result.
Source§type Output = TextureUses
type Output = TextureUses
!
operator.Source§impl Octal for TextureUses
impl Octal for TextureUses
Source§impl PartialEq for TextureUses
impl PartialEq for TextureUses
Source§impl Sub for TextureUses
impl Sub for TextureUses
Source§fn sub(self, other: TextureUses) -> TextureUses
fn sub(self, other: TextureUses) -> TextureUses
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
difference
won’t truncate other
, but the !
operator will.
Source§type Output = TextureUses
type Output = TextureUses
-
operator.Source§impl SubAssign for TextureUses
impl SubAssign for TextureUses
Source§fn sub_assign(&mut self, other: TextureUses)
fn sub_assign(&mut self, other: TextureUses)
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
difference
won’t truncate other
, but the !
operator will.
Source§impl UpperHex for TextureUses
impl UpperHex for TextureUses
impl Copy for TextureUses
impl Eq for TextureUses
impl StructuralPartialEq for TextureUses
Auto Trait Implementations§
impl Freeze for TextureUses
impl RefUnwindSafe for TextureUses
impl Send for TextureUses
impl Sync for TextureUses
impl Unpin for TextureUses
impl UnwindSafe for TextureUses
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.