2008-12-10 05:42:49 +01:00
|
|
|
/*
|
2010-02-28 01:08:10 +01:00
|
|
|
* This file is a part of Winix
|
2008-12-10 05:42:49 +01:00
|
|
|
* and is not publicly distributed
|
|
|
|
*
|
2012-01-16 11:12:38 +01:00
|
|
|
* Copyright (c) 2008-2012, Tomasz Sowa
|
2008-12-10 05:42:49 +01:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2011-01-23 15:15:30 +01:00
|
|
|
#ifndef headerfile_winix_core_log
|
|
|
|
#define headerfile_winix_core_log
|
2008-12-10 05:42:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
#include <sstream>
|
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <string>
|
2010-11-21 01:19:17 +01:00
|
|
|
#include "textstream.h"
|
2011-06-19 22:59:58 +02:00
|
|
|
#include "logmanipulators.h"
|
2012-07-25 12:28:41 +02:00
|
|
|
#include "textstream/textstream.h"
|
2008-12-10 05:42:49 +01:00
|
|
|
|
|
|
|
|
2012-09-06 19:50:14 +02:00
|
|
|
class TimeZones;
|
|
|
|
|
|
|
|
|
2008-12-30 02:05:03 +01:00
|
|
|
|
2008-12-10 05:42:49 +01:00
|
|
|
class Log
|
|
|
|
{
|
|
|
|
public:
|
2011-01-05 22:24:11 +01:00
|
|
|
|
2008-12-10 05:42:49 +01:00
|
|
|
Log();
|
2011-01-05 22:24:11 +01:00
|
|
|
~Log();
|
|
|
|
|
2012-09-06 19:50:14 +02:00
|
|
|
void SetTimeZones(TimeZones * ptime_zones);
|
2011-01-05 22:24:11 +01:00
|
|
|
void Init(int log_level_, bool save_each_line_, const std::string & log_file_, bool log_std, int log_max_requests);
|
2008-12-11 03:46:16 +01:00
|
|
|
|
2010-05-04 23:58:22 +02:00
|
|
|
Log & operator<<(const void * s);
|
2010-11-21 01:19:17 +01:00
|
|
|
Log & operator<<(const char * s);
|
2009-11-17 02:04:01 +01:00
|
|
|
Log & operator<<(const std::string * s);
|
2008-12-10 05:42:49 +01:00
|
|
|
Log & operator<<(const std::string & s);
|
2010-11-21 01:19:17 +01:00
|
|
|
Log & operator<<(const wchar_t * s);
|
|
|
|
Log & operator<<(const std::wstring * s);
|
|
|
|
Log & operator<<(const std::wstring & s);
|
2008-12-10 05:42:49 +01:00
|
|
|
Log & operator<<(int s);
|
|
|
|
Log & operator<<(long s);
|
|
|
|
Log & operator<<(char s);
|
2011-06-07 00:47:34 +02:00
|
|
|
Log & operator<<(wchar_t s);
|
2008-12-10 05:42:49 +01:00
|
|
|
Log & operator<<(size_t s);
|
2009-09-22 01:05:05 +02:00
|
|
|
Log & operator<<(double s);
|
2012-01-16 11:12:38 +01:00
|
|
|
Log & operator<<(const PT::Space & space);
|
2011-06-19 22:59:58 +02:00
|
|
|
Log & operator<<(LogManipulators m);
|
2012-05-19 17:14:35 +02:00
|
|
|
Log & operator<<(const PT::Date & date);
|
2011-06-07 00:47:34 +02:00
|
|
|
|
2012-09-06 19:50:14 +02:00
|
|
|
void PrintDate(const PT::Date & date, size_t time_zone_id);
|
|
|
|
|
2012-07-25 12:28:41 +02:00
|
|
|
template<typename char_type, size_t stack_size, size_t heap_block_size>
|
|
|
|
Log & operator<<(const PT::TextStreamBase<char_type, stack_size, heap_block_size> & buf);
|
|
|
|
|
2012-01-16 11:12:38 +01:00
|
|
|
|
2011-06-07 00:47:34 +02:00
|
|
|
template<class StringType>
|
|
|
|
void LogString(const StringType & value, size_t max_size);
|
|
|
|
|
2012-07-31 05:29:16 +02:00
|
|
|
void LogBinary(const char * blob, size_t blob_len);
|
|
|
|
void LogBinary(const std::string & blob);
|
|
|
|
|
|
|
|
|
2010-02-12 18:05:32 +01:00
|
|
|
void SystemErr(int err);
|
2008-12-10 05:42:49 +01:00
|
|
|
void SaveLog();
|
2011-01-05 22:24:11 +01:00
|
|
|
void SaveLogAndClear();
|
2010-10-24 19:49:38 +02:00
|
|
|
|
2012-07-31 05:29:16 +02:00
|
|
|
int LogLevel();
|
|
|
|
|
|
|
|
|
2010-10-24 19:49:38 +02:00
|
|
|
private:
|
2011-01-05 22:24:11 +01:00
|
|
|
|
2012-09-06 19:50:14 +02:00
|
|
|
// time zones for printing the time in the log file
|
|
|
|
TimeZones * time_zones;
|
|
|
|
|
2011-01-05 22:24:11 +01:00
|
|
|
// buffer for the log
|
2010-11-21 01:19:17 +01:00
|
|
|
TextStream<std::wstring> buffer;
|
2011-01-05 22:24:11 +01:00
|
|
|
|
|
|
|
// log lovel from the config file
|
|
|
|
int log_level;
|
|
|
|
|
|
|
|
// current level set by a modifier (e.g. log << log3)
|
|
|
|
int current_level;
|
|
|
|
|
|
|
|
// current request for logging
|
|
|
|
// starts from zero and incremented after logendrequest modifier
|
|
|
|
int request;
|
|
|
|
|
|
|
|
// how many request to save at once
|
|
|
|
int max_requests;
|
|
|
|
|
|
|
|
// file log
|
2010-10-24 19:49:38 +02:00
|
|
|
std::string log_file;
|
|
|
|
std::ofstream file;
|
2011-01-05 22:24:11 +01:00
|
|
|
|
|
|
|
// logging to stdout
|
|
|
|
bool log_stdout;
|
|
|
|
|
|
|
|
// how many lines there are in the buffer
|
2010-10-24 19:49:38 +02:00
|
|
|
int lines;
|
2011-01-05 22:24:11 +01:00
|
|
|
|
|
|
|
// is the config file already open
|
2010-10-24 19:49:38 +02:00
|
|
|
bool log_file_open;
|
|
|
|
|
2011-01-05 22:24:11 +01:00
|
|
|
// how many lines can be in the config buffer
|
|
|
|
// default: 5000
|
|
|
|
int max_lines;
|
|
|
|
|
|
|
|
// whether to save each line (for debug)
|
|
|
|
bool save_each_line;
|
|
|
|
|
2010-10-24 19:49:38 +02:00
|
|
|
void OpenFile();
|
2012-07-31 05:29:16 +02:00
|
|
|
char GetHEXdigit(unsigned char c);
|
|
|
|
void ToHEX(char * buf, unsigned char c);
|
2010-10-24 19:49:38 +02:00
|
|
|
|
2008-12-10 05:42:49 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-06-07 00:47:34 +02:00
|
|
|
template<class StringType>
|
|
|
|
void Log::LogString(const StringType & value, size_t max_size)
|
|
|
|
{
|
|
|
|
size_t min_size = value.size() < max_size ? value.size() : max_size;
|
|
|
|
|
|
|
|
if( current_level <= log_level )
|
|
|
|
{
|
|
|
|
for(size_t i=0 ; i<min_size ; ++i)
|
|
|
|
{
|
|
|
|
if( value[i] < 32 )
|
|
|
|
buffer << '.';
|
|
|
|
else
|
|
|
|
buffer << value[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-07-25 12:28:41 +02:00
|
|
|
template<typename char_type, size_t stack_size, size_t heap_block_size>
|
|
|
|
Log & Log::operator<<(const PT::TextStreamBase<char_type, stack_size, heap_block_size> & buf)
|
|
|
|
{
|
2012-10-27 09:44:26 +02:00
|
|
|
if( current_level <= log_level )
|
|
|
|
buffer << buf;
|
2012-07-25 12:28:41 +02:00
|
|
|
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-12-10 05:42:49 +01:00
|
|
|
extern Log log;
|
2009-10-01 00:31:20 +02:00
|
|
|
extern Log nlog;
|
2008-12-10 05:42:49 +01:00
|
|
|
|
2011-06-19 22:59:58 +02:00
|
|
|
// for convenience, we have to use only #include "log.h" in the winix
|
|
|
|
#include "slog.h"
|
2008-12-10 05:42:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|