X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fctcphandler.cpp;h=a3bd3087d519bca62276c666995f907d82bc21ee;hp=26697f8206f53e20974b1dcba6c6d86de6aa217e;hb=16d697ab814aa594b71ac45269604aa65ed9d011;hpb=5c00beb706c7761d19f9a6b86751193056086b4a diff --git a/src/core/ctcphandler.cpp b/src/core/ctcphandler.cpp index 26697f82..a3bd3087 100644 --- a/src/core/ctcphandler.cpp +++ b/src/core/ctcphandler.cpp @@ -19,6 +19,7 @@ ***************************************************************************/ #include "ctcphandler.h" +#include "global.h" #include "util.h" #include "message.h" @@ -81,17 +82,21 @@ QString CtcpHandler::XdelimDequote(QString message) { return dequotedMessage; } -QStringList CtcpHandler::parse(CtcpType ctcptype, QString prefix, QString target, QString message) { - QStringList messages; +void CtcpHandler::parse(Message::Type messageType, QString prefix, QString target, QString message) { QString ctcp; //lowlevel message dequote QString dequotedMessage = dequote(message); - + + CtcpType ctcptype = (messageType == Message::Notice) + ? CtcpReply + : CtcpQuery; + // extract tagged / extended data while(dequotedMessage.contains(XDELIM)) { - if(dequotedMessage.indexOf(XDELIM) > 0) - messages << dequotedMessage.section(XDELIM,0,0); + if(dequotedMessage.indexOf(XDELIM) > 0) + emit displayMsg(messageType, target, dequotedMessage.section(XDELIM,0,0), prefix); + // messages << dequotedMessage.section(XDELIM,0,0), prefix); ctcp = XdelimDequote(dequotedMessage.section(XDELIM,1,1)); dequotedMessage = dequotedMessage.section(XDELIM,2,2); @@ -101,10 +106,10 @@ QStringList CtcpHandler::parse(CtcpType ctcptype, QString prefix, QString target handle(ctcpcmd, Q_ARG(CtcpType, ctcptype), Q_ARG(QString, prefix), Q_ARG(QString, target), Q_ARG(QString, ctcpparam)); } - if(!dequotedMessage.isEmpty()) { - messages << dequotedMessage; - } - return messages; + + if(!dequotedMessage.isEmpty()) + emit displayMsg(messageType, target, dequotedMessage, prefix); + } QString CtcpHandler::pack(QString ctcpTag, QString message) { @@ -148,7 +153,8 @@ void CtcpHandler::handleVersion(CtcpType ctcptype, QString prefix, QString targe Q_UNUSED(target) if(ctcptype == CtcpQuery) { // FIXME use real Info about quassel :) - reply(nickFromMask(prefix), "VERSION", QString("Quassel IRC (Pre-Release) - http://www.quassel-irc.org")); + reply(nickFromMask(prefix), "VERSION", QString("Quassel IRC (v%1 build >= %2) -- http://www.quassel-irc.org") + .arg(Global::quasselVersion).arg(Global::quasselBuild)); emit displayMsg(Message::Server, "", tr("Received CTCP VERSION request by %1").arg(prefix)); } else { // display Version answer