Attempt to write fragments and check whether we can notify the client

after every message.
This commit is contained in:
Huw D M Davies 2001-05-29 20:52:23 +00:00 committed by Alexandre Julliard
parent 784fd59e43
commit 738e2461f0
1 changed files with 18 additions and 6 deletions

View File

@ -642,6 +642,7 @@ static DWORD CALLBACK wodPlayer(LPVOID pmt)
int msg; int msg;
DWORD param; DWORD param;
DWORD tc; DWORD tc;
BOOL had_msg;
wwo->state = WINE_WS_STOPPED; wwo->state = WINE_WS_STOPPED;
@ -678,11 +679,14 @@ static DWORD CALLBACK wodPlayer(LPVOID pmt)
dwSleepTime = 0; dwSleepTime = 0;
} }
TRACE("imhere[1]\n"); TRACE("imhere[1] tc = %08lx\n", GetTickCount());
if (dwSleepTime) if (dwSleepTime)
WaitForSingleObject(wwo->msg_event, dwSleepTime); WaitForSingleObject(wwo->msg_event, dwSleepTime);
TRACE("imhere[2] (q=%p p=%p)\n", wwo->lpQueuePtr, wwo->lpPlayPtr); TRACE("imhere[2] (q=%p p=%p) tc = %08lx\n", wwo->lpQueuePtr,
wwo->lpPlayPtr, GetTickCount());
had_msg = FALSE;
while (wodPlayer_RetrieveMessage(wwo, &msg, &param)) { while (wodPlayer_RetrieveMessage(wwo, &msg, &param)) {
had_msg = TRUE;
switch (msg) { switch (msg) {
case WINE_WM_PAUSING: case WINE_WM_PAUSING:
wodPlayer_Reset(wwo, uDevID, FALSE); wodPlayer_Reset(wwo, uDevID, FALSE);
@ -722,11 +726,19 @@ static DWORD CALLBACK wodPlayer(LPVOID pmt)
FIXME("unknown message %d\n", msg); FIXME("unknown message %d\n", msg);
break; break;
} }
if (wwo->state == WINE_WS_PLAYING) {
wodPlayer_WriteFragments(wwo);
}
wodPlayer_Notify(wwo, uDevID, FALSE);
} }
if (wwo->state == WINE_WS_PLAYING) {
wodPlayer_WriteFragments(wwo); if (!had_msg) { /* if we've received a msg we've just done this so we
won't repeat it */
if (wwo->state == WINE_WS_PLAYING) {
wodPlayer_WriteFragments(wwo);
}
wodPlayer_Notify(wwo, uDevID, FALSE);
} }
wodPlayer_Notify(wwo, uDevID, FALSE);
} }
ExitThread(0); ExitThread(0);
/* just for not generating compilation warnings... should never be executed */ /* just for not generating compilation warnings... should never be executed */