|  |  |  | GStreamer 0.10 Library Reference Manual |  | 
|---|---|---|---|---|
#include <gst/base/gstdataqueue.h>
                    GstDataQueue;
                    GstDataQueueSize;
gboolean            (*GstDataQueueCheckFullFunction)    (GstDataQueue *queue,
                                                         guint visible,
                                                         guint bytes,
                                                         guint64 time,
                                                         gpointer checkdata);
                    GstDataQueueItem;
GstDataQueue*       gst_data_queue_new                  (GstDataQueueCheckFullFunction checkfull,
                                                         gpointer checkdata);
gboolean            gst_data_queue_push                 (GstDataQueue *queue,
                                                         GstDataQueueItem *item);
gboolean            gst_data_queue_pop                  (GstDataQueue *queue,
                                                         GstDataQueueItem **item);
void                gst_data_queue_flush                (GstDataQueue *queue);
void                gst_data_queue_set_flushing         (GstDataQueue *queue,
                                                         gboolean flushing);
gboolean            gst_data_queue_drop_head            (GstDataQueue *queue,
                                                         GType type);
gboolean            gst_data_queue_is_full              (GstDataQueue *queue);
gboolean            gst_data_queue_is_empty             (GstDataQueue *queue);
void                gst_data_queue_get_level            (GstDataQueue *queue,
                                                         GstDataQueueSize *level);
void                gst_data_queue_limits_changed       (GstDataQueue *queue);
GstDataQueue is an object that handles threadsafe queueing of objects. It also provides size-related functionality. This object should be used for any GstElement that wishes to provide some sort of queueing functionality.
typedef struct {
  guint visible;
  guint bytes;
  guint64 time;
} GstDataQueueSize;
Structure describing the size of a queue.
| guint  | number of buffers | 
| guint  | number of bytes | 
| guint64  | amount of time | 
gboolean (*GstDataQueueCheckFullFunction) (GstDataQueue *queue, guint visible, guint bytes, guint64 time, gpointer checkdata);
The prototype of the function used to inform the queue that it should be considered as full.
| 
 | a GstDataQueue. | 
| 
 | The number of visible items currently in the queue. | 
| 
 | The amount of bytes currently in the queue. | 
| 
 | The accumulated duration of the items currently in the queue. | 
| 
 | The gpointer registered when the GstDataQueue was created. | 
| Returns : | TRUE if the queue should be considered full. | 
typedef struct {
  GstMiniObject *object;
  guint size;
  guint64 duration;
  gboolean visible;
  /* user supplied destroy function */
  GDestroyNotify destroy;
} GstDataQueueItem;
Structure used by GstDataQueue. You can supply a different structure, as long as the top of the structure is identical to this structure.
| GstMiniObject * | the GstMiniObject to queue. | 
| guint  | the size in bytes of the miniobject. | 
| guint64  | the duration in GstClockTime of the miniobject. Can not be GST_CLOCK_TIME_NONE. | 
| gboolean  | TRUE if objectshould be considered as a visible object. | 
| GDestroyNotify  | The GDestroyNotify function to use to free the GstDataQueueItem.
This function should also drop the reference to objectthe owner of the
GstDataQueueItem is assumed to hold. | 
GstDataQueue* gst_data_queue_new (GstDataQueueCheckFullFunction checkfull, gpointer checkdata);
| 
 | the callback used to tell if the element considers the queue full or not. | 
| 
 | a gpointer that will be given in the checkfullcallback. | 
| Returns : | a new GstDataQueue. | 
gboolean gst_data_queue_push (GstDataQueue *queue, GstDataQueueItem *item);
Pushes a GstDataQueueItem (or a structure that begins with the same fields)
on the queue. If the queue is full, the call will block until space is
available, OR the queue is set to flushing state.
MT safe.
Note that this function has slightly different semantics than gst_pad_push()
and gst_pad_push_event(): this function only takes ownership of item and
the GstMiniObject contained in item if the push was successful. If FALSE
is returned, the caller is responsible for freeing item and its contents.
| 
 | a GstDataQueue. | 
| 
 | a GstDataQueueItem. | 
| Returns : | TRUE if the itemwas successfully pushed on thequeue. | 
gboolean gst_data_queue_pop (GstDataQueue *queue, GstDataQueueItem **item);
Retrieves the first item available on the queue. If the queue is currently
empty, the call will block until at least one item is available, OR the
queue is set to the flushing state.
MT safe.
| 
 | a GstDataQueue. | 
| 
 | pointer to store the returned GstDataQueueItem. | 
| Returns : | TRUE if an itemwas successfully retrieved from thequeue. | 
void gst_data_queue_flush (GstDataQueue *queue);
Flushes all the contents of the queue. Any call to gst_data_queue_pull and
gst_data_queue_pop will be released.
MT safe.
| 
 | a GstDataQueue. | 
void gst_data_queue_set_flushing (GstDataQueue *queue, gboolean flushing);
Sets the queue to flushing state if flushing is TRUE. If set to flushing
state, any incoming data on the queue will be discarded. Any call currently
blocking on gst_data_queue_push or gst_data_queue_pop will return straight
away with a return value of FALSE. While the queue is in flushing state, 
all calls to those two functions will return FALSE.
MT Safe.
| 
 | a GstDataQueue. | 
| 
 | a gboolean stating if the queue will be flushing or not. | 
gboolean gst_data_queue_drop_head (GstDataQueue *queue, GType type);
Pop and unref the head-most GstMiniObject with the given GType.
| 
 | The GstDataQueue to drop an item from. | 
| 
 | The GType of the item to drop. | 
| Returns : | TRUE if an element was removed. | 
gboolean gst_data_queue_is_full (GstDataQueue *queue);
Queries if queue is full. This check will be done using the
GstDataQueueCheckFullCallback registered with queue.
MT safe.
| 
 | a GstDataQueue. | 
| Returns : | TRUE if queueis full. | 
gboolean gst_data_queue_is_empty (GstDataQueue *queue);
Queries if there are any items in the queue.
MT safe.
| 
 | a GstDataQueue. | 
| Returns : | TRUE if queueis empty. | 
void gst_data_queue_get_level (GstDataQueue *queue, GstDataQueueSize *level);
Get the current level of the queue.
| 
 | The GstDataQueue | 
| 
 | the location to store the result | 
void gst_data_queue_limits_changed (GstDataQueue *queue);
Inform the queue that the limits for the fullness check have changed and that
any blocking gst_data_queue_push() should be unblocked to recheck the limts.
| 
 | The GstDataQueue |