ATLAS Offline Software
Functions
d3pdReaderMaker.cxx File Reference
#include <iostream>
#include <vector>
#include <string>
#include <boost/program_options.hpp>
#include <boost/regex.hpp>
#include <TFile.h>
#include <TTree.h>
#include <TList.h>
#include <TKey.h>
#include <TBranch.h>
#include <TBranchElement.h>
#include <TLeaf.h>
#include <TError.h>
#include "GaudiKernel/StatusCode.h"
#include "GaudiKernel/Bootstrap.h"
#include "GaudiKernel/IMessageSvc.h"
#include "GaudiKernel/ISvcLocator.h"
#include "AthenaKernel/errorcheck.h"
#include "CxxUtils/checker_macros.h"
#include "../CodeGenerator_v2.h"
#include "../RootObjectMetadata.h"

Go to the source code of this file.

Functions

template<typename T >
std::ostream & operator<< (std::ostream &out, const std::vector< T > &vec)
 Formatted printing for vector objects. More...
 
StatusCode extractVariables (const std::string &file_name, const std::string &tree_name, const std::vector< std::string > &patterns, D3PD::RootObjectMetadata &metadata)
 This function is used to extract the variable descriptions from the D3PD file. More...
 
StatusCode extractVariables (const std::string &file_name, const std::string &tree_name, const std::string &pattern, D3PD::RootObjectMetadata &metadata)
 
int main ATLAS_NOT_THREAD_SAFE (int argc, char *argv[])
 A convenience declaration to save myself some typeing. More...
 

Function Documentation

◆ ATLAS_NOT_THREAD_SAFE()

int main ATLAS_NOT_THREAD_SAFE ( int  argc,
char *  argv[] 
)

A convenience declaration to save myself some typeing.

Definition at line 89 of file d3pdReaderMaker.cxx.

