# HG changeset patch # User Stefan Monnier # Date 1045952471 0 # Node ID 95557d4395b0f7c4251b1b6c9587cc277e38a4f6 # Parent b4b6ede28a6f77798d1abb1612b7b092b830f01d (string_to_multibyte): Remove unused var i. (Flanginfo): Fix int/Lisp_Object mixup. (void_call2): New fun. (Fmap_char_table): Use it in place of call2. diff -r b4b6ede28a6f -r 95557d4395b0 src/fns.c --- a/src/fns.c Sat Feb 22 22:20:00 2003 +0000 +++ b/src/fns.c Sat Feb 22 22:21:11 2003 +0000 @@ -1047,7 +1047,6 @@ { unsigned char *buf; int nbytes; - int i; if (STRING_MULTIBYTE (string)) return string; @@ -2699,6 +2698,14 @@ } } +static void void_call2 P_ ((Lisp_Object a, Lisp_Object b, Lisp_Object c)); +static void +void_call2 (a, b, c) + Lisp_Object a, b, c; +{ + call2 (a, b, c); +} + DEFUN ("map-char-table", Fmap_char_table, Smap_char_table, 2, 2, 0, doc: /* Call FUNCTION for each (normal and generic) characters in CHAR-TABLE. @@ -2712,7 +2719,11 @@ CHECK_CHAR_TABLE (char_table); - map_char_table ((POINTER_TYPE *) call2, Qnil, char_table, function, 0, indices); + /* When Lisp_Object is represented as a union, `call2' cannot directly + be passed to map_char_table because it returns a Lisp_Object rather + than returning nothing. + Casting leads to crashes on some architectures. -stef */ + map_char_table (void_call2, Qnil, char_table, function, 0, indices); return Qnil; } @@ -3490,7 +3501,7 @@ it is consistent with CODESET? If not, what to do? */ Faset (v, make_number (i), code_convert_string_norecord (val, Vlocale_coding_system, - Qnil)); + 0)); } return v; } @@ -3508,7 +3519,7 @@ str = nl_langinfo (months[i]); val = make_unibyte_string (str, strlen (str)); p->contents[i] = - code_convert_string_norecord (val, Vlocale_coding_system, Qnil); + code_convert_string_norecord (val, Vlocale_coding_system, 0); } XSETVECTOR (val, p); return val;