diff options
author | Gerd Moellmann <gerd@gnu.org> | 2000-02-20 15:55:38 +0000 |
---|---|---|
committer | Gerd Moellmann <gerd@gnu.org> | 2000-02-20 15:55:38 +0000 |
commit | 620cc5fa301677570852647c50f638b27ddc3c03 (patch) | |
tree | d5cda0c3b0a42c746da68e72469ad5b15d025787 /src/bytecode.c | |
parent | 9ab90667d31851abf6e5334d5c8fc866d62dde2f (diff) | |
download | emacs-620cc5fa301677570852647c50f638b27ddc3c03.tar.gz |
(Fbyte_code) <Bvarset>: Inline most common case.
Diffstat (limited to 'src/bytecode.c')
-rw-r--r-- | src/bytecode.c | 41 |
1 files changed, 34 insertions, 7 deletions
diff --git a/src/bytecode.c b/src/bytecode.c index 14a93f18f81..06f644e1481 100644 --- a/src/bytecode.c +++ b/src/bytecode.c @@ -544,20 +544,47 @@ If the third argument is incorrect, Emacs may crash.") break; } - case Bvarset+7: - op = FETCH2; + case Bvarset: + case Bvarset+1: + case Bvarset+2: + case Bvarset+3: + case Bvarset+4: + case Bvarset+5: + op -= Bvarset; goto varset; - case Bvarset: case Bvarset+1: case Bvarset+2: case Bvarset+3: - case Bvarset+4: case Bvarset+5: - op -= Bvarset; + case Bvarset+7: + op = FETCH2; goto varset; case Bvarset+6: op = FETCH; varset: - set_internal (vectorp[op], POP, current_buffer, 0); - /* Fset (vectorp[op], POP); */ + { + Lisp_Object sym, val; + extern int keyword_symbols_constant_flag; + + sym = vectorp[op]; + val = POP; + + /* Inline the most common case. */ + if (SYMBOLP (sym) + && !EQ (val, Qunbound) + && !MISCP (XSYMBOL (sym)->value) + /* I think this should either be checked in the byte + compiler, or there should be a flag indicating that + a symbol might be constant in Lisp_Symbol, instead + of checking this here over and over again. --gerd. */ + && !EQ (sym, Qnil) + && !EQ (sym, Qt) + && !(XSYMBOL (sym)->name->data[0] == ':' + && EQ (XSYMBOL (sym)->obarray, initial_obarray) + && keyword_symbols_constant_flag + && !EQ (val, sym))) + XSYMBOL (sym)->value = val; + else + set_internal (sym, val, current_buffer, 0); + } break; case Bdup: |