From 4c2f559e1616ec431bc2be357adbe6bc70db2edb Mon Sep 17 00:00:00 2001 From: Per Abrahamsen Date: Thu, 3 Oct 2002 13:46:25 +0000 Subject: [PATCH] wid-edit.el fixes --- lisp/ChangeLog | 18 ++++++++++++++++++ lisp/wid-edit.el | 34 +++++++++++++++++++++++----------- man/widget.texi | 13 +++++++++++++ 3 files changed, 54 insertions(+), 11 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index ae0deed1294..4496b3111b6 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -27,6 +27,24 @@ * startup.el (normal-top-level): Reset standard-value property of `user-full-name' here. +2002-10-02 Per Abrahamsen + + * wid-edit.el (widget-default-get): Change to return external + value. + (widget-choice-action): Update caller. + (widget-editable-list-entry-create): Update caller. + + * wid-edit.el (widget-types-copy): New function. + (default): Added :copy keyword. + (menu-choice): Ditto. + (checklist): Ditto. + (radio-button-choice): Ditto. + (editable-list): Ditto. + (group): Ditto. + (widget-copy): New function. + (widget-create-child): Use it. + (widget-create-child-value): Use it. + 2002-10-01 Bill Wohler * mail/mh-comp.el, mail/mh-e.el, mail/mh-funcs.el, diff --git a/lisp/wid-edit.el b/lisp/wid-edit.el index 65c2c6fb28b..b9139dc90e7 100644 --- a/lisp/wid-edit.el +++ b/lisp/wid-edit.el @@ -508,9 +508,10 @@ Otherwise, just return the value." :value-to-internal value))) (defun widget-default-get (widget) - "Extract the default value of WIDGET." - (or (widget-get widget :value) - (widget-apply widget :default-get))) + "Extract the default external value of WIDGET." + (widget-apply widget :value-to-external + (or (widget-get widget :value) + (widget-apply widget :default-get)))) (defun widget-match-inline (widget vals) "In WIDGET, match the start of VALS." @@ -688,7 +689,7 @@ The child is converted, using the keyword arguments ARGS." (defun widget-create-child (parent type) "Create widget of TYPE." - (let ((widget (copy-sequence type))) + (let ((widget (widget-copy type))) (widget-put widget :parent parent) (unless (widget-get widget :indent) (widget-put widget :indent (+ (or (widget-get parent :indent) 0) @@ -699,7 +700,7 @@ The child is converted, using the keyword arguments ARGS." (defun widget-create-child-value (parent type value) "Create widget of TYPE with value VALUE." - (let ((widget (copy-sequence type))) + (let ((widget (widget-copy type))) (widget-put widget :value (widget-apply widget :value-to-internal value)) (widget-put widget :parent parent) (unless (widget-get widget :indent) @@ -714,6 +715,10 @@ The child is converted, using the keyword arguments ARGS." "Delete WIDGET." (widget-apply widget :delete)) +(defun widget-copy (widget) + "Make a deep copy of WIDGET." + (widget-apply (copy-sequence widget) :copy)) + (defun widget-convert (type &rest args) "Convert TYPE to a widget without inserting it in the buffer. The optional ARGS are additional keyword arguments." @@ -1271,6 +1276,11 @@ Optional EVENT is the event that triggered the action." found (widget-apply child :validate))) found)) +(defun widget-types-copy (widget) + "Copy :args as widget types in WIDGET." + (widget-put widget :args (mapcar 'widget-copy (widget-get widget :args))) + widget) + ;; Made defsubst to speed up face editor creation. (defsubst widget-types-convert-widget (widget) "Convert :args as widget types in WIDGET." @@ -1308,6 +1318,7 @@ Optional EVENT is the event that triggered the action." :button-face-get 'widget-default-button-face-get :sample-face-get 'widget-default-sample-face-get :delete 'widget-default-delete + :copy 'identity :value-set 'widget-default-value-set :value-inline 'widget-default-value-inline :default-get 'widget-default-default-get @@ -1853,6 +1864,7 @@ the earlier input." (define-widget 'menu-choice 'default "A menu of options." :convert-widget 'widget-types-convert-widget + :copy 'widget-types-copy :format "%[%t%]: %v" :case-fold t :tag "choice" @@ -1982,9 +1994,7 @@ when he invoked the menu." (when this-explicit (widget-put widget :explicit-choice current) (widget-put widget :explicit-choice-value (widget-get widget :value))) - (widget-value-set - widget (widget-apply current - :value-to-external (widget-default-get current))) + (widget-value-set widget (widget-default-get current)) (widget-setup) (widget-apply widget :notify widget event))) (run-hook-with-args 'widget-edit-functions widget)) @@ -2091,6 +2101,7 @@ when he invoked the menu." (define-widget 'checklist 'default "A multiple choice widget." :convert-widget 'widget-types-convert-widget + :copy 'widget-types-copy :format "%v" :offset 4 :entry-format "%b %v" @@ -2268,6 +2279,7 @@ Return an alist of (TYPE MATCH)." (define-widget 'radio-button-choice 'default "Select one of multiple options." :convert-widget 'widget-types-convert-widget + :copy 'widget-types-copy :offset 4 :format "%v" :entry-format "%b %v" @@ -2456,6 +2468,7 @@ Return an alist of (TYPE MATCH)." (define-widget 'editable-list 'default "A variable list of widgets of the same type." :convert-widget 'widget-types-convert-widget + :copy 'widget-types-copy :offset 12 :format "%v%i\n" :format-handler 'widget-editable-list-format-handler @@ -2607,9 +2620,7 @@ Return an alist of (TYPE MATCH)." (setq child (widget-create-child-value widget type value)) (setq child (widget-create-child-value - widget type - (widget-apply type :value-to-external - (widget-default-get type)))))) + widget type (widget-default-get type))))) (t (error "Unknown escape `%c'" escape))))) (widget-put widget @@ -2631,6 +2642,7 @@ Return an alist of (TYPE MATCH)." (define-widget 'group 'default "A widget which groups other widgets inside." :convert-widget 'widget-types-convert-widget + :copy 'widget-types-copy :format "%v" :value-create 'widget-group-value-create :value-delete 'widget-children-value-delete diff --git a/man/widget.texi b/man/widget.texi index 2efb57624b5..fdac3cdde64 100644 --- a/man/widget.texi +++ b/man/widget.texi @@ -1536,6 +1536,19 @@ Convert @code{:args} as widget types in @var{widget}. Initialize @code{:value} from @code{:args} in @var{widget}. @end defun +@vindex copy@r{ keyword} +@item :copy +Function to deep copy a widget type. It takes a shallow copy of the +widget type as an argument (made by @code{copy-sequence}), and returns a +deep copy. The purpose of this is to avoid having different instances +of combined widgets share nested attributes. + +The following predefined functions can be used here: + +@defun widget-types-copy widget +Copy @code{:args} as widget types in @var{widget}. +@end defun + @vindex value-to-internal@r{ keyword} @item :value-to-internal Function to convert the value to the internal format. The function -- 2.39.2