Mercurial > vim
view src/testdir/test_mzscheme.vim @ 33920:28e1e956f42c v9.0.2159
patch 9.0.2159: screenpos() may crash with neg. column
Commit: https://github.com/vim/vim/commit/ec54af4e26952d954a4cc009f62c80ea01445d30
Author: zeertzjq <zeertzjq@outlook.com>
Date: Tue Dec 12 16:43:44 2023 +0100
patch 9.0.2159: screenpos() may crash with neg. column
Problem: screenpos() may crash with neg. column
Solution: validate and correct column
closes: #13669
Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Tue, 12 Dec 2023 17:00:08 +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