• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1#!/usr/bin/perl
2#
3# Copyright (C) 2006 Daniel Berrange
4#
5# This program is free software; you can redistribute it and/or modify
6# it under the terms of the GNU General Public License as published by
7# the Free Software Foundation; either version 2 of the License, or
8# (at your option) any later version.
9#
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with this program; if not, write to the Free Software
17# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
19use warnings;
20use strict;
21
22my %coverage = ( functions => {}, files => {} );
23
24my %filemap;
25
26my $type;
27my $name;
28
29my @functions;
30
31while (<>) {
32    if (/^Function '(.*)'\s*$/) {
33	$type = "function";
34	$name = $1;
35	$coverage{$type}->{$name} = {};
36	push @functions, $name;
37    } elsif (/^File '(.*?)'\s*$/) {
38	$type = "file";
39	$name = $1;
40	$coverage{$type}->{$name} = {};
41
42	foreach my $func (@functions) {
43	    $coverage{"function"}->{$func}->{file} = $name;
44	}
45	@functions = ();
46    } elsif (/^Lines executed:(.*)%\s*of\s*(\d+)\s*$/) {
47	$coverage{$type}->{$name}->{lines} = $2;
48	$coverage{$type}->{$name}->{linesCoverage} = $1;
49    } elsif (/^Branches executed:(.*)%\s*of\s*(\d+)\s*$/) {
50	$coverage{$type}->{$name}->{branches} = $2;
51	$coverage{$type}->{$name}->{branchesCoverage} = $1;
52    } elsif (/^Taken at least once:(.*)%\s*of\s*(\d+)\s*$/) {
53	$coverage{$type}->{$name}->{conds} = $2;
54	$coverage{$type}->{$name}->{condsCoverage} = $1;
55    } elsif (/^Calls executed:(.*)%\s*of\s*(\d+)\s*$/) {
56	$coverage{$type}->{$name}->{calls} = $2;
57	$coverage{$type}->{$name}->{callsCoverage} = $1;
58    } elsif (/^No branches$/) {
59	$coverage{$type}->{$name}->{branches} = 0;
60	$coverage{$type}->{$name}->{branchesCoverage} = "100.00";
61	$coverage{$type}->{$name}->{conds} = 0;
62	$coverage{$type}->{$name}->{condsCoverage} = "100.00";
63    } elsif (/^No calls$/) {
64	$coverage{$type}->{$name}->{calls} = 0;
65	$coverage{$type}->{$name}->{callsCoverage} = "100.00";
66    } elsif (/^\s*(.*):creating '(.*)'\s*$/) {
67	$filemap{$1} = $2;
68    } elsif (/^\s*$/) {
69	# nada
70    } else {
71	warn "Shit [$_]\n";
72    }
73}
74
75my %summary;
76foreach my $type ("function", "file") {
77    $summary{$type} = {};
78    foreach my $m ("lines", "branches", "conds", "calls") {
79	my $totalGot = 0;
80	my $totalMiss = 0;
81	my $count = 0;
82	foreach my $func (keys %{$coverage{function}}) {
83	    $count++;
84	    my $got = $coverage{function}->{$func}->{$m};
85	    $totalGot += $got;
86	    my $miss = $got * $coverage{function}->{$func}->{$m ."Coverage"} / 100;
87	    $totalMiss += $miss;
88	}
89	$summary{$type}->{$m} = sprintf("%d", $totalGot);
90	$summary{$type}->{$m . "Coverage"} = sprintf("%.2f", $totalMiss / $totalGot * 100);
91    }
92}
93
94
95
96print "<coverage>\n";
97
98foreach my $type ("function", "file") {
99    printf "<%ss>\n", $type;
100    foreach my $name (sort { $a cmp $b } keys %{$coverage{$type}}) {
101	my $rec = $coverage{$type}->{$name};
102	printf "  <entry name=\"%s\" details=\"%s\">\n", $name, ($type eq "file" ? $filemap{$name} : $filemap{$rec->{file}});
103	printf "    <lines count=\"%s\" coverage=\"%s\"/>\n", $rec->{lines}, $rec->{linesCoverage};
104	if (exists $rec->{branches}) {
105	    printf "    <branches count=\"%s\" coverage=\"%s\"/>\n", $rec->{branches}, $rec->{branchesCoverage};
106	}
107	if (exists $rec->{conds}) {
108	    printf "    <conditions count=\"%s\" coverage=\"%s\"/>\n", $rec->{conds}, $rec->{condsCoverage};
109	}
110	if (exists $rec->{calls}) {
111	    printf "    <calls count=\"%s\" coverage=\"%s\"/>\n", $rec->{calls}, $rec->{callsCoverage};
112	}
113	print  "  </entry>\n";
114    }
115
116    printf "  <summary>\n";
117    printf "    <lines count=\"%s\" coverage=\"%s\"/>\n", $summary{$type}->{lines}, $summary{$type}->{linesCoverage};
118    printf "    <branches count=\"%s\" coverage=\"%s\"/>\n", $summary{$type}->{branches}, $summary{$type}->{branchesCoverage};
119    printf "    <conditions count=\"%s\" coverage=\"%s\"/>\n", $summary{$type}->{conds}, $summary{$type}->{condsCoverage};
120    printf "    <calls count=\"%s\" coverage=\"%s\"/>\n", $summary{$type}->{calls}, $summary{$type}->{callsCoverage};
121    printf  "  </summary>\n";
122    printf "</%ss>\n", $type;
123}
124
125print "</coverage>\n";
126