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  void set_ownership(Bool_t enable)
124  {
125  TSeqCollection::SetOwner(enable);
126  fCollection->SetOwner(enable);
127  }
128 
129 public:
130  KVSeqCollection();
133  KVSeqCollection(const TString& collection_classname);
134  virtual ~KVSeqCollection();
135  void Copy(TObject& obj) const override;
138 
139  virtual void Modified()
140  {
141  Emit("Modified()");
142  } // *SIGNAL*
143  virtual void SendModifiedSignals(Bool_t yes = kTRUE)
144  {
151  SetBit(kSignals, yes);
152  }
154  {
157  return TestBit(kSignals);
158  }
159 
160  TObject* At(Int_t idx) const override
161  {
162  return fCollection->At(idx);
163  }
164  void AddFirst(TObject* obj) override
165  {
169 
170  if (IsCleanup()) obj->SetBit(kMustCleanup);
171  fCollection->AddFirst(obj);
172  Changed();
173  }
174  void AddLast(TObject* obj) override
175  {
179 
180  if (IsCleanup()) obj->SetBit(kMustCleanup);
181  fCollection->AddLast(obj);
182  Changed();
183  }
184  void AddAt(TObject* obj, Int_t idx) override
185  {
189 
190  if (IsCleanup()) obj->SetBit(kMustCleanup);
191  fCollection->AddAt(obj, idx);
192  Changed();
193  }
194  void AddAfter(const TObject* after, TObject* obj) override
195  {
199 
200  if (IsCleanup()) obj->SetBit(kMustCleanup);
201  fCollection->AddAfter(after, obj);
202  Changed();
203  }
204  void AddBefore(const TObject* before, TObject* obj) override
205  {
209 
210  if (IsCleanup()) obj->SetBit(kMustCleanup);
211  fCollection->AddBefore(before, obj);
212  Changed();
213  }
214  TObject* Before(const TObject* obj) const override
215  {
216  return fCollection->Before(obj);
217  }
218  TObject* After(const TObject* obj) const override
219  {
220  return fCollection->After(obj);
221  }
222  TObject* First() const override
223  {
224  return fCollection->First();
225  }
226  TObject* Last() const override
227  {
228  return fCollection->Last();
229  }
230  void Add(TObject* obj) override
231  {
235 
236  if (IsCleanup()) obj->SetBit(kMustCleanup);
237  fCollection->Add(obj);
238  Changed();
239  }
240  void Clear(Option_t* option = "") override;
241  void Delete(Option_t* option = "") override;
242  TObject** GetObjectRef(const TObject* obj) const override;
243  TIterator* MakeIterator(Bool_t dir = kIterForward) const override;
244  TObject* Remove(TObject* obj) override;
245  void RecursiveRemove(TObject* obj) override;
246  Int_t GetSize() const override
247  {
248  return fCollection ? fCollection->GetSize() : 0;
249  }
250  void SetOwner(Bool_t enable = kTRUE) override
251  {
252  set_ownership(enable);
253  }
255  {
257  return fCollection->ClassName();
258  }
259  virtual void SetCleanup(Bool_t enable = kTRUE);
261  {
264  return TestBit(kCleanup);
265  }
266  static void RehashCleanupList();
267 
268  TObject* FindObject(const char* name) const override
269  {
270  return fCollection->FindObject(name);
271  }
272  template
273  <typename T>
274  T* get_object(const TString& name) const
275  {
276  return dynamic_cast<T*>(FindObject(name));
277  }
278  TObject* FindObject(const TObject* obj) const override
279  {
280  return fCollection->FindObject(obj);
281  }
282  virtual TObject* FindObjectByName(const Char_t* name) const
283  {
284  return fCollection->FindObject(name);
285  }
286  virtual TObject* FindObjectByType(const Char_t*) const;
287  virtual TObject* FindObjectByTitle(const Char_t*) const;
288  TObject* FindObjectByClass(const Char_t*) const;
289  TObject* FindObjectByClass(const TClass*) const;
290  virtual TObject* FindObjectByLabel(const Char_t*) const;
291  virtual TObject* FindObjectByNumber(UInt_t num) const;
292  virtual TObject* FindObjectWithNameAndType(const Char_t* name, const Char_t* type) const;
293  virtual TObject* FindObjectWithMethod(const Char_t* retvalue, const Char_t* method) const;
294  virtual TObject* FindObjectAny(const Char_t* att, const Char_t* keys, Bool_t contains_all = kFALSE, Bool_t case_sensitive = kTRUE) const;
295 
296 #ifdef __WITHOUT_TCOLLECTION_GETENTRIES
298  Int_t GetEntries() const override
299  {
300  return GetSize();
301  };
302 #endif
303  void Execute(const char* method, const char* params,
304  Int_t* error = 0) override;
305  void Execute(TMethod* method, TObjArray* params,
306  Int_t* error = 0) override;
307  KVSeqCollection* GetSubListWithMethod(const Char_t* retvalue, const Char_t* method) const;
308 
309  KVSeqCollection* GetSubListWithClass(const TClass* _class) const;
310  KVSeqCollection* GetSubListWithClass(const Char_t* class_name) const;
311 
312  KVSeqCollection* GetSubListWithName(const Char_t* retvalue) const;
313  KVSeqCollection* GetSubListWithLabel(const Char_t* retvalue) const;
314  KVSeqCollection* GetSubListWithType(const Char_t* retvalue) const;
315 
317  static KVSeqCollection* MakeListFromFileWithMethod(TFile* file, const Char_t* retvalue, const Char_t* method);
318  static KVSeqCollection* MakeListFromFileWithClass(TFile* file, const TClass* _class);
319  static KVSeqCollection* MakeListFromFileWithClass(TFile* file, const Char_t* class_name);
320 
321  Bool_t IsSortable() const override
322  {
323  return fCollection->IsSortable();
324  }
325  Bool_t IsSorted() const override
326  {
327  return fCollection->IsSorted();
328  }
329 
331  {
332  return fCollection;
333  }
335  {
337  return IsEmpty();
338  }
339 
340  ClassDefOverride(KVSeqCollection, 3) //KaliVeda extensions to ROOT collections
341 };
342 
343 #if ROOT_VERSION_CODE < ROOT_VERSION(5,11,2)
344 
346 
349 
350 #define R__FOR_EACH(type,proc) \
351  SetCurrentCollection(); \
352  TIter _NAME3_(nxt_,type,proc)(TCollection::GetCurrentCollection()); \
353  type *_NAME3_(obj_,type,proc); \
354  while ((_NAME3_(obj_,type,proc) = (type*) _NAME3_(nxt_,type,proc)())) \
355  _NAME3_(obj_,type,proc)->proc
356 
357 #endif
358 
359 #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 &)
Info("operator=","copy ass");.
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
void set_ownership(Bool_t enable)
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.
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)