Tests for Unicode character classification functions.
[pspp] / tests / unictype / test-numeric.c
1 /* Test the Unicode character type functions.
2    Copyright (C) 2007 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           abort ();                                                          \
32         }                                                                    \
33     }                                                                        \
34   while (0)
35 #define SIZEOF(a) (sizeof(a) / sizeof(a[0]))
36
37 static const struct { unsigned int ch; int numerator; int denominator; }
38   mapping[] =
39   {
40 #include "test-numeric.h"
41   };
42
43 int
44 main ()
45 {
46   unsigned int c;
47   uc_fraction_t value;
48   size_t i;
49
50   c = 0;
51   for (i = 0; i < SIZEOF (mapping); i++)
52     {
53       for (; c < mapping[i].ch; c++)
54         {
55           value = uc_numeric_value (c);
56           ASSERT (value.numerator == 0 && value.denominator == 0);
57         }
58       /* Here c = mapping[i].ch.  */
59       value = uc_numeric_value (c);
60       ASSERT (value.numerator == mapping[i].numerator
61               && value.denominator == mapping[i].denominator);
62       c++;
63     }
64   for (; c < 0x110000; c++)
65     {
66       value = uc_numeric_value (c);
67       ASSERT (value.numerator == 0 && value.denominator == 0);
68     }
69
70   return 0;
71 }