Flush the standard error stream before aborting.
[gnulib.git] / tests / unictype / test-numeric.c
1 /* Test the Unicode character type functions.
2    Copyright (C) 2007-2008 Free Software Foundation, Inc.
3
4    This program is free software: you can redistribute it and/or modify
5    it under the terms of the GNU General Public License as published by
6    the Free Software Foundation; either version 3 of the License, or
7    (at your option) any later version.
8
9    This program is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12    GNU General Public License for more details.
13
14    You should have received a copy of the GNU General Public License
15    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
16
17 #include <config.h>
18
19 #include "unictype.h"
20
21 #include <stdio.h>
22 #include <stdlib.h>
23 #include <string.h>
24
25 #define ASSERT(expr) \
26   do                                                                         \
27     {                                                                        \
28       if (!(expr))                                                           \
29         {                                                                    \
30           fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \
31           fflush (stderr);                                                   \
32           abort ();                                                          \
33         }                                                                    \
34     }                                                                        \
35   while (0)
36 #define SIZEOF(a) (sizeof(a) / sizeof(a[0]))
37
38 static const struct { unsigned int ch; int numerator; int denominator; }
39   mapping[] =
40   {
41 #include "test-numeric.h"
42   };
43
44 int
45 main ()
46 {
47   unsigned int c;
48   uc_fraction_t value;
49   size_t i;
50
51   c = 0;
52   for (i = 0; i < SIZEOF (mapping); i++)
53     {
54       for (; c < mapping[i].ch; c++)
55         {
56           value = uc_numeric_value (c);
57           ASSERT (value.numerator == 0 && value.denominator == 0);
58         }
59       /* Here c = mapping[i].ch.  */
60       value = uc_numeric_value (c);
61       ASSERT (value.numerator == mapping[i].numerator
62               && value.denominator == mapping[i].denominator);
63       c++;
64     }
65   for (; c < 0x110000; c++)
66     {
67       value = uc_numeric_value (c);
68       ASSERT (value.numerator == 0 && value.denominator == 0);
69     }
70
71   return 0;
72 }