X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FRelationship%2FManyToMany.pm;h=ea004e347ed4fe3c00f9e352e6c1d5d516c39baa;hb=78060df8cb43cafd81304f386d7111510a4b8f9d;hp=8b29bf4ffc06c860fd3f9cc6f90c45ba615ea361;hpb=303cf522b1c2841ecab3056cfbb4314fa05151a2;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Relationship/ManyToMany.pm b/lib/DBIx/Class/Relationship/ManyToMany.pm index 8b29bf4..ea004e3 100644 --- a/lib/DBIx/Class/Relationship/ManyToMany.pm +++ b/lib/DBIx/Class/Relationship/ManyToMany.pm @@ -10,40 +10,62 @@ sub many_to_many { no strict 'refs'; no warnings 'redefine'; - my $remove_link_meth = "remove_from_$rel"; - my $add_link_meth = "add_to_$rel"; + my $add_meth = "add_to_${meth}"; + my $remove_meth = "remove_from_${meth}"; + my $set_meth = "set_${meth}"; *{"${class}::${meth}"} = sub { my $self = shift; my $attrs = @_ > 1 && ref $_[$#_] eq 'HASH' ? pop(@_) : {}; + my @args = ($f_rel, @_ > 0 ? @_ : undef, { %{$rel_attrs||{}}, %$attrs }); $self->search_related($rel)->search_related( $f_rel, @_ > 0 ? @_ : undef, { %{$rel_attrs||{}}, %$attrs } ); }; - *{"${class}::add_to_${meth}"} = sub { + *{"${class}::${add_meth}"} = sub { my $self = shift; @_ > 0 or $self->throw_exception( - "$add_link_meth needs an object or hashref" + "${add_meth} needs an object or hashref" ); my $source = $self->result_source; my $schema = $source->schema; my $rel_source_name = $source->relationship_info($rel)->{source}; my $rel_source = $schema->resultset($rel_source_name)->result_source; my $f_rel_source_name = $rel_source->relationship_info($f_rel)->{source}; - my $f_rel_rs = $schema->resultset($f_rel_source_name); - my $obj = ref $_[0] - ? ( ref $_[0] eq 'HASH' ? $f_rel_rs->create($_[0]) : $_[0] ) - : ( $f_rel_rs->create({@_}) ); + my $f_rel_rs = $schema->resultset($f_rel_source_name)->search({}, $rel_attrs||{}); + + my $obj; + if (ref $_[0]) { + if (ref $_[0] eq 'HASH') { + $obj = $f_rel_rs->create($_[0]); + } else { + $obj = $_[0]; + } + } else { + $obj = $f_rel_rs->create({@_}); + } + + my $link_vals = @_ > 1 && ref $_[$#_] eq 'HASH' ? pop(@_) : {}; my $link = $self->search_related($rel)->new_result({}); $link->set_from_related($f_rel, $obj); + $link->set_columns($link_vals); $link->insert(); }; - *{"${class}::remove_from_${meth}"} = sub { + *{"${class}::${set_meth}"} = sub { + my $self = shift; + @_ > 0 or $self->throw_exception( + "{$set_meth} needs a list of objects or hashrefs" + ); + $self->search_related($rel, {})->delete; + $self->$add_meth(shift) while (defined $_[0]); + }; + + *{"${class}::${remove_meth}"} = sub { my $self = shift; @_ > 0 && ref $_[0] ne 'HASH' - or $self->throw_exception("$remove_link_meth needs an object"); + or $self->throw_exception("${remove_meth} needs an object"); my $obj = shift; my $rel_source = $self->search_related($rel)->result_source; my $cond = $rel_source->relationship_info($f_rel)->{cond};