[vlc-devel] commit: OpenGL: initialize all variables before creating the provider ( Rémi Denis-Courmont )
git version control
git at videolan.org
Mon Jul 13 20:13:58 CEST 2009
vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Mon Jul 13 21:11:17 2009 +0300| [c936761292fde730ac447f9d469f1207c4b4272d] | committer: Rémi Denis-Courmont
OpenGL: initialize all variables before creating the provider
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=c936761292fde730ac447f9d469f1207c4b4272d
---
modules/video_output/opengl.c | 41 +++++++++++++++++++++--------------------
1 files changed, 21 insertions(+), 20 deletions(-)
diff --git a/modules/video_output/opengl.c b/modules/video_output/opengl.c
index 483fb2f..d6592a9 100644
--- a/modules/video_output/opengl.c
+++ b/modules/video_output/opengl.c
@@ -196,26 +196,6 @@ static int CreateVout( vlc_object_t *p_this )
var_Create( p_sys->p_vout, "video-deco",
VLC_VAR_BOOL | VLC_VAR_DOINHERIT );
- psz = var_CreateGetString( p_vout, "opengl-provider" );
- p_sys->p_vout->p_module =
- module_need( p_sys->p_vout, "opengl provider", psz, false );
- free( psz );
- if( p_sys->p_vout->p_module == NULL )
- {
- msg_Warn( p_vout, "No OpenGL provider found" );
- vlc_object_detach( p_sys->p_vout );
- vlc_object_release( p_sys->p_vout );
- free( p_sys );
- return VLC_ENOOBJ;
- }
-
- p_vout->pf_init = Init;
- p_vout->pf_end = End;
- p_vout->pf_manage = Manage;
- p_vout->pf_render = Render;
- p_vout->pf_display = DisplayVideo;
- p_vout->pf_control = Control;
-
/* Forward events from the opengl provider */
var_Create( p_sys->p_vout, "mouse-x", VLC_VAR_INTEGER );
var_Create( p_sys->p_vout, "mouse-y", VLC_VAR_INTEGER );
@@ -238,6 +218,27 @@ static int CreateVout( vlc_object_t *p_this )
var_AddCallback( p_vout, "autoscale", SendEvents, p_sys->p_vout );
var_AddCallback( p_vout, "scale", SendEvents, p_sys->p_vout );
+ psz = var_CreateGetString( p_vout, "opengl-provider" );
+ p_sys->p_vout->p_module =
+ module_need( p_sys->p_vout, "opengl provider", psz, false );
+ free( psz );
+ if( p_sys->p_vout->p_module == NULL )
+ {
+ msg_Warn( p_vout, "No OpenGL provider found" );
+ vlc_object_detach( p_sys->p_vout );
+ /* no need for var_DelCallback here :-) */
+ vlc_object_release( p_sys->p_vout );
+ free( p_sys );
+ return VLC_ENOOBJ;
+ }
+
+ p_vout->pf_init = Init;
+ p_vout->pf_end = End;
+ p_vout->pf_manage = Manage;
+ p_vout->pf_render = Render;
+ p_vout->pf_display = DisplayVideo;
+ p_vout->pf_control = Control;
+
return VLC_SUCCESS;
}
More information about the vlc-devel
mailing list