From 2af52440baa64aa86481cf5d9f6e05c7d257b4bb Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Tue, 27 Jan 2009 23:35:44 +0000 Subject: -u to start with screen scrolled up. --- window-scroll.c | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) (limited to 'window-scroll.c') diff --git a/window-scroll.c b/window-scroll.c index bdcba248..6938220c 100644 --- a/window-scroll.c +++ b/window-scroll.c @@ -1,4 +1,4 @@ -/* $Id: window-scroll.c,v 1.29 2009-01-27 20:22:33 nicm Exp $ */ +/* $Id: window-scroll.c,v 1.30 2009-01-27 23:35:44 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott @@ -86,6 +86,20 @@ window_scroll_free(struct window_pane *wp) xfree(data); } +void +window_scroll_pageup(struct window_pane *wp) +{ + struct window_scroll_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_scroll_redraw_screen(wp); +} + void window_scroll_resize(struct window_pane *wp, u_int sx, u_int sy) { @@ -126,11 +140,7 @@ window_scroll_key(struct window_pane *wp, unused struct client *c, int key) window_scroll_scroll_down(wp); break; 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_scroll_redraw_screen(wp); + window_scroll_pageup(wp); break; case MODEKEY_NPAGE: if (data->oy < screen_size_y(s)) -- cgit