summaryrefslogtreecommitdiff
path: root/src/bytecode.c
diff options
context:
space:
mode:
authorPaul Eggert <eggert@cs.ucla.edu>2016-03-26 19:24:25 -0700
committerPaul Eggert <eggert@cs.ucla.edu>2016-03-26 19:24:46 -0700
commitbc9cc21d34ae71dc38bd20f224c4b3ac073bcb50 (patch)
tree259f54589caf61669955e0708b6800101db465b2 /src/bytecode.c
parentefb1883244f551cfb43fa9d85e3df8cc334fb232 (diff)
downloademacs-bc9cc21d34ae71dc38bd20f224c4b3ac073bcb50.tar.gz
func-arity minor improvements
* src/bytecode.c (get_byte_code_arity): Omit unnecessary runtime test for integer argument, unless debugging. Use EMACS_INT for Emacs integers. * src/eval.c (Ffunc_arity): Omit unused locals. Avoid side effects in ‘if’ expr. (lambda_arity): Use bool for boolean, and EMACS_INT for Emacs ints.
Diffstat (limited to 'src/bytecode.c')
-rw-r--r--src/bytecode.c20
1 files changed, 8 insertions, 12 deletions
diff --git a/src/bytecode.c b/src/bytecode.c
index 4ff15d2912a..fb9f617b514 100644
--- a/src/bytecode.c
+++ b/src/bytecode.c
@@ -1991,18 +1991,14 @@ exec_byte_code (Lisp_Object bytestr, Lisp_Object vector, Lisp_Object maxdepth,
Lisp_Object
get_byte_code_arity (Lisp_Object args_template)
{
- if (INTEGERP (args_template))
- {
- ptrdiff_t at = XINT (args_template);
- bool rest = (at & 128) != 0;
- int mandatory = at & 127;
- ptrdiff_t nonrest = at >> 8;
-
- return Fcons (make_number (mandatory),
- rest ? Qmany : make_number (nonrest));
- }
- else
- error ("Unknown args template!");
+ eassert (NATNUMP (args_template));
+ EMACS_INT at = XINT (args_template);
+ bool rest = (at & 128) != 0;
+ int mandatory = at & 127;
+ EMACS_INT nonrest = at >> 8;
+
+ return Fcons (make_number (mandatory),
+ rest ? Qmany : make_number (nonrest));
}
void