use volatile pointers for intentional-crash code.
[musl] / src / time / __asctime.c
1 #include <time.h>
2 #include <stdio.h>
3 #include <langinfo.h>
4
5 const char *__langinfo(nl_item);
6
7 char *__asctime(const struct tm *tm, char *buf)
8 {
9         /* FIXME: change __langinfo to __C_langinfo once we have locales */
10         if (snprintf(buf, 26, "%.3s %.3s%3d %.2d:%.2d:%.2d %d\n",
11                 __langinfo(ABDAY_1+tm->tm_wday),
12                 __langinfo(ABMON_1+tm->tm_mon),
13                 tm->tm_mday, tm->tm_hour,
14                 tm->tm_min, tm->tm_sec,
15                 1900 + tm->tm_year) >= 26)
16         {
17                 /* ISO C requires us to use the above format string,
18                  * even if it will not fit in the buffer. Thus asctime_r
19                  * is _supposed_ to crash if the fields in tm are too large.
20                  * We follow this behavior and crash "gracefully" to warn
21                  * application developers that they may not be so lucky
22                  * on other implementations (e.g. stack smashing..).
23                  */
24                 *(volatile int*)0 = 0;
25         }
26         return buf;
27 }