# HG changeset patch # User Richard M. Stallman # Date 854223570 0 # Node ID 8bdfc6767130ae9579be731c645673331a93854f # Parent e1aba4a05388c4639394155005c23744aa733c54 (set_internal): New subroutine. New arg BINDFLAG. Don't make a new buffer-local binding if BINDFLAG is 0. (Fset): Use set_internal. diff -r e1aba4a05388 -r 8bdfc6767130 src/data.c --- a/src/data.c Sat Jan 25 20:19:07 1997 +0000 +++ b/src/data.c Sat Jan 25 20:19:30 1997 +0000 @@ -902,6 +902,19 @@ (symbol, newval) register Lisp_Object symbol, newval; { + return set_internal (symbol, newval, 0); +} + +/* Stpre the value NEWVAL into SYMBOL. + If BINDFLAG is zero, then if this symbol is supposed to become + local in every buffer where it is set, then we make it local. + If BINDFLAG is nonzero, we don't do that. */ + +Lisp_Object +set_internal (symbol, newval, bindflag) + register Lisp_Object symbol, newval; + int bindflag; +{ int voide = EQ (newval, Qunbound); register Lisp_Object valcontents, tem1, current_alist_element; @@ -978,13 +991,14 @@ /* This buffer still sees the default value. */ /* If the variable is a Lisp_Some_Buffer_Local_Value, + or if this is `let' rather than `set', make CURRENT-ALIST-ELEMENT point to itself, indicating that we're seeing the default value. */ - if (SOME_BUFFER_LOCAL_VALUEP (valcontents)) + if (bindflag || SOME_BUFFER_LOCAL_VALUEP (valcontents)) tem1 = XCONS (XBUFFER_LOCAL_VALUE (valcontents)->cdr)->cdr; - /* If it's a Lisp_Buffer_Local_Value, give this buffer a - new assoc for a local value and set + /* If it's a Lisp_Buffer_Local_Value, being set not bound, + give this buffer a new assoc for a local value and set CURRENT-ALIST-ELEMENT to point to that. */ else {