diff options
author | zeertzjq <zeertzjq@outlook.com> | 2023-08-21 14:40:43 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-21 14:40:43 +0800 |
commit | 3b0515e674f279d6504a0fc055808cdf01eead99 (patch) | |
tree | 39f1120f66af1d5fb573241d06ce5d2d70d9a028 /src/nvim/eval.lua | |
parent | 91d8f2ac534a51859c0e3c6562d07c94b27f4478 (diff) | |
parent | 6aa29d0f01e715fe51de4f66dee377e4c1726229 (diff) | |
download | rneovim-3b0515e674f279d6504a0fc055808cdf01eead99.tar.gz rneovim-3b0515e674f279d6504a0fc055808cdf01eead99.tar.bz2 rneovim-3b0515e674f279d6504a0fc055808cdf01eead99.zip |
Merge pull request #24816 from zeertzjq/vim-8.1.2044
vim-patch:8.1.{2044,2046,2047,2048,2053,2066,2067,2068,2069,2099},8.2.4299: SafeState, state()
Diffstat (limited to 'src/nvim/eval.lua')
-rw-r--r-- | src/nvim/eval.lua | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/src/nvim/eval.lua b/src/nvim/eval.lua index be87201bbf..e786901c2f 100644 --- a/src/nvim/eval.lua +++ b/src/nvim/eval.lua @@ -6917,6 +6917,7 @@ M.funcs = { If [expr] is supplied and it evaluates to a non-zero Number or a non-empty String (|non-zero-arg|), then the full mode is returned, otherwise only the first letter is returned. + Also see |state()|. n Normal no Operator-pending @@ -10451,6 +10452,42 @@ M.funcs = { params = { { 'what', 'any' } }, signature = 'stdpath({what})', }, + state = { + args = {0, 1}, + base = 1, + desc = [=[ + Return a string which contains characters indicating the + current state. Mostly useful in callbacks that want to do + work that may not always be safe. Roughly this works like: + - callback uses state() to check if work is safe to do. + If yes, then do it right away. + Otherwise add to work queue and add SafeState autocommand. + - When SafeState is triggered, check with state() if the work + can be done now, and if yes remove it from the queue and + execute. + Also see |mode()|. + + When {what} is given only characters in this string will be + added. E.g, this checks if the screen has scrolled: >vim + if state('s') != '' + + These characters indicate the state, generally indicating that + something is busy: + m halfway a mapping, :normal command, feedkeys() or + stuffed command + o operator pending or waiting for a command argument + a Insert mode autocomplete active + x executing an autocommand + S not triggering SafeState + c callback invoked, including timer (repeats for + recursiveness up to "ccc") + s screen has scrolled for messages + ]=], + fast = true, + name = 'state', + params = { { 'what', 'string' } }, + signature = 'state([{what}])', + }, str2float = { args = 1, base = 1, |