| 1 | // SPDX-FileCopyrightText: 2023 UnionTech Software Technology Co., Ltd. |
| 2 | // |
| 3 | // SPDX-License-Identifier: GPL-3.0-or-later |
| 4 | |
| 5 | #ifndef CODETIMECHECK_H |
| 6 | #define CODETIMECHECK_H |
| 7 | |
| 8 | #include "framework/framework_global.h" |
| 9 | |
| 10 | #ifndef DPF_NO_CHECK_TIME //make use |
| 11 | |
| 12 | #include <QMessageLogContext> |
| 13 | |
| 14 | // QMessageLogContext类型的上下文构造 |
| 15 | #define CodeCheckLogContext {__FILE__,__LINE__,__FUNCTION__,"TimeCheck"} |
| 16 | // 检查点Begin的宏定义,可在任意执行代码块中使用 |
| 17 | #define dpfCheckTimeBegin() dpf::CodeCheckTime::begin(CodeCheckLogContext) |
| 18 | // 检查点End的宏定义,可在任意执行代码块中使用 |
| 19 | #define dpfCheckTimeEnd() dpf::CodeCheckTime::end(CodeCheckLogContext) |
| 20 | #else // define DPF_NO_CHECK_TIME |
| 21 | // 检查点Begin的宏定义,可在任意执行代码块中使用 |
| 22 | #define dpfCheckTimeBegin() |
| 23 | // 检查点End的宏定义,可在任意执行代码块中使用 |
| 24 | #define dpfCheckTimeEnd() |
| 25 | #endif // DPF_NO_CHECK_TIME |
| 26 | |
| 27 | DPF_BEGIN_NAMESPACE |
| 28 | /** |
| 29 | * @brief The CodeCheckTime class |
| 30 | * 代码埋点时间检查模块,可加编译参数进行屏蔽 |
| 31 | * DPF_NO_CHECK_TIME (cmake -DDPF_NO_CHECK_TIME) |
| 32 | */ |
| 33 | class CodeCheckTime final |
| 34 | { |
| 35 | public: |
| 36 | explicit CodeCheckTime() = delete; |
| 37 | static void setLogCacheDayCount(uint dayCount); |
| 38 | static uint logCacheDayCount(); |
| 39 | static void begin(const QMessageLogContext &context); |
| 40 | static void end(const QMessageLogContext &context); |
| 41 | }; |
| 42 | |
| 43 | DPF_END_NAMESPACE |
| 44 | |
| 45 | |
| 46 | #endif // CODETIMECHECK_H |
| 47 | |