1
0
mirror of https://gitlab.xiph.org/xiph/icecast-common.git synced 2024-12-04 14:46:31 -05:00

Feature: Added igloo_objecthandler_flush() and igloo_objecthandler_set_backend()

This commit is contained in:
Philipp Schafft 2019-07-14 12:57:15 +00:00
parent 233a333883
commit fd617578a7
2 changed files with 79 additions and 0 deletions

View File

@ -46,6 +46,18 @@ typedef struct {
/* Perform the actual test on the object. */ /* Perform the actual test on the object. */
igloo_filter_result_t (*handle)(igloo_INTERFACE_BASIC_ARGS, igloo_ro_t object); igloo_filter_result_t (*handle)(igloo_INTERFACE_BASIC_ARGS, igloo_ro_t object);
/* Flush all data left in the handler.
* It should also flush the backend if the backend can be flushed.
*/
int (*flush)(igloo_INTERFACE_BASIC_ARGS);
/* Detach old and attach new backend if operation is possible.
* This is always done locked. So this function must not be thread safe.
* igloo_objecthandler_flush() is automatically called before this
* and is also protected by the lock so that there is no race between
* the flush and the backend update.
*/
int (*set_backend)(igloo_INTERFACE_BASIC_ARGS, igloo_ro_t backend);
} igloo_objecthandler_ifdesc_t; } igloo_objecthandler_ifdesc_t;
/* This creates a new objecthandler from a interface description and state. /* This creates a new objecthandler from a interface description and state.
@ -72,6 +84,27 @@ igloo_objecthandler_t * igloo_objecthandler_new(const igloo_objecthandler_ifdesc
*/ */
igloo_filter_result_t igloo_objecthandler_handle(igloo_objecthandler_t *handler, igloo_ro_t object); igloo_filter_result_t igloo_objecthandler_handle(igloo_objecthandler_t *handler, igloo_ro_t object);
/* Flushes the object handler. All data still in queue will be
* written to the backend.
* Parameters:
* handler
* The handler to use.
*/
int igloo_objecthandler_flush(igloo_objecthandler_t *handler);
/* Detaches the old and attaches a new backend.
* This is useful for e.g. reopening files.
*
* This also calls igloo_objecthandler_flush().
*
* Parameters:
* handler
* The handler to use.
* backend
* The new backend to use.
*/
int igloo_objecthandler_set_backend(igloo_objecthandler_t *handler, igloo_ro_t backend);
/* This adds a filter to the handler. /* This adds a filter to the handler.
* Parameters: * Parameters:
* handler * handler

View File

@ -164,3 +164,49 @@ int igloo_objecthandler_push_filter(igloo_objecthandler_t *handler, igloo_filter
return ret; return ret;
} }
int igloo_objecthandler_flush(igloo_objecthandler_t *handler)
{
int ret = 0;
if (!igloo_RO_IS_VALID(handler, igloo_objecthandler_t))
return -1;
if (!handler->ifdesc->flush)
return 0;
if (handler->ifdesc->is_thread_safe) {
igloo_thread_rwlock_wlock(&(handler->rwlock));
} else {
igloo_thread_rwlock_rlock(&(handler->rwlock));
}
ret = handler->ifdesc->flush(igloo_INTERFACE_BASIC_CALL(handler));
igloo_thread_rwlock_unlock(&(handler->rwlock));
return ret;
}
int igloo_objecthandler_set_backend(igloo_objecthandler_t *handler, igloo_ro_t backend)
{
int ret = 0;
if (!igloo_RO_IS_VALID(handler, igloo_objecthandler_t))
return -1;
if (!handler->ifdesc->set_backend)
return -1;
igloo_thread_rwlock_wlock(&(handler->rwlock));
if (handler->ifdesc->flush)
ret = handler->ifdesc->flush(igloo_INTERFACE_BASIC_CALL(handler));
if (ret == 0)
ret = handler->ifdesc->set_backend(igloo_INTERFACE_BASIC_CALL(handler), backend);
igloo_thread_rwlock_unlock(&(handler->rwlock));
return ret;
}