From 5bcfeb490ea59d6d58c8f30f6840995b8818763d Mon Sep 17 00:00:00 2001 From: Gerd Moellmann Date: Sun, 14 Nov 1999 16:37:23 +0000 Subject: [PATCH] (ensure_echo_area_buffers): New. (with_echo_area_buffer): Use it. (setup_echo_area_for_printing): Ditto. --- src/ChangeLog | 4 ++++ src/xdisp.c | 31 +++++++++++++++++++++++-------- 2 files changed, 27 insertions(+), 8 deletions(-) diff --git a/src/ChangeLog b/src/ChangeLog index b4d26a26abe..63525b0f2d6 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,9 @@ 1999-11-14 Gerd Moellmann + * xdisp.c (ensure_echo_area_buffers): New. + (with_echo_area_buffer): Use it. + (setup_echo_area_for_printing): Ditto. + * buffer.c (indicate-empty-lines): Doc-fix. 1999-11-12 Gerd Moellmann diff --git a/src/xdisp.c b/src/xdisp.c index 484474c2ab6..caa887b39a6 100644 --- a/src/xdisp.c +++ b/src/xdisp.c @@ -582,6 +582,7 @@ enum move_it_result /* Function prototypes. */ +static void ensure_echo_area_buffers P_ ((void)); static struct glyph_row *row_containing_pos P_ ((struct window *, int, struct glyph_row *, struct glyph_row *)); @@ -5162,6 +5163,25 @@ update_echo_area () } +/* Make sure echo area buffers in echo_buffers[] are life. If they + aren't, make new ones. */ + +static void +ensure_echo_area_buffers () +{ + int i; + + for (i = 0; i < 2; ++i) + if (!BUFFERP (echo_buffer[i]) + || NILP (XBUFFER (echo_buffer[i])->name)) + { + char name[30]; + sprintf (name, " *Echo Area %d*", i); + echo_buffer[i] = Fget_buffer_create (build_string (name)); + } +} + + /* Call FN with args A1..A5 with either the current or last displayed echo_area_buffer as current buffer. @@ -5190,14 +5210,7 @@ with_echo_area_buffer (w, which, fn, a1, a2, a3, a4, a5) int count = specpdl_ptr - specpdl; /* If buffers aren't life, make new ones. */ - for (i = 0; i < 2; ++i) - if (!BUFFERP (echo_buffer[i]) - || NILP (XBUFFER (echo_buffer[i])->name)) - { - char name[30]; - sprintf (name, " *Echo Area %d*", i); - echo_buffer[i] = Fget_buffer_create (build_string (name)); - } + ensure_echo_area_buffers (); clear_buffer_p = 0; @@ -5349,6 +5362,8 @@ void setup_echo_area_for_printing (multibyte_p) int multibyte_p; { + ensure_echo_area_buffers (); + if (!message_buf_print) { /* A message has been output since the last time we printed. -- 2.39.5