about summary refs log tree commit diff stats
path: root/src/ui
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2016-01-31 18:52:53 +0000
committerJames Booth <boothj5@gmail.com>2016-01-31 18:52:53 +0000
commita0f43adf5ba49f9024445202394ae14ecabd4d2a (patch)
treed1c39e390f84a0803976545de848fb330a1d4edc /src/ui
parent1c65c36cb6178ae0221dc8d3172807523d363d6e (diff)
downloadprofani-tty-a0f43adf5ba49f9024445202394ae14ecabd4d2a.tar.gz
Only add private chats to Rooms unread count in roster when room active
Diffstat (limited to 'src/ui')
-rw-r--r--src/ui/rosterwin.c27
1 files changed, 15 insertions, 12 deletions
diff --git a/src/ui/rosterwin.c b/src/ui/rosterwin.c
index 971c6fd3..60d2fa91 100644
--- a/src/ui/rosterwin.c
+++ b/src/ui/rosterwin.c
@@ -843,21 +843,24 @@ _rosterwin_rooms_header(ProfLayoutSplit *layout, gboolean newline, GList *rooms)
         while (curr) {
             ProfMucWin *mucwin = curr->data;
             unread += mucwin->unread;
-            curr = g_list_next(curr);
-        }
 
-        char *prefpriv = prefs_get_string(PREF_ROSTER_PRIVATE);
-        if (g_strcmp0(prefpriv, "room") == 0) {
-            GList *privwins = wins_get_private_chats(NULL);
-            GList *curr = privwins;
-            while (curr) {
-                ProfPrivateWin *privwin = curr->data;
-                unread += privwin->unread;
-                curr = g_list_next(curr);
+            // include private chats
+            char *prefpriv = prefs_get_string(PREF_ROSTER_PRIVATE);
+            if (g_strcmp0(prefpriv, "room") == 0) {
+                GList *privwins = wins_get_private_chats(mucwin->roomjid);
+                GList *curr_priv = privwins;
+                while (curr_priv) {
+                    ProfPrivateWin *privwin = curr_priv->data;
+                    unread += privwin->unread;
+                    curr_priv = g_list_next(curr_priv);
+                }
+                g_list_free(privwins);
             }
-            g_list_free(privwins);
+            prefs_free_string(prefpriv);
+
+            curr = g_list_next(curr);
         }
-        prefs_free_string(prefpriv);
+
         if (unread == 0 && prefs_get_boolean(PREF_ROSTER_COUNT_ZERO)) {
             g_string_append_printf(header, " (%d)", unread);
         } else if (unread > 0) {