return;
}
- try {
- internalLock();
-
- // Check to invalid AudioType
- CAudioInfo::EAudioType audioType = mAudioInfo.getAudioType();
- if (audioType < CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA || audioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX) {
- THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT,
- "The audioType is invalid [type:%d]", static_cast<int>(audioType));
- }
+ /* Check invalid AudioType */
+ CAudioInfo::EAudioType audioType = mAudioInfo.getAudioType();
+ if (audioType < CAudioInfo::EAudioType::AUDIO_OUT_TYPE_MEDIA || audioType >= CAudioInfo::EAudioType::AUDIO_TYPE_MAX) {
+ THROW_ERROR_MSG_FORMAT(CAudioError::EError::ERROR_INVALID_ARGUMENT,
+ "The audioType is invalid [type:%d]", static_cast<int>(audioType));
+ }
+ try {
if (mpAudioSessionHandler->getId() < 0) { // Did not registerSound()
if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false) {
- // Register ASM Listener
+ /* Register ASM Listener */
AUDIO_IO_LOGD("Register ASM Listener");
mpAudioSessionHandler->registerSound();
}
CAudioIO::setInternalStreamInfo();
- // Init StreamSpec
+ if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false)
+ mpAudioSessionHandler->updatePlaying();
+ } catch (CAudioError& e) {
+ throw;
+ }
+
+ try {
+ /* Init StreamSpec */
CPulseStreamSpec::EStreamLatency streamSpec = CPulseStreamSpec::EStreamLatency::STREAM_LATENCY_OUTPUT_DEFAULT;
#ifndef DISABLE_MOBILE_BACK_COMP
if (!mStreamCallback.onStream) {
#endif
CPulseStreamSpec spec(streamSpec, mAudioInfo);
- // Create PulseAudio Handler
+ internalLock();
+
+ /* Create PulseAudio Handler */
mpPulseAudioClient = new CPulseAudioClient(CPulseAudioClient::EStreamDirection::STREAM_DIRECTION_PLAYBACK, spec, this);
- // Initialize PulseAudio Handler
+ /* Initialize PulseAudio Handler */
mpPulseAudioClient->initialize();
-
- if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false)
- mpAudioSessionHandler->updatePlaying();
-
#ifndef DISABLE_MOBILE_BACK_COMP
- // Uncork stream which is created with CORKED flag */
+ /* Uncork stream which is created with CORKED flag */
mpPulseAudioClient->cork(false);
#endif
internalUnlock();
try {
if (mpAudioSessionHandler->getId() >= 0 && !mIsInterrupted) {
if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false) {
- CPulseStreamSpec::EStreamLatency streamSpec;
- streamSpec = mpPulseAudioClient->getStreamSpec().getStreamLatency();
- if (CPulseStreamSpec::EStreamLatency::STREAM_LATENCY_OUTPUT_DEFAULT_ASYNC != streamSpec)
+ if (mStreamCallback.onStream == NULL)
CAudioIO::drain();
}
}
internalUnlock();
+ } catch (CAudioError& e) {
+ internalUnlock();
+ throw;
+ }
+
+ try {
if (mpAudioSessionHandler->getId() >= 0) {
if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false)
mpAudioSessionHandler->updateStop();
}
-
CAudioIO::onStateChanged(CAudioInfo::EAudioIOState::AUDIO_IO_STATE_IDLE);
} catch (CAudioError& e) {
internalUnlock();
try {
CAudioIO::pause();
- internalLock();
-
- /* Updates ASM to STOP */
- if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false)
- mpAudioSessionHandler->updateStop();
-
- internalUnlock();
-
CAudioIO::onStateChanged(CAudioInfo::EAudioIOState::AUDIO_IO_STATE_PAUSED);
} catch (CAudioError& e) {
- internalUnlock();
throw;
}
}
}
try {
- internalLock();
-
- if (isForceIgnore() == false && mpAudioSessionHandler->isSkipSession() == false)
- mpAudioSessionHandler->updatePlaying();
-
- internalUnlock();
-
CAudioIO::resume();
CAudioIO::onStateChanged(CAudioInfo::EAudioIOState::AUDIO_IO_STATE_RUNNING);
} catch (CAudioError& e) {
- internalUnlock();
throw;
}
}
void CAudioOutput::drain() {
- CPulseStreamSpec::EStreamLatency streamSpec;
-
if (__IsInit() == false || __IsReady() == false) {
THROW_ERROR_MSG(CAudioError::EError::ERROR_NOT_INITIALIZED,
"Did not initialize or prepare CAudioOutput");
}
- streamSpec = mpPulseAudioClient->getStreamSpec().getStreamLatency();
- if (CPulseStreamSpec::EStreamLatency::STREAM_LATENCY_OUTPUT_DEFAULT_ASYNC == streamSpec)
+ if (mStreamCallback.onStream)
THROW_ERROR_MSG(CAudioError::EError::ERROR_INVALID_OPERATION, "async type don't support drain");
try {