aboutsummaryrefslogtreecommitdiff
path: root/runtime/lua/vim/lsp/health.lua
diff options
context:
space:
mode:
authorMichael Lingelbach <m.j.lbach@gmail.com>2021-09-07 15:20:15 -0700
committerMichael Lingelbach <m.j.lbach@gmail.com>2021-09-07 20:51:40 -0700
commite26802650dd3f660f909a3abde8126cee7db1ab0 (patch)
treeb7f8c9bcb482f2c4a69e70b62b0f251bd703de7e /runtime/lua/vim/lsp/health.lua
parent47f99d66440ae8be26b34531989ac61edc1ad9fe (diff)
downloadrneovim-e26802650dd3f660f909a3abde8126cee7db1ab0.tar.gz
rneovim-e26802650dd3f660f909a3abde8126cee7db1ab0.tar.bz2
rneovim-e26802650dd3f660f909a3abde8126cee7db1ab0.zip
feat(lsp): add lsp healthcheck
Add healthcheck for language server client, currently only checks logging status.
Diffstat (limited to 'runtime/lua/vim/lsp/health.lua')
-rw-r--r--runtime/lua/vim/lsp/health.lua27
1 files changed, 27 insertions, 0 deletions
diff --git a/runtime/lua/vim/lsp/health.lua b/runtime/lua/vim/lsp/health.lua
new file mode 100644
index 0000000000..855679a2df
--- /dev/null
+++ b/runtime/lua/vim/lsp/health.lua
@@ -0,0 +1,27 @@
+local M = {}
+
+--- Performs a healthcheck for LSP
+function M.check_health()
+ local report_info = vim.fn['health#report_info']
+ local report_warn = vim.fn['health#report_warn']
+
+ local log = require('vim.lsp.log')
+ local current_log_level = log.get_level()
+ local log_level_string = log.levels[current_log_level]
+ report_info(string.format("LSP log level : %s", log_level_string))
+
+ if current_log_level < log.levels.WARN then
+ report_warn(string.format("Log level %s will cause degraded performance and high disk usage", log_level_string))
+ end
+
+ local log_path = vim.lsp.get_log_path()
+ report_info(string.format("Log path: %s", log_path))
+
+ local log_size = vim.loop.fs_stat(log_path).size
+
+ local report_fn = (log_size / 1000000 > 100 and report_warn or report_info)
+ report_fn(string.format("Log size: %d KB", log_size / 1000 ))
+end
+
+return M
+