group nicklist handling fixed
This commit is contained in:
parent
cc9d370105
commit
4021d9da0e
3 changed files with 52 additions and 41 deletions
|
@ -133,11 +133,7 @@ twc_chat_new_group(struct t_twc_profile *profile, int32_t group_number)
|
||||||
|
|
||||||
chat->nicklist_group = weechat_nicklist_add_group(chat->buffer, NULL,
|
chat->nicklist_group = weechat_nicklist_add_group(chat->buffer, NULL,
|
||||||
NULL, NULL, true);
|
NULL, NULL, true);
|
||||||
chat->nicks = weechat_hashtable_new(32,
|
chat->nicks = weechat_list_new();
|
||||||
WEECHAT_HASHTABLE_INTEGER,
|
|
||||||
WEECHAT_HASHTABLE_POINTER,
|
|
||||||
NULL,
|
|
||||||
NULL);
|
|
||||||
|
|
||||||
weechat_buffer_set(chat->buffer, "nicklist", "1");
|
weechat_buffer_set(chat->buffer, "nicklist", "1");
|
||||||
}
|
}
|
||||||
|
@ -401,7 +397,10 @@ twc_chat_free(struct t_twc_chat *chat)
|
||||||
{
|
{
|
||||||
weechat_nicklist_remove_all(chat->buffer);
|
weechat_nicklist_remove_all(chat->buffer);
|
||||||
if (chat->nicks)
|
if (chat->nicks)
|
||||||
weechat_hashtable_free(chat->nicks);
|
{
|
||||||
|
weechat_list_remove_all(chat->nicks);
|
||||||
|
weechat_list_free(chat->nicks);
|
||||||
|
}
|
||||||
free(chat);
|
free(chat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@ struct t_twc_chat
|
||||||
int32_t group_number;
|
int32_t group_number;
|
||||||
|
|
||||||
struct t_gui_nick_group *nicklist_group;
|
struct t_gui_nick_group *nicklist_group;
|
||||||
struct t_hashtable *nicks;
|
struct t_weelist *nicks;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct t_twc_chat *
|
struct t_twc_chat *
|
||||||
|
|
|
@ -435,52 +435,64 @@ twc_group_namelist_change_callback(Tox *tox,
|
||||||
true);
|
true);
|
||||||
|
|
||||||
struct t_gui_nick *nick = NULL;
|
struct t_gui_nick *nick = NULL;
|
||||||
char *name = twc_get_peer_name_nt(profile->tox, group_number, peer_number);
|
int i, npeers;
|
||||||
char *prev_name = NULL;
|
TOX_ERR_CONFERENCE_PEER_QUERY err = TOX_ERR_CONFERENCE_PEER_QUERY_OK;
|
||||||
|
|
||||||
if (change_type == TOX_CONFERENCE_STATE_CHANGE_PEER_EXIT
|
struct t_weelist *new_nicks;
|
||||||
|| change_type == TOX_CONFERENCE_STATE_CHANGE_PEER_NAME_CHANGE)
|
struct t_weelist_item *n;
|
||||||
|
|
||||||
|
npeers = tox_conference_peer_count(profile->tox, group_number, &err);
|
||||||
|
|
||||||
|
if (err == TOX_ERR_CONFERENCE_PEER_QUERY_OK)
|
||||||
{
|
{
|
||||||
nick = weechat_hashtable_get(chat->nicks, &peer_number);
|
new_nicks = weechat_list_new();
|
||||||
if (nick)
|
for (i = 0; i < npeers; i++)
|
||||||
{
|
{
|
||||||
prev_name = strdup(weechat_nicklist_nick_get_string(chat->buffer,
|
char *name = twc_get_peer_name_nt(profile->tox, group_number, i);
|
||||||
nick, "name"));
|
weechat_list_add(new_nicks, name, WEECHAT_LIST_POS_SORT, NULL);
|
||||||
|
free(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return;
|
||||||
|
|
||||||
|
// searching for exits
|
||||||
|
n = weechat_list_get(chat->nicks, 0);
|
||||||
|
|
||||||
|
while (n)
|
||||||
|
{
|
||||||
|
const char *name = weechat_list_string(n);
|
||||||
|
if (!weechat_list_search(new_nicks, name))
|
||||||
|
{
|
||||||
|
weechat_printf(chat->buffer, "%s%s just left the group chat",
|
||||||
|
weechat_prefix("quit"), name);
|
||||||
|
nick = weechat_nicklist_search_nick(chat->buffer,
|
||||||
|
chat->nicklist_group,
|
||||||
|
name);
|
||||||
weechat_nicklist_remove_nick(chat->buffer, nick);
|
weechat_nicklist_remove_nick(chat->buffer, nick);
|
||||||
weechat_hashtable_remove(chat->nicks, &peer_number);
|
|
||||||
}
|
}
|
||||||
|
n = weechat_list_next(n);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (change_type == TOX_CONFERENCE_STATE_CHANGE_PEER_JOIN
|
// searching for joins
|
||||||
|| change_type == TOX_CONFERENCE_STATE_CHANGE_PEER_NAME_CHANGE)
|
n = weechat_list_get(new_nicks, 0);
|
||||||
{
|
|
||||||
nick = weechat_nicklist_add_nick(chat->buffer, chat->nicklist_group,
|
|
||||||
name, NULL, NULL, NULL, 1);
|
|
||||||
if (nick)
|
|
||||||
weechat_hashtable_set(chat->nicks, &peer_number, nick);
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (change_type)
|
while (n)
|
||||||
|
{
|
||||||
|
const char *name = weechat_list_string(n);
|
||||||
|
if (!weechat_list_search(chat->nicks, name))
|
||||||
{
|
{
|
||||||
case TOX_CONFERENCE_STATE_CHANGE_PEER_NAME_CHANGE:
|
|
||||||
if (prev_name && name)
|
|
||||||
weechat_printf(chat->buffer, "%s%s is now known as %s",
|
|
||||||
weechat_prefix("network"), prev_name, name);
|
|
||||||
break;
|
|
||||||
case TOX_CONFERENCE_STATE_CHANGE_PEER_JOIN:
|
|
||||||
if (name)
|
|
||||||
weechat_printf(chat->buffer, "%s%s just joined the group chat",
|
weechat_printf(chat->buffer, "%s%s just joined the group chat",
|
||||||
weechat_prefix("join"), name);
|
weechat_prefix("join"), name);
|
||||||
break;
|
weechat_nicklist_add_nick(chat->buffer, chat->nicklist_group,
|
||||||
case TOX_CONFERENCE_STATE_CHANGE_PEER_EXIT:
|
name, NULL, NULL, NULL, 1);
|
||||||
if (prev_name)
|
}
|
||||||
weechat_printf(chat->buffer, "%s%s just left the group chat",
|
n = weechat_list_next(n);
|
||||||
weechat_prefix("quit"), prev_name);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prev_name)
|
weechat_list_remove_all(chat->nicks);
|
||||||
free(prev_name);
|
weechat_list_free(chat->nicks);
|
||||||
|
chat->nicks = new_nicks;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Reference in a new issue