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): add Buf_AddInt to make the calling cod...
details: https://anonhg.NetBSD.org/src/rev/c20fb4641dfe
branches: trunk
changeset: 974218:c20fb4641dfe
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Jul 26 13:39:30 2020 +0000
description:
make(1): add Buf_AddInt to make the calling code simpler
diffstat:
usr.bin/make/buf.c | 35 +++++++++++++++++++++++++++++------
usr.bin/make/buf.h | 3 ++-
usr.bin/make/var.c | 35 ++++++++++++-----------------------
3 files changed, 43 insertions(+), 30 deletions(-)
diffs (173 lines):
diff -r 12eae843f6d7 -r c20fb4641dfe usr.bin/make/buf.c
--- a/usr.bin/make/buf.c Sun Jul 26 13:09:53 2020 +0000
+++ b/usr.bin/make/buf.c Sun Jul 26 13:39:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: buf.c,v 1.26 2020/07/03 08:02:55 rillig Exp $ */
+/* $NetBSD: buf.c,v 1.27 2020/07/26 13:39:30 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -70,25 +70,26 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: buf.c,v 1.26 2020/07/03 08:02:55 rillig Exp $";
+static char rcsid[] = "$NetBSD: buf.c,v 1.27 2020/07/26 13:39:30 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
#if 0
static char sccsid[] = "@(#)buf.c 8.1 (Berkeley) 6/6/93";
#else
-__RCSID("$NetBSD: buf.c,v 1.26 2020/07/03 08:02:55 rillig Exp $");
+__RCSID("$NetBSD: buf.c,v 1.27 2020/07/26 13:39:30 rillig Exp $");
#endif
#endif /* not lint */
#endif
/*-
* buf.c --
- * Functions for automatically-expanded buffers.
+ * Functions for automatically-expanded NUL-terminated buffers.
*/
-#include "make.h"
-#include "buf.h"
+#include <limits.h>
+#include "make.h"
+#include "buf.h"
#ifndef max
#define max(a,b) ((a) > (b) ? (a) : (b))
@@ -142,6 +143,28 @@
/*-
*-----------------------------------------------------------------------
+ * Buf_AddInt --
+ * Add the given number to the buffer.
+ *
+ *-----------------------------------------------------------------------
+ */
+void
+Buf_AddInt(Buffer *bp, int n)
+{
+ /*
+ * We need enough space for the decimal representation of an int.
+ * We calculate the space needed for the octal representation, and
+ * add enough slop to cope with a '-' sign and a trailing '\0'.
+ */
+ size_t bits = sizeof(int) * CHAR_BIT;
+ char buf[1 + (bits + 2) / 3 + 1];
+
+ int len = snprintf(buf, sizeof buf, "%d", n);
+ Buf_AddBytes(bp, len, buf);
+}
+
+/*-
+ *-----------------------------------------------------------------------
* Buf_GetAll --
* Get all the available data at once.
*
diff -r 12eae843f6d7 -r c20fb4641dfe usr.bin/make/buf.h
--- a/usr.bin/make/buf.h Sun Jul 26 13:09:53 2020 +0000
+++ b/usr.bin/make/buf.h Sun Jul 26 13:39:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: buf.h,v 1.19 2017/05/31 22:02:06 maya Exp $ */
+/* $NetBSD: buf.h,v 1.20 2020/07/26 13:39:30 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -110,6 +110,7 @@
void Buf_Expand_1(Buffer *);
void Buf_AddBytes(Buffer *, int, const Byte *);
+void Buf_AddInt(Buffer *, int);
Byte *Buf_GetAll(Buffer *, int *);
void Buf_Empty(Buffer *);
void Buf_Init(Buffer *, int);
diff -r 12eae843f6d7 -r c20fb4641dfe usr.bin/make/var.c
--- a/usr.bin/make/var.c Sun Jul 26 13:09:53 2020 +0000
+++ b/usr.bin/make/var.c Sun Jul 26 13:39:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: var.c,v 1.311 2020/07/26 12:27:09 rillig Exp $ */
+/* $NetBSD: var.c,v 1.312 2020/07/26 13:39:30 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.311 2020/07/26 12:27:09 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.312 2020/07/26 13:39:30 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.311 2020/07/26 12:27:09 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.312 2020/07/26 13:39:30 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -1776,10 +1776,9 @@
VarRange(const char *str, int ac)
{
Buffer buf; /* Buffer for new string */
- char tmp[32]; /* each element */
char **av; /* List of words to affect */
char *as; /* Word list memory */
- int i, n;
+ int i;
Buf_Init(&buf, 0);
if (ac > 0) {
@@ -1789,10 +1788,7 @@
av = brk_string(str, &ac, FALSE, &as);
}
for (i = 0; i < ac; i++) {
- n = snprintf(tmp, sizeof(tmp), "%d", 1 + i);
- if (n >= (int)sizeof(tmp))
- break;
- Buf_AddBytes(&buf, n, tmp);
+ Buf_AddInt(&buf, 1 + i);
if (i != ac - 1)
Buf_AddByte(&buf, ' ');
}
@@ -2657,28 +2653,21 @@
goto bad_modifier; /* empty square brackets in ":[]". */
if (estr[0] == '#' && estr[1] == '\0') { /* Found ":[#]" */
- /*
- * We will need enough space for the decimal representation of an int.
- * We calculate the space needed for the octal representation, and add
- * enough slop to cope with a '-' sign (which should never be needed)
- * and a '\0' string terminator.
- */
- int newStrSize = (sizeof(int) * CHAR_BIT + 2) / 3 + 2;
-
- st->newStr = bmake_malloc(newStrSize);
if (st->oneBigWord) {
- strncpy(st->newStr, "1", newStrSize);
+ st->newStr = bmake_strdup("1");
} else {
/* XXX: brk_string() is a rather expensive
* way of counting words. */
- char **av;
char *as;
int ac;
-
- av = brk_string(st->nstr, &ac, FALSE, &as);
- snprintf(st->newStr, newStrSize, "%d", ac);
+ char **av = brk_string(st->nstr, &ac, FALSE, &as);
free(as);
free(av);
+
+ Buffer buf;
+ Buf_Init(&buf, 4); /* 3 digits + '\0' */
+ Buf_AddInt(&buf, ac);
+ st->newStr = Buf_Destroy(&buf, FALSE);
}
goto ok;
}
Home |
Main Index |
Thread Index |
Old Index