ATLAS Offline Software
Public Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
SGAudSvc Class Reference

#include <SGAudSvc.h>

Inheritance diagram for SGAudSvc:
Collaboration diagram for SGAudSvc:

Public Member Functions

 SGAudSvc (const std::string &name, ISvcLocator *pSvcLocator)
 Constructor with parameters: More...
 
virtual ~SGAudSvc ()
 Destructor: More...
 
virtual StatusCode initialize () override
 Gaudi Service Implementation. More...
 
virtual StatusCode finalize () override
 
virtual void handle (const Incident &incident) override
 incident service handle for EndEvent. More...
 
virtual void SGAudit (const std::string &key, const CLID &id, const int &fnc, const int &store_id) override
 
bool SGGetCurrentAlg ()
 Gets name of curently running algorithm from AlgContextSvc. More...
 
virtual void setFakeCurrentAlg (const std::string &) override
 For implementing custom increased granularity auditing of for instance tools. More...
 
virtual void clearFakeCurrentAlg () override
 For implementing custom increased granularity auditing of for instance tools. More...
 

Private Types

typedef std::map< std::string, std::set< std::string > > DataMap
 

Private Member Functions

 SGAudSvc ()
 Default constructor: More...
 
void SGAudRETRIEVE (std::string SGobject)
 
void SGAudRECORD (std::string SGobject)
 
void getNobj (const std::string &name)
 
void addRead ()
 
void addWrite ()
 
void monitor ()
 just counts events. called at EndEvent incident More...
 
void writeJSON ()
 

Private Attributes

MsgStream m_msg
 MsgStream for talking with the outside world. More...
 
ServiceHandle< IAlgContextSvc > p_algCtxSvc
 Pointer to the AlgContextScv. More...
 
ServiceHandle< IClassIDSvc > m_pCID
 
std::string m_outFileName
 Name of the output file. More...
 
std::string m_allFileName
 
std::string m_sumFileName
 
bool m_ignoreFakeAlgs
 Whether to ignore fake current algs. More...
 
bool m_useCLID
 Whether to use CLID or Data Obj Name in JSON output file. More...
 
std::vector< std::string > m_vObj
 Vector of accessed SG objects names. More...
 
std::vector< std::string > m_vAlg
 Vector of names of algorithms accessing SG. More...
 
std::map< int, int > m_timesRead
 map counting Reads of each object by each algorithm. More...
 
std::map< int, int > m_timesWritten
 map counting Writes of each object by each algorithm. More...
 
std::string m_currAlg
 
std::string m_currObj
 
std::string m_fakeCurrAlg
 
int m_nCurrAlg
 
int m_nCurrObj
 
int m_nEvents
 
int m_startEvent
 
DataMap m_read
 
DataMap m_write
 
std::ofstream m_ofa
 
std::ofstream m_ofs
 
bool m_inExec
 

Detailed Description

Definition at line 39 of file SGAudSvc.h.

Member Typedef Documentation

◆ DataMap

typedef std::map<std::string, std::set<std::string> > SGAudSvc::DataMap
private

Definition at line 133 of file SGAudSvc.h.

Constructor & Destructor Documentation

◆ SGAudSvc() [1/2]

SGAudSvc::SGAudSvc ( const std::string &  name,
ISvcLocator *  pSvcLocator 
)

Constructor with parameters:

Definition at line 39 of file SGAudSvc.cxx.

