* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
- *
+ *
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
*****************************************************************************/
#include <xosd.h>
-#include <vlc/vlc.h>
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <vlc_common.h>
+#include <vlc_plugin.h>
#include <vlc_playlist.h>
#include <vlc_input.h>
#include <vlc_interface.h>
struct intf_sys_t
{
xosd * p_osd; /* libxosd handle */
- vlc_bool_t b_need_update; /* Update display ? */
+ bool b_need_update; /* Update display ? */
};
#define MAX_LINE_LENGTH 256
vlc_module_begin();
set_category( CAT_INTERFACE );
set_subcategory( SUBCAT_INTERFACE_CONTROL );
- set_description( _("XOSD interface") );
+ set_description( N_("XOSD interface") );
set_shortname( "XOSD" );
- add_bool( "xosd-position", 1, NULL, POSITION_TEXT, POSITION_LONGTEXT, VLC_TRUE );
- add_integer( "xosd-text-offset", 30, NULL, TXT_OFS_TEXT, TXT_OFS_LONGTEXT, VLC_TRUE );
+ add_bool( "xosd-position", 1, NULL, POSITION_TEXT, POSITION_LONGTEXT, true );
+ add_integer( "xosd-text-offset", 30, NULL, TXT_OFS_TEXT, TXT_OFS_LONGTEXT, true );
add_integer( "xosd-shadow-offset", 2, NULL,
- SHD_OFS_TEXT, SHD_OFS_LONGTEXT, VLC_TRUE );
+ SHD_OFS_TEXT, SHD_OFS_LONGTEXT, true );
add_string( "xosd-font",
"-adobe-helvetica-bold-r-normal-*-*-160-*-*-p-*-iso8859-1",
- NULL, FONT_TEXT, FONT_LONGTEXT, VLC_TRUE );
+ NULL, FONT_TEXT, FONT_LONGTEXT, true );
add_string( "xosd-colour", "LawnGreen",
- NULL, COLOUR_TEXT, COLOUR_LONGTEXT, VLC_TRUE );
+ NULL, COLOUR_TEXT, COLOUR_LONGTEXT, true );
set_capability( "interface", 10 );
set_callbacks( Open, Close );
vlc_module_end();
{
intf_thread_t *p_intf = (intf_thread_t *)p_this;
xosd *p_osd;
+ char *psz_font, psz_colour;
/* Allocate instance and initialize some members */
p_intf->p_sys = (intf_sys_t *)malloc( sizeof( intf_sys_t ) );
/* Initialize library */
#if defined(HAVE_XOSD_VERSION_0) || defined(HAVE_XOSD_VERSION_1)
- p_osd = p_intf->p_sys->p_osd =
- xosd_init( config_GetPsz( p_intf, "xosd-font" ),
- config_GetPsz( p_intf,"xosd-colour" ), 3,
- XOSD_top, 0, 1 );
+ psz_font = config_GetPsz( p_intf, "xosd-font" );
+ psz_colour = config_GetPsz( p_intf,"xosd-colour" );
+ p_osd = p_intf->p_sys->p_osd = xosd_init( psz_font, psz_colour, 3,
+ XOSD_top, 0, 1 );
+ free( psz_font );
+ free( psz_colour );
+
if( p_intf->p_sys->p_osd == NULL )
{
msg_Err( p_intf, "couldn't initialize libxosd" );
msg_Err( p_intf, "couldn't initialize libxosd" );
return VLC_EGENERIC;
}
- xosd_set_colour( p_osd, config_GetPsz( p_intf,"xosd-colour" ) );
+
+ psz_colour = config_GetPsz( p_intf,"xosd-colour" );
+ xosd_set_colour( p_osd, psz_colour );
xosd_set_timeout( p_osd, 3 );
+ free( psz_colour );
#endif
pl_Release( p_intf );
/* Set user preferences */
- xosd_set_font( p_intf->p_sys->p_osd,
- config_GetPsz( p_intf, "xosd-font" ) );
+ psz_font = config_GetPsz( p_intf, "xosd-font" );
+ xosd_set_font( p_intf->p_sys->p_osd, psz_font );
+ free( psz_font );
xosd_set_outline_colour( p_intf->p_sys->p_osd,"black" );
#ifdef HAVE_XOSD_VERSION_2
xosd_set_horizontal_offset( p_intf->p_sys->p_osd,
p_intf->pf_run = Run;
- p_intf->p_sys->b_need_update = VLC_TRUE;
+ p_intf->p_sys->b_need_update = true;
return VLC_SUCCESS;
}
char psz_duration[MSTRTIME_MAX_SIZE+2];
char *psz_display = NULL;
- while( !p_intf->b_die )
+ while( vlc_object_alive (p_intf) )
{
- if( p_intf->p_sys->b_need_update == VLC_TRUE )
+ if( p_intf->p_sys->b_need_update == true )
{
- p_intf->p_sys->b_need_update = VLC_FALSE;
+ p_intf->p_sys->b_need_update = false;
p_playlist = pl_Yield( p_intf );
- if( !playlist_IsEmpty( p_playlist ) )
+ if( playlist_IsEmpty( p_playlist ) )
{
- vlc_object_release( p_playlist );
+ pl_Release( p_intf );
continue;
}
- if( psz_display )
- {
- free( psz_display );
- psz_display = NULL;
- }
+ free( psz_display );
+ psz_display = NULL;
if( p_playlist->status.i_status == PLAYLIST_STOPPED )
{
psz_display = strdup(_("Stop"));
- vlc_object_release( p_playlist );
+ pl_Release( p_intf );
}
else if( p_playlist->status.i_status == PLAYLIST_PAUSED )
{
psz_display = strdup(_("Pause"));
- vlc_object_release( p_playlist );
+ pl_Release( p_intf );
}
else
{
p_item = p_playlist->status.p_item;
p_input = p_item->p_input;
+
+ pl_Release( p_intf );
if( !p_item )
- {
- vlc_object_release( p_playlist );
continue;
- }
-
- vlc_object_release( p_playlist );
- if( p_input->i_duration != -1 )
+ mtime_t i_duration = input_item_GetDuration( p_input );
+ if( i_duration != -1 )
{
char psz_durationstr[MSTRTIME_MAX_SIZE];
- secstotimestr( psz_durationstr, p_input->i_duration/1000000 );
+ secstotimestr( psz_durationstr, i_duration / 1000000 );
sprintf( psz_duration, "(%s)", psz_durationstr );
}
else
{
intf_thread_t *p_intf = (intf_thread_t *)param;
- p_intf->p_sys->b_need_update = VLC_TRUE;
+ p_intf->p_sys->b_need_update = true;
return VLC_SUCCESS;
}