summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppmodelmanager.h
diff options
context:
space:
mode:
authorErik Verbruggen <erik.verbruggen@digia.com>2013-09-04 18:15:08 +0200
committerErik Verbruggen <erik.verbruggen@digia.com>2013-09-10 11:45:38 +0200
commit3a5d3a2fe93f2d565713790cee6c981169a888c2 (patch)
tree7346ff90cab2aabb0052380a55d908f182c728ac /src/plugins/cpptools/cppmodelmanager.h
parent0c6b64484cebc5e28ec220cc1ca2b19de9f017bd (diff)
downloadqt-creator-3a5d3a2fe93f2d565713790cee6c981169a888c2.tar.gz
C++: unify highlighting/code-completion support "factories".
Both semantic highlighting and code-completion go hand-in-hand, so now the ModelManagerSupport class acts as a "factory" for the model manager. Depending on the mime-type of the document in the editor, the model manager will return the appropriate highlighter or code-completion engine. If none is registered, the built-in fall-back is used. Change-Id: I3e5dbb0e3b58e077dd5eda9aecb2ce5d448ac0b8 Reviewed-by: Nikolai Kosjar <nikolai.kosjar@digia.com>
Diffstat (limited to 'src/plugins/cpptools/cppmodelmanager.h')
-rw-r--r--src/plugins/cpptools/cppmodelmanager.h16
1 files changed, 6 insertions, 10 deletions
diff --git a/src/plugins/cpptools/cppmodelmanager.h b/src/plugins/cpptools/cppmodelmanager.h
index 8f6877ff60..cf25c9d2b5 100644
--- a/src/plugins/cpptools/cppmodelmanager.h
+++ b/src/plugins/cpptools/cppmodelmanager.h
@@ -105,11 +105,10 @@ public:
void finishedRefreshingSourceFiles(const QStringList &files);
+ virtual void addModelManagerSupport(ModelManagerSupport *codeModelSupport);
+ virtual ModelManagerSupport *modelManagerSupportForMimeType(const QString &mimeType) const;
virtual CppCompletionAssistProvider *completionAssistProvider(Core::IEditor *editor) const;
- virtual void setCppCompletionAssistProvider(CppCompletionAssistProvider *completionAssistProvider);
-
virtual CppHighlightingSupport *highlightingSupport(Core::IEditor *editor) const;
- virtual void setHighlightingSupportFactory(CppHighlightingSupportFactory *highlightingFactory);
virtual void setIndexingSupport(CppIndexingSupport *indexingSupport);
virtual CppIndexingSupport *indexingSupport();
@@ -202,13 +201,10 @@ private:
QMap<TextEditor::BaseTextEditor *, CppEditorSupport *> m_cppEditorSupports;
QSet<AbstractEditorSupport *> m_extraEditorSupports;
- // Completion
- CppCompletionAssistProvider *m_completionAssistProvider;
- QScopedPointer<CppCompletionAssistProvider> m_completionFallback;
-
- // Highlighting
- CppHighlightingSupportFactory *m_highlightingFactory;
- CppHighlightingSupportFactory *m_highlightingFallback;
+ // Completion & highlighting
+ QList<ModelManagerSupport *> m_codeModelSupporters;
+ QScopedPointer<ModelManagerSupport> m_modelManagerSupportFallback;
+ QHash<QString, ModelManagerSupport *> m_mimeTypeToCodeModelSupport;
// Indexing
CppIndexingSupport *m_indexingSupporter;