39  :
40  base_class ( name, pSvcLocator ),
41  m_msg ( msgSvc(), name ),
42  p_algCtxSvc("AlgContextSvc", name),
43  m_pCID("ClassIDSvc", name),
44  m_useCLID(true),
45  m_nCurrAlg(0),
46  m_nCurrObj(0),
47  m_nEvents(0), m_startEvent(3), m_inExec(false)
48 {
49  //
50  // Property declaration
51  //
52  declareProperty( "OutFileName", m_outFileName = "SGAudSvc.out",
53  "Name of the output file to hold SGAudSvc data" );
54 
55  declareProperty( "FullFileName", m_allFileName = "",
56  "Name of the output file to hold the full SG aud data");
57 
58  declareProperty( "SummaryFileName", m_sumFileName = "",
59  "Name of the output file to hold the summary output in json format");
60 
61  declareProperty( "IgnoreFakeAlgs", m_ignoreFakeAlgs = false,
62  "Set to ignore any attempts to override current-alg" );
63 
64  declareProperty( "StartEvent", m_startEvent = 3,
65  "Event number to start recording data" );
66 
67  declareProperty( "UseCLID", m_useCLID = true,
68  "Use CLID or DataObj name in Summary File" );
69 }

◆ ~SGAudSvc()

SGAudSvc::~SGAudSvc ( )
virtual

Destructor:

Definition at line 74 of file SGAudSvc.cxx.

75 {
76  m_msg << MSG::DEBUG << "Calling destructor" << endmsg;
77 }

◆ SGAudSvc() [2/2]

SGAudSvc::SGAudSvc ( )
private

Default constructor:

Member Function Documentation

◆ addRead()

void SGAudSvc::addRead ( )
private

Definition at line 412 of file SGAudSvc.cxx.

412  {
413  int oaHash=m_nCurrObj*1000 + m_nCurrAlg;
414  if (m_timesRead.end()!=m_timesRead.find(oaHash)){
415  m_timesRead.find(oaHash)->second++;
416  }
417  else{
418  std::pair<int,int> p(oaHash,1);
419  m_timesRead.insert(p);
420  }
421  return;
422 }

◆ addWrite()

void SGAudSvc::addWrite ( )
private

Definition at line 427 of file SGAudSvc.cxx.

427  {
428  int oaHash=m_nCurrObj*1000 + m_nCurrAlg;
429  if (m_timesWritten.end()!=m_timesWritten.find(oaHash)){
430  m_timesWritten.find(oaHash)->second++;
431  }
432  else{
433  std::pair<int,int> p(oaHash,1);
434  m_timesWritten.insert(p);
435  }
436  return;
437 }

◆ clearFakeCurrentAlg()

void SGAudSvc::clearFakeCurrentAlg ( )
overridevirtual

For implementing custom increased granularity auditing of for instance tools.

Definition at line 447 of file SGAudSvc.cxx.

447 { m_fakeCurrAlg.clear(); }

◆ finalize()

StatusCode SGAudSvc::finalize ( )
overridevirtual

Definition at line 121 of file SGAudSvc.cxx.

121  {
122 
123  m_msg << MSG::INFO << "Finalizing " << name() <<"..."<< endmsg;
124 
125  if (m_vAlg.size()==0) {
126  m_msg << MSG::WARNING<<"No data gathered. This might be because you did not run over at least 3 events."<<endmsg;
127  return StatusCode::SUCCESS;
128  }
129 
130  m_msg << MSG::INFO<<"Writing output to: "<<m_outFileName<<endmsg;
131  std::ofstream f( m_outFileName.c_str() );
132 
133  f << "Algs: " << m_vAlg.size() << std::endl;
135  for (i=m_vAlg.begin();i<m_vAlg.end();++i) {
136  f << (*i) << std::endl;
137  }
138 
139  f << "Obj: "<< m_vObj.size()<<std::endl;
140  for (i=m_vObj.begin();i<m_vObj.end();++i) {
141  f << (*i) << std::endl;
142  }
143 
144 
145  for (unsigned int w=0;w<m_vAlg.size();w++){
146  for(unsigned int q=0;q<m_vObj.size();q++){
147  int oaHash=q*1000 + w;
148  if (m_timesRead.find(oaHash)==m_timesRead.end())
149  f << "0:";
150  else
151  f << m_timesRead.find(oaHash)->second << ":";
152  if (m_timesWritten.find(oaHash)==m_timesWritten.end())
153  f << "0\t";
154  else
155  f << m_timesWritten.find(oaHash)->second << "\t";
156  }
157  f << std::endl;
158  }
159 
160  f.close();
161 
162  if (m_ofa.is_open()) m_ofa.close();
163 
164  if (m_ofs.is_open()) {
165 
166  writeJSON();
167 
168  m_ofs.close();
169  }
170 
171 
172  return StatusCode::SUCCESS;
173 }

