X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fmisc%2Fsvg.c;h=fc54819134f47070b1b111dd5fa82b25c9ca2632;hb=12ade3e3bc975d5426ba4af155b7372c31093b31;hp=c6cf3d140c97f60e2bf40cbe3a73a4baba2af1c2;hpb=152b1687c0ec112f3ab1360006d048d6b9cf7258;p=vlc diff --git a/modules/misc/svg.c b/modules/misc/svg.c index c6cf3d140c..fc54819134 100644 --- a/modules/misc/svg.c +++ b/modules/misc/svg.c @@ -31,15 +31,13 @@ #include #include -#include +#include #include #include #include #include -#ifdef HAVE_SYS_TYPES_H -# include -#endif +#include #ifdef HAVE_UNISTD_H # include @@ -50,7 +48,7 @@ #include #include #include /* g_object_unref( ) */ -#include +#include typedef struct svg_rendition_t svg_rendition_t; @@ -160,7 +158,7 @@ static char *svg_GetTemplate( vlc_object_t *p_this ) char *psz_template; FILE *file; - psz_filename = config_GetPsz( p_filter, "svg-template-file" ); + psz_filename = var_InheritString( p_filter, "svg-template-file" ); if( !psz_filename || (psz_filename[0] == 0) ) { /* No filename. Use a default value. */ @@ -169,7 +167,7 @@ static char *svg_GetTemplate( vlc_object_t *p_this ) else { /* Read the template */ - file = utf8_fopen( psz_filename, "rt" ); + file = vlc_fopen( psz_filename, "rt" ); if( !file ) { msg_Warn( p_this, "SVG template file %s does not exist.", @@ -197,14 +195,13 @@ static char *svg_GetTemplate( vlc_object_t *p_this ) msg_Dbg( p_this, "reading %ld bytes from template %s", (unsigned long)s.st_size, psz_filename ); - psz_template = malloc( s.st_size + 42 ); + psz_template = calloc( 1, s.st_size + 42 ); if( !psz_template ) { fclose( file ); free( psz_filename ); return NULL; } - memset( psz_template, 0, s.st_size + 1 ); if(! fread( psz_template, s.st_size, 1, file ) ) { msg_Dbg( p_this, "No data read from template." ); @@ -278,12 +275,13 @@ static int Render( filter_t *p_filter, subpicture_region_t *p_region, /* Create a new subpicture region */ memset( &fmt, 0, sizeof( video_format_t ) ); fmt.i_chroma = VLC_CODEC_YUVA; - fmt.i_aspect = VOUT_ASPECT_FACTOR; fmt.i_width = fmt.i_visible_width = i_width; fmt.i_height = fmt.i_visible_height = i_height; fmt.i_x_offset = fmt.i_y_offset = 0; + fmt.i_sar_num = 1; + fmt.i_sar_den = 1; - p_region->p_picture = picture_New( fmt.i_chroma, fmt.i_width, fmt.i_height, fmt.i_aspect ); + p_region->p_picture = picture_NewFromFormat( &fmt ); if( !p_region->p_picture ) return VLC_EGENERIC; p_region->fmt = fmt; @@ -404,7 +402,7 @@ static void svg_RenderPicture( filter_t *p_filter, if( !p_handle ) { - msg_Err( p_filter, "Error creating SVG reader: %s", error->message ); + msg_Err( p_filter, "Error creating SVG reader" ); return; } @@ -470,13 +468,12 @@ static int RenderText( filter_t *p_filter, subpicture_region_t *p_region_out, int length; char* psz_template = p_sys->psz_template; length = strlen( psz_string ) + strlen( psz_template ) + 42; - p_svg->psz_text = malloc( length + 1 ); + p_svg->psz_text = calloc( 1, length + 1 ); if( !p_svg->psz_text ) { free( p_svg ); return VLC_ENOMEM; } - memset( p_svg->psz_text, 0, length + 1 ); snprintf( p_svg->psz_text, length, psz_template, psz_string ); } p_svg->i_width = p_sys->i_width;