Browse Source

Improve LSP settings

master
Juan Placencia 3 years ago
parent
commit
b995505100
4 changed files with 84 additions and 72 deletions
  1. +2
    -0
      uno/modules/dev/lsp.org
  2. +75
    -0
      uno/modules/lang/js/lsp.org
  3. +7
    -7
      uno/modules/lang/js/ts.org
  4. +0
    -65
      uno/modules/lang/js/yarn.org

+ 2
- 0
uno/modules/dev/lsp.org View File

@ -28,9 +28,11 @@ Define LSP dev package.
"a" '(lsp-execute-code-action :which-key "Execute action") "a" '(lsp-execute-code-action :which-key "Execute action")
"h" '(:ignore t :which-key "Help") "h" '(:ignore t :which-key "Help")
"hh" '(lsp-describe-thing-at-point :which-key "Describe") "hh" '(lsp-describe-thing-at-point :which-key "Describe")
"R" '(lsp-workspace-restart :which-key "Restart")
"r" '(:ignore t :which-key "Refactor") "r" '(:ignore t :which-key "Refactor")
"rr" '(lsp-rename :which-key "Rename")) "rr" '(lsp-rename :which-key "Rename"))
:config :config
(uno/add-useless-buffer "\\*lsp-install")
(uno/add-useless-buffer "\\*lsp-log\\*") (uno/add-useless-buffer "\\*lsp-log\\*")
(uno/handle-side-window "\\*lsp-help\\*")) (uno/handle-side-window "\\*lsp-help\\*"))

+ 75
- 0
uno/modules/lang/js/lsp.org View File

