ATLAS Offline Software
Loading...
Searching...
No Matches
EventStreamInfoCnv_p2.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
10
12#include "EventInfo/EventType.h"
13
16
18
19void EventStreamInfoCnv_p2::persToTrans(const EventStreamInfo_p2* pers, EventStreamInfo* trans, MsgStream &log) const {
20 *trans = EventStreamInfo();
21 trans->addEvent (pers->m_numberOfEvents);
22 for (unsigned int rn : pers->m_runNumbers)
23 trans->insertRunNumber (rn);
24 for (unsigned int lbn : pers->m_lumiBlockNumbers)
25 trans->insertLumiBlockNumber (lbn);
26 for (const std::string& tag : pers->m_processingTags)
27 trans->insertProcessingTag (tag);
28 for (const std::pair<CLID, std::string>& p : pers->m_itemList)
29 trans->insertItemList (p.first, p.second);
30 for (const EventType_p1& ptype : pers->m_eventTypes)
31 {
32 std::unique_ptr<EventType> p (typeConv.createTransientConst(&ptype, log));
33 trans->insertEventType(*p);
34 }
35}
36
37void EventStreamInfoCnv_p2::transToPers(const EventStreamInfo* trans, EventStreamInfo_p2* pers, MsgStream &log) const {
38 pers->m_numberOfEvents = trans->getNumberOfEvents();
39
40 pers->m_runNumbers.assign (trans->getRunNumbers().begin(),
41 trans->getRunNumbers().end());
42
43 pers->m_lumiBlockNumbers.assign (trans->getLumiBlockNumbers().begin(),
44 trans->getLumiBlockNumbers().end());
45
46 pers->m_processingTags.assign (trans->getProcessingTags().begin(),
47 trans->getProcessingTags().end());
48
49 pers->m_itemList.assign (trans->getItemList().begin(),
50 trans->getItemList().end());
51
52 pers->m_eventTypes.reserve(trans->getEventTypes().size());
53 pers->m_eventTypes.clear();
54 for (const EventType& ttype : trans->getEventTypes()) {
55 EventType_p1 ptype;
56 typeConv.transToPers(&ttype, &ptype, log);
57 pers->m_eventTypes.push_back(std::move(ptype));
58 }
59}
static const EventTypeCnv_p1 typeConv
This file contains the class definition for the EventStreamInfoCnv_p2 class.
This file contains the class definition for the EventStreamInfo class.
Athena::TPCnvVers::Old Athena::TPCnvVers::Current EventStreamInfo
This class provides general information about an event.
virtual void persToTrans(const EventStreamInfo_p2 *persObj, EventStreamInfo *transObj, MsgStream &log) const override
virtual void transToPers(const EventStreamInfo *transObj, EventStreamInfo_p2 *persObj, MsgStream &log) const override
This class is the persistent representation of EventStreamInfo.
std::vector< EventType_p1 > m_eventTypes
unsigned int m_numberOfEvents
std::vector< unsigned int > m_lumiBlockNumbers
std::vector< std::string > m_processingTags
std::vector< unsigned int > m_runNumbers
std::vector< std::pair< unsigned int, std::string > > m_itemList
This class provides the summary information stored for data written as a Event Stream.
const std::set< std::string > & getProcessingTags() const
const std::set< unsigned int > & getLumiBlockNumbers() const
void insertEventType(const EventType &event)
Insert new Event Type into a set.
void insertLumiBlockNumber(unsigned int lumiBlock)
Insert new Luminosity Block Number into a set.
const std::set< unsigned int > & getRunNumbers() const
void insertRunNumber(unsigned int run)
Insert new Run Number into a set.
void addEvent(unsigned int number=1)
Increase Event Counter.
const std::set< EventType > & getEventTypes() const
void insertProcessingTag(const std::string &process)
Insert new Processing Tag into a set.
const std::set< std::pair< CLID, std::string > > & getItemList() const
void insertItemList(CLID type, const std::string &key)
Insert new ItemList Entry into a set.
unsigned int getNumberOfEvents() const
This class represents the "type of event" where the type is given by one or more "characteristics".
Definition EventType.h:92