[PATCH 7/7] mfplay: Implement MFP_EVENT_TYPE_MF event.

Nikolay Sivov nsivov at codeweavers.com
Tue Apr 13 01:03:34 CDT 2021


Signed-off-by: Nikolay Sivov <nsivov at codeweavers.com>
---
 dlls/mfplay/player.c | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)

diff --git a/dlls/mfplay/player.c b/dlls/mfplay/player.c
index a95e1d3ca36..b098d880461 100644
--- a/dlls/mfplay/player.c
+++ b/dlls/mfplay/player.c
@@ -1488,6 +1488,21 @@ static void media_player_clear_item(struct media_player *player, HRESULT event_s
     LeaveCriticalSection(&player->cs);
 }
 
+static void media_player_create_forward_event(struct media_player *player, HRESULT event_status, IMFMediaEvent *session_event,
+        struct media_event **event)
+{
+    EnterCriticalSection(&player->cs);
+
+    if (SUCCEEDED(media_event_create(player, MFP_EVENT_TYPE_MF, event_status, player->item, event)))
+    {
+        IMFMediaEvent_GetType(session_event, &(*event)->u.event.MFEventType);
+        (*event)->u.event.pMFMediaEvent = session_event;
+        IMFMediaEvent_AddRef((*event)->u.event.pMFMediaEvent);
+    }
+
+    LeaveCriticalSection(&player->cs);
+}
+
 static HRESULT WINAPI media_player_session_events_callback_Invoke(IMFAsyncCallback *iface,
         IMFAsyncResult *result)
 {
@@ -1543,6 +1558,19 @@ static HRESULT WINAPI media_player_session_events_callback_Invoke(IMFAsyncCallba
             }
 
             break;
+
+        case MEBufferingStarted:
+        case MEBufferingStopped:
+        case MEExtendedType:
+        case MEReconnectStart:
+        case MEReconnectEnd:
+        case MERendererEvent:
+        case MEStreamSinkFormatChanged:
+
+            media_player_create_forward_event(player, event_status, session_event, &event);
+
+            break;
+
         default:
             ;
     }
-- 
2.30.2




More information about the wine-devel mailing list