]> git.saurik.com Git - apple/libc.git/blob - locale/FreeBSD/gbk.c.patch
df897652f6e3dd215d6f955ed92d64b9cb26cb0e
[apple/libc.git] / locale / FreeBSD / gbk.c.patch
1 --- gbk.c.orig 2009-11-09 15:05:25.000000000 -0800
2 +++ gbk.c 2009-11-09 16:27:30.000000000 -0800
3 @@ -34,6 +34,8 @@
4 #include <sys/cdefs.h>
5 __FBSDID("$FreeBSD: src/lib/libc/locale/gbk.c,v 1.14 2007/10/13 16:28:21 ache Exp $");
6
7 +#include "xlocale_private.h"
8 +
9 #include <sys/types.h>
10 #include <errno.h>
11 #include <runetype.h>
12 @@ -42,33 +44,30 @@ __FBSDID("$FreeBSD: src/lib/libc/locale/
13 #include <wchar.h>
14 #include "mblocal.h"
15
16 -extern int __mb_sb_limit;
17 -
18 static size_t _GBK_mbrtowc(wchar_t * __restrict, const char * __restrict,
19 - size_t, mbstate_t * __restrict);
20 -static int _GBK_mbsinit(const mbstate_t *);
21 + size_t, mbstate_t * __restrict, locale_t);
22 +static int _GBK_mbsinit(const mbstate_t *, locale_t);
23 static size_t _GBK_wcrtomb(char * __restrict, wchar_t,
24 - mbstate_t * __restrict);
25 + mbstate_t * __restrict, locale_t);
26
27 typedef struct {
28 wchar_t ch;
29 } _GBKState;
30
31 -int
32 -_GBK_init(_RuneLocale *rl)
33 +__private_extern__ int
34 +_GBK_init(struct __xlocale_st_runelocale *xrl)
35 {
36
37 - __mbrtowc = _GBK_mbrtowc;
38 - __wcrtomb = _GBK_wcrtomb;
39 - __mbsinit = _GBK_mbsinit;
40 - _CurrentRuneLocale = rl;
41 - __mb_cur_max = 2;
42 - __mb_sb_limit = 128;
43 + xrl->__mbrtowc = _GBK_mbrtowc;
44 + xrl->__wcrtomb = _GBK_wcrtomb;
45 + xrl->__mbsinit = _GBK_mbsinit;
46 + xrl->__mb_cur_max = 2;
47 + xrl->__mb_sb_limit = 128;
48 return (0);
49 }
50
51 static int
52 -_GBK_mbsinit(const mbstate_t *ps)
53 +_GBK_mbsinit(const mbstate_t *ps, locale_t loc __unused)
54 {
55
56 return (ps == NULL || ((const _GBKState *)ps)->ch == 0);
57 @@ -84,7 +83,7 @@ _gbk_check(u_int c)
58
59 static size_t
60 _GBK_mbrtowc(wchar_t * __restrict pwc, const char * __restrict s, size_t n,
61 - mbstate_t * __restrict ps)
62 + mbstate_t * __restrict ps, locale_t loc __unused)
63 {
64 _GBKState *gs;
65 wchar_t wc;
66 @@ -144,7 +143,7 @@ _GBK_mbrtowc(wchar_t * __restrict pwc, c
67 }
68
69 static size_t
70 -_GBK_wcrtomb(char * __restrict s, wchar_t wc, mbstate_t * __restrict ps)
71 +_GBK_wcrtomb(char * __restrict s, wchar_t wc, mbstate_t * __restrict ps, locale_t loc __unused)
72 {
73 _GBKState *gs;
74