X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FRow.pm;h=061184de94d5a2435bbad28c16558ae50ea0825e;hb=6a94f7f49486ca5ad76cfaf1e380bbb787da7e0e;hp=38f6a82de55801139c58820102219aba9711a6a3;hpb=076a6864aae318ebaf7ccbe00e7e9edc2b20d0fa;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Row.pm b/lib/DBIx/Class/Row.pm index 38f6a82..061184d 100644 --- a/lib/DBIx/Class/Row.pm +++ b/lib/DBIx/Class/Row.pm @@ -3,6 +3,8 @@ package DBIx::Class::Row; use strict; use warnings; +use base qw/DBIx::Class/; + =head1 NAME DBIx::Class::Row - Basic row methods @@ -33,7 +35,8 @@ sub new { if ($attrs) { $new->throw("attrs must be a hashref" ) unless ref($attrs) eq 'HASH'; while (my ($k, $v) = each %{$attrs}) { - $new->store_column($k => $v) if exists $class->_columns->{$k}; + die "No such column $k on $class" unless $class->has_column($k); + $new->store_column($k => $v); } } return $new; @@ -121,13 +124,6 @@ sub update { return $self; } -sub ident_condition { - my ($self) = @_; - my %cond; - $cond{$_} = $self->get_column($_) for keys %{$self->_primaries}; - return \%cond; -} - =item delete $obj->delete @@ -170,7 +166,7 @@ Fetches a column value sub get_column { my ($self, $column) = @_; $self->throw( "Can't fetch data as class method" ) unless ref $self; - $self->throw( "No such column '${column}'" ) unless $self->_columns->{$column}; + $self->throw( "No such column '${column}'" ) unless $self->has_column($column); return $self->{_column_data}{$column} if exists $self->{_column_data}{$column}; return undef; @@ -209,7 +205,7 @@ sub set_column { =item set_columns - my $copy = $orig->copy({ $col => $val, ... }); + my $copy = $orig->set_columns({ $col => $val, ... }); Set more than one column value at once. @@ -241,7 +237,7 @@ Sets a column value without marking it as dirty sub store_column { my ($self, $column, $value) = @_; $self->throw( "No such column '${column}'" ) - unless $self->_columns->{$column}; + unless $self->has_column($column); $self->throw( "set_column called for ${column} without value" ) if @_ < 3; return $self->{_column_data}{$column} = $value; @@ -251,7 +247,7 @@ sub _row_to_object { my ($class, $cols, $row) = @_; my %vals; $vals{$cols->[$_]} = $row->[$_] for 0 .. $#$cols; - my $new = $class->new(\%vals); + my $new = bless({ _column_data => \%vals }, ref $class || $class); $new->in_storage(1); return $new; }