forked from qt-creator/qt-creator
		
	CppTools: De-noise SemanticHighlighter
Change-Id: Id4655b0d81104468f6fe799744e49e505d3b8748 Reviewed-by: Nikolai Kosjar <nikolai.kosjar@theqtcompany.com>
This commit is contained in:
		
				
					committed by
					
						
						Orgad Shaneh
					
				
			
			
				
	
			
			
			
						parent
						
							47295d267f
						
					
				
				
					commit
					4191d9ddcd
				
			@@ -35,14 +35,16 @@
 | 
			
		||||
#include <QLoggingCategory>
 | 
			
		||||
#include <QTextDocument>
 | 
			
		||||
 | 
			
		||||
using TextEditor::SemanticHighlighter::incrementalApplyExtraAdditionalFormats;
 | 
			
		||||
using TextEditor::SemanticHighlighter::clearExtraAdditionalFormatsUntilEnd;
 | 
			
		||||
using namespace TextEditor;
 | 
			
		||||
 | 
			
		||||
using SemanticHighlighter::incrementalApplyExtraAdditionalFormats;
 | 
			
		||||
using SemanticHighlighter::clearExtraAdditionalFormatsUntilEnd;
 | 
			
		||||
 | 
			
		||||
static Q_LOGGING_CATEGORY(log, "qtc.cpptools.semantichighlighter")
 | 
			
		||||
 | 
			
		||||
namespace CppTools {
 | 
			
		||||
 | 
			
		||||
SemanticHighlighter::SemanticHighlighter(TextEditor::TextDocument *baseTextDocument)
 | 
			
		||||
SemanticHighlighter::SemanticHighlighter(TextDocument *baseTextDocument)
 | 
			
		||||
    : QObject(baseTextDocument)
 | 
			
		||||
    , m_baseTextDocument(baseTextDocument)
 | 
			
		||||
    , m_revision(0)
 | 
			
		||||
@@ -75,7 +77,7 @@ void SemanticHighlighter::run()
 | 
			
		||||
        disconnectWatcher();
 | 
			
		||||
        m_watcher->cancel();
 | 
			
		||||
    }
 | 
			
		||||
    m_watcher.reset(new QFutureWatcher<TextEditor::HighlightingResult>);
 | 
			
		||||
    m_watcher.reset(new QFutureWatcher<HighlightingResult>);
 | 
			
		||||
    connectWatcher();
 | 
			
		||||
 | 
			
		||||
    m_revision = documentRevision();
 | 
			
		||||
@@ -91,7 +93,7 @@ void SemanticHighlighter::onHighlighterResultAvailable(int from, int to)
 | 
			
		||||
 | 
			
		||||
    qCDebug(log) << "onHighlighterResultAvailable()" << from << to;
 | 
			
		||||
 | 
			
		||||
    TextEditor::SyntaxHighlighter *highlighter = m_baseTextDocument->syntaxHighlighter();
 | 
			
		||||
    SyntaxHighlighter *highlighter = m_baseTextDocument->syntaxHighlighter();
 | 
			
		||||
    QTC_ASSERT(highlighter, return);
 | 
			
		||||
    incrementalApplyExtraAdditionalFormats(highlighter, m_watcher->future(), from, to, m_formatMap);
 | 
			
		||||
}
 | 
			
		||||
