X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fctcpparser.cpp;h=db285a68c43786498e2c98b0e9a2353a2139e44e;hb=0402f2f7f6fbd3895842f421f871744f6d03b156;hp=7517db6f4729756b13e7ac48639099b52103c044;hpb=fd92bfb1f093dcc6295ca9de2c34780d288b0fe2;p=quassel.git diff --git a/src/core/ctcpparser.cpp b/src/core/ctcpparser.cpp index 7517db6f..db285a68 100644 --- a/src/core/ctcpparser.cpp +++ b/src/core/ctcpparser.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2013 by the Quassel Project * + * Copyright (C) 2005-2014 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -24,6 +24,7 @@ #include "coresession.h" #include "ctcpevent.h" #include "messageevent.h" +#include "coreuserinputhandler.h" const QByteArray XDELIM = "\001"; @@ -312,8 +313,29 @@ QByteArray CtcpParser::pack(const QByteArray &ctcpTag, const QByteArray &message void CtcpParser::query(CoreNetwork *net, const QString &bufname, const QString &ctcpTag, const QString &message) { QList params; + QList newparams; params << net->serverEncode(bufname) << lowLevelQuote(pack(net->serverEncode(ctcpTag), net->userEncode(bufname, message))); + + static const char *splitter = " .,-!?"; + int maxSplitPos = message.count(); + int splitPos = maxSplitPos; + + int overrun = net->userInputHandler()->lastParamOverrun("PRIVMSG", params); + if (overrun) { + maxSplitPos = message.count() - overrun -2; + splitPos = -1; + for (const char *splitChar = splitter; *splitChar != 0; splitChar++) { + splitPos = qMax(splitPos, message.lastIndexOf(*splitChar, maxSplitPos) + 1); // keep split char on old line + } + if (splitPos <= 0 || splitPos > maxSplitPos) + splitPos = maxSplitPos; + newparams << net->serverEncode(bufname) << lowLevelQuote(pack(net->serverEncode(ctcpTag), net->userEncode(bufname, message.left(splitPos)))); + params = newparams; + } net->putCmd("PRIVMSG", params); + + if (splitPos < message.count()) + query(net, bufname, ctcpTag, message.mid(splitPos)); }