gstreamer/gst/gstmessage.h

166 lines
6.1 KiB
C
Raw Normal View History

/* GStreamer
* Copyright (C) 2004 Wim Taymans <wim@fluendo.com>
*
* gstmessage.h: Header for GstMessage subsystem
*
* 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_MESSAGE_H__
#define __GST_MESSAGE_H__
#include <gst/gsttypes.h>
#include <gst/gstdata.h>
#include <gst/gstobject.h>
#include <gst/gsttag.h>
#include <gst/gststructure.h>
Add sink base class to abstract locking and preroll. Original commit message from CVS: * configure.ac: * docs/design/part-states.txt: * gst/Makefile.am: * gst/base/Makefile.am: * gst/base/gstbasesink.c: (gst_basesink_get_template), (gst_basesink_base_init), (gst_basesink_class_init), (gst_basesink_init), (gst_basesink_set_pad_functions), (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock), (gst_basesink_set_property), (gst_basesink_get_property), (gst_base_sink_get_template), (gst_base_sink_get_caps), (gst_base_sink_set_caps), (gst_base_sink_alloc_buffer), (gst_basesink_finish_preroll), (gst_basesink_event), (gst_basesink_chain_unlocked), (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate), (gst_basesink_change_state): * gst/base/gstbasesink.h: * gst/elements/Makefile.am: * gst/elements/gstfakesink.c: (gst_fakesink_base_init), (gst_fakesink_class_init), (gst_fakesink_init), (gst_fakesink_set_property), (gst_fakesink_get_property), (gst_fakesink_event), (gst_fakesink_preroll), (gst_fakesink_render), (gst_fakesink_change_state): * gst/elements/gstfakesink.h: * gst/gstelement.c: (gst_element_get_random_pad): * gst/gstevent.h: * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new), (gst_list_iterator_next), (gst_list_iterator_free), (gst_iterator_new_list), (gst_iterator_pop), (gst_iterator_next), (gst_iterator_push), (filter_next): * gst/gstmessage.h: * gst/gsttrashstack.h: Add sink base class to abstract locking and preroll. Make fakesink use the base class. Some doc fixes. Fix missing breaks.
2005-02-23 11:22:43 +00:00
G_BEGIN_DECLS
Add sink base class to abstract locking and preroll. Original commit message from CVS: * configure.ac: * docs/design/part-states.txt: * gst/Makefile.am: * gst/base/Makefile.am: * gst/base/gstbasesink.c: (gst_basesink_get_template), (gst_basesink_base_init), (gst_basesink_class_init), (gst_basesink_init), (gst_basesink_set_pad_functions), (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock), (gst_basesink_set_property), (gst_basesink_get_property), (gst_base_sink_get_template), (gst_base_sink_get_caps), (gst_base_sink_set_caps), (gst_base_sink_alloc_buffer), (gst_basesink_finish_preroll), (gst_basesink_event), (gst_basesink_chain_unlocked), (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate), (gst_basesink_change_state): * gst/base/gstbasesink.h: * gst/elements/Makefile.am: * gst/elements/gstfakesink.c: (gst_fakesink_base_init), (gst_fakesink_class_init), (gst_fakesink_init), (gst_fakesink_set_property), (gst_fakesink_get_property), (gst_fakesink_event), (gst_fakesink_preroll), (gst_fakesink_render), (gst_fakesink_change_state): * gst/elements/gstfakesink.h: * gst/gstelement.c: (gst_element_get_random_pad): * gst/gstevent.h: * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new), (gst_list_iterator_next), (gst_list_iterator_free), (gst_iterator_new_list), (gst_iterator_pop), (gst_iterator_next), (gst_iterator_push), (filter_next): * gst/gstmessage.h: * gst/gsttrashstack.h: Add sink base class to abstract locking and preroll. Make fakesink use the base class. Some doc fixes. Fix missing breaks.
2005-02-23 11:22:43 +00:00
GST_EXPORT GType _gst_message_type;
/**
* GstMessageType:
* @GST_MESSAGE_UNKNOWN: an undefined message
* @GST_MESSAGE_EOS: end-of-stream reached in a pipeline
* @GST_MESSAGE_ERROR: an error occured
* @GST_MESSAGE_WARNING: a warning occured.
* @GST_MESSAGE_INFO: an info message occured
* @GST_MESSAGE_TAG: a tag was found.
* @GST_MESSAGE_BUFFERING: the pipeline is buffering
* @GST_MESSAGE_STATE_CHANGED: a state change happened
* @GST_MESSAGE_STEP_DONE: a framestep finished.
* @GST_MESSAGE_NEW_CLOCK: a new clock was selected in the pipeline
* @GST_MESSAGE_STRUCTURE_CHANGE: the structure of the pipeline changed.
* @GST_MESSAGE_STREAM_STATUS: status about a stream, emited when it starts,
* stops, errors, etc..
* @GST_MESSAGE_APPLICATION: message posted by the application, possibly
* via an application-specific element.
Add sink base class to abstract locking and preroll. Original commit message from CVS: * configure.ac: * docs/design/part-states.txt: * gst/Makefile.am: * gst/base/Makefile.am: * gst/base/gstbasesink.c: (gst_basesink_get_template), (gst_basesink_base_init), (gst_basesink_class_init), (gst_basesink_init), (gst_basesink_set_pad_functions), (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock), (gst_basesink_set_property), (gst_basesink_get_property), (gst_base_sink_get_template), (gst_base_sink_get_caps), (gst_base_sink_set_caps), (gst_base_sink_alloc_buffer), (gst_basesink_finish_preroll), (gst_basesink_event), (gst_basesink_chain_unlocked), (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate), (gst_basesink_change_state): * gst/base/gstbasesink.h: * gst/elements/Makefile.am: * gst/elements/gstfakesink.c: (gst_fakesink_base_init), (gst_fakesink_class_init), (gst_fakesink_init), (gst_fakesink_set_property), (gst_fakesink_get_property), (gst_fakesink_event), (gst_fakesink_preroll), (gst_fakesink_render), (gst_fakesink_change_state): * gst/elements/gstfakesink.h: * gst/gstelement.c: (gst_element_get_random_pad): * gst/gstevent.h: * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new), (gst_list_iterator_next), (gst_list_iterator_free), (gst_iterator_new_list), (gst_iterator_pop), (gst_iterator_next), (gst_iterator_push), (filter_next): * gst/gstmessage.h: * gst/gsttrashstack.h: Add sink base class to abstract locking and preroll. Make fakesink use the base class. Some doc fixes. Fix missing breaks.
2005-02-23 11:22:43 +00:00
* @GST_MESSAGE_ANY: mask for all of the above messages.
*/
typedef enum
{
Add sink base class to abstract locking and preroll. Original commit message from CVS: * configure.ac: * docs/design/part-states.txt: * gst/Makefile.am: * gst/base/Makefile.am: * gst/base/gstbasesink.c: (gst_basesink_get_template), (gst_basesink_base_init), (gst_basesink_class_init), (gst_basesink_init), (gst_basesink_set_pad_functions), (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock), (gst_basesink_set_property), (gst_basesink_get_property), (gst_base_sink_get_template), (gst_base_sink_get_caps), (gst_base_sink_set_caps), (gst_base_sink_alloc_buffer), (gst_basesink_finish_preroll), (gst_basesink_event), (gst_basesink_chain_unlocked), (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate), (gst_basesink_change_state): * gst/base/gstbasesink.h: * gst/elements/Makefile.am: * gst/elements/gstfakesink.c: (gst_fakesink_base_init), (gst_fakesink_class_init), (gst_fakesink_init), (gst_fakesink_set_property), (gst_fakesink_get_property), (gst_fakesink_event), (gst_fakesink_preroll), (gst_fakesink_render), (gst_fakesink_change_state): * gst/elements/gstfakesink.h: * gst/gstelement.c: (gst_element_get_random_pad): * gst/gstevent.h: * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new), (gst_list_iterator_next), (gst_list_iterator_free), (gst_iterator_new_list), (gst_iterator_pop), (gst_iterator_next), (gst_iterator_push), (filter_next): * gst/gstmessage.h: * gst/gsttrashstack.h: Add sink base class to abstract locking and preroll. Make fakesink use the base class. Some doc fixes. Fix missing breaks.
2005-02-23 11:22:43 +00:00
GST_MESSAGE_UNKNOWN = 0,
GST_MESSAGE_EOS = (1 << 0),
GST_MESSAGE_ERROR = (1 << 1),
GST_MESSAGE_WARNING = (1 << 2),
GST_MESSAGE_INFO = (1 << 3),
GST_MESSAGE_TAG = (1 << 4),
GST_MESSAGE_BUFFERING = (1 << 5),
GST_MESSAGE_STATE_CHANGED = (1 << 6),
GST_MESSAGE_STEP_DONE = (1 << 7),
GST_MESSAGE_NEW_CLOCK = (1 << 8),
GST_MESSAGE_STRUCTURE_CHANGE = (1 << 9),
GST_MESSAGE_STREAM_STATUS = (1 << 10),
GST_MESSAGE_APPLICATION = (1 << 11),
Add sink base class to abstract locking and preroll. Original commit message from CVS: * configure.ac: * docs/design/part-states.txt: * gst/Makefile.am: * gst/base/Makefile.am: * gst/base/gstbasesink.c: (gst_basesink_get_template), (gst_basesink_base_init), (gst_basesink_class_init), (gst_basesink_init), (gst_basesink_set_pad_functions), (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock), (gst_basesink_set_property), (gst_basesink_get_property), (gst_base_sink_get_template), (gst_base_sink_get_caps), (gst_base_sink_set_caps), (gst_base_sink_alloc_buffer), (gst_basesink_finish_preroll), (gst_basesink_event), (gst_basesink_chain_unlocked), (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate), (gst_basesink_change_state): * gst/base/gstbasesink.h: * gst/elements/Makefile.am: * gst/elements/gstfakesink.c: (gst_fakesink_base_init), (gst_fakesink_class_init), (gst_fakesink_init), (gst_fakesink_set_property), (gst_fakesink_get_property), (gst_fakesink_event), (gst_fakesink_preroll), (gst_fakesink_render), (gst_fakesink_change_state): * gst/elements/gstfakesink.h: * gst/gstelement.c: (gst_element_get_random_pad): * gst/gstevent.h: * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new), (gst_list_iterator_next), (gst_list_iterator_free), (gst_iterator_new_list), (gst_iterator_pop), (gst_iterator_next), (gst_iterator_push), (filter_next): * gst/gstmessage.h: * gst/gsttrashstack.h: Add sink base class to abstract locking and preroll. Make fakesink use the base class. Some doc fixes. Fix missing breaks.
2005-02-23 11:22:43 +00:00
GST_MESSAGE_ANY = 0xffffffff
} GstMessageType;
#define GST_MESSAGE_TRACE_NAME "GstMessage"
#define GST_TYPE_MESSAGE (_gst_message_type)
#define GST_MESSAGE(message) ((GstMessage*)(message))
#define GST_IS_MESSAGE(message) (GST_DATA_TYPE(message) == GST_TYPE_MESSAGE)
Add sink base class to abstract locking and preroll. Original commit message from CVS: * configure.ac: * docs/design/part-states.txt: * gst/Makefile.am: * gst/base/Makefile.am: * gst/base/gstbasesink.c: (gst_basesink_get_template), (gst_basesink_base_init), (gst_basesink_class_init), (gst_basesink_init), (gst_basesink_set_pad_functions), (gst_basesink_set_all_pad_functions), (gst_basesink_set_clock), (gst_basesink_set_property), (gst_basesink_get_property), (gst_base_sink_get_template), (gst_base_sink_get_caps), (gst_base_sink_set_caps), (gst_base_sink_alloc_buffer), (gst_basesink_finish_preroll), (gst_basesink_event), (gst_basesink_chain_unlocked), (gst_basesink_chain), (gst_basesink_loop), (gst_basesink_activate), (gst_basesink_change_state): * gst/base/gstbasesink.h: * gst/elements/Makefile.am: * gst/elements/gstfakesink.c: (gst_fakesink_base_init), (gst_fakesink_class_init), (gst_fakesink_init), (gst_fakesink_set_property), (gst_fakesink_get_property), (gst_fakesink_event), (gst_fakesink_preroll), (gst_fakesink_render), (gst_fakesink_change_state): * gst/elements/gstfakesink.h: * gst/gstelement.c: (gst_element_get_random_pad): * gst/gstevent.h: * gst/gstiterator.c: (gst_iterator_init), (gst_iterator_new), (gst_list_iterator_next), (gst_list_iterator_free), (gst_iterator_new_list), (gst_iterator_pop), (gst_iterator_next), (gst_iterator_push), (filter_next): * gst/gstmessage.h: * gst/gsttrashstack.h: Add sink base class to abstract locking and preroll. Make fakesink use the base class. Some doc fixes. Fix missing breaks.
2005-02-23 11:22:43 +00:00
/* the lock is used to handle the synchronous handling of messages,
* the emiting thread is block until the handling thread processed
* the message using this mutex/cond pair */
#define GST_MESSAGE_GET_LOCK(message) (GST_MESSAGE(message)->lock)
#define GST_MESSAGE_LOCK(message) g_mutex_lock(GST_MESSAGE_GET_LOCK(message))
#define GST_MESSAGE_UNLOCK(message) g_mutex_unlock(GST_MESSAGE_GET_LOCK(message))
#define GST_MESSAGE_COND(message) (GST_MESSAGE(message)->cond)
#define GST_MESSAGE_WAIT(message) g_cond_wait(GST_MESSAGE_COND(message),GST_MESSAGE_GET_LOCK(message))
#define GST_MESSAGE_SIGNAL(message) g_cond_signal(GST_MESSAGE_COND(message))
#define GST_MESSAGE_TYPE(message) (GST_MESSAGE(message)->type)
#define GST_MESSAGE_TIMESTAMP(message) (GST_MESSAGE(message)->timestamp)
#define GST_MESSAGE_SRC(message) (GST_MESSAGE(message)->src)
#define GST_MESSAGE_TAG_LIST(message) (GST_MESSAGE(message)->message_data.tag.list)
gst/gstmessage.h (GstMessageType): Turned into flags. Added Original commit message from CVS: 2005-02-21 Andy Wingo <wingo@pobox.com> * gst/gstmessage.h (GstMessageType): Turned into flags. Added GST_MESSAGE_ANY as an OR of all flags. (GST_MESSAGE_PARSE_STATE_CHANGED): New terrible macro. Will be made into a function soon. (GstMessage): Add a state_changed structure to the union. The union will die soon in favor of a single GstStructure tho. (gst_message_new_state_changed): New API. * gst/gstmessage.c (gst_message_new_state_changed): New API. * tools/gst-launch.c (check_intr): Set the state of the pipeline to PAUSED here; the poll will catch the state change. (event_loop): New function, polls the pipeline bus for events. Can block until eos/error/state change, or just handle the pending events. (main): Changed to use event_loop instead of running a main loop. * gst/gstbus.h (gst_bus_poll): Added. (gst_bus_peek): Return non-const; the message is refcounted anyway. * gst/gstbus.c (gst_bus_init): Replace the GAsyncQueue with a GQueue+mutex to allow for _peek. (The wake-up functionality provided by GAsyncQueue is already done by our socketpair.) All queue users changed to lock, operate, and unlock. (gst_bus_post): Check the retval of write(2) and handle errno. (gst_bus_peek): Implemented. (gst_bus_pop, gst_bus_peek, bus_callback): Because the socketpair is used to wake up the GSource, read off the character in the GSource handler and not in pop/peek. This is because a peek will require a pop in the future, and you can't read off the char twice. Deal with errno in the read. (bus_callback): Interpret the handler return value as whether or not to pop the message from the bus. (poll_handler, poll_timeout, gst_bus_poll): New API. gst_bus_poll is meant to replace the while(gst_bin_iterate()) idiom.
2005-02-21 11:54:55 +00:00
/* this is terribly nasty cause I'm going to make these all functions soon */
#define GST_MESSAGE_PARSE_STATE_CHANGED(message, pold, pnew) G_STMT_START{ \
*pold = GST_MESSAGE(message)->message_data.state_changed.old; \
*pnew = GST_MESSAGE(message)->message_data.state_changed.new; \
}G_STMT_END
#define GST_MESSAGE_ERROR_GERROR(message) (GST_MESSAGE(message)->message_data.error.gerror)
#define GST_MESSAGE_ERROR_DEBUG(message) (GST_MESSAGE(message)->message_data.error.debug)
#define GST_MESSAGE_WARNING_GERROR(message) (GST_MESSAGE(message)->message_data.error.gerror)
#define GST_MESSAGE_WARNING_DEBUG(message) (GST_MESSAGE(message)->message_data.error.debug)
struct _GstMessage
{
GstData data;
/*< public > *//* with MESSAGE_LOCK */
GMutex *lock; /* lock and cond for async delivery */
GCond *cond;
/*< public > *//* with COW */
GstMessageType type;
guint64 timestamp;
GstObject *src;
union
{
struct
{
GError *gerror;
gchar *debug;
} error;
struct
{
GstStructure *structure;
} structure;
struct
{
GstTagList *list;
} tag;
gst/gstmessage.h (GstMessageType): Turned into flags. Added Original commit message from CVS: 2005-02-21 Andy Wingo <wingo@pobox.com> * gst/gstmessage.h (GstMessageType): Turned into flags. Added GST_MESSAGE_ANY as an OR of all flags. (GST_MESSAGE_PARSE_STATE_CHANGED): New terrible macro. Will be made into a function soon. (GstMessage): Add a state_changed structure to the union. The union will die soon in favor of a single GstStructure tho. (gst_message_new_state_changed): New API. * gst/gstmessage.c (gst_message_new_state_changed): New API. * tools/gst-launch.c (check_intr): Set the state of the pipeline to PAUSED here; the poll will catch the state change. (event_loop): New function, polls the pipeline bus for events. Can block until eos/error/state change, or just handle the pending events. (main): Changed to use event_loop instead of running a main loop. * gst/gstbus.h (gst_bus_poll): Added. (gst_bus_peek): Return non-const; the message is refcounted anyway. * gst/gstbus.c (gst_bus_init): Replace the GAsyncQueue with a GQueue+mutex to allow for _peek. (The wake-up functionality provided by GAsyncQueue is already done by our socketpair.) All queue users changed to lock, operate, and unlock. (gst_bus_post): Check the retval of write(2) and handle errno. (gst_bus_peek): Implemented. (gst_bus_pop, gst_bus_peek, bus_callback): Because the socketpair is used to wake up the GSource, read off the character in the GSource handler and not in pop/peek. This is because a peek will require a pop in the future, and you can't read off the char twice. Deal with errno in the read. (bus_callback): Interpret the handler return value as whether or not to pop the message from the bus. (poll_handler, poll_timeout, gst_bus_poll): New API. gst_bus_poll is meant to replace the while(gst_bin_iterate()) idiom.
2005-02-21 11:54:55 +00:00
struct
{
GstElementState old;
GstElementState new;
} state_changed;
} message_data;
/*< private > */
gpointer _gst_reserved[GST_PADDING];
};
void _gst_message_initialize (void);
GType gst_message_get_type (void);
GstMessage * gst_message_new (GstMessageType type, GstObject * src);
/* refcounting */
#define gst_message_ref(ev) GST_MESSAGE (gst_data_ref (GST_DATA (ev)))
#define gst_message_ref_by_count(ev,c) GST_MESSAGE (gst_data_ref_by_count (GST_DATA (ev), c))
#define gst_message_unref(ev) gst_data_unref (GST_DATA (ev))
/* copy message */
#define gst_message_copy(ev) GST_MESSAGE (gst_data_copy (GST_DATA (ev)))
GstMessage * gst_message_new_eos (GstObject * src);
GstMessage * gst_message_new_error (GstObject * src, GError * error, gchar * debug);
GstMessage * gst_message_new_warning (GstObject * src, GError * error, gchar * debug);
GstMessage * gst_message_new_tag (GstObject * src, GstTagList * tag_list);
gst/gstmessage.h (GstMessageType): Turned into flags. Added Original commit message from CVS: 2005-02-21 Andy Wingo <wingo@pobox.com> * gst/gstmessage.h (GstMessageType): Turned into flags. Added GST_MESSAGE_ANY as an OR of all flags. (GST_MESSAGE_PARSE_STATE_CHANGED): New terrible macro. Will be made into a function soon. (GstMessage): Add a state_changed structure to the union. The union will die soon in favor of a single GstStructure tho. (gst_message_new_state_changed): New API. * gst/gstmessage.c (gst_message_new_state_changed): New API. * tools/gst-launch.c (check_intr): Set the state of the pipeline to PAUSED here; the poll will catch the state change. (event_loop): New function, polls the pipeline bus for events. Can block until eos/error/state change, or just handle the pending events. (main): Changed to use event_loop instead of running a main loop. * gst/gstbus.h (gst_bus_poll): Added. (gst_bus_peek): Return non-const; the message is refcounted anyway. * gst/gstbus.c (gst_bus_init): Replace the GAsyncQueue with a GQueue+mutex to allow for _peek. (The wake-up functionality provided by GAsyncQueue is already done by our socketpair.) All queue users changed to lock, operate, and unlock. (gst_bus_post): Check the retval of write(2) and handle errno. (gst_bus_peek): Implemented. (gst_bus_pop, gst_bus_peek, bus_callback): Because the socketpair is used to wake up the GSource, read off the character in the GSource handler and not in pop/peek. This is because a peek will require a pop in the future, and you can't read off the char twice. Deal with errno in the read. (bus_callback): Interpret the handler return value as whether or not to pop the message from the bus. (poll_handler, poll_timeout, gst_bus_poll): New API. gst_bus_poll is meant to replace the while(gst_bin_iterate()) idiom.
2005-02-21 11:54:55 +00:00
GstMessage * gst_message_new_state_changed (GstObject * src, GstElementState old,
GstElementState new);
GstMessage * gst_message_new_application (GstStructure *structure);
G_END_DECLS
#endif /* __GST_MESSAGE_H__ */