The Gaudi Framework  v30r1 (5d4f4ae2)
CollectionCloneAlg Class Reference

Small algorithm, which allows to merge N-tuples in a generic way. More...

Inheritance diagram for CollectionCloneAlg:
Collaboration diagram for CollectionCloneAlg:

Public Member Functions

StatusCode initialize () override
 Initialize. More...
 
StatusCode finalize () override
 Finalize. More...
 
StatusCode execute () override
 Execute procedure. More...
 
virtual StatusCode book (const NTuple::Tuple *nt)
 Book the N-tuple according to the specification. More...
 
virtual StatusCode checkInput (const NTuple::Tuple *clone, const NTuple::Tuple *src)
 
StatusCode mergeEntries (const std::string &input)
 Merge the entries of a single input tuple into the output. More...
 
StatusCode connect ()
 Connect input and output N-tuples. More...
 
StatusCode mergeInputTuples ()
 Merge all N-tuple entries. More...
 
- Public Member Functions inherited from Algorithm
 Algorithm (const std::string &name, ISvcLocator *svcloc, const std::string &version=PACKAGE_VERSION)
 Constructor. More...
 
StatusCode sysStart () override
 Reinitialization method invoked by the framework. More...
 
StatusCode sysInitialize () override
 Initialization method invoked by the framework. More...
 
StatusCode sysReinitialize () override
 Reinitialization method invoked by the framework. More...
 
StatusCode sysRestart () override
 Restart method invoked by the framework. More...
 
StatusCode sysExecute (const EventContext &ctx) override
 The actions to be performed by the algorithm on an event. More...
 
StatusCode sysStop () override
 System stop. More...
 
StatusCode sysFinalize () override
 System finalization. More...
 
StatusCode sysBeginRun () override
 beginRun method invoked by the framework. More...
 
StatusCode sysEndRun () override
 endRun method invoked by the framework. More...
 
const std::stringname () const override
 The identifying name of the algorithm object. More...
 
const Gaudi::StringKeynameKey () const override
 
const std::stringtype () const override
 The type of the algorithm object. More...
 
void setType (const std::string &type) override
 
const std::stringversion () const override
 
unsigned int index () const override
 
StatusCode configure () override
 Dummy implementation of IStateful::configure() method. More...
 
StatusCode terminate () override
 Dummy implementation of IStateful::terminate() method. More...
 
StatusCode initialize () override
 the default (empty) implementation of IStateful::initialize() method More...
 
StatusCode start () override
 the default (empty) implementation of IStateful::start() method More...
 
StatusCode stop () override
 the default (empty) implementation of IStateful::stop() method More...
 
StatusCode finalize () override
 the default (empty) implementation of IStateful::finalize() method More...
 
StatusCode reinitialize () override
 the default (empty) implementation of IStateful::reinitialize() method More...
 
StatusCode restart () override
 the default (empty) implementation of IStateful::restart() method More...
 
Gaudi::StateMachine::State FSMState () const override
 returns the current state of the algorithm More...
 
Gaudi::StateMachine::State targetFSMState () const override
 returns the state the algorithm will be in after the ongoing transition More...
 
bool isExecuted () const override
 Has this algorithm been executed since the last reset? More...
 
void setExecuted (bool state) const override
 Set the executed flag to the specified state. More...
 
void resetExecuted () override
 Reset the executed state of the Algorithm for the duration of the current event. More...
 
StatusCode beginRun () override
 Algorithm begin run. More...
 
StatusCode endRun () override
 Algorithm end run. This method is called at the end of the event loop. More...
 
bool isEnabled () const override
 Is this algorithm enabled or disabled? More...
 
bool isSequence () const override
 Are we a Sequence? More...
 
bool filterPassed () const override
 Did this algorithm pass or fail its filter criterion for the last event? More...
 
void setFilterPassed (bool state) const override
 Set the filter passed flag to the specified state. More...
 
unsigned int errorCount () const
 Get the number of failures of the algorithm. More...
 
template<class T >
StatusCode service (const std::string &name, T *&psvc, bool createIf=true) const
 Access a service by name, creating it if it doesn't already exist. More...
 
template<class T >
StatusCode service (const std::string &svcType, const std::string &svcName, T *&psvc) const
 Access a service by name and type, creating it if it doesn't already exist. More...
 
SmartIF< IServiceservice (const std::string &name, const bool createIf=true, const bool quiet=false) const
 Return a pointer to the service identified by name (or "type/name") More...
 
template<class T >
SmartIF< T > service (const std::string &name, bool createIf=true, bool quiet=false) const
 
SmartIF< IAuditorSvc > & auditorSvc () const
 The standard auditor service.May not be invoked before sysInitialize() has been invoked. More...
 
SmartIF< IChronoStatSvc > & chronoSvc () const
 The standard Chrono & Stat service, Return a pointer to the service if present. More...
 
SmartIF< IChronoStatSvc > & chronoStatService () const
 
SmartIF< IDataProviderSvc > & detSvc () const
 The standard detector data service. More...
 
SmartIF< IDataProviderSvc > & detDataService () const
 
SmartIF< IConversionSvc > & detCnvSvc () const
 The standard detector data persistency conversion service. More...
 
SmartIF< IConversionSvc > & detDataCnvService () const
 
SmartIF< IDataProviderSvc > & eventSvc () const
 The standard event data service. More...
 
SmartIF< IDataProviderSvc > & evtSvc () const
 shortcut for method eventSvc More...
 
SmartIF< IDataProviderSvc > & eventDataService () const
 
SmartIF< IConversionSvc > & eventCnvSvc () const
 The standard event data persistency conversion service. More...
 
SmartIF< IConversionSvc > & eventDataCnvService () const
 
SmartIF< IHistogramSvc > & histoSvc () const
 The standard histogram service. More...
 
SmartIF< IHistogramSvc > & histogramDataService () const
 
SmartIF< INTupleSvc > & ntupleSvc () const
 The standard N tuple service. More...
 
SmartIF< INTupleSvc > & ntupleService () const
 
SmartIF< IRndmGenSvc > & randSvc () const
 The standard RandomGen service, Return a pointer to the service if present. More...
 
SmartIF< IToolSvc > & toolSvc () const
 The standard ToolSvc service, Return a pointer to the service if present. More...
 
SmartIF< IExceptionSvc > & exceptionSvc () const
 Get the exception Service. More...
 
SmartIF< IAlgContextSvc > & contextSvc () const
 get Algorithm Context Service More...
 
SmartIF< ITimelineSvc > & timelineSvc () const
 
SmartIF< ISvcLocator > & serviceLocator () const override
 The standard service locator. More...
 
SmartIF< ISvcLocator > & svcLoc () const
 shortcut for method serviceLocator More...
 
SmartIF< IHiveWhiteBoard > & whiteboard () const
 
SmartIF< IAlgExecStateSvc > & algExecStateSvc () const
 
bool registerContext () const
 register for Algorithm Context Service? More...
 
StatusCode createSubAlgorithm (const std::string &type, const std::string &name, Algorithm *&pSubAlg)
 Create a sub algorithm. More...
 
const std::vector< Algorithm * > * subAlgorithms () const
 List of sub-algorithms. Returns a pointer to a vector of (sub) Algorithms. More...
 
std::vector< Algorithm * > * subAlgorithms ()
 List of sub-algorithms. Returns a pointer to a vector of (sub) Algorithms. More...
 
StatusCode setProperties ()
 Set the algorithm's properties. More...
 
template<class T >
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, ToolHandle< T > &hndl, const std::string &doc="none")
 
template<class T >
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, ToolHandleArray< T > &hndlArr, const std::string &doc="none")
 
SmartIF< IMonitorSvc > & monitorSvc () const
 Access the monitor service. More...
 
template<class T >
void declareInfo (const std::string &name, const T &var, const std::string &desc) const
 Declare monitoring information. More...
 
void declareInfo (const std::string &name, const std::string &format, const void *var, int size, const std::string &desc) const
 Declare monitoring information (special case) More...
 
const EventContextgetContext () const override
 get the context More...
 
virtual void acceptDHVisitor (IDataHandleVisitor *) const override
 
void commitHandles () override
 
void registerTool (IAlgTool *tool) const
 
void deregisterTool (IAlgTool *tool) const
 
template<class T >
StatusCode declareTool (ToolHandle< T > &handle, std::string toolTypeAndName, bool createIf=true)
 
template<class T >
void addToolsArray (ToolHandleArray< T > &hndlArr)
 
const std::vector< IAlgTool * > & tools () const
 
bool isIOBound () const
 
void setIOBound (bool value)
 
unsigned int cardinality () const override
 Return the cardinality. More...
 
const std::vector< std::string > & neededResources () const override
 
std::ostreamtoControlFlowExpression (std::ostream &os) const override
 Produce string represention of the control flow expression. More...
 
- Public Member Functions inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > > >
std::vector< Gaudi::DataHandle * > inputHandles () const override
 
std::vector< Gaudi::DataHandle * > outputHandles () const override
 
virtual const DataObjIDCollextraInputDeps () const override
 
virtual const DataObjIDCollextraOutputDeps () const override
 
void declare (Gaudi::DataHandle &handle) override
 
