Mercurial > vim
view src/testdir/test_cmdmods.vim @ 31335:5acc0d2cf4f7 v9.0.1001
patch 9.0.1001: classes are not documented or implemented yet
Commit: https://github.com/vim/vim/commit/c1c365c1ca4881488c4fc419b4d5e579b89ef2ed
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Dec 4 20:13:24 2022 +0000
patch 9.0.1001: classes are not documented or implemented yet
Problem: Classes are not documented or implemented yet.
Solution: Make the first steps at documenting Vim9 objects, classes and
interfaces. Make initial choices for the syntax. Add a skeleton
implementation. Add "public" and "this" in the command table.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 04 Dec 2022 21:15:07 +0100 |
parents | 360f286b5869 |
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