2017-02-20 20:42:37 -05:00
|
|
|
;;; tools/rotate-text/config.el
|
|
|
|
|
2017-02-23 00:06:12 -05:00
|
|
|
(def-package! rotate-text
|
2017-02-20 20:42:37 -05:00
|
|
|
:commands (rotate-text rotate-text-backward)
|
|
|
|
:config
|
|
|
|
(push '("true" "false") rotate-text-words))
|
|
|
|
|
2017-02-21 00:46:24 -05:00
|
|
|
|
2017-02-23 00:06:12 -05:00
|
|
|
(def-setting! :rotate (modes &rest plist)
|
2017-02-20 20:42:37 -05:00
|
|
|
"Declare :symbols, :words or :patterns that `rotate-text' will cycle through."
|
|
|
|
(declare (indent 1))
|
|
|
|
(let ((modes (if (listp modes) modes (list modes)))
|
|
|
|
(symbols (plist-get plist :symbols))
|
|
|
|
(words (plist-get plist :words))
|
|
|
|
(patterns (plist-get plist :patterns)))
|
|
|
|
(when (or symbols words patterns)
|
2017-04-17 02:17:10 -04:00
|
|
|
(let ((fn-name (intern (format "doom--rotate-%s" (s-join "-" (mapcar #'symbol-name modes))))))
|
2017-02-21 00:46:24 -05:00
|
|
|
`(progn
|
2017-02-20 20:42:37 -05:00
|
|
|
(defun ,fn-name ()
|
2017-02-21 00:46:24 -05:00
|
|
|
(require 'rotate-text)
|
|
|
|
,(if symbols `(setq rotate-text-local-symbols ',symbols))
|
|
|
|
,(if words `(setq rotate-text-local-words ',words))
|
|
|
|
,(if patterns `(setq rotate-text-local-patterns ',patterns)))
|
2017-04-17 02:17:10 -04:00
|
|
|
(add-hook! ,modes #',fn-name))))))
|
2017-02-20 20:42:37 -05:00
|
|
|
|