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 flags for :S and :C pattern mat...
details: https://anonhg.NetBSD.org/src/rev/6928e2ba7d82
branches: trunk
changeset: 973959:6928e2ba7d82
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Jul 19 13:21:56 2020 +0000
description:
make(1): rename flags for :S and :C pattern matching
Renaming these flags makes it obvious that VarPattern is used in a few
places where it doesn't belong. These will be fixed in follow-up
commits.
diffstat:
usr.bin/make/var.c | 129 ++++++++++++++++++++++++++++------------------------
1 files changed, 70 insertions(+), 59 deletions(-)
diffs (truncated from 389 to 300 lines):
diff -r 5d913bb93b4e -r 6928e2ba7d82 usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Jul 19 12:51:06 2020 +0000
+++ b/usr.bin/make/var.c Sun Jul 19 13:21:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.260 2020/07/19 12:51:06 rillig Exp $ */
+/* $NetBSD: var.c,v 1.261 2020/07/19 13:21:56 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.260 2020/07/19 12:51:06 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.261 2020/07/19 13:21:56 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.260 2020/07/19 12:51:06 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.261 2020/07/19 13:21:56 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -235,14 +235,18 @@
*/
#define VAR_EXPORT_LITERAL 2
+/* Flags for pattern matching in the :S and :C modifiers */
typedef enum {
- VAR_SUB_GLOBAL = 0x01, /* Apply substitution globally */
- VAR_SUB_ONE = 0x02, /* Apply substitution to one word */
- VAR_SUB_MATCHED = 0x04, /* There was a match */
- VAR_MATCH_START = 0x08, /* Match at start of word */
- VAR_MATCH_END = 0x10, /* Match at end of word */
- VAR_NOSUBST = 0x20 /* don't expand vars in VarGetPattern */
-} VarPattern_Flags;
+ VARP_SUB_GLOBAL = 0x01, /* Apply substitution globally */
+ VARP_SUB_ONE = 0x02, /* Apply substitution to one word */
+ VARP_SUB_MATCHED = 0x04, /* There was a match */
+ 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 */
+} VarPatternFlags;
typedef enum {
VAR_NO_EXPORT = 0x01 /* do not export */
@@ -269,7 +273,7 @@
int leftLen; /* Length of string */
const char *rhs; /* Replacement string (w/ &'s removed) */
int rightLen; /* Length of replacement */
- VarPattern_Flags flags;
+ VarPatternFlags pflags;
} VarPattern;
/* struct passed as 'void *' to VarLoopExpand() for ":@tvar@str@" */
@@ -289,7 +293,7 @@
int nsub;
regmatch_t *matches;
char *replace;
- int flags;
+ VarPatternFlags pflags;
} VarREPattern;
#endif
@@ -1360,18 +1364,18 @@
const char *cp; /* General pointer */
VarPattern *pattern = data;
- if ((pattern->flags & (VAR_SUB_ONE|VAR_SUB_MATCHED)) !=
- (VAR_SUB_ONE|VAR_SUB_MATCHED)) {
+ if ((pattern->pflags & (VARP_SUB_ONE | VARP_SUB_MATCHED)) !=
+ (VARP_SUB_ONE | VARP_SUB_MATCHED)) {
/*
* Still substituting -- break it down into simple anchored cases
* and if none of them fits, perform the general substitution case.
*/
- if ((pattern->flags & VAR_MATCH_START) &&
+ if ((pattern->pflags & VARP_MATCH_START) &&
(strncmp(word, pattern->lhs, pattern->leftLen) == 0)) {
/*
* Anchored at start and beginning of word matches pattern
*/
- if ((pattern->flags & VAR_MATCH_END) &&
+ if ((pattern->pflags & VARP_MATCH_END) &&
(wordLen == pattern->leftLen)) {
/*
* Also anchored at end and matches to the end (word
@@ -1385,8 +1389,8 @@
addSpace = TRUE;
Buf_AddBytes(buf, pattern->rightLen, pattern->rhs);
}
- pattern->flags |= VAR_SUB_MATCHED;
- } else if (pattern->flags & VAR_MATCH_END) {
+ pattern->pflags |= VARP_SUB_MATCHED;
+ } else if (pattern->pflags & VARP_MATCH_END) {
/*
* Doesn't match to end -- copy word wholesale
*/
@@ -1404,14 +1408,14 @@
Buf_AddBytes(buf, pattern->rightLen, pattern->rhs);
Buf_AddBytes(buf, wordLen - pattern->leftLen,
(word + pattern->leftLen));
- pattern->flags |= VAR_SUB_MATCHED;
+ pattern->pflags |= VARP_SUB_MATCHED;
}
- } else if (pattern->flags & VAR_MATCH_START) {
+ } else if (pattern->pflags & VARP_MATCH_START) {
/*
* Had to match at start of word and didn't -- copy whole word.
*/
goto nosub;
- } else if (pattern->flags & VAR_MATCH_END) {
+ } else if (pattern->pflags & VARP_MATCH_END) {
/*
* Anchored at end, Find only place match could occur (leftLen
* characters from the end of the word) and see if it does. Note
@@ -1435,7 +1439,7 @@
}
Buf_AddBytes(buf, cp - word, word);
Buf_AddBytes(buf, pattern->rightLen, pattern->rhs);
- pattern->flags |= VAR_SUB_MATCHED;
+ pattern->pflags |= VARP_SUB_MATCHED;
} else {
/*
* Had to match at end and didn't. Copy entire word.
@@ -1473,10 +1477,10 @@
if (wordLen == 0) {
done = TRUE;
}
- if ((pattern->flags & VAR_SUB_GLOBAL) == 0) {
+ if ((pattern->pflags & VARP_SUB_GLOBAL) == 0) {
done = TRUE;
}
- pattern->flags |= VAR_SUB_MATCHED;
+ pattern->pflags |= VARP_SUB_MATCHED;
} else {
done = TRUE;
}
@@ -1548,8 +1552,8 @@
Buf_AddByte(buf, ' '); \
added = 1
- if ((pat->flags & (VAR_SUB_ONE|VAR_SUB_MATCHED)) ==
- (VAR_SUB_ONE|VAR_SUB_MATCHED))
+ if ((pat->pflags & (VARP_SUB_ONE | VARP_SUB_MATCHED)) ==
+ (VARP_SUB_ONE | VARP_SUB_MATCHED))
xrv = REG_NOMATCH;
else {
tryagain:
@@ -1558,7 +1562,7 @@
switch (xrv) {
case 0:
- pat->flags |= VAR_SUB_MATCHED;
+ pat->pflags |= VARP_SUB_MATCHED;
if (pat->matches[0].rm_so > 0) {
MAYBE_ADD_SPACE();
Buf_AddBytes(buf, pat->matches[0].rm_so, wp);
@@ -1612,7 +1616,7 @@
}
}
wp += pat->matches[0].rm_eo;
- if (pat->flags & VAR_SUB_GLOBAL) {
+ if (pat->pflags & VARP_SUB_GLOBAL) {
flags |= REG_NOTBOL;
if (pat->matches[0].rm_so == 0 && pat->matches[0].rm_eo == 0) {
MAYBE_ADD_SPACE();
@@ -2043,14 +2047,14 @@
*/
static char *
VarGetPattern(GNode *ctxt, Var_Parse_State *vpstate MAKE_ATTR_UNUSED,
- VarPattern_Flags flags, const char **tstr, int delim,
- VarPattern_Flags *vflags, int *length, VarPattern *pattern)
+ VarEvalFlags eflags, const char **tstr, int delim,
+ VarPatternFlags *mpflags, int *length, VarPattern *pattern)
{
const char *cp;
char *rstr;
Buffer buf;
int junk;
- int errnum = flags & VARE_UNDEFERR;
+ VarEvalFlags errnum = eflags & VARE_UNDEFERR;
Buf_Init(&buf, 0);
if (length == NULL)
@@ -2072,16 +2076,17 @@
cp++;
} else if (*cp == '$') {
if (cp[1] == delim) {
- if (vflags == NULL)
+ if (mpflags == NULL)
Buf_AddByte(&buf, *cp);
else
/*
* Unescaped $ at end of pattern => anchor
* pattern at end.
*/
- *vflags |= VAR_MATCH_END;
+ *mpflags |= VARP_MATCH_END;
} else {
- if (vflags == NULL || (*vflags & VAR_NOSUBST) == 0) {
+ /* FIXME: mismatch between mpflags and VAR_NOSUBST */
+ if (mpflags == NULL || !(*mpflags & VAR_NOSUBST)) {
char *cp2;
int len;
void *freeIt;
@@ -2091,7 +2096,7 @@
* delimiter, assume it's a variable
* substitution and recurse.
*/
- cp2 = Var_Parse(cp, ctxt, errnum | (flags & VARE_WANTRES),
+ cp2 = Var_Parse(cp, ctxt, errnum | (eflags & VARE_WANTRES),
&len, &freeIt);
Buf_AddBytes(&buf, strlen(cp2), cp2);
free(freeIt);
@@ -2319,19 +2324,19 @@
static Boolean
ApplyModifier_At(ApplyModifiersState *st) {
VarLoop loop;
- VarPattern_Flags vflags = VAR_NOSUBST;
-
- st->cp = ++(st->tstr);
+ VarPatternFlags pflags = VAR_NOSUBST; /* FIXME: mismatch between pflags and VAR_NOSUBST */
+
+ st->cp = ++st->tstr;
st->delim = '@';
loop.tvar = VarGetPattern(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
- &vflags, &loop.tvarLen, NULL);
+ &pflags, &loop.tvarLen, NULL);
if (loop.tvar == NULL)
return FALSE;
loop.str = VarGetPattern(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
- &vflags, &loop.strLen, NULL);
+ &pflags, &loop.strLen, NULL);
if (loop.str == NULL)
return FALSE;
@@ -2500,7 +2505,7 @@
const char *emsg;
VarPattern pattern;
- pattern.flags = 0;
+ pattern.pflags = 0;
st->delim = '!';
emsg = NULL;
@@ -2642,7 +2647,7 @@
VarPattern pattern;
Var_Parse_State tmpparsestate;
- pattern.flags = 0;
+ pattern.pflags = 0;
tmpparsestate = st->parsestate;
st->delim = st->tstr[1];
st->tstr += 2;
@@ -2652,14 +2657,14 @@
* start of the word -- skip over it and flag pattern.
*/
if (*st->tstr == '^') {
- pattern.flags |= VAR_MATCH_START;
- st->tstr += 1;
+ pattern.pflags |= VARP_MATCH_START;
+ st->tstr++;
}
st->cp = st->tstr;
pattern.lhs = VarGetPattern(
st->ctxt, &st->parsestate, st->flags, &st->cp, st->delim,
- &pattern.flags, &pattern.leftLen, NULL);
+ &pattern.pflags, &pattern.leftLen, NULL);
if (pattern.lhs == NULL)
return FALSE;
@@ -2677,10 +2682,10 @@
for (;; st->cp++) {
switch (*st->cp) {
case 'g':
- pattern.flags |= VAR_SUB_GLOBAL;
+ pattern.pflags |= VARP_SUB_GLOBAL;
continue;
case '1':
- pattern.flags |= VAR_SUB_ONE;
+ pattern.pflags |= VARP_SUB_ONE;
continue;
case 'W':
tmpparsestate.oneBigWord = TRUE;
@@ -2710,7 +2715,7 @@
int error;
Var_Parse_State tmpparsestate;
- pattern.flags = 0;
Home |
Main Index |
Thread Index |
Old Index