◆ getNobj()

void SGAudSvc::getNobj ( const std::string &  name)
private

Definition at line 392 of file SGAudSvc.cxx.

392  {
394  int index=0;
395  for (i=m_vObj.begin();i<m_vObj.end();++i){
396  if (*i==name) {
398  m_currObj=name;
399  return;
400  }
401  index++;
402  }
403  m_vObj.push_back(name);
405  m_currObj=name;
406 return;
407 }

◆ handle()

void SGAudSvc::handle ( const Incident &  incident)
overridevirtual

incident service handle for EndEvent.

Calls monitor. There should be more elegant way to get number of events passed.

Definition at line 178 of file SGAudSvc.cxx.

179 {
180  if ( m_msg.level() <= MSG::VERBOSE ) {
181  m_msg << MSG::VERBOSE << "Entering handle(): " << endmsg
182  << " Incidence type: " << inc.type() << endmsg
183  << " from: " << inc.source() << endmsg;
184  }
185 
186  if (inc.type() == IncidentType::BeginEvent) {
187  if (m_ofa.is_open())
188  m_ofa << "---- BEGIN EVENT " << m_nEvents << " ----" << std::endl;
189  m_inExec = true;
190 
191  }
192 
193  // Performing performance-monitoring for EndEvent incident
194  if ( inc.type() == IncidentType::EndEvent ) {
195  monitor();
196 
197  if (m_ofa.is_open())
198  m_ofa << "---- END EVENT " << m_nEvents << " ----" << std::endl;
199  m_inExec = false;
200 
201  }
202 
203  // Performing performance-monitoring for BeginRun incident
204  // at this point everybody has been initialized, we can harvest performance
205  // data for the initialize step.
206 
207  if ( inc.type() == IncidentType::BeginRun ) {
208  monitor();
209  }
210 
211  return;
212 }

◆ initialize()

StatusCode SGAudSvc::initialize ( )
overridevirtual

Gaudi Service Implementation.

Definition at line 84 of file SGAudSvc.cxx.

84  {
85 
86  // initialize MsgStream
87  m_msg.setLevel( m_outputLevel.value() );
88 
89  m_msg << MSG::INFO << "Initializing " << name() << "..." << endmsg;
90 
91  if ( AthService::initialize().isFailure() ) {
92  m_msg << MSG::ERROR << "Could not intialize base class !!" << endmsg;
93  return StatusCode::FAILURE;
94  }
95 
96  ATH_CHECK( p_algCtxSvc.retrieve() );
97  ATH_CHECK( m_pCID.retrieve() );
98 
99  if (m_allFileName != "") {
100  m_ofa.open(m_allFileName.c_str());
101  }
102 
103  if (m_sumFileName != "") {
104  m_ofs.open(m_sumFileName.c_str());
105  }
106 
107  // Set to be listener for end-of-event
108  ServiceHandle<IIncidentSvc> incSvc( "IncidentSvc", this->name() );
109  ATH_CHECK( incSvc.retrieve() );
110 
111  incSvc->addListener( this, IncidentType::BeginRun );
112  incSvc->addListener( this, IncidentType::BeginEvent );
113  incSvc->addListener( this, IncidentType::EndEvent );
114 
115  return StatusCode::SUCCESS;
116 }

◆ monitor()

void SGAudSvc::monitor ( )
private

just counts events. called at EndEvent incident

Definition at line 229 of file SGAudSvc.cxx.

229  {
230  m_nEvents++;
231  return;
232 }

