X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=dbsrgits%2FDBIx-Class.git;a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FRow.pm;h=ceed5a6a3e58d702b6301a544e8a4ab33b9ec452;hp=3efe4186c77147d6af4fcfa9d84f87ca6149cbd4;hb=04786a4c19fe3964002b69e8a3dbb291524e0610;hpb=282cccff68e6084bffedc1245f2f667866f6b966 diff --git a/lib/DBIx/Class/Row.pm b/lib/DBIx/Class/Row.pm index 3efe418..ceed5a6 100644 --- a/lib/DBIx/Class/Row.pm +++ b/lib/DBIx/Class/Row.pm @@ -34,7 +34,10 @@ Creates a new row object from column => value mappings passed as a hash ref sub new { my ($class, $attrs) = @_; $class = ref $class if ref $class; - my $new = bless { _column_data => {} }, $class; + + my $new = { _column_data => {} }; + bless $new, $class; + if ($attrs) { $new->throw_exception("attrs must be a hashref") unless ref($attrs) eq 'HASH'; @@ -44,6 +47,7 @@ sub new { $new->store_column($k => $attrs->{$k}); } } + return $new; } @@ -265,7 +269,10 @@ sub copy { delete $col_data->{$col} if $self->result_source->column_info($col)->{is_auto_increment}; } - my $new = bless { _column_data => $col_data }, ref $self; + + my $new = { _column_data => $col_data }; + bless $new, ref $self; + $new->result_source($self->result_source); $new->set_columns($changes); $new->insert; @@ -310,11 +317,13 @@ Called by ResultSet to inflate a result from storage sub inflate_result { my ($class, $source, $me, $prefetch) = @_; #use Data::Dumper; print Dumper(@_); - my $new = bless({ result_source => $source, - _column_data => $me, - _in_storage => 1 - }, - ref $class || $class); + my $new = { + result_source => $source, + _column_data => $me, + _in_storage => 1 + }; + bless $new, (ref $class || $class); + my $schema; foreach my $pre (keys %{$prefetch||{}}) { my $pre_val = $prefetch->{$pre};