diff options
-rw-r--r-- | usr.bin/make/var.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/usr.bin/make/var.c b/usr.bin/make/var.c index 48e343658ad..a926758e5f7 100644 --- a/usr.bin/make/var.c +++ b/usr.bin/make/var.c @@ -1,4 +1,4 @@ -/* $OpenBSD: var.c,v 1.95 2014/01/06 12:08:18 espie Exp $ */ +/* $OpenBSD: var.c,v 1.96 2014/01/06 12:15:40 espie Exp $ */ /* $NetBSD: var.c,v 1.18 1997/03/18 19:24:46 christos Exp $ */ /* @@ -995,9 +995,19 @@ Var_Parse(const char *str, /* The string to parse */ } if (val == NULL) { val = err ? var_Error : varNoError; - /* Dynamic source */ + /* If it comes from a dynamic source, and it doesn't have + * a context, copy the spec instead. + * Specifically, this make allows constructs like: + * target.o: $*.c + * Absence of a context means "parsing". But these can't + * be expanded during parsing, to be consistent with the + * way .SUFFIXES work. + * .SUFFIXES may be added/reset/removed during parsing, + * but in the end, the final list is what's considered for + * handling targets. So those dynamic variables must be + * handled lazily too. + */ if (idx != GLOBAL_INDEX) { - /* can't be expanded for now: copy the spec instead. */ if (ctxt == NULL) { *freePtr = true; val = Str_dupi(str, tstr); |