solidity
plugins.lsp.servers.solidity.enable
Whether to enable https://github.com/qiuxiang/solidity-ls
npm i solidity-ls -g
Make sure that solc is installed and it’s the same version of the file. solc-select is recommended.
Solidity language server is a LSP with autocomplete, go to definition and diagnostics.
If you use brownie, use this root_dir: root_dir = util.root_pattern(‘brownie-config.yaml’, ‘.git’)
on includePath, you can add an extra path to search for external libs, on remapping you can remap lib <> path, like:
{ solidity = { includePath = '/Users/your_user/.brownie/packages/', remapping = { ["@OpenZeppelin/"] = 'OpenZeppelin/openzeppelin-contracts@4.6.0/' } } }
For brownie users Change the root_dir to:
root_pattern("brownie-config.yaml", ".git")
The best way of using it is to have a package.json in your project folder with the packages that you will use.
After installing with package.json, just create a remappings.txt
with:
@OpenZeppelin/=node_modules/OpenZeppelin/openzeppelin-contracts@4.6.0/
You can omit the node_modules as well. .
Type: boolean
Default:
false
Example:
true
Declared by:
plugins.lsp.servers.solidity.package
The package to use for solidity. Has no default, but can be set to null.
Type: null or package
Declared by:
plugins.lsp.servers.solidity.autostart
Controls if the FileType
autocommand that launches a language server is created.
If false
, allows for deferring language servers until manually launched with
:LspStart
(|lspconfig-commands|).
Type: null or boolean or raw lua code
Default:
null
Plugin default: true
Declared by:
plugins.lsp.servers.solidity.cmd
A list where each entry corresponds to the blankspace delimited part of the command that launches the server.
The first entry is the binary used to run the language server. Additional entries are passed as arguments.
Type: null or (list of string)
Default:
null
Declared by:
plugins.lsp.servers.solidity.extraOptions
Extra options for the solidity language server.
Type: attribute set of anything
Default:
{ }
Declared by:
plugins.lsp.servers.solidity.filetypes
Set of filetypes for which to attempt to resolve {root_dir}. May be empty, or server may specify a default value.
Type: null or (list of string)
Default:
null
Declared by:
plugins.lsp.servers.solidity.rootDir
A function (or function handle) which returns the root of the project used to determine if lspconfig should launch a new language server, or attach a previously launched server when you open a new buffer matching the filetype of the server.
Type: null or lua function string
Default:
null
Plugin default: "nil"
Declared by:
plugins.lsp.servers.solidity.settings
The settings for this LSP.
Type: attribute set of anything
Default:
{ }
Example:
{
callback = {
__raw = ''
function()
print('nixvim')
end
'';
};
foo_bar = 42;
hostname = "localhost:8080";
}
Declared by: