Mercurial > vim
view src/testdir/test_lispwords.vim @ 18991:847cc7932c42 v8.2.0056
patch 8.2.0056: execution stack is incomplete and inefficient
Commit: https://github.com/vim/vim/commit/1a47ae32cdc19b0fd5a82e19fe5fddf45db1a506
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Dec 29 23:04:25 2019 +0100
patch 8.2.0056: execution stack is incomplete and inefficient
Problem: Execution stack is incomplete and inefficient.
Solution: Introduce a proper execution stack and use it instead of
sourcing_name/sourcing_lnum. Create a string only when used.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 29 Dec 2019 23:15:04 +0100 |
parents | 2e53305f2239 |
children | 6d3c683466f4 |
line wrap: on
line source
" Tests for 'lispwords' settings being global-local set nocompatible viminfo+=nviminfo func Test_global_local_lispwords() setglobal lispwords=foo,bar,baz setlocal lispwords-=foo | setlocal lispwords+=quux call assert_equal('foo,bar,baz', &g:lispwords) call assert_equal('bar,baz,quux', &l:lispwords) call assert_equal('bar,baz,quux', &lispwords) setlocal lispwords< call assert_equal('foo,bar,baz', &g:lispwords) call assert_equal('foo,bar,baz', &l:lispwords) call assert_equal('foo,bar,baz', &lispwords) endfunc func Test_lisp_indent() enew! call append(0, [ \ '(defun html-file (base)', \ '(format nil "~(~A~).html" base))', \ '', \ '(defmacro page (name title &rest body)', \ '(let ((ti (gensym)))', \ '`(with-open-file (*standard-output*', \ '(html-file ,name)', \ ':direction :output', \ ':if-exists :supersede)', \ '(let ((,ti ,title))', \ '(as title ,ti)', \ '(with center ', \ '(as h2 (string-upcase ,ti)))', \ '(brs 3)', \ ',@body))))', \ '', \ ';;; Utilities for generating links', \ '', \ '(defmacro with-link (dest &rest body)', \ '`(progn', \ '(format t "<a href=\"~A\">" (html-file ,dest))', \ ',@body', \ '(princ "</a>")))' \ ]) call assert_equal(7, lispindent(2)) call assert_equal(5, 6->lispindent()) set lisp set lispwords& let save_copt = &cpoptions set cpoptions+=p normal 1G=G call assert_equal([ \ '(defun html-file (base)', \ ' (format nil "~(~A~).html" base))', \ '', \ '(defmacro page (name title &rest body)', \ ' (let ((ti (gensym)))', \ ' `(with-open-file (*standard-output*', \ ' (html-file ,name)', \ ' :direction :output', \ ' :if-exists :supersede)', \ ' (let ((,ti ,title))', \ ' (as title ,ti)', \ ' (with center ', \ ' (as h2 (string-upcase ,ti)))', \ ' (brs 3)', \ ' ,@body))))', \ '', \ ';;; Utilities for generating links', \ '', \ '(defmacro with-link (dest &rest body)', \ ' `(progn', \ ' (format t "<a href=\"~A\">" (html-file ,dest))', \ ' ,@body', \ ' (princ "</a>")))', \ '' \ ], getline(1, "$")) enew! let &cpoptions=save_copt set nolisp endfunc