Mercurial > vim
view src/testdir/test_cmdmods.vim @ 30604:9d7914012b82 v9.0.0637
patch 9.0.0637: syntax of commands in Vim9 script depends on +eval feature
Commit: https://github.com/vim/vim/commit/eda29c971c0592d85c5856da7708f3edfdc54cfa
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Oct 2 12:59:00 2022 +0100
patch 9.0.0637: syntax of commands in Vim9 script depends on +eval feature
Problem: Syntax of commands in Vim9 script depends on +eval feature.
Solution: Use same syntax with and without the +eval feature.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 02 Oct 2022 14:00:09 +0200 |
parents | 3564cddda2a5 |
children | 360f286b5869 |
line wrap: on
line source
" Test for all comand modifiers in def Test_cmdmods_array() # Get all the command modifiers from ex_cmds.h. var lines = readfile('../ex_cmds.h')->filter((_, l) => l =~ 'ex_wrongmodifier,') var cmds = lines->map((_, v) => substitute(v, '.*"\(\k*\)".*', '\1', '')) # :hide is both a command and a modifier cmds->extend(['hide']) # Get the entries of cmdmods[] in ex_docmd.c edit ../ex_docmd.c var top = search('^} cmdmods[') + 1 var bot = search('^};') - 1 lines = getline(top, bot) var mods = lines->map((_, v) => substitute(v, '.*"\(\k*\)".*', '\1', '')) # Check the lists are equal. Convert them to a dict to get a clearer error # message. var cmds_dict = {} for v in cmds cmds_dict[v] = 1 endfor var mods_dict = {} for v in mods mods_dict[v] = 1 endfor assert_equal(cmds_dict, mods_dict) bwipe! enddef " vim: shiftwidth=2 sts=2 expandtab