Line data Source code
1 : #include <stdio.h>
2 : #include <stdlib.h>
3 : #include <pgtypes_numeric.h>
4 : #include <pgtypes_error.h>
5 : #include <decimal.h>
6 :
7 : exec sql include ../regression;
8 :
9 : exec sql include ../printf_hack;
10 :
11 :
12 : char* nums[] = { "2E394", "-2", ".794", "3.44", "592.49E21", "-32.84e4",
13 : "2E-394", ".1E-2", "+.0", "-592.49E-07", "+32.84e-4",
14 : ".500001", "-.5000001",
15 : "1234567890123456789012345678.91", /* 30 digits should fit
16 : into decimal */
17 : "1234567890123456789012345678.921", /* 31 digits should NOT
18 : fit into decimal */
19 : "not a number",
20 : NULL};
21 :
22 :
23 : static void
24 : check_errno(void);
25 :
26 : int
27 4 : main(void)
28 : {
29 4 : char *text="error\n";
30 : char *endptr;
31 : numeric *num, *nin;
32 : decimal *dec;
33 : long l;
34 4 : int i, j, k, q, r, count = 0;
35 : double d;
36 4 : numeric **numarr = (numeric **) calloc(1, sizeof(numeric));
37 :
38 4 : ECPGdebug(1, stderr);
39 :
40 68 : for (i = 0; nums[i]; i++)
41 : {
42 64 : num = PGTYPESnumeric_from_asc(nums[i], &endptr);
43 64 : if (!num) check_errno();
44 64 : if (endptr != NULL)
45 : {
46 64 : printf("endptr of %d is not NULL\n", i);
47 64 : if (*endptr != '\0')
48 4 : printf("*endptr of %d is not \\0\n", i);
49 : }
50 64 : if (!num) continue;
51 :
52 60 : numarr = realloc(numarr, sizeof(numeric *) * (count + 1));
53 60 : numarr[count++] = num;
54 :
55 60 : text = PGTYPESnumeric_to_asc(num, -1);
56 60 : if (!text) check_errno();
57 60 : printf("num[%d,1]: %s\n", i, text); PGTYPESchar_free(text);
58 60 : text = PGTYPESnumeric_to_asc(num, 0);
59 60 : if (!text) check_errno();
60 60 : printf("num[%d,2]: %s\n", i, text); PGTYPESchar_free(text);
61 60 : text = PGTYPESnumeric_to_asc(num, 1);
62 60 : if (!text) check_errno();
63 60 : printf("num[%d,3]: %s\n", i, text); PGTYPESchar_free(text);
64 60 : text = PGTYPESnumeric_to_asc(num, 2);
65 60 : if (!text) check_errno();
66 60 : printf("num[%d,4]: %s\n", i, text); PGTYPESchar_free(text);
67 :
68 60 : nin = PGTYPESnumeric_new();
69 60 : text = PGTYPESnumeric_to_asc(nin, 2);
70 60 : if (!text) check_errno();
71 60 : printf("num[%d,5]: %s\n", i, text); PGTYPESchar_free(text);
72 :
73 60 : r = PGTYPESnumeric_to_long(num, &l);
74 60 : if (r) check_errno();
75 60 : printf("num[%d,6]: %ld (r: %d)\n", i, r?0L:l, r);
76 60 : if (r == 0)
77 : {
78 44 : r = PGTYPESnumeric_from_long(l, nin);
79 44 : if (r) check_errno();
80 44 : text = PGTYPESnumeric_to_asc(nin, 2);
81 44 : q = PGTYPESnumeric_cmp(num, nin);
82 44 : printf("num[%d,7]: %s (r: %d - cmp: %d)\n", i, text, r, q);
83 44 : PGTYPESchar_free(text);
84 : }
85 :
86 60 : r = PGTYPESnumeric_to_int(num, &k);
87 60 : if (r) check_errno();
88 60 : printf("num[%d,8]: %d (r: %d)\n", i, r?0:k, r);
89 60 : if (r == 0)
90 : {
91 44 : r = PGTYPESnumeric_from_int(k, nin);
92 44 : if (r) check_errno();
93 44 : text = PGTYPESnumeric_to_asc(nin, 2);
94 44 : q = PGTYPESnumeric_cmp(num, nin);
95 44 : printf("num[%d,9]: %s (r: %d - cmp: %d)\n", i, text, r, q);
96 44 : PGTYPESchar_free(text);
97 : }
98 :
99 60 : if (i != 6)
100 : {
101 : /* underflow does not work reliable on several archs, so not testing it here */
102 : /* this is a libc problem since we only call strtod() */
103 :
104 56 : r = PGTYPESnumeric_to_double(num, &d);
105 56 : if (r) check_errno();
106 56 : printf("num[%d,10]: ", i);
107 56 : print_double(r ? 0.0 : d);
108 56 : printf(" (r: %d)\n", r);
109 : }
110 :
111 : /* do not test double to numeric because
112 : * - extra digits are different on different architectures
113 : * - PGTYPESnumeric_from_double internally calls PGTYPESnumeric_from_asc anyway
114 : */
115 :
116 60 : dec = PGTYPESdecimal_new();
117 60 : r = PGTYPESnumeric_to_decimal(num, dec);
118 60 : if (r) check_errno();
119 : /* we have no special routine for outputting decimal, it would
120 : * convert to a numeric anyway */
121 60 : printf("num[%d,11]: - (r: %d)\n", i, r);
122 60 : if (r == 0)
123 : {
124 56 : r = PGTYPESnumeric_from_decimal(dec, nin);
125 56 : if (r) check_errno();
126 56 : text = PGTYPESnumeric_to_asc(nin, 2);
127 56 : q = PGTYPESnumeric_cmp(num, nin);
128 56 : printf("num[%d,12]: %s (r: %d - cmp: %d)\n", i, text, r, q);
129 56 : PGTYPESchar_free(text);
130 : }
131 :
132 60 : PGTYPESdecimal_free(dec);
133 60 : PGTYPESnumeric_free(nin);
134 60 : printf("\n");
135 : }
136 :
137 64 : for (i = 0; i < count; i++)
138 : {
139 960 : for (j = 0; j < count; j++)
140 : {
141 900 : numeric* a = PGTYPESnumeric_new();
142 900 : numeric* s = PGTYPESnumeric_new();
143 900 : numeric* m = PGTYPESnumeric_new();
144 900 : numeric* d = PGTYPESnumeric_new();
145 900 : r = PGTYPESnumeric_add(numarr[i], numarr[j], a);
146 900 : if (r)
147 : {
148 0 : check_errno();
149 0 : printf("r: %d\n", r);
150 : }
151 : else
152 : {
153 900 : text = PGTYPESnumeric_to_asc(a, 10);
154 900 : printf("num[a,%d,%d]: %s\n", i, j, text);
155 900 : PGTYPESchar_free(text);
156 : }
157 900 : r = PGTYPESnumeric_sub(numarr[i], numarr[j], s);
158 900 : if (r)
159 : {
160 0 : check_errno();
161 0 : printf("r: %d\n", r);
162 : }
163 : else
164 : {
165 900 : text = PGTYPESnumeric_to_asc(s, 10);
166 900 : printf("num[s,%d,%d]: %s\n", i, j, text);
167 900 : PGTYPESchar_free(text);
168 : }
169 900 : r = PGTYPESnumeric_mul(numarr[i], numarr[j], m);
170 900 : if (r)
171 : {
172 0 : check_errno();
173 0 : printf("r: %d\n", r);
174 : }
175 : else
176 : {
177 900 : text = PGTYPESnumeric_to_asc(m, 10);
178 900 : printf("num[m,%d,%d]: %s\n", i, j, text);
179 900 : PGTYPESchar_free(text);
180 : }
181 900 : r = PGTYPESnumeric_div(numarr[i], numarr[j], d);
182 900 : if (r)
183 : {
184 60 : check_errno();
185 60 : printf("r: %d\n", r);
186 : }
187 : else
188 : {
189 840 : text = PGTYPESnumeric_to_asc(d, 10);
190 840 : printf("num[d,%d,%d]: %s\n", i, j, text);
191 840 : PGTYPESchar_free(text);
192 : }
193 :
194 900 : PGTYPESnumeric_free(a);
195 900 : PGTYPESnumeric_free(s);
196 900 : PGTYPESnumeric_free(m);
197 900 : PGTYPESnumeric_free(d);
198 : }
199 : }
200 :
201 64 : for (i = 0; i < count; i++)
202 : {
203 60 : text = PGTYPESnumeric_to_asc(numarr[i], -1);
204 60 : printf("%d: %s\n", i, text);
205 60 : PGTYPESchar_free(text);
206 60 : PGTYPESnumeric_free(numarr[i]);
207 : }
208 4 : free(numarr);
209 :
210 4 : return 0;
211 : }
212 :
213 : static void
214 104 : check_errno(void)
215 : {
216 104 : switch(errno)
217 : {
218 0 : case 0:
219 0 : printf("(no errno set) - ");
220 0 : break;
221 40 : case PGTYPES_NUM_OVERFLOW:
222 40 : printf("(errno == PGTYPES_NUM_OVERFLOW) - ");
223 40 : break;
224 0 : case PGTYPES_NUM_UNDERFLOW:
225 0 : printf("(errno == PGTYPES_NUM_UNDERFLOW) - ");
226 0 : break;
227 4 : case PGTYPES_NUM_BAD_NUMERIC:
228 4 : printf("(errno == PGTYPES_NUM_BAD_NUMERIC) - ");
229 4 : break;
230 60 : case PGTYPES_NUM_DIVIDE_ZERO:
231 60 : printf("(errno == PGTYPES_NUM_DIVIDE_ZERO) - ");
232 60 : break;
233 0 : default:
234 0 : printf("(unknown errno (%d))\n", errno);
235 0 : printf("(libc: (%s)) ", strerror(errno));
236 0 : break;
237 : }
238 :
239 104 : }
|