about summary refs log tree commit diff stats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/command.c4
-rw-r--r--src/jabber.c27
-rw-r--r--src/profanity.c5
3 files changed, 25 insertions, 11 deletions
diff --git a/src/command.c b/src/command.c
index a34f6faa..15424362 100644
--- a/src/command.c
+++ b/src/command.c
@@ -494,7 +494,9 @@ _cmd_connect(const char * const inp, struct cmd_help_t help)
 static gboolean
 _cmd_quit(const char * const inp, struct cmd_help_t help)
 {
-    return FALSE;
+    log_info("Profanity is shutting down.");
+    jabber_disconnect();
+    return TRUE;
 }
 
 static gboolean
diff --git a/src/jabber.c b/src/jabber.c
index 3af7f203..fc76e0e4 100644
--- a/src/jabber.c
+++ b/src/jabber.c
@@ -162,11 +162,9 @@ jabber_disconnect(void)
 {
     if (jabber_conn.conn_status == JABBER_CONNECTED) {
         log_info("Closing connection");
-        xmpp_conn_release(jabber_conn.conn);
-        xmpp_ctx_free(jabber_conn.ctx);
-        xmpp_shutdown();
-        jabber_conn.conn_status = JABBER_DISCONNECTED;
-        jabber_conn.presence = PRESENCE_OFFLINE;
+
+        // attempt closing the XML stream
+        xmpp_disconnect(jabber_conn.conn);
     }
 }
 
@@ -382,6 +380,25 @@ _jabber_conn_handler(xmpp_conn_t * const conn,
         jabber_conn.conn_status = JABBER_DISCONNECTED;
         jabber_conn.presence = PRESENCE_OFFLINE;
     }
+/* TO DO IF END STREAM
+
+
+    // free memory for connection object and context
+    xmpp_conn_release(jabber_conn.conn);
+    xmpp_ctx_free(jabber_conn.ctx);
+
+    // shutdown libstrophe
+    xmpp_shutdown();
+
+    jabber_conn.conn_status = JABBER_DISCONNECTED;
+    jabber_conn.presence = PRESENCE_OFFLINE;
+    
+    gui_close();
+    chat_log_close();
+    prefs_close();
+    log_info("Shutdown complete");
+    log_close();
+*/
 }
 
 static int
diff --git a/src/profanity.c b/src/profanity.c
index 48f20e6c..88792f86 100644
--- a/src/profanity.c
+++ b/src/profanity.c
@@ -93,11 +93,6 @@ _profanity_shutdown(void)
 {
     log_info("Profanity is shutting down.");
     jabber_disconnect();
-    gui_close();
-    chat_log_close();
-    prefs_close();
-    log_info("Shutdown complete");
-    log_close();
 }
 
 static log_level_t