lang/ruby: update rspec-mode integration

Prompted by upstream updates.
This commit is contained in:
Henrik Lissner 2018-08-03 18:07:31 +02:00
parent 0b130d7b9a
commit 0c36b4450e
No known key found for this signature in database
GPG key ID: 5F6C0EA160557395

View file

@ -69,9 +69,6 @@
(def-package! rspec-mode (def-package! rspec-mode
:mode ("/\\.rspec\\'" . text-mode) :mode ("/\\.rspec\\'" . text-mode)
:init :init
(associate! rspec-mode :match "/\\.rspec$")
(associate! rspec-mode :modes (enh-ruby-mode yaml-mode) :files ("spec/"))
(defvar evilmi-ruby-match-tags (defvar evilmi-ruby-match-tags
'((("unless" "if") ("elsif" "else") "end") '((("unless" "if") ("elsif" "else") "end")
("begin" ("rescue" "ensure") "end") ("begin" ("rescue" "ensure") "end")
@ -80,14 +77,20 @@
;; Rake ;; Rake
(("task" "namespace") () "end"))) (("task" "namespace") () "end")))
;; This package autoloads this advice, but does not autoload the advice (unless (featurep! :feature evil)
;; function, causing void-symbol errors when using the compilation buffer (setq rspec-verifiable-mode-keymap (make-sparse-keymap) "TODO")
;; (even for things unrelated to ruby/rspec). Even if the function were (setq rspec-mode-keymap (make-sparse-keymap) "TODO"))
;; autoloaded, it seems silly to add this advice before rspec-mode is loaded,
;; so remove it anyway! (defun +ruby*init-appropriate-rspec-mode ()
(advice-remove 'compilation-buffer-name #'rspec-compilation-buffer-name-wrapper) "TODO"
(cond ((rspec-buffer-is-spec-p)
(rspec-mode +1))
((let ((proot (doom-project-root 'nocache)))
(or (file-directory-p (expand-file-name "spec" proot))
(file-exists-p (expand-file-name ".rspec" proot))))
(rspec-verifiable-mode +1))))
(advice-add #'rspec-enable-appropriate-mode :override #'+ruby*init-appropriate-rspec-mode)
:config :config
(remove-hook 'enh-ruby-mode-hook #'rspec-enable-appropriate-mode)
(map! :map (rspec-mode-map rspec-verifiable-mode-map) (map! :map (rspec-mode-map rspec-verifiable-mode-map)
:localleader :localleader
:prefix "t" :prefix "t"