aboutsummaryrefslogtreecommitdiffstats
path: root/src/indent.c
diff options
context:
space:
mode:
authorPaul Eggert2011-09-21 10:41:20 -0700
committerPaul Eggert2011-09-21 10:41:20 -0700
commitd311d28c3f8a3c43e6ef33d68b852c5ea7f13239 (patch)
tree84b390c8bd472074294a31d51e790437f0a9a75d /src/indent.c
parent4768be09c9866add356a0a9b47ecd42346442b9f (diff)
downloademacs-d311d28c3f8a3c43e6ef33d68b852c5ea7f13239.tar.gz
emacs-d311d28c3f8a3c43e6ef33d68b852c5ea7f13239.zip
* alloc.c (pure_bytes_used_lisp, pure_bytes_used_non_lisp):
(allocate_vectorlike, buffer_memory_full, struct sdata, SDATA_SIZE) (string_bytes, check_sblock, allocate_string_data): (compact_small_strings, Fmake_bool_vector, make_string) (make_unibyte_string, make_multibyte_string) (make_string_from_bytes, make_specified_string) (allocate_vectorlike, Fmake_vector, find_string_data_in_pure) (make_pure_string, make_pure_c_string, make_pure_vector, Fpurecopy) (mark_vectorlike): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (allocate_pseudovector): Use int, not EMACS_INT, where int is wide enough. (inhibit_garbage_collection, Fgarbage_collect): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * bidi.c (bidi_mirror_char): Use EMACS_INT, not int, where int might not be wide enough. (bidi_cache_search, bidi_cache_find, bidi_init_it) (bidi_count_bytes, bidi_char_at_pos, bidi_fetch_char) (bidi_at_paragraph_end, bidi_find_paragraph_start) (bidi_paragraph_init, bidi_resolve_explicit, bidi_resolve_weak) (bidi_level_of_next_char, bidi_move_to_visually_next): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * buffer.c (copy_overlays, Fgenerate_new_buffer_name) (Fkill_buffer, Fset_buffer_major_mode) (advance_to_char_boundary, Fbuffer_swap_text) (Fset_buffer_multibyte, overlays_at, overlays_in) (overlay_touches_p, struct sortvec, record_overlay_string) (overlay_strings, recenter_overlay_lists) (adjust_overlays_for_insert, adjust_overlays_for_delete) (fix_start_end_in_overlays, fix_overlays_before, modify_overlay) (Fmove_overlay, Fnext_overlay_change, Fprevious_overlay_change) (Foverlay_recenter, last_overlay_modification_hooks_used) (report_overlay_modification, evaporate_overlays, enlarge_buffer_text): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (validate_region): Omit unnecessary test for b <= e, since that's guaranteed by the previous test. (adjust_overlays_for_delete): Avoid pos + length overflow. (Fmove_overlay, Fdelete_overlay, add_overlay_mod_hooklist) (report_overlay_modification): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Foverlays_at, Fnext_overlay_change, Fprevious_overlay_change): Omit pointer cast, which isn't needed anyway, and doesn't work after the EMACS_INT -> ptrdiff_t change. * buffer.h: Adjust decls to match defn changes elsewhere. (struct buffer_text, struct buffer): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. Use EMACS_INT, not int, where int might not be wide enough. * bytecode.c (exec_byte_code): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. Remove unnecessary memory-full test. Use EMACS_INT, not ptrdiff_t or int, where ptrdiff_t or int might not be wide enough. * callint.c (Fcall_interactively): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * callproc.c (call_process_kill, Fcall_process): Don't assume pid_t fits into an Emacs fixnum. (call_process_cleanup, Fcall_process, child_setup): Don't assume pid_t fits into int. (call_process_cleanup, Fcall_process, delete_temp_file) (Fcall_process_region): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Fcall_process): Simplify handling of volatile integers. Use int, not EMACS_INT, where int will do. * casefiddle.c (casify_object, casify_region, operate_on_word) (Fupcase_word, Fdowncase_word, Fcapitalize_word): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (casify_object): Avoid integer overflow when overallocating buffer. * casetab.c (set_identity, shuffle): Prefer int to unsigned when either works. * category.c (Fchar_category_set): Don't assume fixnum fits in int. * category.h (CATEGORYP): Don't assume arg is nonnegative. * ccl.c (GET_CCL_INT): Remove; no longer needed, since the integers are now checked earlier. All uses replaced with XINT. (ccl_driver): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. For CCL_MapSingle, check that content and value are in int range. (resolve_symbol_ccl_program): Check that vector header is in range. Always copy the vector, so that we can check its contents reliably now rather than having to recheck each instruction as it's being executed. Check that vector words fit in 'int'. (ccl_get_compiled_code, Fregister_ccl_program) (Fregister_code_conversion_map): Use ptrdiff_t, not int, for program indexes, to avoid needless 32-bit limit on 64-bit hosts. (Fccl_execute, Fccl_execute_on_string): Check that initial reg contents are in range. (Fccl_execute_on_string): Check that status is in range. * ccl.h (struct ccl_program.idx): Now ptrdiff_t, not int. * character.c (char_resolve_modifier_mask, Fchar_resolve_modifiers): Accept and return EMACS_INT, not int, because callers can pass values out of 'int' range. (c_string_width, strwidth, lisp_string_width, chars_in_text) (multibyte_chars_in_text, parse_str_as_multibyte) (str_as_multibyte, count_size_as_multibyte, str_to_multibyte) (str_as_unibyte, str_to_unibyte, string_count_byte8) (string_escape_byte8, Fget_byte): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Funibyte_string): Use CHECK_CHARACTER, not CHECK_NATNUM, to avoid mishandling large integers. * character.h: Adjust decls to match defn changes elsewhere. * charset.c (load_charset_map_from_file, find_charsets_in_text) (Ffind_charset_region): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (load_charset_map_from_file): Redo idx calculation to avoid overflow. (load_charset_map_from_vector, Fdefine_charset_internal): Don't assume fixnum fits in int or unsigned int. (load_charset_map_from_vector, Fmap_charset_chars): Remove now-unnecessary CHECK_NATNUMs. (Fdefine_charset_internal): Check ranges here, more carefully. * chartab.c (Fmake_char_table, Fset_char_table_range) (uniprop_get_decoder, uniprop_get_encoder): Don't assume fixnum fits in int. * cmds.c (move_point): New function, that does the gist of Fforward_char and Fbackward_char, but does so while checking for integer overflow more accurately. (Fforward_char, Fbackward_char, internal_self_insert): Use it. (Fforward_line, Fend_of_line, internal_self_insert) (internal_self_insert): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. Fix a FIXME, by checking for integer overflow when calculating target_clm and actual_clm. * coding.c (detect_coding_XXX, encode_coding_XXX, CODING_DECODE_CHAR) (ASSURE_DESTINATION, coding_alloc_by_realloc) (coding_alloc_by_making_gap, alloc_destination) (detect_coding_utf_8, encode_coding_utf_8, decode_coding_utf_16) (encode_coding_utf_16, detect_coding_emacs_mule) (decode_coding_emacs_mule, encode_coding_emacs_mule) (detect_coding_iso_2022, decode_coding_iso_2022) (encode_invocation_designation, encode_designation_at_bol) (encode_coding_iso_2022, detect_coding_sjis, detect_coding_big5) (decode_coding_sjis, decode_coding_big5, encode_coding_sjis) (encode_coding_big5, detect_coding_ccl, decode_coding_ccl) (encode_coding_ccl, encode_coding_raw_text) (detect_coding_charset, decode_coding_charset) (encode_coding_charset, detect_eol, decode_eol, produce_chars) (produce_composition, produce_charset, produce_annotation) (decode_coding, handle_composition_annotation) (handle_charset_annotation, consume_chars, decode_coding_gap) (decode_coding_object, encode_coding_object, detect_coding_system) (Ffind_coding_systems_region_internal, Fcheck_coding_systems_region) (code_convert_region, code_convert_string) (Fdefine_coding_system_internal): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (setup_iso_safe_charsets, consume_chars, Funencodable_char_position) (Fdefine_coding_system_internal): Don't assume fixnums fit in int. (decode_coding_gap, decode_coding_object, encode_coding_object) (Fread_coding_system, Fdetect_coding_region, Funencodable_char_position) (Fcheck_coding_systems_region): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Ffind_operation_coding_system): NATNUMP can eval its arg twice. (Fdefine_coding_system_internal): Check for charset-id overflow. * coding.h: Adjust decls to match defn changes elsewhere. (struct coding_system): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * composite.c (get_composition_id, find_composition) (run_composition_function, update_compositions) (compose_text, composition_gstring_put_cache) (composition_gstring_p, composition_gstring_width) (fill_gstring_header, fill_gstring_body, autocmp_chars) (composition_compute_stop_pos, composition_reseat_it) (composition_update_it, struct position_record) (find_automatic_composition, composition_adjust_point) (Fcomposition_get_gstring, Ffind_composition_internal): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (update_compositions): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * composite.h: Adjust decls to match defn changes elsewhere. (struct composition): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * data.c (let_shadows_buffer_binding_p, let_shadows_global_binding_p): Do not attempt to compute the address of the object just before a buffer; this is not portable. (Faref, Faset): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Faset): Use int, not EMACS_INT, where int is wide enough. (Fstring_to_number): Don't assume fixnums fit in int. (Frem): Don't assume arg is nonnegative. * dbusbind.c (xd_append_arg): Check for integers out of range. (Fdbus_call_method): Don't overflow the timeout int. * dired.c (directory_files_internal, file_name_completion, scmp) (file_name_completion_stat): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (file_name_completion): Don't overflow matchcount. (file_name_completion_stat): Use SAFE_ALLOCA, not alloca. * dispextern.h: Adjust decls to match defn changes elsewhere. (struct text_pos, struct glyph, struct bidi_saved_info) (struct bidi_string_data, struct bidi_it, struct composition_it) (struct it): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (struct display_pos, struct composition_it, struct it): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * dispnew.c (increment_matrix_positions) (increment_row_positions, mode_line_string) (marginal_area_string): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (change_frame_size_1, Fredisplay): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (duration_to_sec_usec): New function, to check for overflow better. (Fsleep_for, sit_for): Use it. * doc.c (get_doc_string, store_function_docstring): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (get_doc_string, Fsnarf_documentation): Use int, not EMACS_INT, where int is wide enough. (get_doc_string): Use SAFE_ALLOCA, not alloca. Check for overflow when converting EMACS_INT to off_t. * doprnt.c (doprnt): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * editfns.c (init_editfns, Fuser_uid, Fuser_real_uid): Don't assume uid_t fits into fixnum. (buildmark, Fgoto_char, overlays_around, find_field, Fdelete_field) (Ffield_string, Ffield_string_no_properties, Ffield_beginning) (Ffield_end, Fconstrain_to_field, Fline_beginning_position) (Fline_end_position, Fprevious_char, Fchar_after, Fchar_before) (general_insert_function) (Finsert_char, make_buffer_string, make_buffer_string_both) (update_buffer_properties, Fbuffer_substring) (Fbuffer_substring_no_properties, Fcompare_buffer_substrings) (Fsubst_char_in_region, check_translation) (Ftranslate_region_internal, save_restriction_restore, Fformat) (transpose_markers, Ftranspose_regions): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (clip_to_bounds): Move to lisp.h as an inline function). (Fconstrain_to_field): Don't assume integers are nonnegative. (Fline_beginning_position, Fsave_excursion, Fsave_current_buffer): (Fsubst_char_in_region, Fsave_restriction): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Femacs_pid): Don't assume pid_t fits into fixnum. (lo_time): Use int, not EMACS_INT, when int suffices. (lisp_time_argument): Check for usec out of range. (Fencode_time): Don't assume fixnum fits in int. * emacs.c (gdb_valbits, gdb_gctypebits): Now int, not EMACS_INT. (gdb_data_seg_bits): Now uintptr_t, not EMACS_INT. (PVEC_FLAG, gdb_array_mark_flag): Now ptrdiff_t, not EMACS_INT. (init_cmdargs, Fdump_emacs): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Fkill_emacs): Don't assume fixnum fits in int; instead, take just the bottom (typically) 32 bits of the fixnum. * eval.c (specpdl_size, call_debugger): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (when_entered_debugger, Fbacktrace_debug): Don't assume fixnum can fit in int. (Fdefvaralias, Fdefvar): Do not attempt to compute the address of the object just before a buffer; this is not portable. (FletX, Flet, Funwind_protect, do_autoload, Feval, funcall_lambda) (grow_specpdl, unbind_to): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Fapply, apply_lambda): Don't assume ptrdiff_t can hold fixnum. (grow_specpdl): Simplify allocation by using xpalloc. * fileio.c (Ffind_file_name_handler, Fcopy_file, Frename_file) (Finsert_file_contents, Fwrite_region, Fdo_auto_save): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Ffind_file_name_handler, non_regular_inserted, Finsert_file_contents) (a_write, e_write): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fcopy_file, non_regular_nbytes, read_non_regular) (Finsert_file_contents): Use int, not EMACS_INT, where int is wide enough. (READ_BUF_SIZE): Verify that it fits in int. (Finsert_file_contents): Check that counts are in proper range, rather than assuming fixnums fit into ptrdiff_t etc. Don't assume fixnums fit into int. (Fdo_auto_save, Fset_buffer_auto_saved) (Fclear_buffer_auto_save_failure): Don't assume time_t is signed, or that it fits in int. * fns.c (Fcompare_strings, Fstring_lessp, struct textprop_rec) (concat, string_char_byte_cache_charpos, string_char_byte_cache_bytepos) (string_char_to_byte, string_byte_to_char) (string_make_multibyte, string_to_multibyte) (string_make_unibyte, Fstring_as_unibyte, Fstring_as_multibyte) (Fstring_to_unibyte, Fsubstring, Fsubstring_no_properties) (substring_both, Fdelete, internal_equal, Ffillarray) (Fclear_string, mapcar1) (Fbase64_encode_region, Fbase64_encode_string, base64_encode_1) (Fbase64_decode_region, Fbase64_decode_string, base64_decode_1) (larger_vector, make_hash_table, maybe_resize_hash_table) (hash_lookup, hash_remove_from_table, hash_clear, sweep_weak_table) (Fmaphash, secure_hash): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (concat): Check for string index and length overflow. (Fmapconcat): Don't assume fixnums fit into ptrdiff_t. (Frequire): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (larger_vector): New API (vec, incr_min, size_max) replaces old one (vec, new_size, init). This catches size overflow. INIT was removed because it was always Qnil. All callers changed. (INDEX_SIZE_BOUND): New macro, which calculates more precisely the upper bound on a hash table index size. (make_hash_table, maybe_resize_hash_table): Use it. (secure_hash): Computer start_byte and end_byte only after they're known to be in ptrdiff_t range. * font.c (font_intern_prop, font_at, font_range, Ffont_shape_gstring) (Ffont_get_glyphs, Ffont_at): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (font_style_to_value, font_prop_validate_style, font_expand_wildcards) (Flist_fonts, Fopen_font): Don't assume fixnum can fit in int. (check_gstring): Don't assume index can fit in int. (font_match_p): Check that fixnum is a character, not a nonnegative fixnum, since the later code needs to stuff it into an int. (font_find_for_lface): Use SAFE_ALLOCA_LISP, not alloca. (font_fill_lglyph_metrics): Use unsigned, not EMACS_INT, to avoid conversion overflow issues. (Fopen_font): Check for integer out of range. (Ffont_get_glyphs): Don't assume index can fit in int. * font.h: Adjust decls to match defn changes elsewhere. * fontset.c (reorder_font_vector): Redo score calculation to avoid integer overflow. (num_auto_fontsets, fontset_from_font): Use ptrdiff_t, not printmax_t, where ptrdiff_t is wide enough. (Finternal_char_font): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * frame.c (Fset_mouse_position, Fset_mouse_pixel_position) (Fset_frame_height, Fset_frame_width, Fset_frame_size) (Fset_frame_position, x_set_frame_parameters) (x_set_line_spacing, x_set_border_width) (x_set_internal_border_width, x_set_alpha, x_figure_window_size): Check that fixnums are in proper range for system types. (frame_name_fnn_p, Fframe_parameter, Fmodify_frame_parameters): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fmodify_frame_parameters): Don't assume fixnum fits in int. Use SAFE_ALLOCA_LISP, not alloca. * frame.h (struct frame): Use intptr_t, not EMACS_INT, where intptr_t is wide enough. * fringe.c (lookup_fringe_bitmap, get_logical_fringe_bitmap) (Fdefine_fringe_bitmap): Don't assume fixnum fits in int. (Ffringe_bitmaps_at_pos): Don't assume index fits in int. Check for fixnum out of range. * ftfont.c (ftfont_list): Don't assume index fits in int. Check that fixnums are in proper range for system types. (ftfont_shape_by_flt): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. Remove no-longer-needed lint_assume. * gnutls.c (emacs_gnutls_write, emacs_gnutls_read): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fgnutls_error_fatalp, Fgnutls_error_string, Fgnutls_boot): Check that fixnums are in proper range for system types. * gnutls.h: Adjust decls to match defn changes elsewhere. * gtkutil.c (xg_dialog_run): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (update_frame_tool_bar): Check that fixnums are in proper range for system types. * image.c (parse_image_spec): Redo count calculation to avoid overflow. (lookup_image): Check that fixnums are in proper range for system types. * indent.c (last_known_column, last_known_column_point): (current_column_bol_cache): (skip_invisible, current_column, check_display_width): (check_display_width, scan_for_column, current_column_1) (Findent_to, Fcurrent_indentation, position_indentation) (indented_beyond_p, Fmove_to_column, compute_motion): (Fcompute_motion, Fvertical_motion): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (last_known_column_modified): Use EMACS_INT, not int. (check_display_width): (Fcompute_motion): Check that fixnums and floats are in proper range for system types. (compute_motion): Don't assume index or fixnum fits in int. (compute_motion, Fcompute_motion): Use int, not EMACS_INT, when it is wide enough. (vmotion): Omit local var start_hpos that is always 0; that way we don't need to worry about overflow in expressions involving it. * indent.h: Adjust decls to match defn changes elsewhere. (struct position): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. Use int, not EMACS_INT, where int is wide enough. Remove unused members ovstring_chars_done and tab_offset; all uses removed. * insdel.c (move_gap, move_gap_both, gap_left, gap_right) (adjust_markers_for_delete, adjust_markers_for_insert, adjust_point) (adjust_markers_for_replace, make_gap_larger, make_gap_smaller) (make_gap, copy_text, insert, insert_and_inherit) (insert_before_markers, insert_before_markers_and_inherit) (insert_1, count_combining_before, count_combining_after) (insert_1_both, insert_from_string) (insert_from_string_before_markers, insert_from_string_1) (insert_from_gap, insert_from_buffer, insert_from_buffer_1) (adjust_after_replace, adjust_after_insert, replace_range) (replace_range_2, del_range, del_range_1, del_range_byte) (del_range_both, del_range_2, modify_region) (prepare_to_modify_buffer, signal_before_change) (signal_after_change, Fcombine_after_change_execute): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * intervals.c (traverse_intervals, rotate_right, rotate_left) (balance_an_interval, split_interval_right, split_interval_left) (find_interval, next_interval, update_interval) (adjust_intervals_for_insertion, delete_node, delete_interval) (interval_deletion_adjustment, adjust_intervals_for_deletion) (static_offset_intervals, offset_intervals) (merge_interval_right, merge_interval_left, make_new_interval) (graft_intervals_into_buffer, temp_set_point_both) (temp_set_point, set_point, adjust_for_invis_intang) (set_point_both, move_if_not_intangible, get_property_and_range) (get_local_map, copy_intervals, copy_intervals_to_string) (compare_string_intervals, set_intervals_multibyte_1): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * intervals.h: Adjust decls to match defn changes elsewhere. (struct interval): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * keyboard.c (this_command_key_count, this_single_command_key_start) (before_command_key_count, before_command_echo_length, echo_now) (echo_length, recursive_edit_1, Frecursive_edit, Ftrack_mouse) (command_loop_1, safe_run_hooks, read_char, timer_check_2) (menu_item_eval_property, read_key_sequence, Fread_key_sequence) (Fread_key_sequence_vector, Fexecute_extended_command, Fsuspend_emacs): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (last_non_minibuf_size, last_point_position, echo_truncate) (command_loop_1, adjust_point_for_property, read_char, gen_help_event) (make_lispy_position, make_lispy_event, parse_modifiers_uncached) (parse_modifiers, modify_event_symbol, Fexecute_extended_command) (stuff_buffered_input): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (last_auto_save, command_loop_1, read_char): Use EMACS_INT, not int, to avoid integer overflow. (record_char): Avoid overflow in total_keys computation. (parse_modifiers_uncached): Redo index calculation to avoid overflow. * keyboard.h: Adjust decls to match defn changes elsewhere. * keymap.c (Fdefine_key, Fcurrent_active_maps, accessible_keymaps_1) (Fkey_description, Fdescribe_vector, Flookup_key): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (click_position): New function, to check that positions are in range. (Fcurrent_active_maps): (describe_command): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Faccessible_keymaps, Fkey_description): (preferred_sequence_p): Don't assume fixnum can fit into int. (Fkey_description): Use SAFE_ALLOCA_LISP, not alloca. Check for integer overflow in size calculations. (Ftext_char_description): Use CHECK_CHARACTER, not CHECK_NUMBER, to avoid mishandling large integers. * lisp.h: Adjust decls to match defn changes elsewhere. (ARRAY_MARK_FLAG, PSEUDOVECTOR_FLAG, struct Lisp_String) (struct vectorlike_header, struct Lisp_Subr, struct Lisp_Hash_Table) (struct Lisp_Marker): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (clip_to_bounds): Now an inline function, moved here from editfns.c. (XSETSUBR): Use size of 0 since the actual size doesn't matter, and using 0 avoids overflow. (GLYPH_CODE_P): Check for overflow in system types, subsuming the need for GLYPH_CODE_CHAR_VALID_P and doing proper checking ourselves. All callers changed. (GLYPH_CODE_CHAR, GLYPH_CODE_FACE): Assume the arg has valid form, since it always does. (TYPE_RANGED_INTEGERP): Avoid bug when checking against a wide unsigned integer system type. (CHECK_RANGED_INTEGER, CHECK_TYPE_RANGED_INTEGER): New macros. (struct catchtag, specpdl_size, SPECPDL_INDEX, USE_SAFE_ALLOCA): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (struct catchtag): Use EMACS_INT, not int, since it may be a fixnum. (duration_to_sec_usec): New decl. * lread.c (read_from_string_index, read_from_string_index_byte) (read_from_string_limit, readchar, unreadchar, openp) (read_internal_start, read1, oblookup): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fload, readevalloop, Feval_buffer, Feval_region): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (openp): Check for out-of-range argument to 'access'. (read1): Use int, not EMACS_INT, where int is wide enough. Don't assume fixnum fits into int. * macros.c (Fstart_kbd_macro): Use xpalloc to check for overflow in size calculation. (Fexecute_kbd_macro): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * marker.c (cached_charpos, cached_bytepos, CONSIDER) (byte_char_debug_check, buf_charpos_to_bytepos, verify_bytepos) (buf_bytepos_to_charpos, Fset_marker, set_marker_restricted) (set_marker_both, set_marker_restricted_both, marker_position) (marker_byte_position, Fbuffer_has_markers_at): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fset_marker, set_marker_restricted): Don't assume fixnum fits in int. * menu.c (ensure_menu_items): Renamed from grow_menu_items. It now merely ensures that the menu is large enough, without necessarily growing it, as this avoids some integer overflow issues. All callers changed. (keymap_panes, parse_single_submenu, Fx_popup_menu): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (parse_single_submenu, Fx_popup_menu): Don't assume fixnum fits in int. Use SAFE_ALLOCA_LISP, not alloca. (find_and_return_menu_selection): Avoid unnecessary casts of pointers to EMACS_INT. Check that fixnums are in proper range for system types. * minibuf.c (minibuf_prompt_width, string_to_object) (Fminibuffer_contents, Fminibuffer_contents_no_properties) (Fminibuffer_completion_contents, Ftry_completion, Fall_completions): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (get_minibuffer, read_minibuf_unwind): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (read_minibuf): Omit unnecessary arg BACKUP_N, which is always nil; this simplifies overflow checking. All callers changed. (read_minibuf, Fread_buffer, Ftry_completion, Fall_completions) (Ftest_completion): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * nsfns.m (check_ns_display_info): Don't assume fixnum fits in long. (x_set_menu_bar_lines, x_set_tool_bar_lines, Fx_create_frame): Check that fixnums are in proper range for system types. (Fx_create_frame, Fx_show_tip): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * nsfont.m (ns_findfonts, nsfont_list_family): Don't assume fixnum fits in long. * nsmenu.m (ns_update_menubar, ns_menu_show, ns_popup_dialog): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (ns_update_menubar): Use intptr_t, not EMACS_INT, when intptr_t is wide enough. * nsselect.m (ns_get_local_selection): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * print.c (print_buffer_size, print_buffer_pos, print_buffer_pos_byte) (PRINTDECLARE, PRINTPREPARE): (strout, print_string): (print, print_preprocess, print_check_string_charset_prop) (print_object): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (PRINTDECLARE): (temp_output_buffer_setup, Fprin1_to_string, print_object): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (PRINTPREPARE): Use int, not ptrdiff_t, where int is wide enough. (PRINTFINISH): Use SAFE_ALLOCA, not alloca. (printchar, strout): Use xpalloc to catch size calculation overflow. (Fexternal_debugging_output): Use CHECK_CHARACTER, not CHECK_NUMBER, to avoid mishandling large integers. (print_error_message): Use SAFE_ALLOCA, not alloca. (print_object): Use int, not EMACS_INT, where int is wide enough. * process.c (Fdelete_process): Don't assume pid fits into EMACS_INT. (Fset_process_window_size, Fformat_network_address) (get_lisp_to_sockaddr_size, set_socket_option, Fmake_network_process) (Fsignal_process, sigchld_handler): Check that fixnums are in proper range for system types. (Fformat_network_address, read_process_output, send_process) (Fprocess_send_region, status_notify): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fformat_network_address, Fmake_serial_process, Fmake_network_process) (wait_reading_process_output, read_process_output, exec_sentinel): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (conv_lisp_to_sockaddr): Don't assume fixnums fit into int. (Faccept_process_output): Use duration_to_sec_usec to do proper overflow checking on durations. * scroll.c (calculate_scrolling, calculate_direct_scrolling) (line_ins_del): Use int, not EMACS_INT, where int is wide enough. * search.c (looking_at_1, string_match_1): (fast_string_match, fast_c_string_match_ignore_case) (fast_string_match_ignore_case, fast_looking_at, scan_buffer) (scan_newline, find_before_next_newline, search_command) (trivial_regexp_p, search_buffer, simple_search, boyer_moore) (set_search_regs, wordify): (Freplace_match): (Fmatch_data): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (string_match_1, search_buffer, set_search_regs): (Fmatch_data): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (wordify): Check for overflow in size calculation. (Freplace_match): Avoid potential buffer overflow in search_regs.start. (Fset_match_data): Don't assume fixnum fits in ptrdiff_t. Check that fixnums are in proper range for system types. * sound.c (struct sound_device) (wav_play, au_play, vox_write, alsa_period_size, alsa_write): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fplay_sound_internal): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * syntax.c (ST_COMMENT_STYLE, ST_STRING_STYLE): In definitions, make it clearer that these values must be out of range for the respective integer ranges. This fixes a bug with ST_STRING_STYLE and non-ASCII characters. (struct lisp_parse_state, find_start_modiff) (Finternal_describe_syntax_value, scan_lists, scan_sexps_forward): (Fparse_partial_sexp): Don't assume fixnums can fit in int. (struct lisp_parse_state, find_start_pos, find_start_value) (find_start_value_byte, find_start_begv) (update_syntax_table, char_quoted, dec_bytepos) (find_defun_start, prev_char_comend_first, back_comment): (scan_words, skip_chars, skip_syntaxes, forw_comment, Fforward_comment) (scan_lists, Fbackward_prefix_chars, scan_sexps_forward): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Finternal_describe_syntax_value): Check that match_lisp is a character, not an integer, since the code stuffs it into int. (scan_words, scan_sexps_forward): Check that fixnums are in proper range for system types. (Fforward_word): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (scan_sexps_forward): Use CHARACTERP, not INTEGERP, since the value must fit into int. (Fparse_partial_sexp): Fix doc; element 8 is not ignored. * syntax.h: Adjust decls to match defn changes elsewhere. (struct gl_state_s): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * sysdep.c (wait_for_termination_1, wait_for_termination) (interruptible_wait_for_termination, mkdir): Don't assume pid_t fits in int; on 64-bit AIX pid_t is 64-bit. (emacs_read, emacs_write): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (system_process_attributes): Don't assume uid_t, gid_t, and double all fit in int or even EMACS_INT. * term.c (set_tty_color_mode): Check that fixnums are in proper range for system types. * termhooks.h (struct input_event): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * textprop.c (validate_interval_range, interval_of) (Fadd_text_properties, set_text_properties_1) (Fremove_text_properties, Fremove_list_of_text_properties) (Ftext_property_any, Ftext_property_not_all) (copy_text_properties, text_property_list, extend_property_ranges) (verify_interval_modification): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fnext_single_char_property_change) (Fprevious_single_char_property_change): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (copy_text_properties): Check for integer overflow in index calculation. * undo.c (last_boundary_position, record_point, record_insert) (record_delete, record_marker_adjustment, record_change) (record_property_change): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (truncate_undo_list, Fprimitive_undo): Don't assume fixnum fits in int. Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * w32fns.c (Fx_create_frame, x_create_tip_frame, Fx_show_tip) (Fx_hide_tip, Fx_file_dialog): * w32menu.c (set_frame_menubar): Use ptrdiff_t, not int, for consistency with rest of code. * window.c (window_scroll_preserve_hpos, window_scroll_preserve_vpos) (select_window, Fdelete_other_windows_internal) (window_scroll_pixel_based, window_scroll_line_based) (Frecenter, Fset_window_configuration): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (Fset_window_hscroll, run_window_configuration_change_hook) (set_window_buffer, temp_output_buffer_show, scroll_command) (Fscroll_other_window): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Fwindow_line_height, window_scroll, Fscroll_left, Fscroll_right): Don't assume fixnum fits in int. (Fset_window_scroll_bars): Check that fixnums are in proper range for system types. * xdisp.c (help_echo_pos, pos_visible_p, string_pos_nchars_ahead) (string_pos, c_string_pos, number_of_chars, init_iterator) (in_ellipses_for_invisible_text_p, init_from_display_pos) (compute_stop_pos, next_overlay_change, compute_display_string_pos) (compute_display_string_end, handle_face_prop) (face_before_or_after_it_pos, handle_invisible_prop, handle_display_prop) (handle_display_spec, handle_single_display_spec) (display_prop_intangible_p, string_buffer_position_lim) (string_buffer_position, handle_composition_prop, load_overlay_strings) (get_overlay_strings_1, get_overlay_strings) (iterate_out_of_display_property, forward_to_next_line_start) (back_to_previous_visible_line_start, reseat, reseat_to_string) (get_next_display_element, set_iterator_to_next) (get_visually_first_element, compute_stop_pos_backwards) (handle_stop_backwards, next_element_from_buffer) (move_it_in_display_line_to, move_it_in_display_line) (move_it_to, move_it_vertically_backward, move_it_by_lines) (add_to_log, message_dolog, message_log_check_duplicate) (message2, message2_nolog, message3, message3_nolog (with_echo_area_buffer, display_echo_area_1, resize_mini_window_1) (current_message_1, truncate_echo_area, truncate_message_1) (set_message, set_message_1, store_mode_line_noprop) (hscroll_window_tree, debug_delta, debug_delta_bytes, debug_end_vpos) (text_outside_line_unchanged_p, check_point_in_composition) (reconsider_clip_changes) (redisplay_internal, set_cursor_from_row, try_scrolling) (try_cursor_movement, set_vertical_scroll_bar, redisplay_window) (redisplay_window, find_last_unchanged_at_beg_row) (find_first_unchanged_at_end_row, row_containing_pos, try_window_id) (trailing_whitespace_p, find_row_edges, display_line) (RECORD_MAX_MIN_POS, Fcurrent_bidi_paragraph_direction) (display_mode_element, store_mode_line_string) (pint2str, pint2hrstr, decode_mode_spec) (display_count_lines, display_string, draw_glyphs) (x_produce_glyphs, x_insert_glyphs) (rows_from_pos_range, mouse_face_from_buffer_pos) (fast_find_string_pos, mouse_face_from_string_pos) (note_mode_line_or_margin_highlight, note_mouse_highlight): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (safe_call, init_from_display_pos, handle_fontified_prop) (handle_single_display_spec, load_overlay_strings) (with_echo_area_buffer, setup_echo_area_for_printing) (display_echo_area, echo_area_display) (x_consider_frame_title, prepare_menu_bars, update_menu_bar) (update_tool_bar, hscroll_window_tree, redisplay_internal) (redisplay_window, dump_glyph_row, display_mode_line, Fformat_mode_line) (decode_mode_spec, on_hot_spot_p): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (handle_single_display_spec, build_desired_tool_bar_string) (redisplay_tool_bar, scroll_window_tree, Fdump_glyph_matrix) (get_specified_cursor_type): Check that fixnums are in proper range for system types. (struct overlay_entry, resize_mini_window, Fdump_glyph_row) (Flookup_image_map): Don't assume fixnums fit in int. (compare_overlay_entries): Avoid mishandling comparisons due to subtraction overflow. (load_overlay_strings): Use SAFE_NALLOCA, not alloca. (last_escape_glyph_face_id, last_glyphless_glyph_face_id): (handle_tool_bar_click): Use int, not unsigned, since we prefer signed and the signedness doesn't matter here. (get_next_display_element, next_element_from_display_vector): Use int, not EMACS_INT, when int is wide enough. (start_hourglass): Use duration_to_sec_usec to do proper overflow checking on durations. * xfaces.c (Fbitmap_spec_p): Check that fixnums are in proper range for system types. (compare_fonts_by_sort_order): Avoid mishandling comparisons due to subtraction overflow. (Fx_family_fonts, realize_basic_faces): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Fx_family_fonts): Don't assume fixnum fits in int. Use SAFE_ALLOCA_LISP, not alloca. (merge_face_heights): Remove unnecessary cast to EMACS_INT. (Finternal_make_lisp_face): Don't allocate more than MAX_FACE_ID. (face_at_buffer_position, face_for_overlay_string) (face_at_string_position): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. (merge_faces): Use int, not EMACS_INT, where int is wide enough. * xfns.c (x_set_menu_bar_lines, x_set_tool_bar_lines, x_icon_verify) (Fx_show_tip): Check that fixnums are in proper range for system types. (Fx_create_frame, x_create_tip_frame, Fx_show_tip) (Fx_hide_tip, Fx_file_dialog, Fx_select_font): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (Fx_change_window_property): Don't assume fixnums fit in int. * xfont.c (xfont_chars_supported): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * xmenu.c (Fx_popup_dialog, set_frame_menubar) (create_and_show_popup_menu, create_and_show_dialog, xmenu_show): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * xml.c (parse_region): * xrdb.c (magic_file_p): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough. * xselect.c (TRACE1): Don't assume pid_t promotes to int. (x_get_local_selection, x_reply_selection_request) (x_handle_selection_request, wait_for_property_change): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. (selection_data_to_lisp_data): Use short, not EMACS_INT, where short is wide enough. (x_send_client_event): Don't assume fixnum fits in int. * xterm.c (x_x_to_emacs_modifiers): Don't assume EMACS_INT overflows nicely into int. (x_emacs_to_x_modifiers): Use EMACS_INT, not int, because values may come from Lisp. (handle_one_xevent): NATNUMP can eval its arg twice. (x_connection_closed): Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts. * xterm.h: Adjust decls to match defn changes elsewhere. (struct scroll_bar): Use struct vectorlike_header rather than rolling our own approximation. (SCROLL_BAR_VEC_SIZE): Remove; not used.
Diffstat (limited to 'src/indent.c')
-rw-r--r--src/indent.c196
1 files changed, 98 insertions, 98 deletions
diff --git a/src/indent.c b/src/indent.c
index e00d2152577..96b6ea4fa18 100644
--- a/src/indent.c
+++ b/src/indent.c
@@ -45,23 +45,23 @@ along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
45 Some things in set last_known_column_point to -1 45 Some things in set last_known_column_point to -1
46 to mark the memorized value as invalid. */ 46 to mark the memorized value as invalid. */
47 47
48static EMACS_INT last_known_column; 48static ptrdiff_t last_known_column;
49 49
50/* Value of point when current_column was called. */ 50/* Value of point when current_column was called. */
51 51
52EMACS_INT last_known_column_point; 52ptrdiff_t last_known_column_point;
53 53
54/* Value of MODIFF when current_column was called. */ 54/* Value of MODIFF when current_column was called. */
55 55
56static int last_known_column_modified; 56static EMACS_INT last_known_column_modified;
57 57
58static EMACS_INT current_column_1 (void); 58static ptrdiff_t current_column_1 (void);
59static EMACS_INT position_indentation (ptrdiff_t); 59static ptrdiff_t position_indentation (ptrdiff_t);
60 60
61/* Cache of beginning of line found by the last call of 61/* Cache of beginning of line found by the last call of
62 current_column. */ 62 current_column. */
63 63
64static EMACS_INT current_column_bol_cache; 64static ptrdiff_t current_column_bol_cache;
65 65
66/* Get the display table to use for the current buffer. */ 66/* Get the display table to use for the current buffer. */
67 67
@@ -204,12 +204,12 @@ width_run_cache_on_off (void)
204 characters immediately following, then *NEXT_BOUNDARY_P 204 characters immediately following, then *NEXT_BOUNDARY_P
205 will equal the return value. */ 205 will equal the return value. */
206 206
207EMACS_INT 207ptrdiff_t
208skip_invisible (EMACS_INT pos, EMACS_INT *next_boundary_p, EMACS_INT to, Lisp_Object window) 208skip_invisible (ptrdiff_t pos, ptrdiff_t *next_boundary_p, ptrdiff_t to, Lisp_Object window)
209{ 209{
210 Lisp_Object prop, position, overlay_limit, proplimit; 210 Lisp_Object prop, position, overlay_limit, proplimit;
211 Lisp_Object buffer, tmp; 211 Lisp_Object buffer, tmp;
212 EMACS_INT end; 212 ptrdiff_t end;
213 int inv_p; 213 int inv_p;
214 214
215 XSETFASTINT (position, pos); 215 XSETFASTINT (position, pos);
@@ -318,13 +318,13 @@ invalidate_current_column (void)
318 last_known_column_point = 0; 318 last_known_column_point = 0;
319} 319}
320 320
321EMACS_INT 321ptrdiff_t
322current_column (void) 322current_column (void)
323{ 323{
324 register EMACS_INT col; 324 register ptrdiff_t col;
325 register unsigned char *ptr, *stop; 325 register unsigned char *ptr, *stop;
326 register int tab_seen; 326 register int tab_seen;
327 EMACS_INT post_tab; 327 ptrdiff_t post_tab;
328 register int c; 328 register int c;
329 int tab_width = SANE_TAB_WIDTH (current_buffer); 329 int tab_width = SANE_TAB_WIDTH (current_buffer);
330 int ctl_arrow = !NILP (BVAR (current_buffer, ctl_arrow)); 330 int ctl_arrow = !NILP (BVAR (current_buffer, ctl_arrow));
@@ -360,7 +360,7 @@ current_column (void)
360 360
361 while (1) 361 while (1)
362 { 362 {
363 EMACS_INT i, n; 363 ptrdiff_t i, n;
364 Lisp_Object charvec; 364 Lisp_Object charvec;
365 365
366 if (ptr == stop) 366 if (ptr == stop)
@@ -400,8 +400,7 @@ current_column (void)
400 next_element_from_display_vector does it. */ 400 next_element_from_display_vector does it. */
401 Lisp_Object entry = AREF (charvec, i); 401 Lisp_Object entry = AREF (charvec, i);
402 402
403 if (GLYPH_CODE_P (entry) 403 if (GLYPH_CODE_P (entry))
404 && GLYPH_CODE_CHAR_VALID_P (entry))
405 c = GLYPH_CODE_CHAR (entry); 404 c = GLYPH_CODE_CHAR (entry);
406 else 405 else
407 c = ' '; 406 c = ' ';
@@ -464,7 +463,7 @@ current_column (void)
464 in ENDPOS. 463 in ENDPOS.
465 Otherwise just return -1. */ 464 Otherwise just return -1. */
466static int 465static int
467check_display_width (EMACS_INT pos, EMACS_INT col, EMACS_INT *endpos) 466check_display_width (ptrdiff_t pos, ptrdiff_t col, ptrdiff_t *endpos)
468{ 467{
469 Lisp_Object val, overlay; 468 Lisp_Object val, overlay;
470 469
@@ -474,19 +473,27 @@ check_display_width (EMACS_INT pos, EMACS_INT col, EMACS_INT *endpos)
474 { /* FIXME: Use calc_pixel_width_or_height. */ 473 { /* FIXME: Use calc_pixel_width_or_height. */
475 Lisp_Object plist = XCDR (val), prop; 474 Lisp_Object plist = XCDR (val), prop;
476 int width = -1; 475 int width = -1;
476 EMACS_INT align_to_max =
477 (col < MOST_POSITIVE_FIXNUM - INT_MAX
478 ? (EMACS_INT) INT_MAX + col
479 : MOST_POSITIVE_FIXNUM);
477 480
478 if ((prop = Fplist_get (plist, QCwidth), NATNUMP (prop))) 481 if ((prop = Fplist_get (plist, QCwidth),
482 RANGED_INTEGERP (0, prop, INT_MAX)))
479 width = XINT (prop); 483 width = XINT (prop);
480 else if (FLOATP (prop)) 484 else if (FLOATP (prop) && 0 <= XFLOAT_DATA (prop)
485 && XFLOAT_DATA (prop) <= INT_MAX)
481 width = (int)(XFLOAT_DATA (prop) + 0.5); 486 width = (int)(XFLOAT_DATA (prop) + 0.5);
482 else if ((prop = Fplist_get (plist, QCalign_to), NATNUMP (prop))) 487 else if ((prop = Fplist_get (plist, QCalign_to),
488 RANGED_INTEGERP (col, prop, align_to_max)))
483 width = XINT (prop) - col; 489 width = XINT (prop) - col;
484 else if (FLOATP (prop)) 490 else if (FLOATP (prop) && col <= XFLOAT_DATA (prop)
491 && (XFLOAT_DATA (prop) <= align_to_max))
485 width = (int)(XFLOAT_DATA (prop) + 0.5) - col; 492 width = (int)(XFLOAT_DATA (prop) + 0.5) - col;
486 493
487 if (width >= 0) 494 if (width >= 0)
488 { 495 {
489 EMACS_INT start; 496 ptrdiff_t start;
490 if (OVERLAYP (overlay)) 497 if (OVERLAYP (overlay))
491 *endpos = OVERLAY_POSITION (OVERLAY_END (overlay)); 498 *endpos = OVERLAY_POSITION (OVERLAY_END (overlay));
492 else 499 else
@@ -504,7 +511,7 @@ check_display_width (EMACS_INT pos, EMACS_INT col, EMACS_INT *endpos)
504 PREVCOL gets set to the column of the previous position (it's always 511 PREVCOL gets set to the column of the previous position (it's always
505 strictly smaller than the goal column). */ 512 strictly smaller than the goal column). */
506static void 513static void
507scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol) 514scan_for_column (ptrdiff_t *endpos, EMACS_INT *goalcol, ptrdiff_t *prevcol)
508{ 515{
509 int tab_width = SANE_TAB_WIDTH (current_buffer); 516 int tab_width = SANE_TAB_WIDTH (current_buffer);
510 register int ctl_arrow = !NILP (BVAR (current_buffer, ctl_arrow)); 517 register int ctl_arrow = !NILP (BVAR (current_buffer, ctl_arrow));
@@ -515,13 +522,13 @@ scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol)
515 struct window *w; 522 struct window *w;
516 523
517 /* Start the scan at the beginning of this line with column number 0. */ 524 /* Start the scan at the beginning of this line with column number 0. */
518 register EMACS_INT col = 0, prev_col = 0; 525 register ptrdiff_t col = 0, prev_col = 0;
519 EMACS_INT goal = goalcol ? *goalcol : MOST_POSITIVE_FIXNUM; 526 EMACS_INT goal = goalcol ? *goalcol : MOST_POSITIVE_FIXNUM;
520 EMACS_INT end = endpos ? *endpos : PT; 527 ptrdiff_t end = endpos ? *endpos : PT;
521 EMACS_INT scan, scan_byte; 528 ptrdiff_t scan, scan_byte;
522 EMACS_INT next_boundary; 529 ptrdiff_t next_boundary;
523 { 530 {
524 EMACS_INT opoint = PT, opoint_byte = PT_BYTE; 531 ptrdiff_t opoint = PT, opoint_byte = PT_BYTE;
525 scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, -1, 1); 532 scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, -1, 1);
526 current_column_bol_cache = PT; 533 current_column_bol_cache = PT;
527 scan = PT, scan_byte = PT_BYTE; 534 scan = PT, scan_byte = PT_BYTE;
@@ -544,7 +551,7 @@ scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol)
544 /* Occasionally we may need to skip invisible text. */ 551 /* Occasionally we may need to skip invisible text. */
545 while (scan == next_boundary) 552 while (scan == next_boundary)
546 { 553 {
547 EMACS_INT old_scan = scan; 554 ptrdiff_t old_scan = scan;
548 /* This updates NEXT_BOUNDARY to the next place 555 /* This updates NEXT_BOUNDARY to the next place
549 where we might need to skip more invisible text. */ 556 where we might need to skip more invisible text. */
550 scan = skip_invisible (scan, &next_boundary, end, Qnil); 557 scan = skip_invisible (scan, &next_boundary, end, Qnil);
@@ -562,7 +569,7 @@ scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol)
562 prev_col = col; 569 prev_col = col;
563 570
564 { /* Check display property. */ 571 { /* Check display property. */
565 EMACS_INT endp; 572 ptrdiff_t endp;
566 int width = check_display_width (scan, col, &endp); 573 int width = check_display_width (scan, col, &endp);
567 if (width >= 0) 574 if (width >= 0)
568 { 575 {
@@ -608,7 +615,7 @@ scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol)
608 && VECTORP (DISP_CHAR_VECTOR (dp, c))) 615 && VECTORP (DISP_CHAR_VECTOR (dp, c)))
609 { 616 {
610 Lisp_Object charvec; 617 Lisp_Object charvec;
611 EMACS_INT i, n; 618 ptrdiff_t i, n;
612 619
613 /* This character is displayed using a vector of glyphs. 620 /* This character is displayed using a vector of glyphs.
614 Update the column/position based on those glyphs. */ 621 Update the column/position based on those glyphs. */
@@ -622,8 +629,7 @@ scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol)
622 next_element_from_display_vector does it. */ 629 next_element_from_display_vector does it. */
623 Lisp_Object entry = AREF (charvec, i); 630 Lisp_Object entry = AREF (charvec, i);
624 631
625 if (GLYPH_CODE_P (entry) 632 if (GLYPH_CODE_P (entry))
626 && GLYPH_CODE_CHAR_VALID_P (entry))
627 c = GLYPH_CODE_CHAR (entry); 633 c = GLYPH_CODE_CHAR (entry);
628 else 634 else
629 c = ' '; 635 c = ' ';
@@ -698,11 +704,11 @@ scan_for_column (EMACS_INT *endpos, EMACS_INT *goalcol, EMACS_INT *prevcol)
698 This function handles characters that are invisible 704 This function handles characters that are invisible
699 due to text properties or overlays. */ 705 due to text properties or overlays. */
700 706
701static EMACS_INT 707static ptrdiff_t
702current_column_1 (void) 708current_column_1 (void)
703{ 709{
704 EMACS_INT col = MOST_POSITIVE_FIXNUM; 710 EMACS_INT col = MOST_POSITIVE_FIXNUM;
705 EMACS_INT opoint = PT; 711 ptrdiff_t opoint = PT;
706 712
707 scan_for_column (&opoint, &col, NULL); 713 scan_for_column (&opoint, &col, NULL);
708 return col; 714 return col;
@@ -798,7 +804,7 @@ The return value is COLUMN. */)
798 (Lisp_Object column, Lisp_Object minimum) 804 (Lisp_Object column, Lisp_Object minimum)
799{ 805{
800 EMACS_INT mincol; 806 EMACS_INT mincol;
801 register EMACS_INT fromcol; 807 register ptrdiff_t fromcol;
802 int tab_width = SANE_TAB_WIDTH (current_buffer); 808 int tab_width = SANE_TAB_WIDTH (current_buffer);
803 809
804 CHECK_NUMBER (column); 810 CHECK_NUMBER (column);
@@ -845,7 +851,7 @@ following any initial whitespace. */)
845 (void) 851 (void)
846{ 852{
847 Lisp_Object val; 853 Lisp_Object val;
848 EMACS_INT opoint = PT, opoint_byte = PT_BYTE; 854 ptrdiff_t opoint = PT, opoint_byte = PT_BYTE;
849 855
850 scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, -1, 1); 856 scan_newline (PT, PT_BYTE, BEGV, BEGV_BYTE, -1, 1);
851 857
@@ -854,16 +860,16 @@ following any initial whitespace. */)
854 return val; 860 return val;
855} 861}
856 862
857static EMACS_INT 863static ptrdiff_t
858position_indentation (ptrdiff_t pos_byte) 864position_indentation (ptrdiff_t pos_byte)
859{ 865{
860 register EMACS_INT column = 0; 866 register ptrdiff_t column = 0;
861 int tab_width = SANE_TAB_WIDTH (current_buffer); 867 int tab_width = SANE_TAB_WIDTH (current_buffer);
862 register unsigned char *p; 868 register unsigned char *p;
863 register unsigned char *stop; 869 register unsigned char *stop;
864 unsigned char *start; 870 unsigned char *start;
865 EMACS_INT next_boundary_byte = pos_byte; 871 ptrdiff_t next_boundary_byte = pos_byte;
866 EMACS_INT ceiling = next_boundary_byte; 872 ptrdiff_t ceiling = next_boundary_byte;
867 873
868 p = BYTE_POS_ADDR (pos_byte); 874 p = BYTE_POS_ADDR (pos_byte);
869 /* STOP records the value of P at which we will need 875 /* STOP records the value of P at which we will need
@@ -876,7 +882,7 @@ position_indentation (ptrdiff_t pos_byte)
876 { 882 {
877 while (p == stop) 883 while (p == stop)
878 { 884 {
879 EMACS_INT stop_pos_byte; 885 ptrdiff_t stop_pos_byte;
880 886
881 /* If we have updated P, set POS_BYTE to match. 887 /* If we have updated P, set POS_BYTE to match.
882 The first time we enter the loop, POS_BYTE is already right. */ 888 The first time we enter the loop, POS_BYTE is already right. */
@@ -887,8 +893,8 @@ position_indentation (ptrdiff_t pos_byte)
887 return column; 893 return column;
888 if (pos_byte == next_boundary_byte) 894 if (pos_byte == next_boundary_byte)
889 { 895 {
890 EMACS_INT next_boundary; 896 ptrdiff_t next_boundary;
891 EMACS_INT pos = BYTE_TO_CHAR (pos_byte); 897 ptrdiff_t pos = BYTE_TO_CHAR (pos_byte);
892 pos = skip_invisible (pos, &next_boundary, ZV, Qnil); 898 pos = skip_invisible (pos, &next_boundary, ZV, Qnil);
893 pos_byte = CHAR_TO_BYTE (pos); 899 pos_byte = CHAR_TO_BYTE (pos);
894 next_boundary_byte = CHAR_TO_BYTE (next_boundary); 900 next_boundary_byte = CHAR_TO_BYTE (next_boundary);
@@ -942,10 +948,10 @@ position_indentation (ptrdiff_t pos_byte)
942 preceding line. */ 948 preceding line. */
943 949
944int 950int
945indented_beyond_p (EMACS_INT pos, EMACS_INT pos_byte, EMACS_INT column) 951indented_beyond_p (ptrdiff_t pos, ptrdiff_t pos_byte, EMACS_INT column)
946{ 952{
947 EMACS_INT val; 953 ptrdiff_t val;
948 EMACS_INT opoint = PT, opoint_byte = PT_BYTE; 954 ptrdiff_t opoint = PT, opoint_byte = PT_BYTE;
949 955
950 SET_PT_BOTH (pos, pos_byte); 956 SET_PT_BOTH (pos, pos_byte);
951 while (PT > BEGV && FETCH_BYTE (PT_BYTE) == '\n') 957 while (PT > BEGV && FETCH_BYTE (PT_BYTE) == '\n')
@@ -976,8 +982,8 @@ COLUMN, add spaces/tabs to get there.
976The return value is the current column. */) 982The return value is the current column. */)
977 (Lisp_Object column, Lisp_Object force) 983 (Lisp_Object column, Lisp_Object force)
978{ 984{
979 EMACS_INT pos; 985 ptrdiff_t pos, prev_col;
980 EMACS_INT col, prev_col; 986 EMACS_INT col;
981 EMACS_INT goal; 987 EMACS_INT goal;
982 988
983 CHECK_NATNUM (column); 989 CHECK_NATNUM (column);
@@ -994,13 +1000,13 @@ The return value is the current column. */)
994 if (!NILP (force) && col > goal) 1000 if (!NILP (force) && col > goal)
995 { 1001 {
996 int c; 1002 int c;
997 EMACS_INT pos_byte = PT_BYTE; 1003 ptrdiff_t pos_byte = PT_BYTE;
998 1004
999 DEC_POS (pos_byte); 1005 DEC_POS (pos_byte);
1000 c = FETCH_CHAR (pos_byte); 1006 c = FETCH_CHAR (pos_byte);
1001 if (c == '\t' && prev_col < goal) 1007 if (c == '\t' && prev_col < goal)
1002 { 1008 {
1003 EMACS_INT goal_pt, goal_pt_byte; 1009 ptrdiff_t goal_pt, goal_pt_byte;
1004 1010
1005 /* Insert spaces in front of the tab to reach GOAL. Do this 1011 /* Insert spaces in front of the tab to reach GOAL. Do this
1006 first so that a marker at the end of the tab gets 1012 first so that a marker at the end of the tab gets
@@ -1099,13 +1105,13 @@ static struct position val_compute_motion;
1099 the scroll bars if they are turned on. */ 1105 the scroll bars if they are turned on. */
1100 1106
1101struct position * 1107struct position *
1102compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_motion, EMACS_INT to, EMACS_INT tovpos, EMACS_INT tohpos, EMACS_INT width, EMACS_INT hscroll, EMACS_INT tab_offset, struct window *win) 1108compute_motion (ptrdiff_t from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_motion, ptrdiff_t to, EMACS_INT tovpos, EMACS_INT tohpos, EMACS_INT width, ptrdiff_t hscroll, int tab_offset, struct window *win)
1103{ 1109{
1104 register EMACS_INT hpos = fromhpos; 1110 register EMACS_INT hpos = fromhpos;
1105 register EMACS_INT vpos = fromvpos; 1111 register EMACS_INT vpos = fromvpos;
1106 1112
1107 register EMACS_INT pos; 1113 register ptrdiff_t pos;
1108 EMACS_INT pos_byte; 1114 ptrdiff_t pos_byte;
1109 register int c = 0; 1115 register int c = 0;
1110 int tab_width = SANE_TAB_WIDTH (current_buffer); 1116 int tab_width = SANE_TAB_WIDTH (current_buffer);
1111 register int ctl_arrow = !NILP (BVAR (current_buffer, ctl_arrow)); 1117 register int ctl_arrow = !NILP (BVAR (current_buffer, ctl_arrow));
@@ -1114,38 +1120,38 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1114 = (INTEGERP (BVAR (current_buffer, selective_display)) 1120 = (INTEGERP (BVAR (current_buffer, selective_display))
1115 ? XINT (BVAR (current_buffer, selective_display)) 1121 ? XINT (BVAR (current_buffer, selective_display))
1116 : !NILP (BVAR (current_buffer, selective_display)) ? -1 : 0); 1122 : !NILP (BVAR (current_buffer, selective_display)) ? -1 : 0);
1117 int selective_rlen 1123 ptrdiff_t selective_rlen
1118 = (selective && dp && VECTORP (DISP_INVIS_VECTOR (dp)) 1124 = (selective && dp && VECTORP (DISP_INVIS_VECTOR (dp))
1119 ? ASIZE (DISP_INVIS_VECTOR (dp)) : 0); 1125 ? ASIZE (DISP_INVIS_VECTOR (dp)) : 0);
1120 /* The next location where the `invisible' property changes, or an 1126 /* The next location where the `invisible' property changes, or an
1121 overlay starts or ends. */ 1127 overlay starts or ends. */
1122 EMACS_INT next_boundary = from; 1128 ptrdiff_t next_boundary = from;
1123 1129
1124 /* For computing runs of characters with similar widths. 1130 /* For computing runs of characters with similar widths.
1125 Invariant: width_run_width is zero, or all the characters 1131 Invariant: width_run_width is zero, or all the characters
1126 from width_run_start to width_run_end have a fixed width of 1132 from width_run_start to width_run_end have a fixed width of
1127 width_run_width. */ 1133 width_run_width. */
1128 EMACS_INT width_run_start = from; 1134 ptrdiff_t width_run_start = from;
1129 EMACS_INT width_run_end = from; 1135 ptrdiff_t width_run_end = from;
1130 EMACS_INT width_run_width = 0; 1136 ptrdiff_t width_run_width = 0;
1131 Lisp_Object *width_table; 1137 Lisp_Object *width_table;
1132 Lisp_Object buffer; 1138 Lisp_Object buffer;
1133 1139
1134 /* The next buffer pos where we should consult the width run cache. */ 1140 /* The next buffer pos where we should consult the width run cache. */
1135 EMACS_INT next_width_run = from; 1141 ptrdiff_t next_width_run = from;
1136 Lisp_Object window; 1142 Lisp_Object window;
1137 1143
1138 int multibyte = !NILP (BVAR (current_buffer, enable_multibyte_characters)); 1144 int multibyte = !NILP (BVAR (current_buffer, enable_multibyte_characters));
1139 /* If previous char scanned was a wide character, 1145 /* If previous char scanned was a wide character,
1140 this is the column where it ended. Otherwise, this is 0. */ 1146 this is the column where it ended. Otherwise, this is 0. */
1141 EMACS_INT wide_column_end_hpos = 0; 1147 EMACS_INT wide_column_end_hpos = 0;
1142 EMACS_INT prev_pos; /* Previous buffer position. */ 1148 ptrdiff_t prev_pos; /* Previous buffer position. */
1143 EMACS_INT prev_pos_byte; /* Previous buffer position. */ 1149 ptrdiff_t prev_pos_byte; /* Previous buffer position. */
1144 EMACS_INT prev_hpos = 0; 1150 EMACS_INT prev_hpos = 0;
1145 EMACS_INT prev_vpos = 0; 1151 EMACS_INT prev_vpos = 0;
1146 EMACS_INT contin_hpos; /* HPOS of last column of continued line. */ 1152 EMACS_INT contin_hpos; /* HPOS of last column of continued line. */
1147 EMACS_INT prev_tab_offset; /* Previous tab offset. */ 1153 int prev_tab_offset; /* Previous tab offset. */
1148 EMACS_INT continuation_glyph_width; 1154 int continuation_glyph_width;
1149 1155
1150 struct composition_it cmp_it; 1156 struct composition_it cmp_it;
1151 1157
@@ -1194,8 +1200,8 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1194 { 1200 {
1195 while (pos == next_boundary) 1201 while (pos == next_boundary)
1196 { 1202 {
1197 EMACS_INT pos_here = pos; 1203 ptrdiff_t pos_here = pos;
1198 EMACS_INT newpos; 1204 ptrdiff_t newpos;
1199 1205
1200 /* Don't skip invisible if we are already at the margin. */ 1206 /* Don't skip invisible if we are already at the margin. */
1201 if (vpos > tovpos || (vpos == tovpos && hpos >= tohpos)) 1207 if (vpos > tovpos || (vpos == tovpos && hpos >= tohpos))
@@ -1229,7 +1235,7 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1229 to be changed here. */ 1235 to be changed here. */
1230 { 1236 {
1231 unsigned char *ovstr; 1237 unsigned char *ovstr;
1232 EMACS_INT ovlen = overlay_strings (pos, win, &ovstr); 1238 ptrdiff_t ovlen = overlay_strings (pos, win, &ovstr);
1233 hpos += ((multibyte && ovlen > 0) 1239 hpos += ((multibyte && ovlen > 0)
1234 ? strwidth ((char *) ovstr, ovlen) : ovlen); 1240 ? strwidth ((char *) ovstr, ovlen) : ovlen);
1235 } 1241 }
@@ -1304,7 +1310,7 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1304 1310
1305 if (hpos > width) 1311 if (hpos > width)
1306 { 1312 {
1307 int total_width = width + continuation_glyph_width; 1313 EMACS_INT total_width = width + continuation_glyph_width;
1308 int truncate = 0; 1314 int truncate = 0;
1309 1315
1310 if (!NILP (Vtruncate_partial_width_windows) 1316 if (!NILP (Vtruncate_partial_width_windows)
@@ -1434,7 +1440,7 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1434 want to skip over it for some other reason. */ 1440 want to skip over it for some other reason. */
1435 if (common_width != 0) 1441 if (common_width != 0)
1436 { 1442 {
1437 EMACS_INT run_end_hpos; 1443 ptrdiff_t run_end_hpos;
1438 1444
1439 /* Don't go past the final buffer posn the user 1445 /* Don't go past the final buffer posn the user
1440 requested. */ 1446 requested. */
@@ -1474,7 +1480,7 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1474 /* We have to scan the text character-by-character. */ 1480 /* We have to scan the text character-by-character. */
1475 else 1481 else
1476 { 1482 {
1477 EMACS_INT i, n; 1483 ptrdiff_t i, n;
1478 Lisp_Object charvec; 1484 Lisp_Object charvec;
1479 1485
1480 /* Check composition sequence. */ 1486 /* Check composition sequence. */
@@ -1551,8 +1557,7 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1551 next_element_from_display_vector does it. */ 1557 next_element_from_display_vector does it. */
1552 Lisp_Object entry = AREF (charvec, i); 1558 Lisp_Object entry = AREF (charvec, i);
1553 1559
1554 if (GLYPH_CODE_P (entry) 1560 if (GLYPH_CODE_P (entry))
1555 && GLYPH_CODE_CHAR_VALID_P (entry))
1556 c = GLYPH_CODE_CHAR (entry); 1561 c = GLYPH_CODE_CHAR (entry);
1557 else 1562 else
1558 c = ' '; 1563 c = ' ';
@@ -1675,8 +1680,6 @@ compute_motion (EMACS_INT from, EMACS_INT fromvpos, EMACS_INT fromhpos, int did_
1675 val_compute_motion.prevhpos = contin_hpos; 1680 val_compute_motion.prevhpos = contin_hpos;
1676 else 1681 else
1677 val_compute_motion.prevhpos = prev_hpos; 1682 val_compute_motion.prevhpos = prev_hpos;
1678 /* We alalways handle all of them here; none of them remain to do. */
1679 val_compute_motion.ovstring_chars_done = 0;
1680 1683
1681 /* Nonzero if have just continued a line */ 1684 /* Nonzero if have just continued a line */
1682 val_compute_motion.contin = (contin_hpos && prev_hpos == 0); 1685 val_compute_motion.contin = (contin_hpos && prev_hpos == 0);
@@ -1733,7 +1736,8 @@ visible section of the buffer, and pass LINE and COL as TOPOS. */)
1733 struct window *w; 1736 struct window *w;
1734 Lisp_Object bufpos, hpos, vpos, prevhpos; 1737 Lisp_Object bufpos, hpos, vpos, prevhpos;
1735 struct position *pos; 1738 struct position *pos;
1736 EMACS_INT hscroll, tab_offset; 1739 ptrdiff_t hscroll;
1740 int tab_offset;
1737 1741
1738 CHECK_NUMBER_COERCE_MARKER (from); 1742 CHECK_NUMBER_COERCE_MARKER (from);
1739 CHECK_CONS (frompos); 1743 CHECK_CONS (frompos);
@@ -1754,6 +1758,9 @@ visible section of the buffer, and pass LINE and COL as TOPOS. */)
1754 CHECK_CONS (offsets); 1758 CHECK_CONS (offsets);
1755 CHECK_NUMBER_CAR (offsets); 1759 CHECK_NUMBER_CAR (offsets);
1756 CHECK_NUMBER_CDR (offsets); 1760 CHECK_NUMBER_CDR (offsets);
1761 if (! (0 <= XINT (XCAR (offsets)) && XINT (XCAR (offsets)) <= PTRDIFF_MAX
1762 && 0 <= XINT (XCDR (offsets)) && XINT (XCDR (offsets)) <= INT_MAX))
1763 args_out_of_range (XCAR (offsets), XCDR (offsets));
1757 hscroll = XINT (XCAR (offsets)); 1764 hscroll = XINT (XCAR (offsets));
1758 tab_offset = XINT (XCDR (offsets)); 1765 tab_offset = XINT (XCDR (offsets));
1759 } 1766 }
@@ -1807,22 +1814,22 @@ visible section of the buffer, and pass LINE and COL as TOPOS. */)
1807static struct position val_vmotion; 1814static struct position val_vmotion;
1808 1815
1809struct position * 1816struct position *
1810vmotion (register EMACS_INT from, register EMACS_INT vtarget, struct window *w) 1817vmotion (register ptrdiff_t from, register EMACS_INT vtarget, struct window *w)
1811{ 1818{
1812 EMACS_INT hscroll = XINT (w->hscroll); 1819 ptrdiff_t hscroll = XINT (w->hscroll);
1813 struct position pos; 1820 struct position pos;
1814 /* vpos is cumulative vertical position, changed as from is changed */ 1821 /* vpos is cumulative vertical position, changed as from is changed */
1815 register int vpos = 0; 1822 register EMACS_INT vpos = 0;
1816 EMACS_INT prevline; 1823 ptrdiff_t prevline;
1817 register EMACS_INT first; 1824 register ptrdiff_t first;
1818 EMACS_INT from_byte; 1825 ptrdiff_t from_byte;
1819 EMACS_INT lmargin = hscroll > 0 ? 1 - hscroll : 0; 1826 ptrdiff_t lmargin = hscroll > 0 ? 1 - hscroll : 0;
1820 EMACS_INT selective 1827 ptrdiff_t selective
1821 = (INTEGERP (BVAR (current_buffer, selective_display)) 1828 = (INTEGERP (BVAR (current_buffer, selective_display))
1822 ? XINT (BVAR (current_buffer, selective_display)) 1829 ? clip_to_bounds (-1, XINT (BVAR (current_buffer, selective_display)),
1830 PTRDIFF_MAX)
1823 : !NILP (BVAR (current_buffer, selective_display)) ? -1 : 0); 1831 : !NILP (BVAR (current_buffer, selective_display)) ? -1 : 0);
1824 Lisp_Object window; 1832 Lisp_Object window;
1825 EMACS_INT start_hpos = 0;
1826 int did_motion; 1833 int did_motion;
1827 /* This is the object we use for fetching character properties. */ 1834 /* This is the object we use for fetching character properties. */
1828 Lisp_Object text_prop_object; 1835 Lisp_Object text_prop_object;
@@ -1861,7 +1868,7 @@ vmotion (register EMACS_INT from, register EMACS_INT vtarget, struct window *w)
1861 TEXT_PROP_MEANS_INVISIBLE (propval)))) 1868 TEXT_PROP_MEANS_INVISIBLE (propval))))
1862 prevline = find_next_newline_no_quit (prevline - 1, -1); 1869 prevline = find_next_newline_no_quit (prevline - 1, -1);
1863 pos = *compute_motion (prevline, 0, 1870 pos = *compute_motion (prevline, 0,
1864 lmargin + (prevline == BEG ? start_hpos : 0), 1871 lmargin,
1865 0, 1872 0,
1866 from, 1873 from,
1867 /* Don't care for VPOS... */ 1874 /* Don't care for VPOS... */
@@ -1869,10 +1876,7 @@ vmotion (register EMACS_INT from, register EMACS_INT vtarget, struct window *w)
1869 /* ... nor HPOS. */ 1876 /* ... nor HPOS. */
1870 1 << (BITS_PER_SHORT - 1), 1877 1 << (BITS_PER_SHORT - 1),
1871 -1, hscroll, 1878 -1, hscroll,
1872 /* This compensates for start_hpos 1879 0,
1873 so that a tab as first character
1874 still occupies 8 columns. */
1875 (prevline == BEG ? -start_hpos : 0),
1876 w); 1880 w);
1877 vpos -= pos.vpos; 1881 vpos -= pos.vpos;
1878 first = 0; 1882 first = 0;
@@ -1890,8 +1894,6 @@ vmotion (register EMACS_INT from, register EMACS_INT vtarget, struct window *w)
1890 val_vmotion.hpos = lmargin; 1894 val_vmotion.hpos = lmargin;
1891 val_vmotion.contin = 0; 1895 val_vmotion.contin = 0;
1892 val_vmotion.prevhpos = 0; 1896 val_vmotion.prevhpos = 0;
1893 val_vmotion.ovstring_chars_done = 0;
1894 val_vmotion.tab_offset = 0; /* For accumulating tab offset. */
1895 return &val_vmotion; 1897 return &val_vmotion;
1896 } 1898 }
1897 1899
@@ -1918,8 +1920,7 @@ vmotion (register EMACS_INT from, register EMACS_INT vtarget, struct window *w)
1918 TEXT_PROP_MEANS_INVISIBLE (propval)))) 1920 TEXT_PROP_MEANS_INVISIBLE (propval))))
1919 prevline = find_next_newline_no_quit (prevline - 1, -1); 1921 prevline = find_next_newline_no_quit (prevline - 1, -1);
1920 pos = *compute_motion (prevline, 0, 1922 pos = *compute_motion (prevline, 0,
1921 lmargin + (prevline == BEG 1923 lmargin,
1922 ? start_hpos : 0),
1923 0, 1924 0,
1924 from, 1925 from,
1925 /* Don't care for VPOS... */ 1926 /* Don't care for VPOS... */
@@ -1927,21 +1928,20 @@ vmotion (register EMACS_INT from, register EMACS_INT vtarget, struct window *w)
1927 /* ... nor HPOS. */ 1928 /* ... nor HPOS. */
1928 1 << (BITS_PER_SHORT - 1), 1929 1 << (BITS_PER_SHORT - 1),
1929 -1, hscroll, 1930 -1, hscroll,
1930 (prevline == BEG ? -start_hpos : 0), 1931 0,
1931 w); 1932 w);
1932 did_motion = 1; 1933 did_motion = 1;
1933 } 1934 }
1934 else 1935 else
1935 { 1936 {
1936 pos.hpos = lmargin + (from == BEG ? start_hpos : 0); 1937 pos.hpos = lmargin;
1937 pos.vpos = 0; 1938 pos.vpos = 0;
1938 pos.tab_offset = 0;
1939 did_motion = 0; 1939 did_motion = 0;
1940 } 1940 }
1941 return compute_motion (from, vpos, pos.hpos, did_motion, 1941 return compute_motion (from, vpos, pos.hpos, did_motion,
1942 ZV, vtarget, - (1 << (BITS_PER_SHORT - 1)), 1942 ZV, vtarget, - (1 << (BITS_PER_SHORT - 1)),
1943 -1, hscroll, 1943 -1, hscroll,
1944 pos.tab_offset - (from == BEG ? start_hpos : 0), 1944 0,
1945 w); 1945 w);
1946} 1946}
1947 1947
@@ -2018,7 +2018,7 @@ whether or not it is currently displayed in some window. */)
2018 } 2018 }
2019 else 2019 else
2020 { 2020 {
2021 EMACS_INT it_start; 2021 ptrdiff_t it_start;
2022 int first_x, it_overshoot_expected IF_LINT (= 0); 2022 int first_x, it_overshoot_expected IF_LINT (= 0);
2023 2023
2024 itdata = bidi_shelve_cache (); 2024 itdata = bidi_shelve_cache ();