X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/07d690e4c520994e05ba6aa89ee1b5b1c82bbcd4..1df2efffbb760f0c7ad5e32e40807beadc227b80:/SL/DB/Object.pm diff --git a/SL/DB/Object.pm b/SL/DB/Object.pm index 4e6e15c4c..a80640cad 100755 --- a/SL/DB/Object.pm +++ b/SL/DB/Object.pm @@ -110,24 +110,30 @@ sub load { sub save { my ($self, @args) = @_; - my $worker = sub { + + my $result; + my $worker = sub { SL::DB::Object::Hooks::run_hooks($self, 'before_save'); - my $result = $self->SUPER::save(@args); + $result = $self->SUPER::save(@args); SL::DB::Object::Hooks::run_hooks($self, 'after_save', $result); }; - return $self->db->in_transaction ? $worker->() : $self->db->do_transaction($worker); + $self->db->in_transaction ? $worker->() : $self->db->do_transaction($worker); + return $result; } sub delete { my ($self, @args) = @_; - my $worker = sub { + + my $result; + my $worker = sub { SL::DB::Object::Hooks::run_hooks($self, 'before_delete'); - my $result = $self->SUPER::delete(@args); + $result = $self->SUPER::delete(@args); SL::DB::Object::Hooks::run_hooks($self, 'after_delete', $result); }; - return $self->db->in_transaction ? $worker->() : $self->db->do_transaction($worker); + $self->db->in_transaction ? $worker->() : $self->db->do_transaction($worker); + return $result; } 1;