◆ setFakeCurrentAlg()

void SGAudSvc::setFakeCurrentAlg ( const std::string &  s)
overridevirtual

For implementing custom increased granularity auditing of for instance tools.

Definition at line 442 of file SGAudSvc.cxx.

442 { m_fakeCurrAlg=s; }

◆ SGAudit()

void SGAudSvc::SGAudit ( const std::string &  key,
const CLID id,
const int &  fnc,
const int &  store_id 
)
overridevirtual

Definition at line 282 of file SGAudSvc.cxx.

283  {
284 
285  // we can sometimes get here really early, before initialization.
286  if (m_pCID == 0) { return; }
287 
288  bool a = SGGetCurrentAlg();
289 
290  if (m_nEvents >= m_startEvent && store_id == 0 && a) {
291  if (typ == 0) {
293  } else {
294  SGAudRECORD(key);
295  }
296  }
297 
298  std::string idname;
299 
300  if (m_ofa.is_open() || ( m_ofs.is_open() && ! m_useCLID ) ) {
301  if( ! m_pCID->getTypeNameOfID(id,idname).isSuccess()) {
302  std::ostringstream ost;
303  ost << id;
304  idname = ost.str();
305  }
306  }
307 
308  if (m_ofa.is_open()) {
309  m_ofa << ( (typ == 1) ? "RECORD" : "RETRIEVE" ) << " clid: " << id
310  << " | ";
311 
312  m_ofa << idname;
313 
314  m_ofa << " key: " << key << " alg: " << m_currAlg
315  << " store: " << store_id
316  << std:: endl;
317  }
318 
319  // store stuff for the summary
320 
321  if (!m_ofs.is_open()) return;
322 
323  if (m_nEvents < m_startEvent || !m_inExec) return;
324 
325  if (m_currAlg == "----") return;
326 
327  std::string kk;
328  if (m_useCLID) {
329  std::ostringstream ost;
330  ost << id << "/" << key;
331  kk = ost.str();
332  } else {
333  kk = idname + "/" + key;
334  }
335 
336  DataMap::iterator itr;
337  if (typ == 0) {
338  itr = m_read.find(m_currAlg);
339  if (itr != m_read.end()) {
340  itr->second.insert(kk);
341  } else {
342  m_read[m_currAlg] = std::set<std::string> ( {kk} );
343  }
344  } else {
345  itr = m_write.find(m_currAlg);
346  if (itr != m_write.end()) {
347  itr->second.insert(kk);
348  } else {
349  m_write[m_currAlg] = std::set<std::string> ( {kk} );
350  }
351  }
352 }

◆ SGAudRECORD()

void SGAudSvc::SGAudRECORD ( std::string  SGobject)
private

Definition at line 261 of file SGAudSvc.cxx.

261  {
262  // if (m_nEvents<3) return;
263  if (SGobject=="") SGobject="noKey";
264  for (unsigned int i = 0; i < SGobject.length(); i++)
265  if (!std::isdigit(SGobject[i])){
266  //isAnumb=false;
267  break;
268  }
269 
270  if (m_currObj==SGobject)
271  addWrite();
272  else {
273  getNobj(SGobject);
274  addWrite();
275  }
276 
277  return;
278 }

◆ SGAudRETRIEVE()

void SGAudSvc::SGAudRETRIEVE ( std::string  SGobject)
private

Definition at line 237 of file SGAudSvc.cxx.

237  {
238  // if (m_nEvents<3) return;
239  if (SGobject=="") SGobject="noKey";
240  bool isAnumb=true;
241  for (unsigned int i = 0; i < SGobject.length(); i++)
242  if (!std::isdigit(SGobject[i])){
243  isAnumb=false;
244  break;
245  }
246 
247  if (!isAnumb){
248  if (m_currObj==SGobject)
249  addRead();
250  else {
251  getNobj(SGobject);
252  addRead();
253  }
254  }
255  return;
256 }

