public class ReplacementsFinder<T> extends Object implements CommandVisitor<T>
The comparison of two objects sequences leads to the identification of common
parts and parts which only belong to the first or to the second sequence. The
common parts appear in the edit script in the form of keep commands,
they can be considered as synchronization objects between the two sequences.
These synchronization objects split the two sequences in synchronized
sub-sequences. The first sequence can be transformed into the second one by
replacing each synchronized sub-sequence of the first sequence by the
corresponding sub-sequence of the second sequence. This is a synthetic way to
see an edit script
, replacing individual
delete
, keep
and
insert
commands by fewer replacements acting on
complete sub-sequences.
This class is devoted to perform this interpretation. It visits an
edit script
(because it implements the
CommandVisitor
interface) and calls a user-supplied
handler implementing the ReplacementsHandler
interface to process the sub-sequences.
ReplacementsHandler
,
EditScript
,
SequencesComparator
Constructor and Description |
---|
ReplacementsFinder(ReplacementsHandler<T> handler)
Simple constructor.
|
Modifier and Type | Method and Description |
---|---|
void |
visitDeleteCommand(T object)
Add an object to the pending deletions set.
|
void |
visitInsertCommand(T object)
Add an object to the pending insertions set.
|
void |
visitKeepCommand(T object)
Handle a synchronization object.
|
public ReplacementsFinder(ReplacementsHandler<T> handler)
ReplacementsFinder
.handler
- handler to call when synchronized sequences are foundpublic void visitInsertCommand(T object)
visitInsertCommand
in interface CommandVisitor<T>
object
- object to insertpublic void visitKeepCommand(T object)
When a synchronization object is identified, the pending insertions and pending deletions sets are provided to the user handler as subsequences.
visitKeepCommand
in interface CommandVisitor<T>
object
- synchronization object detectedpublic void visitDeleteCommand(T object)
visitDeleteCommand
in interface CommandVisitor<T>
object
- object to deleteCopyright © 2001–2018 The Apache Software Foundation. All rights reserved.