summaryrefslogtreecommitdiff
path: root/protocols/CurrencyRates/src/Log.cpp
blob: c769f1a98d1dd6d5597f7c86e72264fdaf1ed131 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include "StdAfx.h"

namespace
{
	mir_cs g_Mutex;

	tstring get_log_file_name()
	{
		return CreateFilePath(L"CurrencyRates.log");
	}

	bool is_log_enabled()
	{
#ifdef _DEBUG
		return true;
#else
		return (1 == db_get_b(0, CURRENCYRATES_MODULE_NAME, DB_STR_ENABLE_LOG, false));
#endif
	}

	void do_log(const tstring& rsFileName, const tstring& rsMsg)
	{
		mir_cslock lck(g_Mutex);
		tofstream file(rsFileName.c_str(), std::ios::ate | std::ios::app);
		if (file.good())
		{
			wchar_t szTime[20];
			_tstrtime_s(szTime);
			file << szTime << L" ================================>\n" << rsMsg << L"\n\n";
		}
	}
}

void LogIt(const tstring& rsMsg)
{
	if (is_log_enabled())
	{
		tstring sFileName = get_log_file_name();
		do_log(sFileName, rsMsg);
	}
}