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: clean up job.c
details: https://anonhg.NetBSD.org/src/rev/71c4c47db7ab
branches: trunk
changeset: 980344:71c4c47db7ab
user: rillig <rillig%NetBSD.org@localhost>
date: Mon Feb 01 17:49:29 2021 +0000
description:
make: clean up job.c
There used to be a time when Job_Init only ran the commands of the
special .BEGIN target, but that's several years ago.
The 'becomes' for echoTmpl was confusing since it referred to a time
where echoTmpl shared the same memory location as errOn, which was
really confusing since echoTmpl, as the name says, is a printf template
while errOn is a plain string. All this confusion, just to save 4 or 8
bytes of memory, was not worth it.
Since shellArgv is only used for freeing it and no code is supposed to
ever interpret that memory, rename the variable.
diffstat:
usr.bin/make/job.c | 42 +++++++++++++++++++++---------------------
1 files changed, 21 insertions(+), 21 deletions(-)
diffs (130 lines):
diff -r 84a2cb623580 -r 71c4c47db7ab usr.bin/make/job.c
--- a/usr.bin/make/job.c Mon Feb 01 17:32:10 2021 +0000
+++ b/usr.bin/make/job.c Mon Feb 01 17:49:29 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: job.c,v 1.406 2021/02/01 17:10:23 sjg Exp $ */
+/* $NetBSD: job.c,v 1.407 2021/02/01 17:49:29 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -75,8 +75,8 @@
*
* Interface:
* Job_Init Called to initialize this module. In addition,
- * any commands attached to the .BEGIN target
- * are executed before this function returns.
+ * the .BEGIN target is made including all of its
+ * dependencies before this function returns.
* Hence, the makefiles must have been parsed
* before this function is called.
*
@@ -99,9 +99,9 @@
* a time given by the SEL_* constants, below,
* or until output is ready.
*
- * Job_ParseShell Given the line following a .SHELL target, parse
- * the line as a shell specification. Returns
- * FALSE if the spec was incorrect.
+ * Job_ParseShell Given a special dependency line with target '.SHELL',
+ * define the shell that is used for the creation
+ * commands in jobs mode.
*
* Job_Finish Perform any final processing which needs doing.
* This includes the execution of any commands
@@ -109,10 +109,9 @@
* target. It should only be called when the
* job table is empty.
*
- * Job_AbortAll Abort all currently running jobs. It doesn't
- * handle output or do anything for the jobs,
- * just kills them. It should only be called in
- * an emergency.
+ * Job_AbortAll Abort all currently running jobs. Do not handle
+ * output or do anything for the jobs, just kill them.
+ * Should only be called in an emergency.
*
* Job_CheckCommands
* Verify that the commands for a target are
@@ -143,7 +142,7 @@
#include "trace.h"
/* "@(#)job.c 8.2 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: job.c,v 1.406 2021/02/01 17:10:23 sjg Exp $");
+MAKE_RCSID("$NetBSD: job.c,v 1.407 2021/02/01 17:49:29 rillig Exp $");
/*
* A shell defines how the commands are run. All commands for a target are
@@ -164,15 +163,15 @@
* The error checking for individual commands is controlled using hasErrCtl,
* errOn, errOff and runChkTmpl.
*
- * If a shell doesn't have error control, echoTmpl becomes a printf template
- * for echoing the command, should echoing be on; runIgnTmpl becomes
- * another printf template for executing the command while ignoring the return
+ * In case a shell doesn't have error control, echoTmpl is a printf template
+ * for echoing the command, should echoing be on; runIgnTmpl is another
+ * printf template for executing the command while ignoring the return
* status. Finally runChkTmpl is a printf template for running the command and
* causing the shell to exit on error. If any of these strings are empty when
* hasErrCtl is FALSE, the command will be executed anyway as is, and if it
* causes an error, so be it. Any templates set up to echo the command will
- * escape any '$ ` \ "' characters in the command string to avoid common
- * problems with echo "%s\n" as a template.
+ * escape any '$ ` \ "' characters in the command string to avoid unwanted
+ * shell code injection, the escaped command is safe to use in double quotes.
*
* The command-line flags "echo" and "exit" also control the behavior. The
* "echo" flag causes the shell to start echoing commands right away. The
@@ -217,7 +216,7 @@
} Shell;
typedef struct CommandFlags {
- /* Whether to echo the command before running it. */
+ /* Whether to echo the command before or instead of running it. */
Boolean echo;
/* Run the command even in -n or -N mode. */
@@ -253,6 +252,7 @@
ABORT_ERROR, /* Because of an error */
ABORT_INTERRUPT, /* Because it was interrupted */
ABORT_WAIT /* Waiting for jobs to finish */
+ /* XXX: "WAIT" is not a _reason_ for aborting, it's rather a status. */
} AbortReason;
static AbortReason aborting = ABORT_NONE;
#define JOB_TOKENS "+EI+" /* Token to requeue for each abort state */
@@ -407,7 +407,7 @@
const char *shellPath = NULL; /* full pathname of executable image */
const char *shellName = NULL; /* last component of shellPath */
char *shellErrFlag = NULL;
-static char *shellArgv = NULL; /* Custom shell args */
+static char *shell_freeIt = NULL; /* Allocated memory for custom .SHELL */
static Job *job_table; /* The structures that describe them */
@@ -2379,7 +2379,7 @@
/* XXX: don't use line as an iterator variable */
pp_skip_whitespace(&line);
- free(shellArgv);
+ free(shell_freeIt);
memset(&newShell, 0, sizeof newShell);
@@ -2394,7 +2394,7 @@
Error("Unterminated quoted string [%s]", line);
return FALSE;
}
- shellArgv = path;
+ shell_freeIt = path;
for (path = NULL, argv = words; argc != 0; argc--, argv++) {
char *arg = *argv;
@@ -2605,7 +2605,7 @@
Job_End(void)
{
#ifdef CLEANUP
- free(shellArgv);
+ free(shell_freeIt);
#endif
}
Home |
Main Index |
Thread Index |
Old Index