Blame lib/unistr/u8-uctomb.c

Packit Service a2489d
/* Store a character in UTF-8 string.
Packit Service a2489d
   Copyright (C) 2002, 2005-2006, 2009-2018 Free Software Foundation, Inc.
Packit Service a2489d
   Written by Bruno Haible <bruno@clisp.org>, 2002.
Packit Service a2489d
Packit Service a2489d
   This program is free software: you can redistribute it and/or modify it
Packit Service a2489d
   under the terms of the GNU General Public License as published
Packit Service a2489d
   by the Free Software Foundation; either version 3 of the License, or
Packit Service a2489d
   (at your option) any later version.
Packit Service a2489d
Packit Service a2489d
   This program is distributed in the hope that it will be useful,
Packit Service a2489d
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service a2489d
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service a2489d
   General Public License for more details.
Packit Service a2489d
Packit Service a2489d
   You should have received a copy of the GNU General Public License
Packit Service a2489d
   along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
Packit Service a2489d
Packit Service a2489d
#include <config.h>
Packit Service a2489d
Packit Service a2489d
#if defined IN_LIBUNISTRING
Packit Service a2489d
/* Tell unistr.h to declare u8_uctomb as 'extern', not 'static inline'.  */
Packit Service a2489d
# include "unistring-notinline.h"
Packit Service a2489d
#endif
Packit Service a2489d
Packit Service a2489d
/* Specification.  */
Packit Service a2489d
#include "unistr.h"
Packit Service a2489d
Packit Service a2489d
#if !HAVE_INLINE
Packit Service a2489d
Packit Service a2489d
int
Packit Service a2489d
u8_uctomb (uint8_t *s, ucs4_t uc, int n)
Packit Service a2489d
{
Packit Service a2489d
  if (uc < 0x80)
Packit Service a2489d
    {
Packit Service a2489d
      if (n > 0)
Packit Service a2489d
        {
Packit Service a2489d
          s[0] = uc;
Packit Service a2489d
          return 1;
Packit Service a2489d
        }
Packit Service a2489d
      /* else return -2, below.  */
Packit Service a2489d
    }
Packit Service a2489d
  else
Packit Service a2489d
    {
Packit Service a2489d
      int count;
Packit Service a2489d
Packit Service a2489d
      if (uc < 0x800)
Packit Service a2489d
        count = 2;
Packit Service a2489d
      else if (uc < 0x10000)
Packit Service a2489d
        {
Packit Service a2489d
          if (uc < 0xd800 || uc >= 0xe000)
Packit Service a2489d
            count = 3;
Packit Service a2489d
          else
Packit Service a2489d
            return -1;
Packit Service a2489d
        }
Packit Service a2489d
      else if (uc < 0x110000)
Packit Service a2489d
        count = 4;
Packit Service a2489d
      else
Packit Service a2489d
        return -1;
Packit Service a2489d
Packit Service a2489d
      if (n >= count)
Packit Service a2489d
        {
Packit Service a2489d
          switch (count) /* note: code falls through cases! */
Packit Service a2489d
            {
Packit Service a2489d
            case 4: s[3] = 0x80 | (uc & 0x3f); uc = uc >> 6; uc |= 0x10000;
Packit Service a2489d
            case 3: s[2] = 0x80 | (uc & 0x3f); uc = uc >> 6; uc |= 0x800;
Packit Service a2489d
            case 2: s[1] = 0x80 | (uc & 0x3f); uc = uc >> 6; uc |= 0xc0;
Packit Service a2489d
          /*case 1:*/ s[0] = uc;
Packit Service a2489d
            }
Packit Service a2489d
          return count;
Packit Service a2489d
        }
Packit Service a2489d
    }
Packit Service a2489d
  return -2;
Packit Service a2489d
}
Packit Service a2489d
Packit Service a2489d
#endif