aboutsummaryrefslogtreecommitdiff
path: root/tools/common/Log.cpp
blob: 4371a7d0f9f58bf7afdce4f235e904fb22b9f6be (plain) (blame)
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#include "Log.h"

#include "PsString.h"

#include <iomanip>
#include <stdarg.h>
#include <stdio.h>

///////////////////////////////////////////////////////////////////////////

namespace Nv
{
namespace Blast
{

void fLogf(const char* format, ...)
{
	char    buf[4096], *p = buf;
	va_list args;
	int     n;

	va_start(args, format);
	//n = _vsnprintf(p, sizeof buf - 3, format, args);
	n = vsprintf_s(p, sizeof(buf)-3, format, args);
	va_end(args);

	p += (n < 0) ? sizeof buf - 3 : n;

	while (p > buf  &&  isspace((unsigned char)p[-1]))
	{
		*--p = '\0';
	}

	*p++ = '\r';
	*p++ = '\n';
	*p   = '\0';

	fLog(buf, Log::TYPE_INFO);
}


//////////////////////////////////////////////////////////////////////////////

void Log::flushDeferredMessages()
{
	if (mDeferredMessages.size() == 0) return;

	std::cout << std::endl;
	for (std::vector<std::string>::iterator it = mDeferredMessages.begin(); it != mDeferredMessages.end(); ++it)
	{
		log(*it, mMinVerbosity);
	}
	mDeferredMessages.clear();
}



} // namespace Blast
} // namespace Nv