xref: /minix3/lib/libc/locale/__wctoint.h (revision 2fe8fb192fe7e8720e3e7a77f928da545e872a6a)
1*2fe8fb19SBen Gras /* $NetBSD: __wctoint.h,v 1.1 2001/09/28 11:25:37 yamt Exp $ */
2*2fe8fb19SBen Gras 
3*2fe8fb19SBen Gras /*-
4*2fe8fb19SBen Gras  * Copyright (c)2001 Citrus Project,
5*2fe8fb19SBen Gras  * All rights reserved.
6*2fe8fb19SBen Gras  *
7*2fe8fb19SBen Gras  * Redistribution and use in source and binary forms, with or without
8*2fe8fb19SBen Gras  * modification, are permitted provided that the following conditions
9*2fe8fb19SBen Gras  * are met:
10*2fe8fb19SBen Gras  * 1. Redistributions of source code must retain the above copyright
11*2fe8fb19SBen Gras  *    notice, this list of conditions and the following disclaimer.
12*2fe8fb19SBen Gras  * 2. Redistributions in binary form must reproduce the above copyright
13*2fe8fb19SBen Gras  *    notice, this list of conditions and the following disclaimer in the
14*2fe8fb19SBen Gras  *    documentation and/or other materials provided with the distribution.
15*2fe8fb19SBen Gras  *
16*2fe8fb19SBen Gras  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17*2fe8fb19SBen Gras  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*2fe8fb19SBen Gras  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*2fe8fb19SBen Gras  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20*2fe8fb19SBen Gras  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21*2fe8fb19SBen Gras  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22*2fe8fb19SBen Gras  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23*2fe8fb19SBen Gras  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24*2fe8fb19SBen Gras  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25*2fe8fb19SBen Gras  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*2fe8fb19SBen Gras  * SUCH DAMAGE.
27*2fe8fb19SBen Gras  *
28*2fe8fb19SBen Gras  *	$Citrus: xpg4dl/FreeBSD/lib/libc/locale/__wctoint.h,v 1.1 2001/09/21 13:52:32 yamt Exp $
29*2fe8fb19SBen Gras  */
30*2fe8fb19SBen Gras 
31*2fe8fb19SBen Gras 
32*2fe8fb19SBen Gras __inline static int
__wctoint(wchar_t wc)33*2fe8fb19SBen Gras __wctoint(wchar_t wc)
34*2fe8fb19SBen Gras {
35*2fe8fb19SBen Gras 	int n;
36*2fe8fb19SBen Gras 
37*2fe8fb19SBen Gras 	/* XXX I expect compiler to optimize this. :D */
38*2fe8fb19SBen Gras 	switch (wc) {
39*2fe8fb19SBen Gras 	case L'0': n = 0; break;
40*2fe8fb19SBen Gras 	case L'1': n = 1; break;
41*2fe8fb19SBen Gras 	case L'2': n = 2; break;
42*2fe8fb19SBen Gras 	case L'3': n = 3; break;
43*2fe8fb19SBen Gras 	case L'4': n = 4; break;
44*2fe8fb19SBen Gras 	case L'5': n = 5; break;
45*2fe8fb19SBen Gras 	case L'6': n = 6; break;
46*2fe8fb19SBen Gras 	case L'7': n = 7; break;
47*2fe8fb19SBen Gras 	case L'8': n = 8; break;
48*2fe8fb19SBen Gras 	case L'9': n = 9; break;
49*2fe8fb19SBen Gras 	case L'A': case L'a': n = 10; break;
50*2fe8fb19SBen Gras 	case L'B': case L'b': n = 11; break;
51*2fe8fb19SBen Gras 	case L'C': case L'c': n = 12; break;
52*2fe8fb19SBen Gras 	case L'D': case L'd': n = 13; break;
53*2fe8fb19SBen Gras 	case L'E': case L'e': n = 14; break;
54*2fe8fb19SBen Gras 	case L'F': case L'f': n = 15; break;
55*2fe8fb19SBen Gras 	case L'G': case L'g': n = 16; break;
56*2fe8fb19SBen Gras 	case L'H': case L'h': n = 17; break;
57*2fe8fb19SBen Gras 	case L'I': case L'i': n = 18; break;
58*2fe8fb19SBen Gras 	case L'J': case L'j': n = 19; break;
59*2fe8fb19SBen Gras 	case L'K': case L'k': n = 20; break;
60*2fe8fb19SBen Gras 	case L'L': case L'l': n = 21; break;
61*2fe8fb19SBen Gras 	case L'M': case L'm': n = 22; break;
62*2fe8fb19SBen Gras 	case L'N': case L'n': n = 23; break;
63*2fe8fb19SBen Gras 	case L'O': case L'o': n = 24; break;
64*2fe8fb19SBen Gras 	case L'P': case L'p': n = 25; break;
65*2fe8fb19SBen Gras 	case L'Q': case L'q': n = 26; break;
66*2fe8fb19SBen Gras 	case L'R': case L'r': n = 27; break;
67*2fe8fb19SBen Gras 	case L'S': case L's': n = 28; break;
68*2fe8fb19SBen Gras 	case L'T': case L't': n = 29; break;
69*2fe8fb19SBen Gras 	case L'U': case L'u': n = 30; break;
70*2fe8fb19SBen Gras 	case L'V': case L'v': n = 31; break;
71*2fe8fb19SBen Gras 	case L'W': case L'w': n = 32; break;
72*2fe8fb19SBen Gras 	case L'X': case L'x': n = 33; break;
73*2fe8fb19SBen Gras 	case L'Y': case L'y': n = 34; break;
74*2fe8fb19SBen Gras 	case L'Z': case L'z': n = 35; break;
75*2fe8fb19SBen Gras 	default: n = -1; break; /* error */
76*2fe8fb19SBen Gras 	}
77*2fe8fb19SBen Gras 
78*2fe8fb19SBen Gras 	return n;
79*2fe8fb19SBen Gras }
80