Skip to content
Snippets Groups Projects
Geant4InteractionMerger.cpp 1.42 KiB
Newer Older
Markus Frank's avatar
Markus Frank committed
// $Id: $
//==========================================================================
//  AIDA Detector description implementation for LCD
//--------------------------------------------------------------------------
Markus Frank's avatar
Markus Frank committed
// Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
// 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::Simulation;

/// Standard constructor
Geant4InteractionMerger::Geant4InteractionMerger(Geant4Context* ctxt, const std::string& 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());