diff options
author | Sverker Eriksson <[email protected]> | 2019-06-13 16:14:33 +0200 |
---|---|---|
committer | Sverker Eriksson <[email protected]> | 2019-06-19 17:05:32 +0200 |
commit | fceaee6022b07a911c05f6c7005a2edd1a2107e9 (patch) | |
tree | 390fdef7af6902b0f3741c2ec47f7c2da221186e /erts/etc/unix/gcov-gen-html | |
parent | a8ba18249d6fd3a913f320bdeeb8b9ea5eef2888 (diff) | |
download | otp-fceaee6022b07a911c05f6c7005a2edd1a2107e9.tar.gz otp-fceaee6022b07a911c05f6c7005a2edd1a2107e9.tar.bz2 otp-fceaee6022b07a911c05f6c7005a2edd1a2107e9.zip |
erts: Add gcov-gen-html script
to generate nice html from logs of gcov compiled emulator.
Diffstat (limited to 'erts/etc/unix/gcov-gen-html')
-rwxr-xr-x | erts/etc/unix/gcov-gen-html | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/erts/etc/unix/gcov-gen-html b/erts/etc/unix/gcov-gen-html new file mode 100755 index 0000000000..3fd9f1ca49 --- /dev/null +++ b/erts/etc/unix/gcov-gen-html @@ -0,0 +1,62 @@ +#!/usr/bin/perl + +use strict; +use warnings; + +@ARGV == 2 or die "Usage: gcov-gen-html \$ERL_TOP <output directory>\n"; + +my $srcdir = shift @ARGV; +my $outdir = shift @ARGV; + +my $verbose = 1; +my $flavor = "smp"; + +# setup filenames and paths, observe geninfos --base-directory +# it needs a correct path just after the $geninfo + +my $lcov_path = ""; #/usr/local/bin/"; + +my $geninfo = $lcov_path . "geninfo --no-checksum --base-directory"; +my $genhtml = $lcov_path . "genhtml"; + +# src paths + +my $emu_src_path = "$srcdir/erts/emulator"; +my $elib_src_path = "$srcdir/erts/lib_src"; +my $pcre_src_path = "$emu_src_path"; +my $zlib_src_path = "$emu_src_path"; + +# obj paths + +my $emu_obj_path = <$emu_src_path/obj/*-linux-*/gcov/$flavor>; +my $elib_obj_path = <$elib_src_path/obj/*-linux-*/gcov>; +my $pcre_obj_path = <$emu_src_path/pcre/obj/*-linux-*/gcov>; +my $zlib_obj_path = <$emu_src_path/zlib/obj/*-linux-*/gcov>; + +# info files + +my $emu_info = "$srcdir/emulator-cover.info"; +my $elib_info = "$srcdir/elib-cover.info"; +my $pcre_info = "$srcdir/pcre-cover.info"; + +my $infofiles = "$emu_info $elib_info $pcre_info"; + +run("$geninfo $emu_src_path -o $emu_info $emu_obj_path"); +run("$geninfo $elib_src_path -o $elib_info $elib_obj_path"); +run("$geninfo $pcre_src_path -o $pcre_info $pcre_obj_path"); + +if (<$zlib_obj_path/*.o>) { + my $zlib_info = "$srcdir/zlib-cover.info"; + $infofiles .= " $zlib_info"; + run("$geninfo $zlib_src_path -o $zlib_info $zlib_obj_path"); +} + +run("$genhtml -o $outdir $infofiles"); + + + +sub run { + my $cmd = shift; + print STDERR "\nrun($cmd)\n" if $verbose > 0; + system("$cmd 2>&1") == 0 or die "\nCan't run \"$cmd\": $?"; +} |