diff options
author | Erik Verbruggen <erik.verbruggen@digia.com> | 2013-08-09 11:43:20 +0200 |
---|---|---|
committer | Nikolai Kosjar <nikolai.kosjar@digia.com> | 2013-08-19 13:01:07 +0200 |
commit | 073e5d6632c8f1a62b260d331aeebe5c35e58c18 (patch) | |
tree | d02b90373099ea4451f1cc9dc8767591c8cb59e0 /src/plugins/cpptools/cpptoolseditorsupport.cpp | |
parent | 480f7c09fc3a5cf0fa39a80c7d3e7377269e3224 (diff) | |
download | qt-creator-073e5d6632c8f1a62b260d331aeebe5c35e58c18.tar.gz |
C++: optionally let the highlighter handle ifdefed-out blocks.
Change-Id: I38cc0e55348cac0245d2ab8f3e39c68de76e3e6d
Reviewed-by: Nikolai Kosjar <nikolai.kosjar@digia.com>
Diffstat (limited to 'src/plugins/cpptools/cpptoolseditorsupport.cpp')
-rw-r--r-- | src/plugins/cpptools/cpptoolseditorsupport.cpp | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/src/plugins/cpptools/cpptoolseditorsupport.cpp b/src/plugins/cpptools/cpptoolseditorsupport.cpp index 4bec4d9058..e99338bc4a 100644 --- a/src/plugins/cpptools/cpptoolseditorsupport.cpp +++ b/src/plugins/cpptools/cpptoolseditorsupport.cpp @@ -192,6 +192,13 @@ void CppEditorSupport::setExtraDiagnostics(const QString &key, emit diagnosticsChanged(); } +void CppEditorSupport::setIfdefedOutBlocks(const QList<BlockRange> &ifdefedOutBlocks) +{ + m_editorUpdates.ifdefedOutBlocks = ifdefedOutBlocks; + + emit diagnosticsChanged(); +} + bool CppEditorSupport::initialized() { return m_initialized; @@ -262,11 +269,13 @@ void CppEditorSupport::onDocumentUpdated(Document::Ptr doc) return; // outdated content, wait for a new document to be parsed // Update the ifdeffed-out blocks: - QList<Document::Block> skippedBlocks = doc->skippedBlocks(); - m_editorUpdates.ifdefedOutBlocks.clear(); - m_editorUpdates.ifdefedOutBlocks.reserve(skippedBlocks.size()); - foreach (const Document::Block &block, skippedBlocks) { - m_editorUpdates.ifdefedOutBlocks.append(BlockRange(block.begin(), block.end())); + if (m_highlightingSupport && !m_highlightingSupport->hightlighterHandlesIfdefedOutBlocks()) { + QList<Document::Block> skippedBlocks = doc->skippedBlocks(); + QList<BlockRange> ifdefedOutBlocks; + ifdefedOutBlocks.reserve(skippedBlocks.size()); + foreach (const Document::Block &block, skippedBlocks) + ifdefedOutBlocks.append(BlockRange(block.begin(), block.end())); + setIfdefedOutBlocks(ifdefedOutBlocks); } if (m_highlightingSupport && !m_highlightingSupport->hightlighterHandlesDiagnostics()) { |