diff --git a/src/chars.c b/src/chars.c index 134bad3cef899999fc2a0b880a12e7b363fe8292..de28d420b5f546543aa75d0d7052b4fd2f986405 100644 --- a/src/chars.c +++ b/src/chars.c @@ -150,7 +150,7 @@ char *control_mbrep(const char *c, char *crep, int *crep_len) if (c_mb_len <= 0) { mbtowc(NULL, NULL, 0); - wc = *c; + wc = (unsigned char)*c; } wcrep = control_wrep(wc); @@ -237,14 +237,13 @@ char *make_mbchar(unsigned int chr, char *chr_mb, int *chr_mb_len) *chr_mb_len = wctomb(chr_mb, chr); if (*chr_mb_len <= 0) { - mbtowc(NULL, NULL, 0); - *chr_mb_len = 1; - chr_mb[0] = (unsigned char)chr; + wctomb(NULL, 0); + *chr_mb_len = 0; } } else { #endif *chr_mb_len = 1; - chr_mb[0] = (unsigned char)chr; + chr_mb[0] = (char)chr; #ifdef NANO_WIDE } #endif diff --git a/src/winio.c b/src/winio.c index 3a99ea7dffc1d1961270bbcb169132f42d8703c8..328fafc3f9acb18f4f2d19fc7d91c8250710c6b1 100644 --- a/src/winio.c +++ b/src/winio.c @@ -2190,7 +2190,7 @@ char *display_string(const char *buf, size_t start_col, size_t len, bool char *bad_buf_mb = charalloc(mb_cur_max()); int bad_buf_mb_len; - bad_buf_mb = make_mbchar((unsigned int)*buf_mb, + bad_buf_mb = make_mbchar((unsigned char)*buf_mb, bad_buf_mb, &bad_buf_mb_len); for (i = 0; i < bad_buf_mb_len; i++)