Loading...
string/FreeBSD/wcswidth.c.patch /dev/null Libc-763.11
--- /dev/null
+++ Libc/Libc-763.11/string/FreeBSD/wcswidth.c.patch
@@ -0,0 +1,35 @@
+--- wcswidth.c.bsdnew	2009-11-18 18:24:40.000000000 -0800
++++ wcswidth.c	2009-11-18 18:24:41.000000000 -0800
+@@ -38,20 +38,30 @@
+ #include <sys/cdefs.h>
+ __FBSDID("$FreeBSD: src/lib/libc/string/wcswidth.c,v 1.7 2007/01/09 00:28:12 imp Exp $");
+ 
++#include "xlocale_private.h"
++
+ #include <wchar.h>
+ 
+ int
+-wcswidth(const wchar_t *pwcs, size_t n)
++wcswidth_l(const wchar_t *pwcs, size_t n, locale_t loc)
+ {
+ 	wchar_t wc;
+ 	int len, l;
+ 
++	NORMALIZE_LOCALE(loc);
+ 	len = 0;
+ 	while (n-- > 0 && (wc = *pwcs++) != L'\0') {
+-		if ((l = wcwidth(wc)) < 0)
++		if ((l = wcwidth_l(wc, loc)) < 0)
+ 			return (-1);
+ 		len += l;
+ 	}
+ 	return (len);
+ }
+ 
++
++int
++wcswidth(const wchar_t *pwcs, size_t n)
++{
++	return wcswidth_l(pwcs, n, __current_locale());
++}
++