X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=network%2Fserver.cpp;h=d55a9a7159b76bce0aa1ac7afc418f2da653bc7c;hb=84516825d33a1b448a894eaf2e804cabb032f5f1;hp=d493e67cfe1a6ce94098bf572912bd6048be7e1b;hpb=8b192b08f3df4ce0e7cc4a08564645c76efa688d;p=quassel.git diff --git a/network/server.cpp b/network/server.cpp index d493e67c..d55a9a71 100644 --- a/network/server.cpp +++ b/network/server.cpp @@ -18,7 +18,9 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ +#include "quassel.h" #include "server.h" +#include "cmdcodes.h" Server::Server() { socket = new QTcpSocket(); @@ -29,6 +31,10 @@ Server::~Server() { delete socket; } +void Server::init() { + Message::init(&dispatchServerMsg, &dispatchUserMsg); +} + void Server::run() { connect(socket, SIGNAL(connected()), this, SLOT(socketConnected())); connect(socket, SIGNAL(disconnected()), this, SLOT(socketDisconnected())); @@ -57,15 +63,23 @@ void Server::disconnectFromIrc( ) { } void Server::putRawLine( const QString &s ) { - qDebug() << "Raw line: " << s; + qDebug() << "Sent: " << s; stream << s << "\r\n" << flush; + //Message::createFromServerString(this, s); } void Server::socketHasData( ) { while(socket->canReadLine()) { QString s = stream.readLine(); qDebug() << "Read: " << s; - emit recvLine(s + "\n"); + emit recvRawServerMsg(s); + Message *msg = Message::createFromServerString(this, s); + if(msg) { + try { handleServerMsg(msg); } catch(Exception e) { + emit recvLine(e.msg() + "\n"); + } + } + delete msg; } } @@ -88,4 +102,50 @@ void Server::socketStateChanged(QAbstractSocket::SocketState state) { qDebug() << "Socket state changed: " << state; } +/** Handle a message sent by the IRC server that does not have a custom handler. */ +void Server::handleServerMsg(Message *msg) { + int cmdCode = msg->getCmdCode(); + QString prefix = msg->getPrefix(); + QStringList params = msg->getParams(); + if(cmdCode < 0) { + switch(-cmdCode) { + case CMD_PING: + // PING [] + if(params.size() == 1) { + putRawLine(QString("PONG :") + params[0]); + } else if(params.size() == 2) { + putRawLine(QString("PONG ") + params[0] + " :" + params[1]); + } else throw ParseError(msg); + break; + + default: + throw Exception(QString("No handler installed for command: ") + msg->getCmd() + " " + msg->getParams().join(" ")); + } + } else if(msg->getCmdCode() > 0) { + switch(msg->getCmdCode()) { + + default: + // + throw Exception(msg->getCmd() + " " + msg->getParams().join(" ")); + } + + } else { + throw UnknownCmdError(msg); + } +} + +QString Server::handleUserMsg(Message *msg) { + + return ""; +} + +/* Exception classes for message handling */ +Server::ParseError::ParseError(Message *msg) { + _msg = QString("Command Parse Error: ") + msg->getCmd() + msg->getParams().join(" "); + +} + +Server::UnknownCmdError::UnknownCmdError(Message *msg) { + _msg = QString("Unknown Command: ") + msg->getCmd(); +}