Load erlang mode separately for each buffer
This commit is contained in:
parent
42406821d9
commit
239e8fc9df
1 changed files with 51 additions and 13 deletions
64
20erlang.el
64
20erlang.el
|
|
@ -1,15 +1,36 @@
|
||||||
;; Add erlang installation to load path
|
(cl-defun erlang/emacs-path (erlang-version)
|
||||||
(setq erlang-asdf-root "$HOME/.asdf/installs/erlang/21.3.8/")
|
(car (split-string
|
||||||
|
(shell-command-to-string
|
||||||
|
(format "find $HOME/.asdf/installs/erlang/%s/ -name erlang.el"
|
||||||
|
erlang-version)) "erlang.el")))
|
||||||
|
|
||||||
(setq load-path
|
(cl-defun erlang/erlang-path (erlang-version)
|
||||||
(cons (format "%slib/tools-3.1/emacs" erlang-asdf-root)
|
(format "$HOME/.asdf/installs/erlang/%s/" erlang-version))
|
||||||
load-path))
|
|
||||||
|
|
||||||
(require 'erlang-start)
|
(defun erlang/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)))
|
||||||
|
|
||||||
(setq erlang-root-dir erlang-asdf-root)
|
(cl-defun erlang/installed-erlangs ()
|
||||||
(setq exec-path (cons (format "%sbin" erlang-asdf-root) exec-path))
|
(split-string
|
||||||
(setq erlang-man-root-dir (format "%sman" erlang-asdf-root))
|
(shell-command-to-string
|
||||||
|
(format "asdf list erlang"))))
|
||||||
|
|
||||||
|
(cl-defun erlang/available-versions--plist ()
|
||||||
|
(mapcar 'erlang/erlang-plist (erlang/installed-erlangs)))
|
||||||
|
|
||||||
|
(setq erlang/available-versions (erlang/available-versions--plist))
|
||||||
|
|
||||||
|
(cl-defun erlang/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 erlang/current-plist ()
|
||||||
|
(seq-find 'erlang/current-version--plistp erlang/available-versions))
|
||||||
|
|
||||||
;; Flycheck checker for Erlang
|
;; Flycheck checker for Erlang
|
||||||
(flycheck-define-checker erlang-otp
|
(flycheck-define-checker erlang-otp
|
||||||
|
|
@ -22,8 +43,24 @@
|
||||||
(error line-start (file-name) ":" line ": " (message) line-end))
|
(error line-start (file-name) ":" line ": " (message) line-end))
|
||||||
:modes (my-erlang-mode))
|
:modes (my-erlang-mode))
|
||||||
|
|
||||||
(defun activate-erlang-mode ()
|
(defun erlang/activate-erlang-mode ()
|
||||||
"All things for all Erlang, including header files."
|
"All things for all Erlang, including header files."
|
||||||
|
(when (featurep 'erlang-start) (unload-feature 'erlang-start))
|
||||||
|
|
||||||
|
(setq erlang/current-erlang (erlang/current-plist))
|
||||||
|
|
||||||
|
(add-to-list (make-local-variable 'load-path)
|
||||||
|
(plist-get erlang/current-erlang :emacs-path))
|
||||||
|
|
||||||
|
(add-to-list (make-local-variable 'exec-path)
|
||||||
|
(format "%slib/tools-3.1/emacs"
|
||||||
|
(plist-get erlang/current-erlang :erlang-path)))
|
||||||
|
|
||||||
|
(setq-local erlang-man-root-dir
|
||||||
|
(format "%sman"
|
||||||
|
(plist-get erlang/current-erlang :erlang-path)))
|
||||||
|
|
||||||
|
(require 'erlang-start)
|
||||||
|
|
||||||
;; Set specific ctags command
|
;; Set specific ctags command
|
||||||
(setq-local
|
(setq-local
|
||||||
|
|
@ -31,13 +68,14 @@
|
||||||
(format
|
(format
|
||||||
"ctags -e -R --languages=erlang -f %sTAGS %s. %slib/stdlib-* %slib/kernel-*"
|
"ctags -e -R --languages=erlang -f %sTAGS %s. %slib/stdlib-* %slib/kernel-*"
|
||||||
(projectile-project-root) (projectile-project-root)
|
(projectile-project-root) (projectile-project-root)
|
||||||
erlang-asdf-root erlang-asdf-root))
|
(plist-get erlang/current-erlang :erlang-path)
|
||||||
|
(plist-get erlang/current-erlang :erlang-path)))
|
||||||
|
|
||||||
;; Company list override
|
;; Company list override
|
||||||
(add-to-list (make-local-variable 'company-backends)
|
(add-to-list (make-local-variable 'company-backends)
|
||||||
'(company-etags company-yasnippet)))
|
'(company-etags company-yasnippet)))
|
||||||
|
|
||||||
(add-hook 'erlang-mode-hook 'activate-erlang-mode)
|
(add-hook 'erlang-mode-hook 'erlang/activate-erlang-mode)
|
||||||
|
|
||||||
(define-derived-mode my-erlang-mode erlang-mode "My Erlang mode"
|
(define-derived-mode my-erlang-mode erlang-mode "My Erlang mode"
|
||||||
"A mode for Erlang things"
|
"A mode for Erlang things"
|
||||||
|
|
@ -46,5 +84,5 @@
|
||||||
;; Enable flycheck
|
;; Enable flycheck
|
||||||
(flycheck-select-checker 'erlang-otp)
|
(flycheck-select-checker 'erlang-otp)
|
||||||
|
|
||||||
;; Automatically update tags on save
|
;; Automatically update tags on save
|
||||||
(ctags/update-this-mode-on-save 'erlang-mode))
|
(ctags/update-this-mode-on-save 'erlang-mode))
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue