diff options
author | Anton Khirnov <wyskas@gmail.com> | 2008-05-22 22:00:21 +0000 |
---|---|---|
committer | Aurelien Jacobs <aurel@gnuage.org> | 2008-05-22 22:00:21 +0000 |
commit | 79d7836a5e213d547629555e3f1157e7197aef68 (patch) | |
tree | 9a21cfbcdb010a9a5ab271520aaca3fe2c8102e5 | |
parent | d311f8f3e3425369bc98574c11677ab6755d2f69 (diff) | |
download | ffmpeg-79d7836a5e213d547629555e3f1157e7197aef68.tar.gz |
add support for chapters definition in lavf
patch by Anton Khirnov wyskas _at_ gmail _dot_ com
Originally committed as revision 13240 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/avformat.h | 22 | ||||
-rw-r--r-- | libavformat/utils.c | 18 |
2 files changed, 39 insertions, 1 deletions
diff --git a/libavformat/avformat.h b/libavformat/avformat.h index 3c67bdb5ba..17f317e2d0 100644 --- a/libavformat/avformat.h +++ b/libavformat/avformat.h @@ -22,7 +22,7 @@ #define FFMPEG_AVFORMAT_H #define LIBAVFORMAT_VERSION_MAJOR 52 -#define LIBAVFORMAT_VERSION_MINOR 13 +#define LIBAVFORMAT_VERSION_MINOR 14 #define LIBAVFORMAT_VERSION_MICRO 0 #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \ @@ -389,6 +389,11 @@ typedef struct AVProgram { #define AVFMTCTX_NOHEADER 0x0001 /**< signal that no header is present (streams are added dynamically) */ +typedef struct AVChapter { + int64_t start, end; /**< chapter start/end time in AV_TIME_BASE units */ + char *title; /**< chapter title */ +} AVChapter; + #define MAX_STREAMS 20 /** @@ -514,6 +519,9 @@ typedef struct AVFormatContext { * obtained from real-time capture devices. */ unsigned int max_picture_buffer; + + int num_chapters; + AVChapter **chapters; } AVFormatContext; typedef struct AVPacketList { @@ -745,6 +753,18 @@ AVStream *av_new_stream(AVFormatContext *s, int id); AVProgram *av_new_program(AVFormatContext *s, int id); /** + * Add a new chapter. + * This function is NOT part of the public API + * and should be ONLY used by demuxers. + * + * @param s media file handle + * @param start chapter start time in AV_TIME_BASE units + * @param end chapter end time in AV_TIME_BASE units + * @param title chapter title + */ +int ff_new_chapter(AVFormatContext *s, int64_t start, int64_t end, const char *title); + +/** * Set the pts for a given stream. * * @param s stream diff --git a/libavformat/utils.c b/libavformat/utils.c index 5b6fd55381..d98db39632 100644 --- a/libavformat/utils.c +++ b/libavformat/utils.c @@ -2148,6 +2148,11 @@ void av_close_input_stream(AVFormatContext *s) av_freep(&s->programs); flush_packet_queue(s); av_freep(&s->priv_data); + while(s->num_chapters--) { + av_free(s->chapters[s->num_chapters]->title); + av_free(s->chapters[s->num_chapters]); + } + av_freep(&s->chapters); av_free(s); } @@ -2229,6 +2234,19 @@ void av_set_program_name(AVProgram *program, char *provider_name, char *name) } } +int ff_new_chapter(AVFormatContext *s, int64_t start, int64_t end, const char *title) +{ + AVChapter *chapter = av_mallocz(sizeof(AVChapter)); + if(!chapter) + return AVERROR(ENOMEM); + chapter->title = av_strdup(title); + chapter->start = start; + chapter->end = end; + + dynarray_add(&s->chapters, &s->num_chapters, chapter); + + return 0; +} /************************************************************/ /* output media file */ |