KaliVeda
Toolkit for HIC analysis
KVIDGridManager Class Reference

Detailed Description

Handles a stock of identification grids to be used by one or more identification telescopes.

Each KVIDTelescope asks the grid manager for a grid (FindGrid), if one is available its address is given to the telescope to use. In this way many IDTelescopes can use the same grid without making multiple copies.

Definition at line 29 of file KVIDGridManager.h.

#include <KVIDGridManager.h>

Inheritance diagram for KVIDGridManager:

Public Member Functions

 KVIDGridManager ()
 
virtual ~ KVIDGridManager ()
 
void Clear (Option_t *opt="")
 Delete all grids and empty list, ready to start anew. More...
 
void DeleteGrid (KVIDGraph *, Bool_t update=kTRUE)
 
KVIDGraphGetGrid (const Char_t *name)
 Return pointer to grid with name "name". More...
 
KVListGetGrids ()
 
KVListGetGridsForIDTelescope (const Char_t *label)
 
const TList * GetLastReadGrids () const
 
void GetListOfIDTelescopeLabels (KVString &)
 
void Initialize (Option_t *="")
 
virtual bool IsSQLROOT () const
 
virtual void LoadGridsForRun (UInt_t)
 
void ls (Option_t *="") const
 
void Modified ()
 
void Print (Option_t *="") const
 
Bool_t ReadAsciiFile (const Char_t *filename)
 
void StartViewer () const
 Opens GUI for managing grids. More...
 
Int_t WriteAsciiFile (const Char_t *filename, const TCollection *selection=0)
 
- Public Member Functions inherited from KVBase
 KVBase ()
 Default constructor. More...
 
 KVBase (const Char_t *name, const Char_t *title="")
 Ctor for object with given name and type. More...
 
 KVBase (const KVBase &)
 copy ctor More...
 
virtual ~ KVBase ()
 
virtual void Copy (TObject &) const
 Make a copy of this object. More...
 
const Char_t * GetLabel () const
 
UInt_t GetNumber () const
 
UInt_t GetNumberOfObjects () const
 
virtual TObject * GetObject () const
 
virtual const Char_t * GetType () const
 
Bool_t HasLabel () const
 
virtual Bool_t IsCalled (const Char_t *name) const
 
Bool_t IsLabelled (const Char_t *l) const
 
virtual Bool_t IsType (const Char_t *typ) const
 
virtual void List ()
 
KVBaseoperator= (const KVBase &)
 copy assignment operator More...
 
Double_t ProtectedGetX (const TF1 *func, Double_t val, int &status, Double_t xmin=0.0, Double_t xmax=0.0) const
 
void SetLabel (const Char_t *lab)
 
virtual void SetNumber (UInt_t num)
 
virtual void SetType (const Char_t *str)
 

Private Member Functions

void AddGrid (KVIDGraph *)
 Add a grid to the collection. It will be deleted by the manager. More...
 

Private Attributes

KVList fGrids
 collection of all ID graphs handled by manager More...
 
TList fLastReadGrids
 list of grids created by last call to ReadAsciiFile More...
 

Friends

class KVIDGraph
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 
- Static Public Member Functions inherited from KVBase
static Bool_t AreEqual (Double_t x, Double_t y, Long64_t maxdif=1)
 Comparison between two 64-bit floating-point values. More...
 
static void BackupFileWithDate (const Char_t *path)
 
static void CombineFiles (const Char_t *file1, const Char_t *file2, const Char_t *newfilename, Bool_t keep=kTRUE)
 
static void Deprecated (const char *method, const char *advice)
 
static Bool_t FindClassSourceFiles (const Char_t *class_name, KVString &imp_file, KVString &dec_file, const Char_t *dir_name=".")
 
static Bool_t FindExecutable (TString &exec, const Char_t *path="$(PATH)")
 
static const Char_t * FindFile (const Char_t *search, TString &wfil)
 
static const Char_t * GetBINDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetDATABASEFilePath ()
 
static const Char_t * GetDATADIRFilePath (const Char_t *namefile="")
 
static Bool_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval)
 
static const Char_t * GetDataSetEnv (const Char_t *dataset, const Char_t *type, const Char_t *defval)
 
static Double_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Double_t defval)
 
static const Char_t * GetETCDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetExampleFilePath (const Char_t *library, const Char_t *namefile)
 Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) More...
 
static const Char_t * GetINCDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetKVBuildDate ()
 Returns KaliVeda build date. More...
 
static const Char_t * GetKVBuildDir ()
 Returns top-level directory used for build. More...
 
static const Char_t * GetKVBuildTime ()
 Returns KaliVeda build time. More...
 
static const Char_t * GetKVBuildType ()
 Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) More...
 
static const Char_t * GetKVBuildUser ()
 Returns username of person who performed build. More...
 
static const Char_t * GetKVSourceDir ()
 Returns top-level directory of source tree used for build. More...
 
static const Char_t * GetKVVersion ()
 Returns KaliVeda version string. More...
 
static const Char_t * GetLIBDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetListOfPlugins (const Char_t *base)
 
static const Char_t * GetListOfPluginURIs (const Char_t *base)
 
static const Char_t * GetPluginURI (const Char_t *base, const Char_t *plugin)
 
static void GetTempFileName (TString &base)
 
static const Char_t * GetTEMPLATEDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetWORKDIRFilePath (const Char_t *namefile="")
 
static const Char_t * gitBranch ()
 Returns git branch of sources. More...
 
static const Char_t * gitCommit ()
 Returns last git commit of sources. More...
 
static void InitEnvironment ()
 
static bool is_gnuinstall ()
 
static Bool_t IsThisAPlugin (const TString &uri, TString &base)
 
static TPluginHandler * LoadPlugin (const Char_t *base, const Char_t *uri="0")
 
