diff --git a/ffmpeg.c b/ffmpeg.c index c656663b5f..7c47ce807c 100644 --- a/ffmpeg.c +++ b/ffmpeg.c @@ -3321,8 +3321,8 @@ static void opt_show_formats(void) AVInputFormat *ifmt; AVOutputFormat *ofmt; URLProtocol *up; - AVCodec *p, *p2; - AVBitStreamFilter *bsf; + AVCodec *p=NULL, *p2; + AVBitStreamFilter *bsf=NULL; const char *last_name; printf("File formats:\n"); @@ -3373,7 +3373,7 @@ static void opt_show_formats(void) const char *type_str; p2=NULL; - for(p = first_avcodec; p != NULL; p = p->next) { + while(p= av_codec_next(p)) { if((p2==NULL || strcmp(p->name, p2->name)<0) && strcmp(p->name, last_name)>0){ p2= p; @@ -3419,7 +3419,7 @@ static void opt_show_formats(void) printf("\n"); printf("Bitstream filters:\n"); - for(bsf = first_bitstream_filter; bsf != NULL; bsf = bsf->next) + while(bsf = av_bitstream_filter_next(bsf)) printf(" %s", bsf->name); printf("\n"); diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h index 59f04f832b..e802522218 100644 --- a/libavcodec/avcodec.h +++ b/libavcodec/avcodec.h @@ -33,8 +33,8 @@ #define AV_STRINGIFY(s) AV_TOSTRING(s) #define AV_TOSTRING(s) #s -#define LIBAVCODEC_VERSION_INT ((51<<16)+(48<<8)+0) -#define LIBAVCODEC_VERSION 51.48.0 +#define LIBAVCODEC_VERSION_INT ((51<<16)+(49<<8)+0) +#define LIBAVCODEC_VERSION 51.49.0 #define LIBAVCODEC_BUILD LIBAVCODEC_VERSION_INT #define LIBAVCODEC_IDENT "Lavc" AV_STRINGIFY(LIBAVCODEC_VERSION) @@ -2428,7 +2428,10 @@ int avpicture_deinterlace(AVPicture *dst, const AVPicture *src, /* external high level API */ +#if LIBAVCODEC_VERSION_INT < ((52<<16)+(0<<8)+0) extern AVCodec *first_avcodec; +#endif +AVCodec *av_codec_next(AVCodec *c); /* returns LIBAVCODEC_VERSION_INT constant */ unsigned avcodec_version(void); @@ -2784,7 +2787,10 @@ typedef struct AVCodecParser { struct AVCodecParser *next; } AVCodecParser; +#if LIBAVCODEC_VERSION_INT < ((52<<16)+(0<<8)+0) extern AVCodecParser *av_first_parser; +#endif +AVCodecParser *av_parser_next(AVCodecParser *c); void av_register_codec_parser(AVCodecParser *parser); AVCodecParserContext *av_parser_init(int codec_id); @@ -2827,7 +2833,7 @@ int av_bitstream_filter_filter(AVBitStreamFilterContext *bsfc, const uint8_t *buf, int buf_size, int keyframe); void av_bitstream_filter_close(AVBitStreamFilterContext *bsf); -extern AVBitStreamFilter *first_bitstream_filter; +AVBitStreamFilter *av_bitstream_filter_next(AVBitStreamFilter *f); /* memory */ diff --git a/libavcodec/bitstream_filter.c b/libavcodec/bitstream_filter.c index 97fbd776d1..aeafd7db40 100644 --- a/libavcodec/bitstream_filter.c +++ b/libavcodec/bitstream_filter.c @@ -22,6 +22,11 @@ AVBitStreamFilter *first_bitstream_filter= NULL; +AVBitStreamFilter *av_bitstream_filter_next(AVBitStreamFilter *f){ + if(f) return f->next; + else return first_bitstream_filter; +} + void av_register_bitstream_filter(AVBitStreamFilter *bsf){ bsf->next = first_bitstream_filter; first_bitstream_filter= bsf; diff --git a/libavcodec/parser.c b/libavcodec/parser.c index 192241987e..b0a6a2a1b0 100644 --- a/libavcodec/parser.c +++ b/libavcodec/parser.c @@ -24,6 +24,11 @@ AVCodecParser *av_first_parser = NULL; +AVCodecParser* av_parser_next(AVCodecParser *p){ + if(p) return p->next; + else return av_first_parser; +} + void av_register_codec_parser(AVCodecParser *parser) { parser->next = av_first_parser; diff --git a/libavcodec/utils.c b/libavcodec/utils.c index be2aa38367..fdfa7bd4e4 100644 --- a/libavcodec/utils.c +++ b/libavcodec/utils.c @@ -126,6 +126,11 @@ static void do_free(void) /* encoder management */ AVCodec *first_avcodec = NULL; +AVCodec *av_codec_next(AVCodec *c){ + if(c) return c->next; + else return first_avcodec; +} + void register_avcodec(AVCodec *format) { AVCodec **p;