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