summaryrefslogtreecommitdiff
path: root/start/lspconfig-0.1.8/lua/lspconfig/server_configurations/sourcery.lua
diff options
context:
space:
mode:
Diffstat (limited to 'start/lspconfig-0.1.8/lua/lspconfig/server_configurations/sourcery.lua')
-rw-r--r--start/lspconfig-0.1.8/lua/lspconfig/server_configurations/sourcery.lua83
1 files changed, 83 insertions, 0 deletions
diff --git a/start/lspconfig-0.1.8/lua/lspconfig/server_configurations/sourcery.lua b/start/lspconfig-0.1.8/lua/lspconfig/server_configurations/sourcery.lua
new file mode 100644
index 0000000..44340f1
--- /dev/null
+++ b/start/lspconfig-0.1.8/lua/lspconfig/server_configurations/sourcery.lua
@@ -0,0 +1,83 @@
+local util = require 'lspconfig.util'
+
+local root_files = {
+ 'pyproject.toml',
+ 'setup.py',
+ 'setup.cfg',
+ 'requirements.txt',
+ 'Pipfile',
+ 'pyrightconfig.json',
+}
+
+local token_in_auth_file = function()
+ local is_windows = vim.fn.has 'win32' == 1
+ local path_sep = is_windows and '\\' or '/'
+
+ local config_home = is_windows and vim.fn.getenv 'APPDATA' or vim.fn.expand '~/.config'
+ local auth_file_path = config_home .. path_sep .. 'sourcery' .. path_sep .. 'auth.yaml'
+
+ if vim.fn.filereadable(auth_file_path) == 1 then
+ local content = vim.fn.readfile(auth_file_path)
+ for _, line in ipairs(content) do
+ if line:match 'sourcery_token: (.+)' then
+ return true
+ end
+ end
+ end
+
+ return false
+end
+
+return {
+ default_config = {
+ cmd = { 'sourcery', 'lsp' },
+ filetypes = { 'javascript', 'javascriptreact', 'python', 'typescript', 'typescriptreact' },
+ init_options = {
+ editor_version = 'vim',
+ extension_version = 'vim.lsp',
+ token = nil,
+ },
+ root_dir = function(fname)
+ return util.root_pattern(unpack(root_files))(fname) or util.find_git_ancestor(fname)
+ end,
+ single_file_support = true,
+ },
+ on_new_config = function(new_config, _)
+ if not new_config.init_options.token and not token_in_auth_file() then
+ local notify = vim.notify_once or vim.notify
+ notify(
+ '[lspconfig] The authentication token must be provided in config.init_options or configured via "sourcery login"',
+ vim.log.levels.ERROR
+ )
+ end
+ end,
+ docs = {
+ description = [[
+https://github.com/sourcery-ai/sourcery
+
+Refactor Python instantly using the power of AI.
+
+It requires the init_options param to be populated as shown below and will respond with the list of ServerCapabilities that it supports:
+
+```lua
+require'lspconfig'.sourcery.setup {
+ init_options = {
+ --- The Sourcery token for authenticating the user.
+ --- This is retrieved from the Sourcery website and must be
+ --- provided by each user. The extension must provide a
+ --- configuration option for the user to provide this value.
+ token = <YOUR_TOKEN>,
+
+ --- The extension's name and version as defined by the extension.
+ extension_version = 'vim.lsp',
+
+ --- The editor's name and version as defined by the editor.
+ editor_version = 'vim',
+ },
+}
+```
+
+Alternatively, you can login to sourcery by running `sourcery login` with sourcery-cli.
+]],
+ },
+}