Blame gnulib-tests/test-wcrtomb.c

Packit 709fb3
/* Test of conversion of wide character to multibyte character.
Packit 709fb3
   Copyright (C) 2008-2017 Free Software Foundation, Inc.
Packit 709fb3
Packit 709fb3
   This program is free software: you can redistribute it and/or modify
Packit 709fb3
   it under the terms of the GNU General Public License as published by
Packit 709fb3
   the Free Software Foundation; either version 3 of the License, or
Packit 709fb3
   (at your option) any later version.
Packit 709fb3
Packit 709fb3
   This program is distributed in the hope that it will be useful,
Packit 709fb3
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 709fb3
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 709fb3
   GNU General Public License for more details.
Packit 709fb3
Packit 709fb3
   You should have received a copy of the GNU General Public License
Packit 709fb3
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit 709fb3
Packit 709fb3
/* Written by Bruno Haible <bruno@clisp.org>, 2008.  */
Packit 709fb3
Packit 709fb3
#include <config.h>
Packit 709fb3
Packit 709fb3
#include <wchar.h>
Packit 709fb3
Packit 709fb3
#include "signature.h"
Packit 709fb3
SIGNATURE_CHECK (wcrtomb, size_t, (char *, wchar_t, mbstate_t *));
Packit 709fb3
Packit 709fb3
#include <locale.h>
Packit 709fb3
#include <stdlib.h>
Packit 709fb3
#include <string.h>
Packit 709fb3
Packit 709fb3
#include "macros.h"
Packit 709fb3
Packit 709fb3
/* Check the multibyte character s[0..n-1].  */
Packit 709fb3
static void
Packit 709fb3
check_character (const char *s, size_t n)
Packit 709fb3
{
Packit 709fb3
  wchar_t wc;
Packit 709fb3
  char buf[64];
Packit 709fb3
  int iret;
Packit 709fb3
  size_t ret;
Packit 709fb3
Packit 709fb3
  wc = (wchar_t) 0xBADFACE;
Packit 709fb3
  iret = mbtowc (&wc, s, n);
Packit 709fb3
  ASSERT (iret == n);
Packit 709fb3
Packit 709fb3
  ret = wcrtomb (buf, wc, NULL);
Packit 709fb3
  ASSERT (ret == n);
Packit 709fb3
  ASSERT (memcmp (buf, s, n) == 0);
Packit 709fb3
Packit 709fb3
  /* Test special calling convention, passing a NULL pointer.  */
Packit 709fb3
  ret = wcrtomb (NULL, wc, NULL);
Packit 709fb3
  ASSERT (ret == 1);
Packit 709fb3
}
Packit 709fb3
Packit 709fb3
int
Packit 709fb3
main (int argc, char *argv[])
Packit 709fb3
{
Packit 709fb3
  char buf[64];
Packit 709fb3
  size_t ret;
Packit 709fb3
Packit 709fb3
  /* configure should already have checked that the locale is supported.  */
Packit 709fb3
  if (setlocale (LC_ALL, "") == NULL)
Packit 709fb3
    return 1;
Packit 709fb3
Packit 709fb3
  /* Test NUL character.  */
Packit 709fb3
  {
Packit 709fb3
    buf[0] = 'x';
Packit 709fb3
    ret = wcrtomb (buf, 0, NULL);
Packit 709fb3
    ASSERT (ret == 1);
Packit 709fb3
    ASSERT (buf[0] == '\0');
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  /* Test single bytes.  */
Packit 709fb3
  {
Packit 709fb3
    int c;
Packit 709fb3
Packit 709fb3
    for (c = 0; c < 0x100; c++)
Packit 709fb3
      switch (c)
Packit 709fb3
        {
Packit 709fb3
        case '\t': case '\v': case '\f':
Packit 709fb3
        case ' ': case '!': case '"': case '#': case '%':
Packit 709fb3
        case '&': case '\'': case '(': case ')': case '*':
Packit 709fb3
        case '+': case ',': case '-': case '.': case '/':
Packit 709fb3
        case '0': case '1': case '2': case '3': case '4':
Packit 709fb3
        case '5': case '6': case '7': case '8': case '9':
Packit 709fb3
        case ':': case ';': case '<': case '=': case '>':
Packit 709fb3
        case '?':
Packit 709fb3
        case 'A': case 'B': case 'C': case 'D': case 'E':
Packit 709fb3
        case 'F': case 'G': case 'H': case 'I': case 'J':
Packit 709fb3
        case 'K': case 'L': case 'M': case 'N': case 'O':
Packit 709fb3
        case 'P': case 'Q': case 'R': case 'S': case 'T':
Packit 709fb3
        case 'U': case 'V': case 'W': case 'X': case 'Y':
Packit 709fb3
        case 'Z':
Packit 709fb3
        case '[': case '\\': case ']': case '^': case '_':
Packit 709fb3
        case 'a': case 'b': case 'c': case 'd': case 'e':
Packit 709fb3
        case 'f': case 'g': case 'h': case 'i': case 'j':
Packit 709fb3
        case 'k': case 'l': case 'm': case 'n': case 'o':
Packit 709fb3
        case 'p': case 'q': case 'r': case 's': case 't':
Packit 709fb3
        case 'u': case 'v': case 'w': case 'x': case 'y':
Packit 709fb3
        case 'z': case '{': case '|': case '}': case '~':
Packit 709fb3
          /* c is in the ISO C "basic character set".  */
Packit 709fb3
          ret = wcrtomb (buf, btowc (c), NULL);
Packit 709fb3
          ASSERT (ret == 1);
Packit 709fb3
          ASSERT (buf[0] == (char) c);
Packit 709fb3
          break;
Packit 709fb3
        }
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  /* Test special calling convention, passing a NULL pointer.  */
Packit 709fb3
  {
Packit 709fb3
    ret = wcrtomb (NULL, '\0', NULL);
Packit 709fb3
    ASSERT (ret == 1);
Packit 709fb3
    ret = wcrtomb (NULL, btowc ('x'), NULL);
Packit 709fb3
    ASSERT (ret == 1);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  if (argc > 1)
Packit 709fb3
    switch (argv[1][0])
Packit 709fb3
      {
Packit 709fb3
      case '1':
Packit 709fb3
        /* Locale encoding is ISO-8859-1 or ISO-8859-15.  */
Packit 709fb3
        {
Packit 709fb3
          const char input[] = "B\374\337er"; /* "Büßer" */
Packit 709fb3
Packit 709fb3
          check_character (input + 1, 1);
Packit 709fb3
          check_character (input + 2, 1);
Packit 709fb3
        }
Packit 709fb3
        return 0;
Packit 709fb3
Packit 709fb3
      case '2':
Packit 709fb3
        /* Locale encoding is UTF-8.  */
Packit 709fb3
        {
Packit 709fb3
          const char input[] = "B\303\274\303\237er"; /* "Büßer" */
Packit 709fb3
Packit 709fb3
          check_character (input + 1, 2);
Packit 709fb3
          check_character (input + 3, 2);
Packit 709fb3
        }
Packit 709fb3
        return 0;
Packit 709fb3
Packit 709fb3
      case '3':
Packit 709fb3
        /* Locale encoding is EUC-JP.  */
Packit 709fb3
        {
Packit 709fb3
          const char input[] = "<\306\374\313\334\270\354>"; /* "<日本語>" */
Packit 709fb3
Packit 709fb3
          check_character (input + 1, 2);
Packit 709fb3
          check_character (input + 3, 2);
Packit 709fb3
          check_character (input + 5, 2);
Packit 709fb3
        }
Packit 709fb3
        return 0;
Packit 709fb3
Packit 709fb3
      case '4':
Packit 709fb3
        /* Locale encoding is GB18030.  */
Packit 709fb3
        {
Packit 709fb3
          const char input[] = "B\250\271\201\060\211\070er"; /* "Büßer" */
Packit 709fb3
Packit 709fb3
          check_character (input + 1, 2);
Packit 709fb3
          check_character (input + 3, 4);
Packit 709fb3
        }
Packit 709fb3
        return 0;
Packit 709fb3
      }
Packit 709fb3
Packit 709fb3
  return 1;
Packit 709fb3
}