55 lines
1.7 KiB
C
55 lines
1.7 KiB
C
|
#pragma once
|
||
|
|
||
|
#ifndef _WA_LOGGER_HEADER
|
||
|
#define _WA_LOGGER_HEADER
|
||
|
|
||
|
#include <iostream>
|
||
|
|
||
|
#include "spdlog/spdlog.h"
|
||
|
#include "spdlog/async.h" //support for async logging.
|
||
|
#include "spdlog/sinks/basic_file_sink.h"
|
||
|
|
||
|
#include "WAT.h"
|
||
|
|
||
|
#include "..\Winamp\buildType.h"
|
||
|
|
||
|
std::shared_ptr<spdlog::logger> init_log()
|
||
|
{
|
||
|
std::string l_app_version( STR_WINAMP_FILEVER );
|
||
|
wa::strings::replaceAll( l_app_version, ",", "." );
|
||
|
|
||
|
std::string l_app_data_folder( getenv( "APPDATA" ) );
|
||
|
l_app_data_folder.append( "\\Winamp\\winamp.log" );
|
||
|
|
||
|
auto my_wa_logger = spdlog::basic_logger_mt( l_app_version.c_str(), l_app_data_folder.c_str());
|
||
|
|
||
|
spdlog::set_default_logger( my_wa_logger );
|
||
|
spdlog::set_level( spdlog::level::trace );
|
||
|
|
||
|
return my_wa_logger;
|
||
|
}
|
||
|
|
||
|
|
||
|
static std::shared_ptr<spdlog::logger> wa_logger = init_log();
|
||
|
|
||
|
|
||
|
#ifdef _DEBUG
|
||
|
#define LOG_DEBUG(text) spdlog::debug( wa::strings::convert::to_string( text ) );
|
||
|
#define LOG_INFO(text) spdlog::info( wa::strings::convert::to_string( text ) );
|
||
|
#define LOG_WARN(text) spdlog::warn( wa::strings::convert::to_string( text ) );
|
||
|
#define LOG_ERROR(text) spdlog::error( wa::strings::convert::to_string( text ) );
|
||
|
#define LOG_CRITICAL(text) spdlog::critical( wa::strings::convert::to_string( text ) );
|
||
|
#else
|
||
|
#define LOG_DEBUG(text) /* nop */
|
||
|
#define LOG_INFO(text) /* nop */
|
||
|
#define LOG_WARN(text) /* nop */
|
||
|
#define LOG_ERROR(text) spdlog::error( wa::strings::convert::to_string( text ) );
|
||
|
#define LOG_CRITICAL(text) spdlog::critical( wa::strings::convert::to_string( text ) );
|
||
|
#endif // _DEBUG
|
||
|
|
||
|
|
||
|
wchar_t _log_message_w[ DEFAULT_STR_BUFFER_SIZE ];
|
||
|
char _log_message_a[ DEFAULT_STR_BUFFER_SIZE ];
|
||
|
std::string _log_message;
|
||
|
|
||
|
#endif // !_WA_LOGGER_HEADER
|