From 57fcf4b1c1f8b4f6ff9a7bab4018096db45894fc Mon Sep 17 00:00:00 2001 From: Iron-E Date: Wed, 9 Sep 2020 13:24:48 -0400 Subject: [PATCH 1/6] Add ability to specify lua functions as instructions; TODO docs --- lua/libmodal/src/Mode.lua | 22 ++++++++++++++--- lua/libmodal/src/Prompt.lua | 49 +++++++++++++++++++++++++------------ 2 files changed, 51 insertions(+), 20 deletions(-) diff --git a/lua/libmodal/src/Mode.lua b/lua/libmodal/src/Mode.lua index 7b46624..b8bca49 100644 --- a/lua/libmodal/src/Mode.lua +++ b/lua/libmodal/src/Mode.lua @@ -49,6 +49,22 @@ local _metaInputBytes = classes.new(nil, { classes = nil +----------------------------------------------------------- +--[[ SUMMARY: + * Execute some `proposedInstruction` according to a set of determined logic. +]] +--[[ PARAMS: + * `proposedInstruction` => The instruction that is desired to be executed. +]] +----------------------------------------------------------- +function _metaMode._executeInstruction(proposedInstruction) + if type(proposedInstruction) == globals.TYPE_FUNC then + proposedInstruction() + else + api.nvim_command(proposedInstruction) + end +end + ----------------------------------------------- --[[ SUMMARY: * Parse `self.mappings` and see if there is any command to execute. @@ -79,8 +95,6 @@ function _metaMode:_checkInputForMapping() elseif commandType == globals.TYPE_TBL and globals.is_true(self._timeouts.enabled) then - -- Create a new timer - -- start the timer self._flushInputTimer:start( _TIMEOUT.LEN, 0, vim.schedule_wrap(function() @@ -88,7 +102,7 @@ function _metaMode:_checkInputForMapping() _TIMEOUT:SEND() -- if there is a command, execute it. if cmd[ParseTable.CR] then - api.nvim_command(cmd[ParseTable.CR]) + self._executeInstruction(cmd[ParseTable.CR]) end -- clear input inputBytes:clear() @@ -98,7 +112,7 @@ function _metaMode:_checkInputForMapping() -- The command was an actual vim command. else - api.nvim_command(cmd) + self._executeInstruction(cmd) inputBytes:clear() end diff --git a/lua/libmodal/src/Prompt.lua b/lua/libmodal/src/Prompt.lua index 96cfd15..ba7d45d 100644 --- a/lua/libmodal/src/Prompt.lua +++ b/lua/libmodal/src/Prompt.lua @@ -36,6 +36,38 @@ end local _metaPrompt = require('libmodal/src/classes').new(Prompt.TYPE) +--------------------------------------------------- +--[[ SUMMARY: + * Execute the specified instruction based on user input. +]] +--[[ PARAMS: + * `userInput` => the input from the user, used to determine how to execute the `self._instruction`. +]] +--------------------------------------------------- +function _metaPrompt:_executeInstruction(userInput) + -- get the instruction for the mode. + local instruction = self._instruction + + if type(instruction) == globals.TYPE_TBL then -- The instruction is a command table. + if instruction[userInput] then -- There is a defined command for the input. + local to_execute = instruction[userInput] + if type(to_execute) == globals.TYPE_FUNC then + to_execute() + else + api.nvim_command(instruction[userInput]) + end + elseif userInput == _HELP then -- The user did not define a 'help' command, so use the default. + self._help:show() + else -- show an error. + utils.api.nvim_show_err(globals.DEFAULT_ERROR_TITLE, 'Unknown command') + end + elseif type(instruction) == globals.TYPE_STR and vim.fn then -- The instruction is a function. Works on Neovim 0.5+. + vim.fn[instruction]() + else -- attempt to call the instruction. + instruction() + end +end + --------------------------------- --[[ SUMMARY: * Loop to get user input with `input()`. @@ -61,25 +93,10 @@ function _metaPrompt:_inputLoop() api.nvim_call_function('input', {self.indicator}) end - -- get the instruction for the mode. - local instruction = self._instruction - -- determine what to do with the input if string.len(userInput) > 0 then -- The user actually entered something. self.input:nvimSet(userInput) - if type(instruction) == globals.TYPE_TBL then -- The instruction is a command table. - if instruction[userInput] then -- There is a defined command for the input. - api.nvim_command(instruction[userInput]) - elseif userInput == _HELP then -- The user did not define a 'help' command, so use the default. - self._help:show() - else -- show an error. - utils.api.nvim_show_err(globals.DEFAULT_ERROR_TITLE, 'Unknown command') - end - elseif type(instruction) == globals.TYPE_STR and vim.fn then -- The instruction is a function. Works on Neovim 0.5+. - vim.fn[instruction]() - else -- attempt to call the instruction. - instruction() - end + self:_executeInstruction(userInput) else -- indicate we want to leave the prompt return false end From 2844351594b3ae21459bc8cb1f6be0085740ed16 Mon Sep 17 00:00:00 2001 From: Iron-E Date: Wed, 9 Sep 2020 22:35:52 -0400 Subject: [PATCH 2/6] Add tests; fix bugs with Help and ParseTable --- examples/lua/key-combos.lua | 10 ++++++++- examples/lua/prompt-commands.lua | 8 ++++++- lua/libmodal/src/Mode.lua | 20 ++++++++--------- lua/libmodal/src/collections/ParseTable.lua | 10 +++++---- lua/libmodal/src/utils/Help.lua | 25 +++++++++++++++------ 5 files changed, 50 insertions(+), 23 deletions(-) diff --git a/examples/lua/key-combos.lua b/examples/lua/key-combos.lua index 1dc7686..4ad1f2b 100644 --- a/examples/lua/key-combos.lua +++ b/examples/lua/key-combos.lua @@ -1,11 +1,19 @@ -- Imports local libmodal = require('libmodal') +-- A function which will split the window both horizontally and vertically. +local function _split_twice() + local cmd = vim.api.nvim_command + cmd('split') + cmd('vsplit') +end + -- Register key combos for splitting windows and then closing windows local fooModeCombos = { ['zf'] = 'split', ['zfo'] = 'vsplit', - ['zfc'] = 'q' + ['zfc'] = 'q', + ['zff'] = _split_twice } -- Enter the mode using the key combos. diff --git a/examples/lua/prompt-commands.lua b/examples/lua/prompt-commands.lua index 62e9355..5f45fb2 100644 --- a/examples/lua/prompt-commands.lua +++ b/examples/lua/prompt-commands.lua @@ -1,11 +1,17 @@ -- Import local libmodal = require('libmodal') +-- A function, which when called, goes to the first tab. +local function _first() + vim.api.nvim_command('tabfirst') +end + -- Define commands through a dictionary. local commands = { ['new'] = 'tabnew', ['close'] = 'tabclose', - ['last'] = 'tablast' + ['last'] = 'tablast', + ['first'] = _first } -- Begin the prompt. diff --git a/lua/libmodal/src/Mode.lua b/lua/libmodal/src/Mode.lua index b8bca49..4c36176 100644 --- a/lua/libmodal/src/Mode.lua +++ b/lua/libmodal/src/Mode.lua @@ -51,18 +51,18 @@ classes = nil ----------------------------------------------------------- --[[ SUMMARY: - * Execute some `proposedInstruction` according to a set of determined logic. + * Execute some `selection` according to a set of determined logic. +]] +--[[ REMARKS: + * Only provides logic for when `self._instruction` is a table of commands. ]] --[[ PARAMS: - * `proposedInstruction` => The instruction that is desired to be executed. + * `selection` => The instruction that is desired to be executed. ]] ----------------------------------------------------------- -function _metaMode._executeInstruction(proposedInstruction) - if type(proposedInstruction) == globals.TYPE_FUNC then - proposedInstruction() - else - api.nvim_command(proposedInstruction) - end +function _metaMode._commandTableExecute(instruction) + if type(instruction) == globals.TYPE_FUNC then instruction() + else api.nvim_command(instruction) end end ----------------------------------------------- @@ -102,7 +102,7 @@ function _metaMode:_checkInputForMapping() _TIMEOUT:SEND() -- if there is a command, execute it. if cmd[ParseTable.CR] then - self._executeInstruction(cmd[ParseTable.CR]) + self._commandTableExecute(cmd[ParseTable.CR]) end -- clear input inputBytes:clear() @@ -112,7 +112,7 @@ function _metaMode:_checkInputForMapping() -- The command was an actual vim command. else - self._executeInstruction(cmd) + self._commandTableExecute(cmd) inputBytes:clear() end diff --git a/lua/libmodal/src/collections/ParseTable.lua b/lua/libmodal/src/collections/ParseTable.lua index bf065bb..e689657 100644 --- a/lua/libmodal/src/collections/ParseTable.lua +++ b/lua/libmodal/src/collections/ParseTable.lua @@ -106,7 +106,7 @@ local function _get(parseTable, splitKey) else return _get(val, splitKey) end - elseif valType == globals.TYPE_STR and #splitKey < 1 then + elseif valType == globals.TYPE_STR or valType == globals.TYPE_FUNC and #splitKey < 1 then return val end end @@ -129,9 +129,11 @@ local function _put(parseTable, splitKey, value) if #splitKey > 0 then -- there are still characters left in the key. if not parseTable[k] then parseTable[k] = {} -- If there is a previous command mapping in place - elseif type(parseTable[k]) == globals.TYPE_STR then - -- Swap the mapping to a `CR` - parseTable[k] = {[ParseTable.CR] = parseTable[k]} + else local valueType = type(parseTable[k]) + if valueType == globals.TYPE_STR or valueType == globals.TYPE_FUNC then + -- Swap the mapping to a `CR` + parseTable[k] = {[ParseTable.CR] = parseTable[k]} + end end -- run _update() again diff --git a/lua/libmodal/src/utils/Help.lua b/lua/libmodal/src/utils/Help.lua index 3092f9c..9b6c464 100644 --- a/lua/libmodal/src/utils/Help.lua +++ b/lua/libmodal/src/utils/Help.lua @@ -1,3 +1,11 @@ +--[[ + /* + * IMPORTS + */ +--]] +local vim = vim +local globals = require('libmodal/src/globals') + --[[ /* * MODULE @@ -75,18 +83,21 @@ function Help.new(commandsOrMaps, title) ---------------------- local function tabAlign(tbl) local toPrint = {} - for k, v in pairs(tbl) do - toPrint[#toPrint + 1] = k - local len = string.len(k) - local byte = string.byte(k) + for key, value in pairs(tbl) do + toPrint[#toPrint + 1] = key + local len = string.len(key) + local byte = string.byte(key) -- account for ASCII chars that take up more space. - if byte <= 32 or byte == 127 then len = len + 1 - end + if byte <= 32 or byte == 127 then len = len + 1 end for _ = len, longestKeyLen do toPrint[#toPrint + 1] = ' ' end - toPrint[#toPrint + 1] = table.concat(SEPARATOR_TEMPLATE, v) + + toPrint[#toPrint + 1] = table.concat( + SEPARATOR_TEMPLATE, + (type(value) == globals.TYPE_STR) and value or '' + ) end return toPrint end From 84797013b43f7903c33f9324cce79ea6941cb8d8 Mon Sep 17 00:00:00 2001 From: Iron-E Date: Thu, 10 Sep 2020 14:30:43 -0400 Subject: [PATCH 3/6] Begin doc updates; add API exit function --- doc/libmodal.txt | 153 ++++++++++++++++++--------------- lua/libmodal/src/utils/api.lua | 20 +++++ 2 files changed, 102 insertions(+), 71 deletions(-) diff --git a/doc/libmodal.txt b/doc/libmodal.txt index 6c50ae0..000f64b 100644 --- a/doc/libmodal.txt +++ b/doc/libmodal.txt @@ -1,9 +1,9 @@ -*libmodal.txt* Create modes for Neovim +*libmodal.txt* Create modes for Neovim *libmodal* *nvim-libmodal* -============================================================================= -0. Table of Contents *libmodal-toc* +================================================================================ +0. Table of Contents *libmodal-toc* 1. About ................ |libmodal-about| 2. Usage ................ |libmodal-usage| @@ -15,8 +15,8 @@ 8. Changelog ............ |libmodal-changelog| 9. Credits .............. |libmodal-credits| -============================================================================== -1. About *libmodal-about* +================================================================================ +1. About *libmodal-about* |nvim-libmodal|: - Author, Iron-E @ https://github.com/Iron-E & https://gitlab.com/Iron_E @@ -33,8 +33,8 @@ modes is also creator-defined, and is outlined in |libmodal-usage|. See: |vim-modes| ------------------------------------------------------------------------------- -USE CASE *libmodal-use-case-example* +-------------------------------------------------------------------------------- +USE CASE *libmodal-use-case-example* As an |init.vim| configuration grows, it becomes harder to create keybindings that alphabetically represent the action that they perform. To get around @@ -69,8 +69,8 @@ buffers persevere). See: |libmodal-usage| -============================================================================== -2. Usage *libmodal-usage* +================================================================================ +2. Usage *libmodal-usage* The |libmodal| interface is designed completely in |Lua|. It is compatable with Vimscript, and so one may either: @@ -92,8 +92,8 @@ Note: Examples for all topics covered here can be found in the "examples" See: |api|, |lua-api|, https://github.com/Iron-E/nvim-tabmode, https://gist.github.com/Iron-E/f36116e8862ea03fd195e4e0a48cb05d ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-usage-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-usage-functions* *libmodal-mode* *libmodal#Enter()* *libmodal.mode.enter()* `libmodal.mode`.enter({name}, {instruction} [, {supressExit}]) @@ -127,7 +127,8 @@ FUNCTIONS *libmodal-usage-functions* local modeInstruction = { ['zf'] = 'split', ['zfo'] = 'vsplit', - ['zfc'] = 'tabnew' + -- You can also use lua functions + ['zfc'] = function() return 'tabnew' end } " VIMSCRIPT @@ -286,8 +287,8 @@ FUNCTIONS *libmodal-usage-functions* |libmodal-examples-prompt| For examples of this function. -============================================================================== -3. Examples *libmodal-examples* +================================================================================ +3. Examples *libmodal-examples* Below are examples written in |Lua| to help show how specific features of |libmodal| may be implemented. In each example, the name of the mode is @@ -300,8 +301,8 @@ all be tested using the |luafile| |command|. See: |libmodal-usage|, |libmodal-use-case|, |lua-require-example|. ------------------------------------------------------------------------------- -MODES *libmodal-examples-modes* +-------------------------------------------------------------------------------- +MODES *libmodal-examples-modes* Using a callback `function`: > local api = vim.api @@ -356,7 +357,7 @@ Using a |key-mapping| `table`: > < Exit Supression ~ - *libmodal-examples-supress-exit* + *libmodal-examples-supress-exit* Using a callback `function`: > local libmodal = require('libmodal') @@ -399,7 +400,7 @@ Using a |key-mapping| `table`: > < Submodes ~ - *libmodal-examples-submodes* + *libmodal-examples-submodes* Using a callback `function`: > local libmodal = require('libmodal') @@ -457,8 +458,8 @@ Using a |key-mapping| `table`: > fooMode() < ------------------------------------------------------------------------------- -LAYERS *libmodal-examples-layers* +-------------------------------------------------------------------------------- +LAYERS *libmodal-examples-layers* > local libmodal = require('libmodal') @@ -481,8 +482,8 @@ LAYERS *libmodal-examples-layers* vim.schedule_wrap(exitFunc) ) < ------------------------------------------------------------------------------- -PROMPTS *libmodal-examples-prompts* +-------------------------------------------------------------------------------- +PROMPTS *libmodal-examples-prompts* Using a callback `function`: > local libmodal = require('libmodal') @@ -524,14 +525,14 @@ Using a |command| `table`: > libmodal.prompt.enter('BAR', commands) < -============================================================================== -4. Configuration *libmodal-configuration* +================================================================================ +4. Configuration *libmodal-configuration* The following specifies what settings may be used to configure |libmodal-mode|s and |libmodal-prompt|s. ------------------------------------------------------------------------------- -HIGHLIGHT GROUPS *libmodal-highlight-groups* +-------------------------------------------------------------------------------- +HIGHLIGHT GROUPS *libmodal-highlight-groups* The following |highlight-groups| can be |config|ured to change a mode's |color|s: @@ -548,8 +549,8 @@ Note: `LibmodalStar`'s name — while not indicative of its use — is used for when Neovim 0.5 launches that will introduce interoperaability between the two. ------------------------------------------------------------------------------- -TIMEOUTS *libmodal-timeouts* *g:libmodalTimeouts* +-------------------------------------------------------------------------------- +TIMEOUTS *libmodal-timeouts* *g:libmodalTimeouts* When `libmodal.mode.enter()`'s {instruction} argument is a `table`, mode creators may also enable the use of Vim's built-in 'timeout' feature. @@ -631,8 +632,8 @@ then reset it upon exit. Example: Mode creators who use `function` {instruction}s may define timeouts manually using |timers|, which is how |libmodal| implements them internally. -============================================================================== -5. License *libmodal-license* +================================================================================ +5. License *libmodal-license* `nvim-libmodal` – Create new "modes" for Neovim. Copyright © 2020 Iron-E @@ -650,57 +651,57 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . -============================================================================== -6. Bugs *libmodal-bugs* +================================================================================ +6. Bugs *libmodal-bugs* * `libmodal#Enter()` does not work when {instruction} is a |funcref|. * See |E5004|. * `libmodal#Prompt()` does not work when {instruction} is a |funcref|. * See |E5004|. -============================================================================== -7. Contributing *libmodal-contributing* +================================================================================ +7. Contributing *libmodal-contributing* The following describes what should be done if an individual wishes to contribute something to the `Iron-E/nvim-libmodal` repository. ------------------------------------------------------------------------------- -CODE *libmodal-contributing-code* +-------------------------------------------------------------------------------- +CODE *libmodal-contributing-code* - Bugfixes ~ +Bugfixes ~ - If you discover a bug and believe you know the solution to fixing it, then - submit a bug report and state that you are working on a fix (and what that - fix might be), and what general timeframe the fix may be completed in - (months, weeks, days, etc.). +If you discover a bug and believe you know the solution to fixing it, then +submit a bug report and state that you are working on a fix (and what that +fix might be), and what general timeframe the fix may be completed in +(months, weeks, days, etc.). - When the fix is complete, submit a PR that references the issue you - submitted. +When the fix is complete, submit a PR that references the issue you +submitted. - Features ~ +Features ~ - If there is a feature you would like to be a part of |libmodal|, the best - thing you can do is submit a feature request, and then state that you are - working on a pull request (PR) so others don't attempt to do the same work - at the same time. +If there is a feature you would like to be a part of |libmodal|, the best +thing you can do is submit a feature request, and then state that you are +working on a pull request (PR) so others don't attempt to do the same work +at the same time. - When you believe your feature is complete, write some examples for it in - the `examples/lua` folder, and add them to |libmodal-examples| as - appropriate. +When you believe your feature is complete, write some examples for it in +the `examples/lua` folder, and add them to |libmodal-examples| as +appropriate. - Assure that all existing |libmodal-examples| continue to work with your - feature, unless a breaking change was discussed on the feature request. - If you need help getting them to pass, you can ask for help on the PR. +Assure that all existing |libmodal-examples| continue to work with your +feature, unless a breaking change was discussed on the feature request. +If you need help getting them to pass, you can ask for help on the PR. - Reference the issue you submitted on the PR so that the two show up - together when looking back at the history. +Reference the issue you submitted on the PR so that the two show up +together when looking back at the history. - Contributing documentation is not necessary but appreciated, since the - person who knows the most about the feature being implemented is most - likely the one implementing it. +Contributing documentation is not necessary but appreciated, since the +person who knows the most about the feature being implemented is most +likely the one implementing it. ------------------------------------------------------------------------------- -DOCUMENTATION *libmodal-contributing-documentation* +-------------------------------------------------------------------------------- +DOCUMENTATION *libmodal-contributing-documentation* If there is a problem with the documentation, or you see an area where it could be improved, don't hesitate to submit an issue and a PR. At the very @@ -708,8 +709,8 @@ least it will exist in history if such an issue comes up again, and likely it will serve to help yourself and others with more clear and concise wording, or with more helpful and practical examples. ------------------------------------------------------------------------------- -ISSUES *libmodal-contributing-issues* +-------------------------------------------------------------------------------- +ISSUES *libmodal-contributing-issues* Issues are greatly welcomed on the GitHub repository, whether they are bug reports, feature requests, documentation improvements, or misunderstandings: @@ -724,8 +725,18 @@ When submitting an issue, please describe the following: 4. Expected behavior (if applicable). 5. Attached media (screenshots, logs, etc.) (if applicable). -============================================================================== -8. Changelog *libmodal-changelog* +================================================================================ +8. Changelog *libmodal-changelog* + +0.8.0 ~ + + Additions: ~ + * Ability to use |lua| `function`s as values in a |libmodal-mode| + {instruction} `table` . + * Ability to use |lua| `function`s as values in a |libmodal-prompt| + {instruction} `table` . + * Add |libmodal-mode| and |libmodal-prompt| kill functions + (|libmodal-lua-utils-exit|). 0.7.0 ~ @@ -837,8 +848,8 @@ When submitting an issue, please describe the following: 0.3.1 ~ Fixes: ~ - * Fix bug where everytime `api.nvim_lecho()` was called, its {hlTables} would - infinitely grow with placeholder "None" entries. + * Fix bug where everytime `api.nvim_lecho()` was called, its {hlTables} + would infinitely grow with placeholder "None" entries. 0.3.0 ~ @@ -866,8 +877,8 @@ When submitting an issue, please describe the following: Additions: ~ * |libmodal-mode| implementation from |vim-libmodal|. -============================================================================== -9. Credits *libmodal-credits* +================================================================================ +9. Credits *libmodal-credits* Credit Reason --------------------- ---------------------------------- @@ -883,5 +894,5 @@ u/oryiesis Inspiration. www.lua-users.org |Lua| reference. www.stackoverflow.com Vimscript and |Lua| reference. -============================================================================== -vim:tw=78:ts=4:ft=help:norl: +================================================================================ +vim:tw=80:ts=4:ft=help:norl: diff --git a/lua/libmodal/src/utils/api.lua b/lua/libmodal/src/utils/api.lua index 737dfc1..0c8686c 100644 --- a/lua/libmodal/src/utils/api.lua +++ b/lua/libmodal/src/utils/api.lua @@ -5,8 +5,28 @@ --]] local api = {} +local globals = require('libmodal/src/globals') local vim_api = vim.api +--------------------------------- +--[[ SUMMARY: + * Send a character to exit a mode. +]] +--[[ PARAMS: + * `exit_char` => the character used to exit the mode, or ESCAPE if none was provided. +]] +--------------------------------- +function api.mode_exit(exit_char) + -- If there was no provided `exit_char`, or it is a character code. + if not exit_char or type(exit_char) == globals.TYPE_NUM then + -- Translate the character code or default to escape. + exit_char = string.char(exit_char or globals.ESC_NR) + end + + -- Exit the prompt by sending an escape key. + api.nvim_feedkeys(exit_char, 'nt', false) +end + ------------------------ --[[ SUMMARY: * Make vim ring the visual/audio bell, if it is enabled. From c570e3886cb48050316e2c8629b120f9734d89c2 Mon Sep 17 00:00:00 2001 From: Iron-E Date: Thu, 10 Sep 2020 14:34:52 -0400 Subject: [PATCH 4/6] Fix bad reference to vim.api --- lua/libmodal/src/utils/api.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lua/libmodal/src/utils/api.lua b/lua/libmodal/src/utils/api.lua index 0c8686c..6457a80 100644 --- a/lua/libmodal/src/utils/api.lua +++ b/lua/libmodal/src/utils/api.lua @@ -24,7 +24,7 @@ function api.mode_exit(exit_char) end -- Exit the prompt by sending an escape key. - api.nvim_feedkeys(exit_char, 'nt', false) + vim_api.nvim_feedkeys(exit_char, 'nt', false) end ------------------------ From 8d99e05af5800e5cca9b2455b10ea7f4ad4f94db Mon Sep 17 00:00:00 2001 From: Iron-E Date: Thu, 10 Sep 2020 16:39:31 -0400 Subject: [PATCH 5/6] Update docs --- doc/libmodal-lua.txt | 354 ++++++++++++++++++++++++------------------- 1 file changed, 194 insertions(+), 160 deletions(-) diff --git a/doc/libmodal-lua.txt b/doc/libmodal-lua.txt index 25c31f4..88e558f 100644 --- a/doc/libmodal-lua.txt +++ b/doc/libmodal-lua.txt @@ -10,7 +10,7 @@ Any material not covered here is covered in |libmodal-usage|. See: |libmodal-usage|, |lua|, |lua-require-example|. -============================================================================== +================================================================================ 0. Table of Contents *libmodal-lua-toc* 1. `libmodal` ............................. |libmodal-lua-libmodal| @@ -31,15 +31,15 @@ See: |libmodal-usage|, |lua|, |lua-require-example|. 9.3. `libmodal.utils.WindowState` ........... |libmodal-lua-Windowstate| 10. `libmodal.Vars` ........................ |libmodal-lua-Vars| -============================================================================== -1. `libmodal` *libmodal-lua-libmodal* +================================================================================ +1. `libmodal` *libmodal-lua-libmodal* This is the base of |libmodal|. It can be imported using: > local libmodal = require('libmodal') . @@ -127,10 +127,10 @@ functions *libmodal-lua-ParseTable-functions* Value: ~ 13 ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-ParseTable-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-ParseTable-functions* -`ParseTable`.stringSplit({str}, {regex}) *libmodal-lua-ParseTable.stringSplit()* +`ParseTable`.stringSplit({str}, {regex}) *libmodal-lua-ParseTable.stringSplit()* Split some {str} into a `table` with a {regex} expression. @@ -148,7 +148,7 @@ FUNCTIONS *libmodal-lua-ParseTable-functions* print(vim.inspect(ParseTable.stringSplit('testing split', ' '))) < -`ParseTable`.parse({key}) *libmodal-lua-ParseTable.parse()* +`ParseTable`.parse({key}) *libmodal-lua-ParseTable.parse()* Parse some {key} so that it can be stored by a `ParseTable` instance. @@ -175,7 +175,7 @@ FUNCTIONS *libmodal-lua-ParseTable-functions* print(vim.inspect(ParseTable.parse('testkey'))) < -`ParseTable`.new({userTable}) *libmodal-lua-ParseTable.new()* +`ParseTable`.new({userTable}) *libmodal-lua-ParseTable.new()* Create a new `ParseTable` from a user-defined `table` of combos. @@ -211,7 +211,7 @@ FUNCTIONS *libmodal-lua-ParseTable-functions* |libmodal-mode| For information about {userTable}. -`self`:get({keyDict}) *libmodal-lua-ParseTable.get()* +`self`:get({keyDict}) *libmodal-lua-ParseTable.get()* Get a value from an instance of `ParseTable`. @@ -243,7 +243,7 @@ FUNCTIONS *libmodal-lua-ParseTable-functions* print(vim.inspect(tbl)) < -`self`:parsePut({key}, {value}) *libmodal-lua-ParseTable.parsePut()* +`self`:parsePut({key}, {value}) *libmodal-lua-ParseTable.parsePut()* Put `value` into the parse tree as `key`. @@ -272,7 +272,7 @@ FUNCTIONS *libmodal-lua-ParseTable-functions* |libmodal-lua-parsetable-parseputall| for how to put multiple {key}s and {value}s at a time. -`self`:parsePutAll({tableToUnite}) *libmodal-lua-ParseTable.parsePutAll()* +`self`:parsePutAll({tableToUnite}) *libmodal-lua-ParseTable.parsePutAll()* Create the union of `self` and `tableToUnite` @@ -302,8 +302,8 @@ FUNCTIONS *libmodal-lua-ParseTable-functions* |libmodal-lua-parsetable-parseput| For more information on {tableToUnite}. -============================================================================== -3.2. `libmodal.collections.Popup` *libmodal-lua-Popup* +================================================================================ +3.2. `libmodal.collections.Popup` *libmodal-lua-Popup* When `:enter()`ing a `Mode`, an |api-floatwin| is displayed at the bottom right-hand corner of the screen. `libmodal.Mode.Popup` is responsible for @@ -325,10 +325,10 @@ opened with the following options: > } < ------------------------------------------------------------------------------- -VARIABLES *libmodal-lua-Popup-variables* +-------------------------------------------------------------------------------- +VARIABLES *libmodal-lua-Popup-variables* -`Popup`.config *libmodal-lua-Popup.apiOptions* +`Popup`.config *libmodal-lua-Popup.apiOptions* The options used when opening a `Popup`. @@ -353,7 +353,7 @@ VARIABLES *libmodal-lua-Popup-variables* } < -`self`.buffer *libmodal-lua-Popup.buffer* +`self`.buffer *libmodal-lua-Popup.buffer* The scratch buffer used by `Popup` to display text. @@ -363,7 +363,7 @@ VARIABLES *libmodal-lua-Popup-variables* Value: ~ `vim.api.nvim_create_buf(false, true)` -`self`.window *libmodal-lua-Popup.window* +`self`.window *libmodal-lua-Popup.window* The window used to display the contents of `Popup.buffer`. @@ -373,16 +373,16 @@ VARIABLES *libmodal-lua-Popup-variables* Value: ~ `vim.api.nvim_open_win(self.buffer, false, Popup.config)` ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Popup-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Popup-functions* -`self`:close() *libmodal-lua-Popup.close()* +`self`:close() *libmodal-lua-Popup.close()* Close the window that this `Popup` represents. Note: All variables of `Popup` are de-initialized after this method. -`self`:refresh({inputBytes}) *libmodal-lua-Popup.refresh()* +`self`:refresh({inputBytes}) *libmodal-lua-Popup.refresh()* Update the content of the `Popup` using an array-like `table` of |char2nr|s. @@ -395,19 +395,19 @@ FUNCTIONS *libmodal-lua-Popup-functions* {inputBytes} An array-like `table` of |char2nr|s to write to the `Popup`. -`Popup`.new() *libmodal-lua-Popup.new()* +`Popup`.new() *libmodal-lua-Popup.new()* Create a new `Popup` and immediately open it. Return: ~ - * A new `Popup`. + * A new `Popup`. See also: ~ |libmodal-lua-Popup| For the options used to spawn the window. -============================================================================== -4.2. `libmodal.collections.Stack` *libmodal-lua-Stack* +================================================================================ +4.2. `libmodal.collections.Stack` *libmodal-lua-Stack* The `libmodal.collections.Stack` is a simple implementation of a Stack data structure. It is designed with reuse of resources in mind, as @@ -416,15 +416,15 @@ times. The `#` operator in |Lua| will work on this structure. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Stack-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Stack-functions* -`self`:peek() *libmodal-lua-Stack.peek()* +`self`:peek() *libmodal-lua-Stack.peek()* Access the value at the top of the stack without removing it. Return: ~ - * The value at the top of the stack. + * The value at the top of the stack. Example: ~ > @@ -436,12 +436,12 @@ FUNCTIONS *libmodal-lua-Stack-functions* print(stk:peek()) < -`self`:pop() *libmodal-lua-Stack.pop()* +`self`:pop() *libmodal-lua-Stack.pop()* Access the value at the top of the stack by removing it. Return: ~ - * The value at the top of the stack. + * The value at the top of the stack. Example: ~ > @@ -455,7 +455,7 @@ FUNCTIONS *libmodal-lua-Stack-functions* print(stk:peek()) < -`self`:push({value}) *libmodal-lua-Stack.push()* +`self`:push({value}) *libmodal-lua-Stack.push()* Push some {value} onto the top of the stack. @@ -472,12 +472,12 @@ FUNCTIONS *libmodal-lua-Stack-functions* print(vim.inspect(stk)) < -`Stack`.new() *libmodal-lua-Stack.new()* +`Stack`.new() *libmodal-lua-Stack.new()* Create a new `libmodal.collections.Stack` and return it. Return: ~ - * A new `libmodal.collections.Stack`. + * A new `libmodal.collections.Stack`. Example: ~ > @@ -487,16 +487,16 @@ FUNCTIONS *libmodal-lua-Stack-functions* print(vim.inspect(stk)) < -============================================================================== -4. `libmodal.globals` *libmodal-lua-globals* +================================================================================ +4. `libmodal.globals` *libmodal-lua-globals* These are global functions used throughout the project. They are never modified and never meant TO be modified. ------------------------------------------------------------------------------- -functions *libmodal-lua-globals-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-globals-functions* -`globals`.DEFAULT_ERROR_TITLE *libmodal-lua-globals.DEFAULT_ERROR_TITLE* +`globals`.DEFAULT_ERROR_TITLE *libmodal-lua-globals.DEFAULT_ERROR_TITLE* The default error message header for |libmodal| errors. @@ -506,7 +506,7 @@ functions *libmodal-lua-globals-functions* Value: ~ "vim-libmodal error" -`globals`.ESC_NR *libmodal-lua-globals.ESC_NR* +`globals`.ESC_NR *libmodal-lua-globals.ESC_NR* The byte of the character. @@ -516,7 +516,7 @@ functions *libmodal-lua-globals-functions* Value: ~ 27 -`globals`.TYPE_FUNC *libmodal-lua-globals.TYPE_FUNC* +`globals`.TYPE_FUNC *libmodal-lua-globals.TYPE_FUNC* The `string` yielded by `lua type(x)` when `x` is a `function`. @@ -526,7 +526,7 @@ functions *libmodal-lua-globals-functions* Value: ~ "function" -`globals`.TYPE_NUM *libmodal-lua-globals.TYPE_NUM* +`globals`.TYPE_NUM *libmodal-lua-globals.TYPE_NUM* The `string` yielded by `lua type(x)` when `x` is a `number`. @@ -536,7 +536,7 @@ functions *libmodal-lua-globals-functions* Value: ~ "number" -`globals`.TYPE_STR *libmodal-lua-globals.TYPE_STR* +`globals`.TYPE_STR *libmodal-lua-globals.TYPE_STR* The `string` yielded by `lua type(x)` when `x` is a `string`. @@ -546,7 +546,7 @@ functions *libmodal-lua-globals-functions* Value: ~ "string" -`globals`.TYPE_TBL *libmodal-lua-globals.TYPE_TBL* +`globals`.TYPE_TBL *libmodal-lua-globals.TYPE_TBL* The `string` yielded by `lua type(x)` when `x` is a `table`. @@ -556,7 +556,7 @@ functions *libmodal-lua-globals-functions* Value: ~ "table" -`globals`.VIM_FALSE *libmodal-lua-globals.VIM_FALSE* +`globals`.VIM_FALSE *libmodal-lua-globals.VIM_FALSE* The value Vimscript uses to return `false` (besides |v:false|). @@ -566,7 +566,7 @@ functions *libmodal-lua-globals-functions* Value: ~ 0 -`globals`.VIM_TRUE *libmodal-lua-globals.VIM_TRUE* +`globals`.VIM_TRUE *libmodal-lua-globals.VIM_TRUE* Type: ~ `number` @@ -574,10 +574,10 @@ functions *libmodal-lua-globals-functions* Value: ~ 1 ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-globals-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-globals-functions* -`globals`.is_false({val}) *libmodal-lua-globals.is_false()* +`globals`.is_false({val}) *libmodal-lua-globals.is_false()* Determine whether or not some {val} is equal to `globals.VIM_FALSE`, |v:false|, or `false`. @@ -587,9 +587,9 @@ FUNCTIONS *libmodal-lua-globals-functions* expression. Return: ~ - * `true` if {val} is equal to `globals.VIM_FALSE`, |v:false|, or + - `true` if {val} is equal to `globals.VIM_FALSE`, |v:false|, or `false`. - * `false` otherwise. + - `false` otherwise. Example: ~ > @@ -618,7 +618,7 @@ FUNCTIONS *libmodal-lua-globals-functions* print(libmodal.globals.is_false(vim_trueValue)) < -`globals`.is_true({val}) *libmodal-lua-globals.is_true()* +`globals`.is_true({val}) *libmodal-lua-globals.is_true()* Determine whether or not some {val} is equal to `globals.VIM_TRUE`, |v:true|, or `true`. @@ -628,8 +628,8 @@ FUNCTIONS *libmodal-lua-globals-functions* expression. Return: ~ - * `true` if {val} is equal to `globals.VIM_TRUE`, |v:true|, or `true`. - * `false` otherwise. + - `true` if {val} is equal to `globals.VIM_TRUE`, |v:true|, or `true`. + - `false` otherwise. Example: ~ > @@ -658,15 +658,15 @@ FUNCTIONS *libmodal-lua-globals-functions* print(libmodal.globals.is_true(vim_trueValue)) < -============================================================================== -5. `libmodal.utils.Indicator` *libmodal-lua-Indicator* +================================================================================ +5. `libmodal.utils.Indicator` *libmodal-lua-Indicator* Provides creation sources for mode and prompt |echo| / |echohl| `string`s. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-indicator-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-indicator-functions* -`Indicator`.mode({modeName}) *libmodal-lua-Indicator.mode()* +`Indicator`.mode({modeName}) *libmodal-lua-Indicator.mode()* Create a new `Indicator` for a mode. @@ -685,7 +685,7 @@ FUNCTIONS *libmodal-lua-indicator-functions* |libmodal-lua-api.nvim_lecho()| For effective |echo|ing of this function. -`Indicator`.prompt({modeName}) *libmodal-lua-Indicator.prompt()* +`Indicator`.prompt({modeName}) *libmodal-lua-Indicator.prompt()* Create a new `Indicator` for a prompt. @@ -702,8 +702,8 @@ FUNCTIONS *libmodal-lua-indicator-functions* See also: ~ |libmodal-prompt| For this function's use. -============================================================================== -5.1. `libmodal.Indicator.HighlightSegment` *libmodal-lua-HighlightSegment* +================================================================================ +5.1. `libmodal.Indicator.HighlightSegment` *libmodal-lua-HighlightSegment* The `HighlightSegment` is a map describing how a particular string should be highlighted by Vim. @@ -711,28 +711,28 @@ highlighted by Vim. These `HighlightSegment`s can be put into a list and interpreted by `libmodal.utils.api.nvim_lecho()`. ------------------------------------------------------------------------------- -functions *libmodal-lua-HighlightSegment-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-HighlightSegment-functions* -`self`.hl *libmodal-lua-HighlightSegment.hl* +`self`.hl *libmodal-lua-HighlightSegment.hl* Which |highlight-group| to use when |highlight|ing `HighlightSegment.str`. Type: ~ |highlight-group| `string`. -`self`.str *libmodal-lua-HighlightSegment.str* +`self`.str *libmodal-lua-HighlightSegment.str* What this `HighlightSegment`'s string value is. Type: ~ `string` ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-HighlightSegment-Functions* - -`HighlightSegment`.new({hlgroup}, {str}) *libmodal-lua-HighlightSegment.new()* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-HighlightSegment-Functions* +`HighlightSegment`.new({hlgroup}, {str}) *libmodal-lua-HighlightSegment.new()* +-- Create a new `HighlightSegment`. Parameters: ~ @@ -740,7 +740,7 @@ FUNCTIONS *libmodal-lua-HighlightSegment-Functions* {str} The {str} to |highlight|. Return: ~ - * A new `HighlightSegment`. + - A new `HighlightSegment`. Example: ~ > @@ -755,8 +755,8 @@ FUNCTIONS *libmodal-lua-HighlightSegment-Functions* }) < -============================================================================== -6. `libmodal.Layer` *libmodal-lua-Layer* +================================================================================ +6. `libmodal.Layer` *libmodal-lua-Layer* The libmodal `Layer` class provides many additional features to the base `libmodal.layer.enter()`. @@ -766,10 +766,10 @@ returns an anonymous `Layer`'s `:exit()` `function`. By directly having a reference to a `Layer`, one can use the other `function`s that are provided, and extend was is possible. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Layer-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Layer-functions* -`self`:enter() *libmodal-lua-Layer.enter()* +`self`:enter() *libmodal-lua-Layer.enter()* Enter the `Layer`. @@ -795,7 +795,7 @@ FUNCTIONS *libmodal-lua-Layer-functions* See also: ~ |libmodal-lua-Layer.exit()| How to enter the `Layer`. -`self`:map({mode}, {lhs}, {rhs}, {options}) *libmodal-lua-Layer.enter()* +`self`:map({mode}, {lhs}, {rhs}, {options}) *libmodal-lua-Layer.enter()* Add a mapping to the `Layer`. @@ -836,7 +836,7 @@ FUNCTIONS *libmodal-lua-Layer-functions* See also: ~ |nvim_buf_set_keymap()| For more information about the parameters. -`self`:unmap({mode}, {lhs}) *libmodal-lua-Layer.unmap()* +`self`:unmap({mode}, {lhs}) *libmodal-lua-Layer.unmap()* Remove a mapping from the `Layer`. @@ -879,7 +879,7 @@ FUNCTIONS *libmodal-lua-Layer-functions* See also: ~ |nvim_buf_del_keymap()| For more information about the parameters. -`self`:exit() *libmodal-lua-Layer.exit()* +`self`:exit() *libmodal-lua-Layer.exit()* Exit the `Layer`. @@ -910,7 +910,7 @@ FUNCTIONS *libmodal-lua-Layer-functions* See also: ~ |libmodal-lua-Layer.enter()| How to enter the `Layer`. -`Layer`.new({keymap}) *libmodal-lua-Layer.new()* +`Layer`.new({keymap}) *libmodal-lua-Layer.new()* Create a new `Layer` for `mappings`. @@ -918,13 +918,13 @@ FUNCTIONS *libmodal-lua-Layer-functions* {keymap} The list of |map|pings to replace. Returns: ~ - * A new `Layer`. + - A new `Layer`. See also: ~ |libmodal-layer| For more information about the parameters. -============================================================================== -7. `libmodal.Mode` *libmodal-lua-Mode* +================================================================================ +7. `libmodal.Mode` *libmodal-lua-Mode* While `libmodal.mode.enter()` may enter a mode, it silently creates a `Mode` underneath: > @@ -957,10 +957,10 @@ want to for their mode specifically. > < (The specifications for these functions can be found at other places in this document.) ------------------------------------------------------------------------------- -functions *libmodal-lua-Mode-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Mode-functions* -`self`.exit *libmodal-lua-Mode.exit* +`self`.exit *libmodal-lua-Mode.exit* A liason to the `g:`{name}`ModeExit` variable. @@ -970,7 +970,7 @@ functions *libmodal-lua-Mode-functions* Value: ~ `libmodal.Vars.new('exit', `{name}`)` -`self`.indicator *libmodal-lua-Mode.indicator* +`self`.indicator *libmodal-lua-Mode.indicator* The message that is shown in the bottom-left corner of the screen while the mode is active. @@ -986,7 +986,7 @@ functions *libmodal-lua-Mode-functions* Value: ~ `libmodal.Indicator.mode(`{name}`)` -`self`.input *libmodal-lua-Mode.input* +`self`.input *libmodal-lua-Mode.input* A liason to `g:`{name}`ModeInput`. @@ -999,7 +999,7 @@ functions *libmodal-lua-Mode-functions* Value: ~ `libmodal.Vars.new('input', `{name}`)` -`self`.inputBytes *libmodal-lua-Mode.inputBytes* +`self`.inputBytes *libmodal-lua-Mode.inputBytes* The history of user input, stored as |char2nr|s. @@ -1011,10 +1011,10 @@ functions *libmodal-lua-Mode-functions* array-like `table` of |char2nr|s. Value: ~ - * `nil` => {instruction} is a `function`. - * `{}` => {instruction} is a `table`. + - `nil` => {instruction} is a `function`. + - `{}` => {instruction} is a `table`. -`self`.mappings *libmodal-lua-Mode.mappings* +`self`.mappings *libmodal-lua-Mode.mappings* The mappings that have been processed by a `Mode` when `libmodal.Mode.new()`'s {instruction} parameter is a `table`. @@ -1032,10 +1032,10 @@ functions *libmodal-lua-Mode-functions* |libmodal-lua-ParseTable| For information about how to use this variable. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Mode-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Mode-functions* -`self`:enter() *libmodal-lua-Mode.enter()* +`self`:enter() *libmodal-lua-Mode.enter()* Enter the `Mode` that was created. @@ -1047,7 +1047,7 @@ FUNCTIONS *libmodal-lua-Mode-functions* fooMode:enter() < -`Mode`.new({name}, {instruction} [, {supressExit}]) *libmodal-lua-Mode.new()* +`Mode`.new({name}, {instruction} [, {supressExit}]) *libmodal-lua-Mode.new()* Create a new `Mode` with a given {name}, using an {instruction} to perform whenever a key is pressed, and whether or not to {supressExit} handling. @@ -1059,8 +1059,8 @@ FUNCTIONS *libmodal-lua-Mode-functions* |libmodal-mode| For more information, as all of the parameters are the same. -============================================================================== -8. `libmodal.Prompt` *libmodal-lua-Prompt* +================================================================================ +8. `libmodal.Prompt` *libmodal-lua-Prompt* While `libmodal.prompt.enter()` may enter a |libmodal-prompt|, itilently creates a `Mode` underneath: > @@ -1072,10 +1072,10 @@ creates a `Mode` underneath: > See |libmodal-lua-Mode| for more information about the possibilities that are enabled by using such a "class". ------------------------------------------------------------------------------- -VARIABLES *libmodal-lua-Prompt-variables* +-------------------------------------------------------------------------------- +VARIABLES *libmodal-lua-Prompt-variables* -`self`.indicator *libmodal-lua-Prompt.indicator* +`self`.indicator *libmodal-lua-Prompt.indicator* The message that is shown in the bottom-left corner of the screen while the mode is active. @@ -1089,7 +1089,7 @@ VARIABLES *libmodal-lua-Prompt-variables* Value: ~ `libmodal.Indicator.prompt(`{name}`)` -`self`.input *libmodal-lua-Prompt.input* +`self`.input *libmodal-lua-Prompt.input* A liason to `g:`{name}`ModeInput`. @@ -1102,10 +1102,10 @@ VARIABLES *libmodal-lua-Prompt-variables* Value: ~ `libmodal.Vars.new('input', `{name}`)` ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Prompt-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Prompt-functions* -`self`:enter() *libmodal-lua-Prompt.enter()* +`self`:enter() *libmodal-lua-Prompt.enter()* Enter the `Prompt` that was created. @@ -1117,7 +1117,7 @@ FUNCTIONS *libmodal-lua-Prompt-functions* fooMode:enter() < - *libmodal-lua-Prompt.new()* + *libmodal-lua-Prompt.new()* `Prompt`.new({name}, {instruction} [, {completions}]) User input is taken using |input()|. It is passed through a |g:var| @@ -1131,15 +1131,15 @@ FUNCTIONS *libmodal-lua-Prompt-functions* |libmodal-prompt| For more information, as all of the parameters are the same. -============================================================================== -9. `libmodal.utils` *libmodal-lua-utils* +================================================================================ +9. `libmodal.utils` *libmodal-lua-utils* Provides extra utilities to the |libmodal| library. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-utils-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-utils-functions* -`utils`.show_error({pcall_err}) *libmodal-lua-utils.show_error()* +`utils`.show_error({pcall_err}) *libmodal-lua-utils.show_error()* Show an error from `pcall()`. @@ -1164,16 +1164,50 @@ FUNCTIONS *libmodal-lua-utils-functions* < ============================================================================= -9.1. `libmodal.utils.api` *libmodal-lua-api* +9.1. `libmodal.utils.api` *libmodal-lua-api* Provides extensions to the `vim.api` |Lua| library. See: |API|. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-api-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-api-functions* + +`api`.mode_exit({exit_char}) *libmodal-lua-api.mode_exit()* + + Use |feedkeys()| to send an {exit_char} which signals a |libmodal-mode| or + |libmodal-prompt| to stop listening for input. + + It is not usually necessary to specify {exit_char}. It is only necessary + to do so when |libmodal-mode|'s {supressExit} flag is active, because + it is possible that the user has set up some non-default character which + should be used to exit the mode (see |libmodal-examples-supress-exit|). + + Parameters: ~ + {exit_char} (Optional) The character used to exit the mode, or + |libmodal-lua-globals.ESC_NR| by default. + + Can be a character number (see |char2nr()|) or a string. + + Example: ~ +> + local libmodal = require('libmodal') + + -- This function is called every time the user presses a key. + local function _instruction() + -- Exit the mode after pressing any key. + libmodal.utils.api.mode_exit() + end + + libmodal.mode.enter('Press any key to exit.', _instruction) +< + + See also: ~ + |char2nr()| For more information about character numbers. + |libmodal-mode| For more information about {supressExit}. + |feedkeys()| For information about how this method is implemented. -`api`.nvim_bell() *libmodal-lua-api.nvim_bell()* +`api`.nvim_bell() *libmodal-lua-api.nvim_bell()* Make vim ring the visual/audio bell, if it is enabled. @@ -1181,7 +1215,7 @@ FUNCTIONS *libmodal-lua-api-functions* > local libmodal = require('libmodal') - libmoal.utils.api.nvim_bell() + libmodal.utils.api.nvim_bell() < See also: ~ @@ -1189,7 +1223,7 @@ FUNCTIONS *libmodal-lua-api-functions* 'errorbells' For bell settings. 'visualbell' For bell settings. -`api`.nvim_exists({scope}, {var}) *libmodal-lua-api.nvim_exists()* +`api`.nvim_exists({scope}, {var}) *libmodal-lua-api.nvim_exists()* Check whether or not some |variable| exists. @@ -1209,7 +1243,7 @@ FUNCTIONS *libmodal-lua-api-functions* print(libmodal.utils.api.nvim_exists('g', 'foo')) -- false < -`api`.nvim_input() *libmodal-lua-api.nvim_input()* +`api`.nvim_input() *libmodal-lua-api.nvim_input()* Gets one character of user input, as a number. @@ -1231,7 +1265,7 @@ FUNCTIONS *libmodal-lua-api-functions* print(char) < -`api`.nvim_lecho({hlTables}) *libmodal-lua-api.nvim_lecho()* +`api`.nvim_lecho({hlTables}) *libmodal-lua-api.nvim_lecho()* Echo an `Indicator`. Meant to be read as "nvim list echo". @@ -1250,7 +1284,7 @@ FUNCTIONS *libmodal-lua-api-functions* libmodal.utils.api.nvim_lecho(indicator) < -`api`.nvim_redraw() *libmodal-lua-api.nvim_redraw()* +`api`.nvim_redraw() *libmodal-lua-api.nvim_redraw()* Run |mode| to refresh the screen. @@ -1270,7 +1304,7 @@ FUNCTIONS *libmodal-lua-api-functions* libmodal.utils.api.nvim_redraw() < -`api`.nvim_show_err({title}, {msg}) *libmodal-lua-api.nvim_show_err()* +`api`.nvim_show_err({title}, {msg}) *libmodal-lua-api.nvim_show_err()* Show a {title}-error with a given {msg}. @@ -1291,18 +1325,18 @@ FUNCTIONS *libmodal-lua-api-functions* ) < -============================================================================== -9.2. `libmodal.utils.Help` *libmodal-lua-Help* +================================================================================ +9.2. `libmodal.utils.Help` *libmodal-lua-Help* Allows for the creation of a default "Help" table. By default, this "Help" is shown by pressing `?` in a |libmodal-mode| or by entering "help" into a |libmodal-prompt|. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Help-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Help-functions* -`Help`.new({commandsOrMaps}, {title}) *libmodal-lua-Help.new()* +`Help`.new({commandsOrMaps}, {title}) *libmodal-lua-Help.new()* Create a default help table with `commandsOrMaps` and vim expressions. @@ -1333,7 +1367,7 @@ FUNCTIONS *libmodal-lua-Help-functions* local mapsHelp = libmodal.utils.Help.new(maps, 'MAPS') < -`self`:show() *libmodal-lua-Help.show()* +`self`:show() *libmodal-lua-Help.show()* Show the contents of this `Help`. @@ -1360,16 +1394,16 @@ FUNCTIONS *libmodal-lua-Help-functions* mapsHelp:show() < -============================================================================== -9.3. `libmodal.utils.WindowState` *libmodal-lua-WindowState* +================================================================================ +9.3. `libmodal.utils.WindowState` *libmodal-lua-WindowState* Tracks 'winheight' and 'winwidth' when created, so that it can be modified freely and then restored later. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-WindowState-functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-WindowState-functions* -`WindowState`.new() *libmodal-lua-WindowState.new()* +`WindowState`.new() *libmodal-lua-WindowState.new()* Create a table representing the size of the current window. @@ -1387,7 +1421,7 @@ FUNCTIONS *libmodal-lua-WindowState-functions* 'winheight' The `height` property of a `WindowState`. 'winwidth' The `width` property of a `WindowState`. -`self`:restore() *libmodal-lua-WindowState.restore()* +`self`:restore() *libmodal-lua-WindowState.restore()* Restore the state of this `WindowState`. @@ -1415,16 +1449,16 @@ FUNCTIONS *libmodal-lua-WindowState-functions* print_height() < -============================================================================== -10. `libmodal.Vars` *libmodal-lua-Vars* +================================================================================ +10. `libmodal.Vars` *libmodal-lua-Vars* A `Var`'s purpose is to act as an intermediary between |global-variables| and the modes that use them. ------------------------------------------------------------------------------- -FUNCTIONS *libmodal-lua-Vars.functions* +-------------------------------------------------------------------------------- +FUNCTIONS *libmodal-lua-Vars.functions* -`self`:name() *libmodal-lua-Vars.name()* +`self`:name() *libmodal-lua-Vars.name()* Get the name of `modeName`s global setting. @@ -1432,7 +1466,7 @@ FUNCTIONS *libmodal-lua-Vars.functions* {modeName} The name of the mode. Return: ~ - * The name of the vimscript variable that this `Var` corresponds to. + - The name of the vimscript variable that this `Var` corresponds to. Example: ~ > @@ -1442,7 +1476,7 @@ FUNCTIONS *libmodal-lua-Vars.functions* print(input:name()) -- 'fooModeInput' < -`self`:nvimGet() *libmodal-lua-Vars.nvimGet()* +`self`:nvimGet() *libmodal-lua-Vars.nvimGet()* Retrieve a variable value. @@ -1461,7 +1495,7 @@ FUNCTIONS *libmodal-lua-Vars.functions* print(input:nvimGet()) < -`self`:nvimSet({val}) *libmodal-lua-Vars.nvimSet()* +`self`:nvimSet({val}) *libmodal-lua-Vars.nvimSet()* Set a |variable| value. @@ -1478,7 +1512,7 @@ FUNCTIONS *libmodal-lua-Vars.functions* print(input:nvimGet()) < -`Vars`.new(keyName, modeName) *libmodal-lua-Vars.new()* +`Vars`.new(keyName, modeName) *libmodal-lua-Vars.new()* Create a new `Var`. @@ -1489,5 +1523,5 @@ FUNCTIONS *libmodal-lua-Vars.functions* Return: ~ * A new `Var`. -============================================================================== - vim:tw=78:ts=4:ft=help:norl: +================================================================================ + vim:tw=80:ts=4:ft=help:norl: From d35778cf91ed44f797c109be8f4cf32ccfb545e6 Mon Sep 17 00:00:00 2001 From: Iron-E Date: Thu, 10 Sep 2020 16:50:32 -0400 Subject: [PATCH 6/6] Add more tests --- examples/lua/key-combos-submode.lua | 3 +++ examples/lua/prompt-commands.lua | 7 +------ 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/examples/lua/key-combos-submode.lua b/examples/lua/key-combos-submode.lua index 5bf57b5..3b1d728 100644 --- a/examples/lua/key-combos-submode.lua +++ b/examples/lua/key-combos-submode.lua @@ -15,5 +15,8 @@ function FooMode() fooModeRecurse = fooModeRecurse - 1 end +-- Define the character 'f' as the function we defined— but directly through lua, instead of vimL. +fooModeCombos['f'] = FooMode + -- Call FooMode() initially to begin the demo. FooMode() diff --git a/examples/lua/prompt-commands.lua b/examples/lua/prompt-commands.lua index 5f45fb2..be96481 100644 --- a/examples/lua/prompt-commands.lua +++ b/examples/lua/prompt-commands.lua @@ -1,17 +1,12 @@ -- Import local libmodal = require('libmodal') --- A function, which when called, goes to the first tab. -local function _first() - vim.api.nvim_command('tabfirst') -end - -- Define commands through a dictionary. local commands = { ['new'] = 'tabnew', ['close'] = 'tabclose', ['last'] = 'tablast', - ['first'] = _first + ['exit'] = libmodal.utils.api.mode_exit } -- Begin the prompt.