aggregator: Assert if the sink/src pad type that is to be used is not a GstAggregator...
[platform/upstream/gstreamer.git] / libs / gst / base / gstpushsrc.h
1 /* GStreamer
2  * Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
3  *                    2000 Wim Taymans <wtay@chello.be>
4  *                    2005 Wim Taymans <wim@fluendo.com>
5  *
6  * gstpushsrc.h:
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Library General Public
10  * License as published by the Free Software Foundation; either
11  * version 2 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Library General Public License for more details.
17  *
18  * You should have received a copy of the GNU Library General Public
19  * License along with this library; if not, write to the
20  * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
21  * Boston, MA 02110-1301, USA.
22  */
23
24 #ifndef __GST_PUSH_SRC_H__
25 #define __GST_PUSH_SRC_H__
26
27 #include <gst/gst.h>
28 #include <gst/base/gstbasesrc.h>
29
30 G_BEGIN_DECLS
31
32 #define GST_TYPE_PUSH_SRC               (gst_push_src_get_type())
33 #define GST_PUSH_SRC(obj)               (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_PUSH_SRC,GstPushSrc))
34 #define GST_PUSH_SRC_CLASS(klass)       (G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_PUSH_SRC,GstPushSrcClass))
35 #define GST_PUSH_SRC_GET_CLASS(obj)      (G_TYPE_INSTANCE_GET_CLASS ((obj), GST_TYPE_PUSH_SRC, GstPushSrcClass))
36 #define GST_IS_PUSH_SRC(obj)            (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_PUSH_SRC))
37 #define GST_IS_PUSH_SRC_CLASS(klass)    (G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_PUSH_SRC))
38
39 typedef struct _GstPushSrc GstPushSrc;
40 typedef struct _GstPushSrcClass GstPushSrcClass;
41
42 /**
43  * GstPushSrc:
44  *
45  * The opaque #GstPushSrc data structure.
46  */
47 struct _GstPushSrc {
48   GstBaseSrc     parent;
49
50   /*< private >*/
51   gpointer _gst_reserved[GST_PADDING];
52 };
53
54 /**
55  * GstPushSrcClass:
56  * @parent_class: Element parent class
57  * @create: Ask the subclass to create a buffer. The subclass decides which
58  *          size this buffer should be. Other then that, refer to
59  *          #GstBaseSrc<!-- -->.create() for more details. If this method is
60  *          not implemented, @alloc followed by @fill will be called.
61  * @alloc: Ask the subclass to allocate a buffer. The subclass decides which
62  *         size this buffer should be. The default implementation will create
63  *         a new buffer from the negotiated allocator.
64  * @fill: Ask the subclass to fill the buffer with data.
65  *
66  * Subclasses can override any of the available virtual methods or not, as
67  * needed. At the minimum, the @fill method should be overridden to produce
68  * buffers.
69  */
70 struct _GstPushSrcClass {
71   GstBaseSrcClass parent_class;
72
73   /* ask the subclass to create a buffer, the default implementation
74    * uses alloc and fill */
75   GstFlowReturn (*create) (GstPushSrc *src, GstBuffer **buf);
76   /* allocate memory for a buffer */
77   GstFlowReturn (*alloc)  (GstPushSrc *src, GstBuffer **buf);
78   /* ask the subclass to fill a buffer */
79   GstFlowReturn (*fill)   (GstPushSrc *src, GstBuffer *buf);
80
81   /*< private >*/
82   gpointer _gst_reserved[GST_PADDING];
83 };
84
85 GST_BASE_API
86 GType gst_push_src_get_type (void);
87
88 #ifdef G_DEFINE_AUTOPTR_CLEANUP_FUNC
89 G_DEFINE_AUTOPTR_CLEANUP_FUNC(GstPushSrc, gst_object_unref)
90 #endif
91
92 G_END_DECLS
93
94 #endif /* __GST_PUSH_SRC_H__ */