X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Ftabcompleter.cpp;h=8c29e8ab6f8950c4ec6323afaaff0ee554adf884;hp=2b130970c89fae62464c02abca1fd906fc134b36;hb=c030e0d5e910fe8af376e5462c9e58d45fd59e40;hpb=5df99c1ab83baf3a6caef7e49177f84bd48d127e diff --git a/src/uisupport/tabcompleter.cpp b/src/uisupport/tabcompleter.cpp index 2b130970..8c29e8ab 100644 --- a/src/uisupport/tabcompleter.cpp +++ b/src/uisupport/tabcompleter.cpp @@ -1,11 +1,11 @@ /*************************************************************************** - * Copyright (C) 2005/06 by The Quassel Team * + * Copyright (C) 2005/06 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * + * (at your option) version 3. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * @@ -20,27 +20,57 @@ #include "tabcompleter.h" -TabCompleter::TabCompleter(QLineEdit *l, QObject *parent) : QObject(parent) { - lineEdit = l; - enabled = false; - startOfLineSuffix = QString(": "); // TODO make start of line suffix configurable -} +#include "inputline.h" +#include "client.h" +#include "buffermodel.h" +#include "networkmodel.h" +#include "network.h" +#include "ircchannel.h" +#include "ircuser.h" -void TabCompleter::updateNickList(QStringList l) { - nickList = l; -} - -void TabCompleter::updateChannelList(QStringList l) { - channelList = l; +TabCompleter::TabCompleter(InputLine *inputLine_) + : QObject(inputLine_), + inputLine(inputLine_), + enabled(false), + nickSuffix(": ") +{ + inputLine->installEventFilter(this); } void TabCompleter::buildCompletionList() { + completionList.clear(); + nextCompletion = completionList.begin(); // this is the first time tab is pressed -> build up the completion list and it's iterator - QString tabAbbrev = lineEdit->text().left(lineEdit->cursorPosition()).section(' ',-1,-1); + QModelIndex currentIndex = Client::bufferModel()->currentIndex(); + if(!currentIndex.data(NetworkModel::BufferIdRole).isValid()) + return; + + NetworkId networkId = currentIndex.data(NetworkModel::NetworkIdRole).value(); + QString channelName = currentIndex.sibling(currentIndex.row(), 0).data().toString(); + + const Network *network = Client::network(networkId); + if(!network) + return; + + IrcChannel *channel = network->ircChannel(channelName); + if(!channel) + return; + + // FIXME commented for debugging + /* + disconnect(this, SLOT(ircUserJoinedOrParted(IrcUser *))); + connect(channel, SIGNAL(ircUserJoined(IrcUser *)), + this, SLOT(ircUserJoinedOrParted(IrcUser *))); + connect(channel, SIGNAL(ircUserParted(IrcUser *)), + this, SLOT(ircUserJoinedOrParted(IrcUser *))); + */ + + completionList.clear(); + QString tabAbbrev = inputLine->text().left(inputLine->cursorPosition()).section(' ',-1,-1); completionList.clear(); - foreach(QString nick, nickList) { - if(nick.toLower().startsWith(tabAbbrev.toLower())) { - completionList << nick; + foreach(IrcUser *ircUser, channel->ircUsers()) { + if(ircUser->nick().toLower().startsWith(tabAbbrev.toLower())) { + completionList << ircUser->nick(); } } completionList.sort(); @@ -48,29 +78,34 @@ void TabCompleter::buildCompletionList() { lastCompletionLength = tabAbbrev.length(); } +void TabCompleter::ircUserJoinedOrParted(IrcUser *ircUser) { + Q_UNUSED(ircUser) + buildCompletionList(); +} + void TabCompleter::complete() { - if (! enabled) { + if(!enabled) { buildCompletionList(); - enabled = true; + enabled = true; } if (nextCompletion != completionList.end()) { // clear previous completion for (int i = 0; i < lastCompletionLength; i++) { - lineEdit->backspace(); + inputLine->backspace(); } // insert completion - lineEdit->insert(*nextCompletion); + inputLine->insert(*nextCompletion); // remember charcount to delete next time and advance to next completion lastCompletionLength = nextCompletion->length(); nextCompletion++; // we're completing the first word of the line - if(lineEdit->text().length() == lastCompletionLength) { - lineEdit->insert(startOfLineSuffix); - lastCompletionLength += 2; + if(inputLine->text().length() == lastCompletionLength) { + inputLine->insert(nickSuffix); + lastCompletionLength += nickSuffix.length(); } // we're at the end of the list -> start over again @@ -80,7 +115,22 @@ void TabCompleter::complete() { } -void TabCompleter::disable() { +void TabCompleter::reset() { enabled = false; } +bool TabCompleter::eventFilter(QObject *obj, QEvent *event) { + if(obj != inputLine || event->type() != QEvent::KeyPress) + return QObject::eventFilter(obj, event); + + QKeyEvent *keyEvent = static_cast(event); + + if(keyEvent->key() == Qt::Key_Tab) { + complete(); + return true; + } else { + reset(); + return false; + } +} +