diff options
author | James Booth <boothj5@gmail.com> | 2014-10-06 21:42:09 +0100 |
---|---|---|
committer | James Booth <boothj5@gmail.com> | 2014-10-06 21:42:09 +0100 |
commit | 965f048b18f7f7456bcb59dca841784aad3bfa11 (patch) | |
tree | 810e4e479e91e9db57a9d760afd09cd73f56298b /src/ui/core.c | |
parent | 2aeaad230e0095216c6a226ab4da8b03b3198e81 (diff) | |
download | profani-tty-965f048b18f7f7456bcb59dca841784aad3bfa11.tar.gz |
Implemented setting and listing roles
Diffstat (limited to 'src/ui/core.c')
-rw-r--r-- | src/ui/core.c | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/ui/core.c b/src/ui/core.c index a0712142..5269e96b 100644 --- a/src/ui/core.c +++ b/src/ui/core.c @@ -1894,6 +1894,44 @@ _ui_handle_room_affiliation_list(const char * const room, const char * const aff } static void +_ui_handle_room_role_list_error(const char * const room, const char * const role, const char * const error) +{ + ProfWin *window = wins_get_by_recipient(room); + if (window) { + win_save_vprint(window, '!', NULL, 0, COLOUR_ERROR, "", "Error retrieving %s list: %s", role, error); + } +} + +static void +_ui_handle_room_role_list(const char * const room, const char * const role, GSList *nicks) +{ + ProfWin *window = wins_get_by_recipient(room); + if (window) { + if (nicks) { + win_save_vprint(window, '!', NULL, 0, 0, "", "Role: %s", role); + GSList *curr_nick = nicks; + while (curr_nick) { + char *nick = curr_nick->data; + Occupant *occupant = muc_roster_item(room, nick); + if (occupant) { + if (occupant->jid) { + win_save_vprint(window, '!', NULL, 0, 0, "", " %s (%s)", nick, occupant->jid); + } else { + win_save_vprint(window, '!', NULL, 0, 0, "", " %s", nick); + } + } else { + win_save_vprint(window, '!', NULL, 0, 0, "", " %s", nick); + } + curr_nick = g_slist_next(curr_nick); + } + win_save_print(window, '!', NULL, 0, 0, "", ""); + } else { + win_save_vprint(window, '!', NULL, 0, 0, "", "No occupants found with role: %s", role); + } + } +} + +static void _ui_handle_room_affiliation_set_error(const char * const room, const char * const jid, const char * const affiliation, const char * const error) { @@ -1913,6 +1951,25 @@ _ui_handle_room_affiliation_set(const char * const room, const char * const jid, } static void +_ui_handle_room_role_set_error(const char * const room, const char * const nick, const char * const role, + const char * const error) +{ + ProfWin *window = wins_get_by_recipient(room); + if (window) { + win_save_vprint(window, '!', NULL, 0, COLOUR_ERROR, "", "Error setting %s role for %s: %s", role, nick, error); + } +} + +static void +_ui_handle_room_role_set(const char * const room, const char * const nick, const char * const role) +{ + ProfWin *window = wins_get_by_recipient(room); + if (window) { + win_save_vprint(window, '!', NULL, 0, 0, "", "Role for %s set: %s", nick, role); + } +} + +static void _ui_status(void) { char *recipient = ui_current_recipient(); @@ -2870,5 +2927,9 @@ ui_init_module(void) ui_room_kicked = _ui_room_kicked; ui_leave_room = _ui_leave_room; ui_room_member_kicked = _ui_room_member_kicked; + ui_handle_room_role_set_error = _ui_handle_room_role_set_error; + ui_handle_room_role_set = _ui_handle_room_role_set; + ui_handle_room_role_list_error = _ui_handle_room_role_list_error; + ui_handle_room_role_list = _ui_handle_room_role_list; } |