[ACR-1434] Extend channel and format parameters
[platform/core/api/audio-io.git] / src / cpp / CAudioInfo.cpp
1 /*
2  * Copyright (c) 2015 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17
18 #include <stdio.h>
19 #include "CAudioIODef.h"
20
21
22 using namespace std;
23 using namespace tizen_media_audio;
24
25
26 /**
27  * class CAudioInfo
28  */
29 CAudioInfo::CAudioInfo() :
30     __mSampleRate(MAX_SYSTEM_SAMPLERATE),
31     __mChannel(EChannel::CHANNEL_MONO),
32     __mSampleType(ESampleType::SAMPLE_TYPE_U8),
33     __mAudioType(EAudioType::AUDIO_IN_TYPE_MEDIA),
34     __mAudioIndex(-1) {
35 }
36
37 CAudioInfo::CAudioInfo(unsigned int sampleRate, EChannel channel, ESampleType sampleType, EAudioType audioType, int audioIndex) :
38     __mSampleRate(sampleRate),
39     __mChannel(channel),
40     __mSampleType(sampleType),
41     __mAudioType(audioType),
42     __mAudioIndex(audioIndex) {
43     // Check to invalid AudioInfo
44     if (sampleRate < CAudioInfo::MIN_SYSTEM_SAMPLERATE || sampleRate > CAudioInfo::MAX_SYSTEM_SAMPLERATE) {
45         THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT, "The sampleRate is invalid [sampleRate:%u]", sampleRate);
46     }
47
48     if (channel < CAudioInfo::EChannel::CHANNEL_MONO || channel >= CAudioInfo::EChannel::CHANNEL_MAX) {
49         THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT, "The channel is invalid [channel:%u]", to_integral(channel));
50     }
51
52     if (sampleType < CAudioInfo::ESampleType::SAMPLE_TYPE_U8 || sampleType >= CAudioInfo::ESampleType::SAMPLE_TYPE_MAX) {
53         THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT, "The sampleType is invalid [sampleType:%u]", to_integral(sampleType));
54     }
55
56     if (audioType < CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA || audioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX) {
57         THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT, "The audioType is invalid [audioType:%u]", to_integral(audioType));
58     }
59 }
60
61 unsigned int CAudioInfo::getSampleRate() {
62     return __mSampleRate;
63 }
64
65 CAudioInfo::EChannel CAudioInfo::getChannel() {
66     return __mChannel;
67 }
68
69 CAudioInfo::ESampleType CAudioInfo::getSampleType() {
70     return __mSampleType;
71 }
72
73 CAudioInfo::EAudioType CAudioInfo::getAudioType() {
74     return __mAudioType;
75 }
76
77 void CAudioInfo::setAudioType(CAudioInfo::EAudioType audioType) {
78     __mAudioType = audioType;
79     return;
80 }
81
82 int CAudioInfo::getAudioIndex() {
83     return __mAudioIndex;
84 }
85
86 void CAudioInfo::setAudioIndex(int audioIndex) {
87     __mAudioIndex = audioIndex;
88     return;
89 }
90
91 int CAudioInfo::getSampleSize() {
92     int bytes_in_sample = 0;
93
94     switch (__mSampleType) {
95     case ESampleType::SAMPLE_TYPE_U8:
96         bytes_in_sample = 1;
97         break;
98     case ESampleType::SAMPLE_TYPE_S16_LE:
99         bytes_in_sample = 2;
100         break;
101     case ESampleType::SAMPLE_TYPE_S24_LE:
102         bytes_in_sample = 3;
103         break;
104     case ESampleType::SAMPLE_TYPE_S24_32_LE:
105     case ESampleType::SAMPLE_TYPE_S32_LE:
106         bytes_in_sample = 4;
107         break;
108     default:
109         AUDIO_IO_LOGW("As unrecognized sample type %d, let's assume S16_LE", static_cast<int>(__mSampleType));
110         bytes_in_sample = 2;
111         break;
112     }
113
114     return bytes_in_sample * static_cast<int>(__mChannel);
115 }
116
117 void CAudioInfo::convertAudioType2StreamType(CAudioInfo::EAudioType audioType, char **streamType) {
118     if (audioType < CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA || audioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX)
119         THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE,
120                                "The audioType is not supported [audioType:%u]", to_integral(audioType));
121
122     *streamType = (char *)__STREAM_TYPE_TABLE[(unsigned int)audioType];
123     return;
124 }
125
126 void CAudioInfo::convertInputStreamType2AudioType(char *streamType, CAudioInfo::EAudioType *audioType) {
127     for (unsigned int i = (unsigned int)CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA ; i < (unsigned int)CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA ; i++) {
128         if (!strcmp((char *)__STREAM_TYPE_TABLE[i], streamType)) {
129             *audioType = (CAudioInfo::EAudioType)i;
130             return;
131         }
132     }
133     THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE, "The streamType of input is not supported [streamType:%s]", streamType);
134     return;
135 }
136
137 void CAudioInfo::convertOutputStreamType2AudioType(char *streamType, CAudioInfo::EAudioType *audioType) {
138     for (unsigned int i = (unsigned int)CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA ; i < (unsigned int)CAudioInfo::EAudioType::AUDIO_TYPE_MAX ; i++) {
139         if (!strcmp((char *)__STREAM_TYPE_TABLE[i], streamType)) {
140             *audioType = (CAudioInfo::EAudioType)i;
141             return;
142         }
143     }
144     THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE, "The streamType of output is not supported [streamType:%s]", streamType);
145     return;
146 }
147