X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FTriggers.pm;h=3f6aef7a454da3659ad0b2df47c11ee616363620;hb=93b7182b41791a8253cef12f02805eaab05df91d;hp=46a0d4934f97a77948b1dab5c30e4e0a638d6079;hpb=12bbb33986a29dc27dd3e2b9d082a87f50124ec1;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/CDBICompat/Triggers.pm b/lib/DBIx/Class/CDBICompat/Triggers.pm index 46a0d49..3f6aef7 100644 --- a/lib/DBIx/Class/CDBICompat/Triggers.pm +++ b/lib/DBIx/Class/CDBICompat/Triggers.pm @@ -1,11 +1,17 @@ -package DBIx::Class::CDBICompat::Triggers; +package # hide from PAUSE + DBIx::Class::CDBICompat::Triggers; +use strict; +use warnings; use Class::Trigger; sub insert { my $self = shift; + + return $self->create(@_) unless ref $self; + $self->call_trigger('before_create'); - $self->NEXT::ACTUAL::insert(@_); + $self->next::method(@_); $self->call_trigger('after_create'); return $self; } @@ -15,7 +21,7 @@ sub update { $self->call_trigger('before_update'); my @to_update = keys %{$self->{_dirty_columns} || {}}; return -1 unless @to_update; - $self->NEXT::ACTUAL::update(@_); + $self->next::method(@_); $self->call_trigger('after_update'); return $self; } @@ -23,9 +29,16 @@ sub update { sub delete { my $self = shift; $self->call_trigger('before_delete') if ref $self; - $self->NEXT::ACTUAL::delete(@_); + $self->next::method(@_); $self->call_trigger('after_delete') if ref $self; return $self; } +sub store_column { + my ($self, $column, $value, @rest) = @_; + my $vals = { $column => $value }; + $self->call_trigger("before_set_${column}", $value, $vals); + return $self->next::method($column, $vals->{$column}); +} + 1;