{
filter_t *p_filter = (filter_t *)p_this;
filter_sys_t *p_sys;
- vlc_object_t *p_input;
logo_list_t *p_logo_list;
/* Allocate structure */
}
/* Hook used for callback variables */
- p_input = vlc_object_find( p_this, VLC_OBJECT_INPUT, FIND_PARENT );
- if( !p_input )
- {
- free( p_sys );
- free( p_logo_list );
- return VLC_ENOOBJ;
- }
-
p_logo_list->psz_filename =
- var_CreateGetString( p_input->p_libvlc , "logo-file" );
+ var_CreateGetString( p_filter->p_libvlc , "logo-file" );
if( !p_logo_list->psz_filename || !*p_logo_list->psz_filename )
{
msg_Err( p_this, "logo file not specified" );
- vlc_object_release( p_input );
- //if( p_sys->psz_filename ) free( p_sys->psz_filename );
free( p_sys );
free( p_logo_list );
return VLC_EGENERIC;
}
- p_sys->posx = var_CreateGetInteger( p_input->p_libvlc , "logo-x" );
- p_sys->posy = var_CreateGetInteger( p_input->p_libvlc , "logo-y" );
- p_sys->pos = var_CreateGetInteger( p_input->p_libvlc , "logo-position" );
+ p_sys->posx = var_CreateGetInteger( p_filter->p_libvlc , "logo-x" );
+ p_sys->posy = var_CreateGetInteger( p_filter->p_libvlc , "logo-y" );
+ p_sys->pos = var_CreateGetInteger( p_filter->p_libvlc , "logo-position" );
p_logo_list->i_alpha = __MAX( __MIN( var_CreateGetInteger(
- p_input->p_libvlc, "logo-transparency"), 255 ), 0 );
+ p_filter->p_libvlc, "logo-transparency"), 255 ), 0 );
p_logo_list->i_delay =
- var_CreateGetInteger( p_input->p_libvlc , "logo-delay" );
+ var_CreateGetInteger( p_filter->p_libvlc , "logo-delay" );
p_logo_list->i_repeat =
- var_CreateGetInteger( p_input->p_libvlc , "logo-repeat" );
+ var_CreateGetInteger( p_filter->p_libvlc , "logo-repeat" );
- var_AddCallback( p_input->p_libvlc, "logo-file", LogoCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "logo-x", LogoCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "logo-y", LogoCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "logo-position", LogoCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "logo-transparency", LogoCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "logo-repeat", LogoCallback, p_sys );
- vlc_object_release( p_input );
+ var_AddCallback( p_filter->p_libvlc, "logo-file", LogoCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "logo-x", LogoCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "logo-y", LogoCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "logo-position", LogoCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "logo-transparency", LogoCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "logo-repeat", LogoCallback, p_sys );
vlc_mutex_init( p_filter, &p_logo_list->lock );
vlc_mutex_lock( &p_logo_list->lock );
{
filter_t *p_filter = (filter_t *)p_this;
filter_sys_t *p_sys = p_filter->p_sys;
- vlc_object_t *p_input;
vlc_mutex_destroy( &p_sys->p_logo_list->lock );
FreeLogoList( p_sys->p_logo_list );
free( p_sys );
/* Delete the logo variables from INPUT */
- p_input = vlc_object_find( p_this, VLC_OBJECT_INPUT, FIND_PARENT );
- if( !p_input ) return;
-
- var_Destroy( p_input->p_libvlc , "logo-file" );
- var_Destroy( p_input->p_libvlc , "logo-x" );
- var_Destroy( p_input->p_libvlc , "logo-y" );
- var_Destroy( p_input->p_libvlc , "logo-delay" );
- var_Destroy( p_input->p_libvlc , "logo-repeat" );
- var_Destroy( p_input->p_libvlc , "logo-position" );
- var_Destroy( p_input->p_libvlc , "logo-transparency" );
- vlc_object_release( p_input );
+ var_Destroy( p_filter->p_libvlc , "logo-file" );
+ var_Destroy( p_filter->p_libvlc , "logo-x" );
+ var_Destroy( p_filter->p_libvlc , "logo-y" );
+ var_Destroy( p_filter->p_libvlc , "logo-delay" );
+ var_Destroy( p_filter->p_libvlc , "logo-repeat" );
+ var_Destroy( p_filter->p_libvlc , "logo-position" );
+ var_Destroy( p_filter->p_libvlc , "logo-transparency" );
}
/*****************************************************************************
{
filter_t *p_filter = (filter_t *)p_this;
filter_sys_t *p_sys;
- vlc_object_t *p_input;
/* Allocate structure */
p_sys = p_filter->p_sys = malloc( sizeof( filter_sys_t ) );
return VLC_ENOMEM;
}
- /* Hook used for callback variables */
- p_input = vlc_object_find( p_this, VLC_OBJECT_INPUT, FIND_ANYWHERE );
- if( !p_input )
- {
- return VLC_ENOOBJ;
- }
-
p_sys->p_style = malloc( sizeof( text_style_t ) );
memcpy( p_sys->p_style, &default_text_style, sizeof( text_style_t ) );
- p_sys->i_xoff = var_CreateGetInteger( p_input->p_libvlc , "marq-x" );
- p_sys->i_yoff = var_CreateGetInteger( p_input->p_libvlc , "marq-y" );
- p_sys->i_timeout = var_CreateGetInteger( p_input->p_libvlc , "marq-timeout" );
- p_sys->i_pos = var_CreateGetInteger( p_input->p_libvlc , "marq-position" );
- p_sys->psz_marquee = var_CreateGetString( p_input->p_libvlc, "marq-marquee" );
- p_sys->p_style->i_font_alpha = 255 - var_CreateGetInteger( p_input->p_libvlc , "marq-opacity" );
- p_sys->p_style->i_font_color = var_CreateGetInteger( p_input->p_libvlc , "marq-color" );
- p_sys->p_style->i_font_size = var_CreateGetInteger( p_input->p_libvlc , "marq-size" );
-
- var_AddCallback( p_input->p_libvlc, "marq-x", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-y", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-marquee", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-timeout", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-position", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-color", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-opacity", MarqueeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "marq-size", MarqueeCallback, p_sys );
-
- vlc_object_release( p_input );
-
+ p_sys->i_xoff = var_CreateGetInteger( p_filter->p_libvlc , "marq-x" );
+ p_sys->i_yoff = var_CreateGetInteger( p_filter->p_libvlc , "marq-y" );
+ p_sys->i_timeout = var_CreateGetInteger( p_filter->p_libvlc , "marq-timeout" );
+ p_sys->i_pos = var_CreateGetInteger( p_filter->p_libvlc , "marq-position" );
+ p_sys->psz_marquee = var_CreateGetString( p_filter->p_libvlc, "marq-marquee" );
+ p_sys->p_style->i_font_alpha = 255 - var_CreateGetInteger( p_filter->p_libvlc , "marq-opacity" );
+ p_sys->p_style->i_font_color = var_CreateGetInteger( p_filter->p_libvlc , "marq-color" );
+ p_sys->p_style->i_font_size = var_CreateGetInteger( p_filter->p_libvlc , "marq-size" );
+
+ var_AddCallback( p_filter->p_libvlc, "marq-x", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-y", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-marquee", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-timeout", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-position", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-color", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-opacity", MarqueeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "marq-size", MarqueeCallback, p_sys );
/* Misc init */
p_filter->pf_sub_filter = Filter;
{
filter_t *p_filter = (filter_t *)p_this;
filter_sys_t *p_sys = p_filter->p_sys;
- vlc_object_t *p_input;
if( p_sys->p_style ) free( p_sys->p_style );
if( p_sys->psz_marquee ) free( p_sys->psz_marquee );
free( p_sys );
/* Delete the marquee variables */
- p_input = vlc_object_find( p_this, VLC_OBJECT_INPUT, FIND_ANYWHERE );
- if( !p_input )
- {
- return;
- }
- var_DelCallback( p_input->p_libvlc, "marq-x", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-y", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-marquee", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-timeout", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-position", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-color", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-opacity", MarqueeCallback, p_sys );
- var_DelCallback( p_input->p_libvlc, "marq-size", MarqueeCallback, p_sys );
-
- var_Destroy( p_input->p_libvlc , "marq-marquee" );
- var_Destroy( p_input->p_libvlc , "marq-x" );
- var_Destroy( p_input->p_libvlc , "marq-y" );
- var_Destroy( p_input->p_libvlc , "marq-timeout" );
- var_Destroy( p_input->p_libvlc , "marq-position" );
- var_Destroy( p_input->p_libvlc , "marq-color");
- var_Destroy( p_input->p_libvlc , "marq-opacity");
- var_Destroy( p_input->p_libvlc , "marq-size");
-
- vlc_object_release( p_input );
+ var_DelCallback( p_filter->p_libvlc, "marq-x", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-y", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-marquee", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-timeout", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-position", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-color", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-opacity", MarqueeCallback, p_sys );
+ var_DelCallback( p_filter->p_libvlc, "marq-size", MarqueeCallback, p_sys );
+
+ var_Destroy( p_filter->p_libvlc , "marq-marquee" );
+ var_Destroy( p_filter->p_libvlc , "marq-x" );
+ var_Destroy( p_filter->p_libvlc , "marq-y" );
+ var_Destroy( p_filter->p_libvlc , "marq-timeout" );
+ var_Destroy( p_filter->p_libvlc , "marq-position" );
+ var_Destroy( p_filter->p_libvlc , "marq-color");
+ var_Destroy( p_filter->p_libvlc , "marq-opacity");
+ var_Destroy( p_filter->p_libvlc , "marq-size");
}
/****************************************************************************
{
filter_t *p_filter = (filter_t *)p_this;
filter_sys_t *p_sys;
- vlc_object_t *p_input;
/* Allocate structure */
p_sys = p_filter->p_sys = malloc( sizeof( filter_sys_t ) );
msg_Err( p_filter, "out of memory" );
return VLC_ENOMEM;
}
- /* Hook used for callback variables */
- p_input = vlc_object_find( p_this, VLC_OBJECT_INPUT, FIND_ANYWHERE );
- if( !p_input )
- {
- return VLC_ENOOBJ;
- }
p_sys->p_style = malloc( sizeof( text_style_t ) );
memcpy( p_sys->p_style, &default_text_style, sizeof( text_style_t ) );
- p_sys->i_xoff = var_CreateGetInteger( p_input->p_libvlc , "time-x" );
- p_sys->i_yoff = var_CreateGetInteger( p_input->p_libvlc , "time-y" );
- p_sys->psz_format = var_CreateGetString( p_input->p_libvlc, "time-format" );
- p_sys->i_pos = var_CreateGetInteger( p_input->p_libvlc , "time-position" );
+ /* Hook used for callback variables */
+ p_sys->i_xoff = var_CreateGetInteger( p_filter->p_libvlc , "time-x" );
+ p_sys->i_yoff = var_CreateGetInteger( p_filter->p_libvlc , "time-y" );
+ p_sys->psz_format = var_CreateGetString( p_filter->p_libvlc, "time-format" );
+ p_sys->i_pos = var_CreateGetInteger( p_filter->p_libvlc , "time-position" );
- p_sys->p_style->i_font_alpha = 255 - var_CreateGetInteger( p_input->p_libvlc , "time-opacity" );
- p_sys->p_style->i_font_color = var_CreateGetInteger( p_input->p_libvlc , "time-color" );
- p_sys->p_style->i_font_size = var_CreateGetInteger( p_input->p_libvlc , "time-size" );
+ p_sys->p_style->i_font_alpha = 255 - var_CreateGetInteger( p_filter->p_libvlc , "time-opacity" );
+ p_sys->p_style->i_font_color = var_CreateGetInteger( p_filter->p_libvlc , "time-color" );
+ p_sys->p_style->i_font_size = var_CreateGetInteger( p_filter->p_libvlc , "time-size" );
- var_AddCallback( p_input->p_libvlc, "time-x", TimeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "time-y", TimeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "time-format", TimeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "time-position", TimeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "time-color", TimeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "time-opacity", TimeCallback, p_sys );
- var_AddCallback( p_input->p_libvlc, "time-size", TimeCallback, p_sys );
-
- vlc_object_release( p_input );
+ var_AddCallback( p_filter->p_libvlc, "time-x", TimeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "time-y", TimeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "time-format", TimeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "time-position", TimeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "time-color", TimeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "time-opacity", TimeCallback, p_sys );
+ var_AddCallback( p_filter->p_libvlc, "time-size", TimeCallback, p_sys );
/* Misc init */
p_filter->pf_sub_filter = Filter;
{
filter_t *p_filter = (filter_t *)p_this;
filter_sys_t *p_sys = p_filter->p_sys;
- vlc_object_t *p_input;
if( p_sys->p_style ) free( p_sys->p_style );
if( p_sys->psz_format ) free( p_sys->psz_format );
free( p_sys );
+
/* Delete the time variables */
- p_input = vlc_object_find( p_this, VLC_OBJECT_INPUT, FIND_ANYWHERE );
- if( !p_input )
- {
- return;
- }
- var_Destroy( p_input->p_libvlc , "time-format" );
- var_Destroy( p_input->p_libvlc , "time-x" );
- var_Destroy( p_input->p_libvlc , "time-y" );
- var_Destroy( p_input->p_libvlc , "time-position" );
- var_Destroy( p_input->p_libvlc , "time-color");
- var_Destroy( p_input->p_libvlc , "time-opacity");
- var_Destroy( p_input->p_libvlc , "time-size");
-
- vlc_object_release( p_input );
+ var_Destroy( p_filter->p_libvlc , "time-format" );
+ var_Destroy( p_filter->p_libvlc , "time-x" );
+ var_Destroy( p_filter->p_libvlc , "time-y" );
+ var_Destroy( p_filter->p_libvlc , "time-position" );
+ var_Destroy( p_filter->p_libvlc , "time-color");
+ var_Destroy( p_filter->p_libvlc , "time-opacity");
+ var_Destroy( p_filter->p_libvlc , "time-size");
}
static char *FormatTime(char *tformat )