Mercurial > vim
view src/testdir/test_mzscheme.vim @ 26356:0884f2be6c2a v8.2.3709
patch 8.2.3709: Vim9: backtick expression expanded when not desired
Commit: https://github.com/vim/vim/commit/fad2742d538123abb9b384a053fd581f2acf6bb0
Author: Bram Moolenaar <Bram@vim.org>
Date: Tue Nov 30 21:58:19 2021 +0000
patch 8.2.3709: Vim9: backtick expression expanded when not desired
Problem: Vim9: backtick expression expanded when not desired.
Solution: Only expand a backtick expression for commands that expand their
argument. Remove a few outdated TODO comments.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Tue, 30 Nov 2021 23:00:04 +0100 |
parents | 31cb78014fe4 |
children |
line wrap: on
line source
" Test for MzScheme interface and mzeval() function source check.vim CheckFeature mzscheme func MzRequire() redir => l:mzversion mz (version) redir END if strpart(l:mzversion, 1, 1) < "4" " MzScheme versions < 4.x: mz (require (prefix vim- vimext)) else " newer versions: mz (require (prefix-in vim- 'vimext)) mz (require r5rs) endif endfunc func Test_mzscheme() new let lines =<< trim END 1 line 1 2 line 2 3 line 3 END call setline(1, lines) call MzRequire() mz (define l '("item0" "dictionary with list OK" "item2")) mz (define h (make-hash)) mz (hash-set! h "list" l) call cursor(1, 1) " change buffer contents mz (vim-set-buff-line (vim-eval "line('.')") "1 changed line 1") call assert_equal('1 changed line 1', getline(1)) " scalar test let tmp_string = mzeval('"string"') let tmp_1000 = '1000'->mzeval() call assert_equal('string1000', tmp_string .. tmp_1000) " dictionary containing a list call assert_equal('dictionary with list OK', mzeval("h")["list"][1]) call cursor(2, 1) " circular list (at the same time test lists containing lists) mz (set-car! (cddr l) l) let l2 = mzeval("h")["list"] call assert_equal(l2[2], l2) " funcrefs mz (define vim:max (vim-eval "function('max')")) mz (define m (vim:max '(1 100 8))) let m = mzeval('m') call assert_equal(100, m) close! endfunc " vim: shiftwidth=2 sts=2 expandtab