Mercurial > vim
view src/testdir/test_cmdmods.vim @ 31859:8b15e4161605 v9.0.1262
patch 9.0.1262: the did_set_string_option function is too long
Commit: https://github.com/vim/vim/commit/f2e30d0c448b9754d0d4daa901b51fbbf4c30747
Author: Yegappan Lakshmanan <yegappan@yahoo.com>
Date: Mon Jan 30 13:04:42 2023 +0000
patch 9.0.1262: the did_set_string_option function is too long
Problem: The did_set_string_option function is too long.
Solution: Split off functionality to individual functions. (Yegappan
Lakshmanan, Lewis Russell, closes #11904)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Mon, 30 Jan 2023 14:15:05 +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