mirror of
https://github.com/tmux/tmux.git
synced 2025-01-05 23:38:48 +00:00
-u to start with screen scrolled up.
This commit is contained in:
parent
7b18a9a6eb
commit
2af52440ba
4
CHANGES
4
CHANGES
@ -1,5 +1,7 @@
|
|||||||
27 January 2009
|
27 January 2009
|
||||||
|
|
||||||
|
* -u flag to scroll-mode and copy-mode to start scrolled one page
|
||||||
|
up. scroll-mode -u is bound to prefix,page-up (ppage) by default.
|
||||||
* Allow status, mode and message attributes to be changed by three new options:
|
* Allow status, mode and message attributes to be changed by three new options:
|
||||||
status-attr, mode-attr, message-attr. A comma-separataed list is accepted
|
status-attr, mode-attr, message-attr. A comma-separataed list is accepted
|
||||||
containing: bright, dim, underscore, blink, reverse, hidden, italics, for
|
containing: bright, dim, underscore, blink, reverse, hidden, italics, for
|
||||||
@ -1025,7 +1027,7 @@
|
|||||||
(including mutt, emacs). No status bar yet and no key remapping or other
|
(including mutt, emacs). No status bar yet and no key remapping or other
|
||||||
customisation.
|
customisation.
|
||||||
|
|
||||||
$Id: CHANGES,v 1.237 2009-01-27 20:22:33 nicm Exp $
|
$Id: CHANGES,v 1.238 2009-01-27 23:35:44 nicm Exp $
|
||||||
|
|
||||||
LocalWords: showw utf UTF fulvio ciriaco joshe OSC APC gettime abc DEF OA clr
|
LocalWords: showw utf UTF fulvio ciriaco joshe OSC APC gettime abc DEF OA clr
|
||||||
LocalWords: rivo nurges lscm Erdely eol smysession mysession ek dstname RB ms
|
LocalWords: rivo nurges lscm Erdely eol smysession mysession ek dstname RB ms
|
||||||
|
2
TODO
2
TODO
@ -82,7 +82,7 @@
|
|||||||
- move-pane (to window) (maybe break-pane?)
|
- move-pane (to window) (maybe break-pane?)
|
||||||
- command: copy-buffer -s src-session -t dst-session -a src-index -b dst-index
|
- command: copy-buffer -s src-session -t dst-session -a src-index -b dst-index
|
||||||
(copy from other session)
|
(copy from other session)
|
||||||
- flag to scroll-mode/copy-mode to automatically scroll up a page
|
- document -u flag to scroll-mode/copy-mode
|
||||||
- key to switch to copy mode from scroll mode
|
- key to switch to copy mode from scroll mode
|
||||||
- document suspend-client
|
- document suspend-client
|
||||||
- document command sequences
|
- document command sequences
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: cmd-copy-mode.c,v 1.14 2009-01-19 18:23:40 nicm Exp $ */
|
/* $Id: cmd-copy-mode.c,v 1.15 2009-01-27 23:35:44 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -29,7 +29,7 @@ int cmd_copy_mode_exec(struct cmd *, struct cmd_ctx *);
|
|||||||
const struct cmd_entry cmd_copy_mode_entry = {
|
const struct cmd_entry cmd_copy_mode_entry = {
|
||||||
"copy-mode", NULL,
|
"copy-mode", NULL,
|
||||||
CMD_TARGET_WINDOW_USAGE,
|
CMD_TARGET_WINDOW_USAGE,
|
||||||
0,
|
CMD_UFLAG,
|
||||||
cmd_target_init,
|
cmd_target_init,
|
||||||
cmd_target_parse,
|
cmd_target_parse,
|
||||||
cmd_copy_mode_exec,
|
cmd_copy_mode_exec,
|
||||||
@ -49,6 +49,9 @@ cmd_copy_mode_exec(struct cmd *self, struct cmd_ctx *ctx)
|
|||||||
return (-1);
|
return (-1);
|
||||||
|
|
||||||
window_pane_set_mode(wl->window->active, &window_copy_mode);
|
window_pane_set_mode(wl->window->active, &window_copy_mode);
|
||||||
|
if (data->flags & CMD_UFLAG)
|
||||||
|
window_copy_pageup(wl->window->active);
|
||||||
|
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
@ -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>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -24,13 +24,14 @@
|
|||||||
* Enter scroll mode.
|
* Enter scroll mode.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
void cmd_scroll_mode_init(struct cmd *, int);
|
||||||
int cmd_scroll_mode_exec(struct cmd *, struct cmd_ctx *);
|
int cmd_scroll_mode_exec(struct cmd *, struct cmd_ctx *);
|
||||||
|
|
||||||
const struct cmd_entry cmd_scroll_mode_entry = {
|
const struct cmd_entry cmd_scroll_mode_entry = {
|
||||||
"scroll-mode", NULL,
|
"scroll-mode", NULL,
|
||||||
CMD_TARGET_WINDOW_USAGE,
|
CMD_TARGET_WINDOW_USAGE,
|
||||||
0,
|
CMD_UFLAG,
|
||||||
cmd_target_init,
|
cmd_scroll_mode_init,
|
||||||
cmd_target_parse,
|
cmd_target_parse,
|
||||||
cmd_scroll_mode_exec,
|
cmd_scroll_mode_exec,
|
||||||
cmd_target_send,
|
cmd_target_send,
|
||||||
@ -39,6 +40,21 @@ const struct cmd_entry cmd_scroll_mode_entry = {
|
|||||||
cmd_target_print
|
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
|
int
|
||||||
cmd_scroll_mode_exec(struct cmd *self, struct cmd_ctx *ctx)
|
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);
|
return (-1);
|
||||||
|
|
||||||
window_pane_set_mode(wl->window->active, &window_scroll_mode);
|
window_pane_set_mode(wl->window->active, &window_scroll_mode);
|
||||||
|
if (data->flags & CMD_UFLAG)
|
||||||
|
window_scroll_pageup(wl->window->active);
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: key-bindings.c,v 1.57 2009-01-18 18:31:45 nicm Exp $ */
|
/* $Id: key-bindings.c,v 1.58 2009-01-27 23:35:44 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -111,6 +111,7 @@ key_bindings_init(void)
|
|||||||
{ 'w', &cmd_choose_window_entry },
|
{ 'w', &cmd_choose_window_entry },
|
||||||
{ 'x', &cmd_kill_pane_entry, },
|
{ 'x', &cmd_kill_pane_entry, },
|
||||||
{ '\032', &cmd_suspend_client_entry },
|
{ '\032', &cmd_suspend_client_entry },
|
||||||
|
{ KEYC_PPAGE, &cmd_scroll_mode_entry },
|
||||||
{ KEYC_ADDESC('n'), &cmd_next_window_entry },
|
{ KEYC_ADDESC('n'), &cmd_next_window_entry },
|
||||||
{ KEYC_ADDESC('p'), &cmd_previous_window_entry },
|
{ KEYC_ADDESC('p'), &cmd_previous_window_entry },
|
||||||
{ KEYC_UP, &cmd_up_pane_entry },
|
{ KEYC_UP, &cmd_up_pane_entry },
|
||||||
|
4
tmux.h
4
tmux.h
@ -1,4 +1,4 @@
|
|||||||
/* $Id: tmux.h,v 1.253 2009-01-27 21:39:15 nicm Exp $ */
|
/* $Id: tmux.h,v 1.254 2009-01-27 23:35:44 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -1458,9 +1458,11 @@ extern const struct window_mode window_clock_mode;
|
|||||||
|
|
||||||
/* window-copy.c */
|
/* window-copy.c */
|
||||||
extern const struct window_mode window_copy_mode;
|
extern const struct window_mode window_copy_mode;
|
||||||
|
void window_copy_pageup(struct window_pane *);
|
||||||
|
|
||||||
/* window-scroll.c */
|
/* window-scroll.c */
|
||||||
extern const struct window_mode window_scroll_mode;
|
extern const struct window_mode window_scroll_mode;
|
||||||
|
void window_scroll_pageup(struct window_pane *);
|
||||||
|
|
||||||
/* window-more.c */
|
/* window-more.c */
|
||||||
extern const struct window_mode window_more_mode;
|
extern const struct window_mode window_more_mode;
|
||||||
|
@ -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>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -117,6 +117,20 @@ window_copy_free(struct window_pane *wp)
|
|||||||
xfree(data);
|
xfree(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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
|
void
|
||||||
window_copy_resize(struct window_pane *wp, u_int sx, u_int sy)
|
window_copy_resize(struct window_pane *wp, u_int sx, u_int sy)
|
||||||
{
|
{
|
||||||
@ -156,12 +170,7 @@ window_copy_key(struct window_pane *wp, struct client *c, int key)
|
|||||||
window_copy_cursor_down(wp);
|
window_copy_cursor_down(wp);
|
||||||
return;
|
return;
|
||||||
case MODEKEY_PPAGE:
|
case MODEKEY_PPAGE:
|
||||||
if (data->oy + screen_size_y(s) > screen_hsize(&wp->base))
|
window_copy_pageup(wp);
|
||||||
data->oy = screen_hsize(&wp->base);
|
|
||||||
else
|
|
||||||
data->oy += screen_size_y(s);
|
|
||||||
window_copy_update_selection(wp);
|
|
||||||
window_copy_redraw_screen(wp);
|
|
||||||
break;
|
break;
|
||||||
case MODEKEY_NPAGE:
|
case MODEKEY_NPAGE:
|
||||||
if (data->oy < screen_size_y(s))
|
if (data->oy < screen_size_y(s))
|
||||||
|
@ -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 <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -86,6 +86,20 @@ window_scroll_free(struct window_pane *wp)
|
|||||||
xfree(data);
|
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
|
void
|
||||||
window_scroll_resize(struct window_pane *wp, u_int sx, u_int sy)
|
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);
|
window_scroll_scroll_down(wp);
|
||||||
break;
|
break;
|
||||||
case MODEKEY_PPAGE:
|
case MODEKEY_PPAGE:
|
||||||
if (data->oy + screen_size_y(s) > screen_hsize(&wp->base))
|
window_scroll_pageup(wp);
|
||||||
data->oy = screen_hsize(&wp->base);
|
|
||||||
else
|
|
||||||
data->oy += screen_size_y(s);
|
|
||||||
window_scroll_redraw_screen(wp);
|
|
||||||
break;
|
break;
|
||||||
case MODEKEY_NPAGE:
|
case MODEKEY_NPAGE:
|
||||||
if (data->oy < screen_size_y(s))
|
if (data->oy < screen_size_y(s))
|
||||||
|
Loading…
Reference in New Issue
Block a user