void renounce (Gaudi::DataHandle &handle) override
 
const DataObjIDCollinputDataObjs () const override
 
const DataObjIDColloutputDataObjs () const override
 
void addDependency (const DataObjID &id, const Gaudi::DataHandle::Mode &mode) override
 
- Public Member Functions inherited from extends< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > >, IDataHandleHolder >
void * i_cast (const InterfaceID &tid) const override
 Implementation of IInterface::i_cast. More...
 
StatusCode queryInterface (const InterfaceID &ti, void **pp) override
 Implementation of IInterface::queryInterface. More...
 
std::vector< std::stringgetInterfaceNames () const override
 Implementation of IInterface::getInterfaceNames. More...
 
- Public Member Functions inherited from PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > >
 PropertyHolder ()=default
 
Gaudi::Details::PropertyBasedeclareProperty (Gaudi::Details::PropertyBase &prop)
 Declare a property. More...
 
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, TYPE &value, const std::string &doc="none")
 Helper to wrap a regular data member and use it as a regular property. More...
 
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, Gaudi::Property< TYPE, VERIFIER, HANDLERS > &prop, const std::string &doc="none")
 Declare a PropertyBase instance setting name and documentation. More...
 
Gaudi::Details::PropertyBasedeclareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="")
 Declare a remote property. More...
 
StatusCode setProperty (const Gaudi::Details::PropertyBase &p) override
 set the property form another property More...
 
StatusCode setProperty (const std::string &s) override
 set the property from the formatted string More...
 
StatusCode setProperty (const std::string &n, const std::string &v) override
 set the property from name and the value More...
 
StatusCode setProperty (const std::string &name, const TYPE &value)
 set the property form the value More...
 
StatusCode getProperty (Gaudi::Details::PropertyBase *p) const override
 get the property More...
 
const Gaudi::Details::PropertyBasegetProperty (const std::string &name) const override
 get the property by name More...
 
StatusCode getProperty (const std::string &n, std::string &v) const override
 convert the property to the string More...
 
const std::vector< Gaudi::Details::PropertyBase * > & getProperties () const override
 get all properties More...
 
bool hasProperty (const std::string &name) const override
 Return true if we have a property with the given name. More...
 
 PropertyHolder (const PropertyHolder &)=delete
 
PropertyHolderoperator= (const PropertyHolder &)=delete
 
- Public Member Functions inherited from CommonMessagingBase
virtual ~CommonMessagingBase ()=default
 Virtual destructor. More...
 
const SmartIF< IMessageSvc > & msgSvc () const
 The standard message service. More...
 
MsgStreammsgStream () const
 Return an uninitialized MsgStream. More...
 
MsgStreammsgStream (const MSG::Level level) const
 Predefined configurable message stream for the efficient printouts. More...
 
MsgStreamalways () const
 shortcut for the method msgStream(MSG::ALWAYS) More...
 
MsgStreamfatal () const
 shortcut for the method msgStream(MSG::FATAL) More...
 
MsgStreamerr () const
 shortcut for the method msgStream(MSG::ERROR) More...
 
MsgStreamerror () const
 shortcut for the method msgStream(MSG::ERROR) More...
 
MsgStreamwarning () const
 shortcut for the method msgStream(MSG::WARNING) More...
 
MsgStreaminfo () const
 shortcut for the method msgStream(MSG::INFO) More...
 
MsgStreamdebug () const
 shortcut for the method msgStream(MSG::DEBUG) More...
 
MsgStreamverbose () const
 shortcut for the method msgStream(MSG::VERBOSE) More...
 
MsgStreammsg () const
 shortcut for the method msgStream(MSG::INFO) More...
 
MSG::Level msgLevel () const
 get the cached level (originally extracted from the embedded MsgStream) More...
 
MSG::Level outputLevel () const __attribute__((deprecated))
 Backward compatibility function for getting the output level. More...
 
bool msgLevel (MSG::Level lvl) const
 get the output level from the embedded MsgStream More...
 

Private Attributes

Gaudi::Property< std::stringm_tupleSvc {this, "EvtTupleSvc", "EvtTupleSvc", "name of the data provider service"}
 
Gaudi::Property< std::vector< std::string > > m_inputs {this, "Input", {}, "input specifications"}
 
Gaudi::Property< std::stringm_output {this, "Output", {}, "output specification"}
 
SmartIF< INTupleSvcm_dataSvc
 Reference to data provider service. More...
 
std::string m_rootName
 Name of the root leaf (obtained at initialize) More...
 
std::string m_outName
 Output tuple name. More...
 
std::string m_criteria
 Selection criteria (if any) More...
 
std::string m_selectorName
 Selector factory. More...
 

Additional Inherited Members

