diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2000-02-02 13:47:49 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2000-02-02 13:47:49 +0000 |
commit | 89cfbc73b83ac826bd95ad3336d0d9d7cee0d517 (patch) | |
tree | 52a45f86e9a29a5c10005b18695f535cde12dcf7 | |
parent | 6ead3373fdd3f136aefedec5ee2e05f125596a5a (diff) |
Bug-fix: make should behave sensibly when presented with negative times...
- let *_MTime return booleans, as that's what they're used for, the time_t
is set as a side effect.
- use OUT_OF_DATE for a date starting point, set it at the origin of time.
-rw-r--r-- | usr.bin/make/arch.c | 49 | ||||
-rw-r--r-- | usr.bin/make/compat.c | 6 | ||||
-rw-r--r-- | usr.bin/make/dir.c | 22 | ||||
-rw-r--r-- | usr.bin/make/dir.h | 4 | ||||
-rw-r--r-- | usr.bin/make/extern.h | 6 | ||||
-rw-r--r-- | usr.bin/make/main.c | 6 | ||||
-rw-r--r-- | usr.bin/make/make.c | 22 | ||||
-rw-r--r-- | usr.bin/make/make.h | 4 | ||||
-rw-r--r-- | usr.bin/make/targ.c | 8 |
9 files changed, 68 insertions, 59 deletions
diff --git a/usr.bin/make/arch.c b/usr.bin/make/arch.c index e5239a48719..81127ebc320 100644 --- a/usr.bin/make/arch.c +++ b/usr.bin/make/arch.c @@ -1,4 +1,4 @@ -/* $OpenBSD: arch.c,v 1.24 2000/01/08 09:45:15 espie Exp $ */ +/* $OpenBSD: arch.c,v 1.25 2000/02/02 13:47:46 espie Exp $ */ /* $NetBSD: arch.c,v 1.17 1996/11/06 17:58:59 christos Exp $ */ /* @@ -43,7 +43,7 @@ #if 0 static char sccsid[] = "@(#)arch.c 8.2 (Berkeley) 1/2/94"; #else -static char rcsid[] = "$OpenBSD: arch.c,v 1.24 2000/01/08 09:45:15 espie Exp $"; +static char rcsid[] = "$OpenBSD: arch.c,v 1.25 2000/02/02 13:47:46 espie Exp $"; #endif #endif /* not lint */ @@ -73,9 +73,9 @@ static char rcsid[] = "$OpenBSD: arch.c,v 1.24 2000/01/08 09:45:15 espie Exp $"; * of the library's table of contents. * * Arch_MTime Find the modification time of a member of - * an archive *in the archive*. The time is also - * placed in the member's GNode. Returns the - * modification time. + * an archive *in the archive*, return TRUE if + * exists. The time is placed in the member's + * GNode. Returns the modification time. * * Arch_MemTime Find the modification time of a member of * an archive. Called when the member doesn't @@ -995,7 +995,7 @@ Arch_TouchLib (gn) * Return the modification time of a member of an archive. * * Results: - * The modification time (seconds). + * TRUE if found. * * Side Effects: * The mtime field of the given node is filled in with the value @@ -1003,7 +1003,7 @@ Arch_TouchLib (gn) * *----------------------------------------------------------------------- */ -time_t +Boolean Arch_MTime (gn) GNode *gn; /* Node describing archive member */ { @@ -1014,13 +1014,12 @@ Arch_MTime (gn) Var_Value(MEMBER, gn), TRUE); if (arhPtr != NULL) { - modTime = (time_t) strtol(arhPtr->ar_date, NULL, 10); + gn->mtime = (time_t) strtol(arhPtr->ar_date, NULL, 10); + return TRUE; } else { - modTime = 0; + gn->mtime = OUT_OF_DATE; + return FALSE; } - - gn->mtime = modTime; - return (modTime); } /*- @@ -1030,14 +1029,14 @@ Arch_MTime (gn) * time from its archived form, if it exists. * * Results: - * The modification time. + * TRUE if found. * * Side Effects: * The mtime field is filled in. * *----------------------------------------------------------------------- */ -time_t +Boolean Arch_MemMTime (gn) GNode *gn; { @@ -1047,8 +1046,8 @@ Arch_MemMTime (gn) *nameEnd; if (Lst_Open (gn->parents) != SUCCESS) { - gn->mtime = 0; - return (0); + gn->mtime = OUT_OF_DATE; + return FALSE; } while ((ln = Lst_Next (gn->parents)) != NULL) { pgn = (GNode *) Lst_Datum (ln); @@ -1070,21 +1069,24 @@ Arch_MemMTime (gn) if (pgn->make && nameEnd != NULL && strncmp(nameStart, gn->name, nameEnd - nameStart) == 0) { - gn->mtime = Arch_MTime(pgn); + if (Arch_MTime(pgn)) + gn->mtime = pgn->mtime; + else + gn->mtime = OUT_OF_DATE; } } else if (pgn->make) { /* * Something which isn't a library depends on the existence of * this target, so it needs to exist. */ - gn->mtime = 0; + gn->mtime = OUT_OF_DATE; break; } } Lst_Close (gn->parents); - return (gn->mtime); + return gn->mtime == OUT_OF_DATE; } /*- @@ -1172,17 +1174,18 @@ Arch_LibOODate (gn) if (OP_NOP(gn->type) && Lst_IsEmpty(gn->children)) { oodate = FALSE; - } else if ((gn->mtime > now) || (gn->mtime < gn->cmtime) || !gn->mtime) { - oodate = TRUE; + } else if (gn->mtime > now || gn->mtime < gn->cmtime || + gn->mtime == OUT_OF_DATE) { + oodate = TRUE; } else { #ifdef RANLIBMAG struct ar_hdr *arhPtr; /* Header for __.SYMDEF */ - int modTimeTOC; /* The table-of-contents's mod time */ + time_t modTimeTOC; /* The table-of-contents's mod time */ arhPtr = ArchStatMember (gn->path, RANLIBMAG, FALSE); if (arhPtr != NULL) { - modTimeTOC = (int) strtol(arhPtr->ar_date, NULL, 10); + modTimeTOC = (time_t) strtol(arhPtr->ar_date, NULL, 10); if (DEBUG(ARCH) || DEBUG(MAKE)) { printf("%s modified %s...", RANLIBMAG, Targ_FmtTime(modTimeTOC)); diff --git a/usr.bin/make/compat.c b/usr.bin/make/compat.c index f23713bc9a8..a0d74215a1c 100644 --- a/usr.bin/make/compat.c +++ b/usr.bin/make/compat.c @@ -1,4 +1,4 @@ -/* $OpenBSD: compat.c,v 1.21 2000/02/01 03:23:32 deraadt Exp $ */ +/* $OpenBSD: compat.c,v 1.22 2000/02/02 13:47:47 espie Exp $ */ /* $NetBSD: compat.c,v 1.14 1996/11/06 17:59:01 christos Exp $ */ /* @@ -43,7 +43,7 @@ #if 0 static char sccsid[] = "@(#)compat.c 8.2 (Berkeley) 3/19/94"; #else -static char rcsid[] = "$OpenBSD: compat.c,v 1.21 2000/02/01 03:23:32 deraadt Exp $"; +static char rcsid[] = "$OpenBSD: compat.c,v 1.22 2000/02/02 13:47:47 espie Exp $"; #endif #endif /* not lint */ @@ -588,7 +588,7 @@ CompatMake (gnp, pgnp) * ok. * -- ardeb 1/12/88 */ - if (noExecute || Dir_MTime(gn) == 0) { + if (noExecute || Dir_MTime(gn) == FALSE) { gn->mtime = now; } if (gn->cmtime > gn->mtime) diff --git a/usr.bin/make/dir.c b/usr.bin/make/dir.c index 79da0bf429a..7744735a18f 100644 --- a/usr.bin/make/dir.c +++ b/usr.bin/make/dir.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dir.c,v 1.15 2000/01/25 20:52:15 espie Exp $ */ +/* $OpenBSD: dir.c,v 1.16 2000/02/02 13:47:47 espie Exp $ */ /* $NetBSD: dir.c,v 1.14 1997/03/29 16:51:26 christos Exp $ */ /* @@ -43,7 +43,7 @@ #if 0 static char sccsid[] = "@(#)dir.c 8.2 (Berkeley) 1/2/94"; #else -static char rcsid[] = "$OpenBSD: dir.c,v 1.15 2000/01/25 20:52:15 espie Exp $"; +static char rcsid[] = "$OpenBSD: dir.c,v 1.16 2000/02/02 13:47:47 espie Exp $"; #endif #endif /* not lint */ @@ -68,7 +68,7 @@ static char rcsid[] = "$OpenBSD: dir.c,v 1.15 2000/01/25 20:52:15 espie Exp $"; * If it exists, the entire path is returned. * Otherwise NULL is returned. * - * Dir_MTime Return the modification time of a node. The file + * Dir_MTime Return TRUE if node exists. The file * is searched for along the default search path. * The path and mtime fields of the node are filled * in. @@ -977,7 +977,7 @@ Dir_FindFile (name, path) * search path dirSearchPath. * * Results: - * The modification time or 0 if it doesn't exist + * TRUE if file exists. * * Side Effects: * The modification time is placed in the node's mtime slot. @@ -985,7 +985,7 @@ Dir_FindFile (name, path) * found one for it, the full name is placed in the path slot. *----------------------------------------------------------------------- */ -int +Boolean Dir_MTime (gn) GNode *gn; /* the file whose modification time is * desired */ @@ -993,6 +993,7 @@ Dir_MTime (gn) char *fullName; /* the full pathname of name */ struct stat stb; /* buffer for finding the mod time */ Hash_Entry *entry; + Boolean exists; if (gn->type & OP_ARCHV) { return Arch_MTime (gn); @@ -1019,18 +1020,21 @@ Dir_MTime (gn) } stb.st_mtime = (time_t)(long)Hash_GetValue(entry); Hash_DeleteEntry(&mtimes, entry); + exists = TRUE; } else if (stat (fullName, &stb) == 0) { /* XXX forces make to differentiate between the epoch and * non-existent files by kludging the timestamp slightly. */ - if (stb.st_mtime == 0) - stb.st_mtime = 1; + if (stb.st_mtime == OUT_OF_DATE) + stb.st_mtime++; + exists = TRUE; } else { if (gn->type & OP_MEMBER) { if (fullName != gn->path) free(fullName); return Arch_MemMTime (gn); } else { - stb.st_mtime = 0; + stb.st_mtime = OUT_OF_DATE; + exists = FALSE; } } if (fullName && gn->path == (char *)NULL) { @@ -1038,7 +1042,7 @@ Dir_MTime (gn) } gn->mtime = stb.st_mtime; - return (gn->mtime); + return exists; } /*- diff --git a/usr.bin/make/dir.h b/usr.bin/make/dir.h index f1351500112..077530d4d63 100644 --- a/usr.bin/make/dir.h +++ b/usr.bin/make/dir.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dir.h,v 1.4 1998/12/05 00:06:27 espie Exp $ */ +/* $OpenBSD: dir.h,v 1.5 2000/02/02 13:47:47 espie Exp $ */ /* $NetBSD: dir.h,v 1.4 1996/11/06 17:59:05 christos Exp $ */ /* @@ -60,7 +60,7 @@ void Dir_End __P((void)); Boolean Dir_HasWildcards __P((char *)); void Dir_Expand __P((char *, Lst, Lst)); char *Dir_FindFile __P((char *, Lst)); -int Dir_MTime __P((GNode *)); +Boolean Dir_MTime __P((GNode *)); void Dir_AddDir __P((Lst, char *)); char *Dir_MakeFlags __P((char *, Lst)); void Dir_ClearPath __P((Lst)); diff --git a/usr.bin/make/extern.h b/usr.bin/make/extern.h index a647b22c90f..c0f3ecee080 100644 --- a/usr.bin/make/extern.h +++ b/usr.bin/make/extern.h @@ -1,4 +1,4 @@ -/* $OpenBSD: extern.h,v 1.18 2000/01/08 09:45:15 espie Exp $ */ +/* $OpenBSD: extern.h,v 1.19 2000/02/02 13:47:47 espie Exp $ */ /* $NetBSD: nonints.h,v 1.12 1996/11/06 17:59:19 christos Exp $ */ /*- @@ -45,8 +45,8 @@ ReturnStatus Arch_ParseArchive __P((char **, Lst, GNode *)); void Arch_Touch __P((GNode *)); void Arch_TouchLib __P((GNode *)); -time_t Arch_MTime __P((GNode *)); -time_t Arch_MemMTime __P((GNode *)); +Boolean Arch_MTime __P((GNode *)); +Boolean Arch_MemMTime __P((GNode *)); void Arch_FindLib __P((GNode *, Lst)); Boolean Arch_LibOODate __P((GNode *)); void Arch_Init __P((void)); diff --git a/usr.bin/make/main.c b/usr.bin/make/main.c index f602dac7b5f..a3a32825442 100644 --- a/usr.bin/make/main.c +++ b/usr.bin/make/main.c @@ -1,4 +1,4 @@ -/* $OpenBSD: main.c,v 1.27 1999/12/19 00:04:25 espie Exp $ */ +/* $OpenBSD: main.c,v 1.28 2000/02/02 13:47:47 espie Exp $ */ /* $NetBSD: main.c,v 1.34 1997/03/24 20:56:36 gwr Exp $ */ /* @@ -49,7 +49,7 @@ static char copyright[] = #if 0 static char sccsid[] = "@(#)main.c 8.3 (Berkeley) 3/19/94"; #else -static char rcsid[] = "$OpenBSD: main.c,v 1.27 1999/12/19 00:04:25 espie Exp $"; +static char rcsid[] = "$OpenBSD: main.c,v 1.28 2000/02/02 13:47:47 espie Exp $"; #endif #endif /* not lint */ @@ -113,7 +113,7 @@ static char rcsid[] = "$OpenBSD: main.c,v 1.27 1999/12/19 00:04:25 espie Exp $"; #define MAKEFLAGS ".MAKEFLAGS" Lst create; /* Targets to be made */ -time_t now; /* Time at start of make */ +time_t now = OUT_OF_DATE;/* Time at start of make */ GNode *DEFAULT; /* .DEFAULT node */ Boolean allPrecious; /* .PRECIOUS given on line by itself */ diff --git a/usr.bin/make/make.c b/usr.bin/make/make.c index a539d643a28..59b29bf3126 100644 --- a/usr.bin/make/make.c +++ b/usr.bin/make/make.c @@ -1,4 +1,4 @@ -/* $OpenBSD: make.c,v 1.12 1999/12/18 21:58:07 espie Exp $ */ +/* $OpenBSD: make.c,v 1.13 2000/02/02 13:47:48 espie Exp $ */ /* $NetBSD: make.c,v 1.10 1996/11/06 17:59:15 christos Exp $ */ /* @@ -43,7 +43,7 @@ #if 0 static char sccsid[] = "@(#)make.c 8.1 (Berkeley) 6/6/93"; #else -static char rcsid[] = "$OpenBSD: make.c,v 1.12 1999/12/18 21:58:07 espie Exp $"; +static char rcsid[] = "$OpenBSD: make.c,v 1.13 2000/02/02 13:47:48 espie Exp $"; #endif #endif /* not lint */ @@ -163,7 +163,7 @@ Make_OODate (gn) if ((gn->type & (OP_JOIN|OP_USE|OP_EXEC)) == 0) { (void) Dir_MTime (gn); if (DEBUG(MAKE)) { - if (gn->mtime != 0) { + if (gn->mtime != OUT_OF_DATE) { printf ("modified %s...", Targ_FmtTime(gn->mtime)); } else { printf ("non-existent..."); @@ -204,7 +204,7 @@ Make_OODate (gn) */ oodate = Arch_LibOODate (gn) || - ((gn->cmtime == 0) && (gn->type & OP_DOUBLEDEP)); + (gn->cmtime == OUT_OF_DATE && (gn->type & OP_DOUBLEDEP)); } else if (gn->type & OP_JOIN) { /* * A target with the .JOIN attribute is only considered @@ -229,21 +229,21 @@ Make_OODate (gn) } } oodate = TRUE; - } else if ((gn->mtime < gn->cmtime) || - ((gn->cmtime == 0) && - ((gn->mtime==0) || (gn->type & OP_DOUBLEDEP)))) + } else if (gn->mtime < gn->cmtime || + (gn->cmtime == OUT_OF_DATE && + (gn->mtime == OUT_OF_DATE || (gn->type & OP_DOUBLEDEP)))) { /* * A node whose modification time is less than that of its - * youngest child or that has no children (cmtime == 0) and - * either doesn't exist (mtime == 0) or was the object of a + * youngest child or that has no children (cmtime == OUT_OF_DATE) and + * either doesn't exist (mtime == OUT_OF_DATE) or was the object of a * :: operator is out-of-date. Why? Because that's the way Make does * it. */ if (DEBUG(MAKE)) { if (gn->mtime < gn->cmtime) { printf("modified before source..."); - } else if (gn->mtime == 0) { + } else if (gn->mtime == OUT_OF_DATE) { printf("non-existent and no sources..."); } else { printf(":: operator and no sources..."); @@ -472,7 +472,7 @@ Make_Update (cgn) * the target is made now. Otherwise archives with ... rules * don't work! */ - if (noExecute || (cgn->type & OP_SAVE_CMDS) || Dir_MTime(cgn) == 0) { + if (noExecute || (cgn->type & OP_SAVE_CMDS) || Dir_MTime(cgn) == FALSE) { cgn->mtime = now; } if (DEBUG(MAKE)) { diff --git a/usr.bin/make/make.h b/usr.bin/make/make.h index 46904d70b87..14c76caebf0 100644 --- a/usr.bin/make/make.h +++ b/usr.bin/make/make.h @@ -1,4 +1,4 @@ -/* $OpenBSD: make.h,v 1.16 1999/12/18 21:53:32 espie Exp $ */ +/* $OpenBSD: make.h,v 1.17 2000/02/02 13:47:48 espie Exp $ */ /* $NetBSD: make.h,v 1.15 1997/03/10 21:20:00 christos Exp $ */ /* @@ -84,6 +84,8 @@ #include "config.h" #include "buf.h" +#define OUT_OF_DATE INT_MIN + /*- * The structure for an individual graph node. Each node has several * pieces of data associated with it. diff --git a/usr.bin/make/targ.c b/usr.bin/make/targ.c index f181f8af2d9..4206684fdb6 100644 --- a/usr.bin/make/targ.c +++ b/usr.bin/make/targ.c @@ -1,4 +1,4 @@ -/* $OpenBSD: targ.c,v 1.13 1999/12/18 21:58:08 espie Exp $ */ +/* $OpenBSD: targ.c,v 1.14 2000/02/02 13:47:48 espie Exp $ */ /* $NetBSD: targ.c,v 1.11 1997/02/20 16:51:50 christos Exp $ */ /* @@ -43,7 +43,7 @@ #if 0 static char sccsid[] = "@(#)targ.c 8.2 (Berkeley) 3/19/94"; #else -static char *rcsid = "$OpenBSD: targ.c,v 1.13 1999/12/18 21:58:08 espie Exp $"; +static char *rcsid = "$OpenBSD: targ.c,v 1.14 2000/02/02 13:47:48 espie Exp $"; #endif #endif /* not lint */ @@ -183,7 +183,7 @@ Targ_NewGN (name) gn->made = UNMADE; gn->childMade = FALSE; gn->order = 0; - gn->mtime = gn->cmtime = 0; + gn->mtime = gn->cmtime = OUT_OF_DATE; gn->iParents = Lst_Init(); gn->cohorts = Lst_Init(); gn->parents = Lst_Init(); @@ -560,7 +560,7 @@ TargPrintNode (gnp, passp) printf("# No unmade children\n"); } if (! (gn->type & (OP_JOIN|OP_USE|OP_EXEC))) { - if (gn->mtime != 0) { + if (gn->mtime != OUT_OF_DATE) { printf("# last modified %s: %s\n", Targ_FmtTime(gn->mtime), (gn->made == UNMADE ? "unmade" : |