if ( blessed($updates) && $updates->isa('DBIx::Class::Row') ) {
return $updates;
}
+ # warn Dumper( $updates ); use Data::Dumper;
# direct column accessors
my %columns;
my %post_updates;
my %other_methods;
my %columns_by_accessor = _get_columns_by_accessor( $self );
-
for my $name ( keys %$updates ) {
my $source = $self->result_source;
if ( $columns_by_accessor{$name}
$columns{$name} = $updates->{$name};
next;
}
- if( !( $source->has_relationship($name) && ref( $updates->{$name} ) ) ){
+ if( !( $source->has_relationship($name) ) ){
$other_methods{$name} = $updates->{$name};
+ next;
}
- next if !$source->has_relationship($name);
my $info = $source->relationship_info($name);
if (
_master_relation_cond(
$post_updates{$name} = $updates->{$name};
}
}
- # warn 'columns: ' . Dumper( \%columns ); use Data::Dumper;
+ # warn 'other: ' . Dumper( \%other_methods ); use Data::Dumper;
my @missing =
grep { !exists $columns{$_} && !exists $fixed_fields{$_} } $self->result_source->primary_columns;
}
else {
my $sub_updates = $updates->{$name};
- $sub_updates = { %$sub_updates, %$resolved } if $resolved && ref( $sub_updates ) eq 'HASH';
my $sub_object;
- if( $info->{attrs}{accessor} eq 'single' && defined $object->$name ){
- $sub_object = recursive_update(
- resultset => $related_result,
- updates => $sub_updates,
- object => $object->$name
- );
+ if( ref $sub_updates ){
+ $sub_updates = { %$sub_updates, %$resolved } if $resolved && ref( $sub_updates ) eq 'HASH';
+ # for might_have relationship
+ if( $info->{attrs}{accessor} eq 'single' && defined $object->$name ){
+ $sub_object = recursive_update(
+ resultset => $related_result,
+ updates => $sub_updates,
+ object => $object->$name
+ );
+ }
+ else{
+ $sub_object =
+ recursive_update( resultset => $related_result, updates => $sub_updates );
+ }
+ }
+ elsif( ! ref $sub_updates ){
+ $sub_object = $related_result->find( $sub_updates );
}
- else{
- $sub_object =
- recursive_update( resultset => $related_result, updates => $sub_updates );
- }
$object->set_from_related( $name, $sub_object );
}
}