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
950705a7
Commit
950705a7
authored
Dec 04, 2011
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
subsdec: avoid unneeded strdup() and simplify
parent
de721bf9
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
34 deletions
+21
-34
modules/codec/subsdec.c
modules/codec/subsdec.c
+21
-34
No files found.
modules/codec/subsdec.c
View file @
950705a7
...
@@ -246,36 +246,36 @@ static int OpenDecoder( vlc_object_t *p_this )
...
@@ -246,36 +246,36 @@ static int OpenDecoder( vlc_object_t *p_this )
p_sys
->
iconv_handle
=
(
vlc_iconv_t
)
-
1
;
p_sys
->
iconv_handle
=
(
vlc_iconv_t
)
-
1
;
p_sys
->
b_autodetect_utf8
=
false
;
p_sys
->
b_autodetect_utf8
=
false
;
char
*
psz_charset
=
NULL
;
const
char
*
encoding
;
char
*
var
=
NULL
;
/* First try demux-specified encoding */
/* First try demux-specified encoding */
if
(
p_dec
->
fmt_in
.
i_codec
==
VLC_CODEC_ITU_T140
)
if
(
p_dec
->
fmt_in
.
i_codec
==
VLC_CODEC_ITU_T140
)
psz_charset
=
strdup
(
"UTF-8"
)
;
/* IUT T.140 is always using UTF-8 */
encoding
=
"UTF-8"
;
/* IUT T.140 is always using UTF-8 */
else
else
if
(
p_dec
->
fmt_in
.
subs
.
psz_encoding
&&
*
p_dec
->
fmt_in
.
subs
.
psz_encoding
)
if
(
p_dec
->
fmt_in
.
subs
.
psz_encoding
&&
*
p_dec
->
fmt_in
.
subs
.
psz_encoding
)
{
{
psz_charset
=
strdup
(
p_dec
->
fmt_in
.
subs
.
psz_encoding
)
;
encoding
=
p_dec
->
fmt_in
.
subs
.
psz_encoding
;
msg_Dbg
(
p_dec
,
"trying demuxer-specified character encoding: %s"
,
msg_Dbg
(
p_dec
,
"trying demuxer-specified character encoding: %s"
,
p_dec
->
fmt_in
.
subs
.
psz_encoding
?
encoding
);
p_dec
->
fmt_in
.
subs
.
psz_encoding
:
"not specified"
);
}
}
else
/* Second, try configured encoding */
/* Second, try configured encoding */
if
(
psz_charset
=
=
NULL
)
if
(
(
var
=
var_InheritString
(
p_dec
,
"subsdec-encoding"
))
!
=
NULL
)
{
{
psz_charset
=
var_InheritString
(
p_dec
,
"subsdec-encoding"
);
msg_Dbg
(
p_dec
,
"trying configured character encoding: %s"
,
var
);
msg_Dbg
(
p_dec
,
"trying configured character encoding: %s"
,
if
(
!
strcmp
(
var
,
"system"
))
psz_charset
?
psz_charset
:
"not specified"
);
if
(
psz_charset
!=
NULL
&&
!
strcmp
(
psz_charset
,
"system"
))
{
{
free
(
psz_charset
);
free
(
var
);
psz_charset
=
strdup
(
""
);
var
=
NULL
;
encoding
=
""
;
/* ^ iconv() treats "" as nl_langinfo(CODESET) */
/* ^ iconv() treats "" as nl_langinfo(CODESET) */
}
}
else
encoding
=
var
;
}
}
else
/* Third, try "local" encoding with optional UTF-8 autodetection */
/* Third, try "local" encoding with optional UTF-8 autodetection */
if
(
psz_charset
==
NULL
)
{
{
/* xgettext:
/* xgettext:
The Windows ANSI code page most commonly used for this language.
The Windows ANSI code page most commonly used for this language.
...
@@ -287,12 +287,8 @@ static int OpenDecoder( vlc_object_t *p_this )
...
@@ -287,12 +287,8 @@ static int OpenDecoder( vlc_object_t *p_this )
This MUST be a valid iconv character set. If unsure, please refer
This MUST be a valid iconv character set. If unsure, please refer
the VideoLAN translators mailing list. */
the VideoLAN translators mailing list. */
const
char
*
acp
=
vlc_pgettext
(
"GetACP"
,
"CP1252"
);
encoding
=
vlc_pgettext
(
"GetACP"
,
"CP1252"
);
msg_Dbg
(
p_dec
,
"trying default character encoding: %s"
,
encoding
);
psz_charset
=
strdup
(
acp
);
msg_Dbg
(
p_dec
,
"trying default character encoding: %s"
,
psz_charset
?
psz_charset
:
"not specified"
);
if
(
var_InheritBool
(
p_dec
,
"subsdec-autodetect-utf8"
))
if
(
var_InheritBool
(
p_dec
,
"subsdec-autodetect-utf8"
))
{
{
msg_Dbg
(
p_dec
,
"using automatic UTF-8 detection"
);
msg_Dbg
(
p_dec
,
"using automatic UTF-8 detection"
);
...
@@ -300,22 +296,13 @@ static int OpenDecoder( vlc_object_t *p_this )
...
@@ -300,22 +296,13 @@ static int OpenDecoder( vlc_object_t *p_this )
}
}
}
}
/* Forth, don't do character decoding, i.e. assume UTF-8 */
if
(
strcasecmp
(
encoding
,
"UTF-8"
)
&&
strcasecmp
(
encoding
,
"utf8"
))
if
(
psz_charset
==
NULL
)
{
psz_charset
=
strdup
(
"UTF-8"
);
msg_Dbg
(
p_dec
,
"using UTF-8 character encoding"
);
}
if
((
psz_charset
!=
NULL
)
&&
strcasecmp
(
psz_charset
,
"UTF-8"
)
&&
strcasecmp
(
psz_charset
,
"utf8"
))
{
{
p_sys
->
iconv_handle
=
vlc_iconv_open
(
"UTF-8"
,
psz_charset
);
p_sys
->
iconv_handle
=
vlc_iconv_open
(
"UTF-8"
,
encoding
);
if
(
p_sys
->
iconv_handle
==
(
vlc_iconv_t
)(
-
1
))
if
(
p_sys
->
iconv_handle
==
(
vlc_iconv_t
)(
-
1
))
msg_Err
(
p_dec
,
"cannot convert from %s: %m"
,
psz_charset
);
msg_Err
(
p_dec
,
"cannot convert from %s: %m"
,
encoding
);
}
}
free
(
psz_charset
);
free
(
var
);
p_sys
->
i_align
=
var_InheritInteger
(
p_dec
,
"subsdec-align"
);
p_sys
->
i_align
=
var_InheritInteger
(
p_dec
,
"subsdec-align"
);
...
...
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