1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
#ifndef CONTEXT_H
#define CONTEXT_H
#include "base/i2-base.hpp"
#include "base/string.hpp"
#include <functional>
#include <vector>
namespace icinga
{
class ContextTrace
{
public:
ContextTrace();
void Print(std::ostream& fp) const;
size_t GetLength() const;
private:
std::vector<String> m_Frames;
};
std::ostream& operator<<(std::ostream& stream, const ContextTrace& trace);
/**
* A context frame.
*
* @ingroup base
*/
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 */
|