]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix how the `character' custom type handles space chars.
authorChong Yidong <cyd@gnu.org>
Sun, 5 Feb 2012 15:33:30 +0000 (23:33 +0800)
committerChong Yidong <cyd@gnu.org>
Sun, 5 Feb 2012 15:33:30 +0000 (23:33 +0800)
* lisp/wid-edit.el (widget-field-value-get): New optional arg to
suppress trailing whitespace truncation.
(character): Use it.

Fixes: debbugs:2689
lisp/ChangeLog
lisp/wid-edit.el

index 6a31a20f947ec31cb37608ea8209694fad9bad76..93dd50b5ecbc600810f09ed29321725f877936c9 100644 (file)
@@ -1,3 +1,9 @@
+2012-02-05  Chong Yidong  <cyd@gnu.org>
+
+       * wid-edit.el (widget-field-value-get): New optional arg to
+       suppress trailing whitespace truncation.
+       (character): Use it (Bug#2689).
+
 2012-02-05  Andreas Schwab  <schwab@linux-m68k.org>
 
        * progmodes/gud.el (gud-pv): Use pv instead of pv1.
index 27922327f44fc43e5fb5156ccb833971d0dd7370..61bb4db558c517fffb890eb3a630e71903900fd5 100644 (file)
@@ -1987,10 +1987,14 @@ the earlier input."
     (when (overlayp overlay)
       (delete-overlay overlay))))
 
-(defun widget-field-value-get (widget)
-  "Return current text in editing field."
+(defun widget-field-value-get (widget &optional no-truncate)
+  "Return current text in editing field.
+Normally, trailing spaces within the editing field are truncated.
+But if NO-TRUNCATE is non-nil, include them."
   (let ((from (widget-field-start widget))
-       (to (widget-field-text-end widget))
+       (to   (if no-truncate
+                 (widget-field-end widget)
+               (widget-field-text-end widget)))
        (buffer (widget-field-buffer widget))
        (secret (widget-get widget :secret))
        (old (current-buffer)))
@@ -3407,6 +3411,7 @@ To use this type, you must define :match or :match-alternatives."
   :format "%{%t%}: %v\n"
   :valid-regexp "\\`.\\'"
   :error "This field should contain a single character"
+  :value-get (lambda (w) (widget-field-value-get w t))
   :value-to-internal (lambda (_widget value)
                       (if (stringp value)
                           value