1 /* Test of POSIX compatible vsnprintf() and snprintf() functions.
2 Copyright (C) 2007-2020 Free Software Foundation, Inc.
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.
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.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <https://www.gnu.org/licenses/>. */
17 /* Written by Bruno Haible <bruno@clisp.org>, 2007. */
19 #include "minus-zero.h"
23 /* The SGI MIPS floating-point format does not distinguish 0.0 and -0.0. */
27 static double plus_zero
= 0.0;
28 double minus_zero
= minus_zerod
;
29 return memcmp (&plus_zero
, &minus_zero
, sizeof (double)) != 0;
32 /* Representation of an 80-bit 'long double' as an initializer for a sequence
33 of 'unsigned int' words. */
34 #ifdef WORDS_BIGENDIAN
35 # define LDBL80_WORDS(exponent,manthi,mantlo) \
36 { ((unsigned int) (exponent) << 16) | ((unsigned int) (manthi) >> 16), \
37 ((unsigned int) (manthi) << 16) | ((unsigned int) (mantlo) >> 16), \
38 (unsigned int) (mantlo) << 16 \
41 # define LDBL80_WORDS(exponent,manthi,mantlo) \
42 { mantlo, manthi, exponent }
46 strmatch (const char *pattern
, const char *string
)
48 if (strlen (pattern
) != strlen (string
))
50 for (; *pattern
!= '\0'; pattern
++, string
++)
51 if (*pattern
!= '*' && *string
!= *pattern
)
56 /* Test whether string[start_index..end_index-1] is a valid textual
57 representation of NaN. */
59 strisnan (const char *string
, size_t start_index
, size_t end_index
, int uppercase
)
61 if (start_index
< end_index
)
63 if (string
[start_index
] == '-')
65 if (start_index
+ 3 <= end_index
66 && memcmp (string
+ start_index
, uppercase
? "NAN" : "nan", 3) == 0)
69 if (start_index
== end_index
70 || (string
[start_index
] == '(' && string
[end_index
- 1] == ')'))
78 test_function (int (*my_snprintf
) (char *, size_t, const char *, ...))
84 /* Test return value convention. */
86 for (size
= 0; size
<= 8; size
++)
90 memcpy (buf
, "DEADBEEF", 8);
91 retval
= my_snprintf (buf
, size
, "%d", 12345);
97 ASSERT (memcmp (buf
, "12345", size
- 1) == 0);
98 ASSERT (buf
[size
- 1] == '\0');
100 ASSERT (memcmp (buf
+ size
, &"DEADBEEF"[size
], 8 - size
) == 0);
104 ASSERT (memcmp (buf
, "12345\0EF", 8) == 0);
108 /* Test support of size specifiers as in C99. */
112 my_snprintf (result
, sizeof (result
), "%ju %d", (uintmax_t) 12345671, 33, 44, 55);
113 ASSERT (strcmp (result
, "12345671 33") == 0);
114 ASSERT (retval
== strlen (result
));
119 my_snprintf (result
, sizeof (result
), "%zu %d", (size_t) 12345672, 33, 44, 55);
120 ASSERT (strcmp (result
, "12345672 33") == 0);
121 ASSERT (retval
== strlen (result
));
126 my_snprintf (result
, sizeof (result
), "%tu %d", (ptrdiff_t) 12345673, 33, 44, 55);
127 ASSERT (strcmp (result
, "12345673 33") == 0);
128 ASSERT (retval
== strlen (result
));
133 my_snprintf (result
, sizeof (result
), "%Lg %d", (long double) 1.5, 33, 44, 55);
134 ASSERT (strcmp (result
, "1.5 33") == 0);
135 ASSERT (retval
== strlen (result
));
138 /* Test the support of the 'a' and 'A' conversion specifier for hexadecimal
139 output of floating-point numbers. */
141 { /* A positive number. */
143 my_snprintf (result
, sizeof (result
), "%a %d", 3.1416015625, 33, 44, 55);
144 ASSERT (strcmp (result
, "0x1.922p+1 33") == 0
145 || strcmp (result
, "0x3.244p+0 33") == 0
146 || strcmp (result
, "0x6.488p-1 33") == 0
147 || strcmp (result
, "0xc.91p-2 33") == 0);
148 ASSERT (retval
== strlen (result
));
151 { /* A negative number. */
153 my_snprintf (result
, sizeof (result
), "%A %d", -3.1416015625, 33, 44, 55);
154 ASSERT (strcmp (result
, "-0X1.922P+1 33") == 0
155 || strcmp (result
, "-0X3.244P+0 33") == 0
156 || strcmp (result
, "-0X6.488P-1 33") == 0
157 || strcmp (result
, "-0XC.91P-2 33") == 0);
158 ASSERT (retval
== strlen (result
));
161 { /* Positive zero. */
163 my_snprintf (result
, sizeof (result
), "%a %d", 0.0, 33, 44, 55);
164 ASSERT (strcmp (result
, "0x0p+0 33") == 0);
165 ASSERT (retval
== strlen (result
));
168 { /* Negative zero. */
170 my_snprintf (result
, sizeof (result
), "%a %d", minus_zerod
, 33, 44, 55);
171 if (have_minus_zero ())
172 ASSERT (strcmp (result
, "-0x0p+0 33") == 0);
173 ASSERT (retval
== strlen (result
));
176 { /* Positive infinity. */
178 my_snprintf (result
, sizeof (result
), "%a %d", Infinityd (), 33, 44, 55);
179 ASSERT (strcmp (result
, "inf 33") == 0);
180 ASSERT (retval
== strlen (result
));
183 { /* Negative infinity. */
185 my_snprintf (result
, sizeof (result
), "%a %d", - Infinityd (), 33, 44, 55);
186 ASSERT (strcmp (result
, "-inf 33") == 0);
187 ASSERT (retval
== strlen (result
));
192 my_snprintf (result
, sizeof (result
), "%a %d", NaNd (), 33, 44, 55);
193 ASSERT (strlen (result
) >= 3 + 3
194 && strisnan (result
, 0, strlen (result
) - 3, 0)
195 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
196 ASSERT (retval
== strlen (result
));
199 { /* Rounding near the decimal point. */
201 my_snprintf (result
, sizeof (result
), "%.0a %d", 1.5, 33, 44, 55);
202 ASSERT (strcmp (result
, "0x2p+0 33") == 0
203 || strcmp (result
, "0x3p-1 33") == 0
204 || strcmp (result
, "0x6p-2 33") == 0
205 || strcmp (result
, "0xcp-3 33") == 0);
206 ASSERT (retval
== strlen (result
));
209 { /* Rounding with precision 0. */
211 my_snprintf (result
, sizeof (result
), "%.0a %d", 1.51, 33, 44, 55);
212 ASSERT (strcmp (result
, "0x2p+0 33") == 0
213 || strcmp (result
, "0x3p-1 33") == 0
214 || strcmp (result
, "0x6p-2 33") == 0
215 || strcmp (result
, "0xcp-3 33") == 0);
216 ASSERT (retval
== strlen (result
));
219 { /* Rounding with precision 1. */
221 my_snprintf (result
, sizeof (result
), "%.1a %d", 1.51, 33, 44, 55);
222 ASSERT (strcmp (result
, "0x1.8p+0 33") == 0
223 || strcmp (result
, "0x3.0p-1 33") == 0
224 || strcmp (result
, "0x6.1p-2 33") == 0
225 || strcmp (result
, "0xc.1p-3 33") == 0);
226 ASSERT (retval
== strlen (result
));
229 { /* Rounding with precision 2. */
231 my_snprintf (result
, sizeof (result
), "%.2a %d", 1.51, 33, 44, 55);
232 ASSERT (strcmp (result
, "0x1.83p+0 33") == 0
233 || strcmp (result
, "0x3.05p-1 33") == 0
234 || strcmp (result
, "0x6.0ap-2 33") == 0
235 || strcmp (result
, "0xc.14p-3 33") == 0);
236 ASSERT (retval
== strlen (result
));
239 { /* Rounding with precision 3. */
241 my_snprintf (result
, sizeof (result
), "%.3a %d", 1.51, 33, 44, 55);
242 ASSERT (strcmp (result
, "0x1.829p+0 33") == 0
243 || strcmp (result
, "0x3.052p-1 33") == 0
244 || strcmp (result
, "0x6.0a4p-2 33") == 0
245 || strcmp (result
, "0xc.148p-3 33") == 0);
246 ASSERT (retval
== strlen (result
));
249 { /* Rounding can turn a ...FFF into a ...000. */
251 my_snprintf (result
, sizeof (result
), "%.3a %d", 1.49999, 33, 44, 55);
252 ASSERT (strcmp (result
, "0x1.800p+0 33") == 0
253 || strcmp (result
, "0x3.000p-1 33") == 0
254 || strcmp (result
, "0x6.000p-2 33") == 0
255 || strcmp (result
, "0xc.000p-3 33") == 0);
256 ASSERT (retval
== strlen (result
));
259 { /* Rounding can turn a ...FFF into a ...000.
260 This shows a Mac OS X 10.3.9 (Darwin 7.9) bug. */
262 my_snprintf (result
, sizeof (result
), "%.1a %d", 1.999, 33, 44, 55);
263 ASSERT (strcmp (result
, "0x1.0p+1 33") == 0
264 || strcmp (result
, "0x2.0p+0 33") == 0
265 || strcmp (result
, "0x4.0p-1 33") == 0
266 || strcmp (result
, "0x8.0p-2 33") == 0);
267 ASSERT (retval
== strlen (result
));
272 my_snprintf (result
, sizeof (result
), "%10a %d", 1.75, 33, 44, 55);
273 ASSERT (strcmp (result
, " 0x1.cp+0 33") == 0
274 || strcmp (result
, " 0x3.8p-1 33") == 0
275 || strcmp (result
, " 0x7p-2 33") == 0
276 || strcmp (result
, " 0xep-3 33") == 0);
277 ASSERT (retval
== strlen (result
));
280 { /* Small precision. */
282 my_snprintf (result
, sizeof (result
), "%.10a %d", 1.75, 33, 44, 55);
283 ASSERT (strcmp (result
, "0x1.c000000000p+0 33") == 0
284 || strcmp (result
, "0x3.8000000000p-1 33") == 0
285 || strcmp (result
, "0x7.0000000000p-2 33") == 0
286 || strcmp (result
, "0xe.0000000000p-3 33") == 0);
287 ASSERT (retval
== strlen (result
));
290 { /* Large precision. */
292 my_snprintf (result
, sizeof (result
), "%.50a %d", 1.75, 33, 44, 55);
293 ASSERT (strcmp (result
, "0x1.c0000000000000000000000000000000000000000000000000p+0 33") == 0
294 || strcmp (result
, "0x3.80000000000000000000000000000000000000000000000000p-1 33") == 0
295 || strcmp (result
, "0x7.00000000000000000000000000000000000000000000000000p-2 33") == 0
296 || strcmp (result
, "0xe.00000000000000000000000000000000000000000000000000p-3 33") == 0);
297 ASSERT (retval
== strlen (result
));
302 my_snprintf (result
, sizeof (result
), "%-10a %d", 1.75, 33, 44, 55);
303 ASSERT (strcmp (result
, "0x1.cp+0 33") == 0
304 || strcmp (result
, "0x3.8p-1 33") == 0
305 || strcmp (result
, "0x7p-2 33") == 0
306 || strcmp (result
, "0xep-3 33") == 0);
307 ASSERT (retval
== strlen (result
));
310 { /* FLAG_SHOWSIGN. */
312 my_snprintf (result
, sizeof (result
), "%+a %d", 1.75, 33, 44, 55);
313 ASSERT (strcmp (result
, "+0x1.cp+0 33") == 0
314 || strcmp (result
, "+0x3.8p-1 33") == 0
315 || strcmp (result
, "+0x7p-2 33") == 0
316 || strcmp (result
, "+0xep-3 33") == 0);
317 ASSERT (retval
== strlen (result
));
322 my_snprintf (result
, sizeof (result
), "% a %d", 1.75, 33, 44, 55);
323 ASSERT (strcmp (result
, " 0x1.cp+0 33") == 0
324 || strcmp (result
, " 0x3.8p-1 33") == 0
325 || strcmp (result
, " 0x7p-2 33") == 0
326 || strcmp (result
, " 0xep-3 33") == 0);
327 ASSERT (retval
== strlen (result
));
332 my_snprintf (result
, sizeof (result
), "%#a %d", 1.75, 33, 44, 55);
333 ASSERT (strcmp (result
, "0x1.cp+0 33") == 0
334 || strcmp (result
, "0x3.8p-1 33") == 0
335 || strcmp (result
, "0x7.p-2 33") == 0
336 || strcmp (result
, "0xe.p-3 33") == 0);
337 ASSERT (retval
== strlen (result
));
342 my_snprintf (result
, sizeof (result
), "%#a %d", 1.0, 33, 44, 55);
343 ASSERT (strcmp (result
, "0x1.p+0 33") == 0
344 || strcmp (result
, "0x2.p-1 33") == 0
345 || strcmp (result
, "0x4.p-2 33") == 0
346 || strcmp (result
, "0x8.p-3 33") == 0);
347 ASSERT (retval
== strlen (result
));
350 { /* FLAG_ZERO with finite number. */
352 my_snprintf (result
, sizeof (result
), "%010a %d", 1.75, 33, 44, 55);
353 ASSERT (strcmp (result
, "0x001.cp+0 33") == 0
354 || strcmp (result
, "0x003.8p-1 33") == 0
355 || strcmp (result
, "0x00007p-2 33") == 0
356 || strcmp (result
, "0x0000ep-3 33") == 0);
357 ASSERT (retval
== strlen (result
));
360 { /* FLAG_ZERO with infinite number. */
362 my_snprintf (result
, sizeof (result
), "%010a %d", Infinityd (), 33, 44, 55);
363 /* "0000000inf 33" is not a valid result; see
364 <https://lists.gnu.org/r/bug-gnulib/2007-04/msg00107.html> */
365 ASSERT (strcmp (result
, " inf 33") == 0);
366 ASSERT (retval
== strlen (result
));
369 { /* FLAG_ZERO with NaN. */
371 my_snprintf (result
, sizeof (result
), "%050a %d", NaNd (), 33, 44, 55);
372 /* "0000000nan 33" is not a valid result; see
373 <https://lists.gnu.org/r/bug-gnulib/2007-04/msg00107.html> */
374 ASSERT (strlen (result
) == 50 + 3
375 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
376 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
377 ASSERT (retval
== strlen (result
));
380 { /* A positive number. */
382 my_snprintf (result
, sizeof (result
), "%La %d", 3.1416015625L, 33, 44, 55);
383 ASSERT (strcmp (result
, "0x1.922p+1 33") == 0
384 || strcmp (result
, "0x3.244p+0 33") == 0
385 || strcmp (result
, "0x6.488p-1 33") == 0
386 || strcmp (result
, "0xc.91p-2 33") == 0);
387 ASSERT (retval
== strlen (result
));
390 { /* A negative number. */
392 my_snprintf (result
, sizeof (result
), "%LA %d", -3.1416015625L, 33, 44, 55);
393 ASSERT (strcmp (result
, "-0X1.922P+1 33") == 0
394 || strcmp (result
, "-0X3.244P+0 33") == 0
395 || strcmp (result
, "-0X6.488P-1 33") == 0
396 || strcmp (result
, "-0XC.91P-2 33") == 0);
397 ASSERT (retval
== strlen (result
));
400 { /* Positive zero. */
402 my_snprintf (result
, sizeof (result
), "%La %d", 0.0L, 33, 44, 55);
403 ASSERT (strcmp (result
, "0x0p+0 33") == 0);
404 ASSERT (retval
== strlen (result
));
407 { /* Negative zero. */
409 my_snprintf (result
, sizeof (result
), "%La %d", minus_zerol
, 33, 44, 55);
410 if (have_minus_zero ())
411 ASSERT (strcmp (result
, "-0x0p+0 33") == 0);
412 ASSERT (retval
== strlen (result
));
415 { /* Positive infinity. */
417 my_snprintf (result
, sizeof (result
), "%La %d", Infinityl (), 33, 44, 55);
418 ASSERT (strcmp (result
, "inf 33") == 0);
419 ASSERT (retval
== strlen (result
));
422 { /* Negative infinity. */
424 my_snprintf (result
, sizeof (result
), "%La %d", - Infinityl (), 33, 44, 55);
425 ASSERT (strcmp (result
, "-inf 33") == 0);
426 ASSERT (retval
== strlen (result
));
431 my_snprintf (result
, sizeof (result
), "%La %d", NaNl (), 33, 44, 55);
432 ASSERT (strlen (result
) >= 3 + 3
433 && strisnan (result
, 0, strlen (result
) - 3, 0)
434 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
435 ASSERT (retval
== strlen (result
));
437 #if CHECK_PRINTF_SAFE && ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
439 static union { unsigned int word
[4]; long double value
; } x
=
440 { LDBL80_WORDS (0xFFFF, 0xC3333333, 0x00000000) };
442 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
443 ASSERT (strlen (result
) >= 3 + 3
444 && strisnan (result
, 0, strlen (result
) - 3, 0)
445 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
446 ASSERT (retval
== strlen (result
));
449 /* Signalling NaN. */
450 static union { unsigned int word
[4]; long double value
; } x
=
451 { LDBL80_WORDS (0xFFFF, 0x83333333, 0x00000000) };
453 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
454 ASSERT (strlen (result
) >= 3 + 3
455 && strisnan (result
, 0, strlen (result
) - 3, 0)
456 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
457 ASSERT (retval
== strlen (result
));
459 /* snprintf should print something for noncanonical values. */
461 static union { unsigned int word
[4]; long double value
; } x
=
462 { LDBL80_WORDS (0xFFFF, 0x40000001, 0x00000000) };
464 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
465 ASSERT (retval
== strlen (result
));
466 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
468 { /* Pseudo-Infinity. */
469 static union { unsigned int word
[4]; long double value
; } x
=
470 { LDBL80_WORDS (0xFFFF, 0x00000000, 0x00000000) };
472 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
473 ASSERT (retval
== strlen (result
));
474 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
477 static union { unsigned int word
[4]; long double value
; } x
=
478 { LDBL80_WORDS (0x4004, 0x00000000, 0x00000000) };
480 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
481 ASSERT (retval
== strlen (result
));
482 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
484 { /* Unnormalized number. */
485 static union { unsigned int word
[4]; long double value
; } x
=
486 { LDBL80_WORDS (0x4000, 0x63333333, 0x00000000) };
488 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
489 ASSERT (retval
== strlen (result
));
490 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
492 { /* Pseudo-Denormal. */
493 static union { unsigned int word
[4]; long double value
; } x
=
494 { LDBL80_WORDS (0x0000, 0x83333333, 0x00000000) };
496 my_snprintf (result
, sizeof (result
), "%La %d", x
.value
, 33, 44, 55);
497 ASSERT (retval
== strlen (result
));
498 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
502 { /* Rounding near the decimal point. */
504 my_snprintf (result
, sizeof (result
), "%.0La %d", 1.5L, 33, 44, 55);
505 ASSERT (strcmp (result
, "0x2p+0 33") == 0
506 || strcmp (result
, "0x3p-1 33") == 0
507 || strcmp (result
, "0x6p-2 33") == 0
508 || strcmp (result
, "0xcp-3 33") == 0);
509 ASSERT (retval
== strlen (result
));
512 { /* Rounding with precision 0. */
514 my_snprintf (result
, sizeof (result
), "%.0La %d", 1.51L, 33, 44, 55);
515 ASSERT (strcmp (result
, "0x2p+0 33") == 0
516 || strcmp (result
, "0x3p-1 33") == 0
517 || strcmp (result
, "0x6p-2 33") == 0
518 || strcmp (result
, "0xcp-3 33") == 0);
519 ASSERT (retval
== strlen (result
));
522 { /* Rounding with precision 1. */
524 my_snprintf (result
, sizeof (result
), "%.1La %d", 1.51L, 33, 44, 55);
525 ASSERT (strcmp (result
, "0x1.8p+0 33") == 0
526 || strcmp (result
, "0x3.0p-1 33") == 0
527 || strcmp (result
, "0x6.1p-2 33") == 0
528 || strcmp (result
, "0xc.1p-3 33") == 0);
529 ASSERT (retval
== strlen (result
));
532 { /* Rounding with precision 2. */
534 my_snprintf (result
, sizeof (result
), "%.2La %d", 1.51L, 33, 44, 55);
535 ASSERT (strcmp (result
, "0x1.83p+0 33") == 0
536 || strcmp (result
, "0x3.05p-1 33") == 0
537 || strcmp (result
, "0x6.0ap-2 33") == 0
538 || strcmp (result
, "0xc.14p-3 33") == 0);
539 ASSERT (retval
== strlen (result
));
542 { /* Rounding with precision 3. */
544 my_snprintf (result
, sizeof (result
), "%.3La %d", 1.51L, 33, 44, 55);
545 ASSERT (strcmp (result
, "0x1.829p+0 33") == 0
546 || strcmp (result
, "0x3.052p-1 33") == 0
547 || strcmp (result
, "0x6.0a4p-2 33") == 0
548 || strcmp (result
, "0xc.148p-3 33") == 0);
549 ASSERT (retval
== strlen (result
));
552 { /* Rounding can turn a ...FFF into a ...000. */
554 my_snprintf (result
, sizeof (result
), "%.3La %d", 1.49999L, 33, 44, 55);
555 ASSERT (strcmp (result
, "0x1.800p+0 33") == 0
556 || strcmp (result
, "0x3.000p-1 33") == 0
557 || strcmp (result
, "0x6.000p-2 33") == 0
558 || strcmp (result
, "0xc.000p-3 33") == 0);
559 ASSERT (retval
== strlen (result
));
562 { /* Rounding can turn a ...FFF into a ...000.
563 This shows a Mac OS X 10.3.9 (Darwin 7.9) bug and a
564 glibc 2.4 bug <https://sourceware.org/bugzilla/show_bug.cgi?id=2908>. */
566 my_snprintf (result
, sizeof (result
), "%.1La %d", 1.999L, 33, 44, 55);
567 ASSERT (strcmp (result
, "0x1.0p+1 33") == 0
568 || strcmp (result
, "0x2.0p+0 33") == 0
569 || strcmp (result
, "0x4.0p-1 33") == 0
570 || strcmp (result
, "0x8.0p-2 33") == 0);
571 ASSERT (retval
== strlen (result
));
576 my_snprintf (result
, sizeof (result
), "%10La %d", 1.75L, 33, 44, 55);
577 ASSERT (strcmp (result
, " 0x1.cp+0 33") == 0
578 || strcmp (result
, " 0x3.8p-1 33") == 0
579 || strcmp (result
, " 0x7p-2 33") == 0
580 || strcmp (result
, " 0xep-3 33") == 0);
581 ASSERT (retval
== strlen (result
));
584 { /* Small precision. */
586 my_snprintf (result
, sizeof (result
), "%.10La %d", 1.75L, 33, 44, 55);
587 ASSERT (strcmp (result
, "0x1.c000000000p+0 33") == 0
588 || strcmp (result
, "0x3.8000000000p-1 33") == 0
589 || strcmp (result
, "0x7.0000000000p-2 33") == 0
590 || strcmp (result
, "0xe.0000000000p-3 33") == 0);
591 ASSERT (retval
== strlen (result
));
594 { /* Large precision. */
596 my_snprintf (result
, sizeof (result
), "%.50La %d", 1.75L, 33, 44, 55);
597 ASSERT (strcmp (result
, "0x1.c0000000000000000000000000000000000000000000000000p+0 33") == 0
598 || strcmp (result
, "0x3.80000000000000000000000000000000000000000000000000p-1 33") == 0
599 || strcmp (result
, "0x7.00000000000000000000000000000000000000000000000000p-2 33") == 0
600 || strcmp (result
, "0xe.00000000000000000000000000000000000000000000000000p-3 33") == 0);
601 ASSERT (retval
== strlen (result
));
606 my_snprintf (result
, sizeof (result
), "%-10La %d", 1.75L, 33, 44, 55);
607 ASSERT (strcmp (result
, "0x1.cp+0 33") == 0
608 || strcmp (result
, "0x3.8p-1 33") == 0
609 || strcmp (result
, "0x7p-2 33") == 0
610 || strcmp (result
, "0xep-3 33") == 0);
611 ASSERT (retval
== strlen (result
));
614 { /* FLAG_SHOWSIGN. */
616 my_snprintf (result
, sizeof (result
), "%+La %d", 1.75L, 33, 44, 55);
617 ASSERT (strcmp (result
, "+0x1.cp+0 33") == 0
618 || strcmp (result
, "+0x3.8p-1 33") == 0
619 || strcmp (result
, "+0x7p-2 33") == 0
620 || strcmp (result
, "+0xep-3 33") == 0);
621 ASSERT (retval
== strlen (result
));
626 my_snprintf (result
, sizeof (result
), "% La %d", 1.75L, 33, 44, 55);
627 ASSERT (strcmp (result
, " 0x1.cp+0 33") == 0
628 || strcmp (result
, " 0x3.8p-1 33") == 0
629 || strcmp (result
, " 0x7p-2 33") == 0
630 || strcmp (result
, " 0xep-3 33") == 0);
631 ASSERT (retval
== strlen (result
));
636 my_snprintf (result
, sizeof (result
), "%#La %d", 1.75L, 33, 44, 55);
637 ASSERT (strcmp (result
, "0x1.cp+0 33") == 0
638 || strcmp (result
, "0x3.8p-1 33") == 0
639 || strcmp (result
, "0x7.p-2 33") == 0
640 || strcmp (result
, "0xe.p-3 33") == 0);
641 ASSERT (retval
== strlen (result
));
646 my_snprintf (result
, sizeof (result
), "%#La %d", 1.0L, 33, 44, 55);
647 ASSERT (strcmp (result
, "0x1.p+0 33") == 0
648 || strcmp (result
, "0x2.p-1 33") == 0
649 || strcmp (result
, "0x4.p-2 33") == 0
650 || strcmp (result
, "0x8.p-3 33") == 0);
651 ASSERT (retval
== strlen (result
));
654 { /* FLAG_ZERO with finite number. */
656 my_snprintf (result
, sizeof (result
), "%010La %d", 1.75L, 33, 44, 55);
657 ASSERT (strcmp (result
, "0x001.cp+0 33") == 0
658 || strcmp (result
, "0x003.8p-1 33") == 0
659 || strcmp (result
, "0x00007p-2 33") == 0
660 || strcmp (result
, "0x0000ep-3 33") == 0);
661 ASSERT (retval
== strlen (result
));
664 { /* FLAG_ZERO with infinite number. */
666 my_snprintf (result
, sizeof (result
), "%010La %d", Infinityl (), 33, 44, 55);
667 /* "0000000inf 33" is not a valid result; see
668 <https://lists.gnu.org/r/bug-gnulib/2007-04/msg00107.html> */
669 ASSERT (strcmp (result
, " inf 33") == 0);
670 ASSERT (retval
== strlen (result
));
673 { /* FLAG_ZERO with NaN. */
675 my_snprintf (result
, sizeof (result
), "%050La %d", NaNl (), 33, 44, 55);
676 /* "0000000nan 33" is not a valid result; see
677 <https://lists.gnu.org/r/bug-gnulib/2007-04/msg00107.html> */
678 ASSERT (strlen (result
) == 50 + 3
679 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
680 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
681 ASSERT (retval
== strlen (result
));
684 /* Test the support of the %f format directive. */
686 { /* A positive number. */
688 my_snprintf (result
, sizeof (result
), "%f %d", 12.75, 33, 44, 55);
689 ASSERT (strcmp (result
, "12.750000 33") == 0);
690 ASSERT (retval
== strlen (result
));
693 { /* A larger positive number. */
695 my_snprintf (result
, sizeof (result
), "%f %d", 1234567.0, 33, 44, 55);
696 ASSERT (strcmp (result
, "1234567.000000 33") == 0);
697 ASSERT (retval
== strlen (result
));
700 { /* Small and large positive numbers. */
701 static struct { double value
; const char *string
; } data
[] =
703 { 1.234321234321234e-37, "0.000000" },
704 { 1.234321234321234e-36, "0.000000" },
705 { 1.234321234321234e-35, "0.000000" },
706 { 1.234321234321234e-34, "0.000000" },
707 { 1.234321234321234e-33, "0.000000" },
708 { 1.234321234321234e-32, "0.000000" },
709 { 1.234321234321234e-31, "0.000000" },
710 { 1.234321234321234e-30, "0.000000" },
711 { 1.234321234321234e-29, "0.000000" },
712 { 1.234321234321234e-28, "0.000000" },
713 { 1.234321234321234e-27, "0.000000" },
714 { 1.234321234321234e-26, "0.000000" },
715 { 1.234321234321234e-25, "0.000000" },
716 { 1.234321234321234e-24, "0.000000" },
717 { 1.234321234321234e-23, "0.000000" },
718 { 1.234321234321234e-22, "0.000000" },
719 { 1.234321234321234e-21, "0.000000" },
720 { 1.234321234321234e-20, "0.000000" },
721 { 1.234321234321234e-19, "0.000000" },
722 { 1.234321234321234e-18, "0.000000" },
723 { 1.234321234321234e-17, "0.000000" },
724 { 1.234321234321234e-16, "0.000000" },
725 { 1.234321234321234e-15, "0.000000" },
726 { 1.234321234321234e-14, "0.000000" },
727 { 1.234321234321234e-13, "0.000000" },
728 { 1.234321234321234e-12, "0.000000" },
729 { 1.234321234321234e-11, "0.000000" },
730 { 1.234321234321234e-10, "0.000000" },
731 { 1.234321234321234e-9, "0.000000" },
732 { 1.234321234321234e-8, "0.000000" },
733 { 1.234321234321234e-7, "0.000000" },
734 { 1.234321234321234e-6, "0.000001" },
735 { 1.234321234321234e-5, "0.000012" },
736 { 1.234321234321234e-4, "0.000123" },
737 { 1.234321234321234e-3, "0.001234" },
738 { 1.234321234321234e-2, "0.012343" },
739 { 1.234321234321234e-1, "0.123432" },
740 { 1.234321234321234, "1.234321" },
741 { 1.234321234321234e1
, "12.343212" },
742 { 1.234321234321234e2
, "123.432123" },
743 { 1.234321234321234e3
, "1234.321234" },
744 { 1.234321234321234e4
, "12343.212343" },
745 { 1.234321234321234e5
, "123432.123432" },
746 { 1.234321234321234e6
, "1234321.234321" },
747 { 1.234321234321234e7
, "12343212.343212" },
748 { 1.234321234321234e8
, "123432123.432123" },
749 { 1.234321234321234e9
, "1234321234.321234" },
750 { 1.234321234321234e10
, "12343212343.2123**" },
751 { 1.234321234321234e11
, "123432123432.123***" },
752 { 1.234321234321234e12
, "1234321234321.23****" },
753 { 1.234321234321234e13
, "12343212343212.3*****" },
754 { 1.234321234321234e14
, "123432123432123.******" },
755 { 1.234321234321234e15
, "1234321234321234.000000" },
756 { 1.234321234321234e16
, "123432123432123**.000000" },
757 { 1.234321234321234e17
, "123432123432123***.000000" },
758 { 1.234321234321234e18
, "123432123432123****.000000" },
759 { 1.234321234321234e19
, "123432123432123*****.000000" },
760 { 1.234321234321234e20
, "123432123432123******.000000" },
761 { 1.234321234321234e21
, "123432123432123*******.000000" },
762 { 1.234321234321234e22
, "123432123432123********.000000" },
763 { 1.234321234321234e23
, "123432123432123*********.000000" },
764 { 1.234321234321234e24
, "123432123432123**********.000000" },
765 { 1.234321234321234e25
, "123432123432123***********.000000" },
766 { 1.234321234321234e26
, "123432123432123************.000000" },
767 { 1.234321234321234e27
, "123432123432123*************.000000" },
768 { 1.234321234321234e28
, "123432123432123**************.000000" },
769 { 1.234321234321234e29
, "123432123432123***************.000000" },
770 { 1.234321234321234e30
, "123432123432123****************.000000" },
771 { 1.234321234321234e31
, "123432123432123*****************.000000" },
772 { 1.234321234321234e32
, "123432123432123******************.000000" },
773 { 1.234321234321234e33
, "123432123432123*******************.000000" },
774 { 1.234321234321234e34
, "123432123432123********************.000000" },
775 { 1.234321234321234e35
, "123432123432123*********************.000000" },
776 { 1.234321234321234e36
, "123432123432123**********************.000000" }
779 for (k
= 0; k
< SIZEOF (data
); k
++)
782 my_snprintf (result
, sizeof (result
), "%f", data
[k
].value
);
783 ASSERT (strmatch (data
[k
].string
, result
));
784 ASSERT (retval
== strlen (result
));
788 { /* A negative number. */
790 my_snprintf (result
, sizeof (result
), "%f %d", -0.03125, 33, 44, 55);
791 ASSERT (strcmp (result
, "-0.031250 33") == 0);
792 ASSERT (retval
== strlen (result
));
795 { /* Positive zero. */
797 my_snprintf (result
, sizeof (result
), "%f %d", 0.0, 33, 44, 55);
798 ASSERT (strcmp (result
, "0.000000 33") == 0);
799 ASSERT (retval
== strlen (result
));
802 { /* Negative zero. */
804 my_snprintf (result
, sizeof (result
), "%f %d", minus_zerod
, 33, 44, 55);
805 if (have_minus_zero ())
806 ASSERT (strcmp (result
, "-0.000000 33") == 0);
807 ASSERT (retval
== strlen (result
));
810 { /* Positive infinity. */
812 my_snprintf (result
, sizeof (result
), "%f %d", Infinityd (), 33, 44, 55);
813 ASSERT (strcmp (result
, "inf 33") == 0
814 || strcmp (result
, "infinity 33") == 0);
815 ASSERT (retval
== strlen (result
));
818 { /* Negative infinity. */
820 my_snprintf (result
, sizeof (result
), "%f %d", - Infinityd (), 33, 44, 55);
821 ASSERT (strcmp (result
, "-inf 33") == 0
822 || strcmp (result
, "-infinity 33") == 0);
823 ASSERT (retval
== strlen (result
));
828 my_snprintf (result
, sizeof (result
), "%f %d", NaNd (), 33, 44, 55);
829 ASSERT (strlen (result
) >= 3 + 3
830 && strisnan (result
, 0, strlen (result
) - 3, 0)
831 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
832 ASSERT (retval
== strlen (result
));
837 my_snprintf (result
, sizeof (result
), "%10f %d", 1.75, 33, 44, 55);
838 ASSERT (strcmp (result
, " 1.750000 33") == 0);
839 ASSERT (retval
== strlen (result
));
844 my_snprintf (result
, sizeof (result
), "%-10f %d", 1.75, 33, 44, 55);
845 ASSERT (strcmp (result
, "1.750000 33") == 0);
846 ASSERT (retval
== strlen (result
));
849 { /* FLAG_SHOWSIGN. */
851 my_snprintf (result
, sizeof (result
), "%+f %d", 1.75, 33, 44, 55);
852 ASSERT (strcmp (result
, "+1.750000 33") == 0);
853 ASSERT (retval
== strlen (result
));
858 my_snprintf (result
, sizeof (result
), "% f %d", 1.75, 33, 44, 55);
859 ASSERT (strcmp (result
, " 1.750000 33") == 0);
860 ASSERT (retval
== strlen (result
));
865 my_snprintf (result
, sizeof (result
), "%#f %d", 1.75, 33, 44, 55);
866 ASSERT (strcmp (result
, "1.750000 33") == 0);
867 ASSERT (retval
== strlen (result
));
872 my_snprintf (result
, sizeof (result
), "%#.f %d", 1.75, 33, 44, 55);
873 ASSERT (strcmp (result
, "2. 33") == 0);
874 ASSERT (retval
== strlen (result
));
877 { /* FLAG_ZERO with finite number. */
879 my_snprintf (result
, sizeof (result
), "%015f %d", 1234.0, 33, 44, 55);
880 ASSERT (strcmp (result
, "00001234.000000 33") == 0);
881 ASSERT (retval
== strlen (result
));
884 { /* FLAG_ZERO with infinite number. */
886 my_snprintf (result
, sizeof (result
), "%015f %d", - Infinityd (), 33, 44, 55);
887 ASSERT (strcmp (result
, " -inf 33") == 0
888 || strcmp (result
, " -infinity 33") == 0);
889 ASSERT (retval
== strlen (result
));
892 { /* FLAG_ZERO with NaN. */
894 my_snprintf (result
, sizeof (result
), "%050f %d", NaNd (), 33, 44, 55);
895 ASSERT (strlen (result
) == 50 + 3
896 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
897 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
898 ASSERT (retval
== strlen (result
));
903 my_snprintf (result
, sizeof (result
), "%.f %d", 1234.0, 33, 44, 55);
904 ASSERT (strcmp (result
, "1234 33") == 0);
905 ASSERT (retval
== strlen (result
));
908 { /* Precision with no rounding. */
910 my_snprintf (result
, sizeof (result
), "%.2f %d", 999.951, 33, 44, 55);
911 ASSERT (strcmp (result
, "999.95 33") == 0);
912 ASSERT (retval
== strlen (result
));
915 { /* Precision with rounding. */
917 my_snprintf (result
, sizeof (result
), "%.2f %d", 999.996, 33, 44, 55);
918 ASSERT (strcmp (result
, "1000.00 33") == 0);
919 ASSERT (retval
== strlen (result
));
922 { /* A positive number. */
924 my_snprintf (result
, sizeof (result
), "%Lf %d", 12.75L, 33, 44, 55);
925 ASSERT (strcmp (result
, "12.750000 33") == 0);
926 ASSERT (retval
== strlen (result
));
929 { /* A larger positive number. */
931 my_snprintf (result
, sizeof (result
), "%Lf %d", 1234567.0L, 33, 44, 55);
932 ASSERT (strcmp (result
, "1234567.000000 33") == 0);
933 ASSERT (retval
== strlen (result
));
936 { /* Small and large positive numbers. */
937 static struct { long double value
; const char *string
; } data
[] =
939 { 1.234321234321234e-37L, "0.000000" },
940 { 1.234321234321234e-36L, "0.000000" },
941 { 1.234321234321234e-35L, "0.000000" },
942 { 1.234321234321234e-34L, "0.000000" },
943 { 1.234321234321234e-33L, "0.000000" },
944 { 1.234321234321234e-32L, "0.000000" },
945 { 1.234321234321234e-31L, "0.000000" },
946 { 1.234321234321234e-30L, "0.000000" },
947 { 1.234321234321234e-29L, "0.000000" },
948 { 1.234321234321234e-28L, "0.000000" },
949 { 1.234321234321234e-27L, "0.000000" },
950 { 1.234321234321234e-26L, "0.000000" },
951 { 1.234321234321234e-25L, "0.000000" },
952 { 1.234321234321234e-24L, "0.000000" },
953 { 1.234321234321234e-23L, "0.000000" },
954 { 1.234321234321234e-22L, "0.000000" },
955 { 1.234321234321234e-21L, "0.000000" },
956 { 1.234321234321234e-20L, "0.000000" },
957 { 1.234321234321234e-19L, "0.000000" },
958 { 1.234321234321234e-18L, "0.000000" },
959 { 1.234321234321234e-17L, "0.000000" },
960 { 1.234321234321234e-16L, "0.000000" },
961 { 1.234321234321234e-15L, "0.000000" },
962 { 1.234321234321234e-14L, "0.000000" },
963 { 1.234321234321234e-13L, "0.000000" },
964 { 1.234321234321234e-12L, "0.000000" },
965 { 1.234321234321234e-11L, "0.000000" },
966 { 1.234321234321234e-10L, "0.000000" },
967 { 1.234321234321234e-9L, "0.000000" },
968 { 1.234321234321234e-8L, "0.000000" },
969 { 1.234321234321234e-7L, "0.000000" },
970 { 1.234321234321234e-6L, "0.000001" },
971 { 1.234321234321234e-5L, "0.000012" },
972 { 1.234321234321234e-4L, "0.000123" },
973 { 1.234321234321234e-3L, "0.001234" },
974 { 1.234321234321234e-2L, "0.012343" },
975 { 1.234321234321234e-1L, "0.123432" },
976 { 1.234321234321234L, "1.234321" },
977 { 1.234321234321234e1L
, "12.343212" },
978 { 1.234321234321234e2L
, "123.432123" },
979 { 1.234321234321234e3L
, "1234.321234" },
980 { 1.234321234321234e4L
, "12343.212343" },
981 { 1.234321234321234e5L
, "123432.123432" },
982 { 1.234321234321234e6L
, "1234321.234321" },
983 { 1.234321234321234e7L
, "12343212.343212" },
984 { 1.234321234321234e8L
, "123432123.432123" },
985 { 1.234321234321234e9L
, "1234321234.321234" },
986 { 1.234321234321234e10L
, "12343212343.2123**" },
987 { 1.234321234321234e11L
, "123432123432.123***" },
988 { 1.234321234321234e12L
, "1234321234321.23****" },
989 { 1.234321234321234e13L
, "12343212343212.3*****" },
990 { 1.234321234321234e14L
, "123432123432123.******" },
991 { 1.234321234321234e15L
, "1234321234321234.000000" },
992 { 1.234321234321234e16L
, "123432123432123**.000000" },
993 { 1.234321234321234e17L
, "123432123432123***.000000" },
994 { 1.234321234321234e18L
, "123432123432123****.000000" },
995 { 1.234321234321234e19L
, "123432123432123*****.000000" },
996 { 1.234321234321234e20L
, "123432123432123******.000000" },
997 { 1.234321234321234e21L
, "123432123432123*******.000000" },
998 { 1.234321234321234e22L
, "123432123432123********.000000" },
999 { 1.234321234321234e23L
, "123432123432123*********.000000" },
1000 { 1.234321234321234e24L
, "123432123432123**********.000000" },
1001 { 1.234321234321234e25L
, "123432123432123***********.000000" },
1002 { 1.234321234321234e26L
, "123432123432123************.000000" },
1003 { 1.234321234321234e27L
, "123432123432123*************.000000" },
1004 { 1.234321234321234e28L
, "123432123432123**************.000000" },
1005 { 1.234321234321234e29L
, "123432123432123***************.000000" },
1006 { 1.234321234321234e30L
, "123432123432123****************.000000" },
1007 { 1.234321234321234e31L
, "123432123432123*****************.000000" },
1008 { 1.234321234321234e32L
, "123432123432123******************.000000" },
1009 { 1.234321234321234e33L
, "123432123432123*******************.000000" },
1010 { 1.234321234321234e34L
, "123432123432123********************.000000" },
1011 { 1.234321234321234e35L
, "123432123432123*********************.000000" },
1012 { 1.234321234321234e36L
, "123432123432123**********************.000000" }
1015 for (k
= 0; k
< SIZEOF (data
); k
++)
1018 my_snprintf (result
, sizeof (result
), "%Lf", data
[k
].value
);
1019 ASSERT (strmatch (data
[k
].string
, result
));
1020 ASSERT (retval
== strlen (result
));
1024 { /* A negative number. */
1026 my_snprintf (result
, sizeof (result
), "%Lf %d", -0.03125L, 33, 44, 55);
1027 ASSERT (strcmp (result
, "-0.031250 33") == 0);
1028 ASSERT (retval
== strlen (result
));
1031 { /* Positive zero. */
1033 my_snprintf (result
, sizeof (result
), "%Lf %d", 0.0L, 33, 44, 55);
1034 ASSERT (strcmp (result
, "0.000000 33") == 0);
1035 ASSERT (retval
== strlen (result
));
1038 { /* Negative zero. */
1040 my_snprintf (result
, sizeof (result
), "%Lf %d", minus_zerol
, 33, 44, 55);
1041 if (have_minus_zero ())
1042 ASSERT (strcmp (result
, "-0.000000 33") == 0);
1043 ASSERT (retval
== strlen (result
));
1046 { /* Positive infinity. */
1048 my_snprintf (result
, sizeof (result
), "%Lf %d", Infinityl (), 33, 44, 55);
1049 ASSERT (strcmp (result
, "inf 33") == 0
1050 || strcmp (result
, "infinity 33") == 0);
1051 ASSERT (retval
== strlen (result
));
1054 { /* Negative infinity. */
1056 my_snprintf (result
, sizeof (result
), "%Lf %d", - Infinityl (), 33, 44, 55);
1057 ASSERT (strcmp (result
, "-inf 33") == 0
1058 || strcmp (result
, "-infinity 33") == 0);
1059 ASSERT (retval
== strlen (result
));
1064 my_snprintf (result
, sizeof (result
), "%Lf %d", NaNl (), 33, 44, 55);
1065 ASSERT (strlen (result
) >= 3 + 3
1066 && strisnan (result
, 0, strlen (result
) - 3, 0)
1067 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1068 ASSERT (retval
== strlen (result
));
1070 #if CHECK_PRINTF_SAFE && ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
1072 static union { unsigned int word
[4]; long double value
; } x
=
1073 { LDBL80_WORDS (0xFFFF, 0xC3333333, 0x00000000) };
1075 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1076 ASSERT (strlen (result
) >= 3 + 3
1077 && strisnan (result
, 0, strlen (result
) - 3, 0)
1078 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1079 ASSERT (retval
== strlen (result
));
1082 /* Signalling NaN. */
1083 static union { unsigned int word
[4]; long double value
; } x
=
1084 { LDBL80_WORDS (0xFFFF, 0x83333333, 0x00000000) };
1086 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1087 ASSERT (strlen (result
) >= 3 + 3
1088 && strisnan (result
, 0, strlen (result
) - 3, 0)
1089 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1090 ASSERT (retval
== strlen (result
));
1092 /* snprintf should print something for noncanonical values. */
1094 static union { unsigned int word
[4]; long double value
; } x
=
1095 { LDBL80_WORDS (0xFFFF, 0x40000001, 0x00000000) };
1097 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1098 ASSERT (retval
== strlen (result
));
1099 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1101 { /* Pseudo-Infinity. */
1102 static union { unsigned int word
[4]; long double value
; } x
=
1103 { LDBL80_WORDS (0xFFFF, 0x00000000, 0x00000000) };
1105 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1106 ASSERT (retval
== strlen (result
));
1107 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1109 { /* Pseudo-Zero. */
1110 static union { unsigned int word
[4]; long double value
; } x
=
1111 { LDBL80_WORDS (0x4004, 0x00000000, 0x00000000) };
1113 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1114 ASSERT (retval
== strlen (result
));
1115 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1117 { /* Unnormalized number. */
1118 static union { unsigned int word
[4]; long double value
; } x
=
1119 { LDBL80_WORDS (0x4000, 0x63333333, 0x00000000) };
1121 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1122 ASSERT (retval
== strlen (result
));
1123 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1125 { /* Pseudo-Denormal. */
1126 static union { unsigned int word
[4]; long double value
; } x
=
1127 { LDBL80_WORDS (0x0000, 0x83333333, 0x00000000) };
1129 my_snprintf (result
, sizeof (result
), "%Lf %d", x
.value
, 33, 44, 55);
1130 ASSERT (retval
== strlen (result
));
1131 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1137 my_snprintf (result
, sizeof (result
), "%10Lf %d", 1.75L, 33, 44, 55);
1138 ASSERT (strcmp (result
, " 1.750000 33") == 0);
1139 ASSERT (retval
== strlen (result
));
1144 my_snprintf (result
, sizeof (result
), "%-10Lf %d", 1.75L, 33, 44, 55);
1145 ASSERT (strcmp (result
, "1.750000 33") == 0);
1146 ASSERT (retval
== strlen (result
));
1149 { /* FLAG_SHOWSIGN. */
1151 my_snprintf (result
, sizeof (result
), "%+Lf %d", 1.75L, 33, 44, 55);
1152 ASSERT (strcmp (result
, "+1.750000 33") == 0);
1153 ASSERT (retval
== strlen (result
));
1158 my_snprintf (result
, sizeof (result
), "% Lf %d", 1.75L, 33, 44, 55);
1159 ASSERT (strcmp (result
, " 1.750000 33") == 0);
1160 ASSERT (retval
== strlen (result
));
1165 my_snprintf (result
, sizeof (result
), "%#Lf %d", 1.75L, 33, 44, 55);
1166 ASSERT (strcmp (result
, "1.750000 33") == 0);
1167 ASSERT (retval
== strlen (result
));
1172 my_snprintf (result
, sizeof (result
), "%#.Lf %d", 1.75L, 33, 44, 55);
1173 ASSERT (strcmp (result
, "2. 33") == 0);
1174 ASSERT (retval
== strlen (result
));
1177 { /* FLAG_ZERO with finite number. */
1179 my_snprintf (result
, sizeof (result
), "%015Lf %d", 1234.0L, 33, 44, 55);
1180 ASSERT (strcmp (result
, "00001234.000000 33") == 0);
1181 ASSERT (retval
== strlen (result
));
1184 { /* FLAG_ZERO with infinite number. */
1186 my_snprintf (result
, sizeof (result
), "%015Lf %d", - Infinityl (), 33, 44, 55);
1187 ASSERT (strcmp (result
, " -inf 33") == 0
1188 || strcmp (result
, " -infinity 33") == 0);
1189 ASSERT (retval
== strlen (result
));
1192 { /* FLAG_ZERO with NaN. */
1194 my_snprintf (result
, sizeof (result
), "%050Lf %d", NaNl (), 33, 44, 55);
1195 ASSERT (strlen (result
) == 50 + 3
1196 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
1197 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1198 ASSERT (retval
== strlen (result
));
1203 my_snprintf (result
, sizeof (result
), "%.Lf %d", 1234.0L, 33, 44, 55);
1204 ASSERT (strcmp (result
, "1234 33") == 0);
1205 ASSERT (retval
== strlen (result
));
1208 { /* Precision with no rounding. */
1210 my_snprintf (result
, sizeof (result
), "%.2Lf %d", 999.951L, 33, 44, 55);
1211 ASSERT (strcmp (result
, "999.95 33") == 0);
1212 ASSERT (retval
== strlen (result
));
1215 { /* Precision with rounding. */
1217 my_snprintf (result
, sizeof (result
), "%.2Lf %d", 999.996L, 33, 44, 55);
1218 ASSERT (strcmp (result
, "1000.00 33") == 0);
1219 ASSERT (retval
== strlen (result
));
1222 /* Test the support of the %F format directive. */
1224 { /* A positive number. */
1226 my_snprintf (result
, sizeof (result
), "%F %d", 12.75, 33, 44, 55);
1227 ASSERT (strcmp (result
, "12.750000 33") == 0);
1228 ASSERT (retval
== strlen (result
));
1231 { /* A larger positive number. */
1233 my_snprintf (result
, sizeof (result
), "%F %d", 1234567.0, 33, 44, 55);
1234 ASSERT (strcmp (result
, "1234567.000000 33") == 0);
1235 ASSERT (retval
== strlen (result
));
1238 { /* A negative number. */
1240 my_snprintf (result
, sizeof (result
), "%F %d", -0.03125, 33, 44, 55);
1241 ASSERT (strcmp (result
, "-0.031250 33") == 0);
1242 ASSERT (retval
== strlen (result
));
1245 { /* Positive zero. */
1247 my_snprintf (result
, sizeof (result
), "%F %d", 0.0, 33, 44, 55);
1248 ASSERT (strcmp (result
, "0.000000 33") == 0);
1249 ASSERT (retval
== strlen (result
));
1252 { /* Negative zero. */
1254 my_snprintf (result
, sizeof (result
), "%F %d", minus_zerod
, 33, 44, 55);
1255 if (have_minus_zero ())
1256 ASSERT (strcmp (result
, "-0.000000 33") == 0);
1257 ASSERT (retval
== strlen (result
));
1260 { /* Positive infinity. */
1262 my_snprintf (result
, sizeof (result
), "%F %d", Infinityd (), 33, 44, 55);
1263 ASSERT (strcmp (result
, "INF 33") == 0
1264 || strcmp (result
, "INFINITY 33") == 0);
1265 ASSERT (retval
== strlen (result
));
1268 { /* Negative infinity. */
1270 my_snprintf (result
, sizeof (result
), "%F %d", - Infinityd (), 33, 44, 55);
1271 ASSERT (strcmp (result
, "-INF 33") == 0
1272 || strcmp (result
, "-INFINITY 33") == 0);
1273 ASSERT (retval
== strlen (result
));
1278 my_snprintf (result
, sizeof (result
), "%F %d", NaNd (), 33, 44, 55);
1279 ASSERT (strlen (result
) >= 3 + 3
1280 && strisnan (result
, 0, strlen (result
) - 3, 1)
1281 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1282 ASSERT (retval
== strlen (result
));
1287 my_snprintf (result
, sizeof (result
), "%015F %d", 1234.0, 33, 44, 55);
1288 ASSERT (strcmp (result
, "00001234.000000 33") == 0);
1289 ASSERT (retval
== strlen (result
));
1292 { /* FLAG_ZERO with infinite number. */
1294 my_snprintf (result
, sizeof (result
), "%015F %d", - Infinityd (), 33, 44, 55);
1295 ASSERT (strcmp (result
, " -INF 33") == 0
1296 || strcmp (result
, " -INFINITY 33") == 0);
1297 ASSERT (retval
== strlen (result
));
1302 my_snprintf (result
, sizeof (result
), "%.F %d", 1234.0, 33, 44, 55);
1303 ASSERT (strcmp (result
, "1234 33") == 0);
1304 ASSERT (retval
== strlen (result
));
1307 { /* Precision with no rounding. */
1309 my_snprintf (result
, sizeof (result
), "%.2F %d", 999.951, 33, 44, 55);
1310 ASSERT (strcmp (result
, "999.95 33") == 0);
1311 ASSERT (retval
== strlen (result
));
1314 { /* Precision with rounding. */
1316 my_snprintf (result
, sizeof (result
), "%.2F %d", 999.996, 33, 44, 55);
1317 ASSERT (strcmp (result
, "1000.00 33") == 0);
1318 ASSERT (retval
== strlen (result
));
1321 { /* A positive number. */
1323 my_snprintf (result
, sizeof (result
), "%LF %d", 12.75L, 33, 44, 55);
1324 ASSERT (strcmp (result
, "12.750000 33") == 0);
1325 ASSERT (retval
== strlen (result
));
1328 { /* A larger positive number. */
1330 my_snprintf (result
, sizeof (result
), "%LF %d", 1234567.0L, 33, 44, 55);
1331 ASSERT (strcmp (result
, "1234567.000000 33") == 0);
1332 ASSERT (retval
== strlen (result
));
1335 { /* A negative number. */
1337 my_snprintf (result
, sizeof (result
), "%LF %d", -0.03125L, 33, 44, 55);
1338 ASSERT (strcmp (result
, "-0.031250 33") == 0);
1339 ASSERT (retval
== strlen (result
));
1342 { /* Positive zero. */
1344 my_snprintf (result
, sizeof (result
), "%LF %d", 0.0L, 33, 44, 55);
1345 ASSERT (strcmp (result
, "0.000000 33") == 0);
1346 ASSERT (retval
== strlen (result
));
1349 { /* Negative zero. */
1351 my_snprintf (result
, sizeof (result
), "%LF %d", minus_zerol
, 33, 44, 55);
1352 if (have_minus_zero ())
1353 ASSERT (strcmp (result
, "-0.000000 33") == 0);
1354 ASSERT (retval
== strlen (result
));
1357 { /* Positive infinity. */
1359 my_snprintf (result
, sizeof (result
), "%LF %d", Infinityl (), 33, 44, 55);
1360 ASSERT (strcmp (result
, "INF 33") == 0
1361 || strcmp (result
, "INFINITY 33") == 0);
1362 ASSERT (retval
== strlen (result
));
1365 { /* Negative infinity. */
1367 my_snprintf (result
, sizeof (result
), "%LF %d", - Infinityl (), 33, 44, 55);
1368 ASSERT (strcmp (result
, "-INF 33") == 0
1369 || strcmp (result
, "-INFINITY 33") == 0);
1370 ASSERT (retval
== strlen (result
));
1375 my_snprintf (result
, sizeof (result
), "%LF %d", NaNl (), 33, 44, 55);
1376 ASSERT (strlen (result
) >= 3 + 3
1377 && strisnan (result
, 0, strlen (result
) - 3, 1)
1378 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1379 ASSERT (retval
== strlen (result
));
1384 my_snprintf (result
, sizeof (result
), "%015LF %d", 1234.0L, 33, 44, 55);
1385 ASSERT (strcmp (result
, "00001234.000000 33") == 0);
1386 ASSERT (retval
== strlen (result
));
1389 { /* FLAG_ZERO with infinite number. */
1391 my_snprintf (result
, sizeof (result
), "%015LF %d", - Infinityl (), 33, 44, 55);
1392 ASSERT (strcmp (result
, " -INF 33") == 0
1393 || strcmp (result
, " -INFINITY 33") == 0);
1394 ASSERT (retval
== strlen (result
));
1399 my_snprintf (result
, sizeof (result
), "%.LF %d", 1234.0L, 33, 44, 55);
1400 ASSERT (strcmp (result
, "1234 33") == 0);
1401 ASSERT (retval
== strlen (result
));
1404 { /* Precision with no rounding. */
1406 my_snprintf (result
, sizeof (result
), "%.2LF %d", 999.951L, 33, 44, 55);
1407 ASSERT (strcmp (result
, "999.95 33") == 0);
1408 ASSERT (retval
== strlen (result
));
1411 { /* Precision with rounding. */
1413 my_snprintf (result
, sizeof (result
), "%.2LF %d", 999.996L, 33, 44, 55);
1414 ASSERT (strcmp (result
, "1000.00 33") == 0);
1415 ASSERT (retval
== strlen (result
));
1418 /* Test the support of the %e format directive. */
1420 { /* A positive number. */
1422 my_snprintf (result
, sizeof (result
), "%e %d", 12.75, 33, 44, 55);
1423 ASSERT (strcmp (result
, "1.275000e+01 33") == 0
1424 || strcmp (result
, "1.275000e+001 33") == 0);
1425 ASSERT (retval
== strlen (result
));
1428 { /* A larger positive number. */
1430 my_snprintf (result
, sizeof (result
), "%e %d", 1234567.0, 33, 44, 55);
1431 ASSERT (strcmp (result
, "1.234567e+06 33") == 0
1432 || strcmp (result
, "1.234567e+006 33") == 0);
1433 ASSERT (retval
== strlen (result
));
1436 { /* Small and large positive numbers. */
1437 static struct { double value
; const char *string
; } data
[] =
1439 { 1.234321234321234e-37, "1.234321e-37" },
1440 { 1.234321234321234e-36, "1.234321e-36" },
1441 { 1.234321234321234e-35, "1.234321e-35" },
1442 { 1.234321234321234e-34, "1.234321e-34" },
1443 { 1.234321234321234e-33, "1.234321e-33" },
1444 { 1.234321234321234e-32, "1.234321e-32" },
1445 { 1.234321234321234e-31, "1.234321e-31" },
1446 { 1.234321234321234e-30, "1.234321e-30" },
1447 { 1.234321234321234e-29, "1.234321e-29" },
1448 { 1.234321234321234e-28, "1.234321e-28" },
1449 { 1.234321234321234e-27, "1.234321e-27" },
1450 { 1.234321234321234e-26, "1.234321e-26" },
1451 { 1.234321234321234e-25, "1.234321e-25" },
1452 { 1.234321234321234e-24, "1.234321e-24" },
1453 { 1.234321234321234e-23, "1.234321e-23" },
1454 { 1.234321234321234e-22, "1.234321e-22" },
1455 { 1.234321234321234e-21, "1.234321e-21" },
1456 { 1.234321234321234e-20, "1.234321e-20" },
1457 { 1.234321234321234e-19, "1.234321e-19" },
1458 { 1.234321234321234e-18, "1.234321e-18" },
1459 { 1.234321234321234e-17, "1.234321e-17" },
1460 { 1.234321234321234e-16, "1.234321e-16" },
1461 { 1.234321234321234e-15, "1.234321e-15" },
1462 { 1.234321234321234e-14, "1.234321e-14" },
1463 { 1.234321234321234e-13, "1.234321e-13" },
1464 { 1.234321234321234e-12, "1.234321e-12" },
1465 { 1.234321234321234e-11, "1.234321e-11" },
1466 { 1.234321234321234e-10, "1.234321e-10" },
1467 { 1.234321234321234e-9, "1.234321e-09" },
1468 { 1.234321234321234e-8, "1.234321e-08" },
1469 { 1.234321234321234e-7, "1.234321e-07" },
1470 { 1.234321234321234e-6, "1.234321e-06" },
1471 { 1.234321234321234e-5, "1.234321e-05" },
1472 { 1.234321234321234e-4, "1.234321e-04" },
1473 { 1.234321234321234e-3, "1.234321e-03" },
1474 { 1.234321234321234e-2, "1.234321e-02" },
1475 { 1.234321234321234e-1, "1.234321e-01" },
1476 { 1.234321234321234, "1.234321e+00" },
1477 { 1.234321234321234e1
, "1.234321e+01" },
1478 { 1.234321234321234e2
, "1.234321e+02" },
1479 { 1.234321234321234e3
, "1.234321e+03" },
1480 { 1.234321234321234e4
, "1.234321e+04" },
1481 { 1.234321234321234e5
, "1.234321e+05" },
1482 { 1.234321234321234e6
, "1.234321e+06" },
1483 { 1.234321234321234e7
, "1.234321e+07" },
1484 { 1.234321234321234e8
, "1.234321e+08" },
1485 { 1.234321234321234e9
, "1.234321e+09" },
1486 { 1.234321234321234e10
, "1.234321e+10" },
1487 { 1.234321234321234e11
, "1.234321e+11" },
1488 { 1.234321234321234e12
, "1.234321e+12" },
1489 { 1.234321234321234e13
, "1.234321e+13" },
1490 { 1.234321234321234e14
, "1.234321e+14" },
1491 { 1.234321234321234e15
, "1.234321e+15" },
1492 { 1.234321234321234e16
, "1.234321e+16" },
1493 { 1.234321234321234e17
, "1.234321e+17" },
1494 { 1.234321234321234e18
, "1.234321e+18" },
1495 { 1.234321234321234e19
, "1.234321e+19" },
1496 { 1.234321234321234e20
, "1.234321e+20" },
1497 { 1.234321234321234e21
, "1.234321e+21" },
1498 { 1.234321234321234e22
, "1.234321e+22" },
1499 { 1.234321234321234e23
, "1.234321e+23" },
1500 { 1.234321234321234e24
, "1.234321e+24" },
1501 { 1.234321234321234e25
, "1.234321e+25" },
1502 { 1.234321234321234e26
, "1.234321e+26" },
1503 { 1.234321234321234e27
, "1.234321e+27" },
1504 { 1.234321234321234e28
, "1.234321e+28" },
1505 { 1.234321234321234e29
, "1.234321e+29" },
1506 { 1.234321234321234e30
, "1.234321e+30" },
1507 { 1.234321234321234e31
, "1.234321e+31" },
1508 { 1.234321234321234e32
, "1.234321e+32" },
1509 { 1.234321234321234e33
, "1.234321e+33" },
1510 { 1.234321234321234e34
, "1.234321e+34" },
1511 { 1.234321234321234e35
, "1.234321e+35" },
1512 { 1.234321234321234e36
, "1.234321e+36" }
1515 for (k
= 0; k
< SIZEOF (data
); k
++)
1518 my_snprintf (result
, sizeof (result
), "%e", data
[k
].value
);
1519 const char *expected
= data
[k
].string
;
1520 ASSERT (strcmp (result
, expected
) == 0
1521 /* Some implementations produce exponents with 3 digits. */
1522 || (strlen (result
) == strlen (expected
) + 1
1523 && memcmp (result
, expected
, strlen (expected
) - 2) == 0
1524 && result
[strlen (expected
) - 2] == '0'
1525 && strcmp (result
+ strlen (expected
) - 1,
1526 expected
+ strlen (expected
) - 2)
1528 ASSERT (retval
== strlen (result
));
1532 { /* A negative number. */
1534 my_snprintf (result
, sizeof (result
), "%e %d", -0.03125, 33, 44, 55);
1535 ASSERT (strcmp (result
, "-3.125000e-02 33") == 0
1536 || strcmp (result
, "-3.125000e-002 33") == 0);
1537 ASSERT (retval
== strlen (result
));
1540 { /* Positive zero. */
1542 my_snprintf (result
, sizeof (result
), "%e %d", 0.0, 33, 44, 55);
1543 ASSERT (strcmp (result
, "0.000000e+00 33") == 0
1544 || strcmp (result
, "0.000000e+000 33") == 0);
1545 ASSERT (retval
== strlen (result
));
1548 { /* Negative zero. */
1550 my_snprintf (result
, sizeof (result
), "%e %d", minus_zerod
, 33, 44, 55);
1551 if (have_minus_zero ())
1552 ASSERT (strcmp (result
, "-0.000000e+00 33") == 0
1553 || strcmp (result
, "-0.000000e+000 33") == 0);
1554 ASSERT (retval
== strlen (result
));
1557 { /* Positive infinity. */
1559 my_snprintf (result
, sizeof (result
), "%e %d", Infinityd (), 33, 44, 55);
1560 ASSERT (strcmp (result
, "inf 33") == 0
1561 || strcmp (result
, "infinity 33") == 0);
1562 ASSERT (retval
== strlen (result
));
1565 { /* Negative infinity. */
1567 my_snprintf (result
, sizeof (result
), "%e %d", - Infinityd (), 33, 44, 55);
1568 ASSERT (strcmp (result
, "-inf 33") == 0
1569 || strcmp (result
, "-infinity 33") == 0);
1570 ASSERT (retval
== strlen (result
));
1575 my_snprintf (result
, sizeof (result
), "%e %d", NaNd (), 33, 44, 55);
1576 ASSERT (strlen (result
) >= 3 + 3
1577 && strisnan (result
, 0, strlen (result
) - 3, 0)
1578 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1579 ASSERT (retval
== strlen (result
));
1584 my_snprintf (result
, sizeof (result
), "%15e %d", 1.75, 33, 44, 55);
1585 ASSERT (strcmp (result
, " 1.750000e+00 33") == 0
1586 || strcmp (result
, " 1.750000e+000 33") == 0);
1587 ASSERT (retval
== strlen (result
));
1592 my_snprintf (result
, sizeof (result
), "%-15e %d", 1.75, 33, 44, 55);
1593 ASSERT (strcmp (result
, "1.750000e+00 33") == 0
1594 || strcmp (result
, "1.750000e+000 33") == 0);
1595 ASSERT (retval
== strlen (result
));
1598 { /* FLAG_SHOWSIGN. */
1600 my_snprintf (result
, sizeof (result
), "%+e %d", 1.75, 33, 44, 55);
1601 ASSERT (strcmp (result
, "+1.750000e+00 33") == 0
1602 || strcmp (result
, "+1.750000e+000 33") == 0);
1603 ASSERT (retval
== strlen (result
));
1608 my_snprintf (result
, sizeof (result
), "% e %d", 1.75, 33, 44, 55);
1609 ASSERT (strcmp (result
, " 1.750000e+00 33") == 0
1610 || strcmp (result
, " 1.750000e+000 33") == 0);
1611 ASSERT (retval
== strlen (result
));
1616 my_snprintf (result
, sizeof (result
), "%#e %d", 1.75, 33, 44, 55);
1617 ASSERT (strcmp (result
, "1.750000e+00 33") == 0
1618 || strcmp (result
, "1.750000e+000 33") == 0);
1619 ASSERT (retval
== strlen (result
));
1624 my_snprintf (result
, sizeof (result
), "%#.e %d", 1.75, 33, 44, 55);
1625 ASSERT (strcmp (result
, "2.e+00 33") == 0
1626 || strcmp (result
, "2.e+000 33") == 0);
1627 ASSERT (retval
== strlen (result
));
1632 my_snprintf (result
, sizeof (result
), "%#.e %d", 9.75, 33, 44, 55);
1633 ASSERT (strcmp (result
, "1.e+01 33") == 0
1634 || strcmp (result
, "1.e+001 33") == 0);
1635 ASSERT (retval
== strlen (result
));
1638 { /* FLAG_ZERO with finite number. */
1640 my_snprintf (result
, sizeof (result
), "%015e %d", 1234.0, 33, 44, 55);
1641 ASSERT (strcmp (result
, "0001.234000e+03 33") == 0
1642 || strcmp (result
, "001.234000e+003 33") == 0);
1643 ASSERT (retval
== strlen (result
));
1646 { /* FLAG_ZERO with infinite number. */
1648 my_snprintf (result
, sizeof (result
), "%015e %d", - Infinityd (), 33, 44, 55);
1649 ASSERT (strcmp (result
, " -inf 33") == 0
1650 || strcmp (result
, " -infinity 33") == 0);
1651 ASSERT (retval
== strlen (result
));
1654 { /* FLAG_ZERO with NaN. */
1656 my_snprintf (result
, sizeof (result
), "%050e %d", NaNd (), 33, 44, 55);
1657 ASSERT (strlen (result
) == 50 + 3
1658 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
1659 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1660 ASSERT (retval
== strlen (result
));
1665 my_snprintf (result
, sizeof (result
), "%.e %d", 1234.0, 33, 44, 55);
1666 ASSERT (strcmp (result
, "1e+03 33") == 0
1667 || strcmp (result
, "1e+003 33") == 0);
1668 ASSERT (retval
== strlen (result
));
1671 { /* Precision with no rounding. */
1673 my_snprintf (result
, sizeof (result
), "%.4e %d", 999.951, 33, 44, 55);
1674 ASSERT (strcmp (result
, "9.9995e+02 33") == 0
1675 || strcmp (result
, "9.9995e+002 33") == 0);
1676 ASSERT (retval
== strlen (result
));
1679 { /* Precision with rounding. */
1681 my_snprintf (result
, sizeof (result
), "%.4e %d", 999.996, 33, 44, 55);
1682 ASSERT (strcmp (result
, "1.0000e+03 33") == 0
1683 || strcmp (result
, "1.0000e+003 33") == 0);
1684 ASSERT (retval
== strlen (result
));
1687 { /* A positive number. */
1689 my_snprintf (result
, sizeof (result
), "%Le %d", 12.75L, 33, 44, 55);
1690 ASSERT (strcmp (result
, "1.275000e+01 33") == 0
1691 || strcmp (result
, "1.275000e+001 33") == 0);
1692 ASSERT (retval
== strlen (result
));
1695 { /* A larger positive number. */
1697 my_snprintf (result
, sizeof (result
), "%Le %d", 1234567.0L, 33, 44, 55);
1698 ASSERT (strcmp (result
, "1.234567e+06 33") == 0
1699 || strcmp (result
, "1.234567e+006 33") == 0);
1700 ASSERT (retval
== strlen (result
));
1703 { /* Small and large positive numbers. */
1704 static struct { long double value
; const char *string
; } data
[] =
1706 { 1.234321234321234e-37L, "1.234321e-37" },
1707 { 1.234321234321234e-36L, "1.234321e-36" },
1708 { 1.234321234321234e-35L, "1.234321e-35" },
1709 { 1.234321234321234e-34L, "1.234321e-34" },
1710 { 1.234321234321234e-33L, "1.234321e-33" },
1711 { 1.234321234321234e-32L, "1.234321e-32" },
1712 { 1.234321234321234e-31L, "1.234321e-31" },
1713 { 1.234321234321234e-30L, "1.234321e-30" },
1714 { 1.234321234321234e-29L, "1.234321e-29" },
1715 { 1.234321234321234e-28L, "1.234321e-28" },
1716 { 1.234321234321234e-27L, "1.234321e-27" },
1717 { 1.234321234321234e-26L, "1.234321e-26" },
1718 { 1.234321234321234e-25L, "1.234321e-25" },
1719 { 1.234321234321234e-24L, "1.234321e-24" },
1720 { 1.234321234321234e-23L, "1.234321e-23" },
1721 { 1.234321234321234e-22L, "1.234321e-22" },
1722 { 1.234321234321234e-21L, "1.234321e-21" },
1723 { 1.234321234321234e-20L, "1.234321e-20" },
1724 { 1.234321234321234e-19L, "1.234321e-19" },
1725 { 1.234321234321234e-18L, "1.234321e-18" },
1726 { 1.234321234321234e-17L, "1.234321e-17" },
1727 { 1.234321234321234e-16L, "1.234321e-16" },
1728 { 1.234321234321234e-15L, "1.234321e-15" },
1729 { 1.234321234321234e-14L, "1.234321e-14" },
1730 { 1.234321234321234e-13L, "1.234321e-13" },
1731 { 1.234321234321234e-12L, "1.234321e-12" },
1732 { 1.234321234321234e-11L, "1.234321e-11" },
1733 { 1.234321234321234e-10L, "1.234321e-10" },
1734 { 1.234321234321234e-9L, "1.234321e-09" },
1735 { 1.234321234321234e-8L, "1.234321e-08" },
1736 { 1.234321234321234e-7L, "1.234321e-07" },
1737 { 1.234321234321234e-6L, "1.234321e-06" },
1738 { 1.234321234321234e-5L, "1.234321e-05" },
1739 { 1.234321234321234e-4L, "1.234321e-04" },
1740 { 1.234321234321234e-3L, "1.234321e-03" },
1741 { 1.234321234321234e-2L, "1.234321e-02" },
1742 { 1.234321234321234e-1L, "1.234321e-01" },
1743 { 1.234321234321234L, "1.234321e+00" },
1744 { 1.234321234321234e1L
, "1.234321e+01" },
1745 { 1.234321234321234e2L
, "1.234321e+02" },
1746 { 1.234321234321234e3L
, "1.234321e+03" },
1747 { 1.234321234321234e4L
, "1.234321e+04" },
1748 { 1.234321234321234e5L
, "1.234321e+05" },
1749 { 1.234321234321234e6L
, "1.234321e+06" },
1750 { 1.234321234321234e7L
, "1.234321e+07" },
1751 { 1.234321234321234e8L
, "1.234321e+08" },
1752 { 1.234321234321234e9L
, "1.234321e+09" },
1753 { 1.234321234321234e10L
, "1.234321e+10" },
1754 { 1.234321234321234e11L
, "1.234321e+11" },
1755 { 1.234321234321234e12L
, "1.234321e+12" },
1756 { 1.234321234321234e13L
, "1.234321e+13" },
1757 { 1.234321234321234e14L
, "1.234321e+14" },
1758 { 1.234321234321234e15L
, "1.234321e+15" },
1759 { 1.234321234321234e16L
, "1.234321e+16" },
1760 { 1.234321234321234e17L
, "1.234321e+17" },
1761 { 1.234321234321234e18L
, "1.234321e+18" },
1762 { 1.234321234321234e19L
, "1.234321e+19" },
1763 { 1.234321234321234e20L
, "1.234321e+20" },
1764 { 1.234321234321234e21L
, "1.234321e+21" },
1765 { 1.234321234321234e22L
, "1.234321e+22" },
1766 { 1.234321234321234e23L
, "1.234321e+23" },
1767 { 1.234321234321234e24L
, "1.234321e+24" },
1768 { 1.234321234321234e25L
, "1.234321e+25" },
1769 { 1.234321234321234e26L
, "1.234321e+26" },
1770 { 1.234321234321234e27L
, "1.234321e+27" },
1771 { 1.234321234321234e28L
, "1.234321e+28" },
1772 { 1.234321234321234e29L
, "1.234321e+29" },
1773 { 1.234321234321234e30L
, "1.234321e+30" },
1774 { 1.234321234321234e31L
, "1.234321e+31" },
1775 { 1.234321234321234e32L
, "1.234321e+32" },
1776 { 1.234321234321234e33L
, "1.234321e+33" },
1777 { 1.234321234321234e34L
, "1.234321e+34" },
1778 { 1.234321234321234e35L
, "1.234321e+35" },
1779 { 1.234321234321234e36L
, "1.234321e+36" }
1782 for (k
= 0; k
< SIZEOF (data
); k
++)
1785 my_snprintf (result
, sizeof (result
), "%Le", data
[k
].value
);
1786 const char *expected
= data
[k
].string
;
1787 ASSERT (strcmp (result
, expected
) == 0
1788 /* Some implementations produce exponents with 3 digits. */
1789 || (strlen (result
) == strlen (expected
) + 1
1790 && memcmp (result
, expected
, strlen (expected
) - 2) == 0
1791 && result
[strlen (expected
) - 2] == '0'
1792 && strcmp (result
+ strlen (expected
) - 1,
1793 expected
+ strlen (expected
) - 2)
1795 ASSERT (retval
== strlen (result
));
1799 { /* A negative number. */
1801 my_snprintf (result
, sizeof (result
), "%Le %d", -0.03125L, 33, 44, 55);
1802 ASSERT (strcmp (result
, "-3.125000e-02 33") == 0
1803 || strcmp (result
, "-3.125000e-002 33") == 0);
1804 ASSERT (retval
== strlen (result
));
1807 { /* Positive zero. */
1809 my_snprintf (result
, sizeof (result
), "%Le %d", 0.0L, 33, 44, 55);
1810 ASSERT (strcmp (result
, "0.000000e+00 33") == 0
1811 || strcmp (result
, "0.000000e+000 33") == 0);
1812 ASSERT (retval
== strlen (result
));
1815 { /* Negative zero. */
1817 my_snprintf (result
, sizeof (result
), "%Le %d", minus_zerol
, 33, 44, 55);
1818 if (have_minus_zero ())
1819 ASSERT (strcmp (result
, "-0.000000e+00 33") == 0
1820 || strcmp (result
, "-0.000000e+000 33") == 0);
1821 ASSERT (retval
== strlen (result
));
1824 { /* Positive infinity. */
1826 my_snprintf (result
, sizeof (result
), "%Le %d", Infinityl (), 33, 44, 55);
1827 ASSERT (strcmp (result
, "inf 33") == 0
1828 || strcmp (result
, "infinity 33") == 0);
1829 ASSERT (retval
== strlen (result
));
1832 { /* Negative infinity. */
1834 my_snprintf (result
, sizeof (result
), "%Le %d", - Infinityl (), 33, 44, 55);
1835 ASSERT (strcmp (result
, "-inf 33") == 0
1836 || strcmp (result
, "-infinity 33") == 0);
1837 ASSERT (retval
== strlen (result
));
1842 my_snprintf (result
, sizeof (result
), "%Le %d", NaNl (), 33, 44, 55);
1843 ASSERT (strlen (result
) >= 3 + 3
1844 && strisnan (result
, 0, strlen (result
) - 3, 0)
1845 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1846 ASSERT (retval
== strlen (result
));
1848 #if CHECK_PRINTF_SAFE && ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
1850 static union { unsigned int word
[4]; long double value
; } x
=
1851 { LDBL80_WORDS (0xFFFF, 0xC3333333, 0x00000000) };
1853 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1854 ASSERT (strlen (result
) >= 3 + 3
1855 && strisnan (result
, 0, strlen (result
) - 3, 0)
1856 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1857 ASSERT (retval
== strlen (result
));
1860 /* Signalling NaN. */
1861 static union { unsigned int word
[4]; long double value
; } x
=
1862 { LDBL80_WORDS (0xFFFF, 0x83333333, 0x00000000) };
1864 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1865 ASSERT (strlen (result
) >= 3 + 3
1866 && strisnan (result
, 0, strlen (result
) - 3, 0)
1867 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1868 ASSERT (retval
== strlen (result
));
1870 /* snprintf should print something for noncanonical values. */
1872 static union { unsigned int word
[4]; long double value
; } x
=
1873 { LDBL80_WORDS (0xFFFF, 0x40000001, 0x00000000) };
1875 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1876 ASSERT (retval
== strlen (result
));
1877 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1879 { /* Pseudo-Infinity. */
1880 static union { unsigned int word
[4]; long double value
; } x
=
1881 { LDBL80_WORDS (0xFFFF, 0x00000000, 0x00000000) };
1883 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1884 ASSERT (retval
== strlen (result
));
1885 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1887 { /* Pseudo-Zero. */
1888 static union { unsigned int word
[4]; long double value
; } x
=
1889 { LDBL80_WORDS (0x4004, 0x00000000, 0x00000000) };
1891 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1892 ASSERT (retval
== strlen (result
));
1893 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1895 { /* Unnormalized number. */
1896 static union { unsigned int word
[4]; long double value
; } x
=
1897 { LDBL80_WORDS (0x4000, 0x63333333, 0x00000000) };
1899 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1900 ASSERT (retval
== strlen (result
));
1901 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1903 { /* Pseudo-Denormal. */
1904 static union { unsigned int word
[4]; long double value
; } x
=
1905 { LDBL80_WORDS (0x0000, 0x83333333, 0x00000000) };
1907 my_snprintf (result
, sizeof (result
), "%Le %d", x
.value
, 33, 44, 55);
1908 ASSERT (retval
== strlen (result
));
1909 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
1915 my_snprintf (result
, sizeof (result
), "%15Le %d", 1.75L, 33, 44, 55);
1916 ASSERT (strcmp (result
, " 1.750000e+00 33") == 0
1917 || strcmp (result
, " 1.750000e+000 33") == 0);
1918 ASSERT (retval
== strlen (result
));
1923 my_snprintf (result
, sizeof (result
), "%-15Le %d", 1.75L, 33, 44, 55);
1924 ASSERT (strcmp (result
, "1.750000e+00 33") == 0
1925 || strcmp (result
, "1.750000e+000 33") == 0);
1926 ASSERT (retval
== strlen (result
));
1929 { /* FLAG_SHOWSIGN. */
1931 my_snprintf (result
, sizeof (result
), "%+Le %d", 1.75L, 33, 44, 55);
1932 ASSERT (strcmp (result
, "+1.750000e+00 33") == 0
1933 || strcmp (result
, "+1.750000e+000 33") == 0);
1934 ASSERT (retval
== strlen (result
));
1939 my_snprintf (result
, sizeof (result
), "% Le %d", 1.75L, 33, 44, 55);
1940 ASSERT (strcmp (result
, " 1.750000e+00 33") == 0
1941 || strcmp (result
, " 1.750000e+000 33") == 0);
1942 ASSERT (retval
== strlen (result
));
1947 my_snprintf (result
, sizeof (result
), "%#Le %d", 1.75L, 33, 44, 55);
1948 ASSERT (strcmp (result
, "1.750000e+00 33") == 0
1949 || strcmp (result
, "1.750000e+000 33") == 0);
1950 ASSERT (retval
== strlen (result
));
1955 my_snprintf (result
, sizeof (result
), "%#.Le %d", 1.75L, 33, 44, 55);
1956 ASSERT (strcmp (result
, "2.e+00 33") == 0
1957 || strcmp (result
, "2.e+000 33") == 0);
1958 ASSERT (retval
== strlen (result
));
1963 my_snprintf (result
, sizeof (result
), "%#.Le %d", 9.75L, 33, 44, 55);
1964 ASSERT (strcmp (result
, "1.e+01 33") == 0
1965 || strcmp (result
, "1.e+001 33") == 0);
1966 ASSERT (retval
== strlen (result
));
1969 { /* FLAG_ZERO with finite number. */
1971 my_snprintf (result
, sizeof (result
), "%015Le %d", 1234.0L, 33, 44, 55);
1972 ASSERT (strcmp (result
, "0001.234000e+03 33") == 0
1973 || strcmp (result
, "001.234000e+003 33") == 0);
1974 ASSERT (retval
== strlen (result
));
1977 { /* FLAG_ZERO with infinite number. */
1979 my_snprintf (result
, sizeof (result
), "%015Le %d", - Infinityl (), 33, 44, 55);
1980 ASSERT (strcmp (result
, " -inf 33") == 0
1981 || strcmp (result
, " -infinity 33") == 0);
1982 ASSERT (retval
== strlen (result
));
1985 { /* FLAG_ZERO with NaN. */
1987 my_snprintf (result
, sizeof (result
), "%050Le %d", NaNl (), 33, 44, 55);
1988 ASSERT (strlen (result
) == 50 + 3
1989 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
1990 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
1991 ASSERT (retval
== strlen (result
));
1996 my_snprintf (result
, sizeof (result
), "%.Le %d", 1234.0L, 33, 44, 55);
1997 ASSERT (strcmp (result
, "1e+03 33") == 0
1998 || strcmp (result
, "1e+003 33") == 0);
1999 ASSERT (retval
== strlen (result
));
2002 { /* Precision with no rounding. */
2004 my_snprintf (result
, sizeof (result
), "%.4Le %d", 999.951L, 33, 44, 55);
2005 ASSERT (strcmp (result
, "9.9995e+02 33") == 0
2006 || strcmp (result
, "9.9995e+002 33") == 0);
2007 ASSERT (retval
== strlen (result
));
2010 { /* Precision with rounding. */
2012 my_snprintf (result
, sizeof (result
), "%.4Le %d", 999.996L, 33, 44, 55);
2013 ASSERT (strcmp (result
, "1.0000e+03 33") == 0
2014 || strcmp (result
, "1.0000e+003 33") == 0);
2015 ASSERT (retval
== strlen (result
));
2018 /* Test the support of the %g format directive. */
2020 { /* A positive number. */
2022 my_snprintf (result
, sizeof (result
), "%g %d", 12.75, 33, 44, 55);
2023 ASSERT (strcmp (result
, "12.75 33") == 0);
2024 ASSERT (retval
== strlen (result
));
2027 { /* A larger positive number. */
2029 my_snprintf (result
, sizeof (result
), "%g %d", 1234567.0, 33, 44, 55);
2030 ASSERT (strcmp (result
, "1.23457e+06 33") == 0
2031 || strcmp (result
, "1.23457e+006 33") == 0);
2032 ASSERT (retval
== strlen (result
));
2035 { /* Small and large positive numbers. */
2036 static struct { double value
; const char *string
; } data
[] =
2038 { 1.234321234321234e-37, "1.23432e-37" },
2039 { 1.234321234321234e-36, "1.23432e-36" },
2040 { 1.234321234321234e-35, "1.23432e-35" },
2041 { 1.234321234321234e-34, "1.23432e-34" },
2042 { 1.234321234321234e-33, "1.23432e-33" },
2043 { 1.234321234321234e-32, "1.23432e-32" },
2044 { 1.234321234321234e-31, "1.23432e-31" },
2045 { 1.234321234321234e-30, "1.23432e-30" },
2046 { 1.234321234321234e-29, "1.23432e-29" },
2047 { 1.234321234321234e-28, "1.23432e-28" },
2048 { 1.234321234321234e-27, "1.23432e-27" },
2049 { 1.234321234321234e-26, "1.23432e-26" },
2050 { 1.234321234321234e-25, "1.23432e-25" },
2051 { 1.234321234321234e-24, "1.23432e-24" },
2052 { 1.234321234321234e-23, "1.23432e-23" },
2053 { 1.234321234321234e-22, "1.23432e-22" },
2054 { 1.234321234321234e-21, "1.23432e-21" },
2055 { 1.234321234321234e-20, "1.23432e-20" },
2056 { 1.234321234321234e-19, "1.23432e-19" },
2057 { 1.234321234321234e-18, "1.23432e-18" },
2058 { 1.234321234321234e-17, "1.23432e-17" },
2059 { 1.234321234321234e-16, "1.23432e-16" },
2060 { 1.234321234321234e-15, "1.23432e-15" },
2061 { 1.234321234321234e-14, "1.23432e-14" },
2062 { 1.234321234321234e-13, "1.23432e-13" },
2063 { 1.234321234321234e-12, "1.23432e-12" },
2064 { 1.234321234321234e-11, "1.23432e-11" },
2065 { 1.234321234321234e-10, "1.23432e-10" },
2066 { 1.234321234321234e-9, "1.23432e-09" },
2067 { 1.234321234321234e-8, "1.23432e-08" },
2068 { 1.234321234321234e-7, "1.23432e-07" },
2069 { 1.234321234321234e-6, "1.23432e-06" },
2070 { 1.234321234321234e-5, "1.23432e-05" },
2071 { 1.234321234321234e-4, "0.000123432" },
2072 { 1.234321234321234e-3, "0.00123432" },
2073 { 1.234321234321234e-2, "0.0123432" },
2074 { 1.234321234321234e-1, "0.123432" },
2075 { 1.234321234321234, "1.23432" },
2076 { 1.234321234321234e1
, "12.3432" },
2077 { 1.234321234321234e2
, "123.432" },
2078 { 1.234321234321234e3
, "1234.32" },
2079 { 1.234321234321234e4
, "12343.2" },
2080 { 1.234321234321234e5
, "123432" },
2081 { 1.234321234321234e6
, "1.23432e+06" },
2082 { 1.234321234321234e7
, "1.23432e+07" },
2083 { 1.234321234321234e8
, "1.23432e+08" },
2084 { 1.234321234321234e9
, "1.23432e+09" },
2085 { 1.234321234321234e10
, "1.23432e+10" },
2086 { 1.234321234321234e11
, "1.23432e+11" },
2087 { 1.234321234321234e12
, "1.23432e+12" },
2088 { 1.234321234321234e13
, "1.23432e+13" },
2089 { 1.234321234321234e14
, "1.23432e+14" },
2090 { 1.234321234321234e15
, "1.23432e+15" },
2091 { 1.234321234321234e16
, "1.23432e+16" },
2092 { 1.234321234321234e17
, "1.23432e+17" },
2093 { 1.234321234321234e18
, "1.23432e+18" },
2094 { 1.234321234321234e19
, "1.23432e+19" },
2095 { 1.234321234321234e20
, "1.23432e+20" },
2096 { 1.234321234321234e21
, "1.23432e+21" },
2097 { 1.234321234321234e22
, "1.23432e+22" },
2098 { 1.234321234321234e23
, "1.23432e+23" },
2099 { 1.234321234321234e24
, "1.23432e+24" },
2100 { 1.234321234321234e25
, "1.23432e+25" },
2101 { 1.234321234321234e26
, "1.23432e+26" },
2102 { 1.234321234321234e27
, "1.23432e+27" },
2103 { 1.234321234321234e28
, "1.23432e+28" },
2104 { 1.234321234321234e29
, "1.23432e+29" },
2105 { 1.234321234321234e30
, "1.23432e+30" },
2106 { 1.234321234321234e31
, "1.23432e+31" },
2107 { 1.234321234321234e32
, "1.23432e+32" },
2108 { 1.234321234321234e33
, "1.23432e+33" },
2109 { 1.234321234321234e34
, "1.23432e+34" },
2110 { 1.234321234321234e35
, "1.23432e+35" },
2111 { 1.234321234321234e36
, "1.23432e+36" }
2114 for (k
= 0; k
< SIZEOF (data
); k
++)
2117 my_snprintf (result
, sizeof (result
), "%g", data
[k
].value
);
2118 const char *expected
= data
[k
].string
;
2119 ASSERT (strcmp (result
, expected
) == 0
2120 /* Some implementations produce exponents with 3 digits. */
2121 || (expected
[strlen (expected
) - 4] == 'e'
2122 && strlen (result
) == strlen (expected
) + 1
2123 && memcmp (result
, expected
, strlen (expected
) - 2) == 0
2124 && result
[strlen (expected
) - 2] == '0'
2125 && strcmp (result
+ strlen (expected
) - 1,
2126 expected
+ strlen (expected
) - 2)
2128 ASSERT (retval
== strlen (result
));
2132 { /* A negative number. */
2134 my_snprintf (result
, sizeof (result
), "%g %d", -0.03125, 33, 44, 55);
2135 ASSERT (strcmp (result
, "-0.03125 33") == 0);
2136 ASSERT (retval
== strlen (result
));
2139 { /* Positive zero. */
2141 my_snprintf (result
, sizeof (result
), "%g %d", 0.0, 33, 44, 55);
2142 ASSERT (strcmp (result
, "0 33") == 0);
2143 ASSERT (retval
== strlen (result
));
2146 { /* Negative zero. */
2148 my_snprintf (result
, sizeof (result
), "%g %d", minus_zerod
, 33, 44, 55);
2149 if (have_minus_zero ())
2150 ASSERT (strcmp (result
, "-0 33") == 0);
2151 ASSERT (retval
== strlen (result
));
2154 { /* Positive infinity. */
2156 my_snprintf (result
, sizeof (result
), "%g %d", Infinityd (), 33, 44, 55);
2157 ASSERT (strcmp (result
, "inf 33") == 0
2158 || strcmp (result
, "infinity 33") == 0);
2159 ASSERT (retval
== strlen (result
));
2162 { /* Negative infinity. */
2164 my_snprintf (result
, sizeof (result
), "%g %d", - Infinityd (), 33, 44, 55);
2165 ASSERT (strcmp (result
, "-inf 33") == 0
2166 || strcmp (result
, "-infinity 33") == 0);
2167 ASSERT (retval
== strlen (result
));
2172 my_snprintf (result
, sizeof (result
), "%g %d", NaNd (), 33, 44, 55);
2173 ASSERT (strlen (result
) >= 3 + 3
2174 && strisnan (result
, 0, strlen (result
) - 3, 0)
2175 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
2176 ASSERT (retval
== strlen (result
));
2181 my_snprintf (result
, sizeof (result
), "%10g %d", 1.75, 33, 44, 55);
2182 ASSERT (strcmp (result
, " 1.75 33") == 0);
2183 ASSERT (retval
== strlen (result
));
2188 my_snprintf (result
, sizeof (result
), "%-10g %d", 1.75, 33, 44, 55);
2189 ASSERT (strcmp (result
, "1.75 33") == 0);
2190 ASSERT (retval
== strlen (result
));
2193 { /* FLAG_SHOWSIGN. */
2195 my_snprintf (result
, sizeof (result
), "%+g %d", 1.75, 33, 44, 55);
2196 ASSERT (strcmp (result
, "+1.75 33") == 0);
2197 ASSERT (retval
== strlen (result
));
2202 my_snprintf (result
, sizeof (result
), "% g %d", 1.75, 33, 44, 55);
2203 ASSERT (strcmp (result
, " 1.75 33") == 0);
2204 ASSERT (retval
== strlen (result
));
2209 my_snprintf (result
, sizeof (result
), "%#g %d", 1.75, 33, 44, 55);
2210 ASSERT (strcmp (result
, "1.75000 33") == 0);
2211 ASSERT (retval
== strlen (result
));
2216 my_snprintf (result
, sizeof (result
), "%#.g %d", 1.75, 33, 44, 55);
2217 ASSERT (strcmp (result
, "2. 33") == 0);
2218 ASSERT (retval
== strlen (result
));
2223 my_snprintf (result
, sizeof (result
), "%#.g %d", 9.75, 33, 44, 55);
2224 ASSERT (strcmp (result
, "1.e+01 33") == 0
2225 || strcmp (result
, "1.e+001 33") == 0);
2226 ASSERT (retval
== strlen (result
));
2229 { /* FLAG_ZERO with finite number. */
2231 my_snprintf (result
, sizeof (result
), "%010g %d", 1234.0, 33, 44, 55);
2232 ASSERT (strcmp (result
, "0000001234 33") == 0);
2233 ASSERT (retval
== strlen (result
));
2236 { /* FLAG_ZERO with infinite number. */
2238 my_snprintf (result
, sizeof (result
), "%015g %d", - Infinityd (), 33, 44, 55);
2239 ASSERT (strcmp (result
, " -inf 33") == 0
2240 || strcmp (result
, " -infinity 33") == 0);
2241 ASSERT (retval
== strlen (result
));
2244 { /* FLAG_ZERO with NaN. */
2246 my_snprintf (result
, sizeof (result
), "%050g %d", NaNd (), 33, 44, 55);
2247 ASSERT (strlen (result
) == 50 + 3
2248 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
2249 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
2250 ASSERT (retval
== strlen (result
));
2255 my_snprintf (result
, sizeof (result
), "%.g %d", 1234.0, 33, 44, 55);
2256 ASSERT (strcmp (result
, "1e+03 33") == 0
2257 || strcmp (result
, "1e+003 33") == 0);
2258 ASSERT (retval
== strlen (result
));
2261 { /* Precision with no rounding. */
2263 my_snprintf (result
, sizeof (result
), "%.5g %d", 999.951, 33, 44, 55);
2264 ASSERT (strcmp (result
, "999.95 33") == 0);
2265 ASSERT (retval
== strlen (result
));
2268 { /* Precision with rounding. */
2270 my_snprintf (result
, sizeof (result
), "%.5g %d", 999.996, 33, 44, 55);
2271 ASSERT (strcmp (result
, "1000 33") == 0);
2272 ASSERT (retval
== strlen (result
));
2275 { /* A positive number. */
2277 my_snprintf (result
, sizeof (result
), "%Lg %d", 12.75L, 33, 44, 55);
2278 ASSERT (strcmp (result
, "12.75 33") == 0);
2279 ASSERT (retval
== strlen (result
));
2282 { /* A larger positive number. */
2284 my_snprintf (result
, sizeof (result
), "%Lg %d", 1234567.0L, 33, 44, 55);
2285 ASSERT (strcmp (result
, "1.23457e+06 33") == 0
2286 || strcmp (result
, "1.23457e+006 33") == 0);
2287 ASSERT (retval
== strlen (result
));
2290 { /* Small and large positive numbers. */
2291 static struct { long double value
; const char *string
; } data
[] =
2293 { 1.234321234321234e-37L, "1.23432e-37" },
2294 { 1.234321234321234e-36L, "1.23432e-36" },
2295 { 1.234321234321234e-35L, "1.23432e-35" },
2296 { 1.234321234321234e-34L, "1.23432e-34" },
2297 { 1.234321234321234e-33L, "1.23432e-33" },
2298 { 1.234321234321234e-32L, "1.23432e-32" },
2299 { 1.234321234321234e-31L, "1.23432e-31" },
2300 { 1.234321234321234e-30L, "1.23432e-30" },
2301 { 1.234321234321234e-29L, "1.23432e-29" },
2302 { 1.234321234321234e-28L, "1.23432e-28" },
2303 { 1.234321234321234e-27L, "1.23432e-27" },
2304 { 1.234321234321234e-26L, "1.23432e-26" },
2305 { 1.234321234321234e-25L, "1.23432e-25" },
2306 { 1.234321234321234e-24L, "1.23432e-24" },
2307 { 1.234321234321234e-23L, "1.23432e-23" },
2308 { 1.234321234321234e-22L, "1.23432e-22" },
2309 { 1.234321234321234e-21L, "1.23432e-21" },
2310 { 1.234321234321234e-20L, "1.23432e-20" },
2311 { 1.234321234321234e-19L, "1.23432e-19" },
2312 { 1.234321234321234e-18L, "1.23432e-18" },
2313 { 1.234321234321234e-17L, "1.23432e-17" },
2314 { 1.234321234321234e-16L, "1.23432e-16" },
2315 { 1.234321234321234e-15L, "1.23432e-15" },
2316 { 1.234321234321234e-14L, "1.23432e-14" },
2317 { 1.234321234321234e-13L, "1.23432e-13" },
2318 { 1.234321234321234e-12L, "1.23432e-12" },
2319 { 1.234321234321234e-11L, "1.23432e-11" },
2320 { 1.234321234321234e-10L, "1.23432e-10" },
2321 { 1.234321234321234e-9L, "1.23432e-09" },
2322 { 1.234321234321234e-8L, "1.23432e-08" },
2323 { 1.234321234321234e-7L, "1.23432e-07" },
2324 { 1.234321234321234e-6L, "1.23432e-06" },
2325 { 1.234321234321234e-5L, "1.23432e-05" },
2326 { 1.234321234321234e-4L, "0.000123432" },
2327 { 1.234321234321234e-3L, "0.00123432" },
2328 { 1.234321234321234e-2L, "0.0123432" },
2329 { 1.234321234321234e-1L, "0.123432" },
2330 { 1.234321234321234L, "1.23432" },
2331 { 1.234321234321234e1L
, "12.3432" },
2332 { 1.234321234321234e2L
, "123.432" },
2333 { 1.234321234321234e3L
, "1234.32" },
2334 { 1.234321234321234e4L
, "12343.2" },
2335 { 1.234321234321234e5L
, "123432" },
2336 { 1.234321234321234e6L
, "1.23432e+06" },
2337 { 1.234321234321234e7L
, "1.23432e+07" },
2338 { 1.234321234321234e8L
, "1.23432e+08" },
2339 { 1.234321234321234e9L
, "1.23432e+09" },
2340 { 1.234321234321234e10L
, "1.23432e+10" },
2341 { 1.234321234321234e11L
, "1.23432e+11" },
2342 { 1.234321234321234e12L
, "1.23432e+12" },
2343 { 1.234321234321234e13L
, "1.23432e+13" },
2344 { 1.234321234321234e14L
, "1.23432e+14" },
2345 { 1.234321234321234e15L
, "1.23432e+15" },
2346 { 1.234321234321234e16L
, "1.23432e+16" },
2347 { 1.234321234321234e17L
, "1.23432e+17" },
2348 { 1.234321234321234e18L
, "1.23432e+18" },
2349 { 1.234321234321234e19L
, "1.23432e+19" },
2350 { 1.234321234321234e20L
, "1.23432e+20" },
2351 { 1.234321234321234e21L
, "1.23432e+21" },
2352 { 1.234321234321234e22L
, "1.23432e+22" },
2353 { 1.234321234321234e23L
, "1.23432e+23" },
2354 { 1.234321234321234e24L
, "1.23432e+24" },
2355 { 1.234321234321234e25L
, "1.23432e+25" },
2356 { 1.234321234321234e26L
, "1.23432e+26" },
2357 { 1.234321234321234e27L
, "1.23432e+27" },
2358 { 1.234321234321234e28L
, "1.23432e+28" },
2359 { 1.234321234321234e29L
, "1.23432e+29" },
2360 { 1.234321234321234e30L
, "1.23432e+30" },
2361 { 1.234321234321234e31L
, "1.23432e+31" },
2362 { 1.234321234321234e32L
, "1.23432e+32" },
2363 { 1.234321234321234e33L
, "1.23432e+33" },
2364 { 1.234321234321234e34L
, "1.23432e+34" },
2365 { 1.234321234321234e35L
, "1.23432e+35" },
2366 { 1.234321234321234e36L
, "1.23432e+36" }
2369 for (k
= 0; k
< SIZEOF (data
); k
++)
2372 my_snprintf (result
, sizeof (result
), "%Lg", data
[k
].value
);
2373 const char *expected
= data
[k
].string
;
2374 ASSERT (strcmp (result
, expected
) == 0
2375 /* Some implementations produce exponents with 3 digits. */
2376 || (expected
[strlen (expected
) - 4] == 'e'
2377 && strlen (result
) == strlen (expected
) + 1
2378 && memcmp (result
, expected
, strlen (expected
) - 2) == 0
2379 && result
[strlen (expected
) - 2] == '0'
2380 && strcmp (result
+ strlen (expected
) - 1,
2381 expected
+ strlen (expected
) - 2)
2383 ASSERT (retval
== strlen (result
));
2387 { /* A negative number. */
2389 my_snprintf (result
, sizeof (result
), "%Lg %d", -0.03125L, 33, 44, 55);
2390 ASSERT (strcmp (result
, "-0.03125 33") == 0);
2391 ASSERT (retval
== strlen (result
));
2394 { /* Positive zero. */
2396 my_snprintf (result
, sizeof (result
), "%Lg %d", 0.0L, 33, 44, 55);
2397 ASSERT (strcmp (result
, "0 33") == 0);
2398 ASSERT (retval
== strlen (result
));
2401 { /* Negative zero. */
2403 my_snprintf (result
, sizeof (result
), "%Lg %d", minus_zerol
, 33, 44, 55);
2404 if (have_minus_zero ())
2405 ASSERT (strcmp (result
, "-0 33") == 0);
2406 ASSERT (retval
== strlen (result
));
2409 { /* Positive infinity. */
2411 my_snprintf (result
, sizeof (result
), "%Lg %d", Infinityl (), 33, 44, 55);
2412 ASSERT (strcmp (result
, "inf 33") == 0
2413 || strcmp (result
, "infinity 33") == 0);
2414 ASSERT (retval
== strlen (result
));
2417 { /* Negative infinity. */
2419 my_snprintf (result
, sizeof (result
), "%Lg %d", - Infinityl (), 33, 44, 55);
2420 ASSERT (strcmp (result
, "-inf 33") == 0
2421 || strcmp (result
, "-infinity 33") == 0);
2422 ASSERT (retval
== strlen (result
));
2427 my_snprintf (result
, sizeof (result
), "%Lg %d", NaNl (), 33, 44, 55);
2428 ASSERT (strlen (result
) >= 3 + 3
2429 && strisnan (result
, 0, strlen (result
) - 3, 0)
2430 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
2431 ASSERT (retval
== strlen (result
));
2433 #if CHECK_PRINTF_SAFE && ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
2435 static union { unsigned int word
[4]; long double value
; } x
=
2436 { LDBL80_WORDS (0xFFFF, 0xC3333333, 0x00000000) };
2438 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2439 ASSERT (strlen (result
) >= 3 + 3
2440 && strisnan (result
, 0, strlen (result
) - 3, 0)
2441 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
2442 ASSERT (retval
== strlen (result
));
2445 /* Signalling NaN. */
2446 static union { unsigned int word
[4]; long double value
; } x
=
2447 { LDBL80_WORDS (0xFFFF, 0x83333333, 0x00000000) };
2449 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2450 ASSERT (strlen (result
) >= 3 + 3
2451 && strisnan (result
, 0, strlen (result
) - 3, 0)
2452 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
2453 ASSERT (retval
== strlen (result
));
2455 /* snprintf should print something for noncanonical values. */
2457 static union { unsigned int word
[4]; long double value
; } x
=
2458 { LDBL80_WORDS (0xFFFF, 0x40000001, 0x00000000) };
2460 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2461 ASSERT (retval
== strlen (result
));
2462 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
2464 { /* Pseudo-Infinity. */
2465 static union { unsigned int word
[4]; long double value
; } x
=
2466 { LDBL80_WORDS (0xFFFF, 0x00000000, 0x00000000) };
2468 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2469 ASSERT (retval
== strlen (result
));
2470 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
2472 { /* Pseudo-Zero. */
2473 static union { unsigned int word
[4]; long double value
; } x
=
2474 { LDBL80_WORDS (0x4004, 0x00000000, 0x00000000) };
2476 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2477 ASSERT (retval
== strlen (result
));
2478 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
2480 { /* Unnormalized number. */
2481 static union { unsigned int word
[4]; long double value
; } x
=
2482 { LDBL80_WORDS (0x4000, 0x63333333, 0x00000000) };
2484 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2485 ASSERT (retval
== strlen (result
));
2486 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
2488 { /* Pseudo-Denormal. */
2489 static union { unsigned int word
[4]; long double value
; } x
=
2490 { LDBL80_WORDS (0x0000, 0x83333333, 0x00000000) };
2492 my_snprintf (result
, sizeof (result
), "%Lg %d", x
.value
, 33, 44, 55);
2493 ASSERT (retval
== strlen (result
));
2494 ASSERT (3 < retval
&& strcmp (result
+ retval
- 3, " 33") == 0);
2500 my_snprintf (result
, sizeof (result
), "%10Lg %d", 1.75L, 33, 44, 55);
2501 ASSERT (strcmp (result
, " 1.75 33") == 0);
2502 ASSERT (retval
== strlen (result
));
2507 my_snprintf (result
, sizeof (result
), "%-10Lg %d", 1.75L, 33, 44, 55);
2508 ASSERT (strcmp (result
, "1.75 33") == 0);
2509 ASSERT (retval
== strlen (result
));
2512 { /* FLAG_SHOWSIGN. */
2514 my_snprintf (result
, sizeof (result
), "%+Lg %d", 1.75L, 33, 44, 55);
2515 ASSERT (strcmp (result
, "+1.75 33") == 0);
2516 ASSERT (retval
== strlen (result
));
2521 my_snprintf (result
, sizeof (result
), "% Lg %d", 1.75L, 33, 44, 55);
2522 ASSERT (strcmp (result
, " 1.75 33") == 0);
2523 ASSERT (retval
== strlen (result
));
2528 my_snprintf (result
, sizeof (result
), "%#Lg %d", 1.75L, 33, 44, 55);
2529 ASSERT (strcmp (result
, "1.75000 33") == 0);
2530 ASSERT (retval
== strlen (result
));
2535 my_snprintf (result
, sizeof (result
), "%#.Lg %d", 1.75L, 33, 44, 55);
2536 ASSERT (strcmp (result
, "2. 33") == 0);
2537 ASSERT (retval
== strlen (result
));
2542 my_snprintf (result
, sizeof (result
), "%#.Lg %d", 9.75L, 33, 44, 55);
2543 ASSERT (strcmp (result
, "1.e+01 33") == 0
2544 || strcmp (result
, "1.e+001 33") == 0);
2545 ASSERT (retval
== strlen (result
));
2548 { /* FLAG_ZERO with finite number. */
2550 my_snprintf (result
, sizeof (result
), "%010Lg %d", 1234.0L, 33, 44, 55);
2551 ASSERT (strcmp (result
, "0000001234 33") == 0);
2552 ASSERT (retval
== strlen (result
));
2555 { /* FLAG_ZERO with infinite number. */
2557 my_snprintf (result
, sizeof (result
), "%015Lg %d", - Infinityl (), 33, 44, 55);
2558 ASSERT (strcmp (result
, " -inf 33") == 0
2559 || strcmp (result
, " -infinity 33") == 0);
2560 ASSERT (retval
== strlen (result
));
2563 { /* FLAG_ZERO with NaN. */
2565 my_snprintf (result
, sizeof (result
), "%050Lg %d", NaNl (), 33, 44, 55);
2566 ASSERT (strlen (result
) == 50 + 3
2567 && strisnan (result
, strspn (result
, " "), strlen (result
) - 3, 0)
2568 && strcmp (result
+ strlen (result
) - 3, " 33") == 0);
2569 ASSERT (retval
== strlen (result
));
2574 my_snprintf (result
, sizeof (result
), "%.Lg %d", 1234.0L, 33, 44, 55);
2575 ASSERT (strcmp (result
, "1e+03 33") == 0
2576 || strcmp (result
, "1e+003 33") == 0);
2577 ASSERT (retval
== strlen (result
));
2580 { /* Precision with no rounding. */
2582 my_snprintf (result
, sizeof (result
), "%.5Lg %d", 999.951L, 33, 44, 55);
2583 ASSERT (strcmp (result
, "999.95 33") == 0);
2584 ASSERT (retval
== strlen (result
));
2587 { /* Precision with rounding. */
2589 my_snprintf (result
, sizeof (result
), "%.5Lg %d", 999.996L, 33, 44, 55);
2590 ASSERT (strcmp (result
, "1000 33") == 0);
2591 ASSERT (retval
== strlen (result
));
2594 /* Test the support of the %n format directive. */
2599 my_snprintf (result
, sizeof (result
), "%d %n", 123, &count
, 33, 44, 55);
2600 ASSERT (strcmp (result
, "123 ") == 0);
2601 ASSERT (retval
== strlen (result
));
2602 ASSERT (count
== 4);
2605 /* Test the support of the POSIX/XSI format strings with positions. */
2609 my_snprintf (result
, sizeof (result
), "%2$d %1$d", 33, 55);
2610 ASSERT (strcmp (result
, "55 33") == 0);
2611 ASSERT (retval
== strlen (result
));
2614 /* Test the support of the grouping flag. */
2618 my_snprintf (result
, sizeof (result
), "%'d %d", 1234567, 99);
2619 ASSERT (result
[strlen (result
) - 1] == '9');
2620 ASSERT (retval
== strlen (result
));
2623 /* Test the support of the left-adjust flag. */
2627 my_snprintf (result
, sizeof (result
), "a%*sc", -3, "b");
2628 ASSERT (strcmp (result
, "ab c") == 0);
2629 ASSERT (retval
== strlen (result
));
2634 my_snprintf (result
, sizeof (result
), "a%-*sc", 3, "b");
2635 ASSERT (strcmp (result
, "ab c") == 0);
2636 ASSERT (retval
== strlen (result
));
2641 my_snprintf (result
, sizeof (result
), "a%-*sc", -3, "b");
2642 ASSERT (strcmp (result
, "ab c") == 0);
2643 ASSERT (retval
== strlen (result
));
2646 /* Test the support of large precision. */
2650 my_snprintf (result
, sizeof (result
), "%.4000d %d", 1234567, 99);
2652 for (i
= 0; i
< 4000 - 7; i
++)
2653 ASSERT (result
[i
] == '0');
2654 ASSERT (strcmp (result
+ 4000 - 7, "1234567 99") == 0);
2655 ASSERT (retval
== strlen (result
));
2660 my_snprintf (result
, sizeof (result
), "%.*d %d", 4000, 1234567, 99);
2662 for (i
= 0; i
< 4000 - 7; i
++)
2663 ASSERT (result
[i
] == '0');
2664 ASSERT (strcmp (result
+ 4000 - 7, "1234567 99") == 0);
2665 ASSERT (retval
== strlen (result
));
2670 my_snprintf (result
, sizeof (result
), "%.4000d %d", -1234567, 99);
2672 ASSERT (result
[0] == '-');
2673 for (i
= 0; i
< 4000 - 7; i
++)
2674 ASSERT (result
[1 + i
] == '0');
2675 ASSERT (strcmp (result
+ 1 + 4000 - 7, "1234567 99") == 0);
2676 ASSERT (retval
== strlen (result
));
2681 my_snprintf (result
, sizeof (result
), "%.4000u %d", 1234567, 99);
2683 for (i
= 0; i
< 4000 - 7; i
++)
2684 ASSERT (result
[i
] == '0');
2685 ASSERT (strcmp (result
+ 4000 - 7, "1234567 99") == 0);
2686 ASSERT (retval
== strlen (result
));
2691 my_snprintf (result
, sizeof (result
), "%.4000o %d", 1234567, 99);
2693 for (i
= 0; i
< 4000 - 7; i
++)
2694 ASSERT (result
[i
] == '0');
2695 ASSERT (strcmp (result
+ 4000 - 7, "4553207 99") == 0);
2696 ASSERT (retval
== strlen (result
));
2701 my_snprintf (result
, sizeof (result
), "%.4000x %d", 1234567, 99);
2703 for (i
= 0; i
< 4000 - 6; i
++)
2704 ASSERT (result
[i
] == '0');
2705 ASSERT (strcmp (result
+ 4000 - 6, "12d687 99") == 0);
2706 ASSERT (retval
== strlen (result
));
2711 my_snprintf (result
, sizeof (result
), "%#.4000x %d", 1234567, 99);
2713 ASSERT (result
[0] == '0');
2714 ASSERT (result
[1] == 'x');
2715 for (i
= 0; i
< 4000 - 6; i
++)
2716 ASSERT (result
[2 + i
] == '0');
2717 ASSERT (strcmp (result
+ 2 + 4000 - 6, "12d687 99") == 0);
2718 ASSERT (retval
== strlen (result
));
2723 my_snprintf (result
, sizeof (result
), "%.4000f %d", 1.0, 99);
2725 ASSERT (result
[0] == '1');
2726 ASSERT (result
[1] == '.');
2727 for (i
= 0; i
< 4000; i
++)
2728 ASSERT (result
[2 + i
] == '0');
2729 ASSERT (strcmp (result
+ 2 + 4000, " 99") == 0);
2730 ASSERT (retval
== strlen (result
));
2735 my_snprintf (result
, sizeof (result
), "%.511f %d", 1.0, 99);
2737 ASSERT (result
[0] == '1');
2738 ASSERT (result
[1] == '.');
2739 for (i
= 0; i
< 511; i
++)
2740 ASSERT (result
[2 + i
] == '0');
2741 ASSERT (strcmp (result
+ 2 + 511, " 99") == 0);
2742 ASSERT (retval
== strlen (result
));
2750 for (i
= 0; i
< sizeof (input
) - 1; i
++)
2751 input
[i
] = 'a' + ((1000000 / (i
+ 1)) % 26);
2753 retval
= my_snprintf (result
, sizeof (result
), "%.4000s %d", input
, 99);
2754 ASSERT (memcmp (result
, input
, 4000) == 0);
2755 ASSERT (strcmp (result
+ 4000, " 99") == 0);
2756 ASSERT (retval
== strlen (result
));
2759 /* Test the support of the %s format directive. */
2761 /* To verify that these tests succeed, it is necessary to run them under
2762 a tool that checks against invalid memory accesses, such as ElectricFence
2763 or "valgrind --tool=memcheck". */
2767 for (i
= 1; i
<= 8; i
++)
2772 block
= (char *) malloc (i
);
2773 memcpy (block
, "abcdefgh", i
);
2774 retval
= my_snprintf (result
, sizeof (result
), "%.*s", (int) i
, block
);
2775 ASSERT (memcmp (result
, block
, i
) == 0);
2776 ASSERT (result
[i
] == '\0');
2777 ASSERT (retval
== strlen (result
));
2785 for (i
= 1; i
<= 8; i
++)
2791 block
= (wchar_t *) malloc (i
* sizeof (wchar_t));
2792 for (j
= 0; j
< i
; j
++)
2793 block
[j
] = "abcdefgh"[j
];
2794 retval
= my_snprintf (result
, sizeof (result
), "%.*ls", (int) i
, block
);
2795 ASSERT (memcmp (result
, "abcdefgh", i
) == 0);
2796 ASSERT (result
[i
] == '\0');
2797 ASSERT (retval
== strlen (result
));