mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Tidied muc.c
This commit is contained in:
parent
0b2a1a1bc7
commit
70169f8ab9
173
src/muc.c
173
src/muc.c
@ -75,7 +75,7 @@ void
|
|||||||
muc_close(void)
|
muc_close(void)
|
||||||
{
|
{
|
||||||
autocomplete_free(invite_ac);
|
autocomplete_free(invite_ac);
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
g_hash_table_destroy(rooms);
|
g_hash_table_destroy(rooms);
|
||||||
rooms = NULL;
|
rooms = NULL;
|
||||||
}
|
}
|
||||||
@ -110,7 +110,7 @@ muc_invites_include(const char * const room)
|
|||||||
{
|
{
|
||||||
GSList *invites = autocomplete_create_list(invite_ac);
|
GSList *invites = autocomplete_create_list(invite_ac);
|
||||||
GSList *curr = invites;
|
GSList *curr = invites;
|
||||||
while (curr != NULL) {
|
while (curr) {
|
||||||
if (strcmp(curr->data, room) == 0) {
|
if (strcmp(curr->data, room) == 0) {
|
||||||
g_slist_free_full(invites, g_free);
|
g_slist_free_full(invites, g_free);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -119,6 +119,7 @@ muc_invites_include(const char * const room)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
g_slist_free_full(invites, g_free);
|
g_slist_free_full(invites, g_free);
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,14 +141,11 @@ muc_clear_invites(void)
|
|||||||
autocomplete_clear(invite_ac);
|
autocomplete_clear(invite_ac);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Join the chat room with the specified nickname
|
|
||||||
*/
|
|
||||||
void
|
void
|
||||||
muc_join_room(const char * const room, const char * const nick,
|
muc_join_room(const char * const room, const char * const nick,
|
||||||
const char * const password, gboolean autojoin)
|
const char * const password, gboolean autojoin)
|
||||||
{
|
{
|
||||||
if (rooms == NULL) {
|
if (!rooms) {
|
||||||
rooms = g_hash_table_new_full(g_str_hash, g_str_equal, g_free,
|
rooms = g_hash_table_new_full(g_str_hash, g_str_equal, g_free,
|
||||||
(GDestroyNotify)_free_room);
|
(GDestroyNotify)_free_room);
|
||||||
}
|
}
|
||||||
@ -156,7 +154,7 @@ muc_join_room(const char * const room, const char * const nick,
|
|||||||
new_room->room = strdup(room);
|
new_room->room = strdup(room);
|
||||||
new_room->nick = strdup(nick);
|
new_room->nick = strdup(nick);
|
||||||
new_room->autocomplete_prefix = NULL;
|
new_room->autocomplete_prefix = NULL;
|
||||||
if (password != NULL) {
|
if (password) {
|
||||||
new_room->password = strdup(password);
|
new_room->password = strdup(password);
|
||||||
} else {
|
} else {
|
||||||
new_room->password = NULL;
|
new_room->password = NULL;
|
||||||
@ -176,13 +174,10 @@ muc_join_room(const char * const room, const char * const nick,
|
|||||||
g_hash_table_insert(rooms, strdup(room), new_room);
|
g_hash_table_insert(rooms, strdup(room), new_room);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Leave the room
|
|
||||||
*/
|
|
||||||
void
|
void
|
||||||
muc_leave_room(const char * const room)
|
muc_leave_room(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
g_hash_table_remove(rooms, room);
|
g_hash_table_remove(rooms, room);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -190,13 +185,12 @@ muc_leave_room(const char * const room)
|
|||||||
gboolean
|
gboolean
|
||||||
muc_requires_config(const char * const room)
|
muc_requires_config(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms == NULL) {
|
if (!rooms) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (!chat_room) {
|
||||||
if (chat_room == NULL) {
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -206,17 +200,17 @@ muc_requires_config(const char * const room)
|
|||||||
void
|
void
|
||||||
muc_set_requires_config(const char * const room, gboolean val)
|
muc_set_requires_config(const char * const room, gboolean val)
|
||||||
{
|
{
|
||||||
if (rooms == NULL) {
|
if (!rooms) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (!chat_room) {
|
||||||
if (chat_room == NULL) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
chat_room->pending_config = val;
|
chat_room->pending_config = val;
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -226,14 +220,9 @@ muc_set_requires_config(const char * const room, gboolean val)
|
|||||||
gboolean
|
gboolean
|
||||||
muc_room_is_active(const char * const room)
|
muc_room_is_active(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
return (chat_room != NULL);
|
||||||
if (chat_room != NULL) {
|
|
||||||
return TRUE;
|
|
||||||
} else {
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@ -242,29 +231,23 @@ muc_room_is_active(const char * const room)
|
|||||||
gboolean
|
gboolean
|
||||||
muc_room_is_autojoin(const char * const room)
|
muc_room_is_autojoin(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
return chat_room->autojoin;
|
return chat_room->autojoin;
|
||||||
} else {
|
|
||||||
return FALSE;
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return FALSE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
muc_set_subject(const char * const room, const char * const subject)
|
muc_set_subject(const char * const room, const char * const subject)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
if (chat_room->subject != NULL) {
|
|
||||||
free(chat_room->subject);
|
free(chat_room->subject);
|
||||||
}
|
|
||||||
chat_room->subject = strdup(subject);
|
chat_room->subject = strdup(subject);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -273,26 +256,22 @@ muc_set_subject(const char * const room, const char * const subject)
|
|||||||
char *
|
char *
|
||||||
muc_get_subject(const char * const room)
|
muc_get_subject(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
return chat_room->subject;
|
return chat_room->subject;
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
muc_add_pending_broadcast(const char * const room, const char * const message)
|
muc_add_pending_broadcast(const char * const room, const char * const message)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
chat_room->pending_broadcasts = g_list_append(chat_room->pending_broadcasts, strdup(message));
|
chat_room->pending_broadcasts = g_list_append(chat_room->pending_broadcasts, strdup(message));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -301,17 +280,14 @@ muc_add_pending_broadcast(const char * const room, const char * const message)
|
|||||||
GList *
|
GList *
|
||||||
muc_get_pending_broadcasts(const char * const room)
|
muc_get_pending_broadcasts(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
return chat_room->pending_broadcasts;
|
return chat_room->pending_broadcasts;
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *
|
char *
|
||||||
@ -319,7 +295,7 @@ muc_get_old_nick(const char * const room, const char * const new_nick)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if ((chat_room != NULL) && (chat_room->pending_nick_change)) {
|
if (chat_room && chat_room->pending_nick_change) {
|
||||||
return g_hash_table_lookup(chat_room->nick_changes, new_nick);
|
return g_hash_table_lookup(chat_room->nick_changes, new_nick);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -335,7 +311,7 @@ muc_set_room_pending_nick_change(const char * const room, const char * const new
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
chat_room->pending_nick_change = TRUE;
|
chat_room->pending_nick_change = TRUE;
|
||||||
g_hash_table_insert(chat_room->nick_changes, strdup(new_nick), strdup(chat_room->nick));
|
g_hash_table_insert(chat_room->nick_changes, strdup(new_nick), strdup(chat_room->nick));
|
||||||
}
|
}
|
||||||
@ -350,7 +326,7 @@ muc_is_room_pending_nick_change(const char * const room)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
return chat_room->pending_nick_change;
|
return chat_room->pending_nick_change;
|
||||||
} else {
|
} else {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -366,7 +342,7 @@ muc_complete_room_nick_change(const char * const room, const char * const nick)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
free(chat_room->nick);
|
free(chat_room->nick);
|
||||||
chat_room->nick = strdup(nick);
|
chat_room->nick = strdup(nick);
|
||||||
chat_room->pending_nick_change = FALSE;
|
chat_room->pending_nick_change = FALSE;
|
||||||
@ -382,7 +358,7 @@ muc_complete_room_nick_change(const char * const room, const char * const nick)
|
|||||||
GList *
|
GList *
|
||||||
muc_get_active_room_list(void)
|
muc_get_active_room_list(void)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
return g_hash_table_get_keys(rooms);
|
return g_hash_table_get_keys(rooms);
|
||||||
} else {
|
} else {
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -396,17 +372,14 @@ muc_get_active_room_list(void)
|
|||||||
char *
|
char *
|
||||||
muc_get_room_nick(const char * const room)
|
muc_get_room_nick(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
return chat_room->nick;
|
return chat_room->nick;
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -416,17 +389,14 @@ muc_get_room_nick(const char * const room)
|
|||||||
char *
|
char *
|
||||||
muc_get_room_password(const char * const room)
|
muc_get_room_password(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms != NULL) {
|
if (rooms) {
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
if (chat_room) {
|
||||||
if (chat_room != NULL) {
|
|
||||||
return chat_room->password;
|
return chat_room->password;
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -455,16 +425,17 @@ muc_add_to_roster(const char * const room, const char * const nick,
|
|||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
gboolean updated = FALSE;
|
gboolean updated = FALSE;
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
PContact old = g_hash_table_lookup(chat_room->roster, nick);
|
PContact old = g_hash_table_lookup(chat_room->roster, nick);
|
||||||
|
|
||||||
if (old == NULL) {
|
if (!old) {
|
||||||
updated = TRUE;
|
updated = TRUE;
|
||||||
autocomplete_add(chat_room->nick_ac, nick);
|
autocomplete_add(chat_room->nick_ac, nick);
|
||||||
} else if ((g_strcmp0(p_contact_presence(old), show) != 0) ||
|
} else if ((g_strcmp0(p_contact_presence(old), show) != 0) ||
|
||||||
(g_strcmp0(p_contact_status(old), status) != 0)) {
|
(g_strcmp0(p_contact_status(old), status) != 0)) {
|
||||||
updated = TRUE;
|
updated = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
PContact contact = p_contact_new(nick, NULL, NULL, NULL, NULL, FALSE);
|
PContact contact = p_contact_new(nick, NULL, NULL, NULL, NULL, FALSE);
|
||||||
resource_presence_t resource_presence = resource_presence_from_string(show);
|
resource_presence_t resource_presence = resource_presence_from_string(show);
|
||||||
Resource *resource = resource_new(nick, resource_presence, status, 0);
|
Resource *resource = resource_new(nick, resource_presence, status, 0);
|
||||||
@ -483,7 +454,7 @@ muc_remove_from_roster(const char * const room, const char * const nick)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
g_hash_table_remove(chat_room->roster, nick);
|
g_hash_table_remove(chat_room->roster, nick);
|
||||||
autocomplete_remove(chat_room->nick_ac, nick);
|
autocomplete_remove(chat_room->nick_ac, nick);
|
||||||
}
|
}
|
||||||
@ -494,7 +465,7 @@ muc_get_participant(const char * const room, const char * const nick)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
PContact participant = g_hash_table_lookup(chat_room->roster, nick);
|
PContact participant = g_hash_table_lookup(chat_room->roster, nick);
|
||||||
return participant;
|
return participant;
|
||||||
}
|
}
|
||||||
@ -511,7 +482,7 @@ muc_get_roster(const char * const room)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
GList *result = NULL;
|
GList *result = NULL;
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
gpointer key;
|
gpointer key;
|
||||||
@ -536,7 +507,7 @@ muc_get_roster_ac(const char * const room)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
return chat_room->nick_ac;
|
return chat_room->nick_ac;
|
||||||
} else {
|
} else {
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -551,7 +522,7 @@ muc_set_roster_received(const char * const room)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
chat_room->roster_received = TRUE;
|
chat_room->roster_received = TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -564,7 +535,7 @@ muc_get_roster_received(const char * const room)
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
return chat_room->roster_received;
|
return chat_room->roster_received;
|
||||||
} else {
|
} else {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -581,7 +552,7 @@ muc_set_roster_pending_nick_change(const char * const room,
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
g_hash_table_insert(chat_room->nick_changes, strdup(new_nick), strdup(old_nick));
|
g_hash_table_insert(chat_room->nick_changes, strdup(new_nick), strdup(old_nick));
|
||||||
muc_remove_from_roster(room, old_nick);
|
muc_remove_from_roster(room, old_nick);
|
||||||
}
|
}
|
||||||
@ -599,9 +570,9 @@ muc_complete_roster_nick_change(const char * const room,
|
|||||||
{
|
{
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room != NULL) {
|
if (chat_room) {
|
||||||
char *old_nick = g_hash_table_lookup(chat_room->nick_changes, nick);
|
char *old_nick = g_hash_table_lookup(chat_room->nick_changes, nick);
|
||||||
if (old_nick != NULL) {
|
if (old_nick) {
|
||||||
char *old_nick_cpy = strdup(old_nick);
|
char *old_nick_cpy = strdup(old_nick);
|
||||||
g_hash_table_remove(chat_room->nick_changes, nick);
|
g_hash_table_remove(chat_room->nick_changes, nick);
|
||||||
|
|
||||||
@ -615,18 +586,18 @@ muc_complete_roster_nick_change(const char * const room,
|
|||||||
void
|
void
|
||||||
muc_autocomplete(char *input, int *size)
|
muc_autocomplete(char *input, int *size)
|
||||||
{
|
{
|
||||||
if (rooms == NULL) {
|
if (!rooms) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *recipient = ui_current_recipient();
|
char *recipient = ui_current_recipient();
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, recipient);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, recipient);
|
||||||
|
|
||||||
if (chat_room == NULL) {
|
if (!chat_room) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (chat_room->nick_ac == NULL) {
|
if (!chat_room->nick_ac) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -634,23 +605,23 @@ muc_autocomplete(char *input, int *size)
|
|||||||
char *search_str = NULL;
|
char *search_str = NULL;
|
||||||
|
|
||||||
gchar *last_space = g_strrstr(input, " ");
|
gchar *last_space = g_strrstr(input, " ");
|
||||||
if (last_space == NULL) {
|
if (!last_space) {
|
||||||
search_str = input;
|
search_str = input;
|
||||||
if (chat_room->autocomplete_prefix == NULL) {
|
if (!chat_room->autocomplete_prefix) {
|
||||||
chat_room->autocomplete_prefix = strdup("");
|
chat_room->autocomplete_prefix = strdup("");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
search_str = last_space+1;
|
search_str = last_space+1;
|
||||||
if (chat_room->autocomplete_prefix == NULL) {
|
if (!chat_room->autocomplete_prefix) {
|
||||||
chat_room->autocomplete_prefix = g_strndup(input, search_str - input);
|
chat_room->autocomplete_prefix = g_strndup(input, search_str - input);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
char *result = autocomplete_complete(chat_room->nick_ac, search_str, FALSE);
|
char *result = autocomplete_complete(chat_room->nick_ac, search_str, FALSE);
|
||||||
if (result != NULL) {
|
if (result) {
|
||||||
GString *replace_with = g_string_new(chat_room->autocomplete_prefix);
|
GString *replace_with = g_string_new(chat_room->autocomplete_prefix);
|
||||||
g_string_append(replace_with, result);
|
g_string_append(replace_with, result);
|
||||||
if (last_space == NULL || (*(last_space+1) == '\0')) {
|
if (!last_space || (*(last_space+1) == '\0')) {
|
||||||
g_string_append(replace_with, ": ");
|
g_string_append(replace_with, ": ");
|
||||||
}
|
}
|
||||||
ui_replace_input(input, replace_with->str, size);
|
ui_replace_input(input, replace_with->str, size);
|
||||||
@ -664,21 +635,21 @@ muc_autocomplete(char *input, int *size)
|
|||||||
void
|
void
|
||||||
muc_reset_autocomplete(const char * const room)
|
muc_reset_autocomplete(const char * const room)
|
||||||
{
|
{
|
||||||
if (rooms == NULL) {
|
if (!rooms) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
ChatRoom *chat_room = g_hash_table_lookup(rooms, room);
|
||||||
|
|
||||||
if (chat_room == NULL) {
|
if (!chat_room) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (chat_room->nick_ac != NULL) {
|
if (chat_room->nick_ac) {
|
||||||
autocomplete_reset(chat_room->nick_ac);
|
autocomplete_reset(chat_room->nick_ac);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (chat_room->autocomplete_prefix != NULL) {
|
if (chat_room->autocomplete_prefix) {
|
||||||
free(chat_room->autocomplete_prefix);
|
free(chat_room->autocomplete_prefix);
|
||||||
chat_room->autocomplete_prefix = NULL;
|
chat_room->autocomplete_prefix = NULL;
|
||||||
}
|
}
|
||||||
@ -687,24 +658,22 @@ muc_reset_autocomplete(const char * const room)
|
|||||||
static void
|
static void
|
||||||
_free_room(ChatRoom *room)
|
_free_room(ChatRoom *room)
|
||||||
{
|
{
|
||||||
if (room != NULL) {
|
if (room) {
|
||||||
free(room->room);
|
free(room->room);
|
||||||
free(room->nick);
|
free(room->nick);
|
||||||
free(room->subject);
|
free(room->subject);
|
||||||
free(room->password);
|
free(room->password);
|
||||||
if (room->autocomplete_prefix != NULL) {
|
|
||||||
free(room->autocomplete_prefix);
|
free(room->autocomplete_prefix);
|
||||||
}
|
if (room->roster) {
|
||||||
if (room->roster != NULL) {
|
|
||||||
g_hash_table_destroy(room->roster);
|
g_hash_table_destroy(room->roster);
|
||||||
}
|
}
|
||||||
if (room->nick_ac != NULL) {
|
if (room->nick_ac) {
|
||||||
autocomplete_free(room->nick_ac);
|
autocomplete_free(room->nick_ac);
|
||||||
}
|
}
|
||||||
if (room->nick_changes != NULL) {
|
if (room->nick_changes) {
|
||||||
g_hash_table_destroy(room->nick_changes);
|
g_hash_table_destroy(room->nick_changes);
|
||||||
}
|
}
|
||||||
if (room->pending_broadcasts != NULL) {
|
if (room->pending_broadcasts) {
|
||||||
g_list_free_full(room->pending_broadcasts, free);
|
g_list_free_full(room->pending_broadcasts, free);
|
||||||
}
|
}
|
||||||
free(room);
|
free(room);
|
||||||
|
Loading…
Reference in New Issue
Block a user