Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
ProcFileElements.h
Go to the documentation of this file.
1/// \file
2/// \ingroup tutorial_ProcFileElements
3///
4/// Class to hold information about the processed elements of a file
5///
6/// \macro_code
7///
8/// \author Gerardo Ganis (gerardo.ganis@cern.ch)
9
10
11#ifndef ROOT_ProcFileElements
12#define ROOT_ProcFileElements
13
14
15#include "TObject.h"
16#include "TSortedList.h"
17
18class ProcFileElements : public TObject {
19
20public:
21 class ProcFileElement : public TObject {
22 public:
23 Long64_t fFirst; // Lower bound of this range
24 Long64_t fLast; // Upper bound of this range
26 fFirst(fst), fLast(lst) { }
27 ~ProcFileElement() override { }
28
29 Int_t Compare(const TObject *obj) const override;
30
31 Bool_t IsSortable() const override { return kTRUE; }
32 Int_t MergeElement(ProcFileElement *);
33
35 void Print(Option_t *option="") const override;
36
37 ClassDefOverride(ProcFileElement, 1); // ProcFileElement class
38 };
39
40private:
41 TString fName; // File name
42 TSortedList *fElements; // List of processed elements
43
44 Long64_t fFirst; // Overall lower bound
45 Long64_t fLast; // Overall Upper bound
46
47public:
48 ProcFileElements(const char *fn = "") : fName(fn), fElements(nullptr),
49 fFirst(0), fLast(-1) { }
50 ~ProcFileElements() override { if (fElements) { fElements->SetOwner();
51 delete fElements; } }
52 const char * GetName() const override { return fName; }
53 ULong_t Hash() const override { return fName.Hash(); }
54
55 Int_t Add(Long64_t fst = 0, Long64_t lst = -1);
56 Int_t Merge(TCollection *list);
57
58 TSortedList *GetListOfElements() const { return fElements; }
59 Int_t GetNumElements() const { return (fElements ? fElements->GetSize() : 0); }
60
61 Long64_t GetFirst() const { return fFirst; }
62 Long64_t GetLast() const { return fLast; }
63
64 void Print(Option_t *option="") const override;
65
66 ClassDefOverride(ProcFileElements, 1); // Processed File Elements class
67};
68
69#endif
bool Bool_t
Definition RtypesCore.h:63
int Int_t
Definition RtypesCore.h:45
unsigned long ULong_t
Definition RtypesCore.h:55
long long Long64_t
Definition RtypesCore.h:69
constexpr Bool_t kTRUE
Definition RtypesCore.h:93
const char Option_t
Definition RtypesCore.h:66
#define ClassDefOverride(name, id)
Definition Rtypes.h:346
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
Int_t Compare(const void *item1, const void *item2)
Option_t Option_t option
void Print(GNN_Data &d, std::string txt="")
UInt_t Hash(const TString &s)
Definition TString.h:494
T1 fFirst
Definition X11Events.mm:86
Collection abstract base class.
Definition TCollection.h:65
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
Mother of all ROOT objects.
Definition TObject.h:41
A sorted doubly linked list.
Definition TSortedList.h:28
Basic string class.
Definition TString.h:139
UInt_t Hash(ECaseCompare cmp=kExact) const
Return hash value.
Definition TString.cxx:677
TMatrixT< Element > & Add(TMatrixT< Element > &target, Element scalar, const TMatrixT< Element > &source)
Modify addition: target += scalar * source.