/usr/include/BALL/CONCEPT/persistentObject.h is in libball1.4-dev 1.4.3~beta1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 | // -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
#ifndef BALL_CONCEPT_PERSISTENTOBJECT_H
#define BALL_CONCEPT_PERSISTENTOBJECT_H
#ifndef BALL_CONCEPT_OBJECT_H
# include <BALL/CONCEPT/object.h>
#endif
namespace BALL
{
class PersistenceManager;
/** The persistent object.
Each object that needs persistence, has to be derived from
PersistentObject to define an interface to the
\link PersistenceManager PersistenceManager \endlink .
\par
The class itself has no functionality except for the <tt>operator >></tt>.
\par
\ingroup Persistence
*/
class BALL_EXPORT PersistentObject
: public Object
{
public:
/** @name Constructors and Destructors
*/
//@{
/** Default constructor.
The default constructor has no functionality.
*/
PersistentObject()
: Object()
{
}
/** Destructor.
The destructor has no functionality.
*/
virtual ~PersistentObject()
{
}
//@}
/** @name Persistent Writing and Reading
*/
//@{
/** Stream operator.
This operator is used to serialize an instance of PersistentObject.
The method first calls <tt>pm.startOutput()</tt> to write the necessary
headers. Then, <tt>persistentWrite(pm)</tt> is called to serialize
the object. Finally, a call to <tt>pm.stopOutput()</tt> writes all
dependend objects and the end marker to the persistent stream.
@param pm the persistence manager
\throws Exception::GeneralException
@return the persistence manager (for chaining multiple output
operations)
*/
PersistenceManager& operator >> (PersistenceManager& pm) const;
/** Serialize the object.
This method serializes the object by calls to Layer 1 methods of
\link PersistenceManager PersistenceManager \endlink . The first method in the implementation
of persistentRead should be a call to
<tt>pm.writeObjectHeader(*this, name)</tt>. Likewise the last method in
this method should be <tt>pm.writeObjectTrailer(name)</tt>.
@param pm the persistence manager
@param name the name of the object (0 for writing base classes)
\throws Exception::GeneralException
*/
virtual void persistentWrite(PersistenceManager& pm, const char* name = "") const;
/** Deserialize the object.
This method reads the contents of an persistent object into an
(already existing!) object. It is implemented using Layer 1
commands of PersistenceManager. To each <b>write</b> command used
in persistentWrite, there should be exactly the same call to a read
command in persistentRead. Only the header and trailer
(writeObjectHeader/writeObjectTrailer calls) have to be omitted, as
the header is read before this method is called (the object type
has to be known in advance to dynamically create the object).
@param pm the PersistenceManager
\throws Exception::GeneralException
*/
virtual void persistentRead(PersistenceManager& pm);
/** Finalize the deserialization.
This method is called for all objects after their pointers have
been demangled. It is intended for the adaptation of internal data
structures. For example, the bond class has to swap <tt>first_</tt>
and <tt>second_</tt> depending on the order of the atoms. It is
usually left unimplemented.
\throws Exception::GeneralException
*/
virtual void finalize()
{
}
//@}
};
} // namespace BALL
#endif // BALL_CONCEPT_PERSISTENTOBJECT_H
|