Tracking trunk changes:

Merged revisions 5008-5011 via svnmerge from
svn://svn.gajim.org/gajim/trunk

........
r5008 | asterix | 2006-01-05 12:55:22 -0700 (Thu, 05 Jan 2006) | 2 lines

new_chat must be called with a Contact instance instead of GC_Contact

........
r5009 | asterix | 2006-01-05 12:56:35 -0700 (Thu, 05 Jan 2006) | 2 lines

use new contacts functions in common/gajim.py

........
r5010 | asterix | 2006-01-05 12:59:06 -0700 (Thu, 05 Jan 2006) | 2 lines

get_first_contact_from_jid doesn't return a GC_Contact instance

........
r5011 | asterix | 2006-01-05 12:59:35 -0700 (Thu, 05 Jan 2006) | 2 lines

check correctly if a contact leaves the groupchat

........
This commit is contained in:
Travis Shirk 2006-01-06 02:20:38 +00:00
parent 733549f3b0
commit c4f4da5aef
6 changed files with 33 additions and 27 deletions

View File

@ -310,13 +310,17 @@ class ChatControlBase(MessageControl):
message_buffer.set_text('') # clear message buffer (and tv of course) message_buffer.set_text('') # clear message buffer (and tv of course)
# FIXME GC ONLY # FIXME GC ONLY
# if contact is None: # if contact is None:
# # contact was from pm in MUC, and left the room, or we left the room # # contact was from pm in MUC
# room, nick = gajim.get_room_and_nick_from_fjid(jid) # room, nick = gajim.get_room_and_nick_from_fjid(jid)
# dialogs.ErrorDialog(_('Sending private message failed'), # gc_contact = gajim.contacts.get_gc_contact(self.account, room, nick)
# #in second %s code replaces with nickname # if not gc_contact:
# _('You are no longer in room "%s" or "%s" has left.') % \ # # contact left the room, or we left the room
# (room, nick)).get_response() # dialogs.ErrorDialog(_('Sending private message failed'),
# # #in second %s code replaces with nickname
# _('You are no longer in room "%s" or "%s" has left.') % \
# (room, nick)).get_response()
# return
def save_sent_message(self, message): def save_sent_message(self, message):
#save the message, so user can scroll though the list with key up/down #save the message, so user can scroll though the list with key up/down

View File

@ -187,11 +187,6 @@ class Contacts:
def get_first_contact_from_jid(self, account, jid): def get_first_contact_from_jid(self, account, jid):
if jid in self._contacts[account]: if jid in self._contacts[account]:
return self._contacts[account][jid][0] return self._contacts[account][jid][0]
else: # it's fake jid
room, nick = common.gajim.get_room_and_nick_from_fjid(jid)
if self._gc_contacts[account].has_key(room) and \
nick in self._gc_contacts[account][room]:
return self._gc_contacts[account][room][nick]
return None return None
def get_parent_contact(self, account, contact): def get_parent_contact(self, account, contact):

View File

@ -148,18 +148,19 @@ def get_real_jid_from_fjid(account, fjid):
gcs = interface.instances[account]['gc'] gcs = interface.instances[account]['gc']
if gcs.has_key(room_jid): if gcs.has_key(room_jid):
# It's a pm, so if we have real jid it's in contact.jid # It's a pm, so if we have real jid it's in contact.jid
if not gc_contacts[account][room_jid].has_key(nick): gc_contact = contacts.get_gc_contact(account, room_jid, nick)
if not gc_contact:
return return
contact = gc_contacts[account][room_jid][nick] # gc_contact.jid is None when it's not a real jid (we don't know real jid)
# contact.jid is None when it's not a real jid (we don't know real jid) real_jid = gc_contact.jid
real_jid = contact.jid
return real_jid return real_jid
def get_room_from_fjid(jid): def get_room_from_fjid(jid):
return get_room_and_nick_from_fjid(jid)[0] return get_room_and_nick_from_fjid(jid)[0]
def get_contact_name_from_jid(account, jid): def get_contact_name_from_jid(account, jid):
return contacts[account][jid][0].name c = contacts.get_first_contact_from_jid(account, jid)
return c.name
def get_jid_without_resource(jid): def get_jid_without_resource(jid):
return jid.split('/')[0] return jid.split('/')[0]

View File