@@ -100,7 +102,7 @@ void SemanticHighlighter::onHighlighterFinished()
 | 
			
		||||
{
 | 
			
		||||
    QTC_ASSERT(m_watcher, return);
 | 
			
		||||
    if (!m_watcher->isCanceled() && documentRevision() == m_revision) {
 | 
			
		||||
        TextEditor::SyntaxHighlighter *highlighter = m_baseTextDocument->syntaxHighlighter();
 | 
			
		||||
        SyntaxHighlighter *highlighter = m_baseTextDocument->syntaxHighlighter();
 | 
			
		||||
        QTC_CHECK(highlighter);
 | 
			
		||||
        if (highlighter) {
 | 
			
		||||
            qCDebug(log) << "onHighlighterFinished() - clearing formats";
 | 
			
		||||
@@ -112,7 +114,7 @@ void SemanticHighlighter::onHighlighterFinished()
 | 
			
		||||
 | 
			
		||||
void SemanticHighlighter::connectWatcher()
 | 
			
		||||
{
 | 
			
		||||
    typedef QFutureWatcher<TextEditor::HighlightingResult> Watcher;
 | 
			
		||||
    typedef QFutureWatcher<HighlightingResult> Watcher;
 | 
			
		||||
    connect(m_watcher.data(), &Watcher::resultsReadyAt,
 | 
			
		||||
            this, &SemanticHighlighter::onHighlighterResultAvailable);
 | 
			
		||||
    connect(m_watcher.data(), &Watcher::finished,
 | 
			
		||||
@@ -121,7 +123,7 @@ void SemanticHighlighter::connectWatcher()
 | 
			
		||||
 | 
			
		||||
void SemanticHighlighter::disconnectWatcher()
 | 
			
		||||
{
 | 
			
		||||
    typedef QFutureWatcher<TextEditor::HighlightingResult> Watcher;
 | 
			
		||||
    typedef QFutureWatcher<HighlightingResult> Watcher;
 | 
			
		||||
    disconnect(m_watcher.data(), &Watcher::resultsReadyAt,
 | 
			
		||||
               this, &SemanticHighlighter::onHighlighterResultAvailable);
 | 
			
		||||
    disconnect(m_watcher.data(), &Watcher::finished,
 | 
			
		||||
@@ -137,18 +139,18 @@ void SemanticHighlighter::updateFormatMapFromFontSettings()
 | 
			
		||||
{
 | 
			
		||||
    QTC_ASSERT(m_baseTextDocument, return);
 | 
			
		||||
 | 
			
		||||
    const TextEditor::FontSettings &fs = m_baseTextDocument->fontSettings();
 | 
			
		||||
    const FontSettings &fs = m_baseTextDocument->fontSettings();
 | 
			
		||||
 | 
			
		||||
    m_formatMap[TypeUse] = fs.toTextCharFormat(TextEditor::C_TYPE);
 | 
			
		||||
    m_formatMap[LocalUse] = fs.toTextCharFormat(TextEditor::C_LOCAL);
 | 
			
		||||
    m_formatMap[FieldUse] = fs.toTextCharFormat(TextEditor::C_FIELD);
 | 
			
		||||
    m_formatMap[EnumerationUse] = fs.toTextCharFormat(TextEditor::C_ENUMERATION);
 | 
			
		||||
    m_formatMap[VirtualMethodUse] = fs.toTextCharFormat(TextEditor::C_VIRTUAL_METHOD);
 | 
			
		||||
    m_formatMap[LabelUse] = fs.toTextCharFormat(TextEditor::C_LABEL);
 | 
			
		||||
    m_formatMap[MacroUse] = fs.toTextCharFormat(TextEditor::C_PREPROCESSOR);
 | 
			
		||||
    m_formatMap[FunctionUse] = fs.toTextCharFormat(TextEditor::C_FUNCTION);
 | 
			
		||||
    m_formatMap[PseudoKeywordUse] = fs.toTextCharFormat(TextEditor::C_KEYWORD);
 | 
			
		||||
    m_formatMap[StringUse] = fs.toTextCharFormat(TextEditor::C_STRING);
 | 
			
		||||
    m_formatMap[TypeUse] = fs.toTextCharFormat(C_TYPE);
 | 
			
		||||
    m_formatMap[LocalUse] = fs.toTextCharFormat(C_LOCAL);
 | 
			
		||||
    m_formatMap[FieldUse] = fs.toTextCharFormat(C_FIELD);
 | 
			
		||||
    m_formatMap[EnumerationUse] = fs.toTextCharFormat(C_ENUMERATION);
 | 
			
		||||
    m_formatMap[VirtualMethodUse] = fs.toTextCharFormat(C_VIRTUAL_METHOD);
 | 
			
		||||
    m_formatMap[LabelUse] = fs.toTextCharFormat(C_LABEL);
 | 
			
		||||
    m_formatMap[MacroUse] = fs.toTextCharFormat(C_PREPROCESSOR);
 | 
			
		||||
    m_formatMap[FunctionUse] = fs.toTextCharFormat(C_FUNCTION);
 | 
			
		||||
    m_formatMap[PseudoKeywordUse] = fs.toTextCharFormat(C_KEYWORD);
 | 
			
		||||
    m_formatMap[StringUse] = fs.toTextCharFormat(C_STRING);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace CppTools
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user