From d4ee1652537e06592e34e1c7c1011300d0a8cea0 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 7 Aug 2017 18:36:04 +0200 Subject: [PATCH] output/Thread: move OpenSoftwareMixer() to the end This call cannot fail, but needs cleanup if others fail. By moving it to the end, we eliminate some cleanup. --- src/output/Thread.cxx | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/src/output/Thread.cxx b/src/output/Thread.cxx index 3605fc1fd..523a4af5c 100644 --- a/src/output/Thread.cxx +++ b/src/output/Thread.cxx @@ -52,8 +52,6 @@ AudioOutputControl::InternalOpen2(const AudioFormat in_audio_format) { assert(in_audio_format.IsValid()); - output->OpenSoftwareMixer(); - const auto cf = in_audio_format.WithMask(output->config_audio_format); if (open && cf != output->filter_audio_format) @@ -64,13 +62,9 @@ AudioOutputControl::InternalOpen2(const AudioFormat in_audio_format) output->filter_audio_format = cf; if (!open) { - try { + { const ScopeUnlock unlock(mutex); output->OpenOutputAndConvert(output->filter_audio_format); - } catch (...) { - const ScopeUnlock unlock(mutex); - output->CloseSoftwareMixer(); - throw; } open = true; @@ -86,13 +80,18 @@ AudioOutputControl::InternalOpen2(const AudioFormat in_audio_format) { const ScopeUnlock unlock(mutex); - output->Close(false); + output->CloseOutput(false); } std::throw_with_nested(FormatRuntimeError("Failed to convert for \"%s\" [%s]", GetName(), output->plugin.name)); } } + + { + const ScopeUnlock unlock(mutex); + output->OpenSoftwareMixer(); + } } inline bool