@ -231,7 +231,8 @@ class GroupchatControl(ChatControlBase):
self.parent_win.show_title() self.parent_win.show_title()
else: else:
gc_c = gajim.contacts.get_gc_contact(self.account, self.room_jid, nick) gc_c = gajim.contacts.get_gc_contact(self.account, self.room_jid, nick)
gajim.interface.roster.new_chat(gc_c, self.account) c = gajim.contacts.contact_from_gc_contact(gc_c)
gajim.interface.roster.new_chat(c, self.account)
# Scroll to line # Scroll to line
self.list_treeview.expand_row(path[0:1], False) self.list_treeview.expand_row(path[0:1], False)
self.list_treeview.scroll_to_cell(path) self.list_treeview.scroll_to_cell(path)

View File

@ -1519,7 +1519,8 @@ current room topic.') % command, room_jid)
self.show_title() self.show_title()
else: else:
gc_c = gajim.contacts.get_gc_contact(self.account, room_jid, nick) gc_c = gajim.contacts.get_gc_contact(self.account, room_jid, nick)
gajim.interface.roster.new_chat(gc_c, self.account) c = gajim.contacts.contact_from_gc_contact(gc_c)
gajim.interface.roster.new_chat(c, self.account)
# Scroll to line # Scroll to line
self.list_treeview[room_jid].expand_row(path[0:1], False) self.list_treeview[room_jid].expand_row(path[0:1], False)
self.list_treeview[room_jid].scroll_to_cell(path) self.list_treeview[room_jid].scroll_to_cell(path)
@ -1631,7 +1632,8 @@ current room topic.') % command, room_jid)
if not gajim.interface.instances[self.account]['chats'].has_key(fjid): if not gajim.interface.instances[self.account]['chats'].has_key(fjid):
gc_c = gajim.contacts.get_gc_contact(self.account, room_jid, gc_c = gajim.contacts.get_gc_contact(self.account, room_jid,
nick) nick)
gajim.interface.roster.new_chat(gc_c, self.account) c = gajim.contacts.contact_from_gc_contact(gc_c)
gajim.interface.roster.new_chat(c, self.account)
gajim.interface.instances[self.account]['chats'][fjid].set_active_tab(fjid) gajim.interface.instances[self.account]['chats'][fjid].set_active_tab(fjid)
gajim.interface.instances[self.account]['chats'][fjid].window.present() gajim.interface.instances[self.account]['chats'][fjid].window.present()
return True return True
@ -1675,8 +1677,8 @@ current room topic.') % command, room_jid)
# FIXME # FIXME
if not gajim.interface.instances[self.account]['chats'].has_key(jid): if not gajim.interface.instances[self.account]['chats'].has_key(jid):
gc_c = gajim.contacts.get_gc_contact(self.account, room_jid, nick) gc_c = gajim.contacts.get_gc_contact(self.account, room_jid, nick)
gajim.interface.roster.new_chat(gc_c, self.account) c = gajim.contacts.contact_from_gc_contact(gc_c)
jid = gc_c.jid gajim.interface.roster.new_chat(c, self.account)
gajim.interface.instances[self.account]['chats'][jid].set_active_tab(jid) gajim.interface.instances[self.account]['chats'][jid].set_active_tab(jid)
gajim.interface.instances[self.account]['chats'][jid].window.present() gajim.interface.instances[self.account]['chats'][jid].window.present()

View File

@ -745,13 +745,16 @@ class TabbedChatWindow(chat.Chat):
jid = self.get_active_jid() jid = self.get_active_jid()
contact = gajim.contacts.get_first_contact_from_jid(self.account, jid) contact = gajim.contacts.get_first_contact_from_jid(self.account, jid)
if contact is None: if contact is None:
# contact was from pm in MUC, and left the room, or we left the room # contact was from pm in MUC
room, nick = gajim.get_room_and_nick_from_fjid(jid) room, nick = gajim.get_room_and_nick_from_fjid(jid)
dialogs.ErrorDialog(_('Sending private message failed'), gc_contact = gajim.contacts.get_gc_contact(self.account, room, nick)
#in second %s code replaces with nickname if not gc_contact:
_('You are no longer in room "%s" or "%s" has left.') % \ # contact left the room, or we left the room
(room, nick)).get_response() dialogs.ErrorDialog(_('Sending private message failed'),
return #in second %s code replaces with nickname
_('You are no longer in room "%s" or "%s" has left.') % \
(room, nick)).get_response()
return
conv_textview = self.conversation_textviews[jid] conv_textview = self.conversation_textviews[jid]
message_textview = self.message_textviews[jid] message_textview = self.message_textviews[jid]