Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/make make(1): remove pointer indirection from GNode....
details: https://anonhg.NetBSD.org/src/rev/a88bd2e22290
branches: trunk
changeset: 978661:a88bd2e22290
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Nov 28 18:55:52 2020 +0000
description:
make(1): remove pointer indirection from GNode.commands
Just to save a few memory allocations. No noticeable effect on the
performance though.
diffstat:
usr.bin/make/compat.c | 10 +++++-----
usr.bin/make/cond.c | 6 +++---
usr.bin/make/job.c | 14 +++++++-------
usr.bin/make/lst.c | 19 +++++++++++--------
usr.bin/make/lst.h | 12 +++++++++++-
usr.bin/make/main.c | 6 +++---
usr.bin/make/make.c | 10 +++++-----
usr.bin/make/make.h | 4 ++--
usr.bin/make/meta.c | 10 +++++-----
usr.bin/make/parse.c | 8 ++++----
usr.bin/make/suff.c | 14 +++++++-------
usr.bin/make/targ.c | 10 +++++-----
12 files changed, 68 insertions(+), 55 deletions(-)
diffs (truncated from 481 to 300 lines):
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/compat.c
--- a/usr.bin/make/compat.c Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/compat.c Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compat.c,v 1.192 2020/11/24 19:04:42 rillig Exp $ */
+/* $NetBSD: compat.c,v 1.193 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -96,7 +96,7 @@
#include "pathnames.h"
/* "@(#)compat.c 8.2 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: compat.c,v 1.192 2020/11/24 19:04:42 rillig Exp $");
+MAKE_RCSID("$NetBSD: compat.c,v 1.193 2020/11/28 18:55:52 rillig Exp $");
static GNode *curTarg = NULL;
static pid_t compatChild;
@@ -218,7 +218,7 @@
* for delayed commands, run in parallel mode, using the same shell
* command line more than once; see JobPrintCommand.
* TODO: write a unit-test to protect against this potential bug. */
- cmdNode = Lst_FindDatum(gn->commands, cmd);
+ cmdNode = Lst_FindDatum(&gn->commands, cmd);
(void)Var_Subst(cmd, gn, VARE_WANTRES, &cmdStart);
/* TODO: handle errors */
@@ -232,7 +232,7 @@
if (gn->type & OP_SAVE_CMDS) {
GNode *endNode = Targ_GetEndNode();
if (gn != endNode) {
- Lst_Append(endNode->commands, cmdStart);
+ Lst_Append(&endNode->commands, cmdStart);
return 0;
}
}
@@ -449,7 +449,7 @@
{
StringListNode *ln;
- for (ln = gn->commands->first; ln != NULL; ln = ln->next) {
+ for (ln = gn->commands.first; ln != NULL; ln = ln->next) {
const char *cmd = ln->datum;
if (Compat_RunCommand(cmd, gn) != 0)
break;
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/cond.c
--- a/usr.bin/make/cond.c Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/cond.c Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cond.c,v 1.217 2020/11/23 20:52:59 rillig Exp $ */
+/* $NetBSD: cond.c,v 1.218 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -94,7 +94,7 @@
#include "dir.h"
/* "@(#)cond.c 8.2 (Berkeley) 1/2/94" */
-MAKE_RCSID("$NetBSD: cond.c,v 1.217 2020/11/23 20:52:59 rillig Exp $");
+MAKE_RCSID("$NetBSD: cond.c,v 1.218 2020/11/28 18:55:52 rillig Exp $");
/*
* The parsing of conditional expressions is based on this grammar:
@@ -335,7 +335,7 @@
FuncCommands(size_t argLen MAKE_ATTR_UNUSED, const char *arg)
{
GNode *gn = Targ_FindNode(arg);
- return gn != NULL && GNode_IsTarget(gn) && !Lst_IsEmpty(gn->commands);
+ return gn != NULL && GNode_IsTarget(gn) && !Lst_IsEmpty(&gn->commands);
}
/*
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/job.c
--- a/usr.bin/make/job.c Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/job.c Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: job.c,v 1.331 2020/11/28 08:40:05 rillig Exp $ */
+/* $NetBSD: job.c,v 1.332 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -143,7 +143,7 @@
#include "trace.h"
/* "@(#)job.c 8.2 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: job.c,v 1.331 2020/11/28 08:40:05 rillig Exp $");
+MAKE_RCSID("$NetBSD: job.c,v 1.332 2020/11/28 18:55:52 rillig Exp $");
/* A shell defines how the commands are run. All commands for a target are
* written into a single file, which is then given to the shell to execute
@@ -902,7 +902,7 @@
{
StringListNode *ln;
- for (ln = job->node->commands->first; ln != NULL; ln = ln->next) {
+ for (ln = job->node->commands.first; ln != NULL; ln = ln->next) {
const char *cmd = ln->datum;
if (strcmp(cmd, "...") == 0) {
@@ -929,7 +929,7 @@
* expand the other variables as well; see deptgt-end.mk. */
(void)Var_Subst(cmd, job->node, VARE_WANTRES, &expanded_cmd);
/* TODO: handle errors */
- Lst_Append(Targ_GetEndNode()->commands, expanded_cmd);
+ Lst_Append(&Targ_GetEndNode()->commands, expanded_cmd);
}
}
@@ -1175,7 +1175,7 @@
{
if (GNode_IsTarget(gn))
return TRUE;
- if (!Lst_IsEmpty(gn->commands))
+ if (!Lst_IsEmpty(&gn->commands))
return TRUE;
if ((gn->type & OP_LIB) && !Lst_IsEmpty(gn->children))
return TRUE;
@@ -1184,7 +1184,7 @@
* No commands. Look for .DEFAULT rule from which we might infer
* commands.
*/
- if (defaultNode != NULL && !Lst_IsEmpty(defaultNode->commands) &&
+ if (defaultNode != NULL && !Lst_IsEmpty(&defaultNode->commands) &&
!(gn->type & OP_SPECIAL)) {
/*
* The traditional Make only looks for a .DEFAULT if the node was
@@ -2451,7 +2451,7 @@
Job_Finish(void)
{
GNode *endNode = Targ_GetEndNode();
- if (!Lst_IsEmpty(endNode->commands) || !Lst_IsEmpty(endNode->children)) {
+ if (!Lst_IsEmpty(&endNode->commands) || !Lst_IsEmpty(endNode->children)) {
if (job_errors != 0) {
Error("Errors reported so .END ignored");
} else {
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/lst.c
--- a/usr.bin/make/lst.c Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/lst.c Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lst.c,v 1.94 2020/11/27 08:07:26 rillig Exp $ */
+/* $NetBSD: lst.c,v 1.95 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -34,7 +34,7 @@
#include "make.h"
-MAKE_RCSID("$NetBSD: lst.c,v 1.94 2020/11/27 08:07:26 rillig Exp $");
+MAKE_RCSID("$NetBSD: lst.c,v 1.95 2020/11/28 18:55:52 rillig Exp $");
static ListNode *
LstNodeNew(ListNode *prev, ListNode *next, void *datum)
@@ -53,16 +53,12 @@
Lst_New(void)
{
List *list = bmake_malloc(sizeof *list);
-
- list->first = NULL;
- list->last = NULL;
-
+ Lst_Init(list);
return list;
}
-/* Free a list and all its nodes. The node data are not freed though. */
void
-Lst_Free(List *list)
+Lst_Done(List *list)
{
ListNode *ln, *next;
@@ -70,7 +66,14 @@
next = ln->next;
free(ln);
}
+}
+/* Free a list and all its nodes. The node data are not freed though. */
+void
+Lst_Free(List *list)
+{
+
+ Lst_Done(list);
free(list);
}
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/lst.h
--- a/usr.bin/make/lst.h Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/lst.h Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lst.h,v 1.87 2020/11/27 08:07:26 rillig Exp $ */
+/* $NetBSD: lst.h,v 1.88 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -109,11 +109,21 @@
/* Create a new list. */
List *Lst_New(void);
+/* Free the list nodes, but not the list itself. */
+void Lst_Done(List *);
/* Free the list, leaving the node data unmodified. */
void Lst_Free(List *);
/* Free the list, freeing the node data using the given function. */
void Lst_Destroy(List *, LstFreeProc);
+/* Initialize a list, without memory allocation. */
+MAKE_INLINE void
+Lst_Init(List *list)
+{
+ list->first = NULL;
+ list->last = NULL;
+}
+
/* Get information about a list */
MAKE_INLINE Boolean
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/main.c
--- a/usr.bin/make/main.c Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/main.c Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: main.c,v 1.482 2020/11/28 10:00:25 rillig Exp $ */
+/* $NetBSD: main.c,v 1.483 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -109,7 +109,7 @@
#include "trace.h"
/* "@(#)main.c 8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: main.c,v 1.482 2020/11/28 10:00:25 rillig Exp $");
+MAKE_RCSID("$NetBSD: main.c,v 1.483 2020/11/28 18:55:52 rillig Exp $");
#if defined(MAKE_NATIVE) && !defined(lint)
__COPYRIGHT("@(#) Copyright (c) 1988, 1989, 1990, 1993 "
"The Regents of the University of California. "
@@ -2093,7 +2093,7 @@
Var_Set(".ERROR_TARGET", gn->name, VAR_GLOBAL);
Var_Delete(".ERROR_CMD", VAR_GLOBAL);
- for (ln = gn->commands->first; ln != NULL; ln = ln->next) {
+ for (ln = gn->commands.first; ln != NULL; ln = ln->next) {
const char *cmd = ln->datum;
if (cmd == NULL)
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/make.c
--- a/usr.bin/make/make.c Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/make.c Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: make.c,v 1.218 2020/11/27 08:07:26 rillig Exp $ */
+/* $NetBSD: make.c,v 1.219 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -102,7 +102,7 @@
#include "job.h"
/* "@(#)make.c 8.1 (Berkeley) 6/6/93" */
-MAKE_RCSID("$NetBSD: make.c,v 1.218 2020/11/27 08:07:26 rillig Exp $");
+MAKE_RCSID("$NetBSD: make.c,v 1.219 2020/11/28 18:55:52 rillig Exp $");
/* Sequence # to detect recursion. */
static unsigned int checked_seqno = 1;
@@ -376,13 +376,13 @@
}
#endif
- if ((cgn->type & (OP_USE | OP_USEBEFORE)) || Lst_IsEmpty(pgn->commands)) {
+ if ((cgn->type & (OP_USE | OP_USEBEFORE)) || Lst_IsEmpty(&pgn->commands)) {
if (cgn->type & OP_USEBEFORE) {
/* .USEBEFORE */
- Lst_PrependAll(pgn->commands, cgn->commands);
+ Lst_PrependAll(&pgn->commands, &cgn->commands);
} else {
/* .USE, or target has no commands */
- Lst_AppendAll(pgn->commands, cgn->commands);
+ Lst_AppendAll(&pgn->commands, &cgn->commands);
}
}
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/make.h
--- a/usr.bin/make/make.h Sat Nov 28 16:36:19 2020 +0000
+++ b/usr.bin/make/make.h Sat Nov 28 18:55:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: make.h,v 1.220 2020/11/28 09:45:01 rillig Exp $ */
+/* $NetBSD: make.h,v 1.221 2020/11/28 18:55:52 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -421,7 +421,7 @@
HashTable /* of Var pointer */ vars;
/* The commands to be given to a shell to create this target. */
- StringList *commands;
+ StringList commands;
/* Suffix for the node (determined by Suff_FindDeps and opaque to
* everyone but the Suff module) */
diff -r 2bf35dfd69f6 -r a88bd2e22290 usr.bin/make/meta.c
--- a/usr.bin/make/meta.c Sat Nov 28 16:36:19 2020 +0000
Home |
Main Index |
Thread Index |
Old Index