aboutsummaryrefslogtreecommitdiff
path: root/settings
diff options
context:
space:
mode:
authormattn <mattn.jp@gmail.com>2020-03-03 14:25:15 +0900
committerGitHub <noreply@github.com>2020-03-03 14:25:15 +0900
commit16393aa3eab5858e572e53c77fd4c728bb574414 (patch)
tree5dd5a5bb3843fac81a47f88ddb4a507b4d220412 /settings
parentb7317fe4ddd8ece83c3535baf7359cdf7e473848 (diff)
parentf9050494fc1511b50169246e10c853de0fed73c2 (diff)
downloadvim-lsp-settings-16393aa3eab5858e572e53c77fd4c728bb574414.tar.gz
vim-lsp-settings-16393aa3eab5858e572e53c77fd4c728bb574414.tar.bz2
vim-lsp-settings-16393aa3eab5858e572e53c77fd4c728bb574414.zip
Merge pull request #182 from mattn/register-command
Add client-side commands
Diffstat (limited to 'settings')
-rw-r--r--settings/eclipse-jdt-ls.vim15
-rw-r--r--settings/rust-analyzer.vim29
2 files changed, 43 insertions, 1 deletions
diff --git a/settings/eclipse-jdt-ls.vim b/settings/eclipse-jdt-ls.vim
index 1307b0e..2fbaf02 100644
--- a/settings/eclipse-jdt-ls.vim
+++ b/settings/eclipse-jdt-ls.vim
@@ -11,4 +11,19 @@ augroup vimlsp_settings_eclipse_jdt_ls
\ 'workspace_config': lsp_settings#get('eclipse-jdt-ls', 'workspace_config', {}),
\ 'semantic_highlight': lsp_settings#get('eclipse-jdt-ls', 'semantic_highlight', {}),
\ }
+ autocmd User lsp_setup call s:register_command()
augroup END
+
+function! s:eclipse_jdt_ls_java_apply_workspaceEdit(context)
+ let l:command = get(a:context, 'command', {})
+ call lsp#utils#workspace_edit#apply_workspace_edit(l:command['arguments'][0])
+endfunction
+
+function! s:register_command()
+ augroup vimlsp_settings_eclipse_jdt_ls
+ au!
+ augroup END
+ if exists('*lsp#register_command')
+ call lsp#register_command('java.apply.workspaceEdit', function('s:eclipse_jdt_ls_java_apply_workspaceEdit'))
+ endif
+endfunction
diff --git a/settings/rust-analyzer.vim b/settings/rust-analyzer.vim
index 993add9..223b4d9 100644
--- a/settings/rust-analyzer.vim
+++ b/settings/rust-analyzer.vim
@@ -1,4 +1,4 @@
-augroup vimlsp_settings_rust-analyzer
+augroup vimlsp_settings_rust_analyzer
au!
LspRegisterServer {
\ 'name': 'rust-analyzer',
@@ -11,4 +11,31 @@ augroup vimlsp_settings_rust-analyzer
\ 'workspace_config': lsp_settings#get('rust-analyzer', 'workspace_config', {}),
\ 'semantic_highlight': lsp_settings#get('rust-analyzer', 'semantic_highlight', {}),
\ }
+ autocmd User lsp_setup call s:register_command()
augroup END
+
+function! s:rust_analyzer_apply_source_change(context)
+ let l:command = get(a:context, 'command', {})
+
+ let l:arguments = get(l:command, 'arguments', [])
+ let l:argument = get(l:arguments, 0, {})
+
+ let l:workspace_edit = get(l:argument, 'workspaceEdit', {})
+ if !empty(l:workspace_edit)
+ call lsp#utils#workspace_edit#apply_workspace_edit(l:workspace_edit)
+ endif
+
+ let l:cursor_position = get(l:argument, 'cursorPosition', {})
+ if !empty(l:cursor_position)
+ call cursor(lsp#utils#position#lsp_to_vim('%', l:cursor_position))
+ endif
+endfunction
+
+function! s:register_command()
+ augroup vimlsp_settings_rust_analyzer
+ au!
+ augroup END
+ if exists('*lsp#register_command')
+ call lsp#register_command('rust-analyzer.applySourceChange', function('s:rust_analyzer_apply_source_change'))
+ endif
+endfunction