// AUTOGENERATED COPYRIGHT HEADER START // Copyright (C) 2020-2023 Michael Fabian 'Xaymar' Dirks // AUTOGENERATED COPYRIGHT HEADER END #pragma once #include "warning-disable.hpp" #include #include #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