///////////////////////////////////////////////////////////// // // PndSsdContFact // // Factory for the parameter containers in libPndSsd // ///////////////////////////////////////////////////////////// using namespace std; #include "PndSsdContFact.h" #include "FairRuntimeDb.h" #include "PndSsdGeoPar.h" #include "PndSsdPixelDigiPar.h" #include "PndSsdStripDigiPar.h" #include "FairParRootFileIo.h" #include "FairParAsciiFileIo.h" #include #include ClassImp(PndSsdContFact); static PndSsdContFact gPndSsdContFact; PndSsdContFact::PndSsdContFact() { // Constructor (called when the library is loaded) fName="PndSsdContFact"; fTitle="Factory for parameter containers in libPndSsd"; setAllContainers(); FairRuntimeDb::instance()->addContFactory(this); } void PndSsdContFact::setAllContainers() { /** Creates the Container objects with all accepted contexts and adds them to * the list of containers for the Ssd library.*/ FairContainer* p= new FairContainer("PndSsdGeoPar","PndSsd Geometry Parameters","TestDefaultContext"); p->addContext("TestNonDefaultContext"); containers->Add(p); FairContainer* p2 = new FairContainer("SSDPixelDigiPar", "PndSsd Pixel Digitization Parameters", "TestDefaultContext"); p2->addContext("TestNonDefaultContext"); containers->Add(p2); FairContainer* p3 = new FairContainer("SSDStripDigiParRect", "PndSsd Strip Digitization Parameters (rectangular sensors)", "TestDefaultContext"); p3->addContext("TestNonDefaultContext"); containers->Add(p3); FairContainer* p4 = new FairContainer("SSDStripDigiParTrap", "PndSsd Strip Digitization Parameters (trapezoid sensors)", "TestDefaultContext"); p4->addContext("TestNonDefaultContext"); containers->Add(p4); } FairParSet* PndSsdContFact::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=NULL; if (strcmp(name,"PndSsdGeoPar")==0) { p=new PndSsdGeoPar(c->getConcatName().Data(),c->GetTitle(),c->getContext()); } if (strcmp(name,"SSDPixelDigiPar")==0) { p=new PndSsdPixelDigiPar(c->getConcatName().Data(),c->GetTitle(),c->getContext()); } if (strcmp(name,"SSDStripDigiParRect")==0) { p=new PndSsdStripDigiPar(c->getConcatName().Data(),c->GetTitle(),c->getContext()); } if (strcmp(name,"SSDStripDigiParTrap")==0) { p=new PndSsdStripDigiPar(c->getConcatName().Data(),c->GetTitle(),c->getContext()); } return p; }