//========================================================================== // AIDA Detector description implementation //-------------------------------------------------------------------------- // Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN) // All rights reserved. // // For the licensing terms see $DD4hepINSTALL/LICENSE. // For the list of contributors see $DD4hepINSTALL/doc/CREDITS. // // Author : M.Frank // //========================================================================== // Framework include files #include "DD4hep/Printout.h" #include "DD4hep/InstanceCount.h" #include "DDG4/Geant4InputHandling.h" #include "DDG4/Geant4InteractionMerger.h" using namespace dd4hep::sim; /// Standard constructor Geant4InteractionMerger::Geant4InteractionMerger(Geant4Context* ctxt, const std::string& nam) : 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()); }