Welcome to mirror list, hosted at ThFree Co, Russian Federation.

dev.gajim.org/gajim/gajim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorYann Leboulanger <asterix@lagaule.org>2008-05-20 18:18:12 +0400
committerYann Leboulanger <asterix@lagaule.org>2008-05-20 18:18:12 +0400
commit8bda3a554389ad55f4aa1e65e8c5b7355baa6541 (patch)
treed3a0cd34a0226f52ba2b5dd427bb86f270080f06 /src
parente2f98ad2e086b36ab218159740a36cdacb804024 (diff)
upadte all contact instances when we get a pep event for a contact. See #3953
Diffstat (limited to 'src')
-rw-r--r--src/common/pep.py150
1 files changed, 71 insertions, 79 deletions
diff --git a/src/common/pep.py b/src/common/pep.py
index 29d3be090..32b328d4f 100644
--- a/src/common/pep.py
+++ b/src/common/pep.py
@@ -35,23 +35,21 @@ def user_mood(items, name, jid):
del acc.mood['text']
(user, resource) = gajim.get_room_and_nick_from_fjid(jid)
- contact = gajim.contacts.get_contact(name, user, resource=resource)
- if not contact:
- return
- if has_child:
- if contact.mood.has_key('mood'):
- del contact.mood['mood']
- if contact.mood.has_key('text'):
- del contact.mood['text']
- if mood is not None:
- contact.mood['mood'] = mood
- if text is not None:
- contact.mood['text'] = text
- elif retract:
- if contact.mood.has_key('mood'):
- del contact.mood['mood']
- if contact.mood.has_key('text'):
- del contact.mood['text']
+ for contact in gajim.contacts.get_contacts(name, user)
+ if has_child:
+ if contact.mood.has_key('mood'):
+ del contact.mood['mood']
+ if contact.mood.has_key('text'):
+ del contact.mood['text']
+ if mood is not None:
+ contact.mood['mood'] = mood
+ if text is not None:
+ contact.mood['text'] = text
+ elif retract:
+ if contact.mood.has_key('mood'):
+ del contact.mood['mood']
+ if contact.mood.has_key('text'):
+ del contact.mood['text']
def user_tune(items, name, jid):
has_child = False
@@ -116,41 +114,39 @@ def user_tune(items, name, jid):
del acc.tune['length']
(user, resource) = gajim.get_room_and_nick_from_fjid(jid)
- contact = gajim.contacts.get_contact(name, user, resource=resource)
- if not contact:
- return
- if has_child:
- if contact.tune.has_key('artist'):
- del contact.tune['artist']
- if contact.tune.has_key('title'):
- del contact.tune['title']
- if contact.tune.has_key('source'):
- del contact.tune['source']
- if contact.tune.has_key('track'):
- del contact.tune['track']
- if contact.tune.has_key('length'):
- del contact.tune['length']
- if artist is not None:
- contact.tune['artist'] = artist
- if title is not None:
- contact.tune['title'] = title
- if source is not None:
- contact.tune['source'] = source
- if track is not None:
- contact.tune['track'] = track
- if length is not None:
- contact.tune['length'] = length
- elif retract:
- if contact.tune.has_key('artist'):
- del contact.tune['artist']
- if contact.tune.has_key('title'):
- del contact.tune['title']
- if contact.tune.has_key('source'):
- del contact.tune['source']
- if contact.tune.has_key('track'):
- del contact.tune['track']
- if contact.tune.has_key('length'):
- del contact.tune['length']
+ for contact in gajim.contacts.get_contacts(name, user)
+ if has_child:
+ if contact.tune.has_key('artist'):
+ del contact.tune['artist']
+ if contact.tune.has_key('title'):
+ del contact.tune['title']
+ if contact.tune.has_key('source'):
+ del contact.tune['source']
+ if contact.tune.has_key('track'):
+ del contact.tune['track']
+ if contact.tune.has_key('length'):
+ del contact.tune['length']
+ if artist is not None:
+ contact.tune['artist'] = artist
+ if title is not None:
+ contact.tune['title'] = title
+ if source is not None:
+ contact.tune['source'] = source
+ if track is not None:
+ contact.tune['track'] = track
+ if length is not None:
+ contact.tune['length'] = length
+ elif retract:
+ if contact.tune.has_key('artist'):
+ del contact.tune['artist']
+ if contact.tune.has_key('title'):
+ del contact.tune['title']
+ if contact.tune.has_key('source'):
+ del contact.tune['source']
+ if contact.tune.has_key('track'):
+ del contact.tune['track']
+ if contact.tune.has_key('length'):
+ del contact.tune['length']
def user_geoloc(items, name, jid):
pass
@@ -200,29 +196,27 @@ def user_activity(items, name, jid):
del acc.activity['text']
(user, resource) = gajim.get_room_and_nick_from_fjid(jid)
- contact = gajim.contacts.get_contact(name, user, resource=resource)
- if not contact:
- return
- if has_child:
- if contact.activity.has_key('activity'):
- del contact.activity['activity']
- if contact.activity.has_key('subactivity'):
- del contact.activity['subactivity']
- if contact.activity.has_key('text'):
- del contact.activity['text']
- if activity is not None:
- contact.activity['activity'] = activity
- if subactivity is not None:
- contact.activity['subactivity'] = subactivity
- if text is not None:
- contact.activity['text'] = text
- elif retract:
- if contact.activity.has_key('activity'):
- del contact.activity['activity']
- if contact.activity.has_key('subactivity'):
- del contact.activity['subactivity']
- if contact.activity.has_key('text'):
- del contact.activity['text']
+ for contact in gajim.contacts.get_contacts(name, user)
+ if has_child:
+ if contact.activity.has_key('activity'):
+ del contact.activity['activity']
+ if contact.activity.has_key('subactivity'):
+ del contact.activity['subactivity']
+ if contact.activity.has_key('text'):
+ del contact.activity['text']
+ if activity is not None:
+ contact.activity['activity'] = activity
+ if subactivity is not None:
+ contact.activity['subactivity'] = subactivity
+ if text is not None:
+ contact.activity['text'] = text
+ elif retract:
+ if contact.activity.has_key('activity'):
+ del contact.activity['activity']
+ if contact.activity.has_key('subactivity'):
+ del contact.activity['subactivity']
+ if contact.activity.has_key('text'):
+ del contact.activity['text']
def user_nickname(items, name, jid):
has_child = False
@@ -246,12 +240,10 @@ def user_nickname(items, name, jid):
gajim.nicks[name] = gajim.config.get_per('accounts', name, 'name')
(user, resource) = gajim.get_room_and_nick_from_fjid(jid)
- contact = gajim.contacts.get_contact(name, user, resource=resource)
- if not contact:
- return
if has_child:
if nick is not None:
- contact.contact_name = nick
+ for contact in gajim.contacts.get_contacts(name, user)
+ contact.contact_name = nick
gajim.interface.roster.draw_contact(user, name)
for ctrl in gajim.interface.msg_win_mgr.get_chat_controls(user, name):
ctrl.update_ui()