Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
a8fcedd2
Commit
a8fcedd2
authored
Jul 19, 2006
by
Clément Stenac
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove some code duplication
parent
13d09878
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
48 additions
and
154 deletions
+48
-154
include/vlc_common.h
include/vlc_common.h
+2
-0
modules/demux/playlist/podcast.c
modules/demux/playlist/podcast.c
+46
-154
No files found.
include/vlc_common.h
View file @
a8fcedd2
...
@@ -610,6 +610,8 @@ static int64_t GCD( int64_t a, int64_t b )
...
@@ -610,6 +610,8 @@ static int64_t GCD( int64_t a, int64_t b )
#define DECMALLOC_NULL( var, type ) type* var = (type*)malloc( sizeof(type) );\
#define DECMALLOC_NULL( var, type ) type* var = (type*)malloc( sizeof(type) );\
if( !var ) return NULL;
if( !var ) return NULL;
#define FREENULL(a) if( a ) { free( a ); a = NULL; }
/* Dynamic array handling: realloc array, move data, increment position */
/* Dynamic array handling: realloc array, move data, increment position */
#if defined( _MSC_VER ) && _MSC_VER < 1300 && !defined( UNDER_CE )
#if defined( _MSC_VER ) && _MSC_VER < 1300 && !defined( UNDER_CE )
# define VLCCVP (void**)
/* Work-around for broken compiler */
# define VLCCVP (void**)
/* Work-around for broken compiler */
...
...
modules/demux/playlist/podcast.c
View file @
a8fcedd2
...
@@ -197,109 +197,59 @@ static int Demux( demux_t *p_demux )
...
@@ -197,109 +197,59 @@ static int Demux( demux_t *p_demux )
}
}
case
XML_READER_TEXT
:
case
XML_READER_TEXT
:
{
{
#define SET_DATA( field, name ) else if( b_item == VLC_TRUE \
&& !strcmp( psz_elname, name ) ) \
{ \
field = strdup( psz_text ); \
}
char
*
psz_text
=
xml_ReaderValue
(
p_xml_reader
);
char
*
psz_text
=
xml_ReaderValue
(
p_xml_reader
);
/* item specific meta data */
/* item specific meta data */
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"title"
)
)
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"title"
)
)
{
{
psz_item_name
=
strdup
(
psz_text
);
psz_item_name
=
strdup
(
psz_text
);
}
}
else
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"pubDate"
)
)
{
psz_item_date
=
strdup
(
psz_text
);
}
else
if
(
b_item
==
VLC_TRUE
else
if
(
b_item
==
VLC_TRUE
&&
(
!
strcmp
(
psz_elname
,
"itunes:author"
)
&&
(
!
strcmp
(
psz_elname
,
"itunes:author"
)
||!
strcmp
(
psz_elname
,
"author"
)
)
)
||!
strcmp
(
psz_elname
,
"author"
)
)
)
{
/* <author> isn't standard iTunes podcast stuff */
{
/* <author> isn't standard iTunes podcast stuff */
psz_item_author
=
strdup
(
psz_text
);
psz_item_author
=
strdup
(
psz_text
);
}
}
else
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"itunes:category"
)
)
{
psz_item_category
=
strdup
(
psz_text
);
}
else
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"itunes:duration"
)
)
{
psz_item_duration
=
strdup
(
psz_text
);
}
else
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"itunes:keywords"
)
)
{
psz_item_keywords
=
strdup
(
psz_text
);
}
else
if
(
b_item
==
VLC_TRUE
&&
!
strcmp
(
psz_elname
,
"itunes:subtitle"
)
)
{
psz_item_subtitle
=
strdup
(
psz_text
);
}
else
if
(
b_item
==
VLC_TRUE
else
if
(
b_item
==
VLC_TRUE
&&
(
!
strcmp
(
psz_elname
,
"itunes:summary"
)
&&
(
!
strcmp
(
psz_elname
,
"itunes:summary"
)
||!
strcmp
(
psz_elname
,
"description"
)
)
)
||!
strcmp
(
psz_elname
,
"description"
)
)
)
{
/* <description> isn't standard iTunes podcast stuff */
{
/* <description> isn't standard iTunes podcast stuff */
psz_item_summary
=
strdup
(
psz_text
);
psz_item_summary
=
strdup
(
psz_text
);
}
}
SET_DATA
(
psz_item_date
,
"pubDate"
)
SET_DATA
(
psz_item_category
,
"itunes:category"
)
SET_DATA
(
psz_item_duration
,
"itunes:duration"
)
SET_DATA
(
psz_item_keywords
,
"itunes:keywords"
)
SET_DATA
(
psz_item_subtitle
,
"itunes:subtitle"
)
/* toplevel meta data */
/* toplevel meta data */
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
&&
!
strcmp
(
psz_elname
,
"title"
)
)
&&
!
strcmp
(
psz_elname
,
"title"
)
)
{
{
playlist_ItemSetName
(
p_current
,
psz_text
);
playlist_ItemSetName
(
p_current
,
psz_text
);
}
}
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
#define ADD_GINFO( info, name ) \
&&
!
strcmp
(
psz_elname
,
"link"
)
)
else if( !b_item && !b_image && !strcmp( psz_elname, name ) ) \
{
{ \
vlc_input_item_AddInfo
(
p_current
->
p_input
,
vlc_input_item_AddInfo( p_current->p_input, _("Podcast Info"), \
_
(
"Podcast Info"
),
_( info ), "%s", psz_text ); \
_
(
"Podcast Link"
),
}
"%s"
,
ADD_GINFO
(
"Podcast Link"
,
"link"
)
psz_text
);
ADD_GINFO
(
"Podcast Copyright"
,
"copyright"
)
}
ADD_GINFO
(
"Podcast Category"
,
"itunes:category"
)
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
ADD_GINFO
(
"Podcast Keywords"
,
"itunes:keywords"
)
&&
!
strcmp
(
psz_elname
,
"copyright"
)
)
ADD_GINFO
(
"Podcast Subtitle"
,
"itunes:subtitle"
)
{
#undef ADD_GINFO
vlc_input_item_AddInfo
(
p_current
->
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Copyright"
),
"%s"
,
psz_text
);
}
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
&&
!
strcmp
(
psz_elname
,
"itunes:category"
)
)
{
vlc_input_item_AddInfo
(
p_current
->
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Category"
),
"%s"
,
psz_text
);
}
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
&&
!
strcmp
(
psz_elname
,
"itunes:keywords"
)
)
{
vlc_input_item_AddInfo
(
p_current
->
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Keywords"
),
"%s"
,
psz_text
);
}
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
&&
!
strcmp
(
psz_elname
,
"itunes:subtitle"
)
)
{
vlc_input_item_AddInfo
(
p_current
->
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Subtitle"
),
"%s"
,
psz_text
);
}
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
else
if
(
b_item
==
VLC_FALSE
&&
b_image
==
VLC_FALSE
&&
(
!
strcmp
(
psz_elname
,
"itunes:summary"
)
&&
(
!
strcmp
(
psz_elname
,
"itunes:summary"
)
||!
strcmp
(
psz_elname
,
"description"
)
)
)
||!
strcmp
(
psz_elname
,
"description"
)
)
)
{
/* <description> isn't standard iTunes podcast stuff */
{
/* <description> isn't standard iTunes podcast stuff */
vlc_input_item_AddInfo
(
p_current
->
p_input
,
vlc_input_item_AddInfo
(
p_current
->
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Info"
),
_
(
"Podcast Summary"
),
_
(
"Podcast Summary"
),
"%s"
,
psz_text
);
"%s"
,
psz_text
);
}
}
else
else
{
{
...
@@ -321,62 +271,17 @@ static int Demux( demux_t *p_demux )
...
@@ -321,62 +271,17 @@ static int Demux( demux_t *p_demux )
p_input
=
input_ItemNewExt
(
p_playlist
,
psz_item_mrl
,
p_input
=
input_ItemNewExt
(
p_playlist
,
psz_item_mrl
,
psz_item_name
,
0
,
NULL
,
-
1
);
psz_item_name
,
0
,
NULL
,
-
1
);
if
(
p_input
==
NULL
)
break
;
if
(
p_input
==
NULL
)
break
;
if
(
psz_item_date
)
#define ADD_INFO( info, field ) \
{
if( field ) { vlc_input_item_AddInfo( p_input, \
vlc_input_item_AddInfo
(
p_input
,
_( "Podcast Info" ), _( info ), "%s", field ); }
_
(
"Podcast Info"
),
ADD_INFO
(
"Podcast Publication Date"
,
psz_item_date
);
_
(
"Podcast Publication Date"
),
ADD_INFO
(
"Podcast Author"
,
psz_item_author
);
"%s"
,
ADD_INFO
(
"Podcast Subcategory"
,
psz_item_category
);
psz_item_date
);
ADD_INFO
(
"Podcast Duration"
,
psz_item_duration
);
}
ADD_INFO
(
"Podcast Keywords"
,
psz_item_keywords
);
if
(
psz_item_author
)
ADD_INFO
(
"Podcast Subtitle"
,
psz_item_subtitle
);
{
ADD_INFO
(
"Podcast Summary"
,
psz_item_summary
);
vlc_input_item_AddInfo
(
p_input
,
ADD_INFO
(
"Podcast Type"
,
psz_item_type
);
_
(
"Podcast Info"
),
_
(
"Podcast Author"
),
"%s"
,
psz_item_author
);
}
if
(
psz_item_category
)
{
vlc_input_item_AddInfo
(
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Subcategory"
),
"%s"
,
psz_item_category
);
}
if
(
psz_item_duration
)
{
vlc_input_item_AddInfo
(
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Duration"
),
"%s"
,
psz_item_duration
);
}
if
(
psz_item_keywords
)
{
vlc_input_item_AddInfo
(
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Keywords"
),
"%s"
,
psz_item_keywords
);
}
if
(
psz_item_subtitle
)
{
vlc_input_item_AddInfo
(
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Subtitle"
),
"%s"
,
psz_item_subtitle
);
}
if
(
psz_item_summary
)
{
vlc_input_item_AddInfo
(
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Summary"
),
"%s"
,
psz_item_summary
);
}
if
(
psz_item_size
)
if
(
psz_item_size
)
{
{
vlc_input_item_AddInfo
(
p_input
,
vlc_input_item_AddInfo
(
p_input
,
...
@@ -385,33 +290,20 @@ static int Demux( demux_t *p_demux )
...
@@ -385,33 +290,20 @@ static int Demux( demux_t *p_demux )
"%s bytes"
,
"%s bytes"
,
psz_item_size
);
psz_item_size
);
}
}
if
(
psz_item_type
)
{
vlc_input_item_AddInfo
(
p_input
,
_
(
"Podcast Info"
),
_
(
"Podcast Type"
),
"%s"
,
psz_item_type
);
}
msg_Dbg
(
p_demux
,
"Adding WHEREVER
\n
"
);
playlist_AddWhereverNeeded
(
p_playlist
,
p_input
,
p_current
,
playlist_AddWhereverNeeded
(
p_playlist
,
p_input
,
p_current
,
p_item_in_category
,
(
i_parent_id
>
0
)
?
VLC_TRUE
:
p_item_in_category
,
(
i_parent_id
>
0
)
?
VLC_TRUE
:
VLC_FALSE
,
PLAYLIST_APPEND
);
VLC_FALSE
,
PLAYLIST_APPEND
);
#define FREE(a) if( a ) free( a ); a = NULL;
FREENULL
(
psz_item_name
);
FREE
(
psz_item_name
);
FREENULL
(
psz_item_mrl
);
FREE
(
psz_item_mrl
);
FREENULL
(
psz_item_size
);
FREE
(
psz_item_size
);
FREENULL
(
psz_item_type
);
FREE
(
psz_item_type
);
FREENULL
(
psz_item_date
);
FREE
(
psz_item_date
);
FREENULL
(
psz_item_author
);
FREE
(
psz_item_author
);
FREENULL
(
psz_item_category
);
FREE
(
psz_item_category
);
FREENULL
(
psz_item_duration
);
FREE
(
psz_item_duration
);
FREENULL
(
psz_item_keywords
);
FREE
(
psz_item_keywords
);
FREENULL
(
psz_item_subtitle
);
FREE
(
psz_item_subtitle
);
FREENULL
(
psz_item_summary
);
FREE
(
psz_item_summary
);
#undef FREE
b_item
=
VLC_FALSE
;
b_item
=
VLC_FALSE
;
}
}
else
if
(
!
strcmp
(
psz_elname
,
"image"
)
)
else
if
(
!
strcmp
(
psz_elname
,
"image"
)
)
...
...
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