mskanji.c.patch   [plain text]


--- mskanji.c.orig	2009-11-09 15:05:25.000000000 -0800
+++ mskanji.c	2009-11-09 16:30:02.000000000 -0800
@@ -39,6 +39,8 @@ static char sccsid[] = "@(#)mskanji.c	1.
 #include <sys/cdefs.h>
 __FBSDID("$FreeBSD: src/lib/libc/locale/mskanji.c,v 1.18 2007/10/13 16:28:22 ache Exp $");
 
+#include "xlocale_private.h"
+
 #include <sys/types.h>
 #include <errno.h>
 #include <runetype.h>
@@ -47,33 +49,30 @@ __FBSDID("$FreeBSD: src/lib/libc/locale/
 #include <wchar.h>
 #include "mblocal.h"
 
-extern int __mb_sb_limit;
-
 static size_t	_MSKanji_mbrtowc(wchar_t * __restrict, const char * __restrict,
-		    size_t, mbstate_t * __restrict);
-static int	_MSKanji_mbsinit(const mbstate_t *);
+		    size_t, mbstate_t * __restrict, locale_t);
+static int	_MSKanji_mbsinit(const mbstate_t *, locale_t);
 static size_t	_MSKanji_wcrtomb(char * __restrict, wchar_t,
-		    mbstate_t * __restrict);
+		    mbstate_t * __restrict, locale_t);
 
 typedef struct {
 	wchar_t	ch;
 } _MSKanjiState;
 
-int
-_MSKanji_init(_RuneLocale *rl)
+__private_extern__ int
+_MSKanji_init(struct __xlocale_st_runelocale *xrl)
 {
 
-	__mbrtowc = _MSKanji_mbrtowc;
-	__wcrtomb = _MSKanji_wcrtomb;
-	__mbsinit = _MSKanji_mbsinit;
-	_CurrentRuneLocale = rl;
-	__mb_cur_max = 2;
-	__mb_sb_limit = 256;
+	xrl->__mbrtowc = _MSKanji_mbrtowc;
+	xrl->__wcrtomb = _MSKanji_wcrtomb;
+	xrl->__mbsinit = _MSKanji_mbsinit;
+	xrl->__mb_cur_max = 2;
+	xrl->__mb_sb_limit = 256;
 	return (0);
 }
 
 static int
-_MSKanji_mbsinit(const mbstate_t *ps)
+_MSKanji_mbsinit(const mbstate_t *ps, locale_t loc __unused)
 {
 
 	return (ps == NULL || ((const _MSKanjiState *)ps)->ch == 0);
@@ -81,7 +80,7 @@ _MSKanji_mbsinit(const mbstate_t *ps)
 
 static size_t
 _MSKanji_mbrtowc(wchar_t * __restrict pwc, const char * __restrict s, size_t n,
-    mbstate_t * __restrict ps)
+    mbstate_t * __restrict ps, locale_t loc __unused)
 {
 	_MSKanjiState *ms;
 	wchar_t wc;
@@ -138,7 +137,7 @@ _MSKanji_mbrtowc(wchar_t * __restrict pw
 }
 
 static size_t
-_MSKanji_wcrtomb(char * __restrict s, wchar_t wc, mbstate_t * __restrict ps)
+_MSKanji_wcrtomb(char * __restrict s, wchar_t wc, mbstate_t * __restrict ps, locale_t loc __unused)
 {
 	_MSKanjiState *ms;
 	int len, i;