X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fvlc_picture_pool.h;h=d22dbed8e9a6fc05bc5cd8400ade70e258fea03b;hb=12ade3e3bc975d5426ba4af155b7372c31093b31;hp=2a01d522f698b6be85fb836bb6d4c0d843a0c462;hpb=0eb8d3314e7451c5192b12083614a69ca838ce96;p=vlc diff --git a/include/vlc_picture_pool.h b/include/vlc_picture_pool.h index 2a01d522f6..d22dbed8e9 100644 --- a/include/vlc_picture_pool.h +++ b/include/vlc_picture_pool.h @@ -53,7 +53,7 @@ typedef struct { /** * It creates a picture_pool_t wrapping the given configuration. * - * It is usefull to avoid useless picture creations/destructions. + * It avoids useless picture creations/destructions. * The given picture must not have a reference count greater than 1. * The pool takes ownership of the picture and MUST not be used directly. * When deleted, the pool will release the pictures using picture_Release. @@ -62,21 +62,21 @@ typedef struct { * as soon as a picture is unused. They are allowed to modify picture_t::p and * access picture_t::p_sys. */ -VLC_EXPORT( picture_pool_t *, picture_pool_NewExtended, ( const picture_pool_configuration_t * ) ); +VLC_EXPORT( picture_pool_t *, picture_pool_NewExtended, ( const picture_pool_configuration_t * ) LIBVLC_USED ); /** * It creates a picture_pool_t wrapping the given arrays of picture. * * It is provided as convenience. */ -VLC_EXPORT( picture_pool_t *, picture_pool_New, ( int picture_count, picture_t *picture[] ) ); +VLC_EXPORT( picture_pool_t *, picture_pool_New, ( int picture_count, picture_t *picture[] ) LIBVLC_USED ); /** * It creates a picture_pool_t creating images using the given format. * * Provided for convenience. */ -VLC_EXPORT( picture_pool_t *, picture_pool_NewFromFormat, ( const video_format_t *, int picture_count ) ); +VLC_EXPORT( picture_pool_t *, picture_pool_NewFromFormat, ( const video_format_t *, int picture_count ) LIBVLC_USED ); /** * It destroys a pool created by picture_pool_New. @@ -91,7 +91,7 @@ VLC_EXPORT( void, picture_pool_Delete, ( picture_pool_t * ) ); * * The picture must be release by using picture_Release. */ -VLC_EXPORT( picture_t *, picture_pool_Get, ( picture_pool_t * ) ); +VLC_EXPORT( picture_t *, picture_pool_Get, ( picture_pool_t * ) LIBVLC_USED ); /** * It forces the next picture_pool_Get to return a picture even if no @@ -106,5 +106,21 @@ VLC_EXPORT( picture_t *, picture_pool_Get, ( picture_pool_t * ) ); */ VLC_EXPORT( void, picture_pool_NonEmpty, ( picture_pool_t *, bool reset ) ); +/** + * It reserves picture_count pictures from the given pool and returns + * a new pool with thoses pictures. + * + * The master pool must be full. + * The returned pool must be deleted before the master pool. + * When deleted, all pictures return to the master pool. + */ +VLC_EXPORT( picture_pool_t *, picture_pool_Reserve, (picture_pool_t *, int picture_count) LIBVLC_USED ); + +/** + * It returns the size of the given pool. + */ +VLC_EXPORT( int, picture_pool_GetSize, (picture_pool_t *) ); + + #endif /* VLC_PICTURE_POOL_H */