X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fcoresession.cpp;h=696825d6e6bc8d332d2e8a591b6c8da0e28cc0e1;hb=02455427bfd88584a81f94b1b234fe21ad3e09cd;hp=f868379bb34cc4ed6dfdd788c42bf9a72b1617b7;hpb=cb1918d94b5d8ec9f05a192c96fab938782dabf5;p=quassel.git diff --git a/src/core/coresession.cpp b/src/core/coresession.cpp index f868379b..696825d6 100644 --- a/src/core/coresession.cpp +++ b/src/core/coresession.cpp @@ -29,6 +29,7 @@ #include "buffersyncer.h" #include "corebacklogmanager.h" #include "corebufferviewmanager.h" +#include "coreirclisthelper.h" #include "storage.h" #include "corenetwork.h" @@ -43,9 +44,12 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) : QObject(parent), _user(uid), _signalProxy(new SignalProxy(SignalProxy::Server, 0, this)), + _aliasManager(this), _bufferSyncer(new BufferSyncer(this)), _backlogManager(new CoreBacklogManager(this)), _bufferViewManager(new CoreBufferViewManager(_signalProxy, this)), + _ircListHelper(new CoreIrcListHelper(this)), + _coreInfo(this), scriptEngine(new QScriptEngine(this)) { @@ -85,9 +89,18 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) p->synchronize(_bufferSyncer); - // init BacklogManager; + // init alias manager + p->synchronize(&aliasManager()); + + // init BacklogManager p->synchronize(_backlogManager); - + + // init IrcListHelper + p->synchronize(ircListHelper()); + + // init CoreInfo + p->synchronize(&_coreInfo); + // Restore session state if(restoreState) restoreSessionState(); @@ -233,7 +246,7 @@ void CoreSession::removeClient(QIODevice *iodev) { // no checks for validity check - privateslot... QTcpSocket *socket = qobject_cast(iodev); if(socket) - qDebug() << qPrintable(tr("Client %1 disconnected (UserId: %2).").arg(socket->peerAddress().toString()).arg(user().toInt())); + qDebug() << qPrintable(tr("Client")) << qPrintable(socket->peerAddress().toString()) << qPrintable(tr("disconnected (UserId: %1).").arg(user().toInt())); else qDebug() << "Local client disconnedted."; disconnect(socket, 0, this, 0); @@ -453,8 +466,12 @@ void CoreSession::destroyNetwork(NetworkId id) { // this can happen if the network was reconnecting while being removed _connections.take(id)->deleteLater(); } + QList removedBuffers = Core::requestBufferIdsForNetwork(user(), id); Network *net = _networks.take(id); if(net && Core::removeNetwork(user(), id)) { + foreach(BufferId bufferId, removedBuffers) { + _bufferSyncer->removeBuffer(bufferId); + } emit networkRemoved(id); net->deleteLater(); }