89  {
90  // Let's disable the ROOT warnings:
92 
93  // Force the Gaudi MessageSvc into existence. This gets rid of the
94  // warnings from getMessageSvc().
95  SmartIF<IMessageSvc> msvc{Gaudi::svcLocator()->service("MessageSvc")};
96  if( !msvc ) {
97  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
98  << "Couldn't set up the Gaudi message service";
99  return 255;
100  }
101 
102  //
103  // Construct the object describing all the command line parameters of the
104  // application:
105  //
106  po::options_description desc( PROGRAM_DESC );
107  desc.add_options()
108  ( "help,h", "Give some help with the program usage" )
109  ( "classname,n", po::value< std::string >()->default_value( "D3PDReader" ),
110  "Generated class name" )
111  ( "d3pd-files,f", po::value< std::vector< std::string > >()->multitoken(),
112  "Input D3PD file(s)" )
113  ( "tree,t", po::value< std::string >()->default_value( "" ), "Name of the D3PD tree" )
114  ( "variables,v", po::value< std::vector< std::string > >()->multitoken(),
115  "Variable names to consider (regular expression(s))" )
116  ( "prefixes,p", po::value< std::vector< std::string > >()->multitoken(),
117  "Variable name prefix(es)" )
118  ( "container,c", "Option specifying that a proxy class should be created" )
119  ( "output,o", po::value< std::string >()->default_value( "." ),
120  "Output directory for the generated source files" );
121 
122  //
123  // Interpret the command line options provided by the user:
124  //
125  po::variables_map vm;
126  try {
127  po::store( po::parse_command_line( argc, argv, desc ), vm );
128  po::notify( vm );
129  } catch( const std::exception& ex ) {
130  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
131  << "There was a problem with interpreting the command line options.";
132  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
133  << "Message: " << ex.what();
134  return 255;
135  }
136 
137  //
138  // If the user asked for some help, let's print it:
139  //
140  if( vm.count( "help" ) ) {
141  std::cout << desc << std::endl;
142  return 0;
143  }
144 
145  //
146  // Greet the user, and print all the parameters that the application
147  // received:
148  //
149  std::cout << PROGRAM_GREETING << std::endl;
150  std::cout << "Program will be executed with the options:" << std::endl;
151 
152  // Get the name of the class to be generated:
153  std::string class_name = vm[ "classname" ].as< std::string >();
154  std::cout << " Generating class with name: \"D3PDReader::" << class_name << "\""
155  << std::endl;
156 
157  // Extract the file name(s) from the command line arguments:
158  if( ! vm.count( "d3pd-files" ) ) {
159  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
160  << "You have to specify at least one D3PD file!";
161  return 255;
162  }
163  const std::vector< std::string > file_names =
164  vm[ "d3pd-files" ].as< std::vector< std::string > >();
165  std::cout << " D3PD file(s): " << file_names << std::endl;
166 
167  // Get the name of the D3PD TTree:
168  const std::string d3pd_tree_name = vm[ "tree" ].as< std::string >();
169  if( d3pd_tree_name != "" ) {
170  std::cout << " Using D3PD tree: " << d3pd_tree_name << std::endl;
171  } else {
172  std::cout << " Trying to find D3PD tree automatically" << std::endl;
173  }
174 
175  // Get the variable name patterns:
176  std::vector< std::string > var_names;
177  if( vm.count( "variables" ) ) {
178  var_names = vm[ "variables" ].as< std::vector< std::string > >();
179  std::cout << " Only considering variables with names: " << var_names << std::endl;
180  } else {
181  std::cout << " Considering all variables from the input file" << std::endl;
182  }
183 
184  // Get the common prefix of the variable names:
185  if( ( ( vm.count( "prefixes" ) != vm.count( "variables" ) ) &&
186  ( vm.count( "prefixes" ) != 1 ) ) ||
187  ( vm.count( "prefixes" ) == 0 ) ) {
188  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
189  << "You have to either specify just one prefix, or the same number as "
190  << "how many variable regular expressions you gave";
191  return 255;
192  }
193  const std::vector< std::string > prefixes =
194  vm[ "prefixes" ].as< std::vector< std::string > >();
195  std::cout << " Common variable prefix(es): " << prefixes << std::endl;
196 
197  // Get the parameter describing whether proxy classes should be generated:
198  const bool is_container = vm.count( "container" );
199  std::cout << " Proxy class will " << ( is_container ? "" : "NOT " ) << "be created"
200  << std::endl;
201 
202  // Get the output directory:
203  const std::string output = vm[ "output" ].as< std::string >();
204  std::cout << " Output directory: " << output << std::endl;
205 
206  //
207  // Create the metadata object(s):
208  //
209  std::map< std::string, D3PD::RootObjectMetadata > metadata;
210  std::vector< std::string >::const_iterator prefix_itr = prefixes.begin();
211  std::vector< std::string >::const_iterator prefix_end = prefixes.end();
212  for( ; prefix_itr != prefix_end; ++prefix_itr ) {
213  metadata[ *prefix_itr ].setName( class_name );
214  metadata[ *prefix_itr ].setPrefix( *prefix_itr );
215  metadata[ *prefix_itr ].setContainer( is_container );
216  }
217 
218  //
219  // Iterate over the files:
220  //
221  std::vector< std::string >::const_iterator file_itr = file_names.begin();
222  std::vector< std::string >::const_iterator file_end = file_names.end();
223  for( ; file_itr != file_end; ++file_itr ) {
224 
225  if( prefixes.size() > 1 ) {
226 
227  for( size_t i = 0; i < prefixes.size(); ++i ) {
228  if( extractVariables( *file_itr, d3pd_tree_name, var_names[ i ],
229  metadata[ prefixes[ i ] ] ).isFailure() ) {
230  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
231  << "Couldn't extract the variable descriptions from file: "
232  << *file_itr;
233  return 255;
234  }
235  }
236 
237  } else {
238 
239  if( extractVariables( *file_itr, d3pd_tree_name, var_names,
240  metadata[ prefixes[ 0 ] ] ).isFailure() ) {
241  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
242  << "Couldn't extract the variable descriptions from file: "
243  << *file_itr;
244  return 255;
245  }
246 
247  }
248 
249  }
250 
251  //
252  // Merge the information extracted:
253  //
254  D3PD::ObjectMetadata summed_meta;
255  summed_meta.setName( class_name );
256  summed_meta.setPrefix( prefixes[ 0 ] );
257  summed_meta.setContainer( is_container );
258  prefix_itr = prefixes.begin();
259  prefix_end = prefixes.end();
260  for( ; prefix_itr != prefix_end; ++prefix_itr ) {
261  summed_meta += metadata[ *prefix_itr ];
262  }
263 
264  //
265  // Generate the D3PDObjectBase class's source:
266  //
267  if( D3PD::Version2::writeD3PDObjectBase( output ).isFailure() ) {
268  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
269  << "Couldn't create the D3PDObjectBase class source";
270  return 255;
271  }
272 
273  //
274  // Generate the VarHandle class's source:
275  //
276  if( D3PD::Version2::writeVarHandle( output ).isFailure() ) {
277  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
278  << "Couldn't create the VarHandle class source";
279  return 255;
280  }
281 
282  //
283  // Generate the VarProxy class's source if needed:
284  //
285  if( is_container ) {
286  if( D3PD::Version2::writeVarProxy( output ).isFailure() ) {
287  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
288  << "Couldn't create the VarProxy class source";
289  return 255;
290  }
291  }
292 
293  //
294  // Generate the VarHandle class's source:
295  //
296  if( D3PD::Version2::writeUserD3PDObject( output ).isFailure() ) {
297  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
298  << "Couldn't create the UserD3PDObject class source";
299  return 255;
300  }
301 
302  //
303  // Generate the D3PDReadStats class's source:
304  //
305  if( D3PD::Version2::writeD3PDReadStats( output ).isFailure() ) {
306  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
307  << "Couldn't create the D3PDReadStats class source";
308  return 255;
309  }
310 
311  //
312  // Generate the D3PDPerfStats class's source:
313  //
314  if( D3PD::Version2::writeD3PDPerfStats( output ).isFailure() ) {
315  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
316  << "Couldn't create the D3PDPerfStats class source";
317  return 255;
318  }
319 
320  //
321  // Generate the Utils source:
322  //
323  if( D3PD::Version2::writeUtils( output ).isFailure() ) {
324  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
325  << "Couldn't create the Utils source";
326  return 255;
327  }
328 
329  //
330  // Generate the header of the D3PDReader class:
331  //
332  if( D3PD::Version2::writeHeader( class_name, output, summed_meta ).isFailure() ) {
333  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
334  << "Couldn't generate the D3PDReader class header";
335  return 255;
336  }
337 
338  //
339  // Generate the source of the D3PDReader class:
340  //
341  if( D3PD::Version2::writeSource( class_name, output, summed_meta ).isFailure() ) {
342  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker" )
343  << "Couldn't generate the D3PDReader class source";
344  return 255;
345  }
346 
347  return 0;
348 }

