xref: /Universal-ctags/gnulib/mbsinit.c (revision 820c1a8d46849a90376d8eb15b319ac05439f656)
1*820c1a8dSHiroo HAYASHI /* Test for initial conversion state.
2*820c1a8dSHiroo HAYASHI    Copyright (C) 2008-2021 Free Software Foundation, Inc.
3*820c1a8dSHiroo HAYASHI    Written by Bruno Haible <bruno@clisp.org>, 2008.
4*820c1a8dSHiroo HAYASHI 
5*820c1a8dSHiroo HAYASHI    This file is free software: you can redistribute it and/or modify
6*820c1a8dSHiroo HAYASHI    it under the terms of the GNU Lesser General Public License as
7*820c1a8dSHiroo HAYASHI    published by the Free Software Foundation; either version 2.1 of the
8*820c1a8dSHiroo HAYASHI    License, or (at your option) any later version.
9*820c1a8dSHiroo HAYASHI 
10*820c1a8dSHiroo HAYASHI    This file is distributed in the hope that it will be useful,
11*820c1a8dSHiroo HAYASHI    but WITHOUT ANY WARRANTY; without even the implied warranty of
12*820c1a8dSHiroo HAYASHI    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13*820c1a8dSHiroo HAYASHI    GNU Lesser General Public License for more details.
14*820c1a8dSHiroo HAYASHI 
15*820c1a8dSHiroo HAYASHI    You should have received a copy of the GNU Lesser General Public License
16*820c1a8dSHiroo HAYASHI    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
17*820c1a8dSHiroo HAYASHI 
18*820c1a8dSHiroo HAYASHI #include <config.h>
19*820c1a8dSHiroo HAYASHI 
20*820c1a8dSHiroo HAYASHI /* Specification.  */
21*820c1a8dSHiroo HAYASHI #include <wchar.h>
22*820c1a8dSHiroo HAYASHI 
23*820c1a8dSHiroo HAYASHI #include "verify.h"
24*820c1a8dSHiroo HAYASHI 
25*820c1a8dSHiroo HAYASHI #if GNULIB_defined_mbstate_t
26*820c1a8dSHiroo HAYASHI 
27*820c1a8dSHiroo HAYASHI /* Platforms that lack mbsinit() also lack mbrlen(), mbrtowc(), mbsrtowcs()
28*820c1a8dSHiroo HAYASHI    and wcrtomb(), wcsrtombs().
29*820c1a8dSHiroo HAYASHI    We assume that
30*820c1a8dSHiroo HAYASHI      - sizeof (mbstate_t) >= 4,
31*820c1a8dSHiroo HAYASHI      - only stateless encodings are supported (such as UTF-8 and EUC-JP, but
32*820c1a8dSHiroo HAYASHI        not ISO-2022 variants),
33*820c1a8dSHiroo HAYASHI      - for each encoding, the number of bytes for a wide character is <= 4.
34*820c1a8dSHiroo HAYASHI        (This maximum is attained for UTF-8, GB18030, EUC-TW.)
35*820c1a8dSHiroo HAYASHI    We define the meaning of mbstate_t as follows:
36*820c1a8dSHiroo HAYASHI      - In mb -> wc direction, mbstate_t's first byte contains the number of
37*820c1a8dSHiroo HAYASHI        buffered bytes (in the range 0..3), followed by up to 3 buffered bytes.
38*820c1a8dSHiroo HAYASHI        See mbrtowc.c.
39*820c1a8dSHiroo HAYASHI      - In wc -> mb direction, mbstate_t contains no information. In other
40*820c1a8dSHiroo HAYASHI        words, it is always in the initial state.  */
41*820c1a8dSHiroo HAYASHI 
42*820c1a8dSHiroo HAYASHI verify (sizeof (mbstate_t) >= 4);
43*820c1a8dSHiroo HAYASHI 
44*820c1a8dSHiroo HAYASHI int
mbsinit(const mbstate_t * ps)45*820c1a8dSHiroo HAYASHI mbsinit (const mbstate_t *ps)
46*820c1a8dSHiroo HAYASHI {
47*820c1a8dSHiroo HAYASHI   const char *pstate = (const char *)ps;
48*820c1a8dSHiroo HAYASHI 
49*820c1a8dSHiroo HAYASHI   return pstate == NULL || pstate[0] == 0;
50*820c1a8dSHiroo HAYASHI }
51*820c1a8dSHiroo HAYASHI 
52*820c1a8dSHiroo HAYASHI #else
53*820c1a8dSHiroo HAYASHI 
54*820c1a8dSHiroo HAYASHI int
mbsinit(const mbstate_t * ps)55*820c1a8dSHiroo HAYASHI mbsinit (const mbstate_t *ps)
56*820c1a8dSHiroo HAYASHI {
57*820c1a8dSHiroo HAYASHI # if defined _WIN32 && !defined __CYGWIN__
58*820c1a8dSHiroo HAYASHI   /* Native Windows.  */
59*820c1a8dSHiroo HAYASHI   /* MSVC defines 'mbstate_t' as an 8-byte struct; the first 4 bytes matter.
60*820c1a8dSHiroo HAYASHI      On mingw, 'mbstate_t' is sometimes defined as 'int', sometimes defined as
61*820c1a8dSHiroo HAYASHI      an 8-byte struct, of which the first 4 bytes matter.  */
62*820c1a8dSHiroo HAYASHI   return ps == NULL || *(const unsigned int *)ps == 0;
63*820c1a8dSHiroo HAYASHI # else
64*820c1a8dSHiroo HAYASHI   /* Minix, HP-UX 11.00, Solaris 2.6, Interix, ...  */
65*820c1a8dSHiroo HAYASHI   /* Maybe this definition works, maybe not...  */
66*820c1a8dSHiroo HAYASHI   return ps == NULL || *(const char *)ps == 0;
67*820c1a8dSHiroo HAYASHI # endif
68*820c1a8dSHiroo HAYASHI }
69*820c1a8dSHiroo HAYASHI 
70*820c1a8dSHiroo HAYASHI #endif
71