//*-- AUTHOR : Denis Bertini //*-- Created : 20/06/2005 ///////////////////////////////////////////////////////////// // // CbmEcalContFact // // Factory for the parameter containers in libEcal // ///////////////////////////////////////////////////////////// #include "CbmEcalContFact.h" #include "CbmGeoEcalPar.h" #include "FairRuntimeDb.h" #include "FairParRootFileIo.h" #include "FairParAsciiFileIo.h" #include #include ClassImp(CbmEcalContFact) static CbmEcalContFact gCbmEcalContFact; CbmEcalContFact::CbmEcalContFact() { // Constructor (called when the library is loaded) fName="CbmEcalContFact"; fTitle="Factory for parameter containers in libEcal"; setAllContainers(); FairRuntimeDb::instance()->addContFactory(this); } void CbmEcalContFact::setAllContainers() { /** Creates the Container objects with all accepted contexts and adds them to * the list of containers for the STS library.*/ FairContainer* p2= new FairContainer("CbmGeoEcalPar", "Ecal Geometry Parameters", "TestDefaultContext"); p2->addContext("TestNonDefaultContext"); containers->Add(p2); } FairParSet* CbmEcalContFact::createContainer(FairContainer* c) { /** Calls the constructor of the corresponding parameter container. * For an actual context, which is not an empty string and not the default context * of this container, the name is concatinated with the context. */ const char* name=c->GetName(); FairParSet* p=0; if (strcmp(name,"CbmGeoEcalPar")==0) { p=new CbmGeoEcalPar(c->getConcatName().Data(),c->GetTitle(),c->getContext()); } return p; } void CbmEcalContFact::activateParIo(FairParIo* io) { // activates the input/output class for the parameters // needed by the Ecal return; }