Require LSP in Ruby
Some checks failed
/ Test config on ${{matrix.node}} (20) (push) Has been cancelled

This commit is contained in:
Maciej 2024-07-30 13:42:46 +03:00
parent c2caa56b35
commit 13ed56fa04
Signed by: maciej
GPG key ID: 41D62D42D3B0D765
18 changed files with 87 additions and 64 deletions

View file

@ -4,7 +4,9 @@
(require 'icejam-prog-mode)
(defun icejam-lang-clang/activate-clang-mode ()
(declare-function column-enforce-n "column-enforce-mode" (number))
(defun icejam-lang/activate-clang-mode ()
"Goodies for editing c files."
;; Set column width to 100
@ -22,7 +24,7 @@
(add-to-list (make-local-variable 'company-backends)
'(company-etags company-yasnippet)))
(add-hook 'c-mode-hook 'icejam-lang-clang/activate-clang-mode)
(add-hook 'c-mode-hook 'icejam-lang/activate-clang-mode)
(provide 'icejam-lang-clang)
;;; icejam-lang-clang.el ends here

View file

@ -1,10 +1,12 @@
;;; languages/clojure -- summary -*- lexical-binding: t; -*-
;;; icejam-lang-clojure.el -- summary -*- lexical-binding: t; -*-
;;; Commentary:
;;; Code:
(require 'icejam-prog-mode)
(require 'icejam-transient)
(declare-function column-enforce-n "column-enforce-mode" (number))
(use-package clojure-mode :defer t :straight t)
(use-package cider
@ -20,7 +22,7 @@
:straight t)
;; Transient
(transient-define-prefix icejam-lang-clojure/cider-context-menu ()
(transient-define-prefix icejam-lang/cider-context-menu ()
"Clojure Buffer Commands."
[""
["Cider"
@ -34,29 +36,28 @@
[""
("q" "Quit" keyboard-quit)])
(defun icejam-lang-clojure/activate-clojure-mode ()
(defun icejam-lang/activate-clojure-mode ()
"Goodies for clojure files."
(icejam/set-indent 2) ;; Default indentation of 2 characters
(column-enforce-n 80)
(clj-refactor-mode 1)
(cider-mode 1)
(setq-local indent-tabs-mode nil)
(define-key
clojure-mode-map (kbd "C-c l") 'icejam-lang-clojure/cider-context-menu)
clojure-mode-map (kbd "C-c l") 'icejam-lang/cider-context-menu)
;; Do not enable paredit for clojure
;; (paredit-mode 1)
;; Do not show separate error window when in REPL
(setq cider-show-error-buffer 'except-in-repl))
(add-hook 'clojure-mode-hook 'icejam-lang-clojure/activate-clojure-mode)
(add-hook 'clojure-mode-hook 'icejam-lang/activate-clojure-mode)
(defun icejam-lang-clojure/clj-repl-config ()
(defun icejam-lang/clojure-repl-config ()
"Do not show stacktrace when in REPL."
(setq-local cider-show-error-buffer 'except-in-repl))
(add-hook 'cider-repl-mode-hook 'icejam-lang-clojure/clj-repl-config)
(add-hook 'cider-repl-mode-hook 'icejam-lang/clojure-repl-config)
(add-hook 'cider-mode-hook #'cider-company-enable-fuzzy-completion)
(provide 'icejam-lang-clojure)

View file

@ -15,7 +15,6 @@
(use-package slime-company :straight t
:requires (slime company))
(setq inferior-lisp-program "sbcl")
(slime-setup '(slime-fancy slime-company slime-quicklisp slime-asdf))

View file

@ -7,11 +7,11 @@
(use-package dart-mode :straight t :defer t)
(use-package lsp-dart :defer t :straight t :requires (dart-mode lsp))
(defun icejam-lang-dart/activate-dart-mode ()
(defun icejam-lang/activate-dart-mode ()
"Reconfigure dart mode for your own purposes."
(lsp))
(add-hook 'dart-mode-hook 'icejam-lang-dart/activate-dart-mode)
(add-hook 'dart-mode-hook 'icejam-lang/activate-dart-mode)
(provide 'icejam-lang-dart)
;;; icejam-lang-dart.el ends here

View file

@ -7,11 +7,11 @@
(use-package dhall-mode :straight t :defer t :requires (lsp))
(defun icejam-lang-dhall/activate-dhall-mode ()
(defun icejam-lang/activate-dhall-mode ()
"Reconfigure dhall mode for your own purposes."
(lsp))
(add-hook 'dhall-mode-hook 'icejam-lang-dhall/activate-dhall-mode)
(add-hook 'dhall-mode-hook 'icejam-lang/activate-dhall-mode)
(add-hook 'dhall-mode-hook 'display-line-numbers-mode)
(provide 'icejam-lang-dhall)

View file

@ -4,6 +4,8 @@
(require 'icejam-prog-mode)
(declare-function column-enforce-n "column-enforce-mode" (number))
(transient-define-prefix icejam/elisp-lang-menu ()
"Elisp Buffer Commands."
[""

View file

@ -6,8 +6,13 @@
(require 'icejam-flycheck)
(require 'icejam-transient)
(declare-function lsp "lsp-mode" nil)
(declare-function column-enforce-n "column-enforce-mode" (number))
(use-package elixir-mode :defer t :straight t)
(use-package elixir-ts-mode :requires (elixir-mode lsp-mode lsp-ui) :straight t)
(use-package elixir-ts-mode :straight t
:requires (elixir-mode lsp-mode lsp-ui)
:defines (elixir-ts-mode-map))
(add-to-list 'auto-mode-alist '("\\.exs\\'" . elixir-ts-mode))
(add-to-list 'auto-mode-alist '("\\.ex\\'" . elixir-ts-mode))
@ -38,6 +43,7 @@
;; If needed, switch the one below to false to disable documentation pop-ups
;; (setq-local lsp-ui-doc-enable t)
;; Enable mode map
(define-key elixir-ts-mode-map (kbd "C-c l") 'icejam/elixir-lang-menu)
;; Company list override

View file

@ -6,44 +6,54 @@
(require 'icejam-lsp)
(require 'icejam-projectile)
(declare-function lsp "lsp-mode" nil)
(declare-function column-enforce-n "column-enforce-mode" (number))
(use-package erlang
:defer t
:straight t
:requires (lsp-mode lsp-ui))
(cl-defun erlang/emacs-path (erlang-version)
(cl-defun icejam/erlang-emacs-path (erlang-version)
"Find path to Emacs tooling for ERLANG-VERSION."
(car (split-string
(shell-command-to-string
(format "find $HOME/.asdf/installs/erlang/%s/ -name erlang.el"
erlang-version)) "erlang.el")))
(cl-defun erlang/erlang-path (erlang-version)
(cl-defun icejam/erlang-path (erlang-version)
"Find asdf path for ERLANG-VERSION."
(format "$HOME/.asdf/installs/erlang/%s/" erlang-version))
(defun erlang/erlang-plist (erlang-version)
(defun icejam/erlang-plist (erlang-version)
"Create property list for ERLANG-VERSION."
(list :version erlang-version
:erlang-path (erlang/erlang-path erlang-version)
:emacs-path (erlang/emacs-path erlang-version)))
:erlang-path (icejam/erlang-path erlang-version)
:emacs-path (icejam/erlang-emacs-path erlang-version)))
(cl-defun erlang/installed-erlangs ()
(cl-defun icejam/installed-erlangs ()
"List Erlang versions installed with asdf."
(split-string
(shell-command-to-string
(format "asdf list erlang"))))
(cl-defun erlang/available-versions--plist ()
(mapcar 'erlang/erlang-plist (erlang/installed-erlangs)))
(cl-defun icejam/erlang-available-versions--plist ()
"Create plist for all installed Erlang versions."
(mapcar 'icejam/erlang-plist (icejam/installed-erlangs)))
(defvar erlang/available-versions (erlang/available-versions--plist))
(defvar icejam/erlang-available-versions (icejam/erlang-available-versions--plist))
(cl-defun erlang/currently-in-use ()
(cl-defun icejam/erlang-currently-in-use ()
"Get Erlang version currently in use."
(car (split-string (shell-command-to-string "asdf current erlang"))))
(cl-defun erlang/current-version--plistp (erlang-plist)
(equal (plist-get erlang-plist :version) (erlang/currently-in-use)))
(cl-defun icejam/erlang-current-version--plistp (erlang-plist)
"Check if currently in use Erlang is the same as the one in ERLANG-PLIST."
(equal (plist-get erlang-plist :version) (icejam/erlang-currently-in-use)))
(cl-defun erlang/current-plist ()
(seq-find 'erlang/current-version--plistp erlang/available-versions))
(cl-defun icejam/erlang-current-plist ()
"Create plist from current Erlang version."
(seq-find 'erlang/current-version--plistp icejam/erlang-available-versions))
;; Flycheck checker for Erlang
(flycheck-define-checker erlang-otp
@ -60,7 +70,7 @@
"All things for all Erlang, including header files."
(when (featurep 'erlang-start) (unload-feature 'erlang-start))
(defvar erlang/current-erlang (erlang/current-plist))
(defvar erlang/current-erlang (icejam/erlang-current-plist))
(add-to-list (make-local-variable 'load-path)
(plist-get erlang/current-erlang :emacs-path))

View file

@ -19,13 +19,13 @@
:repo "gleam-lang/gleam-mode"
:files ("gleam-mode.el" "tree-sitter-gleam")))
(defun icejam-lang-gleam/activate-gleam-mode ()
(defun icejam-lang/activate-gleam-mode ()
"All things Gleam."
(icejam/set-indent 2)
(column-enforce-n 100)
(lsp))
(add-hook 'gleam-mode-hook 'icejam-lang-gleam/activate-gleam-mode)
(add-hook 'gleam-mode-hook 'icejam-lang/activate-gleam-mode)
(provide 'icejam-lang-gleam)
;;; icejam-lang-gleam.el ends here

View file

@ -9,7 +9,7 @@
:defer t
:init (setq-default markdown-command "pandoc"))
(defun icejam-lang-markdown/activate-markdown-mode ()
(defun icejam-lang/activate-markdown-mode ()
"Reconfigure markdown mode for your own purposes."
(icejam/set-indent 2)
(column-enforce-n 10000)
@ -21,7 +21,7 @@
(define-key markdown-mode-map (kbd "C-c <down>") nil)
(define-key markdown-mode-map (kbd "C-c C-v") 'markdown-preview))
(add-hook 'markdown-mode-hook 'icejam-lang-markdown/activate-markdown-mode)
(add-hook 'markdown-mode-hook 'icejam-lang/activate-markdown-mode)
(add-hook 'markdown-mode-hook 'display-line-numbers-mode)
(provide 'icejam-lang-markdown)

View file

@ -66,8 +66,8 @@
;; Use tuareg-opam with lock files
(add-to-list 'auto-mode-alist '("\\.opam.locked\\'" . tuareg-opam-mode))
(transient-define-prefix icejam-lang-ocaml/reasonml-context-menu ()
"ReasonML Actions"
(transient-define-prefix icejam-lang/reasonml-context-menu ()
"ReasonML Actions."
["ReasonML actions"
[""
("r" "Reload" icejam-revert-buffer-no-confirm)
@ -79,16 +79,16 @@
("q" "Quit" keyboard-quit)])
(defun icejam-lang-ocaml/activate-reason-mode ()
(defun icejam-lang/activate-reason-mode ()
"Generate reason config."
(define-key
reason-mode-map (kbd "C-c l") 'icejam-lang-ocaml/reasonml-context-menu))
reason-mode-map (kbd "C-c l") 'icejam-lang/reasonml-context-menu))
;; Reason setup
(add-hook 'reason-mode-hook
(lambda ()
(add-hook 'before-save-hook #'refmt-before-save)))
(add-hook 'reason-mode-hook 'icejam-lang-ocaml/activate-reason-mode)
(add-hook 'reason-mode-hook 'icejam-lang/activate-reason-mode)
(add-hook 'reason-mode-hook 'merlin-mode)
(provide 'icejam-lang-ocaml)

View file

@ -24,11 +24,11 @@
;; Yaml
(use-package yaml-mode :straight t :defer t :requires (lsp))
(defun icejam-lang-yaml/activate-yaml-mode ()
(defun icejam-lang/activate-yaml-mode ()
"Activate yaml-mode."
(lsp))
(add-hook 'yaml-mode-hook 'icejam-lang-yaml/activate-yaml-mode)
(add-hook 'yaml-mode-hook 'icejam-lang/activate-yaml-mode)
;; Other text files
(use-package json-mode :straight t :defer t)

View file

@ -32,7 +32,7 @@
("q" "Quit" keyboard-quit)])
(defun icejam-lang-php/activate-php-mode ()
(defun icejam-lang/activate-php-mode ()
"All things php."
(icejam/set-indent 4)
(column-enforce-n 80)
@ -43,7 +43,7 @@
(add-to-list (make-local-variable 'company-backends)
'(company-capf company-yasnippet)))
(add-hook 'php-mode-hook 'icejam-lang-php/activate-php-mode)
(add-hook 'php-mode-hook 'icejam-lang/activate-php-mode)
(provide 'icejam-lang-php)
;;; icejam-lang-php.el ends here

View file

@ -19,7 +19,7 @@
("q" "Quit" keyboard-quit)])
(defun icejam-lang-python/activate-python-mode ()
(defun icejam-lang/activate-python-mode ()
(lsp)
(column-enforce-n 99)
@ -30,7 +30,7 @@
(add-to-list (make-local-variable 'company-backends)
'(company-capf company-yasnippet)))
(add-hook 'python-mode-hook 'icejam-lang-python/activate-python-mode)
(add-hook 'python-mode-hook 'icejam-lang/activate-python-mode)
(provide 'icejam-lang-python)
;;; icejam-lang-python.el ends here

View file

@ -10,7 +10,7 @@
(use-package rbs-mode :straight t :defer t)
(use-package enh-ruby-mode
:requires (rspec-mode ruby-end)
:requires (rspec-mode ruby-end lsp)
:straight t
:defer t)
@ -24,6 +24,9 @@
;; Do not insert magic encoding comment at the begining of each file
(setq ruby-insert-encoding-magic-comment nil)
;; Start LSP
(lsp)
;; Company list override
(add-to-list (make-local-variable 'company-backends)
'(company-capf company-yasnippet)))
@ -33,7 +36,7 @@
(add-hook 'enh-ruby-mode-hook 'ruby-end-mode)
(eval-after-load 'rspec-mode
'(rspec-install-snippets))
(add-hook 'enh-ruby-mode-hook 'icejam/activate-ruby-mod)
(add-hook 'enh-ruby-mode-hook 'icejam/activate-ruby-mode)
;; (add-hook 'enh-ruby-mode-hook 'lsp-deferred)
(provide 'icejam-lang-ruby)