aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorsach1t <sach0010t@gmail.com>2016-06-04 01:37:32 -0400
committerJustin M. Keyes <justinkz@gmail.com>2016-09-12 03:11:26 +0200
commitc6f5d6b7e0f274a245cecd80c480212d399df9d4 (patch)
tree2206d2bdac910524164179169bc30087d6c2c5b8 /src
parent4ceacb37d52289df609a23ecfa8130682e0d55e5 (diff)
downloadrneovim-c6f5d6b7e0f274a245cecd80c480212d399df9d4.tar.gz
rneovim-c6f5d6b7e0f274a245cecd80c480212d399df9d4.tar.bz2
rneovim-c6f5d6b7e0f274a245cecd80c480212d399df9d4.zip
normal.c: Restore vim-like tab dragging. #4874
Closes #4663 References #3310
Diffstat (limited to 'src')
-rw-r--r--src/nvim/normal.c26
1 files changed, 16 insertions, 10 deletions
diff --git a/src/nvim/normal.c b/src/nvim/normal.c
index c95e5e1a15..4dec51ce83 100644
--- a/src/nvim/normal.c
+++ b/src/nvim/normal.c
@@ -2110,6 +2110,20 @@ static void op_function(oparg_T *oap)
}
}
+// Move the current tab to tab in same column as mouse or to end of the
+// tabline if there is no tab there.
+static void move_tab_to_mouse(void)
+{
+ int tabnr = tab_page_click_defs[mouse_col].tabnr;
+ if (tabnr <= 0) {
+ tabpage_move(9999);
+ } else if (tabnr < tabpage_index(curtab)) {
+ tabpage_move(tabnr - 1);
+ } else {
+ tabpage_move(tabnr);
+ }
+}
+
/*
* Do the appropriate action for the current mouse click in the current mode.
* Not used for Command-line mode.
@@ -2346,12 +2360,7 @@ do_mouse (
if (mouse_row == 0 && firstwin->w_winrow > 0) {
if (is_drag) {
if (in_tab_line) {
- if (tab_page_click_defs[mouse_col].type == kStlClickTabClose) {
- tabpage_move(9999);
- } else {
- int tabnr = tab_page_click_defs[mouse_col].tabnr;
- tabpage_move(tabnr < tabpage_index(curtab) ? tabnr - 1 : tabnr);
- }
+ move_tab_to_mouse();
}
return false;
}
@@ -2466,10 +2475,7 @@ do_mouse (
}
return true;
} else if (is_drag && in_tab_line) {
- tabpage_move(tab_page_click_defs[mouse_col].type == kStlClickTabClose
- ? 9999
- : tab_page_click_defs[mouse_col].tabnr - 1);
- in_tab_line = false;
+ move_tab_to_mouse();
return false;
}