8 #include "art/Framework/Core/EDAnalyzer.h"
9 #include "art/Framework/Core/ModuleMacros.h"
10 #include "art/Framework/Principal/Event.h"
11 #include "art/Framework/Principal/Handle.h"
12 #include "canvas/Utilities/Exception.h"
14 #include "artdaq-core/Data/ContainerFragment.hh"
15 #include "artdaq-core/Data/Fragment.hh"
45 explicit EventDump(fhicl::ParameterSet
const& pset);
59 void analyze(art::Event
const& e)
override;
62 std::string raw_data_label_;
68 , raw_data_label_(pset.get<std::string>(
"raw_data_label",
"daq"))
69 , verbosity_(pset.get<int>(
"verbosity", 0)) {}
75 std::cout <<
"***** Start of EventDump for event " << e.event() <<
" *****" << std::endl;
77 std::vector<art::Handle<std::vector<artdaq::Fragment> > > fragmentHandles;
78 e.getManyByType(fragmentHandles);
80 for (
auto const& handle : fragmentHandles)
82 if (handle->size() > 0)
84 std::string instance_name = handle.provenance()->productInstanceName();
85 std::cout << instance_name <<
" fragments: " << std::endl;
88 for (
auto const& frag : *handle)
90 std::cout <<
" " << jdx <<
") fragment ID " << frag.fragmentID() <<
" has type "
91 << (int)frag.type() <<
", timestamp " << frag.timestamp()
92 <<
", and sizeBytes " << frag.sizeBytes();
94 if (instance_name.compare(0, 9,
"Container") == 0)
96 artdaq::ContainerFragment cf(frag);
97 std::cout <<
" (contents: type = " << (int)cf.fragment_type() <<
", count = "
98 << cf.block_count() <<
", missing data = " << cf.missing_data()
103 for (
size_t idx = 0; idx < cf.block_count(); ++idx)
105 std::cout <<
" " << (idx + 1) <<
") fragment type " << (
int)(cf.at(idx))->type()
106 <<
", timestamp " << (cf.at(idx))->timestamp()
107 <<
", and sizeBytes " << (cf.at(idx))->sizeBytes() << std::endl;
113 std::cout << std::endl;
120 std::cout <<
"***** End of EventDump for event " << e.event() <<
" *****" << std::endl;
void analyze(art::Event const &e) override
This method is called for each art::Event in a file or run.
EventDump(fhicl::ParameterSet const &pset)
EventDump Constructor.
Write Event information to the console.
virtual ~EventDump()=default
Default virtual Destructor.