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)
2021-07-14 17:41:49 +07:00
BUILDCFG := $( BUILDDIR) /distcfg.mk
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) )
2021-08-20 11:56:05 +07:00
i f e q ( , $( LOGDIR ) )
LOGDIR := $( shell sed -n 's/^LOGDIR ?= \(.*\)/\1/p' $( BUILDCFG) )
e n d i f
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
2019-12-10 22:16:59 +07:00
e l s e
SHORTEN := >>$( BUILDLOG)
2012-04-23 21:56:35 +03:00
e n d i f
2019-12-08 14:12:00 +03:00
report = $( and $( 1) ,$( report_body) )
d e f i n e r e p o r t _ b o d y
{ i f [ - s "$$OUT" ] ; t h e n \
echo " ** $( 1) : $$ OUT " $( SHORTEN) ; \
f i ; }
e n d e f
2021-04-28 14:48:59 +03:00
all : reports /targets reports /scripts reports /cleanlog \
reports/contents reports/packages
2021-06-11 23:20:33 +07:00
@rm -fr " $( LOGDIR) / $( IMAGE_OUTFILE) .reports "
@cp -a " $( REPORTDIR) " " $( LOGDIR) / $( IMAGE_OUTFILE) .reports "
@mv $( LOGDIR) /{ $( IMAGE_OUTFILE) ,$( IMAGE_OUTFILE) .reports/build} .log
@mv $( LOGDIR) /{ $( IMAGE_OUTFILE) ,$( IMAGE_OUTFILE) .reports/build} .cfg
2021-07-15 16:13:03 +07:00
@find $( BUILDDIR) /pkg/ -type f | sed 's:$(BUILDDIR)/pkg/::' > \
" $( LOGDIR) / $( IMAGE_OUTFILE) .reports/pkg.list "
2023-05-30 22:53:28 +07:00
@chmod +r -R " $( LOGDIR) / $( IMAGE_OUTFILE) .reports "
2022-11-23 15:14:07 +07:00
i f e q ( 2 , $( REPORT ) )
@cd " $( LOGDIR) " && tar -cf " $( IMAGE_OUTFILE) .reports.tar " " $( IMAGE_OUTFILE) .reports " && \
rm -r " $( IMAGE_OUTFILE) .reports "
e n d i f
2012-04-18 22:22:29 +03:00
reports/prep :
2021-06-11 23:20:33 +07:00
@mkdir -p " $( REPORTDIR) " " $( LOGDIR) "
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-12-08 14:12:00 +03:00
BUILDDIR = " $( BUILDDIR) " \
cleanlog < $( BUILDLOG) > " $$ OUT " \
&& $( call report,diffable log)
2012-10-17 00:55:53 +03:00
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 " \
2019-12-08 14:12:00 +03:00
&& $( call report,scripts report)
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 \
2021-04-29 21:26:51 +07:00
OUT = " $( REPORTDIR) / $( @F) .svgz " ; \
2012-04-23 20:45:32 +03:00
report-targets < " $( REPORT_PATH) " \
2021-04-29 21:26:51 +07:00
| dot -Tsvgz -o " $$ OUT " \
2019-12-08 14:12:00 +03:00
&& $( call report,target graph report) ; \
2021-07-14 13:06:35 +07:00
if type -t rsvg-convert >& /dev/null; then \
IN = " $$ OUT " ; \
OUT = " $( REPORTDIR) / $( @F) .pdf " ; \
rsvg-convert -f pdf " $$ IN " -o " $$ 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 " \
2019-12-08 14:12:00 +03:00
&& $( call report,graphviz missing, target graph dot file) ; \
fi ; \
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 " ; \
2019-12-08 14:12:00 +03:00
isoinfo -f -R -i $( IMAGE_OUTPATH) > $$ OUT \
&& $( call report,contents list) ; \
2018-06-11 11:15:49 +03:00
else \
echo "reports.mk: missing isoinfo" >& 2; \
fi ; \
esac
2021-04-28 14:48:59 +03:00
2021-04-28 16:29:46 +03:00
reports/packages : SHELL = /bin /bash
2021-04-28 14:48:59 +03:00
reports/packages : reports /prep
@grep -E 'chroot/.in/[^/]*.rpm' < $( BUILDLOG) | \
cut -d' ' -f 1 | tr -d "'" '`' | \
2021-04-28 15:06:57 +03:00
tee /dev/stderr 2> >( sed 's,^.*/,,' | \
2022-01-20 18:15:57 +07:00
sort -u > " $( REPORTDIR) /list-rpms.txt " ) | \
2021-10-25 12:13:15 +03:00
xargs -r rpm -qp --queryformat '%{sourcerpm}\n' | \
2022-01-20 18:15:57 +07:00
sort -u > " $( REPORTDIR) /list-srpms.txt " || :
2018-06-11 11:15:49 +03:00
2012-04-23 12:42:13 +03:00
e l s e
all : ; @:
e n d i f