make(1): rename GNode.cmgn to youngestChild

The name is longer than before but also clearer.
This commit is contained in:
rillig 2020-10-23 19:48:17 +00:00
parent 3d32d01229
commit 685b1164a5
5 changed files with 35 additions and 31 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: arch.c,v 1.139 2020/10/23 18:36:09 rillig Exp $ */ /* $NetBSD: arch.c,v 1.140 2020/10/23 19:48:17 rillig Exp $ */
/* /*
* Copyright (c) 1988, 1989, 1990, 1993 * Copyright (c) 1988, 1989, 1990, 1993
@ -130,7 +130,7 @@
#include "config.h" #include "config.h"
/* "@(#)arch.c 8.2 (Berkeley) 1/2/94" */ /* "@(#)arch.c 8.2 (Berkeley) 1/2/94" */
MAKE_RCSID("$NetBSD: arch.c,v 1.139 2020/10/23 18:36:09 rillig Exp $"); MAKE_RCSID("$NetBSD: arch.c,v 1.140 2020/10/23 19:48:17 rillig Exp $");
#ifdef TARGET_MACHINE #ifdef TARGET_MACHINE
#undef MAKE_MACHINE #undef MAKE_MACHINE
@ -1060,7 +1060,7 @@ Arch_FindLib(GNode *gn, SearchPath *path)
* given that it is a target on a dependency line somewhere: * given that it is a target on a dependency line somewhere:
* *
* Its modification time is less than that of one of its sources * Its modification time is less than that of one of its sources
* (gn->mtime < gn->cmgn->mtime). * (gn->mtime < gn->youngestChild->mtime).
* *
* Its modification time is greater than the time at which the make * Its modification time is greater than the time at which the make
* began (i.e. it's been modified in the course of the make, probably * began (i.e. it's been modified in the course of the make, probably
@ -1088,9 +1088,10 @@ Arch_LibOODate(GNode *gn)
oodate = TRUE; oodate = TRUE;
} else if (!GNode_IsTarget(gn) && Lst_IsEmpty(gn->children)) { } else if (!GNode_IsTarget(gn) && Lst_IsEmpty(gn->children)) {
oodate = FALSE; oodate = FALSE;
} else if ((!Lst_IsEmpty(gn->children) && gn->cmgn == NULL) || } else if ((!Lst_IsEmpty(gn->children) && gn->youngestChild == NULL) ||
(gn->mtime > now) || (gn->mtime > now) ||
(gn->cmgn != NULL && gn->mtime < gn->cmgn->mtime)) { (gn->youngestChild != NULL &&
gn->mtime < gn->youngestChild->mtime)) {
oodate = TRUE; oodate = TRUE;
} else { } else {
#ifdef RANLIBMAG #ifdef RANLIBMAG
@ -1105,7 +1106,7 @@ Arch_LibOODate(GNode *gn)
if (DEBUG(ARCH) || DEBUG(MAKE)) { if (DEBUG(ARCH) || DEBUG(MAKE)) {
debug_printf("%s modified %s...", RANLIBMAG, Targ_FmtTime(modTimeTOC)); debug_printf("%s modified %s...", RANLIBMAG, Targ_FmtTime(modTimeTOC));
} }
oodate = (gn->cmgn == NULL || gn->cmgn->mtime > modTimeTOC); oodate = (gn->youngestChild == NULL || gn->youngestChild->mtime > modTimeTOC);
} else { } else {
/* /*
* A library w/o a table of contents is out-of-date * A library w/o a table of contents is out-of-date

View File

@ -1,4 +1,4 @@
/* $NetBSD: compat.c,v 1.166 2020/10/18 07:46:04 rillig Exp $ */ /* $NetBSD: compat.c,v 1.167 2020/10/23 19:48:17 rillig Exp $ */
/* /*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California. * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@ -96,7 +96,7 @@
#include "pathnames.h" #include "pathnames.h"
/* "@(#)compat.c 8.2 (Berkeley) 3/19/94" */ /* "@(#)compat.c 8.2 (Berkeley) 3/19/94" */
MAKE_RCSID("$NetBSD: compat.c,v 1.166 2020/10/18 07:46:04 rillig Exp $"); MAKE_RCSID("$NetBSD: compat.c,v 1.167 2020/10/23 19:48:17 rillig Exp $");
static GNode *curTarg = NULL; static GNode *curTarg = NULL;
static pid_t compatChild; static pid_t compatChild;
@ -512,7 +512,7 @@ Compat_Make(GNode *gn, GNode *pgn)
} }
/* /*
* All the children were made ok. Now cmgn->mtime contains the * All the children were made ok. Now youngestChild->mtime contains the
* modification time of the newest child, we need to find out if we * modification time of the newest child, we need to find out if we
* exist and when we were modified last. The criteria for datedness * exist and when we were modified last. The criteria for datedness
* are defined by the Make_OODate function. * are defined by the Make_OODate function.

View File

@ -1,4 +1,4 @@
/* $NetBSD: make.c,v 1.177 2020/10/23 18:36:09 rillig Exp $ */ /* $NetBSD: make.c,v 1.178 2020/10/23 19:48:17 rillig Exp $ */
/* /*
* Copyright (c) 1988, 1989, 1990, 1993 * Copyright (c) 1988, 1989, 1990, 1993
@ -81,12 +81,12 @@
* *
* Make_Update Update all parents of a given child. Performs * Make_Update Update all parents of a given child. Performs
* various bookkeeping chores like the updating * various bookkeeping chores like the updating
* of the cmgn field of the parent, filling * of the youngestChild field of the parent, filling
* of the IMPSRC context variable, etc. It will * of the IMPSRC context variable, etc. It will
* place the parent on the toBeMade queue if it * place the parent on the toBeMade queue if it
* should be. * should be.
* *
* Make_TimeStamp Function to set the parent's cmgn field * Make_TimeStamp Function to set the parent's youngestChild field
* based on a child's modification time. * based on a child's modification time.
* *
* Make_DoAllVar Set up the various local variables for a * Make_DoAllVar Set up the various local variables for a
@ -107,7 +107,7 @@
#include "job.h" #include "job.h"
/* "@(#)make.c 8.1 (Berkeley) 6/6/93" */ /* "@(#)make.c 8.1 (Berkeley) 6/6/93" */
MAKE_RCSID("$NetBSD: make.c,v 1.177 2020/10/23 18:36:09 rillig Exp $"); MAKE_RCSID("$NetBSD: make.c,v 1.178 2020/10/23 19:48:17 rillig Exp $");
/* Sequence # to detect recursion. */ /* Sequence # to detect recursion. */
static unsigned int checked = 1; static unsigned int checked = 1;
@ -187,8 +187,8 @@ NoExecute(GNode *gn)
void void
Make_TimeStamp(GNode *pgn, GNode *cgn) Make_TimeStamp(GNode *pgn, GNode *cgn)
{ {
if (pgn->cmgn == NULL || cgn->mtime > pgn->cmgn->mtime) { if (pgn->youngestChild == NULL || cgn->mtime > pgn->youngestChild->mtime) {
pgn->cmgn = cgn; pgn->youngestChild = cgn;
} }
} }
@ -200,7 +200,7 @@ Make_TimeStamp(GNode *pgn, GNode *cgn)
* must be considered out-of-date since at least one of its children * must be considered out-of-date since at least one of its children
* will have been recreated. * will have been recreated.
* *
* The mtime field of the node and the cmgn field of its parents * The mtime field of the node and the youngestChild field of its parents
* may be changed. * may be changed.
*/ */
Boolean Boolean
@ -253,7 +253,7 @@ Make_OODate(GNode *gn)
* or non-existent. * or non-existent.
*/ */
oodate = (gn->mtime == 0 || Arch_LibOODate(gn) || oodate = (gn->mtime == 0 || Arch_LibOODate(gn) ||
(gn->cmgn == NULL && (gn->type & OP_DOUBLEDEP))); (gn->youngestChild == NULL && (gn->type & OP_DOUBLEDEP)));
} else if (gn->type & OP_JOIN) { } else if (gn->type & OP_JOIN) {
/* /*
* A target with the .JOIN attribute is only considered * A target with the .JOIN attribute is only considered
@ -277,22 +277,25 @@ Make_OODate(GNode *gn)
} }
} }
oodate = TRUE; oodate = TRUE;
} else if ((gn->cmgn != NULL && gn->mtime < gn->cmgn->mtime) || } else if ((gn->youngestChild != NULL &&
(gn->cmgn == NULL && gn->mtime < gn->youngestChild->mtime) ||
(gn->youngestChild == NULL &&
((gn->mtime == 0 && !(gn->type & OP_OPTIONAL)) ((gn->mtime == 0 && !(gn->type & OP_OPTIONAL))
|| gn->type & OP_DOUBLEDEP))) || gn->type & OP_DOUBLEDEP)))
{ {
/* /*
* A node whose modification time is less than that of its * A node whose modification time is less than that of its
* youngest child or that has no children (cmgn == NULL) and * youngest child or that has no children (youngestChild == NULL) and
* either doesn't exist (mtime == 0) and it isn't optional * either doesn't exist (mtime == 0) and it isn't optional
* or was the object of a * :: operator is out-of-date. * or was the object of a * :: operator is out-of-date.
* Why? Because that's the way Make does it. * Why? Because that's the way Make does it.
*/ */
if (DEBUG(MAKE)) { if (DEBUG(MAKE)) {
if (gn->cmgn != NULL && gn->mtime < gn->cmgn->mtime) { if (gn->youngestChild != NULL &&
gn->mtime < gn->youngestChild->mtime) {
debug_printf("modified before source %s...", debug_printf("modified before source %s...",
gn->cmgn->path ? gn->cmgn->path : gn->cmgn->name); gn->youngestChild->path ? gn->youngestChild->path
: gn->youngestChild->name);
} else if (gn->mtime == 0) { } else if (gn->mtime == 0) {
debug_printf("non-existent and no sources..."); debug_printf("non-existent and no sources...");
} else { } else {
@ -354,7 +357,7 @@ MakeAddChild(void *gnp, void *lp)
/* Find the pathname of a child that was already made. /* Find the pathname of a child that was already made.
* *
* The path and mtime of the node and the cmgn of the parent are * The path and mtime of the node and the youngestChild of the parent are
* updated; the unmade children count of the parent is decremented. * updated; the unmade children count of the parent is decremented.
* *
* Input: * Input:
@ -594,7 +597,7 @@ UpdateImplicitParentsVars(GNode *cgn, const char *cname)
* If the child is not up-to-date and still does not exist, * If the child is not up-to-date and still does not exist,
* set the FORCE flag on the parents. * set the FORCE flag on the parents.
* *
* If the child wasn't made, the cmgn field of the parent will be * If the child wasn't made, the youngestChild field of the parent will be
* altered if the child's mtime is big enough. * altered if the child's mtime is big enough.
* *
* Finally, if the child is the implied source for the parent, the * Finally, if the child is the implied source for the parent, the
@ -667,7 +670,7 @@ Make_Update(GNode *cgn)
/* /*
* If the parent has the .MADE attribute, its timestamp got * If the parent has the .MADE attribute, its timestamp got
* updated to that of its newest child, and its unmake * updated to that of its newest child, and its unmade
* child count got set to zero in Make_ExpandUse(). * child count got set to zero in Make_ExpandUse().
* However other things might cause us to build one of its * However other things might cause us to build one of its
* children - and so we mustn't do any processing here when * children - and so we mustn't do any processing here when

View File

@ -1,4 +1,4 @@
/* $NetBSD: make.h,v 1.165 2020/10/23 19:11:30 rillig Exp $ */ /* $NetBSD: make.h,v 1.166 2020/10/23 19:48:17 rillig Exp $ */
/* /*
* Copyright (c) 1988, 1989, 1990, 1993 * Copyright (c) 1988, 1989, 1990, 1993
@ -321,7 +321,7 @@ typedef struct GNode {
/* The modification time; 0 means the node does not have a corresponding /* The modification time; 0 means the node does not have a corresponding
* file; see Make_OODate. */ * file; see Make_OODate. */
time_t mtime; time_t mtime;
struct GNode *cmgn; /* The youngest child */ struct GNode *youngestChild;
/* The GNodes for which this node is an implied source. May be empty. /* The GNodes for which this node is an implied source. May be empty.
* For example, when there is an inference rule for .c.o, the node for * For example, when there is an inference rule for .c.o, the node for

View File

@ -1,4 +1,4 @@
/* $NetBSD: targ.c,v 1.121 2020/10/23 18:36:10 rillig Exp $ */ /* $NetBSD: targ.c,v 1.122 2020/10/23 19:48:17 rillig Exp $ */
/* /*
* Copyright (c) 1988, 1989, 1990, 1993 * Copyright (c) 1988, 1989, 1990, 1993
@ -121,7 +121,7 @@
#include "dir.h" #include "dir.h"
/* "@(#)targ.c 8.2 (Berkeley) 3/19/94" */ /* "@(#)targ.c 8.2 (Berkeley) 3/19/94" */
MAKE_RCSID("$NetBSD: targ.c,v 1.121 2020/10/23 18:36:10 rillig Exp $"); MAKE_RCSID("$NetBSD: targ.c,v 1.122 2020/10/23 19:48:17 rillig Exp $");
static GNodeList *allTargets; /* the list of all targets found so far */ static GNodeList *allTargets; /* the list of all targets found so far */
#ifdef CLEANUP #ifdef CLEANUP
@ -189,7 +189,7 @@ Targ_NewGN(const char *name)
gn->flags = 0; gn->flags = 0;
gn->checked_seqno = 0; gn->checked_seqno = 0;
gn->mtime = 0; gn->mtime = 0;
gn->cmgn = NULL; gn->youngestChild = NULL;
gn->implicitParents = Lst_New(); gn->implicitParents = Lst_New();
gn->cohorts = Lst_New(); gn->cohorts = Lst_New();
gn->parents = Lst_New(); gn->parents = Lst_New();