efl/src/lib/ecore_buffer/Ecore_Buffer_Queue.h

456 lines
15 KiB
C

#ifndef _ECORE_BUFFER_QUEUE_H_
#define _ECORE_BUFFER_QUEUE_H_
#include <Eina.h>
#include <Ecore_Buffer.h>
#ifdef EAPI
# undef EAPI
#endif
#ifdef _WIN32
# ifdef EFL_BUILD
# ifdef DLL_EXPORT
# define EAPI __declspec(dllexport)
# else
# define EAPI
# endif
# else
# define EAPI __declspec(dllimport)
# endif
#else
# ifdef __GNUC__
# if __GNUC__ >= 4
# define EAPI __attribute__ ((visibility("default")))
# else
# define EAPI
# endif
# else
# define EAPI
# endif
#endif
#ifdef __cplusplus
extern "C" {
#endif
/**
* @defgroup Ecore_Buffer_Queue_Group Ecore Buffer Queue functions
* @ingroup Ecore_Buffer_Group
*
* Ecore Buffer Queue is a queue which connects processes for sharing
* Ecore_Buffer.
* One process (related object is Ecore_Buffer_Provider) has rear terminal
* position of Ecore_Buffer Queue which can enqueue the Ecore_Buffer,
* and the other process (related object is Ecore_Buffer_Consumer) has front
* terminal position of Ecore_Buffer_Queue which can dequeue the Ecore_Buffer.
*/
/**
* @defgroup Ecore_Buffer_Provider_Group Ecore Buffer Provider functions
* @ingroup Ecore_Buffer_Queue_Group
*
* This group of functions is applied to an Ecore_Buffer_Provider object.
* Ecore_Buffer_Provider provides Ecore_Buffer to Ecore_Buffer_Consumer(usually
* different process or thread from Ecore_Buffer_Provider).
* Ecore_Buffer_Provider should creates Ecore_Buffer as a provider.
*/
/**
* @defgroup Ecore_Buffer_Consumer_Group Ecore Buffer Consumer functions
* @ingroup Ecore_Buffer_Queue_Group
*
* This group of functions is applied to an Ecore_Buffer_Consumer object.
* Ecore_Buffer_Consumer receives Ecore_Buffer enqueued by Ecore_Buffer_Provider.
* Consumer must release Ecore_Buffer when it's no longer used.
* Thus, the Ecore_Buffer_Provider is now free to re-use or destroy Ecore_Buffer.
*/
/**
* @typedef Ecore_Buffer_Return
* @enum _Ecore_Buffer_Return
* Types for an buffer queue state on provider side.
* @ingroup Ecore_Buffer_Provider_Group
* @see ecore_buffer_provider_buffer_acquire()
* @see ecore_buffer_provider_buffer_acquirable_check()
*/
typedef enum _Ecore_Buffer_Return
{
ECORE_BUFFER_RETURN_ERROR, /**< on error @since 1.15 */
ECORE_BUFFER_RETURN_SUCCESS, /**< success to dequeue a buffer @since 1.15 */
ECORE_BUFFER_RETURN_EMPTY, /**< Empty queue @since 1.15 */
ECORE_BUFFER_RETURN_NOT_EMPTY, /**< Not empty queue @since 1.15 */
ECORE_BUFFER_RETURN_NEED_ALLOC, /**< need to create Ecore_Buffer @since 1.15 */
} Ecore_Buffer_Return;
/**
* @typedef Ecore_Buffer_Consumer
* An object representing a consumer of Ecore_Buffer.
*
* @since 1.15
*
* @ingroup Ecore_Buffer_Consumer_Group
*/
typedef struct _Ecore_Buffer_Consumer Ecore_Buffer_Consumer;
/**
* @typedef Ecore_Buffer_Provider
* An object representing a provider of Ecore_Buffer.
*
* @since 1.15
*
* @ingroup Ecore_Buffer_Provider_Group
*/
typedef struct _Ecore_Buffer_Provider Ecore_Buffer_Provider;
/**
* @typedef Ecore_Buffer_Consumer_Provider_Add_Cb
*
* @brief Called whenever a Ecore_Buffer_Provider connected.
*
* @since 1.15
*
* @see ecore_buffer_consumer_provider_add_cb_set()
* @ingroup Ecore_Buffer_Consumer_Group
*/
typedef void (*Ecore_Buffer_Consumer_Provider_Add_Cb) (Ecore_Buffer_Consumer *consumer, void *data);
/**
* @typedef Ecore_Buffer_Consumer_Provider_Del_Cb
*
* @brief Called whenever a Ecore_Buffer_Provider disconnected.
*
* @since 1.15
*
* @see ecore_buffer_consumer_provider_del_cb_set()
* @ingroup Ecore_Buffer_Consumer_Group
*/
typedef void (*Ecore_Buffer_Consumer_Provider_Del_Cb) (Ecore_Buffer_Consumer *consumer, void *data);
/**
* @typedef Ecore_Buffer_Consumer_Enqueue_Cb
*
* @brief Called whenever a Ecore_Buffer enqueued in buffer queue.
*
* @since 1.15
*
* @see ecore_buffer_consumer_buffer_enqueued_cb_set()
* @ingroup Ecore_Buffer_Consumer_Group
*/
typedef void (*Ecore_Buffer_Consumer_Enqueue_Cb) (Ecore_Buffer_Consumer *consumer, void *data);
/**
* @typedef Ecore_Buffer_Provider_Consumer_Add_Cb
*
* @brief Called whenever a Ecore_Buffer_Consumer connected.
*
* @since 1.15
*
* @see ecore_buffer_provider_consumer_add_cb_set()
* @ingroup Ecore_Buffer_Provider_Group
*/
typedef void (*Ecore_Buffer_Provider_Consumer_Add_Cb) (Ecore_Buffer_Provider *provider, int queue_size, int w, int h, void *data);
/**
* @typedef Ecore_Buffer_Provider_Consumer_Del_Cb
*
* @brief Called whenever a Ecore_Buffer_Consumer disconnected.
*
* @since 1.15
*
* @see ecore_buffer_provider_consumer_del_cb_set()
* @ingroup Ecore_Buffer_Provider_Group
*/
typedef void (*Ecore_Buffer_Provider_Consumer_Del_Cb) (Ecore_Buffer_Provider *provider, void *data);
/**
* @typedef Ecore_Buffer_Provider_Enqueue_Cb
*
* @brief Called whenever a Ecore_Buffer is released.
*
* @since 1.15
*
* @see ecore_buffer_provider_buffer_released_cb_set()
* @ingroup Ecore_Buffer_Provider_Group
*/
typedef void (*Ecore_Buffer_Provider_Enqueue_Cb) (Ecore_Buffer_Provider *provider, void *data);
/**
* @addtogroup Ecore_Buffer_Queue_Group
* @{
*/
/**
* @brief Inits the Ecore_Buffer_Queue system.
*
* @since 1.15
*
* @return How many times the lib has been initialized, @c 0 indicates failure.
*
* Set up the connection of Buffer Queue daemon, and Init Ecore_Buffer_Queue libraries.
*
* @see ecore_buffer_queue_shutdown()
*/
EAPI int ecore_buffer_queue_init(void);
/**
* @brief Shuts down the Ecore_Buffer_Queue system.
*
* @since 1.15
*
* @return How many times the lib has been initialized.
*
* This closes the connection of Buffer Queue daemon, and Shut down Ecore_Buffer_Queue libraries.
*
* @see ecore_buffer_queue_init()
*/
EAPI int ecore_buffer_queue_shutdown(void);
/**
* @}
*/
/**
* @addtogroup Ecore_Buffer_Consumer_Group
* @{
*/
/**
* @brief Creates a new Buffer Consumer based on name and common parameters.
*
* @since 1.15
*
* @param[in] name The name of Buffer_Queue, this is needed by Consumer and Provider to connect each other.
* @param[in] queue_size Size of Queue (If you pass this 0, then default size two(2) is appied)
* @param[in] w Width of buffer recommended to provider.
* @param[in] h Height of buffer recommended to provider.
*
* @return Ecore_Buffer_Consumer instance or @c NULL if creation failed.
*/
EAPI Ecore_Buffer_Consumer *ecore_buffer_consumer_new(const char *name, int32_t queue_size, int32_t w, int32_t h);
/**
* @brief Frees an Ecore_Buffer_Consumer.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to free
*
* This frees up any memory used by the Ecore_Buffer_Consumer.
*/
EAPI void ecore_buffer_consumer_free(Ecore_Buffer_Consumer *consumer);
/**
* @brief Returns the latest Ecore_Buffer submitted by provider.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to request for buffer
*
* @return Ecore_Buffer handle or @c NULL if acquirement failed.
*
* @see ecore_buffer_consumer_buffer_release()
*
* Consumer can store Ecore_Buffer submitted by Provider as much as size of queue
* which is passed as a argument of ecore_buffer_consumer_new().
*/
EAPI Ecore_Buffer *ecore_buffer_consumer_buffer_dequeue(Ecore_Buffer_Consumer *consumer);
/**
* @brief Releases the acquired Ecore_Buffer.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to request release buffer
* @param[in] buffer The Ecore_Buffer to release
*
* @return @c EINA_TRUE on success, @c EINA_FALSE otherwise.
*
* @see ecore_buffer_consumer_buffer_dequeue()
*
* Consumer should release the Ecore_Buffer after acquiring and using it.
* By doing release, Ecore_Buffer will be used by provider again,
* or freed internally if Ecore_Buffer is not necessary anymore.
* If not, the resource of Ecore_Buffer is continually owned by consumer until released.
*/
EAPI Eina_Bool ecore_buffer_consumer_buffer_release(Ecore_Buffer_Consumer *consumer, Ecore_Buffer *buffer);
/**
* @brief Checks if Queue of Ecore_Buffer is empty.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to query
*
* @return @c EINA_TRUE means queue is empty, @c EINA_FALSE otherwise.
*/
EAPI Eina_Bool ecore_buffer_consumer_queue_is_empty(Ecore_Buffer_Consumer *consumer);
/**
* @brief Sets a callback for provider connection events.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to set callbacks on
* @param[in] func The function to call
* @param[in] data A pointer to the user data to store.
*
* A call to this function will set a callback on an Ecore_Buffer_Consumer, causing
* @p func to be called whenever @p consumer is connected with provider.
*/
EAPI void ecore_buffer_consumer_provider_add_cb_set(Ecore_Buffer_Consumer *consumer, Ecore_Buffer_Consumer_Provider_Add_Cb func, void *data);
/**
* @brief Sets a callback for provider disconnection events.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to set callbacks on
* @param[in] func The function to call
* @param[in] data A pointer to the user data to store.
*
* A call to this function will set a callback on an Ecore_Buffer_Consumer, causing
* @p func to be called whenever @p consumer is disconnected with provider.
*/
EAPI void ecore_buffer_consumer_provider_del_cb_set(Ecore_Buffer_Consumer *consumer, Ecore_Buffer_Consumer_Provider_Del_Cb func, void *data);
/**
* @brief Sets a callback for enqueued buffer events.
*
* @since 1.15
*
* @param[in] consumer The Ecore_Buffer_Consumer to set callbacks on
* @param[in] func The function to call
* @param[in] data A pointer to the user data to store.
*
* A call to this function will set a callback on an Ecore_Buffer_Consumer, causing
* @p func to be called whenever @p consumer has received buffer submitted from provider.
*
* You may success acquire Ecore_Buffer after this callback called.
*/
EAPI void ecore_buffer_consumer_buffer_enqueued_cb_set(Ecore_Buffer_Consumer *consumer, Ecore_Buffer_Consumer_Enqueue_Cb func, void *data);
/**
* @}
*/
/**
* @addtogroup Ecore_Buffer_Provider_Group
* @{
*/
/**
* @brief Creates a new Buffer Provider based on name.
*
* @since 1.15
*
* @param[in] name The name of Buffer_Queue.
*
* @return Ecore_Buffer_Provider instance or @c NULL if creation failed.
*/
EAPI Ecore_Buffer_Provider *ecore_buffer_provider_new(const char *name);
/**
* @brief Frees an Ecore_Buffer_Provider.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider to free
*
* This frees up any memory used by the Ecore_Buffer_Provider.
*/
EAPI void ecore_buffer_provider_free(Ecore_Buffer_Provider *provider);
/**
* @brief Returns the Ecore_Buffer released by consumer or State of Queue.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider to request for buffer
* @param[out] ret_buf A Pointer to the Ecore_Buffer
*
* @return The enumeration of Ecore_Buffer_Return to indicate result of Dequeuing.
*
* This function gives you drawable buffer and inform you the state of Queue.
* Each return value of enumeration has meaning as below.
* @li ECORE_BUFFER_RETURN_ERROR, means error occurred.
* @li ECORE_BUFFER_RETURN_SUCCESS, means success to dequeue, therefore ret_buf is valid.
* @li ECORE_BUFFER_RETURN_EMPTY, means queue is empty, not available slot in Queue.
* in other words, there is no free drawable buffer in Queue.
* @li ECORE_BUFFER_RETURN_NEED_ALLOC, means that there is available slot, but not allocated.
* so, You may create new Ecore_Buffer, and then just enqueue the Ecore_Buffer.
*
* @see ecore_buffer_new(), ecore_buffer_provider_buffer_enqueue()
*/
EAPI Ecore_Buffer_Return ecore_buffer_provider_buffer_acquire(Ecore_Buffer_Provider *provider, Ecore_Buffer **ret_buf);
/**
* @brief Submits the Ecore_Buffer to Consumer to request compositing.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider connected with consumer.
* @param[in] buffer The Ecore_Buffer to submit
*
* @return @c EINA_TRUE on success, @c EINA_FALSE otherwise.
*
* This function allow you to submit the Ecore_Buffer to consumer to request compositing.
* And this will be success, in case only you submit dequeued Ecore_Buffer,
* and new Ecore_Buffer after received return value of ECORE_BUFFER_RETURN_NEED_ALLOC by ecore_buffer_provider_buffer_acquire().
*
* @see ecore_buffer_new(), ecore_buffer_provider_buffer_dequeue()
*/
EAPI Eina_Bool ecore_buffer_provider_buffer_enqueue(Ecore_Buffer_Provider *provider, Ecore_Buffer *buffer);
/**
* @brief Checks if state of queue.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider to query
*
* @li ECORE_BUFFER_RETURN_NOT_EMPTY, means there is a dequeueable Ecore_Buffer at least one.
* @li ECORE_BUFFER_RETURN_EMPTY, means queue is empty, not available slot in Queue.
* in other words, there is no free drawable buffer in Queue.
* @li ECORE_BUFFER_RETURN_NEED_ALLOC, means that there is available slot, but not allocated.
* so, You may create new Ecore_Buffer, and then just enqueue the Ecore_Buffer.
*
* @return @c EINA_TRUE means queue is empty, @c EINA_FALSE otherwise.
*/
EAPI Ecore_Buffer_Return ecore_buffer_provider_buffer_acquirable_check(Ecore_Buffer_Provider *provider);
/**
* @brief Sets a callback for consumer connection events.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider to set callbacks on
* @param[in] func The function to call
* @param[in] data A pointer to the user data to store.
*
* A call to this function will set a callback on an Ecore_Buffer_Provider, causing
* @p func to be called whenever @p provider is connected with consumer.
*/
EAPI void ecore_buffer_provider_consumer_add_cb_set(Ecore_Buffer_Provider *provider, Ecore_Buffer_Provider_Consumer_Add_Cb func, void *data);
/**
* @brief Sets a callback for consumer disconnection events.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider to set callbacks on
* @param[in] func The function to call
* @param[in] data A pointer to the user data to store.
*
* A call to this function will set a callback on an Ecore_Buffer_Provider, causing
* @p func to be called whenever @p provider is disconnected with consumer.
*/
EAPI void ecore_buffer_provider_consumer_del_cb_set(Ecore_Buffer_Provider *provider, Ecore_Buffer_Provider_Consumer_Del_Cb func, void *data);
/**
* @brief Sets a callback for released buffer events.
*
* @since 1.15
*
* @param[in] provider The Ecore_Buffer_Provider to set callbacks on
* @param[in] func The function to call
* @param[in] data A pointer to the user data to store.
*
* A call to this function will set a callback on an Ecore_Buffer_Provider, causing
* @p func to be called whenever @p provider has received Ecore_Buffer released from provider.
*
* You may success dequeue the Ecore_Buffer after this callback called.
*/
EAPI void ecore_buffer_provider_buffer_released_cb_set(Ecore_Buffer_Provider *provider, Ecore_Buffer_Provider_Enqueue_Cb func, void *data);
/**
* @}
*/
#ifdef __cplusplus
}
#endif
#undef EAPI
#define EAPI
#endif /* _ECORE_BUFFER_QUEUE_H_ */