◆ SGGetCurrentAlg()

bool SGAudSvc::SGGetCurrentAlg ( )

Gets name of curently running algorithm from AlgContextSvc.

Definition at line 357 of file SGAudSvc.cxx.

357  {
358 
359  IAlgorithm *asdf = p_algCtxSvc->currentAlg();
360  if (!asdf || m_nEvents==0) { // to skip before first event
361  m_currAlg="----";
362  m_nCurrAlg=-1;
363  return false;
364  }
365  std::string name = asdf->name();
366 
367  if ( !m_ignoreFakeAlgs && !m_fakeCurrAlg.empty() )
369 
370  if (name!=m_currAlg){
372  int index=0;
373  for (i=m_vAlg.begin();i<m_vAlg.end();++i){
374  if (*i==name) {
376  m_currAlg=name;
377  return true;
378  }
379  index++;
380  }
381  m_vAlg.push_back(name);
383  m_currAlg=name;
384  return true;
385  }
386  return true;
387 }

◆ writeJSON()

void SGAudSvc::writeJSON ( )
private

Definition at line 452 of file SGAudSvc.cxx.

452  {
453 
454  DataMap::const_iterator itr;
455  std::set<std::string>::const_iterator it2;
456  std::vector<std::string>::const_iterator ia;
457 
458  m_ofs << "{ \"algorithms\" : [" << std::endl;
459  for (ia = m_vAlg.begin(); ia != m_vAlg.end(); ++ia) {
460  m_ofs << " {" << std::endl;
461  m_ofs << " \"name\" : \"" << *ia << "\"," << std::endl;
462  m_ofs << " \"inputs\" : [";
463 
464  itr = m_read.find(*ia);
465  if (itr != m_read.end()) {
466  for (it2 = itr->second.begin(); it2 != itr->second.end(); ++it2) {
467  if (it2 != itr->second.begin()) m_ofs << ",";
468  m_ofs << "\"" << *it2 << "\"";
469  }
470  }
471  m_ofs << "]," << std::endl;
472 
473  m_ofs << " \"outputs\" : [";
474 
475  itr = m_write.find(*ia);
476  if (itr != m_write.end()) {
477  for (it2 = itr->second.begin(); it2 != itr->second.end(); ++it2) {
478  if (it2 != itr->second.begin()) m_ofs << ",";
479  m_ofs << "\"" << *it2 << "\"";
480  }
481  }
482  m_ofs << "]," << std::endl;
483  m_ofs << " }," << std::endl;
484  }
485  m_ofs << " ]" << std::endl << "}" << std::endl;
486 
487 }

Member Data Documentation

◆ m_allFileName

std::string SGAudSvc::m_allFileName
private

Definition at line 108 of file SGAudSvc.h.

◆ m_currAlg

std::string SGAudSvc::m_currAlg
private

Definition at line 124 of file SGAudSvc.h.

◆ m_currObj

std::string SGAudSvc::m_currObj
private

Definition at line 125 of file SGAudSvc.h.

◆ m_fakeCurrAlg

std::string SGAudSvc::m_fakeCurrAlg
private

Definition at line 126 of file SGAudSvc.h.

◆ m_ignoreFakeAlgs

bool SGAudSvc::m_ignoreFakeAlgs
private

Whether to ignore fake current algs.

Definition at line 111 of file SGAudSvc.h.

◆ m_inExec

bool SGAudSvc::m_inExec
private

Definition at line 138 of file SGAudSvc.h.

◆ m_msg

MsgStream SGAudSvc::m_msg
private

MsgStream for talking with the outside world.

Definition at line 101 of file SGAudSvc.h.

◆ m_nCurrAlg

int SGAudSvc::m_nCurrAlg
private

Definition at line 127 of file SGAudSvc.h.

◆ m_nCurrObj

int SGAudSvc::m_nCurrObj
private

Definition at line 128 of file SGAudSvc.h.

