The Gaudi Framework  v29r0 (ff2e7097)
IssueLogger.h
Go to the documentation of this file.
1 #ifndef GAUDISVC_ISSUELOGGER_H
2 #define GAUDISVC_ISSUELOGGER_H
3 
6 #include "GaudiKernel/Property.h"
7 #include "GaudiKernel/Service.h"
8 #include "StreamLogger.h"
9 #include <map>
10 #include <string>
11 #include <vector>
12 
13 class IssueLogger : public extends<Service, IIssueLogger>
14 {
15 public:
16  IssueLogger( const std::string& name, ISvcLocator* svc );
17  ~IssueLogger() override = default;
18 
19  StatusCode initialize() override;
20  StatusCode reinitialize() override;
21  StatusCode finalize() override;
22 
23  void report( IssueSeverity::Level level, const std::string& msg, const std::string& origin ) override;
24  void report( const IssueSeverity& err ) override;
25 
26 private:
28  Gaudi::Property<std::string> m_reportLevelS{this, "ReportLevel", "WARNING"};
29  Gaudi::Property<std::string> m_traceLevelS{this, "TracebackLevel", "ERROR"};
30  Gaudi::Property<bool> m_showTime{this, "ShowTime", false};
31 
33 
34  class logger_t final
35  {
37  void ( StreamLogger::*m_fun )( const std::string& ) = nullptr;
38 
39  public:
40  logger_t() = default;
41  logger_t( StreamLogger* logger, void ( StreamLogger::*fun )( const std::string& ) ) : m_logger{logger}, m_fun{fun}
42  {
43  }
44  void operator()( const std::string& s ) const { ( m_logger.get()->*m_fun )( s ); }
45  const std::string& name() const { return m_logger->name(); }
46  explicit operator bool() const { return bool( m_logger ); }
47  void reset() { m_logger.reset(); }
48  };
50 
51  StatusCode connect( const std::string& );
52  void setupDefaultLogger();
55 };
56 
57 #endif
void(StreamLogger::* m_fun)(const std::string &)
Definition: IssueLogger.h:37
MsgStream & msg() const
shortcut for the method msgStream(MSG::INFO)
StatusCode connect(const std::string &)
Definition: IssueLogger.cpp:98
The ISvcLocator is the interface implemented by the Service Factory in the Application Manager to loc...
Definition: ISvcLocator.h:25
const std::string & name() const override
Retrieve name of the service.
Definition: Service.cpp:289
Implementation of property with value of concrete type.
Definition: Property.h:319
void setupStreams(Gaudi::Details::PropertyBase &prop)
StatusCode finalize() override
Definition: IssueLogger.cpp:88
~IssueLogger() override=default
void setupLevels(Gaudi::Details::PropertyBase &prop)
class MergingTransformer< Out(const vector_of_const_< In > void
IssueSeverity::Level m_reportLevel
Definition: IssueLogger.h:32
std::unique_ptr< StreamLogger > m_logger
Definition: IssueLogger.h:36
MsgStream & err() const
shortcut for the method msgStream(MSG::ERROR)
void operator()(const std::string &s) const
Definition: IssueLogger.h:44
const std::string & name() const
Definition: StreamLogger.h:18
GAUDIPS_API Logger & logger()
Return the current logger instance.
STL class.
void setupDefaultLogger()
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:28
Gaudi::Property< bool > m_showTime
Definition: IssueLogger.h:30
T reset(T...args)
PropertyBase base class allowing PropertyBase* collections to be "homogeneous".
Definition: Property.h:32
StatusCode reinitialize() override
Definition: IssueLogger.cpp:79
T get(T...args)
const std::string & name() const
Definition: IssueLogger.h:45
std::array< logger_t, IssueSeverity::NUM_LEVELS > m_log
Definition: IssueLogger.h:49
Base class used to extend a class implementing other interfaces.
Definition: extends.h:10
StatusCode initialize() override
Definition: IssueLogger.cpp:67
double fun(const std::vector< double > &x)
Definition: PFuncTest.cpp:26
logger_t(StreamLogger *logger, void(StreamLogger::*fun)(const std::string &))
Definition: IssueLogger.h:41
Gaudi::Property< std::vector< std::string > > m_outputfile
Definition: IssueLogger.h:27
string s
Definition: gaudirun.py:253
STL class.
Gaudi::Property< std::string > m_traceLevelS
Definition: IssueLogger.h:29
IssueSeverity::Level m_traceLevel
Definition: IssueLogger.h:32
void report(IssueSeverity::Level level, const std::string &msg, const std::string &origin) override
Gaudi::Property< std::string > m_reportLevelS
Definition: IssueLogger.h:28
IssueLogger(const std::string &name, ISvcLocator *svc)
Definition: IssueLogger.cpp:54