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 variable names in ParseGetLin...
details: https://anonhg.NetBSD.org/src/rev/f679ddd50fee
branches: trunk
changeset: 957962:f679ddd50fee
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Dec 19 10:49:36 2020 +0000
description:
make(1): clean up variable names in ParseGetLine and ParseRawLine
diffstat:
usr.bin/make/parse.c | 98 ++++++++++++++++++++++++---------------------------
1 files changed, 46 insertions(+), 52 deletions(-)
diffs (180 lines):
diff -r d5c139b14a2f -r f679ddd50fee usr.bin/make/parse.c
--- a/usr.bin/make/parse.c Sat Dec 19 10:18:46 2020 +0000
+++ b/usr.bin/make/parse.c Sat Dec 19 10:49:36 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: parse.c,v 1.491 2020/12/19 10:18:46 rillig Exp $ */
+/* $NetBSD: parse.c,v 1.492 2020/12/19 10:49:36 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.491 2020/12/19 10:18:46 rillig Exp $");
+MAKE_RCSID("$NetBSD: parse.c,v 1.492 2020/12/19 10:49:36 rillig Exp $");
/* types and constants */
@@ -2657,77 +2657,72 @@
}
/*
- * Parse a line, joining physical lines that end with backslash-newline.
- * Do not unescape "\#", that's done by UnescapeBackslash.
+ * Parse until the end of a line, taking into account lines that end with
+ * backslash-newline.
*/
static Boolean
ParseRawLine(char **out_line, char **out_line_end,
- char **out_escaped, char **out_comment, char *inout_ch,
- IFile *const cf)
+ char **out_firstBackslash, char **out_firstComment,
+ Boolean *out_eof, IFile *const cf)
{
char *line = cf->buf_ptr;
- char *ptr = line;
+ char *p = line;
char *line_end = line;
- char *escaped = NULL;
- char *comment = NULL;
- char ch = *inout_ch;
+ char *firstBackslash = NULL;
+ char *firstComment = NULL;
+ Boolean eof = FALSE;
cf->lineno++;
for (;;) {
- if (ptr == cf->buf_end) {
- /* end of buffer */
- ch = '\0';
+ char ch;
+
+ if (p == cf->buf_end) {
+ eof = TRUE;
break;
}
- ch = *ptr;
+ ch = *p;
if (ch == '\0' ||
- (ch == '\\' && ptr + 1 < cf->buf_end &&
- ptr[1] == '\0')) {
- Parse_Error(PARSE_FATAL,
- "Zero byte read from file");
+ (ch == '\\' && p + 1 < cf->buf_end && p[1] == '\0')) {
+ Parse_Error(PARSE_FATAL, "Zero byte read from file");
return FALSE;
}
- /*
- * Don't treat next character after '\' as special,
- * remember first one.
- */
+ /* Treat next character after '\' as literal. */
if (ch == '\\') {
- if (escaped == NULL)
- escaped = ptr;
- if (ptr[1] == '\n')
+ if (firstBackslash == NULL)
+ firstBackslash = p;
+ if (p[1] == '\n')
cf->lineno++;
- ptr += 2;
- line_end = ptr;
+ p += 2;
+ line_end = p;
continue;
}
/*
- * Remember the first '#' for comment stripping,
- * unless the previous char was '[', as in the
- * modifier ':[#]'.
+ * Remember the first '#' for comment stripping, unless
+ * the previous char was '[', as in the modifier ':[#]'.
*/
- if (ch == '#' && comment == NULL &&
- !(ptr > line && ptr[-1] == '['))
- comment = line_end;
-
- ptr++;
+ if (ch == '#' && firstComment == NULL &&
+ !(p > line && p[-1] == '['))
+ firstComment = line_end;
+
+ p++;
if (ch == '\n')
break;
/* We are not interested in trailing whitespace. */
if (!ch_isspace(ch))
- line_end = ptr;
+ line_end = p;
}
*out_line = line;
- cf->buf_ptr = ptr;
+ cf->buf_ptr = p;
*out_line_end = line_end;
- *out_escaped = escaped;
- *out_comment = comment;
- *inout_ch = ch;
+ *out_firstBackslash = firstBackslash;
+ *out_firstComment = firstComment;
+ *out_eof = eof;
return TRUE;
}
@@ -2800,21 +2795,20 @@
ParseGetLine(GetLineMode mode)
{
IFile *cf = CurFile();
- char ch;
+ Boolean eof;
char *line;
char *line_end;
- char *escaped;
- char *comment;
+ char *firstBackslash;
+ char *firstComment;
/* Loop through blank lines and comment lines */
for (;;) {
- if (!ParseRawLine(&line, &line_end, &escaped, &comment, &ch, cf))
+ if (!ParseRawLine(&line, &line_end,
+ &firstBackslash, &firstComment, &eof, cf))
return NULL;
- /* Check we have a non-comment, non-blank line */
- if (line_end == line || comment == line) {
- if (ch == '\0')
- /* At end of file */
+ if (line_end == line || firstComment == line) {
+ if (eof)
return NULL;
/* Parse another line */
continue;
@@ -2841,17 +2835,17 @@
}
/* Brutally ignore anything after a non-escaped '#' in non-commands. */
- if (comment != NULL && line[0] != '\t') {
- line_end = comment;
+ if (firstComment != NULL && line[0] != '\t') {
+ line_end = firstComment;
*line_end = '\0';
}
/* If we didn't see a '\\' then the in-situ data is fine. */
- if (escaped == NULL)
+ if (firstBackslash == NULL)
return line;
/* Remove escapes from '\n' and '#' */
- UnescapeBackslash(line, escaped);
+ UnescapeBackslash(line, firstBackslash);
return line;
}
Home |
Main Index |
Thread Index |
Old Index