unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* 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

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).