Module Name: src Committed By: rin Date: Sun Jun 3 08:08:37 UTC 2018
Modified Files: src/external/bsd/nvi/dist/common: conv.h src/external/bsd/nvi/dist/vi: vs_line.c vs_relative.c Log Message: Make sure that every wide char occupies at least one display width: - Replace non-printable multibyte char with ?-symbol. - Put space before non-spacing char. Fix problems reported in PR bin/53164 and PR bin/53323, that are because we did not take into account non-printable multibyte char of wctob(wc) == EOF && wcwidth(wc) == -1. To generate a diff of this commit: cvs rdiff -u -r1.2 -r1.3 src/external/bsd/nvi/dist/common/conv.h cvs rdiff -u -r1.4 -r1.5 src/external/bsd/nvi/dist/vi/vs_line.c \ src/external/bsd/nvi/dist/vi/vs_relative.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/external/bsd/nvi/dist/common/conv.h diff -u src/external/bsd/nvi/dist/common/conv.h:1.2 src/external/bsd/nvi/dist/common/conv.h:1.3 --- src/external/bsd/nvi/dist/common/conv.h:1.2 Fri Nov 22 15:52:05 2013 +++ src/external/bsd/nvi/dist/common/conv.h Sun Jun 3 08:08:36 2018 @@ -1,9 +1,14 @@ -/* $NetBSD: conv.h,v 1.2 2013/11/22 15:52:05 christos Exp $ */ +/* $NetBSD: conv.h,v 1.3 2018/06/03 08:08:36 rin Exp $ */ + +/* + * We ensure that every wide char occupies at least one display width. + * See vs_line.c for more details. + */ +#define WIDE_COL(sp, ch) \ + (CHAR_WIDTH(sp, ch) >= 0 ? CHAR_WIDTH(sp, ch) : 1) + #define KEY_COL(sp, ch) \ - (INTISWIDE(ch) ? \ - (CHAR_WIDTH(sp, ch) >= 0) ? \ - (size_t)CHAR_WIDTH(sp, ch) : 1 /* extra space */ \ - : KEY_LEN(sp,ch)) + (INTISWIDE(ch) ? (size_t)WIDE_COL(sp, ch) : KEY_LEN(sp, ch)) struct _conv_win { void *bp1; Index: src/external/bsd/nvi/dist/vi/vs_line.c diff -u src/external/bsd/nvi/dist/vi/vs_line.c:1.4 src/external/bsd/nvi/dist/vi/vs_line.c:1.5 --- src/external/bsd/nvi/dist/vi/vs_line.c:1.4 Fri Nov 10 14:44:13 2017 +++ src/external/bsd/nvi/dist/vi/vs_line.c Sun Jun 3 08:08:37 2018 @@ -1,4 +1,4 @@ -/* $NetBSD: vs_line.c,v 1.4 2017/11/10 14:44:13 rin Exp $ */ +/* $NetBSD: vs_line.c,v 1.5 2018/06/03 08:08:37 rin Exp $ */ /*- * Copyright (c) 1993, 1994 * The Regents of the University of California. All rights reserved. @@ -16,7 +16,7 @@ static const char sccsid[] = "Id: vs_line.c,v 10.38 2002/01/19 21:59:07 skimo Exp (Berkeley) Date: 2002/01/19 21:59:07 "; #endif /* not lint */ #else -__RCSID("$NetBSD: vs_line.c,v 1.4 2017/11/10 14:44:13 rin Exp $"); +__RCSID("$NetBSD: vs_line.c,v 1.5 2018/06/03 08:08:37 rin Exp $"); #endif #include <sys/types.h> @@ -497,10 +497,23 @@ display: /* XXXX this needs some rethinking */ if (INTISWIDE(ch)) { - /* Put a space before non-spacing char. */ - if (CHAR_WIDTH(sp, ch) <= 0) + /* + * We ensure that every wide char occupies at + * least one display width, as noted in conv.h: + * - Replace non-printable char with ?-symbol. + * - Put space before non-spacing char. + */ + switch (CHAR_WIDTH(sp, ch)) { + case -1: + *cbp++ = L('?'); + break; + case 0: *cbp++ = L(' '); - *cbp++ = ch; + /* FALLTHROUGH */ + default: + *cbp++ = ch; + break; + } } else for (kp = KEY_NAME(sp, ch) + offset_in_char; chlen--;) Index: src/external/bsd/nvi/dist/vi/vs_relative.c diff -u src/external/bsd/nvi/dist/vi/vs_relative.c:1.4 src/external/bsd/nvi/dist/vi/vs_relative.c:1.5 --- src/external/bsd/nvi/dist/vi/vs_relative.c:1.4 Fri Nov 10 14:44:13 2017 +++ src/external/bsd/nvi/dist/vi/vs_relative.c Sun Jun 3 08:08:37 2018 @@ -1,4 +1,4 @@ -/* $NetBSD: vs_relative.c,v 1.4 2017/11/10 14:44:13 rin Exp $ */ +/* $NetBSD: vs_relative.c,v 1.5 2018/06/03 08:08:37 rin Exp $ */ /*- * Copyright (c) 1993, 1994 * The Regents of the University of California. All rights reserved. @@ -16,7 +16,7 @@ static const char sccsid[] = "Id: vs_relative.c,v 10.18 2001/07/08 13:02:48 skimo Exp (Berkeley) Date: 2001/07/08 13:02:48 "; #endif /* not lint */ #else -__RCSID("$NetBSD: vs_relative.c,v 1.4 2017/11/10 14:44:13 rin Exp $"); +__RCSID("$NetBSD: vs_relative.c,v 1.5 2018/06/03 08:08:37 rin Exp $"); #endif #include <sys/types.h> @@ -178,7 +178,7 @@ done: if (diffp != NULL) /* XXX */ } /* multibyte case */ - chlen = CHAR_WIDTH(sp, ch); + chlen = WIDE_COL(sp, ch); last = scno; scno += chlen; len--; @@ -216,7 +216,7 @@ done: if (diffp != NULL) /* XXX */ } /* multibyte case */ - chlen = CHAR_WIDTH(sp, ch); + chlen = WIDE_COL(sp, ch); last = scno; scno += chlen; p++;