17c804472Sopenharmony_ci/* 27c804472Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 37c804472Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 47c804472Sopenharmony_ci * you may not use this file except in compliance with the License. 57c804472Sopenharmony_ci * You may obtain a copy of the License at 67c804472Sopenharmony_ci * 77c804472Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 87c804472Sopenharmony_ci * 97c804472Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 107c804472Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 117c804472Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 127c804472Sopenharmony_ci * See the License for the specific language governing permissions and 137c804472Sopenharmony_ci * limitations under the License. 147c804472Sopenharmony_ci */ 157c804472Sopenharmony_ci 167c804472Sopenharmony_ci#include "PreviewerEngineLog.h" 177c804472Sopenharmony_ci 187c804472Sopenharmony_ci#include <cstdio> 197c804472Sopenharmony_ci#include <iostream> 207c804472Sopenharmony_ci#ifdef _WIN32 217c804472Sopenharmony_ci#include <windows.h> 227c804472Sopenharmony_ci#else 237c804472Sopenharmony_ci#include "unistd.h" 247c804472Sopenharmony_ci#endif 257c804472Sopenharmony_ci 267c804472Sopenharmony_ci#include "LocalDate.h" 277c804472Sopenharmony_ci#include "TimeTool.h" 287c804472Sopenharmony_ci#include "securec.h" 297c804472Sopenharmony_ci 307c804472Sopenharmony_civoid PrintLog(const char* level, const char* file, const char* func, int line, const char* fmt, ...) 317c804472Sopenharmony_ci{ 327c804472Sopenharmony_ci#ifdef NDEBUG 337c804472Sopenharmony_ci std::string levelStr(level); 347c804472Sopenharmony_ci if (levelStr == "DEBUG") { 357c804472Sopenharmony_ci return; 367c804472Sopenharmony_ci } 377c804472Sopenharmony_ci#endif 387c804472Sopenharmony_ci static char output[1024] = { 0 }; 397c804472Sopenharmony_ci va_list argsList; 407c804472Sopenharmony_ci if (fmt == nullptr || *fmt == '\0') { 417c804472Sopenharmony_ci std::cerr << "PrintLog error: Format string is null or empty" << std::endl; 427c804472Sopenharmony_ci return; 437c804472Sopenharmony_ci } 447c804472Sopenharmony_ci va_start(argsList, fmt); 457c804472Sopenharmony_ci std::string fileStr(file); 467c804472Sopenharmony_ci int idx = fileStr.find_last_of("/"); 477c804472Sopenharmony_ci fileStr = fileStr.substr(idx + 1); 487c804472Sopenharmony_ci int ret = vsnprintf_s(output, sizeof(output), sizeof(output), fmt, argsList); 497c804472Sopenharmony_ci if (ret == -1) { 507c804472Sopenharmony_ci std::cout << "PrintLog function error"; 517c804472Sopenharmony_ci return; 527c804472Sopenharmony_ci } 537c804472Sopenharmony_ci if (stdout != nullptr) { 547c804472Sopenharmony_ci fprintf(stdout, "[%s][%s][%s][%d]%s:%s\n", level, fileStr.c_str(), func, line, 557c804472Sopenharmony_ci TimeTool::GetFormatTime().c_str(), output); 567c804472Sopenharmony_ci fflush(stdout); 577c804472Sopenharmony_ci } 587c804472Sopenharmony_ci va_end(argsList); 597c804472Sopenharmony_ci}