Mercurial > vim
annotate src/testdir/test_functions.vim @ 18469:66964658cc3c v8.1.2228
patch 8.1.2228: screenpos() returns wrong values when 'number' is set
Commit: https://github.com/vim/vim/commit/38ba4dce4a8574e60f6ddb111922880b0c7affdc
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Oct 27 21:39:09 2019 +0100
patch 8.1.2228: screenpos() returns wrong values when 'number' is set
Problem: screenpos() returns wrong values when 'number' is set. (Ben
Jackson)
Solution: Compare the column with the window width. (closes #5133)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 27 Oct 2019 21:45:03 +0100 |
parents | 9a7bbad64376 |
children | 3089b422b9dc |
rev | line source |
---|---|
10555
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
1 " Tests for various functions. |
14669
63d5ae57a663
patch 8.1.0347: some tests fail on Solaris
Christian Brabandt <cb@256bit.org>
parents:
14579
diff
changeset
|
2 source shared.vim |
17657
0da9bc55c31a
patch 8.1.1826: tests use hand coded feature and option checks
Bram Moolenaar <Bram@vim.org>
parents:
17484
diff
changeset
|
3 source check.vim |
18143
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
4 source term_util.vim |
10555
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
5 |
12869
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
6 " Must be done first, since the alternate buffer must be unset. |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
7 func Test_00_bufexists() |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
8 call assert_equal(0, bufexists('does_not_exist')) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
9 call assert_equal(1, bufexists(bufnr('%'))) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
10 call assert_equal(0, bufexists(0)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
11 new Xfoo |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
12 let bn = bufnr('%') |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
13 call assert_equal(1, bufexists(bn)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
14 call assert_equal(1, bufexists('Xfoo')) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
15 call assert_equal(1, bufexists(getcwd() . '/Xfoo')) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
16 call assert_equal(1, bufexists(0)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
17 bw |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
18 call assert_equal(0, bufexists(bn)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
19 call assert_equal(0, bufexists('Xfoo')) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
20 endfunc |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
21 |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
22 func Test_empty() |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
23 call assert_equal(1, empty('')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
24 call assert_equal(0, empty('a')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
25 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
26 call assert_equal(1, empty(0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
27 call assert_equal(1, empty(-0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
28 call assert_equal(0, empty(1)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
29 call assert_equal(0, empty(-1)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
30 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
31 call assert_equal(1, empty(0.0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
32 call assert_equal(1, empty(-0.0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
33 call assert_equal(0, empty(1.0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
34 call assert_equal(0, empty(-1.0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
35 call assert_equal(0, empty(1.0/0.0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
36 call assert_equal(0, empty(0.0/0.0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
37 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
38 call assert_equal(1, empty([])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
39 call assert_equal(0, empty(['a'])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
40 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
41 call assert_equal(1, empty({})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
42 call assert_equal(0, empty({'a':1})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
43 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
44 call assert_equal(1, empty(v:null)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
45 call assert_equal(1, empty(v:none)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
46 call assert_equal(1, empty(v:false)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
47 call assert_equal(0, empty(v:true)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
48 |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
49 if has('channel') |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
50 call assert_equal(1, empty(test_null_channel())) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
51 endif |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
52 if has('job') |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
53 call assert_equal(1, empty(test_null_job())) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
54 endif |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
55 |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
56 call assert_equal(0, empty(function('Test_empty'))) |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
57 call assert_equal(0, empty(function('Test_empty', [0]))) |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
58 endfunc |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
59 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
60 func Test_len() |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
61 call assert_equal(1, len(0)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
62 call assert_equal(2, len(12)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
63 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
64 call assert_equal(0, len('')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
65 call assert_equal(2, len('ab')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
66 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
67 call assert_equal(0, len([])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
68 call assert_equal(2, len([2, 1])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
69 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
70 call assert_equal(0, len({})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
71 call assert_equal(2, len({'a': 1, 'b': 2})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
72 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
73 call assert_fails('call len(v:none)', 'E701:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
74 call assert_fails('call len({-> 0})', 'E701:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
75 endfunc |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
76 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
77 func Test_max() |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
78 call assert_equal(0, max([])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
79 call assert_equal(2, max([2])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
80 call assert_equal(2, max([1, 2])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
81 call assert_equal(2, max([1, 2, v:null])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
82 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
83 call assert_equal(0, max({})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
84 call assert_equal(2, max({'a':1, 'b':2})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
85 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
86 call assert_fails('call max(1)', 'E712:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
87 call assert_fails('call max(v:none)', 'E712:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
88 endfunc |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
89 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
90 func Test_min() |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
91 call assert_equal(0, min([])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
92 call assert_equal(2, min([2])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
93 call assert_equal(1, min([1, 2])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
94 call assert_equal(0, min([1, 2, v:null])) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
95 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
96 call assert_equal(0, min({})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
97 call assert_equal(1, min({'a':1, 'b':2})) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
98 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
99 call assert_fails('call min(1)', 'E712:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
100 call assert_fails('call min(v:none)', 'E712:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
101 endfunc |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
102 |
13980
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
103 func Test_strwidth() |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
104 for aw in ['single', 'double'] |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
105 exe 'set ambiwidth=' . aw |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
106 call assert_equal(0, strwidth('')) |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
107 call assert_equal(1, strwidth("\t")) |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
108 call assert_equal(3, strwidth('Vim')) |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
109 call assert_equal(4, strwidth(1234)) |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
110 call assert_equal(5, strwidth(-1234)) |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
111 |
15607
2dcaa860e3fc
patch 8.1.0811: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15008
diff
changeset
|
112 call assert_equal(2, strwidth('😉')) |
2dcaa860e3fc
patch 8.1.0811: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15008
diff
changeset
|
113 call assert_equal(17, strwidth('Eĥoŝanĝo ĉiuĵaŭde')) |
2dcaa860e3fc
patch 8.1.0811: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15008
diff
changeset
|
114 call assert_equal((aw == 'single') ? 6 : 7, strwidth('Straße')) |
13980
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
115 |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
116 call assert_fails('call strwidth({->0})', 'E729:') |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
117 call assert_fails('call strwidth([])', 'E730:') |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
118 call assert_fails('call strwidth({})', 'E731:') |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
119 call assert_fails('call strwidth(1.2)', 'E806:') |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
120 endfor |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
121 |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
122 set ambiwidth& |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
123 endfunc |
a9e31b01366b
patch 8.1.0008: no test for strwidth()
Christian Brabandt <cb@256bit.org>
parents:
13513
diff
changeset
|
124 |
10555
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
125 func Test_str2nr() |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
126 call assert_equal(0, str2nr('')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
127 call assert_equal(1, str2nr('1')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
128 call assert_equal(1, str2nr(' 1 ')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
129 |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
130 call assert_equal(1, str2nr('+1')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
131 call assert_equal(1, str2nr('+ 1')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
132 call assert_equal(1, str2nr(' + 1 ')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
133 |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
134 call assert_equal(-1, str2nr('-1')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
135 call assert_equal(-1, str2nr('- 1')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
136 call assert_equal(-1, str2nr(' - 1 ')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
137 |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
138 call assert_equal(123456789, str2nr('123456789')) |
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
139 call assert_equal(-123456789, str2nr('-123456789')) |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
140 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
141 call assert_equal(5, str2nr('101', 2)) |
18017
988e5a868b60
patch 8.1.2004: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18000
diff
changeset
|
142 call assert_equal(5, '0b101'->str2nr(2)) |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
143 call assert_equal(5, str2nr('0B101', 2)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
144 call assert_equal(-5, str2nr('-101', 2)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
145 call assert_equal(-5, str2nr('-0b101', 2)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
146 call assert_equal(-5, str2nr('-0B101', 2)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
147 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
148 call assert_equal(65, str2nr('101', 8)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
149 call assert_equal(65, str2nr('0101', 8)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
150 call assert_equal(-65, str2nr('-101', 8)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
151 call assert_equal(-65, str2nr('-0101', 8)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
152 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
153 call assert_equal(11259375, str2nr('abcdef', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
154 call assert_equal(11259375, str2nr('ABCDEF', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
155 call assert_equal(-11259375, str2nr('-ABCDEF', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
156 call assert_equal(11259375, str2nr('0xabcdef', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
157 call assert_equal(11259375, str2nr('0Xabcdef', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
158 call assert_equal(11259375, str2nr('0XABCDEF', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
159 call assert_equal(-11259375, str2nr('-0xABCDEF', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
160 |
18080
a6d218f99ff7
patch 8.1.2035: recognizing octal numbers is confusing
Bram Moolenaar <Bram@vim.org>
parents:
18035
diff
changeset
|
161 call assert_equal(1, str2nr("1'000'000", 10, 0)) |
a6d218f99ff7
patch 8.1.2035: recognizing octal numbers is confusing
Bram Moolenaar <Bram@vim.org>
parents:
18035
diff
changeset
|
162 call assert_equal(256, str2nr("1'0000'0000", 2, 1)) |
a6d218f99ff7
patch 8.1.2035: recognizing octal numbers is confusing
Bram Moolenaar <Bram@vim.org>
parents:
18035
diff
changeset
|
163 call assert_equal(262144, str2nr("1'000'000", 8, 1)) |
a6d218f99ff7
patch 8.1.2035: recognizing octal numbers is confusing
Bram Moolenaar <Bram@vim.org>
parents:
18035
diff
changeset
|
164 call assert_equal(1000000, str2nr("1'000'000", 10, 1)) |
18096
609b351cb58f
patch 8.1.2043: not sufficient testing for quoted numbers
Bram Moolenaar <Bram@vim.org>
parents:
18080
diff
changeset
|
165 call assert_equal(1000, str2nr("1'000''000", 10, 1)) |
18080
a6d218f99ff7
patch 8.1.2035: recognizing octal numbers is confusing
Bram Moolenaar <Bram@vim.org>
parents:
18035
diff
changeset
|
166 call assert_equal(65536, str2nr("1'00'00", 16, 1)) |
a6d218f99ff7
patch 8.1.2035: recognizing octal numbers is confusing
Bram Moolenaar <Bram@vim.org>
parents:
18035
diff
changeset
|
167 |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
168 call assert_equal(0, str2nr('0x10')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
169 call assert_equal(0, str2nr('0b10')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
170 call assert_equal(1, str2nr('12', 2)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
171 call assert_equal(1, str2nr('18', 8)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
172 call assert_equal(1, str2nr('1g', 16)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
173 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
174 call assert_equal(0, str2nr(v:null)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
175 call assert_equal(0, str2nr(v:none)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
176 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
177 call assert_fails('call str2nr([])', 'E730:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
178 call assert_fails('call str2nr({->2})', 'E729:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
179 call assert_fails('call str2nr(1.2)', 'E806:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
180 call assert_fails('call str2nr(10, [])', 'E474:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
181 endfunc |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
182 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
183 func Test_strftime() |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
184 if !exists('*strftime') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
185 return |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
186 endif |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
187 " Format of strftime() depends on system. We assume |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
188 " that basic formats tested here are available and |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
189 " identical on all systems which support strftime(). |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
190 " |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
191 " The 2nd parameter of strftime() is a local time, so the output day |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
192 " of strftime() can be 17 or 18, depending on timezone. |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
193 call assert_match('^2017-01-1[78]$', strftime('%Y-%m-%d', 1484695512)) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
194 " |
18017
988e5a868b60
patch 8.1.2004: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18000
diff
changeset
|
195 call assert_match('^\d\d\d\d-\(0\d\|1[012]\)-\([012]\d\|3[01]\) \([01]\d\|2[0-3]\):[0-5]\d:\([0-5]\d\|60\)$', '%Y-%m-%d %H:%M:%S'->strftime()) |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
196 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
197 call assert_fails('call strftime([])', 'E730:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
198 call assert_fails('call strftime("%Y", [])', 'E745:') |
17135
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
199 |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
200 " Check that the time changes after we change the timezone |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
201 " Save previous timezone value, if any |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
202 if exists('$TZ') |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
203 let tz = $TZ |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
204 endif |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
205 |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
206 " Force EST and then UTC, save the current hour (24-hour clock) for each |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
207 let $TZ = 'EST' | let est = strftime('%H') |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
208 let $TZ = 'UTC' | let utc = strftime('%H') |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
209 |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
210 " Those hours should be two bytes long, and should not be the same; if they |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
211 " are, a tzset(3) call may have failed somewhere |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
212 call assert_equal(strlen(est), 2) |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
213 call assert_equal(strlen(utc), 2) |
17137
ca4e6685e2f4
patch 8.1.1568: strftime() test fails on MS-Windows
Bram Moolenaar <Bram@vim.org>
parents:
17135
diff
changeset
|
214 " TODO: this fails on MS-Windows |
ca4e6685e2f4
patch 8.1.1568: strftime() test fails on MS-Windows
Bram Moolenaar <Bram@vim.org>
parents:
17135
diff
changeset
|
215 if has('unix') |
ca4e6685e2f4
patch 8.1.1568: strftime() test fails on MS-Windows
Bram Moolenaar <Bram@vim.org>
parents:
17135
diff
changeset
|
216 call assert_notequal(est, utc) |
ca4e6685e2f4
patch 8.1.1568: strftime() test fails on MS-Windows
Bram Moolenaar <Bram@vim.org>
parents:
17135
diff
changeset
|
217 endif |
17135
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
218 |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
219 " If we cached a timezone value, put it back, otherwise clear it |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
220 if exists('tz') |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
221 let $TZ = tz |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
222 else |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
223 unlet $TZ |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
224 endif |
d03a52e02f1a
patch 8.1.1567: localtime_r() does not respond to $TZ changes
Bram Moolenaar <Bram@vim.org>
parents:
16945
diff
changeset
|
225 |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
226 endfunc |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
227 |
15774
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
228 func Test_resolve_unix() |
14885
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
229 if !has('unix') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
230 return |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
231 endif |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
232 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
233 " Xlink1 -> Xlink2 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
234 " Xlink2 -> Xlink3 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
235 silent !ln -s -f Xlink2 Xlink1 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
236 silent !ln -s -f Xlink3 Xlink2 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
237 call assert_equal('Xlink3', resolve('Xlink1')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
238 call assert_equal('./Xlink3', resolve('./Xlink1')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
239 call assert_equal('Xlink3/', resolve('Xlink2/')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
240 " FIXME: these tests result in things like "Xlink2/" instead of "Xlink3/"?! |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
241 "call assert_equal('Xlink3/', resolve('Xlink1/')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
242 "call assert_equal('./Xlink3/', resolve('./Xlink1/')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
243 "call assert_equal(getcwd() . '/Xlink3/', resolve(getcwd() . '/Xlink1/')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
244 call assert_equal(getcwd() . '/Xlink3', resolve(getcwd() . '/Xlink1')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
245 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
246 " Test resolve() with a symlink cycle. |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
247 " Xlink1 -> Xlink2 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
248 " Xlink2 -> Xlink3 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
249 " Xlink3 -> Xlink1 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
250 silent !ln -s -f Xlink1 Xlink3 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
251 call assert_fails('call resolve("Xlink1")', 'E655:') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
252 call assert_fails('call resolve("./Xlink1")', 'E655:') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
253 call assert_fails('call resolve("Xlink2")', 'E655:') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
254 call assert_fails('call resolve("Xlink3")', 'E655:') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
255 call delete('Xlink1') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
256 call delete('Xlink2') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
257 call delete('Xlink3') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
258 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
259 silent !ln -s -f Xdir//Xfile Xlink |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
260 call assert_equal('Xdir/Xfile', resolve('Xlink')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
261 call delete('Xlink') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
262 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
263 silent !ln -s -f Xlink2/ Xlink1 |
17982
2029737e6a22
patch 8.1.1987: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17976
diff
changeset
|
264 call assert_equal('Xlink2', 'Xlink1'->resolve()) |
14885
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
265 call assert_equal('Xlink2/', resolve('Xlink1/')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
266 call delete('Xlink1') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
267 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
268 silent !ln -s -f ./Xlink2 Xlink1 |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
269 call assert_equal('Xlink2', resolve('Xlink1')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
270 call assert_equal('./Xlink2', resolve('./Xlink1')) |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
271 call delete('Xlink1') |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
272 endfunc |
5e47597de905
patch 8.1.0454: resolve() was not tested with a symlink cycle
Bram Moolenaar <Bram@vim.org>
parents:
14883
diff
changeset
|
273 |
15774
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
274 func s:normalize_fname(fname) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
275 let ret = substitute(a:fname, '\', '/', 'g') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
276 let ret = substitute(ret, '//', '/', 'g') |
18035
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
277 return ret->tolower() |
15774
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
278 endfunc |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
279 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
280 func Test_resolve_win32() |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
281 if !has('win32') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
282 return |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
283 endif |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
284 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
285 " test for shortcut file |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
286 if executable('cscript') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
287 new Xfile |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
288 wq |
17172
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
289 let lines =<< trim END |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
290 Set fs = CreateObject("Scripting.FileSystemObject") |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
291 Set ws = WScript.CreateObject("WScript.Shell") |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
292 Set shortcut = ws.CreateShortcut("Xlink.lnk") |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
293 shortcut.TargetPath = fs.BuildPath(ws.CurrentDirectory, "Xfile") |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
294 shortcut.Save |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
295 END |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
17137
diff
changeset
|
296 call writefile(lines, 'link.vbs') |
15774
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
297 silent !cscript link.vbs |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
298 call delete('link.vbs') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
299 call assert_equal(s:normalize_fname(getcwd() . '\Xfile'), s:normalize_fname(resolve('./Xlink.lnk'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
300 call delete('Xfile') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
301 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
302 call assert_equal(s:normalize_fname(getcwd() . '\Xfile'), s:normalize_fname(resolve('./Xlink.lnk'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
303 call delete('Xlink.lnk') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
304 else |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
305 echomsg 'skipped test for shortcut file' |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
306 endif |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
307 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
308 " remove files |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
309 call delete('Xlink') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
310 call delete('Xdir', 'd') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
311 call delete('Xfile') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
312 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
313 " test for symbolic link to a file |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
314 new Xfile |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
315 wq |
16945
efd36a9052cc
patch 8.1.1473: new resolve() implementation causes problem for plugins
Bram Moolenaar <Bram@vim.org>
parents:
16831
diff
changeset
|
316 call assert_equal('Xfile', resolve('Xfile')) |
15774
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
317 silent !mklink Xlink Xfile |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
318 if !v:shell_error |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
319 call assert_equal(s:normalize_fname(getcwd() . '\Xfile'), s:normalize_fname(resolve('./Xlink'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
320 call delete('Xlink') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
321 else |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
322 echomsg 'skipped test for symbolic link to a file' |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
323 endif |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
324 call delete('Xfile') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
325 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
326 " test for junction to a directory |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
327 call mkdir('Xdir') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
328 silent !mklink /J Xlink Xdir |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
329 if !v:shell_error |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
330 call assert_equal(s:normalize_fname(getcwd() . '\Xdir'), s:normalize_fname(resolve(getcwd() . '/Xlink'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
331 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
332 call delete('Xdir', 'd') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
333 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
334 " test for junction already removed |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
335 call assert_equal(s:normalize_fname(getcwd() . '\Xlink'), s:normalize_fname(resolve(getcwd() . '/Xlink'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
336 call delete('Xlink') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
337 else |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
338 echomsg 'skipped test for junction to a directory' |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
339 call delete('Xdir', 'd') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
340 endif |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
341 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
342 " test for symbolic link to a directory |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
343 call mkdir('Xdir') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
344 silent !mklink /D Xlink Xdir |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
345 if !v:shell_error |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
346 call assert_equal(s:normalize_fname(getcwd() . '\Xdir'), s:normalize_fname(resolve(getcwd() . '/Xlink'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
347 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
348 call delete('Xdir', 'd') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
349 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
350 " test for symbolic link already removed |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
351 call assert_equal(s:normalize_fname(getcwd() . '\Xlink'), s:normalize_fname(resolve(getcwd() . '/Xlink'))) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
352 call delete('Xlink') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
353 else |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
354 echomsg 'skipped test for symbolic link to a directory' |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
355 call delete('Xdir', 'd') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
356 endif |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
357 |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
358 " test for buffer name |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
359 new Xfile |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
360 wq |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
361 silent !mklink Xlink Xfile |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
362 if !v:shell_error |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
363 edit Xlink |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
364 call assert_equal('Xlink', bufname('%')) |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
365 call delete('Xlink') |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
366 bw! |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
367 else |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
368 echomsg 'skipped test for buffer name' |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
369 endif |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
370 call delete('Xfile') |
16831
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
371 |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
372 " test for reparse point |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
373 call mkdir('Xdir') |
16945
efd36a9052cc
patch 8.1.1473: new resolve() implementation causes problem for plugins
Bram Moolenaar <Bram@vim.org>
parents:
16831
diff
changeset
|
374 call assert_equal('Xdir', resolve('Xdir')) |
16831
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
375 silent !mklink /D Xdirlink Xdir |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
376 if !v:shell_error |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
377 w Xdir/text.txt |
16945
efd36a9052cc
patch 8.1.1473: new resolve() implementation causes problem for plugins
Bram Moolenaar <Bram@vim.org>
parents:
16831
diff
changeset
|
378 call assert_equal('Xdir/text.txt', resolve('Xdir/text.txt')) |
16831
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
379 call assert_equal(s:normalize_fname(getcwd() . '\Xdir\text.txt'), s:normalize_fname(resolve('Xdirlink\text.txt'))) |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
380 call assert_equal(s:normalize_fname(getcwd() . '\Xdir'), s:normalize_fname(resolve('Xdirlink'))) |
16945
efd36a9052cc
patch 8.1.1473: new resolve() implementation causes problem for plugins
Bram Moolenaar <Bram@vim.org>
parents:
16831
diff
changeset
|
381 call delete('Xdirlink') |
16831
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
382 else |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
383 echomsg 'skipped test for reparse point' |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
384 endif |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
385 |
f42aa3d90b12
patch 8.1.1417: MS-Windows: resolve() does not resolve all components of path
Bram Moolenaar <Bram@vim.org>
parents:
16752
diff
changeset
|
386 call delete('Xdir', 'rf') |
15774
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
387 endfunc |
c4efa095f323
patch 8.1.0894: MS-Windows: resolve() does not return a reparse point
Bram Moolenaar <Bram@vim.org>
parents:
15754
diff
changeset
|
388 |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
389 func Test_simplify() |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
390 call assert_equal('', simplify('')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
391 call assert_equal('/', simplify('/')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
392 call assert_equal('/', simplify('/.')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
393 call assert_equal('/', simplify('/..')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
394 call assert_equal('/...', simplify('/...')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
395 call assert_equal('./dir/file', simplify('./dir/file')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
396 call assert_equal('./dir/file', simplify('.///dir//file')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
397 call assert_equal('./dir/file', simplify('./dir/./file')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
398 call assert_equal('./file', simplify('./dir/../file')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
399 call assert_equal('../dir/file', simplify('dir/../../dir/file')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
400 call assert_equal('./file', simplify('dir/.././file')) |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
401 |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
402 call assert_fails('call simplify({->0})', 'E729:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
403 call assert_fails('call simplify([])', 'E730:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
404 call assert_fails('call simplify({})', 'E731:') |
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
405 call assert_fails('call simplify(1.2)', 'E806:') |
10555
fff45421182b
patch 8.0.0167: str2nr()/str2float() fail with negative values
Christian Brabandt <cb@256bit.org>
parents:
diff
changeset
|
406 endfunc |
10706
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
407 |
14487
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
408 func Test_pathshorten() |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
409 call assert_equal('', pathshorten('')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
410 call assert_equal('foo', pathshorten('foo')) |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
411 call assert_equal('/foo', '/foo'->pathshorten()) |
14487
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
412 call assert_equal('f/', pathshorten('foo/')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
413 call assert_equal('f/bar', pathshorten('foo/bar')) |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
414 call assert_equal('f/b/foobar', 'foo/bar/foobar'->pathshorten()) |
14487
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
415 call assert_equal('/f/b/foobar', pathshorten('/foo/bar/foobar')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
416 call assert_equal('.f/bar', pathshorten('.foo/bar')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
417 call assert_equal('~f/bar', pathshorten('~foo/bar')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
418 call assert_equal('~.f/bar', pathshorten('~.foo/bar')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
419 call assert_equal('.~f/bar', pathshorten('.~foo/bar')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
420 call assert_equal('~/f/bar', pathshorten('~/foo/bar')) |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
421 endfunc |
336213a840d9
patch 8.1.0257: no test for pathshorten()
Christian Brabandt <cb@256bit.org>
parents:
14422
diff
changeset
|
422 |
12869
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
423 func Test_strpart() |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
424 call assert_equal('de', strpart('abcdefg', 3, 2)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
425 call assert_equal('ab', strpart('abcdefg', -2, 4)) |
18017
988e5a868b60
patch 8.1.2004: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18000
diff
changeset
|
426 call assert_equal('abcdefg', 'abcdefg'->strpart(-2)) |
12869
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
427 call assert_equal('fg', strpart('abcdefg', 5, 4)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
428 call assert_equal('defg', strpart('abcdefg', 3)) |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
429 |
15607
2dcaa860e3fc
patch 8.1.0811: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15008
diff
changeset
|
430 call assert_equal('lép', strpart('éléphant', 2, 4)) |
2dcaa860e3fc
patch 8.1.0811: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15008
diff
changeset
|
431 call assert_equal('léphant', strpart('éléphant', 2)) |
12869
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
432 endfunc |
a89350ba2a9d
patch 8.0.1311: no test for strpart()
Christian Brabandt <cb@256bit.org>
parents:
12451
diff
changeset
|
433 |
10706
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
434 func Test_tolower() |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
435 call assert_equal("", tolower("")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
436 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
437 " Test with all printable ASCII characters. |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
438 call assert_equal(' !"#$%&''()*+,-./0123456789:;<=>?@abcdefghijklmnopqrstuvwxyz[\]^_`abcdefghijklmnopqrstuvwxyz{|}~', |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
439 \ tolower(' !"#$%&''()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~')) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
440 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
441 " Test with a few uppercase diacritics. |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
442 call assert_equal("aàáâãäåāăąǎǟǡả", tolower("AÀÁÂÃÄÅĀĂĄǍǞǠẢ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
443 call assert_equal("bḃḇ", tolower("BḂḆ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
444 call assert_equal("cçćĉċč", tolower("CÇĆĈĊČ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
445 call assert_equal("dďđḋḏḑ", tolower("DĎĐḊḎḐ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
446 call assert_equal("eèéêëēĕėęěẻẽ", tolower("EÈÉÊËĒĔĖĘĚẺẼ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
447 call assert_equal("fḟ ", tolower("FḞ ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
448 call assert_equal("gĝğġģǥǧǵḡ", tolower("GĜĞĠĢǤǦǴḠ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
449 call assert_equal("hĥħḣḧḩ", tolower("HĤĦḢḦḨ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
450 call assert_equal("iìíîïĩīĭįiǐỉ", tolower("IÌÍÎÏĨĪĬĮİǏỈ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
451 call assert_equal("jĵ", tolower("JĴ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
452 call assert_equal("kķǩḱḵ", tolower("KĶǨḰḴ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
453 call assert_equal("lĺļľŀłḻ", tolower("LĹĻĽĿŁḺ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
454 call assert_equal("mḿṁ", tolower("MḾṀ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
455 call assert_equal("nñńņňṅṉ", tolower("NÑŃŅŇṄṈ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
456 call assert_equal("oòóôõöøōŏőơǒǫǭỏ", tolower("OÒÓÔÕÖØŌŎŐƠǑǪǬỎ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
457 call assert_equal("pṕṗ", tolower("PṔṖ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
458 call assert_equal("q", tolower("Q")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
459 call assert_equal("rŕŗřṙṟ", tolower("RŔŖŘṘṞ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
460 call assert_equal("sśŝşšṡ", tolower("SŚŜŞŠṠ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
461 call assert_equal("tţťŧṫṯ", tolower("TŢŤŦṪṮ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
462 call assert_equal("uùúûüũūŭůűųưǔủ", tolower("UÙÚÛÜŨŪŬŮŰŲƯǓỦ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
463 call assert_equal("vṽ", tolower("VṼ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
464 call assert_equal("wŵẁẃẅẇ", tolower("WŴẀẂẄẆ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
465 call assert_equal("xẋẍ", tolower("XẊẌ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
466 call assert_equal("yýŷÿẏỳỷỹ", tolower("YÝŶŸẎỲỶỸ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
467 call assert_equal("zźżžƶẑẕ", tolower("ZŹŻŽƵẐẔ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
468 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
469 " Test with a few lowercase diacritics, which should remain unchanged. |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
470 call assert_equal("aàáâãäåāăąǎǟǡả", tolower("aàáâãäåāăąǎǟǡả")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
471 call assert_equal("bḃḇ", tolower("bḃḇ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
472 call assert_equal("cçćĉċč", tolower("cçćĉċč")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
473 call assert_equal("dďđḋḏḑ", tolower("dďđḋḏḑ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
474 call assert_equal("eèéêëēĕėęěẻẽ", tolower("eèéêëēĕėęěẻẽ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
475 call assert_equal("fḟ", tolower("fḟ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
476 call assert_equal("gĝğġģǥǧǵḡ", tolower("gĝğġģǥǧǵḡ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
477 call assert_equal("hĥħḣḧḩẖ", tolower("hĥħḣḧḩẖ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
478 call assert_equal("iìíîïĩīĭįǐỉ", tolower("iìíîïĩīĭįǐỉ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
479 call assert_equal("jĵǰ", tolower("jĵǰ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
480 call assert_equal("kķǩḱḵ", tolower("kķǩḱḵ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
481 call assert_equal("lĺļľŀłḻ", tolower("lĺļľŀłḻ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
482 call assert_equal("mḿṁ ", tolower("mḿṁ ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
483 call assert_equal("nñńņňʼnṅṉ", tolower("nñńņňʼnṅṉ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
484 call assert_equal("oòóôõöøōŏőơǒǫǭỏ", tolower("oòóôõöøōŏőơǒǫǭỏ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
485 call assert_equal("pṕṗ", tolower("pṕṗ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
486 call assert_equal("q", tolower("q")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
487 call assert_equal("rŕŗřṙṟ", tolower("rŕŗřṙṟ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
488 call assert_equal("sśŝşšṡ", tolower("sśŝşšṡ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
489 call assert_equal("tţťŧṫṯẗ", tolower("tţťŧṫṯẗ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
490 call assert_equal("uùúûüũūŭůűųưǔủ", tolower("uùúûüũūŭůűųưǔủ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
491 call assert_equal("vṽ", tolower("vṽ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
492 call assert_equal("wŵẁẃẅẇẘ", tolower("wŵẁẃẅẇẘ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
493 call assert_equal("ẋẍ", tolower("ẋẍ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
494 call assert_equal("yýÿŷẏẙỳỷỹ", tolower("yýÿŷẏẙỳỷỹ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
495 call assert_equal("zźżžƶẑẕ", tolower("zźżžƶẑẕ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
496 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
497 " According to https://twitter.com/jifa/status/625776454479970304 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
498 " Ⱥ (U+023A) and Ⱦ (U+023E) are the *only* code points to increase |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
499 " in length (2 to 3 bytes) when lowercased. So let's test them. |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
500 call assert_equal("ⱥ ⱦ", tolower("Ⱥ Ⱦ")) |
13092
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
501 |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
502 " This call to tolower with invalid utf8 sequence used to cause access to |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
503 " invalid memory. |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
504 call tolower("\xC0\x80\xC0") |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
505 call tolower("123\xC0\x80\xC0") |
10706
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
506 endfunc |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
507 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
508 func Test_toupper() |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
509 call assert_equal("", toupper("")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
510 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
511 " Test with all printable ASCII characters. |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
512 call assert_equal(' !"#$%&''()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`ABCDEFGHIJKLMNOPQRSTUVWXYZ{|}~', |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
513 \ toupper(' !"#$%&''()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~')) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
514 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
515 " Test with a few lowercase diacritics. |
18035
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
516 call assert_equal("AÀÁÂÃÄÅĀĂĄǍǞǠẢ", "aàáâãäåāăąǎǟǡả"->toupper()) |
10706
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
517 call assert_equal("BḂḆ", toupper("bḃḇ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
518 call assert_equal("CÇĆĈĊČ", toupper("cçćĉċč")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
519 call assert_equal("DĎĐḊḎḐ", toupper("dďđḋḏḑ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
520 call assert_equal("EÈÉÊËĒĔĖĘĚẺẼ", toupper("eèéêëēĕėęěẻẽ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
521 call assert_equal("FḞ", toupper("fḟ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
522 call assert_equal("GĜĞĠĢǤǦǴḠ", toupper("gĝğġģǥǧǵḡ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
523 call assert_equal("HĤĦḢḦḨẖ", toupper("hĥħḣḧḩẖ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
524 call assert_equal("IÌÍÎÏĨĪĬĮǏỈ", toupper("iìíîïĩīĭįǐỉ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
525 call assert_equal("JĴǰ", toupper("jĵǰ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
526 call assert_equal("KĶǨḰḴ", toupper("kķǩḱḵ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
527 call assert_equal("LĹĻĽĿŁḺ", toupper("lĺļľŀłḻ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
528 call assert_equal("MḾṀ ", toupper("mḿṁ ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
529 call assert_equal("NÑŃŅŇʼnṄṈ", toupper("nñńņňʼnṅṉ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
530 call assert_equal("OÒÓÔÕÖØŌŎŐƠǑǪǬỎ", toupper("oòóôõöøōŏőơǒǫǭỏ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
531 call assert_equal("PṔṖ", toupper("pṕṗ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
532 call assert_equal("Q", toupper("q")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
533 call assert_equal("RŔŖŘṘṞ", toupper("rŕŗřṙṟ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
534 call assert_equal("SŚŜŞŠṠ", toupper("sśŝşšṡ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
535 call assert_equal("TŢŤŦṪṮẗ", toupper("tţťŧṫṯẗ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
536 call assert_equal("UÙÚÛÜŨŪŬŮŰŲƯǓỦ", toupper("uùúûüũūŭůűųưǔủ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
537 call assert_equal("VṼ", toupper("vṽ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
538 call assert_equal("WŴẀẂẄẆẘ", toupper("wŵẁẃẅẇẘ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
539 call assert_equal("ẊẌ", toupper("ẋẍ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
540 call assert_equal("YÝŸŶẎẙỲỶỸ", toupper("yýÿŷẏẙỳỷỹ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
541 call assert_equal("ZŹŻŽƵẐẔ", toupper("zźżžƶẑẕ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
542 |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
543 " Test that uppercase diacritics, which should remain unchanged. |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
544 call assert_equal("AÀÁÂÃÄÅĀĂĄǍǞǠẢ", toupper("AÀÁÂÃÄÅĀĂĄǍǞǠẢ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
545 call assert_equal("BḂḆ", toupper("BḂḆ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
546 call assert_equal("CÇĆĈĊČ", toupper("CÇĆĈĊČ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
547 call assert_equal("DĎĐḊḎḐ", toupper("DĎĐḊḎḐ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
548 call assert_equal("EÈÉÊËĒĔĖĘĚẺẼ", toupper("EÈÉÊËĒĔĖĘĚẺẼ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
549 call assert_equal("FḞ ", toupper("FḞ ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
550 call assert_equal("GĜĞĠĢǤǦǴḠ", toupper("GĜĞĠĢǤǦǴḠ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
551 call assert_equal("HĤĦḢḦḨ", toupper("HĤĦḢḦḨ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
552 call assert_equal("IÌÍÎÏĨĪĬĮİǏỈ", toupper("IÌÍÎÏĨĪĬĮİǏỈ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
553 call assert_equal("JĴ", toupper("JĴ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
554 call assert_equal("KĶǨḰḴ", toupper("KĶǨḰḴ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
555 call assert_equal("LĹĻĽĿŁḺ", toupper("LĹĻĽĿŁḺ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
556 call assert_equal("MḾṀ", toupper("MḾṀ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
557 call assert_equal("NÑŃŅŇṄṈ", toupper("NÑŃŅŇṄṈ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
558 call assert_equal("OÒÓÔÕÖØŌŎŐƠǑǪǬỎ", toupper("OÒÓÔÕÖØŌŎŐƠǑǪǬỎ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
559 call assert_equal("PṔṖ", toupper("PṔṖ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
560 call assert_equal("Q", toupper("Q")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
561 call assert_equal("RŔŖŘṘṞ", toupper("RŔŖŘṘṞ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
562 call assert_equal("SŚŜŞŠṠ", toupper("SŚŜŞŠṠ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
563 call assert_equal("TŢŤŦṪṮ", toupper("TŢŤŦṪṮ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
564 call assert_equal("UÙÚÛÜŨŪŬŮŰŲƯǓỦ", toupper("UÙÚÛÜŨŪŬŮŰŲƯǓỦ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
565 call assert_equal("VṼ", toupper("VṼ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
566 call assert_equal("WŴẀẂẄẆ", toupper("WŴẀẂẄẆ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
567 call assert_equal("XẊẌ", toupper("XẊẌ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
568 call assert_equal("YÝŶŸẎỲỶỸ", toupper("YÝŶŸẎỲỶỸ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
569 call assert_equal("ZŹŻŽƵẐẔ", toupper("ZŹŻŽƵẐẔ")) |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
570 |
10743
8779b4b2e958
patch 8.0.0261: not enough test coverage for eval functions
Christian Brabandt <cb@256bit.org>
parents:
10706
diff
changeset
|
571 call assert_equal("Ⱥ Ⱦ", toupper("ⱥ ⱦ")) |
13092
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
572 |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
573 " This call to toupper with invalid utf8 sequence used to cause access to |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
574 " invalid memory. |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
575 call toupper("\xC0\x80\xC0") |
d5647746c267
patch 8.0.1421: accessing invalid memory with overlong byte sequence
Christian Brabandt <cb@256bit.org>
parents:
13070
diff
changeset
|
576 call toupper("123\xC0\x80\xC0") |
10706
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
577 endfunc |
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
578 |
18035
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
579 func Test_tr() |
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
580 call assert_equal('foo', tr('bar', 'bar', 'foo')) |
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
581 call assert_equal('zxy', 'cab'->tr('abc', 'xyz')) |
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
582 endfunc |
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
583 |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
584 " Tests for the mode() function |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
585 let current_modes = '' |
11135
c4e4387bbd50
patch 8.0.0455: the mode test may hang
Christian Brabandt <cb@256bit.org>
parents:
11095
diff
changeset
|
586 func Save_mode() |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
587 let g:current_modes = mode(0) . '-' . mode(1) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
588 return '' |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
589 endfunc |
10706
056e32b99e93
patch 8.0.0243: tolower() does not work if the byte count changes
Christian Brabandt <cb@256bit.org>
parents:
10555
diff
changeset
|
590 |
11135
c4e4387bbd50
patch 8.0.0455: the mode test may hang
Christian Brabandt <cb@256bit.org>
parents:
11095
diff
changeset
|
591 func Test_mode() |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
592 new |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
593 call append(0, ["Blue Ball Black", "Brown Band Bowl", ""]) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
594 |
11135
c4e4387bbd50
patch 8.0.0455: the mode test may hang
Christian Brabandt <cb@256bit.org>
parents:
11095
diff
changeset
|
595 " Only complete from the current buffer. |
c4e4387bbd50
patch 8.0.0455: the mode test may hang
Christian Brabandt <cb@256bit.org>
parents:
11095
diff
changeset
|
596 set complete=. |
c4e4387bbd50
patch 8.0.0455: the mode test may hang
Christian Brabandt <cb@256bit.org>
parents:
11095
diff
changeset
|
597 |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
598 inoremap <F2> <C-R>=Save_mode()<CR> |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
599 |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
600 normal! 3G |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
601 exe "normal i\<F2>\<Esc>" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
602 call assert_equal('i-i', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
603 " i_CTRL-P: Multiple matches |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
604 exe "normal i\<C-G>uBa\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
605 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
606 " i_CTRL-P: Single match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
607 exe "normal iBro\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
608 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
609 " i_CTRL-X |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
610 exe "normal iBa\<C-X>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
611 call assert_equal('i-ix', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
612 " i_CTRL-X CTRL-P: Multiple matches |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
613 exe "normal iBa\<C-X>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
614 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
615 " i_CTRL-X CTRL-P: Single match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
616 exe "normal iBro\<C-X>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
617 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
618 " i_CTRL-X CTRL-P + CTRL-P: Single match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
619 exe "normal iBro\<C-X>\<C-P>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
620 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
621 " i_CTRL-X CTRL-L: Multiple matches |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
622 exe "normal i\<C-X>\<C-L>\<F2>\<Esc>u" |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
623 call assert_equal('i-ic', g:current_modes) |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
624 " i_CTRL-X CTRL-L: Single match |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
625 exe "normal iBlu\<C-X>\<C-L>\<F2>\<Esc>u" |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
626 call assert_equal('i-ic', g:current_modes) |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
627 " i_CTRL-P: No match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
628 exe "normal iCom\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
629 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
630 " i_CTRL-X CTRL-P: No match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
631 exe "normal iCom\<C-X>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
632 call assert_equal('i-ic', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
633 " i_CTRL-X CTRL-L: No match |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
634 exe "normal iabc\<C-X>\<C-L>\<F2>\<Esc>u" |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
635 call assert_equal('i-ic', g:current_modes) |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
636 |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
637 " R_CTRL-P: Multiple matches |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
638 exe "normal RBa\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
639 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
640 " R_CTRL-P: Single match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
641 exe "normal RBro\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
642 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
643 " R_CTRL-X |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
644 exe "normal RBa\<C-X>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
645 call assert_equal('R-Rx', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
646 " R_CTRL-X CTRL-P: Multiple matches |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
647 exe "normal RBa\<C-X>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
648 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
649 " R_CTRL-X CTRL-P: Single match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
650 exe "normal RBro\<C-X>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
651 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
652 " R_CTRL-X CTRL-P + CTRL-P: Single match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
653 exe "normal RBro\<C-X>\<C-P>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
654 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
655 " R_CTRL-X CTRL-L: Multiple matches |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
656 exe "normal R\<C-X>\<C-L>\<F2>\<Esc>u" |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
657 call assert_equal('R-Rc', g:current_modes) |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
658 " R_CTRL-X CTRL-L: Single match |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
659 exe "normal RBlu\<C-X>\<C-L>\<F2>\<Esc>u" |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
660 call assert_equal('R-Rc', g:current_modes) |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
661 " R_CTRL-P: No match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
662 exe "normal RCom\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
663 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
664 " R_CTRL-X CTRL-P: No match |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
665 exe "normal RCom\<C-X>\<C-P>\<F2>\<Esc>u" |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
666 call assert_equal('R-Rc', g:current_modes) |
10833
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
667 " R_CTRL-X CTRL-L: No match |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
668 exe "normal Rabc\<C-X>\<C-L>\<F2>\<Esc>u" |
d66e5446cc48
patch 8.0.0306: mode() not sufficiently tested
Christian Brabandt <cb@256bit.org>
parents:
10787
diff
changeset
|
669 call assert_equal('R-Rc', g:current_modes) |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
670 |
17930
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
671 call assert_equal('n', 0->mode()) |
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
672 call assert_equal('n', 1->mode()) |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
673 |
14422
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
674 " i_CTRL-O |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
675 exe "normal i\<C-O>:call Save_mode()\<Cr>\<Esc>" |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
676 call assert_equal("n-niI", g:current_modes) |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
677 |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
678 " R_CTRL-O |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
679 exe "normal R\<C-O>:call Save_mode()\<Cr>\<Esc>" |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
680 call assert_equal("n-niR", g:current_modes) |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
681 |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
682 " gR_CTRL-O |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
683 exe "normal gR\<C-O>:call Save_mode()\<Cr>\<Esc>" |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
684 call assert_equal("n-niV", g:current_modes) |
06316dbd66bc
patch 8.1.0225: mode() does not indicate using CTRL-O from Insert mode
Christian Brabandt <cb@256bit.org>
parents:
14379
diff
changeset
|
685 |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
686 " How to test operator-pending mode? |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
687 |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
688 call feedkeys("v", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
689 call assert_equal('v', mode()) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
690 call assert_equal('v', mode(1)) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
691 call feedkeys("\<Esc>V", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
692 call assert_equal('V', mode()) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
693 call assert_equal('V', mode(1)) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
694 call feedkeys("\<Esc>\<C-V>", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
695 call assert_equal("\<C-V>", mode()) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
696 call assert_equal("\<C-V>", mode(1)) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
697 call feedkeys("\<Esc>", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
698 |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
699 call feedkeys("gh", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
700 call assert_equal('s', mode()) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
701 call assert_equal('s', mode(1)) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
702 call feedkeys("\<Esc>gH", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
703 call assert_equal('S', mode()) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
704 call assert_equal('S', mode(1)) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
705 call feedkeys("\<Esc>g\<C-H>", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
706 call assert_equal("\<C-S>", mode()) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
707 call assert_equal("\<C-S>", mode(1)) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
708 call feedkeys("\<Esc>", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
709 |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
710 call feedkeys(":echo \<C-R>=Save_mode()\<C-U>\<CR>", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
711 call assert_equal('c-c', g:current_modes) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
712 call feedkeys("gQecho \<C-R>=Save_mode()\<CR>\<CR>vi\<CR>", 'xt') |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
713 call assert_equal('c-cv', g:current_modes) |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
714 " How to test Ex mode? |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
715 |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
716 bwipe! |
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
717 iunmap <F2> |
11135
c4e4387bbd50
patch 8.0.0455: the mode test may hang
Christian Brabandt <cb@256bit.org>
parents:
11095
diff
changeset
|
718 set complete& |
10787
09926123316b
patch 8.0.0283: mode() does not indicate Insert mode completion
Christian Brabandt <cb@256bit.org>
parents:
10743
diff
changeset
|
719 endfunc |
10889
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
720 |
17871
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
721 func Test_append() |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
722 enew! |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
723 split |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
724 call append(0, ["foo"]) |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
725 split |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
726 only |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
727 undo |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
728 endfunc |
521ce0d887e5
patch 8.1.1932: ml_get errors after using append()
Bram Moolenaar <Bram@vim.org>
parents:
17849
diff
changeset
|
729 |
10889
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
730 func Test_getbufvar() |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
731 let bnr = bufnr('%') |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
732 let b:var_num = '1234' |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
733 let def_num = '5678' |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
734 call assert_equal('1234', getbufvar(bnr, 'var_num')) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
735 call assert_equal('1234', getbufvar(bnr, 'var_num', def_num)) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
736 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
737 let bd = getbufvar(bnr, '') |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
738 call assert_equal('1234', bd['var_num']) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
739 call assert_true(exists("bd['changedtick']")) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
740 call assert_equal(2, len(bd)) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
741 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
742 let bd2 = getbufvar(bnr, '', def_num) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
743 call assert_equal(bd, bd2) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
744 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
745 unlet b:var_num |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
746 call assert_equal(def_num, getbufvar(bnr, 'var_num', def_num)) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
747 call assert_equal('', getbufvar(bnr, 'var_num')) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
748 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
749 let bd = getbufvar(bnr, '') |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
750 call assert_equal(1, len(bd)) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
751 let bd = getbufvar(bnr, '',def_num) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
752 call assert_equal(1, len(bd)) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
753 |
11197
7f355d8cd634
patch 8.0.0485: not all windows commands are tested
Christian Brabandt <cb@256bit.org>
parents:
11191
diff
changeset
|
754 call assert_equal('', getbufvar(9999, '')) |
7f355d8cd634
patch 8.0.0485: not all windows commands are tested
Christian Brabandt <cb@256bit.org>
parents:
11191
diff
changeset
|
755 call assert_equal(def_num, getbufvar(9999, '', def_num)) |
10889
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
756 unlet def_num |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
757 |
10891
c9d057b7a0ab
patch 8.0.0335: functions test fails
Christian Brabandt <cb@256bit.org>
parents:
10889
diff
changeset
|
758 call assert_equal(0, getbufvar(bnr, '&autoindent')) |
c9d057b7a0ab
patch 8.0.0335: functions test fails
Christian Brabandt <cb@256bit.org>
parents:
10889
diff
changeset
|
759 call assert_equal(0, getbufvar(bnr, '&autoindent', 1)) |
10889
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
760 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
761 " Open new window with forced option values |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
762 set fileformats=unix,dos |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
763 new ++ff=dos ++bin ++enc=iso-8859-2 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
764 call assert_equal('dos', getbufvar(bufnr('%'), '&fileformat')) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
765 call assert_equal(1, getbufvar(bufnr('%'), '&bin')) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
766 call assert_equal('iso-8859-2', getbufvar(bufnr('%'), '&fenc')) |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
767 close |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
768 |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
769 set fileformats& |
5780bd3a5a7e
patch 8.0.0334: can't access b:changedtick from a dict reference
Christian Brabandt <cb@256bit.org>
parents:
10833
diff
changeset
|
770 endfunc |
11020
50f3e37bc210
patch 8.0.0399: crash when using balloon_show() when not supported
Christian Brabandt <cb@256bit.org>
parents:
10891
diff
changeset
|
771 |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
772 func Test_last_buffer_nr() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
773 call assert_equal(bufnr('$'), last_buffer_nr()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
774 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
775 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
776 func Test_stridx() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
777 call assert_equal(-1, stridx('', 'l')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
778 call assert_equal(0, stridx('', '')) |
18017
988e5a868b60
patch 8.1.2004: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18000
diff
changeset
|
779 call assert_equal(0, 'hello'->stridx('')) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
780 call assert_equal(-1, stridx('hello', 'L')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
781 call assert_equal(2, stridx('hello', 'l', -1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
782 call assert_equal(2, stridx('hello', 'l', 0)) |
18017
988e5a868b60
patch 8.1.2004: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18000
diff
changeset
|
783 call assert_equal(2, 'hello'->stridx('l', 1)) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
784 call assert_equal(3, stridx('hello', 'l', 3)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
785 call assert_equal(-1, stridx('hello', 'l', 4)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
786 call assert_equal(-1, stridx('hello', 'l', 10)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
787 call assert_equal(2, stridx('hello', 'll')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
788 call assert_equal(-1, stridx('hello', 'hello world')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
789 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
790 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
791 func Test_strridx() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
792 call assert_equal(-1, strridx('', 'l')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
793 call assert_equal(0, strridx('', '')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
794 call assert_equal(5, strridx('hello', '')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
795 call assert_equal(-1, strridx('hello', 'L')) |
18017
988e5a868b60
patch 8.1.2004: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18000
diff
changeset
|
796 call assert_equal(3, 'hello'->strridx('l')) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
797 call assert_equal(3, strridx('hello', 'l', 10)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
798 call assert_equal(3, strridx('hello', 'l', 3)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
799 call assert_equal(2, strridx('hello', 'l', 2)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
800 call assert_equal(-1, strridx('hello', 'l', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
801 call assert_equal(-1, strridx('hello', 'l', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
802 call assert_equal(-1, strridx('hello', 'l', -1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
803 call assert_equal(2, strridx('hello', 'll')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
804 call assert_equal(-1, strridx('hello', 'hello world')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
805 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
806 |
12451
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
807 func Test_match_func() |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
808 call assert_equal(4, match('testing', 'ing')) |
17930
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
809 call assert_equal(4, 'testing'->match('ing', 2)) |
12451
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
810 call assert_equal(-1, match('testing', 'ing', 5)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
811 call assert_equal(-1, match('testing', 'ing', 8)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
812 call assert_equal(1, match(['vim', 'testing', 'execute'], 'ing')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
813 call assert_equal(-1, match(['vim', 'testing', 'execute'], 'img')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
814 endfunc |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
815 |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
816 func Test_matchend() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
817 call assert_equal(7, matchend('testing', 'ing')) |
17930
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
818 call assert_equal(7, 'testing'->matchend('ing', 2)) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
819 call assert_equal(-1, matchend('testing', 'ing', 5)) |
12451
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
820 call assert_equal(-1, matchend('testing', 'ing', 8)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
821 call assert_equal(match(['vim', 'testing', 'execute'], 'ing'), matchend(['vim', 'testing', 'execute'], 'ing')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
822 call assert_equal(match(['vim', 'testing', 'execute'], 'img'), matchend(['vim', 'testing', 'execute'], 'img')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
823 endfunc |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
824 |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
825 func Test_matchlist() |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
826 call assert_equal(['acd', 'a', '', 'c', 'd', '', '', '', '', ''], matchlist('acd', '\(a\)\?\(b\)\?\(c\)\?\(.*\)')) |
17930
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
827 call assert_equal(['d', '', '', '', 'd', '', '', '', '', ''], 'acd'->matchlist('\(a\)\?\(b\)\?\(c\)\?\(.*\)', 2)) |
12451
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
828 call assert_equal([], matchlist('acd', '\(a\)\?\(b\)\?\(c\)\?\(.*\)', 4)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
829 endfunc |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
830 |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
831 func Test_matchstr() |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
832 call assert_equal('ing', matchstr('testing', 'ing')) |
17930
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
833 call assert_equal('ing', 'testing'->matchstr('ing', 2)) |
12451
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
834 call assert_equal('', matchstr('testing', 'ing', 5)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
835 call assert_equal('', matchstr('testing', 'ing', 8)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
836 call assert_equal('testing', matchstr(['vim', 'testing', 'execute'], 'ing')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
837 call assert_equal('', matchstr(['vim', 'testing', 'execute'], 'img')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
838 endfunc |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
839 |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
840 func Test_matchstrpos() |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
841 call assert_equal(['ing', 4, 7], matchstrpos('testing', 'ing')) |
17930
0cdb6ac20748
patch 8.1.1961: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17916
diff
changeset
|
842 call assert_equal(['ing', 4, 7], 'testing'->matchstrpos('ing', 2)) |
12451
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
843 call assert_equal(['', -1, -1], matchstrpos('testing', 'ing', 5)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
844 call assert_equal(['', -1, -1], matchstrpos('testing', 'ing', 8)) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
845 call assert_equal(['ing', 1, 4, 7], matchstrpos(['vim', 'testing', 'execute'], 'ing')) |
61450cb2b6a1
patch 8.0.1105: match() and matchend() are not tested
Christian Brabandt <cb@256bit.org>
parents:
11828
diff
changeset
|
846 call assert_equal(['', -1, -1, -1], matchstrpos(['vim', 'testing', 'execute'], 'img')) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
847 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
848 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
849 func Test_nextnonblank_prevnonblank() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
850 new |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
851 insert |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
852 This |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
853 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
854 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
855 is |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
856 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
857 a |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
858 Test |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
859 . |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
860 call assert_equal(0, nextnonblank(-1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
861 call assert_equal(0, nextnonblank(0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
862 call assert_equal(1, nextnonblank(1)) |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
863 call assert_equal(4, 2->nextnonblank()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
864 call assert_equal(4, nextnonblank(3)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
865 call assert_equal(4, nextnonblank(4)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
866 call assert_equal(6, nextnonblank(5)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
867 call assert_equal(6, nextnonblank(6)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
868 call assert_equal(7, nextnonblank(7)) |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
869 call assert_equal(0, 8->nextnonblank()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
870 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
871 call assert_equal(0, prevnonblank(-1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
872 call assert_equal(0, prevnonblank(0)) |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
873 call assert_equal(1, 1->prevnonblank()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
874 call assert_equal(1, prevnonblank(2)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
875 call assert_equal(1, prevnonblank(3)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
876 call assert_equal(4, prevnonblank(4)) |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
877 call assert_equal(4, 5->prevnonblank()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
878 call assert_equal(6, prevnonblank(6)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
879 call assert_equal(7, prevnonblank(7)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
880 call assert_equal(0, prevnonblank(8)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
881 bw! |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
882 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
883 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
884 func Test_byte2line_line2byte() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
885 new |
14579
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
886 set endofline |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
887 call setline(1, ['a', 'bc', 'd']) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
888 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
889 set fileformat=unix |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
890 call assert_equal([-1, -1, 1, 1, 2, 2, 2, 3, 3, -1], |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
891 \ map(range(-1, 8), 'byte2line(v:val)')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
892 call assert_equal([-1, -1, 1, 3, 6, 8, -1], |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
893 \ map(range(-1, 5), 'line2byte(v:val)')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
894 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
895 set fileformat=mac |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
896 call assert_equal([-1, -1, 1, 1, 2, 2, 2, 3, 3, -1], |
17829
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
897 \ map(range(-1, 8), 'v:val->byte2line()')) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
898 call assert_equal([-1, -1, 1, 3, 6, 8, -1], |
17916
2e53305f2239
patch 8.1.1954: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17914
diff
changeset
|
899 \ map(range(-1, 5), 'v:val->line2byte()')) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
900 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
901 set fileformat=dos |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
902 call assert_equal([-1, -1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, -1], |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
903 \ map(range(-1, 11), 'byte2line(v:val)')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
904 call assert_equal([-1, -1, 1, 4, 8, 11, -1], |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
905 \ map(range(-1, 5), 'line2byte(v:val)')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
906 |
14579
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
907 bw! |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
908 set noendofline nofixendofline |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
909 normal a- |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
910 for ff in ["unix", "mac", "dos"] |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
911 let &fileformat = ff |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
912 call assert_equal(1, line2byte(1)) |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
913 call assert_equal(2, line2byte(2)) " line2byte(line("$") + 1) is the buffer size plus one (as per :help line2byte). |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
914 endfor |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
915 |
23d6d9e9ae3e
patch 8.1.0303: line2byte() is wrong for last line with 'noeol'
Christian Brabandt <cb@256bit.org>
parents:
14487
diff
changeset
|
916 set endofline& fixendofline& fileformat& |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
917 bw! |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
918 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
919 |
17829
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
920 func Test_byteidx() |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
921 let a = '.é.' " one char of two bytes |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
922 call assert_equal(0, byteidx(a, 0)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
923 call assert_equal(0, byteidxcomp(a, 0)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
924 call assert_equal(1, byteidx(a, 1)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
925 call assert_equal(1, byteidxcomp(a, 1)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
926 call assert_equal(3, byteidx(a, 2)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
927 call assert_equal(3, byteidxcomp(a, 2)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
928 call assert_equal(4, byteidx(a, 3)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
929 call assert_equal(4, byteidxcomp(a, 3)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
930 call assert_equal(-1, byteidx(a, 4)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
931 call assert_equal(-1, byteidxcomp(a, 4)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
932 |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
933 let b = '.é.' " normal e with composing char |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
934 call assert_equal(0, b->byteidx(0)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
935 call assert_equal(1, b->byteidx(1)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
936 call assert_equal(4, b->byteidx(2)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
937 call assert_equal(5, b->byteidx(3)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
938 call assert_equal(-1, b->byteidx(4)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
939 |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
940 call assert_equal(0, b->byteidxcomp(0)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
941 call assert_equal(1, b->byteidxcomp(1)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
942 call assert_equal(2, b->byteidxcomp(2)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
943 call assert_equal(4, b->byteidxcomp(3)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
944 call assert_equal(5, b->byteidxcomp(4)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
945 call assert_equal(-1, b->byteidxcomp(5)) |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
946 endfunc |
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
947 |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
948 func Test_count() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
949 let l = ['a', 'a', 'A', 'b'] |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
950 call assert_equal(2, count(l, 'a')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
951 call assert_equal(1, count(l, 'A')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
952 call assert_equal(1, count(l, 'b')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
953 call assert_equal(0, count(l, 'B')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
954 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
955 call assert_equal(2, count(l, 'a', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
956 call assert_equal(1, count(l, 'A', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
957 call assert_equal(1, count(l, 'b', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
958 call assert_equal(0, count(l, 'B', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
959 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
960 call assert_equal(3, count(l, 'a', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
961 call assert_equal(3, count(l, 'A', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
962 call assert_equal(1, count(l, 'b', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
963 call assert_equal(1, count(l, 'B', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
964 call assert_equal(0, count(l, 'c', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
965 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
966 call assert_equal(1, count(l, 'a', 0, 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
967 call assert_equal(2, count(l, 'a', 1, 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
968 call assert_fails('call count(l, "a", 0, 10)', 'E684:') |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
969 call assert_fails('call count(l, "a", [])', 'E745:') |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
970 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
971 let d = {1: 'a', 2: 'a', 3: 'A', 4: 'b'} |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
972 call assert_equal(2, count(d, 'a')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
973 call assert_equal(1, count(d, 'A')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
974 call assert_equal(1, count(d, 'b')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
975 call assert_equal(0, count(d, 'B')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
976 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
977 call assert_equal(2, count(d, 'a', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
978 call assert_equal(1, count(d, 'A', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
979 call assert_equal(1, count(d, 'b', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
980 call assert_equal(0, count(d, 'B', 0)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
981 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
982 call assert_equal(3, count(d, 'a', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
983 call assert_equal(3, count(d, 'A', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
984 call assert_equal(1, count(d, 'b', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
985 call assert_equal(1, count(d, 'B', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
986 call assert_equal(0, count(d, 'c', 1)) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
987 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
988 call assert_fails('call count(d, "a", 0, 1)', 'E474:') |
11828
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
989 |
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
990 call assert_equal(0, count("foo", "bar")) |
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
991 call assert_equal(1, count("foo", "oo")) |
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
992 call assert_equal(2, count("foo", "o")) |
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
993 call assert_equal(0, count("foo", "O")) |
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
994 call assert_equal(2, count("foo", "O", 1)) |
5a07a3ff56c1
patch 8.0.0794: checking translations fails with multiple NL
Christian Brabandt <cb@256bit.org>
parents:
11484
diff
changeset
|
995 call assert_equal(2, count("fooooo", "oo")) |
13070
17720967656c
patch 8.0.1410: hang when using count() with an empty string
Christian Brabandt <cb@256bit.org>
parents:
12869
diff
changeset
|
996 call assert_equal(0, count("foo", "")) |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
997 |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
998 call assert_fails('call count(0, 0)', 'E712:') |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
999 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1000 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1001 func Test_changenr() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1002 new Xchangenr |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1003 call assert_equal(0, changenr()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1004 norm ifoo |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1005 call assert_equal(1, changenr()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1006 set undolevels=10 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1007 norm Sbar |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1008 call assert_equal(2, changenr()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1009 undo |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1010 call assert_equal(1, changenr()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1011 redo |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1012 call assert_equal(2, changenr()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1013 bw! |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1014 set undolevels& |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1015 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1016 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1017 func Test_filewritable() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1018 new Xfilewritable |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1019 write! |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1020 call assert_equal(1, filewritable('Xfilewritable')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1021 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1022 call assert_notequal(0, setfperm('Xfilewritable', 'r--r-----')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1023 call assert_equal(0, filewritable('Xfilewritable')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1024 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1025 call assert_notequal(0, setfperm('Xfilewritable', 'rw-r-----')) |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1026 call assert_equal(1, 'Xfilewritable'->filewritable()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1027 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1028 call assert_equal(0, filewritable('doesnotexist')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1029 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1030 call delete('Xfilewritable') |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1031 bw! |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1032 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1033 |
14883
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1034 func Test_Executable() |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1035 if has('win32') |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1036 call assert_equal(1, executable('notepad')) |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1037 call assert_equal(1, 'notepad.exe'->executable()) |
14883
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1038 call assert_equal(0, executable('notepad.exe.exe')) |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1039 call assert_equal(0, executable('shell32.dll')) |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1040 call assert_equal(0, executable('win.ini')) |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1041 elseif has('unix') |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1042 call assert_equal(1, 'cat'->executable()) |
14895
bde025b0d7de
patch 8.1.0459: Test_executable fails when there is a dog in the system
Bram Moolenaar <Bram@vim.org>
parents:
14885
diff
changeset
|
1043 call assert_equal(0, executable('nodogshere')) |
17484
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1044 |
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1045 " get "cat" path and remove the leading / |
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1046 let catcmd = exepath('cat')[1:] |
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1047 new |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1048 " check that the relative path works in / |
17484
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1049 lcd / |
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1050 call assert_equal(1, executable(catcmd)) |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1051 call assert_equal('/' .. catcmd, catcmd->exepath()) |
17484
f1fd0b0b335c
patch 8.1.1740: exepath() doesn't work for "bin/cat"
Bram Moolenaar <Bram@vim.org>
parents:
17278
diff
changeset
|
1052 bwipe |
14883
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1053 endif |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1054 endfunc |
1c2ba2b0227e
patch 8.1.0453: MS-Windows: executable() is not reliable
Bram Moolenaar <Bram@vim.org>
parents:
14669
diff
changeset
|
1055 |
16180
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1056 func Test_executable_longname() |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1057 if !has('win32') |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1058 return |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1059 endif |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1060 |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1061 let fname = 'X' . repeat('あ', 200) . '.bat' |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1062 call writefile([], fname) |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1063 call assert_equal(1, executable(fname)) |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1064 call delete(fname) |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1065 endfunc |
1eaaa82ececf
patch 8.1.1095: MS-Windows: executable() fails on very long filename
Bram Moolenaar <Bram@vim.org>
parents:
16144
diff
changeset
|
1066 |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1067 func Test_hostname() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1068 let hostname_vim = hostname() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1069 if has('unix') |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1070 let hostname_system = systemlist('uname -n')[0] |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1071 call assert_equal(hostname_vim, hostname_system) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1072 endif |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1073 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1074 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1075 func Test_getpid() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1076 " getpid() always returns the same value within a vim instance. |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1077 call assert_equal(getpid(), getpid()) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1078 if has('unix') |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1079 call assert_equal(systemlist('echo $PPID')[0], string(getpid())) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1080 endif |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1081 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1082 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1083 func Test_hlexists() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1084 call assert_equal(0, hlexists('does_not_exist')) |
17914
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1085 call assert_equal(0, 'Number'->hlexists()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1086 call assert_equal(0, highlight_exists('does_not_exist')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1087 call assert_equal(0, highlight_exists('Number')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1088 syntax on |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1089 call assert_equal(0, hlexists('does_not_exist')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1090 call assert_equal(1, hlexists('Number')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1091 call assert_equal(0, highlight_exists('does_not_exist')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1092 call assert_equal(1, highlight_exists('Number')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1093 syntax off |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1094 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1095 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1096 func Test_col() |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1097 new |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1098 call setline(1, 'abcdef') |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1099 norm gg4|mx6|mY2| |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1100 call assert_equal(2, col('.')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1101 call assert_equal(7, col('$')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1102 call assert_equal(4, col("'x")) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1103 call assert_equal(6, col("'Y")) |
17837
f71ee7b04f0b
patch 8.1.1915: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17829
diff
changeset
|
1104 call assert_equal(2, [1, 2]->col()) |
11095
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1105 call assert_equal(7, col([1, '$'])) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1106 |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1107 call assert_equal(0, col('')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1108 call assert_equal(0, col('x')) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1109 call assert_equal(0, col([2, '$'])) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1110 call assert_equal(0, col([1, 100])) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1111 call assert_equal(0, col([1])) |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1112 bw! |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1113 endfunc |
5763281d212a
patch 8.0.0435: some functions are not tested
Christian Brabandt <cb@256bit.org>
parents:
11024
diff
changeset
|
1114 |
14379
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1115 func Test_inputlist() |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1116 call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>1\<cr>", 'tx') |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1117 call assert_equal(1, c) |
17914
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1118 call feedkeys(":let c = ['Select color:', '1. red', '2. green', '3. blue']->inputlist()\<cr>2\<cr>", 'tx') |
14379
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1119 call assert_equal(2, c) |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1120 call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>3\<cr>", 'tx') |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1121 call assert_equal(3, c) |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1122 |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1123 call assert_fails('call inputlist("")', 'E686:') |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1124 endfunc |
0f1446193ded
patch 8.1.0204: inputlist() is not tested
Christian Brabandt <cb@256bit.org>
parents:
14348
diff
changeset
|
1125 |
11020
50f3e37bc210
patch 8.0.0399: crash when using balloon_show() when not supported
Christian Brabandt <cb@256bit.org>
parents:
10891
diff
changeset
|
1126 func Test_balloon_show() |
11024
973fa964cb91
patch 8.0.0401: test fails with missing balloon feature
Christian Brabandt <cb@256bit.org>
parents:
11020
diff
changeset
|
1127 if has('balloon_eval') |
973fa964cb91
patch 8.0.0401: test fails with missing balloon feature
Christian Brabandt <cb@256bit.org>
parents:
11020
diff
changeset
|
1128 " This won't do anything but must not crash either. |
973fa964cb91
patch 8.0.0401: test fails with missing balloon feature
Christian Brabandt <cb@256bit.org>
parents:
11020
diff
changeset
|
1129 call balloon_show('hi!') |
973fa964cb91
patch 8.0.0401: test fails with missing balloon feature
Christian Brabandt <cb@256bit.org>
parents:
11020
diff
changeset
|
1130 endif |
11020
50f3e37bc210
patch 8.0.0399: crash when using balloon_show() when not supported
Christian Brabandt <cb@256bit.org>
parents:
10891
diff
changeset
|
1131 endfunc |
11191
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1132 |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1133 func Test_setbufvar_options() |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1134 " This tests that aucmd_prepbuf() and aucmd_restbuf() properly restore the |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1135 " window layout. |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1136 call assert_equal(1, winnr('$')) |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1137 split dummy_preview |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1138 resize 2 |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1139 set winfixheight winfixwidth |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1140 let prev_id = win_getid() |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1141 |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1142 wincmd j |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1143 let wh = winheight('.') |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1144 let dummy_buf = bufnr('dummy_buf1', v:true) |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1145 call setbufvar(dummy_buf, '&buftype', 'nofile') |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1146 execute 'belowright vertical split #' . dummy_buf |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1147 call assert_equal(wh, winheight('.')) |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1148 let dum1_id = win_getid() |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1149 |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1150 wincmd h |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1151 let wh = winheight('.') |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1152 let dummy_buf = bufnr('dummy_buf2', v:true) |
17994
0dcc2ee838dd
patch 8.1.1993: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17982
diff
changeset
|
1153 eval 'nofile'->setbufvar(dummy_buf, '&buftype') |
11191
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1154 execute 'belowright vertical split #' . dummy_buf |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1155 call assert_equal(wh, winheight('.')) |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1156 |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1157 bwipe! |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1158 call win_gotoid(prev_id) |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1159 bwipe! |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1160 call win_gotoid(dum1_id) |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1161 bwipe! |
445fd6be2009
patch 8.0.0482: the setbufvar() function may mess up the window layout
Christian Brabandt <cb@256bit.org>
parents:
11135
diff
changeset
|
1162 endfunc |
11325
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1163 |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1164 func Test_redo_in_nested_functions() |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1165 nnoremap g. :set opfunc=Operator<CR>g@ |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1166 function Operator( type, ... ) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1167 let @x = 'XXX' |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1168 execute 'normal! g`[' . (a:type ==# 'line' ? 'V' : 'v') . 'g`]' . '"xp' |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1169 endfunction |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1170 |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1171 function! Apply() |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1172 5,6normal! . |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1173 endfunction |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1174 |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1175 new |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1176 call setline(1, repeat(['some "quoted" text', 'more "quoted" text'], 3)) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1177 1normal g.i" |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1178 call assert_equal('some "XXX" text', getline(1)) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1179 3,4normal . |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1180 call assert_equal('some "XXX" text', getline(3)) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1181 call assert_equal('more "XXX" text', getline(4)) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1182 call Apply() |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1183 call assert_equal('some "XXX" text', getline(5)) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1184 call assert_equal('more "XXX" text', getline(6)) |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1185 bwipe! |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1186 |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1187 nunmap g. |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1188 delfunc Operator |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1189 delfunc Apply |
77f3b7316d8b
patch 8.0.0548: saving the redo buffer only works one time
Christian Brabandt <cb@256bit.org>
parents:
11197
diff
changeset
|
1190 endfunc |
11484
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1191 |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1192 func Test_shellescape() |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1193 let save_shell = &shell |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1194 set shell=bash |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1195 call assert_equal("'text'", shellescape('text')) |
18000
7a19c8d6bb9e
patch 8.1.1996: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17994
diff
changeset
|
1196 call assert_equal("'te\"xt'", 'te"xt'->shellescape()) |
11484
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1197 call assert_equal("'te'\\''xt'", shellescape("te'xt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1198 |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1199 call assert_equal("'te%xt'", shellescape("te%xt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1200 call assert_equal("'te\\%xt'", shellescape("te%xt", 1)) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1201 call assert_equal("'te#xt'", shellescape("te#xt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1202 call assert_equal("'te\\#xt'", shellescape("te#xt", 1)) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1203 call assert_equal("'te!xt'", shellescape("te!xt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1204 call assert_equal("'te\\!xt'", shellescape("te!xt", 1)) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1205 |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1206 call assert_equal("'te\nxt'", shellescape("te\nxt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1207 call assert_equal("'te\\\nxt'", shellescape("te\nxt", 1)) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1208 set shell=tcsh |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1209 call assert_equal("'te\\!xt'", shellescape("te!xt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1210 call assert_equal("'te\\\\!xt'", shellescape("te!xt", 1)) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1211 call assert_equal("'te\\\nxt'", shellescape("te\nxt")) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1212 call assert_equal("'te\\\\\nxt'", shellescape("te\nxt", 1)) |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1213 |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1214 let &shell = save_shell |
3933a3bf9385
patch 8.0.0625: shellescape() always escapes a newline
Christian Brabandt <cb@256bit.org>
parents:
11325
diff
changeset
|
1215 endfunc |
13513
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1216 |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1217 func Test_trim() |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1218 call assert_equal("Testing", trim(" \t\r\r\x0BTesting \t\n\r\n\t\x0B\x0B")) |
18035
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
1219 call assert_equal("Testing", " \t \r\r\n\n\x0BTesting \t\n\r\n\t\x0B\x0B"->trim()) |
13513
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1220 call assert_equal("RESERVE", trim("xyz \twwRESERVEzyww \t\t", " wxyz\t")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1221 call assert_equal("wRE \tSERVEzyww", trim("wRE \tSERVEzyww")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1222 call assert_equal("abcd\t xxxx tail", trim(" \tabcd\t xxxx tail")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1223 call assert_equal("\tabcd\t xxxx tail", trim(" \tabcd\t xxxx tail", " ")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1224 call assert_equal(" \tabcd\t xxxx tail", trim(" \tabcd\t xxxx tail", "abx")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1225 call assert_equal("RESERVE", trim("你RESERVE好", "你好")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1226 call assert_equal("您R E SER V E早", trim("你好您R E SER V E早好你你", "你好")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1227 call assert_equal("你好您R E SER V E早好你你", trim(" \n\r\r 你好您R E SER V E早好你你 \t \x0B", )) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1228 call assert_equal("您R E SER V E早好你你 \t \x0B", trim(" 你好您R E SER V E早好你你 \t \x0B", " 你好")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1229 call assert_equal("您R E SER V E早好你你 \t \x0B", trim(" tteesstttt你好您R E SER V E早好你你 \t \x0B ttestt", " 你好tes")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1230 call assert_equal("您R E SER V E早好你你 \t \x0B", trim(" tteesstttt你好您R E SER V E早好你你 \t \x0B ttestt", " 你你你好好好tttsses")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1231 call assert_equal("留下", trim("这些些不要这些留下这些", "这些不要")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1232 call assert_equal("", trim("", "")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1233 call assert_equal("a", trim("a", "")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1234 call assert_equal("", trim("", "a")) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1235 |
17976
6d11a0d5751d
patch 8.1.1984: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17952
diff
changeset
|
1236 let chars = join(map(range(1, 0x20) + [0xa0], {n -> n->nr2char()}), '') |
13513
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1237 call assert_equal("x", trim(chars . "x" . chars)) |
4064f342bea4
patch 8.0.1630: trimming white space is not that easy
Christian Brabandt <cb@256bit.org>
parents:
13092
diff
changeset
|
1238 endfunc |
14004
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1239 |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1240 " Test for reg_recording() and reg_executing() |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1241 func Test_reg_executing_and_recording() |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1242 let s:reg_stat = '' |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1243 func s:save_reg_stat() |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1244 let s:reg_stat = reg_recording() . ':' . reg_executing() |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1245 return '' |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1246 endfunc |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1247 |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1248 new |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1249 call s:save_reg_stat() |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1250 call assert_equal(':', s:reg_stat) |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1251 call feedkeys("qa\"=s:save_reg_stat()\<CR>pq", 'xt') |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1252 call assert_equal('a:', s:reg_stat) |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1253 call feedkeys("@a", 'xt') |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1254 call assert_equal(':a', s:reg_stat) |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1255 call feedkeys("qb@aq", 'xt') |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1256 call assert_equal('b:a', s:reg_stat) |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1257 call feedkeys("q\"\"=s:save_reg_stat()\<CR>pq", 'xt') |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1258 call assert_equal('":', s:reg_stat) |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1259 |
15973
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1260 " :normal command saves and restores reg_executing |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1261 let s:reg_stat = '' |
15973
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1262 let @q = ":call TestFunc()\<CR>:call s:save_reg_stat()\<CR>" |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1263 func TestFunc() abort |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1264 normal! ia |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1265 endfunc |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1266 call feedkeys("@q", 'xt') |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1267 call assert_equal(':q', s:reg_stat) |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1268 delfunc TestFunc |
393a9a3a2da2
patch 8.1.0992: a :normal command resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15774
diff
changeset
|
1269 |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1270 " getchar() command saves and restores reg_executing |
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1271 map W :call TestFunc()<CR> |
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1272 let @q = "W" |
16144
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1273 let g:typed = '' |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1274 let g:regs = [] |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1275 func TestFunc() abort |
16144
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1276 let g:regs += [reg_executing()] |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1277 let g:typed = getchar(0) |
16144
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1278 let g:regs += [reg_executing()] |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1279 endfunc |
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1280 call feedkeys("@qy", 'xt') |
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1281 call assert_equal(char2nr("y"), g:typed) |
16144
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1282 call assert_equal(['q', 'q'], g:regs) |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1283 delfunc TestFunc |
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1284 unmap W |
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1285 unlet g:typed |
16144
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1286 unlet g:regs |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1287 |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1288 " input() command saves and restores reg_executing |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1289 map W :call TestFunc()<CR> |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1290 let @q = "W" |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1291 let g:typed = '' |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1292 let g:regs = [] |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1293 func TestFunc() abort |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1294 let g:regs += [reg_executing()] |
17914
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1295 let g:typed = '?'->input() |
16144
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1296 let g:regs += [reg_executing()] |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1297 endfunc |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1298 call feedkeys("@qy\<CR>", 'xt') |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1299 call assert_equal("y", g:typed) |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1300 call assert_equal(['q', 'q'], g:regs) |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1301 delfunc TestFunc |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1302 unmap W |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1303 unlet g:typed |
4850744dc181
patch 8.1.1077: reg_executing() is reset by calling input()
Bram Moolenaar <Bram@vim.org>
parents:
15979
diff
changeset
|
1304 unlet g:regs |
15979
72987a858c96
patch 8.1.0995: a getchar() call resets the reg_executing() result
Bram Moolenaar <Bram@vim.org>
parents:
15973
diff
changeset
|
1305 |
14004
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1306 bwipe! |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1307 delfunc s:save_reg_stat |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1308 unlet s:reg_stat |
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13980
diff
changeset
|
1309 endfunc |
14137
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1310 |
17914
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1311 func Test_inputsecret() |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1312 map W :call TestFunc()<CR> |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1313 let @q = "W" |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1314 let g:typed1 = '' |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1315 let g:typed2 = '' |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1316 let g:regs = [] |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1317 func TestFunc() abort |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1318 let g:typed1 = '?'->inputsecret() |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1319 let g:typed2 = inputsecret('password: ') |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1320 endfunc |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1321 call feedkeys("@qsomething\<CR>else\<CR>", 'xt') |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1322 call assert_equal("something", g:typed1) |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1323 call assert_equal("else", g:typed2) |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1324 delfunc TestFunc |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1325 unmap W |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1326 unlet g:typed1 |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1327 unlet g:typed2 |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1328 endfunc |
af3d441845cd
patch 8.1.1953: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17871
diff
changeset
|
1329 |
17952
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1330 func Test_getchar() |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1331 call feedkeys('a', '') |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1332 call assert_equal(char2nr('a'), getchar()) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1333 |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1334 call test_setmouse(1, 3) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1335 let v:mouse_win = 9 |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1336 let v:mouse_winid = 9 |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1337 let v:mouse_lnum = 9 |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1338 let v:mouse_col = 9 |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1339 call feedkeys("\<S-LeftMouse>", '') |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1340 call assert_equal("\<S-LeftMouse>", getchar()) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1341 call assert_equal(1, v:mouse_win) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1342 call assert_equal(win_getid(1), v:mouse_winid) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1343 call assert_equal(1, v:mouse_lnum) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1344 call assert_equal(3, v:mouse_col) |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1345 endfunc |
4754339d9aee
patch 8.1.1972: no proper test for getchar()
Bram Moolenaar <Bram@vim.org>
parents:
17944
diff
changeset
|
1346 |
14137
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1347 func Test_libcall_libcallnr() |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1348 if !has('libcall') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1349 return |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1350 endif |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1351 |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1352 if has('win32') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1353 let libc = 'msvcrt.dll' |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1354 elseif has('mac') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1355 let libc = 'libSystem.B.dylib' |
15677
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1356 elseif executable('ldd') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1357 let libc = matchstr(split(system('ldd ' . GetVimProg())), '/libc\.so\>') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1358 endif |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1359 if get(l:, 'libc', '') ==# '' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1360 " On Unix, libc.so can be in various places. |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1361 if has('linux') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1362 " There is not documented but regarding the 1st argument of glibc's |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1363 " dlopen an empty string and nullptr are equivalent, so using an empty |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1364 " string for the 1st argument of libcall allows to call functions. |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1365 let libc = '' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1366 elseif has('sun') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1367 " Set the path to libc.so according to the architecture. |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1368 let test_bits = system('file ' . GetVimProg()) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1369 let test_arch = system('uname -p') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1370 if test_bits =~ '64-bit' && test_arch =~ 'sparc' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1371 let libc = '/usr/lib/sparcv9/libc.so' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1372 elseif test_bits =~ '64-bit' && test_arch =~ 'i386' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1373 let libc = '/usr/lib/amd64/libc.so' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1374 else |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1375 let libc = '/usr/lib/libc.so' |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1376 endif |
14669
63d5ae57a663
patch 8.1.0347: some tests fail on Solaris
Christian Brabandt <cb@256bit.org>
parents:
14579
diff
changeset
|
1377 else |
15677
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1378 " Unfortunately skip this test until a good way is found. |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1379 return |
14669
63d5ae57a663
patch 8.1.0347: some tests fail on Solaris
Christian Brabandt <cb@256bit.org>
parents:
14579
diff
changeset
|
1380 endif |
14137
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1381 endif |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1382 |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1383 if has('win32') |
17916
2e53305f2239
patch 8.1.1954: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17914
diff
changeset
|
1384 call assert_equal($USERPROFILE, 'USERPROFILE'->libcall(libc, 'getenv')) |
14137
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1385 else |
17916
2e53305f2239
patch 8.1.1954: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17914
diff
changeset
|
1386 call assert_equal($HOME, 'HOME'->libcall(libc, 'getenv')) |
14137
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1387 endif |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1388 |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1389 " If function returns NULL, libcall() should return an empty string. |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1390 call assert_equal('', libcall(libc, 'getenv', 'X_ENV_DOES_NOT_EXIT')) |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1391 |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1392 " Test libcallnr() with string and integer argument. |
17916
2e53305f2239
patch 8.1.1954: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17914
diff
changeset
|
1393 call assert_equal(4, 'abcd'->libcallnr(libc, 'strlen')) |
2e53305f2239
patch 8.1.1954: more functions can be used as a method
Bram Moolenaar <Bram@vim.org>
parents:
17914
diff
changeset
|
1394 call assert_equal(char2nr('A'), char2nr('a')->libcallnr(libc, 'toupper')) |
14137
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1395 |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1396 call assert_fails("call libcall(libc, 'Xdoesnotexist_', '')", 'E364:') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1397 call assert_fails("call libcallnr(libc, 'Xdoesnotexist_', '')", 'E364:') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1398 |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1399 call assert_fails("call libcall('Xdoesnotexist_', 'getenv', 'HOME')", 'E364:') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1400 call assert_fails("call libcallnr('Xdoesnotexist_', 'strlen', 'abcd')", 'E364:') |
0d534adbcc2f
patch 8.1.0086: no tests for libcall() and libcallnr()
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1401 endfunc |
14348
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1402 |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1403 sandbox function Fsandbox() |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1404 normal ix |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1405 endfunc |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1406 |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1407 func Test_func_sandbox() |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1408 sandbox let F = {-> 'hello'} |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1409 call assert_equal('hello', F()) |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1410 |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1411 sandbox let F = {-> "normal ix\<Esc>"->execute()} |
14348
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1412 call assert_fails('call F()', 'E48:') |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1413 unlet F |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1414 |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1415 call assert_fails('call Fsandbox()', 'E48:') |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1416 delfunc Fsandbox |
e73c0a0e7e87
patch 8.1.0189: function defined in sandbox not tested
Christian Brabandt <cb@256bit.org>
parents:
14137
diff
changeset
|
1417 endfunc |
15000
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1418 |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1419 func EditAnotherFile() |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1420 let word = expand('<cword>') |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1421 edit Xfuncrange2 |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1422 endfunc |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1423 |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1424 func Test_func_range_with_edit() |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1425 " Define a function that edits another buffer, then call it with a range that |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1426 " is invalid in that buffer. |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1427 call writefile(['just one line'], 'Xfuncrange2') |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1428 new |
17994
0dcc2ee838dd
patch 8.1.1993: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17982
diff
changeset
|
1429 eval 10->range()->setline(1) |
15000
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1430 write Xfuncrange1 |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1431 call assert_fails('5,8call EditAnotherFile()', 'E16:') |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1432 |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1433 call delete('Xfuncrange1') |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1434 call delete('Xfuncrange2') |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1435 bwipe! |
32787e326de2
patch 8.1.0511: ml_get error when calling a function with a range
Bram Moolenaar <Bram@vim.org>
parents:
14895
diff
changeset
|
1436 endfunc |
15008
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1437 |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1438 func Test_func_exists_on_reload() |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1439 call writefile(['func ExistingFunction()', 'echo "yes"', 'endfunc'], 'Xfuncexists') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1440 call assert_equal(0, exists('*ExistingFunction')) |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1441 source Xfuncexists |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1442 call assert_equal(1, '*ExistingFunction'->exists()) |
15008
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1443 " Redefining a function when reloading a script is OK. |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1444 source Xfuncexists |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1445 call assert_equal(1, exists('*ExistingFunction')) |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1446 |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1447 " But redefining in another script is not OK. |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1448 call writefile(['func ExistingFunction()', 'echo "yes"', 'endfunc'], 'Xfuncexists2') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1449 call assert_fails('source Xfuncexists2', 'E122:') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1450 |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1451 delfunc ExistingFunction |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1452 call assert_equal(0, exists('*ExistingFunction')) |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1453 call writefile([ |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1454 \ 'func ExistingFunction()', 'echo "yes"', 'endfunc', |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1455 \ 'func ExistingFunction()', 'echo "no"', 'endfunc', |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1456 \ ], 'Xfuncexists') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1457 call assert_fails('source Xfuncexists', 'E122:') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1458 call assert_equal(1, exists('*ExistingFunction')) |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1459 |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1460 call delete('Xfuncexists2') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1461 call delete('Xfuncexists') |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1462 delfunc ExistingFunction |
67e3103d6e18
patch 8.1.0515: reloading a script gives errors for existing functions
Bram Moolenaar <Bram@vim.org>
parents:
15000
diff
changeset
|
1463 endfunc |
15649
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1464 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1465 " Test confirm({msg} [, {choices} [, {default} [, {type}]]]) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1466 func Test_confirm() |
17657
0da9bc55c31a
patch 8.1.1826: tests use hand coded feature and option checks
Bram Moolenaar <Bram@vim.org>
parents:
17484
diff
changeset
|
1467 CheckUnix |
0da9bc55c31a
patch 8.1.1826: tests use hand coded feature and option checks
Bram Moolenaar <Bram@vim.org>
parents:
17484
diff
changeset
|
1468 CheckNotGui |
15649
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1469 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1470 call feedkeys('o', 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1471 let a = confirm('Press O to proceed') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1472 call assert_equal(1, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1473 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1474 call feedkeys('y', 'L') |
17837
f71ee7b04f0b
patch 8.1.1915: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17829
diff
changeset
|
1475 let a = 'Are you sure?'->confirm("&Yes\n&No") |
15649
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1476 call assert_equal(1, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1477 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1478 call feedkeys('n', 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1479 let a = confirm('Are you sure?', "&Yes\n&No") |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1480 call assert_equal(2, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1481 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1482 " confirm() should return 0 when pressing CTRL-C. |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1483 call feedkeys("\<C-c>", 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1484 let a = confirm('Are you sure?', "&Yes\n&No") |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1485 call assert_equal(0, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1486 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1487 " <Esc> requires another character to avoid it being seen as the start of an |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1488 " escape sequence. Zero should be harmless. |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1489 eval "\<Esc>0"->feedkeys('L') |
15649
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1490 let a = confirm('Are you sure?', "&Yes\n&No") |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1491 call assert_equal(0, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1492 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1493 " Default choice is returned when pressing <CR>. |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1494 call feedkeys("\<CR>", 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1495 let a = confirm('Are you sure?', "&Yes\n&No") |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1496 call assert_equal(1, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1497 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1498 call feedkeys("\<CR>", 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1499 let a = confirm('Are you sure?', "&Yes\n&No", 2) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1500 call assert_equal(2, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1501 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1502 call feedkeys("\<CR>", 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1503 let a = confirm('Are you sure?', "&Yes\n&No", 0) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1504 call assert_equal(0, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1505 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1506 " Test with the {type} 4th argument |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1507 for type in ['Error', 'Question', 'Info', 'Warning', 'Generic'] |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1508 call feedkeys('y', 'L') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1509 let a = confirm('Are you sure?', "&Yes\n&No\n", 1, type) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1510 call assert_equal(1, a) |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1511 endfor |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1512 |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1513 call assert_fails('call confirm([])', 'E730:') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1514 call assert_fails('call confirm("Are you sure?", [])', 'E730:') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1515 call assert_fails('call confirm("Are you sure?", "&Yes\n&No\n", [])', 'E745:') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1516 call assert_fails('call confirm("Are you sure?", "&Yes\n&No\n", 0, [])', 'E730:') |
e649df212461
patch 8.1.0832: confirm() is not tested
Bram Moolenaar <Bram@vim.org>
parents:
15607
diff
changeset
|
1517 endfunc |
15677
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1518 |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1519 func Test_platform_name() |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1520 " The system matches at most only one name. |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1521 let names = ['amiga', 'beos', 'bsd', 'hpux', 'linux', 'mac', 'qnx', 'sun', 'vms', 'win32', 'win32unix'] |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1522 call assert_inrange(0, 1, len(filter(copy(names), 'has(v:val)'))) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1523 |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1524 " Is Unix? |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1525 call assert_equal(has('beos'), has('beos') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1526 call assert_equal(has('bsd'), has('bsd') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1527 call assert_equal(has('hpux'), has('hpux') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1528 call assert_equal(has('linux'), has('linux') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1529 call assert_equal(has('mac'), has('mac') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1530 call assert_equal(has('qnx'), has('qnx') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1531 call assert_equal(has('sun'), has('sun') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1532 call assert_equal(has('win32'), has('win32') && !has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1533 call assert_equal(has('win32unix'), has('win32unix') && has('unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1534 |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1535 if has('unix') && executable('uname') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1536 let uname = system('uname') |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1537 call assert_equal(uname =~? 'BeOS', has('beos')) |
15742
916c13256877
patch 8.1.0878: test for has('bsd') fails on some BSD systems
Bram Moolenaar <Bram@vim.org>
parents:
15677
diff
changeset
|
1538 " GNU userland on BSD kernels (e.g., GNU/kFreeBSD) don't have BSD defined |
916c13256877
patch 8.1.0878: test for has('bsd') fails on some BSD systems
Bram Moolenaar <Bram@vim.org>
parents:
15677
diff
changeset
|
1539 call assert_equal(uname =~? '\%(GNU/k\w\+\)\@<!BSD\|DragonFly', has('bsd')) |
15677
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1540 call assert_equal(uname =~? 'HP-UX', has('hpux')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1541 call assert_equal(uname =~? 'Linux', has('linux')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1542 call assert_equal(uname =~? 'Darwin', has('mac')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1543 call assert_equal(uname =~? 'QNX', has('qnx')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1544 call assert_equal(uname =~? 'SunOS', has('sun')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1545 call assert_equal(uname =~? 'CYGWIN\|MSYS', has('win32unix')) |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1546 endif |
772e72b046a3
patch 8.1.0846: not easy to recognize the system Vim runs on
Bram Moolenaar <Bram@vim.org>
parents:
15649
diff
changeset
|
1547 endfunc |
16231
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1548 |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1549 func Test_readdir() |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1550 call mkdir('Xdir') |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1551 call writefile([], 'Xdir/foo.txt') |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1552 call writefile([], 'Xdir/bar.txt') |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1553 call mkdir('Xdir/dir') |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1554 |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1555 " All results |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1556 let files = readdir('Xdir') |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1557 call assert_equal(['bar.txt', 'dir', 'foo.txt'], sort(files)) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1558 |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1559 " Only results containing "f" |
17982
2029737e6a22
patch 8.1.1987: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17976
diff
changeset
|
1560 let files = 'Xdir'->readdir({ x -> stridx(x, 'f') !=- 1 }) |
16231
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1561 call assert_equal(['foo.txt'], sort(files)) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1562 |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1563 " Only .txt files |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1564 let files = readdir('Xdir', { x -> x =~ '.txt$' }) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1565 call assert_equal(['bar.txt', 'foo.txt'], sort(files)) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1566 |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1567 " Only .txt files with string |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1568 let files = readdir('Xdir', 'v:val =~ ".txt$"') |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1569 call assert_equal(['bar.txt', 'foo.txt'], sort(files)) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1570 |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1571 " Limit to 1 result. |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1572 let l = [] |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1573 let files = readdir('Xdir', {x -> len(add(l, x)) == 2 ? -1 : 1}) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1574 call assert_equal(1, len(files)) |
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1575 |
17944
745c02392844
patch 8.1.1968: crash when using nested map()
Bram Moolenaar <Bram@vim.org>
parents:
17930
diff
changeset
|
1576 " Nested readdir() must not crash |
745c02392844
patch 8.1.1968: crash when using nested map()
Bram Moolenaar <Bram@vim.org>
parents:
17930
diff
changeset
|
1577 let files = readdir('Xdir', 'readdir("Xdir", "1") != []') |
745c02392844
patch 8.1.1968: crash when using nested map()
Bram Moolenaar <Bram@vim.org>
parents:
17930
diff
changeset
|
1578 call sort(files)->assert_equal(['bar.txt', 'dir', 'foo.txt']) |
745c02392844
patch 8.1.1968: crash when using nested map()
Bram Moolenaar <Bram@vim.org>
parents:
17930
diff
changeset
|
1579 |
17837
f71ee7b04f0b
patch 8.1.1915: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17829
diff
changeset
|
1580 eval 'Xdir'->delete('rf') |
16231
0761a4c111a7
patch 8.1.1120: cannot easily get directory entry matches
Bram Moolenaar <Bram@vim.org>
parents:
16180
diff
changeset
|
1581 endfunc |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1582 |
16752
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1583 func Test_delete_rf() |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1584 call mkdir('Xdir') |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1585 call writefile([], 'Xdir/foo.txt') |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1586 call writefile([], 'Xdir/bar.txt') |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1587 call mkdir('Xdir/[a-1]') " issue #696 |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1588 call writefile([], 'Xdir/[a-1]/foo.txt') |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1589 call writefile([], 'Xdir/[a-1]/bar.txt') |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1590 call assert_true(filereadable('Xdir/foo.txt')) |
17849
73ddc462979d
patch 8.1.1921: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17837
diff
changeset
|
1591 call assert_true('Xdir/[a-1]/foo.txt'->filereadable()) |
16752
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1592 |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1593 call assert_equal(0, delete('Xdir', 'rf')) |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1594 call assert_false(filereadable('Xdir/foo.txt')) |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1595 call assert_false(filereadable('Xdir/[a-1]/foo.txt')) |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1596 endfunc |
e2d8d83e6721
patch 8.1.1378: delete() can not handle a file name that looks like a pattern
Bram Moolenaar <Bram@vim.org>
parents:
16668
diff
changeset
|
1597 |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1598 func Test_call() |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1599 call assert_equal(3, call('len', [123])) |
17829
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
1600 call assert_equal(3, 'len'->call([123])) |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1601 call assert_fails("call call('len', 123)", 'E714:') |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1602 call assert_equal(0, call('', [])) |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1603 |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1604 function Mylen() dict |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1605 return len(self.data) |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1606 endfunction |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1607 let mydict = {'data': [0, 1, 2, 3], 'len': function("Mylen")} |
17829
1090d6637cfd
patch 8.1.1911: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17783
diff
changeset
|
1608 eval mydict.len->call([], mydict)->assert_equal(4) |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1609 call assert_fails("call call('Mylen', [], 0)", 'E715:') |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1610 endfunc |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1611 |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1612 func Test_char2nr() |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1613 call assert_equal(12354, char2nr('あ', 1)) |
17837
f71ee7b04f0b
patch 8.1.1915: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17829
diff
changeset
|
1614 call assert_equal(120, 'x'->char2nr()) |
16668
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1615 endfunc |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1616 |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1617 func Test_eventhandler() |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1618 call assert_equal(0, eventhandler()) |
81be817c9d9a
patch 8.1.1336: some eval functionality is not covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
16231
diff
changeset
|
1619 endfunc |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1620 |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1621 func Test_bufadd_bufload() |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1622 call assert_equal(0, bufexists('someName')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1623 let buf = bufadd('someName') |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1624 call assert_notequal(0, buf) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1625 call assert_equal(1, bufexists('someName')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1626 call assert_equal(0, getbufvar(buf, '&buflisted')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1627 call assert_equal(0, bufloaded(buf)) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1628 call bufload(buf) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1629 call assert_equal(1, bufloaded(buf)) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1630 call assert_equal([''], getbufline(buf, 1, '$')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1631 |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1632 let curbuf = bufnr('') |
18035
11dca9732a48
patch 8.1.2013: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
18017
diff
changeset
|
1633 eval ['some', 'text']->writefile('XotherName') |
17783
45eca7143d7c
patch 8.1.1888: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17657
diff
changeset
|
1634 let buf = 'XotherName'->bufadd() |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1635 call assert_notequal(0, buf) |
17783
45eca7143d7c
patch 8.1.1888: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17657
diff
changeset
|
1636 eval 'XotherName'->bufexists()->assert_equal(1) |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1637 call assert_equal(0, getbufvar(buf, '&buflisted')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1638 call assert_equal(0, bufloaded(buf)) |
17783
45eca7143d7c
patch 8.1.1888: more functions can be used as methods
Bram Moolenaar <Bram@vim.org>
parents:
17657
diff
changeset
|
1639 eval buf->bufload() |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1640 call assert_equal(1, bufloaded(buf)) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1641 call assert_equal(['some', 'text'], getbufline(buf, 1, '$')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1642 call assert_equal(curbuf, bufnr('')) |
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1643 |
17223
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1644 let buf1 = bufadd('') |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1645 let buf2 = bufadd('') |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1646 call assert_notequal(0, buf1) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1647 call assert_notequal(0, buf2) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1648 call assert_notequal(buf1, buf2) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1649 call assert_equal(1, bufexists(buf1)) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1650 call assert_equal(1, bufexists(buf2)) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1651 call assert_equal(0, bufloaded(buf1)) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1652 exe 'bwipe ' .. buf1 |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1653 call assert_equal(0, bufexists(buf1)) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1654 call assert_equal(1, bufexists(buf2)) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1655 exe 'bwipe ' .. buf2 |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1656 call assert_equal(0, bufexists(buf2)) |
07bbe73b8e74
patch 8.1.1611: bufadd() reuses existing buffer without a name
Bram Moolenaar <Bram@vim.org>
parents:
17221
diff
changeset
|
1657 |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1658 bwipe someName |
17278
b6de6181e5ab
patch 8.1.1638: running tests leaves some files behind
Bram Moolenaar <Bram@vim.org>
parents:
17223
diff
changeset
|
1659 bwipe XotherName |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1660 call assert_equal(0, bufexists('someName')) |
17278
b6de6181e5ab
patch 8.1.1638: running tests leaves some files behind
Bram Moolenaar <Bram@vim.org>
parents:
17223
diff
changeset
|
1661 call delete('XotherName') |
17221
a8fc7d97b54d
patch 8.1.1610: there is no way to add or load a buffer without side effects
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
1662 endfunc |
18143
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1663 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1664 func Test_state() |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1665 CheckRunVimInTerminal |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1666 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1667 let lines =<< trim END |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1668 call setline(1, ['one', 'two', 'three']) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1669 map ;; gg |
18209
9a7bbad64376
patch 8.1.2099: state() test fails on some Mac systems
Bram Moolenaar <Bram@vim.org>
parents:
18143
diff
changeset
|
1670 set complete=. |
18143
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1671 func RunTimer() |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1672 call timer_start(10, {id -> execute('let g:state = state()') .. execute('let g:mode = mode()')}) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1673 endfunc |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1674 au Filetype foobar let g:state = state()|let g:mode = mode() |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1675 END |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1676 call writefile(lines, 'XState') |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1677 let buf = RunVimInTerminal('-S XState', #{rows: 6}) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1678 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1679 " Using a ":" command Vim is busy, thus "S" is returned |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1680 call term_sendkeys(buf, ":echo 'state: ' .. state() .. '; mode: ' .. mode()\<CR>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1681 call WaitForAssert({-> assert_match('state: S; mode: n', term_getline(buf, 6))}, 1000) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1682 call term_sendkeys(buf, ":\<CR>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1683 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1684 " Using a timer callback |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1685 call term_sendkeys(buf, ":call RunTimer()\<CR>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1686 call term_wait(buf, 50) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1687 let getstate = ":echo 'state: ' .. g:state .. '; mode: ' .. g:mode\<CR>" |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1688 call term_sendkeys(buf, getstate) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1689 call WaitForAssert({-> assert_match('state: c; mode: n', term_getline(buf, 6))}, 1000) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1690 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1691 " Halfway a mapping |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1692 call term_sendkeys(buf, ":call RunTimer()\<CR>;") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1693 call term_wait(buf, 50) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1694 call term_sendkeys(buf, ";") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1695 call term_sendkeys(buf, getstate) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1696 call WaitForAssert({-> assert_match('state: mSc; mode: n', term_getline(buf, 6))}, 1000) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1697 |
18209
9a7bbad64376
patch 8.1.2099: state() test fails on some Mac systems
Bram Moolenaar <Bram@vim.org>
parents:
18143
diff
changeset
|
1698 " Insert mode completion (bit slower on Mac) |
18143
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1699 call term_sendkeys(buf, ":call RunTimer()\<CR>Got\<C-N>") |
18209
9a7bbad64376
patch 8.1.2099: state() test fails on some Mac systems
Bram Moolenaar <Bram@vim.org>
parents:
18143
diff
changeset
|
1700 call term_wait(buf, 200) |
18143
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1701 call term_sendkeys(buf, "\<Esc>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1702 call term_sendkeys(buf, getstate) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1703 call WaitForAssert({-> assert_match('state: aSc; mode: i', term_getline(buf, 6))}, 1000) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1704 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1705 " Autocommand executing |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1706 call term_sendkeys(buf, ":set filetype=foobar\<CR>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1707 call term_wait(buf, 50) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1708 call term_sendkeys(buf, getstate) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1709 call WaitForAssert({-> assert_match('state: xS; mode: n', term_getline(buf, 6))}, 1000) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1710 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1711 " Todo: "w" - waiting for ch_evalexpr() |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1712 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1713 " messages scrolled |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1714 call term_sendkeys(buf, ":call RunTimer()\<CR>:echo \"one\\ntwo\\nthree\"\<CR>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1715 call term_wait(buf, 50) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1716 call term_sendkeys(buf, "\<CR>") |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1717 call term_sendkeys(buf, getstate) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1718 call WaitForAssert({-> assert_match('state: Scs; mode: r', term_getline(buf, 6))}, 1000) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1719 |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1720 call StopVimInTerminal(buf) |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1721 call delete('XState') |
2416e1a887ca
patch 8.1.2066: no tests for state()
Bram Moolenaar <Bram@vim.org>
parents:
18096
diff
changeset
|
1722 endfunc |