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/Geant4InputHandling.h>
#include <DDG4/Geant4InteractionMerger.h>
/// Standard constructor
Markus Frank
committed
Geant4InteractionMerger::Geant4InteractionMerger(Geant4Context* ctxt, const std::string& nam)
Markus Frank
committed
: Geant4GeneratorAction(ctxt,nam)
{
InstanceCount::increment(this);
}
/// Default destructor
Geant4InteractionMerger::~Geant4InteractionMerger() {
InstanceCount::decrement(this);
}
/// Event generation action callback
void Geant4InteractionMerger::operator()(G4Event* /* event */) {
Geant4PrimaryEvent* evt = context()->event().extension<Geant4PrimaryEvent>();
const std::vector<Geant4PrimaryEvent::Interaction*>& inter = evt->interactions();
debug("+++ Merging MC input record from %d interactions:",(int)inter.size());
mergeInteractions(this,context());