aboutsummaryrefslogtreecommitdiffhomepage
path: root/examples/data
diff options
context:
space:
mode:
authorGravatar Brendan Taylor <whateley@gmail.com>2011-04-13 07:03:11 -0600
committerGravatar Brendan Taylor <whateley@gmail.com>2011-04-13 07:03:11 -0600
commit89e95533d8e973b92a6217c9824ff595f6b37278 (patch)
tree8d19e5604a7625974475e96e08a6487d5fdb1d32 /examples/data
parent9bbff45ac31eee6458d2c20fc7a15d18c58aca19 (diff)
parentba7117ab362062f7cb0abdf6d0ee212f42d580ae (diff)
Merge remote-tracking branch 'mathstuf/dev/better-word-delete' into experimental
Diffstat (limited to 'examples/data')
-rw-r--r--examples/data/plugins/keycmd.py14
1 files changed, 10 insertions, 4 deletions
diff --git a/examples/data/plugins/keycmd.py b/examples/data/plugins/keycmd.py
index 928c597..76e2d75 100644
--- a/examples/data/plugins/keycmd.py
+++ b/examples/data/plugins/keycmd.py
@@ -406,16 +406,22 @@ def append_keycmd(uzbl, keycmd):
update_event(uzbl, k, False)
-def keycmd_strip_word(uzbl, sep):
+def keycmd_strip_word(uzbl, seps):
''' Removes the last word from the keycmd, similar to readline ^W '''
- sep = sep or ' '
+ seps = seps or ' '
k = uzbl.keylet
if not k.keycmd:
return
- head, tail = k.keycmd[:k.cursor].rstrip(sep), k.keycmd[k.cursor:]
- rfind = head.rfind(sep)
+ head, tail = k.keycmd[:k.cursor].rstrip(seps), k.keycmd[k.cursor:]
+ rfind = -1
+ for sep in seps:
+ p = head.rfind(sep)
+ if p >= 0 and rfind < p + 1:
+ rfind = p + 1
+ if rfind == len(head) and head[-1] in seps:
+ rfind -= 1
head = head[:rfind] if rfind + 1 else ''
k.keycmd = head + tail
k.cursor = len(head)