/*****************************************************************************
* Preamble
*****************************************************************************/
-#include <vlc/vlc.h>
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <vlc_common.h>
#include <assert.h>
/* Needed by str_format_time */
return strdup( psz_enc );
}
+static const struct xml_entity_s
+{
+ char psz_entity[9];
+ uint8_t i_length;
+ char psz_char[4];
+} p_xml_entities[] = {
+ /* Important: this list has to be in alphabetical order (psz_entity-wise) */
+ { "Æ", 7, "Æ" },
+ { "Á", 8, "Á" },
+ { "Â", 7, "Â" },
+ { "À", 8, "À" },
+ { "Å", 7, "Å" },
+ { "Ã", 8, "Ã" },
+ { "Ä", 6, "Ä" },
+ { "Ç", 8, "Ç" },
+ { "‡", 8, "‡" },
+ { "Ð", 5, "Ð" },
+ { "É", 8, "É" },
+ { "Ê", 7, "Ê" },
+ { "È", 8, "È" },
+ { "Ë", 6, "Ë" },
+ { "Í", 8, "Í" },
+ { "Î", 7, "Î" },
+ { "Ì", 8, "Ì" },
+ { "Ï", 6, "Ï" },
+ { "Ñ", 8, "Ñ" },
+ { "Œ", 7, "Œ" },
+ { "Ó", 8, "Ó" },
+ { "Ô", 7, "Ô" },
+ { "Ò", 8, "Ò" },
+ { "Ø", 8, "Ø" },
+ { "Õ", 8, "Õ" },
+ { "Ö", 6, "Ö" },
+ { "Š", 8, "Š" },
+ { "Þ", 7, "Þ" },
+ { "Ú", 8, "Ú" },
+ { "Û", 7, "Û" },
+ { "Ù", 8, "Ù" },
+ { "Ü", 6, "Ü" },
+ { "Ý", 8, "Ý" },
+ { "Ÿ", 6, "Ÿ" },
+ { "á", 8, "á" },
+ { "â", 7, "â" },
+ { "´", 7, "´" },
+ { "æ", 7, "æ" },
+ { "à", 8, "à" },
+ { "å", 7, "å" },
+ { "ã", 8, "ã" },
+ { "ä", 6, "ä" },
+ { "„", 7, "„" },
+ { "¦", 8, "¦" },
+ { "ç", 8, "ç" },
+ { "¸", 7, "¸" },
+ { "¢", 6, "¢" },
+ { "ˆ", 6, "ˆ" },
+ { "©", 6, "©" },
+ { "¤", 8, "¤" },
+ { "†", 8, "†" },
+ { "°", 5, "°" },
+ { "÷", 8, "÷" },
+ { "é", 8, "é" },
+ { "ê", 7, "ê" },
+ { "è", 8, "è" },
+ { "ð", 5, "ð" },
+ { "ë", 6, "ë" },
+ { "€", 6, "€" },
+ { "½", 8, "½" },
+ { "¼", 8, "¼" },
+ { "¾", 8, "¾" },
+ { "…", 8, "…" },
+ { "í", 8, "í" },
+ { "î", 7, "î" },
+ { "¡", 7, "¡" },
+ { "ì", 8, "ì" },
+ { "¿", 8, "¿" },
+ { "ï", 6, "ï" },
+ { "«", 7, "«" },
+ { "“", 7, "“" },
+ { "‹", 8, "‹" },
+ { "‘", 7, "‘" },
+ { "¯", 6, "¯" },
+ { "—", 7, "—" },
+ { "µ", 7, "µ" },
+ { "·", 8, "·" },
+ { "–", 7, "–" },
+ { "¬", 5, "¬" },
+ { "ñ", 8, "ñ" },
+ { "ó", 8, "ó" },
+ { "ô", 7, "ô" },
+ { "œ", 7, "œ" },
+ { "ò", 8, "ò" },
+ { "ª", 6, "ª" },
+ { "º", 6, "º" },
+ { "ø", 8, "ø" },
+ { "õ", 8, "õ" },
+ { "ö", 6, "ö" },
+ { "¶", 6, "¶" },
+ { "‰", 8, "‰" },
+ { "±", 8, "±" },
+ { "£", 7, "£" },
+ { "»", 7, "»" },
+ { "”", 7, "”" },
+ { "®", 5, "®" },
+ { "›", 8, "›" },
+ { "’", 7, "’" },
+ { "‚", 7, "‚" },
+ { "š", 8, "š" },
+ { "§", 6, "§" },
+ { "­", 5, "" },
+ { "¹", 6, "¹" },
+ { "²", 6, "²" },
+ { "³", 6, "³" },
+ { "ß", 7, "ß" },
+ { "þ", 7, "þ" },
+ { "˜", 7, "˜" },
+ { "×", 7, "×" },
+ { "™", 7, "™" },
+ { "ú", 8, "ú" },
+ { "û", 7, "û" },
+ { "ù", 8, "ù" },
+ { "¨", 5, "¨" },
+ { "ü", 6, "ü" },
+ { "ý", 8, "ý" },
+ { "¥", 5, "¥" },
+ { "ÿ", 6, "ÿ" },
+};
+
/**
* Converts "<", ">" and "&" to "<", ">" and "&"
* \param string to convert
*p_pos = dst; \
psz_value += len; \
}
-#define TRY_LONGCHAR( src, len, dst ) \
- if( !strncmp( psz_value, src, len ) ) \
- { \
- strncpy( p_pos, dst, strlen( dst ) ); \
- p_pos += strlen( dst ) - 1; \
- psz_value += len; \
- }
TRY_CHAR( "<", 4, '<' )
- else TRY_CHAR( ">", 4, '>' )
else TRY_CHAR( "&", 5, '&' )
- else TRY_CHAR( """, 6, '"' )
else TRY_CHAR( "'", 6, '\'' )
+ else TRY_CHAR( ">", 4, '>' )
+ else TRY_CHAR( """, 6, '"' )
+#undef TRY_CHAR
else if( psz_value[1] == '#' )
{
char *psz_end;
psz_value++;
}
}
- else TRY_LONGCHAR( "À", 8, "À" )
- else TRY_LONGCHAR( "Á", 8, "Á" )
- else TRY_LONGCHAR( "Â", 7, "Â" )
- else TRY_LONGCHAR( "Ã", 8, "Ã" )
- else TRY_LONGCHAR( "Ä", 6, "Ä" )
- else TRY_LONGCHAR( "Å", 7, "Å" )
- else TRY_LONGCHAR( "Æ", 7, "Æ" )
- else TRY_LONGCHAR( "Ç", 8, "Ç" )
- else TRY_LONGCHAR( "È", 8, "È" )
- else TRY_LONGCHAR( "É", 8, "É" )
- else TRY_LONGCHAR( "Ê", 7, "Ê" )
- else TRY_LONGCHAR( "Ë", 6, "Ë" )
- else TRY_LONGCHAR( "Ì", 8, "Ì" )
- else TRY_LONGCHAR( "Í", 8, "Í" )
- else TRY_LONGCHAR( "Î", 7, "Î" )
- else TRY_LONGCHAR( "Ï", 6, "Ï" )
- else TRY_LONGCHAR( "Ð", 5, "Ð" )
- else TRY_LONGCHAR( "Ñ", 8, "Ñ" )
- else TRY_LONGCHAR( "Ò", 8, "Ò" )
- else TRY_LONGCHAR( "Ó", 8, "Ó" )
- else TRY_LONGCHAR( "Ô", 7, "Ô" )
- else TRY_LONGCHAR( "Õ", 8, "Õ" )
- else TRY_LONGCHAR( "Ö", 6, "Ö" )
- else TRY_LONGCHAR( "Ø", 8, "Ø" )
- else TRY_LONGCHAR( "Ù", 8, "Ù" )
- else TRY_LONGCHAR( "Ú", 8, "Ú" )
- else TRY_LONGCHAR( "Û", 7, "Û" )
- else TRY_LONGCHAR( "Ü", 6, "Ü" )
- else TRY_LONGCHAR( "Ý", 8, "Ý" )
- else TRY_LONGCHAR( "Þ", 7, "Þ" )
- else TRY_LONGCHAR( "ß", 7, "ß" )
- else TRY_LONGCHAR( "à", 8, "à" )
- else TRY_LONGCHAR( "á", 8, "á" )
- else TRY_LONGCHAR( "â", 7, "â" )
- else TRY_LONGCHAR( "ã", 8, "ã" )
- else TRY_LONGCHAR( "ä", 6, "ä" )
- else TRY_LONGCHAR( "å", 7, "å" )
- else TRY_LONGCHAR( "æ", 7, "æ" )
- else TRY_LONGCHAR( "ç", 8, "ç" )
- else TRY_LONGCHAR( "è", 8, "è" )
- else TRY_LONGCHAR( "é", 8, "é" )
- else TRY_LONGCHAR( "ê", 7, "ê" )
- else TRY_LONGCHAR( "ë", 6, "ë" )
- else TRY_LONGCHAR( "ì", 8, "ì" )
- else TRY_LONGCHAR( "í", 8, "í" )
- else TRY_LONGCHAR( "î", 7, "î" )
- else TRY_LONGCHAR( "ï", 6, "ï" )
- else TRY_LONGCHAR( "ð", 5, "ð" )
- else TRY_LONGCHAR( "ñ", 8, "ñ" )
- else TRY_LONGCHAR( "ò", 8, "ò" )
- else TRY_LONGCHAR( "ó", 8, "ó" )
- else TRY_LONGCHAR( "ô", 7, "ô" )
- else TRY_LONGCHAR( "õ", 8, "õ" )
- else TRY_LONGCHAR( "ö", 6, "ö" )
- else TRY_LONGCHAR( "ø", 8, "ø" )
- else TRY_LONGCHAR( "ù", 8, "ù" )
- else TRY_LONGCHAR( "ú", 8, "ú" )
- else TRY_LONGCHAR( "û", 7, "û" )
- else TRY_LONGCHAR( "ü", 6, "ü" )
- else TRY_LONGCHAR( "ý", 8, "ý" )
- else TRY_LONGCHAR( "þ", 7, "þ" )
- else TRY_LONGCHAR( "ÿ", 6, "ÿ" )
- else TRY_LONGCHAR( "¡", 7, "¡" )
- else TRY_LONGCHAR( "¤", 8, "¤" )
- else TRY_LONGCHAR( "¢", 6, "¢" )
- else TRY_LONGCHAR( "£", 7, "£" )
- else TRY_LONGCHAR( "¥", 5, "¥" )
- else TRY_LONGCHAR( "¦", 8, "¦" )
- else TRY_LONGCHAR( "§", 6, "§" )
- else TRY_LONGCHAR( "¨", 5, "¨" )
- else TRY_LONGCHAR( "©", 6, "©" )
- else TRY_LONGCHAR( "ª", 6, "ª" )
- else TRY_LONGCHAR( "«", 7, "«" )
- else TRY_LONGCHAR( "¬", 5, "¬" )
- else TRY_LONGCHAR( "­", 5, "" )
- else TRY_LONGCHAR( "®", 5, "®" )
- else TRY_LONGCHAR( "™", 7, "™" )
- else TRY_LONGCHAR( "¯", 6, "¯" )
- else TRY_LONGCHAR( "°", 5, "°" )
- else TRY_LONGCHAR( "±", 8, "±" )
- else TRY_LONGCHAR( "²", 6, "²" )
- else TRY_LONGCHAR( "³", 6, "³" )
- else TRY_LONGCHAR( "´", 7, "´" )
- else TRY_LONGCHAR( "µ", 7, "µ" )
- else TRY_LONGCHAR( "¶", 6, "¶" )
- else TRY_LONGCHAR( "·", 8, "·" )
- else TRY_LONGCHAR( "¸", 7, "¸" )
- else TRY_LONGCHAR( "¹", 6, "¹" )
- else TRY_LONGCHAR( "º", 6, "º" )
- else TRY_LONGCHAR( "»", 7, "»" )
- else TRY_LONGCHAR( "¼", 8, "¼" )
- else TRY_LONGCHAR( "½", 8, "½" )
- else TRY_LONGCHAR( "¾", 8, "¾" )
- else TRY_LONGCHAR( "¿", 8, "¿" )
- else TRY_LONGCHAR( "×", 7, "×" )
- else TRY_LONGCHAR( "÷", 8, "÷" )
- else TRY_LONGCHAR( "Œ", 7, "Œ" )
- else TRY_LONGCHAR( "œ", 7, "œ" )
- else TRY_LONGCHAR( "Š", 8, "Š" )
- else TRY_LONGCHAR( "š", 8, "š" )
- else TRY_LONGCHAR( "Ÿ", 6, "Ÿ" )
- else TRY_LONGCHAR( "ˆ", 6, "ˆ" )
- else TRY_LONGCHAR( "˜", 7, "˜" )
- else TRY_LONGCHAR( "–", 7, "–" )
- else TRY_LONGCHAR( "—", 7, "—" )
- else TRY_LONGCHAR( "‘", 7, "‘" )
- else TRY_LONGCHAR( "’", 7, "’" )
- else TRY_LONGCHAR( "‚", 7, "‚" )
- else TRY_LONGCHAR( "“", 7, "“" )
- else TRY_LONGCHAR( "”", 7, "”" )
- else TRY_LONGCHAR( "„", 7, "„" )
- else TRY_LONGCHAR( "†", 8, "†" )
- else TRY_LONGCHAR( "‡", 8, "‡" )
- else TRY_LONGCHAR( "…", 8, "…" )
- else TRY_LONGCHAR( "‰", 8, "‰" )
- else TRY_LONGCHAR( "‹", 8, "‹" )
- else TRY_LONGCHAR( "›", 8, "›" )
- else TRY_LONGCHAR( "€", 6, "€" )
else
{
- *p_pos = *psz_value;
- psz_value++;
+ const size_t i_entities = sizeof( p_xml_entities ) /
+ sizeof( p_xml_entities[0] );
+ assert( i_entities < 128 );
+ size_t step = 128>>1;
+ size_t i = step-1;
+ int cmp = -1;
+ while( step )
+ {
+ step >>= 1;
+ if( i >= i_entities )
+ cmp = -1;
+ else
+ cmp = strncmp( psz_value, p_xml_entities[i].psz_entity,
+ p_xml_entities[i].i_length );
+ if( cmp == 0 )
+ {
+ strncpy( p_pos, p_xml_entities[i].psz_char,
+ p_xml_entities[i].i_length );
+ p_pos += strlen( p_xml_entities[i].psz_char ) - 1;
+ psz_value += p_xml_entities[i].i_length;
+ break;
+ }
+ else if( cmp < 0 )
+ i -= step;
+ else
+ i += step;
+ }
+ if( cmp != 0 )
+ {
+ *p_pos = *psz_value;
+ psz_value++;
+ }
}
}
else
int i_level;
int i_last;
- for( i_level = 0, i_last = 0; i_dst > 0 && *p != '\0'; i_dst--, p++ )
+ for( i_level = 0, i_last = 0; (size_t)( p_dst - p_start ) < i_dst && *p != '\0'; p++ )
{
const int c = b64[(unsigned int)*p];
if( c == -1 )
{
char buffer[255];
time_t curtime;
-#if defined(HAVE_LOCALTIME_R)
struct tm loctime;
-#else
- struct tm *loctime;
-#endif
/* Get the current time. */
curtime = time( NULL );
/* Convert it to local time representation. */
-#if defined(HAVE_LOCALTIME_R)
localtime_r( &curtime, &loctime );
strftime( buffer, 255, tformat, &loctime );
-#else
- loctime = localtime( &curtime );
- strftime( buffer, 255, tformat, loctime );
-#endif
return strdup( buffer );
}
-#define INSERT_STRING( check, string ) \
- if( check ) \
+#define INSERT_STRING( string ) \
+ if( string != NULL ) \
+ { \
+ int len = strlen( string ); \
+ dst = realloc( dst, i_size = i_size + len );\
+ memcpy( (dst+d), string, len ); \
+ d += len; \
+ free( string ); \
+ } \
+ else if( !b_empty_if_na ) \
+ { \
+ *(dst+d) = '-'; \
+ d++; \
+ } \
+
+/* same than INSERT_STRING, except that string won't be freed */
+#define INSERT_STRING_NO_FREE( string ) \
{ \
- psz_meta = string; \
- if( string ) \
- { \
- int len = strlen( psz_meta ); \
- dst = realloc( dst, \
- i_size = i_size + len + 1 ); \
- strncpy( d, psz_meta, len+1 ); \
- d += len; \
- free( psz_meta ); \
- } \
- else \
- { \
- *d = '-'; \
- d++; \
- } \
+ int len = strlen( string ); \
+ dst = realloc( dst, i_size = i_size + len );\
+ memcpy( dst+d, string, len ); \
+ d += len; \
}
char *__str_format_meta( vlc_object_t *p_object, const char *string )
{
const char *s = string;
- char *dst = malloc( 1000 );
- char *d = dst;
- int b_is_format = 0;
- int b_empty_if_na = 0;
+ bool b_is_format = false;
+ bool b_empty_if_na = false;
char buf[10];
- int i_size = strlen( string );
+ int i_size = strlen( string ) + 1; /* +1 to store '\0' */
+ char *dst = strdup( string );
+ if( !dst ) return NULL;
+ int d = 0;
- playlist_t *p_playlist = pl_Yield( p_object );
- input_thread_t *p_input = p_playlist->p_input;
+ playlist_t *p_playlist = pl_Hold( p_object );
+ input_thread_t *p_input = playlist_CurrentInput( p_playlist );
input_item_t *p_item = NULL;
pl_Release( p_object );
if( p_input )
{
- vlc_object_yield( p_input );
p_item = input_GetItem(p_input);
- if( p_item )
- vlc_mutex_lock( &p_item->lock );
}
- sprintf( dst, string );
-
while( *s )
{
if( b_is_format )
{
switch( *s )
{
- char *psz_meta; /* used by INSERT_STRING */
case 'a':
- INSERT_STRING( p_item, input_item_GetArtist(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetArtist( p_item ) );
+ }
break;
case 'b':
- INSERT_STRING( p_item, input_item_GetAlbum(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetAlbum( p_item ) );
+ }
break;
case 'c':
- INSERT_STRING( p_item, input_item_GetCopyright(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetCopyright( p_item ) );
+ }
break;
case 'd':
- INSERT_STRING( p_item, input_item_GetDescription(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetDescription( p_item ) );
+ }
break;
case 'e':
- INSERT_STRING( p_item, input_item_GetEncodedBy(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetEncodedBy( p_item ) );
+ }
+ break;
+ case 'f':
+ if( p_item && p_item->p_stats )
+ {
+ snprintf( buf, 10, "%d",
+ p_item->p_stats->i_displayed_pictures );
+ }
+ else
+ {
+ sprintf( buf, b_empty_if_na ? "" : "-" );
+ }
+ INSERT_STRING_NO_FREE( buf );
break;
case 'g':
- INSERT_STRING( p_item, input_item_GetGenre(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetGenre( p_item ) );
+ }
break;
case 'l':
- INSERT_STRING( p_item, input_item_GetLanguage(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetLanguage( p_item ) );
+ }
break;
case 'n':
- INSERT_STRING( p_item, input_item_GetTrackNum(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetTrackNum( p_item ) );
+ }
break;
case 'p':
- INSERT_STRING( p_item, input_item_GetNowPlaying(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetNowPlaying( p_item ) );
+ }
break;
case 'r':
- INSERT_STRING( p_item, input_item_GetRating(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetRating( p_item ) );
+ }
break;
case 's':
{
- char *lang;
+ char *lang = NULL;
if( p_input )
- {
- lang = var_GetString( p_input, "sub-language" );
- }
- else
- {
+ lang = var_GetNonEmptyString( p_input, "sub-language" );
+ if( lang == NULL )
lang = strdup( b_empty_if_na ? "" : "-" );
- }
- INSERT_STRING( 1, lang );
- free( lang );
+ INSERT_STRING( lang );
break;
}
case 't':
- INSERT_STRING( p_item, input_item_GetTitle(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetTitle( p_item ) );
+ }
break;
case 'u':
- INSERT_STRING( p_item, input_item_GetURL(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetURL( p_item ) );
+ }
break;
case 'A':
- INSERT_STRING( p_item, input_item_GetDate(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetDate( p_item ) );
+ }
break;
case 'B':
if( p_input )
{
sprintf( buf, b_empty_if_na ? "" : "-" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'C':
if( p_input )
{
sprintf( buf, b_empty_if_na ? "" : "-" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'D':
if( p_item )
{
+ mtime_t i_duration = input_item_GetDuration( p_item );
sprintf( buf, "%02d:%02d:%02d",
- (int)(p_item->i_duration/(3600000000)),
- (int)((p_item->i_duration/(60000000))%60),
- (int)((p_item->i_duration/1000000)%60) );
+ (int)(i_duration/(3600000000)),
+ (int)((i_duration/(60000000))%60),
+ (int)((i_duration/1000000)%60) );
}
else
{
sprintf( buf, b_empty_if_na ? "" : "--:--:--" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'F':
- INSERT_STRING( p_item, p_item->psz_uri );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetURI( p_item ) );
+ }
break;
case 'I':
if( p_input )
{
sprintf( buf, b_empty_if_na ? "" : "-" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'L':
if( p_item && p_input )
{
+ mtime_t i_duration = input_item_GetDuration( p_item );
+ int64_t i_time = p_input->i_time;
sprintf( buf, "%02d:%02d:%02d",
- (int)((p_item->i_duration-p_input->i_time)/(3600000000)),
- (int)(((p_item->i_duration-p_input->i_time)/(60000000))%60),
- (int)(((p_item->i_duration-p_input->i_time)/1000000)%60) );
+ (int)( ( i_duration - i_time ) / 3600000000 ),
+ (int)( ( ( i_duration - i_time ) / 60000000 ) % 60 ),
+ (int)( ( ( i_duration - i_time ) / 1000000 ) % 60 ) );
}
else
{
sprintf( buf, b_empty_if_na ? "" : "--:--:--" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'N':
- INSERT_STRING( p_item, p_item->psz_name );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetName( p_item ) );
+ }
break;
case 'O':
{
- char *lang;
+ char *lang = NULL;
if( p_input )
- {
- lang = var_GetString( p_input, "audio-language" );
- }
- else
- {
+ lang = var_GetNonEmptyString( p_input,
+ "audio-language" );
+ if( lang == NULL )
lang = strdup( b_empty_if_na ? "" : "-" );
- }
- INSERT_STRING( 1, lang );
- free( lang );
+ INSERT_STRING( lang );
break;
}
case 'P':
{
sprintf( buf, b_empty_if_na ? "" : "--.-%%" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'R':
if( p_input )
{
sprintf( buf, b_empty_if_na ? "" : "-" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'S':
if( p_input )
{
sprintf( buf, b_empty_if_na ? "" : "-" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'T':
if( p_input )
{
sprintf( buf, "%02d:%02d:%02d",
- (int)(p_input->i_time/(3600000000)),
- (int)((p_input->i_time/(60000000))%60),
- (int)((p_input->i_time/1000000)%60) );
+ (int)( p_input->i_time / ( 3600000000 ) ),
+ (int)( ( p_input->i_time / ( 60000000 ) ) % 60 ),
+ (int)( ( p_input->i_time / 1000000 ) % 60 ) );
}
else
{
sprintf( buf, b_empty_if_na ? "" : "--:--:--" );
}
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
case 'U':
- INSERT_STRING( p_item, input_item_GetPublisher(p_item) );
+ if( p_item )
+ {
+ INSERT_STRING( input_item_GetPublisher( p_item ) );
+ }
break;
case 'V':
{
audio_volume_t volume;
aout_VolumeGet( p_object, &volume );
snprintf( buf, 10, "%d", volume );
- INSERT_STRING( 1, buf );
+ INSERT_STRING_NO_FREE( buf );
break;
}
case '_':
- *d = '\n';
+ *(dst+d) = '\n';
d++;
break;
case ' ':
- b_empty_if_na = 1;
+ b_empty_if_na = true;
break;
default:
- *d = *s;
+ *(dst+d) = *s;
d++;
break;
}
if( *s != ' ' )
- b_is_format = 0;
+ b_is_format = false;
}
else if( *s == '$' )
{
- b_is_format = 1;
- b_empty_if_na = 0;
+ b_is_format = true;
+ b_empty_if_na = false;
}
else
{
- *d = *s;
+ *(dst+d) = *s;
d++;
}
s++;
}
- *d = '\0';
+ *(dst+d) = '\0';
if( p_input )
- {
vlc_object_release( p_input );
- if( p_item )
- vlc_mutex_unlock( &p_item->lock );
- }
return dst;
}
+#undef INSERT_STRING
+#undef INSERT_STRING_NO_FREE
/**
* Apply str format time and str format meta
switch( *str )
{
case '/':
-#ifdef WIN32
+#if defined( __APPLE__ )
+ case ':':
+#elif defined( WIN32 )
case '\\':
case '*':
case '"':
#endif
while( *str )
{
-#ifdef WIN32
+#if defined( __APPLE__ )
+ if( *str == ':' )
+ *str = '_';
+#elif defined( WIN32 )
switch( *str )
{
case '*':