Updated scripts for filtering BC reports
authorMaciej Seroka <maciejs@symbian.org>
Wed, 07 Jul 2010 12:42:22 +0100 (2010-07-07)
changeset 305 247cb9582bd0
parent 302 c1b745b16f58
child 306 73890f073898
Updated scripts for filtering BC reports
bc_tools/ha_filter.pl
bc_tools/la_filter.pl
--- a/bc_tools/ha_filter.pl	Wed Jun 30 16:19:02 2010 +0100
+++ b/bc_tools/ha_filter.pl	Wed Jul 07 12:42:22 2010 +0100
@@ -24,13 +24,15 @@
 my $destfile;
 my $pkg_destfile;
 my $del_ok_issues = 1; # This variable determines whether to delete OK issues first.
-my $del_comp_issues = 0; # This variable determines whether to delete Compilation errors.
-my $del_boost_issues = 1; # This variable determines whether to delete issues for Boost API headers.
+my $del_comp_issues = 1; # This variable determines whether to delete Compilation errors.
+my $del_boost_issues = 0; # This variable determines whether to delete issues for Boost API headers.
 my $tsv_file; # If defined then sub-reports per package will be generated.
 my $n;
 my $m;
 my $p;
 my $file_name;
+my $type_id;
+my $identity_description;
 my $delete_node;
 my @lines;
 my $line;
@@ -193,6 +195,8 @@
 	$n = 0;
 	while ($n < $header_num) {
 		$file_name = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'headerfile'}->[$n]->{'shortname'}->[0];
+		$type_id = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'headerfile'}->[$n]->{'issue'}->[0]->{'typeid'}->[0];
+		$identity_description = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'headerfile'}->[$n]->{'issue'}->[0]->{'identitydescription'}->[0];
 		$pkg_found = 0;
 		open FILE, "<$tsv_file" or die("Failed to read $tsv_file: $!\n");
 		while ($line = <FILE>)
@@ -201,7 +205,7 @@
 			($hdr_to_pkg,$package) = split /\t/,$line;
 			$hdr_to_pkg =~ s/\//\\/g;
 			$hdr_to_pkg =~ s/\\epoc32\\include\\//;
