X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclient.cpp;h=cedc0422679c1287f55890cf9da0ba39288c9191;hp=dd8bd21490c0ff80824c7b0e4e2998ce286ee959;hb=c5cbe5eb77fce2ab954a98399a1450803108217b;hpb=23eed68958b7585552be04fab4e5871a781b7f38;ds=sidebyside diff --git a/src/client/client.cpp b/src/client/client.cpp index dd8bd214..cedc0422 100644 --- a/src/client/client.cpp +++ b/src/client/client.cpp @@ -122,18 +122,6 @@ void Client::init() { /*** public static methods ***/ - -QList Client::networks() { - return instance()->_networks.values(); -} - -Network *Client::network(NetworkId networkid) { - if(instance()->_networks.contains(networkid)) - return instance()->_networks[networkid]; - else - return 0; -} - QList Client::allBufferInfos() { QList bufferids; foreach(Buffer *buffer, buffers()) { @@ -200,6 +188,17 @@ bool Client::isSynced() { return instance()->_syncedToCore; } +/*** Network handling ***/ + +QList Client::networkIds() { + return instance()->_networks.keys(); +} + +const Network * Client::network(NetworkId networkid) { + if(instance()->_networks.contains(networkid)) return instance()->_networks[networkid]; + else return 0; +} + /*** Identity handling ***/ QList Client::identityIds() { @@ -284,16 +283,6 @@ void Client::disconnectFromCore() { // Clear internal data. Hopefully nothing relies on it at this point. _networkModel->clear(); - QHash::iterator bufferIter = _buffers.begin(); - while(bufferIter != _buffers.end()) { - Buffer *buffer = bufferIter.value(); - disconnect(buffer, SIGNAL(destroyed()), this, 0); - bufferIter = _buffers.erase(bufferIter); - buffer->deleteLater(); - } - Q_ASSERT(_buffers.isEmpty()); - - QHash::iterator netIter = _networks.begin(); while(netIter != _networks.end()) { Network *net = netIter.value(); @@ -303,6 +292,15 @@ void Client::disconnectFromCore() { } Q_ASSERT(_networks.isEmpty()); + QHash::iterator bufferIter = _buffers.begin(); + while(bufferIter != _buffers.end()) { + Buffer *buffer = bufferIter.value(); + disconnect(buffer, SIGNAL(destroyed()), this, 0); + bufferIter = _buffers.erase(bufferIter); + buffer->deleteLater(); + } + Q_ASSERT(_buffers.isEmpty()); + QHash::iterator idIter = _identities.begin(); while(idIter != _identities.end()) { Identity *id = idIter.value(); @@ -387,6 +385,7 @@ void Client::addNetwork(Network *net) { networkModel()->attachNetwork(net); connect(net, SIGNAL(destroyed()), instance(), SLOT(networkDestroyed())); instance()->_networks[net->networkId()] = net; + emit instance()->networkAdded(net->networkId()); //if(net->networkId() == 1) net->requestConnect(); // FIXME }