@ -0,0 +1,75 @@
#+TITLE: Language - JavaScript - LSP
#+AUTHOR: Juan Placencia
* Package
Define JavaScript language LSP Integration package.
#+BEGIN_SRC emacs-lisp
(use-package emacs
:after (uno-lang-js uno-dev-lsp projectile)
:config
(provide 'uno-lang-js-lsp))
#+END_SRC
* LSP Integration
#+BEGIN_SRC emacs-lisp
(use-package emacs
:after uno-lang-js-lsp
:init
(require 'seq)
(defun uno/lang/js/lsp/add-to-local (name file)
"Add NAME dependency from FILE to local instance."
(when (uno/lang/js/lsp/local-provider file)
(lsp-dependency name `(:local ,file))
t))
(defun uno/lang/js/lsp/check ()
"Set up support with local SDK instance."
(when (uno/lang/js/lsp/local-provider)
(require 'lsp-javascript)
(make-local-variable 'lsp-enabled-clients)
(plist-put lsp-deps-providers
:local '(:path uno/lang/js/lsp/local-provider))
(setq-local lsp-auto-guess-root t)
(run-hooks 'uno-lang-js-lsp-hook)))
(defun uno/lang/js/lsp/local-provider (&optional path)
"Provide path for local SDK instance relative to PATH."
(seq-reduce
(lambda (current sdk)
(if current
current
(let ((-path (concat (projectile-project-root) sdk path)))
(if (file-exists-p -path) -path nil))))
'(".yarn/sdks/" "node_modules/")
nil))
(defun uno/lang/js/lsp/local-provider-type (&optional path)
"Check SDK instance type relative to PATH."
(let ((-path (uno/lang/js/lsp/local-provider path)))
(cond
(string-match-p ".yarn/sdks/" -path) "yarn")
(string-match-p "node_modules/" -path) "npm")))
#+END_SRC
** ESLint Integration
#+BEGIN_SRC emacs-lisp
(use-package emacs
:after (uno-lang-js-lsp flycheck)
:hook
(uno-lang-js-lsp . uno/lang/js/eslint/add)
:init
(defun uno/lang/js/eslint/add ()
"Add support for ESLint."
(when (uno/lang/js/lsp/local-provider "eslint/bin/eslint.js")
(let ((-eslint-full
(uno/lang/js/lsp/local-provider "eslint/bin/eslint.js"))
(-node-path (uno/lang/js/lsp/local-provider)))
(setq-local
flycheck-javascript-eslint-executable -eslint-full
lsp-eslint-node-path -node-path
lsp-eslint-package-manager (uno/lang/js/lsp/local-provider-type)))
(push 'eslint lsp-enabled-clients)))
(uno/add-useless-buffer "\\*eslint\\*")
(uno/add-useless-buffer "\\*eslint::.*\\*"))
#+END_SRC

+ 7
- 7
uno/modules/lang/js/ts.org View File

@ -35,18 +35,18 @@ Define TypeScript JavaScript language package.
#+BEGIN_SRC emacs-lisp #+BEGIN_SRC emacs-lisp
(use-package emacs (use-package emacs
:after (uno-lang-js-ts uno-lang-js-yarn typescript-mode)
:after (uno-lang-js-ts uno-lang-js-lsp typescript-mode)
:hook :hook
(uno-lang-js-yarn . uno/lang/js/ts/yarn)
((typescript-mode typescript-tsx-mode) . uno/lang/js/yarn/check)
(uno-lang-js-lsp . uno/lang/js/ts/lsp)
((typescript-mode typescript-tsx-mode) . uno/lang/js/lsp/check)
:init :init
(defun uno/lang/js/ts/yarn ()
"Attempt to load SDKs with Yarn support."
(defun uno/lang/js/ts/lsp ()
"Attempt to load local SDKs."
(when (and (member major-mode '(typescript-mode typescript-tsx-mode)) (when (and (member major-mode '(typescript-mode typescript-tsx-mode))
(uno/lang/js/yarn/add-to-local-lsp
(uno/lang/js/lsp/add-to-local
'typescript-language-server 'typescript-language-server
"typescript-language-server/lib/cli.js") "typescript-language-server/lib/cli.js")
(uno/lang/js/yarn/add-to-local-lsp
(uno/lang/js/lsp/add-to-local
'typescript 'typescript
"typescript/bin/tsserver")) "typescript/bin/tsserver"))
(push 'ts-ls lsp-enabled-clients) (push 'ts-ls lsp-enabled-clients)

+ 0
- 65
uno/modules/lang/js/yarn.org View File

@ -1,65 +0,0 @@
#+TITLE: Language - JavaScript - Yarn
#+AUTHOR: Juan Placencia
* Package
Define JavaScript language package.
#+BEGIN_SRC emacs-lisp
(use-package emacs
:after (uno-lang-js uno-dev-lsp projectile)
:config
(provide 'uno-lang-js-yarn))
#+END_SRC
* LSP Integration
#+BEGIN_SRC emacs-lisp
(use-package emacs
:after uno-lang-js-yarn
:init
(defun uno/lang/js/yarn/add-to-local-lsp (name file)
"Add NAME dependency from FILE to local yarn instance."
(when (uno/lang/js/yarn/local-p file)
(lsp-dependency name `(:yarn-local ,file))
t))
(defun uno/lang/js/yarn/check ()
"Set up support with local Yarn instance."
(when (uno/lang/js/yarn/local-p)
(require 'lsp-javascript)
(make-local-variable 'lsp-enabled-clients)
(plist-put lsp-deps-providers
:yarn-local '(:path uno/lang/js/yarn/local-provider))
(setq-local lsp-auto-guess-root t)
(run-hooks 'uno-lang-js-yarn-hook)))
(defun uno/lang/js/yarn/local-p (&optional file)
"Check if Yarn SDK is available locally."
(if file
(file-exists-p (uno/lang/js/yarn/local-provider file))
(file-directory-p (uno/lang/js/yarn/local-provider))))
(defun uno/lang/js/yarn/local-provider (&optional path)
"Provide path for local yarn instance relative to PATH."
(concat (projectile-project-root) ".yarn/sdks/" path)))
#+END_SRC
** ESLint Integration
#+BEGIN_SRC emacs-lisp
(use-package emacs
:after (uno-lang-js-yarn flycheck)
:hook
(uno-lang-js-yarn . uno/lang/js/eslint/add)
:init
(defun uno/lang/js/eslint/add ()
"Add support for ESLint."
(when (uno/lang/js/yarn/local-p "eslint/bin/eslint.js")
(let ((-eslint-full (uno/lang/js/yarn/local-provider "eslint/bin/eslint.js"))
(-node-path (uno/lang/js/yarn/local-provider)))
(setq-local
flycheck-javascript-eslint-executable -eslint-full
lsp-eslint-node-path -node-path
lsp-eslint-package-manager "yarn"))
(push 'eslint lsp-enabled-clients)))
(uno/add-useless-buffer "\\*eslint\\*")
(uno/add-useless-buffer "\\*eslint::.*\\*"))
#+END_SRC

Loading…
Cancel
Save