diff options
| -rw-r--r-- | src/nvim/eval.c | 7 | ||||
| -rw-r--r-- | src/nvim/eval/typval.h | 2 | ||||
| -rw-r--r-- | src/nvim/ex_cmds2.c | 3 | ||||
| -rw-r--r-- | src/nvim/ex_getln.c | 70 | ||||
| -rw-r--r-- | src/nvim/ex_getln.h | 2 | 
5 files changed, 44 insertions, 40 deletions
| diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 694c34731d..afa6711645 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -11108,13 +11108,10 @@ void get_user_input(const typval_T *const argvars,    stuffReadbuffSpec(defstr);    const int save_ex_normal_busy = ex_normal_busy; -  const Callback save_getln_input_callback = getln_input_callback;    ex_normal_busy = 0; -  getln_input_callback = input_callback;    rettv->vval.v_string = -    getcmdline_prompt(inputsecret_flag ? NUL : '@', (char_u *)p, echo_attr, -                      xp_type, (char_u *)xp_arg); -  getln_input_callback = save_getln_input_callback; +    (char_u *)getcmdline_prompt(inputsecret_flag ? NUL : '@', p, echo_attr, +                                xp_type, xp_arg, input_callback);    ex_normal_busy = save_ex_normal_busy;    callback_free(&input_callback); diff --git a/src/nvim/eval/typval.h b/src/nvim/eval/typval.h index 3f8ed3b3f9..c44b85644d 100644 --- a/src/nvim/eval/typval.h +++ b/src/nvim/eval/typval.h @@ -43,7 +43,7 @@ typedef struct partial_S partial_T;  typedef struct ufunc ufunc_T;  typedef enum { -  kCallbackNone, +  kCallbackNone = 0,    kCallbackFuncref,    kCallbackPartial,  } CallbackType; diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c index 1a728647ca..79882973b1 100644 --- a/src/nvim/ex_cmds2.c +++ b/src/nvim/ex_cmds2.c @@ -189,7 +189,8 @@ void do_debug(char_u *cmd)      }      xfree(cmdline); -    cmdline = getcmdline_prompt('>', NULL, 0, EXPAND_NOTHING, NULL); +    cmdline = (char_u *)getcmdline_prompt('>', NULL, 0, EXPAND_NOTHING, NULL, +                                          CALLBACK_NONE);      if (typeahead_saved) {        restore_typeahead(&typeaheadbuf); diff --git a/src/nvim/ex_getln.c b/src/nvim/ex_getln.c index 9bcabeee72..13bae4dadc 100644 --- a/src/nvim/ex_getln.c +++ b/src/nvim/ex_getln.c @@ -89,6 +89,7 @@ struct cmdline_info {    char_u      *xp_arg;          // user-defined expansion arg    int input_fn;                 // when TRUE Invoked for input() function    unsigned prompt_id;  ///< Prompt number, used to disable coloring on errors. +  Callback highlight_callback;  ///< Callback used for coloring user input.  };  /// Last value of prompt_id, incremented when doing new prompt  static unsigned last_prompt_id = 0; @@ -148,9 +149,6 @@ typedef struct {    int attr;  ///< Highlight attr.  } ColoredCmdlineChunk; -/// Callback used for coloring input() prompts -Callback getln_input_callback = { .type = kCallbackNone }; -  kvec_t(ColoredCmdlineChunk) ccline_colors;  /* The current cmdline_info.  It is initialized in getcmdline() and after that @@ -1815,42 +1813,50 @@ getcmdline (    return command_line_enter(firstc, count, indent);  } -/* - * Get a command line with a prompt. - * This is prepared to be called recursively from getcmdline() (e.g. by - * f_input() when evaluating an expression from CTRL-R =). - * Returns the command line in allocated memory, or NULL. - */ -char_u * -getcmdline_prompt ( -    int firstc, -    char_u *prompt,            /* command line prompt */ -    int attr,                       /* attributes for prompt */ -    int xp_context,                 /* type of expansion */ -    char_u *xp_arg            /* user-defined expansion argument */ -) +/// Get a command line with a prompt +/// +/// This is prepared to be called recursively from getcmdline() (e.g. by +/// f_input() when evaluating an expression from `<C-r>=`). +/// +/// @param[in]  firstc  Prompt type: e.g. '@' for input(), '>' for debug. +/// @param[in]  prompt  Prompt string: what is displayed before the user text. +/// @param[in]  attr  Prompt highlighting. +/// @param[in]  xp_context  Type of expansion. +/// @param[in]  xp_arg  User-defined expansion argument. +/// @param[in]  highlight_callback  Callback used for highlighting user input. +/// +/// @return [allocated] Command line or NULL. +char *getcmdline_prompt(const char firstc, const char *const prompt, +                        const int attr, const int xp_context, +                        const char *const xp_arg, +                        const Callback highlight_callback) +  FUNC_ATTR_WARN_UNUSED_RESULT FUNC_ATTR_MALLOC  { -  char_u              *s; -  struct cmdline_info save_ccline; -  int msg_col_save = msg_col; +  const int msg_col_save = msg_col; +  struct cmdline_info save_ccline;    save_cmdline(&save_ccline); +    ccline.prompt_id = last_prompt_id++; -  ccline.cmdprompt = prompt; +  ccline.cmdprompt = (char_u *)prompt;    ccline.cmdattr = attr;    ccline.xp_context = xp_context; -  ccline.xp_arg = xp_arg; +  ccline.xp_arg = (char_u *)xp_arg;    ccline.input_fn = (firstc == '@'); -  s = getcmdline(firstc, 1L, 0); +  ccline.highlight_callback = highlight_callback; + +  char *const ret = (char *)getcmdline(firstc, 1L, 0); +    restore_cmdline(&save_ccline); -  /* Restore msg_col, the prompt from input() may have changed it. -   * But only if called recursively and the commandline is therefore being -   * restored to an old one; if not, the input() prompt stays on the screen, -   * so we need its modified msg_col left intact. */ -  if (ccline.cmdbuff != NULL) +  // Restore msg_col, the prompt from input() may have changed it. +  // But only if called recursively and the commandline is therefore being +  // restored to an old one; if not, the input() prompt stays on the screen, +  // so we need its modified msg_col left intact. +  if (ccline.cmdbuff != NULL) {      msg_col = msg_col_save; +  } -  return s; +  return ret;  }  /* @@ -2358,8 +2364,10 @@ static bool color_cmdline(void)    bool dgc_ret = true;    bool tl_ret = true; -  if (ccline.input_fn) { -    color_cb = getln_input_callback; +  if (ccline.highlight_callback.type != kCallbackNone) { +    // Currently this should only happen while processing input() prompts. +    assert(ccline.input_fn); +    color_cb = ccline.highlight_callback;    } else if (ccline.cmdfirstc == ':') {      try_enter(&tstate);      err_errmsg = N_( diff --git a/src/nvim/ex_getln.h b/src/nvim/ex_getln.h index 92cb274010..051564fbe1 100644 --- a/src/nvim/ex_getln.h +++ b/src/nvim/ex_getln.h @@ -52,8 +52,6 @@ typedef struct hist_entry {    list_T *additional_elements;  ///< Additional entries from ShaDa file.  } histentry_T; -extern Callback getln_input_callback; -  #ifdef INCLUDE_GENERATED_DECLARATIONS  # include "ex_getln.h.generated.h"  #endif | 
