[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH] maint: make sc_dd_O_FLAGS more robust
From: |
Bernhard Voelker |
Subject: |
[PATCH] maint: make sc_dd_O_FLAGS more robust |
Date: |
Mon, 9 Feb 2015 08:19:01 +0100 |
The construct "diff ... || diff=1 || diff=" does not set the variable
in all cases. This could be triggered with:
$ env make diff=1 make sc_dd_O_FLAGS
dd_O_FLAGS
maint.mk: ./src/dd.c has inconsistent O_ flag lists
cfg.mk:59: recipe for target 'sc_dd_O_FLAGS' failed
make: *** [sc_dd_O_FLAGS] Error 1
* cfg.mk (sc_dd_O_FLAGS): Remember $? of the diff command directly
and check its value later rather than using the above mentioned
mapping.
---
cfg.mk | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/cfg.mk b/cfg.mk
index 4803074..770527a 100644
--- a/cfg.mk
+++ b/cfg.mk
@@ -61,11 +61,11 @@ sc_dd_O_FLAGS:
perl -nle '/^ +\| (O_\w*)$$/ and print $$1' $(dd); } | sort > $@.1
@{ echo O_NOFOLLOW; perl -nle '/{"[a-z]+",\s*(O_\w+)},/ and print $$1' \
$(dd); } | sort > $@.2
- @diff -u $@.1 $@.2 || diff=1 || diff=; \
+ @diff -u $@.1 $@.2; diff=$$?; \
rm -f $@.1 $@.2; \
- test "$$diff" \
- && { echo '$(ME): $(dd) has inconsistent O_ flag lists'>&2; \
- exit 1; } || :
+ test "$$diff" = 0 \
+ || { echo '$(ME): $(dd) has inconsistent O_ flag lists'>&2; \
+ exit 1; }
# Ensure that dd's definition of LONGEST_SYMBOL stays in sync
# with the strings from the two affected variables.
--
2.1.4
- [PATCH] maint: make sc_dd_O_FLAGS more robust,
Bernhard Voelker <=