◆ m_nEvents

int SGAudSvc::m_nEvents
private

Definition at line 129 of file SGAudSvc.h.

◆ m_ofa

std::ofstream SGAudSvc::m_ofa
private

Definition at line 137 of file SGAudSvc.h.

◆ m_ofs

std::ofstream SGAudSvc::m_ofs
private

Definition at line 137 of file SGAudSvc.h.

◆ m_outFileName

std::string SGAudSvc::m_outFileName
private

Name of the output file.

Definition at line 108 of file SGAudSvc.h.

◆ m_pCID

ServiceHandle<IClassIDSvc> SGAudSvc::m_pCID
private

Definition at line 105 of file SGAudSvc.h.

◆ m_read

DataMap SGAudSvc::m_read
private

Definition at line 134 of file SGAudSvc.h.

◆ m_startEvent

int SGAudSvc::m_startEvent
private

Definition at line 130 of file SGAudSvc.h.

◆ m_sumFileName

std::string SGAudSvc::m_sumFileName
private

Definition at line 108 of file SGAudSvc.h.

◆ m_timesRead

std::map<int,int> SGAudSvc::m_timesRead
private

map counting Reads of each object by each algorithm.

Definition at line 121 of file SGAudSvc.h.

◆ m_timesWritten

std::map<int,int> SGAudSvc::m_timesWritten
private

map counting Writes of each object by each algorithm.

Definition at line 123 of file SGAudSvc.h.

◆ m_useCLID

bool SGAudSvc::m_useCLID
private

Whether to use CLID or Data Obj Name in JSON output file.

Definition at line 114 of file SGAudSvc.h.

◆ m_vAlg

std::vector<std::string> SGAudSvc::m_vAlg
private

Vector of names of algorithms accessing SG.

Definition at line 119 of file SGAudSvc.h.

◆ m_vObj

std::vector<std::string> SGAudSvc::m_vObj
private

Vector of accessed SG objects names.

Definition at line 117 of file SGAudSvc.h.

◆ m_write

DataMap SGAudSvc::m_write
private

Definition at line 135 of file SGAudSvc.h.

◆ p_algCtxSvc

ServiceHandle<IAlgContextSvc> SGAudSvc::p_algCtxSvc
private

Pointer to the AlgContextScv.

Definition at line 104 of file SGAudSvc.h.


