Logo ROOT  
Reference Guide
TBranchClones.h
Go to the documentation of this file.
1// @(#)root/tree
2// Author: Rene Brun 11/02/96
3
4/*************************************************************************
5 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11
12#ifndef ROOT_TBranchClones
13#define ROOT_TBranchClones
14
15
16//////////////////////////////////////////////////////////////////////////
17// //
18// TBranchClones //
19// //
20// A Branch for the case of an array of clone objects. //
21//////////////////////////////////////////////////////////////////////////
22
23
24#include "TBranch.h"
25
26class TClonesArray;
27class TTreeCloner;
28
29class TBranchClones : public TBranch {
30
31protected:
32 TClonesArray *fList; ///<! Pointer to the clonesarray
33 Int_t fRead; ///<! flag = 1 if clonesarray has been read
34 Int_t fN; ///<! Number of elements in ClonesArray
35 Int_t fNdataMax; ///<! Maximum value of fN
36 TString fClassName; ///< name of the class of the objets in the ClonesArray
37 TBranch *fBranchCount; ///< Branch with clones count
38
39 friend class TTreeCloner;
40
41 void Init(TTree *tree, TBranch *parent, const char *name, void *clonesaddress, Int_t basketsize=32000,Int_t compress=-1, Int_t splitlevel=1);
43
44public:
46 TBranchClones(TTree *tree, const char *name, void *clonesaddress, Int_t basketsize=32000,Int_t compress=-1, Int_t splitlevel=1);
47 TBranchClones(TBranch *parent, const char *name, void *clonesaddress, Int_t basketsize=32000,Int_t compress=-1, Int_t splitlevel=1);
48 virtual ~TBranchClones();
49
50 virtual void Browse(TBrowser *b);
51 virtual const char* GetClassName() const { return fClassName; }
52 virtual Int_t GetEntry(Long64_t entry=0, Int_t getall = 0);
53 virtual Int_t GetN() const {return fN;}
54 TClonesArray *GetList() const {return fList;}
55 Bool_t IsFolder() const {return kTRUE;}
56 virtual void Print(Option_t *option="") const;
57 virtual void Reset(Option_t *option="");
58 virtual void ResetAfterMerge(TFileMergeInfo *);
59 virtual void SetAddress(void *add);
60 virtual void SetBasketSize(Int_t buffsize);
62 virtual void UpdateFile();
63
64private:
65
66 ClassDef(TBranchClones,2); //Branch in case of an array of clone objects
67};
68
69#endif
#define b(i)
Definition: RSha256.hxx:100
int Int_t
Definition: RtypesCore.h:41
bool Bool_t
Definition: RtypesCore.h:59
long long Long64_t
Definition: RtypesCore.h:69
const Bool_t kTRUE
Definition: RtypesCore.h:87
const char Option_t
Definition: RtypesCore.h:62
#define ClassDef(name, id)
Definition: Rtypes.h:326
char name[80]
Definition: TGX11.cxx:109
A Branch for the case of an array of clone objects.
Definition: TBranchClones.h:29
virtual const char * GetClassName() const
Return the name of the user class whose content is stored in this branch, if any.
Definition: TBranchClones.h:51
TClonesArray * fList
! Pointer to the clonesarray
Definition: TBranchClones.h:32
TBranch * fBranchCount
Branch with clones count.
Definition: TBranchClones.h:37
Int_t fN
! Number of elements in ClonesArray
Definition: TBranchClones.h:34
virtual void SetAddress(void *add)
Set address of this branch.
virtual void Browse(TBrowser *b)
Browse this branch.
virtual void UpdateFile()
Refresh the value of fDirectory (i.e.
Int_t fRead
! flag = 1 if clonesarray has been read
Definition: TBranchClones.h:33
virtual ~TBranchClones()
Destructor.
virtual void ResetAfterMerge(TFileMergeInfo *)
Reset branch after a merge.
TString fClassName
name of the class of the objets in the ClonesArray
Definition: TBranchClones.h:36
virtual Int_t GetN() const
Definition: TBranchClones.h:53
TBranchClones()
Default and i/o constructor.
virtual Int_t GetEntry(Long64_t entry=0, Int_t getall=0)
Read all branches and return total number of bytes read.
virtual void SetBasketSize(Int_t buffsize)
Reset basket size for all sub-branches.
virtual void SetTree(TTree *tree)
Definition: TBranchClones.h:61
void Init(TTree *tree, TBranch *parent, const char *name, void *clonesaddress, Int_t basketsize=32000, Int_t compress=-1, Int_t splitlevel=1)
Initialization (non-virtual, to be called from constructor).
TClonesArray * GetList() const
Definition: TBranchClones.h:54
virtual Int_t FillImpl(ROOT::Internal::TBranchIMTHelper *)
Loop on all branches and fill Basket buffer.
virtual void Print(Option_t *option="") const
Print branch parameters.
Bool_t IsFolder() const
Return kTRUE if more than one leaf or browsables, kFALSE otherwise.
Definition: TBranchClones.h:55
Int_t fNdataMax
! Maximum value of fN
Definition: TBranchClones.h:35
virtual void Reset(Option_t *option="")
Reset branch.
A TTree is a list of TBranches.
Definition: TBranch.h:91
virtual void SetTree(TTree *tree)
Definition: TBranch.h:285
TTree * fTree
! Pointer to Tree header
Definition: TBranch.h:142
Using a TBrowser one can browse all ROOT objects.
Definition: TBrowser.h:37
An array of clone (identical) objects.
Definition: TClonesArray.h:32
Basic string class.
Definition: TString.h:131
Class implementing or helping the various TTree cloning method.
Definition: TTreeCloner.h:38
A TTree represents a columnar dataset.
Definition: TTree.h:72
Definition: tree.py:1