From 9154c1458ece8b90e7d36b55a97ff364b8cf54f0 Mon Sep 17 00:00:00 2001 From: Alibek Omarov Date: Tue, 28 Mar 2023 21:08:22 +0300 Subject: [PATCH] engine: client: avi: convert filename to wide characters before passing it into VFW API --- engine/client/avi/avi_win.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/engine/client/avi/avi_win.c b/engine/client/avi/avi_win.c index 534b31ceb4..075c8148ff 100644 --- a/engine/client/avi/avi_win.c +++ b/engine/client/avi/avi_win.c @@ -63,7 +63,7 @@ static int (_stdcall *pAVIStreamTimeToSample)( PAVISTREAM pavi, LONG lTime ); static void* (_stdcall *pAVIStreamGetFrame)( PGETFRAME pg, LONG lPos ); static int (_stdcall *pAVIStreamGetFrameClose)( PGETFRAME pg ); static dword (_stdcall *pAVIStreamRelease)( PAVISTREAM pavi ); -static int (_stdcall *pAVIFileOpen)( PAVIFILE *ppfile, LPCSTR szFile, UINT uMode, LPCLSID lpHandler ); +static int (_stdcall *pAVIFileOpenW)( PAVIFILE *ppfile, LPCWSTR szFile, UINT uMode, LPCLSID lpHandler ); static int (_stdcall *pAVIFileGetStream)( PAVIFILE pfile, PAVISTREAM *ppavi, DWORD fccType, LONG lParam ); static int (_stdcall *pAVIStreamReadFormat)( PAVISTREAM pavi, LONG lPos,LPVOID lpFormat, LONG *lpcbFormat ); static int (_stdcall *pAVIStreamStart)( PAVISTREAM pavi ); @@ -76,7 +76,7 @@ static dllfunc_t avifile_funcs[] = { "AVIFileExit", (void **) &pAVIFileExit }, { "AVIFileGetStream", (void **) &pAVIFileGetStream }, { "AVIFileInit", (void **) &pAVIFileInit }, -{ "AVIFileOpenA", (void **) &pAVIFileOpen }, +{ "AVIFileOpenW", (void **) &pAVIFileOpenW }, { "AVIFileRelease", (void **) &pAVIFileRelease }, { "AVIStreamGetFrame", (void **) &pAVIStreamGetFrame }, { "AVIStreamGetFrameClose", (void **) &pAVIStreamGetFrameClose }, @@ -493,6 +493,7 @@ void AVI_OpenVideo( movie_state_t *Avi, const char *filename, qboolean load_audi AVISTREAMINFO stream_info; int opened_streams = 0; LONG hr; + wchar_t pathBuffer[MAX_PATH]; // default state: non-working. Avi->active = false; @@ -501,8 +502,15 @@ void AVI_OpenVideo( movie_state_t *Avi, const char *filename, qboolean load_audi // can't load Video For Windows :-( if( !avi_initialized ) return; + // convert to wide char + if( MultiByteToWideChar( CP_UTF8, 0, filename, -1, pathBuffer, ARRAYSIZE( pathBuffer ) <= 0 ) + { + Con_DPrintf( S_ERROR "filename buffer limit exceeded\n" ); + return; + } + // load the AVI - hr = pAVIFileOpen( &Avi->pfile, filename, OF_SHARE_DENY_WRITE, 0L ); + hr = pAVIFileOpenW( &Avi->pfile, pathBuffer, OF_SHARE_DENY_WRITE, 0L ); if( hr != 0 ) // error opening AVI: {