mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
taskpool: expose dispose_handle() API
This is useful when the subclass does return a non-NULL pointer in push(), and the user doesn't want to call join() Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/692>
This commit is contained in:
parent
c04034c50d
commit
b508287add
2 changed files with 48 additions and 1 deletions
|
@ -126,6 +126,12 @@ default_join (GstTaskPool * pool, gpointer id)
|
||||||
/* we do nothing here, we can't join from the pools */
|
/* we do nothing here, we can't join from the pools */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
default_dispose_handle (GstTaskPool * pool, gpointer id)
|
||||||
|
{
|
||||||
|
/* we do nothing here, the default handle is NULL */
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_task_pool_class_init (GstTaskPoolClass * klass)
|
gst_task_pool_class_init (GstTaskPoolClass * klass)
|
||||||
{
|
{
|
||||||
|
@ -143,6 +149,7 @@ gst_task_pool_class_init (GstTaskPoolClass * klass)
|
||||||
gsttaskpool_class->cleanup = default_cleanup;
|
gsttaskpool_class->cleanup = default_cleanup;
|
||||||
gsttaskpool_class->push = default_push;
|
gsttaskpool_class->push = default_push;
|
||||||
gsttaskpool_class->join = default_join;
|
gsttaskpool_class->join = default_join;
|
||||||
|
gsttaskpool_class->dispose_handle = default_dispose_handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -235,7 +242,9 @@ gst_task_pool_cleanup (GstTaskPool * pool)
|
||||||
*
|
*
|
||||||
* Returns: (transfer full) (nullable): a pointer that should be used
|
* Returns: (transfer full) (nullable): a pointer that should be used
|
||||||
* for the gst_task_pool_join function. This pointer can be %NULL, you
|
* for the gst_task_pool_join function. This pointer can be %NULL, you
|
||||||
* must check @error to detect errors.
|
* must check @error to detect errors. If the pointer is not %NULL and
|
||||||
|
* gst_task_pool_join() is not used, call gst_task_pool_dispose_handle()
|
||||||
|
* instead.
|
||||||
*/
|
*/
|
||||||
gpointer
|
gpointer
|
||||||
gst_task_pool_push (GstTaskPool * pool, GstTaskPoolFunction func,
|
gst_task_pool_push (GstTaskPool * pool, GstTaskPoolFunction func,
|
||||||
|
@ -281,3 +290,28 @@ gst_task_pool_join (GstTaskPool * pool, gpointer id)
|
||||||
if (klass->join)
|
if (klass->join)
|
||||||
klass->join (pool, id);
|
klass->join (pool, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_task_pool_dispose_handle:
|
||||||
|
* @pool: a #GstTaskPool
|
||||||
|
* @id: (transfer full) (nullable): the id
|
||||||
|
*
|
||||||
|
* Dispose of the handle returned by gst_task_pool_push(). This does
|
||||||
|
* not need to be called with the default implementation as the default
|
||||||
|
* push() implementation always returns %NULL. This does not need to be
|
||||||
|
* called either when calling gst_task_pool_join().
|
||||||
|
*
|
||||||
|
* Since: 1.20
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
gst_task_pool_dispose_handle (GstTaskPool * pool, gpointer id)
|
||||||
|
{
|
||||||
|
GstTaskPoolClass *klass;
|
||||||
|
|
||||||
|
g_return_if_fail (GST_IS_TASK_POOL (pool));
|
||||||
|
|
||||||
|
klass = GST_TASK_POOL_GET_CLASS (pool);
|
||||||
|
|
||||||
|
if (klass->dispose_handle)
|
||||||
|
klass->dispose_handle (pool, id);
|
||||||
|
}
|
||||||
|
|
|
@ -67,6 +67,7 @@ struct _GstTaskPool {
|
||||||
* @cleanup: make sure all threads are stopped
|
* @cleanup: make sure all threads are stopped
|
||||||
* @push: start a new thread
|
* @push: start a new thread
|
||||||
* @join: join a thread
|
* @join: join a thread
|
||||||
|
* @dispose_handle: free / unref the handle returned in push
|
||||||
*
|
*
|
||||||
* The #GstTaskPoolClass object.
|
* The #GstTaskPoolClass object.
|
||||||
*/
|
*/
|
||||||
|
@ -81,6 +82,15 @@ struct _GstTaskPoolClass {
|
||||||
gpointer user_data, GError **error);
|
gpointer user_data, GError **error);
|
||||||
void (*join) (GstTaskPool *pool, gpointer id);
|
void (*join) (GstTaskPool *pool, gpointer id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GstTaskPoolClass::dispose_handle:
|
||||||
|
*
|
||||||
|
* free / unref the handle returned in push.
|
||||||
|
*
|
||||||
|
* Since: 1.20
|
||||||
|
*/
|
||||||
|
void (*dispose_handle) (GstTaskPool *pool, gpointer id);
|
||||||
|
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
gpointer _gst_reserved[GST_PADDING];
|
gpointer _gst_reserved[GST_PADDING];
|
||||||
};
|
};
|
||||||
|
@ -100,6 +110,9 @@ gpointer gst_task_pool_push (GstTaskPool *pool, GstTaskPoolFunctio
|
||||||
GST_API
|
GST_API
|
||||||
void gst_task_pool_join (GstTaskPool *pool, gpointer id);
|
void gst_task_pool_join (GstTaskPool *pool, gpointer id);
|
||||||
|
|
||||||
|
GST_API
|
||||||
|
void gst_task_pool_dispose_handle (GstTaskPool *pool, gpointer id);
|
||||||
|
|
||||||
GST_API
|
GST_API
|
||||||
void gst_task_pool_cleanup (GstTaskPool *pool);
|
void gst_task_pool_cleanup (GstTaskPool *pool);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue