diff --git a/src/plugins/cpptools/cppcodecompletion.cpp b/src/plugins/cpptools/cppcodecompletion.cpp index beecf56a8b5..88ca3b75587 100644 --- a/src/plugins/cpptools/cppcodecompletion.cpp +++ b/src/plugins/cpptools/cppcodecompletion.cpp @@ -69,7 +69,6 @@ #include #include #include -#include #include #include #include @@ -653,22 +652,11 @@ bool CppCodeCompletion::triggersCompletion(TextEditor::ITextEditable *editor) return false; } -static QList sortCompletionItems(QList items) -{ - qStableSort(items.begin(), items.end(), CppCodeCompletion::completionItemLessThan); - return items; -} - int CppCodeCompletion::startCompletion(TextEditor::ITextEditable *editor) { int index = startCompletionHelper(editor); - if (index != -1) { - m_sortedCompletions = QtConcurrent::run(sortCompletionItems, m_completions); - - if (m_completions.size() < 1000) - m_completions = m_sortedCompletions; - } - + if (index != -1) + qStableSort(m_completions.begin(), m_completions.end(), completionItemLessThan); return index; } @@ -1580,14 +1568,8 @@ void CppCodeCompletion::completions(QList *completio const QString key = m_editor->textAt(m_startPosition, length); - QList currentCompletion; - if (m_sortedCompletions.isFinished()) - currentCompletion = m_sortedCompletions; - else - currentCompletion = m_completions; - if (length == 0) - *completions = currentCompletion; + *completions = m_completions; else if (length > 0) { /* Close on the trailing slash for include completion, to enable the slash to * trigger a new completion list. */ @@ -1596,12 +1578,12 @@ void CppCodeCompletion::completions(QList *completio return; if (m_completionOperator != T_LPAREN) { - filter(currentCompletion, completions, key); + filter(m_completions, completions, key); } else if (m_completionOperator == T_LPAREN || m_completionOperator == T_SIGNAL || m_completionOperator == T_SLOT) { - foreach (const TextEditor::CompletionItem &item, currentCompletion) { + foreach (const TextEditor::CompletionItem &item, m_completions) { if (item.text.startsWith(key, Qt::CaseInsensitive)) { completions->append(item); } @@ -1760,7 +1742,6 @@ bool CppCodeCompletion::partiallyComplete(const QList #include -#include QT_BEGIN_NAMESPACE class QTextCursor; @@ -150,7 +149,6 @@ private: QPointer m_functionArgumentWidget; QList m_completions; - QFuture > m_sortedCompletions; }; } // namespace Internal diff --git a/src/plugins/texteditor/icompletioncollector.h b/src/plugins/texteditor/icompletioncollector.h index cb6d1a1c863..e78ad83b829 100644 --- a/src/plugins/texteditor/icompletioncollector.h +++ b/src/plugins/texteditor/icompletioncollector.h @@ -131,14 +131,13 @@ public: QList *filteredItems, const QString &key); - static bool completionItemLessThan(const CompletionItem &item, const CompletionItem &other); - public slots: void setCompletionSettings(const TextEditor::CompletionSettings &); protected: static bool compareChar(const QChar &item, const QChar &other); static bool lessThan(const QString &item, const QString &other); + static bool completionItemLessThan(const CompletionItem &item, const CompletionItem &other); private: Internal::ICompletionCollectorPrivate *m_d;