Provided by: libur-perl_0.450-1_all bug

NAME

       UR::Object::Ghost - Abstract class for representing deleted objects not yet committed

SYNOPSIS

         my $obj = Some::Class->get(1234);
         $obj->some_method();

         $obj->delete();   # $obj is now a UR::DeletedRef

         $ghost = Some::Class::Ghost->get(1234);
         $ghost->some_method;  # Works

DESCRIPTION

       Ghost objects are a bookkeeping entity for tracking objects which have been loaded from an external data
       source, deleted within the application, and not yet committed.  This implies that they still exist in the
       external data source.  When the Context is committed, the existence of Ghost objects triggers commands to
       the external data sources to also delete the object(s).  When objects are brought into the Context by
       querying a data source, they are compared against any ghosts that may already exist, and matching objects
       are not re-loaded or returned to the user from a call to get().  If the user wants to get Ghost objects,
       they must call get() explicitly on the Ghost class.

       Each class in the system also has an associated Ghost class, the name of which is formed by tacking
       '::Ghost' to the name of the regular class.  Ghost classes do not have ghosts themselves.

       Instances of Ghosts are not instantiated with create() directly, they are created as a concequence of
       deleting a regular object instance.  A Ghost can be turned back into a "live" object by re-creating it,
       or rolling back the transaction it was deleted in.

DEPRECATED

       Applications will not, and should not, normally interact with Ghosts.  The whole Ghost system is
       scheduled for elimination as we refactor the Context and software transaction framework.

SEE ALSO

       UR::Object, UR::Object::Type