summaryrefslogtreecommitdiffstats
path: root/mode-icons.el
blob: 48157ceeb3c9e6ee5de2b5f2b336d8616420ffe2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
;;; mode-icons.el --- Show icons for modes

;; Copyright (C) 2012  Tom Willemsen

;; Author: Tom Willemsen <thomas@aethon.nl>
;; Keywords: multimedia
;; Version: 0.1.0

;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.

;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;; GNU General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with this program.  If not, see <http://www.gnu.org/licenses/>.

;;; Commentary:

;;

;;; Code:

(defconst mode-icons--load-file-name load-file-name
  "Where mode-icons was loaded from.")

(defun mode-icons-get-icon-file (name)
  (concat (file-name-directory mode-icons--load-file-name)
          "/icons/" name))

(defvar mode-icons
  `(("Emacs-Lisp" . (image :type xpm
                           :file ,(mode-icons-get-icon-file "emacs.xpm")
                           :ascent center))
    ("Python" . (image :type xpm
                       :file ,(mode-icons-get-icon-file "python.xpm")
                       :ascent center))
    ("Scheme" . (image :type xpm
                       :file ,(mode-icons-get-icon-file "scheme.xpm")
                       :ascent center))
    ("Lisp" . (image :type xpm
                     :file ,(mode-icons-get-icon-file "cl.xpm")
                     :ascent center))
    ("PHP" . (image :type xpm
                    :file ,(mode-icons-get-icon-file "php.xpm")
                    :ascent center))
    ("HTML" . (image :type xpm
                     :file ,(mode-icons-get-icon-file "html.xpm")
                     :ascent center))
    ("Org" . (image :type xpm
                    :file ,(mode-icons-get-icon-file "org.xpm")
                    :ascent center)))
  "Icons for major modes.")

(defun set-mode-icon (mode)
  (setq mode (format-mode-line mode))
  (let ((icon-spec (assoc mode mode-icons)))
    (when icon-spec
      (setq mode-name (propertize mode 'display (cdr icon-spec))))))

;;;###autoload
(defun set-current-mode-icon ()
  (set-mode-icon mode-name))

(provide 'mode-icons)
;;; mode-icons.el ends here