2000-12-28 22:12:02 +00:00
|
|
|
/* GStreamer
|
|
|
|
* Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
|
|
|
|
* 2000 Wim Taymans <wtay@chello.be>
|
|
|
|
*
|
|
|
|
* gstbin.h: Header for GstBin container object
|
2000-01-30 09:03:00 +00:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __GST_BIN_H__
|
|
|
|
#define __GST_BIN_H__
|
|
|
|
|
|
|
|
#include <gst/gstelement.h>
|
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
2004-06-13 10:04:12 +00:00
|
|
|
GST_EXPORT GType _gst_bin_type;
|
2001-10-21 18:00:31 +00:00
|
|
|
|
2002-12-19 21:31:03 +00:00
|
|
|
#define GST_TYPE_BIN (_gst_bin_type)
|
|
|
|
#define GST_IS_BIN(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_BIN))
|
|
|
|
#define GST_IS_BIN_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GST_TYPE_BIN))
|
|
|
|
#define GST_BIN_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GST_TYPE_BIN, GstBinClass))
|
2003-12-13 16:58:29 +00:00
|
|
|
#define GST_BIN(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_TYPE_BIN, GstBin))
|
|
|
|
#define GST_BIN_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GST_TYPE_BIN, GstBinClass))
|
2000-01-30 09:03:00 +00:00
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
typedef enum {
|
2000-12-28 21:42:23 +00:00
|
|
|
/* this bin is a manager of child elements, i.e. a pipeline or thread */
|
2004-03-15 14:43:35 +00:00
|
|
|
GST_BIN_FLAG_MANAGER = GST_ELEMENT_FLAG_LAST,
|
2002-03-30 19:31:14 +00:00
|
|
|
|
|
|
|
/* this bin iterates itself */
|
2001-05-25 21:00:07 +00:00
|
|
|
GST_BIN_SELF_SCHEDULABLE,
|
2000-12-20 09:39:43 +00:00
|
|
|
|
2000-12-28 21:42:23 +00:00
|
|
|
/* we prefer to have cothreads when its an option, over chain-based */
|
2000-12-20 09:39:43 +00:00
|
|
|
GST_BIN_FLAG_PREFER_COTHREADS,
|
|
|
|
|
2002-02-03 20:07:09 +00:00
|
|
|
GST_BIN_FLAG_FIXED_CLOCK,
|
|
|
|
|
2000-12-20 09:39:43 +00:00
|
|
|
/* padding */
|
2004-03-15 14:43:35 +00:00
|
|
|
GST_BIN_FLAG_LAST = GST_ELEMENT_FLAG_LAST + 5
|
|
|
|
} GstBinFlags;
|
2000-12-15 01:57:34 +00:00
|
|
|
|
2001-12-15 18:15:13 +00:00
|
|
|
/*typedef struct _GstBin GstBin; */
|
|
|
|
/*typedef struct _GstBinClass GstBinClass; */
|
2000-01-30 09:03:00 +00:00
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
struct _GstBin {
|
|
|
|
GstElement element;
|
2000-01-30 09:03:00 +00:00
|
|
|
|
2000-12-28 21:42:23 +00:00
|
|
|
/* our children */
|
2004-03-15 14:43:35 +00:00
|
|
|
gint numchildren;
|
|
|
|
GList *children;
|
2000-01-30 09:03:00 +00:00
|
|
|
|
gst/gstbin.c: make state changes work correctly and reentrant (so removing elements from bins during state changes of...
Original commit message from CVS:
* gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
(gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
(gst_bin_child_state_change_func), (set_kid_state_func),
(gst_bin_set_state), (gst_bin_change_state_norecurse):
make state changes work correctly and reentrant (so removing
elements from bins during state changes of bins doesn't cause
segfaults or even wrong states)
add debugging category and debugging output to print children states
* gst/gstbin.c: (gst_bin_dispose):
add some assertion checks
* gst/gstbin.h:
* gst/gstbin.c: (gst_bin_sync_children_state):
deprecate this function - it just does gst_bin_set_state (bin,
GST_STATE (bin))
* testsuite/threads/queue.c: (main):
don't use gst_bin_sync_children_state anymore
* testsuite/states/Makefile.am:
* testsuite/states/bin.c:
test that the state changes of bins work as expected
* gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
some adjustments to change states correctly, too
* gst/gstthread.c: (gst_thread_change_state):
don't enable/disable "threadsafe" properties, they're unused and
cause random segfaults
* testsuite/threads/Makefile.am:
the queue check randomly passes now, ignore it
2004-07-21 21:28:58 +00:00
|
|
|
/* FIXME 0.9: important!! make this guint instead of GstElementState */
|
2001-12-04 22:12:50 +00:00
|
|
|
GstElementState child_states[GST_NUM_STATES];
|
2002-02-03 20:07:09 +00:00
|
|
|
|
2003-12-09 02:39:31 +00:00
|
|
|
gpointer _gst_reserved[GST_PADDING];
|
2000-01-30 09:03:00 +00:00
|
|
|
};
|
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
struct _GstBinClass {
|
2000-01-30 09:03:00 +00:00
|
|
|
GstElementClass parent_class;
|
|
|
|
|
2002-11-02 13:54:34 +00:00
|
|
|
/* vtable */
|
2004-03-15 14:43:35 +00:00
|
|
|
void (*add_element) (GstBin *bin, GstElement *element);
|
|
|
|
void (*remove_element) (GstBin *bin, GstElement *element);
|
|
|
|
void (*child_state_change) (GstBin *bin, GstElementState oldstate,
|
|
|
|
GstElementState newstate, GstElement *element);
|
2002-12-19 21:31:03 +00:00
|
|
|
|
2002-11-02 13:54:34 +00:00
|
|
|
/* run a full iteration of operation */
|
2004-03-15 14:43:35 +00:00
|
|
|
gboolean (*iterate) (GstBin *bin);
|
2002-11-02 13:54:34 +00:00
|
|
|
|
2000-12-20 09:39:43 +00:00
|
|
|
/* signals */
|
2004-03-15 14:43:35 +00:00
|
|
|
void (*element_added) (GstBin *bin, GstElement *child);
|
|
|
|
void (*element_removed) (GstBin *bin, GstElement *child);
|
2000-01-30 09:03:00 +00:00
|
|
|
|
2003-12-09 02:39:31 +00:00
|
|
|
gpointer _gst_reserved[GST_PADDING];
|
2000-01-30 09:03:00 +00:00
|
|
|
};
|
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
GType gst_bin_get_type (void);
|
|
|
|
GstElement* gst_bin_new (const gchar *name);
|
2000-01-30 09:03:00 +00:00
|
|
|
|
|
|
|
/* add and remove elements from the bin */
|
2004-03-15 14:43:35 +00:00
|
|
|
void gst_bin_add (GstBin *bin, GstElement *element);
|
|
|
|
void gst_bin_add_many (GstBin *bin, GstElement *element_1, ...);
|
|
|
|
void gst_bin_remove (GstBin *bin, GstElement *element);
|
|
|
|
void gst_bin_remove_many (GstBin *bin, GstElement *element_1, ...);
|
2001-01-13 13:51:08 +00:00
|
|
|
|
2000-11-04 18:54:07 +00:00
|
|
|
/* retrieve a single element or the list of children */
|
2004-03-15 14:43:35 +00:00
|
|
|
GstElement* gst_bin_get_by_name (GstBin *bin, const gchar *name);
|
|
|
|
GstElement* gst_bin_get_by_name_recurse_up (GstBin *bin, const gchar *name);
|
|
|
|
G_CONST_RETURN GList*
|
|
|
|
gst_bin_get_list (GstBin *bin);
|
|
|
|
GstElement* gst_bin_get_by_interface (GstBin *bin, GType interface);
|
|
|
|
GList * gst_bin_get_all_by_interface (GstBin *bin, GType interface);
|
2000-01-30 09:03:00 +00:00
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
gboolean gst_bin_iterate (GstBin *bin);
|
2000-01-30 09:03:00 +00:00
|
|
|
|
2004-03-15 14:43:35 +00:00
|
|
|
void gst_bin_use_clock (GstBin *bin, GstClock *clock);
|
|
|
|
GstClock* gst_bin_get_clock (GstBin *bin);
|
|
|
|
void gst_bin_auto_clock (GstBin *bin);
|
2002-02-03 20:07:09 +00:00
|
|
|
|
gst/gstbin.c: make state changes work correctly and reentrant (so removing elements from bins during state changes of...
Original commit message from CVS:
* gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
(gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
(gst_bin_child_state_change_func), (set_kid_state_func),
(gst_bin_set_state), (gst_bin_change_state_norecurse):
make state changes work correctly and reentrant (so removing
elements from bins during state changes of bins doesn't cause
segfaults or even wrong states)
add debugging category and debugging output to print children states
* gst/gstbin.c: (gst_bin_dispose):
add some assertion checks
* gst/gstbin.h:
* gst/gstbin.c: (gst_bin_sync_children_state):
deprecate this function - it just does gst_bin_set_state (bin,
GST_STATE (bin))
* testsuite/threads/queue.c: (main):
don't use gst_bin_sync_children_state anymore
* testsuite/states/Makefile.am:
* testsuite/states/bin.c:
test that the state changes of bins work as expected
* gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
some adjustments to change states correctly, too
* gst/gstthread.c: (gst_thread_change_state):
don't enable/disable "threadsafe" properties, they're unused and
cause random segfaults
* testsuite/threads/Makefile.am:
the queue check randomly passes now, ignore it
2004-07-21 21:28:58 +00:00
|
|
|
#ifndef GST_DISABLE_DEPRECATED
|
2004-03-15 14:43:35 +00:00
|
|
|
GstElementStateReturn gst_bin_sync_children_state (GstBin *bin);
|
gst/gstbin.c: make state changes work correctly and reentrant (so removing elements from bins during state changes of...
Original commit message from CVS:
* gst/gstbin.c: (gst_bin_get_type), (gst_bin_class_init),
(gst_bin_fix_state), (gst_bin_add_func), (gst_bin_remove_func),
(gst_bin_child_state_change_func), (set_kid_state_func),
(gst_bin_set_state), (gst_bin_change_state_norecurse):
make state changes work correctly and reentrant (so removing
elements from bins during state changes of bins doesn't cause
segfaults or even wrong states)
add debugging category and debugging output to print children states
* gst/gstbin.c: (gst_bin_dispose):
add some assertion checks
* gst/gstbin.h:
* gst/gstbin.c: (gst_bin_sync_children_state):
deprecate this function - it just does gst_bin_set_state (bin,
GST_STATE (bin))
* testsuite/threads/queue.c: (main):
don't use gst_bin_sync_children_state anymore
* testsuite/states/Makefile.am:
* testsuite/states/bin.c:
test that the state changes of bins work as expected
* gst/gstthread.c: (gst_thread_class_init), (gst_thread_set_state):
some adjustments to change states correctly, too
* gst/gstthread.c: (gst_thread_change_state):
don't enable/disable "threadsafe" properties, they're unused and
cause random segfaults
* testsuite/threads/Makefile.am:
the queue check randomly passes now, ignore it
2004-07-21 21:28:58 +00:00
|
|
|
#endif
|
2003-04-18 23:34:21 +00:00
|
|
|
|
2001-12-20 20:03:10 +00:00
|
|
|
/* internal */
|
2002-02-03 20:07:09 +00:00
|
|
|
/* one of our childs signaled a state change */
|
2004-03-15 14:43:35 +00:00
|
|
|
void gst_bin_child_state_change (GstBin *bin, GstElementState oldstate,
|
|
|
|
GstElementState newstate, GstElement *child);
|
2002-12-19 21:31:03 +00:00
|
|
|
|
2002-07-08 19:07:30 +00:00
|
|
|
G_END_DECLS
|
2004-03-15 14:43:35 +00:00
|
|
|
|
|
|
|
|
2001-01-20 03:10:44 +00:00
|
|
|
#endif /* __GST_BIN_H__ */
|