multibyte_amd1.c revision 1.14.20.1 1 1.14.20.1 perseant /* $NetBSD: multibyte_amd1.c,v 1.14.20.1 2017/07/14 15:53:08 perseant Exp $ */
2 1.1 tshiozak
3 1.1 tshiozak /*-
4 1.6 tnozaki * Copyright (c)2002, 2008 Citrus Project,
5 1.1 tshiozak * All rights reserved.
6 1.1 tshiozak *
7 1.1 tshiozak * Redistribution and use in source and binary forms, with or without
8 1.1 tshiozak * modification, are permitted provided that the following conditions
9 1.1 tshiozak * are met:
10 1.1 tshiozak * 1. Redistributions of source code must retain the above copyright
11 1.1 tshiozak * notice, this list of conditions and the following disclaimer.
12 1.1 tshiozak * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 tshiozak * notice, this list of conditions and the following disclaimer in the
14 1.1 tshiozak * documentation and/or other materials provided with the distribution.
15 1.1 tshiozak *
16 1.1 tshiozak * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 1.1 tshiozak * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 1.1 tshiozak * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 1.1 tshiozak * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 1.1 tshiozak * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 1.1 tshiozak * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 1.1 tshiozak * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 1.1 tshiozak * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 1.1 tshiozak * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 1.1 tshiozak * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 1.1 tshiozak * SUCH DAMAGE.
27 1.1 tshiozak */
28 1.1 tshiozak
29 1.1 tshiozak #include <sys/cdefs.h>
30 1.1 tshiozak #if defined(LIBC_SCCS) && !defined(lint)
31 1.14.20.1 perseant __RCSID("$NetBSD: multibyte_amd1.c,v 1.14.20.1 2017/07/14 15:53:08 perseant Exp $");
32 1.1 tshiozak #endif /* LIBC_SCCS and not lint */
33 1.1 tshiozak
34 1.6 tnozaki #include <sys/types.h>
35 1.1 tshiozak #include <assert.h>
36 1.6 tnozaki #include <errno.h>
37 1.6 tnozaki #include <langinfo.h>
38 1.11 joerg #include <stdlib.h>
39 1.6 tnozaki #define __SETLOCALE_SOURCE__
40 1.6 tnozaki #include <locale.h>
41 1.1 tshiozak #include <wchar.h>
42 1.6 tnozaki
43 1.6 tnozaki #include "setlocale_local.h"
44 1.6 tnozaki
45 1.6 tnozaki #include "citrus_module.h"
46 1.6 tnozaki #include "citrus_ctype.h"
47 1.9 tnozaki #include "runetype_local.h"
48 1.14.20.1 perseant #include "rune_iso10646.h"
49 1.1 tshiozak #include "multibyte.h"
50 1.1 tshiozak
51 1.1 tshiozak size_t
52 1.10 joerg mbrlen_l(const char *s, size_t n, mbstate_t *ps, locale_t loc)
53 1.1 tshiozak {
54 1.1 tshiozak size_t ret;
55 1.2 yamt int err0;
56 1.1 tshiozak
57 1.10 joerg _fixup_ps(_RUNE_LOCALE(loc), ps, s == NULL);
58 1.1 tshiozak
59 1.14 joerg err0 = _citrus_ctype_mbrlen(_ps_to_ctype(ps, loc), s, n,
60 1.1 tshiozak _ps_to_private(ps), &ret);
61 1.2 yamt if (err0)
62 1.2 yamt errno = err0;
63 1.1 tshiozak
64 1.1 tshiozak return ret;
65 1.1 tshiozak }
66 1.1 tshiozak
67 1.10 joerg size_t
68 1.10 joerg mbrlen(const char *s, size_t n, mbstate_t *ps)
69 1.10 joerg {
70 1.12 joerg return mbrlen_l(s, n, ps, _current_locale());
71 1.10 joerg }
72 1.10 joerg
73 1.1 tshiozak int
74 1.10 joerg mbsinit_l(const mbstate_t *ps, locale_t loc)
75 1.1 tshiozak {
76 1.1 tshiozak int ret;
77 1.2 yamt int err0;
78 1.1 tshiozak _RuneLocale *rl;
79 1.1 tshiozak
80 1.1 tshiozak if (ps == NULL)
81 1.1 tshiozak return 1;
82 1.1 tshiozak
83 1.1 tshiozak if (_ps_to_runelocale(ps) == NULL)
84 1.10 joerg rl = _RUNE_LOCALE(loc);
85 1.1 tshiozak else
86 1.1 tshiozak rl = _ps_to_runelocale(ps);
87 1.1 tshiozak
88 1.1 tshiozak /* mbsinit should cause no error... */
89 1.2 yamt err0 = _citrus_ctype_mbsinit(rl->rl_citrus_ctype,
90 1.1 tshiozak _ps_to_private_const(ps), &ret);
91 1.3 yamt if (err0)
92 1.3 yamt errno = err0;
93 1.3 yamt
94 1.3 yamt return ret;
95 1.3 yamt }
96 1.3 yamt
97 1.10 joerg int
98 1.10 joerg mbsinit(const mbstate_t *ps)
99 1.10 joerg {
100 1.12 joerg return mbsinit_l(ps, _current_locale());
101 1.10 joerg }
102 1.10 joerg
103 1.3 yamt size_t
104 1.10 joerg mbrtowc_l(wchar_t *pwc, const char *s, size_t n, mbstate_t *ps, locale_t loc)
105 1.3 yamt {
106 1.3 yamt size_t ret;
107 1.3 yamt int err0;
108 1.3 yamt
109 1.10 joerg _fixup_ps(_RUNE_LOCALE(loc), ps, s == NULL);
110 1.3 yamt
111 1.14 joerg err0 = _citrus_ctype_mbrtowc(_ps_to_ctype(ps, loc), pwc, s, n,
112 1.3 yamt _ps_to_private(ps), &ret);
113 1.14.20.1 perseant if (err0) {
114 1.2 yamt errno = err0;
115 1.14.20.1 perseant return -1;
116 1.14.20.1 perseant }
117 1.1 tshiozak
118 1.14.20.1 perseant if (s != NULL && pwc != NULL) {
119 1.14.20.1 perseant err0 = _citrus_kuten_to_unicode(_RUNE_LOCALE(loc), *pwc, pwc);
120 1.14.20.1 perseant if (err0)
121 1.14.20.1 perseant errno = err0;
122 1.14.20.1 perseant }
123 1.14.20.1 perseant
124 1.1 tshiozak return ret;
125 1.1 tshiozak }
126 1.1 tshiozak
127 1.1 tshiozak size_t
128 1.10 joerg mbrtowc(wchar_t *pwc, const char *s, size_t n, mbstate_t *ps)
129 1.10 joerg {
130 1.12 joerg return mbrtowc_l(pwc, s, n, ps, _current_locale());
131 1.10 joerg }
132 1.10 joerg
133 1.10 joerg size_t
134 1.10 joerg mbsrtowcs_l(wchar_t *pwcs, const char **s, size_t n, mbstate_t *ps,
135 1.10 joerg locale_t loc)
136 1.1 tshiozak {
137 1.1 tshiozak size_t ret;
138 1.2 yamt int err0;
139 1.1 tshiozak
140 1.10 joerg _fixup_ps(_RUNE_LOCALE(loc), ps, s == NULL);
141 1.1 tshiozak
142 1.14 joerg err0 = _citrus_ctype_mbsrtowcs(_ps_to_ctype(ps, loc), pwcs, s, n,
143 1.1 tshiozak _ps_to_private(ps), &ret);
144 1.14.20.1 perseant if (err0) {
145 1.2 yamt errno = err0;
146 1.14.20.1 perseant return -1;
147 1.14.20.1 perseant }
148 1.14.20.1 perseant
149 1.14.20.1 perseant if (s != NULL && pwcs != NULL) {
150 1.14.20.1 perseant err0 = _citrus_wcs_kuten_to_unicode(_RUNE_LOCALE(loc), pwcs, pwcs, ret);
151 1.14.20.1 perseant if (err0)
152 1.14.20.1 perseant errno = err0;
153 1.14.20.1 perseant }
154 1.1 tshiozak
155 1.1 tshiozak return ret;
156 1.1 tshiozak }
157 1.1 tshiozak
158 1.1 tshiozak size_t
159 1.10 joerg mbsrtowcs(wchar_t *pwcs, const char **s, size_t n, mbstate_t *ps)
160 1.10 joerg {
161 1.12 joerg return mbsrtowcs_l(pwcs, s, n, ps, _current_locale());
162 1.10 joerg }
163 1.10 joerg
164 1.10 joerg size_t
165 1.13 joerg mbsnrtowcs_l(wchar_t *pwcs, const char **s, size_t in, size_t n, mbstate_t *ps,
166 1.13 joerg locale_t loc)
167 1.13 joerg {
168 1.13 joerg size_t ret;
169 1.13 joerg int err0;
170 1.13 joerg
171 1.13 joerg _fixup_ps(_RUNE_LOCALE(loc), ps, s == NULL);
172 1.13 joerg
173 1.14 joerg err0 = _citrus_ctype_mbsnrtowcs(_ps_to_ctype(ps, loc), pwcs, s, in, n,
174 1.13 joerg _ps_to_private(ps), &ret);
175 1.14.20.1 perseant if (err0) {
176 1.14.20.1 perseant errno = err0;
177 1.14.20.1 perseant return -1;
178 1.14.20.1 perseant }
179 1.14.20.1 perseant
180 1.14.20.1 perseant err0 = _citrus_wcs_kuten_to_unicode(_RUNE_LOCALE(loc), pwcs, pwcs, ret);
181 1.13 joerg if (err0)
182 1.13 joerg errno = err0;
183 1.13 joerg
184 1.13 joerg return ret;
185 1.13 joerg }
186 1.13 joerg
187 1.13 joerg size_t
188 1.13 joerg mbsnrtowcs(wchar_t *pwcs, const char **s, size_t in, size_t n, mbstate_t *ps)
189 1.13 joerg {
190 1.13 joerg return mbsnrtowcs_l(pwcs, s, in, n, ps, _current_locale());
191 1.13 joerg }
192 1.13 joerg
193 1.13 joerg size_t
194 1.10 joerg wcrtomb_l(char *s, wchar_t wc, mbstate_t *ps, locale_t loc)
195 1.1 tshiozak {
196 1.1 tshiozak size_t ret;
197 1.2 yamt int err0;
198 1.1 tshiozak
199 1.10 joerg _fixup_ps(_RUNE_LOCALE(loc), ps, s == NULL);
200 1.1 tshiozak
201 1.14.20.1 perseant err0 = _citrus_unicode_to_kuten(_RUNE_LOCALE(loc), wc, &wc);
202 1.14.20.1 perseant if (err0) {
203 1.14.20.1 perseant errno = err0;
204 1.14.20.1 perseant return -1;
205 1.14.20.1 perseant }
206 1.14.20.1 perseant
207 1.14 joerg err0 = _citrus_ctype_wcrtomb(_ps_to_ctype(ps, loc), s, wc,
208 1.1 tshiozak _ps_to_private(ps), &ret);
209 1.2 yamt if (err0)
210 1.2 yamt errno = err0;
211 1.1 tshiozak
212 1.1 tshiozak return ret;
213 1.1 tshiozak }
214 1.1 tshiozak
215 1.1 tshiozak size_t
216 1.10 joerg wcrtomb(char *s, wchar_t wc, mbstate_t *ps)
217 1.10 joerg {
218 1.12 joerg return wcrtomb_l(s, wc, ps, _current_locale());
219 1.10 joerg }
220 1.10 joerg
221 1.10 joerg size_t
222 1.10 joerg wcsrtombs_l(char *s, const wchar_t **ppwcs, size_t n, mbstate_t *ps,
223 1.10 joerg locale_t loc)
224 1.1 tshiozak {
225 1.1 tshiozak size_t ret;
226 1.2 yamt int err0;
227 1.14.20.1 perseant #ifdef __STDC_ISO_10646__
228 1.14.20.1 perseant wchar_t *wcskt, *owcskt;
229 1.14.20.1 perseant int nn;
230 1.14.20.1 perseant #endif
231 1.2 yamt
232 1.10 joerg _fixup_ps(_RUNE_LOCALE(loc), ps, s == NULL);
233 1.1 tshiozak
234 1.14.20.1 perseant #ifdef __STDC_ISO_10646__
235 1.14.20.1 perseant nn = wcsnlen(*ppwcs, n) + 1;
236 1.14.20.1 perseant owcskt = wcskt = (wchar_t *)malloc(nn * sizeof(*wcskt));
237 1.14.20.1 perseant err0 = _citrus_wcs_unicode_to_kuten(_RUNE_LOCALE(loc), *ppwcs, wcskt, nn);
238 1.14.20.1 perseant if (err0)
239 1.14.20.1 perseant ret = -1;
240 1.14.20.1 perseant else
241 1.14.20.1 perseant err0 = _citrus_ctype_wcsrtombs(_ps_to_ctype(ps, loc), s, (const wchar_t **)(void *)&wcskt, n,
242 1.14.20.1 perseant _ps_to_private(ps), &ret);
243 1.14.20.1 perseant if (wcskt == NULL)
244 1.14.20.1 perseant *ppwcs = NULL;
245 1.14.20.1 perseant else
246 1.14.20.1 perseant *ppwcs += (wcskt - owcskt);
247 1.14.20.1 perseant free(owcskt);
248 1.14.20.1 perseant #else /* ! __STDC_ISO_10646__ */
249 1.14 joerg err0 = _citrus_ctype_wcsrtombs(_ps_to_ctype(ps, loc), s, ppwcs, n,
250 1.14.20.1 perseant _ps_to_private(ps), &ret);
251 1.14.20.1 perseant #endif /* ! __STDC_ISO_10646__ */
252 1.5 tshiozak if (err0)
253 1.5 tshiozak errno = err0;
254 1.5 tshiozak
255 1.5 tshiozak return ret;
256 1.5 tshiozak }
257 1.5 tshiozak
258 1.10 joerg size_t
259 1.10 joerg wcsrtombs(char *s, const wchar_t **ppwcs, size_t n, mbstate_t *ps)
260 1.10 joerg {
261 1.12 joerg return wcsrtombs_l(s, ppwcs, n, ps, _current_locale());
262 1.10 joerg }
263 1.10 joerg
264 1.5 tshiozak wint_t
265 1.10 joerg btowc_l(int c, locale_t loc)
266 1.5 tshiozak {
267 1.5 tshiozak wint_t ret;
268 1.5 tshiozak int err0;
269 1.5 tshiozak
270 1.10 joerg err0 = _citrus_ctype_btowc(_CITRUS_CTYPE(loc), c, &ret);
271 1.14.20.1 perseant if (err0) {
272 1.14.20.1 perseant errno = err0;
273 1.14.20.1 perseant return -1;
274 1.14.20.1 perseant }
275 1.14.20.1 perseant
276 1.14.20.1 perseant err0 = _citrus_kuten_to_unicode(_RUNE_LOCALE(loc), ret, &ret);
277 1.5 tshiozak if (err0)
278 1.5 tshiozak errno = err0;
279 1.5 tshiozak
280 1.5 tshiozak return ret;
281 1.5 tshiozak }
282 1.5 tshiozak
283 1.10 joerg wint_t
284 1.10 joerg btowc(int c)
285 1.10 joerg {
286 1.12 joerg return btowc_l(c, _current_locale());
287 1.10 joerg }
288 1.10 joerg
289 1.5 tshiozak int
290 1.10 joerg wctob_l(wint_t wc, locale_t loc)
291 1.5 tshiozak {
292 1.5 tshiozak int ret;
293 1.5 tshiozak int err0;
294 1.5 tshiozak
295 1.14.20.1 perseant err0 = _citrus_unicode_to_kuten(_RUNE_LOCALE(loc), wc, &wc);
296 1.14.20.1 perseant if (err0) {
297 1.14.20.1 perseant errno = err0;
298 1.14.20.1 perseant return -1;
299 1.14.20.1 perseant }
300 1.14.20.1 perseant
301 1.10 joerg err0 = _citrus_ctype_wctob(_CITRUS_CTYPE(loc), wc, &ret);
302 1.2 yamt if (err0)
303 1.2 yamt errno = err0;
304 1.1 tshiozak
305 1.1 tshiozak return ret;
306 1.1 tshiozak }
307 1.10 joerg
308 1.10 joerg int
309 1.10 joerg wctob(wint_t wc)
310 1.10 joerg {
311 1.12 joerg return wctob_l(wc, _current_locale());
312 1.11 joerg }
313 1.11 joerg
314 1.11 joerg size_t
315 1.11 joerg _mb_cur_max_l(locale_t loc)
316 1.11 joerg {
317 1.11 joerg
318 1.11 joerg return _citrus_ctype_get_mb_cur_max(_CITRUS_CTYPE(loc));
319 1.11 joerg }
320