New modules 'unistr/u8-uctomb', 'unistr/u16-uctomb', 'unistr/u32-uctomb'.
[gnulib.git] / lib / unistr / u16-uctomb.c
1 /* Store a character in UTF-16 string.
2    Copyright (C) 2002, 2005-2006 Free Software Foundation, Inc.
3    Written by Bruno Haible <bruno@clisp.org>, 2002.
4
5    This program is free software; you can redistribute it and/or modify it
6    under the terms of the GNU Library General Public License as published
7    by the Free Software Foundation; either version 2, or (at your option)
8    any later version.
9
10    This program is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Library General Public License for more details.
14
15    You should have received a copy of the GNU Library General Public
16    License along with this program; if not, write to the Free Software
17    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
18    USA.  */
19
20 #include <config.h>
21
22 /* Specification.  */
23 #include "unistr.h"
24
25 #if !HAVE_INLINE
26
27 int
28 u16_uctomb (uint16_t *s, ucs4_t uc, int n)
29 {
30   if (uc < 0xd800)
31     {
32       if (n > 0)
33         {
34           s[0] = uc;
35           return 1;
36         }
37       /* else return -2, below.  */
38     }
39   else if (uc < 0x10000)
40     {
41       if (uc >= 0xe000)
42         {
43           if (n >= 1)
44             {
45               s[0] = uc;
46               return 1;
47             }
48         }
49       else
50         return -1;
51     }
52   else
53     {
54       if (uc < 0x110000)
55         {
56           if (n >= 2)
57             {
58               s[0] = 0xd800 + ((uc - 0x10000) >> 10);
59               s[1] = 0xdc00 + ((uc - 0x10000) & 0x3ff);
60               return 2;
61             }
62         }
63       else
64         return -1;
65     }
66   return -2;
67 }
68
69 #endif