A safe require replacement with niceties
import.nvim is a lua plugin that allows for safely importing packages similar
to pcall that has some added niceties for
hot reloading modules from Vim Command Mode
or Lua. This enables developers to
expirement with new configurations with plugins with the ability to hot load
the changes without restarting neovim, hot reloading a plugin they are
working on, etc.
- Include "import" before doing any requires
require('import')
- Use
import
im place ofrequire
Note: you can provide a callback which will be called on successful importimport('netman')
Note: You can provide a table of modules to import at onceimport('lualine', function(lualine) lualine.setup({ "do module setup" }) end)
import({"cmp", "cmp_nvim_lsp"}, function(modules) modules.cmp.setup() modules.cmp_nvim_lsp.setup() end)
- Profit!
Note: If you are feeling very fancy, import.nvim
has inbuilt support for
lualine
. Simply add the import
component to your lualine configuration
require("lualine").setup({
sections = {
lualine_x = { "import" }
}
})
Also note: import
implements lualine's on_click
functionality, so if you double
click on the failed import icon (by default, that is ⛔), it will open the ImportManager.
See Also: ImportStatus
Import wraps the inbuilt lua pcall
function to ensure safety with module
importing, while also providing a mechanic to reload modules. Additionally,
Import captures (and timestamps) any errors or prints that are outputted
during a module's import and stores them for later viewing by the developer.
Lastly, import stores the amount of time it took for a module to complete its
import process, which can be used later for profiling purposes (or whatever
your heart desires). This is accomplished via the addition of a global function
import
which is done on the initial module import of import
.
Note: Import checks the vim.g._import_imported
variable to ensure that there
we only run our init once.
If you use the :ImportStatus
command with no arguments, a floating window is presented with
the various packages that import imported for you. Additionally, there is a second pane that will display information
about the import include
- Import Duration
- If the package was imported successfully
- What it printed during its import
- Any errors it threw
Currently the UI can be configured by calling the import.config
function after loading import.
All options found in the options file can be overriden
though there are some sanity checks to ensure that the options are valid.
The available options (and their defaults) are
- keypress_select =
'<Enter>'
, - keypress_close =
'<Esc>'
, - keypress_scroll_output_down =
'<C-Down>'
, - keypress_scroll_output_up =
'<C-Up>'
, - output_split_type =
'horizontal'
, -- Can also be vertical, if I dont know what you passed I will assume horizontal - import_failed_icon =
"⛔"
, - import_success_icon =
"✅"
, - import_enable_better_printing =
false
Note: output_split_type
MUST be either 'horizontal'
or 'vertical'
. Failure to provide a valid option will result in the default
being used.
Takes 1-n
arguments and calls import.import for each argument.
Usage:
:Import telescope netman lualine
See Also: import.import
Takes 0-n
arguments and calls import.reload for each argument.
Note, if 0 arguments are provided, performs a reload on all imported modules.
Usage:
:Reload netman lualine
OR
:Reload
See Also: import.reload
Takes 0 or 1 argument and calls import.get_status.
If no argument is provided, reaches out and starts the Import Manager UI.
Otherwise prints the results to the print area.
Prints the following string:
module: { imported=true/false, import_duration=time_took_for_import, imported_with=modules_imported_with_modules }
Usage:
:ImportStatus telescope
OR
:ImportStatus
See Also: import.get_status
The api behind import is pretty simplistic but provides 2 features
- The ability to manage importing/reloading of modules
- The ability to query import details after import is complete
This is achieved through the following functions
Neovim (lua) exposed function that can be used to import a module and optionally specify its callback on success. Takes the following params
- path (string)
- success_callback (function, Optional)
- import_opts (table, Optional)
- Default Values
- hide_output = false,
- hide_errors = false
- Default Values
If the import is successful, success_callback is called (if provided) and is
given the imported module as a parameter to operate on. This way there is very
little retrofitting a user has to do to adopt import
into their plugin
configuration. import_opts
can be provided if you wish to log but hide the
output from a particular import event. If the import is successful,
success_callback is called (if provided) and is given the imported module
as a parameter to operate on. This way there is very little retrofitting a
user has to do to adopt import
into their plugin configuration.
Usage:
require("myplugin").setup({dostuff="yes"})
This can be modified slightly to the following to ensure safe importing (among other things described in Introduction)
import("myplugin", function(myplugin) myplugin.setup({dostuff="yes'}) end)
Note: You can also provide a table of modules to import. If you perform an import this way, the callback function will be provided a table who's keys are the modules that were provided to import, and the values will be the modules that were imported. In practice, this might look like
import({"myplugin1", "myplugin2"}, function(modules)
modules.myplugin1.setup()
modules.myplugin2.setup()
end)
This kind of setup is guaranteed to be safe as a failure in any of the import
modules will prevent the callback from being called. This means that if there
is a failure in myplugin1
, then the callback is never called. Because of
this, you can always assume that any modules that were meant to be imported
will be available in your callback.
See Also: :Import
Neovim (lua) exposed function that can be used to reload a module and optionally specify its callback on success. Takes the following params
- path (string)
- success_callback (function, Optional)
Note: If success_callback is not provided and one was used on import.import, we will simply use that one again on reload. To prevent this behavior, either provide a new callback to take the place of the cached one, or provide the
boolean false
(which will clear out the cached callback and not store a new
one). This is useful for a variety of reasons, from plugin development to
configuration experimentation.
Usage:
require("import").reload("myplugin")
-- Note, as we provided a callback in the above example, that same callback
-- will be called again on reload
OR
require("import").reload("myplugin", function(myplugin) myplugin.setup({
dostuff="no"}) end)
-- Note, this will override the previously stored success callback and
-- any subsequent reloads will call this callback instead
OR
require("import").reload("myplugin", false)
-- Note, this will _remove_ any success callback associated with this module
See Also: :Reload
Neovim (lua) exposed function that allows a user to query the status of a particular path's import status. Takes the following params
- path (string)
Returns the following table
{ status = "unknown" } -- If path was not imported with |import.import|
OR
{
status = status, -- String: This will be either success or failed
message = message, -- String: This will be either the error that
-- was provided on import, or nil
errors = errors, -- Table: Any errors that the path threw during
-- its import attempt
logs = logs, -- Table: Anything that was printed during the
-- import (with approximate timestamps)
co_modules = co_modules -- Table: Any modules that were imported with
-- this module
}
Usage:
require("import").get_status("myplugin")
See Also: :ImportStatus
Neovim (lua) exposed function that expects a table that contains key, value pairs where the key matches what is found in import.opts. Usage:
require("import").config({
-- Your customizations here
})
See Also: UI Configuration
Neovim (lua) exposed function that returns the number (integer) of successfully imported modules
Usage:
require("import").get_success_count()
Neovim (lua) exposed functino that returns the number (integer) of modules that failed to import
Usage:
require("import").get_failure_count()
THIS IS A FREE PRODUCT!
Do not feel obligated to donate anything for this. Your issues will be resolved all the same whether you have donated or not. Still, if you are feeling generous...