summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cpptoolseditorsupport.cpp
diff options
context:
space:
mode:
authorErik Verbruggen <erik.verbruggen@digia.com>2013-08-09 11:43:20 +0200
committerNikolai Kosjar <nikolai.kosjar@digia.com>2013-08-19 13:01:07 +0200
commit073e5d6632c8f1a62b260d331aeebe5c35e58c18 (patch)
treed02b90373099ea4451f1cc9dc8767591c8cb59e0 /src/plugins/cpptools/cpptoolseditorsupport.cpp
parent480f7c09fc3a5cf0fa39a80c7d3e7377269e3224 (diff)
downloadqt-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.cpp19
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()) {