Struct wgpu_types::PipelineStatisticsTypes
source · #[repr(transparent)]pub struct PipelineStatisticsTypes { /* private fields */ }
Expand description
Flags for which pipeline data should be recorded.
The amount of values written when resolved depends on the amount of flags. If 3 flags are enabled, 3 64-bit values will be written per-query.
The order they are written is the order they are declared
in this bitflags. If you enabled CLIPPER_PRIMITIVES_OUT
and COMPUTE_SHADER_INVOCATIONS
, it would write 16 bytes,
the first 8 bytes being the primitive out value, the last 8
bytes being the compute shader invocation count.
Implementations§
source§impl PipelineStatisticsTypes
impl PipelineStatisticsTypes
sourcepub const VERTEX_SHADER_INVOCATIONS: Self = _
pub const VERTEX_SHADER_INVOCATIONS: Self = _
Amount of times the vertex shader is ran. Accounts for the vertex cache when doing indexed rendering.
sourcepub const CLIPPER_INVOCATIONS: Self = _
pub const CLIPPER_INVOCATIONS: Self = _
Amount of times the clipper is invoked. This is also the amount of triangles output by the vertex shader.
sourcepub const CLIPPER_PRIMITIVES_OUT: Self = _
pub const CLIPPER_PRIMITIVES_OUT: Self = _
Amount of primitives that are not culled by the clipper. This is the amount of triangles that are actually on screen and will be rasterized and rendered.
sourcepub const FRAGMENT_SHADER_INVOCATIONS: Self = _
pub const FRAGMENT_SHADER_INVOCATIONS: Self = _
Amount of times the fragment shader is ran. Accounts for fragment shaders running in 2x2 blocks in order to get derivatives.
sourcepub const COMPUTE_SHADER_INVOCATIONS: Self = _
pub const COMPUTE_SHADER_INVOCATIONS: Self = _
Amount of times a compute shader is invoked. This will be equivalent to the dispatch count times the workgroup size.
sourcepub const fn from_bits(bits: u8) -> Option<Self>
pub const fn from_bits(bits: u8) -> 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: u8) -> Self
pub const fn from_bits_truncate(bits: u8) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const unsafe fn from_bits_unchecked(bits: u8) -> Self
pub const unsafe fn from_bits_unchecked(bits: u8) -> 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
.
source§impl PipelineStatisticsTypes
impl PipelineStatisticsTypes
sourcepub fn contains_invalid_bits(&self) -> bool
pub fn contains_invalid_bits(&self) -> bool
Returns true if the bitflags contains bits that are not part of the bitflags definition.
Trait Implementations§
source§impl Binary for PipelineStatisticsTypes
impl Binary for PipelineStatisticsTypes
source§impl BitAndAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl BitAndAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
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<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl BitOr<PipelineStatisticsTypes> for PipelineStatisticsTypes
source§fn bitor(self, other: PipelineStatisticsTypes) -> Self
fn bitor(self, other: PipelineStatisticsTypes) -> Self
Returns the union of the two sets of flags.
§type Output = PipelineStatisticsTypes
type Output = PipelineStatisticsTypes
|
operator.source§impl BitOrAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl BitOrAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXorAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl BitXorAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
source§impl Clone for PipelineStatisticsTypes
impl Clone for PipelineStatisticsTypes
source§fn clone(&self) -> PipelineStatisticsTypes
fn clone(&self) -> PipelineStatisticsTypes
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for PipelineStatisticsTypes
impl Debug for PipelineStatisticsTypes
source§impl<'de> Deserialize<'de> for PipelineStatisticsTypes
Available on crate feature replay
only.
impl<'de> Deserialize<'de> for PipelineStatisticsTypes
replay
only.source§fn deserialize<D>(deserializer: D) -> Result<PipelineStatisticsTypes, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<PipelineStatisticsTypes, D::Error>where D: Deserializer<'de>,
source§impl Extend<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl Extend<PipelineStatisticsTypes> for PipelineStatisticsTypes
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<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl FromIterator<PipelineStatisticsTypes> for PipelineStatisticsTypes
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 PipelineStatisticsTypes
impl Hash for PipelineStatisticsTypes
source§impl LowerHex for PipelineStatisticsTypes
impl LowerHex for PipelineStatisticsTypes
source§impl Not for PipelineStatisticsTypes
impl Not for PipelineStatisticsTypes
source§impl Octal for PipelineStatisticsTypes
impl Octal for PipelineStatisticsTypes
source§impl Ord for PipelineStatisticsTypes
impl Ord for PipelineStatisticsTypes
source§fn cmp(&self, other: &PipelineStatisticsTypes) -> Ordering
fn cmp(&self, other: &PipelineStatisticsTypes) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere Self: Sized,
source§impl PartialEq<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl PartialEq<PipelineStatisticsTypes> for PipelineStatisticsTypes
source§fn eq(&self, other: &PipelineStatisticsTypes) -> bool
fn eq(&self, other: &PipelineStatisticsTypes) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl PartialOrd<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl PartialOrd<PipelineStatisticsTypes> for PipelineStatisticsTypes
source§fn partial_cmp(&self, other: &PipelineStatisticsTypes) -> Option<Ordering>
fn partial_cmp(&self, other: &PipelineStatisticsTypes) -> 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 Serialize for PipelineStatisticsTypes
Available on crate feature trace
only.
impl Serialize for PipelineStatisticsTypes
trace
only.source§impl SubAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
impl SubAssign<PipelineStatisticsTypes> for PipelineStatisticsTypes
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.