mirror of
https://github.com/openbsd/src.git
synced 2025-01-04 23:35:36 -08:00
Fix a regression (and POSIX violation) introduced with UTF-8 support:
When neither running on a terminal nor with -q, names must be passed through as they are, nothing must be replaced with question marks. Effectively, -q was always in effect. SMALL was not affected. Triggered by a different patch from Martijn van Duren <openbsd plus tech at list dot imperialat dot at>, who confirmed that this version is better. Identified as a regression by tedu@. OK sthen@.
This commit is contained in:
parent
09cf2d6e77
commit
f96b7276b0
@ -1,7 +1,7 @@
|
|||||||
/* $OpenBSD: utf8.c,v 1.1 2015/12/01 18:36:13 schwarze Exp $ */
|
/* $OpenBSD: utf8.c,v 1.2 2016/01/18 19:06:37 schwarze Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2015 Ingo Schwarze <schwarze@openbsd.org>
|
* Copyright (c) 2015, 2016 Ingo Schwarze <schwarze@openbsd.org>
|
||||||
*
|
*
|
||||||
* Permission to use, copy, modify, and distribute this software for any
|
* Permission to use, copy, modify, and distribute this software for any
|
||||||
* purpose with or without fee is hereby granted, provided that the above
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
@ -21,6 +21,8 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <wchar.h>
|
#include <wchar.h>
|
||||||
|
|
||||||
|
extern int f_nonprint;
|
||||||
|
|
||||||
int
|
int
|
||||||
mbsprint(const char *mbs, int print)
|
mbsprint(const char *mbs, int print)
|
||||||
{
|
{
|
||||||
@ -33,12 +35,16 @@ mbsprint(const char *mbs, int print)
|
|||||||
if ((len = mbtowc(&wc, mbs, MB_CUR_MAX)) == -1) {
|
if ((len = mbtowc(&wc, mbs, MB_CUR_MAX)) == -1) {
|
||||||
(void)mbtowc(NULL, NULL, MB_CUR_MAX);
|
(void)mbtowc(NULL, NULL, MB_CUR_MAX);
|
||||||
if (print)
|
if (print)
|
||||||
putchar('?');
|
putchar(f_nonprint ? '?' : *mbs);
|
||||||
total_width++;
|
total_width++;
|
||||||
len = 1;
|
len = 1;
|
||||||
} else if ((width = wcwidth(wc)) == -1) {
|
} else if ((width = wcwidth(wc)) == -1) {
|
||||||
if (print)
|
if (print) {
|
||||||
putchar('?');
|
if (f_nonprint)
|
||||||
|
putchar('?');
|
||||||
|
else
|
||||||
|
fwrite(mbs, 1, len, stdout);
|
||||||
|
}
|
||||||
total_width++;
|
total_width++;
|
||||||
} else {
|
} else {
|
||||||
if (print)
|
if (print)
|
||||||
|
Loading…
Reference in New Issue
Block a user