Keywordscompletion: Code cosmetics

Change-Id: I2f25894d5043ea1f5ab50ab6b48ce6b02ab4b987
Reviewed-by: Tobias Hunger <tobias.hunger@qt.io>
Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
Tobias Hunger
2016-08-23 11:13:22 +02:00
parent 454ad164fd
commit 5097acebf3
4 changed files with 36 additions and 48 deletions

View File

@@ -26,6 +26,7 @@
#include "javacompletionassistprovider.h" #include "javacompletionassistprovider.h"
#include "androidconstants.h" #include "androidconstants.h"
#include <texteditor/codeassist/assistinterface.h>
#include <texteditor/codeassist/keywordscompletionassist.h> #include <texteditor/codeassist/keywordscompletionassist.h>
#include <coreplugin/id.h> #include <coreplugin/id.h>

View File

@@ -26,6 +26,7 @@
#include "profilecompletionassist.h" #include "profilecompletionassist.h"
#include "qmakeprojectmanagerconstants.h" #include "qmakeprojectmanagerconstants.h"
#include <texteditor/codeassist/assistinterface.h>
#include <texteditor/codeassist/keywordscompletionassist.h> #include <texteditor/codeassist/keywordscompletionassist.h>
#include <coreplugin/id.h> #include <coreplugin/id.h>

View File

