chars: a control character can never be an invalid multibyte sequence
The function is_cntrl_mbchar() has always been called successfully before calling control_mbrep(), so the passed character *is* a valid sequence.master
parent
21d9bd1107
commit
05e2a6d259
16
src/chars.c
16
src/chars.c
|
@ -250,9 +250,7 @@ wchar_t control_wrep(wchar_t wc)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* c is a multibyte control character. It displays as ^@, ^?, or ^[ch],
|
/* c is a multibyte control character. It displays as ^@, ^?, or ^[ch],
|
||||||
* where ch is (c + 64). We return that multibyte character. If crep
|
* where ch is (c + 64). We return that multibyte character. */
|
||||||
* is an invalid multibyte sequence, it will be replaced with Unicode
|
|
||||||
* 0xFFFD (Replacement Character). */
|
|
||||||
char *control_mbrep(const char *c, char *crep, int *crep_len)
|
char *control_mbrep(const char *c, char *crep, int *crep_len)
|
||||||
{
|
{
|
||||||
assert(c != NULL && crep != NULL && crep_len != NULL);
|
assert(c != NULL && crep != NULL && crep_len != NULL);
|
||||||
|
@ -261,18 +259,8 @@ char *control_mbrep(const char *c, char *crep, int *crep_len)
|
||||||
if (use_utf8) {
|
if (use_utf8) {
|
||||||
wchar_t wc;
|
wchar_t wc;
|
||||||
|
|
||||||
if (mbtowc(&wc, c, MB_CUR_MAX) < 0) {
|
IGNORE_CALL_RESULT(mbtowc(&wc, c, MB_CUR_MAX));
|
||||||
mbtowc_reset();
|
|
||||||
*crep_len = bad_mbchar_len;
|
|
||||||
strncpy(crep, bad_mbchar, *crep_len);
|
|
||||||
} else {
|
|
||||||
*crep_len = wctomb(crep, control_wrep(wc));
|
*crep_len = wctomb(crep, control_wrep(wc));
|
||||||
|
|
||||||
if (*crep_len < 0) {
|
|
||||||
wctomb_reset();
|
|
||||||
*crep_len = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue