Make parsetime.c more consistent by using the (already declared) enum
type instead of int all over the place. (Cosmetic, enhances debugging.) Point out that a date specification _must_ follow the time of day spec, in the man page. This clarifies the last point PR # of bin/483: "at doesn't seem to ..." (the remainder has already been fixed with version 1.3 of parsetime.c).
This commit is contained in:
parent
00a44db927
commit
29eaad36e5
@ -1,4 +1,4 @@
|
||||
.\" $Id: at.man,v 1.3 1994/06/16 16:49:46 kernel Exp $
|
||||
.\" $Id: at.man,v 1.1 1995/04/12 02:42:31 ache Exp $
|
||||
.Dd April 12, 1995
|
||||
.Dt "AT" 1
|
||||
.Os "FreeBSD 2.1"
|
||||
@ -81,6 +81,8 @@ or
|
||||
.Ar MM/DD/YY
|
||||
or
|
||||
.Ar DD.MM.YY .
|
||||
The specification of a date must follow the specification of
|
||||
the time of day.
|
||||
You can also give times like
|
||||
.Op Nm now
|
||||
.Nm + Ar count \%time-units ,
|
||||
|
@ -56,7 +56,7 @@
|
||||
|
||||
/* Structures and unions */
|
||||
|
||||
enum { /* symbols */
|
||||
enum tok { /* symbols */
|
||||
MIDNIGHT, NOON, TEATIME,
|
||||
PM, AM, TOMORROW, TODAY, NOW,
|
||||
MINUTES, HOURS, DAYS, WEEKS,
|
||||
@ -69,8 +69,8 @@ enum { /* symbols */
|
||||
/* parse translation table - table driven parsers can be your FRIEND!
|
||||
*/
|
||||
struct {
|
||||
char *name; /* token name */
|
||||
int value; /* token id */
|
||||
const char *name; /* token name */
|
||||
enum tok value; /* token id */
|
||||
int plural; /* is this plural? */
|
||||
} Specials[] = {
|
||||
{ "midnight", MIDNIGHT,0 }, /* 00:00:00 of today or tomorrow */
|
||||
@ -127,18 +127,18 @@ static int need; /* scanner - need to advance to next argument */
|
||||
|
||||
static char *sc_token; /* scanner - token buffer */
|
||||
static size_t sc_len; /* scanner - lenght of token buffer */
|
||||
static int sc_tokid; /* scanner - token id */
|
||||
static enum tok sc_tokid; /* scanner - token id */
|
||||
static int sc_tokplur; /* scanner - is token plural? */
|
||||
|
||||
static char rcsid[] = "$Id: parsetime.c,v 1.3 1995/04/12 02:42:35 ache Exp $";
|
||||
static char rcsid[] = "$Id: parsetime.c,v 1.4 1995/05/30 06:29:25 rgrimes Exp $";
|
||||
|
||||
/* Local functions */
|
||||
|
||||
/*
|
||||
* parse a token, checking if it's something special to us
|
||||
*/
|
||||
static int
|
||||
parse_token(char *arg)
|
||||
static enum tok
|
||||
parse_token(const char *arg)
|
||||
{
|
||||
int i;
|
||||
|
||||
@ -172,7 +172,7 @@ init_scanner(int argc, char **argv)
|
||||
/*
|
||||
* token() fetches a token from the input stream
|
||||
*/
|
||||
static int
|
||||
static enum tok
|
||||
token()
|
||||
{
|
||||
int idx;
|
||||
@ -250,7 +250,7 @@ plonk(int tok)
|
||||
* expect() gets a token and dies most horribly if it's not the token we want
|
||||
*/
|
||||
static void
|
||||
expect(int desired)
|
||||
expect(enum tok desired)
|
||||
{
|
||||
if (token() != desired)
|
||||
plonk(sc_tokid); /* and we die here... */
|
||||
@ -489,7 +489,7 @@ month(struct tm *tm)
|
||||
token();
|
||||
|
||||
if (sc_tokid == SLASH || sc_tokid == DOT) {
|
||||
int sep;
|
||||
enum tok sep;
|
||||
|
||||
sep = sc_tokid;
|
||||
expect(NUMBER);
|
||||
|
Loading…
Reference in New Issue
Block a user