#include "hhododetector.h"
#include "hhodohistbooker.h"
#include "hhodohistfiller.h"
#include "hmonhist.h"
#include "htrendhist.h"
#include "hhistarray.h"
#include "hgo4parasciifileio.h"
#include "hgo4parrootfileio.h"
#include "hades.h"
#include "hruntimedb.h"
#include "hspectrometer.h"
#include "hpario.h"
#include "hdetpario.h"
#include "hparamlist.h"
#include "hmessagemgr.h"
#include "hevent.h"
#include "hcategory.h"
#include "hparasciifileio.h"
#include "hparrootfileio.h"
#include "hrun.h"
#include "hdatasource.h"
#include "TList.h"
HHodoHistBooker* HHodoHistBooker::fHodoHistBooker=0;
TList* HHodoHistBooker::hodoHistpool=0;
TList* HHodoHistBooker::hodoActiveHists=0;
HHodoHistFiller* HHodoHistBooker::hodofiller=0;
ClassImp(HHodoHistBooker)
HHodoHistBooker::HHodoHistBooker(const Char_t* name,const Char_t* title,
const Char_t* context)
: HParCond(name,title,context)
{
strcpy(detName,"Hodo");
if (gHades) {
fHodo =(HHodoDetector*)(((HSpectrometer*)(gHades->getSetup()))->getDetector("Hodo"));
} else {
fHodo = 0;
}
clear();
fHodoHistBooker =this;
hodoHistpool = new TList;
hodoActiveHists = new TList;
hodofiller = new HHodoHistFiller("HodoFiller","HodoFiller");
}
void HHodoHistBooker::setGo4ParIo(HRuntimeDb *rtdb) {
HParIo *io=0;
io=rtdb->getFirstInput();
if (io != 0) {
if (io->getDetParIo("HGo4ParIo") == 0) {
if (strcmp(io->IsA()->GetName(),"HParAsciiFileIo")==0) {
HGo4ParAsciiFileIo* p=
new HGo4ParAsciiFileIo(((HParAsciiFileIo*)io)->getFile());
io->setDetParIo(p);
io->setInputNumber(1);
}
if (strcmp(io->IsA()->GetName(),"HParRootFileIo")==0) {
HGo4ParRootFileIo* p=
new HGo4ParRootFileIo(((HParRootFileIo*)io)->getParRootFile());
io->setDetParIo(p);
io->setInputNumber(1);
}
if (strcmp(io->IsA()->GetName(),"HParOraIo")==0) {
io->setDetParIo("HGo4ParIo");
io->setInputNumber(1);
}
}
}
io=rtdb->getSecondInput();
if (io != 0) {
if (io->getDetParIo("HGo4ParIo") == 0) {
if (strcmp(io->IsA()->GetName(),"HParAsciiFileIo")==0) {
HGo4ParAsciiFileIo* p=
new HGo4ParAsciiFileIo(((HParAsciiFileIo*)io)->getFile());
io->setDetParIo(p);
io->setInputNumber(2);
}
if (strcmp(io->IsA()->GetName(),"HParRootFileIo")==0) {
HGo4ParRootFileIo* p=
new HGo4ParRootFileIo(((HParRootFileIo*)io)->getParRootFile());
io->setDetParIo(p);
io->setInputNumber(2);
}
if (strcmp(io->IsA()->GetName(),"HParOraIo")==0) {
io->setDetParIo("HGo4ParIo");
io->setInputNumber(2);
}
}
}
io=rtdb->getOutput();
if (io != 0) {
if (io->getDetParIo("HGo4ParIo") == 0) {
if (strcmp(io->IsA()->GetName(),"HParAsciiFileIo")==0) {
HGo4ParAsciiFileIo* p=
new HGo4ParAsciiFileIo(((HParAsciiFileIo*)io)->getFile());
io->setDetParIo(p);
}
if (strcmp(io->IsA()->GetName(),"HParRootFileIo")==0) {
HGo4ParRootFileIo* p=
new HGo4ParRootFileIo(((HParRootFileIo*)io)->getParRootFile());
io->setDetParIo(p);
}
if (strcmp(io->IsA()->GetName(),"HParOraIo")==0) io->setDetParIo("HGo4ParIo");
}
}
}
Bool_t HHodoHistBooker::initStandAlone()
{
HRuntimeDb* rtdb=0;
rtdb=gHades->getRuntimeDb();
HDataSource* source=gHades->getDataSource();
Int_t refId=source->getCurrentRefId();
Int_t runId=source->getCurrentRunId();
HRun* run=rtdb->getRun(runId);
if(!run)run=rtdb->addRun(runId,refId);
Bool_t allFound=kFALSE;
HParVersion* vers;
if(run)
{
if (!run->getParVersion((Char_t*)GetName()))
{
vers=new HParVersion((Char_t*)GetName());
run->addParVersion(vers);
}
}
else
{
Error("HHodoHistBooker:initStandAlone()","NO RUN SET!");
return kFALSE;
}
if (versions[1]!=-1 && versions[2]!=-1) resetInputVersions();
HParIo* io=rtdb->getFirstInput();
if (io) allFound=init(io,0);
if (!allFound)
{
io=rtdb->getSecondInput();
if (io)
{
allFound=init(io,0);
}
}else setInputVersion(-1,2);
if (!allFound)
{
cerr<<"******** "<<GetName()<<" not initialized ********"<<endl;
return kFALSE;
}
return kTRUE;
}
HHodoHistBooker::~HHodoHistBooker()
{
cout<<"~HHodoHistBooker()...Help me I am Killed!"<<endl;
delete hodofiller;
}
HHodoHistBooker* HHodoHistBooker::getExObject()
{
return fHodoHistBooker;
}
HHodoHistBooker* HHodoHistBooker::getObject()
{
if(!fHodoHistBooker) fHodoHistBooker=new HHodoHistBooker();
return fHodoHistBooker;
}
void HHodoHistBooker::resetActiveList(Int_t level,Int_t count)
{
TIterator* myiter=hodoActiveHists->MakeIterator();
HMonHistAddon* h=0;
TString buffer;
while ((h=(HMonHistAddon*)myiter->Next())!= 0)
{
h->reset(level,count);
}
delete myiter;
}
void HHodoHistBooker::clear()
{
status=kFALSE;
resetInputVersions();
changed=kFALSE;
}
Bool_t HHodoHistBooker::check()
{
return kTRUE;
}
void HHodoHistBooker::printParam(void)
{
}
void HHodoHistBooker::printStatus(void)
{
cout<<"###############Status HodoHistbooker#################"<<endl;
HMonHistAddon* h;
TIterator* myiter=hodoActiveHists->MakeIterator();
while ((h=(HMonHistAddon*)myiter->Next())!= 0)
{
cout<<"active: "<<h->getActive()<<" resetable: "<<h->getResetable()<<" "<<h->GetName()<<endl;
}
delete myiter;
cout<<"######################################################"<<endl;
}
Bool_t HHodoHistBooker::init(HParIo* inp,Int_t* set)
{
HRuntimeDb* rtdb=0;
rtdb=gHades->getRuntimeDb();
if(rtdb)
{
setGo4ParIo(rtdb);
}
else
{
Error("HHodoHistBooker()","ZERO POINTER FOR RTDB RECEIVED!");
exit(1);
}
HDetParIo* input=inp->getDetParIo("HGo4ParIo");
if (input) return (input->init(this,set));
return kFALSE;
}
Int_t HHodoHistBooker::write(HParIo* output)
{
HDetParIo* out=output->getDetParIo("HGo4ParIo");
if (out) return out->write(this);
return -1;
}
void HHodoHistBooker::putParams(HParamList* l)
{
if(!l) return;
hodofiller->putHodoParams(l,hodoHistpool);
}
Bool_t HHodoHistBooker::getParams(HParamList* l)
{
if(!l) return kFALSE;
if(isStatic()==0)
{
if(!hodofiller->getHodoParams(l,hodoHistpool,hodoActiveHists)) return kFALSE;
setStatic();
}
return kTRUE;
}
Last change: Sat May 22 12:57:23 2010
Last generated: 2010-05-22 12:57
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.