X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=network%2Fserver.h;h=b0077c19072d3c4499bfcf1de64cd9079784d99d;hp=b2131112699bad1544aa97f0e8ec852f10360329;hb=e368a1672c4f917bfa6adb52dae3b5ebfcd0db18;hpb=7bcf3798d7e4edb49345f40c7c543f7a9bb97805 diff --git a/network/server.h b/network/server.h index b2131112..b0077c19 100644 --- a/network/server.h +++ b/network/server.h @@ -22,12 +22,14 @@ #define _SERVER_H_ #include +#include #include -#include "message.h" +#include "quassel.h" #define DEFAULT_PORT 6667 + /** * This is a server object, managing a single connection to an IRC server, handling the associated channels and so on. * We have this run in its own thread mainly to not block other server objects or the core if something goes wrong, @@ -51,7 +53,8 @@ class Server : public QThread { void connectToIrc(const QString &host, quint16 port = DEFAULT_PORT); void disconnectFromIrc(); - void putRawLine(const QString &input /*, Buffer *source = 0 */); + void putRawLine(QString input); + void putCmd(QString cmd, QStringList params, QString prefix = 0); signals: //void outputLine(const QString & /*, Buffer *target = 0 */); @@ -66,44 +69,34 @@ class Server : public QThread { void socketDisconnected(); void socketStateChanged(QAbstractSocket::SocketState); + /* Message Handlers */ + /* handleXxxxFromServer(QString prefix, QStringList params); */ + void handleNoticeFromServer(QString, QStringList); + void handlePingFromServer(QString, QStringList); + + void defaultHandlerForServer(QString cmd, QString prefix, QStringList params); + private: - QTcpSocket *socket; + QTcpSocket socket; QTextStream stream; - void handleServerMsg(Message *); - void handleUserMsg(Message *); - static inline void dispatchServerMsg(Message *msg) { msg->getServer()->handleServerMsg(msg); } - static inline void dispatchUserMsg(Message *msg) { msg->getServer()->handleUserMsg(msg); } + void handleServerMsg(QString rawMsg); + void handleUserMsg(QString usrMsg); + //static inline void dispatchServerMsg(Message *msg) { msg->getServer()->handleServerMsg(msg); } + //static inline void dispatchUserMsg(Message *msg) { msg->getServer()->handleUserMsg(msg); } + + class ParseError : public Exception { + public: + ParseError(QString cmd, QString prefix, QStringList params); + }; + class UnknownCmdError : public Exception { + public: + UnknownCmdError(QString cmd, QString prefix, QStringList params); + }; }; class Buffer {}; -/* -class TcpConnection : public QThread { - Q_OBJECT - - - public: - void run(); - QAbstractSocket::SocketState state() const; - - public slots: - void connectToHost(const QString &host, quint16 port = DEFAULT_PORT); - void disconnectFromHost(); - void sendLine(const QString &); - - signals: - void recvLine(QString); - void error(QAbstractSocket::SocketError); - void connected(); - void disconnected(); - void stateChanged(QAbstractSocket::SocketState); - - private: - QTcpSocket socket; - QTextStream stream; -}; -*/ #endif