The Gaudi Framework  master (d98a2936)
IODataManager.h
Go to the documentation of this file.
1 /***********************************************************************************\
2 * (c) Copyright 1998-2025 CERN for the benefit of the LHCb and ATLAS collaborations *
3 * *
4 * This software is distributed under the terms of the Apache version 2 licence, *
5 * copied verbatim in the file "LICENSE". *
6 * *
7 * In applying this licence, CERN does not waive the privileges and immunities *
8 * granted to it by virtue of its status as an Intergovernmental Organization *
9 * or submit itself to any jurisdiction. *
10 \***********************************************************************************/
11 #pragma once
12 
13 // C++ include files
14 #include <map>
15 // Framework include files
16 #include <GaudiKernel/Service.h>
18 
19 class IIncidentSvc;
20 
21 /*
22  * LHCb namespace declaration
23  */
24 namespace Gaudi {
25 
26  // Forward declarations
27  class IFileCatalog;
28  class RawDataConnectionEntry;
29 
38  class IODataManager : public extends<Service, IIODataManager> {
39  protected:
40  typedef const std::string& CSTR;
41  struct Entry final {
42  std::string type;
43  IoType ioType;
45  bool keepOpen;
46  Entry( CSTR tech, bool k, IoType iot, IDataConnection* con )
47  : type( tech ), ioType( iot ), connection( con ), keepOpen( k ) {}
48  };
49  typedef std::map<std::string, Entry*> ConnectionMap;
50  typedef std::map<std::string, std::string> FidMap;
51 
52  Gaudi::Property<std::string> m_catalogSvcName{ this, "CatalogType", "Gaudi::MultiFileCatalog/FileCatalog",
53  "name of the file catalog service" };
54  Gaudi::Property<bool> m_useGFAL{ this, "UseGFAL", true, "flag for auto gfal data access" };
55  Gaudi::Property<bool> m_quarantine{ this, "QuarantineFiles", true,
56  "if unaccessible files should be quarantines in job" };
57  Gaudi::Property<int> m_ageLimit{ this, "AgeLimit", 2, "age limit" };
59  this, "DisablePFNWarning", false,
60  "if set to True, we will not report when a file is opened by its physical name" };
61 
68  StatusCode connectDataIO( int typ, IoType rw, CSTR fn, CSTR technology, bool keep, Connection* con );
71  StatusCode establishConnection( Connection* con );
72 
74 
75  public:
77  using extends::extends;
78 
80  StatusCode initialize() override;
81 
83  StatusCode finalize() override;
84 
86  StatusCode connectRead( bool keep_open, Connection* ioDesc ) override;
88  StatusCode connectWrite( Connection* con, IoType mode = Connection::CREATE, CSTR doctype = "UNKNOWN" ) override;
90  StatusCode disconnect( Connection* ioDesc ) override;
92  Connection* connection( const std::string& dsn ) const override;
94  Connections connections( const IInterface* owner ) const override;
96  StatusCode read( Connection* ioDesc, void* const data, size_t len ) override;
98  StatusCode write( Connection* con, const void* data, int len ) override;
100  long long int seek( Connection* ioDesc, long long int where, int origin ) override;
101  };
102 } // End namespace Gaudi
Gaudi::IODataManager::Entry
Definition: IODataManager.h:41
Gaudi::IODataManager::Entry::connection
IDataConnection * connection
Definition: IODataManager.h:44
Gaudi::IODataManager::m_quarantine
Gaudi::Property< bool > m_quarantine
Definition: IODataManager.h:55
Gaudi::IDataConnection
Definition: IIODataManager.h:33
Gaudi::IODataManager::connections
Connections connections(const IInterface *owner) const override
Get connection by owner instance (0=ALL)
Definition: IODataManager.cpp:87
Gaudi::IODataManager::connectRead
StatusCode connectRead(bool keep_open, Connection *ioDesc) override
Open data stream in read mode.
Definition: IODataManager.cpp:97
Gaudi::IODataManager::CSTR
const std::string & CSTR
Definition: IODataManager.h:40
Gaudi::IODataManager::m_useGFAL
Gaudi::Property< bool > m_useGFAL
Definition: IODataManager.h:54
Gaudi::IODataManager::establishConnection
StatusCode establishConnection(Connection *con)
Definition: IODataManager.cpp:208
Gaudi::IODataManager::connectWrite
StatusCode connectWrite(Connection *con, IoType mode=Connection::CREATE, CSTR doctype="UNKNOWN") override
Open data stream in write mode.
Definition: IODataManager.cpp:106
GaudiMP.FdsRegistry.msg
msg
Definition: FdsRegistry.py:19
Gaudi::IODataManager::Entry::keepOpen
bool keepOpen
Definition: IODataManager.h:45
IIODataManager.h
Gaudi::IODataManager::error
StatusCode error(CSTR msg)
Small routine to issue exceptions.
Definition: IODataManager.cpp:80
Gaudi::IODataManager::m_ageLimit
Gaudi::Property< int > m_ageLimit
Definition: IODataManager.h:57
Gaudi::IODataManager::m_connectionMap
ConnectionMap m_connectionMap
Map with I/O descriptors.
Definition: IODataManager.h:63
StatusCode
Definition: StatusCode.h:64
Gaudi::IODataManager::connection
Connection * connection(const std::string &dsn) const override
Retrieve known connection.
Definition: IODataManager.cpp:201
Gaudi::IODataManager::read
StatusCode read(Connection *ioDesc, void *const data, size_t len) override
Read raw byte buffer from input stream.
Definition: IODataManager.cpp:113
Gaudi::IODataManager::initialize
StatusCode initialize() override
IService implementation: initialize the service.
Definition: IODataManager.cpp:51
SmartIF
Definition: IConverter.h:22
Gaudi::IODataManager::finalize
StatusCode finalize() override
IService implementation: finalize the service.
Definition: IODataManager.cpp:74
Gaudi::IODataManager::m_catalogSvcName
Gaudi::Property< std::string > m_catalogSvcName
Definition: IODataManager.h:52
extends
Base class used to extend a class implementing other interfaces.
Definition: extends.h:19
Gaudi::IODataManager::write
StatusCode write(Connection *con, const void *data, int len) override
Write raw byte buffer to output stream.
Definition: IODataManager.cpp:118
Gaudi::IODataManager::m_catalog
SmartIF< IFileCatalog > m_catalog
Reference to file catalog.
Definition: IODataManager.h:65
Gaudi
This file provides a Grammar for the type Gaudi::Accumulators::Axis It allows to use that type from p...
Definition: __init__.py:1
Gaudi::IODataManager::Entry::type
std::string type
Definition: IODataManager.h:42
Gaudi::IODataManager::disconnect
StatusCode disconnect(Connection *ioDesc) override
Release data stream.
Definition: IODataManager.cpp:127
Service.h
Gaudi::IODataManager::reconnect
StatusCode reconnect(Entry *e)
Definition: IODataManager.cpp:164
Gaudi::IODataManager::seek
long long int seek(Connection *ioDesc, long long int where, int origin) override
Seek on the file described by ioDesc. Arguments as in ::seek()
Definition: IODataManager.cpp:123
Gaudi::IODataManager::m_fidMap
FidMap m_fidMap
Map of FID to PFN.
Definition: IODataManager.h:67
Io::CREATE
@ CREATE
Definition: IFileMgr.h:34
IInterface
Definition: IInterface.h:225
Gaudi::IODataManager
Definition: IODataManager.h:38
Gaudi::IODataManager::FidMap
std::map< std::string, std::string > FidMap
Definition: IODataManager.h:50
Gaudi::IODataManager::Entry::Entry
Entry(CSTR tech, bool k, IoType iot, IDataConnection *con)
Definition: IODataManager.h:46
Gaudi::IODataManager::m_disablePFNWarning
Gaudi::Property< bool > m_disablePFNWarning
Definition: IODataManager.h:58
IIncidentSvc
Definition: IIncidentSvc.h:30
Gaudi::IODataManager::ConnectionMap
std::map< std::string, Entry * > ConnectionMap
Definition: IODataManager.h:49
Gaudi::IODataManager::Entry::ioType
IoType ioType
Definition: IODataManager.h:43
Gaudi::Property< std::string >
Gaudi::IODataManager::m_incSvc
SmartIF< IIncidentSvc > m_incSvc
Definition: IODataManager.h:73
Gaudi::IODataManager::connectDataIO
StatusCode connectDataIO(int typ, IoType rw, CSTR fn, CSTR technology, bool keep, Connection *con)
Definition: IODataManager.cpp:227