forked from qt-creator/qt-creator
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:
@@ -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>
|
||||||
|
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user