pub struct AttributeFlags(/* private fields */);Expand description
Represents the flags defined in a PHP #[Attribute] declaration,
specifying the targets where the attribute can be applied and whether it’s repeatable.
Implementations§
Source§impl AttributeFlags
impl AttributeFlags
Sourcepub const TARGET_CLASS: Self
pub const TARGET_CLASS: Self
Flag indicating the attribute can be applied to classes, interfaces, traits, and enums.
Corresponds to Attribute::TARGET_CLASS.
Sourcepub const TARGET_FUNCTION: Self
pub const TARGET_FUNCTION: Self
Flag indicating the attribute can be applied to functions (including closures and arrow functions).
Corresponds to Attribute::TARGET_FUNCTION.
Sourcepub const TARGET_METHOD: Self
pub const TARGET_METHOD: Self
Flag indicating the attribute can be applied to methods.
Corresponds to Attribute::TARGET_METHOD.
Sourcepub const TARGET_PROPERTY: Self
pub const TARGET_PROPERTY: Self
Flag indicating the attribute can be applied to properties.
Corresponds to Attribute::TARGET_PROPERTY.
Sourcepub const TARGET_CLASS_CONSTANT: Self
pub const TARGET_CLASS_CONSTANT: Self
Flag indicating the attribute can be applied to class constants.
Corresponds to Attribute::TARGET_CLASS_CONSTANT.
Sourcepub const TARGET_PARAMETER: Self
pub const TARGET_PARAMETER: Self
Flag indicating the attribute can be applied to function or method parameters.
Corresponds to Attribute::TARGET_PARAMETER.
Sourcepub const TARGET_CONSTANT: Self
pub const TARGET_CONSTANT: Self
Flag indicating the attribute can be applied to global constants (defined with const).
Corresponds to Attribute::TARGET_CONSTANT.
Sourcepub const TARGET_ALL: Self
pub const TARGET_ALL: Self
A combination of all TARGET_* flags, indicating the attribute can be applied anywhere.
Corresponds to Attribute::TARGET_ALL.
Sourcepub const IS_REPEATABLE: Self
pub const IS_REPEATABLE: Self
Flag indicating the attribute can be repeated on the same declaration.
Corresponds to Attribute::IS_REPEATABLE.
Source§impl AttributeFlags
impl AttributeFlags
Sourcepub const fn bits(&self) -> u8
pub const fn bits(&self) -> u8
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
Sourcepub const fn from_bits(bits: u8) -> Option<Self>
pub const fn from_bits(bits: u8) -> Option<Self>
Convert from a bits value.
This method will return None if any unknown bits are set.
Sourcepub const fn from_bits_truncate(bits: u8) -> Self
pub const fn from_bits_truncate(bits: u8) -> Self
Convert from a bits value, unsetting any unknown bits.
Sourcepub const fn from_bits_retain(bits: u8) -> Self
pub const fn from_bits_retain(bits: u8) -> Self
Convert from a bits value exactly.
Sourcepub fn from_name(name: &str) -> Option<Self>
pub fn from_name(name: &str) -> Option<Self>
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: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
Sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
Sourcepub fn remove(&mut self, other: Self)
pub fn remove(&mut self, other: Self)
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: Self)
pub fn toggle(&mut self, other: Self)
The bitwise exclusive-or (^) of the bits in two flags values.
Sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Call insert when value is true or remove when value is false.
Sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
The bitwise and (&) of the bits in two flags values.
Sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
The bitwise or (|) of the bits in two flags values.
Sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
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: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
The bitwise exclusive-or (^) of the bits in two flags values.
Sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
The bitwise negation (!) of the bits in a flags value, truncating the result.
Source§impl AttributeFlags
impl AttributeFlags
Sourcepub const fn iter(&self) -> Iter<AttributeFlags>
pub const fn iter(&self) -> Iter<AttributeFlags>
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<AttributeFlags>
pub const fn iter_names(&self) -> IterNames<AttributeFlags>
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.
Source§impl AttributeFlags
impl AttributeFlags
Sourcepub const fn is_repeatable(&self) -> bool
pub const fn is_repeatable(&self) -> bool
Checks if the IS_REPEATABLE flag is set, meaning the attribute
can be declared multiple times on the same target.
Sourcepub const fn targets_class(&self) -> bool
pub const fn targets_class(&self) -> bool
Checks if the TARGET_CLASS flag is set, indicating the attribute
can be applied to classes, interfaces, traits, or enums.
Sourcepub const fn targets_function(&self) -> bool
pub const fn targets_function(&self) -> bool
Checks if the TARGET_FUNCTION flag is set, indicating the attribute
can be applied to functions or closures.
Sourcepub const fn targets_method(&self) -> bool
pub const fn targets_method(&self) -> bool
Checks if the TARGET_METHOD flag is set, indicating the attribute
can be applied to class or interface methods.
Sourcepub const fn targets_property(&self) -> bool
pub const fn targets_property(&self) -> bool
Checks if the TARGET_PROPERTY flag is set, indicating the attribute
can be applied to class properties.
Sourcepub const fn targets_class_constant(&self) -> bool
pub const fn targets_class_constant(&self) -> bool
Checks if the TARGET_CLASS_CONSTANT flag is set, indicating the attribute
can be applied to class constants.
Sourcepub const fn targets_parameter(&self) -> bool
pub const fn targets_parameter(&self) -> bool
Checks if the TARGET_PARAMETER flag is set, indicating the attribute
can be applied to function or method parameters.
Sourcepub const fn targets_constant(&self) -> bool
pub const fn targets_constant(&self) -> bool
Checks if the TARGET_CONSTANT flag is set, indicating the attribute
can be applied to global constants.
Sourcepub fn get_target_names(&self) -> Vec<&'static str>
pub fn get_target_names(&self) -> Vec<&'static str>
Returns a list of human-readable strings for each target flag set.
Trait Implementations§
Source§impl Binary for AttributeFlags
impl Binary for AttributeFlags
Source§impl BitAnd for AttributeFlags
impl BitAnd for AttributeFlags
Source§impl BitAndAssign for AttributeFlags
impl BitAndAssign for AttributeFlags
Source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
The bitwise and (&) of the bits in two flags values.
Source§impl BitOr for AttributeFlags
impl BitOr for AttributeFlags
Source§fn bitor(self, other: AttributeFlags) -> Self
fn bitor(self, other: AttributeFlags) -> Self
The bitwise or (|) of the bits in two flags values.
Source§type Output = AttributeFlags
type Output = AttributeFlags
| operator.Source§impl BitOrAssign for AttributeFlags
impl BitOrAssign for AttributeFlags
Source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
The bitwise or (|) of the bits in two flags values.
Source§impl BitXor for AttributeFlags
impl BitXor for AttributeFlags
Source§impl BitXorAssign for AttributeFlags
impl BitXorAssign for AttributeFlags
Source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
The bitwise exclusive-or (^) of the bits in two flags values.
Source§impl Clone for AttributeFlags
impl Clone for AttributeFlags
Source§fn clone(&self) -> AttributeFlags
fn clone(&self) -> AttributeFlags
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for AttributeFlags
impl Debug for AttributeFlags
Source§impl<'de> Deserialize<'de> for AttributeFlags
impl<'de> Deserialize<'de> for AttributeFlags
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl Extend<AttributeFlags> for AttributeFlags
impl Extend<AttributeFlags> for AttributeFlags
Source§fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
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 AttributeFlags
impl Flags for AttributeFlags
Source§const FLAGS: &'static [Flag<AttributeFlags>]
const FLAGS: &'static [Flag<AttributeFlags>]
Source§fn from_bits_retain(bits: u8) -> AttributeFlags
fn from_bits_retain(bits: u8) -> AttributeFlags
Source§fn contains_unknown_bits(&self) -> bool
fn contains_unknown_bits(&self) -> bool
true if any unknown bits are set.Source§fn from_bits_truncate(bits: Self::Bits) -> Self
fn from_bits_truncate(bits: Self::Bits) -> Self
Source§fn from_name(name: &str) -> Option<Self>
fn from_name(name: &str) -> Option<Self>
Source§fn iter_names(&self) -> IterNames<Self>
fn iter_names(&self) -> IterNames<Self>
Source§fn iter_defined_names() -> IterDefinedNames<Self>
fn iter_defined_names() -> IterDefinedNames<Self>
Self::FLAGS.Source§fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
Source§fn contains(&self, other: Self) -> boolwhere
Self: Sized,
fn contains(&self, other: Self) -> boolwhere
Self: Sized,
Source§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.Source§fn remove(&mut self, other: Self)where
Self: Sized,
fn remove(&mut self, other: Self)where
Self: Sized,
&!). Read moreSource§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.Source§fn intersection(self, other: Self) -> Self
fn intersection(self, other: Self) -> Self
&) of the bits in two flags values.Source§fn difference(self, other: Self) -> Self
fn difference(self, other: Self) -> Self
&!). Read moreSource§fn symmetric_difference(self, other: Self) -> Self
fn symmetric_difference(self, other: Self) -> Self
^) of the bits in two flags values.Source§fn complement(self) -> Self
fn complement(self) -> Self
!) of the bits in a flags value, truncating the result.Source§impl FromIterator<AttributeFlags> for AttributeFlags
impl FromIterator<AttributeFlags> for AttributeFlags
Source§fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
The bitwise or (|) of the bits in each flags value.
Source§impl IntoIterator for AttributeFlags
impl IntoIterator for AttributeFlags
Source§impl LowerHex for AttributeFlags
impl LowerHex for AttributeFlags
Source§impl Not for AttributeFlags
impl Not for AttributeFlags
Source§impl Octal for AttributeFlags
impl Octal for AttributeFlags
Source§impl PartialEq for AttributeFlags
impl PartialEq for AttributeFlags
Source§impl PublicFlags for AttributeFlags
impl PublicFlags for AttributeFlags
Source§impl Serialize for AttributeFlags
impl Serialize for AttributeFlags
Source§impl Sub for AttributeFlags
impl Sub for AttributeFlags
Source§fn sub(self, other: Self) -> Self
fn sub(self, other: Self) -> Self
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 = AttributeFlags
type Output = AttributeFlags
- operator.Source§impl SubAssign for AttributeFlags
impl SubAssign for AttributeFlags
Source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
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 AttributeFlags
impl UpperHex for AttributeFlags
impl Copy for AttributeFlags
impl Eq for AttributeFlags
impl StructuralPartialEq for AttributeFlags
Auto Trait Implementations§
impl Freeze for AttributeFlags
impl RefUnwindSafe for AttributeFlags
impl Send for AttributeFlags
impl Sync for AttributeFlags
impl Unpin for AttributeFlags
impl UnwindSafe for AttributeFlags
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,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);