Apply tizen coding convention for C++ and header
[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) throw(CAudioError) :
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:%d]", 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:%d]", 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:%d]", 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:%d]", 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 void CAudioInfo::convertAudioType2StreamType(CAudioInfo::EAudioType audioType, char **streamType) {
92     if (audioType < CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA || audioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX) {
93         THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE, "The audioType is not supported [audioType:%d]", audioType);
94     }
95     *streamType = (char *)__STREAM_TYPE_TABLE[(unsigned int)audioType];
96     return;
97 }
98
99 void CAudioInfo::convertInputStreamType2AudioType(char *streamType, CAudioInfo::EAudioType *audioType) {
100     for (unsigned int i = (unsigned int)CAudioInfo::EAudioType::AUDIO_IN_TYPE_MEDIA ; i < (unsigned int)CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA ; i++) {
101         if (!strcmp((char *)__STREAM_TYPE_TABLE[i], streamType)) {
102             *audioType = (CAudioInfo::EAudioType)i;
103             return;
104         }
105     }
106     THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE, "The streamType of input is not supported [streamType:%s]", streamType);
107     return;
108 }
109
110 void CAudioInfo::convertOutputStreamType2AudioType(char *streamType, CAudioInfo::EAudioType *audioType) {
111     for (unsigned int i = (unsigned int)CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA ; i < (unsigned int)CAudioInfo::EAudioType::AUDIO_TYPE_MAX ; i++) {
112         if (!strcmp((char *)__STREAM_TYPE_TABLE[i], streamType)) {
113             *audioType = (CAudioInfo::EAudioType)i;
114             return;
115         }
116     }
117     THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_NOT_SUPPORTED_TYPE, "The streamType of output is not supported [streamType:%s]", streamType);
118     return;
119 }
120