Blame stdlib/tst-strfmon_l.c

Packit Service 82fcde
/* Test locale dependence of strfmon_l.
Packit Service 82fcde
   Copyright (C) 2016-2018 Free Software Foundation, Inc.
Packit Service 82fcde
   This file is part of the GNU C Library.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
   modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
   License as published by the Free Software Foundation; either
Packit Service 82fcde
   version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
   Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
   You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
   License along with the GNU C Library; if not, see
Packit Service 82fcde
   <http://www.gnu.org/licenses/>.  */
Packit Service 82fcde
Packit Service 82fcde
#include <stdbool.h>
Packit Service 82fcde
#include <stdio.h>
Packit Service 82fcde
#include <monetary.h>
Packit Service 82fcde
#include <string.h>
Packit Service 82fcde
#include <stdlib.h>
Packit Service 82fcde
#include <locale.h>
Packit Service 82fcde
Packit Service 82fcde
static const char *const en_us_name = "en_US.ISO-8859-1";
Packit Service 82fcde
Packit Service 82fcde
/* Locale value to be used by tests.  */
Packit Service 82fcde
static locale_t loc;
Packit Service 82fcde
static const char *loc_name;
Packit Service 82fcde
Packit Service 82fcde
/* Set the global locale to GLOBAL_NAME, and the locale referenced by
Packit Service 82fcde
   the loc variable above to LOCAL_NAME.  */
