mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-04 11:40:22 +00:00
Update Commentary header.
(tree-widget-theme-name): Ignore parent themes. (tree-widget-set-parent-theme): New function. (tree-widget-set-theme): Use it. (tree-widget-set-image-properties): Move definition. Does nothing if image properties have already been set. (tree-widget-image-properties): Move definition. Receive an image name. Set the :pointer property. (tree-widget-lookup-image): Doc fix. Search in parent themes. Don't set the :pointer image property. (tree-widget-convert-widget): New function. Handle :dynargs compatibility here. (tree-widget): Use it to :convert-widget. Add the :expander-p predicate to control when the :expander function is entered. Thanks to Ken Manheimer <ken.manheimer@gmail.com> for the idea. (tree-widget-value-create): Handle :expander-p. widget-apply :expander. (tree-widget-expander-p): New function. Default value of the :expander-p property.
This commit is contained in:
parent
3070196c58
commit
f35262f952
@ -50,14 +50,16 @@
|
|||||||
;; Specify a function to be called to dynamically provide the
|
;; Specify a function to be called to dynamically provide the
|
||||||
;; tree's children in response to an expand request. This function
|
;; tree's children in response to an expand request. This function
|
||||||
;; will be passed the tree widget and must return a list of child
|
;; will be passed the tree widget and must return a list of child
|
||||||
;; widgets.
|
;; widgets. Child widgets returned by the :expander function are
|
||||||
|
;; stored in the :args property of the tree widget.
|
||||||
;;
|
;;
|
||||||
;; *Please note:* Child widgets returned by the :expander function
|
;; :expander-p
|
||||||
;; are stored in the :args property of the tree widget. To speed
|
;; Specify a predicate which must return non-nil to indicate that
|
||||||
;; up successive expand requests, the :expander function is not
|
;; the :expander function above has to be called. By default, to
|
||||||
;; called again when the :args value is non-nil. To refresh child
|
;; speed up successive expand requests, the :expander-p predicate
|
||||||
;; values, it is necessary to set the :args property to nil, then
|
;; return non-nil when the :args value is nil. So, by default, to
|
||||||
;; redraw the tree.
|
;; refresh child values, it is necessary to set the :args property
|
||||||
|
;; to nil, then redraw the tree.
|
||||||
;;
|
;;
|
||||||
;; :open-icon (default `tree-widget-open-icon')
|
;; :open-icon (default `tree-widget-open-icon')
|
||||||
;; :close-icon (default `tree-widget-close-icon')
|
;; :close-icon (default `tree-widget-close-icon')
|
||||||
@ -265,19 +267,42 @@ See also the option `widget-image-conversion'."
|
|||||||
|
|
||||||
(defsubst tree-widget-theme-name ()
|
(defsubst tree-widget-theme-name ()
|
||||||
"Return the current theme name, or nil if no theme is active."
|
"Return the current theme name, or nil if no theme is active."
|
||||||
(and tree-widget--theme (aref tree-widget--theme 0)))
|
(and tree-widget--theme (car (aref tree-widget--theme 0))))
|
||||||
|
|
||||||
(defsubst tree-widget-set-theme (&optional name)
|
(defsubst tree-widget-set-parent-theme (name)
|
||||||
|
"Set to NAME the parent theme of the current theme.
|
||||||
|
The default parent theme is the \"default\" theme."
|
||||||
|
(unless (member name (aref tree-widget--theme 0))
|
||||||
|
(aset tree-widget--theme 0
|
||||||
|
(append (aref tree-widget--theme 0) (list name)))
|
||||||
|
;; Load the theme setup
|
||||||
|
(let ((default-directory (tree-widget-themes-directory)))
|
||||||
|
(when default-directory
|
||||||
|
(load (expand-file-name "tree-widget-theme-setup" name) t)))))
|
||||||
|
|
||||||
|
(defun tree-widget-set-theme (&optional name)
|
||||||
"In the current buffer, set the theme to use for images.
|
"In the current buffer, set the theme to use for images.
|
||||||
The current buffer must be where the tree widget is drawn.
|
The current buffer must be where the tree widget is drawn.
|
||||||
Optional argument NAME is the name of the theme to use. It defaults
|
Optional argument NAME is the name of the theme to use. It defaults
|
||||||
to the value of the variable `tree-widget-theme'.
|
to the value of the variable `tree-widget-theme'.
|
||||||
Does nothing if NAME is already the current theme."
|
Does nothing if NAME is already the current theme.
|
||||||
|
|
||||||
|
If there is a \"tree-widget-theme-setup\" library in the theme
|
||||||
|
directory, load it to setup a parent theme or the images properties.
|
||||||
|
Typically it should contain something like this:
|
||||||
|
|
||||||
|
(tree-widget-set-parent-theme \"my-parent-theme\")
|
||||||
|
(tree-widget-set-image-properties
|
||||||
|
(if (featurep 'xemacs)
|
||||||
|
'(:ascent center)
|
||||||
|
'(:ascent center :mask (heuristic t))
|
||||||
|
))"
|
||||||
(or name (setq name (or tree-widget-theme "default")))
|
(or name (setq name (or tree-widget-theme "default")))
|
||||||
(unless (string-equal name (tree-widget-theme-name))
|
(unless (string-equal name (tree-widget-theme-name))
|
||||||
(set (make-local-variable 'tree-widget--theme)
|
(set (make-local-variable 'tree-widget--theme)
|
||||||
(make-vector 4 nil))
|
(make-vector 4 nil))
|
||||||
(aset tree-widget--theme 0 name)))
|
(tree-widget-set-parent-theme name)
|
||||||
|
(tree-widget-set-parent-theme "default")))
|
||||||
|
|
||||||
(defun tree-widget--locate-sub-directory (name path)
|
(defun tree-widget--locate-sub-directory (name path)
|
||||||
"Locate the sub-directory NAME in PATH.
|
"Locate the sub-directory NAME in PATH.
|
||||||
@ -328,50 +353,6 @@ specified directory is not accessible."
|
|||||||
(aset tree-widget--theme 1 (or found 'void))
|
(aset tree-widget--theme 1 (or found 'void))
|
||||||
found))
|
found))
|
||||||
|
|
||||||
(defsubst tree-widget-set-image-properties (props)
|
|
||||||
"In current theme, set images properties to PROPS."
|
|
||||||
(aset tree-widget--theme 2 props))
|
|
||||||
|
|
||||||
(defun tree-widget-image-properties (file)
|
|
||||||
"Return the properties of an image in current theme.
|
|
||||||
FILE is the absolute file name of an image.
|
|
||||||
|
|
||||||
If there is a \"tree-widget-theme-setup\" library in the theme
|
|
||||||
directory, where is located FILE, load it to setup theme images
|
|
||||||
properties. Typically it should contain something like this:
|
|
||||||
|
|
||||||
(tree-widget-set-image-properties
|
|
||||||
(if (featurep 'xemacs)
|
|
||||||
'(:ascent center)
|
|
||||||
'(:ascent center :mask (heuristic t))
|
|
||||||
))
|
|
||||||
|
|
||||||
When there is no \"tree-widget-theme-setup\" library in the current
|
|
||||||
theme directory, load the one from the default theme, if available.
|
|
||||||
Default global properties are provided for respectively Emacs and
|
|
||||||
XEmacs in the variables `tree-widget-image-properties-emacs', and
|
|
||||||
`tree-widget-image-properties-xemacs'."
|
|
||||||
;; If properties are in the cache, use them.
|
|
||||||
(let ((plist (aref tree-widget--theme 2)))
|
|
||||||
(unless plist
|
|
||||||
;; Load tree-widget-theme-setup if available.
|
|
||||||
(load (expand-file-name "tree-widget-theme-setup"
|
|
||||||
(file-name-directory file)) t t)
|
|
||||||
;; If properties have been setup, use them.
|
|
||||||
(unless (setq plist (aref tree-widget--theme 2))
|
|
||||||
;; Try from the default theme.
|
|
||||||
(load (expand-file-name "../default/tree-widget-theme-setup"
|
|
||||||
(file-name-directory file)) t t)
|
|
||||||
;; If properties have been setup, use them.
|
|
||||||
(unless (setq plist (aref tree-widget--theme 2))
|
|
||||||
;; By default, use supplied global properties.
|
|
||||||
(setq plist (if (featurep 'xemacs)
|
|
||||||
tree-widget-image-properties-xemacs
|
|
||||||
tree-widget-image-properties-emacs))
|
|
||||||
;; Setup the cache.
|
|
||||||
(tree-widget-set-image-properties plist))))
|
|
||||||
plist))
|
|
||||||
|
|
||||||
(defconst tree-widget--cursors
|
(defconst tree-widget--cursors
|
||||||
;; Pointer shapes when the mouse pointer is over inactive
|
;; Pointer shapes when the mouse pointer is over inactive
|
||||||
;; tree-widget images. This feature works since Emacs 22, and
|
;; tree-widget images. This feature works since Emacs 22, and
|
||||||
@ -384,35 +365,46 @@ XEmacs in the variables `tree-widget-image-properties-emacs', and
|
|||||||
("no-handle" . arrow)
|
("no-handle" . arrow)
|
||||||
))
|
))
|
||||||
|
|
||||||
|
(defsubst tree-widget-set-image-properties (props)
|
||||||
|
"In current theme, set images properties to PROPS.
|
||||||
|
Does nothing if images properties have already been set for that
|
||||||
|
theme."
|
||||||
|
(or (aref tree-widget--theme 2)
|
||||||
|
(aset tree-widget--theme 2 props)))
|
||||||
|
|
||||||
|
(defsubst tree-widget-image-properties (name)
|
||||||
|
"Return the properties of image NAME in current theme.
|
||||||
|
Default global properties are provided for respectively Emacs and
|
||||||
|
XEmacs in the variables `tree-widget-image-properties-emacs', and
|
||||||
|
`tree-widget-image-properties-xemacs'."
|
||||||
|
;; Add the pointer shape
|
||||||
|
(cons :pointer
|
||||||
|
(cons (or (cdr (assoc name tree-widget--cursors)) 'hand)
|
||||||
|
(tree-widget-set-image-properties
|
||||||
|
(if (featurep 'xemacs)
|
||||||
|
tree-widget-image-properties-xemacs
|
||||||
|
tree-widget-image-properties-emacs)))))
|
||||||
|
|
||||||
(defun tree-widget-lookup-image (name)
|
(defun tree-widget-lookup-image (name)
|
||||||
"Look up in current theme for an image with NAME.
|
"Look up in current theme for an image with NAME.
|
||||||
Search first in current theme, then in default theme (see also the
|
Search first in current theme, then in parent themes (see also the
|
||||||
variable `tree-widget-theme').
|
function `tree-widget-set-parent-theme').
|
||||||
Return the first image found having a supported format, or nil if not
|
Return the first image found having a supported format, or nil if not
|
||||||
found."
|
found."
|
||||||
(let ((default-directory (tree-widget-themes-directory)))
|
(let ((default-directory (tree-widget-themes-directory)) file)
|
||||||
(when default-directory
|
(when default-directory
|
||||||
(let (file (theme (tree-widget-theme-name)))
|
(catch 'found
|
||||||
(catch 'found
|
(dolist (dir (aref tree-widget--theme 0))
|
||||||
(dolist (dir (if (string-equal theme "default")
|
(dolist (fmt (tree-widget-image-formats))
|
||||||
'("default") (list theme "default")))
|
(dolist (ext (cdr fmt))
|
||||||
(dolist (fmt (tree-widget-image-formats))
|
(setq file (expand-file-name (concat name ext) dir))
|
||||||
(dolist (ext (cdr fmt))
|
(and (file-readable-p file)
|
||||||
(setq file (expand-file-name (concat name ext) dir))
|
(file-regular-p file)
|
||||||
(and
|
(throw 'found
|
||||||
(file-readable-p file)
|
(tree-widget-create-image
|
||||||
(file-regular-p file)
|
(car fmt) file
|
||||||
(throw
|
(tree-widget-image-properties name)))))))
|
||||||
'found
|
nil))))
|
||||||
(tree-widget-create-image
|
|
||||||
(car fmt) file
|
|
||||||
;; Add the pointer shape
|
|
||||||
(cons :pointer
|
|
||||||
(cons
|
|
||||||
(or (cdr (assoc name tree-widget--cursors))
|
|
||||||
'hand)
|
|
||||||
(tree-widget-image-properties file)))))))))
|
|
||||||
nil)))))
|
|
||||||
|
|
||||||
(defun tree-widget-find-image (name)
|
(defun tree-widget-find-image (name)
|
||||||
"Find the image with NAME in current theme.
|
"Find the image with NAME in current theme.
|
||||||
@ -530,12 +522,13 @@ Handle mouse button 1 click on buttons.")
|
|||||||
(define-widget 'tree-widget 'default
|
(define-widget 'tree-widget 'default
|
||||||
"Tree widget."
|
"Tree widget."
|
||||||
:format "%v"
|
:format "%v"
|
||||||
:convert-widget 'widget-types-convert-widget
|
:convert-widget 'tree-widget-convert-widget
|
||||||
:value-get 'widget-value-value-get
|
:value-get 'widget-value-value-get
|
||||||
:value-delete 'widget-children-value-delete
|
:value-delete 'widget-children-value-delete
|
||||||
:value-create 'tree-widget-value-create
|
:value-create 'tree-widget-value-create
|
||||||
:action 'tree-widget-action
|
:action 'tree-widget-action
|
||||||
:help-echo 'tree-widget-help-echo
|
:help-echo 'tree-widget-help-echo
|
||||||
|
:expander-p 'tree-widget-expander-p
|
||||||
:open-icon 'tree-widget-open-icon
|
:open-icon 'tree-widget-open-icon
|
||||||
:close-icon 'tree-widget-close-icon
|
:close-icon 'tree-widget-close-icon
|
||||||
:empty-icon 'tree-widget-empty-icon
|
:empty-icon 'tree-widget-empty-icon
|
||||||
@ -646,6 +639,14 @@ This hook should be local in the buffer setup to display widgets.")
|
|||||||
(1- (point)) (point)
|
(1- (point)) (point)
|
||||||
'display (list 'space :width tree-widget-space-width)))
|
'display (list 'space :width tree-widget-space-width)))
|
||||||
|
|
||||||
|
(defun tree-widget-convert-widget (widget)
|
||||||
|
"Convert :args as widget types in WIDGET."
|
||||||
|
(let ((tree (widget-types-convert-widget widget)))
|
||||||
|
;; Compatibility
|
||||||
|
(widget-put tree :expander (or (widget-get tree :expander)
|
||||||
|
(widget-get tree :dynargs)))
|
||||||
|
tree))
|
||||||
|
|
||||||
(defun tree-widget-value-create (tree)
|
(defun tree-widget-value-create (tree)
|
||||||
"Create the TREE tree-widget."
|
"Create the TREE tree-widget."
|
||||||
(let* ((node (tree-widget-node tree))
|
(let* ((node (tree-widget-node tree))
|
||||||
@ -662,8 +663,6 @@ This hook should be local in the buffer setup to display widgets.")
|
|||||||
(if (widget-get tree :open)
|
(if (widget-get tree :open)
|
||||||
;;;; Expanded node.
|
;;;; Expanded node.
|
||||||
(let ((args (widget-get tree :args))
|
(let ((args (widget-get tree :args))
|
||||||
(xpandr (or (widget-get tree :expander)
|
|
||||||
(widget-get tree :dynargs)))
|
|
||||||
(guide (widget-get tree :guide))
|
(guide (widget-get tree :guide))
|
||||||
(noguide (widget-get tree :no-guide))
|
(noguide (widget-get tree :no-guide))
|
||||||
(endguide (widget-get tree :end-guide))
|
(endguide (widget-get tree :end-guide))
|
||||||
@ -674,9 +673,11 @@ This hook should be local in the buffer setup to display widgets.")
|
|||||||
(endguidi (tree-widget-find-image "end-guide"))
|
(endguidi (tree-widget-find-image "end-guide"))
|
||||||
(handli (tree-widget-find-image "handle"))
|
(handli (tree-widget-find-image "handle"))
|
||||||
(nohandli (tree-widget-find-image "no-handle")))
|
(nohandli (tree-widget-find-image "no-handle")))
|
||||||
;; Request children at run time, when not already done.
|
;; Request children at run time, when requested.
|
||||||
(when (and (not args) xpandr)
|
(when (and (widget-get tree :expander)
|
||||||
(setq args (mapcar 'widget-convert (funcall xpandr tree)))
|
(widget-apply tree :expander-p))
|
||||||
|
(setq args (mapcar 'widget-convert
|
||||||
|
(widget-apply tree :expander)))
|
||||||
(widget-put tree :args args))
|
(widget-put tree :args args))
|
||||||
;; Defer the node widget creation after icon creation.
|
;; Defer the node widget creation after icon creation.
|
||||||
(widget-put tree :node (widget-convert node))
|
(widget-put tree :node (widget-convert node))
|
||||||
@ -800,6 +801,11 @@ Ignore the EVENT argument."
|
|||||||
"Collapse node"
|
"Collapse node"
|
||||||
"Expand node"))
|
"Expand node"))
|
||||||
|
|
||||||
|
(defun tree-widget-expander-p (tree)
|
||||||
|
"Return non-nil if the TREE tree-widget :expander has to be called.
|
||||||
|
That is, if TREE :args is nil."
|
||||||
|
(null (widget-get tree :args)))
|
||||||
|
|
||||||
(provide 'tree-widget)
|
(provide 'tree-widget)
|
||||||
|
|
||||||
;; arch-tag: c3a1ada2-1663-41dc-9d16-2479ed8320e8
|
;; arch-tag: c3a1ada2-1663-41dc-9d16-2479ed8320e8
|
||||||
|
Loading…
Reference in New Issue
Block a user