ATLAS Offline Software
PixelIDDetDescrCnv.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 #include "PixelIDDetDescrCnv.h"
6 
9 #include "GaudiKernel/MsgStream.h"
10 #include "StoreGate/StoreGateSvc.h"
11 
14 #include "IdDict/IdDictMgr.h"
16 
17 
18 //--------------------------------------------------------------------
19 
20 long int
22 {
23  return (storageType());
24 }
25 
26 //--------------------------------------------------------------------
27 
30 {
32  return StatusCode::SUCCESS;
33 }
34 
35 //--------------------------------------------------------------------
36 
38 PixelIDDetDescrCnv::createObj(IOpaqueAddress* /*pAddr*/, DataObject*& pObj)
39 {
40  // Get the dictionary manager from the detector store
41  const IdDictManager* idDictMgr;
42  ATH_CHECK( detStore()->retrieve(idDictMgr, "IdDict") );
43 
44  // Only initialize helper if it is the first pass or if there is a
45  // change in the the file or tag
46  bool initHelper = false;
47 
48  const IdDictMgr* mgr = idDictMgr->manager();
49 
50  // Internal InDet id tag
51  const std::string & inDetIDTag = mgr->tag();
52 
53  // DoChecks flag
54  bool doChecks = mgr->do_checks();
55 
56  IdDictDictionary* dict = mgr->find_dictionary("InnerDetector");
57  if (!dict) {
58  ATH_MSG_ERROR("unable to find idDict for InnerDetector");
59  return StatusCode::FAILURE;
60  }
61 
62  // File to be read for InDet ids
63  const std::string & inDetIDFileName = dict->file_name();
64 
65  // Tag of RDB record for InDet ids
66  const std::string & inDetIdDictTag = dict->dict_tag();
67 
68 
69  if (m_pixelId) {
70 
71  // Pixel id helper already exists - second pass. Check for a
72  // change
73  if (inDetIDTag != m_inDetIDTag) {
74  // Internal InDet id tag
75  initHelper = true;
76  ATH_MSG_DEBUG(" Changed internal InDet id tag: " << inDetIDTag);
77  }
78  if (inDetIDFileName != m_inDetIDFileName) {
79  // File to be read for InDet ids
80  initHelper = true;
81  ATH_MSG_DEBUG(" Changed InDetFileName:" << inDetIDFileName);
82  }
83  if (inDetIdDictTag != m_inDetIdDictTag) {
84  // Tag of RDB record for InDet ids
85  initHelper = true;
86  ATH_MSG_DEBUG(" Changed InDetIdDictTag: " << inDetIdDictTag);
87  }
88  if (doChecks != m_doChecks) {
89  // DoChecks flag
90  initHelper = true;
91  ATH_MSG_DEBUG(" Changed doChecks flag: " << doChecks);
92  }
93  }
94  else {
95  // create the helper
96  m_pixelId = new PixelID;
97  initHelper = true;
98  // add in message service for printout
100  }
101 
102  if (initHelper) {
103  ATH_CHECK( idDictMgr->initializeHelper(*m_pixelId) == 0 );
104 
105  // Save state:
106  m_inDetIDTag = inDetIDTag;
107  m_inDetIDFileName = inDetIDFileName;
108  m_inDetIdDictTag = inDetIdDictTag;
109  m_doChecks = doChecks;
110  }
111 
112  // Pass a pointer to the container to the Persistency service by reference.
113  pObj = SG::asStorable(m_pixelId);
114 
115  return StatusCode::SUCCESS;
116 
117 }
118 
119 //--------------------------------------------------------------------
120 
121 long
123 {
124  return DetDescr_StorageType;
125 }
126 
127 //--------------------------------------------------------------------
128 const CLID&
130  return ClassID_traits<PixelID>::ID();
131 }
132 
133 //--------------------------------------------------------------------
135  :
136  DetDescrConverter(ClassID_traits<PixelID>::ID(), svcloc, "PixelIDDetDescrCnv"),
137  m_pixelId(nullptr),
138  m_doChecks(false)
139 
140 {}
141 
142 
143 
python.PyKernel.retrieve
def retrieve(aClass, aKey=None)
Definition: PyKernel.py:110
PixelIDDetDescrCnv::m_doChecks
bool m_doChecks
Whether or not.
Definition: PixelIDDetDescrCnv.h:48
PixelID.h
This is an Identifier helper class for the Pixel subdetector. This class is a factory for creating co...
IdDictMgr.h
PixelIDDetDescrCnv::m_inDetIdDictTag
std::string m_inDetIdDictTag
Tag of RDB record for InDet ids.
Definition: PixelIDDetDescrCnv.h:42
PixelIDDetDescrCnv::m_inDetIDFileName
std::string m_inDetIDFileName
File to be read for InDet ids.
Definition: PixelIDDetDescrCnv.h:39
AtlasDetectorID::setMessageSvc
virtual void setMessageSvc(IMessageSvc *msgSvc) override
Definition: AtlasDetectorID.cxx:491
DetDescr_StorageType
const long DetDescr_StorageType
Definition: DetDescrCnvSvc.cxx:20
ID
std::vector< Identifier > ID
Definition: CalibHitIDCheck.h:24
IdDictDictionary.h
initialize
void initialize()
Definition: run_EoverP.cxx:894
DetDescrAddress.h
PixelIDDetDescrCnv.h
PixelIDDetDescrCnv::createObj
virtual StatusCode createObj(IOpaqueAddress *pAddr, DataObject *&pObj) override
Definition: PixelIDDetDescrCnv.cxx:38
IdDictManager.h
PixelIDDetDescrCnv::m_inDetIDTag
std::string m_inDetIDTag
Internal InDet id tag.
Definition: PixelIDDetDescrCnv.h:45
IdDictDictionary::file_name
const std::string & file_name() const
Access to file name.
Definition: IdDictDictionary.h:367
DetDescrConverter::detStore
const ServiceHandle< StoreGateSvc > & detStore() const
Handle to DetectorStore.
Definition: DetDescrConverter.h:33
PixelIDDetDescrCnv::m_pixelId
PixelID * m_pixelId
The helper - only will create it once.
Definition: PixelIDDetDescrCnv.h:36
BchCleanup.mgr
mgr
Definition: BchCleanup.py:294
SG::asStorable
DataObject * asStorable(SG::DataObjectSharedPtr< T > pObject)
Definition: DataObjectSharedPtr.h:65
IdDictMgr
Definition: IdDictMgr.h:14
DetDescrConverter
Definition: DetDescrConverter.h:25
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
StdJOSetup.msgSvc
msgSvc
Provide convenience handles for various services.
Definition: StdJOSetup.py:36
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
ClassID_traits
Default, invalid implementation of ClassID_traits.
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:37
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
IdDictManager::initializeHelper
int initializeHelper(IdHelper &helper) const
Return value: 0 OK, >0 error.
Definition: IdDictManager.cxx:37
CLID
uint32_t CLID
The Class ID type.
Definition: Event/xAOD/xAODCore/xAODCore/ClassID_traits.h:47
IdDictManager
IdDictManager is the interface to identifier dictionaries.
Definition: IdDictManager.h:26
PixelIDDetDescrCnv::repSvcType
virtual long int repSvcType() const override
Definition: PixelIDDetDescrCnv.cxx:21
IdDictDictionary
Definition: IdDictDictionary.h:30
IdDictDictionary::dict_tag
const std::string & dict_tag() const
Access to the dictionary tag.
Definition: IdDictDictionary.h:374
DetDescrConverter.h
IdDictManager::manager
const IdDictMgr * manager(void) const
Definition: IdDictManager.cxx:30
PixelIDDetDescrCnv::initialize
virtual StatusCode initialize() override
Definition: PixelIDDetDescrCnv.cxx:29
ClassID_traits::ID
static CLID ID()
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:44
PixelIDDetDescrCnv::storageType
static long storageType()
Definition: PixelIDDetDescrCnv.cxx:122
PixelID
Definition: PixelID.h:67
PixelIDDetDescrCnv::PixelIDDetDescrCnv
PixelIDDetDescrCnv(ISvcLocator *svcloc)
Definition: PixelIDDetDescrCnv.cxx:134
StoreGateSvc.h
PixelIDDetDescrCnv::classID
static const CLID & classID()
Definition: PixelIDDetDescrCnv.cxx:129