Struct wgpu_hal::TextureUses
source · pub struct TextureUses { /* private fields */ }
Expand description
Similar to wgt::TextureUsages
but for internal use.
Implementations§
source§impl TextureUses
impl TextureUses
sourcepub const UNINITIALIZED: Self = _
pub const UNINITIALIZED: Self = _
The texture is in unknown state.
sourcepub const COLOR_TARGET: Self = _
pub const COLOR_TARGET: Self = _
The color target of a renderpass.
sourcepub const DEPTH_STENCIL_READ: Self = _
pub const DEPTH_STENCIL_READ: Self = _
Read-only depth stencil usage.
sourcepub const DEPTH_STENCIL_WRITE: Self = _
pub const DEPTH_STENCIL_WRITE: Self = _
Read-write depth stencil usage
sourcepub const STORAGE_READ: Self = _
pub const STORAGE_READ: Self = _
Read-only storage buffer usage. Corresponds to a UAV in d3d, so is exclusive, despite being read only.
sourcepub const STORAGE_READ_WRITE: Self = _
pub const STORAGE_READ_WRITE: Self = _
Read-write or write-only storage buffer usage.
sourcepub const INCLUSIVE: Self = _
pub const INCLUSIVE: Self = _
The combination of states that a texture may be in at the same time.
sourcepub const ORDERED: Self = _
pub const ORDERED: Self = _
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.
sourcepub const COMPLEX: Self = _
pub const COMPLEX: Self = _
Flag used by the wgpu-core texture tracker to say a texture is in different states for every sub-resource
sourcepub const UNKNOWN: Self = _
pub const UNKNOWN: Self = _
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.
sourcepub const fn from_bits(bits: u16) -> Option<Self>
pub const fn from_bits(bits: u16) -> Option<Self>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
sourcepub const fn from_bits_truncate(bits: u16) -> Self
pub const fn from_bits_truncate(bits: u16) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const unsafe fn from_bits_unchecked(bits: u16) -> Self
pub const unsafe fn from_bits_unchecked(bits: u16) -> Self
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
Safety
The caller of the bitflags!
macro can chose to allow or
disallow extra bits for their bitflags type.
The caller of from_bits_unchecked()
has to ensure that
all bits correspond to a defined flag or that extra bits
are valid for this bitflags type.
sourcepub const fn intersects(&self, other: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Returns true
if there are flags common to both self
and other
.
sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Returns true
if all of the flags in other
are contained within self
.
sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Inserts or removes the specified flags depending on the passed value.
sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
Returns the intersection between the flags in self
and
other
.
Specifically, the returned set contains only the flags which are
present in both self
and other
.
This is equivalent to using the &
operator (e.g.
ops::BitAnd
), as in flags & other
.
sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
Returns the union of between the flags in self
and other
.
Specifically, the returned set contains all flags which are
present in either self
or other
, including any which are
present in both (see Self::symmetric_difference
if that
is undesirable).
This is equivalent to using the |
operator (e.g.
ops::BitOr
), as in flags | other
.
sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
Returns the difference between the flags in self
and other
.
Specifically, the returned set contains all flags present in
self
, except for the ones present in other
.
It is also conceptually equivalent to the “bit-clear” operation:
flags & !other
(and this syntax is also supported).
This is equivalent to using the -
operator (e.g.
ops::Sub
), as in flags - other
.
sourcepub const fn symmetric_difference(self, other: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
Returns the symmetric difference between the flags
in self
and other
.
Specifically, the returned set contains the flags present which
are present in self
or other
, but that are not present in
both. Equivalently, it contains the flags present in exactly
one of the sets self
and other
.
This is equivalent to using the ^
operator (e.g.
ops::BitXor
), as in flags ^ other
.
sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
Returns the complement of this set of flags.
Specifically, the returned set contains all the flags which are
not set in self
, but which are allowed for this type.
Alternatively, it can be thought of as the set difference
between Self::all()
and self
(e.g. Self::all() - self
)
This is equivalent to using the !
operator (e.g.
ops::Not
), as in !flags
.
Trait Implementations§
source§impl Binary for TextureUses
impl Binary for TextureUses
source§impl BitAnd<TextureUses> for TextureUses
impl BitAnd<TextureUses> for TextureUses
source§impl BitAndAssign<TextureUses> for TextureUses
impl BitAndAssign<TextureUses> for TextureUses
source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
source§impl BitOr<TextureUses> for TextureUses
impl BitOr<TextureUses> for TextureUses
source§fn bitor(self, other: TextureUses) -> Self
fn bitor(self, other: TextureUses) -> Self
Returns the union of the two sets of flags.
§type Output = TextureUses
type Output = TextureUses
|
operator.source§impl BitOrAssign<TextureUses> for TextureUses
impl BitOrAssign<TextureUses> for TextureUses
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXor<TextureUses> for TextureUses
impl BitXor<TextureUses> for TextureUses
source§impl BitXorAssign<TextureUses> for TextureUses
impl BitXorAssign<TextureUses> for TextureUses
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
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: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
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 FromIterator<TextureUses> for TextureUses
impl FromIterator<TextureUses> for TextureUses
source§fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
source§impl Hash for TextureUses
impl Hash for TextureUses
source§impl LowerHex for TextureUses
impl LowerHex for TextureUses
source§impl Not for TextureUses
impl Not for TextureUses
source§impl Octal for TextureUses
impl Octal for TextureUses
source§impl Ord for TextureUses
impl Ord for TextureUses
source§fn cmp(&self, other: &TextureUses) -> Ordering
fn cmp(&self, other: &TextureUses) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere Self: Sized,
source§impl PartialEq<TextureUses> for TextureUses
impl PartialEq<TextureUses> for TextureUses
source§fn eq(&self, other: &TextureUses) -> bool
fn eq(&self, other: &TextureUses) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl PartialOrd<TextureUses> for TextureUses
impl PartialOrd<TextureUses> for TextureUses
source§fn partial_cmp(&self, other: &TextureUses) -> Option<Ordering>
fn partial_cmp(&self, other: &TextureUses) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read moresource§impl Sub<TextureUses> for TextureUses
impl Sub<TextureUses> for TextureUses
source§impl SubAssign<TextureUses> for TextureUses
impl SubAssign<TextureUses> for TextureUses
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.
source§impl UpperHex for TextureUses
impl UpperHex for TextureUses
impl Copy for TextureUses
impl Eq for TextureUses
impl StructuralEq for TextureUses
impl StructuralPartialEq for TextureUses
Auto Trait Implementations§
impl RefUnwindSafe for TextureUses
impl Send for TextureUses
impl Sync for TextureUses
impl Unpin for TextureUses
impl UnwindSafe for TextureUses
Blanket Implementations§
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.