1ca0551cfSopenharmony_ci/* 2ca0551cfSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd. 3ca0551cfSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4ca0551cfSopenharmony_ci * you may not use this file except in compliance with the License. 5ca0551cfSopenharmony_ci * You may obtain a copy of the License at 6ca0551cfSopenharmony_ci * 7ca0551cfSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8ca0551cfSopenharmony_ci * 9ca0551cfSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10ca0551cfSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11ca0551cfSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12ca0551cfSopenharmony_ci * See the License for the specific language governing permissions and 13ca0551cfSopenharmony_ci * limitations under the License. 14ca0551cfSopenharmony_ci */ 15ca0551cfSopenharmony_ci 16ca0551cfSopenharmony_ci#include "util/logger.h" 17ca0551cfSopenharmony_ci#include <cstdio> 18ca0551cfSopenharmony_ci 19ca0551cfSopenharmony_cinamespace OHOS { 20ca0551cfSopenharmony_cinamespace Idl { 21ca0551cfSopenharmony_ciint Logger::level_ = DEBUG; 22ca0551cfSopenharmony_ci 23ca0551cfSopenharmony_civoid Logger::D(const char *tag, const char *format, ...) 24ca0551cfSopenharmony_ci{ 25ca0551cfSopenharmony_ci if (level_ > DEBUG) { 26ca0551cfSopenharmony_ci return; 27ca0551cfSopenharmony_ci } 28ca0551cfSopenharmony_ci 29ca0551cfSopenharmony_ci va_list args; 30ca0551cfSopenharmony_ci va_start(args, format); 31ca0551cfSopenharmony_ci Log(tag, format, args); 32ca0551cfSopenharmony_ci va_end(args); 33ca0551cfSopenharmony_ci} 34ca0551cfSopenharmony_ci 35ca0551cfSopenharmony_civoid Logger::E(const char *tag, const char *format, ...) 36ca0551cfSopenharmony_ci{ 37ca0551cfSopenharmony_ci if (level_ > ERROR) { 38ca0551cfSopenharmony_ci return; 39ca0551cfSopenharmony_ci } 40ca0551cfSopenharmony_ci 41ca0551cfSopenharmony_ci va_list args; 42ca0551cfSopenharmony_ci va_start(args, format); 43ca0551cfSopenharmony_ci Err(tag, format, args); 44ca0551cfSopenharmony_ci va_end(args); 45ca0551cfSopenharmony_ci} 46ca0551cfSopenharmony_ci 47ca0551cfSopenharmony_civoid Logger::V(const char *tag, const char *format, ...) 48ca0551cfSopenharmony_ci{ 49ca0551cfSopenharmony_ci if (level_ > VERBOSE) { 50ca0551cfSopenharmony_ci return; 51ca0551cfSopenharmony_ci } 52ca0551cfSopenharmony_ci 53ca0551cfSopenharmony_ci va_list args; 54ca0551cfSopenharmony_ci va_start(args, format); 55ca0551cfSopenharmony_ci Log(tag, format, args); 56ca0551cfSopenharmony_ci va_end(args); 57ca0551cfSopenharmony_ci} 58ca0551cfSopenharmony_ci 59ca0551cfSopenharmony_civoid Logger::Log(const char *tag, const char *format, va_list args) 60ca0551cfSopenharmony_ci{ 61ca0551cfSopenharmony_ci (void)printf("[%s]: ", tag); 62ca0551cfSopenharmony_ci (void)vprintf(format, args); 63ca0551cfSopenharmony_ci (void)printf("\n"); 64ca0551cfSopenharmony_ci} 65ca0551cfSopenharmony_ci 66ca0551cfSopenharmony_civoid Logger::Err(const char *tag, const char *format, va_list args) 67ca0551cfSopenharmony_ci{ 68ca0551cfSopenharmony_ci (void)fprintf(stderr, "[%s]: ", tag); 69ca0551cfSopenharmony_ci (void)vfprintf(stderr, format, args); 70ca0551cfSopenharmony_ci (void)fprintf(stderr, "\n"); 71ca0551cfSopenharmony_ci} 72ca0551cfSopenharmony_ci} // namespace Idl 73ca0551cfSopenharmony_ci} // namespace OHOS