make better, add sanity
This commit is contained in:
parent
5ff754e01e
commit
c73f0e5e9b
@ -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
|
# Various list maintenance functions
|
||||||
|
|
||||||
@ -6,6 +6,7 @@
|
|||||||
# mdtomi: move common md file lines to mi, if present
|
# mdtomi: move common md file lines to mi, if present
|
||||||
# dupes: detect (nothing more) duplicate entries in each arch's complete file
|
# dupes: detect (nothing more) duplicate entries in each arch's complete file
|
||||||
# list
|
# list
|
||||||
|
# sanity: sanity check sets for wrong filecounts across archs
|
||||||
|
|
||||||
|
|
||||||
all: sort
|
all: sort
|
||||||
@ -19,40 +20,50 @@ sort:
|
|||||||
done
|
done
|
||||||
|
|
||||||
basefiles!= cd xbase;echo md.*
|
basefiles!= cd xbase;echo md.*
|
||||||
archs = ${basefiles:S/md\.//}
|
archs = ${basefiles:S/^md.//}
|
||||||
|
|
||||||
mdtomi:
|
mdtomi:
|
||||||
@echo "Checking for common md file lines for migration to mi files:"
|
@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; \
|
i1=first; \
|
||||||
for a in ${archs}; do \
|
for a in ${archs}; do \
|
||||||
sort */md.$$a >> $$dir/$$a; \
|
sort $$xdir/md.$$a >> $$dir/$$a; \
|
||||||
[ "X$$i1" = "Xfirst" ] && { \
|
if [ "X$$i1" = "Xfirst" ]; then \
|
||||||
i1=$$dir/$$a; \
|
i1=$$dir/$$a; \
|
||||||
} || { \
|
else \
|
||||||
cat $$i1 $$dir/$$a | sort | uniq -d >> $$dir/mi.tmp; \
|
cat $$i1 $$dir/$$a | sort | uniq -d >> $$dir/mi.tmp; \
|
||||||
echo "===> ($$(echo $$(cat $$dir/mi.tmp|wc -c)))\c"; \
|
echo "===> ($$(echo $$(cat $$dir/mi.tmp|wc -c)))\c"; \
|
||||||
echo " $$i1 vs $$dir/$$a"; \
|
echo " $$i1 vs $$dir/$$a"; \
|
||||||
mv $$dir/mi.tmp $$dir/mi; \
|
mv $$dir/mi.tmp $$dir/mi; \
|
||||||
i1=$$dir/mi; \
|
i1=$$dir/mi; \
|
||||||
}; \
|
fi; \
|
||||||
done; \
|
done; \
|
||||||
echo "If any common md files were found, migrating to mi files:"; \
|
echo "If any common md files were found, migrating to mi files:"; \
|
||||||
cat $$dir/mi | while read line; do \
|
cat $$dir/mi | while read line; do \
|
||||||
echo "==> $$line"; \
|
echo "==> $$line"; \
|
||||||
for line2 in $$(grep $$line */m*); do \
|
for line2 in $$(grep "^$$line$$" $$xdir/m*); do \
|
||||||
f=$${line2%:*}; \
|
f=$${line2%:*}; \
|
||||||
grep -v $$line $$f > $$f.tmp && mv $$f.tmp $$f; \
|
grep -v $$line $$f > $$f.tmp && mv $$f.tmp $$f; \
|
||||||
d=$${f%/*}; \
|
|
||||||
echo "===> -$$line2"; \
|
echo "===> -$$line2"; \
|
||||||
done; \
|
done; \
|
||||||
echo "===> +$$d/mi"; \
|
echo "===> +$$d/mi"; \
|
||||||
echo $$line >> $$d/mi; \
|
echo $$line >> $$xdir/mi; \
|
||||||
done; rm -rf $$dir
|
done; rm -rf $$dir; \
|
||||||
|
|
||||||
dupes:
|
|
||||||
@for arch in ${archs}; do \
|
|
||||||
echo "===> $$arch"; \
|
|
||||||
cat */md.$$arch */mi | sort | uniq -d; \
|
|
||||||
done
|
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
|
||||||
|
Loading…
Reference in New Issue
Block a user