X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Ftabcompleter.cpp;h=cd82ee2b8d4f38e0fd87ce3ffdc69e871b0de6b1;hp=c68b69536407eb93047db69ba7f77a2c2d4bdd14;hb=599218b03a48c53299b6c539208508a25f855164;hpb=8bcd653df36521cd30aed7ddebf7faa9783a48f1 diff --git a/src/uisupport/tabcompleter.cpp b/src/uisupport/tabcompleter.cpp index c68b6953..cd82ee2b 100644 --- a/src/uisupport/tabcompleter.cpp +++ b/src/uisupport/tabcompleter.cpp @@ -29,6 +29,8 @@ #include "ircuser.h" #include "uisettings.h" +#include + TabCompleter::TabCompleter(InputLine *inputLine_) : QObject(inputLine_), inputLine(inputLine_), @@ -39,8 +41,10 @@ TabCompleter::TabCompleter(InputLine *inputLine_) } void TabCompleter::buildCompletionList() { - completionList.clear(); - nextCompletion = completionList.begin(); + // ensure a safe state in case we return early. + completionMap.clear(); + nextCompletion = completionMap.begin(); + // this is the first time tab is pressed -> build up the completion list and it's iterator QModelIndex currentIndex = Client::bufferModel()->currentIndex(); if(!currentIndex.data(NetworkModel::BufferIdRole).isValid()) @@ -66,16 +70,16 @@ void TabCompleter::buildCompletionList() { this, SLOT(ircUserJoinedOrParted(IrcUser *))); */ - completionList.clear(); QString tabAbbrev = inputLine->text().left(inputLine->cursorPosition()).section(' ',-1,-1); - completionList.clear(); + QRegExp regex(QString("^[^a-zA-Z]*").append(QRegExp::escape(tabAbbrev)), Qt::CaseInsensitive); + foreach(IrcUser *ircUser, channel->ircUsers()) { - if(ircUser->nick().toLower().startsWith(tabAbbrev.toLower())) { - completionList << ircUser->nick(); + if(regex.indexIn(ircUser->nick()) > -1) { + completionMap[ircUser->nick().toLower()] = ircUser->nick(); } } - completionList.sort(); - nextCompletion = completionList.begin(); + + nextCompletion = completionMap.begin(); lastCompletionLength = tabAbbrev.length(); } @@ -93,7 +97,7 @@ void TabCompleter::complete() { enabled = true; } - if (nextCompletion != completionList.end()) { + if (nextCompletion != completionMap.end()) { // clear previous completion for (int i = 0; i < lastCompletionLength; i++) { inputLine->backspace(); @@ -114,7 +118,10 @@ void TabCompleter::complete() { // we're at the end of the list -> start over again } else { - nextCompletion = completionList.begin(); + if(!completionMap.isEmpty()) { + nextCompletion = completionMap.begin(); + complete(); + } } }