]> git.eshelyaron.com Git - emacs.git/commitdiff
* lisp/simple.el (goto-line): Don't display default line number in the
authorJuri Linkov <juri@jurta.org>
Sun, 29 Jul 2012 18:11:42 +0000 (21:11 +0300)
committerJuri Linkov <juri@jurta.org>
Sun, 29 Jul 2012 18:11:42 +0000 (21:11 +0300)
prompt because it should be displayed by `read-number' (bug#9952).
Add the current line number to the defaults of `goto-line' to
allow its easier modification by users with `M-n' (bug#9201).

* lisp/subr.el (read-number): Support multiple default values like in
other minibuffer reading functions.  Replace `read' with
`string-to-number' for consistency with `number-to-string'.

lisp/ChangeLog
lisp/simple.el
lisp/subr.el

index 81afe67fd5bc8379ba1fd4a2c74455c56a3b9702..61ae993319a2acd01bc859f9a114359364431154 100644 (file)
@@ -1,3 +1,14 @@
+2012-07-29  Juri Linkov  <juri@jurta.org>
+
+       * simple.el (goto-line): Don't display default line number in the
+       prompt because it should be displayed by `read-number' (bug#9952).
+       Add the current line number to the defaults of `goto-line' to
+       allow its easier modification by users with `M-n' (bug#9201).
+
+       * subr.el (read-number): Support multiple default values like in
+       other minibuffer reading functions.  Replace `read' with
+       `string-to-number' for consistency with `number-to-string'.
+
 2012-07-29  Paul Eggert  <eggert@cs.ucla.edu>
 
        deactive->inactive, inactivate->deactivate spelling fixes (Bug#10150)
index 4b6d6c7a73bedc122ca2d540dd5f5dc55e1f6bbf..e1d6760e72b5ad143d4ae83f05ce1fa6e7a2e972 100644 (file)
@@ -948,11 +948,8 @@ rather than line counts."
                 (concat " in " (buffer-name buffer))
               "")))
        ;; Read the argument, offering that number (if any) as default.
-       (list (read-number (format (if default "Goto line%s (%s): "
-                                    "Goto line%s: ")
-                                  buffer-prompt
-                                  default)
-                          default)
+       (list (read-number (format "Goto line%s: " buffer-prompt)
+                          (list default (line-number-at-pos)))
             buffer))))
   ;; Switch to the desired buffer, one way or another.
   (if buffer
index 76fec5dd5ac522b20b12f9d5bb4399113293c636..73bc1d99e053c2f169f594e55ee5bc3999d2dd61 100644 (file)
@@ -2188,23 +2188,27 @@ by doing (clear-string STRING)."
   "Read a numeric value in the minibuffer, prompting with PROMPT.
 DEFAULT specifies a default value to return if the user just types RET.
 The value of DEFAULT is inserted into PROMPT."
-  (let ((n nil))
-    (when default
+  (let ((n nil)
+       (default1 (if (consp default) (car default) default)))
+    (when default1
       (setq prompt
            (if (string-match "\\(\\):[ \t]*\\'" prompt)
-               (replace-match (format " (default %s)" default) t t prompt 1)
+               (replace-match (format " (default %s)" default1) t t prompt 1)
              (replace-regexp-in-string "[ \t]*\\'"
-                                       (format " (default %s) " default)
+                                       (format " (default %s) " default1)
                                        prompt t t))))
     (while
        (progn
-         (let ((str (read-from-minibuffer prompt nil nil nil nil
-                                          (and default
-                                               (number-to-string default)))))
+         (let ((str (read-from-minibuffer
+                     prompt nil nil nil nil
+                     (when default
+                       (if (consp default)
+                           (mapcar 'number-to-string (delq nil default))
+                         (number-to-string default))))))
            (condition-case nil
                (setq n (cond
-                        ((zerop (length str)) default)
-                        ((stringp str) (read str))))
+                        ((zerop (length str)) default1)
+                        ((stringp str) (string-to-number str))))
              (error nil)))
          (unless (numberp n)
            (message "Please enter a number.")