diff options
author | Tiago Cunha <tcunha@gmx.com> | 2011-08-04 17:05:35 +0000 |
---|---|---|
committer | Tiago Cunha <tcunha@gmx.com> | 2011-08-04 17:05:35 +0000 |
commit | 3ce1b91b1be4f1e2815619dbf3db7448916d7f49 (patch) | |
tree | dce4fe1a7e90ea99dc2d6aeaa08598c4da935cde | |
parent | 2589d117b0b48baefcb39ed3403481eaa24877e8 (diff) | |
download | rtmux-3ce1b91b1be4f1e2815619dbf3db7448916d7f49.tar.gz rtmux-3ce1b91b1be4f1e2815619dbf3db7448916d7f49.tar.bz2 rtmux-3ce1b91b1be4f1e2815619dbf3db7448916d7f49.zip |
Sync OpenBSD patchset 941:
Extend the mode-mouse option to add a third choice which means the mouse
does not enter copy mode. Patch from SF bug 3374493.
In future the mode-mouse option is likely to die and be broken into
several smaller options.
-rw-r--r-- | input-keys.c | 4 | ||||
-rw-r--r-- | options-table.c | 6 | ||||
-rw-r--r-- | tmux.1 | 9 |
3 files changed, 15 insertions, 4 deletions
diff --git a/input-keys.c b/input-keys.c index 3ed6137b..3fda6f86 100644 --- a/input-keys.c +++ b/input-keys.c @@ -203,6 +203,7 @@ input_mouse(struct window_pane *wp, struct mouse_event *m) { char buf[10]; size_t len; + int value; if (wp->screen->mode & ALL_MOUSE_MODES) { if (wp->screen->mode & MODE_MOUSE_UTF8) { @@ -220,7 +221,8 @@ input_mouse(struct window_pane *wp, struct mouse_event *m) } bufferevent_write(wp->event, buf, len); } else if ((m->b & MOUSE_BUTTON) != MOUSE_2) { - if (options_get_number(&wp->window->options, "mode-mouse") && + value = options_get_number(&wp->window->options, "mode-mouse"); + if (value == 1 && window_pane_set_mode(wp, &window_copy_mode) == 0) { window_copy_init_from_pane(wp); if (wp->mode->mouse != NULL) diff --git a/options-table.c b/options-table.c index daeade54..d289ca21 100644 --- a/options-table.c +++ b/options-table.c @@ -35,6 +35,9 @@ const char *options_table_mode_keys_list[] = { "emacs", "vi", NULL }; +const char *options_table_mode_mouse_list[] = { + "off", "on", "copy-mode", NULL +}; const char *options_table_clock_mode_style_list[] = { "12", "24", NULL }; @@ -483,7 +486,8 @@ const struct options_table_entry window_options_table[] = { }, { .name = "mode-mouse", - .type = OPTIONS_TABLE_FLAG, + .type = OPTIONS_TABLE_CHOICE, + .choices = options_table_mode_mouse_list, .default_num = 0 }, @@ -14,7 +14,7 @@ .\" IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING .\" OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. .\" -.Dd $Mdocdate: July 25 2011 $ +.Dd $Mdocdate: July 30 2011 $ .Dt TMUX 1 .Os .Sh NAME @@ -2362,12 +2362,17 @@ contains .Ql vi . .Pp .It Xo Ic mode-mouse -.Op Ic on | off +.Op Ic on | off | copy-mode .Xc Mouse state in modes. If on, the mouse may be used to enter copy mode and copy a selection by dragging, to enter copy mode and scroll with the mouse wheel, or to select an option in choice mode. +If set to +.Em +copy-mode , +the mouse behaves as set to on, but cannot be used to enter copy +mode. .Pp .It Xo Ic monitor-activity .Op Ic on | off |