tab completion is now case insensitive and cycling in gc (thx dennis)

This commit is contained in:
Yann Leboulanger 2005-06-10 15:15:47 +00:00
parent ad19f954ac
commit ab94d57310
1 changed files with 39 additions and 14 deletions

View File

@ -46,6 +46,8 @@ class Groupchat_window(chat.Chat):
self.subject_entry = {} self.subject_entry = {}
self.subject_entry_tooltip = {} self.subject_entry_tooltip = {}
self.room_creation = {} self.room_creation = {}
self.nick_hits = {}
self.last_key_tabs = {}
self.new_room(room_jid, nick) self.new_room(room_jid, nick)
self.show_title() self.show_title()
self.xml.signal_connect('on_groupchat_window_destroy', self.xml.signal_connect('on_groupchat_window_destroy',
@ -175,8 +177,8 @@ class Groupchat_window(chat.Chat):
if not user: if not user:
fin2 = True fin2 = True
while not fin2: while not fin2:
nick = unicode(model.get_value(user, 1)).lower() nick = unicode(model.get_value(user, 1))
list.append() list.append(nick)
user = model.iter_next(user) user = model.iter_next(user)
if not user: if not user:
fin2 = True fin2 = True
@ -347,20 +349,38 @@ class Groupchat_window(chat.Chat):
end_iter = message_buffer.get_iter_at_mark(cursor_position) end_iter = message_buffer.get_iter_at_mark(cursor_position)
text = message_buffer.get_text(start_iter, end_iter, False) text = message_buffer.get_text(start_iter, end_iter, False)
if not text or text.endswith(' '): if not text or text.endswith(' '):
return False if not self.last_key_tabs[room_jid]: # if we are nick cycling, last char will always be space
return False
splitted_text = text.split() splitted_text = text.split()
begin = splitted_text[-1].lower() # last word we typed begin = splitted_text[-1] # last word we typed
for nick in list_nick:
if nick.find(begin) == 0: # the word is the begining of a nick if len(self.nick_hits[room_jid]) and self.nick_hits[room_jid][0].startswith(begin.replace(':', '')) \
if len(splitted_text) == 1: # This is the 1st word of the line and self.last_key_tabs[room_jid]: # we should cycle
add = ': ' self.nick_hits[room_jid].append(self.nick_hits[room_jid][0])
else: self.nick_hits[room_jid].pop(0)
add = ' ' else:
start_iter = end_iter.copy() self.nick_hits[room_jid] = [] # clear the hit list
for nick in list_nick:
if nick.lower().startswith(begin.lower()): # the word is the begining of a nick
self.nick_hits[room_jid].append(nick)
if len(self.nick_hits[room_jid]):
if len(splitted_text) == 1: # This is the 1st word of the line
add = ': '
else:
add = ' '
start_iter = end_iter.copy()
if self.last_key_tabs[room_jid] and begin.endswith(': '):
start_iter.backward_chars(len(begin) + 2) # have to accomodate for the added space from last completion
elif self.last_key_tabs[room_jid]:
start_iter.backward_chars(len(begin) + 1) # have to accomodate for the added space from last completion
else:
start_iter.backward_chars(len(begin)) start_iter.backward_chars(len(begin))
message_buffer.delete(start_iter, end_iter)
message_buffer.insert_at_cursor(nick + add) message_buffer.delete(start_iter, end_iter)
return True message_buffer.insert_at_cursor(self.nick_hits[room_jid][0] + add)
self.last_key_tabs[room_jid] = True
return True
self.last_key_tabs[room_jid] = False
return False return False
elif event.keyval == gtk.keysyms.Page_Down: # PAGE DOWN elif event.keyval == gtk.keysyms.Page_Down: # PAGE DOWN
if event.state & gtk.gdk.CONTROL_MASK: # CTRL + PAGE DOWN if event.state & gtk.gdk.CONTROL_MASK: # CTRL + PAGE DOWN
@ -375,6 +395,7 @@ class Groupchat_window(chat.Chat):
elif event.keyval == gtk.keysyms.Return or \ elif event.keyval == gtk.keysyms.Return or \
event.keyval == gtk.keysyms.KP_Enter: # ENTER event.keyval == gtk.keysyms.KP_Enter: # ENTER
if (event.state & gtk.gdk.SHIFT_MASK): if (event.state & gtk.gdk.SHIFT_MASK):
self.last_key_tabs[room_jid] = False
return False return False
if message != '' or message != '\n': if message != '' or message != '\n':
self.save_sent_message(room_jid, message) self.save_sent_message(room_jid, message)
@ -392,6 +413,8 @@ class Groupchat_window(chat.Chat):
elif event.keyval == gtk.keysyms.Down: elif event.keyval == gtk.keysyms.Down:
if event.state & gtk.gdk.CONTROL_MASK: #Ctrl+Down if event.state & gtk.gdk.CONTROL_MASK: #Ctrl+Down
self.sent_messages_scroll(room_jid, 'down', widget.get_buffer()) self.sent_messages_scroll(room_jid, 'down', widget.get_buffer())
else:
self.last_key_tabs[room_jid] = False
def print_conversation(self, text, room_jid, contact = '', tim = None): def print_conversation(self, text, room_jid, contact = '', tim = None):
"""Print a line in the conversation: """Print a line in the conversation:
@ -594,6 +617,8 @@ class Groupchat_window(chat.Chat):
self.nicks[room_jid] = nick self.nicks[room_jid] = nick
self.subjects[room_jid] = '' self.subjects[room_jid] = ''
self.room_creation[room_jid] = time.time() self.room_creation[room_jid] = time.time()
self.nick_hits[room_jid] = []
self.last_key_tabs[room_jid] = False
self.list_treeview[room_jid] = self.xmls[room_jid].get_widget( self.list_treeview[room_jid] = self.xmls[room_jid].get_widget(
'list_treeview') 'list_treeview')
conversation_textview = self.xmls[room_jid].get_widget( conversation_textview = self.xmls[room_jid].get_widget(