diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/room_chat.c | 105 |
1 files changed, 97 insertions, 8 deletions
diff --git a/src/room_chat.c b/src/room_chat.c index c50eb80b..4a4b7577 100644 --- a/src/room_chat.c +++ b/src/room_chat.c @@ -29,8 +29,8 @@ #include "prof_autocomplete.h" typedef struct _muc_room_t { - char *room; - char *nick; + char *room; // e.g. test@conference.server + char *nick; // e.g. Some User char *subject; gboolean pending_nick_change; GHashTable *roster; @@ -43,6 +43,9 @@ GHashTable *rooms = NULL; static void _room_free(muc_room *room); +/* + * Join the chat room with the specified nickname + */ void room_join(const char * const room, const char * const nick) { @@ -65,6 +68,19 @@ room_join(const char * const room, const char * const nick) g_hash_table_insert(rooms, strdup(room), new_room); } +/* + * Leave the room + */ +void +room_leave(const char * const room) +{ + g_hash_table_remove(rooms, room); +} + +/* + * Flag that the user has sent a nick change to the service + * and is awaiting the response + */ void room_set_pending_nick_change(const char * const room) { @@ -75,6 +91,10 @@ room_set_pending_nick_change(const char * const room) } } +/* + * Returns TRUE if the room is awaiting the result of a + * nick change + */ gboolean room_is_pending_nick_change(const char * const room) { @@ -87,6 +107,10 @@ room_is_pending_nick_change(const char * const room) } } +/* + * Change the current nuck name for the room, call once + * the service has responded + */ void room_change_nick(const char * const room, const char * const nick) { @@ -99,12 +123,9 @@ room_change_nick(const char * const room, const char * const nick) } } -void -room_leave(const char * const room) -{ - g_hash_table_remove(rooms, room); -} - +/* + * Returns TRUE if the user is currently in the room + */ gboolean room_is_active(const char * const full_room_jid) { @@ -124,6 +145,11 @@ room_is_active(const char * const full_room_jid) } } +/* + * Return a list of room names + * The contents of the list are owned by the chat room and should not be + * modified or freed. + */ GList * room_get_rooms(void) { @@ -134,6 +160,10 @@ room_get_rooms(void) } } +/* + * Return current users nickname for the specified room + * The nickname is owned by the chat room and should not be modified or freed + */ char * room_get_nick_for_room(const char * const room) { @@ -150,6 +180,11 @@ room_get_nick_for_room(const char * const room) } } +/* + * Get the room name part of the full JID, e.g. + * Full JID = "test@conference.server/person" + * returns "test@conference.server" + */ char * room_get_room_from_full_jid(const char * const full_room_jid) { @@ -167,6 +202,10 @@ room_get_room_from_full_jid(const char * const full_room_jid) } } +/* + * Returns TRUE if the JID is a room JID + * The test is that the passed JID does not contain a "/" + */ gboolean room_from_jid_is_room(const char * const room_jid) { @@ -174,6 +213,11 @@ room_from_jid_is_room(const char * const room_jid) return (result == NULL); } +/* + * Get the nickname part of the full JID, e.g. + * Full JID = "test@conference.server/person" + * returns "person" + */ char * room_get_nick_from_full_jid(const char * const full_room_jid) { @@ -191,6 +235,11 @@ room_get_nick_from_full_jid(const char * const full_room_jid) } } +/* + * Given a room name, and a nick name create and return a full JID of the form + * room@server/nick + * Will return a newly created string that must be freed by the caller + */ char * room_create_full_room_jid(const char * const room, const char * const nick) { @@ -205,6 +254,14 @@ room_create_full_room_jid(const char * const room, const char * const nick) return result; } +/* + * Given a full room JID of the form + * room@server/nick + * Will create two new strings and point room and nick to them e.g. + * *room = "room@server", *nick = "nick" + * The strings must be freed by the caller + * Returns TRUE if the JID was parsed successfully, FALSE otherwise + */ gboolean room_parse_room_jid(const char * const full_room_jid, char **room, char **nick) { @@ -222,6 +279,9 @@ room_parse_room_jid(const char * const full_room_jid, char **room, char **nick) } } +/* + * Returns TRUE if the specified nick exists in the room's roster + */ gboolean room_nick_in_roster(const char * const room, const char * const nick) { @@ -239,6 +299,9 @@ room_nick_in_roster(const char * const room, const char * const nick) return FALSE; } +/* + * Add a new chat room member to the room's roster + */ gboolean room_add_to_roster(const char * const room, const char * const nick, const char * const show, const char * const status) @@ -264,6 +327,9 @@ room_add_to_roster(const char * const room, const char * const nick, return updated; } +/* + * Remove a room member from the room's roster + */ void room_remove_from_roster(const char * const room, const char * const nick) { @@ -275,6 +341,10 @@ room_remove_from_roster(const char * const room, const char * const nick) } } +/* + * Return a list of PContacts representing the room members in the room's roster + * The list is owned by the room and must not be mofified or freed + */ GList * room_get_roster(const char * const room) { @@ -287,6 +357,9 @@ room_get_roster(const char * const room) } } +/* + * Return a PAutocomplete representing the room member's in the roster + */ PAutocomplete room_get_nick_ac(const char * const room) { @@ -299,6 +372,9 @@ room_get_nick_ac(const char * const room) } } +/* + * Set to TRUE when the rooms roster has been fully recieved + */ void room_set_roster_received(const char * const room) { @@ -309,6 +385,9 @@ room_set_roster_received(const char * const room) } } +/* + * Returns TRUE id the rooms roster has been fully recieved + */ gboolean room_get_roster_received(const char * const room) { @@ -321,6 +400,10 @@ room_get_roster_received(const char * const room) } } +/* + * Remove the old_nick from the roster, and flag that a pending nickname change + * is in progress + */ void room_add_pending_nick_change(const char * const room, const char * const new_nick, const char * const old_nick) @@ -333,6 +416,12 @@ room_add_pending_nick_change(const char * const room, } } +/* + * Complete the pending nick name change for a contact in the room's roster + * The new nick name will be added to the roster + * The old nick name will be returned in a new string which must be freed by + * the caller + */ char * room_complete_pending_nick_change(const char * const room, const char * const nick) |