pub struct BufferFlags(/* private fields */);
Expand description
Flags for buffers.
Implementations§
source§impl BufferFlags
impl BufferFlags
sourcepub const BEGINNING_OF_TEXT: BufferFlags = _
pub const BEGINNING_OF_TEXT: BufferFlags = _
Indicates that special handling of the beginning of text paragraph can be applied to this buffer. Should usually be set, unless you are passing to the buffer only part of the text without the full context.
sourcepub const END_OF_TEXT: BufferFlags = _
pub const END_OF_TEXT: BufferFlags = _
Indicates that special handling of the end of text paragraph can be applied to this buffer, similar to BufferFlags::BEGINNING_OF_TEXT
.
sourcepub const PRESERVE_DEFAULT_IGNORABLES: BufferFlags = _
pub const PRESERVE_DEFAULT_IGNORABLES: BufferFlags = _
Indicates that characters with Default_Ignorable
Unicode property should use the corresponding glyph from the font, instead of hiding them (done by replacing them with the space glyph and zeroing the advance width.) This flag takes precedence over BufferFlags::REMOVE_DEFAULT_IGNORABLES
.
sourcepub const REMOVE_DEFAULT_IGNORABLES: BufferFlags = _
pub const REMOVE_DEFAULT_IGNORABLES: BufferFlags = _
Indicates that characters with Default_Ignorable
Unicode property should be removed from glyph string instead of hiding them (done by replacing them with the space glyph and zeroing the advance width.) BufferFlags::PRESERVE_DEFAULT_IGNORABLES
takes precedence over this flag.
sourcepub const DO_NOT_INSERT_DOTTED_CIRCLE: BufferFlags = _
pub const DO_NOT_INSERT_DOTTED_CIRCLE: BufferFlags = _
Indicates that a dotted circle should not be inserted in the rendering of incorrect character sequences (such as <0905 093E>
).
sourcepub const VERIFY: BufferFlags = _
pub const VERIFY: BufferFlags = _
Indicates that the shape() call and its variants should perform various verification processes on the results of the shaping operation on the buffer. If the verification fails, then either a buffer message is sent, if a message handler is installed on the buffer, or a message is written to standard error. In either case, the shaping result might be modified to show the failed output.
sourcepub const PRODUCE_UNSAFE_TO_CONCAT: BufferFlags = _
pub const PRODUCE_UNSAFE_TO_CONCAT: BufferFlags = _
Indicates that the UNSAFE_TO_CONCAT
glyph-flag should be produced by the shaper. By default it will not be produced since it incurs a cost.
source§impl BufferFlags
impl BufferFlags
sourcepub const fn empty() -> BufferFlags
pub const fn empty() -> BufferFlags
Get a flags value with all bits unset.
sourcepub const fn all() -> BufferFlags
pub const fn all() -> BufferFlags
Get a flags value with all known bits set.
sourcepub const fn bits(&self) -> u32
pub const fn bits(&self) -> u32
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
sourcepub const fn from_bits(bits: u32) -> Option<BufferFlags>
pub const fn from_bits(bits: u32) -> Option<BufferFlags>
Convert from a bits value.
This method will return None
if any unknown bits are set.
sourcepub const fn from_bits_truncate(bits: u32) -> BufferFlags
pub const fn from_bits_truncate(bits: u32) -> BufferFlags
Convert from a bits value, unsetting any unknown bits.
sourcepub const fn from_bits_retain(bits: u32) -> BufferFlags
pub const fn from_bits_retain(bits: u32) -> BufferFlags
Convert from a bits value exactly.
sourcepub fn from_name(name: &str) -> Option<BufferFlags>
pub fn from_name(name: &str) -> Option<BufferFlags>
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: BufferFlags) -> bool
pub const fn intersects(&self, other: BufferFlags) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
sourcepub const fn contains(&self, other: BufferFlags) -> bool
pub const fn contains(&self, other: BufferFlags) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
sourcepub fn insert(&mut self, other: BufferFlags)
pub fn insert(&mut self, other: BufferFlags)
The bitwise or (|
) of the bits in two flags values.
sourcepub fn remove(&mut self, other: BufferFlags)
pub fn remove(&mut self, other: BufferFlags)
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: BufferFlags)
pub fn toggle(&mut self, other: BufferFlags)
The bitwise exclusive-or (^
) of the bits in two flags values.
sourcepub fn set(&mut self, other: BufferFlags, value: bool)
pub fn set(&mut self, other: BufferFlags, value: bool)
Call insert
when value
is true
or remove
when value
is false
.
sourcepub const fn intersection(self, other: BufferFlags) -> BufferFlags
pub const fn intersection(self, other: BufferFlags) -> BufferFlags
The bitwise and (&
) of the bits in two flags values.
sourcepub const fn union(self, other: BufferFlags) -> BufferFlags
pub const fn union(self, other: BufferFlags) -> BufferFlags
The bitwise or (|
) of the bits in two flags values.
sourcepub const fn difference(self, other: BufferFlags) -> BufferFlags
pub const fn difference(self, other: BufferFlags) -> BufferFlags
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: BufferFlags) -> BufferFlags
pub const fn symmetric_difference(self, other: BufferFlags) -> BufferFlags
The bitwise exclusive-or (^
) of the bits in two flags values.
sourcepub const fn complement(self) -> BufferFlags
pub const fn complement(self) -> BufferFlags
The bitwise negation (!
) of the bits in a flags value, truncating the result.
source§impl BufferFlags
impl BufferFlags
sourcepub const fn iter(&self) -> Iter<BufferFlags>
pub const fn iter(&self) -> Iter<BufferFlags>
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<BufferFlags>
pub const fn iter_names(&self) -> IterNames<BufferFlags>
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§
source§impl Binary for BufferFlags
impl Binary for BufferFlags
source§impl BitAnd for BufferFlags
impl BitAnd for BufferFlags
source§fn bitand(self, other: BufferFlags) -> BufferFlags
fn bitand(self, other: BufferFlags) -> BufferFlags
The bitwise and (&
) of the bits in two flags values.
source§type Output = BufferFlags
type Output = BufferFlags
&
operator.source§impl BitAndAssign for BufferFlags
impl BitAndAssign for BufferFlags
source§fn bitand_assign(&mut self, other: BufferFlags)
fn bitand_assign(&mut self, other: BufferFlags)
The bitwise and (&
) of the bits in two flags values.
source§impl BitOr for BufferFlags
impl BitOr for BufferFlags
source§fn bitor(self, other: BufferFlags) -> BufferFlags
fn bitor(self, other: BufferFlags) -> BufferFlags
The bitwise or (|
) of the bits in two flags values.
source§type Output = BufferFlags
type Output = BufferFlags
|
operator.source§impl BitOrAssign for BufferFlags
impl BitOrAssign for BufferFlags
source§fn bitor_assign(&mut self, other: BufferFlags)
fn bitor_assign(&mut self, other: BufferFlags)
The bitwise or (|
) of the bits in two flags values.
source§impl BitXor for BufferFlags
impl BitXor for BufferFlags
source§fn bitxor(self, other: BufferFlags) -> BufferFlags
fn bitxor(self, other: BufferFlags) -> BufferFlags
The bitwise exclusive-or (^
) of the bits in two flags values.
source§type Output = BufferFlags
type Output = BufferFlags
^
operator.source§impl BitXorAssign for BufferFlags
impl BitXorAssign for BufferFlags
source§fn bitxor_assign(&mut self, other: BufferFlags)
fn bitxor_assign(&mut self, other: BufferFlags)
The bitwise exclusive-or (^
) of the bits in two flags values.
source§impl Clone for BufferFlags
impl Clone for BufferFlags
source§fn clone(&self) -> BufferFlags
fn clone(&self) -> BufferFlags
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for BufferFlags
impl Debug for BufferFlags
source§impl Default for BufferFlags
impl Default for BufferFlags
source§fn default() -> BufferFlags
fn default() -> BufferFlags
source§impl Extend<BufferFlags> for BufferFlags
impl Extend<BufferFlags> for BufferFlags
source§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = BufferFlags>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = BufferFlags>,
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 BufferFlags
impl Flags for BufferFlags
source§const FLAGS: &'static [Flag<BufferFlags>] = _
const FLAGS: &'static [Flag<BufferFlags>] = _
source§fn from_bits_retain(bits: u32) -> BufferFlags
fn from_bits_retain(bits: u32) -> BufferFlags
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 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<BufferFlags> for BufferFlags
impl FromIterator<BufferFlags> for BufferFlags
source§fn from_iter<T>(iterator: T) -> BufferFlagswhere
T: IntoIterator<Item = BufferFlags>,
fn from_iter<T>(iterator: T) -> BufferFlagswhere
T: IntoIterator<Item = BufferFlags>,
The bitwise or (|
) of the bits in each flags value.
source§impl IntoIterator for BufferFlags
impl IntoIterator for BufferFlags
source§type Item = BufferFlags
type Item = BufferFlags
source§type IntoIter = Iter<BufferFlags>
type IntoIter = Iter<BufferFlags>
source§fn into_iter(self) -> <BufferFlags as IntoIterator>::IntoIter
fn into_iter(self) -> <BufferFlags as IntoIterator>::IntoIter
source§impl LowerHex for BufferFlags
impl LowerHex for BufferFlags
source§impl Not for BufferFlags
impl Not for BufferFlags
source§fn not(self) -> BufferFlags
fn not(self) -> BufferFlags
The bitwise negation (!
) of the bits in a flags value, truncating the result.
source§type Output = BufferFlags
type Output = BufferFlags
!
operator.source§impl Octal for BufferFlags
impl Octal for BufferFlags
source§impl Sub for BufferFlags
impl Sub for BufferFlags
source§fn sub(self, other: BufferFlags) -> BufferFlags
fn sub(self, other: BufferFlags) -> BufferFlags
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 = BufferFlags
type Output = BufferFlags
-
operator.source§impl SubAssign for BufferFlags
impl SubAssign for BufferFlags
source§fn sub_assign(&mut self, other: BufferFlags)
fn sub_assign(&mut self, other: BufferFlags)
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 BufferFlags
impl UpperHex for BufferFlags
impl Copy for BufferFlags
Auto Trait Implementations§
impl Freeze for BufferFlags
impl RefUnwindSafe for BufferFlags
impl Send for BufferFlags
impl Sync for BufferFlags
impl Unpin for BufferFlags
impl UnwindSafe for BufferFlags
Blanket Implementations§
source§impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for Swhere
T: Real + Zero + Arithmetics + Clone,
Swp: WhitePoint<T>,
Dwp: WhitePoint<T>,
D: AdaptFrom<S, Swp, Dwp, T>,
impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for Swhere
T: Real + Zero + Arithmetics + Clone,
Swp: WhitePoint<T>,
Dwp: WhitePoint<T>,
D: AdaptFrom<S, Swp, Dwp, T>,
source§fn adapt_into_using<M>(self, method: M) -> Dwhere
M: TransformMatrix<T>,
fn adapt_into_using<M>(self, method: M) -> Dwhere
M: TransformMatrix<T>,
source§fn adapt_into(self) -> D
fn adapt_into(self) -> D
source§impl<T, Res> Apply<Res> for Twhere
T: ?Sized,
impl<T, Res> Apply<Res> for Twhere
T: ?Sized,
source§impl<T, C> ArraysFrom<C> for Twhere
C: IntoArrays<T>,
impl<T, C> ArraysFrom<C> for Twhere
C: IntoArrays<T>,
source§fn arrays_from(colors: C) -> T
fn arrays_from(colors: C) -> T
source§impl<T, C> ArraysInto<C> for Twhere
C: FromArrays<T>,
impl<T, C> ArraysInto<C> for Twhere
C: FromArrays<T>,
source§fn arrays_into(self) -> C
fn arrays_into(self) -> C
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<WpParam, T, U> Cam16IntoUnclamped<WpParam, T> for Uwhere
T: FromCam16Unclamped<WpParam, U>,
impl<WpParam, T, U> Cam16IntoUnclamped<WpParam, T> for Uwhere
T: FromCam16Unclamped<WpParam, U>,
source§type Scalar = <T as FromCam16Unclamped<WpParam, U>>::Scalar
type Scalar = <T as FromCam16Unclamped<WpParam, U>>::Scalar
parameters
when converting.source§fn cam16_into_unclamped(
self,
parameters: BakedParameters<WpParam, <U as Cam16IntoUnclamped<WpParam, T>>::Scalar>,
) -> T
fn cam16_into_unclamped( self, parameters: BakedParameters<WpParam, <U as Cam16IntoUnclamped<WpParam, T>>::Scalar>, ) -> T
self
into C
, using the provided parameters.source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T, C> ComponentsFrom<C> for Twhere
C: IntoComponents<T>,
impl<T, C> ComponentsFrom<C> for Twhere
C: IntoComponents<T>,
source§fn components_from(colors: C) -> T
fn components_from(colors: C) -> T
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
source§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
.source§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
.source§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.source§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.source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
source§impl<T> FromAngle<T> for T
impl<T> FromAngle<T> for T
source§fn from_angle(angle: T) -> T
fn from_angle(angle: T) -> T
angle
.source§impl<T, U> FromStimulus<U> for Twhere
U: IntoStimulus<T>,
impl<T, U> FromStimulus<U> for Twhere
U: IntoStimulus<T>,
source§fn from_stimulus(other: U) -> T
fn from_stimulus(other: U) -> T
other
into Self
, while performing the appropriate scaling,
rounding and clamping.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, U> IntoAngle<U> for Twhere
U: FromAngle<T>,
impl<T, U> IntoAngle<U> for Twhere
U: FromAngle<T>,
source§fn into_angle(self) -> U
fn into_angle(self) -> U
T
.source§impl<WpParam, T, U> IntoCam16Unclamped<WpParam, T> for Uwhere
T: Cam16FromUnclamped<WpParam, U>,
impl<WpParam, T, U> IntoCam16Unclamped<WpParam, T> for Uwhere
T: Cam16FromUnclamped<WpParam, U>,
source§type Scalar = <T as Cam16FromUnclamped<WpParam, U>>::Scalar
type Scalar = <T as Cam16FromUnclamped<WpParam, U>>::Scalar
parameters
when converting.source§fn into_cam16_unclamped(
self,
parameters: BakedParameters<WpParam, <U as IntoCam16Unclamped<WpParam, T>>::Scalar>,
) -> T
fn into_cam16_unclamped( self, parameters: BakedParameters<WpParam, <U as IntoCam16Unclamped<WpParam, T>>::Scalar>, ) -> T
self
into C
, using the provided parameters.source§impl<T, U> IntoColor<U> for Twhere
U: FromColor<T>,
impl<T, U> IntoColor<U> for Twhere
U: FromColor<T>,
source§fn into_color(self) -> U
fn into_color(self) -> U
source§impl<T, U> IntoColorUnclamped<U> for Twhere
U: FromColorUnclamped<T>,
impl<T, U> IntoColorUnclamped<U> for Twhere
U: FromColorUnclamped<T>,
source§fn into_color_unclamped(self) -> U
fn into_color_unclamped(self) -> U
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> IntoStimulus<T> for T
impl<T> IntoStimulus<T> for T
source§fn into_stimulus(self) -> T
fn into_stimulus(self) -> T
self
into T
, while performing the appropriate scaling,
rounding and clamping.source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
ReadEndian::read_from_little_endian()
.source§impl<T, C> TryComponentsInto<C> for Twhere
C: TryFromComponents<T>,
impl<T, C> TryComponentsInto<C> for Twhere
C: TryFromComponents<T>,
source§type Error = <C as TryFromComponents<T>>::Error
type Error = <C as TryFromComponents<T>>::Error
try_into_colors
fails to cast.source§fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>
fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>
source§impl<T, U> TryIntoColor<U> for Twhere
U: TryFromColor<T>,
impl<T, U> TryIntoColor<U> for Twhere
U: TryFromColor<T>,
source§fn try_into_color(self) -> Result<U, OutOfBounds<U>>
fn try_into_color(self) -> Result<U, OutOfBounds<U>>
OutOfBounds
error is returned which contains
the unclamped color. Read more