aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2011-08-04 17:05:35 +0000
committerTiago Cunha <tcunha@gmx.com>2011-08-04 17:05:35 +0000
commit3ce1b91b1be4f1e2815619dbf3db7448916d7f49 (patch)
treedce4fe1a7e90ea99dc2d6aeaa08598c4da935cde
parent2589d117b0b48baefcb39ed3403481eaa24877e8 (diff)
downloadrtmux-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.c4
-rw-r--r--options-table.c6
-rw-r--r--tmux.19
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
},
diff --git a/tmux.1 b/tmux.1
index 4f2ff553..3f94e2d3 100644
--- a/tmux.1
+++ b/tmux.1
@@ -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