diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/command/commands.c | 2 | ||||
-rw-r--r-- | src/config/preferences.c | 2 | ||||
-rw-r--r-- | src/ui/rosterwin.c | 120 | ||||
-rw-r--r-- | src/ui/window.c | 13 | ||||
-rw-r--r-- | src/ui/window.h | 1 |
5 files changed, 94 insertions, 44 deletions
diff --git a/src/command/commands.c b/src/command/commands.c index 18fa1bd9..3aa05950 100644 --- a/src/command/commands.c +++ b/src/command/commands.c @@ -1821,7 +1821,7 @@ cmd_roster(ProfWin *window, const char *const command, gchar **args) } else { int intval = 0; char *err_msg = NULL; - gboolean res = strtoi_range(args[2], &intval, 0, 10, &err_msg); + gboolean res = strtoi_range(args[2], &intval, -1, 10, &err_msg); if (res) { prefs_set_roster_presence_indent(intval); cons_show("Roster presence indent set to: %d", intval); diff --git a/src/config/preferences.c b/src/config/preferences.c index d1adfdc4..26405989 100644 --- a/src/config/preferences.c +++ b/src/config/preferences.c @@ -558,7 +558,7 @@ prefs_get_roster_presence_indent(void) } gint result = g_key_file_get_integer(prefs, PREF_GROUP_UI, "roster.presence.indent", NULL); - if (result < 0) { + if (result < -1) { result = 0; } diff --git a/src/ui/rosterwin.c b/src/ui/rosterwin.c index cc31ef55..f3a10257 100644 --- a/src/ui/rosterwin.c +++ b/src/ui/rosterwin.c @@ -65,41 +65,66 @@ _rosterwin_presence(ProfLayoutSplit *layout, theme_item_t colour, const char *pr if (by_presence) { if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { wattron(layout->subwin, theme_attrs(colour)); - GString *msg = g_string_new(" "); - while (current_indent > 0) { - g_string_append(msg, " "); - current_indent--; + if (presence_indent == -1) { + GString *msg = g_string_new(""); + g_string_append_printf(msg, ": \"%s\"", status); + win_print_nowrap(layout->subwin, msg->str, FALSE); + g_string_free(msg, TRUE); + wattroff(layout->subwin, theme_attrs(colour)); + } else { + GString *msg = g_string_new(" "); + while (current_indent > 0) { + g_string_append(msg, " "); + current_indent--; + } + g_string_append_printf(msg, "\"%s\"", status); + win_newline_lazy(layout->subwin); + win_print_nowrap(layout->subwin, msg->str, FALSE); + g_string_free(msg, TRUE); + wattroff(layout->subwin, theme_attrs(colour)); } - g_string_append_printf(msg, "\"%s\"", status); - win_print_nowrap(layout->subwin, msg->str, TRUE); - g_string_free(msg, TRUE); - wattroff(layout->subwin, theme_attrs(colour)); } // show both presence and status when not grouped by presence } else if (prefs_get_boolean(PREF_ROSTER_PRESENCE) || (status && prefs_get_boolean(PREF_ROSTER_STATUS))) { wattron(layout->subwin, theme_attrs(colour)); - GString *msg = g_string_new(" "); - while (current_indent > 0) { - g_string_append(msg, " "); - current_indent--; - } - if (prefs_get_boolean(PREF_ROSTER_PRESENCE)) { - g_string_append(msg, presence); - if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { - g_string_append_printf(msg, " \"%s\"", status); + if (presence_indent == -1) { + GString *msg = g_string_new(""); + if (prefs_get_boolean(PREF_ROSTER_PRESENCE)) { + g_string_append_printf(msg, ": %s", presence); + if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { + g_string_append_printf(msg, " \"%s\"", status); + } + } else if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { + g_string_append_printf(msg, ": \"%s\"", status); + } + win_print_nowrap(layout->subwin, msg->str, FALSE); + g_string_free(msg, TRUE); + wattroff(layout->subwin, theme_attrs(colour)); + } else { + GString *msg = g_string_new(" "); + while (current_indent > 0) { + g_string_append(msg, " "); + current_indent--; + } + if (prefs_get_boolean(PREF_ROSTER_PRESENCE)) { + g_string_append(msg, presence); + if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { + g_string_append_printf(msg, " \"%s\"", status); + } + } else if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { + g_string_append_printf(msg, "\"%s\"", status); } - } else if (status && prefs_get_boolean(PREF_ROSTER_STATUS)) { - g_string_append_printf(msg, "\"%s\"", status); + win_newline_lazy(layout->subwin); + win_print_nowrap(layout->subwin, msg->str, FALSE); + g_string_free(msg, TRUE); + wattroff(layout->subwin, theme_attrs(colour)); } - win_print_nowrap(layout->subwin, msg->str, TRUE); - g_string_free(msg, TRUE); - wattroff(layout->subwin, theme_attrs(colour)); } } static void -_rosterwin_resource(ProfLayoutSplit *layout, PContact contact, int current_indent) +_rosterwin_resources(ProfLayoutSplit *layout, PContact contact, int current_indent) { GList *resources = p_contact_get_available_resources(contact); if (resources) { @@ -125,7 +150,8 @@ _rosterwin_resource(ProfLayoutSplit *layout, PContact contact, int current_inden if (prefs_get_boolean(PREF_ROSTER_PRIORITY)) { g_string_append_printf(msg, " [%d]", resource->priority); } - win_print_nowrap(layout->subwin, msg->str, TRUE); + win_newline_lazy(layout->subwin); + win_print_nowrap(layout->subwin, msg->str, FALSE); g_string_free(msg, TRUE); wattroff(layout->subwin, theme_attrs(resource_presence_colour)); @@ -170,24 +196,28 @@ _rosterwin_contact(ProfLayoutSplit *layout, PContact contact) g_string_append_printf(msg, "%c", ch); } g_string_append(msg, name); - win_print_nowrap(layout->subwin, msg->str, TRUE); + win_newline_lazy(layout->subwin); + win_print_nowrap(layout->subwin, msg->str, FALSE); g_string_free(msg, TRUE); wattroff(layout->subwin, theme_attrs(presence_colour)); if (prefs_get_boolean(PREF_ROSTER_RESOURCE)) { - _rosterwin_resource(layout, contact, current_indent); + _rosterwin_resources(layout, contact, current_indent); } else if (prefs_get_boolean(PREF_ROSTER_PRESENCE) || prefs_get_boolean(PREF_ROSTER_STATUS)) { _rosterwin_presence(layout, presence_colour, presence, status, current_indent); } } static void -_rosterwin_contacts_by_presence(ProfLayoutSplit *layout, const char *const presence, char *title) +_rosterwin_contacts_by_presence(ProfLayoutSplit *layout, const char *const presence, char *title, gboolean newline) { GSList *contacts = roster_get_contacts_by_presence(presence); // if this group has contacts, or if we want to show empty groups if (contacts || prefs_get_boolean(PREF_ROSTER_EMPTY)) { + if (newline) { + win_newline_lazy(layout->subwin); + } wattron(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); GString *title_str = g_string_new(" "); char ch = prefs_get_roster_header_char(); @@ -198,7 +228,7 @@ _rosterwin_contacts_by_presence(ProfLayoutSplit *layout, const char *const prese if (prefs_get_boolean(PREF_ROSTER_COUNT)) { g_string_append_printf(title_str, " (%d)", g_slist_length(contacts)); } - win_print_nowrap(layout->subwin, title_str->str, TRUE); + win_print_nowrap(layout->subwin, title_str->str, FALSE); g_string_free(title_str, TRUE); wattroff(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); } @@ -215,7 +245,7 @@ _rosterwin_contacts_by_presence(ProfLayoutSplit *layout, const char *const prese } static void -_rosterwin_contacts_by_group(ProfLayoutSplit *layout, char *group) +_rosterwin_contacts_by_group(ProfLayoutSplit *layout, char *group, gboolean newline) { GSList *contacts = NULL; @@ -229,6 +259,9 @@ _rosterwin_contacts_by_group(ProfLayoutSplit *layout, char *group) prefs_free_string(order); if (contacts || prefs_get_boolean(PREF_ROSTER_EMPTY)) { + if (newline) { + win_newline_lazy(layout->subwin); + } wattron(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); GString *title = g_string_new(" "); char ch = prefs_get_roster_header_char(); @@ -239,7 +272,7 @@ _rosterwin_contacts_by_group(ProfLayoutSplit *layout, char *group) if (prefs_get_boolean(PREF_ROSTER_COUNT)) { g_string_append_printf(title, " (%d)", g_slist_length(contacts)); } - win_print_nowrap(layout->subwin, title->str, TRUE); + win_print_nowrap(layout->subwin, title->str, FALSE); g_string_free(title, TRUE); wattroff(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); @@ -254,7 +287,7 @@ _rosterwin_contacts_by_group(ProfLayoutSplit *layout, char *group) } static void -_rosterwin_contacts_by_no_group(ProfLayoutSplit *layout) +_rosterwin_contacts_by_no_group(ProfLayoutSplit *layout, gboolean newline) { GSList *contacts = NULL; @@ -268,6 +301,9 @@ _rosterwin_contacts_by_no_group(ProfLayoutSplit *layout) prefs_free_string(order); if (contacts || prefs_get_boolean(PREF_ROSTER_EMPTY)) { + if (newline) { + win_newline_lazy(layout->subwin); + } wattron(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); GString *title = g_string_new(" "); char ch = prefs_get_roster_header_char(); @@ -279,7 +315,7 @@ _rosterwin_contacts_by_no_group(ProfLayoutSplit *layout) if (prefs_get_boolean(PREF_ROSTER_COUNT)) { g_string_append_printf(title, " (%d)", g_slist_length(contacts)); } - win_print_nowrap(layout->subwin, title->str, TRUE); + win_print_nowrap(layout->subwin, title->str, FALSE); g_string_free(title, TRUE); wattroff(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); @@ -307,24 +343,26 @@ rosterwin_roster(void) char *by = prefs_get_string(PREF_ROSTER_BY); if (g_strcmp0(by, "presence") == 0) { werase(layout->subwin); - _rosterwin_contacts_by_presence(layout, "chat", "Available for chat"); - _rosterwin_contacts_by_presence(layout, "online", "Online"); - _rosterwin_contacts_by_presence(layout, "away", "Away"); - _rosterwin_contacts_by_presence(layout, "xa", "Extended Away"); - _rosterwin_contacts_by_presence(layout, "dnd", "Do not disturb"); + _rosterwin_contacts_by_presence(layout, "chat", "Available for chat", FALSE); + _rosterwin_contacts_by_presence(layout, "online", "Online", TRUE); + _rosterwin_contacts_by_presence(layout, "away", "Away", TRUE); + _rosterwin_contacts_by_presence(layout, "xa", "Extended Away", TRUE); + _rosterwin_contacts_by_presence(layout, "dnd", "Do not disturb", TRUE); if (prefs_get_boolean(PREF_ROSTER_OFFLINE)) { - _rosterwin_contacts_by_presence(layout, "offline", "Offline"); + _rosterwin_contacts_by_presence(layout, "offline", "Offline", TRUE); } } else if (g_strcmp0(by, "group") == 0) { werase(layout->subwin); + gboolean newline = FALSE; GSList *groups = roster_get_groups(); GSList *curr_group = groups; while (curr_group) { - _rosterwin_contacts_by_group(layout, curr_group->data); + _rosterwin_contacts_by_group(layout, curr_group->data, newline); + newline = TRUE; curr_group = g_slist_next(curr_group); } g_slist_free_full(groups, free); - _rosterwin_contacts_by_no_group(layout); + _rosterwin_contacts_by_no_group(layout, newline); } else { GSList *contacts = NULL; @@ -349,7 +387,7 @@ rosterwin_roster(void) if (prefs_get_boolean(PREF_ROSTER_COUNT)) { g_string_append_printf(title, " (%d)", g_slist_length(contacts)); } - win_print_nowrap(layout->subwin, title->str, TRUE); + win_print_nowrap(layout->subwin, title->str, FALSE); g_string_free(title, TRUE); wattroff(layout->subwin, theme_attrs(THEME_ROSTER_HEADER)); diff --git a/src/ui/window.c b/src/ui/window.c index 3ca9b927..c40e3547 100644 --- a/src/ui/window.c +++ b/src/ui/window.c @@ -1269,11 +1269,22 @@ void win_print_nowrap(WINDOW *win, char *msg, gboolean newline) { int maxx = getmaxx(win); + int curx = getcurx(win); int cury = getcury(win); - waddnstr(win, msg, maxx); + waddnstr(win, msg, maxx - curx); if (newline) { wmove(win, cury+1, 0); } } + +void +win_newline_lazy(WINDOW *win) +{ + int curx = getcurx(win); + if (curx > 0) { + int cury = getcury(win); + wmove(win, cury+1, 0); + } +} diff --git a/src/ui/window.h b/src/ui/window.h index 24d71ad6..0a01b37f 100644 --- a/src/ui/window.h +++ b/src/ui/window.h @@ -68,6 +68,7 @@ void win_redraw(ProfWin *window); int win_roster_cols(void); int win_occpuants_cols(void); void win_print_nowrap(WINDOW *win, char *msg, gboolean newline); +void win_newline_lazy(WINDOW *win); void win_mark_received(ProfWin *window, const char *const id); gboolean win_has_active_subwin(ProfWin *window); |