library: libCore #include "TStreamerInfo.h" |
TStreamerInfo
class description - header file - source file - inheritance tree (.pdf)
private:
void BuildUserInfo(const char* info)
static Double_t GetValueAux(Int_t type, void* ladd, int k, Int_t len)
static void PrintValueAux(char* ladd, Int_t atype, TStreamerElement* aElement, Int_t aleng, Int_t* count)
protected:
TStreamerInfo(const TStreamerInfo&)
TStreamerInfo& operator=(const TStreamerInfo&)
public:
TStreamerInfo()
TStreamerInfo(TClass* cl, const char* info)
virtual ~TStreamerInfo()
void Build()
void BuildCheck()
void BuildEmulated(TFile* file)
void BuildOld()
static Bool_t CanDelete()
static Bool_t CanOptimize()
static TClass* Class()
virtual void Clear(Option_t*)
void Compile()
void ComputeSize()
void DeleteArray(void* p, Bool_t dtorOnly = kFALSE)
void Destructor(void* p, Bool_t dtorOnly = kFALSE)
void ForceWriteInfo(TFile* file, Bool_t force = kFALSE)
Int_t GenerateHeaderFile(const char* dirname)
UInt_t GetCheckSum() const
TClass* GetClass() const
Int_t GetClassVersion() const
static TStreamerElement* GetCurrentElement()
Int_t GetDataMemberOffset(TDataMember* dm, TMemberStreamer*& streamer) const
static TStreamerBasicType* GetElementCounter(const char* countName, TClass* cl)
TObjArray* GetElements() const
ULong_t* GetElems() const
Int_t* GetLengths() const
ULong_t* GetMethods() const
Int_t GetNdata() const
Int_t* GetNewTypes() const
Int_t GetNumber() const
Int_t GetOffset(const char*) const
Int_t* GetOffsets() const
Version_t GetOldVersion() const
Int_t GetSize() const
Int_t GetSizeElements() const
TStreamerElement* GetStreamerElement(const char* datamember, Int_t& offset) const
TStreamerElement* GetStreamerElementReal(Int_t i, Int_t j) const
static Bool_t GetStreamMemberWise()
Int_t* GetTypes() const
Double_t GetValue(char* pointer, Int_t i, Int_t j, Int_t len) const
Double_t GetValueClones(TClonesArray* clones, Int_t i, Int_t j, Int_t k, Int_t eoffset) const
Double_t GetValueSTL(TVirtualCollectionProxy* cont, Int_t i, Int_t j, Int_t k, Int_t eoffset) const
virtual TClass* IsA() const
Bool_t IsBuilt() const
Bool_t IsOptimized() const
Int_t IsRecovered() const
virtual void ls(Option_t* option = "") const
void* New(void* obj = 0)
void* NewArray(Long_t nElements, void* ary = 0)
static void Optimize(Bool_t opt = kTRUE)
void PrintValue(const char* name, char* pointer, Int_t i, Int_t len, Int_t lenmax = 1000) const
void PrintValueClones(const char* name, TClonesArray* clones, Int_t i, Int_t eoffset, Int_t lenmax = 1000) const
void PrintValueSTL(const char* name, TVirtualCollectionProxy* cont, Int_t i, Int_t eoffset, Int_t lenmax = 1000) const
Int_t ReadBufferClones(TBuffer& b, TClonesArray* clones, Int_t nc, Int_t first, Int_t eoffset)
Int_t ReadBufferSTL(TBuffer& b, TVirtualCollectionProxy* cont, Int_t nc, Int_t first, Int_t eoffset)
static void SetCanDelete(Bool_t opt = kTRUE)
void SetCheckSum(UInt_t checksum)
void SetClass(TClass* cl)
void SetClassVersion(Int_t vers)
static Bool_t SetStreamMemberWise(Bool_t enable = kTRUE)
virtual void ShowMembers(TMemberInspector& insp, char* parent)
virtual void Streamer(TBuffer& b)
void StreamerNVirtual(TBuffer& b)
void TagFile(TFile* fFile)
virtual void Update(const TClass* oldClass, TClass* newClass)
Int_t WriteBuffer(TBuffer& b, char* pointer, Int_t first)
Int_t WriteBufferClones(TBuffer& b, TClonesArray* clones, Int_t nc, Int_t first, Int_t eoffset)
Int_t WriteBufferSTL(TBuffer& b, TVirtualCollectionProxy* cont, Int_t nc, Int_t first, Int_t eoffset)
private:
UInt_t fCheckSum checksum of original class
Int_t fClassVersion Class version identifier
Int_t fNumber !Unique identifier
Int_t fNdata !number of optmized types
Int_t fSize !size of the persistent class
Int_t* fType ![fNdata]
Int_t* fNewType ![fNdata]
Int_t* fOffset ![fNdata]
Int_t* fLength ![fNdata]
ULong_t* fElem ![fNdata]
ULong_t* fMethod ![fNdata]
TStreamerInfo::TCompInfo* fComp ![fNdata] additional info
Bool_t fOptimized ! true if has been optimized
TClass* fClass !pointer to class
TObjArray* fElements Array of TStreamerElements
Version_t fOldVersion ! Version of the TStreamerInfo object read from the file
Bool_t fIsBuilt ! true if the TStreamerInfo has been 'built'
static Int_t fgCount Number of TStreamerInfo instances
static Bool_t fgCanDelete True if ReadBuffer can delete object
static Bool_t fgOptimize True if optimization on
static Bool_t fgStreamMemberWise True if the collections are to be stream "member-wise" (when possible).
static TStreamerElement* fgElement Pointer to current TStreamerElement
public:
static const enum TStreamerInfo:: kCannotOptimize
static const enum TStreamerInfo:: kIgnoreTObjectStreamer
static const enum TStreamerInfo:: kRecovered
static const enum TStreamerInfo:: kNeedCheck
static const TStreamerInfo::EReadWrite kBase
static const TStreamerInfo::EReadWrite kOffsetL
static const TStreamerInfo::EReadWrite kOffsetP
static const TStreamerInfo::EReadWrite kCounter
static const TStreamerInfo::EReadWrite kCharStar
static const TStreamerInfo::EReadWrite kChar
static const TStreamerInfo::EReadWrite kShort
static const TStreamerInfo::EReadWrite kInt
static const TStreamerInfo::EReadWrite kLong
static const TStreamerInfo::EReadWrite kFloat
static const TStreamerInfo::EReadWrite kDouble
static const TStreamerInfo::EReadWrite kDouble32
static const TStreamerInfo::EReadWrite kUChar
static const TStreamerInfo::EReadWrite kUShort
static const TStreamerInfo::EReadWrite kUInt
static const TStreamerInfo::EReadWrite kULong
static const TStreamerInfo::EReadWrite kBits
static const TStreamerInfo::EReadWrite kLong64
static const TStreamerInfo::EReadWrite kULong64
static const TStreamerInfo::EReadWrite kBool
static const TStreamerInfo::EReadWrite kObject
static const TStreamerInfo::EReadWrite kAny
static const TStreamerInfo::EReadWrite kObjectp
static const TStreamerInfo::EReadWrite kObjectP
static const TStreamerInfo::EReadWrite kTString
static const TStreamerInfo::EReadWrite kTObject
static const TStreamerInfo::EReadWrite kTNamed
static const TStreamerInfo::EReadWrite kAnyp
static const TStreamerInfo::EReadWrite kAnyP
static const TStreamerInfo::EReadWrite kAnyPnoVT
static const TStreamerInfo::EReadWrite kSTLp
static const TStreamerInfo::EReadWrite kSkip
static const TStreamerInfo::EReadWrite kSkipL
static const TStreamerInfo::EReadWrite kSkipP
static const TStreamerInfo::EReadWrite kConv
static const TStreamerInfo::EReadWrite kConvL
static const TStreamerInfo::EReadWrite kConvP
static const TStreamerInfo::EReadWrite kSTL
static const TStreamerInfo::EReadWrite kSTLstring
static const TStreamerInfo::EReadWrite kStreamer
static const TStreamerInfo::EReadWrite kStreamLoop
static const TStreamerInfo::EReadWrite kMissing
void Build()
Build the I/O data structure for the current class version.
A list of TStreamerElement derived classes is built by scanning
one by one the list of data members of the analyzed class.
void Clear(Option_t *option)
If opt cointains 'built', reset this StreamerInfo as if Build or BuildOld
was never called on it (usefull to force their re-running).
void Compile()
loop on the TStreamerElement list
regroup members with same type
Store predigested information into local arrays. This saves a huge amount
of time compared to an explicit iteration on all elements.
void ComputeSize()
Compute total size of all persistent elements of the class
void ForceWriteInfo(TFile *file, Bool_t force)
will force this TStreamerInfo to the file and also
all the dependencies.
This function is called when streaming a class that contains
a null pointer. In this case, the TStreamerInfo for the class
with the null pointer must be written to the file and also all the
TStreamerInfo of all the classes referenced by the class.
if argument force > 0 the loop on class dependencies is forced
Int_t GetOffset(const char *elementName)
return the offset of the data member as indicated by this StreamerInfo
Int_t GetSize()
return total size of all persistent elements of the class (with offsets)
Int_t GetSizeElements()
return total size of all persistent elements of the class
use GetSize if you want to get the real size in memory
TStreamerElement* GetStreamerElement(const char* datamember, Int_t &offset)
Return the StreamerElement of "datamember" inside this class of any of its
base class. The offset information contained in the StreamerElement is related
to its immediate containing class, so we return in 'offset' the offset inside
the class of this streamerInfo.
TStreamerElement* GetStreamerElementReal(Int_t i, Int_t j)
TStreamerInfo holds two types of data structures
-TObjArray* fElements; containing the list of all TStreamerElement
objects for this class version.
-ULong_t* fElem; containing the preprocessed information
by TStreamerInfo::Compile In case consecutive data members
are of the same type, the Compile function declares the consecutive
elements as one single element in fElems.
example with the class TAttLine
gROOT->GetClass("TAttLine")->GetStreamerInfo()->ls(); produces;
StreamerInfo for class: TAttLine, version=1
short fLineColor offset= 4 type= 2 line color
short fLineStyle offset= 6 type= 2 line style
short fLineWidth offset= 8 type= 2 line width
i= 0, fLineColor type= 22, offset= 4, len=3, method=0
For I/O implementations (eg. XML) , one has to know the original name
of the data member. This function can be used to return a pointer
to the original TStreamerElement object corresponding to the j-th
element of a compressed array in fElems.
parameters description:
- i: the serial number in array fElem
- j: the element number in the array of consecutive types
In the above example the class TAttLine has 3 consecutive data members
of the same type "short". Compile makes one single array of 3 elements.
To access the TStreamerElement for the second element
of this array, one can call:
TStreamerElement *el = GetStreamerElementReal(0,1);
const char* membername = el->GetName();
This function is typically called from Tbuffer, TXmlBuffer
Bool_t GetStreamMemberWise()
Return whether the TStreamerInfos will save the collections in
"member-wise" order whenever possible. The default is to store member-wise.
kTRUE indicates member-wise storing
kFALSE inddicates object-wise storing
A collection can be saved member wise when it contain is guaranteed to be
homogeneous. For example std::vector<THit> can be stored member wise,
while std::vector<THit*> can not (possible use of polymorphism).
Double_t GetValue(char *pointer, Int_t i, Int_t j, Int_t len)
return value of element i in object at pointer.
The function may be called in two ways:
-method1 len < 0
i is assumed to be the TStreamerElement number i in StreamerInfo
-method2 len >= 0
i is the type
address of variable is directly pointer.
void* New(void *obj)
An emulated object is created at address obj, if obj is null we
allocate memory for the object.
void* NewArray(Long_t nElements, void *ary)
An array of emulated objects is created at address ary, if ary is null,
we allocate memory for the array.
void Destructor(void* obj, Bool_t dtorOnly)
emulated destructor for this class.
An emulated object is destroyed at address p
void DeleteArray(void* ary, Bool_t dtorOnly)
Destroy an array of emulated objects, with optional delete.
void Optimize(Bool_t opt)
This is a static function.
Set optimization option.
When this option is activated (default), consecutive data members
of the same type are merged into an array (faster).
Optimization must be off in TTree split mode.
void PrintValue(const char *name, char *pointer, Int_t i, Int_t len, Int_t lenmax)
print value of element i in object at pointer
The function may be called in two ways:
-method1 len < 0
i is assumed to be the TStreamerElement number i in StreamerInfo
-method2 len >= 0
i is the type
address of variable is directly pointer.
len is the number of elements to be printed starting at pointer.
void SetCanDelete(Bool_t opt)
This is a static function.
Set object delete option.
When this option is activated (default), ReadBuffer automatically
delete objects when a data member is a pointer to an object.
If your constructor is not presetting pointers to 0, you must
call this static function TStreamerInfo::SetCanDelete(kFALSE);
Bool_t SetStreamMemberWise(Bool_t enable)
Set whether the TStreamerInfos will save the collections in
"member-wise" order whenever possible. The default is to store member-wise.
kTRUE indicates member-wise storing
kFALSE inddicates object-wise storing
This function returns the previous value of fgStreamMemberWise.
void PrintValueAux(char *ladd, Int_t atype, TStreamerElement *aElement, Int_t aleng, Int_t *count)
print value of element in object at pointer, type atype, leng aleng or *count
The function may be called in two ways:
-method1 len < 0
i is assumed to be the TStreamerElement number i in StreamerInfo
-method2 len >= 0
i is the type
address of variable is directly pointer.
len is the number of elements to be printed starting at pointer.
void Update(const TClass *oldcl, TClass *newcl)
function called by the TClass constructor when replacing an emulated class
by the real class
Author: Rene Brun 12/10/2000
Last update: root/meta:$Name: $:$Id: TStreamerInfo.cxx,v 1.239 2006/05/29 13:24:09 brun Exp $
Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.