26 #define ON_DEBUG if ( msgLevel( MSG::DEBUG ) ) 37 fatal() <<
"Unable to locate IDataManagerSvc interface" <<
endmsg;
55 fatal() <<
"Unable to connect to conversion service." <<
endmsg;
86 for (
const auto& i : a.second )
addItem( items, i );
162 for (
auto& j : *sel ) {
172 const std::string loc = ( j->registry() ? j->registry()->identifier() :
"UnRegistered" );
179 for (
auto& j : *sel ) {
185 const std::string loc = ( j->registry() ? j->registry()->identifier() :
"UnRegistered" );
207 if ( level < m_currentItem->depth() ) {
257 const Items& items = iAlgItems.second;
260 debug() <<
"Algorithm '" << alg->
name() <<
"' fired. Adding " << items <<
endmsg;
261 for (
const auto& i : items ) {
283 if ( !unique.
count( o ) ) {
289 m_objects.swap( tmp );
301 for (
auto& i : itms )
delete i;
321 auto sep = descriptor.
rfind(
"#" );
323 if ( sep != std::string::npos ) {
325 level = ( slevel ==
"*" ) ? 9999999 :
std::stoi( slevel );
328 size_t idx = obj_path.
find(
"/", 1 );
329 while ( idx != std::string::npos ) {
332 idx = obj_path.
find(
"/", idx + 1 );
336 const auto& item = itms.
back();
338 debug() <<
"Adding OutputStream item " << item->path() <<
" with " << item->depth() <<
" level(s)." <<
endmsg;
350 switch (::
toupper( tag[0] ) ) {
358 switch (::
toupper( tag[1] ) ) {
368 switch (::
toupper( val[0] ) ) {
370 if (::strncasecmp( val.
c_str(),
"RECREATE", 3 ) == 0 )
372 else if (::strncasecmp( val.
c_str(),
"READ", 3 ) == 0 )
405 status = ipers->getService( typ, cnvSvc );
407 fatal() <<
"Unable to locate IConversionSvc interface of database type " << typ <<
endmsg;
413 fatal() <<
"Unable to locate IConversionSvc interface (Unknown technology) " <<
endmsg 414 <<
"You either have to specify a technology name or a service name!" <<
endmsg 415 <<
"Please correct the job option \"" <<
name() <<
".Output\" !" <<
endmsg;
432 theAlgorithm =
dynamic_cast<Algorithm*
>( theIAlg.
get() );
438 fatal() <<
"Can't locate ApplicationMgr!!!" <<
endmsg;
441 if ( !theAlgorithm ) {
442 warning() <<
"Failed to decode Algorithm name " << theName <<
endmsg;
455 for (
const auto& it : theNames.value() ) {
458 if ( theAlgorithm ) {
461 theAlgorithm->addRef();
465 info() << it <<
" doesn't exist - ignored" <<
endmsg;
472 auto passed = [](
const Algorithm* alg ) {
return alg->isExecuted() && alg->filterPassed(); };
Gaudi::Property< std::vector< std::string > > m_acceptNames
Parse attribute strings allowing iteration over the various attributes.
void decodeAlgorithms(Gaudi::Property< std::vector< std::string >> &theNames, std::vector< Algorithm * > &theAlgs)
Decode specified list of Algorithms.
bool isEventAccepted() const
Test whether this event should be output.
constexpr static const auto FAILURE
void clearItems(Items &itms)
Clear item list.
virtual bool hasInput() const
Tell if the instance has been configured with input items or not.
Gaudi::Property< std::vector< std::string > > m_vetoNames
IDataSelector m_objects
Collection of objects being selected.
StatusCode finalize() override
Terminate OutputStream.
const std::string & name() const override
The identifying name of the algorithm object.
int m_events
Number of events written to this output stream.
Implementation of property with value of concrete type.
bool isExecuted() const override
Has this algorithm been executed since the last reset?
MsgStream & info() const
shortcut for the method msgStream(MSG::INFO)
virtual StatusCode addPreLoadItem(const DataStoreItem &item)=0
Add an item to the preload list.
std::string m_outputType
Output type: NEW(NEW,CREATE,WRITE,RECREATE), UPDATE)
GAUDI_API const std::string typeinfoName(const std::type_info &)
Get platform independent information about the class type.
Gaudi::Property< bool > m_verifyItems
DataStoreItem * m_currentItem
Keep track of the current item.
Gaudi::Property< std::string > m_output
Gaudi::Property< std::string > m_outputName
The IAlgManager is the interface implemented by the Algorithm Factory in the Application Manager to s...
Gaudi::Property< ItemNames > m_optItemNames
virtual StatusCode createRep(DataObject *pObject, IOpaqueAddress *&refpAddress)=0
Convert the transient object to the requested representation.
std::vector< Algorithm * > m_requireAlgs
Vector of Algorithms that this stream requires.
IDataSelector * selectedObjects()
Return the list of selected objects.
SmartIF< IDataProviderSvc > m_pDataProvider
Keep reference to the data provider service.
Description of the DataStoreItem class.
Gaudi::Property< bool > m_doPreLoad
virtual StatusCode traverseSubTree(boost::string_ref sub_tree_path, IDataStoreAgent *pAgent)=0
Analyse by traversing all data objects below the sub tree identified by its full path name...
const std::string & path() const
Accessor: Retrieve load path.
A small to stream Data I/O.
std::vector< Algorithm * > m_acceptAlgs
Vector of Algorithms that this stream accepts.
#define DECLARE_COMPONENT(type)
virtual bool collect(IRegistry *dir, int level)
Store agent's classback.
TYPE * get() const
Get interface pointer.
DataStoreItem * findItem(const std::string &path)
Find single item identified by its path (exact match)
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
virtual StatusCode writeObjects()
Select the different objects and write them to file.
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
SmartIF< IConversionSvc > m_pConversionSvc
Keep reference to the data conversion service.
virtual StatusCode connectOutput(const std::string &outputFile)=0
Connect the output file to the service.
StatusCode initialize() override
Initialize OutputStream.
virtual void fireIncident(const Incident &incident)=0
Fire an Incident.
virtual StatusCode connectConversionSvc()
MsgStream & warning() const
shortcut for the method msgStream(MSG::WARNING)
AlgDependentItems m_algDependentItems
Items to be saved for specific algorithms.
virtual StatusCode commitOutput(const std::string &outputFile, bool do_commit)=0
Commit pending output.
Gaudi::Property< std::vector< std::string > > m_requireNames
This class is used for returning status codes from appropriate routines.
Items m_itemList
Vector of items to be saved to this stream.
void addItem(Items &itms, const std::string &descriptor)
Add item to output streamer list.
The IRegistry represents the entry door to the environment any data object residing in a transient da...
Gaudi::Property< AlgDependentItemNames > m_algDependentItemList
SmartIF< IDataManagerSvc > m_pDataManager
Keep reference to the data manager service.
virtual StatusCode retrieveObject(IRegistry *pDirectory, boost::string_ref path, DataObject *&pObject)=0
Retrieve object identified by its directory entry.
void clearSelection()
Clear list of selected objects.
SmartIF< IIncidentSvc > m_incidentSvc
Reference to the incident service.
SmartIF< ISvcLocator > & serviceLocator() const override
The standard service locator.
constexpr static const auto SUCCESS
virtual DataObject * object() const =0
Retrieve object behind the link.
StatusCode execute() override
Working entry point.
Base class from which all concrete algorithm classes should be derived.
Gaudi::Property< std::string > m_storeName
MsgStream & debug() const
shortcut for the method msgStream(MSG::DEBUG)
virtual void setAddress(IOpaqueAddress *pAddress)=0
Set/Update Opaque storage address.
const StatusCode & ignore() const
Ignore/check StatusCode.
bool filterPassed() const override
Did this algorithm pass or fail its filter criterion for the last event?
Base class for all Incidents (computing events).
Gaudi::Property< bool > m_doPreLoadOpt
Algorithm * decodeAlgorithm(const std::string &theName)
Decode a single algorithm name.
Data persistency service interface.
void reset(TYPE *ptr=nullptr)
Set the internal pointer to the passed one disposing of the old one.
StatusCode collectFromSubTree(DataObject *)
Opaque address interface definition.
MsgStream & fatal() const
shortcut for the method msgStream(MSG::FATAL)
Gaudi::Property< std::string > m_persName
std::vector< Algorithm * > m_vetoAlgs
Vector of Algorithms that this stream is vetoed by.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
A DataObject is the base class of any identifiable object on any data store.
Gaudi::Property< ItemNames > m_itemNames
virtual StatusCode collectObjects()
Collect all objects to be written to the output stream.
virtual StatusCode fillRepRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Resolve the references of the converted object.
void toupper(std::string &s)
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
bool m_fireIncidents
should I fire incidents for writing opening/closing etc? in the baseclass, always fire the incidents ...
Items m_optItemList
Vector of optional items to be saved to this stream.