- Public Types inherited from Algorithm
typedef Gaudi::PluginService::Factory< IAlgorithm *, const std::string &, ISvcLocator * > Factory
 
- Public Types inherited from extends< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > >, IDataHandleHolder >
using base_class = extends
 Typedef to this class. More...
 
using extend_interfaces_base = extend_interfaces< Interfaces... >
 Typedef to the base of this class. More...
 
- Public Types inherited from PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > >
using PropertyHolderImpl = PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > >
 Typedef used to refer to this class from derived classes, as in. More...
 
- Public Types inherited from CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > >
using base_class = CommonMessaging
 
- Public Types inherited from extend_interfaces< Interfaces... >
using ext_iids = typename Gaudi::interface_list_cat< typename Interfaces::ext_iids... >::type
 take union of the ext_iids of all Interfaces... More...
 
- Public Attributes inherited from Algorithm
friend AlgorithmManager
 
- Protected Member Functions inherited from Algorithm
std::vector< IAlgTool * > & tools ()
 
bool isInitialized () const override
 Has the Algorithm already been initialized? More...
 
bool isFinalized () const override
 Has the Algorithm already been finalized? More...
 
void setIndex (const unsigned int &idx) override
 set instantiation index of Alg More...
 
AlgExecStateexecState (const EventContext &ctx) const
 reference to AlgExecState of Alg More...
 
- Protected Member Functions inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > > >
void initDataHandleHolder ()
 initializes all handles - called by the sysInitialize method of any descendant of this More...
 
- Protected Member Functions inherited from PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > >
Gaudi::Details::PropertyBaseproperty (const std::string &name) const
 
- Protected Member Functions inherited from CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > >
MSG::Level setUpMessaging ()
 Set up local caches. More...
 
MSG::Level resetMessaging ()
 Reinitialize internal states. More...
 
void updateMsgStreamOutputLevel (int level)
 Update the output level of the cached MsgStream. More...
 
- Protected Attributes inherited from Algorithm
std::unique_ptr< IDataHandleVisitorm_updateDataHandles
 Hook for for derived classes to provide a custom visitor for data handles. More...
 
- Protected Attributes inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > > >
DataObjIDColl m_inputDataObjs
 
DataObjIDColl m_outputDataObjs
 

Detailed Description

Small algorithm, which allows to merge N-tuples in a generic way.

In the options directory an python interface is presented, which shows how to steer this algorithm in a standaqlone program.

Author
: M.Frank
Version
: 1.0

Definition at line 109 of file CollectionCloneAlg.cpp.

Member Function Documentation

virtual StatusCode CollectionCloneAlg::book ( const NTuple::Tuple nt)
inlinevirtual

Book the N-tuple according to the specification.

Definition at line 190 of file CollectionCloneAlg.cpp.

191  {
192  MsgStream log( msgSvc(), name() );
193  const INTuple::ItemContainer& items = nt->items();
195  INTuple::ItemContainer::const_iterator i;
196  NTuple::Tuple* tuple = m_dataSvc->book( m_outName, nt->clID(), nt->title() );
197  for ( i = items.begin(); i != items.end(); ++i ) {
198  long type = ( *i )->type();
199  switch ( type ) {
200  case DataTypeInfo::UCHAR:
201  status = createItem( log, tuple, *i, (unsigned char)0 );
202  break;
204  status = createItem( log, tuple, *i, (unsigned short)0 );
205  break;
206  case DataTypeInfo::UINT:
207  status = createItem( log, tuple, *i, (unsigned int)0 );
208  break;
209  case DataTypeInfo::ULONG:
210  status = createItem( log, tuple, *i, (unsigned long)0 );
211  break;
212  case DataTypeInfo::CHAR:
213  status = createItem( log, tuple, *i, char( 0 ) );
214  break;
215  case DataTypeInfo::SHORT:
216  status = createItem( log, tuple, *i, short( 0 ) );
217  break;
218  case DataTypeInfo::INT:
219  status = createItem( log, tuple, *i, int( 0 ) );
220  break;
221  case DataTypeInfo::LONG:
222  status = createItem( log, tuple, *i, long( 0 ) );
223  break;
224  case DataTypeInfo::BOOL:
225  status = createItem( log, tuple, *i, false );
226  break;
227  case DataTypeInfo::FLOAT:
228  status = createItem( log, tuple, *i, float( 0.0 ) );
229  break;
231  status = createItem( log, tuple, *i, double( 0.0 ) );
232  break;
234  status = createItem( log, tuple, *i, (IOpaqueAddress*)0 );
235  break;
237  status = createItem( log, tuple, *i, (void*)0 );
238  break;
240  // status = createItem(log, tuple, *i, (std::string*)0);
241  // break;
243  // status = createItem(log, tuple, *i, (char*)0);
244  // break;
246  default:
247  status = StatusCode::FAILURE;
248  break;
249  }
250  }
251  return status;
252  }
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
const std::string & name() const override
The identifying name of the algorithm object.
Definition: Algorithm.cpp:737
T end(T...args)
SmartIF< INTupleSvc > m_dataSvc
Reference to data provider service.
virtual const CLID & clID() const
Retrieve reference to class definition structure.
Definition: DataObject.cpp:62
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:26
std::string m_outName
Output tuple name.
const SmartIF< IMessageSvc > & msgSvc() const
The standard message service.
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
STL class.
T begin(T...args)
virtual ItemContainer & items()=0
Access item container.
Opaque address interface definition.
const std::string & type() const override
The type of the algorithm object.
Definition: Algorithm.h:167
virtual const std::string & title() const =0
Object title.
virtual NTuple::Tuple * book(const std::string &fullPath, const CLID &type, const std::string &title)=0
Book Ntuple and register it with the data store.
virtual StatusCode CollectionCloneAlg::checkInput ( const NTuple::Tuple clone,
const NTuple::Tuple src 
)
inlinevirtual

