annotate src/strftime.c @ 112425:9f7614f1a892

Merge from emacs-23
author Glenn Morris <rgm@gnu.org>
date Sat, 22 Jan 2011 11:36:45 -0800
parents d54bb4248183
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
64770
a0d1312ede66 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64084
diff changeset
1 /* Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
75227
e90d04cd455a Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents: 74130
diff changeset
2 2001, 2002, 2003, 2004, 2005, 2006, 2007
e90d04cd455a Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents: 74130
diff changeset
3 Free Software Foundation, Inc.
51234
4458f91cfb2b (my_strftime_localtime_r): Remove `defined but unused' warning.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45846
diff changeset
4
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
5 NOTE: The canonical source of this file is maintained with gnulib.
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
6 Bugs can be reported to bug-gnulib@gnu.org.
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
7
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
8 This file is part of the GNU Emacs.
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
9
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
10 This program is free software; you can redistribute it and/or
72951
751c24f0ec88 Replace "GNU Library General Public License" by "GNU General Public
Jay Belanger <jay.p.belanger@gmail.com>
parents: 68651
diff changeset
11 modify it under the terms of the GNU General Public License
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
12 as published by the Free Software Foundation; either version 2, or
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
13 (at your option) any later version.
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
14
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
15 This program is distributed in the hope that it will be useful,
19875
278944a16af3 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18782
diff changeset
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
72951
751c24f0ec88 Replace "GNU Library General Public License" by "GNU General Public
Jay Belanger <jay.p.belanger@gmail.com>
parents: 68651
diff changeset
18 General Public License for more details.
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
19
72951
751c24f0ec88 Replace "GNU Library General Public License" by "GNU General Public
Jay Belanger <jay.p.belanger@gmail.com>
parents: 68651
diff changeset
20 You should have received a copy of the GNU General Public
751c24f0ec88 Replace "GNU Library General Public License" by "GNU General Public
Jay Belanger <jay.p.belanger@gmail.com>
parents: 68651
diff changeset
21 License along with the GNU C Library; see the file COPYING. If not,
64084
a8fa7c632ee4 Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 52401
diff changeset
22 write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
a8fa7c632ee4 Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 52401
diff changeset
23 Boston, MA 02110-1301, USA. */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
24
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
25 #ifdef HAVE_CONFIG_H
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
26 # include <config.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
27 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
28
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
29 #ifdef _LIBC
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
30 # define HAVE_LIMITS_H 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
31 # define HAVE_MBLEN 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
32 # define HAVE_MBRLEN 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
33 # define HAVE_STRUCT_ERA_ENTRY 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
34 # define HAVE_TM_GMTOFF 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
35 # define HAVE_TM_ZONE 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
36 # define HAVE_TZNAME 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
37 # define HAVE_TZSET 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
38 # define MULTIBYTE_IS_FORMAT_SAFE 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
39 # define STDC_HEADERS 1
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
40 # include "../locale/localeinfo.h"
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
41 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
42
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
43 #include <ctype.h>
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
44 #include <sys/types.h> /* Some systems define `time_t' here. */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
45
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
46 #ifdef TIME_WITH_SYS_TIME
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
47 # include <sys/time.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
48 # include <time.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
49 #else
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
50 # ifdef HAVE_SYS_TIME_H
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
51 # include <sys/time.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
52 # else
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
53 # include <time.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
54 # endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
55 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
56 #if HAVE_TZNAME
31100
92f108b8b281 [USE_CRT_DLL]: Remove unnecessary extern, which
Andrew Innes <andrewi@gnu.org>
parents: 28057
diff changeset
57 #ifndef USE_CRT_DLL
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
58 extern char *tzname[];
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
59 #endif
31100
92f108b8b281 [USE_CRT_DLL]: Remove unnecessary extern, which
Andrew Innes <andrewi@gnu.org>
parents: 28057
diff changeset
60 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
61
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
62 /* Do multibyte processing if multibytes are supported, unless
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
63 multibyte sequences are safe in formats. Multibyte sequences are
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
64 safe if they cannot contain byte sequences that look like format
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
65 conversion specifications. The GNU C Library uses UTF8 multibyte
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
66 encoding, which is safe for formats, but strftime.c can be used
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
67 with other C libraries that use unsafe encodings. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
68 #define DO_MULTIBYTE (HAVE_MBLEN && ! MULTIBYTE_IS_FORMAT_SAFE)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
69
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
70 #if DO_MULTIBYTE
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
71 # if HAVE_MBRLEN
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
72 # include <wchar.h>
74130
a5444650f86b (HAVE_SYS__MBSTATE_T_H): Fix typo.
Nick Roberts <nickrob@snap.net.nz>
parents: 72951
diff changeset
73 # ifdef HAVE_SYS__MBSTATE_T_H /* previously tested __hpux */
a5444650f86b (HAVE_SYS__MBSTATE_T_H): Fix typo.
Nick Roberts <nickrob@snap.net.nz>
parents: 72951
diff changeset
74 # include <sys/_mbstate_t.h>
a5444650f86b (HAVE_SYS__MBSTATE_T_H): Fix typo.
Nick Roberts <nickrob@snap.net.nz>
parents: 72951
diff changeset
75 # endif
42384
e4835ecdffbc (mbsinit): Define as no-op if not available.
Richard M. Stallman <rms@gnu.org>
parents: 34302
diff changeset
76 # if !defined (mbsinit) && !defined (HAVE_MBSINIT)
e4835ecdffbc (mbsinit): Define as no-op if not available.
Richard M. Stallman <rms@gnu.org>
parents: 34302
diff changeset
77 # define mbsinit(ps) 1
e4835ecdffbc (mbsinit): Define as no-op if not available.
Richard M. Stallman <rms@gnu.org>
parents: 34302
diff changeset
78 # endif /* !defined (mbsinit) && !defined (HAVE_MBSINIT) */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
79 # else
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
80 /* Simulate mbrlen with mblen as best we can. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
81 # define mbstate_t int
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
82 # define mbrlen(s, n, ps) mblen (s, n)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
83 # define mbsinit(ps) (*(ps) == 0)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
84 # endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
85 static const mbstate_t mbstate_zero;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
86 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
87
34302
1139c325f625 Change some #if foo to #ifdef foo.
Dave Love <fx@gnu.org>
parents: 32687
diff changeset
88 #ifdef HAVE_LIMITS_H
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
89 # include <limits.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
90 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
91
34302
1139c325f625 Change some #if foo to #ifdef foo.
Dave Love <fx@gnu.org>
parents: 32687
diff changeset
92 #ifdef STDC_HEADERS
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
93 # include <stddef.h>
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
94 # include <stdlib.h>
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
95 # include <string.h>
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
96 #else
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
97 # ifndef HAVE_MEMCPY
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
98 # define memcpy(d, s, n) bcopy ((s), (d), (n))
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
99 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
100 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
101
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
102 #ifdef COMPILE_WIDE
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
103 # include <endian.h>
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
104 # define CHAR_T wchar_t
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
105 # define UCHAR_T unsigned int
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
106 # define L_(Str) L##Str
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
107 # define NLW(Sym) _NL_W##Sym
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
108
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
109 # define MEMCPY(d, s, n) __wmemcpy (d, s, n)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
110 # define STRLEN(s) __wcslen (s)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
111
20212
90f407354bdf automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20211
diff changeset
112 #else
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
113 # define CHAR_T char
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
114 # define UCHAR_T unsigned char
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
115 # define L_(Str) Str
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
116 # define NLW(Sym) Sym
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
117
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
118 # if !defined STDC_HEADERS && !defined HAVE_MEMCPY
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
119 # define MEMCPY(d, s, n) bcopy ((s), (d), (n))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
120 # else
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
121 # define MEMCPY(d, s, n) memcpy ((d), (s), (n))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
122 # endif
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
123 # define STRLEN(s) strlen (s)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
124
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
125 # ifdef _LIBC
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
126 # define MEMPCPY(d, s, n) __mempcpy (d, s, n)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
127 # else
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
128 # ifndef HAVE_MEMPCPY
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
129 # define MEMPCPY(d, s, n) ((void *) ((char *) memcpy (d, s, n) + (n)))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
130 # endif
20212
90f407354bdf automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20211
diff changeset
131 # endif
90f407354bdf automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20211
diff changeset
132 #endif
90f407354bdf automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20211
diff changeset
133
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
134 #ifndef PTR
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
135 # ifdef __STDC__
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
136 # define PTR void *
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
137 # else
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
138 # define PTR char *
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
139 # endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
140 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
141
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
142 #ifndef CHAR_BIT
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
143 # define CHAR_BIT 8
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
144 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
145
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
146 #ifndef NULL
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
147 # define NULL 0
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
148 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
149
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
150 #define TYPE_SIGNED(t) ((t) -1 < 0)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
151
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
152 /* Bound on length of the string representing an integer value of type t.
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
153 Subtract one for the sign bit if t is signed;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
154 302 / 1000 is log10 (2) rounded up;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
155 add one for integer division truncation;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
156 add one more for a minus sign if t is signed. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
157 #define INT_STRLEN_BOUND(t) \
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
158 ((sizeof (t) * CHAR_BIT - TYPE_SIGNED (t)) * 302 / 1000 + 1 + TYPE_SIGNED (t))
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
159
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
160 #define TM_YEAR_BASE 1900
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
161
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
162 #ifndef __isleap
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
163 /* Nonzero if YEAR is a leap year (every 4 years,
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
164 except every 100th isn't, and every 400th is). */
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
165 # define __isleap(year) \
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
166 ((year) % 4 == 0 && ((year) % 100 != 0 || (year) % 400 == 0))
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
167 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
168
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
169
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
170 #ifdef _LIBC
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
171 # define my_strftime_gmtime_r __gmtime_r
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
172 # define my_strftime_localtime_r __localtime_r
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
173 # define tzname __tzname
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
174 # define tzset __tzset
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
175 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
176
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
177 /* If we're a strftime substitute in a GNU program, then prefer gmtime
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
178 to gmtime_r, since many gmtime_r implementations are buggy.
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
179 Similarly for localtime_r. */
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
180
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
181 # if ! HAVE_TM_GMTOFF
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
182 static struct tm *
111628
9937e00afbbc Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111558
diff changeset
183 my_strftime_gmtime_r (const time_t *t, struct tm *tp)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
184 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
185 struct tm *l = gmtime (t);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
186 if (! l)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
187 return 0;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
188 *tp = *l;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
189 return tp;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
190 }
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
191
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
192 static struct tm *
111628
9937e00afbbc Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111558
diff changeset
193 my_strftime_localtime_r (const time_t *t, struct tm *tp)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
194 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
195 struct tm *l = localtime (t);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
196 if (! l)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
197 return 0;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
198 *tp = *l;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
199 return tp;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
200 }
51234
4458f91cfb2b (my_strftime_localtime_r): Remove `defined but unused' warning.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45846
diff changeset
201 # endif /* ! HAVE_TM_GMTOFF */
20253
a7d1d668f57f automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20252
diff changeset
202 #endif /* ! defined _LIBC */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
203
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
204
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
205 #if !defined memset && !defined HAVE_MEMSET && !defined _LIBC
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
206 /* Some systems lack the `memset' function and we don't want to
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
207 introduce additional dependencies. */
18487
47be751da08b automatically generated from GPLed version
Richard M. Stallman <rms@gnu.org>
parents: 17965
diff changeset
208 /* The SGI compiler reportedly barfs on the trailing null
47be751da08b automatically generated from GPLed version
Richard M. Stallman <rms@gnu.org>
parents: 17965
diff changeset
209 if we use a string constant as the initializer. 28 June 1997, rms. */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
210 static const CHAR_T spaces[16] = /* " " */
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
211 {
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
212 L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
213 L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),L_(' '),L_(' ')
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
214 };
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
215 static const CHAR_T zeroes[16] = /* "0000000000000000" */
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
216 {
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
217 L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
218 L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),L_('0'),L_('0')
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
219 };
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
220
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
221 # define memset_space(P, Len) \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
222 do { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
223 int _len = (Len); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
224 \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
225 do \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
226 { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
227 int _this = _len > 16 ? 16 : _len; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
228 (P) = MEMPCPY ((P), spaces, _this * sizeof (CHAR_T)); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
229 _len -= _this; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
230 } \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
231 while (_len > 0); \
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
232 } while (0)
17965
2ef01cc793bf automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 17502
diff changeset
233
2ef01cc793bf automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 17502
diff changeset
234 # define memset_zero(P, Len) \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
235 do { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
236 int _len = (Len); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
237 \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
238 do \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
239 { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
240 int _this = _len > 16 ? 16 : _len; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
241 (P) = MEMPCPY ((P), zeroes, _this * sizeof (CHAR_T)); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
242 _len -= _this; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
243 } \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
244 while (_len > 0); \
17965
2ef01cc793bf automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 17502
diff changeset
245 } while (0)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
246 #else
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
247 # ifdef COMPILE_WIDE
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
248 # define memset_space(P, Len) (wmemset ((P), L' ', (Len)), (P) += (Len))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
249 # define memset_zero(P, Len) (wmemset ((P), L'0', (Len)), (P) += (Len))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
250 # else
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
251 # define memset_space(P, Len) (memset ((P), ' ', (Len)), (P) += (Len))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
252 # define memset_zero(P, Len) (memset ((P), '0', (Len)), (P) += (Len))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
253 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
254 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
255
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
256 #define add(n, f) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
257 do \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
258 { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
259 int _n = (n); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
260 int _delta = width - _n; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
261 int _incr = _n + (_delta > 0 ? _delta : 0); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
262 if ((size_t) _incr >= maxsize - i) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
263 return 0; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
264 if (p) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
265 { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
266 if (_delta > 0) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
267 { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
268 if (pad == L_('0')) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
269 memset_zero (p, _delta); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
270 else \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
271 memset_space (p, _delta); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
272 } \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
273 f; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
274 p += _n; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
275 } \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
276 i += _incr; \
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
277 } while (0)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
278
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
279 #define cpy(n, s) \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
280 add ((n), \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
281 if (to_lowcase) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
282 memcpy_lowcase (p, (s), _n LOCALE_ARG); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
283 else if (to_uppcase) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
284 memcpy_uppcase (p, (s), _n LOCALE_ARG); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
285 else \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
286 MEMCPY ((PTR) p, (const PTR) (s), _n))
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
287
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
288 #ifdef COMPILE_WIDE
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
289 # ifndef USE_IN_EXTENDED_LOCALE_MODEL
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
290 # undef __mbsrtowcs_l
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
291 # define __mbsrtowcs_l(d, s, l, st, loc) __mbsrtowcs (d, s, l, st)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
292 # endif
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
293 # define widen(os, ws, l) \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
294 { \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
295 mbstate_t __st; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
296 const char *__s = os; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
297 memset (&__st, '\0', sizeof (__st)); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
298 l = __mbsrtowcs_l (NULL, &__s, 0, &__st, loc); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
299 ws = (wchar_t *) alloca ((l + 1) * sizeof (wchar_t)); \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
300 (void) __mbsrtowcs_l (ws, &__s, l, &__st, loc); \
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
301 }
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
302 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
303
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
304
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
305 #if defined _LIBC && defined USE_IN_EXTENDED_LOCALE_MODEL
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
306 /* We use this code also for the extended locale handling where the
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
307 function gets as an additional argument the locale which has to be
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
308 used. To access the values we have to redefine the _NL_CURRENT
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
309 macro. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
310 # define strftime __strftime_l
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
311 # define wcsftime __wcsftime_l
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
312 # undef _NL_CURRENT
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
313 # define _NL_CURRENT(category, item) \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
314 (current->values[_NL_ITEM_INDEX (item)].string)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
315 # define LOCALE_ARG , loc
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
316 # define LOCALE_PARAM_DECL , __locale_t loc
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
317 # define HELPER_LOCALE_ARG , current
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
318 #else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
319 # define LOCALE_ARG
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
320 # define LOCALE_PARAM_DECL
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
321 # ifdef _LIBC
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
322 # define HELPER_LOCALE_ARG , _NL_CURRENT_DATA (LC_TIME)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
323 # else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
324 # define HELPER_LOCALE_ARG
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
325 # endif
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
326 #endif
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
327
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
328 #ifdef COMPILE_WIDE
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
329 # ifdef USE_IN_EXTENDED_LOCALE_MODEL
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
330 # define TOUPPER(Ch, L) __towupper_l (Ch, L)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
331 # define TOLOWER(Ch, L) __towlower_l (Ch, L)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
332 # else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
333 # define TOUPPER(Ch, L) towupper (Ch)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
334 # define TOLOWER(Ch, L) towlower (Ch)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
335 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
336 #else
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
337 # ifdef _LIBC
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
338 # ifdef USE_IN_EXTENDED_LOCALE_MODEL
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
339 # define TOUPPER(Ch, L) __toupper_l (Ch, L)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
340 # define TOLOWER(Ch, L) __tolower_l (Ch, L)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
341 # else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
342 # define TOUPPER(Ch, L) toupper (Ch)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
343 # define TOLOWER(Ch, L) tolower (Ch)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
344 # endif
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
345 # else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
346 # define TOUPPER(Ch, L) (islower (Ch) ? toupper (Ch) : (Ch))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
347 # define TOLOWER(Ch, L) (isupper (Ch) ? tolower (Ch) : (Ch))
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
348 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
349 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
350 /* We don't use `isdigit' here since the locale dependent
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
351 interpretation is not what we want here. We only need to accept
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
352 the arabic digits in the ASCII range. One day there is perhaps a
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
353 more reliable way to accept other sets of digits. */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
354 #define ISDIGIT(Ch) ((unsigned int) (Ch) - L_('0') <= 9)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
355
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
356 static CHAR_T *
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
357 memcpy_lowcase (CHAR_T *dest, const CHAR_T *src, size_t len LOCALE_PARAM_DECL)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
358 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
359 while (len-- > 0)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
360 dest[len] = TOLOWER ((UCHAR_T) src[len], loc);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
361 return dest;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
362 }
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
363
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
364 static CHAR_T *
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
365 memcpy_uppcase (CHAR_T *dest, const CHAR_T *src, size_t len LOCALE_PARAM_DECL)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
366 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
367 while (len-- > 0)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
368 dest[len] = TOUPPER ((UCHAR_T) src[len], loc);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
369 return dest;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
370 }
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
371
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
372
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
373 #if ! HAVE_TM_GMTOFF
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
374 /* Yield the difference between *A and *B,
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
375 measured in seconds, ignoring leap seconds. */
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
376 # define tm_diff ftime_tm_diff
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
377 static int
111628
9937e00afbbc Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111558
diff changeset
378 tm_diff (const struct tm *a, const struct tm *b)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
379 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
380 /* Compute intervening leap days correctly even if year is negative.
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
381 Take care to avoid int overflow in leap day calculations,
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
382 but it's OK to assume that A and B are close to each other. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
383 int a4 = (a->tm_year >> 2) + (TM_YEAR_BASE >> 2) - ! (a->tm_year & 3);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
384 int b4 = (b->tm_year >> 2) + (TM_YEAR_BASE >> 2) - ! (b->tm_year & 3);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
385 int a100 = a4 / 25 - (a4 % 25 < 0);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
386 int b100 = b4 / 25 - (b4 % 25 < 0);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
387 int a400 = a100 >> 2;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
388 int b400 = b100 >> 2;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
389 int intervening_leap_days = (a4 - b4) - (a100 - b100) + (a400 - b400);
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
390 int years = a->tm_year - b->tm_year;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
391 int days = (365 * years + intervening_leap_days
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
392 + (a->tm_yday - b->tm_yday));
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
393 return (60 * (60 * (24 * days + (a->tm_hour - b->tm_hour))
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
394 + (a->tm_min - b->tm_min))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
395 + (a->tm_sec - b->tm_sec));
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
396 }
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
397 #endif /* ! HAVE_TM_GMTOFF */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
398
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
399
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
400
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
401 /* The number of days from the first day of the first ISO week of this
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
402 year to the year day YDAY with week day WDAY. ISO weeks start on
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
403 Monday; the first ISO week has the year's first Thursday. YDAY may
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
404 be as small as YDAY_MINIMUM. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
405 #define ISO_WEEK_START_WDAY 1 /* Monday */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
406 #define ISO_WEEK1_WDAY 4 /* Thursday */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
407 #define YDAY_MINIMUM (-366)
109100
2bc9a0c04c87 Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents: 75227
diff changeset
408 static int iso_week_days (int, int);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
409 #ifdef __GNUC__
20010
cb0800f5aa96 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 19875
diff changeset
410 __inline__
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
411 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
412 static int
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
413 iso_week_days (int yday, int wday)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
414 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
415 /* Add enough to the first operand of % to make it nonnegative. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
416 int big_enough_multiple_of_7 = (-YDAY_MINIMUM / 7 + 2) * 7;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
417 return (yday
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
418 - (yday - wday + ISO_WEEK1_WDAY + big_enough_multiple_of_7) % 7
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
419 + ISO_WEEK1_WDAY - ISO_WEEK_START_WDAY);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
420 }
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
421
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
422
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
423 #if !(defined _NL_CURRENT || HAVE_STRFTIME)
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
424 static CHAR_T const weekday_name[][10] =
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
425 {
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
426 L_("Sunday"), L_("Monday"), L_("Tuesday"), L_("Wednesday"),
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
427 L_("Thursday"), L_("Friday"), L_("Saturday")
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
428 };
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
429 static CHAR_T const month_name[][10] =
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
430 {
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
431 L_("January"), L_("February"), L_("March"), L_("April"), L_("May"),
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
432 L_("June"), L_("July"), L_("August"), L_("September"), L_("October"),
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
433 L_("November"), L_("December")
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
434 };
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
435 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
436
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
437
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
438 /* When compiling this file, GNU applications can #define my_strftime
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
439 to a symbol (typically nstrftime) to get an extended strftime with
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
440 extra arguments UT and NS. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
441
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
442 #ifdef my_strftime
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
443 # define extra_args , ut, ns
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
444 # define extra_args_spec , int ut, int ns
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
445 #else
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
446 # ifdef COMPILE_WIDE
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
447 # define my_strftime wcsftime
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
448 # define nl_get_alt_digit _nl_get_walt_digit
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
449 # else
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
450 # define my_strftime strftime
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
451 # define nl_get_alt_digit _nl_get_alt_digit
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
452 # endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
453 # define extra_args
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
454 # define extra_args_spec
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
455 /* We don't have this information in general. */
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
456 # define ut 0
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
457 # define ns 0
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
458 #endif
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
459
32687
52117f9867f2 [!WINDOWSNT]: Don't apply Solaris 2.5 work-around on
Andrew Innes <andrewi@gnu.org>
parents: 32629
diff changeset
460 #if !defined _LIBC && !defined(WINDOWSNT) && HAVE_TZNAME && HAVE_TZSET
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
461 /* Solaris 2.5 tzset sometimes modifies the storage returned by localtime.
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
462 Work around this bug by copying *tp before it might be munged. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
463 size_t
111631
d54bb4248183 * src/strftime.c (_strftime_copytm): Add declaration.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111628
diff changeset
464 _strftime_copytm (CHAR_T *s, size_t maxsize, const CHAR_T *format,
d54bb4248183 * src/strftime.c (_strftime_copytm): Add declaration.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111628
diff changeset
465 const struct tm *tp extra_args_spec LOCALE_PARAM_DECL);
d54bb4248183 * src/strftime.c (_strftime_copytm): Add declaration.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111628
diff changeset
466 size_t
111628
9937e00afbbc Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111558
diff changeset
467 my_strftime (CHAR_T *s, size_t maxsize, const CHAR_T *format,
9937e00afbbc Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 111558
diff changeset
468 const struct tm *tp extra_args_spec)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
469 {
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
470 struct tm tmcopy;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
471 tmcopy = *tp;
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
472 return _strftime_copytm (s, maxsize, format, &tmcopy extra_args);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
473 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
474 # undef my_strftime
32687
52117f9867f2 [!WINDOWSNT]: Don't apply Solaris 2.5 work-around on
Andrew Innes <andrewi@gnu.org>
parents: 32629
diff changeset
475 # define my_strftime _strftime_copytm
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
476 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
477
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
478
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
479 /* Write information from TP into S according to the format
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
480 string FORMAT, writing no more that MAXSIZE characters
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
481 (including the terminating '\0') and returning number of
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
482 characters written. If S is NULL, nothing will be written
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
483 anywhere, so to determine how many characters would be
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
484 written, use NULL for S and (size_t) UINT_MAX for MAXSIZE. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
485 size_t
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
486 my_strftime (CHAR_T *s, size_t maxsize, const CHAR_T *format,
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
487 const struct tm *tp extra_args_spec LOCALE_PARAM_DECL)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
488 {
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
489 #if defined _LIBC && defined USE_IN_EXTENDED_LOCALE_MODEL
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
490 struct locale_data *const current = loc->__locales[LC_TIME];
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
491 #endif
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
492
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
493 int hour12 = tp->tm_hour;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
494 #ifdef _NL_CURRENT
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
495 /* We cannot make the following values variables since we must delay
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
496 the evaluation of these values until really needed since some
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
497 expressions might not be valid in every situation. The `struct tm'
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
498 might be generated by a strptime() call that initialized
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
499 only a few elements. Dereference the pointers only if the format
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
500 requires this. Then it is ok to fail if the pointers are invalid. */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
501 # define a_wkday \
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
502 ((const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(ABDAY_1) + tp->tm_wday))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
503 # define f_wkday \
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
504 ((const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(DAY_1) + tp->tm_wday))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
505 # define a_month \
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
506 ((const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(ABMON_1) + tp->tm_mon))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
507 # define f_month \
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
508 ((const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(MON_1) + tp->tm_mon))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
509 # define ampm \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
510 ((const CHAR_T *) _NL_CURRENT (LC_TIME, tp->tm_hour > 11 \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
511 ? NLW(PM_STR) : NLW(AM_STR)))
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
512
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
513 # define aw_len STRLEN (a_wkday)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
514 # define am_len STRLEN (a_month)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
515 # define ap_len STRLEN (ampm)
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
516 #else
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
517 # if !HAVE_STRFTIME
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
518 # define f_wkday (weekday_name[tp->tm_wday])
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
519 # define f_month (month_name[tp->tm_mon])
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
520 # define a_wkday f_wkday
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
521 # define a_month f_month
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
522 # define ampm (L_("AMPM") + 2 * (tp->tm_hour > 11))
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
523
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
524 size_t aw_len = 3;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
525 size_t am_len = 3;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
526 size_t ap_len = 2;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
527 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
528 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
529 const char *zone;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
530 size_t i = 0;
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
531 CHAR_T *p = s;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
532 const CHAR_T *f;
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
533 #if DO_MULTIBYTE && !defined COMPILE_WIDE
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
534 const char *format_end = NULL;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
535 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
536
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
537 zone = NULL;
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
538 #if HAVE_TM_ZONE
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
539 /* The POSIX test suite assumes that setting
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
540 the environment variable TZ to a new value before calling strftime()
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
541 will influence the result (the %Z format) even if the information in
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
542 TP is computed with a totally different time zone.
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
543 This is bogus: though POSIX allows bad behavior like this,
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
544 POSIX does not require it. Do the right thing instead. */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
545 zone = (const char *) tp->tm_zone;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
546 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
547 #if HAVE_TZNAME
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
548 if (ut)
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
549 {
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
550 if (! (zone && *zone))
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
551 zone = "GMT";
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
552 }
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
553 else
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
554 {
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
555 /* POSIX.1 requires that local time zone information be used as
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
556 though strftime called tzset. */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
557 # if HAVE_TZSET
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
558 tzset ();
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
559 # endif
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
560 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
561 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
562
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
563 if (hour12 > 12)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
564 hour12 -= 12;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
565 else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
566 if (hour12 == 0)
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
567 hour12 = 12;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
568
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
569 for (f = format; *f != '\0'; ++f)
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
570 {
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
571 int pad = 0; /* Padding for number ('-', '_', or 0). */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
572 int modifier; /* Field modifier ('E', 'O', or 0). */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
573 int digits; /* Max digits for numeric format. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
574 int number_value; /* Numeric value to be printed. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
575 int negative_number; /* 1 if the number is negative. */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
576 const CHAR_T *subfmt;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
577 CHAR_T *bufp;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
578 CHAR_T buf[1 + (sizeof (int) < sizeof (time_t)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
579 ? INT_STRLEN_BOUND (time_t)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
580 : INT_STRLEN_BOUND (int))];
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
581 int width = -1;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
582 int to_lowcase = 0;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
583 int to_uppcase = 0;
18781
70883b60c7a5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents: 18488
diff changeset
584 int change_case = 0;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
585 int format_char;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
586
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
587 #if DO_MULTIBYTE && !defined COMPILE_WIDE
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
588 switch (*f)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
589 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
590 case L_('%'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
591 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
592
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
593 case L_('\b'): case L_('\t'): case L_('\n'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
594 case L_('\v'): case L_('\f'): case L_('\r'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
595 case L_(' '): case L_('!'): case L_('"'): case L_('#'): case L_('&'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
596 case L_('\''): case L_('('): case L_(')'): case L_('*'): case L_('+'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
597 case L_(','): case L_('-'): case L_('.'): case L_('/'): case L_('0'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
598 case L_('1'): case L_('2'): case L_('3'): case L_('4'): case L_('5'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
599 case L_('6'): case L_('7'): case L_('8'): case L_('9'): case L_(':'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
600 case L_(';'): case L_('<'): case L_('='): case L_('>'): case L_('?'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
601 case L_('A'): case L_('B'): case L_('C'): case L_('D'): case L_('E'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
602 case L_('F'): case L_('G'): case L_('H'): case L_('I'): case L_('J'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
603 case L_('K'): case L_('L'): case L_('M'): case L_('N'): case L_('O'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
604 case L_('P'): case L_('Q'): case L_('R'): case L_('S'): case L_('T'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
605 case L_('U'): case L_('V'): case L_('W'): case L_('X'): case L_('Y'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
606 case L_('Z'): case L_('['): case L_('\\'): case L_(']'): case L_('^'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
607 case L_('_'): case L_('a'): case L_('b'): case L_('c'): case L_('d'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
608 case L_('e'): case L_('f'): case L_('g'): case L_('h'): case L_('i'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
609 case L_('j'): case L_('k'): case L_('l'): case L_('m'): case L_('n'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
610 case L_('o'): case L_('p'): case L_('q'): case L_('r'): case L_('s'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
611 case L_('t'): case L_('u'): case L_('v'): case L_('w'): case L_('x'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
612 case L_('y'): case L_('z'): case L_('{'): case L_('|'): case L_('}'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
613 case L_('~'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
614 /* The C Standard requires these 98 characters (plus '%') to
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
615 be in the basic execution character set. None of these
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
616 characters can start a multibyte sequence, so they need
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
617 not be analyzed further. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
618 add (1, *p = *f);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
619 continue;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
620
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
621 default:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
622 /* Copy this multibyte sequence until we reach its end, find
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
623 an error, or come back to the initial shift state. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
624 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
625 mbstate_t mbstate = mbstate_zero;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
626 size_t len = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
627 size_t fsize;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
628
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
629 if (! format_end)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
630 format_end = f + strlen (f) + 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
631 fsize = format_end - f;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
632
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
633 do
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
634 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
635 size_t bytes = mbrlen (f + len, fsize - len, &mbstate);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
636
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
637 if (bytes == 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
638 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
639
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
640 if (bytes == (size_t) -2)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
641 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
642 len += strlen (f + len);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
643 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
644 }
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
645
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
646 if (bytes == (size_t) -1)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
647 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
648 len++;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
649 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
650 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
651
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
652 len += bytes;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
653 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
654 while (! mbsinit (&mbstate));
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
655
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
656 cpy (len, f);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
657 f += len - 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
658 continue;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
659 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
660 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
661
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
662 #else /* ! DO_MULTIBYTE */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
663
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
664 /* Either multibyte encodings are not supported, they are
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
665 safe for formats, so any non-'%' byte can be copied through,
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
666 or this is the wide character version. */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
667 if (*f != L_('%'))
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
668 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
669 add (1, *p = *f);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
670 continue;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
671 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
672
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
673 #endif /* ! DO_MULTIBYTE */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
674
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
675 /* Check for flags that can modify a format. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
676 while (1)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
677 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
678 switch (*++f)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
679 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
680 /* This influences the number formats. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
681 case L_('_'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
682 case L_('-'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
683 case L_('0'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
684 pad = *f;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
685 continue;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
686
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
687 /* This changes textual output. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
688 case L_('^'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
689 to_uppcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
690 continue;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
691 case L_('#'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
692 change_case = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
693 continue;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
694
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
695 default:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
696 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
697 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
698 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
699 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
700
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
701 /* As a GNU extension we allow to specify the field width. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
702 if (ISDIGIT (*f))
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
703 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
704 width = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
705 do
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
706 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
707 if (width > INT_MAX / 10
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
708 || (width == INT_MAX / 10 && *f - L_('0') > INT_MAX % 10))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
709 /* Avoid overflow. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
710 width = INT_MAX;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
711 else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
712 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
713 width *= 10;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
714 width += *f - L_('0');
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
715 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
716 ++f;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
717 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
718 while (ISDIGIT (*f));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
719 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
720
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
721 /* Check for modifiers. */
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
722 switch (*f)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
723 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
724 case L_('E'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
725 case L_('O'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
726 modifier = *f++;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
727 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
728
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
729 default:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
730 modifier = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
731 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
732 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
733
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
734 /* Now do the specified format. */
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
735 format_char = *f;
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
736 switch (format_char)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
737 {
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
738 #define DO_NUMBER(d, v) \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
739 digits = d > width ? d : width; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
740 number_value = v; goto do_number
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
741 #define DO_NUMBER_SPACEPAD(d, v) \
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
742 digits = d > width ? d : width; \
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
743 number_value = v; goto do_number_spacepad
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
744
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
745 case L_('%'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
746 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
747 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
748 add (1, *p = *f);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
749 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
750
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
751 case L_('a'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
752 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
753 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
754 if (change_case)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
755 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
756 to_uppcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
757 to_lowcase = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
758 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
759 #if defined _NL_CURRENT || !HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
760 cpy (aw_len, a_wkday);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
761 break;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
762 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
763 goto underlying_strftime;
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
764 #endif
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
765
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
766 case 'A':
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
767 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
768 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
769 if (change_case)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
770 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
771 to_uppcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
772 to_lowcase = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
773 }
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
774 #if defined _NL_CURRENT || !HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
775 cpy (STRLEN (f_wkday), f_wkday);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
776 break;
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
777 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
778 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
779 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
780
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
781 case L_('b'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
782 case L_('h'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
783 if (change_case)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
784 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
785 to_uppcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
786 to_lowcase = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
787 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
788 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
789 goto bad_format;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
790 #if defined _NL_CURRENT || !HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
791 cpy (am_len, a_month);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
792 break;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
793 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
794 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
795 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
796
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
797 case L_('B'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
798 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
799 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
800 if (change_case)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
801 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
802 to_uppcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
803 to_lowcase = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
804 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
805 #if defined _NL_CURRENT || !HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
806 cpy (STRLEN (f_month), f_month);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
807 break;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
808 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
809 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
810 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
811
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
812 case L_('c'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
813 if (modifier == L_('O'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
814 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
815 #ifdef _NL_CURRENT
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
816 if (! (modifier == 'E'
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
817 && (*(subfmt =
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
818 (const CHAR_T *) _NL_CURRENT (LC_TIME,
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
819 NLW(ERA_D_T_FMT)))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
820 != '\0')))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
821 subfmt = (const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(D_T_FMT));
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
822 #else
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
823 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
824 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
825 # else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
826 subfmt = L_("%a %b %e %H:%M:%S %Y");
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
827 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
828 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
829
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
830 subformat:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
831 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
832 CHAR_T *old_start = p;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
833 size_t len = my_strftime (NULL, (size_t) -1, subfmt,
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
834 tp extra_args LOCALE_ARG);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
835 add (len, my_strftime (p, maxsize - i, subfmt,
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
836 tp extra_args LOCALE_ARG));
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
837
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
838 if (to_uppcase)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
839 while (old_start < p)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
840 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
841 *old_start = TOUPPER ((UCHAR_T) *old_start, loc);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
842 ++old_start;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
843 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
844 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
845 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
846
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
847 #if HAVE_STRFTIME && ! (defined _NL_CURRENT && HAVE_STRUCT_ERA_ENTRY)
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
848 underlying_strftime:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
849 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
850 /* The relevant information is available only via the
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
851 underlying strftime implementation, so use that. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
852 char ufmt[4];
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
853 char *u = ufmt;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
854 char ubuf[1024]; /* enough for any single format in practice */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
855 size_t len;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
856 /* Make sure we're calling the actual underlying strftime.
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
857 In some cases, config.h contains something like
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
858 "#define strftime rpl_strftime". */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
859 # ifdef strftime
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
860 # undef strftime
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
861 size_t strftime ();
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
862 # endif
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
863
43890
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
864 #ifdef STRFTIME_NO_POSIX2
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
865 /* Some system libraries do not support the POSIX.2 extensions.
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
866 In those cases, convert %h to %b, and strip modifiers. */
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
867 modifier = 0;
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
868 if (format_char == 'h')
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
869 format_char = 'b';
38d2cf408e27 (my_strftime) [STRFTIME_NO_POSIX2]: Handle %h, %EX
Jason Rumney <jasonr@gnu.org>
parents: 42384
diff changeset
870 #endif
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
871 *u++ = '%';
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
872 if (modifier != 0)
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
873 *u++ = modifier;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
874 *u++ = format_char;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
875 *u = '\0';
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
876 len = strftime (ubuf, sizeof ubuf, ufmt, tp);
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
877 if (len == 0 && ubuf[0] != '\0')
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
878 return 0;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
879 cpy (len, ubuf);
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
880 }
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
881 break;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
882 #endif
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
883
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
884 case L_('C'):
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
885 if (modifier == L_('O'))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
886 goto bad_format;
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
887 if (modifier == L_('E'))
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
888 {
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
889 #if HAVE_STRUCT_ERA_ENTRY
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
890 struct era_entry *era = _nl_get_era_entry (tp HELPER_LOCALE_ARG);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
891 if (era)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
892 {
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
893 # ifdef COMPILE_WIDE
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
894 size_t len = __wcslen (era->era_wname);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
895 cpy (len, era->era_wname);
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
896 # else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
897 size_t len = strlen (era->era_name);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
898 cpy (len, era->era_name);
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
899 # endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
900 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
901 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
902 #else
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
903 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
904 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
905 # endif
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
906 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
907 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
908
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
909 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
910 int year = tp->tm_year + TM_YEAR_BASE;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
911 DO_NUMBER (1, year / 100 - (year % 100 < 0));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
912 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
913
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
914 case L_('x'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
915 if (modifier == L_('O'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
916 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
917 #ifdef _NL_CURRENT
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
918 if (! (modifier == L_('E')
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
919 && (*(subfmt =
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
920 (const CHAR_T *)_NL_CURRENT (LC_TIME, NLW(ERA_D_FMT)))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
921 != L_('\0'))))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
922 subfmt = (const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(D_FMT));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
923 goto subformat;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
924 #else
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
925 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
926 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
927 # else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
928 /* Fall through. */
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
929 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
930 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
931 case L_('D'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
932 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
933 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
934 subfmt = L_("%m/%d/%y");
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
935 goto subformat;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
936
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
937 case L_('d'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
938 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
939 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
940
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
941 DO_NUMBER (2, tp->tm_mday);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
942
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
943 case L_('e'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
944 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
945 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
946
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
947 DO_NUMBER_SPACEPAD (2, tp->tm_mday);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
948
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
949 /* All numeric formats set DIGITS and NUMBER_VALUE and then
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
950 jump to one of these two labels. */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
951
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
952 do_number_spacepad:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
953 /* Force `_' flag unless overridden by `0' or `-' flag. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
954 if (pad != L_('0') && pad != L_('-'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
955 pad = L_('_');
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
956
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
957 do_number:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
958 /* Format the number according to the MODIFIER flag. */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
959
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
960 if (modifier == L_('O') && 0 <= number_value)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
961 {
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
962 #ifdef _NL_CURRENT
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
963 /* Get the locale specific alternate representation of
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
964 the number NUMBER_VALUE. If none exist NULL is returned. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
965 const CHAR_T *cp = nl_get_alt_digit (number_value
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
966 HELPER_LOCALE_ARG);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
967
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
968 if (cp != NULL)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
969 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
970 size_t digitlen = STRLEN (cp);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
971 if (digitlen != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
972 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
973 cpy (digitlen, cp);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
974 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
975 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
976 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
977 #else
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
978 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
979 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
980 # endif
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
981 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
982 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
983 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
984 unsigned int u = number_value;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
985
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
986 bufp = buf + sizeof (buf) / sizeof (buf[0]);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
987 negative_number = number_value < 0;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
988
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
989 if (negative_number)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
990 u = -u;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
991
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
992 do
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
993 *--bufp = u % 10 + L_('0');
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
994 while ((u /= 10) != 0);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
995 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
996
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
997 do_number_sign_and_padding:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
998 if (negative_number)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
999 *--bufp = L_('-');
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1000
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1001 if (pad != L_('-'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1002 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1003 int padding = digits - (buf + (sizeof (buf) / sizeof (buf[0]))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1004 - bufp);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1005
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1006 if (padding > 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1007 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1008 if (pad == L_('_'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1009 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1010 if ((size_t) padding >= maxsize - i)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1011 return 0;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1012
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1013 if (p)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1014 memset_space (p, padding);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1015 i += padding;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1016 width = width > padding ? width - padding : 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1017 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1018 else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1019 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1020 if ((size_t) digits >= maxsize - i)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1021 return 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1022
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1023 if (negative_number)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1024 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1025 ++bufp;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1026
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1027 if (p)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1028 *p++ = L_('-');
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1029 ++i;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1030 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1031
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1032 if (p)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1033 memset_zero (p, padding);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1034 i += padding;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1035 width = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1036 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1037 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1038 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1039
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1040 cpy (buf + sizeof (buf) / sizeof (buf[0]) - bufp, bufp);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1041 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1042
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1043 case L_('F'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1044 if (modifier != 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1045 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1046 subfmt = L_("%Y-%m-%d");
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1047 goto subformat;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1048
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1049 case L_('H'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1050 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1051 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1052
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1053 DO_NUMBER (2, tp->tm_hour);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1054
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1055 case L_('I'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1056 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1057 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1058
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1059 DO_NUMBER (2, hour12);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1060
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1061 case L_('k'): /* GNU extension. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1062 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1063 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1064
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1065 DO_NUMBER_SPACEPAD (2, tp->tm_hour);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1066
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1067 case L_('l'): /* GNU extension. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1068 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1069 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1070
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1071 DO_NUMBER_SPACEPAD (2, hour12);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1072
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1073 case L_('j'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1074 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1075 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1076
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1077 DO_NUMBER (3, 1 + tp->tm_yday);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1078
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1079 case L_('M'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1080 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1081 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1082
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1083 DO_NUMBER (2, tp->tm_min);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1084
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1085 case L_('m'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1086 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1087 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1088
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1089 DO_NUMBER (2, tp->tm_mon + 1);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1090
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1091 #ifndef _LIBC
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1092 case L_('N'): /* GNU extension. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1093 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1094 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1095
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1096 number_value = ns;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1097 if (width != -1)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1098 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1099 /* Take an explicit width less than 9 as a precision. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1100 int j;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1101 for (j = width; j < 9; j++)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1102 number_value /= 10;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1103 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1104
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1105 DO_NUMBER (9, number_value);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1106 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1107
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1108 case L_('n'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1109 add (1, *p = L_('\n'));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1110 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1111
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1112 case L_('P'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1113 to_lowcase = 1;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1114 #if !defined _NL_CURRENT && HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1115 format_char = L_('p');
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1116 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1117 /* FALLTHROUGH */
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1118
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1119 case L_('p'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1120 if (change_case)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1121 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1122 to_uppcase = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1123 to_lowcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1124 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1125 #if defined _NL_CURRENT || !HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1126 cpy (ap_len, ampm);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1127 break;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1128 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1129 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1130 #endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1131
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1132 case L_('R'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1133 subfmt = L_("%H:%M");
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1134 goto subformat;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1135
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1136 case L_('r'):
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1137 #ifdef _NL_CURRENT
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1138 if (*(subfmt = (const CHAR_T *) _NL_CURRENT (LC_TIME,
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1139 NLW(T_FMT_AMPM)))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1140 == L_('\0'))
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1141 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1142 subfmt = L_("%I:%M:%S %p");
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1143 goto subformat;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1144
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1145 case L_('S'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1146 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1147 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1148
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1149 DO_NUMBER (2, tp->tm_sec);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1150
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1151 case L_('s'): /* GNU extension. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1152 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1153 struct tm ltm;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1154 time_t t;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1155
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1156 ltm = *tp;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1157 t = mktime (&ltm);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1158
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1159 /* Generate string value for T using time_t arithmetic;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1160 this works even if sizeof (long) < sizeof (time_t). */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1161
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1162 bufp = buf + sizeof (buf) / sizeof (buf[0]);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1163 negative_number = t < 0;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1164
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1165 do
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1166 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1167 int d = t % 10;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1168 t /= 10;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1169
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1170 if (negative_number)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1171 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1172 d = -d;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1173
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1174 /* Adjust if division truncates to minus infinity. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1175 if (0 < -1 % 10 && d < 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1176 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1177 t++;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1178 d += 10;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1179 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1180 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1181
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1182 *--bufp = d + L_('0');
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1183 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1184 while (t != 0);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1185
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1186 digits = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1187 goto do_number_sign_and_padding;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1188 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1189
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1190 case L_('X'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1191 if (modifier == L_('O'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1192 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1193 #ifdef _NL_CURRENT
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1194 if (! (modifier == L_('E')
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1195 && (*(subfmt =
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1196 (const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(ERA_T_FMT)))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1197 != L_('\0'))))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1198 subfmt = (const CHAR_T *) _NL_CURRENT (LC_TIME, NLW(T_FMT));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1199 goto subformat;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1200 #else
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1201 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1202 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1203 # else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1204 /* Fall through. */
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1205 # endif
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1206 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1207 case L_('T'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1208 subfmt = L_("%H:%M:%S");
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1209 goto subformat;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1210
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1211 case L_('t'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1212 add (1, *p = L_('\t'));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1213 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1214
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1215 case L_('u'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1216 DO_NUMBER (1, (tp->tm_wday - 1 + 7) % 7 + 1);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1217
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1218 case L_('U'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1219 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1220 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1221
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1222 DO_NUMBER (2, (tp->tm_yday - tp->tm_wday + 7) / 7);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1223
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1224 case L_('V'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1225 case L_('g'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1226 case L_('G'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1227 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1228 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1229 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1230 int year = tp->tm_year + TM_YEAR_BASE;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1231 int days = iso_week_days (tp->tm_yday, tp->tm_wday);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1232
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1233 if (days < 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1234 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1235 /* This ISO week belongs to the previous year. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1236 year--;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1237 days = iso_week_days (tp->tm_yday + (365 + __isleap (year)),
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1238 tp->tm_wday);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1239 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1240 else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1241 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1242 int d = iso_week_days (tp->tm_yday - (365 + __isleap (year)),
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1243 tp->tm_wday);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1244 if (0 <= d)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1245 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1246 /* This ISO week belongs to the next year. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1247 year++;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1248 days = d;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1249 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1250 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1251
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1252 switch (*f)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1253 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1254 case L_('g'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1255 DO_NUMBER (2, (year % 100 + 100) % 100);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1256
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1257 case L_('G'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1258 DO_NUMBER (1, year);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1259
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1260 default:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1261 DO_NUMBER (2, days / 7 + 1);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1262 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1263 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1264
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1265 case L_('W'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1266 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1267 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1268
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1269 DO_NUMBER (2, (tp->tm_yday - (tp->tm_wday - 1 + 7) % 7 + 7) / 7);
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1270
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1271 case L_('w'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1272 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1273 goto bad_format;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1274
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1275 DO_NUMBER (1, tp->tm_wday);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1276
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1277 case L_('Y'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1278 if (modifier == 'E')
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1279 {
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1280 #if HAVE_STRUCT_ERA_ENTRY
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1281 struct era_entry *era = _nl_get_era_entry (tp HELPER_LOCALE_ARG);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1282 if (era)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1283 {
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1284 # ifdef COMPILE_WIDE
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1285 subfmt = era->era_wformat;
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1286 # else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1287 subfmt = era->era_format;
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1288 # endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1289 goto subformat;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1290 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1291 #else
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1292 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1293 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1294 # endif
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1295 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1296 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1297 if (modifier == L_('O'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1298 goto bad_format;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1299 else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1300 DO_NUMBER (1, tp->tm_year + TM_YEAR_BASE);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1301
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1302 case L_('y'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1303 if (modifier == L_('E'))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1304 {
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1305 #if HAVE_STRUCT_ERA_ENTRY
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1306 struct era_entry *era = _nl_get_era_entry (tp HELPER_LOCALE_ARG);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1307 if (era)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1308 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1309 int delta = tp->tm_year - era->start_date[0];
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1310 DO_NUMBER (1, (era->offset
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1311 + delta * era->absolute_direction));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1312 }
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1313 #else
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1314 # if HAVE_STRFTIME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1315 goto underlying_strftime;
20211
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1316 # endif
f722b33c682d automatically generated from GPLed version
Ulrich Drepper <drepper@redhat.com>
parents: 20010
diff changeset
1317 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1318 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1319 DO_NUMBER (2, (tp->tm_year % 100 + 100) % 100);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1320
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1321 case L_('Z'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1322 if (change_case)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1323 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1324 to_uppcase = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1325 to_lowcase = 1;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1326 }
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1327
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1328 #if HAVE_TZNAME
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1329 /* The tzset() call might have changed the value. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1330 if (!(zone && *zone) && tp->tm_isdst >= 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1331 zone = tzname[tp->tm_isdst];
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1332 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1333 if (! zone)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1334 zone = "";
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1335
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1336 #ifdef COMPILE_WIDE
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1337 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1338 /* The zone string is always given in multibyte form. We have
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1339 to transform it first. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1340 wchar_t *wczone;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1341 size_t len;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1342 widen (zone, wczone, len);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1343 cpy (len, wczone);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1344 }
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1345 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1346 cpy (strlen (zone), zone);
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1347 #endif
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1348 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1349
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1350 case L_('z'):
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1351 if (tp->tm_isdst < 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1352 break;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1353
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1354 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1355 int diff;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1356 #if HAVE_TM_GMTOFF
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1357 diff = tp->tm_gmtoff;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1358 #else
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1359 if (ut)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1360 diff = 0;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1361 else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1362 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1363 struct tm gtm;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1364 struct tm ltm;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1365 time_t lt;
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1366
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1367 ltm = *tp;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1368 lt = mktime (&ltm);
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1369
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1370 if (lt == (time_t) -1)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1371 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1372 /* mktime returns -1 for errors, but -1 is also a
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1373 valid time_t value. Check whether an error really
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1374 occurred. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1375 struct tm tm;
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1376
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1377 if (! my_strftime_localtime_r (&lt, &tm)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1378 || ((ltm.tm_sec ^ tm.tm_sec)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1379 | (ltm.tm_min ^ tm.tm_min)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1380 | (ltm.tm_hour ^ tm.tm_hour)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1381 | (ltm.tm_mday ^ tm.tm_mday)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1382 | (ltm.tm_mon ^ tm.tm_mon)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1383 | (ltm.tm_year ^ tm.tm_year)))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1384 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1385 }
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1386
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1387 if (! my_strftime_gmtime_r (&lt, &gtm))
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1388 break;
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1389
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1390 diff = tm_diff (&ltm, &gtm);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1391 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1392 #endif
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1393
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1394 if (diff < 0)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1395 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1396 add (1, *p = L_('-'));
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1397 diff = -diff;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1398 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1399 else
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1400 add (1, *p = L_('+'));
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1401
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1402 diff /= 60;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1403 DO_NUMBER (4, (diff / 60) * 100 + diff % 60);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1404 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1405
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1406 case L_('\0'): /* GNU extension: % at end of format. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1407 --f;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1408 /* Fall through. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1409 default:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1410 /* Unknown format; output the format, including the '%',
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1411 since this is most likely the right thing to do if a
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1412 multibyte string has been misparsed. */
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1413 bad_format:
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1414 {
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1415 int flen;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1416 for (flen = 1; f[1 - flen] != L_('%'); flen++)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1417 continue;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1418 cpy (flen, &f[1 - flen]);
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1419 }
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1420 break;
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1421 }
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1422 }
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1423
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 23323
diff changeset
1424 if (p && maxsize != 0)
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1425 *p = L_('\0');
17502
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1426 return i;
8f3dcea869f5 automatically generated from GPLed version
Paul Eggert <eggert@twinsun.com>
parents:
diff changeset
1427 }
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1428 #ifdef _LIBC
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1429 libc_hidden_def (my_strftime)
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1430 #endif
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1431
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1432
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1433 #ifdef emacs
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1434 #undef ut
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1435 /* For Emacs we have a separate interface which corresponds to the normal
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1436 strftime function plus the ut argument, but without the ns argument. */
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1437 size_t
111558
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
1438 emacs_strftimeu (char *s, size_t maxsize, const char *format,
a673d202fe46 Convert definitions to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 109136
diff changeset
1439 const struct tm *tp, int ut)
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1440 {
51648
73b3b97a1595 Test HAVE_SYS__MBSTATE_H, not __hpux. Merge changes
Dave Love <fx@gnu.org>
parents: 51234
diff changeset
1441 return my_strftime (s, maxsize, format, tp, ut, 0);
32629
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1442 }
2683108cd13f Sync with glibc, file version 1.78.
Gerd Moellmann <gerd@gnu.org>
parents: 31100
diff changeset
1443 #endif
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51648
diff changeset
1444