pub struct TextureUses(pub(crate) <TextureUses as PublicFlags>::Internal);
Expand description
Similar to wgt::TextureUsages
but for internal use.
Tuple Fields§
§0: <TextureUses as PublicFlags>::Internal
Implementations§
§impl TextureUses
impl TextureUses
pub const UNINITIALIZED: TextureUses = _
pub const UNINITIALIZED: TextureUses = _
The texture is in unknown state.
pub const PRESENT: TextureUses = _
pub const PRESENT: TextureUses = _
Ready to present image to the surface.
pub const COPY_SRC: TextureUses = _
pub const COPY_SRC: TextureUses = _
The source of a hardware copy.
pub const COPY_DST: TextureUses = _
pub const COPY_DST: TextureUses = _
The destination of a hardware copy.
pub const RESOURCE: TextureUses = _
pub const RESOURCE: TextureUses = _
Read-only sampled or fetched resource.
pub const COLOR_TARGET: TextureUses = _
pub const COLOR_TARGET: TextureUses = _
The color target of a renderpass.
pub const DEPTH_STENCIL_READ: TextureUses = _
pub const DEPTH_STENCIL_READ: TextureUses = _
Read-only depth stencil usage.
pub const DEPTH_STENCIL_WRITE: TextureUses = _
pub const DEPTH_STENCIL_WRITE: TextureUses = _
Read-write depth stencil usage
pub const STORAGE_READ: TextureUses = _
pub const STORAGE_READ: TextureUses = _
Read-only storage buffer usage. Corresponds to a UAV in d3d, so is exclusive, despite being read only.
pub const STORAGE_READ_WRITE: TextureUses = _
pub const STORAGE_READ_WRITE: TextureUses = _
Read-write or write-only storage buffer usage.
pub const INCLUSIVE: TextureUses = _
pub const INCLUSIVE: TextureUses = _
The combination of states that a texture may be in at the same time.
pub const EXCLUSIVE: TextureUses = _
pub const EXCLUSIVE: TextureUses = _
The combination of states that a texture must exclusively be in.
pub 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.
pub 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
pub 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.
§impl TextureUses
impl TextureUses
pub const fn empty() -> TextureUses
pub const fn empty() -> TextureUses
Get a flags value with all bits unset.
pub const fn all() -> TextureUses
pub const fn all() -> TextureUses
Get a flags value with all known bits set.
pub 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.
pub 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.
pub 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.
pub const fn from_bits_retain(bits: u16) -> TextureUses
pub const fn from_bits_retain(bits: u16) -> TextureUses
Convert from a bits value exactly.
pub 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.
pub 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.
pub 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.
pub fn insert(&mut self, other: TextureUses)
pub fn insert(&mut self, other: TextureUses)
The bitwise or (|
) of the bits in two flags values.
pub 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.
pub fn toggle(&mut self, other: TextureUses)
pub fn toggle(&mut self, other: TextureUses)
The bitwise exclusive-or (^
) of the bits in two flags values.
pub 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
.
pub 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.
pub 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.
pub 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.
pub 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.
pub const fn complement(self) -> TextureUses
pub const fn complement(self) -> TextureUses
The bitwise negation (!
) of the bits in a flags value, truncating the result.
§impl TextureUses
impl TextureUses
pub 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.
pub 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§
§impl Binary for TextureUses
impl Binary for TextureUses
§impl BitAnd for TextureUses
impl BitAnd for TextureUses
§fn bitand(self, other: TextureUses) -> TextureUses
fn bitand(self, other: TextureUses) -> TextureUses
The bitwise and (&
) of the bits in two flags values.
§type Output = TextureUses
type Output = TextureUses
&
operator.§impl BitAndAssign for TextureUses
impl BitAndAssign for TextureUses
§fn bitand_assign(&mut self, other: TextureUses)
fn bitand_assign(&mut self, other: TextureUses)
The bitwise and (&
) of the bits in two flags values.
§impl BitOr for TextureUses
impl BitOr for TextureUses
§fn bitor(self, other: TextureUses) -> TextureUses
fn bitor(self, other: TextureUses) -> TextureUses
The bitwise or (|
) of the bits in two flags values.
§type Output = TextureUses
type Output = TextureUses
|
operator.§impl BitOrAssign for TextureUses
impl BitOrAssign for TextureUses
§fn bitor_assign(&mut self, other: TextureUses)
fn bitor_assign(&mut self, other: TextureUses)
The bitwise or (|
) of the bits in two flags values.
§impl BitXor for TextureUses
impl BitXor for TextureUses
§fn bitxor(self, other: TextureUses) -> TextureUses
fn bitxor(self, other: TextureUses) -> TextureUses
The bitwise exclusive-or (^
) of the bits in two flags values.
§type Output = TextureUses
type Output = TextureUses
^
operator.§impl BitXorAssign for TextureUses
impl BitXorAssign for TextureUses
§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.
§impl Clone for TextureUses
impl Clone for TextureUses
§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 more§impl Debug for TextureUses
impl Debug for TextureUses
§impl Extend<TextureUses> for TextureUses
impl Extend<TextureUses> for TextureUses
§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
)§impl Flags for TextureUses
impl Flags for TextureUses
§const FLAGS: &'static [Flag<TextureUses>] = _
const FLAGS: &'static [Flag<TextureUses>] = _
§fn from_bits_retain(bits: u16) -> TextureUses
fn from_bits_retain(bits: u16) -> TextureUses
§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.§impl FromIterator<TextureUses> for TextureUses
impl FromIterator<TextureUses> for TextureUses
§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.
§impl Hash for TextureUses
impl Hash for TextureUses
§impl IntoIterator for TextureUses
impl IntoIterator for TextureUses
§type Item = TextureUses
type Item = TextureUses
§type IntoIter = Iter<TextureUses>
type IntoIter = Iter<TextureUses>
§fn into_iter(self) -> <TextureUses as IntoIterator>::IntoIter
fn into_iter(self) -> <TextureUses as IntoIterator>::IntoIter
§impl LowerHex for TextureUses
impl LowerHex for TextureUses
§impl Not for TextureUses
impl Not for TextureUses
§fn not(self) -> TextureUses
fn not(self) -> TextureUses
The bitwise negation (!
) of the bits in a flags value, truncating the result.
§type Output = TextureUses
type Output = TextureUses
!
operator.§impl Octal for TextureUses
impl Octal for TextureUses
§impl PartialEq for TextureUses
impl PartialEq for TextureUses
§fn eq(&self, other: &TextureUses) -> bool
fn eq(&self, other: &TextureUses) -> bool
self
and other
values to be equal, and is used
by ==
.§impl Sub for TextureUses
impl Sub for TextureUses
§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.
§type Output = TextureUses
type Output = TextureUses
-
operator.§impl SubAssign for TextureUses
impl SubAssign for TextureUses
§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.
§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> CheckedAs for T
impl<T> CheckedAs for T
source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§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.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request