Packit Service 82fcde
static void
Packit Service 82fcde
init_loc (const char *global_name, const char *local_name)
Packit Service 82fcde
{
Packit Service 82fcde
  loc = newlocale (LC_ALL_MASK, local_name, 0);
Packit Service 82fcde
  if (loc == 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("error: newlocale (%s): %m\n", local_name);
Packit Service 82fcde
      abort ();
Packit Service 82fcde
    }
Packit Service 82fcde
  loc_name = local_name;
Packit Service 82fcde
Packit Service 82fcde
  if (setlocale (LC_ALL, global_name) == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("error: setlocale (%s): %m\n", global_name);
Packit Service 82fcde
      abort ();
Packit Service 82fcde
    }
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
/* Expected strings for a positive or negative value.  */
Packit Service 82fcde
struct testcase
Packit Service 82fcde
{
Packit Service 82fcde
  const char *i;                /* %i */
Packit Service 82fcde
  const char *n;                /* %n */
Packit Service 82fcde
  const char *i_ungrouped;      /* %^i */
Packit Service 82fcde
  const char *n_ungrouped;      /* %^n */
Packit Service 82fcde
};
Packit Service 82fcde
Packit Service 82fcde
/* Collected expected strings for both positive and negative
Packit Service 82fcde
   values.  */
Packit Service 82fcde
struct testcase_pair
Packit Service 82fcde
{
Packit Service 82fcde
  struct testcase positive;     /* 1234567.89 */
Packit Service 82fcde
  struct testcase negative;     /* -1234567.89 */
Packit Service 82fcde
};
Packit Service 82fcde
Packit Service 82fcde
static bool errors;
Packit Service 82fcde
Packit Service 82fcde
/* Test one value using the locale loc.  */
Packit Service 82fcde
static void
Packit Service 82fcde
test_one (const char *format, double value, const char *ldformat,
Packit Service 82fcde
	  long double ldvalue, const char *expected)
Packit Service 82fcde
{
Packit Service 82fcde
  static char actual[64], actualld[64];
Packit Service 82fcde
  int result = strfmon_l (actual, sizeof (actual), loc, format, value);
Packit Service 82fcde
  int res_ld = strfmon_l (actualld, sizeof (actualld), loc, ldformat, ldvalue);
Packit Service 82fcde
  if (result < 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("error: locale %s, format \"%s\", value %g: strfmon_l: %m\n",
Packit Service 82fcde
              loc_name, format, value);
Packit Service 82fcde
      errors = true;
Packit Service 82fcde
    }
Packit Service 82fcde
  else if (res_ld < 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("error: locale %s, format \"%s\", value %Lg: strfmon_l: %m\n",
Packit Service 82fcde
	      loc_name, ldformat, ldvalue);
Packit Service 82fcde
      errors = true;
Packit Service 82fcde
    }
Packit Service 82fcde
  else if (strcmp (actual, expected) != 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("error: locale %s, format \"%s\", value %g: mismatch\n",
Packit Service 82fcde
              loc_name, format, value);
Packit Service 82fcde
      printf ("error:   expected: \"%s\"\n", expected);
Packit Service 82fcde
      printf ("error:   actual:   \"%s\"\n", actual);
Packit Service 82fcde
      errors = true;
Packit Service 82fcde
    }
Packit Service 82fcde
  else if (strcmp (actualld, expected) != 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("error: locale %s, format \"%s\", value %Lg: mismatch\n",
Packit Service 82fcde
	      loc_name, ldformat, ldvalue);
Packit Service 82fcde
      printf ("error:   expected: \"%s\"\n", expected);
Packit Service 82fcde
      printf ("error:   actual:   \"%s\"\n", actualld);
Packit Service 82fcde
      errors = true;
Packit Service 82fcde
    }
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static void
Packit Service 82fcde
test_pair (const struct testcase_pair *pair)
Packit Service 82fcde
{
Packit Service 82fcde
  double positive = 1234567.89;
Packit Service 82fcde
  long double pos = 1234567.89L;
Packit Service 82fcde
  test_one ("%i", positive, "%Li", pos, pair->positive.i);
Packit Service 82fcde
  test_one ("%n", positive, "%Ln", pos, pair->positive.n);
Packit Service 82fcde
  test_one ("%^i", positive, "%^Li", pos, pair->positive.i_ungrouped);
Packit Service 82fcde
  test_one ("%^n", positive, "%^Ln", pos, pair->positive.n_ungrouped);
Packit Service 82fcde
  double negative = -1234567.89;
Packit Service 82fcde
  long double neg = -1234567.89L;
Packit Service 82fcde
  test_one ("%i", negative, "%Li", neg, pair->negative.i);
Packit Service 82fcde
  test_one ("%n", negative, "%Ln", neg, pair->negative.n);
Packit Service 82fcde
  test_one ("%^i", negative, "%^Li", neg, pair->negative.i_ungrouped);
Packit Service 82fcde
  test_one ("%^n", negative, "%^Ln", neg, pair->negative.n_ungrouped);
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static const struct testcase_pair en_us =
Packit Service 82fcde
  {
Packit Service 82fcde
    {
Packit Service 82fcde
      "USD 1,234,567.89", "$1,234,567.89",
Packit Service 82fcde
      "USD 1234567.89", "$1234567.89"
Packit Service 82fcde
    },
Packit Service 82fcde
    {
Packit Service 82fcde
      "-USD 1,234,567.89", "-$1,234,567.89",
Packit Service 82fcde
      "-USD 1234567.89", "-$1234567.89"
Packit Service 82fcde
    }
Packit Service 82fcde
  };
Packit Service 82fcde
Packit Service 82fcde
static void
Packit Service 82fcde
test_en_us (const char *other_name)
Packit Service 82fcde
{
Packit Service 82fcde
  init_loc (other_name, en_us_name);
Packit Service 82fcde
  test_pair (&en_us);
Packit Service 82fcde
  freelocale (loc);
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
struct locale_pair
Packit Service 82fcde
{
Packit Service 82fcde
  const char *locale_name;
Packit Service 82fcde
  struct testcase_pair pair;
Packit Service 82fcde
};
Packit Service 82fcde
Packit Service 82fcde
static const struct locale_pair tests[] =
Packit Service 82fcde
  {
Packit Service 82fcde
    {
Packit Service 82fcde
      "de_DE.UTF-8",
Packit Service 82fcde
      {
Packit Service 82fcde
        {
Packit Service 82fcde
         "1.234.567,89 EUR", "1.234.567,89 \u20ac",
Packit Service 82fcde
         "1234567,89 EUR", "1234567,89 \u20ac"
Packit Service 82fcde
        },
Packit Service 82fcde
        {
Packit Service 82fcde
         "-1.234.567,89 EUR", "-1.234.567,89 \u20ac",
Packit Service 82fcde
         "-1234567,89 EUR", "-1234567,89 \u20ac"
Packit Service 82fcde
        }
Packit Service 82fcde
      },
Packit Service 82fcde
    },
Packit Service 82fcde
    {
Packit Service 82fcde
      "tg_TJ.UTF-8",
Packit Service 82fcde
      {
Packit Service 82fcde
        {
Packit Service 82fcde
          "1\u202f234\u202f567.89 TJS", "1\u202f234\u202f567.89 \u0440\u0443\u0431",
Packit Service 82fcde
          "1234567.89 TJS", "1234567.89 \u0440\u0443\u0431"
Packit Service 82fcde
        },
Packit Service 82fcde
        {
Packit Service 82fcde
          "-1\u202f234\u202f567.89 TJS", "-1\u202f234\u202f567.89 \u0440\u0443\u0431",
Packit Service 82fcde
          "-1234567.89 TJS", "-1234567.89 \u0440\u0443\u0431"
Packit Service 82fcde
        }
Packit Service 82fcde
      }
Packit Service 82fcde
    },
Packit Service 82fcde
    {
Packit Service 82fcde
      "hr_HR.UTF-8",
Packit Service 82fcde
      {
Packit Service 82fcde
        {
Packit Service 82fcde
          "HRK 1.234.567,89", "1.234.567,89 kn",
Packit Service 82fcde
          "HRK 1234567,89", "1234567,89 kn"
Packit Service 82fcde
        },
Packit Service 82fcde
        {
Packit Service 82fcde
          "-HRK 1.234.567,89", "-1.234.567,89 kn",
Packit Service 82fcde
          "-HRK 1234567,89", "-1234567,89 kn"
Packit Service 82fcde
        }
Packit Service 82fcde
      }
Packit Service 82fcde
    },
Packit Service 82fcde
    {
Packit Service 82fcde
      "hi_IN.UTF-8",
Packit Service 82fcde
      {
Packit Service 82fcde
        {
Packit Service 82fcde
          "INR12,34,567.89", "\u20b912,34,567.89",
Packit Service 82fcde
          "INR1234567.89", "\u20b91234567.89"
Packit Service 82fcde
        },
Packit Service 82fcde
        {
Packit Service 82fcde
          "-INR12,34,567.89", "-\u20b912,34,567.89",
Packit Service 82fcde
          "-INR1234567.89", "-\u20b91234567.89"
Packit Service 82fcde
        }
Packit Service 82fcde
      }
Packit Service 82fcde
    },
Packit Service 82fcde
    {
Packit Service 82fcde
      "el_GR.UTF-8",
Packit Service 82fcde
      {
Packit Service 82fcde
        {
Packit Service 82fcde
          "1.234.567,89EUR", "1.234.567,89\u20ac",
Packit Service 82fcde
          "1234567,89EUR", "1234567,89\u20ac"
Packit Service 82fcde
        },
Packit Service 82fcde
        {
Packit Service 82fcde
          "-1.234.567,89EUR", "-1.234.567,89\u20ac",
Packit Service 82fcde
          "-1234567,89EUR", "-1234567,89\u20ac",
Packit Service 82fcde
        }
Packit Service 82fcde
      }
Packit Service 82fcde
    },
Packit Service 82fcde
    {}
Packit Service 82fcde
  };
Packit Service 82fcde
Packit Service 82fcde
static int
Packit Service 82fcde
do_test (void)
Packit Service 82fcde
{
Packit Service 82fcde
  for (const struct locale_pair *test = tests;
Packit Service 82fcde
       test->locale_name != NULL; ++test)
Packit Service 82fcde
    {
Packit Service 82fcde
      init_loc (en_us_name, test->locale_name);
Packit Service 82fcde
      test_pair (&test->pair);
Packit Service 82fcde
      freelocale (loc);
Packit Service 82fcde
      test_en_us (test->locale_name);
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  return errors;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
#define TEST_FUNCTION do_test ()
Packit Service 82fcde
#include "../test-skeleton.c"