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
95b2a344
Commit
95b2a344
authored
Apr 02, 2009
by
Rémi Duraffort
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix memleak and use var_Get(Integer|String|...) when possible (easier to find bugs).
parent
13c669e1
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
9 additions
and
16 deletions
+9
-16
src/video_output/video_output.c
src/video_output/video_output.c
+9
-16
No files found.
src/video_output/video_output.c
View file @
95b2a344
...
@@ -181,17 +181,13 @@ vout_thread_t *__vout_Request( vlc_object_t *p_this, vout_thread_t *p_vout,
...
@@ -181,17 +181,13 @@ vout_thread_t *__vout_Request( vlc_object_t *p_this, vout_thread_t *p_vout,
/* If we now have a video output, check it has the right properties */
/* If we now have a video output, check it has the right properties */
if
(
p_vout
)
if
(
p_vout
)
{
{
char
*
psz_filter_chain
;
vlc_value_t
val
;
vlc_mutex_lock
(
&
p_vout
->
change_lock
);
vlc_mutex_lock
(
&
p_vout
->
change_lock
);
/* We don't directly check for the "vout-filter" variable for obvious
/* We don't directly check for the "vout-filter" variable for obvious
* performance reasons. */
* performance reasons. */
if
(
p_vout
->
p
->
b_filter_change
)
if
(
p_vout
->
p
->
b_filter_change
)
{
{
var_Get
(
p_vout
,
"vout-filter"
,
&
val
);
char
*
psz_filter_chain
=
var_GetString
(
p_vout
,
"vout-filter"
);
psz_filter_chain
=
val
.
psz_string
;
if
(
psz_filter_chain
&&
!*
psz_filter_chain
)
if
(
psz_filter_chain
&&
!*
psz_filter_chain
)
{
{
...
@@ -302,7 +298,7 @@ vout_thread_t * __vout_Create( vlc_object_t *p_parent, video_format_t *p_fmt )
...
@@ -302,7 +298,7 @@ vout_thread_t * __vout_Create( vlc_object_t *p_parent, video_format_t *p_fmt )
{
{
vout_thread_t
*
p_vout
;
/* thread descriptor */
vout_thread_t
*
p_vout
;
/* thread descriptor */
int
i_index
;
/* loop variable */
int
i_index
;
/* loop variable */
vlc_value_t
val
,
text
;
vlc_value_t
text
;
unsigned
int
i_width
=
p_fmt
->
i_width
;
unsigned
int
i_width
=
p_fmt
->
i_width
;
unsigned
int
i_height
=
p_fmt
->
i_height
;
unsigned
int
i_height
=
p_fmt
->
i_height
;
...
@@ -475,9 +471,7 @@ vout_thread_t * __vout_Create( vlc_object_t *p_parent, video_format_t *p_fmt )
...
@@ -475,9 +471,7 @@ vout_thread_t * __vout_Create( vlc_object_t *p_parent, video_format_t *p_fmt )
/* Choose the video output module */
/* Choose the video output module */
if
(
!
p_vout
->
p
->
psz_filter_chain
||
!*
p_vout
->
p
->
psz_filter_chain
)
if
(
!
p_vout
->
p
->
psz_filter_chain
||
!*
p_vout
->
p
->
psz_filter_chain
)
{
{
var_Create
(
p_vout
,
"vout"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
psz_parser
=
var_CreateGetString
(
p_vout
,
"vout"
);
var_Get
(
p_vout
,
"vout"
,
&
val
);
psz_parser
=
val
.
psz_string
;
}
}
else
else
{
{
...
@@ -1682,7 +1676,6 @@ static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
...
@@ -1682,7 +1676,6 @@ static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
{
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
input_thread_t
*
p_input
;
input_thread_t
*
p_input
;
vlc_value_t
val
;
(
void
)
psz_cmd
;
(
void
)
oldval
;
(
void
)
p_data
;
(
void
)
psz_cmd
;
(
void
)
oldval
;
(
void
)
p_data
;
p_input
=
(
input_thread_t
*
)
vlc_object_find
(
p_this
,
VLC_OBJECT_INPUT
,
p_input
=
(
input_thread_t
*
)
vlc_object_find
(
p_this
,
VLC_OBJECT_INPUT
,
...
@@ -1690,17 +1683,14 @@ static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
...
@@ -1690,17 +1683,14 @@ static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
if
(
!
p_input
)
if
(
!
p_input
)
{
{
msg_Err
(
p_vout
,
"Input not found"
);
msg_Err
(
p_vout
,
"Input not found"
);
return
(
VLC_EGENERIC
)
;
return
VLC_EGENERIC
;
}
}
val
.
b_bool
=
true
;
var_SetBool
(
p_vout
,
"intf-change"
,
true
);
var_Set
(
p_vout
,
"intf-change"
,
val
);
/* Modify input as well because the vout might have to be restarted */
/* Modify input as well because the vout might have to be restarted */
val
.
psz_string
=
newval
.
psz_string
;
var_Create
(
p_input
,
"vout-filter"
,
VLC_VAR_STRING
);
var_Create
(
p_input
,
"vout-filter"
,
VLC_VAR_STRING
);
var_SetString
(
p_input
,
"vout-filter"
,
newval
.
psz_string
);
var_Set
(
p_input
,
"vout-filter"
,
val
);
/* Now restart current video stream */
/* Now restart current video stream */
input_Control
(
p_input
,
INPUT_RESTART_ES
,
-
VIDEO_ES
);
input_Control
(
p_input
,
INPUT_RESTART_ES
,
-
VIDEO_ES
);
...
@@ -1775,7 +1765,10 @@ static int PostProcessCallback( vlc_object_t *p_this, char const *psz_cmd,
...
@@ -1775,7 +1765,10 @@ static int PostProcessCallback( vlc_object_t *p_this, char const *psz_cmd,
}
}
}
}
if
(
psz_vf2
)
if
(
psz_vf2
)
{
var_SetString
(
p_vout
,
"video-filter"
,
psz_vf2
);
var_SetString
(
p_vout
,
"video-filter"
,
psz_vf2
);
free
(
psz_vf2
);
}
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
...
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