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: do not evaluate modifiers ':M' and ':N' i...
details: https://anonhg.NetBSD.org/src/rev/a9e3a6cd8ddf
branches: trunk
changeset: 981552:a9e3a6cd8ddf
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Mar 14 19:25:05 2021 +0000
description:
make: do not evaluate modifiers ':M' and ':N' in parse-only mode
No functional change outside debug mode (-dv for ModifyWord_Match).
diffstat:
usr.bin/make/var.c | 15 +++++++++------
1 files changed, 9 insertions(+), 6 deletions(-)
diffs (40 lines):
diff -r d779746e56b6 -r a9e3a6cd8ddf usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Mar 14 19:21:28 2021 +0000
+++ b/usr.bin/make/var.c Sun Mar 14 19:25:05 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.875 2021/03/14 19:21:28 rillig Exp $ */
+/* $NetBSD: var.c,v 1.876 2021/03/14 19:25:05 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.875 2021/03/14 19:21:28 rillig Exp $");
+MAKE_RCSID("$NetBSD: var.c,v 1.876 2021/03/14 19:25:05 rillig Exp $");
typedef enum VarFlags {
VFL_NONE = 0,
@@ -2811,14 +2811,17 @@
static ApplyModifierResult
ApplyModifier_Match(const char **pp, ApplyModifiersState *st)
{
- const char *mod = *pp;
+ const char mod = **pp;
char *pattern;
- ModifyWordProc modifyWord;
ParseModifier_Match(pp, st, &pattern);
- modifyWord = mod[0] == 'M' ? ModifyWord_Match : ModifyWord_NoMatch;
- ModifyWords(st, modifyWord, pattern, st->oneBigWord);
+ if (st->expr->eflags & VARE_WANTRES) {
+ ModifyWordProc modifyWord =
+ mod == 'M' ? ModifyWord_Match : ModifyWord_NoMatch;
+ ModifyWords(st, modifyWord, pattern, st->oneBigWord);
+ }
+
free(pattern);
return AMR_OK;
}
Home |
Main Index |
Thread Index |
Old Index