# HG changeset patch # User souliane # Date 1427293551 -3600 # Node ID 50d5d6325f627310c3e114cc782cd8431854e527 # Parent c7082457d03f770b2f8eae797ff2309f47028157 quick_frontend, primitivus: various fixes (MUC and cached signals): - actually call the cached signals, everything was there but the call was not done - display '[]' instead of '[None]' when group message coming from the room (no resource) - catch the exception when trying to delete an occupant who's not in the room - do not cache a "main resource" for MUC entities diff -r c7082457d03f -r 50d5d6325f62 frontends/src/primitivus/chat.py --- a/frontends/src/primitivus/chat.py Wed Mar 25 15:28:02 2015 +0100 +++ b/frontends/src/primitivus/chat.py Wed Mar 25 15:25:51 2015 +0100 @@ -73,7 +73,7 @@ if self.parent.show_short_nick: render_txt.append(('my_nick' if self.my_mess else 'other_nick', "**" if self.my_mess else "*")) else: - render_txt.append(('my_nick' if self.my_mess else 'other_nick', "[%s] " % self.nick)) + render_txt.append(('my_nick' if self.my_mess else 'other_nick', "[%s] " % (self.nick or ''))) render_txt.append(self.message) txt_widget = urwid.Text(render_txt, align=self.align) if self.is_info: @@ -188,7 +188,10 @@ nick = entity.resource show = contact_list.getCache(entity, C.PRESENCE_SHOW) if show == C.PRESENCE_UNAVAILABLE or show is None: - self.occupants_list.deleteValue(nick) + try: + self.occupants_list.deleteValue(nick) + except ValueError: + pass else: values = self.occupants_list.getAllValues() markup = self._buildOccupantMarkup(entity) diff -r c7082457d03f -r 50d5d6325f62 frontends/src/quick_frontend/quick_app.py --- a/frontends/src/quick_frontend/quick_app.py Wed Mar 25 15:28:02 2015 +0100 +++ b/frontends/src/quick_frontend/quick_app.py Wed Mar 25 15:25:51 2015 +0100 @@ -388,6 +388,7 @@ cached_signals = self.signals_cache.pop(profile, []) for function_name, handler, args, kwargs in cached_signals: log.debug(u"Calling cached signal [%s] with args %s and kwargs %s" % (function_name, args, kwargs)) + handler(*args, **kwargs) self.callListeners('profilePlugged', profile=profile) diff -r c7082457d03f -r 50d5d6325f62 frontends/src/quick_frontend/quick_contact_list.py --- a/frontends/src/quick_frontend/quick_contact_list.py Wed Mar 25 15:28:02 2015 +0100 +++ b/frontends/src/quick_frontend/quick_contact_list.py Wed Mar 25 15:25:51 2015 +0100 @@ -296,6 +296,7 @@ self._specials.remove(entity_bare) else: self._specials.add(entity_bare) + cache[C.CONTACT_MAIN_RESOURCE] = None # now the attribute we keep in cache for attribute, value in attributes.iteritems(): @@ -401,8 +402,9 @@ resource_data[C.PRESENCE_PRIORITY] = int(priority) resource_data[C.PRESENCE_STATUSES] = statuses - priority_resource = max(resources_data, key=lambda res: resources_data[res][C.PRESENCE_PRIORITY]) - cache[C.CONTACT_MAIN_RESOURCE] = priority_resource + if entity.bare not in self._specials: + priority_resource = max(resources_data, key=lambda res: resources_data[res][C.PRESENCE_PRIORITY]) + cache[C.CONTACT_MAIN_RESOURCE] = priority_resource self.update() def onNickUpdate(self, entity, new_nick, profile):