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 str_concat4 to make the other code...
details: https://anonhg.NetBSD.org/src/rev/6bf3f38a0603
branches: trunk
changeset: 1012836:6bf3f38a0603
user: rillig <rillig%NetBSD.org@localhost>
date: Tue Aug 11 18:41:46 2020 +0000
description:
make(1): add str_concat4 to make the other code simpler
There's no need for arch.c to call strlen when there is a high-level API
for the same purpose.
diffstat:
usr.bin/make/arch.c | 12 ++++--------
usr.bin/make/nonints.h | 3 ++-
usr.bin/make/str.c | 22 +++++++++++++++++++---
3 files changed, 25 insertions(+), 12 deletions(-)
diffs (112 lines):
diff -r 9fffdcc1ea0d -r 6bf3f38a0603 usr.bin/make/arch.c
--- a/usr.bin/make/arch.c Tue Aug 11 15:48:42 2020 +0000
+++ b/usr.bin/make/arch.c Tue Aug 11 18:41:46 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: arch.c,v 1.81 2020/08/03 20:26:09 rillig Exp $ */
+/* $NetBSD: arch.c,v 1.82 2020/08/11 18:41:46 rillig Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: arch.c,v 1.81 2020/08/03 20:26:09 rillig Exp $";
+static char rcsid[] = "$NetBSD: arch.c,v 1.82 2020/08/11 18:41:46 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
#if 0
static char sccsid[] = "@(#)arch.c 8.2 (Berkeley) 1/2/94";
#else
-__RCSID("$NetBSD: arch.c,v 1.81 2020/08/03 20:26:09 rillig Exp $");
+__RCSID("$NetBSD: arch.c,v 1.82 2020/08/11 18:41:46 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -354,7 +354,6 @@
char *buf;
char *sacrifice;
char *oldMemName = memName;
- size_t sz;
memName = Var_Subst(memName, ctxt, VARE_UNDEFERR | VARE_WANTRES);
@@ -363,10 +362,7 @@
* variables and multi-word variable values.... The results
* are just placed at the end of the nodeLst we're returning.
*/
- sz = strlen(memName)+strlen(libName)+3;
- buf = sacrifice = bmake_malloc(sz);
-
- snprintf(buf, sz, "%s(%s)", libName, memName);
+ buf = sacrifice = str_concat4(libName, "(", memName, ")");
if (strchr(memName, '$') && strcmp(memName, oldMemName) == 0) {
/*
diff -r 9fffdcc1ea0d -r 6bf3f38a0603 usr.bin/make/nonints.h
--- a/usr.bin/make/nonints.h Tue Aug 11 15:48:42 2020 +0000
+++ b/usr.bin/make/nonints.h Tue Aug 11 18:41:46 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nonints.h,v 1.93 2020/08/10 19:53:19 rillig Exp $ */
+/* $NetBSD: nonints.h,v 1.94 2020/08/11 18:41:46 rillig Exp $ */
/*-
* Copyright (c) 1988, 1989, 1990, 1993
@@ -136,6 +136,7 @@
/* str.c */
char *str_concat2(const char *, const char *);
char *str_concat3(const char *, const char *, const char *);
+char *str_concat4(const char *, const char *, const char *, const char *);
char **brk_string(const char *, int *, Boolean, char **);
char *Str_FindSubstring(const char *, const char *);
Boolean Str_Match(const char *, const char *);
diff -r 9fffdcc1ea0d -r 6bf3f38a0603 usr.bin/make/str.c
--- a/usr.bin/make/str.c Tue Aug 11 15:48:42 2020 +0000
+++ b/usr.bin/make/str.c Tue Aug 11 18:41:46 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: str.c,v 1.59 2020/08/10 19:53:19 rillig Exp $ */
+/* $NetBSD: str.c,v 1.60 2020/08/11 18:41:46 rillig Exp $ */
/*-
* Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
*/
#ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: str.c,v 1.59 2020/08/10 19:53:19 rillig Exp $";
+static char rcsid[] = "$NetBSD: str.c,v 1.60 2020/08/11 18:41:46 rillig Exp $";
#else
#include <sys/cdefs.h>
#ifndef lint
#if 0
static char sccsid[] = "@(#)str.c 5.8 (Berkeley) 6/1/90";
#else
-__RCSID("$NetBSD: str.c,v 1.59 2020/08/10 19:53:19 rillig Exp $");
+__RCSID("$NetBSD: str.c,v 1.60 2020/08/11 18:41:46 rillig Exp $");
#endif
#endif /* not lint */
#endif
@@ -109,6 +109,22 @@
return result;
}
+/* Return the concatenation of s1, s2, s3 and s4, freshly allocated. */
+char *
+str_concat4(const char *s1, const char *s2, const char *s3, const char *s4)
+{
+ size_t len1 = strlen(s1);
+ size_t len2 = strlen(s2);
+ size_t len3 = strlen(s3);
+ size_t len4 = strlen(s4);
+ char *result = bmake_malloc(len1 + len2 + len3 + len4 + 1);
+ memcpy(result, s1, len1);
+ memcpy(result + len1, s2, len2);
+ memcpy(result + len1 + len2, s3, len3);
+ memcpy(result + len1 + len2 + len3, s4, len4 + 1);
+ return result;
+}
+
/*-
* brk_string --
* Fracture a string into an array of words (as delineated by tabs or
Home |
Main Index |
Thread Index |
Old Index