annotate lib/getdate.y @ 5548:b8dd75cdd3a8

(YYSTACK_USE_ALLOCA): Define to 0, since there's no need to extend the stack.
author Paul Eggert <eggert@cs.ucla.edu>
date Fri, 24 Dec 2004 05:29:20 +0000
parents b45cd12ab00f
children 42df9db003cc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1 %{
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
2 /* Parse a string into an internal time stamp.
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
3 Copyright (C) 1999, 2000, 2002, 2003, 2004 Free Software Foundation, Inc.
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
4
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
5 This program is free software; you can redistribute it and/or modify
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
6 it under the terms of the GNU General Public License as published by
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
7 the Free Software Foundation; either version 2, or (at your option)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
8 any later version.
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
9
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
10 This program is distributed in the hope that it will be useful,
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
13 GNU General Public License for more details.
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
14
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
15 You should have received a copy of the GNU General Public License
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
16 along with this program; if not, write to the Free Software Foundation,
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
17 Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
18
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
19 /* Originally written by Steven M. Bellovin <smb@research.att.com> while
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
20 at the University of North Carolina at Chapel Hill. Later tweaked by
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
21 a couple of people on Usenet. Completely overhauled by Rich $alz
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
22 <rsalz@bbn.com> and Jim Berets <jberets@bbn.com> in August, 1990.
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
23
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
24 Modified by Paul Eggert <eggert@twinsun.com> in August 1999 to do
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
25 the right thing about local DST. Also modified by Paul Eggert
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
26 <eggert@cs.ucla.edu> in February 2004 to support
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
27 nanosecond-resolution time stamps, and in October 2004 to support
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
28 TZ strings in dates. */
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
29
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
30 /* FIXME: Check for arithmetic overflow in all cases, not just
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
31 some of them. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
32
48
e5f368fdc8c2 update from fsf
Jim Meyering <jim@meyering.net>
parents: 16
diff changeset
33 #ifdef HAVE_CONFIG_H
855
9c89b90524b8 (get_date): Change prototype to reflect const'ness of parameters.
Jim Meyering <jim@meyering.net>
parents: 852
diff changeset
34 # include <config.h>
101
40a78c8d27fd merge with 1.8.1a
Jim Meyering <jim@meyering.net>
parents: 100
diff changeset
35 #endif
48
e5f368fdc8c2 update from fsf
Jim Meyering <jim@meyering.net>
parents: 16
diff changeset
36
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
37 #include "getdate.h"
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
38
5548
b8dd75cdd3a8 (YYSTACK_USE_ALLOCA): Define to 0, since there's no need to extend the
Paul Eggert <eggert@cs.ucla.edu>
parents: 5546
diff changeset
39 /* There's no need to extend the stack, so there's no need to involve
b8dd75cdd3a8 (YYSTACK_USE_ALLOCA): Define to 0, since there's no need to extend the
Paul Eggert <eggert@cs.ucla.edu>
parents: 5546
diff changeset
40 alloca. */
b8dd75cdd3a8 (YYSTACK_USE_ALLOCA): Define to 0, since there's no need to extend the
Paul Eggert <eggert@cs.ucla.edu>
parents: 5546
diff changeset
41 #define YYSTACK_USE_ALLOCA 0
5538
87bc9c0d52d4 * alloca_.h: Conditionalize on _GNULIB_ALLOCA_H, not _ALLOCA_H.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5520
diff changeset
42
5543
96b72280d322 Fix typo in comment in previous change.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5538
diff changeset
43 /* Tell Bison how much stack space is needed. 20 should be plenty for
5538
87bc9c0d52d4 * alloca_.h: Conditionalize on _GNULIB_ALLOCA_H, not _ALLOCA_H.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5520
diff changeset
44 this grammar, which is not right recursive. Beware setting it too
5548
b8dd75cdd3a8 (YYSTACK_USE_ALLOCA): Define to 0, since there's no need to extend the
Paul Eggert <eggert@cs.ucla.edu>
parents: 5546
diff changeset
45 high, since that might cause problems on machines whose
5538
87bc9c0d52d4 * alloca_.h: Conditionalize on _GNULIB_ALLOCA_H, not _ALLOCA_H.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5520
diff changeset
46 implementations have lame stack-overflow checking. */
87bc9c0d52d4 * alloca_.h: Conditionalize on _GNULIB_ALLOCA_H, not _ALLOCA_H.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5520
diff changeset
47 #define YYMAXDEPTH 20
5546
b45cd12ab00f (YYINITDEPTH): New macro, so that the initial stack is small too.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5543
diff changeset
48 #define YYINITDEPTH YYMAXDEPTH
4156
99ea86c79f44 Make it possibly to simply write: #include <alloca.h>.
Bruno Haible <bruno@clisp.org>
parents: 4102
diff changeset
49
100
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
50 /* Since the code of getdate.y is not included in the Emacs executable
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
51 itself, there is no need to #define static in this file. Even if
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
52 the code were included in the Emacs executable, it probably
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
53 wouldn't do any harm to #undef it here; this will only cause
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
54 problems if we try to write to a static variable, which I don't
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
55 think this code needs to do. */
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
56 #ifdef emacs
855
9c89b90524b8 (get_date): Change prototype to reflect const'ness of parameters.
Jim Meyering <jim@meyering.net>
parents: 852
diff changeset
57 # undef static
100
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
58 #endif
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
59
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
60 #include <ctype.h>
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
61 #include <limits.h>
5382
72833e3704a0 * getdate.y [!TEST]: Include <stdio.h>, since we use sprintf now.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5373
diff changeset
62 #include <stdio.h>
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
63 #include <stdlib.h>
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
64 #include <string.h>
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
65
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
66 #include "setenv.h"
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
67 #include "xalloc.h"
1785
197f4bdf9a3d <stdlib.h>: Include if HAVE_STDLIB_H, since bison 1.27 invokes "free".
Jim Meyering <jim@meyering.net>
parents: 1777
diff changeset
68
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
69 #if STDC_HEADERS || (! defined isascii && ! HAVE_ISASCII)
811
193f7d202848 (IN_CTYPE_DOMAIN): Rename from ISASCII.
Jim Meyering <jim@meyering.net>
parents: 805
diff changeset
70 # define IN_CTYPE_DOMAIN(c) 1
688
cc4dbb9f5f58 Define and use upper case variants of ctype.h IS* macros.
Jim Meyering <jim@meyering.net>
parents: 562
diff changeset
71 #else
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
72 # define IN_CTYPE_DOMAIN(c) isascii (c)
688
cc4dbb9f5f58 Define and use upper case variants of ctype.h IS* macros.
Jim Meyering <jim@meyering.net>
parents: 562
diff changeset
73 #endif
cc4dbb9f5f58 Define and use upper case variants of ctype.h IS* macros.
Jim Meyering <jim@meyering.net>
parents: 562
diff changeset
74
811
193f7d202848 (IN_CTYPE_DOMAIN): Rename from ISASCII.
Jim Meyering <jim@meyering.net>
parents: 805
diff changeset
75 #define ISSPACE(c) (IN_CTYPE_DOMAIN (c) && isspace (c))
193f7d202848 (IN_CTYPE_DOMAIN): Rename from ISASCII.
Jim Meyering <jim@meyering.net>
parents: 805
diff changeset
76 #define ISALPHA(c) (IN_CTYPE_DOMAIN (c) && isalpha (c))
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
77 #define ISLOWER(c) (IN_CTYPE_DOMAIN (c) && islower (c))
814
3976dc4f68dd add blank line.
Jim Meyering <jim@meyering.net>
parents: 811
diff changeset
78
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
79 /* ISDIGIT differs from isdigit, as follows:
811
193f7d202848 (IN_CTYPE_DOMAIN): Rename from ISASCII.
Jim Meyering <jim@meyering.net>
parents: 805
diff changeset
80 - Its arg may be any int or unsigned int; it need not be an unsigned char.
193f7d202848 (IN_CTYPE_DOMAIN): Rename from ISASCII.
Jim Meyering <jim@meyering.net>
parents: 805
diff changeset
81 - It's guaranteed to evaluate its argument exactly once.
193f7d202848 (IN_CTYPE_DOMAIN): Rename from ISASCII.
Jim Meyering <jim@meyering.net>
parents: 805
diff changeset
82 - It's typically faster.
3697
cdfc99b9cf86 (ISDIGIT): Comment fix.
Jim Meyering <jim@meyering.net>
parents: 3618
diff changeset
83 POSIX says that only '0' through '9' are digits. Prefer ISDIGIT to
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
84 isdigit unless it's important to use the locale's definition
3697
cdfc99b9cf86 (ISDIGIT): Comment fix.
Jim Meyering <jim@meyering.net>
parents: 3618
diff changeset
85 of `digit' even when the host does not conform to POSIX. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
86 #define ISDIGIT(c) ((unsigned int) (c) - '0' <= 9)
688
cc4dbb9f5f58 Define and use upper case variants of ctype.h IS* macros.
Jim Meyering <jim@meyering.net>
parents: 562
diff changeset
87
1962
1f3b3ce10ab6 (__attribute__): Define to empty if GCC claims to
Jim Meyering <jim@meyering.net>
parents: 1931
diff changeset
88 #if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 8) || __STRICT_ANSI__
1584
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
89 # define __attribute__(x)
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
90 #endif
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
91
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
92 #ifndef ATTRIBUTE_UNUSED
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
93 # define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
94 #endif
0f1daf1810b4 Fix warnings from gcc -W -Wall
Jim Meyering <jim@meyering.net>
parents: 1265
diff changeset
95
5414
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
96 /* Shift A right by B bits portably, by dividing A by 2**B and
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
97 truncating towards minus infinity. A and B should be free of side
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
98 effects, and B should be in the range 0 <= B <= INT_BITS - 2, where
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
99 INT_BITS is the number of useful bits in an int. GNU code can
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
100 assume that INT_BITS is at least 32.
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
101
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
102 ISO C99 says that A >> B is implementation-defined if A < 0. Some
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
103 implementations (e.g., UNICOS 9.0 on a Cray Y-MP EL) don't shift
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
104 right in the usual way when A < 0, so SHR falls back on division if
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
105 ordinary A >> B doesn't seem to be the usual signed shift. */
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
106 #define SHR(a, b) \
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
107 (-1 >> 1 == -1 \
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
108 ? (a) >> (b) \
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
109 : (a) / (1 << (b)) - ((a) % (1 << (b)) < 0))
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
110
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
111 #define EPOCH_YEAR 1970
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
112 #define TM_YEAR_BASE 1900
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
113
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
114 #define HOUR(x) ((x) * 60)
2588
17f2ecbac01c (get_date): Apply relative times after time zone indicator, not before.
Jim Meyering <jim@meyering.net>
parents: 2280
diff changeset
115
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
116 /* An integer value, and the number of digits in its textual
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
117 representation. */
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
118 typedef struct
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
119 {
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
120 bool negative;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
121 long int value;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
122 size_t digits;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
123 } textint;
100
4d645beabfa4 merge with 1.8.1 + partial --version and --help
Jim Meyering <jim@meyering.net>
parents: 49
diff changeset
124
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
125 /* An entry in the lexical lookup table. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
126 typedef struct
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
127 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
128 char const *name;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
129 int type;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
130 int value;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
131 } table;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
132
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
133 /* Meridian: am, pm, or 24-hour style. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
134 enum { MERam, MERpm, MER24 };
769
c906850e724f Remap yacc globals to have gd_ prefix.
Jim Meyering <jim@meyering.net>
parents: 688
diff changeset
135
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
136 enum { BILLION = 1000000000, LOG10_BILLION = 9 };
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
137
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
138 /* Information passed to and from the parser. */
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
139 typedef struct
2047
626ebcce50a3 (get_date): Fix typo in time_t overflow test.
Jim Meyering <jim@meyering.net>
parents: 1986
diff changeset
140 {
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
141 /* The input string remaining to be parsed. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
142 const char *input;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
143
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
144 /* N, if this is the Nth Tuesday. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
145 long int day_ordinal;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
146
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
147 /* Day of week; Sunday is 0. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
148 int day_number;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
149
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
150 /* tm_isdst flag for the local zone. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
151 int local_isdst;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
152
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
153 /* Time zone, in minutes east of UTC. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
154 long int time_zone;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
155
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
156 /* Style used for time. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
157 int meridian;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
158
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
159 /* Gregorian year, month, day, hour, minutes, seconds, and nanoseconds. */
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
160 textint year;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
161 long int month;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
162 long int day;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
163 long int hour;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
164 long int minutes;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
165 struct timespec seconds; /* includes nanoseconds */
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
166
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
167 /* Relative year, month, day, hour, minutes, seconds, and nanoseconds. */
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
168 long int rel_year;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
169 long int rel_month;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
170 long int rel_day;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
171 long int rel_hour;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
172 long int rel_minutes;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
173 long int rel_seconds;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
174 long int rel_ns;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
175
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
176 /* Counts of nonterminals of various flavors parsed so far. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
177 bool timespec_seen;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
178 size_t dates_seen;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
179 size_t days_seen;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
180 size_t local_zones_seen;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
181 size_t rels_seen;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
182 size_t times_seen;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
183 size_t zones_seen;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
184
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
185 /* Table of local time zone abbrevations, terminated by a null entry. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
186 table local_time_zone_table[3];
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
187 } parser_control;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
188
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
189 union YYSTYPE;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
190 static int yylex (union YYSTYPE *, parser_control *);
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
191 static int yyerror (parser_control *, char *);
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
192 static long int time_zone_hhmm (textint, long int);
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
193
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
194 %}
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
195
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
196 /* We want a reentrant parser, even if the TZ manipulation and the calls to
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
197 localtime and gmtime are not reentrant. */
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
198 %pure-parser
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
199 %parse-param { parser_control *pc }
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
200 %lex-param { parser_control *pc }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
201
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
202 /* This grammar has 14 shift/reduce conflicts. */
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
203 %expect 14
2588
17f2ecbac01c (get_date): Apply relative times after time zone indicator, not before.
Jim Meyering <jim@meyering.net>
parents: 2280
diff changeset
204
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
205 %union
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
206 {
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
207 long int intval;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
208 textint textintval;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
209 struct timespec timespec;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
210 }
1203
2b6373ef4d3b Add %expect directive.
Jim Meyering <jim@meyering.net>
parents: 932
diff changeset
211
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
212 %token tAGO tDST
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
213
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
214 %token <intval> tDAY tDAY_UNIT tDAYZONE tHOUR_UNIT tLOCAL_ZONE tMERIDIAN
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
215 %token <intval> tMINUTE_UNIT tMONTH tMONTH_UNIT tORDINAL
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
216 %token <intval> tSEC_UNIT tYEAR_UNIT tZONE
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
217
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
218 %token <textintval> tSNUMBER tUNUMBER
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
219 %token <timespec> tSDECIMAL_NUMBER tUDECIMAL_NUMBER
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
220
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
221 %type <intval> o_colon_minutes o_merid
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
222 %type <timespec> seconds signed_seconds unsigned_seconds
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
223
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
224 %%
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
225
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
226 spec:
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
227 timespec
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
228 | items
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
229 ;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
230
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
231 timespec:
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
232 '@' seconds
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
233 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
234 pc->seconds = $2;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
235 pc->timespec_seen = true;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
236 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
237 ;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
238
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
239 items:
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
240 /* empty */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
241 | items item
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
242 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
243
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
244 item:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
245 time
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
246 { pc->times_seen++; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
247 | local_zone
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
248 { pc->local_zones_seen++; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
249 | zone
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
250 { pc->zones_seen++; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
251 | date
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
252 { pc->dates_seen++; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
253 | day
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
254 { pc->days_seen++; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
255 | rel
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
256 { pc->rels_seen++; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
257 | number
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
258 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
259
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
260 time:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
261 tUNUMBER tMERIDIAN
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
262 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
263 pc->hour = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
264 pc->minutes = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
265 pc->seconds.tv_sec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
266 pc->seconds.tv_nsec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
267 pc->meridian = $2;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
268 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
269 | tUNUMBER ':' tUNUMBER o_merid
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
270 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
271 pc->hour = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
272 pc->minutes = $3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
273 pc->seconds.tv_sec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
274 pc->seconds.tv_nsec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
275 pc->meridian = $4;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
276 }
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
277 | tUNUMBER ':' tUNUMBER tSNUMBER o_colon_minutes
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
278 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
279 pc->hour = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
280 pc->minutes = $3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
281 pc->seconds.tv_sec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
282 pc->seconds.tv_nsec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
283 pc->meridian = MER24;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
284 pc->zones_seen++;
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
285 pc->time_zone = time_zone_hhmm ($4, $5);
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
286 }
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
287 | tUNUMBER ':' tUNUMBER ':' unsigned_seconds o_merid
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
288 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
289 pc->hour = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
290 pc->minutes = $3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
291 pc->seconds = $5;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
292 pc->meridian = $6;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
293 }
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
294 | tUNUMBER ':' tUNUMBER ':' unsigned_seconds tSNUMBER o_colon_minutes
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
295 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
296 pc->hour = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
297 pc->minutes = $3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
298 pc->seconds = $5;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
299 pc->meridian = MER24;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
300 pc->zones_seen++;
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
301 pc->time_zone = time_zone_hhmm ($6, $7);
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
302 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
303 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
304
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
305 local_zone:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
306 tLOCAL_ZONE
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
307 { pc->local_isdst = $1; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
308 | tLOCAL_ZONE tDST
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
309 { pc->local_isdst = $1 < 0 ? 1 : $1 + 1; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
310 ;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
311
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
312 zone:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
313 tZONE
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
314 { pc->time_zone = $1; }
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
315 | tZONE tSNUMBER o_colon_minutes
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
316 { pc->time_zone = $1 + time_zone_hhmm ($2, $3); }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
317 | tDAYZONE
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
318 { pc->time_zone = $1 + 60; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
319 | tZONE tDST
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
320 { pc->time_zone = $1 + 60; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
321 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
322
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
323 day:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
324 tDAY
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
325 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
326 pc->day_ordinal = 1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
327 pc->day_number = $1;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
328 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
329 | tDAY ','
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
330 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
331 pc->day_ordinal = 1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
332 pc->day_number = $1;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
333 }
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
334 | tORDINAL tDAY
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
335 {
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
336 pc->day_ordinal = $1;
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
337 pc->day_number = $2;
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
338 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
339 | tUNUMBER tDAY
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
340 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
341 pc->day_ordinal = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
342 pc->day_number = $2;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
343 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
344 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
345
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
346 date:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
347 tUNUMBER '/' tUNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
348 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
349 pc->month = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
350 pc->day = $3.value;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
351 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
352 | tUNUMBER '/' tUNUMBER '/' tUNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
353 {
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
354 /* Interpret as YYYY/MM/DD if the first value has 4 or more digits,
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
355 otherwise as MM/DD/YY.
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
356 The goal in recognizing YYYY/MM/DD is solely to support legacy
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
357 machine-generated dates like those in an RCS log listing. If
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
358 you want portability, use the ISO 8601 format. */
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
359 if (4 <= $1.digits)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
360 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
361 pc->year = $1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
362 pc->month = $3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
363 pc->day = $5.value;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
364 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
365 else
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
366 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
367 pc->month = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
368 pc->day = $3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
369 pc->year = $5;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
370 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
371 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
372 | tUNUMBER tSNUMBER tSNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
373 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
374 /* ISO 8601 format. YYYY-MM-DD. */
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
375 pc->year = $1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
376 pc->month = -$2.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
377 pc->day = -$3.value;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
378 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
379 | tUNUMBER tMONTH tSNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
380 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
381 /* e.g. 17-JUN-1992. */
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
382 pc->day = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
383 pc->month = $2;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
384 pc->year.value = -$3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
385 pc->year.digits = $3.digits;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
386 }
4503
c4806038beda (date): Also accept dates like May-23-2003; suggestion
Paul Eggert <eggert@cs.ucla.edu>
parents: 4156
diff changeset
387 | tMONTH tSNUMBER tSNUMBER
c4806038beda (date): Also accept dates like May-23-2003; suggestion
Paul Eggert <eggert@cs.ucla.edu>
parents: 4156
diff changeset
388 {
c4806038beda (date): Also accept dates like May-23-2003; suggestion
Paul Eggert <eggert@cs.ucla.edu>
parents: 4156
diff changeset
389 /* e.g. JUN-17-1992. */
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
390 pc->month = $1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
391 pc->day = -$2.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
392 pc->year.value = -$3.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
393 pc->year.digits = $3.digits;
4503
c4806038beda (date): Also accept dates like May-23-2003; suggestion
Paul Eggert <eggert@cs.ucla.edu>
parents: 4156
diff changeset
394 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
395 | tMONTH tUNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
396 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
397 pc->month = $1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
398 pc->day = $2.value;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
399 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
400 | tMONTH tUNUMBER ',' tUNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
401 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
402 pc->month = $1;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
403 pc->day = $2.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
404 pc->year = $4;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
405 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
406 | tUNUMBER tMONTH
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
407 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
408 pc->day = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
409 pc->month = $2;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
410 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
411 | tUNUMBER tMONTH tUNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
412 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
413 pc->day = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
414 pc->month = $2;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
415 pc->year = $3;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
416 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
417 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
418
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
419 rel:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
420 relunit tAGO
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
421 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
422 pc->rel_ns = -pc->rel_ns;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
423 pc->rel_seconds = -pc->rel_seconds;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
424 pc->rel_minutes = -pc->rel_minutes;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
425 pc->rel_hour = -pc->rel_hour;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
426 pc->rel_day = -pc->rel_day;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
427 pc->rel_month = -pc->rel_month;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
428 pc->rel_year = -pc->rel_year;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
429 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
430 | relunit
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
431 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
432
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
433 relunit:
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
434 tORDINAL tYEAR_UNIT
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
435 { pc->rel_year += $1 * $2; }
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
436 | tUNUMBER tYEAR_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
437 { pc->rel_year += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
438 | tSNUMBER tYEAR_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
439 { pc->rel_year += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
440 | tYEAR_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
441 { pc->rel_year += $1; }
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
442 | tORDINAL tMONTH_UNIT
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
443 { pc->rel_month += $1 * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
444 | tUNUMBER tMONTH_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
445 { pc->rel_month += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
446 | tSNUMBER tMONTH_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
447 { pc->rel_month += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
448 | tMONTH_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
449 { pc->rel_month += $1; }
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
450 | tORDINAL tDAY_UNIT
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
451 { pc->rel_day += $1 * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
452 | tUNUMBER tDAY_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
453 { pc->rel_day += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
454 | tSNUMBER tDAY_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
455 { pc->rel_day += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
456 | tDAY_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
457 { pc->rel_day += $1; }
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
458 | tORDINAL tHOUR_UNIT
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
459 { pc->rel_hour += $1 * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
460 | tUNUMBER tHOUR_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
461 { pc->rel_hour += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
462 | tSNUMBER tHOUR_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
463 { pc->rel_hour += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
464 | tHOUR_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
465 { pc->rel_hour += $1; }
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
466 | tORDINAL tMINUTE_UNIT
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
467 { pc->rel_minutes += $1 * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
468 | tUNUMBER tMINUTE_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
469 { pc->rel_minutes += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
470 | tSNUMBER tMINUTE_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
471 { pc->rel_minutes += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
472 | tMINUTE_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
473 { pc->rel_minutes += $1; }
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
474 | tORDINAL tSEC_UNIT
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
475 { pc->rel_seconds += $1 * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
476 | tUNUMBER tSEC_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
477 { pc->rel_seconds += $1.value * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
478 | tSNUMBER tSEC_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
479 { pc->rel_seconds += $1.value * $2; }
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
480 | tSDECIMAL_NUMBER tSEC_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
481 { pc->rel_seconds += $1.tv_sec * $2; pc->rel_ns += $1.tv_nsec * $2; }
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
482 | tUDECIMAL_NUMBER tSEC_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
483 { pc->rel_seconds += $1.tv_sec * $2; pc->rel_ns += $1.tv_nsec * $2; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
484 | tSEC_UNIT
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
485 { pc->rel_seconds += $1; }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
486 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
487
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
488 seconds: signed_seconds | unsigned_seconds;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
489
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
490 signed_seconds:
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
491 tSDECIMAL_NUMBER
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
492 | tSNUMBER
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
493 { $$.tv_sec = $1.value; $$.tv_nsec = 0; }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
494 ;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
495
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
496 unsigned_seconds:
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
497 tUDECIMAL_NUMBER
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
498 | tUNUMBER
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
499 { $$.tv_sec = $1.value; $$.tv_nsec = 0; }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
500 ;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
501
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
502 number:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
503 tUNUMBER
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
504 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
505 if (pc->dates_seen
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
506 && ! pc->rels_seen && (pc->times_seen || 2 < $1.digits))
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
507 pc->year = $1;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
508 else
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
509 {
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
510 if (4 < $1.digits)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
511 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
512 pc->dates_seen++;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
513 pc->day = $1.value % 100;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
514 pc->month = ($1.value / 100) % 100;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
515 pc->year.value = $1.value / 10000;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
516 pc->year.digits = $1.digits - 4;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
517 }
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
518 else
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
519 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
520 pc->times_seen++;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
521 if ($1.digits <= 2)
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
522 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
523 pc->hour = $1.value;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
524 pc->minutes = 0;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
525 }
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
526 else
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
527 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
528 pc->hour = $1.value / 100;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
529 pc->minutes = $1.value % 100;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
530 }
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
531 pc->seconds.tv_sec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
532 pc->seconds.tv_nsec = 0;
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
533 pc->meridian = MER24;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
534 }
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
535 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
536 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
537 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
538
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
539 o_colon_minutes:
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
540 /* empty */
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
541 { $$ = -1; }
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
542 | ':' tUNUMBER
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
543 { $$ = $2.value; }
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
544 ;
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
545
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
546 o_merid:
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
547 /* empty */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
548 { $$ = MER24; }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
549 | tMERIDIAN
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
550 { $$ = $1; }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
551 ;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
552
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
553 %%
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
554
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
555 static table const meridian_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
556 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
557 { "AM", tMERIDIAN, MERam },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
558 { "A.M.", tMERIDIAN, MERam },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
559 { "PM", tMERIDIAN, MERpm },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
560 { "P.M.", tMERIDIAN, MERpm },
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
561 { NULL, 0, 0 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
562 };
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
563
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
564 static table const dst_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
565 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
566 { "DST", tDST, 0 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
567 };
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
568
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
569 static table const month_and_day_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
570 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
571 { "JANUARY", tMONTH, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
572 { "FEBRUARY", tMONTH, 2 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
573 { "MARCH", tMONTH, 3 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
574 { "APRIL", tMONTH, 4 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
575 { "MAY", tMONTH, 5 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
576 { "JUNE", tMONTH, 6 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
577 { "JULY", tMONTH, 7 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
578 { "AUGUST", tMONTH, 8 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
579 { "SEPTEMBER",tMONTH, 9 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
580 { "SEPT", tMONTH, 9 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
581 { "OCTOBER", tMONTH, 10 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
582 { "NOVEMBER", tMONTH, 11 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
583 { "DECEMBER", tMONTH, 12 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
584 { "SUNDAY", tDAY, 0 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
585 { "MONDAY", tDAY, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
586 { "TUESDAY", tDAY, 2 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
587 { "TUES", tDAY, 2 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
588 { "WEDNESDAY",tDAY, 3 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
589 { "WEDNES", tDAY, 3 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
590 { "THURSDAY", tDAY, 4 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
591 { "THUR", tDAY, 4 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
592 { "THURS", tDAY, 4 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
593 { "FRIDAY", tDAY, 5 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
594 { "SATURDAY", tDAY, 6 },
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
595 { NULL, 0, 0 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
596 };
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
597
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
598 static table const time_units_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
599 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
600 { "YEAR", tYEAR_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
601 { "MONTH", tMONTH_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
602 { "FORTNIGHT",tDAY_UNIT, 14 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
603 { "WEEK", tDAY_UNIT, 7 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
604 { "DAY", tDAY_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
605 { "HOUR", tHOUR_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
606 { "MINUTE", tMINUTE_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
607 { "MIN", tMINUTE_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
608 { "SECOND", tSEC_UNIT, 1 },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
609 { "SEC", tSEC_UNIT, 1 },
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
610 { NULL, 0, 0 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
611 };
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
612
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
613 /* Assorted relative-time words. */
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
614 static table const relative_time_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
615 {
4618
daa83913e57f (relative_time_table): Use tDAY_UNIT for "tomorrow", "yesterday",
Paul Eggert <eggert@cs.ucla.edu>
parents: 4503
diff changeset
616 { "TOMORROW", tDAY_UNIT, 1 },
daa83913e57f (relative_time_table): Use tDAY_UNIT for "tomorrow", "yesterday",
Paul Eggert <eggert@cs.ucla.edu>
parents: 4503
diff changeset
617 { "YESTERDAY",tDAY_UNIT, -1 },
daa83913e57f (relative_time_table): Use tDAY_UNIT for "tomorrow", "yesterday",
Paul Eggert <eggert@cs.ucla.edu>
parents: 4503
diff changeset
618 { "TODAY", tDAY_UNIT, 0 },
daa83913e57f (relative_time_table): Use tDAY_UNIT for "tomorrow", "yesterday",
Paul Eggert <eggert@cs.ucla.edu>
parents: 4503
diff changeset
619 { "NOW", tDAY_UNIT, 0 },
5449
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
620 { "LAST", tORDINAL, -1 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
621 { "THIS", tORDINAL, 0 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
622 { "NEXT", tORDINAL, 1 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
623 { "FIRST", tORDINAL, 1 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
624 /*{ "SECOND", tORDINAL, 2 }, */
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
625 { "THIRD", tORDINAL, 3 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
626 { "FOURTH", tORDINAL, 4 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
627 { "FIFTH", tORDINAL, 5 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
628 { "SIXTH", tORDINAL, 6 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
629 { "SEVENTH", tORDINAL, 7 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
630 { "EIGHTH", tORDINAL, 8 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
631 { "NINTH", tORDINAL, 9 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
632 { "TENTH", tORDINAL, 10 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
633 { "ELEVENTH", tORDINAL, 11 },
3b55c2b65e86 (tORDINAL): New token.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5414
diff changeset
634 { "TWELFTH", tORDINAL, 12 },
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
635 { "AGO", tAGO, 1 },
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
636 { NULL, 0, 0 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
637 };
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
638
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
639 /* The time zone table. This table is necessarily incomplete, as time
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
640 zone abbreviations are ambiguous; e.g. Australians interpret "EST"
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
641 as Eastern time in Australia, not as US Eastern Standard Time.
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
642 You cannot rely on getdate to handle arbitrary time zone
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
643 abbreviations; use numeric abbreviations like `-0500' instead. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
644 static table const time_zone_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
645 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
646 { "GMT", tZONE, HOUR ( 0) }, /* Greenwich Mean */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
647 { "UT", tZONE, HOUR ( 0) }, /* Universal (Coordinated) */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
648 { "UTC", tZONE, HOUR ( 0) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
649 { "WET", tZONE, HOUR ( 0) }, /* Western European */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
650 { "WEST", tDAYZONE, HOUR ( 0) }, /* Western European Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
651 { "BST", tDAYZONE, HOUR ( 0) }, /* British Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
652 { "ART", tZONE, -HOUR ( 3) }, /* Argentina */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
653 { "BRT", tZONE, -HOUR ( 3) }, /* Brazil */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
654 { "BRST", tDAYZONE, -HOUR ( 3) }, /* Brazil Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
655 { "NST", tZONE, -(HOUR ( 3) + 30) }, /* Newfoundland Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
656 { "NDT", tDAYZONE,-(HOUR ( 3) + 30) }, /* Newfoundland Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
657 { "AST", tZONE, -HOUR ( 4) }, /* Atlantic Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
658 { "ADT", tDAYZONE, -HOUR ( 4) }, /* Atlantic Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
659 { "CLT", tZONE, -HOUR ( 4) }, /* Chile */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
660 { "CLST", tDAYZONE, -HOUR ( 4) }, /* Chile Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
661 { "EST", tZONE, -HOUR ( 5) }, /* Eastern Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
662 { "EDT", tDAYZONE, -HOUR ( 5) }, /* Eastern Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
663 { "CST", tZONE, -HOUR ( 6) }, /* Central Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
664 { "CDT", tDAYZONE, -HOUR ( 6) }, /* Central Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
665 { "MST", tZONE, -HOUR ( 7) }, /* Mountain Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
666 { "MDT", tDAYZONE, -HOUR ( 7) }, /* Mountain Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
667 { "PST", tZONE, -HOUR ( 8) }, /* Pacific Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
668 { "PDT", tDAYZONE, -HOUR ( 8) }, /* Pacific Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
669 { "AKST", tZONE, -HOUR ( 9) }, /* Alaska Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
670 { "AKDT", tDAYZONE, -HOUR ( 9) }, /* Alaska Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
671 { "HST", tZONE, -HOUR (10) }, /* Hawaii Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
672 { "HAST", tZONE, -HOUR (10) }, /* Hawaii-Aleutian Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
673 { "HADT", tDAYZONE, -HOUR (10) }, /* Hawaii-Aleutian Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
674 { "SST", tZONE, -HOUR (12) }, /* Samoa Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
675 { "WAT", tZONE, HOUR ( 1) }, /* West Africa */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
676 { "CET", tZONE, HOUR ( 1) }, /* Central European */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
677 { "CEST", tDAYZONE, HOUR ( 1) }, /* Central European Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
678 { "MET", tZONE, HOUR ( 1) }, /* Middle European */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
679 { "MEZ", tZONE, HOUR ( 1) }, /* Middle European */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
680 { "MEST", tDAYZONE, HOUR ( 1) }, /* Middle European Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
681 { "MESZ", tDAYZONE, HOUR ( 1) }, /* Middle European Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
682 { "EET", tZONE, HOUR ( 2) }, /* Eastern European */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
683 { "EEST", tDAYZONE, HOUR ( 2) }, /* Eastern European Summer */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
684 { "CAT", tZONE, HOUR ( 2) }, /* Central Africa */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
685 { "SAST", tZONE, HOUR ( 2) }, /* South Africa Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
686 { "EAT", tZONE, HOUR ( 3) }, /* East Africa */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
687 { "MSK", tZONE, HOUR ( 3) }, /* Moscow */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
688 { "MSD", tDAYZONE, HOUR ( 3) }, /* Moscow Daylight */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
689 { "IST", tZONE, (HOUR ( 5) + 30) }, /* India Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
690 { "SGT", tZONE, HOUR ( 8) }, /* Singapore */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
691 { "KST", tZONE, HOUR ( 9) }, /* Korea Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
692 { "JST", tZONE, HOUR ( 9) }, /* Japan Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
693 { "GST", tZONE, HOUR (10) }, /* Guam Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
694 { "NZST", tZONE, HOUR (12) }, /* New Zealand Standard */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
695 { "NZDT", tDAYZONE, HOUR (12) }, /* New Zealand Daylight */
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
696 { NULL, 0, 0 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
697 };
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
698
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
699 /* Military time zone table. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
700 static table const military_table[] =
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
701 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
702 { "A", tZONE, -HOUR ( 1) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
703 { "B", tZONE, -HOUR ( 2) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
704 { "C", tZONE, -HOUR ( 3) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
705 { "D", tZONE, -HOUR ( 4) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
706 { "E", tZONE, -HOUR ( 5) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
707 { "F", tZONE, -HOUR ( 6) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
708 { "G", tZONE, -HOUR ( 7) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
709 { "H", tZONE, -HOUR ( 8) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
710 { "I", tZONE, -HOUR ( 9) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
711 { "K", tZONE, -HOUR (10) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
712 { "L", tZONE, -HOUR (11) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
713 { "M", tZONE, -HOUR (12) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
714 { "N", tZONE, HOUR ( 1) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
715 { "O", tZONE, HOUR ( 2) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
716 { "P", tZONE, HOUR ( 3) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
717 { "Q", tZONE, HOUR ( 4) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
718 { "R", tZONE, HOUR ( 5) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
719 { "S", tZONE, HOUR ( 6) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
720 { "T", tZONE, HOUR ( 7) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
721 { "U", tZONE, HOUR ( 8) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
722 { "V", tZONE, HOUR ( 9) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
723 { "W", tZONE, HOUR (10) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
724 { "X", tZONE, HOUR (11) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
725 { "Y", tZONE, HOUR (12) },
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
726 { "Z", tZONE, HOUR ( 0) },
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
727 { NULL, 0, 0 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
728 };
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
729
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
730
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
731
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
732 /* Convert a time zone expressed as HH:MM into an integer count of
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
733 minutes. If MM is negative, then S is of the form HHMM and needs
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
734 to be picked apart; otherwise, S is of the form HH. */
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
735
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
736 static long int
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
737 time_zone_hhmm (textint s, long int mm)
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
738 {
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
739 if (mm < 0)
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
740 return (s.value / 100) * 60 + s.value % 100;
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
741 else
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
742 return s.value * 60 + (s.negative ? -mm : mm);
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
743 }
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
744
16
01c6d40adf9d Make tables static and const when possible.
Jim Meyering <jim@meyering.net>
parents: 9
diff changeset
745 static int
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
746 to_hour (long int hours, int meridian)
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
747 {
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
748 switch (meridian)
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
749 {
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
750 default: /* Pacify GCC. */
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
751 case MER24:
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
752 return 0 <= hours && hours < 24 ? hours : -1;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
753 case MERam:
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
754 return 0 < hours && hours < 12 ? hours : hours == 12 ? 0 : -1;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
755 case MERpm:
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
756 return 0 < hours && hours < 12 ? hours + 12 : hours == 12 ? 12 : -1;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
757 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
758 }
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
759
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
760 static long int
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
761 to_year (textint textyear)
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
762 {
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
763 long int year = textyear.value;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
764
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
765 if (year < 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
766 year = -year;
852
2156a43352c1 1997-01-06 Paul Eggert <eggert@twinsun.com>
Jim Meyering <jim@meyering.net>
parents: 814
diff changeset
767
2156a43352c1 1997-01-06 Paul Eggert <eggert@twinsun.com>
Jim Meyering <jim@meyering.net>
parents: 814
diff changeset
768 /* XPG4 suggests that years 00-68 map to 2000-2068, and
2156a43352c1 1997-01-06 Paul Eggert <eggert@twinsun.com>
Jim Meyering <jim@meyering.net>
parents: 814
diff changeset
769 years 69-99 map to 1969-1999. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
770 else if (textyear.digits == 2)
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
771 year += year < 69 ? 2000 : 1900;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
772
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
773 return year;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
774 }
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
775
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
776 static table const *
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
777 lookup_zone (parser_control const *pc, char const *name)
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
778 {
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
779 table const *tp;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
780
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
781 /* Try local zone abbreviations first; they're more likely to be right. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
782 for (tp = pc->local_time_zone_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
783 if (strcmp (name, tp->name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
784 return tp;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
785
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
786 for (tp = time_zone_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
787 if (strcmp (name, tp->name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
788 return tp;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
789
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
790 return NULL;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
791 }
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
792
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
793 #if ! HAVE_TM_GMTOFF
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
794 /* Yield the difference between *A and *B,
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
795 measured in seconds, ignoring leap seconds.
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
796 The body of this function is taken directly from the GNU C Library;
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
797 see src/strftime.c. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
798 static long int
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
799 tm_diff (struct tm const *a, struct tm const *b)
207
25a5ae7fce09 Revert 1.14-1.16 changes that removed difftm and modified get_date.
Jim Meyering <jim@meyering.net>
parents: 202
diff changeset
800 {
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
801 /* Compute intervening leap days correctly even if year is negative.
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
802 Take care to avoid int overflow in leap day calculations. */
5414
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
803 int a4 = SHR (a->tm_year, 2) + SHR (TM_YEAR_BASE, 2) - ! (a->tm_year & 3);
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
804 int b4 = SHR (b->tm_year, 2) + SHR (TM_YEAR_BASE, 2) - ! (b->tm_year & 3);
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
805 int a100 = a4 / 25 - (a4 % 25 < 0);
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
806 int b100 = b4 / 25 - (b4 % 25 < 0);
5414
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
807 int a400 = SHR (a100, 2);
1b5e702ecdd1 (SHR): New macro, which is a portable
Paul Eggert <eggert@cs.ucla.edu>
parents: 5391
diff changeset
808 int b400 = SHR (b100, 2);
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
809 int intervening_leap_days = (a4 - b4) - (a100 - b100) + (a400 - b400);
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
810 long int ayear = a->tm_year;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
811 long int years = ayear - b->tm_year;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
812 long int days = (365 * years + intervening_leap_days
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
813 + (a->tm_yday - b->tm_yday));
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
814 return (60 * (60 * (24 * days + (a->tm_hour - b->tm_hour))
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
815 + (a->tm_min - b->tm_min))
207
25a5ae7fce09 Revert 1.14-1.16 changes that removed difftm and modified get_date.
Jim Meyering <jim@meyering.net>
parents: 202
diff changeset
816 + (a->tm_sec - b->tm_sec));
25a5ae7fce09 Revert 1.14-1.16 changes that removed difftm and modified get_date.
Jim Meyering <jim@meyering.net>
parents: 202
diff changeset
817 }
2080
32451d20b978 Sync tm_diff with the GNU C Library.
Jim Meyering <jim@meyering.net>
parents: 2048
diff changeset
818 #endif /* ! HAVE_TM_GMTOFF */
207
25a5ae7fce09 Revert 1.14-1.16 changes that removed difftm and modified get_date.
Jim Meyering <jim@meyering.net>
parents: 202
diff changeset
819
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
820 static table const *
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
821 lookup_word (parser_control const *pc, char *word)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
822 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
823 char *p;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
824 char *q;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
825 size_t wordlen;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
826 table const *tp;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
827 bool period_found;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
828 bool abbrev;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
829
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
830 /* Make it uppercase. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
831 for (p = word; *p; p++)
5159
a535859efd14 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5080
diff changeset
832 {
a535859efd14 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5080
diff changeset
833 unsigned char ch = *p;
a535859efd14 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5080
diff changeset
834 if (ISLOWER (ch))
a535859efd14 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5080
diff changeset
835 *p = toupper (ch);
a535859efd14 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5080
diff changeset
836 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
837
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
838 for (tp = meridian_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
839 if (strcmp (word, tp->name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
840 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
841
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
842 /* See if we have an abbreviation for a month. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
843 wordlen = strlen (word);
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
844 abbrev = wordlen == 3 || (wordlen == 4 && word[3] == '.');
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
845
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
846 for (tp = month_and_day_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
847 if ((abbrev ? strncmp (word, tp->name, 3) : strcmp (word, tp->name)) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
848 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
849
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
850 if ((tp = lookup_zone (pc, word)))
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
851 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
852
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
853 if (strcmp (word, dst_table[0].name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
854 return dst_table;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
855
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
856 for (tp = time_units_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
857 if (strcmp (word, tp->name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
858 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
859
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
860 /* Strip off any plural and try the units table again. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
861 if (word[wordlen - 1] == 'S')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
862 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
863 word[wordlen - 1] = '\0';
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
864 for (tp = time_units_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
865 if (strcmp (word, tp->name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
866 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
867 word[wordlen - 1] = 'S'; /* For "this" in relative_time_table. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
868 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
869
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
870 for (tp = relative_time_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
871 if (strcmp (word, tp->name) == 0)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
872 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
873
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
874 /* Military time zones. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
875 if (wordlen == 1)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
876 for (tp = military_table; tp->name; tp++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
877 if (word[0] == tp->name[0])
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
878 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
879
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
880 /* Drop out any periods and try the time zone table again. */
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
881 for (period_found = false, p = q = word; (*p = *q); q++)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
882 if (*q == '.')
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
883 period_found = true;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
884 else
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
885 p++;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
886 if (period_found && (tp = lookup_zone (pc, word)))
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
887 return tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
888
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
889 return NULL;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
890 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
891
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
892 static int
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
893 yylex (YYSTYPE *lvalp, parser_control *pc)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
894 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
895 unsigned char c;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
896 size_t count;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
897
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
898 for (;;)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
899 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
900 while (c = *pc->input, ISSPACE (c))
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
901 pc->input++;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
902
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
903 if (ISDIGIT (c) || c == '-' || c == '+')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
904 {
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
905 char const *p;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
906 int sign;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
907 unsigned long int value;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
908 if (c == '-' || c == '+')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
909 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
910 sign = c == '-' ? -1 : 1;
5080
033d299cab29 * getdate.y (yylex): Allow space between sign and number.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4984
diff changeset
911 while (c = *++pc->input, ISSPACE (c))
033d299cab29 * getdate.y (yylex): Allow space between sign and number.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4984
diff changeset
912 continue;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
913 if (! ISDIGIT (c))
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
914 /* skip the '-' sign */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
915 continue;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
916 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
917 else
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
918 sign = 0;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
919 p = pc->input;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
920 for (value = 0; ; value *= 10)
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
921 {
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
922 unsigned long int value1 = value + (c - '0');
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
923 if (value1 < value)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
924 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
925 value = value1;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
926 c = *++p;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
927 if (! ISDIGIT (c))
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
928 break;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
929 if (ULONG_MAX / 10 < value)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
930 return '?';
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
931 }
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
932 if ((c == '.' || c == ',') && ISDIGIT (p[1]))
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
933 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
934 time_t s;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
935 int ns;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
936 int digits;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
937 unsigned long int value1;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
938
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
939 /* Check for overflow when converting value to time_t. */
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
940 if (sign < 0)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
941 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
942 s = - value;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
943 if (0 < s)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
944 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
945 value1 = -s;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
946 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
947 else
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
948 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
949 s = value;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
950 if (s < 0)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
951 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
952 value1 = s;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
953 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
954 if (value != value1)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
955 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
956
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
957 /* Accumulate fraction, to ns precision. */
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
958 p++;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
959 ns = *p++ - '0';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
960 for (digits = 2; digits <= LOG10_BILLION; digits++)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
961 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
962 ns *= 10;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
963 if (ISDIGIT (*p))
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
964 ns += *p++ - '0';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
965 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
966
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
967 /* Skip excess digits, truncating toward -Infinity. */
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
968 if (sign < 0)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
969 for (; ISDIGIT (*p); p++)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
970 if (*p != '0')
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
971 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
972 ns++;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
973 break;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
974 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
975 while (ISDIGIT (*p))
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
976 p++;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
977
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
978 /* Adjust to the timespec convention, which is that
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
979 tv_nsec is always a positive offset even if tv_sec is
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
980 negative. */
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
981 if (sign < 0 && ns)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
982 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
983 s--;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
984 if (! (s < 0))
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
985 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
986 ns = BILLION - ns;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
987 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
988
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
989 lvalp->timespec.tv_sec = s;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
990 lvalp->timespec.tv_nsec = ns;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
991 pc->input = p;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
992 return sign ? tSDECIMAL_NUMBER : tUDECIMAL_NUMBER;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
993 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
994 else
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
995 {
5520
abe89af7ac24 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5449
diff changeset
996 lvalp->textintval.negative = sign < 0;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
997 if (sign < 0)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
998 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
999 lvalp->textintval.value = - value;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1000 if (0 < lvalp->textintval.value)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1001 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1002 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1003 else
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1004 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1005 lvalp->textintval.value = value;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1006 if (lvalp->textintval.value < 0)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1007 return '?';
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1008 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1009 lvalp->textintval.digits = p - pc->input;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1010 pc->input = p;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1011 return sign ? tSNUMBER : tUNUMBER;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1012 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1013 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1014
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1015 if (ISALPHA (c))
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1016 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1017 char buff[20];
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1018 char *p = buff;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1019 table const *tp;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1020
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1021 do
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1022 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1023 if (p < buff + sizeof buff - 1)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1024 *p++ = c;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1025 c = *++pc->input;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1026 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1027 while (ISALPHA (c) || c == '.');
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1028
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1029 *p = '\0';
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1030 tp = lookup_word (pc, buff);
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1031 if (! tp)
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
1032 return '?';
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
1033 lvalp->intval = tp->value;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1034 return tp->type;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1035 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1036
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1037 if (c != '(')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1038 return *pc->input++;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1039 count = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1040 do
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1041 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1042 c = *pc->input++;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1043 if (c == '\0')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1044 return c;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1045 if (c == '(')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1046 count++;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1047 else if (c == ')')
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1048 count--;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1049 }
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1050 while (count != 0);
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1051 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1052 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1053
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1054 /* Do nothing if the parser reports an error. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1055 static int
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1056 yyerror (parser_control *pc ATTRIBUTE_UNUSED, char *s ATTRIBUTE_UNUSED)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1057 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1058 return 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1059 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1060
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1061 /* If *TM0 is the old and *TM1 is the new value of a struct tm after
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1062 passing it to mktime, return true if it's OK that mktime returned T.
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1063 It's not OK if *TM0 has out-of-range members. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1064
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1065 static bool
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1066 mktime_ok (struct tm const *tm0, struct tm const *tm1, time_t t)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1067 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1068 if (t == (time_t) -1)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1069 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1070 /* Guard against falsely reporting an error when parsing a time
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1071 stamp that happens to equal (time_t) -1, on a host that
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1072 supports such a time stamp. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1073 tm1 = localtime (&t);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1074 if (!tm1)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1075 return false;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1076 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1077
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1078 return ! ((tm0->tm_sec ^ tm1->tm_sec)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1079 | (tm0->tm_min ^ tm1->tm_min)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1080 | (tm0->tm_hour ^ tm1->tm_hour)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1081 | (tm0->tm_mday ^ tm1->tm_mday)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1082 | (tm0->tm_mon ^ tm1->tm_mon)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1083 | (tm0->tm_year ^ tm1->tm_year));
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1084 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1085
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1086 /* A reasonable upper bound for the size of ordinary TZ strings.
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1087 Use heap allocation if TZ's length exceeds this. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1088 enum { TZBUFSIZE = 100 };
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1089
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1090 /* Return a copy of TZ, stored in TZBUF if it fits, and heap-allocated
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1091 otherwise. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1092 static char *
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1093 get_tz (char tzbuf[TZBUFSIZE])
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1094 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1095 char *tz = getenv ("TZ");
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1096 if (tz)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1097 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1098 size_t tzsize = strlen (tz) + 1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1099 tz = (tzsize <= TZBUFSIZE
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1100 ? memcpy (tzbuf, tz, tzsize)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1101 : xmemdup (tz, tzsize));
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1102 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1103 return tz;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1104 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1105
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1106 /* Parse a date/time string, storing the resulting time value into *RESULT.
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1107 The string itself is pointed to by P. Return true if successful.
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1108 P can be an incomplete or relative time specification; if so, use
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1109 *NOW as the basis for the returned time. */
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1110 bool
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1111 get_date (struct timespec *result, char const *p, struct timespec const *now)
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1112 {
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1113 time_t Start;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1114 long int Start_ns;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1115 struct tm const *tmp;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1116 struct tm tm;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1117 struct tm tm0;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
1118 parser_control pc;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1119 struct timespec gettime_buffer;
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1120 unsigned char c;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1121 bool tz_was_altered = false;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1122 char *tz0 = NULL;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1123 char tz0buf[TZBUFSIZE];
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1124 bool ok = true;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1125
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1126 if (! now)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1127 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1128 if (gettime (&gettime_buffer) != 0)
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1129 return false;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1130 now = &gettime_buffer;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1131 }
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1132
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1133 Start = now->tv_sec;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1134 Start_ns = now->tv_nsec;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1135
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1136 tmp = localtime (&now->tv_sec);
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1137 if (! tmp)
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1138 return false;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1139
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1140 while (c = *p, ISSPACE (c))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1141 p++;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1142
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1143 if (strncmp (p, "TZ=\"", 4) == 0)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1144 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1145 char const *tzbase = p + 4;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1146 size_t tzsize = 1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1147 char const *s;
5391
4776df58a51d Remove trailing white space.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5382
diff changeset
1148
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1149 for (s = tzbase; *s; s++, tzsize++)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1150 if (*s == '\\')
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1151 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1152 s++;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1153 if (! (*s == '\\' || *s == '"'))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1154 break;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1155 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1156 else if (*s == '"')
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1157 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1158 char *z;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1159 char *tz1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1160 char tz1buf[TZBUFSIZE];
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1161 bool large_tz = TZBUFSIZE < tzsize;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1162 bool setenv_ok;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1163 tz0 = get_tz (tz0buf);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1164 z = tz1 = large_tz ? xmalloc (tzsize) : tz1buf;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1165 for (s = tzbase; *s != '"'; s++)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1166 *z++ = *(s += *s == '\\');
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1167 *z = '\0';
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1168 setenv_ok = setenv ("TZ", tz1, 1) == 0;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1169 if (large_tz)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1170 free (tz1);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1171 if (!setenv_ok)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1172 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1173 tz_was_altered = true;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1174 p = s + 1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1175 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1176 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1177
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1178 pc.input = p;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1179 pc.year.value = tmp->tm_year;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1180 pc.year.value += TM_YEAR_BASE;
2280
adaf08e40364 Handle two-digit years with leading zeros correctly.
Jim Meyering <jim@meyering.net>
parents: 2110
diff changeset
1181 pc.year.digits = 4;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1182 pc.month = tmp->tm_mon + 1;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1183 pc.day = tmp->tm_mday;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1184 pc.hour = tmp->tm_hour;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1185 pc.minutes = tmp->tm_min;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1186 pc.seconds.tv_sec = tmp->tm_sec;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1187 pc.seconds.tv_nsec = Start_ns;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1188 tm.tm_isdst = tmp->tm_isdst;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1189
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1190 pc.meridian = MER24;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1191 pc.rel_ns = 0;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1192 pc.rel_seconds = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1193 pc.rel_minutes = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1194 pc.rel_hour = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1195 pc.rel_day = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1196 pc.rel_month = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1197 pc.rel_year = 0;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1198 pc.timespec_seen = false;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1199 pc.dates_seen = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1200 pc.days_seen = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1201 pc.rels_seen = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1202 pc.times_seen = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1203 pc.local_zones_seen = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1204 pc.zones_seen = 0;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1205
4102
1804d7137fc9 Test HAVE_STRUCT_TM_TM_ZONE, not HAVE_TM_ZONE.
Bruno Haible <bruno@clisp.org>
parents: 3701
diff changeset
1206 #if HAVE_STRUCT_TM_TM_ZONE
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1207 pc.local_time_zone_table[0].name = tmp->tm_zone;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1208 pc.local_time_zone_table[0].type = tLOCAL_ZONE;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1209 pc.local_time_zone_table[0].value = tmp->tm_isdst;
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1210 pc.local_time_zone_table[1].name = NULL;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1211
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1212 /* Probe the names used in the next three calendar quarters, looking
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1213 for a tm_isdst different from the one we already have. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1214 {
1929
f7d4ee7478d7 (get_date): Rename outermost local `probe' to `quarter'.
Jim Meyering <jim@meyering.net>
parents: 1928
diff changeset
1215 int quarter;
f7d4ee7478d7 (get_date): Rename outermost local `probe' to `quarter'.
Jim Meyering <jim@meyering.net>
parents: 1928
diff changeset
1216 for (quarter = 1; quarter <= 3; quarter++)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1217 {
1929
f7d4ee7478d7 (get_date): Rename outermost local `probe' to `quarter'.
Jim Meyering <jim@meyering.net>
parents: 1928
diff changeset
1218 time_t probe = Start + quarter * (90 * 24 * 60 * 60);
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1219 struct tm const *probe_tm = localtime (&probe);
1930
92632825178b (get_date): Rename latter local `tm' to probe_tm.
Jim Meyering <jim@meyering.net>
parents: 1929
diff changeset
1220 if (probe_tm && probe_tm->tm_zone
92632825178b (get_date): Rename latter local `tm' to probe_tm.
Jim Meyering <jim@meyering.net>
parents: 1929
diff changeset
1221 && probe_tm->tm_isdst != pc.local_time_zone_table[0].value)
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1222 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1223 {
1930
92632825178b (get_date): Rename latter local `tm' to probe_tm.
Jim Meyering <jim@meyering.net>
parents: 1929
diff changeset
1224 pc.local_time_zone_table[1].name = probe_tm->tm_zone;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1225 pc.local_time_zone_table[1].type = tLOCAL_ZONE;
1930
92632825178b (get_date): Rename latter local `tm' to probe_tm.
Jim Meyering <jim@meyering.net>
parents: 1929
diff changeset
1226 pc.local_time_zone_table[1].value = probe_tm->tm_isdst;
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1227 pc.local_time_zone_table[2].name = NULL;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1228 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1229 break;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1230 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1231 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1232 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1233 #else
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1234 #if HAVE_TZNAME
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1235 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1236 # ifndef tzname
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1237 extern char *tzname[];
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1238 # endif
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1239 int i;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1240 for (i = 0; i < 2; i++)
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1241 {
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1242 pc.local_time_zone_table[i].name = tzname[i];
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1243 pc.local_time_zone_table[i].type = tLOCAL_ZONE;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1244 pc.local_time_zone_table[i].value = i;
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1245 }
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1246 pc.local_time_zone_table[i].name = NULL;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1247 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1248 #else
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1249 pc.local_time_zone_table[0].name = NULL;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1250 #endif
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1251 #endif
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1252
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1253 if (pc.local_time_zone_table[0].name && pc.local_time_zone_table[1].name
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1254 && ! strcmp (pc.local_time_zone_table[0].name,
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1255 pc.local_time_zone_table[1].name))
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1256 {
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1257 /* This locale uses the same abbrevation for standard and
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1258 daylight times. So if we see that abbreviation, we don't
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1259 know whether it's daylight time. */
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1260 pc.local_time_zone_table[0].value = -1;
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1261 pc.local_time_zone_table[1].name = NULL;
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1262 }
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1263
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1264 if (yyparse (&pc) != 0)
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1265 goto fail;
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1266
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1267 if (pc.timespec_seen)
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1268 *result = pc.seconds;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1269 else
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1270 {
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1271 if (1 < pc.times_seen || 1 < pc.dates_seen || 1 < pc.days_seen
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1272 || 1 < (pc.local_zones_seen + pc.zones_seen)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1273 || (pc.local_zones_seen && 1 < pc.local_isdst))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1274 goto fail;
852
2156a43352c1 1997-01-06 Paul Eggert <eggert@twinsun.com>
Jim Meyering <jim@meyering.net>
parents: 814
diff changeset
1275
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1276 tm.tm_year = to_year (pc.year) - TM_YEAR_BASE;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1277 tm.tm_mon = pc.month - 1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1278 tm.tm_mday = pc.day;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1279 if (pc.times_seen || (pc.rels_seen && ! pc.dates_seen && ! pc.days_seen))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1280 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1281 tm.tm_hour = to_hour (pc.hour, pc.meridian);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1282 if (tm.tm_hour < 0)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1283 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1284 tm.tm_min = pc.minutes;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1285 tm.tm_sec = pc.seconds.tv_sec;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1286 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1287 else
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1288 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1289 tm.tm_hour = tm.tm_min = tm.tm_sec = 0;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1290 pc.seconds.tv_nsec = 0;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1291 }
852
2156a43352c1 1997-01-06 Paul Eggert <eggert@twinsun.com>
Jim Meyering <jim@meyering.net>
parents: 814
diff changeset
1292
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1293 /* Let mktime deduce tm_isdst if we have an absolute time stamp. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1294 if (pc.dates_seen | pc.days_seen | pc.times_seen)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1295 tm.tm_isdst = -1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1296
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1297 /* But if the input explicitly specifies local time with or without
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1298 DST, give mktime that information. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1299 if (pc.local_zones_seen)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1300 tm.tm_isdst = pc.local_isdst;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1301
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1302 tm0 = tm;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1303
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1304 Start = mktime (&tm);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1305
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1306 if (! mktime_ok (&tm0, &tm, Start))
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1307 {
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1308 if (! pc.zones_seen)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1309 goto fail;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1310 else
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1311 {
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1312 /* Guard against falsely reporting errors near the time_t
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1313 boundaries when parsing times in other time zones. For
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1314 example, suppose the input string "1969-12-31 23:00:00 -0100",
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1315 the current time zone is 8 hours ahead of UTC, and the min
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1316 time_t value is 1970-01-01 00:00:00 UTC. Then the min
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1317 localtime value is 1970-01-01 08:00:00, and mktime will
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1318 therefore fail on 1969-12-31 23:00:00. To work around the
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1319 problem, set the time zone to 1 hour behind UTC temporarily
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1320 by setting TZ="XXX1:00" and try mktime again. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1321
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1322 long int time_zone = pc.time_zone;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1323 long int abs_time_zone = time_zone < 0 ? - time_zone : time_zone;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1324 long int abs_time_zone_hour = abs_time_zone / 60;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1325 int abs_time_zone_min = abs_time_zone % 60;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1326 char tz1buf[sizeof "XXX+0:00"
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1327 + sizeof pc.time_zone * CHAR_BIT / 3];
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1328 if (!tz_was_altered)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1329 tz0 = get_tz (tz0buf);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1330 sprintf (tz1buf, "XXX%s%ld:%02d", "-" + (time_zone < 0),
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1331 abs_time_zone_hour, abs_time_zone_min);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1332 if (setenv ("TZ", tz1buf, 1) != 0)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1333 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1334 tz_was_altered = true;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1335 tm = tm0;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1336 Start = mktime (&tm);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1337 if (! mktime_ok (&tm0, &tm, Start))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1338 goto fail;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1339 }
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1340 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1341
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1342 if (pc.days_seen && ! pc.dates_seen)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1343 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1344 tm.tm_mday += ((pc.day_number - tm.tm_wday + 7) % 7
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1345 + 7 * (pc.day_ordinal - (0 < pc.day_ordinal)));
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1346 tm.tm_isdst = -1;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1347 Start = mktime (&tm);
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1348 if (Start == (time_t) -1)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1349 goto fail;
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1350 }
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1351
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1352 if (pc.zones_seen)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1353 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1354 long int delta = pc.time_zone * 60;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1355 time_t t1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1356 #ifdef HAVE_TM_GMTOFF
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1357 delta -= tm.tm_gmtoff;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1358 #else
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1359 time_t t = Start;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1360 struct tm const *gmt = gmtime (&t);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1361 if (! gmt)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1362 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1363 delta -= tm_diff (&tm, gmt);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1364 #endif
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1365 t1 = Start - delta;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1366 if ((Start < t1) != (delta < 0))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1367 goto fail; /* time_t overflow */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1368 Start = t1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1369 }
855
9c89b90524b8 (get_date): Change prototype to reflect const'ness of parameters.
Jim Meyering <jim@meyering.net>
parents: 852
diff changeset
1370
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1371 /* Add relative date. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1372 if (pc.rel_year | pc.rel_month | pc.rel_day)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1373 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1374 int year = tm.tm_year + pc.rel_year;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1375 int month = tm.tm_mon + pc.rel_month;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1376 int day = tm.tm_mday + pc.rel_day;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1377 if (((year < tm.tm_year) ^ (pc.rel_year < 0))
5382
72833e3704a0 * getdate.y [!TEST]: Include <stdio.h>, since we use sprintf now.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5373
diff changeset
1378 | ((month < tm.tm_mon) ^ (pc.rel_month < 0))
72833e3704a0 * getdate.y [!TEST]: Include <stdio.h>, since we use sprintf now.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5373
diff changeset
1379 | ((day < tm.tm_mday) ^ (pc.rel_day < 0)))
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1380 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1381 tm.tm_year = year;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1382 tm.tm_mon = month;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1383 tm.tm_mday = day;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1384 Start = mktime (&tm);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1385 if (Start == (time_t) -1)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1386 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1387 }
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1388
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1389 /* Add relative hours, minutes, and seconds. On hosts that support
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1390 leap seconds, ignore the possibility of leap seconds; e.g.,
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1391 "+ 10 minutes" adds 600 seconds, even if one of them is a
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1392 leap second. Typically this is not what the user wants, but it's
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1393 too hard to do it the other way, because the time zone indicator
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1394 must be applied before relative times, and if mktime is applied
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1395 again the time zone will be lost. */
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1396 {
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1397 long int sum_ns = pc.seconds.tv_nsec + pc.rel_ns;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1398 long int normalized_ns = (sum_ns % BILLION + BILLION) % BILLION;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1399 time_t t0 = Start;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1400 long int d1 = 60 * 60 * pc.rel_hour;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1401 time_t t1 = t0 + d1;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1402 long int d2 = 60 * pc.rel_minutes;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1403 time_t t2 = t1 + d2;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1404 long int d3 = pc.rel_seconds;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1405 time_t t3 = t2 + d3;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1406 long int d4 = (sum_ns - normalized_ns) / BILLION;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1407 time_t t4 = t3 + d4;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1408
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1409 if ((d1 / (60 * 60) ^ pc.rel_hour)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1410 | (d2 / 60 ^ pc.rel_minutes)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1411 | ((t1 < t0) ^ (d1 < 0))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1412 | ((t2 < t1) ^ (d2 < 0))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1413 | ((t3 < t2) ^ (d3 < 0))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1414 | ((t4 < t3) ^ (d4 < 0)))
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1415 goto fail;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1416
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1417 result->tv_sec = t4;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1418 result->tv_nsec = normalized_ns;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1419 }
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1420 }
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1421
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1422 goto done;
852
2156a43352c1 1997-01-06 Paul Eggert <eggert@twinsun.com>
Jim Meyering <jim@meyering.net>
parents: 814
diff changeset
1423
5373
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1424 fail:
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1425 ok = false;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1426 done:
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1427 if (tz_was_altered)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1428 ok &= (tz0 ? setenv ("TZ", tz0, 1) : unsetenv ("TZ")) == 0;
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1429 if (tz0 != tz0buf)
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1430 free (tz0);
2169bf8a12fc Add support for TZ="foo" within a date string.
Paul Eggert <eggert@cs.ucla.edu>
parents: 5368
diff changeset
1431 return ok;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1432 }
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1433
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1434 #if TEST
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1435
202
eeeec8731bb9 merge with 1.9.4e
Jim Meyering <jim@meyering.net>
parents: 201
diff changeset
1436 int
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1437 main (int ac, char **av)
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1438 {
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1439 char buff[BUFSIZ];
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1440
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1441 printf ("Enter date, or blank line to exit.\n\t> ");
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1442 fflush (stdout);
321
4f4862ac3437 merge with 1.10q
Jim Meyering <jim@meyering.net>
parents: 307
diff changeset
1443
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1444 buff[BUFSIZ - 1] = '\0';
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1445 while (fgets (buff, BUFSIZ - 1, stdin) && buff[0])
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1446 {
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1447 struct timespec d;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1448 struct tm const *tm;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1449 if (! get_date (&d, buff, NULL))
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1450 printf ("Bad format - couldn't convert.\n");
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1451 else if (! (tm = localtime (&d.tv_sec)))
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1452 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1453 long int sec = d.tv_sec;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1454 printf ("localtime (%ld) failed\n", sec);
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1455 }
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1456 else
4984
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1457 {
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1458 int ns = d.tv_nsec;
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1459 printf ("%04ld-%02d-%02d %02d:%02d:%02d.%09d\n",
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1460 tm->tm_year + 1900L, tm->tm_mon + 1, tm->tm_mday,
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1461 tm->tm_hour, tm->tm_min, tm->tm_sec, ns);
8c6149ff20c9 Merge from coreutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4644
diff changeset
1462 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1463 printf ("\t> ");
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1464 fflush (stdout);
857
35c6ee15b830 Indent with GNU indent.
Jim Meyering <jim@meyering.net>
parents: 856
diff changeset
1465 }
1928
3119c326ccc8 Add copyright notice.
Jim Meyering <jim@meyering.net>
parents: 1914
diff changeset
1466 return 0;
9
f8dce34b5ab0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1467 }
5368
d7bc1d77db6d Use Bison 1.875 features, and some minor
Paul Eggert <eggert@cs.ucla.edu>
parents: 5318
diff changeset
1468 #endif /* TEST */