2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
9#include "ByteStreamCnvSvcBase/ByteStreamAddress.h"
10#include "ByteStreamCnvSvcBase/IROBDataProviderSvc.h"
12#include "ByteStreamData/RawEvent.h"
13#include "ByteStreamData/ROBData.h"
15#include "AthContainers/DataVector.h"
17#include "GaudiKernel/DataObject.h"
18#include "GaudiKernel/IOpaqueAddress.h"
19#include "GaudiKernel/IRegistry.h"
20#include "GaudiKernel/ISvcLocator.h"
21#include "GaudiKernel/StatusCode.h"
23#include "AthenaKernel/ClassID_traits.h"
24#include "AthenaKernel/StorableConversions.h"
25#include "AthenaKernel/errorcheck.h"
27#include "JepByteStreamV1Tool.h"
28#include "JepByteStreamV2Tool.h"
32template <typename Container>
33JepReadByteStreamV1V2Cnv<Container>::JepReadByteStreamV1V2Cnv( ISvcLocator* svcloc )
34 : AthConstConverter( storageType(), classID(), svcloc, "JepReadByteStreamV1V2Cnv" ),
35 m_tool1("LVL1BS::JepByteStreamV1Tool/JepByteStreamV1Tool"),
36 m_tool2("LVL1BS::JepByteStreamV2Tool/JepByteStreamV2Tool"),
37 m_robDataProvider("ROBDataProviderSvc", name())
41template <typename Container>
42JepReadByteStreamV1V2Cnv<Container>::~JepReadByteStreamV1V2Cnv()
48template <typename Container>
49CLID JepReadByteStreamV1V2Cnv<Container>::classID()
51 return ClassID_traits<Container>::ID();
54template <typename Container>
55long JepReadByteStreamV1V2Cnv<Container>::storageType()
57 return ByteStreamAddress::storageType();
60// Init method gets all necessary services etc.
63template <typename Container>
64StatusCode JepReadByteStreamV1V2Cnv<Container>::initialize()
66 ATH_CHECK( Converter::initialize() );
67 ATH_CHECK( m_tool1.retrieve() );
68 ATH_CHECK( m_tool2.retrieve() );
69 ATH_CHECK( m_robDataProvider.retrieve() );
71 return StatusCode::SUCCESS;
74// createObj should create the RDO from bytestream.
76template <typename Container>
77StatusCode JepReadByteStreamV1V2Cnv<Container>::createObjConst ( IOpaqueAddress* pAddr,
78 DataObject*& pObj ) const
80 ByteStreamAddress* pBS_Addr{};
81 ATH_CHECK( (pBS_Addr = dynamic_cast<ByteStreamAddress*>(pAddr)) != nullptr );
83 const EventContext& ctx = pBS_Addr->getEventContext();
84 const std::string nm = *( pBS_Addr->par() );
86 ATH_MSG_DEBUG( " Creating Objects " << nm );
89 const std::vector<uint32_t>& vID1(m_tool1->sourceIDs());
90 const std::vector<uint32_t>& vID2(m_tool2->sourceIDs());
93 IROBDataProviderSvc::VROBFRAG robFrags1;
94 m_robDataProvider->getROBData(ctx, vID1, robFrags1 );
95 IROBDataProviderSvc::VROBFRAG robFrags2;
96 m_robDataProvider->getROBData(ctx, vID2, robFrags2 );
99 auto collection = std::make_unique<Container>();
100 ATH_MSG_DEBUG( " Number of ROB fragments is " << robFrags1.size()
101 << ", " << robFrags2.size() );
103 if (robFrags1.size() == 0 && robFrags2.size() == 0) {
104 pObj = SG::asStorable(std::move(collection)) ;
105 return StatusCode::SUCCESS;
109 if (robFrags1.size() > 0) {
110 ATH_CHECK( m_tool1->convert(nm, robFrags1, collection.get()) );
113 if (robFrags2.size() > 0) {
114 ATH_CHECK( m_tool2->convert(nm, robFrags2, collection.get()) );
117 pObj = SG::asStorable(std::move(collection));
119 return StatusCode::SUCCESS;