diff options
| author | Michael Niedermayer <[email protected]> | 2012-05-16 02:27:31 +0200 | 
|---|---|---|
| committer | Michael Niedermayer <[email protected]> | 2012-05-16 02:27:31 +0200 | 
| commit | 1cbf7fb4345a3e5b7791d483241bf4759bde4ece (patch) | |
| tree | d7acd8317309e051fb240e3505f77aabe2ea0437 /ffprobe.c | |
| parent | a48abf5e263ad7f2e68821766e7cf4d29befb58e (diff) | |
| parent | 0ff0af731ce4544f84b2f748dcc699717a2df8d6 (diff) | |
Merge remote-tracking branch 'qatar/master'
* qatar/master: (26 commits)
  fate: use diff -b in oneline comparison
  Add missing version bumps and APIchanges/Changelog entries.
  lavfi: move buffer management function to a separate file.
  lavfi: move formats-related functions from default.c to formats.c
  lavfi: move video-related functions to a separate file.
  fate: make smjpeg a demux test
  fate: separate sierra-vmd audio and video tests
  fate: separate smacker audio and video tests
  libmp3lame: set supported channel layouts.
  avconv: automatically insert asyncts when -async is used.
  avconv: add support for audio filters.
  lavfi: add asyncts filter.
  lavfi: add aformat filter
  lavfi: add an audio buffer sink.
  lavfi: add an audio buffer source.
  buffersrc: add av_buffersrc_write_frame().
  buffersrc: fix invalid read in uninit if the fifo hasn't been allocated
  lavfi: rename vsrc_buffer.c to buffersrc.c
  avfiltergraph: reindent
  lavfi: add channel layout/sample rate negotiation.
  ...
Conflicts:
	Changelog
	doc/APIchanges
	doc/filters.texi
	ffmpeg.c
	ffprobe.c
	libavcodec/libmp3lame.c
	libavfilter/Makefile
	libavfilter/af_aformat.c
	libavfilter/allfilters.c
	libavfilter/avfilter.c
	libavfilter/avfilter.h
	libavfilter/avfiltergraph.c
	libavfilter/buffersrc.c
	libavfilter/defaults.c
	libavfilter/formats.c
	libavfilter/src_buffer.c
	libavfilter/version.h
	libavfilter/vf_yadif.c
	libavfilter/vsrc_buffer.c
	libavfilter/vsrc_buffer.h
	libavutil/avutil.h
	tests/fate/audio.mak
	tests/fate/demux.mak
	tests/fate/video.mak
Merged-by: Michael Niedermayer <[email protected]>
Diffstat (limited to 'ffprobe.c')
| -rw-r--r-- | ffprobe.c | 22 | 
1 files changed, 18 insertions, 4 deletions
@@ -1549,6 +1549,19 @@ static int open_input_file(AVFormatContext **fmt_ctx_ptr, const char *filename)      return 0;  } +static void close_input_file(AVFormatContext **ctx_ptr) +{ +    int i; +    AVFormatContext *fmt_ctx = *ctx_ptr; + +    /* close decoder for each stream */ +    for (i = 0; i < fmt_ctx->nb_streams; i++) +        if (fmt_ctx->streams[i]->codec->codec_id != CODEC_ID_NONE) +            avcodec_close(fmt_ctx->streams[i]->codec); + +    avformat_close_input(ctx_ptr); +} +  #define PRINT_CHAPTER(name) do {                                        \      if (do_show_ ## name) {                                             \          writer_print_chapter_header(wctx, #name);                       \ @@ -1586,10 +1599,7 @@ static int probe_file(WriterContext *wctx, const char *filename)          }          PRINT_CHAPTER(streams);          PRINT_CHAPTER(format); -        for (i = 0; i < fmt_ctx->nb_streams; i++) -            if (fmt_ctx->streams[i]->codec->codec_id != CODEC_ID_NONE) -                avcodec_close(fmt_ctx->streams[i]->codec); -        avformat_close_input(&fmt_ctx); +        close_input_file(&fmt_ctx);          av_freep(&nb_streams_frames);          av_freep(&nb_streams_packets);      } @@ -1803,6 +1813,10 @@ int main(int argc, char **argv)  end:      av_freep(&print_format); + +    uninit_opts(); +    av_dict_free(&fmt_entries_to_show); +      avformat_network_deinit();      return ret;  | 
