Commit 5e567ccf authored by Rémi Duraffort's avatar Rémi Duraffort

taglib: Fix #2466 and fix also for writting tag on win.

parent b9dfd946
...@@ -326,14 +326,29 @@ static int ReadMeta( vlc_object_t* p_this) ...@@ -326,14 +326,29 @@ static int ReadMeta( vlc_object_t* p_this)
demux_t* p_demux = (demux_t*)p_this; demux_t* p_demux = (demux_t*)p_this;
demux_meta_t* p_demux_meta = (demux_meta_t*)p_demux->p_private; demux_meta_t* p_demux_meta = (demux_meta_t*)p_demux->p_private;
vlc_meta_t* p_meta; vlc_meta_t* p_meta;
TagLib::FileRef f; FileRef f;
p_demux_meta->p_meta = NULL; p_demux_meta->p_meta = NULL;
#if defined(WIN32) || defined (UNDER_CE)
if(GetVersion() < 0x80000000)
{
wchar_t wpath[MAX_PATH + 1];
if( !MultiByteToWideChar( CP_UTF8, 0, p_demux->psz_path, -1, wpath, MAX_PATH) )
return VLC_EGENERIC;
wpath[MAX_PATH] = L'\0';
f = FileRef( wpath );
}
else
return VLC_EGENERIC;
#else
const char* local_name = ToLocale( p_demux->psz_path ); const char* local_name = ToLocale( p_demux->psz_path );
if( !local_name ) if( !local_name )
return VLC_EGENERIC; return VLC_EGENERIC;
f = FileRef( local_name ); f = FileRef( local_name );
LocaleFree( local_name ); LocaleFree( local_name );
#endif
if( f.isNull() ) if( f.isNull() )
return VLC_EGENERIC; return VLC_EGENERIC;
...@@ -510,6 +525,7 @@ static int WriteMeta( vlc_object_t *p_this ) ...@@ -510,6 +525,7 @@ static int WriteMeta( vlc_object_t *p_this )
playlist_t *p_playlist = (playlist_t *)p_this; playlist_t *p_playlist = (playlist_t *)p_this;
meta_export_t *p_export = (meta_export_t *)p_playlist->p_private; meta_export_t *p_export = (meta_export_t *)p_playlist->p_private;
input_item_t *p_item = p_export->p_item; input_item_t *p_item = p_export->p_item;
FileRef f;
if( !p_item ) if( !p_item )
{ {
...@@ -517,7 +533,25 @@ static int WriteMeta( vlc_object_t *p_this ) ...@@ -517,7 +533,25 @@ static int WriteMeta( vlc_object_t *p_this )
return VLC_EGENERIC; return VLC_EGENERIC;
} }
FileRef f( p_export->psz_file ); #if defined(WIN32) || defined (UNDER_CE)
if(GetVersion() < 0x80000000)
{
wchar_t wpath[MAX_PATH + 1];
if( !MultiByteToWideChar( CP_UTF8, 0, p_export->psz_file, -1, wpath, MAX_PATH) )
return VLC_EGENERIC;
wpath[MAX_PATH] = L'\0';
f = FileRef( wpath );
}
else
return VLC_EGENERIC;
#else
const char* local_name = ToLocale( p_export->psz_file );
if( !local_name )
return VLC_EGENERIC;
f = FileRef( local_name );
LocaleFree( local_name );
#endif
if( f.isNull() || !f.tag() || f.file()->readOnly() ) if( f.isNull() || !f.tag() || f.file()->readOnly() )
{ {
msg_Err( p_this, "File %s can't be opened for tag writing\n", msg_Err( p_this, "File %s can't be opened for tag writing\n",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment