/*
 * Copyright (c) 2026 Huawei Device Co., Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
#ifndef AUDIO_LOG_H
#define AUDIO_LOG_H

#include <hilog/log.h>

#undef LOG_DOMAIN
#define LOG_DOMAIN 0x0000

#undef LOG_TAG
#define LOG_TAG "AudioVividDemo"

#define LOGE(fmt, ...)                   \
    OH_LOG_Print(LOG_APP,                \
        LOG_ERROR,                       \
        LOG_DOMAIN,                      \
        LOG_TAG,                         \
        "[%public]s():%{public}d] " fmt, \
        __FUNCTION__,                    \
        __LINE__,                        \
        ##__VA_ARGS__)

#define LOGW(fmt, ...)                   \
    OH_LOG_Print(LOG_APP,                \
        LOG_WARN,                        \
        LOG_DOMAIN,                      \
        LOG_TAG,                         \
        "[%public]s():%{public}d] " fmt, \
        __FUNCTION__,                    \
        __LINE__,                        \
        ##__VA_ARGS__)

#define LOGI(fmt, ...)                   \
    OH_LOG_Print(LOG_APP,                \
        LOG_INFO,                        \
        LOG_DOMAIN,                      \
        LOG_TAG,                         \
        "[%public]s():%{public}d] " fmt, \
        __FUNCTION__,                    \
        __LINE__,                        \
        ##__VA_ARGS__)

#define LOGD(fmt, ...)                   \
    OH_LOG_Print(LOG_APP,                \
        LOG_DEBUG,                       \
        LOG_DOMAIN,                      \
        LOG_TAG,                         \
        "[%public]s():%{public}d] " fmt, \
        __FUNCTION__,                    \
        __LINE__,                        \
        ##__VA_ARGS__)

#define LOGF(fmt, ...)                   \
    OH_LOG_Print(LOG_APP,                \
        LOG_FATAL,                       \
        LOG_DOMAIN,                      \
        LOG_TAG,                         \
        "[%public]s():%{public}d] " fmt, \
        __FUNCTION__,                    \
        __LINE__,                        \
        ##__VA_ARGS__)

#define AVCODEC_SAMPLE_LOGE(fmt, ...) LOGE(fmt, ##__VA_ARGS__)
#define AVCODEC_SAMPLE_LOGW(fmt, ...) LOGW(fmt, ##__VA_ARGS__)
#define AVCODEC_SAMPLE_LOGI(fmt, ...) LOGI(fmt, ##__VA_ARGS__)
#define AVCODEC_SAMPLE_LOGD(fmt, ...) LOGD(fmt, ##__VA_ARGS__)
#define AVCODEC_SAMPLE_LOGF(fmt, ...) LOGF(fmt, ##__VA_ARGS__)

#endif