@ -1528,26 +1528,23 @@ static int mkv_write_simpletag(AVIOContext *pb, const AVDictionaryEntry *t)
return 0 ;
return 0 ;
}
}
static int mkv_write_tag_targets ( AVFormatContext * s , uint32_t elementid ,
static int mkv_write_tag_targets ( MatroskaMuxContext * mkv , AVIOContext * * pb ,
uint64_t uid , ebml_master * tag )
ebml_master * tag , uint32_t elementid , uint64_t uid )
{
{
AVIOContext * pb ;
MatroskaMuxContext * mkv = s - > priv_data ;
ebml_master targets ;
ebml_master targets ;
int ret ;
int ret ;
if ( ! mkv - > tags . bc ) {
if ( ! * pb ) {
ret = start_ebml_master_crc32 ( & mkv - > tags . bc , mkv ) ;
ret = start_ebml_master_crc32 ( p b, mkv ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
}
}
pb = mkv - > tags . bc ;
* tag = start_ebml_master ( pb , MATROSKA_ID_TAG , 0 ) ;
* tag = start_ebml_master ( * pb , MATROSKA_ID_TAG , 0 ) ;
targets = start_ebml_master ( pb , MATROSKA_ID_TAGTARGETS , 4 + 1 + 8 ) ;
targets = start_ebml_master ( * pb , MATROSKA_ID_TAGTARGETS , 4 + 1 + 8 ) ;
if ( elementid )
if ( elementid )
put_ebml_uid ( pb , elementid , uid ) ;
put_ebml_uid ( * pb , elementid , uid ) ;
end_ebml_master ( pb , targets ) ;
end_ebml_master ( * pb , targets ) ;
return 0 ;
return 0 ;
}
}
@ -1565,28 +1562,28 @@ static int mkv_check_tag_name(const char *name, uint32_t elementid)
av_strcasecmp ( name , " mimetype " ) ) ) ;
av_strcasecmp ( name , " mimetype " ) ) ) ;
}
}
static int mkv_write_tag ( AVFormatContext * s , const AVDictionary * m ,
static int mkv_write_tag ( MatroskaMuxContext * mkv , const AVDictionary * m ,
uint32_t elementid , uint64_t uid , ebml_master * tag )
AVIOContext * * pb , ebml_master * tag ,
uint32_t elementid , uint64_t uid )
{
{
MatroskaMuxContext * mkv = s - > priv_data ;
const AVDictionaryEntry * t = NULL ;
const AVDictionaryEntry * t = NULL ;
ebml_master tag2 ;
ebml_master tag2 ;
int ret ;
int ret ;
ret = mkv_write_tag_targets ( s , elementid , uid , tag ? tag : & tag2 ) ;
ret = mkv_write_tag_targets ( mkv , pb , tag ? tag : & tag2 , elementid , uid ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
while ( ( t = av_dict_get ( m , " " , t , AV_DICT_IGNORE_SUFFIX ) ) ) {
while ( ( t = av_dict_get ( m , " " , t , AV_DICT_IGNORE_SUFFIX ) ) ) {
if ( mkv_check_tag_name ( t - > key , elementid ) ) {
if ( mkv_check_tag_name ( t - > key , elementid ) ) {
ret = mkv_write_simpletag ( mkv - > tags . bc , t ) ;
ret = mkv_write_simpletag ( * pb , t ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
}
}
}
}
if ( ! tag )
if ( ! tag )
end_ebml_master ( mkv - > tags . bc , tag2 ) ;
end_ebml_master ( * pb , tag2 ) ;
return 0 ;
return 0 ;
}
}
@ -1611,7 +1608,7 @@ static int mkv_write_tags(AVFormatContext *s)
ff_metadata_conv_ctx ( s , ff_mkv_metadata_conv , NULL ) ;
ff_metadata_conv_ctx ( s , ff_mkv_metadata_conv , NULL ) ;
if ( mkv_check_tag ( s - > metadata , 0 ) ) {
if ( mkv_check_tag ( s - > metadata , 0 ) ) {
ret = mkv_write_tag ( s , s - > metadata , 0 , 0 , NULL ) ;
ret = mkv_write_tag ( mkv , s - > metadata , & mkv - > tags . bc , NULL , 0 , 0 ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
}
}
@ -1626,8 +1623,8 @@ static int mkv_write_tags(AVFormatContext *s)
if ( ! tagp & & ! mkv_check_tag ( st - > metadata , MATROSKA_ID_TAGTARGETS_TRACKUID ) )
if ( ! tagp & & ! mkv_check_tag ( st - > metadata , MATROSKA_ID_TAGTARGETS_TRACKUID ) )
continue ;
continue ;
ret = mkv_write_tag ( s , st - > metadata , MATROSKA_ID_TAGTARGETS_TRACKUID ,
ret = mkv_write_tag ( mkv , st - > metadata , & mkv - > tags . bc , tagp ,
track - > uid , tagp ) ;
MATROSKA_ID_TAGTARGETS_TRACKUID , track - > uid ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
@ -1655,9 +1652,9 @@ static int mkv_write_tags(AVFormatContext *s)
if ( ! mkv_check_tag ( ch - > metadata , MATROSKA_ID_TAGTARGETS_CHAPTERUID ) )
if ( ! mkv_check_tag ( ch - > metadata , MATROSKA_ID_TAGTARGETS_CHAPTERUID ) )
continue ;
continue ;
ret = mkv_write_tag ( s , ch - > metadata , MATROSKA_ID_TAGTARGETS_CHAPTERUID ,
ret = mkv_write_tag ( mkv , ch - > metadata , & mkv - > tags . bc , NULL ,
( uint32_t ) ch - > id + ( uint64_t ) mkv - > chapter_id_offset ,
MATROSKA_ID_TAGTARGETS_CHAPTERUID ,
NULL ) ;
( uint32_t ) ch - > id + ( uint64_t ) mkv - > chapter_id_offset ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
}
}
@ -1674,8 +1671,8 @@ static int mkv_write_tags(AVFormatContext *s)
if ( ! mkv_check_tag ( st - > metadata , MATROSKA_ID_TAGTARGETS_ATTACHUID ) )
if ( ! mkv_check_tag ( st - > metadata , MATROSKA_ID_TAGTARGETS_ATTACHUID ) )
continue ;
continue ;
ret = mkv_write_tag ( s , st - > metadata , MATROSKA_ID_TAGTARGETS_ATTACHUID ,
ret = mkv_write_tag ( mkv , st - > metadata , & mkv - > tags . bc , NULL ,
track - > uid , NULL ) ;
MATROSKA_ID_TAGTARGETS_ATTACHUID , track - > uid ) ;
if ( ret < 0 )
if ( ret < 0 )
return ret ;
return ret ;
}
}