Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
b9bf6dc0
Commit
b9bf6dc0
authored
Sep 02, 2009
by
Rémi Duraffort
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
video_filter_rss: asynch fetch (no more lags while fetching/parsing the rss feeds).
parent
2838403d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
47 additions
and
38 deletions
+47
-38
modules/video_filter/rss.c
modules/video_filter/rss.c
+47
-38
No files found.
modules/video_filter/rss.c
View file @
b9bf6dc0
...
@@ -57,8 +57,8 @@ static int CreateFilter ( vlc_object_t * );
...
@@ -57,8 +57,8 @@ static int CreateFilter ( vlc_object_t * );
static
void
DestroyFilter
(
vlc_object_t
*
);
static
void
DestroyFilter
(
vlc_object_t
*
);
static
subpicture_t
*
Filter
(
filter_t
*
,
mtime_t
);
static
subpicture_t
*
Filter
(
filter_t
*
,
mtime_t
);
static
int
FetchRSS
(
filter_t
*
);
static
struct
rss_feed_t
*
FetchRSS
(
filter_t
*
);
static
void
FreeRSS
(
filter_t
*
);
static
void
FreeRSS
(
struct
rss_feed_t
*
,
int
);
static
int
ParseUrls
(
filter_t
*
,
char
*
);
static
int
ParseUrls
(
filter_t
*
,
char
*
);
static
void
Fetch
(
void
*
);
static
void
Fetch
(
void
*
);
...
@@ -325,7 +325,7 @@ static void DestroyFilter( vlc_object_t *p_this )
...
@@ -325,7 +325,7 @@ static void DestroyFilter( vlc_object_t *p_this )
text_style_Delete
(
p_sys
->
p_style
);
text_style_Delete
(
p_sys
->
p_style
);
free
(
p_sys
->
psz_marquee
);
free
(
p_sys
->
psz_marquee
);
FreeRSS
(
p_
filter
);
FreeRSS
(
p_
sys
->
p_feeds
,
p_sys
->
i_feeds
);
free
(
p_sys
);
free
(
p_sys
);
}
}
...
@@ -879,7 +879,7 @@ end:
...
@@ -879,7 +879,7 @@ end:
/****************************************************************************
/****************************************************************************
* FetchRSS (or Atom) feeds
* FetchRSS (or Atom) feeds
***************************************************************************/
***************************************************************************/
static
int
FetchRSS
(
filter_t
*
p_filter
)
static
rss_feed_t
*
FetchRSS
(
filter_t
*
p_filter
)
{
{
filter_sys_t
*
p_sys
=
p_filter
->
p_sys
;
filter_sys_t
*
p_sys
=
p_filter
->
p_sys
;
...
@@ -887,37 +887,40 @@ static int FetchRSS( filter_t *p_filter )
...
@@ -887,37 +887,40 @@ static int FetchRSS( filter_t *p_filter )
xml_t
*
p_xml
;
xml_t
*
p_xml
;
xml_reader_t
*
p_xml_reader
;
xml_reader_t
*
p_xml_reader
;
/* These data are not modified after the creation of the module so we don't
need to hold the lock */
int
i_feeds
=
p_sys
->
i_feeds
;
bool
b_images
=
p_sys
->
b_images
;
/* Allocate a new structure */
rss_feed_t
*
p_feeds
=
malloc
(
i_feeds
*
sizeof
(
rss_feed_t
)
);
if
(
!
p_feeds
)
return
NULL
;
p_xml
=
xml_Create
(
p_filter
);
p_xml
=
xml_Create
(
p_filter
);
if
(
!
p_xml
)
if
(
!
p_xml
)
{
{
msg_Err
(
p_filter
,
"Failed to open XML parser"
);
msg_Err
(
p_filter
,
"Failed to open XML parser"
);
return
1
;
free
(
p_feeds
);
return
NULL
;
}
}
/* Fetch all feeds and parse them */
/* Fetch all feeds and parse them */
for
(
int
i_feed
=
0
;
i_feed
<
p_sys
->
i_feeds
;
i_feed
++
)
for
(
int
i_feed
=
0
;
i_feed
<
i_feeds
;
i_feed
++
)
{
{
rss_feed_t
*
p_feed
=
p_sys
->
p_feeds
+
i_feed
;
rss_feed_t
*
p_feed
=
p_feeds
+
i_feed
;
rss_feed_t
*
p_old_feed
=
p_sys
->
p_feeds
+
i_feed
;
/* Free the ressources */
FREENULL
(
p_feed
->
psz_title
);
/* Initialize the structure */
FREENULL
(
p_feed
->
psz_description
);
p_feed
->
psz_title
=
NULL
;
FREENULL
(
p_feed
->
psz_link
);
p_feed
->
psz_description
=
NULL
;
FREENULL
(
p_feed
->
psz_image
);
p_feed
->
psz_link
=
NULL
;
if
(
p_feed
->
p_pic
)
p_feed
->
psz_image
=
NULL
;
{
p_feed
->
p_pic
=
NULL
;
picture_Release
(
p_feed
->
p_pic
);
p_feed
->
p_pic
=
NULL
;
}
for
(
int
i
=
0
;
i
<
p_feed
->
i_items
;
i
++
)
{
rss_item_t
*
p_item
=
p_feed
->
p_items
+
i
;
free
(
p_item
->
psz_title
);
free
(
p_item
->
psz_link
);
free
(
p_item
->
psz_description
);
}
p_feed
->
i_items
=
0
;
p_feed
->
i_items
=
0
;
FREENULL
(
p_feed
->
p_items
);
p_feed
->
p_items
=
NULL
;
p_feed
->
psz_url
=
strdup
(
p_old_feed
->
psz_url
);
/* Fetch the feed */
/* Fetch the feed */
msg_Dbg
(
p_filter
,
"opening %s RSS/Atom feed ..."
,
p_feed
->
psz_url
);
msg_Dbg
(
p_filter
,
"opening %s RSS/Atom feed ..."
,
p_feed
->
psz_url
);
...
@@ -942,8 +945,7 @@ static int FetchRSS( filter_t *p_filter )
...
@@ -942,8 +945,7 @@ static int FetchRSS( filter_t *p_filter )
goto
error
;
goto
error
;
/* If we have a image: load it if requiere */
/* If we have a image: load it if requiere */
if
(
p_sys
->
b_images
==
true
if
(
b_images
&&
p_feed
->
psz_image
&&
!
p_feed
->
p_pic
)
&&
p_feed
->
psz_image
&&
!
p_feed
->
p_pic
)
{
{
p_feed
->
p_pic
=
LoadImage
(
p_filter
,
p_feed
->
psz_image
);
p_feed
->
p_pic
=
LoadImage
(
p_filter
,
p_feed
->
psz_image
);
}
}
...
@@ -954,10 +956,11 @@ static int FetchRSS( filter_t *p_filter )
...
@@ -954,10 +956,11 @@ static int FetchRSS( filter_t *p_filter )
}
}
xml_Delete
(
p_xml
);
xml_Delete
(
p_xml
);
return
0
;
return
p_feeds
;
error:
error:
/*TODO: still a memleak */
if
(
p_xml_reader
)
if
(
p_xml_reader
)
xml_ReaderDelete
(
p_xml
,
p_xml_reader
);
xml_ReaderDelete
(
p_xml
,
p_xml_reader
);
if
(
p_stream
)
if
(
p_stream
)
...
@@ -965,19 +968,17 @@ error:
...
@@ -965,19 +968,17 @@ error:
if
(
p_xml
)
if
(
p_xml
)
xml_Delete
(
p_xml
);
xml_Delete
(
p_xml
);
return
1
;
return
NULL
;
}
}
/****************************************************************************
/****************************************************************************
* FreeRSS
* FreeRSS
***************************************************************************/
***************************************************************************/
static
void
FreeRSS
(
filter_t
*
p_filter
)
static
void
FreeRSS
(
rss_feed_t
*
p_feeds
,
int
i_feeds
)
{
{
filter_sys_t
*
p_sys
=
p_filter
->
p_sys
;
for
(
int
i_feed
=
0
;
i_feed
<
i_feeds
;
i_feed
++
)
for
(
int
i_feed
=
0
;
i_feed
<
p_sys
->
i_feeds
;
i_feed
++
)
{
{
rss_feed_t
*
p_feed
=
p_
sys
->
p_
feeds
+
i_feed
;
rss_feed_t
*
p_feed
=
p_feeds
+
i_feed
;
for
(
int
i_item
=
0
;
i_item
<
p_feed
->
i_items
;
i_item
++
)
for
(
int
i_item
=
0
;
i_item
<
p_feed
->
i_items
;
i_item
++
)
{
{
rss_item_t
*
p_item
=
p_feed
->
p_items
+
i_item
;
rss_item_t
*
p_item
=
p_feed
->
p_items
+
i_item
;
...
@@ -994,8 +995,7 @@ static void FreeRSS( filter_t *p_filter)
...
@@ -994,8 +995,7 @@ static void FreeRSS( filter_t *p_filter)
picture_Release
(
p_feed
->
p_pic
);
picture_Release
(
p_feed
->
p_pic
);
free
(
p_feed
->
psz_url
);
free
(
p_feed
->
psz_url
);
}
}
free
(
p_sys
->
p_feeds
);
free
(
p_feeds
);
p_sys
->
i_feeds
=
0
;
}
}
static
void
Fetch
(
void
*
p_data
)
static
void
Fetch
(
void
*
p_data
)
...
@@ -1003,8 +1003,17 @@ static void Fetch( void *p_data )
...
@@ -1003,8 +1003,17 @@ static void Fetch( void *p_data )
filter_t
*
p_filter
=
p_data
;
filter_t
*
p_filter
=
p_data
;
filter_sys_t
*
p_sys
=
p_filter
->
p_sys
;
filter_sys_t
*
p_sys
=
p_filter
->
p_sys
;
rss_feed_t
*
p_feeds
=
FetchRSS
(
p_filter
);
rss_feed_t
*
p_old_feeds
=
p_sys
->
p_feeds
;
if
(
!
p_feeds
)
return
;
vlc_mutex_lock
(
&
p_sys
->
lock
);
vlc_mutex_lock
(
&
p_sys
->
lock
);
FetchRSS
(
p_filter
)
;
p_sys
->
p_feeds
=
p_feeds
;
p_sys
->
b_fetched
=
true
;
p_sys
->
b_fetched
=
true
;
vlc_mutex_unlock
(
&
p_sys
->
lock
);
vlc_mutex_unlock
(
&
p_sys
->
lock
);
if
(
p_old_feeds
)
FreeRSS
(
p_old_feeds
,
p_sys
->
i_feeds
);
}
}
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