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
c53708ad
Commit
c53708ad
authored
Oct 28, 2015
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
preparser: start and wait for input thread explicitly
parent
d8e2c680
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
38 additions
and
18 deletions
+38
-18
src/input/var.c
src/input/var.c
+2
-5
src/playlist/preparser.c
src/playlist/preparser.c
+36
-13
No files found.
src/input/var.c
View file @
c53708ad
...
@@ -212,11 +212,8 @@ void input_ControlVarInit ( input_thread_t *p_input )
...
@@ -212,11 +212,8 @@ void input_ControlVarInit ( input_thread_t *p_input )
var_Create
(
p_input
,
"bit-rate"
,
VLC_VAR_INTEGER
);
var_Create
(
p_input
,
"bit-rate"
,
VLC_VAR_INTEGER
);
var_Create
(
p_input
,
"sample-rate"
,
VLC_VAR_INTEGER
);
var_Create
(
p_input
,
"sample-rate"
,
VLC_VAR_INTEGER
);
if
(
!
p_input
->
b_preparsing
)
/* Special "intf-event" variable. */
{
var_Create
(
p_input
,
"intf-event"
,
VLC_VAR_INTEGER
);
/* Special "intf-event" variable. */
var_Create
(
p_input
,
"intf-event"
,
VLC_VAR_INTEGER
);
}
/* Add all callbacks
/* Add all callbacks
* XXX we put callback only in non preparsing mode. We need to create the variable
* XXX we put callback only in non preparsing mode. We need to create the variable
...
...
src/playlist/preparser.c
View file @
c53708ad
...
@@ -139,10 +139,24 @@ void playlist_preparser_Delete( playlist_preparser_t *p_preparser )
...
@@ -139,10 +139,24 @@ void playlist_preparser_Delete( playlist_preparser_t *p_preparser )
/*****************************************************************************
/*****************************************************************************
* Privates functions
* Privates functions
*****************************************************************************/
*****************************************************************************/
static
int
InputEvent
(
vlc_object_t
*
obj
,
const
char
*
varname
,
vlc_value_t
old
,
vlc_value_t
cur
,
void
*
data
)
{
vlc_sem_t
*
done
=
data
;
int
event
=
cur
.
i_int
;
if
(
event
==
INPUT_EVENT_DEAD
)
vlc_sem_post
(
done
);
(
void
)
obj
;
(
void
)
varname
;
(
void
)
old
;
return
VLC_SUCCESS
;
}
/**
/**
* This function preparses an item when needed.
* This function preparses an item when needed.
*/
*/
static
void
Preparse
(
vlc_object_t
*
obj
,
input_item_t
*
p_item
,
static
void
Preparse
(
playlist_preparser_t
*
preparser
,
input_item_t
*
p_item
,
input_item_meta_request_option_t
i_options
)
input_item_meta_request_option_t
i_options
)
{
{
vlc_mutex_lock
(
&
p_item
->
lock
);
vlc_mutex_lock
(
&
p_item
->
lock
);
...
@@ -160,21 +174,31 @@ static void Preparse( vlc_object_t *obj, input_item_t *p_item,
...
@@ -160,21 +174,31 @@ static void Preparse( vlc_object_t *obj, input_item_t *p_item,
b_preparse
=
true
;
b_preparse
=
true
;
break
;
break
;
}
}
if
(
!
b_preparse
)
{
input_item_SetPreparsed
(
p_item
,
true
);
input_item_SignalPreparseEnded
(
p_item
);
return
;
}
/* Do not preparse if it is already done (like by playing it) */
/* Do not preparse if it is already done (like by playing it) */
if
(
!
input_item_IsPreparsed
(
p_item
)
)
if
(
b_preparse
&&
!
input_item_IsPreparsed
(
p_item
)
)
{
{
input_Preparse
(
obj
,
p_item
);
input_thread_t
*
input
=
input_CreatePreparser
(
preparser
->
object
,
input_item_SetPreparsed
(
p_item
,
true
);
p_item
);
if
(
input
==
NULL
)
return
;
vlc_sem_t
done
;
vlc_sem_init
(
&
done
,
0
);
var_AddCallback
(
input
,
"intf-event"
,
InputEvent
,
&
done
);
if
(
input_Start
(
input
)
==
VLC_SUCCESS
)
vlc_sem_wait
(
&
done
);
var_SetAddress
(
obj
,
"item-change"
,
p_item
);
var_DelCallback
(
input
,
"intf-event"
,
InputEvent
,
&
done
);
vlc_sem_destroy
(
&
done
);
input_Close
(
input
);
var_SetAddress
(
preparser
->
object
,
"item-change"
,
p_item
);
}
}
input_item_SetPreparsed
(
p_item
,
true
);
input_item_SignalPreparseEnded
(
p_item
);
input_item_SignalPreparseEnded
(
p_item
);
}
}
...
@@ -225,7 +249,6 @@ static void Art( playlist_preparser_t *p_preparser, input_item_t *p_item )
...
@@ -225,7 +249,6 @@ static void Art( playlist_preparser_t *p_preparser, input_item_t *p_item )
static
void
*
Thread
(
void
*
data
)
static
void
*
Thread
(
void
*
data
)
{
{
playlist_preparser_t
*
p_preparser
=
data
;
playlist_preparser_t
*
p_preparser
=
data
;
vlc_object_t
*
obj
=
p_preparser
->
object
;
for
(
;;
)
for
(
;;
)
{
{
...
@@ -253,7 +276,7 @@ static void *Thread( void *data )
...
@@ -253,7 +276,7 @@ static void *Thread( void *data )
if
(
!
p_current
)
if
(
!
p_current
)
break
;
break
;
Preparse
(
obj
,
p_current
,
i_options
);
Preparse
(
p_preparser
,
p_current
,
i_options
);
Art
(
p_preparser
,
p_current
);
Art
(
p_preparser
,
p_current
);
vlc_gc_decref
(
p_current
);
vlc_gc_decref
(
p_current
);
...
...
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