library: libTreePlayer
#include "TTreeFormulaManager.h"

TTreeFormulaManager


class description - header file - source file
viewCVS header - viewCVS source

class TTreeFormulaManager: public TObject

Inheritance Inherited Members Includes Libraries
Class Charts

Function Members (Methods)

Display options:
Show inherited
Show non-public
public:
TTreeFormulaManager()
voidTObject::AbstractMethod(const char* method) const
virtual voidAdd(TTreeFormula*)
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
virtual voidTObject::Delete(Option_t* option = "")
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() const
virtual TObject*TObject::DrawClone(Option_t* option = "") const
virtual voidTObject::Dump() const
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
virtual Int_tGetMultiplicity() const
virtual const char*TObject::GetName() const
virtual Int_tGetNdata(Bool_t forceLoadDim = kFALSE)
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() const
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tNotify()
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
virtual voidRemove(TTreeFormula*)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") const
virtual voidTObject::SavePrimitive(ostream& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp, char* parent)
virtual voidStreamer(TBuffer& b)
voidStreamerNVirtual(TBuffer& b)
virtual Bool_tSync()
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidUpdateFormulaLeaves()
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = "0", Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = "0", Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidAddVarDims(Int_t virt_dim)
virtual voidCancelDimension(Int_t virt_dim)
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
virtual voidEnableMultiVarDims()
voidTObject::MakeZombie()
virtual voidUpdateUsedSize(Int_t& virt_dim, Int_t vsize)
private:
TTreeFormulaManager(const TTreeFormulaManager&)
~TTreeFormulaManager()
TTreeFormulaManager&operator=(const TTreeFormulaManager&)

Data Members

public:
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
private:
TObjArrayfFormulas
Int_tfMultiplicityIndicator of the variability of the formula
Bool_tfMultiVarDimTrue if one of the variable has 2 variable size dimensions.
Int_tfNdata! Last value calculated by GetNdata
Int_tfCumulUsedSizes[6]Accumulated size of lower dimensions as seen for this entry
TArrayI*fCumulUsedVarDimsfCumulUsedSizes(1) for multi variable dimensions case
Int_tfUsedSizes[6]Actual size of the dimensions as seen for this entry.
TArrayI*fVarDims[6]List of variable sizes dimensions.
Int_tfVirtUsedSizes[6]Virtual size of lower dimensions as seen for this formula
Bool_tfNeedSyncIndicate whether a new formula has been added since the last synchronization

Class Description


     A TreeFormulaManager is used to coordinate one or more TTreeFormula objecs

  In particular it makes sure that the dimensions and size of all the formulas
  is properly coordinated.

TTreeFormulaManager()
*-*-*-*-*-*-*-*-*-*-*Tree FormulaManger default constructor*-*-*-*-*-*-*-*-*-*
*-*                  ======================================
~TTreeFormulaManager()
*-*-*-*-*-*-*-*-*-*-*Tree FormulaManager default destructor*-*-*-*-*-*-*-*-*-*
*-*                  ======================================
void Remove(TTreeFormula* adding)
 Remove a formula from this manager
void Add(TTreeFormula* adding)
 Add a new formula to the list of formulas managed
 The manager of the formula will be changed and the old one will be deleted
 if it is empty.
void AddVarDims(Int_t virt_dim)
 Add a variable dimension
void CancelDimension(Int_t virt_dim)
 Cancel a dimension.  This is usually called when an out-of-bounds index
 is used.
void EnableMultiVarDims()
 Set the manager as handling a formula with multiple variable dimensions
Int_t GetNdata(Bool_t forceLoadDim)
*-*-*-*-*-*-*-*Return number of available instances in the formulas*-*-*-*-*-*
*-*            ====================================================

Bool_t Sync()
 Synchronize all the formulae.
void UpdateFormulaLeaves()
 this function could be called TTreePlayer::UpdateFormulaLeaves, itself
 called by TChain::LoadTree when a new Tree is loaded.
 Because Trees in a TChain may have a different list of leaves, one
 must update the leaves numbers in the TTreeFormula used by the TreePlayer.
void UpdateUsedSize(Int_t &virt_dim, Int_t vsize)
 Reload the array sizes
TTreeFormulaManager(const TTreeFormulaManager&)
 Not implemented yet
TTreeFormulaManager& operator=(const TTreeFormulaManager&)
Int_t GetMultiplicity()
{return fMultiplicity;}
Bool_t Notify()
{ UpdateFormulaLeaves(); return kTRUE; }

Author: Philippe Canal 20/03/02
Last update: root/treeplayer:$Name: $:$Id: TTreeFormulaManager.cxx,v 1.7 2005/11/11 23:21:43 pcanal Exp $
Copyright (C) 1995-2000, Rene Brun and Fons Rademakers and al. *


ROOT page - Class index - Class Hierarchy - Top of the page

This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.