warn about the new _id stripping only when there was an _id, fix warning count in...
Rafael Kitover [Fri, 19 Feb 2010 06:46:17 +0000 (01:46 -0500)]
lib/DBIx/Class/Schema/Loader/RelBuilder.pm
t/lib/dbixcsl_common_tests.pm

index b36b62b..4121f64 100644 (file)
@@ -249,14 +249,14 @@ sub generate_code {
             my $colnames = q{_} . join(q{_}, @$local_cols);
             my $old_relname = #< TODO: remove me after 0.05003 release
                 $local_relname = lc($local_table) . $colnames;
-            $local_relname =~ s/_id$//; #< strip off any trailing _id
+            my $stripped_id = $local_relname =~ s/_id$//; #< strip off any trailing _id
             $local_relname = $self->_inflect_plural( $local_relname );
             $remote_relname .= $colnames if keys %cond > 1;
 
             # TODO: remove me after 0.05003 release
             $old_relname = $self->_inflect_plural( $old_relname );
-            warn __PACKAGE__." $VERSION: warning, stripping trailing _id from ${remote_class} relation '$old_relname', renaming to '$local_relname'.  This behavior is new as of 0.05003.\n";
-
+            warn __PACKAGE__." $VERSION: warning, stripping trailing _id from ${remote_class} relation '$old_relname', renaming to '$local_relname'.  This behavior is new as of 0.05003.\n"
+                if $stripped_id;
         } else {
             $local_relname = $self->_inflect_plural(lc $local_table);
         }
index 6f21ba6..7fa28cb 100644 (file)
@@ -148,6 +148,8 @@ sub setup_schema {
 
        $warn_count++ for grep /^Bad table or view/, @loader_warnings;
 
+       $warn_count++ for grep /stripping trailing _id/, @loader_warnings;
+
        my $vendor = $self->{vendor};
        $warn_count++ for grep /${vendor}_\S+ has no primary key/,
            @loader_warnings;