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