1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
-- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
-- This config is DEPRECATED.
-- Use the configs in `lsp/` instead (requires Nvim 0.11).
--
-- ALL configs in `lua/lspconfig/configs/` will be DELETED.
-- They exist only to support Nvim 0.10 or older.
-- !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
local util = require 'lspconfig.util'
local bin_name = 'ds-pinyin-lsp'
if vim.fn.has 'win32' == 1 then
bin_name = bin_name .. '.exe'
end
local function ds_pinyin_lsp_off(bufnr)
bufnr = util.validate_bufnr(bufnr)
local ds_pinyin_lsp_client = vim.lsp.get_clients({ bufnr = bufnr, name = 'ds_pinyin_lsp' })[1]
if ds_pinyin_lsp_client then
ds_pinyin_lsp_client.notify('$/turn/completion', {
['completion_on'] = false,
})
else
vim.notify 'notification $/turn/completion is not supported by any servers active on the current buffer'
end
end
local function ds_pinyin_lsp_on(bufnr)
bufnr = util.validate_bufnr(bufnr)
local ds_pinyin_lsp_client = vim.lsp.get_clients({ bufnr = bufnr, name = 'ds_pinyin_lsp' })[1]
if ds_pinyin_lsp_client then
ds_pinyin_lsp_client.notify('$/turn/completion', {
['completion_on'] = true,
})
else
vim.notify 'notification $/turn/completion is not supported by any servers active on the current buffer'
end
end
return {
default_config = {
cmd = { bin_name },
filetypes = { 'markdown', 'org' },
root_dir = function(fname)
return vim.fs.dirname(vim.fs.find('.git', { path = fname, upward = true })[1])
end,
single_file_support = true,
init_options = {
completion_on = true,
show_symbols = true,
show_symbols_only_follow_by_hanzi = false,
show_symbols_by_n_times = 0,
match_as_same_as_input = true,
match_long_input = true,
max_suggest = 15,
},
},
commands = {
DsPinyinCompletionOff = {
function()
ds_pinyin_lsp_off(0)
end,
description = 'Turn off the ds-pinyin-lsp completion',
},
DsPinyinCompletionOn = {
function()
ds_pinyin_lsp_on(0)
end,
description = 'Turn on the ds-pinyin-lsp completion',
},
},
docs = {
description = [=[
https://github.com/iamcco/ds-pinyin-lsp
Dead simple Pinyin language server for input Chinese without IME(input method).
To install, download the latest [release](https://github.com/iamcco/ds-pinyin-lsp/releases) and ensure `ds-pinyin-lsp` is on your path.
And make ensure the database file `dict.db3` is also downloaded. And put the path to `dict.dbs` in the following code.
```lua
require('lspconfig').ds_pinyin_lsp.setup {
init_options = {
db_path = "your_path_to_database"
}
}
```
]=],
},
}
|