Mercurial > vim
view src/testdir/test_cmdmods.vim @ 34169:1f7df4dae067 v9.1.0042
patch 9.1.0042: Missing test for Chuck Filetype
Commit: https://github.com/vim/vim/commit/c1884c94c5d7246e53a83b03a35a66ce81b49f83
Author: Christian Brabandt <cb@256bit.org>
Date: Sun Jan 21 09:40:22 2024 +0100
patch 9.1.0042: Missing test for Chuck Filetype
Problem: Missing test for Chuck filetype
after commit 27a4632af6753
(Christian Clason)
Solution: Add a filetype test
Signed-off-by: Christian Brabandt <cb@256bit.org>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sun, 21 Jan 2024 09:45:07 +0100 |
parents | 5acc0d2cf4f7 |
children | cda1a8a06777 |
line wrap: on
line source
" Test for all command 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', '')) # Add the other commands that use ex_wrongmodifier. mods->extend([ 'endclass', 'endenum', 'endinterface', 'public', 'static', 'this', ]) # 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