diff options
| author | Paul Eggert | 2014-09-29 19:43:23 -0700 |
|---|---|---|
| committer | Paul Eggert | 2014-09-29 19:43:23 -0700 |
| commit | dc4525691c2c236abdb6c074438223413f80091c (patch) | |
| tree | 86305e7415bcf1b5cc6ddad6879e922f9e5e163c /src/keymap.c | |
| parent | a19f0977a96ee74b96410b41a8ea793c86f64b58 (diff) | |
| download | emacs-dc4525691c2c236abdb6c074438223413f80091c.tar.gz emacs-dc4525691c2c236abdb6c074438223413f80091c.zip | |
Simplify stack-allocated Lisp objects, and make them more portable.
The build_local_string macro was used in two ways: (1) string
literals for which scoped allocation suffices, and (2) file name
components, where it's not safe in general to assume bounded-size
ASCII data. Simplify by defining a new macro SCOPED_STRING that
allocates a block-scope string, and by using SCOPED_STRING for (1)
and build_string for (2). Furthermore, actually use stack
allocation only for objects known to have sufficient alignment.
This simpler implementation means Emacs can make
USE_STACK_LISP_OBJECTS the default unless GC_MARK_STACK !=
GC_MAKE_GCPROS_NOOPS.
* lisp.h (GCALIGNED): Align even if !USE_STACK_LISP_OBJECTS,
for fewer differences among implementations.
(struct Lisp_String): Now GCALIGNED.
(USE_STACK_LISP_OBJECTS): Default to true, since the
implementation no longer insists on a nonempty GCALIGNED.
But make it false if GC_MARK_STACK != GC_MAKE_GCPROS_NOOPS.
(SCOPED_CONS_INITIALIZER): Remove, since it's no longer needed
separately. Move definiens to scoped_cons. The old definition
was incorrect when GCALIGNED was defined to be empty.
(union Aligned_String): New type.
(USE_STACK_CONS, USE_STACK_STRING): New constants, so that the
implementation ports to compilers that don't align strictly enough.
Don't worry about the union sizes; it's not worth bothering about.
(scoped_cons, scoped_list1, scoped_list3, scoped_list4):
Rewrite using USE_STACK_CONS.
(scoped_cons): Assume the use of union Aligned_Cons.
(lisp_string_size, make_local_string, build_local_string): Remove.
Unless otherwise specified, all callers of build_local_string
changed to use SCOPED_STRING.
(SCOPED_STRING): New macro.
* data.c (wrong_choice):
* menu.c (single_menu_item):
* process.c (Fformat_network_address):
Hoist use of SCOPED_STRING out of a scope, so that its returned
object lives long enough.
* fileio.c (Fexpand_file_name): Use build_string, not SCOPED_STRING,
as the string might be long or might not be ASCII.
Diffstat (limited to 'src/keymap.c')
| -rw-r--r-- | src/keymap.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/keymap.c b/src/keymap.c index ed572a5a8c1..368903db5e6 100644 --- a/src/keymap.c +++ b/src/keymap.c | |||
| @@ -1338,7 +1338,7 @@ silly_event_symbol_error (Lisp_Object c) | |||
| 1338 | *p = 0; | 1338 | *p = 0; |
| 1339 | 1339 | ||
| 1340 | c = reorder_modifiers (c); | 1340 | c = reorder_modifiers (c); |
| 1341 | keystring = concat2 (build_local_string (new_mods), XCDR (assoc)); | 1341 | keystring = concat2 (SCOPED_STRING (new_mods), XCDR (assoc)); |
| 1342 | 1342 | ||
| 1343 | error ("To bind the key %s, use [?%s], not [%s]", | 1343 | error ("To bind the key %s, use [?%s], not [%s]", |
| 1344 | SDATA (SYMBOL_NAME (c)), SDATA (keystring), | 1344 | SDATA (SYMBOL_NAME (c)), SDATA (keystring), |
| @@ -2243,7 +2243,7 @@ around function keys and event symbols. */) | |||
| 2243 | if (CONSP (key) && INTEGERP (XCAR (key)) && INTEGERP (XCDR (key))) | 2243 | if (CONSP (key) && INTEGERP (XCAR (key)) && INTEGERP (XCDR (key))) |
| 2244 | /* An interval from a map-char-table. */ | 2244 | /* An interval from a map-char-table. */ |
| 2245 | return concat3 (Fsingle_key_description (XCAR (key), no_angles), | 2245 | return concat3 (Fsingle_key_description (XCAR (key), no_angles), |
| 2246 | build_local_string (".."), | 2246 | SCOPED_STRING (".."), |
| 2247 | Fsingle_key_description (XCDR (key), no_angles)); | 2247 | Fsingle_key_description (XCDR (key), no_angles)); |
| 2248 | 2248 | ||
| 2249 | key = EVENT_HEAD (key); | 2249 | key = EVENT_HEAD (key); |
| @@ -3441,7 +3441,7 @@ describe_vector (Lisp_Object vector, Lisp_Object prefix, Lisp_Object args, | |||
| 3441 | { | 3441 | { |
| 3442 | Lisp_Object tem; | 3442 | Lisp_Object tem; |
| 3443 | tem = Fkey_description (prefix, Qnil); | 3443 | tem = Fkey_description (prefix, Qnil); |
| 3444 | elt_prefix = concat2 (tem, build_local_string (" ")); | 3444 | elt_prefix = concat2 (tem, SCOPED_STRING (" ")); |
| 3445 | } | 3445 | } |
| 3446 | prefix = Qnil; | 3446 | prefix = Qnil; |
| 3447 | } | 3447 | } |