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}