doomemacs/modules/ui/ligatures/autoload/ligatures.el

51 lines
1.8 KiB
EmacsLisp
Raw Normal View History

;;; ui/ligatures/autoload/ligatures.el -*- lexical-binding: t; -*-
;; DEPRECATED
;;;###autodef
(define-obsolete-function-alias 'set-pretty-symbols! 'set-ligatures! "3.0.0")
2018-07-06 19:59:16 +02:00
;;;###autodef
(defun set-ligatures! (modes &rest plist)
2018-07-06 19:59:16 +02:00
"Associates string patterns with icons in certain major-modes.
MODES is a major mode symbol or a list of them.
PLIST is a property list whose keys must match keys in
`+ligatures-extra-symbols', and whose values are strings representing the text
to be replaced with that symbol. If the car of PLIST is nil, then unset any
pretty symbols previously defined for MODES.
2018-07-06 19:59:16 +02:00
This function accepts one special property:
2018-07-06 19:59:16 +02:00
:alist ALIST
Appends ALIST to `prettify-symbols-alist' literally, without mapping text to
`+ligatures-extra-symbols'.
2018-07-06 19:59:16 +02:00
For example, the rule for emacs-lisp-mode is very simple:
(set-ligatures! 'emacs-lisp-mode
2018-07-06 19:59:16 +02:00
:lambda \"lambda\")
This will replace any instances of \"lambda\" in emacs-lisp-mode with the symbol
assicated with :lambda in `+ligatures-extra-symbols'.
2018-07-06 19:59:16 +02:00
Pretty symbols can be unset for emacs-lisp-mode with:
(set-ligatures! 'emacs-lisp-mode nil)"
2018-07-06 19:59:16 +02:00
(declare (indent defun))
(if (null (car-safe plist))
(dolist (mode (ensure-list modes))
(delq! mode +ligatures-extra-alist 'assq))
(let (results)
(while plist
(let ((key (pop plist)))
(if (eq key :alist)
(prependq! results (pop plist))
(when-let (char (plist-get +ligatures-extra-symbols key))
(push (cons (pop plist) char) results)))))
(dolist (mode (ensure-list modes))
(setf (alist-get mode +ligatures-extra-alist)
(if-let (old-results (alist-get mode +ligatures-extra-alist))
(dolist (cell results old-results)
(setf (alist-get (car cell) old-results) (cdr cell)))
results))))))