aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorJilles Tjoelker <jilles@FreeBSD.org>2010-09-03 22:24:26 +0000
committerJilles Tjoelker <jilles@FreeBSD.org>2010-09-03 22:24:26 +0000
commit96e75396e1b322d354f5418f9947d26be47ef0e0 (patch)
tree332ffae08a8212bcd4b2e8c87208d9f24caf3bfc /lib
parentfe5d61a4cfad1bcfd0cd225c435882ab3b4fdb3a (diff)
downloadsrc-96e75396e1b322d354f5418f9947d26be47ef0e0.tar.gz
src-96e75396e1b322d354f5418f9947d26be47ef0e0.zip
libedit: Do not move the cursor for ed-delete-next-char in emacs mode.
This makes ed-delete-next-char suitable for mapping to the <Delete> key. Behaviour in vi mode is unchanged (for 'x').
Notes
Notes: svn path=/head/; revision=212191
Diffstat (limited to 'lib')
-rw-r--r--lib/libedit/common.c11
1 files changed, 4 insertions, 7 deletions
diff --git a/lib/libedit/common.c b/lib/libedit/common.c
index d4a9fa302bbc..d314eef52286 100644
--- a/lib/libedit/common.c
+++ b/lib/libedit/common.c
@@ -163,15 +163,12 @@ ed_delete_next_char(EditLine *el, int c)
return (CC_ERROR);
#endif
}
- } else {
- if (el->el_line.cursor != el->el_line.buffer)
- el->el_line.cursor--;
- else
- return (CC_ERROR);
- }
+ } else
+ return (CC_ERROR);
}
c_delafter(el, el->el_state.argument); /* delete after dot */
- if (el->el_line.cursor >= el->el_line.lastchar &&
+ if (el->el_map.type == MAP_VI &&
+ el->el_line.cursor >= el->el_line.lastchar &&
el->el_line.cursor > el->el_line.buffer)
/* bounds check */
el->el_line.cursor = el->el_line.lastchar - 1;