◆ extractVariables() [1/2]

StatusCode extractVariables ( const std::string &  file_name,
const std::string &  tree_name,
const std::string &  pattern,
D3PD::RootObjectMetadata metadata 
)

Definition at line 512 of file d3pdReaderMaker.cxx.

514  {
515 
516  std::vector< std::string > patterns; patterns.push_back( pattern );
517  return extractVariables( file_name, tree_name, patterns, metadata );
518 }

◆ extractVariables() [2/2]

StatusCode extractVariables ( const std::string &  file_name,
const std::string &  tree_name,
const std::vector< std::string > &  patterns,
D3PD::RootObjectMetadata metadata 
)

This function is used to extract the variable descriptions from the D3PD file.

This function is used to parse the variables in the specified D3PD file, and collect the types and names of them.

This information is then used to generate the D3PDReader sources.

Parameters
file_nameName of the input D3PD file
tree_nameName of the D3PD TTree in the file
patternsA vector of regular expressions to select the variables with
varsThe vector which is filled with the extracted information
Returns
A StatusCode indicating whether the operation was successful

Definition at line 361 of file d3pdReaderMaker.cxx.

363  {
364 
365  //
366  // Try to open the D3PD file:
367  //
368  TFile* file = TFile::Open( file_name.c_str(), "READ" );
369  if( ( ! file ) || file->IsZombie() ) {
370  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
371  << "Failed to open D3PD file: " << file_name;
372  return StatusCode::FAILURE;
373  }
374 
375  //
376  // Access the D3PD tree:
377  //
378  TTree* tree = 0;
379  if( tree_name != "" ) {
380  //
381  // If the user specified a tree name, then try to access that tree:
382  //
383  tree = dynamic_cast< TTree* >( file->Get( tree_name.c_str() ) );
384  if( ! tree ) {
385  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
386  << "Couldn't find tree \"" << tree_name << "\" in file: " << file_name;
387  return StatusCode::FAILURE;
388  }
389  } else {
390  //
391  // If the user didn't specify a tree name then search for all the TTree-s
392  // in the file which are not called "CollectionTree", and select the first
393  // one.
394  //
395  std::string name = "";
396  const TList* keys = file->GetListOfKeys();
397  for( Int_t i = 0; i < keys->GetSize(); ++i ) {
398  const TKey* key = dynamic_cast< TKey* >( keys->At( i ) );
399  if (!key) continue;
400  std::string key_name = key->GetName();
401  if( ( key_name.find( "CollectionTree" ) == key_name.npos ) &&
402  ( key->GetClassName() == std::string( "TTree" ) ) ) {
403  name = key_name;
404  std::cout << "Assuming that the D3PD tree is called: " << name
405  << std::endl;
406  break;
407  }
408  }
409  if( name == "" ) {
410  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
411  << "Couldn't find the name for the D3PD tree!";
412  return StatusCode::FAILURE;
413  }
414  tree = dynamic_cast< TTree* >( file->Get( name.c_str() ) );
415  if( ! tree ) {
416  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
417  << "Couldn't find tree \"" << tree_name << "\" in file: "
418  << file_name;
419  return StatusCode::FAILURE;
420  }
421  }
422 
423  //
424  // Look at all the branches in the tree:
425  //
426  TObjArray* branches = tree->GetListOfBranches();
427  for( Int_t i = 0; i < branches->GetSize(); ++i ) {
428 
429  //
430  // Only consider the branches that match one of the specified patterns:
431  //
432  bool pass = false;
433  std::vector< std::string >::const_iterator itr = patterns.begin();
434  std::vector< std::string >::const_iterator end = patterns.end();
435  for( ; itr != end; ++itr ) {
436  if( boost::regex_search( branches->At( i )->GetName(),
437  boost::basic_regex< char >( itr->c_str() ) ) ) {
438  pass = true;
439  break;
440  }
441  }
442  if( ! pass ) continue;
443 
444  //
445  // Extract the type of the variable. This has to be done a little differently for
446  // primitive types and objects (STL containers).
447  //
448  const std::string branch_type( branches->At( i )->IsA()->GetName() );
449  if( branch_type == "TBranch" ) {
450 
451  //
452  // If it's a branch describing a primitive type, then the name of the type
453  // has to be extracted from the single leaf of the branch:
454  //
455  TBranch* branch = dynamic_cast< TBranch* >( branches->At( i ) );
456  if( ! branch ) {
457  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
458  << "Could not cast object into a TBranch!";
459  return StatusCode::FAILURE;
460  }
461  TObjArray* leaves = branch->GetListOfLeaves();
462  bool leaf_found = false;
463  for( Int_t j = 0; j < leaves->GetSize(); ++j ) {
464  TLeaf* leaf = dynamic_cast< TLeaf* >( leaves->At( 0 ) );
465  if( leaf ) {
466  if( metadata.addVariable( branch->GetName(),
467  leaf->GetTypeName(),
468  branch->GetTitle() ).isFailure() ) {
469  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
470  << "Failed adding variable: " << branch->GetName();
471  return StatusCode::FAILURE;
472  }
473  leaf_found = true;
474  break;
475  }
476  }
477  if( ! leaf_found ) {
478  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
479  << "Couldn't find the TLeaf describing a primitive type!";
480  return StatusCode::FAILURE;
481  }
482 
483  } else if( branch_type == "TBranchElement" ) {
484 
485  //
486  // If it's a branch describing an object, then the situation is a bit simpler.
487  // In this case we can ask the TBranchElement directly for the class name.
488  // Remember however that this is a "simplified" name of the class, like
489  // "vector<float>".
490  //
491  TBranchElement* branch = dynamic_cast< TBranchElement* >( branches->At( i ) );
492  if( ! branch ) {
493  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
494  << "Could not cast object into a TBranchElement!";
495  return StatusCode::FAILURE;
496  }
497  if( metadata.addVariable( branch->GetName(),
498  branch->GetClassName(),
499  branch->GetTitle() ).isFailure() ) {
500  REPORT_MESSAGE_WITH_CONTEXT( MSG::ERROR, "d3pdReaderMaker::extractVariables" )
501  << "Failed adding variable: " << branch->GetName();
502  return StatusCode::FAILURE;
503  }
504  }
505  }
506 
507  // Clean up after ourselves:
508  delete file;
509  return StatusCode::SUCCESS;
510 }

