2 ; clean-mode-line from http://www.masteringemacs.org/articles/2012/09/10/hiding-replacing-modeline-strings/
4 (defvar mode-line-cleaner-alist
5 `((auto-complete-mode . " α")
6 (yas/minor-mode . " υ")
10 (my-keys-minor-mode . "")
12 (lisp-interaction-mode . "λ")
17 (org-agenda-mode . "øα")
19 (emacs-lisp-mode . "EL")
21 "Alist for `clean-mode-line'.
23 When you add a new element to the alist, keep in mind that you
24 must pass the correct minor/major mode symbol and a string you
25 want to use in the modeline *in lieu of* the original.")
28 (defun clean-mode-line ()
30 (cl-loop for cleaner in mode-line-cleaner-alist
31 do (let* ((mode (car cleaner))
32 (mode-str (cdr cleaner))
33 (old-mode-str (cdr (assq mode minor-mode-alist))))
35 (setcar old-mode-str mode-str))
37 (when (eq mode major-mode)
38 (setq mode-name mode-str)))))
41 (add-hook 'after-change-major-mode-hook 'clean-mode-line)