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): merge duplicate code in the :O and :u ...



details:   https://anonhg.NetBSD.org/src/rev/bae732455774
branches:  trunk
changeset: 936734:bae732455774
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Aug 02 19:08:54 2020 +0000

description:
make(1): merge duplicate code in the :O and :u modifiers

diffstat:

 usr.bin/make/var.c |  55 +++++++++++++++++++++++------------------------------
 1 files changed, 24 insertions(+), 31 deletions(-)

diffs (100 lines):

diff -r beb842a1659c -r bae732455774 usr.bin/make/var.c
--- a/usr.bin/make/var.c        Sun Aug 02 18:57:55 2020 +0000
+++ b/usr.bin/make/var.c        Sun Aug 02 19:08:54 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: var.c,v 1.402 2020/08/02 18:57:55 rillig Exp $ */
+/*     $NetBSD: var.c,v 1.403 2020/08/02 19:08:54 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.402 2020/08/02 18:57:55 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.403 2020/08/02 19:08:54 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.402 2020/08/02 18:57:55 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.403 2020/08/02 19:08:54 rillig Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -1572,13 +1572,29 @@
     return strcmp(*(const char * const *)b, *(const char * const *)a);
 }
 
+static char *
+WordList_JoinFree(char **av, int ac, char *as)
+{
+    Buffer buf;
+    Buf_InitZ(&buf, 0);
+
+    int i;
+    for (i = 0; i < ac; i++) {
+       if (i != 0)
+           Buf_AddByte(&buf, ' ');
+       Buf_AddStr(&buf, av[i]);
+    }
+
+    free(av);
+    free(as);
+
+    return Buf_Destroy(&buf, FALSE);
+}
+
 /* Remove adjacent duplicate words. */
 static char *
 VarUniq(const char *str)
 {
-    Buffer buf;                        /* Buffer for new string */
-    Buf_InitZ(&buf, 0);
-
     char *as;                  /* Word list memory */
     int ac;
     char **av = brk_string(str, &ac, FALSE, &as);
@@ -1591,17 +1607,7 @@
        ac = j + 1;
     }
 
-    int i;
-    for (i = 0; i < ac; i++) {
-       if (i != 0)
-           Buf_AddByte(&buf, ' ');
-       Buf_AddStr(&buf, av[i]);
-    }
-
-    free(as);
-    free(av);
-
-    return Buf_Destroy(&buf, FALSE);
+    return WordList_JoinFree(av, ac, as);
 }
 
 
@@ -2601,20 +2607,7 @@
        return AMR_BAD;
     }
 
-    Buffer buf;
-    Buf_InitZ(&buf, 0);
-
-    int i;
-    for (i = 0; i < ac; i++) {
-       if (i != 0)
-           Buf_AddByte(&buf, ' ');
-       Buf_AddStr(&buf, av[i]);
-    }
-
-    free(as);
-    free(av);
-
-    st->newVal = Buf_Destroy(&buf, FALSE);
+    st->newVal = WordList_JoinFree(av, ac, as);
     return AMR_OK;
 }
 



Home | Main Index | Thread Index | Old Index