icinga2/lib/base/context.hpp

55 lines
995 B
C++
Raw Normal View History

/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
#ifndef CONTEXT_H
#define CONTEXT_H
2014-05-25 16:23:35 +02:00
#include "base/i2-base.hpp"
#include "base/string.hpp"
#include <functional>
#include <vector>
namespace icinga
{
2017-12-31 07:22:16 +01:00
class ContextTrace
{
public:
ContextTrace();
void Print(std::ostream& fp) const;
size_t GetLength() const;
private:
std::vector<String> m_Frames;
};
2017-12-31 07:22:16 +01:00
std::ostream& operator<<(std::ostream& stream, const ContextTrace& trace);
/**
* A context frame.
*
* @ingroup base
*/
2017-12-31 07:22:16 +01:00
class ContextFrame
{
public:
ContextFrame(std::function<void(std::ostream&)> message);
~ContextFrame();
private:
static std::vector<std::function<void(std::ostream&)>>& GetFrames();
friend class ContextTrace;
};
/* The currentContextFrame variable has to be volatile in order to prevent
* the compiler from optimizing it away. */
#define CONTEXT(message) volatile icinga::ContextFrame currentContextFrame ([&](std::ostream& _CONTEXT_stream) { \
_CONTEXT_stream << message; \
})
}
#endif /* CONTEXT_H */