diff options
| author | Paul Eggert | 2018-12-09 00:18:36 -0800 |
|---|---|---|
| committer | Paul Eggert | 2018-12-09 00:23:55 -0800 |
| commit | d79bb75683ceb4eee2f753eb38fa8db99aff4568 (patch) | |
| tree | b0b20c25387c2eb11b2c79e87898bec2c39b14ea /src/lread.c | |
| parent | c2fdd50c3cb0b03d2414370c58c1aa2a6ec3311d (diff) | |
| download | emacs-d79bb75683ceb4eee2f753eb38fa8db99aff4568.tar.gz emacs-d79bb75683ceb4eee2f753eb38fa8db99aff4568.zip | |
Add make_vector and make_nil_vector
This makes the callers a bit easier to read, and doubtless
improves efficiency very slightly. It also simplifies
possible future changes to allow bignum indexes to buffers.
* src/alloc.c (allocate_vectorlike):
Prefer ptrdiff_t to size_t when either will do.
(make_vector): New function.
(Fmake_vector): Use it.
* src/buffer.c (syms_of_buffer):
* src/bytecode.c (syms_of_bytecode):
* src/category.c (Fmake_category_table, init_category_once):
* src/ccl.c (syms_of_ccl):
* src/character.c (syms_of_character):
* src/charset.c (Fdefine_charset_internal)
(Ffind_charset_region, Ffind_charset_string):
* src/chartab.c (copy_char_table):
* src/coding.c (Fdefine_coding_system_internal, syms_of_coding):
* src/composite.c (get_composition_id, Fcomposition_get_gstring):
* src/composite.h (LGLYPH_NEW):
* src/fns.c (concat, Flocale_info, make_hash_table):
* src/font.c (font_otf_ValueRecord, font_otf_anchor)
(build_style_table, syms_of_font):
* src/fontset.c (RFONT_DEF_NEW, fontset_find_font)
(dump_fontset, syms_of_fontset):
* src/image.c (xpm_make_color_table_v):
* src/keyboard.c (modify_event_symbol, menu_bar_items)
(parse_menu_item, parse_tool_bar_item, init_tool_bar_items)
(syms_of_keyboard):
* src/keymap.c (Fdefine_key, describe_map, describe_vector):
* src/lread.c (read_vector):
* src/macfont.m (macfont_shape):
* src/menu.c (init_menu_items):
* src/nsfns.m (ns_make_monitor_attribute_list):
* src/process.c (conv_sockaddr_to_lisp, network_interface_info):
* src/profiler.c (make_log):
* src/window.c (Fcurrent_window_configuration):
* src/xdisp.c (with_echo_area_buffer_unwind_data)
(format_mode_line_unwind_data):
* src/xfaces.c (Finternal_make_lisp_face)
(Fface_attributes_as_vector):
* src/xfns.c (x_make_monitor_attribute_list)
(Fx_display_monitor_attributes_list):
* src/xfont.c (syms_of_xfont):
* src/xselect.c (x_handle_dnd_message):
* src/xwidget.c (save_script_callback):
Prefer make_nil_vector (N) to Fmake_vector (make_fixnum (N), Qnil).
* src/callint.c (Fcall_interactively):
* src/charset.c (load_charset_map):
* src/chartab.c (Fmake_char_table, uniprop_encode_value_numeric):
* src/composite.c (get_composition_id)
* src/dispnew.c (Fframe_or_buffer_changed_p)
(syms_of_display):
* src/fns.c (make_hash_table, maybe_resize_hash_table):
* src/font.c (font_style_to_value):
* src/fontset.c (FONTSET_ADD, fontset_add):
* src/json.c (json_to_lisp):
* src/keymap.c (syms_of_keymap):
* src/lread.c (init_obarray):
* src/profiler.c (make_log, Fprofiler_cpu_log):
* src/term.c (term_get_fkeys_1):
Prefer make_vector (N, V) to Fmake_vector (make_fixnum (N), V).
* src/font.c (build_style_table):
* src/macfont.m (macfont_shape):
* src/process.c (conv_sockaddr_to_lisp, network_interface_info):
Prefer make_uninit_vector if the vector will be initialized soon.
* src/lisp.h (make_nil_vector): New function.
Diffstat (limited to 'src/lread.c')
| -rw-r--r-- | src/lread.c | 28 |
1 files changed, 11 insertions, 17 deletions
diff --git a/src/lread.c b/src/lread.c index 5f3871436df..4c6b7673228 100644 --- a/src/lread.c +++ b/src/lread.c | |||
| @@ -3846,23 +3846,17 @@ string_to_number (char const *string, int base, ptrdiff_t *plen) | |||
| 3846 | static Lisp_Object | 3846 | static Lisp_Object |
| 3847 | read_vector (Lisp_Object readcharfun, bool bytecodeflag) | 3847 | read_vector (Lisp_Object readcharfun, bool bytecodeflag) |
| 3848 | { | 3848 | { |
| 3849 | ptrdiff_t i, size; | 3849 | Lisp_Object tem = read_list (1, readcharfun); |
| 3850 | Lisp_Object *ptr; | 3850 | Lisp_Object len = Flength (tem); |
| 3851 | Lisp_Object tem, item, vector; | 3851 | ptrdiff_t size = XFIXNAT (len); |
| 3852 | struct Lisp_Cons *otem; | 3852 | if (bytecodeflag && size <= COMPILED_STACK_DEPTH) |
| 3853 | Lisp_Object len; | ||
| 3854 | |||
| 3855 | tem = read_list (1, readcharfun); | ||
| 3856 | len = Flength (tem); | ||
| 3857 | if (bytecodeflag && XFIXNAT (len) <= COMPILED_STACK_DEPTH) | ||
| 3858 | error ("Invalid byte code"); | 3853 | error ("Invalid byte code"); |
| 3859 | vector = Fmake_vector (len, Qnil); | 3854 | Lisp_Object vector = make_nil_vector (size); |
| 3860 | 3855 | ||
| 3861 | size = XFIXNAT (len); | 3856 | Lisp_Object *ptr = XVECTOR (vector)->contents; |
| 3862 | ptr = XVECTOR (vector)->contents; | 3857 | for (ptrdiff_t i = 0; i < size; i++) |
| 3863 | for (i = 0; i < size; i++) | ||
| 3864 | { | 3858 | { |
| 3865 | item = Fcar (tem); | 3859 | Lisp_Object item = Fcar (tem); |
| 3866 | /* If `load-force-doc-strings' is t when reading a lazily-loaded | 3860 | /* If `load-force-doc-strings' is t when reading a lazily-loaded |
| 3867 | bytecode object, the docstring containing the bytecode and | 3861 | bytecode object, the docstring containing the bytecode and |
| 3868 | constants values must be treated as unibyte and passed to | 3862 | constants values must be treated as unibyte and passed to |
| @@ -3896,7 +3890,7 @@ read_vector (Lisp_Object readcharfun, bool bytecodeflag) | |||
| 3896 | if (!CONSP (item)) | 3890 | if (!CONSP (item)) |
| 3897 | error ("Invalid byte code"); | 3891 | error ("Invalid byte code"); |
| 3898 | 3892 | ||
| 3899 | otem = XCONS (item); | 3893 | struct Lisp_Cons *otem = XCONS (item); |
| 3900 | bytestr = XCAR (item); | 3894 | bytestr = XCAR (item); |
| 3901 | item = XCDR (item); | 3895 | item = XCDR (item); |
| 3902 | free_cons (otem); | 3896 | free_cons (otem); |
| @@ -3916,7 +3910,7 @@ read_vector (Lisp_Object readcharfun, bool bytecodeflag) | |||
| 3916 | } | 3910 | } |
| 3917 | } | 3911 | } |
| 3918 | ASET (vector, i, item); | 3912 | ASET (vector, i, item); |
| 3919 | otem = XCONS (tem); | 3913 | struct Lisp_Cons *otem = XCONS (tem); |
| 3920 | tem = Fcdr (tem); | 3914 | tem = Fcdr (tem); |
| 3921 | free_cons (otem); | 3915 | free_cons (otem); |
| 3922 | } | 3916 | } |
| @@ -4383,7 +4377,7 @@ OBARRAY defaults to the value of `obarray'. */) | |||
| 4383 | void | 4377 | void |
| 4384 | init_obarray (void) | 4378 | init_obarray (void) |
| 4385 | { | 4379 | { |
| 4386 | Vobarray = Fmake_vector (make_fixnum (OBARRAY_SIZE), make_fixnum (0)); | 4380 | Vobarray = make_vector (OBARRAY_SIZE, make_fixnum (0)); |
| 4387 | initial_obarray = Vobarray; | 4381 | initial_obarray = Vobarray; |
| 4388 | staticpro (&initial_obarray); | 4382 | staticpro (&initial_obarray); |
| 4389 | 4383 | ||