make better, add sanity

This commit is contained in:
todd 2008-04-07 20:59:41 +00:00
parent 5ff754e01e
commit c73f0e5e9b

View File

@ -1,4 +1,4 @@
# $OpenBSD: Makefile,v 1.2 2007/03/30 03:55:28 todd Exp $
# $OpenBSD: Makefile,v 1.3 2008/04/07 20:59:41 todd Exp $
# Various list maintenance functions
@ -6,6 +6,7 @@
# mdtomi: move common md file lines to mi, if present
# dupes: detect (nothing more) duplicate entries in each arch's complete file
# list
# sanity: sanity check sets for wrong filecounts across archs
all: sort
@ -19,40 +20,50 @@ sort:
done
basefiles!= cd xbase;echo md.*
archs = ${basefiles:S/md\.//}
archs = ${basefiles:S/^md.//}
mdtomi:
@echo "Checking for common md file lines for migration to mi files:"
@dir=$$(mktemp -d /tmp/mdtomi.XXXXXXXXXX); \
@for xdir in x*; do \
dir=$$(mktemp -d /tmp/mdtomi.XXXXXXXXXX); \
i1=first; \
for a in ${archs}; do \
sort */md.$$a >> $$dir/$$a; \
[ "X$$i1" = "Xfirst" ] && { \
sort $$xdir/md.$$a >> $$dir/$$a; \
if [ "X$$i1" = "Xfirst" ]; then \
i1=$$dir/$$a; \
} || { \
else \
cat $$i1 $$dir/$$a | sort | uniq -d >> $$dir/mi.tmp; \
echo "===> ($$(echo $$(cat $$dir/mi.tmp|wc -c)))\c"; \
echo " $$i1 vs $$dir/$$a"; \
mv $$dir/mi.tmp $$dir/mi; \
i1=$$dir/mi; \
}; \
fi; \
done; \
echo "If any common md files were found, migrating to mi files:"; \
cat $$dir/mi | while read line; do \
echo "==> $$line"; \
for line2 in $$(grep $$line */m*); do \
for line2 in $$(grep "^$$line$$" $$xdir/m*); do \
f=$${line2%:*}; \
grep -v $$line $$f > $$f.tmp && mv $$f.tmp $$f; \
d=$${f%/*}; \
echo "===> -$$line2"; \
done; \
echo "===> +$$d/mi"; \
echo $$line >> $$d/mi; \
done; rm -rf $$dir
dupes:
@for arch in ${archs}; do \
echo "===> $$arch"; \
cat */md.$$arch */mi | sort | uniq -d; \
echo $$line >> $$xdir/mi; \
done; rm -rf $$dir; \
done
dupes:
@for d in x*; do \
for arch in ${archs}; do \
[ -f $$d/md.$$arch ] || continue; \
echo "===> $$d/$$arch"; \
cat $$d/md.$$arch $$d/mi | sort | uniq -d; \
done; \
done
sanity:
@for d in x*; do \
[ "$$d" = "xfont" ] && continue; \
echo "==> $$d"; \
(cd $$d; cat md* | sort | uniq -c | sort -n ); \
done