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: improve documentation of ApplyModifiersState
details: https://anonhg.NetBSD.org/src/rev/a7d440f28d31
branches: trunk
changeset: 981584:a7d440f28d31
user: rillig <rillig%NetBSD.org@localhost>
date: Mon Mar 15 19:15:04 2021 +0000
description:
make: improve documentation of ApplyModifiersState
No functional change.
diffstat:
usr.bin/make/unit-tests/var-op-assign.mk | 4 ++--
usr.bin/make/var.c | 23 +++++++++++++----------
2 files changed, 15 insertions(+), 12 deletions(-)
diffs (65 lines):
diff -r ea77c12cfbc2 -r a7d440f28d31 usr.bin/make/unit-tests/var-op-assign.mk
--- a/usr.bin/make/unit-tests/var-op-assign.mk Mon Mar 15 19:02:57 2021 +0000
+++ b/usr.bin/make/unit-tests/var-op-assign.mk Mon Mar 15 19:15:04 2021 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: var-op-assign.mk,v 1.7 2020/11/15 20:20:58 rillig Exp $
+# $NetBSD: var-op-assign.mk,v 1.8 2021/03/15 19:15:04 rillig Exp $
#
# Tests for the = variable assignment operator, which overwrites an existing
# variable or creates it.
@@ -42,7 +42,7 @@
# This alone would not produce any side-effects, therefore the variable has
# a :!...! modifier that executes a shell command. The :!...! modifier turns
# an undefined expression into a defined one, see ApplyModifier_ShellCommand,
-# the call to ApplyModifiersState_Define.
+# the call to Expr_Define.
#
# Since the right-hand side of a '=' assignment is not expanded at the time
# when the variable is defined, the first command is not run at all.
diff -r ea77c12cfbc2 -r a7d440f28d31 usr.bin/make/var.c
--- a/usr.bin/make/var.c Mon Mar 15 19:02:57 2021 +0000
+++ b/usr.bin/make/var.c Mon Mar 15 19:15:04 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.889 2021/03/15 19:02:57 rillig Exp $ */
+/* $NetBSD: var.c,v 1.890 2021/03/15 19:15:04 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -140,7 +140,7 @@
#include "metachar.h"
/* "@(#)var.c 8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: var.c,v 1.889 2021/03/15 19:02:57 rillig Exp $");
+MAKE_RCSID("$NetBSD: var.c,v 1.890 2021/03/15 19:15:04 rillig Exp $");
typedef enum VarFlags {
VFL_NONE = 0,
@@ -2059,17 +2059,20 @@
} Expr;
/*
- * Data that is used when applying a chain of modifiers to an expression.
- * For indirect modifiers, the effects of this data stop after the indirect
- * modifiers have been applied.
+ * The status of applying a chain of modifiers to an expression.
*
- * For example, the expression ${VAR:M*:${indirect}:O:u} has 3 chains of
+ * The modifiers of an expression are broken into chains of modifiers,
+ * starting a new chain whenever an indirect modifier starts or ends.
+ *
+ * For example, the expression ${VAR:M*:${IND1}:${IND2}:O:u} has 4 chains of
* modifiers:
*
- * Chain 1 is ':M', consisting of a single modifier.
- * Chain 2 is whatever modifiers are in the value of the variable named
- * 'indirect'.
- * Chain 3 is ':O:u', consisting of the 2 modifiers ':O' and ':u'.
+ * Chain 1 is ':M*', consisting of the single modifier ':M*'.
+ * Chain 2 is all modifiers from the value of the variable named 'IND1'.
+ * Chain 3 is all modifiers from the value of the variable named 'IND2'.
+ * Chain 4 is ':O:u', consisting of the 2 modifiers ':O' and ':u'.
+ *
+ * After such a chain has finished, its properties no longer have any effect.
*
* It may or may not have been intended that 'defined' has scope Expr while
* 'sep' and 'oneBigWord' have smaller scope.
Home |
Main Index |
Thread Index |
Old Index