1 /* 2 * Copyright (c) 2021 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 UTILS_LOG_H 17 #define UTILS_LOG_H 18 19 #include <string> 20 21 #include "hilog/log.h" 22 23 namespace OHOS { 24 namespace Storage { 25 namespace DistributedFile { 26 #ifndef LOG_DOMAIN 27 #define LOG_DOMAIN 0xD001600 28 #endif 29 30 #ifndef LOG_TAG 31 #define LOG_TAG "distributedfile" 32 #endif 33 34 static constexpr HiviewDFX::HiLogLabel APP_LABEL = {LOG_CORE, LOG_DOMAIN, LOG_TAG}; 35 36 std::string GetFileNameFromFullPath(const char *str); 37 #define PRINT_LOG(Level, fmt, ...) \ 38 HiviewDFX::HiLog::Level(APP_LABEL, "[%{public}s:%{public}d->%{public}s] " fmt, \ 39 GetFileNameFromFullPath(__FILE__).c_str(), __LINE__, __FUNCTION__, ##__VA_ARGS__) 40 41 #define LOGD(fmt, ...) PRINT_LOG(Debug, fmt, ##__VA_ARGS__) 42 #define LOGI(fmt, ...) PRINT_LOG(Info, fmt, ##__VA_ARGS__) 43 #define LOGW(fmt, ...) PRINT_LOG(Warn, fmt, ##__VA_ARGS__) 44 #define LOGE(fmt, ...) PRINT_LOG(Error, fmt, ##__VA_ARGS__) 45 #define LOGF(fmt, ...) PRINT_LOG(Fatal, fmt, ##__VA_ARGS__) 46 } // namespace DistributedFile 47 } // namespace Storage 48 } // namespace OHOS 49 #endif // UTILS_LOG_H