From: Richard M. Stallman Date: Thu, 12 Feb 1998 05:18:59 +0000 (+0000) Subject: (printchar): When outputting to echo area, X-Git-Tag: emacs-20.3~2186 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=1134b8547c41ce376bba631ddf644bf7d142e59b;p=emacs.git (printchar): When outputting to echo area, update message_enable_multibyte, and convert previous text from unibyte to multibyte if necessary. --- diff --git a/src/print.c b/src/print.c index f4b10c49770..6760af3298f 100644 --- a/src/print.c +++ b/src/print.c @@ -384,6 +384,25 @@ printchar (ch, fun) } message_dolog (str, len, 0, len > 1); + + /* Convert message to multibyte if we are now adding multibyte text. */ + if (! NILP (current_buffer->enable_multibyte_characters) + && ! message_enable_multibyte + && printbufidx > 0) + { + int size = count_size_as_multibyte (FRAME_MESSAGE_BUF (mini_frame), + printbufidx); + unsigned char *tembuf = (unsigned char *) alloca (size + 1); + copy_text (FRAME_MESSAGE_BUF (mini_frame), tembuf, printbufidx, + 0, 1); + printbufidx = size; + if (printbufidx > FRAME_MESSAGE_BUF_SIZE (mini_frame)) + printbufidx = FRAME_MESSAGE_BUF_SIZE (mini_frame); + bcopy (tembuf, FRAME_MESSAGE_BUF (mini_frame), printbufidx); + } + message_enable_multibyte + = ! NILP (current_buffer->enable_multibyte_characters); + if (printbufidx < FRAME_MESSAGE_BUF_SIZE (mini_frame) - len) bcopy (str, &FRAME_MESSAGE_BUF (mini_frame)[printbufidx], len), printbufidx += len;