2017-06-08 11:47:56 +02:00
|
|
|
;;; tools/rotate-text/config.el -*- lexical-binding: t; -*-
|
2017-02-20 20:42:37 -05:00
|
|
|
|
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)
|
2018-02-14 07:42:22 -05:00
|
|
|
"Declare :symbols, :words or :patterns (all lists of strings) that
|
|
|
|
`rotate-text' will cycle through."
|
2017-02-20 20:42:37 -05:00
|
|
|
(declare (indent 1))
|
2017-06-19 00:22:04 +02:00
|
|
|
(let* ((modes (doom-enlist (doom-unquote modes)))
|
|
|
|
(fn-name (intern (format "doom--rotate-%s" (mapconcat #'symbol-name modes "-")))))
|
|
|
|
`(progn
|
|
|
|
(defun ,fn-name ()
|
|
|
|
(let ((plist (list ,@plist)))
|
|
|
|
(setq rotate-text-local-symbols (plist-get plist :symbols)
|
|
|
|
rotate-text-local-words (plist-get plist :words)
|
|
|
|
rotate-text-local-patterns (plist-get plist :patterns))))
|
|
|
|
(add-hook! ,modes #',fn-name))))
|
2017-02-20 20:42:37 -05:00
|
|
|
|