diff options
author | Mark H Weaver <mhw@netris.org> | 2019-05-07 02:28:26 -0400 |
---|---|---|
committer | Mark H Weaver <mhw@netris.org> | 2019-05-07 04:37:52 -0400 |
commit | 2a1f22c00abc7b11f4fc5b77933151306e535cbb (patch) | |
tree | ca17c02b15cfdc88da2d065670dfee1018cd5f8c /libguile/strings.c | |
parent | 63818453ad226cd3c2d1fd8ade12e3d7c1d43c05 (diff) | |
download | guile-2a1f22c00abc7b11f4fc5b77933151306e535cbb.tar.gz |
Add 'scm_c_make_char' and use it where appropriate.
This reverts the change to SCM_MAKE_CHAR made in the previous commit
63818453ad226cd3c2d1fd8ade12e3d7c1d43c05, which used an arithmetic trick
to avoid evaluating its argument more than once.
Here, we restore the previous implementation of SCM_MAKE_CHAR, which
evaluates its argument twice. Instead, we introduce a new inlinable
function 'scm_c_make_char' and replace uses of SCM_MAKE_CHAR with calls
to 'scm_c_make_char' where appropriate.
* libguile/chars.h (scm_c_make_char): New inline function.
* libguile/inline.c: Include chars.h.
* libguile/srfi-13.c (REF_IN_CHARSET, scm_string_any, scm_string_every)
(scm_string_trim, scm_string_trim_right, scm_string_trim_both)
(scm_string_index, scm_string_index_right, scm_string_skip)
(scm_string_skip_right, scm_string_count, string_titlecase_x)
(string_reverse_x, scm_string_fold, scm_string_fold_right)
(scm_string_for_each, scm_string_filter, scm_string_delete):
Use 'scm_c_make_char' instead of 'SCM_MAKE_CHAR' in cases where the
argument calls a function.
* libguile/chars.c (scm_char_upcase, scm_char_downcase, scm_char_titlecase),
libguile/ports.c (scm_port_decode_char),
libguile/print.c (scm_simple_format),
libguile/read.c (scm_read_character),
libguile/strings.c (scm_string_ref, scm_c_string_ref),
libguile/vm-engine.c ("string-ref"): Ditto.
Diffstat (limited to 'libguile/strings.c')
-rw-r--r-- | libguile/strings.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/libguile/strings.c b/libguile/strings.c index 62ff2e303..5a150278d 100644 --- a/libguile/strings.c +++ b/libguile/strings.c @@ -1209,9 +1209,9 @@ SCM_DEFINE (scm_string_ref, "string-ref", 2, 0, 0, scm_out_of_range (NULL, k); if (scm_i_is_narrow_string (str)) - return SCM_MAKE_CHAR (scm_i_string_chars (str)[idx]); + return scm_c_make_char (scm_i_string_chars (str)[idx]); else - return SCM_MAKE_CHAR (scm_i_string_wide_chars (str)[idx]); + return scm_c_make_char (scm_i_string_wide_chars (str)[idx]); } #undef FUNC_NAME @@ -1221,9 +1221,9 @@ scm_c_string_ref (SCM str, size_t p) if (p >= scm_i_string_length (str)) scm_out_of_range (NULL, scm_from_size_t (p)); if (scm_i_is_narrow_string (str)) - return SCM_MAKE_CHAR (scm_i_string_chars (str)[p]); + return scm_c_make_char (scm_i_string_chars (str)[p]); else - return SCM_MAKE_CHAR (scm_i_string_wide_chars (str)[p]); + return scm_c_make_char (scm_i_string_wide_chars (str)[p]); } |