KaliVeda
Toolkit for HIC analysis
KVSeqCollection.h
1 
4 #ifndef __KVSEQCOLLECTION_H
5 #define __KVSEQCOLLECTION_H
6 
7 #include "TSeqCollection.h"
8 #include <RQ_OBJECT.h>
9 #include "TFile.h"
10 #include "KVConfig.h"
11 
42 
93  RQ_OBJECT("KVSeqCollection")
94 
95  enum {
96  kSignals = BIT(15), // bit flag for sending 'Modified()' signal on changes
98  kCleanup = BIT(17) // set when objects in list are in ROOT cleanup list
99  };
100 
102  void init();
103  static Int_t fgCounter;
105 
106 protected:
108 
109  void Changed() override
110  {
114 
116  if (TestBit(kSignals)) Modified();
117  };
118  void PrintCollectionHeader(Option_t* option) const override;
120  void SetCollection(const TString&);
121  virtual void _GetSubListWithMethod(KVSeqCollection*, TCollection*, const Char_t*, const Char_t*) const;
123 
124 public:
125  KVSeqCollection();
128  KVSeqCollection(const TString& collection_classname);
129  virtual ~KVSeqCollection();
130  void Copy(TObject& obj) const override;
133 
134  virtual void Modified()
135  {
136  Emit("Modified()");
137  } // *SIGNAL*
138  virtual void SendModifiedSignals(Bool_t yes = kTRUE)
139  {
146  SetBit(kSignals, yes);
147  }
149  {
152  return TestBit(kSignals);
153  }
154 
155  TObject* At(Int_t idx) const override
156  {
157  return fCollection->At(idx);
158  }
159  void AddFirst(TObject* obj) override
160  {
164 
165  if (IsCleanup()) obj->SetBit(kMustCleanup);
166  fCollection->AddFirst(obj);
167  Changed();
168  }
169  void AddLast(TObject* obj) override
170  {
174 
175  if (IsCleanup()) obj->SetBit(kMustCleanup);
176  fCollection->AddLast(obj);
177  Changed();
178  }
179  void AddAt(TObject* obj, Int_t idx) override
180  {
184 
185  if (IsCleanup()) obj->SetBit(kMustCleanup);
186  fCollection->AddAt(obj, idx);
187  Changed();
188  }
189  void AddAfter(const TObject* after, TObject* obj) override
190  {
194 
195  if (IsCleanup()) obj->SetBit(kMustCleanup);
196  fCollection->AddAfter(after, obj);
197  Changed();
198  }
199  void AddBefore(const TObject* before, TObject* obj) override
200  {
204 
205  if (IsCleanup()) obj->SetBit(kMustCleanup);
206  fCollection->AddBefore(before, obj);
207  Changed();
208  }
209  TObject* Before(const TObject* obj) const override
210  {
211  return fCollection->Before(obj);
212  }
213  TObject* After(const TObject* obj) const override
214  {
215  return fCollection->After(obj);
216  }
217  TObject* First() const override
218  {
219  return fCollection->First();
220  }
221  TObject* Last() const override
222  {
223  return fCollection->Last();
224  }
225  void Add(TObject* obj) override
226  {
230 
231  if (IsCleanup()) obj->SetBit(kMustCleanup);
232  fCollection->Add(obj);
233  Changed();
234  }
235  void Clear(Option_t* option = "") override;
236  void Delete(Option_t* option = "") override;
237  TObject** GetObjectRef(const TObject* obj) const override;
238  TIterator* MakeIterator(Bool_t dir = kIterForward) const override;
239  TObject* Remove(TObject* obj) override;
240  void RecursiveRemove(TObject* obj) override;
241  Int_t GetSize() const override
242  {
243  return fCollection ? fCollection->GetSize() : 0;
244  }
245  void SetOwner(Bool_t enable = kTRUE) override
246  {
248  TSeqCollection::SetOwner(enable);
249  fCollection->SetOwner(enable);
250  }
252  {
254  return fCollection->ClassName();
255  }
256  virtual void SetCleanup(Bool_t enable = kTRUE);
258  {
261  return TestBit(kCleanup);
262  }
263  static void RehashCleanupList();
264 
265  TObject* FindObject(const char* name) const override
266  {
267  return fCollection->FindObject(name);
268  }
269  template
270  <typename T>
271  T* get_object(const TString& name) const
272  {
273  return dynamic_cast<T*>(FindObject(name));
274  }
275  TObject* FindObject(const TObject* obj) const override
276  {
277  return fCollection->FindObject(obj);
278  }
279  virtual TObject* FindObjectByName(const Char_t* name) const
280  {
281  return fCollection->FindObject(name);
282  }
283  virtual TObject* FindObjectByType(const Char_t*) const;
284  virtual TObject* FindObjectByTitle(const Char_t*) const;
285  TObject* FindObjectByClass(const Char_t*) const;
286  TObject* FindObjectByClass(const TClass*) const;
287  virtual TObject* FindObjectByLabel(const Char_t*) const;
288  virtual TObject* FindObjectByNumber(UInt_t num) const;
289  virtual TObject* FindObjectWithNameAndType(const Char_t* name, const Char_t* type) const;
290  virtual TObject* FindObjectWithMethod(const Char_t* retvalue, const Char_t* method) const;
291  virtual TObject* FindObjectAny(const Char_t* att, const Char_t* keys, Bool_t contains_all = kFALSE, Bool_t case_sensitive = kTRUE) const;
292 
293 #ifdef __WITHOUT_TCOLLECTION_GETENTRIES
295  Int_t GetEntries() const override
296  {
297  return GetSize();
298  };
299 #endif
300  void Execute(const char* method, const char* params,
301  Int_t* error = 0) override;
302  void Execute(TMethod* method, TObjArray* params,
303  Int_t* error = 0) override;
304  KVSeqCollection* GetSubListWithMethod(const Char_t* retvalue, const Char_t* method) const;
305 
306  KVSeqCollection* GetSubListWithClass(const TClass* _class) const;
307  KVSeqCollection* GetSubListWithClass(const Char_t* class_name) const;
308 
309  KVSeqCollection* GetSubListWithName(const Char_t* retvalue) const;
310  KVSeqCollection* GetSubListWithLabel(const Char_t* retvalue) const;
311  KVSeqCollection* GetSubListWithType(const Char_t* retvalue) const;
312 
314  static KVSeqCollection* MakeListFromFileWithMethod(TFile* file, const Char_t* retvalue, const Char_t* method);
315  static KVSeqCollection* MakeListFromFileWithClass(TFile* file, const TClass* _class);
316  static KVSeqCollection* MakeListFromFileWithClass(TFile* file, const Char_t* class_name);
317 
318  Bool_t IsSortable() const override
319  {
320  return fCollection->IsSortable();
321  }
322  Bool_t IsSorted() const override
323  {
324  return fCollection->IsSorted();
325  }
326 
328  {
329  return fCollection;
330  }
332  {
334  return IsEmpty();
335  }
336 
337  ClassDefOverride(KVSeqCollection, 3) //KaliVeda extensions to ROOT collections
338 };
339 
340 #if ROOT_VERSION_CODE < ROOT_VERSION(5,11,2)
341 
343 
346 
347 #define R__FOR_EACH(type,proc) \
348  SetCurrentCollection(); \
349  TIter _NAME3_(nxt_,type,proc)(TCollection::GetCurrentCollection()); \
350  type *_NAME3_(obj_,type,proc); \
351  while ((_NAME3_(obj_,type,proc) = (type*) _NAME3_(nxt_,type,proc)())) \
352  _NAME3_(obj_,type,proc)->proc
353 
354 #endif
355 
356 #endif
int Int_t
unsigned int UInt_t
#define RQ_OBJECT(sender_class)
bool Bool_t
char Char_t
const char Option_t
#define BIT(n)
#define ClassDefOverride(name, id)
char name[80]
KaliVeda extensions to ROOT collection classes.
Bool_t IsSorted() const override
virtual TObject * FindObjectByLabel(const Char_t *) const
void Copy(TObject &obj) const override
static Long64_t fSCCounter
counter used to give unique names to all lists
virtual void Modified()
TObject ** GetObjectRef(const TObject *obj) const override
Return reference to object.
void Execute(const char *method, const char *params, Int_t *error=0) override
virtual ~KVSeqCollection()
KVSeqCollection * GetSubListWithName(const Char_t *retvalue) const
TObject * First() const override
KVSeqCollection * GetSubListWithMethod(const Char_t *retvalue, const Char_t *method) const
KVSeqCollection & operator=(const KVSeqCollection &)
static TSeqCollection * fgCleanups
regroup all lists which are to be cleaned up
TObject * Before(const TObject *obj) const override
T * get_object(const TString &name) const
virtual void SendModifiedSignals(Bool_t yes=kTRUE)
KVSeqCollection * NewCollectionLikeThisOne() const
TObject * Remove(TObject *obj) override
Remove object from list.
Bool_t IsSortable() const override
void Add(TObject *obj) override
KVSeqCollection * GetSubListWithClass(const TClass *_class) const
TSeqCollection * fCollection
Pointer to embedded ROOT collection.
void Changed() override
@ kCleanup
in ROOT v6 BIT(16) is used by TCollection - without changing the class version
void AddAfter(const TObject *after, TObject *obj) override
TObject * FindObject(const char *name) const override
TObject * FindObject(const TObject *obj) const override
void AddLast(TObject *obj) override
TObject * After(const TObject *obj) const override
virtual TObject * FindObjectAny(const Char_t *att, const Char_t *keys, Bool_t contains_all=kFALSE, Bool_t case_sensitive=kTRUE) const
void AddBefore(const TObject *before, TObject *obj) override
void SetCollection(const TString &)
TObject * FindObjectByClass(const Char_t *) const
Return (first) object in embedded list with given class.
KVSeqCollection * GetSubListWithType(const Char_t *retvalue) const
virtual void _GetSubListWithMethod(KVSeqCollection *, TCollection *, const Char_t *, const Char_t *) const
TIterator * MakeIterator(Bool_t dir=kIterForward) const override
Make and return iterator for the list.
KVSeqCollection()
Default constructor.
void RecursiveRemove(TObject *obj) override
virtual Bool_t IsSendingModifiedSignals() const
void PrintCollectionHeader(Option_t *option) const override
Overrides TCollection::PrintCollectionHeader to show the class name of the embedded list.
TObject * Last() const override
Int_t GetSize() const override
static void RehashCleanupList()
void Clear(Option_t *option="") override
Bool_t operator!() const
static Int_t fgCounter
counts instances
virtual void SetCleanup(Bool_t enable=kTRUE)
Bool_t IsCleanup() const
void SetOwner(Bool_t enable=kTRUE) override
static KVSeqCollection * MakeListFromFileWithClass(TFile *file, const TClass *_class)
virtual TObject * FindObjectByNumber(UInt_t num) const
TSeqCollection * GetCollection() const
virtual TObject * FindObjectWithMethod(const Char_t *retvalue, const Char_t *method) const
static KVSeqCollection * MakeListFromFile(TFile *file)
virtual TObject * FindObjectByType(const Char_t *) const
TObject * At(Int_t idx) const override
virtual TObject * FindObjectByTitle(const Char_t *) const
Will return object with given title (value of TObject::GetTitle() method).
virtual TObject * FindObjectByName(const Char_t *name) const
TString CollectionClassName() const
void AddAt(TObject *obj, Int_t idx) override
void Delete(Option_t *option="") override
virtual TObject * FindObjectWithNameAndType(const Char_t *name, const Char_t *type) const
void AddFirst(TObject *obj) override
KVSeqCollection * GetSubListWithLabel(const Char_t *retvalue) const
static KVSeqCollection * MakeListFromFileWithMethod(TFile *file, const Char_t *retvalue, const Char_t *method)
void _GetSubListWithClass(KVSeqCollection *, TCollection *, const TClass *) const
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
TObject * FindObject(const char *name) const override
virtual Bool_t IsEmpty() const
Bool_t IsSortable() const override
virtual Int_t GetSize() const
void SetBit(UInt_t f)
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual const char * ClassName() const
virtual TObject * After(const TObject *obj) const=0
virtual void AddLast(TObject *obj)=0
virtual void AddBefore(const TObject *before, TObject *obj)=0
virtual TObject * Before(const TObject *obj) const=0
virtual void AddAt(TObject *obj, Int_t idx)=0
virtual TObject * Last() const=0
virtual void AddAfter(const TObject *after, TObject *obj)=0
virtual Bool_t IsSorted() const
virtual void Changed()
virtual TObject * First() const=0
virtual TObject * At(Int_t idx) const=0
virtual void AddFirst(TObject *obj)=0
void Add(TObject *obj) override
long long Long64_t
double T(double x)