Module Name:    src
Committed By:   rillig
Date:           Sun Mar 14 20:00:48 UTC 2021

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

Log Message:
make: separate parsing and evaluating in the ':O' modifiers

No functional change.


To generate a diff of this commit:
cvs rdiff -u -r1.877 -r1.878 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/var.c
diff -u src/usr.bin/make/var.c:1.877 src/usr.bin/make/var.c:1.878
--- src/usr.bin/make/var.c:1.877	Sun Mar 14 19:29:37 2021
+++ src/usr.bin/make/var.c	Sun Mar 14 20:00:48 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: var.c,v 1.877 2021/03/14 19:29:37 rillig Exp $	*/
+/*	$NetBSD: var.c,v 1.878 2021/03/14 20:00:48 rillig Exp $	*/
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -140,7 +140,7 @@
 #include "metachar.h"
 
 /*	"@(#)var.c	8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: var.c,v 1.877 2021/03/14 19:29:37 rillig Exp $");
+MAKE_RCSID("$NetBSD: var.c,v 1.878 2021/03/14 20:00:48 rillig Exp $");
 
 typedef enum VarFlags {
 	VFL_NONE	= 0,
@@ -3261,31 +3261,28 @@ static ApplyModifierResult
 ApplyModifier_Order(const char **pp, ApplyModifiersState *st)
 {
 	const char *mod = (*pp)++;	/* skip past the 'O' in any case */
-
-	/* TODO: separate parsing from evaluating */
-
-	Words words = Str_Words(st->expr->value.str, FALSE);
+	Words words;
+	enum SortMode {
+		ASC, DESC, SHUFFLE
+	} mode;
 
 	if (IsDelimiter(mod[1], st)) {
-		/* :O sorts ascending */
-		qsort(words.words, words.len, sizeof words.words[0],
-		    str_cmp_asc);
-
+		mode = ASC;
 	} else if ((mod[1] == 'r' || mod[1] == 'x') &&
 	    IsDelimiter(mod[2], st)) {
 		(*pp)++;
-
-		if (mod[1] == 'r') {	/* :Or sorts descending */
-			qsort(words.words, words.len, sizeof words.words[0],
-			    str_cmp_desc);
-		} else
-			ShuffleStrings(words.words, words.len);
-	} else {
-		Words_Free(words);
+		mode = mod[1] == 'r' ? DESC : SHUFFLE;
+	} else
 		return AMR_BAD;
-	}
 
+	words = Str_Words(st->expr->value.str, FALSE);
+	if (mode == SHUFFLE)
+		ShuffleStrings(words.words, words.len);
+	else
+		qsort(words.words, words.len, sizeof words.words[0],
+		    mode == ASC ? str_cmp_asc : str_cmp_desc);
 	Expr_SetValueOwn(st->expr, Words_JoinFree(words));
+
 	return AMR_OK;
 }
 

Reply via email to