X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fnetworkconnection.cpp;h=93568b040b3b2530437bc10f8618857423736e19;hb=eb9c5e7ed502b6f01311ecb5d3066a3ac31ec24d;hp=0a2604c0964b04e7afb505ff677533bdf5c806c2;hpb=70638bdb6a34f51409d4618128fbfd5b56af0e52;p=quassel.git diff --git a/src/core/networkconnection.cpp b/src/core/networkconnection.cpp index 0a2604c0..93568b04 100644 --- a/src/core/networkconnection.cpp +++ b/src/core/networkconnection.cpp @@ -51,6 +51,11 @@ NetworkConnection::NetworkConnection(Network *network, CoreSession *session) : Q _whoTimer.setInterval(60 * 1000); _whoTimer.setSingleShot(false); + QHash channels = coreSession()->persistentChannels(networkId()); + foreach(QString chan, channels.keys()) { + _channelKeys[chan.toLower()] = channels[chan]; + } + connect(&_autoReconnectTimer, SIGNAL(timeout()), this, SLOT(doAutoReconnect())); connect(&_whoTimer, SIGNAL(timeout()), this, SLOT(sendWho())); @@ -71,7 +76,7 @@ NetworkConnection::NetworkConnection(Network *network, CoreSession *session) : Q NetworkConnection::~NetworkConnection() { if(connectionState() != Network::Disconnected && connectionState() != Network::Reconnecting) - disconnectFromIrc(); + disconnectFromIrc(false); // clean up, but this does not count as requested disconnect! delete _ircServerHandler; delete _userInputHandler; delete _ctcpHandler; @@ -227,8 +232,8 @@ void NetworkConnection::sendPerform() { // rejoin channels we've been in QStringList channels, keys; - foreach(QString chan, network()->persistentChannels().keys()) { - QString key = network()->persistentChannels()[chan]; + foreach(QString chan, persistentChannels()) { + QString key = channelKey(chan); if(!key.isEmpty()) { channels.prepend(chan); keys.prepend(key); } else { @@ -239,7 +244,7 @@ void NetworkConnection::sendPerform() { if(!joinString.isEmpty()) userInputHandler()->handleJoin(statusBuf, joinString); } -void NetworkConnection::disconnectFromIrc() { +void NetworkConnection::disconnectFromIrc(bool requested) { _autoReconnectTimer.stop(); _autoReconnectCount = 0; displayMsg(Message::Server, BufferInfo::StatusBuffer, "", tr("Disconnecting.")); @@ -247,6 +252,10 @@ void NetworkConnection::disconnectFromIrc() { setConnectionState(Network::Disconnected); socketDisconnected(); } else socket.disconnectFromHost(); + + if(requested) { + emit quitRequested(networkId()); + } } void NetworkConnection::socketHasData() { @@ -307,8 +316,7 @@ void NetworkConnection::socketDisconnected() { _whoTimer.stop(); network()->setConnected(false); emit disconnected(networkId()); - if(_autoReconnectCount == 0) emit quitRequested(networkId()); - else { + if(_autoReconnectCount != 0) { setConnectionState(Network::Reconnecting); if(_autoReconnectCount == network()->autoReconnectRetries()) doAutoReconnect(); // first try is immediate else _autoReconnectTimer.start(); @@ -355,17 +363,29 @@ void NetworkConnection::sendWho() { } } +void NetworkConnection::setChannelJoined(const QString &channel) { + emit channelJoined(networkId(), channel, _channelKeys[channel.toLower()]); +} + +void NetworkConnection::setChannelParted(const QString &channel) { + removeChannelKey(channel); + emit channelParted(networkId(), channel); +} + void NetworkConnection::addChannelKey(const QString &channel, const QString &key) { - if(key.isEmpty()) removeChannelKey(channel); - else _channelKeys[channel] = key; + if(key.isEmpty()) { + removeChannelKey(channel); + } else { + _channelKeys[channel.toLower()] = key; + } } void NetworkConnection::removeChannelKey(const QString &channel) { - _channelKeys.remove(channel); + _channelKeys.remove(channel.toLower()); } void NetworkConnection::nickChanged(const QString &newNick, const QString &oldNick) { - emit nickChanged(_network->networkId(), newNick, oldNick); + emit nickChanged(networkId(), newNick, oldNick); } /* Exception classes for message handling */