The documentation for this class was generated from the following files:
xAOD::iterator
JetConstituentVector::iterator iterator
Definition: JetConstituentVector.cxx:68
SGAudSvc::addWrite
void addWrite()
Definition: SGAudSvc.cxx:427
SGAudSvc::SGGetCurrentAlg
bool SGGetCurrentAlg()
Gets name of curently running algorithm from AlgContextSvc.
Definition: SGAudSvc.cxx:357
python.SystemOfUnits.s
int s
Definition: SystemOfUnits.py:131
python.trigbs_prescaleL1.ost
ost
Definition: trigbs_prescaleL1.py:104
SGAudSvc::m_pCID
ServiceHandle< IClassIDSvc > m_pCID
Definition: SGAudSvc.h:105
SGAudSvc::m_timesWritten
std::map< int, int > m_timesWritten
map counting Writes of each object by each algorithm.
Definition: SGAudSvc.h:123
SGAudSvc::m_sumFileName
std::string m_sumFileName
Definition: SGAudSvc.h:108
SGAudSvc::monitor
void monitor()
just counts events. called at EndEvent incident
Definition: SGAudSvc.cxx:229
SGAudSvc::SGAudRECORD
void SGAudRECORD(std::string SGobject)
Definition: SGAudSvc.cxx:261
index
Definition: index.py:1
SGAudSvc::m_ofa
std::ofstream m_ofa
Definition: SGAudSvc.h:137
initialize
void initialize()
Definition: run_EoverP.cxx:894
SGAudSvc::getNobj
void getNobj(const std::string &name)
Definition: SGAudSvc.cxx:392
SGAudSvc::m_useCLID
bool m_useCLID
Whether to use CLID or Data Obj Name in JSON output file.
Definition: SGAudSvc.h:114
SGAudSvc::m_nCurrObj
int m_nCurrObj
Definition: SGAudSvc.h:128
SGAudSvc::writeJSON
void writeJSON()
Definition: SGAudSvc.cxx:452
SGAudSvc::m_inExec
bool m_inExec
Definition: SGAudSvc.h:138
SGAudSvc::m_write
DataMap m_write
Definition: SGAudSvc.h:135
SGAudSvc::m_ignoreFakeAlgs
bool m_ignoreFakeAlgs
Whether to ignore fake current algs.
Definition: SGAudSvc.h:111
python.changerun.kk
list kk
Definition: changerun.py:41
SGAudSvc::m_currObj
std::string m_currObj
Definition: SGAudSvc.h:125
SGAudSvc::m_timesRead
std::map< int, int > m_timesRead
map counting Reads of each object by each algorithm.
Definition: SGAudSvc.h:121
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
SGAudSvc::m_currAlg
std::string m_currAlg
Definition: SGAudSvc.h:124
StdJOSetup.msgSvc
msgSvc
Provide convenience handles for various services.
Definition: StdJOSetup.py:36
SGAudSvc::m_outFileName
std::string m_outFileName
Name of the output file.
Definition: SGAudSvc.h:108
lumiFormat.i
int i
Definition: lumiFormat.py:85
endmsg
#define endmsg
Definition: AnalysisConfig_Ntuple.cxx:63
SGAudSvc::m_startEvent
int m_startEvent
Definition: SGAudSvc.h:130
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
hist_file_dump.f
f
Definition: hist_file_dump.py:135
SGAudSvc::SGAudRETRIEVE
void SGAudRETRIEVE(std::string SGobject)
Definition: SGAudSvc.cxx:237
SGAudSvc::m_vAlg
std::vector< std::string > m_vAlg
Vector of names of algorithms accessing SG.
Definition: SGAudSvc.h:119
SGAudSvc::addRead
void addRead()
Definition: SGAudSvc.cxx:412
id
SG::auxid_t id
Definition: Control/AthContainers/Root/debug.cxx:227
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
SGAudSvc::m_allFileName
std::string m_allFileName
Definition: SGAudSvc.h:108
SGAudSvc::m_ofs
std::ofstream m_ofs
Definition: SGAudSvc.h:137
SGAudSvc::m_msg
MsgStream m_msg
MsgStream for talking with the outside world.
Definition: SGAudSvc.h:101
SGAudSvc::p_algCtxSvc
ServiceHandle< IAlgContextSvc > p_algCtxSvc
Pointer to the AlgContextScv.
Definition: SGAudSvc.h:104
DeMoScan.index
string index
Definition: DeMoScan.py:364
a
TList * a
Definition: liststreamerinfos.cxx:10
DEBUG
#define DEBUG
Definition: page_access.h:11
extractSporadic.q
list q
Definition: extractSporadic.py:98
python.Constants.VERBOSE
int VERBOSE
Definition: Control/AthenaCommon/python/Constants.py:14
python.IoTestsLib.w
def w
Definition: IoTestsLib.py:200
SGAudSvc::m_vObj
std::vector< std::string > m_vObj
Vector of accessed SG objects names.
Definition: SGAudSvc.h:117
SGAudSvc::m_nCurrAlg
int m_nCurrAlg
Definition: SGAudSvc.h:127
SGAudSvc::m_fakeCurrAlg
std::string m_fakeCurrAlg
Definition: SGAudSvc.h:126
SGAudSvc::m_read
DataMap m_read
Definition: SGAudSvc.h:134
SGAudSvc::m_nEvents
int m_nEvents
Definition: SGAudSvc.h:129
ServiceHandle< IIncidentSvc >
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37