using System;
namespace ICSharpCode.Decompiler.Xml
{
///
/// Describes a change of the document text.
/// This class is thread-safe.
///
[Serializable]
public class TextChangeEventArgs : EventArgs
{
readonly int offset;
readonly ITextSource removedText;
readonly ITextSource insertedText;
///
/// The offset at which the change occurs.
///
public int Offset {
get { return offset; }
}
///
/// The text that was removed.
///
public ITextSource RemovedText {
get { return removedText; }
}
///
/// The number of characters removed.
///
public int RemovalLength {
get { return removedText.TextLength; }
}
///
/// The text that was inserted.
///
public ITextSource InsertedText {
get { return insertedText; }
}
///
/// The number of characters inserted.
///
public int InsertionLength {
get { return insertedText.TextLength; }
}
///
/// Creates a new TextChangeEventArgs object.
///
public TextChangeEventArgs(int offset, string removedText, string insertedText)
{
if (offset < 0)
throw new ArgumentOutOfRangeException("offset", offset, "offset must not be negative");
this.offset = offset;
this.removedText = removedText != null ? new StringTextSource(removedText) : StringTextSource.Empty;
this.insertedText = insertedText != null ? new StringTextSource(insertedText) : StringTextSource.Empty;
}
///
/// Creates a new TextChangeEventArgs object.
///
public TextChangeEventArgs(int offset, ITextSource removedText, ITextSource insertedText)
{
if (offset < 0)
throw new ArgumentOutOfRangeException("offset", offset, "offset must not be negative");
this.offset = offset;
this.removedText = removedText ?? StringTextSource.Empty;
this.insertedText = insertedText ?? StringTextSource.Empty;
}
///
/// Gets the new offset where the specified offset moves after this document change.
///
public virtual int GetNewOffset(int offset, AnchorMovementType movementType = AnchorMovementType.Default)
{
if (offset >= this.Offset && offset <= this.Offset + this.RemovalLength) {
if (movementType == AnchorMovementType.BeforeInsertion)
return this.Offset;
else
return this.Offset + this.InsertionLength;
} else if (offset > this.Offset) {
return offset + this.InsertionLength - this.RemovalLength;
} else {
return offset;
}
}
///
/// Creates TextChangeEventArgs for the reverse change.
///
public virtual TextChangeEventArgs Invert()
{
return new TextChangeEventArgs(offset, insertedText, removedText);
}
}
}