annotate admin/notes/iftc @ 110645:7d7a02c19d8c
Fix int/EMACS_INT use in xdisp.c and print.c.
print.c (print_object): Fix format string and argument types for
printing a Lisp_Misc_Marker.
xdisp.c (pos_visible_p, c_string_pos, number_of_chars)
(load_overlay_strings, get_overlay_strings_1)
(get_overlay_strings, forward_to_next_line_start)
(back_to_previous_visible_line_start, reseat, reseat_to_string)
(get_next_display_element, next_element_from_string)
(next_element_from_c_string, next_element_from_buffer)
(move_it_vertically_backward, move_it_by_lines, add_to_log)
(message_dolog, message_log_check_duplicate, message2_nolog)
(message3, message3_nolog, vmessage, set_message, set_message_1)
(hscroll_window_tree, text_outside_line_unchanged_p)
(set_cursor_from_row, set_vertical_scroll_bar, redisplay_window)
(find_last_unchanged_at_beg_row)
(find_first_unchanged_at_end_row, row_containing_pos)
(trailing_whitespace_p, display_mode_element, decode_mode_spec)
(display_count_lines, x_produce_glyphs, note_mouse_highlight): Use
EMACS_INT for buffer and string positions.
dispextern.h (struct it) <string_nchars>: Declare EMACS_INT.
(row_containing_pos): Adjust prototype.
lisp.h (pos_visible_p, message2, message2_nolog, message3)
(message2_nolog, set_message): Adjust prototypes.
| author |
Eli Zaretskii <eliz@gnu.org> |
| date |
Wed, 29 Sep 2010 05:06:53 -0400 |
| parents |
695cf19ef79e |
| children |
375f2633d815 ef719132ddfa |
| rev |
line source |
|
45625
|
1 Iso-Functional Type Contour
|
|
|
2
|
|
|
3
|
|
|
4 This is a term coined to describe "column int->float" change approach, and can
|
|
|
5 be used whenever low-level types need to change (hopefully not often!) but the
|
|
|
6 meanings of the values (whose type has changed) do not.
|
|
|
7
|
|
|
8 The premise is that changing a low-level type potentially means lots of code
|
|
|
9 needs to be changed as well, and the question is how to do this incrementally,
|
|
|
10 which is the preferred way to change things.
|
|
|
11
|
|
|
12 Say LOW and HIGH are C functions:
|
|
|
13
|
|
|
14 int LOW (void) { return 1; }
|
|
|
15 void HIGH (void) { int value = LOW (); }
|
|
|
16
|
|
|
17 We want to convert LOW to return float, so we cast HIGH usage:
|
|
|
18
|
|
|
19 float LOW (void) { return 1.0; }
|
|
|
20 void HIGH (void) { int value = (int) LOW (); } /* iftc */
|
|
|
21
|
|
|
22 The comment /* iftc */ is used to mark this type of casting to differentiate
|
|
|
23 it from other casting. We commit the changes and can now go about modifying
|
|
|
24 LOW and HIGH separately. When HIGH is ready to handle the type change, the
|
|
|
25 cast can be removed.
|
|
52401
|
26
|
|
|
27 ;;; arch-tag: 3309cc41-5d59-421b-b7be-c94b04083bb5
|