diff --git a/src/common/config.py b/src/common/config.py index 3153e870e..7e8342778 100644 --- a/src/common/config.py +++ b/src/common/config.py @@ -270,6 +270,7 @@ class Config: 'latex_png_dpi': [opt_str, '108',_('Change the value to change the size of latex formulas displayed. The higher is larger.') ], 'uri_schemes': [opt_str, 'aaa aaas acap cap cid crid data dav dict dns fax file ftp go gopher h323 http https icap im imap info ipp iris iris.beep iris.xpc iris.xpcs iris.lwz ldap mid modem msrp msrps mtqp mupdate news nfs nntp opaquelocktoken pop pres rtsp service shttp sip sips snmp soap.beep soap.beeps tag tel telnet tftp thismessage tip tv urn vemmi xmlrpc.beep xmlrpc.beeps z39.50r z39.50s about cvs daap ed2k feed fish git iax2 irc ircs ldaps magnet mms rsync ssh svn sftp smb webcal', _('Valid uri schemes. Only schemes in this list will be accepted as "real" uri. (mailto and xmpp are handled separately)'), True], 'ask_offline_status_on_connection': [ opt_bool, False, _('Ask offline status message to all offline contacts when connection to an accoutn is established. WARNING: This causes a lot of requests to be sent!') ], + 'shell_like_completion': [ opt_bool, False, _('If True, completion in groupchats will be like a shell auto-completion')], } __options_per_key = { diff --git a/src/groupchat_control.py b/src/groupchat_control.py index c44258aae..4b7962135 100644 --- a/src/groupchat_control.py +++ b/src/groupchat_control.py @@ -1856,7 +1856,23 @@ class GroupchatControl(ChatControlBase): start_iter.backward_chars(len(begin)) message_buffer.delete(start_iter, end_iter) - message_buffer.insert_at_cursor(self.nick_hits[0] + add) + completion = self.nick_hits[0] + # get a shell-like completion + # if there's more than one nick for this completion, complete only + # the part that all these nicks have in common + if gajim.config.get('shell_like_completion') and \ + len(self.nick_hits) > 1: + end = False + cur = '' + while not end: + cur = self.nick_hits[0][:len(cur)+1] + for nick in self.nick_hits: + if cur.lower() not in nick.lower(): + end = True + cur = cur[:-1] + completion = cur + add = "" # if nick is not complete, don't but any comma or so + message_buffer.insert_at_cursor(completion + add) self.last_key_tabs = True return True self.last_key_tabs = False