Struct BreaksInfo
pub struct BreaksInfo(/* private fields */);Expand description
The number of breaks.
Trait Implementations§
§impl Clone for BreaksInfo
impl Clone for BreaksInfo
§fn clone(&self) -> BreaksInfo
fn clone(&self) -> BreaksInfo
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read more§impl Debug for BreaksInfo
impl Debug for BreaksInfo
§impl DefaultMetric for BreaksInfo
impl DefaultMetric for BreaksInfo
type DefaultMetric = BreaksBaseMetric
§impl Metric<BreaksInfo> for BreaksBaseMetric
impl Metric<BreaksInfo> for BreaksBaseMetric
§fn measure(_: &BreaksInfo, len: usize) -> usize
fn measure(_: &BreaksInfo, len: usize) -> usize
Return the size of the
NodeInfo::L, as measured by this
metric. Read more
§fn to_base_units(_: &BreaksLeaf, in_measured_units: usize) -> usize
fn to_base_units(_: &BreaksLeaf, in_measured_units: usize) -> usize
Returns the smallest offset, in base units, for an offset in measured units. Read more
§fn from_base_units(_: &BreaksLeaf, in_base_units: usize) -> usize
fn from_base_units(_: &BreaksLeaf, in_base_units: usize) -> usize
Returns the smallest offset in measured units corresponding to an offset in base units. Read more
§fn is_boundary(l: &BreaksLeaf, offset: usize) -> bool
fn is_boundary(l: &BreaksLeaf, offset: usize) -> bool
Return whether the offset in base units is a boundary of this metric.
If a boundary is at end of a leaf then this method must return true.
However, a boundary at the beginning of a leaf is optional
(the previous leaf will be queried).
§fn prev(l: &BreaksLeaf, offset: usize) -> Option<usize>
fn prev(l: &BreaksLeaf, offset: usize) -> Option<usize>
Returns the index of the boundary directly preceding offset,
or None if no such boundary exists. Input and result are in base units.
§fn next(l: &BreaksLeaf, offset: usize) -> Option<usize>
fn next(l: &BreaksLeaf, offset: usize) -> Option<usize>
Returns the index of the first boundary for which index > offset,
or None if no such boundary exists. Input and result are in base units.
§fn can_fragment() -> bool
fn can_fragment() -> bool
Returns true if the measured units in this metric can span multiple
leaves. As an example, in a metric that measures lines in a rope, a
line may start in one leaf and end in another; however in a metric
measuring bytes, storage of a single byte cannot extend across leaves.
§impl Metric<BreaksInfo> for BreaksMetric
impl Metric<BreaksInfo> for BreaksMetric
§fn measure(info: &BreaksInfo, _: usize) -> usize
fn measure(info: &BreaksInfo, _: usize) -> usize
Return the size of the
NodeInfo::L, as measured by this
metric. Read more
§fn to_base_units(l: &BreaksLeaf, in_measured_units: usize) -> usize
fn to_base_units(l: &BreaksLeaf, in_measured_units: usize) -> usize
Returns the smallest offset, in base units, for an offset in measured units. Read more
§fn from_base_units(l: &BreaksLeaf, in_base_units: usize) -> usize
fn from_base_units(l: &BreaksLeaf, in_base_units: usize) -> usize
Returns the smallest offset in measured units corresponding to an offset in base units. Read more
§fn is_boundary(l: &BreaksLeaf, offset: usize) -> bool
fn is_boundary(l: &BreaksLeaf, offset: usize) -> bool
Return whether the offset in base units is a boundary of this metric.
If a boundary is at end of a leaf then this method must return true.
However, a boundary at the beginning of a leaf is optional
(the previous leaf will be queried).
§fn prev(l: &BreaksLeaf, offset: usize) -> Option<usize>
fn prev(l: &BreaksLeaf, offset: usize) -> Option<usize>
Returns the index of the boundary directly preceding offset,
or None if no such boundary exists. Input and result are in base units.
§fn next(l: &BreaksLeaf, offset: usize) -> Option<usize>
fn next(l: &BreaksLeaf, offset: usize) -> Option<usize>
Returns the index of the first boundary for which index > offset,
or None if no such boundary exists. Input and result are in base units.
§fn can_fragment() -> bool
fn can_fragment() -> bool
Returns true if the measured units in this metric can span multiple
leaves. As an example, in a metric that measures lines in a rope, a
line may start in one leaf and end in another; however in a metric
measuring bytes, storage of a single byte cannot extend across leaves.
§impl NodeInfo for BreaksInfo
impl NodeInfo for BreaksInfo
§type L = BreaksLeaf
type L = BreaksLeaf
The type of the leaf. Read more
§fn accumulate(&mut self, other: &BreaksInfo)
fn accumulate(&mut self, other: &BreaksInfo)
An operator that combines info from two subtrees. It is intended
(but not strictly enforced) that this operator be associative and
obey an identity property. In mathematical terms, the accumulate
method is the operation of a monoid.
§fn compute_info(l: &BreaksLeaf) -> BreaksInfo
fn compute_info(l: &BreaksLeaf) -> BreaksInfo
A mapping from a leaf into the info type. It is intended (but
not strictly enforced) that applying the accumulate method to
the info derived from two leaves gives the same result as
deriving the info from the concatenation of the two leaves. In
mathematical terms, the compute_info method is a monoid
homomorphism.
Auto Trait Implementations§
impl Freeze for BreaksInfo
impl RefUnwindSafe for BreaksInfo
impl Send for BreaksInfo
impl Sync for BreaksInfo
impl Unpin for BreaksInfo
impl UnsafeUnpin for BreaksInfo
impl UnwindSafe for BreaksInfo
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§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>
Convert
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>
Convert
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)
Convert
&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)
Convert
&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<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>
Converts
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>
Converts
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 more