46 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
| // AUTOGENERATED COPYRIGHT HEADER START
 | |
| // Copyright (C) 2020-2023 Michael Fabian 'Xaymar' Dirks <info@xaymar.com>
 | |
| // AUTOGENERATED COPYRIGHT HEADER END
 | |
| 
 | |
| #pragma once
 | |
| #include "warning-disable.hpp"
 | |
| #include <cinttypes>
 | |
| #include <cstdint>
 | |
| #include "warning-enable.hpp"
 | |
| 
 | |
| #define P_LOG(...) streamfx::util::logging::log(__VA_ARGS__);
 | |
| #define P_LOG_ERROR(...) P_LOG(streamfx::util::logging::level::LEVEL_ERROR, __VA_ARGS__)
 | |
| #define P_LOG_WARN(...) P_LOG(streamfx::util::logging::level::LEVEL_WARN, __VA_ARGS__)
 | |
| #define P_LOG_INFO(...) P_LOG(streamfx::util::logging::level::LEVEL_INFO, __VA_ARGS__)
 | |
| #ifdef _DEBUG
 | |
| #define P_LOG_DEBUG(...) P_LOG(streamfx::util::logging::level::LEVEL_DEBUG, __VA_ARGS__)
 | |
| #else
 | |
| #define P_LOG_DEBUG(...)
 | |
| #endif
 | |
| 
 | |
| // Function/Class/Struct Name
 | |
| #ifdef _MSC_VER
 | |
| // Microsoft Visual Studio
 | |
| #define __FUNCTION_SIG__ __FUNCSIG__
 | |
| #define __FUNCTION_NAME__ __func__
 | |
| #elif defined(__GNUC__) || defined(__MINGW32__)
 | |
| // GCC and MinGW
 | |
| #define __FUNCTION_SIG__ __PRETTY_FUNCTION__
 | |
| #define __FUNCTION_NAME__ __func__
 | |
| #else
 | |
| // Any other compiler
 | |
| #define __FUNCTION_SIG__ __func__
 | |
| #define __FUNCTION_NAME__ __func__
 | |
| #endif
 | |
| 
 | |
| namespace streamfx::util::logging {
 | |
| 	enum class level {
 | |
| 		LEVEL_DEBUG, // Debug information, which is not necessary to know at runtime.
 | |
| 		LEVEL_INFO,  // Runtime information, which may or may not be needed for support.
 | |
| 		LEVEL_WARN,  // Warnings, which should be respected and fixed.
 | |
| 		LEVEL_ERROR, // Errors that must be fixed.
 | |
| 	};
 | |
| 
 | |
| 	void log(level lvl, const char* format, ...);
 | |
| } // namespace streamfx::util::logging
 |