=head1 NAME

Rose::DBx::Role::NestTransaction - Nested transactions support for Rose::DB

=head1 SYNOPSIS

   # Define yout DB class
   package MyDB;
   use base 'Rose::DB';

   use Role::Tiny::With;
   with 'Rose::DBx::Role::NestTransaction';

   # Somewhere in your code
   MyDB->new_or_cached->nest_transaction(sub {
       User->new( name => 'name' )->save();
   });

=head1 DESCRIPTION

This module provides a role for Rose::DB. Just consume the role in your Rose::DB subclass

=head1 METHODS

=head2 nest_transaction

These methods behaves like do_transaction but it repects existing transactions and do not start new one if the transaction already started. On error it revert transaction and rethrow error

=head1 AUTHOR

Viktor Turskyi, C<< <koorchik at cpan.org> >>

=head1 BUGS

Please report any bugs or feature requests to Github L<https://github.com/koorchik/Rose-DBx-Role-NestTransaction>

=head1 LICENSE AND COPYRIGHT

Copyright 2012 Viktor Turskyi.

This program is free software; you can redistribute it and/or modify it
under the terms of either: the GNU General Public License as published
by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.

=cut