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): clean up ParseReadLine
details:   https://anonhg.NetBSD.org/src/rev/b158290ef15f
branches:  trunk
changeset: 947525:b158290ef15f
user:      rillig <rillig%NetBSD.org@localhost>
date:      Mon Dec 14 23:48:03 2020 +0000
description:
make(1): clean up ParseReadLine
In function names, the word "get" was not used consistently to look up
or compute data, in several cases "get" was a synonym for "read", just
like in the standard C library (fgetc).
The really confusing part is that there are two functions now, called
ParseGetLine and ParseReadLine, and both were underdocumented.
diffstat:
 usr.bin/make/parse.c |  26 ++++++++++++++------------
 1 files changed, 14 insertions(+), 12 deletions(-)
diffs (57 lines):
diff -r 1c946ece04e7 -r b158290ef15f usr.bin/make/parse.c
--- a/usr.bin/make/parse.c      Mon Dec 14 23:12:12 2020 +0000
+++ b/usr.bin/make/parse.c      Mon Dec 14 23:48:03 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: parse.c,v 1.481 2020/12/13 21:27:45 rillig Exp $       */
+/*     $NetBSD: parse.c,v 1.482 2020/12/14 23:48:03 rillig Exp $       */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -117,7 +117,7 @@
 #include "pathnames.h"
 
 /*     "@(#)parse.c    8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: parse.c,v 1.481 2020/12/13 21:27:45 rillig Exp $");
+MAKE_RCSID("$NetBSD: parse.c,v 1.482 2020/12/14 23:48:03 rillig Exp $");
 
 /* types and constants */
 
@@ -2823,10 +2823,15 @@
 }
 
 /*
- * Read an entire line from the input file. Called only by Parse_File.
+ * Read an entire line from the input file.
+ *
+ * Empty lines, .if and .for are completely handled by this function,
+ * leaving only variable assignments, other directives, dependency lines
+ * and shell commands to the caller.
  *
  * Results:
- *     A line without its newline and without any trailing whitespace.
+ *     A line without its newline and without any trailing whitespace,
+ *     or NULL.
  */
 static char *
 ParseReadLine(void)
@@ -2849,15 +2854,12 @@
                 */
                switch (Cond_EvalLine(line)) {
                case COND_SKIP:
-                       /*
-                        * Skip to next conditional that evaluates to
-                        * COND_PARSE.
-                        */
-                       do {
-                               line = ParseGetLine(PARSE_SKIP);
-                       } while (line && Cond_EvalLine(line) != COND_PARSE);
+                       while ((line = ParseGetLine(PARSE_SKIP)) != NULL) {
+                               if (Cond_EvalLine(line) == COND_PARSE)
+                                       break;
+                       }
                        if (line == NULL)
-                               break;
+                               return NULL;
                        continue;
                case COND_PARSE:
                        continue;
Home |
Main Index |
Thread Index |
Old Index