summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--dev-python/urwid/ChangeLog6
-rw-r--r--dev-python/urwid/Manifest5
-rw-r--r--dev-python/urwid/files/urwid-0.8.7-input.diff248
-rw-r--r--dev-python/urwid/urwid-0.8.7.ebuild8
4 files changed, 263 insertions, 4 deletions
diff --git a/dev-python/urwid/ChangeLog b/dev-python/urwid/ChangeLog
index b39cc26eb3e1..572622fe7df7 100644
--- a/dev-python/urwid/ChangeLog
+++ b/dev-python/urwid/ChangeLog
@@ -1,6 +1,10 @@
# ChangeLog for dev-python/urwid
# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/dev-python/urwid/ChangeLog,v 1.6 2005/05/10 00:33:45 pythonhead Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-python/urwid/ChangeLog,v 1.7 2005/05/10 04:18:50 pythonhead Exp $
+
+ 10 May 2005; Rob Cakebread <pythonhead@gentoo.org>
+ +files/urwid-0.8.7-input.diff, urwid-0.8.7.ebuild:
+ Added down key patch from upstream. bug# 91338
*urwid-0.8.7 (10 May 2005)
diff --git a/dev-python/urwid/Manifest b/dev-python/urwid/Manifest
index 5a09ebc61201..8d0689844609 100644
--- a/dev-python/urwid/Manifest
+++ b/dev-python/urwid/Manifest
@@ -1,6 +1,7 @@
MD5 f367b6d77406960c7d3d3b8151f25712 urwid-0.8.6.ebuild 747
MD5 26d7d704ca382b7d9271064f1011385b metadata.xml 855
-MD5 528e01f587a2ea681b6f34136a7c47f5 ChangeLog 847
-MD5 504bfe63d227d53446e0c18788a62830 urwid-0.8.7.ebuild 761
+MD5 d1326a238f08f5068d234ad7429ac17e ChangeLog 1003
+MD5 8b96fd7858092f12da10b26b48f22c68 urwid-0.8.7.ebuild 867
MD5 84b7b6bba847f6a4f3c63695b607eb8a files/digest-urwid-0.8.6 62
MD5 f8967397e1d9508b8cc6df9fc17a0e75 files/digest-urwid-0.8.7 62
+MD5 6f59af79ea7b059a9f84867e083b4818 files/urwid-0.8.7-input.diff 7221
diff --git a/dev-python/urwid/files/urwid-0.8.7-input.diff b/dev-python/urwid/files/urwid-0.8.7-input.diff
new file mode 100644
index 000000000000..1ce066b27070
--- /dev/null
+++ b/dev-python/urwid/files/urwid-0.8.7-input.diff
@@ -0,0 +1,248 @@
+--- urwid/curses_display.py.0.8.7 2005-05-07 12:43:13.757255723 -0400
++++ urwid/curses_display.py 2005-05-01 17:58:03.000000000 -0400
+@@ -79,6 +79,94 @@
+ -1:None,
+ }
+
++def escape_modifier( digit ):
++ mode = ord(digit) - ord("1")
++ return "shift "*(mode&1) + "meta "*((mode&2)/2) + "ctrl "*((mode&4)/4)
++
++
++_escape_sequences = [
++ ('[A','up'),('[B','[down'),('[C','right'),('[D','left'),
++ ('[E','5'),('[F','end'),('[H','home'),
++
++ ('[1~','home'),('[2~','insert'),('[3~','delete'),('[4~','end'),
++ ('[5~','page up'),('[6~','page down'),
++
++ ('[[A','f1'),('[[B','f2'),('[[C','f3'),('[[D','f4'),('[[E','f5'),
++
++ ('[11~','f1'),('[12~','f2'),('[13~','f3'),('[14~','f4'),
++ ('[15~','f5'),('[17~','f6'),('[18~','f7'),('[19~','f8'),
++ ('[20~','f9'),('[21~','f10'),('[23~','f11'),('[24~','f12'),
++ ('[25~','f13'),
++
++ ('OA','up'),('OB','down'),('OC','right'),('OD','left'),
++ ('OH','home'),('OF','end'),
++ ('OP','f1'),('OQ','f2'),('OR','f3'),('OS','f4'),
++ ('Oo','/'),('Oj','*'),('Om','-'),('Ok','+'),
++
++] + [
++ # modified cursor keys -- [#X form
++ ("["+digit+letter, escape_modifier(digit) + key)
++ for digit in "12345678"
++ for letter,key in zip("ABCD",('up','down','right','left'))
++] + [
++ # modified cursor keys + home, end, 5 -- [1;#X form
++ ("[1;"+digit+letter, escape_modifier(digit) + key)
++ for digit in "12345678"
++ for letter,key in zip("ABCDEFH",
++ ('up','down','right','left','5','end','home'))
++] + [
++ # modified F1-F4 keys -- O#X form
++ ("O"+digit+letter, escape_modifier(digit) + key)
++ for digit in "12345678"
++ for letter,key in zip("PQRS",('f1','f2','f3','f4'))
++] + [
++ # modified F1-F13 keys -- [XX;#~ form
++ ("["+str(num)+";"+digit+"~", escape_modifier(digit) + key)
++ for digit in "12345678"
++ for num,key in zip((11,12,13,14,15,17,18,19,20,21,23,24,25),
++ ('f1','f2','f3','f4','f5','f6','f7','f8','f9',
++ 'f10','f11','f12','f13'))
++]
++
++class _KeyqueueTrie:
++ def __init__( self, sequences ):
++ self.data = {}
++ for s, result in sequences:
++ assert type(result) != type({})
++ self.add(self.data, s, result)
++
++ def add(self, root, s, result):
++ assert type(root) == type({}), "trie conflict detected"
++ assert len(s) > 0, "trie conflict detected"
++
++ if root.has_key(ord(s[0])):
++ return self.add(root[ord(s[0])], s[1:], result)
++ if len(s)>1:
++ d = {}
++ root[ord(s[0])] = d
++ return self.add(d, s[1:], result)
++ root[ord(s)] = result
++
++ def get(self, keys, more_fn):
++ return self.get_recurse(self.data, keys, more_fn)
++
++ def get_recurse(self, root, keys, more_fn):
++ if type(root) != type({}):
++ return (root, keys)
++ if not keys:
++ # get more keys
++ key = more_fn()
++ if key < 0:
++ return None
++ keys.append(key)
++ if not root.has_key(keys[0]):
++ return None
++ return self.get_recurse( root[keys[0]], keys[1:], more_fn )
++
++
++_escape_trie = _KeyqueueTrie(_escape_sequences)
++
++
+ # replace control characters with ?'s
+ _trans_table = "?"*32+"".join([chr(x) for x in range(32,256)])
+
+@@ -179,7 +267,7 @@
+ curses.noecho()
+ curses.meta(1)
+ curses.halfdelay(10) # don't wait longer than 1s for keypress
+- self.s.keypad(1)
++ self.s.keypad(0)
+ self.s.scrollok(1)
+ return fn()
+ finally:
+@@ -254,6 +342,11 @@
+ self.s.nodelay(0)
+ return self.s.getch()
+
++ def _getch_tinydelay(self):
++ curses.halfdelay(1) # don't wait longer than 0.1s for keypress
++ self.s.nodelay(0)
++ return self.s.getch()
++
+ def _getch_nodelay(self):
+ self.s.nodelay(1)
+ while 1:
+@@ -345,8 +438,15 @@
+ key = self._getch_nodelay()
+
+ processed = []
++
++ def more_fn(raw=raw):
++ key = self._getch_tinydelay()
++ if key >= 0:
++ raw.append(key)
++ return key
++
+ while keys:
+- run, keys = self._process_keyqueue(keys)
++ run, keys = self._process_keyqueue(keys, more_fn)
+ processed += run
+
+ if resize:
+@@ -354,8 +454,7 @@
+
+ return processed, raw
+
+- def _process_keyqueue(self, keys):
+- # help.. becoming unmaintainable..
++ def _process_keyqueue(self, keys, more_fn):
+ code = keys.pop(0)
+ if code >= 32 and code <= 126:
+ key = chr(code)
+@@ -364,87 +463,28 @@
+ return [_keyconv[code]],keys
+ if code >0 and code <27:
+ return ["ctrl %s" % chr(ord('a')+code-1)],keys
+- if code >=0xA1 and util.double_byte_encoding and keys:
+- if keys[0] >=0xA1:
+- return [chr(code)+chr(keys.pop(0))],keys
++ if code < 256 and util.within_double_byte(chr(code),0,0):
++ if not keys:
++ key = more_fn()
++ if key >= 0: keys.append(key)
++ if keys and key[0] < 256:
++ db = chr(code)+chr(keys[0])
++ if util.within_double_byte( db, 0, 1 ):
++ keys.pop(0)
++ return [db],keys
+ if code >127 and code <256:
+ key = chr(code)
+ return [key],keys
+ if code != 27:
+ return ["<%d>"%code],keys
+
+- if not keys: return ['esc'],keys
+- c2 = keys.pop(0)
+-
+- if c2 == ord('['):
+- if not keys: return ['esc','['],keys
+- c3 = keys.pop(0)
+- if chr(c3) not in "12456[" or not keys:
+- return ['esc','['],[c3]+keys
+- c4 = keys.pop(0)
+- if c3 == ord("["):
+- if c4 == ord('A'): return ["f1"],keys
+- if c4 == ord('B'): return ["f2"],keys
+- if c4 == ord('C'): return ["f3"],keys
+- if c4 == ord('D'): return ["f4"],keys
+- if c4 == ord('E'): return ["f5"],keys
+- return ['esc','['],[c3,c4]+keys
+-
+- if c4 == ord("~"):
+- if c3 == ord('1'): return ["home"],keys
+- if c3 == ord('4'): return ["end"],keys
+- if c3 == ord('5'): return ["page up"],keys
+- if c3 == ord('6'): return ["page down"],keys
+- return ['esc','['],[c3,c4]+keys
+-
+- if chr(c4) not in "0123456789" or not keys:
+- return ['esc','['],[c3,c4]+keys
+- c5 = keys.pop(0)
+-
+- if c5 != ord("~"):
+- return ['esc','['],[c3,c4,c5]+keys
+- num = chr(c3)+chr(c4)
+- numd = {"11":"f1", "12":"f2", "13":"f3", "14":"f4",
+- "15":"f5", "17":"f6", "18":"f7", "19":"f8",
+- "20":"f9", "21":"f10", "23":"f11", "24":"f12",
+- "25":"f13"}
+- if numd.has_key(num):
+- return [numd[num]],keys
+- else:
+- return ['esc','['],[c3,c4,c5]+keys
++ result = _escape_trie.get( keys, more_fn )
++
++ if result is None:
++ return ['esc'],keys
+
+- if c2 != ord('O'):
+- if c2 >32 and c2 <127:
+- key = "meta "+chr(c2)
+- return [key],keys
+- return ['esc'],[c2]+keys
+-
+- c3 = keys.pop(0)
+- if c3 == ord('H'): return ["home"],keys
+- if c3 == ord('F'): return ["end"],keys
+- if c3 == ord('o'): return ["/"],keys
+- if c3 == ord('j'): return ["*"],keys
+- if c3 == ord('m'): return ["-"],keys
+- if c3 == ord('k'): return ["+"],keys
+- if c3 == ord('A'): return ["up"],keys
+- if c3 == ord('B'): return ["down"],keys
+- if c3 == ord('C'): return ["right"],keys
+- if c3 == ord('D'): return ["left"],keys
+-
+- if chr(c3) not in "2345678" or not keys:
+- return ['esc'],[c2,c3]+keys
+- i = c3 - ord("1")
+- mod = ""
+- if i & 1: mod += "shift "
+- if i & 2: mod += "meta "
+- if i & 4: mod += "ctrl "
+-
+- c4 = keys.pop(0)
+- if c4 == ord('A'): return [mod+"up"],keys
+- if c4 == ord('B'): return [mod+"down"],keys
+- if c4 == ord('C'): return [mod+"right"],keys
+- if c4 == ord('D'): return [mod+"left"],keys
+- else: return ['esc'],[c2,c3,c4]+keys
++ result, keys = result
++ return [result],keys
+
+
+ def _dbg_instr(self): # messy input string (intended for debugging)
diff --git a/dev-python/urwid/urwid-0.8.7.ebuild b/dev-python/urwid/urwid-0.8.7.ebuild
index c3e6c04136e0..40d23e0b4485 100644
--- a/dev-python/urwid/urwid-0.8.7.ebuild
+++ b/dev-python/urwid/urwid-0.8.7.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2005 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/dev-python/urwid/urwid-0.8.7.ebuild,v 1.1 2005/05/10 00:29:42 pythonhead Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-python/urwid/urwid-0.8.7.ebuild,v 1.2 2005/05/10 04:18:50 pythonhead Exp $
inherit distutils
@@ -15,6 +15,12 @@ KEYWORDS="~x86 ~ppc"
IUSE="examples"
DEPEND="virtual/python"
+src_unpack() {
+ unpack ${A}
+ cd ${S} || die "Failed to cd to ${S}"
+ epatch ${FILESDIR}/${P}-input.diff
+}
+
src_test() {
${python} test_urwid.py || die "unit tests failed"
}