changeset 26199:eaa97adb0732 v8.2.3631

patch 8.2.3631: "syntax enable" does not work properly in Vim9 context Commit: https://github.com/vim/vim/commit/c8a9fe541d3bee36d2760ed156997ddbb0142ee1 Author: Bram Moolenaar <Bram@vim.org> Date: Sat Nov 20 19:50:59 2021 +0000 patch 8.2.3631: "syntax enable" does not work properly in Vim9 context Problem: "syntax enable" does not work properly in Vim9 context. Solution: Also handle Vim9 context. (closes https://github.com/vim/vim/issues/9161)
author Bram Moolenaar <Bram@vim.org>
date Sat, 20 Nov 2021 21:00:04 +0100
parents 6dc2643388d2
children aeff0cbd3cb3
files src/syntax.c src/testdir/test_vim9_cmd.vim src/version.c
diffstat 3 files changed, 12 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/src/syntax.c
+++ b/src/syntax.c
@@ -3777,7 +3777,7 @@ syn_cmd_on(exarg_T *eap, int syncing UNU
     static void
 syn_cmd_enable(exarg_T *eap, int syncing UNUSED)
 {
-    set_internal_string_var((char_u *)"syntax_cmd", (char_u *)"enable");
+    set_internal_string_var((char_u *)"g:syntax_cmd", (char_u *)"enable");
     syn_cmd_onoff(eap, "syntax");
     do_unlet((char_u *)"g:syntax_cmd", TRUE);
 }
@@ -3792,7 +3792,7 @@ syn_cmd_reset(exarg_T *eap, int syncing 
     set_nextcmd(eap, eap->arg);
     if (!eap->skip)
     {
-	set_internal_string_var((char_u *)"syntax_cmd", (char_u *)"reset");
+	set_internal_string_var((char_u *)"g:syntax_cmd", (char_u *)"reset");
 	do_cmdline_cmd((char_u *)"runtime! syntax/syncolor.vim");
 	do_unlet((char_u *)"g:syntax_cmd", TRUE);
     }
--- a/src/testdir/test_vim9_cmd.vim
+++ b/src/testdir/test_vim9_cmd.vim
@@ -1581,5 +1581,13 @@ def Test_previewpopup()
   set previewpopup&
 enddef
 
+def Test_syntax_enable_clear()
+  syntax clear
+  syntax enable
+  highlight clear String
+  assert_equal(true, hlget('String')->get(0, {})->get('default', false))
+  syntax clear
+enddef
+
 
 " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
--- a/src/version.c
+++ b/src/version.c
@@ -758,6 +758,8 @@ static char *(features[]) =
 static int included_patches[] =
 {   /* Add new patch number below this line */
 /**/
+    3631,
+/**/
     3630,
 /**/
     3629,