#include "stdafx.h"

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


void Log(const char *file, int line, const char *fmt, ...)
{


	va_list vararg;
	const char *file_tmp;
	char str[1024];
	char buf[1024];

	file_tmp = strrchr(file, '\\');
	if (file_tmp == nullptr)
		file_tmp = file;
	else
		file_tmp++;

	va_start(vararg, fmt);
	mir_vsnprintf(str, _countof(str), fmt, vararg);
	va_end(vararg);
	{
		char * tmp = str;
		while (*tmp != '\0')
		{
			if (*tmp == '\n') *tmp = ' ';
			tmp++;
		}
	}
	mir_snprintf(buf, "clist_modern:[%u - %u]: %s \t\t(%s Ln %d)\n", GetCurrentThreadId(), GetTickCount(), str, file_tmp, line);
#ifdef _FILELOG_
	{
		FILE *fp;
		fp = fopen(_FILELOG_,"at");	
		fprintf(fp,buf);
		fclose(fp);
	}
#else
	OutputDebugStringA(buf);
#endif
}