Blame gnulib-tests/test-wcrtomb.c

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