8#ifndef DBE_MESSENGER_H_
9#define DBE_MESSENGER_H_
17#include <unordered_set>
22#define t_messenger dbe::interface::messenger::qt
26#define t_msghandler ::lutils::program::msghandler<t_messenger>
29#define MESSAGE(...) VA_SELECT(MESSAGE,__VA_ARGS__)
33#ifndef MESSAGE_STATICS
34#define MESSAGE_STATICS(msg) \
35 static t_msghandler::t_str sms(msg); \
36 static t_msghandler::t_str smsr("\n\nReason: "); \
40#define MESSAGE_3(level,msg,reason) \
42 MESSAGE_STATICS(msg) \
43 t_msghandler::ref().message( level, sms + smsr + MSEP +reason); \
46#define MESSAGE_4(level,msg,reason,_1) \
48 MESSAGE_STATICS(msg) \
49 t_msghandler::ref().message( level, sms + MSEP + _1 + smsr + MSEP + reason); \
52#define MESSAGE_5(level,msg,reason,_1,_2) \
54 MESSAGE_STATICS(msg) \
55 t_msghandler::ref().message( level, \
56 sms + MSEP + _1 + MSEP + _2 + smsr +MSEP+ reason); \
59#define MESSAGE_6(level,msg,reason,_1,_2,_3) \
61 MESSAGE_STATICS(msg) \
62 t_msghandler::ref().message( level, \
63 sms + MSEP + _1 + MSEP + _2 + MSEP + _3 + smsr +MSEP + reason); \
66#define MESSAGE_7(level,msg,reason,_1,_2,_3,_4) \
68 MESSAGE_STATICS(msg) \
69 t_msghandler::ref().message( level,\
70 sms + MSEP+_1 +MSEP+ _2 + MSEP +_3 + MSEP + _4 + smsr + MSEP + reason); \
73#define MSGHNDL_DEBUG_LEVEL t_messenger::debug
74#define MSGHNDL_INFO_LEVEL t_messenger::info
75#define MSGHNDL_NOTE_LEVEL t_messenger::note
76#define MSGHNDL_WARN_LEVEL t_messenger::warn
77#define MSGHNDL_ERROR_LEVEL t_messenger::error
78#define MSGHNDL_FAIL_LEVEL t_messenger::fail
80#define WARN(...) VA_SELECT(WARN,__VA_ARGS__)
82#define WARN_2(msg,reason) MESSAGE_3(MSGHNDL_WARN_LEVEL,msg,reason)
83#define WARN_3(msg,reason,var) MESSAGE_4(MSGHNDL_WARN_LEVEL,msg,reason,var)
84#define WARN_4(msg,reason,var,_4) MESSAGE_5(MSGHNDL_WARN_LEVEL,msg,reason,var,_4)
85#define WARN_5(msg,reason,var,_4,_5) MESSAGE_6(MSGHNDL_WARN_LEVEL,msg,reason,var,_4,_5)
86#define WARN_6(msg,reason,var,_4,_5,_6) MESSAGE_7(MSGHNDL_WARN_LEVEL,msg,reason,var,_4,_5,_6)
88#define ERROR(...) VA_SELECT(ERROR,__VA_ARGS__)
90#define ERROR_2(msg,reason) MESSAGE_3(MSGHNDL_ERROR_LEVEL,msg,reason)
91#define ERROR_3(msg,reason,var) MESSAGE_4(MSGHNDL_ERROR_LEVEL,msg,reason,var)
92#define ERROR_4(msg,reason,var,_4) MESSAGE_5(MSGHNDL_ERROR_LEVEL,msg,reason,var,_4)
93#define ERROR_5(msg,reason,var,_4,_5) MESSAGE_6(MSGHNDL_ERROR_LEVEL,msg,reason,var,_4,_5)
94#define ERROR_6(msg,reason,var,_4,_5,_6) MESSAGE_7(MSGHNDL_ERROR_LEVEL,msg,reason,var,_4,_5,_6)
96#define INFO(...) VA_SELECT(INFO,__VA_ARGS__)
98#define INFO_2(msg,reason) MESSAGE_3(MSGHNDL_INFO_LEVEL,msg,reason)
99#define INFO_3(msg,reason,var) MESSAGE_4(MSGHNDL_INFO_LEVEL,msg,reason,var)
100#define INFO_4(msg,reason,var,_4) MESSAGE_5(MSGHNDL_INFO_LEVEL,msg,reason,var,_4)
101#define INFO_5(msg,reason,var,_4,_5) MESSAGE_6(MSGHNDL_INFO_LEVEL,msg,reason,var,_4,_5)
103#define NOTE(...) VA_SELECT(NOTE,__VA_ARGS__)
105#define NOTE_2(msg,reason) MESSAGE_3(MSGHNDL_NOTE_LEVEL,msg,reason)
106#define NOTE_3(msg,reason,var) MESSAGE_4(MSGHNDL_NOTE_LEVEL,msg,reason,var)
107#define NOTE_4(msg,reason,var,_4) MESSAGE_5(MSGHNDL_NOTE_LEVEL,msg,reason,var,_4)
108#define NOTE_5(msg,reason,var,_4,_5) MESSAGE_6(MSGHNDL_NOTE_LEVEL,msg,reason,var,_4,_5)
111#ifdef MSGHNDL_FULLDEBUG_INFORMATION
112#define FULLDEBUG(...) VA_SELECT(DEBUG,__VA_ARGS__)
114#define FULLDEBUG(...)
117#ifdef MSGHNDL_FULLDEBUG_INFORMATION
118#define DEBUG(...) VA_SELECT(DEBUG,__VA_ARGS__)
123#define DEBUG_2(msg,reason) MESSAGE_3(MSGHNDL_DEBUG_LEVEL,msg,reason)
124#define DEBUG_3(msg,reason,var) MESSAGE_4(MSGHNDL_DEBUG_LEVEL,msg,reason,var)
125#define DEBUG_4(msg,reason,var,_4) MESSAGE_5(MSGHNDL_DEBUG_LEVEL,msg,reason,var,_4)
126#define DEBUG_5(msg,reason,var,_4,_5) MESSAGE_6(MSGHNDL_DEBUG_LEVEL,msg,reason,var,_4,_5)
128#define FAIL(...) VA_SELECT(FAIL,__VA_ARGS__)
130#define FAIL_2(msg,reason) MESSAGE_3(MSGHNDL_FAIL_LEVEL,msg,reason)
131#define FAIL_3(msg,reason,var) MESSAGE_4(MSGHNDL_FAIL_LEVEL,msg,reason,var)
132#define FAIL_4(msg,reason,var,_4) MESSAGE_5(MSGHNDL_FAIL_LEVEL,msg,reason,var,_4)
133#define FAIL_5(msg,reason,var,_4,_5) MESSAGE_6(MSGHNDL_FAIL_LEVEL,msg,reason,var,_4,_5)
199 static std::unique_ptr<batch_guard>
batchmode();
DEFAULT_POST typedef std::string t_str
static std::atomic< bool > m_batch_mode
static t_batches m_batches
static std::unique_ptr< batch_guard > batchmode()
std::unordered_multiset< t_str > t_message_bucket
static post_ret_type merge_post(t_str const &m, t_str const &l)
static std::mutex m_block
std::array< t_message_bucket, static_cast< int >(messages::sizeme) > t_batches
static post_ret_type direct_post(t_str const &m, t_str const &l)
static HAS_POST post_ret_type post(t_str const &, t_str const &)
qt operator=(qt const &)=delete
std::vector< t_str > t_levels
static t_levels const all_levels