Provided by: libur-perl_0.470+ds-2_all bug

NAME

       UR::Context::AutoUnloadPool - Automatically unload objects when scope ends

SYNOPSIS

         my $not_unloaded = Some::Class->get(...);
         do {
           my $guard = UR::Context::AutoUnloadPool->create();
           my $object = Some::Class->get(...);  # load an object from the database
           ...                                  # load more things
         };  # $guard goes out of scope - unloads objects

DESCRIPTION

       UR Objects retrieved from the database normally live in the object cache for the life of
       the program.  When a UR::Context::AutoUnloadPool is instantiated, it tracks every object
       loaded during its life.  The Pool's destructor calls unload() on those objects.

       Changed objects and objects loaded before before the Pool is created will not get
       unloaded.

METHODS

       create
             my $guard = UR::Context::AutoUnloadPool->create();

           Creates a Pool object.  All UR Objects loaded from the database during this object's
           lifetime will get unloaded when the Pool goes out of scope.

       delete
             $guard->delete();

           Invalidates the Pool object.  No objects are unloaded.  When the Pool later goes out
           of scope, no objects will be unloaded.

SEE ALSO

       UR::Object, UR::Context