1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#ifndef PARSE_EFFECT_CONFIG_H
17094332d3Sopenharmony_ci#define PARSE_EFFECT_CONFIG_H
18094332d3Sopenharmony_ci
19094332d3Sopenharmony_ci#include <stdint.h>
20094332d3Sopenharmony_ci
21094332d3Sopenharmony_ci#define HDF_EFFECT_LIB_NUM_MAX 32
22094332d3Sopenharmony_ci
23094332d3Sopenharmony_cistruct LibraryConfigDescriptor {
24094332d3Sopenharmony_ci    const char *libName;
25094332d3Sopenharmony_ci    const char *libPath;
26094332d3Sopenharmony_ci};
27094332d3Sopenharmony_ci
28094332d3Sopenharmony_cistruct EffectConfigDescriptor {
29094332d3Sopenharmony_ci    const char *name;
30094332d3Sopenharmony_ci    const char *library;
31094332d3Sopenharmony_ci    const char *effectId;
32094332d3Sopenharmony_ci};
33094332d3Sopenharmony_ci
34094332d3Sopenharmony_cistruct ConfigDescriptor {
35094332d3Sopenharmony_ci    struct LibraryConfigDescriptor *libCfgDescs;
36094332d3Sopenharmony_ci    uint32_t libNum;
37094332d3Sopenharmony_ci    struct EffectConfigDescriptor *effectCfgDescs;
38094332d3Sopenharmony_ci    uint32_t effectNum;
39094332d3Sopenharmony_ci};
40094332d3Sopenharmony_ci
41094332d3Sopenharmony_ci/**
42094332d3Sopenharmony_ci * @brief Parse the effect profile and get the effect config descriptor.
43094332d3Sopenharmony_ci *
44094332d3Sopenharmony_ci * @param path Indicates the effect configuration file path.
45094332d3Sopenharmony_ci * @param cfgDesc Indicates pointer of the effect config descriptor.
46094332d3Sopenharmony_ci *
47094332d3Sopenharmony_ci * @return Returns <b>0</b> if the process success; returns a non-zero value otherwise.
48094332d3Sopenharmony_ci *
49094332d3Sopenharmony_ci * @since 4.0
50094332d3Sopenharmony_ci * @version 1.0
51094332d3Sopenharmony_ci */
52094332d3Sopenharmony_ciint32_t AudioEffectGetConfigDescriptor(const char *path, struct ConfigDescriptor **cfgDesc);
53094332d3Sopenharmony_ci
54094332d3Sopenharmony_ci/**
55094332d3Sopenharmony_ci * @brief Release the effect config descriptor.
56094332d3Sopenharmony_ci *
57094332d3Sopenharmony_ci * @param cfgDesc Indicates pointer of the effect config descriptor.
58094332d3Sopenharmony_ci *
59094332d3Sopenharmony_ci * @return Returns <b>0</b> if the process success; returns a non-zero value otherwise.
60094332d3Sopenharmony_ci *
61094332d3Sopenharmony_ci * @since 4.0
62094332d3Sopenharmony_ci * @version 1.0
63094332d3Sopenharmony_ci */
64094332d3Sopenharmony_civoid AudioEffectReleaseCfgDesc(struct ConfigDescriptor *cfgDesc);
65094332d3Sopenharmony_ci
66094332d3Sopenharmony_ci#endif
67