source: Sophya/trunk/SophyaLib/BaseTools/ppersist.h@ 3858

Last change on this file since 3858 was 2805, checked in by ansari, 20 years ago

MAJ commentaires pour documentation doxygen - Reza 9 Juin 2005

File size: 9.7 KB
RevLine 
[241]1// This may look like C code, but it is really -*- C++ -*-
2
[219]3#ifndef PPERSIST_H_SEEN
4#define PPERSIST_H_SEEN
5
[241]6// Flat file persistance, similar to Java serialization
7//
8// E. Aubourg CEA DAPNIA/SPP 1999
[802]9// R. Ansari LAL IN2P3/CNRS 03/2000
[219]10
[2475]11// -------------------- Historique -----------------------
12// Separe en deux (CVS version 1.19 - ppersist.h)
13// Classes PPFBinaryIn/OutputStream ds ppfbinstream.h
14// -------------------------------------------------------
[219]15
[2475]16
[241]17#include "machdefs.h"
18#include "pexceptions.h"
[742]19#include "gnumd5.h"
[2475]20#include "ppfbinstream.h"
[241]21
[219]22#include <string>
23#include <map>
[241]24#include <vector>
25#include <typeinfo>
[219]26
27
[269]28// Classe de base pour les objets qui peuvent devenir PPersist
29
[552]30namespace SOPHYA {
[241]31
[269]32 class AnyDataObj;
33
[241]34 class PIOPersist;
35 class PInPersist;
36 class POutPersist;
37 class PPersist;
[219]38
[895]39//! Persistent (delegate or mixin) base class
[241]40 class PPersist {
41 public:
42 virtual ~PPersist() {}
[219]43
[241]44 void Write(string const& fn) const;
45 void Read(string const& fn);
[219]46
[241]47 virtual void Write(POutPersist&) const;
48 void Read(PInPersist& s); // Reads the type tag and the object
49 void Write(POutPersist&, string const& tag) const;
50 void ReadAtTag(PInPersist& s, string const& tag);
[269]51
[754]52 virtual AnyDataObj* DataObj()=0; // Retourne l'objet reel
[802]53 virtual void SetDataObj(AnyDataObj &)=0;
[754]54
[802]55 virtual uint_8 getMemOId() const ; // Renvoie l'identificateur de l'objet - par defaut=0
56 // Ces deux methodes doivent etre redefinies si getMemOId() renvoie non nul (>0)
57 virtual void ShareDataReference(PPersist &);
58 virtual PPersist* CloneSharedReference();
59 // doit etre surcharge pour renvoyer un mem-oid correct
[241]60 protected:
61 virtual void ReadSelf(PInPersist&)=0;
[802]62 virtual void WriteSelf(POutPersist&) const=0;
[219]63
[241]64 friend class PInPersist;
65 friend class POutPersist;
[219]66 };
67
68
69
[895]70// Handles (statically) the registration of classes.
[219]71
[241]72 class PIOPersist {
73 public:
74 typedef PPersist* (*ClassCreatorFunc)();
75
[802]76 static void RegisterPPHandlerClass(uint_8 classId, string ppclass_name, ClassCreatorFunc f);
77 static void RegisterDataObjClass(uint_8 classId, string class_name);
78
[2657]79 static void ListPPHandlers();
80 static void ListDataObjClasses();
81
[241]82 static ClassCreatorFunc FindCreatorFunc(uint_8 classId);
[802]83
84 static string getPPClassName(uint_8 classId);
85 static uint_8 getPPClassId(string const & typ_name);
86 static uint_8 getPPClassId(PPersist const & ppo);
87 static string getDataObjClassName(uint_8 classId);
88 static uint_8 getDataObjClassId(string const & typ_name);
89 static uint_8 getDataObjClassId(AnyDataObj const & o);
90
[1202]91 static uint_8 Hash(string const& typname);
[742]92 static MD5_CONTEXT ctx;
[241]93
[269]94 static void Initialize(); // Pour initialiser classList
[802]95
96
[241]97 private:
[219]98
[241]99 typedef map<uint_8, ClassCreatorFunc, less<uint_8> > ClassList;
[269]100 // Pas de createur appele pour objets statiques sur Linux - $CHECK$ Reza 26/04/99
[802]101 static ClassList * ppclassList; // PPersist class list
102 static map<string, uint_8> * ppclassNameList; // PPersist classId = f(PPersistClassName)
103 static map<string, uint_8> * dobjclassNameList; // PPersist classId = f(DataObjClassName)
[219]104
[241]105 };
[219]106
107
[2441]108// TBD : use hash tables instead of maps. Check hashtbl status in STL.
[219]109
[895]110//! Input stream for PPersit objects.
[2475]111 class PInPersist : public PPFBinaryInputStream, public PIOPersist {
[241]112 public:
[2477]113 PInPersist(RawInOutStream * is, bool ad, bool scan=false);
[241]114 PInPersist(string const& flnm, bool scan=true);
[2475]115 virtual ~PInPersist();
[219]116
[2475]117 // A faire - Reza Dec 2003
118 string GetTagClassName(int itag);
[802]119 // Object Reading
[241]120 PPersist* ReadObject();
[802]121 void GetObject(AnyDataObj & o);
122 void GetObject(AnyDataObj & o, string tagname);
123 PPersist* GetPPObject(AnyDataObj * po=NULL);
[219]124
[802]125 // Reza 03/2000
126 // Methodes qui pourraient etre protected, mais doivent etre utilisables par PPersist
127 void ReadReference(PPersist & ppo); // Fill the ppo object from the reference tag
128 PPersist * ReadReference(); // Creates object from the reference tag
129 void KeepOId(uint_8 oid, PPersist & ppo); // Keeps the ppo in the objList
130
[241]131 protected:
[802]132
133 // already read objects
134 typedef map<uint_8, PPersist * > ObjList;
[241]135 ObjList objList;
136 friend class PPersist;
137 };
[219]138
[895]139//! Output stream for PPersit objects.
[2475]140 class POutPersist : public PPFBinaryOutputStream, public PIOPersist {
[241]141 public:
[2477]142 POutPersist(RawInOutStream* os, bool ad, int endianness = PPS_NATIVE);
[241]143 POutPersist(string const& flnm, int endianness = PPS_NATIVE);
[2475]144 virtual ~POutPersist();
[219]145
[2475]146 // void Put(PPersist const* x) {PutPPObject(x);}
[219]147
[2441]148 // Objet Write - Ecriture des objets
149 void PutPPObject (PPersist const*); // Like doing Write(stream) on PPersist object
150
151 void PutObject(AnyDataObj & o); // Creates the corresponding PPersist Object and call Write()
152 void PutObject(AnyDataObj & o, string tagname);
153
154
[241]155 protected:
156 bool serializeNullAndRepeat(PPersist const* x);
[802]157 uint_8 findObjectId(PPersist const* x, int_8 & pos);
158 uint_8 assignObjectId(PPersist const* x);
[219]159
[802]160 // objreftag contains the assigned POutStream Object Id and the stream position
161 // of the original written object
162 typedef struct { uint_8 ppsoid; int_8 ppspos; } objreftag;
163 // already serialized objects are kept in a map as a function of the Objects memory Id
164 typedef map<uint_8, objreftag, less<uint_8> > ObjList;
[241]165 ObjList objList;
[802]166 uint_8 pps_OId; // PPS Object Id
[2477]167 int wobj_level; // Niveau d'imbrication lors de l'ecriture d'objet
[241]168 };
169
[2805]170//! \cond
[2441]171// Le macro suivant permettent de simplifier la declaration
172// des operateurs >> << sur les POutPersist et PInPersist
[219]173#define RAWPERSISTIO(_Type_,_xtyp_) \
[241]174 inline POutPersist& operator << (POutPersist& c, _Type_ const& data) \
175 { \
176 c.Put##_xtyp_(data); \
177 return c; \
178 } \
[219]179 \
[241]180 inline PInPersist& operator >> (PInPersist& c, _Type_& data) \
181 { \
182 c.Get##_xtyp_(data); \
183 return c; \
184 }
[219]185
[2441]186// On utilise le macro RAWPERSISTIO pour declarer POutPersist << et PInPersist >>
187// pour les types de base r_4 r_8 int_4 int_8 ...
[2660]188 RAWPERSISTIO(int_8,I8);
189 RAWPERSISTIO(uint_8,U8);
[241]190 RAWPERSISTIO(int_4,I4);
191 RAWPERSISTIO(uint_4,U4);
192 RAWPERSISTIO(int_2,I2);
193 RAWPERSISTIO(uint_2,U2);
194 RAWPERSISTIO(char,Byte);
195 RAWPERSISTIO(r_4,R4);
196 RAWPERSISTIO(r_8,R8);
[2441]197 RAWPERSISTIO(complex<r_4>,Z4);
198 RAWPERSISTIO(complex<r_8>,Z8);
199 RAWPERSISTIO(string,Str);
[241]200
[219]201#if 0
202#define STRUCTPERSISTIO(_Type_, _field_, _size_) \
[241]203 inline POutPersist& operator << (POutPersist& c, _Type_ const& data) \
204 { \
205 c.PutBytes(&data._field_, _size_); \
206 return c; \
207 } \
[219]208 \
[241]209 inline PInPersist& operator >> (PInPersist& c, _Type_& data) \
210 { \
211 c.GetBytes(&data._field_, _size_); \
212 return c; \
213 }
[219]214
215#endif
[802]216
[2805]217//! \endcond
218
[802]219// --- Cela risque d'etre dangereux --- On le laisse au niveau des DataObj
220// Reza 24/3/2000
221// inline POutPersist& operator << (POutPersist& c, PPersist const& obj)
222// {
223// obj.Write(c);
224// return c;
225// }
[241]226
[802]227// inline PInPersist& operator >> (PInPersist& c, PPersist& obj)
228// {
229// obj.Read(c);
230// return c;
231// }
232
[241]233 // Utility class to
234 // - compute the class ID from a MD5 hash of the class name
235 // - register classes with PIOPersist, through PPRegister macro
[895]236
237//! template class for handling the PPersist registration mechanism.
[241]238 template <class T>
239 class PPersistRegistrar {
240 public:
241 static PPersist* Create() {return new T();}
[802]242 static void Register(string id) { PIOPersist::RegisterPPHandlerClass(Hash(id), typeid(T).name(), Create); }
[576]243 static uint_8 Hash(string id) {
244 return PIOPersist::Hash(id);
[241]245 }
246 };
247
[2774]248#define PPRegister(className) PPersistRegistrar< className >::Register( #className );
[802]249#define DObjRegister(ppclassName, className) PIOPersist::RegisterDataObjClass(PIOPersist::Hash(#ppclassName), typeid(className).name());
[754]250
[2475]251} // namespace SOPHYA
[219]252
[2475]253// La classe PPFNameTag facilite la manipulation des Nametag ds les fichiers
254// PPersist - definie ds ppfnametag.h
255#include "ppfnametag.h"
256
257
[219]258#endif
Note: See TracBrowser for help on using the repository browser.