Module Name:    src
Committed By:   rillig
Date:           Sun Sep 27 16:10:07 UTC 2020

Modified Files:
        src/usr.bin/make: buf.h var.c

Log Message:
make(1): replace direct access to Buffer fields with inline function

This way, renaming the fields of the buffer is restricted to only buf.h
and buf.c.


To generate a diff of this commit:
cvs rdiff -u -r1.29 -r1.30 src/usr.bin/make/buf.h
cvs rdiff -u -r1.543 -r1.544 src/usr.bin/make/var.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/usr.bin/make/buf.h
diff -u src/usr.bin/make/buf.h:1.29 src/usr.bin/make/buf.h:1.30
--- src/usr.bin/make/buf.h:1.29	Sun Sep 13 15:27:25 2020
+++ src/usr.bin/make/buf.h	Sun Sep 27 16:10:07 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: buf.h,v 1.29 2020/09/13 15:27:25 rillig Exp $	*/
+/*	$NetBSD: buf.h,v 1.30 2020/09/27 16:10:07 rillig Exp $	*/
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -112,6 +112,12 @@ Buf_Size(const Buffer *bp)
     return bp->count;
 }
 
+static inline MAKE_ATTR_UNUSED Boolean
+Buf_EndsWith(const Buffer *bp, char ch)
+{
+    return bp->count > 0 && bp->buffer[bp->count - 1] == ch;
+}
+
 void Buf_AddBytes(Buffer *, const char *, size_t);
 void Buf_AddBytesBetween(Buffer *, const char *, const char *);
 void Buf_AddStr(Buffer *, const char *);

Index: src/usr.bin/make/var.c
diff -u src/usr.bin/make/var.c:1.543 src/usr.bin/make/var.c:1.544
--- src/usr.bin/make/var.c:1.543	Sat Sep 26 16:00:12 2020
+++ src/usr.bin/make/var.c	Sun Sep 27 16:10:07 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: var.c,v 1.543 2020/09/26 16:00:12 rillig Exp $	*/
+/*	$NetBSD: var.c,v 1.544 2020/09/27 16:10:07 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.543 2020/09/26 16:00:12 rillig Exp $");
+MAKE_RCSID("$NetBSD: var.c,v 1.544 2020/09/27 16:10:07 rillig Exp $");
 
 #define VAR_DEBUG_IF(cond, fmt, ...)	\
     if (!(DEBUG(VAR) && (cond)))	\
@@ -1433,8 +1433,7 @@ ModifyWord_Loop(const char *word, SepBuf
 	      "to \"%s\"\n",
 	      word, args->tvar, args->str, s);
 
-    if (s[0] == '\n' || (buf->buf.count > 0 &&
-			 buf->buf.buffer[buf->buf.count - 1] == '\n'))
+    if (s[0] == '\n' || Buf_EndsWith(&buf->buf, '\n'))
 	buf->needSep = FALSE;
     SepBuf_AddStr(buf, s);
     free(s);
@@ -1552,7 +1551,7 @@ ModifyWords(GNode *ctx, char sep, Boolea
 
     for (i = 0; i < words.len; i++) {
 	modifyWord(words.words[i], &result, modifyWord_args);
-	if (result.buf.count > 0)
+	if (Buf_Size(&result.buf) > 0)
 	    SepBuf_Sep(&result);
     }
 

Reply via email to