summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2016-02-05 10:20:07 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2016-02-05 10:20:07 +0000
commit6a1e2e745fcd2ffb1d8bf378c461792031827e36 (patch)
tree7379da6d5b5bf937f64c7e80eb5c5eec8b6779c0
parent6bb3602fc3b75e57548004bbb2fcbef785acd2c8 (diff)
Do not wrap cursor at start or end of history, from Michal Mazurek.
-rw-r--r--usr.bin/tmux/window-copy.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/usr.bin/tmux/window-copy.c b/usr.bin/tmux/window-copy.c
index 6809b40e023..6ae41bb0ef4 100644
--- a/usr.bin/tmux/window-copy.c
+++ b/usr.bin/tmux/window-copy.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: window-copy.c,v 1.144 2016/01/19 15:59:12 nicm Exp $ */
+/* $OpenBSD: window-copy.c,v 1.145 2016/02/05 10:20:06 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com>
@@ -1775,11 +1775,13 @@ void
window_copy_cursor_left(struct window_pane *wp)
{
struct window_copy_mode_data *data = wp->modedata;
+ u_int py;
- if (data->cx == 0) {
+ py = screen_hsize(data->backing) + data->cy - data->oy;
+ if (data->cx == 0 && py > 0) {
window_copy_cursor_up(wp, 0);
window_copy_cursor_end_of_line(wp);
- } else {
+ } else if (data->cx > 0) {
window_copy_update_cursor(wp, data->cx - 1, data->cy);
if (window_copy_update_selection(wp, 1))
window_copy_redraw_lines(wp, data->cy, 1);
@@ -1790,19 +1792,20 @@ void
window_copy_cursor_right(struct window_pane *wp)
{
struct window_copy_mode_data *data = wp->modedata;
- u_int px, py;
+ u_int px, py, yy;
+ py = screen_hsize(data->backing) + data->cy - data->oy;
+ yy = screen_hsize(data->backing) + screen_size_y(data->backing) - 1;
if (data->screen.sel.flag && data->rectflag)
px = screen_size_x(&data->screen);
else {
- py = screen_hsize(data->backing) + data->cy - data->oy;
px = window_copy_find_length(wp, py);
}
- if (data->cx >= px) {
+ if (data->cx >= px && py < yy) {
window_copy_cursor_start_of_line(wp);
window_copy_cursor_down(wp, 0);
- } else {
+ } else if (data->cx < px) {
window_copy_update_cursor(wp, data->cx + 1, data->cy);
if (window_copy_update_selection(wp, 1))
window_copy_redraw_lines(wp, data->cy, 1);