From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/Plugins/Input/in_wmvdrm/WaitLayer.cpp | 49 +++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 Src/Plugins/Input/in_wmvdrm/WaitLayer.cpp (limited to 'Src/Plugins/Input/in_wmvdrm/WaitLayer.cpp') diff --git a/Src/Plugins/Input/in_wmvdrm/WaitLayer.cpp b/Src/Plugins/Input/in_wmvdrm/WaitLayer.cpp new file mode 100644 index 00000000..39192a8e --- /dev/null +++ b/Src/Plugins/Input/in_wmvdrm/WaitLayer.cpp @@ -0,0 +1,49 @@ +#include "main.h" +#include "WaitLayer.h" +#include "util.h" + +WaitLayer::WaitLayer(IWMReader *_reader) +: reader(_reader), stopEvent(0) +{ + reader->AddRef(); + openEvent = CreateEvent(0, TRUE, FALSE, 0); +} + +WaitLayer::~WaitLayer() +{ + reader->Release(); + reader=0; +} + +void WaitLayer::Opened() +{ + SetEvent(openEvent); + WMHandler::Opened(); +} + +bool WaitLayer::IsOpen() +{ + return WaitForSingleObject(openEvent, 0) == WAIT_OBJECT_0; +} + +void WaitLayer::OpenCalled() +{ + SetEvent(openEvent); + WMHandler::OpenCalled(); +} + +void WaitLayer::OpenFailed() +{ + SetEvent(openEvent); + WMHandler::OpenFailed(); +} + +bool WaitLayer::WaitForOpen(int time_ms) +{ + return WaitForSingleObject(openEvent, time_ms) == WAIT_OBJECT_0; +} + +void WaitLayer::ResetForOpen() +{ + ResetEvent(openEvent); +} \ No newline at end of file -- cgit