From: Richard M. Stallman Date: Sun, 7 Sep 1997 18:32:49 +0000 (+0000) Subject: (Feval_buffer): New arg FILENAME. X-Git-Tag: emacs-20.1~145 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=13febd855d89ec4d59c5e64fa6710189877b3024;p=emacs.git (Feval_buffer): New arg FILENAME. --- diff --git a/src/lread.c b/src/lread.c index 458992cfaa8..a2c90e7f2b1 100644 --- a/src/lread.c +++ b/src/lread.c @@ -941,16 +941,19 @@ readevalloop (readcharfun, stream, sourcename, evalfun, printflag) #ifndef standalone -DEFUN ("eval-buffer", Feval_buffer, Seval_buffer, 0, 2, "", +DEFUN ("eval-buffer", Feval_buffer, Seval_buffer, 0, 3, "", "Execute the current buffer as Lisp code.\n\ Programs can pass two arguments, BUFFER and PRINTFLAG.\n\ BUFFER is the buffer to evaluate (nil means use current buffer).\n\ PRINTFLAG controls printing of output:\n\ nil means discard it; anything else is stream for print.\n\ \n\ +If the optional third argument FILENAME is non-nil,\n\ +it specifies the file name to use for `load-history'.\n\ +\n\ This function preserves the position of point.") - (buffer, printflag) - Lisp_Object buffer, printflag; + (buffer, printflag, filename) + Lisp_Object buffer, printflag, filename; { int count = specpdl_ptr - specpdl; Lisp_Object tem, buf; @@ -960,16 +963,20 @@ This function preserves the position of point.") else buf = Fget_buffer (buffer); if (NILP (buf)) - error ("No such buffer."); + error ("No such buffer"); if (NILP (printflag)) tem = Qsymbolp; else tem = printflag; + + if (NILP (filename)) + filename = XBUFFER (buf)->filename; + specbind (Qstandard_output, tem); record_unwind_protect (save_excursion_restore, save_excursion_save ()); BUF_SET_PT (XBUFFER (buf), BUF_BEGV (XBUFFER (buf))); - readevalloop (buf, 0, XBUFFER (buf)->filename, Feval, !NILP (printflag)); + readevalloop (buf, 0, filename, Feval, !NILP (printflag)); unbind_to (count, Qnil); return Qnil;