#ifndef _Logger_h
#define _Logger_h
#include <fstream>
#include <string>
class Logger : public std::ofstream
{
public:
Logger();
~Logger();
std::string
currentTime();
};
#define require_noerr_with_log( LOG, MESSAGE, ERR, LABEL ) \
do \
{ \
int_least32_t localErr; \
localErr = (int_least32_t)( ERR ); \
if( localErr != 0 ) \
{ \
log << log.currentTime() << " [ERROR] " << MESSAGE << " returned " << ERR << std::endl; \
log << log.currentTime() << " [WHERE] " << "\"" << __FILE__ << "\", \"" << __FUNCTION__ << "\", line " << __LINE__ << std::endl << std::endl; \
goto LABEL; \
} \
} while( 0 )
#define require_action_with_log( LOG, X, LABEL, ACTION ) \
do \
{ \
if( !( X ) ) \
{ \
log << log.currentTime() << " [ERROR] " << # X << std::endl; \
log << log.currentTime() << " [WHERE] " << "\"" << __FILE__ << "\", \"" << __FUNCTION__ << "\", line " << __LINE__ << std::endl << std::endl; \
{ ACTION; } \
goto LABEL; \
} \
} while( 0 )
#endif