output/wasapi: move catch block to the Work() function level
If an exception has been caught, the method cannot continue playback, therefore it doesn't make sense to have the "catch" block inside the "while" block (and not break the loop after catching an exception).
This commit is contained in:
parent
3a0dbb0a67
commit
9256190a9b
@ -317,63 +317,61 @@ wasapi_output_get_client(WasapiOutput &output) noexcept
|
|||||||
|
|
||||||
inline void
|
inline void
|
||||||
WasapiOutputThread::Work() noexcept
|
WasapiOutputThread::Work() noexcept
|
||||||
{
|
try {
|
||||||
SetThreadName("Wasapi Output Worker");
|
SetThreadName("Wasapi Output Worker");
|
||||||
FormatDebug(wasapi_output_domain, "Working thread started");
|
FormatDebug(wasapi_output_domain, "Working thread started");
|
||||||
COM com;
|
COM com;
|
||||||
while (true) {
|
while (true) {
|
||||||
try {
|
event.Wait();
|
||||||
event.Wait();
|
|
||||||
|
|
||||||
Status current_state = status.load();
|
Status current_state = status.load();
|
||||||
if (current_state == Status::FINISH) {
|
if (current_state == Status::FINISH) {
|
||||||
FormatDebug(wasapi_output_domain,
|
FormatDebug(wasapi_output_domain,
|
||||||
"Working thread stopped");
|
"Working thread stopped");
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
UINT32 write_in_frames = buffer_size_in_frames;
|
||||||
|
if (!is_exclusive) {
|
||||||
|
UINT32 data_in_frames =
|
||||||
|
GetCurrentPaddingFrames(client);
|
||||||
|
|
||||||
|
if (data_in_frames >= buffer_size_in_frames) {
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
write_in_frames -= data_in_frames;
|
||||||
|
}
|
||||||
|
|
||||||
UINT32 write_in_frames = buffer_size_in_frames;
|
BYTE *data;
|
||||||
if (!is_exclusive) {
|
DWORD mode = 0;
|
||||||
UINT32 data_in_frames =
|
|
||||||
GetCurrentPaddingFrames(client);
|
|
||||||
|
|
||||||
if (data_in_frames >= buffer_size_in_frames) {
|
if (HRESULT result =
|
||||||
continue;
|
render_client->GetBuffer(write_in_frames, &data);
|
||||||
}
|
FAILED(result)) {
|
||||||
write_in_frames -= data_in_frames;
|
throw MakeHResultError(result, "Failed to get buffer");
|
||||||
}
|
}
|
||||||
|
|
||||||
BYTE *data;
|
AtScopeExit(&) {
|
||||||
DWORD mode = 0;
|
render_client->ReleaseBuffer(write_in_frames, mode);
|
||||||
|
};
|
||||||
|
|
||||||
if (HRESULT result =
|
if (current_state == Status::PLAY) {
|
||||||
render_client->GetBuffer(write_in_frames, &data);
|
const UINT32 write_size = write_in_frames * frame_size;
|
||||||
FAILED(result)) {
|
UINT32 new_data_size = 0;
|
||||||
throw MakeHResultError(result, "Failed to get buffer");
|
new_data_size = spsc_buffer.pop(data, write_size);
|
||||||
}
|
std::fill_n(data + new_data_size,
|
||||||
|
write_size - new_data_size, 0);
|
||||||
AtScopeExit(&) {
|
data_poped.Set();
|
||||||
render_client->ReleaseBuffer(write_in_frames, mode);
|
} else {
|
||||||
};
|
mode = AUDCLNT_BUFFERFLAGS_SILENT;
|
||||||
|
FormatDebug(wasapi_output_domain,
|
||||||
if (current_state == Status::PLAY) {
|
"Working thread paused");
|
||||||
const UINT32 write_size = write_in_frames * frame_size;
|
|
||||||
UINT32 new_data_size = 0;
|
|
||||||
new_data_size = spsc_buffer.pop(data, write_size);
|
|
||||||
std::fill_n(data + new_data_size,
|
|
||||||
write_size - new_data_size, 0);
|
|
||||||
data_poped.Set();
|
|
||||||
} else {
|
|
||||||
mode = AUDCLNT_BUFFERFLAGS_SILENT;
|
|
||||||
FormatDebug(wasapi_output_domain,
|
|
||||||
"Working thread paused");
|
|
||||||
}
|
|
||||||
} catch (...) {
|
|
||||||
error.ptr = std::current_exception();
|
|
||||||
error.occur.store(true);
|
|
||||||
error.thrown.Wait();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} catch (...) {
|
||||||
|
error.ptr = std::current_exception();
|
||||||
|
error.occur.store(true);
|
||||||
|
error.thrown.Wait();
|
||||||
}
|
}
|
||||||
|
|
||||||
AudioOutput *
|
AudioOutput *
|
||||||
|
Loading…
Reference in New Issue
Block a user