]> git.eshelyaron.com Git - emacs.git/commitdiff
Harden exec_byte_code against redefining 'error'
authorPaul Eggert <eggert@union>
Mon, 27 Nov 2017 03:15:14 +0000 (19:15 -0800)
committerPaul Eggert <eggert@cs.ucla.edu>
Mon, 27 Nov 2017 03:16:47 +0000 (19:16 -0800)
Problem discovered by configuring with --enable-gcc-warnings on
Ubuntu 17.10 x86-64 with gcc (Ubuntu 7.2.0-8ubuntu3).
* src/bytecode.c (exec_byte_code): Call the C error function
instead of the Lisp one, so that the Emacs interpreter does not go
haywire if the user redefines the Lisp error function.

src/bytecode.c

index ebaf3c3a7fce76504724b0f78c3ad38a7aef2ebe..8746568f1664d2470f4d0f1fc2d035694fcd447e 100644 (file)
@@ -1346,10 +1346,8 @@ exec_byte_code (Lisp_Object bytestr, Lisp_Object vector, Lisp_Object maxdepth,
          /* Actually this is Bstack_ref with offset 0, but we use Bdup
             for that instead.  */
          /* CASE (Bstack_ref): */
-         call3 (Qerror,
-                build_string ("Invalid byte opcode: op=%s, ptr=%d"),
-                make_number (op),
-                make_number (pc - 1 - bytestr_data));
+         error ("Invalid byte opcode: op=%d, ptr=%"pD"d",
+                op, pc - 1 - bytestr_data);
 
          /* Handy byte-codes for lexical binding.  */
        CASE (Bstack_ref1):