From f1fc4b52c561b04bd6c1cf2fc5c6091cd716e2a0 Mon Sep 17 00:00:00 2001 From: gb Date: Thu, 29 Apr 2010 21:56:10 +0000 Subject: [PATCH] Export gst_vaapi_video_buffer_new(). --- gst-libs/gst/vaapi/gstvaapivideobuffer.c | 33 ++++++++++++++++++++------------ gst-libs/gst/vaapi/gstvaapivideobuffer.h | 3 +++ 2 files changed, 24 insertions(+), 12 deletions(-) diff --git a/gst-libs/gst/vaapi/gstvaapivideobuffer.c b/gst-libs/gst/vaapi/gstvaapivideobuffer.c index bb002bf..113df76 100644 --- a/gst-libs/gst/vaapi/gstvaapivideobuffer.c +++ b/gst-libs/gst/vaapi/gstvaapivideobuffer.c @@ -127,16 +127,25 @@ gst_vaapi_video_buffer_init(GstVaapiVideoBuffer *buffer) priv->proxy = NULL; } -static inline GstVaapiVideoBuffer * -gst_vaapi_video_buffer_new(void) +/** + * gst_vaapi_video_buffer_new: + * + * Creates an empty #GstBuffer. The caller is responsible for completing + * the initialization of the buffer with the gst_vaapi_video_buffer_set_*() + * functions. + * + * Return value: the newly allocated #GstBuffer, or %NULL or error + */ +static inline gpointer +_gst_vaapi_video_buffer_new(void) { - GstMiniObject *object; - - object = gst_mini_object_new(GST_VAAPI_TYPE_VIDEO_BUFFER); - if (!object) - return NULL; + return gst_mini_object_new(GST_VAAPI_TYPE_VIDEO_BUFFER); +} - return GST_VAAPI_VIDEO_BUFFER(object); +GstBuffer * +gst_vaapi_video_buffer_new(void) +{ + return _gst_vaapi_video_buffer_new(); } /** @@ -165,7 +174,7 @@ gst_vaapi_video_buffer_new_from_pool(GstVaapiVideoPool *pool) if (!is_image_pool && !is_surface_pool) return NULL; - buffer = gst_vaapi_video_buffer_new(); + buffer = _gst_vaapi_video_buffer_new(); if (buffer && ((is_image_pool && gst_vaapi_video_buffer_set_image_from_pool(buffer, pool)) || @@ -193,7 +202,7 @@ gst_vaapi_video_buffer_new_with_image(GstVaapiImage *image) g_return_val_if_fail(GST_VAAPI_IS_IMAGE(image), NULL); - buffer = gst_vaapi_video_buffer_new(); + buffer = _gst_vaapi_video_buffer_new(); if (buffer) gst_vaapi_video_buffer_set_image(buffer, image); return GST_BUFFER(buffer); @@ -215,7 +224,7 @@ gst_vaapi_video_buffer_new_with_surface(GstVaapiSurface *surface) g_return_val_if_fail(GST_VAAPI_IS_SURFACE(surface), NULL); - buffer = gst_vaapi_video_buffer_new(); + buffer = _gst_vaapi_video_buffer_new(); if (buffer) gst_vaapi_video_buffer_set_surface(buffer, surface); return GST_BUFFER(buffer); @@ -237,7 +246,7 @@ gst_vaapi_video_buffer_new_with_surface_proxy(GstVaapiSurfaceProxy *proxy) g_return_val_if_fail(GST_VAAPI_IS_SURFACE_PROXY(proxy), NULL); - buffer = gst_vaapi_video_buffer_new(); + buffer = _gst_vaapi_video_buffer_new(); if (buffer) gst_vaapi_video_buffer_set_surface_proxy(buffer, proxy); return GST_BUFFER(buffer); diff --git a/gst-libs/gst/vaapi/gstvaapivideobuffer.h b/gst-libs/gst/vaapi/gstvaapivideobuffer.h index 1303df7..55b4633 100644 --- a/gst-libs/gst/vaapi/gstvaapivideobuffer.h +++ b/gst-libs/gst/vaapi/gstvaapivideobuffer.h @@ -83,6 +83,9 @@ GType gst_vaapi_video_buffer_get_type(void); GstBuffer * +gst_vaapi_video_buffer_new(void); + +GstBuffer * gst_vaapi_video_buffer_new_from_pool(GstVaapiVideoPool *pool); GstBuffer * -- 2.7.4