| [3420] | 1 | Example to illustrate how to make a class persistent | 
|---|
|  | 2 | using SOPHYA PPF services | 
|---|
|  | 3 | ----------------------------------------------- | 
|---|
|  | 4 | (C) LAL-IN2P3/CNRS   (C) DAPNIA-SPP/CEA | 
|---|
|  | 5 | R. Ansari , 2007 | 
|---|
|  | 6 | ----------------------------------------------- | 
|---|
|  | 7 |  | 
|---|
|  | 8 | 0/ Content : | 
|---|
|  | 9 | - vfs.h : Declaration of the Vfs class Vfs . This is the class | 
|---|
|  | 10 | which we want to make persistent using SOPHYA PPF services | 
|---|
|  | 11 | - vfs.cc : the Vfs class implementation AND its PPF handler ObjFileIO<Vfs> | 
|---|
|  | 12 | - tvfs.cc : the test main program | 
|---|
|  | 13 | - makefile : compiles tvfs.cc and vfs.cc and links them to build tvfs | 
|---|
|  | 14 |  | 
|---|
|  | 15 |  | 
|---|
|  | 16 | 1/ The class should inherit from the SOPHYA::AnyDataObj class. | 
|---|
|  | 17 | In the example here, we want to make the class Vfs persistent | 
|---|
|  | 18 | class Vfs : public SOPHYA::AnyDataObj { | 
|---|
|  | 19 | ... | 
|---|
|  | 20 | } | 
|---|
|  | 21 |  | 
|---|
|  | 22 | 2/ A PPF handler should be implemented . The PPF handler class | 
|---|
|  | 23 | should inherit from SOPHYA::PPersist . The pure virtual methods | 
|---|
|  | 24 | of PPersist class (DataObj() , SetDataObj() , ReadSelf(), WriteSelf() | 
|---|
|  | 25 | has to be implemented. | 
|---|
|  | 26 |  | 
|---|
|  | 27 | class PPFHandlerVfs : public SOPHYA::PPersist { | 
|---|
|  | 28 | public: | 
|---|
|  | 29 | virtual SOPHYA::AnyDataObj* DataObj(); | 
|---|
|  | 30 | virtual void       SetDataObj(SOPHYA::AnyDataObj &); | 
|---|
|  | 31 | protected: | 
|---|
|  | 32 | virtual void       ReadSelf(SOPHYA::PInPersist&); | 
|---|
|  | 33 | virtual void       WriteSelf(SOPHYA::POutPersist&) const; | 
|---|
|  | 34 | } | 
|---|
|  | 35 |  | 
|---|
|  | 36 |  | 
|---|
|  | 37 | It is possible to use the template class SOPHYA::ObjFileIO<T>, and | 
|---|
|  | 38 | specialize it for the tharget class (here SOPHYA::ObjFileIO<Vfs>), | 
|---|
|  | 39 | by defining the two methods : | 
|---|
|  | 40 | SOPHYA::ObjFileIO<Vfs>::ReadSelf(SOPHYA::PInPersist&) | 
|---|
|  | 41 | SOPHYA::ObjFileIO<Vfs>::WriteSelf(SOPHYA::POutPersist&) const | 
|---|
|  | 42 |  | 
|---|
|  | 43 | 3/ If it is NOT possible to have the target class inherit from AnyDataObj, | 
|---|
|  | 44 | a wrapper class should be used. The same class can play the role of wrapper | 
|---|
|  | 45 | AND the PPF handler. | 
|---|
|  | 46 | (See the PPF handler / wrapper class for STL vectors : | 
|---|
|  | 47 | SOPHYA::PPFWrapperSTLVector<T> in file BaseTools/ppfwrapstlv.h ) | 
|---|
|  | 48 |  | 
|---|
|  | 49 |  | 
|---|
|  | 50 | 4/ Implement the ReadSelf() and WriteSelf() methods of the PPF handler. | 
|---|
|  | 51 | All the I/O services from the following classes can be used : | 
|---|
|  | 52 | - PPFBinaryIOStrem , PPFBinaryInputStream , PInPersist | 
|---|
|  | 53 | - PPFBinaryIOStrem , PPFBinaryOutputStream , POutPersist | 
|---|
|  | 54 | Writing and reading of the embeded objects for which a handler has been registered | 
|---|
|  | 55 | can simply be performed by : | 
|---|
|  | 56 | POutPersist::PutObject()   PInPersist::GetObject() | 
|---|
|  | 57 |  | 
|---|
|  | 58 | ==> The services associated with nametags (PPFBinaryOutputStream::WriteNameTag() | 
|---|
|  | 59 | PPFBinaryInputStream::GotoNameTag() ... ) are NOT intented to be used in | 
|---|
|  | 60 | WriteSelf() , ReadSelf() | 
|---|
|  | 61 |  | 
|---|
|  | 62 |  | 
|---|
|  | 63 | 5/ The new PPF handler, as well as the list of classes it can handle has to be | 
|---|
|  | 64 | registered prior to use PPF read/write for the target classes. This must be | 
|---|
|  | 65 | performed during the initialization phase, for example at the beginning of the | 
|---|
|  | 66 | main() program. Another possibility is to use a module initializer | 
|---|
|  | 67 | (See SophyaInitiator class in file BaseTools/sophyainit.h ) | 
|---|
|  | 68 | and declare a static instance of the class (Note that this works only if | 
|---|
|  | 69 | the system loader handles correcly the call of constructor | 
|---|
|  | 70 | for the statically declared objects) | 
|---|
|  | 71 |  | 
|---|
|  | 72 | The registration can be performed using the CPP macros defined in BaseTools/ppersist.h | 
|---|
|  | 73 |  | 
|---|
|  | 74 | // First, register the PPF handler ObjFileIO<Vfs> | 
|---|
|  | 75 | PPRegister(ObjFileIO<Vfs>); | 
|---|
|  | 76 | // Register the list of classes which can be handled by ObjFileIO<Vfs> | 
|---|
|  | 77 | DObjRegister(ObjFileIO<Vfs>, Vfs); | 
|---|