Struct similar::algorithms::Replace

source ·
pub struct Replace<D: DiffHook> { /* private fields */ }
Expand description

A DiffHook that combines deletions and insertions to give blocks of maximal length, and replacements when appropriate.

It will replace DiffHook::insert and DiffHook::delete events when possible with DiffHook::replace events. Note that even though the text processing in the crate does not use replace events and always resolves then back to delete and insert, it’s useful to always use the replacer to ensure a consistent order of inserts and deletes. This is why for instance the text diffing automatically uses this hook internally.

Implementations§

source§

impl<D: DiffHook> Replace<D>

source

pub fn new(d: D) -> Self

Creates a new replace hook wrapping another hook.

source

pub fn into_inner(self) -> D

Extracts the inner hook.

Trait Implementations§

source§

impl<D: DiffHook> AsMut<D> for Replace<D>

source§

fn as_mut(&mut self) -> &mut D

Converts this type into a mutable reference of the (usually inferred) input type.
source§

impl<D: DiffHook> AsRef<D> for Replace<D>

source§

fn as_ref(&self) -> &D

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<D: DiffHook> DiffHook for Replace<D>

§

type Error = <D as DiffHook>::Error

The error produced from the hook methods.
source§

fn equal( &mut self, old_index: usize, new_index: usize, len: usize, ) -> Result<(), D::Error>

Called when lines with indices old_index (in the old version) and new_index (in the new version) start an section equal in both versions, of length len.
source§

fn delete( &mut self, old_index: usize, old_len: usize, new_index: usize, ) -> Result<(), D::Error>

Called when a section of length old_len, starting at old_index, needs to be deleted from the old version.
source§

fn insert( &mut self, old_index: usize, new_index: usize, new_len: usize, ) -> Result<(), D::Error>

Called when a section of the new version, of length new_len and starting at new_index, needs to be inserted at position `old_index’.
source§

fn replace( &mut self, old_index: usize, old_len: usize, new_index: usize, new_len: usize, ) -> Result<(), D::Error>

Called when a section of the old version, starting at index old_index and of length old_len, needs to be replaced with a section of length new_len, starting at new_index, of the new version. Read more
source§

fn finish(&mut self) -> Result<(), D::Error>

Always called at the end of the algorithm.

Auto Trait Implementations§

§

impl<D> Freeze for Replace<D>
where D: Freeze,

§

impl<D> RefUnwindSafe for Replace<D>
where D: RefUnwindSafe,

§

impl<D> Send for Replace<D>
where D: Send,

§

impl<D> Sync for Replace<D>
where D: Sync,

§

impl<D> Unpin for Replace<D>
where D: Unpin,

§

impl<D> UnwindSafe for Replace<D>
where D: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.