[kaffe] CVS kaffe (doogie): Start adding description support to the various detected warnings.
Kaffe CVS
cvs-commits at kaffe.org
Thu Dec 9 23:13:57 PST 2004
PatchSet 5592
Date: 2004/12/10 06:20:16
Author: doogie
Branch: HEAD
Tag: (none)
Log:
Start adding description support to the various detected warnings.
Currently, only -Wmissing-braces has a description; this was copied from
the gcc info docs.
Members:
ChangeLog:1.3137->1.3138
scripts/LogWarning.pm:1.1->1.2
scripts/WarningDescription.pm:INITIAL->1.1
scripts/sort-warnings.pl:1.8->1.9
Index: kaffe/ChangeLog
diff -u kaffe/ChangeLog:1.3137 kaffe/ChangeLog:1.3138
--- kaffe/ChangeLog:1.3137 Fri Dec 10 05:36:23 2004
+++ kaffe/ChangeLog Fri Dec 10 06:20:16 2004
@@ -1,3 +1,15 @@
+2004-12-10 Adam Heath <doogie at brainfood.com>
+
+ * scripts/sort-warnings.pl, scripts/LogWarning.pl,
+ scripts/WarningDescription.pl:
+ Start adding description support to the various detected
+ warnings. Currently, only -Wmissing-braces has a description;
+ this was copied from the gcc info docs.
+
+2004-12-10 Adam Heath <doogie at brainfood.com>
+
+ * I'm 30 today!
+
2004-12-09 Adam Heath <doogie at brainfood.com>
* scripts/sort-warnings.pl:
Index: kaffe/scripts/LogWarning.pm
diff -u kaffe/scripts/LogWarning.pm:1.1 kaffe/scripts/LogWarning.pm:1.2
--- kaffe/scripts/LogWarning.pm:1.1 Fri Dec 10 05:07:03 2004
+++ kaffe/scripts/LogWarning.pm Fri Dec 10 06:20:18 2004
@@ -4,14 +4,19 @@
use strict;
use warnings;
+use WarningDescription;
+
sub new {
my $class = shift;
- return bless( {
+ my %data = (
'compiler' => $_[ 0 ],
'simple-name' => $_[ 1 ],
- 'regex' => $_[ 2 ],
- 'description' => $_[ 3 ]
- }, $class );
+ 'regex' => $_[ 2 ]
+ );
+
+ my $self = bless( \%data, $class );
+ $data{ 'description' } = ref( $_[ 3 ] ) ? $_[ 3 ] : new WarningDescription( $self, $_[ 3 ] );
+ return $self;
}
sub compiler {
@@ -25,8 +30,13 @@
sub name {
my $self = shift;
+ return $self->shortName() . $self->index();
+}
+
+sub shortName {
+ my $self = shift;
my $compiler = $self->compiler();
- return ( $compiler ? $compiler . "/" : "" ) . $self->{ 'simple-name' } . $self->index();
+ return ( $compiler ? $compiler . "/" : "" ) . $self->{ 'simple-name' };
}
sub index {
@@ -44,9 +54,9 @@
return $self->{ 'regex' };
}
-sub description {
+sub description_text {
my $self = shift;
- return $self->{ 'description' };
+ return $self->{ 'description' }->description();
}
1;
===================================================================
Checking out kaffe/scripts/WarningDescription.pm
RCS: /home/cvs/kaffe/kaffe/scripts/WarningDescription.pm,v
VERS: 1.1
***************
--- /dev/null Sun Aug 4 19:57:58 2002
+++ kaffe/scripts/WarningDescription.pm Fri Dec 10 07:13:57 2004
@@ -0,0 +1,40 @@
+#!/usr/bin/perl -w
+package WarningDescription;
+
+use strict;
+use warnings;
+
+sub new {
+ my $class = shift;
+ my %data;
+ if ( ref( $_[ 0 ] ) ) {
+ $data{ 'parent' } = shift;
+ } else {
+ $data{ 'compiler' } = shift;
+ $data{ 'simple-name' } = shift;
+ }
+ $data{ 'description' } = shift;
+ return bless( \%data, $class );
+}
+
+sub compiler {
+ my $self = shift;
+ if ( $_[ 0 ] ) {
+ $self->{ 'compiler' } = $_[ 0 ];
+ } else {
+ return $self->{ 'parent' } ? $self->{ 'parent' }->compiler() : $self->{ 'compiler' };
+ }
+}
+
+sub name {
+ my $self = shift;
+ my $compiler = $self->compiler();
+ return ( $compiler ? $compiler . "/" : "" ) . $self->{ 'simple-name' };
+}
+
+sub description {
+ my $self = shift;
+ return $self->{ 'description' };
+}
+
+1;
Index: kaffe/scripts/sort-warnings.pl
diff -u kaffe/scripts/sort-warnings.pl:1.8 kaffe/scripts/sort-warnings.pl:1.9
--- kaffe/scripts/sort-warnings.pl:1.8 Fri Dec 10 05:36:29 2004
+++ kaffe/scripts/sort-warnings.pl Fri Dec 10 06:20:18 2004
@@ -49,6 +49,16 @@
awaiting\ finalization>$
),x;
+
+my @descriptions = (
+ new WarningDescription( 'gcc', '-Wmissing-braces', "Warn if an aggregate or union initializer is not fully bracketed.
+In the following example, the initializer for `a' is not fully
+bracketed, but that for `b' is fully bracketed.
+
+int a[2][2] = { 0, 1, 2, 3 };
+int b[2][2] = { { 0, 1 }, { 2, 3 } };" ),
+);
+
my @warning_types = (
new JikesWarning( 'throws-uncheck', qr/Since type "([^"]+)" is an unchecked exception, it does not need to be listed in the throws clause.$/m, '' ),
new JikesWarning( 'throws-unchecked', qr/Since type "([^"]+)" is an unchecked exception, it does not need to be listed in the throws clause.$/m ),
@@ -154,6 +164,21 @@
}
# </auto-number duplicate entries>
+# <create name warning map>
+my %warning_map;
+for ( my $i = 0; $i < @warning_types; $i++ ) {
+ $warning_map{ $warning_types[ $i ]->name() } = $warning_types[ $i ];
+}
+# </create name warning map>
+
+# <create description name map>
+my %description_map;
+for ( my $i = 0; $i < @descriptions; $i++ ) {
+ $description_map{ $descriptions[ $i ]->name() } = $descriptions[ $i ];
+}
+# </create description name map>
+print STDERR Dumper( \%description_map );
+
#print( STDERR join(',', keys( %warning_types ) )."\n" );
my $text;
my $removeNext = 0;
@@ -220,7 +245,15 @@
print( "\n" );
foreach my $type ( sort( { $error_counts{ $b } <=> $error_counts{ $a } } keys( %errors ) ) ) {
my $h1 = $errors{ $type };
- print( "Type: $type\nCount: $error_counts{ $type }\n" );
+ my $warning = $warning_map{ $type };
+ print( "Type: $type\n" );
+ my $description = $warning->description_text();
+ if ( !$description ) {
+ $description = $description_map{ $warning->shortName() };
+ $description = $description->description() if ( $description );
+ }
+ print( "Description:\n" . join( "", map( { "\t$_\n" } split( "\n", $description ) ) ) ) if ( $description );
+ print( "Count: $error_counts{ $type }\n" );
foreach my $file ( sort( keys( %$h1 ) ) ) {
my @text = ();
my $file_warning_count = 0;
More information about the kaffe
mailing list