• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2023 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef BATTERY_LOG_H
17 #define BATTERY_LOG_H
18 
19 #include "beget_ext.h"
20 #include <string>
21 
22 #define CHARGER_LOG_FILE  "charger.log"
23 #define FEATURE_CHARGING  "charger: "
24 
ReplaceHolder(std::string & str,const std::string & holder)25 inline void ReplaceHolder(std::string& str, const std::string& holder)
26 {
27     size_t index = 0;
28     size_t holderLen = holder.size();
29     while ((index = str.find(holder, index)) != std::string::npos) {
30         str = str.replace(index, holderLen, "");
31         index++;
32     }
33 }
34 
ReplaceHolders(const char * fmt)35 inline std::string ReplaceHolders(const char* fmt)
36 {
37     std::string str(fmt);
38     ReplaceHolder(str, "{public}");
39     ReplaceHolder(str, "{private}");
40     return "[%s:%d] %s# " + str + "\n";
41 }
42 
43 #define BATTERY_HILOGE(label, fmt, ...)                                                                             \
44     do {                                                                                                            \
45         InitLogPrint(INIT_LOG_PATH CHARGER_LOG_FILE, INIT_ERROR, label, (ReplaceHolders(fmt).c_str()), (FILE_NAME), \
46             (__LINE__), (__FUNCTION__), ##__VA_ARGS__);                                                             \
47     } while (0)
48 #define BATTERY_HILOGW(label, fmt, ...)                                                                            \
49     do {                                                                                                           \
50         InitLogPrint(INIT_LOG_PATH CHARGER_LOG_FILE, INIT_WARN, label, (ReplaceHolders(fmt).c_str()), (FILE_NAME), \
51             (__LINE__), (__FUNCTION__), ##__VA_ARGS__);                                                            \
52     } while (0)
53 #define BATTERY_HILOGI(label, fmt, ...)                                                                            \
54     do {                                                                                                           \
55         InitLogPrint(INIT_LOG_PATH CHARGER_LOG_FILE, INIT_INFO, label, (ReplaceHolders(fmt).c_str()), (FILE_NAME), \
56             (__LINE__), (__FUNCTION__), ##__VA_ARGS__);                                                            \
57     } while (0)
58 #define BATTERY_HILOGD(label, fmt, ...)                                                                             \
59     do {                                                                                                            \
60         InitLogPrint(INIT_LOG_PATH CHARGER_LOG_FILE, INIT_DEBUG, label, (ReplaceHolders(fmt).c_str()), (FILE_NAME), \
61             (__LINE__), (__FUNCTION__), ##__VA_ARGS__);                                                             \
62     } while (0)
63 
64 #endif // BATTERY_LOG_H
65