static Bool_t OpenContextMenu (const char *method, TObject *obj, const char *alt_method_name="")
 
static void OpenTempFile (TString &base, std::ofstream &fp)
 
static void PrintSplashScreen ()
 Prints welcome message and infos on version etc. More...
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="")
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, std::ifstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0)
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, std::ofstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0)
 
static Bool_t SearchKVFile (const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
 
static const Char_t * WorkingDirectory ()
 

Constructor & Destructor Documentation

◆ KVIDGridManager()

KVIDGridManager::KVIDGridManager ( )

Default constructor Initialise global pointer gIDGridManager Create list for ID grids

Definition at line 37 of file KVIDGridManager.cpp.

◆ ~ KVIDGridManager()

virtual KVIDGridManager::~ KVIDGridManager ( )
virtual

Member Function Documentation

◆ AddGrid()

void KVIDGridManager::AddGrid ( KVIDGraph grid)
private

Add a grid to the collection. It will be deleted by the manager.

Definition at line 70 of file KVIDGridManager.cpp.

◆ Clear()

void KVIDGridManager::Clear ( Option_t *  opt = "")
virtual

Delete all grids and empty list, ready to start anew.

Reimplemented from KVBase.

Definition at line 101 of file KVIDGridManager.cpp.

◆ DeleteGrid()

void KVIDGridManager::DeleteGrid ( KVIDGraph grid,
Bool_t  update = kTRUE 
)

Remove grid from manager's list and delete it update flag allows to disable the emission of the 'Modified' signal in case the GUI is deleting a list of grids - in this case we don't want to update until the end

Definition at line 84 of file KVIDGridManager.cpp.

◆ GetGrid()

KVIDGraph * KVIDGridManager::GetGrid ( const Char_t *  name)

Return pointer to grid with name "name".

Definition at line 227 of file KVIDGridManager.cpp.

◆ GetGrids()

KVList* KVIDGridManager::GetGrids ( )
inline

Definition at line 52 of file KVIDGridManager.h.

◆ GetGridsForIDTelescope()

KVList* KVIDGridManager::GetGridsForIDTelescope ( const Char_t *  label)
inline

Returns list of ID grids associated to ID telescopes of type 'label' (note: 'type' is actually value of KVIDTelescope::GetLabel) DELETE LIST AFTER USE !!!

N.B. cast to (KVList*) is valid as long as fGrids is a KVList

Definition at line 82 of file KVIDGridManager.h.

◆ GetLastReadGrids()

const TList* KVIDGridManager::GetLastReadGrids ( ) const
inline

List containing grids created by most recent call to ReadAsciiFile

Definition at line 59 of file KVIDGridManager.h.

◆ GetListOfIDTelescopeLabels()

void KVIDGridManager::GetListOfIDTelescopeLabels ( KVString list)

Replace contents of KVString with a comma-separated list of all different labels of ID telescopes associated with current list of ID grids.

Definition at line 255 of file KVIDGridManager.cpp.

◆ Initialize()

void KVIDGridManager::Initialize ( Option_t *  = "")

Initialize all grids in ID grid manager's list, i.e. we call the Initialize() method of every grid/graph.

Definition at line 281 of file KVIDGridManager.cpp.

◆ IsSQLROOT()

virtual bool KVIDGridManager::IsSQLROOT ( ) const
inlinevirtual

Reimplemented in KVSQLROOTIDGridManager.

Definition at line 94 of file KVIDGridManager.h.

◆ LoadGridsForRun()

virtual void KVIDGridManager::LoadGridsForRun ( UInt_t  )
inlinevirtual

Reimplemented in KVSQLROOTIDGridManager.

Definition at line 98 of file KVIDGridManager.h.

◆ ls()

void KVIDGridManager::ls ( Option_t *  = "") const
inline

Definition at line 70 of file KVIDGridManager.h.

◆ Modified()

void KVIDGridManager::Modified ( )
inline

Definition at line 77 of file KVIDGridManager.h.

◆ Print()

void KVIDGridManager::Print ( Option_t *  = "") const
inlinevirtual

Reimplemented from KVBase.

Definition at line 66 of file KVIDGridManager.h.

◆ ReadAsciiFile()

Bool_t KVIDGridManager::ReadAsciiFile ( const Char_t *  filename)

read file, create grids corresponding to information in file. note: any existing grids are not destroyed, use Clear() beforehand if you want to start afresh and anew (ais athat aOK?)

N.B. the links between each grid and the IDtelescope(s) for which it is to be used are not set up by this method.

the list of grids created by reading the file can be accessed with method GetLastReadGrids() after calling this method clear list of read grids

Definition at line 126 of file KVIDGridManager.cpp.

◆ StartViewer()

void KVIDGridManager::StartViewer ( ) const

Opens GUI for managing grids.

Definition at line 238 of file KVIDGridManager.cpp.

◆ WriteAsciiFile()

Int_t KVIDGridManager::WriteAsciiFile ( const Char_t *  filename,
const TCollection *  selection = 0 
)

Write grids in file 'filename'. If selection=0 (default), write all grids. If selection!=0, write only grids in list. Returns number of grids written in file.

Definition at line 197 of file KVIDGridManager.cpp.

Friends And Related Function Documentation

◆ KVIDGraph

friend class KVIDGraph
friend

Definition at line 33 of file KVIDGridManager.h.

Member Data Documentation

◆ fGrids

KVList KVIDGridManager::fGrids
private

collection of all ID graphs handled by manager

Definition at line 37 of file KVIDGridManager.h.

◆ fLastReadGrids

TList KVIDGridManager::fLastReadGrids
private

list of grids created by last call to ReadAsciiFile

Definition at line 38 of file KVIDGridManager.h.