|  | Commit message (Collapse) | Author | Age | 
|---|
| | 
| 
| | We should be consistent in sending the EOL character to servers(I think). Julia expects this to match on bufwrite, or it crashes when vim appends the newline during the write process. | 
| | |  | 
| | |  | 
| |\  
| | 
| | | treesitter: default start and end row when omitted | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | | logic
This function returns the start and stop value if set else the node's range is used
When the node's range is used, the stop is incremented by 1 to make the search inclusive | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | Add support for default start and end row when omitted in the
query:iter_captures and query:iter_matches functions.
When the start and end row values are omitted, the values of the given
node is used. The end row value is incremented by 1 to include the node end
row in the match.
Updated tests and docs accordingly. | 
| | | |  | 
| | | 
| | 
| | 
| | | * update lua documentation
* run docgen | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | The `workspace/configuration` handler could fail with the following
error if `config.settings` is nil:
    runtime/lua/vim/lsp/util.lua:1432: attempt to index local 'settings' (a nil value)"
This ensures that `config.settings` is always initialized to an empty
table. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | * Add in clienInfo to initalize_params.
Some servers (like Metals in my case) will actually pull this
info from the initalize_params and display it in the logs. I
know from the server perspective it helps at times to have this
available to pull from to have more details about the client and
version. You can see that this is part of the spec here:
microsoft.github.io/language-server-protocol/specification#initialize | 
| |/  
|   
| | Until we support dynamicRegistration, we should handle the client/registerCapability in core. There are still some language servers that send this request despite dynamicRegistration not being registered client-side (we got an upstream fix for the node ones, but this depends on them bumping vscode-languageserver-node). | 
| | 
| 
| 
| 
| | Fixes an issue that tree-sitter always attached to the current buffer,
instead of the provided buffer. | 
| | 
| 
| 
| 
| | while there is some controversy, stdpath('cache') looks like  a better fit for logs than stdpath('data'): you can remove logs without preventing nvim to work which fits the XDG_CACHE_HOME definition of `user specific non-essential data files`. | 
| | 
| 
| | * trim trailing whitespace from docs | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * lsp: Add severity_limit for other diagnostics
* docs and tests
* fix: lint
* Add to other types
* fix: lint | 
| | 
| 
| 
| 
| 
| 
| | * fix: Allow subsequent text document edits to pass
* fixup: cleaner code
* add tests | 
| | 
| 
| | pyright (possibly others) does not send any hint diagnostics if we do not have tagSupport in PublishDiagnosticsClientCapabilities. This PR just adds them. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Only the plugin/package manager should "manage" after/. Consumers of
nvim_get_runtime_file() should not need to special case it (if your plugin
manager is broken then fix it instead).
Don't use vim.fn.readfile(). Lua can already read files. It is even
better at it than vim script.
expose M.get_query_files(). Listing the queries is essential for user
config debug, and let plugins do fun things with it.
Abstraction-by-obscurity is not useful (plugins can just cargo cult copy
the code anyway, better with public entry points). | 
| | 
| 
| 
| 
| | * LSP: fix window/showMessageRequest to not return nested title
* Add window/showMessageRequest handler to docs | 
| |\  
| | 
| | | LSP: Move workspace/configuration from nvim-lspconfig to core | 
| | | |  | 
| | | 
| | 
| | 
| | | nvim-lspconfig | 
| |/  
|   
| | Change the update of the client.messages.progress table to overwrite only the percentage and message properties on $report, Previously we were overwriting the table which meant client.messages.progress[token].message.title was wiped on report. | 
| | 
| 
| | Another 3.16 compatibility. Solves Vue crashing currently. Currently not handling the return result, but would allow opening web browser in this case. | 
| | 
| 
| 
| 
| | handlers (#13638)
Several language servers are incorrectly invoking handlers which are not yet implemented in core. | 
| | |  | 
| | |  | 
| | 
| 
| | Run hook even when transitioning from some diagnostics to no diagnostics | 
| | 
| 
| | When using "au User LspDiagnosticsChanged redrawstatus!", modelines get processed again (see h: doautocmd). Fortunately this can be suppressed using the <nomodeline> flag. this replaces every doautocmd call, that issues a User command, with doautocmd <nomodeline>. | 
| | 
| 
| 
| | Heavily inspired by https://github.com/nvim-lua/lsp-status.nvim.
listen to the LspProgressUpdate event to update your statusline. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | According to the specification[1] the payload must look like this:
    interface DidSaveTextDocumentParams {
    	/**
    	 * The document that was saved.
    	 */
    	textDocument: TextDocumentIdentifier;
    	/**
    	 * Optional the content when saved. Depends on the includeText value
    	 * when the save notification was requested.
    	 */
    	text?: string;
    }
`text` must be on the same level as `textDocument´.
Where `TextDocumentIdentifier` is:
    interface TextDocumentIdentifier {
	/**
	 * The text document's URI.
	 */
	uri: DocumentUri;
    }
[1]: https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didSave | 
| |\  
| | 
| | | feat(treesitter): add offset predicate for language injection | 
| | | 
| | 
| | 
| | | refactor(treesitter): add directives to queries | 
| |/  
|   
|   
|   
| | Also adds a test that we actually subscribe to buffer events when in
CMDPREVIEW. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Apparently the new version of LuaJIT changed the consistency with which it
sorted table dictionaries. IIRC lua sorts dictionary keys by memory address, so
it would appear that the reasons tests were previously passing was because of
a differentiation in the implementation of the lua runtime.
Ensure that array fields in the lsp protocol tables are consistently created,
by using ipair when generating arrays for completionItemKind and
symbolItemKind.
For CodeActionKind, the current implementation includes both the keys and the
values in the array. This is incorrect. Ensure that only the values are
included in the array and sort them for consistency. | 
| |\  
| | 
| | | fix(treesitter): don't throw an error for missing injected langs | 
| | | |  | 
| | | |  | 
| | | |  | 
| | | |  | 
| |/ |  | 
| | 
| 
| | Allows users to associate the diagnostics with the right bufnr. | 
| | 
| 
| | Fixes #13429. | 
| | 
| 
| 
| | Server (#13175) | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * First implementation of workspace folders
* Add completion for current directory
* Add tracking of workspace folders
* Add workspace folder listing
* Add checks on adding/removing workspaces
* Add appropriate initialization options
* Add documentation
* Make workspaceFolders available wherever client is | 
| |\  
| | 
| | | feat(luahl): add priority mechanism | 
| | | 
| | 
| | 
| | 
| | | Base priority is 0x1000, in order to stay kinda backward compatible.
Also set tree-sitter default highlight to 100 (middle-ish value) |