X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FInflateColumn.pm;h=de68b23a064a3c627afaed2aa490de5e7e9fdb5d;hb=89d794d486e3c73b489817059e9c3983deebde7f;hp=61efb0046cffc61385ecd8877fc1b746e1afd582;hpb=ba026511a07cd0cc8608b65753fb378e7a74160f;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/InflateColumn.pm b/lib/DBIx/Class/InflateColumn.pm index 61efb00..de68b23 100644 --- a/lib/DBIx/Class/InflateColumn.pm +++ b/lib/DBIx/Class/InflateColumn.pm @@ -127,7 +127,12 @@ analogous to L. sub set_inflated_column { my ($self, $col, $obj) = @_; $self->set_column($col, $self->_deflated_column($col, $obj)); - return $self->store_inflated_column($col, $obj); + if (blessed $obj) { + $self->{_inflated_column}{$col} = $obj; + } else { + delete $self->{_inflated_column}{$col}; + } + return $obj; } =head2 store_inflated_column @@ -141,10 +146,12 @@ as dirty. This is directly analogous to L. sub store_inflated_column { my ($self, $col, $obj) = @_; - unless (blessed($obj)) { - delete $self->{_inflated_column}{$col}; - return undef; + unless (blessed $obj) { + delete $self->{_inflated_column}{$col}; + $self->store_column($col => $obj); + return $obj; } + delete $self->{_column_data}{$col}; return $self->{_inflated_column}{$col} = $obj; } @@ -165,6 +172,14 @@ sub get_column { return $self->next::method($col); } +=head2 get_columns + +Returns the get_column info for all columns as a hash, +just like L. Handles inflation just +like L. + +=cut + sub get_columns { my $self = shift; if (exists $self->{_inflated_column}) { @@ -176,6 +191,13 @@ sub get_columns { return $self->next::method; } +=head2 has_column_loaded + +Like L, but also returns true if there +is an inflated value stored. + +=cut + sub has_column_loaded { my ($self, $col) = @_; return 1 if exists $self->{_inflated_column}{$col};