◆ operator<<()

template<typename T >
std::ostream& operator<< ( std::ostream &  out,
const std::vector< T > &  vec 
)

Formatted printing for vector objects.

The code has to print a vector in at least one place. To make it easily readable in the code, I like to use such an output operator. It can be used for any kind of vector as long as the template type can also be printed with the << operator.

Parameters
outAn STL output stream
vecThe vector that should be printed
Returns
The same output stream that the operator received

Definition at line 63 of file d3pdReaderMaker.cxx.

63  {
64  out << "[";
65  typename std::vector< T >::const_iterator itr = vec.begin();
66  typename std::vector< T >::const_iterator end = vec.end();
67  for( ; itr != end; ++itr ) {
68  out << *itr;
69  if( ++itr != end ) {
70  out << ", ";
71  }
72  --itr;
73  }
74  out << "]";
75  return out;
76 }
mergePhysValFiles.pattern
pattern
Definition: DataQuality/DataQualityUtils/scripts/mergePhysValFiles.py:26
SGTest::store
TestStore store
Definition: TestStore.cxx:23
D3PD::Version2::writeD3PDPerfStats
StatusCode writeD3PDPerfStats(const std::string &dir)
This function can be used to create the D3PDReader::D3PDPerfStats class's source files.
Definition: CodeGenerator_v2.cxx:528
D3PD::Version2::writeUserD3PDObject
StatusCode writeUserD3PDObject(const std::string &dir)
This function can be used to create the D3PDReader::UserD3PDObject class's source files.
Definition: CodeGenerator_v2.cxx:411
D3PD::Version2::writeSource
StatusCode writeSource(const std::string &classname, const std::string &dir, const ObjectMetadata &metadata)
This function is used to generate the source file of a D3PDReader class.
Definition: CodeGenerator_v2.cxx:967
D3PD::Version2::writeD3PDObjectBase
StatusCode writeD3PDObjectBase(const std::string &dir)
This function can be used to create the D3PDReader::D3PDObjectBase class's source files.
Definition: CodeGenerator_v2.cxx:265
patterns
std::vector< std::string > patterns
Definition: listroot.cxx:187
tree
TChain * tree
Definition: tile_monitor.h:30
D3PD::ObjectMetadata::setName
void setName(const std::string &name)
Set the name of the D3PDObject that this object describes.
Definition: ObjectMetadata.cxx:175
python.AthDsoLogger.out
out
Definition: AthDsoLogger.py:71
athena.value
value
Definition: athena.py:124
D3PD::ObjectMetadata::setPrefix
void setPrefix(const std::string &prefix)
Set the prefix given to variables in this D3PDObject.
Definition: ObjectMetadata.cxx:224
D3PD::Version2::writeVarHandle
StatusCode writeVarHandle(const std::string &dir)
This function can be used to create the D3PDReader::VarHandle class's source files.
Definition: CodeGenerator_v2.cxx:298
vec
std::vector< size_t > vec
Definition: CombinationsGeneratorTest.cxx:12
D3PD::Version2::writeUtils
StatusCode writeUtils(const std::string &dir)
This function can be used to create source files containing some utility functions.
Definition: CodeGenerator_v2.cxx:577
mergePhysValFiles.end
end
Definition: DataQuality/DataQualityUtils/scripts/mergePhysValFiles.py:93
python.checkMetadata.metadata
metadata
Definition: checkMetadata.py:175
physics_parameters.file_name
string file_name
Definition: physics_parameters.py:32
runLayerRecalibration.branches
list branches
Definition: runLayerRecalibration.py:98
CaloCondBlobAlgs_fillNoiseFromASCII.desc
desc
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:54
lumiFormat.i
int i
Definition: lumiFormat.py:85
LArCellNtuple.argv
argv
Definition: LArCellNtuple.py:152
Analysis::kError
@ kError
Definition: CalibrationDataVariables.h:60
calibdata.exception
exception
Definition: calibdata.py:496
file
TFile * file
Definition: tile_monitor.h:29
DQHistogramMergeRegExp.argc
argc
Definition: DQHistogramMergeRegExp.py:20
merge.output
output
Definition: merge.py:17
REPORT_MESSAGE_WITH_CONTEXT
#define REPORT_MESSAGE_WITH_CONTEXT(LVL, CONTEXT_NAME)
Report a message, with an explicitly specified context name.
Definition: Control/AthenaKernel/AthenaKernel/errorcheck.h:345
D3PD::ObjectMetadata::setContainer
void setContainer(bool container)
Set whether the D3PDObject describes a container or not.
Definition: ObjectMetadata.cxx:235
D3PD::ObjectMetadata
D3PD variable metadata handling class.
Definition: ObjectMetadata.h:36
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
D3PD::Version2::writeD3PDReadStats
StatusCode writeD3PDReadStats(const std::string &dir)
This function can be used to create the D3PDReader::D3PDReadStats class's source files.
Definition: CodeGenerator_v2.cxx:478
gErrorIgnoreLevel
int gErrorIgnoreLevel
RTTAlgmain.branch
branch
Definition: RTTAlgmain.py:61
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
D3PD::Version2::writeHeader
StatusCode writeHeader(const std::string &classname, const std::string &dir, const ObjectMetadata &metadata)
This function is used to create the header of the class describing a set of D3PD variables.
Definition: CodeGenerator_v2.cxx:632
python.DetectStreamerInfoChanges.class_name
class_name
Definition: DetectStreamerInfoChanges.py:60
D3PD::Version2::writeVarProxy
StatusCode writeVarProxy(const std::string &dir)
This function can be used to create the D3PDReader::VarProxy class's source files.
Definition: CodeGenerator_v2.cxx:363
extractVariables
StatusCode extractVariables(const std::string &file_name, const std::string &tree_name, const std::vector< std::string > &patterns, D3PD::RootObjectMetadata &metadata)
This function is used to extract the variable descriptions from the D3PD file.
Definition: d3pdReaderMaker.cxx:361
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37