diff options
Diffstat (limited to 'src/nvim/syntax.c')
| -rw-r--r-- | src/nvim/syntax.c | 25 | 
1 files changed, 20 insertions, 5 deletions
| diff --git a/src/nvim/syntax.c b/src/nvim/syntax.c index 821411ec7b..b7d8a19de9 100644 --- a/src/nvim/syntax.c +++ b/src/nvim/syntax.c @@ -41,6 +41,8 @@  #include "nvim/os/os.h"  #include "nvim/os/time.h" +static bool did_syntax_onoff = false; +  // Structure that stores information about a highlight group.  // The ID of a highlight group is also called group ID.  It is the index in  // the highlight_ga array PLUS ONE. @@ -3286,17 +3288,28 @@ static void syn_cmd_off(exarg_T *eap, int syncing)  }  static void syn_cmd_onoff(exarg_T *eap, char *name) +  FUNC_ATTR_NONNULL_ALL  { -  char buf[100]; - +  did_syntax_onoff = true;    eap->nextcmd = check_nextcmd(eap->arg);    if (!eap->skip) { -    strcpy(buf, "so "); +    char buf[100]; +    strncpy(buf, "so ", 3);      vim_snprintf(buf + 3, sizeof(buf) - 3, SYNTAX_FNAME, name);      do_cmdline_cmd(buf);    }  } +void syn_maybe_on(void) +{ +  if (!did_syntax_onoff) { +    exarg_T ea; +    ea.arg = (char_u *)""; +    ea.skip = false; +    syn_cmd_onoff(&ea, "syntax"); +  } +} +  /*   * Handle ":syntax [list]" command: list current syntax words.   */ @@ -5406,8 +5419,10 @@ void ex_ownsyntax(exarg_T *eap)    if (curwin->w_s == &curwin->w_buffer->b_s) {      curwin->w_s = xmalloc(sizeof(synblock_T));      memset(curwin->w_s, 0, sizeof(synblock_T)); -    // TODO: Keep the spell checking as it was. -    curwin->w_p_spell = FALSE;          /* No spell checking */ +    hash_init(&curwin->w_s->b_keywtab); +    hash_init(&curwin->w_s->b_keywtab_ic); +    // TODO: Keep the spell checking as it was. NOLINT(readability/todo) +    curwin->w_p_spell = false;  // No spell checking      clear_string_option(&curwin->w_s->b_p_spc);      clear_string_option(&curwin->w_s->b_p_spf);      clear_string_option(&curwin->w_s->b_p_spl); | 
