]> Dogcows Code - chaz/p5-DBIx-Class-ResultSet-RecursiveUpdate/commitdiff
using non-column, non-relation methods
authorzby <zby@bd8105ee-0ff8-0310-8827-fb3f25b6796d>
Wed, 6 May 2009 19:12:19 +0000 (19:12 +0000)
committerzby <zby@bd8105ee-0ff8-0310-8827-fb3f25b6796d>
Wed, 6 May 2009 19:12:19 +0000 (19:12 +0000)
lib/DBIx/Class/ResultSet/RecursiveUpdate.pm
t/var/dvdzbr.db

index 884cf0584d0ebfdef4672ebe30617a1949a2e4da..8992718ae78e52bbe1af5818093d2b182bce6e8d 100644 (file)
@@ -40,6 +40,7 @@ sub recursive_update {
     # relations that that should be done after the row is inserted into the database
     # like has_many and might_have
     my %post_updates;
+    my %other_methods;
     my %columns_by_accessor = _get_columns_by_accessor( $self );
 
     for my $name ( keys %$updates ) {
@@ -51,6 +52,9 @@ sub recursive_update {
             $columns{$name} = $updates->{$name};
             next;
         }
+        if( !( $source->has_relationship($name) && ref( $updates->{$name} ) ) ){
+            $other_methods{$name} = $updates->{$name};
+        }
         next if !$source->has_relationship($name);
         my $info = $source->relationship_info($name);
         if (
@@ -78,6 +82,9 @@ sub recursive_update {
     for my $name ( keys %columns ) {
         $object->$name( $updates->{$name} );
     }
+    for my $name ( keys %other_methods) {
+        $object->$name( $updates->{$name} ) if $object->can( $name );
+    }
     for my $name ( keys %pre_updates ) {
         my $info = $object->result_source->relationship_info($name);
         _update_relation( $self, $name, $updates, $object, $info );
index 73c1fcd598d63602623953b284c2cc14118a6dae..7eb36bb5e2e1d46db41dc335067c2696c02c0a08 100644 (file)
Binary files a/t/var/dvdzbr.db and b/t/var/dvdzbr.db differ
This page took 0.023961 seconds and 4 git commands to generate.