diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-03-24 14:51:44 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-03-24 14:51:44 +0100 |
commit | 3e1f24131ac018c8b4bcc852a02ccfadf20d1dbb (patch) | |
tree | 4fa15874bb03d2c88291ff5b9836cc1d189c2981 /libavutil/frame.c | |
parent | 82e6660ae2372cdf96acb3bfebdd82b82f51d23f (diff) | |
parent | d161ae0a37900cbd36c1390ca32a56b892c02ab5 (diff) | |
download | ffmpeg-3e1f24131ac018c8b4bcc852a02ccfadf20d1dbb.tar.gz |
Merge commit 'd161ae0a37900cbd36c1390ca32a56b892c02ab5'
* commit 'd161ae0a37900cbd36c1390ca32a56b892c02ab5':
frame: add a function for removing side data from a frame
Conflicts:
libavutil/version.h
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavutil/frame.c')
-rw-r--r-- | libavutil/frame.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/libavutil/frame.c b/libavutil/frame.c index 747aa79b8f..07cdc213f2 100644 --- a/libavutil/frame.c +++ b/libavutil/frame.c @@ -642,3 +642,19 @@ int av_frame_copy(AVFrame *dst, const AVFrame *src) return AVERROR(EINVAL); } + +void av_frame_remove_side_data(AVFrame *frame, enum AVFrameSideDataType type) +{ + int i; + + for (i = 0; i < frame->nb_side_data; i++) { + AVFrameSideData *sd = frame->side_data[i]; + if (sd->type == type) { + av_freep(&sd->data); + av_dict_free(&sd->metadata); + av_freep(&frame->side_data[i]); + frame->side_data[i] = frame->side_data[frame->nb_side_data - 1]; + frame->nb_side_data--; + } + } +} |