Definition at line 255 of file CollectionCloneAlg.cpp.

256  {
257  MsgStream log( msgSvc(), name() );
258  if ( 0 != clone && 0 != src ) {
259  const INTuple::ItemContainer& clone_items = clone->items();
260  const std::string clone_id = clone->registry()->identifier();
261  const std::string src_id = src->registry()->identifier();
262 
263  INTuple::ItemContainer::const_iterator i;
264  log << MSG::ERROR;
265  for ( i = clone_items.begin(); i != clone_items.end(); ++i ) {
266  const INTupleItem* itm = *i;
267  const std::string& nam = itm->name();
268  const INTupleItem* src_itm = src->find( nam );
269  if ( !src_itm ) {
270  log << "Tuple item " << nam << " not present in " << src_id << endmsg;
271  return StatusCode::FAILURE;
272  }
273  if ( itm->type() != src_itm->type() ) {
274  log << "Tuple item " << nam << " are of different types in " << src_id << ":" << src_itm->typeName()
275  << " <-> " << clone_id << ":" << itm->typeName() << endmsg;
276  return StatusCode::FAILURE;
277  }
278  if ( itm->ndim() != src_itm->ndim() ) {
279  log << "Tuple item " << nam << " have different dimensions in " << src_id << ":" << src_itm->ndim() << " <-> "
280  << clone_id << ":" << itm->ndim() << endmsg;
281  return StatusCode::FAILURE;
282  }
283  for ( int j = 0; j < itm->ndim(); ++j ) {
284  if ( src_itm->dim( j ) != itm->dim( j ) ) {
285  log << "Tuple item " << nam << " have different dimensions in " << src_id << "[" << j
286  << "]:" << src_itm->dim( j ) << " <-> " << clone_id << "[" << j << "]:" << itm->dim( j ) << endmsg;
287  return StatusCode::FAILURE;
288  }
289  }
290  if ( itm->hasIndex() != src_itm->hasIndex() ) {
291  log << "Tuple item " << nam << " has different index colums " << src_id << ":" << src_itm->hasIndex()
292  << " <-> " << clone_id << ":" << itm->hasIndex() << endmsg;
293  return StatusCode::FAILURE;
294  }
295  if ( itm->hasIndex() ) {
296  if ( itm->index() != src_itm->index() ) {
297  log << "Tuple item " << nam << " has different index colums " << src_id << ":" << src_itm->index()
298  << " <-> " << clone_id << ":" << itm->index() << endmsg;
299  return StatusCode::FAILURE;
300  }
301  }
302  }
303  return StatusCode::SUCCESS;
304  }
305  return StatusCode::FAILURE;
306  }
virtual const std::string & name() const =0
Access _Item name.
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
const std::string & name() const override
The identifying name of the algorithm object.
Definition: Algorithm.cpp:737
T end(T...args)
IRegistry * registry() const
Get pointer to Registry.
Definition: DataObject.h:73
STL class.
virtual std::string typeName() const =0
Proper type name of the object.
virtual long ndim() const =0
Dimension.
NTuple interface class definition.
Definition: INTuple.h:27
virtual const id_type & identifier() const =0
Full identifier (or key)
const SmartIF< IMessageSvc > & msgSvc() const
The standard message service.
virtual long type() const =0
Type information of the item.
STL class.
T begin(T...args)
virtual const std::string & index() const =0
Access the index _Item.
virtual long dim(long i) const =0
Access individual dimensions.
virtual ItemContainer & items()=0
Access item container.
virtual bool hasIndex() const =0
Is the tuple have an index item?
virtual const INTupleItem * find(const std::string &name) const =0
Find an item row of the Ntuple (CONST)
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
StatusCode CollectionCloneAlg::connect ( )
inline

