1ca0551cfSopenharmony_ci/* 2ca0551cfSopenharmony_ci * Copyright (c) 2022 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 18ca0551cfSopenharmony_ci#include <cstdio> 19ca0551cfSopenharmony_ci 20ca0551cfSopenharmony_cinamespace OHOS { 21ca0551cfSopenharmony_cinamespace Idl { 22ca0551cfSopenharmony_ciint Logger::level_ = DEBUG; 23ca0551cfSopenharmony_ci 24ca0551cfSopenharmony_civoid Logger::D(const char* tag, const char* format, ...) 25ca0551cfSopenharmony_ci{ 26ca0551cfSopenharmony_ci if (level_ > DEBUG) return; 27ca0551cfSopenharmony_ci 28ca0551cfSopenharmony_ci va_list args; 29ca0551cfSopenharmony_ci va_start(args, format); 30ca0551cfSopenharmony_ci Log(tag, format, args); 31ca0551cfSopenharmony_ci va_end(args); 32ca0551cfSopenharmony_ci} 33ca0551cfSopenharmony_ci 34ca0551cfSopenharmony_civoid Logger::E(const char* tag, const char* format, ...) 35ca0551cfSopenharmony_ci{ 36ca0551cfSopenharmony_ci if (level_ > ERROR) return; 37ca0551cfSopenharmony_ci 38ca0551cfSopenharmony_ci va_list args; 39ca0551cfSopenharmony_ci va_start(args, format); 40ca0551cfSopenharmony_ci Err(tag, format, args); 41ca0551cfSopenharmony_ci va_end(args); 42ca0551cfSopenharmony_ci} 43ca0551cfSopenharmony_ci 44ca0551cfSopenharmony_civoid Logger::V(const char* tag, const char* format, ...) 45ca0551cfSopenharmony_ci{ 46ca0551cfSopenharmony_ci if (level_ > VERBOSE) return; 47ca0551cfSopenharmony_ci 48ca0551cfSopenharmony_ci va_list args; 49ca0551cfSopenharmony_ci va_start(args, format); 50ca0551cfSopenharmony_ci Log(tag, format, args); 51ca0551cfSopenharmony_ci va_end(args); 52ca0551cfSopenharmony_ci} 53ca0551cfSopenharmony_ci 54ca0551cfSopenharmony_civoid Logger::Log(const char* tag, const char* format, va_list args) 55ca0551cfSopenharmony_ci{ 56ca0551cfSopenharmony_ci printf("[%s]: ", tag); 57ca0551cfSopenharmony_ci vprintf(format, args); 58ca0551cfSopenharmony_ci printf("\n"); 59ca0551cfSopenharmony_ci} 60ca0551cfSopenharmony_ci 61ca0551cfSopenharmony_civoid Logger::Err(const char* tag, const char* format, va_list args) 62ca0551cfSopenharmony_ci{ 63ca0551cfSopenharmony_ci fprintf(stderr, "[%s]: ", tag); 64ca0551cfSopenharmony_ci vfprintf(stderr, format, args); 65ca0551cfSopenharmony_ci fprintf(stderr, "\n"); 66ca0551cfSopenharmony_ci} 67ca0551cfSopenharmony_ci} 68ca0551cfSopenharmony_ci} 69