diff options
author | Nicholas Marriott <nicholas.marriott@gmail.com> | 2009-01-27 23:35:44 +0000 |
---|---|---|
committer | Nicholas Marriott <nicholas.marriott@gmail.com> | 2009-01-27 23:35:44 +0000 |
commit | 2af52440baa64aa86481cf5d9f6e05c7d257b4bb (patch) | |
tree | 4864ea5da4e5fa4c2fb72b4fe592b24edde60cf7 /window-copy.c | |
parent | 7b18a9a6eb86fd2010049b5235aa32058edbb2dc (diff) | |
download | rtmux-2af52440baa64aa86481cf5d9f6e05c7d257b4bb.tar.gz rtmux-2af52440baa64aa86481cf5d9f6e05c7d257b4bb.tar.bz2 rtmux-2af52440baa64aa86481cf5d9f6e05c7d257b4bb.zip |
-u to start with screen scrolled up.
Diffstat (limited to 'window-copy.c')
-rw-r--r-- | window-copy.c | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/window-copy.c b/window-copy.c index 5430384b..d4ade00e 100644 --- a/window-copy.c +++ b/window-copy.c @@ -1,4 +1,4 @@ -/* $Id: window-copy.c,v 1.46 2009-01-27 20:22:33 nicm Exp $ */ +/* $Id: window-copy.c,v 1.47 2009-01-27 23:35:44 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -118,6 +118,20 @@ window_copy_free(struct window_pane *wp) } void +window_copy_pageup(struct window_pane *wp) +{ + struct window_copy_mode_data *data = wp->modedata; + struct screen *s = &data->screen; + + if (data->oy + screen_size_y(s) > screen_hsize(&wp->base)) + data->oy = screen_hsize(&wp->base); + else + data->oy += screen_size_y(s); + window_copy_update_selection(wp); + window_copy_redraw_screen(wp); +} + +void window_copy_resize(struct window_pane *wp, u_int sx, u_int sy) { struct window_copy_mode_data *data = wp->modedata; @@ -156,12 +170,7 @@ window_copy_key(struct window_pane *wp, struct client *c, int key) window_copy_cursor_down(wp); return; case MODEKEY_PPAGE: - if (data->oy + screen_size_y(s) > screen_hsize(&wp->base)) - data->oy = screen_hsize(&wp->base); - else - data->oy += screen_size_y(s); - window_copy_update_selection(wp); - window_copy_redraw_screen(wp); + window_copy_pageup(wp); break; case MODEKEY_NPAGE: if (data->oy < screen_size_y(s)) |