X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclientuserinputhandler.cpp;h=610a70210c7dff290d2bda57205c95fdb2401437;hp=049b9d3d5de057a099a41d79260d8546e960c464;hb=b64a1e62e2168dc21e350fccc6c42b0d0d5e2a35;hpb=6d32c3e6a04a358789c469948d044715d6fb5aed diff --git a/src/client/clientuserinputhandler.cpp b/src/client/clientuserinputhandler.cpp index 049b9d3d..610a7021 100644 --- a/src/client/clientuserinputhandler.cpp +++ b/src/client/clientuserinputhandler.cpp @@ -24,6 +24,7 @@ #include "clientaliasmanager.h" #include "clientuserinputhandler.h" #include "clientsettings.h" +#include "execwrapper.h" #include "ircuser.h" #include "network.h" @@ -54,8 +55,18 @@ void ClientUserInputHandler::handleUserInput(const BufferInfo &bufferInfo, const } } - AliasManager::CommandList clist = _aliasManager.processInput(bufferInfo, msg); + AliasManager::CommandList clist = Client::aliasManager()->processInput(bufferInfo, msg); - for(int i = 0; i < clist.count(); i++) - emit sendInput(clist.at(i).first, clist.at(i).second); + for(int i = 0; i < clist.count(); i++) { + QString cmd = clist.at(i).second.section(' ', 0, 0).remove(0, 1).toUpper(); + if(cmd == "EXEC") + handleExec(clist.at(i).first, clist.at(i).second.section(' ', 1)); + else + emit sendInput(clist.at(i).first, clist.at(i).second); + } +} + +void ClientUserInputHandler::handleExec(const BufferInfo &bufferInfo, const QString &execString) { + ExecWrapper *exec = new ExecWrapper(this); // gets suicidal when it's done + exec->start(bufferInfo, execString); }