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): reduce indentation in ParseModifierPart
details: https://anonhg.NetBSD.org/src/rev/d057f4f65b49
branches: trunk
changeset: 1012563:d057f4f65b49
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Aug 02 09:36:54 2020 +0000
description:
make(1): reduce indentation in ParseModifierPart
diffstat:
usr.bin/make/var.c | 108 ++++++++++++++++++++++++++--------------------------
1 files changed, 55 insertions(+), 53 deletions(-)
diffs (137 lines):
diff -r b7482927d32b -r d057f4f65b49 usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Aug 02 09:06:32 2020 +0000
+++ b/usr.bin/make/var.c Sun Aug 02 09:36:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.390 2020/08/02 09:06:32 rillig Exp $ */
+/* $NetBSD: var.c,v 1.391 2020/08/02 09:36:54 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.390 2020/08/02 09:06:32 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.391 2020/08/02 09:36:54 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.390 2020/08/02 09:06:32 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.391 2020/08/02 09:36:54 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -1766,58 +1766,60 @@
if (is_escaped) {
Buf_AddByte(&buf, cp[1]);
cp++;
- } else if (*cp == '$') {
- if (cp[1] == delim) { /* Unescaped $ at end of pattern */
- if (out_pflags != NULL)
- *out_pflags |= VARP_ANCHOR_END;
- else
- Buf_AddByte(&buf, *cp);
- } else {
- if (eflags & VARE_WANTRES) {
- const char *cp2;
- int len;
- void *freeIt;
-
- /*
- * If unescaped dollar sign not before the
- * delimiter, assume it's a variable
- * substitution and recurse.
- */
- cp2 = Var_Parse(cp, ctxt, errnum | (eflags & VARE_WANTRES),
- &len, &freeIt);
- Buf_AddStr(&buf, cp2);
- free(freeIt);
- cp += len - 1;
- } else {
- const char *cp2 = &cp[1];
-
- if (*cp2 == PROPEN || *cp2 == BROPEN) {
- /*
- * Find the end of this variable reference
- * and suck it in without further ado.
- * It will be interpreted later.
- */
- int have = *cp2;
- int want = *cp2 == PROPEN ? PRCLOSE : BRCLOSE;
- int depth = 1;
-
- for (++cp2; *cp2 != '\0' && depth > 0; ++cp2) {
- if (cp2[-1] != '\\') {
- if (*cp2 == have)
- ++depth;
- if (*cp2 == want)
- --depth;
- }
- }
- Buf_AddBytesBetween(&buf, cp, cp2);
- cp = --cp2;
- } else
- Buf_AddByte(&buf, *cp);
+ continue;
+ }
+
+ if (*cp != '$') { /* Unescaped, simple text */
+ if (subst != NULL && *cp == '&')
+ Buf_AddBytesZ(&buf, subst->lhs, subst->lhsLen);
+ else
+ Buf_AddByte(&buf, *cp);
+ continue;
+ }
+
+ if (cp[1] == delim) { /* Unescaped $ at end of pattern */
+ if (out_pflags != NULL)
+ *out_pflags |= VARP_ANCHOR_END;
+ else
+ Buf_AddByte(&buf, *cp);
+ continue;
+ }
+
+ if (eflags & VARE_WANTRES) { /* Nested variable, evaluated */
+ const char *cp2;
+ int len;
+ void *freeIt;
+
+ cp2 = Var_Parse(cp, ctxt, errnum | (eflags & VARE_WANTRES),
+ &len, &freeIt);
+ Buf_AddStr(&buf, cp2);
+ free(freeIt);
+ cp += len - 1;
+ continue;
+ }
+
+ const char *cp2 = &cp[1]; /* Nested variable, only parsed */
+ if (*cp2 == PROPEN || *cp2 == BROPEN) {
+ /*
+ * Find the end of this variable reference
+ * and suck it in without further ado.
+ * It will be interpreted later.
+ */
+ int have = *cp2;
+ int want = *cp2 == PROPEN ? PRCLOSE : BRCLOSE;
+ int depth = 1;
+
+ for (++cp2; *cp2 != '\0' && depth > 0; ++cp2) {
+ if (cp2[-1] != '\\') {
+ if (*cp2 == have)
+ ++depth;
+ if (*cp2 == want)
+ --depth;
}
}
- } else if (subst != NULL && *cp == '&')
- Buf_AddBytesZ(&buf, subst->lhs, subst->lhsLen);
- else
+ Buf_AddBytesBetween(&buf, cp, cp2);
+ cp = --cp2;
+ } else
Buf_AddByte(&buf, *cp);
}
Home |
Main Index |
Thread Index |
Old Index