Newer
Older
Markus Frank
committed
//==========================================================================
Markus Frank
committed
//--------------------------------------------------------------------------
// Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
Markus Frank
committed
// All rights reserved.
Markus Frank
committed
// For the licensing terms see $DD4hepINSTALL/LICENSE.
// For the list of contributors see $DD4hepINSTALL/doc/CREDITS.
Markus Frank
committed
// Author : M.Frank
//
//==========================================================================
// Framework include files
#include <DD4hep/Printout.h>
#include <DD4hep/InstanceCount.h>
#include <DDG4/Geant4Kernel.h>
#include <DDG4/Geant4RunAction.h>
#include <DDG4/Geant4GeneratorActionInit.h>
#include <DDG4/Geant4InputHandling.h>
/// Standard constructor
Markus Frank
committed
Geant4GeneratorActionInit::Geant4GeneratorActionInit(Geant4Context* ctxt, const std::string& nam)
: Geant4GeneratorAction(ctxt,nam)
{
InstanceCount::increment(this);
Markus Frank
committed
context()->kernel().runAction().callAtEnd(this,&Geant4GeneratorActionInit::end);
context()->kernel().runAction().callAtBegin(this,&Geant4GeneratorActionInit::begin);
declareProperty("numberOfEvents", m_evtTotal);
declareProperty("numberOfRuns", m_evtRun);
}
/// Default destructor
Geant4GeneratorActionInit::~Geant4GeneratorActionInit() {
InstanceCount::decrement(this);
}
/// Begin-run action callback
void Geant4GeneratorActionInit::begin(const G4Run* run) {
m_evtRun = 0;
m_run = run->GetRunID();
}
/// End-run action callback
void Geant4GeneratorActionInit::end(const G4Run* /* run */) {
printP1("+++ Finished run %d after %d events (%d events in total)",m_run,m_evtRun,m_evtTotal);
m_evtRun = 0;
m_run = 0;
}
/// Event generation action callback
void Geant4GeneratorActionInit::operator()(G4Event* /* event */) {
/// Update event counters
++m_evtTotal;
++m_evtRun;
/// + Printout
print("+++ Initializing event %d. Within run:%d event %d.",m_evtTotal,m_run,m_evtRun);
generationInitialization(this,context());