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): clean up comments in var.c
details: https://anonhg.NetBSD.org/src/rev/cd144cdbd763
branches: trunk
changeset: 1012575:cd144cdbd763
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Aug 02 17:10:54 2020 +0000
description:
make(1): clean up comments in var.c
Some of the effects listed in "Side Effects" were really "Main Effects"
and have been moved to the main description.
VarAdd: There's no "front" in a hash table.
VarHash: A const char * is not a "String to modify".
Var_Subst: Even in r1.1 of var.c, there was no "variable structure to
store in" anywhere nearby.
diffstat:
usr.bin/make/var.c | 135 +++++++++++++---------------------------------------
1 files changed, 35 insertions(+), 100 deletions(-)
diffs (truncated from 309 to 300 lines):
diff -r 062a8a562589 -r cd144cdbd763 usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Aug 02 16:23:33 2020 +0000
+++ b/usr.bin/make/var.c Sun Aug 02 17:10:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.399 2020/08/02 16:06:49 rillig Exp $ */
+/* $NetBSD: var.c,v 1.400 2020/08/02 17:10:54 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.399 2020/08/02 16:06:49 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.400 2020/08/02 17:10:54 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
#if 0
static char sccsid[] = "@(#)var.c 8.3 (Berkeley) 3/19/94";
#else
-__RCSID("$NetBSD: var.c,v 1.399 2020/08/02 16:06:49 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.400 2020/08/02 17:10:54 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -393,10 +393,7 @@
* destroy true if the value buffer should be destroyed.
*
* Results:
- * 1 if it is an environment variable 0 ow.
- *
- * Side Effects:
- * The variable is free'ed if it is an environent variable.
+ * TRUE if it is an environment variable, FALSE otherwise.
*-----------------------------------------------------------------------
*/
static Boolean
@@ -410,22 +407,8 @@
return TRUE;
}
-/*-
- *-----------------------------------------------------------------------
- * VarAdd --
- * Add a new variable of name name and value val to the given context
- *
- * Input:
- * name name of variable to add
- * val value to set it to
- * ctxt context in which to set it
- *
- * Side Effects:
- * The new variable is placed at the front of the given context
- * The name and val arguments are duplicated so they may
- * safely be freed.
- *-----------------------------------------------------------------------
- */
+/* Add a new variable of the given name and value to the given context.
+ * The name and val arguments are duplicated so they may safely be freed. */
static void
VarAdd(const char *name, const char *val, GNode *ctxt)
{
@@ -445,16 +428,7 @@
}
}
-/*-
- *-----------------------------------------------------------------------
- * Var_Delete --
- * Remove a variable from a context.
- *
- * Side Effects:
- * The Var structure is removed and freed.
- *
- *-----------------------------------------------------------------------
- */
+/* Remove a variable from a context, freeing the Var structure as well. */
void
Var_Delete(const char *name, GNode *ctxt)
{
@@ -484,7 +458,7 @@
/*
- * Export a var.
+ * Export a variable.
* We ignore make internal variables (those which start with '.')
* Also we jump through some hoops to avoid calling setenv
* more than necessary since it can leak.
@@ -611,9 +585,8 @@
}
/*
- * This is called when .export is seen or
- * .MAKE.EXPORTED is modified.
- * It is also called when any exported var is modified.
+ * This is called when .export is seen or .MAKE.EXPORTED is modified.
+ * It is also called when any exported variable is modified.
*/
void
Var_Export(char *str, int isExport)
@@ -770,6 +743,7 @@
}
}
+/* See Var_Set for documentation. */
static void
Var_Set_with_flags(const char *name, const char *val, GNode *ctxt,
VarSet_Flags flags)
@@ -795,6 +769,7 @@
return;
}
}
+
if (ctxt == VAR_GLOBAL) {
v = VarFind(name, VAR_CMD, 0);
if (v != NULL) {
@@ -807,6 +782,7 @@
VarFreeEnv(v, TRUE);
}
}
+
v = VarFind(name, ctxt, 0);
if (v == NULL) {
if (ctxt == VAR_CMD && !(flags & VAR_NO_EXPORT)) {
@@ -872,8 +848,8 @@
* ctxt context in which to set it
*
* Side Effects:
- * If the variable doesn't yet exist, a new record is created for it.
- * Else the old value is freed and the new one stuck in its place
+ * If the variable doesn't yet exist, it is created.
+ * Otherwise the new value overwrites and replaces the old value.
*
* Notes:
* The variable is searched for only in its context before being
@@ -900,12 +876,12 @@
*
* Input:
* name name of variable to modify
- * val String to append to it
- * ctxt Context in which this should occur
+ * val string to append to it
+ * ctxt context in which this should occur
*
* Side Effects:
- * If the variable doesn't exist, it is created. Else the strings
- * are concatenated (with a space in between).
+ * If the variable doesn't exist, it is created. Otherwise the strings
+ * are concatenated, with a space in between.
*
* Notes:
* Only if the variable is being sought in the global context is the
@@ -1327,16 +1303,7 @@
}
#ifndef NO_REGEX
-/*-
- *-----------------------------------------------------------------------
- * VarREError --
- * Print the error caused by a regcomp or regexec call.
- *
- * Side Effects:
- * An error gets printed.
- *
- *-----------------------------------------------------------------------
- */
+/* Print the error caused by a regcomp or regexec call. */
static void
VarREError(int reerr, regex_t *pat, const char *str)
{
@@ -1503,10 +1470,9 @@
}
/*
- * Now sanitize seldata.
- * If seldata->start or seldata->end are negative, convert them to
- * the positive equivalents (-1 gets converted to argc, -2 gets
- * converted to (argc-1), etc.).
+ * Now sanitize the given range.
+ * If first or last are negative, convert them to the positive equivalents
+ * (-1 gets converted to ac, -2 gets converted to (ac - 1), etc.).
*/
if (first < 0)
first += ac + 1;
@@ -1629,10 +1595,6 @@
*
* Results:
* A string containing the words ordered.
- *
- * Side Effects:
- * None.
- *
*-----------------------------------------------------------------------
*/
static char *
@@ -1742,7 +1704,6 @@
* unescaped ampersands with subst->lhs. */
) {
Buffer buf;
-
Buf_InitZ(&buf, 0);
/*
@@ -1883,23 +1844,8 @@
return str;
}
-/*-
- *-----------------------------------------------------------------------
- * VarHash --
- * Hash the string using the MurmurHash3 algorithm.
- * Output is computed using 32bit Little Endian arithmetic.
- *
- * Input:
- * str String to modify
- *
- * Results:
- * Hash value of str, encoded as 8 hex digits.
- *
- * Side Effects:
- * None.
- *
- *-----------------------------------------------------------------------
- */
+/* Compute the 32-bit hash of the given string, using the MurmurHash3
+ * algorithm. Output is encoded as 8 hex digits, in Little Endian order. */
static char *
VarHash(const char *str)
{
@@ -1996,8 +1942,8 @@
* after the current modifier. */
char missing_delim; /* For error reporting */
- Byte sep; /* Word separator in expansions */
- Boolean oneBigWord; /* TRUE if we will treat the variable as a
+ Byte sep; /* Word separator in expansions */
+ Boolean oneBigWord; /* TRUE if the variable value is treated as a
* single big word, even if it contains
* embedded spaces (as opposed to the
* usual behaviour of treating it as
@@ -2007,13 +1953,13 @@
typedef enum {
AMR_OK, /* Continue parsing */
- AMR_UNKNOWN, /* Not a match, try others as well */
- AMR_BAD, /* Error out with message */
- AMR_CLEANUP /* Error out with "missing delimiter",
+ AMR_UNKNOWN, /* Not a match, try other modifiers as well */
+ AMR_BAD, /* Error out with "Bad modifier" message */
+ AMR_CLEANUP /* Error out, with "Unclosed substitution"
* if st->missing_delim is set. */
} ApplyModifierResult;
-/* we now have some modifiers with long names */
+/* Test whether mod starts with modname, followed by a delimiter. */
static Boolean
ModMatch(const char *mod, const char *modname, char endc)
{
@@ -2022,6 +1968,7 @@
(mod[n] == endc || mod[n] == ':');
}
+/* Test whether mod starts with modname, followed by a delimiter or '='. */
static inline Boolean
ModMatchEq(const char *mod, const char *modname, char endc)
{
@@ -3648,7 +3595,8 @@
* The resulting string.
*
* Side Effects:
- * None.
+ * Any effects from the modifiers, such as ::=, :sh or !cmd!,
+ * if eflags contains VARE_WANTRES.
*-----------------------------------------------------------------------
*/
char *
@@ -3725,16 +3673,8 @@
str += 1;
}
} else {
- /*
- * We've now got a variable structure to store in. But first,
- * advance the string pointer.
- */
str += length;
- /*
- * Copy all the characters from the variable value straight
- * into the new string.
- */
size_t val_len = strlen(val);
Buf_AddBytesZ(&buf, val, val_len);
trailingBslash = val_len > 0 && val[val_len - 1] == '\\';
@@ -3778,12 +3718,7 @@
fprintf(debug_file, "%-16s = %s\n", v->name, Buf_GetAllZ(&v->val, NULL));
}
-/*-
Home |
Main Index |
Thread Index |
Old Index