1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Split connection_free_resources

This commit is contained in:
James Booth 2013-02-27 20:54:38 +00:00
parent 8d1cc96bf2
commit 2ecf20195c

View File

@ -85,7 +85,10 @@ static void _connection_handler(xmpp_conn_t * const conn,
xmpp_stream_error_t * const stream_error, void * const userdata); xmpp_stream_error_t * const stream_error, void * const userdata);
static int _ping_timed_handler(xmpp_conn_t * const conn, void * const userdata); static int _ping_timed_handler(xmpp_conn_t * const conn, void * const userdata);
void _connection_free_resources(void); void _connection_free_saved_account(void);
void _connection_free_saved_details(void);
void _connection_free_session_data(void);
void _connection_shutdown(void);
void void
jabber_init(const int disable_tls) jabber_init(const int disable_tls)
@ -165,7 +168,10 @@ jabber_disconnect(void)
while (jabber_get_connection_status() == JABBER_DISCONNECTING) { while (jabber_get_connection_status() == JABBER_DISCONNECTING) {
jabber_process_events(); jabber_process_events();
} }
_connection_free_resources(); _connection_free_saved_account();
_connection_free_saved_details();
_connection_free_session_data();
_connection_shutdown();
} }
jabber_conn.conn_status = JABBER_STARTED; jabber_conn.conn_status = JABBER_STARTED;
@ -277,17 +283,32 @@ connection_remove_available_resource(const char * const resource)
} }
void void
_connection_free_resources(void) _connection_free_saved_account(void)
{
FREE_SET_NULL(saved_account.name);
FREE_SET_NULL(saved_account.passwd);
}
void
_connection_free_saved_details(void)
{ {
FREE_SET_NULL(saved_details.name); FREE_SET_NULL(saved_details.name);
FREE_SET_NULL(saved_details.jid); FREE_SET_NULL(saved_details.jid);
FREE_SET_NULL(saved_details.passwd); FREE_SET_NULL(saved_details.passwd);
FREE_SET_NULL(saved_details.altdomain); FREE_SET_NULL(saved_details.altdomain);
FREE_SET_NULL(saved_account.name); }
FREE_SET_NULL(saved_account.passwd);
void
_connection_free_session_data(void)
{
g_hash_table_remove_all(available_resources); g_hash_table_remove_all(available_resources);
chat_sessions_clear(); chat_sessions_clear();
presence_free_sub_requests(); presence_free_sub_requests();
}
void
_connection_shutdown(void)
{
xmpp_conn_release(jabber_conn.conn); xmpp_conn_release(jabber_conn.conn);
xmpp_ctx_free(jabber_conn.ctx); xmpp_ctx_free(jabber_conn.ctx);
xmpp_shutdown(); xmpp_shutdown();
@ -458,7 +479,10 @@ _connection_handler(xmpp_conn_t * const conn,
reconnect_timer = g_timer_new(); reconnect_timer = g_timer_new();
// TODO: free resources but leave saved_user untouched // TODO: free resources but leave saved_user untouched
} else { } else {
_connection_free_resources(); _connection_free_saved_account();
_connection_free_saved_details();
_connection_free_session_data();
_connection_shutdown();
} }
// login attempt failed // login attempt failed
@ -467,7 +491,10 @@ _connection_handler(xmpp_conn_t * const conn,
if (reconnect_timer == NULL) { if (reconnect_timer == NULL) {
log_debug("Connection handler: No reconnect timer"); log_debug("Connection handler: No reconnect timer");
prof_handle_failed_login(); prof_handle_failed_login();
_connection_free_resources(); _connection_free_saved_account();
_connection_free_saved_details();
_connection_free_session_data();
_connection_shutdown();
} else { } else {
log_debug("Connection handler: Restarting reconnect timer"); log_debug("Connection handler: Restarting reconnect timer");
if (prefs_get_reconnect() != 0) { if (prefs_get_reconnect() != 0) {