mirror of
https://gitee.com/openharmony/arkcompiler_ets_runtime
synced 2024-11-27 04:00:37 +00:00
343785b5af
Signed-off-by: ChenYC009 <chenyongchun5@huawei.com> Change-Id: I990e9d9667c2dfdf1854bcc3824e6206c37cb019
243 lines
6.6 KiB
C++
243 lines
6.6 KiB
C++
/*
|
|
* Copyright (c) 2022 Huawei Device Co., Ltd.
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef ECMASCRIPT_LOG_H
|
|
#define ECMASCRIPT_LOG_H
|
|
|
|
#include <cstdint>
|
|
#include <iostream>
|
|
#include <sstream>
|
|
|
|
#include "ecmascript/common.h"
|
|
#include "ecmascript/napi/include/jsnapi.h"
|
|
|
|
#ifdef ENABLE_HILOG
|
|
#if defined(__clang__)
|
|
#pragma clang diagnostic ignored "-Wgnu-zero-variadic-macro-arguments"
|
|
#elif defined(__GNUC__)
|
|
#pragma GCC diagnostic ignored "-Wgnu-zero-variadic-macro-arguments"
|
|
#endif
|
|
#include "hilog/log.h"
|
|
#undef LOG_DOMAIN
|
|
#define LOG_DOMAIN 0xD003F00
|
|
#undef LOG_TAG
|
|
#define LOG_TAG "ArkCompiler"
|
|
#endif
|
|
|
|
|
|
using LOG_LEVEL = panda::RuntimeOption::LOG_LEVEL;
|
|
enum Level {
|
|
VERBOSE,
|
|
DEBUG,
|
|
INFO,
|
|
WARN,
|
|
ERROR,
|
|
FATAL,
|
|
};
|
|
|
|
using ComponentMark = uint64_t;
|
|
enum Component {
|
|
NONE = 0ULL,
|
|
GC = 1ULL << 0ULL,
|
|
INTERPRETER = 1ULL << 1ULL,
|
|
COMPILER = 1ULL << 2ULL,
|
|
DEBUGGER = 1ULL << 3ULL,
|
|
ECMASCRIPT = 1ULL << 4ULL,
|
|
BUILTINS = 1ULL << 5ULL,
|
|
TRACE = 1ULL << 6ULL,
|
|
JIT = 1UL << 7ULL,
|
|
BASELINEJIT = 1UL << 8ULL,
|
|
SA = 1ULL << 9ULL,
|
|
NO_TAG = 0xFFFFFFFFULL >> 1ULL,
|
|
ALL = 0xFFFFFFFFULL,
|
|
};
|
|
|
|
namespace panda::ecmascript {
|
|
#ifdef ENABLE_HILOG
|
|
|
|
#if ECMASCRIPT_ENABLE_VERBOSE_LEVEL_LOG
|
|
// print Debug level log if enable Verbose log
|
|
#define LOG_VERBOSE LOG_DEBUG
|
|
#else
|
|
#define LOG_VERBOSE LOG_LEVEL_MIN
|
|
#endif
|
|
#endif // ENABLE_HILOG
|
|
|
|
class JSRuntimeOptions;
|
|
class PUBLIC_API Log {
|
|
public:
|
|
static void Initialize(const JSRuntimeOptions &options);
|
|
static inline bool LogIsLoggable(Level level, Component component)
|
|
{
|
|
switch (component)
|
|
{
|
|
case Component::SA:
|
|
return ((components_ & component) != 0ULL);
|
|
default:
|
|
return (level >= level_) && ((components_ & component) != 0ULL);
|
|
}
|
|
}
|
|
static inline std::string GetComponentStr(Component component)
|
|
{
|
|
switch (component)
|
|
{
|
|
case Component::NO_TAG:
|
|
return "";
|
|
case Component::GC:
|
|
return "[gc] ";
|
|
case Component::ECMASCRIPT:
|
|
return "[ecmascript] ";
|
|
case Component::INTERPRETER:
|
|
return "[interpreter] ";
|
|
case Component::DEBUGGER:
|
|
return "[debugger] ";
|
|
case Component::COMPILER:
|
|
return "[compiler] ";
|
|
case Component::BUILTINS:
|
|
return "[builtins] ";
|
|
case Component::TRACE:
|
|
return "[trace] ";
|
|
case Component::JIT:
|
|
return "[jit] ";
|
|
case Component::BASELINEJIT:
|
|
return "[baselinejit] ";
|
|
case Component::SA:
|
|
return "[sa] ";
|
|
case Component::ALL:
|
|
return "[default] ";
|
|
default:
|
|
return "[unknown] ";
|
|
}
|
|
}
|
|
static std::string LevelToString(Level level);
|
|
static Level ConvertFromRuntime(LOG_LEVEL level);
|
|
|
|
private:
|
|
static void SetLogLevelFromString(const std::string& level);
|
|
static void SetLogComponentFromString(const std::vector<std::string>& components);
|
|
static int32_t PrintLogger(int32_t, int32_t level, const char *, const char *, const char *message);
|
|
|
|
static Level level_;
|
|
static ComponentMark components_;
|
|
};
|
|
|
|
#if defined(ENABLE_HILOG)
|
|
template<LogLevel level, Component component>
|
|
class HiLog {
|
|
public:
|
|
HiLog()
|
|
{
|
|
std::string str = Log::GetComponentStr(component);
|
|
stream_ << str;
|
|
}
|
|
~HiLog()
|
|
{
|
|
if constexpr (level == LOG_LEVEL_MIN) {
|
|
// print nothing
|
|
} else if constexpr (level == LOG_DEBUG) {
|
|
HILOG_DEBUG(LOG_CORE, "%{public}s", stream_.str().c_str());
|
|
} else if constexpr (level == LOG_INFO) {
|
|
HILOG_INFO(LOG_CORE, "%{public}s", stream_.str().c_str());
|
|
} else if constexpr (level == LOG_WARN) {
|
|
HILOG_WARN(LOG_CORE, "%{public}s", stream_.str().c_str());
|
|
} else if constexpr (level == LOG_ERROR) {
|
|
HILOG_ERROR(LOG_CORE, "%{public}s", stream_.str().c_str());
|
|
} else {
|
|
HILOG_FATAL(LOG_CORE, "%{public}s", stream_.str().c_str());
|
|
std::abort();
|
|
}
|
|
}
|
|
template<class type>
|
|
std::ostream &operator <<(type input)
|
|
{
|
|
stream_ << input;
|
|
return stream_;
|
|
}
|
|
|
|
private:
|
|
std::ostringstream stream_;
|
|
};
|
|
#elif defined(ENABLE_ANLOG) // ENABLE_ANLOG
|
|
template<Level level>
|
|
class PUBLIC_API AndroidLog {
|
|
public:
|
|
AndroidLog()
|
|
{
|
|
std::string str = "[default] ";
|
|
stream_ << str;
|
|
}
|
|
~AndroidLog();
|
|
|
|
template<class type>
|
|
std::ostream &operator <<(type input)
|
|
{
|
|
stream_ << input;
|
|
return stream_;
|
|
}
|
|
|
|
private:
|
|
std::ostringstream stream_;
|
|
};
|
|
#else
|
|
template<Level level, Component component>
|
|
class StdLog {
|
|
public:
|
|
StdLog()
|
|
{
|
|
std::string str = Log::GetComponentStr(component);
|
|
stream_ << str;
|
|
}
|
|
~StdLog()
|
|
{
|
|
if constexpr (level == FATAL || level == ERROR) {
|
|
std::cerr << stream_.str().c_str() << std::endl;
|
|
} else {
|
|
std::cout << stream_.str().c_str() << std::endl;
|
|
}
|
|
|
|
if constexpr (level == FATAL) {
|
|
std::abort();
|
|
}
|
|
}
|
|
|
|
template<class type>
|
|
std::ostream &operator <<(type input)
|
|
{
|
|
stream_ << input;
|
|
return stream_;
|
|
}
|
|
|
|
private:
|
|
std::ostringstream stream_;
|
|
};
|
|
#endif
|
|
|
|
#if defined(ENABLE_HILOG)
|
|
#define ARK_LOG(level, component) panda::ecmascript::Log::LogIsLoggable(level, component) && \
|
|
panda::ecmascript::HiLog<LOG_##level, (component)>()
|
|
#elif defined(ENABLE_ANLOG)
|
|
#define ARK_LOG(level, component) panda::ecmascript::AndroidLog<(level)>()
|
|
#else
|
|
#if defined(OHOS_UNIT_TEST)
|
|
#define ARK_LOG(level, component) ((level >= INFO) || panda::ecmascript::Log::LogIsLoggable(level, component)) && \
|
|
panda::ecmascript::StdLog<(level), (component)>()
|
|
#else
|
|
#define ARK_LOG(level, component) panda::ecmascript::Log::LogIsLoggable(level, component) && \
|
|
panda::ecmascript::StdLog<(level), (component)>()
|
|
#endif
|
|
#endif
|
|
} // namespace panda::ecmascript
|
|
#endif // ECMASCRIPT_LOG_H
|