Fix initial backlog for buffers with no new messages
[quassel.git] / src / client / buffermodel.cpp
index 1a184ab..1ae0c2e 100644 (file)
@@ -60,12 +60,13 @@ void BufferModel::networkConnectionChanged(Network::ConnectionState state) {
   switch(state) {
   case Network::Connecting:
   case Network::Initializing:
-  case Network::Initialized:
     if(currentIndex().isValid())
       return;
-    Network *net = qobject_cast<Network *>(sender());
-    Q_ASSERT(net);
-    setCurrentIndex(mapFromSource(Client::networkModel()->networkIndex(net->networkId())));
+    {
+      Network *net = qobject_cast<Network *>(sender());
+      Q_ASSERT(net);
+      setCurrentIndex(mapFromSource(Client::networkModel()->networkIndex(net->networkId())));
+    }
     break;
   default:
     return;
@@ -101,6 +102,17 @@ void BufferModel::switchToBufferIndex(const QModelIndex &bufferIdx) {
   qWarning() << "BufferModel::switchToBufferIndex(const QModelIndex &):" << bufferIdx << "does not belong to BufferModel or NetworkModel";
 }
 
+void BufferModel::switchToOrJoinBuffer(NetworkId networkId, const QString &name) {
+  BufferId bufId = Client::networkModel()->bufferId(networkId, name);
+  if(bufId.isValid()) {
+    QModelIndex targetIdx = Client::networkModel()->bufferIndex(bufId);
+    switchToBuffer(bufId);
+    if(!targetIdx.data(NetworkModel::ItemActiveRole).toBool())
+      Client::userInput(BufferInfo::fakeStatusBuffer(networkId), QString("/JOIN %1").arg(name));
+  } else
+    Client::userInput(BufferInfo::fakeStatusBuffer(networkId), QString("/JOIN %1").arg(name));
+}
+
 void BufferModel::debug_currentChanged(QModelIndex current, QModelIndex previous) {
   Q_UNUSED(previous);
   qDebug() << "Switched current Buffer: " << current << current.data().toString() << "Buffer:" << current.data(NetworkModel::BufferIdRole).value<BufferId>();