Connect input and output N-tuples.

Definition at line 415 of file CollectionCloneAlg.cpp.

416  {
418  for ( size_t i = 0; i < m_inputs.size(); ++i ) {
419  NTuplePtr nt( m_dataSvc.get(), m_inputs[i] );
420  if ( !( 0 == nt ) ) {
421  NTuplePtr out( m_dataSvc.get(), m_outName );
422  if ( 0 == out ) {
423  status = book( nt );
424  } else {
425  status = checkInput( out, nt );
426  }
427  if ( !status.isSuccess() ) {
428  return status;
429  } else if ( m_selectorName != "" ) {
430  SmartIF<ISelectStatement> stmt( ObjFactory::create( m_selectorName, serviceLocator() ) );
431  if ( stmt ) {
432  if ( !m_criteria.empty() ) stmt->setCriteria( m_criteria );
433  nt->attachSelector( stmt );
434  } else {
435  MsgStream log( msgSvc(), name() );
436  log << MSG::ERROR << "Failed to attach tuple selector to " << m_inputs[i] << endmsg;
437  return StatusCode::FAILURE;
438  }
439  }
440  } else {
441  MsgStream log( msgSvc(), name() );
442  log << MSG::ERROR << "Failed to access tuple: " << m_inputs[i] << endmsg;
443  return StatusCode::FAILURE;
444  }
445  }
446  return StatusCode::SUCCESS;
447  }
std::string m_criteria
Selection criteria (if any)
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
T empty(T...args)
const std::string & name() const override
The identifying name of the algorithm object.
Definition: Algorithm.cpp:737
virtual StatusCode book(const NTuple::Tuple *nt)
Book the N-tuple according to the specification.
bool isSuccess() const
Test for a status code of SUCCESS.
Definition: StatusCode.h:50
Gaudi::Property< std::vector< std::string > > m_inputs
SmartIF< INTupleSvc > m_dataSvc
Reference to data provider service.
TYPE * get() const
Get interface pointer.
Definition: SmartIF.h:82
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:26
std::string m_outName
Output tuple name.
const SmartIF< IMessageSvc > & msgSvc() const
The standard message service.
virtual StatusCode checkInput(const NTuple::Tuple *clone, const NTuple::Tuple *src)
SmartIF< ISvcLocator > & serviceLocator() const override
The standard service locator.
Definition: Algorithm.cpp:806
A small class used to access easily (and efficiently) data items residing in data stores...
Definition: SmartDataPtr.h:47
std::string m_selectorName
Selector factory.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
StatusCode CollectionCloneAlg::execute ( )
inlineoverride

Execute procedure.

Definition at line 180 of file CollectionCloneAlg.cpp.

181  {
182  StatusCode status = connect();
183  if ( status.isSuccess() ) {
184  status = mergeInputTuples();
185  }
186  return status;
187  }
bool isSuccess() const
Test for a status code of SUCCESS.
Definition: StatusCode.h:50
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:26
StatusCode mergeInputTuples()
Merge all N-tuple entries.
StatusCode connect()
Connect input and output N-tuples.
StatusCode CollectionCloneAlg::finalize ( )
inlineoverride

Finalize.

Definition at line 173 of file CollectionCloneAlg.cpp.

174  {
175  m_dataSvc.reset();
176  return StatusCode::SUCCESS;
177  }
SmartIF< INTupleSvc > m_dataSvc
Reference to data provider service.
void reset(TYPE *ptr=nullptr)
Set the internal pointer to the passed one disposing of the old one.
Definition: SmartIF.h:92
StatusCode CollectionCloneAlg::initialize ( )
inlineoverride

Initialize.

Definition at line 132 of file CollectionCloneAlg.cpp.

