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): inline VarOrder into ApplyModifier_Order



details:   https://anonhg.NetBSD.org/src/rev/fc77046742dc
branches:  trunk
changeset: 974543:fc77046742dc
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Aug 02 18:57:55 2020 +0000

description:
make(1): inline VarOrder into ApplyModifier_Order

Removing the extra mapping layer "otype" makes the code both faster and
smaller.

diffstat:

 usr.bin/make/var.c |  125 +++++++++++++++++++++-------------------------------
 1 files changed, 51 insertions(+), 74 deletions(-)

diffs (169 lines):

diff -r 138925df8866 -r fc77046742dc usr.bin/make/var.c
--- a/usr.bin/make/var.c        Sun Aug 02 18:23:33 2020 +0000
+++ b/usr.bin/make/var.c        Sun Aug 02 18:57:55 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: var.c,v 1.401 2020/08/02 18:23:00 rillig Exp $ */
+/*     $NetBSD: var.c,v 1.402 2020/08/02 18:57:55 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -69,14 +69,14 @@
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: var.c,v 1.401 2020/08/02 18:23:00 rillig Exp $";
+static char rcsid[] = "$NetBSD: var.c,v 1.402 2020/08/02 18:57:55 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.401 2020/08/02 18:23:00 rillig Exp $");
+__RCSID("$NetBSD: var.c,v 1.402 2020/08/02 18:57:55 rillig Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -1572,70 +1572,6 @@
     return strcmp(*(const char * const *)b, *(const char * const *)a);
 }
 
-/*-
- *-----------------------------------------------------------------------
- * VarOrder --
- *     Order the words in the string.
- *
- * Input:
- *     str             String whose words should be sorted.
- *     otype           How to order: s - sort, r - reverse, x - random.
- *
- * Results:
- *     A string containing the words ordered.
- *-----------------------------------------------------------------------
- */
-static char *
-VarOrder(const char *str, const char otype)
-{
-    Buffer buf;                        /* Buffer for the new string */
-    Buf_InitZ(&buf, 0);
-
-    char **av;                 /* word list */
-    char *as;                  /* word list memory */
-    int ac;
-    av = brk_string(str, &ac, FALSE, &as);
-
-    if (ac > 0) {
-       switch (otype) {
-       case 'r':               /* reverse sort alphabetically */
-           qsort(av, ac, sizeof(char *), VarWordCompareReverse);
-           break;
-       case 's':               /* sort alphabetically */
-           qsort(av, ac, sizeof(char *), VarWordCompare);
-           break;
-       case 'x':               /* randomize */
-           /*
-            * We will use [ac..2] range for mod factors. This will produce
-            * random numbers in [(ac-1)..0] interval, and minimal
-            * reasonable value for mod factor is 2 (the mod 1 will produce
-            * 0 with probability 1).
-            */
-           (void)0;
-           int i;
-           for (i = ac - 1; i > 0; i--) {
-               int rndidx = random() % (i + 1);
-               char *t = av[i];
-               av[i] = av[rndidx];
-               av[rndidx] = t;
-           }
-       }
-    }
-
-    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);
-}
-
-
 /* Remove adjacent duplicate words. */
 static char *
 VarUniq(const char *str)
@@ -2621,23 +2557,64 @@
     return AMR_BAD;
 }
 
-/* :O or :Or or :Ox */
+/* :O (order ascending) or :Or (order descending) or :Ox (shuffle) */
 static ApplyModifierResult
 ApplyModifier_Order(const char *mod, ApplyModifiersState *st)
 {
-    st->next = mod + 1;        /* skip to the rest in any case */
-
-    char otype;
+    st->next = mod + 1;                /* skip past the 'O' in any case */
+
+    char *as;                  /* word list memory */
+    int ac;
+    char **av = brk_string(st->val, &ac, FALSE, &as);
+
     if (mod[1] == st->endc || mod[1] == ':') {
-       otype = 's';
+       /* :O sorts ascending */
+       qsort(av, ac, sizeof(char *), VarWordCompare);
+
     } else if ((mod[1] == 'r' || mod[1] == 'x') &&
               (mod[2] == st->endc || mod[2] == ':')) {
-       otype = mod[1];
        st->next = mod + 2;
+
+       if (mod[1] == 'r') {
+           /* :Or sorts descending */
+           qsort(av, ac, sizeof(char *), VarWordCompareReverse);
+
+       } else {
+           /* :Ox shuffles
+            *
+            * We will use [ac..2] range for mod factors. This will produce
+            * random numbers in [(ac-1)..0] interval, and minimal
+            * reasonable value for mod factor is 2 (the mod 1 will produce
+            * 0 with probability 1).
+            */
+           int i;
+           for (i = ac - 1; i > 0; i--) {
+               int rndidx = random() % (i + 1);
+               char *t = av[i];
+               av[i] = av[rndidx];
+               av[rndidx] = t;
+           }
+       }
     } else {
+       free(as);
+       free(av);
        return AMR_BAD;
     }
-    st->newVal = VarOrder(st->val, otype);
+
+    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);
     return AMR_OK;
 }
 



Home | Main Index | Thread Index | Old Index