X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fcorebasichandler.h;h=f7cd0242d009d5b10913079a1be2c1275c0a4f8e;hb=145a52eb79fed146731f85c23b60f0609e40e785;hp=f741112e055cabe98b14a15209839e23257b66c2;hpb=6eefdfc697067d184a589fc8a231b16316c09106;p=quassel.git diff --git a/src/core/corebasichandler.h b/src/core/corebasichandler.h index f741112e..f7cd0242 100644 --- a/src/core/corebasichandler.h +++ b/src/core/corebasichandler.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -25,9 +25,8 @@ #include #include "basichandler.h" -#include "message.h" - #include "corenetwork.h" +#include "message.h" class CoreSession; @@ -36,45 +35,47 @@ class CoreBasicHandler : public BasicHandler Q_OBJECT public: - CoreBasicHandler(CoreNetwork *parent = nullptr); - - QString serverDecode(const QByteArray &string); - QStringList serverDecode(const QList &stringlist); - QString channelDecode(const QString &bufferName, const QByteArray &string); - QStringList channelDecode(const QString &bufferName, const QList &stringlist); - QString userDecode(const QString &userNick, const QByteArray &string); - QStringList userDecode(const QString &userNick, const QList &stringlist); - - QByteArray serverEncode(const QString &string); - QList serverEncode(const QStringList &stringlist); - QByteArray channelEncode(const QString &bufferName, const QString &string); - QList channelEncode(const QString &bufferName, const QStringList &stringlist); - QByteArray userEncode(const QString &userNick, const QString &string); - QList userEncode(const QString &userNick, const QStringList &stringlist); + CoreBasicHandler(CoreNetwork* parent = nullptr); + + QString serverDecode(const QByteArray& string); + QStringList serverDecode(const QList& stringlist); + QString channelDecode(const QString& bufferName, const QByteArray& string); + QStringList channelDecode(const QString& bufferName, const QList& stringlist); + QString userDecode(const QString& userNick, const QByteArray& string); + QStringList userDecode(const QString& userNick, const QList& stringlist); + + QByteArray serverEncode(const QString& string); + QList serverEncode(const QStringList& stringlist); + QByteArray channelEncode(const QString& bufferName, const QString& string); + QList channelEncode(const QString& bufferName, const QStringList& stringlist); + QByteArray userEncode(const QString& userNick, const QString& string); + QList userEncode(const QString& userNick, const QStringList& stringlist); signals: - void displayMsg(Message::Type, BufferInfo::Type, const QString &target, const QString &text, const QString &sender = "", Message::Flags flags = Message::None); + void displayMsg(const NetworkInternalMessage& msg); /** * Sends the raw (encoded) line, adding to the queue if needed, optionally with higher priority. * * @see CoreNetwork::putRawLine() */ - void putRawLine(const QByteArray &msg, const bool prepend = false); + void putRawLine(const QByteArray& msg, bool prepend = false); /** * Sends the command with encoded parameters, with optional prefix or high priority. * - * @see CoreNetwork::putCmd(const QString &cmd, const QList ¶ms, const QByteArray &prefix = QByteArray(), const bool prepend = false) + * @see CoreNetwork::putCmd(const QString &cmd, const QList ¶ms, const QByteArray &prefix = QByteArray(), const + * QHash& tags = {}, bool prepend = false) */ - void putCmd(const QString &cmd, const QList ¶ms, const QByteArray &prefix = {}, bool prepend = false); + void putCmd(const QString& cmd, const QList& params, const QByteArray& prefix = {}, const QHash& tags = {}, bool prepend = false); /** * Sends the command for each set of encoded parameters, with optional prefix or high priority. * - * @see CoreNetwork::putCmd(const QString &cmd, const QList> ¶ms, const QByteArray &prefix = QByteArray(), const bool prepend = false) + * @see CoreNetwork::putCmd(const QString &cmd, const QList> ¶ms, const QByteArray &prefix = QByteArray(), const + * QHash& tags = {}, bool prepend = false) */ - void putCmd(const QString &cmd, const QList> ¶ms, const QByteArray &prefix = {}, bool prepend = false); + void putCmd(const QString& cmd, const QList>& params, const QByteArray& prefix = {}, const QHash& tags = {}, bool prepend = false); protected: /** @@ -83,6 +84,7 @@ protected: * @param[in] cmd Command to send, ignoring capitalization * @param[in] param Parameter for the command, encoded within a QByteArray * @param[in] prefix Optional command prefix + * @param[in] tags Optional command tags * @param[in] prepend * @parmblock * If true, the command is prepended into the start of the queue, otherwise, it's appended to @@ -90,16 +92,15 @@ protected: * maintain PING/PONG replies, the other side will close the connection. * @endparmblock */ - void putCmd(const QString &cmd, const QByteArray ¶m, const QByteArray &prefix = QByteArray(), const bool prepend = false); + void putCmd(const QString& cmd, const QByteArray& param, const QByteArray& prefix = QByteArray(), const QHash& tags = {}, bool prepend = false); - inline CoreNetwork *network() const { return _network; } - inline CoreSession *coreSession() const { return _network->coreSession(); } + inline CoreNetwork* network() const { return _network; } + inline CoreSession* coreSession() const { return _network->coreSession(); } - BufferInfo::Type typeByTarget(const QString &target) const; + BufferInfo::Type typeByTarget(const QString& target) const; private: - CoreNetwork *_network; + CoreNetwork* _network; }; - #endif