133  {
134  MsgStream log( msgSvc(), name() );
135  m_rootName = "";
136  m_outName = "";
137  m_criteria = "";
138  m_selectorName = "";
139  m_dataSvc = service( m_tupleSvc, true );
140  if ( !m_dataSvc ) {
141  log << MSG::ERROR << "Failed to access service \"" << m_tupleSvc << "\"." << endmsg;
142  return StatusCode::FAILURE;
143  }
145  using Parser = Gaudi::Utils::AttribStringParser;
146  for ( auto attrib : Parser( m_output ) ) {
147  switch (::toupper( attrib.tag[0] ) ) {
148  case 'D':
149  m_outName = std::move( attrib.value );
150  break;
151  case 'S':
152  m_criteria = std::move( attrib.value );
153  break;
154  case 'F':
155  fun = std::move( attrib.value );
156  break;
157  default:
158  break;
159  }
160  }
161  if ( m_outName.empty() ) {
162  log << MSG::ERROR << "Failed to analyze output specs:" << m_output << endmsg;
163  return StatusCode::FAILURE;
164  }
165  if ( !fun.empty() || !m_criteria.empty() ) {
166  if ( !m_criteria.empty() && fun.empty() ) fun = "NTuple::Selector";
168  }
169  return StatusCode::SUCCESS;
170  }
Parse attribute strings allowing iteration over the various attributes.
std::string m_criteria
Selection criteria (if any)
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
T empty(T...args)
const std::string & name() const override
The identifying name of the algorithm object.
Definition: Algorithm.cpp:737
SmartIF< INTupleSvc > m_dataSvc
Reference to data provider service.
STL class.
std::string m_outName
Output tuple name.
const SmartIF< IMessageSvc > & msgSvc() const
The standard message service.
T move(T...args)
std::string m_rootName
Name of the root leaf (obtained at initialize)
double fun(const std::vector< double > &x)
Definition: PFuncTest.cpp:26
Gaudi::Property< std::string > m_output
Gaudi::Property< std::string > m_tupleSvc
StatusCode service(const std::string &name, T *&psvc, bool createIf=true) const
Access a service by name, creating it if it doesn&#39;t already exist.
Definition: Algorithm.h:232
std::string m_selectorName
Selector factory.
void toupper(std::string &s)
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
StatusCode CollectionCloneAlg::mergeEntries ( const std::string input)
inline

Merge the entries of a single input tuple into the output.

Definition at line 309 of file CollectionCloneAlg.cpp.

310  {
311  MsgStream log( msgSvc(), name() );
312  NTuplePtr out( m_dataSvc.get(), m_outName );
313  if ( 0 != out ) {
314  const INTuple::ItemContainer& clone_items = out->items();
315  std::vector<GenericAddress> addrVector( clone_items.size() );
317  NTuplePtr nt( m_dataSvc.get(), input );
318  size_t k = 0, nentry = 0;
319  if ( 0 != nt ) {
320  const INTuple::ItemContainer& source_items = nt->items();
321  for ( k = 0; k < source_items.size(); ++k ) {
322  if ( source_items[k]->type() == DataTypeInfo::OBJECT_ADDR ) {
323  *(IOpaqueAddress**)source_items[k]->buffer() = &addrVector[k];
324  }
325  }
326  while ( status.isSuccess() ) {
327  status = m_dataSvc->readRecord( nt.ptr() );
328  if ( status.isSuccess() ) {
329  INTuple::ItemContainer::const_iterator i;
330  nentry++;
331  for ( k = 0, i = source_items.begin(); i != source_items.end(); ++i, ++k ) {
332  const INTupleItem* src_itm = *i;
333  const INTupleItem* out_itm = out->find( src_itm->name() );
334  size_t size = 0;
335  switch ( ( *i )->type() ) {
336  case DataTypeInfo::UCHAR:
337  size = sizeof( unsigned char );
338  break;
340  size = sizeof( unsigned short );
341  break;
342  case DataTypeInfo::UINT:
343  size = sizeof( unsigned int );
344  break;
345  case DataTypeInfo::ULONG:
346  size = sizeof( unsigned long );
347  break;
348  case DataTypeInfo::CHAR:
349  size = sizeof( char );
350  break;
351  case DataTypeInfo::SHORT:
352  size = sizeof( short );
353  break;
354  case DataTypeInfo::INT:
355  size = sizeof( int );
356  break;
357  case DataTypeInfo::LONG:
358  size = sizeof( long );
359  break;
360  case DataTypeInfo::BOOL:
361  size = sizeof( bool );
362  break;
363  case DataTypeInfo::FLOAT:
364  size = sizeof( float );
365  break;
367  size = sizeof( double );
368  break;
370  *(std::string*)out_itm->buffer() = *(std::string*)src_itm->buffer();
371  size = 0;
372  break;
374  size = ::strlen( (const char*)src_itm->buffer() ) + 1;
375  break;
376  case DataTypeInfo::POINTER: {
377  *(void**)out_itm->buffer() = *(void**)src_itm->buffer();
378  size = 0;
379  } break;
381  IOpaqueAddress* ppA1 = &addrVector[k];
382  IOpaqueAddress** ppA2 = (IOpaqueAddress**)out_itm->buffer();
383  *ppA2 = ppA1;
384  size = 0;
385  } break;
387  default:
388  size = 0;
389  break;
390  }
391  if ( size > 0 ) {
392  ::memcpy( (void*)out_itm->buffer(), src_itm->buffer(), size * src_itm->length() );
393  }
394  }
395  status = m_dataSvc->writeRecord( out.ptr() );
396  if ( !status.isSuccess() ) {
397  log << MSG::ERROR << "Failed to write record " << nentry << " from " << input << " to " << m_outName
398  << endmsg;
399  }
400  }
401  }
402  log << MSG::INFO << "End of reading tuple " << input << " after " << nentry << " entries." << endmsg;
403 
404  if ( nentry > 0 || m_selectorName != "" ) {
405  return StatusCode::SUCCESS;
406  }
407  return StatusCode::FAILURE;
408  }
409  log << MSG::ERROR << "Failed to access input: " << input << endmsg;
410  }
411  return StatusCode::FAILURE;
412  }
virtual const std::string & name() const =0
Access _Item name.
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
const std::string & name() const override
The identifying name of the algorithm object.
Definition: Algorithm.cpp:737
T end(T...args)
constexpr auto size(const C &c) noexcept(noexcept(c.size())) -> decltype(c.size())
SmartIF< INTupleSvc > m_dataSvc
Reference to data provider service.
STL class.
TYPE * get() const
Get interface pointer.
Definition: SmartIF.h:82
NTuple interface class definition.
Definition: INTuple.h:27
virtual long length() const =0
Access the buffer length.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:26
virtual StatusCode writeRecord(NTuple::Tuple *tuple)=0
Write single record to N tuple.
std::string m_outName
Output tuple name.
const SmartIF< IMessageSvc > & msgSvc() const
The standard message service.
virtual const void * buffer() const =0
Access data buffer (CONST)
T size(T...args)
STL class.
T begin(T...args)
virtual StatusCode readRecord(NTuple::Tuple *tuple)=0
Read single record from N tuple.
A small class used to access easily (and efficiently) data items residing in data stores...
Definition: SmartDataPtr.h:47
Opaque address interface definition.
const std::string & type() const override
The type of the algorithm object.
Definition: Algorithm.h:167
std::string m_selectorName
Selector factory.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
StatusCode CollectionCloneAlg::mergeInputTuples ( )
inline

