lavu: improve documentation of some AVFrame functions

Signed-off-by: Anton Khirnov <anton@khirnov.net>
This commit is contained in:
wm4 2016-02-29 22:48:11 +01:00 committed by Anton Khirnov
parent 84b5dcf275
commit 7a6cf27714

View File

@ -391,6 +391,10 @@ void av_frame_free(AVFrame **frame);
* If src is not reference counted, new buffers are allocated and the data is * If src is not reference counted, new buffers are allocated and the data is
* copied. * copied.
* *
* @warning: dst MUST have been either unreferenced with av_frame_unref(dst),
* or newly allocated with av_frame_alloc() before calling this
* function, or undefined behavior will occur.
*
* @return 0 on success, a negative AVERROR on error * @return 0 on success, a negative AVERROR on error
*/ */
int av_frame_ref(AVFrame *dst, const AVFrame *src); int av_frame_ref(AVFrame *dst, const AVFrame *src);
@ -410,7 +414,11 @@ AVFrame *av_frame_clone(const AVFrame *src);
void av_frame_unref(AVFrame *frame); void av_frame_unref(AVFrame *frame);
/** /**
* Move everythnig contained in src to dst and reset src. * Move everything contained in src to dst and reset src.
*
* @warning: dst is not unreferenced, but directly overwritten without reading
* or deallocating its contents. Call av_frame_unref(dst) manually
* before calling this function to ensure that no memory is leaked.
*/ */
void av_frame_move_ref(AVFrame *dst, AVFrame *src); void av_frame_move_ref(AVFrame *dst, AVFrame *src);
@ -426,6 +434,10 @@ void av_frame_move_ref(AVFrame *dst, AVFrame *src);
* necessary, allocate and fill AVFrame.extended_data and AVFrame.extended_buf. * necessary, allocate and fill AVFrame.extended_data and AVFrame.extended_buf.
* For planar formats, one buffer will be allocated for each plane. * For planar formats, one buffer will be allocated for each plane.
* *
* @warning: if frame already has been allocated, calling this function will
* leak memory. In addition, undefined behavior can occur in certain
* cases.
*
* @param frame frame in which to store the new buffers. * @param frame frame in which to store the new buffers.
* @param align required buffer size alignment * @param align required buffer size alignment
* *