]> code.delx.au - gnu-emacs/commitdiff
Fix bug #14063 with reverting the *Colors* buffer.
authorEli Zaretskii <eliz@gnu.org>
Wed, 27 Mar 2013 16:03:15 +0000 (18:03 +0200)
committerEli Zaretskii <eliz@gnu.org>
Wed, 27 Mar 2013 16:03:15 +0000 (18:03 +0200)
 lisp/facemenu.el (list-colors-callback): New defvar.
 (list-colors-redisplay): New function.
 (list-colors-display): Install list-colors-redisplay as the
 revert-buffer-function.

lisp/ChangeLog
lisp/facemenu.el

index fecad470900b1b92a980b9dba995a4cfd58449bb..00a105b514266146f57460ff66be9a4ae91f26f5 100644 (file)
@@ -1,3 +1,10 @@
+2013-03-27  Eli Zaretskii  <eliz@gnu.org>
+
+       * facemenu.el (list-colors-callback): New defvar.
+       (list-colors-redisplay): New function.
+       (list-colors-display): Install list-colors-redisplay as the
+       revert-buffer-function.  (Bug#14063)
+
 2013-03-27  Stefan Monnier  <monnier@iro.umontreal.ca>
 
        * minibuffer.el (completion-pcm--merge-completions): Make sure prefixes
index e86c1c23d66ed44f6ef3490571f91b11a5757f59..9a66edd28fc04571e75ecae08c231feeabb41078 100644 (file)
@@ -513,12 +513,23 @@ filter out the color from the output."
         (* (nth 1 c-rgb) 0.7151522)
         (* (nth 2 c-rgb) 0.0721750))))))
 
+(defvar list-colors-callback nil
+  "Value of CALLBACK arg passed to `list-colors-display'; internal use.")
+
+(defun list-colors-redisplay (_ignore-auto _noconfirm)
+  "Redisplay the colors using `list-colors-sort'.
+
+This is installed as a `revert-buffer-function' in the *Colors* buffer."
+  (list-colors-display nil (buffer-name) list-colors-callback))
+
 (defun list-colors-display (&optional list buffer-name callback)
   "Display names of defined colors, and show what they look like.
 If the optional argument LIST is non-nil, it should be a list of
 colors to display.  Otherwise, this command computes a list of
 colors that the current display can handle.  Customize
 `list-colors-sort' to change the order in which colors are shown.
+Type `g' or \\[revert-buffer] after customizing `list-colors-sort'
+to redisplay colors in the new order.
 
 If the optional argument BUFFER-NAME is nil, it defaults to *Colors*.
 
@@ -566,7 +577,9 @@ color.  The function should accept a single argument, the color name."
       (erase-buffer)
       (list-colors-print list callback)
       (set-buffer-modified-p nil)
-      (setq truncate-lines t)))
+      (setq truncate-lines t)
+      (setq-local list-colors-callback callback)
+      (setq revert-buffer-function 'list-colors-redisplay)))
   (when callback
     (pop-to-buffer buffer-name)
     (message "Click on a color to select it.")))