mirror of https://git.ffmpeg.org/ffmpeg.git
Chapter demuxing support. (untested as I have no nuts with chapters)
Isn't that much simpler than Matroska? Originally committed as revision 13263 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
5c37f43a0d
commit
883fe4d5bb
|
@ -393,6 +393,7 @@ static int decode_info_header(NUTContext *nut){
|
||||||
int64_t value, end;
|
int64_t value, end;
|
||||||
char name[256], str_value[1024], type_str[256];
|
char name[256], str_value[1024], type_str[256];
|
||||||
const char *type;
|
const char *type;
|
||||||
|
AVChapter *chapter= NULL;
|
||||||
|
|
||||||
end= get_packetheader(nut, bc, 1, INFO_STARTCODE);
|
end= get_packetheader(nut, bc, 1, INFO_STARTCODE);
|
||||||
end += url_ftell(bc);
|
end += url_ftell(bc);
|
||||||
|
@ -402,6 +403,13 @@ static int decode_info_header(NUTContext *nut){
|
||||||
chapter_start= ff_get_v(bc);
|
chapter_start= ff_get_v(bc);
|
||||||
chapter_len = ff_get_v(bc);
|
chapter_len = ff_get_v(bc);
|
||||||
count = ff_get_v(bc);
|
count = ff_get_v(bc);
|
||||||
|
|
||||||
|
if(chapter_id && !stream_id_plus1){
|
||||||
|
int64_t start= chapter_start / nut->time_base_count;
|
||||||
|
chapter= ff_new_chapter(s, chapter_id, start, start + chapter_len, NULL);
|
||||||
|
chapter->time_base= nut->time_base[chapter_start % nut->time_base_count];
|
||||||
|
}
|
||||||
|
|
||||||
for(i=0; i<count; i++){
|
for(i=0; i<count; i++){
|
||||||
get_str(bc, name, sizeof(name));
|
get_str(bc, name, sizeof(name));
|
||||||
value= get_s(bc);
|
value= get_s(bc);
|
||||||
|
@ -442,6 +450,10 @@ static int decode_info_header(NUTContext *nut){
|
||||||
else if(!strcmp(name, "Disposition"))
|
else if(!strcmp(name, "Disposition"))
|
||||||
set_disposition_bits(s, str_value, stream_id_plus1 - 1);
|
set_disposition_bits(s, str_value, stream_id_plus1 - 1);
|
||||||
}
|
}
|
||||||
|
if(chapter && !strcmp(type, "UTF-8")){
|
||||||
|
if(!strcmp(name, "Title"))
|
||||||
|
chapter->title= av_strdup(str_value);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(skip_reserved(bc, end) || get_checksum(bc)){
|
if(skip_reserved(bc, end) || get_checksum(bc)){
|
||||||
|
|
Loading…
Reference in New Issue