# HG changeset patch # User Richard M. Stallman <rms@gnu.org> # Date 869031278 0 # Node ID 83425393d550e508daba7734587c6b027194571b # Parent ac2b130c513ae54714ee8a9fa2f71ca36b4b79bb (read-quoted-char): Read any number of octal digits, and ignore a space if that terminates the octal digits. diff -r ac2b130c513a -r 83425393d550 lisp/subr.el --- a/lisp/subr.el Wed Jul 16 05:33:34 1997 +0000 +++ b/lisp/subr.el Wed Jul 16 05:34:38 1997 +0000 @@ -650,29 +650,39 @@ ;;;; Input and display facilities. (defun read-quoted-char (&optional prompt) - "Like `read-char', except that if the first character read is an octal -digit, we read up to two more octal digits and return the character -represented by the octal number consisting of those digits. -Optional argument PROMPT specifies a string to use to prompt the user." - (let ((message-log-max nil) (count 0) (code 0) char) - (while (< count 3) - (let ((inhibit-quit (zerop count)) + "Like `read-char', but do not allow quitting. +Also, if the first character read is an octal digit, +we read any number of octal digits and return the +soecified character code. Any nondigit terminates the sequence. +If the terminator is a space, it is discarded; +any other terminator is used itself as input. + +The optional argument PROMPT specifies a string to use to prompt the user." + (let ((message-log-max nil) done (first t) (code 0) char) + (while (not done) + (let ((inhibit-quit first) ;; Don't let C-h get the help message--only help function keys. (help-char nil) (help-form "Type the special character you want to use, -or three octal digits representing its character code.")) +or the octal character code. +Space terminates the character code and is discarded; +any other non-digit terminates the character code and is then used as input.")) (and prompt (message "%s-" prompt)) (setq char (read-char)) (if inhibit-quit (setq quit-flag nil))) (cond ((null char)) ((and (<= ?0 char) (<= char ?7)) - (setq code (+ (* code 8) (- char ?0)) - count (1+ count)) + (setq code (+ (* code 8) (- char ?0))) (and prompt (setq prompt (message "%s %c" prompt char)))) - ((> count 0) - (setq unread-command-events (list char) count 259)) - (t (setq code char count 259)))) + ((and (not first) (eq char ?\ )) + (setq done t)) + ((not first) + (setq unread-command-events (list char) + done t)) + (t (setq code char + done t))) + (setq first nil)) ;; Turn a meta-character into a character with the 0200 bit set. (logior (if (/= (logand code ?\M-\^@) 0) 128 0) code)))