* bug#16755: 24.3; customize-save-variable saves the wrong value
@ 2014-02-14 15:23 Sean Peters
2014-02-14 18:23 ` Stefan Monnier
0 siblings, 1 reply; 3+ messages in thread
From: Sean Peters @ 2014-02-14 15:23 UTC (permalink / raw)
To: 16755
Bug:
customize-save-variable saves the wrong value if custom-set changes
the value.
Example:
(defcustom emacspeak-feeds
'(
("Wired News" "http://www.wired.com/news_drop/netcenter/netcenter.rdf" rss)
("BBC Podcast Directory" "http://www.bbc.co.uk/podcasts.opml" opml)
("BBC News" "http://www.bbc.co.uk/syndication/feeds/news/ukfs_news/front_page/rss091.xml" rss)
("CNet Tech News" "http://feeds.feedburner.com/cnet/tcoc" rss)
)
"Table of RSS feeds."
:type '(repeat
(list :tag "Feed"
(string :tag "Title")
(string :tag "URI")
(choice :tag "Type"
(const :tag "RSS" rss)
(const :tag "opml" opml)
(const :tag "Atom" atom))))
:initialize 'custom-initialize-reset
:set
#'(lambda (sym val)
(set-default
sym
(sort val #'(lambda (a b)
(string-lessp (first a) (first b))))))
:group 'emacspeak-feeds)
(customize-save-variable 'emacspeak-feeds (push '("z" "z" 'rss) emacspeak-feeds))
The value that gets saved is just '("z" "z" (quote rss)) instead of
the existing list with this on the end.
Cause:
These two lines from customize-save-variable show the problem:
(funcall (or (get variable 'custom-set) 'set-default) variable value)
(put variable 'saved-value (list (custom-quote value)))
During the call of custom-set, value gets destructively sorted. So
when value is used for setting saved-value it is missing the part of
the sorted list of settings before the newly added feed.
Fix:
I think customize-save-variable should use (default-value variable)
instead of value in all the places it currently uses value after the
call to custom-set.
Also, customize-set-variable may have a similar problem.
Sean
--
^ permalink raw reply [flat|nested] 3+ messages in thread
* bug#16755: 24.3; customize-save-variable saves the wrong value
2014-02-14 15:23 bug#16755: 24.3; customize-save-variable saves the wrong value Sean Peters
@ 2014-02-14 18:23 ` Stefan Monnier
2014-03-18 23:32 ` Juanma Barranquero
0 siblings, 1 reply; 3+ messages in thread
From: Stefan Monnier @ 2014-02-14 18:23 UTC (permalink / raw)
To: Sean Peters; +Cc: 16755
> I think customize-save-variable should use (default-value variable)
> instead of value in all the places it currently uses value after the
> call to custom-set.
But that can't work: a "custom variable" may not even have
a `default-value'. The :get and :set are free to completely change
between the world of "value as seen by Custom and the end user" and "the
world of Elisp" where that corresponding value can be represented in
completely different ways.
This is rarely used, admittedly, but attempts at providing support for
Customizing keymaps or things like `load-path' rely on this feature.
So I think the better course is to document that the ":set" function should
not modify its `val' argument destructively.
Stefan
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2014-03-18 23:32 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-02-14 15:23 bug#16755: 24.3; customize-save-variable saves the wrong value Sean Peters
2014-02-14 18:23 ` Stefan Monnier
2014-03-18 23:32 ` Juanma Barranquero
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).