From: Gerd Moellmann Date: Sat, 21 Aug 1999 19:28:42 +0000 (+0000) Subject: (Fgarbage_collect): Use push_message, restore_message, X-Git-Tag: emacs-pretest-21.0.90~7098 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=6efc7df7b88f2315138b507360363cee33a28229;p=emacs.git (Fgarbage_collect): Use push_message, restore_message, pop_message. --- diff --git a/src/alloc.c b/src/alloc.c index c0da91bf61b..978c4240a28 100644 --- a/src/alloc.c +++ b/src/alloc.c @@ -1746,19 +1746,16 @@ Garbage collection happens automatically if you cons more than\n\ struct handler *handler; register struct backtrace *backlist; register Lisp_Object tem; - char *omessage = echo_area_glyphs; - Lisp_Object omessage_string = echo_area_message; - int omessage_length = echo_area_glyphs_length; - int oldmultibyte = message_enable_multibyte; char stack_top_variable; register int i; - struct gcpro gcpro1; + int message_p; /* In case user calls debug_print during GC, don't let that cause a recursive GC. */ consing_since_gc = 0; - GCPRO1 (omessage_string); + /* Save what's currently displayed in the echo area. */ + message_p = push_message (); /* Save a copy of the contents of the stack, for debugging. */ #if MAX_SAVE_STACK > 0 @@ -1942,15 +1939,14 @@ Garbage collection happens automatically if you cons more than\n\ if (garbage_collection_messages) { - if (STRINGP (omessage_string)) - message3_nolog (omessage_string, omessage_length, oldmultibyte); - if (omessage || minibuf_level > 0) - message2_nolog (omessage, omessage_length, oldmultibyte); + if (message_p || minibuf_level > 0) + restore_message (); else message1_nolog ("Garbage collecting...done"); } - UNGCPRO; + pop_message (); + return Fcons (Fcons (make_number (total_conses), make_number (total_free_conses)), Fcons (Fcons (make_number (total_symbols),