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): extract CanonicalVarname from VarFind
details: https://anonhg.NetBSD.org/src/rev/331fa06b7e7d
branches: trunk
changeset: 977339:331fa06b7e7d
user: rillig <rillig%NetBSD.org@localhost>
date: Thu Oct 22 05:35:21 2020 +0000
description:
make(1): extract CanonicalVarname from VarFind
diffstat:
usr.bin/make/var.c | 92 ++++++++++++++++++++++++++++-------------------------
1 files changed, 48 insertions(+), 44 deletions(-)
diffs (120 lines):
diff -r e26a68d865be -r 331fa06b7e7d usr.bin/make/var.c
--- a/usr.bin/make/var.c Thu Oct 22 03:05:17 2020 +0000
+++ b/usr.bin/make/var.c Thu Oct 22 05:35:21 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.579 2020/10/20 23:15:23 rillig Exp $ */
+/* $NetBSD: var.c,v 1.580 2020/10/22 05:35:21 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -121,7 +121,7 @@
#include "metachar.h"
/* "@(#)var.c 8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: var.c,v 1.579 2020/10/20 23:15:23 rillig Exp $");
+MAKE_RCSID("$NetBSD: var.c,v 1.580 2020/10/22 05:35:21 rillig Exp $");
#define VAR_DEBUG1(fmt, arg1) DEBUG1(VAR, fmt, arg1)
#define VAR_DEBUG2(fmt, arg1, arg2) DEBUG2(VAR, fmt, arg1, arg2)
@@ -286,6 +286,51 @@
return var;
}
+static const char *
+CanonicalVarname(const char *name)
+{
+ if (*name == '.' && ch_isupper(name[1])) {
+ switch (name[1]) {
+ case 'A':
+ if (strcmp(name, ".ALLSRC") == 0)
+ name = ALLSRC;
+ if (strcmp(name, ".ARCHIVE") == 0)
+ name = ARCHIVE;
+ break;
+ case 'I':
+ if (strcmp(name, ".IMPSRC") == 0)
+ name = IMPSRC;
+ break;
+ case 'M':
+ if (strcmp(name, ".MEMBER") == 0)
+ name = MEMBER;
+ break;
+ case 'O':
+ if (strcmp(name, ".OODATE") == 0)
+ name = OODATE;
+ break;
+ case 'P':
+ if (strcmp(name, ".PREFIX") == 0)
+ name = PREFIX;
+ break;
+ case 'S':
+ if (strcmp(name, ".SHELL") == 0) {
+ if (!shellPath)
+ Shell_Init();
+ }
+ break;
+ case 'T':
+ if (strcmp(name, ".TARGET") == 0)
+ name = TARGET;
+ break;
+ }
+ }
+
+ /* GNU make has an additional alias $^ == ${.ALLSRC}. */
+
+ return name;
+}
+
/*-
*-----------------------------------------------------------------------
* VarFind --
@@ -315,48 +360,7 @@
* and substitute the short version in for 'name' if it matches one of
* them.
*/
- if (*name == '.' && ch_isupper(name[1])) {
- switch (name[1]) {
- case 'A':
- if (strcmp(name, ".ALLSRC") == 0)
- name = ALLSRC;
- if (strcmp(name, ".ARCHIVE") == 0)
- name = ARCHIVE;
- break;
- case 'I':
- if (strcmp(name, ".IMPSRC") == 0)
- name = IMPSRC;
- break;
- case 'M':
- if (strcmp(name, ".MEMBER") == 0)
- name = MEMBER;
- break;
- case 'O':
- if (strcmp(name, ".OODATE") == 0)
- name = OODATE;
- break;
- case 'P':
- if (strcmp(name, ".PREFIX") == 0)
- name = PREFIX;
- break;
- case 'S':
- if (strcmp(name, ".SHELL") == 0 ) {
- if (!shellPath)
- Shell_Init();
- }
- break;
- case 'T':
- if (strcmp(name, ".TARGET") == 0)
- name = TARGET;
- break;
- }
- }
-
-#if 0
- /* for compatibility with gmake */
- if (name[0] == '^' && name[1] == '\0')
- name = ALLSRC;
-#endif
+ name = CanonicalVarname(name);
/*
* First look for the variable in the given context. If it's not there,
Home |
Main Index |
Thread Index |
Old Index