Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
1de1e4ea
Commit
1de1e4ea
authored
Aug 13, 2005
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- convert UTF16/UTF32 to UTF8 rather than Latin1 - closes #287
parent
203eeb89
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
38 deletions
+13
-38
modules/demux/mkv.cpp
modules/demux/mkv.cpp
+13
-38
No files found.
modules/demux/mkv.cpp
View file @
1de1e4ea
...
@@ -1373,7 +1373,10 @@ static void Seek ( demux_t *, mtime_t i_date, double f_percent, chapter_item_c
...
@@ -1373,7 +1373,10 @@ static void Seek ( demux_t *, mtime_t i_date, double f_percent, chapter_item_c
#define MKV_IS_ID( el, C ) ( EbmlId( (*el) ) == C::ClassInfos.GlobalId )
#define MKV_IS_ID( el, C ) ( EbmlId( (*el) ) == C::ClassInfos.GlobalId )
static
char
*
UTF8ToStr
(
const
UTFstring
&
u
);
static
inline
char
*
ToUTF8
(
const
UTFstring
&
u
)
{
return
strdup
(
u
.
GetUTF8
().
c_str
()
);
}
/*****************************************************************************
/*****************************************************************************
* Open: initializes matroska demux structures
* Open: initializes matroska demux structures
...
@@ -3962,7 +3965,7 @@ void matroska_segment_c::ParseTrackEntry( KaxTrackEntry *m )
...
@@ -3962,7 +3965,7 @@ void matroska_segment_c::ParseTrackEntry( KaxTrackEntry *m )
{
{
KaxTrackName
&
tname
=
*
(
KaxTrackName
*
)
l
;
KaxTrackName
&
tname
=
*
(
KaxTrackName
*
)
l
;
tk
->
fmt
.
psz_description
=
UTF8ToStr
(
UTFstring
(
tname
)
);
tk
->
fmt
.
psz_description
=
ToUTF8
(
UTFstring
(
tname
)
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | | + Track Name=%s"
,
tk
->
fmt
.
psz_description
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | | + Track Name=%s"
,
tk
->
fmt
.
psz_description
);
}
}
else
if
(
MKV_IS_ID
(
l
,
KaxTrackLanguage
)
)
else
if
(
MKV_IS_ID
(
l
,
KaxTrackLanguage
)
)
...
@@ -3996,7 +3999,7 @@ void matroska_segment_c::ParseTrackEntry( KaxTrackEntry *m )
...
@@ -3996,7 +3999,7 @@ void matroska_segment_c::ParseTrackEntry( KaxTrackEntry *m )
{
{
KaxCodecName
&
cname
=
*
(
KaxCodecName
*
)
l
;
KaxCodecName
&
cname
=
*
(
KaxCodecName
*
)
l
;
tk
->
psz_codec_name
=
UTF8ToStr
(
UTFstring
(
cname
)
);
tk
->
psz_codec_name
=
ToUTF8
(
UTFstring
(
cname
)
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | | + Track Codec Name=%s"
,
tk
->
psz_codec_name
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | | + Track Codec Name=%s"
,
tk
->
psz_codec_name
);
}
}
else
if
(
MKV_IS_ID
(
l
,
KaxContentEncodings
)
)
else
if
(
MKV_IS_ID
(
l
,
KaxContentEncodings
)
)
...
@@ -4069,7 +4072,7 @@ void matroska_segment_c::ParseTrackEntry( KaxTrackEntry *m )
...
@@ -4069,7 +4072,7 @@ void matroska_segment_c::ParseTrackEntry( KaxTrackEntry *m )
// {
// {
// KaxCodecSettings &cset = *(KaxCodecSettings*)l;
// KaxCodecSettings &cset = *(KaxCodecSettings*)l;
// tk->psz_codec_settings =
UTF8ToStr
( UTFstring( cset ) );
// tk->psz_codec_settings =
ToUTF8
( UTFstring( cset ) );
// msg_Dbg( &sys.demuxer, "| | | + Track Codec Settings=%s", tk->psz_codec_settings );
// msg_Dbg( &sys.demuxer, "| | | + Track Codec Settings=%s", tk->psz_codec_settings );
// }
// }
// else if( EbmlId( *l ) == KaxCodecInfoURL::ClassInfos.GlobalId )
// else if( EbmlId( *l ) == KaxCodecInfoURL::ClassInfos.GlobalId )
...
@@ -4322,7 +4325,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
...
@@ -4322,7 +4325,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
{
{
KaxMuxingApp
&
mapp
=
*
(
KaxMuxingApp
*
)
l
;
KaxMuxingApp
&
mapp
=
*
(
KaxMuxingApp
*
)
l
;
psz_muxing_application
=
UTF8ToStr
(
UTFstring
(
mapp
)
);
psz_muxing_application
=
ToUTF8
(
UTFstring
(
mapp
)
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Muxing Application=%s"
,
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Muxing Application=%s"
,
psz_muxing_application
);
psz_muxing_application
);
...
@@ -4331,7 +4334,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
...
@@ -4331,7 +4334,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
{
{
KaxWritingApp
&
wapp
=
*
(
KaxWritingApp
*
)
l
;
KaxWritingApp
&
wapp
=
*
(
KaxWritingApp
*
)
l
;
psz_writing_application
=
UTF8ToStr
(
UTFstring
(
wapp
)
);
psz_writing_application
=
ToUTF8
(
UTFstring
(
wapp
)
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Writing Application=%s"
,
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Writing Application=%s"
,
psz_writing_application
);
psz_writing_application
);
...
@@ -4340,7 +4343,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
...
@@ -4340,7 +4343,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
{
{
KaxSegmentFilename
&
sfn
=
*
(
KaxSegmentFilename
*
)
l
;
KaxSegmentFilename
&
sfn
=
*
(
KaxSegmentFilename
*
)
l
;
psz_segment_filename
=
UTF8ToStr
(
UTFstring
(
sfn
)
);
psz_segment_filename
=
ToUTF8
(
UTFstring
(
sfn
)
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Segment Filename=%s"
,
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Segment Filename=%s"
,
psz_segment_filename
);
psz_segment_filename
);
...
@@ -4349,7 +4352,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
...
@@ -4349,7 +4352,7 @@ void matroska_segment_c::ParseInfo( KaxInfo *info )
{
{
KaxTitle
&
title
=
*
(
KaxTitle
*
)
l
;
KaxTitle
&
title
=
*
(
KaxTitle
*
)
l
;
psz_title
=
UTF8ToStr
(
UTFstring
(
title
)
);
psz_title
=
ToUTF8
(
UTFstring
(
title
)
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Title=%s"
,
psz_title
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | + Title=%s"
,
psz_title
);
}
}
...
@@ -4474,10 +4477,10 @@ void matroska_segment_c::ParseChapterAtom( int i_level, KaxChapterAtom *ca, chap
...
@@ -4474,10 +4477,10 @@ void matroska_segment_c::ParseChapterAtom( int i_level, KaxChapterAtom *ca, chap
for
(
k
=
0
;
k
<
i_level
;
k
++
)
for
(
k
=
0
;
k
<
i_level
;
k
++
)
chapters
.
psz_name
+=
'+'
;
chapters
.
psz_name
+=
'+'
;
chapters
.
psz_name
+=
' '
;
chapters
.
psz_name
+=
' '
;
chapters
.
psz_name
+=
UTF8ToStr
(
UTFstring
(
name
)
);
chapters
.
psz_name
+=
ToUTF8
(
UTFstring
(
name
)
);
chapters
.
b_user_display
=
true
;
chapters
.
b_user_display
=
true
;
msg_Dbg
(
&
sys
.
demuxer
,
"| | | | | + ChapterString '%s'"
,
UTF8ToStr
(
UTFstring
(
name
))
);
msg_Dbg
(
&
sys
.
demuxer
,
"| | | | | + ChapterString '%s'"
,
ToUTF8
(
UTFstring
(
name
))
);
}
}
else
if
(
MKV_IS_ID
(
l
,
KaxChapterLanguage
)
)
else
if
(
MKV_IS_ID
(
l
,
KaxChapterLanguage
)
)
{
{
...
@@ -4743,34 +4746,6 @@ void matroska_segment_c::IndexAppendCluster( KaxCluster *cluster )
...
@@ -4743,34 +4746,6 @@ void matroska_segment_c::IndexAppendCluster( KaxCluster *cluster )
#undef idx
#undef idx
}
}
static
char
*
UTF8ToStr
(
const
UTFstring
&
u
)
{
int
i_src
;
const
wchar_t
*
src
;
char
*
dst
,
*
p
;
i_src
=
u
.
length
();
src
=
u
.
c_str
();
p
=
dst
=
(
char
*
)
malloc
(
i_src
+
1
);
while
(
i_src
>
0
)
{
if
(
*
src
<
255
)
{
*
p
++
=
(
char
)
*
src
;
}
else
{
*
p
++
=
'?'
;
}
src
++
;
i_src
--
;
}
*
p
++=
'\0'
;
return
dst
;
}
void
chapter_edition_c
::
RefreshChapters
(
)
void
chapter_edition_c
::
RefreshChapters
(
)
{
{
chapter_item_c
::
RefreshChapters
(
b_ordered
,
-
1
);
chapter_item_c
::
RefreshChapters
(
b_ordered
,
-
1
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment