aboutsummaryrefslogtreecommitdiff
path: root/cmd-scroll-mode.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2009-01-27 23:35:44 +0000
committerNicholas Marriott <nicholas.marriott@gmail.com>2009-01-27 23:35:44 +0000
commit2af52440baa64aa86481cf5d9f6e05c7d257b4bb (patch)
tree4864ea5da4e5fa4c2fb72b4fe592b24edde60cf7 /cmd-scroll-mode.c
parent7b18a9a6eb86fd2010049b5235aa32058edbb2dc (diff)
downloadrtmux-2af52440baa64aa86481cf5d9f6e05c7d257b4bb.tar.gz
rtmux-2af52440baa64aa86481cf5d9f6e05c7d257b4bb.tar.bz2
rtmux-2af52440baa64aa86481cf5d9f6e05c7d257b4bb.zip
-u to start with screen scrolled up.
Diffstat (limited to 'cmd-scroll-mode.c')
-rw-r--r--cmd-scroll-mode.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/cmd-scroll-mode.c b/cmd-scroll-mode.c
index def0d213..e6f9d721 100644
--- a/cmd-scroll-mode.c
+++ b/cmd-scroll-mode.c
@@ -1,4 +1,4 @@
-/* $Id: cmd-scroll-mode.c,v 1.15 2009-01-19 18:23:40 nicm Exp $ */
+/* $Id: cmd-scroll-mode.c,v 1.16 2009-01-27 23:35:44 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -24,13 +24,14 @@
* Enter scroll mode.
*/
+void cmd_scroll_mode_init(struct cmd *, int);
int cmd_scroll_mode_exec(struct cmd *, struct cmd_ctx *);
const struct cmd_entry cmd_scroll_mode_entry = {
"scroll-mode", NULL,
CMD_TARGET_WINDOW_USAGE,
- 0,
- cmd_target_init,
+ CMD_UFLAG,
+ cmd_scroll_mode_init,
cmd_target_parse,
cmd_scroll_mode_exec,
cmd_target_send,
@@ -39,6 +40,21 @@ const struct cmd_entry cmd_scroll_mode_entry = {
cmd_target_print
};
+void
+cmd_scroll_mode_init(struct cmd *self, int key)
+{
+ struct cmd_target_data *data;
+
+ cmd_target_init(self, key);
+ data = self->data;
+
+ switch (key) {
+ case KEYC_PPAGE:
+ data->flags |= CMD_UFLAG;
+ break;
+ }
+}
+
int
cmd_scroll_mode_exec(struct cmd *self, struct cmd_ctx *ctx)
{
@@ -49,6 +65,8 @@ cmd_scroll_mode_exec(struct cmd *self, struct cmd_ctx *ctx)
return (-1);
window_pane_set_mode(wl->window->active, &window_scroll_mode);
+ if (data->flags & CMD_UFLAG)
+ window_scroll_pageup(wl->window->active);
return (0);
}