X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FTriggers.pm;h=3f6aef7a454da3659ad0b2df47c11ee616363620;hb=ad7c50fc26e1304855438776d88f4dd074d2fe05;hp=21826f98865fdc1f09d044874bdaa22015ad3a92;hpb=fe5d862bdaa631796cb26e5fea232a81458e68f8;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/CDBICompat/Triggers.pm b/lib/DBIx/Class/CDBICompat/Triggers.pm index 21826f9..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::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::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::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;