-			if (lc($file_name) eq lc($hdr_to_pkg)) {
+			if ((lc($file_name) eq lc($hdr_to_pkg)) && (!(($type_id eq "0") && ($identity_description eq "File")))) {
 				print "Package found: $package for header file: $file_name \n";
 				$pkg_found = 1;
 				$pkgs_num = @pkgs;
@@ -225,7 +229,7 @@
 		}
 		close FILE;
 		if ($pkg_found == 0) {
-			print "Package not found for header file: $file_name \n";
+			print "Removed header file: $file_name \n";
 			$nopkg++;
 			$n++;
 		} else { # Delete the node.
@@ -263,6 +267,8 @@
 		print "Processing header files for $current_pkg... \n";
 		while ($n < $header_num) {
 			$file_name = $temp_report->{'bbcresults'}->{'issuelist'}->[0]->{'headerfile'}->[$n]->{'shortname'}->[0];
+			$type_id = $temp_report->{'bbcresults'}->{'issuelist'}->[0]->{'headerfile'}->[$n]->{'issue'}->[0]->{'typeid'}->[0];
+			$identity_description = $temp_report->{'bbcresults'}->{'issuelist'}->[0]->{'headerfile'}->[$n]->{'issue'}->[0]->{'identitydescription'}->[0];
 			$pkg_found = 0;
 			open FILE, "<$tsv_file" or die("Failed to read $tsv_file: $!\n");
 			while ($line = <FILE>)
@@ -271,7 +277,7 @@
 				($hdr_to_pkg,$package) = split /\t/,$line;
 				$hdr_to_pkg =~ s/\//\\/g;
 				$hdr_to_pkg =~ s/\\epoc32\\include\\//;	
-				if ((lc($file_name) eq lc($hdr_to_pkg)) && ($current_pkg eq $package)) {
+				if ((lc($file_name) eq lc($hdr_to_pkg)) && ($current_pkg eq $package) && (!(($type_id eq "0") && ($identity_description eq "File")))) {
 					$pkg_found = 1;
 					print "$file_name added to $package \n";
 				}
--- a/bc_tools/la_filter.pl	Wed Jun 30 16:19:02 2010 +0100
+++ b/bc_tools/la_filter.pl	Wed Jul 07 12:42:22 2010 +0100
@@ -30,7 +30,8 @@
 my $counter;
 my $short_name;
 my $del_ok_issues = 1; # This variable determines whether to delete OK issues first.
-my $gen_missing_report = 1; # This variable determines whether to produce report for missing libraries.
+my $del_non_public = 1; # This variable determines whether to delete non-public API issues.
+my $gen_missing_report = 0; # This variable determines whether to produce report for missing libraries.
 my $issues_num;
 my $issue_name;
 my ($xref_name, $xref_type, $xref_line, $xref_hdr, $xref_def);
@@ -40,7 +41,7 @@
 my $check_against_xref;
 my $temp_lib_num;
 my $temp_counter;
-my $sub_reports = 1; # This variable determines whether to generate sub-reports per package.
+my $sub_reports = 0; # This variable determines whether to generate sub-reports per package.
 my @lines_to_ignore = ("\\\\build\\\\", "\\\\compsupp\\\\", "\\\\uc_dll."); # This is the list of key words based on which a line potentially containing a package name will be ignored (skipped).
 my @pkgs;
 my $baselinedlldir;
@@ -78,7 +79,7 @@
 usage_error(), unless (defined($report));
 
 # --xref-file is mandatory.
-usage_error(), unless (defined($xref_file));
+usage_error(), unless ((defined($xref_file)) or (!($del_non_public)));
 
 # Define output files based on the libraries report name.
 $destfile = "filtered_" . $report;
@@ -125,29 +126,30 @@
 }
 
 # Delete non-public API issues.
-$n = 0;
-$counter = 1;
-$temp_counter = 0;
-$temp_lib_num = $lib_num;
-# Temporary variables - namespace fix.
-my $count;
-my $temp_issue;
-while ($n < $lib_num) {
-	print "Processing library: $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'shortname'}->[0] ( $counter out of $temp_lib_num )\n";
-	$issues_num = @{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}};
-	$m = 0;
-	while ($m < $issues_num) {
-		$delete_node = 1;
-		$issue_name = "";
-		# Get issue name based on funcname or newfuncname (If both available get newfuncname).
-		if ($current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'newfuncname'}->[0]) {
-			$issue_name = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'newfuncname'}->[0];
-#			print "newfuncname - $issue_name \n";
-		} elsif ($current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'funcname'}->[0]) {
-			$issue_name = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'funcname'}->[0];
-#			print "funcname - $issue_name \n";
-		}
-		if ($issue_name) {
+if ($del_non_public) {
+	$n = 0;
+	$counter = 1;
+	$temp_counter = 0;
+	$temp_lib_num = $lib_num;
+	# Temporary variables - namespace fix.
+	my $count;
+	my $temp_issue;
+	while ($n < $lib_num) {
+		print "Processing library: $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'shortname'}->[0] ( $counter out of $temp_lib_num )\n";
+		$issues_num = @{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}};
+		$m = 0;
+		while ($m < $issues_num) {
+			$delete_node = 1;
+			$issue_name = "";
+			# Get issue name based on funcname or newfuncname (If both available get newfuncname).
+			if ($current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'newfuncname'}->[0]) {
+				$issue_name = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'newfuncname'}->[0];
+#				print "newfuncname - $issue_name \n";
+			} elsif ($current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'funcname'}->[0]) {
+				$issue_name = $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'funcname'}->[0];
+#				print "funcname - $issue_name \n";
+			}
+			if ($issue_name) {
 			# Leave only Class name - modified to fix namespace issue.
 #			$issue_name =~ s/::.*//;
 			# Find '(' and delete all characters following it.
@@ -165,63 +167,64 @@
 				# Leave only the 1st part (xx) for other issues.
 				$issue_name =~ s/::.*//;
 			}
