diff options
Diffstat (limited to 'src/nvim/ex_eval.c')
| -rw-r--r-- | src/nvim/ex_eval.c | 49 | 
1 files changed, 27 insertions, 22 deletions
| diff --git a/src/nvim/ex_eval.c b/src/nvim/ex_eval.c index 4bb6f97035..65112c4dd8 100644 --- a/src/nvim/ex_eval.c +++ b/src/nvim/ex_eval.c @@ -1,6 +1,8 @@ -/* - * ex_eval.c: functions for Ex command line for the +eval feature. - */ +// TODO(ZyX-I): move to eval/executor + +/// @file ex_eval.c +/// +/// Functions for Ex command line for the +eval feature.  #include <assert.h>  #include <stdbool.h>  #include <stdint.h> @@ -12,6 +14,7 @@  #include "nvim/ex_eval.h"  #include "nvim/charset.h"  #include "nvim/eval.h" +#include "nvim/eval/typval.h"  #include "nvim/ex_cmds2.h"  #include "nvim/ex_docmd.h"  #include "nvim/message.h" @@ -19,8 +22,6 @@  #include "nvim/regexp.h"  #include "nvim/strings.h" - -  #ifdef INCLUDE_GENERATED_DECLARATIONS  # include "ex_eval.c.generated.h"  #endif @@ -57,12 +58,14 @@   * is an error exception.)  -  The macros can be defined as expressions checking   * for a variable that is allowed to be changed during execution of a script.   */ -/* Values used for the Vim release. */ -# define THROW_ON_ERROR         TRUE -# define THROW_ON_ERROR_TRUE -# define THROW_ON_INTERRUPT     TRUE -# define THROW_ON_INTERRUPT_TRUE +// Values used for the Vim release. +#define THROW_ON_ERROR true +#define THROW_ON_ERROR_TRUE +#define THROW_ON_INTERRUPT true +#define THROW_ON_INTERRUPT_TRUE + +#define discard_pending_return(p) tv_free((typval_T *)(p))  /*   * When several errors appear in a row, setting "force_abort" is delayed until @@ -779,7 +782,6 @@ void report_discard_pending(int pending, void *value)   */  void ex_if(exarg_T *eap)  { -  int error;    int skip;    int result;    struct condstack    *cstack = eap->cstack; @@ -800,6 +802,7 @@ void ex_if(exarg_T *eap)                                                                        1] &                                                       CSF_ACTIVE)); +    bool error;      result = eval_to_bool(eap->arg, &error, &eap->nextcmd, skip);      if (!skip && !error) { @@ -844,7 +847,6 @@ void ex_endif(exarg_T *eap)   */  void ex_else(exarg_T *eap)  { -  int error;    int skip;    int result;    struct condstack    *cstack = eap->cstack; @@ -901,6 +903,7 @@ void ex_else(exarg_T *eap)    }    if (eap->cmdidx == CMD_elseif) { +    bool error;      result = eval_to_bool(eap->arg, &error, &eap->nextcmd, skip);      /* When throwing error exceptions, we want to throw always the first       * of several errors in a row.  This is what actually happens when @@ -925,7 +928,7 @@ void ex_else(exarg_T *eap)   */  void ex_while(exarg_T *eap)  { -  int error; +  bool error;    int skip;    int result;    struct condstack    *cstack = eap->cstack; @@ -1147,23 +1150,25 @@ void ex_endwhile(exarg_T *eap)   */  void ex_throw(exarg_T *eap)  { -  char_u      *arg = eap->arg; -  char_u      *value; +  const char *arg = (const char *)eap->arg; +  char *value; -  if (*arg != NUL && *arg != '|' && *arg != '\n') -    value = eval_to_string_skip(arg, &eap->nextcmd, eap->skip); -  else { +  if (*arg != NUL && *arg != '|' && *arg != '\n') { +    value = eval_to_string_skip(arg, (const char **)&eap->nextcmd, +                                (bool)eap->skip); +  } else {      EMSG(_(e_argreq));      value = NULL;    } -  /* On error or when an exception is thrown during argument evaluation, do -   * not throw. */ +  // On error or when an exception is thrown during argument evaluation, do +  // not throw.    if (!eap->skip && value != NULL) { -    if (throw_exception(value, ET_USER, NULL) == FAIL) +    if (throw_exception((char_u *)value, ET_USER, NULL) == FAIL) {        xfree(value); -    else +    } else {        do_throw(eap->cstack); +    }    }  } | 
