Logo ROOT   6.30.04
Reference Guide
 All Namespaces Files Pages
TTreeFormulaManager.h
Go to the documentation of this file.
1 // @(#)root/treeplayer:$Id$
2 // Author: Philippe Canal 20/03/02
3 
4 /*************************************************************************
5  * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers and al. *
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_TTreeFormulaManager
13 #define ROOT_TTreeFormulaManager
14 
15 
16 //////////////////////////////////////////////////////////////////////////
17 // //
18 // TTreeFormulaManager //
19 // //
20 // A class coordinating several TTreeFormula objects. //
21 // //
22 //////////////////////////////////////////////////////////////////////////
23 
24 #include "TObjArray.h"
25 #include "TTreeFormula.h"
26 
27 class TArrayI;
28 
29 
30 class TTreeFormulaManager : public TObject {
31 private:
32  TObjArray fFormulas;
33  Int_t fMultiplicity; // Indicator of the variability of the formula
34  Bool_t fMultiVarDim; // True if one of the variable has 2 variable size dimensions.
35  Int_t fNdata; //! Last value calculated by GetNdata
36 
37  //the next line should be: mutable Int_t fCumulUsedSizes[kMAXFORMDIM+1]; See GetNdata()
38  Int_t fCumulUsedSizes[kMAXFORMDIM+1]; //Accumulated size of lower dimensions as seen for this entry
39  TArrayI *fCumulUsedVarDims; //fCumulUsedSizes(1) for multi variable dimensions case
40  //the next line should be: mutable Int_t fUsedSizes[kMAXFORMDIM+1]; See GetNdata()
41  Int_t fUsedSizes[kMAXFORMDIM+1]; //Actual size of the dimensions as seen for this entry.
42  TArrayI *fVarDims[kMAXFORMDIM+1]; //List of variable sizes dimensions.
43  Int_t fVirtUsedSizes[kMAXFORMDIM+1]; //Virtual size of lower dimensions as seen for this formula
44 
45  Bool_t fNeedSync; // Indicate whether a new formula has been added since the last synchronization
46 
47  friend class TTreeFormula;
48 
49 private:
50  // Not implemented yet
51  TTreeFormulaManager(const TTreeFormulaManager&) = delete;
52  TTreeFormulaManager& operator=(const TTreeFormulaManager&) = delete;
53 
54 protected:
55 
56  virtual void AddVarDims(Int_t virt_dim);
57  virtual void CancelDimension(Int_t virt_dim);
58  virtual void EnableMultiVarDims();
59  virtual void UpdateUsedSize(Int_t &virt_dim, Int_t vsize);
60 
61 public:
62  TTreeFormulaManager();
63  ~TTreeFormulaManager();
64 
65  virtual void Add(TTreeFormula*);
66  virtual Int_t GetMultiplicity() const {return fMultiplicity;}
67  virtual Int_t GetNdata(Bool_t forceLoadDim = kFALSE);
68  virtual Bool_t Notify() { UpdateFormulaLeaves(); return kTRUE; }
69  virtual void Remove(TTreeFormula*);
70  virtual Bool_t Sync();
71  virtual void UpdateFormulaLeaves();
72 
73  ClassDef(TTreeFormulaManager,0) // A class coordinating several TTreeFormula objects.
74 };
75 
76 
77 #endif // ROOT_TTreeFormulaManager
78