#include "logfile.h" #include "pstring.h" #include #include #ifdef _DEBUG static bool log_enable = true; #else static bool log_enable = false; #endif void log_Enable(bool enable) { log_enable = true; } void log_Disable() { log_enable = false; } logfile::logfile() { fp = NULL; } logfile::~logfile() { end(); } // restarts the logfile (opens a new one.) void logfile::start(const char *fname, const char *longname) { if (log_enable) { try { fp = (FILE *)fopen(fname, "wt"); logfile::printf("%s\n", longname); } catch (...) { fp = NULL; } } } void logfile::end() { if (fp) { try { fclose((FILE *)fp); fp = NULL; } catch (...) { fp = NULL; } } } void logfile::printf(const char *fmt, ...) { if (fp && fmt) { char msg[256]; va_list arglist; va_start(arglist, fmt); Pvsprintf(msg, sizeof(msg), fmt, arglist); va_end(arglist); logfile::puts(msg); } } void logfile::puts(const char *msg) { if (fp && msg) { try { fputs(msg, (FILE *)fp); } catch (...) { end(); } } } void logfile::update() { if (fp) { try { fflush((FILE *)fp); } catch (...) { end(); } } }