summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoremkael <emkael@tlen.pl>2016-10-10 16:12:23 +0200
committeremkael <emkael@tlen.pl>2016-11-25 22:10:19 +0100
commit07401a984b58d6d1328264efca45df39e1951ea2 (patch)
treee7c3020be112c2b15b87fb9317a4192b42948c9a
parentae7738768ead06aea4b93826c8e164da53eeba51 (diff)
encoding readline completer options in case Python2 unicode strings are involved
-rw-r--r--ql/completer.py10
1 files changed, 9 insertions, 1 deletions
diff --git a/ql/completer.py b/ql/completer.py
index a9b7d8d..89920d4 100644
--- a/ql/completer.py
+++ b/ql/completer.py
@@ -1,4 +1,5 @@
import readline
+import sys
class Completer(object):
@@ -10,8 +11,15 @@ class Completer(object):
readline.set_completer_delims('') # allow options with whitespace
readline.parse_and_bind('tab: complete')
+ def __encode_completion_string(self, s):
+ try:
+ return s.encode(sys.stdin.encoding) if isinstance(s, unicode) else s
+ except NameError: # Python 3.x does not have a 'unicode' type
+ pass
+ return s
+
def __init__(self, options):
- self.options = options
+ self.options = [self.__encode_completion_string(s) for s in options]
def complete(self, text, state):
text = text.lower()