pub struct DecodeFlags { /* private fields */ }
Expand description
Flags that affect transcoding
Implementations§
Source§impl DecodeFlags
impl DecodeFlags
Sourcepub const PVRTC_DECODE_TO_NEXT_POW_2: Self
pub const PVRTC_DECODE_TO_NEXT_POW_2: Self
PVRTC1: decode non-pow2 ETC1S texture level to the next larger power of 2 (not implemented yet, but we’re going to support it). Ignored if the slice’s dimensions are already a power of 2.
Sourcepub const TRANSCODE_ALPHA_DATA_TO_OPAQUE_FORMATS: Self
pub const TRANSCODE_ALPHA_DATA_TO_OPAQUE_FORMATS: Self
When decoding to an opaque texture format, if the basis file has alpha, decode the alpha slice instead of the color slice to the output texture format. This is primarily to allow decoding of textures with alpha to multiple ETC1 textures (one for color, another for alpha).
Sourcepub const BC1_FORBID_THREE_COLOR_BLOCKS: Self
pub const BC1_FORBID_THREE_COLOR_BLOCKS: Self
Forbid usage of BC1 3 color blocks (we don’t support BC1 punchthrough alpha yet). This flag is used internally when decoding to BC3.
Sourcepub const OUTPUT_HAS_ALPHA_INDICES: Self
pub const OUTPUT_HAS_ALPHA_INDICES: Self
The output buffer contains alpha endpoint/selector indices. Used internally when decoding formats like ASTC that require both color and alpha data to be available when transcoding to the output format.
pub const HIGH_QUALITY: Self
Sourcepub const fn from_bits(bits: i32) -> Option<Self>
pub const fn from_bits(bits: i32) -> 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: i32) -> Self
pub const fn from_bits_truncate(bits: i32) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
Sourcepub const unsafe fn from_bits_unchecked(bits: i32) -> Self
pub const unsafe fn from_bits_unchecked(bits: i32) -> 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 DecodeFlags
impl Binary for DecodeFlags
Source§impl BitAnd for DecodeFlags
impl BitAnd for DecodeFlags
Source§impl BitAndAssign for DecodeFlags
impl BitAndAssign for DecodeFlags
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 for DecodeFlags
impl BitOr for DecodeFlags
Source§fn bitor(self, other: DecodeFlags) -> Self
fn bitor(self, other: DecodeFlags) -> Self
Returns the union of the two sets of flags.
Source§type Output = DecodeFlags
type Output = DecodeFlags
|
operator.Source§impl BitOrAssign for DecodeFlags
impl BitOrAssign for DecodeFlags
Source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
Source§impl BitXor for DecodeFlags
impl BitXor for DecodeFlags
Source§impl BitXorAssign for DecodeFlags
impl BitXorAssign for DecodeFlags
Source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
Source§impl Clone for DecodeFlags
impl Clone for DecodeFlags
Source§fn clone(&self) -> DecodeFlags
fn clone(&self) -> DecodeFlags
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for DecodeFlags
impl Debug for DecodeFlags
Source§impl Extend<DecodeFlags> for DecodeFlags
impl Extend<DecodeFlags> for DecodeFlags
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<DecodeFlags> for DecodeFlags
impl FromIterator<DecodeFlags> for DecodeFlags
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 DecodeFlags
impl Hash for DecodeFlags
Source§impl LowerHex for DecodeFlags
impl LowerHex for DecodeFlags
Source§impl Not for DecodeFlags
impl Not for DecodeFlags
Source§impl Octal for DecodeFlags
impl Octal for DecodeFlags
Source§impl Ord for DecodeFlags
impl Ord for DecodeFlags
Source§fn cmp(&self, other: &DecodeFlags) -> Ordering
fn cmp(&self, other: &DecodeFlags) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Source§impl PartialEq for DecodeFlags
impl PartialEq for DecodeFlags
Source§impl PartialOrd for DecodeFlags
impl PartialOrd for DecodeFlags
Source§impl Sub for DecodeFlags
impl Sub for DecodeFlags
Source§impl SubAssign for DecodeFlags
impl SubAssign for DecodeFlags
Source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.