Merge all N-tuple entries.

Definition at line 450 of file CollectionCloneAlg.cpp.

451  {
452  MsgStream log( msgSvc(), name() );
453  for ( const auto& input : m_inputs ) {
454  StatusCode sc = mergeEntries( input );
455  if ( !sc.isSuccess() ) {
456  log << MSG::ERROR << "Failed to merge tuple:" << input << endmsg;
457  return sc;
458  }
459  }
460  return StatusCode::SUCCESS;
461  }
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
const std::string & name() const override
The identifying name of the algorithm object.
Definition: Algorithm.cpp:737
bool isSuccess() const
Test for a status code of SUCCESS.
Definition: StatusCode.h:50
Gaudi::Property< std::vector< std::string > > m_inputs
StatusCode mergeEntries(const std::string &input)
Merge the entries of a single input tuple into the output.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:26
const SmartIF< IMessageSvc > & msgSvc() const
The standard message service.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209

Member Data Documentation

std::string CollectionCloneAlg::m_criteria
private

Selection criteria (if any)

Definition at line 123 of file CollectionCloneAlg.cpp.

SmartIF<INTupleSvc> CollectionCloneAlg::m_dataSvc
private

Reference to data provider service.

Definition at line 117 of file CollectionCloneAlg.cpp.

Gaudi::Property<std::vector<std::string> > CollectionCloneAlg::m_inputs {this, "Input", {}, "input specifications"}
private

Definition at line 113 of file CollectionCloneAlg.cpp.

std::string CollectionCloneAlg::m_outName
private

Output tuple name.

Definition at line 121 of file CollectionCloneAlg.cpp.

Gaudi::Property<std::string> CollectionCloneAlg::m_output {this, "Output", {}, "output specification"}
private

Definition at line 114 of file CollectionCloneAlg.cpp.

std::string CollectionCloneAlg::m_rootName
private

Name of the root leaf (obtained at initialize)

Definition at line 119 of file CollectionCloneAlg.cpp.

std::string CollectionCloneAlg::m_selectorName
private

Selector factory.

Definition at line 125 of file CollectionCloneAlg.cpp.

Gaudi::Property<std::string> CollectionCloneAlg::m_tupleSvc {this, "EvtTupleSvc", "EvtTupleSvc", "name of the data provider service"}
private

Definition at line 112 of file CollectionCloneAlg.cpp.


The documentation for this class was generated from the following file: