1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
/*
SPDX-FileCopyrightText: 2015-2025 Laurent Montel <montel@kde.org>
SPDX-License-Identifier: LGPL-2.0-or-later
*/
#pragma once
#include "textcustomeditor_export.h"
#include <KSyntaxHighlighting/SyntaxHighlighter>
#include <Sonnet/Highlighter>
namespace KSyntaxHighlighting
{
class Format;
}
namespace TextCustomEditor
{
class PlainTextEditor;
class PlainTextSyntaxSpellCheckingHighlighterPrivate;
/**
* @brief The PlainTextSyntaxSpellCheckingHighlighter class
* @author Laurent Montel <montel@kde.org>
*/
class TEXTCUSTOMEDITOR_EXPORT PlainTextSyntaxSpellCheckingHighlighter : public Sonnet::Highlighter, public KSyntaxHighlighting::AbstractHighlighter
{
public:
explicit PlainTextSyntaxSpellCheckingHighlighter(PlainTextEditor *plainText, const QColor &misspelledColor = Qt::red);
~PlainTextSyntaxSpellCheckingHighlighter() override;
void toggleSpellHighlighting(bool on);
void setDefinition(const KSyntaxHighlighting::Definition &def) override;
/**
* Reimplemented to highlight quote blocks.
*/
void highlightBlock(const QString &text) override;
protected:
/**
* Reimplemented, the base version sets the text color to black, which
* is not what we want. We do nothing, the format is already reset by
* Qt.
* @param start the beginning of text
* @param count the amount of characters to set
*/
void unsetMisspelled(int start, int count) override;
/**
* Reimplemented to set the color of the misspelled word to a color
* defined by setQuoteColor().
*/
void setMisspelled(int start, int count) override;
void applyFormat(int offset, int length, const KSyntaxHighlighting::Format &format) override;
private:
std::unique_ptr<PlainTextSyntaxSpellCheckingHighlighterPrivate> const d;
};
}
|