Fixed binary search: no more infinite loops when vendor is unknown.
[tangerine.git] / compiler / clib / locale / none.c
blob9d88fc0f363260d0a25ba61c6174f11e029d9c40
1 /*-
2 * Copyright (c) 2002-2004 Tim J. Robbins. All rights reserved.
3 * Copyright (c) 1993
4 * The Regents of the University of California. All rights reserved.
6 * This code is derived from software contributed to Berkeley by
7 * Paul Borman at Krystal Technologies.
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 4. Neither the name of the University nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
34 #if defined(LIBC_SCCS) && !defined(lint)
35 static char sccsid[] = "@(#)none.c 8.1 (Berkeley) 6/4/93";
36 #endif /* LIBC_SCCS and not lint */
37 #include <sys/cdefs.h>
38 __FBSDID("$FreeBSD: src/lib/libc/locale/none.c,v 1.15 2007/10/13 16:28:22 ache Exp $");
40 #include <errno.h>
41 #include <limits.h>
42 #include <runetype.h>
43 #include <stddef.h>
44 #include <stdio.h>
45 #include <stdlib.h>
46 #include <string.h>
47 #include <wchar.h>
48 #include "mblocal.h"
50 static size_t _none_mbrtowc(wchar_t * __restrict, const char * __restrict,
51 size_t, mbstate_t * __restrict);
52 static int _none_mbsinit(const mbstate_t *);
53 static size_t _none_mbsnrtowcs(wchar_t * __restrict dst,
54 const char ** __restrict src, size_t nms, size_t len,
55 mbstate_t * __restrict ps __unused);
56 static size_t _none_wcrtomb(char * __restrict, wchar_t,
57 mbstate_t * __restrict);
58 static size_t _none_wcsnrtombs(char * __restrict, const wchar_t ** __restrict,
59 size_t, size_t, mbstate_t * __restrict);
61 #ifndef __AROS__
62 /* setup defaults */
64 int __mb_cur_max = 1;
65 #endif
66 int __mb_sb_limit = 256; /* Expected to be <= _CACHED_RUNES */
68 int
69 _none_init(_RuneLocale *rl)
72 __mbrtowc = _none_mbrtowc;
73 __mbsinit = _none_mbsinit;
74 __mbsnrtowcs = _none_mbsnrtowcs;
75 __wcrtomb = _none_wcrtomb;
76 __wcsnrtombs = _none_wcsnrtombs;
77 _CurrentRuneLocale = rl;
78 __mb_cur_max = 1;
79 __mb_sb_limit = 256;
80 return(0);
83 static int
84 _none_mbsinit(const mbstate_t *ps __unused)
88 * Encoding is not state dependent - we are always in the
89 * initial state.
91 return (1);
94 static size_t
95 _none_mbrtowc(wchar_t * __restrict pwc, const char * __restrict s, size_t n,
96 mbstate_t * __restrict ps __unused)
99 if (s == NULL)
100 /* Reset to initial shift state (no-op) */
101 return (0);
102 if (n == 0)
103 /* Incomplete multibyte sequence */
104 return ((size_t)-2);
105 if (pwc != NULL)
106 *pwc = (unsigned char)*s;
107 return (*s == '\0' ? 0 : 1);
110 static size_t
111 _none_wcrtomb(char * __restrict s, wchar_t wc,
112 mbstate_t * __restrict ps __unused)
115 if (s == NULL)
116 /* Reset to initial shift state (no-op) */
117 return (1);
118 if (wc < 0 || wc > UCHAR_MAX) {
119 errno = EILSEQ;
120 return ((size_t)-1);
122 *s = (unsigned char)wc;
123 return (1);
126 static size_t
127 _none_mbsnrtowcs(wchar_t * __restrict dst, const char ** __restrict src,
128 size_t nms, size_t len, mbstate_t * __restrict ps __unused)
130 const char *s;
131 size_t nchr;
133 if (dst == NULL) {
134 s = memchr(*src, '\0', nms);
135 return (s != NULL ? s - *src : nms);
138 s = *src;
139 nchr = 0;
140 while (len-- > 0 && nms-- > 0) {
141 if ((*dst++ = (unsigned char)*s++) == L'\0') {
142 *src = NULL;
143 return (nchr);
145 nchr++;
147 *src = s;
148 return (nchr);
151 static size_t
152 _none_wcsnrtombs(char * __restrict dst, const wchar_t ** __restrict src,
153 size_t nwc, size_t len, mbstate_t * __restrict ps __unused)
155 const wchar_t *s;
156 size_t nchr;
158 if (dst == NULL) {
159 for (s = *src; nwc > 0 && *s != L'\0'; s++, nwc--) {
160 if (*s < 0 || *s > UCHAR_MAX) {
161 errno = EILSEQ;
162 return ((size_t)-1);
165 return (s - *src);
168 s = *src;
169 nchr = 0;
170 while (len-- > 0 && nwc-- > 0) {
171 if (*s < 0 || *s > UCHAR_MAX) {
172 errno = EILSEQ;
173 return ((size_t)-1);
175 if ((*dst++ = *s++) == '\0') {
176 *src = NULL;
177 return (nchr);
179 nchr++;
181 *src = s;
182 return (nchr);
185 /* setup defaults */
187 size_t (*__mbrtowc)(wchar_t * __restrict, const char * __restrict, size_t,
188 mbstate_t * __restrict) = _none_mbrtowc;
189 int (*__mbsinit)(const mbstate_t *) = _none_mbsinit;
190 size_t (*__mbsnrtowcs)(wchar_t * __restrict, const char ** __restrict,
191 size_t, size_t, mbstate_t * __restrict) = _none_mbsnrtowcs;
192 size_t (*__wcrtomb)(char * __restrict, wchar_t, mbstate_t * __restrict) =
193 _none_wcrtomb;
194 size_t (*__wcsnrtombs)(char * __restrict, const wchar_t ** __restrict,
195 size_t, size_t, mbstate_t * __restrict) = _none_wcsnrtombs;