UseLegacyOrder

FindReplaceOptions.UseLegacyOrder property

True indica che una ricerca di testo viene eseguita in sequenza dall’alto verso il basso considerando le caselle di testo. Il valore predefinito è false.

public bool UseLegacyOrder { get; set; }

Esempi

Mostra come modificare l’ordine di ricerca dei nodi durante l’esecuzione di un’operazione di ricerca e sostituzione del testo.

[TestCase(true)] // Salta
[TestCase(false)] // Salta
public void UseLegacyOrder(bool useLegacyOrder)
{
    Document doc = new Document();
    DocumentBuilder builder = new DocumentBuilder(doc);

    // Inserisce tre esecuzioni che possiamo cercare usando un pattern regex.
    // Posiziona una di queste esecuzioni all'interno di una casella di testo.
    builder.Writeln("[tag 1]");
    Shape textBox = builder.InsertShape(ShapeType.TextBox, 100, 50);
    builder.Writeln("[tag 2]");
    builder.MoveTo(textBox.FirstParagraph);
    builder.Write("[tag 3]");

    // Possiamo usare un oggetto "FindReplaceOptions" per modificare il processo di ricerca e sostituzione.
    FindReplaceOptions options = new FindReplaceOptions();

    // Assegna una richiamata personalizzata alla proprietà "ReplacingCallback".
    TextReplacementTracker callback = new TextReplacementTracker();
    options.ReplacingCallback = callback;

    // Se impostiamo la proprietà "UseLegacyOrder" su "true", il file
    // L'operazione trova e sostituisci passerà attraverso tutte le esecuzioni al di fuori di una casella di testo
    // prima di scorrere quelli all'interno di una casella di testo.
    // Se impostiamo la proprietà "UseLegacyOrder" su "false", il file
    // L'operazione trova e sostituisci esaminerà tutte le esecuzioni in un intervallo in ordine sequenziale.
    options.UseLegacyOrder = useLegacyOrder;

    doc.Range.Replace(new Regex(@"\[tag \d*\]"), "", options);

    Assert.AreEqual(useLegacyOrder ?
        new List<string> { "[tag 1]", "[tag 3]", "[tag 2]" } :
        new List<string> { "[tag 1]", "[tag 2]", "[tag 3]" }, callback.Matches);
}

/// <summary>
/// Registra l'ordine di tutte le corrispondenze che si verificano durante un'operazione di ricerca e sostituzione.
/// </summary>
private class TextReplacementTracker : IReplacingCallback
{
    ReplaceAction IReplacingCallback.Replacing(ReplacingArgs e)
    {
        Matches.Add(e.Match.Value);
        return ReplaceAction.Replace;
    }

    public List<string> Matches { get; } = new List<string>();
}

Guarda anche