From 1f62fb182c798cb29856936693f674bb7841c43b Mon Sep 17 00:00:00 2001 From: Tom Willemsen Date: Sat, 10 Nov 2012 23:12:36 +0100 Subject: [PATCH] Initial commit --- mode-icons.el | 63 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 mode-icons.el diff --git a/mode-icons.el b/mode-icons.el new file mode 100644 index 0000000..78d2e15 --- /dev/null +++ b/mode-icons.el @@ -0,0 +1,63 @@ +;;; mode-icons.el --- Show icons for modes + +;; Copyright (C) 2012 Tom Willemsen + +;; Author: Tom Willemsen +;; Keywords: multimedia + +;; 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 . + +;;; Commentary: + +;; + +;;; Code: + +(defun mode-icons-get-icon-file (name) + (concat user-emacs-directory "/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))) + "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)))))) + +(defun set-current-mode-icon () + (set-mode-icon mode-name)) + +(add-hook 'after-change-major-mode-hook 'set-current-mode-icon) + +(provide 'mode-icons) +;;; mode-icons.el ends here