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): rename VarGetPattern to ParseModifierPart
details: https://anonhg.NetBSD.org/src/rev/2897d108ca6c
branches: trunk
changeset: 973973:2897d108ca6c
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Jul 19 16:08:24 2020 +0000
description:
make(1): rename VarGetPattern to ParseModifierPart
diffstat:
usr.bin/make/unit-tests/varmod-edge.mk | 6 +-
usr.bin/make/var.c | 73 +++++++++++++++------------------
2 files changed, 36 insertions(+), 43 deletions(-)
diffs (222 lines):
diff -r 0980da8de5e0 -r 2897d108ca6c usr.bin/make/unit-tests/varmod-edge.mk
--- a/usr.bin/make/unit-tests/varmod-edge.mk Sun Jul 19 15:51:51 2020 +0000
+++ b/usr.bin/make/unit-tests/varmod-edge.mk Sun Jul 19 16:08:24 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: varmod-edge.mk,v 1.7 2020/04/27 14:07:22 christos Exp $
+# $NetBSD: varmod-edge.mk,v 1.8 2020/07/19 16:08:24 rillig Exp $
#
# Tests for edge cases in variable modifiers.
#
@@ -143,8 +143,8 @@
MOD.eq-bs= ${INP.eq-bs:%.c\=%.o=%.ext}
EXP.eq-bs= file.c file.ext
-# Having only an escaped = results in a parse error.
-# The call to "pattern.lhs = VarGetPattern" fails.
+# Having only an escaped '=' results in a parse error.
+# The call to "pattern.lhs = ParseModifierPart" fails.
TESTS+= eq-esc
INP.eq-esc= file.c file...
MOD.eq-esc= ${INP.eq-esc:a\=b}
diff -r 0980da8de5e0 -r 2897d108ca6c usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Jul 19 15:51:51 2020 +0000
+++ b/usr.bin/make/var.c Sun Jul 19 16:08:24 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.264 2020/07/19 15:51:51 rillig Exp $ */
+/* $NetBSD: var.c,v 1.265 2020/07/19 16:08:24 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.264 2020/07/19 15:51:51 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.265 2020/07/19 16:08:24 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.264 2020/07/19 15:51:51 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.265 2020/07/19 16:08:24 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -243,9 +243,9 @@
VARP_MATCH_START = 0x08, /* Match at start of word */
VARP_MATCH_END = 0x10, /* Match at end of word */
- /* FIXME: This constant doesn't belong here. It is not related to
- * pattern matching, and VarGetPattern is badly named as well. */
- VAR_NOSUBST = 0x20 /* don't expand vars in VarGetPattern */
+ /* FIXME: This constant doesn't belong here.
+ * It is not related to pattern matching. */
+ VAR_NOSUBST = 0x20 /* don't expand vars in ParseModifierPart */
} VarPatternFlags;
typedef enum {
@@ -2023,30 +2023,23 @@
/*-
- *-----------------------------------------------------------------------
- * VarGetPattern --
- * During the parsing of a part of a modifier such as :S or :@,
- * pass through the tstr looking for 1) escaped delimiters,
- * '$'s and backslashes (place the escaped character in
- * uninterpreted) and 2) unescaped $'s that aren't before
- * the delimiter (expand the variable substitution unless flags
- * has VAR_NOSUBST set).
- * Return the expanded string or NULL if the delimiter was missing
- * If pattern is specified, handle escaped ampersands, and replace
- * unescaped ampersands with the lhs of the pattern.
+ * Parse a text part of a modifier such as the "from" and "to" in :S/from/to/
+ * or the :@ modifier. Nested variables in the text are expanded unless
+ * VAR_NOSUBST is set.
+ *
+ * The text part is parsed until the next delimiter. To escape the delimiter,
+ * a backslash or a dollar, put a backslash before it.
*
- * Results:
- * A string of all the words modified appropriately.
- * If length is specified, return the string length of the buffer
- * If flags is specified and the last character of the pattern is a
- * $ set the VAR_MATCH_END bit of flags.
+ * Return the expanded string or NULL if the delimiter was missing.
+ * If pattern is specified, handle escaped ampersands and replace unescaped
+ * ampersands with the lhs of the pattern (for the :S and :C modifiers).
*
- * Side Effects:
- * None.
- *-----------------------------------------------------------------------
+ * If length is specified, return the string length of the buffer.
+ * If mpflags is specified and the last character of the pattern is a $,
+ * set the VARP_MATCH_END bit of mpflags.
*/
static char *
-VarGetPattern(GNode *ctxt, Var_Parse_State *vpstate MAKE_ATTR_UNUSED,
+ParseModifierPart(GNode *ctxt, Var_Parse_State *vpstate MAKE_ATTR_UNUSED,
VarEvalFlags eflags, const char **tstr, int delim,
VarPatternFlags *mpflags, int *length, VarPattern *pattern)
{
@@ -2324,13 +2317,13 @@
st->cp = ++st->tstr;
st->delim = '@';
- loop.tvar = VarGetPattern(
+ loop.tvar = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&pflags, &loop.tvarLen, NULL);
if (loop.tvar == NULL)
return FALSE;
- loop.str = VarGetPattern(
+ loop.str = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&pflags, &loop.strLen, NULL);
if (loop.str == NULL)
@@ -2506,7 +2499,7 @@
st->delim = '!';
emsg = NULL;
st->cp = ++st->tstr;
- pattern.rhs = VarGetPattern(
+ pattern.rhs = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
NULL, &pattern.rightLen, NULL);
if (pattern.rhs == NULL)
@@ -2658,13 +2651,13 @@
}
st->cp = st->tstr;
- pattern.lhs = VarGetPattern(
+ pattern.lhs = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&pattern.pflags, &pattern.leftLen, NULL);
if (pattern.lhs == NULL)
return FALSE;
- pattern.rhs = VarGetPattern(
+ pattern.rhs = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
NULL, &pattern.rightLen, &pattern);
if (pattern.rhs == NULL)
@@ -2718,13 +2711,13 @@
st->cp = st->tstr;
- re = VarGetPattern(
+ re = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
NULL, NULL, NULL);
if (re == NULL)
return FALSE;
- pattern.replace = VarGetPattern(
+ pattern.replace = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
NULL, NULL, NULL);
if (pattern.replace == NULL) {
@@ -2900,7 +2893,7 @@
st->cp = st->tstr + 1; /* point to char after '[' */
st->delim = ']'; /* look for closing ']' */
- estr = VarGetPattern(
+ estr = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
NULL, NULL, NULL);
if (estr == NULL)
@@ -3063,7 +3056,7 @@
st->cp = ++st->tstr;
st->delim = ':';
- char *then_expr = VarGetPattern(
+ char *then_expr = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&then_flags, NULL, NULL);
if (then_expr == NULL)
@@ -3071,7 +3064,7 @@
/* BROPEN or PROPEN */
st->delim = st->endc;
- char *else_expr = VarGetPattern(
+ char *else_expr = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&else_flags, NULL, NULL);
if (else_expr == NULL)
@@ -3121,7 +3114,7 @@
if (st->v->flags & VAR_JUNK) {
/*
* We need to bmake_strdup() it incase
- * VarGetPattern() recurses.
+ * ParseModifierPart() recurses.
*/
sv_name = st->v->name;
st->v->name = bmake_strdup(st->v->name);
@@ -3147,7 +3140,7 @@
pattern.pflags = 0;
pflags = (st->flags & VARE_WANTRES) ? 0 : VAR_NOSUBST;
- pattern.rhs = VarGetPattern(
+ pattern.rhs = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&pflags, &pattern.rightLen, NULL);
if (st->v->flags & VAR_JUNK) {
@@ -3258,14 +3251,14 @@
/* FIXME: There's no point in having a single $ at the end of a
* SysV substitution since that will not be interpreted as an
* anchor anyway. */
- pattern.lhs = VarGetPattern(
+ pattern.lhs = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
&pattern.pflags, &pattern.leftLen, NULL);
if (pattern.lhs == NULL)
return 'c';
st->delim = st->endc;
- pattern.rhs = VarGetPattern(
+ pattern.rhs = ParseModifierPart(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
NULL, &pattern.rightLen, &pattern);
if (pattern.rhs == NULL)
Home |
Main Index |
Thread Index |
Old Index