2012-03-19 13:42:10 +02:00
# collect what's left
2012-04-23 12:42:13 +03:00
i f n e q ( , $( REPORT ) )
2012-04-18 22:22:29 +03:00
i n c l u d e l i b / c o m m o n . m k
2012-04-23 20:45:32 +03:00
2012-04-23 21:56:35 +03:00
BUILDDIR := $( shell sed -n 's/^.* BUILDDIR = \(.*\)/\1/p' " $( REPORT_PATH) " )
BUILDLOG := $( BUILDDIR) /$( BUILD_LOG)
2012-04-25 16:42:04 +03:00
REPORTDIR := $( BUILDDIR) /reports
2012-04-23 21:56:35 +03:00
IMAGE_OUTPATH := $( shell sed -n 's/^IMAGE_OUTPATH = \(.*\)/\1/p' $( BUILDLOG) )
2012-06-15 20:33:04 +04:00
IMAGE_OUTFILE := $( shell sed -n 's/^IMAGE_OUTFILE = \(.*\)/\1/p' $( BUILDLOG) )
LOGDIR := $( shell sed -n 's/^LOGDIR = \(.*\)/\1/p' $( BUILDLOG) )
2012-04-23 21:56:35 +03:00
# for a multi-image build there's no sense to refer to buildroot
# contained reports as these are very ephemeral between builds
i f n e q ( 1 , $( NUM_TARGETS ) )
SHORTEN := >/dev/null
e n d i f
2018-06-11 11:15:49 +03:00
all : reports /targets reports /scripts reports /cleanlog reports /contents
2012-04-25 16:42:04 +03:00
@if [ -n " $( IMAGE_OUTPATH) " ] ; then \
2012-06-15 20:33:04 +04:00
cp -a " $( REPORTDIR) " " $( LOGDIR) / $( IMAGE_OUTFILE) .reports " ; \
2012-04-25 16:42:04 +03:00
fi
2012-04-18 22:22:29 +03:00
reports/prep :
2012-04-23 21:56:35 +03:00
@mkdir -p " $( REPORTDIR) "
2012-04-18 22:22:29 +03:00
2012-10-17 00:55:53 +03:00
# try to drop common noise rendering diff(1) mostly useless
reports/cleanlog : reports /prep
@OUT= " $( REPORTDIR) / $( @F) .log " ; \
2019-06-06 11:42:34 +03:00
BUILDDIR = " $( BUILDDIR) " cleanlog < $( BUILDLOG) > " $$ OUT " \
2012-10-17 00:55:53 +03:00
&& echo " ** diffable log: $$ OUT " $( SHORTEN)
2012-04-18 22:22:29 +03:00
reports/scripts : reports /prep
2012-04-25 16:56:48 +03:00
@OUT= " $( REPORTDIR) / $( @F) .log " ; \
grep "^mki.*scripts: Run: " $( BUILDLOG) \
| sed -rn " s,^.*( $( BUILDDIR) | $( SYMLINK) )/(.*)' $$ ,\2,p " > " $$ OUT " \
&& if [ -s " $$ OUT " ] ; then \
echo " ** scripts report: $$ OUT " $( SHORTEN) ; \
fi
2012-04-18 22:22:29 +03:00
reports/targets : reports /prep
2012-04-23 20:45:32 +03:00
@if ! [ -n " $( REPORT_PATH) " -a -s " $( REPORT_PATH) " ] ; then \
exit 0; \
fi ; \
2012-04-23 12:42:13 +03:00
if type -t dot >& /dev/null; then \
2012-04-25 16:56:48 +03:00
OUT = " $( REPORTDIR) / $( @F) .png " ; \
2012-04-23 20:45:32 +03:00
report-targets < " $( REPORT_PATH) " \
2012-04-25 16:56:48 +03:00
| dot -Tpng -o " $$ OUT " \
&& if [ -s " $$ OUT " ] ; then \
echo " ** target graph report: $$ OUT " ; \
fi ; \
2012-04-09 14:40:42 +03:00
else \
2012-04-25 16:56:48 +03:00
OUT = " $( BUILDDIR) /targets.dot " ; \
report-targets < " $( REPORT_PATH) " > " $$ OUT " \
&& if [ -s " $$ OUT " ] ; then \
2014-06-04 18:19:54 +04:00
echo "** graphviz missing," \
2012-04-25 16:56:48 +03:00
" target graph dot file: $$ OUT " ; \
fi ; \
2012-04-18 22:22:29 +03:00
fi $( SHORTEN) ; \
2012-04-23 21:56:35 +03:00
mv " $( REPORT_PATH) " " $( REPORTDIR) / $( @F) .log "
2012-04-23 12:42:13 +03:00
2018-06-11 11:15:49 +03:00
reports/contents : reports /prep
@case $( IMAGE_OUTFILE) in \
*.iso) \
if type -t isoinfo >& /dev/null; then \
OUT = " $( REPORTDIR) / $( @F) .txt " ; \
isoinfo -f -R -i $( IMAGE_OUTPATH) > $$ OUT && \
echo " ** contents list: $$ OUT " $( SHORTEN) ; \
else \
echo "reports.mk: missing isoinfo" >& 2; \
fi ; \
esac
2012-04-23 12:42:13 +03:00
e l s e
all : ; @:
e n d i f