gst/base/gstbasesink.c: Add the beginning of docs here -- have to work on something else now tho...

Original commit message from CVS:
2005-11-09  Andy Wingo  <wingo@pobox.com>

* gst/base/gstbasesink.c: Add the beginning of docs here -- have
to work on something else now tho...
This commit is contained in:
Andy Wingo 2005-11-09 10:06:30 +00:00
parent 0ae7675f7e
commit 179f6c4f3b
3 changed files with 95 additions and 20 deletions

View file

@ -1,5 +1,8 @@
2005-11-09 Andy Wingo <wingo@pobox.com> 2005-11-09 Andy Wingo <wingo@pobox.com>
* gst/base/gstbasesink.c: Add the beginning of docs here -- have
to work on something else now tho...
* gst/base/gstadapter.c: More adapter docs. * gst/base/gstadapter.c: More adapter docs.
* gst/elements/gstfilesink.c (gst_file_sink_start) * gst/elements/gstfilesink.c (gst_file_sink_start)

View file

@ -1,7 +1,7 @@
/* GStreamer /* GStreamer
* Copyright (C) 2005 Wim Taymans <wim@fluendo.com> * Copyright (C) 2005 Wim Taymans <wim@fluendo.com>
* *
* gstbasesink.c: * gstbasesink.c: Base class for sink elements
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public * modify it under the terms of the GNU Library General Public
@ -24,16 +24,52 @@
* @short_description: Base class for sink elements * @short_description: Base class for sink elements
* @see_also: #GstBaseTransform, #GstBaseSource * @see_also: #GstBaseTransform, #GstBaseSource
* *
* This class is for elements that do output operations. * GstBaseSink is the base class for sink elements in GStreamer, such as
* xvimagesink or filesink. It is a layer on top of #GstElement that provides a
* simplified interface to plugin writers. GstBaseSink handles many details for
* you, for example preroll, clock synchronization, state changes, activation in
* push or pull mode, and queries. In most cases, when writing sink elements,
* there is no need to implement class methods from #GstElement or to set
* functions on pads, because the GstBaseSink infrastructure is sufficient.
* *
* <itemizedlist> * There is only support in GstBaseSink for one sink pad, which should be named
* <listitem><para>one sinkpad</para></listitem> * "sink". A sink implementation (subclass of GstBaseSink) should install a pad
* <listitem><para>handles state changes</para></listitem> * template in its base_init function, like so:
* <listitem><para>pull/push mode</para></listitem> * <programlisting>
* <listitem><para>handles seeking/query</para></listitem> * static void
* <listitem><para>handles preroll</para></listitem> * my_element_base_init (gpointer g_class)
* <listitem><para>EOS handling</para></listitem> * {
* </itemizedlist> * GstElementClass *gstelement_class = GST_ELEMENT_CLASS (g_class);
*
* // sinktemplate should be a #GstStaticPadTemplate with direction
* // #GST_PAD_SINK and name "sink"
* gst_element_class_add_pad_template (gstelement_class,
* gst_static_pad_template_get (&amp;sinktemplate));
* // see #GstElementDetails
* gst_element_class_set_details (gstelement_class, &amp;details);
* }
* </programlisting>
*
* The one method which all subclasses of GstBaseSink must implement is
* GstBaseSink::render. This method will be called...
*
* preroll()
*
* event(): mostly useful for file-like sinks (seeking or flushing)
*
* get_caps/set_caps/buffer_alloc
*
* start/stop for resource allocation
*
* unlock if you block on an fd, for example
*
* get_times i'm sure is for something :P
*
* provide example of textsink
*
* admonishment not to try to implement your own sink with prerolling...
*
* extending via subclassing, setting pad functions, gstelement vmethods.
*/ */
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H

View file

@ -1,7 +1,7 @@
/* GStreamer /* GStreamer
* Copyright (C) 2005 Wim Taymans <wim@fluendo.com> * Copyright (C) 2005 Wim Taymans <wim@fluendo.com>
* *
* gstbasesink.c: * gstbasesink.c: Base class for sink elements
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public * modify it under the terms of the GNU Library General Public
@ -24,16 +24,52 @@
* @short_description: Base class for sink elements * @short_description: Base class for sink elements
* @see_also: #GstBaseTransform, #GstBaseSource * @see_also: #GstBaseTransform, #GstBaseSource
* *
* This class is for elements that do output operations. * GstBaseSink is the base class for sink elements in GStreamer, such as
* xvimagesink or filesink. It is a layer on top of #GstElement that provides a
* simplified interface to plugin writers. GstBaseSink handles many details for
* you, for example preroll, clock synchronization, state changes, activation in
* push or pull mode, and queries. In most cases, when writing sink elements,
* there is no need to implement class methods from #GstElement or to set
* functions on pads, because the GstBaseSink infrastructure is sufficient.
* *
* <itemizedlist> * There is only support in GstBaseSink for one sink pad, which should be named
* <listitem><para>one sinkpad</para></listitem> * "sink". A sink implementation (subclass of GstBaseSink) should install a pad
* <listitem><para>handles state changes</para></listitem> * template in its base_init function, like so:
* <listitem><para>pull/push mode</para></listitem> * <programlisting>
* <listitem><para>handles seeking/query</para></listitem> * static void
* <listitem><para>handles preroll</para></listitem> * my_element_base_init (gpointer g_class)
* <listitem><para>EOS handling</para></listitem> * {
* </itemizedlist> * GstElementClass *gstelement_class = GST_ELEMENT_CLASS (g_class);
*
* // sinktemplate should be a #GstStaticPadTemplate with direction
* // #GST_PAD_SINK and name "sink"
* gst_element_class_add_pad_template (gstelement_class,
* gst_static_pad_template_get (&amp;sinktemplate));
* // see #GstElementDetails
* gst_element_class_set_details (gstelement_class, &amp;details);
* }
* </programlisting>
*
* The one method which all subclasses of GstBaseSink must implement is
* GstBaseSink::render. This method will be called...
*
* preroll()
*
* event(): mostly useful for file-like sinks (seeking or flushing)
*
* get_caps/set_caps/buffer_alloc
*
* start/stop for resource allocation
*
* unlock if you block on an fd, for example
*
* get_times i'm sure is for something :P
*
* provide example of textsink
*
* admonishment not to try to implement your own sink with prerolling...
*
* extending via subclassing, setting pad functions, gstelement vmethods.
*/ */
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H