在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称(OpenSource Name):jose-elias-alvarez/null-ls.nvim开源软件地址(OpenSource Url):https://github.com/jose-elias-alvarez/null-ls.nvim开源编程语言(OpenSource Language):Lua 99.8%开源软件介绍(OpenSource Introduction):null-ls.nvimUse Neovim as a language server to inject LSP diagnostics, code actions, and more via Lua. MotivationNeovim's LSP ecosystem is growing, and plugins like telescope.nvim and trouble.nvim make it a joy to work with LSP features like code actions and diagnostics. Unlike the VS Code and coc.nvim ecosystems, Neovim doesn't provide a way for non-LSP sources to hook into its LSP client. null-ls is an attempt to bridge that gap and simplify the process of creating, sharing, and setting up LSP sources using pure Lua. null-ls is also an attempt to reduce the boilerplate required to set up general-purpose language servers and improve performance by removing the need for external processes. Statusnull-ls is in beta status. Please see below for steps to follow if something doesn't work the way you expect (or doesn't work at all). At the moment, null-is is compatible with Neovim 0.7 (stable) and 0.8 (head), but some features and performance improvements are exclusive to the latest version. Featuresnull-ls sources are able to hook into the following LSP features:
null-ls includes built-in sources for each of these features to provide out-of-the-box functionality. See BUILTINS for a list of available built-in sources and BUILTIN_CONFIG for instructions on how to set up and configure these sources. null-ls also provides helpers to streamline the process of spawning and transforming the output of command-line processes into an LSP-friendly format. If you want to create your own source, either for personal use or for a plugin, see HELPERS for details. SetupInstall null-ls using your favorite package manager. The plugin depends on plenary.nvim, which you are (probably) already using. To get started, you must set up null-ls and register at least one source. See BUILTINS for a list of available built-in sources and CONFIG for information about setting up and configuring null-ls. require("null-ls").setup({
sources = {
require("null-ls").builtins.formatting.stylua,
require("null-ls").builtins.diagnostics.eslint,
require("null-ls").builtins.completion.spell,
},
}) DocumentationThe definitive source for information about null-ls is its documentation, which contains information about how null-ls works, how to set it up, and how to create sources. ContributingContributions to add new features and built-ins for any language are always welcome. See CONTRIBUTING for guidelines. ExamplesParsing buffer contentThe following example demonstrates a diagnostic source that will parse the
current buffer's content and show instances of the word local null_ls = require("null-ls")
local api = vim.api
local no_really = {
method = null_ls.methods.DIAGNOSTICS,
filetypes = { "markdown", "text" },
generator = {
fn = function(params)
local diagnostics = {}
-- sources have access to a params object
-- containing info about the current file and editor state
for i, line in ipairs(params.content) do
local col, end_col = line:find("really")
if col and end_col then
-- null-ls fills in undefined positions
-- and converts source diagnostics into the required format
table.insert(diagnostics, {
row = i,
col = col,
end_col = end_col,
source = "no-really",
message = "Don't use 'really!'",
severity = 2,
})
end
end
return diagnostics
end,
},
}
null_ls.register(no_really) Parsing CLI program outputnull-ls includes helpers to simplify the process of spawning and capturing the
output of CLI programs. This example shows how to pass the content of the
current buffer to local null_ls = require("null-ls")
local helpers = require("null-ls.helpers")
local markdownlint = {
method = null_ls.methods.DIAGNOSTICS,
filetypes = { "markdown" },
-- null_ls.generator creates an async source
-- that spawns the command with the given arguments and options
generator = null_ls.generator({
command = "markdownlint",
args = { "--stdin" },
to_stdin = true,
from_stderr = true,
-- choose an output format (raw, json, or line)
format = "line",
check_exit_code = function(code, stderr)
local success = code <= 1
if not success then
-- can be noisy for things that run often (e.g. diagnostics), but can
-- be useful for things that run on demand (e.g. formatting)
print(stderr)
end
return success
end,
-- use helpers to parse the output from string matchers,
-- or parse it manually with a function
on_output = helpers.diagnostics.from_patterns({
{
pattern = [[:(%d+):(%d+) [%w-/]+ (.*)]],
groups = { "row", "col", "message" },
},
{
pattern = [[:(%d+) [%w-/]+ (.*)]],
groups = { "row", "message" },
},
}),
}),
}
null_ls.register(markdownlint) FAQSomething isn't working! What do I do?NOTE: If you run into issues when using null-ls, please follow the steps below and do not open an issue on the Neovim repository. null-ls is not an actual LSP server, so we need to determine whether issues are specific to this plugin before sending anything upstream.
How do I format files?null-ls formatters run when you call On 0.8, you should use How do I format files on save?See this wiki page. How do I stop Neovim from asking me which server I want to use for formatting?See this wiki page. How do I view project-level diagnostics?For a built-in solution, use How do I enable debug mode and get debug output?
As with LSP logging, debug mode will slow down Neovim. Make sure to disable the option after you've collected the information you're looking for. Does it work with (other plugin)?In most cases, yes. null-ls tries to act like an actual LSP server as much as possible, so it should work seamlessly with most LSP-related plugins. If you run into problems, please try to determine which plugin is causing them and open an issue. This wiki page mentions plugins that require specific configuration options / tweaks to work with null-ls. How does it work?Thanks to hard work by @folke, the plugin wraps the mechanism Neovim uses to spawn language servers to start a client entirely in-memory. The client attaches to buffers that match defined sources and receives and responds to requests, document changes, and other events from Neovim. Will it affect my performance?More testing is necessary, but since null-ls uses pure Lua and runs entirely in memory without any external processes, in most cases it should run faster than similar solutions. If you notice that performance is worse with null-ls than with an alternative, please open an issue!
I am seeing a formatting |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论