@@ -230,9 +230,10 @@ gdigrab_read_header(AVFormatContext *s1)
HBITMAP hbmp = NULL;
void *buffer = NULL;
- const char *filename = s1->url;
- const char *name = NULL;
- AVStream *st = NULL;
+ const char *filename = s1->url;
+ const char *name = NULL;
+ const wchar_t *name_w = NULL;
+ AVStream *st = NULL;
int bpp;
int horzres;
@@ -246,7 +247,17 @@ gdigrab_read_header(AVFormatContext *s1)
if (!strncmp(filename, "title=", 6)) {
name = filename + 6;
- hwnd = FindWindow(NULL, name);
+ if(utf8towchar(name, &name_w)) {
+ ret = AVERROR(ENOMEM);
+ goto error;
+ }
+ if(!name_w) {
+ ret = AVERROR(EINVAL);
+ goto error;
+ }
+ hwnd = FindWindowW(NULL, name_w);
+ av_free(name_w);
+ name_w = NULL;
if (!hwnd) {
av_log(s1, AV_LOG_ERROR,
"Can't find window '%s', aborting.\n", name);