Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
e448f238
Commit
e448f238
authored
Feb 19, 2006
by
Antoine Cellerier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
rss.c: add some Atom stuff and some extra checks.
parent
009df329
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
94 additions
and
21 deletions
+94
-21
modules/video_filter/rss.c
modules/video_filter/rss.c
+94
-21
No files found.
modules/video_filter/rss.c
View file @
e448f238
...
@@ -21,6 +21,11 @@
...
@@ -21,6 +21,11 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
*****************************************************************************/
/*****************************************************************************
* Atom : http://www.ietf.org/rfc/rfc4287.txt
* RSS : http://www.rssboard.org/rss-specification
*****************************************************************************/
/*****************************************************************************
/*****************************************************************************
* Preamble
* Preamble
*****************************************************************************/
*****************************************************************************/
...
@@ -559,7 +564,7 @@ char *removeWhiteChars( char *psz_src )
...
@@ -559,7 +564,7 @@ char *removeWhiteChars( char *psz_src )
}
}
/****************************************************************************
/****************************************************************************
* FetchRSS
* FetchRSS
(or Atom) feeds
***************************************************************************/
***************************************************************************/
static
int
FetchRSS
(
filter_t
*
p_filter
)
static
int
FetchRSS
(
filter_t
*
p_filter
)
{
{
...
@@ -617,7 +622,7 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -617,7 +622,7 @@ static int FetchRSS( filter_t *p_filter)
p_feed
->
i_items
=
0
;
p_feed
->
i_items
=
0
;
p_feed
->
p_items
=
NULL
;
p_feed
->
p_items
=
NULL
;
msg_Dbg
(
p_filter
,
"Opening %s RSS feed ..."
,
psz_feed
);
msg_Dbg
(
p_filter
,
"Opening %s RSS
/Atom
feed ..."
,
psz_feed
);
p_stream
=
stream_UrlNew
(
p_filter
,
psz_feed
);
p_stream
=
stream_UrlNew
(
p_filter
,
psz_feed
);
if
(
!
p_stream
)
if
(
!
p_stream
)
...
@@ -656,12 +661,11 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -656,12 +661,11 @@ static int FetchRSS( filter_t *p_filter)
{
{
return
1
;
return
1
;
}
}
# define RSS_DEBUG
# ifdef RSS_DEBUG
# ifdef RSS_DEBUG
msg_Dbg
(
p_filter
,
"element name : %s"
,
psz_eltname
);
msg_Dbg
(
p_filter
,
"element name : %s"
,
psz_eltname
);
# endif
# endif
if
(
!
strcmp
(
psz_eltname
,
"item"
)
if
(
!
strcmp
(
psz_eltname
,
"item"
)
/* rss */
||
!
strcmp
(
psz_eltname
,
"entry"
)
)
||
!
strcmp
(
psz_eltname
,
"entry"
)
)
/* atom */
{
{
b_is_item
=
VLC_TRUE
;
b_is_item
=
VLC_TRUE
;
p_feed
->
i_items
++
;
p_feed
->
i_items
++
;
...
@@ -671,10 +675,62 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -671,10 +675,62 @@ static int FetchRSS( filter_t *p_filter)
=
NULL
;
=
NULL
;
p_feed
->
p_items
[
p_feed
->
i_items
-
1
].
psz_link
=
NULL
;
p_feed
->
p_items
[
p_feed
->
i_items
-
1
].
psz_link
=
NULL
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"image"
)
)
else
if
(
!
strcmp
(
psz_eltname
,
"image"
)
)
/* rss */
{
{
b_is_image
=
VLC_TRUE
;
b_is_image
=
VLC_TRUE
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"link"
)
)
/* atom */
{
char
*
psz_href
=
NULL
;
char
*
psz_rel
=
NULL
;
while
(
xml_ReaderNextAttr
(
p_xml_reader
)
==
VLC_SUCCESS
)
{
char
*
psz_name
=
xml_ReaderName
(
p_xml_reader
);
char
*
psz_value
=
xml_ReaderValue
(
p_xml_reader
);
if
(
!
strcmp
(
psz_name
,
"rel"
)
)
{
psz_rel
=
psz_value
;
}
else
if
(
!
strcmp
(
psz_name
,
"href"
)
)
{
psz_href
=
psz_value
;
}
else
{
free
(
psz_value
);
}
free
(
psz_name
);
}
if
(
psz_rel
&&
psz_href
)
{
if
(
!
strcmp
(
psz_rel
,
"alternate"
)
&&
b_is_item
==
VLC_FALSE
&&
b_is_image
==
VLC_FALSE
&&
!
p_feed
->
psz_link
)
{
p_feed
->
psz_link
=
psz_href
;
}
/* this isn't in the rfc but i found some ... */
else
if
(
(
!
strcmp
(
psz_rel
,
"logo"
)
||
!
strcmp
(
psz_rel
,
"icon"
)
)
&&
b_is_item
==
VLC_FALSE
&&
b_is_image
==
VLC_FALSE
&&
!
p_feed
->
psz_image
)
{
p_feed
->
psz_image
=
psz_href
;
}
else
{
free
(
psz_href
);
}
}
else
{
if
(
psz_href
)
free
(
psz_href
);
}
if
(
psz_rel
)
free
(
psz_rel
);
}
break
;
break
;
case
XML_READER_ENDELEM
:
case
XML_READER_ENDELEM
:
...
@@ -691,13 +747,13 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -691,13 +747,13 @@ static int FetchRSS( filter_t *p_filter)
# ifdef RSS_DEBUG
# ifdef RSS_DEBUG
msg_Dbg
(
p_filter
,
"element end : %s"
,
psz_eltname
);
msg_Dbg
(
p_filter
,
"element end : %s"
,
psz_eltname
);
# endif
# endif
if
(
!
strcmp
(
psz_eltname
,
"item"
)
if
(
!
strcmp
(
psz_eltname
,
"item"
)
/* rss */
||
!
strcmp
(
psz_eltname
,
"entry"
)
)
||
!
strcmp
(
psz_eltname
,
"entry"
)
)
/* atom */
{
{
b_is_item
=
VLC_FALSE
;
b_is_item
=
VLC_FALSE
;
i_item
++
;
i_item
++
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"image"
)
)
else
if
(
!
strcmp
(
psz_eltname
,
"image"
)
)
/* rss */
{
{
b_is_image
=
VLC_FALSE
;
b_is_image
=
VLC_FALSE
;
}
}
...
@@ -725,15 +781,19 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -725,15 +781,19 @@ static int FetchRSS( filter_t *p_filter)
{
{
struct
rss_item_t
*
p_item
;
struct
rss_item_t
*
p_item
;
p_item
=
p_feed
->
p_items
+
i_item
;
p_item
=
p_feed
->
p_items
+
i_item
;
if
(
!
strcmp
(
psz_eltname
,
"title"
)
)
if
(
!
strcmp
(
psz_eltname
,
"title"
)
/* rss/atom */
&&
!
p_item
->
psz_title
)
{
{
p_item
->
psz_title
=
psz_eltvalue
;
p_item
->
psz_title
=
psz_eltvalue
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"link"
)
)
else
if
(
!
strcmp
(
psz_eltname
,
"link"
)
/* rss */
&&
!
p_item
->
psz_link
)
{
{
p_item
->
psz_link
=
psz_eltvalue
;
p_item
->
psz_link
=
psz_eltvalue
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"description"
)
)
else
if
((
!
strcmp
(
psz_eltname
,
"description"
)
/* rss */
||
!
strcmp
(
psz_eltname
,
"summary"
)
)
/* atom */
&&
!
p_item
->
psz_description
)
{
{
p_item
->
psz_description
=
psz_eltvalue
;
p_item
->
psz_description
=
psz_eltvalue
;
}
}
...
@@ -745,12 +805,10 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -745,12 +805,10 @@ static int FetchRSS( filter_t *p_filter)
}
}
else
if
(
b_is_image
==
VLC_TRUE
)
else
if
(
b_is_image
==
VLC_TRUE
)
{
{
if
(
!
strcmp
(
psz_eltname
,
"url"
)
)
if
(
!
strcmp
(
psz_eltname
,
"url"
)
/* rss */
&&
!
p_feed
->
psz_image
)
{
{
p_feed
->
psz_image
=
psz_eltvalue
;
p_feed
->
psz_image
=
psz_eltvalue
;
if
(
p_sys
->
b_images
==
VLC_TRUE
)
p_feed
->
p_pic
=
LoadImage
(
p_filter
,
p_feed
->
psz_image
);
}
}
else
else
{
{
...
@@ -760,19 +818,28 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -760,19 +818,28 @@ static int FetchRSS( filter_t *p_filter)
}
}
else
else
{
{
if
(
!
strcmp
(
psz_eltname
,
"title"
)
)
if
(
!
strcmp
(
psz_eltname
,
"title"
)
/* rss/atom */
&&
!
p_feed
->
psz_title
)
{
{
p_feed
->
psz_title
=
psz_eltvalue
;
p_feed
->
psz_title
=
psz_eltvalue
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"link"
)
)
else
if
(
!
strcmp
(
psz_eltname
,
"link"
)
/* rss */
&&
!
p_feed
->
psz_link
)
{
{
p_feed
->
psz_link
=
psz_eltvalue
;
p_feed
->
psz_link
=
psz_eltvalue
;
}
}
else
if
(
!
strcmp
(
psz_eltname
,
"description"
)
else
if
((
!
strcmp
(
psz_eltname
,
"description"
)
/* rss */
||
!
strcmp
(
psz_eltname
,
"subtitle"
)
)
||
!
strcmp
(
psz_eltname
,
"subtitle"
)
)
/* atom */
&&
!
p_feed
->
psz_description
)
{
{
p_feed
->
psz_description
=
psz_eltvalue
;
p_feed
->
psz_description
=
psz_eltvalue
;
}
}
else
if
(
(
!
strcmp
(
psz_eltname
,
"logo"
)
/* atom */
||
!
strcmp
(
psz_eltname
,
"icon"
)
)
/* atom */
&&
!
p_feed
->
psz_image
)
{
p_feed
->
psz_image
=
psz_eltvalue
;
}
else
else
{
{
free
(
psz_eltvalue
);
free
(
psz_eltvalue
);
...
@@ -783,9 +850,15 @@ static int FetchRSS( filter_t *p_filter)
...
@@ -783,9 +850,15 @@ static int FetchRSS( filter_t *p_filter)
}
}
}
}
if
(
p_sys
->
b_images
==
VLC_TRUE
&&
p_feed
->
psz_image
&&
!
p_feed
->
p_pic
)
{
p_feed
->
p_pic
=
LoadImage
(
p_filter
,
p_feed
->
psz_image
);
}
if
(
p_xml_reader
&&
p_xml
)
xml_ReaderDelete
(
p_xml
,
p_xml_reader
);
if
(
p_xml_reader
&&
p_xml
)
xml_ReaderDelete
(
p_xml
,
p_xml_reader
);
if
(
p_stream
)
stream_Delete
(
p_stream
);
if
(
p_stream
)
stream_Delete
(
p_stream
);
msg_Dbg
(
p_filter
,
"Done with %s RSS feed."
,
psz_feed
);
msg_Dbg
(
p_filter
,
"Done with %s RSS
/Atom
feed."
,
psz_feed
);
}
}
free
(
psz_buffer_2
);
free
(
psz_buffer_2
);
if
(
p_xml
)
xml_Delete
(
p_xml
);
if
(
p_xml
)
xml_Delete
(
p_xml
);
...
...
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