[FFmpeg-devel] [PATCH] avisynth: Make sure the filename passed to avisynth is in the right code page
Motofumi Oka
chikuzen.mo at gmail.com
Sat Jun 22 21:48:48 CEST 2013
I changed (MAX_AVS_PATH_LENGTH) into (MAX_PATH * 4) in order to avoid
the possibility of overflow.
From: Oka Motofumi <chikuzen.mo at gmail.com
<http://ffmpeg.org/mailman/listinfo/ffmpeg-devel>>
Date: Fri, 21 Jun 2013 22:57:03 +0900
Subject: [PATCH] avisynth: Make sure the filename passed to avisynth is in
the right code page
avisynth is a non-unicode application and cannot accept UTF-8
characters. Therefore, the input filename should be converted to
the correct code page that it expects.
---
libavformat/avisynth.c | 12 ++++++++++++
1 file changed, 12 insertions(+)
diff --git a/libavformat/avisynth.c b/libavformat/avisynth.c
index a5a4fcc..c2e7920 100644
--- a/libavformat/avisynth.c
+++ b/libavformat/avisynth.c
@@ -355,11 +355,23 @@ static int avisynth_open_file(AVFormatContext *s) {
AviSynthContext *avs = (AviSynthContext *)s->priv_data;
AVS_Value arg, val;
int ret;
+#ifdef _WIN32
+ char filename_ansi[MAX_PATH * 4];
+ wchar_t filename_wc[MAX_PATH * 4];
+#endif
if (ret = avisynth_context_create(s))
return ret;
+#ifdef _WIN32
+ // Convert UTF-8 to ANSI code page
+ MultiByteToWideChar(CP_UTF8, 0, s->filename, -1, filename_wc,
MAX_PATH * 4);
+ WideCharToMultiByte(CP_THREAD_ACP, 0, filename_wc, -1, filename_ansi,
MAX_PATH * 4, NULL, NULL);
+ arg = avs_new_value_string(filename_ansi);
+#else
arg = avs_new_value_string(s->filename);
+#endif
val = avs_library->avs_invoke(avs->env, "Import", arg, 0);
if (avs_is_error(val)) {
av_log(s, AV_LOG_ERROR, "%s\n", avs_as_error(val));
--
1.7.11.msysgit.1
More information about the ffmpeg-devel
mailing list