16 #include <sys/types.h> 90 void sign_on (
const string& func_name_);
118 int log_open (
const std::string& logsvr_,
const char* logfname_,
136 #define LOGGER ASSA::Logger::get_instance() 270 #if defined (ASSA_NLOGGING) 271 # define DL(X) do {} while (0) 282 #if defined (ASSA_NLOGGING) 283 # define EL(X) do {} while (0) 288 LOGGER->log_msg(ASSA::ASSAERR,"errno: %d \"%s\"\n", errno, strerror(errno)); \ 307 LOGGER->set_app_name (appname_);
321 u_long maxsize_ = 10485760)
323 return LOGGER->log_open (logfname_, groups_, maxsize_);
329 return LOGGER->log_open (groups_);
345 const char* logfname_,
348 u_long maxsize_ = 10485760)
350 int ret =
LOGGER->log_open (logsvraddr_, logfname_, groups_,
397 : m_fname (fn_), m_mask (mask_)
429 #define trace(s) ASSA::DiagnosticContext tRaCeR(s); 437 #define trace_with_mask(s, m) ASSA::DiagnosticContext tRaCeR(s, m);
void disable_groups(u_long g_)
All messages: library + application.
void set_timezone(int zone)
0 - GMT, 1 - LOCAL
void enable_groups(u_long groups_)
Enable logging for groups_.
#define LOGGER
A shortcut to locate a singleton object of class Logger.
void enable_group(Group g_)
Enable logging for group g_.
int open_log_server(const std::string &logsvraddr_, const char *logfname_, Reactor *reactor_, u_long groups_=ASSA::ALL, u_long maxsize_=10485760)
Open connection with and write log message to the log server.
std::string m_app_name
Stack of all contexts.
void disable_groups(u_long groups_)
Disable logging for groups_.
void enable_timestamp(void)
Add optional timezone: GMT vs. Local.
void disable_timestamp(void)
int log_func(u_long g_, marker_t type_)
void disable_all_groups(void)
bool timestamp_enabled(void) const
void enable_all_groups(void)
Class DiagnosticContext tracks who deep a function is in the calling stack.
void set_app_name(const std::string &appname_)
Set application name.
void enable_groups(u_long g_)
void disable_timestamp(void)
Singleton template class allows to turn any new or existing class T into Singleton Pattern...
void enable_timestamp(void)
void enable_all_groups(void)
void disable_group(Group g_)
Disable logging for group g_.
int open_log_file(const char *logfname_, u_long groups_=ALL, u_long maxsize_=10485760)
Open log file.
DiagnosticContext(const char *fn_, u_long mask_=TRACE)
bool group_enabled(Group g_) const
int open_log_stdout(u_long groups_=ALL)
Write log message to standard output.
int log_open(u_long groups_)
Write log messages to standard output.
virtual void log_resync(void)
void disable_group(Group g_)
A Hex/Ascii memory dump of similar to od(1) UNIX utility.
bool timestamp_enabled(void) const
void sign_on(const string &func_name_)
Group
Bit mask used to mask out log messages.
int log_msg(u_long g_, const char *fmt_,...)
Here is an interesting twist introduced by remote logging server:
void set_timezone(int zone_)
void disable_all_groups(void)
bool group_enabled(Group g_) const
void enable_group(Group g_)
void set_gmt_timezone(void)
Set timezone to GMT.
stack< string > m_context
Logger implementation.