From 90fc47863786e39b2000866592402a7af05f3dfb Mon Sep 17 00:00:00 2001 From: Dmitry Antipov Date: Fri, 6 Jul 2012 13:20:41 +0400 Subject: [PATCH] Compile marker debugging code only if ENABLE_CHECKING is defined. * marker.c (byte_char_debug_check, count_markers): Use only if ENABLE_CHECKING is defined. (byte_debug_flag): Remove. (CONSIDER, buf_charpos_to_bytepos, buf_bytepos_to_charpos): Always call byte_char_debug_check if ENABLE_CHECKING is defined. --- src/ChangeLog | 9 ++++++ src/marker.c | 87 ++++++++++++++++++++++++++------------------------- 2 files changed, 54 insertions(+), 42 deletions(-) diff --git a/src/ChangeLog b/src/ChangeLog index 5e28882e6b3..986c398b7fc 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,12 @@ +2012-07-06 Dmitry Antipov + + Compile marker debugging code only if ENABLE_CHECKING is defined. + * marker.c (byte_char_debug_check, count_markers): Use + only if ENABLE_CHECKING is defined. + (byte_debug_flag): Remove. + (CONSIDER, buf_charpos_to_bytepos, buf_bytepos_to_charpos): + Always call byte_char_debug_check if ENABLE_CHECKING is defined. + 2012-07-06 Dmitry Antipov Avoid code repetition in marker-related functions. diff --git a/src/marker.c b/src/marker.c index 47a3e85e582..ac444fcec08 100644 --- a/src/marker.c +++ b/src/marker.c @@ -31,8 +31,36 @@ static ptrdiff_t cached_bytepos; static struct buffer *cached_buffer; static int cached_modiff; -static void byte_char_debug_check (struct buffer *, ptrdiff_t, ptrdiff_t); +#ifdef ENABLE_CHECKING +extern int count_markers (struct buffer *) EXTERNALLY_VISIBLE; + +static void +byte_char_debug_check (struct buffer *b, ptrdiff_t charpos, ptrdiff_t bytepos) +{ + ptrdiff_t nchars = 0; + + if (bytepos > BUF_GPT_BYTE (b)) + { + nchars = multibyte_chars_in_text (BUF_BEG_ADDR (b), + BUF_GPT_BYTE (b) - BUF_BEG_BYTE (b)); + nchars += multibyte_chars_in_text (BUF_GAP_END_ADDR (b), + bytepos - BUF_GPT_BYTE (b)); + } + else + nchars = multibyte_chars_in_text (BUF_BEG_ADDR (b), + bytepos - BUF_BEG_BYTE (b)); + + if (charpos - 1 != nchars) + abort (); +} + +#else /* not ENABLE_CHECKING */ + +#define byte_char_debug_check(b,charpos,bytepos) do { } while (0) + +#endif /* ENABLE_CHECKING */ + void clear_charpos_cache (struct buffer *b) { @@ -61,8 +89,8 @@ clear_charpos_cache (struct buffer *b) if (this_charpos == charpos) \ { \ ptrdiff_t value = (BYTEPOS); \ - if (byte_debug_flag) \ - byte_char_debug_check (b, charpos, value); \ + \ + byte_char_debug_check (b, charpos, value); \ return value; \ } \ else if (this_charpos > charpos) \ @@ -86,33 +114,13 @@ clear_charpos_cache (struct buffer *b) if (best_above - best_below == best_above_byte - best_below_byte) \ { \ ptrdiff_t value = best_below_byte + (charpos - best_below); \ - if (byte_debug_flag) \ - byte_char_debug_check (b, charpos, value); \ + \ + byte_char_debug_check (b, charpos, value); \ return value; \ } \ } \ } -static void -byte_char_debug_check (struct buffer *b, ptrdiff_t charpos, ptrdiff_t bytepos) -{ - ptrdiff_t nchars = 0; - - if (bytepos > BUF_GPT_BYTE (b)) - { - nchars = multibyte_chars_in_text (BUF_BEG_ADDR (b), - BUF_GPT_BYTE (b) - BUF_BEG_BYTE (b)); - nchars += multibyte_chars_in_text (BUF_GAP_END_ADDR (b), - bytepos - BUF_GPT_BYTE (b)); - } - else - nchars = multibyte_chars_in_text (BUF_BEG_ADDR (b), - bytepos - BUF_BEG_BYTE (b)); - - if (charpos - 1 != nchars) - abort (); -} - ptrdiff_t charpos_to_bytepos (ptrdiff_t charpos) { @@ -189,8 +197,7 @@ buf_charpos_to_bytepos (struct buffer *b, ptrdiff_t charpos) if (record) build_marker (b, best_below, best_below_byte); - if (byte_debug_flag) - byte_char_debug_check (b, charpos, best_below_byte); + byte_char_debug_check (b, charpos, best_below_byte); cached_buffer = b; cached_modiff = BUF_MODIFF (b); @@ -215,8 +222,7 @@ buf_charpos_to_bytepos (struct buffer *b, ptrdiff_t charpos) if (record) build_marker (b, best_above, best_above_byte); - if (byte_debug_flag) - byte_char_debug_check (b, charpos, best_above_byte); + byte_char_debug_check (b, charpos, best_above_byte); cached_buffer = b; cached_modiff = BUF_MODIFF (b); @@ -262,8 +268,8 @@ verify_bytepos (ptrdiff_t charpos) if (this_bytepos == bytepos) \ { \ ptrdiff_t value = (CHARPOS); \ - if (byte_debug_flag) \ - byte_char_debug_check (b, value, bytepos); \ + \ + byte_char_debug_check (b, value, bytepos); \ return value; \ } \ else if (this_bytepos > bytepos) \ @@ -287,8 +293,8 @@ verify_bytepos (ptrdiff_t charpos) if (best_above - best_below == best_above_byte - best_below_byte) \ { \ ptrdiff_t value = best_below + (bytepos - best_below_byte); \ - if (byte_debug_flag) \ - byte_char_debug_check (b, value, bytepos); \ + \ + byte_char_debug_check (b, value, bytepos); \ return value; \ } \ } \ @@ -357,8 +363,7 @@ buf_bytepos_to_charpos (struct buffer *b, ptrdiff_t bytepos) if (record && BUF_MARKERS (b)) build_marker (b, best_below, best_below_byte); - if (byte_debug_flag) - byte_char_debug_check (b, best_below, bytepos); + byte_char_debug_check (b, best_below, bytepos); cached_buffer = b; cached_modiff = BUF_MODIFF (b); @@ -385,8 +390,7 @@ buf_bytepos_to_charpos (struct buffer *b, ptrdiff_t bytepos) if (record && BUF_MARKERS (b)) build_marker (b, best_above, best_above_byte); - if (byte_debug_flag) - byte_char_debug_check (b, best_above, bytepos); + byte_char_debug_check (b, best_above, bytepos); cached_buffer = b; cached_modiff = BUF_MODIFF (b); @@ -775,9 +779,10 @@ DEFUN ("buffer-has-markers-at", Fbuffer_has_markers_at, Sbuffer_has_markers_at, return Qnil; } +#ifdef ENABLE_CHECKING + /* For debugging -- count the markers in buffer BUF. */ -extern int count_markers (struct buffer *) EXTERNALLY_VISIBLE; int count_markers (struct buffer *buf) { @@ -789,6 +794,8 @@ count_markers (struct buffer *buf) return total; } + +#endif /* ENABLE_CHECKING */ void syms_of_marker (void) @@ -800,8 +807,4 @@ syms_of_marker (void) defsubr (&Smarker_insertion_type); defsubr (&Sset_marker_insertion_type); defsubr (&Sbuffer_has_markers_at); - - DEFVAR_BOOL ("byte-debug-flag", byte_debug_flag, - doc: /* Non-nil enables debugging checks in byte/char position conversions. */); - byte_debug_flag = 0; } -- 2.39.2