# HG changeset patch # User benoit # Date 1268053998 0 # Node ID e3ec6991698badad3d5a559175e0c2b419bdc167 # Parent afceb57d364cf7b83e8bb5e47a78eef8987d544f Use ASF supports "markers" which are a name and a time stamp to create lavf chapters. Patch by Vladimir Pantelic pan (arobase) nt tu (dash) darmstadt de diff -r afceb57d364c -r e3ec6991698b asf.c --- a/asf.c Mon Mar 08 09:07:41 2010 +0000 +++ b/asf.c Mon Mar 08 13:13:18 2010 +0000 @@ -106,6 +106,10 @@ 0xea, 0xcb, 0xf8, 0xc5, 0xaf, 0x5b, 0x77, 0x48, 0x84, 0x67, 0xaa, 0x8c, 0x44, 0xfa, 0x4c, 0xca }; +const ff_asf_guid ff_asf_marker_header = { + 0x01, 0xCD, 0x87, 0xF4, 0x51, 0xA9, 0xCF, 0x11, 0x8E, 0xE6, 0x00, 0xC0, 0x0C, 0x20, 0x53, 0x65 +}; + /* I am not a number !!! This GUID is the one found on the PC used to generate the stream */ const ff_asf_guid ff_asf_my_guid = { diff -r afceb57d364c -r e3ec6991698b asf.h --- a/asf.h Mon Mar 08 09:07:41 2010 +0000 +++ b/asf.h Mon Mar 08 13:13:18 2010 +0000 @@ -158,6 +158,7 @@ extern const ff_asf_guid ff_asf_ext_stream_embed_stream_header; extern const ff_asf_guid ff_asf_ext_stream_audio_stream; extern const ff_asf_guid ff_asf_metadata_header; +extern const ff_asf_guid ff_asf_marker_header; extern const ff_asf_guid ff_asf_my_guid; extern const ff_asf_guid ff_asf_language_guid; extern const ff_asf_guid ff_asf_content_encryption; diff -r afceb57d364c -r e3ec6991698b asfdec.c --- a/asfdec.c Mon Mar 08 09:07:41 2010 +0000 +++ b/asfdec.c Mon Mar 08 13:13:18 2010 +0000 @@ -82,6 +82,7 @@ else PRINT_IF_GUID(g, ff_asf_ext_stream_embed_stream_header); else PRINT_IF_GUID(g, ff_asf_ext_stream_audio_stream); else PRINT_IF_GUID(g, ff_asf_metadata_header); + else PRINT_IF_GUID(g, ff_asf_marker_header); else PRINT_IF_GUID(g, stream_bitrate_guid); else PRINT_IF_GUID(g, ff_asf_language_guid); else @@ -520,6 +521,32 @@ get_guid(pb, &g); v1 = get_le32(pb); v2 = get_le16(pb); + } else if (!guidcmp(&g, &ff_asf_marker_header)) { + int i, count, name_len; + char name[1024]; + + get_le64(pb); // reserved 16 bytes + get_le64(pb); // ... + count = get_le32(pb); // markers count + get_le16(pb); // reserved 2 bytes + name_len = get_le16(pb); // name length + for(i=0;i