mirror of
https://github.com/neovim/neovim.git
synced 2025-10-15 22:36:09 +00:00
vim-patch:8.1.1809: more functions can be used as a method
Problem: More functions can be used as a method.
Solution: Add has_key(), split(), str2list(), etc.
a74e4946de
This commit is contained in:
@@ -3274,6 +3274,7 @@ count({comp}, {expr} [, {ic} [, {start}]]) *count()*
|
|||||||
When {comp} is a string then the number of not overlapping
|
When {comp} is a string then the number of not overlapping
|
||||||
occurrences of {expr} is returned. Zero is returned when
|
occurrences of {expr} is returned. Zero is returned when
|
||||||
{expr} is an empty string.
|
{expr} is an empty string.
|
||||||
|
|
||||||
Can also be used as a |method|: >
|
Can also be used as a |method|: >
|
||||||
mylist->count(val)
|
mylist->count(val)
|
||||||
|
|
||||||
@@ -5212,6 +5213,9 @@ has_key({dict}, {key}) *has_key()*
|
|||||||
The result is a Number, which is TRUE if |Dictionary| {dict}
|
The result is a Number, which is TRUE if |Dictionary| {dict}
|
||||||
has an entry with key {key}. FALSE otherwise.
|
has an entry with key {key}. FALSE otherwise.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
mydict->has_key(key)
|
||||||
|
|
||||||
haslocaldir([{winnr}[, {tabnr}]]) *haslocaldir()*
|
haslocaldir([{winnr}[, {tabnr}]]) *haslocaldir()*
|
||||||
The result is a Number, which is 1 when the tabpage or window
|
The result is a Number, which is 1 when the tabpage or window
|
||||||
has set a local path via |:tcd| or |:lcd|, otherwise 0.
|
has set a local path via |:tcd| or |:lcd|, otherwise 0.
|
||||||
@@ -8376,6 +8380,8 @@ split({expr} [, {pattern} [, {keepempty}]]) *split()*
|
|||||||
:let items = split(line, ':', 1)
|
:let items = split(line, ':', 1)
|
||||||
< The opposite function is |join()|.
|
< The opposite function is |join()|.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
GetString()->split()
|
||||||
|
|
||||||
sqrt({expr}) *sqrt()*
|
sqrt({expr}) *sqrt()*
|
||||||
Return the non-negative square root of Float {expr} as a
|
Return the non-negative square root of Float {expr} as a
|
||||||
@@ -8454,12 +8460,18 @@ str2list({expr} [, {utf8}]) *str2list()*
|
|||||||
properly: >
|
properly: >
|
||||||
str2list("á") returns [97, 769]
|
str2list("á") returns [97, 769]
|
||||||
|
|
||||||
|
< Can also be used as a |method|: >
|
||||||
|
GetString()->str2list()
|
||||||
|
|
||||||
str2nr({expr} [, {base}]) *str2nr()*
|
str2nr({expr} [, {base}]) *str2nr()*
|
||||||
Convert string {expr} to a number.
|
Convert string {expr} to a number.
|
||||||
{base} is the conversion base, it can be 2, 8, 10 or 16.
|
{base} is the conversion base, it can be 2, 8, 10 or 16.
|
||||||
|
|
||||||
When {base} is omitted base 10 is used. This also means that
|
When {base} is omitted base 10 is used. This also means that
|
||||||
a leading zero doesn't cause octal conversion to be used, as
|
a leading zero doesn't cause octal conversion to be used, as
|
||||||
with the default String to Number conversion.
|
with the default String to Number conversion. Example: >
|
||||||
|
let nr = str2nr('123')
|
||||||
|
<
|
||||||
When {base} is 16 a leading "0x" or "0X" is ignored. With a
|
When {base} is 16 a leading "0x" or "0X" is ignored. With a
|
||||||
different base the result will be zero. Similarly, when {base}
|
different base the result will be zero. Similarly, when {base}
|
||||||
is 8 a leading "0" is ignored, and when {base} is 2 a leading
|
is 8 a leading "0" is ignored, and when {base} is 2 a leading
|
||||||
@@ -8590,6 +8602,9 @@ strlen({expr}) The result is a Number, which is the length of the String
|
|||||||
|strchars()|.
|
|strchars()|.
|
||||||
Also see |len()|, |strdisplaywidth()| and |strwidth()|.
|
Also see |len()|, |strdisplaywidth()| and |strwidth()|.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
GetString()->strlen()
|
||||||
|
|
||||||
strpart({src}, {start} [, {len} [, {chars}]]) *strpart()*
|
strpart({src}, {start} [, {len} [, {chars}]]) *strpart()*
|
||||||
The result is a String, which is part of {src}, starting from
|
The result is a String, which is part of {src}, starting from
|
||||||
byte {start}, with the byte length {len}.
|
byte {start}, with the byte length {len}.
|
||||||
@@ -8664,6 +8679,9 @@ strtrans({expr}) *strtrans()*
|
|||||||
< This displays a newline in register a as "^@" instead of
|
< This displays a newline in register a as "^@" instead of
|
||||||
starting a new line.
|
starting a new line.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
GetString()->strtrans()
|
||||||
|
|
||||||
strwidth({expr}) *strwidth()*
|
strwidth({expr}) *strwidth()*
|
||||||
The result is a Number, which is the number of display cells
|
The result is a Number, which is the number of display cells
|
||||||
String {expr} occupies. A Tab character is counted as one
|
String {expr} occupies. A Tab character is counted as one
|
||||||
@@ -8672,6 +8690,9 @@ strwidth({expr}) *strwidth()*
|
|||||||
Ambiguous, this function's return value depends on 'ambiwidth'.
|
Ambiguous, this function's return value depends on 'ambiwidth'.
|
||||||
Also see |strlen()|, |strdisplaywidth()| and |strchars()|.
|
Also see |strlen()|, |strdisplaywidth()| and |strchars()|.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
GetString()->strwidth()
|
||||||
|
|
||||||
submatch({nr} [, {list}]) *submatch()* *E935*
|
submatch({nr} [, {list}]) *submatch()* *E935*
|
||||||
Only for an expression in a |:substitute| command or
|
Only for an expression in a |:substitute| command or
|
||||||
substitute() function.
|
substitute() function.
|
||||||
@@ -8739,6 +8760,9 @@ substitute({expr}, {pat}, {sub}, {flags}) *substitute()*
|
|||||||
|submatch()| returns. Example: >
|
|submatch()| returns. Example: >
|
||||||
:echo substitute(s, '%\(\x\x\)', {m -> '0x' . m[1]}, 'g')
|
:echo substitute(s, '%\(\x\x\)', {m -> '0x' . m[1]}, 'g')
|
||||||
|
|
||||||
|
< Can also be used as a |method|: >
|
||||||
|
GetString()->substitute(pat, sub, flags)
|
||||||
|
|
||||||
swapinfo({fname}) *swapinfo()*
|
swapinfo({fname}) *swapinfo()*
|
||||||
The result is a dictionary, which holds information about the
|
The result is a dictionary, which holds information about the
|
||||||
swapfile {fname}. The available fields are:
|
swapfile {fname}. The available fields are:
|
||||||
@@ -8823,12 +8847,18 @@ synIDattr({synID}, {what} [, {mode}]) *synIDattr()*
|
|||||||
cursor): >
|
cursor): >
|
||||||
:echo synIDattr(synIDtrans(synID(line("."), col("."), 1)), "fg")
|
:echo synIDattr(synIDtrans(synID(line("."), col("."), 1)), "fg")
|
||||||
<
|
<
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
:echo synID(line("."), col("."), 1)->synIDtrans()->synIDattr("fg")
|
||||||
|
|
||||||
synIDtrans({synID}) *synIDtrans()*
|
synIDtrans({synID}) *synIDtrans()*
|
||||||
The result is a Number, which is the translated syntax ID of
|
The result is a Number, which is the translated syntax ID of
|
||||||
{synID}. This is the syntax group ID of what is being used to
|
{synID}. This is the syntax group ID of what is being used to
|
||||||
highlight the character. Highlight links given with
|
highlight the character. Highlight links given with
|
||||||
":highlight link" are followed.
|
":highlight link" are followed.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
:echo synID(line("."), col("."), 1)->synIDtrans()->synIDattr("fg")
|
||||||
|
|
||||||
synconcealed({lnum}, {col}) *synconcealed()*
|
synconcealed({lnum}, {col}) *synconcealed()*
|
||||||
The result is a |List| with currently three items:
|
The result is a |List| with currently three items:
|
||||||
1. The first item in the list is 0 if the character at the
|
1. The first item in the list is 0 if the character at the
|
||||||
@@ -8925,6 +8955,8 @@ system({cmd} [, {input}]) *system()* *E677*
|
|||||||
Unlike ":!cmd" there is no automatic check for changed files.
|
Unlike ":!cmd" there is no automatic check for changed files.
|
||||||
Use |:checktime| to force a check.
|
Use |:checktime| to force a check.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
:echo GetCmd()->system()
|
||||||
|
|
||||||
systemlist({cmd} [, {input} [, {keepempty}]]) *systemlist()*
|
systemlist({cmd} [, {input} [, {keepempty}]]) *systemlist()*
|
||||||
Same as |system()|, but returns a |List| with lines (parts of
|
Same as |system()|, but returns a |List| with lines (parts of
|
||||||
@@ -8940,6 +8972,8 @@ systemlist({cmd} [, {input} [, {keepempty}]]) *systemlist()*
|
|||||||
<
|
<
|
||||||
Returns an empty string on error.
|
Returns an empty string on error.
|
||||||
|
|
||||||
|
Can also be used as a |method|: >
|
||||||
|
:echo GetCmd()->systemlist()
|
||||||
|
|
||||||
tabpagebuflist([{arg}]) *tabpagebuflist()*
|
tabpagebuflist([{arg}]) *tabpagebuflist()*
|
||||||
The result is a |List|, where each item is the number of the
|
The result is a |List|, where each item is the number of the
|
||||||
|
@@ -180,7 +180,7 @@ return {
|
|||||||
glob2regpat={args=1},
|
glob2regpat={args=1},
|
||||||
globpath={args={2, 5}},
|
globpath={args={2, 5}},
|
||||||
has={args=1},
|
has={args=1},
|
||||||
has_key={args=2},
|
has_key={args=2, base=1},
|
||||||
haslocaldir={args={0,2}},
|
haslocaldir={args={0,2}},
|
||||||
hasmapto={args={1, 3}},
|
hasmapto={args={1, 3}},
|
||||||
highlightID={args=1, func='f_hlID'}, -- obsolete
|
highlightID={args=1, func='f_hlID'}, -- obsolete
|
||||||
@@ -339,11 +339,11 @@ return {
|
|||||||
stdioopen={args=1},
|
stdioopen={args=1},
|
||||||
spellbadword={args={0, 1}},
|
spellbadword={args={0, 1}},
|
||||||
spellsuggest={args={1, 3}},
|
spellsuggest={args={1, 3}},
|
||||||
split={args={1, 3}},
|
split={args={1, 3}, base=1},
|
||||||
sqrt={args=1, func="float_op_wrapper", data="&sqrt"},
|
sqrt={args=1, func="float_op_wrapper", data="&sqrt"},
|
||||||
stdpath={args=1},
|
stdpath={args=1},
|
||||||
str2float={args=1},
|
str2float={args=1},
|
||||||
str2list={args={1, 2}},
|
str2list={args={1, 2}, base=1},
|
||||||
str2nr={args={1, 2}},
|
str2nr={args={1, 2}},
|
||||||
strcharpart={args={2, 3}},
|
strcharpart={args={2, 3}},
|
||||||
strchars={args={1,2}},
|
strchars={args={1,2}},
|
||||||
@@ -352,23 +352,23 @@ return {
|
|||||||
strgetchar={args={2, 2}},
|
strgetchar={args={2, 2}},
|
||||||
stridx={args={2, 3}},
|
stridx={args={2, 3}},
|
||||||
string={args=1, base=1},
|
string={args=1, base=1},
|
||||||
strlen={args=1},
|
strlen={args=1, base=1},
|
||||||
strpart={args={2, 4}},
|
strpart={args={2, 4}},
|
||||||
strptime={args=2},
|
strptime={args=2},
|
||||||
strridx={args={2, 3}},
|
strridx={args={2, 3}},
|
||||||
strtrans={args=1},
|
strtrans={args=1, base=1},
|
||||||
strwidth={args=1},
|
strwidth={args=1, base=1},
|
||||||
submatch={args={1, 2}},
|
submatch={args={1, 2}},
|
||||||
substitute={args=4},
|
substitute={args=4, base=1},
|
||||||
swapinfo={args={1}},
|
swapinfo={args={1}},
|
||||||
swapname={args={1}},
|
swapname={args={1}},
|
||||||
synID={args=3},
|
synID={args=3},
|
||||||
synIDattr={args={2, 3}},
|
synIDattr={args={2, 3}, base=1},
|
||||||
synIDtrans={args=1},
|
synIDtrans={args=1, base=1},
|
||||||
synconcealed={args=2},
|
synconcealed={args=2},
|
||||||
synstack={args=2},
|
synstack={args=2},
|
||||||
system={args={1, 2}},
|
system={args={1, 2}, base=1},
|
||||||
systemlist={args={1, 3}},
|
systemlist={args={1, 3}, base=1},
|
||||||
tabpagebuflist={args={0, 1}},
|
tabpagebuflist={args={0, 1}},
|
||||||
tabpagenr={args={0, 1}},
|
tabpagenr={args={0, 1}},
|
||||||
tabpagewinnr={args={1, 2}},
|
tabpagewinnr={args={1, 2}},
|
||||||
|
@@ -741,16 +741,16 @@ func Test_diff_hlID()
|
|||||||
diffthis
|
diffthis
|
||||||
redraw
|
redraw
|
||||||
|
|
||||||
call assert_equal(synIDattr(diff_hlID(-1, 1), "name"), "")
|
call diff_hlID(-1, 1)->synIDattr("name")->assert_equal("")
|
||||||
|
|
||||||
call assert_equal(diff_hlID(1, 1), hlID("DiffChange"))
|
call assert_equal(diff_hlID(1, 1), hlID("DiffChange"))
|
||||||
call assert_equal(synIDattr(diff_hlID(1, 1), "name"), "DiffChange")
|
call diff_hlID(1, 1)->synIDattr("name")->assert_equal("DiffChange")
|
||||||
call assert_equal(diff_hlID(1, 2), hlID("DiffText"))
|
call assert_equal(diff_hlID(1, 2), hlID("DiffText"))
|
||||||
call assert_equal(synIDattr(diff_hlID(1, 2), "name"), "DiffText")
|
call diff_hlID(1, 2)->synIDattr("name")->assert_equal("DiffText")
|
||||||
call assert_equal(synIDattr(diff_hlID(2, 1), "name"), "")
|
call diff_hlID(2, 1)->synIDattr("name")->assert_equal("")
|
||||||
call assert_equal(diff_hlID(3, 1), hlID("DiffAdd"))
|
call assert_equal(diff_hlID(3, 1), hlID("DiffAdd"))
|
||||||
call assert_equal(synIDattr(diff_hlID(3, 1), "name"), "DiffAdd")
|
call diff_hlID(3, 1)->synIDattr("name")->assert_equal("DiffAdd")
|
||||||
call assert_equal(synIDattr(diff_hlID(4, 1), "name"), "")
|
call diff_hlID(4, 1)->synIDattr("name")->assert_equal("")
|
||||||
|
|
||||||
wincmd w
|
wincmd w
|
||||||
call assert_equal(diff_hlID(1, 1), hlID("DiffChange"))
|
call assert_equal(diff_hlID(1, 1), hlID("DiffChange"))
|
||||||
|
@@ -49,6 +49,7 @@ func Test_dict()
|
|||||||
" call assert_fails("let x = d->insert(0)", 'E899:')
|
" call assert_fails("let x = d->insert(0)", 'E899:')
|
||||||
call assert_fails("let x = d->index(2)", 'E714:')
|
call assert_fails("let x = d->index(2)", 'E714:')
|
||||||
call assert_fails("let x = d->insert(0)", 'E686:')
|
call assert_fails("let x = d->insert(0)", 'E686:')
|
||||||
|
call assert_true(d->has_key('two'))
|
||||||
call assert_equal([['one', 1], ['two', 2], ['three', 3]], d->items())
|
call assert_equal([['one', 1], ['two', 2], ['three', 3]], d->items())
|
||||||
call assert_fails("let x = d->join()", 'E714:')
|
call assert_fails("let x = d->join()", 'E714:')
|
||||||
call assert_equal(['one', 'two', 'three'], d->keys())
|
call assert_equal(['one', 'two', 'three'], d->keys())
|
||||||
@@ -70,6 +71,16 @@ func Test_dict()
|
|||||||
call assert_equal([1, 2, 3], d->values())
|
call assert_equal([1, 2, 3], d->values())
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_string()
|
||||||
|
call assert_equal(['1', '2', '3'], '1 2 3'->split())
|
||||||
|
call assert_equal([1, 2, 3], '1 2 3'->split()->map({i, v -> str2nr(v)}))
|
||||||
|
call assert_equal([65, 66, 67], 'ABC'->str2list())
|
||||||
|
call assert_equal(3, 'ABC'->strlen())
|
||||||
|
call assert_equal('a^Mb^[c', "a\rb\ec"->strtrans())
|
||||||
|
call assert_equal(4, "aあb"->strwidth())
|
||||||
|
call assert_equal('axc', 'abc'->substitute('b', 'x', ''))
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_append()
|
func Test_append()
|
||||||
new
|
new
|
||||||
eval ['one', 'two', 'three']->append(1)
|
eval ['one', 'two', 'three']->append(1)
|
||||||
|
@@ -546,8 +546,8 @@ func Test_synstack_synIDtrans()
|
|||||||
call assert_equal([], synstack(1, 1))
|
call assert_equal([], synstack(1, 1))
|
||||||
|
|
||||||
norm f/
|
norm f/
|
||||||
call assert_equal(['cComment', 'cCommentStart'], map(synstack(line("."), col(".")), 'synIDattr(v:val, "name")'))
|
eval synstack(line("."), col("."))->map('synIDattr(v:val, "name")')->assert_equal(['cComment', 'cCommentStart'])
|
||||||
call assert_equal(['Comment', 'Comment'], map(synstack(line("."), col(".")), 'synIDattr(synIDtrans(v:val), "name")'))
|
eval synstack(line("."), col("."))->map('synIDattr(synIDtrans(v:val), "name")')->assert_equal(['Comment', 'Comment'])
|
||||||
|
|
||||||
norm fA
|
norm fA
|
||||||
call assert_equal(['cComment'], map(synstack(line("."), col(".")), 'synIDattr(v:val, "name")'))
|
call assert_equal(['cComment'], map(synstack(line("."), col(".")), 'synIDattr(v:val, "name")'))
|
||||||
|
@@ -7,10 +7,10 @@ func Test_System()
|
|||||||
if !executable('echo') || !executable('cat') || !executable('wc')
|
if !executable('echo') || !executable('cat') || !executable('wc')
|
||||||
return
|
return
|
||||||
endif
|
endif
|
||||||
let out = system('echo 123')
|
let out = 'echo 123'->system()
|
||||||
call assert_equal("123\n", out)
|
call assert_equal("123\n", out)
|
||||||
|
|
||||||
let out = systemlist('echo 123')
|
let out = 'echo 123'->systemlist()
|
||||||
if &shell =~# 'cmd.exe$'
|
if &shell =~# 'cmd.exe$'
|
||||||
call assert_equal(["123\r"], out)
|
call assert_equal(["123\r"], out)
|
||||||
else
|
else
|
||||||
|
Reference in New Issue
Block a user