@@ -33,20 +33,16 @@
#include <texteditor/texteditorsettings.h> #include <texteditor/texteditorsettings.h>
#include <texteditor/texteditor.h> #include <texteditor/texteditor.h>
#include <algorithm> #include <utils/algorithm.h>
namespace TextEditor { namespace TextEditor {
// -------------------------- // --------------------------
// Keywords // Keywords
// -------------------------- // --------------------------
Keywords::Keywords()
{
}
// Note: variables and functions must be sorted // Note: variables and functions must be sorted
Keywords::Keywords(const QStringList &variabels, const QStringList &functions, const QMap<QString, QStringList> &functionArgs) Keywords::Keywords(const QStringList &variables, const QStringList &functions, const QMap<QString, QStringList> &functionArgs)
: m_variables(variabels), m_functions(functions), m_functionArgs(functionArgs) : m_variables(variables), m_functions(functions), m_functionArgs(functionArgs)
{ {
} }
@@ -85,9 +81,6 @@ KeywordsAssistProposalItem::KeywordsAssistProposalItem(bool isFunction)
{ {
} }
KeywordsAssistProposalItem::~KeywordsAssistProposalItem() Q_DECL_NOEXCEPT
{}
bool KeywordsAssistProposalItem::prematurelyApplies(const QChar &c) const bool KeywordsAssistProposalItem::prematurelyApplies(const QChar &c) const
{ {
// only '(' in case of a function // only '(' in case of a function
@@ -143,9 +136,6 @@ KeywordsFunctionHintModel::KeywordsFunctionHintModel(const QStringList &function
: m_functionSymbols(functionSymbols) : m_functionSymbols(functionSymbols)
{} {}
KeywordsFunctionHintModel::~KeywordsFunctionHintModel()
{}
void KeywordsFunctionHintModel::reset() void KeywordsFunctionHintModel::reset()
{} {}
@@ -169,25 +159,21 @@ int KeywordsFunctionHintModel::activeArgument(const QString &prefix) const
// KeywordsCompletionAssistProcessor // KeywordsCompletionAssistProcessor
// --------------------------------- // ---------------------------------
KeywordsCompletionAssistProcessor::KeywordsCompletionAssistProcessor(Keywords keywords) KeywordsCompletionAssistProcessor::KeywordsCompletionAssistProcessor(Keywords keywords)
: m_startPosition(-1) : m_snippetCollector(QString(), QIcon(":/texteditor/images/snippet.png"))
, m_snippetCollector(QString(), QIcon(":/texteditor/images/snippet.png"))
, m_variableIcon(QLatin1String(":/codemodel/images/keyword.png")) , m_variableIcon(QLatin1String(":/codemodel/images/keyword.png"))
, m_functionIcon(QLatin1String(":/codemodel/images/member.png")) , m_functionIcon(QLatin1String(":/codemodel/images/member.png"))
, m_keywords(keywords) , m_keywords(keywords)
{} {}
KeywordsCompletionAssistProcessor::~KeywordsCompletionAssistProcessor()
{}
IAssistProposal *KeywordsCompletionAssistProcessor::perform(const AssistInterface *interface) IAssistProposal *KeywordsCompletionAssistProcessor::perform(const AssistInterface *interface)
{ {
m_interface.reset(interface); m_interface.reset(interface);
if (isInComment()) if (isInComment())
return 0; return nullptr;
if (interface->reason() == IdleEditor && !acceptsIdleEditor()) if (interface->reason() == IdleEditor && !acceptsIdleEditor())
return 0; return nullptr;
if (m_startPosition == -1) if (m_startPosition == -1)
m_startPosition = findStartOfName(); m_startPosition = findStartOfName();
@@ -196,10 +182,8 @@ IAssistProposal *KeywordsCompletionAssistProcessor::perform(const AssistInterfac
if (m_keywords.isFunction(m_word) if (m_keywords.isFunction(m_word)
&& m_interface->characterAt(nextCharPos) == QLatin1Char('(')) { && m_interface->characterAt(nextCharPos) == QLatin1Char('(')) {
QStringList functionSymbols = m_keywords.argsForFunction(m_word); QStringList functionSymbols = m_keywords.argsForFunction(m_word);
IFunctionHintProposalModel *model = IFunctionHintProposalModel *model = new KeywordsFunctionHintModel(functionSymbols);
new KeywordsFunctionHintModel(functionSymbols); return new FunctionHintProposal(m_startPosition, model);
IAssistProposal *proposal = new FunctionHintProposal(m_startPosition, model);
return proposal;
} else { } else {
QList<AssistProposalItemInterface *> items = m_snippetCollector.collect(); QList<AssistProposalItemInterface *> items = m_snippetCollector.collect();
addWordsToProposalList(&items, m_keywords.variables(), m_variableIcon); addWordsToProposalList(&items, m_keywords.variables(), m_variableIcon);
@@ -226,7 +210,7 @@ void KeywordsCompletionAssistProcessor::setKeywords(Keywords keywords)
bool KeywordsCompletionAssistProcessor::acceptsIdleEditor() bool KeywordsCompletionAssistProcessor::acceptsIdleEditor()
{ {
const int pos = m_interface->position(); const int pos = m_interface->position();
QChar characterUnderCursor = m_interface->characterAt(pos); const QChar characterUnderCursor = m_interface->characterAt(pos);
if (!characterUnderCursor.isLetterOrNumber()) { if (!characterUnderCursor.isLetterOrNumber()) {
m_startPosition = findStartOfName(); m_startPosition = findStartOfName();
if (pos - m_startPosition >= 3 && !isInComment()) if (pos - m_startPosition >= 3 && !isInComment())
@@ -248,7 +232,7 @@ int KeywordsCompletionAssistProcessor::findStartOfName(int pos)
chr = m_interface->characterAt(--pos); chr = m_interface->characterAt(--pos);
} while (chr.isLetterOrNumber() || chr == QLatin1Char('_')); } while (chr.isLetterOrNumber() || chr == QLatin1Char('_'));
int start = ++pos; const int start = ++pos;
m_word.clear(); m_word.clear();
do { do {
m_word += m_interface->characterAt(pos); m_word += m_interface->characterAt(pos);
@@ -265,22 +249,21 @@ bool KeywordsCompletionAssistProcessor::isInComment() const
tc.setPosition(m_interface->position()); tc.setPosition(m_interface->position());
tc.movePosition(QTextCursor::StartOfLine, QTextCursor::KeepAnchor); tc.movePosition(QTextCursor::StartOfLine, QTextCursor::KeepAnchor);
const QString &lineBeginning = tc.selectedText(); const QString &lineBeginning = tc.selectedText();
if (lineBeginning.contains(startOfCommentChar())) return lineBeginning.contains(startOfCommentChar());
return true;
return false;
} }
void KeywordsCompletionAssistProcessor::addWordsToProposalList(QList<AssistProposalItemInterface *> *items, const QStringList &words, const QIcon &icon) void KeywordsCompletionAssistProcessor::addWordsToProposalList(QList<AssistProposalItemInterface *> *items,
const QStringList &words, const QIcon &icon)
{ {
if (!items) if (!items)
return; return;
for (int i = 0; i < words.count(); ++i) { *items = Utils::transform(words, [this, &icon](const QString &word) -> AssistProposalItemInterface * {
AssistProposalItem *item = new KeywordsAssistProposalItem(m_keywords.isFunction(words.at(i))); AssistProposalItem *item = new KeywordsAssistProposalItem(m_keywords.isFunction(word));
item->setText(words.at(i)); item->setText(word);
item->setIcon(icon); item->setIcon(icon);
items->append(item); return item;
} });
} }
} // namespace TextEditor } // namespace TextEditor

View File

@@ -32,11 +32,14 @@
namespace TextEditor { namespace TextEditor {
class AssistInterface;
class TEXTEDITOR_EXPORT Keywords class TEXTEDITOR_EXPORT Keywords
{ {
public: public:
Keywords(); Keywords() = default;
Keywords(const QStringList &variabels, const QStringList &functions, const QMap<QString, QStringList> &functionArgs); Keywords(const QStringList &variables, const QStringList &functions,
const QMap<QString, QStringList> &functionArgs);
bool isVariable(const QString &word) const; bool isVariable(const QString &word) const;
bool isFunction(const QString &word) const; bool isFunction(const QString &word) const;
@@ -54,10 +57,9 @@ class TEXTEDITOR_EXPORT KeywordsAssistProposalItem : public AssistProposalItem
{ {
public: public:
KeywordsAssistProposalItem(bool isFunction); KeywordsAssistProposalItem(bool isFunction);
~KeywordsAssistProposalItem() Q_DECL_NOEXCEPT;
bool prematurelyApplies(const QChar &c) const override; bool prematurelyApplies(const QChar &c) const final;
void applyContextualContent(TextDocumentManipulatorInterface &manipulator, int basePosition) const override; void applyContextualContent(TextDocumentManipulatorInterface &manipulator, int basePosition) const final;
private: private:
bool m_isFunction; bool m_isFunction;
}; };
@@ -66,12 +68,12 @@ class TEXTEDITOR_EXPORT KeywordsFunctionHintModel : public IFunctionHintProposal
{ {
public: public:
KeywordsFunctionHintModel(const QStringList &functionSymbols); KeywordsFunctionHintModel(const QStringList &functionSymbols);
~KeywordsFunctionHintModel(); ~KeywordsFunctionHintModel() final = default;
void reset() override; void reset() final;
int size() const override; int size() const final;
QString text(int index) const override; QString text(int index) const final;
int activeArgument(const QString &prefix) const override; int activeArgument(const QString &prefix) const final;
private: private:
QStringList m_functionSymbols; QStringList m_functionSymbols;
@@ -81,7 +83,7 @@ class TEXTEDITOR_EXPORT KeywordsCompletionAssistProcessor : public IAssistProces
{ {
public: public:
KeywordsCompletionAssistProcessor(Keywords keywords); KeywordsCompletionAssistProcessor(Keywords keywords);
~KeywordsCompletionAssistProcessor(); ~KeywordsCompletionAssistProcessor() override = default;
IAssistProposal *perform(const AssistInterface *interface) override; IAssistProposal *perform(const AssistInterface *interface) override;
QChar startOfCommentChar() const; QChar startOfCommentChar() const;
@@ -95,9 +97,10 @@ private:
bool acceptsIdleEditor(); bool acceptsIdleEditor();
int findStartOfName(int pos = -1); int findStartOfName(int pos = -1);
bool isInComment() const; bool isInComment() const;
void addWordsToProposalList(QList<AssistProposalItemInterface *> *items, const QStringList &words, const QIcon &icon); void addWordsToProposalList(QList<AssistProposalItemInterface *> *items,
const QStringList &words, const QIcon &icon);
int m_startPosition; int m_startPosition = -1;
TextEditor::SnippetAssistCollector m_snippetCollector; TextEditor::SnippetAssistCollector m_snippetCollector;
QString m_word; QString m_word;
QScopedPointer<const AssistInterface> m_interface; QScopedPointer<const AssistInterface> m_interface;