X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientuserinputhandler.cpp;h=704e835eeeab0f0c7370df89a9389f417e6fbdbd;hp=610a70210c7dff290d2bda57205c95fdb2401437;hb=02b4f33429788d35500454bfb5a8a9ab0a2a2b49;hpb=ab16c77fe03b73a863d9b52b11919bcbac903f58 diff --git a/src/client/clientuserinputhandler.cpp b/src/client/clientuserinputhandler.cpp index 610a7021..704e835e 100644 --- a/src/client/clientuserinputhandler.cpp +++ b/src/client/clientuserinputhandler.cpp @@ -20,6 +20,7 @@ #include +#include "buffermodel.h" #include "client.h" #include "clientaliasmanager.h" #include "clientuserinputhandler.h" @@ -59,10 +60,24 @@ void ClientUserInputHandler::handleUserInput(const BufferInfo &bufferInfo, const for(int i = 0; i < clist.count(); i++) { QString cmd = clist.at(i).second.section(' ', 0, 0).remove(0, 1).toUpper(); + QString args = clist.at(i).second.section(' ', 1); if(cmd == "EXEC") - handleExec(clist.at(i).first, clist.at(i).second.section(' ', 1)); - else + handleExec(clist.at(i).first, args); + else { + if(cmd == "JOIN" || cmd == "QUERY") { + if(args.section(' ', 0, 0).isEmpty()) { + continue; + } + BufferId newBufId = Client::networkModel()->bufferId(bufferInfo.networkId(), args.section(' ', 0, 0)); + if(!newBufId.isValid()) { + Client::bufferModel()->switchToBufferAfterCreation(bufferInfo.networkId(), args.section(' ', 0, 0)); + } + else { + Client::bufferModel()->switchToBuffer(newBufId); + } + } emit sendInput(clist.at(i).first, clist.at(i).second); + } } }