Mercurial > emacs
changeset 83851:c441663cac09
(x-gtk-stock-map): Map diropen to system-file-manager.
(icon-map-list): New variable.
(x-gtk-map-stock): Use icon-map-list.
author | Jan Djärv <jan.h.d@swipnet.se> |
---|---|
date | Sun, 02 Sep 2007 16:51:14 +0000 |
parents | 02e4d90b973f |
children | 983644a28ba7 |
files | lisp/term/x-win.el |
diffstat | 1 files changed, 23 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/term/x-win.el Sun Sep 02 16:47:29 2007 +0000 +++ b/lisp/term/x-win.el Sun Sep 02 16:51:14 2007 +0000 @@ -2569,7 +2569,7 @@ '( ("etc/images/new" . "gtk-new") ("etc/images/open" . "gtk-open") - ("etc/images/diropen" . "gtk-directory") + ("etc/images/diropen" . "n:system-file-manager") ("etc/images/close" . "gtk-close") ("etc/images/save" . "gtk-save") ("etc/images/saveas" . "gtk-save-as") @@ -2589,17 +2589,37 @@ ("etc/images/search" . "gtk-find") ("etc/images/exit" . "gtk-quit")) "How icons for tool bars are mapped to Gtk+ stock items. -Emacs must be compiled with the Gtk+ toolkit for this to have any effect." +Emacs must be compiled with the Gtk+ toolkit for this to have any effect. +A value that begins with n: denotes a named icon instead of a stock icon." :version "23.1" :type 'alist :group 'x) +(defvar icon-map-list '(x-gtk-stock-map) + "*A list of alists that maps icon file names to stock/named icons. +The alists are searched in the order they appear. The first match is used. +The keys in the alists are file names without extension and with two directory +components. For example, to map /usr/share/emacs/22.1.1/etc/images/open.xpm +to stock item gtk-open, use: + + (\"etc/images/open\" . \"gtk-open\") + +Themes also have named icons. To map to one of those, use n: before the name: + + (\"etc/images/diropen\" . \"n:system-file-manager\") + +The list elements are either the symbol name for the alist or the alist itself.") + (defun x-gtk-map-stock (file) "Map icon with file name FILE to a Gtk+ stock name, using `x-gtk-stock-map'." (let* ((file-sans (file-name-sans-extension file)) (key (and (string-match "/\\([^/]+/[^/]+/[^/]+$\\)" file-sans) (match-string 1 file-sans))) - (value (assoc-string (or key file-sans) x-gtk-stock-map))) + (value)) + (mapc (lambda (elem) + (let ((assoc (if (symbolp elem) (symbol-value elem) elem))) + (or value (setq value (assoc-string (or key file-sans) assoc))))) + icon-map-list) (and value (cdr value)))) (provide 'x-win)