-			# Find '<' and delete all characters following it, e.g. TMeta<CommsDat
-			$issue_name =~ s/<.*//;
-			# Delete for example: 'typeinfo for ', 'vtable for ', etc. - will only be done for the likes of vtable for CTransportSelfSender (without '::').
-			$issue_name =~ s/^.* //; 
-#			print $issue_name . "\n";
-			# Check if Class/Macro already on the internal non-public API list.
-			$check_against_xref = 1;
-			foreach $current_item (@non_public_list) {
-				if (lc($issue_name) eq lc($current_item)) {	# Keep the node to be deleted and skip checking against the xref file.
-					$check_against_xref = 0;
-					last;
-				}
-			}
-			if ($check_against_xref) {
-				# Load xref file.
-				open FILE, "<$xref_file" or print "Failed to read $xref_file: $!\n" and return;
-				while ($line = <FILE>)
-				{
-					chomp $line;
-					($xref_name, $xref_type, $xref_line, $xref_hdr, $xref_def) = split /\s+/,$line;
-					if (lc($issue_name) eq lc($xref_name)) { # Mark the node to NOT be deleted.
-						# Insert reference to header file.
-						$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'refheaderfile'}->[0] = $xref_hdr;
-						$delete_node = 0;
-						print "Found issue: $issue_name in public header file: $xref_hdr\n";
+				# Find '<' and delete all characters following it, e.g. TMeta<CommsDat
+				$issue_name =~ s/<.*//;
+				# Delete for example: 'typeinfo for ', 'vtable for ', etc. - will only be done for the likes of vtable for CTransportSelfSender (without '::').
+				$issue_name =~ s/^.* //; 
+#				print $issue_name . "\n";
+				# Check if Class/Macro already on the internal non-public API list.
+				$check_against_xref = 1;
+				foreach $current_item (@non_public_list) {
+					if (lc($issue_name) eq lc($current_item)) {	# Keep the node to be deleted and skip checking against the xref file.
+						$check_against_xref = 0;
 						last;
 					}
 				}
-				# Close xref file.
-				close FILE;
+				if ($check_against_xref) {
+					# Load xref file.
+					open FILE, "<$xref_file" or die("Failed to read $xref_file: $!\n");
+					while ($line = <FILE>)
+					{
+						chomp $line;
+						($xref_name, $xref_type, $xref_line, $xref_hdr, $xref_def) = split /\s+/,$line;
+						if (lc($issue_name) eq lc($xref_name)) { # Mark the node to NOT be deleted.
+							# Insert reference to header file.
+							$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}->[$m]->{'refheaderfile'}->[0] = $xref_hdr;
+							$delete_node = 0;
+							print "Found issue: $issue_name in public header file: $xref_hdr\n";
+							last;
+						}
+					}
+					# Close xref file.
+					close FILE;
+				}
+			} else { # No newfuncname/funcname available (e.g. typeinfo only for missing DLLs or typeid only for not shown ones).
+#				print "Unclassified issue in $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'shortname'}->[0] \n";
 			}
-		} else { # No newfuncname/funcname available (e.g. typeinfo only for missing DLLs or typeid only for not shown ones).
-#			print "Unclassified issue in $current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'shortname'}->[0] \n";
+			if ($delete_node) { # Delete the issue (Not public API-related).
+				splice(@{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}},$m, 1);
+				$issues_num--;
+				if (($issue_name) && ($check_against_xref)) { # Looked for not found in the xref file - add the issue to the internal non-public API list.
+					push @non_public_list, $issue_name;
+				}
+				$temp_counter++; # To count how many issues deleted.
+			} else {
+				$m++;
+			}
 		}
-		if ($delete_node) { # Delete the issue (Not public API-related).
-			splice(@{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}->[$n]->{'issue'}},$m, 1);
-			$issues_num--;
-			if (($issue_name) && ($check_against_xref)) { # Looked for not found in the xref file - add the issue to the internal non-public API list.
-				push @non_public_list, $issue_name;
-			}
-			$temp_counter++; # To count how many issues deleted.
+		if ($issues_num == 0) { # If all issues deleted - remove the whole entry.
+			splice(@{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}},$n, 1);
+			$lib_num--;
 		} else {
-			$m++;
+			$n++;
 		}
+		$counter++;
 	}
-	if ($issues_num == 0) { # If all issues deleted - remove the whole entry.
-		splice(@{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}},$n, 1);
-		$lib_num--;
-	} else {
-		$n++;
-	}
-	$counter++;
+	print "$temp_counter issue(s) has been deleted \n";
+	# Get number of libraries again.
+	$lib_num = @{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}};
+	print "Final number of libraries with public API-related issues: $lib_num \n";
 }
-print "$temp_counter issue(s) has been deleted \n";
-# Get number of libraries again.
-$lib_num = @{$current_report->{'bbcresults'}->{'issuelist'}->[0]->{'library'}};
-print "Final number of libraries with public API-related issues: $lib_num \n";
 
 # Write new XML to dest file.
 open OUT,">$destfile" or die("Cannot open file \"$destfile\" for writing. $!\n");