86, fEntryOffsetLen(1000)
96, fFirstBasketEntry(-1)
105, fBaskets(fMaxBaskets)
119, fReadLeaves(&
TBranch::ReadLeavesImpl)
120, fFillLeaves(&
TBranch::FillLeavesImpl)
188, fBasketSize((basketsize < 100) ? 100 : basketsize)
192, fIOFeatures(
tree ?
tree->GetIOFeatures().GetFeatures() : 0)
200, fFirstBasketEntry(-1)
201, fNextBasketEntry(-1)
209, fBaskets(fMaxBaskets)
216, fAddress((char *)address)
217, fDirectory(fTree->GetDirectory())
223, fReadLeaves(&
TBranch::ReadLeavesImpl)
224, fFillLeaves(&
TBranch::FillLeavesImpl)
240, fBasketSize((basketsize < 100) ? 100 : basketsize)
244, fIOFeatures(parent->fIOFeatures)
252, fFirstBasketEntry(-1)
253, fNextBasketEntry(-1)
261, fBaskets(fMaxBaskets)
265, fTree(parent ? parent->GetTree() : 0)
266, fMother(parent ? parent->GetMother() : 0)
268, fAddress((char *)address)
269, fDirectory(fTree ? fTree->GetDirectory() : 0)
275, fReadLeaves(&
TBranch::ReadLeavesImpl)
276, fFillLeaves(&
TBranch::FillLeavesImpl)
307 char* nameBegin =
const_cast<char*
>(leaflist);
309 auto len = strlen(leaflist);
311 char* leafname =
new char[len + 1];
312 char* leaftype =
new char[320];
314 strlcpy(leaftype,
"F",320);
315 char* pos =
const_cast<char*
>(leaflist);
316 const char* leaflistEnd = leaflist + len;
317 for (; pos <= leaflistEnd; ++pos) {
319 if ((*pos ==
':') || (*pos == 0)) {
321 Int_t lenName = pos - nameBegin;
324 strncpy(leafname, nameBegin, lenName);
325 leafname[lenName] = 0;
326 ctype = strstr(leafname,
"/");
329 strlcpy(leaftype, ctype + 1,320);
332 if (lenName == 0 || ctype == leafname) {
333 Warning(
"TBranch",
"No name was given to the leaf number '%d' in the leaflist of the branch '%s'.",
fNleaves,
name);
337 if (leaftype[1] ==
'[') {
338 Warning(
"TBranch",
"Array size for branch '%s' must be specified after leaf name, not after the type name!",
name);
340 }
else if (leaftype[1]) {
341 Warning(
"TBranch",
"Extra characters after type tag '%s' for branch '%s'; must be one character.", leaftype,
name);
344 if (*leaftype ==
'C') {
345 leaf =
new TLeafC(
this, leafname, leaftype);
346 }
else if (*leaftype ==
'O') {
347 leaf =
new TLeafO(
this, leafname, leaftype);
348 }
else if (*leaftype ==
'B') {
349 leaf =
new TLeafB(
this, leafname, leaftype);
350 }
else if (*leaftype ==
'b') {
351 leaf =
new TLeafB(
this, leafname, leaftype);
353 }
else if (*leaftype ==
'S') {
354 leaf =
new TLeafS(
this, leafname, leaftype);
355 }
else if (*leaftype ==
's') {
356 leaf =
new TLeafS(
this, leafname, leaftype);
358 }
else if (*leaftype ==
'I') {
359 leaf =
new TLeafI(
this, leafname, leaftype);
360 }
else if (*leaftype ==
'i') {
361 leaf =
new TLeafI(
this, leafname, leaftype);
363 }
else if (*leaftype ==
'F') {
364 leaf =
new TLeafF(
this, leafname, leaftype);
365 }
else if (*leaftype ==
'f') {
366 leaf =
new TLeafF(
this, leafname, leaftype);
367 }
else if (*leaftype ==
'L') {
368 leaf =
new TLeafL(
this, leafname, leaftype);
369 }
else if (*leaftype ==
'l') {
370 leaf =
new TLeafL(
this, leafname, leaftype);
372 }
else if (*leaftype ==
'D') {
373 leaf =
new TLeafD(
this, leafname, leaftype);
374 }
else if (*leaftype ==
'd') {
375 leaf =
new TLeafD(
this, leafname, leaftype);
378 Error(
"TLeaf",
"Illegal data type for %s/%s",
name, leaflist);
387 Error(
"TBranch",
"Illegal leaf: %s/%s",
name, leaflist);
451 if (lst && lst->
GetLast()!=-1) {
533 Warning(
"AddBasket",
"The assumption that out-of-order basket only comes from disk based ntuple is false.");
544 Error(
"AddBasket",
"An out-of-order basket matches the entry number of an existing basket.");
594 Fatal(
"AddBasket",
"The last basket must have the highest entry number (%s/%lld/%d).",
GetName(),startEntry,
fWriteBasket);
647 auto endCluster = cluster.GetNextEntry();
704 for (
Int_t j = 0; j < nb; j++) {
722 if (options && options[0]) {
733 for (
Int_t i=0;i<nbaskets;i++) {
735 if (!basket)
continue;
755 for (
Int_t j = 0; j < nb; j++) {
757 if (!branch)
continue;
827 if (!basket)
return 0;
861 nbytes = lnew - lold;
867 nsize = nevbuf *
sizeof(
Int_t);
888 if (nout < 0)
Error(
"TBranch::Fill",
"Failed to write out basket.\n");
889 return (nout >= 0) ? nbytes : -1;
900 Int_t objectStart = 0;
945 char*
s =
new char[maxsize];
948 while (strlen(
s) == (maxsize - 1)) {
953 s =
new char[maxsize];
967 if (startpos >
UInt_t(objectStart)) {
987 nbytes = lnew - lold;
1002 if (longnm[longnm.length()-1]==
']') {
1003 std::size_t dim = longnm.find_first_of(
"[");
1004 if (dim != std::string::npos) {
1008 if (longnm[longnm.length()-1] !=
'.') {
1016 for(
Int_t i = 0; i < nbranches; ++i) {
1019 const char *brname = branch->
fName.
Data();
1021 if (brname[brlen-1]==
']') {
1022 const char *dim = strchr(brname,
'[');
1024 brlen = dim - brname;
1027 if (namelen == brlen
1028 && strncmp(
name,brname,brlen) == 0) {
1031 if (brlen == (
size_t)longnm.length()
1032 && strncmp(longnm.c_str(),brname,brlen) == 0) {
1052 while ((leaf = (
TLeaf*) next())) {
1055 if (dim >= 0) leafname.
Remove(dim);
1057 if (leafname == searchname)
return leaf;
1061 dim = leaftitle.
First(
'[');
1062 if (dim >= 0) leaftitle.
Remove(dim);
1064 if (leaftitle == searchname)
return leaf;
1069 dim = longname.
First(
'[');
1070 if (dim>=0) longname.
Remove(dim);
1071 if (longname == searchname)
return leaf;
1074 longname.
Form(
"%s.%s",branch->
GetName(),searchname);
1075 if (longname==leafname)
return leaf;
1078 dim = longtitle.
First(
'[');
1079 if (dim>=0) longtitle.
Remove(dim);
1080 if (longtitle == searchname)
return leaf;
1087 if (strstr(searchname,
".") && !strcmp(searchname, branch->
GetName()))
return leaf;
1108 for(
Int_t i=0; i != maxbasket; ++i) {
1119 for (
Int_t i = 0; i < len; ++i) {
1190 static std::atomic<Int_t> nerrors(0);
1193 if (basketnumber <0 || basketnumber >
fWriteBasket)
return 0;
1195 if (basket)
return basket;
1229 if (nerrors > 10)
return 0;
1230 if (nerrors == 10) {
1231 printf(
" file probably overwritten: stopping reporting error messages\n");
1233 printf(
"===>File is more than 2 Gigabytes\n");
1237 printf(
"===>Your file is may be bigger than the maximum file size allowed on your system\n");
1238 printf(
" Check your AFS maximum file size limit for example\n");
1242 Error(
"GetBasket",
"File: %s at byte:%lld, branch:%s, entry:%lld, badread=%d, nerrors=%d, basketnumber=%d",
file->GetName(),basket->
GetSeekKey(),
GetName(),
fReadEntry,badread,nerrors.load(),basketnumber);
1251 perfStats->
SetUsed(
this, basketnumber);
1262 if (basketnumber <0 || basketnumber >
fWriteBasket)
return 0;
1293 return "TBranchElement-folder";
1295 return "TBranchElement-leaf";
1340 if ((entry <
first) || (entry > last)) {
1344 Error(
"In the branch %s, no basket contains the entry %d\n",
GetName(), entry);
1367 clusterIterator.
Next();
1382 if (!
file)
return -1;
1396 bufbegin = entryOffset[entry-
first];
1409 return buf->
Length() - bufbegin;
1432 if ((entry <
first) || (entry > last)) {
1436 Error(
"In the branch %s, no basket contains the entry %d\n",
GetName(), entry);
1467 bufbegin = entryOffset[entry-
first];
1479 nbytes = buf->
Length() - bufbegin;
1498 Error(
"GetExpectedType",
"Did not find any leaves in %s",
GetName());
1533 if (!
file)
return 0;
1534 if (
file->IsZombie()) {
delete file;
return 0;}
1546 if (
GetTree()->MemoryFull(0)) {
1612 while (
fBasketEntry[basketToUnload] != entryToUnload) {
1614 if (basketToUnload < 0) {
1684 bFileName = arc.
GetUrl();
1730 Int_t n = array->GetEntriesFast();
1731 for (
Int_t i = 0; i <
n; ++i) {
1749 if (
this == child) {
1759 for (
Int_t i = 0; i < len; ++i) {
1764 if (branch == child) {
1792 const_cast<TBranch *
>(
this)->TBranch::Streamer(
b);
1796 return totbytes +
b.Length();
1806 if (!option)
return totbytes;
1807 if (option[0] !=
'*')
return totbytes;
1810 for (
Int_t i = 0; i < len; ++i) {
1812 if (branch) totbytes += branch->
GetTotBytes(option);
1824 if (!option)
return zipbytes;
1825 if (option[0] !=
'*')
return zipbytes;
1828 for (
Int_t i = 0; i < len; ++i) {
1830 if (branch) zipbytes += branch->
GetZipBytes(option);
1860 return browsables && browsables->
GetSize();
1875 for (
Int_t i = 0; i < nb; ++i) {
1894 Int_t nimported = 0;
1897 if (!
file)
return 0;
1899 for (
Int_t i=0;i<nbaskets;i++) {
1901 if (basket)
continue;
1908 Error(
"Loadbaskets",
"Error while reading basket buffer %d of branch %s",i,
GetName());
1926 const int kLINEND = 77;
1930 if ( titleContent ==
GetName() ) {
1931 titleContent.
Clear();
1935 if (titleContent.
Length()>=2 && titleContent[titleContent.
Length()-2]==
'/' && isalpha(titleContent[titleContent.
Length()-1])) {
1939 if (titleContent.
Length()) {
1949 aLength += (aLength / 54 + 1) * 80 + 100;
1950 if (aLength < 200) aLength = 200;
1951 char *bline =
new char[aLength];
1957 if (strlen(bline) >
UInt_t(kLINEND)) {
1958 char *tmp =
new char[strlen(bline)+1];
1959 if (titleLength) strlcpy(tmp, titleContent.
Data(),strlen(bline)+1);
1961 int pos = strlen (bline);
1964 while (beg < titleLength) {
1965 for (end=beg+1; end < titleLength-1; end ++)
1966 if (tmp[end] ==
':')
break;
1967 if (npos + end-beg+1 >= 78) {
1968 while (npos < kLINEND) {
1969 bline[pos ++] =
' ';
1972 bline[pos ++] =
'*';
1973 bline[pos ++] =
'\n';
1974 bline[pos ++] =
'*';
1976 for (; npos < 12; npos ++)
1977 bline[pos ++] =
' ';
1980 for (
int n = beg;
n <= end;
n ++)
1981 bline[pos+
n-beg] = tmp[
n];
1986 while (npos < kLINEND) {
1987 bline[pos ++] =
' ';
1990 bline[pos ++] =
'*';
2003 Printf(
"*Entries :%9lld : Total Size=%11lld bytes All baskets in memory *",
fEntries,totBytes);
2005 Printf(
"*Entries :%9lld : Total Size=%11lld bytes One basket in memory *",
fEntries,totBytes);
2011 if (strncmp(option,
"basketsInfo",strlen(
"basketsInfo"))==0) {
2013 for (
Int_t i=0;i<nbaskets;i++) {
2014 Printf(
"*Basket #%4d entry=%6lld pos=%6lld size=%5d",
2019 Printf(
"*............................................................................*");
2120 Int_t nbaskets =
b->fBaskets.GetSize();
2224 reusebasket->
Reset();
2247 for (
Int_t i = 0; i < nbranches; ++i) {
2333 Error(
"TBranch::SetAddress",
"Filling from a TBuffer can only be done with a not split object branch. Request ignored.");
2357 for (
Int_t i=0;i<nb;i++) {
2368 if (level < 0) level = 0;
2369 if (level > 99) level = 99;
2379 for (
Int_t i=0;i<nb;i++) {
2393 for (
Int_t i=0;i<nb;i++) {
2409 if (updateExisting) {
2412 while ( (
b = (
TBranch*)next() ) ) {
2413 b->SetEntryOffsetLen( newdefault,
kTRUE );
2460 while ((basket = (
TBasket*)nextb())) {
2467 while ((branch = (
TBranch*)next())) {
2499 while ((branch = (
TBranch*)next())) {
2524 Warning(
"SetObject",
"is not supported in TBranch objects");
2541 if (
b.IsReading()) {
2603 TNamed::Streamer(
b);
2604 if (
v > 7) TAttFill::Streamer(
b);
2634 b.CheckByteCount(R__s, R__c, TBranch::IsA());
2661 b.CheckByteCount(R__s, R__c, TBranch::IsA());
2677 TNamed::Streamer(
b);
2736 b.CheckByteCount(R__s, R__c, TBranch::IsA());
2756 for (
Int_t i = 0; i < lastBasket; ++i) {
2769 for (
Int_t i = 0; i < lastBasket; ++i) {
2770 if (stash[i])
fBaskets[i] = stash[i];
2796 auto doUpdates = [=]() {
2798 if (nout < 0)
Error(
"TBranch::WriteBasketImpl",
"basket's WriteBuffer failed.\n");
2807 reusebasket = basket;
2808 reusebasket->
Reset();
2814#ifdef R__TRACK_BASKET_ALLOC_TIME
2815 fTree->AddAllocationTime(reusebasket->GetResetAllocationTime());
2848 imtHelper->
Run(doUpdates);
2892 while ((basket = (
TBasket*)nextb())) {
2900 while ((branch = (
TBranch*)next())) {
#define R__unlikely(expr)
const UInt_t kNewClassTag
const UInt_t kByteCountMask
R__EXTERN TVirtualMutex * gROOTMutex
R__EXTERN TSystem * gSystem
#define R__LOCKGUARD_IMT(mutex)
#define R__LOCKGUARD(mutex)
void SetUsed(Int_t basketNumber)
void Print(const char *owner, Long64_t *entries) const
void Run(const FN &lambda)
TIOFeatures provides the end-user with the ability to change the IO behavior of data written via a TT...
Fill Area Attributes class.
Manages buffers for branches of a Tree.
virtual void Reset()
Reset the basket to the starting state.
Int_t GetNevBufSize() const
Int_t * GetDisplacement() const
void SetBranch(TBranch *branch)
Int_t ReadBasketBuffers(Long64_t pos, Int_t len, TFile *file)
Read basket buffers in memory and cleanup.
virtual Int_t DropBuffers()
Drop buffers of this basket if it is not the current basket.
virtual void PrepareBasket(Long64_t)
virtual void MoveEntries(Int_t dentries)
Remove the first dentries of this basket, moving entries at dentries to the start of the buffer.
void SetNevBufSize(Int_t n)
Int_t GetBufferSize() const
virtual void AdjustSize(Int_t newsize)
Increase the size of the current fBuffer up to newsize.
virtual void SetReadMode()
Set read mode of basket.
virtual void SetWriteMode()
Set write mode of basket.
Bool_t GetResetAllocationCount() const
Int_t ReadBasketBytes(Long64_t pos, TFile *file)
Read basket buffers in memory and cleanup.
virtual Int_t WriteBuffer()
Write buffer of this basket on the current file.
void Update(Int_t newlast)
A TTree is a list of TBranches.
virtual TLeaf * GetLeaf(const char *name) const
Return pointer to the 1st Leaf named name in thisBranch.
virtual void SetupAddresses()
If the branch address is not set, we set all addresses starting with the top level parent branch.
virtual void ResetAddress()
Reset the address of the branch.
virtual void SetAutoDelete(Bool_t autodel=kTRUE)
Set the automatic delete bit.
TString fFileName
Name of file where buffers are stored ("" if in same file as Tree header)
virtual const char * GetClassName() const
Return the name of the user class whose content is stored in this branch, if any.
const char * GetIconName() const
Return icon name depending on type of branch.
Int_t fEntryOffsetLen
Initial Length of fEntryOffset table in the basket buffers.
virtual void DeleteBaskets(Option_t *option="")
Loop on all branch baskets.
virtual Long64_t GetBasketSeek(Int_t basket) const
Return address of basket in the file.
TBranch()
Default constructor. Used for I/O by default.
Int_t BackFill()
Loop on all leaves of this branch to back fill Basket buffer.
Int_t fMaxBaskets
Maximum number of Baskets so far.
Long64_t fTotBytes
Total number of bytes in all leaves before compression.
TBuffer * fTransientBuffer
! Pointer to the current transient buffer.
virtual void ReadBasket(TBuffer &b)
Loop on all leaves of this branch to read Basket buffer.
FillLeaves_t fFillLeaves
! Pointer to the FillLeaves implementation to use.
TObjArray fLeaves
-> List of leaves of this branch
char * fAddress
! Address of 1st leaf (variable or object)
virtual void DropBaskets(Option_t *option="")
Loop on all branch baskets.
TObjArray * GetListOfBranches()
virtual TList * GetBrowsables()
Returns (and, if 0, creates) browsable objects for this branch See TVirtualBranchBrowsable::FillListO...
TList * fBrowsables
! List of TVirtualBranchBrowsables used for Browse()
void ReadLeavesImpl(TBuffer &b)
Loop on all leaves of this branch to read Basket buffer.
Int_t fOffset
Offset of this branch.
Long64_t * fBasketEntry
[fMaxBaskets] Table of first entry in each basket
virtual void SetEntryOffsetLen(Int_t len, Bool_t updateSubBranches=kFALSE)
Update the default value for the branch's fEntryOffsetLen if and only if it was already non zero (and...
void ExpandBasketArrays()
Increase BasketEntry buffer of a minimum of 10 locations and a maximum of 50 per cent of current size...
void Init(const char *name, const char *leaflist, Int_t compress)
virtual Int_t GetEntry(Long64_t entry=0, Int_t getall=0)
Read all leaves of entry and return total number of bytes read.
TIOFeatures GetIOFeatures() const
Returns the IO settings currently in use for this branch.
void FillLeavesImpl(TBuffer &b)
Loop on all leaves of this branch to fill Basket buffer.
Long64_t fReadEntry
! Current entry number when reading
virtual void AddBasket(TBasket &b, Bool_t ondisk, Long64_t startEntry)
Add the basket to this branch.
static void ResetCount()
Static function resetting fgCount.
TBranch * GetSubBranch(const TBranch *br) const
Find the parent branch of child.
ReadLeaves_t fReadLeaves
! Pointer to the ReadLeaves implementation to use.
virtual void SetObject(void *objadd)
Set object this branch is pointing to.
Int_t FlushBaskets()
Flush to disk all the baskets of this branch and any of subbranches.
void ReadLeaves2Impl(TBuffer &b)
Read two leaves without the overhead of a loop.
TBasket * GetFreshCluster()
Drops the cluster two behind the current cluster and returns a fresh basket by either reusing or crea...
virtual void SetAddress(void *add)
Set address of this branch.
static Int_t fgCount
! branch counter
virtual void AddLastBasket(Long64_t startEntry)
Add the start entry of the write basket (not yet created)
TBasket * GetBasket(Int_t basket)
Return pointer to basket basketnumber in this Branch.
Int_t fNBaskets
! Number of baskets in memory
void ReadLeaves1Impl(TBuffer &b)
Read one leaf without the overhead of a loop.
Bool_t IsFolder() const
Return kTRUE if more than one leaf or browsables, kFALSE otherwise.
virtual Int_t GetEntryExport(Long64_t entry, Int_t getall, TClonesArray *list, Int_t n)
Read all leaves of an entry and export buffers to real objects in a TClonesArray list.
Long64_t fZipBytes
Total number of bytes in all leaves after compression.
TIOFeatures fIOFeatures
IO features for newly-created baskets.
void SetCompressionAlgorithm(Int_t algorithm=ROOT::RCompressionSetting::EAlgorithm::kUseGlobal)
Set compression algorithm.
Bool_t IsAutoDelete() const
Return kTRUE if an existing object in a TBranchObject must be deleted.
virtual TLeaf * FindLeaf(const char *name)
Find the leaf corresponding to the name 'searchname'.
CacheInfo_t fCacheInfo
! Hold info about which basket are in the cache and if they have been retrieved from the cache.
TObjArray * GetListOfBaskets()
virtual void SetBufferAddress(TBuffer *entryBuffer)
Set address of this branch directly from a TBuffer to avoid streaming.
Long64_t GetEntries() const
Int_t fNleaves
! Number of leaves
Int_t fSplitLevel
Branch split level.
Int_t WriteBasketImpl(TBasket *basket, Int_t where, ROOT::Internal::TBranchIMTHelper *)
Write the current basket to disk and return the number of bytes written to the file.
TBasket * GetFreshBasket()
Return a fresh basket by either resusing an existing basket that needs to be drop (according to TTree...
virtual void UpdateFile()
Refresh the value of fDirectory (i.e.
void SetCompressionSettings(Int_t settings=ROOT::RCompressionSetting::EDefaults::kUseGeneralPurpose)
Set compression settings.
Int_t * fBasketBytes
[fMaxBaskets] Length of baskets on file
virtual void Print(Option_t *option="") const
Print TBranch parameters.
Long64_t fNextBasketEntry
! Next entry that will requires us to go to the next basket
virtual ~TBranch()
Destructor.
Int_t FillEntryBuffer(TBasket *basket, TBuffer *buf, Int_t &lnew)
Copy the data from fEntryBuffer into the current basket.
virtual TFile * GetFile(Int_t mode=0)
Return pointer to the file where branch buffers reside, returns 0 in case branch buffers reside in th...
virtual void Browse(TBrowser *b)
Browser interface.
TObjArray fBranches
-> List of Branches of this branch
virtual void KeepCircular(Long64_t maxEntries)
keep a maximum of fMaxEntries in memory
virtual void ResetAfterMerge(TFileMergeInfo *)
Reset a Branch.
void ReadLeaves0Impl(TBuffer &b)
Read zero leaves without the overhead of a loop.
virtual Bool_t GetMakeClass() const
Return whether this branch is in a mode where the object are decomposed or not (Also known as MakeCla...
TString GetRealFileName() const
Get real file name.
virtual TBranch * FindBranch(const char *name)
Find the immediate sub-branch with passed name.
TDirectory * fDirectory
! Pointer to directory where this branch buffers are stored
void PrintCacheInfo() const
Print the information we have about which basket is currently cached and whether they have been 'used...
TObjArray fBaskets
-> List of baskets of this branch
virtual Int_t LoadBaskets()
Baskets associated to this branch are forced to be in memory.
Bool_t fSkipZip
! After being read, the buffer will not be unzipped.
TBranch * fMother
! Pointer to top-level parent branch in the tree.
Long64_t GetTotBytes(Option_t *option="") const
Return total number of bytes in the branch (excluding current buffer) if option ="*" includes all sub...
virtual Bool_t SetMakeClass(Bool_t decomposeObj=kTRUE)
Set the branch in a mode where the object are decomposed (Also known as MakeClass mode).
virtual void SetFile(TFile *file=0)
Set file where this branch writes/reads its buffers.
TBranch * fParent
! Pointer to parent branch.
Int_t WriteBasket(TBasket *basket, Int_t where)
Int_t FlushOneBasket(UInt_t which)
If we have a write basket in memory and it contains some entries and has not yet been written to disk...
virtual Int_t GetExpectedType(TClass *&clptr, EDataType &type)
Fill expectedClass and expectedType with information on the data type of the object/values contained ...
virtual void SetFirstEntry(Long64_t entry)
set the first entry number (case of TBranchSTL)
Long64_t GetTotalSize(Option_t *option="") const
Return total number of bytes in the branch (including current buffer)
Long64_t GetZipBytes(Option_t *option="") const
Return total number of zip bytes in the branch if option ="*" includes all sub-branches of this branc...
virtual void SetBasketSize(Int_t buffsize)
Set the basket size The function makes sure that the basket size is greater than fEntryOffsetlen.
virtual void Refresh(TBranch *b)
Refresh this branch using new information in b This function is called by TTree::Refresh.
Int_t fWriteBasket
Last basket number written.
Long64_t * fBasketSeek
[fMaxBaskets] Addresses of baskets on file
virtual void SetStatus(Bool_t status=1)
Set branch status to Process or DoNotProcess.
TObjArray * GetListOfLeaves()
virtual void SetEntries(Long64_t entries)
Set the number of entries in this branch.
Int_t fReadBasket
! Current basket number when reading
Long64_t fFirstEntry
Number of the first entry in this branch.
virtual Int_t GetRow(Int_t row)
Return all elements of one row unpacked in internal array fValues [Actually just returns 1 (?...
Int_t fBasketSize
Initial Size of Basket Buffer.
virtual void Reset(Option_t *option="")
Reset a Branch.
Long64_t fEntryNumber
Current entry number (last one filled in this branch)
TBranch * GetMother() const
Get our top-level parent branch in the tree.
Int_t fCompress
Compression level and algorithm.
TBuffer * GetTransientBuffer(Int_t size)
Returns the transient buffer currently used by this TBranch for reading/writing baskets.
virtual Int_t FillImpl(ROOT::Internal::TBranchIMTHelper *)
Loop on all leaves of this branch to fill Basket buffer.
TBuffer * fEntryBuffer
! Buffer used to directly pass the content without streaming
TBasket * fCurrentBasket
! Pointer to the current basket.
Long64_t fFirstBasketEntry
! First entry in the current basket.
void SetCompressionLevel(Int_t level=ROOT::RCompressionSetting::ELevel::kUseMin)
Set compression level.
Long64_t fEntries
Number of entries.
TTree * fTree
! Pointer to Tree header
Using a TBrowser one can browse all ROOT objects.
The concrete implementation of TBuffer for writing/reading to/from a ROOT file or socket.
Buffer base class used for serializing objects.
void SetWriteMode()
Set buffer in write mode.
void Expand(Int_t newsize, Bool_t copy=kTRUE)
Expand (or shrink) the I/O buffer to newsize bytes.
virtual Int_t GetBufferDisplacement() const =0
virtual void ResetMap()=0
void SetBufferOffset(Int_t offset=0)
virtual Int_t GetMapCount() const =0
void SetReadMode()
Set buffer in read mode.
virtual void WriteBuf(const void *buf, Int_t max)=0
virtual void SetBufferDisplacement()=0
virtual char * ReadString(char *s, Int_t max)=0
The ROOT global object gROOT contains a list of all defined classes.
An array of clone (identical) objects.
void Browse(TBrowser *b)
Browse this collection (called by TBrowser).
virtual void RemoveAll(TCollection *col)
Remove all objects in collection col from this collection.
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
Describe directory structure in memory.
virtual TFile * GetFile() const
virtual Bool_t IsWritable() const
A cache when reading files over the network.
virtual void SetSkipZip(Bool_t=kTRUE)
virtual Bool_t IsLearning() const
virtual Int_t LearnBranch(TBranch *, Bool_t=kFALSE)
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
Int_t GetCompressionSettings() const
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseGeneralPurpose, Int_t netopt=0)
Create / open a file.
virtual Long64_t GetSeekKey() const
virtual void SetParent(const TObject *parent)
Set parent in key buffer.
TBuffer * GetBufferRef() const
A TLeaf for an 8 bit Integer data type.
A TLeaf for a variable length string.
A TLeaf for a 64 bit floating point data type.
A TLeaf for a 32 bit floating point data type.
A TLeaf for an Integer data type.
A TLeaf for a 64 bit Integer data type.
A TLeaf for a bool data type.
A TLeaf for a 16 bit Integer data type.
A TLeaf describes individual elements of a TBranch See TBranch structure in TTree.
virtual Int_t GetLenType() const
virtual const char * GetTypeName() const
virtual Int_t GetLen() const
Return the number of effective elements of this leaf, for the current entry.
virtual TLeaf * GetLeafCount() const
If this leaf stores a variable-sized array or a multi-dimensional array whose last dimension has vari...
virtual void ReadBasketExport(TBuffer &, TClonesArray *, Int_t)
virtual void SetAddress(void *add=0)
virtual void FillBasket(TBuffer &b)
Pack leaf elements in Basket output buffer.
TBranch * GetBranch() const
virtual void SetOffset(Int_t offset=0)
virtual void SetBranch(TBranch *branch)
virtual void SetUnsigned()
virtual Int_t GetOffset() const
virtual void ReadBasket(TBuffer &)
The TNamed class is the base class for all named ROOT classes.
virtual const char * GetTitle() const
Returns title of object.
virtual const char * GetName() const
Returns name of object.
Int_t GetEntriesFast() const
virtual void Expand(Int_t newSize)
Expand or shrink the array to newSize elements.
virtual void AddAtAndExpand(TObject *obj, Int_t idx)
Add object at position idx.
Int_t GetEntries() const
Return the number of objects in array (i.e.
TObject * UncheckedAt(Int_t i) const
virtual void Delete(Option_t *option="")
Remove all objects from the array AND delete all heap based objects.
void SetLast(Int_t last)
Set index of last object in array, effectively truncating the array.
Int_t GetLast() const
Return index of last object in array.
virtual void AddAt(TObject *obj, Int_t idx)
Add object at position ids.
virtual TObject * RemoveAt(Int_t idx)
Remove object at index idx.
TObject * At(Int_t idx) const
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual const char * ClassName() const
Returns name of class to which the object belongs.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
R__ALWAYS_INLINE Bool_t IsZombie() const
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Fatal(const char *method, const char *msgfmt,...) const
Issue fatal error message.
static void * ReAlloc(void *vp, size_t size)
Reallocate (i.e.
static Int_t * ReAllocInt(Int_t *vp, size_t size, size_t oldsize)
Reallocate (i.e.
void ToLower()
Change string to lower-case.
void Clear()
Clear string without changing its capacity.
Ssiz_t First(char c) const
Find first occurrence of a character c.
const char * Data() const
TString & Prepend(const char *cs)
TString & Remove(Ssiz_t pos)
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual Bool_t ExpandPathName(TString &path)
Expand a pathname getting rid of special shell characters like ~.
virtual const char * DirName(const char *pathname)
Return the directory name in pathname.
virtual const char * BaseName(const char *pathname)
Base name of a file name. Base name of /user/root is root.
virtual Bool_t IsAbsoluteFileName(const char *dir)
Return true if dir is an absolute pathname.
Helper class to iterate over cluster of baskets.
Long64_t Previous()
Move on to the previous cluster and return the starting entry of this previous cluster.
Long64_t Next()
Move on to the next cluster and return the starting entry of this next cluster.
A TTree object has a header with a name and a title.
virtual TVirtualPerfStats * GetPerfStats() const
virtual TClusterIterator GetClusterIterator(Long64_t firstentry)
Return an iterator over the cluster of baskets starting at firstentry.
void AddAllocationCount(UInt_t count)
virtual TObjArray * GetListOfLeaves()
TFile * GetCurrentFile() const
Return pointer to the current file.
virtual void IncrementTotalBuffers(Int_t nbytes)
TDirectory * GetDirectory() const
TTreeCache * GetReadCache(TFile *file) const
Find and return the TTreeCache registered with the file and which may contain branches for us.
virtual TObjArray * GetListOfBranches()
virtual void AddZipBytes(Int_t zip)
virtual TBasket * CreateBasket(TBranch *)
Create a basket for this tree and given branch.
virtual void Draw(Option_t *opt)
Default Draw method for all objects.
virtual Bool_t GetClusterPrefetch() const
virtual void AddTotBytes(Int_t tot)
virtual Long64_t GetAutoFlush() const
virtual Long64_t GetMaxVirtualSize() const
This class represents a WWW compatible URL.
const char * GetAnchor() const
const char * GetUrl(Bool_t withDeflt=kFALSE) const
Return full URL.
void SetAnchor(const char *anchor)
static Int_t FillListOfBrowsables(TList &list, const TBranch *branch, const TVirtualBranchBrowsable *parent=0)
Askes all registered generators to fill their browsables into the list.
virtual void SetUsed(TBranch *b, size_t basketNumber)=0
Type GetType(const std::string &Name)
static constexpr double s
Short_t Max(Short_t a, Short_t b)
Long64_t BinarySearch(Long64_t n, const T *array, T value)
@ kUndefined
Undefined compression algorithm (must be kept the last of the list in case a new algorithm is added).