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: extract ParseDependencySources from Parse...
details: https://anonhg.NetBSD.org/src/rev/fd376f0ec27b
branches: trunk
changeset: 1021862:fd376f0ec27b
user: rillig <rillig%NetBSD.org@localhost>
date: Mon Jun 21 10:29:08 2021 +0000
description:
make: extract ParseDependencySources from ParseDependency
No functional change.
diffstat:
usr.bin/make/parse.c | 112 +++++++++++++++++++++++++++-----------------------
1 files changed, 61 insertions(+), 51 deletions(-)
diffs (147 lines):
diff -r 0753e5e2d691 -r fd376f0ec27b usr.bin/make/parse.c
--- a/usr.bin/make/parse.c Mon Jun 21 08:40:44 2021 +0000
+++ b/usr.bin/make/parse.c Mon Jun 21 10:29:08 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: parse.c,v 1.557 2021/04/04 11:56:43 rillig Exp $ */
+/* $NetBSD: parse.c,v 1.558 2021/06/21 10:29:08 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -109,7 +109,7 @@
#include "pathnames.h"
/* "@(#)parse.c 8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: parse.c,v 1.557 2021/04/04 11:56:43 rillig Exp $");
+MAKE_RCSID("$NetBSD: parse.c,v 1.558 2021/06/21 10:29:08 rillig Exp $");
/* types and constants */
@@ -1303,6 +1303,15 @@
Dir_SetPATH();
}
+/*
+ * Several special targets take different actions if present with no
+ * sources:
+ * a .SUFFIXES line with no sources clears out all old suffixes
+ * a .PRECIOUS line makes all targets precious
+ * a .IGNORE line ignores errors for all targets
+ * a .SILENT line creates silence when making all targets
+ * a .PATH removes all directories from the search path(s).
+ */
static void
ParseDependencySourcesEmpty(ParseSpecial specType, SearchPathList *paths)
{
@@ -1574,6 +1583,55 @@
return true;
}
+/* In a dependency line like 'targets: sources', parse the sources. */
+static void
+ParseDependencySources(char *const line, char *const cp,
+ GNodeType const tOp,
+ ParseSpecial const specType,
+ SearchPathList ** inout_paths)
+{
+ if (line[0] == '\0') {
+ ParseDependencySourcesEmpty(specType, *inout_paths);
+ } else if (specType == SP_MFLAGS) {
+ Main_ParseArgLine(line);
+ /*
+ * Set the initial character to a null-character so the loop
+ * to get sources won't get anything.
+ */
+ *line = '\0';
+ } else if (specType == SP_SHELL) {
+ if (!Job_ParseShell(line)) {
+ Parse_Error(PARSE_FATAL,
+ "improper shell specification");
+ return;
+ }
+ *line = '\0';
+ } else if (specType == SP_NOTPARALLEL || specType == SP_SINGLESHELL ||
+ specType == SP_DELETE_ON_ERROR) {
+ *line = '\0';
+ }
+
+ /* Now go for the sources. */
+ if (specType == SP_SUFFIXES || specType == SP_PATH ||
+ specType == SP_INCLUDES || specType == SP_LIBS ||
+ specType == SP_NULL || specType == SP_OBJDIR) {
+ ParseDependencySourcesSpecial(line, cp, specType,
+ *inout_paths);
+ if (*inout_paths != NULL) {
+ Lst_Free(*inout_paths);
+ *inout_paths = NULL;
+ }
+ if (specType == SP_PATH)
+ Dir_SetPATH();
+ } else {
+ assert(*inout_paths == NULL);
+ if (!ParseDependencySourcesMundane(line, cp, specType, tOp))
+ return;
+ }
+
+ FindMainTarget();
+}
+
/*
* Parse a dependency line consisting of targets, followed by a dependency
* operator, optionally followed by sources.
@@ -1665,55 +1723,7 @@
pp_skip_whitespace(&cp);
line = cp; /* XXX: 'line' is an inappropriate name */
- /*
- * Several special targets take different actions if present with no
- * sources:
- * a .SUFFIXES line with no sources clears out all old suffixes
- * a .PRECIOUS line makes all targets precious
- * a .IGNORE line ignores errors for all targets
- * a .SILENT line creates silence when making all targets
- * a .PATH removes all directories from the search path(s).
- */
- if (line[0] == '\0') {
- ParseDependencySourcesEmpty(specType, paths);
- } else if (specType == SP_MFLAGS) {
- /*
- * Call on functions in main.c to deal with these arguments and
- * set the initial character to a null-character so the loop to
- * get sources won't get anything
- */
- Main_ParseArgLine(line);
- *line = '\0';
- } else if (specType == SP_SHELL) {
- if (!Job_ParseShell(line)) {
- Parse_Error(PARSE_FATAL,
- "improper shell specification");
- goto out;
- }
- *line = '\0';
- } else if (specType == SP_NOTPARALLEL || specType == SP_SINGLESHELL ||
- specType == SP_DELETE_ON_ERROR) {
- *line = '\0';
- }
-
- /* Now go for the sources. */
- if (specType == SP_SUFFIXES || specType == SP_PATH ||
- specType == SP_INCLUDES || specType == SP_LIBS ||
- specType == SP_NULL || specType == SP_OBJDIR) {
- ParseDependencySourcesSpecial(line, cp, specType, paths);
- if (paths != NULL) {
- Lst_Free(paths);
- paths = NULL;
- }
- if (specType == SP_PATH)
- Dir_SetPATH();
- } else {
- assert(paths == NULL);
- if (!ParseDependencySourcesMundane(line, cp, specType, tOp))
- goto out;
- }
-
- FindMainTarget();
+ ParseDependencySources(line, cp, tOp, specType, &paths);
out:
if (paths != NULL)
Home |
Main Index |
Thread Index |
Old Index