diff options
| author | Thiago de Arruda <tpadilha84@gmail.com> | 2014-12-02 07:51:18 -0300 | 
|---|---|---|
| committer | Thiago de Arruda <tpadilha84@gmail.com> | 2014-12-02 07:51:18 -0300 | 
| commit | 888511862bc7b0850e2695e3edd46212dc78cc47 (patch) | |
| tree | 572598e6b335008a71d6bc76faf6c5be7185d91c /src | |
| parent | 212cb13ca4526350ce761378505536fafb559eab (diff) | |
| parent | 6436908ffe1906804a13073dd474e109e8be1d91 (diff) | |
| download | rneovim-888511862bc7b0850e2695e3edd46212dc78cc47.tar.gz rneovim-888511862bc7b0850e2695e3edd46212dc78cc47.tar.bz2 rneovim-888511862bc7b0850e2695e3edd46212dc78cc47.zip | |
Merge PR #1591 'Prepare to rewrite the terminal UI'
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/ex_cmds.c | 1 | ||||
| -rw-r--r-- | src/nvim/ex_cmds2.c | 1 | ||||
| -rw-r--r-- | src/nvim/ex_docmd.c | 6 | ||||
| -rw-r--r-- | src/nvim/ex_getln.c | 5 | ||||
| -rw-r--r-- | src/nvim/fileio.c | 4 | ||||
| -rw-r--r-- | src/nvim/main.c | 3 | ||||
| -rw-r--r-- | src/nvim/misc1.c | 3 | ||||
| -rw-r--r-- | src/nvim/mouse.c | 67 | ||||
| -rw-r--r-- | src/nvim/normal.c | 9 | ||||
| -rw-r--r-- | src/nvim/option.c | 3 | ||||
| -rw-r--r-- | src/nvim/os/shell.c | 10 | ||||
| -rw-r--r-- | src/nvim/os/time.c | 30 | ||||
| -rw-r--r-- | src/nvim/os_unix.c | 1 | ||||
| -rw-r--r-- | src/nvim/screen.c | 98 | ||||
| -rw-r--r-- | src/nvim/search.c | 1 | ||||
| -rw-r--r-- | src/nvim/term.c | 200 | ||||
| -rw-r--r-- | src/nvim/term.h | 4 | ||||
| -rw-r--r-- | src/nvim/window.c | 1 | 
18 files changed, 199 insertions, 248 deletions
| diff --git a/src/nvim/ex_cmds.c b/src/nvim/ex_cmds.c index 0829049e4d..7c6e046133 100644 --- a/src/nvim/ex_cmds.c +++ b/src/nvim/ex_cmds.c @@ -47,6 +47,7 @@  #include "nvim/garray.h"  #include "nvim/memory.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/normal.h"  #include "nvim/ops.h"  #include "nvim/option.h" diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c index 24a1ccf85d..794e9930b9 100644 --- a/src/nvim/ex_cmds2.c +++ b/src/nvim/ex_cmds2.c @@ -157,7 +157,6 @@ void do_debug(char_u *cmd)    /* Make sure we are in raw mode and start termcap mode.  Might have side     * effects... */ -  settmode(TMODE_RAW);    starttermcap();    ++RedrawingDisabled;          /* don't redisplay the window */ diff --git a/src/nvim/ex_docmd.c b/src/nvim/ex_docmd.c index 706aef0133..e180be4421 100644 --- a/src/nvim/ex_docmd.c +++ b/src/nvim/ex_docmd.c @@ -5107,7 +5107,6 @@ static void ex_highlight(exarg_T *eap)  void not_exiting(void)  {    exiting = FALSE; -  settmode(TMODE_RAW);  }  /* @@ -5994,7 +5993,6 @@ do_exedit (  {    int n;    int need_hide; -  int exmode_was = exmode_active;    /*     * ":vi" command ends Ex mode. @@ -6014,8 +6012,6 @@ do_exedit (            eap->nextcmd = NULL;          } -        if (exmode_was != EXMODE_VIM) -          settmode(TMODE_RAW);          RedrawingDisabled = 0;          no_wait_return = 0;          need_wait_return = FALSE; @@ -6446,7 +6442,7 @@ static void ex_winsize(exarg_T *eap)    p = arg;    h = getdigits(&arg);    if (*p != NUL && *arg == NUL) -    set_shellsize(w, h, TRUE); +    screen_resize(w, h, TRUE);    else      EMSG(_("E465: :winsize requires two number arguments"));  } diff --git a/src/nvim/ex_getln.c b/src/nvim/ex_getln.c index 70db2dc479..e56592923d 100644 --- a/src/nvim/ex_getln.c +++ b/src/nvim/ex_getln.c @@ -48,6 +48,7 @@  #include "nvim/keymap.h"  #include "nvim/garray.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/ops.h"  #include "nvim/option.h"  #include "nvim/os_unix.h" @@ -270,10 +271,6 @@ getcmdline (    setmouse();    ui_cursor_shape();            /* may show different cursor shape */ -  /* When inside an autocommand for writing "exiting" may be set and -  * terminal mode set to cooked.  Need to set raw mode here then. */ -  settmode(TMODE_RAW); -    init_history();    hiscnt = hislen;              /* set hiscnt to impossible history value */    histype = hist_char2type(firstc); diff --git a/src/nvim/fileio.c b/src/nvim/fileio.c index 3be9d89d87..021b12208e 100644 --- a/src/nvim/fileio.c +++ b/src/nvim/fileio.c @@ -1812,7 +1812,6 @@ failed:       * Switch on raw mode now and clear the screen.       */      if (read_stdin) { -      settmode(TMODE_RAW);              /* set to raw mode */        starttermcap();        screenclear();      } @@ -2387,9 +2386,6 @@ buf_write (    else      overwriting = FALSE; -  if (exiting) -    settmode(TMODE_COOK);           /* when exiting allow typeahead now */ -    ++no_wait_return;                 /* don't wait for return yet */    /* diff --git a/src/nvim/main.c b/src/nvim/main.c index 54077acfe3..8e19cf3686 100644 --- a/src/nvim/main.c +++ b/src/nvim/main.c @@ -43,6 +43,7 @@  #include "nvim/log.h"  #include "nvim/memory.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/normal.h"  #include "nvim/ops.h"  #include "nvim/option.h" @@ -281,7 +282,7 @@ int main(int argc, char **argv)        // In embedded mode don't do terminal-related initializations, assume an        // initial screen size of 80x20        full_screen = true; -      set_shellsize(80, 20, false); +      screen_resize(80, 20, false);      } else {        // set terminal name and get terminal capabilities (will set full_screen)        // Do some initialization of the screen diff --git a/src/nvim/misc1.c b/src/nvim/misc1.c index 230e198121..fc848466c6 100644 --- a/src/nvim/misc1.c +++ b/src/nvim/misc1.c @@ -42,6 +42,7 @@  #include "nvim/misc2.h"  #include "nvim/garray.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/option.h"  #include "nvim/os_unix.h"  #include "nvim/path.h" @@ -2286,8 +2287,6 @@ int ask_yesno(char_u *str, int direct)    int r = ' ';    int save_State = State; -  if (exiting)                  /* put terminal in raw mode for this question */ -    settmode(TMODE_RAW);    ++no_wait_return;  #ifdef USE_ON_FLY_SCROLL    dont_scroll = TRUE;           /* disallow scrolling here */ diff --git a/src/nvim/mouse.c b/src/nvim/mouse.c index 7fc581a7c0..439cdbd5c8 100644 --- a/src/nvim/mouse.c +++ b/src/nvim/mouse.c @@ -2,8 +2,12 @@  #include "nvim/mouse.h"  #include "nvim/vim.h" -#include "nvim/screen.h" +#include "nvim/ascii.h"  #include "nvim/window.h" +#include "nvim/strings.h" +#include "nvim/screen.h" +#include "nvim/ui.h" +#include "nvim/os_unix.h"  #include "nvim/term.h"  #include "nvim/fold.h"  #include "nvim/diff.h" @@ -165,11 +169,9 @@ retnomove:      // (MOUSE_FOCUS was set above if we dragged first).      if (dragwin == NULL || (flags & MOUSE_RELEASED))        win_enter(wp, true);                      // can make wp invalid! -# ifdef CHECK_DOUBLE_CLICK      // set topline, to be able to check for double click ourselves      if (curwin != old_curwin)        set_mouse_topline(curwin); -# endif      if (on_status_line) {                       // In (or below) status line        // Don't use start_arrow() if we're in the same window        if (curwin == old_curwin) @@ -436,3 +438,62 @@ win_T *mouse_find_win(int *rowp, int *colp)    }    return fp->fr_win;  } + +/* + * setmouse() - switch mouse on/off depending on current mode and 'mouse' + */ +void setmouse(void) +{ +  int checkfor; + + +  /* be quick when mouse is off */ +  if (*p_mouse == NUL) +    return; + +  /* don't switch mouse on when not in raw mode (Ex mode) */ +  if (cur_tmode != TMODE_RAW) { +    mch_setmouse(false); +    return; +  } + +  if (VIsual_active) +    checkfor = MOUSE_VISUAL; +  else if (State == HITRETURN || State == ASKMORE || State == SETWSIZE) +    checkfor = MOUSE_RETURN; +  else if (State & INSERT) +    checkfor = MOUSE_INSERT; +  else if (State & CMDLINE) +    checkfor = MOUSE_COMMAND; +  else if (State == CONFIRM || State == EXTERNCMD) +    checkfor = ' ';     /* don't use mouse for ":confirm" or ":!cmd" */ +  else +    checkfor = MOUSE_NORMAL;        /* assume normal mode */ + +  if (mouse_has(checkfor)) +    mch_setmouse(true); +  else +    mch_setmouse(false); +} + +/* + * Return true if + * - "c" is in 'mouse', or + * - 'a' is in 'mouse' and "c" is in MOUSE_A, or + * - the current buffer is a help file and 'h' is in 'mouse' and we are in a + *   normal editing mode (not at hit-return message). + */ +int mouse_has(int c) +{ +  for (char_u *p = p_mouse; *p; ++p) +    switch (*p) { +    case 'a': if (vim_strchr((char_u *)MOUSE_A, c) != NULL) +        return true; +      break; +    case MOUSE_HELP: if (c != MOUSE_RETURN && curbuf->b_help) +        return true; +      break; +    default: if (c == *p) return true; break; +    } +  return false; +} diff --git a/src/nvim/normal.c b/src/nvim/normal.c index 0a43d59607..1b21100933 100644 --- a/src/nvim/normal.c +++ b/src/nvim/normal.c @@ -46,6 +46,7 @@  #include "nvim/misc2.h"  #include "nvim/keymap.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/ops.h"  #include "nvim/option.h"  #include "nvim/quickfix.h" @@ -7374,3 +7375,11 @@ static void nv_cursorhold(cmdarg_T *cap)    did_cursorhold = true;    cap->retval |= CA_COMMAND_BUSY;       /* don't call edit() now */  } + +/* + * Return TRUE when 'mousemodel' is set to "popup" or "popup_setpos". + */ +static int mouse_model_popup(void) +{ +  return p_mousem[0] == 'p'; +} diff --git a/src/nvim/option.c b/src/nvim/option.c index ee70b5bf8a..2882d7a511 100644 --- a/src/nvim/option.c +++ b/src/nvim/option.c @@ -66,6 +66,7 @@  #include "nvim/garray.h"  #include "nvim/cursor_shape.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/normal.h"  #include "nvim/os_unix.h"  #include "nvim/path.h" @@ -5540,7 +5541,7 @@ set_num_option (        *pp = old_value;      else if (full_screen               ) -      set_shellsize((int)Columns, (int)Rows, TRUE); +      screen_resize((int)Columns, (int)Rows, TRUE);      else {        /* Postpone the resizing; check the size and cmdline position for         * messages. */ diff --git a/src/nvim/os/shell.c b/src/nvim/os/shell.c index 1b279f18f5..cdd85e4e96 100644 --- a/src/nvim/os/shell.c +++ b/src/nvim/os/shell.c @@ -104,14 +104,10 @@ int os_call_shell(char_u *cmd, ShellOpts opts, char_u *extra_arg)  {    DynamicBuffer input = DYNAMIC_BUFFER_INIT;    char *output = NULL, **output_ptr = NULL; -  int current_state = State, old_mode = cur_tmode; +  int current_state = State;    bool forward_output = true;    out_flush(); -  if (opts & kShellOptCooked) { -    settmode(TMODE_COOK); -  } -    // While the child is running, ignore terminating signals    signal_reject_deadly(); @@ -155,10 +151,6 @@ int os_call_shell(char_u *cmd, ShellOpts opts, char_u *extra_arg)      msg_putchar('\n');    } -  if (old_mode == TMODE_RAW) { -    // restore mode -    settmode(TMODE_RAW); -  }    State = current_state;    signal_accept_deadly(); diff --git a/src/nvim/os/time.c b/src/nvim/os/time.c index a4871ef499..3794e813d2 100644 --- a/src/nvim/os/time.c +++ b/src/nvim/os/time.c @@ -6,6 +6,7 @@  #include <uv.h>  #include "nvim/os/time.h" +#include "nvim/os/event.h"  #include "nvim/vim.h"  #include "nvim/term.h" @@ -38,31 +39,22 @@ uint64_t os_hrtime(void)  /// @param ignoreinput If true, allow a SIGINT to interrupt us  void os_delay(uint64_t milliseconds, bool ignoreinput)  { -  os_microdelay(milliseconds * 1000, ignoreinput); +  if (ignoreinput) { +    if (milliseconds > INT_MAX) { +      milliseconds = INT_MAX; +    } +    event_poll_until((int)milliseconds, got_int); +  } else { +    os_microdelay(milliseconds * 1000); +  }  }  /// Sleeps for a certain amount of microseconds  ///  /// @param microseconds Number of microseconds to sleep -/// @param ignoreinput If true, allow a SIGINT to interrupt us -void os_microdelay(uint64_t microseconds, bool ignoreinput) +void os_microdelay(uint64_t microseconds)  { -  int old_tmode; - -  if (ignoreinput) { -    // Go to cooked mode without echo, to allow SIGINT interrupting us -    // here -    old_tmode = curr_tmode; - -    if (curr_tmode == TMODE_RAW) -      settmode(TMODE_SLEEP); - -    microdelay(microseconds); - -    settmode(old_tmode); -  } else { -    microdelay(microseconds); -  } +  microdelay(microseconds);  }  /// Portable version of POSIX localtime_r() diff --git a/src/nvim/os_unix.c b/src/nvim/os_unix.c index 8784559b50..677976e3e1 100644 --- a/src/nvim/os_unix.c +++ b/src/nvim/os_unix.c @@ -37,6 +37,7 @@  #include "nvim/message.h"  #include "nvim/misc1.h"  #include "nvim/misc2.h" +#include "nvim/mouse.h"  #include "nvim/garray.h"  #include "nvim/path.h"  #include "nvim/screen.h" diff --git a/src/nvim/screen.c b/src/nvim/screen.c index 2dbf3f8888..0225eb72c1 100644 --- a/src/nvim/screen.c +++ b/src/nvim/screen.c @@ -103,6 +103,7 @@  #include "nvim/ex_cmds.h"  #include "nvim/ex_cmds2.h"  #include "nvim/ex_getln.h" +#include "nvim/edit.h"  #include "nvim/farsi.h"  #include "nvim/fileio.h"  #include "nvim/fold.h" @@ -120,6 +121,7 @@  #include "nvim/move.h"  #include "nvim/normal.h"  #include "nvim/option.h" +#include "nvim/os_unix.h"  #include "nvim/path.h"  #include "nvim/popupmnu.h"  #include "nvim/quickfix.h" @@ -129,6 +131,7 @@  #include "nvim/strings.h"  #include "nvim/syntax.h"  #include "nvim/term.h" +#include "nvim/ui.h"  #include "nvim/undo.h"  #include "nvim/version.h"  #include "nvim/window.h" @@ -8117,3 +8120,98 @@ int screen_screenrow(void)    return screen_cur_row;  } +/* + * Set size of the Vim shell. + * If 'mustset' is TRUE, we must set Rows and Columns, do not get the real + * window size (this is used for the :win command). + * If 'mustset' is FALSE, we may try to get the real window size and if + * it fails use 'width' and 'height'. + */ +void screen_resize(int width, int height, int mustset) +{ +  static int busy = FALSE; + +  /* +   * Avoid recursiveness, can happen when setting the window size causes +   * another window-changed signal. +   */ +  if (busy) +    return; + +  if (width < 0 || height < 0)      /* just checking... */ +    return; + +  if (State == HITRETURN || State == SETWSIZE) { +    /* postpone the resizing */ +    State = SETWSIZE; +    return; +  } + +  /* curwin->w_buffer can be NULL when we are closing a window and the +   * buffer has already been closed and removing a scrollbar causes a resize +   * event. Don't resize then, it will happen after entering another buffer. +   */ +  if (curwin->w_buffer == NULL) +    return; + +  ++busy; + + +  if (mustset || (ui_get_shellsize() == FAIL && height != 0)) { +    Rows = height; +    Columns = width; +    check_shellsize(); +    mch_set_shellsize(); +  } else +    check_shellsize(); + +  /* The window layout used to be adjusted here, but it now happens in +   * screenalloc() (also invoked from screenclear()).  That is because the +   * "busy" check above may skip this, but not screenalloc(). */ + +  if (State != ASKMORE && State != EXTERNCMD && State != CONFIRM) +    screenclear(); +  else +    screen_start();         /* don't know where cursor is now */ + +  if (starting != NO_SCREEN) { +    maketitle(); +    changed_line_abv_curs(); +    invalidate_botline(); + +    /* +     * We only redraw when it's needed: +     * - While at the more prompt or executing an external command, don't +     *   redraw, but position the cursor. +     * - While editing the command line, only redraw that. +     * - in Ex mode, don't redraw anything. +     * - Otherwise, redraw right now, and position the cursor. +     * Always need to call update_screen() or screenalloc(), to make +     * sure Rows/Columns and the size of ScreenLines[] is correct! +     */ +    if (State == ASKMORE || State == EXTERNCMD || State == CONFIRM +        || exmode_active) { +      screenalloc(false); +      repeat_message(); +    } else { +      if (curwin->w_p_scb) +        do_check_scrollbind(TRUE); +      if (State & CMDLINE) { +        update_screen(NOT_VALID); +        redrawcmdline(); +      } else { +        update_topline(); +        if (pum_visible()) { +          redraw_later(NOT_VALID); +          ins_compl_show_pum();           /* This includes the redraw. */ +        } else +          update_screen(NOT_VALID); +        if (redrawing()) +          setcursor(); +      } +    } +    cursor_on();            /* redrawing may have switched it off */ +  } +  out_flush(); +  --busy; +} diff --git a/src/nvim/search.c b/src/nvim/search.c index e9184d84cd..3055729bf8 100644 --- a/src/nvim/search.c +++ b/src/nvim/search.c @@ -39,6 +39,7 @@  #include "nvim/misc1.h"  #include "nvim/misc2.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/normal.h"  #include "nvim/option.h"  #include "nvim/path.h" diff --git a/src/nvim/term.c b/src/nvim/term.c index 9da7e11b96..54508b1daa 100644 --- a/src/nvim/term.c +++ b/src/nvim/term.c @@ -43,6 +43,7 @@  #include "nvim/keymap.h"  #include "nvim/memory.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/normal.h"  #include "nvim/option.h"  #include "nvim/os_unix.h" @@ -1472,7 +1473,7 @@ int set_termname(char_u *term)      width = 80;      height = 24;            /* most terminals are 24 lines */    } -  set_shellsize(width, height, FALSE);          /* may change Rows */ +  screen_resize(width, height, FALSE);          /* may change Rows */    if (starting != NO_SCREEN) {      if (scroll_region)        scroll_region_reset();                    /* In case Rows changed */ @@ -1506,7 +1507,6 @@ int set_termname(char_u *term)  #  define HMT_PTERM     8  #  define HMT_URXVT     16  #  define HMT_SGR       32 -static int has_mouse_termcode = 0;  void   set_mouse_termcode ( @@ -1517,16 +1517,6 @@ set_mouse_termcode (    char_u name[2] = { n, KE_FILLER };    add_termcode(name, s, FALSE); -  if (n == KS_NETTERM_MOUSE) -    has_mouse_termcode |= HMT_NETTERM; -  else if (n == KS_DEC_MOUSE) -    has_mouse_termcode |= HMT_DEC; -  else if (n == KS_URXVT_MOUSE) -    has_mouse_termcode |= HMT_URXVT; -  else if (n == KS_SGR_MOUSE) -    has_mouse_termcode |= HMT_SGR; -  else -    has_mouse_termcode |= HMT_NORMAL;  }  # if (defined(UNIX) && defined(FEAT_MOUSE_TTY)) || defined(PROTO) @@ -1538,16 +1528,6 @@ del_mouse_termcode (    char_u name[2] = { n, KE_FILLER };    del_termcode(name); -  if (n == KS_NETTERM_MOUSE) -    has_mouse_termcode &= ~HMT_NETTERM; -  else if (n == KS_DEC_MOUSE) -    has_mouse_termcode &= ~HMT_DEC; -  else if (n == KS_URXVT_MOUSE) -    has_mouse_termcode &= ~HMT_URXVT; -  else if (n == KS_SGR_MOUSE) -    has_mouse_termcode &= ~HMT_SGR; -  else -    has_mouse_termcode &= ~HMT_NORMAL;  }  # endif @@ -1865,7 +1845,7 @@ void term_write(char_u *s, size_t len)  #ifdef UNIX    if (p_wd) {           // Unix is too fast, slow down a bit more -    os_microdelay(p_wd, false); +    os_microdelay(p_wd);    }  #endif  } @@ -2289,7 +2269,7 @@ void win_new_shellsize(void)   */  void shell_resized(void)  { -  set_shellsize(0, 0, FALSE); +  screen_resize(0, 0, FALSE);  }  /* @@ -2311,102 +2291,6 @@ void shell_resized_check(void)  }  /* - * Set size of the Vim shell. - * If 'mustset' is TRUE, we must set Rows and Columns, do not get the real - * window size (this is used for the :win command). - * If 'mustset' is FALSE, we may try to get the real window size and if - * it fails use 'width' and 'height'. - */ -void set_shellsize(int width, int height, int mustset) -{ -  static int busy = FALSE; - -  /* -   * Avoid recursiveness, can happen when setting the window size causes -   * another window-changed signal. -   */ -  if (busy) -    return; - -  if (width < 0 || height < 0)      /* just checking... */ -    return; - -  if (State == HITRETURN || State == SETWSIZE) { -    /* postpone the resizing */ -    State = SETWSIZE; -    return; -  } - -  /* curwin->w_buffer can be NULL when we are closing a window and the -   * buffer has already been closed and removing a scrollbar causes a resize -   * event. Don't resize then, it will happen after entering another buffer. -   */ -  if (curwin->w_buffer == NULL) -    return; - -  ++busy; - - -  if (mustset || (ui_get_shellsize() == FAIL && height != 0)) { -    Rows = height; -    Columns = width; -    check_shellsize(); -    mch_set_shellsize(); -  } else -    check_shellsize(); - -  /* The window layout used to be adjusted here, but it now happens in -   * screenalloc() (also invoked from screenclear()).  That is because the -   * "busy" check above may skip this, but not screenalloc(). */ - -  if (State != ASKMORE && State != EXTERNCMD && State != CONFIRM) -    screenclear(); -  else -    screen_start();         /* don't know where cursor is now */ - -  if (starting != NO_SCREEN) { -    maketitle(); -    changed_line_abv_curs(); -    invalidate_botline(); - -    /* -     * We only redraw when it's needed: -     * - While at the more prompt or executing an external command, don't -     *   redraw, but position the cursor. -     * - While editing the command line, only redraw that. -     * - in Ex mode, don't redraw anything. -     * - Otherwise, redraw right now, and position the cursor. -     * Always need to call update_screen() or screenalloc(), to make -     * sure Rows/Columns and the size of ScreenLines[] is correct! -     */ -    if (State == ASKMORE || State == EXTERNCMD || State == CONFIRM -        || exmode_active) { -      screenalloc(false); -      repeat_message(); -    } else { -      if (curwin->w_p_scb) -        do_check_scrollbind(TRUE); -      if (State & CMDLINE) { -        update_screen(NOT_VALID); -        redrawcmdline(); -      } else { -        update_topline(); -        if (pum_visible()) { -          redraw_later(NOT_VALID); -          ins_compl_show_pum();           /* This includes the redraw. */ -        } else -          update_screen(NOT_VALID); -        if (redrawing()) -          setcursor(); -      } -    } -    cursor_on();            /* redrawing may have switched it off */ -  } -  out_flush(); -  --busy; -} - -/*   * Set the terminal to TMODE_RAW (for Normal mode) or TMODE_COOK (for external   * commands and Ex mode).   */ @@ -2641,73 +2525,6 @@ int swapping_screen(void)  }  /* - * setmouse() - switch mouse on/off depending on current mode and 'mouse' - */ -void setmouse(void) -{ -  int checkfor; - - -  /* be quick when mouse is off */ -  if (*p_mouse == NUL || has_mouse_termcode == 0) -    return; - -  /* don't switch mouse on when not in raw mode (Ex mode) */ -  if (cur_tmode != TMODE_RAW) { -    mch_setmouse(FALSE); -    return; -  } - -  if (VIsual_active) -    checkfor = MOUSE_VISUAL; -  else if (State == HITRETURN || State == ASKMORE || State == SETWSIZE) -    checkfor = MOUSE_RETURN; -  else if (State & INSERT) -    checkfor = MOUSE_INSERT; -  else if (State & CMDLINE) -    checkfor = MOUSE_COMMAND; -  else if (State == CONFIRM || State == EXTERNCMD) -    checkfor = ' ';     /* don't use mouse for ":confirm" or ":!cmd" */ -  else -    checkfor = MOUSE_NORMAL;        /* assume normal mode */ - -  if (mouse_has(checkfor)) -    mch_setmouse(TRUE); -  else -    mch_setmouse(FALSE); -} - -/* - * Return TRUE if - * - "c" is in 'mouse', or - * - 'a' is in 'mouse' and "c" is in MOUSE_A, or - * - the current buffer is a help file and 'h' is in 'mouse' and we are in a - *   normal editing mode (not at hit-return message). - */ -int mouse_has(int c) -{ -  for (char_u *p = p_mouse; *p; ++p) -    switch (*p) { -    case 'a': if (vim_strchr((char_u *)MOUSE_A, c) != NULL) -        return TRUE; -      break; -    case MOUSE_HELP: if (c != MOUSE_RETURN && curbuf->b_help) -        return TRUE; -      break; -    default: if (c == *p) return TRUE; break; -    } -  return FALSE; -} - -/* - * Return TRUE when 'mousemodel' is set to "popup" or "popup_setpos". - */ -int mouse_model_popup(void) -{ -  return p_mousem[0] == 'p'; -} - -/*   * By outputting the 'cursor very visible' termcap code, for some windowed   * terminals this makes the screen scrolled to the correct position.   * Used when starting Vim or returning from a shell. @@ -3002,11 +2819,9 @@ static void switch_to_8bit(void)    LOG_TR("Switching to 8 bit");  } -#ifdef CHECK_DOUBLE_CLICK  static linenr_T orig_topline = 0;  static int orig_topfill = 0; -#endif -#if defined(CHECK_DOUBLE_CLICK) || defined(PROTO) +  /*   * Checking for double clicks ourselves.   * "orig_topline" is used to avoid detecting a double-click when the window @@ -3021,7 +2836,6 @@ void set_mouse_topline(win_T *wp)    orig_topline = wp->w_topline;    orig_topfill = wp->w_topfill;  } -#endif  /*   * Check if typebuf.tb_buf[] contains a terminal key code. @@ -3712,7 +3526,6 @@ int check_termcode(int max_offset, char_u *buf, int bufsize, int *buflen)            is_drag = TRUE;          current_button = held_button;        } else if (wheel_code == 0)   { -# ifdef CHECK_DOUBLE_CLICK          {            static int orig_mouse_col = 0;            static int orig_mouse_row = 0; @@ -3746,9 +3559,6 @@ int check_termcode(int max_offset, char_u *buf, int bufsize, int *buflen)            orig_topline = curwin->w_topline;            orig_topfill = curwin->w_topfill;          } -# else -        orig_num_clicks = NUM_MOUSE_CLICKS(mouse_code); -# endif          is_click = TRUE;          orig_mouse_code = mouse_code;        } diff --git a/src/nvim/term.h b/src/nvim/term.h index 17154b8c26..3f70f484a7 100644 --- a/src/nvim/term.h +++ b/src/nvim/term.h @@ -52,10 +52,6 @@   * 128 = 16384 columns, now it's reduced to 10000. */  #define MOUSE_COLOFF 10000 -#if defined(UNIX) -# define CHECK_DOUBLE_CLICK 1  /* Checking for double clicks ourselves. */ -#endif -  #ifdef INCLUDE_GENERATED_DECLARATIONS  # include "term.h.generated.h"  #endif diff --git a/src/nvim/window.c b/src/nvim/window.c index 315d5f07de..bd461a873f 100644 --- a/src/nvim/window.c +++ b/src/nvim/window.c @@ -41,6 +41,7 @@  #include "nvim/file_search.h"  #include "nvim/garray.h"  #include "nvim/move.h" +#include "nvim/mouse.h"  #include "nvim/normal.h"  #include "nvim/option.h"  #include "nvim/os_unix.h" | 
