From 4b5e2381e1cec47a6cc6807cf7bb9be86bc4b63e Mon Sep 17 00:00:00 2001 From: Yann Leboulanger Date: Mon, 18 Apr 2005 09:18:50 +0000 Subject: [PATCH] delete the connection when we go offline --- src/common/connection.py | 8 +++++--- src/gajim.py | 2 +- src/roster_window.py | 1 - 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/src/common/connection.py b/src/common/connection.py index c8d7b5d08..eb1736a30 100644 --- a/src/common/connection.py +++ b/src/common/connection.py @@ -276,6 +276,7 @@ class connection: if self.connection: self.connected = 0 self.dispatch('STATUS', 'offline') + self.connection = None # END disconenctedCB def _rosterSetCB(self, con, iq_obj): @@ -378,7 +379,6 @@ class connection: def connect(self): """Connect and authentificate to the Jabber server""" - self.connected = 1 name = gajim.config.get_per('accounts', self.name, 'name') hostname = gajim.config.get_per('accounts', self.name, 'hostname') resource = gajim.config.get_per('accounts', self.name, 'resource') @@ -386,6 +386,7 @@ class connection: #create connexion if it doesn't already existe if self.connection: return self.connection + self.connected = 1 if gajim.config.get_per('accounts', self.name, 'use_proxy'): proxy = {'host': gajim.config.get_per('accounts', self.name, \ 'proxyhost')} @@ -505,6 +506,7 @@ class connection: self.connected = 0 self.connection.disconnect(msg) self.dispatch('STATUS', 'offline') + self.connection = None elif status != 'offline' and self.connected: self.connected = STATUS_LIST.index(status) ptype = 'available' @@ -756,9 +758,9 @@ class connection: iq.setID(id) self.connection.send(iq) - def process(self): + def process(self, timeout): if not self.connection: return if self.connected: - self.connection.process(1) + self.connection.process(timeout) # END GajimCore diff --git a/src/gajim.py b/src/gajim.py index b60b7fa9e..3182b1fc7 100644 --- a/src/gajim.py +++ b/src/gajim.py @@ -683,7 +683,7 @@ class interface: def process_connections(self): for account in gajim.connections: if gajim.connections[account].connected: - gajim.connections[account].connection.process(0.01) + gajim.connections[account].process(0.01) return True def save_config(self): diff --git a/src/roster_window.py b/src/roster_window.py index aef87a735..9e479aefa 100644 --- a/src/roster_window.py +++ b/src/roster_window.py @@ -698,7 +698,6 @@ class Roster_window: if self.plugin.systray_enabled: self.plugin.systray.set_status('connecting') - save_pass = 0 save_pass = gajim.config.get_per('accounts', account, 'savepass') if not save_pass and gajim.connections[account].connected < 2: passphrase = ''