* -------------------------------------------------------------------------
* This file is part of the MindStudio project.
* Copyright (c) 2025 Huawei Technologies Co.,Ltd.
*
* MindStudio is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
*
* http://license.coscl.org.cn/MulanPSL2
*
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* -------------------------------------------------------------------------
*/
#pragma once
#include <string>
#include <vector>
#include "include/ErrorCode.h"
namespace MindStudioDebugger {
enum class DebuggerErrLevel {
LEVEL_NONE = -1,
LEVEL_DEBUG = 0,
LEVEL_INFO,
LEVEL_WARNING,
LEVEL_ERROR,
LEVEL_CRITICAL,
};
class ErrorInfosManager {
public:
static void LogErrorInfo(DebuggerErrLevel level, DebuggerErrno errId, const std::string& info);
static DebuggerErrLevel GetTopErrLevelInDuration();
static void SetLogThreshold(DebuggerErrLevel t) { threshold = t; }
private:
static DebuggerErrLevel topLevel;
static DebuggerErrLevel threshold;
};
inline void CleanErrorInfoCache()
{
ErrorInfosManager::GetTopErrLevelInDuration();
}
#ifdef __DEBUG__
#define SOURCE_CODE_INFO \
("[" + std::string(__FILE__) + ":" + std::to_string(__LINE__) + " @ " + std::string(__FUNCTION__) + "]:")
#define LOG_CRITICAL(errid, msg) \
ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_CRITICAL, errid, SOURCE_CODE_INFO + (msg))
#define LOG_ERROR(errid, msg) \
ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_ERROR, errid, SOURCE_CODE_INFO + (msg))
#define LOG_WARNING(errid, msg) \
ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_WARNING, errid, SOURCE_CODE_INFO + (msg))
#define LOG_INFO(msg) \
ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_INFO, DebuggerErrno::NONE, SOURCE_CODE_INFO + (msg))
#define LOG_DEBUG(msg) \
ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_DEBUG, DebuggerErrno::NONE, SOURCE_CODE_INFO + (msg))
#define DEBUG_FUNC_TRACE() \
ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_DEBUG, DebuggerErrno::NONE, \
"TRACE: enter " + std::string(__FUNCTION__))
#else
#define LOG_CRITICAL(errid, msg) ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_CRITICAL, errid, msg)
#define LOG_ERROR(errid, msg) ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_ERROR, errid, msg)
#define LOG_WARNING(errid, msg) ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_WARNING, errid, msg)
#define LOG_INFO(msg) ErrorInfosManager::LogErrorInfo(DebuggerErrLevel::LEVEL_INFO, DebuggerErrno::NONE, msg)
#define LOG_DEBUG(msg)
#define DEBUG_FUNC_TRACE()
#endif
}